diff options
1367 files changed, 37161 insertions, 19278 deletions
| @@ -1856,7 +1856,7 @@ E: rfkoenig@immd4.informatik.uni-erlangen.de | |||
| 1856 | D: The Linux Support Team Erlangen | 1856 | D: The Linux Support Team Erlangen |
| 1857 | 1857 | ||
| 1858 | N: Andreas Koensgen | 1858 | N: Andreas Koensgen |
| 1859 | E: ajk@iehk.rwth-aachen.de | 1859 | E: ajk@comnets.uni-bremen.de |
| 1860 | D: 6pack driver for AX.25 | 1860 | D: 6pack driver for AX.25 |
| 1861 | 1861 | ||
| 1862 | N: Harald Koerfgen | 1862 | N: Harald Koerfgen |
| @@ -2006,6 +2006,9 @@ E: paul@laufernet.com | |||
| 2006 | D: Soundblaster driver fixes, ISAPnP quirk | 2006 | D: Soundblaster driver fixes, ISAPnP quirk |
| 2007 | S: California, USA | 2007 | S: California, USA |
| 2008 | 2008 | ||
| 2009 | N: Jonathan Layes | ||
| 2010 | D: ARPD support | ||
| 2011 | |||
| 2009 | N: Tom Lees | 2012 | N: Tom Lees |
| 2010 | E: tom@lpsg.demon.co.uk | 2013 | E: tom@lpsg.demon.co.uk |
| 2011 | W: http://www.lpsg.demon.co.uk/ | 2014 | W: http://www.lpsg.demon.co.uk/ |
| @@ -3802,6 +3805,9 @@ S: van Bronckhorststraat 12 | |||
| 3802 | S: 2612 XV Delft | 3805 | S: 2612 XV Delft |
| 3803 | S: The Netherlands | 3806 | S: The Netherlands |
| 3804 | 3807 | ||
| 3808 | N: Thomas Woller | ||
| 3809 | D: CS461x Cirrus Logic sound driver | ||
| 3810 | |||
| 3805 | N: David Woodhouse | 3811 | N: David Woodhouse |
| 3806 | E: dwmw2@infradead.org | 3812 | E: dwmw2@infradead.org |
| 3807 | D: JFFS2 file system, Memory Technology Device subsystem, | 3813 | D: JFFS2 file system, Memory Technology Device subsystem, |
diff --git a/Documentation/ABI/testing/sysfs-block b/Documentation/ABI/testing/sysfs-block index cbbd3e069945..5f3bedaf8e35 100644 --- a/Documentation/ABI/testing/sysfs-block +++ b/Documentation/ABI/testing/sysfs-block | |||
| @@ -94,28 +94,37 @@ What: /sys/block/<disk>/queue/physical_block_size | |||
| 94 | Date: May 2009 | 94 | Date: May 2009 |
| 95 | Contact: Martin K. Petersen <martin.petersen@oracle.com> | 95 | Contact: Martin K. Petersen <martin.petersen@oracle.com> |
| 96 | Description: | 96 | Description: |
| 97 | This is the smallest unit the storage device can write | 97 | This is the smallest unit a physical storage device can |
| 98 | without resorting to read-modify-write operation. It is | 98 | write atomically. It is usually the same as the logical |
| 99 | usually the same as the logical block size but may be | 99 | block size but may be bigger. One example is SATA |
| 100 | bigger. One example is SATA drives with 4KB sectors | 100 | drives with 4KB sectors that expose a 512-byte logical |
| 101 | that expose a 512-byte logical block size to the | 101 | block size to the operating system. For stacked block |
| 102 | operating system. | 102 | devices the physical_block_size variable contains the |
| 103 | maximum physical_block_size of the component devices. | ||
| 103 | 104 | ||
| 104 | What: /sys/block/<disk>/queue/minimum_io_size | 105 | What: /sys/block/<disk>/queue/minimum_io_size |
| 105 | Date: April 2009 | 106 | Date: April 2009 |
| 106 | Contact: Martin K. Petersen <martin.petersen@oracle.com> | 107 | Contact: Martin K. Petersen <martin.petersen@oracle.com> |
| 107 | Description: | 108 | Description: |
| 108 | Storage devices may report a preferred minimum I/O size, | 109 | Storage devices may report a granularity or preferred |
| 109 | which is the smallest request the device can perform | 110 | minimum I/O size which is the smallest request the |
| 110 | without incurring a read-modify-write penalty. For disk | 111 | device can perform without incurring a performance |
| 111 | drives this is often the physical block size. For RAID | 112 | penalty. For disk drives this is often the physical |
| 112 | arrays it is often the stripe chunk size. | 113 | block size. For RAID arrays it is often the stripe |
| 114 | chunk size. A properly aligned multiple of | ||
| 115 | minimum_io_size is the preferred request size for | ||
| 116 | workloads where a high number of I/O operations is | ||
| 117 | desired. | ||
| 113 | 118 | ||
| 114 | What: /sys/block/<disk>/queue/optimal_io_size | 119 | What: /sys/block/<disk>/queue/optimal_io_size |
| 115 | Date: April 2009 | 120 | Date: April 2009 |
| 116 | Contact: Martin K. Petersen <martin.petersen@oracle.com> | 121 | Contact: Martin K. Petersen <martin.petersen@oracle.com> |
| 117 | Description: | 122 | Description: |
| 118 | Storage devices may report an optimal I/O size, which is | 123 | Storage devices may report an optimal I/O size, which is |
| 119 | the device's preferred unit of receiving I/O. This is | 124 | the device's preferred unit for sustained I/O. This is |
| 120 | rarely reported for disk drives. For RAID devices it is | 125 | rarely reported for disk drives. For RAID arrays it is |
| 121 | usually the stripe width or the internal block size. | 126 | usually the stripe width or the internal track size. A |
| 127 | properly aligned multiple of optimal_io_size is the | ||
| 128 | preferred request size for workloads where sustained | ||
| 129 | throughput is desired. If no optimal I/O size is | ||
| 130 | reported this file contains 0. | ||
diff --git a/Documentation/DocBook/kernel-hacking.tmpl b/Documentation/DocBook/kernel-hacking.tmpl index a50d6cd58573..992e67e6be7f 100644 --- a/Documentation/DocBook/kernel-hacking.tmpl +++ b/Documentation/DocBook/kernel-hacking.tmpl | |||
| @@ -449,8 +449,8 @@ printk(KERN_INFO "i = %u\n", i); | |||
| 449 | </para> | 449 | </para> |
| 450 | 450 | ||
| 451 | <programlisting> | 451 | <programlisting> |
| 452 | __u32 ipaddress; | 452 | __be32 ipaddress; |
| 453 | printk(KERN_INFO "my ip: %d.%d.%d.%d\n", NIPQUAD(ipaddress)); | 453 | printk(KERN_INFO "my ip: %pI4\n", &ipaddress); |
| 454 | </programlisting> | 454 | </programlisting> |
| 455 | 455 | ||
| 456 | <para> | 456 | <para> |
diff --git a/Documentation/RCU/rculist_nulls.txt b/Documentation/RCU/rculist_nulls.txt index 93cb28d05dcd..18f9651ff23d 100644 --- a/Documentation/RCU/rculist_nulls.txt +++ b/Documentation/RCU/rculist_nulls.txt | |||
| @@ -83,11 +83,12 @@ not detect it missed following items in original chain. | |||
| 83 | obj = kmem_cache_alloc(...); | 83 | obj = kmem_cache_alloc(...); |
| 84 | lock_chain(); // typically a spin_lock() | 84 | lock_chain(); // typically a spin_lock() |
| 85 | obj->key = key; | 85 | obj->key = key; |
| 86 | atomic_inc(&obj->refcnt); | ||
| 87 | /* | 86 | /* |
| 88 | * we need to make sure obj->key is updated before obj->next | 87 | * we need to make sure obj->key is updated before obj->next |
| 88 | * or obj->refcnt | ||
| 89 | */ | 89 | */ |
| 90 | smp_wmb(); | 90 | smp_wmb(); |
| 91 | atomic_set(&obj->refcnt, 1); | ||
| 91 | hlist_add_head_rcu(&obj->obj_node, list); | 92 | hlist_add_head_rcu(&obj->obj_node, list); |
| 92 | unlock_chain(); // typically a spin_unlock() | 93 | unlock_chain(); // typically a spin_unlock() |
| 93 | 94 | ||
| @@ -159,6 +160,10 @@ out: | |||
| 159 | obj = kmem_cache_alloc(cachep); | 160 | obj = kmem_cache_alloc(cachep); |
| 160 | lock_chain(); // typically a spin_lock() | 161 | lock_chain(); // typically a spin_lock() |
| 161 | obj->key = key; | 162 | obj->key = key; |
| 163 | /* | ||
| 164 | * changes to obj->key must be visible before refcnt one | ||
| 165 | */ | ||
| 166 | smp_wmb(); | ||
| 162 | atomic_set(&obj->refcnt, 1); | 167 | atomic_set(&obj->refcnt, 1); |
| 163 | /* | 168 | /* |
| 164 | * insert obj in RCU way (readers might be traversing chain) | 169 | * insert obj in RCU way (readers might be traversing chain) |
diff --git a/Documentation/arm/memory.txt b/Documentation/arm/memory.txt index 43cb1004d35f..9d58c7c5eddd 100644 --- a/Documentation/arm/memory.txt +++ b/Documentation/arm/memory.txt | |||
| @@ -21,6 +21,8 @@ ffff8000 ffffffff copy_user_page / clear_user_page use. | |||
| 21 | For SA11xx and Xscale, this is used to | 21 | For SA11xx and Xscale, this is used to |
| 22 | setup a minicache mapping. | 22 | setup a minicache mapping. |
| 23 | 23 | ||
| 24 | ffff4000 ffffffff cache aliasing on ARMv6 and later CPUs. | ||
| 25 | |||
| 24 | ffff1000 ffff7fff Reserved. | 26 | ffff1000 ffff7fff Reserved. |
| 25 | Platforms must not use this address range. | 27 | Platforms must not use this address range. |
| 26 | 28 | ||
diff --git a/Documentation/connector/cn_test.c b/Documentation/connector/cn_test.c index f688eba87704..6a5be5d5c8e4 100644 --- a/Documentation/connector/cn_test.c +++ b/Documentation/connector/cn_test.c | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * cn_test.c | 2 | * cn_test.c |
| 3 | * | 3 | * |
| 4 | * 2004-2005 Copyright (c) Evgeniy Polyakov <johnpol@2ka.mipt.ru> | 4 | * 2004+ Copyright (c) Evgeniy Polyakov <zbr@ioremap.net> |
| 5 | * All rights reserved. | 5 | * All rights reserved. |
| 6 | * | 6 | * |
| 7 | * This program is free software; you can redistribute it and/or modify | 7 | * This program is free software; you can redistribute it and/or modify |
| @@ -194,5 +194,5 @@ module_init(cn_test_init); | |||
| 194 | module_exit(cn_test_fini); | 194 | module_exit(cn_test_fini); |
| 195 | 195 | ||
| 196 | MODULE_LICENSE("GPL"); | 196 | MODULE_LICENSE("GPL"); |
| 197 | MODULE_AUTHOR("Evgeniy Polyakov <johnpol@2ka.mipt.ru>"); | 197 | MODULE_AUTHOR("Evgeniy Polyakov <zbr@ioremap.net>"); |
| 198 | MODULE_DESCRIPTION("Connector's test module"); | 198 | MODULE_DESCRIPTION("Connector's test module"); |
diff --git a/Documentation/connector/ucon.c b/Documentation/connector/ucon.c index d738cde2a8d5..c5092ad0ce4b 100644 --- a/Documentation/connector/ucon.c +++ b/Documentation/connector/ucon.c | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * ucon.c | 2 | * ucon.c |
| 3 | * | 3 | * |
| 4 | * Copyright (c) 2004+ Evgeniy Polyakov <johnpol@2ka.mipt.ru> | 4 | * Copyright (c) 2004+ Evgeniy Polyakov <zbr@ioremap.net> |
| 5 | * | 5 | * |
| 6 | * | 6 | * |
| 7 | * This program is free software; you can redistribute it and/or modify | 7 | * This program is free software; you can redistribute it and/or modify |
diff --git a/Documentation/filesystems/9p.txt b/Documentation/filesystems/9p.txt index bf8080640eba..6208f55c44c3 100644 --- a/Documentation/filesystems/9p.txt +++ b/Documentation/filesystems/9p.txt | |||
| @@ -123,6 +123,9 @@ available from the same CVS repository. | |||
| 123 | There are user and developer mailing lists available through the v9fs project | 123 | There are user and developer mailing lists available through the v9fs project |
| 124 | on sourceforge (http://sourceforge.net/projects/v9fs). | 124 | on sourceforge (http://sourceforge.net/projects/v9fs). |
| 125 | 125 | ||
| 126 | A stand-alone version of the module (which should build for any 2.6 kernel) | ||
| 127 | is available via (http://github.com/ericvh/9p-sac/tree/master) | ||
| 128 | |||
| 126 | News and other information is maintained on SWiK (http://swik.net/v9fs). | 129 | News and other information is maintained on SWiK (http://swik.net/v9fs). |
| 127 | 130 | ||
| 128 | Bug reports may be issued through the kernel.org bugzilla | 131 | Bug reports may be issued through the kernel.org bugzilla |
diff --git a/Documentation/filesystems/afs.txt b/Documentation/filesystems/afs.txt index 12ad6c7f4e50..ffef91c4e0d6 100644 --- a/Documentation/filesystems/afs.txt +++ b/Documentation/filesystems/afs.txt | |||
| @@ -23,15 +23,13 @@ it does support include: | |||
| 23 | 23 | ||
| 24 | (*) Security (currently only AFS kaserver and KerberosIV tickets). | 24 | (*) Security (currently only AFS kaserver and KerberosIV tickets). |
| 25 | 25 | ||
| 26 | (*) File reading. | 26 | (*) File reading and writing. |
| 27 | 27 | ||
| 28 | (*) Automounting. | 28 | (*) Automounting. |
| 29 | 29 | ||
| 30 | It does not yet support the following AFS features: | 30 | (*) Local caching (via fscache). |
| 31 | |||
| 32 | (*) Write support. | ||
| 33 | 31 | ||
| 34 | (*) Local caching. | 32 | It does not yet support the following AFS features: |
| 35 | 33 | ||
| 36 | (*) pioctl() system call. | 34 | (*) pioctl() system call. |
| 37 | 35 | ||
| @@ -56,7 +54,7 @@ They permit the debugging messages to be turned on dynamically by manipulating | |||
| 56 | the masks in the following files: | 54 | the masks in the following files: |
| 57 | 55 | ||
| 58 | /sys/module/af_rxrpc/parameters/debug | 56 | /sys/module/af_rxrpc/parameters/debug |
| 59 | /sys/module/afs/parameters/debug | 57 | /sys/module/kafs/parameters/debug |
| 60 | 58 | ||
| 61 | 59 | ||
| 62 | ===== | 60 | ===== |
| @@ -66,9 +64,9 @@ USAGE | |||
| 66 | When inserting the driver modules the root cell must be specified along with a | 64 | When inserting the driver modules the root cell must be specified along with a |
| 67 | list of volume location server IP addresses: | 65 | list of volume location server IP addresses: |
| 68 | 66 | ||
| 69 | insmod af_rxrpc.o | 67 | modprobe af_rxrpc |
| 70 | insmod rxkad.o | 68 | modprobe rxkad |
| 71 | insmod kafs.o rootcell=cambridge.redhat.com:172.16.18.73:172.16.18.91 | 69 | modprobe kafs rootcell=cambridge.redhat.com:172.16.18.73:172.16.18.91 |
| 72 | 70 | ||
| 73 | The first module is the AF_RXRPC network protocol driver. This provides the | 71 | The first module is the AF_RXRPC network protocol driver. This provides the |
| 74 | RxRPC remote operation protocol and may also be accessed from userspace. See: | 72 | RxRPC remote operation protocol and may also be accessed from userspace. See: |
| @@ -81,7 +79,7 @@ is the actual filesystem driver for the AFS filesystem. | |||
| 81 | Once the module has been loaded, more modules can be added by the following | 79 | Once the module has been loaded, more modules can be added by the following |
| 82 | procedure: | 80 | procedure: |
| 83 | 81 | ||
| 84 | echo add grand.central.org 18.7.14.88:128.2.191.224 >/proc/fs/afs/cells | 82 | echo add grand.central.org 18.9.48.14:128.2.203.61:130.237.48.87 >/proc/fs/afs/cells |
| 85 | 83 | ||
| 86 | Where the parameters to the "add" command are the name of a cell and a list of | 84 | Where the parameters to the "add" command are the name of a cell and a list of |
| 87 | volume location servers within that cell, with the latter separated by colons. | 85 | volume location servers within that cell, with the latter separated by colons. |
| @@ -101,7 +99,7 @@ The name of the volume can be suffixes with ".backup" or ".readonly" to | |||
| 101 | specify connection to only volumes of those types. | 99 | specify connection to only volumes of those types. |
| 102 | 100 | ||
| 103 | The name of the cell is optional, and if not given during a mount, then the | 101 | The name of the cell is optional, and if not given during a mount, then the |
| 104 | named volume will be looked up in the cell specified during insmod. | 102 | named volume will be looked up in the cell specified during modprobe. |
| 105 | 103 | ||
| 106 | Additional cells can be added through /proc (see later section). | 104 | Additional cells can be added through /proc (see later section). |
| 107 | 105 | ||
| @@ -163,14 +161,14 @@ THE CELL DATABASE | |||
| 163 | 161 | ||
| 164 | The filesystem maintains an internal database of all the cells it knows and the | 162 | The filesystem maintains an internal database of all the cells it knows and the |
| 165 | IP addresses of the volume location servers for those cells. The cell to which | 163 | IP addresses of the volume location servers for those cells. The cell to which |
| 166 | the system belongs is added to the database when insmod is performed by the | 164 | the system belongs is added to the database when modprobe is performed by the |
| 167 | "rootcell=" argument or, if compiled in, using a "kafs.rootcell=" argument on | 165 | "rootcell=" argument or, if compiled in, using a "kafs.rootcell=" argument on |
| 168 | the kernel command line. | 166 | the kernel command line. |
| 169 | 167 | ||
| 170 | Further cells can be added by commands similar to the following: | 168 | Further cells can be added by commands similar to the following: |
| 171 | 169 | ||
| 172 | echo add CELLNAME VLADDR[:VLADDR][:VLADDR]... >/proc/fs/afs/cells | 170 | echo add CELLNAME VLADDR[:VLADDR][:VLADDR]... >/proc/fs/afs/cells |
| 173 | echo add grand.central.org 18.7.14.88:128.2.191.224 >/proc/fs/afs/cells | 171 | echo add grand.central.org 18.9.48.14:128.2.203.61:130.237.48.87 >/proc/fs/afs/cells |
| 174 | 172 | ||
| 175 | No other cell database operations are available at this time. | 173 | No other cell database operations are available at this time. |
| 176 | 174 | ||
| @@ -233,7 +231,7 @@ insmod /tmp/kafs.o rootcell=cambridge.redhat.com:172.16.18.91 | |||
| 233 | mount -t afs \%root.afs. /afs | 231 | mount -t afs \%root.afs. /afs |
| 234 | mount -t afs \%cambridge.redhat.com:root.cell. /afs/cambridge.redhat.com/ | 232 | mount -t afs \%cambridge.redhat.com:root.cell. /afs/cambridge.redhat.com/ |
| 235 | 233 | ||
| 236 | echo add grand.central.org 18.7.14.88:128.2.191.224 > /proc/fs/afs/cells | 234 | echo add grand.central.org 18.9.48.14:128.2.203.61:130.237.48.87 > /proc/fs/afs/cells |
| 237 | mount -t afs "#grand.central.org:root.cell." /afs/grand.central.org/ | 235 | mount -t afs "#grand.central.org:root.cell." /afs/grand.central.org/ |
| 238 | mount -t afs "#grand.central.org:root.archive." /afs/grand.central.org/archive | 236 | mount -t afs "#grand.central.org:root.archive." /afs/grand.central.org/archive |
| 239 | mount -t afs "#grand.central.org:root.contrib." /afs/grand.central.org/contrib | 237 | mount -t afs "#grand.central.org:root.contrib." /afs/grand.central.org/contrib |
diff --git a/Documentation/filesystems/proc.txt b/Documentation/filesystems/proc.txt index fad18f9456e4..ffead13f9443 100644 --- a/Documentation/filesystems/proc.txt +++ b/Documentation/filesystems/proc.txt | |||
| @@ -1167,13 +1167,11 @@ CHAPTER 3: PER-PROCESS PARAMETERS | |||
| 1167 | 3.1 /proc/<pid>/oom_adj - Adjust the oom-killer score | 1167 | 3.1 /proc/<pid>/oom_adj - Adjust the oom-killer score |
| 1168 | ------------------------------------------------------ | 1168 | ------------------------------------------------------ |
| 1169 | 1169 | ||
| 1170 | This file can be used to adjust the score used to select which processes should | 1170 | This file can be used to adjust the score used to select which processes |
| 1171 | be killed in an out-of-memory situation. The oom_adj value is a characteristic | 1171 | should be killed in an out-of-memory situation. Giving it a high score will |
| 1172 | of the task's mm, so all threads that share an mm with pid will have the same | 1172 | increase the likelihood of this process being killed by the oom-killer. Valid |
| 1173 | oom_adj value. A high value will increase the likelihood of this process being | 1173 | values are in the range -16 to +15, plus the special value -17, which disables |
| 1174 | killed by the oom-killer. Valid values are in the range -16 to +15 as | 1174 | oom-killing altogether for this process. |
| 1175 | explained below and a special value of -17, which disables oom-killing | ||
| 1176 | altogether for threads sharing pid's mm. | ||
| 1177 | 1175 | ||
| 1178 | The process to be killed in an out-of-memory situation is selected among all others | 1176 | The process to be killed in an out-of-memory situation is selected among all others |
| 1179 | based on its badness score. This value equals the original memory size of the process | 1177 | based on its badness score. This value equals the original memory size of the process |
| @@ -1187,9 +1185,6 @@ the parent's score if they do not share the same memory. Thus forking servers | |||
| 1187 | are the prime candidates to be killed. Having only one 'hungry' child will make | 1185 | are the prime candidates to be killed. Having only one 'hungry' child will make |
| 1188 | parent less preferable than the child. | 1186 | parent less preferable than the child. |
| 1189 | 1187 | ||
| 1190 | /proc/<pid>/oom_adj cannot be changed for kthreads since they are immune from | ||
| 1191 | oom-killing already. | ||
| 1192 | |||
| 1193 | /proc/<pid>/oom_score shows process' current badness score. | 1188 | /proc/<pid>/oom_score shows process' current badness score. |
| 1194 | 1189 | ||
| 1195 | The following heuristics are then applied: | 1190 | The following heuristics are then applied: |
diff --git a/Documentation/filesystems/sysfs.txt b/Documentation/filesystems/sysfs.txt index 7e81e37c0b1e..b245d524d568 100644 --- a/Documentation/filesystems/sysfs.txt +++ b/Documentation/filesystems/sysfs.txt | |||
| @@ -23,7 +23,8 @@ interface. | |||
| 23 | Using sysfs | 23 | Using sysfs |
| 24 | ~~~~~~~~~~~ | 24 | ~~~~~~~~~~~ |
| 25 | 25 | ||
| 26 | sysfs is always compiled in. You can access it by doing: | 26 | sysfs is always compiled in if CONFIG_SYSFS is defined. You can access |
| 27 | it by doing: | ||
| 27 | 28 | ||
| 28 | mount -t sysfs sysfs /sys | 29 | mount -t sysfs sysfs /sys |
| 29 | 30 | ||
diff --git a/Documentation/ioctl/ioctl-number.txt b/Documentation/ioctl/ioctl-number.txt index 7bb0d934b6d8..dbea4f95fc85 100644 --- a/Documentation/ioctl/ioctl-number.txt +++ b/Documentation/ioctl/ioctl-number.txt | |||
| @@ -139,6 +139,7 @@ Code Seq# Include File Comments | |||
| 139 | 'm' all linux/synclink.h conflict! | 139 | 'm' all linux/synclink.h conflict! |
| 140 | 'm' 00-1F net/irda/irmod.h conflict! | 140 | 'm' 00-1F net/irda/irmod.h conflict! |
| 141 | 'n' 00-7F linux/ncp_fs.h | 141 | 'n' 00-7F linux/ncp_fs.h |
| 142 | 'n' 80-8F linux/nilfs2_fs.h NILFS2 | ||
| 142 | 'n' E0-FF video/matrox.h matroxfb | 143 | 'n' E0-FF video/matrox.h matroxfb |
| 143 | 'o' 00-1F fs/ocfs2/ocfs2_fs.h OCFS2 | 144 | 'o' 00-1F fs/ocfs2/ocfs2_fs.h OCFS2 |
| 144 | 'o' 00-03 include/mtd/ubi-user.h conflict! (OCFS2 and UBI overlaps) | 145 | 'o' 00-03 include/mtd/ubi-user.h conflict! (OCFS2 and UBI overlaps) |
diff --git a/Documentation/kernel-parameters.txt b/Documentation/kernel-parameters.txt index dd1a6d4bb747..7936b801fe6a 100644 --- a/Documentation/kernel-parameters.txt +++ b/Documentation/kernel-parameters.txt | |||
| @@ -1115,6 +1115,10 @@ and is between 256 and 4096 characters. It is defined in the file | |||
| 1115 | libata.dma=4 Compact Flash DMA only | 1115 | libata.dma=4 Compact Flash DMA only |
| 1116 | Combinations also work, so libata.dma=3 enables DMA | 1116 | Combinations also work, so libata.dma=3 enables DMA |
| 1117 | for disks and CDROMs, but not CFs. | 1117 | for disks and CDROMs, but not CFs. |
| 1118 | |||
| 1119 | libata.ignore_hpa= [LIBATA] Ignore HPA limit | ||
| 1120 | libata.ignore_hpa=0 keep BIOS limits (default) | ||
| 1121 | libata.ignore_hpa=1 ignore limits, using full disk | ||
| 1118 | 1122 | ||
| 1119 | libata.noacpi [LIBATA] Disables use of ACPI in libata suspend/resume | 1123 | libata.noacpi [LIBATA] Disables use of ACPI in libata suspend/resume |
| 1120 | when set. | 1124 | when set. |
diff --git a/Documentation/laptops/thinkpad-acpi.txt b/Documentation/laptops/thinkpad-acpi.txt index f2296ecedb89..e2ddcdeb61b6 100644 --- a/Documentation/laptops/thinkpad-acpi.txt +++ b/Documentation/laptops/thinkpad-acpi.txt | |||
| @@ -36,8 +36,6 @@ detailed description): | |||
| 36 | - Bluetooth enable and disable | 36 | - Bluetooth enable and disable |
| 37 | - video output switching, expansion control | 37 | - video output switching, expansion control |
| 38 | - ThinkLight on and off | 38 | - ThinkLight on and off |
| 39 | - limited docking and undocking | ||
| 40 | - UltraBay eject | ||
| 41 | - CMOS/UCMS control | 39 | - CMOS/UCMS control |
| 42 | - LED control | 40 | - LED control |
| 43 | - ACPI sounds | 41 | - ACPI sounds |
| @@ -729,131 +727,6 @@ cannot be read or if it is unknown, thinkpad-acpi will report it as "off". | |||
| 729 | It is impossible to know if the status returned through sysfs is valid. | 727 | It is impossible to know if the status returned through sysfs is valid. |
| 730 | 728 | ||
| 731 | 729 | ||
| 732 | Docking / undocking -- /proc/acpi/ibm/dock | ||
| 733 | ------------------------------------------ | ||
| 734 | |||
| 735 | Docking and undocking (e.g. with the X4 UltraBase) requires some | ||
| 736 | actions to be taken by the operating system to safely make or break | ||
| 737 | the electrical connections with the dock. | ||
| 738 | |||
| 739 | The docking feature of this driver generates the following ACPI events: | ||
| 740 | |||
| 741 | ibm/dock GDCK 00000003 00000001 -- eject request | ||
| 742 | ibm/dock GDCK 00000003 00000002 -- undocked | ||
| 743 | ibm/dock GDCK 00000000 00000003 -- docked | ||
| 744 | |||
| 745 | NOTE: These events will only be generated if the laptop was docked | ||
| 746 | when originally booted. This is due to the current lack of support for | ||
| 747 | hot plugging of devices in the Linux ACPI framework. If the laptop was | ||
| 748 | booted while not in the dock, the following message is shown in the | ||
| 749 | logs: | ||
| 750 | |||
| 751 | Mar 17 01:42:34 aero kernel: thinkpad_acpi: dock device not present | ||
| 752 | |||
| 753 | In this case, no dock-related events are generated but the dock and | ||
| 754 | undock commands described below still work. They can be executed | ||
| 755 | manually or triggered by Fn key combinations (see the example acpid | ||
| 756 | configuration files included in the driver tarball package available | ||
| 757 | on the web site). | ||
| 758 | |||
| 759 | When the eject request button on the dock is pressed, the first event | ||
| 760 | above is generated. The handler for this event should issue the | ||
| 761 | following command: | ||
| 762 | |||
| 763 | echo undock > /proc/acpi/ibm/dock | ||
| 764 | |||
| 765 | After the LED on the dock goes off, it is safe to eject the laptop. | ||
| 766 | Note: if you pressed this key by mistake, go ahead and eject the | ||
| 767 | laptop, then dock it back in. Otherwise, the dock may not function as | ||
| 768 | expected. | ||
| 769 | |||
| 770 | When the laptop is docked, the third event above is generated. The | ||
| 771 | handler for this event should issue the following command to fully | ||
| 772 | enable the dock: | ||
| 773 | |||
| 774 | echo dock > /proc/acpi/ibm/dock | ||
| 775 | |||
| 776 | The contents of the /proc/acpi/ibm/dock file shows the current status | ||
| 777 | of the dock, as provided by the ACPI framework. | ||
| 778 | |||
| 779 | The docking support in this driver does not take care of enabling or | ||
| 780 | disabling any other devices you may have attached to the dock. For | ||
| 781 | example, a CD drive plugged into the UltraBase needs to be disabled or | ||
| 782 | enabled separately. See the provided example acpid configuration files | ||
| 783 | for how this can be accomplished. | ||
| 784 | |||
| 785 | There is no support yet for PCI devices that may be attached to a | ||
| 786 | docking station, e.g. in the ThinkPad Dock II. The driver currently | ||
| 787 | does not recognize, enable or disable such devices. This means that | ||
| 788 | the only docking stations currently supported are the X-series | ||
| 789 | UltraBase docks and "dumb" port replicators like the Mini Dock (the | ||
| 790 | latter don't need any ACPI support, actually). | ||
| 791 | |||
| 792 | |||
| 793 | UltraBay eject -- /proc/acpi/ibm/bay | ||
| 794 | ------------------------------------ | ||
| 795 | |||
| 796 | Inserting or ejecting an UltraBay device requires some actions to be | ||
| 797 | taken by the operating system to safely make or break the electrical | ||
| 798 | connections with the device. | ||
| 799 | |||
| 800 | This feature generates the following ACPI events: | ||
| 801 | |||
| 802 | ibm/bay MSTR 00000003 00000000 -- eject request | ||
| 803 | ibm/bay MSTR 00000001 00000000 -- eject lever inserted | ||
| 804 | |||
| 805 | NOTE: These events will only be generated if the UltraBay was present | ||
| 806 | when the laptop was originally booted (on the X series, the UltraBay | ||
| 807 | is in the dock, so it may not be present if the laptop was undocked). | ||
| 808 | This is due to the current lack of support for hot plugging of devices | ||
| 809 | in the Linux ACPI framework. If the laptop was booted without the | ||
| 810 | UltraBay, the following message is shown in the logs: | ||
| 811 | |||
| 812 | Mar 17 01:42:34 aero kernel: thinkpad_acpi: bay device not present | ||
| 813 | |||
| 814 | In this case, no bay-related events are generated but the eject | ||
| 815 | command described below still works. It can be executed manually or | ||
| 816 | triggered by a hot key combination. | ||
| 817 | |||
| 818 | Sliding the eject lever generates the first event shown above. The | ||
| 819 | handler for this event should take whatever actions are necessary to | ||
| 820 | shut down the device in the UltraBay (e.g. call idectl), then issue | ||
| 821 | the following command: | ||
| 822 | |||
| 823 | echo eject > /proc/acpi/ibm/bay | ||
| 824 | |||
| 825 | After the LED on the UltraBay goes off, it is safe to pull out the | ||
| 826 | device. | ||
| 827 | |||
| 828 | When the eject lever is inserted, the second event above is | ||
| 829 | generated. The handler for this event should take whatever actions are | ||
| 830 | necessary to enable the UltraBay device (e.g. call idectl). | ||
| 831 | |||
| 832 | The contents of the /proc/acpi/ibm/bay file shows the current status | ||
| 833 | of the UltraBay, as provided by the ACPI framework. | ||
| 834 | |||
| 835 | EXPERIMENTAL warm eject support on the 600e/x, A22p and A3x (To use | ||
| 836 | this feature, you need to supply the experimental=1 parameter when | ||
| 837 | loading the module): | ||
| 838 | |||
| 839 | These models do not have a button near the UltraBay device to request | ||
| 840 | a hot eject but rather require the laptop to be put to sleep | ||
| 841 | (suspend-to-ram) before the bay device is ejected or inserted). | ||
| 842 | The sequence of steps to eject the device is as follows: | ||
| 843 | |||
| 844 | echo eject > /proc/acpi/ibm/bay | ||
| 845 | put the ThinkPad to sleep | ||
| 846 | remove the drive | ||
| 847 | resume from sleep | ||
| 848 | cat /proc/acpi/ibm/bay should show that the drive was removed | ||
| 849 | |||
| 850 | On the A3x, both the UltraBay 2000 and UltraBay Plus devices are | ||
| 851 | supported. Use "eject2" instead of "eject" for the second bay. | ||
| 852 | |||
| 853 | Note: the UltraBay eject support on the 600e/x, A22p and A3x is | ||
| 854 | EXPERIMENTAL and may not work as expected. USE WITH CAUTION! | ||
| 855 | |||
| 856 | |||
| 857 | CMOS/UCMS control | 730 | CMOS/UCMS control |
| 858 | ----------------- | 731 | ----------------- |
| 859 | 732 | ||
diff --git a/Documentation/lguest/lguest.c b/Documentation/lguest/lguest.c index 9ebcd6ef361b..950cde6d6e58 100644 --- a/Documentation/lguest/lguest.c +++ b/Documentation/lguest/lguest.c | |||
| @@ -1,7 +1,9 @@ | |||
| 1 | /*P:100 This is the Launcher code, a simple program which lays out the | 1 | /*P:100 |
| 2 | * "physical" memory for the new Guest by mapping the kernel image and | 2 | * This is the Launcher code, a simple program which lays out the "physical" |
| 3 | * the virtual devices, then opens /dev/lguest to tell the kernel | 3 | * memory for the new Guest by mapping the kernel image and the virtual |
| 4 | * about the Guest and control it. :*/ | 4 | * devices, then opens /dev/lguest to tell the kernel about the Guest and |
| 5 | * control it. | ||
| 6 | :*/ | ||
| 5 | #define _LARGEFILE64_SOURCE | 7 | #define _LARGEFILE64_SOURCE |
| 6 | #define _GNU_SOURCE | 8 | #define _GNU_SOURCE |
| 7 | #include <stdio.h> | 9 | #include <stdio.h> |
| @@ -46,13 +48,15 @@ | |||
| 46 | #include "linux/virtio_rng.h" | 48 | #include "linux/virtio_rng.h" |
| 47 | #include "linux/virtio_ring.h" | 49 | #include "linux/virtio_ring.h" |
| 48 | #include "asm/bootparam.h" | 50 | #include "asm/bootparam.h" |
| 49 | /*L:110 We can ignore the 39 include files we need for this program, but I do | 51 | /*L:110 |
| 50 | * want to draw attention to the use of kernel-style types. | 52 | * We can ignore the 42 include files we need for this program, but I do want |
| 53 | * to draw attention to the use of kernel-style types. | ||
| 51 | * | 54 | * |
| 52 | * As Linus said, "C is a Spartan language, and so should your naming be." I | 55 | * As Linus said, "C is a Spartan language, and so should your naming be." I |
| 53 | * like these abbreviations, so we define them here. Note that u64 is always | 56 | * like these abbreviations, so we define them here. Note that u64 is always |
| 54 | * unsigned long long, which works on all Linux systems: this means that we can | 57 | * unsigned long long, which works on all Linux systems: this means that we can |
| 55 | * use %llu in printf for any u64. */ | 58 | * use %llu in printf for any u64. |
| 59 | */ | ||
| 56 | typedef unsigned long long u64; | 60 | typedef unsigned long long u64; |
| 57 | typedef uint32_t u32; | 61 | typedef uint32_t u32; |
| 58 | typedef uint16_t u16; | 62 | typedef uint16_t u16; |
| @@ -69,8 +73,10 @@ typedef uint8_t u8; | |||
| 69 | /* This will occupy 3 pages: it must be a power of 2. */ | 73 | /* This will occupy 3 pages: it must be a power of 2. */ |
| 70 | #define VIRTQUEUE_NUM 256 | 74 | #define VIRTQUEUE_NUM 256 |
| 71 | 75 | ||
| 72 | /*L:120 verbose is both a global flag and a macro. The C preprocessor allows | 76 | /*L:120 |
| 73 | * this, and although I wouldn't recommend it, it works quite nicely here. */ | 77 | * verbose is both a global flag and a macro. The C preprocessor allows |
| 78 | * this, and although I wouldn't recommend it, it works quite nicely here. | ||
| 79 | */ | ||
| 74 | static bool verbose; | 80 | static bool verbose; |
| 75 | #define verbose(args...) \ | 81 | #define verbose(args...) \ |
| 76 | do { if (verbose) printf(args); } while(0) | 82 | do { if (verbose) printf(args); } while(0) |
| @@ -87,8 +93,7 @@ static int lguest_fd; | |||
| 87 | static unsigned int __thread cpu_id; | 93 | static unsigned int __thread cpu_id; |
| 88 | 94 | ||
| 89 | /* This is our list of devices. */ | 95 | /* This is our list of devices. */ |
| 90 | struct device_list | 96 | struct device_list { |
| 91 | { | ||
| 92 | /* Counter to assign interrupt numbers. */ | 97 | /* Counter to assign interrupt numbers. */ |
| 93 | unsigned int next_irq; | 98 | unsigned int next_irq; |
| 94 | 99 | ||
| @@ -100,8 +105,7 @@ struct device_list | |||
| 100 | 105 | ||
| 101 | /* A single linked list of devices. */ | 106 | /* A single linked list of devices. */ |
| 102 | struct device *dev; | 107 | struct device *dev; |
| 103 | /* And a pointer to the last device for easy append and also for | 108 | /* And a pointer to the last device for easy append. */ |
| 104 | * configuration appending. */ | ||
| 105 | struct device *lastdev; | 109 | struct device *lastdev; |
| 106 | }; | 110 | }; |
| 107 | 111 | ||
| @@ -109,8 +113,7 @@ struct device_list | |||
| 109 | static struct device_list devices; | 113 | static struct device_list devices; |
| 110 | 114 | ||
| 111 | /* The device structure describes a single device. */ | 115 | /* The device structure describes a single device. */ |
| 112 | struct device | 116 | struct device { |
| 113 | { | ||
| 114 | /* The linked-list pointer. */ | 117 | /* The linked-list pointer. */ |
| 115 | struct device *next; | 118 | struct device *next; |
| 116 | 119 | ||
| @@ -135,8 +138,7 @@ struct device | |||
| 135 | }; | 138 | }; |
| 136 | 139 | ||
| 137 | /* The virtqueue structure describes a queue attached to a device. */ | 140 | /* The virtqueue structure describes a queue attached to a device. */ |
| 138 | struct virtqueue | 141 | struct virtqueue { |
| 139 | { | ||
| 140 | struct virtqueue *next; | 142 | struct virtqueue *next; |
| 141 | 143 | ||
| 142 | /* Which device owns me. */ | 144 | /* Which device owns me. */ |
| @@ -168,20 +170,24 @@ static char **main_args; | |||
| 168 | /* The original tty settings to restore on exit. */ | 170 | /* The original tty settings to restore on exit. */ |
| 169 | static struct termios orig_term; | 171 | static struct termios orig_term; |
| 170 | 172 | ||
| 171 | /* We have to be careful with barriers: our devices are all run in separate | 173 | /* |
| 174 | * We have to be careful with barriers: our devices are all run in separate | ||
| 172 | * threads and so we need to make sure that changes visible to the Guest happen | 175 | * threads and so we need to make sure that changes visible to the Guest happen |
| 173 | * in precise order. */ | 176 | * in precise order. |
| 177 | */ | ||
| 174 | #define wmb() __asm__ __volatile__("" : : : "memory") | 178 | #define wmb() __asm__ __volatile__("" : : : "memory") |
| 175 | #define mb() __asm__ __volatile__("" : : : "memory") | 179 | #define mb() __asm__ __volatile__("" : : : "memory") |
| 176 | 180 | ||
| 177 | /* Convert an iovec element to the given type. | 181 | /* |
| 182 | * Convert an iovec element to the given type. | ||
| 178 | * | 183 | * |
| 179 | * This is a fairly ugly trick: we need to know the size of the type and | 184 | * This is a fairly ugly trick: we need to know the size of the type and |
| 180 | * alignment requirement to check the pointer is kosher. It's also nice to | 185 | * alignment requirement to check the pointer is kosher. It's also nice to |
| 181 | * have the name of the type in case we report failure. | 186 | * have the name of the type in case we report failure. |
| 182 | * | 187 | * |
| 183 | * Typing those three things all the time is cumbersome and error prone, so we | 188 | * Typing those three things all the time is cumbersome and error prone, so we |
| 184 | * have a macro which sets them all up and passes to the real function. */ | 189 | * have a macro which sets them all up and passes to the real function. |
| 190 | */ | ||
| 185 | #define convert(iov, type) \ | 191 | #define convert(iov, type) \ |
| 186 | ((type *)_convert((iov), sizeof(type), __alignof__(type), #type)) | 192 | ((type *)_convert((iov), sizeof(type), __alignof__(type), #type)) |
| 187 | 193 | ||
| @@ -198,8 +204,10 @@ static void *_convert(struct iovec *iov, size_t size, size_t align, | |||
| 198 | /* Wrapper for the last available index. Makes it easier to change. */ | 204 | /* Wrapper for the last available index. Makes it easier to change. */ |
| 199 | #define lg_last_avail(vq) ((vq)->last_avail_idx) | 205 | #define lg_last_avail(vq) ((vq)->last_avail_idx) |
| 200 | 206 | ||
| 201 | /* The virtio configuration space is defined to be little-endian. x86 is | 207 | /* |
| 202 | * little-endian too, but it's nice to be explicit so we have these helpers. */ | 208 | * The virtio configuration space is defined to be little-endian. x86 is |
| 209 | * little-endian too, but it's nice to be explicit so we have these helpers. | ||
| 210 | */ | ||
| 203 | #define cpu_to_le16(v16) (v16) | 211 | #define cpu_to_le16(v16) (v16) |
| 204 | #define cpu_to_le32(v32) (v32) | 212 | #define cpu_to_le32(v32) (v32) |
| 205 | #define cpu_to_le64(v64) (v64) | 213 | #define cpu_to_le64(v64) (v64) |
| @@ -241,11 +249,12 @@ static u8 *get_feature_bits(struct device *dev) | |||
| 241 | + dev->num_vq * sizeof(struct lguest_vqconfig); | 249 | + dev->num_vq * sizeof(struct lguest_vqconfig); |
| 242 | } | 250 | } |
| 243 | 251 | ||
| 244 | /*L:100 The Launcher code itself takes us out into userspace, that scary place | 252 | /*L:100 |
| 245 | * where pointers run wild and free! Unfortunately, like most userspace | 253 | * The Launcher code itself takes us out into userspace, that scary place where |
| 246 | * programs, it's quite boring (which is why everyone likes to hack on the | 254 | * pointers run wild and free! Unfortunately, like most userspace programs, |
| 247 | * kernel!). Perhaps if you make up an Lguest Drinking Game at this point, it | 255 | * it's quite boring (which is why everyone likes to hack on the kernel!). |
| 248 | * will get you through this section. Or, maybe not. | 256 | * Perhaps if you make up an Lguest Drinking Game at this point, it will get |
| 257 | * you through this section. Or, maybe not. | ||
| 249 | * | 258 | * |
| 250 | * The Launcher sets up a big chunk of memory to be the Guest's "physical" | 259 | * The Launcher sets up a big chunk of memory to be the Guest's "physical" |
| 251 | * memory and stores it in "guest_base". In other words, Guest physical == | 260 | * memory and stores it in "guest_base". In other words, Guest physical == |
| @@ -253,7 +262,8 @@ static u8 *get_feature_bits(struct device *dev) | |||
| 253 | * | 262 | * |
| 254 | * This can be tough to get your head around, but usually it just means that we | 263 | * This can be tough to get your head around, but usually it just means that we |
| 255 | * use these trivial conversion functions when the Guest gives us it's | 264 | * use these trivial conversion functions when the Guest gives us it's |
| 256 | * "physical" addresses: */ | 265 | * "physical" addresses: |
| 266 | */ | ||
| 257 | static void *from_guest_phys(unsigned long addr) | 267 | static void *from_guest_phys(unsigned long addr) |
| 258 | { | 268 | { |
| 259 | return guest_base + addr; | 269 | return guest_base + addr; |
| @@ -268,7 +278,8 @@ static unsigned long to_guest_phys(const void *addr) | |||
| 268 | * Loading the Kernel. | 278 | * Loading the Kernel. |
| 269 | * | 279 | * |
| 270 | * We start with couple of simple helper routines. open_or_die() avoids | 280 | * We start with couple of simple helper routines. open_or_die() avoids |
| 271 | * error-checking code cluttering the callers: */ | 281 | * error-checking code cluttering the callers: |
| 282 | */ | ||
| 272 | static int open_or_die(const char *name, int flags) | 283 | static int open_or_die(const char *name, int flags) |
| 273 | { | 284 | { |
| 274 | int fd = open(name, flags); | 285 | int fd = open(name, flags); |
| @@ -283,12 +294,19 @@ static void *map_zeroed_pages(unsigned int num) | |||
| 283 | int fd = open_or_die("/dev/zero", O_RDONLY); | 294 | int fd = open_or_die("/dev/zero", O_RDONLY); |
| 284 | void *addr; | 295 | void *addr; |
| 285 | 296 | ||
| 286 | /* We use a private mapping (ie. if we write to the page, it will be | 297 | /* |
| 287 | * copied). */ | 298 | * We use a private mapping (ie. if we write to the page, it will be |
| 299 | * copied). | ||
| 300 | */ | ||
| 288 | addr = mmap(NULL, getpagesize() * num, | 301 | addr = mmap(NULL, getpagesize() * num, |
| 289 | PROT_READ|PROT_WRITE|PROT_EXEC, MAP_PRIVATE, fd, 0); | 302 | PROT_READ|PROT_WRITE|PROT_EXEC, MAP_PRIVATE, fd, 0); |
| 290 | if (addr == MAP_FAILED) | 303 | if (addr == MAP_FAILED) |
| 291 | err(1, "Mmaping %u pages of /dev/zero", num); | 304 | err(1, "Mmaping %u pages of /dev/zero", num); |
| 305 | |||
| 306 | /* | ||
| 307 | * One neat mmap feature is that you can close the fd, and it | ||
| 308 | * stays mapped. | ||
| 309 | */ | ||
| 292 | close(fd); | 310 | close(fd); |
| 293 | 311 | ||
| 294 | return addr; | 312 | return addr; |
| @@ -305,20 +323,24 @@ static void *get_pages(unsigned int num) | |||
| 305 | return addr; | 323 | return addr; |
| 306 | } | 324 | } |
| 307 | 325 | ||
| 308 | /* This routine is used to load the kernel or initrd. It tries mmap, but if | 326 | /* |
| 327 | * This routine is used to load the kernel or initrd. It tries mmap, but if | ||
| 309 | * that fails (Plan 9's kernel file isn't nicely aligned on page boundaries), | 328 | * that fails (Plan 9's kernel file isn't nicely aligned on page boundaries), |
| 310 | * it falls back to reading the memory in. */ | 329 | * it falls back to reading the memory in. |
| 330 | */ | ||
| 311 | static void map_at(int fd, void *addr, unsigned long offset, unsigned long len) | 331 | static void map_at(int fd, void *addr, unsigned long offset, unsigned long len) |
| 312 | { | 332 | { |
| 313 | ssize_t r; | 333 | ssize_t r; |
| 314 | 334 | ||
| 315 | /* We map writable even though for some segments are marked read-only. | 335 | /* |
| 336 | * We map writable even though for some segments are marked read-only. | ||
| 316 | * The kernel really wants to be writable: it patches its own | 337 | * The kernel really wants to be writable: it patches its own |
| 317 | * instructions. | 338 | * instructions. |
| 318 | * | 339 | * |
| 319 | * MAP_PRIVATE means that the page won't be copied until a write is | 340 | * MAP_PRIVATE means that the page won't be copied until a write is |
| 320 | * done to it. This allows us to share untouched memory between | 341 | * done to it. This allows us to share untouched memory between |
| 321 | * Guests. */ | 342 | * Guests. |
| 343 | */ | ||
| 322 | if (mmap(addr, len, PROT_READ|PROT_WRITE|PROT_EXEC, | 344 | if (mmap(addr, len, PROT_READ|PROT_WRITE|PROT_EXEC, |
| 323 | MAP_FIXED|MAP_PRIVATE, fd, offset) != MAP_FAILED) | 345 | MAP_FIXED|MAP_PRIVATE, fd, offset) != MAP_FAILED) |
| 324 | return; | 346 | return; |
| @@ -329,7 +351,8 @@ static void map_at(int fd, void *addr, unsigned long offset, unsigned long len) | |||
| 329 | err(1, "Reading offset %lu len %lu gave %zi", offset, len, r); | 351 | err(1, "Reading offset %lu len %lu gave %zi", offset, len, r); |
| 330 | } | 352 | } |
| 331 | 353 | ||
| 332 | /* This routine takes an open vmlinux image, which is in ELF, and maps it into | 354 | /* |
| 355 | * This routine takes an open vmlinux image, which is in ELF, and maps it into | ||
| 333 | * the Guest memory. ELF = Embedded Linking Format, which is the format used | 356 | * the Guest memory. ELF = Embedded Linking Format, which is the format used |
| 334 | * by all modern binaries on Linux including the kernel. | 357 | * by all modern binaries on Linux including the kernel. |
| 335 | * | 358 | * |
| @@ -337,23 +360,28 @@ static void map_at(int fd, void *addr, unsigned long offset, unsigned long len) | |||
| 337 | * address. We use the physical address; the Guest will map itself to the | 360 | * address. We use the physical address; the Guest will map itself to the |
| 338 | * virtual address. | 361 | * virtual address. |
| 339 | * | 362 | * |
| 340 | * We return the starting address. */ | 363 | * We return the starting address. |
| 364 | */ | ||
| 341 | static unsigned long map_elf(int elf_fd, const Elf32_Ehdr *ehdr) | 365 | static unsigned long map_elf(int elf_fd, const Elf32_Ehdr *ehdr) |
| 342 | { | 366 | { |
| 343 | Elf32_Phdr phdr[ehdr->e_phnum]; | 367 | Elf32_Phdr phdr[ehdr->e_phnum]; |
| 344 | unsigned int i; | 368 | unsigned int i; |
| 345 | 369 | ||
| 346 | /* Sanity checks on the main ELF header: an x86 executable with a | 370 | /* |
| 347 | * reasonable number of correctly-sized program headers. */ | 371 | * Sanity checks on the main ELF header: an x86 executable with a |
| 372 | * reasonable number of correctly-sized program headers. | ||
| 373 | */ | ||
| 348 | if (ehdr->e_type != ET_EXEC | 374 | if (ehdr->e_type != ET_EXEC |
| 349 | || ehdr->e_machine != EM_386 | 375 | || ehdr->e_machine != EM_386 |
| 350 | || ehdr->e_phentsize != sizeof(Elf32_Phdr) | 376 | || ehdr->e_phentsize != sizeof(Elf32_Phdr) |
| 351 | || ehdr->e_phnum < 1 || ehdr->e_phnum > 65536U/sizeof(Elf32_Phdr)) | 377 | || ehdr->e_phnum < 1 || ehdr->e_phnum > 65536U/sizeof(Elf32_Phdr)) |
| 352 | errx(1, "Malformed elf header"); | 378 | errx(1, "Malformed elf header"); |
| 353 | 379 | ||
| 354 | /* An ELF executable contains an ELF header and a number of "program" | 380 | /* |
| 381 | * An ELF executable contains an ELF header and a number of "program" | ||
| 355 | * headers which indicate which parts ("segments") of the program to | 382 | * headers which indicate which parts ("segments") of the program to |
| 356 | * load where. */ | 383 | * load where. |
| 384 | */ | ||
| 357 | 385 | ||
| 358 | /* We read in all the program headers at once: */ | 386 | /* We read in all the program headers at once: */ |
| 359 | if (lseek(elf_fd, ehdr->e_phoff, SEEK_SET) < 0) | 387 | if (lseek(elf_fd, ehdr->e_phoff, SEEK_SET) < 0) |
| @@ -361,8 +389,10 @@ static unsigned long map_elf(int elf_fd, const Elf32_Ehdr *ehdr) | |||
| 361 | if (read(elf_fd, phdr, sizeof(phdr)) != sizeof(phdr)) | 389 | if (read(elf_fd, phdr, sizeof(phdr)) != sizeof(phdr)) |
| 362 | err(1, "Reading program headers"); | 390 | err(1, "Reading program headers"); |
| 363 | 391 | ||
| 364 | /* Try all the headers: there are usually only three. A read-only one, | 392 | /* |
| 365 | * a read-write one, and a "note" section which we don't load. */ | 393 | * Try all the headers: there are usually only three. A read-only one, |
| 394 | * a read-write one, and a "note" section which we don't load. | ||
| 395 | */ | ||
| 366 | for (i = 0; i < ehdr->e_phnum; i++) { | 396 | for (i = 0; i < ehdr->e_phnum; i++) { |
| 367 | /* If this isn't a loadable segment, we ignore it */ | 397 | /* If this isn't a loadable segment, we ignore it */ |
| 368 | if (phdr[i].p_type != PT_LOAD) | 398 | if (phdr[i].p_type != PT_LOAD) |
| @@ -380,13 +410,15 @@ static unsigned long map_elf(int elf_fd, const Elf32_Ehdr *ehdr) | |||
| 380 | return ehdr->e_entry; | 410 | return ehdr->e_entry; |
| 381 | } | 411 | } |
| 382 | 412 | ||
| 383 | /*L:150 A bzImage, unlike an ELF file, is not meant to be loaded. You're | 413 | /*L:150 |
| 384 | * supposed to jump into it and it will unpack itself. We used to have to | 414 | * A bzImage, unlike an ELF file, is not meant to be loaded. You're supposed |
| 385 | * perform some hairy magic because the unpacking code scared me. | 415 | * to jump into it and it will unpack itself. We used to have to perform some |
| 416 | * hairy magic because the unpacking code scared me. | ||
| 386 | * | 417 | * |
| 387 | * Fortunately, Jeremy Fitzhardinge convinced me it wasn't that hard and wrote | 418 | * Fortunately, Jeremy Fitzhardinge convinced me it wasn't that hard and wrote |
| 388 | * a small patch to jump over the tricky bits in the Guest, so now we just read | 419 | * a small patch to jump over the tricky bits in the Guest, so now we just read |
| 389 | * the funky header so we know where in the file to load, and away we go! */ | 420 | * the funky header so we know where in the file to load, and away we go! |
| 421 | */ | ||
| 390 | static unsigned long load_bzimage(int fd) | 422 | static unsigned long load_bzimage(int fd) |
| 391 | { | 423 | { |
| 392 | struct boot_params boot; | 424 | struct boot_params boot; |
| @@ -394,8 +426,10 @@ static unsigned long load_bzimage(int fd) | |||
| 394 | /* Modern bzImages get loaded at 1M. */ | 426 | /* Modern bzImages get loaded at 1M. */ |
| 395 | void *p = from_guest_phys(0x100000); | 427 | void *p = from_guest_phys(0x100000); |
| 396 | 428 | ||
| 397 | /* Go back to the start of the file and read the header. It should be | 429 | /* |
| 398 | * a Linux boot header (see Documentation/x86/i386/boot.txt) */ | 430 | * Go back to the start of the file and read the header. It should be |
| 431 | * a Linux boot header (see Documentation/x86/i386/boot.txt) | ||
| 432 | */ | ||
| 399 | lseek(fd, 0, SEEK_SET); | 433 | lseek(fd, 0, SEEK_SET); |
| 400 | read(fd, &boot, sizeof(boot)); | 434 | read(fd, &boot, sizeof(boot)); |
| 401 | 435 | ||
| @@ -414,9 +448,11 @@ static unsigned long load_bzimage(int fd) | |||
| 414 | return boot.hdr.code32_start; | 448 | return boot.hdr.code32_start; |
| 415 | } | 449 | } |
| 416 | 450 | ||
| 417 | /*L:140 Loading the kernel is easy when it's a "vmlinux", but most kernels | 451 | /*L:140 |
| 452 | * Loading the kernel is easy when it's a "vmlinux", but most kernels | ||
| 418 | * come wrapped up in the self-decompressing "bzImage" format. With a little | 453 | * come wrapped up in the self-decompressing "bzImage" format. With a little |
| 419 | * work, we can load those, too. */ | 454 | * work, we can load those, too. |
| 455 | */ | ||
| 420 | static unsigned long load_kernel(int fd) | 456 | static unsigned long load_kernel(int fd) |
| 421 | { | 457 | { |
| 422 | Elf32_Ehdr hdr; | 458 | Elf32_Ehdr hdr; |
| @@ -433,24 +469,28 @@ static unsigned long load_kernel(int fd) | |||
| 433 | return load_bzimage(fd); | 469 | return load_bzimage(fd); |
| 434 | } | 470 | } |
| 435 | 471 | ||
| 436 | /* This is a trivial little helper to align pages. Andi Kleen hated it because | 472 | /* |
| 473 | * This is a trivial little helper to align pages. Andi Kleen hated it because | ||
| 437 | * it calls getpagesize() twice: "it's dumb code." | 474 | * it calls getpagesize() twice: "it's dumb code." |
| 438 | * | 475 | * |
| 439 | * Kernel guys get really het up about optimization, even when it's not | 476 | * Kernel guys get really het up about optimization, even when it's not |
| 440 | * necessary. I leave this code as a reaction against that. */ | 477 | * necessary. I leave this code as a reaction against that. |
| 478 | */ | ||
| 441 | static inline unsigned long page_align(unsigned long addr) | 479 | static inline unsigned long page_align(unsigned long addr) |
| 442 | { | 480 | { |
| 443 | /* Add upwards and truncate downwards. */ | 481 | /* Add upwards and truncate downwards. */ |
| 444 | return ((addr + getpagesize()-1) & ~(getpagesize()-1)); | 482 | return ((addr + getpagesize()-1) & ~(getpagesize()-1)); |
| 445 | } | 483 | } |
| 446 | 484 | ||
| 447 | /*L:180 An "initial ram disk" is a disk image loaded into memory along with | 485 | /*L:180 |
| 448 | * the kernel which the kernel can use to boot from without needing any | 486 | * An "initial ram disk" is a disk image loaded into memory along with the |
| 449 | * drivers. Most distributions now use this as standard: the initrd contains | 487 | * kernel which the kernel can use to boot from without needing any drivers. |
| 450 | * the code to load the appropriate driver modules for the current machine. | 488 | * Most distributions now use this as standard: the initrd contains the code to |
| 489 | * load the appropriate driver modules for the current machine. | ||
| 451 | * | 490 | * |
| 452 | * Importantly, James Morris works for RedHat, and Fedora uses initrds for its | 491 | * Importantly, James Morris works for RedHat, and Fedora uses initrds for its |
| 453 | * kernels. He sent me this (and tells me when I break it). */ | 492 | * kernels. He sent me this (and tells me when I break it). |
| 493 | */ | ||
| 454 | static unsigned long load_initrd(const char *name, unsigned long mem) | 494 | static unsigned long load_initrd(const char *name, unsigned long mem) |
| 455 | { | 495 | { |
| 456 | int ifd; | 496 | int ifd; |
| @@ -462,12 +502,16 @@ static unsigned long load_initrd(const char *name, unsigned long mem) | |||
| 462 | if (fstat(ifd, &st) < 0) | 502 | if (fstat(ifd, &st) < 0) |
| 463 | err(1, "fstat() on initrd '%s'", name); | 503 | err(1, "fstat() on initrd '%s'", name); |
| 464 | 504 | ||
| 465 | /* We map the initrd at the top of memory, but mmap wants it to be | 505 | /* |
| 466 | * page-aligned, so we round the size up for that. */ | 506 | * We map the initrd at the top of memory, but mmap wants it to be |
| 507 | * page-aligned, so we round the size up for that. | ||
| 508 | */ | ||
| 467 | len = page_align(st.st_size); | 509 | len = page_align(st.st_size); |
| 468 | map_at(ifd, from_guest_phys(mem - len), 0, st.st_size); | 510 | map_at(ifd, from_guest_phys(mem - len), 0, st.st_size); |
| 469 | /* Once a file is mapped, you can close the file descriptor. It's a | 511 | /* |
| 470 | * little odd, but quite useful. */ | 512 | * Once a file is mapped, you can close the file descriptor. It's a |
| 513 | * little odd, but quite useful. | ||
| 514 | */ | ||
| 471 | close(ifd); | 515 | close(ifd); |
| 472 | verbose("mapped initrd %s size=%lu @ %p\n", name, len, (void*)mem-len); | 516 | verbose("mapped initrd %s size=%lu @ %p\n", name, len, (void*)mem-len); |
| 473 | 517 | ||
| @@ -476,8 +520,10 @@ static unsigned long load_initrd(const char *name, unsigned long mem) | |||
| 476 | } | 520 | } |
| 477 | /*:*/ | 521 | /*:*/ |
| 478 | 522 | ||
| 479 | /* Simple routine to roll all the commandline arguments together with spaces | 523 | /* |
| 480 | * between them. */ | 524 | * Simple routine to roll all the commandline arguments together with spaces |
| 525 | * between them. | ||
| 526 | */ | ||
| 481 | static void concat(char *dst, char *args[]) | 527 | static void concat(char *dst, char *args[]) |
| 482 | { | 528 | { |
| 483 | unsigned int i, len = 0; | 529 | unsigned int i, len = 0; |
| @@ -494,10 +540,12 @@ static void concat(char *dst, char *args[]) | |||
| 494 | dst[len] = '\0'; | 540 | dst[len] = '\0'; |
| 495 | } | 541 | } |
| 496 | 542 | ||
| 497 | /*L:185 This is where we actually tell the kernel to initialize the Guest. We | 543 | /*L:185 |
| 544 | * This is where we actually tell the kernel to initialize the Guest. We | ||
| 498 | * saw the arguments it expects when we looked at initialize() in lguest_user.c: | 545 | * saw the arguments it expects when we looked at initialize() in lguest_user.c: |
| 499 | * the base of Guest "physical" memory, the top physical page to allow and the | 546 | * the base of Guest "physical" memory, the top physical page to allow and the |
| 500 | * entry point for the Guest. */ | 547 | * entry point for the Guest. |
| 548 | */ | ||
| 501 | static void tell_kernel(unsigned long start) | 549 | static void tell_kernel(unsigned long start) |
| 502 | { | 550 | { |
| 503 | unsigned long args[] = { LHREQ_INITIALIZE, | 551 | unsigned long args[] = { LHREQ_INITIALIZE, |
| @@ -511,7 +559,7 @@ static void tell_kernel(unsigned long start) | |||
| 511 | } | 559 | } |
| 512 | /*:*/ | 560 | /*:*/ |
| 513 | 561 | ||
| 514 | /* | 562 | /*L:200 |
| 515 | * Device Handling. | 563 | * Device Handling. |
| 516 | * | 564 | * |
| 517 | * When the Guest gives us a buffer, it sends an array of addresses and sizes. | 565 | * When the Guest gives us a buffer, it sends an array of addresses and sizes. |
| @@ -522,20 +570,26 @@ static void tell_kernel(unsigned long start) | |||
| 522 | static void *_check_pointer(unsigned long addr, unsigned int size, | 570 | static void *_check_pointer(unsigned long addr, unsigned int size, |
| 523 | unsigned int line) | 571 | unsigned int line) |
| 524 | { | 572 | { |
| 525 | /* We have to separately check addr and addr+size, because size could | 573 | /* |
| 526 | * be huge and addr + size might wrap around. */ | 574 | * We have to separately check addr and addr+size, because size could |
| 575 | * be huge and addr + size might wrap around. | ||
| 576 | */ | ||
| 527 | if (addr >= guest_limit || addr + size >= guest_limit) | 577 | if (addr >= guest_limit || addr + size >= guest_limit) |
| 528 | errx(1, "%s:%i: Invalid address %#lx", __FILE__, line, addr); | 578 | errx(1, "%s:%i: Invalid address %#lx", __FILE__, line, addr); |
| 529 | /* We return a pointer for the caller's convenience, now we know it's | 579 | /* |
| 530 | * safe to use. */ | 580 | * We return a pointer for the caller's convenience, now we know it's |
| 581 | * safe to use. | ||
| 582 | */ | ||
| 531 | return from_guest_phys(addr); | 583 | return from_guest_phys(addr); |
| 532 | } | 584 | } |
| 533 | /* A macro which transparently hands the line number to the real function. */ | 585 | /* A macro which transparently hands the line number to the real function. */ |
| 534 | #define check_pointer(addr,size) _check_pointer(addr, size, __LINE__) | 586 | #define check_pointer(addr,size) _check_pointer(addr, size, __LINE__) |
| 535 | 587 | ||
| 536 | /* Each buffer in the virtqueues is actually a chain of descriptors. This | 588 | /* |
| 589 | * Each buffer in the virtqueues is actually a chain of descriptors. This | ||
| 537 | * function returns the next descriptor in the chain, or vq->vring.num if we're | 590 | * function returns the next descriptor in the chain, or vq->vring.num if we're |
| 538 | * at the end. */ | 591 | * at the end. |
| 592 | */ | ||
| 539 | static unsigned next_desc(struct vring_desc *desc, | 593 | static unsigned next_desc(struct vring_desc *desc, |
| 540 | unsigned int i, unsigned int max) | 594 | unsigned int i, unsigned int max) |
| 541 | { | 595 | { |
| @@ -556,7 +610,10 @@ static unsigned next_desc(struct vring_desc *desc, | |||
| 556 | return next; | 610 | return next; |
| 557 | } | 611 | } |
| 558 | 612 | ||
| 559 | /* This actually sends the interrupt for this virtqueue */ | 613 | /* |
| 614 | * This actually sends the interrupt for this virtqueue, if we've used a | ||
| 615 | * buffer. | ||
| 616 | */ | ||
| 560 | static void trigger_irq(struct virtqueue *vq) | 617 | static void trigger_irq(struct virtqueue *vq) |
| 561 | { | 618 | { |
| 562 | unsigned long buf[] = { LHREQ_IRQ, vq->config.irq }; | 619 | unsigned long buf[] = { LHREQ_IRQ, vq->config.irq }; |
| @@ -576,12 +633,14 @@ static void trigger_irq(struct virtqueue *vq) | |||
| 576 | err(1, "Triggering irq %i", vq->config.irq); | 633 | err(1, "Triggering irq %i", vq->config.irq); |
| 577 | } | 634 | } |
| 578 | 635 | ||
| 579 | /* This looks in the virtqueue and for the first available buffer, and converts | 636 | /* |
| 637 | * This looks in the virtqueue for the first available buffer, and converts | ||
| 580 | * it to an iovec for convenient access. Since descriptors consist of some | 638 | * it to an iovec for convenient access. Since descriptors consist of some |
| 581 | * number of output then some number of input descriptors, it's actually two | 639 | * number of output then some number of input descriptors, it's actually two |
| 582 | * iovecs, but we pack them into one and note how many of each there were. | 640 | * iovecs, but we pack them into one and note how many of each there were. |
| 583 | * | 641 | * |
| 584 | * This function returns the descriptor number found. */ | 642 | * This function waits if necessary, and returns the descriptor number found. |
| 643 | */ | ||
| 585 | static unsigned wait_for_vq_desc(struct virtqueue *vq, | 644 | static unsigned wait_for_vq_desc(struct virtqueue *vq, |
| 586 | struct iovec iov[], | 645 | struct iovec iov[], |
| 587 | unsigned int *out_num, unsigned int *in_num) | 646 | unsigned int *out_num, unsigned int *in_num) |
| @@ -590,17 +649,23 @@ static unsigned wait_for_vq_desc(struct virtqueue *vq, | |||
| 590 | struct vring_desc *desc; | 649 | struct vring_desc *desc; |
| 591 | u16 last_avail = lg_last_avail(vq); | 650 | u16 last_avail = lg_last_avail(vq); |
| 592 | 651 | ||
| 652 | /* There's nothing available? */ | ||
| 593 | while (last_avail == vq->vring.avail->idx) { | 653 | while (last_avail == vq->vring.avail->idx) { |
| 594 | u64 event; | 654 | u64 event; |
| 595 | 655 | ||
| 596 | /* OK, tell Guest about progress up to now. */ | 656 | /* |
| 657 | * Since we're about to sleep, now is a good time to tell the | ||
| 658 | * Guest about what we've used up to now. | ||
| 659 | */ | ||
| 597 | trigger_irq(vq); | 660 | trigger_irq(vq); |
| 598 | 661 | ||
| 599 | /* OK, now we need to know about added descriptors. */ | 662 | /* OK, now we need to know about added descriptors. */ |
| 600 | vq->vring.used->flags &= ~VRING_USED_F_NO_NOTIFY; | 663 | vq->vring.used->flags &= ~VRING_USED_F_NO_NOTIFY; |
| 601 | 664 | ||
| 602 | /* They could have slipped one in as we were doing that: make | 665 | /* |
| 603 | * sure it's written, then check again. */ | 666 | * They could have slipped one in as we were doing that: make |
| 667 | * sure it's written, then check again. | ||
| 668 | */ | ||
| 604 | mb(); | 669 | mb(); |
| 605 | if (last_avail != vq->vring.avail->idx) { | 670 | if (last_avail != vq->vring.avail->idx) { |
| 606 | vq->vring.used->flags |= VRING_USED_F_NO_NOTIFY; | 671 | vq->vring.used->flags |= VRING_USED_F_NO_NOTIFY; |
| @@ -620,8 +685,10 @@ static unsigned wait_for_vq_desc(struct virtqueue *vq, | |||
| 620 | errx(1, "Guest moved used index from %u to %u", | 685 | errx(1, "Guest moved used index from %u to %u", |
| 621 | last_avail, vq->vring.avail->idx); | 686 | last_avail, vq->vring.avail->idx); |
| 622 | 687 | ||
| 623 | /* Grab the next descriptor number they're advertising, and increment | 688 | /* |
| 624 | * the index we've seen. */ | 689 | * Grab the next descriptor number they're advertising, and increment |
| 690 | * the index we've seen. | ||
| 691 | */ | ||
| 625 | head = vq->vring.avail->ring[last_avail % vq->vring.num]; | 692 | head = vq->vring.avail->ring[last_avail % vq->vring.num]; |
| 626 | lg_last_avail(vq)++; | 693 | lg_last_avail(vq)++; |
| 627 | 694 | ||
| @@ -636,8 +703,10 @@ static unsigned wait_for_vq_desc(struct virtqueue *vq, | |||
| 636 | desc = vq->vring.desc; | 703 | desc = vq->vring.desc; |
| 637 | i = head; | 704 | i = head; |
| 638 | 705 | ||
| 639 | /* If this is an indirect entry, then this buffer contains a descriptor | 706 | /* |
| 640 | * table which we handle as if it's any normal descriptor chain. */ | 707 | * If this is an indirect entry, then this buffer contains a descriptor |
| 708 | * table which we handle as if it's any normal descriptor chain. | ||
| 709 | */ | ||
| 641 | if (desc[i].flags & VRING_DESC_F_INDIRECT) { | 710 | if (desc[i].flags & VRING_DESC_F_INDIRECT) { |
| 642 | if (desc[i].len % sizeof(struct vring_desc)) | 711 | if (desc[i].len % sizeof(struct vring_desc)) |
| 643 | errx(1, "Invalid size for indirect buffer table"); | 712 | errx(1, "Invalid size for indirect buffer table"); |
| @@ -656,8 +725,10 @@ static unsigned wait_for_vq_desc(struct virtqueue *vq, | |||
| 656 | if (desc[i].flags & VRING_DESC_F_WRITE) | 725 | if (desc[i].flags & VRING_DESC_F_WRITE) |
| 657 | (*in_num)++; | 726 | (*in_num)++; |
| 658 | else { | 727 | else { |
| 659 | /* If it's an output descriptor, they're all supposed | 728 | /* |
| 660 | * to come before any input descriptors. */ | 729 | * If it's an output descriptor, they're all supposed |
| 730 | * to come before any input descriptors. | ||
| 731 | */ | ||
| 661 | if (*in_num) | 732 | if (*in_num) |
| 662 | errx(1, "Descriptor has out after in"); | 733 | errx(1, "Descriptor has out after in"); |
| 663 | (*out_num)++; | 734 | (*out_num)++; |
| @@ -671,14 +742,19 @@ static unsigned wait_for_vq_desc(struct virtqueue *vq, | |||
| 671 | return head; | 742 | return head; |
| 672 | } | 743 | } |
| 673 | 744 | ||
| 674 | /* After we've used one of their buffers, we tell them about it. We'll then | 745 | /* |
| 675 | * want to send them an interrupt, using trigger_irq(). */ | 746 | * After we've used one of their buffers, we tell the Guest about it. Sometime |
| 747 | * later we'll want to send them an interrupt using trigger_irq(); note that | ||
| 748 | * wait_for_vq_desc() does that for us if it has to wait. | ||
| 749 | */ | ||
| 676 | static void add_used(struct virtqueue *vq, unsigned int head, int len) | 750 | static void add_used(struct virtqueue *vq, unsigned int head, int len) |
| 677 | { | 751 | { |
| 678 | struct vring_used_elem *used; | 752 | struct vring_used_elem *used; |
| 679 | 753 | ||
| 680 | /* The virtqueue contains a ring of used buffers. Get a pointer to the | 754 | /* |
| 681 | * next entry in that used ring. */ | 755 | * The virtqueue contains a ring of used buffers. Get a pointer to the |
| 756 | * next entry in that used ring. | ||
| 757 | */ | ||
| 682 | used = &vq->vring.used->ring[vq->vring.used->idx % vq->vring.num]; | 758 | used = &vq->vring.used->ring[vq->vring.used->idx % vq->vring.num]; |
| 683 | used->id = head; | 759 | used->id = head; |
| 684 | used->len = len; | 760 | used->len = len; |
| @@ -698,9 +774,9 @@ static void add_used_and_trigger(struct virtqueue *vq, unsigned head, int len) | |||
| 698 | /* | 774 | /* |
| 699 | * The Console | 775 | * The Console |
| 700 | * | 776 | * |
| 701 | * We associate some data with the console for our exit hack. */ | 777 | * We associate some data with the console for our exit hack. |
| 702 | struct console_abort | 778 | */ |
| 703 | { | 779 | struct console_abort { |
| 704 | /* How many times have they hit ^C? */ | 780 | /* How many times have they hit ^C? */ |
| 705 | int count; | 781 | int count; |
| 706 | /* When did they start? */ | 782 | /* When did they start? */ |
| @@ -715,30 +791,35 @@ static void console_input(struct virtqueue *vq) | |||
| 715 | struct console_abort *abort = vq->dev->priv; | 791 | struct console_abort *abort = vq->dev->priv; |
| 716 | struct iovec iov[vq->vring.num]; | 792 | struct iovec iov[vq->vring.num]; |
| 717 | 793 | ||
| 718 | /* Make sure there's a descriptor waiting. */ | 794 | /* Make sure there's a descriptor available. */ |
| 719 | head = wait_for_vq_desc(vq, iov, &out_num, &in_num); | 795 | head = wait_for_vq_desc(vq, iov, &out_num, &in_num); |
| 720 | if (out_num) | 796 | if (out_num) |
| 721 | errx(1, "Output buffers in console in queue?"); | 797 | errx(1, "Output buffers in console in queue?"); |
| 722 | 798 | ||
| 723 | /* Read it in. */ | 799 | /* Read into it. This is where we usually wait. */ |
| 724 | len = readv(STDIN_FILENO, iov, in_num); | 800 | len = readv(STDIN_FILENO, iov, in_num); |
| 725 | if (len <= 0) { | 801 | if (len <= 0) { |
| 726 | /* Ran out of input? */ | 802 | /* Ran out of input? */ |
| 727 | warnx("Failed to get console input, ignoring console."); | 803 | warnx("Failed to get console input, ignoring console."); |
| 728 | /* For simplicity, dying threads kill the whole Launcher. So | 804 | /* |
| 729 | * just nap here. */ | 805 | * For simplicity, dying threads kill the whole Launcher. So |
| 806 | * just nap here. | ||
| 807 | */ | ||
| 730 | for (;;) | 808 | for (;;) |
| 731 | pause(); | 809 | pause(); |
| 732 | } | 810 | } |
| 733 | 811 | ||
| 812 | /* Tell the Guest we used a buffer. */ | ||
| 734 | add_used_and_trigger(vq, head, len); | 813 | add_used_and_trigger(vq, head, len); |
| 735 | 814 | ||
| 736 | /* Three ^C within one second? Exit. | 815 | /* |
| 816 | * Three ^C within one second? Exit. | ||
| 737 | * | 817 | * |
| 738 | * This is such a hack, but works surprisingly well. Each ^C has to | 818 | * This is such a hack, but works surprisingly well. Each ^C has to |
| 739 | * be in a buffer by itself, so they can't be too fast. But we check | 819 | * be in a buffer by itself, so they can't be too fast. But we check |
| 740 | * that we get three within about a second, so they can't be too | 820 | * that we get three within about a second, so they can't be too |
| 741 | * slow. */ | 821 | * slow. |
| 822 | */ | ||
| 742 | if (len != 1 || ((char *)iov[0].iov_base)[0] != 3) { | 823 | if (len != 1 || ((char *)iov[0].iov_base)[0] != 3) { |
| 743 | abort->count = 0; | 824 | abort->count = 0; |
| 744 | return; | 825 | return; |
| @@ -763,15 +844,23 @@ static void console_output(struct virtqueue *vq) | |||
| 763 | unsigned int head, out, in; | 844 | unsigned int head, out, in; |
| 764 | struct iovec iov[vq->vring.num]; | 845 | struct iovec iov[vq->vring.num]; |
| 765 | 846 | ||
| 847 | /* We usually wait in here, for the Guest to give us something. */ | ||
| 766 | head = wait_for_vq_desc(vq, iov, &out, &in); | 848 | head = wait_for_vq_desc(vq, iov, &out, &in); |
| 767 | if (in) | 849 | if (in) |
| 768 | errx(1, "Input buffers in console output queue?"); | 850 | errx(1, "Input buffers in console output queue?"); |
| 851 | |||
| 852 | /* writev can return a partial write, so we loop here. */ | ||
| 769 | while (!iov_empty(iov, out)) { | 853 | while (!iov_empty(iov, out)) { |
| 770 | int len = writev(STDOUT_FILENO, iov, out); | 854 | int len = writev(STDOUT_FILENO, iov, out); |
| 771 | if (len <= 0) | 855 | if (len <= 0) |
| 772 | err(1, "Write to stdout gave %i", len); | 856 | err(1, "Write to stdout gave %i", len); |
| 773 | iov_consume(iov, out, len); | 857 | iov_consume(iov, out, len); |
| 774 | } | 858 | } |
| 859 | |||
| 860 | /* | ||
| 861 | * We're finished with that buffer: if we're going to sleep, | ||
| 862 | * wait_for_vq_desc() will prod the Guest with an interrupt. | ||
| 863 | */ | ||
| 775 | add_used(vq, head, 0); | 864 | add_used(vq, head, 0); |
| 776 | } | 865 | } |
| 777 | 866 | ||
| @@ -791,15 +880,30 @@ static void net_output(struct virtqueue *vq) | |||
| 791 | unsigned int head, out, in; | 880 | unsigned int head, out, in; |
| 792 | struct iovec iov[vq->vring.num]; | 881 | struct iovec iov[vq->vring.num]; |
| 793 | 882 | ||
| 883 | /* We usually wait in here for the Guest to give us a packet. */ | ||
| 794 | head = wait_for_vq_desc(vq, iov, &out, &in); | 884 | head = wait_for_vq_desc(vq, iov, &out, &in); |
| 795 | if (in) | 885 | if (in) |
| 796 | errx(1, "Input buffers in net output queue?"); | 886 | errx(1, "Input buffers in net output queue?"); |
| 887 | /* | ||
| 888 | * Send the whole thing through to /dev/net/tun. It expects the exact | ||
| 889 | * same format: what a coincidence! | ||
| 890 | */ | ||
| 797 | if (writev(net_info->tunfd, iov, out) < 0) | 891 | if (writev(net_info->tunfd, iov, out) < 0) |
| 798 | errx(1, "Write to tun failed?"); | 892 | errx(1, "Write to tun failed?"); |
| 893 | |||
| 894 | /* | ||
| 895 | * Done with that one; wait_for_vq_desc() will send the interrupt if | ||
| 896 | * all packets are processed. | ||
| 897 | */ | ||
| 799 | add_used(vq, head, 0); | 898 | add_used(vq, head, 0); |
| 800 | } | 899 | } |
| 801 | 900 | ||
| 802 | /* Will reading from this file descriptor block? */ | 901 | /* |
| 902 | * Handling network input is a bit trickier, because I've tried to optimize it. | ||
| 903 | * | ||
| 904 | * First we have a helper routine which tells is if from this file descriptor | ||
| 905 | * (ie. the /dev/net/tun device) will block: | ||
| 906 | */ | ||
| 803 | static bool will_block(int fd) | 907 | static bool will_block(int fd) |
| 804 | { | 908 | { |
| 805 | fd_set fdset; | 909 | fd_set fdset; |
| @@ -809,8 +913,11 @@ static bool will_block(int fd) | |||
| 809 | return select(fd+1, &fdset, NULL, NULL, &zero) != 1; | 913 | return select(fd+1, &fdset, NULL, NULL, &zero) != 1; |
| 810 | } | 914 | } |
| 811 | 915 | ||
| 812 | /* This is where we handle packets coming in from the tun device to our | 916 | /* |
| 813 | * Guest. */ | 917 | * This handles packets coming in from the tun device to our Guest. Like all |
| 918 | * service routines, it gets called again as soon as it returns, so you don't | ||
| 919 | * see a while(1) loop here. | ||
| 920 | */ | ||
| 814 | static void net_input(struct virtqueue *vq) | 921 | static void net_input(struct virtqueue *vq) |
| 815 | { | 922 | { |
| 816 | int len; | 923 | int len; |
| @@ -818,21 +925,38 @@ static void net_input(struct virtqueue *vq) | |||
| 818 | struct iovec iov[vq->vring.num]; | 925 | struct iovec iov[vq->vring.num]; |
| 819 | struct net_info *net_info = vq->dev->priv; | 926 | struct net_info *net_info = vq->dev->priv; |
| 820 | 927 | ||
| 928 | /* | ||
| 929 | * Get a descriptor to write an incoming packet into. This will also | ||
| 930 | * send an interrupt if they're out of descriptors. | ||
| 931 | */ | ||
| 821 | head = wait_for_vq_desc(vq, iov, &out, &in); | 932 | head = wait_for_vq_desc(vq, iov, &out, &in); |
| 822 | if (out) | 933 | if (out) |
| 823 | errx(1, "Output buffers in net input queue?"); | 934 | errx(1, "Output buffers in net input queue?"); |
| 824 | 935 | ||
| 825 | /* Deliver interrupt now, since we're about to sleep. */ | 936 | /* |
| 937 | * If it looks like we'll block reading from the tun device, send them | ||
| 938 | * an interrupt. | ||
| 939 | */ | ||
| 826 | if (vq->pending_used && will_block(net_info->tunfd)) | 940 | if (vq->pending_used && will_block(net_info->tunfd)) |
| 827 | trigger_irq(vq); | 941 | trigger_irq(vq); |
| 828 | 942 | ||
| 943 | /* | ||
| 944 | * Read in the packet. This is where we normally wait (when there's no | ||
| 945 | * incoming network traffic). | ||
| 946 | */ | ||
| 829 | len = readv(net_info->tunfd, iov, in); | 947 | len = readv(net_info->tunfd, iov, in); |
| 830 | if (len <= 0) | 948 | if (len <= 0) |
| 831 | err(1, "Failed to read from tun."); | 949 | err(1, "Failed to read from tun."); |
| 950 | |||
| 951 | /* | ||
| 952 | * Mark that packet buffer as used, but don't interrupt here. We want | ||
| 953 | * to wait until we've done as much work as we can. | ||
| 954 | */ | ||
| 832 | add_used(vq, head, len); | 955 | add_used(vq, head, len); |
| 833 | } | 956 | } |
| 957 | /*:*/ | ||
| 834 | 958 | ||
| 835 | /* This is the helper to create threads. */ | 959 | /* This is the helper to create threads: run the service routine in a loop. */ |
| 836 | static int do_thread(void *_vq) | 960 | static int do_thread(void *_vq) |
| 837 | { | 961 | { |
| 838 | struct virtqueue *vq = _vq; | 962 | struct virtqueue *vq = _vq; |
| @@ -842,8 +966,10 @@ static int do_thread(void *_vq) | |||
| 842 | return 0; | 966 | return 0; |
| 843 | } | 967 | } |
| 844 | 968 | ||
| 845 | /* When a child dies, we kill our entire process group with SIGTERM. This | 969 | /* |
| 846 | * also has the side effect that the shell restores the console for us! */ | 970 | * When a child dies, we kill our entire process group with SIGTERM. This |
| 971 | * also has the side effect that the shell restores the console for us! | ||
| 972 | */ | ||
| 847 | static void kill_launcher(int signal) | 973 | static void kill_launcher(int signal) |
| 848 | { | 974 | { |
| 849 | kill(0, SIGTERM); | 975 | kill(0, SIGTERM); |
| @@ -878,11 +1004,15 @@ static void reset_device(struct device *dev) | |||
| 878 | signal(SIGCHLD, (void *)kill_launcher); | 1004 | signal(SIGCHLD, (void *)kill_launcher); |
| 879 | } | 1005 | } |
| 880 | 1006 | ||
| 1007 | /*L:216 | ||
| 1008 | * This actually creates the thread which services the virtqueue for a device. | ||
| 1009 | */ | ||
| 881 | static void create_thread(struct virtqueue *vq) | 1010 | static void create_thread(struct virtqueue *vq) |
| 882 | { | 1011 | { |
| 883 | /* Create stack for thread and run it. Since stack grows | 1012 | /* |
| 884 | * upwards, we point the stack pointer to the end of this | 1013 | * Create stack for thread. Since the stack grows upwards, we point |
| 885 | * region. */ | 1014 | * the stack pointer to the end of this region. |
| 1015 | */ | ||
| 886 | char *stack = malloc(32768); | 1016 | char *stack = malloc(32768); |
| 887 | unsigned long args[] = { LHREQ_EVENTFD, | 1017 | unsigned long args[] = { LHREQ_EVENTFD, |
| 888 | vq->config.pfn*getpagesize(), 0 }; | 1018 | vq->config.pfn*getpagesize(), 0 }; |
| @@ -893,17 +1023,22 @@ static void create_thread(struct virtqueue *vq) | |||
| 893 | err(1, "Creating eventfd"); | 1023 | err(1, "Creating eventfd"); |
| 894 | args[2] = vq->eventfd; | 1024 | args[2] = vq->eventfd; |
| 895 | 1025 | ||
| 896 | /* Attach an eventfd to this virtqueue: it will go off | 1026 | /* |
| 897 | * when the Guest does an LHCALL_NOTIFY for this vq. */ | 1027 | * Attach an eventfd to this virtqueue: it will go off when the Guest |
| 1028 | * does an LHCALL_NOTIFY for this vq. | ||
| 1029 | */ | ||
| 898 | if (write(lguest_fd, &args, sizeof(args)) != 0) | 1030 | if (write(lguest_fd, &args, sizeof(args)) != 0) |
| 899 | err(1, "Attaching eventfd"); | 1031 | err(1, "Attaching eventfd"); |
| 900 | 1032 | ||
| 901 | /* CLONE_VM: because it has to access the Guest memory, and | 1033 | /* |
| 902 | * SIGCHLD so we get a signal if it dies. */ | 1034 | * CLONE_VM: because it has to access the Guest memory, and SIGCHLD so |
| 1035 | * we get a signal if it dies. | ||
| 1036 | */ | ||
| 903 | vq->thread = clone(do_thread, stack + 32768, CLONE_VM | SIGCHLD, vq); | 1037 | vq->thread = clone(do_thread, stack + 32768, CLONE_VM | SIGCHLD, vq); |
| 904 | if (vq->thread == (pid_t)-1) | 1038 | if (vq->thread == (pid_t)-1) |
| 905 | err(1, "Creating clone"); | 1039 | err(1, "Creating clone"); |
| 906 | /* We close our local copy, now the child has it. */ | 1040 | |
| 1041 | /* We close our local copy now the child has it. */ | ||
| 907 | close(vq->eventfd); | 1042 | close(vq->eventfd); |
| 908 | } | 1043 | } |
| 909 | 1044 | ||
| @@ -955,7 +1090,10 @@ static void update_device_status(struct device *dev) | |||
| 955 | } | 1090 | } |
| 956 | } | 1091 | } |
| 957 | 1092 | ||
| 958 | /* This is the generic routine we call when the Guest uses LHCALL_NOTIFY. */ | 1093 | /*L:215 |
| 1094 | * This is the generic routine we call when the Guest uses LHCALL_NOTIFY. In | ||
| 1095 | * particular, it's used to notify us of device status changes during boot. | ||
| 1096 | */ | ||
| 959 | static void handle_output(unsigned long addr) | 1097 | static void handle_output(unsigned long addr) |
| 960 | { | 1098 | { |
| 961 | struct device *i; | 1099 | struct device *i; |
| @@ -964,25 +1102,42 @@ static void handle_output(unsigned long addr) | |||
| 964 | for (i = devices.dev; i; i = i->next) { | 1102 | for (i = devices.dev; i; i = i->next) { |
| 965 | struct virtqueue *vq; | 1103 | struct virtqueue *vq; |
| 966 | 1104 | ||
| 967 | /* Notifications to device descriptors update device status. */ | 1105 | /* |
| 1106 | * Notifications to device descriptors mean they updated the | ||
| 1107 | * device status. | ||
| 1108 | */ | ||
| 968 | if (from_guest_phys(addr) == i->desc) { | 1109 | if (from_guest_phys(addr) == i->desc) { |
| 969 | update_device_status(i); | 1110 | update_device_status(i); |
| 970 | return; | 1111 | return; |
| 971 | } | 1112 | } |
| 972 | 1113 | ||
| 973 | /* Devices *can* be used before status is set to DRIVER_OK. */ | 1114 | /* |
| 1115 | * Devices *can* be used before status is set to DRIVER_OK. | ||
| 1116 | * The original plan was that they would never do this: they | ||
| 1117 | * would always finish setting up their status bits before | ||
| 1118 | * actually touching the virtqueues. In practice, we allowed | ||
| 1119 | * them to, and they do (eg. the disk probes for partition | ||
| 1120 | * tables as part of initialization). | ||
| 1121 | * | ||
| 1122 | * If we see this, we start the device: once it's running, we | ||
| 1123 | * expect the device to catch all the notifications. | ||
| 1124 | */ | ||
| 974 | for (vq = i->vq; vq; vq = vq->next) { | 1125 | for (vq = i->vq; vq; vq = vq->next) { |
| 975 | if (addr != vq->config.pfn*getpagesize()) | 1126 | if (addr != vq->config.pfn*getpagesize()) |
| 976 | continue; | 1127 | continue; |
| 977 | if (i->running) | 1128 | if (i->running) |
| 978 | errx(1, "Notification on running %s", i->name); | 1129 | errx(1, "Notification on running %s", i->name); |
| 1130 | /* This just calls create_thread() for each virtqueue */ | ||
| 979 | start_device(i); | 1131 | start_device(i); |
| 980 | return; | 1132 | return; |
| 981 | } | 1133 | } |
| 982 | } | 1134 | } |
| 983 | 1135 | ||
| 984 | /* Early console write is done using notify on a nul-terminated string | 1136 | /* |
| 985 | * in Guest memory. */ | 1137 | * Early console write is done using notify on a nul-terminated string |
| 1138 | * in Guest memory. It's also great for hacking debugging messages | ||
| 1139 | * into a Guest. | ||
| 1140 | */ | ||
| 986 | if (addr >= guest_limit) | 1141 | if (addr >= guest_limit) |
| 987 | errx(1, "Bad NOTIFY %#lx", addr); | 1142 | errx(1, "Bad NOTIFY %#lx", addr); |
| 988 | 1143 | ||
| @@ -998,10 +1153,12 @@ static void handle_output(unsigned long addr) | |||
| 998 | * routines to allocate and manage them. | 1153 | * routines to allocate and manage them. |
| 999 | */ | 1154 | */ |
| 1000 | 1155 | ||
| 1001 | /* The layout of the device page is a "struct lguest_device_desc" followed by a | 1156 | /* |
| 1157 | * The layout of the device page is a "struct lguest_device_desc" followed by a | ||
| 1002 | * number of virtqueue descriptors, then two sets of feature bits, then an | 1158 | * number of virtqueue descriptors, then two sets of feature bits, then an |
| 1003 | * array of configuration bytes. This routine returns the configuration | 1159 | * array of configuration bytes. This routine returns the configuration |
| 1004 | * pointer. */ | 1160 | * pointer. |
| 1161 | */ | ||
| 1005 | static u8 *device_config(const struct device *dev) | 1162 | static u8 *device_config(const struct device *dev) |
| 1006 | { | 1163 | { |
| 1007 | return (void *)(dev->desc + 1) | 1164 | return (void *)(dev->desc + 1) |
| @@ -1009,9 +1166,11 @@ static u8 *device_config(const struct device *dev) | |||
| 1009 | + dev->feature_len * 2; | 1166 | + dev->feature_len * 2; |
| 1010 | } | 1167 | } |
| 1011 | 1168 | ||
| 1012 | /* This routine allocates a new "struct lguest_device_desc" from descriptor | 1169 | /* |
| 1170 | * This routine allocates a new "struct lguest_device_desc" from descriptor | ||
| 1013 | * table page just above the Guest's normal memory. It returns a pointer to | 1171 | * table page just above the Guest's normal memory. It returns a pointer to |
| 1014 | * that descriptor. */ | 1172 | * that descriptor. |
| 1173 | */ | ||
| 1015 | static struct lguest_device_desc *new_dev_desc(u16 type) | 1174 | static struct lguest_device_desc *new_dev_desc(u16 type) |
| 1016 | { | 1175 | { |
| 1017 | struct lguest_device_desc d = { .type = type }; | 1176 | struct lguest_device_desc d = { .type = type }; |
| @@ -1032,8 +1191,10 @@ static struct lguest_device_desc *new_dev_desc(u16 type) | |||
| 1032 | return memcpy(p, &d, sizeof(d)); | 1191 | return memcpy(p, &d, sizeof(d)); |
| 1033 | } | 1192 | } |
| 1034 | 1193 | ||
| 1035 | /* Each device descriptor is followed by the description of its virtqueues. We | 1194 | /* |
| 1036 | * specify how many descriptors the virtqueue is to have. */ | 1195 | * Each device descriptor is followed by the description of its virtqueues. We |
| 1196 | * specify how many descriptors the virtqueue is to have. | ||
| 1197 | */ | ||
| 1037 | static void add_virtqueue(struct device *dev, unsigned int num_descs, | 1198 | static void add_virtqueue(struct device *dev, unsigned int num_descs, |
| 1038 | void (*service)(struct virtqueue *)) | 1199 | void (*service)(struct virtqueue *)) |
| 1039 | { | 1200 | { |
| @@ -1050,6 +1211,11 @@ static void add_virtqueue(struct device *dev, unsigned int num_descs, | |||
| 1050 | vq->next = NULL; | 1211 | vq->next = NULL; |
| 1051 | vq->last_avail_idx = 0; | 1212 | vq->last_avail_idx = 0; |
| 1052 | vq->dev = dev; | 1213 | vq->dev = dev; |
| 1214 | |||
| 1215 | /* | ||
| 1216 | * This is the routine the service thread will run, and its Process ID | ||
| 1217 | * once it's running. | ||
| 1218 | */ | ||
| 1053 | vq->service = service; | 1219 | vq->service = service; |
| 1054 | vq->thread = (pid_t)-1; | 1220 | vq->thread = (pid_t)-1; |
| 1055 | 1221 | ||
| @@ -1061,10 +1227,12 @@ static void add_virtqueue(struct device *dev, unsigned int num_descs, | |||
| 1061 | /* Initialize the vring. */ | 1227 | /* Initialize the vring. */ |
| 1062 | vring_init(&vq->vring, num_descs, p, LGUEST_VRING_ALIGN); | 1228 | vring_init(&vq->vring, num_descs, p, LGUEST_VRING_ALIGN); |
| 1063 | 1229 | ||
| 1064 | /* Append virtqueue to this device's descriptor. We use | 1230 | /* |
| 1231 | * Append virtqueue to this device's descriptor. We use | ||
| 1065 | * device_config() to get the end of the device's current virtqueues; | 1232 | * device_config() to get the end of the device's current virtqueues; |
| 1066 | * we check that we haven't added any config or feature information | 1233 | * we check that we haven't added any config or feature information |
| 1067 | * yet, otherwise we'd be overwriting them. */ | 1234 | * yet, otherwise we'd be overwriting them. |
| 1235 | */ | ||
| 1068 | assert(dev->desc->config_len == 0 && dev->desc->feature_len == 0); | 1236 | assert(dev->desc->config_len == 0 && dev->desc->feature_len == 0); |
| 1069 | memcpy(device_config(dev), &vq->config, sizeof(vq->config)); | 1237 | memcpy(device_config(dev), &vq->config, sizeof(vq->config)); |
| 1070 | dev->num_vq++; | 1238 | dev->num_vq++; |
| @@ -1072,14 +1240,18 @@ static void add_virtqueue(struct device *dev, unsigned int num_descs, | |||
| 1072 | 1240 | ||
| 1073 | verbose("Virtqueue page %#lx\n", to_guest_phys(p)); | 1241 | verbose("Virtqueue page %#lx\n", to_guest_phys(p)); |
| 1074 | 1242 | ||
| 1075 | /* Add to tail of list, so dev->vq is first vq, dev->vq->next is | 1243 | /* |
| 1076 | * second. */ | 1244 | * Add to tail of list, so dev->vq is first vq, dev->vq->next is |
| 1245 | * second. | ||
| 1246 | */ | ||
| 1077 | for (i = &dev->vq; *i; i = &(*i)->next); | 1247 | for (i = &dev->vq; *i; i = &(*i)->next); |
| 1078 | *i = vq; | 1248 | *i = vq; |
| 1079 | } | 1249 | } |
| 1080 | 1250 | ||
| 1081 | /* The first half of the feature bitmask is for us to advertise features. The | 1251 | /* |
| 1082 | * second half is for the Guest to accept features. */ | 1252 | * The first half of the feature bitmask is for us to advertise features. The |
| 1253 | * second half is for the Guest to accept features. | ||
| 1254 | */ | ||
| 1083 | static void add_feature(struct device *dev, unsigned bit) | 1255 | static void add_feature(struct device *dev, unsigned bit) |
| 1084 | { | 1256 | { |
| 1085 | u8 *features = get_feature_bits(dev); | 1257 | u8 *features = get_feature_bits(dev); |
| @@ -1093,9 +1265,11 @@ static void add_feature(struct device *dev, unsigned bit) | |||
| 1093 | features[bit / CHAR_BIT] |= (1 << (bit % CHAR_BIT)); | 1265 | features[bit / CHAR_BIT] |= (1 << (bit % CHAR_BIT)); |
| 1094 | } | 1266 | } |
| 1095 | 1267 | ||
| 1096 | /* This routine sets the configuration fields for an existing device's | 1268 | /* |
| 1269 | * This routine sets the configuration fields for an existing device's | ||
| 1097 | * descriptor. It only works for the last device, but that's OK because that's | 1270 | * descriptor. It only works for the last device, but that's OK because that's |
| 1098 | * how we use it. */ | 1271 | * how we use it. |
| 1272 | */ | ||
| 1099 | static void set_config(struct device *dev, unsigned len, const void *conf) | 1273 | static void set_config(struct device *dev, unsigned len, const void *conf) |
| 1100 | { | 1274 | { |
| 1101 | /* Check we haven't overflowed our single page. */ | 1275 | /* Check we haven't overflowed our single page. */ |
| @@ -1105,12 +1279,18 @@ static void set_config(struct device *dev, unsigned len, const void *conf) | |||
| 1105 | /* Copy in the config information, and store the length. */ | 1279 | /* Copy in the config information, and store the length. */ |
| 1106 | memcpy(device_config(dev), conf, len); | 1280 | memcpy(device_config(dev), conf, len); |
| 1107 | dev->desc->config_len = len; | 1281 | dev->desc->config_len = len; |
| 1282 | |||
| 1283 | /* Size must fit in config_len field (8 bits)! */ | ||
| 1284 | assert(dev->desc->config_len == len); | ||
| 1108 | } | 1285 | } |
| 1109 | 1286 | ||
| 1110 | /* This routine does all the creation and setup of a new device, including | 1287 | /* |
| 1111 | * calling new_dev_desc() to allocate the descriptor and device memory. | 1288 | * This routine does all the creation and setup of a new device, including |
| 1289 | * calling new_dev_desc() to allocate the descriptor and device memory. We | ||
| 1290 | * don't actually start the service threads until later. | ||
| 1112 | * | 1291 | * |
| 1113 | * See what I mean about userspace being boring? */ | 1292 | * See what I mean about userspace being boring? |
| 1293 | */ | ||
| 1114 | static struct device *new_device(const char *name, u16 type) | 1294 | static struct device *new_device(const char *name, u16 type) |
| 1115 | { | 1295 | { |
| 1116 | struct device *dev = malloc(sizeof(*dev)); | 1296 | struct device *dev = malloc(sizeof(*dev)); |
| @@ -1123,10 +1303,12 @@ static struct device *new_device(const char *name, u16 type) | |||
| 1123 | dev->num_vq = 0; | 1303 | dev->num_vq = 0; |
| 1124 | dev->running = false; | 1304 | dev->running = false; |
| 1125 | 1305 | ||
| 1126 | /* Append to device list. Prepending to a single-linked list is | 1306 | /* |
| 1307 | * Append to device list. Prepending to a single-linked list is | ||
| 1127 | * easier, but the user expects the devices to be arranged on the bus | 1308 | * easier, but the user expects the devices to be arranged on the bus |
| 1128 | * in command-line order. The first network device on the command line | 1309 | * in command-line order. The first network device on the command line |
| 1129 | * is eth0, the first block device /dev/vda, etc. */ | 1310 | * is eth0, the first block device /dev/vda, etc. |
| 1311 | */ | ||
| 1130 | if (devices.lastdev) | 1312 | if (devices.lastdev) |
| 1131 | devices.lastdev->next = dev; | 1313 | devices.lastdev->next = dev; |
| 1132 | else | 1314 | else |
| @@ -1136,8 +1318,10 @@ static struct device *new_device(const char *name, u16 type) | |||
| 1136 | return dev; | 1318 | return dev; |
| 1137 | } | 1319 | } |
| 1138 | 1320 | ||
| 1139 | /* Our first setup routine is the console. It's a fairly simple device, but | 1321 | /* |
| 1140 | * UNIX tty handling makes it uglier than it could be. */ | 1322 | * Our first setup routine is the console. It's a fairly simple device, but |
| 1323 | * UNIX tty handling makes it uglier than it could be. | ||
| 1324 | */ | ||
| 1141 | static void setup_console(void) | 1325 | static void setup_console(void) |
| 1142 | { | 1326 | { |
| 1143 | struct device *dev; | 1327 | struct device *dev; |
| @@ -1145,8 +1329,10 @@ static void setup_console(void) | |||
| 1145 | /* If we can save the initial standard input settings... */ | 1329 | /* If we can save the initial standard input settings... */ |
| 1146 | if (tcgetattr(STDIN_FILENO, &orig_term) == 0) { | 1330 | if (tcgetattr(STDIN_FILENO, &orig_term) == 0) { |
| 1147 | struct termios term = orig_term; | 1331 | struct termios term = orig_term; |
| 1148 | /* Then we turn off echo, line buffering and ^C etc. We want a | 1332 | /* |
| 1149 | * raw input stream to the Guest. */ | 1333 | * Then we turn off echo, line buffering and ^C etc: We want a |
| 1334 | * raw input stream to the Guest. | ||
| 1335 | */ | ||
| 1150 | term.c_lflag &= ~(ISIG|ICANON|ECHO); | 1336 | term.c_lflag &= ~(ISIG|ICANON|ECHO); |
| 1151 | tcsetattr(STDIN_FILENO, TCSANOW, &term); | 1337 | tcsetattr(STDIN_FILENO, TCSANOW, &term); |
| 1152 | } | 1338 | } |
| @@ -1157,10 +1343,12 @@ static void setup_console(void) | |||
| 1157 | dev->priv = malloc(sizeof(struct console_abort)); | 1343 | dev->priv = malloc(sizeof(struct console_abort)); |
| 1158 | ((struct console_abort *)dev->priv)->count = 0; | 1344 | ((struct console_abort *)dev->priv)->count = 0; |
| 1159 | 1345 | ||
| 1160 | /* The console needs two virtqueues: the input then the output. When | 1346 | /* |
| 1347 | * The console needs two virtqueues: the input then the output. When | ||
| 1161 | * they put something the input queue, we make sure we're listening to | 1348 | * they put something the input queue, we make sure we're listening to |
| 1162 | * stdin. When they put something in the output queue, we write it to | 1349 | * stdin. When they put something in the output queue, we write it to |
| 1163 | * stdout. */ | 1350 | * stdout. |
| 1351 | */ | ||
| 1164 | add_virtqueue(dev, VIRTQUEUE_NUM, console_input); | 1352 | add_virtqueue(dev, VIRTQUEUE_NUM, console_input); |
| 1165 | add_virtqueue(dev, VIRTQUEUE_NUM, console_output); | 1353 | add_virtqueue(dev, VIRTQUEUE_NUM, console_output); |
| 1166 | 1354 | ||
| @@ -1168,7 +1356,8 @@ static void setup_console(void) | |||
| 1168 | } | 1356 | } |
| 1169 | /*:*/ | 1357 | /*:*/ |
| 1170 | 1358 | ||
| 1171 | /*M:010 Inter-guest networking is an interesting area. Simplest is to have a | 1359 | /*M:010 |
| 1360 | * Inter-guest networking is an interesting area. Simplest is to have a | ||
| 1172 | * --sharenet=<name> option which opens or creates a named pipe. This can be | 1361 | * --sharenet=<name> option which opens or creates a named pipe. This can be |
| 1173 | * used to send packets to another guest in a 1:1 manner. | 1362 | * used to send packets to another guest in a 1:1 manner. |
| 1174 | * | 1363 | * |
| @@ -1182,7 +1371,8 @@ static void setup_console(void) | |||
| 1182 | * multiple inter-guest channels behind one interface, although it would | 1371 | * multiple inter-guest channels behind one interface, although it would |
| 1183 | * require some manner of hotplugging new virtio channels. | 1372 | * require some manner of hotplugging new virtio channels. |
| 1184 | * | 1373 | * |
| 1185 | * Finally, we could implement a virtio network switch in the kernel. :*/ | 1374 | * Finally, we could implement a virtio network switch in the kernel. |
| 1375 | :*/ | ||
| 1186 | 1376 | ||
| 1187 | static u32 str2ip(const char *ipaddr) | 1377 | static u32 str2ip(const char *ipaddr) |
| 1188 | { | 1378 | { |
| @@ -1207,11 +1397,13 @@ static void str2mac(const char *macaddr, unsigned char mac[6]) | |||
| 1207 | mac[5] = m[5]; | 1397 | mac[5] = m[5]; |
| 1208 | } | 1398 | } |
| 1209 | 1399 | ||
| 1210 | /* This code is "adapted" from libbridge: it attaches the Host end of the | 1400 | /* |
| 1401 | * This code is "adapted" from libbridge: it attaches the Host end of the | ||
| 1211 | * network device to the bridge device specified by the command line. | 1402 | * network device to the bridge device specified by the command line. |
| 1212 | * | 1403 | * |
| 1213 | * This is yet another James Morris contribution (I'm an IP-level guy, so I | 1404 | * This is yet another James Morris contribution (I'm an IP-level guy, so I |
| 1214 | * dislike bridging), and I just try not to break it. */ | 1405 | * dislike bridging), and I just try not to break it. |
| 1406 | */ | ||
| 1215 | static void add_to_bridge(int fd, const char *if_name, const char *br_name) | 1407 | static void add_to_bridge(int fd, const char *if_name, const char *br_name) |
| 1216 | { | 1408 | { |
| 1217 | int ifidx; | 1409 | int ifidx; |
| @@ -1231,9 +1423,11 @@ static void add_to_bridge(int fd, const char *if_name, const char *br_name) | |||
| 1231 | err(1, "can't add %s to bridge %s", if_name, br_name); | 1423 | err(1, "can't add %s to bridge %s", if_name, br_name); |
| 1232 | } | 1424 | } |
| 1233 | 1425 | ||
| 1234 | /* This sets up the Host end of the network device with an IP address, brings | 1426 | /* |
| 1427 | * This sets up the Host end of the network device with an IP address, brings | ||
| 1235 | * it up so packets will flow, the copies the MAC address into the hwaddr | 1428 | * it up so packets will flow, the copies the MAC address into the hwaddr |
| 1236 | * pointer. */ | 1429 | * pointer. |
| 1430 | */ | ||
| 1237 | static void configure_device(int fd, const char *tapif, u32 ipaddr) | 1431 | static void configure_device(int fd, const char *tapif, u32 ipaddr) |
| 1238 | { | 1432 | { |
| 1239 | struct ifreq ifr; | 1433 | struct ifreq ifr; |
| @@ -1260,10 +1454,12 @@ static int get_tun_device(char tapif[IFNAMSIZ]) | |||
| 1260 | /* Start with this zeroed. Messy but sure. */ | 1454 | /* Start with this zeroed. Messy but sure. */ |
| 1261 | memset(&ifr, 0, sizeof(ifr)); | 1455 | memset(&ifr, 0, sizeof(ifr)); |
| 1262 | 1456 | ||
| 1263 | /* We open the /dev/net/tun device and tell it we want a tap device. A | 1457 | /* |
| 1458 | * We open the /dev/net/tun device and tell it we want a tap device. A | ||
| 1264 | * tap device is like a tun device, only somehow different. To tell | 1459 | * tap device is like a tun device, only somehow different. To tell |
| 1265 | * the truth, I completely blundered my way through this code, but it | 1460 | * the truth, I completely blundered my way through this code, but it |
| 1266 | * works now! */ | 1461 | * works now! |
| 1462 | */ | ||
| 1267 | netfd = open_or_die("/dev/net/tun", O_RDWR); | 1463 | netfd = open_or_die("/dev/net/tun", O_RDWR); |
| 1268 | ifr.ifr_flags = IFF_TAP | IFF_NO_PI | IFF_VNET_HDR; | 1464 | ifr.ifr_flags = IFF_TAP | IFF_NO_PI | IFF_VNET_HDR; |
| 1269 | strcpy(ifr.ifr_name, "tap%d"); | 1465 | strcpy(ifr.ifr_name, "tap%d"); |
| @@ -1274,18 +1470,22 @@ static int get_tun_device(char tapif[IFNAMSIZ]) | |||
| 1274 | TUN_F_CSUM|TUN_F_TSO4|TUN_F_TSO6|TUN_F_TSO_ECN) != 0) | 1470 | TUN_F_CSUM|TUN_F_TSO4|TUN_F_TSO6|TUN_F_TSO_ECN) != 0) |
| 1275 | err(1, "Could not set features for tun device"); | 1471 | err(1, "Could not set features for tun device"); |
| 1276 | 1472 | ||
| 1277 | /* We don't need checksums calculated for packets coming in this | 1473 | /* |
| 1278 | * device: trust us! */ | 1474 | * We don't need checksums calculated for packets coming in this |
| 1475 | * device: trust us! | ||
| 1476 | */ | ||
| 1279 | ioctl(netfd, TUNSETNOCSUM, 1); | 1477 | ioctl(netfd, TUNSETNOCSUM, 1); |
| 1280 | 1478 | ||
| 1281 | memcpy(tapif, ifr.ifr_name, IFNAMSIZ); | 1479 | memcpy(tapif, ifr.ifr_name, IFNAMSIZ); |
| 1282 | return netfd; | 1480 | return netfd; |
| 1283 | } | 1481 | } |
| 1284 | 1482 | ||
| 1285 | /*L:195 Our network is a Host<->Guest network. This can either use bridging or | 1483 | /*L:195 |
| 1484 | * Our network is a Host<->Guest network. This can either use bridging or | ||
| 1286 | * routing, but the principle is the same: it uses the "tun" device to inject | 1485 | * routing, but the principle is the same: it uses the "tun" device to inject |
| 1287 | * packets into the Host as if they came in from a normal network card. We | 1486 | * packets into the Host as if they came in from a normal network card. We |
| 1288 | * just shunt packets between the Guest and the tun device. */ | 1487 | * just shunt packets between the Guest and the tun device. |
| 1488 | */ | ||
| 1289 | static void setup_tun_net(char *arg) | 1489 | static void setup_tun_net(char *arg) |
| 1290 | { | 1490 | { |
| 1291 | struct device *dev; | 1491 | struct device *dev; |
| @@ -1302,13 +1502,14 @@ static void setup_tun_net(char *arg) | |||
| 1302 | dev = new_device("net", VIRTIO_ID_NET); | 1502 | dev = new_device("net", VIRTIO_ID_NET); |
| 1303 | dev->priv = net_info; | 1503 | dev->priv = net_info; |
| 1304 | 1504 | ||
| 1305 | /* Network devices need a receive and a send queue, just like | 1505 | /* Network devices need a recv and a send queue, just like console. */ |
| 1306 | * console. */ | ||
| 1307 | add_virtqueue(dev, VIRTQUEUE_NUM, net_input); | 1506 | add_virtqueue(dev, VIRTQUEUE_NUM, net_input); |
| 1308 | add_virtqueue(dev, VIRTQUEUE_NUM, net_output); | 1507 | add_virtqueue(dev, VIRTQUEUE_NUM, net_output); |
| 1309 | 1508 | ||
| 1310 | /* We need a socket to perform the magic network ioctls to bring up the | 1509 | /* |
| 1311 | * tap interface, connect to the bridge etc. Any socket will do! */ | 1510 | * We need a socket to perform the magic network ioctls to bring up the |
| 1511 | * tap interface, connect to the bridge etc. Any socket will do! | ||
| 1512 | */ | ||
| 1312 | ipfd = socket(PF_INET, SOCK_DGRAM, IPPROTO_IP); | 1513 | ipfd = socket(PF_INET, SOCK_DGRAM, IPPROTO_IP); |
| 1313 | if (ipfd < 0) | 1514 | if (ipfd < 0) |
| 1314 | err(1, "opening IP socket"); | 1515 | err(1, "opening IP socket"); |
| @@ -1362,39 +1563,31 @@ static void setup_tun_net(char *arg) | |||
| 1362 | verbose("device %u: tun %s: %s\n", | 1563 | verbose("device %u: tun %s: %s\n", |
| 1363 | devices.device_num, tapif, arg); | 1564 | devices.device_num, tapif, arg); |
| 1364 | } | 1565 | } |
| 1365 | 1566 | /*:*/ | |
| 1366 | /* Our block (disk) device should be really simple: the Guest asks for a block | ||
| 1367 | * number and we read or write that position in the file. Unfortunately, that | ||
| 1368 | * was amazingly slow: the Guest waits until the read is finished before | ||
| 1369 | * running anything else, even if it could have been doing useful work. | ||
| 1370 | * | ||
| 1371 | * We could use async I/O, except it's reputed to suck so hard that characters | ||
| 1372 | * actually go missing from your code when you try to use it. | ||
| 1373 | * | ||
| 1374 | * So we farm the I/O out to thread, and communicate with it via a pipe. */ | ||
| 1375 | 1567 | ||
| 1376 | /* This hangs off device->priv. */ | 1568 | /* This hangs off device->priv. */ |
| 1377 | struct vblk_info | 1569 | struct vblk_info { |
| 1378 | { | ||
| 1379 | /* The size of the file. */ | 1570 | /* The size of the file. */ |
| 1380 | off64_t len; | 1571 | off64_t len; |
| 1381 | 1572 | ||
| 1382 | /* The file descriptor for the file. */ | 1573 | /* The file descriptor for the file. */ |
| 1383 | int fd; | 1574 | int fd; |
| 1384 | 1575 | ||
| 1385 | /* IO thread listens on this file descriptor [0]. */ | ||
| 1386 | int workpipe[2]; | ||
| 1387 | |||
| 1388 | /* IO thread writes to this file descriptor to mark it done, then | ||
| 1389 | * Launcher triggers interrupt to Guest. */ | ||
| 1390 | int done_fd; | ||
| 1391 | }; | 1576 | }; |
| 1392 | 1577 | ||
| 1393 | /*L:210 | 1578 | /*L:210 |
| 1394 | * The Disk | 1579 | * The Disk |
| 1395 | * | 1580 | * |
| 1396 | * Remember that the block device is handled by a separate I/O thread. We head | 1581 | * The disk only has one virtqueue, so it only has one thread. It is really |
| 1397 | * straight into the core of that thread here: | 1582 | * simple: the Guest asks for a block number and we read or write that position |
| 1583 | * in the file. | ||
| 1584 | * | ||
| 1585 | * Before we serviced each virtqueue in a separate thread, that was unacceptably | ||
| 1586 | * slow: the Guest waits until the read is finished before running anything | ||
| 1587 | * else, even if it could have been doing useful work. | ||
| 1588 | * | ||
| 1589 | * We could have used async I/O, except it's reputed to suck so hard that | ||
| 1590 | * characters actually go missing from your code when you try to use it. | ||
| 1398 | */ | 1591 | */ |
| 1399 | static void blk_request(struct virtqueue *vq) | 1592 | static void blk_request(struct virtqueue *vq) |
| 1400 | { | 1593 | { |
| @@ -1406,47 +1599,64 @@ static void blk_request(struct virtqueue *vq) | |||
| 1406 | struct iovec iov[vq->vring.num]; | 1599 | struct iovec iov[vq->vring.num]; |
| 1407 | off64_t off; | 1600 | off64_t off; |
| 1408 | 1601 | ||
| 1409 | /* Get the next request. */ | 1602 | /* |
| 1603 | * Get the next request, where we normally wait. It triggers the | ||
| 1604 | * interrupt to acknowledge previously serviced requests (if any). | ||
| 1605 | */ | ||
| 1410 | head = wait_for_vq_desc(vq, iov, &out_num, &in_num); | 1606 | head = wait_for_vq_desc(vq, iov, &out_num, &in_num); |
| 1411 | 1607 | ||
| 1412 | /* Every block request should contain at least one output buffer | 1608 | /* |
| 1609 | * Every block request should contain at least one output buffer | ||
| 1413 | * (detailing the location on disk and the type of request) and one | 1610 | * (detailing the location on disk and the type of request) and one |
| 1414 | * input buffer (to hold the result). */ | 1611 | * input buffer (to hold the result). |
| 1612 | */ | ||
| 1415 | if (out_num == 0 || in_num == 0) | 1613 | if (out_num == 0 || in_num == 0) |
| 1416 | errx(1, "Bad virtblk cmd %u out=%u in=%u", | 1614 | errx(1, "Bad virtblk cmd %u out=%u in=%u", |
| 1417 | head, out_num, in_num); | 1615 | head, out_num, in_num); |
| 1418 | 1616 | ||
| 1419 | out = convert(&iov[0], struct virtio_blk_outhdr); | 1617 | out = convert(&iov[0], struct virtio_blk_outhdr); |
| 1420 | in = convert(&iov[out_num+in_num-1], u8); | 1618 | in = convert(&iov[out_num+in_num-1], u8); |
| 1619 | /* | ||
| 1620 | * For historical reasons, block operations are expressed in 512 byte | ||
| 1621 | * "sectors". | ||
| 1622 | */ | ||
| 1421 | off = out->sector * 512; | 1623 | off = out->sector * 512; |
| 1422 | 1624 | ||
| 1423 | /* The block device implements "barriers", where the Guest indicates | 1625 | /* |
| 1626 | * The block device implements "barriers", where the Guest indicates | ||
| 1424 | * that it wants all previous writes to occur before this write. We | 1627 | * that it wants all previous writes to occur before this write. We |
| 1425 | * don't have a way of asking our kernel to do a barrier, so we just | 1628 | * don't have a way of asking our kernel to do a barrier, so we just |
| 1426 | * synchronize all the data in the file. Pretty poor, no? */ | 1629 | * synchronize all the data in the file. Pretty poor, no? |
| 1630 | */ | ||
| 1427 | if (out->type & VIRTIO_BLK_T_BARRIER) | 1631 | if (out->type & VIRTIO_BLK_T_BARRIER) |
| 1428 | fdatasync(vblk->fd); | 1632 | fdatasync(vblk->fd); |
| 1429 | 1633 | ||
| 1430 | /* In general the virtio block driver is allowed to try SCSI commands. | 1634 | /* |
| 1431 | * It'd be nice if we supported eject, for example, but we don't. */ | 1635 | * In general the virtio block driver is allowed to try SCSI commands. |
| 1636 | * It'd be nice if we supported eject, for example, but we don't. | ||
| 1637 | */ | ||
| 1432 | if (out->type & VIRTIO_BLK_T_SCSI_CMD) { | 1638 | if (out->type & VIRTIO_BLK_T_SCSI_CMD) { |
| 1433 | fprintf(stderr, "Scsi commands unsupported\n"); | 1639 | fprintf(stderr, "Scsi commands unsupported\n"); |
| 1434 | *in = VIRTIO_BLK_S_UNSUPP; | 1640 | *in = VIRTIO_BLK_S_UNSUPP; |
| 1435 | wlen = sizeof(*in); | 1641 | wlen = sizeof(*in); |
| 1436 | } else if (out->type & VIRTIO_BLK_T_OUT) { | 1642 | } else if (out->type & VIRTIO_BLK_T_OUT) { |
| 1437 | /* Write */ | 1643 | /* |
| 1438 | 1644 | * Write | |
| 1439 | /* Move to the right location in the block file. This can fail | 1645 | * |
| 1440 | * if they try to write past end. */ | 1646 | * Move to the right location in the block file. This can fail |
| 1647 | * if they try to write past end. | ||
| 1648 | */ | ||
| 1441 | if (lseek64(vblk->fd, off, SEEK_SET) != off) | 1649 | if (lseek64(vblk->fd, off, SEEK_SET) != off) |
| 1442 | err(1, "Bad seek to sector %llu", out->sector); | 1650 | err(1, "Bad seek to sector %llu", out->sector); |
| 1443 | 1651 | ||
| 1444 | ret = writev(vblk->fd, iov+1, out_num-1); | 1652 | ret = writev(vblk->fd, iov+1, out_num-1); |
| 1445 | verbose("WRITE to sector %llu: %i\n", out->sector, ret); | 1653 | verbose("WRITE to sector %llu: %i\n", out->sector, ret); |
| 1446 | 1654 | ||
| 1447 | /* Grr... Now we know how long the descriptor they sent was, we | 1655 | /* |
| 1656 | * Grr... Now we know how long the descriptor they sent was, we | ||
| 1448 | * make sure they didn't try to write over the end of the block | 1657 | * make sure they didn't try to write over the end of the block |
| 1449 | * file (possibly extending it). */ | 1658 | * file (possibly extending it). |
| 1659 | */ | ||
| 1450 | if (ret > 0 && off + ret > vblk->len) { | 1660 | if (ret > 0 && off + ret > vblk->len) { |
| 1451 | /* Trim it back to the correct length */ | 1661 | /* Trim it back to the correct length */ |
| 1452 | ftruncate64(vblk->fd, vblk->len); | 1662 | ftruncate64(vblk->fd, vblk->len); |
| @@ -1456,10 +1666,12 @@ static void blk_request(struct virtqueue *vq) | |||
| 1456 | wlen = sizeof(*in); | 1666 | wlen = sizeof(*in); |
| 1457 | *in = (ret >= 0 ? VIRTIO_BLK_S_OK : VIRTIO_BLK_S_IOERR); | 1667 | *in = (ret >= 0 ? VIRTIO_BLK_S_OK : VIRTIO_BLK_S_IOERR); |
| 1458 | } else { | 1668 | } else { |
| 1459 | /* Read */ | 1669 | /* |
| 1460 | 1670 | * Read | |
| 1461 | /* Move to the right location in the block file. This can fail | 1671 | * |
| 1462 | * if they try to read past end. */ | 1672 | * Move to the right location in the block file. This can fail |
| 1673 | * if they try to read past end. | ||
| 1674 | */ | ||
| 1463 | if (lseek64(vblk->fd, off, SEEK_SET) != off) | 1675 | if (lseek64(vblk->fd, off, SEEK_SET) != off) |
| 1464 | err(1, "Bad seek to sector %llu", out->sector); | 1676 | err(1, "Bad seek to sector %llu", out->sector); |
| 1465 | 1677 | ||
| @@ -1474,13 +1686,16 @@ static void blk_request(struct virtqueue *vq) | |||
| 1474 | } | 1686 | } |
| 1475 | } | 1687 | } |
| 1476 | 1688 | ||
| 1477 | /* OK, so we noted that it was pretty poor to use an fdatasync as a | 1689 | /* |
| 1690 | * OK, so we noted that it was pretty poor to use an fdatasync as a | ||
| 1478 | * barrier. But Christoph Hellwig points out that we need a sync | 1691 | * barrier. But Christoph Hellwig points out that we need a sync |
| 1479 | * *afterwards* as well: "Barriers specify no reordering to the front | 1692 | * *afterwards* as well: "Barriers specify no reordering to the front |
| 1480 | * or the back." And Jens Axboe confirmed it, so here we are: */ | 1693 | * or the back." And Jens Axboe confirmed it, so here we are: |
| 1694 | */ | ||
| 1481 | if (out->type & VIRTIO_BLK_T_BARRIER) | 1695 | if (out->type & VIRTIO_BLK_T_BARRIER) |
| 1482 | fdatasync(vblk->fd); | 1696 | fdatasync(vblk->fd); |
| 1483 | 1697 | ||
| 1698 | /* Finished that request. */ | ||
| 1484 | add_used(vq, head, wlen); | 1699 | add_used(vq, head, wlen); |
| 1485 | } | 1700 | } |
| 1486 | 1701 | ||
| @@ -1491,7 +1706,7 @@ static void setup_block_file(const char *filename) | |||
| 1491 | struct vblk_info *vblk; | 1706 | struct vblk_info *vblk; |
| 1492 | struct virtio_blk_config conf; | 1707 | struct virtio_blk_config conf; |
| 1493 | 1708 | ||
| 1494 | /* The device responds to return from I/O thread. */ | 1709 | /* Creat the device. */ |
| 1495 | dev = new_device("block", VIRTIO_ID_BLOCK); | 1710 | dev = new_device("block", VIRTIO_ID_BLOCK); |
| 1496 | 1711 | ||
| 1497 | /* The device has one virtqueue, where the Guest places requests. */ | 1712 | /* The device has one virtqueue, where the Guest places requests. */ |
| @@ -1510,27 +1725,32 @@ static void setup_block_file(const char *filename) | |||
| 1510 | /* Tell Guest how many sectors this device has. */ | 1725 | /* Tell Guest how many sectors this device has. */ |
| 1511 | conf.capacity = cpu_to_le64(vblk->len / 512); | 1726 | conf.capacity = cpu_to_le64(vblk->len / 512); |
| 1512 | 1727 | ||
| 1513 | /* Tell Guest not to put in too many descriptors at once: two are used | 1728 | /* |
| 1514 | * for the in and out elements. */ | 1729 | * Tell Guest not to put in too many descriptors at once: two are used |
| 1730 | * for the in and out elements. | ||
| 1731 | */ | ||
| 1515 | add_feature(dev, VIRTIO_BLK_F_SEG_MAX); | 1732 | add_feature(dev, VIRTIO_BLK_F_SEG_MAX); |
| 1516 | conf.seg_max = cpu_to_le32(VIRTQUEUE_NUM - 2); | 1733 | conf.seg_max = cpu_to_le32(VIRTQUEUE_NUM - 2); |
| 1517 | 1734 | ||
| 1518 | set_config(dev, sizeof(conf), &conf); | 1735 | /* Don't try to put whole struct: we have 8 bit limit. */ |
| 1736 | set_config(dev, offsetof(struct virtio_blk_config, geometry), &conf); | ||
| 1519 | 1737 | ||
| 1520 | verbose("device %u: virtblock %llu sectors\n", | 1738 | verbose("device %u: virtblock %llu sectors\n", |
| 1521 | ++devices.device_num, le64_to_cpu(conf.capacity)); | 1739 | ++devices.device_num, le64_to_cpu(conf.capacity)); |
| 1522 | } | 1740 | } |
| 1523 | 1741 | ||
| 1524 | struct rng_info { | 1742 | /*L:211 |
| 1525 | int rfd; | 1743 | * Our random number generator device reads from /dev/random into the Guest's |
| 1526 | }; | ||
| 1527 | |||
| 1528 | /* Our random number generator device reads from /dev/random into the Guest's | ||
| 1529 | * input buffers. The usual case is that the Guest doesn't want random numbers | 1744 | * input buffers. The usual case is that the Guest doesn't want random numbers |
| 1530 | * and so has no buffers although /dev/random is still readable, whereas | 1745 | * and so has no buffers although /dev/random is still readable, whereas |
| 1531 | * console is the reverse. | 1746 | * console is the reverse. |
| 1532 | * | 1747 | * |
| 1533 | * The same logic applies, however. */ | 1748 | * The same logic applies, however. |
| 1749 | */ | ||
| 1750 | struct rng_info { | ||
| 1751 | int rfd; | ||
| 1752 | }; | ||
| 1753 | |||
| 1534 | static void rng_input(struct virtqueue *vq) | 1754 | static void rng_input(struct virtqueue *vq) |
| 1535 | { | 1755 | { |
| 1536 | int len; | 1756 | int len; |
| @@ -1543,9 +1763,10 @@ static void rng_input(struct virtqueue *vq) | |||
| 1543 | if (out_num) | 1763 | if (out_num) |
| 1544 | errx(1, "Output buffers in rng?"); | 1764 | errx(1, "Output buffers in rng?"); |
| 1545 | 1765 | ||
| 1546 | /* This is why we convert to iovecs: the readv() call uses them, and so | 1766 | /* |
| 1547 | * it reads straight into the Guest's buffer. We loop to make sure we | 1767 | * Just like the console write, we loop to cover the whole iovec. |
| 1548 | * fill it. */ | 1768 | * In this case, short reads actually happen quite a bit. |
| 1769 | */ | ||
| 1549 | while (!iov_empty(iov, in_num)) { | 1770 | while (!iov_empty(iov, in_num)) { |
| 1550 | len = readv(rng_info->rfd, iov, in_num); | 1771 | len = readv(rng_info->rfd, iov, in_num); |
| 1551 | if (len <= 0) | 1772 | if (len <= 0) |
| @@ -1558,15 +1779,18 @@ static void rng_input(struct virtqueue *vq) | |||
| 1558 | add_used(vq, head, totlen); | 1779 | add_used(vq, head, totlen); |
| 1559 | } | 1780 | } |
| 1560 | 1781 | ||
| 1561 | /* And this creates a "hardware" random number device for the Guest. */ | 1782 | /*L:199 |
| 1783 | * This creates a "hardware" random number device for the Guest. | ||
| 1784 | */ | ||
| 1562 | static void setup_rng(void) | 1785 | static void setup_rng(void) |
| 1563 | { | 1786 | { |
| 1564 | struct device *dev; | 1787 | struct device *dev; |
| 1565 | struct rng_info *rng_info = malloc(sizeof(*rng_info)); | 1788 | struct rng_info *rng_info = malloc(sizeof(*rng_info)); |
| 1566 | 1789 | ||
| 1790 | /* Our device's privat info simply contains the /dev/random fd. */ | ||
| 1567 | rng_info->rfd = open_or_die("/dev/random", O_RDONLY); | 1791 | rng_info->rfd = open_or_die("/dev/random", O_RDONLY); |
| 1568 | 1792 | ||
| 1569 | /* The device responds to return from I/O thread. */ | 1793 | /* Create the new device. */ |
| 1570 | dev = new_device("rng", VIRTIO_ID_RNG); | 1794 | dev = new_device("rng", VIRTIO_ID_RNG); |
| 1571 | dev->priv = rng_info; | 1795 | dev->priv = rng_info; |
| 1572 | 1796 | ||
| @@ -1582,8 +1806,10 @@ static void __attribute__((noreturn)) restart_guest(void) | |||
| 1582 | { | 1806 | { |
| 1583 | unsigned int i; | 1807 | unsigned int i; |
| 1584 | 1808 | ||
| 1585 | /* Since we don't track all open fds, we simply close everything beyond | 1809 | /* |
| 1586 | * stderr. */ | 1810 | * Since we don't track all open fds, we simply close everything beyond |
| 1811 | * stderr. | ||
| 1812 | */ | ||
| 1587 | for (i = 3; i < FD_SETSIZE; i++) | 1813 | for (i = 3; i < FD_SETSIZE; i++) |
| 1588 | close(i); | 1814 | close(i); |
| 1589 | 1815 | ||
| @@ -1594,8 +1820,10 @@ static void __attribute__((noreturn)) restart_guest(void) | |||
| 1594 | err(1, "Could not exec %s", main_args[0]); | 1820 | err(1, "Could not exec %s", main_args[0]); |
| 1595 | } | 1821 | } |
| 1596 | 1822 | ||
| 1597 | /*L:220 Finally we reach the core of the Launcher which runs the Guest, serves | 1823 | /*L:220 |
| 1598 | * its input and output, and finally, lays it to rest. */ | 1824 | * Finally we reach the core of the Launcher which runs the Guest, serves |
| 1825 | * its input and output, and finally, lays it to rest. | ||
| 1826 | */ | ||
| 1599 | static void __attribute__((noreturn)) run_guest(void) | 1827 | static void __attribute__((noreturn)) run_guest(void) |
| 1600 | { | 1828 | { |
| 1601 | for (;;) { | 1829 | for (;;) { |
| @@ -1630,7 +1858,7 @@ static void __attribute__((noreturn)) run_guest(void) | |||
| 1630 | * | 1858 | * |
| 1631 | * Are you ready? Take a deep breath and join me in the core of the Host, in | 1859 | * Are you ready? Take a deep breath and join me in the core of the Host, in |
| 1632 | * "make Host". | 1860 | * "make Host". |
| 1633 | :*/ | 1861 | :*/ |
| 1634 | 1862 | ||
| 1635 | static struct option opts[] = { | 1863 | static struct option opts[] = { |
| 1636 | { "verbose", 0, NULL, 'v' }, | 1864 | { "verbose", 0, NULL, 'v' }, |
| @@ -1651,8 +1879,7 @@ static void usage(void) | |||
| 1651 | /*L:105 The main routine is where the real work begins: */ | 1879 | /*L:105 The main routine is where the real work begins: */ |
| 1652 | int main(int argc, char *argv[]) | 1880 | int main(int argc, char *argv[]) |
| 1653 | { | 1881 | { |
| 1654 | /* Memory, top-level pagetable, code startpoint and size of the | 1882 | /* Memory, code startpoint and size of the (optional) initrd. */ |
| 1655 | * (optional) initrd. */ | ||
| 1656 | unsigned long mem = 0, start, initrd_size = 0; | 1883 | unsigned long mem = 0, start, initrd_size = 0; |
| 1657 | /* Two temporaries. */ | 1884 | /* Two temporaries. */ |
| 1658 | int i, c; | 1885 | int i, c; |
| @@ -1664,24 +1891,32 @@ int main(int argc, char *argv[]) | |||
| 1664 | /* Save the args: we "reboot" by execing ourselves again. */ | 1891 | /* Save the args: we "reboot" by execing ourselves again. */ |
| 1665 | main_args = argv; | 1892 | main_args = argv; |
| 1666 | 1893 | ||
| 1667 | /* First we initialize the device list. We keep a pointer to the last | 1894 | /* |
| 1895 | * First we initialize the device list. We keep a pointer to the last | ||
| 1668 | * device, and the next interrupt number to use for devices (1: | 1896 | * device, and the next interrupt number to use for devices (1: |
| 1669 | * remember that 0 is used by the timer). */ | 1897 | * remember that 0 is used by the timer). |
| 1898 | */ | ||
| 1670 | devices.lastdev = NULL; | 1899 | devices.lastdev = NULL; |
| 1671 | devices.next_irq = 1; | 1900 | devices.next_irq = 1; |
| 1672 | 1901 | ||
| 1902 | /* We're CPU 0. In fact, that's the only CPU possible right now. */ | ||
| 1673 | cpu_id = 0; | 1903 | cpu_id = 0; |
| 1674 | /* We need to know how much memory so we can set up the device | 1904 | |
| 1905 | /* | ||
| 1906 | * We need to know how much memory so we can set up the device | ||
| 1675 | * descriptor and memory pages for the devices as we parse the command | 1907 | * descriptor and memory pages for the devices as we parse the command |
| 1676 | * line. So we quickly look through the arguments to find the amount | 1908 | * line. So we quickly look through the arguments to find the amount |
| 1677 | * of memory now. */ | 1909 | * of memory now. |
| 1910 | */ | ||
| 1678 | for (i = 1; i < argc; i++) { | 1911 | for (i = 1; i < argc; i++) { |
| 1679 | if (argv[i][0] != '-') { | 1912 | if (argv[i][0] != '-') { |
| 1680 | mem = atoi(argv[i]) * 1024 * 1024; | 1913 | mem = atoi(argv[i]) * 1024 * 1024; |
| 1681 | /* We start by mapping anonymous pages over all of | 1914 | /* |
| 1915 | * We start by mapping anonymous pages over all of | ||
| 1682 | * guest-physical memory range. This fills it with 0, | 1916 | * guest-physical memory range. This fills it with 0, |
| 1683 | * and ensures that the Guest won't be killed when it | 1917 | * and ensures that the Guest won't be killed when it |
| 1684 | * tries to access it. */ | 1918 | * tries to access it. |
| 1919 | */ | ||
| 1685 | guest_base = map_zeroed_pages(mem / getpagesize() | 1920 | guest_base = map_zeroed_pages(mem / getpagesize() |
| 1686 | + DEVICE_PAGES); | 1921 | + DEVICE_PAGES); |
| 1687 | guest_limit = mem; | 1922 | guest_limit = mem; |
| @@ -1714,8 +1949,10 @@ int main(int argc, char *argv[]) | |||
| 1714 | usage(); | 1949 | usage(); |
| 1715 | } | 1950 | } |
| 1716 | } | 1951 | } |
| 1717 | /* After the other arguments we expect memory and kernel image name, | 1952 | /* |
| 1718 | * followed by command line arguments for the kernel. */ | 1953 | * After the other arguments we expect memory and kernel image name, |
| 1954 | * followed by command line arguments for the kernel. | ||
| 1955 | */ | ||
| 1719 | if (optind + 2 > argc) | 1956 | if (optind + 2 > argc) |
| 1720 | usage(); | 1957 | usage(); |
| 1721 | 1958 | ||
| @@ -1733,20 +1970,26 @@ int main(int argc, char *argv[]) | |||
| 1733 | /* Map the initrd image if requested (at top of physical memory) */ | 1970 | /* Map the initrd image if requested (at top of physical memory) */ |
| 1734 | if (initrd_name) { | 1971 | if (initrd_name) { |
| 1735 | initrd_size = load_initrd(initrd_name, mem); | 1972 | initrd_size = load_initrd(initrd_name, mem); |
| 1736 | /* These are the location in the Linux boot header where the | 1973 | /* |
| 1737 | * start and size of the initrd are expected to be found. */ | 1974 | * These are the location in the Linux boot header where the |
| 1975 | * start and size of the initrd are expected to be found. | ||
| 1976 | */ | ||
| 1738 | boot->hdr.ramdisk_image = mem - initrd_size; | 1977 | boot->hdr.ramdisk_image = mem - initrd_size; |
| 1739 | boot->hdr.ramdisk_size = initrd_size; | 1978 | boot->hdr.ramdisk_size = initrd_size; |
| 1740 | /* The bootloader type 0xFF means "unknown"; that's OK. */ | 1979 | /* The bootloader type 0xFF means "unknown"; that's OK. */ |
| 1741 | boot->hdr.type_of_loader = 0xFF; | 1980 | boot->hdr.type_of_loader = 0xFF; |
| 1742 | } | 1981 | } |
| 1743 | 1982 | ||
| 1744 | /* The Linux boot header contains an "E820" memory map: ours is a | 1983 | /* |
| 1745 | * simple, single region. */ | 1984 | * The Linux boot header contains an "E820" memory map: ours is a |
| 1985 | * simple, single region. | ||
| 1986 | */ | ||
| 1746 | boot->e820_entries = 1; | 1987 | boot->e820_entries = 1; |
| 1747 | boot->e820_map[0] = ((struct e820entry) { 0, mem, E820_RAM }); | 1988 | boot->e820_map[0] = ((struct e820entry) { 0, mem, E820_RAM }); |
| 1748 | /* The boot header contains a command line pointer: we put the command | 1989 | /* |
| 1749 | * line after the boot header. */ | 1990 | * The boot header contains a command line pointer: we put the command |
| 1991 | * line after the boot header. | ||
| 1992 | */ | ||
| 1750 | boot->hdr.cmd_line_ptr = to_guest_phys(boot + 1); | 1993 | boot->hdr.cmd_line_ptr = to_guest_phys(boot + 1); |
| 1751 | /* We use a simple helper to copy the arguments separated by spaces. */ | 1994 | /* We use a simple helper to copy the arguments separated by spaces. */ |
| 1752 | concat((char *)(boot + 1), argv+optind+2); | 1995 | concat((char *)(boot + 1), argv+optind+2); |
| @@ -1760,11 +2003,13 @@ int main(int argc, char *argv[]) | |||
| 1760 | /* Tell the entry path not to try to reload segment registers. */ | 2003 | /* Tell the entry path not to try to reload segment registers. */ |
| 1761 | boot->hdr.loadflags |= KEEP_SEGMENTS; | 2004 | boot->hdr.loadflags |= KEEP_SEGMENTS; |
| 1762 | 2005 | ||
| 1763 | /* We tell the kernel to initialize the Guest: this returns the open | 2006 | /* |
| 1764 | * /dev/lguest file descriptor. */ | 2007 | * We tell the kernel to initialize the Guest: this returns the open |
| 2008 | * /dev/lguest file descriptor. | ||
| 2009 | */ | ||
| 1765 | tell_kernel(start); | 2010 | tell_kernel(start); |
| 1766 | 2011 | ||
| 1767 | /* Ensure that we terminate if a child dies. */ | 2012 | /* Ensure that we terminate if a device-servicing child dies. */ |
| 1768 | signal(SIGCHLD, kill_launcher); | 2013 | signal(SIGCHLD, kill_launcher); |
| 1769 | 2014 | ||
| 1770 | /* If we exit via err(), this kills all the threads, restores tty. */ | 2015 | /* If we exit via err(), this kills all the threads, restores tty. */ |
diff --git a/Documentation/lockdep-design.txt b/Documentation/lockdep-design.txt index e20d913d5914..abf768c681e2 100644 --- a/Documentation/lockdep-design.txt +++ b/Documentation/lockdep-design.txt | |||
| @@ -30,9 +30,9 @@ State | |||
| 30 | The validator tracks lock-class usage history into 4n + 1 separate state bits: | 30 | The validator tracks lock-class usage history into 4n + 1 separate state bits: |
| 31 | 31 | ||
| 32 | - 'ever held in STATE context' | 32 | - 'ever held in STATE context' |
| 33 | - 'ever head as readlock in STATE context' | 33 | - 'ever held as readlock in STATE context' |
| 34 | - 'ever head with STATE enabled' | 34 | - 'ever held with STATE enabled' |
| 35 | - 'ever head as readlock with STATE enabled' | 35 | - 'ever held as readlock with STATE enabled' |
| 36 | 36 | ||
| 37 | Where STATE can be either one of (kernel/lockdep_states.h) | 37 | Where STATE can be either one of (kernel/lockdep_states.h) |
| 38 | - hardirq | 38 | - hardirq |
diff --git a/Documentation/networking/6pack.txt b/Documentation/networking/6pack.txt index d0777a1200e1..8f339428fdf4 100644 --- a/Documentation/networking/6pack.txt +++ b/Documentation/networking/6pack.txt | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | This is the 6pack-mini-HOWTO, written by | 1 | This is the 6pack-mini-HOWTO, written by |
| 2 | 2 | ||
| 3 | Andreas Könsgen DG3KQ | 3 | Andreas Könsgen DG3KQ |
| 4 | Internet: ajk@iehk.rwth-aachen.de | 4 | Internet: ajk@comnets.uni-bremen.de |
| 5 | AMPR-net: dg3kq@db0pra.ampr.org | 5 | AMPR-net: dg3kq@db0pra.ampr.org |
| 6 | AX.25: dg3kq@db0ach.#nrw.deu.eu | 6 | AX.25: dg3kq@db0ach.#nrw.deu.eu |
| 7 | 7 | ||
diff --git a/Documentation/sound/alsa/Procfile.txt b/Documentation/sound/alsa/Procfile.txt index 381908d8ca42..719a819f8cc2 100644 --- a/Documentation/sound/alsa/Procfile.txt +++ b/Documentation/sound/alsa/Procfile.txt | |||
| @@ -101,6 +101,8 @@ card*/pcm*/xrun_debug | |||
| 101 | bit 0 = Enable XRUN/jiffies debug messages | 101 | bit 0 = Enable XRUN/jiffies debug messages |
| 102 | bit 1 = Show stack trace at XRUN / jiffies check | 102 | bit 1 = Show stack trace at XRUN / jiffies check |
| 103 | bit 2 = Enable additional jiffies check | 103 | bit 2 = Enable additional jiffies check |
| 104 | bit 3 = Log hwptr update at each period interrupt | ||
| 105 | bit 4 = Log hwptr update at each snd_pcm_update_hw_ptr() | ||
| 104 | 106 | ||
| 105 | When the bit 0 is set, the driver will show the messages to | 107 | When the bit 0 is set, the driver will show the messages to |
| 106 | kernel log when an xrun is detected. The debug message is | 108 | kernel log when an xrun is detected. The debug message is |
| @@ -117,6 +119,9 @@ card*/pcm*/xrun_debug | |||
| 117 | buggy) hardware that doesn't give smooth pointer updates. | 119 | buggy) hardware that doesn't give smooth pointer updates. |
| 118 | This feature is enabled via the bit 2. | 120 | This feature is enabled via the bit 2. |
| 119 | 121 | ||
| 122 | Bits 3 and 4 are for logging the hwptr records. Note that | ||
| 123 | these will give flood of kernel messages. | ||
| 124 | |||
| 120 | card*/pcm*/sub*/info | 125 | card*/pcm*/sub*/info |
| 121 | The general information of this PCM sub-stream. | 126 | The general information of this PCM sub-stream. |
| 122 | 127 | ||
diff --git a/Documentation/sysrq.txt b/Documentation/sysrq.txt index cf42b820ff9d..d56a01775423 100644 --- a/Documentation/sysrq.txt +++ b/Documentation/sysrq.txt | |||
| @@ -66,7 +66,8 @@ On all - write a character to /proc/sysrq-trigger. e.g.: | |||
| 66 | 'b' - Will immediately reboot the system without syncing or unmounting | 66 | 'b' - Will immediately reboot the system without syncing or unmounting |
| 67 | your disks. | 67 | your disks. |
| 68 | 68 | ||
| 69 | 'c' - Will perform a kexec reboot in order to take a crashdump. | 69 | 'c' - Will perform a system crash by a NULL pointer dereference. |
| 70 | A crashdump will be taken if configured. | ||
| 70 | 71 | ||
| 71 | 'd' - Shows all locks that are held. | 72 | 'd' - Shows all locks that are held. |
| 72 | 73 | ||
| @@ -141,8 +142,8 @@ useful when you want to exit a program that will not let you switch consoles. | |||
| 141 | re'B'oot is good when you're unable to shut down. But you should also 'S'ync | 142 | re'B'oot is good when you're unable to shut down. But you should also 'S'ync |
| 142 | and 'U'mount first. | 143 | and 'U'mount first. |
| 143 | 144 | ||
| 144 | 'C'rashdump can be used to manually trigger a crashdump when the system is hung. | 145 | 'C'rash can be used to manually trigger a crashdump when the system is hung. |
| 145 | The kernel needs to have been built with CONFIG_KEXEC enabled. | 146 | Note that this just triggers a crash if there is no dump mechanism available. |
| 146 | 147 | ||
| 147 | 'S'ync is great when your system is locked up, it allows you to sync your | 148 | 'S'ync is great when your system is locked up, it allows you to sync your |
| 148 | disks and will certainly lessen the chance of data loss and fscking. Note | 149 | disks and will certainly lessen the chance of data loss and fscking. Note |
diff --git a/Documentation/video4linux/CARDLIST.em28xx b/Documentation/video4linux/CARDLIST.em28xx index 014d255231fc..e352d754875c 100644 --- a/Documentation/video4linux/CARDLIST.em28xx +++ b/Documentation/video4linux/CARDLIST.em28xx | |||
| @@ -1,5 +1,5 @@ | |||
| 1 | 0 -> Unknown EM2800 video grabber (em2800) [eb1a:2800] | 1 | 0 -> Unknown EM2800 video grabber (em2800) [eb1a:2800] |
| 2 | 1 -> Unknown EM2750/28xx video grabber (em2820/em2840) [eb1a:2820,eb1a:2821,eb1a:2860,eb1a:2861,eb1a:2870,eb1a:2881,eb1a:2883] | 2 | 1 -> Unknown EM2750/28xx video grabber (em2820/em2840) [eb1a:2710,eb1a:2820,eb1a:2821,eb1a:2860,eb1a:2861,eb1a:2870,eb1a:2881,eb1a:2883] |
| 3 | 2 -> Terratec Cinergy 250 USB (em2820/em2840) [0ccd:0036] | 3 | 2 -> Terratec Cinergy 250 USB (em2820/em2840) [0ccd:0036] |
| 4 | 3 -> Pinnacle PCTV USB 2 (em2820/em2840) [2304:0208] | 4 | 3 -> Pinnacle PCTV USB 2 (em2820/em2840) [2304:0208] |
| 5 | 4 -> Hauppauge WinTV USB 2 (em2820/em2840) [2040:4200,2040:4201] | 5 | 4 -> Hauppauge WinTV USB 2 (em2820/em2840) [2040:4200,2040:4201] |
| @@ -20,7 +20,7 @@ | |||
| 20 | 19 -> EM2860/SAA711X Reference Design (em2860) | 20 | 19 -> EM2860/SAA711X Reference Design (em2860) |
| 21 | 20 -> AMD ATI TV Wonder HD 600 (em2880) [0438:b002] | 21 | 20 -> AMD ATI TV Wonder HD 600 (em2880) [0438:b002] |
| 22 | 21 -> eMPIA Technology, Inc. GrabBeeX+ Video Encoder (em2800) [eb1a:2801] | 22 | 21 -> eMPIA Technology, Inc. GrabBeeX+ Video Encoder (em2800) [eb1a:2801] |
| 23 | 22 -> Unknown EM2750/EM2751 webcam grabber (em2750) [eb1a:2750,eb1a:2751] | 23 | 22 -> EM2710/EM2750/EM2751 webcam grabber (em2750) [eb1a:2750,eb1a:2751] |
| 24 | 23 -> Huaqi DLCW-130 (em2750) | 24 | 23 -> Huaqi DLCW-130 (em2750) |
| 25 | 24 -> D-Link DUB-T210 TV Tuner (em2820/em2840) [2001:f112] | 25 | 24 -> D-Link DUB-T210 TV Tuner (em2820/em2840) [2001:f112] |
| 26 | 25 -> Gadmei UTV310 (em2820/em2840) | 26 | 25 -> Gadmei UTV310 (em2820/em2840) |
diff --git a/Documentation/video4linux/CARDLIST.saa7134 b/Documentation/video4linux/CARDLIST.saa7134 index 15562427e8a9..c913e5614195 100644 --- a/Documentation/video4linux/CARDLIST.saa7134 +++ b/Documentation/video4linux/CARDLIST.saa7134 | |||
| @@ -153,8 +153,8 @@ | |||
| 153 | 152 -> Asus Tiger Rev:1.00 [1043:4857] | 153 | 152 -> Asus Tiger Rev:1.00 [1043:4857] |
| 154 | 153 -> Kworld Plus TV Analog Lite PCI [17de:7128] | 154 | 153 -> Kworld Plus TV Analog Lite PCI [17de:7128] |
| 155 | 154 -> Avermedia AVerTV GO 007 FM Plus [1461:f31d] | 155 | 154 -> Avermedia AVerTV GO 007 FM Plus [1461:f31d] |
| 156 | 155 -> Hauppauge WinTV-HVR1120 ATSC/QAM-Hybrid [0070:6706,0070:6708] | 156 | 155 -> Hauppauge WinTV-HVR1150 ATSC/QAM-Hybrid [0070:6706,0070:6708] |
| 157 | 156 -> Hauppauge WinTV-HVR1110r3 DVB-T/Hybrid [0070:6707,0070:6709,0070:670a] | 157 | 156 -> Hauppauge WinTV-HVR1120 DVB-T/Hybrid [0070:6707,0070:6709,0070:670a] |
| 158 | 157 -> Avermedia AVerTV Studio 507UA [1461:a11b] | 158 | 157 -> Avermedia AVerTV Studio 507UA [1461:a11b] |
| 159 | 158 -> AVerMedia Cardbus TV/Radio (E501R) [1461:b7e9] | 159 | 158 -> AVerMedia Cardbus TV/Radio (E501R) [1461:b7e9] |
| 160 | 159 -> Beholder BeholdTV 505 RDS [0000:505B] | 160 | 159 -> Beholder BeholdTV 505 RDS [0000:505B] |
diff --git a/Documentation/video4linux/gspca.txt b/Documentation/video4linux/gspca.txt index 2bcf78896e22..573f95b58807 100644 --- a/Documentation/video4linux/gspca.txt +++ b/Documentation/video4linux/gspca.txt | |||
| @@ -44,7 +44,9 @@ zc3xx 0458:7007 Genius VideoCam V2 | |||
| 44 | zc3xx 0458:700c Genius VideoCam V3 | 44 | zc3xx 0458:700c Genius VideoCam V3 |
| 45 | zc3xx 0458:700f Genius VideoCam Web V2 | 45 | zc3xx 0458:700f Genius VideoCam Web V2 |
| 46 | sonixj 0458:7025 Genius Eye 311Q | 46 | sonixj 0458:7025 Genius Eye 311Q |
| 47 | sn9c20x 0458:7029 Genius Look 320s | ||
| 47 | sonixj 0458:702e Genius Slim 310 NB | 48 | sonixj 0458:702e Genius Slim 310 NB |
| 49 | sn9c20x 045e:00f4 LifeCam VX-6000 (SN9C20x + OV9650) | ||
| 48 | sonixj 045e:00f5 MicroSoft VX3000 | 50 | sonixj 045e:00f5 MicroSoft VX3000 |
| 49 | sonixj 045e:00f7 MicroSoft VX1000 | 51 | sonixj 045e:00f7 MicroSoft VX1000 |
| 50 | ov519 045e:028c Micro$oft xbox cam | 52 | ov519 045e:028c Micro$oft xbox cam |
| @@ -282,6 +284,28 @@ sonixj 0c45:613a Microdia Sonix PC Camera | |||
| 282 | sonixj 0c45:613b Surfer SN-206 | 284 | sonixj 0c45:613b Surfer SN-206 |
| 283 | sonixj 0c45:613c Sonix Pccam168 | 285 | sonixj 0c45:613c Sonix Pccam168 |
| 284 | sonixj 0c45:6143 Sonix Pccam168 | 286 | sonixj 0c45:6143 Sonix Pccam168 |
| 287 | sn9c20x 0c45:6240 PC Camera (SN9C201 + MT9M001) | ||
| 288 | sn9c20x 0c45:6242 PC Camera (SN9C201 + MT9M111) | ||
| 289 | sn9c20x 0c45:6248 PC Camera (SN9C201 + OV9655) | ||
| 290 | sn9c20x 0c45:624e PC Camera (SN9C201 + SOI968) | ||
| 291 | sn9c20x 0c45:624f PC Camera (SN9C201 + OV9650) | ||
| 292 | sn9c20x 0c45:6251 PC Camera (SN9C201 + OV9650) | ||
| 293 | sn9c20x 0c45:6253 PC Camera (SN9C201 + OV9650) | ||
| 294 | sn9c20x 0c45:6260 PC Camera (SN9C201 + OV7670) | ||
| 295 | sn9c20x 0c45:6270 PC Camera (SN9C201 + MT9V011/MT9V111/MT9V112) | ||
| 296 | sn9c20x 0c45:627b PC Camera (SN9C201 + OV7660) | ||
| 297 | sn9c20x 0c45:627c PC Camera (SN9C201 + HV7131R) | ||
| 298 | sn9c20x 0c45:627f PC Camera (SN9C201 + OV9650) | ||
| 299 | sn9c20x 0c45:6280 PC Camera (SN9C202 + MT9M001) | ||
| 300 | sn9c20x 0c45:6282 PC Camera (SN9C202 + MT9M111) | ||
| 301 | sn9c20x 0c45:6288 PC Camera (SN9C202 + OV9655) | ||
| 302 | sn9c20x 0c45:628e PC Camera (SN9C202 + SOI968) | ||
| 303 | sn9c20x 0c45:628f PC Camera (SN9C202 + OV9650) | ||
| 304 | sn9c20x 0c45:62a0 PC Camera (SN9C202 + OV7670) | ||
| 305 | sn9c20x 0c45:62b0 PC Camera (SN9C202 + MT9V011/MT9V111/MT9V112) | ||
| 306 | sn9c20x 0c45:62b3 PC Camera (SN9C202 + OV9655) | ||
| 307 | sn9c20x 0c45:62bb PC Camera (SN9C202 + OV7660) | ||
| 308 | sn9c20x 0c45:62bc PC Camera (SN9C202 + HV7131R) | ||
| 285 | sunplus 0d64:0303 Sunplus FashionCam DXG | 309 | sunplus 0d64:0303 Sunplus FashionCam DXG |
| 286 | etoms 102c:6151 Qcam Sangha CIF | 310 | etoms 102c:6151 Qcam Sangha CIF |
| 287 | etoms 102c:6251 Qcam xxxxxx VGA | 311 | etoms 102c:6251 Qcam xxxxxx VGA |
| @@ -290,6 +314,7 @@ spca561 10fd:7e50 FlyCam Usb 100 | |||
| 290 | zc3xx 10fd:8050 Typhoon Webshot II USB 300k | 314 | zc3xx 10fd:8050 Typhoon Webshot II USB 300k |
| 291 | ov534 1415:2000 Sony HD Eye for PS3 (SLEH 00201) | 315 | ov534 1415:2000 Sony HD Eye for PS3 (SLEH 00201) |
| 292 | pac207 145f:013a Trust WB-1300N | 316 | pac207 145f:013a Trust WB-1300N |
| 317 | sn9c20x 145f:013d Trust WB-3600R | ||
| 293 | vc032x 15b8:6001 HP 2.0 Megapixel | 318 | vc032x 15b8:6001 HP 2.0 Megapixel |
| 294 | vc032x 15b8:6002 HP 2.0 Megapixel rz406aa | 319 | vc032x 15b8:6002 HP 2.0 Megapixel rz406aa |
| 295 | spca501 1776:501c Arowana 300K CMOS Camera | 320 | spca501 1776:501c Arowana 300K CMOS Camera |
| @@ -300,4 +325,11 @@ spca500 2899:012c Toptro Industrial | |||
| 300 | spca508 8086:0110 Intel Easy PC Camera | 325 | spca508 8086:0110 Intel Easy PC Camera |
| 301 | spca500 8086:0630 Intel Pocket PC Camera | 326 | spca500 8086:0630 Intel Pocket PC Camera |
| 302 | spca506 99fa:8988 Grandtec V.cap | 327 | spca506 99fa:8988 Grandtec V.cap |
| 328 | sn9c20x a168:0610 Dino-Lite Digital Microscope (SN9C201 + HV7131R) | ||
| 329 | sn9c20x a168:0611 Dino-Lite Digital Microscope (SN9C201 + HV7131R) | ||
| 330 | sn9c20x a168:0613 Dino-Lite Digital Microscope (SN9C201 + HV7131R) | ||
| 331 | sn9c20x a168:0618 Dino-Lite Digital Microscope (SN9C201 + HV7131R) | ||
| 332 | sn9c20x a168:0614 Dino-Lite Digital Microscope (SN9C201 + MT9M111) | ||
| 333 | sn9c20x a168:0615 Dino-Lite Digital Microscope (SN9C201 + MT9M111) | ||
| 334 | sn9c20x a168:0617 Dino-Lite Digital Microscope (SN9C201 + MT9M111) | ||
| 303 | spca561 abcd:cdee Petcam | 335 | spca561 abcd:cdee Petcam |
diff --git a/MAINTAINERS b/MAINTAINERS index 18c3f0c41c95..60299a9a7adb 100644 --- a/MAINTAINERS +++ b/MAINTAINERS | |||
| @@ -73,8 +73,8 @@ Note: For the hard of thinking, this list is meant to remain in alphabetical | |||
| 73 | order. If you could add yourselves to it in alphabetical order that would be | 73 | order. If you could add yourselves to it in alphabetical order that would be |
| 74 | so much easier [Ed] | 74 | so much easier [Ed] |
| 75 | 75 | ||
| 76 | P: Person | 76 | P: Person (obsolete) |
| 77 | M: Mail patches to | 77 | M: Mail patches to: FullName <address@domain> |
| 78 | L: Mailing list that is relevant to this area | 78 | L: Mailing list that is relevant to this area |
| 79 | W: Web-page with status/info | 79 | W: Web-page with status/info |
| 80 | T: SCM tree type and location. Type is one of: git, hg, quilt, stgit. | 80 | T: SCM tree type and location. Type is one of: git, hg, quilt, stgit. |
| @@ -104,88 +104,74 @@ X: Files and directories that are NOT maintained, same rules as F: | |||
| 104 | matches all files in and below net excluding net/ipv6/ | 104 | matches all files in and below net excluding net/ipv6/ |
| 105 | 105 | ||
| 106 | 3C505 NETWORK DRIVER | 106 | 3C505 NETWORK DRIVER |
| 107 | P: Philip Blundell | 107 | M: Philip Blundell <philb@gnu.org> |
| 108 | M: philb@gnu.org | ||
| 109 | L: netdev@vger.kernel.org | 108 | L: netdev@vger.kernel.org |
| 110 | S: Maintained | 109 | S: Maintained |
| 111 | F: drivers/net/3c505* | 110 | F: drivers/net/3c505* |
| 112 | 111 | ||
| 113 | 3C59X NETWORK DRIVER | 112 | 3C59X NETWORK DRIVER |
| 114 | P: Steffen Klassert | 113 | M: Steffen Klassert <klassert@mathematik.tu-chemnitz.de> |
| 115 | M: klassert@mathematik.tu-chemnitz.de | ||
| 116 | L: netdev@vger.kernel.org | 114 | L: netdev@vger.kernel.org |
| 117 | S: Maintained | 115 | S: Maintained |
| 118 | F: Documentation/networking/vortex.txt | 116 | F: Documentation/networking/vortex.txt |
| 119 | F: drivers/net/3c59x.c | 117 | F: drivers/net/3c59x.c |
| 120 | 118 | ||
| 121 | 3CR990 NETWORK DRIVER | 119 | 3CR990 NETWORK DRIVER |
| 122 | P: David Dillow | 120 | M: David Dillow <dave@thedillows.org> |
| 123 | M: dave@thedillows.org | ||
| 124 | L: netdev@vger.kernel.org | 121 | L: netdev@vger.kernel.org |
| 125 | S: Maintained | 122 | S: Maintained |
| 126 | F: drivers/net/typhoon* | 123 | F: drivers/net/typhoon* |
| 127 | 124 | ||
| 128 | 3W-9XXX SATA-RAID CONTROLLER DRIVER | 125 | 3W-9XXX SATA-RAID CONTROLLER DRIVER |
| 129 | P: Adam Radford | 126 | M: Adam Radford <linuxraid@amcc.com> |
| 130 | M: linuxraid@amcc.com | ||
| 131 | L: linux-scsi@vger.kernel.org | 127 | L: linux-scsi@vger.kernel.org |
| 132 | W: http://www.amcc.com | 128 | W: http://www.amcc.com |
| 133 | S: Supported | 129 | S: Supported |
| 134 | F: drivers/scsi/3w-9xxx* | 130 | F: drivers/scsi/3w-9xxx* |
| 135 | 131 | ||
| 136 | 3W-XXXX ATA-RAID CONTROLLER DRIVER | 132 | 3W-XXXX ATA-RAID CONTROLLER DRIVER |
| 137 | P: Adam Radford | 133 | M: Adam Radford <linuxraid@amcc.com> |
| 138 | M: linuxraid@amcc.com | ||
| 139 | L: linux-scsi@vger.kernel.org | 134 | L: linux-scsi@vger.kernel.org |
| 140 | W: http://www.amcc.com | 135 | W: http://www.amcc.com |
| 141 | S: Supported | 136 | S: Supported |
| 142 | F: drivers/scsi/3w-xxxx* | 137 | F: drivers/scsi/3w-xxxx* |
| 143 | 138 | ||
| 144 | 53C700 AND 53C700-66 SCSI DRIVER | 139 | 53C700 AND 53C700-66 SCSI DRIVER |
| 145 | P: James E.J. Bottomley | 140 | M: "James E.J. Bottomley" <James.Bottomley@HansenPartnership.com> |
| 146 | M: James.Bottomley@HansenPartnership.com | ||
| 147 | L: linux-scsi@vger.kernel.org | 141 | L: linux-scsi@vger.kernel.org |
| 148 | S: Maintained | 142 | S: Maintained |
| 149 | F: drivers/scsi/53c700* | 143 | F: drivers/scsi/53c700* |
| 150 | 144 | ||
| 151 | 6PACK NETWORK DRIVER FOR AX.25 | 145 | 6PACK NETWORK DRIVER FOR AX.25 |
| 152 | P: Andreas Koensgen | 146 | M: Andreas Koensgen <ajk@comnets.uni-bremen.de> |
| 153 | M: ajk@iehk.rwth-aachen.de | ||
| 154 | L: linux-hams@vger.kernel.org | 147 | L: linux-hams@vger.kernel.org |
| 155 | S: Maintained | 148 | S: Maintained |
| 156 | F: drivers/net/hamradio/6pack.c | 149 | F: drivers/net/hamradio/6pack.c |
| 157 | 150 | ||
| 158 | 8169 10/100/1000 GIGABIT ETHERNET DRIVER | 151 | 8169 10/100/1000 GIGABIT ETHERNET DRIVER |
| 159 | P: Francois Romieu | 152 | M: Francois Romieu <romieu@fr.zoreil.com> |
| 160 | M: romieu@fr.zoreil.com | ||
| 161 | L: netdev@vger.kernel.org | 153 | L: netdev@vger.kernel.org |
| 162 | S: Maintained | 154 | S: Maintained |
| 163 | F: drivers/net/r8169.c | 155 | F: drivers/net/r8169.c |
| 164 | 156 | ||
| 165 | 8250/16?50 (AND CLONE UARTS) SERIAL DRIVER | 157 | 8250/16?50 (AND CLONE UARTS) SERIAL DRIVER |
| 166 | P: Alan Cox | ||
| 167 | M: alan@lxorguk.ukuu.org.uk | ||
| 168 | L: linux-serial@vger.kernel.org | 158 | L: linux-serial@vger.kernel.org |
| 169 | W: http://serial.sourceforge.net | 159 | W: http://serial.sourceforge.net |
| 170 | S: Odd Fixes | 160 | S: Orphan |
| 171 | F: drivers/serial/8250* | 161 | F: drivers/serial/8250* |
| 172 | F: include/linux/serial_8250.h | 162 | F: include/linux/serial_8250.h |
| 173 | 163 | ||
| 174 | 8390 NETWORK DRIVERS [WD80x3/SMC-ELITE, SMC-ULTRA, NE2000, 3C503, etc.] | 164 | 8390 NETWORK DRIVERS [WD80x3/SMC-ELITE, SMC-ULTRA, NE2000, 3C503, etc.] |
| 175 | P: Paul Gortmaker | 165 | M: Paul Gortmaker <p_gortmaker@yahoo.com> |
| 176 | M: p_gortmaker@yahoo.com | ||
| 177 | L: netdev@vger.kernel.org | 166 | L: netdev@vger.kernel.org |
| 178 | S: Maintained | 167 | S: Maintained |
| 179 | F: drivers/net/*8390* | 168 | F: drivers/net/*8390* |
| 180 | F: drivers/net/ax88796.c | 169 | F: drivers/net/ax88796.c |
| 181 | 170 | ||
| 182 | 9P FILE SYSTEM | 171 | 9P FILE SYSTEM |
| 183 | P: Eric Van Hensbergen | 172 | M: Eric Van Hensbergen <ericvh@gmail.com> |
| 184 | M: ericvh@gmail.com | 173 | M: Ron Minnich <rminnich@sandia.gov> |
| 185 | P: Ron Minnich | 174 | M: Latchesar Ionkov <lucho@ionkov.net> |
| 186 | M: rminnich@sandia.gov | ||
| 187 | P: Latchesar Ionkov | ||
| 188 | M: lucho@ionkov.net | ||
| 189 | L: v9fs-developer@lists.sourceforge.net | 175 | L: v9fs-developer@lists.sourceforge.net |
| 190 | W: http://swik.net/v9fs | 176 | W: http://swik.net/v9fs |
| 191 | T: git git://git.kernel.org/pub/scm/linux/kernel/ericvh/v9fs.git | 177 | T: git git://git.kernel.org/pub/scm/linux/kernel/ericvh/v9fs.git |
| @@ -194,15 +180,13 @@ F: Documentation/filesystems/9p.txt | |||
| 194 | F: fs/9p/ | 180 | F: fs/9p/ |
| 195 | 181 | ||
| 196 | A2232 SERIAL BOARD DRIVER | 182 | A2232 SERIAL BOARD DRIVER |
| 197 | P: Enver Haase | 183 | M: Enver Haase <A2232@gmx.net> |
| 198 | M: A2232@gmx.net | ||
| 199 | L: linux-m68k@lists.linux-m68k.org | 184 | L: linux-m68k@lists.linux-m68k.org |
| 200 | S: Maintained | 185 | S: Maintained |
| 201 | F: drivers/char/ser_a2232* | 186 | F: drivers/char/ser_a2232* |
| 202 | 187 | ||
| 203 | AACRAID SCSI RAID DRIVER | 188 | AACRAID SCSI RAID DRIVER |
| 204 | P: Adaptec OEM Raid Solutions | 189 | M: Adaptec OEM Raid Solutions <aacraid@adaptec.com> |
| 205 | M: aacraid@adaptec.com | ||
| 206 | L: linux-scsi@vger.kernel.org | 190 | L: linux-scsi@vger.kernel.org |
| 207 | W: http://www.adaptec.com/ | 191 | W: http://www.adaptec.com/ |
| 208 | S: Supported | 192 | S: Supported |
| @@ -210,44 +194,38 @@ F: Documentation/scsi/aacraid.txt | |||
| 210 | F: drivers/scsi/aacraid/ | 194 | F: drivers/scsi/aacraid/ |
| 211 | 195 | ||
| 212 | ABIT UGURU 1,2 HARDWARE MONITOR DRIVER | 196 | ABIT UGURU 1,2 HARDWARE MONITOR DRIVER |
| 213 | P: Hans de Goede | 197 | M: Hans de Goede <j.w.r.degoede@hhs.nl> |
| 214 | M: j.w.r.degoede@hhs.nl | ||
| 215 | L: lm-sensors@lm-sensors.org | 198 | L: lm-sensors@lm-sensors.org |
| 216 | S: Maintained | 199 | S: Maintained |
| 217 | F: drivers/hwmon/abituguru.c | 200 | F: drivers/hwmon/abituguru.c |
| 218 | 201 | ||
| 219 | ABIT UGURU 3 HARDWARE MONITOR DRIVER | 202 | ABIT UGURU 3 HARDWARE MONITOR DRIVER |
| 220 | P: Alistair John Strachan | 203 | M: Alistair John Strachan <alistair@devzero.co.uk> |
| 221 | M: alistair@devzero.co.uk | ||
| 222 | L: lm-sensors@lm-sensors.org | 204 | L: lm-sensors@lm-sensors.org |
| 223 | S: Maintained | 205 | S: Maintained |
| 224 | F: drivers/hwmon/abituguru3.c | 206 | F: drivers/hwmon/abituguru3.c |
| 225 | 207 | ||
| 226 | ACENIC DRIVER | 208 | ACENIC DRIVER |
| 227 | P: Jes Sorensen | 209 | M: Jes Sorensen <jes@trained-monkey.org> |
| 228 | M: jes@trained-monkey.org | ||
| 229 | L: linux-acenic@sunsite.dk | 210 | L: linux-acenic@sunsite.dk |
| 230 | S: Maintained | 211 | S: Maintained |
| 231 | F: drivers/net/acenic* | 212 | F: drivers/net/acenic* |
| 232 | 213 | ||
| 233 | ACER ASPIRE ONE TEMPERATURE AND FAN DRIVER | 214 | ACER ASPIRE ONE TEMPERATURE AND FAN DRIVER |
| 234 | P: Peter Feuerer | 215 | M: Peter Feuerer <peter@piie.net> |
| 235 | M: peter@piie.net | 216 | W: http://piie.net/?section=acerhdf |
| 236 | W: http://piie.net/?section=acerhdf | 217 | S: Maintained |
| 237 | S: Maintained | 218 | F: drivers/platform/x86/acerhdf.c |
| 238 | F: drivers/platform/x86/acerhdf.c | ||
| 239 | 219 | ||
| 240 | ACER WMI LAPTOP EXTRAS | 220 | ACER WMI LAPTOP EXTRAS |
| 241 | P: Carlos Corbacho | 221 | M: Carlos Corbacho <carlos@strangeworlds.co.uk> |
| 242 | M: carlos@strangeworlds.co.uk | ||
| 243 | L: aceracpi@googlegroups.com (subscribers-only) | 222 | L: aceracpi@googlegroups.com (subscribers-only) |
| 244 | W: http://code.google.com/p/aceracpi | 223 | W: http://code.google.com/p/aceracpi |
| 245 | S: Maintained | 224 | S: Maintained |
| 246 | F: drivers/platform/x86/acer-wmi.c | 225 | F: drivers/platform/x86/acer-wmi.c |
| 247 | 226 | ||
| 248 | ACPI | 227 | ACPI |
| 249 | P: Len Brown | 228 | M: Len Brown <lenb@kernel.org> |
| 250 | M: lenb@kernel.org | ||
| 251 | L: linux-acpi@vger.kernel.org | 229 | L: linux-acpi@vger.kernel.org |
| 252 | W: http://www.lesswatts.org/projects/acpi/ | 230 | W: http://www.lesswatts.org/projects/acpi/ |
| 253 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux-acpi-2.6.git | 231 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux-acpi-2.6.git |
| @@ -257,8 +235,7 @@ F: drivers/pnp/pnpacpi/ | |||
| 257 | F: include/linux/acpi.h | 235 | F: include/linux/acpi.h |
| 258 | 236 | ||
| 259 | ACPI BATTERY DRIVERS | 237 | ACPI BATTERY DRIVERS |
| 260 | P: Alexey Starikovskiy | 238 | M: Alexey Starikovskiy <astarikovskiy@suse.de> |
| 261 | M: astarikovskiy@suse.de | ||
| 262 | L: linux-acpi@vger.kernel.org | 239 | L: linux-acpi@vger.kernel.org |
| 263 | W: http://www.lesswatts.org/projects/acpi/ | 240 | W: http://www.lesswatts.org/projects/acpi/ |
| 264 | S: Supported | 241 | S: Supported |
| @@ -266,80 +243,69 @@ F: drivers/acpi/battery.c | |||
| 266 | F: drivers/acpi/*sbs* | 243 | F: drivers/acpi/*sbs* |
| 267 | 244 | ||
| 268 | ACPI EC DRIVER | 245 | ACPI EC DRIVER |
| 269 | P: Alexey Starikovskiy | 246 | M: Alexey Starikovskiy <astarikovskiy@suse.de> |
| 270 | M: astarikovskiy@suse.de | ||
| 271 | L: linux-acpi@vger.kernel.org | 247 | L: linux-acpi@vger.kernel.org |
| 272 | W: http://www.lesswatts.org/projects/acpi/ | 248 | W: http://www.lesswatts.org/projects/acpi/ |
| 273 | S: Supported | 249 | S: Supported |
| 274 | F: drivers/acpi/ec.c | 250 | F: drivers/acpi/ec.c |
| 275 | 251 | ||
| 276 | ACPI FAN DRIVER | 252 | ACPI FAN DRIVER |
| 277 | P: Zhang Rui | 253 | M: Zhang Rui <rui.zhang@intel.com> |
| 278 | M: rui.zhang@intel.com | ||
| 279 | L: linux-acpi@vger.kernel.org | 254 | L: linux-acpi@vger.kernel.org |
| 280 | W: http://www.lesswatts.org/projects/acpi/ | 255 | W: http://www.lesswatts.org/projects/acpi/ |
| 281 | S: Supported | 256 | S: Supported |
| 282 | F: drivers/acpi/fan.c | 257 | F: drivers/acpi/fan.c |
| 283 | 258 | ||
| 284 | ACPI PCI HOTPLUG DRIVER | 259 | ACPI PCI HOTPLUG DRIVER |
| 285 | P: Kristen Carlson Accardi | 260 | M: Kristen Carlson Accardi <kristen.c.accardi@intel.com> |
| 286 | M: kristen.c.accardi@intel.com | ||
| 287 | L: linux-pci@vger.kernel.org | 261 | L: linux-pci@vger.kernel.org |
| 288 | S: Supported | 262 | S: Supported |
| 289 | F: drivers/pci/hotplug/acpi* | 263 | F: drivers/pci/hotplug/acpi* |
| 290 | 264 | ||
| 291 | ACPI THERMAL DRIVER | 265 | ACPI THERMAL DRIVER |
| 292 | P: Zhang Rui | 266 | M: Zhang Rui <rui.zhang@intel.com> |
| 293 | M: rui.zhang@intel.com | ||
| 294 | L: linux-acpi@vger.kernel.org | 267 | L: linux-acpi@vger.kernel.org |
| 295 | W: http://www.lesswatts.org/projects/acpi/ | 268 | W: http://www.lesswatts.org/projects/acpi/ |
| 296 | S: Supported | 269 | S: Supported |
| 297 | F: drivers/acpi/*thermal* | 270 | F: drivers/acpi/*thermal* |
| 298 | 271 | ||
| 299 | ACPI VIDEO DRIVER | 272 | ACPI VIDEO DRIVER |
| 300 | P: Zhang Rui | 273 | M: Zhang Rui <rui.zhang@intel.com> |
| 301 | M: rui.zhang@intel.com | ||
| 302 | L: linux-acpi@vger.kernel.org | 274 | L: linux-acpi@vger.kernel.org |
| 303 | W: http://www.lesswatts.org/projects/acpi/ | 275 | W: http://www.lesswatts.org/projects/acpi/ |
| 304 | S: Supported | 276 | S: Supported |
| 305 | F: drivers/acpi/video.c | 277 | F: drivers/acpi/video.c |
| 306 | 278 | ||
| 307 | ACPI WMI DRIVER | 279 | ACPI WMI DRIVER |
| 308 | P: Carlos Corbacho | 280 | M: Carlos Corbacho <carlos@strangeworlds.co.uk> |
| 309 | M: carlos@strangeworlds.co.uk | ||
| 310 | L: linux-acpi@vger.kernel.org | 281 | L: linux-acpi@vger.kernel.org |
| 311 | W: http://www.lesswatts.org/projects/acpi/ | 282 | W: http://www.lesswatts.org/projects/acpi/ |
| 312 | S: Maintained | 283 | S: Maintained |
| 313 | F: drivers/platform/x86/wmi.c | 284 | F: drivers/platform/x86/wmi.c |
| 314 | 285 | ||
| 315 | AD1889 ALSA SOUND DRIVER | 286 | AD1889 ALSA SOUND DRIVER |
| 316 | P: Kyle McMartin | 287 | M: Kyle McMartin <kyle@mcmartin.ca> |
| 317 | M: kyle@mcmartin.ca | 288 | M: Thibaut Varene <T-Bone@parisc-linux.org> |
| 318 | P: Thibaut Varene | ||
| 319 | M: T-Bone@parisc-linux.org | ||
| 320 | W: http://wiki.parisc-linux.org/AD1889 | 289 | W: http://wiki.parisc-linux.org/AD1889 |
| 321 | L: linux-parisc@vger.kernel.org | 290 | L: linux-parisc@vger.kernel.org |
| 322 | S: Maintained | 291 | S: Maintained |
| 323 | F: sound/pci/ad1889.* | 292 | F: sound/pci/ad1889.* |
| 324 | 293 | ||
| 325 | ADM1025 HARDWARE MONITOR DRIVER | 294 | ADM1025 HARDWARE MONITOR DRIVER |
| 326 | P: Jean Delvare | 295 | M: Jean Delvare <khali@linux-fr.org> |
| 327 | M: khali@linux-fr.org | ||
| 328 | L: lm-sensors@lm-sensors.org | 296 | L: lm-sensors@lm-sensors.org |
| 329 | S: Maintained | 297 | S: Maintained |
| 330 | F: Documentation/hwmon/adm1025 | 298 | F: Documentation/hwmon/adm1025 |
| 331 | F: drivers/hwmon/adm1025.c | 299 | F: drivers/hwmon/adm1025.c |
| 332 | 300 | ||
| 333 | ADM1029 HARDWARE MONITOR DRIVER | 301 | ADM1029 HARDWARE MONITOR DRIVER |
| 334 | P: Corentin Labbe | 302 | M: Corentin Labbe <corentin.labbe@geomatys.fr> |
| 335 | M: corentin.labbe@geomatys.fr | ||
| 336 | L: lm-sensors@lm-sensors.org | 303 | L: lm-sensors@lm-sensors.org |
| 337 | S: Maintained | 304 | S: Maintained |
| 338 | F: drivers/hwmon/adm1029.c | 305 | F: drivers/hwmon/adm1029.c |
| 339 | 306 | ||
| 340 | ADM8211 WIRELESS DRIVER | 307 | ADM8211 WIRELESS DRIVER |
| 341 | P: Michael Wu | 308 | M: Michael Wu <flamingice@sourmilk.net> |
| 342 | M: flamingice@sourmilk.net | ||
| 343 | L: linux-wireless@vger.kernel.org | 309 | L: linux-wireless@vger.kernel.org |
| 344 | W: http://linuxwireless.org/ | 310 | W: http://linuxwireless.org/ |
| 345 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mwu/mac80211-drivers.git | 311 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mwu/mac80211-drivers.git |
| @@ -347,35 +313,30 @@ S: Maintained | |||
| 347 | F: drivers/net/wireless/adm8211.* | 313 | F: drivers/net/wireless/adm8211.* |
| 348 | 314 | ||
| 349 | ADT746X FAN DRIVER | 315 | ADT746X FAN DRIVER |
| 350 | P: Colin Leroy | 316 | M: Colin Leroy <colin@colino.net> |
| 351 | M: colin@colino.net | ||
| 352 | S: Maintained | 317 | S: Maintained |
| 353 | F: drivers/macintosh/therm_adt746x.c | 318 | F: drivers/macintosh/therm_adt746x.c |
| 354 | 319 | ||
| 355 | ADVANSYS SCSI DRIVER | 320 | ADVANSYS SCSI DRIVER |
| 356 | P: Matthew Wilcox | 321 | M: Matthew Wilcox <matthew@wil.cx> |
| 357 | M: matthew@wil.cx | ||
| 358 | L: linux-scsi@vger.kernel.org | 322 | L: linux-scsi@vger.kernel.org |
| 359 | S: Maintained | 323 | S: Maintained |
| 360 | F: Documentation/scsi/advansys.txt | 324 | F: Documentation/scsi/advansys.txt |
| 361 | F: drivers/scsi/advansys.c | 325 | F: drivers/scsi/advansys.c |
| 362 | 326 | ||
| 363 | AEDSP16 DRIVER | 327 | AEDSP16 DRIVER |
| 364 | P: Riccardo Facchetti | 328 | M: Riccardo Facchetti <fizban@tin.it> |
| 365 | M: fizban@tin.it | ||
| 366 | S: Maintained | 329 | S: Maintained |
| 367 | F: sound/oss/aedsp16.c | 330 | F: sound/oss/aedsp16.c |
| 368 | 331 | ||
| 369 | AFFS FILE SYSTEM | 332 | AFFS FILE SYSTEM |
| 370 | P: Roman Zippel | 333 | M: Roman Zippel <zippel@linux-m68k.org> |
| 371 | M: zippel@linux-m68k.org | ||
| 372 | S: Maintained | 334 | S: Maintained |
| 373 | F: Documentation/filesystems/affs.txt | 335 | F: Documentation/filesystems/affs.txt |
| 374 | F: fs/affs/ | 336 | F: fs/affs/ |
| 375 | 337 | ||
| 376 | AFS FILESYSTEM & AF_RXRPC SOCKET DOMAIN | 338 | AFS FILESYSTEM & AF_RXRPC SOCKET DOMAIN |
| 377 | P: David Howells | 339 | M: David Howells <dhowells@redhat.com> |
| 378 | M: dhowells@redhat.com | ||
| 379 | L: linux-afs@lists.infradead.org | 340 | L: linux-afs@lists.infradead.org |
| 380 | S: Supported | 341 | S: Supported |
| 381 | F: fs/afs/ | 342 | F: fs/afs/ |
| @@ -383,40 +344,35 @@ F: include/net/af_rxrpc.h | |||
| 383 | F: net/rxrpc/af_rxrpc.c | 344 | F: net/rxrpc/af_rxrpc.c |
| 384 | 345 | ||
| 385 | AGPGART DRIVER | 346 | AGPGART DRIVER |
| 386 | P: David Airlie | 347 | M: David Airlie <airlied@linux.ie> |
| 387 | M: airlied@linux.ie | ||
| 388 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/airlied/drm-2.6.git | 348 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/airlied/drm-2.6.git |
| 389 | S: Maintained | 349 | S: Maintained |
| 390 | F: drivers/char/agp/ | 350 | F: drivers/char/agp/ |
| 391 | F: include/linux/agp* | 351 | F: include/linux/agp* |
| 392 | 352 | ||
| 393 | AHA152X SCSI DRIVER | 353 | AHA152X SCSI DRIVER |
| 394 | P: Juergen E. Fischer | 354 | M: "Juergen E. Fischer" <fischer@norbit.de> |
| 395 | M: fischer@norbit.de | ||
| 396 | L: linux-scsi@vger.kernel.org | 355 | L: linux-scsi@vger.kernel.org |
| 397 | S: Maintained | 356 | S: Maintained |
| 398 | F: drivers/scsi/aha152x* | 357 | F: drivers/scsi/aha152x* |
| 399 | F: drivers/scsi/pcmcia/aha152x* | 358 | F: drivers/scsi/pcmcia/aha152x* |
| 400 | 359 | ||
| 401 | AIC7XXX / AIC79XX SCSI DRIVER | 360 | AIC7XXX / AIC79XX SCSI DRIVER |
| 402 | P: Hannes Reinecke | 361 | M: Hannes Reinecke <hare@suse.de> |
| 403 | M: hare@suse.de | ||
| 404 | L: linux-scsi@vger.kernel.org | 362 | L: linux-scsi@vger.kernel.org |
| 405 | S: Maintained | 363 | S: Maintained |
| 406 | F: drivers/scsi/aic7xxx/ | 364 | F: drivers/scsi/aic7xxx/ |
| 407 | F: drivers/scsi/aic7xxx_old/ | 365 | F: drivers/scsi/aic7xxx_old/ |
| 408 | 366 | ||
| 409 | AIO | 367 | AIO |
| 410 | P: Benjamin LaHaise | 368 | M: Benjamin LaHaise <bcrl@kvack.org> |
| 411 | M: bcrl@kvack.org | ||
| 412 | L: linux-aio@kvack.org | 369 | L: linux-aio@kvack.org |
| 413 | S: Supported | 370 | S: Supported |
| 414 | F: fs/aio.c | 371 | F: fs/aio.c |
| 415 | F: include/linux/*aio*.h | 372 | F: include/linux/*aio*.h |
| 416 | 373 | ||
| 417 | ALCATEL SPEEDTOUCH USB DRIVER | 374 | ALCATEL SPEEDTOUCH USB DRIVER |
| 418 | P: Duncan Sands | 375 | M: Duncan Sands <duncan.sands@free.fr> |
| 419 | M: duncan.sands@free.fr | ||
| 420 | L: linux-usb@vger.kernel.org | 376 | L: linux-usb@vger.kernel.org |
| 421 | W: http://www.linux-usb.org/SpeedTouch/ | 377 | W: http://www.linux-usb.org/SpeedTouch/ |
| 422 | S: Maintained | 378 | S: Maintained |
| @@ -424,32 +380,27 @@ F: drivers/usb/atm/speedtch.c | |||
| 424 | F: drivers/usb/atm/usbatm.c | 380 | F: drivers/usb/atm/usbatm.c |
| 425 | 381 | ||
| 426 | ALCHEMY AU1XX0 MMC DRIVER | 382 | ALCHEMY AU1XX0 MMC DRIVER |
| 427 | P: Manuel Lauss | 383 | M: Manuel Lauss <manuel.lauss@gmail.com> |
| 428 | M: manuel.lauss@gmail.com | ||
| 429 | S: Maintained | 384 | S: Maintained |
| 430 | F: drivers/mmc/host/au1xmmc.c | 385 | F: drivers/mmc/host/au1xmmc.c |
| 431 | 386 | ||
| 432 | ALI1563 I2C DRIVER | 387 | ALI1563 I2C DRIVER |
| 433 | P: Rudolf Marek | 388 | M: Rudolf Marek <r.marek@assembler.cz> |
| 434 | M: r.marek@assembler.cz | ||
| 435 | L: linux-i2c@vger.kernel.org | 389 | L: linux-i2c@vger.kernel.org |
| 436 | S: Maintained | 390 | S: Maintained |
| 437 | F: Documentation/i2c/busses/i2c-ali1563 | 391 | F: Documentation/i2c/busses/i2c-ali1563 |
| 438 | F: drivers/i2c/busses/i2c-ali1563.c | 392 | F: drivers/i2c/busses/i2c-ali1563.c |
| 439 | 393 | ||
| 440 | ALPHA PORT | 394 | ALPHA PORT |
| 441 | P: Richard Henderson | 395 | M: Richard Henderson <rth@twiddle.net> |
| 442 | M: rth@twiddle.net | ||
| 443 | S: Odd Fixes for 2.4; Maintained for 2.6. | 396 | S: Odd Fixes for 2.4; Maintained for 2.6. |
| 444 | P: Ivan Kokshaysky | 397 | M: Ivan Kokshaysky <ink@jurassic.park.msu.ru> |
| 445 | M: ink@jurassic.park.msu.ru | ||
| 446 | S: Maintained for 2.4; PCI support for 2.6. | 398 | S: Maintained for 2.4; PCI support for 2.6. |
| 447 | L: linux-alpha@vger.kernel.org | 399 | L: linux-alpha@vger.kernel.org |
| 448 | F: arch/alpha/ | 400 | F: arch/alpha/ |
| 449 | 401 | ||
| 450 | AMD GEODE CS5536 USB DEVICE CONTROLLER DRIVER | 402 | AMD GEODE CS5536 USB DEVICE CONTROLLER DRIVER |
| 451 | P: Thomas Dahlmann | 403 | M: Thomas Dahlmann <dahlmann.thomas@arcor.de> |
| 452 | M: dahlmann.thomas@arcor.de | ||
| 453 | L: linux-geode@lists.infradead.org (moderated for non-subscribers) | 404 | L: linux-geode@lists.infradead.org (moderated for non-subscribers) |
| 454 | S: Supported | 405 | S: Supported |
| 455 | F: drivers/usb/gadget/amd5536udc.* | 406 | F: drivers/usb/gadget/amd5536udc.* |
| @@ -466,8 +417,7 @@ F: drivers/video/geode/ | |||
| 466 | F: arch/x86/include/asm/geode.h | 417 | F: arch/x86/include/asm/geode.h |
| 467 | 418 | ||
| 468 | AMD IOMMU (AMD-VI) | 419 | AMD IOMMU (AMD-VI) |
| 469 | P: Joerg Roedel | 420 | M: Joerg Roedel <joerg.roedel@amd.com> |
| 470 | M: joerg.roedel@amd.com | ||
| 471 | L: iommu@lists.linux-foundation.org | 421 | L: iommu@lists.linux-foundation.org |
| 472 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/joro/linux-2.6-iommu.git | 422 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/joro/linux-2.6-iommu.git |
| 473 | S: Supported | 423 | S: Supported |
| @@ -475,40 +425,33 @@ F: arch/x86/kernel/amd_iommu*.c | |||
| 475 | F: arch/x86/include/asm/amd_iommu*.h | 425 | F: arch/x86/include/asm/amd_iommu*.h |
| 476 | 426 | ||
| 477 | AMD MICROCODE UPDATE SUPPORT | 427 | AMD MICROCODE UPDATE SUPPORT |
| 478 | P: Andreas Herrmann | 428 | M: Andreas Herrmann <andreas.herrmann3@amd.com> |
| 479 | M: andreas.herrmann3@amd.com | ||
| 480 | L: amd64-microcode@amd64.org | 429 | L: amd64-microcode@amd64.org |
| 481 | S: Supported | 430 | S: Supported |
| 482 | F: arch/x86/kernel/microcode_amd.c | 431 | F: arch/x86/kernel/microcode_amd.c |
| 483 | 432 | ||
| 484 | AMS (Apple Motion Sensor) DRIVER | 433 | AMS (Apple Motion Sensor) DRIVER |
| 485 | P: Stelian Pop | 434 | M: Stelian Pop <stelian@popies.net> |
| 486 | M: stelian@popies.net | 435 | M: Michael Hanselmann <linux-kernel@hansmi.ch> |
| 487 | P: Michael Hanselmann | ||
| 488 | M: linux-kernel@hansmi.ch | ||
| 489 | S: Supported | 436 | S: Supported |
| 490 | F: drivers/hwmon/ams/ | 437 | F: drivers/hwmon/ams/ |
| 491 | 438 | ||
| 492 | AMSO1100 RNIC DRIVER | 439 | AMSO1100 RNIC DRIVER |
| 493 | P: Tom Tucker | 440 | M: Tom Tucker <tom@opengridcomputing.com> |
| 494 | M: tom@opengridcomputing.com | 441 | M: Steve Wise <swise@opengridcomputing.com> |
| 495 | P: Steve Wise | ||
| 496 | M: swise@opengridcomputing.com | ||
| 497 | L: general@lists.openfabrics.org | 442 | L: general@lists.openfabrics.org |
| 498 | S: Maintained | 443 | S: Maintained |
| 499 | F: drivers/infiniband/hw/amso1100/ | 444 | F: drivers/infiniband/hw/amso1100/ |
| 500 | 445 | ||
| 501 | AOA (Apple Onboard Audio) ALSA DRIVER | 446 | AOA (Apple Onboard Audio) ALSA DRIVER |
| 502 | P: Johannes Berg | 447 | M: Johannes Berg <johannes@sipsolutions.net> |
| 503 | M: johannes@sipsolutions.net | ||
| 504 | L: linuxppc-dev@ozlabs.org | 448 | L: linuxppc-dev@ozlabs.org |
| 505 | L: alsa-devel@alsa-project.org (moderated for non-subscribers) | 449 | L: alsa-devel@alsa-project.org (moderated for non-subscribers) |
| 506 | S: Maintained | 450 | S: Maintained |
| 507 | F: sound/aoa/ | 451 | F: sound/aoa/ |
| 508 | 452 | ||
| 509 | APM DRIVER | 453 | APM DRIVER |
| 510 | P: Stephen Rothwell | 454 | M: Stephen Rothwell <sfr@canb.auug.org.au> |
| 511 | M: sfr@canb.auug.org.au | ||
| 512 | L: linux-laptop@vger.kernel.org | 455 | L: linux-laptop@vger.kernel.org |
| 513 | W: http://www.canb.auug.org.au/~sfr/ | 456 | W: http://www.canb.auug.org.au/~sfr/ |
| 514 | S: Supported | 457 | S: Supported |
| @@ -516,51 +459,44 @@ F: arch/x86/kernel/apm_32.c | |||
| 516 | F: include/linux/apm_bios.h | 459 | F: include/linux/apm_bios.h |
| 517 | 460 | ||
| 518 | APPLE BCM5974 MULTITOUCH DRIVER | 461 | APPLE BCM5974 MULTITOUCH DRIVER |
| 519 | P: Henrik Rydberg | 462 | M: Henrik Rydberg <rydberg@euromail.se> |
| 520 | M: rydberg@euromail.se | ||
| 521 | L: linux-input@vger.kernel.org | 463 | L: linux-input@vger.kernel.org |
| 522 | S: Maintained | 464 | S: Maintained |
| 523 | F: drivers/input/mouse/bcm5974.c | 465 | F: drivers/input/mouse/bcm5974.c |
| 524 | 466 | ||
| 525 | APPLE SMC DRIVER | 467 | APPLE SMC DRIVER |
| 526 | P: Nicolas Boichat | 468 | M: Nicolas Boichat <nicolas@boichat.ch> |
| 527 | M: nicolas@boichat.ch | ||
| 528 | L: mactel-linux-devel@lists.sourceforge.net | 469 | L: mactel-linux-devel@lists.sourceforge.net |
| 529 | S: Maintained | 470 | S: Maintained |
| 530 | F: drivers/hwmon/applesmc.c | 471 | F: drivers/hwmon/applesmc.c |
| 531 | 472 | ||
| 532 | APPLETALK NETWORK LAYER | 473 | APPLETALK NETWORK LAYER |
| 533 | P: Arnaldo Carvalho de Melo | 474 | M: Arnaldo Carvalho de Melo <acme@ghostprotocols.net> |
| 534 | M: acme@ghostprotocols.net | ||
| 535 | S: Maintained | 475 | S: Maintained |
| 536 | F: drivers/net/appletalk/ | 476 | F: drivers/net/appletalk/ |
| 537 | F: net/appletalk/ | 477 | F: net/appletalk/ |
| 538 | 478 | ||
| 539 | APPLETOUCH TOUCHPAD DRIVER | 479 | APPLETOUCH TOUCHPAD DRIVER |
| 540 | P: Johannes Berg | 480 | M: Johannes Berg <johannes@sipsolutions.net> |
| 541 | M: johannes@sipsolutions.net | ||
| 542 | L: linux-input@vger.kernel.org | 481 | L: linux-input@vger.kernel.org |
| 543 | S: Maintained | 482 | S: Maintained |
| 544 | F: Documentation/input/appletouch.txt | 483 | F: Documentation/input/appletouch.txt |
| 545 | F: drivers/input/mouse/appletouch.c | 484 | F: drivers/input/mouse/appletouch.c |
| 546 | 485 | ||
| 547 | ARC FRAMEBUFFER DRIVER | 486 | ARC FRAMEBUFFER DRIVER |
| 548 | P: Jaya Kumar | 487 | M: Jaya Kumar <jayalk@intworks.biz> |
| 549 | M: jayalk@intworks.biz | ||
| 550 | S: Maintained | 488 | S: Maintained |
| 551 | F: drivers/video/arcfb.c | 489 | F: drivers/video/arcfb.c |
| 552 | F: drivers/video/fb_defio.c | 490 | F: drivers/video/fb_defio.c |
| 553 | 491 | ||
| 554 | ARM MFM AND FLOPPY DRIVERS | 492 | ARM MFM AND FLOPPY DRIVERS |
| 555 | P: Ian Molton | 493 | M: Ian Molton <spyro@f2s.com> |
| 556 | M: spyro@f2s.com | ||
| 557 | S: Maintained | 494 | S: Maintained |
| 558 | F: arch/arm/lib/floppydma.S | 495 | F: arch/arm/lib/floppydma.S |
| 559 | F: arch/arm/include/asm/floppy.h | 496 | F: arch/arm/include/asm/floppy.h |
| 560 | 497 | ||
| 561 | ARM PORT | 498 | ARM PORT |
| 562 | P: Russell King | 499 | M: Russell King <linux@arm.linux.org.uk> |
| 563 | M: linux@arm.linux.org.uk | ||
| 564 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 500 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 565 | W: http://www.arm.linux.org.uk/ | 501 | W: http://www.arm.linux.org.uk/ |
| 566 | S: Maintained | 502 | S: Maintained |
| @@ -571,79 +507,67 @@ S: Orphan | |||
| 571 | F: drivers/mmc/host/mmci.* | 507 | F: drivers/mmc/host/mmci.* |
| 572 | 508 | ||
| 573 | ARM/ADI ROADRUNNER MACHINE SUPPORT | 509 | ARM/ADI ROADRUNNER MACHINE SUPPORT |
| 574 | P: Lennert Buytenhek | 510 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 575 | M: kernel@wantstofly.org | ||
| 576 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 511 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 577 | S: Maintained | 512 | S: Maintained |
| 578 | F: arch/arm/mach-ixp23xx/ | 513 | F: arch/arm/mach-ixp23xx/ |
| 579 | F: arch/arm/mach-ixp23xx/include/mach/ | 514 | F: arch/arm/mach-ixp23xx/include/mach/ |
| 580 | 515 | ||
| 581 | ARM/ADS SPHERE MACHINE SUPPORT | 516 | ARM/ADS SPHERE MACHINE SUPPORT |
| 582 | P: Lennert Buytenhek | 517 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 583 | M: kernel@wantstofly.org | ||
| 584 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 518 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 585 | S: Maintained | 519 | S: Maintained |
| 586 | 520 | ||
| 587 | ARM/AFEB9260 MACHINE SUPPORT | 521 | ARM/AFEB9260 MACHINE SUPPORT |
| 588 | P: Sergey Lapin | 522 | M: Sergey Lapin <slapin@ossfans.org> |
| 589 | M: slapin@ossfans.org | ||
| 590 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 523 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 591 | S: Maintained | 524 | S: Maintained |
| 592 | 525 | ||
| 593 | ARM/AJECO 1ARM MACHINE SUPPORT | 526 | ARM/AJECO 1ARM MACHINE SUPPORT |
| 594 | P: Lennert Buytenhek | 527 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 595 | M: kernel@wantstofly.org | ||
| 596 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 528 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 597 | S: Maintained | 529 | S: Maintained |
| 598 | 530 | ||
| 599 | ARM/ATMEL AT91RM9200 ARM ARCHITECTURE | 531 | ARM/ATMEL AT91RM9200 ARM ARCHITECTURE |
| 600 | P: Andrew Victor | 532 | M: Andrew Victor <linux@maxim.org.za> |
| 601 | M: linux@maxim.org.za | ||
| 602 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 533 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 603 | W: http://maxim.org.za/at91_26.html | 534 | W: http://maxim.org.za/at91_26.html |
| 604 | S: Maintained | 535 | S: Maintained |
| 605 | 536 | ||
| 606 | ARM/CIRRUS LOGIC EP93XX ARM ARCHITECTURE | 537 | ARM/CIRRUS LOGIC EP93XX ARM ARCHITECTURE |
| 607 | P: Lennert Buytenhek | 538 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 608 | M: kernel@wantstofly.org | ||
| 609 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 539 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 610 | S: Maintained | 540 | S: Maintained |
| 611 | 541 | ||
| 612 | ARM/CIRRUS LOGIC EDB9315A MACHINE SUPPORT | 542 | ARM/CIRRUS LOGIC EDB9315A MACHINE SUPPORT |
| 613 | P: Lennert Buytenhek | 543 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 614 | M: kernel@wantstofly.org | ||
| 615 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 544 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 616 | S: Maintained | 545 | S: Maintained |
| 617 | 546 | ||
| 618 | ARM/CLKDEV SUPPORT | 547 | ARM/CLKDEV SUPPORT |
| 619 | P: Russell King | 548 | M: Russell King <linux@arm.linux.org.uk> |
| 620 | M: linux@arm.linux.org.uk | ||
| 621 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 549 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 622 | F: arch/arm/common/clkdev.c | 550 | F: arch/arm/common/clkdev.c |
| 623 | F: arch/arm/include/asm/clkdev.h | 551 | F: arch/arm/include/asm/clkdev.h |
| 624 | 552 | ||
| 625 | ARM/COMPULAB CM-X270/EM-X270 and CM-X300 MACHINE SUPPORT | 553 | ARM/COMPULAB CM-X270/EM-X270 and CM-X300 MACHINE SUPPORT |
| 626 | P: Mike Rapoport | 554 | M: Mike Rapoport <mike@compulab.co.il> |
| 627 | M: mike@compulab.co.il | ||
| 628 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 555 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 629 | S: Maintained | 556 | S: Maintained |
| 630 | 557 | ||
| 631 | ARM/CORGI MACHINE SUPPORT | 558 | ARM/CORGI MACHINE SUPPORT |
| 632 | P: Richard Purdie | 559 | M: Richard Purdie <rpurdie@rpsys.net> |
| 633 | M: rpurdie@rpsys.net | ||
| 634 | S: Maintained | 560 | S: Maintained |
| 635 | 561 | ||
| 636 | ARM/CORTINA SYSTEMS GEMINI ARM ARCHITECTURE | 562 | ARM/CORTINA SYSTEMS GEMINI ARM ARCHITECTURE |
| 637 | P: Paulius Zaleckas | 563 | M: Paulius Zaleckas <paulius.zaleckas@teltonika.lt> |
| 638 | M: paulius.zaleckas@teltonika.lt | ||
| 639 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 564 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 640 | T: git git://gitorious.org/linux-gemini/mainline.git | 565 | T: git git://gitorious.org/linux-gemini/mainline.git |
| 641 | S: Maintained | 566 | S: Maintained |
| 642 | F: arch/arm/mach-gemini/ | 567 | F: arch/arm/mach-gemini/ |
| 643 | 568 | ||
| 644 | ARM/EBSA110 MACHINE SUPPORT | 569 | ARM/EBSA110 MACHINE SUPPORT |
| 645 | P: Russell King | 570 | M: Russell King <linux@arm.linux.org.uk> |
| 646 | M: linux@arm.linux.org.uk | ||
| 647 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 571 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 648 | W: http://www.arm.linux.org.uk/ | 572 | W: http://www.arm.linux.org.uk/ |
| 649 | S: Maintained | 573 | S: Maintained |
| @@ -651,12 +575,9 @@ F: arch/arm/mach-ebsa110/ | |||
| 651 | F: drivers/net/arm/am79c961a.* | 575 | F: drivers/net/arm/am79c961a.* |
| 652 | 576 | ||
| 653 | ARM/EZX SMARTPHONES (A780, A910, A1200, E680, ROKR E2 and ROKR E6) | 577 | ARM/EZX SMARTPHONES (A780, A910, A1200, E680, ROKR E2 and ROKR E6) |
| 654 | P: Daniel Ribeiro | 578 | M: Daniel Ribeiro <drwyrm@gmail.com> |
| 655 | M: drwyrm@gmail.com | 579 | M: Stefan Schmidt <stefan@openezx.org> |
| 656 | P: Stefan Schmidt | 580 | M: Harald Welte <laforge@openezx.org> |
| 657 | M: stefan@openezx.org | ||
| 658 | P: Harald Welte | ||
| 659 | M: laforge@openezx.org | ||
| 660 | L: openezx-devel@lists.openezx.org (subscribers-only) | 581 | L: openezx-devel@lists.openezx.org (subscribers-only) |
| 661 | W: http://www.openezx.org/ | 582 | W: http://www.openezx.org/ |
| 662 | S: Maintained | 583 | S: Maintained |
| @@ -664,15 +585,13 @@ T: topgit git://git.openezx.org/openezx.git | |||
| 664 | F: arch/arm/mach-pxa/ezx.c | 585 | F: arch/arm/mach-pxa/ezx.c |
| 665 | 586 | ||
| 666 | ARM/FARADAY FA526 PORT | 587 | ARM/FARADAY FA526 PORT |
| 667 | P: Paulius Zaleckas | 588 | M: Paulius Zaleckas <paulius.zaleckas@teltonika.lt> |
| 668 | M: paulius.zaleckas@teltonika.lt | ||
| 669 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 589 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 670 | S: Maintained | 590 | S: Maintained |
| 671 | F: arch/arm/mm/*-fa* | 591 | F: arch/arm/mm/*-fa* |
| 672 | 592 | ||
| 673 | ARM/FOOTBRIDGE ARCHITECTURE | 593 | ARM/FOOTBRIDGE ARCHITECTURE |
| 674 | P: Russell King | 594 | M: Russell King <linux@arm.linux.org.uk> |
| 675 | M: linux@arm.linux.org.uk | ||
| 676 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 595 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 677 | W: http://www.arm.linux.org.uk/ | 596 | W: http://www.arm.linux.org.uk/ |
| 678 | S: Maintained | 597 | S: Maintained |
| @@ -680,175 +599,146 @@ F: arch/arm/include/asm/hardware/dec21285.h | |||
| 680 | F: arch/arm/mach-footbridge/ | 599 | F: arch/arm/mach-footbridge/ |
| 681 | 600 | ||
| 682 | ARM/FREESCALE IMX / MXC ARM ARCHITECTURE | 601 | ARM/FREESCALE IMX / MXC ARM ARCHITECTURE |
| 683 | P: Sascha Hauer | 602 | M: Sascha Hauer <kernel@pengutronix.de> |
| 684 | M: kernel@pengutronix.de | ||
| 685 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 603 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 686 | S: Maintained | 604 | S: Maintained |
| 687 | 605 | ||
| 688 | ARM/GLOMATION GESBC9312SX MACHINE SUPPORT | 606 | ARM/GLOMATION GESBC9312SX MACHINE SUPPORT |
| 689 | P: Lennert Buytenhek | 607 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 690 | M: kernel@wantstofly.org | ||
| 691 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 608 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 692 | S: Maintained | 609 | S: Maintained |
| 693 | 610 | ||
| 694 | ARM/GUMSTIX MACHINE SUPPORT | 611 | ARM/GUMSTIX MACHINE SUPPORT |
| 695 | P: Steve Sakoman | 612 | M: Steve Sakoman <sakoman@gmail.com> |
| 696 | M: sakoman@gmail.com | ||
| 697 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 613 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 698 | S: Maintained | 614 | S: Maintained |
| 699 | 615 | ||
| 700 | ARM/H4700 (HP IPAQ HX4700) MACHINE SUPPORT | 616 | ARM/H4700 (HP IPAQ HX4700) MACHINE SUPPORT |
| 701 | P: Philipp Zabel | 617 | M: Philipp Zabel <philipp.zabel@gmail.com> |
| 702 | M: philipp.zabel@gmail.com | ||
| 703 | S: Maintained | 618 | S: Maintained |
| 704 | F: arch/arm/mach-pxa/hx4700.c | 619 | F: arch/arm/mach-pxa/hx4700.c |
| 705 | F: arch/arm/mach-pxa/include/mach/hx4700.h | 620 | F: arch/arm/mach-pxa/include/mach/hx4700.h |
| 706 | 621 | ||
| 707 | ARM/HP JORNADA 7XX MACHINE SUPPORT | 622 | ARM/HP JORNADA 7XX MACHINE SUPPORT |
| 708 | P: Kristoffer Ericson | 623 | M: Kristoffer Ericson <kristoffer.ericson@gmail.com> |
| 709 | M: kristoffer.ericson@gmail.com | ||
| 710 | W: www.jlime.com | 624 | W: www.jlime.com |
| 711 | S: Maintained | 625 | S: Maintained |
| 626 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/kristoffer/linux-hpc.git | ||
| 627 | F: arch/arm/mach-sa1100/jornada720.c | ||
| 628 | F: arch/arm/mach-sa1100/include/mach/jornada720.h | ||
| 712 | 629 | ||
| 713 | ARM/INTEL IOP32X ARM ARCHITECTURE | 630 | ARM/INTEL IOP32X ARM ARCHITECTURE |
| 714 | P: Lennert Buytenhek | 631 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 715 | M: kernel@wantstofly.org | 632 | M: Dan Williams <dan.j.williams@intel.com> |
| 716 | P: Dan Williams | ||
| 717 | M: dan.j.williams@intel.com | ||
| 718 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 633 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 719 | S: Supported | 634 | S: Supported |
| 720 | 635 | ||
| 721 | ARM/INTEL IOP33X ARM ARCHITECTURE | 636 | ARM/INTEL IOP33X ARM ARCHITECTURE |
| 722 | P: Dan Williams | 637 | M: Dan Williams <dan.j.williams@intel.com> |
| 723 | M: dan.j.williams@intel.com | ||
| 724 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 638 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 725 | S: Supported | 639 | S: Supported |
| 726 | 640 | ||
| 727 | ARM/INTEL IOP13XX ARM ARCHITECTURE | 641 | ARM/INTEL IOP13XX ARM ARCHITECTURE |
| 728 | P: Lennert Buytenhek | 642 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 729 | M: kernel@wantstofly.org | 643 | M: Dan Williams <dan.j.williams@intel.com> |
| 730 | P: Dan Williams | ||
| 731 | M: dan.j.williams@intel.com | ||
| 732 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 644 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 733 | S: Supported | 645 | S: Supported |
| 734 | 646 | ||
| 735 | ARM/INTEL IQ81342EX MACHINE SUPPORT | 647 | ARM/INTEL IQ81342EX MACHINE SUPPORT |
| 736 | P: Lennert Buytenhek | 648 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 737 | M: kernel@wantstofly.org | 649 | M: Dan Williams <dan.j.williams@intel.com> |
| 738 | P: Dan Williams | ||
| 739 | M: dan.j.williams@intel.com | ||
| 740 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 650 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 741 | S: Supported | 651 | S: Supported |
| 742 | 652 | ||
| 743 | ARM/INTEL IXP2000 ARM ARCHITECTURE | 653 | ARM/INTEL IXP2000 ARM ARCHITECTURE |
| 744 | P: Lennert Buytenhek | 654 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 745 | M: kernel@wantstofly.org | ||
| 746 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 655 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 747 | S: Maintained | 656 | S: Maintained |
| 748 | 657 | ||
| 749 | ARM/INTEL IXDP2850 MACHINE SUPPORT | 658 | ARM/INTEL IXDP2850 MACHINE SUPPORT |
| 750 | P: Lennert Buytenhek | 659 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 751 | M: kernel@wantstofly.org | ||
| 752 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 660 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 753 | S: Maintained | 661 | S: Maintained |
| 754 | 662 | ||
| 755 | ARM/INTEL IXP23XX ARM ARCHITECTURE | 663 | ARM/INTEL IXP23XX ARM ARCHITECTURE |
| 756 | P: Lennert Buytenhek | 664 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 757 | M: kernel@wantstofly.org | ||
| 758 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 665 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 759 | S: Maintained | 666 | S: Maintained |
| 760 | 667 | ||
| 761 | ARM/INTEL XSC3 (MANZANO) ARM CORE | 668 | ARM/INTEL XSC3 (MANZANO) ARM CORE |
| 762 | P: Lennert Buytenhek | 669 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 763 | M: kernel@wantstofly.org | 670 | M: Dan Williams <dan.j.williams@intel.com> |
| 764 | P: Dan Williams | ||
| 765 | M: dan.j.williams@intel.com | ||
| 766 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 671 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 767 | S: Supported | 672 | S: Supported |
| 768 | 673 | ||
| 769 | ARM/IP FABRICS DOUBLE ESPRESSO MACHINE SUPPORT | 674 | ARM/IP FABRICS DOUBLE ESPRESSO MACHINE SUPPORT |
| 770 | P: Lennert Buytenhek | 675 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 771 | M: kernel@wantstofly.org | ||
| 772 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 676 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 773 | S: Maintained | 677 | S: Maintained |
| 774 | 678 | ||
| 775 | ARM/LOGICPD PXA270 MACHINE SUPPORT | 679 | ARM/LOGICPD PXA270 MACHINE SUPPORT |
| 776 | P: Lennert Buytenhek | 680 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 777 | M: kernel@wantstofly.org | ||
| 778 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 681 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 779 | S: Maintained | 682 | S: Maintained |
| 780 | 683 | ||
| 781 | ARM/MAGICIAN MACHINE SUPPORT | 684 | ARM/MAGICIAN MACHINE SUPPORT |
| 782 | P: Philipp Zabel | 685 | M: Philipp Zabel <philipp.zabel@gmail.com> |
| 783 | M: philipp.zabel@gmail.com | ||
| 784 | S: Maintained | 686 | S: Maintained |
| 785 | 687 | ||
| 786 | ARM/MIOA701 MACHINE SUPPORT | 688 | ARM/MIOA701 MACHINE SUPPORT |
| 787 | P: Robert Jarzmik | 689 | M: Robert Jarzmik <robert.jarzmik@free.fr> |
| 788 | M: robert.jarzmik@free.fr | ||
| 789 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 690 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 790 | F: arch/arm/mach-pxa/mioa701.c | 691 | F: arch/arm/mach-pxa/mioa701.c |
| 791 | S: Maintained | 692 | S: Maintained |
| 792 | 693 | ||
| 793 | ARM/NEC MOBILEPRO 900/c MACHINE SUPPORT | 694 | ARM/NEC MOBILEPRO 900/c MACHINE SUPPORT |
| 794 | P: Michael Petchkovsky | 695 | M: Michael Petchkovsky <mkpetch@internode.on.net> |
| 795 | M: mkpetch@internode.on.net | ||
| 796 | S: Maintained | 696 | S: Maintained |
| 797 | 697 | ||
| 798 | ARM/OPENMOKO NEO FREERUNNER (GTA02) MACHINE SUPPORT | 698 | ARM/OPENMOKO NEO FREERUNNER (GTA02) MACHINE SUPPORT |
| 799 | P: Nelson Castillo | 699 | M: Nelson Castillo <arhuaco@freaks-unidos.net> |
| 800 | M: arhuaco@freaks-unidos.net | ||
| 801 | L: openmoko-kernel@lists.openmoko.org (subscribers-only) | 700 | L: openmoko-kernel@lists.openmoko.org (subscribers-only) |
| 802 | W: http://wiki.openmoko.org/wiki/Neo_FreeRunner | 701 | W: http://wiki.openmoko.org/wiki/Neo_FreeRunner |
| 803 | S: Supported | 702 | S: Supported |
| 804 | 703 | ||
| 805 | ARM/TOSA MACHINE SUPPORT | 704 | ARM/TOSA MACHINE SUPPORT |
| 806 | P: Dmitry Eremin-Solenikov | 705 | M: Dmitry Eremin-Solenikov <dbaryshkov@gmail.com> |
| 807 | M: dbaryshkov@gmail.com | 706 | M: Dirk Opfer <dirk@opfer-online.de> |
| 808 | P: Dirk Opfer | ||
| 809 | M: dirk@opfer-online.de | ||
| 810 | S: Maintained | 707 | S: Maintained |
| 811 | 708 | ||
| 812 | ARM/PALMTX,PALMT5,PALMLD,PALMTE2 SUPPORT | 709 | ARM/PALMTX,PALMT5,PALMLD,PALMTE2 SUPPORT |
| 813 | P: Marek Vasut | 710 | M: Marek Vasut <marek.vasut@gmail.com> |
| 814 | M: marek.vasut@gmail.com | ||
| 815 | W: http://hackndev.com | 711 | W: http://hackndev.com |
| 816 | S: Maintained | 712 | S: Maintained |
| 817 | 713 | ||
| 818 | ARM/PALM TREO 680 SUPPORT | 714 | ARM/PALM TREO 680 SUPPORT |
| 819 | P: Tomas Cech | 715 | M: Tomas Cech <sleep_walker@suse.cz> |
| 820 | M: sleep_walker@suse.cz | ||
| 821 | W: http://hackndev.com | 716 | W: http://hackndev.com |
| 822 | S: Maintained | 717 | S: Maintained |
| 823 | 718 | ||
| 824 | ARM/PALMZ72 SUPPORT | 719 | ARM/PALMZ72 SUPPORT |
| 825 | P: Sergey Lapin | 720 | M: Sergey Lapin <slapin@ossfans.org> |
| 826 | M: slapin@ossfans.org | ||
| 827 | W: http://hackndev.com | 721 | W: http://hackndev.com |
| 828 | S: Maintained | 722 | S: Maintained |
| 829 | 723 | ||
| 830 | ARM/PLEB SUPPORT | 724 | ARM/PLEB SUPPORT |
| 831 | P: Peter Chubb | 725 | M: Peter Chubb <pleb@gelato.unsw.edu.au> |
| 832 | M: pleb@gelato.unsw.edu.au | ||
| 833 | W: http://www.disy.cse.unsw.edu.au/Hardware/PLEB | 726 | W: http://www.disy.cse.unsw.edu.au/Hardware/PLEB |
| 834 | S: Maintained | 727 | S: Maintained |
| 835 | 728 | ||
| 836 | ARM/PT DIGITAL BOARD PORT | 729 | ARM/PT DIGITAL BOARD PORT |
| 837 | P: Stefan Eletzhofer | 730 | M: Stefan Eletzhofer <stefan.eletzhofer@eletztrick.de> |
| 838 | M: stefan.eletzhofer@eletztrick.de | ||
| 839 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 731 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 840 | W: http://www.arm.linux.org.uk/ | 732 | W: http://www.arm.linux.org.uk/ |
| 841 | S: Maintained | 733 | S: Maintained |
| 842 | 734 | ||
| 843 | ARM/RADISYS ENP2611 MACHINE SUPPORT | 735 | ARM/RADISYS ENP2611 MACHINE SUPPORT |
| 844 | P: Lennert Buytenhek | 736 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 845 | M: kernel@wantstofly.org | ||
| 846 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 737 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 847 | S: Maintained | 738 | S: Maintained |
| 848 | 739 | ||
| 849 | ARM/RISCPC ARCHITECTURE | 740 | ARM/RISCPC ARCHITECTURE |
| 850 | P: Russell King | 741 | M: Russell King <linux@arm.linux.org.uk> |
| 851 | M: linux@arm.linux.org.uk | ||
| 852 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 742 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 853 | W: http://www.arm.linux.org.uk/ | 743 | W: http://www.arm.linux.org.uk/ |
| 854 | S: Maintained | 744 | S: Maintained |
| @@ -862,14 +752,12 @@ F: drivers/net/arm/ether* | |||
| 862 | F: drivers/scsi/arm/ | 752 | F: drivers/scsi/arm/ |
| 863 | 753 | ||
| 864 | ARM/SHARK MACHINE SUPPORT | 754 | ARM/SHARK MACHINE SUPPORT |
| 865 | P: Alexander Schulz | 755 | M: Alexander Schulz <alex@shark-linux.de> |
| 866 | M: alex@shark-linux.de | ||
| 867 | W: http://www.shark-linux.de/shark.html | 756 | W: http://www.shark-linux.de/shark.html |
| 868 | S: Maintained | 757 | S: Maintained |
| 869 | 758 | ||
| 870 | ARM/SAMSUNG ARM ARCHITECTURES | 759 | ARM/SAMSUNG ARM ARCHITECTURES |
| 871 | P: Ben Dooks | 760 | M: Ben Dooks <ben-linux@fluff.org> |
| 872 | M: ben-linux@fluff.org | ||
| 873 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 761 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 874 | W: http://www.fluff.org/ben/linux/ | 762 | W: http://www.fluff.org/ben/linux/ |
| 875 | S: Maintained | 763 | S: Maintained |
| @@ -877,91 +765,73 @@ F: arch/arm/plat-s3c/ | |||
| 877 | F: arch/arm/plat-s3c24xx/ | 765 | F: arch/arm/plat-s3c24xx/ |
| 878 | 766 | ||
| 879 | ARM/S3C2410 ARM ARCHITECTURE | 767 | ARM/S3C2410 ARM ARCHITECTURE |
| 880 | P: Ben Dooks | 768 | M: Ben Dooks <ben-linux@fluff.org> |
| 881 | M: ben-linux@fluff.org | ||
| 882 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 769 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 883 | W: http://www.fluff.org/ben/linux/ | 770 | W: http://www.fluff.org/ben/linux/ |
| 884 | S: Maintained | 771 | S: Maintained |
| 885 | F: arch/arm/mach-s3c2410/ | 772 | F: arch/arm/mach-s3c2410/ |
| 886 | 773 | ||
| 887 | ARM/S3C2440 ARM ARCHITECTURE | 774 | ARM/S3C2440 ARM ARCHITECTURE |
| 888 | P: Ben Dooks | 775 | M: Ben Dooks <ben-linux@fluff.org> |
| 889 | M: ben-linux@fluff.org | ||
| 890 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 776 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 891 | W: http://www.fluff.org/ben/linux/ | 777 | W: http://www.fluff.org/ben/linux/ |
| 892 | S: Maintained | 778 | S: Maintained |
| 893 | F: arch/arm/mach-s3c2440/ | 779 | F: arch/arm/mach-s3c2440/ |
| 894 | 780 | ||
| 895 | ARM/S3C2442 ARM ARCHITECTURE | 781 | ARM/S3C2442 ARM ARCHITECTURE |
| 896 | P: Ben Dooks | 782 | M: Ben Dooks <ben-linux@fluff.org> |
| 897 | M: ben-linux@fluff.org | ||
| 898 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 783 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 899 | W: http://www.fluff.org/ben/linux/ | 784 | W: http://www.fluff.org/ben/linux/ |
| 900 | S: Maintained | 785 | S: Maintained |
| 901 | F: arch/arm/mach-s3c2442/ | 786 | F: arch/arm/mach-s3c2442/ |
| 902 | 787 | ||
| 903 | ARM/S3C2443 ARM ARCHITECTURE | 788 | ARM/S3C2443 ARM ARCHITECTURE |
| 904 | P: Ben Dooks | 789 | M: Ben Dooks <ben-linux@fluff.org> |
| 905 | M: ben-linux@fluff.org | ||
| 906 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 790 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 907 | W: http://www.fluff.org/ben/linux/ | 791 | W: http://www.fluff.org/ben/linux/ |
| 908 | S: Maintained | 792 | S: Maintained |
| 909 | F: arch/arm/mach-s3c2443/ | 793 | F: arch/arm/mach-s3c2443/ |
| 910 | 794 | ||
| 911 | ARM/S3C6400 ARM ARCHITECTURE | 795 | ARM/S3C6400 ARM ARCHITECTURE |
| 912 | P: Ben Dooks | 796 | M: Ben Dooks <ben-linux@fluff.org> |
| 913 | M: ben-linux@fluff.org | ||
| 914 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 797 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 915 | W: http://www.fluff.org/ben/linux/ | 798 | W: http://www.fluff.org/ben/linux/ |
| 916 | S: Maintained | 799 | S: Maintained |
| 917 | F: arch/arm/mach-s3c6400/ | 800 | F: arch/arm/mach-s3c6400/ |
| 918 | 801 | ||
| 919 | ARM/S3C6410 ARM ARCHITECTURE | 802 | ARM/S3C6410 ARM ARCHITECTURE |
| 920 | P: Ben Dooks | 803 | M: Ben Dooks <ben-linux@fluff.org> |
| 921 | M: ben-linux@fluff.org | ||
| 922 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 804 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 923 | W: http://www.fluff.org/ben/linux/ | 805 | W: http://www.fluff.org/ben/linux/ |
| 924 | S: Maintained | 806 | S: Maintained |
| 925 | F: arch/arm/mach-s3c6410/ | 807 | F: arch/arm/mach-s3c6410/ |
| 926 | 808 | ||
| 927 | ARM/TECHNOLOGIC SYSTEMS TS7250 MACHINE SUPPORT | 809 | ARM/TECHNOLOGIC SYSTEMS TS7250 MACHINE SUPPORT |
| 928 | P: Lennert Buytenhek | 810 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 929 | M: kernel@wantstofly.org | ||
| 930 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 811 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 931 | S: Maintained | 812 | S: Maintained |
| 932 | 813 | ||
| 933 | ARM/THECUS N2100 MACHINE SUPPORT | 814 | ARM/THECUS N2100 MACHINE SUPPORT |
| 934 | P: Lennert Buytenhek | 815 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 935 | M: kernel@wantstofly.org | ||
| 936 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 816 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 937 | S: Maintained | 817 | S: Maintained |
| 938 | 818 | ||
| 939 | ARM/NUVOTON W90X900 ARM ARCHITECTURE | 819 | ARM/NUVOTON W90X900 ARM ARCHITECTURE |
| 940 | P: Wan ZongShun | 820 | M: Wan ZongShun <mcuos.com@gmail.com> |
| 941 | M: mcuos.com@gmail.com | ||
| 942 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 821 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 943 | W: http://www.mcuos.com | 822 | W: http://www.mcuos.com |
| 944 | S: Maintained | 823 | S: Maintained |
| 945 | 824 | ||
| 946 | ARM/VFP SUPPORT | 825 | ARM/VFP SUPPORT |
| 947 | P: Russell King | 826 | M: Russell King <linux@arm.linux.org.uk> |
| 948 | M: linux@arm.linux.org.uk | ||
| 949 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 827 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 950 | W: http://www.arm.linux.org.uk/ | 828 | W: http://www.arm.linux.org.uk/ |
| 951 | S: Maintained | 829 | S: Maintained |
| 952 | F: arch/arm/vfp/ | 830 | F: arch/arm/vfp/ |
| 953 | 831 | ||
| 954 | ARPD SUPPORT | ||
| 955 | P: Jonathan Layes | ||
| 956 | L: netdev@vger.kernel.org | ||
| 957 | S: Maintained | ||
| 958 | F: net/ipv4/arp.c | ||
| 959 | |||
| 960 | ASUS ACPI EXTRAS DRIVER | 832 | ASUS ACPI EXTRAS DRIVER |
| 961 | P: Corentin Chary | 833 | M: Corentin Chary <corentincj@iksaif.net> |
| 962 | M: corentincj@iksaif.net | 834 | M: Karol Kozimor <sziwan@users.sourceforge.net> |
| 963 | P: Karol Kozimor | ||
| 964 | M: sziwan@users.sourceforge.net | ||
| 965 | L: acpi4asus-user@lists.sourceforge.net | 835 | L: acpi4asus-user@lists.sourceforge.net |
| 966 | W: http://acpi4asus.sf.net | 836 | W: http://acpi4asus.sf.net |
| 967 | S: Maintained | 837 | S: Maintained |
| @@ -969,25 +839,21 @@ F: arch/x86/kernel/acpi/boot.c | |||
| 969 | F: drivers/platform/x86/asus_acpi.c | 839 | F: drivers/platform/x86/asus_acpi.c |
| 970 | 840 | ||
| 971 | ASUS ASB100 HARDWARE MONITOR DRIVER | 841 | ASUS ASB100 HARDWARE MONITOR DRIVER |
| 972 | P: Mark M. Hoffman | 842 | M: "Mark M. Hoffman" <mhoffman@lightlink.com> |
| 973 | M: mhoffman@lightlink.com | ||
| 974 | L: lm-sensors@lm-sensors.org | 843 | L: lm-sensors@lm-sensors.org |
| 975 | S: Maintained | 844 | S: Maintained |
| 976 | F: drivers/hwmon/asb100.c | 845 | F: drivers/hwmon/asb100.c |
| 977 | 846 | ||
| 978 | ASUS LAPTOP EXTRAS DRIVER | 847 | ASUS LAPTOP EXTRAS DRIVER |
| 979 | P: Corentin Chary | 848 | M: Corentin Chary <corentincj@iksaif.net> |
| 980 | M: corentincj@iksaif.net | ||
| 981 | L: acpi4asus-user@lists.sourceforge.net | 849 | L: acpi4asus-user@lists.sourceforge.net |
| 982 | W: http://acpi4asus.sf.net | 850 | W: http://acpi4asus.sf.net |
| 983 | S: Maintained | 851 | S: Maintained |
| 984 | F: drivers/platform/x86/asus-laptop.c | 852 | F: drivers/platform/x86/asus-laptop.c |
| 985 | 853 | ||
| 986 | ASYNCHRONOUS TRANSFERS/TRANSFORMS (IOAT) API | 854 | ASYNCHRONOUS TRANSFERS/TRANSFORMS (IOAT) API |
| 987 | P: Dan Williams | 855 | M: Dan Williams <dan.j.williams@intel.com> |
| 988 | M: dan.j.williams@intel.com | 856 | M: Maciej Sosnowski <maciej.sosnowski@intel.com> |
| 989 | P: Maciej Sosnowski | ||
| 990 | M: maciej.sosnowski@intel.com | ||
| 991 | W: http://sourceforge.net/projects/xscaleiop | 857 | W: http://sourceforge.net/projects/xscaleiop |
| 992 | S: Supported | 858 | S: Supported |
| 993 | F: Documentation/crypto/async-tx-api.txt | 859 | F: Documentation/crypto/async-tx-api.txt |
| @@ -997,64 +863,49 @@ F: include/linux/dmaengine.h | |||
| 997 | F: include/linux/async_tx.h | 863 | F: include/linux/async_tx.h |
| 998 | 864 | ||
| 999 | ATA OVER ETHERNET (AOE) DRIVER | 865 | ATA OVER ETHERNET (AOE) DRIVER |
| 1000 | P: Ed L. Cashin | 866 | M: "Ed L. Cashin" <ecashin@coraid.com> |
| 1001 | M: ecashin@coraid.com | ||
| 1002 | W: http://www.coraid.com/support/linux | 867 | W: http://www.coraid.com/support/linux |
| 1003 | S: Supported | 868 | S: Supported |
| 1004 | F: Documentation/aoe/ | 869 | F: Documentation/aoe/ |
| 1005 | F: drivers/block/aoe/ | 870 | F: drivers/block/aoe/ |
| 1006 | 871 | ||
| 1007 | ATHEROS ATH5K WIRELESS DRIVER | 872 | ATHEROS ATH5K WIRELESS DRIVER |
| 1008 | P: Jiri Slaby | 873 | M: Jiri Slaby <jirislaby@gmail.com> |
| 1009 | M: jirislaby@gmail.com | 874 | M: Nick Kossifidis <mickflemm@gmail.com> |
| 1010 | P: Nick Kossifidis | 875 | M: "Luis R. Rodriguez" <lrodriguez@atheros.com> |
| 1011 | M: mickflemm@gmail.com | 876 | M: Bob Copeland <me@bobcopeland.com> |
| 1012 | P: Luis R. Rodriguez | ||
| 1013 | M: lrodriguez@atheros.com | ||
| 1014 | P: Bob Copeland | ||
| 1015 | M: me@bobcopeland.com | ||
| 1016 | L: linux-wireless@vger.kernel.org | 877 | L: linux-wireless@vger.kernel.org |
| 1017 | L: ath5k-devel@lists.ath5k.org | 878 | L: ath5k-devel@lists.ath5k.org |
| 1018 | S: Maintained | 879 | S: Maintained |
| 1019 | F: drivers/net/wireless/ath/ath5k/ | 880 | F: drivers/net/wireless/ath/ath5k/ |
| 1020 | 881 | ||
| 1021 | ATHEROS ATH9K WIRELESS DRIVER | 882 | ATHEROS ATH9K WIRELESS DRIVER |
| 1022 | P: Luis R. Rodriguez | 883 | M: "Luis R. Rodriguez" <lrodriguez@atheros.com> |
| 1023 | M: lrodriguez@atheros.com | 884 | M: Jouni Malinen <jmalinen@atheros.com> |
| 1024 | P: Jouni Malinen | 885 | M: Sujith Manoharan <Sujith.Manoharan@atheros.com> |
| 1025 | M: jmalinen@atheros.com | 886 | M: Vasanthakumar Thiagarajan <vasanth@atheros.com> |
| 1026 | P: Sujith Manoharan | 887 | M: Senthil Balasubramanian <senthilkumar@atheros.com> |
| 1027 | M: Sujith.Manoharan@atheros.com | ||
| 1028 | P: Vasanthakumar Thiagarajan | ||
| 1029 | M: vasanth@atheros.com | ||
| 1030 | P: Senthil Balasubramanian | ||
| 1031 | M: senthilkumar@atheros.com | ||
| 1032 | L: linux-wireless@vger.kernel.org | 888 | L: linux-wireless@vger.kernel.org |
| 1033 | L: ath9k-devel@lists.ath9k.org | 889 | L: ath9k-devel@lists.ath9k.org |
| 1034 | S: Supported | 890 | S: Supported |
| 1035 | F: drivers/net/wireless/ath/ath9k/ | 891 | F: drivers/net/wireless/ath/ath9k/ |
| 1036 | 892 | ||
| 1037 | ATHEROS AR9170 WIRELESS DRIVER | 893 | ATHEROS AR9170 WIRELESS DRIVER |
| 1038 | P: Christian Lamparter | 894 | M: Christian Lamparter <chunkeey@web.de> |
| 1039 | M: chunkeey@web.de | ||
| 1040 | L: linux-wireless@vger.kernel.org | 895 | L: linux-wireless@vger.kernel.org |
| 1041 | W: http://wireless.kernel.org/en/users/Drivers/ar9170 | 896 | W: http://wireless.kernel.org/en/users/Drivers/ar9170 |
| 1042 | S: Maintained | 897 | S: Maintained |
| 1043 | F: drivers/net/wireless/ath/ar9170/ | 898 | F: drivers/net/wireless/ath/ar9170/ |
| 1044 | 899 | ||
| 1045 | ATI_REMOTE2 DRIVER | 900 | ATI_REMOTE2 DRIVER |
| 1046 | P: Ville Syrjala | 901 | M: Ville Syrjala <syrjala@sci.fi> |
| 1047 | M: syrjala@sci.fi | ||
| 1048 | S: Maintained | 902 | S: Maintained |
| 1049 | F: drivers/input/misc/ati_remote2.c | 903 | F: drivers/input/misc/ati_remote2.c |
| 1050 | 904 | ||
| 1051 | ATLX ETHERNET DRIVERS | 905 | ATLX ETHERNET DRIVERS |
| 1052 | P: Jay Cliburn | 906 | M: Jay Cliburn <jcliburn@gmail.com> |
| 1053 | M: jcliburn@gmail.com | 907 | M: Chris Snook <chris.snook@gmail.com> |
| 1054 | P: Chris Snook | 908 | M: Jie Yang <jie.yang@atheros.com> |
| 1055 | M: csnook@redhat.com | ||
| 1056 | P: Jie Yang | ||
| 1057 | M: jie.yang@atheros.com | ||
| 1058 | L: atl1-devel@lists.sourceforge.net | 909 | L: atl1-devel@lists.sourceforge.net |
| 1059 | W: http://sourceforge.net/projects/atl1 | 910 | W: http://sourceforge.net/projects/atl1 |
| 1060 | W: http://atl1.sourceforge.net | 911 | W: http://atl1.sourceforge.net |
| @@ -1062,8 +913,7 @@ S: Maintained | |||
| 1062 | F: drivers/net/atlx/ | 913 | F: drivers/net/atlx/ |
| 1063 | 914 | ||
| 1064 | ATM | 915 | ATM |
| 1065 | P: Chas Williams | 916 | M: Chas Williams <chas@cmf.nrl.navy.mil> |
| 1066 | M: chas@cmf.nrl.navy.mil | ||
| 1067 | L: linux-atm-general@lists.sourceforge.net (subscribers-only) | 917 | L: linux-atm-general@lists.sourceforge.net (subscribers-only) |
| 1068 | L: netdev@vger.kernel.org | 918 | L: netdev@vger.kernel.org |
| 1069 | W: http://linux-atm.sourceforge.net | 919 | W: http://linux-atm.sourceforge.net |
| @@ -1072,8 +922,7 @@ F: drivers/atm/ | |||
| 1072 | F: include/linux/atm* | 922 | F: include/linux/atm* |
| 1073 | 923 | ||
| 1074 | ATMEL AT91 MCI DRIVER | 924 | ATMEL AT91 MCI DRIVER |
| 1075 | P: Nicolas Ferre | 925 | M: Nicolas Ferre <nicolas.ferre@atmel.com> |
| 1076 | M: nicolas.ferre@atmel.com | ||
| 1077 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 926 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 1078 | W: http://www.atmel.com/products/AT91/ | 927 | W: http://www.atmel.com/products/AT91/ |
| 1079 | W: http://www.at91.com/ | 928 | W: http://www.at91.com/ |
| @@ -1081,49 +930,42 @@ S: Maintained | |||
| 1081 | F: drivers/mmc/host/at91_mci.c | 930 | F: drivers/mmc/host/at91_mci.c |
| 1082 | 931 | ||
| 1083 | ATMEL AT91 / AT32 MCI DRIVER | 932 | ATMEL AT91 / AT32 MCI DRIVER |
| 1084 | P: Nicolas Ferre | 933 | M: Nicolas Ferre <nicolas.ferre@atmel.com> |
| 1085 | M: nicolas.ferre@atmel.com | ||
| 1086 | S: Maintained | 934 | S: Maintained |
| 1087 | F: drivers/mmc/host/atmel-mci.c | 935 | F: drivers/mmc/host/atmel-mci.c |
| 1088 | F: drivers/mmc/host/atmel-mci-regs.h | 936 | F: drivers/mmc/host/atmel-mci-regs.h |
| 1089 | 937 | ||
| 1090 | ATMEL AT91 / AT32 SERIAL DRIVER | 938 | ATMEL AT91 / AT32 SERIAL DRIVER |
| 1091 | P: Haavard Skinnemoen | 939 | M: Haavard Skinnemoen <hskinnemoen@atmel.com> |
| 1092 | M: hskinnemoen@atmel.com | ||
| 1093 | S: Supported | 940 | S: Supported |
| 1094 | F: drivers/serial/atmel_serial.c | 941 | F: drivers/serial/atmel_serial.c |
| 1095 | 942 | ||
| 1096 | ATMEL LCDFB DRIVER | 943 | ATMEL LCDFB DRIVER |
| 1097 | P: Nicolas Ferre | 944 | M: Nicolas Ferre <nicolas.ferre@atmel.com> |
| 1098 | M: nicolas.ferre@atmel.com | ||
| 1099 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) | 945 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 1100 | S: Maintained | 946 | S: Maintained |
| 1101 | F: drivers/video/atmel_lcdfb.c | 947 | F: drivers/video/atmel_lcdfb.c |
| 1102 | F: include/video/atmel_lcdc.h | 948 | F: include/video/atmel_lcdc.h |
| 1103 | 949 | ||
| 1104 | ATMEL MACB ETHERNET DRIVER | 950 | ATMEL MACB ETHERNET DRIVER |
| 1105 | P: Haavard Skinnemoen | 951 | M: Haavard Skinnemoen <hskinnemoen@atmel.com> |
| 1106 | M: hskinnemoen@atmel.com | ||
| 1107 | S: Supported | 952 | S: Supported |
| 1108 | F: drivers/net/macb.* | 953 | F: drivers/net/macb.* |
| 1109 | 954 | ||
| 1110 | ATMEL SPI DRIVER | 955 | ATMEL SPI DRIVER |
| 1111 | P: Haavard Skinnemoen | 956 | M: Haavard Skinnemoen <hskinnemoen@atmel.com> |
| 1112 | M: hskinnemoen@atmel.com | ||
| 1113 | S: Supported | 957 | S: Supported |
| 1114 | F: drivers/spi/atmel_spi.* | 958 | F: drivers/spi/atmel_spi.* |
| 1115 | 959 | ||
| 1116 | ATMEL USBA UDC DRIVER | 960 | ATMEL USBA UDC DRIVER |
| 1117 | P: Haavard Skinnemoen | 961 | M: Haavard Skinnemoen <hskinnemoen@atmel.com> |
| 1118 | M: hskinnemoen@atmel.com | ||
| 1119 | L: kernel@avr32linux.org | 962 | L: kernel@avr32linux.org |
| 1120 | W: http://avr32linux.org/twiki/bin/view/Main/AtmelUsbDeviceDriver | 963 | W: http://avr32linux.org/twiki/bin/view/Main/AtmelUsbDeviceDriver |
| 1121 | S: Supported | 964 | S: Supported |
| 1122 | F: drivers/usb/gadget/atmel_usba_udc.* | 965 | F: drivers/usb/gadget/atmel_usba_udc.* |
| 1123 | 966 | ||
| 1124 | ATMEL WIRELESS DRIVER | 967 | ATMEL WIRELESS DRIVER |
| 1125 | P: Simon Kelley | 968 | M: Simon Kelley <simon@thekelleys.org.uk> |
| 1126 | M: simon@thekelleys.org.uk | ||
| 1127 | L: linux-wireless@vger.kernel.org | 969 | L: linux-wireless@vger.kernel.org |
| 1128 | W: http://www.thekelleys.org.uk/atmel | 970 | W: http://www.thekelleys.org.uk/atmel |
| 1129 | W: http://atmelwlandriver.sourceforge.net/ | 971 | W: http://atmelwlandriver.sourceforge.net/ |
| @@ -1131,10 +973,8 @@ S: Maintained | |||
| 1131 | F: drivers/net/wireless/atmel* | 973 | F: drivers/net/wireless/atmel* |
| 1132 | 974 | ||
| 1133 | AUDIT SUBSYSTEM | 975 | AUDIT SUBSYSTEM |
| 1134 | P: Al Viro | 976 | M: Al Viro <viro@zeniv.linux.org.uk> |
| 1135 | M: viro@zeniv.linux.org.uk | 977 | M: Eric Paris <eparis@redhat.com> |
| 1136 | P: Eric Paris | ||
| 1137 | M: eparis@redhat.com | ||
| 1138 | L: linux-audit@redhat.com (subscribers-only) | 978 | L: linux-audit@redhat.com (subscribers-only) |
| 1139 | W: http://people.redhat.com/sgrubb/audit/ | 979 | W: http://people.redhat.com/sgrubb/audit/ |
| 1140 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/viro/audit-current.git | 980 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/viro/audit-current.git |
| @@ -1143,8 +983,7 @@ F: include/linux/audit.h | |||
| 1143 | F: kernel/audit* | 983 | F: kernel/audit* |
| 1144 | 984 | ||
| 1145 | AUXILIARY DISPLAY DRIVERS | 985 | AUXILIARY DISPLAY DRIVERS |
| 1146 | P: Miguel Ojeda Sandonis | 986 | M: Miguel Ojeda Sandonis <miguel.ojeda.sandonis@gmail.com> |
| 1147 | M: miguel.ojeda.sandonis@gmail.com | ||
| 1148 | W: http://miguelojeda.es/auxdisplay.htm | 987 | W: http://miguelojeda.es/auxdisplay.htm |
| 1149 | W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm | 988 | W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm |
| 1150 | S: Maintained | 989 | S: Maintained |
| @@ -1152,8 +991,7 @@ F: drivers/auxdisplay/ | |||
| 1152 | F: include/linux/cfag12864b.h | 991 | F: include/linux/cfag12864b.h |
| 1153 | 992 | ||
| 1154 | AVR32 ARCHITECTURE | 993 | AVR32 ARCHITECTURE |
| 1155 | P: Haavard Skinnemoen | 994 | M: Haavard Skinnemoen <hskinnemoen@atmel.com> |
| 1156 | M: hskinnemoen@atmel.com | ||
| 1157 | W: http://www.atmel.com/products/AVR32/ | 995 | W: http://www.atmel.com/products/AVR32/ |
| 1158 | W: http://avr32linux.org/ | 996 | W: http://avr32linux.org/ |
| 1159 | W: http://avrfreaks.net/ | 997 | W: http://avrfreaks.net/ |
| @@ -1161,14 +999,12 @@ S: Supported | |||
| 1161 | F: arch/avr32/ | 999 | F: arch/avr32/ |
| 1162 | 1000 | ||
| 1163 | AVR32/AT32AP MACHINE SUPPORT | 1001 | AVR32/AT32AP MACHINE SUPPORT |
| 1164 | P: Haavard Skinnemoen | 1002 | M: Haavard Skinnemoen <hskinnemoen@atmel.com> |
| 1165 | M: hskinnemoen@atmel.com | ||
| 1166 | S: Supported | 1003 | S: Supported |
| 1167 | F: arch/avr32/mach-at32ap/ | 1004 | F: arch/avr32/mach-at32ap/ |
| 1168 | 1005 | ||
| 1169 | AX.25 NETWORK LAYER | 1006 | AX.25 NETWORK LAYER |
| 1170 | P: Ralf Baechle | 1007 | M: Ralf Baechle <ralf@linux-mips.org> |
| 1171 | M: ralf@linux-mips.org | ||
| 1172 | L: linux-hams@vger.kernel.org | 1008 | L: linux-hams@vger.kernel.org |
| 1173 | W: http://www.linux-ax25.org/ | 1009 | W: http://www.linux-ax25.org/ |
| 1174 | S: Maintained | 1010 | S: Maintained |
| @@ -1177,128 +1013,110 @@ F: include/net/ax25.h | |||
| 1177 | F: net/ax25/ | 1013 | F: net/ax25/ |
| 1178 | 1014 | ||
| 1179 | B43 WIRELESS DRIVER | 1015 | B43 WIRELESS DRIVER |
| 1180 | P: Michael Buesch | 1016 | M: Michael Buesch <mb@bu3sch.de> |
| 1181 | M: mb@bu3sch.de | 1017 | M: Stefano Brivio <stefano.brivio@polimi.it> |
| 1182 | P: Stefano Brivio | ||
| 1183 | M: stefano.brivio@polimi.it | ||
| 1184 | L: linux-wireless@vger.kernel.org | 1018 | L: linux-wireless@vger.kernel.org |
| 1185 | W: http://linuxwireless.org/en/users/Drivers/b43 | 1019 | W: http://linuxwireless.org/en/users/Drivers/b43 |
| 1186 | S: Maintained | 1020 | S: Maintained |
| 1187 | F: drivers/net/wireless/b43/ | 1021 | F: drivers/net/wireless/b43/ |
| 1188 | 1022 | ||
| 1189 | B43LEGACY WIRELESS DRIVER | 1023 | B43LEGACY WIRELESS DRIVER |
| 1190 | P: Larry Finger | 1024 | M: Larry Finger <Larry.Finger@lwfinger.net> |
| 1191 | M: Larry.Finger@lwfinger.net | 1025 | M: Stefano Brivio <stefano.brivio@polimi.it> |
| 1192 | P: Stefano Brivio | ||
| 1193 | M: stefano.brivio@polimi.it | ||
| 1194 | L: linux-wireless@vger.kernel.org | 1026 | L: linux-wireless@vger.kernel.org |
| 1195 | W: http://linuxwireless.org/en/users/Drivers/b43 | 1027 | W: http://linuxwireless.org/en/users/Drivers/b43 |
| 1196 | S: Maintained | 1028 | S: Maintained |
| 1197 | F: drivers/net/wireless/b43legacy/ | 1029 | F: drivers/net/wireless/b43legacy/ |
| 1198 | 1030 | ||
| 1199 | BACKLIGHT CLASS/SUBSYSTEM | 1031 | BACKLIGHT CLASS/SUBSYSTEM |
| 1200 | P: Richard Purdie | 1032 | M: Richard Purdie <rpurdie@rpsys.net> |
| 1201 | M: rpurdie@rpsys.net | ||
| 1202 | S: Maintained | 1033 | S: Maintained |
| 1203 | F: drivers/video/backlight/ | 1034 | F: drivers/video/backlight/ |
| 1204 | F: include/linux/backlight.h | 1035 | F: include/linux/backlight.h |
| 1205 | 1036 | ||
| 1206 | BAYCOM/HDLCDRV DRIVERS FOR AX.25 | 1037 | BAYCOM/HDLCDRV DRIVERS FOR AX.25 |
| 1207 | P: Thomas Sailer | 1038 | M: Thomas Sailer <t.sailer@alumni.ethz.ch> |
| 1208 | M: t.sailer@alumni.ethz.ch | ||
| 1209 | L: linux-hams@vger.kernel.org | 1039 | L: linux-hams@vger.kernel.org |
| 1210 | W: http://www.baycom.org/~tom/ham/ham.html | 1040 | W: http://www.baycom.org/~tom/ham/ham.html |
| 1211 | S: Maintained | 1041 | S: Maintained |
| 1212 | F: drivers/net/hamradio/baycom* | 1042 | F: drivers/net/hamradio/baycom* |
| 1213 | 1043 | ||
| 1214 | BEFS FILE SYSTEM | 1044 | BEFS FILE SYSTEM |
| 1215 | P: Sergey S. Kostyliov | 1045 | M: "Sergey S. Kostyliov" <rathamahata@php4.ru> |
| 1216 | M: rathamahata@php4.ru | ||
| 1217 | S: Maintained | 1046 | S: Maintained |
| 1218 | F: Documentation/filesystems/befs.txt | 1047 | F: Documentation/filesystems/befs.txt |
| 1219 | F: fs/befs/ | 1048 | F: fs/befs/ |
| 1220 | 1049 | ||
| 1221 | BFS FILE SYSTEM | 1050 | BFS FILE SYSTEM |
| 1222 | P: Tigran A. Aivazian | 1051 | M: "Tigran A. Aivazian" <tigran@aivazian.fsnet.co.uk> |
| 1223 | M: tigran@aivazian.fsnet.co.uk | ||
| 1224 | S: Maintained | 1052 | S: Maintained |
| 1225 | F: Documentation/filesystems/bfs.txt | 1053 | F: Documentation/filesystems/bfs.txt |
| 1226 | F: fs/bfs/ | 1054 | F: fs/bfs/ |
| 1227 | F: include/linux/bfs_fs.h | 1055 | F: include/linux/bfs_fs.h |
| 1228 | 1056 | ||
| 1229 | BLACKFIN ARCHITECTURE | 1057 | BLACKFIN ARCHITECTURE |
| 1230 | P: Mike Frysinger | 1058 | M: Mike Frysinger <vapier@gentoo.org> |
| 1231 | M: vapier@gentoo.org | ||
| 1232 | L: uclinux-dist-devel@blackfin.uclinux.org | 1059 | L: uclinux-dist-devel@blackfin.uclinux.org |
| 1233 | W: http://blackfin.uclinux.org | 1060 | W: http://blackfin.uclinux.org |
| 1234 | S: Supported | 1061 | S: Supported |
| 1235 | F: arch/blackfin/ | 1062 | F: arch/blackfin/ |
| 1236 | 1063 | ||
| 1237 | BLACKFIN EMAC DRIVER | 1064 | BLACKFIN EMAC DRIVER |
| 1238 | P: Michael Hennerich | 1065 | M: Michael Hennerich <michael.hennerich@analog.com> |
| 1239 | M: michael.hennerich@analog.com | ||
| 1240 | L: uclinux-dist-devel@blackfin.uclinux.org | 1066 | L: uclinux-dist-devel@blackfin.uclinux.org |
| 1241 | W: http://blackfin.uclinux.org | 1067 | W: http://blackfin.uclinux.org |
| 1242 | S: Supported | 1068 | S: Supported |
| 1243 | F: drivers/net/bfin_mac.* | 1069 | F: drivers/net/bfin_mac.* |
| 1244 | 1070 | ||
| 1245 | BLACKFIN RTC DRIVER | 1071 | BLACKFIN RTC DRIVER |
| 1246 | P: Mike Frysinger | 1072 | M: Mike Frysinger <vapier.adi@gmail.com> |
| 1247 | M: vapier.adi@gmail.com | ||
| 1248 | L: uclinux-dist-devel@blackfin.uclinux.org | 1073 | L: uclinux-dist-devel@blackfin.uclinux.org |
| 1249 | W: http://blackfin.uclinux.org | 1074 | W: http://blackfin.uclinux.org |
| 1250 | S: Supported | 1075 | S: Supported |
| 1251 | F: drivers/rtc/rtc-bfin.c | 1076 | F: drivers/rtc/rtc-bfin.c |
| 1252 | 1077 | ||
| 1253 | BLACKFIN SERIAL DRIVER | 1078 | BLACKFIN SERIAL DRIVER |
| 1254 | P: Sonic Zhang | 1079 | M: Sonic Zhang <sonic.zhang@analog.com> |
| 1255 | M: sonic.zhang@analog.com | ||
| 1256 | L: uclinux-dist-devel@blackfin.uclinux.org | 1080 | L: uclinux-dist-devel@blackfin.uclinux.org |
| 1257 | W: http://blackfin.uclinux.org | 1081 | W: http://blackfin.uclinux.org |
| 1258 | S: Supported | 1082 | S: Supported |
| 1259 | F: drivers/serial/bfin_5xx.c | 1083 | F: drivers/serial/bfin_5xx.c |
| 1260 | 1084 | ||
| 1261 | BLACKFIN WATCHDOG DRIVER | 1085 | BLACKFIN WATCHDOG DRIVER |
| 1262 | P: Mike Frysinger | 1086 | M: Mike Frysinger <vapier.adi@gmail.com> |
| 1263 | M: vapier.adi@gmail.com | ||
| 1264 | L: uclinux-dist-devel@blackfin.uclinux.org | 1087 | L: uclinux-dist-devel@blackfin.uclinux.org |
| 1265 | W: http://blackfin.uclinux.org | 1088 | W: http://blackfin.uclinux.org |
| 1266 | S: Supported | 1089 | S: Supported |
| 1267 | F: drivers/watchdog/bfin_wdt.c | 1090 | F: drivers/watchdog/bfin_wdt.c |
| 1268 | 1091 | ||
| 1269 | BLACKFIN I2C TWI DRIVER | 1092 | BLACKFIN I2C TWI DRIVER |
| 1270 | P: Sonic Zhang | 1093 | M: Sonic Zhang <sonic.zhang@analog.com> |
| 1271 | M: sonic.zhang@analog.com | ||
| 1272 | L: uclinux-dist-devel@blackfin.uclinux.org | 1094 | L: uclinux-dist-devel@blackfin.uclinux.org |
| 1273 | W: http://blackfin.uclinux.org/ | 1095 | W: http://blackfin.uclinux.org/ |
| 1274 | S: Supported | 1096 | S: Supported |
| 1275 | F: drivers/i2c/busses/i2c-bfin-twi.c | 1097 | F: drivers/i2c/busses/i2c-bfin-twi.c |
| 1276 | 1098 | ||
| 1277 | BLOCK LAYER | 1099 | BLOCK LAYER |
| 1278 | P: Jens Axboe | 1100 | M: Jens Axboe <axboe@kernel.dk> |
| 1279 | M: axboe@kernel.dk | ||
| 1280 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/axboe/linux-2.6-block.git | 1101 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/axboe/linux-2.6-block.git |
| 1281 | S: Maintained | 1102 | S: Maintained |
| 1282 | F: block/ | 1103 | F: block/ |
| 1283 | 1104 | ||
| 1284 | BLOCK2MTD DRIVER | 1105 | BLOCK2MTD DRIVER |
| 1285 | P: Joern Engel | 1106 | M: Joern Engel <joern@lazybastard.org> |
| 1286 | M: joern@lazybastard.org | ||
| 1287 | L: linux-mtd@lists.infradead.org | 1107 | L: linux-mtd@lists.infradead.org |
| 1288 | S: Maintained | 1108 | S: Maintained |
| 1289 | F: drivers/mtd/devices/block2mtd.c | 1109 | F: drivers/mtd/devices/block2mtd.c |
| 1290 | 1110 | ||
| 1291 | BLUETOOTH DRIVERS | 1111 | BLUETOOTH DRIVERS |
| 1292 | P: Marcel Holtmann | 1112 | M: Marcel Holtmann <marcel@holtmann.org> |
| 1293 | M: marcel@holtmann.org | ||
| 1294 | L: linux-bluetooth@vger.kernel.org | 1113 | L: linux-bluetooth@vger.kernel.org |
| 1295 | W: http://www.bluez.org/ | 1114 | W: http://www.bluez.org/ |
| 1296 | S: Maintained | 1115 | S: Maintained |
| 1297 | F: drivers/bluetooth/ | 1116 | F: drivers/bluetooth/ |
| 1298 | 1117 | ||
| 1299 | BLUETOOTH SUBSYSTEM | 1118 | BLUETOOTH SUBSYSTEM |
| 1300 | P: Marcel Holtmann | 1119 | M: Marcel Holtmann <marcel@holtmann.org> |
| 1301 | M: marcel@holtmann.org | ||
| 1302 | L: linux-bluetooth@vger.kernel.org | 1120 | L: linux-bluetooth@vger.kernel.org |
| 1303 | W: http://www.bluez.org/ | 1121 | W: http://www.bluez.org/ |
| 1304 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/holtmann/bluetooth-2.6.git | 1122 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/holtmann/bluetooth-2.6.git |
| @@ -1307,8 +1125,7 @@ F: net/bluetooth/ | |||
| 1307 | F: include/net/bluetooth/ | 1125 | F: include/net/bluetooth/ |
| 1308 | 1126 | ||
| 1309 | BONDING DRIVER | 1127 | BONDING DRIVER |
| 1310 | P: Jay Vosburgh | 1128 | M: Jay Vosburgh <fubar@us.ibm.com> |
| 1311 | M: fubar@us.ibm.com | ||
| 1312 | L: bonding-devel@lists.sourceforge.net | 1129 | L: bonding-devel@lists.sourceforge.net |
| 1313 | W: http://sourceforge.net/projects/bonding/ | 1130 | W: http://sourceforge.net/projects/bonding/ |
| 1314 | S: Supported | 1131 | S: Supported |
| @@ -1316,54 +1133,46 @@ F: drivers/net/bonding/ | |||
| 1316 | F: include/linux/if_bonding.h | 1133 | F: include/linux/if_bonding.h |
| 1317 | 1134 | ||
| 1318 | BROADCOM B44 10/100 ETHERNET DRIVER | 1135 | BROADCOM B44 10/100 ETHERNET DRIVER |
| 1319 | P: Gary Zambrano | 1136 | M: Gary Zambrano <zambrano@broadcom.com> |
| 1320 | M: zambrano@broadcom.com | ||
| 1321 | L: netdev@vger.kernel.org | 1137 | L: netdev@vger.kernel.org |
| 1322 | S: Supported | 1138 | S: Supported |
| 1323 | F: drivers/net/b44.* | 1139 | F: drivers/net/b44.* |
| 1324 | 1140 | ||
| 1325 | BROADCOM BNX2 GIGABIT ETHERNET DRIVER | 1141 | BROADCOM BNX2 GIGABIT ETHERNET DRIVER |
| 1326 | P: Michael Chan | 1142 | M: Michael Chan <mchan@broadcom.com> |
| 1327 | M: mchan@broadcom.com | ||
| 1328 | L: netdev@vger.kernel.org | 1143 | L: netdev@vger.kernel.org |
| 1329 | S: Supported | 1144 | S: Supported |
| 1330 | F: drivers/net/bnx2.* | 1145 | F: drivers/net/bnx2.* |
| 1331 | F: drivers/net/bnx2_* | 1146 | F: drivers/net/bnx2_* |
| 1332 | 1147 | ||
| 1333 | BROADCOM BNX2X 10 GIGABIT ETHERNET DRIVER | 1148 | BROADCOM BNX2X 10 GIGABIT ETHERNET DRIVER |
| 1334 | P: Eilon Greenstein | 1149 | M: Eilon Greenstein <eilong@broadcom.com> |
| 1335 | M: eilong@broadcom.com | ||
| 1336 | L: netdev@vger.kernel.org | 1150 | L: netdev@vger.kernel.org |
| 1337 | S: Supported | 1151 | S: Supported |
| 1338 | F: drivers/net/bnx2x* | 1152 | F: drivers/net/bnx2x* |
| 1339 | 1153 | ||
| 1340 | BROADCOM TG3 GIGABIT ETHERNET DRIVER | 1154 | BROADCOM TG3 GIGABIT ETHERNET DRIVER |
| 1341 | P: Matt Carlson | 1155 | M: Matt Carlson <mcarlson@broadcom.com> |
| 1342 | M: mcarlson@broadcom.com | 1156 | M: Michael Chan <mchan@broadcom.com> |
| 1343 | P: Michael Chan | ||
| 1344 | M: mchan@broadcom.com | ||
| 1345 | L: netdev@vger.kernel.org | 1157 | L: netdev@vger.kernel.org |
| 1346 | S: Supported | 1158 | S: Supported |
| 1347 | F: drivers/net/tg3.* | 1159 | F: drivers/net/tg3.* |
| 1348 | 1160 | ||
| 1349 | BSG (block layer generic sg v4 driver) | 1161 | BSG (block layer generic sg v4 driver) |
| 1350 | P: FUJITA Tomonori | 1162 | M: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp> |
| 1351 | M: fujita.tomonori@lab.ntt.co.jp | ||
| 1352 | L: linux-scsi@vger.kernel.org | 1163 | L: linux-scsi@vger.kernel.org |
| 1353 | S: Supported | 1164 | S: Supported |
| 1354 | F: block/bsg.c | 1165 | F: block/bsg.c |
| 1355 | F: include/linux/bsg.h | 1166 | F: include/linux/bsg.h |
| 1356 | 1167 | ||
| 1357 | BT8XXGPIO DRIVER | 1168 | BT8XXGPIO DRIVER |
| 1358 | P: Michael Buesch | 1169 | M: Michael Buesch <mb@bu3sch.de> |
| 1359 | M: mb@bu3sch.de | ||
| 1360 | W: http://bu3sch.de/btgpio.php | 1170 | W: http://bu3sch.de/btgpio.php |
| 1361 | S: Maintained | 1171 | S: Maintained |
| 1362 | F: drivers/gpio/bt8xxgpio.c | 1172 | F: drivers/gpio/bt8xxgpio.c |
| 1363 | 1173 | ||
| 1364 | BTRFS FILE SYSTEM | 1174 | BTRFS FILE SYSTEM |
| 1365 | P: Chris Mason | 1175 | M: Chris Mason <chris.mason@oracle.com> |
| 1366 | M: chris.mason@oracle.com | ||
| 1367 | L: linux-btrfs@vger.kernel.org | 1176 | L: linux-btrfs@vger.kernel.org |
| 1368 | W: http://btrfs.wiki.kernel.org/ | 1177 | W: http://btrfs.wiki.kernel.org/ |
| 1369 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mason/btrfs-unstable.git | 1178 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mason/btrfs-unstable.git |
| @@ -1372,8 +1181,7 @@ F: Documentation/filesystems/btrfs.txt | |||
| 1372 | F: fs/btrfs/ | 1181 | F: fs/btrfs/ |
| 1373 | 1182 | ||
| 1374 | BTTV VIDEO4LINUX DRIVER | 1183 | BTTV VIDEO4LINUX DRIVER |
| 1375 | P: Mauro Carvalho Chehab | 1184 | M: Mauro Carvalho Chehab <mchehab@infradead.org> |
| 1376 | M: mchehab@infradead.org | ||
| 1377 | L: linux-media@vger.kernel.org | 1185 | L: linux-media@vger.kernel.org |
| 1378 | W: http://linuxtv.org | 1186 | W: http://linuxtv.org |
| 1379 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 1187 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| @@ -1382,16 +1190,14 @@ F: Documentation/video4linux/bttv/ | |||
| 1382 | F: drivers/media/video/bt8xx/bttv* | 1190 | F: drivers/media/video/bt8xx/bttv* |
| 1383 | 1191 | ||
| 1384 | CACHEFILES: FS-CACHE BACKEND FOR CACHING ON MOUNTED FILESYSTEMS | 1192 | CACHEFILES: FS-CACHE BACKEND FOR CACHING ON MOUNTED FILESYSTEMS |
| 1385 | P: David Howells | 1193 | M: David Howells <dhowells@redhat.com> |
| 1386 | M: dhowells@redhat.com | ||
| 1387 | L: linux-cachefs@redhat.com | 1194 | L: linux-cachefs@redhat.com |
| 1388 | S: Supported | 1195 | S: Supported |
| 1389 | F: Documentation/filesystems/caching/cachefiles.txt | 1196 | F: Documentation/filesystems/caching/cachefiles.txt |
| 1390 | F: fs/cachefiles/ | 1197 | F: fs/cachefiles/ |
| 1391 | 1198 | ||
| 1392 | CAFE CMOS INTEGRATED CAMERA CONTROLLER DRIVER | 1199 | CAFE CMOS INTEGRATED CAMERA CONTROLLER DRIVER |
| 1393 | P: Jonathan Corbet | 1200 | M: Jonathan Corbet <corbet@lwn.net> |
| 1394 | M: corbet@lwn.net | ||
| 1395 | L: linux-media@vger.kernel.org | 1201 | L: linux-media@vger.kernel.org |
| 1396 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 1202 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| 1397 | S: Maintained | 1203 | S: Maintained |
| @@ -1399,10 +1205,8 @@ F: Documentation/video4linux/cafe_ccic | |||
| 1399 | F: drivers/media/video/cafe_ccic* | 1205 | F: drivers/media/video/cafe_ccic* |
| 1400 | 1206 | ||
| 1401 | CALGARY x86-64 IOMMU | 1207 | CALGARY x86-64 IOMMU |
| 1402 | P: Muli Ben-Yehuda | 1208 | M: Muli Ben-Yehuda <muli@il.ibm.com> |
| 1403 | M: muli@il.ibm.com | 1209 | M: "Jon D. Mason" <jdmason@kudzu.us> |
| 1404 | P: Jon D. Mason | ||
| 1405 | M: jdmason@kudzu.us | ||
| 1406 | L: discuss@x86-64.org | 1210 | L: discuss@x86-64.org |
| 1407 | S: Maintained | 1211 | S: Maintained |
| 1408 | F: arch/x86/kernel/pci-calgary_64.c | 1212 | F: arch/x86/kernel/pci-calgary_64.c |
| @@ -1411,10 +1215,8 @@ F: arch/x86/include/asm/calgary.h | |||
| 1411 | F: arch/x86/include/asm/tce.h | 1215 | F: arch/x86/include/asm/tce.h |
| 1412 | 1216 | ||
| 1413 | CAN NETWORK LAYER | 1217 | CAN NETWORK LAYER |
| 1414 | P: Urs Thuermann | 1218 | M: Urs Thuermann <urs.thuermann@volkswagen.de> |
| 1415 | M: urs.thuermann@volkswagen.de | 1219 | M: Oliver Hartkopp <oliver.hartkopp@volkswagen.de> |
| 1416 | P: Oliver Hartkopp | ||
| 1417 | M: oliver.hartkopp@volkswagen.de | ||
| 1418 | L: socketcan-core@lists.berlios.de (subscribers-only) | 1220 | L: socketcan-core@lists.berlios.de (subscribers-only) |
| 1419 | W: http://developer.berlios.de/projects/socketcan/ | 1221 | W: http://developer.berlios.de/projects/socketcan/ |
| 1420 | S: Maintained | 1222 | S: Maintained |
| @@ -1423,15 +1225,13 @@ F: include/linux/can/ | |||
| 1423 | F: include/linux/can.h | 1225 | F: include/linux/can.h |
| 1424 | 1226 | ||
| 1425 | CAN NETWORK DRIVERS | 1227 | CAN NETWORK DRIVERS |
| 1426 | P: Wolfgang Grandegger | 1228 | M: Wolfgang Grandegger <wg@grandegger.com> |
| 1427 | M: wg@grandegger.com | ||
| 1428 | L: socketcan-core@lists.berlios.de (subscribers-only) | 1229 | L: socketcan-core@lists.berlios.de (subscribers-only) |
| 1429 | W: http://developer.berlios.de/projects/socketcan/ | 1230 | W: http://developer.berlios.de/projects/socketcan/ |
| 1430 | S: Maintained | 1231 | S: Maintained |
| 1431 | 1232 | ||
| 1432 | CELL BROADBAND ENGINE ARCHITECTURE | 1233 | CELL BROADBAND ENGINE ARCHITECTURE |
| 1433 | P: Arnd Bergmann | 1234 | M: Arnd Bergmann <arnd@arndb.de> |
| 1434 | M: arnd@arndb.de | ||
| 1435 | L: linuxppc-dev@ozlabs.org | 1235 | L: linuxppc-dev@ozlabs.org |
| 1436 | L: cbe-oss-dev@ozlabs.org | 1236 | L: cbe-oss-dev@ozlabs.org |
| 1437 | W: http://www.ibm.com/developerworks/power/cell/ | 1237 | W: http://www.ibm.com/developerworks/power/cell/ |
| @@ -1442,8 +1242,7 @@ F: arch/powerpc/oprofile/*cell* | |||
| 1442 | F: arch/powerpc/platforms/cell/ | 1242 | F: arch/powerpc/platforms/cell/ |
| 1443 | 1243 | ||
| 1444 | CERTIFIED WIRELESS USB (WUSB) SUBSYSTEM: | 1244 | CERTIFIED WIRELESS USB (WUSB) SUBSYSTEM: |
| 1445 | P: David Vrabel | 1245 | M: David Vrabel <david.vrabel@csr.com> |
| 1446 | M: david.vrabel@csr.com | ||
| 1447 | L: linux-usb@vger.kernel.org | 1246 | L: linux-usb@vger.kernel.org |
| 1448 | S: Supported | 1247 | S: Supported |
| 1449 | F: Documentation/usb/WUSB-Design-overview.txt | 1248 | F: Documentation/usb/WUSB-Design-overview.txt |
| @@ -1452,8 +1251,7 @@ F: drivers/usb/wusbcore/ | |||
| 1452 | F: include/linux/usb/wusb* | 1251 | F: include/linux/usb/wusb* |
| 1453 | 1252 | ||
| 1454 | CFAG12864B LCD DRIVER | 1253 | CFAG12864B LCD DRIVER |
| 1455 | P: Miguel Ojeda Sandonis | 1254 | M: Miguel Ojeda Sandonis <miguel.ojeda.sandonis@gmail.com> |
| 1456 | M: miguel.ojeda.sandonis@gmail.com | ||
| 1457 | W: http://miguelojeda.es/auxdisplay.htm | 1255 | W: http://miguelojeda.es/auxdisplay.htm |
| 1458 | W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm | 1256 | W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm |
| 1459 | S: Maintained | 1257 | S: Maintained |
| @@ -1461,8 +1259,7 @@ F: drivers/auxdisplay/cfag12864b.c | |||
| 1461 | F: include/linux/cfag12864b.h | 1259 | F: include/linux/cfag12864b.h |
| 1462 | 1260 | ||
| 1463 | CFAG12864BFB LCD FRAMEBUFFER DRIVER | 1261 | CFAG12864BFB LCD FRAMEBUFFER DRIVER |
| 1464 | P: Miguel Ojeda Sandonis | 1262 | M: Miguel Ojeda Sandonis <miguel.ojeda.sandonis@gmail.com> |
| 1465 | M: miguel.ojeda.sandonis@gmail.com | ||
| 1466 | W: http://miguelojeda.es/auxdisplay.htm | 1263 | W: http://miguelojeda.es/auxdisplay.htm |
| 1467 | W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm | 1264 | W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm |
| 1468 | S: Maintained | 1265 | S: Maintained |
| @@ -1470,8 +1267,7 @@ F: drivers/auxdisplay/cfag12864bfb.c | |||
| 1470 | F: include/linux/cfag12864b.h | 1267 | F: include/linux/cfag12864b.h |
| 1471 | 1268 | ||
| 1472 | CFG80211 and NL80211 | 1269 | CFG80211 and NL80211 |
| 1473 | P: Johannes Berg | 1270 | M: Johannes Berg <johannes@sipsolutions.net> |
| 1474 | M: johannes@sipsolutions.net | ||
| 1475 | L: linux-wireless@vger.kernel.org | 1271 | L: linux-wireless@vger.kernel.org |
| 1476 | S: Maintained | 1272 | S: Maintained |
| 1477 | F: include/linux/nl80211.h | 1273 | F: include/linux/nl80211.h |
| @@ -1480,66 +1276,47 @@ F: net/wireless/* | |||
| 1480 | X: net/wireless/wext* | 1276 | X: net/wireless/wext* |
| 1481 | 1277 | ||
| 1482 | CHECKPATCH | 1278 | CHECKPATCH |
| 1483 | P: Andy Whitcroft | 1279 | M: Andy Whitcroft <apw@canonical.com> |
| 1484 | M: apw@canonical.com | ||
| 1485 | S: Supported | 1280 | S: Supported |
| 1486 | F: scripts/checkpatch.pl | 1281 | F: scripts/checkpatch.pl |
| 1487 | 1282 | ||
| 1488 | CISCO 10G ETHERNET DRIVER | 1283 | CISCO 10G ETHERNET DRIVER |
| 1489 | P: Scott Feldman | 1284 | M: Scott Feldman <scofeldm@cisco.com> |
| 1490 | M: scofeldm@cisco.com | 1285 | M: Joe Eykholt <jeykholt@cisco.com> |
| 1491 | P: Joe Eykholt | ||
| 1492 | M: jeykholt@cisco.com | ||
| 1493 | S: Supported | 1286 | S: Supported |
| 1494 | F: drivers/net/enic/ | 1287 | F: drivers/net/enic/ |
| 1495 | 1288 | ||
| 1496 | CIRRUS LOGIC EP93XX ETHERNET DRIVER | 1289 | CIRRUS LOGIC EP93XX ETHERNET DRIVER |
| 1497 | P: Lennert Buytenhek | 1290 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 1498 | M: kernel@wantstofly.org | ||
| 1499 | L: netdev@vger.kernel.org | 1291 | L: netdev@vger.kernel.org |
| 1500 | S: Maintained | 1292 | S: Maintained |
| 1501 | F: drivers/net/arm/ep93xx_eth.c | 1293 | F: drivers/net/arm/ep93xx_eth.c |
| 1502 | 1294 | ||
| 1503 | CIRRUS LOGIC EP93XX OHCI USB HOST DRIVER | 1295 | CIRRUS LOGIC EP93XX OHCI USB HOST DRIVER |
| 1504 | P: Lennert Buytenhek | 1296 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 1505 | M: kernel@wantstofly.org | ||
| 1506 | L: linux-usb@vger.kernel.org | 1297 | L: linux-usb@vger.kernel.org |
| 1507 | S: Maintained | 1298 | S: Maintained |
| 1508 | F: drivers/usb/host/ohci-ep93xx.c | 1299 | F: drivers/usb/host/ohci-ep93xx.c |
| 1509 | 1300 | ||
| 1510 | CIRRUS LOGIC CS4270 SOUND DRIVER | 1301 | CIRRUS LOGIC CS4270 SOUND DRIVER |
| 1511 | P: Timur Tabi | 1302 | M: Timur Tabi <timur@freescale.com> |
| 1512 | M: timur@freescale.com | ||
| 1513 | L: alsa-devel@alsa-project.org (moderated for non-subscribers) | 1303 | L: alsa-devel@alsa-project.org (moderated for non-subscribers) |
| 1514 | S: Supported | 1304 | S: Supported |
| 1515 | F: sound/soc/codecs/cs4270* | 1305 | F: sound/soc/codecs/cs4270* |
| 1516 | 1306 | ||
| 1517 | CIRRUS LOGIC CS4280/CS461x SOUNDDRIVER | ||
| 1518 | P: Cirrus Logic Corporation (kernel 2.2 driver) | ||
| 1519 | M: Cirrus Logic Corporation, Thomas Woller <twoller@crystal.cirrus.com> | ||
| 1520 | P: Nils Faerber (port to kernel 2.4) | ||
| 1521 | M: Nils Faerber <nils@kernelconcepts.de> | ||
| 1522 | S: Maintained | ||
| 1523 | F: Documentation/input/cs461x.txt | ||
| 1524 | F: sound/pci/cs46xx/ | ||
| 1525 | |||
| 1526 | CLK API | 1307 | CLK API |
| 1527 | P: Russell King | 1308 | M: Russell King <linux@arm.linux.org.uk> |
| 1528 | M: linux@arm.linux.org.uk | ||
| 1529 | F: include/linux/clk.h | 1309 | F: include/linux/clk.h |
| 1530 | 1310 | ||
| 1531 | CISCO FCOE HBA DRIVER | 1311 | CISCO FCOE HBA DRIVER |
| 1532 | P: Abhijeet Joglekar | 1312 | M: Abhijeet Joglekar <abjoglek@cisco.com> |
| 1533 | M: abjoglek@cisco.com | 1313 | M: Joe Eykholt <jeykholt@cisco.com> |
| 1534 | P: Joe Eykholt | ||
| 1535 | M: jeykholt@cisco.com | ||
| 1536 | L: linux-scsi@vger.kernel.org | 1314 | L: linux-scsi@vger.kernel.org |
| 1537 | S: Supported | 1315 | S: Supported |
| 1538 | F: drivers/scsi/fnic/ | 1316 | F: drivers/scsi/fnic/ |
| 1539 | 1317 | ||
| 1540 | CODA FILE SYSTEM | 1318 | CODA FILE SYSTEM |
| 1541 | P: Jan Harkes | 1319 | M: Jan Harkes <jaharkes@cs.cmu.edu> |
| 1542 | M: jaharkes@cs.cmu.edu | ||
| 1543 | M: coda@cs.cmu.edu | 1320 | M: coda@cs.cmu.edu |
| 1544 | L: codalist@coda.cs.cmu.edu | 1321 | L: codalist@coda.cs.cmu.edu |
| 1545 | W: http://www.coda.cs.cmu.edu/ | 1322 | W: http://www.coda.cs.cmu.edu/ |
| @@ -1549,8 +1326,7 @@ F: fs/coda/ | |||
| 1549 | F: include/linux/coda*.h | 1326 | F: include/linux/coda*.h |
| 1550 | 1327 | ||
| 1551 | COMMON INTERNET FILE SYSTEM (CIFS) | 1328 | COMMON INTERNET FILE SYSTEM (CIFS) |
| 1552 | P: Steve French | 1329 | M: Steve French <sfrench@samba.org> |
| 1553 | M: sfrench@samba.org | ||
| 1554 | L: linux-cifs-client@lists.samba.org | 1330 | L: linux-cifs-client@lists.samba.org |
| 1555 | L: samba-technical@lists.samba.org | 1331 | L: samba-technical@lists.samba.org |
| 1556 | W: http://linux-cifs.samba.org/ | 1332 | W: http://linux-cifs.samba.org/ |
| @@ -1560,63 +1336,57 @@ F: Documentation/filesystems/cifs.txt | |||
| 1560 | F: fs/cifs/ | 1336 | F: fs/cifs/ |
| 1561 | 1337 | ||
| 1562 | COMPACTPCI HOTPLUG CORE | 1338 | COMPACTPCI HOTPLUG CORE |
| 1563 | P: Scott Murray | 1339 | M: Scott Murray <scott@spiteful.org> |
| 1564 | M: scottm@somanetworks.com | ||
| 1565 | M: scott@spiteful.org | ||
| 1566 | L: linux-pci@vger.kernel.org | 1340 | L: linux-pci@vger.kernel.org |
| 1567 | S: Supported | 1341 | S: Maintained |
| 1568 | F: drivers/pci/hotplug/cpci_hotplug* | 1342 | F: drivers/pci/hotplug/cpci_hotplug* |
| 1569 | 1343 | ||
| 1570 | COMPACTPCI HOTPLUG ZIATECH ZT5550 DRIVER | 1344 | COMPACTPCI HOTPLUG ZIATECH ZT5550 DRIVER |
| 1571 | P: Scott Murray | 1345 | M: Scott Murray <scott@spiteful.org> |
| 1572 | M: scottm@somanetworks.com | ||
| 1573 | M: scott@spiteful.org | ||
| 1574 | L: linux-pci@vger.kernel.org | 1346 | L: linux-pci@vger.kernel.org |
| 1575 | S: Supported | 1347 | S: Maintained |
| 1576 | F: drivers/pci/hotplug/cpcihp_zt5550.* | 1348 | F: drivers/pci/hotplug/cpcihp_zt5550.* |
| 1577 | 1349 | ||
| 1578 | COMPACTPCI HOTPLUG GENERIC DRIVER | 1350 | COMPACTPCI HOTPLUG GENERIC DRIVER |
| 1579 | P: Scott Murray | 1351 | M: Scott Murray <scott@spiteful.org> |
| 1580 | M: scottm@somanetworks.com | ||
| 1581 | M: scott@spiteful.org | ||
| 1582 | L: linux-pci@vger.kernel.org | 1352 | L: linux-pci@vger.kernel.org |
| 1583 | S: Supported | 1353 | S: Maintained |
| 1584 | F: drivers/pci/hotplug/cpcihp_generic.c | 1354 | F: drivers/pci/hotplug/cpcihp_generic.c |
| 1585 | 1355 | ||
| 1586 | COMPAL LAPTOP SUPPORT | 1356 | COMPAL LAPTOP SUPPORT |
| 1587 | P: Cezary Jackiewicz | 1357 | M: Cezary Jackiewicz <cezary.jackiewicz@gmail.com> |
| 1588 | M: cezary.jackiewicz@gmail.com | ||
| 1589 | S: Maintained | 1358 | S: Maintained |
| 1590 | F: drivers/platform/x86/compal-laptop.c | 1359 | F: drivers/platform/x86/compal-laptop.c |
| 1591 | 1360 | ||
| 1592 | COMPUTONE INTELLIPORT MULTIPORT CARD | 1361 | COMPUTONE INTELLIPORT MULTIPORT CARD |
| 1593 | P: Michael H. Warfield | 1362 | M: "Michael H. Warfield" <mhw@wittsend.com> |
| 1594 | M: mhw@wittsend.com | ||
| 1595 | W: http://www.wittsend.com/computone.html | 1363 | W: http://www.wittsend.com/computone.html |
| 1596 | S: Maintained | 1364 | S: Maintained |
| 1597 | F: Documentation/serial/computone.txt | 1365 | F: Documentation/serial/computone.txt |
| 1598 | F: drivers/char/ip2/ | 1366 | F: drivers/char/ip2/ |
| 1599 | 1367 | ||
| 1600 | CONEXANT ACCESSRUNNER USB DRIVER | 1368 | CONEXANT ACCESSRUNNER USB DRIVER |
| 1601 | P: Simon Arlott | 1369 | M: Simon Arlott <cxacru@fire.lp0.eu> |
| 1602 | M: cxacru@fire.lp0.eu | ||
| 1603 | L: accessrunner-general@lists.sourceforge.net | 1370 | L: accessrunner-general@lists.sourceforge.net |
| 1604 | W: http://accessrunner.sourceforge.net/ | 1371 | W: http://accessrunner.sourceforge.net/ |
| 1605 | S: Maintained | 1372 | S: Maintained |
| 1606 | F: drivers/usb/atm/cxacru.c | 1373 | F: drivers/usb/atm/cxacru.c |
| 1607 | 1374 | ||
| 1608 | CONFIGFS | 1375 | CONFIGFS |
| 1609 | P: Joel Becker | 1376 | M: Joel Becker <joel.becker@oracle.com> |
| 1610 | M: joel.becker@oracle.com | ||
| 1611 | S: Supported | 1377 | S: Supported |
| 1612 | F: fs/configfs/ | 1378 | F: fs/configfs/ |
| 1613 | F: include/linux/configfs.h | 1379 | F: include/linux/configfs.h |
| 1614 | 1380 | ||
| 1381 | CONNECTOR | ||
| 1382 | M: Evgeniy Polyakov <zbr@ioremap.net> | ||
| 1383 | L: netdev@vger.kernel.org | ||
| 1384 | S: Maintained | ||
| 1385 | F: drivers/connector/ | ||
| 1386 | |||
| 1615 | CONTROL GROUPS (CGROUPS) | 1387 | CONTROL GROUPS (CGROUPS) |
| 1616 | P: Paul Menage | 1388 | M: Paul Menage <menage@google.com> |
| 1617 | M: menage@google.com | 1389 | M: Li Zefan <lizf@cn.fujitsu.com> |
| 1618 | P: Li Zefan | ||
| 1619 | M: lizf@cn.fujitsu.com | ||
| 1620 | L: containers@lists.linux-foundation.org | 1390 | L: containers@lists.linux-foundation.org |
| 1621 | S: Maintained | 1391 | S: Maintained |
| 1622 | F: include/linux/cgroup* | 1392 | F: include/linux/cgroup* |
| @@ -1624,30 +1394,26 @@ F: kernel/cgroup* | |||
| 1624 | F: mm/*cgroup* | 1394 | F: mm/*cgroup* |
| 1625 | 1395 | ||
| 1626 | CORETEMP HARDWARE MONITORING DRIVER | 1396 | CORETEMP HARDWARE MONITORING DRIVER |
| 1627 | P: Rudolf Marek | 1397 | M: Rudolf Marek <r.marek@assembler.cz> |
| 1628 | M: r.marek@assembler.cz | ||
| 1629 | L: lm-sensors@lm-sensors.org | 1398 | L: lm-sensors@lm-sensors.org |
| 1630 | S: Maintained | 1399 | S: Maintained |
| 1631 | F: Documentation/hwmon/coretemp | 1400 | F: Documentation/hwmon/coretemp |
| 1632 | F: drivers/hwmon/coretemp.c | 1401 | F: drivers/hwmon/coretemp.c |
| 1633 | 1402 | ||
| 1634 | COSA/SRP SYNC SERIAL DRIVER | 1403 | COSA/SRP SYNC SERIAL DRIVER |
| 1635 | P: Jan "Yenya" Kasprzak | 1404 | M: Jan "Yenya" Kasprzak <kas@fi.muni.cz> |
| 1636 | M: kas@fi.muni.cz | ||
| 1637 | W: http://www.fi.muni.cz/~kas/cosa/ | 1405 | W: http://www.fi.muni.cz/~kas/cosa/ |
| 1638 | S: Maintained | 1406 | S: Maintained |
| 1639 | F: drivers/net/wan/cosa* | 1407 | F: drivers/net/wan/cosa* |
| 1640 | 1408 | ||
| 1641 | CPMAC ETHERNET DRIVER | 1409 | CPMAC ETHERNET DRIVER |
| 1642 | P: Florian Fainelli | 1410 | M: Florian Fainelli <florian@openwrt.org> |
| 1643 | M: florian@openwrt.org | ||
| 1644 | L: netdev@vger.kernel.org | 1411 | L: netdev@vger.kernel.org |
| 1645 | S: Maintained | 1412 | S: Maintained |
| 1646 | F: drivers/net/cpmac.c | 1413 | F: drivers/net/cpmac.c |
| 1647 | 1414 | ||
| 1648 | CPU FREQUENCY DRIVERS | 1415 | CPU FREQUENCY DRIVERS |
| 1649 | P: Dave Jones | 1416 | M: Dave Jones <davej@redhat.com> |
| 1650 | M: davej@redhat.com | ||
| 1651 | L: cpufreq@vger.kernel.org | 1417 | L: cpufreq@vger.kernel.org |
| 1652 | W: http://www.codemonkey.org.uk/projects/cpufreq/ | 1418 | W: http://www.codemonkey.org.uk/projects/cpufreq/ |
| 1653 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/davej/cpufreq.git | 1419 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/davej/cpufreq.git |
| @@ -1657,15 +1423,13 @@ F: drivers/cpufreq/ | |||
| 1657 | F: include/linux/cpufreq.h | 1423 | F: include/linux/cpufreq.h |
| 1658 | 1424 | ||
| 1659 | CPUID/MSR DRIVER | 1425 | CPUID/MSR DRIVER |
| 1660 | P: H. Peter Anvin | 1426 | M: "H. Peter Anvin" <hpa@zytor.com> |
| 1661 | M: hpa@zytor.com | ||
| 1662 | S: Maintained | 1427 | S: Maintained |
| 1663 | F: arch/x86/kernel/cpuid.c | 1428 | F: arch/x86/kernel/cpuid.c |
| 1664 | F: arch/x86/kernel/msr.c | 1429 | F: arch/x86/kernel/msr.c |
| 1665 | 1430 | ||
| 1666 | CPUSETS | 1431 | CPUSETS |
| 1667 | P: Paul Menage | 1432 | M: Paul Menage <menage@google.com> |
| 1668 | M: menage@google.com | ||
| 1669 | W: http://www.bullopensource.org/cpuset/ | 1433 | W: http://www.bullopensource.org/cpuset/ |
| 1670 | W: http://oss.sgi.com/projects/cpusets/ | 1434 | W: http://oss.sgi.com/projects/cpusets/ |
| 1671 | S: Supported | 1435 | S: Supported |
| @@ -1680,20 +1444,16 @@ F: Documentation/filesystems/cramfs.txt | |||
| 1680 | F: fs/cramfs/ | 1444 | F: fs/cramfs/ |
| 1681 | 1445 | ||
| 1682 | CRIS PORT | 1446 | CRIS PORT |
| 1683 | P: Mikael Starvik | 1447 | M: Mikael Starvik <starvik@axis.com> |
| 1684 | M: starvik@axis.com | 1448 | M: Jesper Nilsson <jesper.nilsson@axis.com> |
| 1685 | P: Jesper Nilsson | ||
| 1686 | M: jesper.nilsson@axis.com | ||
| 1687 | L: linux-cris-kernel@axis.com | 1449 | L: linux-cris-kernel@axis.com |
| 1688 | W: http://developer.axis.com | 1450 | W: http://developer.axis.com |
| 1689 | S: Maintained | 1451 | S: Maintained |
| 1690 | F: arch/cris/ | 1452 | F: arch/cris/ |
| 1691 | 1453 | ||
| 1692 | CRYPTO API | 1454 | CRYPTO API |
| 1693 | P: Herbert Xu | 1455 | M: Herbert Xu <herbert@gondor.apana.org.au> |
| 1694 | M: herbert@gondor.apana.org.au | 1456 | M: "David S. Miller" <davem@davemloft.net> |
| 1695 | P: David S. Miller | ||
| 1696 | M: davem@davemloft.net | ||
| 1697 | L: linux-crypto@vger.kernel.org | 1457 | L: linux-crypto@vger.kernel.org |
| 1698 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6.git | 1458 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6.git |
| 1699 | S: Maintained | 1459 | S: Maintained |
| @@ -1704,58 +1464,50 @@ F: drivers/crypto/ | |||
| 1704 | F: include/crypto/ | 1464 | F: include/crypto/ |
| 1705 | 1465 | ||
| 1706 | CRYPTOGRAPHIC RANDOM NUMBER GENERATOR | 1466 | CRYPTOGRAPHIC RANDOM NUMBER GENERATOR |
| 1707 | P: Neil Horman | 1467 | M: Neil Horman <nhorman@tuxdriver.com> |
| 1708 | M: nhorman@tuxdriver.com | ||
| 1709 | L: linux-crypto@vger.kernel.org | 1468 | L: linux-crypto@vger.kernel.org |
| 1710 | S: Maintained | 1469 | S: Maintained |
| 1711 | 1470 | ||
| 1712 | CS5535 Audio ALSA driver | 1471 | CS5535 Audio ALSA driver |
| 1713 | P: Jaya Kumar | 1472 | M: Jaya Kumar <jayakumar.alsa@gmail.com> |
| 1714 | M: jayakumar.alsa@gmail.com | ||
| 1715 | S: Maintained | 1473 | S: Maintained |
| 1716 | F: sound/pci/cs5535audio/ | 1474 | F: sound/pci/cs5535audio/ |
| 1717 | 1475 | ||
| 1718 | CX18 VIDEO4LINUX DRIVER | 1476 | CX18 VIDEO4LINUX DRIVER |
| 1719 | P: Hans Verkuil | 1477 | M: Hans Verkuil <hverkuil@xs4all.nl> |
| 1720 | M: hverkuil@xs4all.nl | 1478 | M: Andy Walls <awalls@radix.net> |
| 1721 | P: Andy Walls | ||
| 1722 | M: awalls@radix.net | ||
| 1723 | L: ivtv-devel@ivtvdriver.org | 1479 | L: ivtv-devel@ivtvdriver.org |
| 1724 | L: ivtv-users@ivtvdriver.org | ||
| 1725 | L: linux-media@vger.kernel.org | 1480 | L: linux-media@vger.kernel.org |
| 1726 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 1481 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| 1727 | W: http://linuxtv.org | 1482 | W: http://linuxtv.org |
| 1483 | W: http://www.ivtvdriver.org/index.php/Cx18 | ||
| 1728 | S: Maintained | 1484 | S: Maintained |
| 1729 | F: Documentation/video4linux/cx18.txt | 1485 | F: Documentation/video4linux/cx18.txt |
| 1730 | F: drivers/media/video/cx18/ | 1486 | F: drivers/media/video/cx18/ |
| 1731 | 1487 | ||
| 1732 | CXGB3 ETHERNET DRIVER (CXGB3) | 1488 | CXGB3 ETHERNET DRIVER (CXGB3) |
| 1733 | P: Divy Le Ray | 1489 | M: Divy Le Ray <divy@chelsio.com> |
| 1734 | M: divy@chelsio.com | ||
| 1735 | L: netdev@vger.kernel.org | 1490 | L: netdev@vger.kernel.org |
| 1736 | W: http://www.chelsio.com | 1491 | W: http://www.chelsio.com |
| 1737 | S: Supported | 1492 | S: Supported |
| 1738 | F: drivers/net/cxgb3/ | 1493 | F: drivers/net/cxgb3/ |
| 1739 | 1494 | ||
| 1740 | CXGB3 IWARP RNIC DRIVER (IW_CXGB3) | 1495 | CXGB3 IWARP RNIC DRIVER (IW_CXGB3) |
| 1741 | P: Steve Wise | 1496 | M: Steve Wise <swise@chelsio.com> |
| 1742 | M: swise@chelsio.com | ||
| 1743 | L: general@lists.openfabrics.org | 1497 | L: general@lists.openfabrics.org |
| 1744 | W: http://www.openfabrics.org | 1498 | W: http://www.openfabrics.org |
| 1745 | S: Supported | 1499 | S: Supported |
| 1746 | F: drivers/infiniband/hw/cxgb3/ | 1500 | F: drivers/infiniband/hw/cxgb3/ |
| 1747 | 1501 | ||
| 1748 | CYBERPRO FB DRIVER | 1502 | CYBERPRO FB DRIVER |
| 1749 | P: Russell King | 1503 | M: Russell King <linux@arm.linux.org.uk> |
| 1750 | M: linux@arm.linux.org.uk | ||
| 1751 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 1504 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 1752 | W: http://www.arm.linux.org.uk/ | 1505 | W: http://www.arm.linux.org.uk/ |
| 1753 | S: Maintained | 1506 | S: Maintained |
| 1754 | F: drivers/video/cyber2000fb.* | 1507 | F: drivers/video/cyber2000fb.* |
| 1755 | 1508 | ||
| 1756 | CYCLADES 2X SYNC CARD DRIVER | 1509 | CYCLADES 2X SYNC CARD DRIVER |
| 1757 | P: Arnaldo Carvalho de Melo | 1510 | M: Arnaldo Carvalho de Melo <acme@ghostprotocols.net> |
| 1758 | M: acme@ghostprotocols.net | ||
| 1759 | W: http://oops.ghostprotocols.net:81/blog | 1511 | W: http://oops.ghostprotocols.net:81/blog |
| 1760 | S: Maintained | 1512 | S: Maintained |
| 1761 | F: drivers/net/wan/cycx* | 1513 | F: drivers/net/wan/cycx* |
| @@ -1772,8 +1524,7 @@ S: Orphan | |||
| 1772 | F: drivers/net/wan/pc300* | 1524 | F: drivers/net/wan/pc300* |
| 1773 | 1525 | ||
| 1774 | DAMA SLAVE for AX.25 | 1526 | DAMA SLAVE for AX.25 |
| 1775 | P: Joerg Reuter | 1527 | M: Joerg Reuter <jreuter@yaina.de> |
| 1776 | M: jreuter@yaina.de | ||
| 1777 | W: http://yaina.de/jreuter/ | 1528 | W: http://yaina.de/jreuter/ |
| 1778 | W: http://www.qsl.net/dl1bke/ | 1529 | W: http://www.qsl.net/dl1bke/ |
| 1779 | L: linux-hams@vger.kernel.org | 1530 | L: linux-hams@vger.kernel.org |
| @@ -1787,29 +1538,23 @@ F: net/ax25/ax25_timer.c | |||
| 1787 | F: net/ax25/sysctl_net_ax25.c | 1538 | F: net/ax25/sysctl_net_ax25.c |
| 1788 | 1539 | ||
| 1789 | DAVICOM FAST ETHERNET (DMFE) NETWORK DRIVER | 1540 | DAVICOM FAST ETHERNET (DMFE) NETWORK DRIVER |
| 1790 | P: Tobias Ringstrom | 1541 | M: Tobias Ringstrom <tori@unhappy.mine.nu> |
| 1791 | M: tori@unhappy.mine.nu | ||
| 1792 | L: netdev@vger.kernel.org | 1542 | L: netdev@vger.kernel.org |
| 1793 | S: Maintained | 1543 | S: Maintained |
| 1794 | F: Documentation/networking/dmfe.txt | 1544 | F: Documentation/networking/dmfe.txt |
| 1795 | F: drivers/net/tulip/dmfe.c | 1545 | F: drivers/net/tulip/dmfe.c |
| 1796 | 1546 | ||
| 1797 | DC390/AM53C974 SCSI driver | 1547 | DC390/AM53C974 SCSI driver |
| 1798 | P: Kurt Garloff | 1548 | M: Kurt Garloff <garloff@suse.de> |
| 1799 | M: garloff@suse.de | ||
| 1800 | W: http://www.garloff.de/kurt/linux/dc390/ | 1549 | W: http://www.garloff.de/kurt/linux/dc390/ |
| 1801 | P: Guennadi Liakhovetski | 1550 | M: Guennadi Liakhovetski <g.liakhovetski@gmx.de> |
| 1802 | M: g.liakhovetski@gmx.de | ||
| 1803 | S: Maintained | 1551 | S: Maintained |
| 1804 | F: drivers/scsi/tmscsim.* | 1552 | F: drivers/scsi/tmscsim.* |
| 1805 | 1553 | ||
| 1806 | DC395x SCSI driver | 1554 | DC395x SCSI driver |
| 1807 | P: Oliver Neukum | 1555 | M: Oliver Neukum <oliver@neukum.name> |
| 1808 | M: oliver@neukum.name | 1556 | M: Ali Akcaagac <aliakc@web.de> |
| 1809 | P: Ali Akcaagac | 1557 | M: Jamie Lenehan <lenehan@twibble.org> |
| 1810 | M: aliakc@web.de | ||
| 1811 | P: Jamie Lenehan | ||
| 1812 | M: lenehan@twibble.org | ||
| 1813 | W: http://twibble.org/dist/dc395x/ | 1558 | W: http://twibble.org/dist/dc395x/ |
| 1814 | L: dc395x@twibble.org | 1559 | L: dc395x@twibble.org |
| 1815 | L: http://lists.twibble.org/mailman/listinfo/dc395x/ | 1560 | L: http://lists.twibble.org/mailman/listinfo/dc395x/ |
| @@ -1818,8 +1563,7 @@ F: Documentation/scsi/dc395x.txt | |||
| 1818 | F: drivers/scsi/dc395x.* | 1563 | F: drivers/scsi/dc395x.* |
| 1819 | 1564 | ||
| 1820 | DCCP PROTOCOL | 1565 | DCCP PROTOCOL |
| 1821 | P: Arnaldo Carvalho de Melo | 1566 | M: Arnaldo Carvalho de Melo <acme@ghostprotocols.net> |
| 1822 | M: acme@ghostprotocols.net | ||
| 1823 | L: dccp@vger.kernel.org | 1567 | L: dccp@vger.kernel.org |
| 1824 | W: http://linux-net.osdl.org/index.php/DCCP | 1568 | W: http://linux-net.osdl.org/index.php/DCCP |
| 1825 | S: Maintained | 1569 | S: Maintained |
| @@ -1828,8 +1572,7 @@ F: include/linux/tfrc.h | |||
| 1828 | F: net/dccp/ | 1572 | F: net/dccp/ |
| 1829 | 1573 | ||
| 1830 | DECnet NETWORK LAYER | 1574 | DECnet NETWORK LAYER |
| 1831 | P: Christine Caulfield | 1575 | M: Christine Caulfield <christine.caulfield@googlemail.com> |
| 1832 | M: christine.caulfield@googlemail.com | ||
| 1833 | W: http://linux-decnet.sourceforge.net | 1576 | W: http://linux-decnet.sourceforge.net |
| 1834 | L: linux-decnet-user@lists.sourceforge.net | 1577 | L: linux-decnet-user@lists.sourceforge.net |
| 1835 | S: Maintained | 1578 | S: Maintained |
| @@ -1837,40 +1580,34 @@ F: Documentation/networking/decnet.txt | |||
| 1837 | F: net/decnet/ | 1580 | F: net/decnet/ |
| 1838 | 1581 | ||
| 1839 | DEFXX FDDI NETWORK DRIVER | 1582 | DEFXX FDDI NETWORK DRIVER |
| 1840 | P: Maciej W. Rozycki | 1583 | M: "Maciej W. Rozycki" <macro@linux-mips.org> |
| 1841 | M: macro@linux-mips.org | ||
| 1842 | S: Maintained | 1584 | S: Maintained |
| 1843 | F: drivers/net/defxx.* | 1585 | F: drivers/net/defxx.* |
| 1844 | 1586 | ||
| 1845 | DELL LAPTOP DRIVER | 1587 | DELL LAPTOP DRIVER |
| 1846 | P: Matthew Garrett | 1588 | M: Matthew Garrett <mjg59@srcf.ucam.org> |
| 1847 | M: mjg59@srcf.ucam.org | ||
| 1848 | S: Maintained | 1589 | S: Maintained |
| 1849 | F: drivers/platform/x86/dell-laptop.c | 1590 | F: drivers/platform/x86/dell-laptop.c |
| 1850 | 1591 | ||
| 1851 | DELL LAPTOP SMM DRIVER | 1592 | DELL LAPTOP SMM DRIVER |
| 1852 | P: Massimo Dal Zotto | 1593 | M: Massimo Dal Zotto <dz@debian.org> |
| 1853 | M: dz@debian.org | ||
| 1854 | W: http://www.debian.org/~dz/i8k/ | 1594 | W: http://www.debian.org/~dz/i8k/ |
| 1855 | S: Maintained | 1595 | S: Maintained |
| 1856 | F: drivers/char/i8k.c | 1596 | F: drivers/char/i8k.c |
| 1857 | F: include/linux/i8k.h | 1597 | F: include/linux/i8k.h |
| 1858 | 1598 | ||
| 1859 | DELL SYSTEMS MANAGEMENT BASE DRIVER (dcdbas) | 1599 | DELL SYSTEMS MANAGEMENT BASE DRIVER (dcdbas) |
| 1860 | P: Doug Warzecha | 1600 | M: Doug Warzecha <Douglas_Warzecha@dell.com> |
| 1861 | M: Douglas_Warzecha@dell.com | ||
| 1862 | S: Maintained | 1601 | S: Maintained |
| 1863 | F: Documentation/dcdbas.txt | 1602 | F: Documentation/dcdbas.txt |
| 1864 | F: drivers/firmware/dcdbas.* | 1603 | F: drivers/firmware/dcdbas.* |
| 1865 | 1604 | ||
| 1866 | DELL WMI EXTRAS DRIVER | 1605 | DELL WMI EXTRAS DRIVER |
| 1867 | P: Matthew Garrett | 1606 | M: Matthew Garrett <mjg59@srcf.ucam.org> |
| 1868 | M: mjg59@srcf.ucam.org | ||
| 1869 | S: Maintained | 1607 | S: Maintained |
| 1870 | 1608 | ||
| 1871 | DEVICE NUMBER REGISTRY | 1609 | DEVICE NUMBER REGISTRY |
| 1872 | P: Torben Mathiasen | 1610 | M: Torben Mathiasen <device@lanana.org> |
| 1873 | M: device@lanana.org | ||
| 1874 | W: http://lanana.org/docs/device-list/index.html | 1611 | W: http://lanana.org/docs/device-list/index.html |
| 1875 | S: Maintained | 1612 | S: Maintained |
| 1876 | 1613 | ||
| @@ -1885,8 +1622,7 @@ F: include/linux/device-mapper.h | |||
| 1885 | F: include/linux/dm-*.h | 1622 | F: include/linux/dm-*.h |
| 1886 | 1623 | ||
| 1887 | DIGI INTL. EPCA DRIVER | 1624 | DIGI INTL. EPCA DRIVER |
| 1888 | P: Digi International, Inc | 1625 | M: "Digi International, Inc" <Eng.Linux@digi.com> |
| 1889 | M: Eng.Linux@digi.com | ||
| 1890 | L: Eng.Linux@digi.com | 1626 | L: Eng.Linux@digi.com |
| 1891 | W: http://www.digi.com | 1627 | W: http://www.digi.com |
| 1892 | S: Orphan | 1628 | S: Orphan |
| @@ -1895,34 +1631,29 @@ F: drivers/char/epca* | |||
| 1895 | F: drivers/char/digi* | 1631 | F: drivers/char/digi* |
| 1896 | 1632 | ||
| 1897 | DIRECTORY NOTIFICATION (DNOTIFY) | 1633 | DIRECTORY NOTIFICATION (DNOTIFY) |
| 1898 | P: Eric Paris | 1634 | M: Eric Paris <eparis@parisplace.org> |
| 1899 | M: eparis@parisplace.org | ||
| 1900 | S: Maintained | 1635 | S: Maintained |
| 1901 | F: Documentation/filesystems/dnotify.txt | 1636 | F: Documentation/filesystems/dnotify.txt |
| 1902 | F: fs/notify/dnotify/ | 1637 | F: fs/notify/dnotify/ |
| 1903 | F: include/linux/dnotify.h | 1638 | F: include/linux/dnotify.h |
| 1904 | 1639 | ||
| 1905 | DISK GEOMETRY AND PARTITION HANDLING | 1640 | DISK GEOMETRY AND PARTITION HANDLING |
| 1906 | P: Andries Brouwer | 1641 | M: Andries Brouwer <aeb@cwi.nl> |
| 1907 | M: aeb@cwi.nl | ||
| 1908 | W: http://www.win.tue.nl/~aeb/linux/Large-Disk.html | 1642 | W: http://www.win.tue.nl/~aeb/linux/Large-Disk.html |
| 1909 | W: http://www.win.tue.nl/~aeb/linux/zip/zip-1.html | 1643 | W: http://www.win.tue.nl/~aeb/linux/zip/zip-1.html |
| 1910 | W: http://www.win.tue.nl/~aeb/partitions/partition_types-1.html | 1644 | W: http://www.win.tue.nl/~aeb/partitions/partition_types-1.html |
| 1911 | S: Maintained | 1645 | S: Maintained |
| 1912 | 1646 | ||
| 1913 | DISKQUOTA | 1647 | DISKQUOTA |
| 1914 | P: Jan Kara | 1648 | M: Jan Kara <jack@suse.cz> |
| 1915 | M: jack@suse.cz | ||
| 1916 | S: Maintained | 1649 | S: Maintained |
| 1917 | F: Documentation/filesystems/quota.txt | 1650 | F: Documentation/filesystems/quota.txt |
| 1918 | F: fs/quota/ | 1651 | F: fs/quota/ |
| 1919 | F: include/linux/quota*.h | 1652 | F: include/linux/quota*.h |
| 1920 | 1653 | ||
| 1921 | DISTRIBUTED LOCK MANAGER (DLM) | 1654 | DISTRIBUTED LOCK MANAGER (DLM) |
| 1922 | P: Christine Caulfield | 1655 | M: Christine Caulfield <ccaulfie@redhat.com> |
| 1923 | M: ccaulfie@redhat.com | 1656 | M: David Teigland <teigland@redhat.com> |
| 1924 | P: David Teigland | ||
| 1925 | M: teigland@redhat.com | ||
| 1926 | L: cluster-devel@redhat.com | 1657 | L: cluster-devel@redhat.com |
| 1927 | W: http://sources.redhat.com/cluster/ | 1658 | W: http://sources.redhat.com/cluster/ |
| 1928 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/teigland/dlm.git | 1659 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/teigland/dlm.git |
| @@ -1930,52 +1661,44 @@ S: Supported | |||
| 1930 | F: fs/dlm/ | 1661 | F: fs/dlm/ |
| 1931 | 1662 | ||
| 1932 | DMA GENERIC OFFLOAD ENGINE SUBSYSTEM | 1663 | DMA GENERIC OFFLOAD ENGINE SUBSYSTEM |
| 1933 | P: Maciej Sosnowski | 1664 | M: Maciej Sosnowski <maciej.sosnowski@intel.com> |
| 1934 | M: maciej.sosnowski@intel.com | 1665 | M: Dan Williams <dan.j.williams@intel.com> |
| 1935 | P: Dan Williams | ||
| 1936 | M: dan.j.williams@intel.com | ||
| 1937 | S: Supported | 1666 | S: Supported |
| 1938 | F: drivers/dma/ | 1667 | F: drivers/dma/ |
| 1939 | F: include/linux/dma* | 1668 | F: include/linux/dma* |
| 1940 | 1669 | ||
| 1941 | DME1737 HARDWARE MONITOR DRIVER | 1670 | DME1737 HARDWARE MONITOR DRIVER |
| 1942 | P: Juerg Haefliger | 1671 | M: Juerg Haefliger <juergh@gmail.com> |
| 1943 | M: juergh@gmail.com | ||
| 1944 | L: lm-sensors@lm-sensors.org | 1672 | L: lm-sensors@lm-sensors.org |
| 1945 | S: Maintained | 1673 | S: Maintained |
| 1946 | F: Documentation/hwmon/dme1737 | 1674 | F: Documentation/hwmon/dme1737 |
| 1947 | F: drivers/hwmon/dme1737.c | 1675 | F: drivers/hwmon/dme1737.c |
| 1948 | 1676 | ||
| 1949 | DOCBOOK FOR DOCUMENTATION | 1677 | DOCBOOK FOR DOCUMENTATION |
| 1950 | P: Randy Dunlap | 1678 | M: Randy Dunlap <rdunlap@xenotime.net> |
| 1951 | M: rdunlap@xenotime.net | ||
| 1952 | S: Maintained | 1679 | S: Maintained |
| 1953 | 1680 | ||
| 1954 | DOCKING STATION DRIVER | 1681 | DOCKING STATION DRIVER |
| 1955 | P: Shaohua Li | 1682 | M: Shaohua Li <shaohua.li@intel.com> |
| 1956 | M: shaohua.li@intel.com | ||
| 1957 | L: linux-acpi@vger.kernel.org | 1683 | L: linux-acpi@vger.kernel.org |
| 1958 | S: Supported | 1684 | S: Supported |
| 1959 | F: drivers/acpi/dock.c | 1685 | F: drivers/acpi/dock.c |
| 1960 | 1686 | ||
| 1961 | DOCUMENTATION | 1687 | DOCUMENTATION |
| 1962 | P: Randy Dunlap | 1688 | M: Randy Dunlap <rdunlap@xenotime.net> |
| 1963 | M: rdunlap@xenotime.net | ||
| 1964 | L: linux-doc@vger.kernel.org | 1689 | L: linux-doc@vger.kernel.org |
| 1965 | S: Maintained | 1690 | S: Maintained |
| 1966 | F: Documentation/ | 1691 | F: Documentation/ |
| 1967 | 1692 | ||
| 1968 | DOUBLETALK DRIVER | 1693 | DOUBLETALK DRIVER |
| 1969 | P: James R. Van Zandt | 1694 | M: "James R. Van Zandt" <jrv@vanzandt.mv.com> |
| 1970 | M: jrv@vanzandt.mv.com | ||
| 1971 | L: blinux-list@redhat.com | 1695 | L: blinux-list@redhat.com |
| 1972 | S: Maintained | 1696 | S: Maintained |
| 1973 | F: drivers/char/dtlk.c | 1697 | F: drivers/char/dtlk.c |
| 1974 | F: include/linux/dtlk.h | 1698 | F: include/linux/dtlk.h |
| 1975 | 1699 | ||
| 1976 | DPT_I2O SCSI RAID DRIVER | 1700 | DPT_I2O SCSI RAID DRIVER |
| 1977 | P: Adaptec OEM Raid Solutions | 1701 | M: Adaptec OEM Raid Solutions <aacraid@adaptec.com> |
| 1978 | M: aacraid@adaptec.com | ||
| 1979 | L: linux-scsi@vger.kernel.org | 1702 | L: linux-scsi@vger.kernel.org |
| 1980 | W: http://www.adaptec.com/ | 1703 | W: http://www.adaptec.com/ |
| 1981 | S: Maintained | 1704 | S: Maintained |
| @@ -1983,8 +1706,7 @@ F: drivers/scsi/dpt* | |||
| 1983 | F: drivers/scsi/dpt/ | 1706 | F: drivers/scsi/dpt/ |
| 1984 | 1707 | ||
| 1985 | DRIVER CORE, KOBJECTS, AND SYSFS | 1708 | DRIVER CORE, KOBJECTS, AND SYSFS |
| 1986 | P: Greg Kroah-Hartman | 1709 | M: Greg Kroah-Hartman <gregkh@suse.de> |
| 1987 | M: gregkh@suse.de | ||
| 1988 | T: quilt kernel.org/pub/linux/kernel/people/gregkh/gregkh-2.6/ | 1710 | T: quilt kernel.org/pub/linux/kernel/people/gregkh/gregkh-2.6/ |
| 1989 | S: Supported | 1711 | S: Supported |
| 1990 | F: Documentation/kobject.txt | 1712 | F: Documentation/kobject.txt |
| @@ -1994,52 +1716,45 @@ F: include/linux/kobj* | |||
| 1994 | F: lib/kobj* | 1716 | F: lib/kobj* |
| 1995 | 1717 | ||
| 1996 | DRM DRIVERS | 1718 | DRM DRIVERS |
| 1997 | P: David Airlie | 1719 | M: David Airlie <airlied@linux.ie> |
| 1998 | M: airlied@linux.ie | ||
| 1999 | L: dri-devel@lists.sourceforge.net | 1720 | L: dri-devel@lists.sourceforge.net |
| 2000 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/airlied/drm-2.6.git | 1721 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/airlied/drm-2.6.git |
| 2001 | S: Maintained | 1722 | S: Maintained |
| 2002 | F: drivers/gpu/drm/ | 1723 | F: drivers/gpu/drm/ |
| 2003 | 1724 | ||
| 2004 | DSCC4 DRIVER | 1725 | DSCC4 DRIVER |
| 2005 | P: Francois Romieu | 1726 | M: Francois Romieu <romieu@fr.zoreil.com> |
| 2006 | M: romieu@fr.zoreil.com | ||
| 2007 | L: netdev@vger.kernel.org | 1727 | L: netdev@vger.kernel.org |
| 2008 | S: Maintained | 1728 | S: Maintained |
| 2009 | F: drivers/net/wan/dscc4.c | 1729 | F: drivers/net/wan/dscc4.c |
| 2010 | 1730 | ||
| 2011 | DZ DECSTATION DZ11 SERIAL DRIVER | 1731 | DZ DECSTATION DZ11 SERIAL DRIVER |
| 2012 | P: Maciej W. Rozycki | 1732 | M: "Maciej W. Rozycki" <macro@linux-mips.org> |
| 2013 | M: macro@linux-mips.org | ||
| 2014 | S: Maintained | 1733 | S: Maintained |
| 2015 | F: drivers/serial/dz.* | 1734 | F: drivers/serial/dz.* |
| 2016 | 1735 | ||
| 2017 | EATA-DMA SCSI DRIVER | 1736 | EATA-DMA SCSI DRIVER |
| 2018 | P: Michael Neuffer | 1737 | M: Michael Neuffer <mike@i-Connect.Net> |
| 2019 | M: mike@i-Connect.Net | ||
| 2020 | L: linux-eata@i-connect.net | 1738 | L: linux-eata@i-connect.net |
| 2021 | L: linux-scsi@vger.kernel.org | 1739 | L: linux-scsi@vger.kernel.org |
| 2022 | S: Maintained | 1740 | S: Maintained |
| 2023 | F: drivers/scsi/eata* | 1741 | F: drivers/scsi/eata* |
| 2024 | 1742 | ||
| 2025 | EATA ISA/EISA/PCI SCSI DRIVER | 1743 | EATA ISA/EISA/PCI SCSI DRIVER |
| 2026 | P: Dario Ballabio | 1744 | M: Dario Ballabio <ballabio_dario@emc.com> |
| 2027 | M: ballabio_dario@emc.com | ||
| 2028 | L: linux-scsi@vger.kernel.org | 1745 | L: linux-scsi@vger.kernel.org |
| 2029 | S: Maintained | 1746 | S: Maintained |
| 2030 | F: drivers/scsi/eata.c | 1747 | F: drivers/scsi/eata.c |
| 2031 | 1748 | ||
| 2032 | EATA-PIO SCSI DRIVER | 1749 | EATA-PIO SCSI DRIVER |
| 2033 | P: Michael Neuffer | 1750 | M: Michael Neuffer <mike@i-Connect.Net> |
| 2034 | M: mike@i-Connect.Net | ||
| 2035 | L: linux-eata@i-connect.net | 1751 | L: linux-eata@i-connect.net |
| 2036 | L: linux-scsi@vger.kernel.org | 1752 | L: linux-scsi@vger.kernel.org |
| 2037 | S: Maintained | 1753 | S: Maintained |
| 2038 | F: drivers/scsi/eata_pio.* | 1754 | F: drivers/scsi/eata_pio.* |
| 2039 | 1755 | ||
| 2040 | EBTABLES | 1756 | EBTABLES |
| 2041 | P: Bart De Schuymer | 1757 | M: Bart De Schuymer <bart.de.schuymer@pandora.be> |
| 2042 | M: bart.de.schuymer@pandora.be | ||
| 2043 | L: ebtables-user@lists.sourceforge.net | 1758 | L: ebtables-user@lists.sourceforge.net |
| 2044 | L: ebtables-devel@lists.sourceforge.net | 1759 | L: ebtables-devel@lists.sourceforge.net |
| 2045 | W: http://ebtables.sourceforge.net/ | 1760 | W: http://ebtables.sourceforge.net/ |
| @@ -2048,10 +1763,8 @@ F: include/linux/netfilter_bridge/ebt_*.h | |||
| 2048 | F: net/bridge/netfilter/ebt*.c | 1763 | F: net/bridge/netfilter/ebt*.c |
| 2049 | 1764 | ||
| 2050 | ECRYPT FILE SYSTEM | 1765 | ECRYPT FILE SYSTEM |
| 2051 | P: Tyler Hicks | 1766 | M: Tyler Hicks <tyhicks@linux.vnet.ibm.com> |
| 2052 | M: tyhicks@linux.vnet.ibm.com | 1767 | M: Dustin Kirkland <kirkland@canonical.com> |
| 2053 | P: Dustin Kirkland | ||
| 2054 | M: kirkland@canonical.com | ||
| 2055 | L: ecryptfs-devel@lists.launchpad.net | 1768 | L: ecryptfs-devel@lists.launchpad.net |
| 2056 | W: https://launchpad.net/ecryptfs | 1769 | W: https://launchpad.net/ecryptfs |
| 2057 | S: Supported | 1770 | S: Supported |
| @@ -2059,8 +1772,7 @@ F: Documentation/filesystems/ecryptfs.txt | |||
| 2059 | F: fs/ecryptfs/ | 1772 | F: fs/ecryptfs/ |
| 2060 | 1773 | ||
| 2061 | EDAC-CORE | 1774 | EDAC-CORE |
| 2062 | P: Doug Thompson | 1775 | M: Doug Thompson <dougthompson@xmission.com> |
| 2063 | M: dougthompson@xmission.com | ||
| 2064 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) | 1776 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 2065 | W: bluesmoke.sourceforge.net | 1777 | W: bluesmoke.sourceforge.net |
| 2066 | S: Supported | 1778 | S: Supported |
| @@ -2069,94 +1781,80 @@ F: drivers/edac/edac_* | |||
| 2069 | F: include/linux/edac.h | 1781 | F: include/linux/edac.h |
| 2070 | 1782 | ||
| 2071 | EDAC-AMD64 | 1783 | EDAC-AMD64 |
| 2072 | P: Doug Thompson | 1784 | M: Doug Thompson <dougthompson@xmission.com> |
| 2073 | M: dougthompson@xmission.com | 1785 | M: Borislav Petkov <borislav.petkov@amd.com> |
| 2074 | P: Borislav Petkov | ||
| 2075 | M: borislav.petkov@amd.com | ||
| 2076 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) | 1786 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 2077 | W: bluesmoke.sourceforge.net | 1787 | W: bluesmoke.sourceforge.net |
| 2078 | S: Supported | 1788 | S: Supported |
| 2079 | F: drivers/edac/amd64_edac* | 1789 | F: drivers/edac/amd64_edac* |
| 2080 | 1790 | ||
| 2081 | EDAC-E752X | 1791 | EDAC-E752X |
| 2082 | P: Mark Gross | 1792 | M: Mark Gross <mark.gross@intel.com> |
| 2083 | M: mark.gross@intel.com | 1793 | M: Doug Thompson <dougthompson@xmission.com> |
| 2084 | P: Doug Thompson | ||
| 2085 | M: dougthompson@xmission.com | ||
| 2086 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) | 1794 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 2087 | W: bluesmoke.sourceforge.net | 1795 | W: bluesmoke.sourceforge.net |
| 2088 | S: Maintained | 1796 | S: Maintained |
| 2089 | F: drivers/edac/e752x_edac.c | 1797 | F: drivers/edac/e752x_edac.c |
| 2090 | 1798 | ||
| 2091 | EDAC-E7XXX | 1799 | EDAC-E7XXX |
| 2092 | P: Doug Thompson | 1800 | M: Doug Thompson <dougthompson@xmission.com> |
| 2093 | M: dougthompson@xmission.com | ||
| 2094 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) | 1801 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 2095 | W: bluesmoke.sourceforge.net | 1802 | W: bluesmoke.sourceforge.net |
| 2096 | S: Maintained | 1803 | S: Maintained |
| 2097 | F: drivers/edac/e7xxx_edac.c | 1804 | F: drivers/edac/e7xxx_edac.c |
| 2098 | 1805 | ||
| 2099 | EDAC-I82443BXGX | 1806 | EDAC-I82443BXGX |
| 2100 | P: Tim Small | 1807 | M: Tim Small <tim@buttersideup.com> |
| 2101 | M: tim@buttersideup.com | ||
| 2102 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) | 1808 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 2103 | W: bluesmoke.sourceforge.net | 1809 | W: bluesmoke.sourceforge.net |
| 2104 | S: Maintained | 1810 | S: Maintained |
| 2105 | F: drivers/edac/i82443bxgx_edac.c | 1811 | F: drivers/edac/i82443bxgx_edac.c |
| 2106 | 1812 | ||
| 2107 | EDAC-I3000 | 1813 | EDAC-I3000 |
| 2108 | P: Jason Uhlenkott | 1814 | M: Jason Uhlenkott <juhlenko@akamai.com> |
| 2109 | M: juhlenko@akamai.com | ||
| 2110 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) | 1815 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 2111 | W: bluesmoke.sourceforge.net | 1816 | W: bluesmoke.sourceforge.net |
| 2112 | S: Maintained | 1817 | S: Maintained |
| 2113 | F: drivers/edac/i3000_edac.c | 1818 | F: drivers/edac/i3000_edac.c |
| 2114 | 1819 | ||
| 2115 | EDAC-I5000 | 1820 | EDAC-I5000 |
| 2116 | P: Doug Thompson | 1821 | M: Doug Thompson <dougthompson@xmission.com> |
| 2117 | M: dougthompson@xmission.com | ||
| 2118 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) | 1822 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 2119 | W: bluesmoke.sourceforge.net | 1823 | W: bluesmoke.sourceforge.net |
| 2120 | S: Maintained | 1824 | S: Maintained |
| 2121 | F: drivers/edac/i5000_edac.c | 1825 | F: drivers/edac/i5000_edac.c |
| 2122 | 1826 | ||
| 2123 | EDAC-I5400 | 1827 | EDAC-I5400 |
| 2124 | P: Mauro Carvalho Chehab | 1828 | M: Mauro Carvalho Chehab <mchehab@redhat.com> |
| 2125 | M: mchehab@redhat.com | ||
| 2126 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) | 1829 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 2127 | W: bluesmoke.sourceforge.net | 1830 | W: bluesmoke.sourceforge.net |
| 2128 | S: Maintained | 1831 | S: Maintained |
| 2129 | F: drivers/edac/i5400_edac.c | 1832 | F: drivers/edac/i5400_edac.c |
| 2130 | 1833 | ||
| 2131 | EDAC-I82975X | 1834 | EDAC-I82975X |
| 2132 | P: Ranganathan Desikan | 1835 | M: Ranganathan Desikan <ravi@jetztechnologies.com> |
| 2133 | M: ravi@jetztechnologies.com | 1836 | M: "Arvind R." <arvind@jetztechnologies.com> |
| 2134 | P: Arvind R. | ||
| 2135 | M: arvind@jetztechnologies.com | ||
| 2136 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) | 1837 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 2137 | W: bluesmoke.sourceforge.net | 1838 | W: bluesmoke.sourceforge.net |
| 2138 | S: Maintained | 1839 | S: Maintained |
| 2139 | F: drivers/edac/i82975x_edac.c | 1840 | F: drivers/edac/i82975x_edac.c |
| 2140 | 1841 | ||
| 2141 | EDAC-PASEMI | 1842 | EDAC-PASEMI |
| 2142 | P: Egor Martovetsky | 1843 | M: Egor Martovetsky <egor@pasemi.com> |
| 2143 | M: egor@pasemi.com | ||
| 2144 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) | 1844 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 2145 | W: bluesmoke.sourceforge.net | 1845 | W: bluesmoke.sourceforge.net |
| 2146 | S: Maintained | 1846 | S: Maintained |
| 2147 | F: drivers/edac/pasemi_edac.c | 1847 | F: drivers/edac/pasemi_edac.c |
| 2148 | 1848 | ||
| 2149 | EDAC-R82600 | 1849 | EDAC-R82600 |
| 2150 | P: Tim Small | 1850 | M: Tim Small <tim@buttersideup.com> |
| 2151 | M: tim@buttersideup.com | ||
| 2152 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) | 1851 | L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 2153 | W: bluesmoke.sourceforge.net | 1852 | W: bluesmoke.sourceforge.net |
| 2154 | S: Maintained | 1853 | S: Maintained |
| 2155 | F: drivers/edac/r82600_edac.c | 1854 | F: drivers/edac/r82600_edac.c |
| 2156 | 1855 | ||
| 2157 | EEEPC LAPTOP EXTRAS DRIVER | 1856 | EEEPC LAPTOP EXTRAS DRIVER |
| 2158 | P: Corentin Chary | 1857 | M: Corentin Chary <corentincj@iksaif.net> |
| 2159 | M: corentincj@iksaif.net | ||
| 2160 | L: acpi4asus-user@lists.sourceforge.net | 1858 | L: acpi4asus-user@lists.sourceforge.net |
| 2161 | W: http://acpi4asus.sf.net | 1859 | W: http://acpi4asus.sf.net |
| 2162 | S: Maintained | 1860 | S: Maintained |
| @@ -2168,66 +1866,54 @@ S: Orphan | |||
| 2168 | F: fs/efs/ | 1866 | F: fs/efs/ |
| 2169 | 1867 | ||
| 2170 | EHCA (IBM GX bus InfiniBand adapter) DRIVER | 1868 | EHCA (IBM GX bus InfiniBand adapter) DRIVER |
| 2171 | P: Hoang-Nam Nguyen | 1869 | M: Hoang-Nam Nguyen <hnguyen@de.ibm.com> |
| 2172 | M: hnguyen@de.ibm.com | 1870 | M: Christoph Raisch <raisch@de.ibm.com> |
| 2173 | P: Christoph Raisch | ||
| 2174 | M: raisch@de.ibm.com | ||
| 2175 | L: general@lists.openfabrics.org | 1871 | L: general@lists.openfabrics.org |
| 2176 | S: Supported | 1872 | S: Supported |
| 2177 | F: drivers/infiniband/hw/ehca/ | 1873 | F: drivers/infiniband/hw/ehca/ |
| 2178 | 1874 | ||
| 2179 | EMBEDDED LINUX | 1875 | EMBEDDED LINUX |
| 2180 | P: Paul Gortmaker | 1876 | M: Paul Gortmaker <paul.gortmaker@windriver.com> |
| 2181 | M: paul.gortmaker@windriver.com | 1877 | M: Matt Mackall <mpm@selenic.com> |
| 2182 | P: Matt Mackall | 1878 | M: David Woodhouse <dwmw2@infradead.org> |
| 2183 | M: mpm@selenic.com | ||
| 2184 | P: David Woodhouse | ||
| 2185 | M: dwmw2@infradead.org | ||
| 2186 | L: linux-embedded@vger.kernel.org | 1879 | L: linux-embedded@vger.kernel.org |
| 2187 | S: Maintained | 1880 | S: Maintained |
| 2188 | 1881 | ||
| 2189 | EMULEX LPFC FC SCSI DRIVER | 1882 | EMULEX LPFC FC SCSI DRIVER |
| 2190 | P: James Smart | 1883 | M: James Smart <james.smart@emulex.com> |
| 2191 | M: james.smart@emulex.com | ||
| 2192 | L: linux-scsi@vger.kernel.org | 1884 | L: linux-scsi@vger.kernel.org |
| 2193 | W: http://sourceforge.net/projects/lpfcxxxx | 1885 | W: http://sourceforge.net/projects/lpfcxxxx |
| 2194 | S: Supported | 1886 | S: Supported |
| 2195 | F: drivers/scsi/lpfc/ | 1887 | F: drivers/scsi/lpfc/ |
| 2196 | 1888 | ||
| 2197 | ENE CB710 FLASH CARD READER DRIVER | 1889 | ENE CB710 FLASH CARD READER DRIVER |
| 2198 | P: Michał Mirosław | 1890 | M: Michał Mirosław <mirq-linux@rere.qmqm.pl> |
| 2199 | M: mirq-linux@rere.qmqm.pl | ||
| 2200 | L: linux-kernel@vger.kernel.org | ||
| 2201 | S: Maintained | 1891 | S: Maintained |
| 2202 | F: drivers/misc/cb710/ | 1892 | F: drivers/misc/cb710/ |
| 2203 | F: drivers/mmc/host/cb710-mmc.* | 1893 | F: drivers/mmc/host/cb710-mmc.* |
| 2204 | F: include/linux/cb710.h | 1894 | F: include/linux/cb710.h |
| 2205 | 1895 | ||
| 2206 | EPSON 1355 FRAMEBUFFER DRIVER | 1896 | EPSON 1355 FRAMEBUFFER DRIVER |
| 2207 | P: Christopher Hoover | 1897 | M: Christopher Hoover <ch@murgatroid.com> |
| 2208 | M: ch@murgatroid.com | 1898 | M: Christopher Hoover <ch@hpl.hp.com> |
| 2209 | P: Christopher Hoover | ||
| 2210 | M: ch@hpl.hp.com | ||
| 2211 | S: Maintained | 1899 | S: Maintained |
| 2212 | F: drivers/video/epson1355fb.c | 1900 | F: drivers/video/epson1355fb.c |
| 2213 | 1901 | ||
| 2214 | EPSON S1D13XXX FRAMEBUFFER DRIVER | 1902 | EPSON S1D13XXX FRAMEBUFFER DRIVER |
| 2215 | P: Kristoffer Ericson | 1903 | M: Kristoffer Ericson <kristoffer.ericson@gmail.com> |
| 2216 | M: kristoffer.ericson@gmail.com | ||
| 2217 | S: Maintained | 1904 | S: Maintained |
| 1905 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/kristoffer/linux-hpc.git | ||
| 2218 | F: drivers/video/s1d13xxxfb.c | 1906 | F: drivers/video/s1d13xxxfb.c |
| 2219 | F: include/video/s1d13xxxfb.h | 1907 | F: include/video/s1d13xxxfb.h |
| 2220 | 1908 | ||
| 2221 | ETHEREXPRESS-16 NETWORK DRIVER | 1909 | ETHEREXPRESS-16 NETWORK DRIVER |
| 2222 | P: Philip Blundell | 1910 | M: Philip Blundell <philb@gnu.org> |
| 2223 | M: philb@gnu.org | ||
| 2224 | L: netdev@vger.kernel.org | 1911 | L: netdev@vger.kernel.org |
| 2225 | S: Maintained | 1912 | S: Maintained |
| 2226 | F: drivers/net/eexpress.* | 1913 | F: drivers/net/eexpress.* |
| 2227 | 1914 | ||
| 2228 | ETHERNET BRIDGE | 1915 | ETHERNET BRIDGE |
| 2229 | P: Stephen Hemminger | 1916 | M: Stephen Hemminger <shemminger@linux-foundation.org> |
| 2230 | M: shemminger@linux-foundation.org | ||
| 2231 | L: bridge@lists.linux-foundation.org | 1917 | L: bridge@lists.linux-foundation.org |
| 2232 | W: http://www.linux-foundation.org/en/Net:Bridge | 1918 | W: http://www.linux-foundation.org/en/Net:Bridge |
| 2233 | S: Maintained | 1919 | S: Maintained |
| @@ -2235,8 +1921,7 @@ F: include/linux/netfilter_bridge/ | |||
| 2235 | F: net/bridge/ | 1921 | F: net/bridge/ |
| 2236 | 1922 | ||
| 2237 | ETHERTEAM 16I DRIVER | 1923 | ETHERTEAM 16I DRIVER |
| 2238 | P: Mika Kuoppala | 1924 | M: Mika Kuoppala <miku@iki.fi> |
| 2239 | M: miku@iki.fi | ||
| 2240 | S: Maintained | 1925 | S: Maintained |
| 2241 | F: drivers/net/eth16i.c | 1926 | F: drivers/net/eth16i.c |
| 2242 | 1927 | ||
| @@ -2248,12 +1933,9 @@ F: fs/ext2/ | |||
| 2248 | F: include/linux/ext2* | 1933 | F: include/linux/ext2* |
| 2249 | 1934 | ||
| 2250 | EXT3 FILE SYSTEM | 1935 | EXT3 FILE SYSTEM |
| 2251 | P: Stephen Tweedie | 1936 | M: Stephen Tweedie <sct@redhat.com> |
| 2252 | M: sct@redhat.com | 1937 | M: Andrew Morton <akpm@linux-foundation.org> |
| 2253 | P: Andrew Morton | 1938 | M: Andreas Dilger <adilger@sun.com> |
| 2254 | M: akpm@linux-foundation.org | ||
| 2255 | P: Andreas Dilger | ||
| 2256 | M: adilger@sun.com | ||
| 2257 | L: linux-ext4@vger.kernel.org | 1939 | L: linux-ext4@vger.kernel.org |
| 2258 | S: Maintained | 1940 | S: Maintained |
| 2259 | F: Documentation/filesystems/ext3.txt | 1941 | F: Documentation/filesystems/ext3.txt |
| @@ -2261,10 +1943,8 @@ F: fs/ext3/ | |||
| 2261 | F: include/linux/ext3* | 1943 | F: include/linux/ext3* |
| 2262 | 1944 | ||
| 2263 | EXT4 FILE SYSTEM | 1945 | EXT4 FILE SYSTEM |
| 2264 | P: Theodore Ts'o | 1946 | M: "Theodore Ts'o" <tytso@mit.edu> |
| 2265 | M: tytso@mit.edu | 1947 | M: Andreas Dilger <adilger@sun.com> |
| 2266 | P: Andreas Dilger | ||
| 2267 | M: adilger@sun.com | ||
| 2268 | L: linux-ext4@vger.kernel.org | 1948 | L: linux-ext4@vger.kernel.org |
| 2269 | W: http://ext4.wiki.kernel.org | 1949 | W: http://ext4.wiki.kernel.org |
| 2270 | S: Maintained | 1950 | S: Maintained |
| @@ -2272,30 +1952,26 @@ F: Documentation/filesystems/ext4.txt | |||
| 2272 | F: fs/ext4/ | 1952 | F: fs/ext4/ |
| 2273 | 1953 | ||
| 2274 | F71805F HARDWARE MONITORING DRIVER | 1954 | F71805F HARDWARE MONITORING DRIVER |
| 2275 | P: Jean Delvare | 1955 | M: Jean Delvare <khali@linux-fr.org> |
| 2276 | M: khali@linux-fr.org | ||
| 2277 | L: lm-sensors@lm-sensors.org | 1956 | L: lm-sensors@lm-sensors.org |
| 2278 | S: Maintained | 1957 | S: Maintained |
| 2279 | F: Documentation/hwmon/f71805f | 1958 | F: Documentation/hwmon/f71805f |
| 2280 | F: drivers/hwmon/f71805f.c | 1959 | F: drivers/hwmon/f71805f.c |
| 2281 | 1960 | ||
| 2282 | FARSYNC SYNCHRONOUS DRIVER | 1961 | FARSYNC SYNCHRONOUS DRIVER |
| 2283 | P: Kevin Curtis | 1962 | M: Kevin Curtis <kevin.curtis@farsite.co.uk> |
| 2284 | M: kevin.curtis@farsite.co.uk | ||
| 2285 | W: http://www.farsite.co.uk/ | 1963 | W: http://www.farsite.co.uk/ |
| 2286 | S: Supported | 1964 | S: Supported |
| 2287 | F: drivers/net/wan/farsync.* | 1965 | F: drivers/net/wan/farsync.* |
| 2288 | 1966 | ||
| 2289 | FAULT INJECTION SUPPORT | 1967 | FAULT INJECTION SUPPORT |
| 2290 | P: Akinobu Mita | 1968 | M: Akinobu Mita <akinobu.mita@gmail.com> |
| 2291 | M: akinobu.mita@gmail.com | ||
| 2292 | S: Supported | 1969 | S: Supported |
| 2293 | F: Documentation/fault-injection/ | 1970 | F: Documentation/fault-injection/ |
| 2294 | F: lib/fault-inject.c | 1971 | F: lib/fault-inject.c |
| 2295 | 1972 | ||
| 2296 | FILE LOCKING (flock() and fcntl()/lockf()) | 1973 | FILE LOCKING (flock() and fcntl()/lockf()) |
| 2297 | P: Matthew Wilcox | 1974 | M: Matthew Wilcox <matthew@wil.cx> |
| 2298 | M: matthew@wil.cx | ||
| 2299 | L: linux-fsdevel@vger.kernel.org | 1975 | L: linux-fsdevel@vger.kernel.org |
| 2300 | S: Maintained | 1976 | S: Maintained |
| 2301 | F: include/linux/fcntl.h | 1977 | F: include/linux/fcntl.h |
| @@ -2304,25 +1980,21 @@ F: fs/fcntl.c | |||
| 2304 | F: fs/locks.c | 1980 | F: fs/locks.c |
| 2305 | 1981 | ||
| 2306 | FILESYSTEMS (VFS and infrastructure) | 1982 | FILESYSTEMS (VFS and infrastructure) |
| 2307 | P: Alexander Viro | 1983 | M: Alexander Viro <viro@zeniv.linux.org.uk> |
| 2308 | M: viro@zeniv.linux.org.uk | ||
| 2309 | L: linux-fsdevel@vger.kernel.org | 1984 | L: linux-fsdevel@vger.kernel.org |
| 2310 | S: Maintained | 1985 | S: Maintained |
| 2311 | F: fs/* | 1986 | F: fs/* |
| 2312 | 1987 | ||
| 2313 | FINTEK F75375S HARDWARE MONITOR AND FAN CONTROLLER DRIVER | 1988 | FINTEK F75375S HARDWARE MONITOR AND FAN CONTROLLER DRIVER |
| 2314 | P: Riku Voipio | 1989 | M: Riku Voipio <riku.vipio@iki.fi> |
| 2315 | M: riku.vipio@iki.fi | ||
| 2316 | L: lm-sensors@lm-sensors.org | 1990 | L: lm-sensors@lm-sensors.org |
| 2317 | S: Maintained | 1991 | S: Maintained |
| 2318 | F: drivers/hwmon/f75375s.c | 1992 | F: drivers/hwmon/f75375s.c |
| 2319 | F: include/linux/f75375s.h | 1993 | F: include/linux/f75375s.h |
| 2320 | 1994 | ||
| 2321 | FIREWIRE SUBSYSTEM | 1995 | FIREWIRE SUBSYSTEM |
| 2322 | P: Kristian Hoegsberg | 1996 | M: Kristian Hoegsberg <krh@redhat.com> |
| 2323 | M: krh@redhat.com | 1997 | M: Stefan Richter <stefanr@s5r6.in-berlin.de> |
| 2324 | P: Stefan Richter | ||
| 2325 | M: stefanr@s5r6.in-berlin.de | ||
| 2326 | L: linux1394-devel@lists.sourceforge.net | 1998 | L: linux1394-devel@lists.sourceforge.net |
| 2327 | W: http://www.linux1394.org/ | 1999 | W: http://www.linux1394.org/ |
| 2328 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394-2.6.git | 2000 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394-2.6.git |
| @@ -2337,15 +2009,13 @@ F: drivers/base/firmware*.c | |||
| 2337 | F: include/linux/firmware.h | 2009 | F: include/linux/firmware.h |
| 2338 | 2010 | ||
| 2339 | FPU EMULATOR | 2011 | FPU EMULATOR |
| 2340 | P: Bill Metzenthen | 2012 | M: Bill Metzenthen <billm@melbpc.org.au> |
| 2341 | M: billm@melbpc.org.au | ||
| 2342 | W: http://floatingpoint.sourceforge.net/emulator/index.html | 2013 | W: http://floatingpoint.sourceforge.net/emulator/index.html |
| 2343 | S: Maintained | 2014 | S: Maintained |
| 2344 | F: arch/x86/math-emu/ | 2015 | F: arch/x86/math-emu/ |
| 2345 | 2016 | ||
| 2346 | FRAME RELAY DLCI/FRAD (Sangoma drivers too) | 2017 | FRAME RELAY DLCI/FRAD (Sangoma drivers too) |
| 2347 | P: Mike McLagan | 2018 | M: Mike McLagan <mike.mclagan@linux.org> |
| 2348 | M: mike.mclagan@linux.org | ||
| 2349 | L: netdev@vger.kernel.org | 2019 | L: netdev@vger.kernel.org |
| 2350 | S: Maintained | 2020 | S: Maintained |
| 2351 | F: drivers/net/wan/dlci.c | 2021 | F: drivers/net/wan/dlci.c |
| @@ -2360,25 +2030,21 @@ F: drivers/video/fb* | |||
| 2360 | F: include/linux/fb.h | 2030 | F: include/linux/fb.h |
| 2361 | 2031 | ||
| 2362 | FREESCALE DMA DRIVER | 2032 | FREESCALE DMA DRIVER |
| 2363 | P: Li Yang | 2033 | M: Li Yang <leoli@freescale.com> |
| 2364 | M: leoli@freescale.com | 2034 | M: Zhang Wei <zw@zh-kernel.org> |
| 2365 | P: Zhang Wei | ||
| 2366 | M: zw@zh-kernel.org | ||
| 2367 | L: linuxppc-dev@ozlabs.org | 2035 | L: linuxppc-dev@ozlabs.org |
| 2368 | S: Maintained | 2036 | S: Maintained |
| 2369 | F: drivers/dma/fsldma.* | 2037 | F: drivers/dma/fsldma.* |
| 2370 | 2038 | ||
| 2371 | FREESCALE I2C CPM DRIVER | 2039 | FREESCALE I2C CPM DRIVER |
| 2372 | P: Jochen Friedrich | 2040 | M: Jochen Friedrich <jochen@scram.de> |
| 2373 | M: jochen@scram.de | ||
| 2374 | L: linuxppc-dev@ozlabs.org | 2041 | L: linuxppc-dev@ozlabs.org |
| 2375 | L: linux-i2c@vger.kernel.org | 2042 | L: linux-i2c@vger.kernel.org |
| 2376 | S: Maintained | 2043 | S: Maintained |
| 2377 | F: drivers/i2c/busses/i2c-cpm.c | 2044 | F: drivers/i2c/busses/i2c-cpm.c |
| 2378 | 2045 | ||
| 2379 | FREESCALE IMX / MXC FRAMEBUFFER DRIVER | 2046 | FREESCALE IMX / MXC FRAMEBUFFER DRIVER |
| 2380 | P: Sascha Hauer | 2047 | M: Sascha Hauer <kernel@pengutronix.de> |
| 2381 | M: kernel@pengutronix.de | ||
| 2382 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) | 2048 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 2383 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 2049 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 2384 | S: Maintained | 2050 | S: Maintained |
| @@ -2386,10 +2052,8 @@ F: arch/arm/plat-mxc/include/mach/imxfb.h | |||
| 2386 | F: drivers/video/imxfb.c | 2052 | F: drivers/video/imxfb.c |
| 2387 | 2053 | ||
| 2388 | FREESCALE SOC FS_ENET DRIVER | 2054 | FREESCALE SOC FS_ENET DRIVER |
| 2389 | P: Pantelis Antoniou | 2055 | M: Pantelis Antoniou <pantelis.antoniou@gmail.com> |
| 2390 | M: pantelis.antoniou@gmail.com | 2056 | M: Vitaly Bordug <vbordug@ru.mvista.com> |
| 2391 | P: Vitaly Bordug | ||
| 2392 | M: vbordug@ru.mvista.com | ||
| 2393 | L: linuxppc-dev@ozlabs.org | 2057 | L: linuxppc-dev@ozlabs.org |
| 2394 | L: netdev@vger.kernel.org | 2058 | L: netdev@vger.kernel.org |
| 2395 | S: Maintained | 2059 | S: Maintained |
| @@ -2397,39 +2061,34 @@ F: drivers/net/fs_enet/ | |||
| 2397 | F: include/linux/fs_enet_pd.h | 2061 | F: include/linux/fs_enet_pd.h |
| 2398 | 2062 | ||
| 2399 | FREESCALE QUICC ENGINE LIBRARY | 2063 | FREESCALE QUICC ENGINE LIBRARY |
| 2400 | P: Timur Tabi | 2064 | M: Timur Tabi <timur@freescale.com> |
| 2401 | M: timur@freescale.com | ||
| 2402 | L: linuxppc-dev@ozlabs.org | 2065 | L: linuxppc-dev@ozlabs.org |
| 2403 | S: Supported | 2066 | S: Supported |
| 2404 | F: arch/powerpc/sysdev/qe_lib/ | 2067 | F: arch/powerpc/sysdev/qe_lib/ |
| 2405 | F: arch/powerpc/include/asm/*qe.h | 2068 | F: arch/powerpc/include/asm/*qe.h |
| 2406 | 2069 | ||
| 2407 | FREESCALE HIGHSPEED USB DEVICE DRIVER | 2070 | FREESCALE HIGHSPEED USB DEVICE DRIVER |
| 2408 | P: Li Yang | 2071 | M: Li Yang <leoli@freescale.com> |
| 2409 | M: leoli@freescale.com | ||
| 2410 | L: linux-usb@vger.kernel.org | 2072 | L: linux-usb@vger.kernel.org |
| 2411 | L: linuxppc-dev@ozlabs.org | 2073 | L: linuxppc-dev@ozlabs.org |
| 2412 | S: Maintained | 2074 | S: Maintained |
| 2413 | F: drivers/usb/gadget/fsl_usb2_udc.c | 2075 | F: drivers/usb/gadget/fsl_usb2_udc.c |
| 2414 | 2076 | ||
| 2415 | FREESCALE QUICC ENGINE UCC ETHERNET DRIVER | 2077 | FREESCALE QUICC ENGINE UCC ETHERNET DRIVER |
| 2416 | P: Li Yang | 2078 | M: Li Yang <leoli@freescale.com> |
| 2417 | M: leoli@freescale.com | ||
| 2418 | L: netdev@vger.kernel.org | 2079 | L: netdev@vger.kernel.org |
| 2419 | L: linuxppc-dev@ozlabs.org | 2080 | L: linuxppc-dev@ozlabs.org |
| 2420 | S: Maintained | 2081 | S: Maintained |
| 2421 | F: drivers/net/ucc_geth* | 2082 | F: drivers/net/ucc_geth* |
| 2422 | 2083 | ||
| 2423 | FREESCALE QUICC ENGINE UCC UART DRIVER | 2084 | FREESCALE QUICC ENGINE UCC UART DRIVER |
| 2424 | P: Timur Tabi | 2085 | M: Timur Tabi <timur@freescale.com> |
| 2425 | M: timur@freescale.com | ||
| 2426 | L: linuxppc-dev@ozlabs.org | 2086 | L: linuxppc-dev@ozlabs.org |
| 2427 | S: Supported | 2087 | S: Supported |
| 2428 | F: drivers/serial/ucc_uart.c | 2088 | F: drivers/serial/ucc_uart.c |
| 2429 | 2089 | ||
| 2430 | FREESCALE SOC SOUND DRIVERS | 2090 | FREESCALE SOC SOUND DRIVERS |
| 2431 | P: Timur Tabi | 2091 | M: Timur Tabi <timur@freescale.com> |
| 2432 | M: timur@freescale.com | ||
| 2433 | L: alsa-devel@alsa-project.org (moderated for non-subscribers) | 2092 | L: alsa-devel@alsa-project.org (moderated for non-subscribers) |
| 2434 | L: linuxppc-dev@ozlabs.org | 2093 | L: linuxppc-dev@ozlabs.org |
| 2435 | S: Supported | 2094 | S: Supported |
| @@ -2437,17 +2096,14 @@ F: sound/soc/fsl/fsl* | |||
| 2437 | F: sound/soc/fsl/mpc8610_hpcd.c | 2096 | F: sound/soc/fsl/mpc8610_hpcd.c |
| 2438 | 2097 | ||
| 2439 | FREEVXFS FILESYSTEM | 2098 | FREEVXFS FILESYSTEM |
| 2440 | P: Christoph Hellwig | 2099 | M: Christoph Hellwig <hch@infradead.org> |
| 2441 | M: hch@infradead.org | ||
| 2442 | W: ftp://ftp.openlinux.org/pub/people/hch/vxfs | 2100 | W: ftp://ftp.openlinux.org/pub/people/hch/vxfs |
| 2443 | S: Maintained | 2101 | S: Maintained |
| 2444 | F: fs/freevxfs/ | 2102 | F: fs/freevxfs/ |
| 2445 | 2103 | ||
| 2446 | FREEZER | 2104 | FREEZER |
| 2447 | P: Pavel Machek | 2105 | M: Pavel Machek <pavel@ucw.cz> |
| 2448 | M: pavel@ucw.cz | 2106 | M: "Rafael J. Wysocki" <rjw@sisk.pl> |
| 2449 | P: Rafael J. Wysocki | ||
| 2450 | M: rjw@sisk.pl | ||
| 2451 | L: linux-pm@lists.linux-foundation.org | 2107 | L: linux-pm@lists.linux-foundation.org |
| 2452 | S: Supported | 2108 | S: Supported |
| 2453 | F: Documentation/power/freezing-of-tasks.txt | 2109 | F: Documentation/power/freezing-of-tasks.txt |
| @@ -2455,8 +2111,7 @@ F: include/linux/freezer.h | |||
| 2455 | F: kernel/freezer.c | 2111 | F: kernel/freezer.c |
| 2456 | 2112 | ||
| 2457 | FS-CACHE: LOCAL CACHING FOR NETWORK FILESYSTEMS | 2113 | FS-CACHE: LOCAL CACHING FOR NETWORK FILESYSTEMS |
| 2458 | P: David Howells | 2114 | M: David Howells <dhowells@redhat.com> |
| 2459 | M: dhowells@redhat.com | ||
| 2460 | L: linux-cachefs@redhat.com | 2115 | L: linux-cachefs@redhat.com |
| 2461 | S: Supported | 2116 | S: Supported |
| 2462 | F: Documentation/filesystems/caching/ | 2117 | F: Documentation/filesystems/caching/ |
| @@ -2464,8 +2119,7 @@ F: fs/fscache/ | |||
| 2464 | F: include/linux/fscache*.h | 2119 | F: include/linux/fscache*.h |
| 2465 | 2120 | ||
| 2466 | FTRACE | 2121 | FTRACE |
| 2467 | P: Steven Rostedt | 2122 | M: Steven Rostedt <rostedt@goodmis.org> |
| 2468 | M: rostedt@goodmis.org | ||
| 2469 | S: Maintained | 2123 | S: Maintained |
| 2470 | F: Documentation/trace/ftrace.txt | 2124 | F: Documentation/trace/ftrace.txt |
| 2471 | F: arch/*/*/*/ftrace.h | 2125 | F: arch/*/*/*/ftrace.h |
| @@ -2474,21 +2128,18 @@ F: include/*/ftrace.h | |||
| 2474 | F: kernel/trace/ | 2128 | F: kernel/trace/ |
| 2475 | 2129 | ||
| 2476 | FUJITSU FR-V (FRV) PORT | 2130 | FUJITSU FR-V (FRV) PORT |
| 2477 | P: David Howells | 2131 | M: David Howells <dhowells@redhat.com> |
| 2478 | M: dhowells@redhat.com | ||
| 2479 | S: Maintained | 2132 | S: Maintained |
| 2480 | F: arch/frv/ | 2133 | F: arch/frv/ |
| 2481 | 2134 | ||
| 2482 | FUJITSU LAPTOP EXTRAS | 2135 | FUJITSU LAPTOP EXTRAS |
| 2483 | P: Jonathan Woithe | 2136 | M: Jonathan Woithe <jwoithe@physics.adelaide.edu.au> |
| 2484 | M: jwoithe@physics.adelaide.edu.au | ||
| 2485 | L: linux-acpi@vger.kernel.org | 2137 | L: linux-acpi@vger.kernel.org |
| 2486 | S: Maintained | 2138 | S: Maintained |
| 2487 | F: drivers/platform/x86/fujitsu-laptop.c | 2139 | F: drivers/platform/x86/fujitsu-laptop.c |
| 2488 | 2140 | ||
| 2489 | FUSE: FILESYSTEM IN USERSPACE | 2141 | FUSE: FILESYSTEM IN USERSPACE |
| 2490 | P: Miklos Szeredi | 2142 | M: Miklos Szeredi <miklos@szeredi.hu> |
| 2491 | M: miklos@szeredi.hu | ||
| 2492 | L: fuse-devel@lists.sourceforge.net | 2143 | L: fuse-devel@lists.sourceforge.net |
| 2493 | W: http://fuse.sourceforge.net/ | 2144 | W: http://fuse.sourceforge.net/ |
| 2494 | S: Maintained | 2145 | S: Maintained |
| @@ -2496,30 +2147,26 @@ F: fs/fuse/ | |||
| 2496 | F: include/linux/fuse.h | 2147 | F: include/linux/fuse.h |
| 2497 | 2148 | ||
| 2498 | FUTURE DOMAIN TMC-16x0 SCSI DRIVER (16-bit) | 2149 | FUTURE DOMAIN TMC-16x0 SCSI DRIVER (16-bit) |
| 2499 | P: Rik Faith | 2150 | M: Rik Faith <faith@cs.unc.edu> |
| 2500 | M: faith@cs.unc.edu | ||
| 2501 | L: linux-scsi@vger.kernel.org | 2151 | L: linux-scsi@vger.kernel.org |
| 2502 | S: Odd Fixes (e.g., new signatures) | 2152 | S: Odd Fixes (e.g., new signatures) |
| 2503 | F: drivers/scsi/fdomain.* | 2153 | F: drivers/scsi/fdomain.* |
| 2504 | 2154 | ||
| 2505 | GDT SCSI DISK ARRAY CONTROLLER DRIVER | 2155 | GDT SCSI DISK ARRAY CONTROLLER DRIVER |
| 2506 | P: Achim Leubner | 2156 | M: Achim Leubner <achim_leubner@adaptec.com> |
| 2507 | M: achim_leubner@adaptec.com | ||
| 2508 | L: linux-scsi@vger.kernel.org | 2157 | L: linux-scsi@vger.kernel.org |
| 2509 | W: http://www.icp-vortex.com/ | 2158 | W: http://www.icp-vortex.com/ |
| 2510 | S: Supported | 2159 | S: Supported |
| 2511 | F: drivers/scsi/gdt* | 2160 | F: drivers/scsi/gdt* |
| 2512 | 2161 | ||
| 2513 | GENERIC GPIO I2C DRIVER | 2162 | GENERIC GPIO I2C DRIVER |
| 2514 | P: Haavard Skinnemoen | 2163 | M: Haavard Skinnemoen <hskinnemoen@atmel.com> |
| 2515 | M: hskinnemoen@atmel.com | ||
| 2516 | S: Supported | 2164 | S: Supported |
| 2517 | F: drivers/i2c/busses/i2c-gpio.c | 2165 | F: drivers/i2c/busses/i2c-gpio.c |
| 2518 | F: include/linux/i2c-gpio.h | 2166 | F: include/linux/i2c-gpio.h |
| 2519 | 2167 | ||
| 2520 | GENERIC HDLC (WAN) DRIVERS | 2168 | GENERIC HDLC (WAN) DRIVERS |
| 2521 | P: Krzysztof Halasa | 2169 | M: Krzysztof Halasa <khc@pm.waw.pl> |
| 2522 | M: khc@pm.waw.pl | ||
| 2523 | W: http://www.kernel.org/pub/linux/utils/net/hdlc/ | 2170 | W: http://www.kernel.org/pub/linux/utils/net/hdlc/ |
| 2524 | S: Maintained | 2171 | S: Maintained |
| 2525 | F: drivers/net/wan/c101.c | 2172 | F: drivers/net/wan/c101.c |
| @@ -2531,16 +2178,14 @@ F: drivers/net/wan/pci200syn.c | |||
| 2531 | F: drivers/net/wan/wanxl* | 2178 | F: drivers/net/wan/wanxl* |
| 2532 | 2179 | ||
| 2533 | GENERIC INCLUDE/ASM HEADER FILES | 2180 | GENERIC INCLUDE/ASM HEADER FILES |
| 2534 | P: Arnd Bergmann | 2181 | M: Arnd Bergmann <arnd@arndb.de> |
| 2535 | M: arnd@arndb.de | ||
| 2536 | L: linux-arch@vger.kernel.org | 2182 | L: linux-arch@vger.kernel.org |
| 2537 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic.git | 2183 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic.git |
| 2538 | S: Maintained | 2184 | S: Maintained |
| 2539 | F: include/asm-generic | 2185 | F: include/asm-generic |
| 2540 | 2186 | ||
| 2541 | GFS2 FILE SYSTEM | 2187 | GFS2 FILE SYSTEM |
| 2542 | P: Steven Whitehouse | 2188 | M: Steven Whitehouse <swhiteho@redhat.com> |
| 2543 | M: swhiteho@redhat.com | ||
| 2544 | L: cluster-devel@redhat.com | 2189 | L: cluster-devel@redhat.com |
| 2545 | W: http://sources.redhat.com/cluster/ | 2190 | W: http://sources.redhat.com/cluster/ |
| 2546 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/steve/gfs2-2.6-fixes.git | 2191 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/steve/gfs2-2.6-fixes.git |
| @@ -2551,10 +2196,8 @@ F: fs/gfs2/ | |||
| 2551 | F: include/linux/gfs2_ondisk.h | 2196 | F: include/linux/gfs2_ondisk.h |
| 2552 | 2197 | ||
| 2553 | GIGASET ISDN DRIVERS | 2198 | GIGASET ISDN DRIVERS |
| 2554 | P: Hansjoerg Lipp | 2199 | M: Hansjoerg Lipp <hjlipp@web.de> |
| 2555 | M: hjlipp@web.de | 2200 | M: Tilman Schmidt <tilman@imap.cc> |
| 2556 | P: Tilman Schmidt | ||
| 2557 | M: tilman@imap.cc | ||
| 2558 | L: gigaset307x-common@lists.sourceforge.net | 2201 | L: gigaset307x-common@lists.sourceforge.net |
| 2559 | W: http://gigaset307x.sourceforge.net/ | 2202 | W: http://gigaset307x.sourceforge.net/ |
| 2560 | S: Maintained | 2203 | S: Maintained |
| @@ -2563,8 +2206,7 @@ F: drivers/isdn/gigaset/ | |||
| 2563 | F: include/linux/gigaset_dev.h | 2206 | F: include/linux/gigaset_dev.h |
| 2564 | 2207 | ||
| 2565 | HARD DRIVE ACTIVE PROTECTION SYSTEM (HDAPS) DRIVER | 2208 | HARD DRIVE ACTIVE PROTECTION SYSTEM (HDAPS) DRIVER |
| 2566 | P: Frank Seidel | 2209 | M: Frank Seidel <frank@f-seidel.de> |
| 2567 | M: frank@f-seidel.de | ||
| 2568 | L: lm-sensors@lm-sensors.org | 2210 | L: lm-sensors@lm-sensors.org |
| 2569 | W: http://www.kernel.org/pub/linux/kernel/people/fseidel/hdaps/ | 2211 | W: http://www.kernel.org/pub/linux/kernel/people/fseidel/hdaps/ |
| 2570 | S: Maintained | 2212 | S: Maintained |
| @@ -2576,40 +2218,43 @@ S: Odd Fixes | |||
| 2576 | F: drivers/char/hvc_* | 2218 | F: drivers/char/hvc_* |
| 2577 | 2219 | ||
| 2578 | GSPCA FINEPIX SUBDRIVER | 2220 | GSPCA FINEPIX SUBDRIVER |
| 2579 | P: Frank Zago | 2221 | M: Frank Zago <frank@zago.net> |
| 2580 | M: frank@zago.net | ||
| 2581 | L: linux-media@vger.kernel.org | 2222 | L: linux-media@vger.kernel.org |
| 2582 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 2223 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| 2583 | S: Maintained | 2224 | S: Maintained |
| 2584 | F: drivers/media/video/gspca/finepix.c | 2225 | F: drivers/media/video/gspca/finepix.c |
| 2585 | 2226 | ||
| 2586 | GSPCA M5602 SUBDRIVER | 2227 | GSPCA M5602 SUBDRIVER |
| 2587 | P: Erik Andren | 2228 | M: Erik Andren <erik.andren@gmail.com> |
| 2588 | M: erik.andren@gmail.com | ||
| 2589 | L: linux-media@vger.kernel.org | 2229 | L: linux-media@vger.kernel.org |
| 2590 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 2230 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| 2591 | S: Maintained | 2231 | S: Maintained |
| 2592 | F: drivers/media/video/gspca/m5602/ | 2232 | F: drivers/media/video/gspca/m5602/ |
| 2593 | 2233 | ||
| 2594 | GSPCA PAC207 SONIXB SUBDRIVER | 2234 | GSPCA PAC207 SONIXB SUBDRIVER |
| 2595 | P: Hans de Goede | 2235 | M: Hans de Goede <hdegoede@redhat.com> |
| 2596 | M: hdegoede@redhat.com | ||
| 2597 | L: linux-media@vger.kernel.org | 2236 | L: linux-media@vger.kernel.org |
| 2598 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 2237 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| 2599 | S: Maintained | 2238 | S: Maintained |
| 2600 | F: drivers/media/video/gspca/pac207.c | 2239 | F: drivers/media/video/gspca/pac207.c |
| 2601 | 2240 | ||
| 2241 | GSPCA SN9C20X SUBDRIVER | ||
| 2242 | P: Brian Johnson | ||
| 2243 | M: brijohn@gmail.com | ||
| 2244 | L: linux-media@vger.kernel.org | ||
| 2245 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | ||
| 2246 | S: Maintained | ||
| 2247 | F: drivers/media/video/gspca/sn9c20x.c | ||
| 2248 | |||
| 2602 | GSPCA T613 SUBDRIVER | 2249 | GSPCA T613 SUBDRIVER |
| 2603 | P: Leandro Costantino | 2250 | M: Leandro Costantino <lcostantino@gmail.com> |
| 2604 | M: lcostantino@gmail.com | ||
| 2605 | L: linux-media@vger.kernel.org | 2251 | L: linux-media@vger.kernel.org |
| 2606 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 2252 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| 2607 | S: Maintained | 2253 | S: Maintained |
| 2608 | F: drivers/media/video/gspca/t613.c | 2254 | F: drivers/media/video/gspca/t613.c |
| 2609 | 2255 | ||
| 2610 | GSPCA USB WEBCAM DRIVER | 2256 | GSPCA USB WEBCAM DRIVER |
| 2611 | P: Jean-Francois Moine | 2257 | M: Jean-Francois Moine <moinejf@free.fr> |
| 2612 | M: moinejf@free.fr | ||
| 2613 | W: http://moinejf.free.fr | 2258 | W: http://moinejf.free.fr |
| 2614 | L: linux-media@vger.kernel.org | 2259 | L: linux-media@vger.kernel.org |
| 2615 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 2260 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| @@ -2629,31 +2274,27 @@ F: drivers/char/hw_random/ | |||
| 2629 | F: include/linux/hw_random.h | 2274 | F: include/linux/hw_random.h |
| 2630 | 2275 | ||
| 2631 | HARMONY SOUND DRIVER | 2276 | HARMONY SOUND DRIVER |
| 2632 | P: Kyle McMartin | 2277 | M: Kyle McMartin <kyle@mcmartin.ca> |
| 2633 | M: kyle@mcmartin.ca | ||
| 2634 | L: linux-parisc@vger.kernel.org | 2278 | L: linux-parisc@vger.kernel.org |
| 2635 | S: Maintained | 2279 | S: Maintained |
| 2636 | F: sound/parisc/harmony.* | 2280 | F: sound/parisc/harmony.* |
| 2637 | 2281 | ||
| 2638 | HAYES ESP SERIAL DRIVER | 2282 | HAYES ESP SERIAL DRIVER |
| 2639 | P: Andrew J. Robinson | 2283 | M: "Andrew J. Robinson" <arobinso@nyx.net> |
| 2640 | M: arobinso@nyx.net | ||
| 2641 | W: http://www.nyx.net/~arobinso | 2284 | W: http://www.nyx.net/~arobinso |
| 2642 | S: Maintained | 2285 | S: Maintained |
| 2643 | F: Documentation/serial/hayes-esp.txt | 2286 | F: Documentation/serial/hayes-esp.txt |
| 2644 | F: drivers/char/esp.c | 2287 | F: drivers/char/esp.c |
| 2645 | 2288 | ||
| 2646 | HEWLETT-PACKARD SMART2 RAID DRIVER | 2289 | HEWLETT-PACKARD SMART2 RAID DRIVER |
| 2647 | P: Chirag Kantharia | 2290 | M: Chirag Kantharia <chirag.kantharia@hp.com> |
| 2648 | M: chirag.kantharia@hp.com | ||
| 2649 | L: iss_storagedev@hp.com | 2291 | L: iss_storagedev@hp.com |
| 2650 | S: Maintained | 2292 | S: Maintained |
| 2651 | F: Documentation/blockdev/cpqarray.txt | 2293 | F: Documentation/blockdev/cpqarray.txt |
| 2652 | F: drivers/block/cpqarray.* | 2294 | F: drivers/block/cpqarray.* |
| 2653 | 2295 | ||
| 2654 | HEWLETT-PACKARD SMART CISS RAID DRIVER (cciss) | 2296 | HEWLETT-PACKARD SMART CISS RAID DRIVER (cciss) |
| 2655 | P: Mike Miller | 2297 | M: Mike Miller <mike.miller@hp.com> |
| 2656 | M: mike.miller@hp.com | ||
| 2657 | L: iss_storagedev@hp.com | 2298 | L: iss_storagedev@hp.com |
| 2658 | S: Supported | 2299 | S: Supported |
| 2659 | F: Documentation/blockdev/cciss.txt | 2300 | F: Documentation/blockdev/cciss.txt |
| @@ -2661,25 +2302,21 @@ F: drivers/block/cciss* | |||
| 2661 | F: include/linux/cciss_ioctl.h | 2302 | F: include/linux/cciss_ioctl.h |
| 2662 | 2303 | ||
| 2663 | HFS FILESYSTEM | 2304 | HFS FILESYSTEM |
| 2664 | P: Roman Zippel | 2305 | M: Roman Zippel <zippel@linux-m68k.org> |
| 2665 | M: zippel@linux-m68k.org | ||
| 2666 | S: Maintained | 2306 | S: Maintained |
| 2667 | F: Documentation/filesystems/hfs.txt | 2307 | F: Documentation/filesystems/hfs.txt |
| 2668 | F: fs/hfs/ | 2308 | F: fs/hfs/ |
| 2669 | 2309 | ||
| 2670 | HGA FRAMEBUFFER DRIVER | 2310 | HGA FRAMEBUFFER DRIVER |
| 2671 | P: Ferenc Bakonyi | 2311 | M: Ferenc Bakonyi <fero@drama.obuda.kando.hu> |
| 2672 | M: fero@drama.obuda.kando.hu | ||
| 2673 | L: linux-nvidia@lists.surfsouth.com | 2312 | L: linux-nvidia@lists.surfsouth.com |
| 2674 | W: http://drama.obuda.kando.hu/~fero/cgi-bin/hgafb.shtml | 2313 | W: http://drama.obuda.kando.hu/~fero/cgi-bin/hgafb.shtml |
| 2675 | S: Maintained | 2314 | S: Maintained |
| 2676 | F: drivers/video/hgafb.c | 2315 | F: drivers/video/hgafb.c |
| 2677 | 2316 | ||
| 2678 | HIBERNATION (aka Software Suspend, aka swsusp) | 2317 | HIBERNATION (aka Software Suspend, aka swsusp) |
| 2679 | P: Pavel Machek | 2318 | M: Pavel Machek <pavel@ucw.cz> |
| 2680 | M: pavel@ucw.cz | 2319 | M: "Rafael J. Wysocki" <rjw@sisk.pl> |
| 2681 | P: Rafael J. Wysocki | ||
| 2682 | M: rjw@sisk.pl | ||
| 2683 | L: linux-pm@lists.linux-foundation.org | 2320 | L: linux-pm@lists.linux-foundation.org |
| 2684 | S: Supported | 2321 | S: Supported |
| 2685 | F: arch/x86/power/ | 2322 | F: arch/x86/power/ |
| @@ -2691,8 +2328,7 @@ F: include/linux/pm.h | |||
| 2691 | F: arch/*/include/asm/suspend*.h | 2328 | F: arch/*/include/asm/suspend*.h |
| 2692 | 2329 | ||
| 2693 | HID CORE LAYER | 2330 | HID CORE LAYER |
| 2694 | P: Jiri Kosina | 2331 | M: Jiri Kosina <jkosina@suse.cz> |
| 2695 | M: jkosina@suse.cz | ||
| 2696 | L: linux-input@vger.kernel.org | 2332 | L: linux-input@vger.kernel.org |
| 2697 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/hid.git | 2333 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/hid.git |
| 2698 | S: Maintained | 2334 | S: Maintained |
| @@ -2700,16 +2336,14 @@ F: drivers/hid/ | |||
| 2700 | F: include/linux/hid* | 2336 | F: include/linux/hid* |
| 2701 | 2337 | ||
| 2702 | HIGH-RESOLUTION TIMERS, CLOCKEVENTS, DYNTICKS | 2338 | HIGH-RESOLUTION TIMERS, CLOCKEVENTS, DYNTICKS |
| 2703 | P: Thomas Gleixner | 2339 | M: Thomas Gleixner <tglx@linutronix.de> |
| 2704 | M: tglx@linutronix.de | ||
| 2705 | S: Maintained | 2340 | S: Maintained |
| 2706 | F: Documentation/timers/ | 2341 | F: Documentation/timers/ |
| 2707 | F: kernel/hrtimer.c | 2342 | F: kernel/hrtimer.c |
| 2708 | F: include/linux/hrtimer.h | 2343 | F: include/linux/hrtimer.h |
| 2709 | 2344 | ||
| 2710 | HIGH-SPEED SCC DRIVER FOR AX.25 | 2345 | HIGH-SPEED SCC DRIVER FOR AX.25 |
| 2711 | P: Klaus Kudielka | 2346 | M: Klaus Kudielka <klaus.kudielka@ieee.org> |
| 2712 | M: klaus.kudielka@ieee.org | ||
| 2713 | L: linux-hams@vger.kernel.org | 2347 | L: linux-hams@vger.kernel.org |
| 2714 | W: http://www.nt.tuwien.ac.at/~kkudielk/Linux/ | 2348 | W: http://www.nt.tuwien.ac.at/~kkudielk/Linux/ |
| 2715 | S: Maintained | 2349 | S: Maintained |
| @@ -2717,16 +2351,14 @@ F: drivers/net/hamradio/dmascc.c | |||
| 2717 | F: drivers/net/hamradio/scc.c | 2351 | F: drivers/net/hamradio/scc.c |
| 2718 | 2352 | ||
| 2719 | HIGHPOINT ROCKETRAID 3xxx RAID DRIVER | 2353 | HIGHPOINT ROCKETRAID 3xxx RAID DRIVER |
| 2720 | P: HighPoint Linux Team | 2354 | M: HighPoint Linux Team <linux@highpoint-tech.com> |
| 2721 | M: linux@highpoint-tech.com | ||
| 2722 | W: http://www.highpoint-tech.com | 2355 | W: http://www.highpoint-tech.com |
| 2723 | S: Supported | 2356 | S: Supported |
| 2724 | F: Documentation/scsi/hptiop.txt | 2357 | F: Documentation/scsi/hptiop.txt |
| 2725 | F: drivers/scsi/hptiop.c | 2358 | F: drivers/scsi/hptiop.c |
| 2726 | 2359 | ||
| 2727 | HIPPI | 2360 | HIPPI |
| 2728 | P: Jes Sorensen | 2361 | M: Jes Sorensen <jes@trained-monkey.org> |
| 2729 | M: jes@trained-monkey.org | ||
| 2730 | L: linux-hippi@sunsite.dk | 2362 | L: linux-hippi@sunsite.dk |
| 2731 | S: Maintained | 2363 | S: Maintained |
| 2732 | F: include/linux/hippidevice.h | 2364 | F: include/linux/hippidevice.h |
| @@ -2734,8 +2366,7 @@ F: include/linux/if_hippi.h | |||
| 2734 | F: net/802/hippi.c | 2366 | F: net/802/hippi.c |
| 2735 | 2367 | ||
| 2736 | HOST AP DRIVER | 2368 | HOST AP DRIVER |
| 2737 | P: Jouni Malinen | 2369 | M: Jouni Malinen <j@w1.fi> |
| 2738 | M: j@w1.fi | ||
| 2739 | L: hostap@shmoo.com (subscribers-only) | 2370 | L: hostap@shmoo.com (subscribers-only) |
| 2740 | L: linux-wireless@vger.kernel.org | 2371 | L: linux-wireless@vger.kernel.org |
| 2741 | W: http://hostap.epitest.fi/ | 2372 | W: http://hostap.epitest.fi/ |
| @@ -2743,82 +2374,69 @@ S: Maintained | |||
| 2743 | F: drivers/net/wireless/hostap/ | 2374 | F: drivers/net/wireless/hostap/ |
| 2744 | 2375 | ||
| 2745 | HP COMPAQ TC1100 TABLET WMI EXTRAS DRIVER | 2376 | HP COMPAQ TC1100 TABLET WMI EXTRAS DRIVER |
| 2746 | P: Carlos Corbacho | 2377 | M: Carlos Corbacho <carlos@strangeworlds.co.uk> |
| 2747 | M: carlos@strangeworlds.co.uk | ||
| 2748 | S: Odd Fixes | 2378 | S: Odd Fixes |
| 2749 | F: drivers/platform/x86/tc1100-wmi.c | 2379 | F: drivers/platform/x86/tc1100-wmi.c |
| 2750 | 2380 | ||
| 2751 | HP100: Driver for HP 10/100 Mbit/s Voice Grade Network Adapter Series | 2381 | HP100: Driver for HP 10/100 Mbit/s Voice Grade Network Adapter Series |
| 2752 | P: Jaroslav Kysela | 2382 | M: Jaroslav Kysela <perex@perex.cz> |
| 2753 | M: perex@perex.cz | ||
| 2754 | S: Maintained | 2383 | S: Maintained |
| 2755 | F: drivers/net/hp100.* | 2384 | F: drivers/net/hp100.* |
| 2756 | 2385 | ||
| 2757 | HPET: High Precision Event Timers driver | 2386 | HPET: High Precision Event Timers driver |
| 2758 | P: Clemens Ladisch | 2387 | M: Clemens Ladisch <clemens@ladisch.de> |
| 2759 | M: clemens@ladisch.de | ||
| 2760 | S: Maintained | 2388 | S: Maintained |
| 2761 | F: Documentation/timers/hpet.txt | 2389 | F: Documentation/timers/hpet.txt |
| 2762 | F: drivers/char/hpet.c | 2390 | F: drivers/char/hpet.c |
| 2763 | F: include/linux/hpet.h | 2391 | F: include/linux/hpet.h |
| 2764 | 2392 | ||
| 2765 | HPET: i386 | 2393 | HPET: i386 |
| 2766 | P: Venkatesh Pallipadi (Venki) | 2394 | M: "Venkatesh Pallipadi (Venki)" <venkatesh.pallipadi@intel.com> |
| 2767 | M: venkatesh.pallipadi@intel.com | ||
| 2768 | S: Maintained | 2395 | S: Maintained |
| 2769 | F: arch/x86/kernel/hpet.c | 2396 | F: arch/x86/kernel/hpet.c |
| 2770 | F: arch/x86/include/asm/hpet.h | 2397 | F: arch/x86/include/asm/hpet.h |
| 2771 | 2398 | ||
| 2772 | HPET: x86_64 | 2399 | HPET: x86_64 |
| 2773 | P: Vojtech Pavlik | 2400 | M: Vojtech Pavlik <vojtech@suse.cz> |
| 2774 | M: vojtech@suse.cz | ||
| 2775 | S: Maintained | 2401 | S: Maintained |
| 2776 | 2402 | ||
| 2777 | HPET: ACPI | 2403 | HPET: ACPI |
| 2778 | P: Bob Picco | 2404 | M: Bob Picco <bob.picco@hp.com> |
| 2779 | M: bob.picco@hp.com | ||
| 2780 | S: Maintained | 2405 | S: Maintained |
| 2781 | F: drivers/char/hpet.c | 2406 | F: drivers/char/hpet.c |
| 2782 | 2407 | ||
| 2783 | HPFS FILESYSTEM | 2408 | HPFS FILESYSTEM |
| 2784 | P: Mikulas Patocka | 2409 | M: Mikulas Patocka <mikulas@artax.karlin.mff.cuni.cz> |
| 2785 | M: mikulas@artax.karlin.mff.cuni.cz | ||
| 2786 | W: http://artax.karlin.mff.cuni.cz/~mikulas/vyplody/hpfs/index-e.cgi | 2410 | W: http://artax.karlin.mff.cuni.cz/~mikulas/vyplody/hpfs/index-e.cgi |
| 2787 | S: Maintained | 2411 | S: Maintained |
| 2788 | F: fs/hpfs/ | 2412 | F: fs/hpfs/ |
| 2789 | 2413 | ||
| 2790 | HSO 3G MODEM DRIVER | 2414 | HSO 3G MODEM DRIVER |
| 2791 | P: Jan Dumon | 2415 | M: Jan Dumon <j.dumon@option.com> |
| 2792 | M: j.dumon@option.com | ||
| 2793 | W: http://www.pharscape.org | 2416 | W: http://www.pharscape.org |
| 2794 | S: Maintained | 2417 | S: Maintained |
| 2795 | F: drivers/net/usb/hso.c | 2418 | F: drivers/net/usb/hso.c |
| 2796 | 2419 | ||
| 2797 | HTCPEN TOUCHSCREEN DRIVER | 2420 | HTCPEN TOUCHSCREEN DRIVER |
| 2798 | P: Pau Oliva Fora | 2421 | M: Pau Oliva Fora <pof@eslack.org> |
| 2799 | M: pof@eslack.org | ||
| 2800 | L: linux-input@vger.kernel.org | 2422 | L: linux-input@vger.kernel.org |
| 2801 | S: Maintained | 2423 | S: Maintained |
| 2802 | F: drivers/input/touchscreen/htcpen.c | 2424 | F: drivers/input/touchscreen/htcpen.c |
| 2803 | 2425 | ||
| 2804 | HUGETLB FILESYSTEM | 2426 | HUGETLB FILESYSTEM |
| 2805 | P: William Irwin | 2427 | M: William Irwin <wli@holomorphy.com> |
| 2806 | M: wli@holomorphy.com | ||
| 2807 | S: Maintained | 2428 | S: Maintained |
| 2808 | F: fs/hugetlbfs/ | 2429 | F: fs/hugetlbfs/ |
| 2809 | 2430 | ||
| 2810 | I2C/SMBUS STUB DRIVER | 2431 | I2C/SMBUS STUB DRIVER |
| 2811 | P: Mark M. Hoffman | 2432 | M: "Mark M. Hoffman" <mhoffman@lightlink.com> |
| 2812 | M: mhoffman@lightlink.com | ||
| 2813 | L: linux-i2c@vger.kernel.org | 2433 | L: linux-i2c@vger.kernel.org |
| 2814 | S: Maintained | 2434 | S: Maintained |
| 2815 | F: drivers/i2c/busses/i2c-stub.c | 2435 | F: drivers/i2c/busses/i2c-stub.c |
| 2816 | 2436 | ||
| 2817 | I2C SUBSYSTEM | 2437 | I2C SUBSYSTEM |
| 2818 | P: Jean Delvare (PC drivers, core) | 2438 | M: "Jean Delvare (PC drivers, core)" <khali@linux-fr.org> |
| 2819 | M: khali@linux-fr.org | 2439 | M: "Ben Dooks (embedded platforms)" <ben-linux@fluff.org> |
| 2820 | P: Ben Dooks (embedded platforms) | ||
| 2821 | M: ben-linux@fluff.org | ||
| 2822 | L: linux-i2c@vger.kernel.org | 2440 | L: linux-i2c@vger.kernel.org |
| 2823 | W: http://i2c.wiki.kernel.org/ | 2441 | W: http://i2c.wiki.kernel.org/ |
| 2824 | T: quilt kernel.org/pub/linux/kernel/people/jdelvare/linux-2.6/jdelvare-i2c/ | 2442 | T: quilt kernel.org/pub/linux/kernel/people/jdelvare/linux-2.6/jdelvare-i2c/ |
| @@ -2830,30 +2448,25 @@ F: include/linux/i2c-dev.h | |||
| 2830 | F: include/linux/i2c-id.h | 2448 | F: include/linux/i2c-id.h |
| 2831 | 2449 | ||
| 2832 | I2C-TINY-USB DRIVER | 2450 | I2C-TINY-USB DRIVER |
| 2833 | P: Till Harbaum | 2451 | M: Till Harbaum <till@harbaum.org> |
| 2834 | M: till@harbaum.org | ||
| 2835 | L: linux-i2c@vger.kernel.org | 2452 | L: linux-i2c@vger.kernel.org |
| 2836 | W: http://www.harbaum.org/till/i2c_tiny_usb | 2453 | W: http://www.harbaum.org/till/i2c_tiny_usb |
| 2837 | S: Maintained | 2454 | S: Maintained |
| 2838 | F: drivers/i2c/busses/i2c-tiny-usb.c | 2455 | F: drivers/i2c/busses/i2c-tiny-usb.c |
| 2839 | 2456 | ||
| 2840 | i386 BOOT CODE | 2457 | i386 BOOT CODE |
| 2841 | P: H. Peter Anvin | 2458 | M: "H. Peter Anvin" <hpa@zytor.com> |
| 2842 | M: hpa@zytor.com | ||
| 2843 | S: Maintained | 2459 | S: Maintained |
| 2844 | F: arch/x86/boot/ | 2460 | F: arch/x86/boot/ |
| 2845 | 2461 | ||
| 2846 | i386 SETUP CODE / CPU ERRATA WORKAROUNDS | 2462 | i386 SETUP CODE / CPU ERRATA WORKAROUNDS |
| 2847 | P: H. Peter Anvin | 2463 | M: "H. Peter Anvin" <hpa@zytor.com> |
| 2848 | M: hpa@zytor.com | ||
| 2849 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/hpa/linux-2.6-x86setup.git | 2464 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/hpa/linux-2.6-x86setup.git |
| 2850 | S: Maintained | 2465 | S: Maintained |
| 2851 | 2466 | ||
| 2852 | IA64 (Itanium) PLATFORM | 2467 | IA64 (Itanium) PLATFORM |
| 2853 | P: Tony Luck | 2468 | M: Tony Luck <tony.luck@intel.com> |
| 2854 | P: Fenghua Yu | 2469 | M: Fenghua Yu <fenghua.yu@intel.com> |
| 2855 | M: tony.luck@intel.com | ||
| 2856 | M: fenghua.yu@intel.com | ||
| 2857 | L: linux-ia64@vger.kernel.org | 2470 | L: linux-ia64@vger.kernel.org |
| 2858 | W: http://www.ia64-linux.org/ | 2471 | W: http://www.ia64-linux.org/ |
| 2859 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/aegl/linux-2.6.git | 2472 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/aegl/linux-2.6.git |
| @@ -2861,29 +2474,25 @@ S: Maintained | |||
| 2861 | F: arch/ia64/ | 2474 | F: arch/ia64/ |
| 2862 | 2475 | ||
| 2863 | IBM MCA SCSI SUBSYSTEM DRIVER | 2476 | IBM MCA SCSI SUBSYSTEM DRIVER |
| 2864 | P: Michael Lang | 2477 | M: Michael Lang <langa2@kph.uni-mainz.de> |
| 2865 | M: langa2@kph.uni-mainz.de | ||
| 2866 | W: http://www.uni-mainz.de/~langm000/linux.html | 2478 | W: http://www.uni-mainz.de/~langm000/linux.html |
| 2867 | S: Maintained | 2479 | S: Maintained |
| 2868 | F: drivers/scsi/ibmmca.c | 2480 | F: drivers/scsi/ibmmca.c |
| 2869 | 2481 | ||
| 2870 | IBM Power Linux RAID adapter | 2482 | IBM Power Linux RAID adapter |
| 2871 | P: Brian King | 2483 | M: Brian King <brking@us.ibm.com> |
| 2872 | M: brking@us.ibm.com | ||
| 2873 | S: Supported | 2484 | S: Supported |
| 2874 | F: drivers/scsi/ipr.* | 2485 | F: drivers/scsi/ipr.* |
| 2875 | 2486 | ||
| 2876 | IBM ServeRAID RAID DRIVER | 2487 | IBM ServeRAID RAID DRIVER |
| 2877 | P: Jack Hammer | 2488 | P: Jack Hammer |
| 2878 | P: Dave Jeffery | 2489 | M: Dave Jeffery <ipslinux@adaptec.com> |
| 2879 | M: ipslinux@adaptec.com | ||
| 2880 | W: http://www.developer.ibm.com/welcome/netfinity/serveraid.html | 2490 | W: http://www.developer.ibm.com/welcome/netfinity/serveraid.html |
| 2881 | S: Supported | 2491 | S: Supported |
| 2882 | F: drivers/scsi/ips.* | 2492 | F: drivers/scsi/ips.* |
| 2883 | 2493 | ||
| 2884 | IDE SUBSYSTEM | 2494 | IDE SUBSYSTEM |
| 2885 | P: David S. Miller | 2495 | M: "David S. Miller" <davem@davemloft.net> |
| 2886 | M: davem@davemloft.net | ||
| 2887 | L: linux-ide@vger.kernel.org | 2496 | L: linux-ide@vger.kernel.org |
| 2888 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/ide-2.6.git | 2497 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/ide-2.6.git |
| 2889 | S: Maintained | 2498 | S: Maintained |
| @@ -2892,25 +2501,21 @@ F: drivers/ide/ | |||
| 2892 | F: include/linux/ide.h | 2501 | F: include/linux/ide.h |
| 2893 | 2502 | ||
| 2894 | IDE/ATAPI DRIVERS | 2503 | IDE/ATAPI DRIVERS |
| 2895 | P: Borislav Petkov | 2504 | M: Borislav Petkov <petkovbb@gmail.com> |
| 2896 | M: petkovbb@gmail.com | ||
| 2897 | L: linux-ide@vger.kernel.org | 2505 | L: linux-ide@vger.kernel.org |
| 2898 | S: Maintained | 2506 | S: Maintained |
| 2899 | F: Documentation/cdrom/ide-cd | 2507 | F: Documentation/cdrom/ide-cd |
| 2900 | F: drivers/ide/ide-cd* | 2508 | F: drivers/ide/ide-cd* |
| 2901 | 2509 | ||
| 2902 | IDLE-I7300 | 2510 | IDLE-I7300 |
| 2903 | P: Andy Henroid | 2511 | M: Andy Henroid <andrew.d.henroid@intel.com> |
| 2904 | M: andrew.d.henroid@intel.com | ||
| 2905 | L: linux-pm@lists.linux-foundation.org | 2512 | L: linux-pm@lists.linux-foundation.org |
| 2906 | S: Supported | 2513 | S: Supported |
| 2907 | F: drivers/idle/i7300_idle.c | 2514 | F: drivers/idle/i7300_idle.c |
| 2908 | 2515 | ||
| 2909 | IEEE 1394 SUBSYSTEM | 2516 | IEEE 1394 SUBSYSTEM |
| 2910 | P: Ben Collins | 2517 | M: Ben Collins <ben.collins@ubuntu.com> |
| 2911 | M: ben.collins@ubuntu.com | 2518 | M: Stefan Richter <stefanr@s5r6.in-berlin.de> |
| 2912 | P: Stefan Richter | ||
| 2913 | M: stefanr@s5r6.in-berlin.de | ||
| 2914 | L: linux1394-devel@lists.sourceforge.net | 2519 | L: linux1394-devel@lists.sourceforge.net |
| 2915 | W: http://www.linux1394.org/ | 2520 | W: http://www.linux1394.org/ |
| 2916 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394-2.6.git | 2521 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394-2.6.git |
| @@ -2918,19 +2523,15 @@ S: Maintained | |||
| 2918 | F: drivers/ieee1394/ | 2523 | F: drivers/ieee1394/ |
| 2919 | 2524 | ||
| 2920 | IEEE 1394 RAW I/O DRIVER | 2525 | IEEE 1394 RAW I/O DRIVER |
| 2921 | P: Dan Dennedy | 2526 | M: Dan Dennedy <dan@dennedy.org> |
| 2922 | M: dan@dennedy.org | 2527 | M: Stefan Richter <stefanr@s5r6.in-berlin.de> |
| 2923 | P: Stefan Richter | ||
| 2924 | M: stefanr@s5r6.in-berlin.de | ||
| 2925 | L: linux1394-devel@lists.sourceforge.net | 2528 | L: linux1394-devel@lists.sourceforge.net |
| 2926 | S: Maintained | 2529 | S: Maintained |
| 2927 | F: drivers/ieee1394/raw1394* | 2530 | F: drivers/ieee1394/raw1394* |
| 2928 | 2531 | ||
| 2929 | IEEE 802.15.4 SUBSYSTEM | 2532 | IEEE 802.15.4 SUBSYSTEM |
| 2930 | P: Dmitry Eremin-Solenikov | 2533 | M: Dmitry Eremin-Solenikov <dbaryshkov@gmail.com> |
| 2931 | M: dbaryshkov@gmail.com | 2534 | M: Sergey Lapin <slapin@ossfans.org> |
| 2932 | P: Sergey Lapin | ||
| 2933 | M: slapin@ossfans.org | ||
| 2934 | L: linux-zigbee-devel@lists.sourceforge.net (moderated for non-subscribers) | 2535 | L: linux-zigbee-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 2935 | W: http://apps.sourceforge.net/trac/linux-zigbee | 2536 | W: http://apps.sourceforge.net/trac/linux-zigbee |
| 2936 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/lowpan/lowpan.git | 2537 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/lowpan/lowpan.git |
| @@ -2939,8 +2540,7 @@ F: net/ieee802154/ | |||
| 2939 | F: drivers/ieee802154/ | 2540 | F: drivers/ieee802154/ |
| 2940 | 2541 | ||
| 2941 | INTEGRITY MEASUREMENT ARCHITECTURE (IMA) | 2542 | INTEGRITY MEASUREMENT ARCHITECTURE (IMA) |
| 2942 | P: Mimi Zohar | 2543 | M: Mimi Zohar <zohar@us.ibm.com> |
| 2943 | M: zohar@us.ibm.com | ||
| 2944 | S: Supported | 2544 | S: Supported |
| 2945 | F: security/integrity/ima/ | 2545 | F: security/integrity/ima/ |
| 2946 | 2546 | ||
| @@ -2950,12 +2550,9 @@ S: Orphan | |||
| 2950 | F: drivers/video/imsttfb.c | 2550 | F: drivers/video/imsttfb.c |
| 2951 | 2551 | ||
| 2952 | INFINIBAND SUBSYSTEM | 2552 | INFINIBAND SUBSYSTEM |
| 2953 | P: Roland Dreier | 2553 | M: Roland Dreier <rolandd@cisco.com> |
| 2954 | M: rolandd@cisco.com | 2554 | M: Sean Hefty <sean.hefty@intel.com> |
| 2955 | P: Sean Hefty | 2555 | M: Hal Rosenstock <hal.rosenstock@gmail.com> |
| 2956 | M: sean.hefty@intel.com | ||
| 2957 | P: Hal Rosenstock | ||
| 2958 | M: hal.rosenstock@gmail.com | ||
| 2959 | L: general@lists.openfabrics.org (moderated for non-subscribers) | 2556 | L: general@lists.openfabrics.org (moderated for non-subscribers) |
| 2960 | W: http://www.openib.org/ | 2557 | W: http://www.openib.org/ |
| 2961 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/roland/infiniband.git | 2558 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/roland/infiniband.git |
| @@ -2965,65 +2562,55 @@ F: drivers/infiniband/ | |||
| 2965 | F: include/linux/if_infiniband.h | 2562 | F: include/linux/if_infiniband.h |
| 2966 | 2563 | ||
| 2967 | INOTIFY | 2564 | INOTIFY |
| 2968 | P: John McCutchan | 2565 | M: John McCutchan <john@johnmccutchan.com> |
| 2969 | M: john@johnmccutchan.com | 2566 | M: Robert Love <rlove@rlove.org> |
| 2970 | P: Robert Love | 2567 | M: Eric Paris <eparis@parisplace.org> |
| 2971 | M: rlove@rlove.org | ||
| 2972 | P: Eric Paris | ||
| 2973 | M: eparis@parisplace.org | ||
| 2974 | S: Maintained | 2568 | S: Maintained |
| 2975 | F: Documentation/filesystems/inotify.txt | 2569 | F: Documentation/filesystems/inotify.txt |
| 2976 | F: fs/notify/inotify/ | 2570 | F: fs/notify/inotify/ |
| 2977 | F: include/linux/inotify.h | 2571 | F: include/linux/inotify.h |
| 2978 | 2572 | ||
| 2979 | INPUT (KEYBOARD, MOUSE, JOYSTICK, TOUCHSCREEN) DRIVERS | 2573 | INPUT (KEYBOARD, MOUSE, JOYSTICK, TOUCHSCREEN) DRIVERS |
| 2980 | P: Dmitry Torokhov | 2574 | M: Dmitry Torokhov <dmitry.torokhov@gmail.com> |
| 2981 | M: dmitry.torokhov@gmail.com | 2575 | M: Dmitry Torokhov <dtor@mail.ru> |
| 2982 | M: dtor@mail.ru | ||
| 2983 | L: linux-input@vger.kernel.org | 2576 | L: linux-input@vger.kernel.org |
| 2984 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input.git | 2577 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input.git |
| 2985 | S: Maintained | 2578 | S: Maintained |
| 2986 | F: drivers/input/ | 2579 | F: drivers/input/ |
| 2987 | 2580 | ||
| 2988 | INTEL FRAMEBUFFER DRIVER (excluding 810 and 815) | 2581 | INTEL FRAMEBUFFER DRIVER (excluding 810 and 815) |
| 2989 | P: Sylvain Meyer | 2582 | M: Sylvain Meyer <sylvain.meyer@worldonline.fr> |
| 2990 | M: sylvain.meyer@worldonline.fr | ||
| 2991 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) | 2583 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 2992 | S: Maintained | 2584 | S: Maintained |
| 2993 | F: Documentation/fb/intelfb.txt | 2585 | F: Documentation/fb/intelfb.txt |
| 2994 | F: drivers/video/intelfb/ | 2586 | F: drivers/video/intelfb/ |
| 2995 | 2587 | ||
| 2996 | INTEL 810/815 FRAMEBUFFER DRIVER | 2588 | INTEL 810/815 FRAMEBUFFER DRIVER |
| 2997 | P: Antonino Daplas | 2589 | M: Antonino Daplas <adaplas@gmail.com> |
| 2998 | M: adaplas@gmail.com | ||
| 2999 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) | 2590 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 3000 | S: Maintained | 2591 | S: Maintained |
| 3001 | F: drivers/video/i810/ | 2592 | F: drivers/video/i810/ |
| 3002 | 2593 | ||
| 3003 | INTEL MENLOW THERMAL DRIVER | 2594 | INTEL MENLOW THERMAL DRIVER |
| 3004 | P: Sujith Thomas | 2595 | M: Sujith Thomas <sujith.thomas@intel.com> |
| 3005 | M: sujith.thomas@intel.com | ||
| 3006 | L: linux-acpi@vger.kernel.org | 2596 | L: linux-acpi@vger.kernel.org |
| 3007 | W: http://www.lesswatts.org/projects/acpi/ | 2597 | W: http://www.lesswatts.org/projects/acpi/ |
| 3008 | S: Supported | 2598 | S: Supported |
| 3009 | F: drivers/platform/x86/intel_menlow.c | 2599 | F: drivers/platform/x86/intel_menlow.c |
| 3010 | 2600 | ||
| 3011 | INTEL IA32 MICROCODE UPDATE SUPPORT | 2601 | INTEL IA32 MICROCODE UPDATE SUPPORT |
| 3012 | P: Tigran Aivazian | 2602 | M: Tigran Aivazian <tigran@aivazian.fsnet.co.uk> |
| 3013 | M: tigran@aivazian.fsnet.co.uk | ||
| 3014 | S: Maintained | 2603 | S: Maintained |
| 3015 | F: arch/x86/kernel/microcode_core.c | 2604 | F: arch/x86/kernel/microcode_core.c |
| 3016 | F: arch/x86/kernel/microcode_intel.c | 2605 | F: arch/x86/kernel/microcode_intel.c |
| 3017 | 2606 | ||
| 3018 | INTEL I/OAT DMA DRIVER | 2607 | INTEL I/OAT DMA DRIVER |
| 3019 | P: Maciej Sosnowski | 2608 | M: Maciej Sosnowski <maciej.sosnowski@intel.com> |
| 3020 | M: maciej.sosnowski@intel.com | ||
| 3021 | S: Supported | 2609 | S: Supported |
| 3022 | F: drivers/dma/ioat* | 2610 | F: drivers/dma/ioat* |
| 3023 | 2611 | ||
| 3024 | INTEL IOMMU (VT-d) | 2612 | INTEL IOMMU (VT-d) |
| 3025 | P: David Woodhouse | 2613 | M: David Woodhouse <dwmw2@infradead.org> |
| 3026 | M: dwmw2@infradead.org | ||
| 3027 | L: iommu@lists.linux-foundation.org | 2614 | L: iommu@lists.linux-foundation.org |
| 3028 | T: git git://git.infradead.org/iommu-2.6.git | 2615 | T: git git://git.infradead.org/iommu-2.6.git |
| 3029 | S: Supported | 2616 | S: Supported |
| @@ -3031,14 +2618,12 @@ F: drivers/pci/intel-iommu.c | |||
| 3031 | F: include/linux/intel-iommu.h | 2618 | F: include/linux/intel-iommu.h |
| 3032 | 2619 | ||
| 3033 | INTEL IOP-ADMA DMA DRIVER | 2620 | INTEL IOP-ADMA DMA DRIVER |
| 3034 | P: Dan Williams | 2621 | M: Dan Williams <dan.j.williams@intel.com> |
| 3035 | M: dan.j.williams@intel.com | ||
| 3036 | S: Supported | 2622 | S: Supported |
| 3037 | F: drivers/dma/iop-adma.c | 2623 | F: drivers/dma/iop-adma.c |
| 3038 | 2624 | ||
| 3039 | INTEL IXP4XX QMGR, NPE, ETHERNET and HSS SUPPORT | 2625 | INTEL IXP4XX QMGR, NPE, ETHERNET and HSS SUPPORT |
| 3040 | P: Krzysztof Halasa | 2626 | M: Krzysztof Halasa <khc@pm.waw.pl> |
| 3041 | M: khc@pm.waw.pl | ||
| 3042 | S: Maintained | 2627 | S: Maintained |
| 3043 | F: arch/arm/mach-ixp4xx/include/mach/qmgr.h | 2628 | F: arch/arm/mach-ixp4xx/include/mach/qmgr.h |
| 3044 | F: arch/arm/mach-ixp4xx/include/mach/npe.h | 2629 | F: arch/arm/mach-ixp4xx/include/mach/npe.h |
| @@ -3048,29 +2633,22 @@ F: drivers/net/arm/ixp4xx_eth.c | |||
| 3048 | F: drivers/net/wan/ixp4xx_hss.c | 2633 | F: drivers/net/wan/ixp4xx_hss.c |
| 3049 | 2634 | ||
| 3050 | INTEL IXP4XX RANDOM NUMBER GENERATOR SUPPORT | 2635 | INTEL IXP4XX RANDOM NUMBER GENERATOR SUPPORT |
| 3051 | P: Deepak Saxena | 2636 | M: Deepak Saxena <dsaxena@plexity.net> |
| 3052 | M: dsaxena@plexity.net | ||
| 3053 | S: Maintained | 2637 | S: Maintained |
| 3054 | F: drivers/char/hw_random/ixp4xx-rng.c | 2638 | F: drivers/char/hw_random/ixp4xx-rng.c |
| 3055 | 2639 | ||
| 3056 | INTEL IXP2000 ETHERNET DRIVER | 2640 | INTEL IXP2000 ETHERNET DRIVER |
| 3057 | P: Lennert Buytenhek | 2641 | M: Lennert Buytenhek <kernel@wantstofly.org> |
| 3058 | M: kernel@wantstofly.org | ||
| 3059 | L: netdev@vger.kernel.org | 2642 | L: netdev@vger.kernel.org |
| 3060 | S: Maintained | 2643 | S: Maintained |
| 3061 | F: drivers/net/ixp2000/ | 2644 | F: drivers/net/ixp2000/ |
| 3062 | 2645 | ||
| 3063 | INTEL ETHERNET DRIVERS (e100/e1000/e1000e/igb/ixgb/ixgbe) | 2646 | INTEL ETHERNET DRIVERS (e100/e1000/e1000e/igb/ixgb/ixgbe) |
| 3064 | P: Jeff Kirsher | 2647 | M: Jeff Kirsher <jeffrey.t.kirsher@intel.com> |
| 3065 | M: jeffrey.t.kirsher@intel.com | 2648 | M: Jesse Brandeburg <jesse.brandeburg@intel.com> |
| 3066 | P: Jesse Brandeburg | 2649 | M: Bruce Allan <bruce.w.allan@intel.com> |
| 3067 | M: jesse.brandeburg@intel.com | 2650 | M: PJ Waskiewicz <peter.p.waskiewicz.jr@intel.com> |
| 3068 | P: Bruce Allan | 2651 | M: John Ronciak <john.ronciak@intel.com> |
| 3069 | M: bruce.w.allan@intel.com | ||
| 3070 | P: PJ Waskiewicz | ||
| 3071 | M: peter.p.waskiewicz.jr@intel.com | ||
| 3072 | P: John Ronciak | ||
| 3073 | M: john.ronciak@intel.com | ||
| 3074 | L: e1000-devel@lists.sourceforge.net | 2652 | L: e1000-devel@lists.sourceforge.net |
| 3075 | W: http://e1000.sourceforge.net/ | 2653 | W: http://e1000.sourceforge.net/ |
| 3076 | S: Supported | 2654 | S: Supported |
| @@ -3082,12 +2660,9 @@ F: drivers/net/ixgb/ | |||
| 3082 | F: drivers/net/ixgbe/ | 2660 | F: drivers/net/ixgbe/ |
| 3083 | 2661 | ||
| 3084 | INTEL PRO/WIRELESS 2100 NETWORK CONNECTION SUPPORT | 2662 | INTEL PRO/WIRELESS 2100 NETWORK CONNECTION SUPPORT |
| 3085 | P: Zhu Yi | 2663 | M: Zhu Yi <yi.zhu@intel.com> |
| 3086 | M: yi.zhu@intel.com | 2664 | M: James Ketrenos <jketreno@linux.intel.com> |
| 3087 | P: James Ketrenos | 2665 | M: Reinette Chatre <reinette.chatre@intel.com> |
| 3088 | M: jketreno@linux.intel.com | ||
| 3089 | P: Reinette Chatre | ||
| 3090 | M: reinette.chatre@intel.com | ||
| 3091 | L: linux-wireless@vger.kernel.org | 2666 | L: linux-wireless@vger.kernel.org |
| 3092 | L: ipw2100-devel@lists.sourceforge.net | 2667 | L: ipw2100-devel@lists.sourceforge.net |
| 3093 | W: http://lists.sourceforge.net/mailman/listinfo/ipw2100-devel | 2668 | W: http://lists.sourceforge.net/mailman/listinfo/ipw2100-devel |
| @@ -3097,12 +2672,9 @@ F: Documentation/networking/README.ipw2100 | |||
| 3097 | F: drivers/net/wireless/ipw2x00/ipw2100.* | 2672 | F: drivers/net/wireless/ipw2x00/ipw2100.* |
| 3098 | 2673 | ||
| 3099 | INTEL PRO/WIRELESS 2915ABG NETWORK CONNECTION SUPPORT | 2674 | INTEL PRO/WIRELESS 2915ABG NETWORK CONNECTION SUPPORT |
| 3100 | P: Zhu Yi | 2675 | M: Zhu Yi <yi.zhu@intel.com> |
| 3101 | M: yi.zhu@intel.com | 2676 | M: James Ketrenos <jketreno@linux.intel.com> |
| 3102 | P: James Ketrenos | 2677 | M: Reinette Chatre <reinette.chatre@intel.com> |
| 3103 | M: jketreno@linux.intel.com | ||
| 3104 | P: Reinette Chatre | ||
| 3105 | M: reinette.chatre@intel.com | ||
| 3106 | L: linux-wireless@vger.kernel.org | 2678 | L: linux-wireless@vger.kernel.org |
| 3107 | L: ipw2100-devel@lists.sourceforge.net | 2679 | L: ipw2100-devel@lists.sourceforge.net |
| 3108 | W: http://lists.sourceforge.net/mailman/listinfo/ipw2100-devel | 2680 | W: http://lists.sourceforge.net/mailman/listinfo/ipw2100-devel |
| @@ -3112,8 +2684,7 @@ F: Documentation/networking/README.ipw2200 | |||
| 3112 | F: drivers/net/wireless/ipw2x00/ipw2200.* | 2684 | F: drivers/net/wireless/ipw2x00/ipw2200.* |
| 3113 | 2685 | ||
| 3114 | INTEL WIRELESS WIMAX CONNECTION 2400 | 2686 | INTEL WIRELESS WIMAX CONNECTION 2400 |
| 3115 | P: Inaky Perez-Gonzalez | 2687 | M: Inaky Perez-Gonzalez <inaky.perez-gonzalez@intel.com> |
| 3116 | M: inaky.perez-gonzalez@intel.com | ||
| 3117 | M: linux-wimax@intel.com | 2688 | M: linux-wimax@intel.com |
| 3118 | L: wimax@linuxwimax.org | 2689 | L: wimax@linuxwimax.org |
| 3119 | S: Supported | 2690 | S: Supported |
| @@ -3123,10 +2694,8 @@ F: drivers/net/wimax/i2400m/ | |||
| 3123 | F: include/linux/wimax/i2400m.h | 2694 | F: include/linux/wimax/i2400m.h |
| 3124 | 2695 | ||
| 3125 | INTEL WIRELESS WIFI LINK (iwlwifi) | 2696 | INTEL WIRELESS WIFI LINK (iwlwifi) |
| 3126 | P: Zhu Yi | 2697 | M: Zhu Yi <yi.zhu@intel.com> |
| 3127 | M: yi.zhu@intel.com | 2698 | M: Reinette Chatre <reinette.chatre@intel.com> |
| 3128 | P: Reinette Chatre | ||
| 3129 | M: reinette.chatre@intel.com | ||
| 3130 | L: linux-wireless@vger.kernel.org | 2699 | L: linux-wireless@vger.kernel.org |
| 3131 | L: ipw3945-devel@lists.sourceforge.net | 2700 | L: ipw3945-devel@lists.sourceforge.net |
| 3132 | W: http://intellinuxwireless.org | 2701 | W: http://intellinuxwireless.org |
| @@ -3135,47 +2704,39 @@ S: Supported | |||
| 3135 | F: drivers/net/wireless/iwlwifi/ | 2704 | F: drivers/net/wireless/iwlwifi/ |
| 3136 | 2705 | ||
| 3137 | IOC3 ETHERNET DRIVER | 2706 | IOC3 ETHERNET DRIVER |
| 3138 | P: Ralf Baechle | 2707 | M: Ralf Baechle <ralf@linux-mips.org> |
| 3139 | M: ralf@linux-mips.org | ||
| 3140 | L: linux-mips@linux-mips.org | 2708 | L: linux-mips@linux-mips.org |
| 3141 | S: Maintained | 2709 | S: Maintained |
| 3142 | F: drivers/net/ioc3-eth.c | 2710 | F: drivers/net/ioc3-eth.c |
| 3143 | 2711 | ||
| 3144 | IOC3 SERIAL DRIVER | 2712 | IOC3 SERIAL DRIVER |
| 3145 | P: Pat Gefre | 2713 | M: Pat Gefre <pfg@sgi.com> |
| 3146 | M: pfg@sgi.com | ||
| 3147 | L: linux-mips@linux-mips.org | 2714 | L: linux-mips@linux-mips.org |
| 3148 | S: Maintained | 2715 | S: Maintained |
| 3149 | F: drivers/serial/ioc3_serial.c | 2716 | F: drivers/serial/ioc3_serial.c |
| 3150 | 2717 | ||
| 3151 | IP MASQUERADING | 2718 | IP MASQUERADING |
| 3152 | P: Juanjo Ciarlante | 2719 | M: Juanjo Ciarlante <jjciarla@raiz.uncu.edu.ar> |
| 3153 | M: jjciarla@raiz.uncu.edu.ar | ||
| 3154 | S: Maintained | 2720 | S: Maintained |
| 3155 | F: net/ipv4/netfilter/ipt_MASQUERADE.c | 2721 | F: net/ipv4/netfilter/ipt_MASQUERADE.c |
| 3156 | 2722 | ||
| 3157 | IP1000A 10/100/1000 GIGABIT ETHERNET DRIVER | 2723 | IP1000A 10/100/1000 GIGABIT ETHERNET DRIVER |
| 3158 | P: Francois Romieu | 2724 | M: Francois Romieu <romieu@fr.zoreil.com> |
| 3159 | M: romieu@fr.zoreil.com | 2725 | M: Sorbica Shieh <sorbica@icplus.com.tw> |
| 3160 | P: Sorbica Shieh | 2726 | M: Jesse Huang <jesse@icplus.com.tw> |
| 3161 | M: sorbica@icplus.com.tw | ||
| 3162 | P: Jesse Huang | ||
| 3163 | M: jesse@icplus.com.tw | ||
| 3164 | L: netdev@vger.kernel.org | 2727 | L: netdev@vger.kernel.org |
| 3165 | S: Maintained | 2728 | S: Maintained |
| 3166 | F: drivers/net/ipg.c | 2729 | F: drivers/net/ipg.c |
| 3167 | 2730 | ||
| 3168 | IPATH DRIVER | 2731 | IPATH DRIVER |
| 3169 | P: Ralph Campbell | 2732 | M: Ralph Campbell <infinipath@qlogic.com> |
| 3170 | M: infinipath@qlogic.com | ||
| 3171 | L: general@lists.openfabrics.org | 2733 | L: general@lists.openfabrics.org |
| 3172 | T: git git://git.qlogic.com/ipath-linux-2.6 | 2734 | T: git git://git.qlogic.com/ipath-linux-2.6 |
| 3173 | S: Supported | 2735 | S: Supported |
| 3174 | F: drivers/infiniband/hw/ipath/ | 2736 | F: drivers/infiniband/hw/ipath/ |
| 3175 | 2737 | ||
| 3176 | IPMI SUBSYSTEM | 2738 | IPMI SUBSYSTEM |
| 3177 | P: Corey Minyard | 2739 | M: Corey Minyard <minyard@acm.org> |
| 3178 | M: minyard@acm.org | ||
| 3179 | L: openipmi-developer@lists.sourceforge.net | 2740 | L: openipmi-developer@lists.sourceforge.net |
| 3180 | W: http://openipmi.sourceforge.net/ | 2741 | W: http://openipmi.sourceforge.net/ |
| 3181 | S: Supported | 2742 | S: Supported |
| @@ -3184,20 +2745,16 @@ F: drivers/char/ipmi/ | |||
| 3184 | F: include/linux/ipmi* | 2745 | F: include/linux/ipmi* |
| 3185 | 2746 | ||
| 3186 | IPS SCSI RAID DRIVER | 2747 | IPS SCSI RAID DRIVER |
| 3187 | P: Adaptec OEM Raid Solutions | 2748 | M: Adaptec OEM Raid Solutions <aacraid@adaptec.com> |
| 3188 | M: aacraid@adaptec.com | ||
| 3189 | L: linux-scsi@vger.kernel.org | 2749 | L: linux-scsi@vger.kernel.org |
| 3190 | W: http://www.adaptec.com/ | 2750 | W: http://www.adaptec.com/ |
| 3191 | S: Maintained | 2751 | S: Maintained |
| 3192 | F: drivers/scsi/ips* | 2752 | F: drivers/scsi/ips* |
| 3193 | 2753 | ||
| 3194 | IPVS | 2754 | IPVS |
| 3195 | P: Wensong Zhang | 2755 | M: Wensong Zhang <wensong@linux-vs.org> |
| 3196 | M: wensong@linux-vs.org | 2756 | M: Simon Horman <horms@verge.net.au> |
| 3197 | P: Simon Horman | 2757 | M: Julian Anastasov <ja@ssi.bg> |
| 3198 | M: horms@verge.net.au | ||
| 3199 | P: Julian Anastasov | ||
| 3200 | M: ja@ssi.bg | ||
| 3201 | L: netdev@vger.kernel.org | 2758 | L: netdev@vger.kernel.org |
| 3202 | L: lvs-devel@vger.kernel.org | 2759 | L: lvs-devel@vger.kernel.org |
| 3203 | S: Maintained | 2760 | S: Maintained |
| @@ -3205,17 +2762,14 @@ F: Documentation/networking/ipvs-sysctl.txt | |||
| 3205 | F: net/netfilter/ipvs/ | 2762 | F: net/netfilter/ipvs/ |
| 3206 | 2763 | ||
| 3207 | IPWIRELESS DRIVER | 2764 | IPWIRELESS DRIVER |
| 3208 | P: Jiri Kosina | 2765 | M: Jiri Kosina <jkosina@suse.cz> |
| 3209 | M: jkosina@suse.cz | 2766 | M: David Sterba <dsterba@suse.cz> |
| 3210 | P: David Sterba | ||
| 3211 | M: dsterba@suse.cz | ||
| 3212 | S: Maintained | 2767 | S: Maintained |
| 3213 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/ipwireless_cs.git | 2768 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/ipwireless_cs.git |
| 3214 | F: drivers/char/pcmcia/ipwireless/ | 2769 | F: drivers/char/pcmcia/ipwireless/ |
| 3215 | 2770 | ||
| 3216 | IPX NETWORK LAYER | 2771 | IPX NETWORK LAYER |
| 3217 | P: Arnaldo Carvalho de Melo | 2772 | M: Arnaldo Carvalho de Melo <acme@ghostprotocols.net> |
| 3218 | M: acme@ghostprotocols.net | ||
| 3219 | L: netdev@vger.kernel.org | 2773 | L: netdev@vger.kernel.org |
| 3220 | S: Maintained | 2774 | S: Maintained |
| 3221 | F: include/linux/ipx.h | 2775 | F: include/linux/ipx.h |
| @@ -3223,8 +2777,7 @@ F: include/net/ipx.h | |||
| 3223 | F: net/ipx/ | 2777 | F: net/ipx/ |
| 3224 | 2778 | ||
| 3225 | IRDA SUBSYSTEM | 2779 | IRDA SUBSYSTEM |
| 3226 | P: Samuel Ortiz | 2780 | M: Samuel Ortiz <samuel@sortiz.org> |
| 3227 | M: samuel@sortiz.org | ||
| 3228 | L: irda-users@lists.sourceforge.net (subscribers-only) | 2781 | L: irda-users@lists.sourceforge.net (subscribers-only) |
| 3229 | W: http://irda.sourceforge.net/ | 2782 | W: http://irda.sourceforge.net/ |
| 3230 | S: Maintained | 2783 | S: Maintained |
| @@ -3235,16 +2788,14 @@ F: include/net/irda/ | |||
| 3235 | F: net/irda/ | 2788 | F: net/irda/ |
| 3236 | 2789 | ||
| 3237 | ISAPNP | 2790 | ISAPNP |
| 3238 | P: Jaroslav Kysela | 2791 | M: Jaroslav Kysela <perex@perex.cz> |
| 3239 | M: perex@perex.cz | ||
| 3240 | S: Maintained | 2792 | S: Maintained |
| 3241 | F: Documentation/isapnp.txt | 2793 | F: Documentation/isapnp.txt |
| 3242 | F: drivers/pnp/isapnp/ | 2794 | F: drivers/pnp/isapnp/ |
| 3243 | F: include/linux/isapnp.h | 2795 | F: include/linux/isapnp.h |
| 3244 | 2796 | ||
| 3245 | ISCSI | 2797 | ISCSI |
| 3246 | P: Mike Christie | 2798 | M: Mike Christie <michaelc@cs.wisc.edu> |
| 3247 | M: michaelc@cs.wisc.edu | ||
| 3248 | L: open-iscsi@googlegroups.com | 2799 | L: open-iscsi@googlegroups.com |
| 3249 | W: www.open-iscsi.org | 2800 | W: www.open-iscsi.org |
| 3250 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mnc/linux-2.6-iscsi.git | 2801 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mnc/linux-2.6-iscsi.git |
| @@ -3253,8 +2804,7 @@ F: drivers/scsi/*iscsi* | |||
| 3253 | F: include/scsi/*iscsi* | 2804 | F: include/scsi/*iscsi* |
| 3254 | 2805 | ||
| 3255 | ISDN SUBSYSTEM | 2806 | ISDN SUBSYSTEM |
| 3256 | P: Karsten Keil | 2807 | M: Karsten Keil <isdn@linux-pingi.de> |
| 3257 | M: isdn@linux-pingi.de | ||
| 3258 | L: isdn4linux@listserv.isdn4linux.de (subscribers-only) | 2808 | L: isdn4linux@listserv.isdn4linux.de (subscribers-only) |
| 3259 | W: http://www.isdn4linux.de | 2809 | W: http://www.isdn4linux.de |
| 3260 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/kkeil/isdn-2.6.git | 2810 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/kkeil/isdn-2.6.git |
| @@ -3265,18 +2815,15 @@ F: include/linux/isdn.h | |||
| 3265 | F: include/linux/isdn/ | 2815 | F: include/linux/isdn/ |
| 3266 | 2816 | ||
| 3267 | ISDN SUBSYSTEM (Eicon active card driver) | 2817 | ISDN SUBSYSTEM (Eicon active card driver) |
| 3268 | P: Armin Schindler | 2818 | M: Armin Schindler <mac@melware.de> |
| 3269 | M: mac@melware.de | ||
| 3270 | L: isdn4linux@listserv.isdn4linux.de (subscribers-only) | 2819 | L: isdn4linux@listserv.isdn4linux.de (subscribers-only) |
| 3271 | W: http://www.melware.de | 2820 | W: http://www.melware.de |
| 3272 | S: Maintained | 2821 | S: Maintained |
| 3273 | F: drivers/isdn/hardware/eicon/ | 2822 | F: drivers/isdn/hardware/eicon/ |
| 3274 | 2823 | ||
| 3275 | IVTV VIDEO4LINUX DRIVER | 2824 | IVTV VIDEO4LINUX DRIVER |
| 3276 | P: Hans Verkuil | 2825 | M: Hans Verkuil <hverkuil@xs4all.nl> |
| 3277 | M: hverkuil@xs4all.nl | ||
| 3278 | L: ivtv-devel@ivtvdriver.org | 2826 | L: ivtv-devel@ivtvdriver.org |
| 3279 | L: ivtv-users@ivtvdriver.org | ||
| 3280 | L: linux-media@vger.kernel.org | 2827 | L: linux-media@vger.kernel.org |
| 3281 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 2828 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| 3282 | W: http://www.ivtvdriver.org | 2829 | W: http://www.ivtvdriver.org |
| @@ -3286,8 +2833,7 @@ F: drivers/media/video/ivtv/ | |||
| 3286 | F: include/linux/ivtv* | 2833 | F: include/linux/ivtv* |
| 3287 | 2834 | ||
| 3288 | JFS FILESYSTEM | 2835 | JFS FILESYSTEM |
| 3289 | P: Dave Kleikamp | 2836 | M: Dave Kleikamp <shaggy@linux.vnet.ibm.com> |
| 3290 | M: shaggy@linux.vnet.ibm.com | ||
| 3291 | L: jfs-discussion@lists.sourceforge.net | 2837 | L: jfs-discussion@lists.sourceforge.net |
| 3292 | W: http://jfs.sourceforge.net/ | 2838 | W: http://jfs.sourceforge.net/ |
| 3293 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/shaggy/jfs-2.6.git | 2839 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/shaggy/jfs-2.6.git |
| @@ -3296,15 +2842,13 @@ F: Documentation/filesystems/jfs.txt | |||
| 3296 | F: fs/jfs/ | 2842 | F: fs/jfs/ |
| 3297 | 2843 | ||
| 3298 | JME NETWORK DRIVER | 2844 | JME NETWORK DRIVER |
| 3299 | P: Guo-Fu Tseng | 2845 | M: Guo-Fu Tseng <cooldavid@cooldavid.org> |
| 3300 | M: cooldavid@cooldavid.org | ||
| 3301 | L: netdev@vger.kernel.org | 2846 | L: netdev@vger.kernel.org |
| 3302 | S: Maintained | 2847 | S: Maintained |
| 3303 | F: drivers/net/jme.* | 2848 | F: drivers/net/jme.* |
| 3304 | 2849 | ||
| 3305 | JOURNALLING FLASH FILE SYSTEM V2 (JFFS2) | 2850 | JOURNALLING FLASH FILE SYSTEM V2 (JFFS2) |
| 3306 | P: David Woodhouse | 2851 | M: David Woodhouse <dwmw2@infradead.org> |
| 3307 | M: dwmw2@infradead.org | ||
| 3308 | L: linux-mtd@lists.infradead.org | 2852 | L: linux-mtd@lists.infradead.org |
| 3309 | W: http://www.linux-mtd.infradead.org/doc/jffs2.html | 2853 | W: http://www.linux-mtd.infradead.org/doc/jffs2.html |
| 3310 | S: Maintained | 2854 | S: Maintained |
| @@ -3312,10 +2856,8 @@ F: fs/jffs2/ | |||
| 3312 | F: include/linux/jffs2.h | 2856 | F: include/linux/jffs2.h |
| 3313 | 2857 | ||
| 3314 | JOURNALLING LAYER FOR BLOCK DEVICES (JBD) | 2858 | JOURNALLING LAYER FOR BLOCK DEVICES (JBD) |
| 3315 | P: Stephen Tweedie | 2859 | M: Stephen Tweedie <sct@redhat.com> |
| 3316 | M: sct@redhat.com | 2860 | M: Andrew Morton <akpm@linux-foundation.org> |
| 3317 | P: Andrew Morton | ||
| 3318 | M: akpm@linux-foundation.org | ||
| 3319 | L: linux-ext4@vger.kernel.org | 2861 | L: linux-ext4@vger.kernel.org |
| 3320 | S: Maintained | 2862 | S: Maintained |
| 3321 | F: fs/jbd*/ | 2863 | F: fs/jbd*/ |
| @@ -3323,48 +2865,41 @@ F: include/linux/ext*jbd*.h | |||
| 3323 | F: include/linux/jbd*.h | 2865 | F: include/linux/jbd*.h |
| 3324 | 2866 | ||
| 3325 | K8TEMP HARDWARE MONITORING DRIVER | 2867 | K8TEMP HARDWARE MONITORING DRIVER |
| 3326 | P: Rudolf Marek | 2868 | M: Rudolf Marek <r.marek@assembler.cz> |
| 3327 | M: r.marek@assembler.cz | ||
| 3328 | L: lm-sensors@lm-sensors.org | 2869 | L: lm-sensors@lm-sensors.org |
| 3329 | S: Maintained | 2870 | S: Maintained |
| 3330 | F: Documentation/hwmon/k8temp | 2871 | F: Documentation/hwmon/k8temp |
| 3331 | F: drivers/hwmon/k8temp.c | 2872 | F: drivers/hwmon/k8temp.c |
| 3332 | 2873 | ||
| 3333 | KCONFIG | 2874 | KCONFIG |
| 3334 | P: Roman Zippel | 2875 | M: Roman Zippel <zippel@linux-m68k.org> |
| 3335 | M: zippel@linux-m68k.org | ||
| 3336 | L: linux-kbuild@vger.kernel.org | 2876 | L: linux-kbuild@vger.kernel.org |
| 3337 | S: Maintained | 2877 | S: Maintained |
| 3338 | F: Documentation/kbuild/kconfig-language.txt | 2878 | F: Documentation/kbuild/kconfig-language.txt |
| 3339 | F: scripts/kconfig/ | 2879 | F: scripts/kconfig/ |
| 3340 | 2880 | ||
| 3341 | KDUMP | 2881 | KDUMP |
| 3342 | P: Vivek Goyal | 2882 | M: Vivek Goyal <vgoyal@redhat.com> |
| 3343 | M: vgoyal@redhat.com | 2883 | M: Haren Myneni <hbabu@us.ibm.com> |
| 3344 | P: Haren Myneni | ||
| 3345 | M: hbabu@us.ibm.com | ||
| 3346 | L: kexec@lists.infradead.org | 2884 | L: kexec@lists.infradead.org |
| 3347 | W: http://lse.sourceforge.net/kdump/ | 2885 | W: http://lse.sourceforge.net/kdump/ |
| 3348 | S: Maintained | 2886 | S: Maintained |
| 3349 | F: Documentation/kdump/ | 2887 | F: Documentation/kdump/ |
| 3350 | 2888 | ||
| 3351 | KERNEL AUTOMOUNTER (AUTOFS) | 2889 | KERNEL AUTOMOUNTER (AUTOFS) |
| 3352 | P: H. Peter Anvin | 2890 | M: "H. Peter Anvin" <hpa@zytor.com> |
| 3353 | M: hpa@zytor.com | ||
| 3354 | L: autofs@linux.kernel.org | 2891 | L: autofs@linux.kernel.org |
| 3355 | S: Odd Fixes | 2892 | S: Odd Fixes |
| 3356 | F: fs/autofs/ | 2893 | F: fs/autofs/ |
| 3357 | 2894 | ||
| 3358 | KERNEL AUTOMOUNTER v4 (AUTOFS4) | 2895 | KERNEL AUTOMOUNTER v4 (AUTOFS4) |
| 3359 | P: Ian Kent | 2896 | M: Ian Kent <raven@themaw.net> |
| 3360 | M: raven@themaw.net | ||
| 3361 | L: autofs@linux.kernel.org | 2897 | L: autofs@linux.kernel.org |
| 3362 | S: Maintained | 2898 | S: Maintained |
| 3363 | F: fs/autofs4/ | 2899 | F: fs/autofs4/ |
| 3364 | 2900 | ||
| 3365 | KERNEL BUILD | 2901 | KERNEL BUILD |
| 3366 | P: Sam Ravnborg | 2902 | M: Sam Ravnborg <sam@ravnborg.org> |
| 3367 | M: sam@ravnborg.org | ||
| 3368 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/sam/kbuild-next.git | 2903 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/sam/kbuild-next.git |
| 3369 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/sam/kbuild-fixes.git | 2904 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/sam/kbuild-fixes.git |
| 3370 | L: linux-kbuild@vger.kernel.org | 2905 | L: linux-kbuild@vger.kernel.org |
| @@ -3374,16 +2909,13 @@ F: Makefile | |||
| 3374 | F: scripts/Makefile.* | 2909 | F: scripts/Makefile.* |
| 3375 | 2910 | ||
| 3376 | KERNEL JANITORS | 2911 | KERNEL JANITORS |
| 3377 | P: Several | ||
| 3378 | L: kernel-janitors@vger.kernel.org | 2912 | L: kernel-janitors@vger.kernel.org |
| 3379 | W: http://www.kerneljanitors.org/ | 2913 | W: http://www.kerneljanitors.org/ |
| 3380 | S: Maintained | 2914 | S: Odd fixes |
| 3381 | 2915 | ||
| 3382 | KERNEL NFSD, SUNRPC, AND LOCKD SERVERS | 2916 | KERNEL NFSD, SUNRPC, AND LOCKD SERVERS |
| 3383 | P: J. Bruce Fields | 2917 | M: "J. Bruce Fields" <bfields@fieldses.org> |
| 3384 | M: bfields@fieldses.org | 2918 | M: Neil Brown <neilb@suse.de> |
| 3385 | P: Neil Brown | ||
| 3386 | M: neilb@suse.de | ||
| 3387 | L: linux-nfs@vger.kernel.org | 2919 | L: linux-nfs@vger.kernel.org |
| 3388 | W: http://nfs.sourceforge.net/ | 2920 | W: http://nfs.sourceforge.net/ |
| 3389 | S: Supported | 2921 | S: Supported |
| @@ -3396,8 +2928,7 @@ F: include/linux/lockd/ | |||
| 3396 | F: include/linux/sunrpc/ | 2928 | F: include/linux/sunrpc/ |
| 3397 | 2929 | ||
| 3398 | KERNEL VIRTUAL MACHINE (KVM) | 2930 | KERNEL VIRTUAL MACHINE (KVM) |
| 3399 | P: Avi Kivity | 2931 | M: Avi Kivity <avi@redhat.com> |
| 3400 | M: avi@redhat.com | ||
| 3401 | L: kvm@vger.kernel.org | 2932 | L: kvm@vger.kernel.org |
| 3402 | W: http://kvm.qumranet.com | 2933 | W: http://kvm.qumranet.com |
| 3403 | S: Supported | 2934 | S: Supported |
| @@ -3408,8 +2939,7 @@ F: include/linux/kvm* | |||
| 3408 | F: virt/kvm/ | 2939 | F: virt/kvm/ |
| 3409 | 2940 | ||
| 3410 | KERNEL VIRTUAL MACHINE (KVM) FOR AMD-V | 2941 | KERNEL VIRTUAL MACHINE (KVM) FOR AMD-V |
| 3411 | P: Joerg Roedel | 2942 | M: Joerg Roedel <joerg.roedel@amd.com> |
| 3412 | M: joerg.roedel@amd.com | ||
| 3413 | L: kvm@vger.kernel.org | 2943 | L: kvm@vger.kernel.org |
| 3414 | W: http://kvm.qumranet.com | 2944 | W: http://kvm.qumranet.com |
| 3415 | S: Supported | 2945 | S: Supported |
| @@ -3418,8 +2948,7 @@ F: arch/x86/kvm/kvm_svm.h | |||
| 3418 | F: arch/x86/kvm/svm.c | 2948 | F: arch/x86/kvm/svm.c |
| 3419 | 2949 | ||
| 3420 | KERNEL VIRTUAL MACHINE (KVM) FOR POWERPC | 2950 | KERNEL VIRTUAL MACHINE (KVM) FOR POWERPC |
| 3421 | P: Hollis Blanchard | 2951 | M: Hollis Blanchard <hollisb@us.ibm.com> |
| 3422 | M: hollisb@us.ibm.com | ||
| 3423 | L: kvm-ppc@vger.kernel.org | 2952 | L: kvm-ppc@vger.kernel.org |
| 3424 | W: http://kvm.qumranet.com | 2953 | W: http://kvm.qumranet.com |
| 3425 | S: Supported | 2954 | S: Supported |
| @@ -3427,8 +2956,7 @@ F: arch/powerpc/include/asm/kvm* | |||
| 3427 | F: arch/powerpc/kvm/ | 2956 | F: arch/powerpc/kvm/ |
| 3428 | 2957 | ||
| 3429 | KERNEL VIRTUAL MACHINE For Itanium (KVM/IA64) | 2958 | KERNEL VIRTUAL MACHINE For Itanium (KVM/IA64) |
| 3430 | P: Xiantao Zhang | 2959 | M: Xiantao Zhang <xiantao.zhang@intel.com> |
| 3431 | M: xiantao.zhang@intel.com | ||
| 3432 | L: kvm-ia64@vger.kernel.org | 2960 | L: kvm-ia64@vger.kernel.org |
| 3433 | W: http://kvm.qumranet.com | 2961 | W: http://kvm.qumranet.com |
| 3434 | S: Supported | 2962 | S: Supported |
| @@ -3437,10 +2965,8 @@ F: arch/ia64/include/asm/kvm* | |||
| 3437 | F: arch/ia64/kvm/ | 2965 | F: arch/ia64/kvm/ |
| 3438 | 2966 | ||
| 3439 | KERNEL VIRTUAL MACHINE for s390 (KVM/s390) | 2967 | KERNEL VIRTUAL MACHINE for s390 (KVM/s390) |
| 3440 | P: Carsten Otte | 2968 | M: Carsten Otte <cotte@de.ibm.com> |
| 3441 | M: cotte@de.ibm.com | 2969 | M: Christian Borntraeger <borntraeger@de.ibm.com> |
| 3442 | P: Christian Borntraeger | ||
| 3443 | M: borntraeger@de.ibm.com | ||
| 3444 | M: linux390@de.ibm.com | 2970 | M: linux390@de.ibm.com |
| 3445 | L: linux-s390@vger.kernel.org | 2971 | L: linux-s390@vger.kernel.org |
| 3446 | W: http://www.ibm.com/developerworks/linux/linux390/ | 2972 | W: http://www.ibm.com/developerworks/linux/linux390/ |
| @@ -3450,8 +2976,7 @@ F: arch/s390/include/asm/kvm* | |||
| 3450 | F: arch/s390/kvm/ | 2976 | F: arch/s390/kvm/ |
| 3451 | 2977 | ||
| 3452 | KEXEC | 2978 | KEXEC |
| 3453 | P: Eric Biederman | 2979 | M: Eric Biederman <ebiederm@xmission.com> |
| 3454 | M: ebiederm@xmission.com | ||
| 3455 | W: http://ftp.kernel.org/pub/linux/kernel/people/horms/kexec-tools/ | 2980 | W: http://ftp.kernel.org/pub/linux/kernel/people/horms/kexec-tools/ |
| 3456 | L: kexec@lists.infradead.org | 2981 | L: kexec@lists.infradead.org |
| 3457 | S: Maintained | 2982 | S: Maintained |
| @@ -3459,8 +2984,7 @@ F: include/linux/kexec.h | |||
| 3459 | F: kernel/kexec.c | 2984 | F: kernel/kexec.c |
| 3460 | 2985 | ||
| 3461 | KGDB | 2986 | KGDB |
| 3462 | P: Jason Wessel | 2987 | M: Jason Wessel <jason.wessel@windriver.com> |
| 3463 | M: jason.wessel@windriver.com | ||
| 3464 | L: kgdb-bugreport@lists.sourceforge.net | 2988 | L: kgdb-bugreport@lists.sourceforge.net |
| 3465 | S: Maintained | 2989 | S: Maintained |
| 3466 | F: Documentation/DocBook/kgdb.tmpl | 2990 | F: Documentation/DocBook/kgdb.tmpl |
| @@ -3470,17 +2994,13 @@ F: include/linux/kgdb.h | |||
| 3470 | F: kernel/kgdb.c | 2994 | F: kernel/kgdb.c |
| 3471 | 2995 | ||
| 3472 | KMEMCHECK | 2996 | KMEMCHECK |
| 3473 | P: Vegard Nossum | 2997 | M: Vegard Nossum <vegardno@ifi.uio.no> |
| 3474 | M: vegardno@ifi.uio.no | ||
| 3475 | P Pekka Enberg | 2998 | P Pekka Enberg |
| 3476 | M: penberg@cs.helsinki.fi | 2999 | M: penberg@cs.helsinki.fi |
| 3477 | L: linux-kernel@vger.kernel.org | ||
| 3478 | S: Maintained | 3000 | S: Maintained |
| 3479 | 3001 | ||
| 3480 | KMEMLEAK | 3002 | KMEMLEAK |
| 3481 | P: Catalin Marinas | 3003 | M: Catalin Marinas <catalin.marinas@arm.com> |
| 3482 | M: catalin.marinas@arm.com | ||
| 3483 | L: linux-kernel@vger.kernel.org | ||
| 3484 | S: Maintained | 3004 | S: Maintained |
| 3485 | F: Documentation/kmemleak.txt | 3005 | F: Documentation/kmemleak.txt |
| 3486 | F: include/linux/kmemleak.h | 3006 | F: include/linux/kmemleak.h |
| @@ -3488,30 +3008,24 @@ F: mm/kmemleak.c | |||
| 3488 | F: mm/kmemleak-test.c | 3008 | F: mm/kmemleak-test.c |
| 3489 | 3009 | ||
| 3490 | KMEMTRACE | 3010 | KMEMTRACE |
| 3491 | P: Eduard - Gabriel Munteanu | 3011 | M: Eduard - Gabriel Munteanu <eduard.munteanu@linux360.ro> |
| 3492 | M: eduard.munteanu@linux360.ro | ||
| 3493 | S: Maintained | 3012 | S: Maintained |
| 3494 | F: Documentation/trace/kmemtrace.txt | 3013 | F: Documentation/trace/kmemtrace.txt |
| 3495 | F: include/linux/kmemtrace.h | 3014 | F: include/linux/kmemtrace.h |
| 3496 | F: kernel/trace/kmemtrace.c | 3015 | F: kernel/trace/kmemtrace.c |
| 3497 | 3016 | ||
| 3498 | KPROBES | 3017 | KPROBES |
| 3499 | P: Ananth N Mavinakayanahalli | 3018 | M: Ananth N Mavinakayanahalli <ananth@in.ibm.com> |
| 3500 | M: ananth@in.ibm.com | 3019 | M: Anil S Keshavamurthy <anil.s.keshavamurthy@intel.com> |
| 3501 | P: Anil S Keshavamurthy | 3020 | M: "David S. Miller" <davem@davemloft.net> |
| 3502 | M: anil.s.keshavamurthy@intel.com | 3021 | M: Masami Hiramatsu <mhiramat@redhat.com> |
| 3503 | P: David S. Miller | ||
| 3504 | M: davem@davemloft.net | ||
| 3505 | P: Masami Hiramatsu | ||
| 3506 | M: mhiramat@redhat.com | ||
| 3507 | S: Maintained | 3022 | S: Maintained |
| 3508 | F: Documentation/kprobes.txt | 3023 | F: Documentation/kprobes.txt |
| 3509 | F: include/linux/kprobes.h | 3024 | F: include/linux/kprobes.h |
| 3510 | F: kernel/kprobes.c | 3025 | F: kernel/kprobes.c |
| 3511 | 3026 | ||
| 3512 | KS0108 LCD CONTROLLER DRIVER | 3027 | KS0108 LCD CONTROLLER DRIVER |
| 3513 | P: Miguel Ojeda Sandonis | 3028 | M: Miguel Ojeda Sandonis <miguel.ojeda.sandonis@gmail.com> |
| 3514 | M: miguel.ojeda.sandonis@gmail.com | ||
| 3515 | W: http://miguelojeda.es/auxdisplay.htm | 3029 | W: http://miguelojeda.es/auxdisplay.htm |
| 3516 | W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm | 3030 | W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm |
| 3517 | S: Maintained | 3031 | S: Maintained |
| @@ -3527,31 +3041,27 @@ F: include/*/lapb.h | |||
| 3527 | F: net/lapb/ | 3041 | F: net/lapb/ |
| 3528 | 3042 | ||
| 3529 | LASI 53c700 driver for PARISC | 3043 | LASI 53c700 driver for PARISC |
| 3530 | P: James E.J. Bottomley | 3044 | M: "James E.J. Bottomley" <James.Bottomley@HansenPartnership.com> |
| 3531 | M: James.Bottomley@HansenPartnership.com | ||
| 3532 | L: linux-scsi@vger.kernel.org | 3045 | L: linux-scsi@vger.kernel.org |
| 3533 | S: Maintained | 3046 | S: Maintained |
| 3534 | F: Documentation/scsi/53c700.txt | 3047 | F: Documentation/scsi/53c700.txt |
| 3535 | F: drivers/scsi/53c700* | 3048 | F: drivers/scsi/53c700* |
| 3536 | 3049 | ||
| 3537 | LED SUBSYSTEM | 3050 | LED SUBSYSTEM |
| 3538 | P: Richard Purdie | 3051 | M: Richard Purdie <rpurdie@rpsys.net> |
| 3539 | M: rpurdie@rpsys.net | ||
| 3540 | S: Maintained | 3052 | S: Maintained |
| 3541 | F: drivers/leds/ | 3053 | F: drivers/leds/ |
| 3542 | F: include/linux/leds.h | 3054 | F: include/linux/leds.h |
| 3543 | 3055 | ||
| 3544 | LEGO USB Tower driver | 3056 | LEGO USB Tower driver |
| 3545 | P: Juergen Stuber | 3057 | M: Juergen Stuber <starblue@users.sourceforge.net> |
| 3546 | M: starblue@users.sourceforge.net | ||
| 3547 | L: legousb-devel@lists.sourceforge.net | 3058 | L: legousb-devel@lists.sourceforge.net |
| 3548 | W: http://legousb.sourceforge.net/ | 3059 | W: http://legousb.sourceforge.net/ |
| 3549 | S: Maintained | 3060 | S: Maintained |
| 3550 | F: drivers/usb/misc/legousbtower.c | 3061 | F: drivers/usb/misc/legousbtower.c |
| 3551 | 3062 | ||
| 3552 | LGUEST | 3063 | LGUEST |
| 3553 | P: Rusty Russell | 3064 | M: Rusty Russell <rusty@rustcorp.com.au> |
| 3554 | M: rusty@rustcorp.com.au | ||
| 3555 | L: lguest@ozlabs.org | 3065 | L: lguest@ozlabs.org |
| 3556 | W: http://lguest.ozlabs.org/ | 3066 | W: http://lguest.ozlabs.org/ |
| 3557 | S: Maintained | 3067 | S: Maintained |
| @@ -3562,119 +3072,100 @@ F: include/linux/lguest*.h | |||
| 3562 | F: arch/x86/include/asm/lguest*.h | 3072 | F: arch/x86/include/asm/lguest*.h |
| 3563 | 3073 | ||
| 3564 | LINUX FOR IBM pSERIES (RS/6000) | 3074 | LINUX FOR IBM pSERIES (RS/6000) |
| 3565 | P: Paul Mackerras | 3075 | M: Paul Mackerras <paulus@au.ibm.com> |
| 3566 | M: paulus@au.ibm.com | ||
| 3567 | W: http://www.ibm.com/linux/ltc/projects/ppc | 3076 | W: http://www.ibm.com/linux/ltc/projects/ppc |
| 3568 | S: Supported | 3077 | S: Supported |
| 3569 | 3078 | ||
| 3570 | LINUX FOR POWERPC (32-BIT AND 64-BIT) | 3079 | LINUX FOR POWERPC (32-BIT AND 64-BIT) |
| 3571 | P: Benjamin Herrenschmidt | 3080 | M: Benjamin Herrenschmidt <benh@kernel.crashing.org> |
| 3572 | M: benh@kernel.crashing.org | 3081 | M: Paul Mackerras <paulus@samba.org> |
| 3573 | P: Paul Mackerras | ||
| 3574 | M: paulus@samba.org | ||
| 3575 | W: http://www.penguinppc.org/ | 3082 | W: http://www.penguinppc.org/ |
| 3576 | L: linuxppc-dev@ozlabs.org | 3083 | L: linuxppc-dev@ozlabs.org |
| 3577 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/benh/powerpc.git | 3084 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/benh/powerpc.git |
| 3578 | S: Supported | 3085 | S: Supported |
| 3579 | 3086 | ||
| 3580 | LINUX FOR POWER MACINTOSH | 3087 | LINUX FOR POWER MACINTOSH |
| 3581 | P: Benjamin Herrenschmidt | 3088 | M: Benjamin Herrenschmidt <benh@kernel.crashing.org> |
| 3582 | M: benh@kernel.crashing.org | ||
| 3583 | W: http://www.penguinppc.org/ | 3089 | W: http://www.penguinppc.org/ |
| 3584 | L: linuxppc-dev@ozlabs.org | 3090 | L: linuxppc-dev@ozlabs.org |
| 3585 | S: Maintained | 3091 | S: Maintained |
| 3586 | 3092 | ||
| 3587 | LINUX FOR POWERPC EMBEDDED MPC5XXX | 3093 | LINUX FOR POWERPC EMBEDDED MPC5XXX |
| 3588 | P: Grant Likely | 3094 | M: Grant Likely <grant.likely@secretlab.ca> |
| 3589 | M: grant.likely@secretlab.ca | ||
| 3590 | L: linuxppc-dev@ozlabs.org | 3095 | L: linuxppc-dev@ozlabs.org |
| 3591 | T: git git://git.secretlab.ca/git/linux-2.6.git | 3096 | T: git git://git.secretlab.ca/git/linux-2.6.git |
| 3592 | S: Maintained | 3097 | S: Maintained |
| 3593 | 3098 | ||
| 3594 | LINUX FOR POWERPC EMBEDDED PPC4XX | 3099 | LINUX FOR POWERPC EMBEDDED PPC4XX |
| 3595 | P: Josh Boyer | 3100 | M: Josh Boyer <jwboyer@linux.vnet.ibm.com> |
| 3596 | M: jwboyer@linux.vnet.ibm.com | 3101 | M: Matt Porter <mporter@kernel.crashing.org> |
| 3597 | P: Matt Porter | ||
| 3598 | M: mporter@kernel.crashing.org | ||
| 3599 | W: http://www.penguinppc.org/ | 3102 | W: http://www.penguinppc.org/ |
| 3600 | L: linuxppc-dev@ozlabs.org | 3103 | L: linuxppc-dev@ozlabs.org |
| 3601 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jwboyer/powerpc-4xx.git | 3104 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jwboyer/powerpc-4xx.git |
| 3602 | S: Maintained | 3105 | S: Maintained |
| 3603 | 3106 | ||
| 3604 | LINUX FOR POWERPC EMBEDDED XILINX VIRTEX | 3107 | LINUX FOR POWERPC EMBEDDED XILINX VIRTEX |
| 3605 | P: Grant Likely | 3108 | M: Grant Likely <grant.likely@secretlab.ca> |
| 3606 | M: grant.likely@secretlab.ca | ||
| 3607 | W: http://wiki.secretlab.ca/index.php/Linux_on_Xilinx_Virtex | 3109 | W: http://wiki.secretlab.ca/index.php/Linux_on_Xilinx_Virtex |
| 3608 | L: linuxppc-dev@ozlabs.org | 3110 | L: linuxppc-dev@ozlabs.org |
| 3609 | T: git git://git.secretlab.ca/git/linux-2.6.git | 3111 | T: git git://git.secretlab.ca/git/linux-2.6.git |
| 3610 | S: Maintained | 3112 | S: Maintained |
| 3611 | 3113 | ||
| 3612 | LINUX FOR POWERPC EMBEDDED PPC8XX | 3114 | LINUX FOR POWERPC EMBEDDED PPC8XX |
| 3613 | P: Vitaly Bordug | 3115 | M: Vitaly Bordug <vitb@kernel.crashing.org> |
| 3614 | M: vitb@kernel.crashing.org | 3116 | M: Marcelo Tosatti <marcelo@kvack.org> |
| 3615 | P: Marcelo Tosatti | ||
| 3616 | M: marcelo@kvack.org | ||
| 3617 | W: http://www.penguinppc.org/ | 3117 | W: http://www.penguinppc.org/ |
| 3618 | L: linuxppc-dev@ozlabs.org | 3118 | L: linuxppc-dev@ozlabs.org |
| 3619 | S: Maintained | 3119 | S: Maintained |
| 3620 | 3120 | ||
| 3621 | LINUX FOR POWERPC EMBEDDED PPC83XX AND PPC85XX | 3121 | LINUX FOR POWERPC EMBEDDED PPC83XX AND PPC85XX |
| 3622 | P: Kumar Gala | 3122 | M: Kumar Gala <galak@kernel.crashing.org> |
| 3623 | M: galak@kernel.crashing.org | ||
| 3624 | W: http://www.penguinppc.org/ | 3123 | W: http://www.penguinppc.org/ |
| 3625 | L: linuxppc-dev@ozlabs.org | 3124 | L: linuxppc-dev@ozlabs.org |
| 3626 | S: Maintained | 3125 | S: Maintained |
| 3627 | 3126 | ||
| 3628 | LINUX FOR POWERPC PA SEMI PWRFICIENT | 3127 | LINUX FOR POWERPC PA SEMI PWRFICIENT |
| 3629 | P: Olof Johansson | 3128 | M: Olof Johansson <olof@lixom.net> |
| 3630 | M: olof@lixom.net | ||
| 3631 | W: http://www.pasemi.com/ | 3129 | W: http://www.pasemi.com/ |
| 3632 | L: linuxppc-dev@ozlabs.org | 3130 | L: linuxppc-dev@ozlabs.org |
| 3633 | S: Supported | 3131 | S: Supported |
| 3634 | 3132 | ||
| 3635 | LINUX SECURITY MODULE (LSM) FRAMEWORK | 3133 | LINUX SECURITY MODULE (LSM) FRAMEWORK |
| 3636 | P: Chris Wright | 3134 | M: Chris Wright <chrisw@sous-sol.org> |
| 3637 | M: chrisw@sous-sol.org | ||
| 3638 | L: linux-security-module@vger.kernel.org | 3135 | L: linux-security-module@vger.kernel.org |
| 3639 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/chrisw/lsm-2.6.git | 3136 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/chrisw/lsm-2.6.git |
| 3640 | S: Supported | 3137 | S: Supported |
| 3641 | 3138 | ||
| 3642 | LLC (802.2) | 3139 | LLC (802.2) |
| 3643 | P: Arnaldo Carvalho de Melo | 3140 | M: Arnaldo Carvalho de Melo <acme@ghostprotocols.net> |
| 3644 | M: acme@ghostprotocols.net | ||
| 3645 | S: Maintained | 3141 | S: Maintained |
| 3646 | F: include/linux/llc.h | 3142 | F: include/linux/llc.h |
| 3647 | F: include/net/llc* | 3143 | F: include/net/llc* |
| 3648 | F: net/llc/ | 3144 | F: net/llc/ |
| 3649 | 3145 | ||
| 3650 | LIS3LV02D ACCELEROMETER DRIVER | 3146 | LIS3LV02D ACCELEROMETER DRIVER |
| 3651 | P: Eric Piel | 3147 | M: Eric Piel <eric.piel@tremplin-utc.net> |
| 3652 | M: eric.piel@tremplin-utc.net | ||
| 3653 | S: Maintained | 3148 | S: Maintained |
| 3654 | F: Documentation/hwmon/lis3lv02d | 3149 | F: Documentation/hwmon/lis3lv02d |
| 3655 | F: drivers/hwmon/lis3lv02d.* | 3150 | F: drivers/hwmon/lis3lv02d.* |
| 3656 | 3151 | ||
| 3657 | LM83 HARDWARE MONITOR DRIVER | 3152 | LM83 HARDWARE MONITOR DRIVER |
| 3658 | P: Jean Delvare | 3153 | M: Jean Delvare <khali@linux-fr.org> |
| 3659 | M: khali@linux-fr.org | ||
| 3660 | L: lm-sensors@lm-sensors.org | 3154 | L: lm-sensors@lm-sensors.org |
| 3661 | S: Maintained | 3155 | S: Maintained |
| 3662 | F: Documentation/hwmon/lm83 | 3156 | F: Documentation/hwmon/lm83 |
| 3663 | F: drivers/hwmon/lm83.c | 3157 | F: drivers/hwmon/lm83.c |
| 3664 | 3158 | ||
| 3665 | LM90 HARDWARE MONITOR DRIVER | 3159 | LM90 HARDWARE MONITOR DRIVER |
| 3666 | P: Jean Delvare | 3160 | M: Jean Delvare <khali@linux-fr.org> |
| 3667 | M: khali@linux-fr.org | ||
| 3668 | L: lm-sensors@lm-sensors.org | 3161 | L: lm-sensors@lm-sensors.org |
| 3669 | S: Maintained | 3162 | S: Maintained |
| 3670 | F: Documentation/hwmon/lm90 | 3163 | F: Documentation/hwmon/lm90 |
| 3671 | F: drivers/hwmon/lm90.c | 3164 | F: drivers/hwmon/lm90.c |
| 3672 | 3165 | ||
| 3673 | LOCKDEP AND LOCKSTAT | 3166 | LOCKDEP AND LOCKSTAT |
| 3674 | P: Peter Zijlstra | 3167 | M: Peter Zijlstra <peterz@infradead.org> |
| 3675 | M: peterz@infradead.org | 3168 | M: Ingo Molnar <mingo@redhat.com> |
| 3676 | P: Ingo Molnar | ||
| 3677 | M: mingo@redhat.com | ||
| 3678 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/peterz/linux-2.6-lockdep.git | 3169 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/peterz/linux-2.6-lockdep.git |
| 3679 | S: Maintained | 3170 | S: Maintained |
| 3680 | F: Documentation/lockdep*.txt | 3171 | F: Documentation/lockdep*.txt |
| @@ -3683,8 +3174,7 @@ F: include/linux/lockdep.h | |||
| 3683 | F: kernel/lockdep* | 3174 | F: kernel/lockdep* |
| 3684 | 3175 | ||
| 3685 | LOGICAL DISK MANAGER SUPPORT (LDM, Windows 2000/XP/Vista Dynamic Disks) | 3176 | LOGICAL DISK MANAGER SUPPORT (LDM, Windows 2000/XP/Vista Dynamic Disks) |
| 3686 | P: Richard Russon (FlatCap) | 3177 | M: "Richard Russon (FlatCap)" <ldm@flatcap.org> |
| 3687 | M: ldm@flatcap.org | ||
| 3688 | L: linux-ntfs-dev@lists.sourceforge.net | 3178 | L: linux-ntfs-dev@lists.sourceforge.net |
| 3689 | W: http://www.linux-ntfs.org/content/view/19/37/ | 3179 | W: http://www.linux-ntfs.org/content/view/19/37/ |
| 3690 | S: Maintained | 3180 | S: Maintained |
| @@ -3692,8 +3182,7 @@ F: Documentation/ldm.txt | |||
| 3692 | F: fs/partitions/ldm.* | 3182 | F: fs/partitions/ldm.* |
| 3693 | 3183 | ||
| 3694 | LSILOGIC MPT FUSION DRIVERS (FC/SAS/SPI) | 3184 | LSILOGIC MPT FUSION DRIVERS (FC/SAS/SPI) |
| 3695 | P: Eric Moore | 3185 | M: Eric Moore <Eric.Moore@lsi.com> |
| 3696 | M: Eric.Moore@lsi.com | ||
| 3697 | M: support@lsi.com | 3186 | M: support@lsi.com |
| 3698 | L: DL-MPTFusionLinux@lsi.com | 3187 | L: DL-MPTFusionLinux@lsi.com |
| 3699 | L: linux-scsi@vger.kernel.org | 3188 | L: linux-scsi@vger.kernel.org |
| @@ -3702,25 +3191,21 @@ S: Supported | |||
| 3702 | F: drivers/message/fusion/ | 3191 | F: drivers/message/fusion/ |
| 3703 | 3192 | ||
| 3704 | LSILOGIC/SYMBIOS/NCR 53C8XX and 53C1010 PCI-SCSI drivers | 3193 | LSILOGIC/SYMBIOS/NCR 53C8XX and 53C1010 PCI-SCSI drivers |
| 3705 | P: Matthew Wilcox | 3194 | M: Matthew Wilcox <matthew@wil.cx> |
| 3706 | M: matthew@wil.cx | ||
| 3707 | L: linux-scsi@vger.kernel.org | 3195 | L: linux-scsi@vger.kernel.org |
| 3708 | S: Maintained | 3196 | S: Maintained |
| 3709 | F: drivers/scsi/sym53c8xx_2/ | 3197 | F: drivers/scsi/sym53c8xx_2/ |
| 3710 | 3198 | ||
| 3711 | LTP (Linux Test Project) | 3199 | LTP (Linux Test Project) |
| 3712 | P: Subrata Modak | 3200 | M: Subrata Modak <subrata@linux.vnet.ibm.com> |
| 3713 | M: subrata@linux.vnet.ibm.com | 3201 | M: Mike Frysinger <vapier@gentoo.org> |
| 3714 | P: Mike Frysinger | ||
| 3715 | M: vapier@gentoo.org | ||
| 3716 | L: ltp-list@lists.sourceforge.net (subscribers-only) | 3202 | L: ltp-list@lists.sourceforge.net (subscribers-only) |
| 3717 | W: http://ltp.sourceforge.net/ | 3203 | W: http://ltp.sourceforge.net/ |
| 3718 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/galak/ltp.git | 3204 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/galak/ltp.git |
| 3719 | S: Maintained | 3205 | S: Maintained |
| 3720 | 3206 | ||
| 3721 | M32R ARCHITECTURE | 3207 | M32R ARCHITECTURE |
| 3722 | P: Hirokazu Takata | 3208 | M: Hirokazu Takata <takata@linux-m32r.org> |
| 3723 | M: takata@linux-m32r.org | ||
| 3724 | L: linux-m32r@ml.linux-m32r.org | 3209 | L: linux-m32r@ml.linux-m32r.org |
| 3725 | L: linux-m32r-ja@ml.linux-m32r.org (in Japanese) | 3210 | L: linux-m32r-ja@ml.linux-m32r.org (in Japanese) |
| 3726 | W: http://www.linux-m32r.org/ | 3211 | W: http://www.linux-m32r.org/ |
| @@ -3728,10 +3213,8 @@ S: Maintained | |||
| 3728 | F: arch/m32r/ | 3213 | F: arch/m32r/ |
| 3729 | 3214 | ||
| 3730 | M68K ARCHITECTURE | 3215 | M68K ARCHITECTURE |
| 3731 | P: Geert Uytterhoeven | 3216 | M: Geert Uytterhoeven <geert@linux-m68k.org> |
| 3732 | M: geert@linux-m68k.org | 3217 | M: Roman Zippel <zippel@linux-m68k.org> |
| 3733 | P: Roman Zippel | ||
| 3734 | M: zippel@linux-m68k.org | ||
| 3735 | L: linux-m68k@lists.linux-m68k.org | 3218 | L: linux-m68k@lists.linux-m68k.org |
| 3736 | W: http://www.linux-m68k.org/ | 3219 | W: http://www.linux-m68k.org/ |
| 3737 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/geert/linux-m68k.git | 3220 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/geert/linux-m68k.git |
| @@ -3740,23 +3223,20 @@ F: arch/m68k/ | |||
| 3740 | F: drivers/zorro/ | 3223 | F: drivers/zorro/ |
| 3741 | 3224 | ||
| 3742 | M68K ON APPLE MACINTOSH | 3225 | M68K ON APPLE MACINTOSH |
| 3743 | P: Joshua Thompson | 3226 | M: Joshua Thompson <funaho@jurai.org> |
| 3744 | M: funaho@jurai.org | ||
| 3745 | W: http://www.mac.linux-m68k.org/ | 3227 | W: http://www.mac.linux-m68k.org/ |
| 3746 | L: linux-m68k@lists.linux-m68k.org | 3228 | L: linux-m68k@lists.linux-m68k.org |
| 3747 | S: Maintained | 3229 | S: Maintained |
| 3748 | F: arch/m68k/mac/ | 3230 | F: arch/m68k/mac/ |
| 3749 | 3231 | ||
| 3750 | M68K ON HP9000/300 | 3232 | M68K ON HP9000/300 |
| 3751 | P: Philip Blundell | 3233 | M: Philip Blundell <philb@gnu.org> |
| 3752 | M: philb@gnu.org | ||
| 3753 | W: http://www.tazenda.demon.co.uk/phil/linux-hp | 3234 | W: http://www.tazenda.demon.co.uk/phil/linux-hp |
| 3754 | S: Maintained | 3235 | S: Maintained |
| 3755 | F: arch/m68k/hp300/ | 3236 | F: arch/m68k/hp300/ |
| 3756 | 3237 | ||
| 3757 | MAC80211 | 3238 | MAC80211 |
| 3758 | P: Johannes Berg | 3239 | M: Johannes Berg <johannes@sipsolutions.net> |
| 3759 | M: johannes@sipsolutions.net | ||
| 3760 | L: linux-wireless@vger.kernel.org | 3240 | L: linux-wireless@vger.kernel.org |
| 3761 | W: http://linuxwireless.org/ | 3241 | W: http://linuxwireless.org/ |
| 3762 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6.git | 3242 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6.git |
| @@ -3766,10 +3246,8 @@ F: include/net/mac80211.h | |||
| 3766 | F: net/mac80211/ | 3246 | F: net/mac80211/ |
| 3767 | 3247 | ||
| 3768 | MAC80211 PID RATE CONTROL | 3248 | MAC80211 PID RATE CONTROL |
| 3769 | P: Stefano Brivio | 3249 | M: Stefano Brivio <stefano.brivio@polimi.it> |
| 3770 | M: stefano.brivio@polimi.it | 3250 | M: Mattias Nissler <mattias.nissler@gmx.de> |
| 3771 | P: Mattias Nissler | ||
| 3772 | M: mattias.nissler@gmx.de | ||
| 3773 | L: linux-wireless@vger.kernel.org | 3251 | L: linux-wireless@vger.kernel.org |
| 3774 | W: http://linuxwireless.org/en/developers/Documentation/mac80211/RateControl/PID | 3252 | W: http://linuxwireless.org/en/developers/Documentation/mac80211/RateControl/PID |
| 3775 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6.git | 3253 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6.git |
| @@ -3777,67 +3255,57 @@ S: Maintained | |||
| 3777 | F: net/mac80211/rc80211_pid* | 3255 | F: net/mac80211/rc80211_pid* |
| 3778 | 3256 | ||
| 3779 | MACVLAN DRIVER | 3257 | MACVLAN DRIVER |
| 3780 | P: Patrick McHardy | 3258 | M: Patrick McHardy <kaber@trash.net> |
| 3781 | M: kaber@trash.net | ||
| 3782 | L: netdev@vger.kernel.org | 3259 | L: netdev@vger.kernel.org |
| 3783 | S: Maintained | 3260 | S: Maintained |
| 3784 | F: drivers/net/macvlan.c | 3261 | F: drivers/net/macvlan.c |
| 3785 | F: include/linux/if_macvlan.h | 3262 | F: include/linux/if_macvlan.h |
| 3786 | 3263 | ||
| 3787 | MAN-PAGES: MANUAL PAGES FOR LINUX -- Sections 2, 3, 4, 5, and 7 | 3264 | MAN-PAGES: MANUAL PAGES FOR LINUX -- Sections 2, 3, 4, 5, and 7 |
| 3788 | P: Michael Kerrisk | 3265 | M: Michael Kerrisk <mtk.manpages@gmail.com> |
| 3789 | M: mtk.manpages@gmail.com | ||
| 3790 | W: http://www.kernel.org/doc/man-pages | 3266 | W: http://www.kernel.org/doc/man-pages |
| 3791 | L: linux-man@vger.kernel.org | 3267 | L: linux-man@vger.kernel.org |
| 3792 | S: Maintained | 3268 | S: Maintained |
| 3793 | 3269 | ||
| 3794 | MARVELL LIBERTAS WIRELESS DRIVER | 3270 | MARVELL LIBERTAS WIRELESS DRIVER |
| 3795 | P: Dan Williams | 3271 | M: Dan Williams <dcbw@redhat.com> |
| 3796 | M: dcbw@redhat.com | ||
| 3797 | L: libertas-dev@lists.infradead.org | 3272 | L: libertas-dev@lists.infradead.org |
| 3798 | S: Maintained | 3273 | S: Maintained |
| 3799 | F: drivers/net/wireless/libertas/ | 3274 | F: drivers/net/wireless/libertas/ |
| 3800 | 3275 | ||
| 3801 | MARVELL MV643XX ETHERNET DRIVER | 3276 | MARVELL MV643XX ETHERNET DRIVER |
| 3802 | P: Lennert Buytenhek | 3277 | M: Lennert Buytenhek <buytenh@marvell.com> |
| 3803 | M: buytenh@marvell.com | ||
| 3804 | L: netdev@vger.kernel.org | 3278 | L: netdev@vger.kernel.org |
| 3805 | S: Supported | 3279 | S: Supported |
| 3806 | F: drivers/net/mv643xx_eth.* | 3280 | F: drivers/net/mv643xx_eth.* |
| 3807 | F: include/linux/mv643xx.h | 3281 | F: include/linux/mv643xx.h |
| 3808 | 3282 | ||
| 3809 | MARVELL SOC MMC/SD/SDIO CONTROLLER DRIVER | 3283 | MARVELL SOC MMC/SD/SDIO CONTROLLER DRIVER |
| 3810 | P: Nicolas Pitre | 3284 | M: Nicolas Pitre <nico@cam.org> |
| 3811 | M: nico@cam.org | ||
| 3812 | S: Maintained | 3285 | S: Maintained |
| 3813 | 3286 | ||
| 3814 | MARVELL YUKON / SYSKONNECT DRIVER | 3287 | MARVELL YUKON / SYSKONNECT DRIVER |
| 3815 | P: Mirko Lindner | 3288 | M: Mirko Lindner <mlindner@syskonnect.de> |
| 3816 | M: mlindner@syskonnect.de | 3289 | M: Ralph Roesler <rroesler@syskonnect.de> |
| 3817 | P: Ralph Roesler | ||
| 3818 | M: rroesler@syskonnect.de | ||
| 3819 | W: http://www.syskonnect.com | 3290 | W: http://www.syskonnect.com |
| 3820 | S: Supported | 3291 | S: Supported |
| 3821 | 3292 | ||
| 3822 | MATROX FRAMEBUFFER DRIVER | 3293 | MATROX FRAMEBUFFER DRIVER |
| 3823 | P: Petr Vandrovec | 3294 | M: Petr Vandrovec <vandrove@vc.cvut.cz> |
| 3824 | M: vandrove@vc.cvut.cz | ||
| 3825 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) | 3295 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 3826 | S: Maintained | 3296 | S: Maintained |
| 3827 | F: drivers/video/matrox/matroxfb_* | 3297 | F: drivers/video/matrox/matroxfb_* |
| 3828 | F: include/linux/matroxfb.h | 3298 | F: include/linux/matroxfb.h |
| 3829 | 3299 | ||
| 3830 | MAX6650 HARDWARE MONITOR AND FAN CONTROLLER DRIVER | 3300 | MAX6650 HARDWARE MONITOR AND FAN CONTROLLER DRIVER |
| 3831 | P: Hans J. Koch | 3301 | M: "Hans J. Koch" <hjk@linutronix.de> |
| 3832 | M: hjk@linutronix.de | ||
| 3833 | L: lm-sensors@lm-sensors.org | 3302 | L: lm-sensors@lm-sensors.org |
| 3834 | S: Maintained | 3303 | S: Maintained |
| 3835 | F: Documentation/hwmon/max6650 | 3304 | F: Documentation/hwmon/max6650 |
| 3836 | F: drivers/hwmon/max6650.c | 3305 | F: drivers/hwmon/max6650.c |
| 3837 | 3306 | ||
| 3838 | MEDIA INPUT INFRASTRUCTURE (V4L/DVB) | 3307 | MEDIA INPUT INFRASTRUCTURE (V4L/DVB) |
| 3839 | P: Mauro Carvalho Chehab | 3308 | M: Mauro Carvalho Chehab <mchehab@infradead.org> |
| 3840 | M: mchehab@infradead.org | ||
| 3841 | P: LinuxTV.org Project | 3309 | P: LinuxTV.org Project |
| 3842 | L: linux-media@vger.kernel.org | 3310 | L: linux-media@vger.kernel.org |
| 3843 | W: http://linuxtv.org | 3311 | W: http://linuxtv.org |
| @@ -3851,8 +3319,7 @@ F: include/linux/dvb/ | |||
| 3851 | F: include/linux/videodev*.h | 3319 | F: include/linux/videodev*.h |
| 3852 | 3320 | ||
| 3853 | MEGARAID SCSI DRIVERS | 3321 | MEGARAID SCSI DRIVERS |
| 3854 | P: Neela Syam Kolli | 3322 | M: Neela Syam Kolli <megaraidlinux@lsi.com> |
| 3855 | M: megaraidlinux@lsi.com | ||
| 3856 | L: linux-scsi@vger.kernel.org | 3323 | L: linux-scsi@vger.kernel.org |
| 3857 | W: http://megaraid.lsilogic.com | 3324 | W: http://megaraid.lsilogic.com |
| 3858 | S: Maintained | 3325 | S: Maintained |
| @@ -3868,19 +3335,15 @@ F: include/linux/mm.h | |||
| 3868 | F: mm/ | 3335 | F: mm/ |
| 3869 | 3336 | ||
| 3870 | MEMORY RESOURCE CONTROLLER | 3337 | MEMORY RESOURCE CONTROLLER |
| 3871 | P: Balbir Singh | 3338 | M: Balbir Singh <balbir@linux.vnet.ibm.com> |
| 3872 | M: balbir@linux.vnet.ibm.com | 3339 | M: Pavel Emelyanov <xemul@openvz.org> |
| 3873 | P: Pavel Emelyanov | 3340 | M: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com> |
| 3874 | M: xemul@openvz.org | ||
| 3875 | P: KAMEZAWA Hiroyuki | ||
| 3876 | M: kamezawa.hiroyu@jp.fujitsu.com | ||
| 3877 | L: linux-mm@kvack.org | 3341 | L: linux-mm@kvack.org |
| 3878 | S: Maintained | 3342 | S: Maintained |
| 3879 | F: mm/memcontrol.c | 3343 | F: mm/memcontrol.c |
| 3880 | 3344 | ||
| 3881 | MEMORY TECHNOLOGY DEVICES (MTD) | 3345 | MEMORY TECHNOLOGY DEVICES (MTD) |
| 3882 | P: David Woodhouse | 3346 | M: David Woodhouse <dwmw2@infradead.org> |
| 3883 | M: dwmw2@infradead.org | ||
| 3884 | W: http://www.linux-mtd.infradead.org/ | 3347 | W: http://www.linux-mtd.infradead.org/ |
| 3885 | L: linux-mtd@lists.infradead.org | 3348 | L: linux-mtd@lists.infradead.org |
| 3886 | T: git git://git.infradead.org/mtd-2.6.git | 3349 | T: git git://git.infradead.org/mtd-2.6.git |
| @@ -3890,8 +3353,7 @@ F: include/linux/mtd/ | |||
| 3890 | F: include/mtd/ | 3353 | F: include/mtd/ |
| 3891 | 3354 | ||
| 3892 | MICROBLAZE ARCHITECTURE | 3355 | MICROBLAZE ARCHITECTURE |
| 3893 | P: Michal Simek | 3356 | M: Michal Simek <monstr@monstr.eu> |
| 3894 | M: monstr@monstr.eu | ||
| 3895 | L: microblaze-uclinux@itee.uq.edu.au | 3357 | L: microblaze-uclinux@itee.uq.edu.au |
| 3896 | W: http://www.monstr.eu/fdt/ | 3358 | W: http://www.monstr.eu/fdt/ |
| 3897 | T: git git://git.monstr.eu/linux-2.6-microblaze.git | 3359 | T: git git://git.monstr.eu/linux-2.6-microblaze.git |
| @@ -3899,14 +3361,12 @@ S: Supported | |||
| 3899 | F: arch/microblaze/ | 3361 | F: arch/microblaze/ |
| 3900 | 3362 | ||
| 3901 | MICROTEK X6 SCANNER | 3363 | MICROTEK X6 SCANNER |
| 3902 | P: Oliver Neukum | 3364 | M: Oliver Neukum <oliver@neukum.name> |
| 3903 | M: oliver@neukum.name | ||
| 3904 | S: Maintained | 3365 | S: Maintained |
| 3905 | F: drivers/usb/image/microtek.* | 3366 | F: drivers/usb/image/microtek.* |
| 3906 | 3367 | ||
| 3907 | MIPS | 3368 | MIPS |
| 3908 | P: Ralf Baechle | 3369 | M: Ralf Baechle <ralf@linux-mips.org> |
| 3909 | M: ralf@linux-mips.org | ||
| 3910 | W: http://www.linux-mips.org/ | 3370 | W: http://www.linux-mips.org/ |
| 3911 | L: linux-mips@linux-mips.org | 3371 | L: linux-mips@linux-mips.org |
| 3912 | T: git git://git.linux-mips.org/pub/scm/linux.git | 3372 | T: git git://git.linux-mips.org/pub/scm/linux.git |
| @@ -3915,8 +3375,7 @@ F: Documentation/mips/ | |||
| 3915 | F: arch/mips/ | 3375 | F: arch/mips/ |
| 3916 | 3376 | ||
| 3917 | MISCELLANEOUS MCA-SUPPORT | 3377 | MISCELLANEOUS MCA-SUPPORT |
| 3918 | P: James Bottomley | 3378 | M: James Bottomley <James.Bottomley@HansenPartnership.com> |
| 3919 | M: James.Bottomley@HansenPartnership.com | ||
| 3920 | S: Maintained | 3379 | S: Maintained |
| 3921 | F: Documentation/ia64/mca.txt | 3380 | F: Documentation/ia64/mca.txt |
| 3922 | F: Documentation/mca.txt | 3381 | F: Documentation/mca.txt |
| @@ -3924,15 +3383,13 @@ F: drivers/mca/ | |||
| 3924 | F: include/linux/mca* | 3383 | F: include/linux/mca* |
| 3925 | 3384 | ||
| 3926 | MODULE SUPPORT | 3385 | MODULE SUPPORT |
| 3927 | P: Rusty Russell | 3386 | M: Rusty Russell <rusty@rustcorp.com.au> |
| 3928 | M: rusty@rustcorp.com.au | ||
| 3929 | S: Maintained | 3387 | S: Maintained |
| 3930 | F: include/linux/module.h | 3388 | F: include/linux/module.h |
| 3931 | F: kernel/module.c | 3389 | F: kernel/module.c |
| 3932 | 3390 | ||
| 3933 | MOTION EYE VAIO PICTUREBOOK CAMERA DRIVER | 3391 | MOTION EYE VAIO PICTUREBOOK CAMERA DRIVER |
| 3934 | P: Stelian Pop | 3392 | M: Stelian Pop <stelian@popies.net> |
| 3935 | M: stelian@popies.net | ||
| 3936 | W: http://popies.net/meye/ | 3393 | W: http://popies.net/meye/ |
| 3937 | S: Maintained | 3394 | S: Maintained |
| 3938 | F: Documentation/video4linux/meye.txt | 3395 | F: Documentation/video4linux/meye.txt |
| @@ -3940,135 +3397,112 @@ F: drivers/media/video/meye.* | |||
| 3940 | F: include/linux/meye.h | 3397 | F: include/linux/meye.h |
| 3941 | 3398 | ||
| 3942 | MOTOROLA IMX MMC/SD HOST CONTROLLER INTERFACE DRIVER | 3399 | MOTOROLA IMX MMC/SD HOST CONTROLLER INTERFACE DRIVER |
| 3943 | P: Pavel Pisa | 3400 | M: Pavel Pisa <ppisa@pikron.com> |
| 3944 | M: ppisa@pikron.com | ||
| 3945 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 3401 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 3946 | S: Maintained | 3402 | S: Maintained |
| 3947 | F: drivers/mmc/host/imxmmc.* | 3403 | F: drivers/mmc/host/imxmmc.* |
| 3948 | 3404 | ||
| 3949 | MOUSE AND MISC DEVICES [GENERAL] | 3405 | MOUSE AND MISC DEVICES [GENERAL] |
| 3950 | P: Alessandro Rubini | 3406 | M: Alessandro Rubini <rubini@ipvvis.unipv.it> |
| 3951 | M: rubini@ipvvis.unipv.it | ||
| 3952 | S: Maintained | 3407 | S: Maintained |
| 3953 | F: drivers/input/mouse/ | 3408 | F: drivers/input/mouse/ |
| 3954 | F: include/linux/gpio_mouse.h | 3409 | F: include/linux/gpio_mouse.h |
| 3955 | 3410 | ||
| 3956 | MOXA SMARTIO/INDUSTIO/INTELLIO SERIAL CARD | 3411 | MOXA SMARTIO/INDUSTIO/INTELLIO SERIAL CARD |
| 3957 | P: Jiri Slaby | 3412 | M: Jiri Slaby <jirislaby@gmail.com> |
| 3958 | M: jirislaby@gmail.com | ||
| 3959 | S: Maintained | 3413 | S: Maintained |
| 3960 | F: Documentation/serial/moxa-smartio | 3414 | F: Documentation/serial/moxa-smartio |
| 3961 | F: drivers/char/mxser.* | 3415 | F: drivers/char/mxser.* |
| 3962 | 3416 | ||
| 3963 | MSI LAPTOP SUPPORT | 3417 | MSI LAPTOP SUPPORT |
| 3964 | P: Lennart Poettering | 3418 | M: Lennart Poettering <mzxreary@0pointer.de> |
| 3965 | M: mzxreary@0pointer.de | ||
| 3966 | W: https://tango.0pointer.de/mailman/listinfo/s270-linux | 3419 | W: https://tango.0pointer.de/mailman/listinfo/s270-linux |
| 3967 | W: http://0pointer.de/lennart/tchibo.html | 3420 | W: http://0pointer.de/lennart/tchibo.html |
| 3968 | S: Maintained | 3421 | S: Maintained |
| 3969 | F: drivers/platform/x86/msi-laptop.c | 3422 | F: drivers/platform/x86/msi-laptop.c |
| 3970 | 3423 | ||
| 3971 | MULTIFUNCTION DEVICES (MFD) | 3424 | MULTIFUNCTION DEVICES (MFD) |
| 3972 | P: Samuel Ortiz | 3425 | M: Samuel Ortiz <sameo@linux.intel.com> |
| 3973 | M: sameo@linux.intel.com | ||
| 3974 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/sameo/mfd-2.6.git | 3426 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/sameo/mfd-2.6.git |
| 3975 | S: Supported | 3427 | S: Supported |
| 3976 | F: drivers/mfd/ | 3428 | F: drivers/mfd/ |
| 3977 | 3429 | ||
| 3978 | MULTIMEDIA CARD (MMC), SECURE DIGITAL (SD) AND SDIO SUBSYSTEM | 3430 | MULTIMEDIA CARD (MMC), SECURE DIGITAL (SD) AND SDIO SUBSYSTEM |
| 3979 | P: Pierre Ossman | 3431 | S: Orphan |
| 3980 | M: pierre@ossman.eu | 3432 | L: linux-mmc@vger.kernel.org |
| 3981 | S: Maintained | ||
| 3982 | F: drivers/mmc/ | 3433 | F: drivers/mmc/ |
| 3983 | F: include/linux/mmc/ | 3434 | F: include/linux/mmc/ |
| 3984 | 3435 | ||
| 3985 | MULTIMEDIA CARD (MMC) ETC. OVER SPI | 3436 | MULTIMEDIA CARD (MMC) ETC. OVER SPI |
| 3986 | P: David Brownell | 3437 | M: David Brownell <dbrownell@users.sourceforge.net> |
| 3987 | M: dbrownell@users.sourceforge.net | ||
| 3988 | S: Odd Fixes | 3438 | S: Odd Fixes |
| 3989 | F: drivers/mmc/host/mmc_spi.c | 3439 | F: drivers/mmc/host/mmc_spi.c |
| 3990 | F: include/linux/spi/mmc_spi.h | 3440 | F: include/linux/spi/mmc_spi.h |
| 3991 | 3441 | ||
| 3992 | MULTISOUND SOUND DRIVER | 3442 | MULTISOUND SOUND DRIVER |
| 3993 | P: Andrew Veliath | 3443 | M: Andrew Veliath <andrewtv@usa.net> |
| 3994 | M: andrewtv@usa.net | ||
| 3995 | S: Maintained | 3444 | S: Maintained |
| 3996 | F: Documentation/sound/oss/MultiSound | 3445 | F: Documentation/sound/oss/MultiSound |
| 3997 | F: sound/oss/msnd* | 3446 | F: sound/oss/msnd* |
| 3998 | 3447 | ||
| 3999 | MULTITECH MULTIPORT CARD (ISICOM) | 3448 | MULTITECH MULTIPORT CARD (ISICOM) |
| 4000 | P: Jiri Slaby | 3449 | M: Jiri Slaby <jirislaby@gmail.com> |
| 4001 | M: jirislaby@gmail.com | ||
| 4002 | S: Maintained | 3450 | S: Maintained |
| 4003 | F: drivers/char/isicom.c | 3451 | F: drivers/char/isicom.c |
| 4004 | F: include/linux/isicom.h | 3452 | F: include/linux/isicom.h |
| 4005 | 3453 | ||
| 4006 | MUSB MULTIPOINT HIGH SPEED DUAL-ROLE CONTROLLER | 3454 | MUSB MULTIPOINT HIGH SPEED DUAL-ROLE CONTROLLER |
| 4007 | P: Felipe Balbi | 3455 | M: Felipe Balbi <felipe.balbi@nokia.com> |
| 4008 | M: felipe.balbi@nokia.com | ||
| 4009 | L: linux-usb@vger.kernel.org | 3456 | L: linux-usb@vger.kernel.org |
| 4010 | T: git git://gitorious.org/musb/mainline.git | 3457 | T: git git://gitorious.org/musb/mainline.git |
| 4011 | S: Maintained | 3458 | S: Maintained |
| 4012 | F: drivers/usb/musb/ | 3459 | F: drivers/usb/musb/ |
| 4013 | 3460 | ||
| 4014 | MYRICOM MYRI-10G 10GbE DRIVER (MYRI10GE) | 3461 | MYRICOM MYRI-10G 10GbE DRIVER (MYRI10GE) |
| 4015 | P: Andrew Gallatin | 3462 | M: Andrew Gallatin <gallatin@myri.com> |
| 4016 | M: gallatin@myri.com | 3463 | M: Brice Goglin <brice@myri.com> |
| 4017 | P: Brice Goglin | ||
| 4018 | M: brice@myri.com | ||
| 4019 | L: netdev@vger.kernel.org | 3464 | L: netdev@vger.kernel.org |
| 4020 | W: http://www.myri.com/scs/download-Myri10GE.html | 3465 | W: http://www.myri.com/scs/download-Myri10GE.html |
| 4021 | S: Supported | 3466 | S: Supported |
| 4022 | F: drivers/net/myri10ge/ | 3467 | F: drivers/net/myri10ge/ |
| 4023 | 3468 | ||
| 4024 | NATSEMI ETHERNET DRIVER (DP8381x) | 3469 | NATSEMI ETHERNET DRIVER (DP8381x) |
| 4025 | P: Tim Hockin | 3470 | M: Tim Hockin <thockin@hockin.org> |
| 4026 | M: thockin@hockin.org | ||
| 4027 | S: Maintained | 3471 | S: Maintained |
| 4028 | F: drivers/net/natsemi.c | 3472 | F: drivers/net/natsemi.c |
| 4029 | 3473 | ||
| 4030 | NCP FILESYSTEM | 3474 | NCP FILESYSTEM |
| 4031 | P: Petr Vandrovec | 3475 | M: Petr Vandrovec <vandrove@vc.cvut.cz> |
| 4032 | M: vandrove@vc.cvut.cz | ||
| 4033 | L: linware@sh.cvut.cz | 3476 | L: linware@sh.cvut.cz |
| 4034 | S: Maintained | 3477 | S: Maintained |
| 4035 | F: fs/ncpfs/ | 3478 | F: fs/ncpfs/ |
| 4036 | 3479 | ||
| 4037 | NCR DUAL 700 SCSI DRIVER (MICROCHANNEL) | 3480 | NCR DUAL 700 SCSI DRIVER (MICROCHANNEL) |
| 4038 | P: James E.J. Bottomley | 3481 | M: "James E.J. Bottomley" <James.Bottomley@HansenPartnership.com> |
| 4039 | M: James.Bottomley@HansenPartnership.com | ||
| 4040 | L: linux-scsi@vger.kernel.org | 3482 | L: linux-scsi@vger.kernel.org |
| 4041 | S: Maintained | 3483 | S: Maintained |
| 4042 | F: drivers/scsi/NCR_D700.* | 3484 | F: drivers/scsi/NCR_D700.* |
| 4043 | 3485 | ||
| 4044 | NETEFFECT IWARP RNIC DRIVER (IW_NES) | 3486 | NETEFFECT IWARP RNIC DRIVER (IW_NES) |
| 4045 | P: Faisal Latif | 3487 | M: Faisal Latif <faisal.latif@intel.com> |
| 4046 | M: faisal.latif@intel.com | 3488 | M: Chien Tung <chien.tin.tung@intel.com> |
| 4047 | P: Chien Tung | ||
| 4048 | M: chien.tin.tung@intel.com | ||
| 4049 | L: general@lists.openfabrics.org | 3489 | L: general@lists.openfabrics.org |
| 4050 | W: http://www.neteffect.com | 3490 | W: http://www.neteffect.com |
| 4051 | S: Supported | 3491 | S: Supported |
| 4052 | F: drivers/infiniband/hw/nes/ | 3492 | F: drivers/infiniband/hw/nes/ |
| 4053 | 3493 | ||
| 4054 | NETEM NETWORK EMULATOR | 3494 | NETEM NETWORK EMULATOR |
| 4055 | P: Stephen Hemminger | 3495 | M: Stephen Hemminger <shemminger@linux-foundation.org> |
| 4056 | M: shemminger@linux-foundation.org | ||
| 4057 | L: netem@lists.linux-foundation.org | 3496 | L: netem@lists.linux-foundation.org |
| 4058 | S: Maintained | 3497 | S: Maintained |
| 4059 | F: net/sched/sch_netem.c | 3498 | F: net/sched/sch_netem.c |
| 4060 | 3499 | ||
| 4061 | NETERION (S2IO) 10GbE DRIVER (xframe/vxge) | 3500 | NETERION (S2IO) 10GbE DRIVER (xframe/vxge) |
| 4062 | P: Ramkrishna Vepa | 3501 | M: Ramkrishna Vepa <ram.vepa@neterion.com> |
| 4063 | M: ram.vepa@neterion.com | 3502 | M: Rastapur Santosh <santosh.rastapur@neterion.com> |
| 4064 | P: Rastapur Santosh | 3503 | M: Sivakumar Subramani <sivakumar.subramani@neterion.com> |
| 4065 | M: santosh.rastapur@neterion.com | 3504 | M: Sreenivasa Honnur <sreenivasa.honnur@neterion.com> |
| 4066 | P: Sivakumar Subramani | 3505 | M: Anil Murthy <anil.murthy@neterion.com> |
| 4067 | M: sivakumar.subramani@neterion.com | ||
| 4068 | P: Sreenivasa Honnur | ||
| 4069 | M: sreenivasa.honnur@neterion.com | ||
| 4070 | P: Anil Murthy | ||
| 4071 | M: anil.murthy@neterion.com | ||
| 4072 | L: netdev@vger.kernel.org | 3506 | L: netdev@vger.kernel.org |
| 4073 | W: http://trac.neterion.com/cgi-bin/trac.cgi/wiki/Linux?Anonymous | 3507 | W: http://trac.neterion.com/cgi-bin/trac.cgi/wiki/Linux?Anonymous |
| 4074 | W: http://trac.neterion.com/cgi-bin/trac.cgi/wiki/X3100Linux?Anonymous | 3508 | W: http://trac.neterion.com/cgi-bin/trac.cgi/wiki/X3100Linux?Anonymous |
| @@ -4082,13 +3516,13 @@ P: Marc Boucher | |||
| 4082 | P: James Morris | 3516 | P: James Morris |
| 4083 | P: Harald Welte | 3517 | P: Harald Welte |
| 4084 | P: Jozsef Kadlecsik | 3518 | P: Jozsef Kadlecsik |
| 4085 | P: Patrick McHardy | 3519 | M: Patrick McHardy <kaber@trash.net> |
| 4086 | M: kaber@trash.net | ||
| 4087 | L: netfilter-devel@vger.kernel.org | 3520 | L: netfilter-devel@vger.kernel.org |
| 4088 | L: netfilter@vger.kernel.org | 3521 | L: netfilter@vger.kernel.org |
| 4089 | L: coreteam@netfilter.org | 3522 | L: coreteam@netfilter.org |
| 4090 | W: http://www.netfilter.org/ | 3523 | W: http://www.netfilter.org/ |
| 4091 | W: http://www.iptables.org/ | 3524 | W: http://www.iptables.org/ |
| 3525 | T: git://git.kernel.org/pub/scm/linux/kernel/git/kaber/nf-2.6.git | ||
| 4092 | S: Supported | 3526 | S: Supported |
| 4093 | F: include/linux/netfilter* | 3527 | F: include/linux/netfilter* |
| 4094 | F: include/linux/netfilter/ | 3528 | F: include/linux/netfilter/ |
| @@ -4098,8 +3532,7 @@ F: net/*/netfilter/ | |||
| 4098 | F: net/netfilter/ | 3532 | F: net/netfilter/ |
| 4099 | 3533 | ||
| 4100 | NETLABEL | 3534 | NETLABEL |
| 4101 | P: Paul Moore | 3535 | M: Paul Moore <paul.moore@hp.com> |
| 4102 | M: paul.moore@hp.com | ||
| 4103 | W: http://netlabel.sf.net | 3536 | W: http://netlabel.sf.net |
| 4104 | L: netdev@vger.kernel.org | 3537 | L: netdev@vger.kernel.org |
| 4105 | S: Supported | 3538 | S: Supported |
| @@ -4108,8 +3541,7 @@ F: include/net/netlabel.h | |||
| 4108 | F: net/netlabel/ | 3541 | F: net/netlabel/ |
| 4109 | 3542 | ||
| 4110 | NETROM NETWORK LAYER | 3543 | NETROM NETWORK LAYER |
| 4111 | P: Ralf Baechle | 3544 | M: Ralf Baechle <ralf@linux-mips.org> |
| 4112 | M: ralf@linux-mips.org | ||
| 4113 | L: linux-hams@vger.kernel.org | 3545 | L: linux-hams@vger.kernel.org |
| 4114 | W: http://www.linux-ax25.org/ | 3546 | W: http://www.linux-ax25.org/ |
| 4115 | S: Maintained | 3547 | S: Maintained |
| @@ -4118,36 +3550,31 @@ F: include/net/netrom.h | |||
| 4118 | F: net/netrom/ | 3550 | F: net/netrom/ |
| 4119 | 3551 | ||
| 4120 | NETWORK BLOCK DEVICE (NBD) | 3552 | NETWORK BLOCK DEVICE (NBD) |
| 4121 | P: Paul Clements | 3553 | M: Paul Clements <Paul.Clements@steeleye.com> |
| 4122 | M: Paul.Clements@steeleye.com | ||
| 4123 | S: Maintained | 3554 | S: Maintained |
| 4124 | F: Documentation/blockdev/nbd.txt | 3555 | F: Documentation/blockdev/nbd.txt |
| 4125 | F: drivers/block/nbd.c | 3556 | F: drivers/block/nbd.c |
| 4126 | F: include/linux/nbd.h | 3557 | F: include/linux/nbd.h |
| 4127 | 3558 | ||
| 4128 | NETWORKING [GENERAL] | 3559 | NETWORKING [GENERAL] |
| 4129 | P: David S. Miller | 3560 | M: "David S. Miller" <davem@davemloft.net> |
| 4130 | M: davem@davemloft.net | ||
| 4131 | L: netdev@vger.kernel.org | 3561 | L: netdev@vger.kernel.org |
| 4132 | W: http://www.linuxfoundation.org/en/Net | 3562 | W: http://www.linuxfoundation.org/en/Net |
| 4133 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6.git | 3563 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6.git |
| 4134 | S: Maintained | 3564 | S: Maintained |
| 4135 | F: net/ | 3565 | F: net/ |
| 4136 | F: include/net/ | 3566 | F: include/net/ |
| 3567 | F: include/linux/in.h | ||
| 3568 | F: include/linux/net.h | ||
| 3569 | F: include/linux/netdevice.h | ||
| 4137 | 3570 | ||
| 4138 | NETWORKING [IPv4/IPv6] | 3571 | NETWORKING [IPv4/IPv6] |
| 4139 | P: David S. Miller | 3572 | M: "David S. Miller" <davem@davemloft.net> |
| 4140 | M: davem@davemloft.net | 3573 | M: Alexey Kuznetsov <kuznet@ms2.inr.ac.ru> |
| 4141 | P: Alexey Kuznetsov | 3574 | M: "Pekka Savola (ipv6)" <pekkas@netcore.fi> |
| 4142 | M: kuznet@ms2.inr.ac.ru | 3575 | M: James Morris <jmorris@namei.org> |
| 4143 | P: Pekka Savola (ipv6) | 3576 | M: Hideaki YOSHIFUJI <yoshfuji@linux-ipv6.org> |
| 4144 | M: pekkas@netcore.fi | 3577 | M: Patrick McHardy <kaber@trash.net> |
| 4145 | P: James Morris | ||
| 4146 | M: jmorris@namei.org | ||
| 4147 | P: Hideaki YOSHIFUJI | ||
| 4148 | M: yoshfuji@linux-ipv6.org | ||
| 4149 | P: Patrick McHardy | ||
| 4150 | M: kaber@trash.net | ||
| 4151 | L: netdev@vger.kernel.org | 3578 | L: netdev@vger.kernel.org |
| 4152 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6.git | 3579 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6.git |
| 4153 | S: Maintained | 3580 | S: Maintained |
| @@ -4156,14 +3583,12 @@ F: net/ipv6/ | |||
| 4156 | F: include/net/ip* | 3583 | F: include/net/ip* |
| 4157 | 3584 | ||
| 4158 | NETWORKING [LABELED] (NetLabel, CIPSO, Labeled IPsec, SECMARK) | 3585 | NETWORKING [LABELED] (NetLabel, CIPSO, Labeled IPsec, SECMARK) |
| 4159 | P: Paul Moore | 3586 | M: Paul Moore <paul.moore@hp.com> |
| 4160 | M: paul.moore@hp.com | ||
| 4161 | L: netdev@vger.kernel.org | 3587 | L: netdev@vger.kernel.org |
| 4162 | S: Maintained | 3588 | S: Maintained |
| 4163 | 3589 | ||
| 4164 | NETWORKING [WIRELESS] | 3590 | NETWORKING [WIRELESS] |
| 4165 | P: John W. Linville | 3591 | M: "John W. Linville" <linville@tuxdriver.com> |
| 4166 | M: linville@tuxdriver.com | ||
| 4167 | L: linux-wireless@vger.kernel.org | 3592 | L: linux-wireless@vger.kernel.org |
| 4168 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6.git | 3593 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6.git |
| 4169 | S: Maintained | 3594 | S: Maintained |
| @@ -4177,18 +3602,18 @@ W: http://www.linuxfoundation.org/en/Net | |||
| 4177 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6.git | 3602 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6.git |
| 4178 | S: Odd Fixes | 3603 | S: Odd Fixes |
| 4179 | F: drivers/net/ | 3604 | F: drivers/net/ |
| 3605 | F: include/linux/if_* | ||
| 3606 | F: include/linux/*device.h | ||
| 4180 | 3607 | ||
| 4181 | NETXEN (1/10) GbE SUPPORT | 3608 | NETXEN (1/10) GbE SUPPORT |
| 4182 | P: Dhananjay Phadke | 3609 | M: Dhananjay Phadke <dhananjay@netxen.com> |
| 4183 | M: dhananjay@netxen.com | ||
| 4184 | L: netdev@vger.kernel.org | 3610 | L: netdev@vger.kernel.org |
| 4185 | W: http://www.netxen.com | 3611 | W: http://www.netxen.com |
| 4186 | S: Supported | 3612 | S: Supported |
| 4187 | F: drivers/net/netxen/ | 3613 | F: drivers/net/netxen/ |
| 4188 | 3614 | ||
| 4189 | NFS, SUNRPC, AND LOCKD CLIENTS | 3615 | NFS, SUNRPC, AND LOCKD CLIENTS |
| 4190 | P: Trond Myklebust | 3616 | M: Trond Myklebust <Trond.Myklebust@netapp.com> |
| 4191 | M: Trond.Myklebust@netapp.com | ||
| 4192 | L: linux-nfs@vger.kernel.org | 3617 | L: linux-nfs@vger.kernel.org |
| 4193 | W: http://client.linux-nfs.org | 3618 | W: http://client.linux-nfs.org |
| 4194 | T: git git://git.linux-nfs.org/pub/linux/nfs-2.6.git | 3619 | T: git git://git.linux-nfs.org/pub/linux/nfs-2.6.git |
| @@ -4202,17 +3627,14 @@ F: include/linux/nfs* | |||
| 4202 | F: include/linux/sunrpc/ | 3627 | F: include/linux/sunrpc/ |
| 4203 | 3628 | ||
| 4204 | NI5010 NETWORK DRIVER | 3629 | NI5010 NETWORK DRIVER |
| 4205 | P: Jan-Pascal van Best | 3630 | M: Jan-Pascal van Best <janpascal@vanbest.org> |
| 4206 | M: janpascal@vanbest.org | 3631 | M: Andreas Mohr <andi@lisas.de> |
| 4207 | P: Andreas Mohr | ||
| 4208 | M: andi@lisas.de | ||
| 4209 | L: netdev@vger.kernel.org | 3632 | L: netdev@vger.kernel.org |
| 4210 | S: Maintained | 3633 | S: Maintained |
| 4211 | F: drivers/net/ni5010.* | 3634 | F: drivers/net/ni5010.* |
| 4212 | 3635 | ||
| 4213 | NILFS2 FILESYSTEM | 3636 | NILFS2 FILESYSTEM |
| 4214 | P: KONISHI Ryusuke | 3637 | M: KONISHI Ryusuke <konishi.ryusuke@lab.ntt.co.jp> |
| 4215 | M: konishi.ryusuke@lab.ntt.co.jp | ||
| 4216 | L: users@nilfs.org | 3638 | L: users@nilfs.org |
| 4217 | W: http://www.nilfs.org/en/ | 3639 | W: http://www.nilfs.org/en/ |
| 4218 | S: Supported | 3640 | S: Supported |
| @@ -4221,26 +3643,22 @@ F: fs/nilfs2/ | |||
| 4221 | F: include/linux/nilfs2_fs.h | 3643 | F: include/linux/nilfs2_fs.h |
| 4222 | 3644 | ||
| 4223 | NINJA SCSI-3 / NINJA SCSI-32Bi (16bit/CardBus) PCMCIA SCSI HOST ADAPTER DRIVER | 3645 | NINJA SCSI-3 / NINJA SCSI-32Bi (16bit/CardBus) PCMCIA SCSI HOST ADAPTER DRIVER |
| 4224 | P: YOKOTA Hiroshi | 3646 | M: YOKOTA Hiroshi <yokota@netlab.is.tsukuba.ac.jp> |
| 4225 | M: yokota@netlab.is.tsukuba.ac.jp | ||
| 4226 | W: http://www.netlab.is.tsukuba.ac.jp/~yokota/izumi/ninja/ | 3647 | W: http://www.netlab.is.tsukuba.ac.jp/~yokota/izumi/ninja/ |
| 4227 | S: Maintained | 3648 | S: Maintained |
| 4228 | F: Documentation/scsi/NinjaSCSI.txt | 3649 | F: Documentation/scsi/NinjaSCSI.txt |
| 4229 | F: drivers/scsi/pcmcia/nsp_* | 3650 | F: drivers/scsi/pcmcia/nsp_* |
| 4230 | 3651 | ||
| 4231 | NINJA SCSI-32Bi/UDE PCI/CARDBUS SCSI HOST ADAPTER DRIVER | 3652 | NINJA SCSI-32Bi/UDE PCI/CARDBUS SCSI HOST ADAPTER DRIVER |
| 4232 | P: GOTO Masanori | 3653 | M: GOTO Masanori <gotom@debian.or.jp> |
| 4233 | M: gotom@debian.or.jp | 3654 | M: YOKOTA Hiroshi <yokota@netlab.is.tsukuba.ac.jp> |
| 4234 | P: YOKOTA Hiroshi | ||
| 4235 | M: yokota@netlab.is.tsukuba.ac.jp | ||
| 4236 | W: http://www.netlab.is.tsukuba.ac.jp/~yokota/izumi/ninja/ | 3655 | W: http://www.netlab.is.tsukuba.ac.jp/~yokota/izumi/ninja/ |
| 4237 | S: Maintained | 3656 | S: Maintained |
| 4238 | F: Documentation/scsi/NinjaSCSI.txt | 3657 | F: Documentation/scsi/NinjaSCSI.txt |
| 4239 | F: drivers/scsi/nsp32* | 3658 | F: drivers/scsi/nsp32* |
| 4240 | 3659 | ||
| 4241 | NTFS FILESYSTEM | 3660 | NTFS FILESYSTEM |
| 4242 | P: Anton Altaparmakov | 3661 | M: Anton Altaparmakov <aia21@cantab.net> |
| 4243 | M: aia21@cantab.net | ||
| 4244 | L: linux-ntfs-dev@lists.sourceforge.net | 3662 | L: linux-ntfs-dev@lists.sourceforge.net |
| 4245 | W: http://www.linux-ntfs.org/ | 3663 | W: http://www.linux-ntfs.org/ |
| 4246 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/aia21/ntfs-2.6.git | 3664 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/aia21/ntfs-2.6.git |
| @@ -4249,16 +3667,14 @@ F: Documentation/filesystems/ntfs.txt | |||
| 4249 | F: fs/ntfs/ | 3667 | F: fs/ntfs/ |
| 4250 | 3668 | ||
| 4251 | NVIDIA (rivafb and nvidiafb) FRAMEBUFFER DRIVER | 3669 | NVIDIA (rivafb and nvidiafb) FRAMEBUFFER DRIVER |
| 4252 | P: Antonino Daplas | 3670 | M: Antonino Daplas <adaplas@gmail.com> |
| 4253 | M: adaplas@gmail.com | ||
| 4254 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) | 3671 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 4255 | S: Maintained | 3672 | S: Maintained |
| 4256 | F: drivers/video/riva/ | 3673 | F: drivers/video/riva/ |
| 4257 | F: drivers/video/nvidia/ | 3674 | F: drivers/video/nvidia/ |
| 4258 | 3675 | ||
| 4259 | OMAP SUPPORT | 3676 | OMAP SUPPORT |
| 4260 | P: Tony Lindgren <tony@atomide.com> | 3677 | M: "Tony Lindgren <tony@atomide.com>" <tony@atomide.com> |
| 4261 | M: tony@atomide.com | ||
| 4262 | L: linux-omap@vger.kernel.org | 3678 | L: linux-omap@vger.kernel.org |
| 4263 | W: http://www.muru.com/linux/omap/ | 3679 | W: http://www.muru.com/linux/omap/ |
| 4264 | W: http://linux.omap.com/ | 3680 | W: http://linux.omap.com/ |
| @@ -4267,98 +3683,83 @@ S: Maintained | |||
| 4267 | F: arch/arm/*omap* | 3683 | F: arch/arm/*omap* |
| 4268 | 3684 | ||
| 4269 | OMAP CLOCK FRAMEWORK SUPPORT | 3685 | OMAP CLOCK FRAMEWORK SUPPORT |
| 4270 | P: Paul Walmsley | 3686 | M: Paul Walmsley <paul@pwsan.com> |
| 4271 | M: paul@pwsan.com | ||
| 4272 | L: linux-omap@vger.kernel.org | 3687 | L: linux-omap@vger.kernel.org |
| 4273 | S: Maintained | 3688 | S: Maintained |
| 4274 | F: arch/arm/*omap*/*clock* | 3689 | F: arch/arm/*omap*/*clock* |
| 4275 | 3690 | ||
| 4276 | OMAP POWER MANAGEMENT SUPPORT | 3691 | OMAP POWER MANAGEMENT SUPPORT |
| 4277 | P: Kevin Hilman | 3692 | M: Kevin Hilman <khilman@deeprootsystems.com> |
| 4278 | M: khilman@deeprootsystems.com | ||
| 4279 | L: linux-omap@vger.kernel.org | 3693 | L: linux-omap@vger.kernel.org |
| 4280 | S: Maintained | 3694 | S: Maintained |
| 4281 | F: arch/arm/*omap*/*pm* | 3695 | F: arch/arm/*omap*/*pm* |
| 4282 | 3696 | ||
| 4283 | OMAP AUDIO SUPPORT | 3697 | OMAP AUDIO SUPPORT |
| 4284 | P: Jarkko Nikula | 3698 | M: Jarkko Nikula <jhnikula@gmail.com> |
| 4285 | M: jhnikula@gmail.com | ||
| 4286 | L: alsa-devel@alsa-project.org (subscribers-only) | 3699 | L: alsa-devel@alsa-project.org (subscribers-only) |
| 4287 | L: linux-omap@vger.kernel.org | 3700 | L: linux-omap@vger.kernel.org |
| 4288 | S: Maintained | 3701 | S: Maintained |
| 4289 | F: sound/soc/omap/ | 3702 | F: sound/soc/omap/ |
| 4290 | 3703 | ||
| 4291 | OMAP FRAMEBUFFER SUPPORT | 3704 | OMAP FRAMEBUFFER SUPPORT |
| 4292 | P: Imre Deak | 3705 | M: Imre Deak <imre.deak@nokia.com> |
| 4293 | M: imre.deak@nokia.com | ||
| 4294 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) | 3706 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 4295 | L: linux-omap@vger.kernel.org | 3707 | L: linux-omap@vger.kernel.org |
| 4296 | S: Maintained | 3708 | S: Maintained |
| 4297 | F: drivers/video/omap/ | 3709 | F: drivers/video/omap/ |
| 4298 | 3710 | ||
| 4299 | OMAP MMC SUPPORT | 3711 | OMAP MMC SUPPORT |
| 4300 | P: Jarkko Lavinen | 3712 | M: Jarkko Lavinen <jarkko.lavinen@nokia.com> |
| 4301 | M: jarkko.lavinen@nokia.com | ||
| 4302 | L: linux-kernel@vger.kernel.org | ||
| 4303 | L: linux-omap@vger.kernel.org | 3713 | L: linux-omap@vger.kernel.org |
| 4304 | S: Maintained | 3714 | S: Maintained |
| 4305 | F: drivers/mmc/host/*omap* | 3715 | F: drivers/mmc/host/*omap* |
| 4306 | 3716 | ||
| 4307 | OMAP RANDOM NUMBER GENERATOR SUPPORT | 3717 | OMAP RANDOM NUMBER GENERATOR SUPPORT |
| 4308 | P: Deepak Saxena | 3718 | M: Deepak Saxena <dsaxena@plexity.net> |
| 4309 | M: dsaxena@plexity.net | ||
| 4310 | S: Maintained | 3719 | S: Maintained |
| 4311 | F: drivers/char/hw_random/omap-rng.c | 3720 | F: drivers/char/hw_random/omap-rng.c |
| 4312 | 3721 | ||
| 4313 | OMAP USB SUPPORT | 3722 | OMAP USB SUPPORT |
| 4314 | P: Felipe Balbi | 3723 | M: Felipe Balbi <felipe.balbi@nokia.com> |
| 4315 | M: felipe.balbi@nokia.com | 3724 | M: David Brownell <dbrownell@users.sourceforge.net> |
| 4316 | P: David Brownell | ||
| 4317 | M: dbrownell@users.sourceforge.net | ||
| 4318 | L: linux-usb@vger.kernel.org | 3725 | L: linux-usb@vger.kernel.org |
| 4319 | L: linux-omap@vger.kernel.org | 3726 | L: linux-omap@vger.kernel.org |
| 4320 | S: Maintained | 3727 | S: Maintained |
| 4321 | 3728 | ||
| 4322 | OMFS FILESYSTEM | 3729 | OMFS FILESYSTEM |
| 4323 | P: Bob Copeland | 3730 | M: Bob Copeland <me@bobcopeland.com> |
| 4324 | M: me@bobcopeland.com | ||
| 4325 | L: linux-karma-devel@lists.sourceforge.net | 3731 | L: linux-karma-devel@lists.sourceforge.net |
| 4326 | S: Maintained | 3732 | S: Maintained |
| 4327 | F: Documentation/filesystems/omfs.txt | 3733 | F: Documentation/filesystems/omfs.txt |
| 4328 | F: fs/omfs/ | 3734 | F: fs/omfs/ |
| 4329 | 3735 | ||
| 4330 | OMNIKEY CARDMAN 4000 DRIVER | 3736 | OMNIKEY CARDMAN 4000 DRIVER |
| 4331 | P: Harald Welte | 3737 | M: Harald Welte <laforge@gnumonks.org> |
| 4332 | M: laforge@gnumonks.org | ||
| 4333 | S: Maintained | 3738 | S: Maintained |
| 4334 | F: drivers/char/pcmcia/cm4000_cs.c | 3739 | F: drivers/char/pcmcia/cm4000_cs.c |
| 4335 | F: include/linux/cm4000_cs.h | 3740 | F: include/linux/cm4000_cs.h |
| 4336 | 3741 | ||
| 4337 | OMNIKEY CARDMAN 4040 DRIVER | 3742 | OMNIKEY CARDMAN 4040 DRIVER |
| 4338 | P: Harald Welte | 3743 | M: Harald Welte <laforge@gnumonks.org> |
| 4339 | M: laforge@gnumonks.org | ||
| 4340 | S: Maintained | 3744 | S: Maintained |
| 4341 | F: drivers/char/pcmcia/cm4040_cs.* | 3745 | F: drivers/char/pcmcia/cm4040_cs.* |
| 4342 | 3746 | ||
| 4343 | OMNIVISION OV7670 SENSOR DRIVER | 3747 | OMNIVISION OV7670 SENSOR DRIVER |
| 4344 | P: Jonathan Corbet | 3748 | M: Jonathan Corbet <corbet@lwn.net> |
| 4345 | M: corbet@lwn.net | ||
| 4346 | L: linux-media@vger.kernel.org | 3749 | L: linux-media@vger.kernel.org |
| 4347 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 3750 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| 4348 | S: Maintained | 3751 | S: Maintained |
| 4349 | F: drivers/media/video/ov7670.c | 3752 | F: drivers/media/video/ov7670.c |
| 4350 | 3753 | ||
| 4351 | ONENAND FLASH DRIVER | 3754 | ONENAND FLASH DRIVER |
| 4352 | P: Kyungmin Park | 3755 | M: Kyungmin Park <kyungmin.park@samsung.com> |
| 4353 | M: kyungmin.park@samsung.com | ||
| 4354 | L: linux-mtd@lists.infradead.org | 3756 | L: linux-mtd@lists.infradead.org |
| 4355 | S: Maintained | 3757 | S: Maintained |
| 4356 | F: drivers/mtd/onenand/ | 3758 | F: drivers/mtd/onenand/ |
| 4357 | F: include/linux/mtd/onenand*.h | 3759 | F: include/linux/mtd/onenand*.h |
| 4358 | 3760 | ||
| 4359 | ONSTREAM SCSI TAPE DRIVER | 3761 | ONSTREAM SCSI TAPE DRIVER |
| 4360 | P: Willem Riede | 3762 | M: Willem Riede <osst@riede.org> |
| 4361 | M: osst@riede.org | ||
| 4362 | L: osst-users@lists.sourceforge.net | 3763 | L: osst-users@lists.sourceforge.net |
| 4363 | L: linux-scsi@vger.kernel.org | 3764 | L: linux-scsi@vger.kernel.org |
| 4364 | S: Maintained | 3765 | S: Maintained |
| @@ -4366,16 +3767,14 @@ F: drivers/scsi/osst* | |||
| 4366 | F: drivers/scsi/st* | 3767 | F: drivers/scsi/st* |
| 4367 | 3768 | ||
| 4368 | OPENCORES I2C BUS DRIVER | 3769 | OPENCORES I2C BUS DRIVER |
| 4369 | P: Peter Korsgaard | 3770 | M: Peter Korsgaard <jacmet@sunsite.dk> |
| 4370 | M: jacmet@sunsite.dk | ||
| 4371 | L: linux-i2c@vger.kernel.org | 3771 | L: linux-i2c@vger.kernel.org |
| 4372 | S: Maintained | 3772 | S: Maintained |
| 4373 | F: Documentation/i2c/busses/i2c-ocores | 3773 | F: Documentation/i2c/busses/i2c-ocores |
| 4374 | F: drivers/i2c/busses/i2c-ocores.c | 3774 | F: drivers/i2c/busses/i2c-ocores.c |
| 4375 | 3775 | ||
| 4376 | OPROFILE | 3776 | OPROFILE |
| 4377 | P: Robert Richter | 3777 | M: Robert Richter <robert.richter@amd.com> |
| 4378 | M: robert.richter@amd.com | ||
| 4379 | L: oprofile-list@lists.sf.net | 3778 | L: oprofile-list@lists.sf.net |
| 4380 | S: Maintained | 3779 | S: Maintained |
| 4381 | F: arch/*/oprofile/ | 3780 | F: arch/*/oprofile/ |
| @@ -4383,10 +3782,8 @@ F: drivers/oprofile/ | |||
| 4383 | F: include/linux/oprofile.h | 3782 | F: include/linux/oprofile.h |
| 4384 | 3783 | ||
| 4385 | ORACLE CLUSTER FILESYSTEM 2 (OCFS2) | 3784 | ORACLE CLUSTER FILESYSTEM 2 (OCFS2) |
| 4386 | P: Mark Fasheh | 3785 | M: Mark Fasheh <mfasheh@suse.com> |
| 4387 | M: mfasheh@suse.com | 3786 | M: Joel Becker <joel.becker@oracle.com> |
| 4388 | P: Joel Becker | ||
| 4389 | M: joel.becker@oracle.com | ||
| 4390 | L: ocfs2-devel@oss.oracle.com (moderated for non-subscribers) | 3787 | L: ocfs2-devel@oss.oracle.com (moderated for non-subscribers) |
| 4391 | W: http://oss.oracle.com/projects/ocfs2/ | 3788 | W: http://oss.oracle.com/projects/ocfs2/ |
| 4392 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jlbec/ocfs2.git | 3789 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jlbec/ocfs2.git |
| @@ -4396,10 +3793,8 @@ F: Documentation/filesystems/dlmfs.txt | |||
| 4396 | F: fs/ocfs2/ | 3793 | F: fs/ocfs2/ |
| 4397 | 3794 | ||
| 4398 | ORINOCO DRIVER | 3795 | ORINOCO DRIVER |
| 4399 | P: Pavel Roskin | 3796 | M: Pavel Roskin <proski@gnu.org> |
| 4400 | M: proski@gnu.org | 3797 | M: David Gibson <hermes@gibson.dropbear.id.au> |
| 4401 | P: David Gibson | ||
| 4402 | M: hermes@gibson.dropbear.id.au | ||
| 4403 | L: linux-wireless@vger.kernel.org | 3798 | L: linux-wireless@vger.kernel.org |
| 4404 | L: orinoco-users@lists.sourceforge.net | 3799 | L: orinoco-users@lists.sourceforge.net |
| 4405 | L: orinoco-devel@lists.sourceforge.net | 3800 | L: orinoco-devel@lists.sourceforge.net |
| @@ -4408,21 +3803,18 @@ S: Maintained | |||
| 4408 | F: drivers/net/wireless/orinoco/ | 3803 | F: drivers/net/wireless/orinoco/ |
| 4409 | 3804 | ||
| 4410 | OSD LIBRARY and FILESYSTEM | 3805 | OSD LIBRARY and FILESYSTEM |
| 4411 | P: Boaz Harrosh | 3806 | M: Boaz Harrosh <bharrosh@panasas.com> |
| 4412 | M: bharrosh@panasas.com | 3807 | M: Benny Halevy <bhalevy@panasas.com> |
| 4413 | P: Benny Halevy | ||
| 4414 | M: bhalevy@panasas.com | ||
| 4415 | L: osd-dev@open-osd.org | 3808 | L: osd-dev@open-osd.org |
| 4416 | W: http://open-osd.org | 3809 | W: http://open-osd.org |
| 4417 | T: git git://git.open-osd.org/open-osd.git | 3810 | T: git git://git.open-osd.org/open-osd.git |
| 4418 | S: Maintained | 3811 | S: Maintained |
| 4419 | F: drivers/scsi/osd/ | 3812 | F: drivers/scsi/osd/ |
| 4420 | F: drivers/include/scsi/osd_* | 3813 | F: include/scsi/osd_* |
| 4421 | F: fs/exofs/ | 3814 | F: fs/exofs/ |
| 4422 | 3815 | ||
| 4423 | P54 WIRELESS DRIVER | 3816 | P54 WIRELESS DRIVER |
| 4424 | P: Michael Wu | 3817 | M: Michael Wu <flamingice@sourmilk.net> |
| 4425 | M: flamingice@sourmilk.net | ||
| 4426 | L: linux-wireless@vger.kernel.org | 3818 | L: linux-wireless@vger.kernel.org |
| 4427 | W: http://prism54.org | 3819 | W: http://prism54.org |
| 4428 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mwu/mac80211-drivers.git | 3820 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mwu/mac80211-drivers.git |
| @@ -4430,30 +3822,25 @@ S: Maintained | |||
| 4430 | F: drivers/net/wireless/p54/ | 3822 | F: drivers/net/wireless/p54/ |
| 4431 | 3823 | ||
| 4432 | PA SEMI ETHERNET DRIVER | 3824 | PA SEMI ETHERNET DRIVER |
| 4433 | P: Olof Johansson | 3825 | M: Olof Johansson <olof@lixom.net> |
| 4434 | M: olof@lixom.net | ||
| 4435 | L: netdev@vger.kernel.org | 3826 | L: netdev@vger.kernel.org |
| 4436 | S: Maintained | 3827 | S: Maintained |
| 4437 | F: drivers/net/pasemi_mac.* | 3828 | F: drivers/net/pasemi_mac.* |
| 4438 | 3829 | ||
| 4439 | PA SEMI SMBUS DRIVER | 3830 | PA SEMI SMBUS DRIVER |
| 4440 | P: Olof Johansson | 3831 | M: Olof Johansson <olof@lixom.net> |
| 4441 | M: olof@lixom.net | ||
| 4442 | L: linux-i2c@vger.kernel.org | 3832 | L: linux-i2c@vger.kernel.org |
| 4443 | S: Maintained | 3833 | S: Maintained |
| 4444 | F: drivers/i2c/busses/i2c-pasemi.c | 3834 | F: drivers/i2c/busses/i2c-pasemi.c |
| 4445 | 3835 | ||
| 4446 | PANASONIC LAPTOP ACPI EXTRAS DRIVER | 3836 | PANASONIC LAPTOP ACPI EXTRAS DRIVER |
| 4447 | P: Harald Welte | 3837 | M: Harald Welte <laforge@gnumonks.org> |
| 4448 | M: laforge@gnumonks.org | ||
| 4449 | S: Maintained | 3838 | S: Maintained |
| 4450 | F: drivers/platform/x86/panasonic-laptop.c | 3839 | F: drivers/platform/x86/panasonic-laptop.c |
| 4451 | 3840 | ||
| 4452 | PANASONIC MN10300/AM33 PORT | 3841 | PANASONIC MN10300/AM33 PORT |
| 4453 | P: David Howells | 3842 | M: David Howells <dhowells@redhat.com> |
| 4454 | M: dhowells@redhat.com | 3843 | M: Koichi Yasutake <yasutake.koichi@jp.panasonic.com> |
| 4455 | P: Koichi Yasutake | ||
| 4456 | M: yasutake.koichi@jp.panasonic.com | ||
| 4457 | L: linux-am33-list@redhat.com (moderated for non-subscribers) | 3844 | L: linux-am33-list@redhat.com (moderated for non-subscribers) |
| 4458 | W: ftp://ftp.redhat.com/pub/redhat/gnupro/AM33/ | 3845 | W: ftp://ftp.redhat.com/pub/redhat/gnupro/AM33/ |
| 4459 | S: Maintained | 3846 | S: Maintained |
| @@ -4469,14 +3856,10 @@ F: drivers/char/ppdev.c | |||
| 4469 | F: include/linux/ppdev.h | 3856 | F: include/linux/ppdev.h |
| 4470 | 3857 | ||
| 4471 | PARAVIRT_OPS INTERFACE | 3858 | PARAVIRT_OPS INTERFACE |
| 4472 | P: Jeremy Fitzhardinge | 3859 | M: Jeremy Fitzhardinge <jeremy@xensource.com> |
| 4473 | M: jeremy@xensource.com | 3860 | M: Chris Wright <chrisw@sous-sol.org> |
| 4474 | P: Chris Wright | 3861 | M: Alok Kataria <akataria@vmware.com> |
| 4475 | M: chrisw@sous-sol.org | 3862 | M: Rusty Russell <rusty@rustcorp.com.au> |
| 4476 | P: Alok Kataria | ||
| 4477 | M: akataria@vmware.com | ||
| 4478 | P: Rusty Russell | ||
| 4479 | M: rusty@rustcorp.com.au | ||
| 4480 | L: virtualization@lists.osdl.org | 3863 | L: virtualization@lists.osdl.org |
| 4481 | S: Supported | 3864 | S: Supported |
| 4482 | F: Documentation/ia64/paravirt_ops.txt | 3865 | F: Documentation/ia64/paravirt_ops.txt |
| @@ -4484,8 +3867,7 @@ F: arch/*/kernel/paravirt* | |||
| 4484 | F: arch/*/include/asm/paravirt.h | 3867 | F: arch/*/include/asm/paravirt.h |
| 4485 | 3868 | ||
| 4486 | PARIDE DRIVERS FOR PARALLEL PORT IDE DEVICES | 3869 | PARIDE DRIVERS FOR PARALLEL PORT IDE DEVICES |
| 4487 | P: Tim Waugh | 3870 | M: Tim Waugh <tim@cyberelk.net> |
| 4488 | M: tim@cyberelk.net | ||
| 4489 | L: linux-parport@lists.infradead.org (subscribers-only) | 3871 | L: linux-parport@lists.infradead.org (subscribers-only) |
| 4490 | W: http://www.torque.net/linux-pp.html | 3872 | W: http://www.torque.net/linux-pp.html |
| 4491 | S: Maintained | 3873 | S: Maintained |
| @@ -4493,10 +3875,8 @@ F: Documentation/blockdev/paride.txt | |||
| 4493 | F: drivers/block/paride/ | 3875 | F: drivers/block/paride/ |
| 4494 | 3876 | ||
| 4495 | PARISC ARCHITECTURE | 3877 | PARISC ARCHITECTURE |
| 4496 | P: Kyle McMartin | 3878 | M: Kyle McMartin <kyle@mcmartin.ca> |
| 4497 | M: kyle@mcmartin.ca | 3879 | M: Helge Deller <deller@gmx.de> |
| 4498 | P: Helge Deller | ||
| 4499 | M: deller@gmx.de | ||
| 4500 | L: linux-parisc@vger.kernel.org | 3880 | L: linux-parisc@vger.kernel.org |
| 4501 | W: http://www.parisc-linux.org/ | 3881 | W: http://www.parisc-linux.org/ |
| 4502 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/kyle/parisc-2.6.git | 3882 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/kyle/parisc-2.6.git |
| @@ -4505,37 +3885,32 @@ F: arch/parisc/ | |||
| 4505 | F: drivers/parisc/ | 3885 | F: drivers/parisc/ |
| 4506 | 3886 | ||
| 4507 | PC87360 HARDWARE MONITORING DRIVER | 3887 | PC87360 HARDWARE MONITORING DRIVER |
| 4508 | P: Jim Cromie | 3888 | M: Jim Cromie <jim.cromie@gmail.com> |
| 4509 | M: jim.cromie@gmail.com | ||
| 4510 | L: lm-sensors@lm-sensors.org | 3889 | L: lm-sensors@lm-sensors.org |
| 4511 | S: Maintained | 3890 | S: Maintained |
| 4512 | F: Documentation/hwmon/pc87360 | 3891 | F: Documentation/hwmon/pc87360 |
| 4513 | F: drivers/hwmon/pc87360.c | 3892 | F: drivers/hwmon/pc87360.c |
| 4514 | 3893 | ||
| 4515 | PC8736x GPIO DRIVER | 3894 | PC8736x GPIO DRIVER |
| 4516 | P: Jim Cromie | 3895 | M: Jim Cromie <jim.cromie@gmail.com> |
| 4517 | M: jim.cromie@gmail.com | ||
| 4518 | S: Maintained | 3896 | S: Maintained |
| 4519 | F: drivers/char/pc8736x_gpio.c | 3897 | F: drivers/char/pc8736x_gpio.c |
| 4520 | 3898 | ||
| 4521 | PCA9532 LED DRIVER | 3899 | PCA9532 LED DRIVER |
| 4522 | P: Riku Voipio | 3900 | M: Riku Voipio <riku.voipio@iki.fi> |
| 4523 | M: riku.voipio@iki.fi | ||
| 4524 | S: Maintained | 3901 | S: Maintained |
| 4525 | F: drivers/leds/leds-pca9532.c | 3902 | F: drivers/leds/leds-pca9532.c |
| 4526 | F: include/linux/leds-pca9532.h | 3903 | F: include/linux/leds-pca9532.h |
| 4527 | 3904 | ||
| 4528 | PCI ERROR RECOVERY | 3905 | PCI ERROR RECOVERY |
| 4529 | P: Linas Vepstas | 3906 | M: Linas Vepstas <linas@austin.ibm.com> |
| 4530 | M: linas@austin.ibm.com | ||
| 4531 | L: linux-pci@vger.kernel.org | 3907 | L: linux-pci@vger.kernel.org |
| 4532 | S: Supported | 3908 | S: Supported |
| 4533 | F: Documentation/PCI/pci-error-recovery.txt | 3909 | F: Documentation/PCI/pci-error-recovery.txt |
| 4534 | F: Documentation/powerpc/eeh-pci-error-recovery.txt | 3910 | F: Documentation/powerpc/eeh-pci-error-recovery.txt |
| 4535 | 3911 | ||
| 4536 | PCI SUBSYSTEM | 3912 | PCI SUBSYSTEM |
| 4537 | P: Jesse Barnes | 3913 | M: Jesse Barnes <jbarnes@virtuousgeek.org> |
| 4538 | M: jbarnes@virtuousgeek.org | ||
| 4539 | L: linux-pci@vger.kernel.org | 3914 | L: linux-pci@vger.kernel.org |
| 4540 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jbarnes/pci-2.6.git | 3915 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jbarnes/pci-2.6.git |
| 4541 | S: Supported | 3916 | S: Supported |
| @@ -4544,8 +3919,7 @@ F: drivers/pci/ | |||
| 4544 | F: include/linux/pci* | 3919 | F: include/linux/pci* |
| 4545 | 3920 | ||
| 4546 | PCIE HOTPLUG DRIVER | 3921 | PCIE HOTPLUG DRIVER |
| 4547 | P: Kristen Carlson Accardi | 3922 | M: Kristen Carlson Accardi <kristen.c.accardi@intel.com> |
| 4548 | M: kristen.c.accardi@intel.com | ||
| 4549 | L: linux-pci@vger.kernel.org | 3923 | L: linux-pci@vger.kernel.org |
| 4550 | S: Supported | 3924 | S: Supported |
| 4551 | F: drivers/pci/pcie/ | 3925 | F: drivers/pci/pcie/ |
| @@ -4561,121 +3935,103 @@ F: drivers/pcmcia/ | |||
| 4561 | F: include/pcmcia/ | 3935 | F: include/pcmcia/ |
| 4562 | 3936 | ||
| 4563 | PCNET32 NETWORK DRIVER | 3937 | PCNET32 NETWORK DRIVER |
| 4564 | P: Don Fry | 3938 | M: Don Fry <pcnet32@verizon.net> |
| 4565 | M: pcnet32@verizon.net | ||
| 4566 | L: netdev@vger.kernel.org | 3939 | L: netdev@vger.kernel.org |
| 4567 | S: Maintained | 3940 | S: Maintained |
| 4568 | F: drivers/net/pcnet32.c | 3941 | F: drivers/net/pcnet32.c |
| 4569 | 3942 | ||
| 4570 | PER-TASK DELAY ACCOUNTING | 3943 | PER-TASK DELAY ACCOUNTING |
| 4571 | P: Balbir Singh | 3944 | M: Balbir Singh <balbir@linux.vnet.ibm.com> |
| 4572 | M: balbir@linux.vnet.ibm.com | ||
| 4573 | S: Maintained | 3945 | S: Maintained |
| 4574 | F: include/linux/delayacct.h | 3946 | F: include/linux/delayacct.h |
| 4575 | F: kernel/delayacct.c | 3947 | F: kernel/delayacct.c |
| 4576 | 3948 | ||
| 4577 | PERFORMANCE COUNTER SUBSYSTEM | 3949 | PERFORMANCE COUNTER SUBSYSTEM |
| 4578 | P: Peter Zijlstra | 3950 | M: Peter Zijlstra <a.p.zijlstra@chello.nl> |
| 4579 | M: a.p.zijlstra@chello.nl | 3951 | M: Paul Mackerras <paulus@samba.org> |
| 4580 | P: Paul Mackerras | 3952 | M: Ingo Molnar <mingo@elte.hu> |
| 4581 | M: paulus@samba.org | ||
| 4582 | P: Ingo Molnar | ||
| 4583 | M: mingo@elte.hu | ||
| 4584 | L: linux-kernel@vger.kernel.org | ||
| 4585 | S: Supported | 3953 | S: Supported |
| 4586 | 3954 | ||
| 4587 | PERSONALITY HANDLING | 3955 | PERSONALITY HANDLING |
| 4588 | P: Christoph Hellwig | 3956 | M: Christoph Hellwig <hch@infradead.org> |
| 4589 | M: hch@infradead.org | ||
| 4590 | L: linux-abi-devel@lists.sourceforge.net | 3957 | L: linux-abi-devel@lists.sourceforge.net |
| 4591 | S: Maintained | 3958 | S: Maintained |
| 4592 | F: include/linux/personality.h | 3959 | F: include/linux/personality.h |
| 4593 | 3960 | ||
| 4594 | PHRAM MTD DRIVER | 3961 | PHRAM MTD DRIVER |
| 4595 | P: Joern Engel | 3962 | M: Joern Engel <joern@lazybastard.org> |
| 4596 | M: joern@lazybastard.org | ||
| 4597 | L: linux-mtd@lists.infradead.org | 3963 | L: linux-mtd@lists.infradead.org |
| 4598 | S: Maintained | 3964 | S: Maintained |
| 4599 | F: drivers/mtd/devices/phram.c | 3965 | F: drivers/mtd/devices/phram.c |
| 4600 | 3966 | ||
| 4601 | PKTCDVD DRIVER | 3967 | PKTCDVD DRIVER |
| 4602 | P: Peter Osterlund | 3968 | M: Peter Osterlund <petero2@telia.com> |
| 4603 | M: petero2@telia.com | ||
| 4604 | S: Maintained | 3969 | S: Maintained |
| 4605 | F: drivers/block/pktcdvd.c | 3970 | F: drivers/block/pktcdvd.c |
| 4606 | F: include/linux/pktcdvd.h | 3971 | F: include/linux/pktcdvd.h |
| 4607 | 3972 | ||
| 4608 | POSIX CLOCKS and TIMERS | 3973 | POSIX CLOCKS and TIMERS |
| 4609 | P: Thomas Gleixner | 3974 | M: Thomas Gleixner <tglx@linutronix.de> |
| 4610 | M: tglx@linutronix.de | ||
| 4611 | S: Supported | 3975 | S: Supported |
| 4612 | F: fs/timerfd.c | 3976 | F: fs/timerfd.c |
| 4613 | F: include/linux/timer* | 3977 | F: include/linux/timer* |
| 4614 | F: kernel/*timer* | 3978 | F: kernel/*timer* |
| 4615 | 3979 | ||
| 4616 | POWER SUPPLY CLASS/SUBSYSTEM and DRIVERS | 3980 | POWER SUPPLY CLASS/SUBSYSTEM and DRIVERS |
| 4617 | P: Anton Vorontsov | 3981 | M: Anton Vorontsov <cbou@mail.ru> |
| 4618 | M: cbou@mail.ru | 3982 | M: David Woodhouse <dwmw2@infradead.org> |
| 4619 | P: David Woodhouse | ||
| 4620 | M: dwmw2@infradead.org | ||
| 4621 | T: git git://git.infradead.org/battery-2.6.git | 3983 | T: git git://git.infradead.org/battery-2.6.git |
| 4622 | S: Maintained | 3984 | S: Maintained |
| 4623 | F: include/linux/power_supply.h | 3985 | F: include/linux/power_supply.h |
| 4624 | F: drivers/power/power_supply* | 3986 | F: drivers/power/power_supply* |
| 4625 | 3987 | ||
| 4626 | PNP SUPPORT | 3988 | PNP SUPPORT |
| 4627 | P: Adam Belay | 3989 | M: Adam Belay <abelay@mit.edu> |
| 4628 | M: abelay@mit.edu | 3990 | M: Bjorn Helgaas <bjorn.helgaas@hp.com> |
| 4629 | P: Bjorn Helgaas | ||
| 4630 | M: bjorn.helgaas@hp.com | ||
| 4631 | S: Maintained | 3991 | S: Maintained |
| 4632 | F: drivers/pnp/ | 3992 | F: drivers/pnp/ |
| 4633 | 3993 | ||
| 4634 | PNXxxxx I2C DRIVER | 3994 | PNXxxxx I2C DRIVER |
| 4635 | P: Vitaly Wool | 3995 | M: Vitaly Wool <vitalywool@gmail.com> |
| 4636 | M: vitalywool@gmail.com | ||
| 4637 | L: linux-i2c@vger.kernel.org | 3996 | L: linux-i2c@vger.kernel.org |
| 4638 | S: Maintained | 3997 | S: Maintained |
| 4639 | F: drivers/i2c/busses/i2c-pnx.c | 3998 | F: drivers/i2c/busses/i2c-pnx.c |
| 4640 | 3999 | ||
| 4641 | PPP PROTOCOL DRIVERS AND COMPRESSORS | 4000 | PPP PROTOCOL DRIVERS AND COMPRESSORS |
| 4642 | P: Paul Mackerras | 4001 | M: Paul Mackerras <paulus@samba.org> |
| 4643 | M: paulus@samba.org | ||
| 4644 | L: linux-ppp@vger.kernel.org | 4002 | L: linux-ppp@vger.kernel.org |
| 4645 | S: Maintained | 4003 | S: Maintained |
| 4646 | F: drivers/net/ppp_* | 4004 | F: drivers/net/ppp_* |
| 4647 | 4005 | ||
| 4648 | PPP OVER ATM (RFC 2364) | 4006 | PPP OVER ATM (RFC 2364) |
| 4649 | P: Mitchell Blank Jr | 4007 | M: Mitchell Blank Jr <mitch@sfgoth.com> |
| 4650 | M: mitch@sfgoth.com | ||
| 4651 | S: Maintained | 4008 | S: Maintained |
| 4652 | F: net/atm/pppoatm.c | 4009 | F: net/atm/pppoatm.c |
| 4653 | F: include/linux/atmppp.h | 4010 | F: include/linux/atmppp.h |
| 4654 | 4011 | ||
| 4655 | PPP OVER ETHERNET | 4012 | PPP OVER ETHERNET |
| 4656 | P: Michal Ostrowski | 4013 | M: Michal Ostrowski <mostrows@earthlink.net> |
| 4657 | M: mostrows@earthlink.net | ||
| 4658 | S: Maintained | 4014 | S: Maintained |
| 4659 | F: drivers/net/pppoe.c | 4015 | F: drivers/net/pppoe.c |
| 4660 | F: drivers/net/pppox.c | 4016 | F: drivers/net/pppox.c |
| 4661 | 4017 | ||
| 4662 | PPP OVER L2TP | 4018 | PPP OVER L2TP |
| 4663 | P: James Chapman | 4019 | M: James Chapman <jchapman@katalix.com> |
| 4664 | M: jchapman@katalix.com | ||
| 4665 | S: Maintained | 4020 | S: Maintained |
| 4666 | F: drivers/net/pppol2tp.c | 4021 | F: drivers/net/pppol2tp.c |
| 4667 | F: include/linux/if_pppol2tp.h | 4022 | F: include/linux/if_pppol2tp.h |
| 4668 | 4023 | ||
| 4669 | PPS SUPPORT | 4024 | PPS SUPPORT |
| 4670 | P: Rodolfo Giometti | 4025 | M: Rodolfo Giometti <giometti@enneenne.com> |
| 4671 | M: giometti@enneenne.com | ||
| 4672 | W: http://wiki.enneenne.com/index.php/LinuxPPS_support | 4026 | W: http://wiki.enneenne.com/index.php/LinuxPPS_support |
| 4673 | L: linuxpps@ml.enneenne.com (subscribers-only) | 4027 | L: linuxpps@ml.enneenne.com (subscribers-only) |
| 4674 | S: Maintained | 4028 | S: Maintained |
| 4029 | F: Documentation/pps/ | ||
| 4030 | F: drivers/pps/ | ||
| 4031 | F: include/linux/pps*.h | ||
| 4675 | 4032 | ||
| 4676 | PREEMPTIBLE KERNEL | 4033 | PREEMPTIBLE KERNEL |
| 4677 | P: Robert Love | 4034 | M: Robert Love <rml@tech9.net> |
| 4678 | M: rml@tech9.net | ||
| 4679 | L: kpreempt-tech@lists.sourceforge.net | 4035 | L: kpreempt-tech@lists.sourceforge.net |
| 4680 | W: ftp://ftp.kernel.org/pub/linux/kernel/people/rml/preempt-kernel | 4036 | W: ftp://ftp.kernel.org/pub/linux/kernel/people/rml/preempt-kernel |
| 4681 | S: Supported | 4037 | S: Supported |
| @@ -4683,37 +4039,32 @@ F: Documentation/preempt-locking.txt | |||
| 4683 | F: include/linux/preempt.h | 4039 | F: include/linux/preempt.h |
| 4684 | 4040 | ||
| 4685 | PRISM54 WIRELESS DRIVER | 4041 | PRISM54 WIRELESS DRIVER |
| 4686 | P: Luis R. Rodriguez | 4042 | M: "Luis R. Rodriguez" <mcgrof@gmail.com> |
| 4687 | M: mcgrof@gmail.com | ||
| 4688 | L: linux-wireless@vger.kernel.org | 4043 | L: linux-wireless@vger.kernel.org |
| 4689 | W: http://prism54.org | 4044 | W: http://prism54.org |
| 4690 | S: Maintained | 4045 | S: Maintained |
| 4691 | F: drivers/net/wireless/prism54/ | 4046 | F: drivers/net/wireless/prism54/ |
| 4692 | 4047 | ||
| 4693 | PROMISE DC4030 CACHING DISK CONTROLLER DRIVER | 4048 | PROMISE DC4030 CACHING DISK CONTROLLER DRIVER |
| 4694 | P: Peter Denison | 4049 | M: Peter Denison <promise@pnd-pc.demon.co.uk> |
| 4695 | M: promise@pnd-pc.demon.co.uk | ||
| 4696 | W: http://www.pnd-pc.demon.co.uk/promise/ | 4050 | W: http://www.pnd-pc.demon.co.uk/promise/ |
| 4697 | S: Maintained | 4051 | S: Maintained |
| 4698 | 4052 | ||
| 4699 | PROMISE SATA TX2/TX4 CONTROLLER LIBATA DRIVER | 4053 | PROMISE SATA TX2/TX4 CONTROLLER LIBATA DRIVER |
| 4700 | P: Mikael Pettersson | 4054 | M: Mikael Pettersson <mikpe@it.uu.se> |
| 4701 | M: mikpe@it.uu.se | ||
| 4702 | L: linux-ide@vger.kernel.org | 4055 | L: linux-ide@vger.kernel.org |
| 4703 | S: Maintained | 4056 | S: Maintained |
| 4704 | F: drivers/ata/sata_promise.* | 4057 | F: drivers/ata/sata_promise.* |
| 4705 | 4058 | ||
| 4706 | PS3 NETWORK SUPPORT | 4059 | PS3 NETWORK SUPPORT |
| 4707 | P: Geoff Levand | 4060 | M: Geoff Levand <geoffrey.levand@am.sony.com> |
| 4708 | M: geoffrey.levand@am.sony.com | ||
| 4709 | L: netdev@vger.kernel.org | 4061 | L: netdev@vger.kernel.org |
| 4710 | L: cbe-oss-dev@ozlabs.org | 4062 | L: cbe-oss-dev@ozlabs.org |
| 4711 | S: Supported | 4063 | S: Supported |
| 4712 | F: drivers/net/ps3_gelic_net.* | 4064 | F: drivers/net/ps3_gelic_net.* |
| 4713 | 4065 | ||
| 4714 | PS3 PLATFORM SUPPORT | 4066 | PS3 PLATFORM SUPPORT |
| 4715 | P: Geoff Levand | 4067 | M: Geoff Levand <geoffrey.levand@am.sony.com> |
| 4716 | M: geoffrey.levand@am.sony.com | ||
| 4717 | L: linuxppc-dev@ozlabs.org | 4068 | L: linuxppc-dev@ozlabs.org |
| 4718 | L: cbe-oss-dev@ozlabs.org | 4069 | L: cbe-oss-dev@ozlabs.org |
| 4719 | S: Supported | 4070 | S: Supported |
| @@ -4728,16 +4079,13 @@ F: drivers/usb/host/*ps3.c | |||
| 4728 | F: sound/ppc/snd_ps3* | 4079 | F: sound/ppc/snd_ps3* |
| 4729 | 4080 | ||
| 4730 | PS3VRAM DRIVER | 4081 | PS3VRAM DRIVER |
| 4731 | P: Jim Paris | 4082 | M: Jim Paris <jim@jtan.com> |
| 4732 | M: jim@jtan.com | ||
| 4733 | L: cbe-oss-dev@ozlabs.org | 4083 | L: cbe-oss-dev@ozlabs.org |
| 4734 | S: Maintained | 4084 | S: Maintained |
| 4735 | 4085 | ||
| 4736 | PTRACE SUPPORT | 4086 | PTRACE SUPPORT |
| 4737 | P: Roland McGrath | 4087 | M: Roland McGrath <roland@redhat.com> |
| 4738 | M: roland@redhat.com | 4088 | M: Oleg Nesterov <oleg@redhat.com> |
| 4739 | P: Oleg Nesterov | ||
| 4740 | M: oleg@redhat.com | ||
| 4741 | S: Maintained | 4089 | S: Maintained |
| 4742 | F: include/asm-generic/syscall.h | 4090 | F: include/asm-generic/syscall.h |
| 4743 | F: include/linux/ptrace.h | 4091 | F: include/linux/ptrace.h |
| @@ -4746,8 +4094,7 @@ F: include/linux/tracehook.h | |||
| 4746 | F: kernel/ptrace.c | 4094 | F: kernel/ptrace.c |
| 4747 | 4095 | ||
| 4748 | PVRUSB2 VIDEO4LINUX DRIVER | 4096 | PVRUSB2 VIDEO4LINUX DRIVER |
| 4749 | P: Mike Isely | 4097 | M: Mike Isely <isely@pobox.com> |
| 4750 | M: isely@pobox.com | ||
| 4751 | L: pvrusb2@isely.net (subscribers-only) | 4098 | L: pvrusb2@isely.net (subscribers-only) |
| 4752 | L: linux-media@vger.kernel.org | 4099 | L: linux-media@vger.kernel.org |
| 4753 | W: http://www.isely.net/pvrusb2/ | 4100 | W: http://www.isely.net/pvrusb2/ |
| @@ -4757,10 +4104,8 @@ F: Documentation/video4linux/README.pvrusb2 | |||
| 4757 | F: drivers/media/video/pvrusb2/ | 4104 | F: drivers/media/video/pvrusb2/ |
| 4758 | 4105 | ||
| 4759 | PXA2xx/PXA3xx SUPPORT | 4106 | PXA2xx/PXA3xx SUPPORT |
| 4760 | P: Eric Miao | 4107 | M: Eric Miao <eric.y.miao@gmail.com> |
| 4761 | M: eric.y.miao@gmail.com | 4108 | M: Russell King <linux@arm.linux.org.uk> |
| 4762 | P: Russell King | ||
| 4763 | M: linux@arm.linux.org.uk | ||
| 4764 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 4109 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 4765 | S: Maintained | 4110 | S: Maintained |
| 4766 | F: arch/arm/mach-pxa/ | 4111 | F: arch/arm/mach-pxa/ |
| @@ -4772,17 +4117,14 @@ F: sound/arm/pxa* | |||
| 4772 | F: sound/soc/pxa | 4117 | F: sound/soc/pxa |
| 4773 | 4118 | ||
| 4774 | PXA168 SUPPORT | 4119 | PXA168 SUPPORT |
| 4775 | P: Eric Miao | 4120 | M: Eric Miao <eric.y.miao@gmail.com> |
| 4776 | M: eric.y.miao@gmail.com | 4121 | M: Jason Chagas <jason.chagas@marvell.com> |
| 4777 | P: Jason Chagas | ||
| 4778 | M: jason.chagas@marvell.com | ||
| 4779 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 4122 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 4780 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/ycmiao/pxa-linux-2.6.git | 4123 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/ycmiao/pxa-linux-2.6.git |
| 4781 | S: Maintained | 4124 | S: Maintained |
| 4782 | 4125 | ||
| 4783 | PXA910 SUPPORT | 4126 | PXA910 SUPPORT |
| 4784 | P: Eric Miao | 4127 | M: Eric Miao <eric.y.miao@gmail.com> |
| 4785 | M: eric.y.miao@gmail.com | ||
| 4786 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 4128 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 4787 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/ycmiao/pxa-linux-2.6.git | 4129 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/ycmiao/pxa-linux-2.6.git |
| 4788 | S: Maintained | 4130 | S: Maintained |
| @@ -4791,13 +4133,12 @@ PXA MMCI DRIVER | |||
| 4791 | S: Orphan | 4133 | S: Orphan |
| 4792 | 4134 | ||
| 4793 | PXA RTC DRIVER | 4135 | PXA RTC DRIVER |
| 4794 | P: Robert Jarzmik | 4136 | M: Robert Jarzmik <robert.jarzmik@free.fr> |
| 4795 | M: robert.jarzmik@free.fr | ||
| 4796 | L: rtc-linux@googlegroups.com | 4137 | L: rtc-linux@googlegroups.com |
| 4797 | S: Maintained | 4138 | S: Maintained |
| 4798 | 4139 | ||
| 4799 | QLOGIC QLA2XXX FC-SCSI DRIVER | 4140 | QLOGIC QLA2XXX FC-SCSI DRIVER |
| 4800 | P: Andrew Vasquez | 4141 | M: Andrew Vasquez <andrew.vasquez@qlogic.com> |
| 4801 | M: linux-driver@qlogic.com | 4142 | M: linux-driver@qlogic.com |
| 4802 | L: linux-scsi@vger.kernel.org | 4143 | L: linux-scsi@vger.kernel.org |
| 4803 | S: Supported | 4144 | S: Supported |
| @@ -4805,7 +4146,7 @@ F: Documentation/scsi/LICENSE.qla2xxx | |||
| 4805 | F: drivers/scsi/qla2xxx/ | 4146 | F: drivers/scsi/qla2xxx/ |
| 4806 | 4147 | ||
| 4807 | QLOGIC QLA3XXX NETWORK DRIVER | 4148 | QLOGIC QLA3XXX NETWORK DRIVER |
| 4808 | P: Ron Mercer | 4149 | M: Ron Mercer <ron.mercer@qlogic.com> |
| 4809 | M: linux-driver@qlogic.com | 4150 | M: linux-driver@qlogic.com |
| 4810 | L: netdev@vger.kernel.org | 4151 | L: netdev@vger.kernel.org |
| 4811 | S: Supported | 4152 | S: Supported |
| @@ -4813,16 +4154,14 @@ F: Documentation/networking/LICENSE.qla3xxx | |||
| 4813 | F: drivers/net/qla3xxx.* | 4154 | F: drivers/net/qla3xxx.* |
| 4814 | 4155 | ||
| 4815 | QLOGIC QLGE 10Gb ETHERNET DRIVER | 4156 | QLOGIC QLGE 10Gb ETHERNET DRIVER |
| 4816 | P: Ron Mercer | 4157 | M: Ron Mercer <ron.mercer@qlogic.com> |
| 4817 | M: linux-driver@qlogic.com | 4158 | M: linux-driver@qlogic.com |
| 4818 | M: ron.mercer@qlogic.com | ||
| 4819 | L: netdev@vger.kernel.org | 4159 | L: netdev@vger.kernel.org |
| 4820 | S: Supported | 4160 | S: Supported |
| 4821 | F: drivers/net/qlge/ | 4161 | F: drivers/net/qlge/ |
| 4822 | 4162 | ||
| 4823 | QNX4 FILESYSTEM | 4163 | QNX4 FILESYSTEM |
| 4824 | P: Anders Larsen | 4164 | M: Anders Larsen <al@alarsen.net> |
| 4825 | M: al@alarsen.net | ||
| 4826 | W: http://www.alarsen.net/linux/qnx4fs/ | 4165 | W: http://www.alarsen.net/linux/qnx4fs/ |
| 4827 | S: Maintained | 4166 | S: Maintained |
| 4828 | F: fs/qnx4/ | 4167 | F: fs/qnx4/ |
| @@ -4830,16 +4169,14 @@ F: include/linux/qnx4_fs.h | |||
| 4830 | F: include/linux/qnxtypes.h | 4169 | F: include/linux/qnxtypes.h |
| 4831 | 4170 | ||
| 4832 | RADEON FRAMEBUFFER DISPLAY DRIVER | 4171 | RADEON FRAMEBUFFER DISPLAY DRIVER |
| 4833 | P: Benjamin Herrenschmidt | 4172 | M: Benjamin Herrenschmidt <benh@kernel.crashing.org> |
| 4834 | M: benh@kernel.crashing.org | ||
| 4835 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) | 4173 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 4836 | S: Maintained | 4174 | S: Maintained |
| 4837 | F: drivers/video/aty/radeon* | 4175 | F: drivers/video/aty/radeon* |
| 4838 | F: include/linux/radeonfb.h | 4176 | F: include/linux/radeonfb.h |
| 4839 | 4177 | ||
| 4840 | RAGE128 FRAMEBUFFER DISPLAY DRIVER | 4178 | RAGE128 FRAMEBUFFER DISPLAY DRIVER |
| 4841 | P: Paul Mackerras | 4179 | M: Paul Mackerras <paulus@samba.org> |
| 4842 | M: paulus@samba.org | ||
| 4843 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) | 4180 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 4844 | S: Maintained | 4181 | S: Maintained |
| 4845 | F: drivers/video/aty/aty128fb.c | 4182 | F: drivers/video/aty/aty128fb.c |
| @@ -4854,64 +4191,53 @@ T: git git://git.kernel.org/pub/scm/linux/kernel/git/ivd/rt2x00.git | |||
| 4854 | F: drivers/net/wireless/rt2x00/ | 4191 | F: drivers/net/wireless/rt2x00/ |
| 4855 | 4192 | ||
| 4856 | RAMDISK RAM BLOCK DEVICE DRIVER | 4193 | RAMDISK RAM BLOCK DEVICE DRIVER |
| 4857 | P: Nick Piggin | 4194 | M: Nick Piggin <npiggin@suse.de> |
| 4858 | M: npiggin@suse.de | ||
| 4859 | S: Maintained | 4195 | S: Maintained |
| 4860 | F: Documentation/blockdev/ramdisk.txt | 4196 | F: Documentation/blockdev/ramdisk.txt |
| 4861 | F: drivers/block/brd.c | 4197 | F: drivers/block/brd.c |
| 4862 | 4198 | ||
| 4863 | RANDOM NUMBER DRIVER | 4199 | RANDOM NUMBER DRIVER |
| 4864 | P: Matt Mackall | 4200 | M: Matt Mackall <mpm@selenic.com> |
| 4865 | M: mpm@selenic.com | ||
| 4866 | S: Maintained | 4201 | S: Maintained |
| 4867 | F: drivers/char/random.c | 4202 | F: drivers/char/random.c |
| 4868 | 4203 | ||
| 4869 | RAPIDIO SUBSYSTEM | 4204 | RAPIDIO SUBSYSTEM |
| 4870 | P: Matt Porter | 4205 | M: Matt Porter <mporter@kernel.crashing.org> |
| 4871 | M: mporter@kernel.crashing.org | ||
| 4872 | S: Maintained | 4206 | S: Maintained |
| 4873 | F: drivers/rapidio/ | 4207 | F: drivers/rapidio/ |
| 4874 | 4208 | ||
| 4875 | RAYLINK/WEBGEAR 802.11 WIRELESS LAN DRIVER | 4209 | RAYLINK/WEBGEAR 802.11 WIRELESS LAN DRIVER |
| 4876 | P: Corey Thomas | 4210 | M: Corey Thomas <coreythomas@charter.net> |
| 4877 | M: coreythomas@charter.net | ||
| 4878 | L: linux-wireless@vger.kernel.org | 4211 | L: linux-wireless@vger.kernel.org |
| 4879 | S: Maintained | 4212 | S: Maintained |
| 4880 | F: drivers/net/wireless/ray* | 4213 | F: drivers/net/wireless/ray* |
| 4881 | 4214 | ||
| 4882 | RCUTORTURE MODULE | 4215 | RCUTORTURE MODULE |
| 4883 | P: Josh Triplett | 4216 | M: Josh Triplett <josh@freedesktop.org> |
| 4884 | M: josh@freedesktop.org | 4217 | M: "Paul E. McKenney" <paulmck@linux.vnet.ibm.com> |
| 4885 | P: Paul E. McKenney | ||
| 4886 | M: paulmck@linux.vnet.ibm.com | ||
| 4887 | S: Maintained | 4218 | S: Maintained |
| 4888 | F: Documentation/RCU/torture.txt | 4219 | F: Documentation/RCU/torture.txt |
| 4889 | F: kernel/rcutorture.c | 4220 | F: kernel/rcutorture.c |
| 4890 | 4221 | ||
| 4891 | RDC R-321X SoC | 4222 | RDC R-321X SoC |
| 4892 | P: Florian Fainelli | 4223 | M: Florian Fainelli <florian@openwrt.org> |
| 4893 | M: florian@openwrt.org | ||
| 4894 | S: Maintained | 4224 | S: Maintained |
| 4895 | 4225 | ||
| 4896 | RDC R6040 FAST ETHERNET DRIVER | 4226 | RDC R6040 FAST ETHERNET DRIVER |
| 4897 | P: Florian Fainelli | 4227 | M: Florian Fainelli <florian@openwrt.org> |
| 4898 | M: florian@openwrt.org | ||
| 4899 | L: netdev@vger.kernel.org | 4228 | L: netdev@vger.kernel.org |
| 4900 | S: Maintained | 4229 | S: Maintained |
| 4901 | F: drivers/net/r6040.c | 4230 | F: drivers/net/r6040.c |
| 4902 | 4231 | ||
| 4903 | RDS - RELIABLE DATAGRAM SOCKETS | 4232 | RDS - RELIABLE DATAGRAM SOCKETS |
| 4904 | P: Andy Grover | 4233 | M: Andy Grover <andy.grover@oracle.com> |
| 4905 | M: andy.grover@oracle.com | ||
| 4906 | L: rds-devel@oss.oracle.com (moderated for non-subscribers) | 4234 | L: rds-devel@oss.oracle.com (moderated for non-subscribers) |
| 4907 | S: Supported | 4235 | S: Supported |
| 4908 | F: net/rds/ | 4236 | F: net/rds/ |
| 4909 | 4237 | ||
| 4910 | READ-COPY UPDATE (RCU) | 4238 | READ-COPY UPDATE (RCU) |
| 4911 | P: Dipankar Sarma | 4239 | M: Dipankar Sarma <dipankar@in.ibm.com> |
| 4912 | M: dipankar@in.ibm.com | 4240 | M: "Paul E. McKenney" <paulmck@linux.vnet.ibm.com> |
| 4913 | P: Paul E. McKenney | ||
| 4914 | M: paulmck@linux.vnet.ibm.com | ||
| 4915 | W: http://www.rdrop.com/users/paulmck/rclock/ | 4241 | W: http://www.rdrop.com/users/paulmck/rclock/ |
| 4916 | S: Supported | 4242 | S: Supported |
| 4917 | F: Documentation/RCU/rcu.txt | 4243 | F: Documentation/RCU/rcu.txt |
| @@ -4921,16 +4247,14 @@ F: include/linux/srcu.h | |||
| 4921 | F: kernel/rcupdate.c | 4247 | F: kernel/rcupdate.c |
| 4922 | 4248 | ||
| 4923 | REAL TIME CLOCK DRIVER | 4249 | REAL TIME CLOCK DRIVER |
| 4924 | P: Paul Gortmaker | 4250 | M: Paul Gortmaker <p_gortmaker@yahoo.com> |
| 4925 | M: p_gortmaker@yahoo.com | ||
| 4926 | S: Maintained | 4251 | S: Maintained |
| 4927 | F: Documentation/rtc.txt | 4252 | F: Documentation/rtc.txt |
| 4928 | F: drivers/rtc/ | 4253 | F: drivers/rtc/ |
| 4929 | F: include/linux/rtc.h | 4254 | F: include/linux/rtc.h |
| 4930 | 4255 | ||
| 4931 | REAL TIME CLOCK (RTC) SUBSYSTEM | 4256 | REAL TIME CLOCK (RTC) SUBSYSTEM |
| 4932 | P: Alessandro Zummo | 4257 | M: Alessandro Zummo <a.zummo@towertech.it> |
| 4933 | M: a.zummo@towertech.it | ||
| 4934 | L: rtc-linux@googlegroups.com | 4258 | L: rtc-linux@googlegroups.com |
| 4935 | S: Maintained | 4259 | S: Maintained |
| 4936 | F: Documentation/rtc.txt | 4260 | F: Documentation/rtc.txt |
| @@ -4943,8 +4267,7 @@ S: Supported | |||
| 4943 | F: fs/reiserfs/ | 4267 | F: fs/reiserfs/ |
| 4944 | 4268 | ||
| 4945 | RFKILL | 4269 | RFKILL |
| 4946 | P: Johannes Berg | 4270 | M: Johannes Berg <johannes@sipsolutions.net> |
| 4947 | M: johannes@sipsolutions.net | ||
| 4948 | L: linux-wireless@vger.kernel.org | 4271 | L: linux-wireless@vger.kernel.org |
| 4949 | S: Maintained | 4272 | S: Maintained |
| 4950 | F Documentation/rfkill.txt | 4273 | F Documentation/rfkill.txt |
| @@ -4963,8 +4286,7 @@ F: Documentation/serial/rocket.txt | |||
| 4963 | F: drivers/char/rocket* | 4286 | F: drivers/char/rocket* |
| 4964 | 4287 | ||
| 4965 | ROSE NETWORK LAYER | 4288 | ROSE NETWORK LAYER |
| 4966 | P: Ralf Baechle | 4289 | M: Ralf Baechle <ralf@linux-mips.org> |
| 4967 | M: ralf@linux-mips.org | ||
| 4968 | L: linux-hams@vger.kernel.org | 4290 | L: linux-hams@vger.kernel.org |
| 4969 | W: http://www.linux-ax25.org/ | 4291 | W: http://www.linux-ax25.org/ |
| 4970 | S: Maintained | 4292 | S: Maintained |
| @@ -4973,8 +4295,7 @@ F: include/net/rose.h | |||
| 4973 | F: net/rose/ | 4295 | F: net/rose/ |
| 4974 | 4296 | ||
| 4975 | RTL8180 WIRELESS DRIVER | 4297 | RTL8180 WIRELESS DRIVER |
| 4976 | P: John W. Linville | 4298 | M: "John W. Linville" <linville@tuxdriver.com> |
| 4977 | M: linville@tuxdriver.com | ||
| 4978 | L: linux-wireless@vger.kernel.org | 4299 | L: linux-wireless@vger.kernel.org |
| 4979 | W: http://linuxwireless.org/ | 4300 | W: http://linuxwireless.org/ |
| 4980 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-testing.git | 4301 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-testing.git |
| @@ -4982,12 +4303,9 @@ S: Maintained | |||
| 4982 | F: drivers/net/wireless/rtl818* | 4303 | F: drivers/net/wireless/rtl818* |
| 4983 | 4304 | ||
| 4984 | RTL8187 WIRELESS DRIVER | 4305 | RTL8187 WIRELESS DRIVER |
| 4985 | P: Herton Ronaldo Krzesinski | 4306 | M: Herton Ronaldo Krzesinski <herton@mandriva.com.br> |
| 4986 | M: herton@mandriva.com.br | 4307 | M: Hin-Tak Leung <htl10@users.sourceforge.net> |
| 4987 | P: Hin-Tak Leung | 4308 | M: Larry Finger <Larry.Finger@lwfinger.net> |
| 4988 | M: htl10@users.sourceforge.net | ||
| 4989 | P: Larry Finger | ||
| 4990 | M: Larry.Finger@lwfinger.net | ||
| 4991 | L: linux-wireless@vger.kernel.org | 4309 | L: linux-wireless@vger.kernel.org |
| 4992 | W: http://linuxwireless.org/ | 4310 | W: http://linuxwireless.org/ |
| 4993 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-testing.git | 4311 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-testing.git |
| @@ -4995,17 +4313,14 @@ S: Maintained | |||
| 4995 | F: drivers/net/wireless/rtl818x/rtl8187* | 4313 | F: drivers/net/wireless/rtl818x/rtl8187* |
| 4996 | 4314 | ||
| 4997 | S3 SAVAGE FRAMEBUFFER DRIVER | 4315 | S3 SAVAGE FRAMEBUFFER DRIVER |
| 4998 | P: Antonino Daplas | 4316 | M: Antonino Daplas <adaplas@gmail.com> |
| 4999 | M: adaplas@gmail.com | ||
| 5000 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) | 4317 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 5001 | S: Maintained | 4318 | S: Maintained |
| 5002 | F: drivers/video/savage/ | 4319 | F: drivers/video/savage/ |
| 5003 | 4320 | ||
| 5004 | S390 | 4321 | S390 |
| 5005 | P: Martin Schwidefsky | 4322 | M: Martin Schwidefsky <schwidefsky@de.ibm.com> |
| 5006 | M: schwidefsky@de.ibm.com | 4323 | M: Heiko Carstens <heiko.carstens@de.ibm.com> |
| 5007 | P: Heiko Carstens | ||
| 5008 | M: heiko.carstens@de.ibm.com | ||
| 5009 | M: linux390@de.ibm.com | 4324 | M: linux390@de.ibm.com |
| 5010 | L: linux-s390@vger.kernel.org | 4325 | L: linux-s390@vger.kernel.org |
| 5011 | W: http://www.ibm.com/developerworks/linux/linux390/ | 4326 | W: http://www.ibm.com/developerworks/linux/linux390/ |
| @@ -5013,10 +4328,8 @@ S: Supported | |||
| 5013 | F: arch/s390/ | 4328 | F: arch/s390/ |
| 5014 | 4329 | ||
| 5015 | S390 NETWORK DRIVERS | 4330 | S390 NETWORK DRIVERS |
| 5016 | P: Ursula Braun | 4331 | M: Ursula Braun <ursula.braun@de.ibm.com> |
| 5017 | M: ursula.braun@de.ibm.com | 4332 | M: Frank Blaschka <blaschka@linux.vnet.ibm.com> |
| 5018 | P: Frank Blaschka | ||
| 5019 | M: blaschka@linux.vnet.ibm.com | ||
| 5020 | M: linux390@de.ibm.com | 4333 | M: linux390@de.ibm.com |
| 5021 | L: linux-s390@vger.kernel.org | 4334 | L: linux-s390@vger.kernel.org |
| 5022 | W: http://www.ibm.com/developerworks/linux/linux390/ | 4335 | W: http://www.ibm.com/developerworks/linux/linux390/ |
| @@ -5024,20 +4337,16 @@ S: Supported | |||
| 5024 | F: drivers/s390/net/ | 4337 | F: drivers/s390/net/ |
| 5025 | 4338 | ||
| 5026 | S390 ZCRYPT DRIVER | 4339 | S390 ZCRYPT DRIVER |
| 5027 | P: Felix Beck | 4340 | M: Felix Beck <felix.beck@de.ibm.com> |
| 5028 | M: felix.beck@de.ibm.com | 4341 | M: Ralph Wuerthner <ralph.wuerthner@de.ibm.com> |
| 5029 | P: Ralph Wuerthner | ||
| 5030 | M: ralph.wuerthner@de.ibm.com | ||
| 5031 | M: linux390@de.ibm.com | 4342 | M: linux390@de.ibm.com |
| 5032 | L: linux-s390@vger.kernel.org | 4343 | L: linux-s390@vger.kernel.org |
| 5033 | S: Supported | 4344 | S: Supported |
| 5034 | F: drivers/s390/crypto/ | 4345 | F: drivers/s390/crypto/ |
| 5035 | 4346 | ||
| 5036 | S390 ZFCP DRIVER | 4347 | S390 ZFCP DRIVER |
| 5037 | P: Christof Schmitt | 4348 | M: Christof Schmitt <christof.schmitt@de.ibm.com> |
| 5038 | M: christof.schmitt@de.ibm.com | 4349 | M: Martin Peschke <mp3@de.ibm.com> |
| 5039 | P: Martin Peschke | ||
| 5040 | M: mp3@de.ibm.com | ||
| 5041 | M: linux390@de.ibm.com | 4350 | M: linux390@de.ibm.com |
| 5042 | L: linux-s390@vger.kernel.org | 4351 | L: linux-s390@vger.kernel.org |
| 5043 | W: http://www.ibm.com/developerworks/linux/linux390/ | 4352 | W: http://www.ibm.com/developerworks/linux/linux390/ |
| @@ -5046,8 +4355,7 @@ F: Documentation/s390/zfcpdump.txt | |||
| 5046 | F: drivers/s390/scsi/zfcp_* | 4355 | F: drivers/s390/scsi/zfcp_* |
| 5047 | 4356 | ||
| 5048 | S390 IUCV NETWORK LAYER | 4357 | S390 IUCV NETWORK LAYER |
| 5049 | P: Ursula Braun | 4358 | M: Ursula Braun <ursula.braun@de.ibm.com> |
| 5050 | M: ursula.braun@de.ibm.com | ||
| 5051 | M: linux390@de.ibm.com | 4359 | M: linux390@de.ibm.com |
| 5052 | L: linux-s390@vger.kernel.org | 4360 | L: linux-s390@vger.kernel.org |
| 5053 | W: http://www.ibm.com/developerworks/linux/linux390/ | 4361 | W: http://www.ibm.com/developerworks/linux/linux390/ |
| @@ -5057,15 +4365,13 @@ F: include/net/iucv/ | |||
| 5057 | F: net/iucv/ | 4365 | F: net/iucv/ |
| 5058 | 4366 | ||
| 5059 | S3C24XX SD/MMC Driver | 4367 | S3C24XX SD/MMC Driver |
| 5060 | P: Ben Dooks | 4368 | M: Ben Dooks <ben-linux@fluff.org> |
| 5061 | M: ben-linux@fluff.org | ||
| 5062 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 4369 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 5063 | S: Supported | 4370 | S: Supported |
| 5064 | F: drivers/mmc/host/s3cmci.* | 4371 | F: drivers/mmc/host/s3cmci.* |
| 5065 | 4372 | ||
| 5066 | SAA7146 VIDEO4LINUX-2 DRIVER | 4373 | SAA7146 VIDEO4LINUX-2 DRIVER |
| 5067 | P: Michael Hunold | 4374 | M: Michael Hunold <michael@mihu.de> |
| 5068 | M: michael@mihu.de | ||
| 5069 | L: linux-media@vger.kernel.org | 4375 | L: linux-media@vger.kernel.org |
| 5070 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 4376 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| 5071 | W: http://www.mihu.de/linux/saa7146 | 4377 | W: http://www.mihu.de/linux/saa7146 |
| @@ -5075,31 +4381,26 @@ F: drivers/media/video/*7146* | |||
| 5075 | F: include/media/*7146* | 4381 | F: include/media/*7146* |
| 5076 | 4382 | ||
| 5077 | SC1200 WDT DRIVER | 4383 | SC1200 WDT DRIVER |
| 5078 | P: Zwane Mwaikambo | 4384 | M: Zwane Mwaikambo <zwane@arm.linux.org.uk> |
| 5079 | M: zwane@arm.linux.org.uk | ||
| 5080 | S: Maintained | 4385 | S: Maintained |
| 5081 | F: drivers/watchdog/sc1200wdt.c | 4386 | F: drivers/watchdog/sc1200wdt.c |
| 5082 | 4387 | ||
| 5083 | SCHEDULER | 4388 | SCHEDULER |
| 5084 | P: Ingo Molnar | 4389 | M: Ingo Molnar <mingo@elte.hu> |
| 5085 | M: mingo@elte.hu | 4390 | M: Peter Zijlstra <peterz@infradead.org> |
| 5086 | P: Peter Zijlstra | ||
| 5087 | M: peterz@infradead.org | ||
| 5088 | S: Maintained | 4391 | S: Maintained |
| 5089 | F: kernel/sched* | 4392 | F: kernel/sched* |
| 5090 | F: include/linux/sched.h | 4393 | F: include/linux/sched.h |
| 5091 | 4394 | ||
| 5092 | SCSI CDROM DRIVER | 4395 | SCSI CDROM DRIVER |
| 5093 | P: Jens Axboe | 4396 | M: Jens Axboe <axboe@kernel.dk> |
| 5094 | M: axboe@kernel.dk | ||
| 5095 | L: linux-scsi@vger.kernel.org | 4397 | L: linux-scsi@vger.kernel.org |
| 5096 | W: http://www.kernel.dk | 4398 | W: http://www.kernel.dk |
| 5097 | S: Maintained | 4399 | S: Maintained |
| 5098 | F: drivers/scsi/sr* | 4400 | F: drivers/scsi/sr* |
| 5099 | 4401 | ||
| 5100 | SCSI SG DRIVER | 4402 | SCSI SG DRIVER |
| 5101 | P: Doug Gilbert | 4403 | M: Doug Gilbert <dgilbert@interlog.com> |
| 5102 | M: dgilbert@interlog.com | ||
| 5103 | L: linux-scsi@vger.kernel.org | 4404 | L: linux-scsi@vger.kernel.org |
| 5104 | W: http://www.torque.net/sg | 4405 | W: http://www.torque.net/sg |
| 5105 | S: Maintained | 4406 | S: Maintained |
| @@ -5107,8 +4408,7 @@ F: drivers/scsi/sg.c | |||
| 5107 | F: include/scsi/sg.h | 4408 | F: include/scsi/sg.h |
| 5108 | 4409 | ||
| 5109 | SCSI SUBSYSTEM | 4410 | SCSI SUBSYSTEM |
| 5110 | P: James E.J. Bottomley | 4411 | M: "James E.J. Bottomley" <James.Bottomley@HansenPartnership.com> |
| 5111 | M: James.Bottomley@HansenPartnership.com | ||
| 5112 | L: linux-scsi@vger.kernel.org | 4412 | L: linux-scsi@vger.kernel.org |
| 5113 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi-misc-2.6.git | 4413 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi-misc-2.6.git |
| 5114 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi-rc-fixes-2.6.git | 4414 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi-rc-fixes-2.6.git |
| @@ -5118,18 +4418,15 @@ F: drivers/scsi/ | |||
| 5118 | F: include/scsi/ | 4418 | F: include/scsi/ |
| 5119 | 4419 | ||
| 5120 | SCSI TAPE DRIVER | 4420 | SCSI TAPE DRIVER |
| 5121 | P: Kai Mäkisara | 4421 | M: Kai Mäkisara <Kai.Makisara@kolumbus.fi> |
| 5122 | M: Kai.Makisara@kolumbus.fi | ||
| 5123 | L: linux-scsi@vger.kernel.org | 4422 | L: linux-scsi@vger.kernel.org |
| 5124 | S: Maintained | 4423 | S: Maintained |
| 5125 | F: Documentation/scsi/st.txt | 4424 | F: Documentation/scsi/st.txt |
| 5126 | F: drivers/scsi/st* | 4425 | F: drivers/scsi/st* |
| 5127 | 4426 | ||
| 5128 | SCTP PROTOCOL | 4427 | SCTP PROTOCOL |
| 5129 | P: Vlad Yasevich | 4428 | M: Vlad Yasevich <vladislav.yasevich@hp.com> |
| 5130 | M: vladislav.yasevich@hp.com | 4429 | M: Sridhar Samudrala <sri@us.ibm.com> |
| 5131 | P: Sridhar Samudrala | ||
| 5132 | M: sri@us.ibm.com | ||
| 5133 | L: linux-sctp@vger.kernel.org | 4430 | L: linux-sctp@vger.kernel.org |
| 5134 | W: http://lksctp.sourceforge.net | 4431 | W: http://lksctp.sourceforge.net |
| 5135 | S: Supported | 4432 | S: Supported |
| @@ -5139,8 +4436,7 @@ F: include/net/sctp/ | |||
| 5139 | F: net/sctp/ | 4436 | F: net/sctp/ |
| 5140 | 4437 | ||
| 5141 | SCx200 CPU SUPPORT | 4438 | SCx200 CPU SUPPORT |
| 5142 | P: Jim Cromie | 4439 | M: Jim Cromie <jim.cromie@gmail.com> |
| 5143 | M: jim.cromie@gmail.com | ||
| 5144 | S: Odd Fixes | 4440 | S: Odd Fixes |
| 5145 | F: Documentation/i2c/busses/scx200_acb | 4441 | F: Documentation/i2c/busses/scx200_acb |
| 5146 | F: arch/x86/kernel/scx200_32.c | 4442 | F: arch/x86/kernel/scx200_32.c |
| @@ -5150,49 +4446,42 @@ F: drivers/mtd/maps/scx200_docflash.c | |||
| 5150 | F: include/linux/scx200.h | 4446 | F: include/linux/scx200.h |
| 5151 | 4447 | ||
| 5152 | SCx200 GPIO DRIVER | 4448 | SCx200 GPIO DRIVER |
| 5153 | P: Jim Cromie | 4449 | M: Jim Cromie <jim.cromie@gmail.com> |
| 5154 | M: jim.cromie@gmail.com | ||
| 5155 | S: Maintained | 4450 | S: Maintained |
| 5156 | F: drivers/char/scx200_gpio.c | 4451 | F: drivers/char/scx200_gpio.c |
| 5157 | F: include/linux/scx200_gpio.h | 4452 | F: include/linux/scx200_gpio.h |
| 5158 | 4453 | ||
| 5159 | SCx200 HRT CLOCKSOURCE DRIVER | 4454 | SCx200 HRT CLOCKSOURCE DRIVER |
| 5160 | P: Jim Cromie | 4455 | M: Jim Cromie <jim.cromie@gmail.com> |
| 5161 | M: jim.cromie@gmail.com | ||
| 5162 | S: Maintained | 4456 | S: Maintained |
| 5163 | F: drivers/clocksource/scx200_hrt.c | 4457 | F: drivers/clocksource/scx200_hrt.c |
| 5164 | 4458 | ||
| 5165 | SDRICOH_CS MMC/SD HOST CONTROLLER INTERFACE DRIVER | 4459 | SDRICOH_CS MMC/SD HOST CONTROLLER INTERFACE DRIVER |
| 5166 | P: Sascha Sommer | 4460 | M: Sascha Sommer <saschasommer@freenet.de> |
| 5167 | M: saschasommer@freenet.de | ||
| 5168 | L: sdricohcs-devel@lists.sourceforge.net (subscribers-only) | 4461 | L: sdricohcs-devel@lists.sourceforge.net (subscribers-only) |
| 5169 | S: Maintained | 4462 | S: Maintained |
| 5170 | F: drivers/mmc/host/sdricoh_cs.c | 4463 | F: drivers/mmc/host/sdricoh_cs.c |
| 5171 | 4464 | ||
| 5172 | SECURE DIGITAL HOST CONTROLLER INTERFACE (SDHCI) DRIVER | 4465 | SECURE DIGITAL HOST CONTROLLER INTERFACE (SDHCI) DRIVER |
| 5173 | P: Pierre Ossman | 4466 | M: Pierre Ossman <pierre@ossman.eu> |
| 5174 | M: pierre@ossman.eu | ||
| 5175 | L: sdhci-devel@lists.ossman.eu | 4467 | L: sdhci-devel@lists.ossman.eu |
| 5176 | S: Maintained | 4468 | S: Maintained |
| 5177 | 4469 | ||
| 5178 | SECURE DIGITAL HOST CONTROLLER INTERFACE, OPEN FIRMWARE BINDINGS (SDHCI-OF) | 4470 | SECURE DIGITAL HOST CONTROLLER INTERFACE, OPEN FIRMWARE BINDINGS (SDHCI-OF) |
| 5179 | P: Anton Vorontsov | 4471 | M: Anton Vorontsov <avorontsov@ru.mvista.com> |
| 5180 | M: avorontsov@ru.mvista.com | ||
| 5181 | L: linuxppc-dev@ozlabs.org | 4472 | L: linuxppc-dev@ozlabs.org |
| 5182 | L: sdhci-devel@lists.ossman.eu | 4473 | L: sdhci-devel@lists.ossman.eu |
| 5183 | S: Maintained | 4474 | S: Maintained |
| 5184 | F: drivers/mmc/host/sdhci.* | 4475 | F: drivers/mmc/host/sdhci.* |
| 5185 | 4476 | ||
| 5186 | SECURE DIGITAL HOST CONTROLLER INTERFACE (SDHCI) SAMSUNG DRIVER | 4477 | SECURE DIGITAL HOST CONTROLLER INTERFACE (SDHCI) SAMSUNG DRIVER |
| 5187 | P: Ben Dooks | 4478 | M: Ben Dooks <ben-linux@fluff.org> |
| 5188 | M: ben-linux@fluff.org | ||
| 5189 | L: sdhci-devel@lists.ossman.eu | 4479 | L: sdhci-devel@lists.ossman.eu |
| 5190 | S: Maintained | 4480 | S: Maintained |
| 5191 | F: drivers/mmc/host/sdhci-s3c.c | 4481 | F: drivers/mmc/host/sdhci-s3c.c |
| 5192 | 4482 | ||
| 5193 | SECURITY SUBSYSTEM | 4483 | SECURITY SUBSYSTEM |
| 5194 | P: James Morris | 4484 | M: James Morris <jmorris@namei.org> |
| 5195 | M: jmorris@namei.org | ||
| 5196 | L: linux-security-module@vger.kernel.org (suggested Cc:) | 4485 | L: linux-security-module@vger.kernel.org (suggested Cc:) |
| 5197 | T: git git://www.kernel.org/pub/scm/linux/kernel/git/jmorris/security-testing-2.6.git | 4486 | T: git git://www.kernel.org/pub/scm/linux/kernel/git/jmorris/security-testing-2.6.git |
| 5198 | W: http://security.wiki.kernel.org/ | 4487 | W: http://security.wiki.kernel.org/ |
| @@ -5200,17 +4489,13 @@ S: Supported | |||
| 5200 | F: security/ | 4489 | F: security/ |
| 5201 | 4490 | ||
| 5202 | SECURITY CONTACT | 4491 | SECURITY CONTACT |
| 5203 | P: Security Officers | 4492 | M: Security Officers <security@kernel.org> |
| 5204 | M: security@kernel.org | ||
| 5205 | S: Supported | 4493 | S: Supported |
| 5206 | 4494 | ||
| 5207 | SELINUX SECURITY MODULE | 4495 | SELINUX SECURITY MODULE |
| 5208 | P: Stephen Smalley | 4496 | M: Stephen Smalley <sds@tycho.nsa.gov> |
| 5209 | M: sds@tycho.nsa.gov | 4497 | M: James Morris <jmorris@namei.org> |
| 5210 | P: James Morris | 4498 | M: Eric Paris <eparis@parisplace.org> |
| 5211 | M: jmorris@namei.org | ||
| 5212 | P: Eric Paris | ||
| 5213 | M: eparis@parisplace.org | ||
| 5214 | L: selinux@tycho.nsa.gov (subscribers-only, general discussion) | 4499 | L: selinux@tycho.nsa.gov (subscribers-only, general discussion) |
| 5215 | W: http://selinuxproject.org | 4500 | W: http://selinuxproject.org |
| 5216 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jmorris/security-testing-2.6.git | 4501 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jmorris/security-testing-2.6.git |
| @@ -5219,15 +4504,13 @@ F: include/linux/selinux* | |||
| 5219 | F: security/selinux/ | 4504 | F: security/selinux/ |
| 5220 | 4505 | ||
| 5221 | SENSABLE PHANTOM | 4506 | SENSABLE PHANTOM |
| 5222 | P: Jiri Slaby | 4507 | M: Jiri Slaby <jirislaby@gmail.com> |
| 5223 | M: jirislaby@gmail.com | ||
| 5224 | S: Maintained | 4508 | S: Maintained |
| 5225 | F: drivers/misc/phantom.c | 4509 | F: drivers/misc/phantom.c |
| 5226 | F: include/linux/phantom.h | 4510 | F: include/linux/phantom.h |
| 5227 | 4511 | ||
| 5228 | SERIAL ATA (SATA) SUBSYSTEM | 4512 | SERIAL ATA (SATA) SUBSYSTEM |
| 5229 | P: Jeff Garzik | 4513 | M: Jeff Garzik <jgarzik@pobox.com> |
| 5230 | M: jgarzik@pobox.com | ||
| 5231 | L: linux-ide@vger.kernel.org | 4514 | L: linux-ide@vger.kernel.org |
| 5232 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jgarzik/libata-dev.git | 4515 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jgarzik/libata-dev.git |
| 5233 | S: Supported | 4516 | S: Supported |
| @@ -5236,10 +4519,8 @@ F: include/linux/ata.h | |||
| 5236 | F: include/linux/libata.h | 4519 | F: include/linux/libata.h |
| 5237 | 4520 | ||
| 5238 | SERVER ENGINES 10Gbps NIC - BladeEngine 2 DRIVER | 4521 | SERVER ENGINES 10Gbps NIC - BladeEngine 2 DRIVER |
| 5239 | P: Sathya Perla | 4522 | M: Sathya Perla <sathyap@serverengines.com> |
| 5240 | M: sathyap@serverengines.com | 4523 | M: Subbu Seetharaman <subbus@serverengines.com> |
| 5241 | P: Subbu Seetharaman | ||
| 5242 | M: subbus@serverengines.com | ||
| 5243 | L: netdev@vger.kernel.org | 4524 | L: netdev@vger.kernel.org |
| 5244 | W: http://www.serverengines.com | 4525 | W: http://www.serverengines.com |
| 5245 | S: Supported | 4526 | S: Supported |
| @@ -5248,20 +4529,17 @@ F: drivers/net/benet/ | |||
| 5248 | SFC NETWORK DRIVER | 4529 | SFC NETWORK DRIVER |
| 5249 | P: Steve Hodgson | 4530 | P: Steve Hodgson |
| 5250 | P: Ben Hutchings | 4531 | P: Ben Hutchings |
| 5251 | P: Robert Stonehouse | 4532 | M: Robert Stonehouse <linux-net-drivers@solarflare.com> |
| 5252 | M: linux-net-drivers@solarflare.com | ||
| 5253 | S: Supported | 4533 | S: Supported |
| 5254 | F: drivers/net/sfc/ | 4534 | F: drivers/net/sfc/ |
| 5255 | 4535 | ||
| 5256 | SGI GRU DRIVER | 4536 | SGI GRU DRIVER |
| 5257 | P: Jack Steiner | 4537 | M: Jack Steiner <steiner@sgi.com> |
| 5258 | M: steiner@sgi.com | ||
| 5259 | S: Maintained | 4538 | S: Maintained |
| 5260 | F: drivers/misc/sgi-gru/ | 4539 | F: drivers/misc/sgi-gru/ |
| 5261 | 4540 | ||
| 5262 | SGI SN-IA64 (Altix) SERIAL CONSOLE DRIVER | 4541 | SGI SN-IA64 (Altix) SERIAL CONSOLE DRIVER |
| 5263 | P: Pat Gefre | 4542 | M: Pat Gefre <pfg@sgi.com> |
| 5264 | M: pfg@sgi.com | ||
| 5265 | L: linux-ia64@vger.kernel.org | 4543 | L: linux-ia64@vger.kernel.org |
| 5266 | S: Supported | 4544 | S: Supported |
| 5267 | F: Documentation/ia64/serial.txt | 4545 | F: Documentation/ia64/serial.txt |
| @@ -5269,22 +4547,19 @@ F: drivers/serial/ioc?_serial.c | |||
| 5269 | F: include/linux/ioc?.h | 4547 | F: include/linux/ioc?.h |
| 5270 | 4548 | ||
| 5271 | SGI VISUAL WORKSTATION 320 AND 540 | 4549 | SGI VISUAL WORKSTATION 320 AND 540 |
| 5272 | P: Andrey Panin | 4550 | M: Andrey Panin <pazke@donpac.ru> |
| 5273 | M: pazke@donpac.ru | ||
| 5274 | L: linux-visws-devel@lists.sf.net | 4551 | L: linux-visws-devel@lists.sf.net |
| 5275 | W: http://linux-visws.sf.net | 4552 | W: http://linux-visws.sf.net |
| 5276 | S: Maintained for 2.6. | 4553 | S: Maintained for 2.6. |
| 5277 | F: Documentation/sgi-visws.txt | 4554 | F: Documentation/sgi-visws.txt |
| 5278 | 4555 | ||
| 5279 | SGI XP/XPC/XPNET DRIVER | 4556 | SGI XP/XPC/XPNET DRIVER |
| 5280 | P: Robin Holt | 4557 | M: Robin Holt <holt@sgi.com> |
| 5281 | M: holt@sgi.com | ||
| 5282 | S: Maintained | 4558 | S: Maintained |
| 5283 | F: drivers/misc/sgi-xp/ | 4559 | F: drivers/misc/sgi-xp/ |
| 5284 | 4560 | ||
| 5285 | SHARP LH SUPPORT (LH7952X & LH7A40X) | 4561 | SHARP LH SUPPORT (LH7952X & LH7A40X) |
| 5286 | P: Marc Singer | 4562 | M: Marc Singer <elf@buici.com> |
| 5287 | M: elf@buici.com | ||
| 5288 | W: http://projects.buici.com/arm | 4563 | W: http://projects.buici.com/arm |
| 5289 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) | 4564 | L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) |
| 5290 | S: Maintained | 4565 | S: Maintained |
| @@ -5295,23 +4570,20 @@ F: drivers/usb/gadget/lh7a40* | |||
| 5295 | F: drivers/usb/host/ohci-lh7a40* | 4570 | F: drivers/usb/host/ohci-lh7a40* |
| 5296 | 4571 | ||
| 5297 | SHPC HOTPLUG DRIVER | 4572 | SHPC HOTPLUG DRIVER |
| 5298 | P: Kristen Carlson Accardi | 4573 | M: Kristen Carlson Accardi <kristen.c.accardi@intel.com> |
| 5299 | M: kristen.c.accardi@intel.com | ||
| 5300 | L: linux-pci@vger.kernel.org | 4574 | L: linux-pci@vger.kernel.org |
| 5301 | S: Supported | 4575 | S: Supported |
| 5302 | F: drivers/pci/hotplug/shpchp* | 4576 | F: drivers/pci/hotplug/shpchp* |
| 5303 | 4577 | ||
| 5304 | SIMTEC EB110ATX (Chalice CATS) | 4578 | SIMTEC EB110ATX (Chalice CATS) |
| 5305 | P: Ben Dooks | 4579 | P: Ben Dooks |
| 5306 | P: Vincent Sanders | 4580 | M: Vincent Sanders <support@simtec.co.uk> |
| 5307 | M: support@simtec.co.uk | ||
| 5308 | W: http://www.simtec.co.uk/products/EB110ATX/ | 4581 | W: http://www.simtec.co.uk/products/EB110ATX/ |
| 5309 | S: Supported | 4582 | S: Supported |
| 5310 | 4583 | ||
| 5311 | SIMTEC EB2410ITX (BAST) | 4584 | SIMTEC EB2410ITX (BAST) |
| 5312 | P: Ben Dooks | 4585 | P: Ben Dooks |
| 5313 | P: Vincent Sanders | 4586 | M: Vincent Sanders <support@simtec.co.uk> |
| 5314 | M: support@simtec.co.uk | ||
| 5315 | W: http://www.simtec.co.uk/products/EB2410ITX/ | 4587 | W: http://www.simtec.co.uk/products/EB2410ITX/ |
| 5316 | S: Supported | 4588 | S: Supported |
| 5317 | F: arch/arm/mach-s3c2410/ | 4589 | F: arch/arm/mach-s3c2410/ |
| @@ -5319,31 +4591,27 @@ F: drivers/*/*s3c2410* | |||
| 5319 | F: drivers/*/*/*s3c2410* | 4591 | F: drivers/*/*/*s3c2410* |
| 5320 | 4592 | ||
| 5321 | SIS 190 ETHERNET DRIVER | 4593 | SIS 190 ETHERNET DRIVER |
| 5322 | P: Francois Romieu | 4594 | M: Francois Romieu <romieu@fr.zoreil.com> |
| 5323 | M: romieu@fr.zoreil.com | ||
| 5324 | L: netdev@vger.kernel.org | 4595 | L: netdev@vger.kernel.org |
| 5325 | S: Maintained | 4596 | S: Maintained |
| 5326 | F: drivers/net/sis190.c | 4597 | F: drivers/net/sis190.c |
| 5327 | 4598 | ||
| 5328 | SIS 900/7016 FAST ETHERNET DRIVER | 4599 | SIS 900/7016 FAST ETHERNET DRIVER |
| 5329 | P: Daniele Venzano | 4600 | M: Daniele Venzano <venza@brownhat.org> |
| 5330 | M: venza@brownhat.org | ||
| 5331 | W: http://www.brownhat.org/sis900.html | 4601 | W: http://www.brownhat.org/sis900.html |
| 5332 | L: netdev@vger.kernel.org | 4602 | L: netdev@vger.kernel.org |
| 5333 | S: Maintained | 4603 | S: Maintained |
| 5334 | F: drivers/net/sis900.* | 4604 | F: drivers/net/sis900.* |
| 5335 | 4605 | ||
| 5336 | SIS 96X I2C/SMBUS DRIVER | 4606 | SIS 96X I2C/SMBUS DRIVER |
| 5337 | P: Mark M. Hoffman | 4607 | M: "Mark M. Hoffman" <mhoffman@lightlink.com> |
| 5338 | M: mhoffman@lightlink.com | ||
| 5339 | L: linux-i2c@vger.kernel.org | 4608 | L: linux-i2c@vger.kernel.org |
| 5340 | S: Maintained | 4609 | S: Maintained |
| 5341 | F: Documentation/i2c/busses/i2c-sis96x | 4610 | F: Documentation/i2c/busses/i2c-sis96x |
| 5342 | F: drivers/i2c/busses/i2c-sis96x.c | 4611 | F: drivers/i2c/busses/i2c-sis96x.c |
| 5343 | 4612 | ||
| 5344 | SIS FRAMEBUFFER DRIVER | 4613 | SIS FRAMEBUFFER DRIVER |
| 5345 | P: Thomas Winischhofer | 4614 | M: Thomas Winischhofer <thomas@winischhofer.net> |
| 5346 | M: thomas@winischhofer.net | ||
| 5347 | W: http://www.winischhofer.net/linuxsisvga.shtml | 4615 | W: http://www.winischhofer.net/linuxsisvga.shtml |
| 5348 | S: Maintained | 4616 | S: Maintained |
| 5349 | F: Documentation/fb/sisfb.txt | 4617 | F: Documentation/fb/sisfb.txt |
| @@ -5351,70 +4619,59 @@ F: drivers/video/sis/ | |||
| 5351 | F: include/video/sisfb.h | 4619 | F: include/video/sisfb.h |
| 5352 | 4620 | ||
| 5353 | SIS USB2VGA DRIVER | 4621 | SIS USB2VGA DRIVER |
| 5354 | P: Thomas Winischhofer | 4622 | M: Thomas Winischhofer <thomas@winischhofer.net> |
| 5355 | M: thomas@winischhofer.net | ||
| 5356 | W: http://www.winischhofer.at/linuxsisusbvga.shtml | 4623 | W: http://www.winischhofer.at/linuxsisusbvga.shtml |
| 5357 | S: Maintained | 4624 | S: Maintained |
| 5358 | F: drivers/usb/misc/sisusbvga/ | 4625 | F: drivers/usb/misc/sisusbvga/ |
| 5359 | 4626 | ||
| 5360 | SKGE, SKY2 10/100/1000 GIGABIT ETHERNET DRIVERS | 4627 | SKGE, SKY2 10/100/1000 GIGABIT ETHERNET DRIVERS |
| 5361 | P: Stephen Hemminger | 4628 | M: Stephen Hemminger <shemminger@linux-foundation.org> |
| 5362 | M: shemminger@linux-foundation.org | ||
| 5363 | L: netdev@vger.kernel.org | 4629 | L: netdev@vger.kernel.org |
| 5364 | S: Maintained | 4630 | S: Maintained |
| 5365 | F: drivers/net/skge.* | 4631 | F: drivers/net/skge.* |
| 5366 | F: drivers/net/sky2.* | 4632 | F: drivers/net/sky2.* |
| 5367 | 4633 | ||
| 5368 | SLAB ALLOCATOR | 4634 | SLAB ALLOCATOR |
| 5369 | P: Christoph Lameter | 4635 | M: Christoph Lameter <cl@linux-foundation.org> |
| 5370 | M: cl@linux-foundation.org | 4636 | M: Pekka Enberg <penberg@cs.helsinki.fi> |
| 5371 | P: Pekka Enberg | 4637 | M: Matt Mackall <mpm@selenic.com> |
| 5372 | M: penberg@cs.helsinki.fi | ||
| 5373 | P: Matt Mackall | ||
| 5374 | M: mpm@selenic.com | ||
| 5375 | L: linux-mm@kvack.org | 4638 | L: linux-mm@kvack.org |
| 5376 | S: Maintained | 4639 | S: Maintained |
| 5377 | F: include/linux/sl?b*.h | 4640 | F: include/linux/sl?b*.h |
| 5378 | F: mm/sl?b.c | 4641 | F: mm/sl?b.c |
| 5379 | 4642 | ||
| 5380 | SMC91x ETHERNET DRIVER | 4643 | SMC91x ETHERNET DRIVER |
| 5381 | P: Nicolas Pitre | 4644 | M: Nicolas Pitre <nico@cam.org> |
| 5382 | M: nico@cam.org | ||
| 5383 | S: Maintained | 4645 | S: Maintained |
| 5384 | F: drivers/net/smc91x.* | 4646 | F: drivers/net/smc91x.* |
| 5385 | 4647 | ||
| 5386 | SMSC47B397 HARDWARE MONITOR DRIVER | 4648 | SMSC47B397 HARDWARE MONITOR DRIVER |
| 5387 | P: Mark M. Hoffman | 4649 | M: "Mark M. Hoffman" <mhoffman@lightlink.com> |
| 5388 | M: mhoffman@lightlink.com | ||
| 5389 | L: lm-sensors@lm-sensors.org | 4650 | L: lm-sensors@lm-sensors.org |
| 5390 | S: Maintained | 4651 | S: Maintained |
| 5391 | F: Documentation/hwmon/smsc47b397 | 4652 | F: Documentation/hwmon/smsc47b397 |
| 5392 | F: drivers/hwmon/smsc47b397.c | 4653 | F: drivers/hwmon/smsc47b397.c |
| 5393 | 4654 | ||
| 5394 | SMSC911x ETHERNET DRIVER | 4655 | SMSC911x ETHERNET DRIVER |
| 5395 | P: Steve Glendinning | 4656 | M: Steve Glendinning <steve.glendinning@smsc.com> |
| 5396 | M: steve.glendinning@smsc.com | ||
| 5397 | L: netdev@vger.kernel.org | 4657 | L: netdev@vger.kernel.org |
| 5398 | S: Supported | 4658 | S: Supported |
| 5399 | F: include/linux/smsc911x.h | 4659 | F: include/linux/smsc911x.h |
| 5400 | F: drivers/net/smsc911x.* | 4660 | F: drivers/net/smsc911x.* |
| 5401 | 4661 | ||
| 5402 | SMSC9420 PCI ETHERNET DRIVER | 4662 | SMSC9420 PCI ETHERNET DRIVER |
| 5403 | P: Steve Glendinning | 4663 | M: Steve Glendinning <steve.glendinning@smsc.com> |
| 5404 | M: steve.glendinning@smsc.com | ||
| 5405 | L: netdev@vger.kernel.org | 4664 | L: netdev@vger.kernel.org |
| 5406 | S: Supported | 4665 | S: Supported |
| 5407 | F: drivers/net/smsc9420.* | 4666 | F: drivers/net/smsc9420.* |
| 5408 | 4667 | ||
| 5409 | SMX UIO Interface | 4668 | SMX UIO Interface |
| 5410 | P: Ben Nizette | 4669 | M: Ben Nizette <bn@niasdigital.com> |
| 5411 | M: bn@niasdigital.com | ||
| 5412 | S: Maintained | 4670 | S: Maintained |
| 5413 | F: drivers/uio/uio_smx.c | 4671 | F: drivers/uio/uio_smx.c |
| 5414 | 4672 | ||
| 5415 | SN-IA64 (Itanium) SUB-PLATFORM | 4673 | SN-IA64 (Itanium) SUB-PLATFORM |
| 5416 | P: Jes Sorensen | 4674 | M: Jes Sorensen <jes@sgi.com> |
| 5417 | M: jes@sgi.com | ||
| 5418 | L: linux-altix@sgi.com | 4675 | L: linux-altix@sgi.com |
| 5419 | L: linux-ia64@vger.kernel.org | 4676 | L: linux-ia64@vger.kernel.org |
| 5420 | W: http://www.sgi.com/altix | 4677 | W: http://www.sgi.com/altix |
| @@ -5422,8 +4679,7 @@ S: Maintained | |||
| 5422 | F: arch/ia64/sn/ | 4679 | F: arch/ia64/sn/ |
| 5423 | 4680 | ||
| 5424 | SOC-CAMERA V4L2 SUBSYSTEM | 4681 | SOC-CAMERA V4L2 SUBSYSTEM |
| 5425 | P: Guennadi Liakhovetski | 4682 | M: Guennadi Liakhovetski <g.liakhovetski@gmx.de> |
| 5426 | M: g.liakhovetski@gmx.de | ||
| 5427 | L: linux-media@vger.kernel.org | 4683 | L: linux-media@vger.kernel.org |
| 5428 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 4684 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| 5429 | S: Maintained | 4685 | S: Maintained |
| @@ -5431,37 +4687,32 @@ F: include/media/v4l2* | |||
| 5431 | F: drivers/media/video/v4l2* | 4687 | F: drivers/media/video/v4l2* |
| 5432 | 4688 | ||
| 5433 | SOEKRIS NET48XX LED SUPPORT | 4689 | SOEKRIS NET48XX LED SUPPORT |
| 5434 | P: Chris Boot | 4690 | M: Chris Boot <bootc@bootc.net> |
| 5435 | M: bootc@bootc.net | ||
| 5436 | S: Maintained | 4691 | S: Maintained |
| 5437 | F: drivers/leds/leds-net48xx.c | 4692 | F: drivers/leds/leds-net48xx.c |
| 5438 | 4693 | ||
| 5439 | SOFTWARE RAID (Multiple Disks) SUPPORT | 4694 | SOFTWARE RAID (Multiple Disks) SUPPORT |
| 5440 | P: Neil Brown | 4695 | M: Neil Brown <neilb@suse.de> |
| 5441 | M: neilb@suse.de | ||
| 5442 | L: linux-raid@vger.kernel.org | 4696 | L: linux-raid@vger.kernel.org |
| 5443 | S: Supported | 4697 | S: Supported |
| 5444 | F: drivers/md/ | 4698 | F: drivers/md/ |
| 5445 | F: include/linux/raid/ | 4699 | F: include/linux/raid/ |
| 5446 | 4700 | ||
| 5447 | SONIC NETWORK DRIVER | 4701 | SONIC NETWORK DRIVER |
| 5448 | P: Thomas Bogendoerfer | 4702 | M: Thomas Bogendoerfer <tsbogend@alpha.franken.de> |
| 5449 | M: tsbogend@alpha.franken.de | ||
| 5450 | L: netdev@vger.kernel.org | 4703 | L: netdev@vger.kernel.org |
| 5451 | S: Maintained | 4704 | S: Maintained |
| 5452 | F: drivers/net/sonic.* | 4705 | F: drivers/net/sonic.* |
| 5453 | 4706 | ||
| 5454 | SONICS SILICON BACKPLANE DRIVER (SSB) | 4707 | SONICS SILICON BACKPLANE DRIVER (SSB) |
| 5455 | P: Michael Buesch | 4708 | M: Michael Buesch <mb@bu3sch.de> |
| 5456 | M: mb@bu3sch.de | ||
| 5457 | L: netdev@vger.kernel.org | 4709 | L: netdev@vger.kernel.org |
| 5458 | S: Maintained | 4710 | S: Maintained |
| 5459 | F: drivers/ssb/ | 4711 | F: drivers/ssb/ |
| 5460 | F: include/linux/ssb/ | 4712 | F: include/linux/ssb/ |
| 5461 | 4713 | ||
| 5462 | SONY VAIO CONTROL DEVICE DRIVER | 4714 | SONY VAIO CONTROL DEVICE DRIVER |
| 5463 | P: Mattia Dongili | 4715 | M: Mattia Dongili <malattia@linux.it> |
| 5464 | M: malattia@linux.it | ||
| 5465 | L: linux-acpi@vger.kernel.org | 4716 | L: linux-acpi@vger.kernel.org |
| 5466 | W: http://www.linux.it/~malattia/wiki/index.php/Sony_drivers | 4717 | W: http://www.linux.it/~malattia/wiki/index.php/Sony_drivers |
| 5467 | S: Maintained | 4718 | S: Maintained |
| @@ -5471,17 +4722,14 @@ F: drivers/platform/x86/sony-laptop.c | |||
| 5471 | F: include/linux/sony-laptop.h | 4722 | F: include/linux/sony-laptop.h |
| 5472 | 4723 | ||
| 5473 | SONY MEMORYSTICK CARD SUPPORT | 4724 | SONY MEMORYSTICK CARD SUPPORT |
| 5474 | P: Alex Dubov | 4725 | M: Alex Dubov <oakad@yahoo.com> |
| 5475 | M: oakad@yahoo.com | ||
| 5476 | W: http://tifmxx.berlios.de/ | 4726 | W: http://tifmxx.berlios.de/ |
| 5477 | S: Maintained | 4727 | S: Maintained |
| 5478 | F: drivers/memstick/host/tifm_ms.c | 4728 | F: drivers/memstick/host/tifm_ms.c |
| 5479 | 4729 | ||
| 5480 | SOUND | 4730 | SOUND |
| 5481 | P: Jaroslav Kysela | 4731 | M: Jaroslav Kysela <perex@perex.cz> |
| 5482 | M: perex@perex.cz | 4732 | M: Takashi Iwai <tiwai@suse.de> |
| 5483 | P: Takashi Iwai | ||
| 5484 | M: tiwai@suse.de | ||
| 5485 | L: alsa-devel@alsa-project.org (moderated for non-subscribers) | 4733 | L: alsa-devel@alsa-project.org (moderated for non-subscribers) |
| 5486 | W: http://www.alsa-project.org/ | 4734 | W: http://www.alsa-project.org/ |
| 5487 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound-2.6.git | 4735 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound-2.6.git |
| @@ -5492,10 +4740,8 @@ F: include/sound/ | |||
| 5492 | F: sound/ | 4740 | F: sound/ |
| 5493 | 4741 | ||
| 5494 | SOUND - SOC LAYER / DYNAMIC AUDIO POWER MANAGEMENT (ASoC) | 4742 | SOUND - SOC LAYER / DYNAMIC AUDIO POWER MANAGEMENT (ASoC) |
| 5495 | P: Liam Girdwood | 4743 | M: Liam Girdwood <lrg@slimlogic.co.uk> |
| 5496 | M: lrg@slimlogic.co.uk | 4744 | M: Mark Brown <broonie@opensource.wolfsonmicro.com> |
| 5497 | P: Mark Brown | ||
| 5498 | M: broonie@opensource.wolfsonmicro.com | ||
| 5499 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound-2.6.git | 4745 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound-2.6.git |
| 5500 | L: alsa-devel@alsa-project.org (moderated for non-subscribers) | 4746 | L: alsa-devel@alsa-project.org (moderated for non-subscribers) |
| 5501 | W: http://alsa-project.org/main/index.php/ASoC | 4747 | W: http://alsa-project.org/main/index.php/ASoC |
| @@ -5504,8 +4750,7 @@ F: sound/soc/ | |||
| 5504 | F: include/sound/soc* | 4750 | F: include/sound/soc* |
| 5505 | 4751 | ||
| 5506 | SPARC + UltraSPARC (sparc/sparc64) | 4752 | SPARC + UltraSPARC (sparc/sparc64) |
| 5507 | P: David S. Miller | 4753 | M: "David S. Miller" <davem@davemloft.net> |
| 5508 | M: davem@davemloft.net | ||
| 5509 | L: sparclinux@vger.kernel.org | 4754 | L: sparclinux@vger.kernel.org |
| 5510 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-2.6.git | 4755 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-2.6.git |
| 5511 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-next-2.6.git | 4756 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-next-2.6.git |
| @@ -5513,15 +4758,13 @@ S: Maintained | |||
| 5513 | F: arch/sparc/ | 4758 | F: arch/sparc/ |
| 5514 | 4759 | ||
| 5515 | SPECIALIX IO8+ MULTIPORT SERIAL CARD DRIVER | 4760 | SPECIALIX IO8+ MULTIPORT SERIAL CARD DRIVER |
| 5516 | P: Roger Wolff | 4761 | M: Roger Wolff <R.E.Wolff@BitWizard.nl> |
| 5517 | M: R.E.Wolff@BitWizard.nl | ||
| 5518 | S: Supported | 4762 | S: Supported |
| 5519 | F: Documentation/serial/specialix.txt | 4763 | F: Documentation/serial/specialix.txt |
| 5520 | F: drivers/char/specialix* | 4764 | F: drivers/char/specialix* |
| 5521 | 4765 | ||
| 5522 | SPI SUBSYSTEM | 4766 | SPI SUBSYSTEM |
| 5523 | P: David Brownell | 4767 | M: David Brownell <dbrownell@users.sourceforge.net> |
| 5524 | M: dbrownell@users.sourceforge.net | ||
| 5525 | L: spi-devel-general@lists.sourceforge.net | 4768 | L: spi-devel-general@lists.sourceforge.net |
| 5526 | S: Maintained | 4769 | S: Maintained |
| 5527 | F: Documentation/spi/ | 4770 | F: Documentation/spi/ |
| @@ -5529,18 +4772,15 @@ F: drivers/spi/ | |||
| 5529 | F: include/linux/spi/ | 4772 | F: include/linux/spi/ |
| 5530 | 4773 | ||
| 5531 | SPIDERNET NETWORK DRIVER for CELL | 4774 | SPIDERNET NETWORK DRIVER for CELL |
| 5532 | P: Ishizaki Kou | 4775 | M: Ishizaki Kou <kou.ishizaki@toshiba.co.jp> |
| 5533 | M: kou.ishizaki@toshiba.co.jp | 4776 | M: Jens Osterkamp <jens@de.ibm.com> |
| 5534 | P: Jens Osterkamp | ||
| 5535 | M: jens@de.ibm.com | ||
| 5536 | L: netdev@vger.kernel.org | 4777 | L: netdev@vger.kernel.org |
| 5537 | S: Supported | 4778 | S: Supported |
| 5538 | F: Documentation/networking/spider_net.txt | 4779 | F: Documentation/networking/spider_net.txt |
| 5539 | F: drivers/net/spider_net* | 4780 | F: drivers/net/spider_net* |
| 5540 | 4781 | ||
| 5541 | SPU FILE SYSTEM | 4782 | SPU FILE SYSTEM |
| 5542 | P: Jeremy Kerr | 4783 | M: Jeremy Kerr <jk@ozlabs.org> |
| 5543 | M: jk@ozlabs.org | ||
| 5544 | L: linuxppc-dev@ozlabs.org | 4784 | L: linuxppc-dev@ozlabs.org |
| 5545 | L: cbe-oss-dev@ozlabs.org | 4785 | L: cbe-oss-dev@ozlabs.org |
| 5546 | W: http://www.ibm.com/developerworks/power/cell/ | 4786 | W: http://www.ibm.com/developerworks/power/cell/ |
| @@ -5549,8 +4789,7 @@ F: Documentation/filesystems/spufs.txt | |||
| 5549 | F: arch/powerpc/platforms/cell/spufs/ | 4789 | F: arch/powerpc/platforms/cell/spufs/ |
| 5550 | 4790 | ||
| 5551 | SQUASHFS FILE SYSTEM | 4791 | SQUASHFS FILE SYSTEM |
| 5552 | P: Phillip Lougher | 4792 | M: Phillip Lougher <phillip@lougher.demon.co.uk> |
| 5553 | M: phillip@lougher.demon.co.uk | ||
| 5554 | L: squashfs-devel@lists.sourceforge.net (subscribers-only) | 4793 | L: squashfs-devel@lists.sourceforge.net (subscribers-only) |
| 5555 | W: http://squashfs.org.uk | 4794 | W: http://squashfs.org.uk |
| 5556 | S: Maintained | 4795 | S: Maintained |
| @@ -5558,49 +4797,41 @@ F: Documentation/filesystems/squashfs.txt | |||
| 5558 | F: fs/squashfs/ | 4797 | F: fs/squashfs/ |
| 5559 | 4798 | ||
| 5560 | SRM (Alpha) environment access | 4799 | SRM (Alpha) environment access |
| 5561 | P: Jan-Benedict Glaw | 4800 | M: Jan-Benedict Glaw <jbglaw@lug-owl.de> |
| 5562 | M: jbglaw@lug-owl.de | ||
| 5563 | S: Maintained | 4801 | S: Maintained |
| 5564 | F: arch/alpha/kernel/srm_env.c | 4802 | F: arch/alpha/kernel/srm_env.c |
| 5565 | 4803 | ||
| 5566 | STABLE BRANCH | 4804 | STABLE BRANCH |
| 5567 | P: Greg Kroah-Hartman | 4805 | M: Greg Kroah-Hartman <greg@kroah.com> |
| 5568 | M: greg@kroah.com | 4806 | M: Chris Wright <chrisw@sous-sol.org> |
| 5569 | P: Chris Wright | ||
| 5570 | M: chrisw@sous-sol.org | ||
| 5571 | L: stable@kernel.org | 4807 | L: stable@kernel.org |
| 5572 | S: Maintained | 4808 | S: Maintained |
| 5573 | 4809 | ||
| 5574 | STAGING SUBSYSTEM | 4810 | STAGING SUBSYSTEM |
| 5575 | P: Greg Kroah-Hartman | 4811 | M: Greg Kroah-Hartman <gregkh@suse.de> |
| 5576 | M: gregkh@suse.de | ||
| 5577 | T: quilt kernel.org/pub/linux/kernel/people/gregkh/gregkh-2.6/ | 4812 | T: quilt kernel.org/pub/linux/kernel/people/gregkh/gregkh-2.6/ |
| 5578 | L: devel@driverdev.osuosl.org | 4813 | L: devel@driverdev.osuosl.org |
| 5579 | S: Maintained | 4814 | S: Maintained |
| 5580 | F: drivers/staging/ | 4815 | F: drivers/staging/ |
| 5581 | 4816 | ||
| 5582 | STARFIRE/DURALAN NETWORK DRIVER | 4817 | STARFIRE/DURALAN NETWORK DRIVER |
| 5583 | P: Ion Badulescu | 4818 | M: Ion Badulescu <ionut@badula.org> |
| 5584 | M: ionut@badula.org | ||
| 5585 | S: Odd Fixes | 4819 | S: Odd Fixes |
| 5586 | F: drivers/net/starfire* | 4820 | F: drivers/net/starfire* |
| 5587 | 4821 | ||
| 5588 | STARMODE RADIO IP (STRIP) PROTOCOL DRIVER | 4822 | STARMODE RADIO IP (STRIP) PROTOCOL DRIVER |
| 5589 | W: http://mosquitonet.Stanford.EDU/strip.html | ||
| 5590 | S: Orphan | 4823 | S: Orphan |
| 5591 | F: drivers/net/wireless/strip.c | 4824 | F: drivers/net/wireless/strip.c |
| 5592 | F: include/linux/if_strip.h | 4825 | F: include/linux/if_strip.h |
| 5593 | 4826 | ||
| 5594 | STRADIS MPEG-2 DECODER DRIVER | 4827 | STRADIS MPEG-2 DECODER DRIVER |
| 5595 | P: Nathan Laredo | 4828 | M: Nathan Laredo <laredo@gnu.org> |
| 5596 | M: laredo@gnu.org | ||
| 5597 | W: http://www.stradis.com/ | 4829 | W: http://www.stradis.com/ |
| 5598 | S: Maintained | 4830 | S: Maintained |
| 5599 | F: drivers/media/video/stradis.c | 4831 | F: drivers/media/video/stradis.c |
| 5600 | 4832 | ||
| 5601 | SUN3/3X | 4833 | SUN3/3X |
| 5602 | P: Sam Creasey | 4834 | M: Sam Creasey <sammy@sammy.net> |
| 5603 | M: sammy@sammy.net | ||
| 5604 | W: http://sammy.net/sun3/ | 4835 | W: http://sammy.net/sun3/ |
| 5605 | S: Maintained | 4836 | S: Maintained |
| 5606 | F: arch/m68k/kernel/*sun3* | 4837 | F: arch/m68k/kernel/*sun3* |
| @@ -5608,8 +4839,7 @@ F: arch/m68k/sun3*/ | |||
| 5608 | F: arch/m68k/include/asm/sun3* | 4839 | F: arch/m68k/include/asm/sun3* |
| 5609 | 4840 | ||
| 5610 | SUPERH | 4841 | SUPERH |
| 5611 | P: Paul Mundt | 4842 | M: Paul Mundt <lethal@linux-sh.org> |
| 5612 | M: lethal@linux-sh.org | ||
| 5613 | L: linux-sh@vger.kernel.org | 4843 | L: linux-sh@vger.kernel.org |
| 5614 | W: http://www.linux-sh.org | 4844 | W: http://www.linux-sh.org |
| 5615 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/lethal/sh-2.6.git | 4845 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/lethal/sh-2.6.git |
| @@ -5619,12 +4849,9 @@ F: arch/sh/ | |||
| 5619 | F: drivers/sh/ | 4849 | F: drivers/sh/ |
| 5620 | 4850 | ||
| 5621 | SUSPEND TO RAM | 4851 | SUSPEND TO RAM |
| 5622 | P: Len Brown | 4852 | M: Len Brown <len.brown@intel.com> |
| 5623 | M: len.brown@intel.com | 4853 | M: Pavel Machek <pavel@ucw.cz> |
| 5624 | P: Pavel Machek | 4854 | M: "Rafael J. Wysocki" <rjw@sisk.pl> |
| 5625 | M: pavel@ucw.cz | ||
| 5626 | P: Rafael J. Wysocki | ||
| 5627 | M: rjw@sisk.pl | ||
| 5628 | L: linux-pm@lists.linux-foundation.org | 4855 | L: linux-pm@lists.linux-foundation.org |
| 5629 | S: Supported | 4856 | S: Supported |
| 5630 | F: Documentation/power/ | 4857 | F: Documentation/power/ |
| @@ -5636,32 +4863,28 @@ F: include/linux/freezer.h | |||
| 5636 | F: include/linux/pm.h | 4863 | F: include/linux/pm.h |
| 5637 | 4864 | ||
| 5638 | SVGA HANDLING | 4865 | SVGA HANDLING |
| 5639 | P: Martin Mares | 4866 | M: Martin Mares <mj@ucw.cz> |
| 5640 | M: mj@ucw.cz | ||
| 5641 | L: linux-video@atrey.karlin.mff.cuni.cz | 4867 | L: linux-video@atrey.karlin.mff.cuni.cz |
| 5642 | S: Maintained | 4868 | S: Maintained |
| 5643 | F: Documentation/svga.txt | 4869 | F: Documentation/svga.txt |
| 5644 | F: arch/x86/boot/video* | 4870 | F: arch/x86/boot/video* |
| 5645 | 4871 | ||
| 5646 | SYSV FILESYSTEM | 4872 | SYSV FILESYSTEM |
| 5647 | P: Christoph Hellwig | 4873 | M: Christoph Hellwig <hch@infradead.org> |
| 5648 | M: hch@infradead.org | ||
| 5649 | S: Maintained | 4874 | S: Maintained |
| 5650 | F: Documentation/filesystems/sysv-fs.txt | 4875 | F: Documentation/filesystems/sysv-fs.txt |
| 5651 | F: fs/sysv/ | 4876 | F: fs/sysv/ |
| 5652 | F: include/linux/sysv_fs.h | 4877 | F: include/linux/sysv_fs.h |
| 5653 | 4878 | ||
| 5654 | TASKSTATS STATISTICS INTERFACE | 4879 | TASKSTATS STATISTICS INTERFACE |
| 5655 | P: Balbir Singh | 4880 | M: Balbir Singh <balbir@linux.vnet.ibm.com> |
| 5656 | M: balbir@linux.vnet.ibm.com | ||
| 5657 | S: Maintained | 4881 | S: Maintained |
| 5658 | F: Documentation/accounting/taskstats* | 4882 | F: Documentation/accounting/taskstats* |
| 5659 | F: include/linux/taskstats* | 4883 | F: include/linux/taskstats* |
| 5660 | F: kernel/taskstats.c | 4884 | F: kernel/taskstats.c |
| 5661 | 4885 | ||
| 5662 | TC CLASSIFIER | 4886 | TC CLASSIFIER |
| 5663 | P: Jamal Hadi Salim | 4887 | M: Jamal Hadi Salim <hadi@cyberus.ca> |
| 5664 | M: hadi@cyberus.ca | ||
| 5665 | L: netdev@vger.kernel.org | 4888 | L: netdev@vger.kernel.org |
| 5666 | S: Maintained | 4889 | S: Maintained |
| 5667 | F: include/linux/pkt_cls.h | 4890 | F: include/linux/pkt_cls.h |
| @@ -5669,38 +4892,31 @@ F: include/net/pkt_cls.h | |||
| 5669 | F: net/sched/ | 4892 | F: net/sched/ |
| 5670 | 4893 | ||
| 5671 | TCP LOW PRIORITY MODULE | 4894 | TCP LOW PRIORITY MODULE |
| 5672 | P: Wong Hoi Sing, Edison | 4895 | M: "Wong Hoi Sing, Edison" <hswong3i@gmail.com> |
| 5673 | M: hswong3i@gmail.com | 4896 | M: "Hung Hing Lun, Mike" <hlhung3i@gmail.com> |
| 5674 | P: Hung Hing Lun, Mike | ||
| 5675 | M: hlhung3i@gmail.com | ||
| 5676 | W: http://tcp-lp-mod.sourceforge.net/ | 4897 | W: http://tcp-lp-mod.sourceforge.net/ |
| 5677 | S: Maintained | 4898 | S: Maintained |
| 5678 | F: net/ipv4/tcp_lp.c | 4899 | F: net/ipv4/tcp_lp.c |
| 5679 | 4900 | ||
| 5680 | TEHUTI ETHERNET DRIVER | 4901 | TEHUTI ETHERNET DRIVER |
| 5681 | P: Alexander Indenbaum | 4902 | M: Alexander Indenbaum <baum@tehutinetworks.net> |
| 5682 | M: baum@tehutinetworks.net | 4903 | M: Andy Gospodarek <andy@greyhouse.net> |
| 5683 | P: Andy Gospodarek | ||
| 5684 | M: andy@greyhouse.net | ||
| 5685 | L: netdev@vger.kernel.org | 4904 | L: netdev@vger.kernel.org |
| 5686 | S: Supported | 4905 | S: Supported |
| 5687 | F: drivers/net/tehuti* | 4906 | F: drivers/net/tehuti* |
| 5688 | 4907 | ||
| 5689 | Telecom Clock Driver for MCPL0010 | 4908 | Telecom Clock Driver for MCPL0010 |
| 5690 | P: Mark Gross | 4909 | M: Mark Gross <mark.gross@intel.com> |
| 5691 | M: mark.gross@intel.com | ||
| 5692 | S: Supported | 4910 | S: Supported |
| 5693 | F: drivers/char/tlclk.c | 4911 | F: drivers/char/tlclk.c |
| 5694 | 4912 | ||
| 5695 | TENSILICA XTENSA PORT (xtensa) | 4913 | TENSILICA XTENSA PORT (xtensa) |
| 5696 | P: Chris Zankel | 4914 | M: Chris Zankel <chris@zankel.net> |
| 5697 | M: chris@zankel.net | ||
| 5698 | S: Maintained | 4915 | S: Maintained |
| 5699 | F: arch/xtensa/ | 4916 | F: arch/xtensa/ |
| 5700 | 4917 | ||
| 5701 | THINKPAD ACPI EXTRAS DRIVER | 4918 | THINKPAD ACPI EXTRAS DRIVER |
| 5702 | P: Henrique de Moraes Holschuh | 4919 | M: Henrique de Moraes Holschuh <ibm-acpi@hmh.eng.br> |
| 5703 | M: ibm-acpi@hmh.eng.br | ||
| 5704 | L: ibm-acpi-devel@lists.sourceforge.net | 4920 | L: ibm-acpi-devel@lists.sourceforge.net |
| 5705 | W: http://ibm-acpi.sourceforge.net | 4921 | W: http://ibm-acpi.sourceforge.net |
| 5706 | W: http://thinkwiki.org/wiki/Ibm-acpi | 4922 | W: http://thinkwiki.org/wiki/Ibm-acpi |
| @@ -5709,27 +4925,22 @@ S: Maintained | |||
| 5709 | F: drivers/platform/x86/thinkpad_acpi.c | 4925 | F: drivers/platform/x86/thinkpad_acpi.c |
| 5710 | 4926 | ||
| 5711 | TI FLASH MEDIA INTERFACE DRIVER | 4927 | TI FLASH MEDIA INTERFACE DRIVER |
| 5712 | P: Alex Dubov | 4928 | M: Alex Dubov <oakad@yahoo.com> |
| 5713 | M: oakad@yahoo.com | ||
| 5714 | S: Maintained | 4929 | S: Maintained |
| 5715 | F: drivers/misc/tifm* | 4930 | F: drivers/misc/tifm* |
| 5716 | F: drivers/mmc/host/tifm_sd.c | 4931 | F: drivers/mmc/host/tifm_sd.c |
| 5717 | F: include/linux/tifm.h | 4932 | F: include/linux/tifm.h |
| 5718 | 4933 | ||
| 5719 | TI TWL4030 SERIES SOC CODEC DRIVER | 4934 | TI TWL4030 SERIES SOC CODEC DRIVER |
| 5720 | P: Peter Ujfalusi | 4935 | M: Peter Ujfalusi <peter.ujfalusi@nokia.com> |
| 5721 | M: peter.ujfalusi@nokia.com | ||
| 5722 | L: alsa-devel@alsa-project.org (moderated for non-subscribers) | 4936 | L: alsa-devel@alsa-project.org (moderated for non-subscribers) |
| 5723 | S: Maintained | 4937 | S: Maintained |
| 5724 | F: sound/soc/codecs/twl4030* | 4938 | F: sound/soc/codecs/twl4030* |
| 5725 | 4939 | ||
| 5726 | TIPC NETWORK LAYER | 4940 | TIPC NETWORK LAYER |
| 5727 | P: Per Liden | 4941 | M: Per Liden <per.liden@ericsson.com> |
| 5728 | M: per.liden@ericsson.com | 4942 | M: Jon Maloy <jon.maloy@ericsson.com> |
| 5729 | P: Jon Maloy | 4943 | M: Allan Stephens <allan.stephens@windriver.com> |
| 5730 | M: jon.maloy@ericsson.com | ||
| 5731 | P: Allan Stephens | ||
| 5732 | M: allan.stephens@windriver.com | ||
| 5733 | L: tipc-discussion@lists.sourceforge.net | 4944 | L: tipc-discussion@lists.sourceforge.net |
| 5734 | W: http://tipc.sourceforge.net/ | 4945 | W: http://tipc.sourceforge.net/ |
| 5735 | W: http://tipc.cslab.ericsson.net/ | 4946 | W: http://tipc.cslab.ericsson.net/ |
| @@ -5740,8 +4951,7 @@ F: include/net/tipc/ | |||
| 5740 | F: net/tipc/ | 4951 | F: net/tipc/ |
| 5741 | 4952 | ||
| 5742 | TLAN NETWORK DRIVER | 4953 | TLAN NETWORK DRIVER |
| 5743 | P: Samuel Chessman | 4954 | M: Samuel Chessman <chessman@tux.org> |
| 5744 | M: chessman@tux.org | ||
| 5745 | L: tlan-devel@lists.sourceforge.net (subscribers-only) | 4955 | L: tlan-devel@lists.sourceforge.net (subscribers-only) |
| 5746 | W: http://sourceforge.net/projects/tlan/ | 4956 | W: http://sourceforge.net/projects/tlan/ |
| 5747 | S: Maintained | 4957 | S: Maintained |
| @@ -5749,10 +4959,8 @@ F: Documentation/networking/tlan.txt | |||
| 5749 | F: drivers/net/tlan.* | 4959 | F: drivers/net/tlan.* |
| 5750 | 4960 | ||
| 5751 | TOMOYO SECURITY MODULE | 4961 | TOMOYO SECURITY MODULE |
| 5752 | P: Kentaro Takeda | 4962 | M: Kentaro Takeda <takedakn@nttdata.co.jp> |
| 5753 | M: takedakn@nttdata.co.jp | 4963 | M: Tetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp> |
| 5754 | P: Tetsuo Handa | ||
| 5755 | M: penguin-kernel@I-love.SAKURA.ne.jp | ||
| 5756 | L: tomoyo-users-en@lists.sourceforge.jp (subscribers-only, for developers and users in English) | 4964 | L: tomoyo-users-en@lists.sourceforge.jp (subscribers-only, for developers and users in English) |
| 5757 | L: tomoyo-dev@lists.sourceforge.jp (subscribers-only, for developers in Japanese) | 4965 | L: tomoyo-dev@lists.sourceforge.jp (subscribers-only, for developers in Japanese) |
| 5758 | L: tomoyo-users@lists.sourceforge.jp (subscribers-only, for users in Japanese) | 4966 | L: tomoyo-users@lists.sourceforge.jp (subscribers-only, for users in Japanese) |
| @@ -5766,8 +4974,7 @@ S: Orphan | |||
| 5766 | F: drivers/platform/x86/toshiba_acpi.c | 4974 | F: drivers/platform/x86/toshiba_acpi.c |
| 5767 | 4975 | ||
| 5768 | TOSHIBA SMM DRIVER | 4976 | TOSHIBA SMM DRIVER |
| 5769 | P: Jonathan Buzzard | 4977 | M: Jonathan Buzzard <jonathan@buzzard.org.uk> |
| 5770 | M: jonathan@buzzard.org.uk | ||
| 5771 | L: tlinux-users@tce.toshiba-dme.co.jp | 4978 | L: tlinux-users@tce.toshiba-dme.co.jp |
| 5772 | W: http://www.buzzard.org.uk/toshiba/ | 4979 | W: http://www.buzzard.org.uk/toshiba/ |
| 5773 | S: Maintained | 4980 | S: Maintained |
| @@ -5775,43 +4982,36 @@ F: drivers/char/toshiba.c | |||
| 5775 | F: include/linux/toshiba.h | 4982 | F: include/linux/toshiba.h |
| 5776 | 4983 | ||
| 5777 | TMIO MMC DRIVER | 4984 | TMIO MMC DRIVER |
| 5778 | P: Ian Molton | 4985 | M: Ian Molton <ian@mnementh.co.uk> |
| 5779 | M: ian@mnementh.co.uk | ||
| 5780 | S: Maintained | 4986 | S: Maintained |
| 5781 | F: drivers/mmc/host/tmio_mmc.* | 4987 | F: drivers/mmc/host/tmio_mmc.* |
| 5782 | 4988 | ||
| 5783 | TMPFS (SHMEM FILESYSTEM) | 4989 | TMPFS (SHMEM FILESYSTEM) |
| 5784 | P: Hugh Dickins | 4990 | M: Hugh Dickins <hugh.dickins@tiscali.co.uk> |
| 5785 | M: hugh.dickins@tiscali.co.uk | ||
| 5786 | L: linux-mm@kvack.org | 4991 | L: linux-mm@kvack.org |
| 5787 | S: Maintained | 4992 | S: Maintained |
| 5788 | F: include/linux/shmem_fs.h | 4993 | F: include/linux/shmem_fs.h |
| 5789 | F: mm/shmem.c | 4994 | F: mm/shmem.c |
| 5790 | 4995 | ||
| 5791 | TPM DEVICE DRIVER | 4996 | TPM DEVICE DRIVER |
| 5792 | P: Debora Velarde | 4997 | M: Debora Velarde <debora@linux.vnet.ibm.com> |
| 5793 | M: debora@linux.vnet.ibm.com | 4998 | M: Rajiv Andrade <srajiv@linux.vnet.ibm.com> |
| 5794 | P: Rajiv Andrade | ||
| 5795 | M: srajiv@linux.vnet.ibm.com | ||
| 5796 | W: http://tpmdd.sourceforge.net | 4999 | W: http://tpmdd.sourceforge.net |
| 5797 | P: Marcel Selhorst | 5000 | M: Marcel Selhorst <m.selhorst@sirrix.com> |
| 5798 | M: m.selhorst@sirrix.com | ||
| 5799 | W: http://www.sirrix.com | 5001 | W: http://www.sirrix.com |
| 5800 | L: tpmdd-devel@lists.sourceforge.net (moderated for non-subscribers) | 5002 | L: tpmdd-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 5801 | S: Maintained | 5003 | S: Maintained |
| 5802 | F: drivers/char/tpm/ | 5004 | F: drivers/char/tpm/ |
| 5803 | 5005 | ||
| 5804 | TRIVIAL PATCHES | 5006 | TRIVIAL PATCHES |
| 5805 | P: Jiri Kosina | 5007 | M: Jiri Kosina <trivial@kernel.org> |
| 5806 | M: trivial@kernel.org | ||
| 5807 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/trivial.git | 5008 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/trivial.git |
| 5808 | S: Maintained | 5009 | S: Maintained |
| 5809 | 5010 | ||
| 5810 | TTY LAYER | 5011 | TTY LAYER |
| 5811 | P: Alan Cox | 5012 | M: Greg Kroah-Hartman <gregkh@suse.de> |
| 5812 | M: alan@lxorguk.ukuu.org.uk | ||
| 5813 | S: Maintained | 5013 | S: Maintained |
| 5814 | T: stgit http://zeniv.linux.org.uk/~alan/ttydev/ | 5014 | T: quilt kernel.org/pub/linux/kernel/people/gregkh/gregkh-2.6/ |
| 5815 | F: drivers/char/tty_* | 5015 | F: drivers/char/tty_* |
| 5816 | F: drivers/serial/serial_core.c | 5016 | F: drivers/serial/serial_core.c |
| 5817 | F: include/linux/serial_core.h | 5017 | F: include/linux/serial_core.h |
| @@ -5819,17 +5019,14 @@ F: include/linux/serial.h | |||
| 5819 | F: include/linux/tty.h | 5019 | F: include/linux/tty.h |
| 5820 | 5020 | ||
| 5821 | TULIP NETWORK DRIVERS | 5021 | TULIP NETWORK DRIVERS |
| 5822 | P: Grant Grundler | 5022 | M: Grant Grundler <grundler@parisc-linux.org> |
| 5823 | M: grundler@parisc-linux.org | 5023 | M: Kyle McMartin <kyle@mcmartin.ca> |
| 5824 | P: Kyle McMartin | ||
| 5825 | M: kyle@mcmartin.ca | ||
| 5826 | L: netdev@vger.kernel.org | 5024 | L: netdev@vger.kernel.org |
| 5827 | S: Maintained | 5025 | S: Maintained |
| 5828 | F: drivers/net/tulip/ | 5026 | F: drivers/net/tulip/ |
| 5829 | 5027 | ||
| 5830 | TUN/TAP driver | 5028 | TUN/TAP driver |
| 5831 | P: Maxim Krasnyansky | 5029 | M: Maxim Krasnyansky <maxk@qualcomm.com> |
| 5832 | M: maxk@qualcomm.com | ||
| 5833 | L: vtun@office.satix.net | 5030 | L: vtun@office.satix.net |
| 5834 | W: http://vtun.sourceforge.net/tun | 5031 | W: http://vtun.sourceforge.net/tun |
| 5835 | S: Maintained | 5032 | S: Maintained |
| @@ -5837,24 +5034,20 @@ F: Documentation/networking/tuntap.txt | |||
| 5837 | F: arch/um/os-Linux/drivers/ | 5034 | F: arch/um/os-Linux/drivers/ |
| 5838 | 5035 | ||
| 5839 | TURBOCHANNEL SUBSYSTEM | 5036 | TURBOCHANNEL SUBSYSTEM |
| 5840 | P: Maciej W. Rozycki | 5037 | M: "Maciej W. Rozycki" <macro@linux-mips.org> |
| 5841 | M: macro@linux-mips.org | ||
| 5842 | S: Maintained | 5038 | S: Maintained |
| 5843 | F: drivers/tc/ | 5039 | F: drivers/tc/ |
| 5844 | F: include/linux/tc.h | 5040 | F: include/linux/tc.h |
| 5845 | 5041 | ||
| 5846 | U14-34F SCSI DRIVER | 5042 | U14-34F SCSI DRIVER |
| 5847 | P: Dario Ballabio | 5043 | M: Dario Ballabio <ballabio_dario@emc.com> |
| 5848 | M: ballabio_dario@emc.com | ||
| 5849 | L: linux-scsi@vger.kernel.org | 5044 | L: linux-scsi@vger.kernel.org |
| 5850 | S: Maintained | 5045 | S: Maintained |
| 5851 | F: drivers/scsi/u14-34f.c | 5046 | F: drivers/scsi/u14-34f.c |
| 5852 | 5047 | ||
| 5853 | UBI FILE SYSTEM (UBIFS) | 5048 | UBI FILE SYSTEM (UBIFS) |
| 5854 | P: Artem Bityutskiy | 5049 | M: Artem Bityutskiy <dedekind@infradead.org> |
| 5855 | M: dedekind@infradead.org | 5050 | M: Adrian Hunter <adrian.hunter@nokia.com> |
| 5856 | P: Adrian Hunter | ||
| 5857 | M: adrian.hunter@nokia.com | ||
| 5858 | L: linux-mtd@lists.infradead.org | 5051 | L: linux-mtd@lists.infradead.org |
| 5859 | T: git git://git.infradead.org/ubifs-2.6.git | 5052 | T: git git://git.infradead.org/ubifs-2.6.git |
| 5860 | W: http://www.linux-mtd.infradead.org/doc/ubifs.html | 5053 | W: http://www.linux-mtd.infradead.org/doc/ubifs.html |
| @@ -5863,37 +5056,32 @@ F: Documentation/filesystems/ubifs.txt | |||
| 5863 | F: fs/ubifs/ | 5056 | F: fs/ubifs/ |
| 5864 | 5057 | ||
| 5865 | UCLINUX (AND M68KNOMMU) | 5058 | UCLINUX (AND M68KNOMMU) |
| 5866 | P: Greg Ungerer | 5059 | M: Greg Ungerer <gerg@uclinux.org> |
| 5867 | M: gerg@uclinux.org | ||
| 5868 | W: http://www.uclinux.org/ | 5060 | W: http://www.uclinux.org/ |
| 5869 | L: uclinux-dev@uclinux.org (subscribers-only) | 5061 | L: uclinux-dev@uclinux.org (subscribers-only) |
| 5870 | S: Maintained | 5062 | S: Maintained |
| 5871 | F: arch/m68knommu/ | 5063 | F: arch/m68knommu/ |
| 5872 | 5064 | ||
| 5873 | UCLINUX FOR RENESAS H8/300 (H8300) | 5065 | UCLINUX FOR RENESAS H8/300 (H8300) |
| 5874 | P: Yoshinori Sato | 5066 | M: Yoshinori Sato <ysato@users.sourceforge.jp> |
| 5875 | M: ysato@users.sourceforge.jp | ||
| 5876 | W: http://uclinux-h8.sourceforge.jp/ | 5067 | W: http://uclinux-h8.sourceforge.jp/ |
| 5877 | S: Supported | 5068 | S: Supported |
| 5878 | 5069 | ||
| 5879 | UDF FILESYSTEM | 5070 | UDF FILESYSTEM |
| 5880 | P: Jan Kara | 5071 | M: Jan Kara <jack@suse.cz> |
| 5881 | M: jack@suse.cz | ||
| 5882 | W: http://linux-udf.sourceforge.net | 5072 | W: http://linux-udf.sourceforge.net |
| 5883 | S: Maintained | 5073 | S: Maintained |
| 5884 | F: Documentation/filesystems/udf.txt | 5074 | F: Documentation/filesystems/udf.txt |
| 5885 | F: fs/udf/ | 5075 | F: fs/udf/ |
| 5886 | 5076 | ||
| 5887 | UFS FILESYSTEM | 5077 | UFS FILESYSTEM |
| 5888 | P: Evgeniy Dushistov | 5078 | M: Evgeniy Dushistov <dushistov@mail.ru> |
| 5889 | M: dushistov@mail.ru | ||
| 5890 | S: Maintained | 5079 | S: Maintained |
| 5891 | F: Documentation/filesystems/ufs.txt | 5080 | F: Documentation/filesystems/ufs.txt |
| 5892 | F: fs/ufs/ | 5081 | F: fs/ufs/ |
| 5893 | 5082 | ||
| 5894 | ULTRA-WIDEBAND (UWB) SUBSYSTEM: | 5083 | ULTRA-WIDEBAND (UWB) SUBSYSTEM: |
| 5895 | P: David Vrabel | 5084 | M: David Vrabel <david.vrabel@csr.com> |
| 5896 | M: david.vrabel@csr.com | ||
| 5897 | L: linux-usb@vger.kernel.org | 5085 | L: linux-usb@vger.kernel.org |
| 5898 | S: Supported | 5086 | S: Supported |
| 5899 | F: drivers/uwb/* | 5087 | F: drivers/uwb/* |
| @@ -5901,8 +5089,7 @@ F: include/linux/uwb.h | |||
| 5901 | F: include/linux/uwb/ | 5089 | F: include/linux/uwb/ |
| 5902 | 5090 | ||
| 5903 | UNIFORM CDROM DRIVER | 5091 | UNIFORM CDROM DRIVER |
| 5904 | P: Jens Axboe | 5092 | M: Jens Axboe <axboe@kernel.dk> |
| 5905 | M: axboe@kernel.dk | ||
| 5906 | W: http://www.kernel.dk | 5093 | W: http://www.kernel.dk |
| 5907 | S: Maintained | 5094 | S: Maintained |
| 5908 | F: Documentation/cdrom/ | 5095 | F: Documentation/cdrom/ |
| @@ -5910,8 +5097,7 @@ F: drivers/cdrom/cdrom.c | |||
| 5910 | F: include/linux/cdrom.h | 5097 | F: include/linux/cdrom.h |
| 5911 | 5098 | ||
| 5912 | UNSORTED BLOCK IMAGES (UBI) | 5099 | UNSORTED BLOCK IMAGES (UBI) |
| 5913 | P: Artem Bityutskiy | 5100 | M: Artem Bityutskiy <dedekind@infradead.org> |
| 5914 | M: dedekind@infradead.org | ||
| 5915 | W: http://www.linux-mtd.infradead.org/ | 5101 | W: http://www.linux-mtd.infradead.org/ |
| 5916 | L: linux-mtd@lists.infradead.org | 5102 | L: linux-mtd@lists.infradead.org |
| 5917 | T: git git://git.infradead.org/ubi-2.6.git | 5103 | T: git git://git.infradead.org/ubi-2.6.git |
| @@ -5921,23 +5107,20 @@ F: include/linux/mtd/ubi.h | |||
| 5921 | F: include/mtd/ubi-user.h | 5107 | F: include/mtd/ubi-user.h |
| 5922 | 5108 | ||
| 5923 | USB ACM DRIVER | 5109 | USB ACM DRIVER |
| 5924 | P: Oliver Neukum | 5110 | M: Oliver Neukum <oliver@neukum.name> |
| 5925 | M: oliver@neukum.name | ||
| 5926 | L: linux-usb@vger.kernel.org | 5111 | L: linux-usb@vger.kernel.org |
| 5927 | S: Maintained | 5112 | S: Maintained |
| 5928 | F: Documentation/usb/acm.txt | 5113 | F: Documentation/usb/acm.txt |
| 5929 | F: drivers/usb/class/cdc-acm.* | 5114 | F: drivers/usb/class/cdc-acm.* |
| 5930 | 5115 | ||
| 5931 | USB BLOCK DRIVER (UB ub) | 5116 | USB BLOCK DRIVER (UB ub) |
| 5932 | P: Pete Zaitcev | 5117 | M: Pete Zaitcev <zaitcev@redhat.com> |
| 5933 | M: zaitcev@redhat.com | ||
| 5934 | L: linux-usb@vger.kernel.org | 5118 | L: linux-usb@vger.kernel.org |
| 5935 | S: Supported | 5119 | S: Supported |
| 5936 | F: drivers/block/ub.c | 5120 | F: drivers/block/ub.c |
| 5937 | 5121 | ||
| 5938 | USB CDC ETHERNET DRIVER | 5122 | USB CDC ETHERNET DRIVER |
| 5939 | P: Greg Kroah-Hartman | 5123 | M: Greg Kroah-Hartman <greg@kroah.com> |
| 5940 | M: greg@kroah.com | ||
| 5941 | L: linux-usb@vger.kernel.org | 5124 | L: linux-usb@vger.kernel.org |
| 5942 | S: Maintained | 5125 | S: Maintained |
| 5943 | W: http://www.kroah.com/linux-usb/ | 5126 | W: http://www.kroah.com/linux-usb/ |
| @@ -5945,39 +5128,34 @@ F: drivers/net/usb/cdc_*.c | |||
| 5945 | F: include/linux/usb/cdc.h | 5128 | F: include/linux/usb/cdc.h |
| 5946 | 5129 | ||
| 5947 | USB CYPRESS C67X00 DRIVER | 5130 | USB CYPRESS C67X00 DRIVER |
| 5948 | P: Peter Korsgaard | 5131 | M: Peter Korsgaard <jacmet@sunsite.dk> |
| 5949 | M: jacmet@sunsite.dk | ||
| 5950 | L: linux-usb@vger.kernel.org | 5132 | L: linux-usb@vger.kernel.org |
| 5951 | S: Maintained | 5133 | S: Maintained |
| 5952 | F: drivers/usb/c67x00/ | 5134 | F: drivers/usb/c67x00/ |
| 5953 | 5135 | ||
| 5954 | USB DAVICOM DM9601 DRIVER | 5136 | USB DAVICOM DM9601 DRIVER |
| 5955 | P: Peter Korsgaard | 5137 | M: Peter Korsgaard <jacmet@sunsite.dk> |
| 5956 | M: jacmet@sunsite.dk | ||
| 5957 | L: netdev@vger.kernel.org | 5138 | L: netdev@vger.kernel.org |
| 5958 | W: http://www.linux-usb.org/usbnet | 5139 | W: http://www.linux-usb.org/usbnet |
| 5959 | S: Maintained | 5140 | S: Maintained |
| 5960 | F: drivers/net/usb/dm9601.c | 5141 | F: drivers/net/usb/dm9601.c |
| 5961 | 5142 | ||
| 5962 | USB DIAMOND RIO500 DRIVER | 5143 | USB DIAMOND RIO500 DRIVER |
| 5963 | P: Cesar Miquel | 5144 | M: Cesar Miquel <miquel@df.uba.ar> |
| 5964 | M: miquel@df.uba.ar | ||
| 5965 | L: rio500-users@lists.sourceforge.net | 5145 | L: rio500-users@lists.sourceforge.net |
| 5966 | W: http://rio500.sourceforge.net | 5146 | W: http://rio500.sourceforge.net |
| 5967 | S: Maintained | 5147 | S: Maintained |
| 5968 | F: drivers/usb/misc/rio500* | 5148 | F: drivers/usb/misc/rio500* |
| 5969 | 5149 | ||
| 5970 | USB EHCI DRIVER | 5150 | USB EHCI DRIVER |
| 5971 | P: David Brownell | 5151 | M: David Brownell <dbrownell@users.sourceforge.net> |
| 5972 | M: dbrownell@users.sourceforge.net | ||
| 5973 | L: linux-usb@vger.kernel.org | 5152 | L: linux-usb@vger.kernel.org |
| 5974 | S: Odd Fixes | 5153 | S: Odd Fixes |
| 5975 | F: Documentation/usb/ehci.txt | 5154 | F: Documentation/usb/ehci.txt |
| 5976 | F: drivers/usb/host/ehci* | 5155 | F: drivers/usb/host/ehci* |
| 5977 | 5156 | ||
| 5978 | USB ET61X[12]51 DRIVER | 5157 | USB ET61X[12]51 DRIVER |
| 5979 | P: Luca Risolia | 5158 | M: Luca Risolia <luca.risolia@studio.unibo.it> |
| 5980 | M: luca.risolia@studio.unibo.it | ||
| 5981 | L: linux-usb@vger.kernel.org | 5159 | L: linux-usb@vger.kernel.org |
| 5982 | L: linux-media@vger.kernel.org | 5160 | L: linux-media@vger.kernel.org |
| 5983 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 5161 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| @@ -5986,8 +5164,7 @@ S: Maintained | |||
| 5986 | F: drivers/media/video/et61x251/ | 5164 | F: drivers/media/video/et61x251/ |
| 5987 | 5165 | ||
| 5988 | USB GADGET/PERIPHERAL SUBSYSTEM | 5166 | USB GADGET/PERIPHERAL SUBSYSTEM |
| 5989 | P: David Brownell | 5167 | M: David Brownell <dbrownell@users.sourceforge.net> |
| 5990 | M: dbrownell@users.sourceforge.net | ||
| 5991 | L: linux-usb@vger.kernel.org | 5168 | L: linux-usb@vger.kernel.org |
| 5992 | W: http://www.linux-usb.org/gadget | 5169 | W: http://www.linux-usb.org/gadget |
| 5993 | S: Maintained | 5170 | S: Maintained |
| @@ -5995,8 +5172,7 @@ F: drivers/usb/gadget/ | |||
| 5995 | F: include/linux/usb/gadget* | 5172 | F: include/linux/usb/gadget* |
| 5996 | 5173 | ||
| 5997 | USB HID/HIDBP DRIVERS (USB KEYBOARDS, MICE, REMOTE CONTROLS, ...) | 5174 | USB HID/HIDBP DRIVERS (USB KEYBOARDS, MICE, REMOTE CONTROLS, ...) |
| 5998 | P: Jiri Kosina | 5175 | M: Jiri Kosina <jkosina@suse.cz> |
| 5999 | M: jkosina@suse.cz | ||
| 6000 | L: linux-usb@vger.kernel.org | 5176 | L: linux-usb@vger.kernel.org |
| 6001 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/hid.git | 5177 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/hid.git |
| 6002 | S: Maintained | 5178 | S: Maintained |
| @@ -6004,23 +5180,20 @@ F: Documentation/usb/hiddev.txt | |||
| 6004 | F: drivers/hid/usbhid/ | 5180 | F: drivers/hid/usbhid/ |
| 6005 | 5181 | ||
| 6006 | USB ISP116X DRIVER | 5182 | USB ISP116X DRIVER |
| 6007 | P: Olav Kongas | 5183 | M: Olav Kongas <ok@artecdesign.ee> |
| 6008 | M: ok@artecdesign.ee | ||
| 6009 | L: linux-usb@vger.kernel.org | 5184 | L: linux-usb@vger.kernel.org |
| 6010 | S: Maintained | 5185 | S: Maintained |
| 6011 | F: drivers/usb/host/isp116x* | 5186 | F: drivers/usb/host/isp116x* |
| 6012 | F: include/linux/usb/isp116x.h | 5187 | F: include/linux/usb/isp116x.h |
| 6013 | 5188 | ||
| 6014 | USB KAWASAKI LSI DRIVER | 5189 | USB KAWASAKI LSI DRIVER |
| 6015 | P: Oliver Neukum | 5190 | M: Oliver Neukum <oliver@neukum.name> |
| 6016 | M: oliver@neukum.name | ||
| 6017 | L: linux-usb@vger.kernel.org | 5191 | L: linux-usb@vger.kernel.org |
| 6018 | S: Maintained | 5192 | S: Maintained |
| 6019 | F: drivers/usb/serial/kl5kusb105.* | 5193 | F: drivers/usb/serial/kl5kusb105.* |
| 6020 | 5194 | ||
| 6021 | USB MASS STORAGE DRIVER | 5195 | USB MASS STORAGE DRIVER |
| 6022 | P: Matthew Dharm | 5196 | M: Matthew Dharm <mdharm-usb@one-eyed-alien.net> |
| 6023 | M: mdharm-usb@one-eyed-alien.net | ||
| 6024 | L: linux-usb@vger.kernel.org | 5197 | L: linux-usb@vger.kernel.org |
| 6025 | L: usb-storage@lists.one-eyed-alien.net | 5198 | L: usb-storage@lists.one-eyed-alien.net |
| 6026 | S: Maintained | 5199 | S: Maintained |
| @@ -6028,31 +5201,27 @@ W: http://www.one-eyed-alien.net/~mdharm/linux-usb/ | |||
| 6028 | F: drivers/usb/storage/ | 5201 | F: drivers/usb/storage/ |
| 6029 | 5202 | ||
| 6030 | USB OHCI DRIVER | 5203 | USB OHCI DRIVER |
| 6031 | P: David Brownell | 5204 | M: David Brownell <dbrownell@users.sourceforge.net> |
| 6032 | M: dbrownell@users.sourceforge.net | ||
| 6033 | L: linux-usb@vger.kernel.org | 5205 | L: linux-usb@vger.kernel.org |
| 6034 | S: Odd Fixes | 5206 | S: Odd Fixes |
| 6035 | F: Documentation/usb/ohci.txt | 5207 | F: Documentation/usb/ohci.txt |
| 6036 | F: drivers/usb/host/ohci* | 5208 | F: drivers/usb/host/ohci* |
| 6037 | 5209 | ||
| 6038 | USB OPTION-CARD DRIVER | 5210 | USB OPTION-CARD DRIVER |
| 6039 | P: Matthias Urlichs | 5211 | M: Matthias Urlichs <smurf@smurf.noris.de> |
| 6040 | M: smurf@smurf.noris.de | ||
| 6041 | L: linux-usb@vger.kernel.org | 5212 | L: linux-usb@vger.kernel.org |
| 6042 | S: Maintained | 5213 | S: Maintained |
| 6043 | F: drivers/usb/serial/option.c | 5214 | F: drivers/usb/serial/option.c |
| 6044 | 5215 | ||
| 6045 | USB OV511 DRIVER | 5216 | USB OV511 DRIVER |
| 6046 | P: Mark McClelland | 5217 | M: Mark McClelland <mmcclell@bigfoot.com> |
| 6047 | M: mmcclell@bigfoot.com | ||
| 6048 | L: linux-usb@vger.kernel.org | 5218 | L: linux-usb@vger.kernel.org |
| 6049 | W: http://alpha.dyndns.org/ov511/ | 5219 | W: http://alpha.dyndns.org/ov511/ |
| 6050 | S: Maintained | 5220 | S: Maintained |
| 6051 | F: drivers/media/video/ov511.* | 5221 | F: drivers/media/video/ov511.* |
| 6052 | 5222 | ||
| 6053 | USB PEGASUS DRIVER | 5223 | USB PEGASUS DRIVER |
| 6054 | P: Petko Manolov | 5224 | M: Petko Manolov <petkan@users.sourceforge.net> |
| 6055 | M: petkan@users.sourceforge.net | ||
| 6056 | L: linux-usb@vger.kernel.org | 5225 | L: linux-usb@vger.kernel.org |
| 6057 | L: netdev@vger.kernel.org | 5226 | L: netdev@vger.kernel.org |
| 6058 | W: http://pegasus2.sourceforge.net/ | 5227 | W: http://pegasus2.sourceforge.net/ |
| @@ -6060,15 +5229,13 @@ S: Maintained | |||
| 6060 | F: drivers/net/usb/pegasus.* | 5229 | F: drivers/net/usb/pegasus.* |
| 6061 | 5230 | ||
| 6062 | USB PRINTER DRIVER (usblp) | 5231 | USB PRINTER DRIVER (usblp) |
| 6063 | P: Pete Zaitcev | 5232 | M: Pete Zaitcev <zaitcev@redhat.com> |
| 6064 | M: zaitcev@redhat.com | ||
| 6065 | L: linux-usb@vger.kernel.org | 5233 | L: linux-usb@vger.kernel.org |
| 6066 | S: Supported | 5234 | S: Supported |
| 6067 | F: drivers/usb/class/usblp.c | 5235 | F: drivers/usb/class/usblp.c |
| 6068 | 5236 | ||
| 6069 | USB RTL8150 DRIVER | 5237 | USB RTL8150 DRIVER |
| 6070 | P: Petko Manolov | 5238 | M: Petko Manolov <petkan@users.sourceforge.net> |
| 6071 | M: petkan@users.sourceforge.net | ||
| 6072 | L: linux-usb@vger.kernel.org | 5239 | L: linux-usb@vger.kernel.org |
| 6073 | L: netdev@vger.kernel.org | 5240 | L: netdev@vger.kernel.org |
| 6074 | W: http://pegasus2.sourceforge.net/ | 5241 | W: http://pegasus2.sourceforge.net/ |
| @@ -6076,8 +5243,7 @@ S: Maintained | |||
| 6076 | F: drivers/net/usb/rtl8150.c | 5243 | F: drivers/net/usb/rtl8150.c |
| 6077 | 5244 | ||
| 6078 | USB SE401 DRIVER | 5245 | USB SE401 DRIVER |
| 6079 | P: Jeroen Vreeken | 5246 | M: Jeroen Vreeken <pe1rxq@amsat.org> |
| 6080 | M: pe1rxq@amsat.org | ||
| 6081 | L: linux-usb@vger.kernel.org | 5247 | L: linux-usb@vger.kernel.org |
| 6082 | W: http://www.chello.nl/~j.vreeken/se401/ | 5248 | W: http://www.chello.nl/~j.vreeken/se401/ |
| 6083 | S: Maintained | 5249 | S: Maintained |
| @@ -6085,15 +5251,13 @@ F: Documentation/video4linux/se401.txt | |||
| 6085 | F: drivers/media/video/se401.* | 5251 | F: drivers/media/video/se401.* |
| 6086 | 5252 | ||
| 6087 | USB SERIAL BELKIN F5U103 DRIVER | 5253 | USB SERIAL BELKIN F5U103 DRIVER |
| 6088 | P: William Greathouse | 5254 | M: William Greathouse <wgreathouse@smva.com> |
| 6089 | M: wgreathouse@smva.com | ||
| 6090 | L: linux-usb@vger.kernel.org | 5255 | L: linux-usb@vger.kernel.org |
| 6091 | S: Maintained | 5256 | S: Maintained |
| 6092 | F: drivers/usb/serial/belkin_sa.* | 5257 | F: drivers/usb/serial/belkin_sa.* |
| 6093 | 5258 | ||
| 6094 | USB SERIAL CYPRESS M8 DRIVER | 5259 | USB SERIAL CYPRESS M8 DRIVER |
| 6095 | P: Lonnie Mendez | 5260 | M: Lonnie Mendez <dignome@gmail.com> |
| 6096 | M: dignome@gmail.com | ||
| 6097 | L: linux-usb@vger.kernel.org | 5261 | L: linux-usb@vger.kernel.org |
| 6098 | S: Maintained | 5262 | S: Maintained |
| 6099 | W: http://geocities.com/i0xox0i | 5263 | W: http://geocities.com/i0xox0i |
| @@ -6101,23 +5265,20 @@ W: http://firstlight.net/cvs | |||
| 6101 | F: drivers/usb/serial/cypress_m8.* | 5265 | F: drivers/usb/serial/cypress_m8.* |
| 6102 | 5266 | ||
| 6103 | USB SERIAL CYBERJACK DRIVER | 5267 | USB SERIAL CYBERJACK DRIVER |
| 6104 | P: Matthias Bruestle and Harald Welte | 5268 | M: Matthias Bruestle and Harald Welte <support@reiner-sct.com> |
| 6105 | M: support@reiner-sct.com | ||
| 6106 | W: http://www.reiner-sct.de/support/treiber_cyberjack.php | 5269 | W: http://www.reiner-sct.de/support/treiber_cyberjack.php |
| 6107 | S: Maintained | 5270 | S: Maintained |
| 6108 | F: drivers/usb/serial/cyberjack.c | 5271 | F: drivers/usb/serial/cyberjack.c |
| 6109 | 5272 | ||
| 6110 | USB SERIAL DIGI ACCELEPORT DRIVER | 5273 | USB SERIAL DIGI ACCELEPORT DRIVER |
| 6111 | P: Peter Berger and Al Borchers | 5274 | M: Peter Berger <pberger@brimson.com> |
| 6112 | M: pberger@brimson.com | 5275 | M: Al Borchers <alborchers@steinerpoint.com> |
| 6113 | M: alborchers@steinerpoint.com | ||
| 6114 | L: linux-usb@vger.kernel.org | 5276 | L: linux-usb@vger.kernel.org |
| 6115 | S: Maintained | 5277 | S: Maintained |
| 6116 | F: drivers/usb/serial/digi_acceleport.c | 5278 | F: drivers/usb/serial/digi_acceleport.c |
| 6117 | 5279 | ||
| 6118 | USB SERIAL DRIVER | 5280 | USB SERIAL DRIVER |
| 6119 | P: Greg Kroah-Hartman | 5281 | M: Greg Kroah-Hartman <gregkh@suse.de> |
| 6120 | M: gregkh@suse.de | ||
| 6121 | L: linux-usb@vger.kernel.org | 5282 | L: linux-usb@vger.kernel.org |
| 6122 | S: Supported | 5283 | S: Supported |
| 6123 | F: Documentation/usb/usb-serial.txt | 5284 | F: Documentation/usb/usb-serial.txt |
| @@ -6126,38 +5287,33 @@ F: drivers/usb/serial/usb-serial.c | |||
| 6126 | F: include/linux/usb/serial.h | 5287 | F: include/linux/usb/serial.h |
| 6127 | 5288 | ||
| 6128 | USB SERIAL EMPEG EMPEG-CAR MARK I/II DRIVER | 5289 | USB SERIAL EMPEG EMPEG-CAR MARK I/II DRIVER |
| 6129 | P: Gary Brubaker | 5290 | M: Gary Brubaker <xavyer@ix.netcom.com> |
| 6130 | M: xavyer@ix.netcom.com | ||
| 6131 | L: linux-usb@vger.kernel.org | 5291 | L: linux-usb@vger.kernel.org |
| 6132 | S: Maintained | 5292 | S: Maintained |
| 6133 | F: drivers/usb/serial/empeg.c | 5293 | F: drivers/usb/serial/empeg.c |
| 6134 | 5294 | ||
| 6135 | USB SERIAL KEYSPAN DRIVER | 5295 | USB SERIAL KEYSPAN DRIVER |
| 6136 | P: Greg Kroah-Hartman | 5296 | M: Greg Kroah-Hartman <greg@kroah.com> |
| 6137 | M: greg@kroah.com | ||
| 6138 | L: linux-usb@vger.kernel.org | 5297 | L: linux-usb@vger.kernel.org |
| 6139 | W: http://www.kroah.com/linux/ | 5298 | W: http://www.kroah.com/linux/ |
| 6140 | S: Maintained | 5299 | S: Maintained |
| 6141 | F: drivers/usb/serial/*keyspan* | 5300 | F: drivers/usb/serial/*keyspan* |
| 6142 | 5301 | ||
| 6143 | USB SERIAL WHITEHEAT DRIVER | 5302 | USB SERIAL WHITEHEAT DRIVER |
| 6144 | P: Support Department | 5303 | M: Support Department <support@connecttech.com> |
| 6145 | M: support@connecttech.com | ||
| 6146 | L: linux-usb@vger.kernel.org | 5304 | L: linux-usb@vger.kernel.org |
| 6147 | W: http://www.connecttech.com | 5305 | W: http://www.connecttech.com |
| 6148 | S: Supported | 5306 | S: Supported |
| 6149 | F: drivers/usb/serial/whiteheat* | 5307 | F: drivers/usb/serial/whiteheat* |
| 6150 | 5308 | ||
| 6151 | USB SMSC95XX ETHERNET DRIVER | 5309 | USB SMSC95XX ETHERNET DRIVER |
| 6152 | P: Steve Glendinning | 5310 | M: Steve Glendinning <steve.glendinning@smsc.com> |
| 6153 | M: steve.glendinning@smsc.com | ||
| 6154 | L: netdev@vger.kernel.org | 5311 | L: netdev@vger.kernel.org |
| 6155 | S: Supported | 5312 | S: Supported |
| 6156 | F: drivers/net/usb/smsc95xx.* | 5313 | F: drivers/net/usb/smsc95xx.* |
| 6157 | 5314 | ||
| 6158 | USB SN9C1xx DRIVER | 5315 | USB SN9C1xx DRIVER |
| 6159 | P: Luca Risolia | 5316 | M: Luca Risolia <luca.risolia@studio.unibo.it> |
| 6160 | M: luca.risolia@studio.unibo.it | ||
| 6161 | L: linux-usb@vger.kernel.org | 5317 | L: linux-usb@vger.kernel.org |
| 6162 | L: linux-media@vger.kernel.org | 5318 | L: linux-media@vger.kernel.org |
| 6163 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 5319 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| @@ -6167,8 +5323,7 @@ F: Documentation/video4linux/sn9c102.txt | |||
| 6167 | F: drivers/media/video/sn9c102/ | 5323 | F: drivers/media/video/sn9c102/ |
| 6168 | 5324 | ||
| 6169 | USB SUBSYSTEM | 5325 | USB SUBSYSTEM |
| 6170 | P: Greg Kroah-Hartman | 5326 | M: Greg Kroah-Hartman <gregkh@suse.de> |
| 6171 | M: gregkh@suse.de | ||
| 6172 | L: linux-usb@vger.kernel.org | 5327 | L: linux-usb@vger.kernel.org |
| 6173 | W: http://www.linux-usb.org | 5328 | W: http://www.linux-usb.org |
| 6174 | T: quilt kernel.org/pub/linux/kernel/people/gregkh/gregkh-2.6/ | 5329 | T: quilt kernel.org/pub/linux/kernel/people/gregkh/gregkh-2.6/ |
| @@ -6180,15 +5335,13 @@ F: include/linux/usb.h | |||
| 6180 | F: include/linux/usb/ | 5335 | F: include/linux/usb/ |
| 6181 | 5336 | ||
| 6182 | USB UHCI DRIVER | 5337 | USB UHCI DRIVER |
| 6183 | P: Alan Stern | 5338 | M: Alan Stern <stern@rowland.harvard.edu> |
| 6184 | M: stern@rowland.harvard.edu | ||
| 6185 | L: linux-usb@vger.kernel.org | 5339 | L: linux-usb@vger.kernel.org |
| 6186 | S: Maintained | 5340 | S: Maintained |
| 6187 | F: drivers/usb/host/uhci* | 5341 | F: drivers/usb/host/uhci* |
| 6188 | 5342 | ||
| 6189 | USB "USBNET" DRIVER FRAMEWORK | 5343 | USB "USBNET" DRIVER FRAMEWORK |
| 6190 | P: David Brownell | 5344 | M: David Brownell <dbrownell@users.sourceforge.net> |
| 6191 | M: dbrownell@users.sourceforge.net | ||
| 6192 | L: netdev@vger.kernel.org | 5345 | L: netdev@vger.kernel.org |
| 6193 | W: http://www.linux-usb.org/usbnet | 5346 | W: http://www.linux-usb.org/usbnet |
| 6194 | S: Maintained | 5347 | S: Maintained |
| @@ -6196,8 +5349,7 @@ F: drivers/net/usb/usbnet.c | |||
| 6196 | F: include/linux/usb/usbnet.h | 5349 | F: include/linux/usb/usbnet.h |
| 6197 | 5350 | ||
| 6198 | USB VIDEO CLASS | 5351 | USB VIDEO CLASS |
| 6199 | P: Laurent Pinchart | 5352 | M: Laurent Pinchart <laurent.pinchart@skynet.be> |
| 6200 | M: laurent.pinchart@skynet.be | ||
| 6201 | L: linux-uvc-devel@lists.berlios.de (subscribers-only) | 5353 | L: linux-uvc-devel@lists.berlios.de (subscribers-only) |
| 6202 | L: linux-media@vger.kernel.org | 5354 | L: linux-media@vger.kernel.org |
| 6203 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 5355 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| @@ -6206,8 +5358,7 @@ S: Maintained | |||
| 6206 | F: drivers/media/video/uvc/ | 5358 | F: drivers/media/video/uvc/ |
| 6207 | 5359 | ||
| 6208 | USB W996[87]CF DRIVER | 5360 | USB W996[87]CF DRIVER |
| 6209 | P: Luca Risolia | 5361 | M: Luca Risolia <luca.risolia@studio.unibo.it> |
| 6210 | M: luca.risolia@studio.unibo.it | ||
| 6211 | L: linux-usb@vger.kernel.org | 5362 | L: linux-usb@vger.kernel.org |
| 6212 | L: linux-media@vger.kernel.org | 5363 | L: linux-media@vger.kernel.org |
| 6213 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 5364 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| @@ -6217,21 +5368,18 @@ F: Documentation/video4linux/w9968cf.txt | |||
| 6217 | F: drivers/media/video/w996* | 5368 | F: drivers/media/video/w996* |
| 6218 | 5369 | ||
| 6219 | USB WIRELESS RNDIS DRIVER (rndis_wlan) | 5370 | USB WIRELESS RNDIS DRIVER (rndis_wlan) |
| 6220 | P: Jussi Kivilinna | 5371 | M: Jussi Kivilinna <jussi.kivilinna@mbnet.fi> |
| 6221 | M: jussi.kivilinna@mbnet.fi | ||
| 6222 | L: linux-wireless@vger.kernel.org | 5372 | L: linux-wireless@vger.kernel.org |
| 6223 | S: Maintained | 5373 | S: Maintained |
| 6224 | F: drivers/net/wireless/rndis_wlan.c | 5374 | F: drivers/net/wireless/rndis_wlan.c |
| 6225 | 5375 | ||
| 6226 | USB XHCI DRIVER | 5376 | USB XHCI DRIVER |
| 6227 | P: Sarah Sharp | 5377 | M: Sarah Sharp <sarah.a.sharp@intel.com> |
| 6228 | M: sarah.a.sharp@intel.com | ||
| 6229 | L: linux-usb@vger.kernel.org | 5378 | L: linux-usb@vger.kernel.org |
| 6230 | S: Supported | 5379 | S: Supported |
| 6231 | 5380 | ||
| 6232 | USB ZC0301 DRIVER | 5381 | USB ZC0301 DRIVER |
| 6233 | P: Luca Risolia | 5382 | M: Luca Risolia <luca.risolia@studio.unibo.it> |
| 6234 | M: luca.risolia@studio.unibo.it | ||
| 6235 | L: linux-usb@vger.kernel.org | 5383 | L: linux-usb@vger.kernel.org |
| 6236 | L: linux-media@vger.kernel.org | 5384 | L: linux-media@vger.kernel.org |
| 6237 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 5385 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| @@ -6241,16 +5389,14 @@ F: Documentation/video4linux/zc0301.txt | |||
| 6241 | F: drivers/media/video/zc0301/ | 5389 | F: drivers/media/video/zc0301/ |
| 6242 | 5390 | ||
| 6243 | USB ZD1201 DRIVER | 5391 | USB ZD1201 DRIVER |
| 6244 | P: Jeroen Vreeken | 5392 | M: Jeroen Vreeken <pe1rxq@amsat.org> |
| 6245 | M: pe1rxq@amsat.org | ||
| 6246 | L: linux-usb@vger.kernel.org | 5393 | L: linux-usb@vger.kernel.org |
| 6247 | W: http://linux-lc100020.sourceforge.net | 5394 | W: http://linux-lc100020.sourceforge.net |
| 6248 | S: Maintained | 5395 | S: Maintained |
| 6249 | F: drivers/net/wireless/zd1201.* | 5396 | F: drivers/net/wireless/zd1201.* |
| 6250 | 5397 | ||
| 6251 | USB ZR364XX DRIVER | 5398 | USB ZR364XX DRIVER |
| 6252 | P: Antoine Jacquet | 5399 | M: Antoine Jacquet <royale@zerezo.com> |
| 6253 | M: royale@zerezo.com | ||
| 6254 | L: linux-usb@vger.kernel.org | 5400 | L: linux-usb@vger.kernel.org |
| 6255 | L: linux-media@vger.kernel.org | 5401 | L: linux-media@vger.kernel.org |
| 6256 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git | 5402 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git |
| @@ -6260,8 +5406,7 @@ F: Documentation/video4linux/zr364xx.txt | |||
| 6260 | F: drivers/media/video/zr364xx.c | 5406 | F: drivers/media/video/zr364xx.c |
| 6261 | 5407 | ||
| 6262 | USER-MODE LINUX (UML) | 5408 | USER-MODE LINUX (UML) |
| 6263 | P: Jeff Dike | 5409 | M: Jeff Dike <jdike@addtoit.com> |
| 6264 | M: jdike@addtoit.com | ||
| 6265 | L: user-mode-linux-devel@lists.sourceforge.net | 5410 | L: user-mode-linux-devel@lists.sourceforge.net |
| 6266 | L: user-mode-linux-user@lists.sourceforge.net | 5411 | L: user-mode-linux-user@lists.sourceforge.net |
| 6267 | W: http://user-mode-linux.sourceforge.net | 5412 | W: http://user-mode-linux.sourceforge.net |
| @@ -6272,26 +5417,22 @@ F: fs/hostfs/ | |||
| 6272 | F: fs/hppfs/ | 5417 | F: fs/hppfs/ |
| 6273 | 5418 | ||
| 6274 | USERSPACE I/O (UIO) | 5419 | USERSPACE I/O (UIO) |
| 6275 | P: Hans J. Koch | 5420 | M: "Hans J. Koch" <hjk@linutronix.de> |
| 6276 | M: hjk@linutronix.de | 5421 | M: Greg Kroah-Hartman <gregkh@suse.de> |
| 6277 | P: Greg Kroah-Hartman | ||
| 6278 | M: gregkh@suse.de | ||
| 6279 | S: Maintained | 5422 | S: Maintained |
| 6280 | F: Documentation/DocBook/uio-howto.tmpl | 5423 | F: Documentation/DocBook/uio-howto.tmpl |
| 6281 | F: drivers/uio/ | 5424 | F: drivers/uio/ |
| 6282 | F: include/linux/uio*.h | 5425 | F: include/linux/uio*.h |
| 6283 | 5426 | ||
| 6284 | UTIL-LINUX-NG PACKAGE | 5427 | UTIL-LINUX-NG PACKAGE |
| 6285 | P: Karel Zak | 5428 | M: Karel Zak <kzak@redhat.com> |
| 6286 | M: kzak@redhat.com | ||
| 6287 | L: util-linux-ng@vger.kernel.org | 5429 | L: util-linux-ng@vger.kernel.org |
| 6288 | W: http://kernel.org/~kzak/util-linux-ng/ | 5430 | W: http://kernel.org/~kzak/util-linux-ng/ |
| 6289 | T: git git://git.kernel.org/pub/scm/utils/util-linux-ng/util-linux-ng.git | 5431 | T: git git://git.kernel.org/pub/scm/utils/util-linux-ng/util-linux-ng.git |
| 6290 | S: Maintained | 5432 | S: Maintained |
| 6291 | 5433 | ||
| 6292 | UVESAFB DRIVER | 5434 | UVESAFB DRIVER |
| 6293 | P: Michal Januszewski | 5435 | M: Michal Januszewski <spock@gentoo.org> |
| 6294 | M: spock@gentoo.org | ||
| 6295 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) | 5436 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 6296 | W: http://dev.gentoo.org/~spock/projects/uvesafb/ | 5437 | W: http://dev.gentoo.org/~spock/projects/uvesafb/ |
| 6297 | S: Maintained | 5438 | S: Maintained |
| @@ -6299,53 +5440,44 @@ F: Documentation/fb/uvesafb.txt | |||
| 6299 | F: drivers/video/uvesafb.* | 5440 | F: drivers/video/uvesafb.* |
| 6300 | 5441 | ||
| 6301 | VFAT/FAT/MSDOS FILESYSTEM | 5442 | VFAT/FAT/MSDOS FILESYSTEM |
| 6302 | P: OGAWA Hirofumi | 5443 | M: OGAWA Hirofumi <hirofumi@mail.parknet.co.jp> |
| 6303 | M: hirofumi@mail.parknet.co.jp | ||
| 6304 | S: Maintained | 5444 | S: Maintained |
| 6305 | F: Documentation/filesystems/vfat.txt | 5445 | F: Documentation/filesystems/vfat.txt |
| 6306 | F: fs/fat/ | 5446 | F: fs/fat/ |
| 6307 | 5447 | ||
| 6308 | VIA RHINE NETWORK DRIVER | 5448 | VIA RHINE NETWORK DRIVER |
| 6309 | P: Roger Luethi | 5449 | M: Roger Luethi <rl@hellgate.ch> |
| 6310 | M: rl@hellgate.ch | ||
| 6311 | S: Maintained | 5450 | S: Maintained |
| 6312 | F: drivers/net/via-rhine.c | 5451 | F: drivers/net/via-rhine.c |
| 6313 | 5452 | ||
| 6314 | VIAPRO SMBUS DRIVER | 5453 | VIAPRO SMBUS DRIVER |
| 6315 | P: Jean Delvare | 5454 | M: Jean Delvare <khali@linux-fr.org> |
| 6316 | M: khali@linux-fr.org | ||
| 6317 | L: linux-i2c@vger.kernel.org | 5455 | L: linux-i2c@vger.kernel.org |
| 6318 | S: Maintained | 5456 | S: Maintained |
| 6319 | F: Documentation/i2c/busses/i2c-viapro | 5457 | F: Documentation/i2c/busses/i2c-viapro |
| 6320 | F: drivers/i2c/busses/i2c-viapro.c | 5458 | F: drivers/i2c/busses/i2c-viapro.c |
| 6321 | 5459 | ||
| 6322 | VIA SD/MMC CARD CONTROLLER DRIVER | 5460 | VIA SD/MMC CARD CONTROLLER DRIVER |
| 6323 | P: Joseph Chan | 5461 | M: Joseph Chan <JosephChan@via.com.tw> |
| 6324 | M: JosephChan@via.com.tw | 5462 | M: Harald Welte <HaraldWelte@viatech.com> |
| 6325 | P: Harald Welte | ||
| 6326 | M: HaraldWelte@viatech.com | ||
| 6327 | S: Maintained | 5463 | S: Maintained |
| 6328 | F: drivers/mmc/host/via-sdmmc.c | 5464 | F: drivers/mmc/host/via-sdmmc.c |
| 6329 | 5465 | ||
| 6330 | VIA UNICHROME(PRO)/CHROME9 FRAMEBUFFER DRIVER | 5466 | VIA UNICHROME(PRO)/CHROME9 FRAMEBUFFER DRIVER |
| 6331 | P: Joseph Chan | 5467 | M: Joseph Chan <JosephChan@via.com.tw> |
| 6332 | M: JosephChan@via.com.tw | 5468 | M: Scott Fang <ScottFang@viatech.com.cn> |
| 6333 | P: Scott Fang | ||
| 6334 | M: ScottFang@viatech.com.cn | ||
| 6335 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) | 5469 | L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) |
| 6336 | S: Maintained | 5470 | S: Maintained |
| 6337 | F: drivers/video/via/ | 5471 | F: drivers/video/via/ |
| 6338 | 5472 | ||
| 6339 | VIA VELOCITY NETWORK DRIVER | 5473 | VIA VELOCITY NETWORK DRIVER |
| 6340 | P: Francois Romieu | 5474 | M: Francois Romieu <romieu@fr.zoreil.com> |
| 6341 | M: romieu@fr.zoreil.com | ||
| 6342 | L: netdev@vger.kernel.org | 5475 | L: netdev@vger.kernel.org |
| 6343 | S: Maintained | 5476 | S: Maintained |
| 6344 | F: drivers/net/via-velocity.* | 5477 | F: drivers/net/via-velocity.* |
| 6345 | 5478 | ||
| 6346 | VLAN (802.1Q) | 5479 | VLAN (802.1Q) |
| 6347 | P: Patrick McHardy | 5480 | M: Patrick McHardy <kaber@trash.net> |
| 6348 | M: kaber@trash.net | ||
| 6349 | L: netdev@vger.kernel.org | 5481 | L: netdev@vger.kernel.org |
| 6350 | S: Maintained | 5482 | S: Maintained |
| 6351 | F: drivers/net/macvlan.c | 5483 | F: drivers/net/macvlan.c |
| @@ -6353,18 +5485,15 @@ F: include/linux/if_*vlan.h | |||
| 6353 | F: net/8021q/ | 5485 | F: net/8021q/ |
| 6354 | 5486 | ||
| 6355 | VLYNQ BUS | 5487 | VLYNQ BUS |
| 6356 | P: Florian Fainelli | 5488 | M: Florian Fainelli <florian@openwrt.org> |
| 6357 | M: florian@openwrt.org | ||
| 6358 | L: openwrt-devel@lists.openwrt.org | 5489 | L: openwrt-devel@lists.openwrt.org |
| 6359 | S: Maintained | 5490 | S: Maintained |
| 6360 | F: drivers/vlynq/vlynq.c | 5491 | F: drivers/vlynq/vlynq.c |
| 6361 | F: include/linux/vlynq.h | 5492 | F: include/linux/vlynq.h |
| 6362 | 5493 | ||
| 6363 | VOLTAGE AND CURRENT REGULATOR FRAMEWORK | 5494 | VOLTAGE AND CURRENT REGULATOR FRAMEWORK |
| 6364 | P: Liam Girdwood | 5495 | M: Liam Girdwood <lrg@slimlogic.co.uk> |
| 6365 | M: lrg@slimlogic.co.uk | 5496 | M: Mark Brown <broonie@opensource.wolfsonmicro.com> |
| 6366 | P: Mark Brown | ||
| 6367 | M: broonie@opensource.wolfsonmicro.com | ||
| 6368 | W: http://opensource.wolfsonmicro.com/node/15 | 5497 | W: http://opensource.wolfsonmicro.com/node/15 |
| 6369 | W: http://www.slimlogic.co.uk/?p=48 | 5498 | W: http://www.slimlogic.co.uk/?p=48 |
| 6370 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/lrg/voltage-2.6.git | 5499 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/lrg/voltage-2.6.git |
| @@ -6373,52 +5502,45 @@ F: drivers/regulator/ | |||
| 6373 | F: include/linux/regulator/ | 5502 | F: include/linux/regulator/ |
| 6374 | 5503 | ||
| 6375 | VT1211 HARDWARE MONITOR DRIVER | 5504 | VT1211 HARDWARE MONITOR DRIVER |
| 6376 | P: Juerg Haefliger | 5505 | M: Juerg Haefliger <juergh@gmail.com> |
| 6377 | M: juergh@gmail.com | ||
| 6378 | L: lm-sensors@lm-sensors.org | 5506 | L: lm-sensors@lm-sensors.org |
| 6379 | S: Maintained | 5507 | S: Maintained |
| 6380 | F: Documentation/hwmon/vt1211 | 5508 | F: Documentation/hwmon/vt1211 |
| 6381 | F: drivers/hwmon/vt1211.c | 5509 | F: drivers/hwmon/vt1211.c |
| 6382 | 5510 | ||
| 6383 | VT8231 HARDWARE MONITOR DRIVER | 5511 | VT8231 HARDWARE MONITOR DRIVER |
| 6384 | P: Roger Lucas | 5512 | M: Roger Lucas <vt8231@hiddenengine.co.uk> |
| 6385 | M: vt8231@hiddenengine.co.uk | ||
| 6386 | L: lm-sensors@lm-sensors.org | 5513 | L: lm-sensors@lm-sensors.org |
| 6387 | S: Maintained | 5514 | S: Maintained |
| 6388 | F: drivers/hwmon/vt8231.c | 5515 | F: drivers/hwmon/vt8231.c |
| 6389 | 5516 | ||
| 6390 | W1 DALLAS'S 1-WIRE BUS | 5517 | W1 DALLAS'S 1-WIRE BUS |
| 6391 | P: Evgeniy Polyakov | 5518 | M: Evgeniy Polyakov <johnpol@2ka.mipt.ru> |
| 6392 | M: johnpol@2ka.mipt.ru | ||
| 6393 | S: Maintained | 5519 | S: Maintained |
| 6394 | F: Documentation/w1/ | 5520 | F: Documentation/w1/ |
| 6395 | F: drivers/w1/ | 5521 | F: drivers/w1/ |
| 6396 | 5522 | ||
| 6397 | W83791D HARDWARE MONITORING DRIVER | 5523 | W83791D HARDWARE MONITORING DRIVER |
| 6398 | P: Marc Hulsman | 5524 | M: Marc Hulsman <m.hulsman@tudelft.nl> |
| 6399 | M: m.hulsman@tudelft.nl | ||
| 6400 | L: lm-sensors@lm-sensors.org | 5525 | L: lm-sensors@lm-sensors.org |
| 6401 | S: Maintained | 5526 | S: Maintained |
| 6402 | F: Documentation/hwmon/w83791d | 5527 | F: Documentation/hwmon/w83791d |
| 6403 | F: drivers/hwmon/w83791d.c | 5528 | F: drivers/hwmon/w83791d.c |
| 6404 | 5529 | ||
| 6405 | W83793 HARDWARE MONITORING DRIVER | 5530 | W83793 HARDWARE MONITORING DRIVER |
| 6406 | P: Rudolf Marek | 5531 | M: Rudolf Marek <r.marek@assembler.cz> |
| 6407 | M: r.marek@assembler.cz | ||
| 6408 | L: lm-sensors@lm-sensors.org | 5532 | L: lm-sensors@lm-sensors.org |
| 6409 | S: Maintained | 5533 | S: Maintained |
| 6410 | F: Documentation/hwmon/w83793 | 5534 | F: Documentation/hwmon/w83793 |
| 6411 | F: drivers/hwmon/w83793.c | 5535 | F: drivers/hwmon/w83793.c |
| 6412 | 5536 | ||
| 6413 | W83L51xD SD/MMC CARD INTERFACE DRIVER | 5537 | W83L51xD SD/MMC CARD INTERFACE DRIVER |
| 6414 | P: Pierre Ossman | 5538 | M: Pierre Ossman <pierre@ossman.eu> |
| 6415 | M: pierre@ossman.eu | ||
| 6416 | S: Maintained | 5539 | S: Maintained |
| 6417 | F: drivers/mmc/host/wbsd.* | 5540 | F: drivers/mmc/host/wbsd.* |
| 6418 | 5541 | ||
| 6419 | WATCHDOG DEVICE DRIVERS | 5542 | WATCHDOG DEVICE DRIVERS |
| 6420 | P: Wim Van Sebroeck | 5543 | M: Wim Van Sebroeck <wim@iguana.be> |
| 6421 | M: wim@iguana.be | ||
| 6422 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/wim/linux-2.6-watchdog.git | 5544 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/wim/linux-2.6-watchdog.git |
| 6423 | S: Maintained | 5545 | S: Maintained |
| 6424 | F: Documentation/watchdog/ | 5546 | F: Documentation/watchdog/ |
| @@ -6426,8 +5548,7 @@ F: drivers/watchdog/ | |||
| 6426 | F: include/linux/watchdog.h | 5548 | F: include/linux/watchdog.h |
| 6427 | 5549 | ||
| 6428 | WAVELAN NETWORK DRIVER & WIRELESS EXTENSIONS | 5550 | WAVELAN NETWORK DRIVER & WIRELESS EXTENSIONS |
| 6429 | P: Jean Tourrilhes | 5551 | M: Jean Tourrilhes <jt@hpl.hp.com> |
| 6430 | M: jt@hpl.hp.com | ||
| 6431 | L: linux-wireless@vger.kernel.org | 5552 | L: linux-wireless@vger.kernel.org |
| 6432 | W: http://www.hpl.hp.com/personal/Jean_Tourrilhes/Linux/ | 5553 | W: http://www.hpl.hp.com/personal/Jean_Tourrilhes/Linux/ |
| 6433 | S: Maintained | 5554 | S: Maintained |
| @@ -6435,46 +5556,39 @@ F: Documentation/networking/wavelan.txt | |||
| 6435 | F: drivers/net/wireless/wavelan* | 5556 | F: drivers/net/wireless/wavelan* |
| 6436 | 5557 | ||
| 6437 | WD7000 SCSI DRIVER | 5558 | WD7000 SCSI DRIVER |
| 6438 | P: Miroslav Zagorac | 5559 | M: Miroslav Zagorac <zaga@fly.cc.fer.hr> |
| 6439 | M: zaga@fly.cc.fer.hr | ||
| 6440 | L: linux-scsi@vger.kernel.org | 5560 | L: linux-scsi@vger.kernel.org |
| 6441 | S: Maintained | 5561 | S: Maintained |
| 6442 | F: drivers/scsi/wd7000.c | 5562 | F: drivers/scsi/wd7000.c |
| 6443 | 5563 | ||
| 6444 | WIMAX STACK | 5564 | WIMAX STACK |
| 6445 | P: Inaky Perez-Gonzalez | 5565 | M: Inaky Perez-Gonzalez <inaky.perez-gonzalez@intel.com> |
| 6446 | M: inaky.perez-gonzalez@intel.com | ||
| 6447 | M: linux-wimax@intel.com | 5566 | M: linux-wimax@intel.com |
| 6448 | L: wimax@linuxwimax.org | 5567 | L: wimax@linuxwimax.org |
| 6449 | S: Supported | 5568 | S: Supported |
| 6450 | W: http://linuxwimax.org | 5569 | W: http://linuxwimax.org |
| 6451 | 5570 | ||
| 6452 | WIMEDIA LLC PROTOCOL (WLP) SUBSYSTEM | 5571 | WIMEDIA LLC PROTOCOL (WLP) SUBSYSTEM |
| 6453 | P: David Vrabel | 5572 | M: David Vrabel <david.vrabel@csr.com> |
| 6454 | M: david.vrabel@csr.com | ||
| 6455 | S: Maintained | 5573 | S: Maintained |
| 6456 | F: include/linux/wlp.h | 5574 | F: include/linux/wlp.h |
| 6457 | F: drivers/uwb/wlp/ | 5575 | F: drivers/uwb/wlp/ |
| 6458 | 5576 | ||
| 6459 | WISTRON LAPTOP BUTTON DRIVER | 5577 | WISTRON LAPTOP BUTTON DRIVER |
| 6460 | P: Miloslav Trmac | 5578 | M: Miloslav Trmac <mitr@volny.cz> |
| 6461 | M: mitr@volny.cz | ||
| 6462 | S: Maintained | 5579 | S: Maintained |
| 6463 | F: drivers/input/misc/wistron_btns.c | 5580 | F: drivers/input/misc/wistron_btns.c |
| 6464 | 5581 | ||
| 6465 | WL3501 WIRELESS PCMCIA CARD DRIVER | 5582 | WL3501 WIRELESS PCMCIA CARD DRIVER |
| 6466 | P: Arnaldo Carvalho de Melo | 5583 | M: Arnaldo Carvalho de Melo <acme@ghostprotocols.net> |
| 6467 | M: acme@ghostprotocols.net | ||
| 6468 | L: linux-wireless@vger.kernel.org | 5584 | L: linux-wireless@vger.kernel.org |
| 6469 | W: http://oops.ghostprotocols.net:81/blog | 5585 | W: http://oops.ghostprotocols.net:81/blog |
| 6470 | S: Maintained | 5586 | S: Maintained |
| 6471 | F: drivers/net/wireless/wl3501* | 5587 | F: drivers/net/wireless/wl3501* |
| 6472 | 5588 | ||
| 6473 | WM97XX TOUCHSCREEN DRIVERS | 5589 | WM97XX TOUCHSCREEN DRIVERS |
| 6474 | P: Mark Brown | 5590 | M: Mark Brown <broonie@opensource.wolfsonmicro.com> |
| 6475 | M: broonie@opensource.wolfsonmicro.com | 5591 | M: Liam Girdwood <lrg@slimlogic.co.uk> |
| 6476 | P: Liam Girdwood | ||
| 6477 | M: lrg@slimlogic.co.uk | ||
| 6478 | L: linux-input@vger.kernel.org | 5592 | L: linux-input@vger.kernel.org |
| 6479 | T: git git://opensource.wolfsonmicro.com/linux-2.6-touch | 5593 | T: git git://opensource.wolfsonmicro.com/linux-2.6-touch |
| 6480 | W: http://opensource.wolfsonmicro.com/node/7 | 5594 | W: http://opensource.wolfsonmicro.com/node/7 |
| @@ -6483,8 +5597,7 @@ F: drivers/input/touchscreen/*wm97* | |||
| 6483 | F: include/linux/wm97xx.h | 5597 | F: include/linux/wm97xx.h |
| 6484 | 5598 | ||
| 6485 | X.25 NETWORK LAYER | 5599 | X.25 NETWORK LAYER |
| 6486 | P: Henner Eisen | 5600 | M: Henner Eisen <eis@baty.hanse.de> |
| 6487 | M: eis@baty.hanse.de | ||
| 6488 | L: linux-x25@vger.kernel.org | 5601 | L: linux-x25@vger.kernel.org |
| 6489 | S: Maintained | 5602 | S: Maintained |
| 6490 | F: Documentation/networking/x25* | 5603 | F: Documentation/networking/x25* |
| @@ -6492,12 +5605,9 @@ F: include/net/x25* | |||
| 6492 | F: net/x25/ | 5605 | F: net/x25/ |
| 6493 | 5606 | ||
| 6494 | X86 ARCHITECTURE (32-BIT AND 64-BIT) | 5607 | X86 ARCHITECTURE (32-BIT AND 64-BIT) |
| 6495 | P: Thomas Gleixner | 5608 | M: Thomas Gleixner <tglx@linutronix.de> |
| 6496 | M: tglx@linutronix.de | 5609 | M: Ingo Molnar <mingo@redhat.com> |
| 6497 | P: Ingo Molnar | 5610 | M: "H. Peter Anvin" <hpa@zytor.com> |
| 6498 | M: mingo@redhat.com | ||
| 6499 | P: H. Peter Anvin | ||
| 6500 | M: hpa@zytor.com | ||
| 6501 | M: x86@kernel.org | 5611 | M: x86@kernel.org |
| 6502 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/x86/linux-2.6-x86.git | 5612 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/x86/linux-2.6-x86.git |
| 6503 | S: Maintained | 5613 | S: Maintained |
| @@ -6505,10 +5615,8 @@ F: Documentation/x86/ | |||
| 6505 | F: arch/x86/ | 5615 | F: arch/x86/ |
| 6506 | 5616 | ||
| 6507 | XEN HYPERVISOR INTERFACE | 5617 | XEN HYPERVISOR INTERFACE |
| 6508 | P: Jeremy Fitzhardinge | 5618 | M: Jeremy Fitzhardinge <jeremy@xensource.com> |
| 6509 | M: jeremy@xensource.com | 5619 | M: Chris Wright <chrisw@sous-sol.org> |
| 6510 | P: Chris Wright | ||
| 6511 | M: chrisw@sous-sol.org | ||
| 6512 | L: virtualization@lists.osdl.org | 5620 | L: virtualization@lists.osdl.org |
| 6513 | L: xen-devel@lists.xensource.com | 5621 | L: xen-devel@lists.xensource.com |
| 6514 | S: Supported | 5622 | S: Supported |
| @@ -6520,8 +5628,7 @@ F: include/xen/ | |||
| 6520 | 5628 | ||
| 6521 | XFS FILESYSTEM | 5629 | XFS FILESYSTEM |
| 6522 | P: Silicon Graphics Inc | 5630 | P: Silicon Graphics Inc |
| 6523 | P: Felix Blyakher | 5631 | M: Felix Blyakher <felixb@sgi.com> |
| 6524 | M: felixb@sgi.com | ||
| 6525 | M: xfs-masters@oss.sgi.com | 5632 | M: xfs-masters@oss.sgi.com |
| 6526 | L: xfs@oss.sgi.com | 5633 | L: xfs@oss.sgi.com |
| 6527 | W: http://oss.sgi.com/projects/xfs | 5634 | W: http://oss.sgi.com/projects/xfs |
| @@ -6531,38 +5638,33 @@ F: Documentation/filesystems/xfs.txt | |||
| 6531 | F: fs/xfs/ | 5638 | F: fs/xfs/ |
| 6532 | 5639 | ||
| 6533 | XILINX SYSTEMACE DRIVER | 5640 | XILINX SYSTEMACE DRIVER |
| 6534 | P: Grant Likely | 5641 | M: Grant Likely <grant.likely@secretlab.ca> |
| 6535 | M: grant.likely@secretlab.ca | ||
| 6536 | W: http://www.secretlab.ca/ | 5642 | W: http://www.secretlab.ca/ |
| 6537 | S: Maintained | 5643 | S: Maintained |
| 6538 | F: drivers/block/xsysace.c | 5644 | F: drivers/block/xsysace.c |
| 6539 | 5645 | ||
| 6540 | XILINX UARTLITE SERIAL DRIVER | 5646 | XILINX UARTLITE SERIAL DRIVER |
| 6541 | P: Peter Korsgaard | 5647 | M: Peter Korsgaard <jacmet@sunsite.dk> |
| 6542 | M: jacmet@sunsite.dk | ||
| 6543 | L: linux-serial@vger.kernel.org | 5648 | L: linux-serial@vger.kernel.org |
| 6544 | S: Maintained | 5649 | S: Maintained |
| 6545 | F: drivers/serial/uartlite.c | 5650 | F: drivers/serial/uartlite.c |
| 6546 | 5651 | ||
| 6547 | YAM DRIVER FOR AX.25 | 5652 | YAM DRIVER FOR AX.25 |
| 6548 | P: Jean-Paul Roubelat | 5653 | M: Jean-Paul Roubelat <jpr@f6fbb.org> |
| 6549 | M: jpr@f6fbb.org | ||
| 6550 | L: linux-hams@vger.kernel.org | 5654 | L: linux-hams@vger.kernel.org |
| 6551 | S: Maintained | 5655 | S: Maintained |
| 6552 | F: drivers/net/hamradio/yam* | 5656 | F: drivers/net/hamradio/yam* |
| 6553 | F: include/linux/yam.h | 5657 | F: include/linux/yam.h |
| 6554 | 5658 | ||
| 6555 | YEALINK PHONE DRIVER | 5659 | YEALINK PHONE DRIVER |
| 6556 | P: Henk Vergonet | 5660 | M: Henk Vergonet <Henk.Vergonet@gmail.com> |
| 6557 | M: Henk.Vergonet@gmail.com | ||
| 6558 | L: usbb2k-api-dev@nongnu.org | 5661 | L: usbb2k-api-dev@nongnu.org |
| 6559 | S: Maintained | 5662 | S: Maintained |
| 6560 | F: Documentation/input/yealink.txt | 5663 | F: Documentation/input/yealink.txt |
| 6561 | F: drivers/input/misc/yealink.* | 5664 | F: drivers/input/misc/yealink.* |
| 6562 | 5665 | ||
| 6563 | Z8530 DRIVER FOR AX.25 | 5666 | Z8530 DRIVER FOR AX.25 |
| 6564 | P: Joerg Reuter | 5667 | M: Joerg Reuter <jreuter@yaina.de> |
| 6565 | M: jreuter@yaina.de | ||
| 6566 | W: http://yaina.de/jreuter/ | 5668 | W: http://yaina.de/jreuter/ |
| 6567 | W: http://www.qsl.net/dl1bke/ | 5669 | W: http://www.qsl.net/dl1bke/ |
| 6568 | L: linux-hams@vger.kernel.org | 5670 | L: linux-hams@vger.kernel.org |
| @@ -6572,10 +5674,8 @@ F: drivers/net/hamradio/*scc.c | |||
| 6572 | F: drivers/net/hamradio/z8530.h | 5674 | F: drivers/net/hamradio/z8530.h |
| 6573 | 5675 | ||
| 6574 | ZD1211RW WIRELESS DRIVER | 5676 | ZD1211RW WIRELESS DRIVER |
| 6575 | P: Daniel Drake | 5677 | M: Daniel Drake <dsd@gentoo.org> |
| 6576 | M: dsd@gentoo.org | 5678 | M: Ulrich Kunitz <kune@deine-taler.de> |
| 6577 | P: Ulrich Kunitz | ||
| 6578 | M: kune@deine-taler.de | ||
| 6579 | W: http://zd1211.ath.cx/wiki/DriverRewrite | 5679 | W: http://zd1211.ath.cx/wiki/DriverRewrite |
| 6580 | L: linux-wireless@vger.kernel.org | 5680 | L: linux-wireless@vger.kernel.org |
| 6581 | L: zd1211-devs@lists.sourceforge.net (subscribers-only) | 5681 | L: zd1211-devs@lists.sourceforge.net (subscribers-only) |
| @@ -6591,14 +5691,12 @@ S: Odd Fixes | |||
| 6591 | F: drivers/media/video/zoran/ | 5691 | F: drivers/media/video/zoran/ |
| 6592 | 5692 | ||
| 6593 | ZS DECSTATION Z85C30 SERIAL DRIVER | 5693 | ZS DECSTATION Z85C30 SERIAL DRIVER |
| 6594 | P: Maciej W. Rozycki | 5694 | M: "Maciej W. Rozycki" <macro@linux-mips.org> |
| 6595 | M: macro@linux-mips.org | ||
| 6596 | S: Maintained | 5695 | S: Maintained |
| 6597 | F: drivers/serial/zs.* | 5696 | F: drivers/serial/zs.* |
| 6598 | 5697 | ||
| 6599 | THE REST | 5698 | THE REST |
| 6600 | P: Linus Torvalds | 5699 | M: Linus Torvalds <torvalds@linux-foundation.org> |
| 6601 | M: torvalds@linux-foundation.org | ||
| 6602 | L: linux-kernel@vger.kernel.org | 5700 | L: linux-kernel@vger.kernel.org |
| 6603 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git | 5701 | T: git git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git |
| 6604 | S: Buried alive in reporters | 5702 | S: Buried alive in reporters |
| @@ -1,7 +1,7 @@ | |||
| 1 | VERSION = 2 | 1 | VERSION = 2 |
| 2 | PATCHLEVEL = 6 | 2 | PATCHLEVEL = 6 |
| 3 | SUBLEVEL = 31 | 3 | SUBLEVEL = 31 |
| 4 | EXTRAVERSION = -rc3 | 4 | EXTRAVERSION = -rc8 |
| 5 | NAME = Man-Eating Seals of Antiquity | 5 | NAME = Man-Eating Seals of Antiquity |
| 6 | 6 | ||
| 7 | # *DOCUMENTATION* | 7 | # *DOCUMENTATION* |
diff --git a/REPORTING-BUGS b/REPORTING-BUGS index ab0c56630a8c..55a6074ccbb7 100644 --- a/REPORTING-BUGS +++ b/REPORTING-BUGS | |||
| @@ -15,7 +15,10 @@ worry too much about getting the wrong person. If you are unsure send it | |||
| 15 | to the person responsible for the code relevant to what you were doing. | 15 | to the person responsible for the code relevant to what you were doing. |
| 16 | If it occurs repeatably try and describe how to recreate it. That is | 16 | If it occurs repeatably try and describe how to recreate it. That is |
| 17 | worth even more than the oops itself. The list of maintainers and | 17 | worth even more than the oops itself. The list of maintainers and |
| 18 | mailing lists is in the MAINTAINERS file in this directory. | 18 | mailing lists is in the MAINTAINERS file in this directory. If you |
| 19 | know the file name that causes the problem you can use the following | ||
| 20 | command in this directory to find some of the maintainers of that file: | ||
| 21 | perl scripts/get_maintainer.pl -f <filename> | ||
| 19 | 22 | ||
| 20 | If it is a security bug, please copy the Security Contact listed | 23 | If it is a security bug, please copy the Security Contact listed |
| 21 | in the MAINTAINERS file. They can help coordinate bugfix and disclosure. | 24 | in the MAINTAINERS file. They can help coordinate bugfix and disclosure. |
diff --git a/arch/alpha/include/asm/tlb.h b/arch/alpha/include/asm/tlb.h index c13636575fba..42866759f3fa 100644 --- a/arch/alpha/include/asm/tlb.h +++ b/arch/alpha/include/asm/tlb.h | |||
| @@ -9,7 +9,7 @@ | |||
| 9 | 9 | ||
| 10 | #include <asm-generic/tlb.h> | 10 | #include <asm-generic/tlb.h> |
| 11 | 11 | ||
| 12 | #define __pte_free_tlb(tlb, pte) pte_free((tlb)->mm, pte) | 12 | #define __pte_free_tlb(tlb, pte, address) pte_free((tlb)->mm, pte) |
| 13 | #define __pmd_free_tlb(tlb, pmd) pmd_free((tlb)->mm, pmd) | 13 | #define __pmd_free_tlb(tlb, pmd, address) pmd_free((tlb)->mm, pmd) |
| 14 | 14 | ||
| 15 | #endif | 15 | #endif |
diff --git a/arch/arm/boot/compressed/misc.c b/arch/arm/boot/compressed/misc.c index 9e6e512f0117..17153b54613b 100644 --- a/arch/arm/boot/compressed/misc.c +++ b/arch/arm/boot/compressed/misc.c | |||
| @@ -29,7 +29,6 @@ unsigned int __machine_arch_type; | |||
| 29 | 29 | ||
| 30 | static void putstr(const char *ptr); | 30 | static void putstr(const char *ptr); |
| 31 | 31 | ||
| 32 | #include <linux/compiler.h> | ||
| 33 | #include <mach/uncompress.h> | 32 | #include <mach/uncompress.h> |
| 34 | 33 | ||
| 35 | #ifdef CONFIG_DEBUG_ICEDCC | 34 | #ifdef CONFIG_DEBUG_ICEDCC |
diff --git a/arch/arm/common/clkdev.c b/arch/arm/common/clkdev.c index f37afd9422f3..aae5bc01acc8 100644 --- a/arch/arm/common/clkdev.c +++ b/arch/arm/common/clkdev.c | |||
| @@ -17,6 +17,7 @@ | |||
| 17 | #include <linux/err.h> | 17 | #include <linux/err.h> |
| 18 | #include <linux/string.h> | 18 | #include <linux/string.h> |
| 19 | #include <linux/mutex.h> | 19 | #include <linux/mutex.h> |
| 20 | #include <linux/clk.h> | ||
| 20 | 21 | ||
| 21 | #include <asm/clkdev.h> | 22 | #include <asm/clkdev.h> |
| 22 | #include <mach/clkdev.h> | 23 | #include <mach/clkdev.h> |
diff --git a/arch/arm/configs/kirkwood_defconfig b/arch/arm/configs/kirkwood_defconfig index 0a1abb978d7e..af74cc2de8b6 100644 --- a/arch/arm/configs/kirkwood_defconfig +++ b/arch/arm/configs/kirkwood_defconfig | |||
| @@ -629,7 +629,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 629 | CONFIG_ATA=y | 629 | CONFIG_ATA=y |
| 630 | # CONFIG_ATA_NONSTANDARD is not set | 630 | # CONFIG_ATA_NONSTANDARD is not set |
| 631 | CONFIG_SATA_PMP=y | 631 | CONFIG_SATA_PMP=y |
| 632 | # CONFIG_SATA_AHCI is not set | 632 | CONFIG_SATA_AHCI=y |
| 633 | # CONFIG_SATA_SIL24 is not set | 633 | # CONFIG_SATA_SIL24 is not set |
| 634 | CONFIG_ATA_SFF=y | 634 | CONFIG_ATA_SFF=y |
| 635 | # CONFIG_SATA_SVW is not set | 635 | # CONFIG_SATA_SVW is not set |
diff --git a/arch/arm/configs/mx27_defconfig b/arch/arm/configs/mx27_defconfig index 083516cd0d7f..75263a83741c 100644 --- a/arch/arm/configs/mx27_defconfig +++ b/arch/arm/configs/mx27_defconfig | |||
| @@ -1,15 +1,15 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc1 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed Apr 8 10:18:06 2009 | 4 | # Fri Jul 24 16:08:06 2009 |
| 5 | # | 5 | # |
| 6 | CONFIG_ARM=y | 6 | CONFIG_ARM=y |
| 7 | CONFIG_HAVE_PWM=y | ||
| 7 | CONFIG_SYS_SUPPORTS_APM_EMULATION=y | 8 | CONFIG_SYS_SUPPORTS_APM_EMULATION=y |
| 8 | CONFIG_GENERIC_GPIO=y | 9 | CONFIG_GENERIC_GPIO=y |
| 9 | CONFIG_GENERIC_TIME=y | 10 | CONFIG_GENERIC_TIME=y |
| 10 | CONFIG_GENERIC_CLOCKEVENTS=y | 11 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 11 | CONFIG_MMU=y | 12 | CONFIG_MMU=y |
| 12 | # CONFIG_NO_IOPORT is not set | ||
| 13 | CONFIG_GENERIC_HARDIRQS=y | 13 | CONFIG_GENERIC_HARDIRQS=y |
| 14 | CONFIG_STACKTRACE_SUPPORT=y | 14 | CONFIG_STACKTRACE_SUPPORT=y |
| 15 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 15 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| @@ -18,14 +18,13 @@ CONFIG_TRACE_IRQFLAGS_SUPPORT=y | |||
| 18 | CONFIG_HARDIRQS_SW_RESEND=y | 18 | CONFIG_HARDIRQS_SW_RESEND=y |
| 19 | CONFIG_GENERIC_IRQ_PROBE=y | 19 | CONFIG_GENERIC_IRQ_PROBE=y |
| 20 | CONFIG_RWSEM_GENERIC_SPINLOCK=y | 20 | CONFIG_RWSEM_GENERIC_SPINLOCK=y |
| 21 | # CONFIG_ARCH_HAS_ILOG2_U32 is not set | ||
| 22 | # CONFIG_ARCH_HAS_ILOG2_U64 is not set | ||
| 23 | CONFIG_GENERIC_HWEIGHT=y | 21 | CONFIG_GENERIC_HWEIGHT=y |
| 24 | CONFIG_GENERIC_CALIBRATE_DELAY=y | 22 | CONFIG_GENERIC_CALIBRATE_DELAY=y |
| 25 | CONFIG_ARCH_MTD_XIP=y | 23 | CONFIG_ARCH_MTD_XIP=y |
| 26 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | 24 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y |
| 27 | CONFIG_VECTORS_BASE=0xffff0000 | 25 | CONFIG_VECTORS_BASE=0xffff0000 |
| 28 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 26 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 27 | CONFIG_CONSTRUCTORS=y | ||
| 29 | 28 | ||
| 30 | # | 29 | # |
| 31 | # General setup | 30 | # General setup |
| @@ -85,7 +84,12 @@ CONFIG_TIMERFD=y | |||
| 85 | CONFIG_EVENTFD=y | 84 | CONFIG_EVENTFD=y |
| 86 | CONFIG_SHMEM=y | 85 | CONFIG_SHMEM=y |
| 87 | CONFIG_AIO=y | 86 | CONFIG_AIO=y |
| 87 | |||
| 88 | # | ||
| 89 | # Performance Counters | ||
| 90 | # | ||
| 88 | CONFIG_VM_EVENT_COUNTERS=y | 91 | CONFIG_VM_EVENT_COUNTERS=y |
| 92 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 89 | # CONFIG_COMPAT_BRK is not set | 93 | # CONFIG_COMPAT_BRK is not set |
| 90 | CONFIG_SLAB=y | 94 | CONFIG_SLAB=y |
| 91 | # CONFIG_SLUB is not set | 95 | # CONFIG_SLUB is not set |
| @@ -99,6 +103,12 @@ CONFIG_KPROBES=y | |||
| 99 | CONFIG_KRETPROBES=y | 103 | CONFIG_KRETPROBES=y |
| 100 | CONFIG_HAVE_KPROBES=y | 104 | CONFIG_HAVE_KPROBES=y |
| 101 | CONFIG_HAVE_KRETPROBES=y | 105 | CONFIG_HAVE_KRETPROBES=y |
| 106 | CONFIG_HAVE_CLK=y | ||
| 107 | |||
| 108 | # | ||
| 109 | # GCOV-based kernel profiling | ||
| 110 | # | ||
| 111 | # CONFIG_GCOV_KERNEL is not set | ||
| 102 | # CONFIG_SLOW_WORK is not set | 112 | # CONFIG_SLOW_WORK is not set |
| 103 | CONFIG_HAVE_GENERIC_DMA_COHERENT=y | 113 | CONFIG_HAVE_GENERIC_DMA_COHERENT=y |
| 104 | CONFIG_SLABINFO=y | 114 | CONFIG_SLABINFO=y |
| @@ -111,7 +121,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 111 | # CONFIG_MODVERSIONS is not set | 121 | # CONFIG_MODVERSIONS is not set |
| 112 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 122 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 113 | CONFIG_BLOCK=y | 123 | CONFIG_BLOCK=y |
| 114 | # CONFIG_LBD is not set | 124 | CONFIG_LBDAF=y |
| 115 | # CONFIG_BLK_DEV_BSG is not set | 125 | # CONFIG_BLK_DEV_BSG is not set |
| 116 | # CONFIG_BLK_DEV_INTEGRITY is not set | 126 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 117 | 127 | ||
| @@ -138,13 +148,14 @@ CONFIG_FREEZER=y | |||
| 138 | # CONFIG_ARCH_VERSATILE is not set | 148 | # CONFIG_ARCH_VERSATILE is not set |
| 139 | # CONFIG_ARCH_AT91 is not set | 149 | # CONFIG_ARCH_AT91 is not set |
| 140 | # CONFIG_ARCH_CLPS711X is not set | 150 | # CONFIG_ARCH_CLPS711X is not set |
| 151 | # CONFIG_ARCH_GEMINI is not set | ||
| 141 | # CONFIG_ARCH_EBSA110 is not set | 152 | # CONFIG_ARCH_EBSA110 is not set |
| 142 | # CONFIG_ARCH_EP93XX is not set | 153 | # CONFIG_ARCH_EP93XX is not set |
| 143 | # CONFIG_ARCH_GEMINI is not set | ||
| 144 | # CONFIG_ARCH_FOOTBRIDGE is not set | 154 | # CONFIG_ARCH_FOOTBRIDGE is not set |
| 155 | CONFIG_ARCH_MXC=y | ||
| 156 | # CONFIG_ARCH_STMP3XXX is not set | ||
| 145 | # CONFIG_ARCH_NETX is not set | 157 | # CONFIG_ARCH_NETX is not set |
| 146 | # CONFIG_ARCH_H720X is not set | 158 | # CONFIG_ARCH_H720X is not set |
| 147 | # CONFIG_ARCH_IMX is not set | ||
| 148 | # CONFIG_ARCH_IOP13XX is not set | 159 | # CONFIG_ARCH_IOP13XX is not set |
| 149 | # CONFIG_ARCH_IOP32X is not set | 160 | # CONFIG_ARCH_IOP32X is not set |
| 150 | # CONFIG_ARCH_IOP33X is not set | 161 | # CONFIG_ARCH_IOP33X is not set |
| @@ -153,25 +164,25 @@ CONFIG_FREEZER=y | |||
| 153 | # CONFIG_ARCH_IXP4XX is not set | 164 | # CONFIG_ARCH_IXP4XX is not set |
| 154 | # CONFIG_ARCH_L7200 is not set | 165 | # CONFIG_ARCH_L7200 is not set |
| 155 | # CONFIG_ARCH_KIRKWOOD is not set | 166 | # CONFIG_ARCH_KIRKWOOD is not set |
| 156 | # CONFIG_ARCH_KS8695 is not set | ||
| 157 | # CONFIG_ARCH_NS9XXX is not set | ||
| 158 | # CONFIG_ARCH_LOKI is not set | 167 | # CONFIG_ARCH_LOKI is not set |
| 159 | # CONFIG_ARCH_MV78XX0 is not set | 168 | # CONFIG_ARCH_MV78XX0 is not set |
| 160 | CONFIG_ARCH_MXC=y | ||
| 161 | # CONFIG_ARCH_ORION5X is not set | 169 | # CONFIG_ARCH_ORION5X is not set |
| 170 | # CONFIG_ARCH_MMP is not set | ||
| 171 | # CONFIG_ARCH_KS8695 is not set | ||
| 172 | # CONFIG_ARCH_NS9XXX is not set | ||
| 173 | # CONFIG_ARCH_W90X900 is not set | ||
| 162 | # CONFIG_ARCH_PNX4008 is not set | 174 | # CONFIG_ARCH_PNX4008 is not set |
| 163 | # CONFIG_ARCH_PXA is not set | 175 | # CONFIG_ARCH_PXA is not set |
| 164 | # CONFIG_ARCH_MMP is not set | 176 | # CONFIG_ARCH_MSM is not set |
| 165 | # CONFIG_ARCH_RPC is not set | 177 | # CONFIG_ARCH_RPC is not set |
| 166 | # CONFIG_ARCH_SA1100 is not set | 178 | # CONFIG_ARCH_SA1100 is not set |
| 167 | # CONFIG_ARCH_S3C2410 is not set | 179 | # CONFIG_ARCH_S3C2410 is not set |
| 168 | # CONFIG_ARCH_S3C64XX is not set | 180 | # CONFIG_ARCH_S3C64XX is not set |
| 169 | # CONFIG_ARCH_SHARK is not set | 181 | # CONFIG_ARCH_SHARK is not set |
| 170 | # CONFIG_ARCH_LH7A40X is not set | 182 | # CONFIG_ARCH_LH7A40X is not set |
| 183 | # CONFIG_ARCH_U300 is not set | ||
| 171 | # CONFIG_ARCH_DAVINCI is not set | 184 | # CONFIG_ARCH_DAVINCI is not set |
| 172 | # CONFIG_ARCH_OMAP is not set | 185 | # CONFIG_ARCH_OMAP is not set |
| 173 | # CONFIG_ARCH_MSM is not set | ||
| 174 | # CONFIG_ARCH_W90X900 is not set | ||
| 175 | 186 | ||
| 176 | # | 187 | # |
| 177 | # Freescale MXC Implementations | 188 | # Freescale MXC Implementations |
| @@ -188,6 +199,8 @@ CONFIG_MACH_MX27=y | |||
| 188 | CONFIG_MACH_MX27ADS=y | 199 | CONFIG_MACH_MX27ADS=y |
| 189 | CONFIG_MACH_PCM038=y | 200 | CONFIG_MACH_PCM038=y |
| 190 | CONFIG_MACH_PCM970_BASEBOARD=y | 201 | CONFIG_MACH_PCM970_BASEBOARD=y |
| 202 | CONFIG_MACH_MX27_3DS=y | ||
| 203 | CONFIG_MACH_MX27LITE=y | ||
| 191 | CONFIG_MXC_IRQ_PRIOR=y | 204 | CONFIG_MXC_IRQ_PRIOR=y |
| 192 | CONFIG_MXC_PWM=y | 205 | CONFIG_MXC_PWM=y |
| 193 | 206 | ||
| @@ -213,7 +226,6 @@ CONFIG_ARM_THUMB=y | |||
| 213 | # CONFIG_CPU_DCACHE_DISABLE is not set | 226 | # CONFIG_CPU_DCACHE_DISABLE is not set |
| 214 | # CONFIG_CPU_DCACHE_WRITETHROUGH is not set | 227 | # CONFIG_CPU_DCACHE_WRITETHROUGH is not set |
| 215 | # CONFIG_CPU_CACHE_ROUND_ROBIN is not set | 228 | # CONFIG_CPU_CACHE_ROUND_ROBIN is not set |
| 216 | # CONFIG_OUTER_CACHE is not set | ||
| 217 | CONFIG_COMMON_CLKDEV=y | 229 | CONFIG_COMMON_CLKDEV=y |
| 218 | 230 | ||
| 219 | # | 231 | # |
| @@ -238,7 +250,6 @@ CONFIG_PREEMPT=y | |||
| 238 | CONFIG_HZ=100 | 250 | CONFIG_HZ=100 |
| 239 | CONFIG_AEABI=y | 251 | CONFIG_AEABI=y |
| 240 | CONFIG_OABI_COMPAT=y | 252 | CONFIG_OABI_COMPAT=y |
| 241 | CONFIG_ARCH_FLATMEM_HAS_HOLES=y | ||
| 242 | # CONFIG_ARCH_SPARSEMEM_DEFAULT is not set | 253 | # CONFIG_ARCH_SPARSEMEM_DEFAULT is not set |
| 243 | # CONFIG_ARCH_SELECT_MEMORY_MODEL is not set | 254 | # CONFIG_ARCH_SELECT_MEMORY_MODEL is not set |
| 244 | # CONFIG_HIGHMEM is not set | 255 | # CONFIG_HIGHMEM is not set |
| @@ -253,10 +264,11 @@ CONFIG_SPLIT_PTLOCK_CPUS=4096 | |||
| 253 | # CONFIG_PHYS_ADDR_T_64BIT is not set | 264 | # CONFIG_PHYS_ADDR_T_64BIT is not set |
| 254 | CONFIG_ZONE_DMA_FLAG=0 | 265 | CONFIG_ZONE_DMA_FLAG=0 |
| 255 | CONFIG_VIRT_TO_BUS=y | 266 | CONFIG_VIRT_TO_BUS=y |
| 256 | CONFIG_UNEVICTABLE_LRU=y | ||
| 257 | CONFIG_HAVE_MLOCK=y | 267 | CONFIG_HAVE_MLOCK=y |
| 258 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 268 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 269 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 259 | CONFIG_ALIGNMENT_TRAP=y | 270 | CONFIG_ALIGNMENT_TRAP=y |
| 271 | # CONFIG_UACCESS_WITH_MEMCPY is not set | ||
| 260 | 272 | ||
| 261 | # | 273 | # |
| 262 | # Boot options | 274 | # Boot options |
| @@ -361,6 +373,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 361 | # CONFIG_ECONET is not set | 373 | # CONFIG_ECONET is not set |
| 362 | # CONFIG_WAN_ROUTER is not set | 374 | # CONFIG_WAN_ROUTER is not set |
| 363 | # CONFIG_PHONET is not set | 375 | # CONFIG_PHONET is not set |
| 376 | # CONFIG_IEEE802154 is not set | ||
| 364 | # CONFIG_NET_SCHED is not set | 377 | # CONFIG_NET_SCHED is not set |
| 365 | # CONFIG_DCB is not set | 378 | # CONFIG_DCB is not set |
| 366 | 379 | ||
| @@ -474,7 +487,16 @@ CONFIG_MTD_PHYSMAP=y | |||
| 474 | # CONFIG_MTD_DOC2000 is not set | 487 | # CONFIG_MTD_DOC2000 is not set |
| 475 | # CONFIG_MTD_DOC2001 is not set | 488 | # CONFIG_MTD_DOC2001 is not set |
| 476 | # CONFIG_MTD_DOC2001PLUS is not set | 489 | # CONFIG_MTD_DOC2001PLUS is not set |
| 477 | # CONFIG_MTD_NAND is not set | 490 | CONFIG_MTD_NAND=y |
| 491 | # CONFIG_MTD_NAND_VERIFY_WRITE is not set | ||
| 492 | # CONFIG_MTD_NAND_ECC_SMC is not set | ||
| 493 | # CONFIG_MTD_NAND_MUSEUM_IDS is not set | ||
| 494 | # CONFIG_MTD_NAND_GPIO is not set | ||
| 495 | CONFIG_MTD_NAND_IDS=y | ||
| 496 | # CONFIG_MTD_NAND_DISKONCHIP is not set | ||
| 497 | # CONFIG_MTD_NAND_NANDSIM is not set | ||
| 498 | # CONFIG_MTD_NAND_PLATFORM is not set | ||
| 499 | CONFIG_MTD_NAND_MXC=y | ||
| 478 | # CONFIG_MTD_ONENAND is not set | 500 | # CONFIG_MTD_ONENAND is not set |
| 479 | 501 | ||
| 480 | # | 502 | # |
| @@ -485,7 +507,15 @@ CONFIG_MTD_PHYSMAP=y | |||
| 485 | # | 507 | # |
| 486 | # UBI - Unsorted block images | 508 | # UBI - Unsorted block images |
| 487 | # | 509 | # |
| 488 | # CONFIG_MTD_UBI is not set | 510 | CONFIG_MTD_UBI=y |
| 511 | CONFIG_MTD_UBI_WL_THRESHOLD=4096 | ||
| 512 | CONFIG_MTD_UBI_BEB_RESERVE=1 | ||
| 513 | # CONFIG_MTD_UBI_GLUEBI is not set | ||
| 514 | |||
| 515 | # | ||
| 516 | # UBI debugging options | ||
| 517 | # | ||
| 518 | # CONFIG_MTD_UBI_DEBUG is not set | ||
| 489 | # CONFIG_PARPORT is not set | 519 | # CONFIG_PARPORT is not set |
| 490 | CONFIG_BLK_DEV=y | 520 | CONFIG_BLK_DEV=y |
| 491 | # CONFIG_BLK_DEV_COW_COMMON is not set | 521 | # CONFIG_BLK_DEV_COW_COMMON is not set |
| @@ -494,7 +524,21 @@ CONFIG_BLK_DEV=y | |||
| 494 | # CONFIG_BLK_DEV_RAM is not set | 524 | # CONFIG_BLK_DEV_RAM is not set |
| 495 | # CONFIG_CDROM_PKTCDVD is not set | 525 | # CONFIG_CDROM_PKTCDVD is not set |
| 496 | # CONFIG_ATA_OVER_ETH is not set | 526 | # CONFIG_ATA_OVER_ETH is not set |
| 497 | # CONFIG_MISC_DEVICES is not set | 527 | # CONFIG_MG_DISK is not set |
| 528 | CONFIG_MISC_DEVICES=y | ||
| 529 | # CONFIG_ICS932S401 is not set | ||
| 530 | # CONFIG_ENCLOSURE_SERVICES is not set | ||
| 531 | # CONFIG_ISL29003 is not set | ||
| 532 | # CONFIG_C2PORT is not set | ||
| 533 | |||
| 534 | # | ||
| 535 | # EEPROM support | ||
| 536 | # | ||
| 537 | CONFIG_EEPROM_AT24=y | ||
| 538 | # CONFIG_EEPROM_AT25 is not set | ||
| 539 | # CONFIG_EEPROM_LEGACY is not set | ||
| 540 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 541 | # CONFIG_EEPROM_93CX6 is not set | ||
| 498 | CONFIG_HAVE_IDE=y | 542 | CONFIG_HAVE_IDE=y |
| 499 | # CONFIG_IDE is not set | 543 | # CONFIG_IDE is not set |
| 500 | 544 | ||
| @@ -508,7 +552,6 @@ CONFIG_HAVE_IDE=y | |||
| 508 | # CONFIG_ATA is not set | 552 | # CONFIG_ATA is not set |
| 509 | # CONFIG_MD is not set | 553 | # CONFIG_MD is not set |
| 510 | CONFIG_NETDEVICES=y | 554 | CONFIG_NETDEVICES=y |
| 511 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 512 | # CONFIG_DUMMY is not set | 555 | # CONFIG_DUMMY is not set |
| 513 | # CONFIG_BONDING is not set | 556 | # CONFIG_BONDING is not set |
| 514 | # CONFIG_MACVLAN is not set | 557 | # CONFIG_MACVLAN is not set |
| @@ -534,6 +577,8 @@ CONFIG_NET_ETHERNET=y | |||
| 534 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 577 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 535 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 578 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 536 | # CONFIG_B44 is not set | 579 | # CONFIG_B44 is not set |
| 580 | # CONFIG_KS8842 is not set | ||
| 581 | # CONFIG_KS8851 is not set | ||
| 537 | CONFIG_FEC=y | 582 | CONFIG_FEC=y |
| 538 | # CONFIG_FEC2 is not set | 583 | # CONFIG_FEC2 is not set |
| 539 | # CONFIG_NETDEV_1000 is not set | 584 | # CONFIG_NETDEV_1000 is not set |
| @@ -580,6 +625,11 @@ CONFIG_INPUT_EVDEV=y | |||
| 580 | # CONFIG_INPUT_TABLET is not set | 625 | # CONFIG_INPUT_TABLET is not set |
| 581 | CONFIG_INPUT_TOUCHSCREEN=y | 626 | CONFIG_INPUT_TOUCHSCREEN=y |
| 582 | # CONFIG_TOUCHSCREEN_ADS7846 is not set | 627 | # CONFIG_TOUCHSCREEN_ADS7846 is not set |
| 628 | # CONFIG_TOUCHSCREEN_AD7877 is not set | ||
| 629 | # CONFIG_TOUCHSCREEN_AD7879_I2C is not set | ||
| 630 | # CONFIG_TOUCHSCREEN_AD7879_SPI is not set | ||
| 631 | # CONFIG_TOUCHSCREEN_AD7879 is not set | ||
| 632 | # CONFIG_TOUCHSCREEN_EETI is not set | ||
| 583 | # CONFIG_TOUCHSCREEN_FUJITSU is not set | 633 | # CONFIG_TOUCHSCREEN_FUJITSU is not set |
| 584 | # CONFIG_TOUCHSCREEN_GUNZE is not set | 634 | # CONFIG_TOUCHSCREEN_GUNZE is not set |
| 585 | # CONFIG_TOUCHSCREEN_ELO is not set | 635 | # CONFIG_TOUCHSCREEN_ELO is not set |
| @@ -592,6 +642,7 @@ CONFIG_INPUT_TOUCHSCREEN=y | |||
| 592 | # CONFIG_TOUCHSCREEN_TOUCHWIN is not set | 642 | # CONFIG_TOUCHSCREEN_TOUCHWIN is not set |
| 593 | # CONFIG_TOUCHSCREEN_TOUCHIT213 is not set | 643 | # CONFIG_TOUCHSCREEN_TOUCHIT213 is not set |
| 594 | # CONFIG_TOUCHSCREEN_TSC2007 is not set | 644 | # CONFIG_TOUCHSCREEN_TSC2007 is not set |
| 645 | # CONFIG_TOUCHSCREEN_W90X900 is not set | ||
| 595 | # CONFIG_INPUT_MISC is not set | 646 | # CONFIG_INPUT_MISC is not set |
| 596 | 647 | ||
| 597 | # | 648 | # |
| @@ -644,6 +695,7 @@ CONFIG_I2C_HELPER_AUTO=y | |||
| 644 | # | 695 | # |
| 645 | # I2C system bus drivers (mostly embedded / system-on-chip) | 696 | # I2C system bus drivers (mostly embedded / system-on-chip) |
| 646 | # | 697 | # |
| 698 | # CONFIG_I2C_DESIGNWARE is not set | ||
| 647 | # CONFIG_I2C_GPIO is not set | 699 | # CONFIG_I2C_GPIO is not set |
| 648 | CONFIG_I2C_IMX=y | 700 | CONFIG_I2C_IMX=y |
| 649 | # CONFIG_I2C_OCORES is not set | 701 | # CONFIG_I2C_OCORES is not set |
| @@ -668,7 +720,6 @@ CONFIG_I2C_IMX=y | |||
| 668 | # CONFIG_SENSORS_PCF8574 is not set | 720 | # CONFIG_SENSORS_PCF8574 is not set |
| 669 | # CONFIG_PCF8575 is not set | 721 | # CONFIG_PCF8575 is not set |
| 670 | # CONFIG_SENSORS_PCA9539 is not set | 722 | # CONFIG_SENSORS_PCA9539 is not set |
| 671 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 672 | # CONFIG_SENSORS_TSL2550 is not set | 723 | # CONFIG_SENSORS_TSL2550 is not set |
| 673 | # CONFIG_I2C_DEBUG_CORE is not set | 724 | # CONFIG_I2C_DEBUG_CORE is not set |
| 674 | # CONFIG_I2C_DEBUG_ALGO is not set | 725 | # CONFIG_I2C_DEBUG_ALGO is not set |
| @@ -719,6 +770,7 @@ CONFIG_W1=y | |||
| 719 | # | 770 | # |
| 720 | # CONFIG_W1_MASTER_DS2482 is not set | 771 | # CONFIG_W1_MASTER_DS2482 is not set |
| 721 | CONFIG_W1_MASTER_MXC=y | 772 | CONFIG_W1_MASTER_MXC=y |
| 773 | # CONFIG_W1_MASTER_DS1WM is not set | ||
| 722 | # CONFIG_W1_MASTER_GPIO is not set | 774 | # CONFIG_W1_MASTER_GPIO is not set |
| 723 | 775 | ||
| 724 | # | 776 | # |
| @@ -753,54 +805,16 @@ CONFIG_SSB_POSSIBLE=y | |||
| 753 | # CONFIG_TPS65010 is not set | 805 | # CONFIG_TPS65010 is not set |
| 754 | # CONFIG_TWL4030_CORE is not set | 806 | # CONFIG_TWL4030_CORE is not set |
| 755 | # CONFIG_MFD_TMIO is not set | 807 | # CONFIG_MFD_TMIO is not set |
| 808 | # CONFIG_MFD_T7L66XB is not set | ||
| 809 | # CONFIG_MFD_TC6387XB is not set | ||
| 756 | # CONFIG_MFD_TC6393XB is not set | 810 | # CONFIG_MFD_TC6393XB is not set |
| 757 | # CONFIG_PMIC_DA903X is not set | 811 | # CONFIG_PMIC_DA903X is not set |
| 758 | # CONFIG_MFD_WM8400 is not set | 812 | # CONFIG_MFD_WM8400 is not set |
| 759 | # CONFIG_MFD_WM8350_I2C is not set | 813 | # CONFIG_MFD_WM8350_I2C is not set |
| 760 | # CONFIG_MFD_PCF50633 is not set | 814 | # CONFIG_MFD_PCF50633 is not set |
| 761 | 815 | # CONFIG_AB3100_CORE is not set | |
| 762 | # | 816 | # CONFIG_EZX_PCAP is not set |
| 763 | # Multimedia devices | 817 | # CONFIG_MEDIA_SUPPORT is not set |
| 764 | # | ||
| 765 | |||
| 766 | # | ||
| 767 | # Multimedia core support | ||
| 768 | # | ||
| 769 | CONFIG_VIDEO_DEV=y | ||
| 770 | CONFIG_VIDEO_V4L2_COMMON=y | ||
| 771 | CONFIG_VIDEO_ALLOW_V4L1=y | ||
| 772 | CONFIG_VIDEO_V4L1_COMPAT=y | ||
| 773 | # CONFIG_DVB_CORE is not set | ||
| 774 | CONFIG_VIDEO_MEDIA=y | ||
| 775 | |||
| 776 | # | ||
| 777 | # Multimedia drivers | ||
| 778 | # | ||
| 779 | # CONFIG_MEDIA_ATTACH is not set | ||
| 780 | CONFIG_MEDIA_TUNER=y | ||
| 781 | # CONFIG_MEDIA_TUNER_CUSTOMISE is not set | ||
| 782 | CONFIG_MEDIA_TUNER_SIMPLE=y | ||
| 783 | CONFIG_MEDIA_TUNER_TDA8290=y | ||
| 784 | CONFIG_MEDIA_TUNER_TDA9887=y | ||
| 785 | CONFIG_MEDIA_TUNER_TEA5761=y | ||
| 786 | CONFIG_MEDIA_TUNER_TEA5767=y | ||
| 787 | CONFIG_MEDIA_TUNER_MT20XX=y | ||
| 788 | CONFIG_MEDIA_TUNER_XC2028=y | ||
| 789 | CONFIG_MEDIA_TUNER_XC5000=y | ||
| 790 | CONFIG_MEDIA_TUNER_MC44S803=y | ||
| 791 | CONFIG_VIDEO_V4L2=y | ||
| 792 | CONFIG_VIDEO_V4L1=y | ||
| 793 | CONFIG_VIDEO_CAPTURE_DRIVERS=y | ||
| 794 | # CONFIG_VIDEO_ADV_DEBUG is not set | ||
| 795 | # CONFIG_VIDEO_FIXED_MINOR_RANGES is not set | ||
| 796 | CONFIG_VIDEO_HELPER_CHIPS_AUTO=y | ||
| 797 | # CONFIG_VIDEO_VIVI is not set | ||
| 798 | # CONFIG_VIDEO_CPIA is not set | ||
| 799 | # CONFIG_VIDEO_SAA5246A is not set | ||
| 800 | # CONFIG_VIDEO_SAA5249 is not set | ||
| 801 | # CONFIG_SOC_CAMERA is not set | ||
| 802 | # CONFIG_RADIO_ADAPTERS is not set | ||
| 803 | # CONFIG_DAB is not set | ||
| 804 | 818 | ||
| 805 | # | 819 | # |
| 806 | # Graphics support | 820 | # Graphics support |
| @@ -917,6 +931,7 @@ CONFIG_RTC_DRV_PCF8563=y | |||
| 917 | # CONFIG_RTC_DRV_S35390A is not set | 931 | # CONFIG_RTC_DRV_S35390A is not set |
| 918 | # CONFIG_RTC_DRV_FM3130 is not set | 932 | # CONFIG_RTC_DRV_FM3130 is not set |
| 919 | # CONFIG_RTC_DRV_RX8581 is not set | 933 | # CONFIG_RTC_DRV_RX8581 is not set |
| 934 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 920 | 935 | ||
| 921 | # | 936 | # |
| 922 | # SPI RTC drivers | 937 | # SPI RTC drivers |
| @@ -962,12 +977,15 @@ CONFIG_RTC_DRV_PCF8563=y | |||
| 962 | # CONFIG_REISERFS_FS is not set | 977 | # CONFIG_REISERFS_FS is not set |
| 963 | # CONFIG_JFS_FS is not set | 978 | # CONFIG_JFS_FS is not set |
| 964 | # CONFIG_FS_POSIX_ACL is not set | 979 | # CONFIG_FS_POSIX_ACL is not set |
| 965 | CONFIG_FILE_LOCKING=y | ||
| 966 | # CONFIG_XFS_FS is not set | 980 | # CONFIG_XFS_FS is not set |
| 981 | # CONFIG_GFS2_FS is not set | ||
| 967 | # CONFIG_OCFS2_FS is not set | 982 | # CONFIG_OCFS2_FS is not set |
| 968 | # CONFIG_BTRFS_FS is not set | 983 | # CONFIG_BTRFS_FS is not set |
| 984 | CONFIG_FILE_LOCKING=y | ||
| 985 | CONFIG_FSNOTIFY=y | ||
| 969 | # CONFIG_DNOTIFY is not set | 986 | # CONFIG_DNOTIFY is not set |
| 970 | # CONFIG_INOTIFY is not set | 987 | # CONFIG_INOTIFY is not set |
| 988 | CONFIG_INOTIFY_USER=y | ||
| 971 | # CONFIG_QUOTA is not set | 989 | # CONFIG_QUOTA is not set |
| 972 | # CONFIG_AUTOFS_FS is not set | 990 | # CONFIG_AUTOFS_FS is not set |
| 973 | # CONFIG_AUTOFS4_FS is not set | 991 | # CONFIG_AUTOFS4_FS is not set |
| @@ -1021,6 +1039,12 @@ CONFIG_JFFS2_ZLIB=y | |||
| 1021 | # CONFIG_JFFS2_LZO is not set | 1039 | # CONFIG_JFFS2_LZO is not set |
| 1022 | CONFIG_JFFS2_RTIME=y | 1040 | CONFIG_JFFS2_RTIME=y |
| 1023 | # CONFIG_JFFS2_RUBIN is not set | 1041 | # CONFIG_JFFS2_RUBIN is not set |
| 1042 | CONFIG_UBIFS_FS=y | ||
| 1043 | # CONFIG_UBIFS_FS_XATTR is not set | ||
| 1044 | # CONFIG_UBIFS_FS_ADVANCED_COMPR is not set | ||
| 1045 | CONFIG_UBIFS_FS_LZO=y | ||
| 1046 | CONFIG_UBIFS_FS_ZLIB=y | ||
| 1047 | # CONFIG_UBIFS_FS_DEBUG is not set | ||
| 1024 | # CONFIG_CRAMFS is not set | 1048 | # CONFIG_CRAMFS is not set |
| 1025 | # CONFIG_SQUASHFS is not set | 1049 | # CONFIG_SQUASHFS is not set |
| 1026 | # CONFIG_VXFS_FS is not set | 1050 | # CONFIG_VXFS_FS is not set |
| @@ -1119,25 +1143,11 @@ CONFIG_SYSCTL_SYSCALL_CHECK=y | |||
| 1119 | CONFIG_NOP_TRACER=y | 1143 | CONFIG_NOP_TRACER=y |
| 1120 | CONFIG_HAVE_FUNCTION_TRACER=y | 1144 | CONFIG_HAVE_FUNCTION_TRACER=y |
| 1121 | CONFIG_RING_BUFFER=y | 1145 | CONFIG_RING_BUFFER=y |
| 1146 | CONFIG_EVENT_TRACING=y | ||
| 1147 | CONFIG_CONTEXT_SWITCH_TRACER=y | ||
| 1122 | CONFIG_TRACING=y | 1148 | CONFIG_TRACING=y |
| 1123 | CONFIG_TRACING_SUPPORT=y | 1149 | CONFIG_TRACING_SUPPORT=y |
| 1124 | 1150 | # CONFIG_FTRACE is not set | |
| 1125 | # | ||
| 1126 | # Tracers | ||
| 1127 | # | ||
| 1128 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1129 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1130 | # CONFIG_PREEMPT_TRACER is not set | ||
| 1131 | # CONFIG_SCHED_TRACER is not set | ||
| 1132 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1133 | # CONFIG_EVENT_TRACER is not set | ||
| 1134 | # CONFIG_BOOT_TRACER is not set | ||
| 1135 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1136 | # CONFIG_STACK_TRACER is not set | ||
| 1137 | # CONFIG_KMEMTRACE is not set | ||
| 1138 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1139 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1140 | # CONFIG_FTRACE_STARTUP_TEST is not set | ||
| 1141 | # CONFIG_DYNAMIC_DEBUG is not set | 1151 | # CONFIG_DYNAMIC_DEBUG is not set |
| 1142 | # CONFIG_SAMPLES is not set | 1152 | # CONFIG_SAMPLES is not set |
| 1143 | CONFIG_HAVE_ARCH_KGDB=y | 1153 | CONFIG_HAVE_ARCH_KGDB=y |
| @@ -1151,16 +1161,104 @@ CONFIG_ARM_UNWIND=y | |||
| 1151 | # CONFIG_SECURITY is not set | 1161 | # CONFIG_SECURITY is not set |
| 1152 | # CONFIG_SECURITYFS is not set | 1162 | # CONFIG_SECURITYFS is not set |
| 1153 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set | 1163 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set |
| 1154 | # CONFIG_CRYPTO is not set | 1164 | CONFIG_CRYPTO=y |
| 1165 | |||
| 1166 | # | ||
| 1167 | # Crypto core or helper | ||
| 1168 | # | ||
| 1169 | # CONFIG_CRYPTO_FIPS is not set | ||
| 1170 | CONFIG_CRYPTO_ALGAPI=y | ||
| 1171 | CONFIG_CRYPTO_ALGAPI2=y | ||
| 1172 | # CONFIG_CRYPTO_MANAGER is not set | ||
| 1173 | # CONFIG_CRYPTO_MANAGER2 is not set | ||
| 1174 | # CONFIG_CRYPTO_GF128MUL is not set | ||
| 1175 | # CONFIG_CRYPTO_NULL is not set | ||
| 1176 | # CONFIG_CRYPTO_CRYPTD is not set | ||
| 1177 | # CONFIG_CRYPTO_AUTHENC is not set | ||
| 1178 | # CONFIG_CRYPTO_TEST is not set | ||
| 1179 | |||
| 1180 | # | ||
| 1181 | # Authenticated Encryption with Associated Data | ||
| 1182 | # | ||
| 1183 | # CONFIG_CRYPTO_CCM is not set | ||
| 1184 | # CONFIG_CRYPTO_GCM is not set | ||
| 1185 | # CONFIG_CRYPTO_SEQIV is not set | ||
| 1186 | |||
| 1187 | # | ||
| 1188 | # Block modes | ||
| 1189 | # | ||
| 1190 | # CONFIG_CRYPTO_CBC is not set | ||
| 1191 | # CONFIG_CRYPTO_CTR is not set | ||
| 1192 | # CONFIG_CRYPTO_CTS is not set | ||
| 1193 | # CONFIG_CRYPTO_ECB is not set | ||
| 1194 | # CONFIG_CRYPTO_LRW is not set | ||
| 1195 | # CONFIG_CRYPTO_PCBC is not set | ||
| 1196 | # CONFIG_CRYPTO_XTS is not set | ||
| 1197 | |||
| 1198 | # | ||
| 1199 | # Hash modes | ||
| 1200 | # | ||
| 1201 | # CONFIG_CRYPTO_HMAC is not set | ||
| 1202 | # CONFIG_CRYPTO_XCBC is not set | ||
| 1203 | |||
| 1204 | # | ||
| 1205 | # Digest | ||
| 1206 | # | ||
| 1207 | # CONFIG_CRYPTO_CRC32C is not set | ||
| 1208 | # CONFIG_CRYPTO_MD4 is not set | ||
| 1209 | # CONFIG_CRYPTO_MD5 is not set | ||
| 1210 | # CONFIG_CRYPTO_MICHAEL_MIC is not set | ||
| 1211 | # CONFIG_CRYPTO_RMD128 is not set | ||
| 1212 | # CONFIG_CRYPTO_RMD160 is not set | ||
| 1213 | # CONFIG_CRYPTO_RMD256 is not set | ||
| 1214 | # CONFIG_CRYPTO_RMD320 is not set | ||
| 1215 | # CONFIG_CRYPTO_SHA1 is not set | ||
| 1216 | # CONFIG_CRYPTO_SHA256 is not set | ||
| 1217 | # CONFIG_CRYPTO_SHA512 is not set | ||
| 1218 | # CONFIG_CRYPTO_TGR192 is not set | ||
| 1219 | # CONFIG_CRYPTO_WP512 is not set | ||
| 1220 | |||
| 1221 | # | ||
| 1222 | # Ciphers | ||
| 1223 | # | ||
| 1224 | # CONFIG_CRYPTO_AES is not set | ||
| 1225 | # CONFIG_CRYPTO_ANUBIS is not set | ||
| 1226 | # CONFIG_CRYPTO_ARC4 is not set | ||
| 1227 | # CONFIG_CRYPTO_BLOWFISH is not set | ||
| 1228 | # CONFIG_CRYPTO_CAMELLIA is not set | ||
| 1229 | # CONFIG_CRYPTO_CAST5 is not set | ||
| 1230 | # CONFIG_CRYPTO_CAST6 is not set | ||
| 1231 | # CONFIG_CRYPTO_DES is not set | ||
| 1232 | # CONFIG_CRYPTO_FCRYPT is not set | ||
| 1233 | # CONFIG_CRYPTO_KHAZAD is not set | ||
| 1234 | # CONFIG_CRYPTO_SALSA20 is not set | ||
| 1235 | # CONFIG_CRYPTO_SEED is not set | ||
| 1236 | # CONFIG_CRYPTO_SERPENT is not set | ||
| 1237 | # CONFIG_CRYPTO_TEA is not set | ||
| 1238 | # CONFIG_CRYPTO_TWOFISH is not set | ||
| 1239 | |||
| 1240 | # | ||
| 1241 | # Compression | ||
| 1242 | # | ||
| 1243 | CONFIG_CRYPTO_DEFLATE=y | ||
| 1244 | # CONFIG_CRYPTO_ZLIB is not set | ||
| 1245 | CONFIG_CRYPTO_LZO=y | ||
| 1246 | |||
| 1247 | # | ||
| 1248 | # Random Number Generation | ||
| 1249 | # | ||
| 1250 | # CONFIG_CRYPTO_ANSI_CPRNG is not set | ||
| 1251 | CONFIG_CRYPTO_HW=y | ||
| 1155 | CONFIG_BINARY_PRINTF=y | 1252 | CONFIG_BINARY_PRINTF=y |
| 1156 | 1253 | ||
| 1157 | # | 1254 | # |
| 1158 | # Library routines | 1255 | # Library routines |
| 1159 | # | 1256 | # |
| 1160 | CONFIG_BITREVERSE=y | 1257 | CONFIG_BITREVERSE=y |
| 1258 | CONFIG_RATIONAL=y | ||
| 1161 | CONFIG_GENERIC_FIND_LAST_BIT=y | 1259 | CONFIG_GENERIC_FIND_LAST_BIT=y |
| 1162 | # CONFIG_CRC_CCITT is not set | 1260 | # CONFIG_CRC_CCITT is not set |
| 1163 | # CONFIG_CRC16 is not set | 1261 | CONFIG_CRC16=y |
| 1164 | # CONFIG_CRC_T10DIF is not set | 1262 | # CONFIG_CRC_T10DIF is not set |
| 1165 | # CONFIG_CRC_ITU_T is not set | 1263 | # CONFIG_CRC_ITU_T is not set |
| 1166 | CONFIG_CRC32=y | 1264 | CONFIG_CRC32=y |
| @@ -1168,6 +1266,8 @@ CONFIG_CRC32=y | |||
| 1168 | # CONFIG_LIBCRC32C is not set | 1266 | # CONFIG_LIBCRC32C is not set |
| 1169 | CONFIG_ZLIB_INFLATE=y | 1267 | CONFIG_ZLIB_INFLATE=y |
| 1170 | CONFIG_ZLIB_DEFLATE=y | 1268 | CONFIG_ZLIB_DEFLATE=y |
| 1269 | CONFIG_LZO_COMPRESS=y | ||
| 1270 | CONFIG_LZO_DECOMPRESS=y | ||
| 1171 | CONFIG_HAS_IOMEM=y | 1271 | CONFIG_HAS_IOMEM=y |
| 1172 | CONFIG_HAS_IOPORT=y | 1272 | CONFIG_HAS_IOPORT=y |
| 1173 | CONFIG_HAS_DMA=y | 1273 | CONFIG_HAS_DMA=y |
diff --git a/arch/arm/configs/mx3_defconfig b/arch/arm/configs/mx3_defconfig index 20ada526f6de..a4f9a2a8149c 100644 --- a/arch/arm/configs/mx3_defconfig +++ b/arch/arm/configs/mx3_defconfig | |||
| @@ -1,15 +1,15 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc1 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed Apr 8 11:06:37 2009 | 4 | # Tue Jul 28 14:11:34 2009 |
| 5 | # | 5 | # |
| 6 | CONFIG_ARM=y | 6 | CONFIG_ARM=y |
| 7 | CONFIG_HAVE_PWM=y | ||
| 7 | CONFIG_SYS_SUPPORTS_APM_EMULATION=y | 8 | CONFIG_SYS_SUPPORTS_APM_EMULATION=y |
| 8 | CONFIG_GENERIC_GPIO=y | 9 | CONFIG_GENERIC_GPIO=y |
| 9 | CONFIG_GENERIC_TIME=y | 10 | CONFIG_GENERIC_TIME=y |
| 10 | CONFIG_GENERIC_CLOCKEVENTS=y | 11 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 11 | CONFIG_MMU=y | 12 | CONFIG_MMU=y |
| 12 | # CONFIG_NO_IOPORT is not set | ||
| 13 | CONFIG_GENERIC_HARDIRQS=y | 13 | CONFIG_GENERIC_HARDIRQS=y |
| 14 | CONFIG_STACKTRACE_SUPPORT=y | 14 | CONFIG_STACKTRACE_SUPPORT=y |
| 15 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 15 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| @@ -18,14 +18,13 @@ CONFIG_TRACE_IRQFLAGS_SUPPORT=y | |||
| 18 | CONFIG_HARDIRQS_SW_RESEND=y | 18 | CONFIG_HARDIRQS_SW_RESEND=y |
| 19 | CONFIG_GENERIC_IRQ_PROBE=y | 19 | CONFIG_GENERIC_IRQ_PROBE=y |
| 20 | CONFIG_RWSEM_GENERIC_SPINLOCK=y | 20 | CONFIG_RWSEM_GENERIC_SPINLOCK=y |
| 21 | # CONFIG_ARCH_HAS_ILOG2_U32 is not set | ||
| 22 | # CONFIG_ARCH_HAS_ILOG2_U64 is not set | ||
| 23 | CONFIG_GENERIC_HWEIGHT=y | 21 | CONFIG_GENERIC_HWEIGHT=y |
| 24 | CONFIG_GENERIC_CALIBRATE_DELAY=y | 22 | CONFIG_GENERIC_CALIBRATE_DELAY=y |
| 25 | CONFIG_ARCH_MTD_XIP=y | 23 | CONFIG_ARCH_MTD_XIP=y |
| 26 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | 24 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y |
| 27 | CONFIG_VECTORS_BASE=0xffff0000 | 25 | CONFIG_VECTORS_BASE=0xffff0000 |
| 28 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 26 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 27 | CONFIG_CONSTRUCTORS=y | ||
| 29 | 28 | ||
| 30 | # | 29 | # |
| 31 | # General setup | 30 | # General setup |
| @@ -86,7 +85,12 @@ CONFIG_TIMERFD=y | |||
| 86 | CONFIG_EVENTFD=y | 85 | CONFIG_EVENTFD=y |
| 87 | CONFIG_SHMEM=y | 86 | CONFIG_SHMEM=y |
| 88 | CONFIG_AIO=y | 87 | CONFIG_AIO=y |
| 88 | |||
| 89 | # | ||
| 90 | # Performance Counters | ||
| 91 | # | ||
| 89 | CONFIG_VM_EVENT_COUNTERS=y | 92 | CONFIG_VM_EVENT_COUNTERS=y |
| 93 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 90 | CONFIG_COMPAT_BRK=y | 94 | CONFIG_COMPAT_BRK=y |
| 91 | CONFIG_SLAB=y | 95 | CONFIG_SLAB=y |
| 92 | # CONFIG_SLUB is not set | 96 | # CONFIG_SLUB is not set |
| @@ -97,6 +101,11 @@ CONFIG_HAVE_OPROFILE=y | |||
| 97 | # CONFIG_KPROBES is not set | 101 | # CONFIG_KPROBES is not set |
| 98 | CONFIG_HAVE_KPROBES=y | 102 | CONFIG_HAVE_KPROBES=y |
| 99 | CONFIG_HAVE_KRETPROBES=y | 103 | CONFIG_HAVE_KRETPROBES=y |
| 104 | CONFIG_HAVE_CLK=y | ||
| 105 | |||
| 106 | # | ||
| 107 | # GCOV-based kernel profiling | ||
| 108 | # | ||
| 100 | # CONFIG_SLOW_WORK is not set | 109 | # CONFIG_SLOW_WORK is not set |
| 101 | CONFIG_HAVE_GENERIC_DMA_COHERENT=y | 110 | CONFIG_HAVE_GENERIC_DMA_COHERENT=y |
| 102 | CONFIG_SLABINFO=y | 111 | CONFIG_SLABINFO=y |
| @@ -109,7 +118,7 @@ CONFIG_MODULE_FORCE_UNLOAD=y | |||
| 109 | CONFIG_MODVERSIONS=y | 118 | CONFIG_MODVERSIONS=y |
| 110 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 119 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 111 | CONFIG_BLOCK=y | 120 | CONFIG_BLOCK=y |
| 112 | # CONFIG_LBD is not set | 121 | CONFIG_LBDAF=y |
| 113 | # CONFIG_BLK_DEV_BSG is not set | 122 | # CONFIG_BLK_DEV_BSG is not set |
| 114 | # CONFIG_BLK_DEV_INTEGRITY is not set | 123 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 115 | 124 | ||
| @@ -136,13 +145,14 @@ CONFIG_FREEZER=y | |||
| 136 | # CONFIG_ARCH_VERSATILE is not set | 145 | # CONFIG_ARCH_VERSATILE is not set |
| 137 | # CONFIG_ARCH_AT91 is not set | 146 | # CONFIG_ARCH_AT91 is not set |
| 138 | # CONFIG_ARCH_CLPS711X is not set | 147 | # CONFIG_ARCH_CLPS711X is not set |
| 148 | # CONFIG_ARCH_GEMINI is not set | ||
| 139 | # CONFIG_ARCH_EBSA110 is not set | 149 | # CONFIG_ARCH_EBSA110 is not set |
| 140 | # CONFIG_ARCH_EP93XX is not set | 150 | # CONFIG_ARCH_EP93XX is not set |
| 141 | # CONFIG_ARCH_GEMINI is not set | ||
| 142 | # CONFIG_ARCH_FOOTBRIDGE is not set | 151 | # CONFIG_ARCH_FOOTBRIDGE is not set |
| 152 | CONFIG_ARCH_MXC=y | ||
| 153 | # CONFIG_ARCH_STMP3XXX is not set | ||
| 143 | # CONFIG_ARCH_NETX is not set | 154 | # CONFIG_ARCH_NETX is not set |
| 144 | # CONFIG_ARCH_H720X is not set | 155 | # CONFIG_ARCH_H720X is not set |
| 145 | # CONFIG_ARCH_IMX is not set | ||
| 146 | # CONFIG_ARCH_IOP13XX is not set | 156 | # CONFIG_ARCH_IOP13XX is not set |
| 147 | # CONFIG_ARCH_IOP32X is not set | 157 | # CONFIG_ARCH_IOP32X is not set |
| 148 | # CONFIG_ARCH_IOP33X is not set | 158 | # CONFIG_ARCH_IOP33X is not set |
| @@ -151,25 +161,25 @@ CONFIG_FREEZER=y | |||
| 151 | # CONFIG_ARCH_IXP4XX is not set | 161 | # CONFIG_ARCH_IXP4XX is not set |
| 152 | # CONFIG_ARCH_L7200 is not set | 162 | # CONFIG_ARCH_L7200 is not set |
| 153 | # CONFIG_ARCH_KIRKWOOD is not set | 163 | # CONFIG_ARCH_KIRKWOOD is not set |
| 154 | # CONFIG_ARCH_KS8695 is not set | ||
| 155 | # CONFIG_ARCH_NS9XXX is not set | ||
| 156 | # CONFIG_ARCH_LOKI is not set | 164 | # CONFIG_ARCH_LOKI is not set |
| 157 | # CONFIG_ARCH_MV78XX0 is not set | 165 | # CONFIG_ARCH_MV78XX0 is not set |
| 158 | CONFIG_ARCH_MXC=y | ||
| 159 | # CONFIG_ARCH_ORION5X is not set | 166 | # CONFIG_ARCH_ORION5X is not set |
| 167 | # CONFIG_ARCH_MMP is not set | ||
| 168 | # CONFIG_ARCH_KS8695 is not set | ||
| 169 | # CONFIG_ARCH_NS9XXX is not set | ||
| 170 | # CONFIG_ARCH_W90X900 is not set | ||
| 160 | # CONFIG_ARCH_PNX4008 is not set | 171 | # CONFIG_ARCH_PNX4008 is not set |
| 161 | # CONFIG_ARCH_PXA is not set | 172 | # CONFIG_ARCH_PXA is not set |
| 162 | # CONFIG_ARCH_MMP is not set | 173 | # CONFIG_ARCH_MSM is not set |
| 163 | # CONFIG_ARCH_RPC is not set | 174 | # CONFIG_ARCH_RPC is not set |
| 164 | # CONFIG_ARCH_SA1100 is not set | 175 | # CONFIG_ARCH_SA1100 is not set |
| 165 | # CONFIG_ARCH_S3C2410 is not set | 176 | # CONFIG_ARCH_S3C2410 is not set |
| 166 | # CONFIG_ARCH_S3C64XX is not set | 177 | # CONFIG_ARCH_S3C64XX is not set |
| 167 | # CONFIG_ARCH_SHARK is not set | 178 | # CONFIG_ARCH_SHARK is not set |
| 168 | # CONFIG_ARCH_LH7A40X is not set | 179 | # CONFIG_ARCH_LH7A40X is not set |
| 180 | # CONFIG_ARCH_U300 is not set | ||
| 169 | # CONFIG_ARCH_DAVINCI is not set | 181 | # CONFIG_ARCH_DAVINCI is not set |
| 170 | # CONFIG_ARCH_OMAP is not set | 182 | # CONFIG_ARCH_OMAP is not set |
| 171 | # CONFIG_ARCH_MSM is not set | ||
| 172 | # CONFIG_ARCH_W90X900 is not set | ||
| 173 | 183 | ||
| 174 | # | 184 | # |
| 175 | # Freescale MXC Implementations | 185 | # Freescale MXC Implementations |
| @@ -178,6 +188,7 @@ CONFIG_ARCH_MXC=y | |||
| 178 | # CONFIG_ARCH_MX2 is not set | 188 | # CONFIG_ARCH_MX2 is not set |
| 179 | CONFIG_ARCH_MX3=y | 189 | CONFIG_ARCH_MX3=y |
| 180 | CONFIG_ARCH_MX31=y | 190 | CONFIG_ARCH_MX31=y |
| 191 | CONFIG_ARCH_MX35=y | ||
| 181 | 192 | ||
| 182 | # | 193 | # |
| 183 | # MX3 platforms: | 194 | # MX3 platforms: |
| @@ -185,12 +196,19 @@ CONFIG_ARCH_MX31=y | |||
| 185 | CONFIG_MACH_MX31ADS=y | 196 | CONFIG_MACH_MX31ADS=y |
| 186 | CONFIG_MACH_MX31ADS_WM1133_EV1=y | 197 | CONFIG_MACH_MX31ADS_WM1133_EV1=y |
| 187 | CONFIG_MACH_PCM037=y | 198 | CONFIG_MACH_PCM037=y |
| 199 | CONFIG_MACH_PCM037_EET=y | ||
| 188 | CONFIG_MACH_MX31LITE=y | 200 | CONFIG_MACH_MX31LITE=y |
| 189 | CONFIG_MACH_MX31_3DS=y | 201 | CONFIG_MACH_MX31_3DS=y |
| 190 | CONFIG_MACH_MX31MOBOARD=y | 202 | CONFIG_MACH_MX31MOBOARD=y |
| 203 | CONFIG_MACH_MX31LILLY=y | ||
| 191 | CONFIG_MACH_QONG=y | 204 | CONFIG_MACH_QONG=y |
| 205 | CONFIG_MACH_PCM043=y | ||
| 206 | CONFIG_MACH_ARMADILLO5X0=y | ||
| 207 | CONFIG_MACH_MX35_3DS=y | ||
| 192 | CONFIG_MXC_IRQ_PRIOR=y | 208 | CONFIG_MXC_IRQ_PRIOR=y |
| 193 | CONFIG_MXC_PWM=y | 209 | CONFIG_MXC_PWM=y |
| 210 | CONFIG_ARCH_HAS_RNGA=y | ||
| 211 | CONFIG_ARCH_MXC_IOMUX_V3=y | ||
| 194 | 212 | ||
| 195 | # | 213 | # |
| 196 | # Processor Type | 214 | # Processor Type |
| @@ -218,6 +236,7 @@ CONFIG_ARM_THUMB=y | |||
| 218 | # CONFIG_CPU_BPREDICT_DISABLE is not set | 236 | # CONFIG_CPU_BPREDICT_DISABLE is not set |
| 219 | CONFIG_OUTER_CACHE=y | 237 | CONFIG_OUTER_CACHE=y |
| 220 | CONFIG_CACHE_L2X0=y | 238 | CONFIG_CACHE_L2X0=y |
| 239 | # CONFIG_ARM_ERRATA_411920 is not set | ||
| 221 | CONFIG_COMMON_CLKDEV=y | 240 | CONFIG_COMMON_CLKDEV=y |
| 222 | 241 | ||
| 223 | # | 242 | # |
| @@ -242,7 +261,6 @@ CONFIG_PREEMPT=y | |||
| 242 | CONFIG_HZ=100 | 261 | CONFIG_HZ=100 |
| 243 | CONFIG_AEABI=y | 262 | CONFIG_AEABI=y |
| 244 | CONFIG_OABI_COMPAT=y | 263 | CONFIG_OABI_COMPAT=y |
| 245 | CONFIG_ARCH_FLATMEM_HAS_HOLES=y | ||
| 246 | # CONFIG_ARCH_SPARSEMEM_DEFAULT is not set | 264 | # CONFIG_ARCH_SPARSEMEM_DEFAULT is not set |
| 247 | # CONFIG_ARCH_SELECT_MEMORY_MODEL is not set | 265 | # CONFIG_ARCH_SELECT_MEMORY_MODEL is not set |
| 248 | # CONFIG_HIGHMEM is not set | 266 | # CONFIG_HIGHMEM is not set |
| @@ -257,10 +275,11 @@ CONFIG_SPLIT_PTLOCK_CPUS=4 | |||
| 257 | # CONFIG_PHYS_ADDR_T_64BIT is not set | 275 | # CONFIG_PHYS_ADDR_T_64BIT is not set |
| 258 | CONFIG_ZONE_DMA_FLAG=0 | 276 | CONFIG_ZONE_DMA_FLAG=0 |
| 259 | CONFIG_VIRT_TO_BUS=y | 277 | CONFIG_VIRT_TO_BUS=y |
| 260 | CONFIG_UNEVICTABLE_LRU=y | ||
| 261 | CONFIG_HAVE_MLOCK=y | 278 | CONFIG_HAVE_MLOCK=y |
| 262 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 279 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 280 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 263 | CONFIG_ALIGNMENT_TRAP=y | 281 | CONFIG_ALIGNMENT_TRAP=y |
| 282 | # CONFIG_UACCESS_WITH_MEMCPY is not set | ||
| 264 | 283 | ||
| 265 | # | 284 | # |
| 266 | # Boot options | 285 | # Boot options |
| @@ -362,6 +381,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 362 | # CONFIG_ECONET is not set | 381 | # CONFIG_ECONET is not set |
| 363 | # CONFIG_WAN_ROUTER is not set | 382 | # CONFIG_WAN_ROUTER is not set |
| 364 | # CONFIG_PHONET is not set | 383 | # CONFIG_PHONET is not set |
| 384 | # CONFIG_IEEE802154 is not set | ||
| 365 | # CONFIG_NET_SCHED is not set | 385 | # CONFIG_NET_SCHED is not set |
| 366 | # CONFIG_DCB is not set | 386 | # CONFIG_DCB is not set |
| 367 | 387 | ||
| @@ -465,7 +485,16 @@ CONFIG_MTD_PHYSMAP=y | |||
| 465 | # CONFIG_MTD_DOC2000 is not set | 485 | # CONFIG_MTD_DOC2000 is not set |
| 466 | # CONFIG_MTD_DOC2001 is not set | 486 | # CONFIG_MTD_DOC2001 is not set |
| 467 | # CONFIG_MTD_DOC2001PLUS is not set | 487 | # CONFIG_MTD_DOC2001PLUS is not set |
| 468 | # CONFIG_MTD_NAND is not set | 488 | CONFIG_MTD_NAND=y |
| 489 | # CONFIG_MTD_NAND_VERIFY_WRITE is not set | ||
| 490 | # CONFIG_MTD_NAND_ECC_SMC is not set | ||
| 491 | # CONFIG_MTD_NAND_MUSEUM_IDS is not set | ||
| 492 | # CONFIG_MTD_NAND_GPIO is not set | ||
| 493 | CONFIG_MTD_NAND_IDS=y | ||
| 494 | # CONFIG_MTD_NAND_DISKONCHIP is not set | ||
| 495 | # CONFIG_MTD_NAND_NANDSIM is not set | ||
| 496 | # CONFIG_MTD_NAND_PLATFORM is not set | ||
| 497 | CONFIG_MTD_NAND_MXC=y | ||
| 469 | # CONFIG_MTD_ONENAND is not set | 498 | # CONFIG_MTD_ONENAND is not set |
| 470 | 499 | ||
| 471 | # | 500 | # |
| @@ -476,10 +505,30 @@ CONFIG_MTD_PHYSMAP=y | |||
| 476 | # | 505 | # |
| 477 | # UBI - Unsorted block images | 506 | # UBI - Unsorted block images |
| 478 | # | 507 | # |
| 479 | # CONFIG_MTD_UBI is not set | 508 | CONFIG_MTD_UBI=y |
| 509 | CONFIG_MTD_UBI_WL_THRESHOLD=4096 | ||
| 510 | CONFIG_MTD_UBI_BEB_RESERVE=1 | ||
| 511 | # CONFIG_MTD_UBI_GLUEBI is not set | ||
| 512 | |||
| 513 | # | ||
| 514 | # UBI debugging options | ||
| 515 | # | ||
| 516 | # CONFIG_MTD_UBI_DEBUG is not set | ||
| 480 | # CONFIG_PARPORT is not set | 517 | # CONFIG_PARPORT is not set |
| 481 | # CONFIG_BLK_DEV is not set | 518 | # CONFIG_BLK_DEV is not set |
| 482 | # CONFIG_MISC_DEVICES is not set | 519 | CONFIG_MISC_DEVICES=y |
| 520 | # CONFIG_ICS932S401 is not set | ||
| 521 | # CONFIG_ENCLOSURE_SERVICES is not set | ||
| 522 | # CONFIG_ISL29003 is not set | ||
| 523 | # CONFIG_C2PORT is not set | ||
| 524 | |||
| 525 | # | ||
| 526 | # EEPROM support | ||
| 527 | # | ||
| 528 | CONFIG_EEPROM_AT24=y | ||
| 529 | # CONFIG_EEPROM_LEGACY is not set | ||
| 530 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 531 | # CONFIG_EEPROM_93CX6 is not set | ||
| 483 | CONFIG_HAVE_IDE=y | 532 | CONFIG_HAVE_IDE=y |
| 484 | # CONFIG_IDE is not set | 533 | # CONFIG_IDE is not set |
| 485 | 534 | ||
| @@ -493,7 +542,6 @@ CONFIG_HAVE_IDE=y | |||
| 493 | # CONFIG_ATA is not set | 542 | # CONFIG_ATA is not set |
| 494 | # CONFIG_MD is not set | 543 | # CONFIG_MD is not set |
| 495 | CONFIG_NETDEVICES=y | 544 | CONFIG_NETDEVICES=y |
| 496 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 497 | # CONFIG_DUMMY is not set | 545 | # CONFIG_DUMMY is not set |
| 498 | # CONFIG_BONDING is not set | 546 | # CONFIG_BONDING is not set |
| 499 | # CONFIG_MACVLAN is not set | 547 | # CONFIG_MACVLAN is not set |
| @@ -528,7 +576,7 @@ CONFIG_MII=y | |||
| 528 | # CONFIG_ETHOC is not set | 576 | # CONFIG_ETHOC is not set |
| 529 | # CONFIG_SMC911X is not set | 577 | # CONFIG_SMC911X is not set |
| 530 | CONFIG_SMSC911X=y | 578 | CONFIG_SMSC911X=y |
| 531 | # CONFIG_DNET is not set | 579 | CONFIG_DNET=y |
| 532 | # CONFIG_IBM_NEW_EMAC_ZMII is not set | 580 | # CONFIG_IBM_NEW_EMAC_ZMII is not set |
| 533 | # CONFIG_IBM_NEW_EMAC_RGMII is not set | 581 | # CONFIG_IBM_NEW_EMAC_RGMII is not set |
| 534 | # CONFIG_IBM_NEW_EMAC_TAH is not set | 582 | # CONFIG_IBM_NEW_EMAC_TAH is not set |
| @@ -537,8 +585,10 @@ CONFIG_SMSC911X=y | |||
| 537 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 585 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 538 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 586 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 539 | # CONFIG_B44 is not set | 587 | # CONFIG_B44 is not set |
| 540 | CONFIG_CS89x0=y | 588 | # CONFIG_CS89x0 is not set |
| 541 | CONFIG_CS89x0_NONISA_IRQ=y | 589 | # CONFIG_KS8842 is not set |
| 590 | CONFIG_FEC=y | ||
| 591 | # CONFIG_FEC2 is not set | ||
| 542 | # CONFIG_NETDEV_1000 is not set | 592 | # CONFIG_NETDEV_1000 is not set |
| 543 | # CONFIG_NETDEV_10000 is not set | 593 | # CONFIG_NETDEV_10000 is not set |
| 544 | 594 | ||
| @@ -609,6 +659,7 @@ CONFIG_I2C_HELPER_AUTO=y | |||
| 609 | # | 659 | # |
| 610 | # I2C system bus drivers (mostly embedded / system-on-chip) | 660 | # I2C system bus drivers (mostly embedded / system-on-chip) |
| 611 | # | 661 | # |
| 662 | # CONFIG_I2C_DESIGNWARE is not set | ||
| 612 | # CONFIG_I2C_GPIO is not set | 663 | # CONFIG_I2C_GPIO is not set |
| 613 | CONFIG_I2C_IMX=y | 664 | CONFIG_I2C_IMX=y |
| 614 | # CONFIG_I2C_OCORES is not set | 665 | # CONFIG_I2C_OCORES is not set |
| @@ -633,7 +684,6 @@ CONFIG_I2C_IMX=y | |||
| 633 | # CONFIG_SENSORS_PCF8574 is not set | 684 | # CONFIG_SENSORS_PCF8574 is not set |
| 634 | # CONFIG_PCF8575 is not set | 685 | # CONFIG_PCF8575 is not set |
| 635 | # CONFIG_SENSORS_PCA9539 is not set | 686 | # CONFIG_SENSORS_PCA9539 is not set |
| 636 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 637 | # CONFIG_SENSORS_TSL2550 is not set | 687 | # CONFIG_SENSORS_TSL2550 is not set |
| 638 | # CONFIG_I2C_DEBUG_CORE is not set | 688 | # CONFIG_I2C_DEBUG_CORE is not set |
| 639 | # CONFIG_I2C_DEBUG_ALGO is not set | 689 | # CONFIG_I2C_DEBUG_ALGO is not set |
| @@ -669,6 +719,7 @@ CONFIG_W1=y | |||
| 669 | # | 719 | # |
| 670 | # CONFIG_W1_MASTER_DS2482 is not set | 720 | # CONFIG_W1_MASTER_DS2482 is not set |
| 671 | CONFIG_W1_MASTER_MXC=y | 721 | CONFIG_W1_MASTER_MXC=y |
| 722 | # CONFIG_W1_MASTER_DS1WM is not set | ||
| 672 | # CONFIG_W1_MASTER_GPIO is not set | 723 | # CONFIG_W1_MASTER_GPIO is not set |
| 673 | 724 | ||
| 674 | # | 725 | # |
| @@ -703,6 +754,8 @@ CONFIG_SSB_POSSIBLE=y | |||
| 703 | # CONFIG_TPS65010 is not set | 754 | # CONFIG_TPS65010 is not set |
| 704 | # CONFIG_TWL4030_CORE is not set | 755 | # CONFIG_TWL4030_CORE is not set |
| 705 | # CONFIG_MFD_TMIO is not set | 756 | # CONFIG_MFD_TMIO is not set |
| 757 | # CONFIG_MFD_T7L66XB is not set | ||
| 758 | # CONFIG_MFD_TC6387XB is not set | ||
| 706 | # CONFIG_MFD_TC6393XB is not set | 759 | # CONFIG_MFD_TC6393XB is not set |
| 707 | # CONFIG_PMIC_DA903X is not set | 760 | # CONFIG_PMIC_DA903X is not set |
| 708 | # CONFIG_MFD_WM8400 is not set | 761 | # CONFIG_MFD_WM8400 is not set |
| @@ -711,10 +764,8 @@ CONFIG_MFD_WM8350_CONFIG_MODE_0=y | |||
| 711 | CONFIG_MFD_WM8352_CONFIG_MODE_0=y | 764 | CONFIG_MFD_WM8352_CONFIG_MODE_0=y |
| 712 | CONFIG_MFD_WM8350_I2C=y | 765 | CONFIG_MFD_WM8350_I2C=y |
| 713 | # CONFIG_MFD_PCF50633 is not set | 766 | # CONFIG_MFD_PCF50633 is not set |
| 714 | 767 | # CONFIG_AB3100_CORE is not set | |
| 715 | # | 768 | CONFIG_MEDIA_SUPPORT=y |
| 716 | # Multimedia devices | ||
| 717 | # | ||
| 718 | 769 | ||
| 719 | # | 770 | # |
| 720 | # Multimedia core support | 771 | # Multimedia core support |
| @@ -758,8 +809,10 @@ CONFIG_SOC_CAMERA_MT9T031=y | |||
| 758 | CONFIG_SOC_CAMERA_MT9V022=y | 809 | CONFIG_SOC_CAMERA_MT9V022=y |
| 759 | CONFIG_SOC_CAMERA_TW9910=y | 810 | CONFIG_SOC_CAMERA_TW9910=y |
| 760 | # CONFIG_SOC_CAMERA_PLATFORM is not set | 811 | # CONFIG_SOC_CAMERA_PLATFORM is not set |
| 761 | # CONFIG_SOC_CAMERA_OV772X is not set | 812 | CONFIG_SOC_CAMERA_OV772X=y |
| 813 | CONFIG_MX3_VIDEO=y | ||
| 762 | CONFIG_VIDEO_MX3=y | 814 | CONFIG_VIDEO_MX3=y |
| 815 | # CONFIG_VIDEO_SH_MOBILE_CEU is not set | ||
| 763 | # CONFIG_RADIO_ADAPTERS is not set | 816 | # CONFIG_RADIO_ADAPTERS is not set |
| 764 | # CONFIG_DAB is not set | 817 | # CONFIG_DAB is not set |
| 765 | 818 | ||
| @@ -847,8 +900,11 @@ CONFIG_REGULATOR=y | |||
| 847 | # CONFIG_REGULATOR_DEBUG is not set | 900 | # CONFIG_REGULATOR_DEBUG is not set |
| 848 | # CONFIG_REGULATOR_FIXED_VOLTAGE is not set | 901 | # CONFIG_REGULATOR_FIXED_VOLTAGE is not set |
| 849 | # CONFIG_REGULATOR_VIRTUAL_CONSUMER is not set | 902 | # CONFIG_REGULATOR_VIRTUAL_CONSUMER is not set |
| 903 | # CONFIG_REGULATOR_USERSPACE_CONSUMER is not set | ||
| 850 | # CONFIG_REGULATOR_BQ24022 is not set | 904 | # CONFIG_REGULATOR_BQ24022 is not set |
| 905 | # CONFIG_REGULATOR_MAX1586 is not set | ||
| 851 | CONFIG_REGULATOR_WM8350=y | 906 | CONFIG_REGULATOR_WM8350=y |
| 907 | # CONFIG_REGULATOR_LP3971 is not set | ||
| 852 | # CONFIG_UIO is not set | 908 | # CONFIG_UIO is not set |
| 853 | # CONFIG_STAGING is not set | 909 | # CONFIG_STAGING is not set |
| 854 | 910 | ||
| @@ -861,10 +917,12 @@ CONFIG_REGULATOR_WM8350=y | |||
| 861 | # CONFIG_REISERFS_FS is not set | 917 | # CONFIG_REISERFS_FS is not set |
| 862 | # CONFIG_JFS_FS is not set | 918 | # CONFIG_JFS_FS is not set |
| 863 | # CONFIG_FS_POSIX_ACL is not set | 919 | # CONFIG_FS_POSIX_ACL is not set |
| 864 | CONFIG_FILE_LOCKING=y | ||
| 865 | # CONFIG_XFS_FS is not set | 920 | # CONFIG_XFS_FS is not set |
| 921 | # CONFIG_GFS2_FS is not set | ||
| 866 | # CONFIG_OCFS2_FS is not set | 922 | # CONFIG_OCFS2_FS is not set |
| 867 | # CONFIG_BTRFS_FS is not set | 923 | # CONFIG_BTRFS_FS is not set |
| 924 | CONFIG_FILE_LOCKING=y | ||
| 925 | CONFIG_FSNOTIFY=y | ||
| 868 | # CONFIG_DNOTIFY is not set | 926 | # CONFIG_DNOTIFY is not set |
| 869 | CONFIG_INOTIFY=y | 927 | CONFIG_INOTIFY=y |
| 870 | CONFIG_INOTIFY_USER=y | 928 | CONFIG_INOTIFY_USER=y |
| @@ -921,6 +979,12 @@ CONFIG_JFFS2_ZLIB=y | |||
| 921 | # CONFIG_JFFS2_LZO is not set | 979 | # CONFIG_JFFS2_LZO is not set |
| 922 | CONFIG_JFFS2_RTIME=y | 980 | CONFIG_JFFS2_RTIME=y |
| 923 | # CONFIG_JFFS2_RUBIN is not set | 981 | # CONFIG_JFFS2_RUBIN is not set |
| 982 | CONFIG_UBIFS_FS=y | ||
| 983 | # CONFIG_UBIFS_FS_XATTR is not set | ||
| 984 | # CONFIG_UBIFS_FS_ADVANCED_COMPR is not set | ||
| 985 | CONFIG_UBIFS_FS_LZO=y | ||
| 986 | CONFIG_UBIFS_FS_ZLIB=y | ||
| 987 | # CONFIG_UBIFS_FS_DEBUG is not set | ||
| 924 | # CONFIG_CRAMFS is not set | 988 | # CONFIG_CRAMFS is not set |
| 925 | # CONFIG_SQUASHFS is not set | 989 | # CONFIG_SQUASHFS is not set |
| 926 | # CONFIG_VXFS_FS is not set | 990 | # CONFIG_VXFS_FS is not set |
| @@ -937,6 +1001,7 @@ CONFIG_NFS_FS=y | |||
| 937 | CONFIG_NFS_V3=y | 1001 | CONFIG_NFS_V3=y |
| 938 | # CONFIG_NFS_V3_ACL is not set | 1002 | # CONFIG_NFS_V3_ACL is not set |
| 939 | CONFIG_NFS_V4=y | 1003 | CONFIG_NFS_V4=y |
| 1004 | # CONFIG_NFS_V4_1 is not set | ||
| 940 | CONFIG_ROOT_NFS=y | 1005 | CONFIG_ROOT_NFS=y |
| 941 | # CONFIG_NFSD is not set | 1006 | # CONFIG_NFSD is not set |
| 942 | CONFIG_LOCKD=y | 1007 | CONFIG_LOCKD=y |
| @@ -979,22 +1044,7 @@ CONFIG_FRAME_WARN=1024 | |||
| 979 | CONFIG_SYSCTL_SYSCALL_CHECK=y | 1044 | CONFIG_SYSCTL_SYSCALL_CHECK=y |
| 980 | CONFIG_HAVE_FUNCTION_TRACER=y | 1045 | CONFIG_HAVE_FUNCTION_TRACER=y |
| 981 | CONFIG_TRACING_SUPPORT=y | 1046 | CONFIG_TRACING_SUPPORT=y |
| 982 | 1047 | # CONFIG_FTRACE is not set | |
| 983 | # | ||
| 984 | # Tracers | ||
| 985 | # | ||
| 986 | # CONFIG_FUNCTION_TRACER is not set | ||
| 987 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 988 | # CONFIG_PREEMPT_TRACER is not set | ||
| 989 | # CONFIG_SCHED_TRACER is not set | ||
| 990 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 991 | # CONFIG_EVENT_TRACER is not set | ||
| 992 | # CONFIG_BOOT_TRACER is not set | ||
| 993 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 994 | # CONFIG_STACK_TRACER is not set | ||
| 995 | # CONFIG_KMEMTRACE is not set | ||
| 996 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 997 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 998 | # CONFIG_SAMPLES is not set | 1048 | # CONFIG_SAMPLES is not set |
| 999 | CONFIG_HAVE_ARCH_KGDB=y | 1049 | CONFIG_HAVE_ARCH_KGDB=y |
| 1000 | CONFIG_ARM_UNWIND=y | 1050 | CONFIG_ARM_UNWIND=y |
| @@ -1094,9 +1144,9 @@ CONFIG_CRYPTO_DES=y | |||
| 1094 | # | 1144 | # |
| 1095 | # Compression | 1145 | # Compression |
| 1096 | # | 1146 | # |
| 1097 | # CONFIG_CRYPTO_DEFLATE is not set | 1147 | CONFIG_CRYPTO_DEFLATE=y |
| 1098 | # CONFIG_CRYPTO_ZLIB is not set | 1148 | # CONFIG_CRYPTO_ZLIB is not set |
| 1099 | # CONFIG_CRYPTO_LZO is not set | 1149 | CONFIG_CRYPTO_LZO=y |
| 1100 | 1150 | ||
| 1101 | # | 1151 | # |
| 1102 | # Random Number Generation | 1152 | # Random Number Generation |
| @@ -1109,9 +1159,10 @@ CONFIG_CRYPTO_HW=y | |||
| 1109 | # Library routines | 1159 | # Library routines |
| 1110 | # | 1160 | # |
| 1111 | CONFIG_BITREVERSE=y | 1161 | CONFIG_BITREVERSE=y |
| 1162 | CONFIG_RATIONAL=y | ||
| 1112 | CONFIG_GENERIC_FIND_LAST_BIT=y | 1163 | CONFIG_GENERIC_FIND_LAST_BIT=y |
| 1113 | # CONFIG_CRC_CCITT is not set | 1164 | # CONFIG_CRC_CCITT is not set |
| 1114 | # CONFIG_CRC16 is not set | 1165 | CONFIG_CRC16=y |
| 1115 | # CONFIG_CRC_T10DIF is not set | 1166 | # CONFIG_CRC_T10DIF is not set |
| 1116 | # CONFIG_CRC_ITU_T is not set | 1167 | # CONFIG_CRC_ITU_T is not set |
| 1117 | CONFIG_CRC32=y | 1168 | CONFIG_CRC32=y |
| @@ -1119,6 +1170,8 @@ CONFIG_CRC32=y | |||
| 1119 | # CONFIG_LIBCRC32C is not set | 1170 | # CONFIG_LIBCRC32C is not set |
| 1120 | CONFIG_ZLIB_INFLATE=y | 1171 | CONFIG_ZLIB_INFLATE=y |
| 1121 | CONFIG_ZLIB_DEFLATE=y | 1172 | CONFIG_ZLIB_DEFLATE=y |
| 1173 | CONFIG_LZO_COMPRESS=y | ||
| 1174 | CONFIG_LZO_DECOMPRESS=y | ||
| 1122 | CONFIG_HAS_IOMEM=y | 1175 | CONFIG_HAS_IOMEM=y |
| 1123 | CONFIG_HAS_IOPORT=y | 1176 | CONFIG_HAS_IOPORT=y |
| 1124 | CONFIG_HAS_DMA=y | 1177 | CONFIG_HAS_DMA=y |
diff --git a/arch/arm/configs/omap3_evm_defconfig b/arch/arm/configs/omap3_evm_defconfig index 28be17fbc157..d5ff4776cd0a 100644 --- a/arch/arm/configs/omap3_evm_defconfig +++ b/arch/arm/configs/omap3_evm_defconfig | |||
| @@ -1107,7 +1107,7 @@ CONFIG_USB_ZERO=m | |||
| 1107 | CONFIG_USB_OTG_UTILS=y | 1107 | CONFIG_USB_OTG_UTILS=y |
| 1108 | # CONFIG_USB_GPIO_VBUS is not set | 1108 | # CONFIG_USB_GPIO_VBUS is not set |
| 1109 | # CONFIG_ISP1301_OMAP is not set | 1109 | # CONFIG_ISP1301_OMAP is not set |
| 1110 | CONFIG_TWL4030_USB=y | 1110 | # CONFIG_TWL4030_USB is not set |
| 1111 | # CONFIG_NOP_USB_XCEIV is not set | 1111 | # CONFIG_NOP_USB_XCEIV is not set |
| 1112 | CONFIG_MMC=y | 1112 | CONFIG_MMC=y |
| 1113 | # CONFIG_MMC_DEBUG is not set | 1113 | # CONFIG_MMC_DEBUG is not set |
diff --git a/arch/arm/configs/rx51_defconfig b/arch/arm/configs/rx51_defconfig index eb2cb31825c0..f238df66efd4 100644 --- a/arch/arm/configs/rx51_defconfig +++ b/arch/arm/configs/rx51_defconfig | |||
| @@ -282,7 +282,7 @@ CONFIG_ALIGNMENT_TRAP=y | |||
| 282 | # | 282 | # |
| 283 | CONFIG_ZBOOT_ROM_TEXT=0x0 | 283 | CONFIG_ZBOOT_ROM_TEXT=0x0 |
| 284 | CONFIG_ZBOOT_ROM_BSS=0x0 | 284 | CONFIG_ZBOOT_ROM_BSS=0x0 |
| 285 | CONFIG_CMDLINE="init=/sbin/preinit ubi.mtd=rootfs root=ubi0:rootfs rootfstype=ubifs rootflags=bulk_read,no_chk_data_crc rw console=ttyMTD,log console=tty0" | 285 | CONFIG_CMDLINE="init=/sbin/preinit ubi.mtd=rootfs root=ubi0:rootfs rootfstype=ubifs rootflags=bulk_read,no_chk_data_crc rw console=ttyMTD,log console=tty0 console=ttyS2,115200n8" |
| 286 | # CONFIG_XIP_KERNEL is not set | 286 | # CONFIG_XIP_KERNEL is not set |
| 287 | # CONFIG_KEXEC is not set | 287 | # CONFIG_KEXEC is not set |
| 288 | 288 | ||
| @@ -1354,7 +1354,7 @@ CONFIG_USB_OTG_UTILS=y | |||
| 1354 | # CONFIG_USB_GPIO_VBUS is not set | 1354 | # CONFIG_USB_GPIO_VBUS is not set |
| 1355 | # CONFIG_ISP1301_OMAP is not set | 1355 | # CONFIG_ISP1301_OMAP is not set |
| 1356 | CONFIG_TWL4030_USB=y | 1356 | CONFIG_TWL4030_USB=y |
| 1357 | CONFIG_MMC=m | 1357 | CONFIG_MMC=y |
| 1358 | # CONFIG_MMC_DEBUG is not set | 1358 | # CONFIG_MMC_DEBUG is not set |
| 1359 | # CONFIG_MMC_UNSAFE_RESUME is not set | 1359 | # CONFIG_MMC_UNSAFE_RESUME is not set |
| 1360 | 1360 | ||
| @@ -1449,7 +1449,8 @@ CONFIG_RTC_DRV_TWL4030=m | |||
| 1449 | # on-CPU RTC drivers | 1449 | # on-CPU RTC drivers |
| 1450 | # | 1450 | # |
| 1451 | # CONFIG_DMADEVICES is not set | 1451 | # CONFIG_DMADEVICES is not set |
| 1452 | # CONFIG_REGULATOR is not set | 1452 | CONFIG_REGULATOR=y |
| 1453 | CONFIG_REGULATOR_TWL4030=y | ||
| 1453 | # CONFIG_UIO is not set | 1454 | # CONFIG_UIO is not set |
| 1454 | # CONFIG_STAGING is not set | 1455 | # CONFIG_STAGING is not set |
| 1455 | 1456 | ||
diff --git a/arch/arm/include/asm/atomic.h b/arch/arm/include/asm/atomic.h index 9e07fe507029..9ed2377fe8e5 100644 --- a/arch/arm/include/asm/atomic.h +++ b/arch/arm/include/asm/atomic.h | |||
| @@ -159,8 +159,6 @@ static inline void atomic_clear_mask(unsigned long mask, unsigned long *addr) | |||
| 159 | 159 | ||
| 160 | #else /* ARM_ARCH_6 */ | 160 | #else /* ARM_ARCH_6 */ |
| 161 | 161 | ||
| 162 | #include <asm/system.h> | ||
| 163 | |||
| 164 | #ifdef CONFIG_SMP | 162 | #ifdef CONFIG_SMP |
| 165 | #error SMP not supported on pre-ARMv6 CPUs | 163 | #error SMP not supported on pre-ARMv6 CPUs |
| 166 | #endif | 164 | #endif |
diff --git a/arch/arm/include/asm/setup.h b/arch/arm/include/asm/setup.h index ee1304f22f94..5ccce0a9b03c 100644 --- a/arch/arm/include/asm/setup.h +++ b/arch/arm/include/asm/setup.h | |||
| @@ -201,7 +201,8 @@ static struct tagtable __tagtable_##fn __tag = { tag, fn } | |||
| 201 | struct membank { | 201 | struct membank { |
| 202 | unsigned long start; | 202 | unsigned long start; |
| 203 | unsigned long size; | 203 | unsigned long size; |
| 204 | int node; | 204 | unsigned short node; |
| 205 | unsigned short highmem; | ||
| 205 | }; | 206 | }; |
| 206 | 207 | ||
| 207 | struct meminfo { | 208 | struct meminfo { |
diff --git a/arch/arm/include/asm/tlb.h b/arch/arm/include/asm/tlb.h index 321c83e43a1e..f41a6f57cd12 100644 --- a/arch/arm/include/asm/tlb.h +++ b/arch/arm/include/asm/tlb.h | |||
| @@ -102,8 +102,8 @@ tlb_end_vma(struct mmu_gather *tlb, struct vm_area_struct *vma) | |||
| 102 | } | 102 | } |
| 103 | 103 | ||
| 104 | #define tlb_remove_page(tlb,page) free_page_and_swap_cache(page) | 104 | #define tlb_remove_page(tlb,page) free_page_and_swap_cache(page) |
| 105 | #define pte_free_tlb(tlb, ptep) pte_free((tlb)->mm, ptep) | 105 | #define pte_free_tlb(tlb, ptep, addr) pte_free((tlb)->mm, ptep) |
| 106 | #define pmd_free_tlb(tlb, pmdp) pmd_free((tlb)->mm, pmdp) | 106 | #define pmd_free_tlb(tlb, pmdp, addr) pmd_free((tlb)->mm, pmdp) |
| 107 | 107 | ||
| 108 | #define tlb_migrate_finish(mm) do { } while (0) | 108 | #define tlb_migrate_finish(mm) do { } while (0) |
| 109 | 109 | ||
diff --git a/arch/arm/kernel/entry-common.S b/arch/arm/kernel/entry-common.S index 366e5097a41a..8c3de1a350b5 100644 --- a/arch/arm/kernel/entry-common.S +++ b/arch/arm/kernel/entry-common.S | |||
| @@ -148,7 +148,7 @@ trace: | |||
| 148 | sub r0, r0, #MCOUNT_INSN_SIZE | 148 | sub r0, r0, #MCOUNT_INSN_SIZE |
| 149 | mov lr, pc | 149 | mov lr, pc |
| 150 | mov pc, r2 | 150 | mov pc, r2 |
| 151 | mov lr, r1 @ restore lr | 151 | ldr lr, [fp, #-4] @ restore lr |
| 152 | ldmia sp!, {r0-r3, pc} | 152 | ldmia sp!, {r0-r3, pc} |
| 153 | 153 | ||
| 154 | #endif /* CONFIG_DYNAMIC_FTRACE */ | 154 | #endif /* CONFIG_DYNAMIC_FTRACE */ |
diff --git a/arch/arm/kernel/signal.c b/arch/arm/kernel/signal.c index 93bb4247b7ed..f6bc5d442782 100644 --- a/arch/arm/kernel/signal.c +++ b/arch/arm/kernel/signal.c | |||
| @@ -133,7 +133,7 @@ sys_sigaction(int sig, const struct old_sigaction __user *act, | |||
| 133 | } | 133 | } |
| 134 | 134 | ||
| 135 | #ifdef CONFIG_CRUNCH | 135 | #ifdef CONFIG_CRUNCH |
| 136 | static int preserve_crunch_context(struct crunch_sigframe *frame) | 136 | static int preserve_crunch_context(struct crunch_sigframe __user *frame) |
| 137 | { | 137 | { |
| 138 | char kbuf[sizeof(*frame) + 8]; | 138 | char kbuf[sizeof(*frame) + 8]; |
| 139 | struct crunch_sigframe *kframe; | 139 | struct crunch_sigframe *kframe; |
| @@ -146,7 +146,7 @@ static int preserve_crunch_context(struct crunch_sigframe *frame) | |||
| 146 | return __copy_to_user(frame, kframe, sizeof(*frame)); | 146 | return __copy_to_user(frame, kframe, sizeof(*frame)); |
| 147 | } | 147 | } |
| 148 | 148 | ||
| 149 | static int restore_crunch_context(struct crunch_sigframe *frame) | 149 | static int restore_crunch_context(struct crunch_sigframe __user *frame) |
| 150 | { | 150 | { |
| 151 | char kbuf[sizeof(*frame) + 8]; | 151 | char kbuf[sizeof(*frame) + 8]; |
| 152 | struct crunch_sigframe *kframe; | 152 | struct crunch_sigframe *kframe; |
diff --git a/arch/arm/mach-at91/include/mach/at_hdmac.h b/arch/arm/mach-at91/include/mach/at_hdmac.h new file mode 100644 index 000000000000..187cb58345c0 --- /dev/null +++ b/arch/arm/mach-at91/include/mach/at_hdmac.h | |||
| @@ -0,0 +1,102 @@ | |||
| 1 | /* | ||
| 2 | * Header file for the Atmel AHB DMA Controller driver | ||
| 3 | * | ||
| 4 | * Copyright (C) 2008 Atmel Corporation | ||
| 5 | * | ||
| 6 | * This program is free software; you can redistribute it and/or modify | ||
| 7 | * it under the terms of the GNU General Public License as published by | ||
| 8 | * the Free Software Foundation; either version 2 of the License, or | ||
| 9 | * (at your option) any later version. | ||
| 10 | */ | ||
| 11 | #ifndef AT_HDMAC_H | ||
| 12 | #define AT_HDMAC_H | ||
| 13 | |||
| 14 | #include <linux/dmaengine.h> | ||
| 15 | |||
| 16 | /** | ||
| 17 | * struct at_dma_platform_data - Controller configuration parameters | ||
| 18 | * @nr_channels: Number of channels supported by hardware (max 8) | ||
| 19 | * @cap_mask: dma_capability flags supported by the platform | ||
| 20 | */ | ||
| 21 | struct at_dma_platform_data { | ||
| 22 | unsigned int nr_channels; | ||
| 23 | dma_cap_mask_t cap_mask; | ||
| 24 | }; | ||
| 25 | |||
| 26 | /** | ||
| 27 | * enum at_dma_slave_width - DMA slave register access width. | ||
| 28 | * @AT_DMA_SLAVE_WIDTH_8BIT: Do 8-bit slave register accesses | ||
| 29 | * @AT_DMA_SLAVE_WIDTH_16BIT: Do 16-bit slave register accesses | ||
| 30 | * @AT_DMA_SLAVE_WIDTH_32BIT: Do 32-bit slave register accesses | ||
| 31 | */ | ||
| 32 | enum at_dma_slave_width { | ||
| 33 | AT_DMA_SLAVE_WIDTH_8BIT = 0, | ||
| 34 | AT_DMA_SLAVE_WIDTH_16BIT, | ||
| 35 | AT_DMA_SLAVE_WIDTH_32BIT, | ||
| 36 | }; | ||
| 37 | |||
| 38 | /** | ||
| 39 | * struct at_dma_slave - Controller-specific information about a slave | ||
| 40 | * @dma_dev: required DMA master device | ||
| 41 | * @tx_reg: physical address of data register used for | ||
| 42 | * memory-to-peripheral transfers | ||
| 43 | * @rx_reg: physical address of data register used for | ||
| 44 | * peripheral-to-memory transfers | ||
| 45 | * @reg_width: peripheral register width | ||
| 46 | * @cfg: Platform-specific initializer for the CFG register | ||
| 47 | * @ctrla: Platform-specific initializer for the CTRLA register | ||
| 48 | */ | ||
| 49 | struct at_dma_slave { | ||
| 50 | struct device *dma_dev; | ||
| 51 | dma_addr_t tx_reg; | ||
| 52 | dma_addr_t rx_reg; | ||
| 53 | enum at_dma_slave_width reg_width; | ||
| 54 | u32 cfg; | ||
| 55 | u32 ctrla; | ||
| 56 | }; | ||
| 57 | |||
| 58 | |||
| 59 | /* Platform-configurable bits in CFG */ | ||
| 60 | #define ATC_SRC_PER(h) (0xFU & (h)) /* Channel src rq associated with periph handshaking ifc h */ | ||
| 61 | #define ATC_DST_PER(h) ((0xFU & (h)) << 4) /* Channel dst rq associated with periph handshaking ifc h */ | ||
| 62 | #define ATC_SRC_REP (0x1 << 8) /* Source Replay Mod */ | ||
| 63 | #define ATC_SRC_H2SEL (0x1 << 9) /* Source Handshaking Mod */ | ||
| 64 | #define ATC_SRC_H2SEL_SW (0x0 << 9) | ||
| 65 | #define ATC_SRC_H2SEL_HW (0x1 << 9) | ||
| 66 | #define ATC_DST_REP (0x1 << 12) /* Destination Replay Mod */ | ||
| 67 | #define ATC_DST_H2SEL (0x1 << 13) /* Destination Handshaking Mod */ | ||
| 68 | #define ATC_DST_H2SEL_SW (0x0 << 13) | ||
| 69 | #define ATC_DST_H2SEL_HW (0x1 << 13) | ||
| 70 | #define ATC_SOD (0x1 << 16) /* Stop On Done */ | ||
| 71 | #define ATC_LOCK_IF (0x1 << 20) /* Interface Lock */ | ||
| 72 | #define ATC_LOCK_B (0x1 << 21) /* AHB Bus Lock */ | ||
| 73 | #define ATC_LOCK_IF_L (0x1 << 22) /* Master Interface Arbiter Lock */ | ||
| 74 | #define ATC_LOCK_IF_L_CHUNK (0x0 << 22) | ||
| 75 | #define ATC_LOCK_IF_L_BUFFER (0x1 << 22) | ||
| 76 | #define ATC_AHB_PROT_MASK (0x7 << 24) /* AHB Protection */ | ||
| 77 | #define ATC_FIFOCFG_MASK (0x3 << 28) /* FIFO Request Configuration */ | ||
| 78 | #define ATC_FIFOCFG_LARGESTBURST (0x0 << 28) | ||
| 79 | #define ATC_FIFOCFG_HALFFIFO (0x1 << 28) | ||
| 80 | #define ATC_FIFOCFG_ENOUGHSPACE (0x2 << 28) | ||
| 81 | |||
| 82 | /* Platform-configurable bits in CTRLA */ | ||
| 83 | #define ATC_SCSIZE_MASK (0x7 << 16) /* Source Chunk Transfer Size */ | ||
| 84 | #define ATC_SCSIZE_1 (0x0 << 16) | ||
| 85 | #define ATC_SCSIZE_4 (0x1 << 16) | ||
| 86 | #define ATC_SCSIZE_8 (0x2 << 16) | ||
| 87 | #define ATC_SCSIZE_16 (0x3 << 16) | ||
| 88 | #define ATC_SCSIZE_32 (0x4 << 16) | ||
| 89 | #define ATC_SCSIZE_64 (0x5 << 16) | ||
| 90 | #define ATC_SCSIZE_128 (0x6 << 16) | ||
| 91 | #define ATC_SCSIZE_256 (0x7 << 16) | ||
| 92 | #define ATC_DCSIZE_MASK (0x7 << 20) /* Destination Chunk Transfer Size */ | ||
| 93 | #define ATC_DCSIZE_1 (0x0 << 20) | ||
| 94 | #define ATC_DCSIZE_4 (0x1 << 20) | ||
| 95 | #define ATC_DCSIZE_8 (0x2 << 20) | ||
| 96 | #define ATC_DCSIZE_16 (0x3 << 20) | ||
| 97 | #define ATC_DCSIZE_32 (0x4 << 20) | ||
| 98 | #define ATC_DCSIZE_64 (0x5 << 20) | ||
| 99 | #define ATC_DCSIZE_128 (0x6 << 20) | ||
| 100 | #define ATC_DCSIZE_256 (0x7 << 20) | ||
| 101 | |||
| 102 | #endif /* AT_HDMAC_H */ | ||
diff --git a/arch/arm/mach-davinci/board-dm355-evm.c b/arch/arm/mach-davinci/board-dm355-evm.c index 5ac2f565d860..d6ab64ccd496 100644 --- a/arch/arm/mach-davinci/board-dm355-evm.c +++ b/arch/arm/mach-davinci/board-dm355-evm.c | |||
| @@ -37,7 +37,6 @@ | |||
| 37 | #include <mach/serial.h> | 37 | #include <mach/serial.h> |
| 38 | #include <mach/nand.h> | 38 | #include <mach/nand.h> |
| 39 | #include <mach/mmc.h> | 39 | #include <mach/mmc.h> |
| 40 | #include <mach/common.h> | ||
| 41 | 40 | ||
| 42 | #define DAVINCI_ASYNC_EMIF_CONTROL_BASE 0x01e10000 | 41 | #define DAVINCI_ASYNC_EMIF_CONTROL_BASE 0x01e10000 |
| 43 | #define DAVINCI_ASYNC_EMIF_DATA_CE0_BASE 0x02000000 | 42 | #define DAVINCI_ASYNC_EMIF_DATA_CE0_BASE 0x02000000 |
diff --git a/arch/arm/mach-davinci/board-dm355-leopard.c b/arch/arm/mach-davinci/board-dm355-leopard.c index 28c9008df4f4..84ad5d161a87 100644 --- a/arch/arm/mach-davinci/board-dm355-leopard.c +++ b/arch/arm/mach-davinci/board-dm355-leopard.c | |||
| @@ -36,7 +36,6 @@ | |||
| 36 | #include <mach/serial.h> | 36 | #include <mach/serial.h> |
| 37 | #include <mach/nand.h> | 37 | #include <mach/nand.h> |
| 38 | #include <mach/mmc.h> | 38 | #include <mach/mmc.h> |
| 39 | #include <mach/common.h> | ||
| 40 | 39 | ||
| 41 | #define DAVINCI_ASYNC_EMIF_CONTROL_BASE 0x01e10000 | 40 | #define DAVINCI_ASYNC_EMIF_CONTROL_BASE 0x01e10000 |
| 42 | #define DAVINCI_ASYNC_EMIF_DATA_CE0_BASE 0x02000000 | 41 | #define DAVINCI_ASYNC_EMIF_DATA_CE0_BASE 0x02000000 |
diff --git a/arch/arm/mach-davinci/board-dm644x-evm.c b/arch/arm/mach-davinci/board-dm644x-evm.c index d9d40450bdc5..56c8cd01de9a 100644 --- a/arch/arm/mach-davinci/board-dm644x-evm.c +++ b/arch/arm/mach-davinci/board-dm644x-evm.c | |||
| @@ -45,7 +45,6 @@ | |||
| 45 | #include <mach/nand.h> | 45 | #include <mach/nand.h> |
| 46 | #include <mach/mmc.h> | 46 | #include <mach/mmc.h> |
| 47 | #include <mach/emac.h> | 47 | #include <mach/emac.h> |
| 48 | #include <mach/common.h> | ||
| 49 | 48 | ||
| 50 | #define DM644X_EVM_PHY_MASK (0x2) | 49 | #define DM644X_EVM_PHY_MASK (0x2) |
| 51 | #define DM644X_EVM_MDIO_FREQUENCY (2200000) /* PHY bus frequency */ | 50 | #define DM644X_EVM_MDIO_FREQUENCY (2200000) /* PHY bus frequency */ |
diff --git a/arch/arm/mach-davinci/board-dm646x-evm.c b/arch/arm/mach-davinci/board-dm646x-evm.c index e17de6352624..8657e72debc1 100644 --- a/arch/arm/mach-davinci/board-dm646x-evm.c +++ b/arch/arm/mach-davinci/board-dm646x-evm.c | |||
| @@ -47,7 +47,6 @@ | |||
| 47 | #include <mach/i2c.h> | 47 | #include <mach/i2c.h> |
| 48 | #include <mach/mmc.h> | 48 | #include <mach/mmc.h> |
| 49 | #include <mach/emac.h> | 49 | #include <mach/emac.h> |
| 50 | #include <mach/common.h> | ||
| 51 | 50 | ||
| 52 | #define DM646X_EVM_PHY_MASK (0x2) | 51 | #define DM646X_EVM_PHY_MASK (0x2) |
| 53 | #define DM646X_EVM_MDIO_FREQUENCY (2200000) /* PHY bus frequency */ | 52 | #define DM646X_EVM_MDIO_FREQUENCY (2200000) /* PHY bus frequency */ |
diff --git a/arch/arm/mach-davinci/board-sffsdr.c b/arch/arm/mach-davinci/board-sffsdr.c index 748a8e48541e..7acdfd8ac071 100644 --- a/arch/arm/mach-davinci/board-sffsdr.c +++ b/arch/arm/mach-davinci/board-sffsdr.c | |||
| @@ -52,7 +52,6 @@ | |||
| 52 | #include <mach/serial.h> | 52 | #include <mach/serial.h> |
| 53 | #include <mach/psc.h> | 53 | #include <mach/psc.h> |
| 54 | #include <mach/mux.h> | 54 | #include <mach/mux.h> |
| 55 | #include <mach/common.h> | ||
| 56 | 55 | ||
| 57 | #define SFFSDR_PHY_MASK (0x2) | 56 | #define SFFSDR_PHY_MASK (0x2) |
| 58 | #define SFFSDR_MDIO_FREQUENCY (2200000) /* PHY bus frequency */ | 57 | #define SFFSDR_MDIO_FREQUENCY (2200000) /* PHY bus frequency */ |
diff --git a/arch/arm/mach-ep93xx/include/mach/ts72xx.h b/arch/arm/mach-ep93xx/include/mach/ts72xx.h index 34ddec081c40..411734422c1d 100644 --- a/arch/arm/mach-ep93xx/include/mach/ts72xx.h +++ b/arch/arm/mach-ep93xx/include/mach/ts72xx.h | |||
| @@ -41,9 +41,6 @@ | |||
| 41 | #define TS72XX_OPTIONS2_TS9420_BOOT 0x02 | 41 | #define TS72XX_OPTIONS2_TS9420_BOOT 0x02 |
| 42 | 42 | ||
| 43 | 43 | ||
| 44 | #define TS72XX_NOR_PHYS_BASE 0x60000000 | ||
| 45 | #define TS72XX_NOR2_PHYS_BASE 0x62000000 | ||
| 46 | |||
| 47 | #define TS72XX_NAND1_DATA_PHYS_BASE 0x60000000 | 44 | #define TS72XX_NAND1_DATA_PHYS_BASE 0x60000000 |
| 48 | #define TS72XX_NAND2_DATA_PHYS_BASE 0x70000000 | 45 | #define TS72XX_NAND2_DATA_PHYS_BASE 0x70000000 |
| 49 | #define TS72XX_NAND_DATA_VIRT_BASE 0xfebfc000 | 46 | #define TS72XX_NAND_DATA_VIRT_BASE 0xfebfc000 |
diff --git a/arch/arm/mach-ep93xx/ts72xx.c b/arch/arm/mach-ep93xx/ts72xx.c index 7ee024d34829..aaf1371412af 100644 --- a/arch/arm/mach-ep93xx/ts72xx.c +++ b/arch/arm/mach-ep93xx/ts72xx.c | |||
| @@ -112,13 +112,16 @@ static void __init ts72xx_map_io(void) | |||
| 112 | } | 112 | } |
| 113 | } | 113 | } |
| 114 | 114 | ||
| 115 | /************************************************************************* | ||
| 116 | * NOR flash (TS-7200 only) | ||
| 117 | *************************************************************************/ | ||
| 115 | static struct physmap_flash_data ts72xx_flash_data = { | 118 | static struct physmap_flash_data ts72xx_flash_data = { |
| 116 | .width = 1, | 119 | .width = 2, |
| 117 | }; | 120 | }; |
| 118 | 121 | ||
| 119 | static struct resource ts72xx_flash_resource = { | 122 | static struct resource ts72xx_flash_resource = { |
| 120 | .start = TS72XX_NOR_PHYS_BASE, | 123 | .start = EP93XX_CS6_PHYS_BASE, |
| 121 | .end = TS72XX_NOR_PHYS_BASE + SZ_16M - 1, | 124 | .end = EP93XX_CS6_PHYS_BASE + SZ_16M - 1, |
| 122 | .flags = IORESOURCE_MEM, | 125 | .flags = IORESOURCE_MEM, |
| 123 | }; | 126 | }; |
| 124 | 127 | ||
| @@ -132,6 +135,12 @@ static struct platform_device ts72xx_flash = { | |||
| 132 | .resource = &ts72xx_flash_resource, | 135 | .resource = &ts72xx_flash_resource, |
| 133 | }; | 136 | }; |
| 134 | 137 | ||
| 138 | static void __init ts72xx_register_flash(void) | ||
| 139 | { | ||
| 140 | if (board_is_ts7200()) | ||
| 141 | platform_device_register(&ts72xx_flash); | ||
| 142 | } | ||
| 143 | |||
| 135 | static unsigned char ts72xx_rtc_readbyte(unsigned long addr) | 144 | static unsigned char ts72xx_rtc_readbyte(unsigned long addr) |
| 136 | { | 145 | { |
| 137 | __raw_writeb(addr, TS72XX_RTC_INDEX_VIRT_BASE); | 146 | __raw_writeb(addr, TS72XX_RTC_INDEX_VIRT_BASE); |
| @@ -165,8 +174,7 @@ static struct ep93xx_eth_data ts72xx_eth_data = { | |||
| 165 | static void __init ts72xx_init_machine(void) | 174 | static void __init ts72xx_init_machine(void) |
| 166 | { | 175 | { |
| 167 | ep93xx_init_devices(); | 176 | ep93xx_init_devices(); |
| 168 | if (board_is_ts7200()) | 177 | ts72xx_register_flash(); |
| 169 | platform_device_register(&ts72xx_flash); | ||
| 170 | platform_device_register(&ts72xx_rtc_device); | 178 | platform_device_register(&ts72xx_rtc_device); |
| 171 | 179 | ||
| 172 | ep93xx_register_eth(&ts72xx_eth_data, 1); | 180 | ep93xx_register_eth(&ts72xx_eth_data, 1); |
diff --git a/arch/arm/mach-ixp4xx/include/mach/io.h b/arch/arm/mach-ixp4xx/include/mach/io.h index ce63048d45eb..8a947d42a6f1 100644 --- a/arch/arm/mach-ixp4xx/include/mach/io.h +++ b/arch/arm/mach-ixp4xx/include/mach/io.h | |||
| @@ -17,7 +17,7 @@ | |||
| 17 | 17 | ||
| 18 | #include <mach/hardware.h> | 18 | #include <mach/hardware.h> |
| 19 | 19 | ||
| 20 | #define IO_SPACE_LIMIT 0xffff0000 | 20 | #define IO_SPACE_LIMIT 0x0000ffff |
| 21 | 21 | ||
| 22 | extern int (*ixp4xx_pci_read)(u32 addr, u32 cmd, u32* data); | 22 | extern int (*ixp4xx_pci_read)(u32 addr, u32 cmd, u32* data); |
| 23 | extern int ixp4xx_pci_write(u32 addr, u32 cmd, u32 data); | 23 | extern int ixp4xx_pci_write(u32 addr, u32 cmd, u32 data); |
diff --git a/arch/arm/mach-kirkwood/ts219-setup.c b/arch/arm/mach-kirkwood/ts219-setup.c index 01aa213c0a6f..ec1a64f263d2 100644 --- a/arch/arm/mach-kirkwood/ts219-setup.c +++ b/arch/arm/mach-kirkwood/ts219-setup.c | |||
| @@ -206,6 +206,15 @@ static void __init qnap_ts219_init(void) | |||
| 206 | 206 | ||
| 207 | } | 207 | } |
| 208 | 208 | ||
| 209 | static int __init ts219_pci_init(void) | ||
| 210 | { | ||
| 211 | if (machine_is_ts219()) | ||
| 212 | kirkwood_pcie_init(); | ||
| 213 | |||
| 214 | return 0; | ||
| 215 | } | ||
| 216 | subsys_initcall(ts219_pci_init); | ||
| 217 | |||
| 209 | MACHINE_START(TS219, "QNAP TS-119/TS-219") | 218 | MACHINE_START(TS219, "QNAP TS-119/TS-219") |
| 210 | /* Maintainer: Martin Michlmayr <tbm@cyrius.com> */ | 219 | /* Maintainer: Martin Michlmayr <tbm@cyrius.com> */ |
| 211 | .phys_io = KIRKWOOD_REGS_PHYS_BASE, | 220 | .phys_io = KIRKWOOD_REGS_PHYS_BASE, |
diff --git a/arch/arm/mach-ks8695/include/mach/hardware.h b/arch/arm/mach-ks8695/include/mach/hardware.h index 1d640d075b7e..e0f911d9e021 100644 --- a/arch/arm/mach-ks8695/include/mach/hardware.h +++ b/arch/arm/mach-ks8695/include/mach/hardware.h | |||
| @@ -17,6 +17,11 @@ | |||
| 17 | #include <asm/sizes.h> | 17 | #include <asm/sizes.h> |
| 18 | 18 | ||
| 19 | /* | 19 | /* |
| 20 | * Clocks are derived from MCLK, which is 25Mhz | ||
| 21 | */ | ||
| 22 | #define KS8695_CLOCK_RATE 25000000 | ||
| 23 | |||
| 24 | /* | ||
| 20 | * Physical RAM address. | 25 | * Physical RAM address. |
| 21 | */ | 26 | */ |
| 22 | #define KS8695_SDRAM_PA 0x00000000 | 27 | #define KS8695_SDRAM_PA 0x00000000 |
diff --git a/arch/arm/mach-ks8695/include/mach/timex.h b/arch/arm/mach-ks8695/include/mach/timex.h index 4682e350369b..10f716371bd3 100644 --- a/arch/arm/mach-ks8695/include/mach/timex.h +++ b/arch/arm/mach-ks8695/include/mach/timex.h | |||
| @@ -14,7 +14,8 @@ | |||
| 14 | #ifndef __ASM_ARCH_TIMEX_H | 14 | #ifndef __ASM_ARCH_TIMEX_H |
| 15 | #define __ASM_ARCH_TIMEX_H | 15 | #define __ASM_ARCH_TIMEX_H |
| 16 | 16 | ||
| 17 | /* timers are derived from MCLK, which is 25MHz */ | 17 | #include <mach/hardware.h> |
| 18 | #define CLOCK_TICK_RATE 25000000 | 18 | |
| 19 | #define CLOCK_TICK_RATE KS8695_CLOCK_RATE | ||
| 19 | 20 | ||
| 20 | #endif | 21 | #endif |
diff --git a/arch/arm/mach-ks8695/pci.c b/arch/arm/mach-ks8695/pci.c index f5ebcc0fcab9..78499667eb7b 100644 --- a/arch/arm/mach-ks8695/pci.c +++ b/arch/arm/mach-ks8695/pci.c | |||
| @@ -245,6 +245,9 @@ static int ks8695_pci_fault(unsigned long addr, unsigned int fsr, struct pt_regs | |||
| 245 | 245 | ||
| 246 | static void __init ks8695_pci_preinit(void) | 246 | static void __init ks8695_pci_preinit(void) |
| 247 | { | 247 | { |
| 248 | /* make software reset to avoid freeze if PCI bus was messed up */ | ||
| 249 | __raw_writel(0x80000000, KS8695_PCI_VA + KS8695_PBCS); | ||
| 250 | |||
| 248 | /* stage 1 initialization, subid, subdevice = 0x0001 */ | 251 | /* stage 1 initialization, subid, subdevice = 0x0001 */ |
| 249 | __raw_writel(0x00010001, KS8695_PCI_VA + KS8695_CRCSID); | 252 | __raw_writel(0x00010001, KS8695_PCI_VA + KS8695_CRCSID); |
| 250 | 253 | ||
diff --git a/arch/arm/mach-mx3/mx31moboard-devboard.c b/arch/arm/mach-mx3/mx31moboard-devboard.c index 4704405165a1..b48581e7dedd 100644 --- a/arch/arm/mach-mx3/mx31moboard-devboard.c +++ b/arch/arm/mach-mx3/mx31moboard-devboard.c | |||
| @@ -63,7 +63,7 @@ static struct imxuart_platform_data uart_pdata = { | |||
| 63 | 63 | ||
| 64 | static int devboard_sdhc2_get_ro(struct device *dev) | 64 | static int devboard_sdhc2_get_ro(struct device *dev) |
| 65 | { | 65 | { |
| 66 | return gpio_get_value(SDHC2_WP); | 66 | return !gpio_get_value(SDHC2_WP); |
| 67 | } | 67 | } |
| 68 | 68 | ||
| 69 | static int devboard_sdhc2_init(struct device *dev, irq_handler_t detect_irq, | 69 | static int devboard_sdhc2_init(struct device *dev, irq_handler_t detect_irq, |
diff --git a/arch/arm/mach-mx3/mx31moboard-marxbot.c b/arch/arm/mach-mx3/mx31moboard-marxbot.c index 641c3d6153ae..901fb0166c0e 100644 --- a/arch/arm/mach-mx3/mx31moboard-marxbot.c +++ b/arch/arm/mach-mx3/mx31moboard-marxbot.c | |||
| @@ -67,7 +67,7 @@ static unsigned int marxbot_pins[] = { | |||
| 67 | 67 | ||
| 68 | static int marxbot_sdhc2_get_ro(struct device *dev) | 68 | static int marxbot_sdhc2_get_ro(struct device *dev) |
| 69 | { | 69 | { |
| 70 | return gpio_get_value(SDHC2_WP); | 70 | return !gpio_get_value(SDHC2_WP); |
| 71 | } | 71 | } |
| 72 | 72 | ||
| 73 | static int marxbot_sdhc2_init(struct device *dev, irq_handler_t detect_irq, | 73 | static int marxbot_sdhc2_init(struct device *dev, irq_handler_t detect_irq, |
diff --git a/arch/arm/mach-mx3/mx31moboard.c b/arch/arm/mach-mx3/mx31moboard.c index a17f2e411609..2a2da4739ecf 100644 --- a/arch/arm/mach-mx3/mx31moboard.c +++ b/arch/arm/mach-mx3/mx31moboard.c | |||
| @@ -94,7 +94,7 @@ static struct imxi2c_platform_data moboard_i2c1_pdata = { | |||
| 94 | 94 | ||
| 95 | static int moboard_sdhc1_get_ro(struct device *dev) | 95 | static int moboard_sdhc1_get_ro(struct device *dev) |
| 96 | { | 96 | { |
| 97 | return gpio_get_value(SDHC1_WP); | 97 | return !gpio_get_value(SDHC1_WP); |
| 98 | } | 98 | } |
| 99 | 99 | ||
| 100 | static int moboard_sdhc1_init(struct device *dev, irq_handler_t detect_irq, | 100 | static int moboard_sdhc1_init(struct device *dev, irq_handler_t detect_irq, |
diff --git a/arch/arm/mach-mx3/pcm037_eet.c b/arch/arm/mach-mx3/pcm037_eet.c index fe52fb1bb8b7..8d386000fc40 100644 --- a/arch/arm/mach-mx3/pcm037_eet.c +++ b/arch/arm/mach-mx3/pcm037_eet.c | |||
| @@ -24,15 +24,6 @@ | |||
| 24 | #include "devices.h" | 24 | #include "devices.h" |
| 25 | 25 | ||
| 26 | static unsigned int pcm037_eet_pins[] = { | 26 | static unsigned int pcm037_eet_pins[] = { |
| 27 | /* SPI #1 */ | ||
| 28 | MX31_PIN_CSPI1_MISO__MISO, | ||
| 29 | MX31_PIN_CSPI1_MOSI__MOSI, | ||
| 30 | MX31_PIN_CSPI1_SCLK__SCLK, | ||
| 31 | MX31_PIN_CSPI1_SPI_RDY__SPI_RDY, | ||
| 32 | MX31_PIN_CSPI1_SS0__SS0, | ||
| 33 | MX31_PIN_CSPI1_SS1__SS1, | ||
| 34 | MX31_PIN_CSPI1_SS2__SS2, | ||
| 35 | |||
| 36 | /* Reserve and hardwire GPIO 57 high - S6E63D6 chipselect */ | 27 | /* Reserve and hardwire GPIO 57 high - S6E63D6 chipselect */ |
| 37 | IOMUX_MODE(MX31_PIN_KEY_COL7, IOMUX_CONFIG_GPIO), | 28 | IOMUX_MODE(MX31_PIN_KEY_COL7, IOMUX_CONFIG_GPIO), |
| 38 | /* GPIO keys */ | 29 | /* GPIO keys */ |
diff --git a/arch/arm/mach-omap1/mcbsp.c b/arch/arm/mach-omap1/mcbsp.c index a2d7814896be..505d98cfe508 100644 --- a/arch/arm/mach-omap1/mcbsp.c +++ b/arch/arm/mach-omap1/mcbsp.c | |||
| @@ -19,7 +19,6 @@ | |||
| 19 | 19 | ||
| 20 | #include <mach/irqs.h> | 20 | #include <mach/irqs.h> |
| 21 | #include <mach/dma.h> | 21 | #include <mach/dma.h> |
| 22 | #include <mach/irqs.h> | ||
| 23 | #include <mach/mux.h> | 22 | #include <mach/mux.h> |
| 24 | #include <mach/cpu.h> | 23 | #include <mach/cpu.h> |
| 25 | #include <mach/mcbsp.h> | 24 | #include <mach/mcbsp.h> |
diff --git a/arch/arm/mach-omap2/board-2430sdp.c b/arch/arm/mach-omap2/board-2430sdp.c index 9c3fdcdf76c3..8ec2a132904d 100644 --- a/arch/arm/mach-omap2/board-2430sdp.c +++ b/arch/arm/mach-omap2/board-2430sdp.c | |||
| @@ -141,7 +141,7 @@ static inline void board_smc91x_init(void) | |||
| 141 | 141 | ||
| 142 | static void __init omap_2430sdp_init_irq(void) | 142 | static void __init omap_2430sdp_init_irq(void) |
| 143 | { | 143 | { |
| 144 | omap2_init_common_hw(NULL); | 144 | omap2_init_common_hw(NULL, NULL); |
| 145 | omap_init_irq(); | 145 | omap_init_irq(); |
| 146 | omap_gpio_init(); | 146 | omap_gpio_init(); |
| 147 | } | 147 | } |
diff --git a/arch/arm/mach-omap2/board-3430sdp.c b/arch/arm/mach-omap2/board-3430sdp.c index 496a90e4ea7a..ac262cd74503 100644 --- a/arch/arm/mach-omap2/board-3430sdp.c +++ b/arch/arm/mach-omap2/board-3430sdp.c | |||
| @@ -169,7 +169,7 @@ static struct platform_device *sdp3430_devices[] __initdata = { | |||
| 169 | 169 | ||
| 170 | static void __init omap_3430sdp_init_irq(void) | 170 | static void __init omap_3430sdp_init_irq(void) |
| 171 | { | 171 | { |
| 172 | omap2_init_common_hw(hyb18m512160af6_sdrc_params); | 172 | omap2_init_common_hw(hyb18m512160af6_sdrc_params, NULL); |
| 173 | omap_init_irq(); | 173 | omap_init_irq(); |
| 174 | omap_gpio_init(); | 174 | omap_gpio_init(); |
| 175 | } | 175 | } |
diff --git a/arch/arm/mach-omap2/board-4430sdp.c b/arch/arm/mach-omap2/board-4430sdp.c index 57e477bd89c6..b0c7402248f7 100644 --- a/arch/arm/mach-omap2/board-4430sdp.c +++ b/arch/arm/mach-omap2/board-4430sdp.c | |||
| @@ -59,7 +59,7 @@ static void __init gic_init_irq(void) | |||
| 59 | 59 | ||
| 60 | static void __init omap_4430sdp_init_irq(void) | 60 | static void __init omap_4430sdp_init_irq(void) |
| 61 | { | 61 | { |
| 62 | omap2_init_common_hw(NULL); | 62 | omap2_init_common_hw(NULL, NULL); |
| 63 | #ifdef CONFIG_OMAP_32K_TIMER | 63 | #ifdef CONFIG_OMAP_32K_TIMER |
| 64 | omap2_gp_clockevent_set_gptimer(1); | 64 | omap2_gp_clockevent_set_gptimer(1); |
| 65 | #endif | 65 | #endif |
diff --git a/arch/arm/mach-omap2/board-apollon.c b/arch/arm/mach-omap2/board-apollon.c index 06dfba888b0c..dcfc20d03894 100644 --- a/arch/arm/mach-omap2/board-apollon.c +++ b/arch/arm/mach-omap2/board-apollon.c | |||
| @@ -250,7 +250,7 @@ out: | |||
| 250 | 250 | ||
| 251 | static void __init omap_apollon_init_irq(void) | 251 | static void __init omap_apollon_init_irq(void) |
| 252 | { | 252 | { |
| 253 | omap2_init_common_hw(NULL); | 253 | omap2_init_common_hw(NULL, NULL); |
| 254 | omap_init_irq(); | 254 | omap_init_irq(); |
| 255 | omap_gpio_init(); | 255 | omap_gpio_init(); |
| 256 | apollon_init_smc91x(); | 256 | apollon_init_smc91x(); |
diff --git a/arch/arm/mach-omap2/board-generic.c b/arch/arm/mach-omap2/board-generic.c index 3492162a65c3..fd00aa03690c 100644 --- a/arch/arm/mach-omap2/board-generic.c +++ b/arch/arm/mach-omap2/board-generic.c | |||
| @@ -33,7 +33,7 @@ | |||
| 33 | 33 | ||
| 34 | static void __init omap_generic_init_irq(void) | 34 | static void __init omap_generic_init_irq(void) |
| 35 | { | 35 | { |
| 36 | omap2_init_common_hw(NULL); | 36 | omap2_init_common_hw(NULL, NULL); |
| 37 | omap_init_irq(); | 37 | omap_init_irq(); |
| 38 | } | 38 | } |
| 39 | 39 | ||
diff --git a/arch/arm/mach-omap2/board-h4.c b/arch/arm/mach-omap2/board-h4.c index e7d017cdc438..7b1d61d5bb2c 100644 --- a/arch/arm/mach-omap2/board-h4.c +++ b/arch/arm/mach-omap2/board-h4.c | |||
| @@ -270,7 +270,7 @@ static void __init h4_init_flash(void) | |||
| 270 | 270 | ||
| 271 | static void __init omap_h4_init_irq(void) | 271 | static void __init omap_h4_init_irq(void) |
| 272 | { | 272 | { |
| 273 | omap2_init_common_hw(NULL); | 273 | omap2_init_common_hw(NULL, NULL); |
| 274 | omap_init_irq(); | 274 | omap_init_irq(); |
| 275 | omap_gpio_init(); | 275 | omap_gpio_init(); |
| 276 | h4_init_flash(); | 276 | h4_init_flash(); |
diff --git a/arch/arm/mach-omap2/board-ldp.c b/arch/arm/mach-omap2/board-ldp.c index d8bc0a7dcb8d..ea383f88cb1b 100644 --- a/arch/arm/mach-omap2/board-ldp.c +++ b/arch/arm/mach-omap2/board-ldp.c | |||
| @@ -270,7 +270,7 @@ static inline void __init ldp_init_smsc911x(void) | |||
| 270 | 270 | ||
| 271 | static void __init omap_ldp_init_irq(void) | 271 | static void __init omap_ldp_init_irq(void) |
| 272 | { | 272 | { |
| 273 | omap2_init_common_hw(NULL); | 273 | omap2_init_common_hw(NULL, NULL); |
| 274 | omap_init_irq(); | 274 | omap_init_irq(); |
| 275 | omap_gpio_init(); | 275 | omap_gpio_init(); |
| 276 | ldp_init_smsc911x(); | 276 | ldp_init_smsc911x(); |
diff --git a/arch/arm/mach-omap2/board-omap3beagle.c b/arch/arm/mach-omap2/board-omap3beagle.c index 991ac9c38032..e00ba128cece 100644 --- a/arch/arm/mach-omap2/board-omap3beagle.c +++ b/arch/arm/mach-omap2/board-omap3beagle.c | |||
| @@ -282,7 +282,8 @@ static int __init omap3_beagle_i2c_init(void) | |||
| 282 | 282 | ||
| 283 | static void __init omap3_beagle_init_irq(void) | 283 | static void __init omap3_beagle_init_irq(void) |
| 284 | { | 284 | { |
| 285 | omap2_init_common_hw(mt46h32m32lf6_sdrc_params); | 285 | omap2_init_common_hw(mt46h32m32lf6_sdrc_params, |
| 286 | mt46h32m32lf6_sdrc_params); | ||
| 286 | omap_init_irq(); | 287 | omap_init_irq(); |
| 287 | #ifdef CONFIG_OMAP_32K_TIMER | 288 | #ifdef CONFIG_OMAP_32K_TIMER |
| 288 | omap2_gp_clockevent_set_gptimer(12); | 289 | omap2_gp_clockevent_set_gptimer(12); |
| @@ -408,6 +409,10 @@ static void __init omap3_beagle_init(void) | |||
| 408 | 409 | ||
| 409 | usb_musb_init(); | 410 | usb_musb_init(); |
| 410 | omap3beagle_flash_init(); | 411 | omap3beagle_flash_init(); |
| 412 | |||
| 413 | /* Ensure SDRC pins are mux'd for self-refresh */ | ||
| 414 | omap_cfg_reg(H16_34XX_SDRC_CKE0); | ||
| 415 | omap_cfg_reg(H17_34XX_SDRC_CKE1); | ||
| 411 | } | 416 | } |
| 412 | 417 | ||
| 413 | static void __init omap3_beagle_map_io(void) | 418 | static void __init omap3_beagle_map_io(void) |
diff --git a/arch/arm/mach-omap2/board-omap3evm.c b/arch/arm/mach-omap2/board-omap3evm.c index d3cc145814d0..c4b144647dc5 100644 --- a/arch/arm/mach-omap2/board-omap3evm.c +++ b/arch/arm/mach-omap2/board-omap3evm.c | |||
| @@ -25,6 +25,7 @@ | |||
| 25 | #include <linux/spi/spi.h> | 25 | #include <linux/spi/spi.h> |
| 26 | #include <linux/spi/ads7846.h> | 26 | #include <linux/spi/ads7846.h> |
| 27 | #include <linux/i2c/twl4030.h> | 27 | #include <linux/i2c/twl4030.h> |
| 28 | #include <linux/usb/otg.h> | ||
| 28 | 29 | ||
| 29 | #include <mach/hardware.h> | 30 | #include <mach/hardware.h> |
| 30 | #include <asm/mach-types.h> | 31 | #include <asm/mach-types.h> |
| @@ -279,7 +280,7 @@ struct spi_board_info omap3evm_spi_board_info[] = { | |||
| 279 | 280 | ||
| 280 | static void __init omap3_evm_init_irq(void) | 281 | static void __init omap3_evm_init_irq(void) |
| 281 | { | 282 | { |
| 282 | omap2_init_common_hw(mt46h32m32lf6_sdrc_params); | 283 | omap2_init_common_hw(mt46h32m32lf6_sdrc_params, NULL); |
| 283 | omap_init_irq(); | 284 | omap_init_irq(); |
| 284 | omap_gpio_init(); | 285 | omap_gpio_init(); |
| 285 | omap3evm_init_smc911x(); | 286 | omap3evm_init_smc911x(); |
| @@ -307,6 +308,10 @@ static void __init omap3_evm_init(void) | |||
| 307 | ARRAY_SIZE(omap3evm_spi_board_info)); | 308 | ARRAY_SIZE(omap3evm_spi_board_info)); |
| 308 | 309 | ||
| 309 | omap_serial_init(); | 310 | omap_serial_init(); |
| 311 | #ifdef CONFIG_NOP_USB_XCEIV | ||
| 312 | /* OMAP3EVM uses ISP1504 phy and so register nop transceiver */ | ||
| 313 | usb_nop_xceiv_register(); | ||
| 314 | #endif | ||
| 310 | usb_musb_init(); | 315 | usb_musb_init(); |
| 311 | ads7846_dev_init(); | 316 | ads7846_dev_init(); |
| 312 | } | 317 | } |
diff --git a/arch/arm/mach-omap2/board-omap3pandora.c b/arch/arm/mach-omap2/board-omap3pandora.c index e32aa23ce962..864ee3d021f7 100644 --- a/arch/arm/mach-omap2/board-omap3pandora.c +++ b/arch/arm/mach-omap2/board-omap3pandora.c | |||
| @@ -40,6 +40,7 @@ | |||
| 40 | #include <mach/mcspi.h> | 40 | #include <mach/mcspi.h> |
| 41 | #include <mach/usb.h> | 41 | #include <mach/usb.h> |
| 42 | #include <mach/keypad.h> | 42 | #include <mach/keypad.h> |
| 43 | #include <mach/mux.h> | ||
| 43 | 44 | ||
| 44 | #include "sdram-micron-mt46h32m32lf-6.h" | 45 | #include "sdram-micron-mt46h32m32lf-6.h" |
| 45 | #include "mmc-twl4030.h" | 46 | #include "mmc-twl4030.h" |
| @@ -310,7 +311,8 @@ static int __init omap3pandora_i2c_init(void) | |||
| 310 | 311 | ||
| 311 | static void __init omap3pandora_init_irq(void) | 312 | static void __init omap3pandora_init_irq(void) |
| 312 | { | 313 | { |
| 313 | omap2_init_common_hw(mt46h32m32lf6_sdrc_params); | 314 | omap2_init_common_hw(mt46h32m32lf6_sdrc_params, |
| 315 | mt46h32m32lf6_sdrc_params); | ||
| 314 | omap_init_irq(); | 316 | omap_init_irq(); |
| 315 | omap_gpio_init(); | 317 | omap_gpio_init(); |
| 316 | } | 318 | } |
| @@ -397,6 +399,10 @@ static void __init omap3pandora_init(void) | |||
| 397 | omap3pandora_ads7846_init(); | 399 | omap3pandora_ads7846_init(); |
| 398 | pandora_keys_gpio_init(); | 400 | pandora_keys_gpio_init(); |
| 399 | usb_musb_init(); | 401 | usb_musb_init(); |
| 402 | |||
| 403 | /* Ensure SDRC pins are mux'd for self-refresh */ | ||
| 404 | omap_cfg_reg(H16_34XX_SDRC_CKE0); | ||
| 405 | omap_cfg_reg(H17_34XX_SDRC_CKE1); | ||
| 400 | } | 406 | } |
| 401 | 407 | ||
| 402 | static void __init omap3pandora_map_io(void) | 408 | static void __init omap3pandora_map_io(void) |
diff --git a/arch/arm/mach-omap2/board-overo.c b/arch/arm/mach-omap2/board-overo.c index dff5528fbfb5..6bce23004aa4 100644 --- a/arch/arm/mach-omap2/board-overo.c +++ b/arch/arm/mach-omap2/board-overo.c | |||
| @@ -44,6 +44,7 @@ | |||
| 44 | #include <mach/gpmc.h> | 44 | #include <mach/gpmc.h> |
| 45 | #include <mach/hardware.h> | 45 | #include <mach/hardware.h> |
| 46 | #include <mach/nand.h> | 46 | #include <mach/nand.h> |
| 47 | #include <mach/mux.h> | ||
| 47 | #include <mach/usb.h> | 48 | #include <mach/usb.h> |
| 48 | 49 | ||
| 49 | #include "sdram-micron-mt46h32m32lf-6.h" | 50 | #include "sdram-micron-mt46h32m32lf-6.h" |
| @@ -51,6 +52,7 @@ | |||
| 51 | 52 | ||
| 52 | #define OVERO_GPIO_BT_XGATE 15 | 53 | #define OVERO_GPIO_BT_XGATE 15 |
| 53 | #define OVERO_GPIO_W2W_NRESET 16 | 54 | #define OVERO_GPIO_W2W_NRESET 16 |
| 55 | #define OVERO_GPIO_PENDOWN 114 | ||
| 54 | #define OVERO_GPIO_BT_NRESET 164 | 56 | #define OVERO_GPIO_BT_NRESET 164 |
| 55 | #define OVERO_GPIO_USBH_CPEN 168 | 57 | #define OVERO_GPIO_USBH_CPEN 168 |
| 56 | #define OVERO_GPIO_USBH_NRESET 183 | 58 | #define OVERO_GPIO_USBH_NRESET 183 |
| @@ -146,7 +148,7 @@ static struct platform_device overo_smsc911x_device = { | |||
| 146 | .name = "smsc911x", | 148 | .name = "smsc911x", |
| 147 | .id = -1, | 149 | .id = -1, |
| 148 | .num_resources = ARRAY_SIZE(overo_smsc911x_resources), | 150 | .num_resources = ARRAY_SIZE(overo_smsc911x_resources), |
| 149 | .resource = &overo_smsc911x_resources, | 151 | .resource = overo_smsc911x_resources, |
| 150 | .dev = { | 152 | .dev = { |
| 151 | .platform_data = &overo_smsc911x_config, | 153 | .platform_data = &overo_smsc911x_config, |
| 152 | }, | 154 | }, |
| @@ -360,7 +362,8 @@ static int __init overo_i2c_init(void) | |||
| 360 | 362 | ||
| 361 | static void __init overo_init_irq(void) | 363 | static void __init overo_init_irq(void) |
| 362 | { | 364 | { |
| 363 | omap2_init_common_hw(mt46h32m32lf6_sdrc_params); | 365 | omap2_init_common_hw(mt46h32m32lf6_sdrc_params, |
| 366 | mt46h32m32lf6_sdrc_params); | ||
| 364 | omap_init_irq(); | 367 | omap_init_irq(); |
| 365 | omap_gpio_init(); | 368 | omap_gpio_init(); |
| 366 | } | 369 | } |
| @@ -395,6 +398,10 @@ static void __init overo_init(void) | |||
| 395 | overo_ads7846_init(); | 398 | overo_ads7846_init(); |
| 396 | overo_init_smsc911x(); | 399 | overo_init_smsc911x(); |
| 397 | 400 | ||
| 401 | /* Ensure SDRC pins are mux'd for self-refresh */ | ||
| 402 | omap_cfg_reg(H16_34XX_SDRC_CKE0); | ||
| 403 | omap_cfg_reg(H17_34XX_SDRC_CKE1); | ||
| 404 | |||
| 398 | if ((gpio_request(OVERO_GPIO_W2W_NRESET, | 405 | if ((gpio_request(OVERO_GPIO_W2W_NRESET, |
| 399 | "OVERO_GPIO_W2W_NRESET") == 0) && | 406 | "OVERO_GPIO_W2W_NRESET") == 0) && |
| 400 | (gpio_direction_output(OVERO_GPIO_W2W_NRESET, 1) == 0)) { | 407 | (gpio_direction_output(OVERO_GPIO_W2W_NRESET, 1) == 0)) { |
diff --git a/arch/arm/mach-omap2/board-rx51-peripherals.c b/arch/arm/mach-omap2/board-rx51-peripherals.c index 9a0bf6744a05..56d931a425f7 100644 --- a/arch/arm/mach-omap2/board-rx51-peripherals.c +++ b/arch/arm/mach-omap2/board-rx51-peripherals.c | |||
| @@ -278,6 +278,10 @@ static struct twl4030_gpio_platform_data rx51_gpio_data = { | |||
| 278 | .setup = rx51_twlgpio_setup, | 278 | .setup = rx51_twlgpio_setup, |
| 279 | }; | 279 | }; |
| 280 | 280 | ||
| 281 | static struct twl4030_usb_data rx51_usb_data = { | ||
| 282 | .usb_mode = T2_USB_MODE_ULPI, | ||
| 283 | }; | ||
| 284 | |||
| 281 | static struct twl4030_platform_data rx51_twldata = { | 285 | static struct twl4030_platform_data rx51_twldata = { |
| 282 | .irq_base = TWL4030_IRQ_BASE, | 286 | .irq_base = TWL4030_IRQ_BASE, |
| 283 | .irq_end = TWL4030_IRQ_END, | 287 | .irq_end = TWL4030_IRQ_END, |
| @@ -286,6 +290,7 @@ static struct twl4030_platform_data rx51_twldata = { | |||
| 286 | .gpio = &rx51_gpio_data, | 290 | .gpio = &rx51_gpio_data, |
| 287 | .keypad = &rx51_kp_data, | 291 | .keypad = &rx51_kp_data, |
| 288 | .madc = &rx51_madc_data, | 292 | .madc = &rx51_madc_data, |
| 293 | .usb = &rx51_usb_data, | ||
| 289 | 294 | ||
| 290 | .vaux1 = &rx51_vaux1, | 295 | .vaux1 = &rx51_vaux1, |
| 291 | .vaux2 = &rx51_vaux2, | 296 | .vaux2 = &rx51_vaux2, |
diff --git a/arch/arm/mach-omap2/board-rx51.c b/arch/arm/mach-omap2/board-rx51.c index 374ff63c3eb2..1c9e07fe8266 100644 --- a/arch/arm/mach-omap2/board-rx51.c +++ b/arch/arm/mach-omap2/board-rx51.c | |||
| @@ -61,7 +61,7 @@ static struct omap_board_config_kernel rx51_config[] = { | |||
| 61 | 61 | ||
| 62 | static void __init rx51_init_irq(void) | 62 | static void __init rx51_init_irq(void) |
| 63 | { | 63 | { |
| 64 | omap2_init_common_hw(NULL); | 64 | omap2_init_common_hw(NULL, NULL); |
| 65 | omap_init_irq(); | 65 | omap_init_irq(); |
| 66 | omap_gpio_init(); | 66 | omap_gpio_init(); |
| 67 | } | 67 | } |
| @@ -75,6 +75,10 @@ static void __init rx51_init(void) | |||
| 75 | omap_serial_init(); | 75 | omap_serial_init(); |
| 76 | usb_musb_init(); | 76 | usb_musb_init(); |
| 77 | rx51_peripherals_init(); | 77 | rx51_peripherals_init(); |
| 78 | |||
| 79 | /* Ensure SDRC pins are mux'd for self-refresh */ | ||
| 80 | omap_cfg_reg(H16_34XX_SDRC_CKE0); | ||
| 81 | omap_cfg_reg(H17_34XX_SDRC_CKE1); | ||
| 78 | } | 82 | } |
| 79 | 83 | ||
| 80 | static void __init rx51_map_io(void) | 84 | static void __init rx51_map_io(void) |
diff --git a/arch/arm/mach-omap2/board-zoom2.c b/arch/arm/mach-omap2/board-zoom2.c index bcc0f7632dea..427b7b8b1237 100644 --- a/arch/arm/mach-omap2/board-zoom2.c +++ b/arch/arm/mach-omap2/board-zoom2.c | |||
| @@ -25,7 +25,7 @@ | |||
| 25 | 25 | ||
| 26 | static void __init omap_zoom2_init_irq(void) | 26 | static void __init omap_zoom2_init_irq(void) |
| 27 | { | 27 | { |
| 28 | omap2_init_common_hw(NULL); | 28 | omap2_init_common_hw(NULL, NULL); |
| 29 | omap_init_irq(); | 29 | omap_init_irq(); |
| 30 | omap_gpio_init(); | 30 | omap_gpio_init(); |
| 31 | } | 31 | } |
diff --git a/arch/arm/mach-omap2/clock.c b/arch/arm/mach-omap2/clock.c index b0665f161c03..456e2ad5f621 100644 --- a/arch/arm/mach-omap2/clock.c +++ b/arch/arm/mach-omap2/clock.c | |||
| @@ -27,6 +27,7 @@ | |||
| 27 | #include <mach/clock.h> | 27 | #include <mach/clock.h> |
| 28 | #include <mach/clockdomain.h> | 28 | #include <mach/clockdomain.h> |
| 29 | #include <mach/cpu.h> | 29 | #include <mach/cpu.h> |
| 30 | #include <mach/prcm.h> | ||
| 30 | #include <asm/div64.h> | 31 | #include <asm/div64.h> |
| 31 | 32 | ||
| 32 | #include <mach/sdrc.h> | 33 | #include <mach/sdrc.h> |
| @@ -38,8 +39,6 @@ | |||
| 38 | #include "cm-regbits-24xx.h" | 39 | #include "cm-regbits-24xx.h" |
| 39 | #include "cm-regbits-34xx.h" | 40 | #include "cm-regbits-34xx.h" |
| 40 | 41 | ||
| 41 | #define MAX_CLOCK_ENABLE_WAIT 100000 | ||
| 42 | |||
| 43 | /* DPLL rate rounding: minimum DPLL multiplier, divider values */ | 42 | /* DPLL rate rounding: minimum DPLL multiplier, divider values */ |
| 44 | #define DPLL_MIN_MULTIPLIER 1 | 43 | #define DPLL_MIN_MULTIPLIER 1 |
| 45 | #define DPLL_MIN_DIVIDER 1 | 44 | #define DPLL_MIN_DIVIDER 1 |
| @@ -274,83 +273,97 @@ unsigned long omap2_fixed_divisor_recalc(struct clk *clk) | |||
| 274 | } | 273 | } |
| 275 | 274 | ||
| 276 | /** | 275 | /** |
| 277 | * omap2_wait_clock_ready - wait for clock to enable | 276 | * omap2_clk_dflt_find_companion - find companion clock to @clk |
| 278 | * @reg: physical address of clock IDLEST register | 277 | * @clk: struct clk * to find the companion clock of |
| 279 | * @mask: value to mask against to determine if the clock is active | 278 | * @other_reg: void __iomem ** to return the companion clock CM_*CLKEN va in |
| 280 | * @name: name of the clock (for printk) | 279 | * @other_bit: u8 ** to return the companion clock bit shift in |
| 280 | * | ||
| 281 | * Note: We don't need special code here for INVERT_ENABLE for the | ||
| 282 | * time being since INVERT_ENABLE only applies to clocks enabled by | ||
| 283 | * CM_CLKEN_PLL | ||
| 281 | * | 284 | * |
| 282 | * Returns 1 if the clock enabled in time, or 0 if it failed to enable | 285 | * Convert CM_ICLKEN* <-> CM_FCLKEN*. This conversion assumes it's |
| 283 | * in roughly MAX_CLOCK_ENABLE_WAIT microseconds. | 286 | * just a matter of XORing the bits. |
| 287 | * | ||
| 288 | * Some clocks don't have companion clocks. For example, modules with | ||
| 289 | * only an interface clock (such as MAILBOXES) don't have a companion | ||
| 290 | * clock. Right now, this code relies on the hardware exporting a bit | ||
| 291 | * in the correct companion register that indicates that the | ||
| 292 | * nonexistent 'companion clock' is active. Future patches will | ||
| 293 | * associate this type of code with per-module data structures to | ||
| 294 | * avoid this issue, and remove the casts. No return value. | ||
| 284 | */ | 295 | */ |
| 285 | int omap2_wait_clock_ready(void __iomem *reg, u32 mask, const char *name) | 296 | void omap2_clk_dflt_find_companion(struct clk *clk, void __iomem **other_reg, |
| 297 | u8 *other_bit) | ||
| 286 | { | 298 | { |
| 287 | int i = 0; | 299 | u32 r; |
| 288 | int ena = 0; | ||
| 289 | 300 | ||
| 290 | /* | 301 | /* |
| 291 | * 24xx uses 0 to indicate not ready, and 1 to indicate ready. | 302 | * Convert CM_ICLKEN* <-> CM_FCLKEN*. This conversion assumes |
| 292 | * 34xx reverses this, just to keep us on our toes | 303 | * it's just a matter of XORing the bits. |
| 293 | */ | 304 | */ |
| 294 | if (cpu_mask & (RATE_IN_242X | RATE_IN_243X)) | 305 | r = ((__force u32)clk->enable_reg ^ (CM_FCLKEN ^ CM_ICLKEN)); |
| 295 | ena = mask; | ||
| 296 | else if (cpu_mask & RATE_IN_343X) | ||
| 297 | ena = 0; | ||
| 298 | |||
| 299 | /* Wait for lock */ | ||
| 300 | while (((__raw_readl(reg) & mask) != ena) && | ||
| 301 | (i++ < MAX_CLOCK_ENABLE_WAIT)) { | ||
| 302 | udelay(1); | ||
| 303 | } | ||
| 304 | |||
| 305 | if (i <= MAX_CLOCK_ENABLE_WAIT) | ||
| 306 | pr_debug("Clock %s stable after %d loops\n", name, i); | ||
| 307 | else | ||
| 308 | printk(KERN_ERR "Clock %s didn't enable in %d tries\n", | ||
| 309 | name, MAX_CLOCK_ENABLE_WAIT); | ||
| 310 | |||
| 311 | |||
| 312 | return (i < MAX_CLOCK_ENABLE_WAIT) ? 1 : 0; | ||
| 313 | }; | ||
| 314 | 306 | ||
| 307 | *other_reg = (__force void __iomem *)r; | ||
| 308 | *other_bit = clk->enable_bit; | ||
| 309 | } | ||
| 315 | 310 | ||
| 316 | /* | 311 | /** |
| 317 | * Note: We don't need special code here for INVERT_ENABLE | 312 | * omap2_clk_dflt_find_idlest - find CM_IDLEST reg va, bit shift for @clk |
| 318 | * for the time being since INVERT_ENABLE only applies to clocks enabled by | 313 | * @clk: struct clk * to find IDLEST info for |
| 319 | * CM_CLKEN_PLL | 314 | * @idlest_reg: void __iomem ** to return the CM_IDLEST va in |
| 315 | * @idlest_bit: u8 ** to return the CM_IDLEST bit shift in | ||
| 316 | * | ||
| 317 | * Return the CM_IDLEST register address and bit shift corresponding | ||
| 318 | * to the module that "owns" this clock. This default code assumes | ||
| 319 | * that the CM_IDLEST bit shift is the CM_*CLKEN bit shift, and that | ||
| 320 | * the IDLEST register address ID corresponds to the CM_*CLKEN | ||
| 321 | * register address ID (e.g., that CM_FCLKEN2 corresponds to | ||
| 322 | * CM_IDLEST2). This is not true for all modules. No return value. | ||
| 320 | */ | 323 | */ |
| 321 | static void omap2_clk_wait_ready(struct clk *clk) | 324 | void omap2_clk_dflt_find_idlest(struct clk *clk, void __iomem **idlest_reg, |
| 325 | u8 *idlest_bit) | ||
| 322 | { | 326 | { |
| 323 | void __iomem *reg, *other_reg, *st_reg; | 327 | u32 r; |
| 324 | u32 bit; | ||
| 325 | 328 | ||
| 326 | /* | 329 | r = (((__force u32)clk->enable_reg & ~0xf0) | 0x20); |
| 327 | * REVISIT: This code is pretty ugly. It would be nice to generalize | 330 | *idlest_reg = (__force void __iomem *)r; |
| 328 | * it and pull it into struct clk itself somehow. | 331 | *idlest_bit = clk->enable_bit; |
| 329 | */ | 332 | } |
| 330 | reg = clk->enable_reg; | ||
| 331 | 333 | ||
| 332 | /* | 334 | /** |
| 333 | * Convert CM_ICLKEN* <-> CM_FCLKEN*. This conversion assumes | 335 | * omap2_module_wait_ready - wait for an OMAP module to leave IDLE |
| 334 | * it's just a matter of XORing the bits. | 336 | * @clk: struct clk * belonging to the module |
| 335 | */ | 337 | * |
| 336 | other_reg = (void __iomem *)((u32)reg ^ (CM_FCLKEN ^ CM_ICLKEN)); | 338 | * If the necessary clocks for the OMAP hardware IP block that |
| 339 | * corresponds to clock @clk are enabled, then wait for the module to | ||
| 340 | * indicate readiness (i.e., to leave IDLE). This code does not | ||
| 341 | * belong in the clock code and will be moved in the medium term to | ||
| 342 | * module-dependent code. No return value. | ||
| 343 | */ | ||
| 344 | static void omap2_module_wait_ready(struct clk *clk) | ||
| 345 | { | ||
| 346 | void __iomem *companion_reg, *idlest_reg; | ||
| 347 | u8 other_bit, idlest_bit; | ||
| 348 | |||
| 349 | /* Not all modules have multiple clocks that their IDLEST depends on */ | ||
| 350 | if (clk->ops->find_companion) { | ||
| 351 | clk->ops->find_companion(clk, &companion_reg, &other_bit); | ||
| 352 | if (!(__raw_readl(companion_reg) & (1 << other_bit))) | ||
| 353 | return; | ||
| 354 | } | ||
| 337 | 355 | ||
| 338 | /* Check if both functional and interface clocks | 356 | clk->ops->find_idlest(clk, &idlest_reg, &idlest_bit); |
| 339 | * are running. */ | ||
| 340 | bit = 1 << clk->enable_bit; | ||
| 341 | if (!(__raw_readl(other_reg) & bit)) | ||
| 342 | return; | ||
| 343 | st_reg = (void __iomem *)(((u32)other_reg & ~0xf0) | 0x20); /* CM_IDLEST* */ | ||
| 344 | 357 | ||
| 345 | omap2_wait_clock_ready(st_reg, bit, clk->name); | 358 | omap2_cm_wait_idlest(idlest_reg, (1 << idlest_bit), clk->name); |
| 346 | } | 359 | } |
| 347 | 360 | ||
| 348 | static int omap2_dflt_clk_enable(struct clk *clk) | 361 | int omap2_dflt_clk_enable(struct clk *clk) |
| 349 | { | 362 | { |
| 350 | u32 v; | 363 | u32 v; |
| 351 | 364 | ||
| 352 | if (unlikely(clk->enable_reg == NULL)) { | 365 | if (unlikely(clk->enable_reg == NULL)) { |
| 353 | printk(KERN_ERR "clock.c: Enable for %s without enable code\n", | 366 | pr_err("clock.c: Enable for %s without enable code\n", |
| 354 | clk->name); | 367 | clk->name); |
| 355 | return 0; /* REVISIT: -EINVAL */ | 368 | return 0; /* REVISIT: -EINVAL */ |
| 356 | } | 369 | } |
| @@ -363,26 +376,13 @@ static int omap2_dflt_clk_enable(struct clk *clk) | |||
| 363 | __raw_writel(v, clk->enable_reg); | 376 | __raw_writel(v, clk->enable_reg); |
| 364 | v = __raw_readl(clk->enable_reg); /* OCP barrier */ | 377 | v = __raw_readl(clk->enable_reg); /* OCP barrier */ |
| 365 | 378 | ||
| 366 | return 0; | 379 | if (clk->ops->find_idlest) |
| 367 | } | 380 | omap2_module_wait_ready(clk); |
| 368 | 381 | ||
| 369 | static int omap2_dflt_clk_enable_wait(struct clk *clk) | 382 | return 0; |
| 370 | { | ||
| 371 | int ret; | ||
| 372 | |||
| 373 | if (!clk->enable_reg) { | ||
| 374 | printk(KERN_ERR "clock.c: Enable for %s without enable code\n", | ||
| 375 | clk->name); | ||
| 376 | return 0; /* REVISIT: -EINVAL */ | ||
| 377 | } | ||
| 378 | |||
| 379 | ret = omap2_dflt_clk_enable(clk); | ||
| 380 | if (ret == 0) | ||
| 381 | omap2_clk_wait_ready(clk); | ||
| 382 | return ret; | ||
| 383 | } | 383 | } |
| 384 | 384 | ||
| 385 | static void omap2_dflt_clk_disable(struct clk *clk) | 385 | void omap2_dflt_clk_disable(struct clk *clk) |
| 386 | { | 386 | { |
| 387 | u32 v; | 387 | u32 v; |
| 388 | 388 | ||
| @@ -406,8 +406,10 @@ static void omap2_dflt_clk_disable(struct clk *clk) | |||
| 406 | } | 406 | } |
| 407 | 407 | ||
| 408 | const struct clkops clkops_omap2_dflt_wait = { | 408 | const struct clkops clkops_omap2_dflt_wait = { |
| 409 | .enable = omap2_dflt_clk_enable_wait, | 409 | .enable = omap2_dflt_clk_enable, |
| 410 | .disable = omap2_dflt_clk_disable, | 410 | .disable = omap2_dflt_clk_disable, |
| 411 | .find_companion = omap2_clk_dflt_find_companion, | ||
| 412 | .find_idlest = omap2_clk_dflt_find_idlest, | ||
| 411 | }; | 413 | }; |
| 412 | 414 | ||
| 413 | const struct clkops clkops_omap2_dflt = { | 415 | const struct clkops clkops_omap2_dflt = { |
diff --git a/arch/arm/mach-omap2/clock.h b/arch/arm/mach-omap2/clock.h index 2679ddfa6424..9ae7540f8af2 100644 --- a/arch/arm/mach-omap2/clock.h +++ b/arch/arm/mach-omap2/clock.h | |||
| @@ -65,6 +65,12 @@ int omap2_clksel_set_rate(struct clk *clk, unsigned long rate); | |||
| 65 | u32 omap2_get_dpll_rate(struct clk *clk); | 65 | u32 omap2_get_dpll_rate(struct clk *clk); |
| 66 | int omap2_wait_clock_ready(void __iomem *reg, u32 cval, const char *name); | 66 | int omap2_wait_clock_ready(void __iomem *reg, u32 cval, const char *name); |
| 67 | void omap2_clk_prepare_for_reboot(void); | 67 | void omap2_clk_prepare_for_reboot(void); |
| 68 | int omap2_dflt_clk_enable(struct clk *clk); | ||
| 69 | void omap2_dflt_clk_disable(struct clk *clk); | ||
| 70 | void omap2_clk_dflt_find_companion(struct clk *clk, void __iomem **other_reg, | ||
| 71 | u8 *other_bit); | ||
| 72 | void omap2_clk_dflt_find_idlest(struct clk *clk, void __iomem **idlest_reg, | ||
| 73 | u8 *idlest_bit); | ||
| 68 | 74 | ||
| 69 | extern const struct clkops clkops_omap2_dflt_wait; | 75 | extern const struct clkops clkops_omap2_dflt_wait; |
| 70 | extern const struct clkops clkops_omap2_dflt; | 76 | extern const struct clkops clkops_omap2_dflt; |
diff --git a/arch/arm/mach-omap2/clock24xx.c b/arch/arm/mach-omap2/clock24xx.c index 44de0271fc2f..bc5d3ac66611 100644 --- a/arch/arm/mach-omap2/clock24xx.c +++ b/arch/arm/mach-omap2/clock24xx.c | |||
| @@ -30,6 +30,7 @@ | |||
| 30 | 30 | ||
| 31 | #include <mach/clock.h> | 31 | #include <mach/clock.h> |
| 32 | #include <mach/sram.h> | 32 | #include <mach/sram.h> |
| 33 | #include <mach/prcm.h> | ||
| 33 | #include <asm/div64.h> | 34 | #include <asm/div64.h> |
| 34 | #include <asm/clkdev.h> | 35 | #include <asm/clkdev.h> |
| 35 | 36 | ||
| @@ -43,6 +44,18 @@ | |||
| 43 | static const struct clkops clkops_oscck; | 44 | static const struct clkops clkops_oscck; |
| 44 | static const struct clkops clkops_fixed; | 45 | static const struct clkops clkops_fixed; |
| 45 | 46 | ||
| 47 | static void omap2430_clk_i2chs_find_idlest(struct clk *clk, | ||
| 48 | void __iomem **idlest_reg, | ||
| 49 | u8 *idlest_bit); | ||
| 50 | |||
| 51 | /* 2430 I2CHS has non-standard IDLEST register */ | ||
| 52 | static const struct clkops clkops_omap2430_i2chs_wait = { | ||
| 53 | .enable = omap2_dflt_clk_enable, | ||
| 54 | .disable = omap2_dflt_clk_disable, | ||
| 55 | .find_idlest = omap2430_clk_i2chs_find_idlest, | ||
| 56 | .find_companion = omap2_clk_dflt_find_companion, | ||
| 57 | }; | ||
| 58 | |||
| 46 | #include "clock24xx.h" | 59 | #include "clock24xx.h" |
| 47 | 60 | ||
| 48 | struct omap_clk { | 61 | struct omap_clk { |
| @@ -240,6 +253,26 @@ static void __iomem *prcm_clksrc_ctrl; | |||
| 240 | *-------------------------------------------------------------------------*/ | 253 | *-------------------------------------------------------------------------*/ |
| 241 | 254 | ||
| 242 | /** | 255 | /** |
| 256 | * omap2430_clk_i2chs_find_idlest - return CM_IDLEST info for 2430 I2CHS | ||
| 257 | * @clk: struct clk * being enabled | ||
| 258 | * @idlest_reg: void __iomem ** to store CM_IDLEST reg address into | ||
| 259 | * @idlest_bit: pointer to a u8 to store the CM_IDLEST bit shift into | ||
| 260 | * | ||
| 261 | * OMAP2430 I2CHS CM_IDLEST bits are in CM_IDLEST1_CORE, but the | ||
| 262 | * CM_*CLKEN bits are in CM_{I,F}CLKEN2_CORE. This custom function | ||
| 263 | * passes back the correct CM_IDLEST register address for I2CHS | ||
| 264 | * modules. No return value. | ||
| 265 | */ | ||
| 266 | static void omap2430_clk_i2chs_find_idlest(struct clk *clk, | ||
| 267 | void __iomem **idlest_reg, | ||
| 268 | u8 *idlest_bit) | ||
| 269 | { | ||
| 270 | *idlest_reg = OMAP_CM_REGADDR(CORE_MOD, CM_IDLEST); | ||
| 271 | *idlest_bit = clk->enable_bit; | ||
| 272 | } | ||
| 273 | |||
| 274 | |||
| 275 | /** | ||
| 243 | * omap2xxx_clk_get_core_rate - return the CORE_CLK rate | 276 | * omap2xxx_clk_get_core_rate - return the CORE_CLK rate |
| 244 | * @clk: pointer to the combined dpll_ck + core_ck (currently "dpll_ck") | 277 | * @clk: pointer to the combined dpll_ck + core_ck (currently "dpll_ck") |
| 245 | * | 278 | * |
| @@ -325,8 +358,8 @@ static int omap2_clk_fixed_enable(struct clk *clk) | |||
| 325 | else if (clk == &apll54_ck) | 358 | else if (clk == &apll54_ck) |
| 326 | cval = OMAP24XX_ST_54M_APLL; | 359 | cval = OMAP24XX_ST_54M_APLL; |
| 327 | 360 | ||
| 328 | omap2_wait_clock_ready(OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST), cval, | 361 | omap2_cm_wait_idlest(OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST), cval, |
| 329 | clk->name); | 362 | clk->name); |
| 330 | 363 | ||
| 331 | /* | 364 | /* |
| 332 | * REVISIT: Should we return an error code if omap2_wait_clock_ready() | 365 | * REVISIT: Should we return an error code if omap2_wait_clock_ready() |
diff --git a/arch/arm/mach-omap2/clock24xx.h b/arch/arm/mach-omap2/clock24xx.h index 458f00cdcbea..d19cf7a7d8db 100644 --- a/arch/arm/mach-omap2/clock24xx.h +++ b/arch/arm/mach-omap2/clock24xx.h | |||
| @@ -2337,7 +2337,7 @@ static struct clk i2c2_fck = { | |||
| 2337 | 2337 | ||
| 2338 | static struct clk i2chs2_fck = { | 2338 | static struct clk i2chs2_fck = { |
| 2339 | .name = "i2c_fck", | 2339 | .name = "i2c_fck", |
| 2340 | .ops = &clkops_omap2_dflt_wait, | 2340 | .ops = &clkops_omap2430_i2chs_wait, |
| 2341 | .id = 2, | 2341 | .id = 2, |
| 2342 | .parent = &func_96m_ck, | 2342 | .parent = &func_96m_ck, |
| 2343 | .clkdm_name = "core_l4_clkdm", | 2343 | .clkdm_name = "core_l4_clkdm", |
| @@ -2370,7 +2370,7 @@ static struct clk i2c1_fck = { | |||
| 2370 | 2370 | ||
| 2371 | static struct clk i2chs1_fck = { | 2371 | static struct clk i2chs1_fck = { |
| 2372 | .name = "i2c_fck", | 2372 | .name = "i2c_fck", |
| 2373 | .ops = &clkops_omap2_dflt_wait, | 2373 | .ops = &clkops_omap2430_i2chs_wait, |
| 2374 | .id = 1, | 2374 | .id = 1, |
| 2375 | .parent = &func_96m_ck, | 2375 | .parent = &func_96m_ck, |
| 2376 | .clkdm_name = "core_l4_clkdm", | 2376 | .clkdm_name = "core_l4_clkdm", |
diff --git a/arch/arm/mach-omap2/clock34xx.c b/arch/arm/mach-omap2/clock34xx.c index 045da923e75b..cd7819cc0c9e 100644 --- a/arch/arm/mach-omap2/clock34xx.c +++ b/arch/arm/mach-omap2/clock34xx.c | |||
| @@ -2,7 +2,7 @@ | |||
| 2 | * OMAP3-specific clock framework functions | 2 | * OMAP3-specific clock framework functions |
| 3 | * | 3 | * |
| 4 | * Copyright (C) 2007-2008 Texas Instruments, Inc. | 4 | * Copyright (C) 2007-2008 Texas Instruments, Inc. |
| 5 | * Copyright (C) 2007-2008 Nokia Corporation | 5 | * Copyright (C) 2007-2009 Nokia Corporation |
| 6 | * | 6 | * |
| 7 | * Written by Paul Walmsley | 7 | * Written by Paul Walmsley |
| 8 | * Testing and integration fixes by Jouni Högander | 8 | * Testing and integration fixes by Jouni Högander |
| @@ -41,6 +41,37 @@ | |||
| 41 | 41 | ||
| 42 | static const struct clkops clkops_noncore_dpll_ops; | 42 | static const struct clkops clkops_noncore_dpll_ops; |
| 43 | 43 | ||
| 44 | static void omap3430es2_clk_ssi_find_idlest(struct clk *clk, | ||
| 45 | void __iomem **idlest_reg, | ||
| 46 | u8 *idlest_bit); | ||
| 47 | static void omap3430es2_clk_hsotgusb_find_idlest(struct clk *clk, | ||
| 48 | void __iomem **idlest_reg, | ||
| 49 | u8 *idlest_bit); | ||
| 50 | static void omap3430es2_clk_dss_usbhost_find_idlest(struct clk *clk, | ||
| 51 | void __iomem **idlest_reg, | ||
| 52 | u8 *idlest_bit); | ||
| 53 | |||
| 54 | static const struct clkops clkops_omap3430es2_ssi_wait = { | ||
| 55 | .enable = omap2_dflt_clk_enable, | ||
| 56 | .disable = omap2_dflt_clk_disable, | ||
| 57 | .find_idlest = omap3430es2_clk_ssi_find_idlest, | ||
| 58 | .find_companion = omap2_clk_dflt_find_companion, | ||
| 59 | }; | ||
| 60 | |||
| 61 | static const struct clkops clkops_omap3430es2_hsotgusb_wait = { | ||
| 62 | .enable = omap2_dflt_clk_enable, | ||
| 63 | .disable = omap2_dflt_clk_disable, | ||
| 64 | .find_idlest = omap3430es2_clk_hsotgusb_find_idlest, | ||
| 65 | .find_companion = omap2_clk_dflt_find_companion, | ||
| 66 | }; | ||
| 67 | |||
| 68 | static const struct clkops clkops_omap3430es2_dss_usbhost_wait = { | ||
| 69 | .enable = omap2_dflt_clk_enable, | ||
| 70 | .disable = omap2_dflt_clk_disable, | ||
| 71 | .find_idlest = omap3430es2_clk_dss_usbhost_find_idlest, | ||
| 72 | .find_companion = omap2_clk_dflt_find_companion, | ||
| 73 | }; | ||
| 74 | |||
| 44 | #include "clock34xx.h" | 75 | #include "clock34xx.h" |
| 45 | 76 | ||
| 46 | struct omap_clk { | 77 | struct omap_clk { |
| @@ -157,10 +188,13 @@ static struct omap_clk omap34xx_clks[] = { | |||
| 157 | CLK(NULL, "fshostusb_fck", &fshostusb_fck, CK_3430ES1), | 188 | CLK(NULL, "fshostusb_fck", &fshostusb_fck, CK_3430ES1), |
| 158 | CLK(NULL, "core_12m_fck", &core_12m_fck, CK_343X), | 189 | CLK(NULL, "core_12m_fck", &core_12m_fck, CK_343X), |
| 159 | CLK("omap_hdq.0", "fck", &hdq_fck, CK_343X), | 190 | CLK("omap_hdq.0", "fck", &hdq_fck, CK_343X), |
| 160 | CLK(NULL, "ssi_ssr_fck", &ssi_ssr_fck, CK_343X), | 191 | CLK(NULL, "ssi_ssr_fck", &ssi_ssr_fck_3430es1, CK_3430ES1), |
| 161 | CLK(NULL, "ssi_sst_fck", &ssi_sst_fck, CK_343X), | 192 | CLK(NULL, "ssi_ssr_fck", &ssi_ssr_fck_3430es2, CK_3430ES2), |
| 193 | CLK(NULL, "ssi_sst_fck", &ssi_sst_fck_3430es1, CK_3430ES1), | ||
| 194 | CLK(NULL, "ssi_sst_fck", &ssi_sst_fck_3430es2, CK_3430ES2), | ||
| 162 | CLK(NULL, "core_l3_ick", &core_l3_ick, CK_343X), | 195 | CLK(NULL, "core_l3_ick", &core_l3_ick, CK_343X), |
| 163 | CLK("musb_hdrc", "ick", &hsotgusb_ick, CK_343X), | 196 | CLK("musb_hdrc", "ick", &hsotgusb_ick_3430es1, CK_3430ES1), |
| 197 | CLK("musb_hdrc", "ick", &hsotgusb_ick_3430es2, CK_3430ES2), | ||
| 164 | CLK(NULL, "sdrc_ick", &sdrc_ick, CK_343X), | 198 | CLK(NULL, "sdrc_ick", &sdrc_ick, CK_343X), |
| 165 | CLK(NULL, "gpmc_fck", &gpmc_fck, CK_343X), | 199 | CLK(NULL, "gpmc_fck", &gpmc_fck, CK_343X), |
| 166 | CLK(NULL, "security_l3_ick", &security_l3_ick, CK_343X), | 200 | CLK(NULL, "security_l3_ick", &security_l3_ick, CK_343X), |
| @@ -193,18 +227,21 @@ static struct omap_clk omap34xx_clks[] = { | |||
| 193 | CLK(NULL, "mailboxes_ick", &mailboxes_ick, CK_343X), | 227 | CLK(NULL, "mailboxes_ick", &mailboxes_ick, CK_343X), |
| 194 | CLK(NULL, "omapctrl_ick", &omapctrl_ick, CK_343X), | 228 | CLK(NULL, "omapctrl_ick", &omapctrl_ick, CK_343X), |
| 195 | CLK(NULL, "ssi_l4_ick", &ssi_l4_ick, CK_343X), | 229 | CLK(NULL, "ssi_l4_ick", &ssi_l4_ick, CK_343X), |
| 196 | CLK(NULL, "ssi_ick", &ssi_ick, CK_343X), | 230 | CLK(NULL, "ssi_ick", &ssi_ick_3430es1, CK_3430ES1), |
| 231 | CLK(NULL, "ssi_ick", &ssi_ick_3430es2, CK_3430ES2), | ||
| 197 | CLK(NULL, "usb_l4_ick", &usb_l4_ick, CK_3430ES1), | 232 | CLK(NULL, "usb_l4_ick", &usb_l4_ick, CK_3430ES1), |
| 198 | CLK(NULL, "security_l4_ick2", &security_l4_ick2, CK_343X), | 233 | CLK(NULL, "security_l4_ick2", &security_l4_ick2, CK_343X), |
| 199 | CLK(NULL, "aes1_ick", &aes1_ick, CK_343X), | 234 | CLK(NULL, "aes1_ick", &aes1_ick, CK_343X), |
| 200 | CLK("omap_rng", "ick", &rng_ick, CK_343X), | 235 | CLK("omap_rng", "ick", &rng_ick, CK_343X), |
| 201 | CLK(NULL, "sha11_ick", &sha11_ick, CK_343X), | 236 | CLK(NULL, "sha11_ick", &sha11_ick, CK_343X), |
| 202 | CLK(NULL, "des1_ick", &des1_ick, CK_343X), | 237 | CLK(NULL, "des1_ick", &des1_ick, CK_343X), |
| 203 | CLK("omapfb", "dss1_fck", &dss1_alwon_fck, CK_343X), | 238 | CLK("omapfb", "dss1_fck", &dss1_alwon_fck_3430es1, CK_3430ES1), |
| 239 | CLK("omapfb", "dss1_fck", &dss1_alwon_fck_3430es2, CK_3430ES2), | ||
| 204 | CLK("omapfb", "tv_fck", &dss_tv_fck, CK_343X), | 240 | CLK("omapfb", "tv_fck", &dss_tv_fck, CK_343X), |
| 205 | CLK("omapfb", "video_fck", &dss_96m_fck, CK_343X), | 241 | CLK("omapfb", "video_fck", &dss_96m_fck, CK_343X), |
| 206 | CLK("omapfb", "dss2_fck", &dss2_alwon_fck, CK_343X), | 242 | CLK("omapfb", "dss2_fck", &dss2_alwon_fck, CK_343X), |
| 207 | CLK("omapfb", "ick", &dss_ick, CK_343X), | 243 | CLK("omapfb", "ick", &dss_ick_3430es1, CK_3430ES1), |
| 244 | CLK("omapfb", "ick", &dss_ick_3430es2, CK_3430ES2), | ||
| 208 | CLK(NULL, "cam_mclk", &cam_mclk, CK_343X), | 245 | CLK(NULL, "cam_mclk", &cam_mclk, CK_343X), |
| 209 | CLK(NULL, "cam_ick", &cam_ick, CK_343X), | 246 | CLK(NULL, "cam_ick", &cam_ick, CK_343X), |
| 210 | CLK(NULL, "csi2_96m_fck", &csi2_96m_fck, CK_343X), | 247 | CLK(NULL, "csi2_96m_fck", &csi2_96m_fck, CK_343X), |
| @@ -301,6 +338,73 @@ static struct omap_clk omap34xx_clks[] = { | |||
| 301 | #define SDRC_MPURATE_LOOPS 96 | 338 | #define SDRC_MPURATE_LOOPS 96 |
| 302 | 339 | ||
| 303 | /** | 340 | /** |
| 341 | * omap3430es2_clk_ssi_find_idlest - return CM_IDLEST info for SSI | ||
| 342 | * @clk: struct clk * being enabled | ||
| 343 | * @idlest_reg: void __iomem ** to store CM_IDLEST reg address into | ||
| 344 | * @idlest_bit: pointer to a u8 to store the CM_IDLEST bit shift into | ||
| 345 | * | ||
| 346 | * The OMAP3430ES2 SSI target CM_IDLEST bit is at a different shift | ||
| 347 | * from the CM_{I,F}CLKEN bit. Pass back the correct info via | ||
| 348 | * @idlest_reg and @idlest_bit. No return value. | ||
| 349 | */ | ||
| 350 | static void omap3430es2_clk_ssi_find_idlest(struct clk *clk, | ||
| 351 | void __iomem **idlest_reg, | ||
| 352 | u8 *idlest_bit) | ||
| 353 | { | ||
| 354 | u32 r; | ||
| 355 | |||
| 356 | r = (((__force u32)clk->enable_reg & ~0xf0) | 0x20); | ||
| 357 | *idlest_reg = (__force void __iomem *)r; | ||
| 358 | *idlest_bit = OMAP3430ES2_ST_SSI_IDLE_SHIFT; | ||
| 359 | } | ||
| 360 | |||
| 361 | /** | ||
| 362 | * omap3430es2_clk_dss_usbhost_find_idlest - CM_IDLEST info for DSS, USBHOST | ||
| 363 | * @clk: struct clk * being enabled | ||
| 364 | * @idlest_reg: void __iomem ** to store CM_IDLEST reg address into | ||
| 365 | * @idlest_bit: pointer to a u8 to store the CM_IDLEST bit shift into | ||
| 366 | * | ||
| 367 | * Some OMAP modules on OMAP3 ES2+ chips have both initiator and | ||
| 368 | * target IDLEST bits. For our purposes, we are concerned with the | ||
| 369 | * target IDLEST bits, which exist at a different bit position than | ||
| 370 | * the *CLKEN bit position for these modules (DSS and USBHOST) (The | ||
| 371 | * default find_idlest code assumes that they are at the same | ||
| 372 | * position.) No return value. | ||
| 373 | */ | ||
| 374 | static void omap3430es2_clk_dss_usbhost_find_idlest(struct clk *clk, | ||
| 375 | void __iomem **idlest_reg, | ||
| 376 | u8 *idlest_bit) | ||
| 377 | { | ||
| 378 | u32 r; | ||
| 379 | |||
| 380 | r = (((__force u32)clk->enable_reg & ~0xf0) | 0x20); | ||
| 381 | *idlest_reg = (__force void __iomem *)r; | ||
| 382 | /* USBHOST_IDLE has same shift */ | ||
| 383 | *idlest_bit = OMAP3430ES2_ST_DSS_IDLE_SHIFT; | ||
| 384 | } | ||
| 385 | |||
| 386 | /** | ||
| 387 | * omap3430es2_clk_hsotgusb_find_idlest - return CM_IDLEST info for HSOTGUSB | ||
| 388 | * @clk: struct clk * being enabled | ||
| 389 | * @idlest_reg: void __iomem ** to store CM_IDLEST reg address into | ||
| 390 | * @idlest_bit: pointer to a u8 to store the CM_IDLEST bit shift into | ||
| 391 | * | ||
| 392 | * The OMAP3430ES2 HSOTGUSB target CM_IDLEST bit is at a different | ||
| 393 | * shift from the CM_{I,F}CLKEN bit. Pass back the correct info via | ||
| 394 | * @idlest_reg and @idlest_bit. No return value. | ||
| 395 | */ | ||
| 396 | static void omap3430es2_clk_hsotgusb_find_idlest(struct clk *clk, | ||
| 397 | void __iomem **idlest_reg, | ||
| 398 | u8 *idlest_bit) | ||
| 399 | { | ||
| 400 | u32 r; | ||
| 401 | |||
| 402 | r = (((__force u32)clk->enable_reg & ~0xf0) | 0x20); | ||
| 403 | *idlest_reg = (__force void __iomem *)r; | ||
| 404 | *idlest_bit = OMAP3430ES2_ST_HSOTGUSB_IDLE_SHIFT; | ||
| 405 | } | ||
| 406 | |||
| 407 | /** | ||
| 304 | * omap3_dpll_recalc - recalculate DPLL rate | 408 | * omap3_dpll_recalc - recalculate DPLL rate |
| 305 | * @clk: DPLL struct clk | 409 | * @clk: DPLL struct clk |
| 306 | * | 410 | * |
| @@ -725,7 +829,9 @@ static int omap3_core_dpll_m2_set_rate(struct clk *clk, unsigned long rate) | |||
| 725 | u32 unlock_dll = 0; | 829 | u32 unlock_dll = 0; |
| 726 | u32 c; | 830 | u32 c; |
| 727 | unsigned long validrate, sdrcrate, mpurate; | 831 | unsigned long validrate, sdrcrate, mpurate; |
| 728 | struct omap_sdrc_params *sp; | 832 | struct omap_sdrc_params *sdrc_cs0; |
| 833 | struct omap_sdrc_params *sdrc_cs1; | ||
| 834 | int ret; | ||
| 729 | 835 | ||
| 730 | if (!clk || !rate) | 836 | if (!clk || !rate) |
| 731 | return -EINVAL; | 837 | return -EINVAL; |
| @@ -743,8 +849,8 @@ static int omap3_core_dpll_m2_set_rate(struct clk *clk, unsigned long rate) | |||
| 743 | else | 849 | else |
| 744 | sdrcrate >>= ((clk->rate / rate) >> 1); | 850 | sdrcrate >>= ((clk->rate / rate) >> 1); |
| 745 | 851 | ||
| 746 | sp = omap2_sdrc_get_params(sdrcrate); | 852 | ret = omap2_sdrc_get_params(sdrcrate, &sdrc_cs0, &sdrc_cs1); |
| 747 | if (!sp) | 853 | if (ret) |
| 748 | return -EINVAL; | 854 | return -EINVAL; |
| 749 | 855 | ||
| 750 | if (sdrcrate < MIN_SDRC_DLL_LOCK_FREQ) { | 856 | if (sdrcrate < MIN_SDRC_DLL_LOCK_FREQ) { |
| @@ -765,12 +871,29 @@ static int omap3_core_dpll_m2_set_rate(struct clk *clk, unsigned long rate) | |||
| 765 | 871 | ||
| 766 | pr_debug("clock: changing CORE DPLL rate from %lu to %lu\n", clk->rate, | 872 | pr_debug("clock: changing CORE DPLL rate from %lu to %lu\n", clk->rate, |
| 767 | validrate); | 873 | validrate); |
| 768 | pr_debug("clock: SDRC timing params used: %08x %08x %08x\n", | 874 | pr_debug("clock: SDRC CS0 timing params used:" |
| 769 | sp->rfr_ctrl, sp->actim_ctrla, sp->actim_ctrlb); | 875 | " RFR %08x CTRLA %08x CTRLB %08x MR %08x\n", |
| 770 | 876 | sdrc_cs0->rfr_ctrl, sdrc_cs0->actim_ctrla, | |
| 771 | omap3_configure_core_dpll(sp->rfr_ctrl, sp->actim_ctrla, | 877 | sdrc_cs0->actim_ctrlb, sdrc_cs0->mr); |
| 772 | sp->actim_ctrlb, new_div, unlock_dll, c, | 878 | if (sdrc_cs1) |
| 773 | sp->mr, rate > clk->rate); | 879 | pr_debug("clock: SDRC CS1 timing params used: " |
| 880 | " RFR %08x CTRLA %08x CTRLB %08x MR %08x\n", | ||
| 881 | sdrc_cs1->rfr_ctrl, sdrc_cs1->actim_ctrla, | ||
| 882 | sdrc_cs1->actim_ctrlb, sdrc_cs1->mr); | ||
| 883 | |||
| 884 | if (sdrc_cs1) | ||
| 885 | omap3_configure_core_dpll( | ||
| 886 | new_div, unlock_dll, c, rate > clk->rate, | ||
| 887 | sdrc_cs0->rfr_ctrl, sdrc_cs0->actim_ctrla, | ||
| 888 | sdrc_cs0->actim_ctrlb, sdrc_cs0->mr, | ||
| 889 | sdrc_cs1->rfr_ctrl, sdrc_cs1->actim_ctrla, | ||
| 890 | sdrc_cs1->actim_ctrlb, sdrc_cs1->mr); | ||
| 891 | else | ||
| 892 | omap3_configure_core_dpll( | ||
| 893 | new_div, unlock_dll, c, rate > clk->rate, | ||
| 894 | sdrc_cs0->rfr_ctrl, sdrc_cs0->actim_ctrla, | ||
| 895 | sdrc_cs0->actim_ctrlb, sdrc_cs0->mr, | ||
| 896 | 0, 0, 0, 0); | ||
| 774 | 897 | ||
| 775 | return 0; | 898 | return 0; |
| 776 | } | 899 | } |
diff --git a/arch/arm/mach-omap2/clock34xx.h b/arch/arm/mach-omap2/clock34xx.h index e433aec4efdd..57cc2725b923 100644 --- a/arch/arm/mach-omap2/clock34xx.h +++ b/arch/arm/mach-omap2/clock34xx.h | |||
| @@ -1568,7 +1568,7 @@ static const struct clksel ssi_ssr_clksel[] = { | |||
| 1568 | { .parent = NULL } | 1568 | { .parent = NULL } |
| 1569 | }; | 1569 | }; |
| 1570 | 1570 | ||
| 1571 | static struct clk ssi_ssr_fck = { | 1571 | static struct clk ssi_ssr_fck_3430es1 = { |
| 1572 | .name = "ssi_ssr_fck", | 1572 | .name = "ssi_ssr_fck", |
| 1573 | .ops = &clkops_omap2_dflt, | 1573 | .ops = &clkops_omap2_dflt, |
| 1574 | .init = &omap2_init_clksel_parent, | 1574 | .init = &omap2_init_clksel_parent, |
| @@ -1581,10 +1581,31 @@ static struct clk ssi_ssr_fck = { | |||
| 1581 | .recalc = &omap2_clksel_recalc, | 1581 | .recalc = &omap2_clksel_recalc, |
| 1582 | }; | 1582 | }; |
| 1583 | 1583 | ||
| 1584 | static struct clk ssi_sst_fck = { | 1584 | static struct clk ssi_ssr_fck_3430es2 = { |
| 1585 | .name = "ssi_ssr_fck", | ||
| 1586 | .ops = &clkops_omap3430es2_ssi_wait, | ||
| 1587 | .init = &omap2_init_clksel_parent, | ||
| 1588 | .enable_reg = OMAP_CM_REGADDR(CORE_MOD, CM_FCLKEN1), | ||
| 1589 | .enable_bit = OMAP3430_EN_SSI_SHIFT, | ||
| 1590 | .clksel_reg = OMAP_CM_REGADDR(CORE_MOD, CM_CLKSEL), | ||
| 1591 | .clksel_mask = OMAP3430_CLKSEL_SSI_MASK, | ||
| 1592 | .clksel = ssi_ssr_clksel, | ||
| 1593 | .clkdm_name = "core_l4_clkdm", | ||
| 1594 | .recalc = &omap2_clksel_recalc, | ||
| 1595 | }; | ||
| 1596 | |||
| 1597 | static struct clk ssi_sst_fck_3430es1 = { | ||
| 1585 | .name = "ssi_sst_fck", | 1598 | .name = "ssi_sst_fck", |
| 1586 | .ops = &clkops_null, | 1599 | .ops = &clkops_null, |
| 1587 | .parent = &ssi_ssr_fck, | 1600 | .parent = &ssi_ssr_fck_3430es1, |
| 1601 | .fixed_div = 2, | ||
| 1602 | .recalc = &omap2_fixed_divisor_recalc, | ||
| 1603 | }; | ||
| 1604 | |||
| 1605 | static struct clk ssi_sst_fck_3430es2 = { | ||
| 1606 | .name = "ssi_sst_fck", | ||
| 1607 | .ops = &clkops_null, | ||
| 1608 | .parent = &ssi_ssr_fck_3430es2, | ||
| 1588 | .fixed_div = 2, | 1609 | .fixed_div = 2, |
| 1589 | .recalc = &omap2_fixed_divisor_recalc, | 1610 | .recalc = &omap2_fixed_divisor_recalc, |
| 1590 | }; | 1611 | }; |
| @@ -1606,9 +1627,19 @@ static struct clk core_l3_ick = { | |||
| 1606 | .recalc = &followparent_recalc, | 1627 | .recalc = &followparent_recalc, |
| 1607 | }; | 1628 | }; |
| 1608 | 1629 | ||
| 1609 | static struct clk hsotgusb_ick = { | 1630 | static struct clk hsotgusb_ick_3430es1 = { |
| 1610 | .name = "hsotgusb_ick", | 1631 | .name = "hsotgusb_ick", |
| 1611 | .ops = &clkops_omap2_dflt_wait, | 1632 | .ops = &clkops_omap2_dflt, |
| 1633 | .parent = &core_l3_ick, | ||
| 1634 | .enable_reg = OMAP_CM_REGADDR(CORE_MOD, CM_ICLKEN1), | ||
| 1635 | .enable_bit = OMAP3430_EN_HSOTGUSB_SHIFT, | ||
| 1636 | .clkdm_name = "core_l3_clkdm", | ||
| 1637 | .recalc = &followparent_recalc, | ||
| 1638 | }; | ||
| 1639 | |||
| 1640 | static struct clk hsotgusb_ick_3430es2 = { | ||
| 1641 | .name = "hsotgusb_ick", | ||
| 1642 | .ops = &clkops_omap3430es2_hsotgusb_wait, | ||
| 1612 | .parent = &core_l3_ick, | 1643 | .parent = &core_l3_ick, |
| 1613 | .enable_reg = OMAP_CM_REGADDR(CORE_MOD, CM_ICLKEN1), | 1644 | .enable_reg = OMAP_CM_REGADDR(CORE_MOD, CM_ICLKEN1), |
| 1614 | .enable_bit = OMAP3430_EN_HSOTGUSB_SHIFT, | 1645 | .enable_bit = OMAP3430_EN_HSOTGUSB_SHIFT, |
| @@ -1947,7 +1978,7 @@ static struct clk ssi_l4_ick = { | |||
| 1947 | .recalc = &followparent_recalc, | 1978 | .recalc = &followparent_recalc, |
| 1948 | }; | 1979 | }; |
| 1949 | 1980 | ||
| 1950 | static struct clk ssi_ick = { | 1981 | static struct clk ssi_ick_3430es1 = { |
| 1951 | .name = "ssi_ick", | 1982 | .name = "ssi_ick", |
| 1952 | .ops = &clkops_omap2_dflt, | 1983 | .ops = &clkops_omap2_dflt, |
| 1953 | .parent = &ssi_l4_ick, | 1984 | .parent = &ssi_l4_ick, |
| @@ -1957,6 +1988,16 @@ static struct clk ssi_ick = { | |||
| 1957 | .recalc = &followparent_recalc, | 1988 | .recalc = &followparent_recalc, |
| 1958 | }; | 1989 | }; |
| 1959 | 1990 | ||
| 1991 | static struct clk ssi_ick_3430es2 = { | ||
| 1992 | .name = "ssi_ick", | ||
| 1993 | .ops = &clkops_omap3430es2_ssi_wait, | ||
| 1994 | .parent = &ssi_l4_ick, | ||
| 1995 | .enable_reg = OMAP_CM_REGADDR(CORE_MOD, CM_ICLKEN1), | ||
| 1996 | .enable_bit = OMAP3430_EN_SSI_SHIFT, | ||
| 1997 | .clkdm_name = "core_l4_clkdm", | ||
| 1998 | .recalc = &followparent_recalc, | ||
| 1999 | }; | ||
| 2000 | |||
| 1960 | /* REVISIT: Technically the TRM claims that this is CORE_CLK based, | 2001 | /* REVISIT: Technically the TRM claims that this is CORE_CLK based, |
| 1961 | * but l4_ick makes more sense to me */ | 2002 | * but l4_ick makes more sense to me */ |
| 1962 | 2003 | ||
| @@ -2024,7 +2065,7 @@ static struct clk des1_ick = { | |||
| 2024 | }; | 2065 | }; |
| 2025 | 2066 | ||
| 2026 | /* DSS */ | 2067 | /* DSS */ |
| 2027 | static struct clk dss1_alwon_fck = { | 2068 | static struct clk dss1_alwon_fck_3430es1 = { |
| 2028 | .name = "dss1_alwon_fck", | 2069 | .name = "dss1_alwon_fck", |
| 2029 | .ops = &clkops_omap2_dflt, | 2070 | .ops = &clkops_omap2_dflt, |
| 2030 | .parent = &dpll4_m4x2_ck, | 2071 | .parent = &dpll4_m4x2_ck, |
| @@ -2034,6 +2075,16 @@ static struct clk dss1_alwon_fck = { | |||
| 2034 | .recalc = &followparent_recalc, | 2075 | .recalc = &followparent_recalc, |
| 2035 | }; | 2076 | }; |
| 2036 | 2077 | ||
| 2078 | static struct clk dss1_alwon_fck_3430es2 = { | ||
| 2079 | .name = "dss1_alwon_fck", | ||
| 2080 | .ops = &clkops_omap3430es2_dss_usbhost_wait, | ||
| 2081 | .parent = &dpll4_m4x2_ck, | ||
| 2082 | .enable_reg = OMAP_CM_REGADDR(OMAP3430_DSS_MOD, CM_FCLKEN), | ||
| 2083 | .enable_bit = OMAP3430_EN_DSS1_SHIFT, | ||
| 2084 | .clkdm_name = "dss_clkdm", | ||
| 2085 | .recalc = &followparent_recalc, | ||
| 2086 | }; | ||
| 2087 | |||
| 2037 | static struct clk dss_tv_fck = { | 2088 | static struct clk dss_tv_fck = { |
| 2038 | .name = "dss_tv_fck", | 2089 | .name = "dss_tv_fck", |
| 2039 | .ops = &clkops_omap2_dflt, | 2090 | .ops = &clkops_omap2_dflt, |
| @@ -2067,7 +2118,7 @@ static struct clk dss2_alwon_fck = { | |||
| 2067 | .recalc = &followparent_recalc, | 2118 | .recalc = &followparent_recalc, |
| 2068 | }; | 2119 | }; |
| 2069 | 2120 | ||
| 2070 | static struct clk dss_ick = { | 2121 | static struct clk dss_ick_3430es1 = { |
| 2071 | /* Handles both L3 and L4 clocks */ | 2122 | /* Handles both L3 and L4 clocks */ |
| 2072 | .name = "dss_ick", | 2123 | .name = "dss_ick", |
| 2073 | .ops = &clkops_omap2_dflt, | 2124 | .ops = &clkops_omap2_dflt, |
| @@ -2079,6 +2130,18 @@ static struct clk dss_ick = { | |||
| 2079 | .recalc = &followparent_recalc, | 2130 | .recalc = &followparent_recalc, |
| 2080 | }; | 2131 | }; |
| 2081 | 2132 | ||
| 2133 | static struct clk dss_ick_3430es2 = { | ||
| 2134 | /* Handles both L3 and L4 clocks */ | ||
| 2135 | .name = "dss_ick", | ||
| 2136 | .ops = &clkops_omap3430es2_dss_usbhost_wait, | ||
| 2137 | .parent = &l4_ick, | ||
| 2138 | .init = &omap2_init_clk_clkdm, | ||
| 2139 | .enable_reg = OMAP_CM_REGADDR(OMAP3430_DSS_MOD, CM_ICLKEN), | ||
| 2140 | .enable_bit = OMAP3430_CM_ICLKEN_DSS_EN_DSS_SHIFT, | ||
| 2141 | .clkdm_name = "dss_clkdm", | ||
| 2142 | .recalc = &followparent_recalc, | ||
| 2143 | }; | ||
| 2144 | |||
| 2082 | /* CAM */ | 2145 | /* CAM */ |
| 2083 | 2146 | ||
| 2084 | static struct clk cam_mclk = { | 2147 | static struct clk cam_mclk = { |
| @@ -2118,7 +2181,7 @@ static struct clk csi2_96m_fck = { | |||
| 2118 | 2181 | ||
| 2119 | static struct clk usbhost_120m_fck = { | 2182 | static struct clk usbhost_120m_fck = { |
| 2120 | .name = "usbhost_120m_fck", | 2183 | .name = "usbhost_120m_fck", |
| 2121 | .ops = &clkops_omap2_dflt_wait, | 2184 | .ops = &clkops_omap2_dflt, |
| 2122 | .parent = &dpll5_m2_ck, | 2185 | .parent = &dpll5_m2_ck, |
| 2123 | .init = &omap2_init_clk_clkdm, | 2186 | .init = &omap2_init_clk_clkdm, |
| 2124 | .enable_reg = OMAP_CM_REGADDR(OMAP3430ES2_USBHOST_MOD, CM_FCLKEN), | 2187 | .enable_reg = OMAP_CM_REGADDR(OMAP3430ES2_USBHOST_MOD, CM_FCLKEN), |
| @@ -2129,7 +2192,7 @@ static struct clk usbhost_120m_fck = { | |||
| 2129 | 2192 | ||
| 2130 | static struct clk usbhost_48m_fck = { | 2193 | static struct clk usbhost_48m_fck = { |
| 2131 | .name = "usbhost_48m_fck", | 2194 | .name = "usbhost_48m_fck", |
| 2132 | .ops = &clkops_omap2_dflt_wait, | 2195 | .ops = &clkops_omap3430es2_dss_usbhost_wait, |
| 2133 | .parent = &omap_48m_fck, | 2196 | .parent = &omap_48m_fck, |
| 2134 | .init = &omap2_init_clk_clkdm, | 2197 | .init = &omap2_init_clk_clkdm, |
| 2135 | .enable_reg = OMAP_CM_REGADDR(OMAP3430ES2_USBHOST_MOD, CM_FCLKEN), | 2198 | .enable_reg = OMAP_CM_REGADDR(OMAP3430ES2_USBHOST_MOD, CM_FCLKEN), |
| @@ -2141,7 +2204,7 @@ static struct clk usbhost_48m_fck = { | |||
| 2141 | static struct clk usbhost_ick = { | 2204 | static struct clk usbhost_ick = { |
| 2142 | /* Handles both L3 and L4 clocks */ | 2205 | /* Handles both L3 and L4 clocks */ |
| 2143 | .name = "usbhost_ick", | 2206 | .name = "usbhost_ick", |
| 2144 | .ops = &clkops_omap2_dflt_wait, | 2207 | .ops = &clkops_omap3430es2_dss_usbhost_wait, |
| 2145 | .parent = &l4_ick, | 2208 | .parent = &l4_ick, |
| 2146 | .init = &omap2_init_clk_clkdm, | 2209 | .init = &omap2_init_clk_clkdm, |
| 2147 | .enable_reg = OMAP_CM_REGADDR(OMAP3430ES2_USBHOST_MOD, CM_ICLKEN), | 2210 | .enable_reg = OMAP_CM_REGADDR(OMAP3430ES2_USBHOST_MOD, CM_ICLKEN), |
diff --git a/arch/arm/mach-omap2/cm.h b/arch/arm/mach-omap2/cm.h index 1d3c93bf86d3..f3c91a1ca391 100644 --- a/arch/arm/mach-omap2/cm.h +++ b/arch/arm/mach-omap2/cm.h | |||
| @@ -29,9 +29,9 @@ | |||
| 29 | * These registers appear once per CM module. | 29 | * These registers appear once per CM module. |
| 30 | */ | 30 | */ |
| 31 | 31 | ||
| 32 | #define OMAP3430_CM_REVISION OMAP_CM_REGADDR(OCP_MOD, 0x0000) | 32 | #define OMAP3430_CM_REVISION OMAP34XX_CM_REGADDR(OCP_MOD, 0x0000) |
| 33 | #define OMAP3430_CM_SYSCONFIG OMAP_CM_REGADDR(OCP_MOD, 0x0010) | 33 | #define OMAP3430_CM_SYSCONFIG OMAP34XX_CM_REGADDR(OCP_MOD, 0x0010) |
| 34 | #define OMAP3430_CM_POLCTRL OMAP_CM_REGADDR(OCP_MOD, 0x009c) | 34 | #define OMAP3430_CM_POLCTRL OMAP34XX_CM_REGADDR(OCP_MOD, 0x009c) |
| 35 | 35 | ||
| 36 | #define OMAP3_CM_CLKOUT_CTRL_OFFSET 0x0070 | 36 | #define OMAP3_CM_CLKOUT_CTRL_OFFSET 0x0070 |
| 37 | #define OMAP3430_CM_CLKOUT_CTRL OMAP_CM_REGADDR(OMAP3430_CCR_MOD, 0x0070) | 37 | #define OMAP3430_CM_CLKOUT_CTRL OMAP_CM_REGADDR(OMAP3430_CCR_MOD, 0x0070) |
diff --git a/arch/arm/mach-omap2/io.c b/arch/arm/mach-omap2/io.c index 3a86b0f66031..e9b9bcb19b4e 100644 --- a/arch/arm/mach-omap2/io.c +++ b/arch/arm/mach-omap2/io.c | |||
| @@ -276,14 +276,15 @@ static int __init _omap2_init_reprogram_sdrc(void) | |||
| 276 | return v; | 276 | return v; |
| 277 | } | 277 | } |
| 278 | 278 | ||
| 279 | void __init omap2_init_common_hw(struct omap_sdrc_params *sp) | 279 | void __init omap2_init_common_hw(struct omap_sdrc_params *sdrc_cs0, |
| 280 | struct omap_sdrc_params *sdrc_cs1) | ||
| 280 | { | 281 | { |
| 281 | omap2_mux_init(); | 282 | omap2_mux_init(); |
| 282 | #ifndef CONFIG_ARCH_OMAP4 /* FIXME: Remove this once the clkdev is ready */ | 283 | #ifndef CONFIG_ARCH_OMAP4 /* FIXME: Remove this once the clkdev is ready */ |
| 283 | pwrdm_init(powerdomains_omap); | 284 | pwrdm_init(powerdomains_omap); |
| 284 | clkdm_init(clockdomains_omap, clkdm_pwrdm_autodeps); | 285 | clkdm_init(clockdomains_omap, clkdm_pwrdm_autodeps); |
| 285 | omap2_clk_init(); | 286 | omap2_clk_init(); |
| 286 | omap2_sdrc_init(sp); | 287 | omap2_sdrc_init(sdrc_cs0, sdrc_cs1); |
| 287 | _omap2_init_reprogram_sdrc(); | 288 | _omap2_init_reprogram_sdrc(); |
| 288 | #endif | 289 | #endif |
| 289 | gpmc_init(); | 290 | gpmc_init(); |
diff --git a/arch/arm/mach-omap2/mcbsp.c b/arch/arm/mach-omap2/mcbsp.c index a5c0f0435cd6..99b6e1546311 100644 --- a/arch/arm/mach-omap2/mcbsp.c +++ b/arch/arm/mach-omap2/mcbsp.c | |||
| @@ -19,7 +19,6 @@ | |||
| 19 | 19 | ||
| 20 | #include <mach/irqs.h> | 20 | #include <mach/irqs.h> |
| 21 | #include <mach/dma.h> | 21 | #include <mach/dma.h> |
| 22 | #include <mach/irqs.h> | ||
| 23 | #include <mach/mux.h> | 22 | #include <mach/mux.h> |
| 24 | #include <mach/cpu.h> | 23 | #include <mach/cpu.h> |
| 25 | #include <mach/mcbsp.h> | 24 | #include <mach/mcbsp.h> |
diff --git a/arch/arm/mach-omap2/mmc-twl4030.c b/arch/arm/mach-omap2/mmc-twl4030.c index 1541fd4c8d0f..3c04c2f1b23f 100644 --- a/arch/arm/mach-omap2/mmc-twl4030.c +++ b/arch/arm/mach-omap2/mmc-twl4030.c | |||
| @@ -119,6 +119,7 @@ static int twl_mmc_late_init(struct device *dev) | |||
| 119 | if (i != 0) | 119 | if (i != 0) |
| 120 | break; | 120 | break; |
| 121 | ret = PTR_ERR(reg); | 121 | ret = PTR_ERR(reg); |
| 122 | hsmmc[i].vcc = NULL; | ||
| 122 | goto err; | 123 | goto err; |
| 123 | } | 124 | } |
| 124 | hsmmc[i].vcc = reg; | 125 | hsmmc[i].vcc = reg; |
| @@ -165,8 +166,13 @@ done: | |||
| 165 | static void twl_mmc_cleanup(struct device *dev) | 166 | static void twl_mmc_cleanup(struct device *dev) |
| 166 | { | 167 | { |
| 167 | struct omap_mmc_platform_data *mmc = dev->platform_data; | 168 | struct omap_mmc_platform_data *mmc = dev->platform_data; |
| 169 | int i; | ||
| 168 | 170 | ||
| 169 | gpio_free(mmc->slots[0].switch_pin); | 171 | gpio_free(mmc->slots[0].switch_pin); |
| 172 | for(i = 0; i < ARRAY_SIZE(hsmmc); i++) { | ||
| 173 | regulator_put(hsmmc[i].vcc); | ||
| 174 | regulator_put(hsmmc[i].vcc_aux); | ||
| 175 | } | ||
| 170 | } | 176 | } |
| 171 | 177 | ||
| 172 | #ifdef CONFIG_PM | 178 | #ifdef CONFIG_PM |
diff --git a/arch/arm/mach-omap2/mux.c b/arch/arm/mach-omap2/mux.c index 026c4fc883a7..43d6b92b65f2 100644 --- a/arch/arm/mach-omap2/mux.c +++ b/arch/arm/mach-omap2/mux.c | |||
| @@ -486,6 +486,12 @@ MUX_CFG_34XX("H19_34XX_GPIO164_OUT", 0x19c, | |||
| 486 | OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_OUTPUT) | 486 | OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_OUTPUT) |
| 487 | MUX_CFG_34XX("J25_34XX_GPIO170", 0x1c6, | 487 | MUX_CFG_34XX("J25_34XX_GPIO170", 0x1c6, |
| 488 | OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_INPUT) | 488 | OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_INPUT) |
| 489 | |||
| 490 | /* OMAP3 SDRC CKE signals to SDR/DDR ram chips */ | ||
| 491 | MUX_CFG_34XX("H16_34XX_SDRC_CKE0", 0x262, | ||
| 492 | OMAP34XX_MUX_MODE0 | OMAP34XX_PIN_OUTPUT) | ||
| 493 | MUX_CFG_34XX("H17_34XX_SDRC_CKE1", 0x264, | ||
| 494 | OMAP34XX_MUX_MODE0 | OMAP34XX_PIN_OUTPUT) | ||
| 489 | }; | 495 | }; |
| 490 | 496 | ||
| 491 | #define OMAP34XX_PINS_SZ ARRAY_SIZE(omap34xx_pins) | 497 | #define OMAP34XX_PINS_SZ ARRAY_SIZE(omap34xx_pins) |
diff --git a/arch/arm/mach-omap2/pm.h b/arch/arm/mach-omap2/pm.h index f7b3baf76678..21201cd4117b 100644 --- a/arch/arm/mach-omap2/pm.h +++ b/arch/arm/mach-omap2/pm.h | |||
| @@ -11,9 +11,6 @@ | |||
| 11 | #ifndef __ARCH_ARM_MACH_OMAP2_PM_H | 11 | #ifndef __ARCH_ARM_MACH_OMAP2_PM_H |
| 12 | #define __ARCH_ARM_MACH_OMAP2_PM_H | 12 | #define __ARCH_ARM_MACH_OMAP2_PM_H |
| 13 | 13 | ||
| 14 | extern int omap2_pm_init(void); | ||
| 15 | extern int omap3_pm_init(void); | ||
| 16 | |||
| 17 | #ifdef CONFIG_PM_DEBUG | 14 | #ifdef CONFIG_PM_DEBUG |
| 18 | extern void omap2_pm_dump(int mode, int resume, unsigned int us); | 15 | extern void omap2_pm_dump(int mode, int resume, unsigned int us); |
| 19 | extern int omap2_pm_debug; | 16 | extern int omap2_pm_debug; |
diff --git a/arch/arm/mach-omap2/pm24xx.c b/arch/arm/mach-omap2/pm24xx.c index db1025562fb0..528dbdc26e23 100644 --- a/arch/arm/mach-omap2/pm24xx.c +++ b/arch/arm/mach-omap2/pm24xx.c | |||
| @@ -470,7 +470,7 @@ static void __init prcm_setup_regs(void) | |||
| 470 | WKUP_MOD, PM_WKEN); | 470 | WKUP_MOD, PM_WKEN); |
| 471 | } | 471 | } |
| 472 | 472 | ||
| 473 | int __init omap2_pm_init(void) | 473 | static int __init omap2_pm_init(void) |
| 474 | { | 474 | { |
| 475 | u32 l; | 475 | u32 l; |
| 476 | 476 | ||
diff --git a/arch/arm/mach-omap2/pm34xx.c b/arch/arm/mach-omap2/pm34xx.c index 841d4c5ed8be..488d595d8e4b 100644 --- a/arch/arm/mach-omap2/pm34xx.c +++ b/arch/arm/mach-omap2/pm34xx.c | |||
| @@ -39,7 +39,9 @@ | |||
| 39 | struct power_state { | 39 | struct power_state { |
| 40 | struct powerdomain *pwrdm; | 40 | struct powerdomain *pwrdm; |
| 41 | u32 next_state; | 41 | u32 next_state; |
| 42 | #ifdef CONFIG_SUSPEND | ||
| 42 | u32 saved_state; | 43 | u32 saved_state; |
| 44 | #endif | ||
| 43 | struct list_head node; | 45 | struct list_head node; |
| 44 | }; | 46 | }; |
| 45 | 47 | ||
| @@ -293,6 +295,9 @@ out: | |||
| 293 | local_irq_enable(); | 295 | local_irq_enable(); |
| 294 | } | 296 | } |
| 295 | 297 | ||
| 298 | #ifdef CONFIG_SUSPEND | ||
| 299 | static suspend_state_t suspend_state; | ||
| 300 | |||
| 296 | static int omap3_pm_prepare(void) | 301 | static int omap3_pm_prepare(void) |
| 297 | { | 302 | { |
| 298 | disable_hlt(); | 303 | disable_hlt(); |
| @@ -321,7 +326,6 @@ static int omap3_pm_suspend(void) | |||
| 321 | restore: | 326 | restore: |
| 322 | /* Restore next_pwrsts */ | 327 | /* Restore next_pwrsts */ |
| 323 | list_for_each_entry(pwrst, &pwrst_list, node) { | 328 | list_for_each_entry(pwrst, &pwrst_list, node) { |
| 324 | set_pwrdm_state(pwrst->pwrdm, pwrst->saved_state); | ||
| 325 | state = pwrdm_read_prev_pwrst(pwrst->pwrdm); | 329 | state = pwrdm_read_prev_pwrst(pwrst->pwrdm); |
| 326 | if (state > pwrst->next_state) { | 330 | if (state > pwrst->next_state) { |
| 327 | printk(KERN_INFO "Powerdomain (%s) didn't enter " | 331 | printk(KERN_INFO "Powerdomain (%s) didn't enter " |
| @@ -329,6 +333,7 @@ restore: | |||
| 329 | pwrst->pwrdm->name, pwrst->next_state); | 333 | pwrst->pwrdm->name, pwrst->next_state); |
| 330 | ret = -1; | 334 | ret = -1; |
| 331 | } | 335 | } |
| 336 | set_pwrdm_state(pwrst->pwrdm, pwrst->saved_state); | ||
| 332 | } | 337 | } |
| 333 | if (ret) | 338 | if (ret) |
| 334 | printk(KERN_ERR "Could not enter target state in pm_suspend\n"); | 339 | printk(KERN_ERR "Could not enter target state in pm_suspend\n"); |
| @@ -339,11 +344,11 @@ restore: | |||
| 339 | return ret; | 344 | return ret; |
| 340 | } | 345 | } |
| 341 | 346 | ||
| 342 | static int omap3_pm_enter(suspend_state_t state) | 347 | static int omap3_pm_enter(suspend_state_t unused) |
| 343 | { | 348 | { |
| 344 | int ret = 0; | 349 | int ret = 0; |
| 345 | 350 | ||
| 346 | switch (state) { | 351 | switch (suspend_state) { |
| 347 | case PM_SUSPEND_STANDBY: | 352 | case PM_SUSPEND_STANDBY: |
| 348 | case PM_SUSPEND_MEM: | 353 | case PM_SUSPEND_MEM: |
| 349 | ret = omap3_pm_suspend(); | 354 | ret = omap3_pm_suspend(); |
| @@ -360,12 +365,30 @@ static void omap3_pm_finish(void) | |||
| 360 | enable_hlt(); | 365 | enable_hlt(); |
| 361 | } | 366 | } |
| 362 | 367 | ||
| 368 | /* Hooks to enable / disable UART interrupts during suspend */ | ||
| 369 | static int omap3_pm_begin(suspend_state_t state) | ||
| 370 | { | ||
| 371 | suspend_state = state; | ||
| 372 | omap_uart_enable_irqs(0); | ||
| 373 | return 0; | ||
| 374 | } | ||
| 375 | |||
| 376 | static void omap3_pm_end(void) | ||
| 377 | { | ||
| 378 | suspend_state = PM_SUSPEND_ON; | ||
| 379 | omap_uart_enable_irqs(1); | ||
| 380 | return; | ||
| 381 | } | ||
| 382 | |||
| 363 | static struct platform_suspend_ops omap_pm_ops = { | 383 | static struct platform_suspend_ops omap_pm_ops = { |
| 384 | .begin = omap3_pm_begin, | ||
| 385 | .end = omap3_pm_end, | ||
| 364 | .prepare = omap3_pm_prepare, | 386 | .prepare = omap3_pm_prepare, |
| 365 | .enter = omap3_pm_enter, | 387 | .enter = omap3_pm_enter, |
| 366 | .finish = omap3_pm_finish, | 388 | .finish = omap3_pm_finish, |
| 367 | .valid = suspend_valid_only_mem, | 389 | .valid = suspend_valid_only_mem, |
| 368 | }; | 390 | }; |
| 391 | #endif /* CONFIG_SUSPEND */ | ||
| 369 | 392 | ||
| 370 | 393 | ||
| 371 | /** | 394 | /** |
| @@ -613,6 +636,24 @@ static void __init prcm_setup_regs(void) | |||
| 613 | /* Clear any pending PRCM interrupts */ | 636 | /* Clear any pending PRCM interrupts */ |
| 614 | prm_write_mod_reg(0, OCP_MOD, OMAP3_PRM_IRQSTATUS_MPU_OFFSET); | 637 | prm_write_mod_reg(0, OCP_MOD, OMAP3_PRM_IRQSTATUS_MPU_OFFSET); |
| 615 | 638 | ||
| 639 | /* Don't attach IVA interrupts */ | ||
| 640 | prm_write_mod_reg(0, WKUP_MOD, OMAP3430_PM_IVAGRPSEL); | ||
| 641 | prm_write_mod_reg(0, CORE_MOD, OMAP3430_PM_IVAGRPSEL1); | ||
| 642 | prm_write_mod_reg(0, CORE_MOD, OMAP3430ES2_PM_IVAGRPSEL3); | ||
| 643 | prm_write_mod_reg(0, OMAP3430_PER_MOD, OMAP3430_PM_IVAGRPSEL); | ||
| 644 | |||
| 645 | /* Clear any pending 'reset' flags */ | ||
| 646 | prm_write_mod_reg(0xffffffff, MPU_MOD, RM_RSTST); | ||
| 647 | prm_write_mod_reg(0xffffffff, CORE_MOD, RM_RSTST); | ||
| 648 | prm_write_mod_reg(0xffffffff, OMAP3430_PER_MOD, RM_RSTST); | ||
| 649 | prm_write_mod_reg(0xffffffff, OMAP3430_EMU_MOD, RM_RSTST); | ||
| 650 | prm_write_mod_reg(0xffffffff, OMAP3430_NEON_MOD, RM_RSTST); | ||
| 651 | prm_write_mod_reg(0xffffffff, OMAP3430_DSS_MOD, RM_RSTST); | ||
| 652 | prm_write_mod_reg(0xffffffff, OMAP3430ES2_USBHOST_MOD, RM_RSTST); | ||
| 653 | |||
| 654 | /* Clear any pending PRCM interrupts */ | ||
| 655 | prm_write_mod_reg(0, OCP_MOD, OMAP3_PRM_IRQSTATUS_MPU_OFFSET); | ||
| 656 | |||
| 616 | omap3_iva_idle(); | 657 | omap3_iva_idle(); |
| 617 | omap3_d2d_idle(); | 658 | omap3_d2d_idle(); |
| 618 | } | 659 | } |
| @@ -652,7 +693,7 @@ static int __init clkdms_setup(struct clockdomain *clkdm) | |||
| 652 | return 0; | 693 | return 0; |
| 653 | } | 694 | } |
| 654 | 695 | ||
| 655 | int __init omap3_pm_init(void) | 696 | static int __init omap3_pm_init(void) |
| 656 | { | 697 | { |
| 657 | struct power_state *pwrst, *tmp; | 698 | struct power_state *pwrst, *tmp; |
| 658 | int ret; | 699 | int ret; |
| @@ -692,7 +733,9 @@ int __init omap3_pm_init(void) | |||
| 692 | _omap_sram_idle = omap_sram_push(omap34xx_cpu_suspend, | 733 | _omap_sram_idle = omap_sram_push(omap34xx_cpu_suspend, |
| 693 | omap34xx_cpu_suspend_sz); | 734 | omap34xx_cpu_suspend_sz); |
| 694 | 735 | ||
| 736 | #ifdef CONFIG_SUSPEND | ||
| 695 | suspend_set_ops(&omap_pm_ops); | 737 | suspend_set_ops(&omap_pm_ops); |
| 738 | #endif /* CONFIG_SUSPEND */ | ||
| 696 | 739 | ||
| 697 | pm_idle = omap3_pm_idle; | 740 | pm_idle = omap3_pm_idle; |
| 698 | 741 | ||
diff --git a/arch/arm/mach-omap2/prcm.c b/arch/arm/mach-omap2/prcm.c index f945156d5585..ced555a4cd1a 100644 --- a/arch/arm/mach-omap2/prcm.c +++ b/arch/arm/mach-omap2/prcm.c | |||
| @@ -17,6 +17,7 @@ | |||
| 17 | #include <linux/init.h> | 17 | #include <linux/init.h> |
| 18 | #include <linux/clk.h> | 18 | #include <linux/clk.h> |
| 19 | #include <linux/io.h> | 19 | #include <linux/io.h> |
| 20 | #include <linux/delay.h> | ||
| 20 | 21 | ||
| 21 | #include <mach/common.h> | 22 | #include <mach/common.h> |
| 22 | #include <mach/prcm.h> | 23 | #include <mach/prcm.h> |
| @@ -28,6 +29,8 @@ | |||
| 28 | static void __iomem *prm_base; | 29 | static void __iomem *prm_base; |
| 29 | static void __iomem *cm_base; | 30 | static void __iomem *cm_base; |
| 30 | 31 | ||
| 32 | #define MAX_MODULE_ENABLE_WAIT 100000 | ||
| 33 | |||
| 31 | u32 omap_prcm_get_reset_sources(void) | 34 | u32 omap_prcm_get_reset_sources(void) |
| 32 | { | 35 | { |
| 33 | /* XXX This presumably needs modification for 34XX */ | 36 | /* XXX This presumably needs modification for 34XX */ |
| @@ -120,6 +123,46 @@ u32 cm_rmw_mod_reg_bits(u32 mask, u32 bits, s16 module, s16 idx) | |||
| 120 | } | 123 | } |
| 121 | EXPORT_SYMBOL(cm_rmw_mod_reg_bits); | 124 | EXPORT_SYMBOL(cm_rmw_mod_reg_bits); |
| 122 | 125 | ||
| 126 | /** | ||
| 127 | * omap2_cm_wait_idlest - wait for IDLEST bit to indicate module readiness | ||
| 128 | * @reg: physical address of module IDLEST register | ||
| 129 | * @mask: value to mask against to determine if the module is active | ||
| 130 | * @name: name of the clock (for printk) | ||
| 131 | * | ||
| 132 | * Returns 1 if the module indicated readiness in time, or 0 if it | ||
| 133 | * failed to enable in roughly MAX_MODULE_ENABLE_WAIT microseconds. | ||
| 134 | */ | ||
| 135 | int omap2_cm_wait_idlest(void __iomem *reg, u32 mask, const char *name) | ||
| 136 | { | ||
| 137 | int i = 0; | ||
| 138 | int ena = 0; | ||
| 139 | |||
| 140 | /* | ||
| 141 | * 24xx uses 0 to indicate not ready, and 1 to indicate ready. | ||
| 142 | * 34xx reverses this, just to keep us on our toes | ||
| 143 | */ | ||
| 144 | if (cpu_is_omap24xx()) | ||
| 145 | ena = mask; | ||
| 146 | else if (cpu_is_omap34xx()) | ||
| 147 | ena = 0; | ||
| 148 | else | ||
| 149 | BUG(); | ||
| 150 | |||
| 151 | /* Wait for lock */ | ||
| 152 | while (((__raw_readl(reg) & mask) != ena) && | ||
| 153 | (i++ < MAX_MODULE_ENABLE_WAIT)) | ||
| 154 | udelay(1); | ||
| 155 | |||
| 156 | if (i < MAX_MODULE_ENABLE_WAIT) | ||
| 157 | pr_debug("cm: Module associated with clock %s ready after %d " | ||
| 158 | "loops\n", name, i); | ||
| 159 | else | ||
| 160 | pr_err("cm: Module associated with clock %s didn't enable in " | ||
| 161 | "%d tries\n", name, MAX_MODULE_ENABLE_WAIT); | ||
| 162 | |||
| 163 | return (i < MAX_MODULE_ENABLE_WAIT) ? 1 : 0; | ||
| 164 | }; | ||
| 165 | |||
| 123 | void __init omap2_set_globals_prcm(struct omap_globals *omap2_globals) | 166 | void __init omap2_set_globals_prcm(struct omap_globals *omap2_globals) |
| 124 | { | 167 | { |
| 125 | prm_base = omap2_globals->prm; | 168 | prm_base = omap2_globals->prm; |
diff --git a/arch/arm/mach-omap2/sdrc.c b/arch/arm/mach-omap2/sdrc.c index 2045441e8385..9e3bd4fa7810 100644 --- a/arch/arm/mach-omap2/sdrc.c +++ b/arch/arm/mach-omap2/sdrc.c | |||
| @@ -32,7 +32,7 @@ | |||
| 32 | #include <mach/sdrc.h> | 32 | #include <mach/sdrc.h> |
| 33 | #include "sdrc.h" | 33 | #include "sdrc.h" |
| 34 | 34 | ||
| 35 | static struct omap_sdrc_params *sdrc_init_params; | 35 | static struct omap_sdrc_params *sdrc_init_params_cs0, *sdrc_init_params_cs1; |
| 36 | 36 | ||
| 37 | void __iomem *omap2_sdrc_base; | 37 | void __iomem *omap2_sdrc_base; |
| 38 | void __iomem *omap2_sms_base; | 38 | void __iomem *omap2_sms_base; |
| @@ -45,33 +45,49 @@ void __iomem *omap2_sms_base; | |||
| 45 | /** | 45 | /** |
| 46 | * omap2_sdrc_get_params - return SDRC register values for a given clock rate | 46 | * omap2_sdrc_get_params - return SDRC register values for a given clock rate |
| 47 | * @r: SDRC clock rate (in Hz) | 47 | * @r: SDRC clock rate (in Hz) |
| 48 | * @sdrc_cs0: chip select 0 ram timings ** | ||
| 49 | * @sdrc_cs1: chip select 1 ram timings ** | ||
| 48 | * | 50 | * |
| 49 | * Return pre-calculated values for the SDRC_ACTIM_CTRLA, | 51 | * Return pre-calculated values for the SDRC_ACTIM_CTRLA, |
| 50 | * SDRC_ACTIM_CTRLB, SDRC_RFR_CTRL, and SDRC_MR registers, for a given | 52 | * SDRC_ACTIM_CTRLB, SDRC_RFR_CTRL and SDRC_MR registers in sdrc_cs[01] |
| 51 | * SDRC clock rate 'r'. These parameters control various timing | 53 | * structs,for a given SDRC clock rate 'r'. |
| 52 | * delays in the SDRAM controller that are expressed in terms of the | 54 | * These parameters control various timing delays in the SDRAM controller |
| 53 | * number of SDRC clock cycles to wait; hence the clock rate | 55 | * that are expressed in terms of the number of SDRC clock cycles to |
| 54 | * dependency. Note that sdrc_init_params must be sorted rate | 56 | * wait; hence the clock rate dependency. |
| 55 | * descending. Also assumes that both chip-selects use the same | 57 | * |
| 56 | * timing parameters. Returns a struct omap_sdrc_params * upon | 58 | * Supports 2 different timing parameters for both chip selects. |
| 57 | * success, or NULL upon failure. | 59 | * |
| 60 | * Note 1: the sdrc_init_params_cs[01] must be sorted rate descending. | ||
| 61 | * Note 2: If sdrc_init_params_cs_1 is not NULL it must be of same size | ||
| 62 | * as sdrc_init_params_cs_0. | ||
| 63 | * | ||
| 64 | * Fills in the struct omap_sdrc_params * for each chip select. | ||
| 65 | * Returns 0 upon success or -1 upon failure. | ||
| 58 | */ | 66 | */ |
| 59 | struct omap_sdrc_params *omap2_sdrc_get_params(unsigned long r) | 67 | int omap2_sdrc_get_params(unsigned long r, |
| 68 | struct omap_sdrc_params **sdrc_cs0, | ||
| 69 | struct omap_sdrc_params **sdrc_cs1) | ||
| 60 | { | 70 | { |
| 61 | struct omap_sdrc_params *sp; | 71 | struct omap_sdrc_params *sp0, *sp1; |
| 62 | 72 | ||
| 63 | if (!sdrc_init_params) | 73 | if (!sdrc_init_params_cs0) |
| 64 | return NULL; | 74 | return -1; |
| 65 | 75 | ||
| 66 | sp = sdrc_init_params; | 76 | sp0 = sdrc_init_params_cs0; |
| 77 | sp1 = sdrc_init_params_cs1; | ||
| 67 | 78 | ||
| 68 | while (sp->rate && sp->rate != r) | 79 | while (sp0->rate && sp0->rate != r) { |
| 69 | sp++; | 80 | sp0++; |
| 81 | if (sdrc_init_params_cs1) | ||
| 82 | sp1++; | ||
| 83 | } | ||
| 70 | 84 | ||
| 71 | if (!sp->rate) | 85 | if (!sp0->rate) |
| 72 | return NULL; | 86 | return -1; |
| 73 | 87 | ||
| 74 | return sp; | 88 | *sdrc_cs0 = sp0; |
| 89 | *sdrc_cs1 = sp1; | ||
| 90 | return 0; | ||
| 75 | } | 91 | } |
| 76 | 92 | ||
| 77 | 93 | ||
| @@ -83,13 +99,15 @@ void __init omap2_set_globals_sdrc(struct omap_globals *omap2_globals) | |||
| 83 | 99 | ||
| 84 | /** | 100 | /** |
| 85 | * omap2_sdrc_init - initialize SMS, SDRC devices on boot | 101 | * omap2_sdrc_init - initialize SMS, SDRC devices on boot |
| 86 | * @sp: pointer to a null-terminated list of struct omap_sdrc_params | 102 | * @sdrc_cs[01]: pointers to a null-terminated list of struct omap_sdrc_params |
| 103 | * Support for 2 chip selects timings | ||
| 87 | * | 104 | * |
| 88 | * Turn on smart idle modes for SDRAM scheduler and controller. | 105 | * Turn on smart idle modes for SDRAM scheduler and controller. |
| 89 | * Program a known-good configuration for the SDRC to deal with buggy | 106 | * Program a known-good configuration for the SDRC to deal with buggy |
| 90 | * bootloaders. | 107 | * bootloaders. |
| 91 | */ | 108 | */ |
| 92 | void __init omap2_sdrc_init(struct omap_sdrc_params *sp) | 109 | void __init omap2_sdrc_init(struct omap_sdrc_params *sdrc_cs0, |
| 110 | struct omap_sdrc_params *sdrc_cs1) | ||
| 93 | { | 111 | { |
| 94 | u32 l; | 112 | u32 l; |
| 95 | 113 | ||
| @@ -103,11 +121,15 @@ void __init omap2_sdrc_init(struct omap_sdrc_params *sp) | |||
| 103 | l |= (0x2 << 3); | 121 | l |= (0x2 << 3); |
| 104 | sdrc_write_reg(l, SDRC_SYSCONFIG); | 122 | sdrc_write_reg(l, SDRC_SYSCONFIG); |
| 105 | 123 | ||
| 106 | sdrc_init_params = sp; | 124 | sdrc_init_params_cs0 = sdrc_cs0; |
| 125 | sdrc_init_params_cs1 = sdrc_cs1; | ||
| 107 | 126 | ||
| 108 | /* XXX Enable SRFRONIDLEREQ here also? */ | 127 | /* XXX Enable SRFRONIDLEREQ here also? */ |
| 128 | /* | ||
| 129 | * PWDENA should not be set due to 34xx erratum 1.150 - PWDENA | ||
| 130 | * can cause random memory corruption | ||
| 131 | */ | ||
| 109 | l = (1 << SDRC_POWER_EXTCLKDIS_SHIFT) | | 132 | l = (1 << SDRC_POWER_EXTCLKDIS_SHIFT) | |
| 110 | (1 << SDRC_POWER_PWDENA_SHIFT) | | ||
| 111 | (1 << SDRC_POWER_PAGEPOLICY_SHIFT); | 133 | (1 << SDRC_POWER_PAGEPOLICY_SHIFT); |
| 112 | sdrc_write_reg(l, SDRC_POWER); | 134 | sdrc_write_reg(l, SDRC_POWER); |
| 113 | } | 135 | } |
diff --git a/arch/arm/mach-omap2/serial.c b/arch/arm/mach-omap2/serial.c index b094c15bfe47..a7421a50410b 100644 --- a/arch/arm/mach-omap2/serial.c +++ b/arch/arm/mach-omap2/serial.c | |||
| @@ -54,6 +54,7 @@ struct omap_uart_state { | |||
| 54 | 54 | ||
| 55 | struct plat_serial8250_port *p; | 55 | struct plat_serial8250_port *p; |
| 56 | struct list_head node; | 56 | struct list_head node; |
| 57 | struct platform_device pdev; | ||
| 57 | 58 | ||
| 58 | #if defined(CONFIG_ARCH_OMAP3) && defined(CONFIG_PM) | 59 | #if defined(CONFIG_ARCH_OMAP3) && defined(CONFIG_PM) |
| 59 | int context_valid; | 60 | int context_valid; |
| @@ -68,10 +69,9 @@ struct omap_uart_state { | |||
| 68 | #endif | 69 | #endif |
| 69 | }; | 70 | }; |
| 70 | 71 | ||
| 71 | static struct omap_uart_state omap_uart[OMAP_MAX_NR_PORTS]; | ||
| 72 | static LIST_HEAD(uart_list); | 72 | static LIST_HEAD(uart_list); |
| 73 | 73 | ||
| 74 | static struct plat_serial8250_port serial_platform_data[] = { | 74 | static struct plat_serial8250_port serial_platform_data0[] = { |
| 75 | { | 75 | { |
| 76 | .membase = IO_ADDRESS(OMAP_UART1_BASE), | 76 | .membase = IO_ADDRESS(OMAP_UART1_BASE), |
| 77 | .mapbase = OMAP_UART1_BASE, | 77 | .mapbase = OMAP_UART1_BASE, |
| @@ -81,6 +81,12 @@ static struct plat_serial8250_port serial_platform_data[] = { | |||
| 81 | .regshift = 2, | 81 | .regshift = 2, |
| 82 | .uartclk = OMAP24XX_BASE_BAUD * 16, | 82 | .uartclk = OMAP24XX_BASE_BAUD * 16, |
| 83 | }, { | 83 | }, { |
| 84 | .flags = 0 | ||
| 85 | } | ||
| 86 | }; | ||
| 87 | |||
| 88 | static struct plat_serial8250_port serial_platform_data1[] = { | ||
| 89 | { | ||
| 84 | .membase = IO_ADDRESS(OMAP_UART2_BASE), | 90 | .membase = IO_ADDRESS(OMAP_UART2_BASE), |
| 85 | .mapbase = OMAP_UART2_BASE, | 91 | .mapbase = OMAP_UART2_BASE, |
| 86 | .irq = 73, | 92 | .irq = 73, |
| @@ -89,6 +95,12 @@ static struct plat_serial8250_port serial_platform_data[] = { | |||
| 89 | .regshift = 2, | 95 | .regshift = 2, |
| 90 | .uartclk = OMAP24XX_BASE_BAUD * 16, | 96 | .uartclk = OMAP24XX_BASE_BAUD * 16, |
| 91 | }, { | 97 | }, { |
| 98 | .flags = 0 | ||
| 99 | } | ||
| 100 | }; | ||
| 101 | |||
| 102 | static struct plat_serial8250_port serial_platform_data2[] = { | ||
| 103 | { | ||
| 92 | .membase = IO_ADDRESS(OMAP_UART3_BASE), | 104 | .membase = IO_ADDRESS(OMAP_UART3_BASE), |
| 93 | .mapbase = OMAP_UART3_BASE, | 105 | .mapbase = OMAP_UART3_BASE, |
| 94 | .irq = 74, | 106 | .irq = 74, |
| @@ -217,6 +229,40 @@ static inline void omap_uart_disable_clocks(struct omap_uart_state *uart) | |||
| 217 | clk_disable(uart->fck); | 229 | clk_disable(uart->fck); |
| 218 | } | 230 | } |
| 219 | 231 | ||
| 232 | static void omap_uart_enable_wakeup(struct omap_uart_state *uart) | ||
| 233 | { | ||
| 234 | /* Set wake-enable bit */ | ||
| 235 | if (uart->wk_en && uart->wk_mask) { | ||
| 236 | u32 v = __raw_readl(uart->wk_en); | ||
| 237 | v |= uart->wk_mask; | ||
| 238 | __raw_writel(v, uart->wk_en); | ||
| 239 | } | ||
| 240 | |||
| 241 | /* Ensure IOPAD wake-enables are set */ | ||
| 242 | if (cpu_is_omap34xx() && uart->padconf) { | ||
| 243 | u16 v = omap_ctrl_readw(uart->padconf); | ||
| 244 | v |= OMAP3_PADCONF_WAKEUPENABLE0; | ||
| 245 | omap_ctrl_writew(v, uart->padconf); | ||
| 246 | } | ||
| 247 | } | ||
| 248 | |||
| 249 | static void omap_uart_disable_wakeup(struct omap_uart_state *uart) | ||
| 250 | { | ||
| 251 | /* Clear wake-enable bit */ | ||
| 252 | if (uart->wk_en && uart->wk_mask) { | ||
| 253 | u32 v = __raw_readl(uart->wk_en); | ||
| 254 | v &= ~uart->wk_mask; | ||
| 255 | __raw_writel(v, uart->wk_en); | ||
| 256 | } | ||
| 257 | |||
| 258 | /* Ensure IOPAD wake-enables are cleared */ | ||
| 259 | if (cpu_is_omap34xx() && uart->padconf) { | ||
| 260 | u16 v = omap_ctrl_readw(uart->padconf); | ||
| 261 | v &= ~OMAP3_PADCONF_WAKEUPENABLE0; | ||
| 262 | omap_ctrl_writew(v, uart->padconf); | ||
| 263 | } | ||
| 264 | } | ||
| 265 | |||
| 220 | static void omap_uart_smart_idle_enable(struct omap_uart_state *uart, | 266 | static void omap_uart_smart_idle_enable(struct omap_uart_state *uart, |
| 221 | int enable) | 267 | int enable) |
| 222 | { | 268 | { |
| @@ -246,6 +292,11 @@ static void omap_uart_block_sleep(struct omap_uart_state *uart) | |||
| 246 | 292 | ||
| 247 | static void omap_uart_allow_sleep(struct omap_uart_state *uart) | 293 | static void omap_uart_allow_sleep(struct omap_uart_state *uart) |
| 248 | { | 294 | { |
| 295 | if (device_may_wakeup(&uart->pdev.dev)) | ||
| 296 | omap_uart_enable_wakeup(uart); | ||
| 297 | else | ||
| 298 | omap_uart_disable_wakeup(uart); | ||
| 299 | |||
| 249 | if (!uart->clocked) | 300 | if (!uart->clocked) |
| 250 | return; | 301 | return; |
| 251 | 302 | ||
| @@ -292,7 +343,6 @@ void omap_uart_resume_idle(int num) | |||
| 292 | /* Check for normal UART wakeup */ | 343 | /* Check for normal UART wakeup */ |
| 293 | if (__raw_readl(uart->wk_st) & uart->wk_mask) | 344 | if (__raw_readl(uart->wk_st) & uart->wk_mask) |
| 294 | omap_uart_block_sleep(uart); | 345 | omap_uart_block_sleep(uart); |
| 295 | |||
| 296 | return; | 346 | return; |
| 297 | } | 347 | } |
| 298 | } | 348 | } |
| @@ -346,16 +396,13 @@ static irqreturn_t omap_uart_interrupt(int irq, void *dev_id) | |||
| 346 | return IRQ_NONE; | 396 | return IRQ_NONE; |
| 347 | } | 397 | } |
| 348 | 398 | ||
| 349 | static u32 sleep_timeout = DEFAULT_TIMEOUT; | ||
| 350 | |||
| 351 | static void omap_uart_idle_init(struct omap_uart_state *uart) | 399 | static void omap_uart_idle_init(struct omap_uart_state *uart) |
| 352 | { | 400 | { |
| 353 | u32 v; | ||
| 354 | struct plat_serial8250_port *p = uart->p; | 401 | struct plat_serial8250_port *p = uart->p; |
| 355 | int ret; | 402 | int ret; |
| 356 | 403 | ||
| 357 | uart->can_sleep = 0; | 404 | uart->can_sleep = 0; |
| 358 | uart->timeout = sleep_timeout; | 405 | uart->timeout = DEFAULT_TIMEOUT; |
| 359 | setup_timer(&uart->timer, omap_uart_idle_timer, | 406 | setup_timer(&uart->timer, omap_uart_idle_timer, |
| 360 | (unsigned long) uart); | 407 | (unsigned long) uart); |
| 361 | mod_timer(&uart->timer, jiffies + uart->timeout); | 408 | mod_timer(&uart->timer, jiffies + uart->timeout); |
| @@ -413,76 +460,101 @@ static void omap_uart_idle_init(struct omap_uart_state *uart) | |||
| 413 | uart->padconf = 0; | 460 | uart->padconf = 0; |
| 414 | } | 461 | } |
| 415 | 462 | ||
| 416 | /* Set wake-enable bit */ | ||
| 417 | if (uart->wk_en && uart->wk_mask) { | ||
| 418 | v = __raw_readl(uart->wk_en); | ||
| 419 | v |= uart->wk_mask; | ||
| 420 | __raw_writel(v, uart->wk_en); | ||
| 421 | } | ||
| 422 | |||
| 423 | /* Ensure IOPAD wake-enables are set */ | ||
| 424 | if (cpu_is_omap34xx() && uart->padconf) { | ||
| 425 | u16 v; | ||
| 426 | |||
| 427 | v = omap_ctrl_readw(uart->padconf); | ||
| 428 | v |= OMAP3_PADCONF_WAKEUPENABLE0; | ||
| 429 | omap_ctrl_writew(v, uart->padconf); | ||
| 430 | } | ||
| 431 | |||
| 432 | p->flags |= UPF_SHARE_IRQ; | 463 | p->flags |= UPF_SHARE_IRQ; |
| 433 | ret = request_irq(p->irq, omap_uart_interrupt, IRQF_SHARED, | 464 | ret = request_irq(p->irq, omap_uart_interrupt, IRQF_SHARED, |
| 434 | "serial idle", (void *)uart); | 465 | "serial idle", (void *)uart); |
| 435 | WARN_ON(ret); | 466 | WARN_ON(ret); |
| 436 | } | 467 | } |
| 437 | 468 | ||
| 438 | static ssize_t sleep_timeout_show(struct kobject *kobj, | 469 | void omap_uart_enable_irqs(int enable) |
| 439 | struct kobj_attribute *attr, | 470 | { |
| 471 | int ret; | ||
| 472 | struct omap_uart_state *uart; | ||
| 473 | |||
| 474 | list_for_each_entry(uart, &uart_list, node) { | ||
| 475 | if (enable) | ||
| 476 | ret = request_irq(uart->p->irq, omap_uart_interrupt, | ||
| 477 | IRQF_SHARED, "serial idle", (void *)uart); | ||
| 478 | else | ||
| 479 | free_irq(uart->p->irq, (void *)uart); | ||
| 480 | } | ||
| 481 | } | ||
| 482 | |||
| 483 | static ssize_t sleep_timeout_show(struct device *dev, | ||
| 484 | struct device_attribute *attr, | ||
| 440 | char *buf) | 485 | char *buf) |
| 441 | { | 486 | { |
| 442 | return sprintf(buf, "%u\n", sleep_timeout / HZ); | 487 | struct platform_device *pdev = container_of(dev, |
| 488 | struct platform_device, dev); | ||
| 489 | struct omap_uart_state *uart = container_of(pdev, | ||
| 490 | struct omap_uart_state, pdev); | ||
| 491 | |||
| 492 | return sprintf(buf, "%u\n", uart->timeout / HZ); | ||
| 443 | } | 493 | } |
| 444 | 494 | ||
| 445 | static ssize_t sleep_timeout_store(struct kobject *kobj, | 495 | static ssize_t sleep_timeout_store(struct device *dev, |
| 446 | struct kobj_attribute *attr, | 496 | struct device_attribute *attr, |
| 447 | const char *buf, size_t n) | 497 | const char *buf, size_t n) |
| 448 | { | 498 | { |
| 449 | struct omap_uart_state *uart; | 499 | struct platform_device *pdev = container_of(dev, |
| 500 | struct platform_device, dev); | ||
| 501 | struct omap_uart_state *uart = container_of(pdev, | ||
| 502 | struct omap_uart_state, pdev); | ||
| 450 | unsigned int value; | 503 | unsigned int value; |
| 451 | 504 | ||
| 452 | if (sscanf(buf, "%u", &value) != 1) { | 505 | if (sscanf(buf, "%u", &value) != 1) { |
| 453 | printk(KERN_ERR "sleep_timeout_store: Invalid value\n"); | 506 | printk(KERN_ERR "sleep_timeout_store: Invalid value\n"); |
| 454 | return -EINVAL; | 507 | return -EINVAL; |
| 455 | } | 508 | } |
| 456 | sleep_timeout = value * HZ; | 509 | |
| 457 | list_for_each_entry(uart, &uart_list, node) { | 510 | uart->timeout = value * HZ; |
| 458 | uart->timeout = sleep_timeout; | 511 | if (uart->timeout) |
| 459 | if (uart->timeout) | 512 | mod_timer(&uart->timer, jiffies + uart->timeout); |
| 460 | mod_timer(&uart->timer, jiffies + uart->timeout); | 513 | else |
| 461 | else | 514 | /* A zero value means disable timeout feature */ |
| 462 | /* A zero value means disable timeout feature */ | 515 | omap_uart_block_sleep(uart); |
| 463 | omap_uart_block_sleep(uart); | 516 | |
| 464 | } | ||
| 465 | return n; | 517 | return n; |
| 466 | } | 518 | } |
| 467 | 519 | ||
| 468 | static struct kobj_attribute sleep_timeout_attr = | 520 | DEVICE_ATTR(sleep_timeout, 0644, sleep_timeout_show, sleep_timeout_store); |
| 469 | __ATTR(sleep_timeout, 0644, sleep_timeout_show, sleep_timeout_store); | 521 | #define DEV_CREATE_FILE(dev, attr) WARN_ON(device_create_file(dev, attr)) |
| 470 | |||
| 471 | #else | 522 | #else |
| 472 | static inline void omap_uart_idle_init(struct omap_uart_state *uart) {} | 523 | static inline void omap_uart_idle_init(struct omap_uart_state *uart) {} |
| 524 | #define DEV_CREATE_FILE(dev, attr) | ||
| 473 | #endif /* CONFIG_PM */ | 525 | #endif /* CONFIG_PM */ |
| 474 | 526 | ||
| 475 | static struct platform_device serial_device = { | 527 | static struct omap_uart_state omap_uart[OMAP_MAX_NR_PORTS] = { |
| 476 | .name = "serial8250", | 528 | { |
| 477 | .id = PLAT8250_DEV_PLATFORM, | 529 | .pdev = { |
| 478 | .dev = { | 530 | .name = "serial8250", |
| 479 | .platform_data = serial_platform_data, | 531 | .id = PLAT8250_DEV_PLATFORM, |
| 532 | .dev = { | ||
| 533 | .platform_data = serial_platform_data0, | ||
| 534 | }, | ||
| 535 | }, | ||
| 536 | }, { | ||
| 537 | .pdev = { | ||
| 538 | .name = "serial8250", | ||
| 539 | .id = PLAT8250_DEV_PLATFORM1, | ||
| 540 | .dev = { | ||
| 541 | .platform_data = serial_platform_data1, | ||
| 542 | }, | ||
| 543 | }, | ||
| 544 | }, { | ||
| 545 | .pdev = { | ||
| 546 | .name = "serial8250", | ||
| 547 | .id = PLAT8250_DEV_PLATFORM2, | ||
| 548 | .dev = { | ||
| 549 | .platform_data = serial_platform_data2, | ||
| 550 | }, | ||
| 551 | }, | ||
| 480 | }, | 552 | }, |
| 481 | }; | 553 | }; |
| 482 | 554 | ||
| 483 | void __init omap_serial_init(void) | 555 | void __init omap_serial_init(void) |
| 484 | { | 556 | { |
| 485 | int i, err; | 557 | int i; |
| 486 | const struct omap_uart_config *info; | 558 | const struct omap_uart_config *info; |
| 487 | char name[16]; | 559 | char name[16]; |
| 488 | 560 | ||
| @@ -496,14 +568,12 @@ void __init omap_serial_init(void) | |||
| 496 | 568 | ||
| 497 | if (info == NULL) | 569 | if (info == NULL) |
| 498 | return; | 570 | return; |
| 499 | if (cpu_is_omap44xx()) { | ||
| 500 | for (i = 0; i < OMAP_MAX_NR_PORTS; i++) | ||
| 501 | serial_platform_data[i].irq += 32; | ||
| 502 | } | ||
| 503 | 571 | ||
| 504 | for (i = 0; i < OMAP_MAX_NR_PORTS; i++) { | 572 | for (i = 0; i < OMAP_MAX_NR_PORTS; i++) { |
| 505 | struct plat_serial8250_port *p = serial_platform_data + i; | ||
| 506 | struct omap_uart_state *uart = &omap_uart[i]; | 573 | struct omap_uart_state *uart = &omap_uart[i]; |
| 574 | struct platform_device *pdev = &uart->pdev; | ||
| 575 | struct device *dev = &pdev->dev; | ||
| 576 | struct plat_serial8250_port *p = dev->platform_data; | ||
| 507 | 577 | ||
| 508 | if (!(info->enabled_uarts & (1 << i))) { | 578 | if (!(info->enabled_uarts & (1 << i))) { |
| 509 | p->membase = NULL; | 579 | p->membase = NULL; |
| @@ -531,20 +601,21 @@ void __init omap_serial_init(void) | |||
| 531 | uart->num = i; | 601 | uart->num = i; |
| 532 | p->private_data = uart; | 602 | p->private_data = uart; |
| 533 | uart->p = p; | 603 | uart->p = p; |
| 534 | list_add(&uart->node, &uart_list); | 604 | list_add_tail(&uart->node, &uart_list); |
| 605 | |||
| 606 | if (cpu_is_omap44xx()) | ||
| 607 | p->irq += 32; | ||
| 535 | 608 | ||
| 536 | omap_uart_enable_clocks(uart); | 609 | omap_uart_enable_clocks(uart); |
| 537 | omap_uart_reset(uart); | 610 | omap_uart_reset(uart); |
| 538 | omap_uart_idle_init(uart); | 611 | omap_uart_idle_init(uart); |
| 539 | } | ||
| 540 | |||
| 541 | err = platform_device_register(&serial_device); | ||
| 542 | |||
| 543 | #ifdef CONFIG_PM | ||
| 544 | if (!err) | ||
| 545 | err = sysfs_create_file(&serial_device.dev.kobj, | ||
| 546 | &sleep_timeout_attr.attr); | ||
| 547 | #endif | ||
| 548 | 612 | ||
| 613 | if (WARN_ON(platform_device_register(pdev))) | ||
| 614 | continue; | ||
| 615 | if ((cpu_is_omap34xx() && uart->padconf) || | ||
| 616 | (uart->wk_en && uart->wk_mask)) { | ||
| 617 | device_init_wakeup(dev, true); | ||
| 618 | DEV_CREATE_FILE(dev, &dev_attr_sleep_timeout); | ||
| 619 | } | ||
| 620 | } | ||
| 549 | } | 621 | } |
| 550 | |||
diff --git a/arch/arm/mach-omap2/sram34xx.S b/arch/arm/mach-omap2/sram34xx.S index f41f8d96ddba..82aa4a3d160c 100644 --- a/arch/arm/mach-omap2/sram34xx.S +++ b/arch/arm/mach-omap2/sram34xx.S | |||
| @@ -36,7 +36,7 @@ | |||
| 36 | 36 | ||
| 37 | .text | 37 | .text |
| 38 | 38 | ||
| 39 | /* r4 parameters */ | 39 | /* r1 parameters */ |
| 40 | #define SDRC_NO_UNLOCK_DLL 0x0 | 40 | #define SDRC_NO_UNLOCK_DLL 0x0 |
| 41 | #define SDRC_UNLOCK_DLL 0x1 | 41 | #define SDRC_UNLOCK_DLL 0x1 |
| 42 | 42 | ||
| @@ -58,7 +58,6 @@ | |||
| 58 | 58 | ||
| 59 | /* SDRC_POWER bit settings */ | 59 | /* SDRC_POWER bit settings */ |
| 60 | #define SRFRONIDLEREQ_MASK 0x40 | 60 | #define SRFRONIDLEREQ_MASK 0x40 |
| 61 | #define PWDENA_MASK 0x4 | ||
| 62 | 61 | ||
| 63 | /* CM_IDLEST1_CORE bit settings */ | 62 | /* CM_IDLEST1_CORE bit settings */ |
| 64 | #define ST_SDRC_MASK 0x2 | 63 | #define ST_SDRC_MASK 0x2 |
| @@ -71,41 +70,72 @@ | |||
| 71 | 70 | ||
| 72 | /* | 71 | /* |
| 73 | * omap3_sram_configure_core_dpll - change DPLL3 M2 divider | 72 | * omap3_sram_configure_core_dpll - change DPLL3 M2 divider |
| 74 | * r0 = new SDRC_RFR_CTRL register contents | 73 | * |
| 75 | * r1 = new SDRC_ACTIM_CTRLA register contents | 74 | * Params passed in registers: |
| 76 | * r2 = new SDRC_ACTIM_CTRLB register contents | 75 | * r0 = new M2 divider setting (only 1 and 2 supported right now) |
| 77 | * r3 = new M2 divider setting (only 1 and 2 supported right now) | 76 | * r1 = unlock SDRC DLL? (1 = yes, 0 = no). Only unlock DLL for |
| 78 | * r4 = unlock SDRC DLL? (1 = yes, 0 = no). Only unlock DLL for | ||
| 79 | * SDRC rates < 83MHz | 77 | * SDRC rates < 83MHz |
| 80 | * r5 = number of MPU cycles to wait for SDRC to stabilize after | 78 | * r2 = number of MPU cycles to wait for SDRC to stabilize after |
| 81 | * reprogramming the SDRC when switching to a slower MPU speed | 79 | * reprogramming the SDRC when switching to a slower MPU speed |
| 82 | * r6 = new SDRC_MR_0 register value | 80 | * r3 = increasing SDRC rate? (1 = yes, 0 = no) |
| 83 | * r7 = increasing SDRC rate? (1 = yes, 0 = no) | 81 | * |
| 82 | * Params passed via the stack. The needed params will be copied in SRAM | ||
| 83 | * before use by the code in SRAM (SDRAM is not accessible during SDRC | ||
| 84 | * reconfiguration): | ||
| 85 | * new SDRC_RFR_CTRL_0 register contents | ||
| 86 | * new SDRC_ACTIM_CTRL_A_0 register contents | ||
| 87 | * new SDRC_ACTIM_CTRL_B_0 register contents | ||
| 88 | * new SDRC_MR_0 register value | ||
| 89 | * new SDRC_RFR_CTRL_1 register contents | ||
| 90 | * new SDRC_ACTIM_CTRL_A_1 register contents | ||
| 91 | * new SDRC_ACTIM_CTRL_B_1 register contents | ||
| 92 | * new SDRC_MR_1 register value | ||
| 84 | * | 93 | * |
| 94 | * If the param SDRC_RFR_CTRL_1 is 0, the parameters | ||
| 95 | * are not programmed into the SDRC CS1 registers | ||
| 85 | */ | 96 | */ |
| 86 | ENTRY(omap3_sram_configure_core_dpll) | 97 | ENTRY(omap3_sram_configure_core_dpll) |
| 87 | stmfd sp!, {r1-r12, lr} @ store regs to stack | 98 | stmfd sp!, {r1-r12, lr} @ store regs to stack |
| 88 | ldr r4, [sp, #52] @ pull extra args off the stack | 99 | |
| 89 | ldr r5, [sp, #56] @ load extra args from the stack | 100 | @ pull the extra args off the stack |
| 90 | ldr r6, [sp, #60] @ load extra args from the stack | 101 | @ and store them in SRAM |
| 91 | ldr r7, [sp, #64] @ load extra args from the stack | 102 | ldr r4, [sp, #52] |
| 103 | str r4, omap_sdrc_rfr_ctrl_0_val | ||
| 104 | ldr r4, [sp, #56] | ||
| 105 | str r4, omap_sdrc_actim_ctrl_a_0_val | ||
| 106 | ldr r4, [sp, #60] | ||
| 107 | str r4, omap_sdrc_actim_ctrl_b_0_val | ||
| 108 | ldr r4, [sp, #64] | ||
| 109 | str r4, omap_sdrc_mr_0_val | ||
| 110 | ldr r4, [sp, #68] | ||
| 111 | str r4, omap_sdrc_rfr_ctrl_1_val | ||
| 112 | cmp r4, #0 @ if SDRC_RFR_CTRL_1 is 0, | ||
| 113 | beq skip_cs1_params @ do not use cs1 params | ||
| 114 | ldr r4, [sp, #72] | ||
| 115 | str r4, omap_sdrc_actim_ctrl_a_1_val | ||
| 116 | ldr r4, [sp, #76] | ||
| 117 | str r4, omap_sdrc_actim_ctrl_b_1_val | ||
| 118 | ldr r4, [sp, #80] | ||
| 119 | str r4, omap_sdrc_mr_1_val | ||
| 120 | skip_cs1_params: | ||
| 92 | dsb @ flush buffered writes to interconnect | 121 | dsb @ flush buffered writes to interconnect |
| 93 | cmp r7, #1 @ if increasing SDRC clk rate, | 122 | |
| 123 | cmp r3, #1 @ if increasing SDRC clk rate, | ||
| 94 | bleq configure_sdrc @ program the SDRC regs early (for RFR) | 124 | bleq configure_sdrc @ program the SDRC regs early (for RFR) |
| 95 | cmp r4, #SDRC_UNLOCK_DLL @ set the intended DLL state | 125 | cmp r1, #SDRC_UNLOCK_DLL @ set the intended DLL state |
| 96 | bleq unlock_dll | 126 | bleq unlock_dll |
| 97 | blne lock_dll | 127 | blne lock_dll |
| 98 | bl sdram_in_selfrefresh @ put SDRAM in self refresh, idle SDRC | 128 | bl sdram_in_selfrefresh @ put SDRAM in self refresh, idle SDRC |
| 99 | bl configure_core_dpll @ change the DPLL3 M2 divider | 129 | bl configure_core_dpll @ change the DPLL3 M2 divider |
| 130 | mov r12, r2 | ||
| 131 | bl wait_clk_stable @ wait for SDRC to stabilize | ||
| 100 | bl enable_sdrc @ take SDRC out of idle | 132 | bl enable_sdrc @ take SDRC out of idle |
| 101 | cmp r4, #SDRC_UNLOCK_DLL @ wait for DLL status to change | 133 | cmp r1, #SDRC_UNLOCK_DLL @ wait for DLL status to change |
| 102 | bleq wait_dll_unlock | 134 | bleq wait_dll_unlock |
| 103 | blne wait_dll_lock | 135 | blne wait_dll_lock |
| 104 | cmp r7, #1 @ if increasing SDRC clk rate, | 136 | cmp r3, #1 @ if increasing SDRC clk rate, |
| 105 | beq return_to_sdram @ return to SDRAM code, otherwise, | 137 | beq return_to_sdram @ return to SDRAM code, otherwise, |
| 106 | bl configure_sdrc @ reprogram SDRC regs now | 138 | bl configure_sdrc @ reprogram SDRC regs now |
| 107 | mov r12, r5 | ||
| 108 | bl wait_clk_stable @ wait for SDRC to stabilize | ||
| 109 | return_to_sdram: | 139 | return_to_sdram: |
| 110 | isb @ prevent speculative exec past here | 140 | isb @ prevent speculative exec past here |
| 111 | mov r0, #0 @ return value | 141 | mov r0, #0 @ return value |
| @@ -113,7 +143,7 @@ return_to_sdram: | |||
| 113 | unlock_dll: | 143 | unlock_dll: |
| 114 | ldr r11, omap3_sdrc_dlla_ctrl | 144 | ldr r11, omap3_sdrc_dlla_ctrl |
| 115 | ldr r12, [r11] | 145 | ldr r12, [r11] |
| 116 | and r12, r12, #FIXEDDELAY_MASK | 146 | bic r12, r12, #FIXEDDELAY_MASK |
| 117 | orr r12, r12, #FIXEDDELAY_DEFAULT | 147 | orr r12, r12, #FIXEDDELAY_DEFAULT |
| 118 | orr r12, r12, #DLLIDLE_MASK | 148 | orr r12, r12, #DLLIDLE_MASK |
| 119 | str r12, [r11] @ (no OCP barrier needed) | 149 | str r12, [r11] @ (no OCP barrier needed) |
| @@ -129,7 +159,6 @@ sdram_in_selfrefresh: | |||
| 129 | ldr r12, [r11] @ read the contents of SDRC_POWER | 159 | ldr r12, [r11] @ read the contents of SDRC_POWER |
| 130 | mov r9, r12 @ keep a copy of SDRC_POWER bits | 160 | mov r9, r12 @ keep a copy of SDRC_POWER bits |
| 131 | orr r12, r12, #SRFRONIDLEREQ_MASK @ enable self refresh on idle | 161 | orr r12, r12, #SRFRONIDLEREQ_MASK @ enable self refresh on idle |
| 132 | bic r12, r12, #PWDENA_MASK @ clear PWDENA | ||
| 133 | str r12, [r11] @ write back to SDRC_POWER register | 162 | str r12, [r11] @ write back to SDRC_POWER register |
| 134 | ldr r12, [r11] @ posted-write barrier for SDRC | 163 | ldr r12, [r11] @ posted-write barrier for SDRC |
| 135 | idle_sdrc: | 164 | idle_sdrc: |
| @@ -149,7 +178,7 @@ configure_core_dpll: | |||
| 149 | ldr r12, [r11] | 178 | ldr r12, [r11] |
| 150 | ldr r10, core_m2_mask_val @ modify m2 for core dpll | 179 | ldr r10, core_m2_mask_val @ modify m2 for core dpll |
| 151 | and r12, r12, r10 | 180 | and r12, r12, r10 |
| 152 | orr r12, r12, r3, lsl #CORE_DPLL_CLKOUT_DIV_SHIFT | 181 | orr r12, r12, r0, lsl #CORE_DPLL_CLKOUT_DIV_SHIFT |
| 153 | str r12, [r11] | 182 | str r12, [r11] |
| 154 | ldr r12, [r11] @ posted-write barrier for CM | 183 | ldr r12, [r11] @ posted-write barrier for CM |
| 155 | bx lr | 184 | bx lr |
| @@ -187,15 +216,34 @@ wait_dll_unlock: | |||
| 187 | bne wait_dll_unlock | 216 | bne wait_dll_unlock |
| 188 | bx lr | 217 | bx lr |
| 189 | configure_sdrc: | 218 | configure_sdrc: |
| 190 | ldr r11, omap3_sdrc_rfr_ctrl | 219 | ldr r12, omap_sdrc_rfr_ctrl_0_val @ fetch value from SRAM |
| 191 | str r0, [r11] | 220 | ldr r11, omap3_sdrc_rfr_ctrl_0 @ fetch addr from SRAM |
| 192 | ldr r11, omap3_sdrc_actim_ctrla | 221 | str r12, [r11] @ store |
| 193 | str r1, [r11] | 222 | ldr r12, omap_sdrc_actim_ctrl_a_0_val |
| 194 | ldr r11, omap3_sdrc_actim_ctrlb | 223 | ldr r11, omap3_sdrc_actim_ctrl_a_0 |
| 195 | str r2, [r11] | 224 | str r12, [r11] |
| 225 | ldr r12, omap_sdrc_actim_ctrl_b_0_val | ||
| 226 | ldr r11, omap3_sdrc_actim_ctrl_b_0 | ||
| 227 | str r12, [r11] | ||
| 228 | ldr r12, omap_sdrc_mr_0_val | ||
| 196 | ldr r11, omap3_sdrc_mr_0 | 229 | ldr r11, omap3_sdrc_mr_0 |
| 197 | str r6, [r11] | 230 | str r12, [r11] |
| 198 | ldr r6, [r11] @ posted-write barrier for SDRC | 231 | ldr r12, omap_sdrc_rfr_ctrl_1_val |
| 232 | cmp r12, #0 @ if SDRC_RFR_CTRL_1 is 0, | ||
| 233 | beq skip_cs1_prog @ do not program cs1 params | ||
| 234 | ldr r11, omap3_sdrc_rfr_ctrl_1 | ||
| 235 | str r12, [r11] | ||
| 236 | ldr r12, omap_sdrc_actim_ctrl_a_1_val | ||
| 237 | ldr r11, omap3_sdrc_actim_ctrl_a_1 | ||
| 238 | str r12, [r11] | ||
| 239 | ldr r12, omap_sdrc_actim_ctrl_b_1_val | ||
| 240 | ldr r11, omap3_sdrc_actim_ctrl_b_1 | ||
| 241 | str r12, [r11] | ||
| 242 | ldr r12, omap_sdrc_mr_1_val | ||
| 243 | ldr r11, omap3_sdrc_mr_1 | ||
| 244 | str r12, [r11] | ||
| 245 | skip_cs1_prog: | ||
| 246 | ldr r12, [r11] @ posted-write barrier for SDRC | ||
| 199 | bx lr | 247 | bx lr |
| 200 | 248 | ||
| 201 | omap3_sdrc_power: | 249 | omap3_sdrc_power: |
| @@ -206,14 +254,40 @@ omap3_cm_idlest1_core: | |||
| 206 | .word OMAP34XX_CM_REGADDR(CORE_MOD, CM_IDLEST) | 254 | .word OMAP34XX_CM_REGADDR(CORE_MOD, CM_IDLEST) |
| 207 | omap3_cm_iclken1_core: | 255 | omap3_cm_iclken1_core: |
| 208 | .word OMAP34XX_CM_REGADDR(CORE_MOD, CM_ICLKEN1) | 256 | .word OMAP34XX_CM_REGADDR(CORE_MOD, CM_ICLKEN1) |
| 209 | omap3_sdrc_rfr_ctrl: | 257 | |
| 258 | omap3_sdrc_rfr_ctrl_0: | ||
| 210 | .word OMAP34XX_SDRC_REGADDR(SDRC_RFR_CTRL_0) | 259 | .word OMAP34XX_SDRC_REGADDR(SDRC_RFR_CTRL_0) |
| 211 | omap3_sdrc_actim_ctrla: | 260 | omap3_sdrc_rfr_ctrl_1: |
| 261 | .word OMAP34XX_SDRC_REGADDR(SDRC_RFR_CTRL_1) | ||
| 262 | omap3_sdrc_actim_ctrl_a_0: | ||
| 212 | .word OMAP34XX_SDRC_REGADDR(SDRC_ACTIM_CTRL_A_0) | 263 | .word OMAP34XX_SDRC_REGADDR(SDRC_ACTIM_CTRL_A_0) |
| 213 | omap3_sdrc_actim_ctrlb: | 264 | omap3_sdrc_actim_ctrl_a_1: |
| 265 | .word OMAP34XX_SDRC_REGADDR(SDRC_ACTIM_CTRL_A_1) | ||
| 266 | omap3_sdrc_actim_ctrl_b_0: | ||
| 214 | .word OMAP34XX_SDRC_REGADDR(SDRC_ACTIM_CTRL_B_0) | 267 | .word OMAP34XX_SDRC_REGADDR(SDRC_ACTIM_CTRL_B_0) |
| 268 | omap3_sdrc_actim_ctrl_b_1: | ||
| 269 | .word OMAP34XX_SDRC_REGADDR(SDRC_ACTIM_CTRL_B_1) | ||
| 215 | omap3_sdrc_mr_0: | 270 | omap3_sdrc_mr_0: |
| 216 | .word OMAP34XX_SDRC_REGADDR(SDRC_MR_0) | 271 | .word OMAP34XX_SDRC_REGADDR(SDRC_MR_0) |
| 272 | omap3_sdrc_mr_1: | ||
| 273 | .word OMAP34XX_SDRC_REGADDR(SDRC_MR_1) | ||
| 274 | omap_sdrc_rfr_ctrl_0_val: | ||
| 275 | .word 0xDEADBEEF | ||
| 276 | omap_sdrc_rfr_ctrl_1_val: | ||
| 277 | .word 0xDEADBEEF | ||
| 278 | omap_sdrc_actim_ctrl_a_0_val: | ||
| 279 | .word 0xDEADBEEF | ||
| 280 | omap_sdrc_actim_ctrl_a_1_val: | ||
| 281 | .word 0xDEADBEEF | ||
| 282 | omap_sdrc_actim_ctrl_b_0_val: | ||
| 283 | .word 0xDEADBEEF | ||
| 284 | omap_sdrc_actim_ctrl_b_1_val: | ||
| 285 | .word 0xDEADBEEF | ||
| 286 | omap_sdrc_mr_0_val: | ||
| 287 | .word 0xDEADBEEF | ||
| 288 | omap_sdrc_mr_1_val: | ||
| 289 | .word 0xDEADBEEF | ||
| 290 | |||
| 217 | omap3_sdrc_dlla_status: | 291 | omap3_sdrc_dlla_status: |
| 218 | .word OMAP34XX_SDRC_REGADDR(SDRC_DLLA_STATUS) | 292 | .word OMAP34XX_SDRC_REGADDR(SDRC_DLLA_STATUS) |
| 219 | omap3_sdrc_dlla_ctrl: | 293 | omap3_sdrc_dlla_ctrl: |
| @@ -223,3 +297,4 @@ core_m2_mask_val: | |||
| 223 | 297 | ||
| 224 | ENTRY(omap3_sram_configure_core_dpll_sz) | 298 | ENTRY(omap3_sram_configure_core_dpll_sz) |
| 225 | .word . - omap3_sram_configure_core_dpll | 299 | .word . - omap3_sram_configure_core_dpll |
| 300 | |||
diff --git a/arch/arm/mach-omap2/usb-musb.c b/arch/arm/mach-omap2/usb-musb.c index d85296dc896c..739e59e8025c 100644 --- a/arch/arm/mach-omap2/usb-musb.c +++ b/arch/arm/mach-omap2/usb-musb.c | |||
| @@ -155,20 +155,6 @@ static struct platform_device musb_device = { | |||
| 155 | .resource = musb_resources, | 155 | .resource = musb_resources, |
| 156 | }; | 156 | }; |
| 157 | 157 | ||
| 158 | #ifdef CONFIG_NOP_USB_XCEIV | ||
| 159 | static u64 nop_xceiv_dmamask = DMA_BIT_MASK(32); | ||
| 160 | |||
| 161 | static struct platform_device nop_xceiv_device = { | ||
| 162 | .name = "nop_usb_xceiv", | ||
| 163 | .id = -1, | ||
| 164 | .dev = { | ||
| 165 | .dma_mask = &nop_xceiv_dmamask, | ||
| 166 | .coherent_dma_mask = DMA_BIT_MASK(32), | ||
| 167 | .platform_data = NULL, | ||
| 168 | }, | ||
| 169 | }; | ||
| 170 | #endif | ||
| 171 | |||
| 172 | void __init usb_musb_init(void) | 158 | void __init usb_musb_init(void) |
| 173 | { | 159 | { |
| 174 | if (cpu_is_omap243x()) | 160 | if (cpu_is_omap243x()) |
| @@ -183,13 +169,6 @@ void __init usb_musb_init(void) | |||
| 183 | */ | 169 | */ |
| 184 | musb_plat.clock = "ick"; | 170 | musb_plat.clock = "ick"; |
| 185 | 171 | ||
| 186 | #ifdef CONFIG_NOP_USB_XCEIV | ||
| 187 | if (platform_device_register(&nop_xceiv_device) < 0) { | ||
| 188 | printk(KERN_ERR "Unable to register NOP-XCEIV device\n"); | ||
| 189 | return; | ||
| 190 | } | ||
| 191 | #endif | ||
| 192 | |||
| 193 | if (platform_device_register(&musb_device) < 0) { | 172 | if (platform_device_register(&musb_device) < 0) { |
| 194 | printk(KERN_ERR "Unable to register HS-USB (MUSB) device\n"); | 173 | printk(KERN_ERR "Unable to register HS-USB (MUSB) device\n"); |
| 195 | return; | 174 | return; |
diff --git a/arch/arm/mach-pxa/em-x270.c b/arch/arm/mach-pxa/em-x270.c index 63b10d9bb1d3..9cd09465a0e8 100644 --- a/arch/arm/mach-pxa/em-x270.c +++ b/arch/arm/mach-pxa/em-x270.c | |||
| @@ -1141,12 +1141,16 @@ struct power_supply_info em_x270_psy_info = { | |||
| 1141 | 1141 | ||
| 1142 | static void em_x270_battery_low(void) | 1142 | static void em_x270_battery_low(void) |
| 1143 | { | 1143 | { |
| 1144 | #if defined(CONFIG_APM_EMULATION) | ||
| 1144 | apm_queue_event(APM_LOW_BATTERY); | 1145 | apm_queue_event(APM_LOW_BATTERY); |
| 1146 | #endif | ||
| 1145 | } | 1147 | } |
| 1146 | 1148 | ||
| 1147 | static void em_x270_battery_critical(void) | 1149 | static void em_x270_battery_critical(void) |
| 1148 | { | 1150 | { |
| 1151 | #if defined(CONFIG_APM_EMULATION) | ||
| 1149 | apm_queue_event(APM_CRITICAL_SUSPEND); | 1152 | apm_queue_event(APM_CRITICAL_SUSPEND); |
| 1153 | #endif | ||
| 1150 | } | 1154 | } |
| 1151 | 1155 | ||
| 1152 | struct da9030_battery_info em_x270_batterty_info = { | 1156 | struct da9030_battery_info em_x270_batterty_info = { |
diff --git a/arch/arm/mach-pxa/palmld.c b/arch/arm/mach-pxa/palmld.c index ed70f281dd09..169fcc18154e 100644 --- a/arch/arm/mach-pxa/palmld.c +++ b/arch/arm/mach-pxa/palmld.c | |||
| @@ -128,6 +128,10 @@ static unsigned long palmld_pin_config[] __initdata = { | |||
| 128 | GPIO38_GPIO, /* wifi ready */ | 128 | GPIO38_GPIO, /* wifi ready */ |
| 129 | GPIO81_GPIO, /* wifi reset */ | 129 | GPIO81_GPIO, /* wifi reset */ |
| 130 | 130 | ||
| 131 | /* FFUART */ | ||
| 132 | GPIO34_FFUART_RXD, | ||
| 133 | GPIO39_FFUART_TXD, | ||
| 134 | |||
| 131 | /* HDD */ | 135 | /* HDD */ |
| 132 | GPIO98_GPIO, /* HDD reset */ | 136 | GPIO98_GPIO, /* HDD reset */ |
| 133 | GPIO115_GPIO, /* HDD power */ | 137 | GPIO115_GPIO, /* HDD power */ |
diff --git a/arch/arm/mach-pxa/palmt5.c b/arch/arm/mach-pxa/palmt5.c index aae64a12a734..33f726ff55e5 100644 --- a/arch/arm/mach-pxa/palmt5.c +++ b/arch/arm/mach-pxa/palmt5.c | |||
| @@ -111,6 +111,10 @@ static unsigned long palmt5_pin_config[] __initdata = { | |||
| 111 | /* PWM */ | 111 | /* PWM */ |
| 112 | GPIO16_PWM0_OUT, | 112 | GPIO16_PWM0_OUT, |
| 113 | 113 | ||
| 114 | /* FFUART */ | ||
| 115 | GPIO34_FFUART_RXD, | ||
| 116 | GPIO39_FFUART_TXD, | ||
| 117 | |||
| 114 | /* MISC */ | 118 | /* MISC */ |
| 115 | GPIO10_GPIO, /* hotsync button */ | 119 | GPIO10_GPIO, /* hotsync button */ |
| 116 | GPIO90_GPIO, /* power detect */ | 120 | GPIO90_GPIO, /* power detect */ |
diff --git a/arch/arm/mach-pxa/palmtx.c b/arch/arm/mach-pxa/palmtx.c index 6c15d84bde53..83d020879581 100644 --- a/arch/arm/mach-pxa/palmtx.c +++ b/arch/arm/mach-pxa/palmtx.c | |||
| @@ -127,6 +127,10 @@ static unsigned long palmtx_pin_config[] __initdata = { | |||
| 127 | GPIO76_LCD_PCLK, | 127 | GPIO76_LCD_PCLK, |
| 128 | GPIO77_LCD_BIAS, | 128 | GPIO77_LCD_BIAS, |
| 129 | 129 | ||
| 130 | /* FFUART */ | ||
| 131 | GPIO34_FFUART_RXD, | ||
| 132 | GPIO39_FFUART_TXD, | ||
| 133 | |||
| 130 | /* MISC. */ | 134 | /* MISC. */ |
| 131 | GPIO10_GPIO, /* hotsync button */ | 135 | GPIO10_GPIO, /* hotsync button */ |
| 132 | GPIO12_GPIO, /* power detect */ | 136 | GPIO12_GPIO, /* power detect */ |
diff --git a/arch/arm/mach-pxa/treo680.c b/arch/arm/mach-pxa/treo680.c index a06f19edebb3..753ec4df17b9 100644 --- a/arch/arm/mach-pxa/treo680.c +++ b/arch/arm/mach-pxa/treo680.c | |||
| @@ -409,7 +409,7 @@ err1: | |||
| 409 | 409 | ||
| 410 | static void treo680_irda_shutdown(struct device *dev) | 410 | static void treo680_irda_shutdown(struct device *dev) |
| 411 | { | 411 | { |
| 412 | gpio_free(GPIO_NR_TREO680_AMP_EN); | 412 | gpio_free(GPIO_NR_TREO680_IR_EN); |
| 413 | } | 413 | } |
| 414 | 414 | ||
| 415 | static struct pxaficp_platform_data treo680_ficp_info = { | 415 | static struct pxaficp_platform_data treo680_ficp_info = { |
diff --git a/arch/arm/mach-pxa/zylonite_pxa300.c b/arch/arm/mach-pxa/zylonite_pxa300.c index cefd1c0a854a..84095440a878 100644 --- a/arch/arm/mach-pxa/zylonite_pxa300.c +++ b/arch/arm/mach-pxa/zylonite_pxa300.c | |||
| @@ -197,10 +197,12 @@ static void __init zylonite_detect_lcd_panel(void) | |||
| 197 | for (i = 0; i < NUM_LCD_DETECT_PINS; i++) { | 197 | for (i = 0; i < NUM_LCD_DETECT_PINS; i++) { |
| 198 | id = id << 1; | 198 | id = id << 1; |
| 199 | gpio = mfp_to_gpio(lcd_detect_pins[i]); | 199 | gpio = mfp_to_gpio(lcd_detect_pins[i]); |
| 200 | gpio_request(gpio, "LCD_ID_PINS"); | ||
| 200 | gpio_direction_input(gpio); | 201 | gpio_direction_input(gpio); |
| 201 | 202 | ||
| 202 | if (gpio_get_value(gpio)) | 203 | if (gpio_get_value(gpio)) |
| 203 | id = id | 0x1; | 204 | id = id | 0x1; |
| 205 | gpio_free(gpio); | ||
| 204 | } | 206 | } |
| 205 | 207 | ||
| 206 | /* lcd id, flush out bit 1 */ | 208 | /* lcd id, flush out bit 1 */ |
diff --git a/arch/arm/mach-pxa/zylonite_pxa320.c b/arch/arm/mach-pxa/zylonite_pxa320.c index cc5a22833605..60d08f23f5e4 100644 --- a/arch/arm/mach-pxa/zylonite_pxa320.c +++ b/arch/arm/mach-pxa/zylonite_pxa320.c | |||
| @@ -176,10 +176,12 @@ static void __init zylonite_detect_lcd_panel(void) | |||
| 176 | for (i = 0; i < NUM_LCD_DETECT_PINS; i++) { | 176 | for (i = 0; i < NUM_LCD_DETECT_PINS; i++) { |
| 177 | id = id << 1; | 177 | id = id << 1; |
| 178 | gpio = mfp_to_gpio(lcd_detect_pins[i]); | 178 | gpio = mfp_to_gpio(lcd_detect_pins[i]); |
| 179 | gpio_request(gpio, "LCD_ID_PINS"); | ||
| 179 | gpio_direction_input(gpio); | 180 | gpio_direction_input(gpio); |
| 180 | 181 | ||
| 181 | if (gpio_get_value(gpio)) | 182 | if (gpio_get_value(gpio)) |
| 182 | id = id | 0x1; | 183 | id = id | 0x1; |
| 184 | gpio_free(gpio); | ||
| 183 | } | 185 | } |
| 184 | 186 | ||
| 185 | /* lcd id, flush out bit 1 */ | 187 | /* lcd id, flush out bit 1 */ |
diff --git a/arch/arm/mach-s3c2410/include/mach/gpio-core.h b/arch/arm/mach-s3c2410/include/mach/gpio-core.h index 8fe192081d3a..f8b879a7973c 100644 --- a/arch/arm/mach-s3c2410/include/mach/gpio-core.h +++ b/arch/arm/mach-s3c2410/include/mach/gpio-core.h | |||
| @@ -28,7 +28,7 @@ static inline struct s3c_gpio_chip *s3c_gpiolib_getchip(unsigned int pin) | |||
| 28 | return NULL; | 28 | return NULL; |
| 29 | 29 | ||
| 30 | chip = &s3c24xx_gpios[pin/32]; | 30 | chip = &s3c24xx_gpios[pin/32]; |
| 31 | return (S3C2410_GPIO_OFFSET(pin) > chip->chip.ngpio) ? chip : NULL; | 31 | return (S3C2410_GPIO_OFFSET(pin) < chip->chip.ngpio) ? chip : NULL; |
| 32 | } | 32 | } |
| 33 | 33 | ||
| 34 | #endif /* __ASM_ARCH_GPIO_CORE_H */ | 34 | #endif /* __ASM_ARCH_GPIO_CORE_H */ |
diff --git a/arch/arm/mach-u300/core.c b/arch/arm/mach-u300/core.c index 7936085dd758..2e9b8ccd8ec2 100644 --- a/arch/arm/mach-u300/core.c +++ b/arch/arm/mach-u300/core.c | |||
| @@ -510,7 +510,7 @@ static struct db_chip db_chips[] __initdata = { | |||
| 510 | } | 510 | } |
| 511 | }; | 511 | }; |
| 512 | 512 | ||
| 513 | static void u300_init_check_chip(void) | 513 | static void __init u300_init_check_chip(void) |
| 514 | { | 514 | { |
| 515 | 515 | ||
| 516 | u16 val; | 516 | u16 val; |
diff --git a/arch/arm/mm/init.c b/arch/arm/mm/init.c index 8277802ec859..3a7279c1ce5e 100644 --- a/arch/arm/mm/init.c +++ b/arch/arm/mm/init.c | |||
| @@ -120,6 +120,32 @@ void show_mem(void) | |||
| 120 | printk("%d pages swap cached\n", cached); | 120 | printk("%d pages swap cached\n", cached); |
| 121 | } | 121 | } |
| 122 | 122 | ||
| 123 | static void __init find_node_limits(int node, struct meminfo *mi, | ||
| 124 | unsigned long *min, unsigned long *max_low, unsigned long *max_high) | ||
| 125 | { | ||
| 126 | int i; | ||
| 127 | |||
| 128 | *min = -1UL; | ||
| 129 | *max_low = *max_high = 0; | ||
| 130 | |||
| 131 | for_each_nodebank(i, mi, node) { | ||
| 132 | struct membank *bank = &mi->bank[i]; | ||
| 133 | unsigned long start, end; | ||
| 134 | |||
| 135 | start = bank_pfn_start(bank); | ||
| 136 | end = bank_pfn_end(bank); | ||
| 137 | |||
| 138 | if (*min > start) | ||
| 139 | *min = start; | ||
| 140 | if (*max_high < end) | ||
| 141 | *max_high = end; | ||
| 142 | if (bank->highmem) | ||
| 143 | continue; | ||
| 144 | if (*max_low < end) | ||
| 145 | *max_low = end; | ||
| 146 | } | ||
| 147 | } | ||
| 148 | |||
| 123 | /* | 149 | /* |
| 124 | * FIXME: We really want to avoid allocating the bootmap bitmap | 150 | * FIXME: We really want to avoid allocating the bootmap bitmap |
| 125 | * over the top of the initrd. Hopefully, this is located towards | 151 | * over the top of the initrd. Hopefully, this is located towards |
| @@ -210,41 +236,25 @@ static inline void map_memory_bank(struct membank *bank) | |||
| 210 | #endif | 236 | #endif |
| 211 | } | 237 | } |
| 212 | 238 | ||
| 213 | static unsigned long __init bootmem_init_node(int node, struct meminfo *mi) | 239 | static void __init bootmem_init_node(int node, struct meminfo *mi, |
| 240 | unsigned long start_pfn, unsigned long end_pfn) | ||
| 214 | { | 241 | { |
| 215 | unsigned long start_pfn, end_pfn, boot_pfn; | 242 | unsigned long boot_pfn; |
| 216 | unsigned int boot_pages; | 243 | unsigned int boot_pages; |
| 217 | pg_data_t *pgdat; | 244 | pg_data_t *pgdat; |
| 218 | int i; | 245 | int i; |
| 219 | 246 | ||
| 220 | start_pfn = -1UL; | ||
| 221 | end_pfn = 0; | ||
| 222 | |||
| 223 | /* | 247 | /* |
| 224 | * Calculate the pfn range, and map the memory banks for this node. | 248 | * Map the memory banks for this node. |
| 225 | */ | 249 | */ |
| 226 | for_each_nodebank(i, mi, node) { | 250 | for_each_nodebank(i, mi, node) { |
| 227 | struct membank *bank = &mi->bank[i]; | 251 | struct membank *bank = &mi->bank[i]; |
| 228 | unsigned long start, end; | ||
| 229 | 252 | ||
| 230 | start = bank_pfn_start(bank); | 253 | if (!bank->highmem) |
| 231 | end = bank_pfn_end(bank); | 254 | map_memory_bank(bank); |
| 232 | |||
| 233 | if (start_pfn > start) | ||
| 234 | start_pfn = start; | ||
| 235 | if (end_pfn < end) | ||
| 236 | end_pfn = end; | ||
| 237 | |||
| 238 | map_memory_bank(bank); | ||
| 239 | } | 255 | } |
| 240 | 256 | ||
| 241 | /* | 257 | /* |
| 242 | * If there is no memory in this node, ignore it. | ||
| 243 | */ | ||
| 244 | if (end_pfn == 0) | ||
| 245 | return end_pfn; | ||
| 246 | |||
| 247 | /* | ||
| 248 | * Allocate the bootmem bitmap page. | 258 | * Allocate the bootmem bitmap page. |
| 249 | */ | 259 | */ |
| 250 | boot_pages = bootmem_bootmap_pages(end_pfn - start_pfn); | 260 | boot_pages = bootmem_bootmap_pages(end_pfn - start_pfn); |
| @@ -260,7 +270,8 @@ static unsigned long __init bootmem_init_node(int node, struct meminfo *mi) | |||
| 260 | 270 | ||
| 261 | for_each_nodebank(i, mi, node) { | 271 | for_each_nodebank(i, mi, node) { |
| 262 | struct membank *bank = &mi->bank[i]; | 272 | struct membank *bank = &mi->bank[i]; |
| 263 | free_bootmem_node(pgdat, bank_phys_start(bank), bank_phys_size(bank)); | 273 | if (!bank->highmem) |
| 274 | free_bootmem_node(pgdat, bank_phys_start(bank), bank_phys_size(bank)); | ||
| 264 | memory_present(node, bank_pfn_start(bank), bank_pfn_end(bank)); | 275 | memory_present(node, bank_pfn_start(bank), bank_pfn_end(bank)); |
| 265 | } | 276 | } |
| 266 | 277 | ||
| @@ -269,8 +280,6 @@ static unsigned long __init bootmem_init_node(int node, struct meminfo *mi) | |||
| 269 | */ | 280 | */ |
| 270 | reserve_bootmem_node(pgdat, boot_pfn << PAGE_SHIFT, | 281 | reserve_bootmem_node(pgdat, boot_pfn << PAGE_SHIFT, |
| 271 | boot_pages << PAGE_SHIFT, BOOTMEM_DEFAULT); | 282 | boot_pages << PAGE_SHIFT, BOOTMEM_DEFAULT); |
| 272 | |||
| 273 | return end_pfn; | ||
| 274 | } | 283 | } |
| 275 | 284 | ||
| 276 | static void __init bootmem_reserve_initrd(int node) | 285 | static void __init bootmem_reserve_initrd(int node) |
| @@ -297,33 +306,39 @@ static void __init bootmem_reserve_initrd(int node) | |||
| 297 | static void __init bootmem_free_node(int node, struct meminfo *mi) | 306 | static void __init bootmem_free_node(int node, struct meminfo *mi) |
| 298 | { | 307 | { |
| 299 | unsigned long zone_size[MAX_NR_ZONES], zhole_size[MAX_NR_ZONES]; | 308 | unsigned long zone_size[MAX_NR_ZONES], zhole_size[MAX_NR_ZONES]; |
| 300 | unsigned long start_pfn, end_pfn; | 309 | unsigned long min, max_low, max_high; |
| 301 | pg_data_t *pgdat = NODE_DATA(node); | ||
| 302 | int i; | 310 | int i; |
| 303 | 311 | ||
| 304 | start_pfn = pgdat->bdata->node_min_pfn; | 312 | find_node_limits(node, mi, &min, &max_low, &max_high); |
| 305 | end_pfn = pgdat->bdata->node_low_pfn; | ||
| 306 | 313 | ||
| 307 | /* | 314 | /* |
| 308 | * initialise the zones within this node. | 315 | * initialise the zones within this node. |
| 309 | */ | 316 | */ |
| 310 | memset(zone_size, 0, sizeof(zone_size)); | 317 | memset(zone_size, 0, sizeof(zone_size)); |
| 311 | memset(zhole_size, 0, sizeof(zhole_size)); | ||
| 312 | 318 | ||
| 313 | /* | 319 | /* |
| 314 | * The size of this node has already been determined. If we need | 320 | * The size of this node has already been determined. If we need |
| 315 | * to do anything fancy with the allocation of this memory to the | 321 | * to do anything fancy with the allocation of this memory to the |
| 316 | * zones, now is the time to do it. | 322 | * zones, now is the time to do it. |
| 317 | */ | 323 | */ |
| 318 | zone_size[0] = end_pfn - start_pfn; | 324 | zone_size[0] = max_low - min; |
| 325 | #ifdef CONFIG_HIGHMEM | ||
| 326 | zone_size[ZONE_HIGHMEM] = max_high - max_low; | ||
| 327 | #endif | ||
| 319 | 328 | ||
| 320 | /* | 329 | /* |
| 321 | * For each bank in this node, calculate the size of the holes. | 330 | * For each bank in this node, calculate the size of the holes. |
| 322 | * holes = node_size - sum(bank_sizes_in_node) | 331 | * holes = node_size - sum(bank_sizes_in_node) |
| 323 | */ | 332 | */ |
| 324 | zhole_size[0] = zone_size[0]; | 333 | memcpy(zhole_size, zone_size, sizeof(zhole_size)); |
| 325 | for_each_nodebank(i, mi, node) | 334 | for_each_nodebank(i, mi, node) { |
| 326 | zhole_size[0] -= bank_pfn_size(&mi->bank[i]); | 335 | int idx = 0; |
| 336 | #ifdef CONFIG_HIGHMEM | ||
| 337 | if (mi->bank[i].highmem) | ||
| 338 | idx = ZONE_HIGHMEM; | ||
| 339 | #endif | ||
| 340 | zhole_size[idx] -= bank_pfn_size(&mi->bank[i]); | ||
| 341 | } | ||
| 327 | 342 | ||
| 328 | /* | 343 | /* |
| 329 | * Adjust the sizes according to any special requirements for | 344 | * Adjust the sizes according to any special requirements for |
| @@ -331,13 +346,13 @@ static void __init bootmem_free_node(int node, struct meminfo *mi) | |||
| 331 | */ | 346 | */ |
| 332 | arch_adjust_zones(node, zone_size, zhole_size); | 347 | arch_adjust_zones(node, zone_size, zhole_size); |
| 333 | 348 | ||
| 334 | free_area_init_node(node, zone_size, start_pfn, zhole_size); | 349 | free_area_init_node(node, zone_size, min, zhole_size); |
| 335 | } | 350 | } |
| 336 | 351 | ||
| 337 | void __init bootmem_init(void) | 352 | void __init bootmem_init(void) |
| 338 | { | 353 | { |
| 339 | struct meminfo *mi = &meminfo; | 354 | struct meminfo *mi = &meminfo; |
| 340 | unsigned long memend_pfn = 0; | 355 | unsigned long min, max_low, max_high; |
| 341 | int node, initrd_node; | 356 | int node, initrd_node; |
| 342 | 357 | ||
| 343 | /* | 358 | /* |
| @@ -345,11 +360,29 @@ void __init bootmem_init(void) | |||
| 345 | */ | 360 | */ |
| 346 | initrd_node = check_initrd(mi); | 361 | initrd_node = check_initrd(mi); |
| 347 | 362 | ||
| 363 | max_low = max_high = 0; | ||
| 364 | |||
| 348 | /* | 365 | /* |
| 349 | * Run through each node initialising the bootmem allocator. | 366 | * Run through each node initialising the bootmem allocator. |
| 350 | */ | 367 | */ |
| 351 | for_each_node(node) { | 368 | for_each_node(node) { |
| 352 | unsigned long end_pfn = bootmem_init_node(node, mi); | 369 | unsigned long node_low, node_high; |
| 370 | |||
| 371 | find_node_limits(node, mi, &min, &node_low, &node_high); | ||
| 372 | |||
| 373 | if (node_low > max_low) | ||
| 374 | max_low = node_low; | ||
| 375 | if (node_high > max_high) | ||
| 376 | max_high = node_high; | ||
| 377 | |||
| 378 | /* | ||
| 379 | * If there is no memory in this node, ignore it. | ||
| 380 | * (We can't have nodes which have no lowmem) | ||
| 381 | */ | ||
| 382 | if (node_low == 0) | ||
| 383 | continue; | ||
| 384 | |||
| 385 | bootmem_init_node(node, mi, min, node_low); | ||
| 353 | 386 | ||
| 354 | /* | 387 | /* |
| 355 | * Reserve any special node zero regions. | 388 | * Reserve any special node zero regions. |
| @@ -362,12 +395,6 @@ void __init bootmem_init(void) | |||
| 362 | */ | 395 | */ |
| 363 | if (node == initrd_node) | 396 | if (node == initrd_node) |
| 364 | bootmem_reserve_initrd(node); | 397 | bootmem_reserve_initrd(node); |
| 365 | |||
| 366 | /* | ||
| 367 | * Remember the highest memory PFN. | ||
| 368 | */ | ||
| 369 | if (end_pfn > memend_pfn) | ||
| 370 | memend_pfn = end_pfn; | ||
| 371 | } | 398 | } |
| 372 | 399 | ||
| 373 | /* | 400 | /* |
| @@ -383,7 +410,7 @@ void __init bootmem_init(void) | |||
| 383 | for_each_node(node) | 410 | for_each_node(node) |
| 384 | bootmem_free_node(node, mi); | 411 | bootmem_free_node(node, mi); |
| 385 | 412 | ||
| 386 | high_memory = __va((memend_pfn << PAGE_SHIFT) - 1) + 1; | 413 | high_memory = __va((max_low << PAGE_SHIFT) - 1) + 1; |
| 387 | 414 | ||
| 388 | /* | 415 | /* |
| 389 | * This doesn't seem to be used by the Linux memory manager any | 416 | * This doesn't seem to be used by the Linux memory manager any |
| @@ -393,7 +420,8 @@ void __init bootmem_init(void) | |||
| 393 | * Note: max_low_pfn and max_pfn reflect the number of _pages_ in | 420 | * Note: max_low_pfn and max_pfn reflect the number of _pages_ in |
| 394 | * the system, not the maximum PFN. | 421 | * the system, not the maximum PFN. |
| 395 | */ | 422 | */ |
| 396 | max_pfn = max_low_pfn = memend_pfn - PHYS_PFN_OFFSET; | 423 | max_low_pfn = max_low - PHYS_PFN_OFFSET; |
| 424 | max_pfn = max_high - PHYS_PFN_OFFSET; | ||
| 397 | } | 425 | } |
| 398 | 426 | ||
| 399 | static inline int free_area(unsigned long pfn, unsigned long end, char *s) | 427 | static inline int free_area(unsigned long pfn, unsigned long end, char *s) |
diff --git a/arch/arm/mm/mmu.c b/arch/arm/mm/mmu.c index 4722582b17b8..4426ee67ceca 100644 --- a/arch/arm/mm/mmu.c +++ b/arch/arm/mm/mmu.c | |||
| @@ -687,13 +687,19 @@ __early_param("vmalloc=", early_vmalloc); | |||
| 687 | 687 | ||
| 688 | static void __init sanity_check_meminfo(void) | 688 | static void __init sanity_check_meminfo(void) |
| 689 | { | 689 | { |
| 690 | int i, j; | 690 | int i, j, highmem = 0; |
| 691 | 691 | ||
| 692 | for (i = 0, j = 0; i < meminfo.nr_banks; i++) { | 692 | for (i = 0, j = 0; i < meminfo.nr_banks; i++) { |
| 693 | struct membank *bank = &meminfo.bank[j]; | 693 | struct membank *bank = &meminfo.bank[j]; |
| 694 | *bank = meminfo.bank[i]; | 694 | *bank = meminfo.bank[i]; |
| 695 | 695 | ||
| 696 | #ifdef CONFIG_HIGHMEM | 696 | #ifdef CONFIG_HIGHMEM |
| 697 | if (__va(bank->start) > VMALLOC_MIN || | ||
| 698 | __va(bank->start) < (void *)PAGE_OFFSET) | ||
| 699 | highmem = 1; | ||
| 700 | |||
| 701 | bank->highmem = highmem; | ||
| 702 | |||
| 697 | /* | 703 | /* |
| 698 | * Split those memory banks which are partially overlapping | 704 | * Split those memory banks which are partially overlapping |
| 699 | * the vmalloc area greatly simplifying things later. | 705 | * the vmalloc area greatly simplifying things later. |
| @@ -714,6 +720,7 @@ static void __init sanity_check_meminfo(void) | |||
| 714 | i++; | 720 | i++; |
| 715 | bank[1].size -= VMALLOC_MIN - __va(bank->start); | 721 | bank[1].size -= VMALLOC_MIN - __va(bank->start); |
| 716 | bank[1].start = __pa(VMALLOC_MIN - 1) + 1; | 722 | bank[1].start = __pa(VMALLOC_MIN - 1) + 1; |
| 723 | bank[1].highmem = highmem = 1; | ||
| 717 | j++; | 724 | j++; |
| 718 | } | 725 | } |
| 719 | bank->size = VMALLOC_MIN - __va(bank->start); | 726 | bank->size = VMALLOC_MIN - __va(bank->start); |
diff --git a/arch/arm/plat-omap/cpu-omap.c b/arch/arm/plat-omap/cpu-omap.c index 843e8af64066..1868c0d8f9b5 100644 --- a/arch/arm/plat-omap/cpu-omap.c +++ b/arch/arm/plat-omap/cpu-omap.c | |||
| @@ -78,10 +78,10 @@ static int omap_target(struct cpufreq_policy *policy, | |||
| 78 | 78 | ||
| 79 | /* Ensure desired rate is within allowed range. Some govenors | 79 | /* Ensure desired rate is within allowed range. Some govenors |
| 80 | * (ondemand) will just pass target_freq=0 to get the minimum. */ | 80 | * (ondemand) will just pass target_freq=0 to get the minimum. */ |
| 81 | if (target_freq < policy->cpuinfo.min_freq) | 81 | if (target_freq < policy->min) |
| 82 | target_freq = policy->cpuinfo.min_freq; | 82 | target_freq = policy->min; |
| 83 | if (target_freq > policy->cpuinfo.max_freq) | 83 | if (target_freq > policy->max) |
| 84 | target_freq = policy->cpuinfo.max_freq; | 84 | target_freq = policy->max; |
| 85 | 85 | ||
| 86 | freqs.old = omap_getspeed(0); | 86 | freqs.old = omap_getspeed(0); |
| 87 | freqs.new = clk_round_rate(mpu_clk, target_freq * 1000) / 1000; | 87 | freqs.new = clk_round_rate(mpu_clk, target_freq * 1000) / 1000; |
diff --git a/arch/arm/plat-omap/dma.c b/arch/arm/plat-omap/dma.c index 7677a4a1cef2..e3ac94f09006 100644 --- a/arch/arm/plat-omap/dma.c +++ b/arch/arm/plat-omap/dma.c | |||
| @@ -946,7 +946,9 @@ void omap_start_dma(int lch) | |||
| 946 | 946 | ||
| 947 | cur_lch = next_lch; | 947 | cur_lch = next_lch; |
| 948 | } while (next_lch != -1); | 948 | } while (next_lch != -1); |
| 949 | } else if (cpu_class_is_omap2()) { | 949 | } else if (cpu_is_omap242x() || |
| 950 | (cpu_is_omap243x() && omap_type() <= OMAP2430_REV_ES1_0)) { | ||
| 951 | |||
| 950 | /* Errata: Need to write lch even if not using chaining */ | 952 | /* Errata: Need to write lch even if not using chaining */ |
| 951 | dma_write(lch, CLNK_CTRL(lch)); | 953 | dma_write(lch, CLNK_CTRL(lch)); |
| 952 | } | 954 | } |
diff --git a/arch/arm/plat-omap/gpio.c b/arch/arm/plat-omap/gpio.c index 26b387c12423..9298bc0ab171 100644 --- a/arch/arm/plat-omap/gpio.c +++ b/arch/arm/plat-omap/gpio.c | |||
| @@ -476,14 +476,12 @@ static void _set_gpio_dataout(struct gpio_bank *bank, int gpio, int enable) | |||
| 476 | __raw_writel(l, reg); | 476 | __raw_writel(l, reg); |
| 477 | } | 477 | } |
| 478 | 478 | ||
| 479 | static int __omap_get_gpio_datain(int gpio) | 479 | static int _get_gpio_datain(struct gpio_bank *bank, int gpio) |
| 480 | { | 480 | { |
| 481 | struct gpio_bank *bank; | ||
| 482 | void __iomem *reg; | 481 | void __iomem *reg; |
| 483 | 482 | ||
| 484 | if (check_gpio(gpio) < 0) | 483 | if (check_gpio(gpio) < 0) |
| 485 | return -EINVAL; | 484 | return -EINVAL; |
| 486 | bank = get_gpio_bank(gpio); | ||
| 487 | reg = bank->base; | 485 | reg = bank->base; |
| 488 | switch (bank->method) { | 486 | switch (bank->method) { |
| 489 | #ifdef CONFIG_ARCH_OMAP1 | 487 | #ifdef CONFIG_ARCH_OMAP1 |
| @@ -524,6 +522,53 @@ static int __omap_get_gpio_datain(int gpio) | |||
| 524 | & (1 << get_gpio_index(gpio))) != 0; | 522 | & (1 << get_gpio_index(gpio))) != 0; |
| 525 | } | 523 | } |
| 526 | 524 | ||
| 525 | static int _get_gpio_dataout(struct gpio_bank *bank, int gpio) | ||
| 526 | { | ||
| 527 | void __iomem *reg; | ||
| 528 | |||
| 529 | if (check_gpio(gpio) < 0) | ||
| 530 | return -EINVAL; | ||
| 531 | reg = bank->base; | ||
| 532 | |||
| 533 | switch (bank->method) { | ||
| 534 | #ifdef CONFIG_ARCH_OMAP1 | ||
| 535 | case METHOD_MPUIO: | ||
| 536 | reg += OMAP_MPUIO_OUTPUT; | ||
| 537 | break; | ||
| 538 | #endif | ||
| 539 | #ifdef CONFIG_ARCH_OMAP15XX | ||
| 540 | case METHOD_GPIO_1510: | ||
| 541 | reg += OMAP1510_GPIO_DATA_OUTPUT; | ||
| 542 | break; | ||
| 543 | #endif | ||
| 544 | #ifdef CONFIG_ARCH_OMAP16XX | ||
| 545 | case METHOD_GPIO_1610: | ||
| 546 | reg += OMAP1610_GPIO_DATAOUT; | ||
| 547 | break; | ||
| 548 | #endif | ||
| 549 | #ifdef CONFIG_ARCH_OMAP730 | ||
| 550 | case METHOD_GPIO_730: | ||
| 551 | reg += OMAP730_GPIO_DATA_OUTPUT; | ||
| 552 | break; | ||
| 553 | #endif | ||
| 554 | #ifdef CONFIG_ARCH_OMAP850 | ||
| 555 | case METHOD_GPIO_850: | ||
| 556 | reg += OMAP850_GPIO_DATA_OUTPUT; | ||
| 557 | break; | ||
| 558 | #endif | ||
| 559 | #if defined(CONFIG_ARCH_OMAP24XX) || defined(CONFIG_ARCH_OMAP34XX) || \ | ||
| 560 | defined(CONFIG_ARCH_OMAP4) | ||
| 561 | case METHOD_GPIO_24XX: | ||
| 562 | reg += OMAP24XX_GPIO_DATAOUT; | ||
| 563 | break; | ||
| 564 | #endif | ||
| 565 | default: | ||
| 566 | return -EINVAL; | ||
| 567 | } | ||
| 568 | |||
| 569 | return (__raw_readl(reg) & (1 << get_gpio_index(gpio))) != 0; | ||
| 570 | } | ||
| 571 | |||
| 527 | #define MOD_REG_BIT(reg, bit_mask, set) \ | 572 | #define MOD_REG_BIT(reg, bit_mask, set) \ |
| 528 | do { \ | 573 | do { \ |
| 529 | int l = __raw_readl(base + reg); \ | 574 | int l = __raw_readl(base + reg); \ |
| @@ -1189,6 +1234,7 @@ static void gpio_mask_irq(unsigned int irq) | |||
| 1189 | struct gpio_bank *bank = get_irq_chip_data(irq); | 1234 | struct gpio_bank *bank = get_irq_chip_data(irq); |
| 1190 | 1235 | ||
| 1191 | _set_gpio_irqenable(bank, gpio, 0); | 1236 | _set_gpio_irqenable(bank, gpio, 0); |
| 1237 | _set_gpio_triggering(bank, get_gpio_index(gpio), IRQ_TYPE_NONE); | ||
| 1192 | } | 1238 | } |
| 1193 | 1239 | ||
| 1194 | static void gpio_unmask_irq(unsigned int irq) | 1240 | static void gpio_unmask_irq(unsigned int irq) |
| @@ -1196,6 +1242,11 @@ static void gpio_unmask_irq(unsigned int irq) | |||
| 1196 | unsigned int gpio = irq - IH_GPIO_BASE; | 1242 | unsigned int gpio = irq - IH_GPIO_BASE; |
| 1197 | struct gpio_bank *bank = get_irq_chip_data(irq); | 1243 | struct gpio_bank *bank = get_irq_chip_data(irq); |
| 1198 | unsigned int irq_mask = 1 << get_gpio_index(gpio); | 1244 | unsigned int irq_mask = 1 << get_gpio_index(gpio); |
| 1245 | struct irq_desc *desc = irq_to_desc(irq); | ||
| 1246 | u32 trigger = desc->status & IRQ_TYPE_SENSE_MASK; | ||
| 1247 | |||
| 1248 | if (trigger) | ||
| 1249 | _set_gpio_triggering(bank, get_gpio_index(gpio), trigger); | ||
| 1199 | 1250 | ||
| 1200 | /* For level-triggered GPIOs, the clearing must be done after | 1251 | /* For level-triggered GPIOs, the clearing must be done after |
| 1201 | * the HW source is cleared, thus after the handler has run */ | 1252 | * the HW source is cleared, thus after the handler has run */ |
| @@ -1350,9 +1401,49 @@ static int gpio_input(struct gpio_chip *chip, unsigned offset) | |||
| 1350 | return 0; | 1401 | return 0; |
| 1351 | } | 1402 | } |
| 1352 | 1403 | ||
| 1404 | static int gpio_is_input(struct gpio_bank *bank, int mask) | ||
| 1405 | { | ||
| 1406 | void __iomem *reg = bank->base; | ||
| 1407 | |||
| 1408 | switch (bank->method) { | ||
| 1409 | case METHOD_MPUIO: | ||
| 1410 | reg += OMAP_MPUIO_IO_CNTL; | ||
| 1411 | break; | ||
| 1412 | case METHOD_GPIO_1510: | ||
| 1413 | reg += OMAP1510_GPIO_DIR_CONTROL; | ||
| 1414 | break; | ||
| 1415 | case METHOD_GPIO_1610: | ||
| 1416 | reg += OMAP1610_GPIO_DIRECTION; | ||
| 1417 | break; | ||
| 1418 | case METHOD_GPIO_730: | ||
| 1419 | reg += OMAP730_GPIO_DIR_CONTROL; | ||
| 1420 | break; | ||
| 1421 | case METHOD_GPIO_850: | ||
| 1422 | reg += OMAP850_GPIO_DIR_CONTROL; | ||
| 1423 | break; | ||
| 1424 | case METHOD_GPIO_24XX: | ||
| 1425 | reg += OMAP24XX_GPIO_OE; | ||
| 1426 | break; | ||
| 1427 | } | ||
| 1428 | return __raw_readl(reg) & mask; | ||
| 1429 | } | ||
| 1430 | |||
| 1353 | static int gpio_get(struct gpio_chip *chip, unsigned offset) | 1431 | static int gpio_get(struct gpio_chip *chip, unsigned offset) |
| 1354 | { | 1432 | { |
| 1355 | return __omap_get_gpio_datain(chip->base + offset); | 1433 | struct gpio_bank *bank; |
| 1434 | void __iomem *reg; | ||
| 1435 | int gpio; | ||
| 1436 | u32 mask; | ||
| 1437 | |||
| 1438 | gpio = chip->base + offset; | ||
| 1439 | bank = get_gpio_bank(gpio); | ||
| 1440 | reg = bank->base; | ||
| 1441 | mask = 1 << get_gpio_index(gpio); | ||
| 1442 | |||
| 1443 | if (gpio_is_input(bank, mask)) | ||
| 1444 | return _get_gpio_datain(bank, gpio); | ||
| 1445 | else | ||
| 1446 | return _get_gpio_dataout(bank, gpio); | ||
| 1356 | } | 1447 | } |
| 1357 | 1448 | ||
| 1358 | static int gpio_output(struct gpio_chip *chip, unsigned offset, int value) | 1449 | static int gpio_output(struct gpio_chip *chip, unsigned offset, int value) |
| @@ -1886,34 +1977,6 @@ arch_initcall(omap_gpio_sysinit); | |||
| 1886 | #include <linux/debugfs.h> | 1977 | #include <linux/debugfs.h> |
| 1887 | #include <linux/seq_file.h> | 1978 | #include <linux/seq_file.h> |
| 1888 | 1979 | ||
| 1889 | static int gpio_is_input(struct gpio_bank *bank, int mask) | ||
| 1890 | { | ||
| 1891 | void __iomem *reg = bank->base; | ||
| 1892 | |||
| 1893 | switch (bank->method) { | ||
| 1894 | case METHOD_MPUIO: | ||
| 1895 | reg += OMAP_MPUIO_IO_CNTL; | ||
| 1896 | break; | ||
| 1897 | case METHOD_GPIO_1510: | ||
| 1898 | reg += OMAP1510_GPIO_DIR_CONTROL; | ||
| 1899 | break; | ||
| 1900 | case METHOD_GPIO_1610: | ||
| 1901 | reg += OMAP1610_GPIO_DIRECTION; | ||
| 1902 | break; | ||
| 1903 | case METHOD_GPIO_730: | ||
| 1904 | reg += OMAP730_GPIO_DIR_CONTROL; | ||
| 1905 | break; | ||
| 1906 | case METHOD_GPIO_850: | ||
| 1907 | reg += OMAP850_GPIO_DIR_CONTROL; | ||
| 1908 | break; | ||
| 1909 | case METHOD_GPIO_24XX: | ||
| 1910 | reg += OMAP24XX_GPIO_OE; | ||
| 1911 | break; | ||
| 1912 | } | ||
| 1913 | return __raw_readl(reg) & mask; | ||
| 1914 | } | ||
| 1915 | |||
| 1916 | |||
| 1917 | static int dbg_gpio_show(struct seq_file *s, void *unused) | 1980 | static int dbg_gpio_show(struct seq_file *s, void *unused) |
| 1918 | { | 1981 | { |
| 1919 | unsigned i, j, gpio; | 1982 | unsigned i, j, gpio; |
diff --git a/arch/arm/plat-omap/include/mach/clock.h b/arch/arm/plat-omap/include/mach/clock.h index f9f65e1ba3f1..4b8b0d65cbf2 100644 --- a/arch/arm/plat-omap/include/mach/clock.h +++ b/arch/arm/plat-omap/include/mach/clock.h | |||
| @@ -20,6 +20,8 @@ struct clockdomain; | |||
| 20 | struct clkops { | 20 | struct clkops { |
| 21 | int (*enable)(struct clk *); | 21 | int (*enable)(struct clk *); |
| 22 | void (*disable)(struct clk *); | 22 | void (*disable)(struct clk *); |
| 23 | void (*find_idlest)(struct clk *, void __iomem **, u8 *); | ||
| 24 | void (*find_companion)(struct clk *, void __iomem **, u8 *); | ||
| 23 | }; | 25 | }; |
| 24 | 26 | ||
| 25 | #if defined(CONFIG_ARCH_OMAP2) || defined(CONFIG_ARCH_OMAP3) || \ | 27 | #if defined(CONFIG_ARCH_OMAP2) || defined(CONFIG_ARCH_OMAP3) || \ |
diff --git a/arch/arm/plat-omap/include/mach/cpu.h b/arch/arm/plat-omap/include/mach/cpu.h index 285eaa3a8275..11e73d9e8928 100644 --- a/arch/arm/plat-omap/include/mach/cpu.h +++ b/arch/arm/plat-omap/include/mach/cpu.h | |||
| @@ -378,9 +378,6 @@ IS_OMAP_TYPE(3430, 0x3430) | |||
| 378 | #define cpu_class_is_omap2() (cpu_is_omap24xx() || cpu_is_omap34xx() || \ | 378 | #define cpu_class_is_omap2() (cpu_is_omap24xx() || cpu_is_omap34xx() || \ |
| 379 | cpu_is_omap44xx()) | 379 | cpu_is_omap44xx()) |
| 380 | 380 | ||
| 381 | #if defined(CONFIG_ARCH_OMAP2) || defined(CONFIG_ARCH_OMAP3) || \ | ||
| 382 | defined(CONFIG_ARCH_OMAP4) | ||
| 383 | |||
| 384 | /* Various silicon revisions for omap2 */ | 381 | /* Various silicon revisions for omap2 */ |
| 385 | #define OMAP242X_CLASS 0x24200024 | 382 | #define OMAP242X_CLASS 0x24200024 |
| 386 | #define OMAP2420_REV_ES1_0 0x24200024 | 383 | #define OMAP2420_REV_ES1_0 0x24200024 |
| @@ -436,5 +433,3 @@ IS_OMAP_TYPE(3430, 0x3430) | |||
| 436 | 433 | ||
| 437 | int omap_chip_is(struct omap_chip_id oci); | 434 | int omap_chip_is(struct omap_chip_id oci); |
| 438 | void omap2_check_revision(void); | 435 | void omap2_check_revision(void); |
| 439 | |||
| 440 | #endif /* defined(CONFIG_ARCH_OMAP2) || defined(CONFIG_ARCH_OMAP3) */ | ||
diff --git a/arch/arm/plat-omap/include/mach/io.h b/arch/arm/plat-omap/include/mach/io.h index 73f483d56ca6..21fb0efdda86 100644 --- a/arch/arm/plat-omap/include/mach/io.h +++ b/arch/arm/plat-omap/include/mach/io.h | |||
| @@ -228,7 +228,8 @@ extern void omap1_map_common_io(void); | |||
| 228 | extern void omap1_init_common_hw(void); | 228 | extern void omap1_init_common_hw(void); |
| 229 | 229 | ||
| 230 | extern void omap2_map_common_io(void); | 230 | extern void omap2_map_common_io(void); |
| 231 | extern void omap2_init_common_hw(struct omap_sdrc_params *sp); | 231 | extern void omap2_init_common_hw(struct omap_sdrc_params *sdrc_cs0, |
| 232 | struct omap_sdrc_params *sdrc_cs1); | ||
| 232 | 233 | ||
| 233 | #define __arch_ioremap(p,s,t) omap_ioremap(p,s,t) | 234 | #define __arch_ioremap(p,s,t) omap_ioremap(p,s,t) |
| 234 | #define __arch_iounmap(v) omap_iounmap(v) | 235 | #define __arch_iounmap(v) omap_iounmap(v) |
diff --git a/arch/arm/plat-omap/include/mach/mux.h b/arch/arm/plat-omap/include/mach/mux.h index 85a621705766..80281c458baf 100644 --- a/arch/arm/plat-omap/include/mach/mux.h +++ b/arch/arm/plat-omap/include/mach/mux.h | |||
| @@ -853,6 +853,10 @@ enum omap34xx_index { | |||
| 853 | AE5_34XX_GPIO143, | 853 | AE5_34XX_GPIO143, |
| 854 | H19_34XX_GPIO164_OUT, | 854 | H19_34XX_GPIO164_OUT, |
| 855 | J25_34XX_GPIO170, | 855 | J25_34XX_GPIO170, |
| 856 | |||
| 857 | /* OMAP3 SDRC CKE signals to SDR/DDR ram chips */ | ||
| 858 | H16_34XX_SDRC_CKE0, | ||
| 859 | H17_34XX_SDRC_CKE1, | ||
| 856 | }; | 860 | }; |
| 857 | 861 | ||
| 858 | struct omap_mux_cfg { | 862 | struct omap_mux_cfg { |
diff --git a/arch/arm/plat-omap/include/mach/prcm.h b/arch/arm/plat-omap/include/mach/prcm.h index 24ac3c715912..cda2a70397b4 100644 --- a/arch/arm/plat-omap/include/mach/prcm.h +++ b/arch/arm/plat-omap/include/mach/prcm.h | |||
| @@ -25,6 +25,7 @@ | |||
| 25 | 25 | ||
| 26 | u32 omap_prcm_get_reset_sources(void); | 26 | u32 omap_prcm_get_reset_sources(void); |
| 27 | void omap_prcm_arch_reset(char mode); | 27 | void omap_prcm_arch_reset(char mode); |
| 28 | int omap2_cm_wait_idlest(void __iomem *reg, u32 mask, const char *name); | ||
| 28 | 29 | ||
| 29 | #endif | 30 | #endif |
| 30 | 31 | ||
diff --git a/arch/arm/plat-omap/include/mach/sdrc.h b/arch/arm/plat-omap/include/mach/sdrc.h index adc73522491f..0be18e4ff182 100644 --- a/arch/arm/plat-omap/include/mach/sdrc.h +++ b/arch/arm/plat-omap/include/mach/sdrc.h | |||
| @@ -30,6 +30,10 @@ | |||
| 30 | #define SDRC_ACTIM_CTRL_A_0 0x09c | 30 | #define SDRC_ACTIM_CTRL_A_0 0x09c |
| 31 | #define SDRC_ACTIM_CTRL_B_0 0x0a0 | 31 | #define SDRC_ACTIM_CTRL_B_0 0x0a0 |
| 32 | #define SDRC_RFR_CTRL_0 0x0a4 | 32 | #define SDRC_RFR_CTRL_0 0x0a4 |
| 33 | #define SDRC_MR_1 0x0B4 | ||
| 34 | #define SDRC_ACTIM_CTRL_A_1 0x0C4 | ||
| 35 | #define SDRC_ACTIM_CTRL_B_1 0x0C8 | ||
| 36 | #define SDRC_RFR_CTRL_1 0x0D4 | ||
| 33 | 37 | ||
| 34 | /* | 38 | /* |
| 35 | * These values represent the number of memory clock cycles between | 39 | * These values represent the number of memory clock cycles between |
| @@ -102,8 +106,11 @@ struct omap_sdrc_params { | |||
| 102 | u32 mr; | 106 | u32 mr; |
| 103 | }; | 107 | }; |
| 104 | 108 | ||
| 105 | void __init omap2_sdrc_init(struct omap_sdrc_params *sp); | 109 | void __init omap2_sdrc_init(struct omap_sdrc_params *sdrc_cs0, |
| 106 | struct omap_sdrc_params *omap2_sdrc_get_params(unsigned long r); | 110 | struct omap_sdrc_params *sdrc_cs1); |
| 111 | int omap2_sdrc_get_params(unsigned long r, | ||
| 112 | struct omap_sdrc_params **sdrc_cs0, | ||
| 113 | struct omap_sdrc_params **sdrc_cs1); | ||
| 107 | 114 | ||
| 108 | #ifdef CONFIG_ARCH_OMAP2 | 115 | #ifdef CONFIG_ARCH_OMAP2 |
| 109 | 116 | ||
diff --git a/arch/arm/plat-omap/include/mach/serial.h b/arch/arm/plat-omap/include/mach/serial.h index 13abd02d1527..def0529c75eb 100644 --- a/arch/arm/plat-omap/include/mach/serial.h +++ b/arch/arm/plat-omap/include/mach/serial.h | |||
| @@ -59,6 +59,7 @@ extern void omap_uart_check_wakeup(void); | |||
| 59 | extern void omap_uart_prepare_suspend(void); | 59 | extern void omap_uart_prepare_suspend(void); |
| 60 | extern void omap_uart_prepare_idle(int num); | 60 | extern void omap_uart_prepare_idle(int num); |
| 61 | extern void omap_uart_resume_idle(int num); | 61 | extern void omap_uart_resume_idle(int num); |
| 62 | extern void omap_uart_enable_irqs(int enable); | ||
| 62 | #endif | 63 | #endif |
| 63 | 64 | ||
| 64 | #endif | 65 | #endif |
diff --git a/arch/arm/plat-omap/include/mach/sram.h b/arch/arm/plat-omap/include/mach/sram.h index 4d53cc59d7a3..8974e3fc2691 100644 --- a/arch/arm/plat-omap/include/mach/sram.h +++ b/arch/arm/plat-omap/include/mach/sram.h | |||
| @@ -21,11 +21,12 @@ extern void omap2_sram_reprogram_sdrc(u32 perf_level, u32 dll_val, | |||
| 21 | u32 mem_type); | 21 | u32 mem_type); |
| 22 | extern u32 omap2_set_prcm(u32 dpll_ctrl_val, u32 sdrc_rfr_val, int bypass); | 22 | extern u32 omap2_set_prcm(u32 dpll_ctrl_val, u32 sdrc_rfr_val, int bypass); |
| 23 | 23 | ||
| 24 | extern u32 omap3_configure_core_dpll(u32 sdrc_rfr_ctrl, | 24 | extern u32 omap3_configure_core_dpll( |
| 25 | u32 sdrc_actim_ctrla, | 25 | u32 m2, u32 unlock_dll, u32 f, u32 inc, |
| 26 | u32 sdrc_actim_ctrlb, u32 m2, | 26 | u32 sdrc_rfr_ctrl_0, u32 sdrc_actim_ctrl_a_0, |
| 27 | u32 unlock_dll, u32 f, u32 sdrc_mr, | 27 | u32 sdrc_actim_ctrl_b_0, u32 sdrc_mr_0, |
| 28 | u32 inc); | 28 | u32 sdrc_rfr_ctrl_1, u32 sdrc_actim_ctrl_a_1, |
| 29 | u32 sdrc_actim_ctrl_b_1, u32 sdrc_mr_1); | ||
| 29 | 30 | ||
| 30 | /* Do not use these */ | 31 | /* Do not use these */ |
| 31 | extern void omap1_sram_reprogram_clock(u32 ckctl, u32 dpllctl); | 32 | extern void omap1_sram_reprogram_clock(u32 ckctl, u32 dpllctl); |
| @@ -59,12 +60,12 @@ extern void omap243x_sram_reprogram_sdrc(u32 perf_level, u32 dll_val, | |||
| 59 | u32 mem_type); | 60 | u32 mem_type); |
| 60 | extern unsigned long omap243x_sram_reprogram_sdrc_sz; | 61 | extern unsigned long omap243x_sram_reprogram_sdrc_sz; |
| 61 | 62 | ||
| 62 | 63 | extern u32 omap3_sram_configure_core_dpll( | |
| 63 | extern u32 omap3_sram_configure_core_dpll(u32 sdrc_rfr_ctrl, | 64 | u32 m2, u32 unlock_dll, u32 f, u32 inc, |
| 64 | u32 sdrc_actim_ctrla, | 65 | u32 sdrc_rfr_ctrl_0, u32 sdrc_actim_ctrl_a_0, |
| 65 | u32 sdrc_actim_ctrlb, u32 m2, | 66 | u32 sdrc_actim_ctrl_b_0, u32 sdrc_mr_0, |
| 66 | u32 unlock_dll, u32 f, u32 sdrc_mr, | 67 | u32 sdrc_rfr_ctrl_1, u32 sdrc_actim_ctrl_a_1, |
| 67 | u32 inc); | 68 | u32 sdrc_actim_ctrl_b_1, u32 sdrc_mr_1); |
| 68 | extern unsigned long omap3_sram_configure_core_dpll_sz; | 69 | extern unsigned long omap3_sram_configure_core_dpll_sz; |
| 69 | 70 | ||
| 70 | #endif | 71 | #endif |
diff --git a/arch/arm/plat-omap/sram.c b/arch/arm/plat-omap/sram.c index 4ea73804d21e..5eae7876979c 100644 --- a/arch/arm/plat-omap/sram.c +++ b/arch/arm/plat-omap/sram.c | |||
| @@ -44,9 +44,9 @@ | |||
| 44 | #define OMAP2_SRAM_VA 0xe3000000 | 44 | #define OMAP2_SRAM_VA 0xe3000000 |
| 45 | #define OMAP2_SRAM_PUB_VA (OMAP2_SRAM_VA + 0x800) | 45 | #define OMAP2_SRAM_PUB_VA (OMAP2_SRAM_VA + 0x800) |
| 46 | #define OMAP3_SRAM_PA 0x40200000 | 46 | #define OMAP3_SRAM_PA 0x40200000 |
| 47 | #define OMAP3_SRAM_VA 0xd7000000 | 47 | #define OMAP3_SRAM_VA 0xe3000000 |
| 48 | #define OMAP3_SRAM_PUB_PA 0x40208000 | 48 | #define OMAP3_SRAM_PUB_PA 0x40208000 |
| 49 | #define OMAP3_SRAM_PUB_VA 0xd7008000 | 49 | #define OMAP3_SRAM_PUB_VA (OMAP3_SRAM_VA + 0x8000) |
| 50 | #define OMAP4_SRAM_PA 0x40200000 /*0x402f0000*/ | 50 | #define OMAP4_SRAM_PA 0x40200000 /*0x402f0000*/ |
| 51 | #define OMAP4_SRAM_VA 0xd7000000 /*0xd70f0000*/ | 51 | #define OMAP4_SRAM_VA 0xd7000000 /*0xd70f0000*/ |
| 52 | 52 | ||
| @@ -373,20 +373,26 @@ static inline int omap243x_sram_init(void) | |||
| 373 | 373 | ||
| 374 | #ifdef CONFIG_ARCH_OMAP3 | 374 | #ifdef CONFIG_ARCH_OMAP3 |
| 375 | 375 | ||
| 376 | static u32 (*_omap3_sram_configure_core_dpll)(u32 sdrc_rfr_ctrl, | 376 | static u32 (*_omap3_sram_configure_core_dpll)( |
| 377 | u32 sdrc_actim_ctrla, | 377 | u32 m2, u32 unlock_dll, u32 f, u32 inc, |
| 378 | u32 sdrc_actim_ctrlb, | 378 | u32 sdrc_rfr_ctrl_0, u32 sdrc_actim_ctrl_a_0, |
| 379 | u32 m2, u32 unlock_dll, | 379 | u32 sdrc_actim_ctrl_b_0, u32 sdrc_mr_0, |
| 380 | u32 f, u32 sdrc_mr, u32 inc); | 380 | u32 sdrc_rfr_ctrl_1, u32 sdrc_actim_ctrl_a_1, |
| 381 | u32 omap3_configure_core_dpll(u32 sdrc_rfr_ctrl, u32 sdrc_actim_ctrla, | 381 | u32 sdrc_actim_ctrl_b_1, u32 sdrc_mr_1); |
| 382 | u32 sdrc_actim_ctrlb, u32 m2, u32 unlock_dll, | 382 | |
| 383 | u32 f, u32 sdrc_mr, u32 inc) | 383 | u32 omap3_configure_core_dpll(u32 m2, u32 unlock_dll, u32 f, u32 inc, |
| 384 | u32 sdrc_rfr_ctrl_0, u32 sdrc_actim_ctrl_a_0, | ||
| 385 | u32 sdrc_actim_ctrl_b_0, u32 sdrc_mr_0, | ||
| 386 | u32 sdrc_rfr_ctrl_1, u32 sdrc_actim_ctrl_a_1, | ||
| 387 | u32 sdrc_actim_ctrl_b_1, u32 sdrc_mr_1) | ||
| 384 | { | 388 | { |
| 385 | BUG_ON(!_omap3_sram_configure_core_dpll); | 389 | BUG_ON(!_omap3_sram_configure_core_dpll); |
| 386 | return _omap3_sram_configure_core_dpll(sdrc_rfr_ctrl, | 390 | return _omap3_sram_configure_core_dpll( |
| 387 | sdrc_actim_ctrla, | 391 | m2, unlock_dll, f, inc, |
| 388 | sdrc_actim_ctrlb, m2, | 392 | sdrc_rfr_ctrl_0, sdrc_actim_ctrl_a_0, |
| 389 | unlock_dll, f, sdrc_mr, inc); | 393 | sdrc_actim_ctrl_b_0, sdrc_mr_0, |
| 394 | sdrc_rfr_ctrl_1, sdrc_actim_ctrl_a_1, | ||
| 395 | sdrc_actim_ctrl_b_1, sdrc_mr_1); | ||
| 390 | } | 396 | } |
| 391 | 397 | ||
| 392 | /* REVISIT: Should this be same as omap34xx_sram_init() after off-idle? */ | 398 | /* REVISIT: Should this be same as omap34xx_sram_init() after off-idle? */ |
diff --git a/arch/arm/plat-orion/include/plat/gpio.h b/arch/arm/plat-orion/include/plat/gpio.h index 9646a94ed3d0..07c430fdc9ef 100644 --- a/arch/arm/plat-orion/include/plat/gpio.h +++ b/arch/arm/plat-orion/include/plat/gpio.h | |||
| @@ -11,6 +11,8 @@ | |||
| 11 | #ifndef __PLAT_GPIO_H | 11 | #ifndef __PLAT_GPIO_H |
| 12 | #define __PLAT_GPIO_H | 12 | #define __PLAT_GPIO_H |
| 13 | 13 | ||
| 14 | #include <linux/init.h> | ||
| 15 | |||
| 14 | /* | 16 | /* |
| 15 | * GENERIC_GPIO primitives. | 17 | * GENERIC_GPIO primitives. |
| 16 | */ | 18 | */ |
diff --git a/arch/arm/plat-s3c24xx/clock-dclk.c b/arch/arm/plat-s3c24xx/clock-dclk.c index 5b75a797b5ab..0afb217a775e 100644 --- a/arch/arm/plat-s3c24xx/clock-dclk.c +++ b/arch/arm/plat-s3c24xx/clock-dclk.c | |||
| @@ -129,7 +129,7 @@ static int s3c24xx_clkout_setparent(struct clk *clk, struct clk *parent) | |||
| 129 | 129 | ||
| 130 | /* calculate the MISCCR setting for the clock */ | 130 | /* calculate the MISCCR setting for the clock */ |
| 131 | 131 | ||
| 132 | if (parent == &clk_xtal) | 132 | if (parent == &clk_mpll) |
| 133 | source = S3C2410_MISCCR_CLK0_MPLL; | 133 | source = S3C2410_MISCCR_CLK0_MPLL; |
| 134 | else if (parent == &clk_upll) | 134 | else if (parent == &clk_upll) |
| 135 | source = S3C2410_MISCCR_CLK0_UPLL; | 135 | source = S3C2410_MISCCR_CLK0_UPLL; |
diff --git a/arch/arm/plat-s3c24xx/pwm.c b/arch/arm/plat-s3c24xx/pwm.c index 0120b760315b..82a6d4de02a3 100644 --- a/arch/arm/plat-s3c24xx/pwm.c +++ b/arch/arm/plat-s3c24xx/pwm.c | |||
| @@ -246,6 +246,10 @@ int pwm_config(struct pwm_device *pwm, int duty_ns, int period_ns) | |||
| 246 | 246 | ||
| 247 | tcmp = duty_ns / tin_ns; | 247 | tcmp = duty_ns / tin_ns; |
| 248 | tcmp = tcnt - tcmp; | 248 | tcmp = tcnt - tcmp; |
| 249 | /* the pwm hw only checks the compare register after a decrement, | ||
| 250 | so the pin never toggles if tcmp = tcnt */ | ||
| 251 | if (tcmp == tcnt) | ||
| 252 | tcmp--; | ||
| 249 | 253 | ||
| 250 | pwm_dbg(pwm, "tin_ns=%lu, tcmp=%ld/%lu\n", tin_ns, tcmp, tcnt); | 254 | pwm_dbg(pwm, "tin_ns=%lu, tcmp=%ld/%lu\n", tin_ns, tcmp, tcnt); |
| 251 | 255 | ||
diff --git a/arch/arm/plat-s3c64xx/pm.c b/arch/arm/plat-s3c64xx/pm.c index 07a6516a4f3c..47632fc7eb66 100644 --- a/arch/arm/plat-s3c64xx/pm.c +++ b/arch/arm/plat-s3c64xx/pm.c | |||
| @@ -117,8 +117,6 @@ void s3c_pm_save_core(void) | |||
| 117 | * this. | 117 | * this. |
| 118 | */ | 118 | */ |
| 119 | 119 | ||
| 120 | #include <plat/regs-gpio.h> | ||
| 121 | |||
| 122 | static void s3c64xx_cpu_suspend(void) | 120 | static void s3c64xx_cpu_suspend(void) |
| 123 | { | 121 | { |
| 124 | unsigned long tmp; | 122 | unsigned long tmp; |
diff --git a/arch/arm/plat-s3c64xx/s3c6400-clock.c b/arch/arm/plat-s3c64xx/s3c6400-clock.c index 1debc1f9f987..febac1950d8e 100644 --- a/arch/arm/plat-s3c64xx/s3c6400-clock.c +++ b/arch/arm/plat-s3c64xx/s3c6400-clock.c | |||
| @@ -153,7 +153,7 @@ static unsigned long s3c64xx_clk_arm_round_rate(struct clk *clk, | |||
| 153 | u32 div; | 153 | u32 div; |
| 154 | 154 | ||
| 155 | if (parent < rate) | 155 | if (parent < rate) |
| 156 | return rate; | 156 | return parent; |
| 157 | 157 | ||
| 158 | div = (parent / rate) - 1; | 158 | div = (parent / rate) - 1; |
| 159 | if (div > armclk_mask) | 159 | if (div > armclk_mask) |
| @@ -175,7 +175,7 @@ static int s3c64xx_clk_arm_set_rate(struct clk *clk, unsigned long rate) | |||
| 175 | div = clk_get_rate(clk->parent) / rate; | 175 | div = clk_get_rate(clk->parent) / rate; |
| 176 | 176 | ||
| 177 | val = __raw_readl(S3C_CLK_DIV0); | 177 | val = __raw_readl(S3C_CLK_DIV0); |
| 178 | val &= armclk_mask; | 178 | val &= ~armclk_mask; |
| 179 | val |= (div - 1); | 179 | val |= (div - 1); |
| 180 | __raw_writel(val, S3C_CLK_DIV0); | 180 | __raw_writel(val, S3C_CLK_DIV0); |
| 181 | 181 | ||
diff --git a/arch/arm/plat-stmp3xxx/pinmux.c b/arch/arm/plat-stmp3xxx/pinmux.c index d41200382208..6d6b1a468eda 100644 --- a/arch/arm/plat-stmp3xxx/pinmux.c +++ b/arch/arm/plat-stmp3xxx/pinmux.c | |||
| @@ -22,7 +22,6 @@ | |||
| 22 | #include <linux/sysdev.h> | 22 | #include <linux/sysdev.h> |
| 23 | #include <linux/string.h> | 23 | #include <linux/string.h> |
| 24 | #include <linux/bitops.h> | 24 | #include <linux/bitops.h> |
| 25 | #include <linux/sysdev.h> | ||
| 26 | #include <linux/irq.h> | 25 | #include <linux/irq.h> |
| 27 | 26 | ||
| 28 | #include <mach/hardware.h> | 27 | #include <mach/hardware.h> |
diff --git a/arch/avr32/boards/favr-32/setup.c b/arch/avr32/boards/favr-32/setup.c index 46c9b0a224cf..75f19f47fb2f 100644 --- a/arch/avr32/boards/favr-32/setup.c +++ b/arch/avr32/boards/favr-32/setup.c | |||
| @@ -72,6 +72,10 @@ static struct ads7846_platform_data ads7843_data = { | |||
| 72 | .debounce_max = 20, | 72 | .debounce_max = 20, |
| 73 | .debounce_rep = 4, | 73 | .debounce_rep = 4, |
| 74 | .debounce_tol = 5, | 74 | .debounce_tol = 5, |
| 75 | |||
| 76 | .keep_vref_on = true, | ||
| 77 | .settle_delay_usecs = 500, | ||
| 78 | .penirq_recheck_delay_usecs = 100, | ||
| 75 | }; | 79 | }; |
| 76 | 80 | ||
| 77 | static struct spi_board_info __initdata spi1_board_info[] = { | 81 | static struct spi_board_info __initdata spi1_board_info[] = { |
diff --git a/arch/avr32/include/asm/pgalloc.h b/arch/avr32/include/asm/pgalloc.h index 640821323943..92ecd8446ef8 100644 --- a/arch/avr32/include/asm/pgalloc.h +++ b/arch/avr32/include/asm/pgalloc.h | |||
| @@ -83,7 +83,7 @@ static inline void pte_free(struct mm_struct *mm, pgtable_t pte) | |||
| 83 | quicklist_free_page(QUICK_PT, NULL, pte); | 83 | quicklist_free_page(QUICK_PT, NULL, pte); |
| 84 | } | 84 | } |
| 85 | 85 | ||
| 86 | #define __pte_free_tlb(tlb,pte) \ | 86 | #define __pte_free_tlb(tlb,pte,addr) \ |
| 87 | do { \ | 87 | do { \ |
| 88 | pgtable_page_dtor(pte); \ | 88 | pgtable_page_dtor(pte); \ |
| 89 | tlb_remove_page((tlb), pte); \ | 89 | tlb_remove_page((tlb), pte); \ |
diff --git a/arch/avr32/lib/memcpy.S b/arch/avr32/lib/memcpy.S index 0abb26142b64..c2ca49d705af 100644 --- a/arch/avr32/lib/memcpy.S +++ b/arch/avr32/lib/memcpy.S | |||
| @@ -24,8 +24,8 @@ memcpy: | |||
| 24 | brne 1f | 24 | brne 1f |
| 25 | 25 | ||
| 26 | /* At this point, "from" is word-aligned */ | 26 | /* At this point, "from" is word-aligned */ |
| 27 | 2: sub r10, 4 | 27 | 2: mov r9, r12 |
| 28 | mov r9, r12 | 28 | 5: sub r10, 4 |
| 29 | brlt 4f | 29 | brlt 4f |
| 30 | 30 | ||
| 31 | 3: ld.w r8, r11++ | 31 | 3: ld.w r8, r11++ |
| @@ -49,6 +49,7 @@ memcpy: | |||
| 49 | 49 | ||
| 50 | /* Handle unaligned "from" pointer */ | 50 | /* Handle unaligned "from" pointer */ |
| 51 | 1: sub r10, 4 | 51 | 1: sub r10, 4 |
| 52 | movlt r9, r12 | ||
| 52 | brlt 4b | 53 | brlt 4b |
| 53 | add r10, r9 | 54 | add r10, r9 |
| 54 | lsl r9, 2 | 55 | lsl r9, 2 |
| @@ -59,4 +60,13 @@ memcpy: | |||
| 59 | st.b r12++, r8 | 60 | st.b r12++, r8 |
| 60 | ld.ub r8, r11++ | 61 | ld.ub r8, r11++ |
| 61 | st.b r12++, r8 | 62 | st.b r12++, r8 |
| 62 | rjmp 2b | 63 | mov r8, r12 |
| 64 | add pc, pc, r9 | ||
| 65 | sub r8, 1 | ||
| 66 | nop | ||
| 67 | sub r8, 1 | ||
| 68 | nop | ||
| 69 | sub r8, 1 | ||
| 70 | nop | ||
| 71 | mov r9, r8 | ||
| 72 | rjmp 5b | ||
diff --git a/arch/cris/include/asm/pgalloc.h b/arch/cris/include/asm/pgalloc.h index a1ba761d0573..6da975db112f 100644 --- a/arch/cris/include/asm/pgalloc.h +++ b/arch/cris/include/asm/pgalloc.h | |||
| @@ -47,7 +47,7 @@ static inline void pte_free(struct mm_struct *mm, pgtable_t pte) | |||
| 47 | __free_page(pte); | 47 | __free_page(pte); |
| 48 | } | 48 | } |
| 49 | 49 | ||
| 50 | #define __pte_free_tlb(tlb,pte) \ | 50 | #define __pte_free_tlb(tlb,pte,address) \ |
| 51 | do { \ | 51 | do { \ |
| 52 | pgtable_page_dtor(pte); \ | 52 | pgtable_page_dtor(pte); \ |
| 53 | tlb_remove_page((tlb), pte); \ | 53 | tlb_remove_page((tlb), pte); \ |
diff --git a/arch/frv/include/asm/pgalloc.h b/arch/frv/include/asm/pgalloc.h index 971e6addb009..416d19a632f2 100644 --- a/arch/frv/include/asm/pgalloc.h +++ b/arch/frv/include/asm/pgalloc.h | |||
| @@ -49,7 +49,7 @@ static inline void pte_free(struct mm_struct *mm, pgtable_t pte) | |||
| 49 | __free_page(pte); | 49 | __free_page(pte); |
| 50 | } | 50 | } |
| 51 | 51 | ||
| 52 | #define __pte_free_tlb(tlb,pte) \ | 52 | #define __pte_free_tlb(tlb,pte,address) \ |
| 53 | do { \ | 53 | do { \ |
| 54 | pgtable_page_dtor(pte); \ | 54 | pgtable_page_dtor(pte); \ |
| 55 | tlb_remove_page((tlb),(pte)); \ | 55 | tlb_remove_page((tlb),(pte)); \ |
| @@ -62,7 +62,7 @@ do { \ | |||
| 62 | */ | 62 | */ |
| 63 | #define pmd_alloc_one(mm, addr) ({ BUG(); ((pmd_t *) 2); }) | 63 | #define pmd_alloc_one(mm, addr) ({ BUG(); ((pmd_t *) 2); }) |
| 64 | #define pmd_free(mm, x) do { } while (0) | 64 | #define pmd_free(mm, x) do { } while (0) |
| 65 | #define __pmd_free_tlb(tlb,x) do { } while (0) | 65 | #define __pmd_free_tlb(tlb,x,a) do { } while (0) |
| 66 | 66 | ||
| 67 | #endif /* CONFIG_MMU */ | 67 | #endif /* CONFIG_MMU */ |
| 68 | 68 | ||
diff --git a/arch/frv/include/asm/pgtable.h b/arch/frv/include/asm/pgtable.h index 33233011b1c1..22c60692b551 100644 --- a/arch/frv/include/asm/pgtable.h +++ b/arch/frv/include/asm/pgtable.h | |||
| @@ -225,7 +225,7 @@ static inline pud_t *pud_offset(pgd_t *pgd, unsigned long address) | |||
| 225 | */ | 225 | */ |
| 226 | #define pud_alloc_one(mm, address) NULL | 226 | #define pud_alloc_one(mm, address) NULL |
| 227 | #define pud_free(mm, x) do { } while (0) | 227 | #define pud_free(mm, x) do { } while (0) |
| 228 | #define __pud_free_tlb(tlb, x) do { } while (0) | 228 | #define __pud_free_tlb(tlb, x, address) do { } while (0) |
| 229 | 229 | ||
| 230 | /* | 230 | /* |
| 231 | * The "pud_xxx()" functions here are trivial for a folded two-level | 231 | * The "pud_xxx()" functions here are trivial for a folded two-level |
diff --git a/arch/ia64/Makefile b/arch/ia64/Makefile index 58a7e46affda..e7cbaa02cd0b 100644 --- a/arch/ia64/Makefile +++ b/arch/ia64/Makefile | |||
| @@ -41,11 +41,6 @@ $(error Sorry, you need a newer version of the assember, one that is built from | |||
| 41 | ftp://ftp.hpl.hp.com/pub/linux-ia64/gas-030124.tar.gz) | 41 | ftp://ftp.hpl.hp.com/pub/linux-ia64/gas-030124.tar.gz) |
| 42 | endif | 42 | endif |
| 43 | 43 | ||
| 44 | ifeq ($(call cc-version),0304) | ||
| 45 | cflags-$(CONFIG_ITANIUM) += -mtune=merced | ||
| 46 | cflags-$(CONFIG_MCKINLEY) += -mtune=mckinley | ||
| 47 | endif | ||
| 48 | |||
| 49 | KBUILD_CFLAGS += $(cflags-y) | 44 | KBUILD_CFLAGS += $(cflags-y) |
| 50 | head-y := arch/ia64/kernel/head.o arch/ia64/kernel/init_task.o | 45 | head-y := arch/ia64/kernel/head.o arch/ia64/kernel/init_task.o |
| 51 | 46 | ||
diff --git a/arch/ia64/include/asm/bitops.h b/arch/ia64/include/asm/bitops.h index e2ca80037335..57a2787bc9fb 100644 --- a/arch/ia64/include/asm/bitops.h +++ b/arch/ia64/include/asm/bitops.h | |||
| @@ -286,7 +286,7 @@ __test_and_clear_bit(int nr, volatile void * addr) | |||
| 286 | { | 286 | { |
| 287 | __u32 *p = (__u32 *) addr + (nr >> 5); | 287 | __u32 *p = (__u32 *) addr + (nr >> 5); |
| 288 | __u32 m = 1 << (nr & 31); | 288 | __u32 m = 1 << (nr & 31); |
| 289 | int oldbitset = *p & m; | 289 | int oldbitset = (*p & m) != 0; |
| 290 | 290 | ||
| 291 | *p &= ~m; | 291 | *p &= ~m; |
| 292 | return oldbitset; | 292 | return oldbitset; |
diff --git a/arch/ia64/include/asm/pgalloc.h b/arch/ia64/include/asm/pgalloc.h index b9ac1a6fc216..96a8d927db28 100644 --- a/arch/ia64/include/asm/pgalloc.h +++ b/arch/ia64/include/asm/pgalloc.h | |||
| @@ -48,7 +48,7 @@ static inline void pud_free(struct mm_struct *mm, pud_t *pud) | |||
| 48 | { | 48 | { |
| 49 | quicklist_free(0, NULL, pud); | 49 | quicklist_free(0, NULL, pud); |
| 50 | } | 50 | } |
| 51 | #define __pud_free_tlb(tlb, pud) pud_free((tlb)->mm, pud) | 51 | #define __pud_free_tlb(tlb, pud, address) pud_free((tlb)->mm, pud) |
| 52 | #endif /* CONFIG_PGTABLE_4 */ | 52 | #endif /* CONFIG_PGTABLE_4 */ |
| 53 | 53 | ||
| 54 | static inline void | 54 | static inline void |
| @@ -67,7 +67,7 @@ static inline void pmd_free(struct mm_struct *mm, pmd_t *pmd) | |||
| 67 | quicklist_free(0, NULL, pmd); | 67 | quicklist_free(0, NULL, pmd); |
| 68 | } | 68 | } |
| 69 | 69 | ||
| 70 | #define __pmd_free_tlb(tlb, pmd) pmd_free((tlb)->mm, pmd) | 70 | #define __pmd_free_tlb(tlb, pmd, address) pmd_free((tlb)->mm, pmd) |
| 71 | 71 | ||
| 72 | static inline void | 72 | static inline void |
| 73 | pmd_populate(struct mm_struct *mm, pmd_t * pmd_entry, pgtable_t pte) | 73 | pmd_populate(struct mm_struct *mm, pmd_t * pmd_entry, pgtable_t pte) |
| @@ -117,6 +117,6 @@ static inline void check_pgt_cache(void) | |||
| 117 | quicklist_trim(0, NULL, 25, 16); | 117 | quicklist_trim(0, NULL, 25, 16); |
| 118 | } | 118 | } |
| 119 | 119 | ||
| 120 | #define __pte_free_tlb(tlb, pte) pte_free((tlb)->mm, pte) | 120 | #define __pte_free_tlb(tlb, pte, address) pte_free((tlb)->mm, pte) |
| 121 | 121 | ||
| 122 | #endif /* _ASM_IA64_PGALLOC_H */ | 122 | #endif /* _ASM_IA64_PGALLOC_H */ |
diff --git a/arch/ia64/include/asm/pgtable.h b/arch/ia64/include/asm/pgtable.h index 0a9cc73d35c7..8840a690d1e7 100644 --- a/arch/ia64/include/asm/pgtable.h +++ b/arch/ia64/include/asm/pgtable.h | |||
| @@ -155,7 +155,6 @@ | |||
| 155 | #include <linux/bitops.h> | 155 | #include <linux/bitops.h> |
| 156 | #include <asm/cacheflush.h> | 156 | #include <asm/cacheflush.h> |
| 157 | #include <asm/mmu_context.h> | 157 | #include <asm/mmu_context.h> |
| 158 | #include <asm/processor.h> | ||
| 159 | 158 | ||
| 160 | /* | 159 | /* |
| 161 | * Next come the mappings that determine how mmap() protection bits | 160 | * Next come the mappings that determine how mmap() protection bits |
diff --git a/arch/ia64/include/asm/tlb.h b/arch/ia64/include/asm/tlb.h index 20d8a39680c2..85d965cb19a0 100644 --- a/arch/ia64/include/asm/tlb.h +++ b/arch/ia64/include/asm/tlb.h | |||
| @@ -236,22 +236,22 @@ do { \ | |||
| 236 | __tlb_remove_tlb_entry(tlb, ptep, addr); \ | 236 | __tlb_remove_tlb_entry(tlb, ptep, addr); \ |
| 237 | } while (0) | 237 | } while (0) |
| 238 | 238 | ||
| 239 | #define pte_free_tlb(tlb, ptep) \ | 239 | #define pte_free_tlb(tlb, ptep, address) \ |
| 240 | do { \ | 240 | do { \ |
| 241 | tlb->need_flush = 1; \ | 241 | tlb->need_flush = 1; \ |
| 242 | __pte_free_tlb(tlb, ptep); \ | 242 | __pte_free_tlb(tlb, ptep, address); \ |
| 243 | } while (0) | 243 | } while (0) |
| 244 | 244 | ||
| 245 | #define pmd_free_tlb(tlb, ptep) \ | 245 | #define pmd_free_tlb(tlb, ptep, address) \ |
| 246 | do { \ | 246 | do { \ |
| 247 | tlb->need_flush = 1; \ | 247 | tlb->need_flush = 1; \ |
| 248 | __pmd_free_tlb(tlb, ptep); \ | 248 | __pmd_free_tlb(tlb, ptep, address); \ |
| 249 | } while (0) | 249 | } while (0) |
| 250 | 250 | ||
| 251 | #define pud_free_tlb(tlb, pudp) \ | 251 | #define pud_free_tlb(tlb, pudp, address) \ |
| 252 | do { \ | 252 | do { \ |
| 253 | tlb->need_flush = 1; \ | 253 | tlb->need_flush = 1; \ |
| 254 | __pud_free_tlb(tlb, pudp); \ | 254 | __pud_free_tlb(tlb, pudp, address); \ |
| 255 | } while (0) | 255 | } while (0) |
| 256 | 256 | ||
| 257 | #endif /* _ASM_IA64_TLB_H */ | 257 | #endif /* _ASM_IA64_TLB_H */ |
diff --git a/arch/ia64/kernel/ia64_ksyms.c b/arch/ia64/kernel/ia64_ksyms.c index 2d311864e359..8ebccb589e1c 100644 --- a/arch/ia64/kernel/ia64_ksyms.c +++ b/arch/ia64/kernel/ia64_ksyms.c | |||
| @@ -21,6 +21,7 @@ EXPORT_SYMBOL(csum_ipv6_magic); | |||
| 21 | 21 | ||
| 22 | #include <asm/page.h> | 22 | #include <asm/page.h> |
| 23 | EXPORT_SYMBOL(clear_page); | 23 | EXPORT_SYMBOL(clear_page); |
| 24 | EXPORT_SYMBOL(copy_page); | ||
| 24 | 25 | ||
| 25 | #ifdef CONFIG_VIRTUAL_MEM_MAP | 26 | #ifdef CONFIG_VIRTUAL_MEM_MAP |
| 26 | #include <linux/bootmem.h> | 27 | #include <linux/bootmem.h> |
| @@ -60,9 +61,6 @@ EXPORT_SYMBOL(__udivdi3); | |||
| 60 | EXPORT_SYMBOL(__moddi3); | 61 | EXPORT_SYMBOL(__moddi3); |
| 61 | EXPORT_SYMBOL(__umoddi3); | 62 | EXPORT_SYMBOL(__umoddi3); |
| 62 | 63 | ||
| 63 | #include <asm/page.h> | ||
| 64 | EXPORT_SYMBOL(copy_page); | ||
| 65 | |||
| 66 | #if defined(CONFIG_MD_RAID456) || defined(CONFIG_MD_RAID456_MODULE) | 64 | #if defined(CONFIG_MD_RAID456) || defined(CONFIG_MD_RAID456_MODULE) |
| 67 | extern void xor_ia64_2(void); | 65 | extern void xor_ia64_2(void); |
| 68 | extern void xor_ia64_3(void); | 66 | extern void xor_ia64_3(void); |
diff --git a/arch/ia64/kernel/iosapic.c b/arch/ia64/kernel/iosapic.c index c48b03f2b61d..dab4d393908c 100644 --- a/arch/ia64/kernel/iosapic.c +++ b/arch/ia64/kernel/iosapic.c | |||
| @@ -1072,6 +1072,10 @@ iosapic_init (unsigned long phys_addr, unsigned int gsi_base) | |||
| 1072 | } | 1072 | } |
| 1073 | 1073 | ||
| 1074 | addr = ioremap(phys_addr, 0); | 1074 | addr = ioremap(phys_addr, 0); |
| 1075 | if (addr == NULL) { | ||
| 1076 | spin_unlock_irqrestore(&iosapic_lock, flags); | ||
| 1077 | return -ENOMEM; | ||
| 1078 | } | ||
| 1075 | ver = iosapic_version(addr); | 1079 | ver = iosapic_version(addr); |
| 1076 | if ((err = iosapic_check_gsi_range(gsi_base, ver))) { | 1080 | if ((err = iosapic_check_gsi_range(gsi_base, ver))) { |
| 1077 | iounmap(addr); | 1081 | iounmap(addr); |
diff --git a/arch/ia64/kernel/pci-dma.c b/arch/ia64/kernel/pci-dma.c index 05695962fe44..f6b1ff0aea76 100644 --- a/arch/ia64/kernel/pci-dma.c +++ b/arch/ia64/kernel/pci-dma.c | |||
| @@ -69,11 +69,6 @@ iommu_dma_init(void) | |||
| 69 | 69 | ||
| 70 | int iommu_dma_supported(struct device *dev, u64 mask) | 70 | int iommu_dma_supported(struct device *dev, u64 mask) |
| 71 | { | 71 | { |
| 72 | struct dma_map_ops *ops = platform_dma_get_ops(dev); | ||
| 73 | |||
| 74 | if (ops->dma_supported) | ||
| 75 | return ops->dma_supported(dev, mask); | ||
| 76 | |||
| 77 | /* Copied from i386. Doesn't make much sense, because it will | 72 | /* Copied from i386. Doesn't make much sense, because it will |
| 78 | only work for pci_alloc_coherent. | 73 | only work for pci_alloc_coherent. |
| 79 | The caller just has to use GFP_DMA in this case. */ | 74 | The caller just has to use GFP_DMA in this case. */ |
diff --git a/arch/ia64/kernel/topology.c b/arch/ia64/kernel/topology.c index bc80dff1df7a..8f060352e129 100644 --- a/arch/ia64/kernel/topology.c +++ b/arch/ia64/kernel/topology.c | |||
| @@ -372,6 +372,10 @@ static int __cpuinit cache_add_dev(struct sys_device * sys_dev) | |||
| 372 | retval = kobject_init_and_add(&all_cpu_cache_info[cpu].kobj, | 372 | retval = kobject_init_and_add(&all_cpu_cache_info[cpu].kobj, |
| 373 | &cache_ktype_percpu_entry, &sys_dev->kobj, | 373 | &cache_ktype_percpu_entry, &sys_dev->kobj, |
| 374 | "%s", "cache"); | 374 | "%s", "cache"); |
| 375 | if (unlikely(retval < 0)) { | ||
| 376 | cpu_cache_sysfs_exit(cpu); | ||
| 377 | return retval; | ||
| 378 | } | ||
| 375 | 379 | ||
| 376 | for (i = 0; i < all_cpu_cache_info[cpu].num_cache_leaves; i++) { | 380 | for (i = 0; i < all_cpu_cache_info[cpu].num_cache_leaves; i++) { |
| 377 | this_object = LEAF_KOBJECT_PTR(cpu,i); | 381 | this_object = LEAF_KOBJECT_PTR(cpu,i); |
| @@ -385,7 +389,7 @@ static int __cpuinit cache_add_dev(struct sys_device * sys_dev) | |||
| 385 | } | 389 | } |
| 386 | kobject_put(&all_cpu_cache_info[cpu].kobj); | 390 | kobject_put(&all_cpu_cache_info[cpu].kobj); |
| 387 | cpu_cache_sysfs_exit(cpu); | 391 | cpu_cache_sysfs_exit(cpu); |
| 388 | break; | 392 | return retval; |
| 389 | } | 393 | } |
| 390 | kobject_uevent(&(this_object->kobj), KOBJ_ADD); | 394 | kobject_uevent(&(this_object->kobj), KOBJ_ADD); |
| 391 | } | 395 | } |
diff --git a/arch/ia64/kvm/mmio.c b/arch/ia64/kvm/mmio.c index 21f63fffc379..9bf55afd08d0 100644 --- a/arch/ia64/kvm/mmio.c +++ b/arch/ia64/kvm/mmio.c | |||
| @@ -247,7 +247,8 @@ void emulate_io_inst(struct kvm_vcpu *vcpu, u64 padr, u64 ma) | |||
| 247 | vcpu_get_fpreg(vcpu, inst.M9.f2, &v); | 247 | vcpu_get_fpreg(vcpu, inst.M9.f2, &v); |
| 248 | /* Write high word. FIXME: this is a kludge! */ | 248 | /* Write high word. FIXME: this is a kludge! */ |
| 249 | v.u.bits[1] &= 0x3ffff; | 249 | v.u.bits[1] &= 0x3ffff; |
| 250 | mmio_access(vcpu, padr + 8, &v.u.bits[1], 8, ma, IOREQ_WRITE); | 250 | mmio_access(vcpu, padr + 8, (u64 *)&v.u.bits[1], 8, |
| 251 | ma, IOREQ_WRITE); | ||
| 251 | data = v.u.bits[0]; | 252 | data = v.u.bits[0]; |
| 252 | size = 3; | 253 | size = 3; |
| 253 | } else if (inst.M10.major == 7 && inst.M10.x6 == 0x3B) { | 254 | } else if (inst.M10.major == 7 && inst.M10.x6 == 0x3B) { |
| @@ -265,7 +266,8 @@ void emulate_io_inst(struct kvm_vcpu *vcpu, u64 padr, u64 ma) | |||
| 265 | 266 | ||
| 266 | /* Write high word.FIXME: this is a kludge! */ | 267 | /* Write high word.FIXME: this is a kludge! */ |
| 267 | v.u.bits[1] &= 0x3ffff; | 268 | v.u.bits[1] &= 0x3ffff; |
| 268 | mmio_access(vcpu, padr + 8, &v.u.bits[1], 8, ma, IOREQ_WRITE); | 269 | mmio_access(vcpu, padr + 8, (u64 *)&v.u.bits[1], |
| 270 | 8, ma, IOREQ_WRITE); | ||
| 269 | data = v.u.bits[0]; | 271 | data = v.u.bits[0]; |
| 270 | size = 3; | 272 | size = 3; |
| 271 | } else if (inst.M10.major == 7 && inst.M10.x6 == 0x31) { | 273 | } else if (inst.M10.major == 7 && inst.M10.x6 == 0x31) { |
diff --git a/arch/ia64/kvm/vcpu.c b/arch/ia64/kvm/vcpu.c index 46b02cbcc874..cc406d064a09 100644 --- a/arch/ia64/kvm/vcpu.c +++ b/arch/ia64/kvm/vcpu.c | |||
| @@ -461,7 +461,7 @@ void setreg(unsigned long regnum, unsigned long val, | |||
| 461 | u64 vcpu_get_gr(struct kvm_vcpu *vcpu, unsigned long reg) | 461 | u64 vcpu_get_gr(struct kvm_vcpu *vcpu, unsigned long reg) |
| 462 | { | 462 | { |
| 463 | struct kvm_pt_regs *regs = vcpu_regs(vcpu); | 463 | struct kvm_pt_regs *regs = vcpu_regs(vcpu); |
| 464 | u64 val; | 464 | unsigned long val; |
| 465 | 465 | ||
| 466 | if (!reg) | 466 | if (!reg) |
| 467 | return 0; | 467 | return 0; |
| @@ -469,7 +469,7 @@ u64 vcpu_get_gr(struct kvm_vcpu *vcpu, unsigned long reg) | |||
| 469 | return val; | 469 | return val; |
| 470 | } | 470 | } |
| 471 | 471 | ||
| 472 | void vcpu_set_gr(struct kvm_vcpu *vcpu, u64 reg, u64 value, int nat) | 472 | void vcpu_set_gr(struct kvm_vcpu *vcpu, unsigned long reg, u64 value, int nat) |
| 473 | { | 473 | { |
| 474 | struct kvm_pt_regs *regs = vcpu_regs(vcpu); | 474 | struct kvm_pt_regs *regs = vcpu_regs(vcpu); |
| 475 | long sof = (regs->cr_ifs) & 0x7f; | 475 | long sof = (regs->cr_ifs) & 0x7f; |
| @@ -1072,7 +1072,7 @@ void kvm_ttag(struct kvm_vcpu *vcpu, INST64 inst) | |||
| 1072 | vcpu_set_gr(vcpu, inst.M46.r1, tag, 0); | 1072 | vcpu_set_gr(vcpu, inst.M46.r1, tag, 0); |
| 1073 | } | 1073 | } |
| 1074 | 1074 | ||
| 1075 | int vcpu_tpa(struct kvm_vcpu *vcpu, u64 vadr, u64 *padr) | 1075 | int vcpu_tpa(struct kvm_vcpu *vcpu, u64 vadr, unsigned long *padr) |
| 1076 | { | 1076 | { |
| 1077 | struct thash_data *data; | 1077 | struct thash_data *data; |
| 1078 | union ia64_isr visr, pt_isr; | 1078 | union ia64_isr visr, pt_isr; |
diff --git a/arch/ia64/kvm/vcpu.h b/arch/ia64/kvm/vcpu.h index 042af92ced83..360724d3ae69 100644 --- a/arch/ia64/kvm/vcpu.h +++ b/arch/ia64/kvm/vcpu.h | |||
| @@ -686,14 +686,15 @@ static inline int highest_inservice_irq(struct kvm_vcpu *vcpu) | |||
| 686 | return highest_bits((int *)&(VMX(vcpu, insvc[0]))); | 686 | return highest_bits((int *)&(VMX(vcpu, insvc[0]))); |
| 687 | } | 687 | } |
| 688 | 688 | ||
| 689 | extern void vcpu_get_fpreg(struct kvm_vcpu *vcpu, u64 reg, | 689 | extern void vcpu_get_fpreg(struct kvm_vcpu *vcpu, unsigned long reg, |
| 690 | struct ia64_fpreg *val); | 690 | struct ia64_fpreg *val); |
| 691 | extern void vcpu_set_fpreg(struct kvm_vcpu *vcpu, u64 reg, | 691 | extern void vcpu_set_fpreg(struct kvm_vcpu *vcpu, unsigned long reg, |
| 692 | struct ia64_fpreg *val); | 692 | struct ia64_fpreg *val); |
| 693 | extern u64 vcpu_get_gr(struct kvm_vcpu *vcpu, u64 reg); | 693 | extern u64 vcpu_get_gr(struct kvm_vcpu *vcpu, unsigned long reg); |
| 694 | extern void vcpu_set_gr(struct kvm_vcpu *vcpu, u64 reg, u64 val, int nat); | 694 | extern void vcpu_set_gr(struct kvm_vcpu *vcpu, unsigned long reg, |
| 695 | extern u64 vcpu_get_psr(struct kvm_vcpu *vcpu); | 695 | u64 val, int nat); |
| 696 | extern void vcpu_set_psr(struct kvm_vcpu *vcpu, u64 val); | 696 | extern unsigned long vcpu_get_psr(struct kvm_vcpu *vcpu); |
| 697 | extern void vcpu_set_psr(struct kvm_vcpu *vcpu, unsigned long val); | ||
| 697 | extern u64 vcpu_thash(struct kvm_vcpu *vcpu, u64 vadr); | 698 | extern u64 vcpu_thash(struct kvm_vcpu *vcpu, u64 vadr); |
| 698 | extern void vcpu_bsw0(struct kvm_vcpu *vcpu); | 699 | extern void vcpu_bsw0(struct kvm_vcpu *vcpu); |
| 699 | extern void thash_vhpt_insert(struct kvm_vcpu *v, u64 pte, | 700 | extern void thash_vhpt_insert(struct kvm_vcpu *v, u64 pte, |
diff --git a/arch/m32r/include/asm/pgalloc.h b/arch/m32r/include/asm/pgalloc.h index f11a2b909cdb..0fc736198979 100644 --- a/arch/m32r/include/asm/pgalloc.h +++ b/arch/m32r/include/asm/pgalloc.h | |||
| @@ -58,7 +58,7 @@ static inline void pte_free(struct mm_struct *mm, pgtable_t pte) | |||
| 58 | __free_page(pte); | 58 | __free_page(pte); |
| 59 | } | 59 | } |
| 60 | 60 | ||
| 61 | #define __pte_free_tlb(tlb, pte) pte_free((tlb)->mm, (pte)) | 61 | #define __pte_free_tlb(tlb, pte, addr) pte_free((tlb)->mm, (pte)) |
| 62 | 62 | ||
| 63 | /* | 63 | /* |
| 64 | * allocating and freeing a pmd is trivial: the 1-entry pmd is | 64 | * allocating and freeing a pmd is trivial: the 1-entry pmd is |
| @@ -68,7 +68,7 @@ static inline void pte_free(struct mm_struct *mm, pgtable_t pte) | |||
| 68 | 68 | ||
| 69 | #define pmd_alloc_one(mm, addr) ({ BUG(); ((pmd_t *)2); }) | 69 | #define pmd_alloc_one(mm, addr) ({ BUG(); ((pmd_t *)2); }) |
| 70 | #define pmd_free(mm, x) do { } while (0) | 70 | #define pmd_free(mm, x) do { } while (0) |
| 71 | #define __pmd_free_tlb(tlb, x) do { } while (0) | 71 | #define __pmd_free_tlb(tlb, x, addr) do { } while (0) |
| 72 | #define pgd_populate(mm, pmd, pte) BUG() | 72 | #define pgd_populate(mm, pmd, pte) BUG() |
| 73 | 73 | ||
| 74 | #define check_pgt_cache() do { } while (0) | 74 | #define check_pgt_cache() do { } while (0) |
diff --git a/arch/m68k/amiga/config.c b/arch/m68k/amiga/config.c index 6e562751ad51..6c74751c7b82 100644 --- a/arch/m68k/amiga/config.c +++ b/arch/m68k/amiga/config.c | |||
| @@ -574,10 +574,11 @@ static int a2000_hwclk(int op, struct rtc_time *t) | |||
| 574 | 574 | ||
| 575 | tod_2000.cntrl1 = TOD2000_CNTRL1_HOLD; | 575 | tod_2000.cntrl1 = TOD2000_CNTRL1_HOLD; |
| 576 | 576 | ||
| 577 | while ((tod_2000.cntrl1 & TOD2000_CNTRL1_BUSY) && cnt--) { | 577 | while ((tod_2000.cntrl1 & TOD2000_CNTRL1_BUSY) && cnt) { |
| 578 | tod_2000.cntrl1 &= ~TOD2000_CNTRL1_HOLD; | 578 | tod_2000.cntrl1 &= ~TOD2000_CNTRL1_HOLD; |
| 579 | udelay(70); | 579 | udelay(70); |
| 580 | tod_2000.cntrl1 |= TOD2000_CNTRL1_HOLD; | 580 | tod_2000.cntrl1 |= TOD2000_CNTRL1_HOLD; |
| 581 | --cnt; | ||
| 581 | } | 582 | } |
| 582 | 583 | ||
| 583 | if (!cnt) | 584 | if (!cnt) |
| @@ -649,10 +650,11 @@ static int amiga_set_clock_mmss(unsigned long nowtime) | |||
| 649 | 650 | ||
| 650 | tod_2000.cntrl1 |= TOD2000_CNTRL1_HOLD; | 651 | tod_2000.cntrl1 |= TOD2000_CNTRL1_HOLD; |
| 651 | 652 | ||
| 652 | while ((tod_2000.cntrl1 & TOD2000_CNTRL1_BUSY) && cnt--) { | 653 | while ((tod_2000.cntrl1 & TOD2000_CNTRL1_BUSY) && cnt) { |
| 653 | tod_2000.cntrl1 &= ~TOD2000_CNTRL1_HOLD; | 654 | tod_2000.cntrl1 &= ~TOD2000_CNTRL1_HOLD; |
| 654 | udelay(70); | 655 | udelay(70); |
| 655 | tod_2000.cntrl1 |= TOD2000_CNTRL1_HOLD; | 656 | tod_2000.cntrl1 |= TOD2000_CNTRL1_HOLD; |
| 657 | --cnt; | ||
| 656 | } | 658 | } |
| 657 | 659 | ||
| 658 | if (!cnt) | 660 | if (!cnt) |
diff --git a/arch/m68k/include/asm/motorola_pgalloc.h b/arch/m68k/include/asm/motorola_pgalloc.h index d08bf6261df8..2f02f264e694 100644 --- a/arch/m68k/include/asm/motorola_pgalloc.h +++ b/arch/m68k/include/asm/motorola_pgalloc.h | |||
| @@ -36,12 +36,10 @@ static inline pgtable_t pte_alloc_one(struct mm_struct *mm, unsigned long addres | |||
| 36 | return NULL; | 36 | return NULL; |
| 37 | 37 | ||
| 38 | pte = kmap(page); | 38 | pte = kmap(page); |
| 39 | if (pte) { | 39 | __flush_page_to_ram(pte); |
| 40 | __flush_page_to_ram(pte); | 40 | flush_tlb_kernel_page(pte); |
| 41 | flush_tlb_kernel_page(pte); | 41 | nocache_page(pte); |
| 42 | nocache_page(pte); | 42 | kunmap(page); |
| 43 | } | ||
| 44 | kunmap(pte); | ||
| 45 | pgtable_page_ctor(page); | 43 | pgtable_page_ctor(page); |
| 46 | return page; | 44 | return page; |
| 47 | } | 45 | } |
| @@ -54,7 +52,8 @@ static inline void pte_free(struct mm_struct *mm, pgtable_t page) | |||
| 54 | __free_page(page); | 52 | __free_page(page); |
| 55 | } | 53 | } |
| 56 | 54 | ||
| 57 | static inline void __pte_free_tlb(struct mmu_gather *tlb, pgtable_t page) | 55 | static inline void __pte_free_tlb(struct mmu_gather *tlb, pgtable_t page, |
| 56 | unsigned long address) | ||
| 58 | { | 57 | { |
| 59 | pgtable_page_dtor(page); | 58 | pgtable_page_dtor(page); |
| 60 | cache_page(kmap(page)); | 59 | cache_page(kmap(page)); |
| @@ -73,7 +72,8 @@ static inline int pmd_free(struct mm_struct *mm, pmd_t *pmd) | |||
| 73 | return free_pointer_table(pmd); | 72 | return free_pointer_table(pmd); |
| 74 | } | 73 | } |
| 75 | 74 | ||
| 76 | static inline int __pmd_free_tlb(struct mmu_gather *tlb, pmd_t *pmd) | 75 | static inline int __pmd_free_tlb(struct mmu_gather *tlb, pmd_t *pmd, |
| 76 | unsigned long address) | ||
| 77 | { | 77 | { |
| 78 | return free_pointer_table(pmd); | 78 | return free_pointer_table(pmd); |
| 79 | } | 79 | } |
diff --git a/arch/m68k/include/asm/pgtable_mm.h b/arch/m68k/include/asm/pgtable_mm.h index 0b604f0f192d..fe60e1abaee8 100644 --- a/arch/m68k/include/asm/pgtable_mm.h +++ b/arch/m68k/include/asm/pgtable_mm.h | |||
| @@ -135,8 +135,6 @@ static inline void update_mmu_cache(struct vm_area_struct *vma, | |||
| 135 | #endif | 135 | #endif |
| 136 | 136 | ||
| 137 | #ifndef __ASSEMBLY__ | 137 | #ifndef __ASSEMBLY__ |
| 138 | #include <asm-generic/pgtable.h> | ||
| 139 | |||
| 140 | /* | 138 | /* |
| 141 | * Macro to mark a page protection value as "uncacheable". | 139 | * Macro to mark a page protection value as "uncacheable". |
| 142 | */ | 140 | */ |
| @@ -154,6 +152,7 @@ static inline void update_mmu_cache(struct vm_area_struct *vma, | |||
| 154 | ? (__pgprot((pgprot_val(prot) & _CACHEMASK040) | _PAGE_NOCACHE_S)) \ | 152 | ? (__pgprot((pgprot_val(prot) & _CACHEMASK040) | _PAGE_NOCACHE_S)) \ |
| 155 | : (prot))) | 153 | : (prot))) |
| 156 | 154 | ||
| 155 | #include <asm-generic/pgtable.h> | ||
| 157 | #endif /* !__ASSEMBLY__ */ | 156 | #endif /* !__ASSEMBLY__ */ |
| 158 | 157 | ||
| 159 | /* | 158 | /* |
diff --git a/arch/m68k/include/asm/sun3_pgalloc.h b/arch/m68k/include/asm/sun3_pgalloc.h index d4c83f143816..48d80d5a666f 100644 --- a/arch/m68k/include/asm/sun3_pgalloc.h +++ b/arch/m68k/include/asm/sun3_pgalloc.h | |||
| @@ -32,7 +32,7 @@ static inline void pte_free(struct mm_struct *mm, pgtable_t page) | |||
| 32 | __free_page(page); | 32 | __free_page(page); |
| 33 | } | 33 | } |
| 34 | 34 | ||
| 35 | #define __pte_free_tlb(tlb,pte) \ | 35 | #define __pte_free_tlb(tlb,pte,addr) \ |
| 36 | do { \ | 36 | do { \ |
| 37 | pgtable_page_dtor(pte); \ | 37 | pgtable_page_dtor(pte); \ |
| 38 | tlb_remove_page((tlb), pte); \ | 38 | tlb_remove_page((tlb), pte); \ |
| @@ -80,7 +80,7 @@ static inline void pmd_populate(struct mm_struct *mm, pmd_t *pmd, pgtable_t page | |||
| 80 | * inside the pgd, so has no extra memory associated with it. | 80 | * inside the pgd, so has no extra memory associated with it. |
| 81 | */ | 81 | */ |
| 82 | #define pmd_free(mm, x) do { } while (0) | 82 | #define pmd_free(mm, x) do { } while (0) |
| 83 | #define __pmd_free_tlb(tlb, x) do { } while (0) | 83 | #define __pmd_free_tlb(tlb, x, addr) do { } while (0) |
| 84 | 84 | ||
| 85 | static inline void pgd_free(struct mm_struct *mm, pgd_t *pgd) | 85 | static inline void pgd_free(struct mm_struct *mm, pgd_t *pgd) |
| 86 | { | 86 | { |
diff --git a/arch/m68k/include/asm/unistd.h b/arch/m68k/include/asm/unistd.h index aa29a8640f74..946d8691f2b0 100644 --- a/arch/m68k/include/asm/unistd.h +++ b/arch/m68k/include/asm/unistd.h | |||
| @@ -334,10 +334,12 @@ | |||
| 334 | #define __NR_inotify_init1 328 | 334 | #define __NR_inotify_init1 328 |
| 335 | #define __NR_preadv 329 | 335 | #define __NR_preadv 329 |
| 336 | #define __NR_pwritev 330 | 336 | #define __NR_pwritev 330 |
| 337 | #define __NR_rt_tgsigqueueinfo 331 | ||
| 338 | #define __NR_perf_counter_open 332 | ||
| 337 | 339 | ||
| 338 | #ifdef __KERNEL__ | 340 | #ifdef __KERNEL__ |
| 339 | 341 | ||
| 340 | #define NR_syscalls 331 | 342 | #define NR_syscalls 333 |
| 341 | 343 | ||
| 342 | #define __ARCH_WANT_IPC_PARSE_VERSION | 344 | #define __ARCH_WANT_IPC_PARSE_VERSION |
| 343 | #define __ARCH_WANT_OLD_READDIR | 345 | #define __ARCH_WANT_OLD_READDIR |
diff --git a/arch/m68k/kernel/entry.S b/arch/m68k/kernel/entry.S index 8744f60c07a9..c3735cd6207e 100644 --- a/arch/m68k/kernel/entry.S +++ b/arch/m68k/kernel/entry.S | |||
| @@ -755,4 +755,6 @@ sys_call_table: | |||
| 755 | .long sys_inotify_init1 | 755 | .long sys_inotify_init1 |
| 756 | .long sys_preadv | 756 | .long sys_preadv |
| 757 | .long sys_pwritev /* 330 */ | 757 | .long sys_pwritev /* 330 */ |
| 758 | .long sys_rt_tgsigqueueinfo | ||
| 759 | .long sys_perf_counter_open | ||
| 758 | 760 | ||
diff --git a/arch/m68knommu/kernel/syscalltable.S b/arch/m68knommu/kernel/syscalltable.S index c0b8782832fd..0ae123e08985 100644 --- a/arch/m68knommu/kernel/syscalltable.S +++ b/arch/m68knommu/kernel/syscalltable.S | |||
| @@ -349,6 +349,8 @@ ENTRY(sys_call_table) | |||
| 349 | .long sys_inotify_init1 | 349 | .long sys_inotify_init1 |
| 350 | .long sys_preadv | 350 | .long sys_preadv |
| 351 | .long sys_pwritev /* 330 */ | 351 | .long sys_pwritev /* 330 */ |
| 352 | .long sys_rt_tgsigqueueinfo | ||
| 353 | .long sys_perf_counter_open | ||
| 352 | 354 | ||
| 353 | .rept NR_syscalls-(.-sys_call_table)/4 | 355 | .rept NR_syscalls-(.-sys_call_table)/4 |
| 354 | .long sys_ni_syscall | 356 | .long sys_ni_syscall |
diff --git a/arch/microblaze/Makefile b/arch/microblaze/Makefile index d0bcf80a1136..8439598d4655 100644 --- a/arch/microblaze/Makefile +++ b/arch/microblaze/Makefile | |||
| @@ -6,14 +6,16 @@ endif | |||
| 6 | 6 | ||
| 7 | # What CPU vesion are we building for, and crack it open | 7 | # What CPU vesion are we building for, and crack it open |
| 8 | # as major.minor.rev | 8 | # as major.minor.rev |
| 9 | CPU_VER=$(subst ",,$(CONFIG_XILINX_MICROBLAZE0_HW_VER) ) | 9 | CPU_VER := $(shell echo $(CONFIG_XILINX_MICROBLAZE0_HW_VER)) |
| 10 | CPU_MAJOR=$(shell echo $(CPU_VER) | cut -d '.' -f 1) | 10 | CPU_MAJOR := $(shell echo $(CPU_VER) | cut -d '.' -f 1) |
| 11 | CPU_MINOR=$(shell echo $(CPU_VER) | cut -d '.' -f 2) | 11 | CPU_MINOR := $(shell echo $(CPU_VER) | cut -d '.' -f 2) |
| 12 | CPU_REV=$(shell echo $(CPU_VER) | cut -d '.' -f 3) | 12 | CPU_REV := $(shell echo $(CPU_VER) | cut -d '.' -f 3) |
| 13 | 13 | ||
| 14 | export CPU_VER CPU_MAJOR CPU_MINOR CPU_REV | 14 | export CPU_VER CPU_MAJOR CPU_MINOR CPU_REV |
| 15 | 15 | ||
| 16 | # Use cpu-related CONFIG_ vars to set compile options. | 16 | # Use cpu-related CONFIG_ vars to set compile options. |
| 17 | # The various CONFIG_XILINX cpu features options are integers 0/1/2... | ||
| 18 | # rather than bools y/n | ||
| 17 | 19 | ||
| 18 | # Work out HW multipler support. This is icky. | 20 | # Work out HW multipler support. This is icky. |
| 19 | # 1. Spartan2 has no HW multiplers. | 21 | # 1. Spartan2 has no HW multiplers. |
| @@ -34,30 +36,29 @@ CPUFLAGS-$(CONFIG_XILINX_MICROBLAZE0_USE_PCMP_INSTR) += -mxl-pattern-compare | |||
| 34 | 36 | ||
| 35 | CPUFLAGS-1 += $(call cc-option,-mcpu=v$(CPU_VER)) | 37 | CPUFLAGS-1 += $(call cc-option,-mcpu=v$(CPU_VER)) |
| 36 | 38 | ||
| 37 | # The various CONFIG_XILINX cpu features options are integers 0/1/2... | ||
| 38 | # rather than bools y/n | ||
| 39 | |||
| 40 | # r31 holds current when in kernel mode | 39 | # r31 holds current when in kernel mode |
| 41 | CFLAGS_KERNEL += -ffixed-r31 $(CPUFLAGS-1) $(CPUFLAGS-2) | 40 | KBUILD_KERNEL += -ffixed-r31 $(CPUFLAGS-1) $(CPUFLAGS-2) |
| 42 | 41 | ||
| 43 | LDFLAGS := | 42 | LDFLAGS := |
| 44 | LDFLAGS_vmlinux := | 43 | LDFLAGS_vmlinux := |
| 45 | LDFLAGS_BLOB := --format binary --oformat elf32-microblaze | ||
| 46 | 44 | ||
| 47 | LIBGCC := $(shell $(CC) $(CFLAGS_KERNEL) -print-libgcc-file-name) | 45 | LIBGCC := $(shell $(CC) $(KBUILD_KERNEL) -print-libgcc-file-name) |
| 48 | 46 | ||
| 49 | head-y := arch/microblaze/kernel/head.o | 47 | head-y := arch/microblaze/kernel/head.o |
| 50 | libs-y += arch/microblaze/lib/ $(LIBGCC) | 48 | libs-y += arch/microblaze/lib/ |
| 51 | core-y += arch/microblaze/kernel/ arch/microblaze/mm/ \ | 49 | libs-y += $(LIBGCC) |
| 52 | arch/microblaze/platform/ | 50 | core-y += arch/microblaze/kernel/ |
| 51 | core-y += arch/microblaze/mm/ | ||
| 52 | core-y += arch/microblaze/platform/ | ||
| 53 | 53 | ||
| 54 | boot := arch/$(ARCH)/boot | 54 | boot := arch/microblaze/boot |
| 55 | 55 | ||
| 56 | # defines filename extension depending memory management type | 56 | # defines filename extension depending memory management type |
| 57 | ifeq ($(CONFIG_MMU),) | 57 | ifeq ($(CONFIG_MMU),) |
| 58 | MMUEXT := -nommu | 58 | MMU := -nommu |
| 59 | endif | 59 | endif |
| 60 | export MMUEXT | 60 | |
| 61 | export MMU | ||
| 61 | 62 | ||
| 62 | all: linux.bin | 63 | all: linux.bin |
| 63 | 64 | ||
diff --git a/arch/microblaze/configs/mmu_defconfig b/arch/microblaze/configs/mmu_defconfig index bd0b85ec38f5..09c32962b66f 100644 --- a/arch/microblaze/configs/mmu_defconfig +++ b/arch/microblaze/configs/mmu_defconfig | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc6 | 3 | # Linux kernel version: 2.6.31-rc6 |
| 4 | # Fri May 22 10:02:33 2009 | 4 | # Tue Aug 18 11:00:02 2009 |
| 5 | # | 5 | # |
| 6 | CONFIG_MICROBLAZE=y | 6 | CONFIG_MICROBLAZE=y |
| 7 | # CONFIG_SWAP is not set | 7 | # CONFIG_SWAP is not set |
| @@ -18,7 +18,11 @@ CONFIG_GENERIC_TIME=y | |||
| 18 | CONFIG_GENERIC_CLOCKEVENTS=y | 18 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 19 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | 19 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y |
| 20 | CONFIG_GENERIC_GPIO=y | 20 | CONFIG_GENERIC_GPIO=y |
| 21 | CONFIG_GENERIC_CSUM=y | ||
| 22 | # CONFIG_PCI is not set | ||
| 23 | CONFIG_NO_DMA=y | ||
| 21 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 24 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 25 | CONFIG_CONSTRUCTORS=y | ||
| 22 | 26 | ||
| 23 | # | 27 | # |
| 24 | # General setup | 28 | # General setup |
| @@ -59,8 +63,8 @@ CONFIG_INITRAMFS_ROOT_GID=0 | |||
| 59 | CONFIG_RD_GZIP=y | 63 | CONFIG_RD_GZIP=y |
| 60 | # CONFIG_RD_BZIP2 is not set | 64 | # CONFIG_RD_BZIP2 is not set |
| 61 | # CONFIG_RD_LZMA is not set | 65 | # CONFIG_RD_LZMA is not set |
| 62 | CONFIG_INITRAMFS_COMPRESSION_NONE=y | 66 | # CONFIG_INITRAMFS_COMPRESSION_NONE is not set |
| 63 | # CONFIG_INITRAMFS_COMPRESSION_GZIP is not set | 67 | CONFIG_INITRAMFS_COMPRESSION_GZIP=y |
| 64 | # CONFIG_INITRAMFS_COMPRESSION_BZIP2 is not set | 68 | # CONFIG_INITRAMFS_COMPRESSION_BZIP2 is not set |
| 65 | # CONFIG_INITRAMFS_COMPRESSION_LZMA is not set | 69 | # CONFIG_INITRAMFS_COMPRESSION_LZMA is not set |
| 66 | # CONFIG_CC_OPTIMIZE_FOR_SIZE is not set | 70 | # CONFIG_CC_OPTIMIZE_FOR_SIZE is not set |
| @@ -71,7 +75,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 71 | CONFIG_KALLSYMS=y | 75 | CONFIG_KALLSYMS=y |
| 72 | CONFIG_KALLSYMS_ALL=y | 76 | CONFIG_KALLSYMS_ALL=y |
| 73 | CONFIG_KALLSYMS_EXTRA_PASS=y | 77 | CONFIG_KALLSYMS_EXTRA_PASS=y |
| 74 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 75 | # CONFIG_HOTPLUG is not set | 78 | # CONFIG_HOTPLUG is not set |
| 76 | CONFIG_PRINTK=y | 79 | CONFIG_PRINTK=y |
| 77 | CONFIG_BUG=y | 80 | CONFIG_BUG=y |
| @@ -84,13 +87,22 @@ CONFIG_TIMERFD=y | |||
| 84 | CONFIG_EVENTFD=y | 87 | CONFIG_EVENTFD=y |
| 85 | # CONFIG_SHMEM is not set | 88 | # CONFIG_SHMEM is not set |
| 86 | CONFIG_AIO=y | 89 | CONFIG_AIO=y |
| 90 | |||
| 91 | # | ||
| 92 | # Performance Counters | ||
| 93 | # | ||
| 87 | CONFIG_VM_EVENT_COUNTERS=y | 94 | CONFIG_VM_EVENT_COUNTERS=y |
| 95 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 88 | CONFIG_COMPAT_BRK=y | 96 | CONFIG_COMPAT_BRK=y |
| 89 | CONFIG_SLAB=y | 97 | CONFIG_SLAB=y |
| 90 | # CONFIG_SLUB is not set | 98 | # CONFIG_SLUB is not set |
| 91 | # CONFIG_SLOB is not set | 99 | # CONFIG_SLOB is not set |
| 92 | # CONFIG_PROFILING is not set | 100 | # CONFIG_PROFILING is not set |
| 93 | # CONFIG_MARKERS is not set | 101 | # CONFIG_MARKERS is not set |
| 102 | |||
| 103 | # | ||
| 104 | # GCOV-based kernel profiling | ||
| 105 | # | ||
| 94 | # CONFIG_SLOW_WORK is not set | 106 | # CONFIG_SLOW_WORK is not set |
| 95 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 107 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 96 | CONFIG_SLABINFO=y | 108 | CONFIG_SLABINFO=y |
| @@ -102,7 +114,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 102 | # CONFIG_MODVERSIONS is not set | 114 | # CONFIG_MODVERSIONS is not set |
| 103 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 115 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 104 | CONFIG_BLOCK=y | 116 | CONFIG_BLOCK=y |
| 105 | # CONFIG_LBD is not set | 117 | CONFIG_LBDAF=y |
| 106 | # CONFIG_BLK_DEV_BSG is not set | 118 | # CONFIG_BLK_DEV_BSG is not set |
| 107 | # CONFIG_BLK_DEV_INTEGRITY is not set | 119 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 108 | 120 | ||
| @@ -194,9 +206,9 @@ CONFIG_SPLIT_PTLOCK_CPUS=4 | |||
| 194 | # CONFIG_PHYS_ADDR_T_64BIT is not set | 206 | # CONFIG_PHYS_ADDR_T_64BIT is not set |
| 195 | CONFIG_ZONE_DMA_FLAG=0 | 207 | CONFIG_ZONE_DMA_FLAG=0 |
| 196 | CONFIG_VIRT_TO_BUS=y | 208 | CONFIG_VIRT_TO_BUS=y |
| 197 | CONFIG_UNEVICTABLE_LRU=y | ||
| 198 | CONFIG_HAVE_MLOCK=y | 209 | CONFIG_HAVE_MLOCK=y |
| 199 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 210 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 211 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 200 | 212 | ||
| 201 | # | 213 | # |
| 202 | # Exectuable file formats | 214 | # Exectuable file formats |
| @@ -262,6 +274,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 262 | # CONFIG_ECONET is not set | 274 | # CONFIG_ECONET is not set |
| 263 | # CONFIG_WAN_ROUTER is not set | 275 | # CONFIG_WAN_ROUTER is not set |
| 264 | # CONFIG_PHONET is not set | 276 | # CONFIG_PHONET is not set |
| 277 | # CONFIG_IEEE802154 is not set | ||
| 265 | # CONFIG_NET_SCHED is not set | 278 | # CONFIG_NET_SCHED is not set |
| 266 | # CONFIG_DCB is not set | 279 | # CONFIG_DCB is not set |
| 267 | 280 | ||
| @@ -325,7 +338,6 @@ CONFIG_MISC_DEVICES=y | |||
| 325 | # CONFIG_ATA is not set | 338 | # CONFIG_ATA is not set |
| 326 | # CONFIG_MD is not set | 339 | # CONFIG_MD is not set |
| 327 | CONFIG_NETDEVICES=y | 340 | CONFIG_NETDEVICES=y |
| 328 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 329 | # CONFIG_DUMMY is not set | 341 | # CONFIG_DUMMY is not set |
| 330 | # CONFIG_BONDING is not set | 342 | # CONFIG_BONDING is not set |
| 331 | # CONFIG_MACVLAN is not set | 343 | # CONFIG_MACVLAN is not set |
| @@ -344,7 +356,7 @@ CONFIG_NET_ETHERNET=y | |||
| 344 | # CONFIG_IBM_NEW_EMAC_NO_FLOW_CTRL is not set | 356 | # CONFIG_IBM_NEW_EMAC_NO_FLOW_CTRL is not set |
| 345 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 357 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 346 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 358 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 347 | # CONFIG_B44 is not set | 359 | # CONFIG_KS8842 is not set |
| 348 | CONFIG_NETDEV_1000=y | 360 | CONFIG_NETDEV_1000=y |
| 349 | CONFIG_NETDEV_10000=y | 361 | CONFIG_NETDEV_10000=y |
| 350 | 362 | ||
| @@ -410,6 +422,11 @@ CONFIG_LEGACY_PTY_COUNT=256 | |||
| 410 | # CONFIG_TCG_TPM is not set | 422 | # CONFIG_TCG_TPM is not set |
| 411 | # CONFIG_I2C is not set | 423 | # CONFIG_I2C is not set |
| 412 | # CONFIG_SPI is not set | 424 | # CONFIG_SPI is not set |
| 425 | |||
| 426 | # | ||
| 427 | # PPS support | ||
| 428 | # | ||
| 429 | # CONFIG_PPS is not set | ||
| 413 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 430 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 414 | # CONFIG_GPIOLIB is not set | 431 | # CONFIG_GPIOLIB is not set |
| 415 | # CONFIG_W1 is not set | 432 | # CONFIG_W1 is not set |
| @@ -418,12 +435,6 @@ CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | |||
| 418 | # CONFIG_THERMAL is not set | 435 | # CONFIG_THERMAL is not set |
| 419 | # CONFIG_THERMAL_HWMON is not set | 436 | # CONFIG_THERMAL_HWMON is not set |
| 420 | # CONFIG_WATCHDOG is not set | 437 | # CONFIG_WATCHDOG is not set |
| 421 | CONFIG_SSB_POSSIBLE=y | ||
| 422 | |||
| 423 | # | ||
| 424 | # Sonics Silicon Backplane | ||
| 425 | # | ||
| 426 | # CONFIG_SSB is not set | ||
| 427 | 438 | ||
| 428 | # | 439 | # |
| 429 | # Multifunction device drivers | 440 | # Multifunction device drivers |
| @@ -433,22 +444,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 433 | # CONFIG_HTC_PASIC3 is not set | 444 | # CONFIG_HTC_PASIC3 is not set |
| 434 | # CONFIG_MFD_TMIO is not set | 445 | # CONFIG_MFD_TMIO is not set |
| 435 | # CONFIG_REGULATOR is not set | 446 | # CONFIG_REGULATOR is not set |
| 436 | 447 | # CONFIG_MEDIA_SUPPORT is not set | |
| 437 | # | ||
| 438 | # Multimedia devices | ||
| 439 | # | ||
| 440 | |||
| 441 | # | ||
| 442 | # Multimedia core support | ||
| 443 | # | ||
| 444 | # CONFIG_VIDEO_DEV is not set | ||
| 445 | # CONFIG_DVB_CORE is not set | ||
| 446 | # CONFIG_VIDEO_MEDIA is not set | ||
| 447 | |||
| 448 | # | ||
| 449 | # Multimedia drivers | ||
| 450 | # | ||
| 451 | # CONFIG_DAB is not set | ||
| 452 | 448 | ||
| 453 | # | 449 | # |
| 454 | # Graphics support | 450 | # Graphics support |
| @@ -469,9 +465,12 @@ CONFIG_SSB_POSSIBLE=y | |||
| 469 | # CONFIG_NEW_LEDS is not set | 465 | # CONFIG_NEW_LEDS is not set |
| 470 | # CONFIG_ACCESSIBILITY is not set | 466 | # CONFIG_ACCESSIBILITY is not set |
| 471 | # CONFIG_RTC_CLASS is not set | 467 | # CONFIG_RTC_CLASS is not set |
| 472 | # CONFIG_DMADEVICES is not set | ||
| 473 | # CONFIG_AUXDISPLAY is not set | 468 | # CONFIG_AUXDISPLAY is not set |
| 474 | # CONFIG_UIO is not set | 469 | # CONFIG_UIO is not set |
| 470 | |||
| 471 | # | ||
| 472 | # TI VLYNQ | ||
| 473 | # | ||
| 475 | # CONFIG_STAGING is not set | 474 | # CONFIG_STAGING is not set |
| 476 | 475 | ||
| 477 | # | 476 | # |
| @@ -485,12 +484,15 @@ CONFIG_EXT2_FS=y | |||
| 485 | # CONFIG_REISERFS_FS is not set | 484 | # CONFIG_REISERFS_FS is not set |
| 486 | # CONFIG_JFS_FS is not set | 485 | # CONFIG_JFS_FS is not set |
| 487 | # CONFIG_FS_POSIX_ACL is not set | 486 | # CONFIG_FS_POSIX_ACL is not set |
| 488 | CONFIG_FILE_LOCKING=y | ||
| 489 | # CONFIG_XFS_FS is not set | 487 | # CONFIG_XFS_FS is not set |
| 488 | # CONFIG_GFS2_FS is not set | ||
| 490 | # CONFIG_OCFS2_FS is not set | 489 | # CONFIG_OCFS2_FS is not set |
| 491 | # CONFIG_BTRFS_FS is not set | 490 | # CONFIG_BTRFS_FS is not set |
| 491 | CONFIG_FILE_LOCKING=y | ||
| 492 | CONFIG_FSNOTIFY=y | ||
| 492 | # CONFIG_DNOTIFY is not set | 493 | # CONFIG_DNOTIFY is not set |
| 493 | # CONFIG_INOTIFY is not set | 494 | # CONFIG_INOTIFY is not set |
| 495 | CONFIG_INOTIFY_USER=y | ||
| 494 | # CONFIG_QUOTA is not set | 496 | # CONFIG_QUOTA is not set |
| 495 | # CONFIG_AUTOFS_FS is not set | 497 | # CONFIG_AUTOFS_FS is not set |
| 496 | # CONFIG_AUTOFS4_FS is not set | 498 | # CONFIG_AUTOFS4_FS is not set |
| @@ -678,6 +680,7 @@ CONFIG_DEBUG_INFO=y | |||
| 678 | # CONFIG_SYSCTL_SYSCALL_CHECK is not set | 680 | # CONFIG_SYSCTL_SYSCALL_CHECK is not set |
| 679 | # CONFIG_PAGE_POISONING is not set | 681 | # CONFIG_PAGE_POISONING is not set |
| 680 | # CONFIG_SAMPLES is not set | 682 | # CONFIG_SAMPLES is not set |
| 683 | # CONFIG_KMEMCHECK is not set | ||
| 681 | CONFIG_EARLY_PRINTK=y | 684 | CONFIG_EARLY_PRINTK=y |
| 682 | CONFIG_HEART_BEAT=y | 685 | CONFIG_HEART_BEAT=y |
| 683 | CONFIG_DEBUG_BOOTMEM=y | 686 | CONFIG_DEBUG_BOOTMEM=y |
| @@ -793,6 +796,5 @@ CONFIG_ZLIB_INFLATE=y | |||
| 793 | CONFIG_DECOMPRESS_GZIP=y | 796 | CONFIG_DECOMPRESS_GZIP=y |
| 794 | CONFIG_HAS_IOMEM=y | 797 | CONFIG_HAS_IOMEM=y |
| 795 | CONFIG_HAS_IOPORT=y | 798 | CONFIG_HAS_IOPORT=y |
| 796 | CONFIG_HAS_DMA=y | ||
| 797 | CONFIG_HAVE_LMB=y | 799 | CONFIG_HAVE_LMB=y |
| 798 | CONFIG_NLATTR=y | 800 | CONFIG_NLATTR=y |
diff --git a/arch/microblaze/configs/nommu_defconfig b/arch/microblaze/configs/nommu_defconfig index 4ef6af0a8f31..8b638615a972 100644 --- a/arch/microblaze/configs/nommu_defconfig +++ b/arch/microblaze/configs/nommu_defconfig | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc5 | 3 | # Linux kernel version: 2.6.31-rc6 |
| 4 | # Mon May 11 09:01:02 2009 | 4 | # Tue Aug 18 10:35:30 2009 |
| 5 | # | 5 | # |
| 6 | CONFIG_MICROBLAZE=y | 6 | CONFIG_MICROBLAZE=y |
| 7 | # CONFIG_SWAP is not set | 7 | # CONFIG_SWAP is not set |
| @@ -17,9 +17,12 @@ CONFIG_GENERIC_TIME=y | |||
| 17 | # CONFIG_GENERIC_TIME_VSYSCALL is not set | 17 | # CONFIG_GENERIC_TIME_VSYSCALL is not set |
| 18 | CONFIG_GENERIC_CLOCKEVENTS=y | 18 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 19 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | 19 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y |
| 20 | CONFIG_GENERIC_GPIO=y | ||
| 21 | CONFIG_GENERIC_CSUM=y | ||
| 20 | # CONFIG_PCI is not set | 22 | # CONFIG_PCI is not set |
| 21 | # CONFIG_NO_DMA is not set | 23 | CONFIG_NO_DMA=y |
| 22 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 24 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 25 | CONFIG_CONSTRUCTORS=y | ||
| 23 | 26 | ||
| 24 | # | 27 | # |
| 25 | # General setup | 28 | # General setup |
| @@ -64,7 +67,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 64 | CONFIG_KALLSYMS=y | 67 | CONFIG_KALLSYMS=y |
| 65 | CONFIG_KALLSYMS_ALL=y | 68 | CONFIG_KALLSYMS_ALL=y |
| 66 | CONFIG_KALLSYMS_EXTRA_PASS=y | 69 | CONFIG_KALLSYMS_EXTRA_PASS=y |
| 67 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 68 | # CONFIG_HOTPLUG is not set | 70 | # CONFIG_HOTPLUG is not set |
| 69 | CONFIG_PRINTK=y | 71 | CONFIG_PRINTK=y |
| 70 | CONFIG_BUG=y | 72 | CONFIG_BUG=y |
| @@ -76,13 +78,23 @@ CONFIG_SIGNALFD=y | |||
| 76 | CONFIG_TIMERFD=y | 78 | CONFIG_TIMERFD=y |
| 77 | CONFIG_EVENTFD=y | 79 | CONFIG_EVENTFD=y |
| 78 | CONFIG_AIO=y | 80 | CONFIG_AIO=y |
| 81 | |||
| 82 | # | ||
| 83 | # Performance Counters | ||
| 84 | # | ||
| 79 | CONFIG_VM_EVENT_COUNTERS=y | 85 | CONFIG_VM_EVENT_COUNTERS=y |
| 86 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 80 | CONFIG_COMPAT_BRK=y | 87 | CONFIG_COMPAT_BRK=y |
| 81 | CONFIG_SLAB=y | 88 | CONFIG_SLAB=y |
| 82 | # CONFIG_SLUB is not set | 89 | # CONFIG_SLUB is not set |
| 83 | # CONFIG_SLOB is not set | 90 | # CONFIG_SLOB is not set |
| 84 | # CONFIG_PROFILING is not set | 91 | # CONFIG_PROFILING is not set |
| 85 | # CONFIG_MARKERS is not set | 92 | # CONFIG_MARKERS is not set |
| 93 | |||
| 94 | # | ||
| 95 | # GCOV-based kernel profiling | ||
| 96 | # | ||
| 97 | # CONFIG_GCOV_KERNEL is not set | ||
| 86 | # CONFIG_SLOW_WORK is not set | 98 | # CONFIG_SLOW_WORK is not set |
| 87 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 99 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 88 | CONFIG_SLABINFO=y | 100 | CONFIG_SLABINFO=y |
| @@ -95,7 +107,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 95 | # CONFIG_MODVERSIONS is not set | 107 | # CONFIG_MODVERSIONS is not set |
| 96 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 108 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 97 | CONFIG_BLOCK=y | 109 | CONFIG_BLOCK=y |
| 98 | # CONFIG_LBD is not set | 110 | CONFIG_LBDAF=y |
| 99 | # CONFIG_BLK_DEV_BSG is not set | 111 | # CONFIG_BLK_DEV_BSG is not set |
| 100 | # CONFIG_BLK_DEV_INTEGRITY is not set | 112 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 101 | 113 | ||
| @@ -156,8 +168,16 @@ CONFIG_CMDLINE_BOOL=y | |||
| 156 | CONFIG_CMDLINE="console=ttyUL0,115200" | 168 | CONFIG_CMDLINE="console=ttyUL0,115200" |
| 157 | # CONFIG_CMDLINE_FORCE is not set | 169 | # CONFIG_CMDLINE_FORCE is not set |
| 158 | CONFIG_OF=y | 170 | CONFIG_OF=y |
| 159 | CONFIG_OF_DEVICE=y | ||
| 160 | CONFIG_PROC_DEVICETREE=y | 171 | CONFIG_PROC_DEVICETREE=y |
| 172 | |||
| 173 | # | ||
| 174 | # Advanced setup | ||
| 175 | # | ||
| 176 | |||
| 177 | # | ||
| 178 | # Default settings for advanced configuration options are used | ||
| 179 | # | ||
| 180 | CONFIG_KERNEL_START=0x90000000 | ||
| 161 | CONFIG_SELECT_MEMORY_MODEL=y | 181 | CONFIG_SELECT_MEMORY_MODEL=y |
| 162 | CONFIG_FLATMEM_MANUAL=y | 182 | CONFIG_FLATMEM_MANUAL=y |
| 163 | # CONFIG_DISCONTIGMEM_MANUAL is not set | 183 | # CONFIG_DISCONTIGMEM_MANUAL is not set |
| @@ -169,7 +189,7 @@ CONFIG_SPLIT_PTLOCK_CPUS=4 | |||
| 169 | # CONFIG_PHYS_ADDR_T_64BIT is not set | 189 | # CONFIG_PHYS_ADDR_T_64BIT is not set |
| 170 | CONFIG_ZONE_DMA_FLAG=0 | 190 | CONFIG_ZONE_DMA_FLAG=0 |
| 171 | CONFIG_VIRT_TO_BUS=y | 191 | CONFIG_VIRT_TO_BUS=y |
| 172 | CONFIG_UNEVICTABLE_LRU=y | 192 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 |
| 173 | CONFIG_NOMMU_INITIAL_TRIM_EXCESS=1 | 193 | CONFIG_NOMMU_INITIAL_TRIM_EXCESS=1 |
| 174 | 194 | ||
| 175 | # | 195 | # |
| @@ -237,6 +257,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 237 | # CONFIG_ECONET is not set | 257 | # CONFIG_ECONET is not set |
| 238 | # CONFIG_WAN_ROUTER is not set | 258 | # CONFIG_WAN_ROUTER is not set |
| 239 | # CONFIG_PHONET is not set | 259 | # CONFIG_PHONET is not set |
| 260 | # CONFIG_IEEE802154 is not set | ||
| 240 | # CONFIG_NET_SCHED is not set | 261 | # CONFIG_NET_SCHED is not set |
| 241 | # CONFIG_DCB is not set | 262 | # CONFIG_DCB is not set |
| 242 | 263 | ||
| @@ -254,7 +275,11 @@ CONFIG_WIRELESS=y | |||
| 254 | CONFIG_WIRELESS_OLD_REGULATORY=y | 275 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 255 | # CONFIG_WIRELESS_EXT is not set | 276 | # CONFIG_WIRELESS_EXT is not set |
| 256 | # CONFIG_LIB80211 is not set | 277 | # CONFIG_LIB80211 is not set |
| 257 | # CONFIG_MAC80211 is not set | 278 | |
| 279 | # | ||
| 280 | # CFG80211 needs to be enabled for MAC80211 | ||
| 281 | # | ||
| 282 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 258 | # CONFIG_WIMAX is not set | 283 | # CONFIG_WIMAX is not set |
| 259 | # CONFIG_RFKILL is not set | 284 | # CONFIG_RFKILL is not set |
| 260 | # CONFIG_NET_9P is not set | 285 | # CONFIG_NET_9P is not set |
| @@ -353,6 +378,7 @@ CONFIG_MTD_UCLINUX=y | |||
| 353 | # UBI - Unsorted block images | 378 | # UBI - Unsorted block images |
| 354 | # | 379 | # |
| 355 | # CONFIG_MTD_UBI is not set | 380 | # CONFIG_MTD_UBI is not set |
| 381 | CONFIG_OF_DEVICE=y | ||
| 356 | # CONFIG_PARPORT is not set | 382 | # CONFIG_PARPORT is not set |
| 357 | CONFIG_BLK_DEV=y | 383 | CONFIG_BLK_DEV=y |
| 358 | # CONFIG_BLK_DEV_COW_COMMON is not set | 384 | # CONFIG_BLK_DEV_COW_COMMON is not set |
| @@ -364,6 +390,7 @@ CONFIG_BLK_DEV_RAM_SIZE=4096 | |||
| 364 | # CONFIG_BLK_DEV_XIP is not set | 390 | # CONFIG_BLK_DEV_XIP is not set |
| 365 | # CONFIG_CDROM_PKTCDVD is not set | 391 | # CONFIG_CDROM_PKTCDVD is not set |
| 366 | # CONFIG_ATA_OVER_ETH is not set | 392 | # CONFIG_ATA_OVER_ETH is not set |
| 393 | # CONFIG_XILINX_SYSACE is not set | ||
| 367 | CONFIG_MISC_DEVICES=y | 394 | CONFIG_MISC_DEVICES=y |
| 368 | # CONFIG_ENCLOSURE_SERVICES is not set | 395 | # CONFIG_ENCLOSURE_SERVICES is not set |
| 369 | # CONFIG_C2PORT is not set | 396 | # CONFIG_C2PORT is not set |
| @@ -383,7 +410,6 @@ CONFIG_MISC_DEVICES=y | |||
| 383 | # CONFIG_ATA is not set | 410 | # CONFIG_ATA is not set |
| 384 | # CONFIG_MD is not set | 411 | # CONFIG_MD is not set |
| 385 | CONFIG_NETDEVICES=y | 412 | CONFIG_NETDEVICES=y |
| 386 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 387 | # CONFIG_DUMMY is not set | 413 | # CONFIG_DUMMY is not set |
| 388 | # CONFIG_BONDING is not set | 414 | # CONFIG_BONDING is not set |
| 389 | # CONFIG_MACVLAN is not set | 415 | # CONFIG_MACVLAN is not set |
| @@ -402,7 +428,7 @@ CONFIG_NET_ETHERNET=y | |||
| 402 | # CONFIG_IBM_NEW_EMAC_NO_FLOW_CTRL is not set | 428 | # CONFIG_IBM_NEW_EMAC_NO_FLOW_CTRL is not set |
| 403 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 429 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 404 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 430 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 405 | # CONFIG_B44 is not set | 431 | # CONFIG_KS8842 is not set |
| 406 | CONFIG_NETDEV_1000=y | 432 | CONFIG_NETDEV_1000=y |
| 407 | CONFIG_NETDEV_10000=y | 433 | CONFIG_NETDEV_10000=y |
| 408 | 434 | ||
| @@ -463,23 +489,25 @@ CONFIG_HW_RANDOM=y | |||
| 463 | # CONFIG_HW_RANDOM_TIMERIOMEM is not set | 489 | # CONFIG_HW_RANDOM_TIMERIOMEM is not set |
| 464 | # CONFIG_RTC is not set | 490 | # CONFIG_RTC is not set |
| 465 | # CONFIG_GEN_RTC is not set | 491 | # CONFIG_GEN_RTC is not set |
| 492 | # CONFIG_XILINX_HWICAP is not set | ||
| 466 | # CONFIG_R3964 is not set | 493 | # CONFIG_R3964 is not set |
| 467 | # CONFIG_RAW_DRIVER is not set | 494 | # CONFIG_RAW_DRIVER is not set |
| 468 | # CONFIG_TCG_TPM is not set | 495 | # CONFIG_TCG_TPM is not set |
| 469 | # CONFIG_I2C is not set | 496 | # CONFIG_I2C is not set |
| 470 | # CONFIG_SPI is not set | 497 | # CONFIG_SPI is not set |
| 498 | |||
| 499 | # | ||
| 500 | # PPS support | ||
| 501 | # | ||
| 502 | # CONFIG_PPS is not set | ||
| 503 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | ||
| 504 | # CONFIG_GPIOLIB is not set | ||
| 471 | # CONFIG_W1 is not set | 505 | # CONFIG_W1 is not set |
| 472 | # CONFIG_POWER_SUPPLY is not set | 506 | # CONFIG_POWER_SUPPLY is not set |
| 473 | # CONFIG_HWMON is not set | 507 | # CONFIG_HWMON is not set |
| 474 | # CONFIG_THERMAL is not set | 508 | # CONFIG_THERMAL is not set |
| 475 | # CONFIG_THERMAL_HWMON is not set | 509 | # CONFIG_THERMAL_HWMON is not set |
| 476 | # CONFIG_WATCHDOG is not set | 510 | # CONFIG_WATCHDOG is not set |
| 477 | CONFIG_SSB_POSSIBLE=y | ||
| 478 | |||
| 479 | # | ||
| 480 | # Sonics Silicon Backplane | ||
| 481 | # | ||
| 482 | # CONFIG_SSB is not set | ||
| 483 | 511 | ||
| 484 | # | 512 | # |
| 485 | # Multifunction device drivers | 513 | # Multifunction device drivers |
| @@ -489,22 +517,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 489 | # CONFIG_HTC_PASIC3 is not set | 517 | # CONFIG_HTC_PASIC3 is not set |
| 490 | # CONFIG_MFD_TMIO is not set | 518 | # CONFIG_MFD_TMIO is not set |
| 491 | # CONFIG_REGULATOR is not set | 519 | # CONFIG_REGULATOR is not set |
| 492 | 520 | # CONFIG_MEDIA_SUPPORT is not set | |
| 493 | # | ||
| 494 | # Multimedia devices | ||
| 495 | # | ||
| 496 | |||
| 497 | # | ||
| 498 | # Multimedia core support | ||
| 499 | # | ||
| 500 | # CONFIG_VIDEO_DEV is not set | ||
| 501 | # CONFIG_DVB_CORE is not set | ||
| 502 | # CONFIG_VIDEO_MEDIA is not set | ||
| 503 | |||
| 504 | # | ||
| 505 | # Multimedia drivers | ||
| 506 | # | ||
| 507 | CONFIG_DAB=y | ||
| 508 | 521 | ||
| 509 | # | 522 | # |
| 510 | # Graphics support | 523 | # Graphics support |
| @@ -520,9 +533,10 @@ CONFIG_VIDEO_OUTPUT_CONTROL=y | |||
| 520 | # CONFIG_DISPLAY_SUPPORT is not set | 533 | # CONFIG_DISPLAY_SUPPORT is not set |
| 521 | # CONFIG_SOUND is not set | 534 | # CONFIG_SOUND is not set |
| 522 | CONFIG_USB_SUPPORT=y | 535 | CONFIG_USB_SUPPORT=y |
| 523 | # CONFIG_USB_ARCH_HAS_HCD is not set | 536 | CONFIG_USB_ARCH_HAS_HCD=y |
| 524 | # CONFIG_USB_ARCH_HAS_OHCI is not set | 537 | # CONFIG_USB_ARCH_HAS_OHCI is not set |
| 525 | # CONFIG_USB_ARCH_HAS_EHCI is not set | 538 | # CONFIG_USB_ARCH_HAS_EHCI is not set |
| 539 | # CONFIG_USB is not set | ||
| 526 | # CONFIG_USB_OTG_WHITELIST is not set | 540 | # CONFIG_USB_OTG_WHITELIST is not set |
| 527 | # CONFIG_USB_OTG_BLACKLIST_HUB is not set | 541 | # CONFIG_USB_OTG_BLACKLIST_HUB is not set |
| 528 | 542 | ||
| @@ -543,9 +557,12 @@ CONFIG_USB_SUPPORT=y | |||
| 543 | # CONFIG_NEW_LEDS is not set | 557 | # CONFIG_NEW_LEDS is not set |
| 544 | # CONFIG_ACCESSIBILITY is not set | 558 | # CONFIG_ACCESSIBILITY is not set |
| 545 | # CONFIG_RTC_CLASS is not set | 559 | # CONFIG_RTC_CLASS is not set |
| 546 | # CONFIG_DMADEVICES is not set | ||
| 547 | # CONFIG_AUXDISPLAY is not set | 560 | # CONFIG_AUXDISPLAY is not set |
| 548 | # CONFIG_UIO is not set | 561 | # CONFIG_UIO is not set |
| 562 | |||
| 563 | # | ||
| 564 | # TI VLYNQ | ||
| 565 | # | ||
| 549 | # CONFIG_STAGING is not set | 566 | # CONFIG_STAGING is not set |
| 550 | 567 | ||
| 551 | # | 568 | # |
| @@ -558,12 +575,15 @@ CONFIG_EXT2_FS=y | |||
| 558 | # CONFIG_REISERFS_FS is not set | 575 | # CONFIG_REISERFS_FS is not set |
| 559 | # CONFIG_JFS_FS is not set | 576 | # CONFIG_JFS_FS is not set |
| 560 | CONFIG_FS_POSIX_ACL=y | 577 | CONFIG_FS_POSIX_ACL=y |
| 561 | CONFIG_FILE_LOCKING=y | ||
| 562 | # CONFIG_XFS_FS is not set | 578 | # CONFIG_XFS_FS is not set |
| 579 | # CONFIG_GFS2_FS is not set | ||
| 563 | # CONFIG_OCFS2_FS is not set | 580 | # CONFIG_OCFS2_FS is not set |
| 564 | # CONFIG_BTRFS_FS is not set | 581 | # CONFIG_BTRFS_FS is not set |
| 582 | CONFIG_FILE_LOCKING=y | ||
| 583 | CONFIG_FSNOTIFY=y | ||
| 565 | # CONFIG_DNOTIFY is not set | 584 | # CONFIG_DNOTIFY is not set |
| 566 | # CONFIG_INOTIFY is not set | 585 | # CONFIG_INOTIFY is not set |
| 586 | CONFIG_INOTIFY_USER=y | ||
| 567 | # CONFIG_QUOTA is not set | 587 | # CONFIG_QUOTA is not set |
| 568 | # CONFIG_AUTOFS_FS is not set | 588 | # CONFIG_AUTOFS_FS is not set |
| 569 | # CONFIG_AUTOFS4_FS is not set | 589 | # CONFIG_AUTOFS4_FS is not set |
| @@ -813,6 +833,5 @@ CONFIG_GENERIC_FIND_LAST_BIT=y | |||
| 813 | CONFIG_ZLIB_INFLATE=y | 833 | CONFIG_ZLIB_INFLATE=y |
| 814 | CONFIG_HAS_IOMEM=y | 834 | CONFIG_HAS_IOMEM=y |
| 815 | CONFIG_HAS_IOPORT=y | 835 | CONFIG_HAS_IOPORT=y |
| 816 | CONFIG_HAS_DMA=y | ||
| 817 | CONFIG_HAVE_LMB=y | 836 | CONFIG_HAVE_LMB=y |
| 818 | CONFIG_NLATTR=y | 837 | CONFIG_NLATTR=y |
diff --git a/arch/microblaze/include/asm/hardirq.h b/arch/microblaze/include/asm/hardirq.h index 41e1e1aa36ac..cd1ac9aad56c 100644 --- a/arch/microblaze/include/asm/hardirq.h +++ b/arch/microblaze/include/asm/hardirq.h | |||
| @@ -12,8 +12,6 @@ | |||
| 12 | /* should be defined in each interrupt controller driver */ | 12 | /* should be defined in each interrupt controller driver */ |
| 13 | extern unsigned int get_irq(struct pt_regs *regs); | 13 | extern unsigned int get_irq(struct pt_regs *regs); |
| 14 | 14 | ||
| 15 | #define ack_bad_irq ack_bad_irq | ||
| 16 | void ack_bad_irq(unsigned int irq); | ||
| 17 | #include <asm-generic/hardirq.h> | 15 | #include <asm-generic/hardirq.h> |
| 18 | 16 | ||
| 19 | #endif /* _ASM_MICROBLAZE_HARDIRQ_H */ | 17 | #endif /* _ASM_MICROBLAZE_HARDIRQ_H */ |
diff --git a/arch/microblaze/include/asm/io.h b/arch/microblaze/include/asm/io.h index 5c173424d074..7c3ec13b44d8 100644 --- a/arch/microblaze/include/asm/io.h +++ b/arch/microblaze/include/asm/io.h | |||
| @@ -14,7 +14,6 @@ | |||
| 14 | #include <asm/byteorder.h> | 14 | #include <asm/byteorder.h> |
| 15 | #include <asm/page.h> | 15 | #include <asm/page.h> |
| 16 | #include <linux/types.h> | 16 | #include <linux/types.h> |
| 17 | #include <asm/byteorder.h> | ||
| 18 | #include <linux/mm.h> /* Get struct page {...} */ | 17 | #include <linux/mm.h> /* Get struct page {...} */ |
| 19 | 18 | ||
| 20 | 19 | ||
diff --git a/arch/microblaze/include/asm/pgalloc.h b/arch/microblaze/include/asm/pgalloc.h index 59a757e46ba5..b0131da1387b 100644 --- a/arch/microblaze/include/asm/pgalloc.h +++ b/arch/microblaze/include/asm/pgalloc.h | |||
| @@ -180,7 +180,7 @@ extern inline void pte_free(struct mm_struct *mm, struct page *ptepage) | |||
| 180 | __free_page(ptepage); | 180 | __free_page(ptepage); |
| 181 | } | 181 | } |
| 182 | 182 | ||
| 183 | #define __pte_free_tlb(tlb, pte) pte_free((tlb)->mm, (pte)) | 183 | #define __pte_free_tlb(tlb, pte, addr) pte_free((tlb)->mm, (pte)) |
| 184 | 184 | ||
| 185 | #define pmd_populate(mm, pmd, pte) (pmd_val(*(pmd)) = page_address(pte)) | 185 | #define pmd_populate(mm, pmd, pte) (pmd_val(*(pmd)) = page_address(pte)) |
| 186 | 186 | ||
| @@ -193,7 +193,7 @@ extern inline void pte_free(struct mm_struct *mm, struct page *ptepage) | |||
| 193 | */ | 193 | */ |
| 194 | #define pmd_alloc_one(mm, address) ({ BUG(); ((pmd_t *)2); }) | 194 | #define pmd_alloc_one(mm, address) ({ BUG(); ((pmd_t *)2); }) |
| 195 | /*#define pmd_free(mm, x) do { } while (0)*/ | 195 | /*#define pmd_free(mm, x) do { } while (0)*/ |
| 196 | #define __pmd_free_tlb(tlb, x) do { } while (0) | 196 | #define __pmd_free_tlb(tlb, x, addr) do { } while (0) |
| 197 | #define pgd_populate(mm, pmd, pte) BUG() | 197 | #define pgd_populate(mm, pmd, pte) BUG() |
| 198 | 198 | ||
| 199 | extern int do_check_pgt_cache(int, int); | 199 | extern int do_check_pgt_cache(int, int); |
diff --git a/arch/microblaze/include/asm/pgtable.h b/arch/microblaze/include/asm/pgtable.h index 4c57a586a989..cc3a4dfc3eaa 100644 --- a/arch/microblaze/include/asm/pgtable.h +++ b/arch/microblaze/include/asm/pgtable.h | |||
| @@ -185,6 +185,7 @@ static inline pte_t pte_mkspecial(pte_t pte) { return pte; } | |||
| 185 | 185 | ||
| 186 | /* Definitions for MicroBlaze. */ | 186 | /* Definitions for MicroBlaze. */ |
| 187 | #define _PAGE_GUARDED 0x001 /* G: page is guarded from prefetch */ | 187 | #define _PAGE_GUARDED 0x001 /* G: page is guarded from prefetch */ |
| 188 | #define _PAGE_FILE 0x001 /* when !present: nonlinear file mapping */ | ||
| 188 | #define _PAGE_PRESENT 0x002 /* software: PTE contains a translation */ | 189 | #define _PAGE_PRESENT 0x002 /* software: PTE contains a translation */ |
| 189 | #define _PAGE_NO_CACHE 0x004 /* I: caching is inhibited */ | 190 | #define _PAGE_NO_CACHE 0x004 /* I: caching is inhibited */ |
| 190 | #define _PAGE_WRITETHRU 0x008 /* W: caching is write-through */ | 191 | #define _PAGE_WRITETHRU 0x008 /* W: caching is write-through */ |
| @@ -320,8 +321,7 @@ static inline int pte_write(pte_t pte) { return pte_val(pte) & _PAGE_RW; } | |||
| 320 | static inline int pte_exec(pte_t pte) { return pte_val(pte) & _PAGE_EXEC; } | 321 | static inline int pte_exec(pte_t pte) { return pte_val(pte) & _PAGE_EXEC; } |
| 321 | static inline int pte_dirty(pte_t pte) { return pte_val(pte) & _PAGE_DIRTY; } | 322 | static inline int pte_dirty(pte_t pte) { return pte_val(pte) & _PAGE_DIRTY; } |
| 322 | static inline int pte_young(pte_t pte) { return pte_val(pte) & _PAGE_ACCESSED; } | 323 | static inline int pte_young(pte_t pte) { return pte_val(pte) & _PAGE_ACCESSED; } |
| 323 | /* FIXME */ | 324 | static inline int pte_file(pte_t pte) { return pte_val(pte) & _PAGE_FILE; } |
| 324 | static inline int pte_file(pte_t pte) { return 0; } | ||
| 325 | 325 | ||
| 326 | static inline void pte_uncache(pte_t pte) { pte_val(pte) |= _PAGE_NO_CACHE; } | 326 | static inline void pte_uncache(pte_t pte) { pte_val(pte) |= _PAGE_NO_CACHE; } |
| 327 | static inline void pte_cache(pte_t pte) { pte_val(pte) &= ~_PAGE_NO_CACHE; } | 327 | static inline void pte_cache(pte_t pte) { pte_val(pte) &= ~_PAGE_NO_CACHE; } |
| @@ -488,7 +488,7 @@ static inline pmd_t *pmd_offset(pgd_t *dir, unsigned long address) | |||
| 488 | /* Encode and decode a nonlinear file mapping entry */ | 488 | /* Encode and decode a nonlinear file mapping entry */ |
| 489 | #define PTE_FILE_MAX_BITS 29 | 489 | #define PTE_FILE_MAX_BITS 29 |
| 490 | #define pte_to_pgoff(pte) (pte_val(pte) >> 3) | 490 | #define pte_to_pgoff(pte) (pte_val(pte) >> 3) |
| 491 | #define pgoff_to_pte(off) ((pte_t) { ((off) << 3) }) | 491 | #define pgoff_to_pte(off) ((pte_t) { ((off) << 3) | _PAGE_FILE }) |
| 492 | 492 | ||
| 493 | extern pgd_t swapper_pg_dir[PTRS_PER_PGD]; | 493 | extern pgd_t swapper_pg_dir[PTRS_PER_PGD]; |
| 494 | 494 | ||
diff --git a/arch/microblaze/include/asm/prom.h b/arch/microblaze/include/asm/prom.h index 20f7b3a926e8..37e6f305a68e 100644 --- a/arch/microblaze/include/asm/prom.h +++ b/arch/microblaze/include/asm/prom.h | |||
| @@ -16,6 +16,18 @@ | |||
| 16 | #define _ASM_MICROBLAZE_PROM_H | 16 | #define _ASM_MICROBLAZE_PROM_H |
| 17 | #ifdef __KERNEL__ | 17 | #ifdef __KERNEL__ |
| 18 | 18 | ||
| 19 | /* Definitions used by the flattened device tree */ | ||
| 20 | #define OF_DT_HEADER 0xd00dfeed /* marker */ | ||
| 21 | #define OF_DT_BEGIN_NODE 0x1 /* Start of node, full name */ | ||
| 22 | #define OF_DT_END_NODE 0x2 /* End node */ | ||
| 23 | #define OF_DT_PROP 0x3 /* Property: name off, size, content */ | ||
| 24 | #define OF_DT_NOP 0x4 /* nop */ | ||
| 25 | #define OF_DT_END 0x9 | ||
| 26 | |||
| 27 | #define OF_DT_VERSION 0x10 | ||
| 28 | |||
| 29 | #ifndef __ASSEMBLY__ | ||
| 30 | |||
| 19 | #include <linux/types.h> | 31 | #include <linux/types.h> |
| 20 | #include <linux/proc_fs.h> | 32 | #include <linux/proc_fs.h> |
| 21 | #include <linux/platform_device.h> | 33 | #include <linux/platform_device.h> |
| @@ -29,16 +41,6 @@ | |||
| 29 | #define of_prop_cmp(s1, s2) strcmp((s1), (s2)) | 41 | #define of_prop_cmp(s1, s2) strcmp((s1), (s2)) |
| 30 | #define of_node_cmp(s1, s2) strcasecmp((s1), (s2)) | 42 | #define of_node_cmp(s1, s2) strcasecmp((s1), (s2)) |
| 31 | 43 | ||
| 32 | /* Definitions used by the flattened device tree */ | ||
| 33 | #define OF_DT_HEADER 0xd00dfeed /* marker */ | ||
| 34 | #define OF_DT_BEGIN_NODE 0x1 /* Start of node, full name */ | ||
| 35 | #define OF_DT_END_NODE 0x2 /* End node */ | ||
| 36 | #define OF_DT_PROP 0x3 /* Property: name off, size, content */ | ||
| 37 | #define OF_DT_NOP 0x4 /* nop */ | ||
| 38 | #define OF_DT_END 0x9 | ||
| 39 | |||
| 40 | #define OF_DT_VERSION 0x10 | ||
| 41 | |||
| 42 | /* | 44 | /* |
| 43 | * This is what gets passed to the kernel by prom_init or kexec | 45 | * This is what gets passed to the kernel by prom_init or kexec |
| 44 | * | 46 | * |
| @@ -309,5 +311,6 @@ extern void __iomem *of_iomap(struct device_node *device, int index); | |||
| 309 | */ | 311 | */ |
| 310 | #include <linux/of.h> | 312 | #include <linux/of.h> |
| 311 | 313 | ||
| 314 | #endif /* __ASSEMBLY__ */ | ||
| 312 | #endif /* __KERNEL__ */ | 315 | #endif /* __KERNEL__ */ |
| 313 | #endif /* _ASM_MICROBLAZE_PROM_H */ | 316 | #endif /* _ASM_MICROBLAZE_PROM_H */ |
diff --git a/arch/microblaze/include/asm/tlb.h b/arch/microblaze/include/asm/tlb.h index c472d2801132..e8abd4a0349c 100644 --- a/arch/microblaze/include/asm/tlb.h +++ b/arch/microblaze/include/asm/tlb.h | |||
| @@ -11,7 +11,7 @@ | |||
| 11 | #ifndef _ASM_MICROBLAZE_TLB_H | 11 | #ifndef _ASM_MICROBLAZE_TLB_H |
| 12 | #define _ASM_MICROBLAZE_TLB_H | 12 | #define _ASM_MICROBLAZE_TLB_H |
| 13 | 13 | ||
| 14 | #define tlb_flush(tlb) do {} while (0) | 14 | #define tlb_flush(tlb) flush_tlb_mm((tlb)->mm) |
| 15 | 15 | ||
| 16 | #include <asm-generic/tlb.h> | 16 | #include <asm-generic/tlb.h> |
| 17 | 17 | ||
diff --git a/arch/microblaze/include/asm/uaccess.h b/arch/microblaze/include/asm/uaccess.h index 65adad61e7e9..5431b4631a7a 100644 --- a/arch/microblaze/include/asm/uaccess.h +++ b/arch/microblaze/include/asm/uaccess.h | |||
| @@ -189,7 +189,7 @@ extern long strnlen_user(const char *src, long count); | |||
| 189 | 189 | ||
| 190 | #define __put_user(x, ptr) \ | 190 | #define __put_user(x, ptr) \ |
| 191 | ({ \ | 191 | ({ \ |
| 192 | __typeof__(*(ptr)) __gu_val = x; \ | 192 | __typeof__(*(ptr)) volatile __gu_val = (x); \ |
| 193 | long __gu_err = 0; \ | 193 | long __gu_err = 0; \ |
| 194 | switch (sizeof(__gu_val)) { \ | 194 | switch (sizeof(__gu_val)) { \ |
| 195 | case 1: \ | 195 | case 1: \ |
diff --git a/arch/microblaze/kernel/Makefile b/arch/microblaze/kernel/Makefile index f4a5e19a20eb..d487729683de 100644 --- a/arch/microblaze/kernel/Makefile +++ b/arch/microblaze/kernel/Makefile | |||
| @@ -17,4 +17,4 @@ obj-$(CONFIG_HEART_BEAT) += heartbeat.o | |||
| 17 | obj-$(CONFIG_MODULES) += microblaze_ksyms.o module.o | 17 | obj-$(CONFIG_MODULES) += microblaze_ksyms.o module.o |
| 18 | obj-$(CONFIG_MMU) += misc.o | 18 | obj-$(CONFIG_MMU) += misc.o |
| 19 | 19 | ||
| 20 | obj-y += entry$(MMUEXT).o | 20 | obj-y += entry$(MMU).o |
diff --git a/arch/microblaze/kernel/cpu/cpuinfo-pvr-full.c b/arch/microblaze/kernel/cpu/cpuinfo-pvr-full.c index 153f57c57b6d..c259786e7faa 100644 --- a/arch/microblaze/kernel/cpu/cpuinfo-pvr-full.c +++ b/arch/microblaze/kernel/cpu/cpuinfo-pvr-full.c | |||
| @@ -22,7 +22,7 @@ | |||
| 22 | 22 | ||
| 23 | #define CI(c, p) { ci->c = PVR_##p(pvr); } | 23 | #define CI(c, p) { ci->c = PVR_##p(pvr); } |
| 24 | #define err_printk(x) \ | 24 | #define err_printk(x) \ |
| 25 | early_printk("ERROR: Microblaze " x " - different for PVR and DTS\n"); | 25 | early_printk("ERROR: Microblaze " x "-different for PVR and DTS\n"); |
| 26 | 26 | ||
| 27 | void set_cpuinfo_pvr_full(struct cpuinfo *ci, struct device_node *cpu) | 27 | void set_cpuinfo_pvr_full(struct cpuinfo *ci, struct device_node *cpu) |
| 28 | { | 28 | { |
diff --git a/arch/microblaze/kernel/cpu/cpuinfo-static.c b/arch/microblaze/kernel/cpu/cpuinfo-static.c index 450ca6bb828d..adb448f93d5f 100644 --- a/arch/microblaze/kernel/cpu/cpuinfo-static.c +++ b/arch/microblaze/kernel/cpu/cpuinfo-static.c | |||
| @@ -18,7 +18,7 @@ static const char family_string[] = CONFIG_XILINX_MICROBLAZE0_FAMILY; | |||
| 18 | static const char cpu_ver_string[] = CONFIG_XILINX_MICROBLAZE0_HW_VER; | 18 | static const char cpu_ver_string[] = CONFIG_XILINX_MICROBLAZE0_HW_VER; |
| 19 | 19 | ||
| 20 | #define err_printk(x) \ | 20 | #define err_printk(x) \ |
| 21 | early_printk("ERROR: Microblaze " x "- different for kernel and DTS\n"); | 21 | early_printk("ERROR: Microblaze " x "-different for kernel and DTS\n"); |
| 22 | 22 | ||
| 23 | void __init set_cpuinfo_static(struct cpuinfo *ci, struct device_node *cpu) | 23 | void __init set_cpuinfo_static(struct cpuinfo *ci, struct device_node *cpu) |
| 24 | { | 24 | { |
diff --git a/arch/microblaze/kernel/cpu/cpuinfo.c b/arch/microblaze/kernel/cpu/cpuinfo.c index a10bea119b94..c411c6757deb 100644 --- a/arch/microblaze/kernel/cpu/cpuinfo.c +++ b/arch/microblaze/kernel/cpu/cpuinfo.c | |||
| @@ -26,6 +26,8 @@ const struct cpu_ver_key cpu_ver_lookup[] = { | |||
| 26 | {"7.10.b", 0x09}, | 26 | {"7.10.b", 0x09}, |
| 27 | {"7.10.c", 0x0a}, | 27 | {"7.10.c", 0x0a}, |
| 28 | {"7.10.d", 0x0b}, | 28 | {"7.10.d", 0x0b}, |
| 29 | {"7.20.a", 0x0c}, | ||
| 30 | {"7.20.b", 0x0d}, | ||
| 29 | /* FIXME There is no keycode defined in MBV for these versions */ | 31 | /* FIXME There is no keycode defined in MBV for these versions */ |
| 30 | {"2.10.a", 0x10}, | 32 | {"2.10.a", 0x10}, |
| 31 | {"3.00.a", 0x20}, | 33 | {"3.00.a", 0x20}, |
diff --git a/arch/microblaze/kernel/head.S b/arch/microblaze/kernel/head.S index e568d6ec621b..e41c6ce2a7be 100644 --- a/arch/microblaze/kernel/head.S +++ b/arch/microblaze/kernel/head.S | |||
| @@ -31,6 +31,7 @@ | |||
| 31 | #include <linux/linkage.h> | 31 | #include <linux/linkage.h> |
| 32 | #include <asm/thread_info.h> | 32 | #include <asm/thread_info.h> |
| 33 | #include <asm/page.h> | 33 | #include <asm/page.h> |
| 34 | #include <asm/prom.h> /* for OF_DT_HEADER */ | ||
| 34 | 35 | ||
| 35 | #ifdef CONFIG_MMU | 36 | #ifdef CONFIG_MMU |
| 36 | #include <asm/setup.h> /* COMMAND_LINE_SIZE */ | 37 | #include <asm/setup.h> /* COMMAND_LINE_SIZE */ |
| @@ -54,11 +55,19 @@ ENTRY(_start) | |||
| 54 | andi r1, r1, ~2 | 55 | andi r1, r1, ~2 |
| 55 | mts rmsr, r1 | 56 | mts rmsr, r1 |
| 56 | 57 | ||
| 57 | /* save fdt to kernel location */ | 58 | /* r7 may point to an FDT, or there may be one linked in. |
| 58 | /* r7 stores pointer to fdt blob */ | 59 | if it's in r7, we've got to save it away ASAP. |
| 59 | beqi r7, no_fdt_arg | 60 | We ensure r7 points to a valid FDT, just in case the bootloader |
| 61 | is broken or non-existent */ | ||
| 62 | beqi r7, no_fdt_arg /* NULL pointer? don't copy */ | ||
| 63 | lw r11, r0, r7 /* Does r7 point to a */ | ||
| 64 | rsubi r11, r11, OF_DT_HEADER /* valid FDT? */ | ||
| 65 | beqi r11, _prepare_copy_fdt | ||
| 66 | or r7, r0, r0 /* clear R7 when not valid DTB */ | ||
| 67 | bnei r11, no_fdt_arg /* No - get out of here */ | ||
| 68 | _prepare_copy_fdt: | ||
| 60 | or r11, r0, r0 /* incremment */ | 69 | or r11, r0, r0 /* incremment */ |
| 61 | ori r4, r0, TOPHYS(_fdt_start) /* save bram context */ | 70 | ori r4, r0, TOPHYS(_fdt_start) |
| 62 | ori r3, r0, (0x4000 - 4) | 71 | ori r3, r0, (0x4000 - 4) |
| 63 | _copy_fdt: | 72 | _copy_fdt: |
| 64 | lw r12, r7, r11 /* r12 = r7 + r11 */ | 73 | lw r12, r7, r11 /* r12 = r7 + r11 */ |
diff --git a/arch/microblaze/kernel/hw_exception_handler.S b/arch/microblaze/kernel/hw_exception_handler.S index 9d591cd74fc2..3288c9737671 100644 --- a/arch/microblaze/kernel/hw_exception_handler.S +++ b/arch/microblaze/kernel/hw_exception_handler.S | |||
| @@ -74,6 +74,7 @@ | |||
| 74 | 74 | ||
| 75 | #include <asm/mmu.h> | 75 | #include <asm/mmu.h> |
| 76 | #include <asm/pgtable.h> | 76 | #include <asm/pgtable.h> |
| 77 | #include <asm/signal.h> | ||
| 77 | #include <asm/asm-offsets.h> | 78 | #include <asm/asm-offsets.h> |
| 78 | 79 | ||
| 79 | /* Helpful Macros */ | 80 | /* Helpful Macros */ |
| @@ -428,19 +429,9 @@ handle_unaligned_ex: | |||
| 428 | mfs r17, rbtr; /* ESR[DS] set - return address in BTR */ | 429 | mfs r17, rbtr; /* ESR[DS] set - return address in BTR */ |
| 429 | nop | 430 | nop |
| 430 | _no_delayslot: | 431 | _no_delayslot: |
| 431 | #endif | 432 | /* jump to high level unaligned handler */ |
| 432 | 433 | RESTORE_STATE; | |
| 433 | #ifdef CONFIG_MMU | 434 | bri unaligned_data_trap |
| 434 | /* Check if unaligned address is last on a 4k page */ | ||
| 435 | andi r5, r4, 0xffc | ||
| 436 | xori r5, r5, 0xffc | ||
| 437 | bnei r5, _unaligned_ex2 | ||
| 438 | _unaligned_ex1: | ||
| 439 | RESTORE_STATE; | ||
| 440 | /* Another page must be accessed or physical address not in page table */ | ||
| 441 | bri unaligned_data_trap | ||
| 442 | |||
| 443 | _unaligned_ex2: | ||
| 444 | #endif | 435 | #endif |
| 445 | andi r6, r3, 0x3E0; /* Mask and extract the register operand */ | 436 | andi r6, r3, 0x3E0; /* Mask and extract the register operand */ |
| 446 | srl r6, r6; /* r6 >> 5 */ | 437 | srl r6, r6; /* r6 >> 5 */ |
| @@ -450,45 +441,6 @@ _no_delayslot: | |||
| 450 | srl r6, r6; | 441 | srl r6, r6; |
| 451 | /* Store the register operand in a temporary location */ | 442 | /* Store the register operand in a temporary location */ |
| 452 | sbi r6, r0, TOPHYS(ex_reg_op); | 443 | sbi r6, r0, TOPHYS(ex_reg_op); |
| 453 | #ifdef CONFIG_MMU | ||
| 454 | /* Get physical address */ | ||
| 455 | /* If we are faulting a kernel address, we have to use the | ||
| 456 | * kernel page tables. | ||
| 457 | */ | ||
| 458 | ori r5, r0, CONFIG_KERNEL_START | ||
| 459 | cmpu r5, r4, r5 | ||
| 460 | bgti r5, _unaligned_ex3 | ||
| 461 | ori r5, r0, swapper_pg_dir | ||
| 462 | bri _unaligned_ex4 | ||
| 463 | |||
| 464 | /* Get the PGD for the current thread. */ | ||
| 465 | _unaligned_ex3: /* user thread */ | ||
| 466 | addi r5 ,CURRENT_TASK, TOPHYS(0); /* get current task address */ | ||
| 467 | lwi r5, r5, TASK_THREAD + PGDIR | ||
| 468 | _unaligned_ex4: | ||
| 469 | tophys(r5,r5) | ||
| 470 | BSRLI(r6,r4,20) /* Create L1 (pgdir/pmd) address */ | ||
| 471 | andi r6, r6, 0xffc | ||
| 472 | /* Assume pgdir aligned on 4K boundary, no need for "andi r5,r5,0xfffff003" */ | ||
| 473 | or r5, r5, r6 | ||
| 474 | lwi r6, r5, 0 /* Get L1 entry */ | ||
| 475 | andi r5, r6, 0xfffff000 /* Extract L2 (pte) base address. */ | ||
| 476 | beqi r5, _unaligned_ex1 /* Bail if no table */ | ||
| 477 | |||
| 478 | tophys(r5,r5) | ||
| 479 | BSRLI(r6,r4,10) /* Compute PTE address */ | ||
| 480 | andi r6, r6, 0xffc | ||
| 481 | andi r5, r5, 0xfffff003 | ||
| 482 | or r5, r5, r6 | ||
| 483 | lwi r5, r5, 0 /* Get Linux PTE */ | ||
| 484 | |||
| 485 | andi r6, r5, _PAGE_PRESENT | ||
| 486 | beqi r6, _unaligned_ex1 /* Bail if no page */ | ||
| 487 | |||
| 488 | andi r5, r5, 0xfffff000 /* Extract RPN */ | ||
| 489 | andi r4, r4, 0x00000fff /* Extract offset */ | ||
| 490 | or r4, r4, r5 /* Create physical address */ | ||
| 491 | #endif /* CONFIG_MMU */ | ||
| 492 | 444 | ||
| 493 | andi r6, r3, 0x400; /* Extract ESR[S] */ | 445 | andi r6, r3, 0x400; /* Extract ESR[S] */ |
| 494 | bnei r6, ex_sw; | 446 | bnei r6, ex_sw; |
| @@ -959,15 +911,15 @@ _unaligned_data_exception: | |||
| 959 | andi r6, r3, 0x800; /* Extract ESR[W] - delay slot */ | 911 | andi r6, r3, 0x800; /* Extract ESR[W] - delay slot */ |
| 960 | ex_lw_vm: | 912 | ex_lw_vm: |
| 961 | beqid r6, ex_lhw_vm; | 913 | beqid r6, ex_lhw_vm; |
| 962 | lbui r5, r4, 0; /* Exception address in r4 - delay slot */ | 914 | load1: lbui r5, r4, 0; /* Exception address in r4 - delay slot */ |
| 963 | /* Load a word, byte-by-byte from destination address and save it in tmp space*/ | 915 | /* Load a word, byte-by-byte from destination address and save it in tmp space*/ |
| 964 | la r6, r0, ex_tmp_data_loc_0; | 916 | la r6, r0, ex_tmp_data_loc_0; |
| 965 | sbi r5, r6, 0; | 917 | sbi r5, r6, 0; |
| 966 | lbui r5, r4, 1; | 918 | load2: lbui r5, r4, 1; |
| 967 | sbi r5, r6, 1; | 919 | sbi r5, r6, 1; |
| 968 | lbui r5, r4, 2; | 920 | load3: lbui r5, r4, 2; |
| 969 | sbi r5, r6, 2; | 921 | sbi r5, r6, 2; |
| 970 | lbui r5, r4, 3; | 922 | load4: lbui r5, r4, 3; |
| 971 | sbi r5, r6, 3; | 923 | sbi r5, r6, 3; |
| 972 | brid ex_lw_tail_vm; | 924 | brid ex_lw_tail_vm; |
| 973 | /* Get the destination register value into r3 - delay slot */ | 925 | /* Get the destination register value into r3 - delay slot */ |
| @@ -977,7 +929,7 @@ ex_lhw_vm: | |||
| 977 | * save it in tmp space */ | 929 | * save it in tmp space */ |
| 978 | la r6, r0, ex_tmp_data_loc_0; | 930 | la r6, r0, ex_tmp_data_loc_0; |
| 979 | sbi r5, r6, 0; | 931 | sbi r5, r6, 0; |
| 980 | lbui r5, r4, 1; | 932 | load5: lbui r5, r4, 1; |
| 981 | sbi r5, r6, 1; | 933 | sbi r5, r6, 1; |
| 982 | lhui r3, r6, 0; /* Get the destination register value into r3 */ | 934 | lhui r3, r6, 0; /* Get the destination register value into r3 */ |
| 983 | ex_lw_tail_vm: | 935 | ex_lw_tail_vm: |
| @@ -996,22 +948,53 @@ ex_sw_tail_vm: | |||
| 996 | swi r3, r5, 0; /* Get the word - delay slot */ | 948 | swi r3, r5, 0; /* Get the word - delay slot */ |
| 997 | /* Store the word, byte-by-byte into destination address */ | 949 | /* Store the word, byte-by-byte into destination address */ |
| 998 | lbui r3, r5, 0; | 950 | lbui r3, r5, 0; |
| 999 | sbi r3, r4, 0; | 951 | store1: sbi r3, r4, 0; |
| 1000 | lbui r3, r5, 1; | 952 | lbui r3, r5, 1; |
| 1001 | sbi r3, r4, 1; | 953 | store2: sbi r3, r4, 1; |
| 1002 | lbui r3, r5, 2; | 954 | lbui r3, r5, 2; |
| 1003 | sbi r3, r4, 2; | 955 | store3: sbi r3, r4, 2; |
| 1004 | lbui r3, r5, 3; | 956 | lbui r3, r5, 3; |
| 1005 | brid ret_from_exc; | 957 | brid ret_from_exc; |
| 1006 | sbi r3, r4, 3; /* Delay slot */ | 958 | store4: sbi r3, r4, 3; /* Delay slot */ |
| 1007 | ex_shw_vm: | 959 | ex_shw_vm: |
| 1008 | /* Store the lower half-word, byte-by-byte into destination address */ | 960 | /* Store the lower half-word, byte-by-byte into destination address */ |
| 1009 | lbui r3, r5, 2; | 961 | lbui r3, r5, 2; |
| 1010 | sbi r3, r4, 0; | 962 | store5: sbi r3, r4, 0; |
| 1011 | lbui r3, r5, 3; | 963 | lbui r3, r5, 3; |
| 1012 | brid ret_from_exc; | 964 | brid ret_from_exc; |
| 1013 | sbi r3, r4, 1; /* Delay slot */ | 965 | store6: sbi r3, r4, 1; /* Delay slot */ |
| 1014 | ex_sw_end_vm: /* Exception handling of store word, ends. */ | 966 | ex_sw_end_vm: /* Exception handling of store word, ends. */ |
| 967 | |||
| 968 | /* We have to prevent cases that get/put_user macros get unaligned pointer | ||
| 969 | * to bad page area. We have to find out which origin instruction caused it | ||
| 970 | * and called fixup for that origin instruction not instruction in unaligned | ||
| 971 | * handler */ | ||
| 972 | ex_unaligned_fixup: | ||
| 973 | ori r5, r7, 0 /* setup pointer to pt_regs */ | ||
| 974 | lwi r6, r7, PT_PC; /* faulting address is one instruction above */ | ||
| 975 | addik r6, r6, -4 /* for finding proper fixup */ | ||
| 976 | swi r6, r7, PT_PC; /* a save back it to PT_PC */ | ||
| 977 | addik r7, r0, SIGSEGV | ||
| 978 | /* call bad_page_fault for finding aligned fixup, fixup address is saved | ||
| 979 | * in PT_PC which is used as return address from exception */ | ||
| 980 | la r15, r0, ret_from_exc-8 /* setup return address */ | ||
| 981 | brid bad_page_fault | ||
| 982 | nop | ||
| 983 | |||
| 984 | /* We prevent all load/store because it could failed any attempt to access */ | ||
| 985 | .section __ex_table,"a"; | ||
| 986 | .word load1,ex_unaligned_fixup; | ||
| 987 | .word load2,ex_unaligned_fixup; | ||
| 988 | .word load3,ex_unaligned_fixup; | ||
| 989 | .word load4,ex_unaligned_fixup; | ||
| 990 | .word load5,ex_unaligned_fixup; | ||
| 991 | .word store1,ex_unaligned_fixup; | ||
| 992 | .word store2,ex_unaligned_fixup; | ||
| 993 | .word store3,ex_unaligned_fixup; | ||
| 994 | .word store4,ex_unaligned_fixup; | ||
| 995 | .word store5,ex_unaligned_fixup; | ||
| 996 | .word store6,ex_unaligned_fixup; | ||
| 997 | .previous; | ||
| 1015 | .end _unaligned_data_exception | 998 | .end _unaligned_data_exception |
| 1016 | #endif /* CONFIG_MMU */ | 999 | #endif /* CONFIG_MMU */ |
| 1017 | 1000 | ||
diff --git a/arch/microblaze/kernel/intc.c b/arch/microblaze/kernel/intc.c index b15605299a57..6eea6f92b84e 100644 --- a/arch/microblaze/kernel/intc.c +++ b/arch/microblaze/kernel/intc.c | |||
| @@ -12,6 +12,7 @@ | |||
| 12 | #include <linux/irq.h> | 12 | #include <linux/irq.h> |
| 13 | #include <asm/page.h> | 13 | #include <asm/page.h> |
| 14 | #include <linux/io.h> | 14 | #include <linux/io.h> |
| 15 | #include <linux/bug.h> | ||
| 15 | 16 | ||
| 16 | #include <asm/prom.h> | 17 | #include <asm/prom.h> |
| 17 | #include <asm/irq.h> | 18 | #include <asm/irq.h> |
| @@ -130,6 +131,7 @@ void __init init_IRQ(void) | |||
| 130 | if (intc) | 131 | if (intc) |
| 131 | break; | 132 | break; |
| 132 | } | 133 | } |
| 134 | BUG_ON(!intc); | ||
| 133 | 135 | ||
| 134 | intc_baseaddr = *(int *) of_get_property(intc, "reg", NULL); | 136 | intc_baseaddr = *(int *) of_get_property(intc, "reg", NULL); |
| 135 | intc_baseaddr = (unsigned long) ioremap(intc_baseaddr, PAGE_SIZE); | 137 | intc_baseaddr = (unsigned long) ioremap(intc_baseaddr, PAGE_SIZE); |
diff --git a/arch/microblaze/kernel/irq.c b/arch/microblaze/kernel/irq.c index f688ee93e3b9..7d5ddd62d4d2 100644 --- a/arch/microblaze/kernel/irq.c +++ b/arch/microblaze/kernel/irq.c | |||
| @@ -30,15 +30,6 @@ unsigned int irq_of_parse_and_map(struct device_node *dev, int index) | |||
| 30 | } | 30 | } |
| 31 | EXPORT_SYMBOL_GPL(irq_of_parse_and_map); | 31 | EXPORT_SYMBOL_GPL(irq_of_parse_and_map); |
| 32 | 32 | ||
| 33 | /* | ||
| 34 | * 'what should we do if we get a hw irq event on an illegal vector'. | ||
| 35 | * each architecture has to answer this themselves. | ||
| 36 | */ | ||
| 37 | void ack_bad_irq(unsigned int irq) | ||
| 38 | { | ||
| 39 | printk(KERN_WARNING "unexpected IRQ trap at vector %02x\n", irq); | ||
| 40 | } | ||
| 41 | |||
| 42 | static u32 concurrent_irq; | 33 | static u32 concurrent_irq; |
| 43 | 34 | ||
| 44 | void do_IRQ(struct pt_regs *regs) | 35 | void do_IRQ(struct pt_regs *regs) |
diff --git a/arch/microblaze/kernel/module.c b/arch/microblaze/kernel/module.c index 51414171326f..5a45b1adfef1 100644 --- a/arch/microblaze/kernel/module.c +++ b/arch/microblaze/kernel/module.c | |||
| @@ -57,7 +57,6 @@ int apply_relocate_add(Elf32_Shdr *sechdrs, const char *strtab, | |||
| 57 | Elf32_Rela *rela = (void *)sechdrs[relsec].sh_addr; | 57 | Elf32_Rela *rela = (void *)sechdrs[relsec].sh_addr; |
| 58 | Elf32_Sym *sym; | 58 | Elf32_Sym *sym; |
| 59 | unsigned long int *location; | 59 | unsigned long int *location; |
| 60 | unsigned long int locoffs; | ||
| 61 | unsigned long int value; | 60 | unsigned long int value; |
| 62 | #if __GNUC__ < 4 | 61 | #if __GNUC__ < 4 |
| 63 | unsigned long int old_value; | 62 | unsigned long int old_value; |
| @@ -113,10 +112,12 @@ int apply_relocate_add(Elf32_Shdr *sechdrs, const char *strtab, | |||
| 113 | break; | 112 | break; |
| 114 | 113 | ||
| 115 | case R_MICROBLAZE_64_PCREL: | 114 | case R_MICROBLAZE_64_PCREL: |
| 116 | locoffs = (location[0] & 0xFFFF) << 16 | | 115 | #if __GNUC__ < 4 |
| 116 | old_value = (location[0] & 0xFFFF) << 16 | | ||
| 117 | (location[1] & 0xFFFF); | 117 | (location[1] & 0xFFFF); |
| 118 | value -= (unsigned long int)(location) + 4 + | 118 | value -= old_value; |
| 119 | locoffs; | 119 | #endif |
| 120 | value -= (unsigned long int)(location) + 4; | ||
| 120 | location[0] = (location[0] & 0xFFFF0000) | | 121 | location[0] = (location[0] & 0xFFFF0000) | |
| 121 | (value >> 16); | 122 | (value >> 16); |
| 122 | location[1] = (location[1] & 0xFFFF0000) | | 123 | location[1] = (location[1] & 0xFFFF0000) | |
| @@ -125,6 +126,14 @@ int apply_relocate_add(Elf32_Shdr *sechdrs, const char *strtab, | |||
| 125 | value); | 126 | value); |
| 126 | break; | 127 | break; |
| 127 | 128 | ||
| 129 | case R_MICROBLAZE_32_PCREL_LO: | ||
| 130 | pr_debug("R_MICROBLAZE_32_PCREL_LO\n"); | ||
| 131 | break; | ||
| 132 | |||
| 133 | case R_MICROBLAZE_64_NONE: | ||
| 134 | pr_debug("R_MICROBLAZE_NONE\n"); | ||
| 135 | break; | ||
| 136 | |||
| 128 | case R_MICROBLAZE_NONE: | 137 | case R_MICROBLAZE_NONE: |
| 129 | pr_debug("R_MICROBLAZE_NONE\n"); | 138 | pr_debug("R_MICROBLAZE_NONE\n"); |
| 130 | break; | 139 | break; |
| @@ -133,7 +142,7 @@ int apply_relocate_add(Elf32_Shdr *sechdrs, const char *strtab, | |||
| 133 | printk(KERN_ERR "module %s: " | 142 | printk(KERN_ERR "module %s: " |
| 134 | "Unknown relocation: %u\n", | 143 | "Unknown relocation: %u\n", |
| 135 | module->name, | 144 | module->name, |
| 136 | ELF32_R_TYPE(rela->r_info)); | 145 | ELF32_R_TYPE(rela[i].r_info)); |
| 137 | return -ENOEXEC; | 146 | return -ENOEXEC; |
| 138 | } | 147 | } |
| 139 | } | 148 | } |
diff --git a/arch/microblaze/kernel/setup.c b/arch/microblaze/kernel/setup.c index 8709bea09604..2a97bf513b64 100644 --- a/arch/microblaze/kernel/setup.c +++ b/arch/microblaze/kernel/setup.c | |||
| @@ -138,8 +138,12 @@ void __init machine_early_init(const char *cmdline, unsigned int ram, | |||
| 138 | setup_early_printk(NULL); | 138 | setup_early_printk(NULL); |
| 139 | #endif | 139 | #endif |
| 140 | 140 | ||
| 141 | early_printk("Ramdisk addr 0x%08x, FDT 0x%08x\n", ram, fdt); | 141 | early_printk("Ramdisk addr 0x%08x, ", ram); |
| 142 | printk(KERN_NOTICE "Found FDT at 0x%08x\n", fdt); | 142 | if (fdt) |
| 143 | early_printk("FDT at 0x%08x\n", fdt); | ||
| 144 | else | ||
| 145 | early_printk("Compiled-in FDT at 0x%08x\n", | ||
| 146 | (unsigned int)_fdt_start); | ||
| 143 | 147 | ||
| 144 | #ifdef CONFIG_MTD_UCLINUX | 148 | #ifdef CONFIG_MTD_UCLINUX |
| 145 | early_printk("Found romfs @ 0x%08x (0x%08x)\n", | 149 | early_printk("Found romfs @ 0x%08x (0x%08x)\n", |
diff --git a/arch/microblaze/kernel/sys_microblaze.c b/arch/microblaze/kernel/sys_microblaze.c index e000bce09b2b..b96f1682bb24 100644 --- a/arch/microblaze/kernel/sys_microblaze.c +++ b/arch/microblaze/kernel/sys_microblaze.c | |||
| @@ -33,105 +33,6 @@ | |||
| 33 | #include <linux/unistd.h> | 33 | #include <linux/unistd.h> |
| 34 | 34 | ||
| 35 | #include <asm/syscalls.h> | 35 | #include <asm/syscalls.h> |
| 36 | /* | ||
| 37 | * sys_ipc() is the de-multiplexer for the SysV IPC calls.. | ||
| 38 | * | ||
| 39 | * This is really horribly ugly. This will be remove with new toolchain. | ||
| 40 | */ | ||
| 41 | asmlinkage long | ||
| 42 | sys_ipc(uint call, int first, int second, int third, void *ptr, long fifth) | ||
| 43 | { | ||
| 44 | int version, ret; | ||
| 45 | |||
| 46 | version = call >> 16; /* hack for backward compatibility */ | ||
| 47 | call &= 0xffff; | ||
| 48 | |||
| 49 | ret = -EINVAL; | ||
| 50 | switch (call) { | ||
| 51 | case SEMOP: | ||
| 52 | ret = sys_semop(first, (struct sembuf *)ptr, second); | ||
| 53 | break; | ||
| 54 | case SEMGET: | ||
| 55 | ret = sys_semget(first, second, third); | ||
| 56 | break; | ||
| 57 | case SEMCTL: | ||
| 58 | { | ||
| 59 | union semun fourth; | ||
| 60 | |||
| 61 | if (!ptr) | ||
| 62 | break; | ||
| 63 | ret = (access_ok(VERIFY_READ, ptr, sizeof(long)) ? 0 : -EFAULT) | ||
| 64 | || (get_user(fourth.__pad, (void **)ptr)) ; | ||
| 65 | if (ret) | ||
| 66 | break; | ||
| 67 | ret = sys_semctl(first, second, third, fourth); | ||
| 68 | break; | ||
| 69 | } | ||
| 70 | case MSGSND: | ||
| 71 | ret = sys_msgsnd(first, (struct msgbuf *) ptr, second, third); | ||
| 72 | break; | ||
| 73 | case MSGRCV: | ||
| 74 | switch (version) { | ||
| 75 | case 0: { | ||
| 76 | struct ipc_kludge tmp; | ||
| 77 | |||
| 78 | if (!ptr) | ||
| 79 | break; | ||
| 80 | ret = (access_ok(VERIFY_READ, ptr, sizeof(tmp)) | ||
| 81 | ? 0 : -EFAULT) || copy_from_user(&tmp, | ||
| 82 | (struct ipc_kludge *) ptr, sizeof(tmp)); | ||
| 83 | if (ret) | ||
| 84 | break; | ||
| 85 | ret = sys_msgrcv(first, tmp.msgp, second, tmp.msgtyp, | ||
| 86 | third); | ||
| 87 | break; | ||
| 88 | } | ||
| 89 | default: | ||
| 90 | ret = sys_msgrcv(first, (struct msgbuf *) ptr, | ||
| 91 | second, fifth, third); | ||
| 92 | break; | ||
| 93 | } | ||
| 94 | break; | ||
| 95 | case MSGGET: | ||
| 96 | ret = sys_msgget((key_t) first, second); | ||
| 97 | break; | ||
| 98 | case MSGCTL: | ||
| 99 | ret = sys_msgctl(first, second, (struct msqid_ds *) ptr); | ||
| 100 | break; | ||
| 101 | case SHMAT: | ||
| 102 | switch (version) { | ||
| 103 | default: { | ||
| 104 | ulong raddr; | ||
| 105 | ret = access_ok(VERIFY_WRITE, (ulong *) third, | ||
| 106 | sizeof(ulong)) ? 0 : -EFAULT; | ||
| 107 | if (ret) | ||
| 108 | break; | ||
| 109 | ret = do_shmat(first, (char *) ptr, second, &raddr); | ||
| 110 | if (ret) | ||
| 111 | break; | ||
| 112 | ret = put_user(raddr, (ulong *) third); | ||
| 113 | break; | ||
| 114 | } | ||
| 115 | case 1: /* iBCS2 emulator entry point */ | ||
| 116 | if (!segment_eq(get_fs(), get_ds())) | ||
| 117 | break; | ||
| 118 | ret = do_shmat(first, (char *) ptr, second, | ||
| 119 | (ulong *) third); | ||
| 120 | break; | ||
| 121 | } | ||
| 122 | break; | ||
| 123 | case SHMDT: | ||
| 124 | ret = sys_shmdt((char *)ptr); | ||
| 125 | break; | ||
| 126 | case SHMGET: | ||
| 127 | ret = sys_shmget(first, second, third); | ||
| 128 | break; | ||
| 129 | case SHMCTL: | ||
| 130 | ret = sys_shmctl(first, second, (struct shmid_ds *) ptr); | ||
| 131 | break; | ||
| 132 | } | ||
| 133 | return ret; | ||
| 134 | } | ||
| 135 | 36 | ||
| 136 | asmlinkage long microblaze_vfork(struct pt_regs *regs) | 37 | asmlinkage long microblaze_vfork(struct pt_regs *regs) |
| 137 | { | 38 | { |
diff --git a/arch/microblaze/kernel/syscall_table.S b/arch/microblaze/kernel/syscall_table.S index 31b32a6c5f4e..457216097dfd 100644 --- a/arch/microblaze/kernel/syscall_table.S +++ b/arch/microblaze/kernel/syscall_table.S | |||
| @@ -121,7 +121,7 @@ ENTRY(sys_call_table) | |||
| 121 | .long sys_wait4 | 121 | .long sys_wait4 |
| 122 | .long sys_swapoff /* 115 */ | 122 | .long sys_swapoff /* 115 */ |
| 123 | .long sys_sysinfo | 123 | .long sys_sysinfo |
| 124 | .long sys_ipc | 124 | .long sys_ni_syscall /* old sys_ipc */ |
| 125 | .long sys_fsync | 125 | .long sys_fsync |
| 126 | .long sys_ni_syscall /* sys_sigreturn_wrapper */ | 126 | .long sys_ni_syscall /* sys_sigreturn_wrapper */ |
| 127 | .long sys_clone /* 120 */ | 127 | .long sys_clone /* 120 */ |
| @@ -313,7 +313,7 @@ ENTRY(sys_call_table) | |||
| 313 | .long sys_fchmodat | 313 | .long sys_fchmodat |
| 314 | .long sys_faccessat | 314 | .long sys_faccessat |
| 315 | .long sys_ni_syscall /* pselect6 */ | 315 | .long sys_ni_syscall /* pselect6 */ |
| 316 | .long sys_ni_syscall /* sys_ppoll */ | 316 | .long sys_ppoll |
| 317 | .long sys_unshare /* 310 */ | 317 | .long sys_unshare /* 310 */ |
| 318 | .long sys_set_robust_list | 318 | .long sys_set_robust_list |
| 319 | .long sys_get_robust_list | 319 | .long sys_get_robust_list |
diff --git a/arch/microblaze/kernel/timer.c b/arch/microblaze/kernel/timer.c index bdfa2f9f0c81..5499deae7fa6 100644 --- a/arch/microblaze/kernel/timer.c +++ b/arch/microblaze/kernel/timer.c | |||
| @@ -22,6 +22,7 @@ | |||
| 22 | #include <linux/clocksource.h> | 22 | #include <linux/clocksource.h> |
| 23 | #include <linux/clockchips.h> | 23 | #include <linux/clockchips.h> |
| 24 | #include <linux/io.h> | 24 | #include <linux/io.h> |
| 25 | #include <linux/bug.h> | ||
| 25 | #include <asm/cpuinfo.h> | 26 | #include <asm/cpuinfo.h> |
| 26 | #include <asm/setup.h> | 27 | #include <asm/setup.h> |
| 27 | #include <asm/prom.h> | 28 | #include <asm/prom.h> |
| @@ -234,6 +235,7 @@ void __init time_init(void) | |||
| 234 | if (timer) | 235 | if (timer) |
| 235 | break; | 236 | break; |
| 236 | } | 237 | } |
| 238 | BUG_ON(!timer); | ||
| 237 | 239 | ||
| 238 | timer_baseaddr = *(int *) of_get_property(timer, "reg", NULL); | 240 | timer_baseaddr = *(int *) of_get_property(timer, "reg", NULL); |
| 239 | timer_baseaddr = (unsigned long) ioremap(timer_baseaddr, PAGE_SIZE); | 241 | timer_baseaddr = (unsigned long) ioremap(timer_baseaddr, PAGE_SIZE); |
diff --git a/arch/microblaze/mm/fault.c b/arch/microblaze/mm/fault.c index 956607a63f4c..d9d249a66ff2 100644 --- a/arch/microblaze/mm/fault.c +++ b/arch/microblaze/mm/fault.c | |||
| @@ -69,7 +69,7 @@ static int store_updates_sp(struct pt_regs *regs) | |||
| 69 | * It is called from do_page_fault above and from some of the procedures | 69 | * It is called from do_page_fault above and from some of the procedures |
| 70 | * in traps.c. | 70 | * in traps.c. |
| 71 | */ | 71 | */ |
| 72 | static void bad_page_fault(struct pt_regs *regs, unsigned long address, int sig) | 72 | void bad_page_fault(struct pt_regs *regs, unsigned long address, int sig) |
| 73 | { | 73 | { |
| 74 | const struct exception_table_entry *fixup; | 74 | const struct exception_table_entry *fixup; |
| 75 | /* MS: no context */ | 75 | /* MS: no context */ |
| @@ -122,15 +122,10 @@ void do_page_fault(struct pt_regs *regs, unsigned long address, | |||
| 122 | } | 122 | } |
| 123 | #endif /* CONFIG_KGDB */ | 123 | #endif /* CONFIG_KGDB */ |
| 124 | 124 | ||
| 125 | if (in_atomic() || mm == NULL) { | 125 | if (in_atomic() || !mm) { |
| 126 | /* FIXME */ | 126 | if (kernel_mode(regs)) |
| 127 | if (kernel_mode(regs)) { | 127 | goto bad_area_nosemaphore; |
| 128 | printk(KERN_EMERG | 128 | |
| 129 | "Page fault in kernel mode - Oooou!!! pid %d\n", | ||
| 130 | current->pid); | ||
| 131 | _exception(SIGSEGV, regs, code, address); | ||
| 132 | return; | ||
| 133 | } | ||
| 134 | /* in_atomic() in user mode is really bad, | 129 | /* in_atomic() in user mode is really bad, |
| 135 | as is current->mm == NULL. */ | 130 | as is current->mm == NULL. */ |
| 136 | printk(KERN_EMERG "Page fault in user mode with " | 131 | printk(KERN_EMERG "Page fault in user mode with " |
diff --git a/arch/microblaze/mm/init.c b/arch/microblaze/mm/init.c index 8d92c4efe9a4..f207f1a94dbc 100644 --- a/arch/microblaze/mm/init.c +++ b/arch/microblaze/mm/init.c | |||
| @@ -130,13 +130,13 @@ void __init setup_memory(void) | |||
| 130 | * (in case the address isn't page-aligned). | 130 | * (in case the address isn't page-aligned). |
| 131 | */ | 131 | */ |
| 132 | #ifndef CONFIG_MMU | 132 | #ifndef CONFIG_MMU |
| 133 | map_size = init_bootmem_node(NODE_DATA(0), PFN_UP(TOPHYS((u32)_end)), | 133 | map_size = init_bootmem_node(NODE_DATA(0), PFN_UP(TOPHYS((u32)klimit)), |
| 134 | min_low_pfn, max_low_pfn); | 134 | min_low_pfn, max_low_pfn); |
| 135 | #else | 135 | #else |
| 136 | map_size = init_bootmem_node(&contig_page_data, | 136 | map_size = init_bootmem_node(&contig_page_data, |
| 137 | PFN_UP(TOPHYS((u32)_end)), min_low_pfn, max_low_pfn); | 137 | PFN_UP(TOPHYS((u32)klimit)), min_low_pfn, max_low_pfn); |
| 138 | #endif | 138 | #endif |
| 139 | lmb_reserve(PFN_UP(TOPHYS((u32)_end)) << PAGE_SHIFT, map_size); | 139 | lmb_reserve(PFN_UP(TOPHYS((u32)klimit)) << PAGE_SHIFT, map_size); |
| 140 | 140 | ||
| 141 | /* free bootmem is whole main memory */ | 141 | /* free bootmem is whole main memory */ |
| 142 | free_bootmem(memory_start, memory_size); | 142 | free_bootmem(memory_start, memory_size); |
diff --git a/arch/mips/alchemy/mtx-1/platform.c b/arch/mips/alchemy/mtx-1/platform.c index 8b5914d1241f..e30e42add697 100644 --- a/arch/mips/alchemy/mtx-1/platform.c +++ b/arch/mips/alchemy/mtx-1/platform.c | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * MTX-1 platform devices registration | 2 | * MTX-1 platform devices registration |
| 3 | * | 3 | * |
| 4 | * Copyright (C) 2007, Florian Fainelli <florian@openwrt.org> | 4 | * Copyright (C) 2007-2009, Florian Fainelli <florian@openwrt.org> |
| 5 | * | 5 | * |
| 6 | * This program is free software; you can redistribute it and/or modify | 6 | * This program is free software; you can redistribute it and/or modify |
| 7 | * it under the terms of the GNU General Public License as published by | 7 | * it under the terms of the GNU General Public License as published by |
| @@ -142,7 +142,17 @@ static struct __initdata platform_device * mtx1_devs[] = { | |||
| 142 | 142 | ||
| 143 | static int __init mtx1_register_devices(void) | 143 | static int __init mtx1_register_devices(void) |
| 144 | { | 144 | { |
| 145 | gpio_direction_input(207); | 145 | int rc; |
| 146 | |||
| 147 | rc = gpio_request(mtx1_gpio_button[0].gpio, | ||
| 148 | mtx1_gpio_button[0].desc); | ||
| 149 | if (rc < 0) { | ||
| 150 | printk(KERN_INFO "mtx1: failed to request %d\n", | ||
| 151 | mtx1_gpio_button[0].gpio); | ||
| 152 | goto out; | ||
| 153 | } | ||
| 154 | gpio_direction_input(mtx1_gpio_button[0].gpio); | ||
| 155 | out: | ||
| 146 | return platform_add_devices(mtx1_devs, ARRAY_SIZE(mtx1_devs)); | 156 | return platform_add_devices(mtx1_devs, ARRAY_SIZE(mtx1_devs)); |
| 147 | } | 157 | } |
| 148 | 158 | ||
diff --git a/arch/mips/ar7/Makefile b/arch/mips/ar7/Makefile index 7435e44b3964..26bc5da18997 100644 --- a/arch/mips/ar7/Makefile +++ b/arch/mips/ar7/Makefile | |||
| @@ -8,3 +8,4 @@ obj-y := \ | |||
| 8 | platform.o \ | 8 | platform.o \ |
| 9 | gpio.o \ | 9 | gpio.o \ |
| 10 | clock.o | 10 | clock.o |
| 11 | EXTRA_CFLAGS += -Werror | ||
diff --git a/arch/mips/ar7/clock.c b/arch/mips/ar7/clock.c index 27dc6663f2fa..cc65c8eb391b 100644 --- a/arch/mips/ar7/clock.c +++ b/arch/mips/ar7/clock.c | |||
| @@ -264,19 +264,6 @@ static void __init tnetd7300_init_clocks(void) | |||
| 264 | iounmap(bootcr); | 264 | iounmap(bootcr); |
| 265 | } | 265 | } |
| 266 | 266 | ||
| 267 | static int tnetd7200_get_clock(int base, struct tnetd7200_clock *clock, | ||
| 268 | u32 *bootcr, u32 bus_clock) | ||
| 269 | { | ||
| 270 | int divisor = ((readl(&clock->prediv) & 0x1f) + 1) * | ||
| 271 | ((readl(&clock->postdiv) & 0x1f) + 1); | ||
| 272 | |||
| 273 | if (*bootcr & BOOT_PLL_BYPASS) | ||
| 274 | return base / divisor; | ||
| 275 | |||
| 276 | return base * ((readl(&clock->mul) & 0xf) + 1) / divisor; | ||
| 277 | } | ||
| 278 | |||
| 279 | |||
| 280 | static void tnetd7200_set_clock(int base, struct tnetd7200_clock *clock, | 267 | static void tnetd7200_set_clock(int base, struct tnetd7200_clock *clock, |
| 281 | int prediv, int postdiv, int postdiv2, int mul, u32 frequency) | 268 | int prediv, int postdiv, int postdiv2, int mul, u32 frequency) |
| 282 | { | 269 | { |
diff --git a/arch/mips/ar7/memory.c b/arch/mips/ar7/memory.c index 46fed44825a6..696c723dc6d4 100644 --- a/arch/mips/ar7/memory.c +++ b/arch/mips/ar7/memory.c | |||
| @@ -52,7 +52,7 @@ static int __init memsize(void) | |||
| 52 | size <<= 1; | 52 | size <<= 1; |
| 53 | } while (size < (64 << 20)); | 53 | } while (size < (64 << 20)); |
| 54 | 54 | ||
| 55 | writel(tmpaddr, &addr); | 55 | writel((u32)tmpaddr, &addr); |
| 56 | 56 | ||
| 57 | return size; | 57 | return size; |
| 58 | } | 58 | } |
diff --git a/arch/mips/ar7/platform.c b/arch/mips/ar7/platform.c index 542244961780..2ecab6155932 100644 --- a/arch/mips/ar7/platform.c +++ b/arch/mips/ar7/platform.c | |||
| @@ -28,7 +28,6 @@ | |||
| 28 | #include <linux/serial_8250.h> | 28 | #include <linux/serial_8250.h> |
| 29 | #include <linux/ioport.h> | 29 | #include <linux/ioport.h> |
| 30 | #include <linux/io.h> | 30 | #include <linux/io.h> |
| 31 | #include <linux/version.h> | ||
| 32 | #include <linux/vlynq.h> | 31 | #include <linux/vlynq.h> |
| 33 | #include <linux/leds.h> | 32 | #include <linux/leds.h> |
| 34 | #include <linux/string.h> | 33 | #include <linux/string.h> |
| @@ -243,13 +242,13 @@ static struct platform_device physmap_flash = { | |||
| 243 | .num_resources = 1, | 242 | .num_resources = 1, |
| 244 | }; | 243 | }; |
| 245 | 244 | ||
| 246 | static u64 cpmac_dma_mask = DMA_32BIT_MASK; | 245 | static u64 cpmac_dma_mask = DMA_BIT_MASK(32); |
| 247 | static struct platform_device cpmac_low = { | 246 | static struct platform_device cpmac_low = { |
| 248 | .id = 0, | 247 | .id = 0, |
| 249 | .name = "cpmac", | 248 | .name = "cpmac", |
| 250 | .dev = { | 249 | .dev = { |
| 251 | .dma_mask = &cpmac_dma_mask, | 250 | .dma_mask = &cpmac_dma_mask, |
| 252 | .coherent_dma_mask = DMA_32BIT_MASK, | 251 | .coherent_dma_mask = DMA_BIT_MASK(32), |
| 253 | .platform_data = &cpmac_low_data, | 252 | .platform_data = &cpmac_low_data, |
| 254 | }, | 253 | }, |
| 255 | .resource = cpmac_low_res, | 254 | .resource = cpmac_low_res, |
| @@ -261,7 +260,7 @@ static struct platform_device cpmac_high = { | |||
| 261 | .name = "cpmac", | 260 | .name = "cpmac", |
| 262 | .dev = { | 261 | .dev = { |
| 263 | .dma_mask = &cpmac_dma_mask, | 262 | .dma_mask = &cpmac_dma_mask, |
| 264 | .coherent_dma_mask = DMA_32BIT_MASK, | 263 | .coherent_dma_mask = DMA_BIT_MASK(32), |
| 265 | .platform_data = &cpmac_high_data, | 264 | .platform_data = &cpmac_high_data, |
| 266 | }, | 265 | }, |
| 267 | .resource = cpmac_high_res, | 266 | .resource = cpmac_high_res, |
| @@ -481,6 +480,7 @@ static void __init detect_leds(void) | |||
| 481 | static int __init ar7_register_devices(void) | 480 | static int __init ar7_register_devices(void) |
| 482 | { | 481 | { |
| 483 | int res; | 482 | int res; |
| 483 | #ifdef CONFIG_SERIAL_8250 | ||
| 484 | static struct uart_port uart_port[2]; | 484 | static struct uart_port uart_port[2]; |
| 485 | 485 | ||
| 486 | memset(uart_port, 0, sizeof(struct uart_port) * 2); | 486 | memset(uart_port, 0, sizeof(struct uart_port) * 2); |
| @@ -512,7 +512,7 @@ static int __init ar7_register_devices(void) | |||
| 512 | if (res) | 512 | if (res) |
| 513 | return res; | 513 | return res; |
| 514 | } | 514 | } |
| 515 | 515 | #endif /* CONFIG_SERIAL_8250 */ | |
| 516 | res = platform_device_register(&physmap_flash); | 516 | res = platform_device_register(&physmap_flash); |
| 517 | if (res) | 517 | if (res) |
| 518 | return res; | 518 | return res; |
diff --git a/arch/mips/ar7/prom.c b/arch/mips/ar7/prom.c index a320bceb2f9d..5ad6f1db6567 100644 --- a/arch/mips/ar7/prom.c +++ b/arch/mips/ar7/prom.c | |||
| @@ -144,7 +144,7 @@ static char * __init lookup_psp_var_map(u8 num) | |||
| 144 | { | 144 | { |
| 145 | int i; | 145 | int i; |
| 146 | 146 | ||
| 147 | for (i = 0; i < sizeof(psp_var_map); i++) | 147 | for (i = 0; i < ARRAY_SIZE(psp_var_map); i++) |
| 148 | if (psp_var_map[i].num == num) | 148 | if (psp_var_map[i].num == num) |
| 149 | return psp_var_map[i].value; | 149 | return psp_var_map[i].value; |
| 150 | 150 | ||
diff --git a/arch/mips/ar7/setup.c b/arch/mips/ar7/setup.c index 6ebb5f16d967..39f6b5b96463 100644 --- a/arch/mips/ar7/setup.c +++ b/arch/mips/ar7/setup.c | |||
| @@ -15,7 +15,6 @@ | |||
| 15 | * with this program; if not, write to the Free Software Foundation, Inc., | 15 | * with this program; if not, write to the Free Software Foundation, Inc., |
| 16 | * 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. | 16 | * 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. |
| 17 | */ | 17 | */ |
| 18 | #include <linux/version.h> | ||
| 19 | #include <linux/init.h> | 18 | #include <linux/init.h> |
| 20 | #include <linux/ioport.h> | 19 | #include <linux/ioport.h> |
| 21 | #include <linux/pm.h> | 20 | #include <linux/pm.h> |
diff --git a/arch/mips/cavium-octeon/smp.c b/arch/mips/cavium-octeon/smp.c index 0b891a9c6253..32d51a31dc48 100644 --- a/arch/mips/cavium-octeon/smp.c +++ b/arch/mips/cavium-octeon/smp.c | |||
| @@ -194,11 +194,11 @@ static void octeon_init_secondary(void) | |||
| 194 | void octeon_prepare_cpus(unsigned int max_cpus) | 194 | void octeon_prepare_cpus(unsigned int max_cpus) |
| 195 | { | 195 | { |
| 196 | cvmx_write_csr(CVMX_CIU_MBOX_CLRX(cvmx_get_core_num()), 0xffffffff); | 196 | cvmx_write_csr(CVMX_CIU_MBOX_CLRX(cvmx_get_core_num()), 0xffffffff); |
| 197 | if (request_irq(OCTEON_IRQ_MBOX0, mailbox_interrupt, IRQF_SHARED, | 197 | if (request_irq(OCTEON_IRQ_MBOX0, mailbox_interrupt, IRQF_DISABLED, |
| 198 | "mailbox0", mailbox_interrupt)) { | 198 | "mailbox0", mailbox_interrupt)) { |
| 199 | panic("Cannot request_irq(OCTEON_IRQ_MBOX0)\n"); | 199 | panic("Cannot request_irq(OCTEON_IRQ_MBOX0)\n"); |
| 200 | } | 200 | } |
| 201 | if (request_irq(OCTEON_IRQ_MBOX1, mailbox_interrupt, IRQF_SHARED, | 201 | if (request_irq(OCTEON_IRQ_MBOX1, mailbox_interrupt, IRQF_DISABLED, |
| 202 | "mailbox1", mailbox_interrupt)) { | 202 | "mailbox1", mailbox_interrupt)) { |
| 203 | panic("Cannot request_irq(OCTEON_IRQ_MBOX1)\n"); | 203 | panic("Cannot request_irq(OCTEON_IRQ_MBOX1)\n"); |
| 204 | } | 204 | } |
diff --git a/arch/mips/dec/ecc-berr.c b/arch/mips/dec/ecc-berr.c index 6a17c9b508ea..7abce661b90f 100644 --- a/arch/mips/dec/ecc-berr.c +++ b/arch/mips/dec/ecc-berr.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/arch/mips/dec/ecc-berr.c | ||
| 3 | * | ||
| 4 | * Bus error event handling code for systems equipped with ECC | 2 | * Bus error event handling code for systems equipped with ECC |
| 5 | * handling logic, i.e. DECstation/DECsystem 5000/200 (KN02), | 3 | * handling logic, i.e. DECstation/DECsystem 5000/200 (KN02), |
| 6 | * 5000/240 (KN03), 5000/260 (KN05) and DECsystem 5900 (KN03), | 4 | * 5000/240 (KN03), 5000/260 (KN05) and DECsystem 5900 (KN03), |
diff --git a/arch/mips/dec/int-handler.S b/arch/mips/dec/int-handler.S index 00cecdcc75f2..82c852818781 100644 --- a/arch/mips/dec/int-handler.S +++ b/arch/mips/dec/int-handler.S | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/dec/int-handler.S | ||
| 3 | * | ||
| 4 | * Copyright (C) 1995, 1996, 1997 Paul M. Antoine and Harald Koerfgen | 2 | * Copyright (C) 1995, 1996, 1997 Paul M. Antoine and Harald Koerfgen |
| 5 | * Copyright (C) 2000, 2001, 2002, 2003, 2005 Maciej W. Rozycki | 3 | * Copyright (C) 2000, 2001, 2002, 2003, 2005 Maciej W. Rozycki |
| 6 | * | 4 | * |
diff --git a/arch/mips/dec/ioasic-irq.c b/arch/mips/dec/ioasic-irq.c index 3acb133668dc..cb41954fc321 100644 --- a/arch/mips/dec/ioasic-irq.c +++ b/arch/mips/dec/ioasic-irq.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/arch/mips/dec/ioasic-irq.c | ||
| 3 | * | ||
| 4 | * DEC I/O ASIC interrupts. | 2 | * DEC I/O ASIC interrupts. |
| 5 | * | 3 | * |
| 6 | * Copyright (c) 2002, 2003 Maciej W. Rozycki | 4 | * Copyright (c) 2002, 2003 Maciej W. Rozycki |
diff --git a/arch/mips/dec/kn01-berr.c b/arch/mips/dec/kn01-berr.c index d3b8002bf1e7..b0dc6d53edd6 100644 --- a/arch/mips/dec/kn01-berr.c +++ b/arch/mips/dec/kn01-berr.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/arch/mips/dec/kn01-berr.c | ||
| 3 | * | ||
| 4 | * Bus error event handling code for DECstation/DECsystem 3100 | 2 | * Bus error event handling code for DECstation/DECsystem 3100 |
| 5 | * and 2100 (KN01) systems equipped with parity error detection | 3 | * and 2100 (KN01) systems equipped with parity error detection |
| 6 | * logic. | 4 | * logic. |
diff --git a/arch/mips/dec/kn02-irq.c b/arch/mips/dec/kn02-irq.c index 02439dc0ba83..ed90a8deabcc 100644 --- a/arch/mips/dec/kn02-irq.c +++ b/arch/mips/dec/kn02-irq.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/arch/mips/dec/kn02-irq.c | ||
| 3 | * | ||
| 4 | * DECstation 5000/200 (KN02) Control and Status Register | 2 | * DECstation 5000/200 (KN02) Control and Status Register |
| 5 | * interrupts. | 3 | * interrupts. |
| 6 | * | 4 | * |
diff --git a/arch/mips/dec/kn02xa-berr.c b/arch/mips/dec/kn02xa-berr.c index 5f04545c3606..07ca5405d48d 100644 --- a/arch/mips/dec/kn02xa-berr.c +++ b/arch/mips/dec/kn02xa-berr.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/arch/mips/dec/kn02xa-berr.c | ||
| 3 | * | ||
| 4 | * Bus error event handling code for 5000-series systems equipped | 2 | * Bus error event handling code for 5000-series systems equipped |
| 5 | * with parity error detection logic, i.e. DECstation/DECsystem | 3 | * with parity error detection logic, i.e. DECstation/DECsystem |
| 6 | * 5000/120, /125, /133 (KN02-BA), 5000/150 (KN04-BA) and Personal | 4 | * 5000/120, /125, /133 (KN02-BA), 5000/150 (KN04-BA) and Personal |
diff --git a/arch/mips/dec/prom/call_o32.S b/arch/mips/dec/prom/call_o32.S index e523454bda3a..8c8498159e43 100644 --- a/arch/mips/dec/prom/call_o32.S +++ b/arch/mips/dec/prom/call_o32.S | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/dec/prom/call_o32.S | ||
| 3 | * | ||
| 4 | * O32 interface for the 64 (or N32) ABI. | 2 | * O32 interface for the 64 (or N32) ABI. |
| 5 | * | 3 | * |
| 6 | * Copyright (C) 2002 Maciej W. Rozycki | 4 | * Copyright (C) 2002 Maciej W. Rozycki |
diff --git a/arch/mips/dec/prom/console.c b/arch/mips/dec/prom/console.c index 078e1a12421d..caa6e047caf1 100644 --- a/arch/mips/dec/prom/console.c +++ b/arch/mips/dec/prom/console.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/dec/prom/console.c | ||
| 3 | * | ||
| 4 | * DECstation PROM-based early console support. | 2 | * DECstation PROM-based early console support. |
| 5 | * | 3 | * |
| 6 | * Copyright (C) 2004, 2007 Maciej W. Rozycki | 4 | * Copyright (C) 2004, 2007 Maciej W. Rozycki |
diff --git a/arch/mips/dec/time.c b/arch/mips/dec/time.c index 1359c03ded51..463136e6685a 100644 --- a/arch/mips/dec/time.c +++ b/arch/mips/dec/time.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/arch/mips/dec/time.c | ||
| 3 | * | ||
| 4 | * Copyright (C) 1991, 1992, 1995 Linus Torvalds | 2 | * Copyright (C) 1991, 1992, 1995 Linus Torvalds |
| 5 | * Copyright (C) 2000, 2003 Maciej W. Rozycki | 3 | * Copyright (C) 2000, 2003 Maciej W. Rozycki |
| 6 | * | 4 | * |
diff --git a/arch/mips/emma/common/Makefile b/arch/mips/emma/common/Makefile index c392d28c1ef1..f27d84d1904f 100644 --- a/arch/mips/emma/common/Makefile +++ b/arch/mips/emma/common/Makefile | |||
| @@ -1,7 +1,4 @@ | |||
| 1 | # | 1 | # |
| 2 | # arch/mips/emma2rh/common/Makefile | ||
| 3 | # Makefile for the common code of NEC EMMA2RH based board. | ||
| 4 | # | ||
| 5 | # Copyright (C) NEC Electronics Corporation 2005-2006 | 2 | # Copyright (C) NEC Electronics Corporation 2005-2006 |
| 6 | # | 3 | # |
| 7 | # This program is free software; you can redistribute it and/or modify | 4 | # This program is free software; you can redistribute it and/or modify |
diff --git a/arch/mips/emma/common/prom.c b/arch/mips/emma/common/prom.c index 120f53fbdb45..708f08761406 100644 --- a/arch/mips/emma/common/prom.c +++ b/arch/mips/emma/common/prom.c | |||
| @@ -1,7 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/emma2rh/common/prom.c | ||
| 3 | * This file is prom file. | ||
| 4 | * | ||
| 5 | * Copyright (C) NEC Electronics Corporation 2004-2006 | 2 | * Copyright (C) NEC Electronics Corporation 2004-2006 |
| 6 | * | 3 | * |
| 7 | * This file is based on the arch/mips/ddb5xxx/common/prom.c | 4 | * This file is based on the arch/mips/ddb5xxx/common/prom.c |
diff --git a/arch/mips/emma/markeins/Makefile b/arch/mips/emma/markeins/Makefile index 16e0017ba919..f8ba2508fa2b 100644 --- a/arch/mips/emma/markeins/Makefile +++ b/arch/mips/emma/markeins/Makefile | |||
| @@ -1,7 +1,4 @@ | |||
| 1 | # | 1 | # |
| 2 | # arch/mips/emma2rh/markeins/Makefile | ||
| 3 | # Makefile for the common code of NEC EMMA2RH based board. | ||
| 4 | # | ||
| 5 | # Copyright (C) NEC Electronics Corporation 2005-2006 | 2 | # Copyright (C) NEC Electronics Corporation 2005-2006 |
| 6 | # | 3 | # |
| 7 | # This program is free software; you can redistribute it and/or modify | 4 | # This program is free software; you can redistribute it and/or modify |
diff --git a/arch/mips/emma/markeins/irq.c b/arch/mips/emma/markeins/irq.c index 43828ae796ec..9504b7ee0b7c 100644 --- a/arch/mips/emma/markeins/irq.c +++ b/arch/mips/emma/markeins/irq.c | |||
| @@ -1,7 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/emma2rh/markeins/irq.c | ||
| 3 | * This file defines the irq handler for EMMA2RH. | ||
| 4 | * | ||
| 5 | * Copyright (C) NEC Electronics Corporation 2004-2006 | 2 | * Copyright (C) NEC Electronics Corporation 2004-2006 |
| 6 | * | 3 | * |
| 7 | * This file is based on the arch/mips/ddb5xxx/ddb5477/irq.c | 4 | * This file is based on the arch/mips/ddb5xxx/ddb5477/irq.c |
diff --git a/arch/mips/emma/markeins/led.c b/arch/mips/emma/markeins/led.c index 377a181b6561..49755896857f 100644 --- a/arch/mips/emma/markeins/led.c +++ b/arch/mips/emma/markeins/led.c | |||
| @@ -1,7 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/emma2rh/markeins/led.c | ||
| 3 | * This file defines the led display for Mark-eins. | ||
| 4 | * | ||
| 5 | * Copyright (C) NEC Electronics Corporation 2004-2006 | 2 | * Copyright (C) NEC Electronics Corporation 2004-2006 |
| 6 | * | 3 | * |
| 7 | * This program is free software; you can redistribute it and/or modify | 4 | * This program is free software; you can redistribute it and/or modify |
diff --git a/arch/mips/emma/markeins/platform.c b/arch/mips/emma/markeins/platform.c index 80ae12ef87db..b05b08b92a34 100644 --- a/arch/mips/emma/markeins/platform.c +++ b/arch/mips/emma/markeins/platform.c | |||
| @@ -1,7 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/emma2rh/markeins/platofrm.c | ||
| 3 | * This file sets up platform devices for EMMA2RH Mark-eins. | ||
| 4 | * | ||
| 5 | * Copyright(C) MontaVista Software Inc, 2006 | 2 | * Copyright(C) MontaVista Software Inc, 2006 |
| 6 | * | 3 | * |
| 7 | * Author: dmitry pervushin <dpervushin@ru.mvista.com> | 4 | * Author: dmitry pervushin <dpervushin@ru.mvista.com> |
diff --git a/arch/mips/emma/markeins/setup.c b/arch/mips/emma/markeins/setup.c index 67f456500084..335dc8c1a1bb 100644 --- a/arch/mips/emma/markeins/setup.c +++ b/arch/mips/emma/markeins/setup.c | |||
| @@ -1,7 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/emma2rh/markeins/setup.c | ||
| 3 | * This file is setup for EMMA2RH Mark-eins. | ||
| 4 | * | ||
| 5 | * Copyright (C) NEC Electronics Corporation 2004-2006 | 2 | * Copyright (C) NEC Electronics Corporation 2004-2006 |
| 6 | * | 3 | * |
| 7 | * This file is based on the arch/mips/ddb5xxx/ddb5477/setup.c. | 4 | * This file is based on the arch/mips/ddb5xxx/ddb5477/setup.c. |
diff --git a/arch/mips/fw/lib/call_o32.S b/arch/mips/fw/lib/call_o32.S index bdf7d1d4081a..e0a68713b3c3 100644 --- a/arch/mips/fw/lib/call_o32.S +++ b/arch/mips/fw/lib/call_o32.S | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/dec/prom/call_o32.S | ||
| 3 | * | ||
| 4 | * O32 interface for the 64 (or N32) ABI. | 2 | * O32 interface for the 64 (or N32) ABI. |
| 5 | * | 3 | * |
| 6 | * Copyright (C) 2002 Maciej W. Rozycki | 4 | * Copyright (C) 2002 Maciej W. Rozycki |
diff --git a/arch/mips/include/asm/emma/emma2rh.h b/arch/mips/include/asm/emma/emma2rh.h index 30aea91de626..2afb2fe11b30 100644 --- a/arch/mips/include/asm/emma/emma2rh.h +++ b/arch/mips/include/asm/emma/emma2rh.h | |||
| @@ -1,7 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/include/asm/emma/emma2rh.h | ||
| 3 | * This file is EMMA2RH common header. | ||
| 4 | * | ||
| 5 | * Copyright (C) NEC Electronics Corporation 2005-2006 | 2 | * Copyright (C) NEC Electronics Corporation 2005-2006 |
| 6 | * | 3 | * |
| 7 | * This file based on include/asm-mips/ddb5xxx/ddb5xxx.h | 4 | * This file based on include/asm-mips/ddb5xxx/ddb5xxx.h |
diff --git a/arch/mips/include/asm/emma/markeins.h b/arch/mips/include/asm/emma/markeins.h index 973b0628490d..2618bf230248 100644 --- a/arch/mips/include/asm/emma/markeins.h +++ b/arch/mips/include/asm/emma/markeins.h | |||
| @@ -1,7 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * include/asm-mips/emma2rh/markeins.h | ||
| 3 | * This file is EMMA2RH board depended header. | ||
| 4 | * | ||
| 5 | * Copyright (C) NEC Electronics Corporation 2005-2006 | 2 | * Copyright (C) NEC Electronics Corporation 2005-2006 |
| 6 | * | 3 | * |
| 7 | * This file based on include/asm-mips/ddb5xxx/ddb5xxx.h | 4 | * This file based on include/asm-mips/ddb5xxx/ddb5xxx.h |
diff --git a/arch/mips/include/asm/gic.h b/arch/mips/include/asm/gic.h index 10292e37c1f7..a8f57341f123 100644 --- a/arch/mips/include/asm/gic.h +++ b/arch/mips/include/asm/gic.h | |||
| @@ -20,7 +20,7 @@ | |||
| 20 | #define GIC_TRIG_EDGE 1 | 20 | #define GIC_TRIG_EDGE 1 |
| 21 | #define GIC_TRIG_LEVEL 0 | 21 | #define GIC_TRIG_LEVEL 0 |
| 22 | 22 | ||
| 23 | #if CONFIG_SMP | 23 | #ifdef CONFIG_SMP |
| 24 | #define GIC_NUM_INTRS (24 + NR_CPUS * 2) | 24 | #define GIC_NUM_INTRS (24 + NR_CPUS * 2) |
| 25 | #else | 25 | #else |
| 26 | #define GIC_NUM_INTRS 32 | 26 | #define GIC_NUM_INTRS 32 |
diff --git a/arch/mips/include/asm/page.h b/arch/mips/include/asm/page.h index 96a14a426a7c..4320239cf4ef 100644 --- a/arch/mips/include/asm/page.h +++ b/arch/mips/include/asm/page.h | |||
| @@ -32,10 +32,12 @@ | |||
| 32 | #define PAGE_SIZE (1UL << PAGE_SHIFT) | 32 | #define PAGE_SIZE (1UL << PAGE_SHIFT) |
| 33 | #define PAGE_MASK (~((1 << PAGE_SHIFT) - 1)) | 33 | #define PAGE_MASK (~((1 << PAGE_SHIFT) - 1)) |
| 34 | 34 | ||
| 35 | #ifdef CONFIG_HUGETLB_PAGE | ||
| 35 | #define HPAGE_SHIFT (PAGE_SHIFT + PAGE_SHIFT - 3) | 36 | #define HPAGE_SHIFT (PAGE_SHIFT + PAGE_SHIFT - 3) |
| 36 | #define HPAGE_SIZE ((1UL) << HPAGE_SHIFT) | 37 | #define HPAGE_SIZE ((1UL) << HPAGE_SHIFT) |
| 37 | #define HPAGE_MASK (~(HPAGE_SIZE - 1)) | 38 | #define HPAGE_MASK (~(HPAGE_SIZE - 1)) |
| 38 | #define HUGETLB_PAGE_ORDER (HPAGE_SHIFT - PAGE_SHIFT) | 39 | #define HUGETLB_PAGE_ORDER (HPAGE_SHIFT - PAGE_SHIFT) |
| 40 | #endif /* CONFIG_HUGETLB_PAGE */ | ||
| 39 | 41 | ||
| 40 | #ifndef __ASSEMBLY__ | 42 | #ifndef __ASSEMBLY__ |
| 41 | 43 | ||
diff --git a/arch/mips/include/asm/pgalloc.h b/arch/mips/include/asm/pgalloc.h index 1275831dda29..3738f4b48cbd 100644 --- a/arch/mips/include/asm/pgalloc.h +++ b/arch/mips/include/asm/pgalloc.h | |||
| @@ -98,23 +98,12 @@ static inline void pte_free(struct mm_struct *mm, pgtable_t pte) | |||
| 98 | __free_pages(pte, PTE_ORDER); | 98 | __free_pages(pte, PTE_ORDER); |
| 99 | } | 99 | } |
| 100 | 100 | ||
| 101 | #define __pte_free_tlb(tlb,pte) \ | 101 | #define __pte_free_tlb(tlb,pte,address) \ |
| 102 | do { \ | 102 | do { \ |
| 103 | pgtable_page_dtor(pte); \ | 103 | pgtable_page_dtor(pte); \ |
| 104 | tlb_remove_page((tlb), pte); \ | 104 | tlb_remove_page((tlb), pte); \ |
| 105 | } while (0) | 105 | } while (0) |
| 106 | 106 | ||
| 107 | #ifdef CONFIG_32BIT | ||
| 108 | |||
| 109 | /* | ||
| 110 | * allocating and freeing a pmd is trivial: the 1-entry pmd is | ||
| 111 | * inside the pgd, so has no extra memory associated with it. | ||
| 112 | */ | ||
| 113 | #define pmd_free(mm, x) do { } while (0) | ||
| 114 | #define __pmd_free_tlb(tlb, x) do { } while (0) | ||
| 115 | |||
| 116 | #endif | ||
| 117 | |||
| 118 | #ifdef CONFIG_64BIT | 107 | #ifdef CONFIG_64BIT |
| 119 | 108 | ||
| 120 | static inline pmd_t *pmd_alloc_one(struct mm_struct *mm, unsigned long address) | 109 | static inline pmd_t *pmd_alloc_one(struct mm_struct *mm, unsigned long address) |
| @@ -132,7 +121,7 @@ static inline void pmd_free(struct mm_struct *mm, pmd_t *pmd) | |||
| 132 | free_pages((unsigned long)pmd, PMD_ORDER); | 121 | free_pages((unsigned long)pmd, PMD_ORDER); |
| 133 | } | 122 | } |
| 134 | 123 | ||
| 135 | #define __pmd_free_tlb(tlb, x) pmd_free((tlb)->mm, x) | 124 | #define __pmd_free_tlb(tlb, x, addr) pmd_free((tlb)->mm, x) |
| 136 | 125 | ||
| 137 | #endif | 126 | #endif |
| 138 | 127 | ||
diff --git a/arch/mips/include/asm/pmc-sierra/msp71xx/war.h b/arch/mips/include/asm/pmc-sierra/msp71xx/war.h index 0bf48fc1892b..9e2ee429c529 100644 --- a/arch/mips/include/asm/pmc-sierra/msp71xx/war.h +++ b/arch/mips/include/asm/pmc-sierra/msp71xx/war.h | |||
| @@ -23,6 +23,8 @@ | |||
| 23 | #if defined(CONFIG_PMC_MSP7120_EVAL) || defined(CONFIG_PMC_MSP7120_GW) || \ | 23 | #if defined(CONFIG_PMC_MSP7120_EVAL) || defined(CONFIG_PMC_MSP7120_GW) || \ |
| 24 | defined(CONFIG_PMC_MSP7120_FPGA) | 24 | defined(CONFIG_PMC_MSP7120_FPGA) |
| 25 | #define MIPS34K_MISSED_ITLB_WAR 1 | 25 | #define MIPS34K_MISSED_ITLB_WAR 1 |
| 26 | #else | ||
| 27 | #define MIPS34K_MISSED_ITLB_WAR 0 | ||
| 26 | #endif | 28 | #endif |
| 27 | 29 | ||
| 28 | #endif /* __ASM_MIPS_PMC_SIERRA_WAR_H */ | 30 | #endif /* __ASM_MIPS_PMC_SIERRA_WAR_H */ |
diff --git a/arch/mips/include/asm/processor.h b/arch/mips/include/asm/processor.h index 0f926aa0cb47..087a8884ef06 100644 --- a/arch/mips/include/asm/processor.h +++ b/arch/mips/include/asm/processor.h | |||
| @@ -311,8 +311,9 @@ extern void start_thread(struct pt_regs * regs, unsigned long pc, unsigned long | |||
| 311 | 311 | ||
| 312 | unsigned long get_wchan(struct task_struct *p); | 312 | unsigned long get_wchan(struct task_struct *p); |
| 313 | 313 | ||
| 314 | #define __KSTK_TOS(tsk) ((unsigned long)task_stack_page(tsk) + THREAD_SIZE - 32) | 314 | #define __KSTK_TOS(tsk) ((unsigned long)task_stack_page(tsk) + \ |
| 315 | #define task_pt_regs(tsk) ((struct pt_regs *)__KSTK_TOS(tsk) - 1) | 315 | THREAD_SIZE - 32 - sizeof(struct pt_regs)) |
| 316 | #define task_pt_regs(tsk) ((struct pt_regs *)__KSTK_TOS(tsk)) | ||
| 316 | #define KSTK_EIP(tsk) (task_pt_regs(tsk)->cp0_epc) | 317 | #define KSTK_EIP(tsk) (task_pt_regs(tsk)->cp0_epc) |
| 317 | #define KSTK_ESP(tsk) (task_pt_regs(tsk)->regs[29]) | 318 | #define KSTK_ESP(tsk) (task_pt_regs(tsk)->regs[29]) |
| 318 | #define KSTK_STATUS(tsk) (task_pt_regs(tsk)->cp0_status) | 319 | #define KSTK_STATUS(tsk) (task_pt_regs(tsk)->cp0_status) |
diff --git a/arch/mips/include/asm/unistd.h b/arch/mips/include/asm/unistd.h index b70c49fdda26..e753a777949b 100644 --- a/arch/mips/include/asm/unistd.h +++ b/arch/mips/include/asm/unistd.h | |||
| @@ -354,16 +354,17 @@ | |||
| 354 | #define __NR_pwritev (__NR_Linux + 331) | 354 | #define __NR_pwritev (__NR_Linux + 331) |
| 355 | #define __NR_rt_tgsigqueueinfo (__NR_Linux + 332) | 355 | #define __NR_rt_tgsigqueueinfo (__NR_Linux + 332) |
| 356 | #define __NR_perf_counter_open (__NR_Linux + 333) | 356 | #define __NR_perf_counter_open (__NR_Linux + 333) |
| 357 | #define __NR_accept4 (__NR_Linux + 334) | ||
| 357 | 358 | ||
| 358 | /* | 359 | /* |
| 359 | * Offset of the last Linux o32 flavoured syscall | 360 | * Offset of the last Linux o32 flavoured syscall |
| 360 | */ | 361 | */ |
| 361 | #define __NR_Linux_syscalls 333 | 362 | #define __NR_Linux_syscalls 334 |
| 362 | 363 | ||
| 363 | #endif /* _MIPS_SIM == _MIPS_SIM_ABI32 */ | 364 | #endif /* _MIPS_SIM == _MIPS_SIM_ABI32 */ |
| 364 | 365 | ||
| 365 | #define __NR_O32_Linux 4000 | 366 | #define __NR_O32_Linux 4000 |
| 366 | #define __NR_O32_Linux_syscalls 333 | 367 | #define __NR_O32_Linux_syscalls 334 |
| 367 | 368 | ||
| 368 | #if _MIPS_SIM == _MIPS_SIM_ABI64 | 369 | #if _MIPS_SIM == _MIPS_SIM_ABI64 |
| 369 | 370 | ||
| @@ -664,16 +665,17 @@ | |||
| 664 | #define __NR_pwritev (__NR_Linux + 290) | 665 | #define __NR_pwritev (__NR_Linux + 290) |
| 665 | #define __NR_rt_tgsigqueueinfo (__NR_Linux + 291) | 666 | #define __NR_rt_tgsigqueueinfo (__NR_Linux + 291) |
| 666 | #define __NR_perf_counter_open (__NR_Linux + 292) | 667 | #define __NR_perf_counter_open (__NR_Linux + 292) |
| 668 | #define __NR_accept4 (__NR_Linux + 293) | ||
| 667 | 669 | ||
| 668 | /* | 670 | /* |
| 669 | * Offset of the last Linux 64-bit flavoured syscall | 671 | * Offset of the last Linux 64-bit flavoured syscall |
| 670 | */ | 672 | */ |
| 671 | #define __NR_Linux_syscalls 292 | 673 | #define __NR_Linux_syscalls 293 |
| 672 | 674 | ||
| 673 | #endif /* _MIPS_SIM == _MIPS_SIM_ABI64 */ | 675 | #endif /* _MIPS_SIM == _MIPS_SIM_ABI64 */ |
| 674 | 676 | ||
| 675 | #define __NR_64_Linux 5000 | 677 | #define __NR_64_Linux 5000 |
| 676 | #define __NR_64_Linux_syscalls 292 | 678 | #define __NR_64_Linux_syscalls 293 |
| 677 | 679 | ||
| 678 | #if _MIPS_SIM == _MIPS_SIM_NABI32 | 680 | #if _MIPS_SIM == _MIPS_SIM_NABI32 |
| 679 | 681 | ||
| @@ -978,16 +980,17 @@ | |||
| 978 | #define __NR_pwritev (__NR_Linux + 294) | 980 | #define __NR_pwritev (__NR_Linux + 294) |
| 979 | #define __NR_rt_tgsigqueueinfo (__NR_Linux + 295) | 981 | #define __NR_rt_tgsigqueueinfo (__NR_Linux + 295) |
| 980 | #define __NR_perf_counter_open (__NR_Linux + 296) | 982 | #define __NR_perf_counter_open (__NR_Linux + 296) |
| 983 | #define __NR_accept4 (__NR_Linux + 297) | ||
| 981 | 984 | ||
| 982 | /* | 985 | /* |
| 983 | * Offset of the last N32 flavoured syscall | 986 | * Offset of the last N32 flavoured syscall |
| 984 | */ | 987 | */ |
| 985 | #define __NR_Linux_syscalls 296 | 988 | #define __NR_Linux_syscalls 297 |
| 986 | 989 | ||
| 987 | #endif /* _MIPS_SIM == _MIPS_SIM_NABI32 */ | 990 | #endif /* _MIPS_SIM == _MIPS_SIM_NABI32 */ |
| 988 | 991 | ||
| 989 | #define __NR_N32_Linux 6000 | 992 | #define __NR_N32_Linux 6000 |
| 990 | #define __NR_N32_Linux_syscalls 296 | 993 | #define __NR_N32_Linux_syscalls 297 |
| 991 | 994 | ||
| 992 | #ifdef __KERNEL__ | 995 | #ifdef __KERNEL__ |
| 993 | 996 | ||
diff --git a/arch/mips/jazz/jazzdma.c b/arch/mips/jazz/jazzdma.c index f0fd636723be..0d64d0f46418 100644 --- a/arch/mips/jazz/jazzdma.c +++ b/arch/mips/jazz/jazzdma.c | |||
| @@ -190,7 +190,7 @@ int vdma_free(unsigned long laddr) | |||
| 190 | return -1; | 190 | return -1; |
| 191 | } | 191 | } |
| 192 | 192 | ||
| 193 | while (pgtbl[i].owner == laddr && i < VDMA_PGTBL_ENTRIES) { | 193 | while (i < VDMA_PGTBL_ENTRIES && pgtbl[i].owner == laddr) { |
| 194 | pgtbl[i].owner = VDMA_PAGE_EMPTY; | 194 | pgtbl[i].owner = VDMA_PAGE_EMPTY; |
| 195 | i++; | 195 | i++; |
| 196 | } | 196 | } |
diff --git a/arch/mips/kernel/head.S b/arch/mips/kernel/head.S index 492a0a8d70fb..531ce7b16124 100644 --- a/arch/mips/kernel/head.S +++ b/arch/mips/kernel/head.S | |||
| @@ -188,7 +188,8 @@ NESTED(kernel_entry, 16, sp) # kernel entry point | |||
| 188 | 188 | ||
| 189 | MTC0 zero, CP0_CONTEXT # clear context register | 189 | MTC0 zero, CP0_CONTEXT # clear context register |
| 190 | PTR_LA $28, init_thread_union | 190 | PTR_LA $28, init_thread_union |
| 191 | PTR_LI sp, _THREAD_SIZE - 32 | 191 | /* Set the SP after an empty pt_regs. */ |
| 192 | PTR_LI sp, _THREAD_SIZE - 32 - PT_SIZE | ||
| 192 | PTR_ADDU sp, $28 | 193 | PTR_ADDU sp, $28 |
| 193 | set_saved_sp sp, t0, t1 | 194 | set_saved_sp sp, t0, t1 |
| 194 | PTR_SUBU sp, 4 * SZREG # init stack pointer | 195 | PTR_SUBU sp, 4 * SZREG # init stack pointer |
diff --git a/arch/mips/kernel/irq_txx9.c b/arch/mips/kernel/irq_txx9.c index a4d1462c27f7..9b78029bea70 100644 --- a/arch/mips/kernel/irq_txx9.c +++ b/arch/mips/kernel/irq_txx9.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/arch/mips/kernel/irq_txx9.c | ||
| 3 | * | ||
| 4 | * Based on linux/arch/mips/jmr3927/rbhma3100/irq.c, | 2 | * Based on linux/arch/mips/jmr3927/rbhma3100/irq.c, |
| 5 | * linux/arch/mips/tx4927/common/tx4927_irq.c, | 3 | * linux/arch/mips/tx4927/common/tx4927_irq.c, |
| 6 | * linux/arch/mips/tx4938/common/irq.c | 4 | * linux/arch/mips/tx4938/common/irq.c |
diff --git a/arch/mips/kernel/module.c b/arch/mips/kernel/module.c index 3e9100dcc12d..6f51dda87fce 100644 --- a/arch/mips/kernel/module.c +++ b/arch/mips/kernel/module.c | |||
| @@ -98,7 +98,8 @@ static int apply_r_mips_32_rela(struct module *me, u32 *location, Elf_Addr v) | |||
| 98 | static int apply_r_mips_26_rel(struct module *me, u32 *location, Elf_Addr v) | 98 | static int apply_r_mips_26_rel(struct module *me, u32 *location, Elf_Addr v) |
| 99 | { | 99 | { |
| 100 | if (v % 4) { | 100 | if (v % 4) { |
| 101 | printk(KERN_ERR "module %s: dangerous relocation\n", me->name); | 101 | pr_err("module %s: dangerous R_MIPS_26 REL relocation\n", |
| 102 | me->name); | ||
| 102 | return -ENOEXEC; | 103 | return -ENOEXEC; |
| 103 | } | 104 | } |
| 104 | 105 | ||
| @@ -118,7 +119,8 @@ static int apply_r_mips_26_rel(struct module *me, u32 *location, Elf_Addr v) | |||
| 118 | static int apply_r_mips_26_rela(struct module *me, u32 *location, Elf_Addr v) | 119 | static int apply_r_mips_26_rela(struct module *me, u32 *location, Elf_Addr v) |
| 119 | { | 120 | { |
| 120 | if (v % 4) { | 121 | if (v % 4) { |
| 121 | printk(KERN_ERR "module %s: dangerous relocation\n", me->name); | 122 | pr_err("module %s: dangerous R_MIPS_26 RELArelocation\n", |
| 123 | me->name); | ||
| 122 | return -ENOEXEC; | 124 | return -ENOEXEC; |
| 123 | } | 125 | } |
| 124 | 126 | ||
| @@ -222,7 +224,7 @@ static int apply_r_mips_lo16_rel(struct module *me, u32 *location, Elf_Addr v) | |||
| 222 | return 0; | 224 | return 0; |
| 223 | 225 | ||
| 224 | out_danger: | 226 | out_danger: |
| 225 | printk(KERN_ERR "module %s: dangerous " "relocation\n", me->name); | 227 | pr_err("module %s: dangerous R_MIPS_LO16 REL relocation\n", me->name); |
| 226 | 228 | ||
| 227 | return -ENOEXEC; | 229 | return -ENOEXEC; |
| 228 | } | 230 | } |
| @@ -301,7 +303,7 @@ int apply_relocate(Elf_Shdr *sechdrs, const char *strtab, | |||
| 301 | /* This is the symbol it is referring to */ | 303 | /* This is the symbol it is referring to */ |
| 302 | sym = (Elf_Sym *)sechdrs[symindex].sh_addr | 304 | sym = (Elf_Sym *)sechdrs[symindex].sh_addr |
| 303 | + ELF_MIPS_R_SYM(rel[i]); | 305 | + ELF_MIPS_R_SYM(rel[i]); |
| 304 | if (!sym->st_value) { | 306 | if (IS_ERR_VALUE(sym->st_value)) { |
| 305 | /* Ignore unresolved weak symbol */ | 307 | /* Ignore unresolved weak symbol */ |
| 306 | if (ELF_ST_BIND(sym->st_info) == STB_WEAK) | 308 | if (ELF_ST_BIND(sym->st_info) == STB_WEAK) |
| 307 | continue; | 309 | continue; |
| @@ -341,7 +343,7 @@ int apply_relocate_add(Elf_Shdr *sechdrs, const char *strtab, | |||
| 341 | /* This is the symbol it is referring to */ | 343 | /* This is the symbol it is referring to */ |
| 342 | sym = (Elf_Sym *)sechdrs[symindex].sh_addr | 344 | sym = (Elf_Sym *)sechdrs[symindex].sh_addr |
| 343 | + ELF_MIPS_R_SYM(rel[i]); | 345 | + ELF_MIPS_R_SYM(rel[i]); |
| 344 | if (!sym->st_value) { | 346 | if (IS_ERR_VALUE(sym->st_value)) { |
| 345 | /* Ignore unresolved weak symbol */ | 347 | /* Ignore unresolved weak symbol */ |
| 346 | if (ELF_ST_BIND(sym->st_info) == STB_WEAK) | 348 | if (ELF_ST_BIND(sym->st_info) == STB_WEAK) |
| 347 | continue; | 349 | continue; |
diff --git a/arch/mips/kernel/proc.c b/arch/mips/kernel/proc.c index e0a4ac18fa07..26109c4d5170 100644 --- a/arch/mips/kernel/proc.c +++ b/arch/mips/kernel/proc.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/arch/mips/kernel/proc.c | ||
| 3 | * | ||
| 4 | * Copyright (C) 1995, 1996, 2001 Ralf Baechle | 2 | * Copyright (C) 1995, 1996, 2001 Ralf Baechle |
| 5 | * Copyright (C) 2001, 2004 MIPS Technologies, Inc. | 3 | * Copyright (C) 2001, 2004 MIPS Technologies, Inc. |
| 6 | * Copyright (C) 2004 Maciej W. Rozycki | 4 | * Copyright (C) 2004 Maciej W. Rozycki |
diff --git a/arch/mips/kernel/process.c b/arch/mips/kernel/process.c index c09d681b7181..f3d73e1831c1 100644 --- a/arch/mips/kernel/process.c +++ b/arch/mips/kernel/process.c | |||
| @@ -115,7 +115,7 @@ int copy_thread(unsigned long clone_flags, unsigned long usp, | |||
| 115 | { | 115 | { |
| 116 | struct thread_info *ti = task_thread_info(p); | 116 | struct thread_info *ti = task_thread_info(p); |
| 117 | struct pt_regs *childregs; | 117 | struct pt_regs *childregs; |
| 118 | long childksp; | 118 | unsigned long childksp; |
| 119 | p->set_child_tid = p->clear_child_tid = NULL; | 119 | p->set_child_tid = p->clear_child_tid = NULL; |
| 120 | 120 | ||
| 121 | childksp = (unsigned long)task_stack_page(p) + THREAD_SIZE - 32; | 121 | childksp = (unsigned long)task_stack_page(p) + THREAD_SIZE - 32; |
| @@ -132,6 +132,8 @@ int copy_thread(unsigned long clone_flags, unsigned long usp, | |||
| 132 | 132 | ||
| 133 | /* set up new TSS. */ | 133 | /* set up new TSS. */ |
| 134 | childregs = (struct pt_regs *) childksp - 1; | 134 | childregs = (struct pt_regs *) childksp - 1; |
| 135 | /* Put the stack after the struct pt_regs. */ | ||
| 136 | childksp = (unsigned long) childregs; | ||
| 135 | *childregs = *regs; | 137 | *childregs = *regs; |
| 136 | childregs->regs[7] = 0; /* Clear error flag */ | 138 | childregs->regs[7] = 0; /* Clear error flag */ |
| 137 | 139 | ||
diff --git a/arch/mips/kernel/scall32-o32.S b/arch/mips/kernel/scall32-o32.S index 20a86e08fd58..b57082123536 100644 --- a/arch/mips/kernel/scall32-o32.S +++ b/arch/mips/kernel/scall32-o32.S | |||
| @@ -654,6 +654,7 @@ einval: li v0, -ENOSYS | |||
| 654 | sys sys_pwritev 6 | 654 | sys sys_pwritev 6 |
| 655 | sys sys_rt_tgsigqueueinfo 4 | 655 | sys sys_rt_tgsigqueueinfo 4 |
| 656 | sys sys_perf_counter_open 5 | 656 | sys sys_perf_counter_open 5 |
| 657 | sys sys_accept4 4 | ||
| 657 | .endm | 658 | .endm |
| 658 | 659 | ||
| 659 | /* We pre-compute the number of _instruction_ bytes needed to | 660 | /* We pre-compute the number of _instruction_ bytes needed to |
diff --git a/arch/mips/kernel/scall64-64.S b/arch/mips/kernel/scall64-64.S index b046130d4c5d..3d866f24e064 100644 --- a/arch/mips/kernel/scall64-64.S +++ b/arch/mips/kernel/scall64-64.S | |||
| @@ -491,4 +491,5 @@ sys_call_table: | |||
| 491 | PTR sys_pwritev /* 5390 */ | 491 | PTR sys_pwritev /* 5390 */ |
| 492 | PTR sys_rt_tgsigqueueinfo | 492 | PTR sys_rt_tgsigqueueinfo |
| 493 | PTR sys_perf_counter_open | 493 | PTR sys_perf_counter_open |
| 494 | PTR sys_accept4 | ||
| 494 | .size sys_call_table,.-sys_call_table | 495 | .size sys_call_table,.-sys_call_table |
diff --git a/arch/mips/kernel/scall64-n32.S b/arch/mips/kernel/scall64-n32.S index 15874f9812cc..e855b118a079 100644 --- a/arch/mips/kernel/scall64-n32.S +++ b/arch/mips/kernel/scall64-n32.S | |||
| @@ -417,4 +417,5 @@ EXPORT(sysn32_call_table) | |||
| 417 | PTR sys_pwritev | 417 | PTR sys_pwritev |
| 418 | PTR compat_sys_rt_tgsigqueueinfo /* 5295 */ | 418 | PTR compat_sys_rt_tgsigqueueinfo /* 5295 */ |
| 419 | PTR sys_perf_counter_open | 419 | PTR sys_perf_counter_open |
| 420 | PTR sys_accept4 | ||
| 420 | .size sysn32_call_table,.-sysn32_call_table | 421 | .size sysn32_call_table,.-sysn32_call_table |
diff --git a/arch/mips/kernel/scall64-o32.S b/arch/mips/kernel/scall64-o32.S index 781e0f1e9533..0c49f1a660be 100644 --- a/arch/mips/kernel/scall64-o32.S +++ b/arch/mips/kernel/scall64-o32.S | |||
| @@ -537,4 +537,5 @@ sys_call_table: | |||
| 537 | PTR compat_sys_pwritev | 537 | PTR compat_sys_pwritev |
| 538 | PTR compat_sys_rt_tgsigqueueinfo | 538 | PTR compat_sys_rt_tgsigqueueinfo |
| 539 | PTR sys_perf_counter_open | 539 | PTR sys_perf_counter_open |
| 540 | PTR sys_accept4 | ||
| 540 | .size sys_call_table,.-sys_call_table | 541 | .size sys_call_table,.-sys_call_table |
diff --git a/arch/mips/kernel/smtc.c b/arch/mips/kernel/smtc.c index 8a0626cbb108..c16bb6d6c25c 100644 --- a/arch/mips/kernel/smtc.c +++ b/arch/mips/kernel/smtc.c | |||
| @@ -465,11 +465,8 @@ void smtc_prepare_cpus(int cpus) | |||
| 465 | smtc_configure_tlb(); | 465 | smtc_configure_tlb(); |
| 466 | 466 | ||
| 467 | for (tc = 0, vpe = 0 ; (vpe < nvpe) && (tc < ntc) ; vpe++) { | 467 | for (tc = 0, vpe = 0 ; (vpe < nvpe) && (tc < ntc) ; vpe++) { |
| 468 | /* | 468 | if (tcpervpe[vpe] == 0) |
| 469 | * Set the MVP bits. | 469 | continue; |
| 470 | */ | ||
| 471 | settc(tc); | ||
| 472 | write_vpe_c0_vpeconf0(read_vpe_c0_vpeconf0() | VPECONF0_MVP); | ||
| 473 | if (vpe != 0) | 470 | if (vpe != 0) |
| 474 | printk(", "); | 471 | printk(", "); |
| 475 | printk("VPE %d: TC", vpe); | 472 | printk("VPE %d: TC", vpe); |
| @@ -488,6 +485,12 @@ void smtc_prepare_cpus(int cpus) | |||
| 488 | } | 485 | } |
| 489 | if (vpe != 0) { | 486 | if (vpe != 0) { |
| 490 | /* | 487 | /* |
| 488 | * Allow this VPE to control others. | ||
| 489 | */ | ||
| 490 | write_vpe_c0_vpeconf0(read_vpe_c0_vpeconf0() | | ||
| 491 | VPECONF0_MVP); | ||
| 492 | |||
| 493 | /* | ||
| 491 | * Clear any stale software interrupts from VPE's Cause | 494 | * Clear any stale software interrupts from VPE's Cause |
| 492 | */ | 495 | */ |
| 493 | write_vpe_c0_cause(0); | 496 | write_vpe_c0_cause(0); |
diff --git a/arch/mips/kernel/stacktrace.c b/arch/mips/kernel/stacktrace.c index 58f5cd76c8c3..d52ff77baf3f 100644 --- a/arch/mips/kernel/stacktrace.c +++ b/arch/mips/kernel/stacktrace.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/kernel/stacktrace.c | ||
| 3 | * | ||
| 4 | * Stack trace management functions | 2 | * Stack trace management functions |
| 5 | * | 3 | * |
| 6 | * Copyright (C) 2006 Atsushi Nemoto <anemo@mba.ocn.ne.jp> | 4 | * Copyright (C) 2006 Atsushi Nemoto <anemo@mba.ocn.ne.jp> |
diff --git a/arch/mips/kernel/vpe.c b/arch/mips/kernel/vpe.c index 07b9ec2c6e3d..9a1ab7e87fd4 100644 --- a/arch/mips/kernel/vpe.c +++ b/arch/mips/kernel/vpe.c | |||
| @@ -73,7 +73,7 @@ static int major; | |||
| 73 | static const int minor = 1; /* fixed for now */ | 73 | static const int minor = 1; /* fixed for now */ |
| 74 | 74 | ||
| 75 | #ifdef CONFIG_MIPS_APSP_KSPD | 75 | #ifdef CONFIG_MIPS_APSP_KSPD |
| 76 | static struct kspd_notifications kspd_events; | 76 | static struct kspd_notifications kspd_events; |
| 77 | static int kspd_events_reqd = 0; | 77 | static int kspd_events_reqd = 0; |
| 78 | #endif | 78 | #endif |
| 79 | 79 | ||
| @@ -155,10 +155,9 @@ struct { | |||
| 155 | }; | 155 | }; |
| 156 | 156 | ||
| 157 | static void release_progmem(void *ptr); | 157 | static void release_progmem(void *ptr); |
| 158 | extern void save_gp_address(unsigned int secbase, unsigned int rel); | ||
| 159 | 158 | ||
| 160 | /* get the vpe associated with this minor */ | 159 | /* get the vpe associated with this minor */ |
| 161 | struct vpe *get_vpe(int minor) | 160 | static struct vpe *get_vpe(int minor) |
| 162 | { | 161 | { |
| 163 | struct vpe *v; | 162 | struct vpe *v; |
| 164 | 163 | ||
| @@ -174,7 +173,7 @@ struct vpe *get_vpe(int minor) | |||
| 174 | } | 173 | } |
| 175 | 174 | ||
| 176 | /* get the vpe associated with this minor */ | 175 | /* get the vpe associated with this minor */ |
| 177 | struct tc *get_tc(int index) | 176 | static struct tc *get_tc(int index) |
| 178 | { | 177 | { |
| 179 | struct tc *t; | 178 | struct tc *t; |
| 180 | 179 | ||
| @@ -186,20 +185,8 @@ struct tc *get_tc(int index) | |||
| 186 | return NULL; | 185 | return NULL; |
| 187 | } | 186 | } |
| 188 | 187 | ||
| 189 | struct tc *get_tc_unused(void) | ||
| 190 | { | ||
| 191 | struct tc *t; | ||
| 192 | |||
| 193 | list_for_each_entry(t, &vpecontrol.tc_list, list) { | ||
| 194 | if (t->state == TC_STATE_UNUSED) | ||
| 195 | return t; | ||
| 196 | } | ||
| 197 | |||
| 198 | return NULL; | ||
| 199 | } | ||
| 200 | |||
| 201 | /* allocate a vpe and associate it with this minor (or index) */ | 188 | /* allocate a vpe and associate it with this minor (or index) */ |
| 202 | struct vpe *alloc_vpe(int minor) | 189 | static struct vpe *alloc_vpe(int minor) |
| 203 | { | 190 | { |
| 204 | struct vpe *v; | 191 | struct vpe *v; |
| 205 | 192 | ||
| @@ -216,7 +203,7 @@ struct vpe *alloc_vpe(int minor) | |||
| 216 | } | 203 | } |
| 217 | 204 | ||
| 218 | /* allocate a tc. At startup only tc0 is running, all other can be halted. */ | 205 | /* allocate a tc. At startup only tc0 is running, all other can be halted. */ |
| 219 | struct tc *alloc_tc(int index) | 206 | static struct tc *alloc_tc(int index) |
| 220 | { | 207 | { |
| 221 | struct tc *tc; | 208 | struct tc *tc; |
| 222 | 209 | ||
| @@ -232,7 +219,7 @@ out: | |||
| 232 | } | 219 | } |
| 233 | 220 | ||
| 234 | /* clean up and free everything */ | 221 | /* clean up and free everything */ |
| 235 | void release_vpe(struct vpe *v) | 222 | static void release_vpe(struct vpe *v) |
| 236 | { | 223 | { |
| 237 | list_del(&v->list); | 224 | list_del(&v->list); |
| 238 | if (v->load_addr) | 225 | if (v->load_addr) |
| @@ -240,7 +227,7 @@ void release_vpe(struct vpe *v) | |||
| 240 | kfree(v); | 227 | kfree(v); |
| 241 | } | 228 | } |
| 242 | 229 | ||
| 243 | void dump_mtregs(void) | 230 | static void dump_mtregs(void) |
| 244 | { | 231 | { |
| 245 | unsigned long val; | 232 | unsigned long val; |
| 246 | 233 | ||
| @@ -327,7 +314,8 @@ static void layout_sections(struct module *mod, const Elf_Ehdr * hdr, | |||
| 327 | || (s->sh_flags & masks[m][1]) | 314 | || (s->sh_flags & masks[m][1]) |
| 328 | || s->sh_entsize != ~0UL) | 315 | || s->sh_entsize != ~0UL) |
| 329 | continue; | 316 | continue; |
| 330 | s->sh_entsize = get_offset(&mod->core_size, s); | 317 | s->sh_entsize = |
| 318 | get_offset((unsigned long *)&mod->core_size, s); | ||
| 331 | } | 319 | } |
| 332 | 320 | ||
| 333 | if (m == 0) | 321 | if (m == 0) |
| @@ -461,16 +449,15 @@ static int apply_r_mips_lo16(struct module *me, uint32_t *location, | |||
| 461 | { | 449 | { |
| 462 | unsigned long insnlo = *location; | 450 | unsigned long insnlo = *location; |
| 463 | Elf32_Addr val, vallo; | 451 | Elf32_Addr val, vallo; |
| 452 | struct mips_hi16 *l, *next; | ||
| 464 | 453 | ||
| 465 | /* Sign extend the addend we extract from the lo insn. */ | 454 | /* Sign extend the addend we extract from the lo insn. */ |
| 466 | vallo = ((insnlo & 0xffff) ^ 0x8000) - 0x8000; | 455 | vallo = ((insnlo & 0xffff) ^ 0x8000) - 0x8000; |
| 467 | 456 | ||
| 468 | if (mips_hi16_list != NULL) { | 457 | if (mips_hi16_list != NULL) { |
| 469 | struct mips_hi16 *l; | ||
| 470 | 458 | ||
| 471 | l = mips_hi16_list; | 459 | l = mips_hi16_list; |
| 472 | while (l != NULL) { | 460 | while (l != NULL) { |
| 473 | struct mips_hi16 *next; | ||
| 474 | unsigned long insn; | 461 | unsigned long insn; |
| 475 | 462 | ||
| 476 | /* | 463 | /* |
| @@ -480,7 +467,7 @@ static int apply_r_mips_lo16(struct module *me, uint32_t *location, | |||
| 480 | printk(KERN_DEBUG "VPE loader: " | 467 | printk(KERN_DEBUG "VPE loader: " |
| 481 | "apply_r_mips_lo16/hi16: \t" | 468 | "apply_r_mips_lo16/hi16: \t" |
| 482 | "inconsistent value information\n"); | 469 | "inconsistent value information\n"); |
| 483 | return -ENOEXEC; | 470 | goto out_free; |
| 484 | } | 471 | } |
| 485 | 472 | ||
| 486 | /* | 473 | /* |
| @@ -518,6 +505,16 @@ static int apply_r_mips_lo16(struct module *me, uint32_t *location, | |||
| 518 | *location = insnlo; | 505 | *location = insnlo; |
| 519 | 506 | ||
| 520 | return 0; | 507 | return 0; |
| 508 | |||
| 509 | out_free: | ||
| 510 | while (l != NULL) { | ||
| 511 | next = l->next; | ||
| 512 | kfree(l); | ||
| 513 | l = next; | ||
| 514 | } | ||
| 515 | mips_hi16_list = NULL; | ||
| 516 | |||
| 517 | return -ENOEXEC; | ||
| 521 | } | 518 | } |
| 522 | 519 | ||
| 523 | static int (*reloc_handlers[]) (struct module *me, uint32_t *location, | 520 | static int (*reloc_handlers[]) (struct module *me, uint32_t *location, |
| @@ -541,7 +538,7 @@ static char *rstrs[] = { | |||
| 541 | [R_MIPS_PC16] = "MIPS_PC16" | 538 | [R_MIPS_PC16] = "MIPS_PC16" |
| 542 | }; | 539 | }; |
| 543 | 540 | ||
| 544 | int apply_relocations(Elf32_Shdr *sechdrs, | 541 | static int apply_relocations(Elf32_Shdr *sechdrs, |
| 545 | const char *strtab, | 542 | const char *strtab, |
| 546 | unsigned int symindex, | 543 | unsigned int symindex, |
| 547 | unsigned int relsec, | 544 | unsigned int relsec, |
| @@ -586,7 +583,7 @@ int apply_relocations(Elf32_Shdr *sechdrs, | |||
| 586 | return 0; | 583 | return 0; |
| 587 | } | 584 | } |
| 588 | 585 | ||
| 589 | void save_gp_address(unsigned int secbase, unsigned int rel) | 586 | static inline void save_gp_address(unsigned int secbase, unsigned int rel) |
| 590 | { | 587 | { |
| 591 | gp_addr = secbase + rel; | 588 | gp_addr = secbase + rel; |
| 592 | gp_offs = gp_addr - (secbase & 0xffff0000); | 589 | gp_offs = gp_addr - (secbase & 0xffff0000); |
diff --git a/arch/mips/mipssim/sim_time.c b/arch/mips/mipssim/sim_time.c index 0cea932f1241..5492c42f7650 100644 --- a/arch/mips/mipssim/sim_time.c +++ b/arch/mips/mipssim/sim_time.c | |||
| @@ -89,13 +89,13 @@ unsigned __cpuinit get_c0_compare_int(void) | |||
| 89 | if (cpu_has_veic) { | 89 | if (cpu_has_veic) { |
| 90 | set_vi_handler(MSC01E_INT_CPUCTR, mips_timer_dispatch); | 90 | set_vi_handler(MSC01E_INT_CPUCTR, mips_timer_dispatch); |
| 91 | mips_cpu_timer_irq = MSC01E_INT_BASE + MSC01E_INT_CPUCTR; | 91 | mips_cpu_timer_irq = MSC01E_INT_BASE + MSC01E_INT_CPUCTR; |
| 92 | } else { | 92 | |
| 93 | #endif | 93 | return mips_cpu_timer_irq; |
| 94 | { | ||
| 95 | if (cpu_has_vint) | ||
| 96 | set_vi_handler(cp0_compare_irq, mips_timer_dispatch); | ||
| 97 | mips_cpu_timer_irq = MIPS_CPU_IRQ_BASE + cp0_compare_irq; | ||
| 98 | } | 94 | } |
| 95 | #endif | ||
| 96 | if (cpu_has_vint) | ||
| 97 | set_vi_handler(cp0_compare_irq, mips_timer_dispatch); | ||
| 98 | mips_cpu_timer_irq = MIPS_CPU_IRQ_BASE + cp0_compare_irq; | ||
| 99 | 99 | ||
| 100 | return mips_cpu_timer_irq; | 100 | return mips_cpu_timer_irq; |
| 101 | } | 101 | } |
diff --git a/arch/mips/mm/c-octeon.c b/arch/mips/mm/c-octeon.c index b165cdcb2818..10ab69f7183f 100644 --- a/arch/mips/mm/c-octeon.c +++ b/arch/mips/mm/c-octeon.c | |||
| @@ -289,7 +289,7 @@ static void cache_parity_error_octeon(int non_recoverable) | |||
| 289 | } | 289 | } |
| 290 | 290 | ||
| 291 | /** | 291 | /** |
| 292 | * Called when the the exception is not recoverable | 292 | * Called when the the exception is recoverable |
| 293 | */ | 293 | */ |
| 294 | 294 | ||
| 295 | asmlinkage void cache_parity_error_octeon_recoverable(void) | 295 | asmlinkage void cache_parity_error_octeon_recoverable(void) |
| @@ -298,7 +298,7 @@ asmlinkage void cache_parity_error_octeon_recoverable(void) | |||
| 298 | } | 298 | } |
| 299 | 299 | ||
| 300 | /** | 300 | /** |
| 301 | * Called when the the exception is recoverable | 301 | * Called when the the exception is not recoverable |
| 302 | */ | 302 | */ |
| 303 | 303 | ||
| 304 | asmlinkage void cache_parity_error_octeon_non_recoverable(void) | 304 | asmlinkage void cache_parity_error_octeon_non_recoverable(void) |
diff --git a/arch/mips/mm/extable.c b/arch/mips/mm/extable.c index 297fb9f390dc..9d25d2ba4b9e 100644 --- a/arch/mips/mm/extable.c +++ b/arch/mips/mm/extable.c | |||
| @@ -1,5 +1,9 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/arch/mips/mm/extable.c | 2 | * This file is subject to the terms and conditions of the GNU General Public |
| 3 | * License. See the file "COPYING" in the main directory of this archive | ||
| 4 | * for more details. | ||
| 5 | * | ||
| 6 | * Copyright (C) 1997, 99, 2001 - 2004 Ralf Baechle <ralf@linux-mips.org> | ||
| 3 | */ | 7 | */ |
| 4 | #include <linux/module.h> | 8 | #include <linux/module.h> |
| 5 | #include <linux/spinlock.h> | 9 | #include <linux/spinlock.h> |
diff --git a/arch/mips/mm/fault.c b/arch/mips/mm/fault.c index 6751ce9ede9e..f956ecbb8136 100644 --- a/arch/mips/mm/fault.c +++ b/arch/mips/mm/fault.c | |||
| @@ -171,6 +171,7 @@ out_of_memory: | |||
| 171 | * We ran out of memory, call the OOM killer, and return the userspace | 171 | * We ran out of memory, call the OOM killer, and return the userspace |
| 172 | * (which will retry the fault, or kill us if we got oom-killed). | 172 | * (which will retry the fault, or kill us if we got oom-killed). |
| 173 | */ | 173 | */ |
| 174 | up_read(&mm->mmap_sem); | ||
| 174 | pagefault_out_of_memory(); | 175 | pagefault_out_of_memory(); |
| 175 | return; | 176 | return; |
| 176 | 177 | ||
diff --git a/arch/mips/mti-malta/malta-int.c b/arch/mips/mti-malta/malta-int.c index a8756f82c31b..3e0a9b35ba5c 100644 --- a/arch/mips/mti-malta/malta-int.c +++ b/arch/mips/mti-malta/malta-int.c | |||
| @@ -331,6 +331,7 @@ static struct irqaction irq_call = { | |||
| 331 | .flags = IRQF_DISABLED|IRQF_PERCPU, | 331 | .flags = IRQF_DISABLED|IRQF_PERCPU, |
| 332 | .name = "IPI_call" | 332 | .name = "IPI_call" |
| 333 | }; | 333 | }; |
| 334 | #endif /* CONFIG_MIPS_MT_SMP */ | ||
| 334 | 335 | ||
| 335 | static int gic_resched_int_base; | 336 | static int gic_resched_int_base; |
| 336 | static int gic_call_int_base; | 337 | static int gic_call_int_base; |
| @@ -346,7 +347,6 @@ unsigned int plat_ipi_resched_int_xlate(unsigned int cpu) | |||
| 346 | { | 347 | { |
| 347 | return GIC_RESCHED_INT(cpu); | 348 | return GIC_RESCHED_INT(cpu); |
| 348 | } | 349 | } |
| 349 | #endif /* CONFIG_MIPS_MT_SMP */ | ||
| 350 | 350 | ||
| 351 | static struct irqaction i8259irq = { | 351 | static struct irqaction i8259irq = { |
| 352 | .handler = no_action, | 352 | .handler = no_action, |
diff --git a/arch/mips/nxp/pnx8550/common/time.c b/arch/mips/nxp/pnx8550/common/time.c index 8df43e9e4d90..18b192784877 100644 --- a/arch/mips/nxp/pnx8550/common/time.c +++ b/arch/mips/nxp/pnx8550/common/time.c | |||
| @@ -138,7 +138,7 @@ __init void plat_time_init(void) | |||
| 138 | * HZ timer interrupts per second. | 138 | * HZ timer interrupts per second. |
| 139 | */ | 139 | */ |
| 140 | mips_hpt_frequency = 27UL * ((1000000UL * n)/(m * pow2p)); | 140 | mips_hpt_frequency = 27UL * ((1000000UL * n)/(m * pow2p)); |
| 141 | cpj = (mips_hpt_frequency + HZ / 2) / HZ; | 141 | cpj = DIV_ROUND_CLOSEST(mips_hpt_frequency, HZ); |
| 142 | write_c0_count(0); | 142 | write_c0_count(0); |
| 143 | timer_ack(); | 143 | timer_ack(); |
| 144 | 144 | ||
diff --git a/arch/mips/pci/fixup-emma2rh.c b/arch/mips/pci/fixup-emma2rh.c index fba5aad00d51..0d9ccf4dfc5a 100644 --- a/arch/mips/pci/fixup-emma2rh.c +++ b/arch/mips/pci/fixup-emma2rh.c | |||
| @@ -1,7 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/pci/fixup-emma2rh.c | ||
| 3 | * This file defines the PCI configration. | ||
| 4 | * | ||
| 5 | * Copyright (C) NEC Electronics Corporation 2004-2006 | 2 | * Copyright (C) NEC Electronics Corporation 2004-2006 |
| 6 | * | 3 | * |
| 7 | * This file is based on the arch/mips/ddb5xxx/ddb5477/pci.c | 4 | * This file is based on the arch/mips/ddb5xxx/ddb5477/pci.c |
diff --git a/arch/mips/pci/fixup-sb1250.c b/arch/mips/pci/fixup-sb1250.c index 0ad39e53f7b1..f0bb9146e6c0 100644 --- a/arch/mips/pci/fixup-sb1250.c +++ b/arch/mips/pci/fixup-sb1250.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/pci/fixup-sb1250.c | ||
| 3 | * | ||
| 4 | * Copyright (C) 2004, 2006 MIPS Technologies, Inc. All rights reserved. | 2 | * Copyright (C) 2004, 2006 MIPS Technologies, Inc. All rights reserved. |
| 5 | * Author: Maciej W. Rozycki <macro@mips.com> | 3 | * Author: Maciej W. Rozycki <macro@mips.com> |
| 6 | * | 4 | * |
diff --git a/arch/mips/pci/ops-emma2rh.c b/arch/mips/pci/ops-emma2rh.c index 5947a70b0b7f..710aef5c070e 100644 --- a/arch/mips/pci/ops-emma2rh.c +++ b/arch/mips/pci/ops-emma2rh.c | |||
| @@ -1,7 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/pci/ops-emma2rh.c | ||
| 3 | * This file defines the PCI operation for EMMA2RH. | ||
| 4 | * | ||
| 5 | * Copyright (C) NEC Electronics Corporation 2004-2006 | 2 | * Copyright (C) NEC Electronics Corporation 2004-2006 |
| 6 | * | 3 | * |
| 7 | * This file is based on the arch/mips/pci/ops-vr41xx.c | 4 | * This file is based on the arch/mips/pci/ops-vr41xx.c |
diff --git a/arch/mips/pci/pci-emma2rh.c b/arch/mips/pci/pci-emma2rh.c index 2df4190232cd..773e34ff4d1c 100644 --- a/arch/mips/pci/pci-emma2rh.c +++ b/arch/mips/pci/pci-emma2rh.c | |||
| @@ -1,7 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/pci/pci-emma2rh.c | ||
| 3 | * This file defines the PCI configration. | ||
| 4 | * | ||
| 5 | * Copyright (C) NEC Electronics Corporation 2004-2006 | 2 | * Copyright (C) NEC Electronics Corporation 2004-2006 |
| 6 | * | 3 | * |
| 7 | * This file is based on the arch/mips/ddb5xxx/ddb5477/pci.c | 4 | * This file is based on the arch/mips/ddb5xxx/ddb5477/pci.c |
diff --git a/arch/mips/pci/pci-tx4927.c b/arch/mips/pci/pci-tx4927.c index aaa900596792..a5807406a7f1 100644 --- a/arch/mips/pci/pci-tx4927.c +++ b/arch/mips/pci/pci-tx4927.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/arch/mips/pci/pci-tx4927.c | ||
| 3 | * | ||
| 4 | * Based on linux/arch/mips/txx9/rbtx4938/setup.c, | 2 | * Based on linux/arch/mips/txx9/rbtx4938/setup.c, |
| 5 | * and RBTX49xx patch from CELF patch archive. | 3 | * and RBTX49xx patch from CELF patch archive. |
| 6 | * | 4 | * |
diff --git a/arch/mips/pci/pci-tx4938.c b/arch/mips/pci/pci-tx4938.c index 1ea257bc3b8f..20e45f30b2ef 100644 --- a/arch/mips/pci/pci-tx4938.c +++ b/arch/mips/pci/pci-tx4938.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/arch/mips/pci/pci-tx4938.c | ||
| 3 | * | ||
| 4 | * Based on linux/arch/mips/txx9/rbtx4938/setup.c, | 2 | * Based on linux/arch/mips/txx9/rbtx4938/setup.c, |
| 5 | * and RBTX49xx patch from CELF patch archive. | 3 | * and RBTX49xx patch from CELF patch archive. |
| 6 | * | 4 | * |
diff --git a/arch/mips/pci/pci-tx4939.c b/arch/mips/pci/pci-tx4939.c index 5fecf1cdc325..9ef840693baf 100644 --- a/arch/mips/pci/pci-tx4939.c +++ b/arch/mips/pci/pci-tx4939.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/arch/mips/pci/pci-tx4939.c | ||
| 3 | * | ||
| 4 | * Based on linux/arch/mips/txx9/rbtx4939/setup.c, | 2 | * Based on linux/arch/mips/txx9/rbtx4939/setup.c, |
| 5 | * and RBTX49xx patch from CELF patch archive. | 3 | * and RBTX49xx patch from CELF patch archive. |
| 6 | * | 4 | * |
diff --git a/arch/mips/pci/pcie-octeon.c b/arch/mips/pci/pcie-octeon.c index 75262247f3e4..6aa5c542d52d 100644 --- a/arch/mips/pci/pcie-octeon.c +++ b/arch/mips/pci/pcie-octeon.c | |||
| @@ -1040,19 +1040,29 @@ static inline int octeon_pcie_read_config(int pcie_port, struct pci_bus *bus, | |||
| 1040 | int bus_number = bus->number; | 1040 | int bus_number = bus->number; |
| 1041 | 1041 | ||
| 1042 | /* | 1042 | /* |
| 1043 | * We need to force the bus number to be zero on the root | 1043 | * For the top level bus make sure our hardware bus number |
| 1044 | * bus. Linux numbers the 2nd root bus to start after all | 1044 | * matches the software one. |
| 1045 | * buses on root 0. | ||
| 1046 | */ | 1045 | */ |
| 1047 | if (bus->parent == NULL) | 1046 | if (bus->parent == NULL) { |
| 1048 | bus_number = 0; | 1047 | union cvmx_pciercx_cfg006 pciercx_cfg006; |
| 1048 | pciercx_cfg006.u32 = cvmx_pcie_cfgx_read(pcie_port, | ||
| 1049 | CVMX_PCIERCX_CFG006(pcie_port)); | ||
| 1050 | if (pciercx_cfg006.s.pbnum != bus_number) { | ||
| 1051 | pciercx_cfg006.s.pbnum = bus_number; | ||
| 1052 | pciercx_cfg006.s.sbnum = bus_number; | ||
| 1053 | pciercx_cfg006.s.subbnum = bus_number; | ||
| 1054 | cvmx_pcie_cfgx_write(pcie_port, | ||
| 1055 | CVMX_PCIERCX_CFG006(pcie_port), | ||
| 1056 | pciercx_cfg006.u32); | ||
| 1057 | } | ||
| 1058 | } | ||
| 1049 | 1059 | ||
| 1050 | /* | 1060 | /* |
| 1051 | * PCIe only has a single device connected to Octeon. It is | 1061 | * PCIe only has a single device connected to Octeon. It is |
| 1052 | * always device ID 0. Don't bother doing reads for other | 1062 | * always device ID 0. Don't bother doing reads for other |
| 1053 | * device IDs on the first segment. | 1063 | * device IDs on the first segment. |
| 1054 | */ | 1064 | */ |
| 1055 | if ((bus_number == 0) && (devfn >> 3 != 0)) | 1065 | if ((bus->parent == NULL) && (devfn >> 3 != 0)) |
| 1056 | return PCIBIOS_FUNC_NOT_SUPPORTED; | 1066 | return PCIBIOS_FUNC_NOT_SUPPORTED; |
| 1057 | 1067 | ||
| 1058 | /* | 1068 | /* |
| @@ -1070,7 +1080,7 @@ static inline int octeon_pcie_read_config(int pcie_port, struct pci_bus *bus, | |||
| 1070 | * bridge only respondes to device ID 0, function | 1080 | * bridge only respondes to device ID 0, function |
| 1071 | * 0-1 | 1081 | * 0-1 |
| 1072 | */ | 1082 | */ |
| 1073 | if ((bus_number == 0) && (devfn >= 2)) | 1083 | if ((bus->parent == NULL) && (devfn >= 2)) |
| 1074 | return PCIBIOS_FUNC_NOT_SUPPORTED; | 1084 | return PCIBIOS_FUNC_NOT_SUPPORTED; |
| 1075 | /* | 1085 | /* |
| 1076 | * The PCI-X slots are device ID 2,3. Choose one of | 1086 | * The PCI-X slots are device ID 2,3. Choose one of |
| @@ -1167,13 +1177,6 @@ static inline int octeon_pcie_write_config(int pcie_port, struct pci_bus *bus, | |||
| 1167 | int size, u32 val) | 1177 | int size, u32 val) |
| 1168 | { | 1178 | { |
| 1169 | int bus_number = bus->number; | 1179 | int bus_number = bus->number; |
| 1170 | /* | ||
| 1171 | * We need to force the bus number to be zero on the root | ||
| 1172 | * bus. Linux numbers the 2nd root bus to start after all | ||
| 1173 | * busses on root 0. | ||
| 1174 | */ | ||
| 1175 | if (bus->parent == NULL) | ||
| 1176 | bus_number = 0; | ||
| 1177 | 1180 | ||
| 1178 | switch (size) { | 1181 | switch (size) { |
| 1179 | case 4: | 1182 | case 4: |
diff --git a/arch/mips/pmc-sierra/msp71xx/gpio.c b/arch/mips/pmc-sierra/msp71xx/gpio.c index 69848c5813e2..aaccbe524386 100644 --- a/arch/mips/pmc-sierra/msp71xx/gpio.c +++ b/arch/mips/pmc-sierra/msp71xx/gpio.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * @file /arch/mips/pmc-sierra/msp71xx/gpio.c | ||
| 3 | * | ||
| 4 | * Generic PMC MSP71xx GPIO handling. These base gpio are controlled by two | 2 | * Generic PMC MSP71xx GPIO handling. These base gpio are controlled by two |
| 5 | * types of registers. The data register sets the output level when in output | 3 | * types of registers. The data register sets the output level when in output |
| 6 | * mode and when in input mode will contain the value at the input. The config | 4 | * mode and when in input mode will contain the value at the input. The config |
diff --git a/arch/mips/pmc-sierra/msp71xx/gpio_extended.c b/arch/mips/pmc-sierra/msp71xx/gpio_extended.c index fc6dbc6cf1c0..2a99f360fae4 100644 --- a/arch/mips/pmc-sierra/msp71xx/gpio_extended.c +++ b/arch/mips/pmc-sierra/msp71xx/gpio_extended.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * @file /arch/mips/pmc-sierra/msp71xx/gpio_extended.c | ||
| 3 | * | ||
| 4 | * Generic PMC MSP71xx EXTENDED (EXD) GPIO handling. The extended gpio is | 2 | * Generic PMC MSP71xx EXTENDED (EXD) GPIO handling. The extended gpio is |
| 5 | * a set of hardware registers that have no need for explicit locking as | 3 | * a set of hardware registers that have no need for explicit locking as |
| 6 | * it is handled by unique method of writing individual set/clr bits. | 4 | * it is handled by unique method of writing individual set/clr bits. |
diff --git a/arch/mips/pmc-sierra/msp71xx/msp_irq_slp.c b/arch/mips/pmc-sierra/msp71xx/msp_irq_slp.c index f5f1b8d2bb9a..61f390232346 100644 --- a/arch/mips/pmc-sierra/msp71xx/msp_irq_slp.c +++ b/arch/mips/pmc-sierra/msp71xx/msp_irq_slp.c | |||
| @@ -45,13 +45,6 @@ static inline void mask_msp_slp_irq(unsigned int irq) | |||
| 45 | */ | 45 | */ |
| 46 | static inline void ack_msp_slp_irq(unsigned int irq) | 46 | static inline void ack_msp_slp_irq(unsigned int irq) |
| 47 | { | 47 | { |
| 48 | mask_slp_irq(irq); | ||
| 49 | |||
| 50 | /* | ||
| 51 | * only really necessary for 18, 16-14 and sometimes 3:0 (since | ||
| 52 | * these can be edge sensitive) but it doesn't hurt for the others. | ||
| 53 | */ | ||
| 54 | |||
| 55 | /* check for PER interrupt range */ | 48 | /* check for PER interrupt range */ |
| 56 | if (irq < MSP_PER_INTBASE) | 49 | if (irq < MSP_PER_INTBASE) |
| 57 | *SLP_INT_STS_REG = (1 << (irq - MSP_SLP_INTBASE)); | 50 | *SLP_INT_STS_REG = (1 << (irq - MSP_SLP_INTBASE)); |
| @@ -62,8 +55,7 @@ static inline void ack_msp_slp_irq(unsigned int irq) | |||
| 62 | static struct irq_chip msp_slp_irq_controller = { | 55 | static struct irq_chip msp_slp_irq_controller = { |
| 63 | .name = "MSP_SLP", | 56 | .name = "MSP_SLP", |
| 64 | .ack = ack_msp_slp_irq, | 57 | .ack = ack_msp_slp_irq, |
| 65 | .mask = ack_msp_slp_irq, | 58 | .mask = mask_msp_slp_irq, |
| 66 | .mask_ack = ack_msp_slp_irq, | ||
| 67 | .unmask = unmask_msp_slp_irq, | 59 | .unmask = unmask_msp_slp_irq, |
| 68 | }; | 60 | }; |
| 69 | 61 | ||
| @@ -79,7 +71,7 @@ void __init msp_slp_irq_init(void) | |||
| 79 | 71 | ||
| 80 | /* initialize all the IRQ descriptors */ | 72 | /* initialize all the IRQ descriptors */ |
| 81 | for (i = MSP_SLP_INTBASE; i < MSP_PER_INTBASE + 32; i++) | 73 | for (i = MSP_SLP_INTBASE; i < MSP_PER_INTBASE + 32; i++) |
| 82 | set_irq_chip_and_handler(i, &msp_slp_irq_controller | 74 | set_irq_chip_and_handler(i, &msp_slp_irq_controller, |
| 83 | handle_level_irq); | 75 | handle_level_irq); |
| 84 | } | 76 | } |
| 85 | 77 | ||
diff --git a/arch/mips/pmc-sierra/yosemite/atmel_read_eeprom.c b/arch/mips/pmc-sierra/yosemite/atmel_read_eeprom.c index caf5e9a0acc7..fc990cb31941 100644 --- a/arch/mips/pmc-sierra/yosemite/atmel_read_eeprom.c +++ b/arch/mips/pmc-sierra/yosemite/atmel_read_eeprom.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/pmc-sierra/yosemite/atmel_read_eeprom.c | ||
| 3 | * | ||
| 4 | * Copyright (C) 2003 PMC-Sierra Inc. | 2 | * Copyright (C) 2003 PMC-Sierra Inc. |
| 5 | * Author: Manish Lachwani (lachwani@pmc-sierra.com) | 3 | * Author: Manish Lachwani (lachwani@pmc-sierra.com) |
| 6 | * | 4 | * |
diff --git a/arch/mips/sibyte/swarm/swarm-i2c.c b/arch/mips/sibyte/swarm/swarm-i2c.c index 4282ac9d01d2..062505054d42 100644 --- a/arch/mips/sibyte/swarm/swarm-i2c.c +++ b/arch/mips/sibyte/swarm/swarm-i2c.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * arch/mips/sibyte/swarm/swarm-i2c.c | ||
| 3 | * | ||
| 4 | * Broadcom BCM91250A (SWARM), etc. I2C platform setup. | 2 | * Broadcom BCM91250A (SWARM), etc. I2C platform setup. |
| 5 | * | 3 | * |
| 6 | * Copyright (c) 2008 Maciej W. Rozycki | 4 | * Copyright (c) 2008 Maciej W. Rozycki |
diff --git a/arch/mips/txx9/generic/mem_tx4927.c b/arch/mips/txx9/generic/mem_tx4927.c index ef6ea6e97873..70f9626f8227 100644 --- a/arch/mips/txx9/generic/mem_tx4927.c +++ b/arch/mips/txx9/generic/mem_tx4927.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/arch/mips/txx9/generic/mem_tx4927.c | ||
| 3 | * | ||
| 4 | * common tx4927 memory interface | 2 | * common tx4927 memory interface |
| 5 | * | 3 | * |
| 6 | * Author: MontaVista Software, Inc. | 4 | * Author: MontaVista Software, Inc. |
diff --git a/arch/mips/txx9/generic/setup.c b/arch/mips/txx9/generic/setup.c index 3b7d77d61ce0..a205e2ba8e7b 100644 --- a/arch/mips/txx9/generic/setup.c +++ b/arch/mips/txx9/generic/setup.c | |||
| @@ -1,6 +1,4 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/arch/mips/txx9/generic/setup.c | ||
| 3 | * | ||
| 4 | * Based on linux/arch/mips/txx9/rbtx4938/setup.c, | 2 | * Based on linux/arch/mips/txx9/rbtx4938/setup.c, |
| 5 | * and RBTX49xx patch from CELF patch archive. | 3 | * and RBTX49xx patch from CELF patch archive. |
| 6 | * | 4 | * |
diff --git a/arch/mips/txx9/rbtx4939/setup.c b/arch/mips/txx9/rbtx4939/setup.c index c033ffe71cdf..b0c241ecf603 100644 --- a/arch/mips/txx9/rbtx4939/setup.c +++ b/arch/mips/txx9/rbtx4939/setup.c | |||
| @@ -512,10 +512,10 @@ static void __init rbtx4939_setup(void) | |||
| 512 | rbtx4939_ebusc_setup(); | 512 | rbtx4939_ebusc_setup(); |
| 513 | /* always enable ATA0 */ | 513 | /* always enable ATA0 */ |
| 514 | txx9_set64(&tx4939_ccfgptr->pcfg, TX4939_PCFG_ATA0MODE); | 514 | txx9_set64(&tx4939_ccfgptr->pcfg, TX4939_PCFG_ATA0MODE); |
| 515 | rbtx4939_update_ioc_pen(); | ||
| 516 | if (txx9_master_clock == 0) | 515 | if (txx9_master_clock == 0) |
| 517 | txx9_master_clock = 20000000; | 516 | txx9_master_clock = 20000000; |
| 518 | tx4939_setup(); | 517 | tx4939_setup(); |
| 518 | rbtx4939_update_ioc_pen(); | ||
| 519 | #ifdef HAVE_RBTX4939_IOSWAB | 519 | #ifdef HAVE_RBTX4939_IOSWAB |
| 520 | ioswabw = rbtx4939_ioswabw; | 520 | ioswabw = rbtx4939_ioswabw; |
| 521 | __mem_ioswabw = rbtx4939_mem_ioswabw; | 521 | __mem_ioswabw = rbtx4939_mem_ioswabw; |
diff --git a/arch/mn10300/include/asm/pci.h b/arch/mn10300/include/asm/pci.h index 35d2ed6396f6..19aecc90f7a4 100644 --- a/arch/mn10300/include/asm/pci.h +++ b/arch/mn10300/include/asm/pci.h | |||
| @@ -59,7 +59,6 @@ void pcibios_penalize_isa_irq(int irq); | |||
| 59 | #include <linux/slab.h> | 59 | #include <linux/slab.h> |
| 60 | #include <asm/scatterlist.h> | 60 | #include <asm/scatterlist.h> |
| 61 | #include <linux/string.h> | 61 | #include <linux/string.h> |
| 62 | #include <linux/mm.h> | ||
| 63 | #include <asm/io.h> | 62 | #include <asm/io.h> |
| 64 | 63 | ||
| 65 | struct pci_dev; | 64 | struct pci_dev; |
diff --git a/arch/mn10300/include/asm/pgalloc.h b/arch/mn10300/include/asm/pgalloc.h index ec057e1bd4cf..a19f11327cd8 100644 --- a/arch/mn10300/include/asm/pgalloc.h +++ b/arch/mn10300/include/asm/pgalloc.h | |||
| @@ -51,6 +51,6 @@ static inline void pte_free(struct mm_struct *mm, struct page *pte) | |||
| 51 | } | 51 | } |
| 52 | 52 | ||
| 53 | 53 | ||
| 54 | #define __pte_free_tlb(tlb, pte) tlb_remove_page((tlb), (pte)) | 54 | #define __pte_free_tlb(tlb, pte, addr) tlb_remove_page((tlb), (pte)) |
| 55 | 55 | ||
| 56 | #endif /* _ASM_PGALLOC_H */ | 56 | #endif /* _ASM_PGALLOC_H */ |
diff --git a/arch/parisc/include/asm/tlb.h b/arch/parisc/include/asm/tlb.h index 383b1db310ee..07924903989e 100644 --- a/arch/parisc/include/asm/tlb.h +++ b/arch/parisc/include/asm/tlb.h | |||
| @@ -21,7 +21,7 @@ do { if (!(tlb)->fullmm) \ | |||
| 21 | 21 | ||
| 22 | #include <asm-generic/tlb.h> | 22 | #include <asm-generic/tlb.h> |
| 23 | 23 | ||
| 24 | #define __pmd_free_tlb(tlb, pmd) pmd_free((tlb)->mm, pmd) | 24 | #define __pmd_free_tlb(tlb, pmd, addr) pmd_free((tlb)->mm, pmd) |
| 25 | #define __pte_free_tlb(tlb, pte) pte_free((tlb)->mm, pte) | 25 | #define __pte_free_tlb(tlb, pte, addr) pte_free((tlb)->mm, pte) |
| 26 | 26 | ||
| 27 | #endif | 27 | #endif |
diff --git a/arch/parisc/kernel/entry.S b/arch/parisc/kernel/entry.S index ae3e70cd1e14..e552e547cb93 100644 --- a/arch/parisc/kernel/entry.S +++ b/arch/parisc/kernel/entry.S | |||
| @@ -553,7 +553,7 @@ | |||
| 553 | * on most of those machines only handles cache transactions. | 553 | * on most of those machines only handles cache transactions. |
| 554 | */ | 554 | */ |
| 555 | extrd,u,*= \pte,_PAGE_NO_CACHE_BIT+32,1,%r0 | 555 | extrd,u,*= \pte,_PAGE_NO_CACHE_BIT+32,1,%r0 |
| 556 | depi 1,12,1,\prot | 556 | depdi 1,12,1,\prot |
| 557 | 557 | ||
| 558 | /* Drop prot bits and convert to page addr for iitlbt and idtlbt */ | 558 | /* Drop prot bits and convert to page addr for iitlbt and idtlbt */ |
| 559 | convert_for_tlb_insert20 \pte | 559 | convert_for_tlb_insert20 \pte |
diff --git a/arch/parisc/kernel/module.c b/arch/parisc/kernel/module.c index ef5caf2e6ed0..61ee0eec4e69 100644 --- a/arch/parisc/kernel/module.c +++ b/arch/parisc/kernel/module.c | |||
| @@ -86,8 +86,12 @@ | |||
| 86 | * the bottom of the table, which has a maximum signed displacement of | 86 | * the bottom of the table, which has a maximum signed displacement of |
| 87 | * 0x3fff; however, since we're only going forward, this becomes | 87 | * 0x3fff; however, since we're only going forward, this becomes |
| 88 | * 0x1fff, and thus, since each GOT entry is 8 bytes long we can have | 88 | * 0x1fff, and thus, since each GOT entry is 8 bytes long we can have |
| 89 | * at most 1023 entries */ | 89 | * at most 1023 entries. |
| 90 | #define MAX_GOTS 1023 | 90 | * To overcome this 14bit displacement with some kernel modules, we'll |
| 91 | * use instead the unusal 16bit displacement method (see reassemble_16a) | ||
| 92 | * which gives us a maximum positive displacement of 0x7fff, and as such | ||
| 93 | * allows us to allocate up to 4095 GOT entries. */ | ||
| 94 | #define MAX_GOTS 4095 | ||
| 91 | 95 | ||
| 92 | /* three functions to determine where in the module core | 96 | /* three functions to determine where in the module core |
| 93 | * or init pieces the location is */ | 97 | * or init pieces the location is */ |
| @@ -145,12 +149,40 @@ struct stub_entry { | |||
| 145 | /* The reassemble_* functions prepare an immediate value for | 149 | /* The reassemble_* functions prepare an immediate value for |
| 146 | insertion into an opcode. pa-risc uses all sorts of weird bitfields | 150 | insertion into an opcode. pa-risc uses all sorts of weird bitfields |
| 147 | in the instruction to hold the value. */ | 151 | in the instruction to hold the value. */ |
| 152 | static inline int sign_unext(int x, int len) | ||
| 153 | { | ||
| 154 | int len_ones; | ||
| 155 | |||
| 156 | len_ones = (1 << len) - 1; | ||
| 157 | return x & len_ones; | ||
| 158 | } | ||
| 159 | |||
| 160 | static inline int low_sign_unext(int x, int len) | ||
| 161 | { | ||
| 162 | int sign, temp; | ||
| 163 | |||
| 164 | sign = (x >> (len-1)) & 1; | ||
| 165 | temp = sign_unext(x, len-1); | ||
| 166 | return (temp << 1) | sign; | ||
| 167 | } | ||
| 168 | |||
| 148 | static inline int reassemble_14(int as14) | 169 | static inline int reassemble_14(int as14) |
| 149 | { | 170 | { |
| 150 | return (((as14 & 0x1fff) << 1) | | 171 | return (((as14 & 0x1fff) << 1) | |
| 151 | ((as14 & 0x2000) >> 13)); | 172 | ((as14 & 0x2000) >> 13)); |
| 152 | } | 173 | } |
| 153 | 174 | ||
| 175 | static inline int reassemble_16a(int as16) | ||
| 176 | { | ||
| 177 | int s, t; | ||
| 178 | |||
| 179 | /* Unusual 16-bit encoding, for wide mode only. */ | ||
| 180 | t = (as16 << 1) & 0xffff; | ||
| 181 | s = (as16 & 0x8000); | ||
| 182 | return (t ^ s ^ (s >> 1)) | (s >> 15); | ||
| 183 | } | ||
| 184 | |||
| 185 | |||
| 154 | static inline int reassemble_17(int as17) | 186 | static inline int reassemble_17(int as17) |
| 155 | { | 187 | { |
| 156 | return (((as17 & 0x10000) >> 16) | | 188 | return (((as17 & 0x10000) >> 16) | |
| @@ -407,6 +439,7 @@ static Elf_Addr get_stub(struct module *me, unsigned long value, long addend, | |||
| 407 | enum elf_stub_type stub_type, Elf_Addr loc0, unsigned int targetsec) | 439 | enum elf_stub_type stub_type, Elf_Addr loc0, unsigned int targetsec) |
| 408 | { | 440 | { |
| 409 | struct stub_entry *stub; | 441 | struct stub_entry *stub; |
| 442 | int __maybe_unused d; | ||
| 410 | 443 | ||
| 411 | /* initialize stub_offset to point in front of the section */ | 444 | /* initialize stub_offset to point in front of the section */ |
| 412 | if (!me->arch.section[targetsec].stub_offset) { | 445 | if (!me->arch.section[targetsec].stub_offset) { |
| @@ -460,12 +493,19 @@ static Elf_Addr get_stub(struct module *me, unsigned long value, long addend, | |||
| 460 | */ | 493 | */ |
| 461 | switch (stub_type) { | 494 | switch (stub_type) { |
| 462 | case ELF_STUB_GOT: | 495 | case ELF_STUB_GOT: |
| 463 | stub->insns[0] = 0x537b0000; /* ldd 0(%dp),%dp */ | 496 | d = get_got(me, value, addend); |
| 497 | if (d <= 15) { | ||
| 498 | /* Format 5 */ | ||
| 499 | stub->insns[0] = 0x0f6010db; /* ldd 0(%dp),%dp */ | ||
| 500 | stub->insns[0] |= low_sign_unext(d, 5) << 16; | ||
| 501 | } else { | ||
| 502 | /* Format 3 */ | ||
| 503 | stub->insns[0] = 0x537b0000; /* ldd 0(%dp),%dp */ | ||
| 504 | stub->insns[0] |= reassemble_16a(d); | ||
| 505 | } | ||
| 464 | stub->insns[1] = 0x53610020; /* ldd 10(%dp),%r1 */ | 506 | stub->insns[1] = 0x53610020; /* ldd 10(%dp),%r1 */ |
| 465 | stub->insns[2] = 0xe820d000; /* bve (%r1) */ | 507 | stub->insns[2] = 0xe820d000; /* bve (%r1) */ |
| 466 | stub->insns[3] = 0x537b0030; /* ldd 18(%dp),%dp */ | 508 | stub->insns[3] = 0x537b0030; /* ldd 18(%dp),%dp */ |
| 467 | |||
| 468 | stub->insns[0] |= reassemble_14(get_got(me, value, addend) & 0x3fff); | ||
| 469 | break; | 509 | break; |
| 470 | case ELF_STUB_MILLI: | 510 | case ELF_STUB_MILLI: |
| 471 | stub->insns[0] = 0x20200000; /* ldil 0,%r1 */ | 511 | stub->insns[0] = 0x20200000; /* ldil 0,%r1 */ |
diff --git a/arch/powerpc/boot/dts/mpc8377_rdb.dts b/arch/powerpc/boot/dts/mpc8377_rdb.dts index 224b4f0704b8..4f06dbc0d27e 100644 --- a/arch/powerpc/boot/dts/mpc8377_rdb.dts +++ b/arch/powerpc/boot/dts/mpc8377_rdb.dts | |||
| @@ -410,7 +410,7 @@ | |||
| 410 | bus-range = <0 0>; | 410 | bus-range = <0 0>; |
| 411 | ranges = <0x02000000 0x0 0x90000000 0x90000000 0x0 0x10000000 | 411 | ranges = <0x02000000 0x0 0x90000000 0x90000000 0x0 0x10000000 |
| 412 | 0x42000000 0x0 0x80000000 0x80000000 0x0 0x10000000 | 412 | 0x42000000 0x0 0x80000000 0x80000000 0x0 0x10000000 |
| 413 | 0x01000000 0x0 0x00000000 0xe2000000 0x0 0x00100000>; | 413 | 0x01000000 0x0 0x00000000 0xe0300000 0x0 0x00100000>; |
| 414 | sleep = <&pmc 0x00010000>; | 414 | sleep = <&pmc 0x00010000>; |
| 415 | clock-frequency = <66666666>; | 415 | clock-frequency = <66666666>; |
| 416 | #interrupt-cells = <1>; | 416 | #interrupt-cells = <1>; |
diff --git a/arch/powerpc/boot/dts/mpc8378_rdb.dts b/arch/powerpc/boot/dts/mpc8378_rdb.dts index 474ea2fa3f86..aabf3437cadf 100644 --- a/arch/powerpc/boot/dts/mpc8378_rdb.dts +++ b/arch/powerpc/boot/dts/mpc8378_rdb.dts | |||
| @@ -394,7 +394,7 @@ | |||
| 394 | bus-range = <0 0>; | 394 | bus-range = <0 0>; |
| 395 | ranges = <0x02000000 0x0 0x90000000 0x90000000 0x0 0x10000000 | 395 | ranges = <0x02000000 0x0 0x90000000 0x90000000 0x0 0x10000000 |
| 396 | 0x42000000 0x0 0x80000000 0x80000000 0x0 0x10000000 | 396 | 0x42000000 0x0 0x80000000 0x80000000 0x0 0x10000000 |
| 397 | 0x01000000 0x0 0x00000000 0xe2000000 0x0 0x00100000>; | 397 | 0x01000000 0x0 0x00000000 0xe0300000 0x0 0x00100000>; |
| 398 | sleep = <&pmc 0x00010000>; | 398 | sleep = <&pmc 0x00010000>; |
| 399 | clock-frequency = <66666666>; | 399 | clock-frequency = <66666666>; |
| 400 | #interrupt-cells = <1>; | 400 | #interrupt-cells = <1>; |
diff --git a/arch/powerpc/boot/dts/mpc8379_rdb.dts b/arch/powerpc/boot/dts/mpc8379_rdb.dts index d4838af8d379..9b1da864d890 100644 --- a/arch/powerpc/boot/dts/mpc8379_rdb.dts +++ b/arch/powerpc/boot/dts/mpc8379_rdb.dts | |||
| @@ -424,7 +424,7 @@ | |||
| 424 | bus-range = <0x0 0x0>; | 424 | bus-range = <0x0 0x0>; |
| 425 | ranges = <0x02000000 0x0 0x90000000 0x90000000 0x0 0x10000000 | 425 | ranges = <0x02000000 0x0 0x90000000 0x90000000 0x0 0x10000000 |
| 426 | 0x42000000 0x0 0x80000000 0x80000000 0x0 0x10000000 | 426 | 0x42000000 0x0 0x80000000 0x80000000 0x0 0x10000000 |
| 427 | 0x01000000 0x0 0x00000000 0xe2000000 0x0 0x00100000>; | 427 | 0x01000000 0x0 0x00000000 0xe0300000 0x0 0x00100000>; |
| 428 | sleep = <&pmc 0x00010000>; | 428 | sleep = <&pmc 0x00010000>; |
| 429 | clock-frequency = <66666666>; | 429 | clock-frequency = <66666666>; |
| 430 | #interrupt-cells = <1>; | 430 | #interrupt-cells = <1>; |
diff --git a/arch/powerpc/boot/dts/mpc8569mds.dts b/arch/powerpc/boot/dts/mpc8569mds.dts index a680165292f2..9e4ce99e1613 100644 --- a/arch/powerpc/boot/dts/mpc8569mds.dts +++ b/arch/powerpc/boot/dts/mpc8569mds.dts | |||
| @@ -501,6 +501,10 @@ | |||
| 501 | reg = <0x6>; | 501 | reg = <0x6>; |
| 502 | device_type = "ethernet-phy"; | 502 | device_type = "ethernet-phy"; |
| 503 | }; | 503 | }; |
| 504 | tbi-phy@11 { | ||
| 505 | reg = <0x11>; | ||
| 506 | device_type = "tbi-phy"; | ||
| 507 | }; | ||
| 504 | }; | 508 | }; |
| 505 | mdio@3520 { | 509 | mdio@3520 { |
| 506 | #address-cells = <1>; | 510 | #address-cells = <1>; |
diff --git a/arch/powerpc/configs/83xx/asp8347_defconfig b/arch/powerpc/configs/83xx/asp8347_defconfig index 278939713775..a2df0635b6de 100644 --- a/arch/powerpc/configs/83xx/asp8347_defconfig +++ b/arch/powerpc/configs/83xx/asp8347_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:05 2009 | 4 | # Wed Jul 29 23:32:02 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | CONFIG_FSL_EMB_PERFMON=y | 20 | CONFIG_FSL_EMB_PERFMON=y |
| 20 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 45 | CONFIG_PPC=y | 48 | CONFIG_PPC=y |
| @@ -53,6 +56,7 @@ CONFIG_PPC_UDBG_16550=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | # CONFIG_DEFAULT_UIMAGE is not set | 60 | # CONFIG_DEFAULT_UIMAGE is not set |
| 57 | CONFIG_REDBOOT=y | 61 | CONFIG_REDBOOT=y |
| 58 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 62 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| @@ -60,6 +64,7 @@ CONFIG_ARCH_SUSPEND_POSSIBLE=y | |||
| 60 | # CONFIG_PPC_DCR_MMIO is not set | 64 | # CONFIG_PPC_DCR_MMIO is not set |
| 61 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 65 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 62 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 66 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 67 | CONFIG_CONSTRUCTORS=y | ||
| 63 | 68 | ||
| 64 | # | 69 | # |
| 65 | # General setup | 70 | # General setup |
| @@ -108,7 +113,6 @@ CONFIG_ANON_INODES=y | |||
| 108 | CONFIG_EMBEDDED=y | 113 | CONFIG_EMBEDDED=y |
| 109 | CONFIG_SYSCTL_SYSCALL=y | 114 | CONFIG_SYSCTL_SYSCALL=y |
| 110 | # CONFIG_KALLSYMS is not set | 115 | # CONFIG_KALLSYMS is not set |
| 111 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 112 | CONFIG_HOTPLUG=y | 116 | CONFIG_HOTPLUG=y |
| 113 | CONFIG_PRINTK=y | 117 | CONFIG_PRINTK=y |
| 114 | CONFIG_BUG=y | 118 | CONFIG_BUG=y |
| @@ -121,9 +125,16 @@ CONFIG_TIMERFD=y | |||
| 121 | CONFIG_EVENTFD=y | 125 | CONFIG_EVENTFD=y |
| 122 | CONFIG_SHMEM=y | 126 | CONFIG_SHMEM=y |
| 123 | CONFIG_AIO=y | 127 | CONFIG_AIO=y |
| 128 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 129 | |||
| 130 | # | ||
| 131 | # Performance Counters | ||
| 132 | # | ||
| 133 | # CONFIG_PERF_COUNTERS is not set | ||
| 124 | CONFIG_VM_EVENT_COUNTERS=y | 134 | CONFIG_VM_EVENT_COUNTERS=y |
| 125 | CONFIG_PCI_QUIRKS=y | 135 | CONFIG_PCI_QUIRKS=y |
| 126 | CONFIG_SLUB_DEBUG=y | 136 | CONFIG_SLUB_DEBUG=y |
| 137 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 127 | CONFIG_COMPAT_BRK=y | 138 | CONFIG_COMPAT_BRK=y |
| 128 | # CONFIG_SLAB is not set | 139 | # CONFIG_SLAB is not set |
| 129 | CONFIG_SLUB=y | 140 | CONFIG_SLUB=y |
| @@ -136,6 +147,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 136 | CONFIG_HAVE_KPROBES=y | 147 | CONFIG_HAVE_KPROBES=y |
| 137 | CONFIG_HAVE_KRETPROBES=y | 148 | CONFIG_HAVE_KRETPROBES=y |
| 138 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 149 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 150 | |||
| 151 | # | ||
| 152 | # GCOV-based kernel profiling | ||
| 153 | # | ||
| 139 | # CONFIG_SLOW_WORK is not set | 154 | # CONFIG_SLOW_WORK is not set |
| 140 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 155 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 141 | CONFIG_SLABINFO=y | 156 | CONFIG_SLABINFO=y |
| @@ -148,7 +163,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 148 | # CONFIG_MODVERSIONS is not set | 163 | # CONFIG_MODVERSIONS is not set |
| 149 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 164 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 150 | CONFIG_BLOCK=y | 165 | CONFIG_BLOCK=y |
| 151 | # CONFIG_LBD is not set | 166 | CONFIG_LBDAF=y |
| 152 | # CONFIG_BLK_DEV_BSG is not set | 167 | # CONFIG_BLK_DEV_BSG is not set |
| 153 | # CONFIG_BLK_DEV_INTEGRITY is not set | 168 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 154 | 169 | ||
| @@ -190,6 +205,7 @@ CONFIG_PPC_83xx=y | |||
| 190 | # CONFIG_MPC837x_RDB is not set | 205 | # CONFIG_MPC837x_RDB is not set |
| 191 | # CONFIG_SBC834x is not set | 206 | # CONFIG_SBC834x is not set |
| 192 | CONFIG_ASP834x=y | 207 | CONFIG_ASP834x=y |
| 208 | # CONFIG_KMETER1 is not set | ||
| 193 | CONFIG_PPC_MPC834x=y | 209 | CONFIG_PPC_MPC834x=y |
| 194 | # CONFIG_PPC_86xx is not set | 210 | # CONFIG_PPC_86xx is not set |
| 195 | # CONFIG_EMBEDDED6xx is not set | 211 | # CONFIG_EMBEDDED6xx is not set |
| @@ -235,6 +251,7 @@ CONFIG_BINFMT_ELF=y | |||
| 235 | # CONFIG_HAVE_AOUT is not set | 251 | # CONFIG_HAVE_AOUT is not set |
| 236 | # CONFIG_BINFMT_MISC is not set | 252 | # CONFIG_BINFMT_MISC is not set |
| 237 | # CONFIG_IOMMU_HELPER is not set | 253 | # CONFIG_IOMMU_HELPER is not set |
| 254 | # CONFIG_SWIOTLB is not set | ||
| 238 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 255 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 239 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 256 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 240 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 257 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -255,9 +272,9 @@ CONFIG_MIGRATION=y | |||
| 255 | CONFIG_ZONE_DMA_FLAG=1 | 272 | CONFIG_ZONE_DMA_FLAG=1 |
| 256 | CONFIG_BOUNCE=y | 273 | CONFIG_BOUNCE=y |
| 257 | CONFIG_VIRT_TO_BUS=y | 274 | CONFIG_VIRT_TO_BUS=y |
| 258 | CONFIG_UNEVICTABLE_LRU=y | ||
| 259 | CONFIG_HAVE_MLOCK=y | 275 | CONFIG_HAVE_MLOCK=y |
| 260 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 276 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 277 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 261 | CONFIG_PPC_4K_PAGES=y | 278 | CONFIG_PPC_4K_PAGES=y |
| 262 | # CONFIG_PPC_16K_PAGES is not set | 279 | # CONFIG_PPC_16K_PAGES is not set |
| 263 | # CONFIG_PPC_64K_PAGES is not set | 280 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -366,6 +383,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 366 | # CONFIG_ECONET is not set | 383 | # CONFIG_ECONET is not set |
| 367 | # CONFIG_WAN_ROUTER is not set | 384 | # CONFIG_WAN_ROUTER is not set |
| 368 | # CONFIG_PHONET is not set | 385 | # CONFIG_PHONET is not set |
| 386 | # CONFIG_IEEE802154 is not set | ||
| 369 | # CONFIG_NET_SCHED is not set | 387 | # CONFIG_NET_SCHED is not set |
| 370 | # CONFIG_DCB is not set | 388 | # CONFIG_DCB is not set |
| 371 | 389 | ||
| @@ -383,7 +401,11 @@ CONFIG_WIRELESS=y | |||
| 383 | CONFIG_WIRELESS_OLD_REGULATORY=y | 401 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 384 | # CONFIG_WIRELESS_EXT is not set | 402 | # CONFIG_WIRELESS_EXT is not set |
| 385 | # CONFIG_LIB80211 is not set | 403 | # CONFIG_LIB80211 is not set |
| 386 | # CONFIG_MAC80211 is not set | 404 | |
| 405 | # | ||
| 406 | # CFG80211 needs to be enabled for MAC80211 | ||
| 407 | # | ||
| 408 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 387 | # CONFIG_WIMAX is not set | 409 | # CONFIG_WIMAX is not set |
| 388 | # CONFIG_RFKILL is not set | 410 | # CONFIG_RFKILL is not set |
| 389 | # CONFIG_NET_9P is not set | 411 | # CONFIG_NET_9P is not set |
| @@ -490,6 +512,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 490 | # CONFIG_MTD_UBI is not set | 512 | # CONFIG_MTD_UBI is not set |
| 491 | CONFIG_OF_DEVICE=y | 513 | CONFIG_OF_DEVICE=y |
| 492 | CONFIG_OF_I2C=y | 514 | CONFIG_OF_I2C=y |
| 515 | CONFIG_OF_MDIO=y | ||
| 493 | # CONFIG_PARPORT is not set | 516 | # CONFIG_PARPORT is not set |
| 494 | CONFIG_BLK_DEV=y | 517 | CONFIG_BLK_DEV=y |
| 495 | # CONFIG_BLK_DEV_FD is not set | 518 | # CONFIG_BLK_DEV_FD is not set |
| @@ -525,7 +548,9 @@ CONFIG_MISC_DEVICES=y | |||
| 525 | # | 548 | # |
| 526 | # CONFIG_EEPROM_AT24 is not set | 549 | # CONFIG_EEPROM_AT24 is not set |
| 527 | # CONFIG_EEPROM_LEGACY is not set | 550 | # CONFIG_EEPROM_LEGACY is not set |
| 551 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 528 | # CONFIG_EEPROM_93CX6 is not set | 552 | # CONFIG_EEPROM_93CX6 is not set |
| 553 | # CONFIG_CB710_CORE is not set | ||
| 529 | CONFIG_HAVE_IDE=y | 554 | CONFIG_HAVE_IDE=y |
| 530 | # CONFIG_IDE is not set | 555 | # CONFIG_IDE is not set |
| 531 | 556 | ||
| @@ -545,14 +570,17 @@ CONFIG_HAVE_IDE=y | |||
| 545 | # | 570 | # |
| 546 | 571 | ||
| 547 | # | 572 | # |
| 548 | # Enable only one of the two stacks, unless you know what you are doing | 573 | # You can enable one or both FireWire driver stacks. |
| 574 | # | ||
| 575 | |||
| 576 | # | ||
| 577 | # See the help texts for more information. | ||
| 549 | # | 578 | # |
| 550 | # CONFIG_FIREWIRE is not set | 579 | # CONFIG_FIREWIRE is not set |
| 551 | # CONFIG_IEEE1394 is not set | 580 | # CONFIG_IEEE1394 is not set |
| 552 | # CONFIG_I2O is not set | 581 | # CONFIG_I2O is not set |
| 553 | # CONFIG_MACINTOSH_DRIVERS is not set | 582 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 554 | CONFIG_NETDEVICES=y | 583 | CONFIG_NETDEVICES=y |
| 555 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 556 | # CONFIG_DUMMY is not set | 584 | # CONFIG_DUMMY is not set |
| 557 | # CONFIG_BONDING is not set | 585 | # CONFIG_BONDING is not set |
| 558 | # CONFIG_MACVLAN is not set | 586 | # CONFIG_MACVLAN is not set |
| @@ -599,6 +627,7 @@ CONFIG_MII=y | |||
| 599 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 627 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 600 | # CONFIG_NET_PCI is not set | 628 | # CONFIG_NET_PCI is not set |
| 601 | # CONFIG_B44 is not set | 629 | # CONFIG_B44 is not set |
| 630 | # CONFIG_KS8842 is not set | ||
| 602 | # CONFIG_ATL2 is not set | 631 | # CONFIG_ATL2 is not set |
| 603 | CONFIG_NETDEV_1000=y | 632 | CONFIG_NETDEV_1000=y |
| 604 | # CONFIG_ACENIC is not set | 633 | # CONFIG_ACENIC is not set |
| @@ -618,8 +647,10 @@ CONFIG_NETDEV_1000=y | |||
| 618 | # CONFIG_VIA_VELOCITY is not set | 647 | # CONFIG_VIA_VELOCITY is not set |
| 619 | # CONFIG_TIGON3 is not set | 648 | # CONFIG_TIGON3 is not set |
| 620 | # CONFIG_BNX2 is not set | 649 | # CONFIG_BNX2 is not set |
| 650 | # CONFIG_CNIC is not set | ||
| 621 | CONFIG_FSL_PQ_MDIO=y | 651 | CONFIG_FSL_PQ_MDIO=y |
| 622 | CONFIG_GIANFAR=y | 652 | CONFIG_GIANFAR=y |
| 653 | # CONFIG_MV643XX_ETH is not set | ||
| 623 | # CONFIG_QLA3XXX is not set | 654 | # CONFIG_QLA3XXX is not set |
| 624 | # CONFIG_ATL1 is not set | 655 | # CONFIG_ATL1 is not set |
| 625 | # CONFIG_ATL1E is not set | 656 | # CONFIG_ATL1E is not set |
| @@ -786,13 +817,17 @@ CONFIG_I2C_MPC=y | |||
| 786 | # CONFIG_SENSORS_PCF8574 is not set | 817 | # CONFIG_SENSORS_PCF8574 is not set |
| 787 | # CONFIG_PCF8575 is not set | 818 | # CONFIG_PCF8575 is not set |
| 788 | # CONFIG_SENSORS_PCA9539 is not set | 819 | # CONFIG_SENSORS_PCA9539 is not set |
| 789 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 790 | # CONFIG_SENSORS_TSL2550 is not set | 820 | # CONFIG_SENSORS_TSL2550 is not set |
| 791 | # CONFIG_I2C_DEBUG_CORE is not set | 821 | # CONFIG_I2C_DEBUG_CORE is not set |
| 792 | # CONFIG_I2C_DEBUG_ALGO is not set | 822 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 793 | # CONFIG_I2C_DEBUG_BUS is not set | 823 | # CONFIG_I2C_DEBUG_BUS is not set |
| 794 | # CONFIG_I2C_DEBUG_CHIP is not set | 824 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 795 | # CONFIG_SPI is not set | 825 | # CONFIG_SPI is not set |
| 826 | |||
| 827 | # | ||
| 828 | # PPS support | ||
| 829 | # | ||
| 830 | # CONFIG_PPS is not set | ||
| 796 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 831 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 797 | # CONFIG_GPIOLIB is not set | 832 | # CONFIG_GPIOLIB is not set |
| 798 | # CONFIG_W1 is not set | 833 | # CONFIG_W1 is not set |
| @@ -847,6 +882,7 @@ CONFIG_HWMON=y | |||
| 847 | # CONFIG_SENSORS_SMSC47B397 is not set | 882 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 848 | # CONFIG_SENSORS_ADS7828 is not set | 883 | # CONFIG_SENSORS_ADS7828 is not set |
| 849 | # CONFIG_SENSORS_THMC50 is not set | 884 | # CONFIG_SENSORS_THMC50 is not set |
| 885 | # CONFIG_SENSORS_TMP401 is not set | ||
| 850 | # CONFIG_SENSORS_VIA686A is not set | 886 | # CONFIG_SENSORS_VIA686A is not set |
| 851 | # CONFIG_SENSORS_VT1211 is not set | 887 | # CONFIG_SENSORS_VT1211 is not set |
| 852 | # CONFIG_SENSORS_VT8231 is not set | 888 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -900,24 +936,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 900 | # CONFIG_MFD_WM8400 is not set | 936 | # CONFIG_MFD_WM8400 is not set |
| 901 | # CONFIG_MFD_WM8350_I2C is not set | 937 | # CONFIG_MFD_WM8350_I2C is not set |
| 902 | # CONFIG_MFD_PCF50633 is not set | 938 | # CONFIG_MFD_PCF50633 is not set |
| 939 | # CONFIG_AB3100_CORE is not set | ||
| 903 | # CONFIG_REGULATOR is not set | 940 | # CONFIG_REGULATOR is not set |
| 904 | 941 | # CONFIG_MEDIA_SUPPORT is not set | |
| 905 | # | ||
| 906 | # Multimedia devices | ||
| 907 | # | ||
| 908 | |||
| 909 | # | ||
| 910 | # Multimedia core support | ||
| 911 | # | ||
| 912 | # CONFIG_VIDEO_DEV is not set | ||
| 913 | # CONFIG_DVB_CORE is not set | ||
| 914 | # CONFIG_VIDEO_MEDIA is not set | ||
| 915 | |||
| 916 | # | ||
| 917 | # Multimedia drivers | ||
| 918 | # | ||
| 919 | CONFIG_DAB=y | ||
| 920 | # CONFIG_USB_DABUSB is not set | ||
| 921 | 942 | ||
| 922 | # | 943 | # |
| 923 | # Graphics support | 944 | # Graphics support |
| @@ -960,6 +981,7 @@ CONFIG_USB_MON=y | |||
| 960 | # USB Host Controller Drivers | 981 | # USB Host Controller Drivers |
| 961 | # | 982 | # |
| 962 | # CONFIG_USB_C67X00_HCD is not set | 983 | # CONFIG_USB_C67X00_HCD is not set |
| 984 | # CONFIG_USB_XHCI_HCD is not set | ||
| 963 | CONFIG_USB_EHCI_HCD=y | 985 | CONFIG_USB_EHCI_HCD=y |
| 964 | CONFIG_USB_EHCI_ROOT_HUB_TT=y | 986 | CONFIG_USB_EHCI_ROOT_HUB_TT=y |
| 965 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 987 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1069,6 +1091,7 @@ CONFIG_RTC_DRV_DS1374=y | |||
| 1069 | # CONFIG_RTC_DRV_S35390A is not set | 1091 | # CONFIG_RTC_DRV_S35390A is not set |
| 1070 | # CONFIG_RTC_DRV_FM3130 is not set | 1092 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1071 | # CONFIG_RTC_DRV_RX8581 is not set | 1093 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1094 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1072 | 1095 | ||
| 1073 | # | 1096 | # |
| 1074 | # SPI RTC drivers | 1097 | # SPI RTC drivers |
| @@ -1096,6 +1119,10 @@ CONFIG_RTC_DRV_DS1374=y | |||
| 1096 | # CONFIG_DMADEVICES is not set | 1119 | # CONFIG_DMADEVICES is not set |
| 1097 | # CONFIG_AUXDISPLAY is not set | 1120 | # CONFIG_AUXDISPLAY is not set |
| 1098 | # CONFIG_UIO is not set | 1121 | # CONFIG_UIO is not set |
| 1122 | |||
| 1123 | # | ||
| 1124 | # TI VLYNQ | ||
| 1125 | # | ||
| 1099 | # CONFIG_STAGING is not set | 1126 | # CONFIG_STAGING is not set |
| 1100 | 1127 | ||
| 1101 | # | 1128 | # |
| @@ -1115,10 +1142,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1115 | # CONFIG_REISERFS_FS is not set | 1142 | # CONFIG_REISERFS_FS is not set |
| 1116 | # CONFIG_JFS_FS is not set | 1143 | # CONFIG_JFS_FS is not set |
| 1117 | # CONFIG_FS_POSIX_ACL is not set | 1144 | # CONFIG_FS_POSIX_ACL is not set |
| 1118 | CONFIG_FILE_LOCKING=y | ||
| 1119 | # CONFIG_XFS_FS is not set | 1145 | # CONFIG_XFS_FS is not set |
| 1146 | # CONFIG_GFS2_FS is not set | ||
| 1120 | # CONFIG_OCFS2_FS is not set | 1147 | # CONFIG_OCFS2_FS is not set |
| 1121 | # CONFIG_BTRFS_FS is not set | 1148 | # CONFIG_BTRFS_FS is not set |
| 1149 | CONFIG_FILE_LOCKING=y | ||
| 1150 | CONFIG_FSNOTIFY=y | ||
| 1122 | CONFIG_DNOTIFY=y | 1151 | CONFIG_DNOTIFY=y |
| 1123 | CONFIG_INOTIFY=y | 1152 | CONFIG_INOTIFY=y |
| 1124 | CONFIG_INOTIFY_USER=y | 1153 | CONFIG_INOTIFY_USER=y |
| @@ -1192,6 +1221,7 @@ CONFIG_NFS_FS=y | |||
| 1192 | CONFIG_NFS_V3=y | 1221 | CONFIG_NFS_V3=y |
| 1193 | # CONFIG_NFS_V3_ACL is not set | 1222 | # CONFIG_NFS_V3_ACL is not set |
| 1194 | CONFIG_NFS_V4=y | 1223 | CONFIG_NFS_V4=y |
| 1224 | # CONFIG_NFS_V4_1 is not set | ||
| 1195 | CONFIG_ROOT_NFS=y | 1225 | CONFIG_ROOT_NFS=y |
| 1196 | # CONFIG_NFSD is not set | 1226 | # CONFIG_NFSD is not set |
| 1197 | CONFIG_LOCKD=y | 1227 | CONFIG_LOCKD=y |
| @@ -1287,6 +1317,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1287 | CONFIG_HAS_DMA=y | 1317 | CONFIG_HAS_DMA=y |
| 1288 | CONFIG_HAVE_LMB=y | 1318 | CONFIG_HAVE_LMB=y |
| 1289 | CONFIG_NLATTR=y | 1319 | CONFIG_NLATTR=y |
| 1320 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1290 | 1321 | ||
| 1291 | # | 1322 | # |
| 1292 | # Kernel hacking | 1323 | # Kernel hacking |
| @@ -1312,22 +1343,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1312 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1343 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1313 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1344 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1314 | CONFIG_TRACING_SUPPORT=y | 1345 | CONFIG_TRACING_SUPPORT=y |
| 1315 | 1346 | # CONFIG_FTRACE is not set | |
| 1316 | # | ||
| 1317 | # Tracers | ||
| 1318 | # | ||
| 1319 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1320 | # CONFIG_SCHED_TRACER is not set | ||
| 1321 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1322 | # CONFIG_EVENT_TRACER is not set | ||
| 1323 | # CONFIG_BOOT_TRACER is not set | ||
| 1324 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1325 | # CONFIG_STACK_TRACER is not set | ||
| 1326 | # CONFIG_KMEMTRACE is not set | ||
| 1327 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1328 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1329 | # CONFIG_SAMPLES is not set | 1347 | # CONFIG_SAMPLES is not set |
| 1330 | CONFIG_HAVE_ARCH_KGDB=y | 1348 | CONFIG_HAVE_ARCH_KGDB=y |
| 1349 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1350 | CONFIG_PPC_WERROR=y | ||
| 1331 | CONFIG_PRINT_STACK_DEPTH=64 | 1351 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1332 | # CONFIG_IRQSTACKS is not set | 1352 | # CONFIG_IRQSTACKS is not set |
| 1333 | # CONFIG_BOOTX_TEXT is not set | 1353 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/83xx/kmeter1_defconfig b/arch/powerpc/configs/83xx/kmeter1_defconfig index bf0853f29f31..93ebd443a18f 100644 --- a/arch/powerpc/configs/83xx/kmeter1_defconfig +++ b/arch/powerpc/configs/83xx/kmeter1_defconfig | |||
| @@ -1,25 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.28 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Fri Apr 3 10:34:33 2009 | 4 | # Wed Jul 29 23:32:03 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | ||
| 18 | CONFIG_6xx=y | ||
| 17 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 18 | # CONFIG_FSL_EMB_PERFMON is not set | 20 | # CONFIG_FSL_EMB_PERFMON is not set |
| 19 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 20 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 21 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 22 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 23 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 24 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 25 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -30,21 +33,22 @@ CONFIG_GENERIC_TIME=y | |||
| 30 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 31 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 32 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 33 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 34 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 35 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 36 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 37 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 38 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 39 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 40 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 41 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 42 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 43 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 44 | CONFIG_PPC=y | 48 | CONFIG_PPC=y |
| 45 | CONFIG_EARLY_PRINTK=y | 49 | CONFIG_EARLY_PRINTK=y |
| 46 | CONFIG_GENERIC_NVRAM=y | 50 | CONFIG_GENERIC_NVRAM=y |
| 47 | CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y | 51 | CONFIG_SCHED_OMIT_FRAME_POINTER=y |
| 48 | CONFIG_ARCH_MAY_HAVE_PC_FDC=y | 52 | CONFIG_ARCH_MAY_HAVE_PC_FDC=y |
| 49 | CONFIG_PPC_OF=y | 53 | CONFIG_PPC_OF=y |
| 50 | CONFIG_OF=y | 54 | CONFIG_OF=y |
| @@ -52,11 +56,14 @@ CONFIG_PPC_UDBG_16550=y | |||
| 52 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 53 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 54 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 55 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 56 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 61 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| 57 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 58 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | ||
| 59 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 60 | 67 | ||
| 61 | # | 68 | # |
| 62 | # General setup | 69 | # General setup |
| @@ -71,19 +78,30 @@ CONFIG_LOCALVERSION_AUTO=y | |||
| 71 | CONFIG_SYSVIPC=y | 78 | CONFIG_SYSVIPC=y |
| 72 | CONFIG_SYSVIPC_SYSCTL=y | 79 | CONFIG_SYSVIPC_SYSCTL=y |
| 73 | CONFIG_POSIX_MQUEUE=y | 80 | CONFIG_POSIX_MQUEUE=y |
| 81 | CONFIG_POSIX_MQUEUE_SYSCTL=y | ||
| 74 | # CONFIG_BSD_PROCESS_ACCT is not set | 82 | # CONFIG_BSD_PROCESS_ACCT is not set |
| 75 | # CONFIG_TASKSTATS is not set | 83 | # CONFIG_TASKSTATS is not set |
| 76 | # CONFIG_AUDIT is not set | 84 | # CONFIG_AUDIT is not set |
| 85 | |||
| 86 | # | ||
| 87 | # RCU Subsystem | ||
| 88 | # | ||
| 89 | CONFIG_CLASSIC_RCU=y | ||
| 90 | # CONFIG_TREE_RCU is not set | ||
| 91 | # CONFIG_PREEMPT_RCU is not set | ||
| 92 | # CONFIG_TREE_RCU_TRACE is not set | ||
| 93 | # CONFIG_PREEMPT_RCU_TRACE is not set | ||
| 77 | # CONFIG_IKCONFIG is not set | 94 | # CONFIG_IKCONFIG is not set |
| 78 | CONFIG_LOG_BUF_SHIFT=14 | 95 | CONFIG_LOG_BUF_SHIFT=14 |
| 79 | # CONFIG_CGROUPS is not set | ||
| 80 | # CONFIG_GROUP_SCHED is not set | 96 | # CONFIG_GROUP_SCHED is not set |
| 97 | # CONFIG_CGROUPS is not set | ||
| 81 | # CONFIG_SYSFS_DEPRECATED_V2 is not set | 98 | # CONFIG_SYSFS_DEPRECATED_V2 is not set |
| 82 | # CONFIG_RELAY is not set | 99 | # CONFIG_RELAY is not set |
| 83 | # CONFIG_NAMESPACES is not set | 100 | # CONFIG_NAMESPACES is not set |
| 84 | # CONFIG_BLK_DEV_INITRD is not set | 101 | # CONFIG_BLK_DEV_INITRD is not set |
| 85 | CONFIG_CC_OPTIMIZE_FOR_SIZE=y | 102 | CONFIG_CC_OPTIMIZE_FOR_SIZE=y |
| 86 | CONFIG_SYSCTL=y | 103 | CONFIG_SYSCTL=y |
| 104 | CONFIG_ANON_INODES=y | ||
| 87 | CONFIG_EMBEDDED=y | 105 | CONFIG_EMBEDDED=y |
| 88 | CONFIG_SYSCTL_SYSCALL=y | 106 | CONFIG_SYSCTL_SYSCALL=y |
| 89 | CONFIG_KALLSYMS=y | 107 | CONFIG_KALLSYMS=y |
| @@ -93,17 +111,23 @@ CONFIG_KALLSYMS_ALL=y | |||
| 93 | CONFIG_PRINTK=y | 111 | CONFIG_PRINTK=y |
| 94 | CONFIG_BUG=y | 112 | CONFIG_BUG=y |
| 95 | CONFIG_ELF_CORE=y | 113 | CONFIG_ELF_CORE=y |
| 96 | CONFIG_COMPAT_BRK=y | ||
| 97 | CONFIG_BASE_FULL=y | 114 | CONFIG_BASE_FULL=y |
| 98 | CONFIG_FUTEX=y | 115 | CONFIG_FUTEX=y |
| 99 | CONFIG_ANON_INODES=y | ||
| 100 | CONFIG_EPOLL=y | 116 | CONFIG_EPOLL=y |
| 101 | CONFIG_SIGNALFD=y | 117 | CONFIG_SIGNALFD=y |
| 102 | CONFIG_TIMERFD=y | 118 | CONFIG_TIMERFD=y |
| 103 | CONFIG_EVENTFD=y | 119 | CONFIG_EVENTFD=y |
| 104 | CONFIG_SHMEM=y | 120 | CONFIG_SHMEM=y |
| 105 | CONFIG_AIO=y | 121 | CONFIG_AIO=y |
| 122 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 123 | |||
| 124 | # | ||
| 125 | # Performance Counters | ||
| 126 | # | ||
| 127 | # CONFIG_PERF_COUNTERS is not set | ||
| 106 | CONFIG_VM_EVENT_COUNTERS=y | 128 | CONFIG_VM_EVENT_COUNTERS=y |
| 129 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 130 | CONFIG_COMPAT_BRK=y | ||
| 107 | CONFIG_SLAB=y | 131 | CONFIG_SLAB=y |
| 108 | # CONFIG_SLUB is not set | 132 | # CONFIG_SLUB is not set |
| 109 | # CONFIG_SLOB is not set | 133 | # CONFIG_SLOB is not set |
| @@ -116,10 +140,15 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 116 | CONFIG_HAVE_KPROBES=y | 140 | CONFIG_HAVE_KPROBES=y |
| 117 | CONFIG_HAVE_KRETPROBES=y | 141 | CONFIG_HAVE_KRETPROBES=y |
| 118 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 142 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 143 | |||
| 144 | # | ||
| 145 | # GCOV-based kernel profiling | ||
| 146 | # | ||
| 147 | # CONFIG_GCOV_KERNEL is not set | ||
| 148 | # CONFIG_SLOW_WORK is not set | ||
| 119 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 149 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 120 | CONFIG_SLABINFO=y | 150 | CONFIG_SLABINFO=y |
| 121 | CONFIG_RT_MUTEXES=y | 151 | CONFIG_RT_MUTEXES=y |
| 122 | # CONFIG_TINY_SHMEM is not set | ||
| 123 | CONFIG_BASE_SMALL=0 | 152 | CONFIG_BASE_SMALL=0 |
| 124 | CONFIG_MODULES=y | 153 | CONFIG_MODULES=y |
| 125 | # CONFIG_MODULE_FORCE_LOAD is not set | 154 | # CONFIG_MODULE_FORCE_LOAD is not set |
| @@ -127,11 +156,8 @@ CONFIG_MODULE_UNLOAD=y | |||
| 127 | # CONFIG_MODULE_FORCE_UNLOAD is not set | 156 | # CONFIG_MODULE_FORCE_UNLOAD is not set |
| 128 | # CONFIG_MODVERSIONS is not set | 157 | # CONFIG_MODVERSIONS is not set |
| 129 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 158 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 130 | CONFIG_KMOD=y | ||
| 131 | CONFIG_BLOCK=y | 159 | CONFIG_BLOCK=y |
| 132 | # CONFIG_LBD is not set | 160 | CONFIG_LBDAF=y |
| 133 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 134 | # CONFIG_LSF is not set | ||
| 135 | # CONFIG_BLK_DEV_BSG is not set | 161 | # CONFIG_BLK_DEV_BSG is not set |
| 136 | # CONFIG_BLK_DEV_INTEGRITY is not set | 162 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 137 | 163 | ||
| @@ -147,14 +173,11 @@ CONFIG_IOSCHED_NOOP=y | |||
| 147 | # CONFIG_DEFAULT_CFQ is not set | 173 | # CONFIG_DEFAULT_CFQ is not set |
| 148 | CONFIG_DEFAULT_NOOP=y | 174 | CONFIG_DEFAULT_NOOP=y |
| 149 | CONFIG_DEFAULT_IOSCHED="noop" | 175 | CONFIG_DEFAULT_IOSCHED="noop" |
| 150 | CONFIG_CLASSIC_RCU=y | ||
| 151 | # CONFIG_FREEZER is not set | 176 | # CONFIG_FREEZER is not set |
| 152 | 177 | ||
| 153 | # | 178 | # |
| 154 | # Platform support | 179 | # Platform support |
| 155 | # | 180 | # |
| 156 | CONFIG_PPC_MULTIPLATFORM=y | ||
| 157 | CONFIG_CLASSIC32=y | ||
| 158 | # CONFIG_PPC_CHRP is not set | 181 | # CONFIG_PPC_CHRP is not set |
| 159 | # CONFIG_MPC5121_ADS is not set | 182 | # CONFIG_MPC5121_ADS is not set |
| 160 | # CONFIG_MPC5121_GENERIC is not set | 183 | # CONFIG_MPC5121_GENERIC is not set |
| @@ -179,6 +202,8 @@ CONFIG_PPC_83xx=y | |||
| 179 | CONFIG_KMETER1=y | 202 | CONFIG_KMETER1=y |
| 180 | # CONFIG_PPC_86xx is not set | 203 | # CONFIG_PPC_86xx is not set |
| 181 | # CONFIG_EMBEDDED6xx is not set | 204 | # CONFIG_EMBEDDED6xx is not set |
| 205 | # CONFIG_AMIGAONE is not set | ||
| 206 | CONFIG_PPC_OF_BOOT_TRAMPOLINE=y | ||
| 182 | CONFIG_IPIC=y | 207 | CONFIG_IPIC=y |
| 183 | # CONFIG_MPIC is not set | 208 | # CONFIG_MPIC is not set |
| 184 | # CONFIG_MPIC_WEIRD is not set | 209 | # CONFIG_MPIC_WEIRD is not set |
| @@ -194,6 +219,8 @@ CONFIG_IPIC=y | |||
| 194 | CONFIG_QUICC_ENGINE=y | 219 | CONFIG_QUICC_ENGINE=y |
| 195 | # CONFIG_QE_GPIO is not set | 220 | # CONFIG_QE_GPIO is not set |
| 196 | # CONFIG_FSL_ULI1575 is not set | 221 | # CONFIG_FSL_ULI1575 is not set |
| 222 | # CONFIG_SIMPLE_GPIO is not set | ||
| 223 | # CONFIG_MCU_MPC8349EMITX is not set | ||
| 197 | 224 | ||
| 198 | # | 225 | # |
| 199 | # Kernel options | 226 | # Kernel options |
| @@ -212,16 +239,17 @@ CONFIG_SCHED_HRTICK=y | |||
| 212 | # CONFIG_PREEMPT_NONE is not set | 239 | # CONFIG_PREEMPT_NONE is not set |
| 213 | # CONFIG_PREEMPT_VOLUNTARY is not set | 240 | # CONFIG_PREEMPT_VOLUNTARY is not set |
| 214 | CONFIG_PREEMPT=y | 241 | CONFIG_PREEMPT=y |
| 215 | # CONFIG_PREEMPT_RCU is not set | ||
| 216 | CONFIG_BINFMT_ELF=y | 242 | CONFIG_BINFMT_ELF=y |
| 217 | # CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set | 243 | # CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set |
| 218 | # CONFIG_HAVE_AOUT is not set | 244 | # CONFIG_HAVE_AOUT is not set |
| 219 | # CONFIG_BINFMT_MISC is not set | 245 | # CONFIG_BINFMT_MISC is not set |
| 220 | # CONFIG_IOMMU_HELPER is not set | 246 | # CONFIG_IOMMU_HELPER is not set |
| 247 | # CONFIG_SWIOTLB is not set | ||
| 221 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 248 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 222 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 249 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 223 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 250 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| 224 | # CONFIG_KEXEC is not set | 251 | # CONFIG_KEXEC is not set |
| 252 | # CONFIG_CRASH_DUMP is not set | ||
| 225 | CONFIG_ARCH_FLATMEM_ENABLE=y | 253 | CONFIG_ARCH_FLATMEM_ENABLE=y |
| 226 | CONFIG_ARCH_POPULATES_NODE_MAP=y | 254 | CONFIG_ARCH_POPULATES_NODE_MAP=y |
| 227 | CONFIG_SELECT_MEMORY_MODEL=y | 255 | CONFIG_SELECT_MEMORY_MODEL=y |
| @@ -233,12 +261,17 @@ CONFIG_FLAT_NODE_MEM_MAP=y | |||
| 233 | CONFIG_PAGEFLAGS_EXTENDED=y | 261 | CONFIG_PAGEFLAGS_EXTENDED=y |
| 234 | CONFIG_SPLIT_PTLOCK_CPUS=4 | 262 | CONFIG_SPLIT_PTLOCK_CPUS=4 |
| 235 | CONFIG_MIGRATION=y | 263 | CONFIG_MIGRATION=y |
| 236 | # CONFIG_RESOURCES_64BIT is not set | ||
| 237 | # CONFIG_PHYS_ADDR_T_64BIT is not set | 264 | # CONFIG_PHYS_ADDR_T_64BIT is not set |
| 238 | CONFIG_ZONE_DMA_FLAG=1 | 265 | CONFIG_ZONE_DMA_FLAG=1 |
| 239 | CONFIG_BOUNCE=y | 266 | CONFIG_BOUNCE=y |
| 240 | CONFIG_VIRT_TO_BUS=y | 267 | CONFIG_VIRT_TO_BUS=y |
| 241 | CONFIG_UNEVICTABLE_LRU=y | 268 | CONFIG_HAVE_MLOCK=y |
| 269 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | ||
| 270 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 271 | CONFIG_PPC_4K_PAGES=y | ||
| 272 | # CONFIG_PPC_16K_PAGES is not set | ||
| 273 | # CONFIG_PPC_64K_PAGES is not set | ||
| 274 | # CONFIG_PPC_256K_PAGES is not set | ||
| 242 | CONFIG_FORCE_MAX_ZONEORDER=11 | 275 | CONFIG_FORCE_MAX_ZONEORDER=11 |
| 243 | CONFIG_PROC_DEVICETREE=y | 276 | CONFIG_PROC_DEVICETREE=y |
| 244 | # CONFIG_CMDLINE_BOOL is not set | 277 | # CONFIG_CMDLINE_BOOL is not set |
| @@ -331,7 +364,10 @@ CONFIG_LLC=m | |||
| 331 | # CONFIG_LAPB is not set | 364 | # CONFIG_LAPB is not set |
| 332 | # CONFIG_ECONET is not set | 365 | # CONFIG_ECONET is not set |
| 333 | # CONFIG_WAN_ROUTER is not set | 366 | # CONFIG_WAN_ROUTER is not set |
| 367 | # CONFIG_PHONET is not set | ||
| 368 | # CONFIG_IEEE802154 is not set | ||
| 334 | # CONFIG_NET_SCHED is not set | 369 | # CONFIG_NET_SCHED is not set |
| 370 | # CONFIG_DCB is not set | ||
| 335 | 371 | ||
| 336 | # | 372 | # |
| 337 | # Network testing | 373 | # Network testing |
| @@ -342,8 +378,8 @@ CONFIG_LLC=m | |||
| 342 | # CONFIG_IRDA is not set | 378 | # CONFIG_IRDA is not set |
| 343 | # CONFIG_BT is not set | 379 | # CONFIG_BT is not set |
| 344 | # CONFIG_AF_RXRPC is not set | 380 | # CONFIG_AF_RXRPC is not set |
| 345 | # CONFIG_PHONET is not set | ||
| 346 | # CONFIG_WIRELESS is not set | 381 | # CONFIG_WIRELESS is not set |
| 382 | # CONFIG_WIMAX is not set | ||
| 347 | # CONFIG_RFKILL is not set | 383 | # CONFIG_RFKILL is not set |
| 348 | # CONFIG_NET_9P is not set | 384 | # CONFIG_NET_9P is not set |
| 349 | 385 | ||
| @@ -362,6 +398,7 @@ CONFIG_MTD=y | |||
| 362 | # CONFIG_MTD_DEBUG is not set | 398 | # CONFIG_MTD_DEBUG is not set |
| 363 | CONFIG_MTD_CONCAT=y | 399 | CONFIG_MTD_CONCAT=y |
| 364 | CONFIG_MTD_PARTITIONS=y | 400 | CONFIG_MTD_PARTITIONS=y |
| 401 | # CONFIG_MTD_TESTS is not set | ||
| 365 | # CONFIG_MTD_REDBOOT_PARTS is not set | 402 | # CONFIG_MTD_REDBOOT_PARTS is not set |
| 366 | CONFIG_MTD_CMDLINE_PARTS=y | 403 | CONFIG_MTD_CMDLINE_PARTS=y |
| 367 | CONFIG_MTD_OF_PARTS=y | 404 | CONFIG_MTD_OF_PARTS=y |
| @@ -431,6 +468,11 @@ CONFIG_MTD_PHRAM=y | |||
| 431 | # CONFIG_MTD_ONENAND is not set | 468 | # CONFIG_MTD_ONENAND is not set |
| 432 | 469 | ||
| 433 | # | 470 | # |
| 471 | # LPDDR flash memory drivers | ||
| 472 | # | ||
| 473 | # CONFIG_MTD_LPDDR is not set | ||
| 474 | |||
| 475 | # | ||
| 434 | # UBI - Unsorted block images | 476 | # UBI - Unsorted block images |
| 435 | # | 477 | # |
| 436 | CONFIG_MTD_UBI=y | 478 | CONFIG_MTD_UBI=y |
| @@ -445,7 +487,6 @@ CONFIG_MTD_UBI_DEBUG=y | |||
| 445 | # CONFIG_MTD_UBI_DEBUG_MSG is not set | 487 | # CONFIG_MTD_UBI_DEBUG_MSG is not set |
| 446 | # CONFIG_MTD_UBI_DEBUG_PARANOID is not set | 488 | # CONFIG_MTD_UBI_DEBUG_PARANOID is not set |
| 447 | # CONFIG_MTD_UBI_DEBUG_DISABLE_BGT is not set | 489 | # CONFIG_MTD_UBI_DEBUG_DISABLE_BGT is not set |
| 448 | # CONFIG_MTD_UBI_DEBUG_USERSPACE_IO is not set | ||
| 449 | # CONFIG_MTD_UBI_DEBUG_EMULATE_BITFLIPS is not set | 490 | # CONFIG_MTD_UBI_DEBUG_EMULATE_BITFLIPS is not set |
| 450 | # CONFIG_MTD_UBI_DEBUG_EMULATE_WRITE_FAILURES is not set | 491 | # CONFIG_MTD_UBI_DEBUG_EMULATE_WRITE_FAILURES is not set |
| 451 | # CONFIG_MTD_UBI_DEBUG_EMULATE_ERASE_FAILURES is not set | 492 | # CONFIG_MTD_UBI_DEBUG_EMULATE_ERASE_FAILURES is not set |
| @@ -459,6 +500,7 @@ CONFIG_MTD_UBI_DEBUG=y | |||
| 459 | # CONFIG_MTD_UBI_DEBUG_MSG_IO is not set | 500 | # CONFIG_MTD_UBI_DEBUG_MSG_IO is not set |
| 460 | CONFIG_OF_DEVICE=y | 501 | CONFIG_OF_DEVICE=y |
| 461 | CONFIG_OF_I2C=y | 502 | CONFIG_OF_I2C=y |
| 503 | CONFIG_OF_MDIO=y | ||
| 462 | # CONFIG_PARPORT is not set | 504 | # CONFIG_PARPORT is not set |
| 463 | CONFIG_BLK_DEV=y | 505 | CONFIG_BLK_DEV=y |
| 464 | # CONFIG_BLK_DEV_FD is not set | 506 | # CONFIG_BLK_DEV_FD is not set |
| @@ -505,10 +547,15 @@ CONFIG_MARVELL_PHY=y | |||
| 505 | # CONFIG_BROADCOM_PHY is not set | 547 | # CONFIG_BROADCOM_PHY is not set |
| 506 | # CONFIG_ICPLUS_PHY is not set | 548 | # CONFIG_ICPLUS_PHY is not set |
| 507 | # CONFIG_REALTEK_PHY is not set | 549 | # CONFIG_REALTEK_PHY is not set |
| 550 | # CONFIG_NATIONAL_PHY is not set | ||
| 551 | # CONFIG_STE10XP is not set | ||
| 552 | # CONFIG_LSI_ET1011C_PHY is not set | ||
| 508 | # CONFIG_FIXED_PHY is not set | 553 | # CONFIG_FIXED_PHY is not set |
| 509 | # CONFIG_MDIO_BITBANG is not set | 554 | # CONFIG_MDIO_BITBANG is not set |
| 510 | CONFIG_NET_ETHERNET=y | 555 | CONFIG_NET_ETHERNET=y |
| 511 | CONFIG_MII=y | 556 | CONFIG_MII=y |
| 557 | # CONFIG_ETHOC is not set | ||
| 558 | # CONFIG_DNET is not set | ||
| 512 | # CONFIG_IBM_NEW_EMAC_ZMII is not set | 559 | # CONFIG_IBM_NEW_EMAC_ZMII is not set |
| 513 | # CONFIG_IBM_NEW_EMAC_RGMII is not set | 560 | # CONFIG_IBM_NEW_EMAC_RGMII is not set |
| 514 | # CONFIG_IBM_NEW_EMAC_TAH is not set | 561 | # CONFIG_IBM_NEW_EMAC_TAH is not set |
| @@ -517,11 +564,12 @@ CONFIG_MII=y | |||
| 517 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 564 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 518 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 565 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 519 | # CONFIG_B44 is not set | 566 | # CONFIG_B44 is not set |
| 567 | # CONFIG_KS8842 is not set | ||
| 520 | CONFIG_NETDEV_1000=y | 568 | CONFIG_NETDEV_1000=y |
| 569 | CONFIG_FSL_PQ_MDIO=y | ||
| 521 | # CONFIG_GIANFAR is not set | 570 | # CONFIG_GIANFAR is not set |
| 522 | CONFIG_UCC_GETH=y | 571 | CONFIG_UCC_GETH=y |
| 523 | # CONFIG_UGETH_MAGIC_PACKET is not set | 572 | # CONFIG_UGETH_MAGIC_PACKET is not set |
| 524 | # CONFIG_UGETH_FILTERING is not set | ||
| 525 | # CONFIG_UGETH_TX_ON_DEMAND is not set | 573 | # CONFIG_UGETH_TX_ON_DEMAND is not set |
| 526 | # CONFIG_MV643XX_ETH is not set | 574 | # CONFIG_MV643XX_ETH is not set |
| 527 | # CONFIG_NETDEV_10000 is not set | 575 | # CONFIG_NETDEV_10000 is not set |
| @@ -531,7 +579,10 @@ CONFIG_UCC_GETH=y | |||
| 531 | # | 579 | # |
| 532 | # CONFIG_WLAN_PRE80211 is not set | 580 | # CONFIG_WLAN_PRE80211 is not set |
| 533 | # CONFIG_WLAN_80211 is not set | 581 | # CONFIG_WLAN_80211 is not set |
| 534 | # CONFIG_IWLWIFI_LEDS is not set | 582 | |
| 583 | # | ||
| 584 | # Enable WiMAX (Networking options) to see the WiMAX drivers | ||
| 585 | # | ||
| 535 | CONFIG_WAN=y | 586 | CONFIG_WAN=y |
| 536 | CONFIG_HDLC=y | 587 | CONFIG_HDLC=y |
| 537 | # CONFIG_HDLC_RAW is not set | 588 | # CONFIG_HDLC_RAW is not set |
| @@ -543,8 +594,6 @@ CONFIG_HDLC=y | |||
| 543 | # | 594 | # |
| 544 | # X.25/LAPB support is disabled | 595 | # X.25/LAPB support is disabled |
| 545 | # | 596 | # |
| 546 | CONFIG_HDLC_KM=y | ||
| 547 | CONFIG_FS_UCC_HDLC=y | ||
| 548 | # CONFIG_DLCI is not set | 597 | # CONFIG_DLCI is not set |
| 549 | CONFIG_PPP=y | 598 | CONFIG_PPP=y |
| 550 | CONFIG_PPP_MULTILINK=y | 599 | CONFIG_PPP_MULTILINK=y |
| @@ -600,16 +649,18 @@ CONFIG_SERIAL_CORE_CONSOLE=y | |||
| 600 | # CONFIG_SERIAL_OF_PLATFORM is not set | 649 | # CONFIG_SERIAL_OF_PLATFORM is not set |
| 601 | # CONFIG_SERIAL_QE is not set | 650 | # CONFIG_SERIAL_QE is not set |
| 602 | CONFIG_UNIX98_PTYS=y | 651 | CONFIG_UNIX98_PTYS=y |
| 652 | # CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set | ||
| 603 | CONFIG_LEGACY_PTYS=y | 653 | CONFIG_LEGACY_PTYS=y |
| 604 | CONFIG_LEGACY_PTY_COUNT=256 | 654 | CONFIG_LEGACY_PTY_COUNT=256 |
| 655 | # CONFIG_HVC_UDBG is not set | ||
| 605 | # CONFIG_IPMI_HANDLER is not set | 656 | # CONFIG_IPMI_HANDLER is not set |
| 606 | CONFIG_HW_RANDOM=y | 657 | CONFIG_HW_RANDOM=y |
| 658 | # CONFIG_HW_RANDOM_TIMERIOMEM is not set | ||
| 607 | # CONFIG_NVRAM is not set | 659 | # CONFIG_NVRAM is not set |
| 608 | # CONFIG_GEN_RTC is not set | 660 | # CONFIG_GEN_RTC is not set |
| 609 | # CONFIG_R3964 is not set | 661 | # CONFIG_R3964 is not set |
| 610 | # CONFIG_RAW_DRIVER is not set | 662 | # CONFIG_RAW_DRIVER is not set |
| 611 | # CONFIG_TCG_TPM is not set | 663 | # CONFIG_TCG_TPM is not set |
| 612 | CONFIG_BOOTCOUNT=y | ||
| 613 | CONFIG_I2C=y | 664 | CONFIG_I2C=y |
| 614 | CONFIG_I2C_BOARDINFO=y | 665 | CONFIG_I2C_BOARDINFO=y |
| 615 | CONFIG_I2C_CHARDEV=y | 666 | CONFIG_I2C_CHARDEV=y |
| @@ -642,20 +693,20 @@ CONFIG_I2C_MPC=y | |||
| 642 | # Miscellaneous I2C Chip support | 693 | # Miscellaneous I2C Chip support |
| 643 | # | 694 | # |
| 644 | # CONFIG_DS1682 is not set | 695 | # CONFIG_DS1682 is not set |
| 645 | # CONFIG_AT24 is not set | ||
| 646 | # CONFIG_SENSORS_EEPROM is not set | ||
| 647 | # CONFIG_SENSORS_PCF8574 is not set | 696 | # CONFIG_SENSORS_PCF8574 is not set |
| 648 | # CONFIG_PCF8575 is not set | 697 | # CONFIG_PCF8575 is not set |
| 649 | # CONFIG_SENSORS_PCA9539 is not set | 698 | # CONFIG_SENSORS_PCA9539 is not set |
| 650 | # CONFIG_SENSORS_PCF8591 is not set | ||
| 651 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 652 | # CONFIG_SENSORS_TSL2550 is not set | 699 | # CONFIG_SENSORS_TSL2550 is not set |
| 653 | # CONFIG_MCU_MPC8349EMITX is not set | ||
| 654 | # CONFIG_I2C_DEBUG_CORE is not set | 700 | # CONFIG_I2C_DEBUG_CORE is not set |
| 655 | # CONFIG_I2C_DEBUG_ALGO is not set | 701 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 656 | # CONFIG_I2C_DEBUG_BUS is not set | 702 | # CONFIG_I2C_DEBUG_BUS is not set |
| 657 | # CONFIG_I2C_DEBUG_CHIP is not set | 703 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 658 | # CONFIG_SPI is not set | 704 | # CONFIG_SPI is not set |
| 705 | |||
| 706 | # | ||
| 707 | # PPS support | ||
| 708 | # | ||
| 709 | # CONFIG_PPS is not set | ||
| 659 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 710 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 660 | # CONFIG_GPIOLIB is not set | 711 | # CONFIG_GPIOLIB is not set |
| 661 | # CONFIG_W1 is not set | 712 | # CONFIG_W1 is not set |
| @@ -677,27 +728,15 @@ CONFIG_SSB_POSSIBLE=y | |||
| 677 | # CONFIG_MFD_CORE is not set | 728 | # CONFIG_MFD_CORE is not set |
| 678 | # CONFIG_MFD_SM501 is not set | 729 | # CONFIG_MFD_SM501 is not set |
| 679 | # CONFIG_HTC_PASIC3 is not set | 730 | # CONFIG_HTC_PASIC3 is not set |
| 731 | # CONFIG_TWL4030_CORE is not set | ||
| 680 | # CONFIG_MFD_TMIO is not set | 732 | # CONFIG_MFD_TMIO is not set |
| 681 | # CONFIG_PMIC_DA903X is not set | 733 | # CONFIG_PMIC_DA903X is not set |
| 682 | # CONFIG_MFD_WM8400 is not set | 734 | # CONFIG_MFD_WM8400 is not set |
| 683 | # CONFIG_MFD_WM8350_I2C is not set | 735 | # CONFIG_MFD_WM8350_I2C is not set |
| 736 | # CONFIG_MFD_PCF50633 is not set | ||
| 737 | # CONFIG_AB3100_CORE is not set | ||
| 684 | # CONFIG_REGULATOR is not set | 738 | # CONFIG_REGULATOR is not set |
| 685 | 739 | # CONFIG_MEDIA_SUPPORT is not set | |
| 686 | # | ||
| 687 | # Multimedia devices | ||
| 688 | # | ||
| 689 | |||
| 690 | # | ||
| 691 | # Multimedia core support | ||
| 692 | # | ||
| 693 | # CONFIG_VIDEO_DEV is not set | ||
| 694 | # CONFIG_DVB_CORE is not set | ||
| 695 | # CONFIG_VIDEO_MEDIA is not set | ||
| 696 | |||
| 697 | # | ||
| 698 | # Multimedia drivers | ||
| 699 | # | ||
| 700 | # CONFIG_DAB is not set | ||
| 701 | 740 | ||
| 702 | # | 741 | # |
| 703 | # Graphics support | 742 | # Graphics support |
| @@ -720,11 +759,16 @@ CONFIG_SSB_POSSIBLE=y | |||
| 720 | # CONFIG_EDAC is not set | 759 | # CONFIG_EDAC is not set |
| 721 | # CONFIG_RTC_CLASS is not set | 760 | # CONFIG_RTC_CLASS is not set |
| 722 | # CONFIG_DMADEVICES is not set | 761 | # CONFIG_DMADEVICES is not set |
| 762 | # CONFIG_AUXDISPLAY is not set | ||
| 723 | CONFIG_UIO=y | 763 | CONFIG_UIO=y |
| 724 | # CONFIG_UIO_PDRV is not set | 764 | # CONFIG_UIO_PDRV is not set |
| 725 | # CONFIG_UIO_PDRV_GENIRQ is not set | 765 | # CONFIG_UIO_PDRV_GENIRQ is not set |
| 726 | # CONFIG_UIO_SMX is not set | 766 | # CONFIG_UIO_SMX is not set |
| 727 | # CONFIG_UIO_SERCOS3 is not set | 767 | # CONFIG_UIO_SERCOS3 is not set |
| 768 | |||
| 769 | # | ||
| 770 | # TI VLYNQ | ||
| 771 | # | ||
| 728 | # CONFIG_STAGING is not set | 772 | # CONFIG_STAGING is not set |
| 729 | 773 | ||
| 730 | # | 774 | # |
| @@ -736,9 +780,12 @@ CONFIG_UIO=y | |||
| 736 | # CONFIG_REISERFS_FS is not set | 780 | # CONFIG_REISERFS_FS is not set |
| 737 | # CONFIG_JFS_FS is not set | 781 | # CONFIG_JFS_FS is not set |
| 738 | # CONFIG_FS_POSIX_ACL is not set | 782 | # CONFIG_FS_POSIX_ACL is not set |
| 739 | CONFIG_FILE_LOCKING=y | ||
| 740 | # CONFIG_XFS_FS is not set | 783 | # CONFIG_XFS_FS is not set |
| 784 | # CONFIG_GFS2_FS is not set | ||
| 741 | # CONFIG_OCFS2_FS is not set | 785 | # CONFIG_OCFS2_FS is not set |
| 786 | # CONFIG_BTRFS_FS is not set | ||
| 787 | CONFIG_FILE_LOCKING=y | ||
| 788 | CONFIG_FSNOTIFY=y | ||
| 742 | # CONFIG_DNOTIFY is not set | 789 | # CONFIG_DNOTIFY is not set |
| 743 | CONFIG_INOTIFY=y | 790 | CONFIG_INOTIFY=y |
| 744 | CONFIG_INOTIFY_USER=y | 791 | CONFIG_INOTIFY_USER=y |
| @@ -748,6 +795,11 @@ CONFIG_INOTIFY_USER=y | |||
| 748 | # CONFIG_FUSE_FS is not set | 795 | # CONFIG_FUSE_FS is not set |
| 749 | 796 | ||
| 750 | # | 797 | # |
| 798 | # Caches | ||
| 799 | # | ||
| 800 | # CONFIG_FSCACHE is not set | ||
| 801 | |||
| 802 | # | ||
| 751 | # CD-ROM/DVD Filesystems | 803 | # CD-ROM/DVD Filesystems |
| 752 | # | 804 | # |
| 753 | # CONFIG_ISO9660_FS is not set | 805 | # CONFIG_ISO9660_FS is not set |
| @@ -772,10 +824,7 @@ CONFIG_TMPFS=y | |||
| 772 | # CONFIG_TMPFS_POSIX_ACL is not set | 824 | # CONFIG_TMPFS_POSIX_ACL is not set |
| 773 | # CONFIG_HUGETLB_PAGE is not set | 825 | # CONFIG_HUGETLB_PAGE is not set |
| 774 | # CONFIG_CONFIGFS_FS is not set | 826 | # CONFIG_CONFIGFS_FS is not set |
| 775 | 827 | CONFIG_MISC_FILESYSTEMS=y | |
| 776 | # | ||
| 777 | # Miscellaneous filesystems | ||
| 778 | # | ||
| 779 | # CONFIG_ADFS_FS is not set | 828 | # CONFIG_ADFS_FS is not set |
| 780 | # CONFIG_AFFS_FS is not set | 829 | # CONFIG_AFFS_FS is not set |
| 781 | # CONFIG_HFS_FS is not set | 830 | # CONFIG_HFS_FS is not set |
| @@ -796,6 +845,7 @@ CONFIG_JFFS2_RTIME=y | |||
| 796 | # CONFIG_JFFS2_RUBIN is not set | 845 | # CONFIG_JFFS2_RUBIN is not set |
| 797 | # CONFIG_UBIFS_FS is not set | 846 | # CONFIG_UBIFS_FS is not set |
| 798 | # CONFIG_CRAMFS is not set | 847 | # CONFIG_CRAMFS is not set |
| 848 | # CONFIG_SQUASHFS is not set | ||
| 799 | # CONFIG_VXFS_FS is not set | 849 | # CONFIG_VXFS_FS is not set |
| 800 | # CONFIG_MINIX_FS is not set | 850 | # CONFIG_MINIX_FS is not set |
| 801 | # CONFIG_OMFS_FS is not set | 851 | # CONFIG_OMFS_FS is not set |
| @@ -804,6 +854,7 @@ CONFIG_JFFS2_RTIME=y | |||
| 804 | # CONFIG_ROMFS_FS is not set | 854 | # CONFIG_ROMFS_FS is not set |
| 805 | # CONFIG_SYSV_FS is not set | 855 | # CONFIG_SYSV_FS is not set |
| 806 | # CONFIG_UFS_FS is not set | 856 | # CONFIG_UFS_FS is not set |
| 857 | # CONFIG_NILFS2_FS is not set | ||
| 807 | CONFIG_NETWORK_FILESYSTEMS=y | 858 | CONFIG_NETWORK_FILESYSTEMS=y |
| 808 | CONFIG_NFS_FS=y | 859 | CONFIG_NFS_FS=y |
| 809 | CONFIG_NFS_V3=y | 860 | CONFIG_NFS_V3=y |
| @@ -815,7 +866,6 @@ CONFIG_LOCKD=y | |||
| 815 | CONFIG_LOCKD_V4=y | 866 | CONFIG_LOCKD_V4=y |
| 816 | CONFIG_NFS_COMMON=y | 867 | CONFIG_NFS_COMMON=y |
| 817 | CONFIG_SUNRPC=y | 868 | CONFIG_SUNRPC=y |
| 818 | # CONFIG_SUNRPC_REGISTER_V4 is not set | ||
| 819 | # CONFIG_RPCSEC_GSS_KRB5 is not set | 869 | # CONFIG_RPCSEC_GSS_KRB5 is not set |
| 820 | # CONFIG_RPCSEC_GSS_SPKM3 is not set | 870 | # CONFIG_RPCSEC_GSS_SPKM3 is not set |
| 821 | # CONFIG_SMB_FS is not set | 871 | # CONFIG_SMB_FS is not set |
| @@ -845,11 +895,13 @@ CONFIG_PARTITION_ADVANCED=y | |||
| 845 | # CONFIG_DLM is not set | 895 | # CONFIG_DLM is not set |
| 846 | CONFIG_UCC_FAST=y | 896 | CONFIG_UCC_FAST=y |
| 847 | CONFIG_UCC=y | 897 | CONFIG_UCC=y |
| 898 | # CONFIG_BINARY_PRINTF is not set | ||
| 848 | 899 | ||
| 849 | # | 900 | # |
| 850 | # Library routines | 901 | # Library routines |
| 851 | # | 902 | # |
| 852 | CONFIG_BITREVERSE=y | 903 | CONFIG_BITREVERSE=y |
| 904 | CONFIG_GENERIC_FIND_LAST_BIT=y | ||
| 853 | # CONFIG_CRC_CCITT is not set | 905 | # CONFIG_CRC_CCITT is not set |
| 854 | # CONFIG_CRC16 is not set | 906 | # CONFIG_CRC16 is not set |
| 855 | # CONFIG_CRC_T10DIF is not set | 907 | # CONFIG_CRC_T10DIF is not set |
| @@ -859,11 +911,12 @@ CONFIG_CRC32=y | |||
| 859 | # CONFIG_LIBCRC32C is not set | 911 | # CONFIG_LIBCRC32C is not set |
| 860 | CONFIG_ZLIB_INFLATE=y | 912 | CONFIG_ZLIB_INFLATE=y |
| 861 | CONFIG_ZLIB_DEFLATE=y | 913 | CONFIG_ZLIB_DEFLATE=y |
| 862 | CONFIG_PLIST=y | ||
| 863 | CONFIG_HAS_IOMEM=y | 914 | CONFIG_HAS_IOMEM=y |
| 864 | CONFIG_HAS_IOPORT=y | 915 | CONFIG_HAS_IOPORT=y |
| 865 | CONFIG_HAS_DMA=y | 916 | CONFIG_HAS_DMA=y |
| 866 | CONFIG_HAVE_LMB=y | 917 | CONFIG_HAVE_LMB=y |
| 918 | CONFIG_NLATTR=y | ||
| 919 | CONFIG_GENERIC_ATOMIC64=y | ||
| 867 | 920 | ||
| 868 | # | 921 | # |
| 869 | # Kernel hacking | 922 | # Kernel hacking |
| @@ -883,13 +936,18 @@ CONFIG_DEBUG_FS=y | |||
| 883 | # CONFIG_LATENCYTOP is not set | 936 | # CONFIG_LATENCYTOP is not set |
| 884 | CONFIG_SYSCTL_SYSCALL_CHECK=y | 937 | CONFIG_SYSCTL_SYSCALL_CHECK=y |
| 885 | CONFIG_HAVE_FUNCTION_TRACER=y | 938 | CONFIG_HAVE_FUNCTION_TRACER=y |
| 886 | 939 | CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |
| 887 | # | 940 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 888 | # Tracers | 941 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 889 | # | 942 | CONFIG_TRACING_SUPPORT=y |
| 890 | # CONFIG_DYNAMIC_PRINTK_DEBUG is not set | 943 | # CONFIG_FTRACE is not set |
| 944 | # CONFIG_DYNAMIC_DEBUG is not set | ||
| 891 | # CONFIG_SAMPLES is not set | 945 | # CONFIG_SAMPLES is not set |
| 892 | CONFIG_HAVE_ARCH_KGDB=y | 946 | CONFIG_HAVE_ARCH_KGDB=y |
| 947 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 948 | CONFIG_PPC_WERROR=y | ||
| 949 | CONFIG_PRINT_STACK_DEPTH=64 | ||
| 950 | # CONFIG_PPC_EMULATED_STATS is not set | ||
| 893 | # CONFIG_IRQSTACKS is not set | 951 | # CONFIG_IRQSTACKS is not set |
| 894 | # CONFIG_VIRQ_DEBUG is not set | 952 | # CONFIG_VIRQ_DEBUG is not set |
| 895 | # CONFIG_BOOTX_TEXT is not set | 953 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/83xx/mpc8313_rdb_defconfig b/arch/powerpc/configs/83xx/mpc8313_rdb_defconfig index c5c0fe71a438..ff33a7db2eab 100644 --- a/arch/powerpc/configs/83xx/mpc8313_rdb_defconfig +++ b/arch/powerpc/configs/83xx/mpc8313_rdb_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:06 2009 | 4 | # Wed Jul 29 23:32:04 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_FSL_EMB_PERFMON is not set | 20 | # CONFIG_FSL_EMB_PERFMON is not set |
| 20 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 45 | CONFIG_PPC=y | 48 | CONFIG_PPC=y |
| @@ -53,12 +56,14 @@ CONFIG_PPC_UDBG_16550=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 57 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 61 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| 58 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 59 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 60 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 61 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 62 | 67 | ||
| 63 | # | 68 | # |
| 64 | # General setup | 69 | # General setup |
| @@ -107,7 +112,6 @@ CONFIG_ANON_INODES=y | |||
| 107 | CONFIG_EMBEDDED=y | 112 | CONFIG_EMBEDDED=y |
| 108 | CONFIG_SYSCTL_SYSCALL=y | 113 | CONFIG_SYSCTL_SYSCALL=y |
| 109 | # CONFIG_KALLSYMS is not set | 114 | # CONFIG_KALLSYMS is not set |
| 110 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 111 | CONFIG_HOTPLUG=y | 115 | CONFIG_HOTPLUG=y |
| 112 | CONFIG_PRINTK=y | 116 | CONFIG_PRINTK=y |
| 113 | CONFIG_BUG=y | 117 | CONFIG_BUG=y |
| @@ -120,9 +124,16 @@ CONFIG_TIMERFD=y | |||
| 120 | CONFIG_EVENTFD=y | 124 | CONFIG_EVENTFD=y |
| 121 | CONFIG_SHMEM=y | 125 | CONFIG_SHMEM=y |
| 122 | CONFIG_AIO=y | 126 | CONFIG_AIO=y |
| 127 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 128 | |||
| 129 | # | ||
| 130 | # Performance Counters | ||
| 131 | # | ||
| 132 | # CONFIG_PERF_COUNTERS is not set | ||
| 123 | CONFIG_VM_EVENT_COUNTERS=y | 133 | CONFIG_VM_EVENT_COUNTERS=y |
| 124 | CONFIG_PCI_QUIRKS=y | 134 | CONFIG_PCI_QUIRKS=y |
| 125 | CONFIG_SLUB_DEBUG=y | 135 | CONFIG_SLUB_DEBUG=y |
| 136 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 126 | CONFIG_COMPAT_BRK=y | 137 | CONFIG_COMPAT_BRK=y |
| 127 | # CONFIG_SLAB is not set | 138 | # CONFIG_SLAB is not set |
| 128 | CONFIG_SLUB=y | 139 | CONFIG_SLUB=y |
| @@ -135,6 +146,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 135 | CONFIG_HAVE_KPROBES=y | 146 | CONFIG_HAVE_KPROBES=y |
| 136 | CONFIG_HAVE_KRETPROBES=y | 147 | CONFIG_HAVE_KRETPROBES=y |
| 137 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 148 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 149 | |||
| 150 | # | ||
| 151 | # GCOV-based kernel profiling | ||
| 152 | # | ||
| 138 | # CONFIG_SLOW_WORK is not set | 153 | # CONFIG_SLOW_WORK is not set |
| 139 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 140 | CONFIG_SLABINFO=y | 155 | CONFIG_SLABINFO=y |
| @@ -147,7 +162,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 147 | # CONFIG_MODVERSIONS is not set | 162 | # CONFIG_MODVERSIONS is not set |
| 148 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 163 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 149 | CONFIG_BLOCK=y | 164 | CONFIG_BLOCK=y |
| 150 | # CONFIG_LBD is not set | 165 | CONFIG_LBDAF=y |
| 151 | # CONFIG_BLK_DEV_BSG is not set | 166 | # CONFIG_BLK_DEV_BSG is not set |
| 152 | # CONFIG_BLK_DEV_INTEGRITY is not set | 167 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 153 | 168 | ||
| @@ -189,6 +204,7 @@ CONFIG_MPC831x_RDB=y | |||
| 189 | # CONFIG_MPC837x_RDB is not set | 204 | # CONFIG_MPC837x_RDB is not set |
| 190 | # CONFIG_SBC834x is not set | 205 | # CONFIG_SBC834x is not set |
| 191 | # CONFIG_ASP834x is not set | 206 | # CONFIG_ASP834x is not set |
| 207 | # CONFIG_KMETER1 is not set | ||
| 192 | CONFIG_PPC_MPC831x=y | 208 | CONFIG_PPC_MPC831x=y |
| 193 | # CONFIG_PPC_86xx is not set | 209 | # CONFIG_PPC_86xx is not set |
| 194 | # CONFIG_EMBEDDED6xx is not set | 210 | # CONFIG_EMBEDDED6xx is not set |
| @@ -234,6 +250,7 @@ CONFIG_BINFMT_ELF=y | |||
| 234 | # CONFIG_HAVE_AOUT is not set | 250 | # CONFIG_HAVE_AOUT is not set |
| 235 | # CONFIG_BINFMT_MISC is not set | 251 | # CONFIG_BINFMT_MISC is not set |
| 236 | # CONFIG_IOMMU_HELPER is not set | 252 | # CONFIG_IOMMU_HELPER is not set |
| 253 | # CONFIG_SWIOTLB is not set | ||
| 237 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 254 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 238 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 255 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 239 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 256 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -254,9 +271,9 @@ CONFIG_MIGRATION=y | |||
| 254 | CONFIG_ZONE_DMA_FLAG=1 | 271 | CONFIG_ZONE_DMA_FLAG=1 |
| 255 | CONFIG_BOUNCE=y | 272 | CONFIG_BOUNCE=y |
| 256 | CONFIG_VIRT_TO_BUS=y | 273 | CONFIG_VIRT_TO_BUS=y |
| 257 | CONFIG_UNEVICTABLE_LRU=y | ||
| 258 | CONFIG_HAVE_MLOCK=y | 274 | CONFIG_HAVE_MLOCK=y |
| 259 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 275 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 276 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 260 | CONFIG_PPC_4K_PAGES=y | 277 | CONFIG_PPC_4K_PAGES=y |
| 261 | # CONFIG_PPC_16K_PAGES is not set | 278 | # CONFIG_PPC_16K_PAGES is not set |
| 262 | # CONFIG_PPC_64K_PAGES is not set | 279 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -366,6 +383,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 366 | # CONFIG_ECONET is not set | 383 | # CONFIG_ECONET is not set |
| 367 | # CONFIG_WAN_ROUTER is not set | 384 | # CONFIG_WAN_ROUTER is not set |
| 368 | # CONFIG_PHONET is not set | 385 | # CONFIG_PHONET is not set |
| 386 | # CONFIG_IEEE802154 is not set | ||
| 369 | # CONFIG_NET_SCHED is not set | 387 | # CONFIG_NET_SCHED is not set |
| 370 | # CONFIG_DCB is not set | 388 | # CONFIG_DCB is not set |
| 371 | 389 | ||
| @@ -383,7 +401,11 @@ CONFIG_WIRELESS=y | |||
| 383 | CONFIG_WIRELESS_OLD_REGULATORY=y | 401 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 384 | # CONFIG_WIRELESS_EXT is not set | 402 | # CONFIG_WIRELESS_EXT is not set |
| 385 | # CONFIG_LIB80211 is not set | 403 | # CONFIG_LIB80211 is not set |
| 386 | # CONFIG_MAC80211 is not set | 404 | |
| 405 | # | ||
| 406 | # CFG80211 needs to be enabled for MAC80211 | ||
| 407 | # | ||
| 408 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 387 | # CONFIG_WIMAX is not set | 409 | # CONFIG_WIMAX is not set |
| 388 | # CONFIG_RFKILL is not set | 410 | # CONFIG_RFKILL is not set |
| 389 | # CONFIG_NET_9P is not set | 411 | # CONFIG_NET_9P is not set |
| @@ -503,6 +525,7 @@ CONFIG_MTD_NAND_FSL_ELBC=y | |||
| 503 | CONFIG_OF_DEVICE=y | 525 | CONFIG_OF_DEVICE=y |
| 504 | CONFIG_OF_I2C=y | 526 | CONFIG_OF_I2C=y |
| 505 | CONFIG_OF_SPI=y | 527 | CONFIG_OF_SPI=y |
| 528 | CONFIG_OF_MDIO=y | ||
| 506 | # CONFIG_PARPORT is not set | 529 | # CONFIG_PARPORT is not set |
| 507 | CONFIG_BLK_DEV=y | 530 | CONFIG_BLK_DEV=y |
| 508 | # CONFIG_BLK_DEV_FD is not set | 531 | # CONFIG_BLK_DEV_FD is not set |
| @@ -539,7 +562,9 @@ CONFIG_MISC_DEVICES=y | |||
| 539 | # CONFIG_EEPROM_AT24 is not set | 562 | # CONFIG_EEPROM_AT24 is not set |
| 540 | # CONFIG_EEPROM_AT25 is not set | 563 | # CONFIG_EEPROM_AT25 is not set |
| 541 | # CONFIG_EEPROM_LEGACY is not set | 564 | # CONFIG_EEPROM_LEGACY is not set |
| 565 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 542 | # CONFIG_EEPROM_93CX6 is not set | 566 | # CONFIG_EEPROM_93CX6 is not set |
| 567 | # CONFIG_CB710_CORE is not set | ||
| 543 | CONFIG_HAVE_IDE=y | 568 | CONFIG_HAVE_IDE=y |
| 544 | # CONFIG_IDE is not set | 569 | # CONFIG_IDE is not set |
| 545 | 570 | ||
| @@ -562,10 +587,6 @@ CONFIG_SCSI_PROC_FS=y | |||
| 562 | # CONFIG_BLK_DEV_SR is not set | 587 | # CONFIG_BLK_DEV_SR is not set |
| 563 | CONFIG_CHR_DEV_SG=y | 588 | CONFIG_CHR_DEV_SG=y |
| 564 | # CONFIG_CHR_DEV_SCH is not set | 589 | # CONFIG_CHR_DEV_SCH is not set |
| 565 | |||
| 566 | # | ||
| 567 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 568 | # | ||
| 569 | # CONFIG_SCSI_MULTI_LUN is not set | 590 | # CONFIG_SCSI_MULTI_LUN is not set |
| 570 | # CONFIG_SCSI_CONSTANTS is not set | 591 | # CONFIG_SCSI_CONSTANTS is not set |
| 571 | # CONFIG_SCSI_LOGGING is not set | 592 | # CONFIG_SCSI_LOGGING is not set |
| @@ -583,6 +604,7 @@ CONFIG_SCSI_SPI_ATTRS=y | |||
| 583 | CONFIG_SCSI_LOWLEVEL=y | 604 | CONFIG_SCSI_LOWLEVEL=y |
| 584 | # CONFIG_ISCSI_TCP is not set | 605 | # CONFIG_ISCSI_TCP is not set |
| 585 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 606 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 607 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 586 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 608 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 587 | # CONFIG_SCSI_3W_9XXX is not set | 609 | # CONFIG_SCSI_3W_9XXX is not set |
| 588 | # CONFIG_SCSI_ACARD is not set | 610 | # CONFIG_SCSI_ACARD is not set |
| @@ -591,6 +613,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 591 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 613 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 592 | # CONFIG_SCSI_AIC79XX is not set | 614 | # CONFIG_SCSI_AIC79XX is not set |
| 593 | # CONFIG_SCSI_AIC94XX is not set | 615 | # CONFIG_SCSI_AIC94XX is not set |
| 616 | # CONFIG_SCSI_MVSAS is not set | ||
| 594 | # CONFIG_SCSI_DPT_I2O is not set | 617 | # CONFIG_SCSI_DPT_I2O is not set |
| 595 | # CONFIG_SCSI_ADVANSYS is not set | 618 | # CONFIG_SCSI_ADVANSYS is not set |
| 596 | # CONFIG_SCSI_ARCMSR is not set | 619 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -610,7 +633,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 610 | # CONFIG_SCSI_IPS is not set | 633 | # CONFIG_SCSI_IPS is not set |
| 611 | # CONFIG_SCSI_INITIO is not set | 634 | # CONFIG_SCSI_INITIO is not set |
| 612 | # CONFIG_SCSI_INIA100 is not set | 635 | # CONFIG_SCSI_INIA100 is not set |
| 613 | # CONFIG_SCSI_MVSAS is not set | ||
| 614 | # CONFIG_SCSI_STEX is not set | 636 | # CONFIG_SCSI_STEX is not set |
| 615 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 637 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 616 | # CONFIG_SCSI_QLOGIC_1280 is not set | 638 | # CONFIG_SCSI_QLOGIC_1280 is not set |
| @@ -643,14 +665,17 @@ CONFIG_MD_RAID1=y | |||
| 643 | # | 665 | # |
| 644 | 666 | ||
| 645 | # | 667 | # |
| 646 | # Enable only one of the two stacks, unless you know what you are doing | 668 | # You can enable one or both FireWire driver stacks. |
| 669 | # | ||
| 670 | |||
| 671 | # | ||
| 672 | # See the help texts for more information. | ||
| 647 | # | 673 | # |
| 648 | # CONFIG_FIREWIRE is not set | 674 | # CONFIG_FIREWIRE is not set |
| 649 | # CONFIG_IEEE1394 is not set | 675 | # CONFIG_IEEE1394 is not set |
| 650 | # CONFIG_I2O is not set | 676 | # CONFIG_I2O is not set |
| 651 | # CONFIG_MACINTOSH_DRIVERS is not set | 677 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 652 | CONFIG_NETDEVICES=y | 678 | CONFIG_NETDEVICES=y |
| 653 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 654 | # CONFIG_DUMMY is not set | 679 | # CONFIG_DUMMY is not set |
| 655 | # CONFIG_BONDING is not set | 680 | # CONFIG_BONDING is not set |
| 656 | # CONFIG_MACVLAN is not set | 681 | # CONFIG_MACVLAN is not set |
| @@ -714,6 +739,8 @@ CONFIG_E100=y | |||
| 714 | # CONFIG_SMSC9420 is not set | 739 | # CONFIG_SMSC9420 is not set |
| 715 | # CONFIG_SUNDANCE is not set | 740 | # CONFIG_SUNDANCE is not set |
| 716 | # CONFIG_TLAN is not set | 741 | # CONFIG_TLAN is not set |
| 742 | # CONFIG_KS8842 is not set | ||
| 743 | # CONFIG_KS8851 is not set | ||
| 717 | # CONFIG_VIA_RHINE is not set | 744 | # CONFIG_VIA_RHINE is not set |
| 718 | # CONFIG_SC92031 is not set | 745 | # CONFIG_SC92031 is not set |
| 719 | # CONFIG_ATL2 is not set | 746 | # CONFIG_ATL2 is not set |
| @@ -735,8 +762,10 @@ CONFIG_NETDEV_1000=y | |||
| 735 | # CONFIG_VIA_VELOCITY is not set | 762 | # CONFIG_VIA_VELOCITY is not set |
| 736 | # CONFIG_TIGON3 is not set | 763 | # CONFIG_TIGON3 is not set |
| 737 | # CONFIG_BNX2 is not set | 764 | # CONFIG_BNX2 is not set |
| 765 | # CONFIG_CNIC is not set | ||
| 738 | CONFIG_FSL_PQ_MDIO=y | 766 | CONFIG_FSL_PQ_MDIO=y |
| 739 | CONFIG_GIANFAR=y | 767 | CONFIG_GIANFAR=y |
| 768 | # CONFIG_MV643XX_ETH is not set | ||
| 740 | # CONFIG_QLA3XXX is not set | 769 | # CONFIG_QLA3XXX is not set |
| 741 | # CONFIG_ATL1 is not set | 770 | # CONFIG_ATL1 is not set |
| 742 | # CONFIG_ATL1E is not set | 771 | # CONFIG_ATL1E is not set |
| @@ -924,7 +953,6 @@ CONFIG_I2C_MPC=y | |||
| 924 | # CONFIG_SENSORS_PCF8574 is not set | 953 | # CONFIG_SENSORS_PCF8574 is not set |
| 925 | # CONFIG_PCF8575 is not set | 954 | # CONFIG_PCF8575 is not set |
| 926 | # CONFIG_SENSORS_PCA9539 is not set | 955 | # CONFIG_SENSORS_PCA9539 is not set |
| 927 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 928 | # CONFIG_SENSORS_TSL2550 is not set | 956 | # CONFIG_SENSORS_TSL2550 is not set |
| 929 | # CONFIG_I2C_DEBUG_CORE is not set | 957 | # CONFIG_I2C_DEBUG_CORE is not set |
| 930 | # CONFIG_I2C_DEBUG_ALGO is not set | 958 | # CONFIG_I2C_DEBUG_ALGO is not set |
| @@ -938,13 +966,18 @@ CONFIG_SPI_MASTER=y | |||
| 938 | # SPI Master Controller Drivers | 966 | # SPI Master Controller Drivers |
| 939 | # | 967 | # |
| 940 | CONFIG_SPI_BITBANG=y | 968 | CONFIG_SPI_BITBANG=y |
| 941 | CONFIG_SPI_MPC83xx=y | 969 | # CONFIG_SPI_MPC8xxx is not set |
| 942 | 970 | ||
| 943 | # | 971 | # |
| 944 | # SPI Protocol Masters | 972 | # SPI Protocol Masters |
| 945 | # | 973 | # |
| 946 | # CONFIG_SPI_SPIDEV is not set | 974 | # CONFIG_SPI_SPIDEV is not set |
| 947 | # CONFIG_SPI_TLE62X0 is not set | 975 | # CONFIG_SPI_TLE62X0 is not set |
| 976 | |||
| 977 | # | ||
| 978 | # PPS support | ||
| 979 | # | ||
| 980 | # CONFIG_PPS is not set | ||
| 948 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 981 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 949 | # CONFIG_GPIOLIB is not set | 982 | # CONFIG_GPIOLIB is not set |
| 950 | # CONFIG_W1 is not set | 983 | # CONFIG_W1 is not set |
| @@ -1002,6 +1035,7 @@ CONFIG_HWMON=y | |||
| 1002 | # CONFIG_SENSORS_SMSC47B397 is not set | 1035 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 1003 | # CONFIG_SENSORS_ADS7828 is not set | 1036 | # CONFIG_SENSORS_ADS7828 is not set |
| 1004 | # CONFIG_SENSORS_THMC50 is not set | 1037 | # CONFIG_SENSORS_THMC50 is not set |
| 1038 | # CONFIG_SENSORS_TMP401 is not set | ||
| 1005 | # CONFIG_SENSORS_VIA686A is not set | 1039 | # CONFIG_SENSORS_VIA686A is not set |
| 1006 | # CONFIG_SENSORS_VT1211 is not set | 1040 | # CONFIG_SENSORS_VT1211 is not set |
| 1007 | # CONFIG_SENSORS_VT8231 is not set | 1041 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -1056,24 +1090,10 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1056 | # CONFIG_MFD_WM8400 is not set | 1090 | # CONFIG_MFD_WM8400 is not set |
| 1057 | # CONFIG_MFD_WM8350_I2C is not set | 1091 | # CONFIG_MFD_WM8350_I2C is not set |
| 1058 | # CONFIG_MFD_PCF50633 is not set | 1092 | # CONFIG_MFD_PCF50633 is not set |
| 1093 | # CONFIG_AB3100_CORE is not set | ||
| 1094 | # CONFIG_EZX_PCAP is not set | ||
| 1059 | # CONFIG_REGULATOR is not set | 1095 | # CONFIG_REGULATOR is not set |
| 1060 | 1096 | # CONFIG_MEDIA_SUPPORT is not set | |
| 1061 | # | ||
| 1062 | # Multimedia devices | ||
| 1063 | # | ||
| 1064 | |||
| 1065 | # | ||
| 1066 | # Multimedia core support | ||
| 1067 | # | ||
| 1068 | # CONFIG_VIDEO_DEV is not set | ||
| 1069 | # CONFIG_DVB_CORE is not set | ||
| 1070 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1071 | |||
| 1072 | # | ||
| 1073 | # Multimedia drivers | ||
| 1074 | # | ||
| 1075 | CONFIG_DAB=y | ||
| 1076 | # CONFIG_USB_DABUSB is not set | ||
| 1077 | 1097 | ||
| 1078 | # | 1098 | # |
| 1079 | # Graphics support | 1099 | # Graphics support |
| @@ -1135,6 +1155,7 @@ CONFIG_USB_MON=y | |||
| 1135 | # USB Host Controller Drivers | 1155 | # USB Host Controller Drivers |
| 1136 | # | 1156 | # |
| 1137 | # CONFIG_USB_C67X00_HCD is not set | 1157 | # CONFIG_USB_C67X00_HCD is not set |
| 1158 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1138 | CONFIG_USB_EHCI_HCD=y | 1159 | CONFIG_USB_EHCI_HCD=y |
| 1139 | CONFIG_USB_EHCI_ROOT_HUB_TT=y | 1160 | CONFIG_USB_EHCI_ROOT_HUB_TT=y |
| 1140 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1161 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1144,9 +1165,9 @@ CONFIG_USB_EHCI_HCD_PPC_OF=y | |||
| 1144 | # CONFIG_USB_ISP116X_HCD is not set | 1165 | # CONFIG_USB_ISP116X_HCD is not set |
| 1145 | # CONFIG_USB_ISP1760_HCD is not set | 1166 | # CONFIG_USB_ISP1760_HCD is not set |
| 1146 | CONFIG_USB_OHCI_HCD=y | 1167 | CONFIG_USB_OHCI_HCD=y |
| 1147 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1148 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y | 1168 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y |
| 1149 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set | 1169 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set |
| 1170 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1150 | CONFIG_USB_OHCI_HCD_PCI=y | 1171 | CONFIG_USB_OHCI_HCD_PCI=y |
| 1151 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y | 1172 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y |
| 1152 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y | 1173 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y |
| @@ -1235,8 +1256,9 @@ CONFIG_USB_GADGET_SELECTED=y | |||
| 1235 | # CONFIG_USB_GADGET_OMAP is not set | 1256 | # CONFIG_USB_GADGET_OMAP is not set |
| 1236 | # CONFIG_USB_GADGET_PXA25X is not set | 1257 | # CONFIG_USB_GADGET_PXA25X is not set |
| 1237 | # CONFIG_USB_GADGET_PXA27X is not set | 1258 | # CONFIG_USB_GADGET_PXA27X is not set |
| 1238 | # CONFIG_USB_GADGET_S3C2410 is not set | 1259 | # CONFIG_USB_GADGET_S3C_HSOTG is not set |
| 1239 | # CONFIG_USB_GADGET_IMX is not set | 1260 | # CONFIG_USB_GADGET_IMX is not set |
| 1261 | # CONFIG_USB_GADGET_S3C2410 is not set | ||
| 1240 | # CONFIG_USB_GADGET_M66592 is not set | 1262 | # CONFIG_USB_GADGET_M66592 is not set |
| 1241 | # CONFIG_USB_GADGET_AMD5536UDC is not set | 1263 | # CONFIG_USB_GADGET_AMD5536UDC is not set |
| 1242 | # CONFIG_USB_GADGET_FSL_QE is not set | 1264 | # CONFIG_USB_GADGET_FSL_QE is not set |
| @@ -1244,9 +1266,11 @@ CONFIG_USB_GADGET_SELECTED=y | |||
| 1244 | CONFIG_USB_GADGET_NET2280=y | 1266 | CONFIG_USB_GADGET_NET2280=y |
| 1245 | CONFIG_USB_NET2280=y | 1267 | CONFIG_USB_NET2280=y |
| 1246 | # CONFIG_USB_GADGET_GOKU is not set | 1268 | # CONFIG_USB_GADGET_GOKU is not set |
| 1269 | # CONFIG_USB_GADGET_LANGWELL is not set | ||
| 1247 | # CONFIG_USB_GADGET_DUMMY_HCD is not set | 1270 | # CONFIG_USB_GADGET_DUMMY_HCD is not set |
| 1248 | CONFIG_USB_GADGET_DUALSPEED=y | 1271 | CONFIG_USB_GADGET_DUALSPEED=y |
| 1249 | # CONFIG_USB_ZERO is not set | 1272 | # CONFIG_USB_ZERO is not set |
| 1273 | # CONFIG_USB_AUDIO is not set | ||
| 1250 | CONFIG_USB_ETH=y | 1274 | CONFIG_USB_ETH=y |
| 1251 | CONFIG_USB_ETH_RNDIS=y | 1275 | CONFIG_USB_ETH_RNDIS=y |
| 1252 | # CONFIG_USB_GADGETFS is not set | 1276 | # CONFIG_USB_GADGETFS is not set |
| @@ -1298,6 +1322,7 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 1298 | # CONFIG_RTC_DRV_S35390A is not set | 1322 | # CONFIG_RTC_DRV_S35390A is not set |
| 1299 | # CONFIG_RTC_DRV_FM3130 is not set | 1323 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1300 | # CONFIG_RTC_DRV_RX8581 is not set | 1324 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1325 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1301 | 1326 | ||
| 1302 | # | 1327 | # |
| 1303 | # SPI RTC drivers | 1328 | # SPI RTC drivers |
| @@ -1332,6 +1357,10 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 1332 | # CONFIG_DMADEVICES is not set | 1357 | # CONFIG_DMADEVICES is not set |
| 1333 | # CONFIG_AUXDISPLAY is not set | 1358 | # CONFIG_AUXDISPLAY is not set |
| 1334 | # CONFIG_UIO is not set | 1359 | # CONFIG_UIO is not set |
| 1360 | |||
| 1361 | # | ||
| 1362 | # TI VLYNQ | ||
| 1363 | # | ||
| 1335 | # CONFIG_STAGING is not set | 1364 | # CONFIG_STAGING is not set |
| 1336 | 1365 | ||
| 1337 | # | 1366 | # |
| @@ -1351,10 +1380,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1351 | # CONFIG_REISERFS_FS is not set | 1380 | # CONFIG_REISERFS_FS is not set |
| 1352 | # CONFIG_JFS_FS is not set | 1381 | # CONFIG_JFS_FS is not set |
| 1353 | # CONFIG_FS_POSIX_ACL is not set | 1382 | # CONFIG_FS_POSIX_ACL is not set |
| 1354 | CONFIG_FILE_LOCKING=y | ||
| 1355 | # CONFIG_XFS_FS is not set | 1383 | # CONFIG_XFS_FS is not set |
| 1384 | # CONFIG_GFS2_FS is not set | ||
| 1356 | # CONFIG_OCFS2_FS is not set | 1385 | # CONFIG_OCFS2_FS is not set |
| 1357 | # CONFIG_BTRFS_FS is not set | 1386 | # CONFIG_BTRFS_FS is not set |
| 1387 | CONFIG_FILE_LOCKING=y | ||
| 1388 | CONFIG_FSNOTIFY=y | ||
| 1358 | CONFIG_DNOTIFY=y | 1389 | CONFIG_DNOTIFY=y |
| 1359 | CONFIG_INOTIFY=y | 1390 | CONFIG_INOTIFY=y |
| 1360 | CONFIG_INOTIFY_USER=y | 1391 | CONFIG_INOTIFY_USER=y |
| @@ -1428,6 +1459,7 @@ CONFIG_NFS_FS=y | |||
| 1428 | CONFIG_NFS_V3=y | 1459 | CONFIG_NFS_V3=y |
| 1429 | # CONFIG_NFS_V3_ACL is not set | 1460 | # CONFIG_NFS_V3_ACL is not set |
| 1430 | CONFIG_NFS_V4=y | 1461 | CONFIG_NFS_V4=y |
| 1462 | # CONFIG_NFS_V4_1 is not set | ||
| 1431 | CONFIG_ROOT_NFS=y | 1463 | CONFIG_ROOT_NFS=y |
| 1432 | # CONFIG_NFSD is not set | 1464 | # CONFIG_NFSD is not set |
| 1433 | CONFIG_LOCKD=y | 1465 | CONFIG_LOCKD=y |
| @@ -1464,7 +1496,46 @@ CONFIG_MSDOS_PARTITION=y | |||
| 1464 | # CONFIG_KARMA_PARTITION is not set | 1496 | # CONFIG_KARMA_PARTITION is not set |
| 1465 | # CONFIG_EFI_PARTITION is not set | 1497 | # CONFIG_EFI_PARTITION is not set |
| 1466 | # CONFIG_SYSV68_PARTITION is not set | 1498 | # CONFIG_SYSV68_PARTITION is not set |
| 1467 | # CONFIG_NLS is not set | 1499 | CONFIG_NLS=y |
| 1500 | CONFIG_NLS_DEFAULT="iso8859-1" | ||
| 1501 | # CONFIG_NLS_CODEPAGE_437 is not set | ||
| 1502 | # CONFIG_NLS_CODEPAGE_737 is not set | ||
| 1503 | # CONFIG_NLS_CODEPAGE_775 is not set | ||
| 1504 | # CONFIG_NLS_CODEPAGE_850 is not set | ||
| 1505 | # CONFIG_NLS_CODEPAGE_852 is not set | ||
| 1506 | # CONFIG_NLS_CODEPAGE_855 is not set | ||
| 1507 | # CONFIG_NLS_CODEPAGE_857 is not set | ||
| 1508 | # CONFIG_NLS_CODEPAGE_860 is not set | ||
| 1509 | # CONFIG_NLS_CODEPAGE_861 is not set | ||
| 1510 | # CONFIG_NLS_CODEPAGE_862 is not set | ||
| 1511 | # CONFIG_NLS_CODEPAGE_863 is not set | ||
| 1512 | # CONFIG_NLS_CODEPAGE_864 is not set | ||
| 1513 | # CONFIG_NLS_CODEPAGE_865 is not set | ||
| 1514 | # CONFIG_NLS_CODEPAGE_866 is not set | ||
| 1515 | # CONFIG_NLS_CODEPAGE_869 is not set | ||
| 1516 | # CONFIG_NLS_CODEPAGE_936 is not set | ||
| 1517 | # CONFIG_NLS_CODEPAGE_950 is not set | ||
| 1518 | # CONFIG_NLS_CODEPAGE_932 is not set | ||
| 1519 | # CONFIG_NLS_CODEPAGE_949 is not set | ||
| 1520 | # CONFIG_NLS_CODEPAGE_874 is not set | ||
| 1521 | # CONFIG_NLS_ISO8859_8 is not set | ||
| 1522 | # CONFIG_NLS_CODEPAGE_1250 is not set | ||
| 1523 | # CONFIG_NLS_CODEPAGE_1251 is not set | ||
| 1524 | # CONFIG_NLS_ASCII is not set | ||
| 1525 | # CONFIG_NLS_ISO8859_1 is not set | ||
| 1526 | # CONFIG_NLS_ISO8859_2 is not set | ||
| 1527 | # CONFIG_NLS_ISO8859_3 is not set | ||
| 1528 | # CONFIG_NLS_ISO8859_4 is not set | ||
| 1529 | # CONFIG_NLS_ISO8859_5 is not set | ||
| 1530 | # CONFIG_NLS_ISO8859_6 is not set | ||
| 1531 | # CONFIG_NLS_ISO8859_7 is not set | ||
| 1532 | # CONFIG_NLS_ISO8859_9 is not set | ||
| 1533 | # CONFIG_NLS_ISO8859_13 is not set | ||
| 1534 | # CONFIG_NLS_ISO8859_14 is not set | ||
| 1535 | # CONFIG_NLS_ISO8859_15 is not set | ||
| 1536 | # CONFIG_NLS_KOI8_R is not set | ||
| 1537 | # CONFIG_NLS_KOI8_U is not set | ||
| 1538 | # CONFIG_NLS_UTF8 is not set | ||
| 1468 | # CONFIG_DLM is not set | 1539 | # CONFIG_DLM is not set |
| 1469 | # CONFIG_BINARY_PRINTF is not set | 1540 | # CONFIG_BINARY_PRINTF is not set |
| 1470 | 1541 | ||
| @@ -1488,6 +1559,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1488 | CONFIG_HAS_DMA=y | 1559 | CONFIG_HAS_DMA=y |
| 1489 | CONFIG_HAVE_LMB=y | 1560 | CONFIG_HAVE_LMB=y |
| 1490 | CONFIG_NLATTR=y | 1561 | CONFIG_NLATTR=y |
| 1562 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1491 | 1563 | ||
| 1492 | # | 1564 | # |
| 1493 | # Kernel hacking | 1565 | # Kernel hacking |
| @@ -1518,6 +1590,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 1518 | # CONFIG_RT_MUTEX_TESTER is not set | 1590 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1519 | # CONFIG_DEBUG_SPINLOCK is not set | 1591 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1520 | # CONFIG_DEBUG_MUTEXES is not set | 1592 | # CONFIG_DEBUG_MUTEXES is not set |
| 1593 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1594 | # CONFIG_PROVE_LOCKING is not set | ||
| 1595 | # CONFIG_LOCK_STAT is not set | ||
| 1521 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1596 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1522 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1597 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1523 | # CONFIG_DEBUG_KOBJECT is not set | 1598 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1529,7 +1604,6 @@ CONFIG_SCHED_DEBUG=y | |||
| 1529 | # CONFIG_DEBUG_LIST is not set | 1604 | # CONFIG_DEBUG_LIST is not set |
| 1530 | # CONFIG_DEBUG_SG is not set | 1605 | # CONFIG_DEBUG_SG is not set |
| 1531 | # CONFIG_DEBUG_NOTIFIERS is not set | 1606 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1532 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1533 | # CONFIG_RCU_TORTURE_TEST is not set | 1607 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1534 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1608 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1535 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1609 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1543,16 +1617,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1543 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1617 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1544 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1618 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1545 | CONFIG_TRACING_SUPPORT=y | 1619 | CONFIG_TRACING_SUPPORT=y |
| 1546 | 1620 | CONFIG_FTRACE=y | |
| 1547 | # | ||
| 1548 | # Tracers | ||
| 1549 | # | ||
| 1550 | # CONFIG_FUNCTION_TRACER is not set | 1621 | # CONFIG_FUNCTION_TRACER is not set |
| 1622 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1551 | # CONFIG_SCHED_TRACER is not set | 1623 | # CONFIG_SCHED_TRACER is not set |
| 1552 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1624 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1553 | # CONFIG_EVENT_TRACER is not set | ||
| 1554 | # CONFIG_BOOT_TRACER is not set | 1625 | # CONFIG_BOOT_TRACER is not set |
| 1555 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1626 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1627 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1628 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1556 | # CONFIG_STACK_TRACER is not set | 1629 | # CONFIG_STACK_TRACER is not set |
| 1557 | # CONFIG_KMEMTRACE is not set | 1630 | # CONFIG_KMEMTRACE is not set |
| 1558 | # CONFIG_WORKQUEUE_TRACER is not set | 1631 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -1560,6 +1633,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 1560 | # CONFIG_SAMPLES is not set | 1633 | # CONFIG_SAMPLES is not set |
| 1561 | CONFIG_HAVE_ARCH_KGDB=y | 1634 | CONFIG_HAVE_ARCH_KGDB=y |
| 1562 | # CONFIG_KGDB is not set | 1635 | # CONFIG_KGDB is not set |
| 1636 | # CONFIG_KMEMCHECK is not set | ||
| 1637 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1638 | CONFIG_PPC_WERROR=y | ||
| 1563 | CONFIG_PRINT_STACK_DEPTH=64 | 1639 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1564 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1640 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1565 | # CONFIG_DEBUG_STACK_USAGE is not set | 1641 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/83xx/mpc8315_rdb_defconfig b/arch/powerpc/configs/83xx/mpc8315_rdb_defconfig index af4952feba36..76237d466702 100644 --- a/arch/powerpc/configs/83xx/mpc8315_rdb_defconfig +++ b/arch/powerpc/configs/83xx/mpc8315_rdb_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:06 2009 | 4 | # Wed Jul 29 23:32:05 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_FSL_EMB_PERFMON is not set | 20 | # CONFIG_FSL_EMB_PERFMON is not set |
| 20 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 45 | CONFIG_PPC=y | 48 | CONFIG_PPC=y |
| @@ -53,12 +56,14 @@ CONFIG_PPC_UDBG_16550=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 57 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 61 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| 58 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 59 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 60 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 61 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 62 | 67 | ||
| 63 | # | 68 | # |
| 64 | # General setup | 69 | # General setup |
| @@ -107,7 +112,6 @@ CONFIG_ANON_INODES=y | |||
| 107 | CONFIG_EMBEDDED=y | 112 | CONFIG_EMBEDDED=y |
| 108 | CONFIG_SYSCTL_SYSCALL=y | 113 | CONFIG_SYSCTL_SYSCALL=y |
| 109 | # CONFIG_KALLSYMS is not set | 114 | # CONFIG_KALLSYMS is not set |
| 110 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 111 | CONFIG_HOTPLUG=y | 115 | CONFIG_HOTPLUG=y |
| 112 | CONFIG_PRINTK=y | 116 | CONFIG_PRINTK=y |
| 113 | CONFIG_BUG=y | 117 | CONFIG_BUG=y |
| @@ -120,9 +124,16 @@ CONFIG_TIMERFD=y | |||
| 120 | CONFIG_EVENTFD=y | 124 | CONFIG_EVENTFD=y |
| 121 | CONFIG_SHMEM=y | 125 | CONFIG_SHMEM=y |
| 122 | CONFIG_AIO=y | 126 | CONFIG_AIO=y |
| 127 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 128 | |||
| 129 | # | ||
| 130 | # Performance Counters | ||
| 131 | # | ||
| 132 | # CONFIG_PERF_COUNTERS is not set | ||
| 123 | CONFIG_VM_EVENT_COUNTERS=y | 133 | CONFIG_VM_EVENT_COUNTERS=y |
| 124 | CONFIG_PCI_QUIRKS=y | 134 | CONFIG_PCI_QUIRKS=y |
| 125 | CONFIG_SLUB_DEBUG=y | 135 | CONFIG_SLUB_DEBUG=y |
| 136 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 126 | CONFIG_COMPAT_BRK=y | 137 | CONFIG_COMPAT_BRK=y |
| 127 | # CONFIG_SLAB is not set | 138 | # CONFIG_SLAB is not set |
| 128 | CONFIG_SLUB=y | 139 | CONFIG_SLUB=y |
| @@ -135,6 +146,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 135 | CONFIG_HAVE_KPROBES=y | 146 | CONFIG_HAVE_KPROBES=y |
| 136 | CONFIG_HAVE_KRETPROBES=y | 147 | CONFIG_HAVE_KRETPROBES=y |
| 137 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 148 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 149 | |||
| 150 | # | ||
| 151 | # GCOV-based kernel profiling | ||
| 152 | # | ||
| 138 | # CONFIG_SLOW_WORK is not set | 153 | # CONFIG_SLOW_WORK is not set |
| 139 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 140 | CONFIG_SLABINFO=y | 155 | CONFIG_SLABINFO=y |
| @@ -147,7 +162,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 147 | # CONFIG_MODVERSIONS is not set | 162 | # CONFIG_MODVERSIONS is not set |
| 148 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 163 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 149 | CONFIG_BLOCK=y | 164 | CONFIG_BLOCK=y |
| 150 | # CONFIG_LBD is not set | 165 | CONFIG_LBDAF=y |
| 151 | # CONFIG_BLK_DEV_BSG is not set | 166 | # CONFIG_BLK_DEV_BSG is not set |
| 152 | # CONFIG_BLK_DEV_INTEGRITY is not set | 167 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 153 | 168 | ||
| @@ -189,6 +204,7 @@ CONFIG_MPC831x_RDB=y | |||
| 189 | # CONFIG_MPC837x_RDB is not set | 204 | # CONFIG_MPC837x_RDB is not set |
| 190 | # CONFIG_SBC834x is not set | 205 | # CONFIG_SBC834x is not set |
| 191 | # CONFIG_ASP834x is not set | 206 | # CONFIG_ASP834x is not set |
| 207 | # CONFIG_KMETER1 is not set | ||
| 192 | CONFIG_PPC_MPC831x=y | 208 | CONFIG_PPC_MPC831x=y |
| 193 | # CONFIG_PPC_86xx is not set | 209 | # CONFIG_PPC_86xx is not set |
| 194 | # CONFIG_EMBEDDED6xx is not set | 210 | # CONFIG_EMBEDDED6xx is not set |
| @@ -234,6 +250,7 @@ CONFIG_BINFMT_ELF=y | |||
| 234 | # CONFIG_HAVE_AOUT is not set | 250 | # CONFIG_HAVE_AOUT is not set |
| 235 | # CONFIG_BINFMT_MISC is not set | 251 | # CONFIG_BINFMT_MISC is not set |
| 236 | # CONFIG_IOMMU_HELPER is not set | 252 | # CONFIG_IOMMU_HELPER is not set |
| 253 | # CONFIG_SWIOTLB is not set | ||
| 237 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 254 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 238 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 255 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 239 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 256 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -254,9 +271,9 @@ CONFIG_MIGRATION=y | |||
| 254 | CONFIG_ZONE_DMA_FLAG=1 | 271 | CONFIG_ZONE_DMA_FLAG=1 |
| 255 | CONFIG_BOUNCE=y | 272 | CONFIG_BOUNCE=y |
| 256 | CONFIG_VIRT_TO_BUS=y | 273 | CONFIG_VIRT_TO_BUS=y |
| 257 | CONFIG_UNEVICTABLE_LRU=y | ||
| 258 | CONFIG_HAVE_MLOCK=y | 274 | CONFIG_HAVE_MLOCK=y |
| 259 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 275 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 276 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 260 | CONFIG_PPC_4K_PAGES=y | 277 | CONFIG_PPC_4K_PAGES=y |
| 261 | # CONFIG_PPC_16K_PAGES is not set | 278 | # CONFIG_PPC_16K_PAGES is not set |
| 262 | # CONFIG_PPC_64K_PAGES is not set | 279 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -366,6 +383,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 366 | # CONFIG_ECONET is not set | 383 | # CONFIG_ECONET is not set |
| 367 | # CONFIG_WAN_ROUTER is not set | 384 | # CONFIG_WAN_ROUTER is not set |
| 368 | # CONFIG_PHONET is not set | 385 | # CONFIG_PHONET is not set |
| 386 | # CONFIG_IEEE802154 is not set | ||
| 369 | # CONFIG_NET_SCHED is not set | 387 | # CONFIG_NET_SCHED is not set |
| 370 | # CONFIG_DCB is not set | 388 | # CONFIG_DCB is not set |
| 371 | 389 | ||
| @@ -383,7 +401,11 @@ CONFIG_WIRELESS=y | |||
| 383 | CONFIG_WIRELESS_OLD_REGULATORY=y | 401 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 384 | # CONFIG_WIRELESS_EXT is not set | 402 | # CONFIG_WIRELESS_EXT is not set |
| 385 | # CONFIG_LIB80211 is not set | 403 | # CONFIG_LIB80211 is not set |
| 386 | # CONFIG_MAC80211 is not set | 404 | |
| 405 | # | ||
| 406 | # CFG80211 needs to be enabled for MAC80211 | ||
| 407 | # | ||
| 408 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 387 | # CONFIG_WIMAX is not set | 409 | # CONFIG_WIMAX is not set |
| 388 | # CONFIG_RFKILL is not set | 410 | # CONFIG_RFKILL is not set |
| 389 | # CONFIG_NET_9P is not set | 411 | # CONFIG_NET_9P is not set |
| @@ -503,6 +525,7 @@ CONFIG_MTD_NAND_IDS=y | |||
| 503 | CONFIG_OF_DEVICE=y | 525 | CONFIG_OF_DEVICE=y |
| 504 | CONFIG_OF_I2C=y | 526 | CONFIG_OF_I2C=y |
| 505 | CONFIG_OF_SPI=y | 527 | CONFIG_OF_SPI=y |
| 528 | CONFIG_OF_MDIO=y | ||
| 506 | # CONFIG_PARPORT is not set | 529 | # CONFIG_PARPORT is not set |
| 507 | CONFIG_BLK_DEV=y | 530 | CONFIG_BLK_DEV=y |
| 508 | # CONFIG_BLK_DEV_FD is not set | 531 | # CONFIG_BLK_DEV_FD is not set |
| @@ -539,7 +562,9 @@ CONFIG_MISC_DEVICES=y | |||
| 539 | # CONFIG_EEPROM_AT24 is not set | 562 | # CONFIG_EEPROM_AT24 is not set |
| 540 | # CONFIG_EEPROM_AT25 is not set | 563 | # CONFIG_EEPROM_AT25 is not set |
| 541 | # CONFIG_EEPROM_LEGACY is not set | 564 | # CONFIG_EEPROM_LEGACY is not set |
| 565 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 542 | # CONFIG_EEPROM_93CX6 is not set | 566 | # CONFIG_EEPROM_93CX6 is not set |
| 567 | # CONFIG_CB710_CORE is not set | ||
| 543 | CONFIG_HAVE_IDE=y | 568 | CONFIG_HAVE_IDE=y |
| 544 | # CONFIG_IDE is not set | 569 | # CONFIG_IDE is not set |
| 545 | 570 | ||
| @@ -562,10 +587,6 @@ CONFIG_SCSI_PROC_FS=y | |||
| 562 | # CONFIG_BLK_DEV_SR is not set | 587 | # CONFIG_BLK_DEV_SR is not set |
| 563 | CONFIG_CHR_DEV_SG=y | 588 | CONFIG_CHR_DEV_SG=y |
| 564 | # CONFIG_CHR_DEV_SCH is not set | 589 | # CONFIG_CHR_DEV_SCH is not set |
| 565 | |||
| 566 | # | ||
| 567 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 568 | # | ||
| 569 | # CONFIG_SCSI_MULTI_LUN is not set | 590 | # CONFIG_SCSI_MULTI_LUN is not set |
| 570 | # CONFIG_SCSI_CONSTANTS is not set | 591 | # CONFIG_SCSI_CONSTANTS is not set |
| 571 | # CONFIG_SCSI_LOGGING is not set | 592 | # CONFIG_SCSI_LOGGING is not set |
| @@ -583,6 +604,7 @@ CONFIG_SCSI_SPI_ATTRS=y | |||
| 583 | CONFIG_SCSI_LOWLEVEL=y | 604 | CONFIG_SCSI_LOWLEVEL=y |
| 584 | # CONFIG_ISCSI_TCP is not set | 605 | # CONFIG_ISCSI_TCP is not set |
| 585 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 606 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 607 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 586 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 608 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 587 | # CONFIG_SCSI_3W_9XXX is not set | 609 | # CONFIG_SCSI_3W_9XXX is not set |
| 588 | # CONFIG_SCSI_ACARD is not set | 610 | # CONFIG_SCSI_ACARD is not set |
| @@ -591,6 +613,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 591 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 613 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 592 | # CONFIG_SCSI_AIC79XX is not set | 614 | # CONFIG_SCSI_AIC79XX is not set |
| 593 | # CONFIG_SCSI_AIC94XX is not set | 615 | # CONFIG_SCSI_AIC94XX is not set |
| 616 | # CONFIG_SCSI_MVSAS is not set | ||
| 594 | # CONFIG_SCSI_DPT_I2O is not set | 617 | # CONFIG_SCSI_DPT_I2O is not set |
| 595 | # CONFIG_SCSI_ADVANSYS is not set | 618 | # CONFIG_SCSI_ADVANSYS is not set |
| 596 | # CONFIG_SCSI_ARCMSR is not set | 619 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -610,7 +633,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 610 | # CONFIG_SCSI_IPS is not set | 633 | # CONFIG_SCSI_IPS is not set |
| 611 | # CONFIG_SCSI_INITIO is not set | 634 | # CONFIG_SCSI_INITIO is not set |
| 612 | # CONFIG_SCSI_INIA100 is not set | 635 | # CONFIG_SCSI_INIA100 is not set |
| 613 | # CONFIG_SCSI_MVSAS is not set | ||
| 614 | # CONFIG_SCSI_STEX is not set | 636 | # CONFIG_SCSI_STEX is not set |
| 615 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 637 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 616 | # CONFIG_SCSI_IPR is not set | 638 | # CONFIG_SCSI_IPR is not set |
| @@ -704,14 +726,17 @@ CONFIG_MD_RAID1=y | |||
| 704 | # | 726 | # |
| 705 | 727 | ||
| 706 | # | 728 | # |
| 707 | # Enable only one of the two stacks, unless you know what you are doing | 729 | # You can enable one or both FireWire driver stacks. |
| 730 | # | ||
| 731 | |||
| 732 | # | ||
| 733 | # See the help texts for more information. | ||
| 708 | # | 734 | # |
| 709 | # CONFIG_FIREWIRE is not set | 735 | # CONFIG_FIREWIRE is not set |
| 710 | # CONFIG_IEEE1394 is not set | 736 | # CONFIG_IEEE1394 is not set |
| 711 | # CONFIG_I2O is not set | 737 | # CONFIG_I2O is not set |
| 712 | # CONFIG_MACINTOSH_DRIVERS is not set | 738 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 713 | CONFIG_NETDEVICES=y | 739 | CONFIG_NETDEVICES=y |
| 714 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 715 | # CONFIG_DUMMY is not set | 740 | # CONFIG_DUMMY is not set |
| 716 | # CONFIG_BONDING is not set | 741 | # CONFIG_BONDING is not set |
| 717 | # CONFIG_MACVLAN is not set | 742 | # CONFIG_MACVLAN is not set |
| @@ -775,6 +800,8 @@ CONFIG_E100=y | |||
| 775 | # CONFIG_SMSC9420 is not set | 800 | # CONFIG_SMSC9420 is not set |
| 776 | # CONFIG_SUNDANCE is not set | 801 | # CONFIG_SUNDANCE is not set |
| 777 | # CONFIG_TLAN is not set | 802 | # CONFIG_TLAN is not set |
| 803 | # CONFIG_KS8842 is not set | ||
| 804 | # CONFIG_KS8851 is not set | ||
| 778 | # CONFIG_VIA_RHINE is not set | 805 | # CONFIG_VIA_RHINE is not set |
| 779 | # CONFIG_SC92031 is not set | 806 | # CONFIG_SC92031 is not set |
| 780 | # CONFIG_ATL2 is not set | 807 | # CONFIG_ATL2 is not set |
| @@ -796,8 +823,10 @@ CONFIG_NETDEV_1000=y | |||
| 796 | # CONFIG_VIA_VELOCITY is not set | 823 | # CONFIG_VIA_VELOCITY is not set |
| 797 | # CONFIG_TIGON3 is not set | 824 | # CONFIG_TIGON3 is not set |
| 798 | # CONFIG_BNX2 is not set | 825 | # CONFIG_BNX2 is not set |
| 826 | # CONFIG_CNIC is not set | ||
| 799 | CONFIG_FSL_PQ_MDIO=y | 827 | CONFIG_FSL_PQ_MDIO=y |
| 800 | CONFIG_GIANFAR=y | 828 | CONFIG_GIANFAR=y |
| 829 | # CONFIG_MV643XX_ETH is not set | ||
| 801 | # CONFIG_QLA3XXX is not set | 830 | # CONFIG_QLA3XXX is not set |
| 802 | # CONFIG_ATL1 is not set | 831 | # CONFIG_ATL1 is not set |
| 803 | # CONFIG_ATL1E is not set | 832 | # CONFIG_ATL1E is not set |
| @@ -985,7 +1014,6 @@ CONFIG_I2C_MPC=y | |||
| 985 | # CONFIG_SENSORS_PCF8574 is not set | 1014 | # CONFIG_SENSORS_PCF8574 is not set |
| 986 | # CONFIG_PCF8575 is not set | 1015 | # CONFIG_PCF8575 is not set |
| 987 | # CONFIG_SENSORS_PCA9539 is not set | 1016 | # CONFIG_SENSORS_PCA9539 is not set |
| 988 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 989 | # CONFIG_SENSORS_TSL2550 is not set | 1017 | # CONFIG_SENSORS_TSL2550 is not set |
| 990 | # CONFIG_I2C_DEBUG_CORE is not set | 1018 | # CONFIG_I2C_DEBUG_CORE is not set |
| 991 | # CONFIG_I2C_DEBUG_ALGO is not set | 1019 | # CONFIG_I2C_DEBUG_ALGO is not set |
| @@ -999,13 +1027,18 @@ CONFIG_SPI_MASTER=y | |||
| 999 | # SPI Master Controller Drivers | 1027 | # SPI Master Controller Drivers |
| 1000 | # | 1028 | # |
| 1001 | CONFIG_SPI_BITBANG=y | 1029 | CONFIG_SPI_BITBANG=y |
| 1002 | CONFIG_SPI_MPC83xx=y | 1030 | # CONFIG_SPI_MPC8xxx is not set |
| 1003 | 1031 | ||
| 1004 | # | 1032 | # |
| 1005 | # SPI Protocol Masters | 1033 | # SPI Protocol Masters |
| 1006 | # | 1034 | # |
| 1007 | # CONFIG_SPI_SPIDEV is not set | 1035 | # CONFIG_SPI_SPIDEV is not set |
| 1008 | # CONFIG_SPI_TLE62X0 is not set | 1036 | # CONFIG_SPI_TLE62X0 is not set |
| 1037 | |||
| 1038 | # | ||
| 1039 | # PPS support | ||
| 1040 | # | ||
| 1041 | # CONFIG_PPS is not set | ||
| 1009 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 1042 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 1010 | # CONFIG_GPIOLIB is not set | 1043 | # CONFIG_GPIOLIB is not set |
| 1011 | # CONFIG_W1 is not set | 1044 | # CONFIG_W1 is not set |
| @@ -1063,6 +1096,7 @@ CONFIG_HWMON=y | |||
| 1063 | # CONFIG_SENSORS_SMSC47B397 is not set | 1096 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 1064 | # CONFIG_SENSORS_ADS7828 is not set | 1097 | # CONFIG_SENSORS_ADS7828 is not set |
| 1065 | # CONFIG_SENSORS_THMC50 is not set | 1098 | # CONFIG_SENSORS_THMC50 is not set |
| 1099 | # CONFIG_SENSORS_TMP401 is not set | ||
| 1066 | # CONFIG_SENSORS_VIA686A is not set | 1100 | # CONFIG_SENSORS_VIA686A is not set |
| 1067 | # CONFIG_SENSORS_VT1211 is not set | 1101 | # CONFIG_SENSORS_VT1211 is not set |
| 1068 | # CONFIG_SENSORS_VT8231 is not set | 1102 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -1117,24 +1151,10 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1117 | # CONFIG_MFD_WM8400 is not set | 1151 | # CONFIG_MFD_WM8400 is not set |
| 1118 | # CONFIG_MFD_WM8350_I2C is not set | 1152 | # CONFIG_MFD_WM8350_I2C is not set |
| 1119 | # CONFIG_MFD_PCF50633 is not set | 1153 | # CONFIG_MFD_PCF50633 is not set |
| 1154 | # CONFIG_AB3100_CORE is not set | ||
| 1155 | # CONFIG_EZX_PCAP is not set | ||
| 1120 | # CONFIG_REGULATOR is not set | 1156 | # CONFIG_REGULATOR is not set |
| 1121 | 1157 | # CONFIG_MEDIA_SUPPORT is not set | |
| 1122 | # | ||
| 1123 | # Multimedia devices | ||
| 1124 | # | ||
| 1125 | |||
| 1126 | # | ||
| 1127 | # Multimedia core support | ||
| 1128 | # | ||
| 1129 | # CONFIG_VIDEO_DEV is not set | ||
| 1130 | # CONFIG_DVB_CORE is not set | ||
| 1131 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1132 | |||
| 1133 | # | ||
| 1134 | # Multimedia drivers | ||
| 1135 | # | ||
| 1136 | CONFIG_DAB=y | ||
| 1137 | # CONFIG_USB_DABUSB is not set | ||
| 1138 | 1158 | ||
| 1139 | # | 1159 | # |
| 1140 | # Graphics support | 1160 | # Graphics support |
| @@ -1196,6 +1216,7 @@ CONFIG_USB_MON=y | |||
| 1196 | # USB Host Controller Drivers | 1216 | # USB Host Controller Drivers |
| 1197 | # | 1217 | # |
| 1198 | # CONFIG_USB_C67X00_HCD is not set | 1218 | # CONFIG_USB_C67X00_HCD is not set |
| 1219 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1199 | CONFIG_USB_EHCI_HCD=y | 1220 | CONFIG_USB_EHCI_HCD=y |
| 1200 | CONFIG_USB_EHCI_ROOT_HUB_TT=y | 1221 | CONFIG_USB_EHCI_ROOT_HUB_TT=y |
| 1201 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1222 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1205,9 +1226,9 @@ CONFIG_USB_EHCI_HCD_PPC_OF=y | |||
| 1205 | # CONFIG_USB_ISP116X_HCD is not set | 1226 | # CONFIG_USB_ISP116X_HCD is not set |
| 1206 | # CONFIG_USB_ISP1760_HCD is not set | 1227 | # CONFIG_USB_ISP1760_HCD is not set |
| 1207 | CONFIG_USB_OHCI_HCD=y | 1228 | CONFIG_USB_OHCI_HCD=y |
| 1208 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1209 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y | 1229 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y |
| 1210 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set | 1230 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set |
| 1231 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1211 | CONFIG_USB_OHCI_HCD_PCI=y | 1232 | CONFIG_USB_OHCI_HCD_PCI=y |
| 1212 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y | 1233 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y |
| 1213 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y | 1234 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y |
| @@ -1296,8 +1317,9 @@ CONFIG_USB_GADGET_SELECTED=y | |||
| 1296 | # CONFIG_USB_GADGET_OMAP is not set | 1317 | # CONFIG_USB_GADGET_OMAP is not set |
| 1297 | # CONFIG_USB_GADGET_PXA25X is not set | 1318 | # CONFIG_USB_GADGET_PXA25X is not set |
| 1298 | # CONFIG_USB_GADGET_PXA27X is not set | 1319 | # CONFIG_USB_GADGET_PXA27X is not set |
| 1299 | # CONFIG_USB_GADGET_S3C2410 is not set | 1320 | # CONFIG_USB_GADGET_S3C_HSOTG is not set |
| 1300 | # CONFIG_USB_GADGET_IMX is not set | 1321 | # CONFIG_USB_GADGET_IMX is not set |
| 1322 | # CONFIG_USB_GADGET_S3C2410 is not set | ||
| 1301 | # CONFIG_USB_GADGET_M66592 is not set | 1323 | # CONFIG_USB_GADGET_M66592 is not set |
| 1302 | # CONFIG_USB_GADGET_AMD5536UDC is not set | 1324 | # CONFIG_USB_GADGET_AMD5536UDC is not set |
| 1303 | # CONFIG_USB_GADGET_FSL_QE is not set | 1325 | # CONFIG_USB_GADGET_FSL_QE is not set |
| @@ -1305,9 +1327,11 @@ CONFIG_USB_GADGET_SELECTED=y | |||
| 1305 | CONFIG_USB_GADGET_NET2280=y | 1327 | CONFIG_USB_GADGET_NET2280=y |
| 1306 | CONFIG_USB_NET2280=y | 1328 | CONFIG_USB_NET2280=y |
| 1307 | # CONFIG_USB_GADGET_GOKU is not set | 1329 | # CONFIG_USB_GADGET_GOKU is not set |
| 1330 | # CONFIG_USB_GADGET_LANGWELL is not set | ||
| 1308 | # CONFIG_USB_GADGET_DUMMY_HCD is not set | 1331 | # CONFIG_USB_GADGET_DUMMY_HCD is not set |
| 1309 | CONFIG_USB_GADGET_DUALSPEED=y | 1332 | CONFIG_USB_GADGET_DUALSPEED=y |
| 1310 | # CONFIG_USB_ZERO is not set | 1333 | # CONFIG_USB_ZERO is not set |
| 1334 | # CONFIG_USB_AUDIO is not set | ||
| 1311 | CONFIG_USB_ETH=y | 1335 | CONFIG_USB_ETH=y |
| 1312 | CONFIG_USB_ETH_RNDIS=y | 1336 | CONFIG_USB_ETH_RNDIS=y |
| 1313 | # CONFIG_USB_GADGETFS is not set | 1337 | # CONFIG_USB_GADGETFS is not set |
| @@ -1359,6 +1383,7 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 1359 | # CONFIG_RTC_DRV_S35390A is not set | 1383 | # CONFIG_RTC_DRV_S35390A is not set |
| 1360 | # CONFIG_RTC_DRV_FM3130 is not set | 1384 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1361 | # CONFIG_RTC_DRV_RX8581 is not set | 1385 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1386 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1362 | 1387 | ||
| 1363 | # | 1388 | # |
| 1364 | # SPI RTC drivers | 1389 | # SPI RTC drivers |
| @@ -1393,6 +1418,10 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 1393 | # CONFIG_DMADEVICES is not set | 1418 | # CONFIG_DMADEVICES is not set |
| 1394 | # CONFIG_AUXDISPLAY is not set | 1419 | # CONFIG_AUXDISPLAY is not set |
| 1395 | # CONFIG_UIO is not set | 1420 | # CONFIG_UIO is not set |
| 1421 | |||
| 1422 | # | ||
| 1423 | # TI VLYNQ | ||
| 1424 | # | ||
| 1396 | # CONFIG_STAGING is not set | 1425 | # CONFIG_STAGING is not set |
| 1397 | 1426 | ||
| 1398 | # | 1427 | # |
| @@ -1412,10 +1441,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1412 | # CONFIG_REISERFS_FS is not set | 1441 | # CONFIG_REISERFS_FS is not set |
| 1413 | # CONFIG_JFS_FS is not set | 1442 | # CONFIG_JFS_FS is not set |
| 1414 | # CONFIG_FS_POSIX_ACL is not set | 1443 | # CONFIG_FS_POSIX_ACL is not set |
| 1415 | CONFIG_FILE_LOCKING=y | ||
| 1416 | # CONFIG_XFS_FS is not set | 1444 | # CONFIG_XFS_FS is not set |
| 1445 | # CONFIG_GFS2_FS is not set | ||
| 1417 | # CONFIG_OCFS2_FS is not set | 1446 | # CONFIG_OCFS2_FS is not set |
| 1418 | # CONFIG_BTRFS_FS is not set | 1447 | # CONFIG_BTRFS_FS is not set |
| 1448 | CONFIG_FILE_LOCKING=y | ||
| 1449 | CONFIG_FSNOTIFY=y | ||
| 1419 | CONFIG_DNOTIFY=y | 1450 | CONFIG_DNOTIFY=y |
| 1420 | CONFIG_INOTIFY=y | 1451 | CONFIG_INOTIFY=y |
| 1421 | CONFIG_INOTIFY_USER=y | 1452 | CONFIG_INOTIFY_USER=y |
| @@ -1489,6 +1520,7 @@ CONFIG_NFS_FS=y | |||
| 1489 | CONFIG_NFS_V3=y | 1520 | CONFIG_NFS_V3=y |
| 1490 | # CONFIG_NFS_V3_ACL is not set | 1521 | # CONFIG_NFS_V3_ACL is not set |
| 1491 | CONFIG_NFS_V4=y | 1522 | CONFIG_NFS_V4=y |
| 1523 | # CONFIG_NFS_V4_1 is not set | ||
| 1492 | CONFIG_ROOT_NFS=y | 1524 | CONFIG_ROOT_NFS=y |
| 1493 | # CONFIG_NFSD is not set | 1525 | # CONFIG_NFSD is not set |
| 1494 | CONFIG_LOCKD=y | 1526 | CONFIG_LOCKD=y |
| @@ -1525,7 +1557,46 @@ CONFIG_MSDOS_PARTITION=y | |||
| 1525 | # CONFIG_KARMA_PARTITION is not set | 1557 | # CONFIG_KARMA_PARTITION is not set |
| 1526 | # CONFIG_EFI_PARTITION is not set | 1558 | # CONFIG_EFI_PARTITION is not set |
| 1527 | # CONFIG_SYSV68_PARTITION is not set | 1559 | # CONFIG_SYSV68_PARTITION is not set |
| 1528 | # CONFIG_NLS is not set | 1560 | CONFIG_NLS=y |
| 1561 | CONFIG_NLS_DEFAULT="iso8859-1" | ||
| 1562 | # CONFIG_NLS_CODEPAGE_437 is not set | ||
| 1563 | # CONFIG_NLS_CODEPAGE_737 is not set | ||
| 1564 | # CONFIG_NLS_CODEPAGE_775 is not set | ||
| 1565 | # CONFIG_NLS_CODEPAGE_850 is not set | ||
| 1566 | # CONFIG_NLS_CODEPAGE_852 is not set | ||
| 1567 | # CONFIG_NLS_CODEPAGE_855 is not set | ||
| 1568 | # CONFIG_NLS_CODEPAGE_857 is not set | ||
| 1569 | # CONFIG_NLS_CODEPAGE_860 is not set | ||
| 1570 | # CONFIG_NLS_CODEPAGE_861 is not set | ||
| 1571 | # CONFIG_NLS_CODEPAGE_862 is not set | ||
| 1572 | # CONFIG_NLS_CODEPAGE_863 is not set | ||
| 1573 | # CONFIG_NLS_CODEPAGE_864 is not set | ||
| 1574 | # CONFIG_NLS_CODEPAGE_865 is not set | ||
| 1575 | # CONFIG_NLS_CODEPAGE_866 is not set | ||
| 1576 | # CONFIG_NLS_CODEPAGE_869 is not set | ||
| 1577 | # CONFIG_NLS_CODEPAGE_936 is not set | ||
| 1578 | # CONFIG_NLS_CODEPAGE_950 is not set | ||
| 1579 | # CONFIG_NLS_CODEPAGE_932 is not set | ||
| 1580 | # CONFIG_NLS_CODEPAGE_949 is not set | ||
| 1581 | # CONFIG_NLS_CODEPAGE_874 is not set | ||
| 1582 | # CONFIG_NLS_ISO8859_8 is not set | ||
| 1583 | # CONFIG_NLS_CODEPAGE_1250 is not set | ||
| 1584 | # CONFIG_NLS_CODEPAGE_1251 is not set | ||
| 1585 | # CONFIG_NLS_ASCII is not set | ||
| 1586 | # CONFIG_NLS_ISO8859_1 is not set | ||
| 1587 | # CONFIG_NLS_ISO8859_2 is not set | ||
| 1588 | # CONFIG_NLS_ISO8859_3 is not set | ||
| 1589 | # CONFIG_NLS_ISO8859_4 is not set | ||
| 1590 | # CONFIG_NLS_ISO8859_5 is not set | ||
| 1591 | # CONFIG_NLS_ISO8859_6 is not set | ||
| 1592 | # CONFIG_NLS_ISO8859_7 is not set | ||
| 1593 | # CONFIG_NLS_ISO8859_9 is not set | ||
| 1594 | # CONFIG_NLS_ISO8859_13 is not set | ||
| 1595 | # CONFIG_NLS_ISO8859_14 is not set | ||
| 1596 | # CONFIG_NLS_ISO8859_15 is not set | ||
| 1597 | # CONFIG_NLS_KOI8_R is not set | ||
| 1598 | # CONFIG_NLS_KOI8_U is not set | ||
| 1599 | # CONFIG_NLS_UTF8 is not set | ||
| 1529 | # CONFIG_DLM is not set | 1600 | # CONFIG_DLM is not set |
| 1530 | # CONFIG_BINARY_PRINTF is not set | 1601 | # CONFIG_BINARY_PRINTF is not set |
| 1531 | 1602 | ||
| @@ -1549,6 +1620,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1549 | CONFIG_HAS_DMA=y | 1620 | CONFIG_HAS_DMA=y |
| 1550 | CONFIG_HAVE_LMB=y | 1621 | CONFIG_HAVE_LMB=y |
| 1551 | CONFIG_NLATTR=y | 1622 | CONFIG_NLATTR=y |
| 1623 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1552 | 1624 | ||
| 1553 | # | 1625 | # |
| 1554 | # Kernel hacking | 1626 | # Kernel hacking |
| @@ -1579,6 +1651,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 1579 | # CONFIG_RT_MUTEX_TESTER is not set | 1651 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1580 | # CONFIG_DEBUG_SPINLOCK is not set | 1652 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1581 | # CONFIG_DEBUG_MUTEXES is not set | 1653 | # CONFIG_DEBUG_MUTEXES is not set |
| 1654 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1655 | # CONFIG_PROVE_LOCKING is not set | ||
| 1656 | # CONFIG_LOCK_STAT is not set | ||
| 1582 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1657 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1583 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1658 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1584 | # CONFIG_DEBUG_KOBJECT is not set | 1659 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1590,7 +1665,6 @@ CONFIG_SCHED_DEBUG=y | |||
| 1590 | # CONFIG_DEBUG_LIST is not set | 1665 | # CONFIG_DEBUG_LIST is not set |
| 1591 | # CONFIG_DEBUG_SG is not set | 1666 | # CONFIG_DEBUG_SG is not set |
| 1592 | # CONFIG_DEBUG_NOTIFIERS is not set | 1667 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1593 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1594 | # CONFIG_RCU_TORTURE_TEST is not set | 1668 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1595 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1669 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1596 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1670 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1604,16 +1678,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1604 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1678 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1605 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1679 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1606 | CONFIG_TRACING_SUPPORT=y | 1680 | CONFIG_TRACING_SUPPORT=y |
| 1607 | 1681 | CONFIG_FTRACE=y | |
| 1608 | # | ||
| 1609 | # Tracers | ||
| 1610 | # | ||
| 1611 | # CONFIG_FUNCTION_TRACER is not set | 1682 | # CONFIG_FUNCTION_TRACER is not set |
| 1683 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1612 | # CONFIG_SCHED_TRACER is not set | 1684 | # CONFIG_SCHED_TRACER is not set |
| 1613 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1685 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1614 | # CONFIG_EVENT_TRACER is not set | ||
| 1615 | # CONFIG_BOOT_TRACER is not set | 1686 | # CONFIG_BOOT_TRACER is not set |
| 1616 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1687 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1688 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1689 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1617 | # CONFIG_STACK_TRACER is not set | 1690 | # CONFIG_STACK_TRACER is not set |
| 1618 | # CONFIG_KMEMTRACE is not set | 1691 | # CONFIG_KMEMTRACE is not set |
| 1619 | # CONFIG_WORKQUEUE_TRACER is not set | 1692 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -1621,6 +1694,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 1621 | # CONFIG_SAMPLES is not set | 1694 | # CONFIG_SAMPLES is not set |
| 1622 | CONFIG_HAVE_ARCH_KGDB=y | 1695 | CONFIG_HAVE_ARCH_KGDB=y |
| 1623 | # CONFIG_KGDB is not set | 1696 | # CONFIG_KGDB is not set |
| 1697 | # CONFIG_KMEMCHECK is not set | ||
| 1698 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1699 | CONFIG_PPC_WERROR=y | ||
| 1624 | CONFIG_PRINT_STACK_DEPTH=64 | 1700 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1625 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1701 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1626 | # CONFIG_DEBUG_STACK_USAGE is not set | 1702 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/83xx/mpc832x_mds_defconfig b/arch/powerpc/configs/83xx/mpc832x_mds_defconfig index 8c8f660b4fc7..e0e36a113409 100644 --- a/arch/powerpc/configs/83xx/mpc832x_mds_defconfig +++ b/arch/powerpc/configs/83xx/mpc832x_mds_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:07 2009 | 4 | # Wed Jul 29 23:32:06 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_FSL_EMB_PERFMON is not set | 20 | # CONFIG_FSL_EMB_PERFMON is not set |
| 20 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 45 | CONFIG_PPC=y | 48 | CONFIG_PPC=y |
| @@ -53,12 +56,14 @@ CONFIG_PPC_UDBG_16550=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 57 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 61 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| 58 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 59 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 60 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 61 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 62 | 67 | ||
| 63 | # | 68 | # |
| 64 | # General setup | 69 | # General setup |
| @@ -107,7 +112,6 @@ CONFIG_ANON_INODES=y | |||
| 107 | CONFIG_EMBEDDED=y | 112 | CONFIG_EMBEDDED=y |
| 108 | CONFIG_SYSCTL_SYSCALL=y | 113 | CONFIG_SYSCTL_SYSCALL=y |
| 109 | # CONFIG_KALLSYMS is not set | 114 | # CONFIG_KALLSYMS is not set |
| 110 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 111 | CONFIG_HOTPLUG=y | 115 | CONFIG_HOTPLUG=y |
| 112 | CONFIG_PRINTK=y | 116 | CONFIG_PRINTK=y |
| 113 | CONFIG_BUG=y | 117 | CONFIG_BUG=y |
| @@ -120,9 +124,16 @@ CONFIG_TIMERFD=y | |||
| 120 | CONFIG_EVENTFD=y | 124 | CONFIG_EVENTFD=y |
| 121 | CONFIG_SHMEM=y | 125 | CONFIG_SHMEM=y |
| 122 | CONFIG_AIO=y | 126 | CONFIG_AIO=y |
| 127 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 128 | |||
| 129 | # | ||
| 130 | # Performance Counters | ||
| 131 | # | ||
| 132 | # CONFIG_PERF_COUNTERS is not set | ||
| 123 | CONFIG_VM_EVENT_COUNTERS=y | 133 | CONFIG_VM_EVENT_COUNTERS=y |
| 124 | CONFIG_PCI_QUIRKS=y | 134 | CONFIG_PCI_QUIRKS=y |
| 125 | CONFIG_SLUB_DEBUG=y | 135 | CONFIG_SLUB_DEBUG=y |
| 136 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 126 | CONFIG_COMPAT_BRK=y | 137 | CONFIG_COMPAT_BRK=y |
| 127 | # CONFIG_SLAB is not set | 138 | # CONFIG_SLAB is not set |
| 128 | CONFIG_SLUB=y | 139 | CONFIG_SLUB=y |
| @@ -135,6 +146,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 135 | CONFIG_HAVE_KPROBES=y | 146 | CONFIG_HAVE_KPROBES=y |
| 136 | CONFIG_HAVE_KRETPROBES=y | 147 | CONFIG_HAVE_KRETPROBES=y |
| 137 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 148 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 149 | |||
| 150 | # | ||
| 151 | # GCOV-based kernel profiling | ||
| 152 | # | ||
| 138 | # CONFIG_SLOW_WORK is not set | 153 | # CONFIG_SLOW_WORK is not set |
| 139 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 140 | CONFIG_SLABINFO=y | 155 | CONFIG_SLABINFO=y |
| @@ -147,7 +162,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 147 | # CONFIG_MODVERSIONS is not set | 162 | # CONFIG_MODVERSIONS is not set |
| 148 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 163 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 149 | CONFIG_BLOCK=y | 164 | CONFIG_BLOCK=y |
| 150 | # CONFIG_LBD is not set | 165 | CONFIG_LBDAF=y |
| 151 | # CONFIG_BLK_DEV_BSG is not set | 166 | # CONFIG_BLK_DEV_BSG is not set |
| 152 | # CONFIG_BLK_DEV_INTEGRITY is not set | 167 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 153 | 168 | ||
| @@ -189,6 +204,7 @@ CONFIG_MPC832x_MDS=y | |||
| 189 | # CONFIG_MPC837x_RDB is not set | 204 | # CONFIG_MPC837x_RDB is not set |
| 190 | # CONFIG_SBC834x is not set | 205 | # CONFIG_SBC834x is not set |
| 191 | # CONFIG_ASP834x is not set | 206 | # CONFIG_ASP834x is not set |
| 207 | # CONFIG_KMETER1 is not set | ||
| 192 | CONFIG_PPC_MPC832x=y | 208 | CONFIG_PPC_MPC832x=y |
| 193 | # CONFIG_PPC_86xx is not set | 209 | # CONFIG_PPC_86xx is not set |
| 194 | # CONFIG_EMBEDDED6xx is not set | 210 | # CONFIG_EMBEDDED6xx is not set |
| @@ -235,6 +251,7 @@ CONFIG_BINFMT_ELF=y | |||
| 235 | # CONFIG_BINFMT_MISC is not set | 251 | # CONFIG_BINFMT_MISC is not set |
| 236 | CONFIG_MATH_EMULATION=y | 252 | CONFIG_MATH_EMULATION=y |
| 237 | # CONFIG_IOMMU_HELPER is not set | 253 | # CONFIG_IOMMU_HELPER is not set |
| 254 | # CONFIG_SWIOTLB is not set | ||
| 238 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 255 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 239 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 256 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 240 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 257 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -255,9 +272,9 @@ CONFIG_MIGRATION=y | |||
| 255 | CONFIG_ZONE_DMA_FLAG=1 | 272 | CONFIG_ZONE_DMA_FLAG=1 |
| 256 | CONFIG_BOUNCE=y | 273 | CONFIG_BOUNCE=y |
| 257 | CONFIG_VIRT_TO_BUS=y | 274 | CONFIG_VIRT_TO_BUS=y |
| 258 | CONFIG_UNEVICTABLE_LRU=y | ||
| 259 | CONFIG_HAVE_MLOCK=y | 275 | CONFIG_HAVE_MLOCK=y |
| 260 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 276 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 277 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 261 | CONFIG_PPC_4K_PAGES=y | 278 | CONFIG_PPC_4K_PAGES=y |
| 262 | # CONFIG_PPC_16K_PAGES is not set | 279 | # CONFIG_PPC_16K_PAGES is not set |
| 263 | # CONFIG_PPC_64K_PAGES is not set | 280 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -366,6 +383,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 366 | # CONFIG_ECONET is not set | 383 | # CONFIG_ECONET is not set |
| 367 | # CONFIG_WAN_ROUTER is not set | 384 | # CONFIG_WAN_ROUTER is not set |
| 368 | # CONFIG_PHONET is not set | 385 | # CONFIG_PHONET is not set |
| 386 | # CONFIG_IEEE802154 is not set | ||
| 369 | # CONFIG_NET_SCHED is not set | 387 | # CONFIG_NET_SCHED is not set |
| 370 | # CONFIG_DCB is not set | 388 | # CONFIG_DCB is not set |
| 371 | 389 | ||
| @@ -383,7 +401,11 @@ CONFIG_WIRELESS=y | |||
| 383 | CONFIG_WIRELESS_OLD_REGULATORY=y | 401 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 384 | # CONFIG_WIRELESS_EXT is not set | 402 | # CONFIG_WIRELESS_EXT is not set |
| 385 | # CONFIG_LIB80211 is not set | 403 | # CONFIG_LIB80211 is not set |
| 386 | # CONFIG_MAC80211 is not set | 404 | |
| 405 | # | ||
| 406 | # CFG80211 needs to be enabled for MAC80211 | ||
| 407 | # | ||
| 408 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 387 | # CONFIG_WIMAX is not set | 409 | # CONFIG_WIMAX is not set |
| 388 | # CONFIG_RFKILL is not set | 410 | # CONFIG_RFKILL is not set |
| 389 | # CONFIG_NET_9P is not set | 411 | # CONFIG_NET_9P is not set |
| @@ -404,6 +426,7 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 404 | # CONFIG_MTD is not set | 426 | # CONFIG_MTD is not set |
| 405 | CONFIG_OF_DEVICE=y | 427 | CONFIG_OF_DEVICE=y |
| 406 | CONFIG_OF_I2C=y | 428 | CONFIG_OF_I2C=y |
| 429 | CONFIG_OF_MDIO=y | ||
| 407 | # CONFIG_PARPORT is not set | 430 | # CONFIG_PARPORT is not set |
| 408 | CONFIG_BLK_DEV=y | 431 | CONFIG_BLK_DEV=y |
| 409 | # CONFIG_BLK_DEV_FD is not set | 432 | # CONFIG_BLK_DEV_FD is not set |
| @@ -438,7 +461,9 @@ CONFIG_MISC_DEVICES=y | |||
| 438 | # | 461 | # |
| 439 | # CONFIG_EEPROM_AT24 is not set | 462 | # CONFIG_EEPROM_AT24 is not set |
| 440 | # CONFIG_EEPROM_LEGACY is not set | 463 | # CONFIG_EEPROM_LEGACY is not set |
| 464 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 441 | # CONFIG_EEPROM_93CX6 is not set | 465 | # CONFIG_EEPROM_93CX6 is not set |
| 466 | # CONFIG_CB710_CORE is not set | ||
| 442 | CONFIG_HAVE_IDE=y | 467 | CONFIG_HAVE_IDE=y |
| 443 | # CONFIG_IDE is not set | 468 | # CONFIG_IDE is not set |
| 444 | 469 | ||
| @@ -461,10 +486,6 @@ CONFIG_SCSI_PROC_FS=y | |||
| 461 | # CONFIG_BLK_DEV_SR is not set | 486 | # CONFIG_BLK_DEV_SR is not set |
| 462 | # CONFIG_CHR_DEV_SG is not set | 487 | # CONFIG_CHR_DEV_SG is not set |
| 463 | # CONFIG_CHR_DEV_SCH is not set | 488 | # CONFIG_CHR_DEV_SCH is not set |
| 464 | |||
| 465 | # | ||
| 466 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 467 | # | ||
| 468 | # CONFIG_SCSI_MULTI_LUN is not set | 489 | # CONFIG_SCSI_MULTI_LUN is not set |
| 469 | # CONFIG_SCSI_CONSTANTS is not set | 490 | # CONFIG_SCSI_CONSTANTS is not set |
| 470 | # CONFIG_SCSI_LOGGING is not set | 491 | # CONFIG_SCSI_LOGGING is not set |
| @@ -482,6 +503,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 482 | CONFIG_SCSI_LOWLEVEL=y | 503 | CONFIG_SCSI_LOWLEVEL=y |
| 483 | # CONFIG_ISCSI_TCP is not set | 504 | # CONFIG_ISCSI_TCP is not set |
| 484 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 505 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 506 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 485 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 507 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 486 | # CONFIG_SCSI_3W_9XXX is not set | 508 | # CONFIG_SCSI_3W_9XXX is not set |
| 487 | # CONFIG_SCSI_ACARD is not set | 509 | # CONFIG_SCSI_ACARD is not set |
| @@ -490,6 +512,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 490 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 512 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 491 | # CONFIG_SCSI_AIC79XX is not set | 513 | # CONFIG_SCSI_AIC79XX is not set |
| 492 | # CONFIG_SCSI_AIC94XX is not set | 514 | # CONFIG_SCSI_AIC94XX is not set |
| 515 | # CONFIG_SCSI_MVSAS is not set | ||
| 493 | # CONFIG_SCSI_DPT_I2O is not set | 516 | # CONFIG_SCSI_DPT_I2O is not set |
| 494 | # CONFIG_SCSI_ADVANSYS is not set | 517 | # CONFIG_SCSI_ADVANSYS is not set |
| 495 | # CONFIG_SCSI_ARCMSR is not set | 518 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -509,7 +532,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 509 | # CONFIG_SCSI_IPS is not set | 532 | # CONFIG_SCSI_IPS is not set |
| 510 | # CONFIG_SCSI_INITIO is not set | 533 | # CONFIG_SCSI_INITIO is not set |
| 511 | # CONFIG_SCSI_INIA100 is not set | 534 | # CONFIG_SCSI_INIA100 is not set |
| 512 | # CONFIG_SCSI_MVSAS is not set | ||
| 513 | # CONFIG_SCSI_STEX is not set | 535 | # CONFIG_SCSI_STEX is not set |
| 514 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 536 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 515 | # CONFIG_SCSI_QLOGIC_1280 is not set | 537 | # CONFIG_SCSI_QLOGIC_1280 is not set |
| @@ -532,14 +554,17 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 532 | # | 554 | # |
| 533 | 555 | ||
| 534 | # | 556 | # |
| 535 | # Enable only one of the two stacks, unless you know what you are doing | 557 | # You can enable one or both FireWire driver stacks. |
| 558 | # | ||
| 559 | |||
| 560 | # | ||
| 561 | # See the help texts for more information. | ||
| 536 | # | 562 | # |
| 537 | # CONFIG_FIREWIRE is not set | 563 | # CONFIG_FIREWIRE is not set |
| 538 | # CONFIG_IEEE1394 is not set | 564 | # CONFIG_IEEE1394 is not set |
| 539 | # CONFIG_I2O is not set | 565 | # CONFIG_I2O is not set |
| 540 | # CONFIG_MACINTOSH_DRIVERS is not set | 566 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 541 | CONFIG_NETDEVICES=y | 567 | CONFIG_NETDEVICES=y |
| 542 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 543 | # CONFIG_DUMMY is not set | 568 | # CONFIG_DUMMY is not set |
| 544 | # CONFIG_BONDING is not set | 569 | # CONFIG_BONDING is not set |
| 545 | # CONFIG_MACVLAN is not set | 570 | # CONFIG_MACVLAN is not set |
| @@ -586,6 +611,7 @@ CONFIG_MII=y | |||
| 586 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 611 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 587 | # CONFIG_NET_PCI is not set | 612 | # CONFIG_NET_PCI is not set |
| 588 | # CONFIG_B44 is not set | 613 | # CONFIG_B44 is not set |
| 614 | # CONFIG_KS8842 is not set | ||
| 589 | # CONFIG_ATL2 is not set | 615 | # CONFIG_ATL2 is not set |
| 590 | CONFIG_NETDEV_1000=y | 616 | CONFIG_NETDEV_1000=y |
| 591 | # CONFIG_ACENIC is not set | 617 | # CONFIG_ACENIC is not set |
| @@ -605,11 +631,13 @@ CONFIG_NETDEV_1000=y | |||
| 605 | # CONFIG_VIA_VELOCITY is not set | 631 | # CONFIG_VIA_VELOCITY is not set |
| 606 | # CONFIG_TIGON3 is not set | 632 | # CONFIG_TIGON3 is not set |
| 607 | # CONFIG_BNX2 is not set | 633 | # CONFIG_BNX2 is not set |
| 634 | # CONFIG_CNIC is not set | ||
| 608 | CONFIG_FSL_PQ_MDIO=y | 635 | CONFIG_FSL_PQ_MDIO=y |
| 609 | # CONFIG_GIANFAR is not set | 636 | # CONFIG_GIANFAR is not set |
| 610 | CONFIG_UCC_GETH=y | 637 | CONFIG_UCC_GETH=y |
| 611 | # CONFIG_UGETH_MAGIC_PACKET is not set | 638 | # CONFIG_UGETH_MAGIC_PACKET is not set |
| 612 | # CONFIG_UGETH_TX_ON_DEMAND is not set | 639 | # CONFIG_UGETH_TX_ON_DEMAND is not set |
| 640 | # CONFIG_MV643XX_ETH is not set | ||
| 613 | # CONFIG_QLA3XXX is not set | 641 | # CONFIG_QLA3XXX is not set |
| 614 | # CONFIG_ATL1 is not set | 642 | # CONFIG_ATL1 is not set |
| 615 | # CONFIG_ATL1E is not set | 643 | # CONFIG_ATL1E is not set |
| @@ -787,13 +815,17 @@ CONFIG_I2C_MPC=y | |||
| 787 | # CONFIG_SENSORS_PCF8574 is not set | 815 | # CONFIG_SENSORS_PCF8574 is not set |
| 788 | # CONFIG_PCF8575 is not set | 816 | # CONFIG_PCF8575 is not set |
| 789 | # CONFIG_SENSORS_PCA9539 is not set | 817 | # CONFIG_SENSORS_PCA9539 is not set |
| 790 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 791 | # CONFIG_SENSORS_TSL2550 is not set | 818 | # CONFIG_SENSORS_TSL2550 is not set |
| 792 | # CONFIG_I2C_DEBUG_CORE is not set | 819 | # CONFIG_I2C_DEBUG_CORE is not set |
| 793 | # CONFIG_I2C_DEBUG_ALGO is not set | 820 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 794 | # CONFIG_I2C_DEBUG_BUS is not set | 821 | # CONFIG_I2C_DEBUG_BUS is not set |
| 795 | # CONFIG_I2C_DEBUG_CHIP is not set | 822 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 796 | # CONFIG_SPI is not set | 823 | # CONFIG_SPI is not set |
| 824 | |||
| 825 | # | ||
| 826 | # PPS support | ||
| 827 | # | ||
| 828 | # CONFIG_PPS is not set | ||
| 797 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 829 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 798 | # CONFIG_GPIOLIB is not set | 830 | # CONFIG_GPIOLIB is not set |
| 799 | # CONFIG_W1 is not set | 831 | # CONFIG_W1 is not set |
| @@ -848,6 +880,7 @@ CONFIG_HWMON=y | |||
| 848 | # CONFIG_SENSORS_SMSC47B397 is not set | 880 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 849 | # CONFIG_SENSORS_ADS7828 is not set | 881 | # CONFIG_SENSORS_ADS7828 is not set |
| 850 | # CONFIG_SENSORS_THMC50 is not set | 882 | # CONFIG_SENSORS_THMC50 is not set |
| 883 | # CONFIG_SENSORS_TMP401 is not set | ||
| 851 | # CONFIG_SENSORS_VIA686A is not set | 884 | # CONFIG_SENSORS_VIA686A is not set |
| 852 | # CONFIG_SENSORS_VT1211 is not set | 885 | # CONFIG_SENSORS_VT1211 is not set |
| 853 | # CONFIG_SENSORS_VT8231 is not set | 886 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -896,23 +929,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 896 | # CONFIG_MFD_WM8400 is not set | 929 | # CONFIG_MFD_WM8400 is not set |
| 897 | # CONFIG_MFD_WM8350_I2C is not set | 930 | # CONFIG_MFD_WM8350_I2C is not set |
| 898 | # CONFIG_MFD_PCF50633 is not set | 931 | # CONFIG_MFD_PCF50633 is not set |
| 932 | # CONFIG_AB3100_CORE is not set | ||
| 899 | # CONFIG_REGULATOR is not set | 933 | # CONFIG_REGULATOR is not set |
| 900 | 934 | # CONFIG_MEDIA_SUPPORT is not set | |
| 901 | # | ||
| 902 | # Multimedia devices | ||
| 903 | # | ||
| 904 | |||
| 905 | # | ||
| 906 | # Multimedia core support | ||
| 907 | # | ||
| 908 | # CONFIG_VIDEO_DEV is not set | ||
| 909 | # CONFIG_DVB_CORE is not set | ||
| 910 | # CONFIG_VIDEO_MEDIA is not set | ||
| 911 | |||
| 912 | # | ||
| 913 | # Multimedia drivers | ||
| 914 | # | ||
| 915 | CONFIG_DAB=y | ||
| 916 | 935 | ||
| 917 | # | 936 | # |
| 918 | # Graphics support | 937 | # Graphics support |
| @@ -996,6 +1015,7 @@ CONFIG_RTC_DRV_DS1374=y | |||
| 996 | # CONFIG_RTC_DRV_S35390A is not set | 1015 | # CONFIG_RTC_DRV_S35390A is not set |
| 997 | # CONFIG_RTC_DRV_FM3130 is not set | 1016 | # CONFIG_RTC_DRV_FM3130 is not set |
| 998 | # CONFIG_RTC_DRV_RX8581 is not set | 1017 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1018 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 999 | 1019 | ||
| 1000 | # | 1020 | # |
| 1001 | # SPI RTC drivers | 1021 | # SPI RTC drivers |
| @@ -1023,6 +1043,10 @@ CONFIG_RTC_DRV_DS1374=y | |||
| 1023 | # CONFIG_DMADEVICES is not set | 1043 | # CONFIG_DMADEVICES is not set |
| 1024 | # CONFIG_AUXDISPLAY is not set | 1044 | # CONFIG_AUXDISPLAY is not set |
| 1025 | # CONFIG_UIO is not set | 1045 | # CONFIG_UIO is not set |
| 1046 | |||
| 1047 | # | ||
| 1048 | # TI VLYNQ | ||
| 1049 | # | ||
| 1026 | # CONFIG_STAGING is not set | 1050 | # CONFIG_STAGING is not set |
| 1027 | 1051 | ||
| 1028 | # | 1052 | # |
| @@ -1042,10 +1066,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1042 | # CONFIG_REISERFS_FS is not set | 1066 | # CONFIG_REISERFS_FS is not set |
| 1043 | # CONFIG_JFS_FS is not set | 1067 | # CONFIG_JFS_FS is not set |
| 1044 | # CONFIG_FS_POSIX_ACL is not set | 1068 | # CONFIG_FS_POSIX_ACL is not set |
| 1045 | CONFIG_FILE_LOCKING=y | ||
| 1046 | # CONFIG_XFS_FS is not set | 1069 | # CONFIG_XFS_FS is not set |
| 1070 | # CONFIG_GFS2_FS is not set | ||
| 1047 | # CONFIG_OCFS2_FS is not set | 1071 | # CONFIG_OCFS2_FS is not set |
| 1048 | # CONFIG_BTRFS_FS is not set | 1072 | # CONFIG_BTRFS_FS is not set |
| 1073 | CONFIG_FILE_LOCKING=y | ||
| 1074 | CONFIG_FSNOTIFY=y | ||
| 1049 | CONFIG_DNOTIFY=y | 1075 | CONFIG_DNOTIFY=y |
| 1050 | CONFIG_INOTIFY=y | 1076 | CONFIG_INOTIFY=y |
| 1051 | CONFIG_INOTIFY_USER=y | 1077 | CONFIG_INOTIFY_USER=y |
| @@ -1108,6 +1134,7 @@ CONFIG_NFS_FS=y | |||
| 1108 | CONFIG_NFS_V3=y | 1134 | CONFIG_NFS_V3=y |
| 1109 | # CONFIG_NFS_V3_ACL is not set | 1135 | # CONFIG_NFS_V3_ACL is not set |
| 1110 | CONFIG_NFS_V4=y | 1136 | CONFIG_NFS_V4=y |
| 1137 | # CONFIG_NFS_V4_1 is not set | ||
| 1111 | CONFIG_ROOT_NFS=y | 1138 | CONFIG_ROOT_NFS=y |
| 1112 | # CONFIG_NFSD is not set | 1139 | # CONFIG_NFSD is not set |
| 1113 | CONFIG_LOCKD=y | 1140 | CONFIG_LOCKD=y |
| @@ -1165,6 +1192,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1165 | CONFIG_HAS_DMA=y | 1192 | CONFIG_HAS_DMA=y |
| 1166 | CONFIG_HAVE_LMB=y | 1193 | CONFIG_HAVE_LMB=y |
| 1167 | CONFIG_NLATTR=y | 1194 | CONFIG_NLATTR=y |
| 1195 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1168 | 1196 | ||
| 1169 | # | 1197 | # |
| 1170 | # Kernel hacking | 1198 | # Kernel hacking |
| @@ -1190,22 +1218,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1190 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1218 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1191 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1219 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1192 | CONFIG_TRACING_SUPPORT=y | 1220 | CONFIG_TRACING_SUPPORT=y |
| 1193 | 1221 | # CONFIG_FTRACE is not set | |
| 1194 | # | ||
| 1195 | # Tracers | ||
| 1196 | # | ||
| 1197 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1198 | # CONFIG_SCHED_TRACER is not set | ||
| 1199 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1200 | # CONFIG_EVENT_TRACER is not set | ||
| 1201 | # CONFIG_BOOT_TRACER is not set | ||
| 1202 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1203 | # CONFIG_STACK_TRACER is not set | ||
| 1204 | # CONFIG_KMEMTRACE is not set | ||
| 1205 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1206 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1207 | # CONFIG_SAMPLES is not set | 1222 | # CONFIG_SAMPLES is not set |
| 1208 | CONFIG_HAVE_ARCH_KGDB=y | 1223 | CONFIG_HAVE_ARCH_KGDB=y |
| 1224 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1225 | CONFIG_PPC_WERROR=y | ||
| 1209 | CONFIG_PRINT_STACK_DEPTH=64 | 1226 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1210 | # CONFIG_IRQSTACKS is not set | 1227 | # CONFIG_IRQSTACKS is not set |
| 1211 | # CONFIG_BOOTX_TEXT is not set | 1228 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/83xx/mpc832x_rdb_defconfig b/arch/powerpc/configs/83xx/mpc832x_rdb_defconfig index 227dbba76795..4f27d4548223 100644 --- a/arch/powerpc/configs/83xx/mpc832x_rdb_defconfig +++ b/arch/powerpc/configs/83xx/mpc832x_rdb_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:08 2009 | 4 | # Wed Jul 29 23:32:07 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_FSL_EMB_PERFMON is not set | 20 | # CONFIG_FSL_EMB_PERFMON is not set |
| 20 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 45 | CONFIG_PPC=y | 48 | CONFIG_PPC=y |
| @@ -53,12 +56,14 @@ CONFIG_PPC_UDBG_16550=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 57 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 61 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| 58 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 59 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 60 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 61 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 62 | 67 | ||
| 63 | # | 68 | # |
| 64 | # General setup | 69 | # General setup |
| @@ -107,7 +112,6 @@ CONFIG_ANON_INODES=y | |||
| 107 | CONFIG_EMBEDDED=y | 112 | CONFIG_EMBEDDED=y |
| 108 | CONFIG_SYSCTL_SYSCALL=y | 113 | CONFIG_SYSCTL_SYSCALL=y |
| 109 | # CONFIG_KALLSYMS is not set | 114 | # CONFIG_KALLSYMS is not set |
| 110 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 111 | CONFIG_HOTPLUG=y | 115 | CONFIG_HOTPLUG=y |
| 112 | CONFIG_PRINTK=y | 116 | CONFIG_PRINTK=y |
| 113 | CONFIG_BUG=y | 117 | CONFIG_BUG=y |
| @@ -120,9 +124,16 @@ CONFIG_TIMERFD=y | |||
| 120 | CONFIG_EVENTFD=y | 124 | CONFIG_EVENTFD=y |
| 121 | CONFIG_SHMEM=y | 125 | CONFIG_SHMEM=y |
| 122 | CONFIG_AIO=y | 126 | CONFIG_AIO=y |
| 127 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 128 | |||
| 129 | # | ||
| 130 | # Performance Counters | ||
| 131 | # | ||
| 132 | # CONFIG_PERF_COUNTERS is not set | ||
| 123 | CONFIG_VM_EVENT_COUNTERS=y | 133 | CONFIG_VM_EVENT_COUNTERS=y |
| 124 | CONFIG_PCI_QUIRKS=y | 134 | CONFIG_PCI_QUIRKS=y |
| 125 | CONFIG_SLUB_DEBUG=y | 135 | CONFIG_SLUB_DEBUG=y |
| 136 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 126 | CONFIG_COMPAT_BRK=y | 137 | CONFIG_COMPAT_BRK=y |
| 127 | # CONFIG_SLAB is not set | 138 | # CONFIG_SLAB is not set |
| 128 | CONFIG_SLUB=y | 139 | CONFIG_SLUB=y |
| @@ -135,6 +146,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 135 | CONFIG_HAVE_KPROBES=y | 146 | CONFIG_HAVE_KPROBES=y |
| 136 | CONFIG_HAVE_KRETPROBES=y | 147 | CONFIG_HAVE_KRETPROBES=y |
| 137 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 148 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 149 | |||
| 150 | # | ||
| 151 | # GCOV-based kernel profiling | ||
| 152 | # | ||
| 138 | # CONFIG_SLOW_WORK is not set | 153 | # CONFIG_SLOW_WORK is not set |
| 139 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 140 | CONFIG_SLABINFO=y | 155 | CONFIG_SLABINFO=y |
| @@ -147,7 +162,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 147 | # CONFIG_MODVERSIONS is not set | 162 | # CONFIG_MODVERSIONS is not set |
| 148 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 163 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 149 | CONFIG_BLOCK=y | 164 | CONFIG_BLOCK=y |
| 150 | # CONFIG_LBD is not set | 165 | CONFIG_LBDAF=y |
| 151 | # CONFIG_BLK_DEV_BSG is not set | 166 | # CONFIG_BLK_DEV_BSG is not set |
| 152 | # CONFIG_BLK_DEV_INTEGRITY is not set | 167 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 153 | 168 | ||
| @@ -189,6 +204,7 @@ CONFIG_MPC832x_RDB=y | |||
| 189 | # CONFIG_MPC837x_RDB is not set | 204 | # CONFIG_MPC837x_RDB is not set |
| 190 | # CONFIG_SBC834x is not set | 205 | # CONFIG_SBC834x is not set |
| 191 | # CONFIG_ASP834x is not set | 206 | # CONFIG_ASP834x is not set |
| 207 | # CONFIG_KMETER1 is not set | ||
| 192 | CONFIG_PPC_MPC832x=y | 208 | CONFIG_PPC_MPC832x=y |
| 193 | # CONFIG_PPC_86xx is not set | 209 | # CONFIG_PPC_86xx is not set |
| 194 | # CONFIG_EMBEDDED6xx is not set | 210 | # CONFIG_EMBEDDED6xx is not set |
| @@ -235,6 +251,7 @@ CONFIG_BINFMT_ELF=y | |||
| 235 | # CONFIG_BINFMT_MISC is not set | 251 | # CONFIG_BINFMT_MISC is not set |
| 236 | CONFIG_MATH_EMULATION=y | 252 | CONFIG_MATH_EMULATION=y |
| 237 | # CONFIG_IOMMU_HELPER is not set | 253 | # CONFIG_IOMMU_HELPER is not set |
| 254 | # CONFIG_SWIOTLB is not set | ||
| 238 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 255 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 239 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 256 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 240 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 257 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -255,9 +272,9 @@ CONFIG_MIGRATION=y | |||
| 255 | CONFIG_ZONE_DMA_FLAG=1 | 272 | CONFIG_ZONE_DMA_FLAG=1 |
| 256 | CONFIG_BOUNCE=y | 273 | CONFIG_BOUNCE=y |
| 257 | CONFIG_VIRT_TO_BUS=y | 274 | CONFIG_VIRT_TO_BUS=y |
| 258 | CONFIG_UNEVICTABLE_LRU=y | ||
| 259 | CONFIG_HAVE_MLOCK=y | 275 | CONFIG_HAVE_MLOCK=y |
| 260 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 276 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 277 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 261 | CONFIG_PPC_4K_PAGES=y | 278 | CONFIG_PPC_4K_PAGES=y |
| 262 | # CONFIG_PPC_16K_PAGES is not set | 279 | # CONFIG_PPC_16K_PAGES is not set |
| 263 | # CONFIG_PPC_64K_PAGES is not set | 280 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -366,6 +383,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 366 | # CONFIG_ECONET is not set | 383 | # CONFIG_ECONET is not set |
| 367 | # CONFIG_WAN_ROUTER is not set | 384 | # CONFIG_WAN_ROUTER is not set |
| 368 | # CONFIG_PHONET is not set | 385 | # CONFIG_PHONET is not set |
| 386 | # CONFIG_IEEE802154 is not set | ||
| 369 | # CONFIG_NET_SCHED is not set | 387 | # CONFIG_NET_SCHED is not set |
| 370 | # CONFIG_DCB is not set | 388 | # CONFIG_DCB is not set |
| 371 | 389 | ||
| @@ -383,7 +401,11 @@ CONFIG_WIRELESS=y | |||
| 383 | CONFIG_WIRELESS_OLD_REGULATORY=y | 401 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 384 | # CONFIG_WIRELESS_EXT is not set | 402 | # CONFIG_WIRELESS_EXT is not set |
| 385 | # CONFIG_LIB80211 is not set | 403 | # CONFIG_LIB80211 is not set |
| 386 | # CONFIG_MAC80211 is not set | 404 | |
| 405 | # | ||
| 406 | # CFG80211 needs to be enabled for MAC80211 | ||
| 407 | # | ||
| 408 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 387 | # CONFIG_WIMAX is not set | 409 | # CONFIG_WIMAX is not set |
| 388 | # CONFIG_RFKILL is not set | 410 | # CONFIG_RFKILL is not set |
| 389 | # CONFIG_NET_9P is not set | 411 | # CONFIG_NET_9P is not set |
| @@ -405,6 +427,7 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 405 | CONFIG_OF_DEVICE=y | 427 | CONFIG_OF_DEVICE=y |
| 406 | CONFIG_OF_I2C=y | 428 | CONFIG_OF_I2C=y |
| 407 | CONFIG_OF_SPI=y | 429 | CONFIG_OF_SPI=y |
| 430 | CONFIG_OF_MDIO=y | ||
| 408 | # CONFIG_PARPORT is not set | 431 | # CONFIG_PARPORT is not set |
| 409 | CONFIG_BLK_DEV=y | 432 | CONFIG_BLK_DEV=y |
| 410 | # CONFIG_BLK_DEV_FD is not set | 433 | # CONFIG_BLK_DEV_FD is not set |
| @@ -441,7 +464,9 @@ CONFIG_MISC_DEVICES=y | |||
| 441 | # CONFIG_EEPROM_AT24 is not set | 464 | # CONFIG_EEPROM_AT24 is not set |
| 442 | # CONFIG_EEPROM_AT25 is not set | 465 | # CONFIG_EEPROM_AT25 is not set |
| 443 | # CONFIG_EEPROM_LEGACY is not set | 466 | # CONFIG_EEPROM_LEGACY is not set |
| 467 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 444 | # CONFIG_EEPROM_93CX6 is not set | 468 | # CONFIG_EEPROM_93CX6 is not set |
| 469 | # CONFIG_CB710_CORE is not set | ||
| 445 | CONFIG_HAVE_IDE=y | 470 | CONFIG_HAVE_IDE=y |
| 446 | # CONFIG_IDE is not set | 471 | # CONFIG_IDE is not set |
| 447 | 472 | ||
| @@ -464,10 +489,6 @@ CONFIG_BLK_DEV_SD=y | |||
| 464 | # CONFIG_BLK_DEV_SR is not set | 489 | # CONFIG_BLK_DEV_SR is not set |
| 465 | # CONFIG_CHR_DEV_SG is not set | 490 | # CONFIG_CHR_DEV_SG is not set |
| 466 | # CONFIG_CHR_DEV_SCH is not set | 491 | # CONFIG_CHR_DEV_SCH is not set |
| 467 | |||
| 468 | # | ||
| 469 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 470 | # | ||
| 471 | # CONFIG_SCSI_MULTI_LUN is not set | 492 | # CONFIG_SCSI_MULTI_LUN is not set |
| 472 | # CONFIG_SCSI_CONSTANTS is not set | 493 | # CONFIG_SCSI_CONSTANTS is not set |
| 473 | # CONFIG_SCSI_LOGGING is not set | 494 | # CONFIG_SCSI_LOGGING is not set |
| @@ -485,6 +506,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 485 | CONFIG_SCSI_LOWLEVEL=y | 506 | CONFIG_SCSI_LOWLEVEL=y |
| 486 | # CONFIG_ISCSI_TCP is not set | 507 | # CONFIG_ISCSI_TCP is not set |
| 487 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 508 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 509 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 488 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 510 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 489 | # CONFIG_SCSI_3W_9XXX is not set | 511 | # CONFIG_SCSI_3W_9XXX is not set |
| 490 | # CONFIG_SCSI_ACARD is not set | 512 | # CONFIG_SCSI_ACARD is not set |
| @@ -493,6 +515,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 493 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 515 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 494 | # CONFIG_SCSI_AIC79XX is not set | 516 | # CONFIG_SCSI_AIC79XX is not set |
| 495 | # CONFIG_SCSI_AIC94XX is not set | 517 | # CONFIG_SCSI_AIC94XX is not set |
| 518 | # CONFIG_SCSI_MVSAS is not set | ||
| 496 | # CONFIG_SCSI_DPT_I2O is not set | 519 | # CONFIG_SCSI_DPT_I2O is not set |
| 497 | # CONFIG_SCSI_ADVANSYS is not set | 520 | # CONFIG_SCSI_ADVANSYS is not set |
| 498 | # CONFIG_SCSI_ARCMSR is not set | 521 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -512,7 +535,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 512 | # CONFIG_SCSI_IPS is not set | 535 | # CONFIG_SCSI_IPS is not set |
| 513 | # CONFIG_SCSI_INITIO is not set | 536 | # CONFIG_SCSI_INITIO is not set |
| 514 | # CONFIG_SCSI_INIA100 is not set | 537 | # CONFIG_SCSI_INIA100 is not set |
| 515 | # CONFIG_SCSI_MVSAS is not set | ||
| 516 | # CONFIG_SCSI_STEX is not set | 538 | # CONFIG_SCSI_STEX is not set |
| 517 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 539 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 518 | # CONFIG_SCSI_QLOGIC_1280 is not set | 540 | # CONFIG_SCSI_QLOGIC_1280 is not set |
| @@ -535,14 +557,17 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 535 | # | 557 | # |
| 536 | 558 | ||
| 537 | # | 559 | # |
| 538 | # Enable only one of the two stacks, unless you know what you are doing | 560 | # You can enable one or both FireWire driver stacks. |
| 561 | # | ||
| 562 | |||
| 563 | # | ||
| 564 | # See the help texts for more information. | ||
| 539 | # | 565 | # |
| 540 | # CONFIG_FIREWIRE is not set | 566 | # CONFIG_FIREWIRE is not set |
| 541 | # CONFIG_IEEE1394 is not set | 567 | # CONFIG_IEEE1394 is not set |
| 542 | # CONFIG_I2O is not set | 568 | # CONFIG_I2O is not set |
| 543 | # CONFIG_MACINTOSH_DRIVERS is not set | 569 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 544 | CONFIG_NETDEVICES=y | 570 | CONFIG_NETDEVICES=y |
| 545 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 546 | # CONFIG_DUMMY is not set | 571 | # CONFIG_DUMMY is not set |
| 547 | # CONFIG_BONDING is not set | 572 | # CONFIG_BONDING is not set |
| 548 | # CONFIG_MACVLAN is not set | 573 | # CONFIG_MACVLAN is not set |
| @@ -590,6 +615,8 @@ CONFIG_MII=y | |||
| 590 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 615 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 591 | # CONFIG_NET_PCI is not set | 616 | # CONFIG_NET_PCI is not set |
| 592 | # CONFIG_B44 is not set | 617 | # CONFIG_B44 is not set |
| 618 | # CONFIG_KS8842 is not set | ||
| 619 | # CONFIG_KS8851 is not set | ||
| 593 | # CONFIG_ATL2 is not set | 620 | # CONFIG_ATL2 is not set |
| 594 | CONFIG_NETDEV_1000=y | 621 | CONFIG_NETDEV_1000=y |
| 595 | # CONFIG_ACENIC is not set | 622 | # CONFIG_ACENIC is not set |
| @@ -609,11 +636,13 @@ CONFIG_E1000=y | |||
| 609 | # CONFIG_VIA_VELOCITY is not set | 636 | # CONFIG_VIA_VELOCITY is not set |
| 610 | # CONFIG_TIGON3 is not set | 637 | # CONFIG_TIGON3 is not set |
| 611 | # CONFIG_BNX2 is not set | 638 | # CONFIG_BNX2 is not set |
| 639 | # CONFIG_CNIC is not set | ||
| 612 | CONFIG_FSL_PQ_MDIO=y | 640 | CONFIG_FSL_PQ_MDIO=y |
| 613 | # CONFIG_GIANFAR is not set | 641 | # CONFIG_GIANFAR is not set |
| 614 | CONFIG_UCC_GETH=y | 642 | CONFIG_UCC_GETH=y |
| 615 | # CONFIG_UGETH_MAGIC_PACKET is not set | 643 | # CONFIG_UGETH_MAGIC_PACKET is not set |
| 616 | # CONFIG_UGETH_TX_ON_DEMAND is not set | 644 | # CONFIG_UGETH_TX_ON_DEMAND is not set |
| 645 | # CONFIG_MV643XX_ETH is not set | ||
| 617 | # CONFIG_QLA3XXX is not set | 646 | # CONFIG_QLA3XXX is not set |
| 618 | # CONFIG_ATL1 is not set | 647 | # CONFIG_ATL1 is not set |
| 619 | # CONFIG_ATL1E is not set | 648 | # CONFIG_ATL1E is not set |
| @@ -804,7 +833,6 @@ CONFIG_I2C_MPC=y | |||
| 804 | # CONFIG_SENSORS_PCF8574 is not set | 833 | # CONFIG_SENSORS_PCF8574 is not set |
| 805 | # CONFIG_PCF8575 is not set | 834 | # CONFIG_PCF8575 is not set |
| 806 | # CONFIG_SENSORS_PCA9539 is not set | 835 | # CONFIG_SENSORS_PCA9539 is not set |
| 807 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 808 | # CONFIG_SENSORS_TSL2550 is not set | 836 | # CONFIG_SENSORS_TSL2550 is not set |
| 809 | # CONFIG_I2C_DEBUG_CORE is not set | 837 | # CONFIG_I2C_DEBUG_CORE is not set |
| 810 | # CONFIG_I2C_DEBUG_ALGO is not set | 838 | # CONFIG_I2C_DEBUG_ALGO is not set |
| @@ -817,13 +845,18 @@ CONFIG_SPI_MASTER=y | |||
| 817 | # SPI Master Controller Drivers | 845 | # SPI Master Controller Drivers |
| 818 | # | 846 | # |
| 819 | CONFIG_SPI_BITBANG=y | 847 | CONFIG_SPI_BITBANG=y |
| 820 | CONFIG_SPI_MPC83xx=y | 848 | # CONFIG_SPI_MPC8xxx is not set |
| 821 | 849 | ||
| 822 | # | 850 | # |
| 823 | # SPI Protocol Masters | 851 | # SPI Protocol Masters |
| 824 | # | 852 | # |
| 825 | # CONFIG_SPI_SPIDEV is not set | 853 | # CONFIG_SPI_SPIDEV is not set |
| 826 | # CONFIG_SPI_TLE62X0 is not set | 854 | # CONFIG_SPI_TLE62X0 is not set |
| 855 | |||
| 856 | # | ||
| 857 | # PPS support | ||
| 858 | # | ||
| 859 | # CONFIG_PPS is not set | ||
| 827 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 860 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 828 | # CONFIG_GPIOLIB is not set | 861 | # CONFIG_GPIOLIB is not set |
| 829 | # CONFIG_W1 is not set | 862 | # CONFIG_W1 is not set |
| @@ -881,6 +914,7 @@ CONFIG_HWMON=y | |||
| 881 | # CONFIG_SENSORS_SMSC47B397 is not set | 914 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 882 | # CONFIG_SENSORS_ADS7828 is not set | 915 | # CONFIG_SENSORS_ADS7828 is not set |
| 883 | # CONFIG_SENSORS_THMC50 is not set | 916 | # CONFIG_SENSORS_THMC50 is not set |
| 917 | # CONFIG_SENSORS_TMP401 is not set | ||
| 884 | # CONFIG_SENSORS_VIA686A is not set | 918 | # CONFIG_SENSORS_VIA686A is not set |
| 885 | # CONFIG_SENSORS_VT1211 is not set | 919 | # CONFIG_SENSORS_VT1211 is not set |
| 886 | # CONFIG_SENSORS_VT8231 is not set | 920 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -935,24 +969,10 @@ CONFIG_SSB_POSSIBLE=y | |||
| 935 | # CONFIG_MFD_WM8400 is not set | 969 | # CONFIG_MFD_WM8400 is not set |
| 936 | # CONFIG_MFD_WM8350_I2C is not set | 970 | # CONFIG_MFD_WM8350_I2C is not set |
| 937 | # CONFIG_MFD_PCF50633 is not set | 971 | # CONFIG_MFD_PCF50633 is not set |
| 972 | # CONFIG_AB3100_CORE is not set | ||
| 973 | # CONFIG_EZX_PCAP is not set | ||
| 938 | # CONFIG_REGULATOR is not set | 974 | # CONFIG_REGULATOR is not set |
| 939 | 975 | # CONFIG_MEDIA_SUPPORT is not set | |
| 940 | # | ||
| 941 | # Multimedia devices | ||
| 942 | # | ||
| 943 | |||
| 944 | # | ||
| 945 | # Multimedia core support | ||
| 946 | # | ||
| 947 | # CONFIG_VIDEO_DEV is not set | ||
| 948 | # CONFIG_DVB_CORE is not set | ||
| 949 | # CONFIG_VIDEO_MEDIA is not set | ||
| 950 | |||
| 951 | # | ||
| 952 | # Multimedia drivers | ||
| 953 | # | ||
| 954 | CONFIG_DAB=y | ||
| 955 | # CONFIG_USB_DABUSB is not set | ||
| 956 | 976 | ||
| 957 | # | 977 | # |
| 958 | # Graphics support | 978 | # Graphics support |
| @@ -1014,6 +1034,7 @@ CONFIG_USB_MON=y | |||
| 1014 | # USB Host Controller Drivers | 1034 | # USB Host Controller Drivers |
| 1015 | # | 1035 | # |
| 1016 | # CONFIG_USB_C67X00_HCD is not set | 1036 | # CONFIG_USB_C67X00_HCD is not set |
| 1037 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1017 | CONFIG_USB_EHCI_HCD=y | 1038 | CONFIG_USB_EHCI_HCD=y |
| 1018 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set | 1039 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set |
| 1019 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1040 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1023,9 +1044,9 @@ CONFIG_USB_EHCI_HCD_PPC_OF=y | |||
| 1023 | # CONFIG_USB_ISP116X_HCD is not set | 1044 | # CONFIG_USB_ISP116X_HCD is not set |
| 1024 | # CONFIG_USB_ISP1760_HCD is not set | 1045 | # CONFIG_USB_ISP1760_HCD is not set |
| 1025 | CONFIG_USB_OHCI_HCD=y | 1046 | CONFIG_USB_OHCI_HCD=y |
| 1026 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1027 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y | 1047 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y |
| 1028 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set | 1048 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set |
| 1049 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1029 | CONFIG_USB_OHCI_HCD_PCI=y | 1050 | CONFIG_USB_OHCI_HCD_PCI=y |
| 1030 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y | 1051 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y |
| 1031 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y | 1052 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y |
| @@ -1127,6 +1148,8 @@ CONFIG_MMC_BLOCK_BOUNCE=y | |||
| 1127 | # CONFIG_MMC_WBSD is not set | 1148 | # CONFIG_MMC_WBSD is not set |
| 1128 | # CONFIG_MMC_TIFM_SD is not set | 1149 | # CONFIG_MMC_TIFM_SD is not set |
| 1129 | CONFIG_MMC_SPI=y | 1150 | CONFIG_MMC_SPI=y |
| 1151 | # CONFIG_MMC_CB710 is not set | ||
| 1152 | # CONFIG_MMC_VIA_SDMMC is not set | ||
| 1130 | # CONFIG_MEMSTICK is not set | 1153 | # CONFIG_MEMSTICK is not set |
| 1131 | # CONFIG_NEW_LEDS is not set | 1154 | # CONFIG_NEW_LEDS is not set |
| 1132 | # CONFIG_ACCESSIBILITY is not set | 1155 | # CONFIG_ACCESSIBILITY is not set |
| @@ -1136,6 +1159,10 @@ CONFIG_MMC_SPI=y | |||
| 1136 | # CONFIG_DMADEVICES is not set | 1159 | # CONFIG_DMADEVICES is not set |
| 1137 | # CONFIG_AUXDISPLAY is not set | 1160 | # CONFIG_AUXDISPLAY is not set |
| 1138 | # CONFIG_UIO is not set | 1161 | # CONFIG_UIO is not set |
| 1162 | |||
| 1163 | # | ||
| 1164 | # TI VLYNQ | ||
| 1165 | # | ||
| 1139 | # CONFIG_STAGING is not set | 1166 | # CONFIG_STAGING is not set |
| 1140 | 1167 | ||
| 1141 | # | 1168 | # |
| @@ -1155,10 +1182,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1155 | # CONFIG_REISERFS_FS is not set | 1182 | # CONFIG_REISERFS_FS is not set |
| 1156 | # CONFIG_JFS_FS is not set | 1183 | # CONFIG_JFS_FS is not set |
| 1157 | # CONFIG_FS_POSIX_ACL is not set | 1184 | # CONFIG_FS_POSIX_ACL is not set |
| 1158 | CONFIG_FILE_LOCKING=y | ||
| 1159 | # CONFIG_XFS_FS is not set | 1185 | # CONFIG_XFS_FS is not set |
| 1186 | # CONFIG_GFS2_FS is not set | ||
| 1160 | # CONFIG_OCFS2_FS is not set | 1187 | # CONFIG_OCFS2_FS is not set |
| 1161 | # CONFIG_BTRFS_FS is not set | 1188 | # CONFIG_BTRFS_FS is not set |
| 1189 | CONFIG_FILE_LOCKING=y | ||
| 1190 | CONFIG_FSNOTIFY=y | ||
| 1162 | CONFIG_DNOTIFY=y | 1191 | CONFIG_DNOTIFY=y |
| 1163 | CONFIG_INOTIFY=y | 1192 | CONFIG_INOTIFY=y |
| 1164 | CONFIG_INOTIFY_USER=y | 1193 | CONFIG_INOTIFY_USER=y |
| @@ -1224,6 +1253,7 @@ CONFIG_NFS_FS=y | |||
| 1224 | CONFIG_NFS_V3=y | 1253 | CONFIG_NFS_V3=y |
| 1225 | # CONFIG_NFS_V3_ACL is not set | 1254 | # CONFIG_NFS_V3_ACL is not set |
| 1226 | CONFIG_NFS_V4=y | 1255 | CONFIG_NFS_V4=y |
| 1256 | # CONFIG_NFS_V4_1 is not set | ||
| 1227 | CONFIG_ROOT_NFS=y | 1257 | CONFIG_ROOT_NFS=y |
| 1228 | # CONFIG_NFSD is not set | 1258 | # CONFIG_NFSD is not set |
| 1229 | CONFIG_LOCKD=y | 1259 | CONFIG_LOCKD=y |
| @@ -1325,6 +1355,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1325 | CONFIG_HAS_DMA=y | 1355 | CONFIG_HAS_DMA=y |
| 1326 | CONFIG_HAVE_LMB=y | 1356 | CONFIG_HAVE_LMB=y |
| 1327 | CONFIG_NLATTR=y | 1357 | CONFIG_NLATTR=y |
| 1358 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1328 | 1359 | ||
| 1329 | # | 1360 | # |
| 1330 | # Kernel hacking | 1361 | # Kernel hacking |
| @@ -1350,22 +1381,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1350 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1381 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1351 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1382 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1352 | CONFIG_TRACING_SUPPORT=y | 1383 | CONFIG_TRACING_SUPPORT=y |
| 1353 | 1384 | # CONFIG_FTRACE is not set | |
| 1354 | # | ||
| 1355 | # Tracers | ||
| 1356 | # | ||
| 1357 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1358 | # CONFIG_SCHED_TRACER is not set | ||
| 1359 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1360 | # CONFIG_EVENT_TRACER is not set | ||
| 1361 | # CONFIG_BOOT_TRACER is not set | ||
| 1362 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1363 | # CONFIG_STACK_TRACER is not set | ||
| 1364 | # CONFIG_KMEMTRACE is not set | ||
| 1365 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1366 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1367 | # CONFIG_SAMPLES is not set | 1385 | # CONFIG_SAMPLES is not set |
| 1368 | CONFIG_HAVE_ARCH_KGDB=y | 1386 | CONFIG_HAVE_ARCH_KGDB=y |
| 1387 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1388 | CONFIG_PPC_WERROR=y | ||
| 1369 | CONFIG_PRINT_STACK_DEPTH=64 | 1389 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1370 | # CONFIG_IRQSTACKS is not set | 1390 | # CONFIG_IRQSTACKS is not set |
| 1371 | # CONFIG_BOOTX_TEXT is not set | 1391 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/83xx/mpc834x_itx_defconfig b/arch/powerpc/configs/83xx/mpc834x_itx_defconfig index 24ee7fcac87e..648dac0c9d8d 100644 --- a/arch/powerpc/configs/83xx/mpc834x_itx_defconfig +++ b/arch/powerpc/configs/83xx/mpc834x_itx_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:09 2009 | 4 | # Wed Jul 29 23:32:07 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_FSL_EMB_PERFMON is not set | 20 | # CONFIG_FSL_EMB_PERFMON is not set |
| 20 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 45 | CONFIG_PPC=y | 48 | CONFIG_PPC=y |
| @@ -53,12 +56,14 @@ CONFIG_PPC_UDBG_16550=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 57 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 61 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| 58 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 59 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 60 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 61 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 62 | 67 | ||
| 63 | # | 68 | # |
| 64 | # General setup | 69 | # General setup |
| @@ -107,7 +112,6 @@ CONFIG_ANON_INODES=y | |||
| 107 | CONFIG_EMBEDDED=y | 112 | CONFIG_EMBEDDED=y |
| 108 | CONFIG_SYSCTL_SYSCALL=y | 113 | CONFIG_SYSCTL_SYSCALL=y |
| 109 | # CONFIG_KALLSYMS is not set | 114 | # CONFIG_KALLSYMS is not set |
| 110 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 111 | CONFIG_HOTPLUG=y | 115 | CONFIG_HOTPLUG=y |
| 112 | CONFIG_PRINTK=y | 116 | CONFIG_PRINTK=y |
| 113 | CONFIG_BUG=y | 117 | CONFIG_BUG=y |
| @@ -120,9 +124,16 @@ CONFIG_TIMERFD=y | |||
| 120 | CONFIG_EVENTFD=y | 124 | CONFIG_EVENTFD=y |
| 121 | CONFIG_SHMEM=y | 125 | CONFIG_SHMEM=y |
| 122 | CONFIG_AIO=y | 126 | CONFIG_AIO=y |
| 127 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 128 | |||
| 129 | # | ||
| 130 | # Performance Counters | ||
| 131 | # | ||
| 132 | # CONFIG_PERF_COUNTERS is not set | ||
| 123 | CONFIG_VM_EVENT_COUNTERS=y | 133 | CONFIG_VM_EVENT_COUNTERS=y |
| 124 | CONFIG_PCI_QUIRKS=y | 134 | CONFIG_PCI_QUIRKS=y |
| 125 | CONFIG_SLUB_DEBUG=y | 135 | CONFIG_SLUB_DEBUG=y |
| 136 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 126 | CONFIG_COMPAT_BRK=y | 137 | CONFIG_COMPAT_BRK=y |
| 127 | # CONFIG_SLAB is not set | 138 | # CONFIG_SLAB is not set |
| 128 | CONFIG_SLUB=y | 139 | CONFIG_SLUB=y |
| @@ -135,6 +146,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 135 | CONFIG_HAVE_KPROBES=y | 146 | CONFIG_HAVE_KPROBES=y |
| 136 | CONFIG_HAVE_KRETPROBES=y | 147 | CONFIG_HAVE_KRETPROBES=y |
| 137 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 148 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 149 | |||
| 150 | # | ||
| 151 | # GCOV-based kernel profiling | ||
| 152 | # | ||
| 138 | # CONFIG_SLOW_WORK is not set | 153 | # CONFIG_SLOW_WORK is not set |
| 139 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 140 | CONFIG_SLABINFO=y | 155 | CONFIG_SLABINFO=y |
| @@ -147,7 +162,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 147 | # CONFIG_MODVERSIONS is not set | 162 | # CONFIG_MODVERSIONS is not set |
| 148 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 163 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 149 | CONFIG_BLOCK=y | 164 | CONFIG_BLOCK=y |
| 150 | # CONFIG_LBD is not set | 165 | CONFIG_LBDAF=y |
| 151 | # CONFIG_BLK_DEV_BSG is not set | 166 | # CONFIG_BLK_DEV_BSG is not set |
| 152 | # CONFIG_BLK_DEV_INTEGRITY is not set | 167 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 153 | 168 | ||
| @@ -189,6 +204,7 @@ CONFIG_MPC834x_ITX=y | |||
| 189 | # CONFIG_MPC837x_RDB is not set | 204 | # CONFIG_MPC837x_RDB is not set |
| 190 | # CONFIG_SBC834x is not set | 205 | # CONFIG_SBC834x is not set |
| 191 | # CONFIG_ASP834x is not set | 206 | # CONFIG_ASP834x is not set |
| 207 | # CONFIG_KMETER1 is not set | ||
| 192 | CONFIG_PPC_MPC834x=y | 208 | CONFIG_PPC_MPC834x=y |
| 193 | # CONFIG_PPC_86xx is not set | 209 | # CONFIG_PPC_86xx is not set |
| 194 | # CONFIG_EMBEDDED6xx is not set | 210 | # CONFIG_EMBEDDED6xx is not set |
| @@ -234,6 +250,7 @@ CONFIG_BINFMT_ELF=y | |||
| 234 | # CONFIG_HAVE_AOUT is not set | 250 | # CONFIG_HAVE_AOUT is not set |
| 235 | # CONFIG_BINFMT_MISC is not set | 251 | # CONFIG_BINFMT_MISC is not set |
| 236 | # CONFIG_IOMMU_HELPER is not set | 252 | # CONFIG_IOMMU_HELPER is not set |
| 253 | # CONFIG_SWIOTLB is not set | ||
| 237 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 254 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 238 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 255 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 239 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 256 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -254,9 +271,9 @@ CONFIG_MIGRATION=y | |||
| 254 | CONFIG_ZONE_DMA_FLAG=1 | 271 | CONFIG_ZONE_DMA_FLAG=1 |
| 255 | CONFIG_BOUNCE=y | 272 | CONFIG_BOUNCE=y |
| 256 | CONFIG_VIRT_TO_BUS=y | 273 | CONFIG_VIRT_TO_BUS=y |
| 257 | CONFIG_UNEVICTABLE_LRU=y | ||
| 258 | CONFIG_HAVE_MLOCK=y | 274 | CONFIG_HAVE_MLOCK=y |
| 259 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 275 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 276 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 260 | CONFIG_PPC_4K_PAGES=y | 277 | CONFIG_PPC_4K_PAGES=y |
| 261 | # CONFIG_PPC_16K_PAGES is not set | 278 | # CONFIG_PPC_16K_PAGES is not set |
| 262 | # CONFIG_PPC_64K_PAGES is not set | 279 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -365,6 +382,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 365 | # CONFIG_ECONET is not set | 382 | # CONFIG_ECONET is not set |
| 366 | # CONFIG_WAN_ROUTER is not set | 383 | # CONFIG_WAN_ROUTER is not set |
| 367 | # CONFIG_PHONET is not set | 384 | # CONFIG_PHONET is not set |
| 385 | # CONFIG_IEEE802154 is not set | ||
| 368 | # CONFIG_NET_SCHED is not set | 386 | # CONFIG_NET_SCHED is not set |
| 369 | # CONFIG_DCB is not set | 387 | # CONFIG_DCB is not set |
| 370 | 388 | ||
| @@ -382,7 +400,11 @@ CONFIG_WIRELESS=y | |||
| 382 | CONFIG_WIRELESS_OLD_REGULATORY=y | 400 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 383 | # CONFIG_WIRELESS_EXT is not set | 401 | # CONFIG_WIRELESS_EXT is not set |
| 384 | # CONFIG_LIB80211 is not set | 402 | # CONFIG_LIB80211 is not set |
| 385 | # CONFIG_MAC80211 is not set | 403 | |
| 404 | # | ||
| 405 | # CFG80211 needs to be enabled for MAC80211 | ||
| 406 | # | ||
| 407 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 386 | # CONFIG_WIMAX is not set | 408 | # CONFIG_WIMAX is not set |
| 387 | # CONFIG_RFKILL is not set | 409 | # CONFIG_RFKILL is not set |
| 388 | # CONFIG_NET_9P is not set | 410 | # CONFIG_NET_9P is not set |
| @@ -487,6 +509,7 @@ CONFIG_MTD_PHYSMAP=y | |||
| 487 | CONFIG_OF_DEVICE=y | 509 | CONFIG_OF_DEVICE=y |
| 488 | CONFIG_OF_I2C=y | 510 | CONFIG_OF_I2C=y |
| 489 | CONFIG_OF_SPI=y | 511 | CONFIG_OF_SPI=y |
| 512 | CONFIG_OF_MDIO=y | ||
| 490 | # CONFIG_PARPORT is not set | 513 | # CONFIG_PARPORT is not set |
| 491 | CONFIG_BLK_DEV=y | 514 | CONFIG_BLK_DEV=y |
| 492 | # CONFIG_BLK_DEV_FD is not set | 515 | # CONFIG_BLK_DEV_FD is not set |
| @@ -523,7 +546,9 @@ CONFIG_MISC_DEVICES=y | |||
| 523 | # CONFIG_EEPROM_AT24 is not set | 546 | # CONFIG_EEPROM_AT24 is not set |
| 524 | # CONFIG_EEPROM_AT25 is not set | 547 | # CONFIG_EEPROM_AT25 is not set |
| 525 | # CONFIG_EEPROM_LEGACY is not set | 548 | # CONFIG_EEPROM_LEGACY is not set |
| 549 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 526 | # CONFIG_EEPROM_93CX6 is not set | 550 | # CONFIG_EEPROM_93CX6 is not set |
| 551 | # CONFIG_CB710_CORE is not set | ||
| 527 | CONFIG_HAVE_IDE=y | 552 | CONFIG_HAVE_IDE=y |
| 528 | CONFIG_IDE=y | 553 | CONFIG_IDE=y |
| 529 | 554 | ||
| @@ -594,10 +619,6 @@ CONFIG_BLK_DEV_SD=y | |||
| 594 | # CONFIG_BLK_DEV_SR is not set | 619 | # CONFIG_BLK_DEV_SR is not set |
| 595 | CONFIG_CHR_DEV_SG=y | 620 | CONFIG_CHR_DEV_SG=y |
| 596 | # CONFIG_CHR_DEV_SCH is not set | 621 | # CONFIG_CHR_DEV_SCH is not set |
| 597 | |||
| 598 | # | ||
| 599 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 600 | # | ||
| 601 | # CONFIG_SCSI_MULTI_LUN is not set | 622 | # CONFIG_SCSI_MULTI_LUN is not set |
| 602 | # CONFIG_SCSI_CONSTANTS is not set | 623 | # CONFIG_SCSI_CONSTANTS is not set |
| 603 | # CONFIG_SCSI_LOGGING is not set | 624 | # CONFIG_SCSI_LOGGING is not set |
| @@ -615,6 +636,7 @@ CONFIG_SCSI_SPI_ATTRS=y | |||
| 615 | CONFIG_SCSI_LOWLEVEL=y | 636 | CONFIG_SCSI_LOWLEVEL=y |
| 616 | # CONFIG_ISCSI_TCP is not set | 637 | # CONFIG_ISCSI_TCP is not set |
| 617 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 638 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 639 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 618 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 640 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 619 | # CONFIG_SCSI_3W_9XXX is not set | 641 | # CONFIG_SCSI_3W_9XXX is not set |
| 620 | # CONFIG_SCSI_ACARD is not set | 642 | # CONFIG_SCSI_ACARD is not set |
| @@ -623,6 +645,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 623 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 645 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 624 | # CONFIG_SCSI_AIC79XX is not set | 646 | # CONFIG_SCSI_AIC79XX is not set |
| 625 | # CONFIG_SCSI_AIC94XX is not set | 647 | # CONFIG_SCSI_AIC94XX is not set |
| 648 | # CONFIG_SCSI_MVSAS is not set | ||
| 626 | # CONFIG_SCSI_DPT_I2O is not set | 649 | # CONFIG_SCSI_DPT_I2O is not set |
| 627 | # CONFIG_SCSI_ADVANSYS is not set | 650 | # CONFIG_SCSI_ADVANSYS is not set |
| 628 | # CONFIG_SCSI_ARCMSR is not set | 651 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -642,7 +665,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 642 | # CONFIG_SCSI_IPS is not set | 665 | # CONFIG_SCSI_IPS is not set |
| 643 | # CONFIG_SCSI_INITIO is not set | 666 | # CONFIG_SCSI_INITIO is not set |
| 644 | # CONFIG_SCSI_INIA100 is not set | 667 | # CONFIG_SCSI_INIA100 is not set |
| 645 | # CONFIG_SCSI_MVSAS is not set | ||
| 646 | # CONFIG_SCSI_STEX is not set | 668 | # CONFIG_SCSI_STEX is not set |
| 647 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 669 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 648 | # CONFIG_SCSI_IPR is not set | 670 | # CONFIG_SCSI_IPR is not set |
| @@ -737,14 +759,17 @@ CONFIG_MD_RAID1=y | |||
| 737 | # | 759 | # |
| 738 | 760 | ||
| 739 | # | 761 | # |
| 740 | # Enable only one of the two stacks, unless you know what you are doing | 762 | # You can enable one or both FireWire driver stacks. |
| 763 | # | ||
| 764 | |||
| 765 | # | ||
| 766 | # See the help texts for more information. | ||
| 741 | # | 767 | # |
| 742 | # CONFIG_FIREWIRE is not set | 768 | # CONFIG_FIREWIRE is not set |
| 743 | # CONFIG_IEEE1394 is not set | 769 | # CONFIG_IEEE1394 is not set |
| 744 | # CONFIG_I2O is not set | 770 | # CONFIG_I2O is not set |
| 745 | # CONFIG_MACINTOSH_DRIVERS is not set | 771 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 746 | CONFIG_NETDEVICES=y | 772 | CONFIG_NETDEVICES=y |
| 747 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 748 | # CONFIG_DUMMY is not set | 773 | # CONFIG_DUMMY is not set |
| 749 | # CONFIG_BONDING is not set | 774 | # CONFIG_BONDING is not set |
| 750 | # CONFIG_MACVLAN is not set | 775 | # CONFIG_MACVLAN is not set |
| @@ -791,8 +816,10 @@ CONFIG_NETDEV_1000=y | |||
| 791 | # CONFIG_VIA_VELOCITY is not set | 816 | # CONFIG_VIA_VELOCITY is not set |
| 792 | # CONFIG_TIGON3 is not set | 817 | # CONFIG_TIGON3 is not set |
| 793 | # CONFIG_BNX2 is not set | 818 | # CONFIG_BNX2 is not set |
| 819 | # CONFIG_CNIC is not set | ||
| 794 | CONFIG_FSL_PQ_MDIO=y | 820 | CONFIG_FSL_PQ_MDIO=y |
| 795 | CONFIG_GIANFAR=y | 821 | CONFIG_GIANFAR=y |
| 822 | # CONFIG_MV643XX_ETH is not set | ||
| 796 | # CONFIG_QLA3XXX is not set | 823 | # CONFIG_QLA3XXX is not set |
| 797 | # CONFIG_ATL1 is not set | 824 | # CONFIG_ATL1 is not set |
| 798 | # CONFIG_ATL1E is not set | 825 | # CONFIG_ATL1E is not set |
| @@ -960,7 +987,6 @@ CONFIG_I2C_MPC=y | |||
| 960 | CONFIG_SENSORS_PCF8574=y | 987 | CONFIG_SENSORS_PCF8574=y |
| 961 | # CONFIG_PCF8575 is not set | 988 | # CONFIG_PCF8575 is not set |
| 962 | # CONFIG_SENSORS_PCA9539 is not set | 989 | # CONFIG_SENSORS_PCA9539 is not set |
| 963 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 964 | # CONFIG_SENSORS_TSL2550 is not set | 990 | # CONFIG_SENSORS_TSL2550 is not set |
| 965 | # CONFIG_I2C_DEBUG_CORE is not set | 991 | # CONFIG_I2C_DEBUG_CORE is not set |
| 966 | # CONFIG_I2C_DEBUG_ALGO is not set | 992 | # CONFIG_I2C_DEBUG_ALGO is not set |
| @@ -973,13 +999,18 @@ CONFIG_SPI_MASTER=y | |||
| 973 | # SPI Master Controller Drivers | 999 | # SPI Master Controller Drivers |
| 974 | # | 1000 | # |
| 975 | CONFIG_SPI_BITBANG=y | 1001 | CONFIG_SPI_BITBANG=y |
| 976 | CONFIG_SPI_MPC83xx=y | 1002 | # CONFIG_SPI_MPC8xxx is not set |
| 977 | 1003 | ||
| 978 | # | 1004 | # |
| 979 | # SPI Protocol Masters | 1005 | # SPI Protocol Masters |
| 980 | # | 1006 | # |
| 981 | # CONFIG_SPI_SPIDEV is not set | 1007 | # CONFIG_SPI_SPIDEV is not set |
| 982 | # CONFIG_SPI_TLE62X0 is not set | 1008 | # CONFIG_SPI_TLE62X0 is not set |
| 1009 | |||
| 1010 | # | ||
| 1011 | # PPS support | ||
| 1012 | # | ||
| 1013 | # CONFIG_PPS is not set | ||
| 983 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 1014 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 984 | # CONFIG_GPIOLIB is not set | 1015 | # CONFIG_GPIOLIB is not set |
| 985 | # CONFIG_W1 is not set | 1016 | # CONFIG_W1 is not set |
| @@ -1026,24 +1057,10 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1026 | # CONFIG_MFD_WM8400 is not set | 1057 | # CONFIG_MFD_WM8400 is not set |
| 1027 | # CONFIG_MFD_WM8350_I2C is not set | 1058 | # CONFIG_MFD_WM8350_I2C is not set |
| 1028 | # CONFIG_MFD_PCF50633 is not set | 1059 | # CONFIG_MFD_PCF50633 is not set |
| 1060 | # CONFIG_AB3100_CORE is not set | ||
| 1061 | # CONFIG_EZX_PCAP is not set | ||
| 1029 | # CONFIG_REGULATOR is not set | 1062 | # CONFIG_REGULATOR is not set |
| 1030 | 1063 | # CONFIG_MEDIA_SUPPORT is not set | |
| 1031 | # | ||
| 1032 | # Multimedia devices | ||
| 1033 | # | ||
| 1034 | |||
| 1035 | # | ||
| 1036 | # Multimedia core support | ||
| 1037 | # | ||
| 1038 | # CONFIG_VIDEO_DEV is not set | ||
| 1039 | # CONFIG_DVB_CORE is not set | ||
| 1040 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1041 | |||
| 1042 | # | ||
| 1043 | # Multimedia drivers | ||
| 1044 | # | ||
| 1045 | CONFIG_DAB=y | ||
| 1046 | # CONFIG_USB_DABUSB is not set | ||
| 1047 | 1064 | ||
| 1048 | # | 1065 | # |
| 1049 | # Graphics support | 1066 | # Graphics support |
| @@ -1085,6 +1102,7 @@ CONFIG_USB_MON=y | |||
| 1085 | # USB Host Controller Drivers | 1102 | # USB Host Controller Drivers |
| 1086 | # | 1103 | # |
| 1087 | # CONFIG_USB_C67X00_HCD is not set | 1104 | # CONFIG_USB_C67X00_HCD is not set |
| 1105 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1088 | CONFIG_USB_EHCI_HCD=y | 1106 | CONFIG_USB_EHCI_HCD=y |
| 1089 | CONFIG_USB_EHCI_ROOT_HUB_TT=y | 1107 | CONFIG_USB_EHCI_ROOT_HUB_TT=y |
| 1090 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1108 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1208,6 +1226,7 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 1208 | # CONFIG_RTC_DRV_S35390A is not set | 1226 | # CONFIG_RTC_DRV_S35390A is not set |
| 1209 | # CONFIG_RTC_DRV_FM3130 is not set | 1227 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1210 | # CONFIG_RTC_DRV_RX8581 is not set | 1228 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1229 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1211 | 1230 | ||
| 1212 | # | 1231 | # |
| 1213 | # SPI RTC drivers | 1232 | # SPI RTC drivers |
| @@ -1242,6 +1261,10 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 1242 | # CONFIG_DMADEVICES is not set | 1261 | # CONFIG_DMADEVICES is not set |
| 1243 | # CONFIG_AUXDISPLAY is not set | 1262 | # CONFIG_AUXDISPLAY is not set |
| 1244 | # CONFIG_UIO is not set | 1263 | # CONFIG_UIO is not set |
| 1264 | |||
| 1265 | # | ||
| 1266 | # TI VLYNQ | ||
| 1267 | # | ||
| 1245 | # CONFIG_STAGING is not set | 1268 | # CONFIG_STAGING is not set |
| 1246 | 1269 | ||
| 1247 | # | 1270 | # |
| @@ -1261,10 +1284,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1261 | # CONFIG_REISERFS_FS is not set | 1284 | # CONFIG_REISERFS_FS is not set |
| 1262 | # CONFIG_JFS_FS is not set | 1285 | # CONFIG_JFS_FS is not set |
| 1263 | # CONFIG_FS_POSIX_ACL is not set | 1286 | # CONFIG_FS_POSIX_ACL is not set |
| 1264 | CONFIG_FILE_LOCKING=y | ||
| 1265 | # CONFIG_XFS_FS is not set | 1287 | # CONFIG_XFS_FS is not set |
| 1288 | # CONFIG_GFS2_FS is not set | ||
| 1266 | # CONFIG_OCFS2_FS is not set | 1289 | # CONFIG_OCFS2_FS is not set |
| 1267 | # CONFIG_BTRFS_FS is not set | 1290 | # CONFIG_BTRFS_FS is not set |
| 1291 | CONFIG_FILE_LOCKING=y | ||
| 1292 | CONFIG_FSNOTIFY=y | ||
| 1268 | CONFIG_DNOTIFY=y | 1293 | CONFIG_DNOTIFY=y |
| 1269 | CONFIG_INOTIFY=y | 1294 | CONFIG_INOTIFY=y |
| 1270 | CONFIG_INOTIFY_USER=y | 1295 | CONFIG_INOTIFY_USER=y |
| @@ -1331,6 +1356,7 @@ CONFIG_NFS_FS=y | |||
| 1331 | CONFIG_NFS_V3=y | 1356 | CONFIG_NFS_V3=y |
| 1332 | # CONFIG_NFS_V3_ACL is not set | 1357 | # CONFIG_NFS_V3_ACL is not set |
| 1333 | CONFIG_NFS_V4=y | 1358 | CONFIG_NFS_V4=y |
| 1359 | # CONFIG_NFS_V4_1 is not set | ||
| 1334 | CONFIG_ROOT_NFS=y | 1360 | CONFIG_ROOT_NFS=y |
| 1335 | # CONFIG_NFSD is not set | 1361 | # CONFIG_NFSD is not set |
| 1336 | CONFIG_LOCKD=y | 1362 | CONFIG_LOCKD=y |
| @@ -1429,6 +1455,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1429 | CONFIG_HAS_DMA=y | 1455 | CONFIG_HAS_DMA=y |
| 1430 | CONFIG_HAVE_LMB=y | 1456 | CONFIG_HAVE_LMB=y |
| 1431 | CONFIG_NLATTR=y | 1457 | CONFIG_NLATTR=y |
| 1458 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1432 | 1459 | ||
| 1433 | # | 1460 | # |
| 1434 | # Kernel hacking | 1461 | # Kernel hacking |
| @@ -1454,22 +1481,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1454 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1481 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1455 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1482 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1456 | CONFIG_TRACING_SUPPORT=y | 1483 | CONFIG_TRACING_SUPPORT=y |
| 1457 | 1484 | # CONFIG_FTRACE is not set | |
| 1458 | # | ||
| 1459 | # Tracers | ||
| 1460 | # | ||
| 1461 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1462 | # CONFIG_SCHED_TRACER is not set | ||
| 1463 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1464 | # CONFIG_EVENT_TRACER is not set | ||
| 1465 | # CONFIG_BOOT_TRACER is not set | ||
| 1466 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1467 | # CONFIG_STACK_TRACER is not set | ||
| 1468 | # CONFIG_KMEMTRACE is not set | ||
| 1469 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1470 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1471 | # CONFIG_SAMPLES is not set | 1485 | # CONFIG_SAMPLES is not set |
| 1472 | CONFIG_HAVE_ARCH_KGDB=y | 1486 | CONFIG_HAVE_ARCH_KGDB=y |
| 1487 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1488 | CONFIG_PPC_WERROR=y | ||
| 1473 | CONFIG_PRINT_STACK_DEPTH=64 | 1489 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1474 | # CONFIG_IRQSTACKS is not set | 1490 | # CONFIG_IRQSTACKS is not set |
| 1475 | # CONFIG_BOOTX_TEXT is not set | 1491 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/83xx/mpc834x_itxgp_defconfig b/arch/powerpc/configs/83xx/mpc834x_itxgp_defconfig index 7f39543205a9..bf6deb831dc3 100644 --- a/arch/powerpc/configs/83xx/mpc834x_itxgp_defconfig +++ b/arch/powerpc/configs/83xx/mpc834x_itxgp_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:10 2009 | 4 | # Wed Jul 29 23:32:08 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_FSL_EMB_PERFMON is not set | 20 | # CONFIG_FSL_EMB_PERFMON is not set |
| 20 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 45 | CONFIG_PPC=y | 48 | CONFIG_PPC=y |
| @@ -53,12 +56,14 @@ CONFIG_PPC_UDBG_16550=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 57 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 61 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| 58 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 59 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 60 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 61 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 62 | 67 | ||
| 63 | # | 68 | # |
| 64 | # General setup | 69 | # General setup |
| @@ -107,7 +112,6 @@ CONFIG_ANON_INODES=y | |||
| 107 | CONFIG_EMBEDDED=y | 112 | CONFIG_EMBEDDED=y |
| 108 | CONFIG_SYSCTL_SYSCALL=y | 113 | CONFIG_SYSCTL_SYSCALL=y |
| 109 | # CONFIG_KALLSYMS is not set | 114 | # CONFIG_KALLSYMS is not set |
| 110 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 111 | CONFIG_HOTPLUG=y | 115 | CONFIG_HOTPLUG=y |
| 112 | CONFIG_PRINTK=y | 116 | CONFIG_PRINTK=y |
| 113 | CONFIG_BUG=y | 117 | CONFIG_BUG=y |
| @@ -120,9 +124,16 @@ CONFIG_TIMERFD=y | |||
| 120 | CONFIG_EVENTFD=y | 124 | CONFIG_EVENTFD=y |
| 121 | CONFIG_SHMEM=y | 125 | CONFIG_SHMEM=y |
| 122 | CONFIG_AIO=y | 126 | CONFIG_AIO=y |
| 127 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 128 | |||
| 129 | # | ||
| 130 | # Performance Counters | ||
| 131 | # | ||
| 132 | # CONFIG_PERF_COUNTERS is not set | ||
| 123 | CONFIG_VM_EVENT_COUNTERS=y | 133 | CONFIG_VM_EVENT_COUNTERS=y |
| 124 | CONFIG_PCI_QUIRKS=y | 134 | CONFIG_PCI_QUIRKS=y |
| 125 | CONFIG_SLUB_DEBUG=y | 135 | CONFIG_SLUB_DEBUG=y |
| 136 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 126 | CONFIG_COMPAT_BRK=y | 137 | CONFIG_COMPAT_BRK=y |
| 127 | # CONFIG_SLAB is not set | 138 | # CONFIG_SLAB is not set |
| 128 | CONFIG_SLUB=y | 139 | CONFIG_SLUB=y |
| @@ -135,6 +146,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 135 | CONFIG_HAVE_KPROBES=y | 146 | CONFIG_HAVE_KPROBES=y |
| 136 | CONFIG_HAVE_KRETPROBES=y | 147 | CONFIG_HAVE_KRETPROBES=y |
| 137 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 148 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 149 | |||
| 150 | # | ||
| 151 | # GCOV-based kernel profiling | ||
| 152 | # | ||
| 138 | # CONFIG_SLOW_WORK is not set | 153 | # CONFIG_SLOW_WORK is not set |
| 139 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 140 | CONFIG_SLABINFO=y | 155 | CONFIG_SLABINFO=y |
| @@ -147,7 +162,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 147 | # CONFIG_MODVERSIONS is not set | 162 | # CONFIG_MODVERSIONS is not set |
| 148 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 163 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 149 | CONFIG_BLOCK=y | 164 | CONFIG_BLOCK=y |
| 150 | # CONFIG_LBD is not set | 165 | CONFIG_LBDAF=y |
| 151 | # CONFIG_BLK_DEV_BSG is not set | 166 | # CONFIG_BLK_DEV_BSG is not set |
| 152 | # CONFIG_BLK_DEV_INTEGRITY is not set | 167 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 153 | 168 | ||
| @@ -189,6 +204,7 @@ CONFIG_MPC834x_ITX=y | |||
| 189 | # CONFIG_MPC837x_RDB is not set | 204 | # CONFIG_MPC837x_RDB is not set |
| 190 | # CONFIG_SBC834x is not set | 205 | # CONFIG_SBC834x is not set |
| 191 | # CONFIG_ASP834x is not set | 206 | # CONFIG_ASP834x is not set |
| 207 | # CONFIG_KMETER1 is not set | ||
| 192 | CONFIG_PPC_MPC834x=y | 208 | CONFIG_PPC_MPC834x=y |
| 193 | # CONFIG_PPC_86xx is not set | 209 | # CONFIG_PPC_86xx is not set |
| 194 | # CONFIG_EMBEDDED6xx is not set | 210 | # CONFIG_EMBEDDED6xx is not set |
| @@ -234,6 +250,7 @@ CONFIG_BINFMT_ELF=y | |||
| 234 | # CONFIG_HAVE_AOUT is not set | 250 | # CONFIG_HAVE_AOUT is not set |
| 235 | # CONFIG_BINFMT_MISC is not set | 251 | # CONFIG_BINFMT_MISC is not set |
| 236 | # CONFIG_IOMMU_HELPER is not set | 252 | # CONFIG_IOMMU_HELPER is not set |
| 253 | # CONFIG_SWIOTLB is not set | ||
| 237 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 254 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 238 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 255 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 239 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 256 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -254,9 +271,9 @@ CONFIG_MIGRATION=y | |||
| 254 | CONFIG_ZONE_DMA_FLAG=1 | 271 | CONFIG_ZONE_DMA_FLAG=1 |
| 255 | CONFIG_BOUNCE=y | 272 | CONFIG_BOUNCE=y |
| 256 | CONFIG_VIRT_TO_BUS=y | 273 | CONFIG_VIRT_TO_BUS=y |
| 257 | CONFIG_UNEVICTABLE_LRU=y | ||
| 258 | CONFIG_HAVE_MLOCK=y | 274 | CONFIG_HAVE_MLOCK=y |
| 259 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 275 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 276 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 260 | CONFIG_PPC_4K_PAGES=y | 277 | CONFIG_PPC_4K_PAGES=y |
| 261 | # CONFIG_PPC_16K_PAGES is not set | 278 | # CONFIG_PPC_16K_PAGES is not set |
| 262 | # CONFIG_PPC_64K_PAGES is not set | 279 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -365,6 +382,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 365 | # CONFIG_ECONET is not set | 382 | # CONFIG_ECONET is not set |
| 366 | # CONFIG_WAN_ROUTER is not set | 383 | # CONFIG_WAN_ROUTER is not set |
| 367 | # CONFIG_PHONET is not set | 384 | # CONFIG_PHONET is not set |
| 385 | # CONFIG_IEEE802154 is not set | ||
| 368 | # CONFIG_NET_SCHED is not set | 386 | # CONFIG_NET_SCHED is not set |
| 369 | # CONFIG_DCB is not set | 387 | # CONFIG_DCB is not set |
| 370 | 388 | ||
| @@ -382,7 +400,11 @@ CONFIG_WIRELESS=y | |||
| 382 | CONFIG_WIRELESS_OLD_REGULATORY=y | 400 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 383 | # CONFIG_WIRELESS_EXT is not set | 401 | # CONFIG_WIRELESS_EXT is not set |
| 384 | # CONFIG_LIB80211 is not set | 402 | # CONFIG_LIB80211 is not set |
| 385 | # CONFIG_MAC80211 is not set | 403 | |
| 404 | # | ||
| 405 | # CFG80211 needs to be enabled for MAC80211 | ||
| 406 | # | ||
| 407 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 386 | # CONFIG_WIMAX is not set | 408 | # CONFIG_WIMAX is not set |
| 387 | # CONFIG_RFKILL is not set | 409 | # CONFIG_RFKILL is not set |
| 388 | # CONFIG_NET_9P is not set | 410 | # CONFIG_NET_9P is not set |
| @@ -487,6 +509,7 @@ CONFIG_MTD_PHYSMAP=y | |||
| 487 | CONFIG_OF_DEVICE=y | 509 | CONFIG_OF_DEVICE=y |
| 488 | CONFIG_OF_I2C=y | 510 | CONFIG_OF_I2C=y |
| 489 | CONFIG_OF_SPI=y | 511 | CONFIG_OF_SPI=y |
| 512 | CONFIG_OF_MDIO=y | ||
| 490 | # CONFIG_PARPORT is not set | 513 | # CONFIG_PARPORT is not set |
| 491 | CONFIG_BLK_DEV=y | 514 | CONFIG_BLK_DEV=y |
| 492 | # CONFIG_BLK_DEV_FD is not set | 515 | # CONFIG_BLK_DEV_FD is not set |
| @@ -523,7 +546,9 @@ CONFIG_MISC_DEVICES=y | |||
| 523 | # CONFIG_EEPROM_AT24 is not set | 546 | # CONFIG_EEPROM_AT24 is not set |
| 524 | # CONFIG_EEPROM_AT25 is not set | 547 | # CONFIG_EEPROM_AT25 is not set |
| 525 | # CONFIG_EEPROM_LEGACY is not set | 548 | # CONFIG_EEPROM_LEGACY is not set |
| 549 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 526 | # CONFIG_EEPROM_93CX6 is not set | 550 | # CONFIG_EEPROM_93CX6 is not set |
| 551 | # CONFIG_CB710_CORE is not set | ||
| 527 | CONFIG_HAVE_IDE=y | 552 | CONFIG_HAVE_IDE=y |
| 528 | # CONFIG_IDE is not set | 553 | # CONFIG_IDE is not set |
| 529 | 554 | ||
| @@ -546,10 +571,6 @@ CONFIG_BLK_DEV_SD=y | |||
| 546 | # CONFIG_BLK_DEV_SR is not set | 571 | # CONFIG_BLK_DEV_SR is not set |
| 547 | CONFIG_CHR_DEV_SG=y | 572 | CONFIG_CHR_DEV_SG=y |
| 548 | # CONFIG_CHR_DEV_SCH is not set | 573 | # CONFIG_CHR_DEV_SCH is not set |
| 549 | |||
| 550 | # | ||
| 551 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 552 | # | ||
| 553 | # CONFIG_SCSI_MULTI_LUN is not set | 574 | # CONFIG_SCSI_MULTI_LUN is not set |
| 554 | # CONFIG_SCSI_CONSTANTS is not set | 575 | # CONFIG_SCSI_CONSTANTS is not set |
| 555 | # CONFIG_SCSI_LOGGING is not set | 576 | # CONFIG_SCSI_LOGGING is not set |
| @@ -567,6 +588,7 @@ CONFIG_SCSI_SPI_ATTRS=y | |||
| 567 | CONFIG_SCSI_LOWLEVEL=y | 588 | CONFIG_SCSI_LOWLEVEL=y |
| 568 | # CONFIG_ISCSI_TCP is not set | 589 | # CONFIG_ISCSI_TCP is not set |
| 569 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 590 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 591 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 570 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 592 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 571 | # CONFIG_SCSI_3W_9XXX is not set | 593 | # CONFIG_SCSI_3W_9XXX is not set |
| 572 | # CONFIG_SCSI_ACARD is not set | 594 | # CONFIG_SCSI_ACARD is not set |
| @@ -575,6 +597,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 575 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 597 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 576 | # CONFIG_SCSI_AIC79XX is not set | 598 | # CONFIG_SCSI_AIC79XX is not set |
| 577 | # CONFIG_SCSI_AIC94XX is not set | 599 | # CONFIG_SCSI_AIC94XX is not set |
| 600 | # CONFIG_SCSI_MVSAS is not set | ||
| 578 | # CONFIG_SCSI_DPT_I2O is not set | 601 | # CONFIG_SCSI_DPT_I2O is not set |
| 579 | # CONFIG_SCSI_ADVANSYS is not set | 602 | # CONFIG_SCSI_ADVANSYS is not set |
| 580 | # CONFIG_SCSI_ARCMSR is not set | 603 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -594,7 +617,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 594 | # CONFIG_SCSI_IPS is not set | 617 | # CONFIG_SCSI_IPS is not set |
| 595 | # CONFIG_SCSI_INITIO is not set | 618 | # CONFIG_SCSI_INITIO is not set |
| 596 | # CONFIG_SCSI_INIA100 is not set | 619 | # CONFIG_SCSI_INIA100 is not set |
| 597 | # CONFIG_SCSI_MVSAS is not set | ||
| 598 | # CONFIG_SCSI_STEX is not set | 620 | # CONFIG_SCSI_STEX is not set |
| 599 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 621 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 600 | # CONFIG_SCSI_QLOGIC_1280 is not set | 622 | # CONFIG_SCSI_QLOGIC_1280 is not set |
| @@ -617,14 +639,17 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 617 | # | 639 | # |
| 618 | 640 | ||
| 619 | # | 641 | # |
| 620 | # Enable only one of the two stacks, unless you know what you are doing | 642 | # You can enable one or both FireWire driver stacks. |
| 643 | # | ||
| 644 | |||
| 645 | # | ||
| 646 | # See the help texts for more information. | ||
| 621 | # | 647 | # |
| 622 | # CONFIG_FIREWIRE is not set | 648 | # CONFIG_FIREWIRE is not set |
| 623 | # CONFIG_IEEE1394 is not set | 649 | # CONFIG_IEEE1394 is not set |
| 624 | # CONFIG_I2O is not set | 650 | # CONFIG_I2O is not set |
| 625 | # CONFIG_MACINTOSH_DRIVERS is not set | 651 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 626 | CONFIG_NETDEVICES=y | 652 | CONFIG_NETDEVICES=y |
| 627 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 628 | # CONFIG_DUMMY is not set | 653 | # CONFIG_DUMMY is not set |
| 629 | # CONFIG_BONDING is not set | 654 | # CONFIG_BONDING is not set |
| 630 | # CONFIG_MACVLAN is not set | 655 | # CONFIG_MACVLAN is not set |
| @@ -671,8 +696,10 @@ CONFIG_NETDEV_1000=y | |||
| 671 | # CONFIG_VIA_VELOCITY is not set | 696 | # CONFIG_VIA_VELOCITY is not set |
| 672 | # CONFIG_TIGON3 is not set | 697 | # CONFIG_TIGON3 is not set |
| 673 | # CONFIG_BNX2 is not set | 698 | # CONFIG_BNX2 is not set |
| 699 | # CONFIG_CNIC is not set | ||
| 674 | CONFIG_FSL_PQ_MDIO=y | 700 | CONFIG_FSL_PQ_MDIO=y |
| 675 | CONFIG_GIANFAR=y | 701 | CONFIG_GIANFAR=y |
| 702 | # CONFIG_MV643XX_ETH is not set | ||
| 676 | # CONFIG_QLA3XXX is not set | 703 | # CONFIG_QLA3XXX is not set |
| 677 | # CONFIG_ATL1 is not set | 704 | # CONFIG_ATL1 is not set |
| 678 | # CONFIG_ATL1E is not set | 705 | # CONFIG_ATL1E is not set |
| @@ -840,7 +867,6 @@ CONFIG_I2C_MPC=y | |||
| 840 | CONFIG_SENSORS_PCF8574=y | 867 | CONFIG_SENSORS_PCF8574=y |
| 841 | # CONFIG_PCF8575 is not set | 868 | # CONFIG_PCF8575 is not set |
| 842 | # CONFIG_SENSORS_PCA9539 is not set | 869 | # CONFIG_SENSORS_PCA9539 is not set |
| 843 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 844 | # CONFIG_SENSORS_TSL2550 is not set | 870 | # CONFIG_SENSORS_TSL2550 is not set |
| 845 | # CONFIG_I2C_DEBUG_CORE is not set | 871 | # CONFIG_I2C_DEBUG_CORE is not set |
| 846 | # CONFIG_I2C_DEBUG_ALGO is not set | 872 | # CONFIG_I2C_DEBUG_ALGO is not set |
| @@ -853,13 +879,18 @@ CONFIG_SPI_MASTER=y | |||
| 853 | # SPI Master Controller Drivers | 879 | # SPI Master Controller Drivers |
| 854 | # | 880 | # |
| 855 | CONFIG_SPI_BITBANG=y | 881 | CONFIG_SPI_BITBANG=y |
| 856 | CONFIG_SPI_MPC83xx=y | 882 | # CONFIG_SPI_MPC8xxx is not set |
| 857 | 883 | ||
| 858 | # | 884 | # |
| 859 | # SPI Protocol Masters | 885 | # SPI Protocol Masters |
| 860 | # | 886 | # |
| 861 | # CONFIG_SPI_SPIDEV is not set | 887 | # CONFIG_SPI_SPIDEV is not set |
| 862 | # CONFIG_SPI_TLE62X0 is not set | 888 | # CONFIG_SPI_TLE62X0 is not set |
| 889 | |||
| 890 | # | ||
| 891 | # PPS support | ||
| 892 | # | ||
| 893 | # CONFIG_PPS is not set | ||
| 863 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 894 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 864 | # CONFIG_GPIOLIB is not set | 895 | # CONFIG_GPIOLIB is not set |
| 865 | # CONFIG_W1 is not set | 896 | # CONFIG_W1 is not set |
| @@ -906,24 +937,10 @@ CONFIG_SSB_POSSIBLE=y | |||
| 906 | # CONFIG_MFD_WM8400 is not set | 937 | # CONFIG_MFD_WM8400 is not set |
| 907 | # CONFIG_MFD_WM8350_I2C is not set | 938 | # CONFIG_MFD_WM8350_I2C is not set |
| 908 | # CONFIG_MFD_PCF50633 is not set | 939 | # CONFIG_MFD_PCF50633 is not set |
| 940 | # CONFIG_AB3100_CORE is not set | ||
| 941 | # CONFIG_EZX_PCAP is not set | ||
| 909 | # CONFIG_REGULATOR is not set | 942 | # CONFIG_REGULATOR is not set |
| 910 | 943 | # CONFIG_MEDIA_SUPPORT is not set | |
| 911 | # | ||
| 912 | # Multimedia devices | ||
| 913 | # | ||
| 914 | |||
| 915 | # | ||
| 916 | # Multimedia core support | ||
| 917 | # | ||
| 918 | # CONFIG_VIDEO_DEV is not set | ||
| 919 | # CONFIG_DVB_CORE is not set | ||
| 920 | # CONFIG_VIDEO_MEDIA is not set | ||
| 921 | |||
| 922 | # | ||
| 923 | # Multimedia drivers | ||
| 924 | # | ||
| 925 | CONFIG_DAB=y | ||
| 926 | # CONFIG_USB_DABUSB is not set | ||
| 927 | 944 | ||
| 928 | # | 945 | # |
| 929 | # Graphics support | 946 | # Graphics support |
| @@ -965,6 +982,7 @@ CONFIG_USB_MON=y | |||
| 965 | # USB Host Controller Drivers | 982 | # USB Host Controller Drivers |
| 966 | # | 983 | # |
| 967 | # CONFIG_USB_C67X00_HCD is not set | 984 | # CONFIG_USB_C67X00_HCD is not set |
| 985 | # CONFIG_USB_XHCI_HCD is not set | ||
| 968 | CONFIG_USB_EHCI_HCD=y | 986 | CONFIG_USB_EHCI_HCD=y |
| 969 | CONFIG_USB_EHCI_ROOT_HUB_TT=y | 987 | CONFIG_USB_EHCI_ROOT_HUB_TT=y |
| 970 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 988 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1087,6 +1105,7 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 1087 | # CONFIG_RTC_DRV_S35390A is not set | 1105 | # CONFIG_RTC_DRV_S35390A is not set |
| 1088 | # CONFIG_RTC_DRV_FM3130 is not set | 1106 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1089 | # CONFIG_RTC_DRV_RX8581 is not set | 1107 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1108 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1090 | 1109 | ||
| 1091 | # | 1110 | # |
| 1092 | # SPI RTC drivers | 1111 | # SPI RTC drivers |
| @@ -1121,6 +1140,10 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 1121 | # CONFIG_DMADEVICES is not set | 1140 | # CONFIG_DMADEVICES is not set |
| 1122 | # CONFIG_AUXDISPLAY is not set | 1141 | # CONFIG_AUXDISPLAY is not set |
| 1123 | # CONFIG_UIO is not set | 1142 | # CONFIG_UIO is not set |
| 1143 | |||
| 1144 | # | ||
| 1145 | # TI VLYNQ | ||
| 1146 | # | ||
| 1124 | # CONFIG_STAGING is not set | 1147 | # CONFIG_STAGING is not set |
| 1125 | 1148 | ||
| 1126 | # | 1149 | # |
| @@ -1140,10 +1163,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1140 | # CONFIG_REISERFS_FS is not set | 1163 | # CONFIG_REISERFS_FS is not set |
| 1141 | # CONFIG_JFS_FS is not set | 1164 | # CONFIG_JFS_FS is not set |
| 1142 | # CONFIG_FS_POSIX_ACL is not set | 1165 | # CONFIG_FS_POSIX_ACL is not set |
| 1143 | CONFIG_FILE_LOCKING=y | ||
| 1144 | # CONFIG_XFS_FS is not set | 1166 | # CONFIG_XFS_FS is not set |
| 1167 | # CONFIG_GFS2_FS is not set | ||
| 1145 | # CONFIG_OCFS2_FS is not set | 1168 | # CONFIG_OCFS2_FS is not set |
| 1146 | # CONFIG_BTRFS_FS is not set | 1169 | # CONFIG_BTRFS_FS is not set |
| 1170 | CONFIG_FILE_LOCKING=y | ||
| 1171 | CONFIG_FSNOTIFY=y | ||
| 1147 | CONFIG_DNOTIFY=y | 1172 | CONFIG_DNOTIFY=y |
| 1148 | CONFIG_INOTIFY=y | 1173 | CONFIG_INOTIFY=y |
| 1149 | CONFIG_INOTIFY_USER=y | 1174 | CONFIG_INOTIFY_USER=y |
| @@ -1210,6 +1235,7 @@ CONFIG_NFS_FS=y | |||
| 1210 | CONFIG_NFS_V3=y | 1235 | CONFIG_NFS_V3=y |
| 1211 | # CONFIG_NFS_V3_ACL is not set | 1236 | # CONFIG_NFS_V3_ACL is not set |
| 1212 | CONFIG_NFS_V4=y | 1237 | CONFIG_NFS_V4=y |
| 1238 | # CONFIG_NFS_V4_1 is not set | ||
| 1213 | CONFIG_ROOT_NFS=y | 1239 | CONFIG_ROOT_NFS=y |
| 1214 | # CONFIG_NFSD is not set | 1240 | # CONFIG_NFSD is not set |
| 1215 | CONFIG_LOCKD=y | 1241 | CONFIG_LOCKD=y |
| @@ -1308,6 +1334,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1308 | CONFIG_HAS_DMA=y | 1334 | CONFIG_HAS_DMA=y |
| 1309 | CONFIG_HAVE_LMB=y | 1335 | CONFIG_HAVE_LMB=y |
| 1310 | CONFIG_NLATTR=y | 1336 | CONFIG_NLATTR=y |
| 1337 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1311 | 1338 | ||
| 1312 | # | 1339 | # |
| 1313 | # Kernel hacking | 1340 | # Kernel hacking |
| @@ -1333,22 +1360,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1333 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1360 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1334 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1361 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1335 | CONFIG_TRACING_SUPPORT=y | 1362 | CONFIG_TRACING_SUPPORT=y |
| 1336 | 1363 | # CONFIG_FTRACE is not set | |
| 1337 | # | ||
| 1338 | # Tracers | ||
| 1339 | # | ||
| 1340 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1341 | # CONFIG_SCHED_TRACER is not set | ||
| 1342 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1343 | # CONFIG_EVENT_TRACER is not set | ||
| 1344 | # CONFIG_BOOT_TRACER is not set | ||
| 1345 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1346 | # CONFIG_STACK_TRACER is not set | ||
| 1347 | # CONFIG_KMEMTRACE is not set | ||
| 1348 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1349 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1350 | # CONFIG_SAMPLES is not set | 1364 | # CONFIG_SAMPLES is not set |
| 1351 | CONFIG_HAVE_ARCH_KGDB=y | 1365 | CONFIG_HAVE_ARCH_KGDB=y |
| 1366 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1367 | CONFIG_PPC_WERROR=y | ||
| 1352 | CONFIG_PRINT_STACK_DEPTH=64 | 1368 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1353 | # CONFIG_IRQSTACKS is not set | 1369 | # CONFIG_IRQSTACKS is not set |
| 1354 | # CONFIG_BOOTX_TEXT is not set | 1370 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/83xx/mpc834x_mds_defconfig b/arch/powerpc/configs/83xx/mpc834x_mds_defconfig index 1cd1fcac22c8..3236c47712c2 100644 --- a/arch/powerpc/configs/83xx/mpc834x_mds_defconfig +++ b/arch/powerpc/configs/83xx/mpc834x_mds_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:11 2009 | 4 | # Wed Jul 29 23:32:09 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_FSL_EMB_PERFMON is not set | 20 | # CONFIG_FSL_EMB_PERFMON is not set |
| 20 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 45 | CONFIG_PPC=y | 48 | CONFIG_PPC=y |
| @@ -53,12 +56,14 @@ CONFIG_PPC_UDBG_16550=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 57 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 61 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| 58 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 59 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 60 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 61 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 62 | 67 | ||
| 63 | # | 68 | # |
| 64 | # General setup | 69 | # General setup |
| @@ -107,7 +112,6 @@ CONFIG_ANON_INODES=y | |||
| 107 | CONFIG_EMBEDDED=y | 112 | CONFIG_EMBEDDED=y |
| 108 | CONFIG_SYSCTL_SYSCALL=y | 113 | CONFIG_SYSCTL_SYSCALL=y |
| 109 | # CONFIG_KALLSYMS is not set | 114 | # CONFIG_KALLSYMS is not set |
| 110 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 111 | CONFIG_HOTPLUG=y | 115 | CONFIG_HOTPLUG=y |
| 112 | CONFIG_PRINTK=y | 116 | CONFIG_PRINTK=y |
| 113 | CONFIG_BUG=y | 117 | CONFIG_BUG=y |
| @@ -120,9 +124,16 @@ CONFIG_TIMERFD=y | |||
| 120 | CONFIG_EVENTFD=y | 124 | CONFIG_EVENTFD=y |
| 121 | CONFIG_SHMEM=y | 125 | CONFIG_SHMEM=y |
| 122 | CONFIG_AIO=y | 126 | CONFIG_AIO=y |
| 127 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 128 | |||
| 129 | # | ||
| 130 | # Performance Counters | ||
| 131 | # | ||
| 132 | # CONFIG_PERF_COUNTERS is not set | ||
| 123 | CONFIG_VM_EVENT_COUNTERS=y | 133 | CONFIG_VM_EVENT_COUNTERS=y |
| 124 | CONFIG_PCI_QUIRKS=y | 134 | CONFIG_PCI_QUIRKS=y |
| 125 | CONFIG_SLUB_DEBUG=y | 135 | CONFIG_SLUB_DEBUG=y |
| 136 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 126 | CONFIG_COMPAT_BRK=y | 137 | CONFIG_COMPAT_BRK=y |
| 127 | # CONFIG_SLAB is not set | 138 | # CONFIG_SLAB is not set |
| 128 | CONFIG_SLUB=y | 139 | CONFIG_SLUB=y |
| @@ -135,6 +146,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 135 | CONFIG_HAVE_KPROBES=y | 146 | CONFIG_HAVE_KPROBES=y |
| 136 | CONFIG_HAVE_KRETPROBES=y | 147 | CONFIG_HAVE_KRETPROBES=y |
| 137 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 148 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 149 | |||
| 150 | # | ||
| 151 | # GCOV-based kernel profiling | ||
| 152 | # | ||
| 138 | # CONFIG_SLOW_WORK is not set | 153 | # CONFIG_SLOW_WORK is not set |
| 139 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 140 | CONFIG_SLABINFO=y | 155 | CONFIG_SLABINFO=y |
| @@ -147,7 +162,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 147 | # CONFIG_MODVERSIONS is not set | 162 | # CONFIG_MODVERSIONS is not set |
| 148 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 163 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 149 | CONFIG_BLOCK=y | 164 | CONFIG_BLOCK=y |
| 150 | # CONFIG_LBD is not set | 165 | CONFIG_LBDAF=y |
| 151 | # CONFIG_BLK_DEV_BSG is not set | 166 | # CONFIG_BLK_DEV_BSG is not set |
| 152 | # CONFIG_BLK_DEV_INTEGRITY is not set | 167 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 153 | 168 | ||
| @@ -189,6 +204,7 @@ CONFIG_MPC834x_MDS=y | |||
| 189 | # CONFIG_MPC837x_RDB is not set | 204 | # CONFIG_MPC837x_RDB is not set |
| 190 | # CONFIG_SBC834x is not set | 205 | # CONFIG_SBC834x is not set |
| 191 | # CONFIG_ASP834x is not set | 206 | # CONFIG_ASP834x is not set |
| 207 | # CONFIG_KMETER1 is not set | ||
| 192 | CONFIG_PPC_MPC834x=y | 208 | CONFIG_PPC_MPC834x=y |
| 193 | # CONFIG_PPC_86xx is not set | 209 | # CONFIG_PPC_86xx is not set |
| 194 | # CONFIG_EMBEDDED6xx is not set | 210 | # CONFIG_EMBEDDED6xx is not set |
| @@ -234,6 +250,7 @@ CONFIG_BINFMT_ELF=y | |||
| 234 | # CONFIG_HAVE_AOUT is not set | 250 | # CONFIG_HAVE_AOUT is not set |
| 235 | # CONFIG_BINFMT_MISC is not set | 251 | # CONFIG_BINFMT_MISC is not set |
| 236 | # CONFIG_IOMMU_HELPER is not set | 252 | # CONFIG_IOMMU_HELPER is not set |
| 253 | # CONFIG_SWIOTLB is not set | ||
| 237 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 254 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 238 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 255 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 239 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 256 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -254,9 +271,9 @@ CONFIG_MIGRATION=y | |||
| 254 | CONFIG_ZONE_DMA_FLAG=1 | 271 | CONFIG_ZONE_DMA_FLAG=1 |
| 255 | CONFIG_BOUNCE=y | 272 | CONFIG_BOUNCE=y |
| 256 | CONFIG_VIRT_TO_BUS=y | 273 | CONFIG_VIRT_TO_BUS=y |
| 257 | CONFIG_UNEVICTABLE_LRU=y | ||
| 258 | CONFIG_HAVE_MLOCK=y | 274 | CONFIG_HAVE_MLOCK=y |
| 259 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 275 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 276 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 260 | CONFIG_PPC_4K_PAGES=y | 277 | CONFIG_PPC_4K_PAGES=y |
| 261 | # CONFIG_PPC_16K_PAGES is not set | 278 | # CONFIG_PPC_16K_PAGES is not set |
| 262 | # CONFIG_PPC_64K_PAGES is not set | 279 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -365,6 +382,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 365 | # CONFIG_ECONET is not set | 382 | # CONFIG_ECONET is not set |
| 366 | # CONFIG_WAN_ROUTER is not set | 383 | # CONFIG_WAN_ROUTER is not set |
| 367 | # CONFIG_PHONET is not set | 384 | # CONFIG_PHONET is not set |
| 385 | # CONFIG_IEEE802154 is not set | ||
| 368 | # CONFIG_NET_SCHED is not set | 386 | # CONFIG_NET_SCHED is not set |
| 369 | # CONFIG_DCB is not set | 387 | # CONFIG_DCB is not set |
| 370 | 388 | ||
| @@ -382,7 +400,11 @@ CONFIG_WIRELESS=y | |||
| 382 | CONFIG_WIRELESS_OLD_REGULATORY=y | 400 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 383 | # CONFIG_WIRELESS_EXT is not set | 401 | # CONFIG_WIRELESS_EXT is not set |
| 384 | # CONFIG_LIB80211 is not set | 402 | # CONFIG_LIB80211 is not set |
| 385 | # CONFIG_MAC80211 is not set | 403 | |
| 404 | # | ||
| 405 | # CFG80211 needs to be enabled for MAC80211 | ||
| 406 | # | ||
| 407 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 386 | # CONFIG_WIMAX is not set | 408 | # CONFIG_WIMAX is not set |
| 387 | # CONFIG_RFKILL is not set | 409 | # CONFIG_RFKILL is not set |
| 388 | # CONFIG_NET_9P is not set | 410 | # CONFIG_NET_9P is not set |
| @@ -403,6 +425,7 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 403 | # CONFIG_MTD is not set | 425 | # CONFIG_MTD is not set |
| 404 | CONFIG_OF_DEVICE=y | 426 | CONFIG_OF_DEVICE=y |
| 405 | CONFIG_OF_I2C=y | 427 | CONFIG_OF_I2C=y |
| 428 | CONFIG_OF_MDIO=y | ||
| 406 | # CONFIG_PARPORT is not set | 429 | # CONFIG_PARPORT is not set |
| 407 | CONFIG_BLK_DEV=y | 430 | CONFIG_BLK_DEV=y |
| 408 | # CONFIG_BLK_DEV_FD is not set | 431 | # CONFIG_BLK_DEV_FD is not set |
| @@ -437,7 +460,9 @@ CONFIG_MISC_DEVICES=y | |||
| 437 | # | 460 | # |
| 438 | # CONFIG_EEPROM_AT24 is not set | 461 | # CONFIG_EEPROM_AT24 is not set |
| 439 | # CONFIG_EEPROM_LEGACY is not set | 462 | # CONFIG_EEPROM_LEGACY is not set |
| 463 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 440 | # CONFIG_EEPROM_93CX6 is not set | 464 | # CONFIG_EEPROM_93CX6 is not set |
| 465 | # CONFIG_CB710_CORE is not set | ||
| 441 | CONFIG_HAVE_IDE=y | 466 | CONFIG_HAVE_IDE=y |
| 442 | # CONFIG_IDE is not set | 467 | # CONFIG_IDE is not set |
| 443 | 468 | ||
| @@ -457,14 +482,17 @@ CONFIG_HAVE_IDE=y | |||
| 457 | # | 482 | # |
| 458 | 483 | ||
| 459 | # | 484 | # |
| 460 | # Enable only one of the two stacks, unless you know what you are doing | 485 | # You can enable one or both FireWire driver stacks. |
| 486 | # | ||
| 487 | |||
| 488 | # | ||
| 489 | # See the help texts for more information. | ||
| 461 | # | 490 | # |
| 462 | # CONFIG_FIREWIRE is not set | 491 | # CONFIG_FIREWIRE is not set |
| 463 | # CONFIG_IEEE1394 is not set | 492 | # CONFIG_IEEE1394 is not set |
| 464 | # CONFIG_I2O is not set | 493 | # CONFIG_I2O is not set |
| 465 | # CONFIG_MACINTOSH_DRIVERS is not set | 494 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 466 | CONFIG_NETDEVICES=y | 495 | CONFIG_NETDEVICES=y |
| 467 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 468 | # CONFIG_DUMMY is not set | 496 | # CONFIG_DUMMY is not set |
| 469 | # CONFIG_BONDING is not set | 497 | # CONFIG_BONDING is not set |
| 470 | # CONFIG_MACVLAN is not set | 498 | # CONFIG_MACVLAN is not set |
| @@ -527,6 +555,7 @@ CONFIG_E100=y | |||
| 527 | # CONFIG_SMSC9420 is not set | 555 | # CONFIG_SMSC9420 is not set |
| 528 | # CONFIG_SUNDANCE is not set | 556 | # CONFIG_SUNDANCE is not set |
| 529 | # CONFIG_TLAN is not set | 557 | # CONFIG_TLAN is not set |
| 558 | # CONFIG_KS8842 is not set | ||
| 530 | # CONFIG_VIA_RHINE is not set | 559 | # CONFIG_VIA_RHINE is not set |
| 531 | # CONFIG_SC92031 is not set | 560 | # CONFIG_SC92031 is not set |
| 532 | # CONFIG_ATL2 is not set | 561 | # CONFIG_ATL2 is not set |
| @@ -548,8 +577,10 @@ CONFIG_NETDEV_1000=y | |||
| 548 | # CONFIG_VIA_VELOCITY is not set | 577 | # CONFIG_VIA_VELOCITY is not set |
| 549 | # CONFIG_TIGON3 is not set | 578 | # CONFIG_TIGON3 is not set |
| 550 | # CONFIG_BNX2 is not set | 579 | # CONFIG_BNX2 is not set |
| 580 | # CONFIG_CNIC is not set | ||
| 551 | CONFIG_FSL_PQ_MDIO=y | 581 | CONFIG_FSL_PQ_MDIO=y |
| 552 | CONFIG_GIANFAR=y | 582 | CONFIG_GIANFAR=y |
| 583 | # CONFIG_MV643XX_ETH is not set | ||
| 553 | # CONFIG_QLA3XXX is not set | 584 | # CONFIG_QLA3XXX is not set |
| 554 | # CONFIG_ATL1 is not set | 585 | # CONFIG_ATL1 is not set |
| 555 | # CONFIG_ATL1E is not set | 586 | # CONFIG_ATL1E is not set |
| @@ -724,13 +755,17 @@ CONFIG_I2C_MPC=y | |||
| 724 | # CONFIG_SENSORS_PCF8574 is not set | 755 | # CONFIG_SENSORS_PCF8574 is not set |
| 725 | # CONFIG_PCF8575 is not set | 756 | # CONFIG_PCF8575 is not set |
| 726 | # CONFIG_SENSORS_PCA9539 is not set | 757 | # CONFIG_SENSORS_PCA9539 is not set |
| 727 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 728 | # CONFIG_SENSORS_TSL2550 is not set | 758 | # CONFIG_SENSORS_TSL2550 is not set |
| 729 | # CONFIG_I2C_DEBUG_CORE is not set | 759 | # CONFIG_I2C_DEBUG_CORE is not set |
| 730 | # CONFIG_I2C_DEBUG_ALGO is not set | 760 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 731 | # CONFIG_I2C_DEBUG_BUS is not set | 761 | # CONFIG_I2C_DEBUG_BUS is not set |
| 732 | # CONFIG_I2C_DEBUG_CHIP is not set | 762 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 733 | # CONFIG_SPI is not set | 763 | # CONFIG_SPI is not set |
| 764 | |||
| 765 | # | ||
| 766 | # PPS support | ||
| 767 | # | ||
| 768 | # CONFIG_PPS is not set | ||
| 734 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 769 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 735 | # CONFIG_GPIOLIB is not set | 770 | # CONFIG_GPIOLIB is not set |
| 736 | # CONFIG_W1 is not set | 771 | # CONFIG_W1 is not set |
| @@ -785,6 +820,7 @@ CONFIG_HWMON=y | |||
| 785 | # CONFIG_SENSORS_SMSC47B397 is not set | 820 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 786 | # CONFIG_SENSORS_ADS7828 is not set | 821 | # CONFIG_SENSORS_ADS7828 is not set |
| 787 | # CONFIG_SENSORS_THMC50 is not set | 822 | # CONFIG_SENSORS_THMC50 is not set |
| 823 | # CONFIG_SENSORS_TMP401 is not set | ||
| 788 | # CONFIG_SENSORS_VIA686A is not set | 824 | # CONFIG_SENSORS_VIA686A is not set |
| 789 | # CONFIG_SENSORS_VT1211 is not set | 825 | # CONFIG_SENSORS_VT1211 is not set |
| 790 | # CONFIG_SENSORS_VT8231 is not set | 826 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -833,23 +869,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 833 | # CONFIG_MFD_WM8400 is not set | 869 | # CONFIG_MFD_WM8400 is not set |
| 834 | # CONFIG_MFD_WM8350_I2C is not set | 870 | # CONFIG_MFD_WM8350_I2C is not set |
| 835 | # CONFIG_MFD_PCF50633 is not set | 871 | # CONFIG_MFD_PCF50633 is not set |
| 872 | # CONFIG_AB3100_CORE is not set | ||
| 836 | # CONFIG_REGULATOR is not set | 873 | # CONFIG_REGULATOR is not set |
| 837 | 874 | # CONFIG_MEDIA_SUPPORT is not set | |
| 838 | # | ||
| 839 | # Multimedia devices | ||
| 840 | # | ||
| 841 | |||
| 842 | # | ||
| 843 | # Multimedia core support | ||
| 844 | # | ||
| 845 | # CONFIG_VIDEO_DEV is not set | ||
| 846 | # CONFIG_DVB_CORE is not set | ||
| 847 | # CONFIG_VIDEO_MEDIA is not set | ||
| 848 | |||
| 849 | # | ||
| 850 | # Multimedia drivers | ||
| 851 | # | ||
| 852 | CONFIG_DAB=y | ||
| 853 | 875 | ||
| 854 | # | 876 | # |
| 855 | # Graphics support | 877 | # Graphics support |
| @@ -933,6 +955,7 @@ CONFIG_RTC_DRV_DS1374=y | |||
| 933 | # CONFIG_RTC_DRV_S35390A is not set | 955 | # CONFIG_RTC_DRV_S35390A is not set |
| 934 | # CONFIG_RTC_DRV_FM3130 is not set | 956 | # CONFIG_RTC_DRV_FM3130 is not set |
| 935 | # CONFIG_RTC_DRV_RX8581 is not set | 957 | # CONFIG_RTC_DRV_RX8581 is not set |
| 958 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 936 | 959 | ||
| 937 | # | 960 | # |
| 938 | # SPI RTC drivers | 961 | # SPI RTC drivers |
| @@ -960,6 +983,10 @@ CONFIG_RTC_DRV_DS1374=y | |||
| 960 | # CONFIG_DMADEVICES is not set | 983 | # CONFIG_DMADEVICES is not set |
| 961 | # CONFIG_AUXDISPLAY is not set | 984 | # CONFIG_AUXDISPLAY is not set |
| 962 | # CONFIG_UIO is not set | 985 | # CONFIG_UIO is not set |
| 986 | |||
| 987 | # | ||
| 988 | # TI VLYNQ | ||
| 989 | # | ||
| 963 | # CONFIG_STAGING is not set | 990 | # CONFIG_STAGING is not set |
| 964 | 991 | ||
| 965 | # | 992 | # |
| @@ -979,10 +1006,12 @@ CONFIG_FS_MBCACHE=y | |||
| 979 | # CONFIG_REISERFS_FS is not set | 1006 | # CONFIG_REISERFS_FS is not set |
| 980 | # CONFIG_JFS_FS is not set | 1007 | # CONFIG_JFS_FS is not set |
| 981 | # CONFIG_FS_POSIX_ACL is not set | 1008 | # CONFIG_FS_POSIX_ACL is not set |
| 982 | CONFIG_FILE_LOCKING=y | ||
| 983 | # CONFIG_XFS_FS is not set | 1009 | # CONFIG_XFS_FS is not set |
| 1010 | # CONFIG_GFS2_FS is not set | ||
| 984 | # CONFIG_OCFS2_FS is not set | 1011 | # CONFIG_OCFS2_FS is not set |
| 985 | # CONFIG_BTRFS_FS is not set | 1012 | # CONFIG_BTRFS_FS is not set |
| 1013 | CONFIG_FILE_LOCKING=y | ||
| 1014 | CONFIG_FSNOTIFY=y | ||
| 986 | CONFIG_DNOTIFY=y | 1015 | CONFIG_DNOTIFY=y |
| 987 | CONFIG_INOTIFY=y | 1016 | CONFIG_INOTIFY=y |
| 988 | CONFIG_INOTIFY_USER=y | 1017 | CONFIG_INOTIFY_USER=y |
| @@ -1045,6 +1074,7 @@ CONFIG_NFS_FS=y | |||
| 1045 | CONFIG_NFS_V3=y | 1074 | CONFIG_NFS_V3=y |
| 1046 | # CONFIG_NFS_V3_ACL is not set | 1075 | # CONFIG_NFS_V3_ACL is not set |
| 1047 | CONFIG_NFS_V4=y | 1076 | CONFIG_NFS_V4=y |
| 1077 | # CONFIG_NFS_V4_1 is not set | ||
| 1048 | CONFIG_ROOT_NFS=y | 1078 | CONFIG_ROOT_NFS=y |
| 1049 | # CONFIG_NFSD is not set | 1079 | # CONFIG_NFSD is not set |
| 1050 | CONFIG_LOCKD=y | 1080 | CONFIG_LOCKD=y |
| @@ -1100,6 +1130,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1100 | CONFIG_HAS_DMA=y | 1130 | CONFIG_HAS_DMA=y |
| 1101 | CONFIG_HAVE_LMB=y | 1131 | CONFIG_HAVE_LMB=y |
| 1102 | CONFIG_NLATTR=y | 1132 | CONFIG_NLATTR=y |
| 1133 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1103 | 1134 | ||
| 1104 | # | 1135 | # |
| 1105 | # Kernel hacking | 1136 | # Kernel hacking |
| @@ -1125,22 +1156,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1125 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1156 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1126 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1157 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1127 | CONFIG_TRACING_SUPPORT=y | 1158 | CONFIG_TRACING_SUPPORT=y |
| 1128 | 1159 | # CONFIG_FTRACE is not set | |
| 1129 | # | ||
| 1130 | # Tracers | ||
| 1131 | # | ||
| 1132 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1133 | # CONFIG_SCHED_TRACER is not set | ||
| 1134 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1135 | # CONFIG_EVENT_TRACER is not set | ||
| 1136 | # CONFIG_BOOT_TRACER is not set | ||
| 1137 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1138 | # CONFIG_STACK_TRACER is not set | ||
| 1139 | # CONFIG_KMEMTRACE is not set | ||
| 1140 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1141 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1142 | # CONFIG_SAMPLES is not set | 1160 | # CONFIG_SAMPLES is not set |
| 1143 | CONFIG_HAVE_ARCH_KGDB=y | 1161 | CONFIG_HAVE_ARCH_KGDB=y |
| 1162 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1163 | CONFIG_PPC_WERROR=y | ||
| 1144 | CONFIG_PRINT_STACK_DEPTH=64 | 1164 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1145 | # CONFIG_IRQSTACKS is not set | 1165 | # CONFIG_IRQSTACKS is not set |
| 1146 | # CONFIG_BOOTX_TEXT is not set | 1166 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/83xx/mpc836x_mds_defconfig b/arch/powerpc/configs/83xx/mpc836x_mds_defconfig index ce5177393a0d..8c5299d74813 100644 --- a/arch/powerpc/configs/83xx/mpc836x_mds_defconfig +++ b/arch/powerpc/configs/83xx/mpc836x_mds_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:12 2009 | 4 | # Wed Jul 29 23:32:10 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_FSL_EMB_PERFMON is not set | 20 | # CONFIG_FSL_EMB_PERFMON is not set |
| 20 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 45 | CONFIG_PPC=y | 48 | CONFIG_PPC=y |
| @@ -53,12 +56,14 @@ CONFIG_PPC_UDBG_16550=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 57 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 61 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| 58 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 59 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 60 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 61 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 62 | 67 | ||
| 63 | # | 68 | # |
| 64 | # General setup | 69 | # General setup |
| @@ -107,7 +112,6 @@ CONFIG_ANON_INODES=y | |||
| 107 | CONFIG_EMBEDDED=y | 112 | CONFIG_EMBEDDED=y |
| 108 | CONFIG_SYSCTL_SYSCALL=y | 113 | CONFIG_SYSCTL_SYSCALL=y |
| 109 | # CONFIG_KALLSYMS is not set | 114 | # CONFIG_KALLSYMS is not set |
| 110 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 111 | CONFIG_HOTPLUG=y | 115 | CONFIG_HOTPLUG=y |
| 112 | CONFIG_PRINTK=y | 116 | CONFIG_PRINTK=y |
| 113 | CONFIG_BUG=y | 117 | CONFIG_BUG=y |
| @@ -120,9 +124,16 @@ CONFIG_TIMERFD=y | |||
| 120 | CONFIG_EVENTFD=y | 124 | CONFIG_EVENTFD=y |
| 121 | CONFIG_SHMEM=y | 125 | CONFIG_SHMEM=y |
| 122 | CONFIG_AIO=y | 126 | CONFIG_AIO=y |
| 127 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 128 | |||
| 129 | # | ||
| 130 | # Performance Counters | ||
| 131 | # | ||
| 132 | # CONFIG_PERF_COUNTERS is not set | ||
| 123 | CONFIG_VM_EVENT_COUNTERS=y | 133 | CONFIG_VM_EVENT_COUNTERS=y |
| 124 | CONFIG_PCI_QUIRKS=y | 134 | CONFIG_PCI_QUIRKS=y |
| 125 | CONFIG_SLUB_DEBUG=y | 135 | CONFIG_SLUB_DEBUG=y |
| 136 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 126 | CONFIG_COMPAT_BRK=y | 137 | CONFIG_COMPAT_BRK=y |
| 127 | # CONFIG_SLAB is not set | 138 | # CONFIG_SLAB is not set |
| 128 | CONFIG_SLUB=y | 139 | CONFIG_SLUB=y |
| @@ -135,6 +146,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 135 | CONFIG_HAVE_KPROBES=y | 146 | CONFIG_HAVE_KPROBES=y |
| 136 | CONFIG_HAVE_KRETPROBES=y | 147 | CONFIG_HAVE_KRETPROBES=y |
| 137 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 148 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 149 | |||
| 150 | # | ||
| 151 | # GCOV-based kernel profiling | ||
| 152 | # | ||
| 138 | # CONFIG_SLOW_WORK is not set | 153 | # CONFIG_SLOW_WORK is not set |
| 139 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 140 | CONFIG_SLABINFO=y | 155 | CONFIG_SLABINFO=y |
| @@ -147,7 +162,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 147 | # CONFIG_MODVERSIONS is not set | 162 | # CONFIG_MODVERSIONS is not set |
| 148 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 163 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 149 | CONFIG_BLOCK=y | 164 | CONFIG_BLOCK=y |
| 150 | # CONFIG_LBD is not set | 165 | CONFIG_LBDAF=y |
| 151 | # CONFIG_BLK_DEV_BSG is not set | 166 | # CONFIG_BLK_DEV_BSG is not set |
| 152 | # CONFIG_BLK_DEV_INTEGRITY is not set | 167 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 153 | 168 | ||
| @@ -189,6 +204,7 @@ CONFIG_MPC836x_MDS=y | |||
| 189 | # CONFIG_MPC837x_RDB is not set | 204 | # CONFIG_MPC837x_RDB is not set |
| 190 | # CONFIG_SBC834x is not set | 205 | # CONFIG_SBC834x is not set |
| 191 | # CONFIG_ASP834x is not set | 206 | # CONFIG_ASP834x is not set |
| 207 | # CONFIG_KMETER1 is not set | ||
| 192 | # CONFIG_PPC_86xx is not set | 208 | # CONFIG_PPC_86xx is not set |
| 193 | # CONFIG_EMBEDDED6xx is not set | 209 | # CONFIG_EMBEDDED6xx is not set |
| 194 | # CONFIG_AMIGAONE is not set | 210 | # CONFIG_AMIGAONE is not set |
| @@ -233,6 +249,7 @@ CONFIG_BINFMT_ELF=y | |||
| 233 | # CONFIG_HAVE_AOUT is not set | 249 | # CONFIG_HAVE_AOUT is not set |
| 234 | # CONFIG_BINFMT_MISC is not set | 250 | # CONFIG_BINFMT_MISC is not set |
| 235 | # CONFIG_IOMMU_HELPER is not set | 251 | # CONFIG_IOMMU_HELPER is not set |
| 252 | # CONFIG_SWIOTLB is not set | ||
| 236 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 253 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 237 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 254 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 238 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 255 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -253,9 +270,9 @@ CONFIG_MIGRATION=y | |||
| 253 | CONFIG_ZONE_DMA_FLAG=1 | 270 | CONFIG_ZONE_DMA_FLAG=1 |
| 254 | CONFIG_BOUNCE=y | 271 | CONFIG_BOUNCE=y |
| 255 | CONFIG_VIRT_TO_BUS=y | 272 | CONFIG_VIRT_TO_BUS=y |
| 256 | CONFIG_UNEVICTABLE_LRU=y | ||
| 257 | CONFIG_HAVE_MLOCK=y | 273 | CONFIG_HAVE_MLOCK=y |
| 258 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 274 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 275 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 259 | CONFIG_PPC_4K_PAGES=y | 276 | CONFIG_PPC_4K_PAGES=y |
| 260 | # CONFIG_PPC_16K_PAGES is not set | 277 | # CONFIG_PPC_16K_PAGES is not set |
| 261 | # CONFIG_PPC_64K_PAGES is not set | 278 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -364,6 +381,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 364 | # CONFIG_ECONET is not set | 381 | # CONFIG_ECONET is not set |
| 365 | # CONFIG_WAN_ROUTER is not set | 382 | # CONFIG_WAN_ROUTER is not set |
| 366 | # CONFIG_PHONET is not set | 383 | # CONFIG_PHONET is not set |
| 384 | # CONFIG_IEEE802154 is not set | ||
| 367 | # CONFIG_NET_SCHED is not set | 385 | # CONFIG_NET_SCHED is not set |
| 368 | # CONFIG_DCB is not set | 386 | # CONFIG_DCB is not set |
| 369 | 387 | ||
| @@ -381,7 +399,11 @@ CONFIG_WIRELESS=y | |||
| 381 | CONFIG_WIRELESS_OLD_REGULATORY=y | 399 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 382 | # CONFIG_WIRELESS_EXT is not set | 400 | # CONFIG_WIRELESS_EXT is not set |
| 383 | # CONFIG_LIB80211 is not set | 401 | # CONFIG_LIB80211 is not set |
| 384 | # CONFIG_MAC80211 is not set | 402 | |
| 403 | # | ||
| 404 | # CFG80211 needs to be enabled for MAC80211 | ||
| 405 | # | ||
| 406 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 385 | # CONFIG_WIMAX is not set | 407 | # CONFIG_WIMAX is not set |
| 386 | # CONFIG_RFKILL is not set | 408 | # CONFIG_RFKILL is not set |
| 387 | # CONFIG_NET_9P is not set | 409 | # CONFIG_NET_9P is not set |
| @@ -485,6 +507,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 485 | # CONFIG_MTD_UBI is not set | 507 | # CONFIG_MTD_UBI is not set |
| 486 | CONFIG_OF_DEVICE=y | 508 | CONFIG_OF_DEVICE=y |
| 487 | CONFIG_OF_I2C=y | 509 | CONFIG_OF_I2C=y |
| 510 | CONFIG_OF_MDIO=y | ||
| 488 | # CONFIG_PARPORT is not set | 511 | # CONFIG_PARPORT is not set |
| 489 | CONFIG_BLK_DEV=y | 512 | CONFIG_BLK_DEV=y |
| 490 | # CONFIG_BLK_DEV_FD is not set | 513 | # CONFIG_BLK_DEV_FD is not set |
| @@ -519,7 +542,9 @@ CONFIG_MISC_DEVICES=y | |||
| 519 | # | 542 | # |
| 520 | # CONFIG_EEPROM_AT24 is not set | 543 | # CONFIG_EEPROM_AT24 is not set |
| 521 | # CONFIG_EEPROM_LEGACY is not set | 544 | # CONFIG_EEPROM_LEGACY is not set |
| 545 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 522 | # CONFIG_EEPROM_93CX6 is not set | 546 | # CONFIG_EEPROM_93CX6 is not set |
| 547 | # CONFIG_CB710_CORE is not set | ||
| 523 | CONFIG_HAVE_IDE=y | 548 | CONFIG_HAVE_IDE=y |
| 524 | # CONFIG_IDE is not set | 549 | # CONFIG_IDE is not set |
| 525 | 550 | ||
| @@ -542,10 +567,6 @@ CONFIG_SCSI_PROC_FS=y | |||
| 542 | # CONFIG_BLK_DEV_SR is not set | 567 | # CONFIG_BLK_DEV_SR is not set |
| 543 | # CONFIG_CHR_DEV_SG is not set | 568 | # CONFIG_CHR_DEV_SG is not set |
| 544 | # CONFIG_CHR_DEV_SCH is not set | 569 | # CONFIG_CHR_DEV_SCH is not set |
| 545 | |||
| 546 | # | ||
| 547 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 548 | # | ||
| 549 | # CONFIG_SCSI_MULTI_LUN is not set | 570 | # CONFIG_SCSI_MULTI_LUN is not set |
| 550 | # CONFIG_SCSI_CONSTANTS is not set | 571 | # CONFIG_SCSI_CONSTANTS is not set |
| 551 | # CONFIG_SCSI_LOGGING is not set | 572 | # CONFIG_SCSI_LOGGING is not set |
| @@ -563,6 +584,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 563 | CONFIG_SCSI_LOWLEVEL=y | 584 | CONFIG_SCSI_LOWLEVEL=y |
| 564 | # CONFIG_ISCSI_TCP is not set | 585 | # CONFIG_ISCSI_TCP is not set |
| 565 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 586 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 587 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 566 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 588 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 567 | # CONFIG_SCSI_3W_9XXX is not set | 589 | # CONFIG_SCSI_3W_9XXX is not set |
| 568 | # CONFIG_SCSI_ACARD is not set | 590 | # CONFIG_SCSI_ACARD is not set |
| @@ -571,6 +593,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 571 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 593 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 572 | # CONFIG_SCSI_AIC79XX is not set | 594 | # CONFIG_SCSI_AIC79XX is not set |
| 573 | # CONFIG_SCSI_AIC94XX is not set | 595 | # CONFIG_SCSI_AIC94XX is not set |
| 596 | # CONFIG_SCSI_MVSAS is not set | ||
| 574 | # CONFIG_SCSI_DPT_I2O is not set | 597 | # CONFIG_SCSI_DPT_I2O is not set |
| 575 | # CONFIG_SCSI_ADVANSYS is not set | 598 | # CONFIG_SCSI_ADVANSYS is not set |
| 576 | # CONFIG_SCSI_ARCMSR is not set | 599 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -590,7 +613,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 590 | # CONFIG_SCSI_IPS is not set | 613 | # CONFIG_SCSI_IPS is not set |
| 591 | # CONFIG_SCSI_INITIO is not set | 614 | # CONFIG_SCSI_INITIO is not set |
| 592 | # CONFIG_SCSI_INIA100 is not set | 615 | # CONFIG_SCSI_INIA100 is not set |
| 593 | # CONFIG_SCSI_MVSAS is not set | ||
| 594 | # CONFIG_SCSI_STEX is not set | 616 | # CONFIG_SCSI_STEX is not set |
| 595 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 617 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 596 | # CONFIG_SCSI_QLOGIC_1280 is not set | 618 | # CONFIG_SCSI_QLOGIC_1280 is not set |
| @@ -613,14 +635,17 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 613 | # | 635 | # |
| 614 | 636 | ||
| 615 | # | 637 | # |
| 616 | # Enable only one of the two stacks, unless you know what you are doing | 638 | # You can enable one or both FireWire driver stacks. |
| 639 | # | ||
| 640 | |||
| 641 | # | ||
| 642 | # See the help texts for more information. | ||
| 617 | # | 643 | # |
| 618 | # CONFIG_FIREWIRE is not set | 644 | # CONFIG_FIREWIRE is not set |
| 619 | # CONFIG_IEEE1394 is not set | 645 | # CONFIG_IEEE1394 is not set |
| 620 | # CONFIG_I2O is not set | 646 | # CONFIG_I2O is not set |
| 621 | # CONFIG_MACINTOSH_DRIVERS is not set | 647 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 622 | CONFIG_NETDEVICES=y | 648 | CONFIG_NETDEVICES=y |
| 623 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 624 | # CONFIG_DUMMY is not set | 649 | # CONFIG_DUMMY is not set |
| 625 | # CONFIG_BONDING is not set | 650 | # CONFIG_BONDING is not set |
| 626 | # CONFIG_MACVLAN is not set | 651 | # CONFIG_MACVLAN is not set |
| @@ -667,6 +692,7 @@ CONFIG_MII=y | |||
| 667 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 692 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 668 | # CONFIG_NET_PCI is not set | 693 | # CONFIG_NET_PCI is not set |
| 669 | # CONFIG_B44 is not set | 694 | # CONFIG_B44 is not set |
| 695 | # CONFIG_KS8842 is not set | ||
| 670 | # CONFIG_ATL2 is not set | 696 | # CONFIG_ATL2 is not set |
| 671 | CONFIG_NETDEV_1000=y | 697 | CONFIG_NETDEV_1000=y |
| 672 | # CONFIG_ACENIC is not set | 698 | # CONFIG_ACENIC is not set |
| @@ -686,11 +712,13 @@ CONFIG_NETDEV_1000=y | |||
| 686 | # CONFIG_VIA_VELOCITY is not set | 712 | # CONFIG_VIA_VELOCITY is not set |
| 687 | # CONFIG_TIGON3 is not set | 713 | # CONFIG_TIGON3 is not set |
| 688 | # CONFIG_BNX2 is not set | 714 | # CONFIG_BNX2 is not set |
| 715 | # CONFIG_CNIC is not set | ||
| 689 | CONFIG_FSL_PQ_MDIO=y | 716 | CONFIG_FSL_PQ_MDIO=y |
| 690 | # CONFIG_GIANFAR is not set | 717 | # CONFIG_GIANFAR is not set |
| 691 | CONFIG_UCC_GETH=y | 718 | CONFIG_UCC_GETH=y |
| 692 | # CONFIG_UGETH_MAGIC_PACKET is not set | 719 | # CONFIG_UGETH_MAGIC_PACKET is not set |
| 693 | # CONFIG_UGETH_TX_ON_DEMAND is not set | 720 | # CONFIG_UGETH_TX_ON_DEMAND is not set |
| 721 | # CONFIG_MV643XX_ETH is not set | ||
| 694 | # CONFIG_QLA3XXX is not set | 722 | # CONFIG_QLA3XXX is not set |
| 695 | # CONFIG_ATL1 is not set | 723 | # CONFIG_ATL1 is not set |
| 696 | # CONFIG_ATL1E is not set | 724 | # CONFIG_ATL1E is not set |
| @@ -868,13 +896,17 @@ CONFIG_I2C_MPC=y | |||
| 868 | # CONFIG_SENSORS_PCF8574 is not set | 896 | # CONFIG_SENSORS_PCF8574 is not set |
| 869 | # CONFIG_PCF8575 is not set | 897 | # CONFIG_PCF8575 is not set |
| 870 | # CONFIG_SENSORS_PCA9539 is not set | 898 | # CONFIG_SENSORS_PCA9539 is not set |
| 871 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 872 | # CONFIG_SENSORS_TSL2550 is not set | 899 | # CONFIG_SENSORS_TSL2550 is not set |
| 873 | # CONFIG_I2C_DEBUG_CORE is not set | 900 | # CONFIG_I2C_DEBUG_CORE is not set |
| 874 | # CONFIG_I2C_DEBUG_ALGO is not set | 901 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 875 | # CONFIG_I2C_DEBUG_BUS is not set | 902 | # CONFIG_I2C_DEBUG_BUS is not set |
| 876 | # CONFIG_I2C_DEBUG_CHIP is not set | 903 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 877 | # CONFIG_SPI is not set | 904 | # CONFIG_SPI is not set |
| 905 | |||
| 906 | # | ||
| 907 | # PPS support | ||
| 908 | # | ||
| 909 | # CONFIG_PPS is not set | ||
| 878 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 910 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 879 | # CONFIG_GPIOLIB is not set | 911 | # CONFIG_GPIOLIB is not set |
| 880 | # CONFIG_W1 is not set | 912 | # CONFIG_W1 is not set |
| @@ -929,6 +961,7 @@ CONFIG_HWMON=y | |||
| 929 | # CONFIG_SENSORS_SMSC47B397 is not set | 961 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 930 | # CONFIG_SENSORS_ADS7828 is not set | 962 | # CONFIG_SENSORS_ADS7828 is not set |
| 931 | # CONFIG_SENSORS_THMC50 is not set | 963 | # CONFIG_SENSORS_THMC50 is not set |
| 964 | # CONFIG_SENSORS_TMP401 is not set | ||
| 932 | # CONFIG_SENSORS_VIA686A is not set | 965 | # CONFIG_SENSORS_VIA686A is not set |
| 933 | # CONFIG_SENSORS_VT1211 is not set | 966 | # CONFIG_SENSORS_VT1211 is not set |
| 934 | # CONFIG_SENSORS_VT8231 is not set | 967 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -977,23 +1010,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 977 | # CONFIG_MFD_WM8400 is not set | 1010 | # CONFIG_MFD_WM8400 is not set |
| 978 | # CONFIG_MFD_WM8350_I2C is not set | 1011 | # CONFIG_MFD_WM8350_I2C is not set |
| 979 | # CONFIG_MFD_PCF50633 is not set | 1012 | # CONFIG_MFD_PCF50633 is not set |
| 1013 | # CONFIG_AB3100_CORE is not set | ||
| 980 | # CONFIG_REGULATOR is not set | 1014 | # CONFIG_REGULATOR is not set |
| 981 | 1015 | # CONFIG_MEDIA_SUPPORT is not set | |
| 982 | # | ||
| 983 | # Multimedia devices | ||
| 984 | # | ||
| 985 | |||
| 986 | # | ||
| 987 | # Multimedia core support | ||
| 988 | # | ||
| 989 | # CONFIG_VIDEO_DEV is not set | ||
| 990 | # CONFIG_DVB_CORE is not set | ||
| 991 | # CONFIG_VIDEO_MEDIA is not set | ||
| 992 | |||
| 993 | # | ||
| 994 | # Multimedia drivers | ||
| 995 | # | ||
| 996 | CONFIG_DAB=y | ||
| 997 | 1016 | ||
| 998 | # | 1017 | # |
| 999 | # Graphics support | 1018 | # Graphics support |
| @@ -1077,6 +1096,7 @@ CONFIG_RTC_DRV_DS1374=y | |||
| 1077 | # CONFIG_RTC_DRV_S35390A is not set | 1096 | # CONFIG_RTC_DRV_S35390A is not set |
| 1078 | # CONFIG_RTC_DRV_FM3130 is not set | 1097 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1079 | # CONFIG_RTC_DRV_RX8581 is not set | 1098 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1099 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1080 | 1100 | ||
| 1081 | # | 1101 | # |
| 1082 | # SPI RTC drivers | 1102 | # SPI RTC drivers |
| @@ -1104,6 +1124,10 @@ CONFIG_RTC_DRV_DS1374=y | |||
| 1104 | # CONFIG_DMADEVICES is not set | 1124 | # CONFIG_DMADEVICES is not set |
| 1105 | # CONFIG_AUXDISPLAY is not set | 1125 | # CONFIG_AUXDISPLAY is not set |
| 1106 | # CONFIG_UIO is not set | 1126 | # CONFIG_UIO is not set |
| 1127 | |||
| 1128 | # | ||
| 1129 | # TI VLYNQ | ||
| 1130 | # | ||
| 1107 | # CONFIG_STAGING is not set | 1131 | # CONFIG_STAGING is not set |
| 1108 | 1132 | ||
| 1109 | # | 1133 | # |
| @@ -1123,10 +1147,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1123 | # CONFIG_REISERFS_FS is not set | 1147 | # CONFIG_REISERFS_FS is not set |
| 1124 | # CONFIG_JFS_FS is not set | 1148 | # CONFIG_JFS_FS is not set |
| 1125 | # CONFIG_FS_POSIX_ACL is not set | 1149 | # CONFIG_FS_POSIX_ACL is not set |
| 1126 | CONFIG_FILE_LOCKING=y | ||
| 1127 | # CONFIG_XFS_FS is not set | 1150 | # CONFIG_XFS_FS is not set |
| 1151 | # CONFIG_GFS2_FS is not set | ||
| 1128 | # CONFIG_OCFS2_FS is not set | 1152 | # CONFIG_OCFS2_FS is not set |
| 1129 | # CONFIG_BTRFS_FS is not set | 1153 | # CONFIG_BTRFS_FS is not set |
| 1154 | CONFIG_FILE_LOCKING=y | ||
| 1155 | CONFIG_FSNOTIFY=y | ||
| 1130 | CONFIG_DNOTIFY=y | 1156 | CONFIG_DNOTIFY=y |
| 1131 | CONFIG_INOTIFY=y | 1157 | CONFIG_INOTIFY=y |
| 1132 | CONFIG_INOTIFY_USER=y | 1158 | CONFIG_INOTIFY_USER=y |
| @@ -1190,6 +1216,7 @@ CONFIG_NFS_FS=y | |||
| 1190 | CONFIG_NFS_V3=y | 1216 | CONFIG_NFS_V3=y |
| 1191 | # CONFIG_NFS_V3_ACL is not set | 1217 | # CONFIG_NFS_V3_ACL is not set |
| 1192 | CONFIG_NFS_V4=y | 1218 | CONFIG_NFS_V4=y |
| 1219 | # CONFIG_NFS_V4_1 is not set | ||
| 1193 | CONFIG_ROOT_NFS=y | 1220 | CONFIG_ROOT_NFS=y |
| 1194 | # CONFIG_NFSD is not set | 1221 | # CONFIG_NFSD is not set |
| 1195 | CONFIG_LOCKD=y | 1222 | CONFIG_LOCKD=y |
| @@ -1247,6 +1274,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1247 | CONFIG_HAS_DMA=y | 1274 | CONFIG_HAS_DMA=y |
| 1248 | CONFIG_HAVE_LMB=y | 1275 | CONFIG_HAVE_LMB=y |
| 1249 | CONFIG_NLATTR=y | 1276 | CONFIG_NLATTR=y |
| 1277 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1250 | 1278 | ||
| 1251 | # | 1279 | # |
| 1252 | # Kernel hacking | 1280 | # Kernel hacking |
| @@ -1272,22 +1300,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1272 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1300 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1273 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1301 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1274 | CONFIG_TRACING_SUPPORT=y | 1302 | CONFIG_TRACING_SUPPORT=y |
| 1275 | 1303 | # CONFIG_FTRACE is not set | |
| 1276 | # | ||
| 1277 | # Tracers | ||
| 1278 | # | ||
| 1279 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1280 | # CONFIG_SCHED_TRACER is not set | ||
| 1281 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1282 | # CONFIG_EVENT_TRACER is not set | ||
| 1283 | # CONFIG_BOOT_TRACER is not set | ||
| 1284 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1285 | # CONFIG_STACK_TRACER is not set | ||
| 1286 | # CONFIG_KMEMTRACE is not set | ||
| 1287 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1288 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1289 | # CONFIG_SAMPLES is not set | 1304 | # CONFIG_SAMPLES is not set |
| 1290 | CONFIG_HAVE_ARCH_KGDB=y | 1305 | CONFIG_HAVE_ARCH_KGDB=y |
| 1306 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1307 | CONFIG_PPC_WERROR=y | ||
| 1291 | CONFIG_PRINT_STACK_DEPTH=64 | 1308 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1292 | # CONFIG_IRQSTACKS is not set | 1309 | # CONFIG_IRQSTACKS is not set |
| 1293 | # CONFIG_BOOTX_TEXT is not set | 1310 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/83xx/mpc836x_rdk_defconfig b/arch/powerpc/configs/83xx/mpc836x_rdk_defconfig index 7f1d1383a249..ff31667a890b 100644 --- a/arch/powerpc/configs/83xx/mpc836x_rdk_defconfig +++ b/arch/powerpc/configs/83xx/mpc836x_rdk_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:13 2009 | 4 | # Wed Jul 29 23:32:12 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_FSL_EMB_PERFMON is not set | 20 | # CONFIG_FSL_EMB_PERFMON is not set |
| 20 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | CONFIG_GENERIC_GPIO=y | 47 | CONFIG_GENERIC_GPIO=y |
| 45 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -54,12 +57,14 @@ CONFIG_PPC_UDBG_16550=y | |||
| 54 | # CONFIG_GENERIC_TBSYNC is not set | 57 | # CONFIG_GENERIC_TBSYNC is not set |
| 55 | CONFIG_AUDIT_ARCH=y | 58 | CONFIG_AUDIT_ARCH=y |
| 56 | CONFIG_GENERIC_BUG=y | 59 | CONFIG_GENERIC_BUG=y |
| 60 | CONFIG_DTC=y | ||
| 57 | CONFIG_DEFAULT_UIMAGE=y | 61 | CONFIG_DEFAULT_UIMAGE=y |
| 58 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 62 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| 59 | # CONFIG_PPC_DCR_NATIVE is not set | 63 | # CONFIG_PPC_DCR_NATIVE is not set |
| 60 | # CONFIG_PPC_DCR_MMIO is not set | 64 | # CONFIG_PPC_DCR_MMIO is not set |
| 61 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 65 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 62 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 66 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 67 | CONFIG_CONSTRUCTORS=y | ||
| 63 | 68 | ||
| 64 | # | 69 | # |
| 65 | # General setup | 70 | # General setup |
| @@ -108,7 +113,6 @@ CONFIG_ANON_INODES=y | |||
| 108 | CONFIG_EMBEDDED=y | 113 | CONFIG_EMBEDDED=y |
| 109 | CONFIG_SYSCTL_SYSCALL=y | 114 | CONFIG_SYSCTL_SYSCALL=y |
| 110 | # CONFIG_KALLSYMS is not set | 115 | # CONFIG_KALLSYMS is not set |
| 111 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 112 | CONFIG_HOTPLUG=y | 116 | CONFIG_HOTPLUG=y |
| 113 | CONFIG_PRINTK=y | 117 | CONFIG_PRINTK=y |
| 114 | CONFIG_BUG=y | 118 | CONFIG_BUG=y |
| @@ -121,9 +125,16 @@ CONFIG_TIMERFD=y | |||
| 121 | CONFIG_EVENTFD=y | 125 | CONFIG_EVENTFD=y |
| 122 | CONFIG_SHMEM=y | 126 | CONFIG_SHMEM=y |
| 123 | CONFIG_AIO=y | 127 | CONFIG_AIO=y |
| 128 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 129 | |||
| 130 | # | ||
| 131 | # Performance Counters | ||
| 132 | # | ||
| 133 | # CONFIG_PERF_COUNTERS is not set | ||
| 124 | CONFIG_VM_EVENT_COUNTERS=y | 134 | CONFIG_VM_EVENT_COUNTERS=y |
| 125 | CONFIG_PCI_QUIRKS=y | 135 | CONFIG_PCI_QUIRKS=y |
| 126 | CONFIG_SLUB_DEBUG=y | 136 | CONFIG_SLUB_DEBUG=y |
| 137 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 127 | CONFIG_COMPAT_BRK=y | 138 | CONFIG_COMPAT_BRK=y |
| 128 | # CONFIG_SLAB is not set | 139 | # CONFIG_SLAB is not set |
| 129 | CONFIG_SLUB=y | 140 | CONFIG_SLUB=y |
| @@ -136,6 +147,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 136 | CONFIG_HAVE_KPROBES=y | 147 | CONFIG_HAVE_KPROBES=y |
| 137 | CONFIG_HAVE_KRETPROBES=y | 148 | CONFIG_HAVE_KRETPROBES=y |
| 138 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 149 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 150 | |||
| 151 | # | ||
| 152 | # GCOV-based kernel profiling | ||
| 153 | # | ||
| 139 | # CONFIG_SLOW_WORK is not set | 154 | # CONFIG_SLOW_WORK is not set |
| 140 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 155 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 141 | CONFIG_SLABINFO=y | 156 | CONFIG_SLABINFO=y |
| @@ -148,7 +163,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 148 | # CONFIG_MODVERSIONS is not set | 163 | # CONFIG_MODVERSIONS is not set |
| 149 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 164 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 150 | CONFIG_BLOCK=y | 165 | CONFIG_BLOCK=y |
| 151 | # CONFIG_LBD is not set | 166 | CONFIG_LBDAF=y |
| 152 | # CONFIG_BLK_DEV_BSG is not set | 167 | # CONFIG_BLK_DEV_BSG is not set |
| 153 | # CONFIG_BLK_DEV_INTEGRITY is not set | 168 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 154 | 169 | ||
| @@ -190,6 +205,7 @@ CONFIG_MPC836x_RDK=y | |||
| 190 | # CONFIG_MPC837x_RDB is not set | 205 | # CONFIG_MPC837x_RDB is not set |
| 191 | # CONFIG_SBC834x is not set | 206 | # CONFIG_SBC834x is not set |
| 192 | # CONFIG_ASP834x is not set | 207 | # CONFIG_ASP834x is not set |
| 208 | # CONFIG_KMETER1 is not set | ||
| 193 | # CONFIG_PPC_86xx is not set | 209 | # CONFIG_PPC_86xx is not set |
| 194 | # CONFIG_EMBEDDED6xx is not set | 210 | # CONFIG_EMBEDDED6xx is not set |
| 195 | # CONFIG_AMIGAONE is not set | 211 | # CONFIG_AMIGAONE is not set |
| @@ -233,6 +249,7 @@ CONFIG_BINFMT_ELF=y | |||
| 233 | # CONFIG_HAVE_AOUT is not set | 249 | # CONFIG_HAVE_AOUT is not set |
| 234 | # CONFIG_BINFMT_MISC is not set | 250 | # CONFIG_BINFMT_MISC is not set |
| 235 | # CONFIG_IOMMU_HELPER is not set | 251 | # CONFIG_IOMMU_HELPER is not set |
| 252 | # CONFIG_SWIOTLB is not set | ||
| 236 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 253 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 237 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 254 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 238 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 255 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -253,9 +270,9 @@ CONFIG_MIGRATION=y | |||
| 253 | CONFIG_ZONE_DMA_FLAG=1 | 270 | CONFIG_ZONE_DMA_FLAG=1 |
| 254 | CONFIG_BOUNCE=y | 271 | CONFIG_BOUNCE=y |
| 255 | CONFIG_VIRT_TO_BUS=y | 272 | CONFIG_VIRT_TO_BUS=y |
| 256 | CONFIG_UNEVICTABLE_LRU=y | ||
| 257 | CONFIG_HAVE_MLOCK=y | 273 | CONFIG_HAVE_MLOCK=y |
| 258 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 274 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 275 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 259 | CONFIG_PPC_4K_PAGES=y | 276 | CONFIG_PPC_4K_PAGES=y |
| 260 | # CONFIG_PPC_16K_PAGES is not set | 277 | # CONFIG_PPC_16K_PAGES is not set |
| 261 | # CONFIG_PPC_64K_PAGES is not set | 278 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -366,6 +383,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 366 | # CONFIG_ECONET is not set | 383 | # CONFIG_ECONET is not set |
| 367 | # CONFIG_WAN_ROUTER is not set | 384 | # CONFIG_WAN_ROUTER is not set |
| 368 | # CONFIG_PHONET is not set | 385 | # CONFIG_PHONET is not set |
| 386 | # CONFIG_IEEE802154 is not set | ||
| 369 | # CONFIG_NET_SCHED is not set | 387 | # CONFIG_NET_SCHED is not set |
| 370 | # CONFIG_DCB is not set | 388 | # CONFIG_DCB is not set |
| 371 | 389 | ||
| @@ -383,7 +401,11 @@ CONFIG_WIRELESS=y | |||
| 383 | CONFIG_WIRELESS_OLD_REGULATORY=y | 401 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 384 | # CONFIG_WIRELESS_EXT is not set | 402 | # CONFIG_WIRELESS_EXT is not set |
| 385 | # CONFIG_LIB80211 is not set | 403 | # CONFIG_LIB80211 is not set |
| 386 | # CONFIG_MAC80211 is not set | 404 | |
| 405 | # | ||
| 406 | # CFG80211 needs to be enabled for MAC80211 | ||
| 407 | # | ||
| 408 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 387 | # CONFIG_WIMAX is not set | 409 | # CONFIG_WIMAX is not set |
| 388 | # CONFIG_RFKILL is not set | 410 | # CONFIG_RFKILL is not set |
| 389 | # CONFIG_NET_9P is not set | 411 | # CONFIG_NET_9P is not set |
| @@ -498,6 +520,7 @@ CONFIG_OF_DEVICE=y | |||
| 498 | CONFIG_OF_GPIO=y | 520 | CONFIG_OF_GPIO=y |
| 499 | CONFIG_OF_I2C=y | 521 | CONFIG_OF_I2C=y |
| 500 | CONFIG_OF_SPI=y | 522 | CONFIG_OF_SPI=y |
| 523 | CONFIG_OF_MDIO=y | ||
| 501 | # CONFIG_PARPORT is not set | 524 | # CONFIG_PARPORT is not set |
| 502 | CONFIG_BLK_DEV=y | 525 | CONFIG_BLK_DEV=y |
| 503 | # CONFIG_BLK_DEV_FD is not set | 526 | # CONFIG_BLK_DEV_FD is not set |
| @@ -533,7 +556,9 @@ CONFIG_MISC_DEVICES=y | |||
| 533 | # CONFIG_EEPROM_AT24 is not set | 556 | # CONFIG_EEPROM_AT24 is not set |
| 534 | # CONFIG_EEPROM_AT25 is not set | 557 | # CONFIG_EEPROM_AT25 is not set |
| 535 | # CONFIG_EEPROM_LEGACY is not set | 558 | # CONFIG_EEPROM_LEGACY is not set |
| 559 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 536 | # CONFIG_EEPROM_93CX6 is not set | 560 | # CONFIG_EEPROM_93CX6 is not set |
| 561 | # CONFIG_CB710_CORE is not set | ||
| 537 | CONFIG_HAVE_IDE=y | 562 | CONFIG_HAVE_IDE=y |
| 538 | # CONFIG_IDE is not set | 563 | # CONFIG_IDE is not set |
| 539 | 564 | ||
| @@ -553,14 +578,17 @@ CONFIG_HAVE_IDE=y | |||
| 553 | # | 578 | # |
| 554 | 579 | ||
| 555 | # | 580 | # |
| 556 | # Enable only one of the two stacks, unless you know what you are doing | 581 | # You can enable one or both FireWire driver stacks. |
| 582 | # | ||
| 583 | |||
| 584 | # | ||
| 585 | # See the help texts for more information. | ||
| 557 | # | 586 | # |
| 558 | # CONFIG_FIREWIRE is not set | 587 | # CONFIG_FIREWIRE is not set |
| 559 | # CONFIG_IEEE1394 is not set | 588 | # CONFIG_IEEE1394 is not set |
| 560 | # CONFIG_I2O is not set | 589 | # CONFIG_I2O is not set |
| 561 | # CONFIG_MACINTOSH_DRIVERS is not set | 590 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 562 | CONFIG_NETDEVICES=y | 591 | CONFIG_NETDEVICES=y |
| 563 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 564 | # CONFIG_DUMMY is not set | 592 | # CONFIG_DUMMY is not set |
| 565 | # CONFIG_BONDING is not set | 593 | # CONFIG_BONDING is not set |
| 566 | # CONFIG_MACVLAN is not set | 594 | # CONFIG_MACVLAN is not set |
| @@ -607,11 +635,13 @@ CONFIG_NETDEV_1000=y | |||
| 607 | # CONFIG_VIA_VELOCITY is not set | 635 | # CONFIG_VIA_VELOCITY is not set |
| 608 | # CONFIG_TIGON3 is not set | 636 | # CONFIG_TIGON3 is not set |
| 609 | # CONFIG_BNX2 is not set | 637 | # CONFIG_BNX2 is not set |
| 638 | # CONFIG_CNIC is not set | ||
| 610 | CONFIG_FSL_PQ_MDIO=y | 639 | CONFIG_FSL_PQ_MDIO=y |
| 611 | # CONFIG_GIANFAR is not set | 640 | # CONFIG_GIANFAR is not set |
| 612 | CONFIG_UCC_GETH=y | 641 | CONFIG_UCC_GETH=y |
| 613 | # CONFIG_UGETH_MAGIC_PACKET is not set | 642 | # CONFIG_UGETH_MAGIC_PACKET is not set |
| 614 | # CONFIG_UGETH_TX_ON_DEMAND is not set | 643 | # CONFIG_UGETH_TX_ON_DEMAND is not set |
| 644 | # CONFIG_MV643XX_ETH is not set | ||
| 615 | # CONFIG_QLA3XXX is not set | 645 | # CONFIG_QLA3XXX is not set |
| 616 | # CONFIG_ATL1 is not set | 646 | # CONFIG_ATL1 is not set |
| 617 | # CONFIG_ATL1E is not set | 647 | # CONFIG_ATL1E is not set |
| @@ -777,7 +807,6 @@ CONFIG_I2C_MPC=y | |||
| 777 | # CONFIG_SENSORS_PCF8574 is not set | 807 | # CONFIG_SENSORS_PCF8574 is not set |
| 778 | # CONFIG_PCF8575 is not set | 808 | # CONFIG_PCF8575 is not set |
| 779 | # CONFIG_SENSORS_PCA9539 is not set | 809 | # CONFIG_SENSORS_PCA9539 is not set |
| 780 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 781 | # CONFIG_SENSORS_TSL2550 is not set | 810 | # CONFIG_SENSORS_TSL2550 is not set |
| 782 | # CONFIG_I2C_DEBUG_CORE is not set | 811 | # CONFIG_I2C_DEBUG_CORE is not set |
| 783 | # CONFIG_I2C_DEBUG_ALGO is not set | 812 | # CONFIG_I2C_DEBUG_ALGO is not set |
| @@ -791,13 +820,18 @@ CONFIG_SPI_MASTER=y | |||
| 791 | # | 820 | # |
| 792 | CONFIG_SPI_BITBANG=y | 821 | CONFIG_SPI_BITBANG=y |
| 793 | # CONFIG_SPI_GPIO is not set | 822 | # CONFIG_SPI_GPIO is not set |
| 794 | CONFIG_SPI_MPC83xx=y | 823 | # CONFIG_SPI_MPC8xxx is not set |
| 795 | 824 | ||
| 796 | # | 825 | # |
| 797 | # SPI Protocol Masters | 826 | # SPI Protocol Masters |
| 798 | # | 827 | # |
| 799 | CONFIG_SPI_SPIDEV=y | 828 | CONFIG_SPI_SPIDEV=y |
| 800 | # CONFIG_SPI_TLE62X0 is not set | 829 | # CONFIG_SPI_TLE62X0 is not set |
| 830 | |||
| 831 | # | ||
| 832 | # PPS support | ||
| 833 | # | ||
| 834 | # CONFIG_PPS is not set | ||
| 801 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 835 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 802 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 836 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 803 | CONFIG_GPIOLIB=y | 837 | CONFIG_GPIOLIB=y |
| @@ -865,23 +899,10 @@ CONFIG_SSB_POSSIBLE=y | |||
| 865 | # CONFIG_MFD_WM8400 is not set | 899 | # CONFIG_MFD_WM8400 is not set |
| 866 | # CONFIG_MFD_WM8350_I2C is not set | 900 | # CONFIG_MFD_WM8350_I2C is not set |
| 867 | # CONFIG_MFD_PCF50633 is not set | 901 | # CONFIG_MFD_PCF50633 is not set |
| 902 | # CONFIG_AB3100_CORE is not set | ||
| 903 | # CONFIG_EZX_PCAP is not set | ||
| 868 | # CONFIG_REGULATOR is not set | 904 | # CONFIG_REGULATOR is not set |
| 869 | 905 | # CONFIG_MEDIA_SUPPORT is not set | |
| 870 | # | ||
| 871 | # Multimedia devices | ||
| 872 | # | ||
| 873 | |||
| 874 | # | ||
| 875 | # Multimedia core support | ||
| 876 | # | ||
| 877 | # CONFIG_VIDEO_DEV is not set | ||
| 878 | # CONFIG_DVB_CORE is not set | ||
| 879 | # CONFIG_VIDEO_MEDIA is not set | ||
| 880 | |||
| 881 | # | ||
| 882 | # Multimedia drivers | ||
| 883 | # | ||
| 884 | CONFIG_DAB=y | ||
| 885 | 906 | ||
| 886 | # | 907 | # |
| 887 | # Graphics support | 908 | # Graphics support |
| @@ -990,6 +1011,10 @@ CONFIG_HID=y | |||
| 990 | # CONFIG_DMADEVICES is not set | 1011 | # CONFIG_DMADEVICES is not set |
| 991 | # CONFIG_AUXDISPLAY is not set | 1012 | # CONFIG_AUXDISPLAY is not set |
| 992 | # CONFIG_UIO is not set | 1013 | # CONFIG_UIO is not set |
| 1014 | |||
| 1015 | # | ||
| 1016 | # TI VLYNQ | ||
| 1017 | # | ||
| 993 | # CONFIG_STAGING is not set | 1018 | # CONFIG_STAGING is not set |
| 994 | 1019 | ||
| 995 | # | 1020 | # |
| @@ -1009,10 +1034,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1009 | # CONFIG_REISERFS_FS is not set | 1034 | # CONFIG_REISERFS_FS is not set |
| 1010 | # CONFIG_JFS_FS is not set | 1035 | # CONFIG_JFS_FS is not set |
| 1011 | # CONFIG_FS_POSIX_ACL is not set | 1036 | # CONFIG_FS_POSIX_ACL is not set |
| 1012 | CONFIG_FILE_LOCKING=y | ||
| 1013 | # CONFIG_XFS_FS is not set | 1037 | # CONFIG_XFS_FS is not set |
| 1038 | # CONFIG_GFS2_FS is not set | ||
| 1014 | # CONFIG_OCFS2_FS is not set | 1039 | # CONFIG_OCFS2_FS is not set |
| 1015 | # CONFIG_BTRFS_FS is not set | 1040 | # CONFIG_BTRFS_FS is not set |
| 1041 | CONFIG_FILE_LOCKING=y | ||
| 1042 | CONFIG_FSNOTIFY=y | ||
| 1016 | CONFIG_DNOTIFY=y | 1043 | CONFIG_DNOTIFY=y |
| 1017 | CONFIG_INOTIFY=y | 1044 | CONFIG_INOTIFY=y |
| 1018 | CONFIG_INOTIFY_USER=y | 1045 | CONFIG_INOTIFY_USER=y |
| @@ -1086,6 +1113,7 @@ CONFIG_NFS_FS=y | |||
| 1086 | CONFIG_NFS_V3=y | 1113 | CONFIG_NFS_V3=y |
| 1087 | # CONFIG_NFS_V3_ACL is not set | 1114 | # CONFIG_NFS_V3_ACL is not set |
| 1088 | CONFIG_NFS_V4=y | 1115 | CONFIG_NFS_V4=y |
| 1116 | # CONFIG_NFS_V4_1 is not set | ||
| 1089 | CONFIG_ROOT_NFS=y | 1117 | CONFIG_ROOT_NFS=y |
| 1090 | # CONFIG_NFSD is not set | 1118 | # CONFIG_NFSD is not set |
| 1091 | CONFIG_LOCKD=y | 1119 | CONFIG_LOCKD=y |
| @@ -1145,6 +1173,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1145 | CONFIG_HAS_DMA=y | 1173 | CONFIG_HAS_DMA=y |
| 1146 | CONFIG_HAVE_LMB=y | 1174 | CONFIG_HAVE_LMB=y |
| 1147 | CONFIG_NLATTR=y | 1175 | CONFIG_NLATTR=y |
| 1176 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1148 | 1177 | ||
| 1149 | # | 1178 | # |
| 1150 | # Kernel hacking | 1179 | # Kernel hacking |
| @@ -1170,22 +1199,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1170 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1199 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1171 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1200 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1172 | CONFIG_TRACING_SUPPORT=y | 1201 | CONFIG_TRACING_SUPPORT=y |
| 1173 | 1202 | # CONFIG_FTRACE is not set | |
| 1174 | # | ||
| 1175 | # Tracers | ||
| 1176 | # | ||
| 1177 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1178 | # CONFIG_SCHED_TRACER is not set | ||
| 1179 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1180 | # CONFIG_EVENT_TRACER is not set | ||
| 1181 | # CONFIG_BOOT_TRACER is not set | ||
| 1182 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1183 | # CONFIG_STACK_TRACER is not set | ||
| 1184 | # CONFIG_KMEMTRACE is not set | ||
| 1185 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1186 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1187 | # CONFIG_SAMPLES is not set | 1203 | # CONFIG_SAMPLES is not set |
| 1188 | CONFIG_HAVE_ARCH_KGDB=y | 1204 | CONFIG_HAVE_ARCH_KGDB=y |
| 1205 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1206 | CONFIG_PPC_WERROR=y | ||
| 1189 | CONFIG_PRINT_STACK_DEPTH=64 | 1207 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1190 | # CONFIG_IRQSTACKS is not set | 1208 | # CONFIG_IRQSTACKS is not set |
| 1191 | # CONFIG_BOOTX_TEXT is not set | 1209 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/83xx/mpc837x_mds_defconfig b/arch/powerpc/configs/83xx/mpc837x_mds_defconfig index bf636fd560ad..e285ec0fe958 100644 --- a/arch/powerpc/configs/83xx/mpc837x_mds_defconfig +++ b/arch/powerpc/configs/83xx/mpc837x_mds_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:12 2009 | 4 | # Wed Jul 29 23:32:11 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_FSL_EMB_PERFMON is not set | 20 | # CONFIG_FSL_EMB_PERFMON is not set |
| 20 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 45 | CONFIG_PPC=y | 48 | CONFIG_PPC=y |
| @@ -53,12 +56,14 @@ CONFIG_PPC_UDBG_16550=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 57 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 61 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| 58 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 59 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 60 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 61 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 62 | 67 | ||
| 63 | # | 68 | # |
| 64 | # General setup | 69 | # General setup |
| @@ -108,7 +113,6 @@ CONFIG_EMBEDDED=y | |||
| 108 | CONFIG_SYSCTL_SYSCALL=y | 113 | CONFIG_SYSCTL_SYSCALL=y |
| 109 | CONFIG_KALLSYMS=y | 114 | CONFIG_KALLSYMS=y |
| 110 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 115 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 111 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 112 | CONFIG_HOTPLUG=y | 116 | CONFIG_HOTPLUG=y |
| 113 | CONFIG_PRINTK=y | 117 | CONFIG_PRINTK=y |
| 114 | CONFIG_BUG=y | 118 | CONFIG_BUG=y |
| @@ -121,8 +125,15 @@ CONFIG_TIMERFD=y | |||
| 121 | CONFIG_EVENTFD=y | 125 | CONFIG_EVENTFD=y |
| 122 | CONFIG_SHMEM=y | 126 | CONFIG_SHMEM=y |
| 123 | CONFIG_AIO=y | 127 | CONFIG_AIO=y |
| 128 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 129 | |||
| 130 | # | ||
| 131 | # Performance Counters | ||
| 132 | # | ||
| 133 | # CONFIG_PERF_COUNTERS is not set | ||
| 124 | CONFIG_VM_EVENT_COUNTERS=y | 134 | CONFIG_VM_EVENT_COUNTERS=y |
| 125 | CONFIG_PCI_QUIRKS=y | 135 | CONFIG_PCI_QUIRKS=y |
| 136 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 126 | CONFIG_COMPAT_BRK=y | 137 | CONFIG_COMPAT_BRK=y |
| 127 | CONFIG_SLAB=y | 138 | CONFIG_SLAB=y |
| 128 | # CONFIG_SLUB is not set | 139 | # CONFIG_SLUB is not set |
| @@ -136,6 +147,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 136 | CONFIG_HAVE_KPROBES=y | 147 | CONFIG_HAVE_KPROBES=y |
| 137 | CONFIG_HAVE_KRETPROBES=y | 148 | CONFIG_HAVE_KRETPROBES=y |
| 138 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 149 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 150 | |||
| 151 | # | ||
| 152 | # GCOV-based kernel profiling | ||
| 153 | # | ||
| 139 | # CONFIG_SLOW_WORK is not set | 154 | # CONFIG_SLOW_WORK is not set |
| 140 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 155 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 141 | CONFIG_SLABINFO=y | 156 | CONFIG_SLABINFO=y |
| @@ -148,7 +163,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 148 | # CONFIG_MODVERSIONS is not set | 163 | # CONFIG_MODVERSIONS is not set |
| 149 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 164 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 150 | CONFIG_BLOCK=y | 165 | CONFIG_BLOCK=y |
| 151 | # CONFIG_LBD is not set | 166 | CONFIG_LBDAF=y |
| 152 | # CONFIG_BLK_DEV_BSG is not set | 167 | # CONFIG_BLK_DEV_BSG is not set |
| 153 | # CONFIG_BLK_DEV_INTEGRITY is not set | 168 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 154 | 169 | ||
| @@ -190,6 +205,7 @@ CONFIG_MPC837x_MDS=y | |||
| 190 | # CONFIG_MPC837x_RDB is not set | 205 | # CONFIG_MPC837x_RDB is not set |
| 191 | # CONFIG_SBC834x is not set | 206 | # CONFIG_SBC834x is not set |
| 192 | # CONFIG_ASP834x is not set | 207 | # CONFIG_ASP834x is not set |
| 208 | # CONFIG_KMETER1 is not set | ||
| 193 | CONFIG_PPC_MPC837x=y | 209 | CONFIG_PPC_MPC837x=y |
| 194 | # CONFIG_PPC_86xx is not set | 210 | # CONFIG_PPC_86xx is not set |
| 195 | # CONFIG_EMBEDDED6xx is not set | 211 | # CONFIG_EMBEDDED6xx is not set |
| @@ -234,6 +250,7 @@ CONFIG_BINFMT_ELF=y | |||
| 234 | # CONFIG_HAVE_AOUT is not set | 250 | # CONFIG_HAVE_AOUT is not set |
| 235 | # CONFIG_BINFMT_MISC is not set | 251 | # CONFIG_BINFMT_MISC is not set |
| 236 | # CONFIG_IOMMU_HELPER is not set | 252 | # CONFIG_IOMMU_HELPER is not set |
| 253 | # CONFIG_SWIOTLB is not set | ||
| 237 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 254 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 238 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 255 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 239 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 256 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -254,9 +271,9 @@ CONFIG_MIGRATION=y | |||
| 254 | CONFIG_ZONE_DMA_FLAG=1 | 271 | CONFIG_ZONE_DMA_FLAG=1 |
| 255 | CONFIG_BOUNCE=y | 272 | CONFIG_BOUNCE=y |
| 256 | CONFIG_VIRT_TO_BUS=y | 273 | CONFIG_VIRT_TO_BUS=y |
| 257 | CONFIG_UNEVICTABLE_LRU=y | ||
| 258 | CONFIG_HAVE_MLOCK=y | 274 | CONFIG_HAVE_MLOCK=y |
| 259 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 275 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 276 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 260 | CONFIG_PPC_4K_PAGES=y | 277 | CONFIG_PPC_4K_PAGES=y |
| 261 | # CONFIG_PPC_16K_PAGES is not set | 278 | # CONFIG_PPC_16K_PAGES is not set |
| 262 | # CONFIG_PPC_64K_PAGES is not set | 279 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -365,6 +382,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 365 | # CONFIG_ECONET is not set | 382 | # CONFIG_ECONET is not set |
| 366 | # CONFIG_WAN_ROUTER is not set | 383 | # CONFIG_WAN_ROUTER is not set |
| 367 | # CONFIG_PHONET is not set | 384 | # CONFIG_PHONET is not set |
| 385 | # CONFIG_IEEE802154 is not set | ||
| 368 | # CONFIG_NET_SCHED is not set | 386 | # CONFIG_NET_SCHED is not set |
| 369 | # CONFIG_DCB is not set | 387 | # CONFIG_DCB is not set |
| 370 | 388 | ||
| @@ -382,7 +400,11 @@ CONFIG_WIRELESS=y | |||
| 382 | CONFIG_WIRELESS_OLD_REGULATORY=y | 400 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 383 | # CONFIG_WIRELESS_EXT is not set | 401 | # CONFIG_WIRELESS_EXT is not set |
| 384 | # CONFIG_LIB80211 is not set | 402 | # CONFIG_LIB80211 is not set |
| 385 | # CONFIG_MAC80211 is not set | 403 | |
| 404 | # | ||
| 405 | # CFG80211 needs to be enabled for MAC80211 | ||
| 406 | # | ||
| 407 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 386 | # CONFIG_WIMAX is not set | 408 | # CONFIG_WIMAX is not set |
| 387 | # CONFIG_RFKILL is not set | 409 | # CONFIG_RFKILL is not set |
| 388 | # CONFIG_NET_9P is not set | 410 | # CONFIG_NET_9P is not set |
| @@ -403,6 +425,7 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 403 | # CONFIG_MTD is not set | 425 | # CONFIG_MTD is not set |
| 404 | CONFIG_OF_DEVICE=y | 426 | CONFIG_OF_DEVICE=y |
| 405 | CONFIG_OF_I2C=y | 427 | CONFIG_OF_I2C=y |
| 428 | CONFIG_OF_MDIO=y | ||
| 406 | # CONFIG_PARPORT is not set | 429 | # CONFIG_PARPORT is not set |
| 407 | CONFIG_BLK_DEV=y | 430 | CONFIG_BLK_DEV=y |
| 408 | # CONFIG_BLK_DEV_FD is not set | 431 | # CONFIG_BLK_DEV_FD is not set |
| @@ -437,7 +460,9 @@ CONFIG_MISC_DEVICES=y | |||
| 437 | # | 460 | # |
| 438 | # CONFIG_EEPROM_AT24 is not set | 461 | # CONFIG_EEPROM_AT24 is not set |
| 439 | # CONFIG_EEPROM_LEGACY is not set | 462 | # CONFIG_EEPROM_LEGACY is not set |
| 463 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 440 | # CONFIG_EEPROM_93CX6 is not set | 464 | # CONFIG_EEPROM_93CX6 is not set |
| 465 | # CONFIG_CB710_CORE is not set | ||
| 441 | CONFIG_HAVE_IDE=y | 466 | CONFIG_HAVE_IDE=y |
| 442 | # CONFIG_IDE is not set | 467 | # CONFIG_IDE is not set |
| 443 | 468 | ||
| @@ -460,10 +485,6 @@ CONFIG_BLK_DEV_SD=y | |||
| 460 | # CONFIG_BLK_DEV_SR is not set | 485 | # CONFIG_BLK_DEV_SR is not set |
| 461 | CONFIG_CHR_DEV_SG=y | 486 | CONFIG_CHR_DEV_SG=y |
| 462 | # CONFIG_CHR_DEV_SCH is not set | 487 | # CONFIG_CHR_DEV_SCH is not set |
| 463 | |||
| 464 | # | ||
| 465 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 466 | # | ||
| 467 | # CONFIG_SCSI_MULTI_LUN is not set | 488 | # CONFIG_SCSI_MULTI_LUN is not set |
| 468 | # CONFIG_SCSI_CONSTANTS is not set | 489 | # CONFIG_SCSI_CONSTANTS is not set |
| 469 | # CONFIG_SCSI_LOGGING is not set | 490 | # CONFIG_SCSI_LOGGING is not set |
| @@ -481,6 +502,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 481 | CONFIG_SCSI_LOWLEVEL=y | 502 | CONFIG_SCSI_LOWLEVEL=y |
| 482 | # CONFIG_ISCSI_TCP is not set | 503 | # CONFIG_ISCSI_TCP is not set |
| 483 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 504 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 505 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 484 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 506 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 485 | # CONFIG_SCSI_3W_9XXX is not set | 507 | # CONFIG_SCSI_3W_9XXX is not set |
| 486 | # CONFIG_SCSI_ACARD is not set | 508 | # CONFIG_SCSI_ACARD is not set |
| @@ -489,6 +511,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 489 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 511 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 490 | # CONFIG_SCSI_AIC79XX is not set | 512 | # CONFIG_SCSI_AIC79XX is not set |
| 491 | # CONFIG_SCSI_AIC94XX is not set | 513 | # CONFIG_SCSI_AIC94XX is not set |
| 514 | # CONFIG_SCSI_MVSAS is not set | ||
| 492 | # CONFIG_SCSI_DPT_I2O is not set | 515 | # CONFIG_SCSI_DPT_I2O is not set |
| 493 | # CONFIG_SCSI_ADVANSYS is not set | 516 | # CONFIG_SCSI_ADVANSYS is not set |
| 494 | # CONFIG_SCSI_ARCMSR is not set | 517 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -508,7 +531,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 508 | # CONFIG_SCSI_IPS is not set | 531 | # CONFIG_SCSI_IPS is not set |
| 509 | # CONFIG_SCSI_INITIO is not set | 532 | # CONFIG_SCSI_INITIO is not set |
| 510 | # CONFIG_SCSI_INIA100 is not set | 533 | # CONFIG_SCSI_INIA100 is not set |
| 511 | # CONFIG_SCSI_MVSAS is not set | ||
| 512 | # CONFIG_SCSI_STEX is not set | 534 | # CONFIG_SCSI_STEX is not set |
| 513 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 535 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 514 | # CONFIG_SCSI_IPR is not set | 536 | # CONFIG_SCSI_IPR is not set |
| @@ -592,14 +614,17 @@ CONFIG_ATA_SFF=y | |||
| 592 | # | 614 | # |
| 593 | 615 | ||
| 594 | # | 616 | # |
| 595 | # Enable only one of the two stacks, unless you know what you are doing | 617 | # You can enable one or both FireWire driver stacks. |
| 618 | # | ||
| 619 | |||
| 620 | # | ||
| 621 | # See the help texts for more information. | ||
| 596 | # | 622 | # |
| 597 | # CONFIG_FIREWIRE is not set | 623 | # CONFIG_FIREWIRE is not set |
| 598 | # CONFIG_IEEE1394 is not set | 624 | # CONFIG_IEEE1394 is not set |
| 599 | # CONFIG_I2O is not set | 625 | # CONFIG_I2O is not set |
| 600 | # CONFIG_MACINTOSH_DRIVERS is not set | 626 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 601 | CONFIG_NETDEVICES=y | 627 | CONFIG_NETDEVICES=y |
| 602 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 603 | # CONFIG_DUMMY is not set | 628 | # CONFIG_DUMMY is not set |
| 604 | # CONFIG_BONDING is not set | 629 | # CONFIG_BONDING is not set |
| 605 | # CONFIG_MACVLAN is not set | 630 | # CONFIG_MACVLAN is not set |
| @@ -646,6 +671,7 @@ CONFIG_MII=y | |||
| 646 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 671 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 647 | # CONFIG_NET_PCI is not set | 672 | # CONFIG_NET_PCI is not set |
| 648 | # CONFIG_B44 is not set | 673 | # CONFIG_B44 is not set |
| 674 | # CONFIG_KS8842 is not set | ||
| 649 | # CONFIG_ATL2 is not set | 675 | # CONFIG_ATL2 is not set |
| 650 | CONFIG_NETDEV_1000=y | 676 | CONFIG_NETDEV_1000=y |
| 651 | # CONFIG_ACENIC is not set | 677 | # CONFIG_ACENIC is not set |
| @@ -665,8 +691,10 @@ CONFIG_NETDEV_1000=y | |||
| 665 | # CONFIG_VIA_VELOCITY is not set | 691 | # CONFIG_VIA_VELOCITY is not set |
| 666 | # CONFIG_TIGON3 is not set | 692 | # CONFIG_TIGON3 is not set |
| 667 | # CONFIG_BNX2 is not set | 693 | # CONFIG_BNX2 is not set |
| 694 | # CONFIG_CNIC is not set | ||
| 668 | CONFIG_FSL_PQ_MDIO=y | 695 | CONFIG_FSL_PQ_MDIO=y |
| 669 | CONFIG_GIANFAR=y | 696 | CONFIG_GIANFAR=y |
| 697 | # CONFIG_MV643XX_ETH is not set | ||
| 670 | # CONFIG_QLA3XXX is not set | 698 | # CONFIG_QLA3XXX is not set |
| 671 | # CONFIG_ATL1 is not set | 699 | # CONFIG_ATL1 is not set |
| 672 | # CONFIG_ATL1E is not set | 700 | # CONFIG_ATL1E is not set |
| @@ -844,13 +872,17 @@ CONFIG_I2C_MPC=y | |||
| 844 | # CONFIG_SENSORS_PCF8574 is not set | 872 | # CONFIG_SENSORS_PCF8574 is not set |
| 845 | # CONFIG_PCF8575 is not set | 873 | # CONFIG_PCF8575 is not set |
| 846 | # CONFIG_SENSORS_PCA9539 is not set | 874 | # CONFIG_SENSORS_PCA9539 is not set |
| 847 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 848 | # CONFIG_SENSORS_TSL2550 is not set | 875 | # CONFIG_SENSORS_TSL2550 is not set |
| 849 | # CONFIG_I2C_DEBUG_CORE is not set | 876 | # CONFIG_I2C_DEBUG_CORE is not set |
| 850 | # CONFIG_I2C_DEBUG_ALGO is not set | 877 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 851 | # CONFIG_I2C_DEBUG_BUS is not set | 878 | # CONFIG_I2C_DEBUG_BUS is not set |
| 852 | # CONFIG_I2C_DEBUG_CHIP is not set | 879 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 853 | # CONFIG_SPI is not set | 880 | # CONFIG_SPI is not set |
| 881 | |||
| 882 | # | ||
| 883 | # PPS support | ||
| 884 | # | ||
| 885 | # CONFIG_PPS is not set | ||
| 854 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 886 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 855 | # CONFIG_GPIOLIB is not set | 887 | # CONFIG_GPIOLIB is not set |
| 856 | # CONFIG_W1 is not set | 888 | # CONFIG_W1 is not set |
| @@ -905,6 +937,7 @@ CONFIG_HWMON=y | |||
| 905 | # CONFIG_SENSORS_SMSC47B397 is not set | 937 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 906 | # CONFIG_SENSORS_ADS7828 is not set | 938 | # CONFIG_SENSORS_ADS7828 is not set |
| 907 | # CONFIG_SENSORS_THMC50 is not set | 939 | # CONFIG_SENSORS_THMC50 is not set |
| 940 | # CONFIG_SENSORS_TMP401 is not set | ||
| 908 | # CONFIG_SENSORS_VIA686A is not set | 941 | # CONFIG_SENSORS_VIA686A is not set |
| 909 | # CONFIG_SENSORS_VT1211 is not set | 942 | # CONFIG_SENSORS_VT1211 is not set |
| 910 | # CONFIG_SENSORS_VT8231 is not set | 943 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -953,23 +986,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 953 | # CONFIG_MFD_WM8400 is not set | 986 | # CONFIG_MFD_WM8400 is not set |
| 954 | # CONFIG_MFD_WM8350_I2C is not set | 987 | # CONFIG_MFD_WM8350_I2C is not set |
| 955 | # CONFIG_MFD_PCF50633 is not set | 988 | # CONFIG_MFD_PCF50633 is not set |
| 989 | # CONFIG_AB3100_CORE is not set | ||
| 956 | # CONFIG_REGULATOR is not set | 990 | # CONFIG_REGULATOR is not set |
| 957 | 991 | # CONFIG_MEDIA_SUPPORT is not set | |
| 958 | # | ||
| 959 | # Multimedia devices | ||
| 960 | # | ||
| 961 | |||
| 962 | # | ||
| 963 | # Multimedia core support | ||
| 964 | # | ||
| 965 | # CONFIG_VIDEO_DEV is not set | ||
| 966 | # CONFIG_DVB_CORE is not set | ||
| 967 | # CONFIG_VIDEO_MEDIA is not set | ||
| 968 | |||
| 969 | # | ||
| 970 | # Multimedia drivers | ||
| 971 | # | ||
| 972 | CONFIG_DAB=y | ||
| 973 | 992 | ||
| 974 | # | 993 | # |
| 975 | # Graphics support | 994 | # Graphics support |
| @@ -1026,6 +1045,10 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
| 1026 | # CONFIG_DMADEVICES is not set | 1045 | # CONFIG_DMADEVICES is not set |
| 1027 | # CONFIG_AUXDISPLAY is not set | 1046 | # CONFIG_AUXDISPLAY is not set |
| 1028 | # CONFIG_UIO is not set | 1047 | # CONFIG_UIO is not set |
| 1048 | |||
| 1049 | # | ||
| 1050 | # TI VLYNQ | ||
| 1051 | # | ||
| 1029 | # CONFIG_STAGING is not set | 1052 | # CONFIG_STAGING is not set |
| 1030 | 1053 | ||
| 1031 | # | 1054 | # |
| @@ -1045,10 +1068,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1045 | # CONFIG_REISERFS_FS is not set | 1068 | # CONFIG_REISERFS_FS is not set |
| 1046 | # CONFIG_JFS_FS is not set | 1069 | # CONFIG_JFS_FS is not set |
| 1047 | # CONFIG_FS_POSIX_ACL is not set | 1070 | # CONFIG_FS_POSIX_ACL is not set |
| 1048 | CONFIG_FILE_LOCKING=y | ||
| 1049 | # CONFIG_XFS_FS is not set | 1071 | # CONFIG_XFS_FS is not set |
| 1072 | # CONFIG_GFS2_FS is not set | ||
| 1050 | # CONFIG_OCFS2_FS is not set | 1073 | # CONFIG_OCFS2_FS is not set |
| 1051 | # CONFIG_BTRFS_FS is not set | 1074 | # CONFIG_BTRFS_FS is not set |
| 1075 | CONFIG_FILE_LOCKING=y | ||
| 1076 | CONFIG_FSNOTIFY=y | ||
| 1052 | CONFIG_DNOTIFY=y | 1077 | CONFIG_DNOTIFY=y |
| 1053 | CONFIG_INOTIFY=y | 1078 | CONFIG_INOTIFY=y |
| 1054 | CONFIG_INOTIFY_USER=y | 1079 | CONFIG_INOTIFY_USER=y |
| @@ -1111,6 +1136,7 @@ CONFIG_NFS_FS=y | |||
| 1111 | CONFIG_NFS_V3=y | 1136 | CONFIG_NFS_V3=y |
| 1112 | # CONFIG_NFS_V3_ACL is not set | 1137 | # CONFIG_NFS_V3_ACL is not set |
| 1113 | CONFIG_NFS_V4=y | 1138 | CONFIG_NFS_V4=y |
| 1139 | # CONFIG_NFS_V4_1 is not set | ||
| 1114 | CONFIG_ROOT_NFS=y | 1140 | CONFIG_ROOT_NFS=y |
| 1115 | # CONFIG_NFSD is not set | 1141 | # CONFIG_NFSD is not set |
| 1116 | CONFIG_LOCKD=y | 1142 | CONFIG_LOCKD=y |
| @@ -1170,6 +1196,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1170 | CONFIG_HAS_DMA=y | 1196 | CONFIG_HAS_DMA=y |
| 1171 | CONFIG_HAVE_LMB=y | 1197 | CONFIG_HAVE_LMB=y |
| 1172 | CONFIG_NLATTR=y | 1198 | CONFIG_NLATTR=y |
| 1199 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1173 | 1200 | ||
| 1174 | # | 1201 | # |
| 1175 | # Kernel hacking | 1202 | # Kernel hacking |
| @@ -1193,22 +1220,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1193 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1220 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1194 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1221 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1195 | CONFIG_TRACING_SUPPORT=y | 1222 | CONFIG_TRACING_SUPPORT=y |
| 1196 | 1223 | # CONFIG_FTRACE is not set | |
| 1197 | # | ||
| 1198 | # Tracers | ||
| 1199 | # | ||
| 1200 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1201 | # CONFIG_SCHED_TRACER is not set | ||
| 1202 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1203 | # CONFIG_EVENT_TRACER is not set | ||
| 1204 | # CONFIG_BOOT_TRACER is not set | ||
| 1205 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1206 | # CONFIG_STACK_TRACER is not set | ||
| 1207 | # CONFIG_KMEMTRACE is not set | ||
| 1208 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1209 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1210 | # CONFIG_SAMPLES is not set | 1224 | # CONFIG_SAMPLES is not set |
| 1211 | CONFIG_HAVE_ARCH_KGDB=y | 1225 | CONFIG_HAVE_ARCH_KGDB=y |
| 1226 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1227 | CONFIG_PPC_WERROR=y | ||
| 1212 | CONFIG_PRINT_STACK_DEPTH=64 | 1228 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1213 | # CONFIG_IRQSTACKS is not set | 1229 | # CONFIG_IRQSTACKS is not set |
| 1214 | # CONFIG_BOOTX_TEXT is not set | 1230 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/83xx/mpc837x_rdb_defconfig b/arch/powerpc/configs/83xx/mpc837x_rdb_defconfig index fe6454eacbdb..1ab3e4cd3018 100644 --- a/arch/powerpc/configs/83xx/mpc837x_rdb_defconfig +++ b/arch/powerpc/configs/83xx/mpc837x_rdb_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:14 2009 | 4 | # Wed Jul 29 23:32:13 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_FSL_EMB_PERFMON is not set | 20 | # CONFIG_FSL_EMB_PERFMON is not set |
| 20 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 45 | CONFIG_PPC=y | 48 | CONFIG_PPC=y |
| @@ -53,12 +56,14 @@ CONFIG_PPC_UDBG_16550=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 57 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 61 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| 58 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 59 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 60 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 61 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 62 | 67 | ||
| 63 | # | 68 | # |
| 64 | # General setup | 69 | # General setup |
| @@ -108,7 +113,6 @@ CONFIG_EMBEDDED=y | |||
| 108 | CONFIG_SYSCTL_SYSCALL=y | 113 | CONFIG_SYSCTL_SYSCALL=y |
| 109 | CONFIG_KALLSYMS=y | 114 | CONFIG_KALLSYMS=y |
| 110 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 115 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 111 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 112 | CONFIG_HOTPLUG=y | 116 | CONFIG_HOTPLUG=y |
| 113 | CONFIG_PRINTK=y | 117 | CONFIG_PRINTK=y |
| 114 | CONFIG_BUG=y | 118 | CONFIG_BUG=y |
| @@ -121,8 +125,15 @@ CONFIG_TIMERFD=y | |||
| 121 | CONFIG_EVENTFD=y | 125 | CONFIG_EVENTFD=y |
| 122 | CONFIG_SHMEM=y | 126 | CONFIG_SHMEM=y |
| 123 | CONFIG_AIO=y | 127 | CONFIG_AIO=y |
| 128 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 129 | |||
| 130 | # | ||
| 131 | # Performance Counters | ||
| 132 | # | ||
| 133 | # CONFIG_PERF_COUNTERS is not set | ||
| 124 | CONFIG_VM_EVENT_COUNTERS=y | 134 | CONFIG_VM_EVENT_COUNTERS=y |
| 125 | CONFIG_PCI_QUIRKS=y | 135 | CONFIG_PCI_QUIRKS=y |
| 136 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 126 | CONFIG_COMPAT_BRK=y | 137 | CONFIG_COMPAT_BRK=y |
| 127 | CONFIG_SLAB=y | 138 | CONFIG_SLAB=y |
| 128 | # CONFIG_SLUB is not set | 139 | # CONFIG_SLUB is not set |
| @@ -136,6 +147,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 136 | CONFIG_HAVE_KPROBES=y | 147 | CONFIG_HAVE_KPROBES=y |
| 137 | CONFIG_HAVE_KRETPROBES=y | 148 | CONFIG_HAVE_KRETPROBES=y |
| 138 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 149 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 150 | |||
| 151 | # | ||
| 152 | # GCOV-based kernel profiling | ||
| 153 | # | ||
| 139 | # CONFIG_SLOW_WORK is not set | 154 | # CONFIG_SLOW_WORK is not set |
| 140 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 155 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 141 | CONFIG_SLABINFO=y | 156 | CONFIG_SLABINFO=y |
| @@ -148,7 +163,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 148 | # CONFIG_MODVERSIONS is not set | 163 | # CONFIG_MODVERSIONS is not set |
| 149 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 164 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 150 | CONFIG_BLOCK=y | 165 | CONFIG_BLOCK=y |
| 151 | # CONFIG_LBD is not set | 166 | CONFIG_LBDAF=y |
| 152 | # CONFIG_BLK_DEV_BSG is not set | 167 | # CONFIG_BLK_DEV_BSG is not set |
| 153 | # CONFIG_BLK_DEV_INTEGRITY is not set | 168 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 154 | 169 | ||
| @@ -190,6 +205,7 @@ CONFIG_PPC_83xx=y | |||
| 190 | CONFIG_MPC837x_RDB=y | 205 | CONFIG_MPC837x_RDB=y |
| 191 | # CONFIG_SBC834x is not set | 206 | # CONFIG_SBC834x is not set |
| 192 | # CONFIG_ASP834x is not set | 207 | # CONFIG_ASP834x is not set |
| 208 | # CONFIG_KMETER1 is not set | ||
| 193 | CONFIG_PPC_MPC837x=y | 209 | CONFIG_PPC_MPC837x=y |
| 194 | # CONFIG_PPC_86xx is not set | 210 | # CONFIG_PPC_86xx is not set |
| 195 | # CONFIG_EMBEDDED6xx is not set | 211 | # CONFIG_EMBEDDED6xx is not set |
| @@ -234,6 +250,7 @@ CONFIG_BINFMT_ELF=y | |||
| 234 | # CONFIG_HAVE_AOUT is not set | 250 | # CONFIG_HAVE_AOUT is not set |
| 235 | # CONFIG_BINFMT_MISC is not set | 251 | # CONFIG_BINFMT_MISC is not set |
| 236 | # CONFIG_IOMMU_HELPER is not set | 252 | # CONFIG_IOMMU_HELPER is not set |
| 253 | # CONFIG_SWIOTLB is not set | ||
| 237 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 254 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 238 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 255 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 239 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 256 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -254,9 +271,9 @@ CONFIG_MIGRATION=y | |||
| 254 | CONFIG_ZONE_DMA_FLAG=1 | 271 | CONFIG_ZONE_DMA_FLAG=1 |
| 255 | CONFIG_BOUNCE=y | 272 | CONFIG_BOUNCE=y |
| 256 | CONFIG_VIRT_TO_BUS=y | 273 | CONFIG_VIRT_TO_BUS=y |
| 257 | CONFIG_UNEVICTABLE_LRU=y | ||
| 258 | CONFIG_HAVE_MLOCK=y | 274 | CONFIG_HAVE_MLOCK=y |
| 259 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 275 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 276 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 260 | CONFIG_PPC_4K_PAGES=y | 277 | CONFIG_PPC_4K_PAGES=y |
| 261 | # CONFIG_PPC_16K_PAGES is not set | 278 | # CONFIG_PPC_16K_PAGES is not set |
| 262 | # CONFIG_PPC_64K_PAGES is not set | 279 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -360,6 +377,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 360 | # CONFIG_ECONET is not set | 377 | # CONFIG_ECONET is not set |
| 361 | # CONFIG_WAN_ROUTER is not set | 378 | # CONFIG_WAN_ROUTER is not set |
| 362 | # CONFIG_PHONET is not set | 379 | # CONFIG_PHONET is not set |
| 380 | # CONFIG_IEEE802154 is not set | ||
| 363 | # CONFIG_NET_SCHED is not set | 381 | # CONFIG_NET_SCHED is not set |
| 364 | # CONFIG_DCB is not set | 382 | # CONFIG_DCB is not set |
| 365 | 383 | ||
| @@ -377,7 +395,11 @@ CONFIG_WIRELESS=y | |||
| 377 | CONFIG_WIRELESS_OLD_REGULATORY=y | 395 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 378 | # CONFIG_WIRELESS_EXT is not set | 396 | # CONFIG_WIRELESS_EXT is not set |
| 379 | # CONFIG_LIB80211 is not set | 397 | # CONFIG_LIB80211 is not set |
| 380 | # CONFIG_MAC80211 is not set | 398 | |
| 399 | # | ||
| 400 | # CFG80211 needs to be enabled for MAC80211 | ||
| 401 | # | ||
| 402 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 381 | # CONFIG_WIMAX is not set | 403 | # CONFIG_WIMAX is not set |
| 382 | # CONFIG_RFKILL is not set | 404 | # CONFIG_RFKILL is not set |
| 383 | # CONFIG_NET_9P is not set | 405 | # CONFIG_NET_9P is not set |
| @@ -398,6 +420,7 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 398 | # CONFIG_MTD is not set | 420 | # CONFIG_MTD is not set |
| 399 | CONFIG_OF_DEVICE=y | 421 | CONFIG_OF_DEVICE=y |
| 400 | CONFIG_OF_I2C=y | 422 | CONFIG_OF_I2C=y |
| 423 | CONFIG_OF_MDIO=y | ||
| 401 | # CONFIG_PARPORT is not set | 424 | # CONFIG_PARPORT is not set |
| 402 | CONFIG_BLK_DEV=y | 425 | CONFIG_BLK_DEV=y |
| 403 | # CONFIG_BLK_DEV_FD is not set | 426 | # CONFIG_BLK_DEV_FD is not set |
| @@ -433,7 +456,9 @@ CONFIG_MISC_DEVICES=y | |||
| 433 | # | 456 | # |
| 434 | # CONFIG_EEPROM_AT24 is not set | 457 | # CONFIG_EEPROM_AT24 is not set |
| 435 | # CONFIG_EEPROM_LEGACY is not set | 458 | # CONFIG_EEPROM_LEGACY is not set |
| 459 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 436 | # CONFIG_EEPROM_93CX6 is not set | 460 | # CONFIG_EEPROM_93CX6 is not set |
| 461 | # CONFIG_CB710_CORE is not set | ||
| 437 | CONFIG_HAVE_IDE=y | 462 | CONFIG_HAVE_IDE=y |
| 438 | # CONFIG_IDE is not set | 463 | # CONFIG_IDE is not set |
| 439 | 464 | ||
| @@ -456,10 +481,6 @@ CONFIG_BLK_DEV_SD=y | |||
| 456 | # CONFIG_BLK_DEV_SR is not set | 481 | # CONFIG_BLK_DEV_SR is not set |
| 457 | CONFIG_CHR_DEV_SG=y | 482 | CONFIG_CHR_DEV_SG=y |
| 458 | # CONFIG_CHR_DEV_SCH is not set | 483 | # CONFIG_CHR_DEV_SCH is not set |
| 459 | |||
| 460 | # | ||
| 461 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 462 | # | ||
| 463 | # CONFIG_SCSI_MULTI_LUN is not set | 484 | # CONFIG_SCSI_MULTI_LUN is not set |
| 464 | # CONFIG_SCSI_CONSTANTS is not set | 485 | # CONFIG_SCSI_CONSTANTS is not set |
| 465 | # CONFIG_SCSI_LOGGING is not set | 486 | # CONFIG_SCSI_LOGGING is not set |
| @@ -476,6 +497,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 476 | # CONFIG_SCSI_SRP_ATTRS is not set | 497 | # CONFIG_SCSI_SRP_ATTRS is not set |
| 477 | CONFIG_SCSI_LOWLEVEL=y | 498 | CONFIG_SCSI_LOWLEVEL=y |
| 478 | # CONFIG_ISCSI_TCP is not set | 499 | # CONFIG_ISCSI_TCP is not set |
| 500 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 479 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 501 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 480 | # CONFIG_SCSI_3W_9XXX is not set | 502 | # CONFIG_SCSI_3W_9XXX is not set |
| 481 | # CONFIG_SCSI_ACARD is not set | 503 | # CONFIG_SCSI_ACARD is not set |
| @@ -484,6 +506,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 484 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 506 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 485 | # CONFIG_SCSI_AIC79XX is not set | 507 | # CONFIG_SCSI_AIC79XX is not set |
| 486 | # CONFIG_SCSI_AIC94XX is not set | 508 | # CONFIG_SCSI_AIC94XX is not set |
| 509 | # CONFIG_SCSI_MVSAS is not set | ||
| 487 | # CONFIG_SCSI_DPT_I2O is not set | 510 | # CONFIG_SCSI_DPT_I2O is not set |
| 488 | # CONFIG_SCSI_ADVANSYS is not set | 511 | # CONFIG_SCSI_ADVANSYS is not set |
| 489 | # CONFIG_SCSI_ARCMSR is not set | 512 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -503,7 +526,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 503 | # CONFIG_SCSI_IPS is not set | 526 | # CONFIG_SCSI_IPS is not set |
| 504 | # CONFIG_SCSI_INITIO is not set | 527 | # CONFIG_SCSI_INITIO is not set |
| 505 | # CONFIG_SCSI_INIA100 is not set | 528 | # CONFIG_SCSI_INIA100 is not set |
| 506 | # CONFIG_SCSI_MVSAS is not set | ||
| 507 | # CONFIG_SCSI_STEX is not set | 529 | # CONFIG_SCSI_STEX is not set |
| 508 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 530 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 509 | # CONFIG_SCSI_IPR is not set | 531 | # CONFIG_SCSI_IPR is not set |
| @@ -598,14 +620,17 @@ CONFIG_MD_RAID6_PQ=y | |||
| 598 | # | 620 | # |
| 599 | 621 | ||
| 600 | # | 622 | # |
| 601 | # Enable only one of the two stacks, unless you know what you are doing | 623 | # You can enable one or both FireWire driver stacks. |
| 624 | # | ||
| 625 | |||
| 626 | # | ||
| 627 | # See the help texts for more information. | ||
| 602 | # | 628 | # |
| 603 | # CONFIG_FIREWIRE is not set | 629 | # CONFIG_FIREWIRE is not set |
| 604 | # CONFIG_IEEE1394 is not set | 630 | # CONFIG_IEEE1394 is not set |
| 605 | # CONFIG_I2O is not set | 631 | # CONFIG_I2O is not set |
| 606 | # CONFIG_MACINTOSH_DRIVERS is not set | 632 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 607 | CONFIG_NETDEVICES=y | 633 | CONFIG_NETDEVICES=y |
| 608 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 609 | # CONFIG_DUMMY is not set | 634 | # CONFIG_DUMMY is not set |
| 610 | # CONFIG_BONDING is not set | 635 | # CONFIG_BONDING is not set |
| 611 | # CONFIG_MACVLAN is not set | 636 | # CONFIG_MACVLAN is not set |
| @@ -652,6 +677,7 @@ CONFIG_MII=y | |||
| 652 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 677 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 653 | # CONFIG_NET_PCI is not set | 678 | # CONFIG_NET_PCI is not set |
| 654 | # CONFIG_B44 is not set | 679 | # CONFIG_B44 is not set |
| 680 | # CONFIG_KS8842 is not set | ||
| 655 | # CONFIG_ATL2 is not set | 681 | # CONFIG_ATL2 is not set |
| 656 | CONFIG_NETDEV_1000=y | 682 | CONFIG_NETDEV_1000=y |
| 657 | # CONFIG_ACENIC is not set | 683 | # CONFIG_ACENIC is not set |
| @@ -671,8 +697,10 @@ CONFIG_NETDEV_1000=y | |||
| 671 | # CONFIG_VIA_VELOCITY is not set | 697 | # CONFIG_VIA_VELOCITY is not set |
| 672 | # CONFIG_TIGON3 is not set | 698 | # CONFIG_TIGON3 is not set |
| 673 | # CONFIG_BNX2 is not set | 699 | # CONFIG_BNX2 is not set |
| 700 | # CONFIG_CNIC is not set | ||
| 674 | CONFIG_FSL_PQ_MDIO=y | 701 | CONFIG_FSL_PQ_MDIO=y |
| 675 | CONFIG_GIANFAR=y | 702 | CONFIG_GIANFAR=y |
| 703 | # CONFIG_MV643XX_ETH is not set | ||
| 676 | # CONFIG_QLA3XXX is not set | 704 | # CONFIG_QLA3XXX is not set |
| 677 | # CONFIG_ATL1 is not set | 705 | # CONFIG_ATL1 is not set |
| 678 | # CONFIG_ATL1E is not set | 706 | # CONFIG_ATL1E is not set |
| @@ -842,13 +870,17 @@ CONFIG_I2C_MPC=y | |||
| 842 | # CONFIG_SENSORS_PCF8574 is not set | 870 | # CONFIG_SENSORS_PCF8574 is not set |
| 843 | # CONFIG_PCF8575 is not set | 871 | # CONFIG_PCF8575 is not set |
| 844 | # CONFIG_SENSORS_PCA9539 is not set | 872 | # CONFIG_SENSORS_PCA9539 is not set |
| 845 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 846 | # CONFIG_SENSORS_TSL2550 is not set | 873 | # CONFIG_SENSORS_TSL2550 is not set |
| 847 | # CONFIG_I2C_DEBUG_CORE is not set | 874 | # CONFIG_I2C_DEBUG_CORE is not set |
| 848 | # CONFIG_I2C_DEBUG_ALGO is not set | 875 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 849 | # CONFIG_I2C_DEBUG_BUS is not set | 876 | # CONFIG_I2C_DEBUG_BUS is not set |
| 850 | # CONFIG_I2C_DEBUG_CHIP is not set | 877 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 851 | # CONFIG_SPI is not set | 878 | # CONFIG_SPI is not set |
| 879 | |||
| 880 | # | ||
| 881 | # PPS support | ||
| 882 | # | ||
| 883 | # CONFIG_PPS is not set | ||
| 852 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 884 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 853 | # CONFIG_GPIOLIB is not set | 885 | # CONFIG_GPIOLIB is not set |
| 854 | # CONFIG_W1 is not set | 886 | # CONFIG_W1 is not set |
| @@ -903,6 +935,7 @@ CONFIG_HWMON=y | |||
| 903 | # CONFIG_SENSORS_SMSC47B397 is not set | 935 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 904 | # CONFIG_SENSORS_ADS7828 is not set | 936 | # CONFIG_SENSORS_ADS7828 is not set |
| 905 | # CONFIG_SENSORS_THMC50 is not set | 937 | # CONFIG_SENSORS_THMC50 is not set |
| 938 | # CONFIG_SENSORS_TMP401 is not set | ||
| 906 | # CONFIG_SENSORS_VIA686A is not set | 939 | # CONFIG_SENSORS_VIA686A is not set |
| 907 | # CONFIG_SENSORS_VT1211 is not set | 940 | # CONFIG_SENSORS_VT1211 is not set |
| 908 | # CONFIG_SENSORS_VT8231 is not set | 941 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -956,24 +989,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 956 | # CONFIG_MFD_WM8400 is not set | 989 | # CONFIG_MFD_WM8400 is not set |
| 957 | # CONFIG_MFD_WM8350_I2C is not set | 990 | # CONFIG_MFD_WM8350_I2C is not set |
| 958 | # CONFIG_MFD_PCF50633 is not set | 991 | # CONFIG_MFD_PCF50633 is not set |
| 992 | # CONFIG_AB3100_CORE is not set | ||
| 959 | # CONFIG_REGULATOR is not set | 993 | # CONFIG_REGULATOR is not set |
| 960 | 994 | # CONFIG_MEDIA_SUPPORT is not set | |
| 961 | # | ||
| 962 | # Multimedia devices | ||
| 963 | # | ||
| 964 | |||
| 965 | # | ||
| 966 | # Multimedia core support | ||
| 967 | # | ||
| 968 | # CONFIG_VIDEO_DEV is not set | ||
| 969 | # CONFIG_DVB_CORE is not set | ||
| 970 | # CONFIG_VIDEO_MEDIA is not set | ||
| 971 | |||
| 972 | # | ||
| 973 | # Multimedia drivers | ||
| 974 | # | ||
| 975 | CONFIG_DAB=y | ||
| 976 | # CONFIG_USB_DABUSB is not set | ||
| 977 | 995 | ||
| 978 | # | 996 | # |
| 979 | # Graphics support | 997 | # Graphics support |
| @@ -1011,7 +1029,7 @@ CONFIG_HID_BELKIN=y | |||
| 1011 | CONFIG_HID_CHERRY=y | 1029 | CONFIG_HID_CHERRY=y |
| 1012 | CONFIG_HID_CHICONY=y | 1030 | CONFIG_HID_CHICONY=y |
| 1013 | CONFIG_HID_CYPRESS=y | 1031 | CONFIG_HID_CYPRESS=y |
| 1014 | # CONFIG_DRAGONRISE_FF is not set | 1032 | # CONFIG_HID_DRAGONRISE is not set |
| 1015 | CONFIG_HID_EZKEY=y | 1033 | CONFIG_HID_EZKEY=y |
| 1016 | # CONFIG_HID_KYE is not set | 1034 | # CONFIG_HID_KYE is not set |
| 1017 | CONFIG_HID_GYRATION=y | 1035 | CONFIG_HID_GYRATION=y |
| @@ -1028,10 +1046,11 @@ CONFIG_HID_PETALYNX=y | |||
| 1028 | CONFIG_HID_SAMSUNG=y | 1046 | CONFIG_HID_SAMSUNG=y |
| 1029 | CONFIG_HID_SONY=y | 1047 | CONFIG_HID_SONY=y |
| 1030 | CONFIG_HID_SUNPLUS=y | 1048 | CONFIG_HID_SUNPLUS=y |
| 1031 | # CONFIG_GREENASIA_FF is not set | 1049 | # CONFIG_HID_GREENASIA is not set |
| 1050 | # CONFIG_HID_SMARTJOYPLUS is not set | ||
| 1032 | # CONFIG_HID_TOPSEED is not set | 1051 | # CONFIG_HID_TOPSEED is not set |
| 1033 | CONFIG_THRUSTMASTER_FF=m | 1052 | # CONFIG_HID_THRUSTMASTER is not set |
| 1034 | CONFIG_ZEROPLUS_FF=m | 1053 | # CONFIG_HID_ZEROPLUS is not set |
| 1035 | CONFIG_USB_SUPPORT=y | 1054 | CONFIG_USB_SUPPORT=y |
| 1036 | CONFIG_USB_ARCH_HAS_HCD=y | 1055 | CONFIG_USB_ARCH_HAS_HCD=y |
| 1037 | CONFIG_USB_ARCH_HAS_OHCI=y | 1056 | CONFIG_USB_ARCH_HAS_OHCI=y |
| @@ -1057,6 +1076,7 @@ CONFIG_USB_MON=y | |||
| 1057 | # USB Host Controller Drivers | 1076 | # USB Host Controller Drivers |
| 1058 | # | 1077 | # |
| 1059 | # CONFIG_USB_C67X00_HCD is not set | 1078 | # CONFIG_USB_C67X00_HCD is not set |
| 1079 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1060 | CONFIG_USB_EHCI_HCD=y | 1080 | CONFIG_USB_EHCI_HCD=y |
| 1061 | CONFIG_USB_EHCI_ROOT_HUB_TT=y | 1081 | CONFIG_USB_EHCI_ROOT_HUB_TT=y |
| 1062 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1082 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1141,6 +1161,10 @@ CONFIG_USB_EHCI_HCD_PPC_OF=y | |||
| 1141 | # CONFIG_DMADEVICES is not set | 1161 | # CONFIG_DMADEVICES is not set |
| 1142 | # CONFIG_AUXDISPLAY is not set | 1162 | # CONFIG_AUXDISPLAY is not set |
| 1143 | # CONFIG_UIO is not set | 1163 | # CONFIG_UIO is not set |
| 1164 | |||
| 1165 | # | ||
| 1166 | # TI VLYNQ | ||
| 1167 | # | ||
| 1144 | # CONFIG_STAGING is not set | 1168 | # CONFIG_STAGING is not set |
| 1145 | 1169 | ||
| 1146 | # | 1170 | # |
| @@ -1160,10 +1184,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1160 | # CONFIG_REISERFS_FS is not set | 1184 | # CONFIG_REISERFS_FS is not set |
| 1161 | # CONFIG_JFS_FS is not set | 1185 | # CONFIG_JFS_FS is not set |
| 1162 | # CONFIG_FS_POSIX_ACL is not set | 1186 | # CONFIG_FS_POSIX_ACL is not set |
| 1163 | CONFIG_FILE_LOCKING=y | ||
| 1164 | # CONFIG_XFS_FS is not set | 1187 | # CONFIG_XFS_FS is not set |
| 1188 | # CONFIG_GFS2_FS is not set | ||
| 1165 | # CONFIG_OCFS2_FS is not set | 1189 | # CONFIG_OCFS2_FS is not set |
| 1166 | # CONFIG_BTRFS_FS is not set | 1190 | # CONFIG_BTRFS_FS is not set |
| 1191 | CONFIG_FILE_LOCKING=y | ||
| 1192 | CONFIG_FSNOTIFY=y | ||
| 1167 | CONFIG_DNOTIFY=y | 1193 | CONFIG_DNOTIFY=y |
| 1168 | CONFIG_INOTIFY=y | 1194 | CONFIG_INOTIFY=y |
| 1169 | CONFIG_INOTIFY_USER=y | 1195 | CONFIG_INOTIFY_USER=y |
| @@ -1226,6 +1252,7 @@ CONFIG_NFS_FS=y | |||
| 1226 | CONFIG_NFS_V3=y | 1252 | CONFIG_NFS_V3=y |
| 1227 | # CONFIG_NFS_V3_ACL is not set | 1253 | # CONFIG_NFS_V3_ACL is not set |
| 1228 | CONFIG_NFS_V4=y | 1254 | CONFIG_NFS_V4=y |
| 1255 | # CONFIG_NFS_V4_1 is not set | ||
| 1229 | CONFIG_ROOT_NFS=y | 1256 | CONFIG_ROOT_NFS=y |
| 1230 | # CONFIG_NFSD is not set | 1257 | # CONFIG_NFSD is not set |
| 1231 | CONFIG_LOCKD=y | 1258 | CONFIG_LOCKD=y |
| @@ -1262,7 +1289,46 @@ CONFIG_MSDOS_PARTITION=y | |||
| 1262 | # CONFIG_KARMA_PARTITION is not set | 1289 | # CONFIG_KARMA_PARTITION is not set |
| 1263 | # CONFIG_EFI_PARTITION is not set | 1290 | # CONFIG_EFI_PARTITION is not set |
| 1264 | # CONFIG_SYSV68_PARTITION is not set | 1291 | # CONFIG_SYSV68_PARTITION is not set |
| 1265 | # CONFIG_NLS is not set | 1292 | CONFIG_NLS=y |
| 1293 | CONFIG_NLS_DEFAULT="iso8859-1" | ||
| 1294 | # CONFIG_NLS_CODEPAGE_437 is not set | ||
| 1295 | # CONFIG_NLS_CODEPAGE_737 is not set | ||
| 1296 | # CONFIG_NLS_CODEPAGE_775 is not set | ||
| 1297 | # CONFIG_NLS_CODEPAGE_850 is not set | ||
| 1298 | # CONFIG_NLS_CODEPAGE_852 is not set | ||
| 1299 | # CONFIG_NLS_CODEPAGE_855 is not set | ||
| 1300 | # CONFIG_NLS_CODEPAGE_857 is not set | ||
| 1301 | # CONFIG_NLS_CODEPAGE_860 is not set | ||
| 1302 | # CONFIG_NLS_CODEPAGE_861 is not set | ||
| 1303 | # CONFIG_NLS_CODEPAGE_862 is not set | ||
| 1304 | # CONFIG_NLS_CODEPAGE_863 is not set | ||
| 1305 | # CONFIG_NLS_CODEPAGE_864 is not set | ||
| 1306 | # CONFIG_NLS_CODEPAGE_865 is not set | ||
| 1307 | # CONFIG_NLS_CODEPAGE_866 is not set | ||
| 1308 | # CONFIG_NLS_CODEPAGE_869 is not set | ||
| 1309 | # CONFIG_NLS_CODEPAGE_936 is not set | ||
| 1310 | # CONFIG_NLS_CODEPAGE_950 is not set | ||
| 1311 | # CONFIG_NLS_CODEPAGE_932 is not set | ||
| 1312 | # CONFIG_NLS_CODEPAGE_949 is not set | ||
| 1313 | # CONFIG_NLS_CODEPAGE_874 is not set | ||
| 1314 | # CONFIG_NLS_ISO8859_8 is not set | ||
| 1315 | # CONFIG_NLS_CODEPAGE_1250 is not set | ||
| 1316 | # CONFIG_NLS_CODEPAGE_1251 is not set | ||
| 1317 | # CONFIG_NLS_ASCII is not set | ||
| 1318 | # CONFIG_NLS_ISO8859_1 is not set | ||
| 1319 | # CONFIG_NLS_ISO8859_2 is not set | ||
| 1320 | # CONFIG_NLS_ISO8859_3 is not set | ||
| 1321 | # CONFIG_NLS_ISO8859_4 is not set | ||
| 1322 | # CONFIG_NLS_ISO8859_5 is not set | ||
| 1323 | # CONFIG_NLS_ISO8859_6 is not set | ||
| 1324 | # CONFIG_NLS_ISO8859_7 is not set | ||
| 1325 | # CONFIG_NLS_ISO8859_9 is not set | ||
| 1326 | # CONFIG_NLS_ISO8859_13 is not set | ||
| 1327 | # CONFIG_NLS_ISO8859_14 is not set | ||
| 1328 | # CONFIG_NLS_ISO8859_15 is not set | ||
| 1329 | # CONFIG_NLS_KOI8_R is not set | ||
| 1330 | # CONFIG_NLS_KOI8_U is not set | ||
| 1331 | # CONFIG_NLS_UTF8 is not set | ||
| 1266 | # CONFIG_DLM is not set | 1332 | # CONFIG_DLM is not set |
| 1267 | # CONFIG_BINARY_PRINTF is not set | 1333 | # CONFIG_BINARY_PRINTF is not set |
| 1268 | 1334 | ||
| @@ -1285,6 +1351,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1285 | CONFIG_HAS_DMA=y | 1351 | CONFIG_HAS_DMA=y |
| 1286 | CONFIG_HAVE_LMB=y | 1352 | CONFIG_HAVE_LMB=y |
| 1287 | CONFIG_NLATTR=y | 1353 | CONFIG_NLATTR=y |
| 1354 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1288 | 1355 | ||
| 1289 | # | 1356 | # |
| 1290 | # Kernel hacking | 1357 | # Kernel hacking |
| @@ -1308,22 +1375,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1308 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1375 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1309 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1376 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1310 | CONFIG_TRACING_SUPPORT=y | 1377 | CONFIG_TRACING_SUPPORT=y |
| 1311 | 1378 | # CONFIG_FTRACE is not set | |
| 1312 | # | ||
| 1313 | # Tracers | ||
| 1314 | # | ||
| 1315 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1316 | # CONFIG_SCHED_TRACER is not set | ||
| 1317 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1318 | # CONFIG_EVENT_TRACER is not set | ||
| 1319 | # CONFIG_BOOT_TRACER is not set | ||
| 1320 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1321 | # CONFIG_STACK_TRACER is not set | ||
| 1322 | # CONFIG_KMEMTRACE is not set | ||
| 1323 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1324 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1325 | # CONFIG_SAMPLES is not set | 1379 | # CONFIG_SAMPLES is not set |
| 1326 | CONFIG_HAVE_ARCH_KGDB=y | 1380 | CONFIG_HAVE_ARCH_KGDB=y |
| 1381 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1382 | CONFIG_PPC_WERROR=y | ||
| 1327 | CONFIG_PRINT_STACK_DEPTH=64 | 1383 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1328 | # CONFIG_IRQSTACKS is not set | 1384 | # CONFIG_IRQSTACKS is not set |
| 1329 | # CONFIG_BOOTX_TEXT is not set | 1385 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/83xx/sbc834x_defconfig b/arch/powerpc/configs/83xx/sbc834x_defconfig index fe08f672cb27..a592b5efdc4d 100644 --- a/arch/powerpc/configs/83xx/sbc834x_defconfig +++ b/arch/powerpc/configs/83xx/sbc834x_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:15 2009 | 4 | # Wed Jul 29 23:32:13 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_FSL_EMB_PERFMON is not set | 20 | # CONFIG_FSL_EMB_PERFMON is not set |
| 20 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 45 | CONFIG_PPC=y | 48 | CONFIG_PPC=y |
| @@ -53,12 +56,14 @@ CONFIG_PPC_UDBG_16550=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 57 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 61 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| 58 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 59 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 60 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 61 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 62 | 67 | ||
| 63 | # | 68 | # |
| 64 | # General setup | 69 | # General setup |
| @@ -107,7 +112,6 @@ CONFIG_ANON_INODES=y | |||
| 107 | CONFIG_EMBEDDED=y | 112 | CONFIG_EMBEDDED=y |
| 108 | CONFIG_SYSCTL_SYSCALL=y | 113 | CONFIG_SYSCTL_SYSCALL=y |
| 109 | # CONFIG_KALLSYMS is not set | 114 | # CONFIG_KALLSYMS is not set |
| 110 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 111 | CONFIG_HOTPLUG=y | 115 | CONFIG_HOTPLUG=y |
| 112 | CONFIG_PRINTK=y | 116 | CONFIG_PRINTK=y |
| 113 | CONFIG_BUG=y | 117 | CONFIG_BUG=y |
| @@ -120,8 +124,15 @@ CONFIG_TIMERFD=y | |||
| 120 | CONFIG_EVENTFD=y | 124 | CONFIG_EVENTFD=y |
| 121 | CONFIG_SHMEM=y | 125 | CONFIG_SHMEM=y |
| 122 | CONFIG_AIO=y | 126 | CONFIG_AIO=y |
| 127 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 128 | |||
| 129 | # | ||
| 130 | # Performance Counters | ||
| 131 | # | ||
| 132 | # CONFIG_PERF_COUNTERS is not set | ||
| 123 | CONFIG_VM_EVENT_COUNTERS=y | 133 | CONFIG_VM_EVENT_COUNTERS=y |
| 124 | CONFIG_PCI_QUIRKS=y | 134 | CONFIG_PCI_QUIRKS=y |
| 135 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 125 | CONFIG_COMPAT_BRK=y | 136 | CONFIG_COMPAT_BRK=y |
| 126 | CONFIG_SLAB=y | 137 | CONFIG_SLAB=y |
| 127 | # CONFIG_SLUB is not set | 138 | # CONFIG_SLUB is not set |
| @@ -134,6 +145,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 134 | CONFIG_HAVE_KPROBES=y | 145 | CONFIG_HAVE_KPROBES=y |
| 135 | CONFIG_HAVE_KRETPROBES=y | 146 | CONFIG_HAVE_KRETPROBES=y |
| 136 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 147 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 148 | |||
| 149 | # | ||
| 150 | # GCOV-based kernel profiling | ||
| 151 | # | ||
| 137 | # CONFIG_SLOW_WORK is not set | 152 | # CONFIG_SLOW_WORK is not set |
| 138 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 153 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 139 | CONFIG_SLABINFO=y | 154 | CONFIG_SLABINFO=y |
| @@ -146,7 +161,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 146 | # CONFIG_MODVERSIONS is not set | 161 | # CONFIG_MODVERSIONS is not set |
| 147 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 162 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 148 | CONFIG_BLOCK=y | 163 | CONFIG_BLOCK=y |
| 149 | # CONFIG_LBD is not set | 164 | CONFIG_LBDAF=y |
| 150 | # CONFIG_BLK_DEV_BSG is not set | 165 | # CONFIG_BLK_DEV_BSG is not set |
| 151 | # CONFIG_BLK_DEV_INTEGRITY is not set | 166 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 152 | 167 | ||
| @@ -188,6 +203,7 @@ CONFIG_PPC_83xx=y | |||
| 188 | # CONFIG_MPC837x_RDB is not set | 203 | # CONFIG_MPC837x_RDB is not set |
| 189 | CONFIG_SBC834x=y | 204 | CONFIG_SBC834x=y |
| 190 | # CONFIG_ASP834x is not set | 205 | # CONFIG_ASP834x is not set |
| 206 | # CONFIG_KMETER1 is not set | ||
| 191 | CONFIG_PPC_MPC834x=y | 207 | CONFIG_PPC_MPC834x=y |
| 192 | # CONFIG_PPC_86xx is not set | 208 | # CONFIG_PPC_86xx is not set |
| 193 | # CONFIG_EMBEDDED6xx is not set | 209 | # CONFIG_EMBEDDED6xx is not set |
| @@ -232,6 +248,7 @@ CONFIG_BINFMT_ELF=y | |||
| 232 | # CONFIG_HAVE_AOUT is not set | 248 | # CONFIG_HAVE_AOUT is not set |
| 233 | # CONFIG_BINFMT_MISC is not set | 249 | # CONFIG_BINFMT_MISC is not set |
| 234 | # CONFIG_IOMMU_HELPER is not set | 250 | # CONFIG_IOMMU_HELPER is not set |
| 251 | # CONFIG_SWIOTLB is not set | ||
| 235 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 252 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 236 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 253 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 237 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 254 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -252,9 +269,9 @@ CONFIG_MIGRATION=y | |||
| 252 | CONFIG_ZONE_DMA_FLAG=1 | 269 | CONFIG_ZONE_DMA_FLAG=1 |
| 253 | CONFIG_BOUNCE=y | 270 | CONFIG_BOUNCE=y |
| 254 | CONFIG_VIRT_TO_BUS=y | 271 | CONFIG_VIRT_TO_BUS=y |
| 255 | CONFIG_UNEVICTABLE_LRU=y | ||
| 256 | CONFIG_HAVE_MLOCK=y | 272 | CONFIG_HAVE_MLOCK=y |
| 257 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 273 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 274 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 258 | CONFIG_PPC_4K_PAGES=y | 275 | CONFIG_PPC_4K_PAGES=y |
| 259 | # CONFIG_PPC_16K_PAGES is not set | 276 | # CONFIG_PPC_16K_PAGES is not set |
| 260 | # CONFIG_PPC_64K_PAGES is not set | 277 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -363,6 +380,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 363 | # CONFIG_ECONET is not set | 380 | # CONFIG_ECONET is not set |
| 364 | # CONFIG_WAN_ROUTER is not set | 381 | # CONFIG_WAN_ROUTER is not set |
| 365 | # CONFIG_PHONET is not set | 382 | # CONFIG_PHONET is not set |
| 383 | # CONFIG_IEEE802154 is not set | ||
| 366 | # CONFIG_NET_SCHED is not set | 384 | # CONFIG_NET_SCHED is not set |
| 367 | # CONFIG_DCB is not set | 385 | # CONFIG_DCB is not set |
| 368 | 386 | ||
| @@ -380,7 +398,11 @@ CONFIG_WIRELESS=y | |||
| 380 | CONFIG_WIRELESS_OLD_REGULATORY=y | 398 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 381 | # CONFIG_WIRELESS_EXT is not set | 399 | # CONFIG_WIRELESS_EXT is not set |
| 382 | # CONFIG_LIB80211 is not set | 400 | # CONFIG_LIB80211 is not set |
| 383 | # CONFIG_MAC80211 is not set | 401 | |
| 402 | # | ||
| 403 | # CFG80211 needs to be enabled for MAC80211 | ||
| 404 | # | ||
| 405 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 384 | # CONFIG_WIMAX is not set | 406 | # CONFIG_WIMAX is not set |
| 385 | # CONFIG_RFKILL is not set | 407 | # CONFIG_RFKILL is not set |
| 386 | # CONFIG_NET_9P is not set | 408 | # CONFIG_NET_9P is not set |
| @@ -401,6 +423,7 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 401 | # CONFIG_MTD is not set | 423 | # CONFIG_MTD is not set |
| 402 | CONFIG_OF_DEVICE=y | 424 | CONFIG_OF_DEVICE=y |
| 403 | CONFIG_OF_I2C=y | 425 | CONFIG_OF_I2C=y |
| 426 | CONFIG_OF_MDIO=y | ||
| 404 | # CONFIG_PARPORT is not set | 427 | # CONFIG_PARPORT is not set |
| 405 | CONFIG_BLK_DEV=y | 428 | CONFIG_BLK_DEV=y |
| 406 | # CONFIG_BLK_DEV_FD is not set | 429 | # CONFIG_BLK_DEV_FD is not set |
| @@ -435,7 +458,9 @@ CONFIG_MISC_DEVICES=y | |||
| 435 | # | 458 | # |
| 436 | # CONFIG_EEPROM_AT24 is not set | 459 | # CONFIG_EEPROM_AT24 is not set |
| 437 | # CONFIG_EEPROM_LEGACY is not set | 460 | # CONFIG_EEPROM_LEGACY is not set |
| 461 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 438 | # CONFIG_EEPROM_93CX6 is not set | 462 | # CONFIG_EEPROM_93CX6 is not set |
| 463 | # CONFIG_CB710_CORE is not set | ||
| 439 | CONFIG_HAVE_IDE=y | 464 | CONFIG_HAVE_IDE=y |
| 440 | # CONFIG_IDE is not set | 465 | # CONFIG_IDE is not set |
| 441 | 466 | ||
| @@ -455,14 +480,17 @@ CONFIG_HAVE_IDE=y | |||
| 455 | # | 480 | # |
| 456 | 481 | ||
| 457 | # | 482 | # |
| 458 | # Enable only one of the two stacks, unless you know what you are doing | 483 | # You can enable one or both FireWire driver stacks. |
| 484 | # | ||
| 485 | |||
| 486 | # | ||
| 487 | # See the help texts for more information. | ||
| 459 | # | 488 | # |
| 460 | # CONFIG_FIREWIRE is not set | 489 | # CONFIG_FIREWIRE is not set |
| 461 | # CONFIG_IEEE1394 is not set | 490 | # CONFIG_IEEE1394 is not set |
| 462 | # CONFIG_I2O is not set | 491 | # CONFIG_I2O is not set |
| 463 | # CONFIG_MACINTOSH_DRIVERS is not set | 492 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 464 | CONFIG_NETDEVICES=y | 493 | CONFIG_NETDEVICES=y |
| 465 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 466 | # CONFIG_DUMMY is not set | 494 | # CONFIG_DUMMY is not set |
| 467 | # CONFIG_BONDING is not set | 495 | # CONFIG_BONDING is not set |
| 468 | # CONFIG_MACVLAN is not set | 496 | # CONFIG_MACVLAN is not set |
| @@ -509,6 +537,7 @@ CONFIG_MII=y | |||
| 509 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 537 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 510 | # CONFIG_NET_PCI is not set | 538 | # CONFIG_NET_PCI is not set |
| 511 | # CONFIG_B44 is not set | 539 | # CONFIG_B44 is not set |
| 540 | # CONFIG_KS8842 is not set | ||
| 512 | # CONFIG_ATL2 is not set | 541 | # CONFIG_ATL2 is not set |
| 513 | CONFIG_NETDEV_1000=y | 542 | CONFIG_NETDEV_1000=y |
| 514 | # CONFIG_ACENIC is not set | 543 | # CONFIG_ACENIC is not set |
| @@ -528,8 +557,10 @@ CONFIG_NETDEV_1000=y | |||
| 528 | # CONFIG_VIA_VELOCITY is not set | 557 | # CONFIG_VIA_VELOCITY is not set |
| 529 | # CONFIG_TIGON3 is not set | 558 | # CONFIG_TIGON3 is not set |
| 530 | # CONFIG_BNX2 is not set | 559 | # CONFIG_BNX2 is not set |
| 560 | # CONFIG_CNIC is not set | ||
| 531 | CONFIG_FSL_PQ_MDIO=y | 561 | CONFIG_FSL_PQ_MDIO=y |
| 532 | CONFIG_GIANFAR=y | 562 | CONFIG_GIANFAR=y |
| 563 | # CONFIG_MV643XX_ETH is not set | ||
| 533 | # CONFIG_QLA3XXX is not set | 564 | # CONFIG_QLA3XXX is not set |
| 534 | # CONFIG_ATL1 is not set | 565 | # CONFIG_ATL1 is not set |
| 535 | # CONFIG_ATL1E is not set | 566 | # CONFIG_ATL1E is not set |
| @@ -688,13 +719,17 @@ CONFIG_I2C_MPC=y | |||
| 688 | # CONFIG_SENSORS_PCF8574 is not set | 719 | # CONFIG_SENSORS_PCF8574 is not set |
| 689 | # CONFIG_PCF8575 is not set | 720 | # CONFIG_PCF8575 is not set |
| 690 | # CONFIG_SENSORS_PCA9539 is not set | 721 | # CONFIG_SENSORS_PCA9539 is not set |
| 691 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 692 | # CONFIG_SENSORS_TSL2550 is not set | 722 | # CONFIG_SENSORS_TSL2550 is not set |
| 693 | # CONFIG_I2C_DEBUG_CORE is not set | 723 | # CONFIG_I2C_DEBUG_CORE is not set |
| 694 | # CONFIG_I2C_DEBUG_ALGO is not set | 724 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 695 | # CONFIG_I2C_DEBUG_BUS is not set | 725 | # CONFIG_I2C_DEBUG_BUS is not set |
| 696 | # CONFIG_I2C_DEBUG_CHIP is not set | 726 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 697 | # CONFIG_SPI is not set | 727 | # CONFIG_SPI is not set |
| 728 | |||
| 729 | # | ||
| 730 | # PPS support | ||
| 731 | # | ||
| 732 | # CONFIG_PPS is not set | ||
| 698 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 733 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 699 | # CONFIG_GPIOLIB is not set | 734 | # CONFIG_GPIOLIB is not set |
| 700 | # CONFIG_W1 is not set | 735 | # CONFIG_W1 is not set |
| @@ -749,6 +784,7 @@ CONFIG_HWMON=y | |||
| 749 | # CONFIG_SENSORS_SMSC47B397 is not set | 784 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 750 | # CONFIG_SENSORS_ADS7828 is not set | 785 | # CONFIG_SENSORS_ADS7828 is not set |
| 751 | # CONFIG_SENSORS_THMC50 is not set | 786 | # CONFIG_SENSORS_THMC50 is not set |
| 787 | # CONFIG_SENSORS_TMP401 is not set | ||
| 752 | # CONFIG_SENSORS_VIA686A is not set | 788 | # CONFIG_SENSORS_VIA686A is not set |
| 753 | # CONFIG_SENSORS_VT1211 is not set | 789 | # CONFIG_SENSORS_VT1211 is not set |
| 754 | # CONFIG_SENSORS_VT8231 is not set | 790 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -797,23 +833,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 797 | # CONFIG_MFD_WM8400 is not set | 833 | # CONFIG_MFD_WM8400 is not set |
| 798 | # CONFIG_MFD_WM8350_I2C is not set | 834 | # CONFIG_MFD_WM8350_I2C is not set |
| 799 | # CONFIG_MFD_PCF50633 is not set | 835 | # CONFIG_MFD_PCF50633 is not set |
| 836 | # CONFIG_AB3100_CORE is not set | ||
| 800 | # CONFIG_REGULATOR is not set | 837 | # CONFIG_REGULATOR is not set |
| 801 | 838 | # CONFIG_MEDIA_SUPPORT is not set | |
| 802 | # | ||
| 803 | # Multimedia devices | ||
| 804 | # | ||
| 805 | |||
| 806 | # | ||
| 807 | # Multimedia core support | ||
| 808 | # | ||
| 809 | # CONFIG_VIDEO_DEV is not set | ||
| 810 | # CONFIG_DVB_CORE is not set | ||
| 811 | # CONFIG_VIDEO_MEDIA is not set | ||
| 812 | |||
| 813 | # | ||
| 814 | # Multimedia drivers | ||
| 815 | # | ||
| 816 | # CONFIG_DAB is not set | ||
| 817 | 839 | ||
| 818 | # | 840 | # |
| 819 | # Graphics support | 841 | # Graphics support |
| @@ -851,6 +873,10 @@ CONFIG_HID=y | |||
| 851 | # CONFIG_DMADEVICES is not set | 873 | # CONFIG_DMADEVICES is not set |
| 852 | # CONFIG_AUXDISPLAY is not set | 874 | # CONFIG_AUXDISPLAY is not set |
| 853 | # CONFIG_UIO is not set | 875 | # CONFIG_UIO is not set |
| 876 | |||
| 877 | # | ||
| 878 | # TI VLYNQ | ||
| 879 | # | ||
| 854 | # CONFIG_STAGING is not set | 880 | # CONFIG_STAGING is not set |
| 855 | 881 | ||
| 856 | # | 882 | # |
| @@ -862,10 +888,12 @@ CONFIG_HID=y | |||
| 862 | # CONFIG_REISERFS_FS is not set | 888 | # CONFIG_REISERFS_FS is not set |
| 863 | # CONFIG_JFS_FS is not set | 889 | # CONFIG_JFS_FS is not set |
| 864 | # CONFIG_FS_POSIX_ACL is not set | 890 | # CONFIG_FS_POSIX_ACL is not set |
| 865 | CONFIG_FILE_LOCKING=y | ||
| 866 | # CONFIG_XFS_FS is not set | 891 | # CONFIG_XFS_FS is not set |
| 892 | # CONFIG_GFS2_FS is not set | ||
| 867 | # CONFIG_OCFS2_FS is not set | 893 | # CONFIG_OCFS2_FS is not set |
| 868 | # CONFIG_BTRFS_FS is not set | 894 | # CONFIG_BTRFS_FS is not set |
| 895 | CONFIG_FILE_LOCKING=y | ||
| 896 | CONFIG_FSNOTIFY=y | ||
| 869 | CONFIG_DNOTIFY=y | 897 | CONFIG_DNOTIFY=y |
| 870 | CONFIG_INOTIFY=y | 898 | CONFIG_INOTIFY=y |
| 871 | CONFIG_INOTIFY_USER=y | 899 | CONFIG_INOTIFY_USER=y |
| @@ -928,6 +956,7 @@ CONFIG_NFS_FS=y | |||
| 928 | CONFIG_NFS_V3=y | 956 | CONFIG_NFS_V3=y |
| 929 | # CONFIG_NFS_V3_ACL is not set | 957 | # CONFIG_NFS_V3_ACL is not set |
| 930 | CONFIG_NFS_V4=y | 958 | CONFIG_NFS_V4=y |
| 959 | # CONFIG_NFS_V4_1 is not set | ||
| 931 | CONFIG_ROOT_NFS=y | 960 | CONFIG_ROOT_NFS=y |
| 932 | # CONFIG_NFSD is not set | 961 | # CONFIG_NFSD is not set |
| 933 | CONFIG_LOCKD=y | 962 | CONFIG_LOCKD=y |
| @@ -971,6 +1000,7 @@ CONFIG_HAS_IOPORT=y | |||
| 971 | CONFIG_HAS_DMA=y | 1000 | CONFIG_HAS_DMA=y |
| 972 | CONFIG_HAVE_LMB=y | 1001 | CONFIG_HAVE_LMB=y |
| 973 | CONFIG_NLATTR=y | 1002 | CONFIG_NLATTR=y |
| 1003 | CONFIG_GENERIC_ATOMIC64=y | ||
| 974 | 1004 | ||
| 975 | # | 1005 | # |
| 976 | # Kernel hacking | 1006 | # Kernel hacking |
| @@ -994,22 +1024,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 994 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1024 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 995 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1025 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 996 | CONFIG_TRACING_SUPPORT=y | 1026 | CONFIG_TRACING_SUPPORT=y |
| 997 | 1027 | # CONFIG_FTRACE is not set | |
| 998 | # | ||
| 999 | # Tracers | ||
| 1000 | # | ||
| 1001 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1002 | # CONFIG_SCHED_TRACER is not set | ||
| 1003 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1004 | # CONFIG_EVENT_TRACER is not set | ||
| 1005 | # CONFIG_BOOT_TRACER is not set | ||
| 1006 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1007 | # CONFIG_STACK_TRACER is not set | ||
| 1008 | # CONFIG_KMEMTRACE is not set | ||
| 1009 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1010 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1011 | # CONFIG_SAMPLES is not set | 1028 | # CONFIG_SAMPLES is not set |
| 1012 | CONFIG_HAVE_ARCH_KGDB=y | 1029 | CONFIG_HAVE_ARCH_KGDB=y |
| 1030 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1031 | CONFIG_PPC_WERROR=y | ||
| 1013 | CONFIG_PRINT_STACK_DEPTH=64 | 1032 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1014 | # CONFIG_IRQSTACKS is not set | 1033 | # CONFIG_IRQSTACKS is not set |
| 1015 | # CONFIG_BOOTX_TEXT is not set | 1034 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/85xx/ksi8560_defconfig b/arch/powerpc/configs/85xx/ksi8560_defconfig index 09146ddaa3ca..ff04e1028f5e 100644 --- a/arch/powerpc/configs/85xx/ksi8560_defconfig +++ b/arch/powerpc/configs/85xx/ksi8560_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:16 2009 | 4 | # Wed Jul 29 23:32:14 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -34,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 34 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 35 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 36 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 38 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 39 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 41 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 43 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 44 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 45 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 47 | CONFIG_GENERIC_GPIO=y | 48 | CONFIG_GENERIC_GPIO=y |
| 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 49 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -57,11 +58,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 57 | # CONFIG_GENERIC_TBSYNC is not set | 58 | # CONFIG_GENERIC_TBSYNC is not set |
| 58 | CONFIG_AUDIT_ARCH=y | 59 | CONFIG_AUDIT_ARCH=y |
| 59 | CONFIG_GENERIC_BUG=y | 60 | CONFIG_GENERIC_BUG=y |
| 61 | CONFIG_DTC=y | ||
| 60 | CONFIG_DEFAULT_UIMAGE=y | 62 | CONFIG_DEFAULT_UIMAGE=y |
| 61 | # CONFIG_PPC_DCR_NATIVE is not set | 63 | # CONFIG_PPC_DCR_NATIVE is not set |
| 62 | # CONFIG_PPC_DCR_MMIO is not set | 64 | # CONFIG_PPC_DCR_MMIO is not set |
| 63 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 65 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 64 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 66 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 67 | CONFIG_CONSTRUCTORS=y | ||
| 65 | 68 | ||
| 66 | # | 69 | # |
| 67 | # General setup | 70 | # General setup |
| @@ -108,7 +111,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 108 | CONFIG_KALLSYMS=y | 111 | CONFIG_KALLSYMS=y |
| 109 | # CONFIG_KALLSYMS_ALL is not set | 112 | # CONFIG_KALLSYMS_ALL is not set |
| 110 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 113 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 111 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 112 | CONFIG_HOTPLUG=y | 114 | CONFIG_HOTPLUG=y |
| 113 | CONFIG_PRINTK=y | 115 | CONFIG_PRINTK=y |
| 114 | CONFIG_BUG=y | 116 | CONFIG_BUG=y |
| @@ -121,8 +123,15 @@ CONFIG_TIMERFD=y | |||
| 121 | CONFIG_EVENTFD=y | 123 | CONFIG_EVENTFD=y |
| 122 | CONFIG_SHMEM=y | 124 | CONFIG_SHMEM=y |
| 123 | CONFIG_AIO=y | 125 | CONFIG_AIO=y |
| 126 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 127 | |||
| 128 | # | ||
| 129 | # Performance Counters | ||
| 130 | # | ||
| 131 | # CONFIG_PERF_COUNTERS is not set | ||
| 124 | CONFIG_VM_EVENT_COUNTERS=y | 132 | CONFIG_VM_EVENT_COUNTERS=y |
| 125 | CONFIG_SLUB_DEBUG=y | 133 | CONFIG_SLUB_DEBUG=y |
| 134 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 126 | CONFIG_COMPAT_BRK=y | 135 | CONFIG_COMPAT_BRK=y |
| 127 | # CONFIG_SLAB is not set | 136 | # CONFIG_SLAB is not set |
| 128 | CONFIG_SLUB=y | 137 | CONFIG_SLUB=y |
| @@ -136,6 +145,11 @@ CONFIG_HAVE_KPROBES=y | |||
| 136 | CONFIG_HAVE_KRETPROBES=y | 145 | CONFIG_HAVE_KRETPROBES=y |
| 137 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 146 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 138 | CONFIG_HAVE_CLK=y | 147 | CONFIG_HAVE_CLK=y |
| 148 | |||
| 149 | # | ||
| 150 | # GCOV-based kernel profiling | ||
| 151 | # | ||
| 152 | # CONFIG_GCOV_KERNEL is not set | ||
| 139 | # CONFIG_SLOW_WORK is not set | 153 | # CONFIG_SLOW_WORK is not set |
| 140 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 141 | CONFIG_SLABINFO=y | 155 | CONFIG_SLABINFO=y |
| @@ -143,7 +157,7 @@ CONFIG_RT_MUTEXES=y | |||
| 143 | CONFIG_BASE_SMALL=0 | 157 | CONFIG_BASE_SMALL=0 |
| 144 | # CONFIG_MODULES is not set | 158 | # CONFIG_MODULES is not set |
| 145 | CONFIG_BLOCK=y | 159 | CONFIG_BLOCK=y |
| 146 | # CONFIG_LBD is not set | 160 | CONFIG_LBDAF=y |
| 147 | # CONFIG_BLK_DEV_BSG is not set | 161 | # CONFIG_BLK_DEV_BSG is not set |
| 148 | # CONFIG_BLK_DEV_INTEGRITY is not set | 162 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 149 | 163 | ||
| @@ -176,6 +190,7 @@ CONFIG_MPC85xx=y | |||
| 176 | # CONFIG_MPC85xx_DS is not set | 190 | # CONFIG_MPC85xx_DS is not set |
| 177 | # CONFIG_SOCRATES is not set | 191 | # CONFIG_SOCRATES is not set |
| 178 | CONFIG_KSI8560=y | 192 | CONFIG_KSI8560=y |
| 193 | # CONFIG_XES_MPC85xx is not set | ||
| 179 | # CONFIG_STX_GP3 is not set | 194 | # CONFIG_STX_GP3 is not set |
| 180 | # CONFIG_TQM8540 is not set | 195 | # CONFIG_TQM8540 is not set |
| 181 | # CONFIG_TQM8541 is not set | 196 | # CONFIG_TQM8541 is not set |
| @@ -224,6 +239,7 @@ CONFIG_BINFMT_ELF=y | |||
| 224 | CONFIG_BINFMT_MISC=y | 239 | CONFIG_BINFMT_MISC=y |
| 225 | CONFIG_MATH_EMULATION=y | 240 | CONFIG_MATH_EMULATION=y |
| 226 | # CONFIG_IOMMU_HELPER is not set | 241 | # CONFIG_IOMMU_HELPER is not set |
| 242 | # CONFIG_SWIOTLB is not set | ||
| 227 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 243 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 228 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 244 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 229 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 245 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -242,9 +258,9 @@ CONFIG_MIGRATION=y | |||
| 242 | CONFIG_ZONE_DMA_FLAG=1 | 258 | CONFIG_ZONE_DMA_FLAG=1 |
| 243 | CONFIG_BOUNCE=y | 259 | CONFIG_BOUNCE=y |
| 244 | CONFIG_VIRT_TO_BUS=y | 260 | CONFIG_VIRT_TO_BUS=y |
| 245 | CONFIG_UNEVICTABLE_LRU=y | ||
| 246 | CONFIG_HAVE_MLOCK=y | 261 | CONFIG_HAVE_MLOCK=y |
| 247 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 262 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 263 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 248 | CONFIG_PPC_4K_PAGES=y | 264 | CONFIG_PPC_4K_PAGES=y |
| 249 | # CONFIG_PPC_16K_PAGES is not set | 265 | # CONFIG_PPC_16K_PAGES is not set |
| 250 | # CONFIG_PPC_64K_PAGES is not set | 266 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -346,6 +362,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 346 | # CONFIG_ECONET is not set | 362 | # CONFIG_ECONET is not set |
| 347 | # CONFIG_WAN_ROUTER is not set | 363 | # CONFIG_WAN_ROUTER is not set |
| 348 | # CONFIG_PHONET is not set | 364 | # CONFIG_PHONET is not set |
| 365 | # CONFIG_IEEE802154 is not set | ||
| 349 | # CONFIG_NET_SCHED is not set | 366 | # CONFIG_NET_SCHED is not set |
| 350 | # CONFIG_DCB is not set | 367 | # CONFIG_DCB is not set |
| 351 | 368 | ||
| @@ -363,7 +380,11 @@ CONFIG_WIRELESS=y | |||
| 363 | CONFIG_WIRELESS_OLD_REGULATORY=y | 380 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 364 | # CONFIG_WIRELESS_EXT is not set | 381 | # CONFIG_WIRELESS_EXT is not set |
| 365 | # CONFIG_LIB80211 is not set | 382 | # CONFIG_LIB80211 is not set |
| 366 | # CONFIG_MAC80211 is not set | 383 | |
| 384 | # | ||
| 385 | # CFG80211 needs to be enabled for MAC80211 | ||
| 386 | # | ||
| 387 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 367 | # CONFIG_WIMAX is not set | 388 | # CONFIG_WIMAX is not set |
| 368 | # CONFIG_RFKILL is not set | 389 | # CONFIG_RFKILL is not set |
| 369 | # CONFIG_NET_9P is not set | 390 | # CONFIG_NET_9P is not set |
| @@ -466,6 +487,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 466 | # CONFIG_MTD_UBI is not set | 487 | # CONFIG_MTD_UBI is not set |
| 467 | CONFIG_OF_DEVICE=y | 488 | CONFIG_OF_DEVICE=y |
| 468 | CONFIG_OF_GPIO=y | 489 | CONFIG_OF_GPIO=y |
| 490 | CONFIG_OF_MDIO=y | ||
| 469 | # CONFIG_PARPORT is not set | 491 | # CONFIG_PARPORT is not set |
| 470 | CONFIG_BLK_DEV=y | 492 | CONFIG_BLK_DEV=y |
| 471 | # CONFIG_BLK_DEV_FD is not set | 493 | # CONFIG_BLK_DEV_FD is not set |
| @@ -520,7 +542,6 @@ CONFIG_IDE_PROC_FS=y | |||
| 520 | # CONFIG_MD is not set | 542 | # CONFIG_MD is not set |
| 521 | # CONFIG_MACINTOSH_DRIVERS is not set | 543 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 522 | CONFIG_NETDEVICES=y | 544 | CONFIG_NETDEVICES=y |
| 523 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 524 | # CONFIG_DUMMY is not set | 545 | # CONFIG_DUMMY is not set |
| 525 | # CONFIG_BONDING is not set | 546 | # CONFIG_BONDING is not set |
| 526 | # CONFIG_MACVLAN is not set | 547 | # CONFIG_MACVLAN is not set |
| @@ -560,6 +581,7 @@ CONFIG_MII=y | |||
| 560 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 581 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 561 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 582 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 562 | # CONFIG_B44 is not set | 583 | # CONFIG_B44 is not set |
| 584 | # CONFIG_KS8842 is not set | ||
| 563 | CONFIG_FS_ENET=y | 585 | CONFIG_FS_ENET=y |
| 564 | # CONFIG_FS_ENET_HAS_SCC is not set | 586 | # CONFIG_FS_ENET_HAS_SCC is not set |
| 565 | CONFIG_FS_ENET_HAS_FCC=y | 587 | CONFIG_FS_ENET_HAS_FCC=y |
| @@ -567,6 +589,7 @@ CONFIG_FS_ENET_MDIO_FCC=y | |||
| 567 | CONFIG_NETDEV_1000=y | 589 | CONFIG_NETDEV_1000=y |
| 568 | CONFIG_FSL_PQ_MDIO=y | 590 | CONFIG_FSL_PQ_MDIO=y |
| 569 | CONFIG_GIANFAR=y | 591 | CONFIG_GIANFAR=y |
| 592 | # CONFIG_MV643XX_ETH is not set | ||
| 570 | CONFIG_NETDEV_10000=y | 593 | CONFIG_NETDEV_10000=y |
| 571 | 594 | ||
| 572 | # | 595 | # |
| @@ -654,6 +677,11 @@ CONFIG_GEN_RTC=y | |||
| 654 | # CONFIG_TCG_TPM is not set | 677 | # CONFIG_TCG_TPM is not set |
| 655 | # CONFIG_I2C is not set | 678 | # CONFIG_I2C is not set |
| 656 | # CONFIG_SPI is not set | 679 | # CONFIG_SPI is not set |
| 680 | |||
| 681 | # | ||
| 682 | # PPS support | ||
| 683 | # | ||
| 684 | # CONFIG_PPS is not set | ||
| 657 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 685 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 658 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 686 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 659 | CONFIG_GPIOLIB=y | 687 | CONFIG_GPIOLIB=y |
| @@ -710,22 +738,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 710 | # CONFIG_HTC_PASIC3 is not set | 738 | # CONFIG_HTC_PASIC3 is not set |
| 711 | # CONFIG_MFD_TMIO is not set | 739 | # CONFIG_MFD_TMIO is not set |
| 712 | # CONFIG_REGULATOR is not set | 740 | # CONFIG_REGULATOR is not set |
| 713 | 741 | # CONFIG_MEDIA_SUPPORT is not set | |
| 714 | # | ||
| 715 | # Multimedia devices | ||
| 716 | # | ||
| 717 | |||
| 718 | # | ||
| 719 | # Multimedia core support | ||
| 720 | # | ||
| 721 | # CONFIG_VIDEO_DEV is not set | ||
| 722 | # CONFIG_DVB_CORE is not set | ||
| 723 | # CONFIG_VIDEO_MEDIA is not set | ||
| 724 | |||
| 725 | # | ||
| 726 | # Multimedia drivers | ||
| 727 | # | ||
| 728 | CONFIG_DAB=y | ||
| 729 | 742 | ||
| 730 | # | 743 | # |
| 731 | # Graphics support | 744 | # Graphics support |
| @@ -777,6 +790,10 @@ CONFIG_USB_SUPPORT=y | |||
| 777 | # CONFIG_DMADEVICES is not set | 790 | # CONFIG_DMADEVICES is not set |
| 778 | # CONFIG_AUXDISPLAY is not set | 791 | # CONFIG_AUXDISPLAY is not set |
| 779 | # CONFIG_UIO is not set | 792 | # CONFIG_UIO is not set |
| 793 | |||
| 794 | # | ||
| 795 | # TI VLYNQ | ||
| 796 | # | ||
| 780 | # CONFIG_STAGING is not set | 797 | # CONFIG_STAGING is not set |
| 781 | 798 | ||
| 782 | # | 799 | # |
| @@ -797,10 +814,12 @@ CONFIG_FS_MBCACHE=y | |||
| 797 | # CONFIG_REISERFS_FS is not set | 814 | # CONFIG_REISERFS_FS is not set |
| 798 | # CONFIG_JFS_FS is not set | 815 | # CONFIG_JFS_FS is not set |
| 799 | # CONFIG_FS_POSIX_ACL is not set | 816 | # CONFIG_FS_POSIX_ACL is not set |
| 800 | CONFIG_FILE_LOCKING=y | ||
| 801 | # CONFIG_XFS_FS is not set | 817 | # CONFIG_XFS_FS is not set |
| 818 | # CONFIG_GFS2_FS is not set | ||
| 802 | # CONFIG_OCFS2_FS is not set | 819 | # CONFIG_OCFS2_FS is not set |
| 803 | # CONFIG_BTRFS_FS is not set | 820 | # CONFIG_BTRFS_FS is not set |
| 821 | CONFIG_FILE_LOCKING=y | ||
| 822 | CONFIG_FSNOTIFY=y | ||
| 804 | CONFIG_DNOTIFY=y | 823 | CONFIG_DNOTIFY=y |
| 805 | CONFIG_INOTIFY=y | 824 | CONFIG_INOTIFY=y |
| 806 | CONFIG_INOTIFY_USER=y | 825 | CONFIG_INOTIFY_USER=y |
| @@ -916,6 +935,7 @@ CONFIG_HAS_IOPORT=y | |||
| 916 | CONFIG_HAS_DMA=y | 935 | CONFIG_HAS_DMA=y |
| 917 | CONFIG_HAVE_LMB=y | 936 | CONFIG_HAVE_LMB=y |
| 918 | CONFIG_NLATTR=y | 937 | CONFIG_NLATTR=y |
| 938 | CONFIG_GENERIC_ATOMIC64=y | ||
| 919 | 939 | ||
| 920 | # | 940 | # |
| 921 | # Kernel hacking | 941 | # Kernel hacking |
| @@ -946,6 +966,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 946 | # CONFIG_RT_MUTEX_TESTER is not set | 966 | # CONFIG_RT_MUTEX_TESTER is not set |
| 947 | # CONFIG_DEBUG_SPINLOCK is not set | 967 | # CONFIG_DEBUG_SPINLOCK is not set |
| 948 | CONFIG_DEBUG_MUTEXES=y | 968 | CONFIG_DEBUG_MUTEXES=y |
| 969 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 970 | # CONFIG_PROVE_LOCKING is not set | ||
| 971 | # CONFIG_LOCK_STAT is not set | ||
| 949 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 972 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 950 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 973 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 951 | # CONFIG_DEBUG_KOBJECT is not set | 974 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -958,7 +981,6 @@ CONFIG_DEBUG_MUTEXES=y | |||
| 958 | # CONFIG_DEBUG_LIST is not set | 981 | # CONFIG_DEBUG_LIST is not set |
| 959 | # CONFIG_DEBUG_SG is not set | 982 | # CONFIG_DEBUG_SG is not set |
| 960 | # CONFIG_DEBUG_NOTIFIERS is not set | 983 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 961 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 962 | # CONFIG_RCU_TORTURE_TEST is not set | 984 | # CONFIG_RCU_TORTURE_TEST is not set |
| 963 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 985 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 964 | # CONFIG_BACKTRACE_SELF_TEST is not set | 986 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -972,16 +994,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 972 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 994 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 973 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 995 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 974 | CONFIG_TRACING_SUPPORT=y | 996 | CONFIG_TRACING_SUPPORT=y |
| 975 | 997 | CONFIG_FTRACE=y | |
| 976 | # | ||
| 977 | # Tracers | ||
| 978 | # | ||
| 979 | # CONFIG_FUNCTION_TRACER is not set | 998 | # CONFIG_FUNCTION_TRACER is not set |
| 999 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 980 | # CONFIG_SCHED_TRACER is not set | 1000 | # CONFIG_SCHED_TRACER is not set |
| 981 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1001 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 982 | # CONFIG_EVENT_TRACER is not set | ||
| 983 | # CONFIG_BOOT_TRACER is not set | 1002 | # CONFIG_BOOT_TRACER is not set |
| 984 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1003 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1004 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1005 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 985 | # CONFIG_STACK_TRACER is not set | 1006 | # CONFIG_STACK_TRACER is not set |
| 986 | # CONFIG_KMEMTRACE is not set | 1007 | # CONFIG_KMEMTRACE is not set |
| 987 | # CONFIG_WORKQUEUE_TRACER is not set | 1008 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -990,9 +1011,13 @@ CONFIG_TRACING_SUPPORT=y | |||
| 990 | # CONFIG_SAMPLES is not set | 1011 | # CONFIG_SAMPLES is not set |
| 991 | CONFIG_HAVE_ARCH_KGDB=y | 1012 | CONFIG_HAVE_ARCH_KGDB=y |
| 992 | # CONFIG_KGDB is not set | 1013 | # CONFIG_KGDB is not set |
| 1014 | # CONFIG_KMEMCHECK is not set | ||
| 1015 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1016 | CONFIG_PPC_WERROR=y | ||
| 993 | CONFIG_PRINT_STACK_DEPTH=64 | 1017 | CONFIG_PRINT_STACK_DEPTH=64 |
| 994 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1018 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 995 | # CONFIG_DEBUG_STACK_USAGE is not set | 1019 | # CONFIG_DEBUG_STACK_USAGE is not set |
| 1020 | # CONFIG_PPC_EMULATED_STATS is not set | ||
| 996 | # CONFIG_CODE_PATCHING_SELFTEST is not set | 1021 | # CONFIG_CODE_PATCHING_SELFTEST is not set |
| 997 | # CONFIG_FTR_FIXUP_SELFTEST is not set | 1022 | # CONFIG_FTR_FIXUP_SELFTEST is not set |
| 998 | # CONFIG_MSI_BITMAP_SELFTEST is not set | 1023 | # CONFIG_MSI_BITMAP_SELFTEST is not set |
diff --git a/arch/powerpc/configs/85xx/mpc8540_ads_defconfig b/arch/powerpc/configs/85xx/mpc8540_ads_defconfig index 7b43be7586b6..fb10cc83702e 100644 --- a/arch/powerpc/configs/85xx/mpc8540_ads_defconfig +++ b/arch/powerpc/configs/85xx/mpc8540_ads_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:17 2009 | 4 | # Wed Jul 29 23:32:15 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -34,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 34 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 35 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 36 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 38 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 39 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 41 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 43 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 44 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 45 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 48 | CONFIG_PPC=y | 49 | CONFIG_PPC=y |
| @@ -56,11 +57,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 56 | # CONFIG_GENERIC_TBSYNC is not set | 57 | # CONFIG_GENERIC_TBSYNC is not set |
| 57 | CONFIG_AUDIT_ARCH=y | 58 | CONFIG_AUDIT_ARCH=y |
| 58 | CONFIG_GENERIC_BUG=y | 59 | CONFIG_GENERIC_BUG=y |
| 60 | CONFIG_DTC=y | ||
| 59 | CONFIG_DEFAULT_UIMAGE=y | 61 | CONFIG_DEFAULT_UIMAGE=y |
| 60 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 61 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 62 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 63 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 64 | 67 | ||
| 65 | # | 68 | # |
| 66 | # General setup | 69 | # General setup |
| @@ -111,7 +114,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 111 | CONFIG_KALLSYMS=y | 114 | CONFIG_KALLSYMS=y |
| 112 | # CONFIG_KALLSYMS_ALL is not set | 115 | # CONFIG_KALLSYMS_ALL is not set |
| 113 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 116 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 114 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 115 | CONFIG_HOTPLUG=y | 117 | CONFIG_HOTPLUG=y |
| 116 | CONFIG_PRINTK=y | 118 | CONFIG_PRINTK=y |
| 117 | CONFIG_BUG=y | 119 | CONFIG_BUG=y |
| @@ -124,8 +126,15 @@ CONFIG_TIMERFD=y | |||
| 124 | CONFIG_EVENTFD=y | 126 | CONFIG_EVENTFD=y |
| 125 | CONFIG_SHMEM=y | 127 | CONFIG_SHMEM=y |
| 126 | CONFIG_AIO=y | 128 | CONFIG_AIO=y |
| 129 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 130 | |||
| 131 | # | ||
| 132 | # Performance Counters | ||
| 133 | # | ||
| 134 | # CONFIG_PERF_COUNTERS is not set | ||
| 127 | CONFIG_VM_EVENT_COUNTERS=y | 135 | CONFIG_VM_EVENT_COUNTERS=y |
| 128 | CONFIG_SLUB_DEBUG=y | 136 | CONFIG_SLUB_DEBUG=y |
| 137 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 129 | CONFIG_COMPAT_BRK=y | 138 | CONFIG_COMPAT_BRK=y |
| 130 | # CONFIG_SLAB is not set | 139 | # CONFIG_SLAB is not set |
| 131 | CONFIG_SLUB=y | 140 | CONFIG_SLUB=y |
| @@ -138,6 +147,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 138 | CONFIG_HAVE_KPROBES=y | 147 | CONFIG_HAVE_KPROBES=y |
| 139 | CONFIG_HAVE_KRETPROBES=y | 148 | CONFIG_HAVE_KRETPROBES=y |
| 140 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 149 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 150 | |||
| 151 | # | ||
| 152 | # GCOV-based kernel profiling | ||
| 153 | # | ||
| 141 | # CONFIG_SLOW_WORK is not set | 154 | # CONFIG_SLOW_WORK is not set |
| 142 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 155 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 143 | CONFIG_SLABINFO=y | 156 | CONFIG_SLABINFO=y |
| @@ -145,7 +158,7 @@ CONFIG_RT_MUTEXES=y | |||
| 145 | CONFIG_BASE_SMALL=0 | 158 | CONFIG_BASE_SMALL=0 |
| 146 | # CONFIG_MODULES is not set | 159 | # CONFIG_MODULES is not set |
| 147 | CONFIG_BLOCK=y | 160 | CONFIG_BLOCK=y |
| 148 | # CONFIG_LBD is not set | 161 | CONFIG_LBDAF=y |
| 149 | # CONFIG_BLK_DEV_BSG is not set | 162 | # CONFIG_BLK_DEV_BSG is not set |
| 150 | # CONFIG_BLK_DEV_INTEGRITY is not set | 163 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 151 | 164 | ||
| @@ -178,6 +191,7 @@ CONFIG_MPC8540_ADS=y | |||
| 178 | # CONFIG_MPC85xx_DS is not set | 191 | # CONFIG_MPC85xx_DS is not set |
| 179 | # CONFIG_SOCRATES is not set | 192 | # CONFIG_SOCRATES is not set |
| 180 | # CONFIG_KSI8560 is not set | 193 | # CONFIG_KSI8560 is not set |
| 194 | # CONFIG_XES_MPC85xx is not set | ||
| 181 | # CONFIG_STX_GP3 is not set | 195 | # CONFIG_STX_GP3 is not set |
| 182 | # CONFIG_TQM8540 is not set | 196 | # CONFIG_TQM8540 is not set |
| 183 | # CONFIG_TQM8541 is not set | 197 | # CONFIG_TQM8541 is not set |
| @@ -226,6 +240,7 @@ CONFIG_BINFMT_ELF=y | |||
| 226 | CONFIG_BINFMT_MISC=y | 240 | CONFIG_BINFMT_MISC=y |
| 227 | CONFIG_MATH_EMULATION=y | 241 | CONFIG_MATH_EMULATION=y |
| 228 | # CONFIG_IOMMU_HELPER is not set | 242 | # CONFIG_IOMMU_HELPER is not set |
| 243 | # CONFIG_SWIOTLB is not set | ||
| 229 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 244 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 230 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 245 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 231 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 246 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -244,9 +259,9 @@ CONFIG_MIGRATION=y | |||
| 244 | CONFIG_ZONE_DMA_FLAG=1 | 259 | CONFIG_ZONE_DMA_FLAG=1 |
| 245 | CONFIG_BOUNCE=y | 260 | CONFIG_BOUNCE=y |
| 246 | CONFIG_VIRT_TO_BUS=y | 261 | CONFIG_VIRT_TO_BUS=y |
| 247 | CONFIG_UNEVICTABLE_LRU=y | ||
| 248 | CONFIG_HAVE_MLOCK=y | 262 | CONFIG_HAVE_MLOCK=y |
| 249 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 263 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 264 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 250 | CONFIG_PPC_4K_PAGES=y | 265 | CONFIG_PPC_4K_PAGES=y |
| 251 | # CONFIG_PPC_16K_PAGES is not set | 266 | # CONFIG_PPC_16K_PAGES is not set |
| 252 | # CONFIG_PPC_64K_PAGES is not set | 267 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -348,6 +363,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 348 | # CONFIG_ECONET is not set | 363 | # CONFIG_ECONET is not set |
| 349 | # CONFIG_WAN_ROUTER is not set | 364 | # CONFIG_WAN_ROUTER is not set |
| 350 | # CONFIG_PHONET is not set | 365 | # CONFIG_PHONET is not set |
| 366 | # CONFIG_IEEE802154 is not set | ||
| 351 | # CONFIG_NET_SCHED is not set | 367 | # CONFIG_NET_SCHED is not set |
| 352 | # CONFIG_DCB is not set | 368 | # CONFIG_DCB is not set |
| 353 | 369 | ||
| @@ -365,7 +381,11 @@ CONFIG_WIRELESS=y | |||
| 365 | CONFIG_WIRELESS_OLD_REGULATORY=y | 381 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 366 | # CONFIG_WIRELESS_EXT is not set | 382 | # CONFIG_WIRELESS_EXT is not set |
| 367 | # CONFIG_LIB80211 is not set | 383 | # CONFIG_LIB80211 is not set |
| 368 | # CONFIG_MAC80211 is not set | 384 | |
| 385 | # | ||
| 386 | # CFG80211 needs to be enabled for MAC80211 | ||
| 387 | # | ||
| 388 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 369 | # CONFIG_WIMAX is not set | 389 | # CONFIG_WIMAX is not set |
| 370 | # CONFIG_RFKILL is not set | 390 | # CONFIG_RFKILL is not set |
| 371 | # CONFIG_NET_9P is not set | 391 | # CONFIG_NET_9P is not set |
| @@ -387,6 +407,7 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 387 | # CONFIG_CONNECTOR is not set | 407 | # CONFIG_CONNECTOR is not set |
| 388 | # CONFIG_MTD is not set | 408 | # CONFIG_MTD is not set |
| 389 | CONFIG_OF_DEVICE=y | 409 | CONFIG_OF_DEVICE=y |
| 410 | CONFIG_OF_MDIO=y | ||
| 390 | # CONFIG_PARPORT is not set | 411 | # CONFIG_PARPORT is not set |
| 391 | CONFIG_BLK_DEV=y | 412 | CONFIG_BLK_DEV=y |
| 392 | # CONFIG_BLK_DEV_FD is not set | 413 | # CONFIG_BLK_DEV_FD is not set |
| @@ -423,7 +444,6 @@ CONFIG_HAVE_IDE=y | |||
| 423 | # CONFIG_MD is not set | 444 | # CONFIG_MD is not set |
| 424 | # CONFIG_MACINTOSH_DRIVERS is not set | 445 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 425 | CONFIG_NETDEVICES=y | 446 | CONFIG_NETDEVICES=y |
| 426 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 427 | # CONFIG_DUMMY is not set | 447 | # CONFIG_DUMMY is not set |
| 428 | # CONFIG_BONDING is not set | 448 | # CONFIG_BONDING is not set |
| 429 | # CONFIG_MACVLAN is not set | 449 | # CONFIG_MACVLAN is not set |
| @@ -462,9 +482,11 @@ CONFIG_MII=y | |||
| 462 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 482 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 463 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 483 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 464 | # CONFIG_B44 is not set | 484 | # CONFIG_B44 is not set |
| 485 | # CONFIG_KS8842 is not set | ||
| 465 | CONFIG_NETDEV_1000=y | 486 | CONFIG_NETDEV_1000=y |
| 466 | CONFIG_FSL_PQ_MDIO=y | 487 | CONFIG_FSL_PQ_MDIO=y |
| 467 | CONFIG_GIANFAR=y | 488 | CONFIG_GIANFAR=y |
| 489 | # CONFIG_MV643XX_ETH is not set | ||
| 468 | CONFIG_NETDEV_10000=y | 490 | CONFIG_NETDEV_10000=y |
| 469 | 491 | ||
| 470 | # | 492 | # |
| @@ -555,6 +577,11 @@ CONFIG_GEN_RTC=y | |||
| 555 | # CONFIG_TCG_TPM is not set | 577 | # CONFIG_TCG_TPM is not set |
| 556 | # CONFIG_I2C is not set | 578 | # CONFIG_I2C is not set |
| 557 | # CONFIG_SPI is not set | 579 | # CONFIG_SPI is not set |
| 580 | |||
| 581 | # | ||
| 582 | # PPS support | ||
| 583 | # | ||
| 584 | # CONFIG_PPS is not set | ||
| 558 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 585 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 559 | # CONFIG_GPIOLIB is not set | 586 | # CONFIG_GPIOLIB is not set |
| 560 | # CONFIG_W1 is not set | 587 | # CONFIG_W1 is not set |
| @@ -590,22 +617,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 590 | # CONFIG_HTC_PASIC3 is not set | 617 | # CONFIG_HTC_PASIC3 is not set |
| 591 | # CONFIG_MFD_TMIO is not set | 618 | # CONFIG_MFD_TMIO is not set |
| 592 | # CONFIG_REGULATOR is not set | 619 | # CONFIG_REGULATOR is not set |
| 593 | 620 | # CONFIG_MEDIA_SUPPORT is not set | |
| 594 | # | ||
| 595 | # Multimedia devices | ||
| 596 | # | ||
| 597 | |||
| 598 | # | ||
| 599 | # Multimedia core support | ||
| 600 | # | ||
| 601 | # CONFIG_VIDEO_DEV is not set | ||
| 602 | # CONFIG_DVB_CORE is not set | ||
| 603 | # CONFIG_VIDEO_MEDIA is not set | ||
| 604 | |||
| 605 | # | ||
| 606 | # Multimedia drivers | ||
| 607 | # | ||
| 608 | CONFIG_DAB=y | ||
| 609 | 621 | ||
| 610 | # | 622 | # |
| 611 | # Graphics support | 623 | # Graphics support |
| @@ -657,6 +669,10 @@ CONFIG_USB_SUPPORT=y | |||
| 657 | # CONFIG_DMADEVICES is not set | 669 | # CONFIG_DMADEVICES is not set |
| 658 | # CONFIG_AUXDISPLAY is not set | 670 | # CONFIG_AUXDISPLAY is not set |
| 659 | # CONFIG_UIO is not set | 671 | # CONFIG_UIO is not set |
| 672 | |||
| 673 | # | ||
| 674 | # TI VLYNQ | ||
| 675 | # | ||
| 660 | # CONFIG_STAGING is not set | 676 | # CONFIG_STAGING is not set |
| 661 | 677 | ||
| 662 | # | 678 | # |
| @@ -676,10 +692,12 @@ CONFIG_FS_MBCACHE=y | |||
| 676 | # CONFIG_REISERFS_FS is not set | 692 | # CONFIG_REISERFS_FS is not set |
| 677 | # CONFIG_JFS_FS is not set | 693 | # CONFIG_JFS_FS is not set |
| 678 | # CONFIG_FS_POSIX_ACL is not set | 694 | # CONFIG_FS_POSIX_ACL is not set |
| 679 | CONFIG_FILE_LOCKING=y | ||
| 680 | # CONFIG_XFS_FS is not set | 695 | # CONFIG_XFS_FS is not set |
| 696 | # CONFIG_GFS2_FS is not set | ||
| 681 | # CONFIG_OCFS2_FS is not set | 697 | # CONFIG_OCFS2_FS is not set |
| 682 | # CONFIG_BTRFS_FS is not set | 698 | # CONFIG_BTRFS_FS is not set |
| 699 | CONFIG_FILE_LOCKING=y | ||
| 700 | CONFIG_FSNOTIFY=y | ||
| 683 | CONFIG_DNOTIFY=y | 701 | CONFIG_DNOTIFY=y |
| 684 | CONFIG_INOTIFY=y | 702 | CONFIG_INOTIFY=y |
| 685 | CONFIG_INOTIFY_USER=y | 703 | CONFIG_INOTIFY_USER=y |
| @@ -794,6 +812,7 @@ CONFIG_HAS_IOPORT=y | |||
| 794 | CONFIG_HAS_DMA=y | 812 | CONFIG_HAS_DMA=y |
| 795 | CONFIG_HAVE_LMB=y | 813 | CONFIG_HAVE_LMB=y |
| 796 | CONFIG_NLATTR=y | 814 | CONFIG_NLATTR=y |
| 815 | CONFIG_GENERIC_ATOMIC64=y | ||
| 797 | 816 | ||
| 798 | # | 817 | # |
| 799 | # Kernel hacking | 818 | # Kernel hacking |
| @@ -824,6 +843,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 824 | # CONFIG_RT_MUTEX_TESTER is not set | 843 | # CONFIG_RT_MUTEX_TESTER is not set |
| 825 | # CONFIG_DEBUG_SPINLOCK is not set | 844 | # CONFIG_DEBUG_SPINLOCK is not set |
| 826 | CONFIG_DEBUG_MUTEXES=y | 845 | CONFIG_DEBUG_MUTEXES=y |
| 846 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 847 | # CONFIG_PROVE_LOCKING is not set | ||
| 848 | # CONFIG_LOCK_STAT is not set | ||
| 827 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 849 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 828 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 850 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 829 | # CONFIG_DEBUG_KOBJECT is not set | 851 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -835,7 +857,6 @@ CONFIG_DEBUG_MUTEXES=y | |||
| 835 | # CONFIG_DEBUG_LIST is not set | 857 | # CONFIG_DEBUG_LIST is not set |
| 836 | # CONFIG_DEBUG_SG is not set | 858 | # CONFIG_DEBUG_SG is not set |
| 837 | # CONFIG_DEBUG_NOTIFIERS is not set | 859 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 838 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 839 | # CONFIG_RCU_TORTURE_TEST is not set | 860 | # CONFIG_RCU_TORTURE_TEST is not set |
| 840 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 861 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 841 | # CONFIG_BACKTRACE_SELF_TEST is not set | 862 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -849,16 +870,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 849 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 870 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 850 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 871 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 851 | CONFIG_TRACING_SUPPORT=y | 872 | CONFIG_TRACING_SUPPORT=y |
| 852 | 873 | CONFIG_FTRACE=y | |
| 853 | # | ||
| 854 | # Tracers | ||
| 855 | # | ||
| 856 | # CONFIG_FUNCTION_TRACER is not set | 874 | # CONFIG_FUNCTION_TRACER is not set |
| 875 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 857 | # CONFIG_SCHED_TRACER is not set | 876 | # CONFIG_SCHED_TRACER is not set |
| 858 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 877 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 859 | # CONFIG_EVENT_TRACER is not set | ||
| 860 | # CONFIG_BOOT_TRACER is not set | 878 | # CONFIG_BOOT_TRACER is not set |
| 861 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 879 | CONFIG_BRANCH_PROFILE_NONE=y |
| 880 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 881 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 862 | # CONFIG_STACK_TRACER is not set | 882 | # CONFIG_STACK_TRACER is not set |
| 863 | # CONFIG_KMEMTRACE is not set | 883 | # CONFIG_KMEMTRACE is not set |
| 864 | # CONFIG_WORKQUEUE_TRACER is not set | 884 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -866,6 +886,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 866 | # CONFIG_SAMPLES is not set | 886 | # CONFIG_SAMPLES is not set |
| 867 | CONFIG_HAVE_ARCH_KGDB=y | 887 | CONFIG_HAVE_ARCH_KGDB=y |
| 868 | # CONFIG_KGDB is not set | 888 | # CONFIG_KGDB is not set |
| 889 | # CONFIG_KMEMCHECK is not set | ||
| 890 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 891 | CONFIG_PPC_WERROR=y | ||
| 869 | CONFIG_PRINT_STACK_DEPTH=64 | 892 | CONFIG_PRINT_STACK_DEPTH=64 |
| 870 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 893 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 871 | # CONFIG_DEBUG_STACK_USAGE is not set | 894 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/85xx/mpc8560_ads_defconfig b/arch/powerpc/configs/85xx/mpc8560_ads_defconfig index 62adb71a5d4f..5c8ce6978825 100644 --- a/arch/powerpc/configs/85xx/mpc8560_ads_defconfig +++ b/arch/powerpc/configs/85xx/mpc8560_ads_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:17 2009 | 4 | # Wed Jul 29 23:32:16 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -34,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 34 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 35 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 36 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 38 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 39 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 41 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 43 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 44 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 45 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 47 | CONFIG_GENERIC_GPIO=y | 48 | CONFIG_GENERIC_GPIO=y |
| 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 49 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -57,11 +58,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 57 | # CONFIG_GENERIC_TBSYNC is not set | 58 | # CONFIG_GENERIC_TBSYNC is not set |
| 58 | CONFIG_AUDIT_ARCH=y | 59 | CONFIG_AUDIT_ARCH=y |
| 59 | CONFIG_GENERIC_BUG=y | 60 | CONFIG_GENERIC_BUG=y |
| 61 | CONFIG_DTC=y | ||
| 60 | CONFIG_DEFAULT_UIMAGE=y | 62 | CONFIG_DEFAULT_UIMAGE=y |
| 61 | # CONFIG_PPC_DCR_NATIVE is not set | 63 | # CONFIG_PPC_DCR_NATIVE is not set |
| 62 | # CONFIG_PPC_DCR_MMIO is not set | 64 | # CONFIG_PPC_DCR_MMIO is not set |
| 63 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 65 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 64 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 66 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 67 | CONFIG_CONSTRUCTORS=y | ||
| 65 | 68 | ||
| 66 | # | 69 | # |
| 67 | # General setup | 70 | # General setup |
| @@ -112,7 +115,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 112 | CONFIG_KALLSYMS=y | 115 | CONFIG_KALLSYMS=y |
| 113 | # CONFIG_KALLSYMS_ALL is not set | 116 | # CONFIG_KALLSYMS_ALL is not set |
| 114 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 117 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 115 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 116 | CONFIG_HOTPLUG=y | 118 | CONFIG_HOTPLUG=y |
| 117 | CONFIG_PRINTK=y | 119 | CONFIG_PRINTK=y |
| 118 | CONFIG_BUG=y | 120 | CONFIG_BUG=y |
| @@ -125,9 +127,16 @@ CONFIG_TIMERFD=y | |||
| 125 | CONFIG_EVENTFD=y | 127 | CONFIG_EVENTFD=y |
| 126 | CONFIG_SHMEM=y | 128 | CONFIG_SHMEM=y |
| 127 | CONFIG_AIO=y | 129 | CONFIG_AIO=y |
| 130 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 131 | |||
| 132 | # | ||
| 133 | # Performance Counters | ||
| 134 | # | ||
| 135 | # CONFIG_PERF_COUNTERS is not set | ||
| 128 | CONFIG_VM_EVENT_COUNTERS=y | 136 | CONFIG_VM_EVENT_COUNTERS=y |
| 129 | CONFIG_PCI_QUIRKS=y | 137 | CONFIG_PCI_QUIRKS=y |
| 130 | CONFIG_SLUB_DEBUG=y | 138 | CONFIG_SLUB_DEBUG=y |
| 139 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 131 | CONFIG_COMPAT_BRK=y | 140 | CONFIG_COMPAT_BRK=y |
| 132 | # CONFIG_SLAB is not set | 141 | # CONFIG_SLAB is not set |
| 133 | CONFIG_SLUB=y | 142 | CONFIG_SLUB=y |
| @@ -141,6 +150,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 141 | CONFIG_HAVE_KRETPROBES=y | 150 | CONFIG_HAVE_KRETPROBES=y |
| 142 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 151 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 143 | CONFIG_HAVE_CLK=y | 152 | CONFIG_HAVE_CLK=y |
| 153 | |||
| 154 | # | ||
| 155 | # GCOV-based kernel profiling | ||
| 156 | # | ||
| 144 | # CONFIG_SLOW_WORK is not set | 157 | # CONFIG_SLOW_WORK is not set |
| 145 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 158 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 146 | CONFIG_SLABINFO=y | 159 | CONFIG_SLABINFO=y |
| @@ -148,7 +161,7 @@ CONFIG_RT_MUTEXES=y | |||
| 148 | CONFIG_BASE_SMALL=0 | 161 | CONFIG_BASE_SMALL=0 |
| 149 | # CONFIG_MODULES is not set | 162 | # CONFIG_MODULES is not set |
| 150 | CONFIG_BLOCK=y | 163 | CONFIG_BLOCK=y |
| 151 | # CONFIG_LBD is not set | 164 | CONFIG_LBDAF=y |
| 152 | # CONFIG_BLK_DEV_BSG is not set | 165 | # CONFIG_BLK_DEV_BSG is not set |
| 153 | # CONFIG_BLK_DEV_INTEGRITY is not set | 166 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 154 | 167 | ||
| @@ -181,6 +194,7 @@ CONFIG_MPC8560_ADS=y | |||
| 181 | # CONFIG_MPC85xx_DS is not set | 194 | # CONFIG_MPC85xx_DS is not set |
| 182 | # CONFIG_SOCRATES is not set | 195 | # CONFIG_SOCRATES is not set |
| 183 | # CONFIG_KSI8560 is not set | 196 | # CONFIG_KSI8560 is not set |
| 197 | # CONFIG_XES_MPC85xx is not set | ||
| 184 | # CONFIG_STX_GP3 is not set | 198 | # CONFIG_STX_GP3 is not set |
| 185 | # CONFIG_TQM8540 is not set | 199 | # CONFIG_TQM8540 is not set |
| 186 | # CONFIG_TQM8541 is not set | 200 | # CONFIG_TQM8541 is not set |
| @@ -229,6 +243,7 @@ CONFIG_BINFMT_ELF=y | |||
| 229 | CONFIG_BINFMT_MISC=y | 243 | CONFIG_BINFMT_MISC=y |
| 230 | CONFIG_MATH_EMULATION=y | 244 | CONFIG_MATH_EMULATION=y |
| 231 | # CONFIG_IOMMU_HELPER is not set | 245 | # CONFIG_IOMMU_HELPER is not set |
| 246 | # CONFIG_SWIOTLB is not set | ||
| 232 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 247 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 233 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 248 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 234 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 249 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -247,9 +262,9 @@ CONFIG_MIGRATION=y | |||
| 247 | CONFIG_ZONE_DMA_FLAG=1 | 262 | CONFIG_ZONE_DMA_FLAG=1 |
| 248 | CONFIG_BOUNCE=y | 263 | CONFIG_BOUNCE=y |
| 249 | CONFIG_VIRT_TO_BUS=y | 264 | CONFIG_VIRT_TO_BUS=y |
| 250 | CONFIG_UNEVICTABLE_LRU=y | ||
| 251 | CONFIG_HAVE_MLOCK=y | 265 | CONFIG_HAVE_MLOCK=y |
| 252 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 266 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 267 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 253 | CONFIG_PPC_4K_PAGES=y | 268 | CONFIG_PPC_4K_PAGES=y |
| 254 | # CONFIG_PPC_16K_PAGES is not set | 269 | # CONFIG_PPC_16K_PAGES is not set |
| 255 | # CONFIG_PPC_64K_PAGES is not set | 270 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -360,6 +375,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 360 | # CONFIG_ECONET is not set | 375 | # CONFIG_ECONET is not set |
| 361 | # CONFIG_WAN_ROUTER is not set | 376 | # CONFIG_WAN_ROUTER is not set |
| 362 | # CONFIG_PHONET is not set | 377 | # CONFIG_PHONET is not set |
| 378 | # CONFIG_IEEE802154 is not set | ||
| 363 | # CONFIG_NET_SCHED is not set | 379 | # CONFIG_NET_SCHED is not set |
| 364 | # CONFIG_DCB is not set | 380 | # CONFIG_DCB is not set |
| 365 | 381 | ||
| @@ -377,7 +393,11 @@ CONFIG_WIRELESS=y | |||
| 377 | CONFIG_WIRELESS_OLD_REGULATORY=y | 393 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 378 | # CONFIG_WIRELESS_EXT is not set | 394 | # CONFIG_WIRELESS_EXT is not set |
| 379 | # CONFIG_LIB80211 is not set | 395 | # CONFIG_LIB80211 is not set |
| 380 | # CONFIG_MAC80211 is not set | 396 | |
| 397 | # | ||
| 398 | # CFG80211 needs to be enabled for MAC80211 | ||
| 399 | # | ||
| 400 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 381 | # CONFIG_WIMAX is not set | 401 | # CONFIG_WIMAX is not set |
| 382 | # CONFIG_RFKILL is not set | 402 | # CONFIG_RFKILL is not set |
| 383 | # CONFIG_NET_9P is not set | 403 | # CONFIG_NET_9P is not set |
| @@ -400,6 +420,7 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 400 | # CONFIG_MTD is not set | 420 | # CONFIG_MTD is not set |
| 401 | CONFIG_OF_DEVICE=y | 421 | CONFIG_OF_DEVICE=y |
| 402 | CONFIG_OF_GPIO=y | 422 | CONFIG_OF_GPIO=y |
| 423 | CONFIG_OF_MDIO=y | ||
| 403 | # CONFIG_PARPORT is not set | 424 | # CONFIG_PARPORT is not set |
| 404 | CONFIG_BLK_DEV=y | 425 | CONFIG_BLK_DEV=y |
| 405 | # CONFIG_BLK_DEV_FD is not set | 426 | # CONFIG_BLK_DEV_FD is not set |
| @@ -431,6 +452,7 @@ CONFIG_MISC_DEVICES=y | |||
| 431 | # EEPROM support | 452 | # EEPROM support |
| 432 | # | 453 | # |
| 433 | # CONFIG_EEPROM_93CX6 is not set | 454 | # CONFIG_EEPROM_93CX6 is not set |
| 455 | # CONFIG_CB710_CORE is not set | ||
| 434 | CONFIG_HAVE_IDE=y | 456 | CONFIG_HAVE_IDE=y |
| 435 | # CONFIG_IDE is not set | 457 | # CONFIG_IDE is not set |
| 436 | 458 | ||
| @@ -450,14 +472,17 @@ CONFIG_HAVE_IDE=y | |||
| 450 | # | 472 | # |
| 451 | 473 | ||
| 452 | # | 474 | # |
| 453 | # Enable only one of the two stacks, unless you know what you are doing | 475 | # You can enable one or both FireWire driver stacks. |
| 476 | # | ||
| 477 | |||
| 478 | # | ||
| 479 | # See the help texts for more information. | ||
| 454 | # | 480 | # |
| 455 | # CONFIG_FIREWIRE is not set | 481 | # CONFIG_FIREWIRE is not set |
| 456 | # CONFIG_IEEE1394 is not set | 482 | # CONFIG_IEEE1394 is not set |
| 457 | # CONFIG_I2O is not set | 483 | # CONFIG_I2O is not set |
| 458 | # CONFIG_MACINTOSH_DRIVERS is not set | 484 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 459 | CONFIG_NETDEVICES=y | 485 | CONFIG_NETDEVICES=y |
| 460 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 461 | # CONFIG_DUMMY is not set | 486 | # CONFIG_DUMMY is not set |
| 462 | # CONFIG_BONDING is not set | 487 | # CONFIG_BONDING is not set |
| 463 | # CONFIG_MACVLAN is not set | 488 | # CONFIG_MACVLAN is not set |
| @@ -504,6 +529,7 @@ CONFIG_MII=y | |||
| 504 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 529 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 505 | # CONFIG_NET_PCI is not set | 530 | # CONFIG_NET_PCI is not set |
| 506 | # CONFIG_B44 is not set | 531 | # CONFIG_B44 is not set |
| 532 | # CONFIG_KS8842 is not set | ||
| 507 | # CONFIG_ATL2 is not set | 533 | # CONFIG_ATL2 is not set |
| 508 | CONFIG_FS_ENET=y | 534 | CONFIG_FS_ENET=y |
| 509 | # CONFIG_FS_ENET_HAS_SCC is not set | 535 | # CONFIG_FS_ENET_HAS_SCC is not set |
| @@ -527,8 +553,10 @@ CONFIG_E1000=y | |||
| 527 | # CONFIG_VIA_VELOCITY is not set | 553 | # CONFIG_VIA_VELOCITY is not set |
| 528 | # CONFIG_TIGON3 is not set | 554 | # CONFIG_TIGON3 is not set |
| 529 | # CONFIG_BNX2 is not set | 555 | # CONFIG_BNX2 is not set |
| 556 | # CONFIG_CNIC is not set | ||
| 530 | CONFIG_FSL_PQ_MDIO=y | 557 | CONFIG_FSL_PQ_MDIO=y |
| 531 | CONFIG_GIANFAR=y | 558 | CONFIG_GIANFAR=y |
| 559 | # CONFIG_MV643XX_ETH is not set | ||
| 532 | # CONFIG_QLA3XXX is not set | 560 | # CONFIG_QLA3XXX is not set |
| 533 | # CONFIG_ATL1 is not set | 561 | # CONFIG_ATL1 is not set |
| 534 | # CONFIG_ATL1E is not set | 562 | # CONFIG_ATL1E is not set |
| @@ -646,6 +674,11 @@ CONFIG_GEN_RTC=y | |||
| 646 | CONFIG_DEVPORT=y | 674 | CONFIG_DEVPORT=y |
| 647 | # CONFIG_I2C is not set | 675 | # CONFIG_I2C is not set |
| 648 | # CONFIG_SPI is not set | 676 | # CONFIG_SPI is not set |
| 677 | |||
| 678 | # | ||
| 679 | # PPS support | ||
| 680 | # | ||
| 681 | # CONFIG_PPS is not set | ||
| 649 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 682 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 650 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 683 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 651 | CONFIG_GPIOLIB=y | 684 | CONFIG_GPIOLIB=y |
| @@ -707,22 +740,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 707 | # CONFIG_HTC_PASIC3 is not set | 740 | # CONFIG_HTC_PASIC3 is not set |
| 708 | # CONFIG_MFD_TMIO is not set | 741 | # CONFIG_MFD_TMIO is not set |
| 709 | # CONFIG_REGULATOR is not set | 742 | # CONFIG_REGULATOR is not set |
| 710 | 743 | # CONFIG_MEDIA_SUPPORT is not set | |
| 711 | # | ||
| 712 | # Multimedia devices | ||
| 713 | # | ||
| 714 | |||
| 715 | # | ||
| 716 | # Multimedia core support | ||
| 717 | # | ||
| 718 | # CONFIG_VIDEO_DEV is not set | ||
| 719 | # CONFIG_DVB_CORE is not set | ||
| 720 | # CONFIG_VIDEO_MEDIA is not set | ||
| 721 | |||
| 722 | # | ||
| 723 | # Multimedia drivers | ||
| 724 | # | ||
| 725 | CONFIG_DAB=y | ||
| 726 | 744 | ||
| 727 | # | 745 | # |
| 728 | # Graphics support | 746 | # Graphics support |
| @@ -779,6 +797,10 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
| 779 | # CONFIG_DMADEVICES is not set | 797 | # CONFIG_DMADEVICES is not set |
| 780 | # CONFIG_AUXDISPLAY is not set | 798 | # CONFIG_AUXDISPLAY is not set |
| 781 | # CONFIG_UIO is not set | 799 | # CONFIG_UIO is not set |
| 800 | |||
| 801 | # | ||
| 802 | # TI VLYNQ | ||
| 803 | # | ||
| 782 | # CONFIG_STAGING is not set | 804 | # CONFIG_STAGING is not set |
| 783 | 805 | ||
| 784 | # | 806 | # |
| @@ -798,10 +820,12 @@ CONFIG_FS_MBCACHE=y | |||
| 798 | # CONFIG_REISERFS_FS is not set | 820 | # CONFIG_REISERFS_FS is not set |
| 799 | # CONFIG_JFS_FS is not set | 821 | # CONFIG_JFS_FS is not set |
| 800 | # CONFIG_FS_POSIX_ACL is not set | 822 | # CONFIG_FS_POSIX_ACL is not set |
| 801 | CONFIG_FILE_LOCKING=y | ||
| 802 | # CONFIG_XFS_FS is not set | 823 | # CONFIG_XFS_FS is not set |
| 824 | # CONFIG_GFS2_FS is not set | ||
| 803 | # CONFIG_OCFS2_FS is not set | 825 | # CONFIG_OCFS2_FS is not set |
| 804 | # CONFIG_BTRFS_FS is not set | 826 | # CONFIG_BTRFS_FS is not set |
| 827 | CONFIG_FILE_LOCKING=y | ||
| 828 | CONFIG_FSNOTIFY=y | ||
| 805 | CONFIG_DNOTIFY=y | 829 | CONFIG_DNOTIFY=y |
| 806 | CONFIG_INOTIFY=y | 830 | CONFIG_INOTIFY=y |
| 807 | CONFIG_INOTIFY_USER=y | 831 | CONFIG_INOTIFY_USER=y |
| @@ -916,6 +940,7 @@ CONFIG_HAS_IOPORT=y | |||
| 916 | CONFIG_HAS_DMA=y | 940 | CONFIG_HAS_DMA=y |
| 917 | CONFIG_HAVE_LMB=y | 941 | CONFIG_HAVE_LMB=y |
| 918 | CONFIG_NLATTR=y | 942 | CONFIG_NLATTR=y |
| 943 | CONFIG_GENERIC_ATOMIC64=y | ||
| 919 | 944 | ||
| 920 | # | 945 | # |
| 921 | # Kernel hacking | 946 | # Kernel hacking |
| @@ -946,6 +971,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 946 | # CONFIG_RT_MUTEX_TESTER is not set | 971 | # CONFIG_RT_MUTEX_TESTER is not set |
| 947 | # CONFIG_DEBUG_SPINLOCK is not set | 972 | # CONFIG_DEBUG_SPINLOCK is not set |
| 948 | CONFIG_DEBUG_MUTEXES=y | 973 | CONFIG_DEBUG_MUTEXES=y |
| 974 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 975 | # CONFIG_PROVE_LOCKING is not set | ||
| 976 | # CONFIG_LOCK_STAT is not set | ||
| 949 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 977 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 950 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 978 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 951 | # CONFIG_DEBUG_KOBJECT is not set | 979 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -957,7 +985,6 @@ CONFIG_DEBUG_MUTEXES=y | |||
| 957 | # CONFIG_DEBUG_LIST is not set | 985 | # CONFIG_DEBUG_LIST is not set |
| 958 | # CONFIG_DEBUG_SG is not set | 986 | # CONFIG_DEBUG_SG is not set |
| 959 | # CONFIG_DEBUG_NOTIFIERS is not set | 987 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 960 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 961 | # CONFIG_RCU_TORTURE_TEST is not set | 988 | # CONFIG_RCU_TORTURE_TEST is not set |
| 962 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 989 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 963 | # CONFIG_BACKTRACE_SELF_TEST is not set | 990 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -971,16 +998,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 971 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 998 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 972 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 999 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 973 | CONFIG_TRACING_SUPPORT=y | 1000 | CONFIG_TRACING_SUPPORT=y |
| 974 | 1001 | CONFIG_FTRACE=y | |
| 975 | # | ||
| 976 | # Tracers | ||
| 977 | # | ||
| 978 | # CONFIG_FUNCTION_TRACER is not set | 1002 | # CONFIG_FUNCTION_TRACER is not set |
| 1003 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 979 | # CONFIG_SCHED_TRACER is not set | 1004 | # CONFIG_SCHED_TRACER is not set |
| 980 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1005 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 981 | # CONFIG_EVENT_TRACER is not set | ||
| 982 | # CONFIG_BOOT_TRACER is not set | 1006 | # CONFIG_BOOT_TRACER is not set |
| 983 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1007 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1008 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1009 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 984 | # CONFIG_STACK_TRACER is not set | 1010 | # CONFIG_STACK_TRACER is not set |
| 985 | # CONFIG_KMEMTRACE is not set | 1011 | # CONFIG_KMEMTRACE is not set |
| 986 | # CONFIG_WORKQUEUE_TRACER is not set | 1012 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -988,6 +1014,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 988 | # CONFIG_SAMPLES is not set | 1014 | # CONFIG_SAMPLES is not set |
| 989 | CONFIG_HAVE_ARCH_KGDB=y | 1015 | CONFIG_HAVE_ARCH_KGDB=y |
| 990 | # CONFIG_KGDB is not set | 1016 | # CONFIG_KGDB is not set |
| 1017 | # CONFIG_KMEMCHECK is not set | ||
| 1018 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1019 | CONFIG_PPC_WERROR=y | ||
| 991 | CONFIG_PRINT_STACK_DEPTH=64 | 1020 | CONFIG_PRINT_STACK_DEPTH=64 |
| 992 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1021 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 993 | # CONFIG_DEBUG_STACK_USAGE is not set | 1022 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/85xx/mpc85xx_cds_defconfig b/arch/powerpc/configs/85xx/mpc85xx_cds_defconfig index 41209e3a6545..158e63e8607f 100644 --- a/arch/powerpc/configs/85xx/mpc85xx_cds_defconfig +++ b/arch/powerpc/configs/85xx/mpc85xx_cds_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:18 2009 | 4 | # Wed Jul 29 23:32:17 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -34,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 34 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 35 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 36 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 38 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 39 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 41 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 43 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 44 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 45 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 48 | CONFIG_PPC=y | 49 | CONFIG_PPC=y |
| @@ -56,11 +57,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 56 | # CONFIG_GENERIC_TBSYNC is not set | 57 | # CONFIG_GENERIC_TBSYNC is not set |
| 57 | CONFIG_AUDIT_ARCH=y | 58 | CONFIG_AUDIT_ARCH=y |
| 58 | CONFIG_GENERIC_BUG=y | 59 | CONFIG_GENERIC_BUG=y |
| 60 | CONFIG_DTC=y | ||
| 59 | CONFIG_DEFAULT_UIMAGE=y | 61 | CONFIG_DEFAULT_UIMAGE=y |
| 60 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 61 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 62 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 63 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 64 | 67 | ||
| 65 | # | 68 | # |
| 66 | # General setup | 69 | # General setup |
| @@ -111,7 +114,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 111 | CONFIG_KALLSYMS=y | 114 | CONFIG_KALLSYMS=y |
| 112 | # CONFIG_KALLSYMS_ALL is not set | 115 | # CONFIG_KALLSYMS_ALL is not set |
| 113 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 116 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 114 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 115 | CONFIG_HOTPLUG=y | 117 | CONFIG_HOTPLUG=y |
| 116 | CONFIG_PRINTK=y | 118 | CONFIG_PRINTK=y |
| 117 | CONFIG_BUG=y | 119 | CONFIG_BUG=y |
| @@ -124,9 +126,16 @@ CONFIG_TIMERFD=y | |||
| 124 | CONFIG_EVENTFD=y | 126 | CONFIG_EVENTFD=y |
| 125 | CONFIG_SHMEM=y | 127 | CONFIG_SHMEM=y |
| 126 | CONFIG_AIO=y | 128 | CONFIG_AIO=y |
| 129 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 130 | |||
| 131 | # | ||
| 132 | # Performance Counters | ||
| 133 | # | ||
| 134 | # CONFIG_PERF_COUNTERS is not set | ||
| 127 | CONFIG_VM_EVENT_COUNTERS=y | 135 | CONFIG_VM_EVENT_COUNTERS=y |
| 128 | CONFIG_PCI_QUIRKS=y | 136 | CONFIG_PCI_QUIRKS=y |
| 129 | CONFIG_SLUB_DEBUG=y | 137 | CONFIG_SLUB_DEBUG=y |
| 138 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 130 | CONFIG_COMPAT_BRK=y | 139 | CONFIG_COMPAT_BRK=y |
| 131 | # CONFIG_SLAB is not set | 140 | # CONFIG_SLAB is not set |
| 132 | CONFIG_SLUB=y | 141 | CONFIG_SLUB=y |
| @@ -139,6 +148,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 139 | CONFIG_HAVE_KPROBES=y | 148 | CONFIG_HAVE_KPROBES=y |
| 140 | CONFIG_HAVE_KRETPROBES=y | 149 | CONFIG_HAVE_KRETPROBES=y |
| 141 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 150 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 151 | |||
| 152 | # | ||
| 153 | # GCOV-based kernel profiling | ||
| 154 | # | ||
| 142 | # CONFIG_SLOW_WORK is not set | 155 | # CONFIG_SLOW_WORK is not set |
| 143 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 156 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 144 | CONFIG_SLABINFO=y | 157 | CONFIG_SLABINFO=y |
| @@ -146,7 +159,7 @@ CONFIG_RT_MUTEXES=y | |||
| 146 | CONFIG_BASE_SMALL=0 | 159 | CONFIG_BASE_SMALL=0 |
| 147 | # CONFIG_MODULES is not set | 160 | # CONFIG_MODULES is not set |
| 148 | CONFIG_BLOCK=y | 161 | CONFIG_BLOCK=y |
| 149 | # CONFIG_LBD is not set | 162 | CONFIG_LBDAF=y |
| 150 | # CONFIG_BLK_DEV_BSG is not set | 163 | # CONFIG_BLK_DEV_BSG is not set |
| 151 | # CONFIG_BLK_DEV_INTEGRITY is not set | 164 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 152 | 165 | ||
| @@ -179,6 +192,7 @@ CONFIG_MPC85xx_CDS=y | |||
| 179 | # CONFIG_MPC85xx_DS is not set | 192 | # CONFIG_MPC85xx_DS is not set |
| 180 | # CONFIG_SOCRATES is not set | 193 | # CONFIG_SOCRATES is not set |
| 181 | # CONFIG_KSI8560 is not set | 194 | # CONFIG_KSI8560 is not set |
| 195 | # CONFIG_XES_MPC85xx is not set | ||
| 182 | # CONFIG_STX_GP3 is not set | 196 | # CONFIG_STX_GP3 is not set |
| 183 | # CONFIG_TQM8540 is not set | 197 | # CONFIG_TQM8540 is not set |
| 184 | # CONFIG_TQM8541 is not set | 198 | # CONFIG_TQM8541 is not set |
| @@ -227,6 +241,7 @@ CONFIG_BINFMT_ELF=y | |||
| 227 | CONFIG_BINFMT_MISC=y | 241 | CONFIG_BINFMT_MISC=y |
| 228 | CONFIG_MATH_EMULATION=y | 242 | CONFIG_MATH_EMULATION=y |
| 229 | # CONFIG_IOMMU_HELPER is not set | 243 | # CONFIG_IOMMU_HELPER is not set |
| 244 | # CONFIG_SWIOTLB is not set | ||
| 230 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 245 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 231 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 246 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 232 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 247 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -245,9 +260,9 @@ CONFIG_MIGRATION=y | |||
| 245 | CONFIG_ZONE_DMA_FLAG=1 | 260 | CONFIG_ZONE_DMA_FLAG=1 |
| 246 | CONFIG_BOUNCE=y | 261 | CONFIG_BOUNCE=y |
| 247 | CONFIG_VIRT_TO_BUS=y | 262 | CONFIG_VIRT_TO_BUS=y |
| 248 | CONFIG_UNEVICTABLE_LRU=y | ||
| 249 | CONFIG_HAVE_MLOCK=y | 263 | CONFIG_HAVE_MLOCK=y |
| 250 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 264 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 265 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 251 | CONFIG_PPC_4K_PAGES=y | 266 | CONFIG_PPC_4K_PAGES=y |
| 252 | # CONFIG_PPC_16K_PAGES is not set | 267 | # CONFIG_PPC_16K_PAGES is not set |
| 253 | # CONFIG_PPC_64K_PAGES is not set | 268 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -358,6 +373,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 358 | # CONFIG_ECONET is not set | 373 | # CONFIG_ECONET is not set |
| 359 | # CONFIG_WAN_ROUTER is not set | 374 | # CONFIG_WAN_ROUTER is not set |
| 360 | # CONFIG_PHONET is not set | 375 | # CONFIG_PHONET is not set |
| 376 | # CONFIG_IEEE802154 is not set | ||
| 361 | # CONFIG_NET_SCHED is not set | 377 | # CONFIG_NET_SCHED is not set |
| 362 | # CONFIG_DCB is not set | 378 | # CONFIG_DCB is not set |
| 363 | 379 | ||
| @@ -375,7 +391,11 @@ CONFIG_WIRELESS=y | |||
| 375 | CONFIG_WIRELESS_OLD_REGULATORY=y | 391 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 376 | # CONFIG_WIRELESS_EXT is not set | 392 | # CONFIG_WIRELESS_EXT is not set |
| 377 | # CONFIG_LIB80211 is not set | 393 | # CONFIG_LIB80211 is not set |
| 378 | # CONFIG_MAC80211 is not set | 394 | |
| 395 | # | ||
| 396 | # CFG80211 needs to be enabled for MAC80211 | ||
| 397 | # | ||
| 398 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 379 | # CONFIG_WIMAX is not set | 399 | # CONFIG_WIMAX is not set |
| 380 | # CONFIG_RFKILL is not set | 400 | # CONFIG_RFKILL is not set |
| 381 | # CONFIG_NET_9P is not set | 401 | # CONFIG_NET_9P is not set |
| @@ -397,6 +417,7 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 397 | # CONFIG_CONNECTOR is not set | 417 | # CONFIG_CONNECTOR is not set |
| 398 | # CONFIG_MTD is not set | 418 | # CONFIG_MTD is not set |
| 399 | CONFIG_OF_DEVICE=y | 419 | CONFIG_OF_DEVICE=y |
| 420 | CONFIG_OF_MDIO=y | ||
| 400 | # CONFIG_PARPORT is not set | 421 | # CONFIG_PARPORT is not set |
| 401 | CONFIG_BLK_DEV=y | 422 | CONFIG_BLK_DEV=y |
| 402 | # CONFIG_BLK_DEV_FD is not set | 423 | # CONFIG_BLK_DEV_FD is not set |
| @@ -428,6 +449,7 @@ CONFIG_MISC_DEVICES=y | |||
| 428 | # EEPROM support | 449 | # EEPROM support |
| 429 | # | 450 | # |
| 430 | # CONFIG_EEPROM_93CX6 is not set | 451 | # CONFIG_EEPROM_93CX6 is not set |
| 452 | # CONFIG_CB710_CORE is not set | ||
| 431 | CONFIG_HAVE_IDE=y | 453 | CONFIG_HAVE_IDE=y |
| 432 | CONFIG_IDE=y | 454 | CONFIG_IDE=y |
| 433 | 455 | ||
| @@ -502,14 +524,17 @@ CONFIG_BLK_DEV_IDEDMA=y | |||
| 502 | # | 524 | # |
| 503 | 525 | ||
| 504 | # | 526 | # |
| 505 | # Enable only one of the two stacks, unless you know what you are doing | 527 | # You can enable one or both FireWire driver stacks. |
| 528 | # | ||
| 529 | |||
| 530 | # | ||
| 531 | # See the help texts for more information. | ||
| 506 | # | 532 | # |
| 507 | # CONFIG_FIREWIRE is not set | 533 | # CONFIG_FIREWIRE is not set |
| 508 | # CONFIG_IEEE1394 is not set | 534 | # CONFIG_IEEE1394 is not set |
| 509 | # CONFIG_I2O is not set | 535 | # CONFIG_I2O is not set |
| 510 | # CONFIG_MACINTOSH_DRIVERS is not set | 536 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 511 | CONFIG_NETDEVICES=y | 537 | CONFIG_NETDEVICES=y |
| 512 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 513 | # CONFIG_DUMMY is not set | 538 | # CONFIG_DUMMY is not set |
| 514 | # CONFIG_BONDING is not set | 539 | # CONFIG_BONDING is not set |
| 515 | # CONFIG_MACVLAN is not set | 540 | # CONFIG_MACVLAN is not set |
| @@ -556,6 +581,7 @@ CONFIG_MII=y | |||
| 556 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 581 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 557 | # CONFIG_NET_PCI is not set | 582 | # CONFIG_NET_PCI is not set |
| 558 | # CONFIG_B44 is not set | 583 | # CONFIG_B44 is not set |
| 584 | # CONFIG_KS8842 is not set | ||
| 559 | # CONFIG_ATL2 is not set | 585 | # CONFIG_ATL2 is not set |
| 560 | CONFIG_NETDEV_1000=y | 586 | CONFIG_NETDEV_1000=y |
| 561 | # CONFIG_ACENIC is not set | 587 | # CONFIG_ACENIC is not set |
| @@ -575,8 +601,10 @@ CONFIG_E1000=y | |||
| 575 | # CONFIG_VIA_VELOCITY is not set | 601 | # CONFIG_VIA_VELOCITY is not set |
| 576 | # CONFIG_TIGON3 is not set | 602 | # CONFIG_TIGON3 is not set |
| 577 | # CONFIG_BNX2 is not set | 603 | # CONFIG_BNX2 is not set |
| 604 | # CONFIG_CNIC is not set | ||
| 578 | CONFIG_FSL_PQ_MDIO=y | 605 | CONFIG_FSL_PQ_MDIO=y |
| 579 | CONFIG_GIANFAR=y | 606 | CONFIG_GIANFAR=y |
| 607 | # CONFIG_MV643XX_ETH is not set | ||
| 580 | # CONFIG_QLA3XXX is not set | 608 | # CONFIG_QLA3XXX is not set |
| 581 | # CONFIG_ATL1 is not set | 609 | # CONFIG_ATL1 is not set |
| 582 | # CONFIG_ATL1E is not set | 610 | # CONFIG_ATL1E is not set |
| @@ -698,6 +726,11 @@ CONFIG_GEN_RTC=y | |||
| 698 | CONFIG_DEVPORT=y | 726 | CONFIG_DEVPORT=y |
| 699 | # CONFIG_I2C is not set | 727 | # CONFIG_I2C is not set |
| 700 | # CONFIG_SPI is not set | 728 | # CONFIG_SPI is not set |
| 729 | |||
| 730 | # | ||
| 731 | # PPS support | ||
| 732 | # | ||
| 733 | # CONFIG_PPS is not set | ||
| 701 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 734 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 702 | # CONFIG_GPIOLIB is not set | 735 | # CONFIG_GPIOLIB is not set |
| 703 | # CONFIG_W1 is not set | 736 | # CONFIG_W1 is not set |
| @@ -737,22 +770,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 737 | # CONFIG_HTC_PASIC3 is not set | 770 | # CONFIG_HTC_PASIC3 is not set |
| 738 | # CONFIG_MFD_TMIO is not set | 771 | # CONFIG_MFD_TMIO is not set |
| 739 | # CONFIG_REGULATOR is not set | 772 | # CONFIG_REGULATOR is not set |
| 740 | 773 | # CONFIG_MEDIA_SUPPORT is not set | |
| 741 | # | ||
| 742 | # Multimedia devices | ||
| 743 | # | ||
| 744 | |||
| 745 | # | ||
| 746 | # Multimedia core support | ||
| 747 | # | ||
| 748 | # CONFIG_VIDEO_DEV is not set | ||
| 749 | # CONFIG_DVB_CORE is not set | ||
| 750 | # CONFIG_VIDEO_MEDIA is not set | ||
| 751 | |||
| 752 | # | ||
| 753 | # Multimedia drivers | ||
| 754 | # | ||
| 755 | CONFIG_DAB=y | ||
| 756 | 774 | ||
| 757 | # | 775 | # |
| 758 | # Graphics support | 776 | # Graphics support |
| @@ -809,6 +827,10 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
| 809 | # CONFIG_DMADEVICES is not set | 827 | # CONFIG_DMADEVICES is not set |
| 810 | # CONFIG_AUXDISPLAY is not set | 828 | # CONFIG_AUXDISPLAY is not set |
| 811 | # CONFIG_UIO is not set | 829 | # CONFIG_UIO is not set |
| 830 | |||
| 831 | # | ||
| 832 | # TI VLYNQ | ||
| 833 | # | ||
| 812 | # CONFIG_STAGING is not set | 834 | # CONFIG_STAGING is not set |
| 813 | 835 | ||
| 814 | # | 836 | # |
| @@ -828,10 +850,12 @@ CONFIG_FS_MBCACHE=y | |||
| 828 | # CONFIG_REISERFS_FS is not set | 850 | # CONFIG_REISERFS_FS is not set |
| 829 | # CONFIG_JFS_FS is not set | 851 | # CONFIG_JFS_FS is not set |
| 830 | # CONFIG_FS_POSIX_ACL is not set | 852 | # CONFIG_FS_POSIX_ACL is not set |
| 831 | CONFIG_FILE_LOCKING=y | ||
| 832 | # CONFIG_XFS_FS is not set | 853 | # CONFIG_XFS_FS is not set |
| 854 | # CONFIG_GFS2_FS is not set | ||
| 833 | # CONFIG_OCFS2_FS is not set | 855 | # CONFIG_OCFS2_FS is not set |
| 834 | # CONFIG_BTRFS_FS is not set | 856 | # CONFIG_BTRFS_FS is not set |
| 857 | CONFIG_FILE_LOCKING=y | ||
| 858 | CONFIG_FSNOTIFY=y | ||
| 835 | CONFIG_DNOTIFY=y | 859 | CONFIG_DNOTIFY=y |
| 836 | CONFIG_INOTIFY=y | 860 | CONFIG_INOTIFY=y |
| 837 | CONFIG_INOTIFY_USER=y | 861 | CONFIG_INOTIFY_USER=y |
| @@ -946,6 +970,7 @@ CONFIG_HAS_IOPORT=y | |||
| 946 | CONFIG_HAS_DMA=y | 970 | CONFIG_HAS_DMA=y |
| 947 | CONFIG_HAVE_LMB=y | 971 | CONFIG_HAVE_LMB=y |
| 948 | CONFIG_NLATTR=y | 972 | CONFIG_NLATTR=y |
| 973 | CONFIG_GENERIC_ATOMIC64=y | ||
| 949 | 974 | ||
| 950 | # | 975 | # |
| 951 | # Kernel hacking | 976 | # Kernel hacking |
| @@ -976,6 +1001,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 976 | # CONFIG_RT_MUTEX_TESTER is not set | 1001 | # CONFIG_RT_MUTEX_TESTER is not set |
| 977 | # CONFIG_DEBUG_SPINLOCK is not set | 1002 | # CONFIG_DEBUG_SPINLOCK is not set |
| 978 | CONFIG_DEBUG_MUTEXES=y | 1003 | CONFIG_DEBUG_MUTEXES=y |
| 1004 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1005 | # CONFIG_PROVE_LOCKING is not set | ||
| 1006 | # CONFIG_LOCK_STAT is not set | ||
| 979 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1007 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 980 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1008 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 981 | # CONFIG_DEBUG_KOBJECT is not set | 1009 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -987,7 +1015,6 @@ CONFIG_DEBUG_MUTEXES=y | |||
| 987 | # CONFIG_DEBUG_LIST is not set | 1015 | # CONFIG_DEBUG_LIST is not set |
| 988 | # CONFIG_DEBUG_SG is not set | 1016 | # CONFIG_DEBUG_SG is not set |
| 989 | # CONFIG_DEBUG_NOTIFIERS is not set | 1017 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 990 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 991 | # CONFIG_RCU_TORTURE_TEST is not set | 1018 | # CONFIG_RCU_TORTURE_TEST is not set |
| 992 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1019 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 993 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1020 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1001,16 +1028,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1001 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1028 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1002 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1029 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1003 | CONFIG_TRACING_SUPPORT=y | 1030 | CONFIG_TRACING_SUPPORT=y |
| 1004 | 1031 | CONFIG_FTRACE=y | |
| 1005 | # | ||
| 1006 | # Tracers | ||
| 1007 | # | ||
| 1008 | # CONFIG_FUNCTION_TRACER is not set | 1032 | # CONFIG_FUNCTION_TRACER is not set |
| 1033 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1009 | # CONFIG_SCHED_TRACER is not set | 1034 | # CONFIG_SCHED_TRACER is not set |
| 1010 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1035 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1011 | # CONFIG_EVENT_TRACER is not set | ||
| 1012 | # CONFIG_BOOT_TRACER is not set | 1036 | # CONFIG_BOOT_TRACER is not set |
| 1013 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1037 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1038 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1039 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1014 | # CONFIG_STACK_TRACER is not set | 1040 | # CONFIG_STACK_TRACER is not set |
| 1015 | # CONFIG_KMEMTRACE is not set | 1041 | # CONFIG_KMEMTRACE is not set |
| 1016 | # CONFIG_WORKQUEUE_TRACER is not set | 1042 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -1018,6 +1044,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 1018 | # CONFIG_SAMPLES is not set | 1044 | # CONFIG_SAMPLES is not set |
| 1019 | CONFIG_HAVE_ARCH_KGDB=y | 1045 | CONFIG_HAVE_ARCH_KGDB=y |
| 1020 | # CONFIG_KGDB is not set | 1046 | # CONFIG_KGDB is not set |
| 1047 | # CONFIG_KMEMCHECK is not set | ||
| 1048 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1049 | CONFIG_PPC_WERROR=y | ||
| 1021 | CONFIG_PRINT_STACK_DEPTH=64 | 1050 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1022 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1051 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1023 | # CONFIG_DEBUG_STACK_USAGE is not set | 1052 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/85xx/sbc8548_defconfig b/arch/powerpc/configs/85xx/sbc8548_defconfig index 6c36c9c7abfd..2726fca1d694 100644 --- a/arch/powerpc/configs/85xx/sbc8548_defconfig +++ b/arch/powerpc/configs/85xx/sbc8548_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:19 2009 | 4 | # Wed Jul 29 23:32:18 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -34,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 34 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 35 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 36 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 38 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 39 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 41 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 43 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 44 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 45 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 48 | CONFIG_PPC=y | 49 | CONFIG_PPC=y |
| @@ -56,11 +57,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 56 | # CONFIG_GENERIC_TBSYNC is not set | 57 | # CONFIG_GENERIC_TBSYNC is not set |
| 57 | CONFIG_AUDIT_ARCH=y | 58 | CONFIG_AUDIT_ARCH=y |
| 58 | CONFIG_GENERIC_BUG=y | 59 | CONFIG_GENERIC_BUG=y |
| 60 | CONFIG_DTC=y | ||
| 59 | CONFIG_DEFAULT_UIMAGE=y | 61 | CONFIG_DEFAULT_UIMAGE=y |
| 60 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 61 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 62 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 63 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 64 | 67 | ||
| 65 | # | 68 | # |
| 66 | # General setup | 69 | # General setup |
| @@ -110,7 +113,6 @@ CONFIG_EMBEDDED=y | |||
| 110 | CONFIG_SYSCTL_SYSCALL=y | 113 | CONFIG_SYSCTL_SYSCALL=y |
| 111 | CONFIG_KALLSYMS=y | 114 | CONFIG_KALLSYMS=y |
| 112 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 115 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 113 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 114 | CONFIG_HOTPLUG=y | 116 | CONFIG_HOTPLUG=y |
| 115 | CONFIG_PRINTK=y | 117 | CONFIG_PRINTK=y |
| 116 | CONFIG_BUG=y | 118 | CONFIG_BUG=y |
| @@ -123,8 +125,15 @@ CONFIG_TIMERFD=y | |||
| 123 | CONFIG_EVENTFD=y | 125 | CONFIG_EVENTFD=y |
| 124 | CONFIG_SHMEM=y | 126 | CONFIG_SHMEM=y |
| 125 | CONFIG_AIO=y | 127 | CONFIG_AIO=y |
| 128 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 129 | |||
| 130 | # | ||
| 131 | # Performance Counters | ||
| 132 | # | ||
| 133 | # CONFIG_PERF_COUNTERS is not set | ||
| 126 | CONFIG_VM_EVENT_COUNTERS=y | 134 | CONFIG_VM_EVENT_COUNTERS=y |
| 127 | CONFIG_PCI_QUIRKS=y | 135 | CONFIG_PCI_QUIRKS=y |
| 136 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 128 | CONFIG_COMPAT_BRK=y | 137 | CONFIG_COMPAT_BRK=y |
| 129 | CONFIG_SLAB=y | 138 | CONFIG_SLAB=y |
| 130 | # CONFIG_SLUB is not set | 139 | # CONFIG_SLUB is not set |
| @@ -137,6 +146,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 137 | CONFIG_HAVE_KPROBES=y | 146 | CONFIG_HAVE_KPROBES=y |
| 138 | CONFIG_HAVE_KRETPROBES=y | 147 | CONFIG_HAVE_KRETPROBES=y |
| 139 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 148 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 149 | |||
| 150 | # | ||
| 151 | # GCOV-based kernel profiling | ||
| 152 | # | ||
| 140 | # CONFIG_SLOW_WORK is not set | 153 | # CONFIG_SLOW_WORK is not set |
| 141 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 142 | CONFIG_SLABINFO=y | 155 | CONFIG_SLABINFO=y |
| @@ -144,7 +157,7 @@ CONFIG_RT_MUTEXES=y | |||
| 144 | CONFIG_BASE_SMALL=0 | 157 | CONFIG_BASE_SMALL=0 |
| 145 | # CONFIG_MODULES is not set | 158 | # CONFIG_MODULES is not set |
| 146 | CONFIG_BLOCK=y | 159 | CONFIG_BLOCK=y |
| 147 | # CONFIG_LBD is not set | 160 | CONFIG_LBDAF=y |
| 148 | # CONFIG_BLK_DEV_BSG is not set | 161 | # CONFIG_BLK_DEV_BSG is not set |
| 149 | # CONFIG_BLK_DEV_INTEGRITY is not set | 162 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 150 | 163 | ||
| @@ -177,6 +190,7 @@ CONFIG_MPC85xx=y | |||
| 177 | # CONFIG_MPC85xx_DS is not set | 190 | # CONFIG_MPC85xx_DS is not set |
| 178 | # CONFIG_SOCRATES is not set | 191 | # CONFIG_SOCRATES is not set |
| 179 | # CONFIG_KSI8560 is not set | 192 | # CONFIG_KSI8560 is not set |
| 193 | # CONFIG_XES_MPC85xx is not set | ||
| 180 | # CONFIG_STX_GP3 is not set | 194 | # CONFIG_STX_GP3 is not set |
| 181 | # CONFIG_TQM8540 is not set | 195 | # CONFIG_TQM8540 is not set |
| 182 | # CONFIG_TQM8541 is not set | 196 | # CONFIG_TQM8541 is not set |
| @@ -224,6 +238,7 @@ CONFIG_BINFMT_ELF=y | |||
| 224 | CONFIG_BINFMT_MISC=y | 238 | CONFIG_BINFMT_MISC=y |
| 225 | CONFIG_MATH_EMULATION=y | 239 | CONFIG_MATH_EMULATION=y |
| 226 | # CONFIG_IOMMU_HELPER is not set | 240 | # CONFIG_IOMMU_HELPER is not set |
| 241 | # CONFIG_SWIOTLB is not set | ||
| 227 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 242 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 228 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 243 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 229 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 244 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -242,9 +257,9 @@ CONFIG_MIGRATION=y | |||
| 242 | CONFIG_ZONE_DMA_FLAG=1 | 257 | CONFIG_ZONE_DMA_FLAG=1 |
| 243 | CONFIG_BOUNCE=y | 258 | CONFIG_BOUNCE=y |
| 244 | CONFIG_VIRT_TO_BUS=y | 259 | CONFIG_VIRT_TO_BUS=y |
| 245 | CONFIG_UNEVICTABLE_LRU=y | ||
| 246 | CONFIG_HAVE_MLOCK=y | 260 | CONFIG_HAVE_MLOCK=y |
| 247 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 261 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 262 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 248 | CONFIG_PPC_4K_PAGES=y | 263 | CONFIG_PPC_4K_PAGES=y |
| 249 | # CONFIG_PPC_16K_PAGES is not set | 264 | # CONFIG_PPC_16K_PAGES is not set |
| 250 | # CONFIG_PPC_64K_PAGES is not set | 265 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -354,6 +369,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 354 | # CONFIG_ECONET is not set | 369 | # CONFIG_ECONET is not set |
| 355 | # CONFIG_WAN_ROUTER is not set | 370 | # CONFIG_WAN_ROUTER is not set |
| 356 | # CONFIG_PHONET is not set | 371 | # CONFIG_PHONET is not set |
| 372 | # CONFIG_IEEE802154 is not set | ||
| 357 | # CONFIG_NET_SCHED is not set | 373 | # CONFIG_NET_SCHED is not set |
| 358 | # CONFIG_DCB is not set | 374 | # CONFIG_DCB is not set |
| 359 | 375 | ||
| @@ -371,7 +387,11 @@ CONFIG_WIRELESS=y | |||
| 371 | CONFIG_WIRELESS_OLD_REGULATORY=y | 387 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 372 | # CONFIG_WIRELESS_EXT is not set | 388 | # CONFIG_WIRELESS_EXT is not set |
| 373 | # CONFIG_LIB80211 is not set | 389 | # CONFIG_LIB80211 is not set |
| 374 | # CONFIG_MAC80211 is not set | 390 | |
| 391 | # | ||
| 392 | # CFG80211 needs to be enabled for MAC80211 | ||
| 393 | # | ||
| 394 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 375 | # CONFIG_WIMAX is not set | 395 | # CONFIG_WIMAX is not set |
| 376 | # CONFIG_RFKILL is not set | 396 | # CONFIG_RFKILL is not set |
| 377 | # CONFIG_NET_9P is not set | 397 | # CONFIG_NET_9P is not set |
| @@ -391,6 +411,7 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 391 | # CONFIG_CONNECTOR is not set | 411 | # CONFIG_CONNECTOR is not set |
| 392 | # CONFIG_MTD is not set | 412 | # CONFIG_MTD is not set |
| 393 | CONFIG_OF_DEVICE=y | 413 | CONFIG_OF_DEVICE=y |
| 414 | CONFIG_OF_MDIO=y | ||
| 394 | # CONFIG_PARPORT is not set | 415 | # CONFIG_PARPORT is not set |
| 395 | CONFIG_BLK_DEV=y | 416 | CONFIG_BLK_DEV=y |
| 396 | # CONFIG_BLK_DEV_FD is not set | 417 | # CONFIG_BLK_DEV_FD is not set |
| @@ -422,6 +443,7 @@ CONFIG_MISC_DEVICES=y | |||
| 422 | # EEPROM support | 443 | # EEPROM support |
| 423 | # | 444 | # |
| 424 | # CONFIG_EEPROM_93CX6 is not set | 445 | # CONFIG_EEPROM_93CX6 is not set |
| 446 | # CONFIG_CB710_CORE is not set | ||
| 425 | CONFIG_HAVE_IDE=y | 447 | CONFIG_HAVE_IDE=y |
| 426 | # CONFIG_IDE is not set | 448 | # CONFIG_IDE is not set |
| 427 | 449 | ||
| @@ -441,14 +463,17 @@ CONFIG_HAVE_IDE=y | |||
| 441 | # | 463 | # |
| 442 | 464 | ||
| 443 | # | 465 | # |
| 444 | # Enable only one of the two stacks, unless you know what you are doing | 466 | # You can enable one or both FireWire driver stacks. |
| 467 | # | ||
| 468 | |||
| 469 | # | ||
| 470 | # See the help texts for more information. | ||
| 445 | # | 471 | # |
| 446 | # CONFIG_FIREWIRE is not set | 472 | # CONFIG_FIREWIRE is not set |
| 447 | # CONFIG_IEEE1394 is not set | 473 | # CONFIG_IEEE1394 is not set |
| 448 | # CONFIG_I2O is not set | 474 | # CONFIG_I2O is not set |
| 449 | # CONFIG_MACINTOSH_DRIVERS is not set | 475 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 450 | CONFIG_NETDEVICES=y | 476 | CONFIG_NETDEVICES=y |
| 451 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 452 | # CONFIG_DUMMY is not set | 477 | # CONFIG_DUMMY is not set |
| 453 | # CONFIG_BONDING is not set | 478 | # CONFIG_BONDING is not set |
| 454 | # CONFIG_MACVLAN is not set | 479 | # CONFIG_MACVLAN is not set |
| @@ -495,6 +520,7 @@ CONFIG_MII=y | |||
| 495 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 520 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 496 | # CONFIG_NET_PCI is not set | 521 | # CONFIG_NET_PCI is not set |
| 497 | # CONFIG_B44 is not set | 522 | # CONFIG_B44 is not set |
| 523 | # CONFIG_KS8842 is not set | ||
| 498 | # CONFIG_ATL2 is not set | 524 | # CONFIG_ATL2 is not set |
| 499 | CONFIG_NETDEV_1000=y | 525 | CONFIG_NETDEV_1000=y |
| 500 | # CONFIG_ACENIC is not set | 526 | # CONFIG_ACENIC is not set |
| @@ -514,8 +540,10 @@ CONFIG_NETDEV_1000=y | |||
| 514 | # CONFIG_VIA_VELOCITY is not set | 540 | # CONFIG_VIA_VELOCITY is not set |
| 515 | # CONFIG_TIGON3 is not set | 541 | # CONFIG_TIGON3 is not set |
| 516 | # CONFIG_BNX2 is not set | 542 | # CONFIG_BNX2 is not set |
| 543 | # CONFIG_CNIC is not set | ||
| 517 | CONFIG_FSL_PQ_MDIO=y | 544 | CONFIG_FSL_PQ_MDIO=y |
| 518 | CONFIG_GIANFAR=y | 545 | CONFIG_GIANFAR=y |
| 546 | # CONFIG_MV643XX_ETH is not set | ||
| 519 | # CONFIG_QLA3XXX is not set | 547 | # CONFIG_QLA3XXX is not set |
| 520 | # CONFIG_ATL1 is not set | 548 | # CONFIG_ATL1 is not set |
| 521 | # CONFIG_ATL1E is not set | 549 | # CONFIG_ATL1E is not set |
| @@ -637,6 +665,11 @@ CONFIG_GEN_RTC=y | |||
| 637 | CONFIG_DEVPORT=y | 665 | CONFIG_DEVPORT=y |
| 638 | # CONFIG_I2C is not set | 666 | # CONFIG_I2C is not set |
| 639 | # CONFIG_SPI is not set | 667 | # CONFIG_SPI is not set |
| 668 | |||
| 669 | # | ||
| 670 | # PPS support | ||
| 671 | # | ||
| 672 | # CONFIG_PPS is not set | ||
| 640 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 673 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 641 | # CONFIG_GPIOLIB is not set | 674 | # CONFIG_GPIOLIB is not set |
| 642 | # CONFIG_W1 is not set | 675 | # CONFIG_W1 is not set |
| @@ -676,22 +709,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 676 | # CONFIG_HTC_PASIC3 is not set | 709 | # CONFIG_HTC_PASIC3 is not set |
| 677 | # CONFIG_MFD_TMIO is not set | 710 | # CONFIG_MFD_TMIO is not set |
| 678 | # CONFIG_REGULATOR is not set | 711 | # CONFIG_REGULATOR is not set |
| 679 | 712 | # CONFIG_MEDIA_SUPPORT is not set | |
| 680 | # | ||
| 681 | # Multimedia devices | ||
| 682 | # | ||
| 683 | |||
| 684 | # | ||
| 685 | # Multimedia core support | ||
| 686 | # | ||
| 687 | # CONFIG_VIDEO_DEV is not set | ||
| 688 | # CONFIG_DVB_CORE is not set | ||
| 689 | # CONFIG_VIDEO_MEDIA is not set | ||
| 690 | |||
| 691 | # | ||
| 692 | # Multimedia drivers | ||
| 693 | # | ||
| 694 | CONFIG_DAB=y | ||
| 695 | 713 | ||
| 696 | # | 714 | # |
| 697 | # Graphics support | 715 | # Graphics support |
| @@ -721,6 +739,10 @@ CONFIG_VIDEO_OUTPUT_CONTROL=y | |||
| 721 | # CONFIG_DMADEVICES is not set | 739 | # CONFIG_DMADEVICES is not set |
| 722 | # CONFIG_AUXDISPLAY is not set | 740 | # CONFIG_AUXDISPLAY is not set |
| 723 | # CONFIG_UIO is not set | 741 | # CONFIG_UIO is not set |
| 742 | |||
| 743 | # | ||
| 744 | # TI VLYNQ | ||
| 745 | # | ||
| 724 | # CONFIG_STAGING is not set | 746 | # CONFIG_STAGING is not set |
| 725 | 747 | ||
| 726 | # | 748 | # |
| @@ -732,10 +754,12 @@ CONFIG_VIDEO_OUTPUT_CONTROL=y | |||
| 732 | # CONFIG_REISERFS_FS is not set | 754 | # CONFIG_REISERFS_FS is not set |
| 733 | # CONFIG_JFS_FS is not set | 755 | # CONFIG_JFS_FS is not set |
| 734 | # CONFIG_FS_POSIX_ACL is not set | 756 | # CONFIG_FS_POSIX_ACL is not set |
| 735 | CONFIG_FILE_LOCKING=y | ||
| 736 | # CONFIG_XFS_FS is not set | 757 | # CONFIG_XFS_FS is not set |
| 758 | # CONFIG_GFS2_FS is not set | ||
| 737 | # CONFIG_OCFS2_FS is not set | 759 | # CONFIG_OCFS2_FS is not set |
| 738 | # CONFIG_BTRFS_FS is not set | 760 | # CONFIG_BTRFS_FS is not set |
| 761 | CONFIG_FILE_LOCKING=y | ||
| 762 | CONFIG_FSNOTIFY=y | ||
| 739 | CONFIG_DNOTIFY=y | 763 | CONFIG_DNOTIFY=y |
| 740 | CONFIG_INOTIFY=y | 764 | CONFIG_INOTIFY=y |
| 741 | CONFIG_INOTIFY_USER=y | 765 | CONFIG_INOTIFY_USER=y |
| @@ -838,6 +862,7 @@ CONFIG_HAS_IOPORT=y | |||
| 838 | CONFIG_HAS_DMA=y | 862 | CONFIG_HAS_DMA=y |
| 839 | CONFIG_HAVE_LMB=y | 863 | CONFIG_HAVE_LMB=y |
| 840 | CONFIG_NLATTR=y | 864 | CONFIG_NLATTR=y |
| 865 | CONFIG_GENERIC_ATOMIC64=y | ||
| 841 | 866 | ||
| 842 | # | 867 | # |
| 843 | # Kernel hacking | 868 | # Kernel hacking |
| @@ -861,22 +886,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 861 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 886 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 862 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 887 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 863 | CONFIG_TRACING_SUPPORT=y | 888 | CONFIG_TRACING_SUPPORT=y |
| 864 | 889 | # CONFIG_FTRACE is not set | |
| 865 | # | ||
| 866 | # Tracers | ||
| 867 | # | ||
| 868 | # CONFIG_FUNCTION_TRACER is not set | ||
| 869 | # CONFIG_SCHED_TRACER is not set | ||
| 870 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 871 | # CONFIG_EVENT_TRACER is not set | ||
| 872 | # CONFIG_BOOT_TRACER is not set | ||
| 873 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 874 | # CONFIG_STACK_TRACER is not set | ||
| 875 | # CONFIG_KMEMTRACE is not set | ||
| 876 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 877 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 878 | # CONFIG_SAMPLES is not set | 890 | # CONFIG_SAMPLES is not set |
| 879 | CONFIG_HAVE_ARCH_KGDB=y | 891 | CONFIG_HAVE_ARCH_KGDB=y |
| 892 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 893 | CONFIG_PPC_WERROR=y | ||
| 880 | CONFIG_PRINT_STACK_DEPTH=64 | 894 | CONFIG_PRINT_STACK_DEPTH=64 |
| 881 | # CONFIG_IRQSTACKS is not set | 895 | # CONFIG_IRQSTACKS is not set |
| 882 | # CONFIG_PPC_EARLY_DEBUG is not set | 896 | # CONFIG_PPC_EARLY_DEBUG is not set |
diff --git a/arch/powerpc/configs/85xx/sbc8560_defconfig b/arch/powerpc/configs/85xx/sbc8560_defconfig index 4aaf1a6bdc7d..b0c469823b02 100644 --- a/arch/powerpc/configs/85xx/sbc8560_defconfig +++ b/arch/powerpc/configs/85xx/sbc8560_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:20 2009 | 4 | # Wed Jul 29 23:32:19 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -34,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 34 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 35 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 36 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 38 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 39 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 41 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 43 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 44 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 45 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 48 | CONFIG_PPC=y | 49 | CONFIG_PPC=y |
| @@ -56,11 +57,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 56 | # CONFIG_GENERIC_TBSYNC is not set | 57 | # CONFIG_GENERIC_TBSYNC is not set |
| 57 | CONFIG_AUDIT_ARCH=y | 58 | CONFIG_AUDIT_ARCH=y |
| 58 | CONFIG_GENERIC_BUG=y | 59 | CONFIG_GENERIC_BUG=y |
| 60 | CONFIG_DTC=y | ||
| 59 | CONFIG_DEFAULT_UIMAGE=y | 61 | CONFIG_DEFAULT_UIMAGE=y |
| 60 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 61 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 62 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 63 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 64 | 67 | ||
| 65 | # | 68 | # |
| 66 | # General setup | 69 | # General setup |
| @@ -111,7 +114,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 111 | CONFIG_KALLSYMS=y | 114 | CONFIG_KALLSYMS=y |
| 112 | # CONFIG_KALLSYMS_ALL is not set | 115 | # CONFIG_KALLSYMS_ALL is not set |
| 113 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 116 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 114 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 115 | CONFIG_HOTPLUG=y | 117 | CONFIG_HOTPLUG=y |
| 116 | CONFIG_PRINTK=y | 118 | CONFIG_PRINTK=y |
| 117 | CONFIG_BUG=y | 119 | CONFIG_BUG=y |
| @@ -124,7 +126,14 @@ CONFIG_TIMERFD=y | |||
| 124 | CONFIG_EVENTFD=y | 126 | CONFIG_EVENTFD=y |
| 125 | CONFIG_SHMEM=y | 127 | CONFIG_SHMEM=y |
| 126 | CONFIG_AIO=y | 128 | CONFIG_AIO=y |
| 129 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 130 | |||
| 131 | # | ||
| 132 | # Performance Counters | ||
| 133 | # | ||
| 134 | # CONFIG_PERF_COUNTERS is not set | ||
| 127 | CONFIG_VM_EVENT_COUNTERS=y | 135 | CONFIG_VM_EVENT_COUNTERS=y |
| 136 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 128 | CONFIG_COMPAT_BRK=y | 137 | CONFIG_COMPAT_BRK=y |
| 129 | CONFIG_SLAB=y | 138 | CONFIG_SLAB=y |
| 130 | # CONFIG_SLUB is not set | 139 | # CONFIG_SLUB is not set |
| @@ -137,6 +146,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 137 | CONFIG_HAVE_KPROBES=y | 146 | CONFIG_HAVE_KPROBES=y |
| 138 | CONFIG_HAVE_KRETPROBES=y | 147 | CONFIG_HAVE_KRETPROBES=y |
| 139 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 148 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 149 | |||
| 150 | # | ||
| 151 | # GCOV-based kernel profiling | ||
| 152 | # | ||
| 140 | # CONFIG_SLOW_WORK is not set | 153 | # CONFIG_SLOW_WORK is not set |
| 141 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 142 | CONFIG_SLABINFO=y | 155 | CONFIG_SLABINFO=y |
| @@ -144,7 +157,7 @@ CONFIG_RT_MUTEXES=y | |||
| 144 | CONFIG_BASE_SMALL=0 | 157 | CONFIG_BASE_SMALL=0 |
| 145 | # CONFIG_MODULES is not set | 158 | # CONFIG_MODULES is not set |
| 146 | CONFIG_BLOCK=y | 159 | CONFIG_BLOCK=y |
| 147 | # CONFIG_LBD is not set | 160 | CONFIG_LBDAF=y |
| 148 | # CONFIG_BLK_DEV_BSG is not set | 161 | # CONFIG_BLK_DEV_BSG is not set |
| 149 | # CONFIG_BLK_DEV_INTEGRITY is not set | 162 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 150 | 163 | ||
| @@ -177,6 +190,7 @@ CONFIG_MPC85xx=y | |||
| 177 | # CONFIG_MPC85xx_DS is not set | 190 | # CONFIG_MPC85xx_DS is not set |
| 178 | # CONFIG_SOCRATES is not set | 191 | # CONFIG_SOCRATES is not set |
| 179 | # CONFIG_KSI8560 is not set | 192 | # CONFIG_KSI8560 is not set |
| 193 | # CONFIG_XES_MPC85xx is not set | ||
| 180 | # CONFIG_STX_GP3 is not set | 194 | # CONFIG_STX_GP3 is not set |
| 181 | # CONFIG_TQM8540 is not set | 195 | # CONFIG_TQM8540 is not set |
| 182 | # CONFIG_TQM8541 is not set | 196 | # CONFIG_TQM8541 is not set |
| @@ -224,6 +238,7 @@ CONFIG_BINFMT_ELF=y | |||
| 224 | CONFIG_BINFMT_MISC=y | 238 | CONFIG_BINFMT_MISC=y |
| 225 | # CONFIG_MATH_EMULATION is not set | 239 | # CONFIG_MATH_EMULATION is not set |
| 226 | # CONFIG_IOMMU_HELPER is not set | 240 | # CONFIG_IOMMU_HELPER is not set |
| 241 | # CONFIG_SWIOTLB is not set | ||
| 227 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 242 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 228 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 243 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 229 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 244 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -242,9 +257,9 @@ CONFIG_MIGRATION=y | |||
| 242 | CONFIG_ZONE_DMA_FLAG=1 | 257 | CONFIG_ZONE_DMA_FLAG=1 |
| 243 | CONFIG_BOUNCE=y | 258 | CONFIG_BOUNCE=y |
| 244 | CONFIG_VIRT_TO_BUS=y | 259 | CONFIG_VIRT_TO_BUS=y |
| 245 | CONFIG_UNEVICTABLE_LRU=y | ||
| 246 | CONFIG_HAVE_MLOCK=y | 260 | CONFIG_HAVE_MLOCK=y |
| 247 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 261 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 262 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 248 | CONFIG_PPC_4K_PAGES=y | 263 | CONFIG_PPC_4K_PAGES=y |
| 249 | # CONFIG_PPC_16K_PAGES is not set | 264 | # CONFIG_PPC_16K_PAGES is not set |
| 250 | # CONFIG_PPC_64K_PAGES is not set | 265 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -346,6 +361,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 346 | # CONFIG_ECONET is not set | 361 | # CONFIG_ECONET is not set |
| 347 | # CONFIG_WAN_ROUTER is not set | 362 | # CONFIG_WAN_ROUTER is not set |
| 348 | # CONFIG_PHONET is not set | 363 | # CONFIG_PHONET is not set |
| 364 | # CONFIG_IEEE802154 is not set | ||
| 349 | # CONFIG_NET_SCHED is not set | 365 | # CONFIG_NET_SCHED is not set |
| 350 | # CONFIG_DCB is not set | 366 | # CONFIG_DCB is not set |
| 351 | 367 | ||
| @@ -363,7 +379,11 @@ CONFIG_WIRELESS=y | |||
| 363 | CONFIG_WIRELESS_OLD_REGULATORY=y | 379 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 364 | # CONFIG_WIRELESS_EXT is not set | 380 | # CONFIG_WIRELESS_EXT is not set |
| 365 | # CONFIG_LIB80211 is not set | 381 | # CONFIG_LIB80211 is not set |
| 366 | # CONFIG_MAC80211 is not set | 382 | |
| 383 | # | ||
| 384 | # CFG80211 needs to be enabled for MAC80211 | ||
| 385 | # | ||
| 386 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 367 | # CONFIG_WIMAX is not set | 387 | # CONFIG_WIMAX is not set |
| 368 | # CONFIG_RFKILL is not set | 388 | # CONFIG_RFKILL is not set |
| 369 | # CONFIG_NET_9P is not set | 389 | # CONFIG_NET_9P is not set |
| @@ -385,6 +405,7 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 385 | # CONFIG_CONNECTOR is not set | 405 | # CONFIG_CONNECTOR is not set |
| 386 | # CONFIG_MTD is not set | 406 | # CONFIG_MTD is not set |
| 387 | CONFIG_OF_DEVICE=y | 407 | CONFIG_OF_DEVICE=y |
| 408 | CONFIG_OF_MDIO=y | ||
| 388 | # CONFIG_PARPORT is not set | 409 | # CONFIG_PARPORT is not set |
| 389 | CONFIG_BLK_DEV=y | 410 | CONFIG_BLK_DEV=y |
| 390 | # CONFIG_BLK_DEV_FD is not set | 411 | # CONFIG_BLK_DEV_FD is not set |
| @@ -421,7 +442,6 @@ CONFIG_HAVE_IDE=y | |||
| 421 | # CONFIG_MD is not set | 442 | # CONFIG_MD is not set |
| 422 | # CONFIG_MACINTOSH_DRIVERS is not set | 443 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 423 | CONFIG_NETDEVICES=y | 444 | CONFIG_NETDEVICES=y |
| 424 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 425 | # CONFIG_DUMMY is not set | 445 | # CONFIG_DUMMY is not set |
| 426 | # CONFIG_BONDING is not set | 446 | # CONFIG_BONDING is not set |
| 427 | # CONFIG_MACVLAN is not set | 447 | # CONFIG_MACVLAN is not set |
| @@ -460,9 +480,11 @@ CONFIG_MII=y | |||
| 460 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 480 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 461 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 481 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 462 | # CONFIG_B44 is not set | 482 | # CONFIG_B44 is not set |
| 483 | # CONFIG_KS8842 is not set | ||
| 463 | CONFIG_NETDEV_1000=y | 484 | CONFIG_NETDEV_1000=y |
| 464 | CONFIG_FSL_PQ_MDIO=y | 485 | CONFIG_FSL_PQ_MDIO=y |
| 465 | CONFIG_GIANFAR=y | 486 | CONFIG_GIANFAR=y |
| 487 | # CONFIG_MV643XX_ETH is not set | ||
| 466 | CONFIG_NETDEV_10000=y | 488 | CONFIG_NETDEV_10000=y |
| 467 | 489 | ||
| 468 | # | 490 | # |
| @@ -551,6 +573,11 @@ CONFIG_LEGACY_PTY_COUNT=256 | |||
| 551 | # CONFIG_TCG_TPM is not set | 573 | # CONFIG_TCG_TPM is not set |
| 552 | # CONFIG_I2C is not set | 574 | # CONFIG_I2C is not set |
| 553 | # CONFIG_SPI is not set | 575 | # CONFIG_SPI is not set |
| 576 | |||
| 577 | # | ||
| 578 | # PPS support | ||
| 579 | # | ||
| 580 | # CONFIG_PPS is not set | ||
| 554 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 581 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 555 | # CONFIG_GPIOLIB is not set | 582 | # CONFIG_GPIOLIB is not set |
| 556 | # CONFIG_W1 is not set | 583 | # CONFIG_W1 is not set |
| @@ -586,22 +613,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 586 | # CONFIG_HTC_PASIC3 is not set | 613 | # CONFIG_HTC_PASIC3 is not set |
| 587 | # CONFIG_MFD_TMIO is not set | 614 | # CONFIG_MFD_TMIO is not set |
| 588 | # CONFIG_REGULATOR is not set | 615 | # CONFIG_REGULATOR is not set |
| 589 | 616 | # CONFIG_MEDIA_SUPPORT is not set | |
| 590 | # | ||
| 591 | # Multimedia devices | ||
| 592 | # | ||
| 593 | |||
| 594 | # | ||
| 595 | # Multimedia core support | ||
| 596 | # | ||
| 597 | # CONFIG_VIDEO_DEV is not set | ||
| 598 | # CONFIG_DVB_CORE is not set | ||
| 599 | # CONFIG_VIDEO_MEDIA is not set | ||
| 600 | |||
| 601 | # | ||
| 602 | # Multimedia drivers | ||
| 603 | # | ||
| 604 | CONFIG_DAB=y | ||
| 605 | 617 | ||
| 606 | # | 618 | # |
| 607 | # Graphics support | 619 | # Graphics support |
| @@ -690,6 +702,10 @@ CONFIG_RTC_DRV_M48T59=y | |||
| 690 | # CONFIG_DMADEVICES is not set | 702 | # CONFIG_DMADEVICES is not set |
| 691 | # CONFIG_AUXDISPLAY is not set | 703 | # CONFIG_AUXDISPLAY is not set |
| 692 | # CONFIG_UIO is not set | 704 | # CONFIG_UIO is not set |
| 705 | |||
| 706 | # | ||
| 707 | # TI VLYNQ | ||
| 708 | # | ||
| 693 | # CONFIG_STAGING is not set | 709 | # CONFIG_STAGING is not set |
| 694 | 710 | ||
| 695 | # | 711 | # |
| @@ -701,10 +717,12 @@ CONFIG_RTC_DRV_M48T59=y | |||
| 701 | # CONFIG_REISERFS_FS is not set | 717 | # CONFIG_REISERFS_FS is not set |
| 702 | # CONFIG_JFS_FS is not set | 718 | # CONFIG_JFS_FS is not set |
| 703 | # CONFIG_FS_POSIX_ACL is not set | 719 | # CONFIG_FS_POSIX_ACL is not set |
| 704 | CONFIG_FILE_LOCKING=y | ||
| 705 | # CONFIG_XFS_FS is not set | 720 | # CONFIG_XFS_FS is not set |
| 721 | # CONFIG_GFS2_FS is not set | ||
| 706 | # CONFIG_OCFS2_FS is not set | 722 | # CONFIG_OCFS2_FS is not set |
| 707 | # CONFIG_BTRFS_FS is not set | 723 | # CONFIG_BTRFS_FS is not set |
| 724 | CONFIG_FILE_LOCKING=y | ||
| 725 | CONFIG_FSNOTIFY=y | ||
| 708 | CONFIG_DNOTIFY=y | 726 | CONFIG_DNOTIFY=y |
| 709 | CONFIG_INOTIFY=y | 727 | CONFIG_INOTIFY=y |
| 710 | CONFIG_INOTIFY_USER=y | 728 | CONFIG_INOTIFY_USER=y |
| @@ -819,6 +837,7 @@ CONFIG_HAS_IOPORT=y | |||
| 819 | CONFIG_HAS_DMA=y | 837 | CONFIG_HAS_DMA=y |
| 820 | CONFIG_HAVE_LMB=y | 838 | CONFIG_HAVE_LMB=y |
| 821 | CONFIG_NLATTR=y | 839 | CONFIG_NLATTR=y |
| 840 | CONFIG_GENERIC_ATOMIC64=y | ||
| 822 | 841 | ||
| 823 | # | 842 | # |
| 824 | # Kernel hacking | 843 | # Kernel hacking |
| @@ -848,6 +867,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 848 | # CONFIG_RT_MUTEX_TESTER is not set | 867 | # CONFIG_RT_MUTEX_TESTER is not set |
| 849 | # CONFIG_DEBUG_SPINLOCK is not set | 868 | # CONFIG_DEBUG_SPINLOCK is not set |
| 850 | CONFIG_DEBUG_MUTEXES=y | 869 | CONFIG_DEBUG_MUTEXES=y |
| 870 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 871 | # CONFIG_PROVE_LOCKING is not set | ||
| 872 | # CONFIG_LOCK_STAT is not set | ||
| 851 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 873 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 852 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 874 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 853 | # CONFIG_DEBUG_KOBJECT is not set | 875 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -859,7 +881,6 @@ CONFIG_DEBUG_MUTEXES=y | |||
| 859 | # CONFIG_DEBUG_LIST is not set | 881 | # CONFIG_DEBUG_LIST is not set |
| 860 | # CONFIG_DEBUG_SG is not set | 882 | # CONFIG_DEBUG_SG is not set |
| 861 | # CONFIG_DEBUG_NOTIFIERS is not set | 883 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 862 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 863 | # CONFIG_RCU_TORTURE_TEST is not set | 884 | # CONFIG_RCU_TORTURE_TEST is not set |
| 864 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 885 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 865 | # CONFIG_BACKTRACE_SELF_TEST is not set | 886 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -873,16 +894,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 873 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 894 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 874 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 895 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 875 | CONFIG_TRACING_SUPPORT=y | 896 | CONFIG_TRACING_SUPPORT=y |
| 876 | 897 | CONFIG_FTRACE=y | |
| 877 | # | ||
| 878 | # Tracers | ||
| 879 | # | ||
| 880 | # CONFIG_FUNCTION_TRACER is not set | 898 | # CONFIG_FUNCTION_TRACER is not set |
| 899 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 881 | # CONFIG_SCHED_TRACER is not set | 900 | # CONFIG_SCHED_TRACER is not set |
| 882 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 901 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 883 | # CONFIG_EVENT_TRACER is not set | ||
| 884 | # CONFIG_BOOT_TRACER is not set | 902 | # CONFIG_BOOT_TRACER is not set |
| 885 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 903 | CONFIG_BRANCH_PROFILE_NONE=y |
| 904 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 905 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 886 | # CONFIG_STACK_TRACER is not set | 906 | # CONFIG_STACK_TRACER is not set |
| 887 | # CONFIG_KMEMTRACE is not set | 907 | # CONFIG_KMEMTRACE is not set |
| 888 | # CONFIG_WORKQUEUE_TRACER is not set | 908 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -890,6 +910,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 890 | # CONFIG_SAMPLES is not set | 910 | # CONFIG_SAMPLES is not set |
| 891 | CONFIG_HAVE_ARCH_KGDB=y | 911 | CONFIG_HAVE_ARCH_KGDB=y |
| 892 | # CONFIG_KGDB is not set | 912 | # CONFIG_KGDB is not set |
| 913 | # CONFIG_KMEMCHECK is not set | ||
| 914 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 915 | CONFIG_PPC_WERROR=y | ||
| 893 | CONFIG_PRINT_STACK_DEPTH=64 | 916 | CONFIG_PRINT_STACK_DEPTH=64 |
| 894 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 917 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 895 | # CONFIG_DEBUG_STACK_USAGE is not set | 918 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/85xx/socrates_defconfig b/arch/powerpc/configs/85xx/socrates_defconfig index 79984589db69..04c85dada845 100644 --- a/arch/powerpc/configs/85xx/socrates_defconfig +++ b/arch/powerpc/configs/85xx/socrates_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:21 2009 | 4 | # Wed Jul 29 23:32:19 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -34,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 34 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 35 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 36 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 38 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 39 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 41 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 43 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 44 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 45 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 48 | CONFIG_PPC=y | 49 | CONFIG_PPC=y |
| @@ -56,11 +57,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 56 | # CONFIG_GENERIC_TBSYNC is not set | 57 | # CONFIG_GENERIC_TBSYNC is not set |
| 57 | CONFIG_AUDIT_ARCH=y | 58 | CONFIG_AUDIT_ARCH=y |
| 58 | CONFIG_GENERIC_BUG=y | 59 | CONFIG_GENERIC_BUG=y |
| 60 | CONFIG_DTC=y | ||
| 59 | CONFIG_DEFAULT_UIMAGE=y | 61 | CONFIG_DEFAULT_UIMAGE=y |
| 60 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 61 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 62 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 63 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 64 | 67 | ||
| 65 | # | 68 | # |
| 66 | # General setup | 69 | # General setup |
| @@ -109,7 +112,6 @@ CONFIG_ANON_INODES=y | |||
| 109 | CONFIG_EMBEDDED=y | 112 | CONFIG_EMBEDDED=y |
| 110 | CONFIG_SYSCTL_SYSCALL=y | 113 | CONFIG_SYSCTL_SYSCALL=y |
| 111 | # CONFIG_KALLSYMS is not set | 114 | # CONFIG_KALLSYMS is not set |
| 112 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 113 | # CONFIG_HOTPLUG is not set | 115 | # CONFIG_HOTPLUG is not set |
| 114 | CONFIG_PRINTK=y | 116 | CONFIG_PRINTK=y |
| 115 | CONFIG_BUG=y | 117 | CONFIG_BUG=y |
| @@ -122,9 +124,16 @@ CONFIG_TIMERFD=y | |||
| 122 | CONFIG_EVENTFD=y | 124 | CONFIG_EVENTFD=y |
| 123 | CONFIG_SHMEM=y | 125 | CONFIG_SHMEM=y |
| 124 | CONFIG_AIO=y | 126 | CONFIG_AIO=y |
| 127 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 128 | |||
| 129 | # | ||
| 130 | # Performance Counters | ||
| 131 | # | ||
| 132 | # CONFIG_PERF_COUNTERS is not set | ||
| 125 | CONFIG_VM_EVENT_COUNTERS=y | 133 | CONFIG_VM_EVENT_COUNTERS=y |
| 126 | CONFIG_PCI_QUIRKS=y | 134 | CONFIG_PCI_QUIRKS=y |
| 127 | CONFIG_SLUB_DEBUG=y | 135 | CONFIG_SLUB_DEBUG=y |
| 136 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 128 | CONFIG_COMPAT_BRK=y | 137 | CONFIG_COMPAT_BRK=y |
| 129 | # CONFIG_SLAB is not set | 138 | # CONFIG_SLAB is not set |
| 130 | CONFIG_SLUB=y | 139 | CONFIG_SLUB=y |
| @@ -137,6 +146,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 137 | CONFIG_HAVE_KPROBES=y | 146 | CONFIG_HAVE_KPROBES=y |
| 138 | CONFIG_HAVE_KRETPROBES=y | 147 | CONFIG_HAVE_KRETPROBES=y |
| 139 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 148 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 149 | |||
| 150 | # | ||
| 151 | # GCOV-based kernel profiling | ||
| 152 | # | ||
| 140 | # CONFIG_SLOW_WORK is not set | 153 | # CONFIG_SLOW_WORK is not set |
| 141 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 142 | CONFIG_SLABINFO=y | 155 | CONFIG_SLABINFO=y |
| @@ -149,7 +162,7 @@ CONFIG_MODULE_FORCE_UNLOAD=y | |||
| 149 | # CONFIG_MODVERSIONS is not set | 162 | # CONFIG_MODVERSIONS is not set |
| 150 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 163 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 151 | CONFIG_BLOCK=y | 164 | CONFIG_BLOCK=y |
| 152 | # CONFIG_LBD is not set | 165 | CONFIG_LBDAF=y |
| 153 | # CONFIG_BLK_DEV_BSG is not set | 166 | # CONFIG_BLK_DEV_BSG is not set |
| 154 | # CONFIG_BLK_DEV_INTEGRITY is not set | 167 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 155 | 168 | ||
| @@ -182,6 +195,7 @@ CONFIG_MPC85xx=y | |||
| 182 | # CONFIG_MPC85xx_DS is not set | 195 | # CONFIG_MPC85xx_DS is not set |
| 183 | CONFIG_SOCRATES=y | 196 | CONFIG_SOCRATES=y |
| 184 | # CONFIG_KSI8560 is not set | 197 | # CONFIG_KSI8560 is not set |
| 198 | # CONFIG_XES_MPC85xx is not set | ||
| 185 | # CONFIG_STX_GP3 is not set | 199 | # CONFIG_STX_GP3 is not set |
| 186 | # CONFIG_TQM8540 is not set | 200 | # CONFIG_TQM8540 is not set |
| 187 | # CONFIG_TQM8541 is not set | 201 | # CONFIG_TQM8541 is not set |
| @@ -229,6 +243,7 @@ CONFIG_BINFMT_ELF=y | |||
| 229 | # CONFIG_BINFMT_MISC is not set | 243 | # CONFIG_BINFMT_MISC is not set |
| 230 | CONFIG_MATH_EMULATION=y | 244 | CONFIG_MATH_EMULATION=y |
| 231 | # CONFIG_IOMMU_HELPER is not set | 245 | # CONFIG_IOMMU_HELPER is not set |
| 246 | # CONFIG_SWIOTLB is not set | ||
| 232 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 247 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 233 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 248 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 234 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 249 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -247,9 +262,9 @@ CONFIG_MIGRATION=y | |||
| 247 | CONFIG_ZONE_DMA_FLAG=1 | 262 | CONFIG_ZONE_DMA_FLAG=1 |
| 248 | CONFIG_BOUNCE=y | 263 | CONFIG_BOUNCE=y |
| 249 | CONFIG_VIRT_TO_BUS=y | 264 | CONFIG_VIRT_TO_BUS=y |
| 250 | CONFIG_UNEVICTABLE_LRU=y | ||
| 251 | CONFIG_HAVE_MLOCK=y | 265 | CONFIG_HAVE_MLOCK=y |
| 252 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 266 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 267 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 253 | CONFIG_PPC_4K_PAGES=y | 268 | CONFIG_PPC_4K_PAGES=y |
| 254 | # CONFIG_PPC_16K_PAGES is not set | 269 | # CONFIG_PPC_16K_PAGES is not set |
| 255 | # CONFIG_PPC_64K_PAGES is not set | 270 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -357,6 +372,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 357 | # CONFIG_ECONET is not set | 372 | # CONFIG_ECONET is not set |
| 358 | # CONFIG_WAN_ROUTER is not set | 373 | # CONFIG_WAN_ROUTER is not set |
| 359 | # CONFIG_PHONET is not set | 374 | # CONFIG_PHONET is not set |
| 375 | # CONFIG_IEEE802154 is not set | ||
| 360 | # CONFIG_NET_SCHED is not set | 376 | # CONFIG_NET_SCHED is not set |
| 361 | # CONFIG_DCB is not set | 377 | # CONFIG_DCB is not set |
| 362 | 378 | ||
| @@ -373,6 +389,7 @@ CONFIG_CAN_BCM=y | |||
| 373 | # CAN Device Drivers | 389 | # CAN Device Drivers |
| 374 | # | 390 | # |
| 375 | # CONFIG_CAN_VCAN is not set | 391 | # CONFIG_CAN_VCAN is not set |
| 392 | # CONFIG_CAN_DEV is not set | ||
| 376 | # CONFIG_CAN_DEBUG_DEVICES is not set | 393 | # CONFIG_CAN_DEBUG_DEVICES is not set |
| 377 | # CONFIG_IRDA is not set | 394 | # CONFIG_IRDA is not set |
| 378 | # CONFIG_BT is not set | 395 | # CONFIG_BT is not set |
| @@ -382,7 +399,11 @@ CONFIG_WIRELESS=y | |||
| 382 | # CONFIG_WIRELESS_OLD_REGULATORY is not set | 399 | # CONFIG_WIRELESS_OLD_REGULATORY is not set |
| 383 | # CONFIG_WIRELESS_EXT is not set | 400 | # CONFIG_WIRELESS_EXT is not set |
| 384 | # CONFIG_LIB80211 is not set | 401 | # CONFIG_LIB80211 is not set |
| 385 | # CONFIG_MAC80211 is not set | 402 | |
| 403 | # | ||
| 404 | # CFG80211 needs to be enabled for MAC80211 | ||
| 405 | # | ||
| 406 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 386 | # CONFIG_WIMAX is not set | 407 | # CONFIG_WIMAX is not set |
| 387 | # CONFIG_RFKILL is not set | 408 | # CONFIG_RFKILL is not set |
| 388 | # CONFIG_NET_9P is not set | 409 | # CONFIG_NET_9P is not set |
| @@ -499,6 +520,7 @@ CONFIG_MTD_NAND_SOCRATES=y | |||
| 499 | CONFIG_OF_DEVICE=y | 520 | CONFIG_OF_DEVICE=y |
| 500 | CONFIG_OF_I2C=y | 521 | CONFIG_OF_I2C=y |
| 501 | CONFIG_OF_SPI=y | 522 | CONFIG_OF_SPI=y |
| 523 | CONFIG_OF_MDIO=y | ||
| 502 | # CONFIG_PARPORT is not set | 524 | # CONFIG_PARPORT is not set |
| 503 | CONFIG_BLK_DEV=y | 525 | CONFIG_BLK_DEV=y |
| 504 | # CONFIG_BLK_DEV_FD is not set | 526 | # CONFIG_BLK_DEV_FD is not set |
| @@ -535,7 +557,9 @@ CONFIG_MISC_DEVICES=y | |||
| 535 | # CONFIG_EEPROM_AT24 is not set | 557 | # CONFIG_EEPROM_AT24 is not set |
| 536 | # CONFIG_EEPROM_AT25 is not set | 558 | # CONFIG_EEPROM_AT25 is not set |
| 537 | # CONFIG_EEPROM_LEGACY is not set | 559 | # CONFIG_EEPROM_LEGACY is not set |
| 560 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 538 | # CONFIG_EEPROM_93CX6 is not set | 561 | # CONFIG_EEPROM_93CX6 is not set |
| 562 | # CONFIG_CB710_CORE is not set | ||
| 539 | CONFIG_HAVE_IDE=y | 563 | CONFIG_HAVE_IDE=y |
| 540 | # CONFIG_IDE is not set | 564 | # CONFIG_IDE is not set |
| 541 | 565 | ||
| @@ -558,10 +582,6 @@ CONFIG_BLK_DEV_SD=y | |||
| 558 | # CONFIG_BLK_DEV_SR is not set | 582 | # CONFIG_BLK_DEV_SR is not set |
| 559 | # CONFIG_CHR_DEV_SG is not set | 583 | # CONFIG_CHR_DEV_SG is not set |
| 560 | # CONFIG_CHR_DEV_SCH is not set | 584 | # CONFIG_CHR_DEV_SCH is not set |
| 561 | |||
| 562 | # | ||
| 563 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 564 | # | ||
| 565 | # CONFIG_SCSI_MULTI_LUN is not set | 585 | # CONFIG_SCSI_MULTI_LUN is not set |
| 566 | # CONFIG_SCSI_CONSTANTS is not set | 586 | # CONFIG_SCSI_CONSTANTS is not set |
| 567 | # CONFIG_SCSI_LOGGING is not set | 587 | # CONFIG_SCSI_LOGGING is not set |
| @@ -588,14 +608,17 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 588 | # | 608 | # |
| 589 | 609 | ||
| 590 | # | 610 | # |
| 591 | # Enable only one of the two stacks, unless you know what you are doing | 611 | # You can enable one or both FireWire driver stacks. |
| 612 | # | ||
| 613 | |||
| 614 | # | ||
| 615 | # See the help texts for more information. | ||
| 592 | # | 616 | # |
| 593 | # CONFIG_FIREWIRE is not set | 617 | # CONFIG_FIREWIRE is not set |
| 594 | # CONFIG_IEEE1394 is not set | 618 | # CONFIG_IEEE1394 is not set |
| 595 | # CONFIG_I2O is not set | 619 | # CONFIG_I2O is not set |
| 596 | # CONFIG_MACINTOSH_DRIVERS is not set | 620 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 597 | CONFIG_NETDEVICES=y | 621 | CONFIG_NETDEVICES=y |
| 598 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 599 | # CONFIG_DUMMY is not set | 622 | # CONFIG_DUMMY is not set |
| 600 | # CONFIG_BONDING is not set | 623 | # CONFIG_BONDING is not set |
| 601 | # CONFIG_MACVLAN is not set | 624 | # CONFIG_MACVLAN is not set |
| @@ -643,6 +666,8 @@ CONFIG_MII=y | |||
| 643 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 666 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 644 | # CONFIG_NET_PCI is not set | 667 | # CONFIG_NET_PCI is not set |
| 645 | # CONFIG_B44 is not set | 668 | # CONFIG_B44 is not set |
| 669 | # CONFIG_KS8842 is not set | ||
| 670 | # CONFIG_KS8851 is not set | ||
| 646 | # CONFIG_ATL2 is not set | 671 | # CONFIG_ATL2 is not set |
| 647 | CONFIG_NETDEV_1000=y | 672 | CONFIG_NETDEV_1000=y |
| 648 | # CONFIG_ACENIC is not set | 673 | # CONFIG_ACENIC is not set |
| @@ -662,8 +687,10 @@ CONFIG_NETDEV_1000=y | |||
| 662 | # CONFIG_VIA_VELOCITY is not set | 687 | # CONFIG_VIA_VELOCITY is not set |
| 663 | # CONFIG_TIGON3 is not set | 688 | # CONFIG_TIGON3 is not set |
| 664 | # CONFIG_BNX2 is not set | 689 | # CONFIG_BNX2 is not set |
| 690 | # CONFIG_CNIC is not set | ||
| 665 | CONFIG_FSL_PQ_MDIO=y | 691 | CONFIG_FSL_PQ_MDIO=y |
| 666 | CONFIG_GIANFAR=y | 692 | CONFIG_GIANFAR=y |
| 693 | # CONFIG_MV643XX_ETH is not set | ||
| 667 | # CONFIG_QLA3XXX is not set | 694 | # CONFIG_QLA3XXX is not set |
| 668 | # CONFIG_ATL1 is not set | 695 | # CONFIG_ATL1 is not set |
| 669 | # CONFIG_ATL1E is not set | 696 | # CONFIG_ATL1E is not set |
| @@ -733,6 +760,7 @@ CONFIG_INPUT_TOUCHSCREEN=y | |||
| 733 | # CONFIG_TOUCHSCREEN_AD7879_I2C is not set | 760 | # CONFIG_TOUCHSCREEN_AD7879_I2C is not set |
| 734 | # CONFIG_TOUCHSCREEN_AD7879_SPI is not set | 761 | # CONFIG_TOUCHSCREEN_AD7879_SPI is not set |
| 735 | # CONFIG_TOUCHSCREEN_AD7879 is not set | 762 | # CONFIG_TOUCHSCREEN_AD7879 is not set |
| 763 | # CONFIG_TOUCHSCREEN_EETI is not set | ||
| 736 | # CONFIG_TOUCHSCREEN_FUJITSU is not set | 764 | # CONFIG_TOUCHSCREEN_FUJITSU is not set |
| 737 | # CONFIG_TOUCHSCREEN_GUNZE is not set | 765 | # CONFIG_TOUCHSCREEN_GUNZE is not set |
| 738 | # CONFIG_TOUCHSCREEN_ELO is not set | 766 | # CONFIG_TOUCHSCREEN_ELO is not set |
| @@ -746,6 +774,7 @@ CONFIG_INPUT_TOUCHSCREEN=y | |||
| 746 | # CONFIG_TOUCHSCREEN_USB_COMPOSITE is not set | 774 | # CONFIG_TOUCHSCREEN_USB_COMPOSITE is not set |
| 747 | # CONFIG_TOUCHSCREEN_TOUCHIT213 is not set | 775 | # CONFIG_TOUCHSCREEN_TOUCHIT213 is not set |
| 748 | # CONFIG_TOUCHSCREEN_TSC2007 is not set | 776 | # CONFIG_TOUCHSCREEN_TSC2007 is not set |
| 777 | # CONFIG_TOUCHSCREEN_W90X900 is not set | ||
| 749 | # CONFIG_INPUT_MISC is not set | 778 | # CONFIG_INPUT_MISC is not set |
| 750 | 779 | ||
| 751 | # | 780 | # |
| @@ -862,7 +891,6 @@ CONFIG_I2C_MPC=y | |||
| 862 | # CONFIG_SENSORS_PCF8574 is not set | 891 | # CONFIG_SENSORS_PCF8574 is not set |
| 863 | # CONFIG_PCF8575 is not set | 892 | # CONFIG_PCF8575 is not set |
| 864 | # CONFIG_SENSORS_PCA9539 is not set | 893 | # CONFIG_SENSORS_PCA9539 is not set |
| 865 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 866 | # CONFIG_SENSORS_TSL2550 is not set | 894 | # CONFIG_SENSORS_TSL2550 is not set |
| 867 | # CONFIG_I2C_DEBUG_CORE is not set | 895 | # CONFIG_I2C_DEBUG_CORE is not set |
| 868 | # CONFIG_I2C_DEBUG_ALGO is not set | 896 | # CONFIG_I2C_DEBUG_ALGO is not set |
| @@ -875,12 +903,18 @@ CONFIG_SPI_MASTER=y | |||
| 875 | # SPI Master Controller Drivers | 903 | # SPI Master Controller Drivers |
| 876 | # | 904 | # |
| 877 | # CONFIG_SPI_BITBANG is not set | 905 | # CONFIG_SPI_BITBANG is not set |
| 906 | # CONFIG_SPI_MPC8xxx is not set | ||
| 878 | 907 | ||
| 879 | # | 908 | # |
| 880 | # SPI Protocol Masters | 909 | # SPI Protocol Masters |
| 881 | # | 910 | # |
| 882 | # CONFIG_SPI_SPIDEV is not set | 911 | # CONFIG_SPI_SPIDEV is not set |
| 883 | # CONFIG_SPI_TLE62X0 is not set | 912 | # CONFIG_SPI_TLE62X0 is not set |
| 913 | |||
| 914 | # | ||
| 915 | # PPS support | ||
| 916 | # | ||
| 917 | # CONFIG_PPS is not set | ||
| 884 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 918 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 885 | # CONFIG_GPIOLIB is not set | 919 | # CONFIG_GPIOLIB is not set |
| 886 | # CONFIG_W1 is not set | 920 | # CONFIG_W1 is not set |
| @@ -938,6 +972,7 @@ CONFIG_SENSORS_LM75=y | |||
| 938 | # CONFIG_SENSORS_SMSC47B397 is not set | 972 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 939 | # CONFIG_SENSORS_ADS7828 is not set | 973 | # CONFIG_SENSORS_ADS7828 is not set |
| 940 | # CONFIG_SENSORS_THMC50 is not set | 974 | # CONFIG_SENSORS_THMC50 is not set |
| 975 | # CONFIG_SENSORS_TMP401 is not set | ||
| 941 | # CONFIG_SENSORS_VIA686A is not set | 976 | # CONFIG_SENSORS_VIA686A is not set |
| 942 | # CONFIG_SENSORS_VT1211 is not set | 977 | # CONFIG_SENSORS_VT1211 is not set |
| 943 | # CONFIG_SENSORS_VT8231 is not set | 978 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -973,24 +1008,10 @@ CONFIG_SSB_POSSIBLE=y | |||
| 973 | # CONFIG_MFD_WM8400 is not set | 1008 | # CONFIG_MFD_WM8400 is not set |
| 974 | # CONFIG_MFD_WM8350_I2C is not set | 1009 | # CONFIG_MFD_WM8350_I2C is not set |
| 975 | # CONFIG_MFD_PCF50633 is not set | 1010 | # CONFIG_MFD_PCF50633 is not set |
| 1011 | # CONFIG_AB3100_CORE is not set | ||
| 1012 | # CONFIG_EZX_PCAP is not set | ||
| 976 | # CONFIG_REGULATOR is not set | 1013 | # CONFIG_REGULATOR is not set |
| 977 | 1014 | # CONFIG_MEDIA_SUPPORT is not set | |
| 978 | # | ||
| 979 | # Multimedia devices | ||
| 980 | # | ||
| 981 | |||
| 982 | # | ||
| 983 | # Multimedia core support | ||
| 984 | # | ||
| 985 | # CONFIG_VIDEO_DEV is not set | ||
| 986 | # CONFIG_DVB_CORE is not set | ||
| 987 | # CONFIG_VIDEO_MEDIA is not set | ||
| 988 | |||
| 989 | # | ||
| 990 | # Multimedia drivers | ||
| 991 | # | ||
| 992 | CONFIG_DAB=y | ||
| 993 | # CONFIG_USB_DABUSB is not set | ||
| 994 | 1015 | ||
| 995 | # | 1016 | # |
| 996 | # Graphics support | 1017 | # Graphics support |
| @@ -1110,7 +1131,7 @@ CONFIG_USB_HID=y | |||
| 1110 | # CONFIG_HID_CHERRY is not set | 1131 | # CONFIG_HID_CHERRY is not set |
| 1111 | # CONFIG_HID_CHICONY is not set | 1132 | # CONFIG_HID_CHICONY is not set |
| 1112 | # CONFIG_HID_CYPRESS is not set | 1133 | # CONFIG_HID_CYPRESS is not set |
| 1113 | # CONFIG_DRAGONRISE_FF is not set | 1134 | # CONFIG_HID_DRAGONRISE is not set |
| 1114 | # CONFIG_HID_EZKEY is not set | 1135 | # CONFIG_HID_EZKEY is not set |
| 1115 | # CONFIG_HID_KYE is not set | 1136 | # CONFIG_HID_KYE is not set |
| 1116 | # CONFIG_HID_GYRATION is not set | 1137 | # CONFIG_HID_GYRATION is not set |
| @@ -1124,10 +1145,11 @@ CONFIG_USB_HID=y | |||
| 1124 | # CONFIG_HID_SAMSUNG is not set | 1145 | # CONFIG_HID_SAMSUNG is not set |
| 1125 | # CONFIG_HID_SONY is not set | 1146 | # CONFIG_HID_SONY is not set |
| 1126 | # CONFIG_HID_SUNPLUS is not set | 1147 | # CONFIG_HID_SUNPLUS is not set |
| 1127 | # CONFIG_GREENASIA_FF is not set | 1148 | # CONFIG_HID_GREENASIA is not set |
| 1149 | # CONFIG_HID_SMARTJOYPLUS is not set | ||
| 1128 | # CONFIG_HID_TOPSEED is not set | 1150 | # CONFIG_HID_TOPSEED is not set |
| 1129 | # CONFIG_THRUSTMASTER_FF is not set | 1151 | # CONFIG_HID_THRUSTMASTER is not set |
| 1130 | # CONFIG_ZEROPLUS_FF is not set | 1152 | # CONFIG_HID_ZEROPLUS is not set |
| 1131 | CONFIG_USB_SUPPORT=y | 1153 | CONFIG_USB_SUPPORT=y |
| 1132 | CONFIG_USB_ARCH_HAS_HCD=y | 1154 | CONFIG_USB_ARCH_HAS_HCD=y |
| 1133 | CONFIG_USB_ARCH_HAS_OHCI=y | 1155 | CONFIG_USB_ARCH_HAS_OHCI=y |
| @@ -1153,6 +1175,7 @@ CONFIG_USB_MON=y | |||
| 1153 | # USB Host Controller Drivers | 1175 | # USB Host Controller Drivers |
| 1154 | # | 1176 | # |
| 1155 | # CONFIG_USB_C67X00_HCD is not set | 1177 | # CONFIG_USB_C67X00_HCD is not set |
| 1178 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1156 | CONFIG_USB_EHCI_HCD=y | 1179 | CONFIG_USB_EHCI_HCD=y |
| 1157 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set | 1180 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set |
| 1158 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1181 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1162,9 +1185,9 @@ CONFIG_USB_EHCI_HCD_PPC_OF=y | |||
| 1162 | # CONFIG_USB_ISP116X_HCD is not set | 1185 | # CONFIG_USB_ISP116X_HCD is not set |
| 1163 | # CONFIG_USB_ISP1760_HCD is not set | 1186 | # CONFIG_USB_ISP1760_HCD is not set |
| 1164 | CONFIG_USB_OHCI_HCD=y | 1187 | CONFIG_USB_OHCI_HCD=y |
| 1165 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1166 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y | 1188 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y |
| 1167 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set | 1189 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set |
| 1190 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1168 | CONFIG_USB_OHCI_HCD_PCI=y | 1191 | CONFIG_USB_OHCI_HCD_PCI=y |
| 1169 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y | 1192 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y |
| 1170 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y | 1193 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y |
| @@ -1284,6 +1307,7 @@ CONFIG_RTC_INTF_DEV=y | |||
| 1284 | # CONFIG_RTC_DRV_S35390A is not set | 1307 | # CONFIG_RTC_DRV_S35390A is not set |
| 1285 | # CONFIG_RTC_DRV_FM3130 is not set | 1308 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1286 | # CONFIG_RTC_DRV_RX8581 is not set | 1309 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1310 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1287 | 1311 | ||
| 1288 | # | 1312 | # |
| 1289 | # SPI RTC drivers | 1313 | # SPI RTC drivers |
| @@ -1318,6 +1342,10 @@ CONFIG_RTC_INTF_DEV=y | |||
| 1318 | # CONFIG_DMADEVICES is not set | 1342 | # CONFIG_DMADEVICES is not set |
| 1319 | # CONFIG_AUXDISPLAY is not set | 1343 | # CONFIG_AUXDISPLAY is not set |
| 1320 | # CONFIG_UIO is not set | 1344 | # CONFIG_UIO is not set |
| 1345 | |||
| 1346 | # | ||
| 1347 | # TI VLYNQ | ||
| 1348 | # | ||
| 1321 | # CONFIG_STAGING is not set | 1349 | # CONFIG_STAGING is not set |
| 1322 | 1350 | ||
| 1323 | # | 1351 | # |
| @@ -1337,10 +1365,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1337 | # CONFIG_REISERFS_FS is not set | 1365 | # CONFIG_REISERFS_FS is not set |
| 1338 | # CONFIG_JFS_FS is not set | 1366 | # CONFIG_JFS_FS is not set |
| 1339 | # CONFIG_FS_POSIX_ACL is not set | 1367 | # CONFIG_FS_POSIX_ACL is not set |
| 1340 | CONFIG_FILE_LOCKING=y | ||
| 1341 | # CONFIG_XFS_FS is not set | 1368 | # CONFIG_XFS_FS is not set |
| 1369 | # CONFIG_GFS2_FS is not set | ||
| 1342 | # CONFIG_OCFS2_FS is not set | 1370 | # CONFIG_OCFS2_FS is not set |
| 1343 | # CONFIG_BTRFS_FS is not set | 1371 | # CONFIG_BTRFS_FS is not set |
| 1372 | CONFIG_FILE_LOCKING=y | ||
| 1373 | CONFIG_FSNOTIFY=y | ||
| 1344 | CONFIG_DNOTIFY=y | 1374 | CONFIG_DNOTIFY=y |
| 1345 | CONFIG_INOTIFY=y | 1375 | CONFIG_INOTIFY=y |
| 1346 | CONFIG_INOTIFY_USER=y | 1376 | CONFIG_INOTIFY_USER=y |
| @@ -1449,7 +1479,46 @@ CONFIG_MSDOS_PARTITION=y | |||
| 1449 | # CONFIG_KARMA_PARTITION is not set | 1479 | # CONFIG_KARMA_PARTITION is not set |
| 1450 | # CONFIG_EFI_PARTITION is not set | 1480 | # CONFIG_EFI_PARTITION is not set |
| 1451 | # CONFIG_SYSV68_PARTITION is not set | 1481 | # CONFIG_SYSV68_PARTITION is not set |
| 1452 | # CONFIG_NLS is not set | 1482 | CONFIG_NLS=y |
| 1483 | CONFIG_NLS_DEFAULT="iso8859-1" | ||
| 1484 | # CONFIG_NLS_CODEPAGE_437 is not set | ||
| 1485 | # CONFIG_NLS_CODEPAGE_737 is not set | ||
| 1486 | # CONFIG_NLS_CODEPAGE_775 is not set | ||
| 1487 | # CONFIG_NLS_CODEPAGE_850 is not set | ||
| 1488 | # CONFIG_NLS_CODEPAGE_852 is not set | ||
| 1489 | # CONFIG_NLS_CODEPAGE_855 is not set | ||
| 1490 | # CONFIG_NLS_CODEPAGE_857 is not set | ||
| 1491 | # CONFIG_NLS_CODEPAGE_860 is not set | ||
| 1492 | # CONFIG_NLS_CODEPAGE_861 is not set | ||
| 1493 | # CONFIG_NLS_CODEPAGE_862 is not set | ||
| 1494 | # CONFIG_NLS_CODEPAGE_863 is not set | ||
| 1495 | # CONFIG_NLS_CODEPAGE_864 is not set | ||
| 1496 | # CONFIG_NLS_CODEPAGE_865 is not set | ||
| 1497 | # CONFIG_NLS_CODEPAGE_866 is not set | ||
| 1498 | # CONFIG_NLS_CODEPAGE_869 is not set | ||
| 1499 | # CONFIG_NLS_CODEPAGE_936 is not set | ||
| 1500 | # CONFIG_NLS_CODEPAGE_950 is not set | ||
| 1501 | # CONFIG_NLS_CODEPAGE_932 is not set | ||
| 1502 | # CONFIG_NLS_CODEPAGE_949 is not set | ||
| 1503 | # CONFIG_NLS_CODEPAGE_874 is not set | ||
| 1504 | # CONFIG_NLS_ISO8859_8 is not set | ||
| 1505 | # CONFIG_NLS_CODEPAGE_1250 is not set | ||
| 1506 | # CONFIG_NLS_CODEPAGE_1251 is not set | ||
| 1507 | # CONFIG_NLS_ASCII is not set | ||
| 1508 | # CONFIG_NLS_ISO8859_1 is not set | ||
| 1509 | # CONFIG_NLS_ISO8859_2 is not set | ||
| 1510 | # CONFIG_NLS_ISO8859_3 is not set | ||
| 1511 | # CONFIG_NLS_ISO8859_4 is not set | ||
| 1512 | # CONFIG_NLS_ISO8859_5 is not set | ||
| 1513 | # CONFIG_NLS_ISO8859_6 is not set | ||
| 1514 | # CONFIG_NLS_ISO8859_7 is not set | ||
| 1515 | # CONFIG_NLS_ISO8859_9 is not set | ||
| 1516 | # CONFIG_NLS_ISO8859_13 is not set | ||
| 1517 | # CONFIG_NLS_ISO8859_14 is not set | ||
| 1518 | # CONFIG_NLS_ISO8859_15 is not set | ||
| 1519 | # CONFIG_NLS_KOI8_R is not set | ||
| 1520 | # CONFIG_NLS_KOI8_U is not set | ||
| 1521 | # CONFIG_NLS_UTF8 is not set | ||
| 1453 | # CONFIG_DLM is not set | 1522 | # CONFIG_DLM is not set |
| 1454 | # CONFIG_BINARY_PRINTF is not set | 1523 | # CONFIG_BINARY_PRINTF is not set |
| 1455 | 1524 | ||
| @@ -1473,6 +1542,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1473 | CONFIG_HAS_DMA=y | 1542 | CONFIG_HAS_DMA=y |
| 1474 | CONFIG_HAVE_LMB=y | 1543 | CONFIG_HAVE_LMB=y |
| 1475 | CONFIG_NLATTR=y | 1544 | CONFIG_NLATTR=y |
| 1545 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1476 | 1546 | ||
| 1477 | # | 1547 | # |
| 1478 | # Kernel hacking | 1548 | # Kernel hacking |
| @@ -1498,22 +1568,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1498 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1568 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1499 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1569 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1500 | CONFIG_TRACING_SUPPORT=y | 1570 | CONFIG_TRACING_SUPPORT=y |
| 1501 | 1571 | # CONFIG_FTRACE is not set | |
| 1502 | # | ||
| 1503 | # Tracers | ||
| 1504 | # | ||
| 1505 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1506 | # CONFIG_SCHED_TRACER is not set | ||
| 1507 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1508 | # CONFIG_EVENT_TRACER is not set | ||
| 1509 | # CONFIG_BOOT_TRACER is not set | ||
| 1510 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1511 | # CONFIG_STACK_TRACER is not set | ||
| 1512 | # CONFIG_KMEMTRACE is not set | ||
| 1513 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1514 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1515 | # CONFIG_SAMPLES is not set | 1572 | # CONFIG_SAMPLES is not set |
| 1516 | CONFIG_HAVE_ARCH_KGDB=y | 1573 | CONFIG_HAVE_ARCH_KGDB=y |
| 1574 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1575 | CONFIG_PPC_WERROR=y | ||
| 1517 | CONFIG_PRINT_STACK_DEPTH=64 | 1576 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1518 | # CONFIG_IRQSTACKS is not set | 1577 | # CONFIG_IRQSTACKS is not set |
| 1519 | # CONFIG_PPC_EARLY_DEBUG is not set | 1578 | # CONFIG_PPC_EARLY_DEBUG is not set |
diff --git a/arch/powerpc/configs/85xx/stx_gp3_defconfig b/arch/powerpc/configs/85xx/stx_gp3_defconfig index bd1bfcddbd0c..e7e81d6769fe 100644 --- a/arch/powerpc/configs/85xx/stx_gp3_defconfig +++ b/arch/powerpc/configs/85xx/stx_gp3_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:22 2009 | 4 | # Wed Jul 29 23:32:20 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -34,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 34 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 35 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 36 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 38 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 39 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 41 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 43 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 44 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 45 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 47 | CONFIG_GENERIC_GPIO=y | 48 | CONFIG_GENERIC_GPIO=y |
| 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 49 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -57,11 +58,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 57 | # CONFIG_GENERIC_TBSYNC is not set | 58 | # CONFIG_GENERIC_TBSYNC is not set |
| 58 | CONFIG_AUDIT_ARCH=y | 59 | CONFIG_AUDIT_ARCH=y |
| 59 | CONFIG_GENERIC_BUG=y | 60 | CONFIG_GENERIC_BUG=y |
| 61 | CONFIG_DTC=y | ||
| 60 | CONFIG_DEFAULT_UIMAGE=y | 62 | CONFIG_DEFAULT_UIMAGE=y |
| 61 | # CONFIG_PPC_DCR_NATIVE is not set | 63 | # CONFIG_PPC_DCR_NATIVE is not set |
| 62 | # CONFIG_PPC_DCR_MMIO is not set | 64 | # CONFIG_PPC_DCR_MMIO is not set |
| 63 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 65 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 64 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 66 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 67 | CONFIG_CONSTRUCTORS=y | ||
| 65 | 68 | ||
| 66 | # | 69 | # |
| 67 | # General setup | 70 | # General setup |
| @@ -112,7 +115,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 112 | CONFIG_KALLSYMS=y | 115 | CONFIG_KALLSYMS=y |
| 113 | # CONFIG_KALLSYMS_ALL is not set | 116 | # CONFIG_KALLSYMS_ALL is not set |
| 114 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 117 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 115 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 116 | CONFIG_HOTPLUG=y | 118 | CONFIG_HOTPLUG=y |
| 117 | CONFIG_PRINTK=y | 119 | CONFIG_PRINTK=y |
| 118 | CONFIG_BUG=y | 120 | CONFIG_BUG=y |
| @@ -125,9 +127,16 @@ CONFIG_TIMERFD=y | |||
| 125 | CONFIG_EVENTFD=y | 127 | CONFIG_EVENTFD=y |
| 126 | CONFIG_SHMEM=y | 128 | CONFIG_SHMEM=y |
| 127 | CONFIG_AIO=y | 129 | CONFIG_AIO=y |
| 130 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 131 | |||
| 132 | # | ||
| 133 | # Performance Counters | ||
| 134 | # | ||
| 135 | # CONFIG_PERF_COUNTERS is not set | ||
| 128 | CONFIG_VM_EVENT_COUNTERS=y | 136 | CONFIG_VM_EVENT_COUNTERS=y |
| 129 | CONFIG_PCI_QUIRKS=y | 137 | CONFIG_PCI_QUIRKS=y |
| 130 | CONFIG_SLUB_DEBUG=y | 138 | CONFIG_SLUB_DEBUG=y |
| 139 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 131 | CONFIG_COMPAT_BRK=y | 140 | CONFIG_COMPAT_BRK=y |
| 132 | # CONFIG_SLAB is not set | 141 | # CONFIG_SLAB is not set |
| 133 | CONFIG_SLUB=y | 142 | CONFIG_SLUB=y |
| @@ -142,6 +151,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 142 | CONFIG_HAVE_KRETPROBES=y | 151 | CONFIG_HAVE_KRETPROBES=y |
| 143 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 152 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 144 | CONFIG_HAVE_CLK=y | 153 | CONFIG_HAVE_CLK=y |
| 154 | |||
| 155 | # | ||
| 156 | # GCOV-based kernel profiling | ||
| 157 | # | ||
| 145 | # CONFIG_SLOW_WORK is not set | 158 | # CONFIG_SLOW_WORK is not set |
| 146 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 159 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 147 | CONFIG_SLABINFO=y | 160 | CONFIG_SLABINFO=y |
| @@ -153,7 +166,7 @@ CONFIG_MODULES=y | |||
| 153 | CONFIG_MODVERSIONS=y | 166 | CONFIG_MODVERSIONS=y |
| 154 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 167 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 155 | CONFIG_BLOCK=y | 168 | CONFIG_BLOCK=y |
| 156 | # CONFIG_LBD is not set | 169 | CONFIG_LBDAF=y |
| 157 | # CONFIG_BLK_DEV_BSG is not set | 170 | # CONFIG_BLK_DEV_BSG is not set |
| 158 | # CONFIG_BLK_DEV_INTEGRITY is not set | 171 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 159 | 172 | ||
| @@ -186,6 +199,7 @@ CONFIG_MPC85xx=y | |||
| 186 | # CONFIG_MPC85xx_DS is not set | 199 | # CONFIG_MPC85xx_DS is not set |
| 187 | # CONFIG_SOCRATES is not set | 200 | # CONFIG_SOCRATES is not set |
| 188 | # CONFIG_KSI8560 is not set | 201 | # CONFIG_KSI8560 is not set |
| 202 | # CONFIG_XES_MPC85xx is not set | ||
| 189 | CONFIG_STX_GP3=y | 203 | CONFIG_STX_GP3=y |
| 190 | # CONFIG_TQM8540 is not set | 204 | # CONFIG_TQM8540 is not set |
| 191 | # CONFIG_TQM8541 is not set | 205 | # CONFIG_TQM8541 is not set |
| @@ -234,6 +248,7 @@ CONFIG_BINFMT_ELF=y | |||
| 234 | CONFIG_BINFMT_MISC=m | 248 | CONFIG_BINFMT_MISC=m |
| 235 | CONFIG_MATH_EMULATION=y | 249 | CONFIG_MATH_EMULATION=y |
| 236 | # CONFIG_IOMMU_HELPER is not set | 250 | # CONFIG_IOMMU_HELPER is not set |
| 251 | # CONFIG_SWIOTLB is not set | ||
| 237 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 252 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 238 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 253 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 239 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 254 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -252,9 +267,9 @@ CONFIG_MIGRATION=y | |||
| 252 | CONFIG_ZONE_DMA_FLAG=1 | 267 | CONFIG_ZONE_DMA_FLAG=1 |
| 253 | CONFIG_BOUNCE=y | 268 | CONFIG_BOUNCE=y |
| 254 | CONFIG_VIRT_TO_BUS=y | 269 | CONFIG_VIRT_TO_BUS=y |
| 255 | CONFIG_UNEVICTABLE_LRU=y | ||
| 256 | CONFIG_HAVE_MLOCK=y | 270 | CONFIG_HAVE_MLOCK=y |
| 257 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 271 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 272 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 258 | CONFIG_PPC_4K_PAGES=y | 273 | CONFIG_PPC_4K_PAGES=y |
| 259 | # CONFIG_PPC_16K_PAGES is not set | 274 | # CONFIG_PPC_16K_PAGES is not set |
| 260 | # CONFIG_PPC_64K_PAGES is not set | 275 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -425,6 +440,7 @@ CONFIG_IP_NF_FILTER=m | |||
| 425 | # CONFIG_ECONET is not set | 440 | # CONFIG_ECONET is not set |
| 426 | # CONFIG_WAN_ROUTER is not set | 441 | # CONFIG_WAN_ROUTER is not set |
| 427 | # CONFIG_PHONET is not set | 442 | # CONFIG_PHONET is not set |
| 443 | # CONFIG_IEEE802154 is not set | ||
| 428 | # CONFIG_NET_SCHED is not set | 444 | # CONFIG_NET_SCHED is not set |
| 429 | # CONFIG_DCB is not set | 445 | # CONFIG_DCB is not set |
| 430 | 446 | ||
| @@ -442,7 +458,11 @@ CONFIG_WIRELESS=y | |||
| 442 | CONFIG_WIRELESS_OLD_REGULATORY=y | 458 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 443 | # CONFIG_WIRELESS_EXT is not set | 459 | # CONFIG_WIRELESS_EXT is not set |
| 444 | # CONFIG_LIB80211 is not set | 460 | # CONFIG_LIB80211 is not set |
| 445 | # CONFIG_MAC80211 is not set | 461 | |
| 462 | # | ||
| 463 | # CFG80211 needs to be enabled for MAC80211 | ||
| 464 | # | ||
| 465 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 446 | # CONFIG_WIMAX is not set | 466 | # CONFIG_WIMAX is not set |
| 447 | # CONFIG_RFKILL is not set | 467 | # CONFIG_RFKILL is not set |
| 448 | # CONFIG_NET_9P is not set | 468 | # CONFIG_NET_9P is not set |
| @@ -466,6 +486,7 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 466 | CONFIG_OF_DEVICE=y | 486 | CONFIG_OF_DEVICE=y |
| 467 | CONFIG_OF_GPIO=y | 487 | CONFIG_OF_GPIO=y |
| 468 | CONFIG_OF_I2C=m | 488 | CONFIG_OF_I2C=m |
| 489 | CONFIG_OF_MDIO=y | ||
| 469 | CONFIG_PARPORT=m | 490 | CONFIG_PARPORT=m |
| 470 | CONFIG_PARPORT_PC=m | 491 | CONFIG_PARPORT_PC=m |
| 471 | # CONFIG_PARPORT_PC_FIFO is not set | 492 | # CONFIG_PARPORT_PC_FIFO is not set |
| @@ -507,7 +528,9 @@ CONFIG_MISC_DEVICES=y | |||
| 507 | # | 528 | # |
| 508 | # CONFIG_EEPROM_AT24 is not set | 529 | # CONFIG_EEPROM_AT24 is not set |
| 509 | # CONFIG_EEPROM_LEGACY is not set | 530 | # CONFIG_EEPROM_LEGACY is not set |
| 531 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 510 | # CONFIG_EEPROM_93CX6 is not set | 532 | # CONFIG_EEPROM_93CX6 is not set |
| 533 | # CONFIG_CB710_CORE is not set | ||
| 511 | CONFIG_HAVE_IDE=y | 534 | CONFIG_HAVE_IDE=y |
| 512 | CONFIG_IDE=y | 535 | CONFIG_IDE=y |
| 513 | 536 | ||
| @@ -581,10 +604,6 @@ CONFIG_BLK_DEV_SR=m | |||
| 581 | # CONFIG_BLK_DEV_SR_VENDOR is not set | 604 | # CONFIG_BLK_DEV_SR_VENDOR is not set |
| 582 | CONFIG_CHR_DEV_SG=m | 605 | CONFIG_CHR_DEV_SG=m |
| 583 | # CONFIG_CHR_DEV_SCH is not set | 606 | # CONFIG_CHR_DEV_SCH is not set |
| 584 | |||
| 585 | # | ||
| 586 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 587 | # | ||
| 588 | CONFIG_SCSI_MULTI_LUN=y | 607 | CONFIG_SCSI_MULTI_LUN=y |
| 589 | CONFIG_SCSI_CONSTANTS=y | 608 | CONFIG_SCSI_CONSTANTS=y |
| 590 | # CONFIG_SCSI_LOGGING is not set | 609 | # CONFIG_SCSI_LOGGING is not set |
| @@ -602,6 +621,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 602 | CONFIG_SCSI_LOWLEVEL=y | 621 | CONFIG_SCSI_LOWLEVEL=y |
| 603 | # CONFIG_ISCSI_TCP is not set | 622 | # CONFIG_ISCSI_TCP is not set |
| 604 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 623 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 624 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 605 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 625 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 606 | # CONFIG_SCSI_3W_9XXX is not set | 626 | # CONFIG_SCSI_3W_9XXX is not set |
| 607 | # CONFIG_SCSI_ACARD is not set | 627 | # CONFIG_SCSI_ACARD is not set |
| @@ -610,6 +630,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 610 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 630 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 611 | # CONFIG_SCSI_AIC79XX is not set | 631 | # CONFIG_SCSI_AIC79XX is not set |
| 612 | # CONFIG_SCSI_AIC94XX is not set | 632 | # CONFIG_SCSI_AIC94XX is not set |
| 633 | # CONFIG_SCSI_MVSAS is not set | ||
| 613 | # CONFIG_SCSI_DPT_I2O is not set | 634 | # CONFIG_SCSI_DPT_I2O is not set |
| 614 | # CONFIG_SCSI_ADVANSYS is not set | 635 | # CONFIG_SCSI_ADVANSYS is not set |
| 615 | # CONFIG_SCSI_ARCMSR is not set | 636 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -631,7 +652,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 631 | # CONFIG_SCSI_INIA100 is not set | 652 | # CONFIG_SCSI_INIA100 is not set |
| 632 | # CONFIG_SCSI_PPA is not set | 653 | # CONFIG_SCSI_PPA is not set |
| 633 | # CONFIG_SCSI_IMM is not set | 654 | # CONFIG_SCSI_IMM is not set |
| 634 | # CONFIG_SCSI_MVSAS is not set | ||
| 635 | # CONFIG_SCSI_STEX is not set | 655 | # CONFIG_SCSI_STEX is not set |
| 636 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 656 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 637 | # CONFIG_SCSI_QLOGIC_1280 is not set | 657 | # CONFIG_SCSI_QLOGIC_1280 is not set |
| @@ -654,14 +674,17 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 654 | # | 674 | # |
| 655 | 675 | ||
| 656 | # | 676 | # |
| 657 | # Enable only one of the two stacks, unless you know what you are doing | 677 | # You can enable one or both FireWire driver stacks. |
| 678 | # | ||
| 679 | |||
| 680 | # | ||
| 681 | # See the help texts for more information. | ||
| 658 | # | 682 | # |
| 659 | # CONFIG_FIREWIRE is not set | 683 | # CONFIG_FIREWIRE is not set |
| 660 | # CONFIG_IEEE1394 is not set | 684 | # CONFIG_IEEE1394 is not set |
| 661 | # CONFIG_I2O is not set | 685 | # CONFIG_I2O is not set |
| 662 | # CONFIG_MACINTOSH_DRIVERS is not set | 686 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 663 | CONFIG_NETDEVICES=y | 687 | CONFIG_NETDEVICES=y |
| 664 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 665 | # CONFIG_DUMMY is not set | 688 | # CONFIG_DUMMY is not set |
| 666 | # CONFIG_BONDING is not set | 689 | # CONFIG_BONDING is not set |
| 667 | # CONFIG_MACVLAN is not set | 690 | # CONFIG_MACVLAN is not set |
| @@ -708,6 +731,7 @@ CONFIG_NET_ETHERNET=y | |||
| 708 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 731 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 709 | # CONFIG_NET_PCI is not set | 732 | # CONFIG_NET_PCI is not set |
| 710 | # CONFIG_B44 is not set | 733 | # CONFIG_B44 is not set |
| 734 | # CONFIG_KS8842 is not set | ||
| 711 | # CONFIG_NET_POCKET is not set | 735 | # CONFIG_NET_POCKET is not set |
| 712 | # CONFIG_ATL2 is not set | 736 | # CONFIG_ATL2 is not set |
| 713 | # CONFIG_FS_ENET is not set | 737 | # CONFIG_FS_ENET is not set |
| @@ -729,8 +753,10 @@ CONFIG_NETDEV_1000=y | |||
| 729 | # CONFIG_VIA_VELOCITY is not set | 753 | # CONFIG_VIA_VELOCITY is not set |
| 730 | # CONFIG_TIGON3 is not set | 754 | # CONFIG_TIGON3 is not set |
| 731 | # CONFIG_BNX2 is not set | 755 | # CONFIG_BNX2 is not set |
| 756 | # CONFIG_CNIC is not set | ||
| 732 | CONFIG_FSL_PQ_MDIO=y | 757 | CONFIG_FSL_PQ_MDIO=y |
| 733 | CONFIG_GIANFAR=y | 758 | CONFIG_GIANFAR=y |
| 759 | # CONFIG_MV643XX_ETH is not set | ||
| 734 | # CONFIG_QLA3XXX is not set | 760 | # CONFIG_QLA3XXX is not set |
| 735 | # CONFIG_ATL1 is not set | 761 | # CONFIG_ATL1 is not set |
| 736 | # CONFIG_ATL1E is not set | 762 | # CONFIG_ATL1E is not set |
| @@ -802,12 +828,13 @@ CONFIG_INPUT_EVDEV=m | |||
| 802 | # | 828 | # |
| 803 | CONFIG_INPUT_KEYBOARD=y | 829 | CONFIG_INPUT_KEYBOARD=y |
| 804 | CONFIG_KEYBOARD_ATKBD=y | 830 | CONFIG_KEYBOARD_ATKBD=y |
| 805 | # CONFIG_KEYBOARD_SUNKBD is not set | ||
| 806 | # CONFIG_KEYBOARD_LKKBD is not set | 831 | # CONFIG_KEYBOARD_LKKBD is not set |
| 807 | # CONFIG_KEYBOARD_XTKBD is not set | 832 | # CONFIG_KEYBOARD_GPIO is not set |
| 833 | # CONFIG_KEYBOARD_MATRIX is not set | ||
| 808 | # CONFIG_KEYBOARD_NEWTON is not set | 834 | # CONFIG_KEYBOARD_NEWTON is not set |
| 809 | # CONFIG_KEYBOARD_STOWAWAY is not set | 835 | # CONFIG_KEYBOARD_STOWAWAY is not set |
| 810 | # CONFIG_KEYBOARD_GPIO is not set | 836 | # CONFIG_KEYBOARD_SUNKBD is not set |
| 837 | # CONFIG_KEYBOARD_XTKBD is not set | ||
| 811 | CONFIG_INPUT_MOUSE=y | 838 | CONFIG_INPUT_MOUSE=y |
| 812 | CONFIG_MOUSE_PS2=y | 839 | CONFIG_MOUSE_PS2=y |
| 813 | CONFIG_MOUSE_PS2_ALPS=y | 840 | CONFIG_MOUSE_PS2_ALPS=y |
| @@ -821,6 +848,7 @@ CONFIG_MOUSE_PS2_TRACKPOINT=y | |||
| 821 | # CONFIG_MOUSE_BCM5974 is not set | 848 | # CONFIG_MOUSE_BCM5974 is not set |
| 822 | # CONFIG_MOUSE_VSXXXAA is not set | 849 | # CONFIG_MOUSE_VSXXXAA is not set |
| 823 | # CONFIG_MOUSE_GPIO is not set | 850 | # CONFIG_MOUSE_GPIO is not set |
| 851 | # CONFIG_MOUSE_SYNAPTICS_I2C is not set | ||
| 824 | # CONFIG_INPUT_JOYSTICK is not set | 852 | # CONFIG_INPUT_JOYSTICK is not set |
| 825 | # CONFIG_INPUT_TABLET is not set | 853 | # CONFIG_INPUT_TABLET is not set |
| 826 | # CONFIG_INPUT_TOUCHSCREEN is not set | 854 | # CONFIG_INPUT_TOUCHSCREEN is not set |
| @@ -911,6 +939,7 @@ CONFIG_I2C_ALGOBIT=m | |||
| 911 | # I2C system bus drivers (mostly embedded / system-on-chip) | 939 | # I2C system bus drivers (mostly embedded / system-on-chip) |
| 912 | # | 940 | # |
| 913 | # CONFIG_I2C_CPM is not set | 941 | # CONFIG_I2C_CPM is not set |
| 942 | # CONFIG_I2C_DESIGNWARE is not set | ||
| 914 | # CONFIG_I2C_GPIO is not set | 943 | # CONFIG_I2C_GPIO is not set |
| 915 | # CONFIG_I2C_MPC is not set | 944 | # CONFIG_I2C_MPC is not set |
| 916 | # CONFIG_I2C_OCORES is not set | 945 | # CONFIG_I2C_OCORES is not set |
| @@ -941,13 +970,17 @@ CONFIG_I2C_ALGOBIT=m | |||
| 941 | # CONFIG_SENSORS_PCF8574 is not set | 970 | # CONFIG_SENSORS_PCF8574 is not set |
| 942 | # CONFIG_PCF8575 is not set | 971 | # CONFIG_PCF8575 is not set |
| 943 | # CONFIG_SENSORS_PCA9539 is not set | 972 | # CONFIG_SENSORS_PCA9539 is not set |
| 944 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 945 | # CONFIG_SENSORS_TSL2550 is not set | 973 | # CONFIG_SENSORS_TSL2550 is not set |
| 946 | # CONFIG_I2C_DEBUG_CORE is not set | 974 | # CONFIG_I2C_DEBUG_CORE is not set |
| 947 | # CONFIG_I2C_DEBUG_ALGO is not set | 975 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 948 | # CONFIG_I2C_DEBUG_BUS is not set | 976 | # CONFIG_I2C_DEBUG_BUS is not set |
| 949 | # CONFIG_I2C_DEBUG_CHIP is not set | 977 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 950 | # CONFIG_SPI is not set | 978 | # CONFIG_SPI is not set |
| 979 | |||
| 980 | # | ||
| 981 | # PPS support | ||
| 982 | # | ||
| 983 | # CONFIG_PPS is not set | ||
| 951 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 984 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 952 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 985 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 953 | CONFIG_GPIOLIB=y | 986 | CONFIG_GPIOLIB=y |
| @@ -1027,6 +1060,7 @@ CONFIG_HWMON=y | |||
| 1027 | # CONFIG_SENSORS_SMSC47B397 is not set | 1060 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 1028 | # CONFIG_SENSORS_ADS7828 is not set | 1061 | # CONFIG_SENSORS_ADS7828 is not set |
| 1029 | # CONFIG_SENSORS_THMC50 is not set | 1062 | # CONFIG_SENSORS_THMC50 is not set |
| 1063 | # CONFIG_SENSORS_TMP401 is not set | ||
| 1030 | # CONFIG_SENSORS_VIA686A is not set | 1064 | # CONFIG_SENSORS_VIA686A is not set |
| 1031 | # CONFIG_SENSORS_VT1211 is not set | 1065 | # CONFIG_SENSORS_VT1211 is not set |
| 1032 | # CONFIG_SENSORS_VT8231 is not set | 1066 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -1060,23 +1094,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1060 | # CONFIG_MFD_WM8400 is not set | 1094 | # CONFIG_MFD_WM8400 is not set |
| 1061 | # CONFIG_MFD_WM8350_I2C is not set | 1095 | # CONFIG_MFD_WM8350_I2C is not set |
| 1062 | # CONFIG_MFD_PCF50633 is not set | 1096 | # CONFIG_MFD_PCF50633 is not set |
| 1097 | # CONFIG_AB3100_CORE is not set | ||
| 1063 | # CONFIG_REGULATOR is not set | 1098 | # CONFIG_REGULATOR is not set |
| 1064 | 1099 | # CONFIG_MEDIA_SUPPORT is not set | |
| 1065 | # | ||
| 1066 | # Multimedia devices | ||
| 1067 | # | ||
| 1068 | |||
| 1069 | # | ||
| 1070 | # Multimedia core support | ||
| 1071 | # | ||
| 1072 | # CONFIG_VIDEO_DEV is not set | ||
| 1073 | # CONFIG_DVB_CORE is not set | ||
| 1074 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1075 | |||
| 1076 | # | ||
| 1077 | # Multimedia drivers | ||
| 1078 | # | ||
| 1079 | CONFIG_DAB=y | ||
| 1080 | 1100 | ||
| 1081 | # | 1101 | # |
| 1082 | # Graphics support | 1102 | # Graphics support |
| @@ -1143,6 +1163,10 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
| 1143 | # CONFIG_DMADEVICES is not set | 1163 | # CONFIG_DMADEVICES is not set |
| 1144 | # CONFIG_AUXDISPLAY is not set | 1164 | # CONFIG_AUXDISPLAY is not set |
| 1145 | # CONFIG_UIO is not set | 1165 | # CONFIG_UIO is not set |
| 1166 | |||
| 1167 | # | ||
| 1168 | # TI VLYNQ | ||
| 1169 | # | ||
| 1146 | # CONFIG_STAGING is not set | 1170 | # CONFIG_STAGING is not set |
| 1147 | 1171 | ||
| 1148 | # | 1172 | # |
| @@ -1162,10 +1186,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1162 | # CONFIG_REISERFS_FS is not set | 1186 | # CONFIG_REISERFS_FS is not set |
| 1163 | # CONFIG_JFS_FS is not set | 1187 | # CONFIG_JFS_FS is not set |
| 1164 | # CONFIG_FS_POSIX_ACL is not set | 1188 | # CONFIG_FS_POSIX_ACL is not set |
| 1165 | CONFIG_FILE_LOCKING=y | ||
| 1166 | # CONFIG_XFS_FS is not set | 1189 | # CONFIG_XFS_FS is not set |
| 1190 | # CONFIG_GFS2_FS is not set | ||
| 1167 | # CONFIG_OCFS2_FS is not set | 1191 | # CONFIG_OCFS2_FS is not set |
| 1168 | # CONFIG_BTRFS_FS is not set | 1192 | # CONFIG_BTRFS_FS is not set |
| 1193 | CONFIG_FILE_LOCKING=y | ||
| 1194 | CONFIG_FSNOTIFY=y | ||
| 1169 | CONFIG_DNOTIFY=y | 1195 | CONFIG_DNOTIFY=y |
| 1170 | CONFIG_INOTIFY=y | 1196 | CONFIG_INOTIFY=y |
| 1171 | CONFIG_INOTIFY_USER=y | 1197 | CONFIG_INOTIFY_USER=y |
| @@ -1316,6 +1342,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1316 | CONFIG_HAS_DMA=y | 1342 | CONFIG_HAS_DMA=y |
| 1317 | CONFIG_HAVE_LMB=y | 1343 | CONFIG_HAVE_LMB=y |
| 1318 | CONFIG_NLATTR=y | 1344 | CONFIG_NLATTR=y |
| 1345 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1319 | 1346 | ||
| 1320 | # | 1347 | # |
| 1321 | # Kernel hacking | 1348 | # Kernel hacking |
| @@ -1346,6 +1373,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 1346 | # CONFIG_RT_MUTEX_TESTER is not set | 1373 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1347 | # CONFIG_DEBUG_SPINLOCK is not set | 1374 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1348 | # CONFIG_DEBUG_MUTEXES is not set | 1375 | # CONFIG_DEBUG_MUTEXES is not set |
| 1376 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1377 | # CONFIG_PROVE_LOCKING is not set | ||
| 1378 | # CONFIG_LOCK_STAT is not set | ||
| 1349 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1379 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1350 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1380 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1351 | # CONFIG_DEBUG_KOBJECT is not set | 1381 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1358,7 +1388,6 @@ CONFIG_SCHED_DEBUG=y | |||
| 1358 | # CONFIG_DEBUG_LIST is not set | 1388 | # CONFIG_DEBUG_LIST is not set |
| 1359 | # CONFIG_DEBUG_SG is not set | 1389 | # CONFIG_DEBUG_SG is not set |
| 1360 | # CONFIG_DEBUG_NOTIFIERS is not set | 1390 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1361 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1362 | # CONFIG_RCU_TORTURE_TEST is not set | 1391 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1363 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1392 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1364 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1393 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1372,16 +1401,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1372 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1401 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1373 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1402 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1374 | CONFIG_TRACING_SUPPORT=y | 1403 | CONFIG_TRACING_SUPPORT=y |
| 1375 | 1404 | CONFIG_FTRACE=y | |
| 1376 | # | ||
| 1377 | # Tracers | ||
| 1378 | # | ||
| 1379 | # CONFIG_FUNCTION_TRACER is not set | 1405 | # CONFIG_FUNCTION_TRACER is not set |
| 1406 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1380 | # CONFIG_SCHED_TRACER is not set | 1407 | # CONFIG_SCHED_TRACER is not set |
| 1381 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1408 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1382 | # CONFIG_EVENT_TRACER is not set | ||
| 1383 | # CONFIG_BOOT_TRACER is not set | 1409 | # CONFIG_BOOT_TRACER is not set |
| 1384 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1410 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1411 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1412 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1385 | # CONFIG_STACK_TRACER is not set | 1413 | # CONFIG_STACK_TRACER is not set |
| 1386 | # CONFIG_KMEMTRACE is not set | 1414 | # CONFIG_KMEMTRACE is not set |
| 1387 | # CONFIG_WORKQUEUE_TRACER is not set | 1415 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -1389,6 +1417,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 1389 | # CONFIG_SAMPLES is not set | 1417 | # CONFIG_SAMPLES is not set |
| 1390 | CONFIG_HAVE_ARCH_KGDB=y | 1418 | CONFIG_HAVE_ARCH_KGDB=y |
| 1391 | # CONFIG_KGDB is not set | 1419 | # CONFIG_KGDB is not set |
| 1420 | # CONFIG_KMEMCHECK is not set | ||
| 1421 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1422 | CONFIG_PPC_WERROR=y | ||
| 1392 | CONFIG_PRINT_STACK_DEPTH=64 | 1423 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1393 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1424 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1394 | # CONFIG_DEBUG_STACK_USAGE is not set | 1425 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/85xx/tqm8540_defconfig b/arch/powerpc/configs/85xx/tqm8540_defconfig index 767600145fb2..2c407523aad2 100644 --- a/arch/powerpc/configs/85xx/tqm8540_defconfig +++ b/arch/powerpc/configs/85xx/tqm8540_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:23 2009 | 4 | # Wed Jul 29 23:32:21 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -34,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 34 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 35 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 36 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 38 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 39 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 41 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 43 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 44 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 45 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 48 | CONFIG_PPC=y | 49 | CONFIG_PPC=y |
| @@ -56,11 +57,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 56 | # CONFIG_GENERIC_TBSYNC is not set | 57 | # CONFIG_GENERIC_TBSYNC is not set |
| 57 | CONFIG_AUDIT_ARCH=y | 58 | CONFIG_AUDIT_ARCH=y |
| 58 | CONFIG_GENERIC_BUG=y | 59 | CONFIG_GENERIC_BUG=y |
| 60 | CONFIG_DTC=y | ||
| 59 | CONFIG_DEFAULT_UIMAGE=y | 61 | CONFIG_DEFAULT_UIMAGE=y |
| 60 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 61 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 62 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 63 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 64 | 67 | ||
| 65 | # | 68 | # |
| 66 | # General setup | 69 | # General setup |
| @@ -109,7 +112,6 @@ CONFIG_ANON_INODES=y | |||
| 109 | CONFIG_EMBEDDED=y | 112 | CONFIG_EMBEDDED=y |
| 110 | CONFIG_SYSCTL_SYSCALL=y | 113 | CONFIG_SYSCTL_SYSCALL=y |
| 111 | # CONFIG_KALLSYMS is not set | 114 | # CONFIG_KALLSYMS is not set |
| 112 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 113 | # CONFIG_HOTPLUG is not set | 115 | # CONFIG_HOTPLUG is not set |
| 114 | CONFIG_PRINTK=y | 116 | CONFIG_PRINTK=y |
| 115 | CONFIG_BUG=y | 117 | CONFIG_BUG=y |
| @@ -122,9 +124,16 @@ CONFIG_TIMERFD=y | |||
| 122 | CONFIG_EVENTFD=y | 124 | CONFIG_EVENTFD=y |
| 123 | CONFIG_SHMEM=y | 125 | CONFIG_SHMEM=y |
| 124 | CONFIG_AIO=y | 126 | CONFIG_AIO=y |
| 127 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 128 | |||
| 129 | # | ||
| 130 | # Performance Counters | ||
| 131 | # | ||
| 132 | # CONFIG_PERF_COUNTERS is not set | ||
| 125 | CONFIG_VM_EVENT_COUNTERS=y | 133 | CONFIG_VM_EVENT_COUNTERS=y |
| 126 | CONFIG_PCI_QUIRKS=y | 134 | CONFIG_PCI_QUIRKS=y |
| 127 | CONFIG_SLUB_DEBUG=y | 135 | CONFIG_SLUB_DEBUG=y |
| 136 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 128 | CONFIG_COMPAT_BRK=y | 137 | CONFIG_COMPAT_BRK=y |
| 129 | # CONFIG_SLAB is not set | 138 | # CONFIG_SLAB is not set |
| 130 | CONFIG_SLUB=y | 139 | CONFIG_SLUB=y |
| @@ -137,6 +146,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 137 | CONFIG_HAVE_KPROBES=y | 146 | CONFIG_HAVE_KPROBES=y |
| 138 | CONFIG_HAVE_KRETPROBES=y | 147 | CONFIG_HAVE_KRETPROBES=y |
| 139 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 148 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 149 | |||
| 150 | # | ||
| 151 | # GCOV-based kernel profiling | ||
| 152 | # | ||
| 140 | # CONFIG_SLOW_WORK is not set | 153 | # CONFIG_SLOW_WORK is not set |
| 141 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 142 | CONFIG_SLABINFO=y | 155 | CONFIG_SLABINFO=y |
| @@ -144,7 +157,7 @@ CONFIG_RT_MUTEXES=y | |||
| 144 | CONFIG_BASE_SMALL=0 | 157 | CONFIG_BASE_SMALL=0 |
| 145 | # CONFIG_MODULES is not set | 158 | # CONFIG_MODULES is not set |
| 146 | CONFIG_BLOCK=y | 159 | CONFIG_BLOCK=y |
| 147 | # CONFIG_LBD is not set | 160 | CONFIG_LBDAF=y |
| 148 | # CONFIG_BLK_DEV_BSG is not set | 161 | # CONFIG_BLK_DEV_BSG is not set |
| 149 | # CONFIG_BLK_DEV_INTEGRITY is not set | 162 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 150 | 163 | ||
| @@ -177,6 +190,7 @@ CONFIG_MPC85xx=y | |||
| 177 | # CONFIG_MPC85xx_DS is not set | 190 | # CONFIG_MPC85xx_DS is not set |
| 178 | # CONFIG_SOCRATES is not set | 191 | # CONFIG_SOCRATES is not set |
| 179 | # CONFIG_KSI8560 is not set | 192 | # CONFIG_KSI8560 is not set |
| 193 | # CONFIG_XES_MPC85xx is not set | ||
| 180 | # CONFIG_STX_GP3 is not set | 194 | # CONFIG_STX_GP3 is not set |
| 181 | CONFIG_TQM8540=y | 195 | CONFIG_TQM8540=y |
| 182 | # CONFIG_TQM8541 is not set | 196 | # CONFIG_TQM8541 is not set |
| @@ -225,6 +239,7 @@ CONFIG_BINFMT_ELF=y | |||
| 225 | # CONFIG_BINFMT_MISC is not set | 239 | # CONFIG_BINFMT_MISC is not set |
| 226 | CONFIG_MATH_EMULATION=y | 240 | CONFIG_MATH_EMULATION=y |
| 227 | # CONFIG_IOMMU_HELPER is not set | 241 | # CONFIG_IOMMU_HELPER is not set |
| 242 | # CONFIG_SWIOTLB is not set | ||
| 228 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 243 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 229 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 244 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 230 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 245 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -243,9 +258,9 @@ CONFIG_MIGRATION=y | |||
| 243 | CONFIG_ZONE_DMA_FLAG=1 | 258 | CONFIG_ZONE_DMA_FLAG=1 |
| 244 | CONFIG_BOUNCE=y | 259 | CONFIG_BOUNCE=y |
| 245 | CONFIG_VIRT_TO_BUS=y | 260 | CONFIG_VIRT_TO_BUS=y |
| 246 | CONFIG_UNEVICTABLE_LRU=y | ||
| 247 | CONFIG_HAVE_MLOCK=y | 261 | CONFIG_HAVE_MLOCK=y |
| 248 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 262 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 263 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 249 | CONFIG_PPC_4K_PAGES=y | 264 | CONFIG_PPC_4K_PAGES=y |
| 250 | # CONFIG_PPC_16K_PAGES is not set | 265 | # CONFIG_PPC_16K_PAGES is not set |
| 251 | # CONFIG_PPC_64K_PAGES is not set | 266 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -353,6 +368,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 353 | # CONFIG_ECONET is not set | 368 | # CONFIG_ECONET is not set |
| 354 | # CONFIG_WAN_ROUTER is not set | 369 | # CONFIG_WAN_ROUTER is not set |
| 355 | # CONFIG_PHONET is not set | 370 | # CONFIG_PHONET is not set |
| 371 | # CONFIG_IEEE802154 is not set | ||
| 356 | # CONFIG_NET_SCHED is not set | 372 | # CONFIG_NET_SCHED is not set |
| 357 | # CONFIG_DCB is not set | 373 | # CONFIG_DCB is not set |
| 358 | 374 | ||
| @@ -370,7 +386,11 @@ CONFIG_WIRELESS=y | |||
| 370 | CONFIG_WIRELESS_OLD_REGULATORY=y | 386 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 371 | # CONFIG_WIRELESS_EXT is not set | 387 | # CONFIG_WIRELESS_EXT is not set |
| 372 | # CONFIG_LIB80211 is not set | 388 | # CONFIG_LIB80211 is not set |
| 373 | # CONFIG_MAC80211 is not set | 389 | |
| 390 | # | ||
| 391 | # CFG80211 needs to be enabled for MAC80211 | ||
| 392 | # | ||
| 393 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 374 | # CONFIG_WIMAX is not set | 394 | # CONFIG_WIMAX is not set |
| 375 | # CONFIG_RFKILL is not set | 395 | # CONFIG_RFKILL is not set |
| 376 | # CONFIG_NET_9P is not set | 396 | # CONFIG_NET_9P is not set |
| @@ -471,6 +491,7 @@ CONFIG_MTD_CFI_UTIL=y | |||
| 471 | # CONFIG_MTD_UBI is not set | 491 | # CONFIG_MTD_UBI is not set |
| 472 | CONFIG_OF_DEVICE=y | 492 | CONFIG_OF_DEVICE=y |
| 473 | CONFIG_OF_I2C=y | 493 | CONFIG_OF_I2C=y |
| 494 | CONFIG_OF_MDIO=y | ||
| 474 | # CONFIG_PARPORT is not set | 495 | # CONFIG_PARPORT is not set |
| 475 | CONFIG_BLK_DEV=y | 496 | CONFIG_BLK_DEV=y |
| 476 | # CONFIG_BLK_DEV_FD is not set | 497 | # CONFIG_BLK_DEV_FD is not set |
| @@ -505,7 +526,9 @@ CONFIG_MISC_DEVICES=y | |||
| 505 | # | 526 | # |
| 506 | # CONFIG_EEPROM_AT24 is not set | 527 | # CONFIG_EEPROM_AT24 is not set |
| 507 | # CONFIG_EEPROM_LEGACY is not set | 528 | # CONFIG_EEPROM_LEGACY is not set |
| 529 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 508 | # CONFIG_EEPROM_93CX6 is not set | 530 | # CONFIG_EEPROM_93CX6 is not set |
| 531 | # CONFIG_CB710_CORE is not set | ||
| 509 | CONFIG_HAVE_IDE=y | 532 | CONFIG_HAVE_IDE=y |
| 510 | CONFIG_IDE=y | 533 | CONFIG_IDE=y |
| 511 | 534 | ||
| @@ -580,14 +603,17 @@ CONFIG_BLK_DEV_IDEDMA=y | |||
| 580 | # | 603 | # |
| 581 | 604 | ||
| 582 | # | 605 | # |
| 583 | # Enable only one of the two stacks, unless you know what you are doing | 606 | # You can enable one or both FireWire driver stacks. |
| 607 | # | ||
| 608 | |||
| 609 | # | ||
| 610 | # See the help texts for more information. | ||
| 584 | # | 611 | # |
| 585 | # CONFIG_FIREWIRE is not set | 612 | # CONFIG_FIREWIRE is not set |
| 586 | # CONFIG_IEEE1394 is not set | 613 | # CONFIG_IEEE1394 is not set |
| 587 | # CONFIG_I2O is not set | 614 | # CONFIG_I2O is not set |
| 588 | # CONFIG_MACINTOSH_DRIVERS is not set | 615 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 589 | CONFIG_NETDEVICES=y | 616 | CONFIG_NETDEVICES=y |
| 590 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 591 | # CONFIG_DUMMY is not set | 617 | # CONFIG_DUMMY is not set |
| 592 | # CONFIG_BONDING is not set | 618 | # CONFIG_BONDING is not set |
| 593 | # CONFIG_MACVLAN is not set | 619 | # CONFIG_MACVLAN is not set |
| @@ -650,6 +676,7 @@ CONFIG_E100=y | |||
| 650 | # CONFIG_SMSC9420 is not set | 676 | # CONFIG_SMSC9420 is not set |
| 651 | # CONFIG_SUNDANCE is not set | 677 | # CONFIG_SUNDANCE is not set |
| 652 | # CONFIG_TLAN is not set | 678 | # CONFIG_TLAN is not set |
| 679 | # CONFIG_KS8842 is not set | ||
| 653 | # CONFIG_VIA_RHINE is not set | 680 | # CONFIG_VIA_RHINE is not set |
| 654 | # CONFIG_SC92031 is not set | 681 | # CONFIG_SC92031 is not set |
| 655 | # CONFIG_ATL2 is not set | 682 | # CONFIG_ATL2 is not set |
| @@ -671,8 +698,10 @@ CONFIG_NETDEV_1000=y | |||
| 671 | # CONFIG_VIA_VELOCITY is not set | 698 | # CONFIG_VIA_VELOCITY is not set |
| 672 | # CONFIG_TIGON3 is not set | 699 | # CONFIG_TIGON3 is not set |
| 673 | # CONFIG_BNX2 is not set | 700 | # CONFIG_BNX2 is not set |
| 701 | # CONFIG_CNIC is not set | ||
| 674 | CONFIG_FSL_PQ_MDIO=y | 702 | CONFIG_FSL_PQ_MDIO=y |
| 675 | CONFIG_GIANFAR=y | 703 | CONFIG_GIANFAR=y |
| 704 | # CONFIG_MV643XX_ETH is not set | ||
| 676 | # CONFIG_QLA3XXX is not set | 705 | # CONFIG_QLA3XXX is not set |
| 677 | # CONFIG_ATL1 is not set | 706 | # CONFIG_ATL1 is not set |
| 678 | # CONFIG_ATL1E is not set | 707 | # CONFIG_ATL1E is not set |
| @@ -850,13 +879,17 @@ CONFIG_I2C_MPC=y | |||
| 850 | # CONFIG_SENSORS_PCF8574 is not set | 879 | # CONFIG_SENSORS_PCF8574 is not set |
| 851 | # CONFIG_PCF8575 is not set | 880 | # CONFIG_PCF8575 is not set |
| 852 | # CONFIG_SENSORS_PCA9539 is not set | 881 | # CONFIG_SENSORS_PCA9539 is not set |
| 853 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 854 | # CONFIG_SENSORS_TSL2550 is not set | 882 | # CONFIG_SENSORS_TSL2550 is not set |
| 855 | # CONFIG_I2C_DEBUG_CORE is not set | 883 | # CONFIG_I2C_DEBUG_CORE is not set |
| 856 | # CONFIG_I2C_DEBUG_ALGO is not set | 884 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 857 | # CONFIG_I2C_DEBUG_BUS is not set | 885 | # CONFIG_I2C_DEBUG_BUS is not set |
| 858 | # CONFIG_I2C_DEBUG_CHIP is not set | 886 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 859 | # CONFIG_SPI is not set | 887 | # CONFIG_SPI is not set |
| 888 | |||
| 889 | # | ||
| 890 | # PPS support | ||
| 891 | # | ||
| 892 | # CONFIG_PPS is not set | ||
| 860 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 893 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 861 | # CONFIG_GPIOLIB is not set | 894 | # CONFIG_GPIOLIB is not set |
| 862 | # CONFIG_W1 is not set | 895 | # CONFIG_W1 is not set |
| @@ -911,6 +944,7 @@ CONFIG_SENSORS_LM75=y | |||
| 911 | # CONFIG_SENSORS_SMSC47B397 is not set | 944 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 912 | # CONFIG_SENSORS_ADS7828 is not set | 945 | # CONFIG_SENSORS_ADS7828 is not set |
| 913 | # CONFIG_SENSORS_THMC50 is not set | 946 | # CONFIG_SENSORS_THMC50 is not set |
| 947 | # CONFIG_SENSORS_TMP401 is not set | ||
| 914 | # CONFIG_SENSORS_VIA686A is not set | 948 | # CONFIG_SENSORS_VIA686A is not set |
| 915 | # CONFIG_SENSORS_VT1211 is not set | 949 | # CONFIG_SENSORS_VT1211 is not set |
| 916 | # CONFIG_SENSORS_VT8231 is not set | 950 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -945,23 +979,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 945 | # CONFIG_MFD_WM8400 is not set | 979 | # CONFIG_MFD_WM8400 is not set |
| 946 | # CONFIG_MFD_WM8350_I2C is not set | 980 | # CONFIG_MFD_WM8350_I2C is not set |
| 947 | # CONFIG_MFD_PCF50633 is not set | 981 | # CONFIG_MFD_PCF50633 is not set |
| 982 | # CONFIG_AB3100_CORE is not set | ||
| 948 | # CONFIG_REGULATOR is not set | 983 | # CONFIG_REGULATOR is not set |
| 949 | 984 | # CONFIG_MEDIA_SUPPORT is not set | |
| 950 | # | ||
| 951 | # Multimedia devices | ||
| 952 | # | ||
| 953 | |||
| 954 | # | ||
| 955 | # Multimedia core support | ||
| 956 | # | ||
| 957 | # CONFIG_VIDEO_DEV is not set | ||
| 958 | # CONFIG_DVB_CORE is not set | ||
| 959 | # CONFIG_VIDEO_MEDIA is not set | ||
| 960 | |||
| 961 | # | ||
| 962 | # Multimedia drivers | ||
| 963 | # | ||
| 964 | CONFIG_DAB=y | ||
| 965 | 985 | ||
| 966 | # | 986 | # |
| 967 | # Graphics support | 987 | # Graphics support |
| @@ -1018,6 +1038,10 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
| 1018 | # CONFIG_DMADEVICES is not set | 1038 | # CONFIG_DMADEVICES is not set |
| 1019 | # CONFIG_AUXDISPLAY is not set | 1039 | # CONFIG_AUXDISPLAY is not set |
| 1020 | # CONFIG_UIO is not set | 1040 | # CONFIG_UIO is not set |
| 1041 | |||
| 1042 | # | ||
| 1043 | # TI VLYNQ | ||
| 1044 | # | ||
| 1021 | # CONFIG_STAGING is not set | 1045 | # CONFIG_STAGING is not set |
| 1022 | 1046 | ||
| 1023 | # | 1047 | # |
| @@ -1037,10 +1061,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1037 | # CONFIG_REISERFS_FS is not set | 1061 | # CONFIG_REISERFS_FS is not set |
| 1038 | # CONFIG_JFS_FS is not set | 1062 | # CONFIG_JFS_FS is not set |
| 1039 | # CONFIG_FS_POSIX_ACL is not set | 1063 | # CONFIG_FS_POSIX_ACL is not set |
| 1040 | CONFIG_FILE_LOCKING=y | ||
| 1041 | # CONFIG_XFS_FS is not set | 1064 | # CONFIG_XFS_FS is not set |
| 1065 | # CONFIG_GFS2_FS is not set | ||
| 1042 | # CONFIG_OCFS2_FS is not set | 1066 | # CONFIG_OCFS2_FS is not set |
| 1043 | # CONFIG_BTRFS_FS is not set | 1067 | # CONFIG_BTRFS_FS is not set |
| 1068 | CONFIG_FILE_LOCKING=y | ||
| 1069 | CONFIG_FSNOTIFY=y | ||
| 1044 | CONFIG_DNOTIFY=y | 1070 | CONFIG_DNOTIFY=y |
| 1045 | CONFIG_INOTIFY=y | 1071 | CONFIG_INOTIFY=y |
| 1046 | CONFIG_INOTIFY_USER=y | 1072 | CONFIG_INOTIFY_USER=y |
| @@ -1167,6 +1193,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1167 | CONFIG_HAS_DMA=y | 1193 | CONFIG_HAS_DMA=y |
| 1168 | CONFIG_HAVE_LMB=y | 1194 | CONFIG_HAVE_LMB=y |
| 1169 | CONFIG_NLATTR=y | 1195 | CONFIG_NLATTR=y |
| 1196 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1170 | 1197 | ||
| 1171 | # | 1198 | # |
| 1172 | # Kernel hacking | 1199 | # Kernel hacking |
| @@ -1192,22 +1219,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1192 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1219 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1193 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1220 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1194 | CONFIG_TRACING_SUPPORT=y | 1221 | CONFIG_TRACING_SUPPORT=y |
| 1195 | 1222 | # CONFIG_FTRACE is not set | |
| 1196 | # | ||
| 1197 | # Tracers | ||
| 1198 | # | ||
| 1199 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1200 | # CONFIG_SCHED_TRACER is not set | ||
| 1201 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1202 | # CONFIG_EVENT_TRACER is not set | ||
| 1203 | # CONFIG_BOOT_TRACER is not set | ||
| 1204 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1205 | # CONFIG_STACK_TRACER is not set | ||
| 1206 | # CONFIG_KMEMTRACE is not set | ||
| 1207 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1208 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1209 | # CONFIG_SAMPLES is not set | 1223 | # CONFIG_SAMPLES is not set |
| 1210 | CONFIG_HAVE_ARCH_KGDB=y | 1224 | CONFIG_HAVE_ARCH_KGDB=y |
| 1225 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1226 | CONFIG_PPC_WERROR=y | ||
| 1211 | CONFIG_PRINT_STACK_DEPTH=64 | 1227 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1212 | # CONFIG_IRQSTACKS is not set | 1228 | # CONFIG_IRQSTACKS is not set |
| 1213 | # CONFIG_PPC_EARLY_DEBUG is not set | 1229 | # CONFIG_PPC_EARLY_DEBUG is not set |
diff --git a/arch/powerpc/configs/85xx/tqm8541_defconfig b/arch/powerpc/configs/85xx/tqm8541_defconfig index 52fafc006dd0..845731dc51c6 100644 --- a/arch/powerpc/configs/85xx/tqm8541_defconfig +++ b/arch/powerpc/configs/85xx/tqm8541_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:23 2009 | 4 | # Wed Jul 29 23:32:22 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -34,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 34 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 35 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 36 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 38 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 39 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 41 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 43 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 44 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 45 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 47 | CONFIG_GENERIC_GPIO=y | 48 | CONFIG_GENERIC_GPIO=y |
| 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 49 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -57,11 +58,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 57 | # CONFIG_GENERIC_TBSYNC is not set | 58 | # CONFIG_GENERIC_TBSYNC is not set |
| 58 | CONFIG_AUDIT_ARCH=y | 59 | CONFIG_AUDIT_ARCH=y |
| 59 | CONFIG_GENERIC_BUG=y | 60 | CONFIG_GENERIC_BUG=y |
| 61 | CONFIG_DTC=y | ||
| 60 | CONFIG_DEFAULT_UIMAGE=y | 62 | CONFIG_DEFAULT_UIMAGE=y |
| 61 | # CONFIG_PPC_DCR_NATIVE is not set | 63 | # CONFIG_PPC_DCR_NATIVE is not set |
| 62 | # CONFIG_PPC_DCR_MMIO is not set | 64 | # CONFIG_PPC_DCR_MMIO is not set |
| 63 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 65 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 64 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 66 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 67 | CONFIG_CONSTRUCTORS=y | ||
| 65 | 68 | ||
| 66 | # | 69 | # |
| 67 | # General setup | 70 | # General setup |
| @@ -110,7 +113,6 @@ CONFIG_ANON_INODES=y | |||
| 110 | CONFIG_EMBEDDED=y | 113 | CONFIG_EMBEDDED=y |
| 111 | CONFIG_SYSCTL_SYSCALL=y | 114 | CONFIG_SYSCTL_SYSCALL=y |
| 112 | # CONFIG_KALLSYMS is not set | 115 | # CONFIG_KALLSYMS is not set |
| 113 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 114 | # CONFIG_HOTPLUG is not set | 116 | # CONFIG_HOTPLUG is not set |
| 115 | CONFIG_PRINTK=y | 117 | CONFIG_PRINTK=y |
| 116 | CONFIG_BUG=y | 118 | CONFIG_BUG=y |
| @@ -123,9 +125,16 @@ CONFIG_TIMERFD=y | |||
| 123 | CONFIG_EVENTFD=y | 125 | CONFIG_EVENTFD=y |
| 124 | CONFIG_SHMEM=y | 126 | CONFIG_SHMEM=y |
| 125 | CONFIG_AIO=y | 127 | CONFIG_AIO=y |
| 128 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 129 | |||
| 130 | # | ||
| 131 | # Performance Counters | ||
| 132 | # | ||
| 133 | # CONFIG_PERF_COUNTERS is not set | ||
| 126 | CONFIG_VM_EVENT_COUNTERS=y | 134 | CONFIG_VM_EVENT_COUNTERS=y |
| 127 | CONFIG_PCI_QUIRKS=y | 135 | CONFIG_PCI_QUIRKS=y |
| 128 | CONFIG_SLUB_DEBUG=y | 136 | CONFIG_SLUB_DEBUG=y |
| 137 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 129 | CONFIG_COMPAT_BRK=y | 138 | CONFIG_COMPAT_BRK=y |
| 130 | # CONFIG_SLAB is not set | 139 | # CONFIG_SLAB is not set |
| 131 | CONFIG_SLUB=y | 140 | CONFIG_SLUB=y |
| @@ -139,6 +148,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 139 | CONFIG_HAVE_KRETPROBES=y | 148 | CONFIG_HAVE_KRETPROBES=y |
| 140 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 149 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 141 | CONFIG_HAVE_CLK=y | 150 | CONFIG_HAVE_CLK=y |
| 151 | |||
| 152 | # | ||
| 153 | # GCOV-based kernel profiling | ||
| 154 | # | ||
| 142 | # CONFIG_SLOW_WORK is not set | 155 | # CONFIG_SLOW_WORK is not set |
| 143 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 156 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 144 | CONFIG_SLABINFO=y | 157 | CONFIG_SLABINFO=y |
| @@ -146,7 +159,7 @@ CONFIG_RT_MUTEXES=y | |||
| 146 | CONFIG_BASE_SMALL=0 | 159 | CONFIG_BASE_SMALL=0 |
| 147 | # CONFIG_MODULES is not set | 160 | # CONFIG_MODULES is not set |
| 148 | CONFIG_BLOCK=y | 161 | CONFIG_BLOCK=y |
| 149 | # CONFIG_LBD is not set | 162 | CONFIG_LBDAF=y |
| 150 | # CONFIG_BLK_DEV_BSG is not set | 163 | # CONFIG_BLK_DEV_BSG is not set |
| 151 | # CONFIG_BLK_DEV_INTEGRITY is not set | 164 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 152 | 165 | ||
| @@ -179,6 +192,7 @@ CONFIG_MPC85xx=y | |||
| 179 | # CONFIG_MPC85xx_DS is not set | 192 | # CONFIG_MPC85xx_DS is not set |
| 180 | # CONFIG_SOCRATES is not set | 193 | # CONFIG_SOCRATES is not set |
| 181 | # CONFIG_KSI8560 is not set | 194 | # CONFIG_KSI8560 is not set |
| 195 | # CONFIG_XES_MPC85xx is not set | ||
| 182 | # CONFIG_STX_GP3 is not set | 196 | # CONFIG_STX_GP3 is not set |
| 183 | # CONFIG_TQM8540 is not set | 197 | # CONFIG_TQM8540 is not set |
| 184 | CONFIG_TQM8541=y | 198 | CONFIG_TQM8541=y |
| @@ -228,6 +242,7 @@ CONFIG_BINFMT_ELF=y | |||
| 228 | # CONFIG_BINFMT_MISC is not set | 242 | # CONFIG_BINFMT_MISC is not set |
| 229 | CONFIG_MATH_EMULATION=y | 243 | CONFIG_MATH_EMULATION=y |
| 230 | # CONFIG_IOMMU_HELPER is not set | 244 | # CONFIG_IOMMU_HELPER is not set |
| 245 | # CONFIG_SWIOTLB is not set | ||
| 231 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 246 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 232 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 247 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 233 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 248 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -246,9 +261,9 @@ CONFIG_MIGRATION=y | |||
| 246 | CONFIG_ZONE_DMA_FLAG=1 | 261 | CONFIG_ZONE_DMA_FLAG=1 |
| 247 | CONFIG_BOUNCE=y | 262 | CONFIG_BOUNCE=y |
| 248 | CONFIG_VIRT_TO_BUS=y | 263 | CONFIG_VIRT_TO_BUS=y |
| 249 | CONFIG_UNEVICTABLE_LRU=y | ||
| 250 | CONFIG_HAVE_MLOCK=y | 264 | CONFIG_HAVE_MLOCK=y |
| 251 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 265 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 266 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 252 | CONFIG_PPC_4K_PAGES=y | 267 | CONFIG_PPC_4K_PAGES=y |
| 253 | # CONFIG_PPC_16K_PAGES is not set | 268 | # CONFIG_PPC_16K_PAGES is not set |
| 254 | # CONFIG_PPC_64K_PAGES is not set | 269 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -356,6 +371,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 356 | # CONFIG_ECONET is not set | 371 | # CONFIG_ECONET is not set |
| 357 | # CONFIG_WAN_ROUTER is not set | 372 | # CONFIG_WAN_ROUTER is not set |
| 358 | # CONFIG_PHONET is not set | 373 | # CONFIG_PHONET is not set |
| 374 | # CONFIG_IEEE802154 is not set | ||
| 359 | # CONFIG_NET_SCHED is not set | 375 | # CONFIG_NET_SCHED is not set |
| 360 | # CONFIG_DCB is not set | 376 | # CONFIG_DCB is not set |
| 361 | 377 | ||
| @@ -373,7 +389,11 @@ CONFIG_WIRELESS=y | |||
| 373 | CONFIG_WIRELESS_OLD_REGULATORY=y | 389 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 374 | # CONFIG_WIRELESS_EXT is not set | 390 | # CONFIG_WIRELESS_EXT is not set |
| 375 | # CONFIG_LIB80211 is not set | 391 | # CONFIG_LIB80211 is not set |
| 376 | # CONFIG_MAC80211 is not set | 392 | |
| 393 | # | ||
| 394 | # CFG80211 needs to be enabled for MAC80211 | ||
| 395 | # | ||
| 396 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 377 | # CONFIG_WIMAX is not set | 397 | # CONFIG_WIMAX is not set |
| 378 | # CONFIG_RFKILL is not set | 398 | # CONFIG_RFKILL is not set |
| 379 | # CONFIG_NET_9P is not set | 399 | # CONFIG_NET_9P is not set |
| @@ -475,6 +495,7 @@ CONFIG_MTD_CFI_UTIL=y | |||
| 475 | CONFIG_OF_DEVICE=y | 495 | CONFIG_OF_DEVICE=y |
| 476 | CONFIG_OF_GPIO=y | 496 | CONFIG_OF_GPIO=y |
| 477 | CONFIG_OF_I2C=y | 497 | CONFIG_OF_I2C=y |
| 498 | CONFIG_OF_MDIO=y | ||
| 478 | # CONFIG_PARPORT is not set | 499 | # CONFIG_PARPORT is not set |
| 479 | CONFIG_BLK_DEV=y | 500 | CONFIG_BLK_DEV=y |
| 480 | # CONFIG_BLK_DEV_FD is not set | 501 | # CONFIG_BLK_DEV_FD is not set |
| @@ -509,7 +530,9 @@ CONFIG_MISC_DEVICES=y | |||
| 509 | # | 530 | # |
| 510 | # CONFIG_EEPROM_AT24 is not set | 531 | # CONFIG_EEPROM_AT24 is not set |
| 511 | # CONFIG_EEPROM_LEGACY is not set | 532 | # CONFIG_EEPROM_LEGACY is not set |
| 533 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 512 | # CONFIG_EEPROM_93CX6 is not set | 534 | # CONFIG_EEPROM_93CX6 is not set |
| 535 | # CONFIG_CB710_CORE is not set | ||
| 513 | CONFIG_HAVE_IDE=y | 536 | CONFIG_HAVE_IDE=y |
| 514 | CONFIG_IDE=y | 537 | CONFIG_IDE=y |
| 515 | 538 | ||
| @@ -584,14 +607,17 @@ CONFIG_BLK_DEV_IDEDMA=y | |||
| 584 | # | 607 | # |
| 585 | 608 | ||
| 586 | # | 609 | # |
| 587 | # Enable only one of the two stacks, unless you know what you are doing | 610 | # You can enable one or both FireWire driver stacks. |
| 611 | # | ||
| 612 | |||
| 613 | # | ||
| 614 | # See the help texts for more information. | ||
| 588 | # | 615 | # |
| 589 | # CONFIG_FIREWIRE is not set | 616 | # CONFIG_FIREWIRE is not set |
| 590 | # CONFIG_IEEE1394 is not set | 617 | # CONFIG_IEEE1394 is not set |
| 591 | # CONFIG_I2O is not set | 618 | # CONFIG_I2O is not set |
| 592 | # CONFIG_MACINTOSH_DRIVERS is not set | 619 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 593 | CONFIG_NETDEVICES=y | 620 | CONFIG_NETDEVICES=y |
| 594 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 595 | # CONFIG_DUMMY is not set | 621 | # CONFIG_DUMMY is not set |
| 596 | # CONFIG_BONDING is not set | 622 | # CONFIG_BONDING is not set |
| 597 | # CONFIG_MACVLAN is not set | 623 | # CONFIG_MACVLAN is not set |
| @@ -654,6 +680,7 @@ CONFIG_E100=y | |||
| 654 | # CONFIG_SMSC9420 is not set | 680 | # CONFIG_SMSC9420 is not set |
| 655 | # CONFIG_SUNDANCE is not set | 681 | # CONFIG_SUNDANCE is not set |
| 656 | # CONFIG_TLAN is not set | 682 | # CONFIG_TLAN is not set |
| 683 | # CONFIG_KS8842 is not set | ||
| 657 | # CONFIG_VIA_RHINE is not set | 684 | # CONFIG_VIA_RHINE is not set |
| 658 | # CONFIG_SC92031 is not set | 685 | # CONFIG_SC92031 is not set |
| 659 | # CONFIG_ATL2 is not set | 686 | # CONFIG_ATL2 is not set |
| @@ -676,8 +703,10 @@ CONFIG_NETDEV_1000=y | |||
| 676 | # CONFIG_VIA_VELOCITY is not set | 703 | # CONFIG_VIA_VELOCITY is not set |
| 677 | # CONFIG_TIGON3 is not set | 704 | # CONFIG_TIGON3 is not set |
| 678 | # CONFIG_BNX2 is not set | 705 | # CONFIG_BNX2 is not set |
| 706 | # CONFIG_CNIC is not set | ||
| 679 | CONFIG_FSL_PQ_MDIO=y | 707 | CONFIG_FSL_PQ_MDIO=y |
| 680 | CONFIG_GIANFAR=y | 708 | CONFIG_GIANFAR=y |
| 709 | # CONFIG_MV643XX_ETH is not set | ||
| 681 | # CONFIG_QLA3XXX is not set | 710 | # CONFIG_QLA3XXX is not set |
| 682 | # CONFIG_ATL1 is not set | 711 | # CONFIG_ATL1 is not set |
| 683 | # CONFIG_ATL1E is not set | 712 | # CONFIG_ATL1E is not set |
| @@ -831,6 +860,7 @@ CONFIG_I2C_HELPER_AUTO=y | |||
| 831 | # I2C system bus drivers (mostly embedded / system-on-chip) | 860 | # I2C system bus drivers (mostly embedded / system-on-chip) |
| 832 | # | 861 | # |
| 833 | # CONFIG_I2C_CPM is not set | 862 | # CONFIG_I2C_CPM is not set |
| 863 | # CONFIG_I2C_DESIGNWARE is not set | ||
| 834 | # CONFIG_I2C_GPIO is not set | 864 | # CONFIG_I2C_GPIO is not set |
| 835 | CONFIG_I2C_MPC=y | 865 | CONFIG_I2C_MPC=y |
| 836 | # CONFIG_I2C_OCORES is not set | 866 | # CONFIG_I2C_OCORES is not set |
| @@ -859,13 +889,17 @@ CONFIG_I2C_MPC=y | |||
| 859 | # CONFIG_SENSORS_PCF8574 is not set | 889 | # CONFIG_SENSORS_PCF8574 is not set |
| 860 | # CONFIG_PCF8575 is not set | 890 | # CONFIG_PCF8575 is not set |
| 861 | # CONFIG_SENSORS_PCA9539 is not set | 891 | # CONFIG_SENSORS_PCA9539 is not set |
| 862 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 863 | # CONFIG_SENSORS_TSL2550 is not set | 892 | # CONFIG_SENSORS_TSL2550 is not set |
| 864 | # CONFIG_I2C_DEBUG_CORE is not set | 893 | # CONFIG_I2C_DEBUG_CORE is not set |
| 865 | # CONFIG_I2C_DEBUG_ALGO is not set | 894 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 866 | # CONFIG_I2C_DEBUG_BUS is not set | 895 | # CONFIG_I2C_DEBUG_BUS is not set |
| 867 | # CONFIG_I2C_DEBUG_CHIP is not set | 896 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 868 | # CONFIG_SPI is not set | 897 | # CONFIG_SPI is not set |
| 898 | |||
| 899 | # | ||
| 900 | # PPS support | ||
| 901 | # | ||
| 902 | # CONFIG_PPS is not set | ||
| 869 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 903 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 870 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 904 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 871 | CONFIG_GPIOLIB=y | 905 | CONFIG_GPIOLIB=y |
| @@ -944,6 +978,7 @@ CONFIG_SENSORS_LM75=y | |||
| 944 | # CONFIG_SENSORS_SMSC47B397 is not set | 978 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 945 | # CONFIG_SENSORS_ADS7828 is not set | 979 | # CONFIG_SENSORS_ADS7828 is not set |
| 946 | # CONFIG_SENSORS_THMC50 is not set | 980 | # CONFIG_SENSORS_THMC50 is not set |
| 981 | # CONFIG_SENSORS_TMP401 is not set | ||
| 947 | # CONFIG_SENSORS_VIA686A is not set | 982 | # CONFIG_SENSORS_VIA686A is not set |
| 948 | # CONFIG_SENSORS_VT1211 is not set | 983 | # CONFIG_SENSORS_VT1211 is not set |
| 949 | # CONFIG_SENSORS_VT8231 is not set | 984 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -979,23 +1014,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 979 | # CONFIG_MFD_WM8400 is not set | 1014 | # CONFIG_MFD_WM8400 is not set |
| 980 | # CONFIG_MFD_WM8350_I2C is not set | 1015 | # CONFIG_MFD_WM8350_I2C is not set |
| 981 | # CONFIG_MFD_PCF50633 is not set | 1016 | # CONFIG_MFD_PCF50633 is not set |
| 1017 | # CONFIG_AB3100_CORE is not set | ||
| 982 | # CONFIG_REGULATOR is not set | 1018 | # CONFIG_REGULATOR is not set |
| 983 | 1019 | # CONFIG_MEDIA_SUPPORT is not set | |
| 984 | # | ||
| 985 | # Multimedia devices | ||
| 986 | # | ||
| 987 | |||
| 988 | # | ||
| 989 | # Multimedia core support | ||
| 990 | # | ||
| 991 | # CONFIG_VIDEO_DEV is not set | ||
| 992 | # CONFIG_DVB_CORE is not set | ||
| 993 | # CONFIG_VIDEO_MEDIA is not set | ||
| 994 | |||
| 995 | # | ||
| 996 | # Multimedia drivers | ||
| 997 | # | ||
| 998 | CONFIG_DAB=y | ||
| 999 | 1020 | ||
| 1000 | # | 1021 | # |
| 1001 | # Graphics support | 1022 | # Graphics support |
| @@ -1052,6 +1073,10 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
| 1052 | # CONFIG_DMADEVICES is not set | 1073 | # CONFIG_DMADEVICES is not set |
| 1053 | # CONFIG_AUXDISPLAY is not set | 1074 | # CONFIG_AUXDISPLAY is not set |
| 1054 | # CONFIG_UIO is not set | 1075 | # CONFIG_UIO is not set |
| 1076 | |||
| 1077 | # | ||
| 1078 | # TI VLYNQ | ||
| 1079 | # | ||
| 1055 | # CONFIG_STAGING is not set | 1080 | # CONFIG_STAGING is not set |
| 1056 | 1081 | ||
| 1057 | # | 1082 | # |
| @@ -1071,10 +1096,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1071 | # CONFIG_REISERFS_FS is not set | 1096 | # CONFIG_REISERFS_FS is not set |
| 1072 | # CONFIG_JFS_FS is not set | 1097 | # CONFIG_JFS_FS is not set |
| 1073 | # CONFIG_FS_POSIX_ACL is not set | 1098 | # CONFIG_FS_POSIX_ACL is not set |
| 1074 | CONFIG_FILE_LOCKING=y | ||
| 1075 | # CONFIG_XFS_FS is not set | 1099 | # CONFIG_XFS_FS is not set |
| 1100 | # CONFIG_GFS2_FS is not set | ||
| 1076 | # CONFIG_OCFS2_FS is not set | 1101 | # CONFIG_OCFS2_FS is not set |
| 1077 | # CONFIG_BTRFS_FS is not set | 1102 | # CONFIG_BTRFS_FS is not set |
| 1103 | CONFIG_FILE_LOCKING=y | ||
| 1104 | CONFIG_FSNOTIFY=y | ||
| 1078 | CONFIG_DNOTIFY=y | 1105 | CONFIG_DNOTIFY=y |
| 1079 | CONFIG_INOTIFY=y | 1106 | CONFIG_INOTIFY=y |
| 1080 | CONFIG_INOTIFY_USER=y | 1107 | CONFIG_INOTIFY_USER=y |
| @@ -1201,6 +1228,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1201 | CONFIG_HAS_DMA=y | 1228 | CONFIG_HAS_DMA=y |
| 1202 | CONFIG_HAVE_LMB=y | 1229 | CONFIG_HAVE_LMB=y |
| 1203 | CONFIG_NLATTR=y | 1230 | CONFIG_NLATTR=y |
| 1231 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1204 | 1232 | ||
| 1205 | # | 1233 | # |
| 1206 | # Kernel hacking | 1234 | # Kernel hacking |
| @@ -1226,22 +1254,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1226 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1254 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1227 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1255 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1228 | CONFIG_TRACING_SUPPORT=y | 1256 | CONFIG_TRACING_SUPPORT=y |
| 1229 | 1257 | # CONFIG_FTRACE is not set | |
| 1230 | # | ||
| 1231 | # Tracers | ||
| 1232 | # | ||
| 1233 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1234 | # CONFIG_SCHED_TRACER is not set | ||
| 1235 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1236 | # CONFIG_EVENT_TRACER is not set | ||
| 1237 | # CONFIG_BOOT_TRACER is not set | ||
| 1238 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1239 | # CONFIG_STACK_TRACER is not set | ||
| 1240 | # CONFIG_KMEMTRACE is not set | ||
| 1241 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1242 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1243 | # CONFIG_SAMPLES is not set | 1258 | # CONFIG_SAMPLES is not set |
| 1244 | CONFIG_HAVE_ARCH_KGDB=y | 1259 | CONFIG_HAVE_ARCH_KGDB=y |
| 1260 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1261 | CONFIG_PPC_WERROR=y | ||
| 1245 | CONFIG_PRINT_STACK_DEPTH=64 | 1262 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1246 | # CONFIG_IRQSTACKS is not set | 1263 | # CONFIG_IRQSTACKS is not set |
| 1247 | # CONFIG_PPC_EARLY_DEBUG is not set | 1264 | # CONFIG_PPC_EARLY_DEBUG is not set |
diff --git a/arch/powerpc/configs/85xx/tqm8548_defconfig b/arch/powerpc/configs/85xx/tqm8548_defconfig index 8b4faae7a9a1..4f228a905274 100644 --- a/arch/powerpc/configs/85xx/tqm8548_defconfig +++ b/arch/powerpc/configs/85xx/tqm8548_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:24 2009 | 4 | # Wed Jul 29 23:32:23 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -34,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 34 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 35 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 36 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 38 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 39 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 41 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 43 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 44 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 45 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 48 | CONFIG_PPC=y | 49 | CONFIG_PPC=y |
| @@ -56,11 +57,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 56 | # CONFIG_GENERIC_TBSYNC is not set | 57 | # CONFIG_GENERIC_TBSYNC is not set |
| 57 | CONFIG_AUDIT_ARCH=y | 58 | CONFIG_AUDIT_ARCH=y |
| 58 | CONFIG_GENERIC_BUG=y | 59 | CONFIG_GENERIC_BUG=y |
| 60 | CONFIG_DTC=y | ||
| 59 | CONFIG_DEFAULT_UIMAGE=y | 61 | CONFIG_DEFAULT_UIMAGE=y |
| 60 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 61 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 62 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 63 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 64 | 67 | ||
| 65 | # | 68 | # |
| 66 | # General setup | 69 | # General setup |
| @@ -111,7 +114,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 111 | CONFIG_KALLSYMS=y | 114 | CONFIG_KALLSYMS=y |
| 112 | # CONFIG_KALLSYMS_ALL is not set | 115 | # CONFIG_KALLSYMS_ALL is not set |
| 113 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 116 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 114 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 115 | CONFIG_HOTPLUG=y | 117 | CONFIG_HOTPLUG=y |
| 116 | CONFIG_PRINTK=y | 118 | CONFIG_PRINTK=y |
| 117 | CONFIG_BUG=y | 119 | CONFIG_BUG=y |
| @@ -124,9 +126,16 @@ CONFIG_TIMERFD=y | |||
| 124 | CONFIG_EVENTFD=y | 126 | CONFIG_EVENTFD=y |
| 125 | CONFIG_SHMEM=y | 127 | CONFIG_SHMEM=y |
| 126 | CONFIG_AIO=y | 128 | CONFIG_AIO=y |
| 129 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 130 | |||
| 131 | # | ||
| 132 | # Performance Counters | ||
| 133 | # | ||
| 134 | # CONFIG_PERF_COUNTERS is not set | ||
| 127 | CONFIG_VM_EVENT_COUNTERS=y | 135 | CONFIG_VM_EVENT_COUNTERS=y |
| 128 | CONFIG_PCI_QUIRKS=y | 136 | CONFIG_PCI_QUIRKS=y |
| 129 | CONFIG_SLUB_DEBUG=y | 137 | CONFIG_SLUB_DEBUG=y |
| 138 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 130 | CONFIG_COMPAT_BRK=y | 139 | CONFIG_COMPAT_BRK=y |
| 131 | # CONFIG_SLAB is not set | 140 | # CONFIG_SLAB is not set |
| 132 | CONFIG_SLUB=y | 141 | CONFIG_SLUB=y |
| @@ -140,6 +149,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 140 | CONFIG_HAVE_KPROBES=y | 149 | CONFIG_HAVE_KPROBES=y |
| 141 | CONFIG_HAVE_KRETPROBES=y | 150 | CONFIG_HAVE_KRETPROBES=y |
| 142 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 151 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 152 | |||
| 153 | # | ||
| 154 | # GCOV-based kernel profiling | ||
| 155 | # | ||
| 143 | # CONFIG_SLOW_WORK is not set | 156 | # CONFIG_SLOW_WORK is not set |
| 144 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 157 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 145 | CONFIG_SLABINFO=y | 158 | CONFIG_SLABINFO=y |
| @@ -152,7 +165,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 152 | # CONFIG_MODVERSIONS is not set | 165 | # CONFIG_MODVERSIONS is not set |
| 153 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 166 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 154 | CONFIG_BLOCK=y | 167 | CONFIG_BLOCK=y |
| 155 | # CONFIG_LBD is not set | 168 | CONFIG_LBDAF=y |
| 156 | # CONFIG_BLK_DEV_BSG is not set | 169 | # CONFIG_BLK_DEV_BSG is not set |
| 157 | # CONFIG_BLK_DEV_INTEGRITY is not set | 170 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 158 | 171 | ||
| @@ -185,6 +198,7 @@ CONFIG_MPC85xx=y | |||
| 185 | # CONFIG_MPC85xx_DS is not set | 198 | # CONFIG_MPC85xx_DS is not set |
| 186 | # CONFIG_SOCRATES is not set | 199 | # CONFIG_SOCRATES is not set |
| 187 | # CONFIG_KSI8560 is not set | 200 | # CONFIG_KSI8560 is not set |
| 201 | # CONFIG_XES_MPC85xx is not set | ||
| 188 | # CONFIG_STX_GP3 is not set | 202 | # CONFIG_STX_GP3 is not set |
| 189 | # CONFIG_TQM8540 is not set | 203 | # CONFIG_TQM8540 is not set |
| 190 | # CONFIG_TQM8541 is not set | 204 | # CONFIG_TQM8541 is not set |
| @@ -234,6 +248,7 @@ CONFIG_BINFMT_ELF=y | |||
| 234 | CONFIG_BINFMT_MISC=y | 248 | CONFIG_BINFMT_MISC=y |
| 235 | CONFIG_MATH_EMULATION=y | 249 | CONFIG_MATH_EMULATION=y |
| 236 | # CONFIG_IOMMU_HELPER is not set | 250 | # CONFIG_IOMMU_HELPER is not set |
| 251 | # CONFIG_SWIOTLB is not set | ||
| 237 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 252 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 238 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 253 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 239 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 254 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -252,9 +267,9 @@ CONFIG_MIGRATION=y | |||
| 252 | CONFIG_ZONE_DMA_FLAG=1 | 267 | CONFIG_ZONE_DMA_FLAG=1 |
| 253 | CONFIG_BOUNCE=y | 268 | CONFIG_BOUNCE=y |
| 254 | CONFIG_VIRT_TO_BUS=y | 269 | CONFIG_VIRT_TO_BUS=y |
| 255 | CONFIG_UNEVICTABLE_LRU=y | ||
| 256 | CONFIG_HAVE_MLOCK=y | 270 | CONFIG_HAVE_MLOCK=y |
| 257 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 271 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 272 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 258 | CONFIG_PPC_4K_PAGES=y | 273 | CONFIG_PPC_4K_PAGES=y |
| 259 | # CONFIG_PPC_16K_PAGES is not set | 274 | # CONFIG_PPC_16K_PAGES is not set |
| 260 | # CONFIG_PPC_64K_PAGES is not set | 275 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -281,6 +296,8 @@ CONFIG_PCI_DOMAINS=y | |||
| 281 | CONFIG_PCI_SYSCALL=y | 296 | CONFIG_PCI_SYSCALL=y |
| 282 | CONFIG_PCIEPORTBUS=y | 297 | CONFIG_PCIEPORTBUS=y |
| 283 | CONFIG_PCIEAER=y | 298 | CONFIG_PCIEAER=y |
| 299 | # CONFIG_PCIE_ECRC is not set | ||
| 300 | # CONFIG_PCIEAER_INJECT is not set | ||
| 284 | # CONFIG_PCIEASPM is not set | 301 | # CONFIG_PCIEASPM is not set |
| 285 | CONFIG_ARCH_SUPPORTS_MSI=y | 302 | CONFIG_ARCH_SUPPORTS_MSI=y |
| 286 | # CONFIG_PCI_MSI is not set | 303 | # CONFIG_PCI_MSI is not set |
| @@ -368,6 +385,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 368 | # CONFIG_ECONET is not set | 385 | # CONFIG_ECONET is not set |
| 369 | # CONFIG_WAN_ROUTER is not set | 386 | # CONFIG_WAN_ROUTER is not set |
| 370 | # CONFIG_PHONET is not set | 387 | # CONFIG_PHONET is not set |
| 388 | # CONFIG_IEEE802154 is not set | ||
| 371 | # CONFIG_NET_SCHED is not set | 389 | # CONFIG_NET_SCHED is not set |
| 372 | # CONFIG_DCB is not set | 390 | # CONFIG_DCB is not set |
| 373 | 391 | ||
| @@ -497,6 +515,7 @@ CONFIG_MTD_NAND_FSL_UPM=y | |||
| 497 | # CONFIG_MTD_UBI is not set | 515 | # CONFIG_MTD_UBI is not set |
| 498 | CONFIG_OF_DEVICE=y | 516 | CONFIG_OF_DEVICE=y |
| 499 | CONFIG_OF_I2C=y | 517 | CONFIG_OF_I2C=y |
| 518 | CONFIG_OF_MDIO=y | ||
| 500 | # CONFIG_PARPORT is not set | 519 | # CONFIG_PARPORT is not set |
| 501 | CONFIG_BLK_DEV=y | 520 | CONFIG_BLK_DEV=y |
| 502 | # CONFIG_BLK_DEV_FD is not set | 521 | # CONFIG_BLK_DEV_FD is not set |
| @@ -531,7 +550,9 @@ CONFIG_MISC_DEVICES=y | |||
| 531 | # | 550 | # |
| 532 | # CONFIG_EEPROM_AT24 is not set | 551 | # CONFIG_EEPROM_AT24 is not set |
| 533 | # CONFIG_EEPROM_LEGACY is not set | 552 | # CONFIG_EEPROM_LEGACY is not set |
| 553 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 534 | # CONFIG_EEPROM_93CX6 is not set | 554 | # CONFIG_EEPROM_93CX6 is not set |
| 555 | # CONFIG_CB710_CORE is not set | ||
| 535 | CONFIG_HAVE_IDE=y | 556 | CONFIG_HAVE_IDE=y |
| 536 | # CONFIG_IDE is not set | 557 | # CONFIG_IDE is not set |
| 537 | 558 | ||
| @@ -551,14 +572,17 @@ CONFIG_HAVE_IDE=y | |||
| 551 | # | 572 | # |
| 552 | 573 | ||
| 553 | # | 574 | # |
| 554 | # Enable only one of the two stacks, unless you know what you are doing | 575 | # You can enable one or both FireWire driver stacks. |
| 576 | # | ||
| 577 | |||
| 578 | # | ||
| 579 | # See the help texts for more information. | ||
| 555 | # | 580 | # |
| 556 | # CONFIG_FIREWIRE is not set | 581 | # CONFIG_FIREWIRE is not set |
| 557 | # CONFIG_IEEE1394 is not set | 582 | # CONFIG_IEEE1394 is not set |
| 558 | # CONFIG_I2O is not set | 583 | # CONFIG_I2O is not set |
| 559 | # CONFIG_MACINTOSH_DRIVERS is not set | 584 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 560 | CONFIG_NETDEVICES=y | 585 | CONFIG_NETDEVICES=y |
| 561 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 562 | # CONFIG_DUMMY is not set | 586 | # CONFIG_DUMMY is not set |
| 563 | # CONFIG_BONDING is not set | 587 | # CONFIG_BONDING is not set |
| 564 | # CONFIG_MACVLAN is not set | 588 | # CONFIG_MACVLAN is not set |
| @@ -605,6 +629,7 @@ CONFIG_MII=y | |||
| 605 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 629 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 606 | # CONFIG_NET_PCI is not set | 630 | # CONFIG_NET_PCI is not set |
| 607 | # CONFIG_B44 is not set | 631 | # CONFIG_B44 is not set |
| 632 | # CONFIG_KS8842 is not set | ||
| 608 | # CONFIG_ATL2 is not set | 633 | # CONFIG_ATL2 is not set |
| 609 | CONFIG_NETDEV_1000=y | 634 | CONFIG_NETDEV_1000=y |
| 610 | # CONFIG_ACENIC is not set | 635 | # CONFIG_ACENIC is not set |
| @@ -624,8 +649,10 @@ CONFIG_NETDEV_1000=y | |||
| 624 | # CONFIG_VIA_VELOCITY is not set | 649 | # CONFIG_VIA_VELOCITY is not set |
| 625 | # CONFIG_TIGON3 is not set | 650 | # CONFIG_TIGON3 is not set |
| 626 | # CONFIG_BNX2 is not set | 651 | # CONFIG_BNX2 is not set |
| 652 | # CONFIG_CNIC is not set | ||
| 627 | CONFIG_FSL_PQ_MDIO=y | 653 | CONFIG_FSL_PQ_MDIO=y |
| 628 | CONFIG_GIANFAR=y | 654 | CONFIG_GIANFAR=y |
| 655 | # CONFIG_MV643XX_ETH is not set | ||
| 629 | # CONFIG_QLA3XXX is not set | 656 | # CONFIG_QLA3XXX is not set |
| 630 | # CONFIG_ATL1 is not set | 657 | # CONFIG_ATL1 is not set |
| 631 | # CONFIG_ATL1E is not set | 658 | # CONFIG_ATL1E is not set |
| @@ -801,13 +828,17 @@ CONFIG_I2C_MPC=y | |||
| 801 | # CONFIG_SENSORS_PCF8574 is not set | 828 | # CONFIG_SENSORS_PCF8574 is not set |
| 802 | # CONFIG_PCF8575 is not set | 829 | # CONFIG_PCF8575 is not set |
| 803 | # CONFIG_SENSORS_PCA9539 is not set | 830 | # CONFIG_SENSORS_PCA9539 is not set |
| 804 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 805 | # CONFIG_SENSORS_TSL2550 is not set | 831 | # CONFIG_SENSORS_TSL2550 is not set |
| 806 | # CONFIG_I2C_DEBUG_CORE is not set | 832 | # CONFIG_I2C_DEBUG_CORE is not set |
| 807 | # CONFIG_I2C_DEBUG_ALGO is not set | 833 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 808 | # CONFIG_I2C_DEBUG_BUS is not set | 834 | # CONFIG_I2C_DEBUG_BUS is not set |
| 809 | # CONFIG_I2C_DEBUG_CHIP is not set | 835 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 810 | # CONFIG_SPI is not set | 836 | # CONFIG_SPI is not set |
| 837 | |||
| 838 | # | ||
| 839 | # PPS support | ||
| 840 | # | ||
| 841 | # CONFIG_PPS is not set | ||
| 811 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 842 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 812 | # CONFIG_GPIOLIB is not set | 843 | # CONFIG_GPIOLIB is not set |
| 813 | # CONFIG_W1 is not set | 844 | # CONFIG_W1 is not set |
| @@ -862,6 +893,7 @@ CONFIG_SENSORS_LM75=y | |||
| 862 | # CONFIG_SENSORS_SMSC47B397 is not set | 893 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 863 | # CONFIG_SENSORS_ADS7828 is not set | 894 | # CONFIG_SENSORS_ADS7828 is not set |
| 864 | # CONFIG_SENSORS_THMC50 is not set | 895 | # CONFIG_SENSORS_THMC50 is not set |
| 896 | # CONFIG_SENSORS_TMP401 is not set | ||
| 865 | # CONFIG_SENSORS_VIA686A is not set | 897 | # CONFIG_SENSORS_VIA686A is not set |
| 866 | # CONFIG_SENSORS_VT1211 is not set | 898 | # CONFIG_SENSORS_VT1211 is not set |
| 867 | # CONFIG_SENSORS_VT8231 is not set | 899 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -896,23 +928,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 896 | # CONFIG_MFD_WM8400 is not set | 928 | # CONFIG_MFD_WM8400 is not set |
| 897 | # CONFIG_MFD_WM8350_I2C is not set | 929 | # CONFIG_MFD_WM8350_I2C is not set |
| 898 | # CONFIG_MFD_PCF50633 is not set | 930 | # CONFIG_MFD_PCF50633 is not set |
| 931 | # CONFIG_AB3100_CORE is not set | ||
| 899 | # CONFIG_REGULATOR is not set | 932 | # CONFIG_REGULATOR is not set |
| 900 | 933 | # CONFIG_MEDIA_SUPPORT is not set | |
| 901 | # | ||
| 902 | # Multimedia devices | ||
| 903 | # | ||
| 904 | |||
| 905 | # | ||
| 906 | # Multimedia core support | ||
| 907 | # | ||
| 908 | # CONFIG_VIDEO_DEV is not set | ||
| 909 | # CONFIG_DVB_CORE is not set | ||
| 910 | # CONFIG_VIDEO_MEDIA is not set | ||
| 911 | |||
| 912 | # | ||
| 913 | # Multimedia drivers | ||
| 914 | # | ||
| 915 | CONFIG_DAB=y | ||
| 916 | 934 | ||
| 917 | # | 935 | # |
| 918 | # Graphics support | 936 | # Graphics support |
| @@ -977,6 +995,7 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 977 | # CONFIG_RTC_DRV_S35390A is not set | 995 | # CONFIG_RTC_DRV_S35390A is not set |
| 978 | # CONFIG_RTC_DRV_FM3130 is not set | 996 | # CONFIG_RTC_DRV_FM3130 is not set |
| 979 | # CONFIG_RTC_DRV_RX8581 is not set | 997 | # CONFIG_RTC_DRV_RX8581 is not set |
| 998 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 980 | 999 | ||
| 981 | # | 1000 | # |
| 982 | # SPI RTC drivers | 1001 | # SPI RTC drivers |
| @@ -1004,6 +1023,10 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 1004 | # CONFIG_DMADEVICES is not set | 1023 | # CONFIG_DMADEVICES is not set |
| 1005 | # CONFIG_AUXDISPLAY is not set | 1024 | # CONFIG_AUXDISPLAY is not set |
| 1006 | # CONFIG_UIO is not set | 1025 | # CONFIG_UIO is not set |
| 1026 | |||
| 1027 | # | ||
| 1028 | # TI VLYNQ | ||
| 1029 | # | ||
| 1007 | # CONFIG_STAGING is not set | 1030 | # CONFIG_STAGING is not set |
| 1008 | 1031 | ||
| 1009 | # | 1032 | # |
| @@ -1015,10 +1038,12 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 1015 | # CONFIG_REISERFS_FS is not set | 1038 | # CONFIG_REISERFS_FS is not set |
| 1016 | # CONFIG_JFS_FS is not set | 1039 | # CONFIG_JFS_FS is not set |
| 1017 | # CONFIG_FS_POSIX_ACL is not set | 1040 | # CONFIG_FS_POSIX_ACL is not set |
| 1018 | CONFIG_FILE_LOCKING=y | ||
| 1019 | # CONFIG_XFS_FS is not set | 1041 | # CONFIG_XFS_FS is not set |
| 1042 | # CONFIG_GFS2_FS is not set | ||
| 1020 | # CONFIG_OCFS2_FS is not set | 1043 | # CONFIG_OCFS2_FS is not set |
| 1021 | # CONFIG_BTRFS_FS is not set | 1044 | # CONFIG_BTRFS_FS is not set |
| 1045 | CONFIG_FILE_LOCKING=y | ||
| 1046 | CONFIG_FSNOTIFY=y | ||
| 1022 | CONFIG_DNOTIFY=y | 1047 | CONFIG_DNOTIFY=y |
| 1023 | CONFIG_INOTIFY=y | 1048 | CONFIG_INOTIFY=y |
| 1024 | CONFIG_INOTIFY_USER=y | 1049 | CONFIG_INOTIFY_USER=y |
| @@ -1145,6 +1170,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1145 | CONFIG_HAS_DMA=y | 1170 | CONFIG_HAS_DMA=y |
| 1146 | CONFIG_HAVE_LMB=y | 1171 | CONFIG_HAVE_LMB=y |
| 1147 | CONFIG_NLATTR=y | 1172 | CONFIG_NLATTR=y |
| 1173 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1148 | 1174 | ||
| 1149 | # | 1175 | # |
| 1150 | # Kernel hacking | 1176 | # Kernel hacking |
| @@ -1175,6 +1201,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 1175 | # CONFIG_RT_MUTEX_TESTER is not set | 1201 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1176 | # CONFIG_DEBUG_SPINLOCK is not set | 1202 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1177 | CONFIG_DEBUG_MUTEXES=y | 1203 | CONFIG_DEBUG_MUTEXES=y |
| 1204 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1205 | # CONFIG_PROVE_LOCKING is not set | ||
| 1206 | # CONFIG_LOCK_STAT is not set | ||
| 1178 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1207 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1179 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1208 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1180 | # CONFIG_DEBUG_KOBJECT is not set | 1209 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1187,7 +1216,6 @@ CONFIG_DEBUG_MUTEXES=y | |||
| 1187 | # CONFIG_DEBUG_LIST is not set | 1216 | # CONFIG_DEBUG_LIST is not set |
| 1188 | # CONFIG_DEBUG_SG is not set | 1217 | # CONFIG_DEBUG_SG is not set |
| 1189 | # CONFIG_DEBUG_NOTIFIERS is not set | 1218 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1190 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1191 | # CONFIG_RCU_TORTURE_TEST is not set | 1219 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1192 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1220 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1193 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1221 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1201,16 +1229,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1201 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1229 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1202 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1230 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1203 | CONFIG_TRACING_SUPPORT=y | 1231 | CONFIG_TRACING_SUPPORT=y |
| 1204 | 1232 | CONFIG_FTRACE=y | |
| 1205 | # | ||
| 1206 | # Tracers | ||
| 1207 | # | ||
| 1208 | # CONFIG_FUNCTION_TRACER is not set | 1233 | # CONFIG_FUNCTION_TRACER is not set |
| 1234 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1209 | # CONFIG_SCHED_TRACER is not set | 1235 | # CONFIG_SCHED_TRACER is not set |
| 1210 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1236 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1211 | # CONFIG_EVENT_TRACER is not set | ||
| 1212 | # CONFIG_BOOT_TRACER is not set | 1237 | # CONFIG_BOOT_TRACER is not set |
| 1213 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1238 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1239 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1240 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1214 | # CONFIG_STACK_TRACER is not set | 1241 | # CONFIG_STACK_TRACER is not set |
| 1215 | # CONFIG_KMEMTRACE is not set | 1242 | # CONFIG_KMEMTRACE is not set |
| 1216 | # CONFIG_WORKQUEUE_TRACER is not set | 1243 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -1218,6 +1245,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 1218 | # CONFIG_SAMPLES is not set | 1245 | # CONFIG_SAMPLES is not set |
| 1219 | CONFIG_HAVE_ARCH_KGDB=y | 1246 | CONFIG_HAVE_ARCH_KGDB=y |
| 1220 | # CONFIG_KGDB is not set | 1247 | # CONFIG_KGDB is not set |
| 1248 | # CONFIG_KMEMCHECK is not set | ||
| 1249 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1250 | CONFIG_PPC_WERROR=y | ||
| 1221 | CONFIG_PRINT_STACK_DEPTH=64 | 1251 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1222 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1252 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1223 | # CONFIG_DEBUG_STACK_USAGE is not set | 1253 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/85xx/tqm8555_defconfig b/arch/powerpc/configs/85xx/tqm8555_defconfig index 170360934cec..9196724bebc7 100644 --- a/arch/powerpc/configs/85xx/tqm8555_defconfig +++ b/arch/powerpc/configs/85xx/tqm8555_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:25 2009 | 4 | # Wed Jul 29 23:32:24 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -34,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 34 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 35 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 36 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 38 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 39 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 41 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 43 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 44 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 45 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 47 | CONFIG_GENERIC_GPIO=y | 48 | CONFIG_GENERIC_GPIO=y |
| 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 49 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -57,11 +58,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 57 | # CONFIG_GENERIC_TBSYNC is not set | 58 | # CONFIG_GENERIC_TBSYNC is not set |
| 58 | CONFIG_AUDIT_ARCH=y | 59 | CONFIG_AUDIT_ARCH=y |
| 59 | CONFIG_GENERIC_BUG=y | 60 | CONFIG_GENERIC_BUG=y |
| 61 | CONFIG_DTC=y | ||
| 60 | CONFIG_DEFAULT_UIMAGE=y | 62 | CONFIG_DEFAULT_UIMAGE=y |
| 61 | # CONFIG_PPC_DCR_NATIVE is not set | 63 | # CONFIG_PPC_DCR_NATIVE is not set |
| 62 | # CONFIG_PPC_DCR_MMIO is not set | 64 | # CONFIG_PPC_DCR_MMIO is not set |
| 63 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 65 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 64 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 66 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 67 | CONFIG_CONSTRUCTORS=y | ||
| 65 | 68 | ||
| 66 | # | 69 | # |
| 67 | # General setup | 70 | # General setup |
| @@ -110,7 +113,6 @@ CONFIG_ANON_INODES=y | |||
| 110 | CONFIG_EMBEDDED=y | 113 | CONFIG_EMBEDDED=y |
| 111 | CONFIG_SYSCTL_SYSCALL=y | 114 | CONFIG_SYSCTL_SYSCALL=y |
| 112 | # CONFIG_KALLSYMS is not set | 115 | # CONFIG_KALLSYMS is not set |
| 113 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 114 | # CONFIG_HOTPLUG is not set | 116 | # CONFIG_HOTPLUG is not set |
| 115 | CONFIG_PRINTK=y | 117 | CONFIG_PRINTK=y |
| 116 | CONFIG_BUG=y | 118 | CONFIG_BUG=y |
| @@ -123,9 +125,16 @@ CONFIG_TIMERFD=y | |||
| 123 | CONFIG_EVENTFD=y | 125 | CONFIG_EVENTFD=y |
| 124 | CONFIG_SHMEM=y | 126 | CONFIG_SHMEM=y |
| 125 | CONFIG_AIO=y | 127 | CONFIG_AIO=y |
| 128 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 129 | |||
| 130 | # | ||
| 131 | # Performance Counters | ||
| 132 | # | ||
| 133 | # CONFIG_PERF_COUNTERS is not set | ||
| 126 | CONFIG_VM_EVENT_COUNTERS=y | 134 | CONFIG_VM_EVENT_COUNTERS=y |
| 127 | CONFIG_PCI_QUIRKS=y | 135 | CONFIG_PCI_QUIRKS=y |
| 128 | CONFIG_SLUB_DEBUG=y | 136 | CONFIG_SLUB_DEBUG=y |
| 137 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 129 | CONFIG_COMPAT_BRK=y | 138 | CONFIG_COMPAT_BRK=y |
| 130 | # CONFIG_SLAB is not set | 139 | # CONFIG_SLAB is not set |
| 131 | CONFIG_SLUB=y | 140 | CONFIG_SLUB=y |
| @@ -139,6 +148,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 139 | CONFIG_HAVE_KRETPROBES=y | 148 | CONFIG_HAVE_KRETPROBES=y |
| 140 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 149 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 141 | CONFIG_HAVE_CLK=y | 150 | CONFIG_HAVE_CLK=y |
| 151 | |||
| 152 | # | ||
| 153 | # GCOV-based kernel profiling | ||
| 154 | # | ||
| 142 | # CONFIG_SLOW_WORK is not set | 155 | # CONFIG_SLOW_WORK is not set |
| 143 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 156 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 144 | CONFIG_SLABINFO=y | 157 | CONFIG_SLABINFO=y |
| @@ -146,7 +159,7 @@ CONFIG_RT_MUTEXES=y | |||
| 146 | CONFIG_BASE_SMALL=0 | 159 | CONFIG_BASE_SMALL=0 |
| 147 | # CONFIG_MODULES is not set | 160 | # CONFIG_MODULES is not set |
| 148 | CONFIG_BLOCK=y | 161 | CONFIG_BLOCK=y |
| 149 | # CONFIG_LBD is not set | 162 | CONFIG_LBDAF=y |
| 150 | # CONFIG_BLK_DEV_BSG is not set | 163 | # CONFIG_BLK_DEV_BSG is not set |
| 151 | # CONFIG_BLK_DEV_INTEGRITY is not set | 164 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 152 | 165 | ||
| @@ -179,6 +192,7 @@ CONFIG_MPC85xx=y | |||
| 179 | # CONFIG_MPC85xx_DS is not set | 192 | # CONFIG_MPC85xx_DS is not set |
| 180 | # CONFIG_SOCRATES is not set | 193 | # CONFIG_SOCRATES is not set |
| 181 | # CONFIG_KSI8560 is not set | 194 | # CONFIG_KSI8560 is not set |
| 195 | # CONFIG_XES_MPC85xx is not set | ||
| 182 | # CONFIG_STX_GP3 is not set | 196 | # CONFIG_STX_GP3 is not set |
| 183 | # CONFIG_TQM8540 is not set | 197 | # CONFIG_TQM8540 is not set |
| 184 | # CONFIG_TQM8541 is not set | 198 | # CONFIG_TQM8541 is not set |
| @@ -228,6 +242,7 @@ CONFIG_BINFMT_ELF=y | |||
| 228 | # CONFIG_BINFMT_MISC is not set | 242 | # CONFIG_BINFMT_MISC is not set |
| 229 | CONFIG_MATH_EMULATION=y | 243 | CONFIG_MATH_EMULATION=y |
| 230 | # CONFIG_IOMMU_HELPER is not set | 244 | # CONFIG_IOMMU_HELPER is not set |
| 245 | # CONFIG_SWIOTLB is not set | ||
| 231 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 246 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 232 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 247 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 233 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 248 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -246,9 +261,9 @@ CONFIG_MIGRATION=y | |||
| 246 | CONFIG_ZONE_DMA_FLAG=1 | 261 | CONFIG_ZONE_DMA_FLAG=1 |
| 247 | CONFIG_BOUNCE=y | 262 | CONFIG_BOUNCE=y |
| 248 | CONFIG_VIRT_TO_BUS=y | 263 | CONFIG_VIRT_TO_BUS=y |
| 249 | CONFIG_UNEVICTABLE_LRU=y | ||
| 250 | CONFIG_HAVE_MLOCK=y | 264 | CONFIG_HAVE_MLOCK=y |
| 251 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 265 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 266 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 252 | CONFIG_PPC_4K_PAGES=y | 267 | CONFIG_PPC_4K_PAGES=y |
| 253 | # CONFIG_PPC_16K_PAGES is not set | 268 | # CONFIG_PPC_16K_PAGES is not set |
| 254 | # CONFIG_PPC_64K_PAGES is not set | 269 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -356,6 +371,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 356 | # CONFIG_ECONET is not set | 371 | # CONFIG_ECONET is not set |
| 357 | # CONFIG_WAN_ROUTER is not set | 372 | # CONFIG_WAN_ROUTER is not set |
| 358 | # CONFIG_PHONET is not set | 373 | # CONFIG_PHONET is not set |
| 374 | # CONFIG_IEEE802154 is not set | ||
| 359 | # CONFIG_NET_SCHED is not set | 375 | # CONFIG_NET_SCHED is not set |
| 360 | # CONFIG_DCB is not set | 376 | # CONFIG_DCB is not set |
| 361 | 377 | ||
| @@ -373,7 +389,11 @@ CONFIG_WIRELESS=y | |||
| 373 | CONFIG_WIRELESS_OLD_REGULATORY=y | 389 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 374 | # CONFIG_WIRELESS_EXT is not set | 390 | # CONFIG_WIRELESS_EXT is not set |
| 375 | # CONFIG_LIB80211 is not set | 391 | # CONFIG_LIB80211 is not set |
| 376 | # CONFIG_MAC80211 is not set | 392 | |
| 393 | # | ||
| 394 | # CFG80211 needs to be enabled for MAC80211 | ||
| 395 | # | ||
| 396 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 377 | # CONFIG_WIMAX is not set | 397 | # CONFIG_WIMAX is not set |
| 378 | # CONFIG_RFKILL is not set | 398 | # CONFIG_RFKILL is not set |
| 379 | # CONFIG_NET_9P is not set | 399 | # CONFIG_NET_9P is not set |
| @@ -475,6 +495,7 @@ CONFIG_MTD_CFI_UTIL=y | |||
| 475 | CONFIG_OF_DEVICE=y | 495 | CONFIG_OF_DEVICE=y |
| 476 | CONFIG_OF_GPIO=y | 496 | CONFIG_OF_GPIO=y |
| 477 | CONFIG_OF_I2C=y | 497 | CONFIG_OF_I2C=y |
| 498 | CONFIG_OF_MDIO=y | ||
| 478 | # CONFIG_PARPORT is not set | 499 | # CONFIG_PARPORT is not set |
| 479 | CONFIG_BLK_DEV=y | 500 | CONFIG_BLK_DEV=y |
| 480 | # CONFIG_BLK_DEV_FD is not set | 501 | # CONFIG_BLK_DEV_FD is not set |
| @@ -509,7 +530,9 @@ CONFIG_MISC_DEVICES=y | |||
| 509 | # | 530 | # |
| 510 | # CONFIG_EEPROM_AT24 is not set | 531 | # CONFIG_EEPROM_AT24 is not set |
| 511 | # CONFIG_EEPROM_LEGACY is not set | 532 | # CONFIG_EEPROM_LEGACY is not set |
| 533 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 512 | # CONFIG_EEPROM_93CX6 is not set | 534 | # CONFIG_EEPROM_93CX6 is not set |
| 535 | # CONFIG_CB710_CORE is not set | ||
| 513 | CONFIG_HAVE_IDE=y | 536 | CONFIG_HAVE_IDE=y |
| 514 | CONFIG_IDE=y | 537 | CONFIG_IDE=y |
| 515 | 538 | ||
| @@ -584,14 +607,17 @@ CONFIG_BLK_DEV_IDEDMA=y | |||
| 584 | # | 607 | # |
| 585 | 608 | ||
| 586 | # | 609 | # |
| 587 | # Enable only one of the two stacks, unless you know what you are doing | 610 | # You can enable one or both FireWire driver stacks. |
| 611 | # | ||
| 612 | |||
| 613 | # | ||
| 614 | # See the help texts for more information. | ||
| 588 | # | 615 | # |
| 589 | # CONFIG_FIREWIRE is not set | 616 | # CONFIG_FIREWIRE is not set |
| 590 | # CONFIG_IEEE1394 is not set | 617 | # CONFIG_IEEE1394 is not set |
| 591 | # CONFIG_I2O is not set | 618 | # CONFIG_I2O is not set |
| 592 | # CONFIG_MACINTOSH_DRIVERS is not set | 619 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 593 | CONFIG_NETDEVICES=y | 620 | CONFIG_NETDEVICES=y |
| 594 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 595 | # CONFIG_DUMMY is not set | 621 | # CONFIG_DUMMY is not set |
| 596 | # CONFIG_BONDING is not set | 622 | # CONFIG_BONDING is not set |
| 597 | # CONFIG_MACVLAN is not set | 623 | # CONFIG_MACVLAN is not set |
| @@ -654,6 +680,7 @@ CONFIG_E100=y | |||
| 654 | # CONFIG_SMSC9420 is not set | 680 | # CONFIG_SMSC9420 is not set |
| 655 | # CONFIG_SUNDANCE is not set | 681 | # CONFIG_SUNDANCE is not set |
| 656 | # CONFIG_TLAN is not set | 682 | # CONFIG_TLAN is not set |
| 683 | # CONFIG_KS8842 is not set | ||
| 657 | # CONFIG_VIA_RHINE is not set | 684 | # CONFIG_VIA_RHINE is not set |
| 658 | # CONFIG_SC92031 is not set | 685 | # CONFIG_SC92031 is not set |
| 659 | # CONFIG_ATL2 is not set | 686 | # CONFIG_ATL2 is not set |
| @@ -676,8 +703,10 @@ CONFIG_NETDEV_1000=y | |||
| 676 | # CONFIG_VIA_VELOCITY is not set | 703 | # CONFIG_VIA_VELOCITY is not set |
| 677 | # CONFIG_TIGON3 is not set | 704 | # CONFIG_TIGON3 is not set |
| 678 | # CONFIG_BNX2 is not set | 705 | # CONFIG_BNX2 is not set |
| 706 | # CONFIG_CNIC is not set | ||
| 679 | CONFIG_FSL_PQ_MDIO=y | 707 | CONFIG_FSL_PQ_MDIO=y |
| 680 | CONFIG_GIANFAR=y | 708 | CONFIG_GIANFAR=y |
| 709 | # CONFIG_MV643XX_ETH is not set | ||
| 681 | # CONFIG_QLA3XXX is not set | 710 | # CONFIG_QLA3XXX is not set |
| 682 | # CONFIG_ATL1 is not set | 711 | # CONFIG_ATL1 is not set |
| 683 | # CONFIG_ATL1E is not set | 712 | # CONFIG_ATL1E is not set |
| @@ -831,6 +860,7 @@ CONFIG_I2C_HELPER_AUTO=y | |||
| 831 | # I2C system bus drivers (mostly embedded / system-on-chip) | 860 | # I2C system bus drivers (mostly embedded / system-on-chip) |
| 832 | # | 861 | # |
| 833 | # CONFIG_I2C_CPM is not set | 862 | # CONFIG_I2C_CPM is not set |
| 863 | # CONFIG_I2C_DESIGNWARE is not set | ||
| 834 | # CONFIG_I2C_GPIO is not set | 864 | # CONFIG_I2C_GPIO is not set |
| 835 | CONFIG_I2C_MPC=y | 865 | CONFIG_I2C_MPC=y |
| 836 | # CONFIG_I2C_OCORES is not set | 866 | # CONFIG_I2C_OCORES is not set |
| @@ -859,13 +889,17 @@ CONFIG_I2C_MPC=y | |||
| 859 | # CONFIG_SENSORS_PCF8574 is not set | 889 | # CONFIG_SENSORS_PCF8574 is not set |
| 860 | # CONFIG_PCF8575 is not set | 890 | # CONFIG_PCF8575 is not set |
| 861 | # CONFIG_SENSORS_PCA9539 is not set | 891 | # CONFIG_SENSORS_PCA9539 is not set |
| 862 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 863 | # CONFIG_SENSORS_TSL2550 is not set | 892 | # CONFIG_SENSORS_TSL2550 is not set |
| 864 | # CONFIG_I2C_DEBUG_CORE is not set | 893 | # CONFIG_I2C_DEBUG_CORE is not set |
| 865 | # CONFIG_I2C_DEBUG_ALGO is not set | 894 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 866 | # CONFIG_I2C_DEBUG_BUS is not set | 895 | # CONFIG_I2C_DEBUG_BUS is not set |
| 867 | # CONFIG_I2C_DEBUG_CHIP is not set | 896 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 868 | # CONFIG_SPI is not set | 897 | # CONFIG_SPI is not set |
| 898 | |||
| 899 | # | ||
| 900 | # PPS support | ||
| 901 | # | ||
| 902 | # CONFIG_PPS is not set | ||
| 869 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 903 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 870 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 904 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 871 | CONFIG_GPIOLIB=y | 905 | CONFIG_GPIOLIB=y |
| @@ -944,6 +978,7 @@ CONFIG_SENSORS_LM75=y | |||
| 944 | # CONFIG_SENSORS_SMSC47B397 is not set | 978 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 945 | # CONFIG_SENSORS_ADS7828 is not set | 979 | # CONFIG_SENSORS_ADS7828 is not set |
| 946 | # CONFIG_SENSORS_THMC50 is not set | 980 | # CONFIG_SENSORS_THMC50 is not set |
| 981 | # CONFIG_SENSORS_TMP401 is not set | ||
| 947 | # CONFIG_SENSORS_VIA686A is not set | 982 | # CONFIG_SENSORS_VIA686A is not set |
| 948 | # CONFIG_SENSORS_VT1211 is not set | 983 | # CONFIG_SENSORS_VT1211 is not set |
| 949 | # CONFIG_SENSORS_VT8231 is not set | 984 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -979,23 +1014,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 979 | # CONFIG_MFD_WM8400 is not set | 1014 | # CONFIG_MFD_WM8400 is not set |
| 980 | # CONFIG_MFD_WM8350_I2C is not set | 1015 | # CONFIG_MFD_WM8350_I2C is not set |
| 981 | # CONFIG_MFD_PCF50633 is not set | 1016 | # CONFIG_MFD_PCF50633 is not set |
| 1017 | # CONFIG_AB3100_CORE is not set | ||
| 982 | # CONFIG_REGULATOR is not set | 1018 | # CONFIG_REGULATOR is not set |
| 983 | 1019 | # CONFIG_MEDIA_SUPPORT is not set | |
| 984 | # | ||
| 985 | # Multimedia devices | ||
| 986 | # | ||
| 987 | |||
| 988 | # | ||
| 989 | # Multimedia core support | ||
| 990 | # | ||
| 991 | # CONFIG_VIDEO_DEV is not set | ||
| 992 | # CONFIG_DVB_CORE is not set | ||
| 993 | # CONFIG_VIDEO_MEDIA is not set | ||
| 994 | |||
| 995 | # | ||
| 996 | # Multimedia drivers | ||
| 997 | # | ||
| 998 | CONFIG_DAB=y | ||
| 999 | 1020 | ||
| 1000 | # | 1021 | # |
| 1001 | # Graphics support | 1022 | # Graphics support |
| @@ -1052,6 +1073,10 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
| 1052 | # CONFIG_DMADEVICES is not set | 1073 | # CONFIG_DMADEVICES is not set |
| 1053 | # CONFIG_AUXDISPLAY is not set | 1074 | # CONFIG_AUXDISPLAY is not set |
| 1054 | # CONFIG_UIO is not set | 1075 | # CONFIG_UIO is not set |
| 1076 | |||
| 1077 | # | ||
| 1078 | # TI VLYNQ | ||
| 1079 | # | ||
| 1055 | # CONFIG_STAGING is not set | 1080 | # CONFIG_STAGING is not set |
| 1056 | 1081 | ||
| 1057 | # | 1082 | # |
| @@ -1071,10 +1096,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1071 | # CONFIG_REISERFS_FS is not set | 1096 | # CONFIG_REISERFS_FS is not set |
| 1072 | # CONFIG_JFS_FS is not set | 1097 | # CONFIG_JFS_FS is not set |
| 1073 | # CONFIG_FS_POSIX_ACL is not set | 1098 | # CONFIG_FS_POSIX_ACL is not set |
| 1074 | CONFIG_FILE_LOCKING=y | ||
| 1075 | # CONFIG_XFS_FS is not set | 1099 | # CONFIG_XFS_FS is not set |
| 1100 | # CONFIG_GFS2_FS is not set | ||
| 1076 | # CONFIG_OCFS2_FS is not set | 1101 | # CONFIG_OCFS2_FS is not set |
| 1077 | # CONFIG_BTRFS_FS is not set | 1102 | # CONFIG_BTRFS_FS is not set |
| 1103 | CONFIG_FILE_LOCKING=y | ||
| 1104 | CONFIG_FSNOTIFY=y | ||
| 1078 | CONFIG_DNOTIFY=y | 1105 | CONFIG_DNOTIFY=y |
| 1079 | CONFIG_INOTIFY=y | 1106 | CONFIG_INOTIFY=y |
| 1080 | CONFIG_INOTIFY_USER=y | 1107 | CONFIG_INOTIFY_USER=y |
| @@ -1201,6 +1228,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1201 | CONFIG_HAS_DMA=y | 1228 | CONFIG_HAS_DMA=y |
| 1202 | CONFIG_HAVE_LMB=y | 1229 | CONFIG_HAVE_LMB=y |
| 1203 | CONFIG_NLATTR=y | 1230 | CONFIG_NLATTR=y |
| 1231 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1204 | 1232 | ||
| 1205 | # | 1233 | # |
| 1206 | # Kernel hacking | 1234 | # Kernel hacking |
| @@ -1226,22 +1254,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1226 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1254 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1227 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1255 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1228 | CONFIG_TRACING_SUPPORT=y | 1256 | CONFIG_TRACING_SUPPORT=y |
| 1229 | 1257 | # CONFIG_FTRACE is not set | |
| 1230 | # | ||
| 1231 | # Tracers | ||
| 1232 | # | ||
| 1233 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1234 | # CONFIG_SCHED_TRACER is not set | ||
| 1235 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1236 | # CONFIG_EVENT_TRACER is not set | ||
| 1237 | # CONFIG_BOOT_TRACER is not set | ||
| 1238 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1239 | # CONFIG_STACK_TRACER is not set | ||
| 1240 | # CONFIG_KMEMTRACE is not set | ||
| 1241 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1242 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1243 | # CONFIG_SAMPLES is not set | 1258 | # CONFIG_SAMPLES is not set |
| 1244 | CONFIG_HAVE_ARCH_KGDB=y | 1259 | CONFIG_HAVE_ARCH_KGDB=y |
| 1260 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1261 | CONFIG_PPC_WERROR=y | ||
| 1245 | CONFIG_PRINT_STACK_DEPTH=64 | 1262 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1246 | # CONFIG_IRQSTACKS is not set | 1263 | # CONFIG_IRQSTACKS is not set |
| 1247 | # CONFIG_PPC_EARLY_DEBUG is not set | 1264 | # CONFIG_PPC_EARLY_DEBUG is not set |
diff --git a/arch/powerpc/configs/85xx/tqm8560_defconfig b/arch/powerpc/configs/85xx/tqm8560_defconfig index f41cc2444d48..2e49a6e9faf2 100644 --- a/arch/powerpc/configs/85xx/tqm8560_defconfig +++ b/arch/powerpc/configs/85xx/tqm8560_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:26 2009 | 4 | # Wed Jul 29 23:32:25 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -34,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 34 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 35 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 36 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 38 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 39 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 41 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 43 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 44 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 45 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 47 | CONFIG_GENERIC_GPIO=y | 48 | CONFIG_GENERIC_GPIO=y |
| 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 49 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -57,11 +58,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 57 | # CONFIG_GENERIC_TBSYNC is not set | 58 | # CONFIG_GENERIC_TBSYNC is not set |
| 58 | CONFIG_AUDIT_ARCH=y | 59 | CONFIG_AUDIT_ARCH=y |
| 59 | CONFIG_GENERIC_BUG=y | 60 | CONFIG_GENERIC_BUG=y |
| 61 | CONFIG_DTC=y | ||
| 60 | CONFIG_DEFAULT_UIMAGE=y | 62 | CONFIG_DEFAULT_UIMAGE=y |
| 61 | # CONFIG_PPC_DCR_NATIVE is not set | 63 | # CONFIG_PPC_DCR_NATIVE is not set |
| 62 | # CONFIG_PPC_DCR_MMIO is not set | 64 | # CONFIG_PPC_DCR_MMIO is not set |
| 63 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 65 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 64 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 66 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 67 | CONFIG_CONSTRUCTORS=y | ||
| 65 | 68 | ||
| 66 | # | 69 | # |
| 67 | # General setup | 70 | # General setup |
| @@ -110,7 +113,6 @@ CONFIG_ANON_INODES=y | |||
| 110 | CONFIG_EMBEDDED=y | 113 | CONFIG_EMBEDDED=y |
| 111 | CONFIG_SYSCTL_SYSCALL=y | 114 | CONFIG_SYSCTL_SYSCALL=y |
| 112 | # CONFIG_KALLSYMS is not set | 115 | # CONFIG_KALLSYMS is not set |
| 113 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 114 | # CONFIG_HOTPLUG is not set | 116 | # CONFIG_HOTPLUG is not set |
| 115 | CONFIG_PRINTK=y | 117 | CONFIG_PRINTK=y |
| 116 | CONFIG_BUG=y | 118 | CONFIG_BUG=y |
| @@ -123,9 +125,16 @@ CONFIG_TIMERFD=y | |||
| 123 | CONFIG_EVENTFD=y | 125 | CONFIG_EVENTFD=y |
| 124 | CONFIG_SHMEM=y | 126 | CONFIG_SHMEM=y |
| 125 | CONFIG_AIO=y | 127 | CONFIG_AIO=y |
| 128 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 129 | |||
| 130 | # | ||
| 131 | # Performance Counters | ||
| 132 | # | ||
| 133 | # CONFIG_PERF_COUNTERS is not set | ||
| 126 | CONFIG_VM_EVENT_COUNTERS=y | 134 | CONFIG_VM_EVENT_COUNTERS=y |
| 127 | CONFIG_PCI_QUIRKS=y | 135 | CONFIG_PCI_QUIRKS=y |
| 128 | CONFIG_SLUB_DEBUG=y | 136 | CONFIG_SLUB_DEBUG=y |
| 137 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 129 | CONFIG_COMPAT_BRK=y | 138 | CONFIG_COMPAT_BRK=y |
| 130 | # CONFIG_SLAB is not set | 139 | # CONFIG_SLAB is not set |
| 131 | CONFIG_SLUB=y | 140 | CONFIG_SLUB=y |
| @@ -139,6 +148,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 139 | CONFIG_HAVE_KRETPROBES=y | 148 | CONFIG_HAVE_KRETPROBES=y |
| 140 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 149 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 141 | CONFIG_HAVE_CLK=y | 150 | CONFIG_HAVE_CLK=y |
| 151 | |||
| 152 | # | ||
| 153 | # GCOV-based kernel profiling | ||
| 154 | # | ||
| 142 | # CONFIG_SLOW_WORK is not set | 155 | # CONFIG_SLOW_WORK is not set |
| 143 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 156 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 144 | CONFIG_SLABINFO=y | 157 | CONFIG_SLABINFO=y |
| @@ -146,7 +159,7 @@ CONFIG_RT_MUTEXES=y | |||
| 146 | CONFIG_BASE_SMALL=0 | 159 | CONFIG_BASE_SMALL=0 |
| 147 | # CONFIG_MODULES is not set | 160 | # CONFIG_MODULES is not set |
| 148 | CONFIG_BLOCK=y | 161 | CONFIG_BLOCK=y |
| 149 | # CONFIG_LBD is not set | 162 | CONFIG_LBDAF=y |
| 150 | # CONFIG_BLK_DEV_BSG is not set | 163 | # CONFIG_BLK_DEV_BSG is not set |
| 151 | # CONFIG_BLK_DEV_INTEGRITY is not set | 164 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 152 | 165 | ||
| @@ -179,6 +192,7 @@ CONFIG_MPC85xx=y | |||
| 179 | # CONFIG_MPC85xx_DS is not set | 192 | # CONFIG_MPC85xx_DS is not set |
| 180 | # CONFIG_SOCRATES is not set | 193 | # CONFIG_SOCRATES is not set |
| 181 | # CONFIG_KSI8560 is not set | 194 | # CONFIG_KSI8560 is not set |
| 195 | # CONFIG_XES_MPC85xx is not set | ||
| 182 | # CONFIG_STX_GP3 is not set | 196 | # CONFIG_STX_GP3 is not set |
| 183 | # CONFIG_TQM8540 is not set | 197 | # CONFIG_TQM8540 is not set |
| 184 | # CONFIG_TQM8541 is not set | 198 | # CONFIG_TQM8541 is not set |
| @@ -228,6 +242,7 @@ CONFIG_BINFMT_ELF=y | |||
| 228 | # CONFIG_BINFMT_MISC is not set | 242 | # CONFIG_BINFMT_MISC is not set |
| 229 | CONFIG_MATH_EMULATION=y | 243 | CONFIG_MATH_EMULATION=y |
| 230 | # CONFIG_IOMMU_HELPER is not set | 244 | # CONFIG_IOMMU_HELPER is not set |
| 245 | # CONFIG_SWIOTLB is not set | ||
| 231 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 246 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 232 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 247 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 233 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 248 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -246,9 +261,9 @@ CONFIG_MIGRATION=y | |||
| 246 | CONFIG_ZONE_DMA_FLAG=1 | 261 | CONFIG_ZONE_DMA_FLAG=1 |
| 247 | CONFIG_BOUNCE=y | 262 | CONFIG_BOUNCE=y |
| 248 | CONFIG_VIRT_TO_BUS=y | 263 | CONFIG_VIRT_TO_BUS=y |
| 249 | CONFIG_UNEVICTABLE_LRU=y | ||
| 250 | CONFIG_HAVE_MLOCK=y | 264 | CONFIG_HAVE_MLOCK=y |
| 251 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 265 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 266 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 252 | CONFIG_PPC_4K_PAGES=y | 267 | CONFIG_PPC_4K_PAGES=y |
| 253 | # CONFIG_PPC_16K_PAGES is not set | 268 | # CONFIG_PPC_16K_PAGES is not set |
| 254 | # CONFIG_PPC_64K_PAGES is not set | 269 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -356,6 +371,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 356 | # CONFIG_ECONET is not set | 371 | # CONFIG_ECONET is not set |
| 357 | # CONFIG_WAN_ROUTER is not set | 372 | # CONFIG_WAN_ROUTER is not set |
| 358 | # CONFIG_PHONET is not set | 373 | # CONFIG_PHONET is not set |
| 374 | # CONFIG_IEEE802154 is not set | ||
| 359 | # CONFIG_NET_SCHED is not set | 375 | # CONFIG_NET_SCHED is not set |
| 360 | # CONFIG_DCB is not set | 376 | # CONFIG_DCB is not set |
| 361 | 377 | ||
| @@ -373,7 +389,11 @@ CONFIG_WIRELESS=y | |||
| 373 | CONFIG_WIRELESS_OLD_REGULATORY=y | 389 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 374 | # CONFIG_WIRELESS_EXT is not set | 390 | # CONFIG_WIRELESS_EXT is not set |
| 375 | # CONFIG_LIB80211 is not set | 391 | # CONFIG_LIB80211 is not set |
| 376 | # CONFIG_MAC80211 is not set | 392 | |
| 393 | # | ||
| 394 | # CFG80211 needs to be enabled for MAC80211 | ||
| 395 | # | ||
| 396 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 377 | # CONFIG_WIMAX is not set | 397 | # CONFIG_WIMAX is not set |
| 378 | # CONFIG_RFKILL is not set | 398 | # CONFIG_RFKILL is not set |
| 379 | # CONFIG_NET_9P is not set | 399 | # CONFIG_NET_9P is not set |
| @@ -475,6 +495,7 @@ CONFIG_MTD_CFI_UTIL=y | |||
| 475 | CONFIG_OF_DEVICE=y | 495 | CONFIG_OF_DEVICE=y |
| 476 | CONFIG_OF_GPIO=y | 496 | CONFIG_OF_GPIO=y |
| 477 | CONFIG_OF_I2C=y | 497 | CONFIG_OF_I2C=y |
| 498 | CONFIG_OF_MDIO=y | ||
| 478 | # CONFIG_PARPORT is not set | 499 | # CONFIG_PARPORT is not set |
| 479 | CONFIG_BLK_DEV=y | 500 | CONFIG_BLK_DEV=y |
| 480 | # CONFIG_BLK_DEV_FD is not set | 501 | # CONFIG_BLK_DEV_FD is not set |
| @@ -509,7 +530,9 @@ CONFIG_MISC_DEVICES=y | |||
| 509 | # | 530 | # |
| 510 | # CONFIG_EEPROM_AT24 is not set | 531 | # CONFIG_EEPROM_AT24 is not set |
| 511 | # CONFIG_EEPROM_LEGACY is not set | 532 | # CONFIG_EEPROM_LEGACY is not set |
| 533 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 512 | # CONFIG_EEPROM_93CX6 is not set | 534 | # CONFIG_EEPROM_93CX6 is not set |
| 535 | # CONFIG_CB710_CORE is not set | ||
| 513 | CONFIG_HAVE_IDE=y | 536 | CONFIG_HAVE_IDE=y |
| 514 | CONFIG_IDE=y | 537 | CONFIG_IDE=y |
| 515 | 538 | ||
| @@ -584,14 +607,17 @@ CONFIG_BLK_DEV_IDEDMA=y | |||
| 584 | # | 607 | # |
| 585 | 608 | ||
| 586 | # | 609 | # |
| 587 | # Enable only one of the two stacks, unless you know what you are doing | 610 | # You can enable one or both FireWire driver stacks. |
| 611 | # | ||
| 612 | |||
| 613 | # | ||
| 614 | # See the help texts for more information. | ||
| 588 | # | 615 | # |
| 589 | # CONFIG_FIREWIRE is not set | 616 | # CONFIG_FIREWIRE is not set |
| 590 | # CONFIG_IEEE1394 is not set | 617 | # CONFIG_IEEE1394 is not set |
| 591 | # CONFIG_I2O is not set | 618 | # CONFIG_I2O is not set |
| 592 | # CONFIG_MACINTOSH_DRIVERS is not set | 619 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 593 | CONFIG_NETDEVICES=y | 620 | CONFIG_NETDEVICES=y |
| 594 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 595 | # CONFIG_DUMMY is not set | 621 | # CONFIG_DUMMY is not set |
| 596 | # CONFIG_BONDING is not set | 622 | # CONFIG_BONDING is not set |
| 597 | # CONFIG_MACVLAN is not set | 623 | # CONFIG_MACVLAN is not set |
| @@ -654,6 +680,7 @@ CONFIG_E100=y | |||
| 654 | # CONFIG_SMSC9420 is not set | 680 | # CONFIG_SMSC9420 is not set |
| 655 | # CONFIG_SUNDANCE is not set | 681 | # CONFIG_SUNDANCE is not set |
| 656 | # CONFIG_TLAN is not set | 682 | # CONFIG_TLAN is not set |
| 683 | # CONFIG_KS8842 is not set | ||
| 657 | # CONFIG_VIA_RHINE is not set | 684 | # CONFIG_VIA_RHINE is not set |
| 658 | # CONFIG_SC92031 is not set | 685 | # CONFIG_SC92031 is not set |
| 659 | # CONFIG_ATL2 is not set | 686 | # CONFIG_ATL2 is not set |
| @@ -676,8 +703,10 @@ CONFIG_NETDEV_1000=y | |||
| 676 | # CONFIG_VIA_VELOCITY is not set | 703 | # CONFIG_VIA_VELOCITY is not set |
| 677 | # CONFIG_TIGON3 is not set | 704 | # CONFIG_TIGON3 is not set |
| 678 | # CONFIG_BNX2 is not set | 705 | # CONFIG_BNX2 is not set |
| 706 | # CONFIG_CNIC is not set | ||
| 679 | CONFIG_FSL_PQ_MDIO=y | 707 | CONFIG_FSL_PQ_MDIO=y |
| 680 | CONFIG_GIANFAR=y | 708 | CONFIG_GIANFAR=y |
| 709 | # CONFIG_MV643XX_ETH is not set | ||
| 681 | # CONFIG_QLA3XXX is not set | 710 | # CONFIG_QLA3XXX is not set |
| 682 | # CONFIG_ATL1 is not set | 711 | # CONFIG_ATL1 is not set |
| 683 | # CONFIG_ATL1E is not set | 712 | # CONFIG_ATL1E is not set |
| @@ -831,6 +860,7 @@ CONFIG_I2C_HELPER_AUTO=y | |||
| 831 | # I2C system bus drivers (mostly embedded / system-on-chip) | 860 | # I2C system bus drivers (mostly embedded / system-on-chip) |
| 832 | # | 861 | # |
| 833 | # CONFIG_I2C_CPM is not set | 862 | # CONFIG_I2C_CPM is not set |
| 863 | # CONFIG_I2C_DESIGNWARE is not set | ||
| 834 | # CONFIG_I2C_GPIO is not set | 864 | # CONFIG_I2C_GPIO is not set |
| 835 | CONFIG_I2C_MPC=y | 865 | CONFIG_I2C_MPC=y |
| 836 | # CONFIG_I2C_OCORES is not set | 866 | # CONFIG_I2C_OCORES is not set |
| @@ -859,13 +889,17 @@ CONFIG_I2C_MPC=y | |||
| 859 | # CONFIG_SENSORS_PCF8574 is not set | 889 | # CONFIG_SENSORS_PCF8574 is not set |
| 860 | # CONFIG_PCF8575 is not set | 890 | # CONFIG_PCF8575 is not set |
| 861 | # CONFIG_SENSORS_PCA9539 is not set | 891 | # CONFIG_SENSORS_PCA9539 is not set |
| 862 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 863 | # CONFIG_SENSORS_TSL2550 is not set | 892 | # CONFIG_SENSORS_TSL2550 is not set |
| 864 | # CONFIG_I2C_DEBUG_CORE is not set | 893 | # CONFIG_I2C_DEBUG_CORE is not set |
| 865 | # CONFIG_I2C_DEBUG_ALGO is not set | 894 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 866 | # CONFIG_I2C_DEBUG_BUS is not set | 895 | # CONFIG_I2C_DEBUG_BUS is not set |
| 867 | # CONFIG_I2C_DEBUG_CHIP is not set | 896 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 868 | # CONFIG_SPI is not set | 897 | # CONFIG_SPI is not set |
| 898 | |||
| 899 | # | ||
| 900 | # PPS support | ||
| 901 | # | ||
| 902 | # CONFIG_PPS is not set | ||
| 869 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 903 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 870 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 904 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 871 | CONFIG_GPIOLIB=y | 905 | CONFIG_GPIOLIB=y |
| @@ -944,6 +978,7 @@ CONFIG_SENSORS_LM75=y | |||
| 944 | # CONFIG_SENSORS_SMSC47B397 is not set | 978 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 945 | # CONFIG_SENSORS_ADS7828 is not set | 979 | # CONFIG_SENSORS_ADS7828 is not set |
| 946 | # CONFIG_SENSORS_THMC50 is not set | 980 | # CONFIG_SENSORS_THMC50 is not set |
| 981 | # CONFIG_SENSORS_TMP401 is not set | ||
| 947 | # CONFIG_SENSORS_VIA686A is not set | 982 | # CONFIG_SENSORS_VIA686A is not set |
| 948 | # CONFIG_SENSORS_VT1211 is not set | 983 | # CONFIG_SENSORS_VT1211 is not set |
| 949 | # CONFIG_SENSORS_VT8231 is not set | 984 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -979,23 +1014,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 979 | # CONFIG_MFD_WM8400 is not set | 1014 | # CONFIG_MFD_WM8400 is not set |
| 980 | # CONFIG_MFD_WM8350_I2C is not set | 1015 | # CONFIG_MFD_WM8350_I2C is not set |
| 981 | # CONFIG_MFD_PCF50633 is not set | 1016 | # CONFIG_MFD_PCF50633 is not set |
| 1017 | # CONFIG_AB3100_CORE is not set | ||
| 982 | # CONFIG_REGULATOR is not set | 1018 | # CONFIG_REGULATOR is not set |
| 983 | 1019 | # CONFIG_MEDIA_SUPPORT is not set | |
| 984 | # | ||
| 985 | # Multimedia devices | ||
| 986 | # | ||
| 987 | |||
| 988 | # | ||
| 989 | # Multimedia core support | ||
| 990 | # | ||
| 991 | # CONFIG_VIDEO_DEV is not set | ||
| 992 | # CONFIG_DVB_CORE is not set | ||
| 993 | # CONFIG_VIDEO_MEDIA is not set | ||
| 994 | |||
| 995 | # | ||
| 996 | # Multimedia drivers | ||
| 997 | # | ||
| 998 | CONFIG_DAB=y | ||
| 999 | 1020 | ||
| 1000 | # | 1021 | # |
| 1001 | # Graphics support | 1022 | # Graphics support |
| @@ -1052,6 +1073,10 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
| 1052 | # CONFIG_DMADEVICES is not set | 1073 | # CONFIG_DMADEVICES is not set |
| 1053 | # CONFIG_AUXDISPLAY is not set | 1074 | # CONFIG_AUXDISPLAY is not set |
| 1054 | # CONFIG_UIO is not set | 1075 | # CONFIG_UIO is not set |
| 1076 | |||
| 1077 | # | ||
| 1078 | # TI VLYNQ | ||
| 1079 | # | ||
| 1055 | # CONFIG_STAGING is not set | 1080 | # CONFIG_STAGING is not set |
| 1056 | 1081 | ||
| 1057 | # | 1082 | # |
| @@ -1071,10 +1096,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1071 | # CONFIG_REISERFS_FS is not set | 1096 | # CONFIG_REISERFS_FS is not set |
| 1072 | # CONFIG_JFS_FS is not set | 1097 | # CONFIG_JFS_FS is not set |
| 1073 | # CONFIG_FS_POSIX_ACL is not set | 1098 | # CONFIG_FS_POSIX_ACL is not set |
| 1074 | CONFIG_FILE_LOCKING=y | ||
| 1075 | # CONFIG_XFS_FS is not set | 1099 | # CONFIG_XFS_FS is not set |
| 1100 | # CONFIG_GFS2_FS is not set | ||
| 1076 | # CONFIG_OCFS2_FS is not set | 1101 | # CONFIG_OCFS2_FS is not set |
| 1077 | # CONFIG_BTRFS_FS is not set | 1102 | # CONFIG_BTRFS_FS is not set |
| 1103 | CONFIG_FILE_LOCKING=y | ||
| 1104 | CONFIG_FSNOTIFY=y | ||
| 1078 | CONFIG_DNOTIFY=y | 1105 | CONFIG_DNOTIFY=y |
| 1079 | CONFIG_INOTIFY=y | 1106 | CONFIG_INOTIFY=y |
| 1080 | CONFIG_INOTIFY_USER=y | 1107 | CONFIG_INOTIFY_USER=y |
| @@ -1201,6 +1228,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1201 | CONFIG_HAS_DMA=y | 1228 | CONFIG_HAS_DMA=y |
| 1202 | CONFIG_HAVE_LMB=y | 1229 | CONFIG_HAVE_LMB=y |
| 1203 | CONFIG_NLATTR=y | 1230 | CONFIG_NLATTR=y |
| 1231 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1204 | 1232 | ||
| 1205 | # | 1233 | # |
| 1206 | # Kernel hacking | 1234 | # Kernel hacking |
| @@ -1226,22 +1254,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1226 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1254 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1227 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1255 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1228 | CONFIG_TRACING_SUPPORT=y | 1256 | CONFIG_TRACING_SUPPORT=y |
| 1229 | 1257 | # CONFIG_FTRACE is not set | |
| 1230 | # | ||
| 1231 | # Tracers | ||
| 1232 | # | ||
| 1233 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1234 | # CONFIG_SCHED_TRACER is not set | ||
| 1235 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1236 | # CONFIG_EVENT_TRACER is not set | ||
| 1237 | # CONFIG_BOOT_TRACER is not set | ||
| 1238 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1239 | # CONFIG_STACK_TRACER is not set | ||
| 1240 | # CONFIG_KMEMTRACE is not set | ||
| 1241 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1242 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1243 | # CONFIG_SAMPLES is not set | 1258 | # CONFIG_SAMPLES is not set |
| 1244 | CONFIG_HAVE_ARCH_KGDB=y | 1259 | CONFIG_HAVE_ARCH_KGDB=y |
| 1260 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1261 | CONFIG_PPC_WERROR=y | ||
| 1245 | CONFIG_PRINT_STACK_DEPTH=64 | 1262 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1246 | # CONFIG_IRQSTACKS is not set | 1263 | # CONFIG_IRQSTACKS is not set |
| 1247 | # CONFIG_PPC_EARLY_DEBUG is not set | 1264 | # CONFIG_PPC_EARLY_DEBUG is not set |
diff --git a/arch/powerpc/configs/85xx/xes_mpc85xx_defconfig b/arch/powerpc/configs/85xx/xes_mpc85xx_defconfig index 2552cbefba6b..1025da2bf069 100644 --- a/arch/powerpc/configs/85xx/xes_mpc85xx_defconfig +++ b/arch/powerpc/configs/85xx/xes_mpc85xx_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc6 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Thu Jun 11 11:25:17 2009 | 4 | # Wed Jul 29 23:32:25 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -35,15 +35,16 @@ CONFIG_GENERIC_TIME=y | |||
| 35 | CONFIG_GENERIC_TIME_VSYSCALL=y | 35 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 36 | CONFIG_GENERIC_CLOCKEVENTS=y | 36 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 37 | CONFIG_GENERIC_HARDIRQS=y | 37 | CONFIG_GENERIC_HARDIRQS=y |
| 38 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 39 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 39 | CONFIG_IRQ_PER_CPU=y | 40 | CONFIG_IRQ_PER_CPU=y |
| 40 | CONFIG_STACKTRACE_SUPPORT=y | 41 | CONFIG_STACKTRACE_SUPPORT=y |
| 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 42 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 43 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 42 | CONFIG_LOCKDEP_SUPPORT=y | 44 | CONFIG_LOCKDEP_SUPPORT=y |
| 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 45 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 44 | CONFIG_ARCH_HAS_ILOG2_U32=y | 46 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 45 | CONFIG_GENERIC_HWEIGHT=y | 47 | CONFIG_GENERIC_HWEIGHT=y |
| 46 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 48 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 48 | CONFIG_GENERIC_GPIO=y | 49 | CONFIG_GENERIC_GPIO=y |
| 49 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 50 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -64,6 +65,7 @@ CONFIG_DEFAULT_UIMAGE=y | |||
| 64 | # CONFIG_PPC_DCR_MMIO is not set | 65 | # CONFIG_PPC_DCR_MMIO is not set |
| 65 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 66 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 66 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 67 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 68 | CONFIG_CONSTRUCTORS=y | ||
| 67 | 69 | ||
| 68 | # | 70 | # |
| 69 | # General setup | 71 | # General setup |
| @@ -114,7 +116,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 114 | CONFIG_KALLSYMS=y | 116 | CONFIG_KALLSYMS=y |
| 115 | CONFIG_KALLSYMS_ALL=y | 117 | CONFIG_KALLSYMS_ALL=y |
| 116 | CONFIG_KALLSYMS_EXTRA_PASS=y | 118 | CONFIG_KALLSYMS_EXTRA_PASS=y |
| 117 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 118 | CONFIG_HOTPLUG=y | 119 | CONFIG_HOTPLUG=y |
| 119 | CONFIG_PRINTK=y | 120 | CONFIG_PRINTK=y |
| 120 | CONFIG_BUG=y | 121 | CONFIG_BUG=y |
| @@ -127,9 +128,16 @@ CONFIG_TIMERFD=y | |||
| 127 | CONFIG_EVENTFD=y | 128 | CONFIG_EVENTFD=y |
| 128 | CONFIG_SHMEM=y | 129 | CONFIG_SHMEM=y |
| 129 | CONFIG_AIO=y | 130 | CONFIG_AIO=y |
| 131 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 132 | |||
| 133 | # | ||
| 134 | # Performance Counters | ||
| 135 | # | ||
| 136 | # CONFIG_PERF_COUNTERS is not set | ||
| 130 | CONFIG_VM_EVENT_COUNTERS=y | 137 | CONFIG_VM_EVENT_COUNTERS=y |
| 131 | CONFIG_PCI_QUIRKS=y | 138 | CONFIG_PCI_QUIRKS=y |
| 132 | CONFIG_SLUB_DEBUG=y | 139 | CONFIG_SLUB_DEBUG=y |
| 140 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 133 | CONFIG_COMPAT_BRK=y | 141 | CONFIG_COMPAT_BRK=y |
| 134 | # CONFIG_SLAB is not set | 142 | # CONFIG_SLAB is not set |
| 135 | CONFIG_SLUB=y | 143 | CONFIG_SLUB=y |
| @@ -144,6 +152,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 144 | CONFIG_HAVE_KRETPROBES=y | 152 | CONFIG_HAVE_KRETPROBES=y |
| 145 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 153 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 146 | CONFIG_USE_GENERIC_SMP_HELPERS=y | 154 | CONFIG_USE_GENERIC_SMP_HELPERS=y |
| 155 | |||
| 156 | # | ||
| 157 | # GCOV-based kernel profiling | ||
| 158 | # | ||
| 147 | # CONFIG_SLOW_WORK is not set | 159 | # CONFIG_SLOW_WORK is not set |
| 148 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 160 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 149 | CONFIG_SLABINFO=y | 161 | CONFIG_SLABINFO=y |
| @@ -157,7 +169,7 @@ CONFIG_MODVERSIONS=y | |||
| 157 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 169 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 158 | CONFIG_STOP_MACHINE=y | 170 | CONFIG_STOP_MACHINE=y |
| 159 | CONFIG_BLOCK=y | 171 | CONFIG_BLOCK=y |
| 160 | CONFIG_LBD=y | 172 | CONFIG_LBDAF=y |
| 161 | # CONFIG_BLK_DEV_BSG is not set | 173 | # CONFIG_BLK_DEV_BSG is not set |
| 162 | # CONFIG_BLK_DEV_INTEGRITY is not set | 174 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 163 | 175 | ||
| @@ -239,6 +251,7 @@ CONFIG_BINFMT_ELF=y | |||
| 239 | # CONFIG_BINFMT_MISC is not set | 251 | # CONFIG_BINFMT_MISC is not set |
| 240 | CONFIG_MATH_EMULATION=y | 252 | CONFIG_MATH_EMULATION=y |
| 241 | # CONFIG_IOMMU_HELPER is not set | 253 | # CONFIG_IOMMU_HELPER is not set |
| 254 | # CONFIG_SWIOTLB is not set | ||
| 242 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 255 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 243 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 256 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 244 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 257 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -258,9 +271,9 @@ CONFIG_MIGRATION=y | |||
| 258 | CONFIG_ZONE_DMA_FLAG=1 | 271 | CONFIG_ZONE_DMA_FLAG=1 |
| 259 | CONFIG_BOUNCE=y | 272 | CONFIG_BOUNCE=y |
| 260 | CONFIG_VIRT_TO_BUS=y | 273 | CONFIG_VIRT_TO_BUS=y |
| 261 | CONFIG_UNEVICTABLE_LRU=y | ||
| 262 | CONFIG_HAVE_MLOCK=y | 274 | CONFIG_HAVE_MLOCK=y |
| 263 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 275 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 276 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 264 | CONFIG_PPC_4K_PAGES=y | 277 | CONFIG_PPC_4K_PAGES=y |
| 265 | # CONFIG_PPC_16K_PAGES is not set | 278 | # CONFIG_PPC_16K_PAGES is not set |
| 266 | # CONFIG_PPC_64K_PAGES is not set | 279 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -287,6 +300,8 @@ CONFIG_PCI_DOMAINS=y | |||
| 287 | CONFIG_PCI_SYSCALL=y | 300 | CONFIG_PCI_SYSCALL=y |
| 288 | CONFIG_PCIEPORTBUS=y | 301 | CONFIG_PCIEPORTBUS=y |
| 289 | CONFIG_PCIEAER=y | 302 | CONFIG_PCIEAER=y |
| 303 | # CONFIG_PCIE_ECRC is not set | ||
| 304 | # CONFIG_PCIEAER_INJECT is not set | ||
| 290 | # CONFIG_PCIEASPM is not set | 305 | # CONFIG_PCIEASPM is not set |
| 291 | CONFIG_ARCH_SUPPORTS_MSI=y | 306 | CONFIG_ARCH_SUPPORTS_MSI=y |
| 292 | CONFIG_PCI_MSI=y | 307 | CONFIG_PCI_MSI=y |
| @@ -404,6 +419,7 @@ CONFIG_IPV6_NDISC_NODETYPE=y | |||
| 404 | # CONFIG_ECONET is not set | 419 | # CONFIG_ECONET is not set |
| 405 | # CONFIG_WAN_ROUTER is not set | 420 | # CONFIG_WAN_ROUTER is not set |
| 406 | # CONFIG_PHONET is not set | 421 | # CONFIG_PHONET is not set |
| 422 | # CONFIG_IEEE802154 is not set | ||
| 407 | # CONFIG_NET_SCHED is not set | 423 | # CONFIG_NET_SCHED is not set |
| 408 | # CONFIG_DCB is not set | 424 | # CONFIG_DCB is not set |
| 409 | 425 | ||
| @@ -540,6 +556,7 @@ CONFIG_MTD_NAND_FSL_UPM=y | |||
| 540 | CONFIG_OF_DEVICE=y | 556 | CONFIG_OF_DEVICE=y |
| 541 | CONFIG_OF_GPIO=y | 557 | CONFIG_OF_GPIO=y |
| 542 | CONFIG_OF_I2C=y | 558 | CONFIG_OF_I2C=y |
| 559 | CONFIG_OF_MDIO=y | ||
| 543 | # CONFIG_PARPORT is not set | 560 | # CONFIG_PARPORT is not set |
| 544 | CONFIG_BLK_DEV=y | 561 | CONFIG_BLK_DEV=y |
| 545 | # CONFIG_BLK_DEV_FD is not set | 562 | # CONFIG_BLK_DEV_FD is not set |
| @@ -575,7 +592,9 @@ CONFIG_MISC_DEVICES=y | |||
| 575 | # | 592 | # |
| 576 | # CONFIG_EEPROM_AT24 is not set | 593 | # CONFIG_EEPROM_AT24 is not set |
| 577 | # CONFIG_EEPROM_LEGACY is not set | 594 | # CONFIG_EEPROM_LEGACY is not set |
| 595 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 578 | # CONFIG_EEPROM_93CX6 is not set | 596 | # CONFIG_EEPROM_93CX6 is not set |
| 597 | # CONFIG_CB710_CORE is not set | ||
| 579 | CONFIG_HAVE_IDE=y | 598 | CONFIG_HAVE_IDE=y |
| 580 | # CONFIG_IDE is not set | 599 | # CONFIG_IDE is not set |
| 581 | 600 | ||
| @@ -599,10 +618,6 @@ CONFIG_BLK_DEV_SR=y | |||
| 599 | # CONFIG_BLK_DEV_SR_VENDOR is not set | 618 | # CONFIG_BLK_DEV_SR_VENDOR is not set |
| 600 | CONFIG_CHR_DEV_SG=y | 619 | CONFIG_CHR_DEV_SG=y |
| 601 | # CONFIG_CHR_DEV_SCH is not set | 620 | # CONFIG_CHR_DEV_SCH is not set |
| 602 | |||
| 603 | # | ||
| 604 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 605 | # | ||
| 606 | CONFIG_SCSI_MULTI_LUN=y | 621 | CONFIG_SCSI_MULTI_LUN=y |
| 607 | # CONFIG_SCSI_CONSTANTS is not set | 622 | # CONFIG_SCSI_CONSTANTS is not set |
| 608 | CONFIG_SCSI_LOGGING=y | 623 | CONFIG_SCSI_LOGGING=y |
| @@ -619,6 +634,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 619 | # CONFIG_SCSI_SRP_ATTRS is not set | 634 | # CONFIG_SCSI_SRP_ATTRS is not set |
| 620 | CONFIG_SCSI_LOWLEVEL=y | 635 | CONFIG_SCSI_LOWLEVEL=y |
| 621 | # CONFIG_ISCSI_TCP is not set | 636 | # CONFIG_ISCSI_TCP is not set |
| 637 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 622 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 638 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 623 | # CONFIG_SCSI_3W_9XXX is not set | 639 | # CONFIG_SCSI_3W_9XXX is not set |
| 624 | # CONFIG_SCSI_ACARD is not set | 640 | # CONFIG_SCSI_ACARD is not set |
| @@ -627,6 +643,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 627 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 643 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 628 | # CONFIG_SCSI_AIC79XX is not set | 644 | # CONFIG_SCSI_AIC79XX is not set |
| 629 | # CONFIG_SCSI_AIC94XX is not set | 645 | # CONFIG_SCSI_AIC94XX is not set |
| 646 | # CONFIG_SCSI_MVSAS is not set | ||
| 630 | # CONFIG_SCSI_DPT_I2O is not set | 647 | # CONFIG_SCSI_DPT_I2O is not set |
| 631 | # CONFIG_SCSI_ADVANSYS is not set | 648 | # CONFIG_SCSI_ADVANSYS is not set |
| 632 | # CONFIG_SCSI_ARCMSR is not set | 649 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -646,7 +663,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 646 | # CONFIG_SCSI_IPS is not set | 663 | # CONFIG_SCSI_IPS is not set |
| 647 | # CONFIG_SCSI_INITIO is not set | 664 | # CONFIG_SCSI_INITIO is not set |
| 648 | # CONFIG_SCSI_INIA100 is not set | 665 | # CONFIG_SCSI_INIA100 is not set |
| 649 | # CONFIG_SCSI_MVSAS is not set | ||
| 650 | # CONFIG_SCSI_STEX is not set | 666 | # CONFIG_SCSI_STEX is not set |
| 651 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 667 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 652 | # CONFIG_SCSI_IPR is not set | 668 | # CONFIG_SCSI_IPR is not set |
| @@ -730,14 +746,17 @@ CONFIG_PATA_ALI=y | |||
| 730 | # | 746 | # |
| 731 | 747 | ||
| 732 | # | 748 | # |
| 733 | # Enable only one of the two stacks, unless you know what you are doing | 749 | # You can enable one or both FireWire driver stacks. |
| 750 | # | ||
| 751 | |||
| 752 | # | ||
| 753 | # See the help texts for more information. | ||
| 734 | # | 754 | # |
| 735 | # CONFIG_FIREWIRE is not set | 755 | # CONFIG_FIREWIRE is not set |
| 736 | # CONFIG_IEEE1394 is not set | 756 | # CONFIG_IEEE1394 is not set |
| 737 | # CONFIG_I2O is not set | 757 | # CONFIG_I2O is not set |
| 738 | # CONFIG_MACINTOSH_DRIVERS is not set | 758 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 739 | CONFIG_NETDEVICES=y | 759 | CONFIG_NETDEVICES=y |
| 740 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 741 | CONFIG_DUMMY=y | 760 | CONFIG_DUMMY=y |
| 742 | # CONFIG_BONDING is not set | 761 | # CONFIG_BONDING is not set |
| 743 | # CONFIG_MACVLAN is not set | 762 | # CONFIG_MACVLAN is not set |
| @@ -784,6 +803,7 @@ CONFIG_MII=y | |||
| 784 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 803 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 785 | # CONFIG_NET_PCI is not set | 804 | # CONFIG_NET_PCI is not set |
| 786 | # CONFIG_B44 is not set | 805 | # CONFIG_B44 is not set |
| 806 | # CONFIG_KS8842 is not set | ||
| 787 | # CONFIG_ATL2 is not set | 807 | # CONFIG_ATL2 is not set |
| 788 | CONFIG_NETDEV_1000=y | 808 | CONFIG_NETDEV_1000=y |
| 789 | # CONFIG_ACENIC is not set | 809 | # CONFIG_ACENIC is not set |
| @@ -803,8 +823,10 @@ CONFIG_E1000=y | |||
| 803 | # CONFIG_VIA_VELOCITY is not set | 823 | # CONFIG_VIA_VELOCITY is not set |
| 804 | # CONFIG_TIGON3 is not set | 824 | # CONFIG_TIGON3 is not set |
| 805 | # CONFIG_BNX2 is not set | 825 | # CONFIG_BNX2 is not set |
| 826 | # CONFIG_CNIC is not set | ||
| 806 | CONFIG_FSL_PQ_MDIO=y | 827 | CONFIG_FSL_PQ_MDIO=y |
| 807 | CONFIG_GIANFAR=y | 828 | CONFIG_GIANFAR=y |
| 829 | # CONFIG_MV643XX_ETH is not set | ||
| 808 | # CONFIG_QLA3XXX is not set | 830 | # CONFIG_QLA3XXX is not set |
| 809 | # CONFIG_ATL1 is not set | 831 | # CONFIG_ATL1 is not set |
| 810 | # CONFIG_ATL1E is not set | 832 | # CONFIG_ATL1E is not set |
| @@ -986,13 +1008,17 @@ CONFIG_I2C_MPC=y | |||
| 986 | # CONFIG_DS1682 is not set | 1008 | # CONFIG_DS1682 is not set |
| 987 | # CONFIG_SENSORS_PCF8574 is not set | 1009 | # CONFIG_SENSORS_PCF8574 is not set |
| 988 | # CONFIG_PCF8575 is not set | 1010 | # CONFIG_PCF8575 is not set |
| 989 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 990 | # CONFIG_SENSORS_TSL2550 is not set | 1011 | # CONFIG_SENSORS_TSL2550 is not set |
| 991 | # CONFIG_I2C_DEBUG_CORE is not set | 1012 | # CONFIG_I2C_DEBUG_CORE is not set |
| 992 | # CONFIG_I2C_DEBUG_ALGO is not set | 1013 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 993 | # CONFIG_I2C_DEBUG_BUS is not set | 1014 | # CONFIG_I2C_DEBUG_BUS is not set |
| 994 | # CONFIG_I2C_DEBUG_CHIP is not set | 1015 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 995 | # CONFIG_SPI is not set | 1016 | # CONFIG_SPI is not set |
| 1017 | |||
| 1018 | # | ||
| 1019 | # PPS support | ||
| 1020 | # | ||
| 1021 | # CONFIG_PPS is not set | ||
| 996 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 1022 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 997 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 1023 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 998 | CONFIG_GPIOLIB=y | 1024 | CONFIG_GPIOLIB=y |
| @@ -1072,6 +1098,7 @@ CONFIG_SENSORS_LM90=y | |||
| 1072 | # CONFIG_SENSORS_SMSC47B397 is not set | 1098 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 1073 | # CONFIG_SENSORS_ADS7828 is not set | 1099 | # CONFIG_SENSORS_ADS7828 is not set |
| 1074 | # CONFIG_SENSORS_THMC50 is not set | 1100 | # CONFIG_SENSORS_THMC50 is not set |
| 1101 | # CONFIG_SENSORS_TMP401 is not set | ||
| 1075 | # CONFIG_SENSORS_VIA686A is not set | 1102 | # CONFIG_SENSORS_VIA686A is not set |
| 1076 | # CONFIG_SENSORS_VT1211 is not set | 1103 | # CONFIG_SENSORS_VT1211 is not set |
| 1077 | # CONFIG_SENSORS_VT8231 is not set | 1104 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -1126,23 +1153,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1126 | # CONFIG_MFD_WM8400 is not set | 1153 | # CONFIG_MFD_WM8400 is not set |
| 1127 | # CONFIG_MFD_WM8350_I2C is not set | 1154 | # CONFIG_MFD_WM8350_I2C is not set |
| 1128 | # CONFIG_MFD_PCF50633 is not set | 1155 | # CONFIG_MFD_PCF50633 is not set |
| 1156 | # CONFIG_AB3100_CORE is not set | ||
| 1129 | # CONFIG_REGULATOR is not set | 1157 | # CONFIG_REGULATOR is not set |
| 1130 | 1158 | # CONFIG_MEDIA_SUPPORT is not set | |
| 1131 | # | ||
| 1132 | # Multimedia devices | ||
| 1133 | # | ||
| 1134 | |||
| 1135 | # | ||
| 1136 | # Multimedia core support | ||
| 1137 | # | ||
| 1138 | # CONFIG_VIDEO_DEV is not set | ||
| 1139 | # CONFIG_DVB_CORE is not set | ||
| 1140 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1141 | |||
| 1142 | # | ||
| 1143 | # Multimedia drivers | ||
| 1144 | # | ||
| 1145 | # CONFIG_DAB is not set | ||
| 1146 | 1159 | ||
| 1147 | # | 1160 | # |
| 1148 | # Graphics support | 1161 | # Graphics support |
| @@ -1187,7 +1200,7 @@ CONFIG_USB_HID=y | |||
| 1187 | # CONFIG_HID_CHERRY is not set | 1200 | # CONFIG_HID_CHERRY is not set |
| 1188 | # CONFIG_HID_CHICONY is not set | 1201 | # CONFIG_HID_CHICONY is not set |
| 1189 | # CONFIG_HID_CYPRESS is not set | 1202 | # CONFIG_HID_CYPRESS is not set |
| 1190 | # CONFIG_DRAGONRISE_FF is not set | 1203 | # CONFIG_HID_DRAGONRISE is not set |
| 1191 | # CONFIG_HID_EZKEY is not set | 1204 | # CONFIG_HID_EZKEY is not set |
| 1192 | # CONFIG_HID_KYE is not set | 1205 | # CONFIG_HID_KYE is not set |
| 1193 | # CONFIG_HID_GYRATION is not set | 1206 | # CONFIG_HID_GYRATION is not set |
| @@ -1201,10 +1214,11 @@ CONFIG_USB_HID=y | |||
| 1201 | # CONFIG_HID_SAMSUNG is not set | 1214 | # CONFIG_HID_SAMSUNG is not set |
| 1202 | # CONFIG_HID_SONY is not set | 1215 | # CONFIG_HID_SONY is not set |
| 1203 | # CONFIG_HID_SUNPLUS is not set | 1216 | # CONFIG_HID_SUNPLUS is not set |
| 1204 | # CONFIG_GREENASIA_FF is not set | 1217 | # CONFIG_HID_GREENASIA is not set |
| 1218 | # CONFIG_HID_SMARTJOYPLUS is not set | ||
| 1205 | # CONFIG_HID_TOPSEED is not set | 1219 | # CONFIG_HID_TOPSEED is not set |
| 1206 | # CONFIG_THRUSTMASTER_FF is not set | 1220 | # CONFIG_HID_THRUSTMASTER is not set |
| 1207 | # CONFIG_ZEROPLUS_FF is not set | 1221 | # CONFIG_HID_ZEROPLUS is not set |
| 1208 | CONFIG_USB_SUPPORT=y | 1222 | CONFIG_USB_SUPPORT=y |
| 1209 | CONFIG_USB_ARCH_HAS_HCD=y | 1223 | CONFIG_USB_ARCH_HAS_HCD=y |
| 1210 | CONFIG_USB_ARCH_HAS_OHCI=y | 1224 | CONFIG_USB_ARCH_HAS_OHCI=y |
| @@ -1230,6 +1244,7 @@ CONFIG_USB_MON=y | |||
| 1230 | # USB Host Controller Drivers | 1244 | # USB Host Controller Drivers |
| 1231 | # | 1245 | # |
| 1232 | # CONFIG_USB_C67X00_HCD is not set | 1246 | # CONFIG_USB_C67X00_HCD is not set |
| 1247 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1233 | # CONFIG_USB_EHCI_HCD is not set | 1248 | # CONFIG_USB_EHCI_HCD is not set |
| 1234 | # CONFIG_USB_OXU210HP_HCD is not set | 1249 | # CONFIG_USB_OXU210HP_HCD is not set |
| 1235 | # CONFIG_USB_ISP116X_HCD is not set | 1250 | # CONFIG_USB_ISP116X_HCD is not set |
| @@ -1325,7 +1340,7 @@ CONFIG_LEDS_CLASS=y | |||
| 1325 | CONFIG_LEDS_GPIO=y | 1340 | CONFIG_LEDS_GPIO=y |
| 1326 | CONFIG_LEDS_GPIO_PLATFORM=y | 1341 | CONFIG_LEDS_GPIO_PLATFORM=y |
| 1327 | CONFIG_LEDS_GPIO_OF=y | 1342 | CONFIG_LEDS_GPIO_OF=y |
| 1328 | # CONFIG_LEDS_LP5521 is not set | 1343 | # CONFIG_LEDS_LP3944 is not set |
| 1329 | CONFIG_LEDS_PCA955X=y | 1344 | CONFIG_LEDS_PCA955X=y |
| 1330 | # CONFIG_LEDS_BD2802 is not set | 1345 | # CONFIG_LEDS_BD2802 is not set |
| 1331 | 1346 | ||
| @@ -1352,8 +1367,6 @@ CONFIG_EDAC=y | |||
| 1352 | # CONFIG_EDAC_DEBUG is not set | 1367 | # CONFIG_EDAC_DEBUG is not set |
| 1353 | CONFIG_EDAC_MM_EDAC=y | 1368 | CONFIG_EDAC_MM_EDAC=y |
| 1354 | CONFIG_EDAC_MPC85XX=y | 1369 | CONFIG_EDAC_MPC85XX=y |
| 1355 | # CONFIG_EDAC_AMD8131 is not set | ||
| 1356 | # CONFIG_EDAC_AMD8111 is not set | ||
| 1357 | CONFIG_RTC_LIB=y | 1370 | CONFIG_RTC_LIB=y |
| 1358 | CONFIG_RTC_CLASS=y | 1371 | CONFIG_RTC_CLASS=y |
| 1359 | CONFIG_RTC_HCTOSYS=y | 1372 | CONFIG_RTC_HCTOSYS=y |
| @@ -1385,6 +1398,7 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 1385 | # CONFIG_RTC_DRV_S35390A is not set | 1398 | # CONFIG_RTC_DRV_S35390A is not set |
| 1386 | # CONFIG_RTC_DRV_FM3130 is not set | 1399 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1387 | # CONFIG_RTC_DRV_RX8581 is not set | 1400 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1401 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1388 | 1402 | ||
| 1389 | # | 1403 | # |
| 1390 | # SPI RTC drivers | 1404 | # SPI RTC drivers |
| @@ -1425,6 +1439,10 @@ CONFIG_NET_DMA=y | |||
| 1425 | # CONFIG_DMATEST is not set | 1439 | # CONFIG_DMATEST is not set |
| 1426 | # CONFIG_AUXDISPLAY is not set | 1440 | # CONFIG_AUXDISPLAY is not set |
| 1427 | # CONFIG_UIO is not set | 1441 | # CONFIG_UIO is not set |
| 1442 | |||
| 1443 | # | ||
| 1444 | # TI VLYNQ | ||
| 1445 | # | ||
| 1428 | # CONFIG_STAGING is not set | 1446 | # CONFIG_STAGING is not set |
| 1429 | 1447 | ||
| 1430 | # | 1448 | # |
| @@ -1444,11 +1462,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1444 | # CONFIG_REISERFS_FS is not set | 1462 | # CONFIG_REISERFS_FS is not set |
| 1445 | # CONFIG_JFS_FS is not set | 1463 | # CONFIG_JFS_FS is not set |
| 1446 | # CONFIG_FS_POSIX_ACL is not set | 1464 | # CONFIG_FS_POSIX_ACL is not set |
| 1447 | CONFIG_FILE_LOCKING=y | ||
| 1448 | # CONFIG_XFS_FS is not set | 1465 | # CONFIG_XFS_FS is not set |
| 1449 | # CONFIG_GFS2_FS is not set | 1466 | # CONFIG_GFS2_FS is not set |
| 1450 | # CONFIG_OCFS2_FS is not set | 1467 | # CONFIG_OCFS2_FS is not set |
| 1451 | # CONFIG_BTRFS_FS is not set | 1468 | # CONFIG_BTRFS_FS is not set |
| 1469 | CONFIG_FILE_LOCKING=y | ||
| 1470 | CONFIG_FSNOTIFY=y | ||
| 1452 | CONFIG_DNOTIFY=y | 1471 | CONFIG_DNOTIFY=y |
| 1453 | CONFIG_INOTIFY=y | 1472 | CONFIG_INOTIFY=y |
| 1454 | CONFIG_INOTIFY_USER=y | 1473 | CONFIG_INOTIFY_USER=y |
| @@ -1629,6 +1648,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1629 | CONFIG_HAS_DMA=y | 1648 | CONFIG_HAS_DMA=y |
| 1630 | CONFIG_HAVE_LMB=y | 1649 | CONFIG_HAVE_LMB=y |
| 1631 | CONFIG_NLATTR=y | 1650 | CONFIG_NLATTR=y |
| 1651 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1632 | 1652 | ||
| 1633 | # | 1653 | # |
| 1634 | # Kernel hacking | 1654 | # Kernel hacking |
| @@ -1659,6 +1679,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 1659 | # CONFIG_RT_MUTEX_TESTER is not set | 1679 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1660 | # CONFIG_DEBUG_SPINLOCK is not set | 1680 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1661 | # CONFIG_DEBUG_MUTEXES is not set | 1681 | # CONFIG_DEBUG_MUTEXES is not set |
| 1682 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1683 | # CONFIG_PROVE_LOCKING is not set | ||
| 1684 | # CONFIG_LOCK_STAT is not set | ||
| 1662 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1685 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1663 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1686 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1664 | # CONFIG_DEBUG_KOBJECT is not set | 1687 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1671,7 +1694,6 @@ CONFIG_SCHED_DEBUG=y | |||
| 1671 | # CONFIG_DEBUG_LIST is not set | 1694 | # CONFIG_DEBUG_LIST is not set |
| 1672 | # CONFIG_DEBUG_SG is not set | 1695 | # CONFIG_DEBUG_SG is not set |
| 1673 | # CONFIG_DEBUG_NOTIFIERS is not set | 1696 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1674 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1675 | # CONFIG_RCU_TORTURE_TEST is not set | 1697 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1676 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1698 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1677 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1699 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1685,16 +1707,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1685 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1707 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1686 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1708 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1687 | CONFIG_TRACING_SUPPORT=y | 1709 | CONFIG_TRACING_SUPPORT=y |
| 1688 | 1710 | CONFIG_FTRACE=y | |
| 1689 | # | ||
| 1690 | # Tracers | ||
| 1691 | # | ||
| 1692 | # CONFIG_FUNCTION_TRACER is not set | 1711 | # CONFIG_FUNCTION_TRACER is not set |
| 1712 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1693 | # CONFIG_SCHED_TRACER is not set | 1713 | # CONFIG_SCHED_TRACER is not set |
| 1694 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1714 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1695 | # CONFIG_EVENT_TRACER is not set | ||
| 1696 | # CONFIG_BOOT_TRACER is not set | 1715 | # CONFIG_BOOT_TRACER is not set |
| 1697 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1716 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1717 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1718 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1698 | # CONFIG_STACK_TRACER is not set | 1719 | # CONFIG_STACK_TRACER is not set |
| 1699 | # CONFIG_KMEMTRACE is not set | 1720 | # CONFIG_KMEMTRACE is not set |
| 1700 | # CONFIG_WORKQUEUE_TRACER is not set | 1721 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -1702,6 +1723,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 1702 | # CONFIG_SAMPLES is not set | 1723 | # CONFIG_SAMPLES is not set |
| 1703 | CONFIG_HAVE_ARCH_KGDB=y | 1724 | CONFIG_HAVE_ARCH_KGDB=y |
| 1704 | # CONFIG_KGDB is not set | 1725 | # CONFIG_KGDB is not set |
| 1726 | # CONFIG_KMEMCHECK is not set | ||
| 1727 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1728 | CONFIG_PPC_WERROR=y | ||
| 1705 | CONFIG_PRINT_STACK_DEPTH=64 | 1729 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1706 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1730 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1707 | # CONFIG_DEBUG_STACK_USAGE is not set | 1731 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/86xx/gef_ppc9a_defconfig b/arch/powerpc/configs/86xx/gef_ppc9a_defconfig index b6a23af57f46..527ad1a5e802 100644 --- a/arch/powerpc/configs/86xx/gef_ppc9a_defconfig +++ b/arch/powerpc/configs/86xx/gef_ppc9a_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:31 2009 | 4 | # Wed Jul 29 23:32:31 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_PHYS_64BIT is not set | 20 | # CONFIG_PHYS_64BIT is not set |
| 20 | CONFIG_ALTIVEC=y | 21 | CONFIG_ALTIVEC=y |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | CONFIG_SMP=y | 26 | CONFIG_SMP=y |
| 25 | CONFIG_NR_CPUS=2 | 27 | CONFIG_NR_CPUS=2 |
| 26 | CONFIG_PPC32=y | 28 | CONFIG_PPC32=y |
| @@ -32,16 +34,17 @@ CONFIG_GENERIC_TIME=y | |||
| 32 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 33 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 34 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 35 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 36 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 37 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 38 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 39 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 40 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 41 | CONFIG_GENERIC_LOCKBREAK=y | 45 | CONFIG_GENERIC_LOCKBREAK=y |
| 42 | CONFIG_ARCH_HAS_ILOG2_U32=y | 46 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 43 | CONFIG_GENERIC_HWEIGHT=y | 47 | CONFIG_GENERIC_HWEIGHT=y |
| 44 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 45 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 48 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 46 | CONFIG_GENERIC_GPIO=y | 49 | CONFIG_GENERIC_GPIO=y |
| 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 50 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -56,11 +59,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 56 | CONFIG_GENERIC_TBSYNC=y | 59 | CONFIG_GENERIC_TBSYNC=y |
| 57 | CONFIG_AUDIT_ARCH=y | 60 | CONFIG_AUDIT_ARCH=y |
| 58 | CONFIG_GENERIC_BUG=y | 61 | CONFIG_GENERIC_BUG=y |
| 62 | CONFIG_DTC=y | ||
| 59 | CONFIG_DEFAULT_UIMAGE=y | 63 | CONFIG_DEFAULT_UIMAGE=y |
| 60 | # CONFIG_PPC_DCR_NATIVE is not set | 64 | # CONFIG_PPC_DCR_NATIVE is not set |
| 61 | # CONFIG_PPC_DCR_MMIO is not set | 65 | # CONFIG_PPC_DCR_MMIO is not set |
| 62 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 66 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 63 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 67 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 68 | CONFIG_CONSTRUCTORS=y | ||
| 64 | 69 | ||
| 65 | # | 70 | # |
| 66 | # General setup | 71 | # General setup |
| @@ -112,9 +117,7 @@ CONFIG_ANON_INODES=y | |||
| 112 | CONFIG_EMBEDDED=y | 117 | CONFIG_EMBEDDED=y |
| 113 | CONFIG_SYSCTL_SYSCALL=y | 118 | CONFIG_SYSCTL_SYSCALL=y |
| 114 | CONFIG_KALLSYMS=y | 119 | CONFIG_KALLSYMS=y |
| 115 | # CONFIG_KALLSYMS_ALL is not set | ||
| 116 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 120 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 117 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 118 | CONFIG_HOTPLUG=y | 121 | CONFIG_HOTPLUG=y |
| 119 | CONFIG_PRINTK=y | 122 | CONFIG_PRINTK=y |
| 120 | CONFIG_BUG=y | 123 | CONFIG_BUG=y |
| @@ -127,8 +130,15 @@ CONFIG_TIMERFD=y | |||
| 127 | CONFIG_EVENTFD=y | 130 | CONFIG_EVENTFD=y |
| 128 | CONFIG_SHMEM=y | 131 | CONFIG_SHMEM=y |
| 129 | CONFIG_AIO=y | 132 | CONFIG_AIO=y |
| 133 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 134 | |||
| 135 | # | ||
| 136 | # Performance Counters | ||
| 137 | # | ||
| 138 | # CONFIG_PERF_COUNTERS is not set | ||
| 130 | CONFIG_VM_EVENT_COUNTERS=y | 139 | CONFIG_VM_EVENT_COUNTERS=y |
| 131 | CONFIG_PCI_QUIRKS=y | 140 | CONFIG_PCI_QUIRKS=y |
| 141 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 132 | CONFIG_COMPAT_BRK=y | 142 | CONFIG_COMPAT_BRK=y |
| 133 | CONFIG_SLAB=y | 143 | CONFIG_SLAB=y |
| 134 | # CONFIG_SLUB is not set | 144 | # CONFIG_SLUB is not set |
| @@ -143,6 +153,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 143 | CONFIG_HAVE_KRETPROBES=y | 153 | CONFIG_HAVE_KRETPROBES=y |
| 144 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 154 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 145 | CONFIG_USE_GENERIC_SMP_HELPERS=y | 155 | CONFIG_USE_GENERIC_SMP_HELPERS=y |
| 156 | |||
| 157 | # | ||
| 158 | # GCOV-based kernel profiling | ||
| 159 | # | ||
| 146 | # CONFIG_SLOW_WORK is not set | 160 | # CONFIG_SLOW_WORK is not set |
| 147 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 161 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 148 | CONFIG_SLABINFO=y | 162 | CONFIG_SLABINFO=y |
| @@ -156,7 +170,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 156 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 170 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 157 | CONFIG_STOP_MACHINE=y | 171 | CONFIG_STOP_MACHINE=y |
| 158 | CONFIG_BLOCK=y | 172 | CONFIG_BLOCK=y |
| 159 | # CONFIG_LBD is not set | 173 | CONFIG_LBDAF=y |
| 160 | # CONFIG_BLK_DEV_BSG is not set | 174 | # CONFIG_BLK_DEV_BSG is not set |
| 161 | # CONFIG_BLK_DEV_INTEGRITY is not set | 175 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 162 | 176 | ||
| @@ -216,7 +230,7 @@ CONFIG_MPIC=y | |||
| 216 | # | 230 | # |
| 217 | # Kernel options | 231 | # Kernel options |
| 218 | # | 232 | # |
| 219 | # CONFIG_HIGHMEM is not set | 233 | CONFIG_HIGHMEM=y |
| 220 | CONFIG_TICK_ONESHOT=y | 234 | CONFIG_TICK_ONESHOT=y |
| 221 | # CONFIG_NO_HZ is not set | 235 | # CONFIG_NO_HZ is not set |
| 222 | CONFIG_HIGH_RES_TIMERS=y | 236 | CONFIG_HIGH_RES_TIMERS=y |
| @@ -235,6 +249,7 @@ CONFIG_BINFMT_ELF=y | |||
| 235 | # CONFIG_HAVE_AOUT is not set | 249 | # CONFIG_HAVE_AOUT is not set |
| 236 | CONFIG_BINFMT_MISC=m | 250 | CONFIG_BINFMT_MISC=m |
| 237 | # CONFIG_IOMMU_HELPER is not set | 251 | # CONFIG_IOMMU_HELPER is not set |
| 252 | # CONFIG_SWIOTLB is not set | ||
| 238 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 253 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 239 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 254 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 240 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 255 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -256,9 +271,9 @@ CONFIG_MIGRATION=y | |||
| 256 | CONFIG_ZONE_DMA_FLAG=1 | 271 | CONFIG_ZONE_DMA_FLAG=1 |
| 257 | CONFIG_BOUNCE=y | 272 | CONFIG_BOUNCE=y |
| 258 | CONFIG_VIRT_TO_BUS=y | 273 | CONFIG_VIRT_TO_BUS=y |
| 259 | CONFIG_UNEVICTABLE_LRU=y | ||
| 260 | CONFIG_HAVE_MLOCK=y | 274 | CONFIG_HAVE_MLOCK=y |
| 261 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 275 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 276 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 262 | CONFIG_PPC_4K_PAGES=y | 277 | CONFIG_PPC_4K_PAGES=y |
| 263 | # CONFIG_PPC_16K_PAGES is not set | 278 | # CONFIG_PPC_16K_PAGES is not set |
| 264 | # CONFIG_PPC_64K_PAGES is not set | 279 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -285,14 +300,32 @@ CONFIG_PCI_DOMAINS=y | |||
| 285 | CONFIG_PCI_SYSCALL=y | 300 | CONFIG_PCI_SYSCALL=y |
| 286 | CONFIG_PCIEPORTBUS=y | 301 | CONFIG_PCIEPORTBUS=y |
| 287 | CONFIG_PCIEAER=y | 302 | CONFIG_PCIEAER=y |
| 303 | # CONFIG_PCIE_ECRC is not set | ||
| 304 | # CONFIG_PCIEAER_INJECT is not set | ||
| 288 | # CONFIG_PCIEASPM is not set | 305 | # CONFIG_PCIEASPM is not set |
| 289 | CONFIG_ARCH_SUPPORTS_MSI=y | 306 | CONFIG_ARCH_SUPPORTS_MSI=y |
| 290 | # CONFIG_PCI_MSI is not set | 307 | # CONFIG_PCI_MSI is not set |
| 291 | # CONFIG_PCI_LEGACY is not set | 308 | # CONFIG_PCI_LEGACY is not set |
| 292 | CONFIG_PCI_DEBUG=y | ||
| 293 | # CONFIG_PCI_STUB is not set | 309 | # CONFIG_PCI_STUB is not set |
| 294 | # CONFIG_PCI_IOV is not set | 310 | # CONFIG_PCI_IOV is not set |
| 295 | # CONFIG_PCCARD is not set | 311 | CONFIG_PCCARD=y |
| 312 | # CONFIG_PCMCIA_DEBUG is not set | ||
| 313 | CONFIG_PCMCIA=y | ||
| 314 | # CONFIG_PCMCIA_LOAD_CIS is not set | ||
| 315 | # CONFIG_PCMCIA_IOCTL is not set | ||
| 316 | # CONFIG_CARDBUS is not set | ||
| 317 | |||
| 318 | # | ||
| 319 | # PC-card bridges | ||
| 320 | # | ||
| 321 | CONFIG_YENTA=y | ||
| 322 | # CONFIG_YENTA_O2 is not set | ||
| 323 | # CONFIG_YENTA_RICOH is not set | ||
| 324 | CONFIG_YENTA_TI=y | ||
| 325 | # CONFIG_YENTA_TOSHIBA is not set | ||
| 326 | # CONFIG_PD6729 is not set | ||
| 327 | # CONFIG_I82092 is not set | ||
| 328 | CONFIG_PCCARD_NONSTATIC=y | ||
| 296 | # CONFIG_HOTPLUG_PCI is not set | 329 | # CONFIG_HOTPLUG_PCI is not set |
| 297 | # CONFIG_HAS_RAPIDIO is not set | 330 | # CONFIG_HAS_RAPIDIO is not set |
| 298 | 331 | ||
| @@ -353,8 +386,8 @@ CONFIG_INET_XFRM_TUNNEL=m | |||
| 353 | CONFIG_INET_TUNNEL=m | 386 | CONFIG_INET_TUNNEL=m |
| 354 | CONFIG_INET_XFRM_MODE_TRANSPORT=y | 387 | CONFIG_INET_XFRM_MODE_TRANSPORT=y |
| 355 | CONFIG_INET_XFRM_MODE_TUNNEL=y | 388 | CONFIG_INET_XFRM_MODE_TUNNEL=y |
| 356 | CONFIG_INET_XFRM_MODE_BEET=y | 389 | # CONFIG_INET_XFRM_MODE_BEET is not set |
| 357 | # CONFIG_INET_LRO is not set | 390 | CONFIG_INET_LRO=y |
| 358 | CONFIG_INET_DIAG=y | 391 | CONFIG_INET_DIAG=y |
| 359 | CONFIG_INET_TCP_DIAG=y | 392 | CONFIG_INET_TCP_DIAG=y |
| 360 | # CONFIG_TCP_CONG_ADVANCED is not set | 393 | # CONFIG_TCP_CONG_ADVANCED is not set |
| @@ -380,174 +413,26 @@ CONFIG_IPV6_NDISC_NODETYPE=y | |||
| 380 | CONFIG_IPV6_TUNNEL=m | 413 | CONFIG_IPV6_TUNNEL=m |
| 381 | # CONFIG_IPV6_MULTIPLE_TABLES is not set | 414 | # CONFIG_IPV6_MULTIPLE_TABLES is not set |
| 382 | # CONFIG_IPV6_MROUTE is not set | 415 | # CONFIG_IPV6_MROUTE is not set |
| 383 | # CONFIG_NETLABEL is not set | ||
| 384 | # CONFIG_NETWORK_SECMARK is not set | 416 | # CONFIG_NETWORK_SECMARK is not set |
| 385 | CONFIG_NETFILTER=y | 417 | # CONFIG_NETFILTER is not set |
| 386 | # CONFIG_NETFILTER_DEBUG is not set | ||
| 387 | CONFIG_NETFILTER_ADVANCED=y | ||
| 388 | CONFIG_BRIDGE_NETFILTER=y | ||
| 389 | |||
| 390 | # | ||
| 391 | # Core Netfilter Configuration | ||
| 392 | # | ||
| 393 | # CONFIG_NETFILTER_NETLINK_QUEUE is not set | ||
| 394 | # CONFIG_NETFILTER_NETLINK_LOG is not set | ||
| 395 | # CONFIG_NF_CONNTRACK is not set | ||
| 396 | # CONFIG_NETFILTER_TPROXY is not set | ||
| 397 | CONFIG_NETFILTER_XTABLES=m | ||
| 398 | # CONFIG_NETFILTER_XT_TARGET_CLASSIFY is not set | ||
| 399 | # CONFIG_NETFILTER_XT_TARGET_DSCP is not set | ||
| 400 | # CONFIG_NETFILTER_XT_TARGET_HL is not set | ||
| 401 | # CONFIG_NETFILTER_XT_TARGET_MARK is not set | ||
| 402 | # CONFIG_NETFILTER_XT_TARGET_NFLOG is not set | ||
| 403 | # CONFIG_NETFILTER_XT_TARGET_NFQUEUE is not set | ||
| 404 | # CONFIG_NETFILTER_XT_TARGET_RATEEST is not set | ||
| 405 | # CONFIG_NETFILTER_XT_TARGET_TRACE is not set | ||
| 406 | # CONFIG_NETFILTER_XT_TARGET_TCPMSS is not set | ||
| 407 | # CONFIG_NETFILTER_XT_TARGET_TCPOPTSTRIP is not set | ||
| 408 | # CONFIG_NETFILTER_XT_MATCH_COMMENT is not set | ||
| 409 | # CONFIG_NETFILTER_XT_MATCH_DCCP is not set | ||
| 410 | # CONFIG_NETFILTER_XT_MATCH_DSCP is not set | ||
| 411 | # CONFIG_NETFILTER_XT_MATCH_ESP is not set | ||
| 412 | # CONFIG_NETFILTER_XT_MATCH_HASHLIMIT is not set | ||
| 413 | CONFIG_NETFILTER_XT_MATCH_HL=m | ||
| 414 | # CONFIG_NETFILTER_XT_MATCH_IPRANGE is not set | ||
| 415 | # CONFIG_NETFILTER_XT_MATCH_LENGTH is not set | ||
| 416 | # CONFIG_NETFILTER_XT_MATCH_LIMIT is not set | ||
| 417 | # CONFIG_NETFILTER_XT_MATCH_MAC is not set | ||
| 418 | # CONFIG_NETFILTER_XT_MATCH_MARK is not set | ||
| 419 | # CONFIG_NETFILTER_XT_MATCH_MULTIPORT is not set | ||
| 420 | # CONFIG_NETFILTER_XT_MATCH_OWNER is not set | ||
| 421 | # CONFIG_NETFILTER_XT_MATCH_POLICY is not set | ||
| 422 | # CONFIG_NETFILTER_XT_MATCH_PHYSDEV is not set | ||
| 423 | # CONFIG_NETFILTER_XT_MATCH_PKTTYPE is not set | ||
| 424 | # CONFIG_NETFILTER_XT_MATCH_QUOTA is not set | ||
| 425 | # CONFIG_NETFILTER_XT_MATCH_RATEEST is not set | ||
| 426 | # CONFIG_NETFILTER_XT_MATCH_REALM is not set | ||
| 427 | # CONFIG_NETFILTER_XT_MATCH_RECENT is not set | ||
| 428 | # CONFIG_NETFILTER_XT_MATCH_SCTP is not set | ||
| 429 | # CONFIG_NETFILTER_XT_MATCH_STATISTIC is not set | ||
| 430 | # CONFIG_NETFILTER_XT_MATCH_STRING is not set | ||
| 431 | # CONFIG_NETFILTER_XT_MATCH_TCPMSS is not set | ||
| 432 | # CONFIG_NETFILTER_XT_MATCH_TIME is not set | ||
| 433 | # CONFIG_NETFILTER_XT_MATCH_U32 is not set | ||
| 434 | # CONFIG_IP_VS is not set | ||
| 435 | |||
| 436 | # | ||
| 437 | # IP: Netfilter Configuration | ||
| 438 | # | ||
| 439 | # CONFIG_NF_DEFRAG_IPV4 is not set | ||
| 440 | CONFIG_IP_NF_QUEUE=m | ||
| 441 | CONFIG_IP_NF_IPTABLES=m | ||
| 442 | CONFIG_IP_NF_MATCH_ADDRTYPE=m | ||
| 443 | # CONFIG_IP_NF_MATCH_AH is not set | ||
| 444 | CONFIG_IP_NF_MATCH_ECN=m | ||
| 445 | CONFIG_IP_NF_MATCH_TTL=m | ||
| 446 | CONFIG_IP_NF_FILTER=m | ||
| 447 | CONFIG_IP_NF_TARGET_REJECT=m | ||
| 448 | CONFIG_IP_NF_TARGET_LOG=m | ||
| 449 | CONFIG_IP_NF_TARGET_ULOG=m | ||
| 450 | CONFIG_IP_NF_MANGLE=m | ||
| 451 | CONFIG_IP_NF_TARGET_ECN=m | ||
| 452 | # CONFIG_IP_NF_TARGET_TTL is not set | ||
| 453 | CONFIG_IP_NF_RAW=m | ||
| 454 | # CONFIG_IP_NF_SECURITY is not set | ||
| 455 | CONFIG_IP_NF_ARPTABLES=m | ||
| 456 | CONFIG_IP_NF_ARPFILTER=m | ||
| 457 | CONFIG_IP_NF_ARP_MANGLE=m | ||
| 458 | |||
| 459 | # | ||
| 460 | # IPv6: Netfilter Configuration | ||
| 461 | # | ||
| 462 | CONFIG_IP6_NF_QUEUE=m | ||
| 463 | CONFIG_IP6_NF_IPTABLES=m | ||
| 464 | # CONFIG_IP6_NF_MATCH_AH is not set | ||
| 465 | CONFIG_IP6_NF_MATCH_EUI64=m | ||
| 466 | CONFIG_IP6_NF_MATCH_FRAG=m | ||
| 467 | CONFIG_IP6_NF_MATCH_OPTS=m | ||
| 468 | CONFIG_IP6_NF_MATCH_HL=m | ||
| 469 | CONFIG_IP6_NF_MATCH_IPV6HEADER=m | ||
| 470 | # CONFIG_IP6_NF_MATCH_MH is not set | ||
| 471 | CONFIG_IP6_NF_MATCH_RT=m | ||
| 472 | # CONFIG_IP6_NF_TARGET_HL is not set | ||
| 473 | CONFIG_IP6_NF_TARGET_LOG=m | ||
| 474 | CONFIG_IP6_NF_FILTER=m | ||
| 475 | # CONFIG_IP6_NF_TARGET_REJECT is not set | ||
| 476 | CONFIG_IP6_NF_MANGLE=m | ||
| 477 | CONFIG_IP6_NF_RAW=m | ||
| 478 | # CONFIG_IP6_NF_SECURITY is not set | ||
| 479 | # CONFIG_BRIDGE_NF_EBTABLES is not set | ||
| 480 | # CONFIG_IP_DCCP is not set | 418 | # CONFIG_IP_DCCP is not set |
| 481 | CONFIG_IP_SCTP=m | 419 | # CONFIG_IP_SCTP is not set |
| 482 | # CONFIG_SCTP_DBG_MSG is not set | 420 | # CONFIG_TIPC is not set |
| 483 | # CONFIG_SCTP_DBG_OBJCNT is not set | 421 | # CONFIG_ATM is not set |
| 484 | # CONFIG_SCTP_HMAC_NONE is not set | 422 | # CONFIG_BRIDGE is not set |
| 485 | # CONFIG_SCTP_HMAC_SHA1 is not set | ||
| 486 | CONFIG_SCTP_HMAC_MD5=y | ||
| 487 | CONFIG_TIPC=m | ||
| 488 | # CONFIG_TIPC_ADVANCED is not set | ||
| 489 | # CONFIG_TIPC_DEBUG is not set | ||
| 490 | CONFIG_ATM=m | ||
| 491 | CONFIG_ATM_CLIP=m | ||
| 492 | # CONFIG_ATM_CLIP_NO_ICMP is not set | ||
| 493 | CONFIG_ATM_LANE=m | ||
| 494 | CONFIG_ATM_MPOA=m | ||
| 495 | CONFIG_ATM_BR2684=m | ||
| 496 | # CONFIG_ATM_BR2684_IPFILTER is not set | ||
| 497 | CONFIG_STP=m | ||
| 498 | CONFIG_BRIDGE=m | ||
| 499 | # CONFIG_NET_DSA is not set | 423 | # CONFIG_NET_DSA is not set |
| 500 | CONFIG_VLAN_8021Q=m | 424 | # CONFIG_VLAN_8021Q is not set |
| 501 | # CONFIG_VLAN_8021Q_GVRP is not set | ||
| 502 | # CONFIG_DECNET is not set | 425 | # CONFIG_DECNET is not set |
| 503 | CONFIG_LLC=m | ||
| 504 | # CONFIG_LLC2 is not set | 426 | # CONFIG_LLC2 is not set |
| 505 | # CONFIG_IPX is not set | 427 | # CONFIG_IPX is not set |
| 506 | # CONFIG_ATALK is not set | 428 | # CONFIG_ATALK is not set |
| 507 | # CONFIG_X25 is not set | 429 | # CONFIG_X25 is not set |
| 508 | # CONFIG_LAPB is not set | 430 | # CONFIG_LAPB is not set |
| 509 | # CONFIG_ECONET is not set | 431 | # CONFIG_ECONET is not set |
| 510 | CONFIG_WAN_ROUTER=m | 432 | # CONFIG_WAN_ROUTER is not set |
| 511 | # CONFIG_PHONET is not set | 433 | # CONFIG_PHONET is not set |
| 512 | CONFIG_NET_SCHED=y | 434 | # CONFIG_IEEE802154 is not set |
| 513 | 435 | # CONFIG_NET_SCHED is not set | |
| 514 | # | ||
| 515 | # Queueing/Scheduling | ||
| 516 | # | ||
| 517 | CONFIG_NET_SCH_CBQ=m | ||
| 518 | CONFIG_NET_SCH_HTB=m | ||
| 519 | CONFIG_NET_SCH_HFSC=m | ||
| 520 | CONFIG_NET_SCH_ATM=m | ||
| 521 | CONFIG_NET_SCH_PRIO=m | ||
| 522 | # CONFIG_NET_SCH_MULTIQ is not set | ||
| 523 | CONFIG_NET_SCH_RED=m | ||
| 524 | CONFIG_NET_SCH_SFQ=m | ||
| 525 | CONFIG_NET_SCH_TEQL=m | ||
| 526 | CONFIG_NET_SCH_TBF=m | ||
| 527 | CONFIG_NET_SCH_GRED=m | ||
| 528 | CONFIG_NET_SCH_DSMARK=m | ||
| 529 | CONFIG_NET_SCH_NETEM=m | ||
| 530 | # CONFIG_NET_SCH_DRR is not set | ||
| 531 | |||
| 532 | # | ||
| 533 | # Classification | ||
| 534 | # | ||
| 535 | CONFIG_NET_CLS=y | ||
| 536 | # CONFIG_NET_CLS_BASIC is not set | ||
| 537 | CONFIG_NET_CLS_TCINDEX=m | ||
| 538 | CONFIG_NET_CLS_ROUTE4=m | ||
| 539 | CONFIG_NET_CLS_ROUTE=y | ||
| 540 | CONFIG_NET_CLS_FW=m | ||
| 541 | CONFIG_NET_CLS_U32=m | ||
| 542 | # CONFIG_CLS_U32_PERF is not set | ||
| 543 | # CONFIG_CLS_U32_MARK is not set | ||
| 544 | CONFIG_NET_CLS_RSVP=m | ||
| 545 | CONFIG_NET_CLS_RSVP6=m | ||
| 546 | # CONFIG_NET_CLS_FLOW is not set | ||
| 547 | # CONFIG_NET_EMATCH is not set | ||
| 548 | # CONFIG_NET_CLS_ACT is not set | ||
| 549 | # CONFIG_NET_CLS_IND is not set | ||
| 550 | CONFIG_NET_SCH_FIFO=y | ||
| 551 | # CONFIG_DCB is not set | 436 | # CONFIG_DCB is not set |
| 552 | 437 | ||
| 553 | # | 438 | # |
| @@ -560,12 +445,7 @@ CONFIG_NET_PKTGEN=m | |||
| 560 | # CONFIG_BT is not set | 445 | # CONFIG_BT is not set |
| 561 | # CONFIG_AF_RXRPC is not set | 446 | # CONFIG_AF_RXRPC is not set |
| 562 | CONFIG_FIB_RULES=y | 447 | CONFIG_FIB_RULES=y |
| 563 | CONFIG_WIRELESS=y | 448 | # CONFIG_WIRELESS is not set |
| 564 | # CONFIG_CFG80211 is not set | ||
| 565 | CONFIG_WIRELESS_OLD_REGULATORY=y | ||
| 566 | # CONFIG_WIRELESS_EXT is not set | ||
| 567 | # CONFIG_LIB80211 is not set | ||
| 568 | # CONFIG_MAC80211 is not set | ||
| 569 | # CONFIG_WIMAX is not set | 449 | # CONFIG_WIMAX is not set |
| 570 | # CONFIG_RFKILL is not set | 450 | # CONFIG_RFKILL is not set |
| 571 | # CONFIG_NET_9P is not set | 451 | # CONFIG_NET_9P is not set |
| @@ -580,9 +460,9 @@ CONFIG_WIRELESS_OLD_REGULATORY=y | |||
| 580 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" | 460 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" |
| 581 | CONFIG_STANDALONE=y | 461 | CONFIG_STANDALONE=y |
| 582 | CONFIG_PREVENT_FIRMWARE_BUILD=y | 462 | CONFIG_PREVENT_FIRMWARE_BUILD=y |
| 583 | # CONFIG_FW_LOADER is not set | 463 | CONFIG_FW_LOADER=y |
| 584 | # CONFIG_DEBUG_DRIVER is not set | 464 | CONFIG_FIRMWARE_IN_KERNEL=y |
| 585 | # CONFIG_DEBUG_DEVRES is not set | 465 | CONFIG_EXTRA_FIRMWARE="" |
| 586 | # CONFIG_SYS_HYPERVISOR is not set | 466 | # CONFIG_SYS_HYPERVISOR is not set |
| 587 | # CONFIG_CONNECTOR is not set | 467 | # CONFIG_CONNECTOR is not set |
| 588 | CONFIG_MTD=y | 468 | CONFIG_MTD=y |
| @@ -672,6 +552,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 672 | CONFIG_OF_DEVICE=y | 552 | CONFIG_OF_DEVICE=y |
| 673 | CONFIG_OF_GPIO=y | 553 | CONFIG_OF_GPIO=y |
| 674 | CONFIG_OF_I2C=y | 554 | CONFIG_OF_I2C=y |
| 555 | CONFIG_OF_MDIO=y | ||
| 675 | # CONFIG_PARPORT is not set | 556 | # CONFIG_PARPORT is not set |
| 676 | CONFIG_BLK_DEV=y | 557 | CONFIG_BLK_DEV=y |
| 677 | # CONFIG_BLK_DEV_FD is not set | 558 | # CONFIG_BLK_DEV_FD is not set |
| @@ -707,9 +588,60 @@ CONFIG_MISC_DEVICES=y | |||
| 707 | # | 588 | # |
| 708 | # CONFIG_EEPROM_AT24 is not set | 589 | # CONFIG_EEPROM_AT24 is not set |
| 709 | # CONFIG_EEPROM_LEGACY is not set | 590 | # CONFIG_EEPROM_LEGACY is not set |
| 591 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 710 | # CONFIG_EEPROM_93CX6 is not set | 592 | # CONFIG_EEPROM_93CX6 is not set |
| 593 | # CONFIG_CB710_CORE is not set | ||
| 711 | CONFIG_HAVE_IDE=y | 594 | CONFIG_HAVE_IDE=y |
| 712 | # CONFIG_IDE is not set | 595 | CONFIG_IDE=y |
| 596 | |||
| 597 | # | ||
| 598 | # Please see Documentation/ide/ide.txt for help/info on IDE drives | ||
| 599 | # | ||
| 600 | # CONFIG_BLK_DEV_IDE_SATA is not set | ||
| 601 | CONFIG_IDE_GD=y | ||
| 602 | CONFIG_IDE_GD_ATA=y | ||
| 603 | # CONFIG_IDE_GD_ATAPI is not set | ||
| 604 | CONFIG_BLK_DEV_IDECS=y | ||
| 605 | # CONFIG_BLK_DEV_IDECD is not set | ||
| 606 | # CONFIG_BLK_DEV_IDETAPE is not set | ||
| 607 | # CONFIG_IDE_TASK_IOCTL is not set | ||
| 608 | CONFIG_IDE_PROC_FS=y | ||
| 609 | |||
| 610 | # | ||
| 611 | # IDE chipset support/bugfixes | ||
| 612 | # | ||
| 613 | # CONFIG_BLK_DEV_PLATFORM is not set | ||
| 614 | |||
| 615 | # | ||
| 616 | # PCI IDE chipsets support | ||
| 617 | # | ||
| 618 | # CONFIG_BLK_DEV_GENERIC is not set | ||
| 619 | # CONFIG_BLK_DEV_OPTI621 is not set | ||
| 620 | # CONFIG_BLK_DEV_AEC62XX is not set | ||
| 621 | # CONFIG_BLK_DEV_ALI15X3 is not set | ||
| 622 | # CONFIG_BLK_DEV_AMD74XX is not set | ||
| 623 | # CONFIG_BLK_DEV_CMD64X is not set | ||
| 624 | # CONFIG_BLK_DEV_TRIFLEX is not set | ||
| 625 | # CONFIG_BLK_DEV_CS5520 is not set | ||
| 626 | # CONFIG_BLK_DEV_CS5530 is not set | ||
| 627 | # CONFIG_BLK_DEV_HPT366 is not set | ||
| 628 | # CONFIG_BLK_DEV_JMICRON is not set | ||
| 629 | # CONFIG_BLK_DEV_SC1200 is not set | ||
| 630 | # CONFIG_BLK_DEV_PIIX is not set | ||
| 631 | # CONFIG_BLK_DEV_IT8172 is not set | ||
| 632 | # CONFIG_BLK_DEV_IT8213 is not set | ||
| 633 | # CONFIG_BLK_DEV_IT821X is not set | ||
| 634 | # CONFIG_BLK_DEV_NS87415 is not set | ||
| 635 | # CONFIG_BLK_DEV_PDC202XX_OLD is not set | ||
| 636 | # CONFIG_BLK_DEV_PDC202XX_NEW is not set | ||
| 637 | # CONFIG_BLK_DEV_SVWKS is not set | ||
| 638 | # CONFIG_BLK_DEV_SIIMAGE is not set | ||
| 639 | # CONFIG_BLK_DEV_SL82C105 is not set | ||
| 640 | # CONFIG_BLK_DEV_SLC90E66 is not set | ||
| 641 | # CONFIG_BLK_DEV_TRM290 is not set | ||
| 642 | # CONFIG_BLK_DEV_VIA82CXXX is not set | ||
| 643 | # CONFIG_BLK_DEV_TC86C001 is not set | ||
| 644 | # CONFIG_BLK_DEV_IDEDMA is not set | ||
| 713 | 645 | ||
| 714 | # | 646 | # |
| 715 | # SCSI device support | 647 | # SCSI device support |
| @@ -731,10 +663,6 @@ CONFIG_BLK_DEV_SR=y | |||
| 731 | # CONFIG_BLK_DEV_SR_VENDOR is not set | 663 | # CONFIG_BLK_DEV_SR_VENDOR is not set |
| 732 | # CONFIG_CHR_DEV_SG is not set | 664 | # CONFIG_CHR_DEV_SG is not set |
| 733 | # CONFIG_CHR_DEV_SCH is not set | 665 | # CONFIG_CHR_DEV_SCH is not set |
| 734 | |||
| 735 | # | ||
| 736 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 737 | # | ||
| 738 | # CONFIG_SCSI_MULTI_LUN is not set | 666 | # CONFIG_SCSI_MULTI_LUN is not set |
| 739 | # CONFIG_SCSI_CONSTANTS is not set | 667 | # CONFIG_SCSI_CONSTANTS is not set |
| 740 | # CONFIG_SCSI_LOGGING is not set | 668 | # CONFIG_SCSI_LOGGING is not set |
| @@ -751,6 +679,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 751 | # CONFIG_SCSI_SRP_ATTRS is not set | 679 | # CONFIG_SCSI_SRP_ATTRS is not set |
| 752 | CONFIG_SCSI_LOWLEVEL=y | 680 | CONFIG_SCSI_LOWLEVEL=y |
| 753 | # CONFIG_ISCSI_TCP is not set | 681 | # CONFIG_ISCSI_TCP is not set |
| 682 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 754 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 683 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 755 | # CONFIG_SCSI_3W_9XXX is not set | 684 | # CONFIG_SCSI_3W_9XXX is not set |
| 756 | # CONFIG_SCSI_ACARD is not set | 685 | # CONFIG_SCSI_ACARD is not set |
| @@ -759,6 +688,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 759 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 688 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 760 | # CONFIG_SCSI_AIC79XX is not set | 689 | # CONFIG_SCSI_AIC79XX is not set |
| 761 | # CONFIG_SCSI_AIC94XX is not set | 690 | # CONFIG_SCSI_AIC94XX is not set |
| 691 | # CONFIG_SCSI_MVSAS is not set | ||
| 762 | # CONFIG_SCSI_DPT_I2O is not set | 692 | # CONFIG_SCSI_DPT_I2O is not set |
| 763 | # CONFIG_SCSI_ADVANSYS is not set | 693 | # CONFIG_SCSI_ADVANSYS is not set |
| 764 | # CONFIG_SCSI_ARCMSR is not set | 694 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -778,7 +708,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 778 | # CONFIG_SCSI_IPS is not set | 708 | # CONFIG_SCSI_IPS is not set |
| 779 | # CONFIG_SCSI_INITIO is not set | 709 | # CONFIG_SCSI_INITIO is not set |
| 780 | # CONFIG_SCSI_INIA100 is not set | 710 | # CONFIG_SCSI_INIA100 is not set |
| 781 | # CONFIG_SCSI_MVSAS is not set | ||
| 782 | # CONFIG_SCSI_STEX is not set | 711 | # CONFIG_SCSI_STEX is not set |
| 783 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 712 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 784 | # CONFIG_SCSI_IPR is not set | 713 | # CONFIG_SCSI_IPR is not set |
| @@ -791,6 +720,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 791 | # CONFIG_SCSI_NSP32 is not set | 720 | # CONFIG_SCSI_NSP32 is not set |
| 792 | # CONFIG_SCSI_DEBUG is not set | 721 | # CONFIG_SCSI_DEBUG is not set |
| 793 | # CONFIG_SCSI_SRP is not set | 722 | # CONFIG_SCSI_SRP is not set |
| 723 | # CONFIG_SCSI_LOWLEVEL_PCMCIA is not set | ||
| 794 | # CONFIG_SCSI_DH is not set | 724 | # CONFIG_SCSI_DH is not set |
| 795 | # CONFIG_SCSI_OSD_INITIATOR is not set | 725 | # CONFIG_SCSI_OSD_INITIATOR is not set |
| 796 | CONFIG_ATA=y | 726 | CONFIG_ATA=y |
| @@ -842,6 +772,7 @@ CONFIG_SATA_SIL=y | |||
| 842 | # CONFIG_PATA_NS87415 is not set | 772 | # CONFIG_PATA_NS87415 is not set |
| 843 | # CONFIG_PATA_OPTI is not set | 773 | # CONFIG_PATA_OPTI is not set |
| 844 | # CONFIG_PATA_OPTIDMA is not set | 774 | # CONFIG_PATA_OPTIDMA is not set |
| 775 | # CONFIG_PATA_PCMCIA is not set | ||
| 845 | # CONFIG_PATA_PDC_OLD is not set | 776 | # CONFIG_PATA_PDC_OLD is not set |
| 846 | # CONFIG_PATA_RADISYS is not set | 777 | # CONFIG_PATA_RADISYS is not set |
| 847 | # CONFIG_PATA_RZ1000 is not set | 778 | # CONFIG_PATA_RZ1000 is not set |
| @@ -862,14 +793,17 @@ CONFIG_SATA_SIL=y | |||
| 862 | # | 793 | # |
| 863 | 794 | ||
| 864 | # | 795 | # |
| 865 | # Enable only one of the two stacks, unless you know what you are doing | 796 | # You can enable one or both FireWire driver stacks. |
| 797 | # | ||
| 798 | |||
| 799 | # | ||
| 800 | # See the help texts for more information. | ||
| 866 | # | 801 | # |
| 867 | # CONFIG_FIREWIRE is not set | 802 | # CONFIG_FIREWIRE is not set |
| 868 | # CONFIG_IEEE1394 is not set | 803 | # CONFIG_IEEE1394 is not set |
| 869 | # CONFIG_I2O is not set | 804 | # CONFIG_I2O is not set |
| 870 | # CONFIG_MACINTOSH_DRIVERS is not set | 805 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 871 | CONFIG_NETDEVICES=y | 806 | CONFIG_NETDEVICES=y |
| 872 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 873 | CONFIG_DUMMY=m | 807 | CONFIG_DUMMY=m |
| 874 | CONFIG_BONDING=m | 808 | CONFIG_BONDING=m |
| 875 | # CONFIG_MACVLAN is not set | 809 | # CONFIG_MACVLAN is not set |
| @@ -916,6 +850,7 @@ CONFIG_MII=y | |||
| 916 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 850 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 917 | # CONFIG_NET_PCI is not set | 851 | # CONFIG_NET_PCI is not set |
| 918 | # CONFIG_B44 is not set | 852 | # CONFIG_B44 is not set |
| 853 | # CONFIG_KS8842 is not set | ||
| 919 | # CONFIG_ATL2 is not set | 854 | # CONFIG_ATL2 is not set |
| 920 | CONFIG_NETDEV_1000=y | 855 | CONFIG_NETDEV_1000=y |
| 921 | # CONFIG_ACENIC is not set | 856 | # CONFIG_ACENIC is not set |
| @@ -935,8 +870,10 @@ CONFIG_NETDEV_1000=y | |||
| 935 | # CONFIG_VIA_VELOCITY is not set | 870 | # CONFIG_VIA_VELOCITY is not set |
| 936 | # CONFIG_TIGON3 is not set | 871 | # CONFIG_TIGON3 is not set |
| 937 | # CONFIG_BNX2 is not set | 872 | # CONFIG_BNX2 is not set |
| 873 | # CONFIG_CNIC is not set | ||
| 938 | CONFIG_FSL_PQ_MDIO=y | 874 | CONFIG_FSL_PQ_MDIO=y |
| 939 | CONFIG_GIANFAR=y | 875 | CONFIG_GIANFAR=y |
| 876 | # CONFIG_MV643XX_ETH is not set | ||
| 940 | # CONFIG_QLA3XXX is not set | 877 | # CONFIG_QLA3XXX is not set |
| 941 | # CONFIG_ATL1 is not set | 878 | # CONFIG_ATL1 is not set |
| 942 | # CONFIG_ATL1E is not set | 879 | # CONFIG_ATL1E is not set |
| @@ -963,22 +900,8 @@ CONFIG_GIANFAR=y | |||
| 963 | # CONFIG_USB_PEGASUS is not set | 900 | # CONFIG_USB_PEGASUS is not set |
| 964 | # CONFIG_USB_RTL8150 is not set | 901 | # CONFIG_USB_RTL8150 is not set |
| 965 | # CONFIG_USB_USBNET is not set | 902 | # CONFIG_USB_USBNET is not set |
| 903 | # CONFIG_NET_PCMCIA is not set | ||
| 966 | # CONFIG_WAN is not set | 904 | # CONFIG_WAN is not set |
| 967 | CONFIG_ATM_DRIVERS=y | ||
| 968 | # CONFIG_ATM_DUMMY is not set | ||
| 969 | # CONFIG_ATM_TCP is not set | ||
| 970 | # CONFIG_ATM_LANAI is not set | ||
| 971 | # CONFIG_ATM_ENI is not set | ||
| 972 | # CONFIG_ATM_FIRESTREAM is not set | ||
| 973 | # CONFIG_ATM_ZATM is not set | ||
| 974 | # CONFIG_ATM_NICSTAR is not set | ||
| 975 | # CONFIG_ATM_IDT77252 is not set | ||
| 976 | # CONFIG_ATM_AMBASSADOR is not set | ||
| 977 | # CONFIG_ATM_HORIZON is not set | ||
| 978 | # CONFIG_ATM_IA is not set | ||
| 979 | # CONFIG_ATM_FORE200E is not set | ||
| 980 | # CONFIG_ATM_HE is not set | ||
| 981 | # CONFIG_ATM_SOLOS is not set | ||
| 982 | # CONFIG_FDDI is not set | 905 | # CONFIG_FDDI is not set |
| 983 | # CONFIG_HIPPI is not set | 906 | # CONFIG_HIPPI is not set |
| 984 | CONFIG_PPP=m | 907 | CONFIG_PPP=m |
| @@ -990,7 +913,6 @@ CONFIG_PPP_DEFLATE=m | |||
| 990 | CONFIG_PPP_BSDCOMP=m | 913 | CONFIG_PPP_BSDCOMP=m |
| 991 | # CONFIG_PPP_MPPE is not set | 914 | # CONFIG_PPP_MPPE is not set |
| 992 | CONFIG_PPPOE=m | 915 | CONFIG_PPPOE=m |
| 993 | CONFIG_PPPOATM=m | ||
| 994 | # CONFIG_PPPOL2TP is not set | 916 | # CONFIG_PPPOL2TP is not set |
| 995 | CONFIG_SLIP=m | 917 | CONFIG_SLIP=m |
| 996 | CONFIG_SLIP_COMPRESSED=y | 918 | CONFIG_SLIP_COMPRESSED=y |
| @@ -1010,7 +932,7 @@ CONFIG_NET_POLL_CONTROLLER=y | |||
| 1010 | # Input device support | 932 | # Input device support |
| 1011 | # | 933 | # |
| 1012 | CONFIG_INPUT=y | 934 | CONFIG_INPUT=y |
| 1013 | CONFIG_INPUT_FF_MEMLESS=m | 935 | # CONFIG_INPUT_FF_MEMLESS is not set |
| 1014 | # CONFIG_INPUT_POLLDEV is not set | 936 | # CONFIG_INPUT_POLLDEV is not set |
| 1015 | 937 | ||
| 1016 | # | 938 | # |
| @@ -1058,6 +980,7 @@ CONFIG_DEVKMEM=y | |||
| 1058 | CONFIG_SERIAL_8250=y | 980 | CONFIG_SERIAL_8250=y |
| 1059 | CONFIG_SERIAL_8250_CONSOLE=y | 981 | CONFIG_SERIAL_8250_CONSOLE=y |
| 1060 | # CONFIG_SERIAL_8250_PCI is not set | 982 | # CONFIG_SERIAL_8250_PCI is not set |
| 983 | # CONFIG_SERIAL_8250_CS is not set | ||
| 1061 | CONFIG_SERIAL_8250_NR_UARTS=2 | 984 | CONFIG_SERIAL_8250_NR_UARTS=2 |
| 1062 | CONFIG_SERIAL_8250_RUNTIME_UARTS=2 | 985 | CONFIG_SERIAL_8250_RUNTIME_UARTS=2 |
| 1063 | # CONFIG_SERIAL_8250_EXTENDED is not set | 986 | # CONFIG_SERIAL_8250_EXTENDED is not set |
| @@ -1080,6 +1003,14 @@ CONFIG_HW_RANDOM=y | |||
| 1080 | CONFIG_NVRAM=y | 1003 | CONFIG_NVRAM=y |
| 1081 | # CONFIG_R3964 is not set | 1004 | # CONFIG_R3964 is not set |
| 1082 | # CONFIG_APPLICOM is not set | 1005 | # CONFIG_APPLICOM is not set |
| 1006 | |||
| 1007 | # | ||
| 1008 | # PCMCIA character devices | ||
| 1009 | # | ||
| 1010 | # CONFIG_SYNCLINK_CS is not set | ||
| 1011 | # CONFIG_CARDMAN_4000 is not set | ||
| 1012 | # CONFIG_CARDMAN_4040 is not set | ||
| 1013 | # CONFIG_IPWIRELESS is not set | ||
| 1083 | # CONFIG_RAW_DRIVER is not set | 1014 | # CONFIG_RAW_DRIVER is not set |
| 1084 | # CONFIG_TCG_TPM is not set | 1015 | # CONFIG_TCG_TPM is not set |
| 1085 | CONFIG_DEVPORT=y | 1016 | CONFIG_DEVPORT=y |
| @@ -1143,18 +1074,21 @@ CONFIG_DS1682=y | |||
| 1143 | # CONFIG_SENSORS_PCF8574 is not set | 1074 | # CONFIG_SENSORS_PCF8574 is not set |
| 1144 | # CONFIG_PCF8575 is not set | 1075 | # CONFIG_PCF8575 is not set |
| 1145 | # CONFIG_SENSORS_PCA9539 is not set | 1076 | # CONFIG_SENSORS_PCA9539 is not set |
| 1146 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 1147 | # CONFIG_SENSORS_TSL2550 is not set | 1077 | # CONFIG_SENSORS_TSL2550 is not set |
| 1148 | # CONFIG_I2C_DEBUG_CORE is not set | 1078 | # CONFIG_I2C_DEBUG_CORE is not set |
| 1149 | # CONFIG_I2C_DEBUG_ALGO is not set | 1079 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 1150 | # CONFIG_I2C_DEBUG_BUS is not set | 1080 | # CONFIG_I2C_DEBUG_BUS is not set |
| 1151 | # CONFIG_I2C_DEBUG_CHIP is not set | 1081 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 1152 | # CONFIG_SPI is not set | 1082 | # CONFIG_SPI is not set |
| 1083 | |||
| 1084 | # | ||
| 1085 | # PPS support | ||
| 1086 | # | ||
| 1087 | # CONFIG_PPS is not set | ||
| 1153 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 1088 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 1154 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 1089 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 1155 | CONFIG_GPIOLIB=y | 1090 | CONFIG_GPIOLIB=y |
| 1156 | # CONFIG_DEBUG_GPIO is not set | 1091 | CONFIG_GPIO_SYSFS=y |
| 1157 | # CONFIG_GPIO_SYSFS is not set | ||
| 1158 | 1092 | ||
| 1159 | # | 1093 | # |
| 1160 | # Memory mapped GPIO expanders: | 1094 | # Memory mapped GPIO expanders: |
| @@ -1229,6 +1163,7 @@ CONFIG_SENSORS_LM92=y | |||
| 1229 | # CONFIG_SENSORS_SMSC47B397 is not set | 1163 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 1230 | # CONFIG_SENSORS_ADS7828 is not set | 1164 | # CONFIG_SENSORS_ADS7828 is not set |
| 1231 | # CONFIG_SENSORS_THMC50 is not set | 1165 | # CONFIG_SENSORS_THMC50 is not set |
| 1166 | # CONFIG_SENSORS_TMP401 is not set | ||
| 1232 | # CONFIG_SENSORS_VIA686A is not set | 1167 | # CONFIG_SENSORS_VIA686A is not set |
| 1233 | # CONFIG_SENSORS_VT1211 is not set | 1168 | # CONFIG_SENSORS_VT1211 is not set |
| 1234 | # CONFIG_SENSORS_VT8231 is not set | 1169 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -1284,24 +1219,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1284 | # CONFIG_MFD_WM8400 is not set | 1219 | # CONFIG_MFD_WM8400 is not set |
| 1285 | # CONFIG_MFD_WM8350_I2C is not set | 1220 | # CONFIG_MFD_WM8350_I2C is not set |
| 1286 | # CONFIG_MFD_PCF50633 is not set | 1221 | # CONFIG_MFD_PCF50633 is not set |
| 1222 | # CONFIG_AB3100_CORE is not set | ||
| 1287 | # CONFIG_REGULATOR is not set | 1223 | # CONFIG_REGULATOR is not set |
| 1288 | 1224 | # CONFIG_MEDIA_SUPPORT is not set | |
| 1289 | # | ||
| 1290 | # Multimedia devices | ||
| 1291 | # | ||
| 1292 | |||
| 1293 | # | ||
| 1294 | # Multimedia core support | ||
| 1295 | # | ||
| 1296 | # CONFIG_VIDEO_DEV is not set | ||
| 1297 | # CONFIG_DVB_CORE is not set | ||
| 1298 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1299 | |||
| 1300 | # | ||
| 1301 | # Multimedia drivers | ||
| 1302 | # | ||
| 1303 | CONFIG_DAB=y | ||
| 1304 | # CONFIG_USB_DABUSB is not set | ||
| 1305 | 1225 | ||
| 1306 | # | 1226 | # |
| 1307 | # Graphics support | 1227 | # Graphics support |
| @@ -1346,7 +1266,7 @@ CONFIG_HID_BELKIN=y | |||
| 1346 | CONFIG_HID_CHERRY=y | 1266 | CONFIG_HID_CHERRY=y |
| 1347 | CONFIG_HID_CHICONY=y | 1267 | CONFIG_HID_CHICONY=y |
| 1348 | CONFIG_HID_CYPRESS=y | 1268 | CONFIG_HID_CYPRESS=y |
| 1349 | # CONFIG_DRAGONRISE_FF is not set | 1269 | # CONFIG_HID_DRAGONRISE is not set |
| 1350 | CONFIG_HID_EZKEY=y | 1270 | CONFIG_HID_EZKEY=y |
| 1351 | # CONFIG_HID_KYE is not set | 1271 | # CONFIG_HID_KYE is not set |
| 1352 | CONFIG_HID_GYRATION=y | 1272 | CONFIG_HID_GYRATION=y |
| @@ -1363,10 +1283,11 @@ CONFIG_HID_PETALYNX=y | |||
| 1363 | CONFIG_HID_SAMSUNG=y | 1283 | CONFIG_HID_SAMSUNG=y |
| 1364 | CONFIG_HID_SONY=y | 1284 | CONFIG_HID_SONY=y |
| 1365 | CONFIG_HID_SUNPLUS=y | 1285 | CONFIG_HID_SUNPLUS=y |
| 1366 | # CONFIG_GREENASIA_FF is not set | 1286 | # CONFIG_HID_GREENASIA is not set |
| 1287 | # CONFIG_HID_SMARTJOYPLUS is not set | ||
| 1367 | # CONFIG_HID_TOPSEED is not set | 1288 | # CONFIG_HID_TOPSEED is not set |
| 1368 | CONFIG_THRUSTMASTER_FF=m | 1289 | # CONFIG_HID_THRUSTMASTER is not set |
| 1369 | CONFIG_ZEROPLUS_FF=m | 1290 | # CONFIG_HID_ZEROPLUS is not set |
| 1370 | CONFIG_USB_SUPPORT=y | 1291 | CONFIG_USB_SUPPORT=y |
| 1371 | CONFIG_USB_ARCH_HAS_HCD=y | 1292 | CONFIG_USB_ARCH_HAS_HCD=y |
| 1372 | CONFIG_USB_ARCH_HAS_OHCI=y | 1293 | CONFIG_USB_ARCH_HAS_OHCI=y |
| @@ -1392,6 +1313,7 @@ CONFIG_USB=y | |||
| 1392 | # USB Host Controller Drivers | 1313 | # USB Host Controller Drivers |
| 1393 | # | 1314 | # |
| 1394 | # CONFIG_USB_C67X00_HCD is not set | 1315 | # CONFIG_USB_C67X00_HCD is not set |
| 1316 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1395 | CONFIG_USB_EHCI_HCD=y | 1317 | CONFIG_USB_EHCI_HCD=y |
| 1396 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set | 1318 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set |
| 1397 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1319 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1401,6 +1323,8 @@ CONFIG_USB_EHCI_HCD=y | |||
| 1401 | # CONFIG_USB_ISP116X_HCD is not set | 1323 | # CONFIG_USB_ISP116X_HCD is not set |
| 1402 | # CONFIG_USB_ISP1760_HCD is not set | 1324 | # CONFIG_USB_ISP1760_HCD is not set |
| 1403 | CONFIG_USB_OHCI_HCD=y | 1325 | CONFIG_USB_OHCI_HCD=y |
| 1326 | # CONFIG_USB_OHCI_HCD_PPC_OF_BE is not set | ||
| 1327 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set | ||
| 1404 | # CONFIG_USB_OHCI_HCD_PPC_OF is not set | 1328 | # CONFIG_USB_OHCI_HCD_PPC_OF is not set |
| 1405 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set | 1329 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set |
| 1406 | # CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set | 1330 | # CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set |
| @@ -1475,7 +1399,6 @@ CONFIG_USB_STORAGE=y | |||
| 1475 | # CONFIG_USB_IOWARRIOR is not set | 1399 | # CONFIG_USB_IOWARRIOR is not set |
| 1476 | # CONFIG_USB_ISIGHTFW is not set | 1400 | # CONFIG_USB_ISIGHTFW is not set |
| 1477 | # CONFIG_USB_VST is not set | 1401 | # CONFIG_USB_VST is not set |
| 1478 | # CONFIG_USB_ATM is not set | ||
| 1479 | # CONFIG_USB_GADGET is not set | 1402 | # CONFIG_USB_GADGET is not set |
| 1480 | 1403 | ||
| 1481 | # | 1404 | # |
| @@ -1521,6 +1444,7 @@ CONFIG_RTC_INTF_DEV=y | |||
| 1521 | # CONFIG_RTC_DRV_S35390A is not set | 1444 | # CONFIG_RTC_DRV_S35390A is not set |
| 1522 | # CONFIG_RTC_DRV_FM3130 is not set | 1445 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1523 | CONFIG_RTC_DRV_RX8581=y | 1446 | CONFIG_RTC_DRV_RX8581=y |
| 1447 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1524 | 1448 | ||
| 1525 | # | 1449 | # |
| 1526 | # SPI RTC drivers | 1450 | # SPI RTC drivers |
| @@ -1548,6 +1472,10 @@ CONFIG_RTC_DRV_RX8581=y | |||
| 1548 | # CONFIG_DMADEVICES is not set | 1472 | # CONFIG_DMADEVICES is not set |
| 1549 | # CONFIG_AUXDISPLAY is not set | 1473 | # CONFIG_AUXDISPLAY is not set |
| 1550 | # CONFIG_UIO is not set | 1474 | # CONFIG_UIO is not set |
| 1475 | |||
| 1476 | # | ||
| 1477 | # TI VLYNQ | ||
| 1478 | # | ||
| 1551 | # CONFIG_STAGING is not set | 1479 | # CONFIG_STAGING is not set |
| 1552 | 1480 | ||
| 1553 | # | 1481 | # |
| @@ -1569,10 +1497,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1569 | # CONFIG_REISERFS_FS is not set | 1497 | # CONFIG_REISERFS_FS is not set |
| 1570 | # CONFIG_JFS_FS is not set | 1498 | # CONFIG_JFS_FS is not set |
| 1571 | CONFIG_FS_POSIX_ACL=y | 1499 | CONFIG_FS_POSIX_ACL=y |
| 1572 | CONFIG_FILE_LOCKING=y | ||
| 1573 | # CONFIG_XFS_FS is not set | 1500 | # CONFIG_XFS_FS is not set |
| 1501 | # CONFIG_GFS2_FS is not set | ||
| 1574 | # CONFIG_OCFS2_FS is not set | 1502 | # CONFIG_OCFS2_FS is not set |
| 1575 | # CONFIG_BTRFS_FS is not set | 1503 | # CONFIG_BTRFS_FS is not set |
| 1504 | CONFIG_FILE_LOCKING=y | ||
| 1505 | CONFIG_FSNOTIFY=y | ||
| 1576 | CONFIG_DNOTIFY=y | 1506 | CONFIG_DNOTIFY=y |
| 1577 | CONFIG_INOTIFY=y | 1507 | CONFIG_INOTIFY=y |
| 1578 | CONFIG_INOTIFY_USER=y | 1508 | CONFIG_INOTIFY_USER=y |
| @@ -1589,8 +1519,11 @@ CONFIG_INOTIFY_USER=y | |||
| 1589 | # | 1519 | # |
| 1590 | # CD-ROM/DVD Filesystems | 1520 | # CD-ROM/DVD Filesystems |
| 1591 | # | 1521 | # |
| 1592 | # CONFIG_ISO9660_FS is not set | 1522 | CONFIG_ISO9660_FS=y |
| 1593 | # CONFIG_UDF_FS is not set | 1523 | CONFIG_JOLIET=y |
| 1524 | CONFIG_ZISOFS=y | ||
| 1525 | CONFIG_UDF_FS=y | ||
| 1526 | CONFIG_UDF_NLS=y | ||
| 1594 | 1527 | ||
| 1595 | # | 1528 | # |
| 1596 | # DOS/FAT/NT Filesystems | 1529 | # DOS/FAT/NT Filesystems |
| @@ -1598,8 +1531,8 @@ CONFIG_INOTIFY_USER=y | |||
| 1598 | CONFIG_FAT_FS=y | 1531 | CONFIG_FAT_FS=y |
| 1599 | CONFIG_MSDOS_FS=y | 1532 | CONFIG_MSDOS_FS=y |
| 1600 | CONFIG_VFAT_FS=y | 1533 | CONFIG_VFAT_FS=y |
| 1601 | CONFIG_FAT_DEFAULT_CODEPAGE=437 | 1534 | CONFIG_FAT_DEFAULT_CODEPAGE=850 |
| 1602 | CONFIG_FAT_DEFAULT_IOCHARSET="iso8859-1" | 1535 | CONFIG_FAT_DEFAULT_IOCHARSET="ascii" |
| 1603 | # CONFIG_NTFS_FS is not set | 1536 | # CONFIG_NTFS_FS is not set |
| 1604 | 1537 | ||
| 1605 | # | 1538 | # |
| @@ -1649,6 +1582,7 @@ CONFIG_NFS_FS=y | |||
| 1649 | CONFIG_NFS_V3=y | 1582 | CONFIG_NFS_V3=y |
| 1650 | # CONFIG_NFS_V3_ACL is not set | 1583 | # CONFIG_NFS_V3_ACL is not set |
| 1651 | CONFIG_NFS_V4=y | 1584 | CONFIG_NFS_V4=y |
| 1585 | # CONFIG_NFS_V4_1 is not set | ||
| 1652 | CONFIG_ROOT_NFS=y | 1586 | CONFIG_ROOT_NFS=y |
| 1653 | # CONFIG_NFSD is not set | 1587 | # CONFIG_NFSD is not set |
| 1654 | CONFIG_LOCKD=y | 1588 | CONFIG_LOCKD=y |
| @@ -1723,13 +1657,13 @@ CONFIG_NLS_UTF8=m | |||
| 1723 | # | 1657 | # |
| 1724 | CONFIG_BITREVERSE=y | 1658 | CONFIG_BITREVERSE=y |
| 1725 | CONFIG_GENERIC_FIND_LAST_BIT=y | 1659 | CONFIG_GENERIC_FIND_LAST_BIT=y |
| 1726 | CONFIG_CRC_CCITT=m | 1660 | CONFIG_CRC_CCITT=y |
| 1727 | # CONFIG_CRC16 is not set | 1661 | # CONFIG_CRC16 is not set |
| 1728 | # CONFIG_CRC_T10DIF is not set | 1662 | CONFIG_CRC_T10DIF=y |
| 1729 | # CONFIG_CRC_ITU_T is not set | 1663 | CONFIG_CRC_ITU_T=y |
| 1730 | CONFIG_CRC32=y | 1664 | CONFIG_CRC32=y |
| 1731 | # CONFIG_CRC7 is not set | 1665 | # CONFIG_CRC7 is not set |
| 1732 | CONFIG_LIBCRC32C=m | 1666 | CONFIG_LIBCRC32C=y |
| 1733 | CONFIG_ZLIB_INFLATE=y | 1667 | CONFIG_ZLIB_INFLATE=y |
| 1734 | CONFIG_ZLIB_DEFLATE=y | 1668 | CONFIG_ZLIB_DEFLATE=y |
| 1735 | CONFIG_DECOMPRESS_GZIP=y | 1669 | CONFIG_DECOMPRESS_GZIP=y |
| @@ -1738,6 +1672,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1738 | CONFIG_HAS_DMA=y | 1672 | CONFIG_HAS_DMA=y |
| 1739 | CONFIG_HAVE_LMB=y | 1673 | CONFIG_HAVE_LMB=y |
| 1740 | CONFIG_NLATTR=y | 1674 | CONFIG_NLATTR=y |
| 1675 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1741 | 1676 | ||
| 1742 | # | 1677 | # |
| 1743 | # Kernel hacking | 1678 | # Kernel hacking |
| @@ -1750,75 +1685,24 @@ CONFIG_MAGIC_SYSRQ=y | |||
| 1750 | # CONFIG_UNUSED_SYMBOLS is not set | 1685 | # CONFIG_UNUSED_SYMBOLS is not set |
| 1751 | # CONFIG_DEBUG_FS is not set | 1686 | # CONFIG_DEBUG_FS is not set |
| 1752 | # CONFIG_HEADERS_CHECK is not set | 1687 | # CONFIG_HEADERS_CHECK is not set |
| 1753 | CONFIG_DEBUG_KERNEL=y | 1688 | # CONFIG_DEBUG_KERNEL is not set |
| 1754 | # CONFIG_DEBUG_SHIRQ is not set | ||
| 1755 | CONFIG_DETECT_SOFTLOCKUP=y | ||
| 1756 | # CONFIG_BOOTPARAM_SOFTLOCKUP_PANIC is not set | ||
| 1757 | CONFIG_BOOTPARAM_SOFTLOCKUP_PANIC_VALUE=0 | ||
| 1758 | CONFIG_DETECT_HUNG_TASK=y | ||
| 1759 | # CONFIG_BOOTPARAM_HUNG_TASK_PANIC is not set | ||
| 1760 | CONFIG_BOOTPARAM_HUNG_TASK_PANIC_VALUE=0 | ||
| 1761 | CONFIG_SCHED_DEBUG=y | ||
| 1762 | # CONFIG_SCHEDSTATS is not set | ||
| 1763 | # CONFIG_TIMER_STATS is not set | ||
| 1764 | # CONFIG_DEBUG_OBJECTS is not set | ||
| 1765 | # CONFIG_DEBUG_SLAB is not set | ||
| 1766 | # CONFIG_DEBUG_RT_MUTEXES is not set | ||
| 1767 | # CONFIG_RT_MUTEX_TESTER is not set | ||
| 1768 | # CONFIG_DEBUG_SPINLOCK is not set | ||
| 1769 | # CONFIG_DEBUG_MUTEXES is not set | ||
| 1770 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | ||
| 1771 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | ||
| 1772 | # CONFIG_DEBUG_KOBJECT is not set | ||
| 1773 | # CONFIG_DEBUG_BUGVERBOSE is not set | 1689 | # CONFIG_DEBUG_BUGVERBOSE is not set |
| 1774 | CONFIG_DEBUG_INFO=y | ||
| 1775 | # CONFIG_DEBUG_VM is not set | ||
| 1776 | # CONFIG_DEBUG_WRITECOUNT is not set | ||
| 1777 | # CONFIG_DEBUG_MEMORY_INIT is not set | 1690 | # CONFIG_DEBUG_MEMORY_INIT is not set |
| 1778 | # CONFIG_DEBUG_LIST is not set | ||
| 1779 | # CONFIG_DEBUG_SG is not set | ||
| 1780 | # CONFIG_DEBUG_NOTIFIERS is not set | ||
| 1781 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1782 | # CONFIG_RCU_TORTURE_TEST is not set | ||
| 1783 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1691 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1784 | # CONFIG_BACKTRACE_SELF_TEST is not set | ||
| 1785 | # CONFIG_DEBUG_BLOCK_EXT_DEVT is not set | ||
| 1786 | # CONFIG_FAULT_INJECTION is not set | ||
| 1787 | # CONFIG_LATENCYTOP is not set | 1692 | # CONFIG_LATENCYTOP is not set |
| 1788 | CONFIG_SYSCTL_SYSCALL_CHECK=y | 1693 | CONFIG_SYSCTL_SYSCALL_CHECK=y |
| 1789 | # CONFIG_DEBUG_PAGEALLOC is not set | ||
| 1790 | CONFIG_HAVE_FUNCTION_TRACER=y | 1694 | CONFIG_HAVE_FUNCTION_TRACER=y |
| 1791 | CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | 1695 | CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y |
| 1792 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1696 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1793 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1697 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1794 | CONFIG_TRACING_SUPPORT=y | 1698 | CONFIG_TRACING_SUPPORT=y |
| 1795 | 1699 | # CONFIG_FTRACE is not set | |
| 1796 | # | ||
| 1797 | # Tracers | ||
| 1798 | # | ||
| 1799 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1800 | # CONFIG_PREEMPT_TRACER is not set | ||
| 1801 | # CONFIG_SCHED_TRACER is not set | ||
| 1802 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1803 | # CONFIG_EVENT_TRACER is not set | ||
| 1804 | # CONFIG_BOOT_TRACER is not set | ||
| 1805 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1806 | # CONFIG_STACK_TRACER is not set | ||
| 1807 | # CONFIG_KMEMTRACE is not set | ||
| 1808 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1809 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1810 | # CONFIG_SAMPLES is not set | 1700 | # CONFIG_SAMPLES is not set |
| 1811 | CONFIG_HAVE_ARCH_KGDB=y | 1701 | CONFIG_HAVE_ARCH_KGDB=y |
| 1812 | # CONFIG_KGDB is not set | 1702 | # CONFIG_PPC_DISABLE_WERROR is not set |
| 1703 | CONFIG_PPC_WERROR=y | ||
| 1813 | CONFIG_PRINT_STACK_DEPTH=64 | 1704 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1814 | # CONFIG_DEBUG_STACKOVERFLOW is not set | ||
| 1815 | # CONFIG_DEBUG_STACK_USAGE is not set | ||
| 1816 | # CONFIG_CODE_PATCHING_SELFTEST is not set | ||
| 1817 | # CONFIG_FTR_FIXUP_SELFTEST is not set | ||
| 1818 | # CONFIG_MSI_BITMAP_SELFTEST is not set | ||
| 1819 | # CONFIG_XMON is not set | ||
| 1820 | # CONFIG_IRQSTACKS is not set | 1705 | # CONFIG_IRQSTACKS is not set |
| 1821 | # CONFIG_BDI_SWITCH is not set | ||
| 1822 | # CONFIG_BOOTX_TEXT is not set | 1706 | # CONFIG_BOOTX_TEXT is not set |
| 1823 | # CONFIG_PPC_EARLY_DEBUG is not set | 1707 | # CONFIG_PPC_EARLY_DEBUG is not set |
| 1824 | 1708 | ||
| @@ -1826,15 +1710,9 @@ CONFIG_PRINT_STACK_DEPTH=64 | |||
| 1826 | # Security options | 1710 | # Security options |
| 1827 | # | 1711 | # |
| 1828 | # CONFIG_KEYS is not set | 1712 | # CONFIG_KEYS is not set |
| 1829 | CONFIG_SECURITY=y | 1713 | # CONFIG_SECURITY is not set |
| 1830 | # CONFIG_SECURITYFS is not set | 1714 | # CONFIG_SECURITYFS is not set |
| 1831 | CONFIG_SECURITY_NETWORK=y | ||
| 1832 | # CONFIG_SECURITY_NETWORK_XFRM is not set | ||
| 1833 | # CONFIG_SECURITY_PATH is not set | ||
| 1834 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set | 1715 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set |
| 1835 | # CONFIG_SECURITY_ROOTPLUG is not set | ||
| 1836 | CONFIG_SECURITY_DEFAULT_MMAP_MIN_ADDR=0 | ||
| 1837 | # CONFIG_SECURITY_TOMOYO is not set | ||
| 1838 | CONFIG_CRYPTO=y | 1716 | CONFIG_CRYPTO=y |
| 1839 | 1717 | ||
| 1840 | # | 1718 | # |
| @@ -1854,11 +1732,11 @@ CONFIG_CRYPTO_PCOMP=y | |||
| 1854 | CONFIG_CRYPTO_MANAGER=y | 1732 | CONFIG_CRYPTO_MANAGER=y |
| 1855 | CONFIG_CRYPTO_MANAGER2=y | 1733 | CONFIG_CRYPTO_MANAGER2=y |
| 1856 | # CONFIG_CRYPTO_GF128MUL is not set | 1734 | # CONFIG_CRYPTO_GF128MUL is not set |
| 1857 | CONFIG_CRYPTO_NULL=m | 1735 | # CONFIG_CRYPTO_NULL is not set |
| 1858 | CONFIG_CRYPTO_WORKQUEUE=y | 1736 | CONFIG_CRYPTO_WORKQUEUE=y |
| 1859 | # CONFIG_CRYPTO_CRYPTD is not set | 1737 | # CONFIG_CRYPTO_CRYPTD is not set |
| 1860 | CONFIG_CRYPTO_AUTHENC=m | 1738 | CONFIG_CRYPTO_AUTHENC=m |
| 1861 | CONFIG_CRYPTO_TEST=m | 1739 | # CONFIG_CRYPTO_TEST is not set |
| 1862 | 1740 | ||
| 1863 | # | 1741 | # |
| 1864 | # Authenticated Encryption with Associated Data | 1742 | # Authenticated Encryption with Associated Data |
| @@ -1873,53 +1751,52 @@ CONFIG_CRYPTO_TEST=m | |||
| 1873 | CONFIG_CRYPTO_CBC=y | 1751 | CONFIG_CRYPTO_CBC=y |
| 1874 | # CONFIG_CRYPTO_CTR is not set | 1752 | # CONFIG_CRYPTO_CTR is not set |
| 1875 | # CONFIG_CRYPTO_CTS is not set | 1753 | # CONFIG_CRYPTO_CTS is not set |
| 1876 | CONFIG_CRYPTO_ECB=m | 1754 | # CONFIG_CRYPTO_ECB is not set |
| 1877 | # CONFIG_CRYPTO_LRW is not set | 1755 | # CONFIG_CRYPTO_LRW is not set |
| 1878 | CONFIG_CRYPTO_PCBC=m | 1756 | # CONFIG_CRYPTO_PCBC is not set |
| 1879 | # CONFIG_CRYPTO_XTS is not set | 1757 | # CONFIG_CRYPTO_XTS is not set |
| 1880 | 1758 | ||
| 1881 | # | 1759 | # |
| 1882 | # Hash modes | 1760 | # Hash modes |
| 1883 | # | 1761 | # |
| 1884 | CONFIG_CRYPTO_HMAC=y | 1762 | CONFIG_CRYPTO_HMAC=m |
| 1885 | # CONFIG_CRYPTO_XCBC is not set | 1763 | # CONFIG_CRYPTO_XCBC is not set |
| 1886 | 1764 | ||
| 1887 | # | 1765 | # |
| 1888 | # Digest | 1766 | # Digest |
| 1889 | # | 1767 | # |
| 1890 | CONFIG_CRYPTO_CRC32C=m | 1768 | CONFIG_CRYPTO_CRC32C=y |
| 1891 | CONFIG_CRYPTO_MD4=m | 1769 | # CONFIG_CRYPTO_MD4 is not set |
| 1892 | CONFIG_CRYPTO_MD5=y | 1770 | CONFIG_CRYPTO_MD5=y |
| 1893 | CONFIG_CRYPTO_MICHAEL_MIC=m | 1771 | # CONFIG_CRYPTO_MICHAEL_MIC is not set |
| 1894 | # CONFIG_CRYPTO_RMD128 is not set | 1772 | # CONFIG_CRYPTO_RMD128 is not set |
| 1895 | # CONFIG_CRYPTO_RMD160 is not set | 1773 | # CONFIG_CRYPTO_RMD160 is not set |
| 1896 | # CONFIG_CRYPTO_RMD256 is not set | 1774 | # CONFIG_CRYPTO_RMD256 is not set |
| 1897 | # CONFIG_CRYPTO_RMD320 is not set | 1775 | # CONFIG_CRYPTO_RMD320 is not set |
| 1898 | CONFIG_CRYPTO_SHA1=m | 1776 | CONFIG_CRYPTO_SHA1=m |
| 1899 | CONFIG_CRYPTO_SHA256=m | 1777 | # CONFIG_CRYPTO_SHA256 is not set |
| 1900 | CONFIG_CRYPTO_SHA512=m | 1778 | # CONFIG_CRYPTO_SHA512 is not set |
| 1901 | # CONFIG_CRYPTO_TGR192 is not set | 1779 | # CONFIG_CRYPTO_TGR192 is not set |
| 1902 | CONFIG_CRYPTO_WP512=m | 1780 | # CONFIG_CRYPTO_WP512 is not set |
| 1903 | 1781 | ||
| 1904 | # | 1782 | # |
| 1905 | # Ciphers | 1783 | # Ciphers |
| 1906 | # | 1784 | # |
| 1907 | CONFIG_CRYPTO_AES=m | 1785 | # CONFIG_CRYPTO_AES is not set |
| 1908 | CONFIG_CRYPTO_ANUBIS=m | 1786 | # CONFIG_CRYPTO_ANUBIS is not set |
| 1909 | CONFIG_CRYPTO_ARC4=m | 1787 | # CONFIG_CRYPTO_ARC4 is not set |
| 1910 | CONFIG_CRYPTO_BLOWFISH=m | 1788 | # CONFIG_CRYPTO_BLOWFISH is not set |
| 1911 | # CONFIG_CRYPTO_CAMELLIA is not set | 1789 | # CONFIG_CRYPTO_CAMELLIA is not set |
| 1912 | CONFIG_CRYPTO_CAST5=m | 1790 | # CONFIG_CRYPTO_CAST5 is not set |
| 1913 | CONFIG_CRYPTO_CAST6=m | 1791 | # CONFIG_CRYPTO_CAST6 is not set |
| 1914 | CONFIG_CRYPTO_DES=y | 1792 | CONFIG_CRYPTO_DES=y |
| 1915 | # CONFIG_CRYPTO_FCRYPT is not set | 1793 | # CONFIG_CRYPTO_FCRYPT is not set |
| 1916 | CONFIG_CRYPTO_KHAZAD=m | 1794 | # CONFIG_CRYPTO_KHAZAD is not set |
| 1917 | # CONFIG_CRYPTO_SALSA20 is not set | 1795 | # CONFIG_CRYPTO_SALSA20 is not set |
| 1918 | # CONFIG_CRYPTO_SEED is not set | 1796 | # CONFIG_CRYPTO_SEED is not set |
| 1919 | CONFIG_CRYPTO_SERPENT=m | 1797 | # CONFIG_CRYPTO_SERPENT is not set |
| 1920 | CONFIG_CRYPTO_TEA=m | 1798 | # CONFIG_CRYPTO_TEA is not set |
| 1921 | CONFIG_CRYPTO_TWOFISH=m | 1799 | # CONFIG_CRYPTO_TWOFISH is not set |
| 1922 | CONFIG_CRYPTO_TWOFISH_COMMON=m | ||
| 1923 | 1800 | ||
| 1924 | # | 1801 | # |
| 1925 | # Compression | 1802 | # Compression |
diff --git a/arch/powerpc/configs/86xx/gef_sbc310_defconfig b/arch/powerpc/configs/86xx/gef_sbc310_defconfig index a66910e63345..cd338d493bed 100644 --- a/arch/powerpc/configs/86xx/gef_sbc310_defconfig +++ b/arch/powerpc/configs/86xx/gef_sbc310_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:29 2009 | 4 | # Wed Jul 29 23:32:29 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_PHYS_64BIT is not set | 20 | # CONFIG_PHYS_64BIT is not set |
| 20 | CONFIG_ALTIVEC=y | 21 | CONFIG_ALTIVEC=y |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | CONFIG_SMP=y | 26 | CONFIG_SMP=y |
| 25 | CONFIG_NR_CPUS=2 | 27 | CONFIG_NR_CPUS=2 |
| 26 | CONFIG_PPC32=y | 28 | CONFIG_PPC32=y |
| @@ -32,16 +34,17 @@ CONFIG_GENERIC_TIME=y | |||
| 32 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 33 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 34 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 35 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 36 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 37 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 38 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 39 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 40 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 41 | CONFIG_GENERIC_LOCKBREAK=y | 45 | CONFIG_GENERIC_LOCKBREAK=y |
| 42 | CONFIG_ARCH_HAS_ILOG2_U32=y | 46 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 43 | CONFIG_GENERIC_HWEIGHT=y | 47 | CONFIG_GENERIC_HWEIGHT=y |
| 44 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 45 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 48 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 46 | CONFIG_GENERIC_GPIO=y | 49 | CONFIG_GENERIC_GPIO=y |
| 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 50 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -56,11 +59,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 56 | CONFIG_GENERIC_TBSYNC=y | 59 | CONFIG_GENERIC_TBSYNC=y |
| 57 | CONFIG_AUDIT_ARCH=y | 60 | CONFIG_AUDIT_ARCH=y |
| 58 | CONFIG_GENERIC_BUG=y | 61 | CONFIG_GENERIC_BUG=y |
| 62 | CONFIG_DTC=y | ||
| 59 | CONFIG_DEFAULT_UIMAGE=y | 63 | CONFIG_DEFAULT_UIMAGE=y |
| 60 | # CONFIG_PPC_DCR_NATIVE is not set | 64 | # CONFIG_PPC_DCR_NATIVE is not set |
| 61 | # CONFIG_PPC_DCR_MMIO is not set | 65 | # CONFIG_PPC_DCR_MMIO is not set |
| 62 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 66 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 63 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 67 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 68 | CONFIG_CONSTRUCTORS=y | ||
| 64 | 69 | ||
| 65 | # | 70 | # |
| 66 | # General setup | 71 | # General setup |
| @@ -91,7 +96,11 @@ CONFIG_CLASSIC_RCU=y | |||
| 91 | CONFIG_IKCONFIG=y | 96 | CONFIG_IKCONFIG=y |
| 92 | CONFIG_IKCONFIG_PROC=y | 97 | CONFIG_IKCONFIG_PROC=y |
| 93 | CONFIG_LOG_BUF_SHIFT=14 | 98 | CONFIG_LOG_BUF_SHIFT=14 |
| 94 | # CONFIG_GROUP_SCHED is not set | 99 | CONFIG_GROUP_SCHED=y |
| 100 | CONFIG_FAIR_GROUP_SCHED=y | ||
| 101 | # CONFIG_RT_GROUP_SCHED is not set | ||
| 102 | CONFIG_USER_SCHED=y | ||
| 103 | # CONFIG_CGROUP_SCHED is not set | ||
| 95 | # CONFIG_CGROUPS is not set | 104 | # CONFIG_CGROUPS is not set |
| 96 | CONFIG_SYSFS_DEPRECATED=y | 105 | CONFIG_SYSFS_DEPRECATED=y |
| 97 | CONFIG_SYSFS_DEPRECATED_V2=y | 106 | CONFIG_SYSFS_DEPRECATED_V2=y |
| @@ -109,7 +118,6 @@ CONFIG_EMBEDDED=y | |||
| 109 | CONFIG_SYSCTL_SYSCALL=y | 118 | CONFIG_SYSCTL_SYSCALL=y |
| 110 | CONFIG_KALLSYMS=y | 119 | CONFIG_KALLSYMS=y |
| 111 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 120 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 112 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 113 | CONFIG_HOTPLUG=y | 121 | CONFIG_HOTPLUG=y |
| 114 | CONFIG_PRINTK=y | 122 | CONFIG_PRINTK=y |
| 115 | CONFIG_BUG=y | 123 | CONFIG_BUG=y |
| @@ -122,8 +130,15 @@ CONFIG_TIMERFD=y | |||
| 122 | CONFIG_EVENTFD=y | 130 | CONFIG_EVENTFD=y |
| 123 | CONFIG_SHMEM=y | 131 | CONFIG_SHMEM=y |
| 124 | CONFIG_AIO=y | 132 | CONFIG_AIO=y |
| 133 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 134 | |||
| 135 | # | ||
| 136 | # Performance Counters | ||
| 137 | # | ||
| 138 | # CONFIG_PERF_COUNTERS is not set | ||
| 125 | CONFIG_VM_EVENT_COUNTERS=y | 139 | CONFIG_VM_EVENT_COUNTERS=y |
| 126 | CONFIG_PCI_QUIRKS=y | 140 | CONFIG_PCI_QUIRKS=y |
| 141 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 127 | CONFIG_COMPAT_BRK=y | 142 | CONFIG_COMPAT_BRK=y |
| 128 | CONFIG_SLAB=y | 143 | CONFIG_SLAB=y |
| 129 | # CONFIG_SLUB is not set | 144 | # CONFIG_SLUB is not set |
| @@ -138,6 +153,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 138 | CONFIG_HAVE_KRETPROBES=y | 153 | CONFIG_HAVE_KRETPROBES=y |
| 139 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 154 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 140 | CONFIG_USE_GENERIC_SMP_HELPERS=y | 155 | CONFIG_USE_GENERIC_SMP_HELPERS=y |
| 156 | |||
| 157 | # | ||
| 158 | # GCOV-based kernel profiling | ||
| 159 | # | ||
| 141 | # CONFIG_SLOW_WORK is not set | 160 | # CONFIG_SLOW_WORK is not set |
| 142 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 161 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 143 | CONFIG_SLABINFO=y | 162 | CONFIG_SLABINFO=y |
| @@ -151,7 +170,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 151 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 170 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 152 | CONFIG_STOP_MACHINE=y | 171 | CONFIG_STOP_MACHINE=y |
| 153 | CONFIG_BLOCK=y | 172 | CONFIG_BLOCK=y |
| 154 | # CONFIG_LBD is not set | 173 | CONFIG_LBDAF=y |
| 155 | # CONFIG_BLK_DEV_BSG is not set | 174 | # CONFIG_BLK_DEV_BSG is not set |
| 156 | # CONFIG_BLK_DEV_INTEGRITY is not set | 175 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 157 | 176 | ||
| @@ -168,7 +187,6 @@ CONFIG_DEFAULT_CFQ=y | |||
| 168 | # CONFIG_DEFAULT_NOOP is not set | 187 | # CONFIG_DEFAULT_NOOP is not set |
| 169 | CONFIG_DEFAULT_IOSCHED="cfq" | 188 | CONFIG_DEFAULT_IOSCHED="cfq" |
| 170 | # CONFIG_FREEZER is not set | 189 | # CONFIG_FREEZER is not set |
| 171 | CONFIG_PPC_MSI_BITMAP=y | ||
| 172 | 190 | ||
| 173 | # | 191 | # |
| 174 | # Platform support | 192 | # Platform support |
| @@ -212,7 +230,7 @@ CONFIG_MPIC=y | |||
| 212 | # | 230 | # |
| 213 | # Kernel options | 231 | # Kernel options |
| 214 | # | 232 | # |
| 215 | # CONFIG_HIGHMEM is not set | 233 | CONFIG_HIGHMEM=y |
| 216 | CONFIG_TICK_ONESHOT=y | 234 | CONFIG_TICK_ONESHOT=y |
| 217 | # CONFIG_NO_HZ is not set | 235 | # CONFIG_NO_HZ is not set |
| 218 | CONFIG_HIGH_RES_TIMERS=y | 236 | CONFIG_HIGH_RES_TIMERS=y |
| @@ -231,6 +249,7 @@ CONFIG_BINFMT_ELF=y | |||
| 231 | # CONFIG_HAVE_AOUT is not set | 249 | # CONFIG_HAVE_AOUT is not set |
| 232 | CONFIG_BINFMT_MISC=y | 250 | CONFIG_BINFMT_MISC=y |
| 233 | # CONFIG_IOMMU_HELPER is not set | 251 | # CONFIG_IOMMU_HELPER is not set |
| 252 | # CONFIG_SWIOTLB is not set | ||
| 234 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 253 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 235 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 254 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 236 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 255 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -252,9 +271,9 @@ CONFIG_MIGRATION=y | |||
| 252 | CONFIG_ZONE_DMA_FLAG=1 | 271 | CONFIG_ZONE_DMA_FLAG=1 |
| 253 | CONFIG_BOUNCE=y | 272 | CONFIG_BOUNCE=y |
| 254 | CONFIG_VIRT_TO_BUS=y | 273 | CONFIG_VIRT_TO_BUS=y |
| 255 | CONFIG_UNEVICTABLE_LRU=y | ||
| 256 | CONFIG_HAVE_MLOCK=y | 274 | CONFIG_HAVE_MLOCK=y |
| 257 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 275 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 276 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 258 | CONFIG_PPC_4K_PAGES=y | 277 | CONFIG_PPC_4K_PAGES=y |
| 259 | # CONFIG_PPC_16K_PAGES is not set | 278 | # CONFIG_PPC_16K_PAGES is not set |
| 260 | # CONFIG_PPC_64K_PAGES is not set | 279 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -281,13 +300,32 @@ CONFIG_PCI_DOMAINS=y | |||
| 281 | CONFIG_PCI_SYSCALL=y | 300 | CONFIG_PCI_SYSCALL=y |
| 282 | CONFIG_PCIEPORTBUS=y | 301 | CONFIG_PCIEPORTBUS=y |
| 283 | CONFIG_PCIEAER=y | 302 | CONFIG_PCIEAER=y |
| 303 | # CONFIG_PCIE_ECRC is not set | ||
| 304 | # CONFIG_PCIEAER_INJECT is not set | ||
| 284 | # CONFIG_PCIEASPM is not set | 305 | # CONFIG_PCIEASPM is not set |
| 285 | CONFIG_ARCH_SUPPORTS_MSI=y | 306 | CONFIG_ARCH_SUPPORTS_MSI=y |
| 286 | CONFIG_PCI_MSI=y | 307 | # CONFIG_PCI_MSI is not set |
| 287 | # CONFIG_PCI_LEGACY is not set | 308 | # CONFIG_PCI_LEGACY is not set |
| 288 | # CONFIG_PCI_STUB is not set | 309 | # CONFIG_PCI_STUB is not set |
| 289 | # CONFIG_PCI_IOV is not set | 310 | # CONFIG_PCI_IOV is not set |
| 290 | # CONFIG_PCCARD is not set | 311 | CONFIG_PCCARD=y |
| 312 | # CONFIG_PCMCIA_DEBUG is not set | ||
| 313 | CONFIG_PCMCIA=y | ||
| 314 | # CONFIG_PCMCIA_LOAD_CIS is not set | ||
| 315 | # CONFIG_PCMCIA_IOCTL is not set | ||
| 316 | # CONFIG_CARDBUS is not set | ||
| 317 | |||
| 318 | # | ||
| 319 | # PC-card bridges | ||
| 320 | # | ||
| 321 | CONFIG_YENTA=y | ||
| 322 | # CONFIG_YENTA_O2 is not set | ||
| 323 | # CONFIG_YENTA_RICOH is not set | ||
| 324 | CONFIG_YENTA_TI=y | ||
| 325 | # CONFIG_YENTA_TOSHIBA is not set | ||
| 326 | # CONFIG_PD6729 is not set | ||
| 327 | # CONFIG_I82092 is not set | ||
| 328 | CONFIG_PCCARD_NONSTATIC=y | ||
| 291 | # CONFIG_HOTPLUG_PCI is not set | 329 | # CONFIG_HOTPLUG_PCI is not set |
| 292 | # CONFIG_HAS_RAPIDIO is not set | 330 | # CONFIG_HAS_RAPIDIO is not set |
| 293 | 331 | ||
| @@ -393,6 +431,7 @@ CONFIG_IPV6_TUNNEL=m | |||
| 393 | # CONFIG_ECONET is not set | 431 | # CONFIG_ECONET is not set |
| 394 | # CONFIG_WAN_ROUTER is not set | 432 | # CONFIG_WAN_ROUTER is not set |
| 395 | # CONFIG_PHONET is not set | 433 | # CONFIG_PHONET is not set |
| 434 | # CONFIG_IEEE802154 is not set | ||
| 396 | # CONFIG_NET_SCHED is not set | 435 | # CONFIG_NET_SCHED is not set |
| 397 | # CONFIG_DCB is not set | 436 | # CONFIG_DCB is not set |
| 398 | 437 | ||
| @@ -421,7 +460,9 @@ CONFIG_FIB_RULES=y | |||
| 421 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" | 460 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" |
| 422 | CONFIG_STANDALONE=y | 461 | CONFIG_STANDALONE=y |
| 423 | CONFIG_PREVENT_FIRMWARE_BUILD=y | 462 | CONFIG_PREVENT_FIRMWARE_BUILD=y |
| 424 | # CONFIG_FW_LOADER is not set | 463 | CONFIG_FW_LOADER=y |
| 464 | CONFIG_FIRMWARE_IN_KERNEL=y | ||
| 465 | CONFIG_EXTRA_FIRMWARE="" | ||
| 425 | # CONFIG_SYS_HYPERVISOR is not set | 466 | # CONFIG_SYS_HYPERVISOR is not set |
| 426 | # CONFIG_CONNECTOR is not set | 467 | # CONFIG_CONNECTOR is not set |
| 427 | CONFIG_MTD=y | 468 | CONFIG_MTD=y |
| @@ -511,6 +552,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 511 | CONFIG_OF_DEVICE=y | 552 | CONFIG_OF_DEVICE=y |
| 512 | CONFIG_OF_GPIO=y | 553 | CONFIG_OF_GPIO=y |
| 513 | CONFIG_OF_I2C=y | 554 | CONFIG_OF_I2C=y |
| 555 | CONFIG_OF_MDIO=y | ||
| 514 | # CONFIG_PARPORT is not set | 556 | # CONFIG_PARPORT is not set |
| 515 | CONFIG_BLK_DEV=y | 557 | CONFIG_BLK_DEV=y |
| 516 | # CONFIG_BLK_DEV_FD is not set | 558 | # CONFIG_BLK_DEV_FD is not set |
| @@ -546,9 +588,60 @@ CONFIG_MISC_DEVICES=y | |||
| 546 | # | 588 | # |
| 547 | # CONFIG_EEPROM_AT24 is not set | 589 | # CONFIG_EEPROM_AT24 is not set |
| 548 | # CONFIG_EEPROM_LEGACY is not set | 590 | # CONFIG_EEPROM_LEGACY is not set |
| 591 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 549 | # CONFIG_EEPROM_93CX6 is not set | 592 | # CONFIG_EEPROM_93CX6 is not set |
| 593 | # CONFIG_CB710_CORE is not set | ||
| 550 | CONFIG_HAVE_IDE=y | 594 | CONFIG_HAVE_IDE=y |
| 551 | # CONFIG_IDE is not set | 595 | CONFIG_IDE=y |
| 596 | |||
| 597 | # | ||
| 598 | # Please see Documentation/ide/ide.txt for help/info on IDE drives | ||
| 599 | # | ||
| 600 | # CONFIG_BLK_DEV_IDE_SATA is not set | ||
| 601 | CONFIG_IDE_GD=y | ||
| 602 | CONFIG_IDE_GD_ATA=y | ||
| 603 | # CONFIG_IDE_GD_ATAPI is not set | ||
| 604 | CONFIG_BLK_DEV_IDECS=y | ||
| 605 | # CONFIG_BLK_DEV_IDECD is not set | ||
| 606 | # CONFIG_BLK_DEV_IDETAPE is not set | ||
| 607 | # CONFIG_IDE_TASK_IOCTL is not set | ||
| 608 | CONFIG_IDE_PROC_FS=y | ||
| 609 | |||
| 610 | # | ||
| 611 | # IDE chipset support/bugfixes | ||
| 612 | # | ||
| 613 | # CONFIG_BLK_DEV_PLATFORM is not set | ||
| 614 | |||
| 615 | # | ||
| 616 | # PCI IDE chipsets support | ||
| 617 | # | ||
| 618 | # CONFIG_BLK_DEV_GENERIC is not set | ||
| 619 | # CONFIG_BLK_DEV_OPTI621 is not set | ||
| 620 | # CONFIG_BLK_DEV_AEC62XX is not set | ||
| 621 | # CONFIG_BLK_DEV_ALI15X3 is not set | ||
| 622 | # CONFIG_BLK_DEV_AMD74XX is not set | ||
| 623 | # CONFIG_BLK_DEV_CMD64X is not set | ||
| 624 | # CONFIG_BLK_DEV_TRIFLEX is not set | ||
| 625 | # CONFIG_BLK_DEV_CS5520 is not set | ||
| 626 | # CONFIG_BLK_DEV_CS5530 is not set | ||
| 627 | # CONFIG_BLK_DEV_HPT366 is not set | ||
| 628 | # CONFIG_BLK_DEV_JMICRON is not set | ||
| 629 | # CONFIG_BLK_DEV_SC1200 is not set | ||
| 630 | # CONFIG_BLK_DEV_PIIX is not set | ||
| 631 | # CONFIG_BLK_DEV_IT8172 is not set | ||
| 632 | # CONFIG_BLK_DEV_IT8213 is not set | ||
| 633 | # CONFIG_BLK_DEV_IT821X is not set | ||
| 634 | # CONFIG_BLK_DEV_NS87415 is not set | ||
| 635 | # CONFIG_BLK_DEV_PDC202XX_OLD is not set | ||
| 636 | # CONFIG_BLK_DEV_PDC202XX_NEW is not set | ||
| 637 | # CONFIG_BLK_DEV_SVWKS is not set | ||
| 638 | # CONFIG_BLK_DEV_SIIMAGE is not set | ||
| 639 | # CONFIG_BLK_DEV_SL82C105 is not set | ||
| 640 | # CONFIG_BLK_DEV_SLC90E66 is not set | ||
| 641 | # CONFIG_BLK_DEV_TRM290 is not set | ||
| 642 | # CONFIG_BLK_DEV_VIA82CXXX is not set | ||
| 643 | # CONFIG_BLK_DEV_TC86C001 is not set | ||
| 644 | # CONFIG_BLK_DEV_IDEDMA is not set | ||
| 552 | 645 | ||
| 553 | # | 646 | # |
| 554 | # SCSI device support | 647 | # SCSI device support |
| @@ -570,10 +663,6 @@ CONFIG_BLK_DEV_SR=y | |||
| 570 | # CONFIG_BLK_DEV_SR_VENDOR is not set | 663 | # CONFIG_BLK_DEV_SR_VENDOR is not set |
| 571 | # CONFIG_CHR_DEV_SG is not set | 664 | # CONFIG_CHR_DEV_SG is not set |
| 572 | # CONFIG_CHR_DEV_SCH is not set | 665 | # CONFIG_CHR_DEV_SCH is not set |
| 573 | |||
| 574 | # | ||
| 575 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 576 | # | ||
| 577 | # CONFIG_SCSI_MULTI_LUN is not set | 666 | # CONFIG_SCSI_MULTI_LUN is not set |
| 578 | # CONFIG_SCSI_CONSTANTS is not set | 667 | # CONFIG_SCSI_CONSTANTS is not set |
| 579 | # CONFIG_SCSI_LOGGING is not set | 668 | # CONFIG_SCSI_LOGGING is not set |
| @@ -590,6 +679,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 590 | # CONFIG_SCSI_SRP_ATTRS is not set | 679 | # CONFIG_SCSI_SRP_ATTRS is not set |
| 591 | CONFIG_SCSI_LOWLEVEL=y | 680 | CONFIG_SCSI_LOWLEVEL=y |
| 592 | # CONFIG_ISCSI_TCP is not set | 681 | # CONFIG_ISCSI_TCP is not set |
| 682 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 593 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 683 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 594 | # CONFIG_SCSI_3W_9XXX is not set | 684 | # CONFIG_SCSI_3W_9XXX is not set |
| 595 | # CONFIG_SCSI_ACARD is not set | 685 | # CONFIG_SCSI_ACARD is not set |
| @@ -598,6 +688,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 598 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 688 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 599 | # CONFIG_SCSI_AIC79XX is not set | 689 | # CONFIG_SCSI_AIC79XX is not set |
| 600 | # CONFIG_SCSI_AIC94XX is not set | 690 | # CONFIG_SCSI_AIC94XX is not set |
| 691 | # CONFIG_SCSI_MVSAS is not set | ||
| 601 | # CONFIG_SCSI_DPT_I2O is not set | 692 | # CONFIG_SCSI_DPT_I2O is not set |
| 602 | # CONFIG_SCSI_ADVANSYS is not set | 693 | # CONFIG_SCSI_ADVANSYS is not set |
| 603 | # CONFIG_SCSI_ARCMSR is not set | 694 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -617,7 +708,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 617 | # CONFIG_SCSI_IPS is not set | 708 | # CONFIG_SCSI_IPS is not set |
| 618 | # CONFIG_SCSI_INITIO is not set | 709 | # CONFIG_SCSI_INITIO is not set |
| 619 | # CONFIG_SCSI_INIA100 is not set | 710 | # CONFIG_SCSI_INIA100 is not set |
| 620 | # CONFIG_SCSI_MVSAS is not set | ||
| 621 | # CONFIG_SCSI_STEX is not set | 711 | # CONFIG_SCSI_STEX is not set |
| 622 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 712 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 623 | # CONFIG_SCSI_IPR is not set | 713 | # CONFIG_SCSI_IPR is not set |
| @@ -630,6 +720,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 630 | # CONFIG_SCSI_NSP32 is not set | 720 | # CONFIG_SCSI_NSP32 is not set |
| 631 | # CONFIG_SCSI_DEBUG is not set | 721 | # CONFIG_SCSI_DEBUG is not set |
| 632 | # CONFIG_SCSI_SRP is not set | 722 | # CONFIG_SCSI_SRP is not set |
| 723 | # CONFIG_SCSI_LOWLEVEL_PCMCIA is not set | ||
| 633 | # CONFIG_SCSI_DH is not set | 724 | # CONFIG_SCSI_DH is not set |
| 634 | # CONFIG_SCSI_OSD_INITIATOR is not set | 725 | # CONFIG_SCSI_OSD_INITIATOR is not set |
| 635 | CONFIG_ATA=y | 726 | CONFIG_ATA=y |
| @@ -647,14 +738,17 @@ CONFIG_SATA_SIL24=y | |||
| 647 | # | 738 | # |
| 648 | 739 | ||
| 649 | # | 740 | # |
| 650 | # Enable only one of the two stacks, unless you know what you are doing | 741 | # You can enable one or both FireWire driver stacks. |
| 742 | # | ||
| 743 | |||
| 744 | # | ||
| 745 | # See the help texts for more information. | ||
| 651 | # | 746 | # |
| 652 | # CONFIG_FIREWIRE is not set | 747 | # CONFIG_FIREWIRE is not set |
| 653 | # CONFIG_IEEE1394 is not set | 748 | # CONFIG_IEEE1394 is not set |
| 654 | # CONFIG_I2O is not set | 749 | # CONFIG_I2O is not set |
| 655 | # CONFIG_MACINTOSH_DRIVERS is not set | 750 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 656 | CONFIG_NETDEVICES=y | 751 | CONFIG_NETDEVICES=y |
| 657 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 658 | CONFIG_DUMMY=m | 752 | CONFIG_DUMMY=m |
| 659 | CONFIG_BONDING=m | 753 | CONFIG_BONDING=m |
| 660 | # CONFIG_MACVLAN is not set | 754 | # CONFIG_MACVLAN is not set |
| @@ -701,6 +795,7 @@ CONFIG_MII=y | |||
| 701 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 795 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 702 | # CONFIG_NET_PCI is not set | 796 | # CONFIG_NET_PCI is not set |
| 703 | # CONFIG_B44 is not set | 797 | # CONFIG_B44 is not set |
| 798 | # CONFIG_KS8842 is not set | ||
| 704 | # CONFIG_ATL2 is not set | 799 | # CONFIG_ATL2 is not set |
| 705 | CONFIG_NETDEV_1000=y | 800 | CONFIG_NETDEV_1000=y |
| 706 | # CONFIG_ACENIC is not set | 801 | # CONFIG_ACENIC is not set |
| @@ -720,8 +815,10 @@ CONFIG_NETDEV_1000=y | |||
| 720 | # CONFIG_VIA_VELOCITY is not set | 815 | # CONFIG_VIA_VELOCITY is not set |
| 721 | # CONFIG_TIGON3 is not set | 816 | # CONFIG_TIGON3 is not set |
| 722 | # CONFIG_BNX2 is not set | 817 | # CONFIG_BNX2 is not set |
| 818 | # CONFIG_CNIC is not set | ||
| 723 | CONFIG_FSL_PQ_MDIO=y | 819 | CONFIG_FSL_PQ_MDIO=y |
| 724 | CONFIG_GIANFAR=y | 820 | CONFIG_GIANFAR=y |
| 821 | # CONFIG_MV643XX_ETH is not set | ||
| 725 | # CONFIG_QLA3XXX is not set | 822 | # CONFIG_QLA3XXX is not set |
| 726 | # CONFIG_ATL1 is not set | 823 | # CONFIG_ATL1 is not set |
| 727 | # CONFIG_ATL1E is not set | 824 | # CONFIG_ATL1E is not set |
| @@ -748,6 +845,7 @@ CONFIG_GIANFAR=y | |||
| 748 | # CONFIG_USB_PEGASUS is not set | 845 | # CONFIG_USB_PEGASUS is not set |
| 749 | # CONFIG_USB_RTL8150 is not set | 846 | # CONFIG_USB_RTL8150 is not set |
| 750 | # CONFIG_USB_USBNET is not set | 847 | # CONFIG_USB_USBNET is not set |
| 848 | # CONFIG_NET_PCMCIA is not set | ||
| 751 | # CONFIG_WAN is not set | 849 | # CONFIG_WAN is not set |
| 752 | # CONFIG_FDDI is not set | 850 | # CONFIG_FDDI is not set |
| 753 | # CONFIG_HIPPI is not set | 851 | # CONFIG_HIPPI is not set |
| @@ -827,6 +925,7 @@ CONFIG_DEVKMEM=y | |||
| 827 | CONFIG_SERIAL_8250=y | 925 | CONFIG_SERIAL_8250=y |
| 828 | CONFIG_SERIAL_8250_CONSOLE=y | 926 | CONFIG_SERIAL_8250_CONSOLE=y |
| 829 | # CONFIG_SERIAL_8250_PCI is not set | 927 | # CONFIG_SERIAL_8250_PCI is not set |
| 928 | # CONFIG_SERIAL_8250_CS is not set | ||
| 830 | CONFIG_SERIAL_8250_NR_UARTS=2 | 929 | CONFIG_SERIAL_8250_NR_UARTS=2 |
| 831 | CONFIG_SERIAL_8250_RUNTIME_UARTS=2 | 930 | CONFIG_SERIAL_8250_RUNTIME_UARTS=2 |
| 832 | # CONFIG_SERIAL_8250_EXTENDED is not set | 931 | # CONFIG_SERIAL_8250_EXTENDED is not set |
| @@ -849,6 +948,14 @@ CONFIG_HW_RANDOM=y | |||
| 849 | CONFIG_NVRAM=y | 948 | CONFIG_NVRAM=y |
| 850 | # CONFIG_R3964 is not set | 949 | # CONFIG_R3964 is not set |
| 851 | # CONFIG_APPLICOM is not set | 950 | # CONFIG_APPLICOM is not set |
| 951 | |||
| 952 | # | ||
| 953 | # PCMCIA character devices | ||
| 954 | # | ||
| 955 | # CONFIG_SYNCLINK_CS is not set | ||
| 956 | # CONFIG_CARDMAN_4000 is not set | ||
| 957 | # CONFIG_CARDMAN_4040 is not set | ||
| 958 | # CONFIG_IPWIRELESS is not set | ||
| 852 | # CONFIG_RAW_DRIVER is not set | 959 | # CONFIG_RAW_DRIVER is not set |
| 853 | # CONFIG_TCG_TPM is not set | 960 | # CONFIG_TCG_TPM is not set |
| 854 | CONFIG_DEVPORT=y | 961 | CONFIG_DEVPORT=y |
| @@ -912,13 +1019,17 @@ CONFIG_DS1682=y | |||
| 912 | # CONFIG_SENSORS_PCF8574 is not set | 1019 | # CONFIG_SENSORS_PCF8574 is not set |
| 913 | # CONFIG_PCF8575 is not set | 1020 | # CONFIG_PCF8575 is not set |
| 914 | # CONFIG_SENSORS_PCA9539 is not set | 1021 | # CONFIG_SENSORS_PCA9539 is not set |
| 915 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 916 | # CONFIG_SENSORS_TSL2550 is not set | 1022 | # CONFIG_SENSORS_TSL2550 is not set |
| 917 | # CONFIG_I2C_DEBUG_CORE is not set | 1023 | # CONFIG_I2C_DEBUG_CORE is not set |
| 918 | # CONFIG_I2C_DEBUG_ALGO is not set | 1024 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 919 | # CONFIG_I2C_DEBUG_BUS is not set | 1025 | # CONFIG_I2C_DEBUG_BUS is not set |
| 920 | # CONFIG_I2C_DEBUG_CHIP is not set | 1026 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 921 | # CONFIG_SPI is not set | 1027 | # CONFIG_SPI is not set |
| 1028 | |||
| 1029 | # | ||
| 1030 | # PPS support | ||
| 1031 | # | ||
| 1032 | # CONFIG_PPS is not set | ||
| 922 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 1033 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 923 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 1034 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 924 | CONFIG_GPIOLIB=y | 1035 | CONFIG_GPIOLIB=y |
| @@ -997,6 +1108,7 @@ CONFIG_SENSORS_LM92=y | |||
| 997 | # CONFIG_SENSORS_SMSC47B397 is not set | 1108 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 998 | # CONFIG_SENSORS_ADS7828 is not set | 1109 | # CONFIG_SENSORS_ADS7828 is not set |
| 999 | # CONFIG_SENSORS_THMC50 is not set | 1110 | # CONFIG_SENSORS_THMC50 is not set |
| 1111 | # CONFIG_SENSORS_TMP401 is not set | ||
| 1000 | # CONFIG_SENSORS_VIA686A is not set | 1112 | # CONFIG_SENSORS_VIA686A is not set |
| 1001 | # CONFIG_SENSORS_VT1211 is not set | 1113 | # CONFIG_SENSORS_VT1211 is not set |
| 1002 | # CONFIG_SENSORS_VT8231 is not set | 1114 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -1052,24 +1164,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1052 | # CONFIG_MFD_WM8400 is not set | 1164 | # CONFIG_MFD_WM8400 is not set |
| 1053 | # CONFIG_MFD_WM8350_I2C is not set | 1165 | # CONFIG_MFD_WM8350_I2C is not set |
| 1054 | # CONFIG_MFD_PCF50633 is not set | 1166 | # CONFIG_MFD_PCF50633 is not set |
| 1167 | # CONFIG_AB3100_CORE is not set | ||
| 1055 | # CONFIG_REGULATOR is not set | 1168 | # CONFIG_REGULATOR is not set |
| 1056 | 1169 | # CONFIG_MEDIA_SUPPORT is not set | |
| 1057 | # | ||
| 1058 | # Multimedia devices | ||
| 1059 | # | ||
| 1060 | |||
| 1061 | # | ||
| 1062 | # Multimedia core support | ||
| 1063 | # | ||
| 1064 | # CONFIG_VIDEO_DEV is not set | ||
| 1065 | # CONFIG_DVB_CORE is not set | ||
| 1066 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1067 | |||
| 1068 | # | ||
| 1069 | # Multimedia drivers | ||
| 1070 | # | ||
| 1071 | CONFIG_DAB=y | ||
| 1072 | # CONFIG_USB_DABUSB is not set | ||
| 1073 | 1170 | ||
| 1074 | # | 1171 | # |
| 1075 | # Graphics support | 1172 | # Graphics support |
| @@ -1114,7 +1211,7 @@ CONFIG_HID_BELKIN=y | |||
| 1114 | CONFIG_HID_CHERRY=y | 1211 | CONFIG_HID_CHERRY=y |
| 1115 | CONFIG_HID_CHICONY=y | 1212 | CONFIG_HID_CHICONY=y |
| 1116 | CONFIG_HID_CYPRESS=y | 1213 | CONFIG_HID_CYPRESS=y |
| 1117 | # CONFIG_DRAGONRISE_FF is not set | 1214 | # CONFIG_HID_DRAGONRISE is not set |
| 1118 | CONFIG_HID_EZKEY=y | 1215 | CONFIG_HID_EZKEY=y |
| 1119 | # CONFIG_HID_KYE is not set | 1216 | # CONFIG_HID_KYE is not set |
| 1120 | CONFIG_HID_GYRATION=y | 1217 | CONFIG_HID_GYRATION=y |
| @@ -1131,10 +1228,11 @@ CONFIG_HID_PETALYNX=y | |||
| 1131 | CONFIG_HID_SAMSUNG=y | 1228 | CONFIG_HID_SAMSUNG=y |
| 1132 | CONFIG_HID_SONY=y | 1229 | CONFIG_HID_SONY=y |
| 1133 | CONFIG_HID_SUNPLUS=y | 1230 | CONFIG_HID_SUNPLUS=y |
| 1134 | # CONFIG_GREENASIA_FF is not set | 1231 | # CONFIG_HID_GREENASIA is not set |
| 1232 | # CONFIG_HID_SMARTJOYPLUS is not set | ||
| 1135 | # CONFIG_HID_TOPSEED is not set | 1233 | # CONFIG_HID_TOPSEED is not set |
| 1136 | # CONFIG_THRUSTMASTER_FF is not set | 1234 | # CONFIG_HID_THRUSTMASTER is not set |
| 1137 | # CONFIG_ZEROPLUS_FF is not set | 1235 | # CONFIG_HID_ZEROPLUS is not set |
| 1138 | CONFIG_USB_SUPPORT=y | 1236 | CONFIG_USB_SUPPORT=y |
| 1139 | CONFIG_USB_ARCH_HAS_HCD=y | 1237 | CONFIG_USB_ARCH_HAS_HCD=y |
| 1140 | CONFIG_USB_ARCH_HAS_OHCI=y | 1238 | CONFIG_USB_ARCH_HAS_OHCI=y |
| @@ -1160,6 +1258,7 @@ CONFIG_USB=y | |||
| 1160 | # USB Host Controller Drivers | 1258 | # USB Host Controller Drivers |
| 1161 | # | 1259 | # |
| 1162 | # CONFIG_USB_C67X00_HCD is not set | 1260 | # CONFIG_USB_C67X00_HCD is not set |
| 1261 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1163 | CONFIG_USB_EHCI_HCD=y | 1262 | CONFIG_USB_EHCI_HCD=y |
| 1164 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set | 1263 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set |
| 1165 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1264 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1169,6 +1268,8 @@ CONFIG_USB_EHCI_HCD=y | |||
| 1169 | # CONFIG_USB_ISP116X_HCD is not set | 1268 | # CONFIG_USB_ISP116X_HCD is not set |
| 1170 | # CONFIG_USB_ISP1760_HCD is not set | 1269 | # CONFIG_USB_ISP1760_HCD is not set |
| 1171 | CONFIG_USB_OHCI_HCD=y | 1270 | CONFIG_USB_OHCI_HCD=y |
| 1271 | # CONFIG_USB_OHCI_HCD_PPC_OF_BE is not set | ||
| 1272 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set | ||
| 1172 | # CONFIG_USB_OHCI_HCD_PPC_OF is not set | 1273 | # CONFIG_USB_OHCI_HCD_PPC_OF is not set |
| 1173 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set | 1274 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set |
| 1174 | # CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set | 1275 | # CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set |
| @@ -1288,6 +1389,7 @@ CONFIG_RTC_INTF_DEV=y | |||
| 1288 | # CONFIG_RTC_DRV_S35390A is not set | 1389 | # CONFIG_RTC_DRV_S35390A is not set |
| 1289 | # CONFIG_RTC_DRV_FM3130 is not set | 1390 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1290 | CONFIG_RTC_DRV_RX8581=y | 1391 | CONFIG_RTC_DRV_RX8581=y |
| 1392 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1291 | 1393 | ||
| 1292 | # | 1394 | # |
| 1293 | # SPI RTC drivers | 1395 | # SPI RTC drivers |
| @@ -1315,6 +1417,10 @@ CONFIG_RTC_DRV_RX8581=y | |||
| 1315 | # CONFIG_DMADEVICES is not set | 1417 | # CONFIG_DMADEVICES is not set |
| 1316 | # CONFIG_AUXDISPLAY is not set | 1418 | # CONFIG_AUXDISPLAY is not set |
| 1317 | # CONFIG_UIO is not set | 1419 | # CONFIG_UIO is not set |
| 1420 | |||
| 1421 | # | ||
| 1422 | # TI VLYNQ | ||
| 1423 | # | ||
| 1318 | # CONFIG_STAGING is not set | 1424 | # CONFIG_STAGING is not set |
| 1319 | 1425 | ||
| 1320 | # | 1426 | # |
| @@ -1336,10 +1442,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1336 | # CONFIG_REISERFS_FS is not set | 1442 | # CONFIG_REISERFS_FS is not set |
| 1337 | # CONFIG_JFS_FS is not set | 1443 | # CONFIG_JFS_FS is not set |
| 1338 | CONFIG_FS_POSIX_ACL=y | 1444 | CONFIG_FS_POSIX_ACL=y |
| 1339 | CONFIG_FILE_LOCKING=y | ||
| 1340 | # CONFIG_XFS_FS is not set | 1445 | # CONFIG_XFS_FS is not set |
| 1446 | # CONFIG_GFS2_FS is not set | ||
| 1341 | # CONFIG_OCFS2_FS is not set | 1447 | # CONFIG_OCFS2_FS is not set |
| 1342 | # CONFIG_BTRFS_FS is not set | 1448 | # CONFIG_BTRFS_FS is not set |
| 1449 | CONFIG_FILE_LOCKING=y | ||
| 1450 | CONFIG_FSNOTIFY=y | ||
| 1343 | CONFIG_DNOTIFY=y | 1451 | CONFIG_DNOTIFY=y |
| 1344 | CONFIG_INOTIFY=y | 1452 | CONFIG_INOTIFY=y |
| 1345 | CONFIG_INOTIFY_USER=y | 1453 | CONFIG_INOTIFY_USER=y |
| @@ -1419,6 +1527,7 @@ CONFIG_NFS_FS=y | |||
| 1419 | CONFIG_NFS_V3=y | 1527 | CONFIG_NFS_V3=y |
| 1420 | # CONFIG_NFS_V3_ACL is not set | 1528 | # CONFIG_NFS_V3_ACL is not set |
| 1421 | CONFIG_NFS_V4=y | 1529 | CONFIG_NFS_V4=y |
| 1530 | # CONFIG_NFS_V4_1 is not set | ||
| 1422 | CONFIG_ROOT_NFS=y | 1531 | CONFIG_ROOT_NFS=y |
| 1423 | # CONFIG_NFSD is not set | 1532 | # CONFIG_NFSD is not set |
| 1424 | CONFIG_LOCKD=y | 1533 | CONFIG_LOCKD=y |
| @@ -1508,6 +1617,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1508 | CONFIG_HAS_DMA=y | 1617 | CONFIG_HAS_DMA=y |
| 1509 | CONFIG_HAVE_LMB=y | 1618 | CONFIG_HAVE_LMB=y |
| 1510 | CONFIG_NLATTR=y | 1619 | CONFIG_NLATTR=y |
| 1620 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1511 | 1621 | ||
| 1512 | # | 1622 | # |
| 1513 | # Kernel hacking | 1623 | # Kernel hacking |
| @@ -1531,23 +1641,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1531 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1641 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1532 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1642 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1533 | CONFIG_TRACING_SUPPORT=y | 1643 | CONFIG_TRACING_SUPPORT=y |
| 1534 | 1644 | # CONFIG_FTRACE is not set | |
| 1535 | # | ||
| 1536 | # Tracers | ||
| 1537 | # | ||
| 1538 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1539 | # CONFIG_PREEMPT_TRACER is not set | ||
| 1540 | # CONFIG_SCHED_TRACER is not set | ||
| 1541 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1542 | # CONFIG_EVENT_TRACER is not set | ||
| 1543 | # CONFIG_BOOT_TRACER is not set | ||
| 1544 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1545 | # CONFIG_STACK_TRACER is not set | ||
| 1546 | # CONFIG_KMEMTRACE is not set | ||
| 1547 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1548 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1549 | # CONFIG_SAMPLES is not set | 1645 | # CONFIG_SAMPLES is not set |
| 1550 | CONFIG_HAVE_ARCH_KGDB=y | 1646 | CONFIG_HAVE_ARCH_KGDB=y |
| 1647 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1648 | CONFIG_PPC_WERROR=y | ||
| 1551 | CONFIG_PRINT_STACK_DEPTH=64 | 1649 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1552 | # CONFIG_IRQSTACKS is not set | 1650 | # CONFIG_IRQSTACKS is not set |
| 1553 | # CONFIG_BOOTX_TEXT is not set | 1651 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/86xx/gef_sbc610_defconfig b/arch/powerpc/configs/86xx/gef_sbc610_defconfig index c6a7fc82b69a..ba47883f4aa0 100644 --- a/arch/powerpc/configs/86xx/gef_sbc610_defconfig +++ b/arch/powerpc/configs/86xx/gef_sbc610_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:30 2009 | 4 | # Wed Jul 29 23:32:30 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_PHYS_64BIT is not set | 20 | # CONFIG_PHYS_64BIT is not set |
| 20 | CONFIG_ALTIVEC=y | 21 | CONFIG_ALTIVEC=y |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | CONFIG_SMP=y | 26 | CONFIG_SMP=y |
| 25 | CONFIG_NR_CPUS=2 | 27 | CONFIG_NR_CPUS=2 |
| 26 | CONFIG_PPC32=y | 28 | CONFIG_PPC32=y |
| @@ -32,16 +34,17 @@ CONFIG_GENERIC_TIME=y | |||
| 32 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 33 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 34 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 35 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 36 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 37 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 38 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 39 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 40 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 41 | CONFIG_GENERIC_LOCKBREAK=y | 45 | CONFIG_GENERIC_LOCKBREAK=y |
| 42 | CONFIG_ARCH_HAS_ILOG2_U32=y | 46 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 43 | CONFIG_GENERIC_HWEIGHT=y | 47 | CONFIG_GENERIC_HWEIGHT=y |
| 44 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 45 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 48 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 46 | CONFIG_GENERIC_GPIO=y | 49 | CONFIG_GENERIC_GPIO=y |
| 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 50 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -56,11 +59,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 56 | CONFIG_GENERIC_TBSYNC=y | 59 | CONFIG_GENERIC_TBSYNC=y |
| 57 | CONFIG_AUDIT_ARCH=y | 60 | CONFIG_AUDIT_ARCH=y |
| 58 | CONFIG_GENERIC_BUG=y | 61 | CONFIG_GENERIC_BUG=y |
| 62 | CONFIG_DTC=y | ||
| 59 | CONFIG_DEFAULT_UIMAGE=y | 63 | CONFIG_DEFAULT_UIMAGE=y |
| 60 | # CONFIG_PPC_DCR_NATIVE is not set | 64 | # CONFIG_PPC_DCR_NATIVE is not set |
| 61 | # CONFIG_PPC_DCR_MMIO is not set | 65 | # CONFIG_PPC_DCR_MMIO is not set |
| 62 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 66 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 63 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 67 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 68 | CONFIG_CONSTRUCTORS=y | ||
| 64 | 69 | ||
| 65 | # | 70 | # |
| 66 | # General setup | 71 | # General setup |
| @@ -114,7 +119,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 114 | CONFIG_KALLSYMS=y | 119 | CONFIG_KALLSYMS=y |
| 115 | # CONFIG_KALLSYMS_ALL is not set | 120 | # CONFIG_KALLSYMS_ALL is not set |
| 116 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 121 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 117 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 118 | CONFIG_HOTPLUG=y | 122 | CONFIG_HOTPLUG=y |
| 119 | CONFIG_PRINTK=y | 123 | CONFIG_PRINTK=y |
| 120 | CONFIG_BUG=y | 124 | CONFIG_BUG=y |
| @@ -127,8 +131,15 @@ CONFIG_TIMERFD=y | |||
| 127 | CONFIG_EVENTFD=y | 131 | CONFIG_EVENTFD=y |
| 128 | CONFIG_SHMEM=y | 132 | CONFIG_SHMEM=y |
| 129 | CONFIG_AIO=y | 133 | CONFIG_AIO=y |
| 134 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 135 | |||
| 136 | # | ||
| 137 | # Performance Counters | ||
| 138 | # | ||
| 139 | # CONFIG_PERF_COUNTERS is not set | ||
| 130 | CONFIG_VM_EVENT_COUNTERS=y | 140 | CONFIG_VM_EVENT_COUNTERS=y |
| 131 | CONFIG_PCI_QUIRKS=y | 141 | CONFIG_PCI_QUIRKS=y |
| 142 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 132 | CONFIG_COMPAT_BRK=y | 143 | CONFIG_COMPAT_BRK=y |
| 133 | CONFIG_SLAB=y | 144 | CONFIG_SLAB=y |
| 134 | # CONFIG_SLUB is not set | 145 | # CONFIG_SLUB is not set |
| @@ -143,6 +154,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 143 | CONFIG_HAVE_KRETPROBES=y | 154 | CONFIG_HAVE_KRETPROBES=y |
| 144 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 155 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 145 | CONFIG_USE_GENERIC_SMP_HELPERS=y | 156 | CONFIG_USE_GENERIC_SMP_HELPERS=y |
| 157 | |||
| 158 | # | ||
| 159 | # GCOV-based kernel profiling | ||
| 160 | # | ||
| 146 | # CONFIG_SLOW_WORK is not set | 161 | # CONFIG_SLOW_WORK is not set |
| 147 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 162 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 148 | CONFIG_SLABINFO=y | 163 | CONFIG_SLABINFO=y |
| @@ -156,7 +171,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 156 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 171 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 157 | CONFIG_STOP_MACHINE=y | 172 | CONFIG_STOP_MACHINE=y |
| 158 | CONFIG_BLOCK=y | 173 | CONFIG_BLOCK=y |
| 159 | # CONFIG_LBD is not set | 174 | CONFIG_LBDAF=y |
| 160 | # CONFIG_BLK_DEV_BSG is not set | 175 | # CONFIG_BLK_DEV_BSG is not set |
| 161 | # CONFIG_BLK_DEV_INTEGRITY is not set | 176 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 162 | 177 | ||
| @@ -235,6 +250,7 @@ CONFIG_BINFMT_ELF=y | |||
| 235 | # CONFIG_HAVE_AOUT is not set | 250 | # CONFIG_HAVE_AOUT is not set |
| 236 | CONFIG_BINFMT_MISC=m | 251 | CONFIG_BINFMT_MISC=m |
| 237 | # CONFIG_IOMMU_HELPER is not set | 252 | # CONFIG_IOMMU_HELPER is not set |
| 253 | # CONFIG_SWIOTLB is not set | ||
| 238 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 254 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 239 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 255 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 240 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 256 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -256,9 +272,9 @@ CONFIG_MIGRATION=y | |||
| 256 | CONFIG_ZONE_DMA_FLAG=1 | 272 | CONFIG_ZONE_DMA_FLAG=1 |
| 257 | CONFIG_BOUNCE=y | 273 | CONFIG_BOUNCE=y |
| 258 | CONFIG_VIRT_TO_BUS=y | 274 | CONFIG_VIRT_TO_BUS=y |
| 259 | CONFIG_UNEVICTABLE_LRU=y | ||
| 260 | CONFIG_HAVE_MLOCK=y | 275 | CONFIG_HAVE_MLOCK=y |
| 261 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 276 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 277 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 262 | CONFIG_PPC_4K_PAGES=y | 278 | CONFIG_PPC_4K_PAGES=y |
| 263 | # CONFIG_PPC_16K_PAGES is not set | 279 | # CONFIG_PPC_16K_PAGES is not set |
| 264 | # CONFIG_PPC_64K_PAGES is not set | 280 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -285,6 +301,8 @@ CONFIG_PCI_DOMAINS=y | |||
| 285 | CONFIG_PCI_SYSCALL=y | 301 | CONFIG_PCI_SYSCALL=y |
| 286 | CONFIG_PCIEPORTBUS=y | 302 | CONFIG_PCIEPORTBUS=y |
| 287 | CONFIG_PCIEAER=y | 303 | CONFIG_PCIEAER=y |
| 304 | # CONFIG_PCIE_ECRC is not set | ||
| 305 | # CONFIG_PCIEAER_INJECT is not set | ||
| 288 | # CONFIG_PCIEASPM is not set | 306 | # CONFIG_PCIEASPM is not set |
| 289 | CONFIG_ARCH_SUPPORTS_MSI=y | 307 | CONFIG_ARCH_SUPPORTS_MSI=y |
| 290 | # CONFIG_PCI_MSI is not set | 308 | # CONFIG_PCI_MSI is not set |
| @@ -510,6 +528,7 @@ CONFIG_LLC=m | |||
| 510 | # CONFIG_ECONET is not set | 528 | # CONFIG_ECONET is not set |
| 511 | CONFIG_WAN_ROUTER=m | 529 | CONFIG_WAN_ROUTER=m |
| 512 | # CONFIG_PHONET is not set | 530 | # CONFIG_PHONET is not set |
| 531 | # CONFIG_IEEE802154 is not set | ||
| 513 | CONFIG_NET_SCHED=y | 532 | CONFIG_NET_SCHED=y |
| 514 | 533 | ||
| 515 | # | 534 | # |
| @@ -566,7 +585,11 @@ CONFIG_WIRELESS=y | |||
| 566 | CONFIG_WIRELESS_OLD_REGULATORY=y | 585 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 567 | # CONFIG_WIRELESS_EXT is not set | 586 | # CONFIG_WIRELESS_EXT is not set |
| 568 | # CONFIG_LIB80211 is not set | 587 | # CONFIG_LIB80211 is not set |
| 569 | # CONFIG_MAC80211 is not set | 588 | |
| 589 | # | ||
| 590 | # CFG80211 needs to be enabled for MAC80211 | ||
| 591 | # | ||
| 592 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 570 | # CONFIG_WIMAX is not set | 593 | # CONFIG_WIMAX is not set |
| 571 | # CONFIG_RFKILL is not set | 594 | # CONFIG_RFKILL is not set |
| 572 | # CONFIG_NET_9P is not set | 595 | # CONFIG_NET_9P is not set |
| @@ -678,6 +701,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 678 | CONFIG_OF_DEVICE=y | 701 | CONFIG_OF_DEVICE=y |
| 679 | CONFIG_OF_GPIO=y | 702 | CONFIG_OF_GPIO=y |
| 680 | CONFIG_OF_I2C=y | 703 | CONFIG_OF_I2C=y |
| 704 | CONFIG_OF_MDIO=y | ||
| 681 | # CONFIG_PARPORT is not set | 705 | # CONFIG_PARPORT is not set |
| 682 | CONFIG_BLK_DEV=y | 706 | CONFIG_BLK_DEV=y |
| 683 | # CONFIG_BLK_DEV_FD is not set | 707 | # CONFIG_BLK_DEV_FD is not set |
| @@ -713,7 +737,9 @@ CONFIG_MISC_DEVICES=y | |||
| 713 | # | 737 | # |
| 714 | # CONFIG_EEPROM_AT24 is not set | 738 | # CONFIG_EEPROM_AT24 is not set |
| 715 | # CONFIG_EEPROM_LEGACY is not set | 739 | # CONFIG_EEPROM_LEGACY is not set |
| 740 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 716 | # CONFIG_EEPROM_93CX6 is not set | 741 | # CONFIG_EEPROM_93CX6 is not set |
| 742 | # CONFIG_CB710_CORE is not set | ||
| 717 | CONFIG_HAVE_IDE=y | 743 | CONFIG_HAVE_IDE=y |
| 718 | # CONFIG_IDE is not set | 744 | # CONFIG_IDE is not set |
| 719 | 745 | ||
| @@ -737,10 +763,6 @@ CONFIG_BLK_DEV_SR=y | |||
| 737 | # CONFIG_BLK_DEV_SR_VENDOR is not set | 763 | # CONFIG_BLK_DEV_SR_VENDOR is not set |
| 738 | # CONFIG_CHR_DEV_SG is not set | 764 | # CONFIG_CHR_DEV_SG is not set |
| 739 | # CONFIG_CHR_DEV_SCH is not set | 765 | # CONFIG_CHR_DEV_SCH is not set |
| 740 | |||
| 741 | # | ||
| 742 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 743 | # | ||
| 744 | # CONFIG_SCSI_MULTI_LUN is not set | 766 | # CONFIG_SCSI_MULTI_LUN is not set |
| 745 | # CONFIG_SCSI_CONSTANTS is not set | 767 | # CONFIG_SCSI_CONSTANTS is not set |
| 746 | # CONFIG_SCSI_LOGGING is not set | 768 | # CONFIG_SCSI_LOGGING is not set |
| @@ -757,6 +779,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 757 | # CONFIG_SCSI_SRP_ATTRS is not set | 779 | # CONFIG_SCSI_SRP_ATTRS is not set |
| 758 | CONFIG_SCSI_LOWLEVEL=y | 780 | CONFIG_SCSI_LOWLEVEL=y |
| 759 | # CONFIG_ISCSI_TCP is not set | 781 | # CONFIG_ISCSI_TCP is not set |
| 782 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 760 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 783 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 761 | # CONFIG_SCSI_3W_9XXX is not set | 784 | # CONFIG_SCSI_3W_9XXX is not set |
| 762 | # CONFIG_SCSI_ACARD is not set | 785 | # CONFIG_SCSI_ACARD is not set |
| @@ -765,6 +788,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 765 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 788 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 766 | # CONFIG_SCSI_AIC79XX is not set | 789 | # CONFIG_SCSI_AIC79XX is not set |
| 767 | # CONFIG_SCSI_AIC94XX is not set | 790 | # CONFIG_SCSI_AIC94XX is not set |
| 791 | # CONFIG_SCSI_MVSAS is not set | ||
| 768 | # CONFIG_SCSI_DPT_I2O is not set | 792 | # CONFIG_SCSI_DPT_I2O is not set |
| 769 | # CONFIG_SCSI_ADVANSYS is not set | 793 | # CONFIG_SCSI_ADVANSYS is not set |
| 770 | # CONFIG_SCSI_ARCMSR is not set | 794 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -784,7 +808,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 784 | # CONFIG_SCSI_IPS is not set | 808 | # CONFIG_SCSI_IPS is not set |
| 785 | # CONFIG_SCSI_INITIO is not set | 809 | # CONFIG_SCSI_INITIO is not set |
| 786 | # CONFIG_SCSI_INIA100 is not set | 810 | # CONFIG_SCSI_INIA100 is not set |
| 787 | # CONFIG_SCSI_MVSAS is not set | ||
| 788 | # CONFIG_SCSI_STEX is not set | 811 | # CONFIG_SCSI_STEX is not set |
| 789 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 812 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 790 | # CONFIG_SCSI_IPR is not set | 813 | # CONFIG_SCSI_IPR is not set |
| @@ -868,14 +891,17 @@ CONFIG_SATA_SIL=y | |||
| 868 | # | 891 | # |
| 869 | 892 | ||
| 870 | # | 893 | # |
| 871 | # Enable only one of the two stacks, unless you know what you are doing | 894 | # You can enable one or both FireWire driver stacks. |
| 895 | # | ||
| 896 | |||
| 897 | # | ||
| 898 | # See the help texts for more information. | ||
| 872 | # | 899 | # |
| 873 | # CONFIG_FIREWIRE is not set | 900 | # CONFIG_FIREWIRE is not set |
| 874 | # CONFIG_IEEE1394 is not set | 901 | # CONFIG_IEEE1394 is not set |
| 875 | # CONFIG_I2O is not set | 902 | # CONFIG_I2O is not set |
| 876 | # CONFIG_MACINTOSH_DRIVERS is not set | 903 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 877 | CONFIG_NETDEVICES=y | 904 | CONFIG_NETDEVICES=y |
| 878 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 879 | CONFIG_DUMMY=m | 905 | CONFIG_DUMMY=m |
| 880 | CONFIG_BONDING=m | 906 | CONFIG_BONDING=m |
| 881 | # CONFIG_MACVLAN is not set | 907 | # CONFIG_MACVLAN is not set |
| @@ -922,6 +948,7 @@ CONFIG_MII=y | |||
| 922 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 948 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 923 | # CONFIG_NET_PCI is not set | 949 | # CONFIG_NET_PCI is not set |
| 924 | # CONFIG_B44 is not set | 950 | # CONFIG_B44 is not set |
| 951 | # CONFIG_KS8842 is not set | ||
| 925 | # CONFIG_ATL2 is not set | 952 | # CONFIG_ATL2 is not set |
| 926 | CONFIG_NETDEV_1000=y | 953 | CONFIG_NETDEV_1000=y |
| 927 | # CONFIG_ACENIC is not set | 954 | # CONFIG_ACENIC is not set |
| @@ -941,8 +968,10 @@ CONFIG_NETDEV_1000=y | |||
| 941 | # CONFIG_VIA_VELOCITY is not set | 968 | # CONFIG_VIA_VELOCITY is not set |
| 942 | # CONFIG_TIGON3 is not set | 969 | # CONFIG_TIGON3 is not set |
| 943 | # CONFIG_BNX2 is not set | 970 | # CONFIG_BNX2 is not set |
| 971 | # CONFIG_CNIC is not set | ||
| 944 | CONFIG_FSL_PQ_MDIO=y | 972 | CONFIG_FSL_PQ_MDIO=y |
| 945 | CONFIG_GIANFAR=y | 973 | CONFIG_GIANFAR=y |
| 974 | # CONFIG_MV643XX_ETH is not set | ||
| 946 | # CONFIG_QLA3XXX is not set | 975 | # CONFIG_QLA3XXX is not set |
| 947 | # CONFIG_ATL1 is not set | 976 | # CONFIG_ATL1 is not set |
| 948 | # CONFIG_ATL1E is not set | 977 | # CONFIG_ATL1E is not set |
| @@ -1149,13 +1178,17 @@ CONFIG_DS1682=y | |||
| 1149 | # CONFIG_SENSORS_PCF8574 is not set | 1178 | # CONFIG_SENSORS_PCF8574 is not set |
| 1150 | # CONFIG_PCF8575 is not set | 1179 | # CONFIG_PCF8575 is not set |
| 1151 | # CONFIG_SENSORS_PCA9539 is not set | 1180 | # CONFIG_SENSORS_PCA9539 is not set |
| 1152 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 1153 | # CONFIG_SENSORS_TSL2550 is not set | 1181 | # CONFIG_SENSORS_TSL2550 is not set |
| 1154 | # CONFIG_I2C_DEBUG_CORE is not set | 1182 | # CONFIG_I2C_DEBUG_CORE is not set |
| 1155 | # CONFIG_I2C_DEBUG_ALGO is not set | 1183 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 1156 | # CONFIG_I2C_DEBUG_BUS is not set | 1184 | # CONFIG_I2C_DEBUG_BUS is not set |
| 1157 | # CONFIG_I2C_DEBUG_CHIP is not set | 1185 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 1158 | # CONFIG_SPI is not set | 1186 | # CONFIG_SPI is not set |
| 1187 | |||
| 1188 | # | ||
| 1189 | # PPS support | ||
| 1190 | # | ||
| 1191 | # CONFIG_PPS is not set | ||
| 1159 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 1192 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 1160 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 1193 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 1161 | CONFIG_GPIOLIB=y | 1194 | CONFIG_GPIOLIB=y |
| @@ -1235,6 +1268,7 @@ CONFIG_SENSORS_LM92=y | |||
| 1235 | # CONFIG_SENSORS_SMSC47B397 is not set | 1268 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 1236 | # CONFIG_SENSORS_ADS7828 is not set | 1269 | # CONFIG_SENSORS_ADS7828 is not set |
| 1237 | # CONFIG_SENSORS_THMC50 is not set | 1270 | # CONFIG_SENSORS_THMC50 is not set |
| 1271 | # CONFIG_SENSORS_TMP401 is not set | ||
| 1238 | # CONFIG_SENSORS_VIA686A is not set | 1272 | # CONFIG_SENSORS_VIA686A is not set |
| 1239 | # CONFIG_SENSORS_VT1211 is not set | 1273 | # CONFIG_SENSORS_VT1211 is not set |
| 1240 | # CONFIG_SENSORS_VT8231 is not set | 1274 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -1290,24 +1324,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1290 | # CONFIG_MFD_WM8400 is not set | 1324 | # CONFIG_MFD_WM8400 is not set |
| 1291 | # CONFIG_MFD_WM8350_I2C is not set | 1325 | # CONFIG_MFD_WM8350_I2C is not set |
| 1292 | # CONFIG_MFD_PCF50633 is not set | 1326 | # CONFIG_MFD_PCF50633 is not set |
| 1327 | # CONFIG_AB3100_CORE is not set | ||
| 1293 | # CONFIG_REGULATOR is not set | 1328 | # CONFIG_REGULATOR is not set |
| 1294 | 1329 | # CONFIG_MEDIA_SUPPORT is not set | |
| 1295 | # | ||
| 1296 | # Multimedia devices | ||
| 1297 | # | ||
| 1298 | |||
| 1299 | # | ||
| 1300 | # Multimedia core support | ||
| 1301 | # | ||
| 1302 | # CONFIG_VIDEO_DEV is not set | ||
| 1303 | # CONFIG_DVB_CORE is not set | ||
| 1304 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1305 | |||
| 1306 | # | ||
| 1307 | # Multimedia drivers | ||
| 1308 | # | ||
| 1309 | CONFIG_DAB=y | ||
| 1310 | # CONFIG_USB_DABUSB is not set | ||
| 1311 | 1330 | ||
| 1312 | # | 1331 | # |
| 1313 | # Graphics support | 1332 | # Graphics support |
| @@ -1352,7 +1371,7 @@ CONFIG_HID_BELKIN=y | |||
| 1352 | CONFIG_HID_CHERRY=y | 1371 | CONFIG_HID_CHERRY=y |
| 1353 | CONFIG_HID_CHICONY=y | 1372 | CONFIG_HID_CHICONY=y |
| 1354 | CONFIG_HID_CYPRESS=y | 1373 | CONFIG_HID_CYPRESS=y |
| 1355 | # CONFIG_DRAGONRISE_FF is not set | 1374 | # CONFIG_HID_DRAGONRISE is not set |
| 1356 | CONFIG_HID_EZKEY=y | 1375 | CONFIG_HID_EZKEY=y |
| 1357 | # CONFIG_HID_KYE is not set | 1376 | # CONFIG_HID_KYE is not set |
| 1358 | CONFIG_HID_GYRATION=y | 1377 | CONFIG_HID_GYRATION=y |
| @@ -1369,10 +1388,11 @@ CONFIG_HID_PETALYNX=y | |||
| 1369 | CONFIG_HID_SAMSUNG=y | 1388 | CONFIG_HID_SAMSUNG=y |
| 1370 | CONFIG_HID_SONY=y | 1389 | CONFIG_HID_SONY=y |
| 1371 | CONFIG_HID_SUNPLUS=y | 1390 | CONFIG_HID_SUNPLUS=y |
| 1372 | # CONFIG_GREENASIA_FF is not set | 1391 | # CONFIG_HID_GREENASIA is not set |
| 1392 | # CONFIG_HID_SMARTJOYPLUS is not set | ||
| 1373 | # CONFIG_HID_TOPSEED is not set | 1393 | # CONFIG_HID_TOPSEED is not set |
| 1374 | CONFIG_THRUSTMASTER_FF=m | 1394 | # CONFIG_HID_THRUSTMASTER is not set |
| 1375 | CONFIG_ZEROPLUS_FF=m | 1395 | # CONFIG_HID_ZEROPLUS is not set |
| 1376 | CONFIG_USB_SUPPORT=y | 1396 | CONFIG_USB_SUPPORT=y |
| 1377 | CONFIG_USB_ARCH_HAS_HCD=y | 1397 | CONFIG_USB_ARCH_HAS_HCD=y |
| 1378 | CONFIG_USB_ARCH_HAS_OHCI=y | 1398 | CONFIG_USB_ARCH_HAS_OHCI=y |
| @@ -1398,6 +1418,7 @@ CONFIG_USB=y | |||
| 1398 | # USB Host Controller Drivers | 1418 | # USB Host Controller Drivers |
| 1399 | # | 1419 | # |
| 1400 | # CONFIG_USB_C67X00_HCD is not set | 1420 | # CONFIG_USB_C67X00_HCD is not set |
| 1421 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1401 | CONFIG_USB_EHCI_HCD=y | 1422 | CONFIG_USB_EHCI_HCD=y |
| 1402 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set | 1423 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set |
| 1403 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1424 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1407,6 +1428,8 @@ CONFIG_USB_EHCI_HCD=y | |||
| 1407 | # CONFIG_USB_ISP116X_HCD is not set | 1428 | # CONFIG_USB_ISP116X_HCD is not set |
| 1408 | # CONFIG_USB_ISP1760_HCD is not set | 1429 | # CONFIG_USB_ISP1760_HCD is not set |
| 1409 | CONFIG_USB_OHCI_HCD=y | 1430 | CONFIG_USB_OHCI_HCD=y |
| 1431 | # CONFIG_USB_OHCI_HCD_PPC_OF_BE is not set | ||
| 1432 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set | ||
| 1410 | # CONFIG_USB_OHCI_HCD_PPC_OF is not set | 1433 | # CONFIG_USB_OHCI_HCD_PPC_OF is not set |
| 1411 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set | 1434 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set |
| 1412 | # CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set | 1435 | # CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set |
| @@ -1527,6 +1550,7 @@ CONFIG_RTC_INTF_DEV=y | |||
| 1527 | # CONFIG_RTC_DRV_S35390A is not set | 1550 | # CONFIG_RTC_DRV_S35390A is not set |
| 1528 | # CONFIG_RTC_DRV_FM3130 is not set | 1551 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1529 | CONFIG_RTC_DRV_RX8581=y | 1552 | CONFIG_RTC_DRV_RX8581=y |
| 1553 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1530 | 1554 | ||
| 1531 | # | 1555 | # |
| 1532 | # SPI RTC drivers | 1556 | # SPI RTC drivers |
| @@ -1554,6 +1578,10 @@ CONFIG_RTC_DRV_RX8581=y | |||
| 1554 | # CONFIG_DMADEVICES is not set | 1578 | # CONFIG_DMADEVICES is not set |
| 1555 | # CONFIG_AUXDISPLAY is not set | 1579 | # CONFIG_AUXDISPLAY is not set |
| 1556 | # CONFIG_UIO is not set | 1580 | # CONFIG_UIO is not set |
| 1581 | |||
| 1582 | # | ||
| 1583 | # TI VLYNQ | ||
| 1584 | # | ||
| 1557 | # CONFIG_STAGING is not set | 1585 | # CONFIG_STAGING is not set |
| 1558 | 1586 | ||
| 1559 | # | 1587 | # |
| @@ -1575,10 +1603,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1575 | # CONFIG_REISERFS_FS is not set | 1603 | # CONFIG_REISERFS_FS is not set |
| 1576 | # CONFIG_JFS_FS is not set | 1604 | # CONFIG_JFS_FS is not set |
| 1577 | CONFIG_FS_POSIX_ACL=y | 1605 | CONFIG_FS_POSIX_ACL=y |
| 1578 | CONFIG_FILE_LOCKING=y | ||
| 1579 | # CONFIG_XFS_FS is not set | 1606 | # CONFIG_XFS_FS is not set |
| 1607 | # CONFIG_GFS2_FS is not set | ||
| 1580 | # CONFIG_OCFS2_FS is not set | 1608 | # CONFIG_OCFS2_FS is not set |
| 1581 | # CONFIG_BTRFS_FS is not set | 1609 | # CONFIG_BTRFS_FS is not set |
| 1610 | CONFIG_FILE_LOCKING=y | ||
| 1611 | CONFIG_FSNOTIFY=y | ||
| 1582 | CONFIG_DNOTIFY=y | 1612 | CONFIG_DNOTIFY=y |
| 1583 | CONFIG_INOTIFY=y | 1613 | CONFIG_INOTIFY=y |
| 1584 | CONFIG_INOTIFY_USER=y | 1614 | CONFIG_INOTIFY_USER=y |
| @@ -1645,6 +1675,7 @@ CONFIG_NFS_FS=y | |||
| 1645 | CONFIG_NFS_V3=y | 1675 | CONFIG_NFS_V3=y |
| 1646 | # CONFIG_NFS_V3_ACL is not set | 1676 | # CONFIG_NFS_V3_ACL is not set |
| 1647 | CONFIG_NFS_V4=y | 1677 | CONFIG_NFS_V4=y |
| 1678 | # CONFIG_NFS_V4_1 is not set | ||
| 1648 | CONFIG_ROOT_NFS=y | 1679 | CONFIG_ROOT_NFS=y |
| 1649 | # CONFIG_NFSD is not set | 1680 | # CONFIG_NFSD is not set |
| 1650 | CONFIG_LOCKD=y | 1681 | CONFIG_LOCKD=y |
| @@ -1734,6 +1765,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1734 | CONFIG_HAS_DMA=y | 1765 | CONFIG_HAS_DMA=y |
| 1735 | CONFIG_HAVE_LMB=y | 1766 | CONFIG_HAVE_LMB=y |
| 1736 | CONFIG_NLATTR=y | 1767 | CONFIG_NLATTR=y |
| 1768 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1737 | 1769 | ||
| 1738 | # | 1770 | # |
| 1739 | # Kernel hacking | 1771 | # Kernel hacking |
| @@ -1759,10 +1791,14 @@ CONFIG_SCHED_DEBUG=y | |||
| 1759 | # CONFIG_TIMER_STATS is not set | 1791 | # CONFIG_TIMER_STATS is not set |
| 1760 | # CONFIG_DEBUG_OBJECTS is not set | 1792 | # CONFIG_DEBUG_OBJECTS is not set |
| 1761 | # CONFIG_DEBUG_SLAB is not set | 1793 | # CONFIG_DEBUG_SLAB is not set |
| 1794 | CONFIG_DEBUG_PREEMPT=y | ||
| 1762 | # CONFIG_DEBUG_RT_MUTEXES is not set | 1795 | # CONFIG_DEBUG_RT_MUTEXES is not set |
| 1763 | # CONFIG_RT_MUTEX_TESTER is not set | 1796 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1764 | # CONFIG_DEBUG_SPINLOCK is not set | 1797 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1765 | # CONFIG_DEBUG_MUTEXES is not set | 1798 | # CONFIG_DEBUG_MUTEXES is not set |
| 1799 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1800 | # CONFIG_PROVE_LOCKING is not set | ||
| 1801 | # CONFIG_LOCK_STAT is not set | ||
| 1766 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1802 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1767 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1803 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1768 | # CONFIG_DEBUG_KOBJECT is not set | 1804 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1774,7 +1810,6 @@ CONFIG_DEBUG_INFO=y | |||
| 1774 | # CONFIG_DEBUG_LIST is not set | 1810 | # CONFIG_DEBUG_LIST is not set |
| 1775 | # CONFIG_DEBUG_SG is not set | 1811 | # CONFIG_DEBUG_SG is not set |
| 1776 | # CONFIG_DEBUG_NOTIFIERS is not set | 1812 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1777 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1778 | # CONFIG_RCU_TORTURE_TEST is not set | 1813 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1779 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1814 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1780 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1815 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1788,17 +1823,16 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1788 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1823 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1789 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1824 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1790 | CONFIG_TRACING_SUPPORT=y | 1825 | CONFIG_TRACING_SUPPORT=y |
| 1791 | 1826 | CONFIG_FTRACE=y | |
| 1792 | # | ||
| 1793 | # Tracers | ||
| 1794 | # | ||
| 1795 | # CONFIG_FUNCTION_TRACER is not set | 1827 | # CONFIG_FUNCTION_TRACER is not set |
| 1828 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1796 | # CONFIG_PREEMPT_TRACER is not set | 1829 | # CONFIG_PREEMPT_TRACER is not set |
| 1797 | # CONFIG_SCHED_TRACER is not set | 1830 | # CONFIG_SCHED_TRACER is not set |
| 1798 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1831 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1799 | # CONFIG_EVENT_TRACER is not set | ||
| 1800 | # CONFIG_BOOT_TRACER is not set | 1832 | # CONFIG_BOOT_TRACER is not set |
| 1801 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1833 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1834 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1835 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1802 | # CONFIG_STACK_TRACER is not set | 1836 | # CONFIG_STACK_TRACER is not set |
| 1803 | # CONFIG_KMEMTRACE is not set | 1837 | # CONFIG_KMEMTRACE is not set |
| 1804 | # CONFIG_WORKQUEUE_TRACER is not set | 1838 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -1806,6 +1840,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 1806 | # CONFIG_SAMPLES is not set | 1840 | # CONFIG_SAMPLES is not set |
| 1807 | CONFIG_HAVE_ARCH_KGDB=y | 1841 | CONFIG_HAVE_ARCH_KGDB=y |
| 1808 | # CONFIG_KGDB is not set | 1842 | # CONFIG_KGDB is not set |
| 1843 | # CONFIG_KMEMCHECK is not set | ||
| 1844 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1845 | CONFIG_PPC_WERROR=y | ||
| 1809 | CONFIG_PRINT_STACK_DEPTH=64 | 1846 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1810 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1847 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1811 | # CONFIG_DEBUG_STACK_USAGE is not set | 1848 | # CONFIG_DEBUG_STACK_USAGE is not set |
| @@ -1829,7 +1866,6 @@ CONFIG_SECURITY_NETWORK=y | |||
| 1829 | # CONFIG_SECURITY_PATH is not set | 1866 | # CONFIG_SECURITY_PATH is not set |
| 1830 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set | 1867 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set |
| 1831 | # CONFIG_SECURITY_ROOTPLUG is not set | 1868 | # CONFIG_SECURITY_ROOTPLUG is not set |
| 1832 | CONFIG_SECURITY_DEFAULT_MMAP_MIN_ADDR=0 | ||
| 1833 | # CONFIG_SECURITY_TOMOYO is not set | 1869 | # CONFIG_SECURITY_TOMOYO is not set |
| 1834 | CONFIG_CRYPTO=y | 1870 | CONFIG_CRYPTO=y |
| 1835 | 1871 | ||
diff --git a/arch/powerpc/configs/86xx/mpc8610_hpcd_defconfig b/arch/powerpc/configs/86xx/mpc8610_hpcd_defconfig index cfd2efcc6bce..a61f183f7186 100644 --- a/arch/powerpc/configs/86xx/mpc8610_hpcd_defconfig +++ b/arch/powerpc/configs/86xx/mpc8610_hpcd_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:28 2009 | 4 | # Wed Jul 29 23:32:27 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_PHYS_64BIT is not set | 20 | # CONFIG_PHYS_64BIT is not set |
| 20 | CONFIG_ALTIVEC=y | 21 | CONFIG_ALTIVEC=y |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 45 | CONFIG_PPC=y | 48 | CONFIG_PPC=y |
| @@ -53,11 +56,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 57 | # CONFIG_PPC_DCR_NATIVE is not set | 61 | # CONFIG_PPC_DCR_NATIVE is not set |
| 58 | # CONFIG_PPC_DCR_MMIO is not set | 62 | # CONFIG_PPC_DCR_MMIO is not set |
| 59 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 63 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 60 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 64 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 65 | CONFIG_CONSTRUCTORS=y | ||
| 61 | 66 | ||
| 62 | # | 67 | # |
| 63 | # General setup | 68 | # General setup |
| @@ -109,7 +114,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 109 | CONFIG_KALLSYMS=y | 114 | CONFIG_KALLSYMS=y |
| 110 | # CONFIG_KALLSYMS_ALL is not set | 115 | # CONFIG_KALLSYMS_ALL is not set |
| 111 | CONFIG_KALLSYMS_EXTRA_PASS=y | 116 | CONFIG_KALLSYMS_EXTRA_PASS=y |
| 112 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 113 | CONFIG_HOTPLUG=y | 117 | CONFIG_HOTPLUG=y |
| 114 | CONFIG_PRINTK=y | 118 | CONFIG_PRINTK=y |
| 115 | CONFIG_BUG=y | 119 | CONFIG_BUG=y |
| @@ -122,9 +126,16 @@ CONFIG_TIMERFD=y | |||
| 122 | CONFIG_EVENTFD=y | 126 | CONFIG_EVENTFD=y |
| 123 | CONFIG_SHMEM=y | 127 | CONFIG_SHMEM=y |
| 124 | CONFIG_AIO=y | 128 | CONFIG_AIO=y |
| 129 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 130 | |||
| 131 | # | ||
| 132 | # Performance Counters | ||
| 133 | # | ||
| 134 | # CONFIG_PERF_COUNTERS is not set | ||
| 125 | CONFIG_VM_EVENT_COUNTERS=y | 135 | CONFIG_VM_EVENT_COUNTERS=y |
| 126 | CONFIG_PCI_QUIRKS=y | 136 | CONFIG_PCI_QUIRKS=y |
| 127 | CONFIG_SLUB_DEBUG=y | 137 | CONFIG_SLUB_DEBUG=y |
| 138 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 128 | CONFIG_COMPAT_BRK=y | 139 | CONFIG_COMPAT_BRK=y |
| 129 | # CONFIG_SLAB is not set | 140 | # CONFIG_SLAB is not set |
| 130 | CONFIG_SLUB=y | 141 | CONFIG_SLUB=y |
| @@ -138,6 +149,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 138 | CONFIG_HAVE_KPROBES=y | 149 | CONFIG_HAVE_KPROBES=y |
| 139 | CONFIG_HAVE_KRETPROBES=y | 150 | CONFIG_HAVE_KRETPROBES=y |
| 140 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 151 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 152 | |||
| 153 | # | ||
| 154 | # GCOV-based kernel profiling | ||
| 155 | # | ||
| 141 | # CONFIG_SLOW_WORK is not set | 156 | # CONFIG_SLOW_WORK is not set |
| 142 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 157 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 143 | CONFIG_SLABINFO=y | 158 | CONFIG_SLABINFO=y |
| @@ -150,7 +165,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 150 | # CONFIG_MODVERSIONS is not set | 165 | # CONFIG_MODVERSIONS is not set |
| 151 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 166 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 152 | CONFIG_BLOCK=y | 167 | CONFIG_BLOCK=y |
| 153 | # CONFIG_LBD is not set | 168 | CONFIG_LBDAF=y |
| 154 | # CONFIG_BLK_DEV_BSG is not set | 169 | # CONFIG_BLK_DEV_BSG is not set |
| 155 | # CONFIG_BLK_DEV_INTEGRITY is not set | 170 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 156 | 171 | ||
| @@ -230,6 +245,7 @@ CONFIG_BINFMT_ELF=y | |||
| 230 | # CONFIG_HAVE_AOUT is not set | 245 | # CONFIG_HAVE_AOUT is not set |
| 231 | # CONFIG_BINFMT_MISC is not set | 246 | # CONFIG_BINFMT_MISC is not set |
| 232 | # CONFIG_IOMMU_HELPER is not set | 247 | # CONFIG_IOMMU_HELPER is not set |
| 248 | # CONFIG_SWIOTLB is not set | ||
| 233 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 249 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 234 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 250 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 235 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 251 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -250,9 +266,9 @@ CONFIG_MIGRATION=y | |||
| 250 | CONFIG_ZONE_DMA_FLAG=1 | 266 | CONFIG_ZONE_DMA_FLAG=1 |
| 251 | CONFIG_BOUNCE=y | 267 | CONFIG_BOUNCE=y |
| 252 | CONFIG_VIRT_TO_BUS=y | 268 | CONFIG_VIRT_TO_BUS=y |
| 253 | CONFIG_UNEVICTABLE_LRU=y | ||
| 254 | CONFIG_HAVE_MLOCK=y | 269 | CONFIG_HAVE_MLOCK=y |
| 255 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 270 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 271 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 256 | CONFIG_PPC_4K_PAGES=y | 272 | CONFIG_PPC_4K_PAGES=y |
| 257 | # CONFIG_PPC_16K_PAGES is not set | 273 | # CONFIG_PPC_16K_PAGES is not set |
| 258 | # CONFIG_PPC_64K_PAGES is not set | 274 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -279,6 +295,8 @@ CONFIG_PCI_DOMAINS=y | |||
| 279 | CONFIG_PCI_SYSCALL=y | 295 | CONFIG_PCI_SYSCALL=y |
| 280 | CONFIG_PCIEPORTBUS=y | 296 | CONFIG_PCIEPORTBUS=y |
| 281 | CONFIG_PCIEAER=y | 297 | CONFIG_PCIEAER=y |
| 298 | # CONFIG_PCIE_ECRC is not set | ||
| 299 | # CONFIG_PCIEAER_INJECT is not set | ||
| 282 | # CONFIG_PCIEASPM is not set | 300 | # CONFIG_PCIEASPM is not set |
| 283 | CONFIG_ARCH_SUPPORTS_MSI=y | 301 | CONFIG_ARCH_SUPPORTS_MSI=y |
| 284 | # CONFIG_PCI_MSI is not set | 302 | # CONFIG_PCI_MSI is not set |
| @@ -381,6 +399,7 @@ CONFIG_IPV6_NDISC_NODETYPE=y | |||
| 381 | # CONFIG_ECONET is not set | 399 | # CONFIG_ECONET is not set |
| 382 | # CONFIG_WAN_ROUTER is not set | 400 | # CONFIG_WAN_ROUTER is not set |
| 383 | # CONFIG_PHONET is not set | 401 | # CONFIG_PHONET is not set |
| 402 | # CONFIG_IEEE802154 is not set | ||
| 384 | # CONFIG_NET_SCHED is not set | 403 | # CONFIG_NET_SCHED is not set |
| 385 | # CONFIG_DCB is not set | 404 | # CONFIG_DCB is not set |
| 386 | 405 | ||
| @@ -398,7 +417,11 @@ CONFIG_WIRELESS=y | |||
| 398 | CONFIG_WIRELESS_OLD_REGULATORY=y | 417 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 399 | # CONFIG_WIRELESS_EXT is not set | 418 | # CONFIG_WIRELESS_EXT is not set |
| 400 | # CONFIG_LIB80211 is not set | 419 | # CONFIG_LIB80211 is not set |
| 401 | # CONFIG_MAC80211 is not set | 420 | |
| 421 | # | ||
| 422 | # CFG80211 needs to be enabled for MAC80211 | ||
| 423 | # | ||
| 424 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 402 | # CONFIG_WIMAX is not set | 425 | # CONFIG_WIMAX is not set |
| 403 | # CONFIG_RFKILL is not set | 426 | # CONFIG_RFKILL is not set |
| 404 | # CONFIG_NET_9P is not set | 427 | # CONFIG_NET_9P is not set |
| @@ -549,7 +572,9 @@ CONFIG_MISC_DEVICES=y | |||
| 549 | # | 572 | # |
| 550 | # CONFIG_EEPROM_AT24 is not set | 573 | # CONFIG_EEPROM_AT24 is not set |
| 551 | # CONFIG_EEPROM_LEGACY is not set | 574 | # CONFIG_EEPROM_LEGACY is not set |
| 575 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 552 | # CONFIG_EEPROM_93CX6 is not set | 576 | # CONFIG_EEPROM_93CX6 is not set |
| 577 | # CONFIG_CB710_CORE is not set | ||
| 553 | CONFIG_HAVE_IDE=y | 578 | CONFIG_HAVE_IDE=y |
| 554 | CONFIG_IDE=y | 579 | CONFIG_IDE=y |
| 555 | 580 | ||
| @@ -620,10 +645,6 @@ CONFIG_BLK_DEV_SD=y | |||
| 620 | # CONFIG_BLK_DEV_SR is not set | 645 | # CONFIG_BLK_DEV_SR is not set |
| 621 | CONFIG_CHR_DEV_SG=y | 646 | CONFIG_CHR_DEV_SG=y |
| 622 | # CONFIG_CHR_DEV_SCH is not set | 647 | # CONFIG_CHR_DEV_SCH is not set |
| 623 | |||
| 624 | # | ||
| 625 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 626 | # | ||
| 627 | # CONFIG_SCSI_MULTI_LUN is not set | 648 | # CONFIG_SCSI_MULTI_LUN is not set |
| 628 | # CONFIG_SCSI_CONSTANTS is not set | 649 | # CONFIG_SCSI_CONSTANTS is not set |
| 629 | # CONFIG_SCSI_LOGGING is not set | 650 | # CONFIG_SCSI_LOGGING is not set |
| @@ -640,6 +661,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 640 | # CONFIG_SCSI_SRP_ATTRS is not set | 661 | # CONFIG_SCSI_SRP_ATTRS is not set |
| 641 | CONFIG_SCSI_LOWLEVEL=y | 662 | CONFIG_SCSI_LOWLEVEL=y |
| 642 | # CONFIG_ISCSI_TCP is not set | 663 | # CONFIG_ISCSI_TCP is not set |
| 664 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 643 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 665 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 644 | # CONFIG_SCSI_3W_9XXX is not set | 666 | # CONFIG_SCSI_3W_9XXX is not set |
| 645 | # CONFIG_SCSI_ACARD is not set | 667 | # CONFIG_SCSI_ACARD is not set |
| @@ -648,6 +670,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 648 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 670 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 649 | # CONFIG_SCSI_AIC79XX is not set | 671 | # CONFIG_SCSI_AIC79XX is not set |
| 650 | # CONFIG_SCSI_AIC94XX is not set | 672 | # CONFIG_SCSI_AIC94XX is not set |
| 673 | # CONFIG_SCSI_MVSAS is not set | ||
| 651 | # CONFIG_SCSI_DPT_I2O is not set | 674 | # CONFIG_SCSI_DPT_I2O is not set |
| 652 | # CONFIG_SCSI_ADVANSYS is not set | 675 | # CONFIG_SCSI_ADVANSYS is not set |
| 653 | # CONFIG_SCSI_ARCMSR is not set | 676 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -667,7 +690,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 667 | # CONFIG_SCSI_IPS is not set | 690 | # CONFIG_SCSI_IPS is not set |
| 668 | # CONFIG_SCSI_INITIO is not set | 691 | # CONFIG_SCSI_INITIO is not set |
| 669 | # CONFIG_SCSI_INIA100 is not set | 692 | # CONFIG_SCSI_INIA100 is not set |
| 670 | # CONFIG_SCSI_MVSAS is not set | ||
| 671 | # CONFIG_SCSI_STEX is not set | 693 | # CONFIG_SCSI_STEX is not set |
| 672 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 694 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 673 | # CONFIG_SCSI_IPR is not set | 695 | # CONFIG_SCSI_IPR is not set |
| @@ -751,14 +773,17 @@ CONFIG_PATA_ALI=y | |||
| 751 | # | 773 | # |
| 752 | 774 | ||
| 753 | # | 775 | # |
| 754 | # Enable only one of the two stacks, unless you know what you are doing | 776 | # You can enable one or both FireWire driver stacks. |
| 777 | # | ||
| 778 | |||
| 779 | # | ||
| 780 | # See the help texts for more information. | ||
| 755 | # | 781 | # |
| 756 | # CONFIG_FIREWIRE is not set | 782 | # CONFIG_FIREWIRE is not set |
| 757 | # CONFIG_IEEE1394 is not set | 783 | # CONFIG_IEEE1394 is not set |
| 758 | # CONFIG_I2O is not set | 784 | # CONFIG_I2O is not set |
| 759 | # CONFIG_MACINTOSH_DRIVERS is not set | 785 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 760 | CONFIG_NETDEVICES=y | 786 | CONFIG_NETDEVICES=y |
| 761 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 762 | CONFIG_DUMMY=y | 787 | CONFIG_DUMMY=y |
| 763 | # CONFIG_BONDING is not set | 788 | # CONFIG_BONDING is not set |
| 764 | # CONFIG_MACVLAN is not set | 789 | # CONFIG_MACVLAN is not set |
| @@ -792,6 +817,7 @@ CONFIG_ULI526X=y | |||
| 792 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 817 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 793 | # CONFIG_NET_PCI is not set | 818 | # CONFIG_NET_PCI is not set |
| 794 | # CONFIG_B44 is not set | 819 | # CONFIG_B44 is not set |
| 820 | # CONFIG_KS8842 is not set | ||
| 795 | # CONFIG_ATL2 is not set | 821 | # CONFIG_ATL2 is not set |
| 796 | # CONFIG_NETDEV_1000 is not set | 822 | # CONFIG_NETDEV_1000 is not set |
| 797 | # CONFIG_NETDEV_10000 is not set | 823 | # CONFIG_NETDEV_10000 is not set |
| @@ -959,13 +985,17 @@ CONFIG_I2C_MPC=y | |||
| 959 | # CONFIG_SENSORS_PCF8574 is not set | 985 | # CONFIG_SENSORS_PCF8574 is not set |
| 960 | # CONFIG_PCF8575 is not set | 986 | # CONFIG_PCF8575 is not set |
| 961 | # CONFIG_SENSORS_PCA9539 is not set | 987 | # CONFIG_SENSORS_PCA9539 is not set |
| 962 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 963 | # CONFIG_SENSORS_TSL2550 is not set | 988 | # CONFIG_SENSORS_TSL2550 is not set |
| 964 | # CONFIG_I2C_DEBUG_CORE is not set | 989 | # CONFIG_I2C_DEBUG_CORE is not set |
| 965 | # CONFIG_I2C_DEBUG_ALGO is not set | 990 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 966 | # CONFIG_I2C_DEBUG_BUS is not set | 991 | # CONFIG_I2C_DEBUG_BUS is not set |
| 967 | # CONFIG_I2C_DEBUG_CHIP is not set | 992 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 968 | # CONFIG_SPI is not set | 993 | # CONFIG_SPI is not set |
| 994 | |||
| 995 | # | ||
| 996 | # PPS support | ||
| 997 | # | ||
| 998 | # CONFIG_PPS is not set | ||
| 969 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 999 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 970 | # CONFIG_GPIOLIB is not set | 1000 | # CONFIG_GPIOLIB is not set |
| 971 | # CONFIG_W1 is not set | 1001 | # CONFIG_W1 is not set |
| @@ -993,23 +1023,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 993 | # CONFIG_MFD_WM8400 is not set | 1023 | # CONFIG_MFD_WM8400 is not set |
| 994 | # CONFIG_MFD_WM8350_I2C is not set | 1024 | # CONFIG_MFD_WM8350_I2C is not set |
| 995 | # CONFIG_MFD_PCF50633 is not set | 1025 | # CONFIG_MFD_PCF50633 is not set |
| 1026 | # CONFIG_AB3100_CORE is not set | ||
| 996 | # CONFIG_REGULATOR is not set | 1027 | # CONFIG_REGULATOR is not set |
| 997 | 1028 | # CONFIG_MEDIA_SUPPORT is not set | |
| 998 | # | ||
| 999 | # Multimedia devices | ||
| 1000 | # | ||
| 1001 | |||
| 1002 | # | ||
| 1003 | # Multimedia core support | ||
| 1004 | # | ||
| 1005 | # CONFIG_VIDEO_DEV is not set | ||
| 1006 | # CONFIG_DVB_CORE is not set | ||
| 1007 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1008 | |||
| 1009 | # | ||
| 1010 | # Multimedia drivers | ||
| 1011 | # | ||
| 1012 | CONFIG_DAB=y | ||
| 1013 | 1029 | ||
| 1014 | # | 1030 | # |
| 1015 | # Graphics support | 1031 | # Graphics support |
| @@ -1106,6 +1122,11 @@ CONFIG_SND_PCM_OSS_PLUGINS=y | |||
| 1106 | CONFIG_SND_VERBOSE_PROCFS=y | 1122 | CONFIG_SND_VERBOSE_PROCFS=y |
| 1107 | # CONFIG_SND_VERBOSE_PRINTK is not set | 1123 | # CONFIG_SND_VERBOSE_PRINTK is not set |
| 1108 | # CONFIG_SND_DEBUG is not set | 1124 | # CONFIG_SND_DEBUG is not set |
| 1125 | # CONFIG_SND_RAWMIDI_SEQ is not set | ||
| 1126 | # CONFIG_SND_OPL3_LIB_SEQ is not set | ||
| 1127 | # CONFIG_SND_OPL4_LIB_SEQ is not set | ||
| 1128 | # CONFIG_SND_SBAWE_SEQ is not set | ||
| 1129 | # CONFIG_SND_EMU10K1_SEQ is not set | ||
| 1109 | CONFIG_SND_DRIVERS=y | 1130 | CONFIG_SND_DRIVERS=y |
| 1110 | # CONFIG_SND_DUMMY is not set | 1131 | # CONFIG_SND_DUMMY is not set |
| 1111 | # CONFIG_SND_MTPAV is not set | 1132 | # CONFIG_SND_MTPAV is not set |
| @@ -1130,6 +1151,7 @@ CONFIG_SND_PCI=y | |||
| 1130 | # CONFIG_SND_CS4281 is not set | 1151 | # CONFIG_SND_CS4281 is not set |
| 1131 | # CONFIG_SND_CS46XX is not set | 1152 | # CONFIG_SND_CS46XX is not set |
| 1132 | # CONFIG_SND_CS5530 is not set | 1153 | # CONFIG_SND_CS5530 is not set |
| 1154 | # CONFIG_SND_CTXFI is not set | ||
| 1133 | # CONFIG_SND_DARLA20 is not set | 1155 | # CONFIG_SND_DARLA20 is not set |
| 1134 | # CONFIG_SND_GINA20 is not set | 1156 | # CONFIG_SND_GINA20 is not set |
| 1135 | # CONFIG_SND_LAYLA20 is not set | 1157 | # CONFIG_SND_LAYLA20 is not set |
| @@ -1160,6 +1182,7 @@ CONFIG_SND_PCI=y | |||
| 1160 | # CONFIG_SND_INTEL8X0 is not set | 1182 | # CONFIG_SND_INTEL8X0 is not set |
| 1161 | # CONFIG_SND_INTEL8X0M is not set | 1183 | # CONFIG_SND_INTEL8X0M is not set |
| 1162 | # CONFIG_SND_KORG1212 is not set | 1184 | # CONFIG_SND_KORG1212 is not set |
| 1185 | # CONFIG_SND_LX6464ES is not set | ||
| 1163 | # CONFIG_SND_MAESTRO3 is not set | 1186 | # CONFIG_SND_MAESTRO3 is not set |
| 1164 | # CONFIG_SND_MIXART is not set | 1187 | # CONFIG_SND_MIXART is not set |
| 1165 | # CONFIG_SND_NM256 is not set | 1188 | # CONFIG_SND_NM256 is not set |
| @@ -1251,6 +1274,7 @@ CONFIG_RTC_INTF_DEV=y | |||
| 1251 | # CONFIG_RTC_DRV_S35390A is not set | 1274 | # CONFIG_RTC_DRV_S35390A is not set |
| 1252 | # CONFIG_RTC_DRV_FM3130 is not set | 1275 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1253 | # CONFIG_RTC_DRV_RX8581 is not set | 1276 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1277 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1254 | 1278 | ||
| 1255 | # | 1279 | # |
| 1256 | # SPI RTC drivers | 1280 | # SPI RTC drivers |
| @@ -1278,6 +1302,10 @@ CONFIG_RTC_DRV_CMOS=y | |||
| 1278 | # CONFIG_DMADEVICES is not set | 1302 | # CONFIG_DMADEVICES is not set |
| 1279 | # CONFIG_AUXDISPLAY is not set | 1303 | # CONFIG_AUXDISPLAY is not set |
| 1280 | # CONFIG_UIO is not set | 1304 | # CONFIG_UIO is not set |
| 1305 | |||
| 1306 | # | ||
| 1307 | # TI VLYNQ | ||
| 1308 | # | ||
| 1281 | # CONFIG_STAGING is not set | 1309 | # CONFIG_STAGING is not set |
| 1282 | 1310 | ||
| 1283 | # | 1311 | # |
| @@ -1297,12 +1325,15 @@ CONFIG_FS_MBCACHE=y | |||
| 1297 | # CONFIG_REISERFS_FS is not set | 1325 | # CONFIG_REISERFS_FS is not set |
| 1298 | # CONFIG_JFS_FS is not set | 1326 | # CONFIG_JFS_FS is not set |
| 1299 | # CONFIG_FS_POSIX_ACL is not set | 1327 | # CONFIG_FS_POSIX_ACL is not set |
| 1300 | CONFIG_FILE_LOCKING=y | ||
| 1301 | # CONFIG_XFS_FS is not set | 1328 | # CONFIG_XFS_FS is not set |
| 1329 | # CONFIG_GFS2_FS is not set | ||
| 1302 | # CONFIG_OCFS2_FS is not set | 1330 | # CONFIG_OCFS2_FS is not set |
| 1303 | # CONFIG_BTRFS_FS is not set | 1331 | # CONFIG_BTRFS_FS is not set |
| 1332 | CONFIG_FILE_LOCKING=y | ||
| 1333 | CONFIG_FSNOTIFY=y | ||
| 1304 | # CONFIG_DNOTIFY is not set | 1334 | # CONFIG_DNOTIFY is not set |
| 1305 | # CONFIG_INOTIFY is not set | 1335 | # CONFIG_INOTIFY is not set |
| 1336 | CONFIG_INOTIFY_USER=y | ||
| 1306 | # CONFIG_QUOTA is not set | 1337 | # CONFIG_QUOTA is not set |
| 1307 | # CONFIG_AUTOFS_FS is not set | 1338 | # CONFIG_AUTOFS_FS is not set |
| 1308 | # CONFIG_AUTOFS4_FS is not set | 1339 | # CONFIG_AUTOFS4_FS is not set |
| @@ -1464,6 +1495,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1464 | CONFIG_HAS_DMA=y | 1495 | CONFIG_HAS_DMA=y |
| 1465 | CONFIG_HAVE_LMB=y | 1496 | CONFIG_HAVE_LMB=y |
| 1466 | CONFIG_NLATTR=y | 1497 | CONFIG_NLATTR=y |
| 1498 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1467 | 1499 | ||
| 1468 | # | 1500 | # |
| 1469 | # Kernel hacking | 1501 | # Kernel hacking |
| @@ -1494,6 +1526,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 1494 | # CONFIG_RT_MUTEX_TESTER is not set | 1526 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1495 | # CONFIG_DEBUG_SPINLOCK is not set | 1527 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1496 | # CONFIG_DEBUG_MUTEXES is not set | 1528 | # CONFIG_DEBUG_MUTEXES is not set |
| 1529 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1530 | # CONFIG_PROVE_LOCKING is not set | ||
| 1531 | # CONFIG_LOCK_STAT is not set | ||
| 1497 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1532 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1498 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1533 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1499 | # CONFIG_DEBUG_KOBJECT is not set | 1534 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1506,7 +1541,6 @@ CONFIG_DEBUG_INFO=y | |||
| 1506 | # CONFIG_DEBUG_LIST is not set | 1541 | # CONFIG_DEBUG_LIST is not set |
| 1507 | # CONFIG_DEBUG_SG is not set | 1542 | # CONFIG_DEBUG_SG is not set |
| 1508 | # CONFIG_DEBUG_NOTIFIERS is not set | 1543 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1509 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1510 | # CONFIG_RCU_TORTURE_TEST is not set | 1544 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1511 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1545 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1512 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1546 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1520,16 +1554,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1520 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1554 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1521 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1555 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1522 | CONFIG_TRACING_SUPPORT=y | 1556 | CONFIG_TRACING_SUPPORT=y |
| 1523 | 1557 | CONFIG_FTRACE=y | |
| 1524 | # | ||
| 1525 | # Tracers | ||
| 1526 | # | ||
| 1527 | # CONFIG_FUNCTION_TRACER is not set | 1558 | # CONFIG_FUNCTION_TRACER is not set |
| 1559 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1528 | # CONFIG_SCHED_TRACER is not set | 1560 | # CONFIG_SCHED_TRACER is not set |
| 1529 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1561 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1530 | # CONFIG_EVENT_TRACER is not set | ||
| 1531 | # CONFIG_BOOT_TRACER is not set | 1562 | # CONFIG_BOOT_TRACER is not set |
| 1532 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1563 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1564 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1565 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1533 | # CONFIG_STACK_TRACER is not set | 1566 | # CONFIG_STACK_TRACER is not set |
| 1534 | # CONFIG_KMEMTRACE is not set | 1567 | # CONFIG_KMEMTRACE is not set |
| 1535 | # CONFIG_WORKQUEUE_TRACER is not set | 1568 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -1537,6 +1570,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 1537 | # CONFIG_SAMPLES is not set | 1570 | # CONFIG_SAMPLES is not set |
| 1538 | CONFIG_HAVE_ARCH_KGDB=y | 1571 | CONFIG_HAVE_ARCH_KGDB=y |
| 1539 | # CONFIG_KGDB is not set | 1572 | # CONFIG_KGDB is not set |
| 1573 | # CONFIG_KMEMCHECK is not set | ||
| 1574 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1575 | CONFIG_PPC_WERROR=y | ||
| 1540 | CONFIG_PRINT_STACK_DEPTH=64 | 1576 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1541 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1577 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1542 | # CONFIG_DEBUG_STACK_USAGE is not set | 1578 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/86xx/mpc8641_hpcn_defconfig b/arch/powerpc/configs/86xx/mpc8641_hpcn_defconfig index 0bee3e303942..7016ce732605 100644 --- a/arch/powerpc/configs/86xx/mpc8641_hpcn_defconfig +++ b/arch/powerpc/configs/86xx/mpc8641_hpcn_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:28 2009 | 4 | # Wed Jul 29 23:32:28 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_PHYS_64BIT is not set | 20 | # CONFIG_PHYS_64BIT is not set |
| 20 | CONFIG_ALTIVEC=y | 21 | CONFIG_ALTIVEC=y |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | CONFIG_SMP=y | 26 | CONFIG_SMP=y |
| 25 | CONFIG_NR_CPUS=2 | 27 | CONFIG_NR_CPUS=2 |
| 26 | CONFIG_PPC32=y | 28 | CONFIG_PPC32=y |
| @@ -32,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 32 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 33 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 34 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 35 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 36 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 37 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 38 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 39 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 40 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 41 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 42 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 43 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 44 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 45 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 46 | CONFIG_PPC=y | 49 | CONFIG_PPC=y |
| @@ -54,11 +57,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 54 | CONFIG_GENERIC_TBSYNC=y | 57 | CONFIG_GENERIC_TBSYNC=y |
| 55 | CONFIG_AUDIT_ARCH=y | 58 | CONFIG_AUDIT_ARCH=y |
| 56 | CONFIG_GENERIC_BUG=y | 59 | CONFIG_GENERIC_BUG=y |
| 60 | CONFIG_DTC=y | ||
| 57 | CONFIG_DEFAULT_UIMAGE=y | 61 | CONFIG_DEFAULT_UIMAGE=y |
| 58 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 59 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 60 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 61 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 62 | 67 | ||
| 63 | # | 68 | # |
| 64 | # General setup | 69 | # General setup |
| @@ -113,7 +118,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 113 | CONFIG_KALLSYMS=y | 118 | CONFIG_KALLSYMS=y |
| 114 | CONFIG_KALLSYMS_ALL=y | 119 | CONFIG_KALLSYMS_ALL=y |
| 115 | CONFIG_KALLSYMS_EXTRA_PASS=y | 120 | CONFIG_KALLSYMS_EXTRA_PASS=y |
| 116 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 117 | CONFIG_HOTPLUG=y | 121 | CONFIG_HOTPLUG=y |
| 118 | CONFIG_PRINTK=y | 122 | CONFIG_PRINTK=y |
| 119 | CONFIG_BUG=y | 123 | CONFIG_BUG=y |
| @@ -126,9 +130,16 @@ CONFIG_TIMERFD=y | |||
| 126 | CONFIG_EVENTFD=y | 130 | CONFIG_EVENTFD=y |
| 127 | CONFIG_SHMEM=y | 131 | CONFIG_SHMEM=y |
| 128 | CONFIG_AIO=y | 132 | CONFIG_AIO=y |
| 133 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 134 | |||
| 135 | # | ||
| 136 | # Performance Counters | ||
| 137 | # | ||
| 138 | # CONFIG_PERF_COUNTERS is not set | ||
| 129 | CONFIG_VM_EVENT_COUNTERS=y | 139 | CONFIG_VM_EVENT_COUNTERS=y |
| 130 | CONFIG_PCI_QUIRKS=y | 140 | CONFIG_PCI_QUIRKS=y |
| 131 | CONFIG_SLUB_DEBUG=y | 141 | CONFIG_SLUB_DEBUG=y |
| 142 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 132 | CONFIG_COMPAT_BRK=y | 143 | CONFIG_COMPAT_BRK=y |
| 133 | # CONFIG_SLAB is not set | 144 | # CONFIG_SLAB is not set |
| 134 | CONFIG_SLUB=y | 145 | CONFIG_SLUB=y |
| @@ -143,6 +154,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 143 | CONFIG_HAVE_KRETPROBES=y | 154 | CONFIG_HAVE_KRETPROBES=y |
| 144 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 155 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 145 | CONFIG_USE_GENERIC_SMP_HELPERS=y | 156 | CONFIG_USE_GENERIC_SMP_HELPERS=y |
| 157 | |||
| 158 | # | ||
| 159 | # GCOV-based kernel profiling | ||
| 160 | # | ||
| 146 | # CONFIG_SLOW_WORK is not set | 161 | # CONFIG_SLOW_WORK is not set |
| 147 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 162 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 148 | CONFIG_SLABINFO=y | 163 | CONFIG_SLABINFO=y |
| @@ -156,7 +171,7 @@ CONFIG_MODVERSIONS=y | |||
| 156 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 171 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 157 | CONFIG_STOP_MACHINE=y | 172 | CONFIG_STOP_MACHINE=y |
| 158 | CONFIG_BLOCK=y | 173 | CONFIG_BLOCK=y |
| 159 | CONFIG_LBD=y | 174 | CONFIG_LBDAF=y |
| 160 | # CONFIG_BLK_DEV_BSG is not set | 175 | # CONFIG_BLK_DEV_BSG is not set |
| 161 | # CONFIG_BLK_DEV_INTEGRITY is not set | 176 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 162 | 177 | ||
| @@ -234,7 +249,9 @@ CONFIG_BINFMT_ELF=y | |||
| 234 | # CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set | 249 | # CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set |
| 235 | # CONFIG_HAVE_AOUT is not set | 250 | # CONFIG_HAVE_AOUT is not set |
| 236 | CONFIG_BINFMT_MISC=m | 251 | CONFIG_BINFMT_MISC=m |
| 237 | # CONFIG_IOMMU_HELPER is not set | 252 | CONFIG_IOMMU_HELPER=y |
| 253 | CONFIG_SWIOTLB=y | ||
| 254 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y | ||
| 238 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 255 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 239 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 256 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 240 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 257 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -256,9 +273,9 @@ CONFIG_MIGRATION=y | |||
| 256 | CONFIG_ZONE_DMA_FLAG=1 | 273 | CONFIG_ZONE_DMA_FLAG=1 |
| 257 | CONFIG_BOUNCE=y | 274 | CONFIG_BOUNCE=y |
| 258 | CONFIG_VIRT_TO_BUS=y | 275 | CONFIG_VIRT_TO_BUS=y |
| 259 | CONFIG_UNEVICTABLE_LRU=y | ||
| 260 | CONFIG_HAVE_MLOCK=y | 276 | CONFIG_HAVE_MLOCK=y |
| 261 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 277 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 278 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 262 | CONFIG_PPC_4K_PAGES=y | 279 | CONFIG_PPC_4K_PAGES=y |
| 263 | # CONFIG_PPC_16K_PAGES is not set | 280 | # CONFIG_PPC_16K_PAGES is not set |
| 264 | # CONFIG_PPC_64K_PAGES is not set | 281 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -401,6 +418,7 @@ CONFIG_SCTP_HMAC_MD5=y | |||
| 401 | # CONFIG_ECONET is not set | 418 | # CONFIG_ECONET is not set |
| 402 | # CONFIG_WAN_ROUTER is not set | 419 | # CONFIG_WAN_ROUTER is not set |
| 403 | # CONFIG_PHONET is not set | 420 | # CONFIG_PHONET is not set |
| 421 | # CONFIG_IEEE802154 is not set | ||
| 404 | # CONFIG_NET_SCHED is not set | 422 | # CONFIG_NET_SCHED is not set |
| 405 | # CONFIG_DCB is not set | 423 | # CONFIG_DCB is not set |
| 406 | 424 | ||
| @@ -419,7 +437,11 @@ CONFIG_WIRELESS=y | |||
| 419 | CONFIG_WIRELESS_OLD_REGULATORY=y | 437 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 420 | # CONFIG_WIRELESS_EXT is not set | 438 | # CONFIG_WIRELESS_EXT is not set |
| 421 | # CONFIG_LIB80211 is not set | 439 | # CONFIG_LIB80211 is not set |
| 422 | # CONFIG_MAC80211 is not set | 440 | |
| 441 | # | ||
| 442 | # CFG80211 needs to be enabled for MAC80211 | ||
| 443 | # | ||
| 444 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 423 | # CONFIG_WIMAX is not set | 445 | # CONFIG_WIMAX is not set |
| 424 | # CONFIG_RFKILL is not set | 446 | # CONFIG_RFKILL is not set |
| 425 | # CONFIG_NET_9P is not set | 447 | # CONFIG_NET_9P is not set |
| @@ -444,6 +466,7 @@ CONFIG_EXTRA_FIRMWARE="" | |||
| 444 | # CONFIG_MTD is not set | 466 | # CONFIG_MTD is not set |
| 445 | CONFIG_OF_DEVICE=y | 467 | CONFIG_OF_DEVICE=y |
| 446 | CONFIG_OF_I2C=y | 468 | CONFIG_OF_I2C=y |
| 469 | CONFIG_OF_MDIO=y | ||
| 447 | # CONFIG_PARPORT is not set | 470 | # CONFIG_PARPORT is not set |
| 448 | CONFIG_BLK_DEV=y | 471 | CONFIG_BLK_DEV=y |
| 449 | # CONFIG_BLK_DEV_FD is not set | 472 | # CONFIG_BLK_DEV_FD is not set |
| @@ -479,7 +502,9 @@ CONFIG_MISC_DEVICES=y | |||
| 479 | # | 502 | # |
| 480 | # CONFIG_EEPROM_AT24 is not set | 503 | # CONFIG_EEPROM_AT24 is not set |
| 481 | CONFIG_EEPROM_LEGACY=y | 504 | CONFIG_EEPROM_LEGACY=y |
| 505 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 482 | # CONFIG_EEPROM_93CX6 is not set | 506 | # CONFIG_EEPROM_93CX6 is not set |
| 507 | # CONFIG_CB710_CORE is not set | ||
| 483 | CONFIG_HAVE_IDE=y | 508 | CONFIG_HAVE_IDE=y |
| 484 | # CONFIG_IDE is not set | 509 | # CONFIG_IDE is not set |
| 485 | 510 | ||
| @@ -503,10 +528,6 @@ CONFIG_BLK_DEV_SR=y | |||
| 503 | # CONFIG_BLK_DEV_SR_VENDOR is not set | 528 | # CONFIG_BLK_DEV_SR_VENDOR is not set |
| 504 | CONFIG_CHR_DEV_SG=y | 529 | CONFIG_CHR_DEV_SG=y |
| 505 | # CONFIG_CHR_DEV_SCH is not set | 530 | # CONFIG_CHR_DEV_SCH is not set |
| 506 | |||
| 507 | # | ||
| 508 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 509 | # | ||
| 510 | CONFIG_SCSI_MULTI_LUN=y | 531 | CONFIG_SCSI_MULTI_LUN=y |
| 511 | # CONFIG_SCSI_CONSTANTS is not set | 532 | # CONFIG_SCSI_CONSTANTS is not set |
| 512 | CONFIG_SCSI_LOGGING=y | 533 | CONFIG_SCSI_LOGGING=y |
| @@ -524,6 +545,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 524 | CONFIG_SCSI_LOWLEVEL=y | 545 | CONFIG_SCSI_LOWLEVEL=y |
| 525 | # CONFIG_ISCSI_TCP is not set | 546 | # CONFIG_ISCSI_TCP is not set |
| 526 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 547 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 548 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 527 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 549 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 528 | # CONFIG_SCSI_3W_9XXX is not set | 550 | # CONFIG_SCSI_3W_9XXX is not set |
| 529 | # CONFIG_SCSI_ACARD is not set | 551 | # CONFIG_SCSI_ACARD is not set |
| @@ -532,6 +554,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 532 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 554 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 533 | # CONFIG_SCSI_AIC79XX is not set | 555 | # CONFIG_SCSI_AIC79XX is not set |
| 534 | # CONFIG_SCSI_AIC94XX is not set | 556 | # CONFIG_SCSI_AIC94XX is not set |
| 557 | # CONFIG_SCSI_MVSAS is not set | ||
| 535 | # CONFIG_SCSI_DPT_I2O is not set | 558 | # CONFIG_SCSI_DPT_I2O is not set |
| 536 | # CONFIG_SCSI_ADVANSYS is not set | 559 | # CONFIG_SCSI_ADVANSYS is not set |
| 537 | # CONFIG_SCSI_ARCMSR is not set | 560 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -551,7 +574,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 551 | # CONFIG_SCSI_IPS is not set | 574 | # CONFIG_SCSI_IPS is not set |
| 552 | # CONFIG_SCSI_INITIO is not set | 575 | # CONFIG_SCSI_INITIO is not set |
| 553 | # CONFIG_SCSI_INIA100 is not set | 576 | # CONFIG_SCSI_INIA100 is not set |
| 554 | # CONFIG_SCSI_MVSAS is not set | ||
| 555 | # CONFIG_SCSI_STEX is not set | 577 | # CONFIG_SCSI_STEX is not set |
| 556 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 578 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 557 | # CONFIG_SCSI_IPR is not set | 579 | # CONFIG_SCSI_IPR is not set |
| @@ -635,14 +657,17 @@ CONFIG_PATA_ALI=y | |||
| 635 | # | 657 | # |
| 636 | 658 | ||
| 637 | # | 659 | # |
| 638 | # Enable only one of the two stacks, unless you know what you are doing | 660 | # You can enable one or both FireWire driver stacks. |
| 661 | # | ||
| 662 | |||
| 663 | # | ||
| 664 | # See the help texts for more information. | ||
| 639 | # | 665 | # |
| 640 | # CONFIG_FIREWIRE is not set | 666 | # CONFIG_FIREWIRE is not set |
| 641 | # CONFIG_IEEE1394 is not set | 667 | # CONFIG_IEEE1394 is not set |
| 642 | # CONFIG_I2O is not set | 668 | # CONFIG_I2O is not set |
| 643 | # CONFIG_MACINTOSH_DRIVERS is not set | 669 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 644 | CONFIG_NETDEVICES=y | 670 | CONFIG_NETDEVICES=y |
| 645 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 646 | CONFIG_DUMMY=y | 671 | CONFIG_DUMMY=y |
| 647 | # CONFIG_BONDING is not set | 672 | # CONFIG_BONDING is not set |
| 648 | # CONFIG_MACVLAN is not set | 673 | # CONFIG_MACVLAN is not set |
| @@ -689,6 +714,7 @@ CONFIG_MII=y | |||
| 689 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 714 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 690 | # CONFIG_NET_PCI is not set | 715 | # CONFIG_NET_PCI is not set |
| 691 | # CONFIG_B44 is not set | 716 | # CONFIG_B44 is not set |
| 717 | # CONFIG_KS8842 is not set | ||
| 692 | # CONFIG_ATL2 is not set | 718 | # CONFIG_ATL2 is not set |
| 693 | CONFIG_NETDEV_1000=y | 719 | CONFIG_NETDEV_1000=y |
| 694 | # CONFIG_ACENIC is not set | 720 | # CONFIG_ACENIC is not set |
| @@ -708,8 +734,10 @@ CONFIG_NETDEV_1000=y | |||
| 708 | # CONFIG_VIA_VELOCITY is not set | 734 | # CONFIG_VIA_VELOCITY is not set |
| 709 | # CONFIG_TIGON3 is not set | 735 | # CONFIG_TIGON3 is not set |
| 710 | # CONFIG_BNX2 is not set | 736 | # CONFIG_BNX2 is not set |
| 737 | # CONFIG_CNIC is not set | ||
| 711 | CONFIG_FSL_PQ_MDIO=y | 738 | CONFIG_FSL_PQ_MDIO=y |
| 712 | CONFIG_GIANFAR=y | 739 | CONFIG_GIANFAR=y |
| 740 | # CONFIG_MV643XX_ETH is not set | ||
| 713 | # CONFIG_QLA3XXX is not set | 741 | # CONFIG_QLA3XXX is not set |
| 714 | # CONFIG_ATL1 is not set | 742 | # CONFIG_ATL1 is not set |
| 715 | # CONFIG_ATL1E is not set | 743 | # CONFIG_ATL1E is not set |
| @@ -909,13 +937,17 @@ CONFIG_I2C_MPC=y | |||
| 909 | # CONFIG_SENSORS_PCF8574 is not set | 937 | # CONFIG_SENSORS_PCF8574 is not set |
| 910 | # CONFIG_PCF8575 is not set | 938 | # CONFIG_PCF8575 is not set |
| 911 | # CONFIG_SENSORS_PCA9539 is not set | 939 | # CONFIG_SENSORS_PCA9539 is not set |
| 912 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 913 | # CONFIG_SENSORS_TSL2550 is not set | 940 | # CONFIG_SENSORS_TSL2550 is not set |
| 914 | # CONFIG_I2C_DEBUG_CORE is not set | 941 | # CONFIG_I2C_DEBUG_CORE is not set |
| 915 | # CONFIG_I2C_DEBUG_ALGO is not set | 942 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 916 | # CONFIG_I2C_DEBUG_BUS is not set | 943 | # CONFIG_I2C_DEBUG_BUS is not set |
| 917 | # CONFIG_I2C_DEBUG_CHIP is not set | 944 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 918 | # CONFIG_SPI is not set | 945 | # CONFIG_SPI is not set |
| 946 | |||
| 947 | # | ||
| 948 | # PPS support | ||
| 949 | # | ||
| 950 | # CONFIG_PPS is not set | ||
| 919 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 951 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 920 | # CONFIG_GPIOLIB is not set | 952 | # CONFIG_GPIOLIB is not set |
| 921 | # CONFIG_W1 is not set | 953 | # CONFIG_W1 is not set |
| @@ -943,76 +975,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 943 | # CONFIG_MFD_WM8400 is not set | 975 | # CONFIG_MFD_WM8400 is not set |
| 944 | # CONFIG_MFD_WM8350_I2C is not set | 976 | # CONFIG_MFD_WM8350_I2C is not set |
| 945 | # CONFIG_MFD_PCF50633 is not set | 977 | # CONFIG_MFD_PCF50633 is not set |
| 978 | # CONFIG_AB3100_CORE is not set | ||
| 946 | # CONFIG_REGULATOR is not set | 979 | # CONFIG_REGULATOR is not set |
| 947 | 980 | # CONFIG_MEDIA_SUPPORT is not set | |
| 948 | # | ||
| 949 | # Multimedia devices | ||
| 950 | # | ||
| 951 | |||
| 952 | # | ||
| 953 | # Multimedia core support | ||
| 954 | # | ||
| 955 | # CONFIG_VIDEO_DEV is not set | ||
| 956 | CONFIG_DVB_CORE=m | ||
| 957 | CONFIG_VIDEO_MEDIA=m | ||
| 958 | |||
| 959 | # | ||
| 960 | # Multimedia drivers | ||
| 961 | # | ||
| 962 | # CONFIG_MEDIA_ATTACH is not set | ||
| 963 | CONFIG_MEDIA_TUNER=m | ||
| 964 | # CONFIG_MEDIA_TUNER_CUSTOMISE is not set | ||
| 965 | CONFIG_MEDIA_TUNER_SIMPLE=m | ||
| 966 | CONFIG_MEDIA_TUNER_TDA8290=m | ||
| 967 | CONFIG_MEDIA_TUNER_TDA9887=m | ||
| 968 | CONFIG_MEDIA_TUNER_TEA5761=m | ||
| 969 | CONFIG_MEDIA_TUNER_TEA5767=m | ||
| 970 | CONFIG_MEDIA_TUNER_MT20XX=m | ||
| 971 | CONFIG_MEDIA_TUNER_XC2028=m | ||
| 972 | CONFIG_MEDIA_TUNER_XC5000=m | ||
| 973 | CONFIG_MEDIA_TUNER_MC44S803=m | ||
| 974 | # CONFIG_DVB_DYNAMIC_MINORS is not set | ||
| 975 | CONFIG_DVB_CAPTURE_DRIVERS=y | ||
| 976 | |||
| 977 | # | ||
| 978 | # Supported SAA7146 based PCI Adapters | ||
| 979 | # | ||
| 980 | # CONFIG_TTPCI_EEPROM is not set | ||
| 981 | # CONFIG_DVB_BUDGET_CORE is not set | ||
| 982 | |||
| 983 | # | ||
| 984 | # Supported USB Adapters | ||
| 985 | # | ||
| 986 | # CONFIG_DVB_USB is not set | ||
| 987 | # CONFIG_DVB_TTUSB_BUDGET is not set | ||
| 988 | # CONFIG_DVB_TTUSB_DEC is not set | ||
| 989 | # CONFIG_DVB_SIANO_SMS1XXX is not set | ||
| 990 | |||
| 991 | # | ||
| 992 | # Supported FlexCopII (B2C2) Adapters | ||
| 993 | # | ||
| 994 | # CONFIG_DVB_B2C2_FLEXCOP is not set | ||
| 995 | |||
| 996 | # | ||
| 997 | # Supported BT878 Adapters | ||
| 998 | # | ||
| 999 | |||
| 1000 | # | ||
| 1001 | # Supported Pluto2 Adapters | ||
| 1002 | # | ||
| 1003 | # CONFIG_DVB_PLUTO2 is not set | ||
| 1004 | |||
| 1005 | # | ||
| 1006 | # Supported SDMC DM1105 Adapters | ||
| 1007 | # | ||
| 1008 | # CONFIG_DVB_DM1105 is not set | ||
| 1009 | |||
| 1010 | # | ||
| 1011 | # Supported DVB Frontends | ||
| 1012 | # | ||
| 1013 | # CONFIG_DVB_FE_CUSTOMISE is not set | ||
| 1014 | CONFIG_DAB=y | ||
| 1015 | # CONFIG_USB_DABUSB is not set | ||
| 1016 | 981 | ||
| 1017 | # | 982 | # |
| 1018 | # Graphics support | 983 | # Graphics support |
| @@ -1052,6 +1017,11 @@ CONFIG_SND_VERBOSE_PROCFS=y | |||
| 1052 | # CONFIG_SND_VERBOSE_PRINTK is not set | 1017 | # CONFIG_SND_VERBOSE_PRINTK is not set |
| 1053 | # CONFIG_SND_DEBUG is not set | 1018 | # CONFIG_SND_DEBUG is not set |
| 1054 | CONFIG_SND_VMASTER=y | 1019 | CONFIG_SND_VMASTER=y |
| 1020 | # CONFIG_SND_RAWMIDI_SEQ is not set | ||
| 1021 | # CONFIG_SND_OPL3_LIB_SEQ is not set | ||
| 1022 | # CONFIG_SND_OPL4_LIB_SEQ is not set | ||
| 1023 | # CONFIG_SND_SBAWE_SEQ is not set | ||
| 1024 | # CONFIG_SND_EMU10K1_SEQ is not set | ||
| 1055 | CONFIG_SND_AC97_CODEC=y | 1025 | CONFIG_SND_AC97_CODEC=y |
| 1056 | CONFIG_SND_DRIVERS=y | 1026 | CONFIG_SND_DRIVERS=y |
| 1057 | # CONFIG_SND_DUMMY is not set | 1027 | # CONFIG_SND_DUMMY is not set |
| @@ -1078,6 +1048,7 @@ CONFIG_SND_PCI=y | |||
| 1078 | # CONFIG_SND_CS4281 is not set | 1048 | # CONFIG_SND_CS4281 is not set |
| 1079 | # CONFIG_SND_CS46XX is not set | 1049 | # CONFIG_SND_CS46XX is not set |
| 1080 | # CONFIG_SND_CS5530 is not set | 1050 | # CONFIG_SND_CS5530 is not set |
| 1051 | # CONFIG_SND_CTXFI is not set | ||
| 1081 | # CONFIG_SND_DARLA20 is not set | 1052 | # CONFIG_SND_DARLA20 is not set |
| 1082 | # CONFIG_SND_GINA20 is not set | 1053 | # CONFIG_SND_GINA20 is not set |
| 1083 | # CONFIG_SND_LAYLA20 is not set | 1054 | # CONFIG_SND_LAYLA20 is not set |
| @@ -1108,6 +1079,7 @@ CONFIG_SND_PCI=y | |||
| 1108 | CONFIG_SND_INTEL8X0=y | 1079 | CONFIG_SND_INTEL8X0=y |
| 1109 | # CONFIG_SND_INTEL8X0M is not set | 1080 | # CONFIG_SND_INTEL8X0M is not set |
| 1110 | # CONFIG_SND_KORG1212 is not set | 1081 | # CONFIG_SND_KORG1212 is not set |
| 1082 | # CONFIG_SND_LX6464ES is not set | ||
| 1111 | # CONFIG_SND_MAESTRO3 is not set | 1083 | # CONFIG_SND_MAESTRO3 is not set |
| 1112 | # CONFIG_SND_MIXART is not set | 1084 | # CONFIG_SND_MIXART is not set |
| 1113 | # CONFIG_SND_NM256 is not set | 1085 | # CONFIG_SND_NM256 is not set |
| @@ -1152,7 +1124,7 @@ CONFIG_HID_BELKIN=y | |||
| 1152 | CONFIG_HID_CHERRY=y | 1124 | CONFIG_HID_CHERRY=y |
| 1153 | CONFIG_HID_CHICONY=y | 1125 | CONFIG_HID_CHICONY=y |
| 1154 | CONFIG_HID_CYPRESS=y | 1126 | CONFIG_HID_CYPRESS=y |
| 1155 | # CONFIG_DRAGONRISE_FF is not set | 1127 | # CONFIG_HID_DRAGONRISE is not set |
| 1156 | CONFIG_HID_EZKEY=y | 1128 | CONFIG_HID_EZKEY=y |
| 1157 | # CONFIG_HID_KYE is not set | 1129 | # CONFIG_HID_KYE is not set |
| 1158 | CONFIG_HID_GYRATION=y | 1130 | CONFIG_HID_GYRATION=y |
| @@ -1169,10 +1141,11 @@ CONFIG_HID_PETALYNX=y | |||
| 1169 | CONFIG_HID_SAMSUNG=y | 1141 | CONFIG_HID_SAMSUNG=y |
| 1170 | CONFIG_HID_SONY=y | 1142 | CONFIG_HID_SONY=y |
| 1171 | CONFIG_HID_SUNPLUS=y | 1143 | CONFIG_HID_SUNPLUS=y |
| 1172 | # CONFIG_GREENASIA_FF is not set | 1144 | # CONFIG_HID_GREENASIA is not set |
| 1145 | # CONFIG_HID_SMARTJOYPLUS is not set | ||
| 1173 | # CONFIG_HID_TOPSEED is not set | 1146 | # CONFIG_HID_TOPSEED is not set |
| 1174 | CONFIG_THRUSTMASTER_FF=m | 1147 | # CONFIG_HID_THRUSTMASTER is not set |
| 1175 | CONFIG_ZEROPLUS_FF=m | 1148 | # CONFIG_HID_ZEROPLUS is not set |
| 1176 | CONFIG_USB_SUPPORT=y | 1149 | CONFIG_USB_SUPPORT=y |
| 1177 | CONFIG_USB_ARCH_HAS_HCD=y | 1150 | CONFIG_USB_ARCH_HAS_HCD=y |
| 1178 | CONFIG_USB_ARCH_HAS_OHCI=y | 1151 | CONFIG_USB_ARCH_HAS_OHCI=y |
| @@ -1198,6 +1171,7 @@ CONFIG_USB_MON=y | |||
| 1198 | # USB Host Controller Drivers | 1171 | # USB Host Controller Drivers |
| 1199 | # | 1172 | # |
| 1200 | # CONFIG_USB_C67X00_HCD is not set | 1173 | # CONFIG_USB_C67X00_HCD is not set |
| 1174 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1201 | CONFIG_USB_EHCI_HCD=y | 1175 | CONFIG_USB_EHCI_HCD=y |
| 1202 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set | 1176 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set |
| 1203 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1177 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1207,9 +1181,9 @@ CONFIG_USB_EHCI_HCD_PPC_OF=y | |||
| 1207 | # CONFIG_USB_ISP116X_HCD is not set | 1181 | # CONFIG_USB_ISP116X_HCD is not set |
| 1208 | # CONFIG_USB_ISP1760_HCD is not set | 1182 | # CONFIG_USB_ISP1760_HCD is not set |
| 1209 | CONFIG_USB_OHCI_HCD=y | 1183 | CONFIG_USB_OHCI_HCD=y |
| 1210 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1211 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y | 1184 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y |
| 1212 | CONFIG_USB_OHCI_HCD_PPC_OF_LE=y | 1185 | CONFIG_USB_OHCI_HCD_PPC_OF_LE=y |
| 1186 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1213 | CONFIG_USB_OHCI_HCD_PCI=y | 1187 | CONFIG_USB_OHCI_HCD_PCI=y |
| 1214 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y | 1188 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y |
| 1215 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y | 1189 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y |
| @@ -1329,6 +1303,7 @@ CONFIG_RTC_INTF_DEV=y | |||
| 1329 | # CONFIG_RTC_DRV_S35390A is not set | 1303 | # CONFIG_RTC_DRV_S35390A is not set |
| 1330 | # CONFIG_RTC_DRV_FM3130 is not set | 1304 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1331 | # CONFIG_RTC_DRV_RX8581 is not set | 1305 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1306 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1332 | 1307 | ||
| 1333 | # | 1308 | # |
| 1334 | # SPI RTC drivers | 1309 | # SPI RTC drivers |
| @@ -1356,6 +1331,10 @@ CONFIG_RTC_DRV_CMOS=y | |||
| 1356 | # CONFIG_DMADEVICES is not set | 1331 | # CONFIG_DMADEVICES is not set |
| 1357 | # CONFIG_AUXDISPLAY is not set | 1332 | # CONFIG_AUXDISPLAY is not set |
| 1358 | # CONFIG_UIO is not set | 1333 | # CONFIG_UIO is not set |
| 1334 | |||
| 1335 | # | ||
| 1336 | # TI VLYNQ | ||
| 1337 | # | ||
| 1359 | # CONFIG_STAGING is not set | 1338 | # CONFIG_STAGING is not set |
| 1360 | 1339 | ||
| 1361 | # | 1340 | # |
| @@ -1375,11 +1354,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1375 | # CONFIG_REISERFS_FS is not set | 1354 | # CONFIG_REISERFS_FS is not set |
| 1376 | # CONFIG_JFS_FS is not set | 1355 | # CONFIG_JFS_FS is not set |
| 1377 | # CONFIG_FS_POSIX_ACL is not set | 1356 | # CONFIG_FS_POSIX_ACL is not set |
| 1378 | CONFIG_FILE_LOCKING=y | ||
| 1379 | # CONFIG_XFS_FS is not set | 1357 | # CONFIG_XFS_FS is not set |
| 1380 | # CONFIG_GFS2_FS is not set | 1358 | # CONFIG_GFS2_FS is not set |
| 1381 | # CONFIG_OCFS2_FS is not set | 1359 | # CONFIG_OCFS2_FS is not set |
| 1382 | # CONFIG_BTRFS_FS is not set | 1360 | # CONFIG_BTRFS_FS is not set |
| 1361 | CONFIG_FILE_LOCKING=y | ||
| 1362 | CONFIG_FSNOTIFY=y | ||
| 1383 | CONFIG_DNOTIFY=y | 1363 | CONFIG_DNOTIFY=y |
| 1384 | CONFIG_INOTIFY=y | 1364 | CONFIG_INOTIFY=y |
| 1385 | CONFIG_INOTIFY_USER=y | 1365 | CONFIG_INOTIFY_USER=y |
| @@ -1454,6 +1434,7 @@ CONFIG_NFS_FS=y | |||
| 1454 | CONFIG_NFS_V3=y | 1434 | CONFIG_NFS_V3=y |
| 1455 | # CONFIG_NFS_V3_ACL is not set | 1435 | # CONFIG_NFS_V3_ACL is not set |
| 1456 | CONFIG_NFS_V4=y | 1436 | CONFIG_NFS_V4=y |
| 1437 | # CONFIG_NFS_V4_1 is not set | ||
| 1457 | CONFIG_ROOT_NFS=y | 1438 | CONFIG_ROOT_NFS=y |
| 1458 | CONFIG_NFSD=y | 1439 | CONFIG_NFSD=y |
| 1459 | # CONFIG_NFSD_V3 is not set | 1440 | # CONFIG_NFSD_V3 is not set |
| @@ -1555,6 +1536,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1555 | CONFIG_HAS_DMA=y | 1536 | CONFIG_HAS_DMA=y |
| 1556 | CONFIG_HAVE_LMB=y | 1537 | CONFIG_HAVE_LMB=y |
| 1557 | CONFIG_NLATTR=y | 1538 | CONFIG_NLATTR=y |
| 1539 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1558 | 1540 | ||
| 1559 | # | 1541 | # |
| 1560 | # Kernel hacking | 1542 | # Kernel hacking |
| @@ -1585,6 +1567,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 1585 | # CONFIG_RT_MUTEX_TESTER is not set | 1567 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1586 | # CONFIG_DEBUG_SPINLOCK is not set | 1568 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1587 | # CONFIG_DEBUG_MUTEXES is not set | 1569 | # CONFIG_DEBUG_MUTEXES is not set |
| 1570 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1571 | # CONFIG_PROVE_LOCKING is not set | ||
| 1572 | # CONFIG_LOCK_STAT is not set | ||
| 1588 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1573 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1589 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1574 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1590 | # CONFIG_DEBUG_KOBJECT is not set | 1575 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1597,7 +1582,6 @@ CONFIG_DEBUG_INFO=y | |||
| 1597 | # CONFIG_DEBUG_LIST is not set | 1582 | # CONFIG_DEBUG_LIST is not set |
| 1598 | # CONFIG_DEBUG_SG is not set | 1583 | # CONFIG_DEBUG_SG is not set |
| 1599 | # CONFIG_DEBUG_NOTIFIERS is not set | 1584 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1600 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1601 | # CONFIG_RCU_TORTURE_TEST is not set | 1585 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1602 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1586 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1603 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1587 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1611,16 +1595,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1611 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1595 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1612 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1596 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1613 | CONFIG_TRACING_SUPPORT=y | 1597 | CONFIG_TRACING_SUPPORT=y |
| 1614 | 1598 | CONFIG_FTRACE=y | |
| 1615 | # | ||
| 1616 | # Tracers | ||
| 1617 | # | ||
| 1618 | # CONFIG_FUNCTION_TRACER is not set | 1599 | # CONFIG_FUNCTION_TRACER is not set |
| 1600 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1619 | # CONFIG_SCHED_TRACER is not set | 1601 | # CONFIG_SCHED_TRACER is not set |
| 1620 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1602 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1621 | # CONFIG_EVENT_TRACER is not set | ||
| 1622 | # CONFIG_BOOT_TRACER is not set | 1603 | # CONFIG_BOOT_TRACER is not set |
| 1623 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1604 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1605 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1606 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1624 | # CONFIG_STACK_TRACER is not set | 1607 | # CONFIG_STACK_TRACER is not set |
| 1625 | # CONFIG_KMEMTRACE is not set | 1608 | # CONFIG_KMEMTRACE is not set |
| 1626 | # CONFIG_WORKQUEUE_TRACER is not set | 1609 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -1628,6 +1611,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 1628 | # CONFIG_SAMPLES is not set | 1611 | # CONFIG_SAMPLES is not set |
| 1629 | CONFIG_HAVE_ARCH_KGDB=y | 1612 | CONFIG_HAVE_ARCH_KGDB=y |
| 1630 | # CONFIG_KGDB is not set | 1613 | # CONFIG_KGDB is not set |
| 1614 | # CONFIG_KMEMCHECK is not set | ||
| 1615 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1616 | CONFIG_PPC_WERROR=y | ||
| 1631 | CONFIG_PRINT_STACK_DEPTH=64 | 1617 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1632 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1618 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1633 | # CONFIG_DEBUG_STACK_USAGE is not set | 1619 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/86xx/sbc8641d_defconfig b/arch/powerpc/configs/86xx/sbc8641d_defconfig index c30a0c715873..f5ca2e0cd402 100644 --- a/arch/powerpc/configs/86xx/sbc8641d_defconfig +++ b/arch/powerpc/configs/86xx/sbc8641d_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:27 2009 | 4 | # Wed Jul 29 23:32:26 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_PHYS_64BIT is not set | 20 | # CONFIG_PHYS_64BIT is not set |
| 20 | CONFIG_ALTIVEC=y | 21 | CONFIG_ALTIVEC=y |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | CONFIG_SMP=y | 26 | CONFIG_SMP=y |
| 25 | CONFIG_NR_CPUS=2 | 27 | CONFIG_NR_CPUS=2 |
| 26 | CONFIG_PPC32=y | 28 | CONFIG_PPC32=y |
| @@ -32,16 +34,17 @@ CONFIG_GENERIC_TIME=y | |||
| 32 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 33 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 34 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 35 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 36 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 37 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 38 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 39 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 40 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 41 | CONFIG_GENERIC_LOCKBREAK=y | 45 | CONFIG_GENERIC_LOCKBREAK=y |
| 42 | CONFIG_ARCH_HAS_ILOG2_U32=y | 46 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 43 | CONFIG_GENERIC_HWEIGHT=y | 47 | CONFIG_GENERIC_HWEIGHT=y |
| 44 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 45 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 48 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 46 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 49 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 47 | CONFIG_PPC=y | 50 | CONFIG_PPC=y |
| @@ -55,11 +58,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 55 | CONFIG_GENERIC_TBSYNC=y | 58 | CONFIG_GENERIC_TBSYNC=y |
| 56 | CONFIG_AUDIT_ARCH=y | 59 | CONFIG_AUDIT_ARCH=y |
| 57 | CONFIG_GENERIC_BUG=y | 60 | CONFIG_GENERIC_BUG=y |
| 61 | CONFIG_DTC=y | ||
| 58 | CONFIG_DEFAULT_UIMAGE=y | 62 | CONFIG_DEFAULT_UIMAGE=y |
| 59 | # CONFIG_PPC_DCR_NATIVE is not set | 63 | # CONFIG_PPC_DCR_NATIVE is not set |
| 60 | # CONFIG_PPC_DCR_MMIO is not set | 64 | # CONFIG_PPC_DCR_MMIO is not set |
| 61 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 65 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 62 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 66 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 67 | CONFIG_CONSTRUCTORS=y | ||
| 63 | 68 | ||
| 64 | # | 69 | # |
| 65 | # General setup | 70 | # General setup |
| @@ -113,7 +118,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 113 | CONFIG_KALLSYMS=y | 118 | CONFIG_KALLSYMS=y |
| 114 | # CONFIG_KALLSYMS_ALL is not set | 119 | # CONFIG_KALLSYMS_ALL is not set |
| 115 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 120 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 116 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 117 | CONFIG_HOTPLUG=y | 121 | CONFIG_HOTPLUG=y |
| 118 | CONFIG_PRINTK=y | 122 | CONFIG_PRINTK=y |
| 119 | CONFIG_BUG=y | 123 | CONFIG_BUG=y |
| @@ -126,8 +130,15 @@ CONFIG_TIMERFD=y | |||
| 126 | CONFIG_EVENTFD=y | 130 | CONFIG_EVENTFD=y |
| 127 | CONFIG_SHMEM=y | 131 | CONFIG_SHMEM=y |
| 128 | CONFIG_AIO=y | 132 | CONFIG_AIO=y |
| 133 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 134 | |||
| 135 | # | ||
| 136 | # Performance Counters | ||
| 137 | # | ||
| 138 | # CONFIG_PERF_COUNTERS is not set | ||
| 129 | CONFIG_VM_EVENT_COUNTERS=y | 139 | CONFIG_VM_EVENT_COUNTERS=y |
| 130 | CONFIG_PCI_QUIRKS=y | 140 | CONFIG_PCI_QUIRKS=y |
| 141 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 131 | CONFIG_COMPAT_BRK=y | 142 | CONFIG_COMPAT_BRK=y |
| 132 | CONFIG_SLAB=y | 143 | CONFIG_SLAB=y |
| 133 | # CONFIG_SLUB is not set | 144 | # CONFIG_SLUB is not set |
| @@ -142,6 +153,11 @@ CONFIG_HAVE_KPROBES=y | |||
| 142 | CONFIG_HAVE_KRETPROBES=y | 153 | CONFIG_HAVE_KRETPROBES=y |
| 143 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 154 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 144 | CONFIG_USE_GENERIC_SMP_HELPERS=y | 155 | CONFIG_USE_GENERIC_SMP_HELPERS=y |
| 156 | |||
| 157 | # | ||
| 158 | # GCOV-based kernel profiling | ||
| 159 | # | ||
| 160 | # CONFIG_GCOV_KERNEL is not set | ||
| 145 | # CONFIG_SLOW_WORK is not set | 161 | # CONFIG_SLOW_WORK is not set |
| 146 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 162 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 147 | CONFIG_SLABINFO=y | 163 | CONFIG_SLABINFO=y |
| @@ -155,7 +171,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 155 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 171 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 156 | CONFIG_STOP_MACHINE=y | 172 | CONFIG_STOP_MACHINE=y |
| 157 | CONFIG_BLOCK=y | 173 | CONFIG_BLOCK=y |
| 158 | # CONFIG_LBD is not set | 174 | CONFIG_LBDAF=y |
| 159 | # CONFIG_BLK_DEV_BSG is not set | 175 | # CONFIG_BLK_DEV_BSG is not set |
| 160 | # CONFIG_BLK_DEV_INTEGRITY is not set | 176 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 161 | 177 | ||
| @@ -234,6 +250,7 @@ CONFIG_BINFMT_ELF=y | |||
| 234 | # CONFIG_HAVE_AOUT is not set | 250 | # CONFIG_HAVE_AOUT is not set |
| 235 | CONFIG_BINFMT_MISC=m | 251 | CONFIG_BINFMT_MISC=m |
| 236 | # CONFIG_IOMMU_HELPER is not set | 252 | # CONFIG_IOMMU_HELPER is not set |
| 253 | # CONFIG_SWIOTLB is not set | ||
| 237 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 254 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 238 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 255 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 239 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 256 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -255,9 +272,9 @@ CONFIG_MIGRATION=y | |||
| 255 | CONFIG_ZONE_DMA_FLAG=1 | 272 | CONFIG_ZONE_DMA_FLAG=1 |
| 256 | CONFIG_BOUNCE=y | 273 | CONFIG_BOUNCE=y |
| 257 | CONFIG_VIRT_TO_BUS=y | 274 | CONFIG_VIRT_TO_BUS=y |
| 258 | CONFIG_UNEVICTABLE_LRU=y | ||
| 259 | CONFIG_HAVE_MLOCK=y | 275 | CONFIG_HAVE_MLOCK=y |
| 260 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 276 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 277 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 261 | CONFIG_PPC_4K_PAGES=y | 278 | CONFIG_PPC_4K_PAGES=y |
| 262 | # CONFIG_PPC_16K_PAGES is not set | 279 | # CONFIG_PPC_16K_PAGES is not set |
| 263 | # CONFIG_PPC_64K_PAGES is not set | 280 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -284,6 +301,8 @@ CONFIG_PCI_DOMAINS=y | |||
| 284 | CONFIG_PCI_SYSCALL=y | 301 | CONFIG_PCI_SYSCALL=y |
| 285 | CONFIG_PCIEPORTBUS=y | 302 | CONFIG_PCIEPORTBUS=y |
| 286 | CONFIG_PCIEAER=y | 303 | CONFIG_PCIEAER=y |
| 304 | # CONFIG_PCIE_ECRC is not set | ||
| 305 | # CONFIG_PCIEAER_INJECT is not set | ||
| 287 | # CONFIG_PCIEASPM is not set | 306 | # CONFIG_PCIEASPM is not set |
| 288 | CONFIG_ARCH_SUPPORTS_MSI=y | 307 | CONFIG_ARCH_SUPPORTS_MSI=y |
| 289 | # CONFIG_PCI_MSI is not set | 308 | # CONFIG_PCI_MSI is not set |
| @@ -508,6 +527,7 @@ CONFIG_LLC=m | |||
| 508 | # CONFIG_ECONET is not set | 527 | # CONFIG_ECONET is not set |
| 509 | CONFIG_WAN_ROUTER=m | 528 | CONFIG_WAN_ROUTER=m |
| 510 | # CONFIG_PHONET is not set | 529 | # CONFIG_PHONET is not set |
| 530 | # CONFIG_IEEE802154 is not set | ||
| 511 | CONFIG_NET_SCHED=y | 531 | CONFIG_NET_SCHED=y |
| 512 | 532 | ||
| 513 | # | 533 | # |
| @@ -564,7 +584,11 @@ CONFIG_WIRELESS=y | |||
| 564 | CONFIG_WIRELESS_OLD_REGULATORY=y | 584 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 565 | # CONFIG_WIRELESS_EXT is not set | 585 | # CONFIG_WIRELESS_EXT is not set |
| 566 | # CONFIG_LIB80211 is not set | 586 | # CONFIG_LIB80211 is not set |
| 567 | # CONFIG_MAC80211 is not set | 587 | |
| 588 | # | ||
| 589 | # CFG80211 needs to be enabled for MAC80211 | ||
| 590 | # | ||
| 591 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 568 | # CONFIG_WIMAX is not set | 592 | # CONFIG_WIMAX is not set |
| 569 | # CONFIG_RFKILL is not set | 593 | # CONFIG_RFKILL is not set |
| 570 | # CONFIG_NET_9P is not set | 594 | # CONFIG_NET_9P is not set |
| @@ -675,6 +699,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 675 | # CONFIG_MTD_UBI is not set | 699 | # CONFIG_MTD_UBI is not set |
| 676 | CONFIG_OF_DEVICE=y | 700 | CONFIG_OF_DEVICE=y |
| 677 | CONFIG_OF_I2C=y | 701 | CONFIG_OF_I2C=y |
| 702 | CONFIG_OF_MDIO=y | ||
| 678 | # CONFIG_PARPORT is not set | 703 | # CONFIG_PARPORT is not set |
| 679 | CONFIG_BLK_DEV=y | 704 | CONFIG_BLK_DEV=y |
| 680 | # CONFIG_BLK_DEV_FD is not set | 705 | # CONFIG_BLK_DEV_FD is not set |
| @@ -709,7 +734,9 @@ CONFIG_MISC_DEVICES=y | |||
| 709 | # | 734 | # |
| 710 | # CONFIG_EEPROM_AT24 is not set | 735 | # CONFIG_EEPROM_AT24 is not set |
| 711 | # CONFIG_EEPROM_LEGACY is not set | 736 | # CONFIG_EEPROM_LEGACY is not set |
| 737 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 712 | # CONFIG_EEPROM_93CX6 is not set | 738 | # CONFIG_EEPROM_93CX6 is not set |
| 739 | # CONFIG_CB710_CORE is not set | ||
| 713 | CONFIG_HAVE_IDE=y | 740 | CONFIG_HAVE_IDE=y |
| 714 | # CONFIG_IDE is not set | 741 | # CONFIG_IDE is not set |
| 715 | 742 | ||
| @@ -736,6 +763,7 @@ CONFIG_BLK_DEV_DM=y | |||
| 736 | CONFIG_DM_CRYPT=y | 763 | CONFIG_DM_CRYPT=y |
| 737 | CONFIG_DM_SNAPSHOT=y | 764 | CONFIG_DM_SNAPSHOT=y |
| 738 | CONFIG_DM_MIRROR=y | 765 | CONFIG_DM_MIRROR=y |
| 766 | # CONFIG_DM_LOG_USERSPACE is not set | ||
| 739 | CONFIG_DM_ZERO=y | 767 | CONFIG_DM_ZERO=y |
| 740 | # CONFIG_DM_MULTIPATH is not set | 768 | # CONFIG_DM_MULTIPATH is not set |
| 741 | # CONFIG_DM_DELAY is not set | 769 | # CONFIG_DM_DELAY is not set |
| @@ -747,14 +775,17 @@ CONFIG_DM_ZERO=y | |||
| 747 | # | 775 | # |
| 748 | 776 | ||
| 749 | # | 777 | # |
| 750 | # Enable only one of the two stacks, unless you know what you are doing | 778 | # You can enable one or both FireWire driver stacks. |
| 779 | # | ||
| 780 | |||
| 781 | # | ||
| 782 | # See the help texts for more information. | ||
| 751 | # | 783 | # |
| 752 | # CONFIG_FIREWIRE is not set | 784 | # CONFIG_FIREWIRE is not set |
| 753 | # CONFIG_IEEE1394 is not set | 785 | # CONFIG_IEEE1394 is not set |
| 754 | # CONFIG_I2O is not set | 786 | # CONFIG_I2O is not set |
| 755 | # CONFIG_MACINTOSH_DRIVERS is not set | 787 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 756 | CONFIG_NETDEVICES=y | 788 | CONFIG_NETDEVICES=y |
| 757 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 758 | CONFIG_DUMMY=m | 789 | CONFIG_DUMMY=m |
| 759 | CONFIG_BONDING=m | 790 | CONFIG_BONDING=m |
| 760 | # CONFIG_MACVLAN is not set | 791 | # CONFIG_MACVLAN is not set |
| @@ -801,6 +832,7 @@ CONFIG_MII=y | |||
| 801 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 832 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 802 | # CONFIG_NET_PCI is not set | 833 | # CONFIG_NET_PCI is not set |
| 803 | # CONFIG_B44 is not set | 834 | # CONFIG_B44 is not set |
| 835 | # CONFIG_KS8842 is not set | ||
| 804 | # CONFIG_ATL2 is not set | 836 | # CONFIG_ATL2 is not set |
| 805 | CONFIG_NETDEV_1000=y | 837 | CONFIG_NETDEV_1000=y |
| 806 | # CONFIG_ACENIC is not set | 838 | # CONFIG_ACENIC is not set |
| @@ -820,8 +852,10 @@ CONFIG_NETDEV_1000=y | |||
| 820 | # CONFIG_VIA_VELOCITY is not set | 852 | # CONFIG_VIA_VELOCITY is not set |
| 821 | # CONFIG_TIGON3 is not set | 853 | # CONFIG_TIGON3 is not set |
| 822 | # CONFIG_BNX2 is not set | 854 | # CONFIG_BNX2 is not set |
| 855 | # CONFIG_CNIC is not set | ||
| 823 | CONFIG_FSL_PQ_MDIO=y | 856 | CONFIG_FSL_PQ_MDIO=y |
| 824 | CONFIG_GIANFAR=y | 857 | CONFIG_GIANFAR=y |
| 858 | # CONFIG_MV643XX_ETH is not set | ||
| 825 | # CONFIG_QLA3XXX is not set | 859 | # CONFIG_QLA3XXX is not set |
| 826 | # CONFIG_ATL1 is not set | 860 | # CONFIG_ATL1 is not set |
| 827 | # CONFIG_ATL1E is not set | 861 | # CONFIG_ATL1E is not set |
| @@ -1018,13 +1052,17 @@ CONFIG_I2C_MPC=y | |||
| 1018 | # CONFIG_SENSORS_PCF8574 is not set | 1052 | # CONFIG_SENSORS_PCF8574 is not set |
| 1019 | # CONFIG_PCF8575 is not set | 1053 | # CONFIG_PCF8575 is not set |
| 1020 | # CONFIG_SENSORS_PCA9539 is not set | 1054 | # CONFIG_SENSORS_PCA9539 is not set |
| 1021 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 1022 | # CONFIG_SENSORS_TSL2550 is not set | 1055 | # CONFIG_SENSORS_TSL2550 is not set |
| 1023 | # CONFIG_I2C_DEBUG_CORE is not set | 1056 | # CONFIG_I2C_DEBUG_CORE is not set |
| 1024 | # CONFIG_I2C_DEBUG_ALGO is not set | 1057 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 1025 | # CONFIG_I2C_DEBUG_BUS is not set | 1058 | # CONFIG_I2C_DEBUG_BUS is not set |
| 1026 | # CONFIG_I2C_DEBUG_CHIP is not set | 1059 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 1027 | # CONFIG_SPI is not set | 1060 | # CONFIG_SPI is not set |
| 1061 | |||
| 1062 | # | ||
| 1063 | # PPS support | ||
| 1064 | # | ||
| 1065 | # CONFIG_PPS is not set | ||
| 1028 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 1066 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 1029 | # CONFIG_GPIOLIB is not set | 1067 | # CONFIG_GPIOLIB is not set |
| 1030 | # CONFIG_W1 is not set | 1068 | # CONFIG_W1 is not set |
| @@ -1079,6 +1117,7 @@ CONFIG_HWMON=y | |||
| 1079 | # CONFIG_SENSORS_SMSC47B397 is not set | 1117 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 1080 | # CONFIG_SENSORS_ADS7828 is not set | 1118 | # CONFIG_SENSORS_ADS7828 is not set |
| 1081 | # CONFIG_SENSORS_THMC50 is not set | 1119 | # CONFIG_SENSORS_THMC50 is not set |
| 1120 | # CONFIG_SENSORS_TMP401 is not set | ||
| 1082 | # CONFIG_SENSORS_VIA686A is not set | 1121 | # CONFIG_SENSORS_VIA686A is not set |
| 1083 | # CONFIG_SENSORS_VT1211 is not set | 1122 | # CONFIG_SENSORS_VT1211 is not set |
| 1084 | # CONFIG_SENSORS_VT8231 is not set | 1123 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -1127,23 +1166,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1127 | # CONFIG_MFD_WM8400 is not set | 1166 | # CONFIG_MFD_WM8400 is not set |
| 1128 | # CONFIG_MFD_WM8350_I2C is not set | 1167 | # CONFIG_MFD_WM8350_I2C is not set |
| 1129 | # CONFIG_MFD_PCF50633 is not set | 1168 | # CONFIG_MFD_PCF50633 is not set |
| 1169 | # CONFIG_AB3100_CORE is not set | ||
| 1130 | # CONFIG_REGULATOR is not set | 1170 | # CONFIG_REGULATOR is not set |
| 1131 | 1171 | # CONFIG_MEDIA_SUPPORT is not set | |
| 1132 | # | ||
| 1133 | # Multimedia devices | ||
| 1134 | # | ||
| 1135 | |||
| 1136 | # | ||
| 1137 | # Multimedia core support | ||
| 1138 | # | ||
| 1139 | # CONFIG_VIDEO_DEV is not set | ||
| 1140 | # CONFIG_DVB_CORE is not set | ||
| 1141 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1142 | |||
| 1143 | # | ||
| 1144 | # Multimedia drivers | ||
| 1145 | # | ||
| 1146 | CONFIG_DAB=y | ||
| 1147 | 1172 | ||
| 1148 | # | 1173 | # |
| 1149 | # Graphics support | 1174 | # Graphics support |
| @@ -1207,6 +1232,10 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
| 1207 | # CONFIG_DMADEVICES is not set | 1232 | # CONFIG_DMADEVICES is not set |
| 1208 | # CONFIG_AUXDISPLAY is not set | 1233 | # CONFIG_AUXDISPLAY is not set |
| 1209 | # CONFIG_UIO is not set | 1234 | # CONFIG_UIO is not set |
| 1235 | |||
| 1236 | # | ||
| 1237 | # TI VLYNQ | ||
| 1238 | # | ||
| 1210 | # CONFIG_STAGING is not set | 1239 | # CONFIG_STAGING is not set |
| 1211 | 1240 | ||
| 1212 | # | 1241 | # |
| @@ -1236,8 +1265,8 @@ CONFIG_REISERFS_FS_POSIX_ACL=y | |||
| 1236 | # CONFIG_REISERFS_FS_SECURITY is not set | 1265 | # CONFIG_REISERFS_FS_SECURITY is not set |
| 1237 | # CONFIG_JFS_FS is not set | 1266 | # CONFIG_JFS_FS is not set |
| 1238 | CONFIG_FS_POSIX_ACL=y | 1267 | CONFIG_FS_POSIX_ACL=y |
| 1239 | CONFIG_FILE_LOCKING=y | ||
| 1240 | # CONFIG_XFS_FS is not set | 1268 | # CONFIG_XFS_FS is not set |
| 1269 | # CONFIG_GFS2_FS is not set | ||
| 1241 | CONFIG_OCFS2_FS=m | 1270 | CONFIG_OCFS2_FS=m |
| 1242 | CONFIG_OCFS2_FS_O2CB=m | 1271 | CONFIG_OCFS2_FS_O2CB=m |
| 1243 | CONFIG_OCFS2_FS_STATS=y | 1272 | CONFIG_OCFS2_FS_STATS=y |
| @@ -1245,6 +1274,8 @@ CONFIG_OCFS2_DEBUG_MASKLOG=y | |||
| 1245 | # CONFIG_OCFS2_DEBUG_FS is not set | 1274 | # CONFIG_OCFS2_DEBUG_FS is not set |
| 1246 | # CONFIG_OCFS2_FS_POSIX_ACL is not set | 1275 | # CONFIG_OCFS2_FS_POSIX_ACL is not set |
| 1247 | # CONFIG_BTRFS_FS is not set | 1276 | # CONFIG_BTRFS_FS is not set |
| 1277 | CONFIG_FILE_LOCKING=y | ||
| 1278 | CONFIG_FSNOTIFY=y | ||
| 1248 | CONFIG_DNOTIFY=y | 1279 | CONFIG_DNOTIFY=y |
| 1249 | CONFIG_INOTIFY=y | 1280 | CONFIG_INOTIFY=y |
| 1250 | CONFIG_INOTIFY_USER=y | 1281 | CONFIG_INOTIFY_USER=y |
| @@ -1318,6 +1349,7 @@ CONFIG_NFS_FS=y | |||
| 1318 | CONFIG_NFS_V3=y | 1349 | CONFIG_NFS_V3=y |
| 1319 | # CONFIG_NFS_V3_ACL is not set | 1350 | # CONFIG_NFS_V3_ACL is not set |
| 1320 | CONFIG_NFS_V4=y | 1351 | CONFIG_NFS_V4=y |
| 1352 | # CONFIG_NFS_V4_1 is not set | ||
| 1321 | CONFIG_ROOT_NFS=y | 1353 | CONFIG_ROOT_NFS=y |
| 1322 | # CONFIG_NFSD is not set | 1354 | # CONFIG_NFSD is not set |
| 1323 | CONFIG_LOCKD=y | 1355 | CONFIG_LOCKD=y |
| @@ -1409,6 +1441,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1409 | CONFIG_HAS_DMA=y | 1441 | CONFIG_HAS_DMA=y |
| 1410 | CONFIG_HAVE_LMB=y | 1442 | CONFIG_HAVE_LMB=y |
| 1411 | CONFIG_NLATTR=y | 1443 | CONFIG_NLATTR=y |
| 1444 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1412 | 1445 | ||
| 1413 | # | 1446 | # |
| 1414 | # Kernel hacking | 1447 | # Kernel hacking |
| @@ -1434,10 +1467,14 @@ CONFIG_SCHED_DEBUG=y | |||
| 1434 | # CONFIG_TIMER_STATS is not set | 1467 | # CONFIG_TIMER_STATS is not set |
| 1435 | # CONFIG_DEBUG_OBJECTS is not set | 1468 | # CONFIG_DEBUG_OBJECTS is not set |
| 1436 | # CONFIG_DEBUG_SLAB is not set | 1469 | # CONFIG_DEBUG_SLAB is not set |
| 1470 | CONFIG_DEBUG_PREEMPT=y | ||
| 1437 | # CONFIG_DEBUG_RT_MUTEXES is not set | 1471 | # CONFIG_DEBUG_RT_MUTEXES is not set |
| 1438 | # CONFIG_RT_MUTEX_TESTER is not set | 1472 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1439 | # CONFIG_DEBUG_SPINLOCK is not set | 1473 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1440 | # CONFIG_DEBUG_MUTEXES is not set | 1474 | # CONFIG_DEBUG_MUTEXES is not set |
| 1475 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1476 | # CONFIG_PROVE_LOCKING is not set | ||
| 1477 | # CONFIG_LOCK_STAT is not set | ||
| 1441 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1478 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1442 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1479 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1443 | # CONFIG_DEBUG_KOBJECT is not set | 1480 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1449,7 +1486,6 @@ CONFIG_DEBUG_INFO=y | |||
| 1449 | # CONFIG_DEBUG_LIST is not set | 1486 | # CONFIG_DEBUG_LIST is not set |
| 1450 | # CONFIG_DEBUG_SG is not set | 1487 | # CONFIG_DEBUG_SG is not set |
| 1451 | # CONFIG_DEBUG_NOTIFIERS is not set | 1488 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1452 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1453 | # CONFIG_RCU_TORTURE_TEST is not set | 1489 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1454 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1490 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1455 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1491 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1463,17 +1499,16 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1463 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1499 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1464 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1500 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1465 | CONFIG_TRACING_SUPPORT=y | 1501 | CONFIG_TRACING_SUPPORT=y |
| 1466 | 1502 | CONFIG_FTRACE=y | |
| 1467 | # | ||
| 1468 | # Tracers | ||
| 1469 | # | ||
| 1470 | # CONFIG_FUNCTION_TRACER is not set | 1503 | # CONFIG_FUNCTION_TRACER is not set |
| 1504 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1471 | # CONFIG_PREEMPT_TRACER is not set | 1505 | # CONFIG_PREEMPT_TRACER is not set |
| 1472 | # CONFIG_SCHED_TRACER is not set | 1506 | # CONFIG_SCHED_TRACER is not set |
| 1473 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1507 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1474 | # CONFIG_EVENT_TRACER is not set | ||
| 1475 | # CONFIG_BOOT_TRACER is not set | 1508 | # CONFIG_BOOT_TRACER is not set |
| 1476 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1509 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1510 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1511 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1477 | # CONFIG_STACK_TRACER is not set | 1512 | # CONFIG_STACK_TRACER is not set |
| 1478 | # CONFIG_KMEMTRACE is not set | 1513 | # CONFIG_KMEMTRACE is not set |
| 1479 | # CONFIG_WORKQUEUE_TRACER is not set | 1514 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -1482,9 +1517,13 @@ CONFIG_TRACING_SUPPORT=y | |||
| 1482 | # CONFIG_SAMPLES is not set | 1517 | # CONFIG_SAMPLES is not set |
| 1483 | CONFIG_HAVE_ARCH_KGDB=y | 1518 | CONFIG_HAVE_ARCH_KGDB=y |
| 1484 | # CONFIG_KGDB is not set | 1519 | # CONFIG_KGDB is not set |
| 1520 | # CONFIG_KMEMCHECK is not set | ||
| 1521 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1522 | CONFIG_PPC_WERROR=y | ||
| 1485 | CONFIG_PRINT_STACK_DEPTH=64 | 1523 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1486 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1524 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1487 | # CONFIG_DEBUG_STACK_USAGE is not set | 1525 | # CONFIG_DEBUG_STACK_USAGE is not set |
| 1526 | # CONFIG_PPC_EMULATED_STATS is not set | ||
| 1488 | # CONFIG_CODE_PATCHING_SELFTEST is not set | 1527 | # CONFIG_CODE_PATCHING_SELFTEST is not set |
| 1489 | # CONFIG_FTR_FIXUP_SELFTEST is not set | 1528 | # CONFIG_FTR_FIXUP_SELFTEST is not set |
| 1490 | # CONFIG_MSI_BITMAP_SELFTEST is not set | 1529 | # CONFIG_MSI_BITMAP_SELFTEST is not set |
| @@ -1505,7 +1544,6 @@ CONFIG_SECURITY_NETWORK=y | |||
| 1505 | # CONFIG_SECURITY_NETWORK_XFRM is not set | 1544 | # CONFIG_SECURITY_NETWORK_XFRM is not set |
| 1506 | # CONFIG_SECURITY_PATH is not set | 1545 | # CONFIG_SECURITY_PATH is not set |
| 1507 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set | 1546 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set |
| 1508 | CONFIG_SECURITY_DEFAULT_MMAP_MIN_ADDR=0 | ||
| 1509 | # CONFIG_SECURITY_TOMOYO is not set | 1547 | # CONFIG_SECURITY_TOMOYO is not set |
| 1510 | CONFIG_CRYPTO=y | 1548 | CONFIG_CRYPTO=y |
| 1511 | 1549 | ||
diff --git a/arch/powerpc/configs/adder875_defconfig b/arch/powerpc/configs/adder875_defconfig index 74f7f7c6fdc4..aece6bb5f733 100644 --- a/arch/powerpc/configs/adder875_defconfig +++ b/arch/powerpc/configs/adder875_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:21:50 2009 | 4 | # Wed Jul 29 23:31:47 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | CONFIG_PPC_8xx=y | 13 | CONFIG_PPC_8xx=y |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -27,15 +27,16 @@ CONFIG_GENERIC_TIME=y | |||
| 27 | CONFIG_GENERIC_TIME_VSYSCALL=y | 27 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 28 | CONFIG_GENERIC_CLOCKEVENTS=y | 28 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 29 | CONFIG_GENERIC_HARDIRQS=y | 29 | CONFIG_GENERIC_HARDIRQS=y |
| 30 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 30 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 31 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 31 | CONFIG_IRQ_PER_CPU=y | 32 | CONFIG_IRQ_PER_CPU=y |
| 32 | CONFIG_STACKTRACE_SUPPORT=y | 33 | CONFIG_STACKTRACE_SUPPORT=y |
| 33 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 34 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 35 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 34 | CONFIG_LOCKDEP_SUPPORT=y | 36 | CONFIG_LOCKDEP_SUPPORT=y |
| 35 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 37 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 36 | CONFIG_ARCH_HAS_ILOG2_U32=y | 38 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 37 | CONFIG_GENERIC_HWEIGHT=y | 39 | CONFIG_GENERIC_HWEIGHT=y |
| 38 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 39 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 40 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 40 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 41 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 41 | CONFIG_PPC=y | 42 | CONFIG_PPC=y |
| @@ -49,12 +50,14 @@ CONFIG_OF=y | |||
| 49 | # CONFIG_GENERIC_TBSYNC is not set | 50 | # CONFIG_GENERIC_TBSYNC is not set |
| 50 | CONFIG_AUDIT_ARCH=y | 51 | CONFIG_AUDIT_ARCH=y |
| 51 | CONFIG_GENERIC_BUG=y | 52 | CONFIG_GENERIC_BUG=y |
| 53 | CONFIG_DTC=y | ||
| 52 | # CONFIG_DEFAULT_UIMAGE is not set | 54 | # CONFIG_DEFAULT_UIMAGE is not set |
| 53 | CONFIG_REDBOOT=y | 55 | CONFIG_REDBOOT=y |
| 54 | # CONFIG_PPC_DCR_NATIVE is not set | 56 | # CONFIG_PPC_DCR_NATIVE is not set |
| 55 | # CONFIG_PPC_DCR_MMIO is not set | 57 | # CONFIG_PPC_DCR_MMIO is not set |
| 56 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 58 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 57 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 59 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 60 | CONFIG_CONSTRUCTORS=y | ||
| 58 | 61 | ||
| 59 | # | 62 | # |
| 60 | # General setup | 63 | # General setup |
| @@ -101,7 +104,6 @@ CONFIG_EMBEDDED=y | |||
| 101 | CONFIG_KALLSYMS=y | 104 | CONFIG_KALLSYMS=y |
| 102 | # CONFIG_KALLSYMS_ALL is not set | 105 | # CONFIG_KALLSYMS_ALL is not set |
| 103 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 106 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 104 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 105 | CONFIG_HOTPLUG=y | 107 | CONFIG_HOTPLUG=y |
| 106 | CONFIG_PRINTK=y | 108 | CONFIG_PRINTK=y |
| 107 | CONFIG_BUG=y | 109 | CONFIG_BUG=y |
| @@ -114,8 +116,15 @@ CONFIG_TIMERFD=y | |||
| 114 | CONFIG_EVENTFD=y | 116 | CONFIG_EVENTFD=y |
| 115 | CONFIG_SHMEM=y | 117 | CONFIG_SHMEM=y |
| 116 | CONFIG_AIO=y | 118 | CONFIG_AIO=y |
| 119 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 120 | |||
| 121 | # | ||
| 122 | # Performance Counters | ||
| 123 | # | ||
| 124 | # CONFIG_PERF_COUNTERS is not set | ||
| 117 | # CONFIG_VM_EVENT_COUNTERS is not set | 125 | # CONFIG_VM_EVENT_COUNTERS is not set |
| 118 | CONFIG_SLUB_DEBUG=y | 126 | CONFIG_SLUB_DEBUG=y |
| 127 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 119 | CONFIG_COMPAT_BRK=y | 128 | CONFIG_COMPAT_BRK=y |
| 120 | # CONFIG_SLAB is not set | 129 | # CONFIG_SLAB is not set |
| 121 | CONFIG_SLUB=y | 130 | CONFIG_SLUB=y |
| @@ -129,13 +138,18 @@ CONFIG_HAVE_KPROBES=y | |||
| 129 | CONFIG_HAVE_KRETPROBES=y | 138 | CONFIG_HAVE_KRETPROBES=y |
| 130 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 139 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 131 | CONFIG_HAVE_CLK=y | 140 | CONFIG_HAVE_CLK=y |
| 141 | |||
| 142 | # | ||
| 143 | # GCOV-based kernel profiling | ||
| 144 | # | ||
| 145 | # CONFIG_GCOV_KERNEL is not set | ||
| 132 | # CONFIG_SLOW_WORK is not set | 146 | # CONFIG_SLOW_WORK is not set |
| 133 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 147 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 134 | CONFIG_SLABINFO=y | 148 | CONFIG_SLABINFO=y |
| 135 | CONFIG_BASE_SMALL=1 | 149 | CONFIG_BASE_SMALL=1 |
| 136 | # CONFIG_MODULES is not set | 150 | # CONFIG_MODULES is not set |
| 137 | CONFIG_BLOCK=y | 151 | CONFIG_BLOCK=y |
| 138 | # CONFIG_LBD is not set | 152 | CONFIG_LBDAF=y |
| 139 | # CONFIG_BLK_DEV_BSG is not set | 153 | # CONFIG_BLK_DEV_BSG is not set |
| 140 | # CONFIG_BLK_DEV_INTEGRITY is not set | 154 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 141 | 155 | ||
| @@ -220,6 +234,7 @@ CONFIG_BINFMT_ELF=y | |||
| 220 | # CONFIG_MATH_EMULATION is not set | 234 | # CONFIG_MATH_EMULATION is not set |
| 221 | # CONFIG_8XX_MINIMAL_FPEMU is not set | 235 | # CONFIG_8XX_MINIMAL_FPEMU is not set |
| 222 | # CONFIG_IOMMU_HELPER is not set | 236 | # CONFIG_IOMMU_HELPER is not set |
| 237 | # CONFIG_SWIOTLB is not set | ||
| 223 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y | 238 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y |
| 224 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 239 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 225 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 240 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| @@ -239,9 +254,9 @@ CONFIG_MIGRATION=y | |||
| 239 | CONFIG_ZONE_DMA_FLAG=1 | 254 | CONFIG_ZONE_DMA_FLAG=1 |
| 240 | CONFIG_BOUNCE=y | 255 | CONFIG_BOUNCE=y |
| 241 | CONFIG_VIRT_TO_BUS=y | 256 | CONFIG_VIRT_TO_BUS=y |
| 242 | CONFIG_UNEVICTABLE_LRU=y | ||
| 243 | CONFIG_HAVE_MLOCK=y | 257 | CONFIG_HAVE_MLOCK=y |
| 244 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 258 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 259 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 245 | CONFIG_PPC_4K_PAGES=y | 260 | CONFIG_PPC_4K_PAGES=y |
| 246 | # CONFIG_PPC_16K_PAGES is not set | 261 | # CONFIG_PPC_16K_PAGES is not set |
| 247 | # CONFIG_PPC_64K_PAGES is not set | 262 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -280,6 +295,7 @@ CONFIG_PAGE_OFFSET=0xc0000000 | |||
| 280 | CONFIG_KERNEL_START=0xc0000000 | 295 | CONFIG_KERNEL_START=0xc0000000 |
| 281 | CONFIG_PHYSICAL_START=0x00000000 | 296 | CONFIG_PHYSICAL_START=0x00000000 |
| 282 | CONFIG_TASK_SIZE=0x80000000 | 297 | CONFIG_TASK_SIZE=0x80000000 |
| 298 | CONFIG_CONSISTENT_SIZE=0x00200000 | ||
| 283 | CONFIG_NET=y | 299 | CONFIG_NET=y |
| 284 | 300 | ||
| 285 | # | 301 | # |
| @@ -336,6 +352,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 336 | # CONFIG_ECONET is not set | 352 | # CONFIG_ECONET is not set |
| 337 | # CONFIG_WAN_ROUTER is not set | 353 | # CONFIG_WAN_ROUTER is not set |
| 338 | # CONFIG_PHONET is not set | 354 | # CONFIG_PHONET is not set |
| 355 | # CONFIG_IEEE802154 is not set | ||
| 339 | # CONFIG_NET_SCHED is not set | 356 | # CONFIG_NET_SCHED is not set |
| 340 | # CONFIG_DCB is not set | 357 | # CONFIG_DCB is not set |
| 341 | 358 | ||
| @@ -353,7 +370,11 @@ CONFIG_WIRELESS=y | |||
| 353 | CONFIG_WIRELESS_OLD_REGULATORY=y | 370 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 354 | # CONFIG_WIRELESS_EXT is not set | 371 | # CONFIG_WIRELESS_EXT is not set |
| 355 | # CONFIG_LIB80211 is not set | 372 | # CONFIG_LIB80211 is not set |
| 356 | # CONFIG_MAC80211 is not set | 373 | |
| 374 | # | ||
| 375 | # CFG80211 needs to be enabled for MAC80211 | ||
| 376 | # | ||
| 377 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 357 | # CONFIG_WIMAX is not set | 378 | # CONFIG_WIMAX is not set |
| 358 | # CONFIG_RFKILL is not set | 379 | # CONFIG_RFKILL is not set |
| 359 | # CONFIG_NET_9P is not set | 380 | # CONFIG_NET_9P is not set |
| @@ -452,6 +473,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 452 | # | 473 | # |
| 453 | # CONFIG_MTD_UBI is not set | 474 | # CONFIG_MTD_UBI is not set |
| 454 | CONFIG_OF_DEVICE=y | 475 | CONFIG_OF_DEVICE=y |
| 476 | CONFIG_OF_MDIO=y | ||
| 455 | # CONFIG_PARPORT is not set | 477 | # CONFIG_PARPORT is not set |
| 456 | # CONFIG_BLK_DEV is not set | 478 | # CONFIG_BLK_DEV is not set |
| 457 | # CONFIG_MISC_DEVICES is not set | 479 | # CONFIG_MISC_DEVICES is not set |
| @@ -469,7 +491,6 @@ CONFIG_HAVE_IDE=y | |||
| 469 | # CONFIG_MD is not set | 491 | # CONFIG_MD is not set |
| 470 | # CONFIG_MACINTOSH_DRIVERS is not set | 492 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 471 | CONFIG_NETDEVICES=y | 493 | CONFIG_NETDEVICES=y |
| 472 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 473 | # CONFIG_DUMMY is not set | 494 | # CONFIG_DUMMY is not set |
| 474 | # CONFIG_BONDING is not set | 495 | # CONFIG_BONDING is not set |
| 475 | # CONFIG_MACVLAN is not set | 496 | # CONFIG_MACVLAN is not set |
| @@ -508,6 +529,7 @@ CONFIG_MII=y | |||
| 508 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 529 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 509 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 530 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 510 | # CONFIG_B44 is not set | 531 | # CONFIG_B44 is not set |
| 532 | # CONFIG_KS8842 is not set | ||
| 511 | CONFIG_FS_ENET=y | 533 | CONFIG_FS_ENET=y |
| 512 | # CONFIG_FS_ENET_HAS_SCC is not set | 534 | # CONFIG_FS_ENET_HAS_SCC is not set |
| 513 | CONFIG_FS_ENET_HAS_FEC=y | 535 | CONFIG_FS_ENET_HAS_FEC=y |
| @@ -556,11 +578,11 @@ CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 | |||
| 556 | # | 578 | # |
| 557 | CONFIG_INPUT_KEYBOARD=y | 579 | CONFIG_INPUT_KEYBOARD=y |
| 558 | CONFIG_KEYBOARD_ATKBD=y | 580 | CONFIG_KEYBOARD_ATKBD=y |
| 559 | # CONFIG_KEYBOARD_SUNKBD is not set | ||
| 560 | # CONFIG_KEYBOARD_LKKBD is not set | 581 | # CONFIG_KEYBOARD_LKKBD is not set |
| 561 | # CONFIG_KEYBOARD_XTKBD is not set | ||
| 562 | # CONFIG_KEYBOARD_NEWTON is not set | 582 | # CONFIG_KEYBOARD_NEWTON is not set |
| 563 | # CONFIG_KEYBOARD_STOWAWAY is not set | 583 | # CONFIG_KEYBOARD_STOWAWAY is not set |
| 584 | # CONFIG_KEYBOARD_SUNKBD is not set | ||
| 585 | # CONFIG_KEYBOARD_XTKBD is not set | ||
| 564 | CONFIG_INPUT_MOUSE=y | 586 | CONFIG_INPUT_MOUSE=y |
| 565 | CONFIG_MOUSE_PS2=y | 587 | CONFIG_MOUSE_PS2=y |
| 566 | CONFIG_MOUSE_PS2_ALPS=y | 588 | CONFIG_MOUSE_PS2_ALPS=y |
| @@ -622,6 +644,11 @@ CONFIG_GEN_RTC=y | |||
| 622 | # CONFIG_TCG_TPM is not set | 644 | # CONFIG_TCG_TPM is not set |
| 623 | # CONFIG_I2C is not set | 645 | # CONFIG_I2C is not set |
| 624 | # CONFIG_SPI is not set | 646 | # CONFIG_SPI is not set |
| 647 | |||
| 648 | # | ||
| 649 | # PPS support | ||
| 650 | # | ||
| 651 | # CONFIG_PPS is not set | ||
| 625 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 652 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 626 | # CONFIG_GPIOLIB is not set | 653 | # CONFIG_GPIOLIB is not set |
| 627 | # CONFIG_W1 is not set | 654 | # CONFIG_W1 is not set |
| @@ -644,22 +671,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 644 | # CONFIG_HTC_PASIC3 is not set | 671 | # CONFIG_HTC_PASIC3 is not set |
| 645 | # CONFIG_MFD_TMIO is not set | 672 | # CONFIG_MFD_TMIO is not set |
| 646 | # CONFIG_REGULATOR is not set | 673 | # CONFIG_REGULATOR is not set |
| 647 | 674 | # CONFIG_MEDIA_SUPPORT is not set | |
| 648 | # | ||
| 649 | # Multimedia devices | ||
| 650 | # | ||
| 651 | |||
| 652 | # | ||
| 653 | # Multimedia core support | ||
| 654 | # | ||
| 655 | # CONFIG_VIDEO_DEV is not set | ||
| 656 | # CONFIG_DVB_CORE is not set | ||
| 657 | # CONFIG_VIDEO_MEDIA is not set | ||
| 658 | |||
| 659 | # | ||
| 660 | # Multimedia drivers | ||
| 661 | # | ||
| 662 | CONFIG_DAB=y | ||
| 663 | 675 | ||
| 664 | # | 676 | # |
| 665 | # Graphics support | 677 | # Graphics support |
| @@ -685,6 +697,10 @@ CONFIG_VIDEO_OUTPUT_CONTROL=y | |||
| 685 | # CONFIG_DMADEVICES is not set | 697 | # CONFIG_DMADEVICES is not set |
| 686 | # CONFIG_AUXDISPLAY is not set | 698 | # CONFIG_AUXDISPLAY is not set |
| 687 | # CONFIG_UIO is not set | 699 | # CONFIG_UIO is not set |
| 700 | |||
| 701 | # | ||
| 702 | # TI VLYNQ | ||
| 703 | # | ||
| 688 | # CONFIG_STAGING is not set | 704 | # CONFIG_STAGING is not set |
| 689 | 705 | ||
| 690 | # | 706 | # |
| @@ -696,12 +712,15 @@ CONFIG_VIDEO_OUTPUT_CONTROL=y | |||
| 696 | # CONFIG_REISERFS_FS is not set | 712 | # CONFIG_REISERFS_FS is not set |
| 697 | # CONFIG_JFS_FS is not set | 713 | # CONFIG_JFS_FS is not set |
| 698 | # CONFIG_FS_POSIX_ACL is not set | 714 | # CONFIG_FS_POSIX_ACL is not set |
| 699 | CONFIG_FILE_LOCKING=y | ||
| 700 | # CONFIG_XFS_FS is not set | 715 | # CONFIG_XFS_FS is not set |
| 716 | # CONFIG_GFS2_FS is not set | ||
| 701 | # CONFIG_OCFS2_FS is not set | 717 | # CONFIG_OCFS2_FS is not set |
| 702 | # CONFIG_BTRFS_FS is not set | 718 | # CONFIG_BTRFS_FS is not set |
| 719 | CONFIG_FILE_LOCKING=y | ||
| 720 | CONFIG_FSNOTIFY=y | ||
| 703 | # CONFIG_DNOTIFY is not set | 721 | # CONFIG_DNOTIFY is not set |
| 704 | # CONFIG_INOTIFY is not set | 722 | # CONFIG_INOTIFY is not set |
| 723 | CONFIG_INOTIFY_USER=y | ||
| 705 | # CONFIG_QUOTA is not set | 724 | # CONFIG_QUOTA is not set |
| 706 | # CONFIG_AUTOFS_FS is not set | 725 | # CONFIG_AUTOFS_FS is not set |
| 707 | # CONFIG_AUTOFS4_FS is not set | 726 | # CONFIG_AUTOFS4_FS is not set |
| @@ -818,6 +837,7 @@ CONFIG_HAS_IOPORT=y | |||
| 818 | CONFIG_HAS_DMA=y | 837 | CONFIG_HAS_DMA=y |
| 819 | CONFIG_HAVE_LMB=y | 838 | CONFIG_HAVE_LMB=y |
| 820 | CONFIG_NLATTR=y | 839 | CONFIG_NLATTR=y |
| 840 | CONFIG_GENERIC_ATOMIC64=y | ||
| 821 | 841 | ||
| 822 | # | 842 | # |
| 823 | # Kernel hacking | 843 | # Kernel hacking |
| @@ -846,6 +866,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 846 | # CONFIG_SLUB_STATS is not set | 866 | # CONFIG_SLUB_STATS is not set |
| 847 | # CONFIG_DEBUG_SPINLOCK is not set | 867 | # CONFIG_DEBUG_SPINLOCK is not set |
| 848 | # CONFIG_DEBUG_MUTEXES is not set | 868 | # CONFIG_DEBUG_MUTEXES is not set |
| 869 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 870 | # CONFIG_PROVE_LOCKING is not set | ||
| 871 | # CONFIG_LOCK_STAT is not set | ||
| 849 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 872 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 850 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 873 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 851 | # CONFIG_DEBUG_KOBJECT is not set | 874 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -857,7 +880,6 @@ CONFIG_DEBUG_INFO=y | |||
| 857 | # CONFIG_DEBUG_LIST is not set | 880 | # CONFIG_DEBUG_LIST is not set |
| 858 | # CONFIG_DEBUG_SG is not set | 881 | # CONFIG_DEBUG_SG is not set |
| 859 | # CONFIG_DEBUG_NOTIFIERS is not set | 882 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 860 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 861 | # CONFIG_RCU_TORTURE_TEST is not set | 883 | # CONFIG_RCU_TORTURE_TEST is not set |
| 862 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 884 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 863 | # CONFIG_BACKTRACE_SELF_TEST is not set | 885 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -870,16 +892,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 870 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 892 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 871 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 893 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 872 | CONFIG_TRACING_SUPPORT=y | 894 | CONFIG_TRACING_SUPPORT=y |
| 873 | 895 | CONFIG_FTRACE=y | |
| 874 | # | ||
| 875 | # Tracers | ||
| 876 | # | ||
| 877 | # CONFIG_FUNCTION_TRACER is not set | 896 | # CONFIG_FUNCTION_TRACER is not set |
| 897 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 878 | # CONFIG_SCHED_TRACER is not set | 898 | # CONFIG_SCHED_TRACER is not set |
| 879 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 899 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 880 | # CONFIG_EVENT_TRACER is not set | ||
| 881 | # CONFIG_BOOT_TRACER is not set | 900 | # CONFIG_BOOT_TRACER is not set |
| 882 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 901 | CONFIG_BRANCH_PROFILE_NONE=y |
| 902 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 903 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 883 | # CONFIG_STACK_TRACER is not set | 904 | # CONFIG_STACK_TRACER is not set |
| 884 | # CONFIG_KMEMTRACE is not set | 905 | # CONFIG_KMEMTRACE is not set |
| 885 | # CONFIG_WORKQUEUE_TRACER is not set | 906 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -888,9 +909,13 @@ CONFIG_TRACING_SUPPORT=y | |||
| 888 | # CONFIG_SAMPLES is not set | 909 | # CONFIG_SAMPLES is not set |
| 889 | CONFIG_HAVE_ARCH_KGDB=y | 910 | CONFIG_HAVE_ARCH_KGDB=y |
| 890 | # CONFIG_KGDB is not set | 911 | # CONFIG_KGDB is not set |
| 912 | # CONFIG_KMEMCHECK is not set | ||
| 913 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 914 | CONFIG_PPC_WERROR=y | ||
| 891 | CONFIG_PRINT_STACK_DEPTH=64 | 915 | CONFIG_PRINT_STACK_DEPTH=64 |
| 892 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 916 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 893 | # CONFIG_DEBUG_STACK_USAGE is not set | 917 | # CONFIG_DEBUG_STACK_USAGE is not set |
| 918 | # CONFIG_PPC_EMULATED_STATS is not set | ||
| 894 | # CONFIG_CODE_PATCHING_SELFTEST is not set | 919 | # CONFIG_CODE_PATCHING_SELFTEST is not set |
| 895 | # CONFIG_FTR_FIXUP_SELFTEST is not set | 920 | # CONFIG_FTR_FIXUP_SELFTEST is not set |
| 896 | # CONFIG_MSI_BITMAP_SELFTEST is not set | 921 | # CONFIG_MSI_BITMAP_SELFTEST is not set |
diff --git a/arch/powerpc/configs/c2k_defconfig b/arch/powerpc/configs/c2k_defconfig index 9ffa8de92803..8105360d53f4 100644 --- a/arch/powerpc/configs/c2k_defconfig +++ b/arch/powerpc/configs/c2k_defconfig | |||
| @@ -1,25 +1,27 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:21:51 2009 | 4 | # Wed Jul 29 23:31:48 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_ALTIVEC is not set | 20 | # CONFIG_ALTIVEC is not set |
| 20 | CONFIG_PPC_STD_MMU=y | 21 | CONFIG_PPC_STD_MMU=y |
| 21 | CONFIG_PPC_STD_MMU_32=y | 22 | CONFIG_PPC_STD_MMU_32=y |
| 22 | # CONFIG_PPC_MM_SLICES is not set | 23 | # CONFIG_PPC_MM_SLICES is not set |
| 24 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 23 | # CONFIG_SMP is not set | 25 | # CONFIG_SMP is not set |
| 24 | CONFIG_NOT_COHERENT_CACHE=y | 26 | CONFIG_NOT_COHERENT_CACHE=y |
| 25 | CONFIG_CHECK_CACHE_COHERENCY=y | 27 | CONFIG_CHECK_CACHE_COHERENCY=y |
| @@ -32,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 32 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 33 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 34 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 35 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 36 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 37 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 38 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 39 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 40 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 41 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 42 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 43 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 44 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 45 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 46 | CONFIG_PPC=y | 49 | CONFIG_PPC=y |
| @@ -54,11 +57,13 @@ CONFIG_OF=y | |||
| 54 | # CONFIG_GENERIC_TBSYNC is not set | 57 | # CONFIG_GENERIC_TBSYNC is not set |
| 55 | CONFIG_AUDIT_ARCH=y | 58 | CONFIG_AUDIT_ARCH=y |
| 56 | CONFIG_GENERIC_BUG=y | 59 | CONFIG_GENERIC_BUG=y |
| 60 | CONFIG_DTC=y | ||
| 57 | # CONFIG_DEFAULT_UIMAGE is not set | 61 | # CONFIG_DEFAULT_UIMAGE is not set |
| 58 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 59 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 60 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 61 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 62 | 67 | ||
| 63 | # | 68 | # |
| 64 | # General setup | 69 | # General setup |
| @@ -118,7 +123,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 118 | CONFIG_KALLSYMS=y | 123 | CONFIG_KALLSYMS=y |
| 119 | # CONFIG_KALLSYMS_ALL is not set | 124 | # CONFIG_KALLSYMS_ALL is not set |
| 120 | CONFIG_KALLSYMS_EXTRA_PASS=y | 125 | CONFIG_KALLSYMS_EXTRA_PASS=y |
| 121 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 122 | CONFIG_HOTPLUG=y | 126 | CONFIG_HOTPLUG=y |
| 123 | CONFIG_PRINTK=y | 127 | CONFIG_PRINTK=y |
| 124 | CONFIG_BUG=y | 128 | CONFIG_BUG=y |
| @@ -131,16 +135,23 @@ CONFIG_TIMERFD=y | |||
| 131 | CONFIG_EVENTFD=y | 135 | CONFIG_EVENTFD=y |
| 132 | CONFIG_SHMEM=y | 136 | CONFIG_SHMEM=y |
| 133 | CONFIG_AIO=y | 137 | CONFIG_AIO=y |
| 138 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 139 | |||
| 140 | # | ||
| 141 | # Performance Counters | ||
| 142 | # | ||
| 143 | # CONFIG_PERF_COUNTERS is not set | ||
| 134 | CONFIG_VM_EVENT_COUNTERS=y | 144 | CONFIG_VM_EVENT_COUNTERS=y |
| 135 | CONFIG_PCI_QUIRKS=y | 145 | CONFIG_PCI_QUIRKS=y |
| 136 | CONFIG_SLUB_DEBUG=y | 146 | CONFIG_SLUB_DEBUG=y |
| 147 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 137 | CONFIG_COMPAT_BRK=y | 148 | CONFIG_COMPAT_BRK=y |
| 138 | # CONFIG_SLAB is not set | 149 | # CONFIG_SLAB is not set |
| 139 | CONFIG_SLUB=y | 150 | CONFIG_SLUB=y |
| 140 | # CONFIG_SLOB is not set | 151 | # CONFIG_SLOB is not set |
| 141 | CONFIG_PROFILING=y | 152 | CONFIG_PROFILING=y |
| 142 | CONFIG_TRACEPOINTS=y | 153 | CONFIG_TRACEPOINTS=y |
| 143 | # CONFIG_MARKERS is not set | 154 | CONFIG_MARKERS=y |
| 144 | CONFIG_OPROFILE=m | 155 | CONFIG_OPROFILE=m |
| 145 | CONFIG_HAVE_OPROFILE=y | 156 | CONFIG_HAVE_OPROFILE=y |
| 146 | CONFIG_KPROBES=y | 157 | CONFIG_KPROBES=y |
| @@ -150,6 +161,11 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 150 | CONFIG_HAVE_KPROBES=y | 161 | CONFIG_HAVE_KPROBES=y |
| 151 | CONFIG_HAVE_KRETPROBES=y | 162 | CONFIG_HAVE_KRETPROBES=y |
| 152 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 163 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 164 | |||
| 165 | # | ||
| 166 | # GCOV-based kernel profiling | ||
| 167 | # | ||
| 168 | # CONFIG_GCOV_KERNEL is not set | ||
| 153 | # CONFIG_SLOW_WORK is not set | 169 | # CONFIG_SLOW_WORK is not set |
| 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 170 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 155 | CONFIG_SLABINFO=y | 171 | CONFIG_SLABINFO=y |
| @@ -162,7 +178,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 162 | CONFIG_MODVERSIONS=y | 178 | CONFIG_MODVERSIONS=y |
| 163 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 179 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 164 | CONFIG_BLOCK=y | 180 | CONFIG_BLOCK=y |
| 165 | CONFIG_LBD=y | 181 | CONFIG_LBDAF=y |
| 166 | # CONFIG_BLK_DEV_BSG is not set | 182 | # CONFIG_BLK_DEV_BSG is not set |
| 167 | # CONFIG_BLK_DEV_INTEGRITY is not set | 183 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 168 | 184 | ||
| @@ -258,6 +274,7 @@ CONFIG_BINFMT_ELF=y | |||
| 258 | # CONFIG_HAVE_AOUT is not set | 274 | # CONFIG_HAVE_AOUT is not set |
| 259 | CONFIG_BINFMT_MISC=y | 275 | CONFIG_BINFMT_MISC=y |
| 260 | # CONFIG_IOMMU_HELPER is not set | 276 | # CONFIG_IOMMU_HELPER is not set |
| 277 | # CONFIG_SWIOTLB is not set | ||
| 261 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y | 278 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y |
| 262 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 279 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 263 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 280 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| @@ -279,9 +296,9 @@ CONFIG_MIGRATION=y | |||
| 279 | CONFIG_ZONE_DMA_FLAG=1 | 296 | CONFIG_ZONE_DMA_FLAG=1 |
| 280 | CONFIG_BOUNCE=y | 297 | CONFIG_BOUNCE=y |
| 281 | CONFIG_VIRT_TO_BUS=y | 298 | CONFIG_VIRT_TO_BUS=y |
| 282 | CONFIG_UNEVICTABLE_LRU=y | ||
| 283 | CONFIG_HAVE_MLOCK=y | 299 | CONFIG_HAVE_MLOCK=y |
| 284 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 300 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 301 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 285 | CONFIG_PPC_4K_PAGES=y | 302 | CONFIG_PPC_4K_PAGES=y |
| 286 | # CONFIG_PPC_16K_PAGES is not set | 303 | # CONFIG_PPC_16K_PAGES is not set |
| 287 | # CONFIG_PPC_64K_PAGES is not set | 304 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -331,6 +348,7 @@ CONFIG_PAGE_OFFSET=0xc0000000 | |||
| 331 | CONFIG_KERNEL_START=0xc0000000 | 348 | CONFIG_KERNEL_START=0xc0000000 |
| 332 | CONFIG_PHYSICAL_START=0x00000000 | 349 | CONFIG_PHYSICAL_START=0x00000000 |
| 333 | CONFIG_TASK_SIZE=0xc0000000 | 350 | CONFIG_TASK_SIZE=0xc0000000 |
| 351 | CONFIG_CONSISTENT_SIZE=0x00200000 | ||
| 334 | CONFIG_NET=y | 352 | CONFIG_NET=y |
| 335 | 353 | ||
| 336 | # | 354 | # |
| @@ -583,6 +601,7 @@ CONFIG_LLC=m | |||
| 583 | # CONFIG_ECONET is not set | 601 | # CONFIG_ECONET is not set |
| 584 | # CONFIG_WAN_ROUTER is not set | 602 | # CONFIG_WAN_ROUTER is not set |
| 585 | # CONFIG_PHONET is not set | 603 | # CONFIG_PHONET is not set |
| 604 | # CONFIG_IEEE802154 is not set | ||
| 586 | CONFIG_NET_SCHED=y | 605 | CONFIG_NET_SCHED=y |
| 587 | 606 | ||
| 588 | # | 607 | # |
| @@ -663,7 +682,11 @@ CONFIG_WIRELESS_OLD_REGULATORY=y | |||
| 663 | CONFIG_WIRELESS_EXT=y | 682 | CONFIG_WIRELESS_EXT=y |
| 664 | CONFIG_WIRELESS_EXT_SYSFS=y | 683 | CONFIG_WIRELESS_EXT_SYSFS=y |
| 665 | # CONFIG_LIB80211 is not set | 684 | # CONFIG_LIB80211 is not set |
| 666 | # CONFIG_MAC80211 is not set | 685 | |
| 686 | # | ||
| 687 | # CFG80211 needs to be enabled for MAC80211 | ||
| 688 | # | ||
| 689 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 667 | # CONFIG_WIMAX is not set | 690 | # CONFIG_WIMAX is not set |
| 668 | # CONFIG_RFKILL is not set | 691 | # CONFIG_RFKILL is not set |
| 669 | # CONFIG_NET_9P is not set | 692 | # CONFIG_NET_9P is not set |
| @@ -772,6 +795,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 772 | # CONFIG_MTD_UBI is not set | 795 | # CONFIG_MTD_UBI is not set |
| 773 | CONFIG_OF_DEVICE=y | 796 | CONFIG_OF_DEVICE=y |
| 774 | CONFIG_OF_I2C=m | 797 | CONFIG_OF_I2C=m |
| 798 | CONFIG_OF_MDIO=y | ||
| 775 | # CONFIG_PARPORT is not set | 799 | # CONFIG_PARPORT is not set |
| 776 | CONFIG_BLK_DEV=y | 800 | CONFIG_BLK_DEV=y |
| 777 | # CONFIG_BLK_DEV_FD is not set | 801 | # CONFIG_BLK_DEV_FD is not set |
| @@ -816,10 +840,6 @@ CONFIG_BLK_DEV_SR=m | |||
| 816 | CONFIG_BLK_DEV_SR_VENDOR=y | 840 | CONFIG_BLK_DEV_SR_VENDOR=y |
| 817 | CONFIG_CHR_DEV_SG=m | 841 | CONFIG_CHR_DEV_SG=m |
| 818 | # CONFIG_CHR_DEV_SCH is not set | 842 | # CONFIG_CHR_DEV_SCH is not set |
| 819 | |||
| 820 | # | ||
| 821 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 822 | # | ||
| 823 | # CONFIG_SCSI_MULTI_LUN is not set | 843 | # CONFIG_SCSI_MULTI_LUN is not set |
| 824 | CONFIG_SCSI_CONSTANTS=y | 844 | CONFIG_SCSI_CONSTANTS=y |
| 825 | CONFIG_SCSI_LOGGING=y | 845 | CONFIG_SCSI_LOGGING=y |
| @@ -836,6 +856,7 @@ CONFIG_SCSI_ISCSI_ATTRS=m | |||
| 836 | CONFIG_SCSI_SRP_ATTRS=m | 856 | CONFIG_SCSI_SRP_ATTRS=m |
| 837 | CONFIG_SCSI_LOWLEVEL=y | 857 | CONFIG_SCSI_LOWLEVEL=y |
| 838 | # CONFIG_ISCSI_TCP is not set | 858 | # CONFIG_ISCSI_TCP is not set |
| 859 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 839 | CONFIG_BLK_DEV_3W_XXXX_RAID=m | 860 | CONFIG_BLK_DEV_3W_XXXX_RAID=m |
| 840 | CONFIG_SCSI_3W_9XXX=m | 861 | CONFIG_SCSI_3W_9XXX=m |
| 841 | CONFIG_SCSI_ACARD=m | 862 | CONFIG_SCSI_ACARD=m |
| @@ -854,6 +875,7 @@ CONFIG_AIC79XX_RESET_DELAY_MS=15000 | |||
| 854 | CONFIG_AIC79XX_DEBUG_MASK=0 | 875 | CONFIG_AIC79XX_DEBUG_MASK=0 |
| 855 | # CONFIG_AIC79XX_REG_PRETTY_PRINT is not set | 876 | # CONFIG_AIC79XX_REG_PRETTY_PRINT is not set |
| 856 | # CONFIG_SCSI_AIC94XX is not set | 877 | # CONFIG_SCSI_AIC94XX is not set |
| 878 | # CONFIG_SCSI_MVSAS is not set | ||
| 857 | # CONFIG_SCSI_DPT_I2O is not set | 879 | # CONFIG_SCSI_DPT_I2O is not set |
| 858 | # CONFIG_SCSI_ADVANSYS is not set | 880 | # CONFIG_SCSI_ADVANSYS is not set |
| 859 | CONFIG_SCSI_ARCMSR=m | 881 | CONFIG_SCSI_ARCMSR=m |
| @@ -875,7 +897,6 @@ CONFIG_SCSI_GDTH=m | |||
| 875 | CONFIG_SCSI_IPS=m | 897 | CONFIG_SCSI_IPS=m |
| 876 | CONFIG_SCSI_INITIO=m | 898 | CONFIG_SCSI_INITIO=m |
| 877 | # CONFIG_SCSI_INIA100 is not set | 899 | # CONFIG_SCSI_INIA100 is not set |
| 878 | # CONFIG_SCSI_MVSAS is not set | ||
| 879 | # CONFIG_SCSI_STEX is not set | 900 | # CONFIG_SCSI_STEX is not set |
| 880 | CONFIG_SCSI_SYM53C8XX_2=m | 901 | CONFIG_SCSI_SYM53C8XX_2=m |
| 881 | CONFIG_SCSI_SYM53C8XX_DMA_ADDRESSING_MODE=1 | 902 | CONFIG_SCSI_SYM53C8XX_DMA_ADDRESSING_MODE=1 |
| @@ -903,14 +924,17 @@ CONFIG_SCSI_LPFC=m | |||
| 903 | # | 924 | # |
| 904 | 925 | ||
| 905 | # | 926 | # |
| 906 | # Enable only one of the two stacks, unless you know what you are doing | 927 | # You can enable one or both FireWire driver stacks. |
| 928 | # | ||
| 929 | |||
| 930 | # | ||
| 931 | # See the help texts for more information. | ||
| 907 | # | 932 | # |
| 908 | # CONFIG_FIREWIRE is not set | 933 | # CONFIG_FIREWIRE is not set |
| 909 | # CONFIG_IEEE1394 is not set | 934 | # CONFIG_IEEE1394 is not set |
| 910 | # CONFIG_I2O is not set | 935 | # CONFIG_I2O is not set |
| 911 | # CONFIG_MACINTOSH_DRIVERS is not set | 936 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 912 | CONFIG_NETDEVICES=y | 937 | CONFIG_NETDEVICES=y |
| 913 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 914 | CONFIG_DUMMY=m | 938 | CONFIG_DUMMY=m |
| 915 | CONFIG_BONDING=m | 939 | CONFIG_BONDING=m |
| 916 | # CONFIG_MACVLAN is not set | 940 | # CONFIG_MACVLAN is not set |
| @@ -957,6 +981,7 @@ CONFIG_MII=y | |||
| 957 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 981 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 958 | # CONFIG_NET_PCI is not set | 982 | # CONFIG_NET_PCI is not set |
| 959 | # CONFIG_B44 is not set | 983 | # CONFIG_B44 is not set |
| 984 | # CONFIG_KS8842 is not set | ||
| 960 | # CONFIG_ATL2 is not set | 985 | # CONFIG_ATL2 is not set |
| 961 | CONFIG_NETDEV_1000=y | 986 | CONFIG_NETDEV_1000=y |
| 962 | # CONFIG_ACENIC is not set | 987 | # CONFIG_ACENIC is not set |
| @@ -976,6 +1001,7 @@ CONFIG_NETDEV_1000=y | |||
| 976 | # CONFIG_VIA_VELOCITY is not set | 1001 | # CONFIG_VIA_VELOCITY is not set |
| 977 | # CONFIG_TIGON3 is not set | 1002 | # CONFIG_TIGON3 is not set |
| 978 | # CONFIG_BNX2 is not set | 1003 | # CONFIG_BNX2 is not set |
| 1004 | # CONFIG_CNIC is not set | ||
| 979 | CONFIG_MV643XX_ETH=y | 1005 | CONFIG_MV643XX_ETH=y |
| 980 | # CONFIG_QLA3XXX is not set | 1006 | # CONFIG_QLA3XXX is not set |
| 981 | # CONFIG_ATL1 is not set | 1007 | # CONFIG_ATL1 is not set |
| @@ -1177,13 +1203,17 @@ CONFIG_I2C_MV64XXX=m | |||
| 1177 | CONFIG_SENSORS_PCF8574=m | 1203 | CONFIG_SENSORS_PCF8574=m |
| 1178 | # CONFIG_PCF8575 is not set | 1204 | # CONFIG_PCF8575 is not set |
| 1179 | # CONFIG_SENSORS_PCA9539 is not set | 1205 | # CONFIG_SENSORS_PCA9539 is not set |
| 1180 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 1181 | # CONFIG_SENSORS_TSL2550 is not set | 1206 | # CONFIG_SENSORS_TSL2550 is not set |
| 1182 | # CONFIG_I2C_DEBUG_CORE is not set | 1207 | # CONFIG_I2C_DEBUG_CORE is not set |
| 1183 | # CONFIG_I2C_DEBUG_ALGO is not set | 1208 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 1184 | # CONFIG_I2C_DEBUG_BUS is not set | 1209 | # CONFIG_I2C_DEBUG_BUS is not set |
| 1185 | # CONFIG_I2C_DEBUG_CHIP is not set | 1210 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 1186 | # CONFIG_SPI is not set | 1211 | # CONFIG_SPI is not set |
| 1212 | |||
| 1213 | # | ||
| 1214 | # PPS support | ||
| 1215 | # | ||
| 1216 | # CONFIG_PPS is not set | ||
| 1187 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 1217 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 1188 | # CONFIG_GPIOLIB is not set | 1218 | # CONFIG_GPIOLIB is not set |
| 1189 | # CONFIG_W1 is not set | 1219 | # CONFIG_W1 is not set |
| @@ -1238,6 +1268,7 @@ CONFIG_SENSORS_SMSC47M1=m | |||
| 1238 | CONFIG_SENSORS_SMSC47B397=m | 1268 | CONFIG_SENSORS_SMSC47B397=m |
| 1239 | # CONFIG_SENSORS_ADS7828 is not set | 1269 | # CONFIG_SENSORS_ADS7828 is not set |
| 1240 | # CONFIG_SENSORS_THMC50 is not set | 1270 | # CONFIG_SENSORS_THMC50 is not set |
| 1271 | # CONFIG_SENSORS_TMP401 is not set | ||
| 1241 | CONFIG_SENSORS_VIA686A=m | 1272 | CONFIG_SENSORS_VIA686A=m |
| 1242 | # CONFIG_SENSORS_VT1211 is not set | 1273 | # CONFIG_SENSORS_VT1211 is not set |
| 1243 | # CONFIG_SENSORS_VT8231 is not set | 1274 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -1266,7 +1297,6 @@ CONFIG_SOFT_WATCHDOG=m | |||
| 1266 | # | 1297 | # |
| 1267 | CONFIG_PCIPCWATCHDOG=m | 1298 | CONFIG_PCIPCWATCHDOG=m |
| 1268 | CONFIG_WDTPCI=m | 1299 | CONFIG_WDTPCI=m |
| 1269 | CONFIG_WDT_501_PCI=y | ||
| 1270 | 1300 | ||
| 1271 | # | 1301 | # |
| 1272 | # USB-based Watchdog Cards | 1302 | # USB-based Watchdog Cards |
| @@ -1289,23 +1319,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1289 | # CONFIG_MFD_WM8400 is not set | 1319 | # CONFIG_MFD_WM8400 is not set |
| 1290 | # CONFIG_MFD_WM8350_I2C is not set | 1320 | # CONFIG_MFD_WM8350_I2C is not set |
| 1291 | # CONFIG_MFD_PCF50633 is not set | 1321 | # CONFIG_MFD_PCF50633 is not set |
| 1322 | # CONFIG_AB3100_CORE is not set | ||
| 1292 | # CONFIG_REGULATOR is not set | 1323 | # CONFIG_REGULATOR is not set |
| 1293 | 1324 | # CONFIG_MEDIA_SUPPORT is not set | |
| 1294 | # | ||
| 1295 | # Multimedia devices | ||
| 1296 | # | ||
| 1297 | |||
| 1298 | # | ||
| 1299 | # Multimedia core support | ||
| 1300 | # | ||
| 1301 | # CONFIG_VIDEO_DEV is not set | ||
| 1302 | # CONFIG_DVB_CORE is not set | ||
| 1303 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1304 | |||
| 1305 | # | ||
| 1306 | # Multimedia drivers | ||
| 1307 | # | ||
| 1308 | # CONFIG_DAB is not set | ||
| 1309 | 1325 | ||
| 1310 | # | 1326 | # |
| 1311 | # Graphics support | 1327 | # Graphics support |
| @@ -1354,6 +1370,7 @@ CONFIG_USB_MON=m | |||
| 1354 | # USB Host Controller Drivers | 1370 | # USB Host Controller Drivers |
| 1355 | # | 1371 | # |
| 1356 | # CONFIG_USB_C67X00_HCD is not set | 1372 | # CONFIG_USB_C67X00_HCD is not set |
| 1373 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1357 | CONFIG_USB_EHCI_HCD=m | 1374 | CONFIG_USB_EHCI_HCD=m |
| 1358 | CONFIG_USB_EHCI_ROOT_HUB_TT=y | 1375 | CONFIG_USB_EHCI_ROOT_HUB_TT=y |
| 1359 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1376 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1362,9 +1379,9 @@ CONFIG_USB_EHCI_HCD_PPC_OF=y | |||
| 1362 | # CONFIG_USB_ISP116X_HCD is not set | 1379 | # CONFIG_USB_ISP116X_HCD is not set |
| 1363 | # CONFIG_USB_ISP1760_HCD is not set | 1380 | # CONFIG_USB_ISP1760_HCD is not set |
| 1364 | CONFIG_USB_OHCI_HCD=m | 1381 | CONFIG_USB_OHCI_HCD=m |
| 1365 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1366 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y | 1382 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y |
| 1367 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set | 1383 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set |
| 1384 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1368 | CONFIG_USB_OHCI_HCD_PCI=y | 1385 | CONFIG_USB_OHCI_HCD_PCI=y |
| 1369 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y | 1386 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y |
| 1370 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y | 1387 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y |
| @@ -1545,6 +1562,10 @@ CONFIG_DMADEVICES=y | |||
| 1545 | # | 1562 | # |
| 1546 | # CONFIG_AUXDISPLAY is not set | 1563 | # CONFIG_AUXDISPLAY is not set |
| 1547 | # CONFIG_UIO is not set | 1564 | # CONFIG_UIO is not set |
| 1565 | |||
| 1566 | # | ||
| 1567 | # TI VLYNQ | ||
| 1568 | # | ||
| 1548 | # CONFIG_STAGING is not set | 1569 | # CONFIG_STAGING is not set |
| 1549 | 1570 | ||
| 1550 | # | 1571 | # |
| @@ -1563,11 +1584,12 @@ CONFIG_FS_MBCACHE=m | |||
| 1563 | # CONFIG_REISERFS_FS is not set | 1584 | # CONFIG_REISERFS_FS is not set |
| 1564 | # CONFIG_JFS_FS is not set | 1585 | # CONFIG_JFS_FS is not set |
| 1565 | CONFIG_FS_POSIX_ACL=y | 1586 | CONFIG_FS_POSIX_ACL=y |
| 1566 | CONFIG_FILE_LOCKING=y | ||
| 1567 | # CONFIG_XFS_FS is not set | 1587 | # CONFIG_XFS_FS is not set |
| 1568 | # CONFIG_GFS2_FS is not set | 1588 | # CONFIG_GFS2_FS is not set |
| 1569 | # CONFIG_OCFS2_FS is not set | 1589 | # CONFIG_OCFS2_FS is not set |
| 1570 | # CONFIG_BTRFS_FS is not set | 1590 | # CONFIG_BTRFS_FS is not set |
| 1591 | CONFIG_FILE_LOCKING=y | ||
| 1592 | CONFIG_FSNOTIFY=y | ||
| 1571 | CONFIG_DNOTIFY=y | 1593 | CONFIG_DNOTIFY=y |
| 1572 | CONFIG_INOTIFY=y | 1594 | CONFIG_INOTIFY=y |
| 1573 | CONFIG_INOTIFY_USER=y | 1595 | CONFIG_INOTIFY_USER=y |
| @@ -1652,6 +1674,7 @@ CONFIG_NFS_FS=y | |||
| 1652 | CONFIG_NFS_V3=y | 1674 | CONFIG_NFS_V3=y |
| 1653 | CONFIG_NFS_V3_ACL=y | 1675 | CONFIG_NFS_V3_ACL=y |
| 1654 | CONFIG_NFS_V4=y | 1676 | CONFIG_NFS_V4=y |
| 1677 | # CONFIG_NFS_V4_1 is not set | ||
| 1655 | CONFIG_ROOT_NFS=y | 1678 | CONFIG_ROOT_NFS=y |
| 1656 | # CONFIG_NFSD is not set | 1679 | # CONFIG_NFSD is not set |
| 1657 | CONFIG_LOCKD=y | 1680 | CONFIG_LOCKD=y |
| @@ -1764,6 +1787,7 @@ CONFIG_HAS_DMA=y | |||
| 1764 | CONFIG_CHECK_SIGNATURE=y | 1787 | CONFIG_CHECK_SIGNATURE=y |
| 1765 | CONFIG_HAVE_LMB=y | 1788 | CONFIG_HAVE_LMB=y |
| 1766 | CONFIG_NLATTR=y | 1789 | CONFIG_NLATTR=y |
| 1790 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1767 | 1791 | ||
| 1768 | # | 1792 | # |
| 1769 | # Kernel hacking | 1793 | # Kernel hacking |
| @@ -1794,6 +1818,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 1794 | # CONFIG_RT_MUTEX_TESTER is not set | 1818 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1795 | CONFIG_DEBUG_SPINLOCK=y | 1819 | CONFIG_DEBUG_SPINLOCK=y |
| 1796 | # CONFIG_DEBUG_MUTEXES is not set | 1820 | # CONFIG_DEBUG_MUTEXES is not set |
| 1821 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1822 | # CONFIG_PROVE_LOCKING is not set | ||
| 1823 | # CONFIG_LOCK_STAT is not set | ||
| 1797 | CONFIG_DEBUG_SPINLOCK_SLEEP=y | 1824 | CONFIG_DEBUG_SPINLOCK_SLEEP=y |
| 1798 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1825 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1799 | CONFIG_STACKTRACE=y | 1826 | CONFIG_STACKTRACE=y |
| @@ -1807,7 +1834,6 @@ CONFIG_DEBUG_MEMORY_INIT=y | |||
| 1807 | # CONFIG_DEBUG_LIST is not set | 1834 | # CONFIG_DEBUG_LIST is not set |
| 1808 | # CONFIG_DEBUG_SG is not set | 1835 | # CONFIG_DEBUG_SG is not set |
| 1809 | # CONFIG_DEBUG_NOTIFIERS is not set | 1836 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1810 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1811 | # CONFIG_RCU_TORTURE_TEST is not set | 1837 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1812 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1838 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1813 | # CONFIG_KPROBES_SANITY_TEST is not set | 1839 | # CONFIG_KPROBES_SANITY_TEST is not set |
| @@ -1824,30 +1850,34 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1824 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1850 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1825 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1851 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1826 | CONFIG_RING_BUFFER=y | 1852 | CONFIG_RING_BUFFER=y |
| 1853 | CONFIG_EVENT_TRACING=y | ||
| 1854 | CONFIG_CONTEXT_SWITCH_TRACER=y | ||
| 1827 | CONFIG_TRACING=y | 1855 | CONFIG_TRACING=y |
| 1828 | CONFIG_TRACING_SUPPORT=y | 1856 | CONFIG_TRACING_SUPPORT=y |
| 1829 | 1857 | CONFIG_FTRACE=y | |
| 1830 | # | ||
| 1831 | # Tracers | ||
| 1832 | # | ||
| 1833 | # CONFIG_FUNCTION_TRACER is not set | 1858 | # CONFIG_FUNCTION_TRACER is not set |
| 1859 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1834 | # CONFIG_SCHED_TRACER is not set | 1860 | # CONFIG_SCHED_TRACER is not set |
| 1835 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1861 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1836 | # CONFIG_EVENT_TRACER is not set | ||
| 1837 | # CONFIG_BOOT_TRACER is not set | 1862 | # CONFIG_BOOT_TRACER is not set |
| 1838 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1863 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1864 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1865 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1839 | # CONFIG_STACK_TRACER is not set | 1866 | # CONFIG_STACK_TRACER is not set |
| 1840 | # CONFIG_KMEMTRACE is not set | 1867 | # CONFIG_KMEMTRACE is not set |
| 1841 | # CONFIG_WORKQUEUE_TRACER is not set | 1868 | # CONFIG_WORKQUEUE_TRACER is not set |
| 1842 | # CONFIG_BLK_DEV_IO_TRACE is not set | 1869 | # CONFIG_BLK_DEV_IO_TRACE is not set |
| 1843 | # CONFIG_FTRACE_STARTUP_TEST is not set | 1870 | # CONFIG_RING_BUFFER_BENCHMARK is not set |
| 1844 | # CONFIG_DYNAMIC_DEBUG is not set | 1871 | # CONFIG_DYNAMIC_DEBUG is not set |
| 1845 | # CONFIG_SAMPLES is not set | 1872 | # CONFIG_SAMPLES is not set |
| 1846 | CONFIG_HAVE_ARCH_KGDB=y | 1873 | CONFIG_HAVE_ARCH_KGDB=y |
| 1847 | # CONFIG_KGDB is not set | 1874 | # CONFIG_KGDB is not set |
| 1875 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1876 | CONFIG_PPC_WERROR=y | ||
| 1848 | CONFIG_PRINT_STACK_DEPTH=64 | 1877 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1849 | CONFIG_DEBUG_STACKOVERFLOW=y | 1878 | CONFIG_DEBUG_STACKOVERFLOW=y |
| 1850 | CONFIG_DEBUG_STACK_USAGE=y | 1879 | CONFIG_DEBUG_STACK_USAGE=y |
| 1880 | # CONFIG_PPC_EMULATED_STATS is not set | ||
| 1851 | # CONFIG_CODE_PATCHING_SELFTEST is not set | 1881 | # CONFIG_CODE_PATCHING_SELFTEST is not set |
| 1852 | # CONFIG_FTR_FIXUP_SELFTEST is not set | 1882 | # CONFIG_FTR_FIXUP_SELFTEST is not set |
| 1853 | # CONFIG_MSI_BITMAP_SELFTEST is not set | 1883 | # CONFIG_MSI_BITMAP_SELFTEST is not set |
| @@ -1869,7 +1899,6 @@ CONFIG_SECURITY_NETWORK=y | |||
| 1869 | # CONFIG_SECURITY_NETWORK_XFRM is not set | 1899 | # CONFIG_SECURITY_NETWORK_XFRM is not set |
| 1870 | # CONFIG_SECURITY_PATH is not set | 1900 | # CONFIG_SECURITY_PATH is not set |
| 1871 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set | 1901 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set |
| 1872 | CONFIG_SECURITY_DEFAULT_MMAP_MIN_ADDR=0 | ||
| 1873 | CONFIG_SECURITY_SELINUX=y | 1902 | CONFIG_SECURITY_SELINUX=y |
| 1874 | CONFIG_SECURITY_SELINUX_BOOTPARAM=y | 1903 | CONFIG_SECURITY_SELINUX_BOOTPARAM=y |
| 1875 | CONFIG_SECURITY_SELINUX_BOOTPARAM_VALUE=1 | 1904 | CONFIG_SECURITY_SELINUX_BOOTPARAM_VALUE=1 |
diff --git a/arch/powerpc/configs/ep8248e_defconfig b/arch/powerpc/configs/ep8248e_defconfig index 04915c3a43f6..0aa5b43ffeb2 100644 --- a/arch/powerpc/configs/ep8248e_defconfig +++ b/arch/powerpc/configs/ep8248e_defconfig | |||
| @@ -1,25 +1,27 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:21:52 2009 | 4 | # Wed Jul 29 23:31:49 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_ALTIVEC is not set | 20 | # CONFIG_ALTIVEC is not set |
| 20 | CONFIG_PPC_STD_MMU=y | 21 | CONFIG_PPC_STD_MMU=y |
| 21 | CONFIG_PPC_STD_MMU_32=y | 22 | CONFIG_PPC_STD_MMU_32=y |
| 22 | # CONFIG_PPC_MM_SLICES is not set | 23 | # CONFIG_PPC_MM_SLICES is not set |
| 24 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 23 | # CONFIG_SMP is not set | 25 | # CONFIG_SMP is not set |
| 24 | CONFIG_PPC32=y | 26 | CONFIG_PPC32=y |
| 25 | CONFIG_WORD_SIZE=32 | 27 | CONFIG_WORD_SIZE=32 |
| @@ -30,15 +32,16 @@ CONFIG_GENERIC_TIME=y | |||
| 30 | CONFIG_GENERIC_TIME_VSYSCALL=y | 32 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 31 | CONFIG_GENERIC_CLOCKEVENTS=y | 33 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 32 | CONFIG_GENERIC_HARDIRQS=y | 34 | CONFIG_GENERIC_HARDIRQS=y |
| 35 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 33 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 36 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 34 | CONFIG_IRQ_PER_CPU=y | 37 | CONFIG_IRQ_PER_CPU=y |
| 35 | CONFIG_STACKTRACE_SUPPORT=y | 38 | CONFIG_STACKTRACE_SUPPORT=y |
| 36 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 39 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 40 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 37 | CONFIG_LOCKDEP_SUPPORT=y | 41 | CONFIG_LOCKDEP_SUPPORT=y |
| 38 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 39 | CONFIG_ARCH_HAS_ILOG2_U32=y | 43 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 40 | CONFIG_GENERIC_HWEIGHT=y | 44 | CONFIG_GENERIC_HWEIGHT=y |
| 41 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 42 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 45 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 43 | CONFIG_GENERIC_GPIO=y | 46 | CONFIG_GENERIC_GPIO=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -53,11 +56,13 @@ CONFIG_OF=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | # CONFIG_DEFAULT_UIMAGE is not set | 60 | # CONFIG_DEFAULT_UIMAGE is not set |
| 57 | # CONFIG_PPC_DCR_NATIVE is not set | 61 | # CONFIG_PPC_DCR_NATIVE is not set |
| 58 | # CONFIG_PPC_DCR_MMIO is not set | 62 | # CONFIG_PPC_DCR_MMIO is not set |
| 59 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 63 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 60 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 64 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 65 | CONFIG_CONSTRUCTORS=y | ||
| 61 | 66 | ||
| 62 | # | 67 | # |
| 63 | # General setup | 68 | # General setup |
| @@ -99,7 +104,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 99 | CONFIG_KALLSYMS=y | 104 | CONFIG_KALLSYMS=y |
| 100 | CONFIG_KALLSYMS_ALL=y | 105 | CONFIG_KALLSYMS_ALL=y |
| 101 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 106 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 102 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 103 | CONFIG_HOTPLUG=y | 107 | CONFIG_HOTPLUG=y |
| 104 | CONFIG_PRINTK=y | 108 | CONFIG_PRINTK=y |
| 105 | CONFIG_BUG=y | 109 | CONFIG_BUG=y |
| @@ -112,8 +116,15 @@ CONFIG_TIMERFD=y | |||
| 112 | CONFIG_EVENTFD=y | 116 | CONFIG_EVENTFD=y |
| 113 | CONFIG_SHMEM=y | 117 | CONFIG_SHMEM=y |
| 114 | CONFIG_AIO=y | 118 | CONFIG_AIO=y |
| 119 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 120 | |||
| 121 | # | ||
| 122 | # Performance Counters | ||
| 123 | # | ||
| 124 | # CONFIG_PERF_COUNTERS is not set | ||
| 115 | CONFIG_VM_EVENT_COUNTERS=y | 125 | CONFIG_VM_EVENT_COUNTERS=y |
| 116 | CONFIG_PCI_QUIRKS=y | 126 | CONFIG_PCI_QUIRKS=y |
| 127 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 117 | CONFIG_COMPAT_BRK=y | 128 | CONFIG_COMPAT_BRK=y |
| 118 | CONFIG_SLAB=y | 129 | CONFIG_SLAB=y |
| 119 | # CONFIG_SLUB is not set | 130 | # CONFIG_SLUB is not set |
| @@ -127,6 +138,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 127 | CONFIG_HAVE_KRETPROBES=y | 138 | CONFIG_HAVE_KRETPROBES=y |
| 128 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 139 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 129 | CONFIG_HAVE_CLK=y | 140 | CONFIG_HAVE_CLK=y |
| 141 | |||
| 142 | # | ||
| 143 | # GCOV-based kernel profiling | ||
| 144 | # | ||
| 130 | # CONFIG_SLOW_WORK is not set | 145 | # CONFIG_SLOW_WORK is not set |
| 131 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 146 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 132 | CONFIG_SLABINFO=y | 147 | CONFIG_SLABINFO=y |
| @@ -134,7 +149,7 @@ CONFIG_RT_MUTEXES=y | |||
| 134 | CONFIG_BASE_SMALL=0 | 149 | CONFIG_BASE_SMALL=0 |
| 135 | # CONFIG_MODULES is not set | 150 | # CONFIG_MODULES is not set |
| 136 | CONFIG_BLOCK=y | 151 | CONFIG_BLOCK=y |
| 137 | # CONFIG_LBD is not set | 152 | CONFIG_LBDAF=y |
| 138 | # CONFIG_BLK_DEV_INTEGRITY is not set | 153 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 139 | 154 | ||
| 140 | # | 155 | # |
| @@ -213,6 +228,7 @@ CONFIG_BINFMT_ELF=y | |||
| 213 | # CONFIG_HAVE_AOUT is not set | 228 | # CONFIG_HAVE_AOUT is not set |
| 214 | CONFIG_BINFMT_MISC=y | 229 | CONFIG_BINFMT_MISC=y |
| 215 | # CONFIG_IOMMU_HELPER is not set | 230 | # CONFIG_IOMMU_HELPER is not set |
| 231 | # CONFIG_SWIOTLB is not set | ||
| 216 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 232 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 217 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 233 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 218 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 234 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -228,9 +244,9 @@ CONFIG_MIGRATION=y | |||
| 228 | CONFIG_ZONE_DMA_FLAG=1 | 244 | CONFIG_ZONE_DMA_FLAG=1 |
| 229 | CONFIG_BOUNCE=y | 245 | CONFIG_BOUNCE=y |
| 230 | CONFIG_VIRT_TO_BUS=y | 246 | CONFIG_VIRT_TO_BUS=y |
| 231 | CONFIG_UNEVICTABLE_LRU=y | ||
| 232 | CONFIG_HAVE_MLOCK=y | 247 | CONFIG_HAVE_MLOCK=y |
| 233 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 248 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 249 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 234 | CONFIG_PPC_4K_PAGES=y | 250 | CONFIG_PPC_4K_PAGES=y |
| 235 | # CONFIG_PPC_16K_PAGES is not set | 251 | # CONFIG_PPC_16K_PAGES is not set |
| 236 | # CONFIG_PPC_64K_PAGES is not set | 252 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -300,6 +316,7 @@ CONFIG_IP_PNP_BOOTP=y | |||
| 300 | # CONFIG_NET_IPIP is not set | 316 | # CONFIG_NET_IPIP is not set |
| 301 | # CONFIG_NET_IPGRE is not set | 317 | # CONFIG_NET_IPGRE is not set |
| 302 | # CONFIG_IP_MROUTE is not set | 318 | # CONFIG_IP_MROUTE is not set |
| 319 | # CONFIG_ARPD is not set | ||
| 303 | CONFIG_SYN_COOKIES=y | 320 | CONFIG_SYN_COOKIES=y |
| 304 | # CONFIG_INET_AH is not set | 321 | # CONFIG_INET_AH is not set |
| 305 | # CONFIG_INET_ESP is not set | 322 | # CONFIG_INET_ESP is not set |
| @@ -380,7 +397,11 @@ CONFIG_WIRELESS=y | |||
| 380 | CONFIG_WIRELESS_OLD_REGULATORY=y | 397 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 381 | # CONFIG_WIRELESS_EXT is not set | 398 | # CONFIG_WIRELESS_EXT is not set |
| 382 | # CONFIG_LIB80211 is not set | 399 | # CONFIG_LIB80211 is not set |
| 383 | # CONFIG_MAC80211 is not set | 400 | |
| 401 | # | ||
| 402 | # CFG80211 needs to be enabled for MAC80211 | ||
| 403 | # | ||
| 404 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 384 | # CONFIG_WIMAX is not set | 405 | # CONFIG_WIMAX is not set |
| 385 | # CONFIG_RFKILL is not set | 406 | # CONFIG_RFKILL is not set |
| 386 | 407 | ||
| @@ -485,6 +506,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 485 | # CONFIG_MTD_UBI is not set | 506 | # CONFIG_MTD_UBI is not set |
| 486 | CONFIG_OF_DEVICE=y | 507 | CONFIG_OF_DEVICE=y |
| 487 | CONFIG_OF_GPIO=y | 508 | CONFIG_OF_GPIO=y |
| 509 | CONFIG_OF_MDIO=y | ||
| 488 | # CONFIG_PARPORT is not set | 510 | # CONFIG_PARPORT is not set |
| 489 | CONFIG_BLK_DEV=y | 511 | CONFIG_BLK_DEV=y |
| 490 | # CONFIG_BLK_DEV_FD is not set | 512 | # CONFIG_BLK_DEV_FD is not set |
| @@ -520,13 +542,17 @@ CONFIG_HAVE_IDE=y | |||
| 520 | # | 542 | # |
| 521 | 543 | ||
| 522 | # | 544 | # |
| 523 | # A new alternative FireWire stack is available with EXPERIMENTAL=y | 545 | # You can enable one or both FireWire driver stacks. |
| 524 | # | 546 | # |
| 547 | |||
| 548 | # | ||
| 549 | # See the help texts for more information. | ||
| 550 | # | ||
| 551 | # CONFIG_FIREWIRE is not set | ||
| 525 | # CONFIG_IEEE1394 is not set | 552 | # CONFIG_IEEE1394 is not set |
| 526 | # CONFIG_I2O is not set | 553 | # CONFIG_I2O is not set |
| 527 | # CONFIG_MACINTOSH_DRIVERS is not set | 554 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 528 | CONFIG_NETDEVICES=y | 555 | CONFIG_NETDEVICES=y |
| 529 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 530 | # CONFIG_DUMMY is not set | 556 | # CONFIG_DUMMY is not set |
| 531 | # CONFIG_BONDING is not set | 557 | # CONFIG_BONDING is not set |
| 532 | # CONFIG_EQUALIZER is not set | 558 | # CONFIG_EQUALIZER is not set |
| @@ -573,6 +599,7 @@ CONFIG_MII=y | |||
| 573 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 599 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 574 | # CONFIG_NET_PCI is not set | 600 | # CONFIG_NET_PCI is not set |
| 575 | # CONFIG_B44 is not set | 601 | # CONFIG_B44 is not set |
| 602 | # CONFIG_KS8842 is not set | ||
| 576 | # CONFIG_ATL2 is not set | 603 | # CONFIG_ATL2 is not set |
| 577 | CONFIG_FS_ENET=y | 604 | CONFIG_FS_ENET=y |
| 578 | # CONFIG_FS_ENET_HAS_SCC is not set | 605 | # CONFIG_FS_ENET_HAS_SCC is not set |
| @@ -594,8 +621,10 @@ CONFIG_NETDEV_1000=y | |||
| 594 | # CONFIG_VIA_VELOCITY is not set | 621 | # CONFIG_VIA_VELOCITY is not set |
| 595 | # CONFIG_TIGON3 is not set | 622 | # CONFIG_TIGON3 is not set |
| 596 | # CONFIG_BNX2 is not set | 623 | # CONFIG_BNX2 is not set |
| 624 | # CONFIG_CNIC is not set | ||
| 597 | # CONFIG_FSL_PQ_MDIO is not set | 625 | # CONFIG_FSL_PQ_MDIO is not set |
| 598 | # CONFIG_GIANFAR is not set | 626 | # CONFIG_GIANFAR is not set |
| 627 | # CONFIG_MV643XX_ETH is not set | ||
| 599 | # CONFIG_QLA3XXX is not set | 628 | # CONFIG_QLA3XXX is not set |
| 600 | # CONFIG_ATL1 is not set | 629 | # CONFIG_ATL1 is not set |
| 601 | # CONFIG_JME is not set | 630 | # CONFIG_JME is not set |
| @@ -685,6 +714,10 @@ CONFIG_HW_RANDOM=y | |||
| 685 | CONFIG_DEVPORT=y | 714 | CONFIG_DEVPORT=y |
| 686 | # CONFIG_I2C is not set | 715 | # CONFIG_I2C is not set |
| 687 | # CONFIG_SPI is not set | 716 | # CONFIG_SPI is not set |
| 717 | |||
| 718 | # | ||
| 719 | # PPS support | ||
| 720 | # | ||
| 688 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 721 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 689 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 722 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 690 | CONFIG_GPIOLIB=y | 723 | CONFIG_GPIOLIB=y |
| @@ -728,22 +761,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 728 | # CONFIG_HTC_PASIC3 is not set | 761 | # CONFIG_HTC_PASIC3 is not set |
| 729 | # CONFIG_MFD_TMIO is not set | 762 | # CONFIG_MFD_TMIO is not set |
| 730 | # CONFIG_REGULATOR is not set | 763 | # CONFIG_REGULATOR is not set |
| 731 | 764 | # CONFIG_MEDIA_SUPPORT is not set | |
| 732 | # | ||
| 733 | # Multimedia devices | ||
| 734 | # | ||
| 735 | |||
| 736 | # | ||
| 737 | # Multimedia core support | ||
| 738 | # | ||
| 739 | # CONFIG_VIDEO_DEV is not set | ||
| 740 | # CONFIG_DVB_CORE is not set | ||
| 741 | # CONFIG_VIDEO_MEDIA is not set | ||
| 742 | |||
| 743 | # | ||
| 744 | # Multimedia drivers | ||
| 745 | # | ||
| 746 | CONFIG_DAB=y | ||
| 747 | 765 | ||
| 748 | # | 766 | # |
| 749 | # Graphics support | 767 | # Graphics support |
| @@ -771,6 +789,10 @@ CONFIG_DAB=y | |||
| 771 | # CONFIG_DMADEVICES is not set | 789 | # CONFIG_DMADEVICES is not set |
| 772 | # CONFIG_AUXDISPLAY is not set | 790 | # CONFIG_AUXDISPLAY is not set |
| 773 | # CONFIG_UIO is not set | 791 | # CONFIG_UIO is not set |
| 792 | |||
| 793 | # | ||
| 794 | # TI VLYNQ | ||
| 795 | # | ||
| 774 | # CONFIG_STAGING is not set | 796 | # CONFIG_STAGING is not set |
| 775 | 797 | ||
| 776 | # | 798 | # |
| @@ -787,9 +809,10 @@ CONFIG_JBD=y | |||
| 787 | # CONFIG_REISERFS_FS is not set | 809 | # CONFIG_REISERFS_FS is not set |
| 788 | # CONFIG_JFS_FS is not set | 810 | # CONFIG_JFS_FS is not set |
| 789 | # CONFIG_FS_POSIX_ACL is not set | 811 | # CONFIG_FS_POSIX_ACL is not set |
| 790 | CONFIG_FILE_LOCKING=y | ||
| 791 | # CONFIG_XFS_FS is not set | 812 | # CONFIG_XFS_FS is not set |
| 792 | # CONFIG_OCFS2_FS is not set | 813 | # CONFIG_OCFS2_FS is not set |
| 814 | CONFIG_FILE_LOCKING=y | ||
| 815 | CONFIG_FSNOTIFY=y | ||
| 793 | CONFIG_DNOTIFY=y | 816 | CONFIG_DNOTIFY=y |
| 794 | CONFIG_INOTIFY=y | 817 | CONFIG_INOTIFY=y |
| 795 | CONFIG_INOTIFY_USER=y | 818 | CONFIG_INOTIFY_USER=y |
| @@ -935,6 +958,7 @@ CONFIG_HAS_IOPORT=y | |||
| 935 | CONFIG_HAS_DMA=y | 958 | CONFIG_HAS_DMA=y |
| 936 | CONFIG_HAVE_LMB=y | 959 | CONFIG_HAVE_LMB=y |
| 937 | CONFIG_NLATTR=y | 960 | CONFIG_NLATTR=y |
| 961 | CONFIG_GENERIC_ATOMIC64=y | ||
| 938 | 962 | ||
| 939 | # | 963 | # |
| 940 | # Kernel hacking | 964 | # Kernel hacking |
| @@ -960,6 +984,9 @@ CONFIG_DEBUG_KERNEL=y | |||
| 960 | # CONFIG_RT_MUTEX_TESTER is not set | 984 | # CONFIG_RT_MUTEX_TESTER is not set |
| 961 | # CONFIG_DEBUG_SPINLOCK is not set | 985 | # CONFIG_DEBUG_SPINLOCK is not set |
| 962 | # CONFIG_DEBUG_MUTEXES is not set | 986 | # CONFIG_DEBUG_MUTEXES is not set |
| 987 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 988 | # CONFIG_PROVE_LOCKING is not set | ||
| 989 | # CONFIG_LOCK_STAT is not set | ||
| 963 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 990 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 964 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 991 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 965 | # CONFIG_DEBUG_KOBJECT is not set | 992 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -971,7 +998,6 @@ CONFIG_DEBUG_INFO=y | |||
| 971 | # CONFIG_DEBUG_LIST is not set | 998 | # CONFIG_DEBUG_LIST is not set |
| 972 | # CONFIG_DEBUG_SG is not set | 999 | # CONFIG_DEBUG_SG is not set |
| 973 | # CONFIG_DEBUG_NOTIFIERS is not set | 1000 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 974 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 975 | # CONFIG_RCU_TORTURE_TEST is not set | 1001 | # CONFIG_RCU_TORTURE_TEST is not set |
| 976 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1002 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 977 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1003 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -985,22 +1011,23 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 985 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1011 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 986 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1012 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 987 | CONFIG_TRACING_SUPPORT=y | 1013 | CONFIG_TRACING_SUPPORT=y |
| 988 | 1014 | CONFIG_FTRACE=y | |
| 989 | # | ||
| 990 | # Tracers | ||
| 991 | # | ||
| 992 | # CONFIG_FUNCTION_TRACER is not set | 1015 | # CONFIG_FUNCTION_TRACER is not set |
| 1016 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 993 | # CONFIG_SCHED_TRACER is not set | 1017 | # CONFIG_SCHED_TRACER is not set |
| 994 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1018 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 995 | # CONFIG_EVENT_TRACER is not set | ||
| 996 | # CONFIG_BOOT_TRACER is not set | 1019 | # CONFIG_BOOT_TRACER is not set |
| 997 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1020 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1021 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1022 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 998 | # CONFIG_STACK_TRACER is not set | 1023 | # CONFIG_STACK_TRACER is not set |
| 999 | # CONFIG_KMEMTRACE is not set | 1024 | # CONFIG_KMEMTRACE is not set |
| 1000 | # CONFIG_WORKQUEUE_TRACER is not set | 1025 | # CONFIG_WORKQUEUE_TRACER is not set |
| 1001 | # CONFIG_BLK_DEV_IO_TRACE is not set | 1026 | # CONFIG_BLK_DEV_IO_TRACE is not set |
| 1002 | # CONFIG_SAMPLES is not set | 1027 | # CONFIG_SAMPLES is not set |
| 1003 | CONFIG_HAVE_ARCH_KGDB=y | 1028 | CONFIG_HAVE_ARCH_KGDB=y |
| 1029 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1030 | CONFIG_PPC_WERROR=y | ||
| 1004 | CONFIG_PRINT_STACK_DEPTH=64 | 1031 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1005 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1032 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1006 | # CONFIG_DEBUG_STACK_USAGE is not set | 1033 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/ep88xc_defconfig b/arch/powerpc/configs/ep88xc_defconfig index c2a439595f4d..2c292e25cc01 100644 --- a/arch/powerpc/configs/ep88xc_defconfig +++ b/arch/powerpc/configs/ep88xc_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:21:53 2009 | 4 | # Wed Jul 29 23:31:49 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | CONFIG_PPC_8xx=y | 13 | CONFIG_PPC_8xx=y |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -27,15 +27,16 @@ CONFIG_GENERIC_TIME=y | |||
| 27 | CONFIG_GENERIC_TIME_VSYSCALL=y | 27 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 28 | CONFIG_GENERIC_CLOCKEVENTS=y | 28 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 29 | CONFIG_GENERIC_HARDIRQS=y | 29 | CONFIG_GENERIC_HARDIRQS=y |
| 30 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 30 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 31 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 31 | CONFIG_IRQ_PER_CPU=y | 32 | CONFIG_IRQ_PER_CPU=y |
| 32 | CONFIG_STACKTRACE_SUPPORT=y | 33 | CONFIG_STACKTRACE_SUPPORT=y |
| 33 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 34 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 35 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 34 | CONFIG_LOCKDEP_SUPPORT=y | 36 | CONFIG_LOCKDEP_SUPPORT=y |
| 35 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 37 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 36 | CONFIG_ARCH_HAS_ILOG2_U32=y | 38 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 37 | CONFIG_GENERIC_HWEIGHT=y | 39 | CONFIG_GENERIC_HWEIGHT=y |
| 38 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 39 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 40 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 40 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 41 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 41 | CONFIG_PPC=y | 42 | CONFIG_PPC=y |
| @@ -49,11 +50,13 @@ CONFIG_OF=y | |||
| 49 | # CONFIG_GENERIC_TBSYNC is not set | 50 | # CONFIG_GENERIC_TBSYNC is not set |
| 50 | CONFIG_AUDIT_ARCH=y | 51 | CONFIG_AUDIT_ARCH=y |
| 51 | CONFIG_GENERIC_BUG=y | 52 | CONFIG_GENERIC_BUG=y |
| 53 | CONFIG_DTC=y | ||
| 52 | # CONFIG_DEFAULT_UIMAGE is not set | 54 | # CONFIG_DEFAULT_UIMAGE is not set |
| 53 | # CONFIG_PPC_DCR_NATIVE is not set | 55 | # CONFIG_PPC_DCR_NATIVE is not set |
| 54 | # CONFIG_PPC_DCR_MMIO is not set | 56 | # CONFIG_PPC_DCR_MMIO is not set |
| 55 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 57 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 56 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 58 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 59 | CONFIG_CONSTRUCTORS=y | ||
| 57 | 60 | ||
| 58 | # | 61 | # |
| 59 | # General setup | 62 | # General setup |
| @@ -100,7 +103,6 @@ CONFIG_EMBEDDED=y | |||
| 100 | CONFIG_KALLSYMS=y | 103 | CONFIG_KALLSYMS=y |
| 101 | # CONFIG_KALLSYMS_ALL is not set | 104 | # CONFIG_KALLSYMS_ALL is not set |
| 102 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 105 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 103 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 104 | CONFIG_HOTPLUG=y | 106 | CONFIG_HOTPLUG=y |
| 105 | CONFIG_PRINTK=y | 107 | CONFIG_PRINTK=y |
| 106 | CONFIG_BUG=y | 108 | CONFIG_BUG=y |
| @@ -113,8 +115,15 @@ CONFIG_TIMERFD=y | |||
| 113 | CONFIG_EVENTFD=y | 115 | CONFIG_EVENTFD=y |
| 114 | CONFIG_SHMEM=y | 116 | CONFIG_SHMEM=y |
| 115 | CONFIG_AIO=y | 117 | CONFIG_AIO=y |
| 118 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 119 | |||
| 120 | # | ||
| 121 | # Performance Counters | ||
| 122 | # | ||
| 123 | # CONFIG_PERF_COUNTERS is not set | ||
| 116 | # CONFIG_VM_EVENT_COUNTERS is not set | 124 | # CONFIG_VM_EVENT_COUNTERS is not set |
| 117 | CONFIG_SLUB_DEBUG=y | 125 | CONFIG_SLUB_DEBUG=y |
| 126 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 118 | CONFIG_COMPAT_BRK=y | 127 | CONFIG_COMPAT_BRK=y |
| 119 | # CONFIG_SLAB is not set | 128 | # CONFIG_SLAB is not set |
| 120 | CONFIG_SLUB=y | 129 | CONFIG_SLUB=y |
| @@ -128,13 +137,17 @@ CONFIG_HAVE_KPROBES=y | |||
| 128 | CONFIG_HAVE_KRETPROBES=y | 137 | CONFIG_HAVE_KRETPROBES=y |
| 129 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 138 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 130 | CONFIG_HAVE_CLK=y | 139 | CONFIG_HAVE_CLK=y |
| 140 | |||
| 141 | # | ||
| 142 | # GCOV-based kernel profiling | ||
| 143 | # | ||
| 131 | # CONFIG_SLOW_WORK is not set | 144 | # CONFIG_SLOW_WORK is not set |
| 132 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 145 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 133 | CONFIG_SLABINFO=y | 146 | CONFIG_SLABINFO=y |
| 134 | CONFIG_BASE_SMALL=1 | 147 | CONFIG_BASE_SMALL=1 |
| 135 | # CONFIG_MODULES is not set | 148 | # CONFIG_MODULES is not set |
| 136 | CONFIG_BLOCK=y | 149 | CONFIG_BLOCK=y |
| 137 | # CONFIG_LBD is not set | 150 | CONFIG_LBDAF=y |
| 138 | # CONFIG_BLK_DEV_BSG is not set | 151 | # CONFIG_BLK_DEV_BSG is not set |
| 139 | # CONFIG_BLK_DEV_INTEGRITY is not set | 152 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 140 | 153 | ||
| @@ -220,6 +233,7 @@ CONFIG_BINFMT_ELF=y | |||
| 220 | # CONFIG_MATH_EMULATION is not set | 233 | # CONFIG_MATH_EMULATION is not set |
| 221 | CONFIG_8XX_MINIMAL_FPEMU=y | 234 | CONFIG_8XX_MINIMAL_FPEMU=y |
| 222 | # CONFIG_IOMMU_HELPER is not set | 235 | # CONFIG_IOMMU_HELPER is not set |
| 236 | # CONFIG_SWIOTLB is not set | ||
| 223 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y | 237 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y |
| 224 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 238 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 225 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 239 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| @@ -239,9 +253,9 @@ CONFIG_MIGRATION=y | |||
| 239 | CONFIG_ZONE_DMA_FLAG=1 | 253 | CONFIG_ZONE_DMA_FLAG=1 |
| 240 | CONFIG_BOUNCE=y | 254 | CONFIG_BOUNCE=y |
| 241 | CONFIG_VIRT_TO_BUS=y | 255 | CONFIG_VIRT_TO_BUS=y |
| 242 | CONFIG_UNEVICTABLE_LRU=y | ||
| 243 | CONFIG_HAVE_MLOCK=y | 256 | CONFIG_HAVE_MLOCK=y |
| 244 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 257 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 258 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 245 | CONFIG_PPC_4K_PAGES=y | 259 | CONFIG_PPC_4K_PAGES=y |
| 246 | # CONFIG_PPC_16K_PAGES is not set | 260 | # CONFIG_PPC_16K_PAGES is not set |
| 247 | # CONFIG_PPC_64K_PAGES is not set | 261 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -280,6 +294,7 @@ CONFIG_PAGE_OFFSET=0xc0000000 | |||
| 280 | CONFIG_KERNEL_START=0xc0000000 | 294 | CONFIG_KERNEL_START=0xc0000000 |
| 281 | CONFIG_PHYSICAL_START=0x00000000 | 295 | CONFIG_PHYSICAL_START=0x00000000 |
| 282 | CONFIG_TASK_SIZE=0x80000000 | 296 | CONFIG_TASK_SIZE=0x80000000 |
| 297 | CONFIG_CONSISTENT_SIZE=0x00200000 | ||
| 283 | CONFIG_NET=y | 298 | CONFIG_NET=y |
| 284 | 299 | ||
| 285 | # | 300 | # |
| @@ -336,6 +351,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 336 | # CONFIG_ECONET is not set | 351 | # CONFIG_ECONET is not set |
| 337 | # CONFIG_WAN_ROUTER is not set | 352 | # CONFIG_WAN_ROUTER is not set |
| 338 | # CONFIG_PHONET is not set | 353 | # CONFIG_PHONET is not set |
| 354 | # CONFIG_IEEE802154 is not set | ||
| 339 | # CONFIG_NET_SCHED is not set | 355 | # CONFIG_NET_SCHED is not set |
| 340 | # CONFIG_DCB is not set | 356 | # CONFIG_DCB is not set |
| 341 | 357 | ||
| @@ -353,7 +369,11 @@ CONFIG_WIRELESS=y | |||
| 353 | CONFIG_WIRELESS_OLD_REGULATORY=y | 369 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 354 | # CONFIG_WIRELESS_EXT is not set | 370 | # CONFIG_WIRELESS_EXT is not set |
| 355 | # CONFIG_LIB80211 is not set | 371 | # CONFIG_LIB80211 is not set |
| 356 | # CONFIG_MAC80211 is not set | 372 | |
| 373 | # | ||
| 374 | # CFG80211 needs to be enabled for MAC80211 | ||
| 375 | # | ||
| 376 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 357 | # CONFIG_WIMAX is not set | 377 | # CONFIG_WIMAX is not set |
| 358 | # CONFIG_RFKILL is not set | 378 | # CONFIG_RFKILL is not set |
| 359 | # CONFIG_NET_9P is not set | 379 | # CONFIG_NET_9P is not set |
| @@ -452,6 +472,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 452 | # | 472 | # |
| 453 | # CONFIG_MTD_UBI is not set | 473 | # CONFIG_MTD_UBI is not set |
| 454 | CONFIG_OF_DEVICE=y | 474 | CONFIG_OF_DEVICE=y |
| 475 | CONFIG_OF_MDIO=y | ||
| 455 | # CONFIG_PARPORT is not set | 476 | # CONFIG_PARPORT is not set |
| 456 | # CONFIG_BLK_DEV is not set | 477 | # CONFIG_BLK_DEV is not set |
| 457 | # CONFIG_MISC_DEVICES is not set | 478 | # CONFIG_MISC_DEVICES is not set |
| @@ -469,7 +490,6 @@ CONFIG_HAVE_IDE=y | |||
| 469 | # CONFIG_MD is not set | 490 | # CONFIG_MD is not set |
| 470 | # CONFIG_MACINTOSH_DRIVERS is not set | 491 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 471 | CONFIG_NETDEVICES=y | 492 | CONFIG_NETDEVICES=y |
| 472 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 473 | # CONFIG_DUMMY is not set | 493 | # CONFIG_DUMMY is not set |
| 474 | # CONFIG_BONDING is not set | 494 | # CONFIG_BONDING is not set |
| 475 | # CONFIG_MACVLAN is not set | 495 | # CONFIG_MACVLAN is not set |
| @@ -508,6 +528,7 @@ CONFIG_MII=y | |||
| 508 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 528 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 509 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 529 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 510 | # CONFIG_B44 is not set | 530 | # CONFIG_B44 is not set |
| 531 | # CONFIG_KS8842 is not set | ||
| 511 | CONFIG_FS_ENET=y | 532 | CONFIG_FS_ENET=y |
| 512 | # CONFIG_FS_ENET_HAS_SCC is not set | 533 | # CONFIG_FS_ENET_HAS_SCC is not set |
| 513 | CONFIG_FS_ENET_HAS_FEC=y | 534 | CONFIG_FS_ENET_HAS_FEC=y |
| @@ -579,6 +600,11 @@ CONFIG_GEN_RTC=y | |||
| 579 | # CONFIG_TCG_TPM is not set | 600 | # CONFIG_TCG_TPM is not set |
| 580 | # CONFIG_I2C is not set | 601 | # CONFIG_I2C is not set |
| 581 | # CONFIG_SPI is not set | 602 | # CONFIG_SPI is not set |
| 603 | |||
| 604 | # | ||
| 605 | # PPS support | ||
| 606 | # | ||
| 607 | # CONFIG_PPS is not set | ||
| 582 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 608 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 583 | # CONFIG_GPIOLIB is not set | 609 | # CONFIG_GPIOLIB is not set |
| 584 | # CONFIG_W1 is not set | 610 | # CONFIG_W1 is not set |
| @@ -602,22 +628,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 602 | # CONFIG_HTC_PASIC3 is not set | 628 | # CONFIG_HTC_PASIC3 is not set |
| 603 | # CONFIG_MFD_TMIO is not set | 629 | # CONFIG_MFD_TMIO is not set |
| 604 | # CONFIG_REGULATOR is not set | 630 | # CONFIG_REGULATOR is not set |
| 605 | 631 | # CONFIG_MEDIA_SUPPORT is not set | |
| 606 | # | ||
| 607 | # Multimedia devices | ||
| 608 | # | ||
| 609 | |||
| 610 | # | ||
| 611 | # Multimedia core support | ||
| 612 | # | ||
| 613 | # CONFIG_VIDEO_DEV is not set | ||
| 614 | # CONFIG_DVB_CORE is not set | ||
| 615 | # CONFIG_VIDEO_MEDIA is not set | ||
| 616 | |||
| 617 | # | ||
| 618 | # Multimedia drivers | ||
| 619 | # | ||
| 620 | CONFIG_DAB=y | ||
| 621 | 632 | ||
| 622 | # | 633 | # |
| 623 | # Graphics support | 634 | # Graphics support |
| @@ -642,6 +653,10 @@ CONFIG_DAB=y | |||
| 642 | # CONFIG_DMADEVICES is not set | 653 | # CONFIG_DMADEVICES is not set |
| 643 | # CONFIG_AUXDISPLAY is not set | 654 | # CONFIG_AUXDISPLAY is not set |
| 644 | # CONFIG_UIO is not set | 655 | # CONFIG_UIO is not set |
| 656 | |||
| 657 | # | ||
| 658 | # TI VLYNQ | ||
| 659 | # | ||
| 645 | # CONFIG_STAGING is not set | 660 | # CONFIG_STAGING is not set |
| 646 | 661 | ||
| 647 | # | 662 | # |
| @@ -653,12 +668,15 @@ CONFIG_DAB=y | |||
| 653 | # CONFIG_REISERFS_FS is not set | 668 | # CONFIG_REISERFS_FS is not set |
| 654 | # CONFIG_JFS_FS is not set | 669 | # CONFIG_JFS_FS is not set |
| 655 | # CONFIG_FS_POSIX_ACL is not set | 670 | # CONFIG_FS_POSIX_ACL is not set |
| 656 | CONFIG_FILE_LOCKING=y | ||
| 657 | # CONFIG_XFS_FS is not set | 671 | # CONFIG_XFS_FS is not set |
| 672 | # CONFIG_GFS2_FS is not set | ||
| 658 | # CONFIG_OCFS2_FS is not set | 673 | # CONFIG_OCFS2_FS is not set |
| 659 | # CONFIG_BTRFS_FS is not set | 674 | # CONFIG_BTRFS_FS is not set |
| 675 | CONFIG_FILE_LOCKING=y | ||
| 676 | CONFIG_FSNOTIFY=y | ||
| 660 | # CONFIG_DNOTIFY is not set | 677 | # CONFIG_DNOTIFY is not set |
| 661 | # CONFIG_INOTIFY is not set | 678 | # CONFIG_INOTIFY is not set |
| 679 | CONFIG_INOTIFY_USER=y | ||
| 662 | # CONFIG_QUOTA is not set | 680 | # CONFIG_QUOTA is not set |
| 663 | # CONFIG_AUTOFS_FS is not set | 681 | # CONFIG_AUTOFS_FS is not set |
| 664 | # CONFIG_AUTOFS4_FS is not set | 682 | # CONFIG_AUTOFS4_FS is not set |
| @@ -775,6 +793,7 @@ CONFIG_HAS_IOPORT=y | |||
| 775 | CONFIG_HAS_DMA=y | 793 | CONFIG_HAS_DMA=y |
| 776 | CONFIG_HAVE_LMB=y | 794 | CONFIG_HAVE_LMB=y |
| 777 | CONFIG_NLATTR=y | 795 | CONFIG_NLATTR=y |
| 796 | CONFIG_GENERIC_ATOMIC64=y | ||
| 778 | 797 | ||
| 779 | # | 798 | # |
| 780 | # Kernel hacking | 799 | # Kernel hacking |
| @@ -803,6 +822,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 803 | # CONFIG_SLUB_STATS is not set | 822 | # CONFIG_SLUB_STATS is not set |
| 804 | # CONFIG_DEBUG_SPINLOCK is not set | 823 | # CONFIG_DEBUG_SPINLOCK is not set |
| 805 | # CONFIG_DEBUG_MUTEXES is not set | 824 | # CONFIG_DEBUG_MUTEXES is not set |
| 825 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 826 | # CONFIG_PROVE_LOCKING is not set | ||
| 827 | # CONFIG_LOCK_STAT is not set | ||
| 806 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 828 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 807 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 829 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 808 | # CONFIG_DEBUG_KOBJECT is not set | 830 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -814,7 +836,6 @@ CONFIG_DEBUG_INFO=y | |||
| 814 | # CONFIG_DEBUG_LIST is not set | 836 | # CONFIG_DEBUG_LIST is not set |
| 815 | # CONFIG_DEBUG_SG is not set | 837 | # CONFIG_DEBUG_SG is not set |
| 816 | # CONFIG_DEBUG_NOTIFIERS is not set | 838 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 817 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 818 | # CONFIG_RCU_TORTURE_TEST is not set | 839 | # CONFIG_RCU_TORTURE_TEST is not set |
| 819 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 840 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 820 | # CONFIG_BACKTRACE_SELF_TEST is not set | 841 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -827,16 +848,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 827 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 848 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 828 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 849 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 829 | CONFIG_TRACING_SUPPORT=y | 850 | CONFIG_TRACING_SUPPORT=y |
| 830 | 851 | CONFIG_FTRACE=y | |
| 831 | # | ||
| 832 | # Tracers | ||
| 833 | # | ||
| 834 | # CONFIG_FUNCTION_TRACER is not set | 852 | # CONFIG_FUNCTION_TRACER is not set |
| 853 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 835 | # CONFIG_SCHED_TRACER is not set | 854 | # CONFIG_SCHED_TRACER is not set |
| 836 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 855 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 837 | # CONFIG_EVENT_TRACER is not set | ||
| 838 | # CONFIG_BOOT_TRACER is not set | 856 | # CONFIG_BOOT_TRACER is not set |
| 839 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 857 | CONFIG_BRANCH_PROFILE_NONE=y |
| 858 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 859 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 840 | # CONFIG_STACK_TRACER is not set | 860 | # CONFIG_STACK_TRACER is not set |
| 841 | # CONFIG_KMEMTRACE is not set | 861 | # CONFIG_KMEMTRACE is not set |
| 842 | # CONFIG_WORKQUEUE_TRACER is not set | 862 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -844,6 +864,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 844 | # CONFIG_SAMPLES is not set | 864 | # CONFIG_SAMPLES is not set |
| 845 | CONFIG_HAVE_ARCH_KGDB=y | 865 | CONFIG_HAVE_ARCH_KGDB=y |
| 846 | # CONFIG_KGDB is not set | 866 | # CONFIG_KGDB is not set |
| 867 | # CONFIG_KMEMCHECK is not set | ||
| 868 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 869 | CONFIG_PPC_WERROR=y | ||
| 847 | CONFIG_PRINT_STACK_DEPTH=64 | 870 | CONFIG_PRINT_STACK_DEPTH=64 |
| 848 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 871 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 849 | # CONFIG_DEBUG_STACK_USAGE is not set | 872 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/linkstation_defconfig b/arch/powerpc/configs/linkstation_defconfig index a4053ab9e244..45671e7dd2c7 100644 --- a/arch/powerpc/configs/linkstation_defconfig +++ b/arch/powerpc/configs/linkstation_defconfig | |||
| @@ -1,25 +1,27 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:21:54 2009 | 4 | # Wed Jul 29 23:31:50 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_ALTIVEC is not set | 20 | # CONFIG_ALTIVEC is not set |
| 20 | CONFIG_PPC_STD_MMU=y | 21 | CONFIG_PPC_STD_MMU=y |
| 21 | CONFIG_PPC_STD_MMU_32=y | 22 | CONFIG_PPC_STD_MMU_32=y |
| 22 | # CONFIG_PPC_MM_SLICES is not set | 23 | # CONFIG_PPC_MM_SLICES is not set |
| 24 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 23 | # CONFIG_SMP is not set | 25 | # CONFIG_SMP is not set |
| 24 | CONFIG_PPC32=y | 26 | CONFIG_PPC32=y |
| 25 | CONFIG_WORD_SIZE=32 | 27 | CONFIG_WORD_SIZE=32 |
| @@ -30,15 +32,16 @@ CONFIG_GENERIC_TIME=y | |||
| 30 | CONFIG_GENERIC_TIME_VSYSCALL=y | 32 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 31 | CONFIG_GENERIC_CLOCKEVENTS=y | 33 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 32 | CONFIG_GENERIC_HARDIRQS=y | 34 | CONFIG_GENERIC_HARDIRQS=y |
| 35 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 33 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 36 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 34 | CONFIG_IRQ_PER_CPU=y | 37 | CONFIG_IRQ_PER_CPU=y |
| 35 | CONFIG_STACKTRACE_SUPPORT=y | 38 | CONFIG_STACKTRACE_SUPPORT=y |
| 36 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 39 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 40 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 37 | CONFIG_LOCKDEP_SUPPORT=y | 41 | CONFIG_LOCKDEP_SUPPORT=y |
| 38 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 39 | CONFIG_ARCH_HAS_ILOG2_U32=y | 43 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 40 | CONFIG_GENERIC_HWEIGHT=y | 44 | CONFIG_GENERIC_HWEIGHT=y |
| 41 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 42 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 45 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 43 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 46 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 44 | CONFIG_PPC=y | 47 | CONFIG_PPC=y |
| @@ -52,11 +55,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 52 | # CONFIG_GENERIC_TBSYNC is not set | 55 | # CONFIG_GENERIC_TBSYNC is not set |
| 53 | CONFIG_AUDIT_ARCH=y | 56 | CONFIG_AUDIT_ARCH=y |
| 54 | CONFIG_GENERIC_BUG=y | 57 | CONFIG_GENERIC_BUG=y |
| 58 | CONFIG_DTC=y | ||
| 55 | CONFIG_DEFAULT_UIMAGE=y | 59 | CONFIG_DEFAULT_UIMAGE=y |
| 56 | # CONFIG_PPC_DCR_NATIVE is not set | 60 | # CONFIG_PPC_DCR_NATIVE is not set |
| 57 | # CONFIG_PPC_DCR_MMIO is not set | 61 | # CONFIG_PPC_DCR_MMIO is not set |
| 58 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 62 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 59 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 63 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 64 | CONFIG_CONSTRUCTORS=y | ||
| 60 | 65 | ||
| 61 | # | 66 | # |
| 62 | # General setup | 67 | # General setup |
| @@ -114,7 +119,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 114 | CONFIG_KALLSYMS=y | 119 | CONFIG_KALLSYMS=y |
| 115 | # CONFIG_KALLSYMS_ALL is not set | 120 | # CONFIG_KALLSYMS_ALL is not set |
| 116 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 121 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 117 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 118 | CONFIG_HOTPLUG=y | 122 | CONFIG_HOTPLUG=y |
| 119 | CONFIG_PRINTK=y | 123 | CONFIG_PRINTK=y |
| 120 | CONFIG_BUG=y | 124 | CONFIG_BUG=y |
| @@ -127,9 +131,16 @@ CONFIG_TIMERFD=y | |||
| 127 | CONFIG_EVENTFD=y | 131 | CONFIG_EVENTFD=y |
| 128 | CONFIG_SHMEM=y | 132 | CONFIG_SHMEM=y |
| 129 | CONFIG_AIO=y | 133 | CONFIG_AIO=y |
| 134 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 135 | |||
| 136 | # | ||
| 137 | # Performance Counters | ||
| 138 | # | ||
| 139 | # CONFIG_PERF_COUNTERS is not set | ||
| 130 | CONFIG_VM_EVENT_COUNTERS=y | 140 | CONFIG_VM_EVENT_COUNTERS=y |
| 131 | CONFIG_PCI_QUIRKS=y | 141 | CONFIG_PCI_QUIRKS=y |
| 132 | CONFIG_SLUB_DEBUG=y | 142 | CONFIG_SLUB_DEBUG=y |
| 143 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 133 | # CONFIG_COMPAT_BRK is not set | 144 | # CONFIG_COMPAT_BRK is not set |
| 134 | # CONFIG_SLAB is not set | 145 | # CONFIG_SLAB is not set |
| 135 | CONFIG_SLUB=y | 146 | CONFIG_SLUB=y |
| @@ -143,6 +154,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 143 | CONFIG_HAVE_KPROBES=y | 154 | CONFIG_HAVE_KPROBES=y |
| 144 | CONFIG_HAVE_KRETPROBES=y | 155 | CONFIG_HAVE_KRETPROBES=y |
| 145 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 156 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 157 | |||
| 158 | # | ||
| 159 | # GCOV-based kernel profiling | ||
| 160 | # | ||
| 146 | # CONFIG_SLOW_WORK is not set | 161 | # CONFIG_SLOW_WORK is not set |
| 147 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 162 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 148 | CONFIG_SLABINFO=y | 163 | CONFIG_SLABINFO=y |
| @@ -155,7 +170,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 155 | # CONFIG_MODVERSIONS is not set | 170 | # CONFIG_MODVERSIONS is not set |
| 156 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 171 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 157 | CONFIG_BLOCK=y | 172 | CONFIG_BLOCK=y |
| 158 | # CONFIG_LBD is not set | 173 | CONFIG_LBDAF=y |
| 159 | # CONFIG_BLK_DEV_BSG is not set | 174 | # CONFIG_BLK_DEV_BSG is not set |
| 160 | # CONFIG_BLK_DEV_INTEGRITY is not set | 175 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 161 | 176 | ||
| @@ -237,6 +252,7 @@ CONFIG_BINFMT_ELF=y | |||
| 237 | # CONFIG_HAVE_AOUT is not set | 252 | # CONFIG_HAVE_AOUT is not set |
| 238 | # CONFIG_BINFMT_MISC is not set | 253 | # CONFIG_BINFMT_MISC is not set |
| 239 | # CONFIG_IOMMU_HELPER is not set | 254 | # CONFIG_IOMMU_HELPER is not set |
| 255 | # CONFIG_SWIOTLB is not set | ||
| 240 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 256 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 241 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 257 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 242 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 258 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -257,9 +273,9 @@ CONFIG_MIGRATION=y | |||
| 257 | CONFIG_ZONE_DMA_FLAG=1 | 273 | CONFIG_ZONE_DMA_FLAG=1 |
| 258 | CONFIG_BOUNCE=y | 274 | CONFIG_BOUNCE=y |
| 259 | CONFIG_VIRT_TO_BUS=y | 275 | CONFIG_VIRT_TO_BUS=y |
| 260 | CONFIG_UNEVICTABLE_LRU=y | ||
| 261 | CONFIG_HAVE_MLOCK=y | 276 | CONFIG_HAVE_MLOCK=y |
| 262 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 277 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 278 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 263 | CONFIG_PPC_4K_PAGES=y | 279 | CONFIG_PPC_4K_PAGES=y |
| 264 | # CONFIG_PPC_16K_PAGES is not set | 280 | # CONFIG_PPC_16K_PAGES is not set |
| 265 | # CONFIG_PPC_64K_PAGES is not set | 281 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -480,6 +496,7 @@ CONFIG_IP_NF_ARP_MANGLE=m | |||
| 480 | # CONFIG_ECONET is not set | 496 | # CONFIG_ECONET is not set |
| 481 | # CONFIG_WAN_ROUTER is not set | 497 | # CONFIG_WAN_ROUTER is not set |
| 482 | # CONFIG_PHONET is not set | 498 | # CONFIG_PHONET is not set |
| 499 | # CONFIG_IEEE802154 is not set | ||
| 483 | # CONFIG_NET_SCHED is not set | 500 | # CONFIG_NET_SCHED is not set |
| 484 | # CONFIG_DCB is not set | 501 | # CONFIG_DCB is not set |
| 485 | 502 | ||
| @@ -498,7 +515,11 @@ CONFIG_WIRELESS_OLD_REGULATORY=y | |||
| 498 | CONFIG_WIRELESS_EXT=y | 515 | CONFIG_WIRELESS_EXT=y |
| 499 | CONFIG_WIRELESS_EXT_SYSFS=y | 516 | CONFIG_WIRELESS_EXT_SYSFS=y |
| 500 | # CONFIG_LIB80211 is not set | 517 | # CONFIG_LIB80211 is not set |
| 501 | # CONFIG_MAC80211 is not set | 518 | |
| 519 | # | ||
| 520 | # CFG80211 needs to be enabled for MAC80211 | ||
| 521 | # | ||
| 522 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 502 | # CONFIG_WIMAX is not set | 523 | # CONFIG_WIMAX is not set |
| 503 | # CONFIG_RFKILL is not set | 524 | # CONFIG_RFKILL is not set |
| 504 | # CONFIG_NET_9P is not set | 525 | # CONFIG_NET_9P is not set |
| @@ -647,7 +668,9 @@ CONFIG_MISC_DEVICES=y | |||
| 647 | # | 668 | # |
| 648 | # CONFIG_EEPROM_AT24 is not set | 669 | # CONFIG_EEPROM_AT24 is not set |
| 649 | CONFIG_EEPROM_LEGACY=m | 670 | CONFIG_EEPROM_LEGACY=m |
| 671 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 650 | # CONFIG_EEPROM_93CX6 is not set | 672 | # CONFIG_EEPROM_93CX6 is not set |
| 673 | # CONFIG_CB710_CORE is not set | ||
| 651 | CONFIG_HAVE_IDE=y | 674 | CONFIG_HAVE_IDE=y |
| 652 | # CONFIG_IDE is not set | 675 | # CONFIG_IDE is not set |
| 653 | 676 | ||
| @@ -670,10 +693,6 @@ CONFIG_BLK_DEV_SD=y | |||
| 670 | # CONFIG_BLK_DEV_SR is not set | 693 | # CONFIG_BLK_DEV_SR is not set |
| 671 | CONFIG_CHR_DEV_SG=y | 694 | CONFIG_CHR_DEV_SG=y |
| 672 | # CONFIG_CHR_DEV_SCH is not set | 695 | # CONFIG_CHR_DEV_SCH is not set |
| 673 | |||
| 674 | # | ||
| 675 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 676 | # | ||
| 677 | CONFIG_SCSI_MULTI_LUN=y | 696 | CONFIG_SCSI_MULTI_LUN=y |
| 678 | # CONFIG_SCSI_CONSTANTS is not set | 697 | # CONFIG_SCSI_CONSTANTS is not set |
| 679 | # CONFIG_SCSI_LOGGING is not set | 698 | # CONFIG_SCSI_LOGGING is not set |
| @@ -691,6 +710,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 691 | CONFIG_SCSI_LOWLEVEL=y | 710 | CONFIG_SCSI_LOWLEVEL=y |
| 692 | # CONFIG_ISCSI_TCP is not set | 711 | # CONFIG_ISCSI_TCP is not set |
| 693 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 712 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 713 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 694 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 714 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 695 | # CONFIG_SCSI_3W_9XXX is not set | 715 | # CONFIG_SCSI_3W_9XXX is not set |
| 696 | # CONFIG_SCSI_ACARD is not set | 716 | # CONFIG_SCSI_ACARD is not set |
| @@ -699,6 +719,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 699 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 719 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 700 | # CONFIG_SCSI_AIC79XX is not set | 720 | # CONFIG_SCSI_AIC79XX is not set |
| 701 | # CONFIG_SCSI_AIC94XX is not set | 721 | # CONFIG_SCSI_AIC94XX is not set |
| 722 | # CONFIG_SCSI_MVSAS is not set | ||
| 702 | # CONFIG_SCSI_DPT_I2O is not set | 723 | # CONFIG_SCSI_DPT_I2O is not set |
| 703 | # CONFIG_SCSI_ADVANSYS is not set | 724 | # CONFIG_SCSI_ADVANSYS is not set |
| 704 | # CONFIG_SCSI_ARCMSR is not set | 725 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -718,7 +739,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 718 | # CONFIG_SCSI_IPS is not set | 739 | # CONFIG_SCSI_IPS is not set |
| 719 | # CONFIG_SCSI_INITIO is not set | 740 | # CONFIG_SCSI_INITIO is not set |
| 720 | # CONFIG_SCSI_INIA100 is not set | 741 | # CONFIG_SCSI_INIA100 is not set |
| 721 | # CONFIG_SCSI_MVSAS is not set | ||
| 722 | # CONFIG_SCSI_STEX is not set | 742 | # CONFIG_SCSI_STEX is not set |
| 723 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 743 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 724 | # CONFIG_SCSI_IPR is not set | 744 | # CONFIG_SCSI_IPR is not set |
| @@ -802,14 +822,17 @@ CONFIG_PATA_SIL680=y | |||
| 802 | # | 822 | # |
| 803 | 823 | ||
| 804 | # | 824 | # |
| 805 | # Enable only one of the two stacks, unless you know what you are doing | 825 | # You can enable one or both FireWire driver stacks. |
| 826 | # | ||
| 827 | |||
| 828 | # | ||
| 829 | # See the help texts for more information. | ||
| 806 | # | 830 | # |
| 807 | # CONFIG_FIREWIRE is not set | 831 | # CONFIG_FIREWIRE is not set |
| 808 | # CONFIG_IEEE1394 is not set | 832 | # CONFIG_IEEE1394 is not set |
| 809 | # CONFIG_I2O is not set | 833 | # CONFIG_I2O is not set |
| 810 | # CONFIG_MACINTOSH_DRIVERS is not set | 834 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 811 | CONFIG_NETDEVICES=y | 835 | CONFIG_NETDEVICES=y |
| 812 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 813 | # CONFIG_DUMMY is not set | 836 | # CONFIG_DUMMY is not set |
| 814 | # CONFIG_BONDING is not set | 837 | # CONFIG_BONDING is not set |
| 815 | # CONFIG_MACVLAN is not set | 838 | # CONFIG_MACVLAN is not set |
| @@ -846,6 +869,7 @@ CONFIG_TULIP_MMIO=y | |||
| 846 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 869 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 847 | # CONFIG_NET_PCI is not set | 870 | # CONFIG_NET_PCI is not set |
| 848 | # CONFIG_B44 is not set | 871 | # CONFIG_B44 is not set |
| 872 | # CONFIG_KS8842 is not set | ||
| 849 | # CONFIG_ATL2 is not set | 873 | # CONFIG_ATL2 is not set |
| 850 | CONFIG_NETDEV_1000=y | 874 | CONFIG_NETDEV_1000=y |
| 851 | # CONFIG_ACENIC is not set | 875 | # CONFIG_ACENIC is not set |
| @@ -865,8 +889,10 @@ CONFIG_R8169=y | |||
| 865 | # CONFIG_VIA_VELOCITY is not set | 889 | # CONFIG_VIA_VELOCITY is not set |
| 866 | # CONFIG_TIGON3 is not set | 890 | # CONFIG_TIGON3 is not set |
| 867 | # CONFIG_BNX2 is not set | 891 | # CONFIG_BNX2 is not set |
| 892 | # CONFIG_CNIC is not set | ||
| 868 | # CONFIG_FSL_PQ_MDIO is not set | 893 | # CONFIG_FSL_PQ_MDIO is not set |
| 869 | # CONFIG_GIANFAR is not set | 894 | # CONFIG_GIANFAR is not set |
| 895 | # CONFIG_MV643XX_ETH is not set | ||
| 870 | # CONFIG_QLA3XXX is not set | 896 | # CONFIG_QLA3XXX is not set |
| 871 | # CONFIG_ATL1 is not set | 897 | # CONFIG_ATL1 is not set |
| 872 | # CONFIG_ATL1E is not set | 898 | # CONFIG_ATL1E is not set |
| @@ -1074,13 +1100,17 @@ CONFIG_I2C_MPC=y | |||
| 1074 | # CONFIG_SENSORS_PCF8574 is not set | 1100 | # CONFIG_SENSORS_PCF8574 is not set |
| 1075 | # CONFIG_PCF8575 is not set | 1101 | # CONFIG_PCF8575 is not set |
| 1076 | # CONFIG_SENSORS_PCA9539 is not set | 1102 | # CONFIG_SENSORS_PCA9539 is not set |
| 1077 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 1078 | # CONFIG_SENSORS_TSL2550 is not set | 1103 | # CONFIG_SENSORS_TSL2550 is not set |
| 1079 | # CONFIG_I2C_DEBUG_CORE is not set | 1104 | # CONFIG_I2C_DEBUG_CORE is not set |
| 1080 | # CONFIG_I2C_DEBUG_ALGO is not set | 1105 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 1081 | # CONFIG_I2C_DEBUG_BUS is not set | 1106 | # CONFIG_I2C_DEBUG_BUS is not set |
| 1082 | # CONFIG_I2C_DEBUG_CHIP is not set | 1107 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 1083 | # CONFIG_SPI is not set | 1108 | # CONFIG_SPI is not set |
| 1109 | |||
| 1110 | # | ||
| 1111 | # PPS support | ||
| 1112 | # | ||
| 1113 | # CONFIG_PPS is not set | ||
| 1084 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 1114 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 1085 | # CONFIG_GPIOLIB is not set | 1115 | # CONFIG_GPIOLIB is not set |
| 1086 | # CONFIG_W1 is not set | 1116 | # CONFIG_W1 is not set |
| @@ -1135,6 +1165,7 @@ CONFIG_HWMON=y | |||
| 1135 | # CONFIG_SENSORS_SMSC47B397 is not set | 1165 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 1136 | # CONFIG_SENSORS_ADS7828 is not set | 1166 | # CONFIG_SENSORS_ADS7828 is not set |
| 1137 | # CONFIG_SENSORS_THMC50 is not set | 1167 | # CONFIG_SENSORS_THMC50 is not set |
| 1168 | # CONFIG_SENSORS_TMP401 is not set | ||
| 1138 | # CONFIG_SENSORS_VIA686A is not set | 1169 | # CONFIG_SENSORS_VIA686A is not set |
| 1139 | # CONFIG_SENSORS_VT1211 is not set | 1170 | # CONFIG_SENSORS_VT1211 is not set |
| 1140 | # CONFIG_SENSORS_VT8231 is not set | 1171 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -1169,23 +1200,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1169 | # CONFIG_MFD_WM8400 is not set | 1200 | # CONFIG_MFD_WM8400 is not set |
| 1170 | # CONFIG_MFD_WM8350_I2C is not set | 1201 | # CONFIG_MFD_WM8350_I2C is not set |
| 1171 | # CONFIG_MFD_PCF50633 is not set | 1202 | # CONFIG_MFD_PCF50633 is not set |
| 1203 | # CONFIG_AB3100_CORE is not set | ||
| 1172 | # CONFIG_REGULATOR is not set | 1204 | # CONFIG_REGULATOR is not set |
| 1173 | 1205 | # CONFIG_MEDIA_SUPPORT is not set | |
| 1174 | # | ||
| 1175 | # Multimedia devices | ||
| 1176 | # | ||
| 1177 | |||
| 1178 | # | ||
| 1179 | # Multimedia core support | ||
| 1180 | # | ||
| 1181 | # CONFIG_VIDEO_DEV is not set | ||
| 1182 | # CONFIG_DVB_CORE is not set | ||
| 1183 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1184 | |||
| 1185 | # | ||
| 1186 | # Multimedia drivers | ||
| 1187 | # | ||
| 1188 | # CONFIG_DAB is not set | ||
| 1189 | 1206 | ||
| 1190 | # | 1207 | # |
| 1191 | # Graphics support | 1208 | # Graphics support |
| @@ -1245,6 +1262,7 @@ CONFIG_USB_MON=y | |||
| 1245 | # USB Host Controller Drivers | 1262 | # USB Host Controller Drivers |
| 1246 | # | 1263 | # |
| 1247 | # CONFIG_USB_C67X00_HCD is not set | 1264 | # CONFIG_USB_C67X00_HCD is not set |
| 1265 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1248 | CONFIG_USB_EHCI_HCD=y | 1266 | CONFIG_USB_EHCI_HCD=y |
| 1249 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set | 1267 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set |
| 1250 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1268 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1254,9 +1272,9 @@ CONFIG_USB_EHCI_HCD_PPC_OF=y | |||
| 1254 | # CONFIG_USB_ISP116X_HCD is not set | 1272 | # CONFIG_USB_ISP116X_HCD is not set |
| 1255 | # CONFIG_USB_ISP1760_HCD is not set | 1273 | # CONFIG_USB_ISP1760_HCD is not set |
| 1256 | CONFIG_USB_OHCI_HCD=y | 1274 | CONFIG_USB_OHCI_HCD=y |
| 1257 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1258 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y | 1275 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y |
| 1259 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set | 1276 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set |
| 1277 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1260 | CONFIG_USB_OHCI_HCD_PCI=y | 1278 | CONFIG_USB_OHCI_HCD_PCI=y |
| 1261 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y | 1279 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y |
| 1262 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y | 1280 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y |
| @@ -1423,6 +1441,7 @@ CONFIG_RTC_DRV_RS5C372=y | |||
| 1423 | # CONFIG_RTC_DRV_S35390A is not set | 1441 | # CONFIG_RTC_DRV_S35390A is not set |
| 1424 | # CONFIG_RTC_DRV_FM3130 is not set | 1442 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1425 | # CONFIG_RTC_DRV_RX8581 is not set | 1443 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1444 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1426 | 1445 | ||
| 1427 | # | 1446 | # |
| 1428 | # SPI RTC drivers | 1447 | # SPI RTC drivers |
| @@ -1450,6 +1469,10 @@ CONFIG_RTC_DRV_RS5C372=y | |||
| 1450 | # CONFIG_DMADEVICES is not set | 1469 | # CONFIG_DMADEVICES is not set |
| 1451 | # CONFIG_AUXDISPLAY is not set | 1470 | # CONFIG_AUXDISPLAY is not set |
| 1452 | # CONFIG_UIO is not set | 1471 | # CONFIG_UIO is not set |
| 1472 | |||
| 1473 | # | ||
| 1474 | # TI VLYNQ | ||
| 1475 | # | ||
| 1453 | # CONFIG_STAGING is not set | 1476 | # CONFIG_STAGING is not set |
| 1454 | 1477 | ||
| 1455 | # | 1478 | # |
| @@ -1469,14 +1492,16 @@ CONFIG_FS_MBCACHE=y | |||
| 1469 | # CONFIG_REISERFS_FS is not set | 1492 | # CONFIG_REISERFS_FS is not set |
| 1470 | # CONFIG_JFS_FS is not set | 1493 | # CONFIG_JFS_FS is not set |
| 1471 | CONFIG_FS_POSIX_ACL=y | 1494 | CONFIG_FS_POSIX_ACL=y |
| 1472 | CONFIG_FILE_LOCKING=y | ||
| 1473 | CONFIG_XFS_FS=m | 1495 | CONFIG_XFS_FS=m |
| 1474 | # CONFIG_XFS_QUOTA is not set | 1496 | # CONFIG_XFS_QUOTA is not set |
| 1475 | # CONFIG_XFS_POSIX_ACL is not set | 1497 | # CONFIG_XFS_POSIX_ACL is not set |
| 1476 | # CONFIG_XFS_RT is not set | 1498 | # CONFIG_XFS_RT is not set |
| 1477 | # CONFIG_XFS_DEBUG is not set | 1499 | # CONFIG_XFS_DEBUG is not set |
| 1500 | # CONFIG_GFS2_FS is not set | ||
| 1478 | # CONFIG_OCFS2_FS is not set | 1501 | # CONFIG_OCFS2_FS is not set |
| 1479 | # CONFIG_BTRFS_FS is not set | 1502 | # CONFIG_BTRFS_FS is not set |
| 1503 | CONFIG_FILE_LOCKING=y | ||
| 1504 | CONFIG_FSNOTIFY=y | ||
| 1480 | CONFIG_DNOTIFY=y | 1505 | CONFIG_DNOTIFY=y |
| 1481 | CONFIG_INOTIFY=y | 1506 | CONFIG_INOTIFY=y |
| 1482 | CONFIG_INOTIFY_USER=y | 1507 | CONFIG_INOTIFY_USER=y |
| @@ -1548,6 +1573,7 @@ CONFIG_NFS_FS=y | |||
| 1548 | CONFIG_NFS_V3=y | 1573 | CONFIG_NFS_V3=y |
| 1549 | CONFIG_NFS_V3_ACL=y | 1574 | CONFIG_NFS_V3_ACL=y |
| 1550 | CONFIG_NFS_V4=y | 1575 | CONFIG_NFS_V4=y |
| 1576 | # CONFIG_NFS_V4_1 is not set | ||
| 1551 | CONFIG_ROOT_NFS=y | 1577 | CONFIG_ROOT_NFS=y |
| 1552 | CONFIG_NFSD=m | 1578 | CONFIG_NFSD=m |
| 1553 | CONFIG_NFSD_V3=y | 1579 | CONFIG_NFSD_V3=y |
| @@ -1578,7 +1604,7 @@ CONFIG_CIFS=m | |||
| 1578 | # | 1604 | # |
| 1579 | # CONFIG_PARTITION_ADVANCED is not set | 1605 | # CONFIG_PARTITION_ADVANCED is not set |
| 1580 | CONFIG_MSDOS_PARTITION=y | 1606 | CONFIG_MSDOS_PARTITION=y |
| 1581 | CONFIG_NLS=m | 1607 | CONFIG_NLS=y |
| 1582 | CONFIG_NLS_DEFAULT="iso8859-1" | 1608 | CONFIG_NLS_DEFAULT="iso8859-1" |
| 1583 | CONFIG_NLS_CODEPAGE_437=m | 1609 | CONFIG_NLS_CODEPAGE_437=m |
| 1584 | # CONFIG_NLS_CODEPAGE_737 is not set | 1610 | # CONFIG_NLS_CODEPAGE_737 is not set |
| @@ -1645,6 +1671,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1645 | CONFIG_HAS_DMA=y | 1671 | CONFIG_HAS_DMA=y |
| 1646 | CONFIG_HAVE_LMB=y | 1672 | CONFIG_HAVE_LMB=y |
| 1647 | CONFIG_NLATTR=y | 1673 | CONFIG_NLATTR=y |
| 1674 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1648 | 1675 | ||
| 1649 | # | 1676 | # |
| 1650 | # Kernel hacking | 1677 | # Kernel hacking |
| @@ -1675,6 +1702,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 1675 | # CONFIG_RT_MUTEX_TESTER is not set | 1702 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1676 | # CONFIG_DEBUG_SPINLOCK is not set | 1703 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1677 | # CONFIG_DEBUG_MUTEXES is not set | 1704 | # CONFIG_DEBUG_MUTEXES is not set |
| 1705 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1706 | # CONFIG_PROVE_LOCKING is not set | ||
| 1707 | # CONFIG_LOCK_STAT is not set | ||
| 1678 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1708 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1679 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1709 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1680 | # CONFIG_DEBUG_KOBJECT is not set | 1710 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1686,7 +1716,6 @@ CONFIG_DEBUG_MEMORY_INIT=y | |||
| 1686 | # CONFIG_DEBUG_LIST is not set | 1716 | # CONFIG_DEBUG_LIST is not set |
| 1687 | # CONFIG_DEBUG_SG is not set | 1717 | # CONFIG_DEBUG_SG is not set |
| 1688 | # CONFIG_DEBUG_NOTIFIERS is not set | 1718 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1689 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1690 | # CONFIG_RCU_TORTURE_TEST is not set | 1719 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1691 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1720 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1692 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1721 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1700,16 +1729,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1700 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1729 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1701 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1730 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1702 | CONFIG_TRACING_SUPPORT=y | 1731 | CONFIG_TRACING_SUPPORT=y |
| 1703 | 1732 | CONFIG_FTRACE=y | |
| 1704 | # | ||
| 1705 | # Tracers | ||
| 1706 | # | ||
| 1707 | # CONFIG_FUNCTION_TRACER is not set | 1733 | # CONFIG_FUNCTION_TRACER is not set |
| 1734 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1708 | # CONFIG_SCHED_TRACER is not set | 1735 | # CONFIG_SCHED_TRACER is not set |
| 1709 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1736 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1710 | # CONFIG_EVENT_TRACER is not set | ||
| 1711 | # CONFIG_BOOT_TRACER is not set | 1737 | # CONFIG_BOOT_TRACER is not set |
| 1712 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1738 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1739 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1740 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1713 | # CONFIG_STACK_TRACER is not set | 1741 | # CONFIG_STACK_TRACER is not set |
| 1714 | # CONFIG_KMEMTRACE is not set | 1742 | # CONFIG_KMEMTRACE is not set |
| 1715 | # CONFIG_WORKQUEUE_TRACER is not set | 1743 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -1717,6 +1745,8 @@ CONFIG_TRACING_SUPPORT=y | |||
| 1717 | # CONFIG_SAMPLES is not set | 1745 | # CONFIG_SAMPLES is not set |
| 1718 | CONFIG_HAVE_ARCH_KGDB=y | 1746 | CONFIG_HAVE_ARCH_KGDB=y |
| 1719 | # CONFIG_KGDB is not set | 1747 | # CONFIG_KGDB is not set |
| 1748 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1749 | CONFIG_PPC_WERROR=y | ||
| 1720 | CONFIG_PRINT_STACK_DEPTH=64 | 1750 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1721 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1751 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1722 | # CONFIG_DEBUG_STACK_USAGE is not set | 1752 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/mgcoge_defconfig b/arch/powerpc/configs/mgcoge_defconfig index 31e1df665157..e9491c1c3f31 100644 --- a/arch/powerpc/configs/mgcoge_defconfig +++ b/arch/powerpc/configs/mgcoge_defconfig | |||
| @@ -1,25 +1,27 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:21:55 2009 | 4 | # Wed Jul 29 23:31:51 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_ALTIVEC is not set | 20 | # CONFIG_ALTIVEC is not set |
| 20 | CONFIG_PPC_STD_MMU=y | 21 | CONFIG_PPC_STD_MMU=y |
| 21 | CONFIG_PPC_STD_MMU_32=y | 22 | CONFIG_PPC_STD_MMU_32=y |
| 22 | # CONFIG_PPC_MM_SLICES is not set | 23 | # CONFIG_PPC_MM_SLICES is not set |
| 24 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 23 | # CONFIG_SMP is not set | 25 | # CONFIG_SMP is not set |
| 24 | CONFIG_PPC32=y | 26 | CONFIG_PPC32=y |
| 25 | CONFIG_WORD_SIZE=32 | 27 | CONFIG_WORD_SIZE=32 |
| @@ -30,15 +32,16 @@ CONFIG_GENERIC_TIME=y | |||
| 30 | CONFIG_GENERIC_TIME_VSYSCALL=y | 32 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 31 | CONFIG_GENERIC_CLOCKEVENTS=y | 33 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 32 | CONFIG_GENERIC_HARDIRQS=y | 34 | CONFIG_GENERIC_HARDIRQS=y |
| 35 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 33 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 36 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 34 | CONFIG_IRQ_PER_CPU=y | 37 | CONFIG_IRQ_PER_CPU=y |
| 35 | CONFIG_STACKTRACE_SUPPORT=y | 38 | CONFIG_STACKTRACE_SUPPORT=y |
| 36 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 39 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 40 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 37 | CONFIG_LOCKDEP_SUPPORT=y | 41 | CONFIG_LOCKDEP_SUPPORT=y |
| 38 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 39 | CONFIG_ARCH_HAS_ILOG2_U32=y | 43 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 40 | CONFIG_GENERIC_HWEIGHT=y | 44 | CONFIG_GENERIC_HWEIGHT=y |
| 41 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 42 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 45 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 43 | CONFIG_GENERIC_GPIO=y | 46 | CONFIG_GENERIC_GPIO=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -53,6 +56,7 @@ CONFIG_PPC_UDBG_16550=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | # CONFIG_DEFAULT_UIMAGE is not set | 60 | # CONFIG_DEFAULT_UIMAGE is not set |
| 57 | CONFIG_HIBERNATE_32=y | 61 | CONFIG_HIBERNATE_32=y |
| 58 | CONFIG_ARCH_HIBERNATION_POSSIBLE=y | 62 | CONFIG_ARCH_HIBERNATION_POSSIBLE=y |
| @@ -60,6 +64,7 @@ CONFIG_ARCH_HIBERNATION_POSSIBLE=y | |||
| 60 | # CONFIG_PPC_DCR_MMIO is not set | 64 | # CONFIG_PPC_DCR_MMIO is not set |
| 61 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 65 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 62 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 66 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 67 | CONFIG_CONSTRUCTORS=y | ||
| 63 | 68 | ||
| 64 | # | 69 | # |
| 65 | # General setup | 70 | # General setup |
| @@ -105,7 +110,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 105 | CONFIG_KALLSYMS=y | 110 | CONFIG_KALLSYMS=y |
| 106 | CONFIG_KALLSYMS_ALL=y | 111 | CONFIG_KALLSYMS_ALL=y |
| 107 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 112 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 108 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 109 | CONFIG_HOTPLUG=y | 113 | CONFIG_HOTPLUG=y |
| 110 | CONFIG_PRINTK=y | 114 | CONFIG_PRINTK=y |
| 111 | CONFIG_BUG=y | 115 | CONFIG_BUG=y |
| @@ -119,8 +123,15 @@ CONFIG_TIMERFD=y | |||
| 119 | CONFIG_EVENTFD=y | 123 | CONFIG_EVENTFD=y |
| 120 | CONFIG_SHMEM=y | 124 | CONFIG_SHMEM=y |
| 121 | CONFIG_AIO=y | 125 | CONFIG_AIO=y |
| 126 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 127 | |||
| 128 | # | ||
| 129 | # Performance Counters | ||
| 130 | # | ||
| 131 | # CONFIG_PERF_COUNTERS is not set | ||
| 122 | CONFIG_VM_EVENT_COUNTERS=y | 132 | CONFIG_VM_EVENT_COUNTERS=y |
| 123 | CONFIG_PCI_QUIRKS=y | 133 | CONFIG_PCI_QUIRKS=y |
| 134 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 124 | CONFIG_COMPAT_BRK=y | 135 | CONFIG_COMPAT_BRK=y |
| 125 | CONFIG_SLAB=y | 136 | CONFIG_SLAB=y |
| 126 | # CONFIG_SLUB is not set | 137 | # CONFIG_SLUB is not set |
| @@ -134,6 +145,11 @@ CONFIG_HAVE_KPROBES=y | |||
| 134 | CONFIG_HAVE_KRETPROBES=y | 145 | CONFIG_HAVE_KRETPROBES=y |
| 135 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 146 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 136 | CONFIG_HAVE_CLK=y | 147 | CONFIG_HAVE_CLK=y |
| 148 | |||
| 149 | # | ||
| 150 | # GCOV-based kernel profiling | ||
| 151 | # | ||
| 152 | # CONFIG_GCOV_KERNEL is not set | ||
| 137 | # CONFIG_SLOW_WORK is not set | 153 | # CONFIG_SLOW_WORK is not set |
| 138 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 154 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 139 | CONFIG_SLABINFO=y | 155 | CONFIG_SLABINFO=y |
| @@ -141,7 +157,7 @@ CONFIG_RT_MUTEXES=y | |||
| 141 | CONFIG_BASE_SMALL=0 | 157 | CONFIG_BASE_SMALL=0 |
| 142 | # CONFIG_MODULES is not set | 158 | # CONFIG_MODULES is not set |
| 143 | CONFIG_BLOCK=y | 159 | CONFIG_BLOCK=y |
| 144 | # CONFIG_LBD is not set | 160 | CONFIG_LBDAF=y |
| 145 | # CONFIG_BLK_DEV_INTEGRITY is not set | 161 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 146 | 162 | ||
| 147 | # | 163 | # |
| @@ -225,6 +241,7 @@ CONFIG_BINFMT_ELF=y | |||
| 225 | # CONFIG_HAVE_AOUT is not set | 241 | # CONFIG_HAVE_AOUT is not set |
| 226 | CONFIG_BINFMT_MISC=y | 242 | CONFIG_BINFMT_MISC=y |
| 227 | # CONFIG_IOMMU_HELPER is not set | 243 | # CONFIG_IOMMU_HELPER is not set |
| 244 | # CONFIG_SWIOTLB is not set | ||
| 228 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 245 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 229 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 246 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 230 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 247 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -240,9 +257,9 @@ CONFIG_MIGRATION=y | |||
| 240 | CONFIG_ZONE_DMA_FLAG=1 | 257 | CONFIG_ZONE_DMA_FLAG=1 |
| 241 | CONFIG_BOUNCE=y | 258 | CONFIG_BOUNCE=y |
| 242 | CONFIG_VIRT_TO_BUS=y | 259 | CONFIG_VIRT_TO_BUS=y |
| 243 | CONFIG_UNEVICTABLE_LRU=y | ||
| 244 | CONFIG_HAVE_MLOCK=y | 260 | CONFIG_HAVE_MLOCK=y |
| 245 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 261 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 262 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 246 | CONFIG_PPC_4K_PAGES=y | 263 | CONFIG_PPC_4K_PAGES=y |
| 247 | # CONFIG_PPC_16K_PAGES is not set | 264 | # CONFIG_PPC_16K_PAGES is not set |
| 248 | # CONFIG_PPC_64K_PAGES is not set | 265 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -313,6 +330,7 @@ CONFIG_IP_PNP_BOOTP=y | |||
| 313 | # CONFIG_NET_IPIP is not set | 330 | # CONFIG_NET_IPIP is not set |
| 314 | # CONFIG_NET_IPGRE is not set | 331 | # CONFIG_NET_IPGRE is not set |
| 315 | # CONFIG_IP_MROUTE is not set | 332 | # CONFIG_IP_MROUTE is not set |
| 333 | # CONFIG_ARPD is not set | ||
| 316 | CONFIG_SYN_COOKIES=y | 334 | CONFIG_SYN_COOKIES=y |
| 317 | # CONFIG_INET_AH is not set | 335 | # CONFIG_INET_AH is not set |
| 318 | # CONFIG_INET_ESP is not set | 336 | # CONFIG_INET_ESP is not set |
| @@ -374,7 +392,11 @@ CONFIG_WIRELESS=y | |||
| 374 | CONFIG_WIRELESS_OLD_REGULATORY=y | 392 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 375 | # CONFIG_WIRELESS_EXT is not set | 393 | # CONFIG_WIRELESS_EXT is not set |
| 376 | # CONFIG_LIB80211 is not set | 394 | # CONFIG_LIB80211 is not set |
| 377 | # CONFIG_MAC80211 is not set | 395 | |
| 396 | # | ||
| 397 | # CFG80211 needs to be enabled for MAC80211 | ||
| 398 | # | ||
| 399 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 378 | # CONFIG_WIMAX is not set | 400 | # CONFIG_WIMAX is not set |
| 379 | # CONFIG_RFKILL is not set | 401 | # CONFIG_RFKILL is not set |
| 380 | 402 | ||
| @@ -484,6 +506,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 484 | # CONFIG_MTD_UBI is not set | 506 | # CONFIG_MTD_UBI is not set |
| 485 | CONFIG_OF_DEVICE=y | 507 | CONFIG_OF_DEVICE=y |
| 486 | CONFIG_OF_GPIO=y | 508 | CONFIG_OF_GPIO=y |
| 509 | CONFIG_OF_MDIO=y | ||
| 487 | # CONFIG_PARPORT is not set | 510 | # CONFIG_PARPORT is not set |
| 488 | CONFIG_BLK_DEV=y | 511 | CONFIG_BLK_DEV=y |
| 489 | # CONFIG_BLK_DEV_FD is not set | 512 | # CONFIG_BLK_DEV_FD is not set |
| @@ -523,13 +546,17 @@ CONFIG_HAVE_IDE=y | |||
| 523 | # | 546 | # |
| 524 | 547 | ||
| 525 | # | 548 | # |
| 526 | # A new alternative FireWire stack is available with EXPERIMENTAL=y | 549 | # You can enable one or both FireWire driver stacks. |
| 527 | # | 550 | # |
| 551 | |||
| 552 | # | ||
| 553 | # See the help texts for more information. | ||
| 554 | # | ||
| 555 | # CONFIG_FIREWIRE is not set | ||
| 528 | # CONFIG_IEEE1394 is not set | 556 | # CONFIG_IEEE1394 is not set |
| 529 | # CONFIG_I2O is not set | 557 | # CONFIG_I2O is not set |
| 530 | # CONFIG_MACINTOSH_DRIVERS is not set | 558 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 531 | CONFIG_NETDEVICES=y | 559 | CONFIG_NETDEVICES=y |
| 532 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 533 | # CONFIG_DUMMY is not set | 560 | # CONFIG_DUMMY is not set |
| 534 | # CONFIG_BONDING is not set | 561 | # CONFIG_BONDING is not set |
| 535 | # CONFIG_EQUALIZER is not set | 562 | # CONFIG_EQUALIZER is not set |
| @@ -577,6 +604,7 @@ CONFIG_MII=y | |||
| 577 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 604 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 578 | # CONFIG_NET_PCI is not set | 605 | # CONFIG_NET_PCI is not set |
| 579 | # CONFIG_B44 is not set | 606 | # CONFIG_B44 is not set |
| 607 | # CONFIG_KS8842 is not set | ||
| 580 | # CONFIG_ATL2 is not set | 608 | # CONFIG_ATL2 is not set |
| 581 | CONFIG_FS_ENET=y | 609 | CONFIG_FS_ENET=y |
| 582 | CONFIG_FS_ENET_HAS_SCC=y | 610 | CONFIG_FS_ENET_HAS_SCC=y |
| @@ -654,6 +682,10 @@ CONFIG_HW_RANDOM=y | |||
| 654 | CONFIG_DEVPORT=y | 682 | CONFIG_DEVPORT=y |
| 655 | # CONFIG_I2C is not set | 683 | # CONFIG_I2C is not set |
| 656 | # CONFIG_SPI is not set | 684 | # CONFIG_SPI is not set |
| 685 | |||
| 686 | # | ||
| 687 | # PPS support | ||
| 688 | # | ||
| 657 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 689 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 658 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 690 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 659 | CONFIG_GPIOLIB=y | 691 | CONFIG_GPIOLIB=y |
| @@ -697,22 +729,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 697 | # CONFIG_HTC_PASIC3 is not set | 729 | # CONFIG_HTC_PASIC3 is not set |
| 698 | # CONFIG_MFD_TMIO is not set | 730 | # CONFIG_MFD_TMIO is not set |
| 699 | # CONFIG_REGULATOR is not set | 731 | # CONFIG_REGULATOR is not set |
| 700 | 732 | # CONFIG_MEDIA_SUPPORT is not set | |
| 701 | # | ||
| 702 | # Multimedia devices | ||
| 703 | # | ||
| 704 | |||
| 705 | # | ||
| 706 | # Multimedia core support | ||
| 707 | # | ||
| 708 | # CONFIG_VIDEO_DEV is not set | ||
| 709 | # CONFIG_DVB_CORE is not set | ||
| 710 | # CONFIG_VIDEO_MEDIA is not set | ||
| 711 | |||
| 712 | # | ||
| 713 | # Multimedia drivers | ||
| 714 | # | ||
| 715 | # CONFIG_DAB is not set | ||
| 716 | 733 | ||
| 717 | # | 734 | # |
| 718 | # Graphics support | 735 | # Graphics support |
| @@ -740,6 +757,10 @@ CONFIG_SSB_POSSIBLE=y | |||
| 740 | # CONFIG_DMADEVICES is not set | 757 | # CONFIG_DMADEVICES is not set |
| 741 | # CONFIG_AUXDISPLAY is not set | 758 | # CONFIG_AUXDISPLAY is not set |
| 742 | # CONFIG_UIO is not set | 759 | # CONFIG_UIO is not set |
| 760 | |||
| 761 | # | ||
| 762 | # TI VLYNQ | ||
| 763 | # | ||
| 743 | # CONFIG_STAGING is not set | 764 | # CONFIG_STAGING is not set |
| 744 | 765 | ||
| 745 | # | 766 | # |
| @@ -757,9 +778,10 @@ CONFIG_JBD=y | |||
| 757 | # CONFIG_REISERFS_FS is not set | 778 | # CONFIG_REISERFS_FS is not set |
| 758 | # CONFIG_JFS_FS is not set | 779 | # CONFIG_JFS_FS is not set |
| 759 | # CONFIG_FS_POSIX_ACL is not set | 780 | # CONFIG_FS_POSIX_ACL is not set |
| 760 | CONFIG_FILE_LOCKING=y | ||
| 761 | # CONFIG_XFS_FS is not set | 781 | # CONFIG_XFS_FS is not set |
| 762 | # CONFIG_OCFS2_FS is not set | 782 | # CONFIG_OCFS2_FS is not set |
| 783 | CONFIG_FILE_LOCKING=y | ||
| 784 | CONFIG_FSNOTIFY=y | ||
| 763 | CONFIG_DNOTIFY=y | 785 | CONFIG_DNOTIFY=y |
| 764 | CONFIG_INOTIFY=y | 786 | CONFIG_INOTIFY=y |
| 765 | CONFIG_INOTIFY_USER=y | 787 | CONFIG_INOTIFY_USER=y |
| @@ -916,6 +938,7 @@ CONFIG_HAS_IOPORT=y | |||
| 916 | CONFIG_HAS_DMA=y | 938 | CONFIG_HAS_DMA=y |
| 917 | CONFIG_HAVE_LMB=y | 939 | CONFIG_HAVE_LMB=y |
| 918 | CONFIG_NLATTR=y | 940 | CONFIG_NLATTR=y |
| 941 | CONFIG_GENERIC_ATOMIC64=y | ||
| 919 | 942 | ||
| 920 | # | 943 | # |
| 921 | # Kernel hacking | 944 | # Kernel hacking |
| @@ -941,6 +964,9 @@ CONFIG_DEBUG_KERNEL=y | |||
| 941 | # CONFIG_RT_MUTEX_TESTER is not set | 964 | # CONFIG_RT_MUTEX_TESTER is not set |
| 942 | # CONFIG_DEBUG_SPINLOCK is not set | 965 | # CONFIG_DEBUG_SPINLOCK is not set |
| 943 | # CONFIG_DEBUG_MUTEXES is not set | 966 | # CONFIG_DEBUG_MUTEXES is not set |
| 967 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 968 | # CONFIG_PROVE_LOCKING is not set | ||
| 969 | # CONFIG_LOCK_STAT is not set | ||
| 944 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 970 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 945 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 971 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 946 | # CONFIG_DEBUG_KOBJECT is not set | 972 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -952,7 +978,6 @@ CONFIG_DEBUG_INFO=y | |||
| 952 | # CONFIG_DEBUG_LIST is not set | 978 | # CONFIG_DEBUG_LIST is not set |
| 953 | # CONFIG_DEBUG_SG is not set | 979 | # CONFIG_DEBUG_SG is not set |
| 954 | # CONFIG_DEBUG_NOTIFIERS is not set | 980 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 955 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 956 | # CONFIG_RCU_TORTURE_TEST is not set | 981 | # CONFIG_RCU_TORTURE_TEST is not set |
| 957 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 982 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 958 | # CONFIG_BACKTRACE_SELF_TEST is not set | 983 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -966,16 +991,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 966 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 991 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 967 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 992 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 968 | CONFIG_TRACING_SUPPORT=y | 993 | CONFIG_TRACING_SUPPORT=y |
| 969 | 994 | CONFIG_FTRACE=y | |
| 970 | # | ||
| 971 | # Tracers | ||
| 972 | # | ||
| 973 | # CONFIG_FUNCTION_TRACER is not set | 995 | # CONFIG_FUNCTION_TRACER is not set |
| 996 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 974 | # CONFIG_SCHED_TRACER is not set | 997 | # CONFIG_SCHED_TRACER is not set |
| 975 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 998 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 976 | # CONFIG_EVENT_TRACER is not set | ||
| 977 | # CONFIG_BOOT_TRACER is not set | 999 | # CONFIG_BOOT_TRACER is not set |
| 978 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1000 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1001 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1002 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 979 | # CONFIG_STACK_TRACER is not set | 1003 | # CONFIG_STACK_TRACER is not set |
| 980 | # CONFIG_KMEMTRACE is not set | 1004 | # CONFIG_KMEMTRACE is not set |
| 981 | # CONFIG_WORKQUEUE_TRACER is not set | 1005 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -983,9 +1007,12 @@ CONFIG_TRACING_SUPPORT=y | |||
| 983 | # CONFIG_DYNAMIC_DEBUG is not set | 1007 | # CONFIG_DYNAMIC_DEBUG is not set |
| 984 | # CONFIG_SAMPLES is not set | 1008 | # CONFIG_SAMPLES is not set |
| 985 | CONFIG_HAVE_ARCH_KGDB=y | 1009 | CONFIG_HAVE_ARCH_KGDB=y |
| 1010 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1011 | CONFIG_PPC_WERROR=y | ||
| 986 | CONFIG_PRINT_STACK_DEPTH=64 | 1012 | CONFIG_PRINT_STACK_DEPTH=64 |
| 987 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1013 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 988 | # CONFIG_DEBUG_STACK_USAGE is not set | 1014 | # CONFIG_DEBUG_STACK_USAGE is not set |
| 1015 | # CONFIG_PPC_EMULATED_STATS is not set | ||
| 989 | # CONFIG_CODE_PATCHING_SELFTEST is not set | 1016 | # CONFIG_CODE_PATCHING_SELFTEST is not set |
| 990 | # CONFIG_FTR_FIXUP_SELFTEST is not set | 1017 | # CONFIG_FTR_FIXUP_SELFTEST is not set |
| 991 | # CONFIG_MSI_BITMAP_SELFTEST is not set | 1018 | # CONFIG_MSI_BITMAP_SELFTEST is not set |
diff --git a/arch/powerpc/configs/mgsuvd_defconfig b/arch/powerpc/configs/mgsuvd_defconfig index 24fa90792c54..1ae85a3b2942 100644 --- a/arch/powerpc/configs/mgsuvd_defconfig +++ b/arch/powerpc/configs/mgsuvd_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:21:55 2009 | 4 | # Wed Jul 29 23:31:52 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | CONFIG_PPC_8xx=y | 13 | CONFIG_PPC_8xx=y |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -27,15 +27,16 @@ CONFIG_GENERIC_TIME=y | |||
| 27 | CONFIG_GENERIC_TIME_VSYSCALL=y | 27 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 28 | CONFIG_GENERIC_CLOCKEVENTS=y | 28 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 29 | CONFIG_GENERIC_HARDIRQS=y | 29 | CONFIG_GENERIC_HARDIRQS=y |
| 30 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 30 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 31 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 31 | CONFIG_IRQ_PER_CPU=y | 32 | CONFIG_IRQ_PER_CPU=y |
| 32 | CONFIG_STACKTRACE_SUPPORT=y | 33 | CONFIG_STACKTRACE_SUPPORT=y |
| 33 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 34 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 35 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 34 | CONFIG_LOCKDEP_SUPPORT=y | 36 | CONFIG_LOCKDEP_SUPPORT=y |
| 35 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 37 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 36 | CONFIG_ARCH_HAS_ILOG2_U32=y | 38 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 37 | CONFIG_GENERIC_HWEIGHT=y | 39 | CONFIG_GENERIC_HWEIGHT=y |
| 38 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 39 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 40 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 40 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 41 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 41 | CONFIG_PPC=y | 42 | CONFIG_PPC=y |
| @@ -48,11 +49,13 @@ CONFIG_OF=y | |||
| 48 | # CONFIG_PPC_UDBG_16550 is not set | 49 | # CONFIG_PPC_UDBG_16550 is not set |
| 49 | # CONFIG_GENERIC_TBSYNC is not set | 50 | # CONFIG_GENERIC_TBSYNC is not set |
| 50 | CONFIG_AUDIT_ARCH=y | 51 | CONFIG_AUDIT_ARCH=y |
| 52 | CONFIG_DTC=y | ||
| 51 | # CONFIG_DEFAULT_UIMAGE is not set | 53 | # CONFIG_DEFAULT_UIMAGE is not set |
| 52 | # CONFIG_PPC_DCR_NATIVE is not set | 54 | # CONFIG_PPC_DCR_NATIVE is not set |
| 53 | # CONFIG_PPC_DCR_MMIO is not set | 55 | # CONFIG_PPC_DCR_MMIO is not set |
| 54 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 56 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 55 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 57 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 58 | CONFIG_CONSTRUCTORS=y | ||
| 56 | 59 | ||
| 57 | # | 60 | # |
| 58 | # General setup | 61 | # General setup |
| @@ -102,7 +105,6 @@ CONFIG_EMBEDDED=y | |||
| 102 | # CONFIG_SYSCTL_SYSCALL is not set | 105 | # CONFIG_SYSCTL_SYSCALL is not set |
| 103 | CONFIG_KALLSYMS=y | 106 | CONFIG_KALLSYMS=y |
| 104 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 107 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 105 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 106 | # CONFIG_HOTPLUG is not set | 108 | # CONFIG_HOTPLUG is not set |
| 107 | CONFIG_PRINTK=y | 109 | CONFIG_PRINTK=y |
| 108 | # CONFIG_BUG is not set | 110 | # CONFIG_BUG is not set |
| @@ -115,7 +117,14 @@ CONFIG_TIMERFD=y | |||
| 115 | CONFIG_EVENTFD=y | 117 | CONFIG_EVENTFD=y |
| 116 | CONFIG_SHMEM=y | 118 | CONFIG_SHMEM=y |
| 117 | CONFIG_AIO=y | 119 | CONFIG_AIO=y |
| 120 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 121 | |||
| 122 | # | ||
| 123 | # Performance Counters | ||
| 124 | # | ||
| 125 | # CONFIG_PERF_COUNTERS is not set | ||
| 118 | # CONFIG_VM_EVENT_COUNTERS is not set | 126 | # CONFIG_VM_EVENT_COUNTERS is not set |
| 127 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 119 | CONFIG_COMPAT_BRK=y | 128 | CONFIG_COMPAT_BRK=y |
| 120 | CONFIG_SLAB=y | 129 | CONFIG_SLAB=y |
| 121 | # CONFIG_SLUB is not set | 130 | # CONFIG_SLUB is not set |
| @@ -129,6 +138,11 @@ CONFIG_HAVE_KPROBES=y | |||
| 129 | CONFIG_HAVE_KRETPROBES=y | 138 | CONFIG_HAVE_KRETPROBES=y |
| 130 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 139 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 131 | CONFIG_HAVE_CLK=y | 140 | CONFIG_HAVE_CLK=y |
| 141 | |||
| 142 | # | ||
| 143 | # GCOV-based kernel profiling | ||
| 144 | # | ||
| 145 | # CONFIG_GCOV_KERNEL is not set | ||
| 132 | # CONFIG_SLOW_WORK is not set | 146 | # CONFIG_SLOW_WORK is not set |
| 133 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 147 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 134 | CONFIG_SLABINFO=y | 148 | CONFIG_SLABINFO=y |
| @@ -136,7 +150,7 @@ CONFIG_RT_MUTEXES=y | |||
| 136 | CONFIG_BASE_SMALL=1 | 150 | CONFIG_BASE_SMALL=1 |
| 137 | # CONFIG_MODULES is not set | 151 | # CONFIG_MODULES is not set |
| 138 | CONFIG_BLOCK=y | 152 | CONFIG_BLOCK=y |
| 139 | # CONFIG_LBD is not set | 153 | CONFIG_LBDAF=y |
| 140 | # CONFIG_BLK_DEV_BSG is not set | 154 | # CONFIG_BLK_DEV_BSG is not set |
| 141 | # CONFIG_BLK_DEV_INTEGRITY is not set | 155 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 142 | 156 | ||
| @@ -222,6 +236,7 @@ CONFIG_BINFMT_ELF=y | |||
| 222 | # CONFIG_BINFMT_MISC is not set | 236 | # CONFIG_BINFMT_MISC is not set |
| 223 | CONFIG_MATH_EMULATION=y | 237 | CONFIG_MATH_EMULATION=y |
| 224 | # CONFIG_IOMMU_HELPER is not set | 238 | # CONFIG_IOMMU_HELPER is not set |
| 239 | # CONFIG_SWIOTLB is not set | ||
| 225 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y | 240 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y |
| 226 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 241 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 227 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 242 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| @@ -241,9 +256,9 @@ CONFIG_MIGRATION=y | |||
| 241 | CONFIG_ZONE_DMA_FLAG=1 | 256 | CONFIG_ZONE_DMA_FLAG=1 |
| 242 | CONFIG_BOUNCE=y | 257 | CONFIG_BOUNCE=y |
| 243 | CONFIG_VIRT_TO_BUS=y | 258 | CONFIG_VIRT_TO_BUS=y |
| 244 | CONFIG_UNEVICTABLE_LRU=y | ||
| 245 | CONFIG_HAVE_MLOCK=y | 259 | CONFIG_HAVE_MLOCK=y |
| 246 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 260 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 261 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 247 | CONFIG_PPC_4K_PAGES=y | 262 | CONFIG_PPC_4K_PAGES=y |
| 248 | # CONFIG_PPC_16K_PAGES is not set | 263 | # CONFIG_PPC_16K_PAGES is not set |
| 249 | # CONFIG_PPC_64K_PAGES is not set | 264 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -281,6 +296,7 @@ CONFIG_PAGE_OFFSET=0xc0000000 | |||
| 281 | CONFIG_KERNEL_START=0xc0000000 | 296 | CONFIG_KERNEL_START=0xc0000000 |
| 282 | CONFIG_PHYSICAL_START=0x00000000 | 297 | CONFIG_PHYSICAL_START=0x00000000 |
| 283 | CONFIG_TASK_SIZE=0x80000000 | 298 | CONFIG_TASK_SIZE=0x80000000 |
| 299 | CONFIG_CONSISTENT_SIZE=0x00200000 | ||
| 284 | CONFIG_NET=y | 300 | CONFIG_NET=y |
| 285 | 301 | ||
| 286 | # | 302 | # |
| @@ -342,6 +358,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 342 | # CONFIG_ECONET is not set | 358 | # CONFIG_ECONET is not set |
| 343 | # CONFIG_WAN_ROUTER is not set | 359 | # CONFIG_WAN_ROUTER is not set |
| 344 | # CONFIG_PHONET is not set | 360 | # CONFIG_PHONET is not set |
| 361 | # CONFIG_IEEE802154 is not set | ||
| 345 | # CONFIG_NET_SCHED is not set | 362 | # CONFIG_NET_SCHED is not set |
| 346 | # CONFIG_DCB is not set | 363 | # CONFIG_DCB is not set |
| 347 | 364 | ||
| @@ -359,7 +376,11 @@ CONFIG_WIRELESS=y | |||
| 359 | CONFIG_WIRELESS_OLD_REGULATORY=y | 376 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 360 | # CONFIG_WIRELESS_EXT is not set | 377 | # CONFIG_WIRELESS_EXT is not set |
| 361 | # CONFIG_LIB80211 is not set | 378 | # CONFIG_LIB80211 is not set |
| 362 | # CONFIG_MAC80211 is not set | 379 | |
| 380 | # | ||
| 381 | # CFG80211 needs to be enabled for MAC80211 | ||
| 382 | # | ||
| 383 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 363 | # CONFIG_WIMAX is not set | 384 | # CONFIG_WIMAX is not set |
| 364 | # CONFIG_RFKILL is not set | 385 | # CONFIG_RFKILL is not set |
| 365 | # CONFIG_NET_9P is not set | 386 | # CONFIG_NET_9P is not set |
| @@ -463,6 +484,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 463 | # | 484 | # |
| 464 | # CONFIG_MTD_UBI is not set | 485 | # CONFIG_MTD_UBI is not set |
| 465 | CONFIG_OF_DEVICE=y | 486 | CONFIG_OF_DEVICE=y |
| 487 | CONFIG_OF_MDIO=y | ||
| 466 | # CONFIG_PARPORT is not set | 488 | # CONFIG_PARPORT is not set |
| 467 | CONFIG_BLK_DEV=y | 489 | CONFIG_BLK_DEV=y |
| 468 | # CONFIG_BLK_DEV_FD is not set | 490 | # CONFIG_BLK_DEV_FD is not set |
| @@ -492,7 +514,6 @@ CONFIG_HAVE_IDE=y | |||
| 492 | # CONFIG_MD is not set | 514 | # CONFIG_MD is not set |
| 493 | # CONFIG_MACINTOSH_DRIVERS is not set | 515 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 494 | CONFIG_NETDEVICES=y | 516 | CONFIG_NETDEVICES=y |
| 495 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 496 | # CONFIG_DUMMY is not set | 517 | # CONFIG_DUMMY is not set |
| 497 | # CONFIG_BONDING is not set | 518 | # CONFIG_BONDING is not set |
| 498 | # CONFIG_MACVLAN is not set | 519 | # CONFIG_MACVLAN is not set |
| @@ -531,6 +552,7 @@ CONFIG_MII=y | |||
| 531 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 552 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 532 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 553 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 533 | # CONFIG_B44 is not set | 554 | # CONFIG_B44 is not set |
| 555 | # CONFIG_KS8842 is not set | ||
| 534 | CONFIG_FS_ENET=y | 556 | CONFIG_FS_ENET=y |
| 535 | CONFIG_FS_ENET_HAS_SCC=y | 557 | CONFIG_FS_ENET_HAS_SCC=y |
| 536 | # CONFIG_FS_ENET_HAS_FEC is not set | 558 | # CONFIG_FS_ENET_HAS_FEC is not set |
| @@ -602,6 +624,11 @@ CONFIG_GEN_RTC=y | |||
| 602 | # CONFIG_TCG_TPM is not set | 624 | # CONFIG_TCG_TPM is not set |
| 603 | # CONFIG_I2C is not set | 625 | # CONFIG_I2C is not set |
| 604 | # CONFIG_SPI is not set | 626 | # CONFIG_SPI is not set |
| 627 | |||
| 628 | # | ||
| 629 | # PPS support | ||
| 630 | # | ||
| 631 | # CONFIG_PPS is not set | ||
| 605 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 632 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 606 | # CONFIG_GPIOLIB is not set | 633 | # CONFIG_GPIOLIB is not set |
| 607 | # CONFIG_W1 is not set | 634 | # CONFIG_W1 is not set |
| @@ -625,22 +652,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 625 | # CONFIG_HTC_PASIC3 is not set | 652 | # CONFIG_HTC_PASIC3 is not set |
| 626 | # CONFIG_MFD_TMIO is not set | 653 | # CONFIG_MFD_TMIO is not set |
| 627 | # CONFIG_REGULATOR is not set | 654 | # CONFIG_REGULATOR is not set |
| 628 | 655 | # CONFIG_MEDIA_SUPPORT is not set | |
| 629 | # | ||
| 630 | # Multimedia devices | ||
| 631 | # | ||
| 632 | |||
| 633 | # | ||
| 634 | # Multimedia core support | ||
| 635 | # | ||
| 636 | # CONFIG_VIDEO_DEV is not set | ||
| 637 | # CONFIG_DVB_CORE is not set | ||
| 638 | # CONFIG_VIDEO_MEDIA is not set | ||
| 639 | |||
| 640 | # | ||
| 641 | # Multimedia drivers | ||
| 642 | # | ||
| 643 | # CONFIG_DAB is not set | ||
| 644 | 656 | ||
| 645 | # | 657 | # |
| 646 | # Graphics support | 658 | # Graphics support |
| @@ -665,6 +677,10 @@ CONFIG_SSB_POSSIBLE=y | |||
| 665 | # CONFIG_DMADEVICES is not set | 677 | # CONFIG_DMADEVICES is not set |
| 666 | # CONFIG_AUXDISPLAY is not set | 678 | # CONFIG_AUXDISPLAY is not set |
| 667 | # CONFIG_UIO is not set | 679 | # CONFIG_UIO is not set |
| 680 | |||
| 681 | # | ||
| 682 | # TI VLYNQ | ||
| 683 | # | ||
| 668 | # CONFIG_STAGING is not set | 684 | # CONFIG_STAGING is not set |
| 669 | 685 | ||
| 670 | # | 686 | # |
| @@ -687,10 +703,12 @@ CONFIG_FS_MBCACHE=y | |||
| 687 | # CONFIG_REISERFS_FS is not set | 703 | # CONFIG_REISERFS_FS is not set |
| 688 | # CONFIG_JFS_FS is not set | 704 | # CONFIG_JFS_FS is not set |
| 689 | # CONFIG_FS_POSIX_ACL is not set | 705 | # CONFIG_FS_POSIX_ACL is not set |
| 690 | CONFIG_FILE_LOCKING=y | ||
| 691 | # CONFIG_XFS_FS is not set | 706 | # CONFIG_XFS_FS is not set |
| 707 | # CONFIG_GFS2_FS is not set | ||
| 692 | # CONFIG_OCFS2_FS is not set | 708 | # CONFIG_OCFS2_FS is not set |
| 693 | # CONFIG_BTRFS_FS is not set | 709 | # CONFIG_BTRFS_FS is not set |
| 710 | CONFIG_FILE_LOCKING=y | ||
| 711 | CONFIG_FSNOTIFY=y | ||
| 694 | CONFIG_DNOTIFY=y | 712 | CONFIG_DNOTIFY=y |
| 695 | CONFIG_INOTIFY=y | 713 | CONFIG_INOTIFY=y |
| 696 | CONFIG_INOTIFY_USER=y | 714 | CONFIG_INOTIFY_USER=y |
| @@ -823,6 +841,7 @@ CONFIG_HAS_IOPORT=y | |||
| 823 | CONFIG_HAS_DMA=y | 841 | CONFIG_HAS_DMA=y |
| 824 | CONFIG_HAVE_LMB=y | 842 | CONFIG_HAVE_LMB=y |
| 825 | CONFIG_NLATTR=y | 843 | CONFIG_NLATTR=y |
| 844 | CONFIG_GENERIC_ATOMIC64=y | ||
| 826 | 845 | ||
| 827 | # | 846 | # |
| 828 | # Kernel hacking | 847 | # Kernel hacking |
| @@ -844,24 +863,14 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 844 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 863 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 845 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 864 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 846 | CONFIG_TRACING_SUPPORT=y | 865 | CONFIG_TRACING_SUPPORT=y |
| 847 | 866 | # CONFIG_FTRACE is not set | |
| 848 | # | ||
| 849 | # Tracers | ||
| 850 | # | ||
| 851 | # CONFIG_FUNCTION_TRACER is not set | ||
| 852 | # CONFIG_SCHED_TRACER is not set | ||
| 853 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 854 | # CONFIG_EVENT_TRACER is not set | ||
| 855 | # CONFIG_BOOT_TRACER is not set | ||
| 856 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 857 | # CONFIG_STACK_TRACER is not set | ||
| 858 | # CONFIG_KMEMTRACE is not set | ||
| 859 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 860 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 861 | # CONFIG_DYNAMIC_DEBUG is not set | 867 | # CONFIG_DYNAMIC_DEBUG is not set |
| 862 | # CONFIG_SAMPLES is not set | 868 | # CONFIG_SAMPLES is not set |
| 863 | CONFIG_HAVE_ARCH_KGDB=y | 869 | CONFIG_HAVE_ARCH_KGDB=y |
| 870 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 871 | CONFIG_PPC_WERROR=y | ||
| 864 | CONFIG_PRINT_STACK_DEPTH=64 | 872 | CONFIG_PRINT_STACK_DEPTH=64 |
| 873 | # CONFIG_PPC_EMULATED_STATS is not set | ||
| 865 | # CONFIG_IRQSTACKS is not set | 874 | # CONFIG_IRQSTACKS is not set |
| 866 | # CONFIG_VIRQ_DEBUG is not set | 875 | # CONFIG_VIRQ_DEBUG is not set |
| 867 | # CONFIG_PPC_EARLY_DEBUG is not set | 876 | # CONFIG_PPC_EARLY_DEBUG is not set |
diff --git a/arch/powerpc/configs/mpc7448_hpc2_defconfig b/arch/powerpc/configs/mpc7448_hpc2_defconfig index 642ab67c8431..f23428c3b34e 100644 --- a/arch/powerpc/configs/mpc7448_hpc2_defconfig +++ b/arch/powerpc/configs/mpc7448_hpc2_defconfig | |||
| @@ -1,25 +1,27 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:21:56 2009 | 4 | # Wed Jul 29 23:31:53 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | CONFIG_ALTIVEC=y | 20 | CONFIG_ALTIVEC=y |
| 20 | CONFIG_PPC_STD_MMU=y | 21 | CONFIG_PPC_STD_MMU=y |
| 21 | CONFIG_PPC_STD_MMU_32=y | 22 | CONFIG_PPC_STD_MMU_32=y |
| 22 | # CONFIG_PPC_MM_SLICES is not set | 23 | # CONFIG_PPC_MM_SLICES is not set |
| 24 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 23 | # CONFIG_SMP is not set | 25 | # CONFIG_SMP is not set |
| 24 | CONFIG_PPC32=y | 26 | CONFIG_PPC32=y |
| 25 | CONFIG_WORD_SIZE=32 | 27 | CONFIG_WORD_SIZE=32 |
| @@ -30,15 +32,16 @@ CONFIG_GENERIC_TIME=y | |||
| 30 | CONFIG_GENERIC_TIME_VSYSCALL=y | 32 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 31 | CONFIG_GENERIC_CLOCKEVENTS=y | 33 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 32 | CONFIG_GENERIC_HARDIRQS=y | 34 | CONFIG_GENERIC_HARDIRQS=y |
| 35 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 33 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 36 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 34 | CONFIG_IRQ_PER_CPU=y | 37 | CONFIG_IRQ_PER_CPU=y |
| 35 | CONFIG_STACKTRACE_SUPPORT=y | 38 | CONFIG_STACKTRACE_SUPPORT=y |
| 36 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 39 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 40 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 37 | CONFIG_LOCKDEP_SUPPORT=y | 41 | CONFIG_LOCKDEP_SUPPORT=y |
| 38 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 39 | CONFIG_ARCH_HAS_ILOG2_U32=y | 43 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 40 | CONFIG_GENERIC_HWEIGHT=y | 44 | CONFIG_GENERIC_HWEIGHT=y |
| 41 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 42 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 45 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 43 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 46 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 44 | CONFIG_PPC=y | 47 | CONFIG_PPC=y |
| @@ -52,11 +55,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 52 | # CONFIG_GENERIC_TBSYNC is not set | 55 | # CONFIG_GENERIC_TBSYNC is not set |
| 53 | CONFIG_AUDIT_ARCH=y | 56 | CONFIG_AUDIT_ARCH=y |
| 54 | CONFIG_GENERIC_BUG=y | 57 | CONFIG_GENERIC_BUG=y |
| 58 | CONFIG_DTC=y | ||
| 55 | CONFIG_DEFAULT_UIMAGE=y | 59 | CONFIG_DEFAULT_UIMAGE=y |
| 56 | # CONFIG_PPC_DCR_NATIVE is not set | 60 | # CONFIG_PPC_DCR_NATIVE is not set |
| 57 | # CONFIG_PPC_DCR_MMIO is not set | 61 | # CONFIG_PPC_DCR_MMIO is not set |
| 58 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 62 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 59 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 63 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 64 | CONFIG_CONSTRUCTORS=y | ||
| 60 | 65 | ||
| 61 | # | 66 | # |
| 62 | # General setup | 67 | # General setup |
| @@ -106,7 +111,6 @@ CONFIG_EMBEDDED=y | |||
| 106 | CONFIG_SYSCTL_SYSCALL=y | 111 | CONFIG_SYSCTL_SYSCALL=y |
| 107 | CONFIG_KALLSYMS=y | 112 | CONFIG_KALLSYMS=y |
| 108 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 113 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 109 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 110 | CONFIG_HOTPLUG=y | 114 | CONFIG_HOTPLUG=y |
| 111 | CONFIG_PRINTK=y | 115 | CONFIG_PRINTK=y |
| 112 | CONFIG_BUG=y | 116 | CONFIG_BUG=y |
| @@ -119,9 +123,16 @@ CONFIG_TIMERFD=y | |||
| 119 | CONFIG_EVENTFD=y | 123 | CONFIG_EVENTFD=y |
| 120 | CONFIG_SHMEM=y | 124 | CONFIG_SHMEM=y |
| 121 | CONFIG_AIO=y | 125 | CONFIG_AIO=y |
| 126 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 127 | |||
| 128 | # | ||
| 129 | # Performance Counters | ||
| 130 | # | ||
| 131 | # CONFIG_PERF_COUNTERS is not set | ||
| 122 | CONFIG_VM_EVENT_COUNTERS=y | 132 | CONFIG_VM_EVENT_COUNTERS=y |
| 123 | CONFIG_PCI_QUIRKS=y | 133 | CONFIG_PCI_QUIRKS=y |
| 124 | CONFIG_SLUB_DEBUG=y | 134 | CONFIG_SLUB_DEBUG=y |
| 135 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 125 | CONFIG_COMPAT_BRK=y | 136 | CONFIG_COMPAT_BRK=y |
| 126 | # CONFIG_SLAB is not set | 137 | # CONFIG_SLAB is not set |
| 127 | CONFIG_SLUB=y | 138 | CONFIG_SLUB=y |
| @@ -134,6 +145,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 134 | CONFIG_HAVE_KPROBES=y | 145 | CONFIG_HAVE_KPROBES=y |
| 135 | CONFIG_HAVE_KRETPROBES=y | 146 | CONFIG_HAVE_KRETPROBES=y |
| 136 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 147 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 148 | |||
| 149 | # | ||
| 150 | # GCOV-based kernel profiling | ||
| 151 | # | ||
| 137 | # CONFIG_SLOW_WORK is not set | 152 | # CONFIG_SLOW_WORK is not set |
| 138 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 153 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 139 | CONFIG_SLABINFO=y | 154 | CONFIG_SLABINFO=y |
| @@ -141,7 +156,7 @@ CONFIG_RT_MUTEXES=y | |||
| 141 | CONFIG_BASE_SMALL=0 | 156 | CONFIG_BASE_SMALL=0 |
| 142 | # CONFIG_MODULES is not set | 157 | # CONFIG_MODULES is not set |
| 143 | CONFIG_BLOCK=y | 158 | CONFIG_BLOCK=y |
| 144 | CONFIG_LBD=y | 159 | CONFIG_LBDAF=y |
| 145 | # CONFIG_BLK_DEV_BSG is not set | 160 | # CONFIG_BLK_DEV_BSG is not set |
| 146 | # CONFIG_BLK_DEV_INTEGRITY is not set | 161 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 147 | 162 | ||
| @@ -220,6 +235,7 @@ CONFIG_BINFMT_ELF=y | |||
| 220 | # CONFIG_HAVE_AOUT is not set | 235 | # CONFIG_HAVE_AOUT is not set |
| 221 | CONFIG_BINFMT_MISC=y | 236 | CONFIG_BINFMT_MISC=y |
| 222 | # CONFIG_IOMMU_HELPER is not set | 237 | # CONFIG_IOMMU_HELPER is not set |
| 238 | # CONFIG_SWIOTLB is not set | ||
| 223 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 239 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 224 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 240 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 225 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 241 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -240,9 +256,9 @@ CONFIG_MIGRATION=y | |||
| 240 | CONFIG_ZONE_DMA_FLAG=1 | 256 | CONFIG_ZONE_DMA_FLAG=1 |
| 241 | CONFIG_BOUNCE=y | 257 | CONFIG_BOUNCE=y |
| 242 | CONFIG_VIRT_TO_BUS=y | 258 | CONFIG_VIRT_TO_BUS=y |
| 243 | CONFIG_UNEVICTABLE_LRU=y | ||
| 244 | CONFIG_HAVE_MLOCK=y | 259 | CONFIG_HAVE_MLOCK=y |
| 245 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 260 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 261 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 246 | CONFIG_PPC_4K_PAGES=y | 262 | CONFIG_PPC_4K_PAGES=y |
| 247 | # CONFIG_PPC_16K_PAGES is not set | 263 | # CONFIG_PPC_16K_PAGES is not set |
| 248 | # CONFIG_PPC_64K_PAGES is not set | 264 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -348,6 +364,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 348 | # CONFIG_ECONET is not set | 364 | # CONFIG_ECONET is not set |
| 349 | # CONFIG_WAN_ROUTER is not set | 365 | # CONFIG_WAN_ROUTER is not set |
| 350 | # CONFIG_PHONET is not set | 366 | # CONFIG_PHONET is not set |
| 367 | # CONFIG_IEEE802154 is not set | ||
| 351 | # CONFIG_NET_SCHED is not set | 368 | # CONFIG_NET_SCHED is not set |
| 352 | # CONFIG_DCB is not set | 369 | # CONFIG_DCB is not set |
| 353 | 370 | ||
| @@ -365,7 +382,11 @@ CONFIG_WIRELESS=y | |||
| 365 | CONFIG_WIRELESS_OLD_REGULATORY=y | 382 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 366 | # CONFIG_WIRELESS_EXT is not set | 383 | # CONFIG_WIRELESS_EXT is not set |
| 367 | # CONFIG_LIB80211 is not set | 384 | # CONFIG_LIB80211 is not set |
| 368 | # CONFIG_MAC80211 is not set | 385 | |
| 386 | # | ||
| 387 | # CFG80211 needs to be enabled for MAC80211 | ||
| 388 | # | ||
| 389 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 369 | # CONFIG_WIMAX is not set | 390 | # CONFIG_WIMAX is not set |
| 370 | # CONFIG_RFKILL is not set | 391 | # CONFIG_RFKILL is not set |
| 371 | # CONFIG_NET_9P is not set | 392 | # CONFIG_NET_9P is not set |
| @@ -385,6 +406,7 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 385 | # CONFIG_CONNECTOR is not set | 406 | # CONFIG_CONNECTOR is not set |
| 386 | # CONFIG_MTD is not set | 407 | # CONFIG_MTD is not set |
| 387 | CONFIG_OF_DEVICE=y | 408 | CONFIG_OF_DEVICE=y |
| 409 | CONFIG_OF_MDIO=y | ||
| 388 | # CONFIG_PARPORT is not set | 410 | # CONFIG_PARPORT is not set |
| 389 | CONFIG_BLK_DEV=y | 411 | CONFIG_BLK_DEV=y |
| 390 | # CONFIG_BLK_DEV_FD is not set | 412 | # CONFIG_BLK_DEV_FD is not set |
| @@ -416,6 +438,7 @@ CONFIG_MISC_DEVICES=y | |||
| 416 | # EEPROM support | 438 | # EEPROM support |
| 417 | # | 439 | # |
| 418 | # CONFIG_EEPROM_93CX6 is not set | 440 | # CONFIG_EEPROM_93CX6 is not set |
| 441 | # CONFIG_CB710_CORE is not set | ||
| 419 | CONFIG_HAVE_IDE=y | 442 | CONFIG_HAVE_IDE=y |
| 420 | # CONFIG_IDE is not set | 443 | # CONFIG_IDE is not set |
| 421 | 444 | ||
| @@ -438,10 +461,6 @@ CONFIG_BLK_DEV_SD=y | |||
| 438 | # CONFIG_BLK_DEV_SR is not set | 461 | # CONFIG_BLK_DEV_SR is not set |
| 439 | # CONFIG_CHR_DEV_SG is not set | 462 | # CONFIG_CHR_DEV_SG is not set |
| 440 | # CONFIG_CHR_DEV_SCH is not set | 463 | # CONFIG_CHR_DEV_SCH is not set |
| 441 | |||
| 442 | # | ||
| 443 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 444 | # | ||
| 445 | # CONFIG_SCSI_MULTI_LUN is not set | 464 | # CONFIG_SCSI_MULTI_LUN is not set |
| 446 | # CONFIG_SCSI_CONSTANTS is not set | 465 | # CONFIG_SCSI_CONSTANTS is not set |
| 447 | # CONFIG_SCSI_LOGGING is not set | 466 | # CONFIG_SCSI_LOGGING is not set |
| @@ -458,6 +477,7 @@ CONFIG_BLK_DEV_SD=y | |||
| 458 | CONFIG_SCSI_LOWLEVEL=y | 477 | CONFIG_SCSI_LOWLEVEL=y |
| 459 | # CONFIG_ISCSI_TCP is not set | 478 | # CONFIG_ISCSI_TCP is not set |
| 460 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 479 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 480 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 461 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 481 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 462 | # CONFIG_SCSI_3W_9XXX is not set | 482 | # CONFIG_SCSI_3W_9XXX is not set |
| 463 | # CONFIG_SCSI_ACARD is not set | 483 | # CONFIG_SCSI_ACARD is not set |
| @@ -466,6 +486,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 466 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 486 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 467 | # CONFIG_SCSI_AIC79XX is not set | 487 | # CONFIG_SCSI_AIC79XX is not set |
| 468 | # CONFIG_SCSI_AIC94XX is not set | 488 | # CONFIG_SCSI_AIC94XX is not set |
| 489 | # CONFIG_SCSI_MVSAS is not set | ||
| 469 | # CONFIG_SCSI_DPT_I2O is not set | 490 | # CONFIG_SCSI_DPT_I2O is not set |
| 470 | # CONFIG_SCSI_ADVANSYS is not set | 491 | # CONFIG_SCSI_ADVANSYS is not set |
| 471 | # CONFIG_SCSI_ARCMSR is not set | 492 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -485,7 +506,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 485 | # CONFIG_SCSI_IPS is not set | 506 | # CONFIG_SCSI_IPS is not set |
| 486 | # CONFIG_SCSI_INITIO is not set | 507 | # CONFIG_SCSI_INITIO is not set |
| 487 | # CONFIG_SCSI_INIA100 is not set | 508 | # CONFIG_SCSI_INIA100 is not set |
| 488 | # CONFIG_SCSI_MVSAS is not set | ||
| 489 | # CONFIG_SCSI_STEX is not set | 509 | # CONFIG_SCSI_STEX is not set |
| 490 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 510 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 491 | # CONFIG_SCSI_IPR is not set | 511 | # CONFIG_SCSI_IPR is not set |
| @@ -568,14 +588,17 @@ CONFIG_SATA_MV=y | |||
| 568 | # | 588 | # |
| 569 | 589 | ||
| 570 | # | 590 | # |
| 571 | # Enable only one of the two stacks, unless you know what you are doing | 591 | # You can enable one or both FireWire driver stacks. |
| 592 | # | ||
| 593 | |||
| 594 | # | ||
| 595 | # See the help texts for more information. | ||
| 572 | # | 596 | # |
| 573 | # CONFIG_FIREWIRE is not set | 597 | # CONFIG_FIREWIRE is not set |
| 574 | # CONFIG_IEEE1394 is not set | 598 | # CONFIG_IEEE1394 is not set |
| 575 | # CONFIG_I2O is not set | 599 | # CONFIG_I2O is not set |
| 576 | # CONFIG_MACINTOSH_DRIVERS is not set | 600 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 577 | CONFIG_NETDEVICES=y | 601 | CONFIG_NETDEVICES=y |
| 578 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 579 | # CONFIG_DUMMY is not set | 602 | # CONFIG_DUMMY is not set |
| 580 | # CONFIG_BONDING is not set | 603 | # CONFIG_BONDING is not set |
| 581 | # CONFIG_MACVLAN is not set | 604 | # CONFIG_MACVLAN is not set |
| @@ -642,6 +665,7 @@ CONFIG_8139TOO=y | |||
| 642 | # CONFIG_SMSC9420 is not set | 665 | # CONFIG_SMSC9420 is not set |
| 643 | # CONFIG_SUNDANCE is not set | 666 | # CONFIG_SUNDANCE is not set |
| 644 | # CONFIG_TLAN is not set | 667 | # CONFIG_TLAN is not set |
| 668 | # CONFIG_KS8842 is not set | ||
| 645 | # CONFIG_VIA_RHINE is not set | 669 | # CONFIG_VIA_RHINE is not set |
| 646 | # CONFIG_SC92031 is not set | 670 | # CONFIG_SC92031 is not set |
| 647 | # CONFIG_ATL2 is not set | 671 | # CONFIG_ATL2 is not set |
| @@ -663,7 +687,9 @@ CONFIG_NETDEV_1000=y | |||
| 663 | # CONFIG_VIA_VELOCITY is not set | 687 | # CONFIG_VIA_VELOCITY is not set |
| 664 | # CONFIG_TIGON3 is not set | 688 | # CONFIG_TIGON3 is not set |
| 665 | # CONFIG_BNX2 is not set | 689 | # CONFIG_BNX2 is not set |
| 690 | # CONFIG_CNIC is not set | ||
| 666 | CONFIG_TSI108_ETH=y | 691 | CONFIG_TSI108_ETH=y |
| 692 | # CONFIG_MV643XX_ETH is not set | ||
| 667 | # CONFIG_QLA3XXX is not set | 693 | # CONFIG_QLA3XXX is not set |
| 668 | # CONFIG_ATL1 is not set | 694 | # CONFIG_ATL1 is not set |
| 669 | # CONFIG_ATL1E is not set | 695 | # CONFIG_ATL1E is not set |
| @@ -785,6 +811,11 @@ CONFIG_GEN_RTC=y | |||
| 785 | CONFIG_DEVPORT=y | 811 | CONFIG_DEVPORT=y |
| 786 | # CONFIG_I2C is not set | 812 | # CONFIG_I2C is not set |
| 787 | # CONFIG_SPI is not set | 813 | # CONFIG_SPI is not set |
| 814 | |||
| 815 | # | ||
| 816 | # PPS support | ||
| 817 | # | ||
| 818 | # CONFIG_PPS is not set | ||
| 788 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 819 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 789 | # CONFIG_GPIOLIB is not set | 820 | # CONFIG_GPIOLIB is not set |
| 790 | # CONFIG_W1 is not set | 821 | # CONFIG_W1 is not set |
| @@ -824,22 +855,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 824 | # CONFIG_HTC_PASIC3 is not set | 855 | # CONFIG_HTC_PASIC3 is not set |
| 825 | # CONFIG_MFD_TMIO is not set | 856 | # CONFIG_MFD_TMIO is not set |
| 826 | # CONFIG_REGULATOR is not set | 857 | # CONFIG_REGULATOR is not set |
| 827 | 858 | # CONFIG_MEDIA_SUPPORT is not set | |
| 828 | # | ||
| 829 | # Multimedia devices | ||
| 830 | # | ||
| 831 | |||
| 832 | # | ||
| 833 | # Multimedia core support | ||
| 834 | # | ||
| 835 | # CONFIG_VIDEO_DEV is not set | ||
| 836 | # CONFIG_DVB_CORE is not set | ||
| 837 | # CONFIG_VIDEO_MEDIA is not set | ||
| 838 | |||
| 839 | # | ||
| 840 | # Multimedia drivers | ||
| 841 | # | ||
| 842 | CONFIG_DAB=y | ||
| 843 | 859 | ||
| 844 | # | 860 | # |
| 845 | # Graphics support | 861 | # Graphics support |
| @@ -896,6 +912,10 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
| 896 | # CONFIG_DMADEVICES is not set | 912 | # CONFIG_DMADEVICES is not set |
| 897 | # CONFIG_AUXDISPLAY is not set | 913 | # CONFIG_AUXDISPLAY is not set |
| 898 | # CONFIG_UIO is not set | 914 | # CONFIG_UIO is not set |
| 915 | |||
| 916 | # | ||
| 917 | # TI VLYNQ | ||
| 918 | # | ||
| 899 | # CONFIG_STAGING is not set | 919 | # CONFIG_STAGING is not set |
| 900 | 920 | ||
| 901 | # | 921 | # |
| @@ -915,11 +935,12 @@ CONFIG_FS_MBCACHE=y | |||
| 915 | # CONFIG_REISERFS_FS is not set | 935 | # CONFIG_REISERFS_FS is not set |
| 916 | # CONFIG_JFS_FS is not set | 936 | # CONFIG_JFS_FS is not set |
| 917 | # CONFIG_FS_POSIX_ACL is not set | 937 | # CONFIG_FS_POSIX_ACL is not set |
| 918 | CONFIG_FILE_LOCKING=y | ||
| 919 | # CONFIG_XFS_FS is not set | 938 | # CONFIG_XFS_FS is not set |
| 920 | # CONFIG_GFS2_FS is not set | 939 | # CONFIG_GFS2_FS is not set |
| 921 | # CONFIG_OCFS2_FS is not set | 940 | # CONFIG_OCFS2_FS is not set |
| 922 | # CONFIG_BTRFS_FS is not set | 941 | # CONFIG_BTRFS_FS is not set |
| 942 | CONFIG_FILE_LOCKING=y | ||
| 943 | CONFIG_FSNOTIFY=y | ||
| 923 | CONFIG_DNOTIFY=y | 944 | CONFIG_DNOTIFY=y |
| 924 | CONFIG_INOTIFY=y | 945 | CONFIG_INOTIFY=y |
| 925 | CONFIG_INOTIFY_USER=y | 946 | CONFIG_INOTIFY_USER=y |
| @@ -1038,6 +1059,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1038 | CONFIG_HAS_DMA=y | 1059 | CONFIG_HAS_DMA=y |
| 1039 | CONFIG_HAVE_LMB=y | 1060 | CONFIG_HAVE_LMB=y |
| 1040 | CONFIG_NLATTR=y | 1061 | CONFIG_NLATTR=y |
| 1062 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1041 | 1063 | ||
| 1042 | # | 1064 | # |
| 1043 | # Kernel hacking | 1065 | # Kernel hacking |
| @@ -1063,22 +1085,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1063 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1085 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1064 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1086 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1065 | CONFIG_TRACING_SUPPORT=y | 1087 | CONFIG_TRACING_SUPPORT=y |
| 1066 | 1088 | # CONFIG_FTRACE is not set | |
| 1067 | # | ||
| 1068 | # Tracers | ||
| 1069 | # | ||
| 1070 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1071 | # CONFIG_SCHED_TRACER is not set | ||
| 1072 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1073 | # CONFIG_EVENT_TRACER is not set | ||
| 1074 | # CONFIG_BOOT_TRACER is not set | ||
| 1075 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1076 | # CONFIG_STACK_TRACER is not set | ||
| 1077 | # CONFIG_KMEMTRACE is not set | ||
| 1078 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1079 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1080 | # CONFIG_SAMPLES is not set | 1089 | # CONFIG_SAMPLES is not set |
| 1081 | CONFIG_HAVE_ARCH_KGDB=y | 1090 | CONFIG_HAVE_ARCH_KGDB=y |
| 1091 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1092 | CONFIG_PPC_WERROR=y | ||
| 1082 | CONFIG_PRINT_STACK_DEPTH=64 | 1093 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1083 | # CONFIG_IRQSTACKS is not set | 1094 | # CONFIG_IRQSTACKS is not set |
| 1084 | # CONFIG_BOOTX_TEXT is not set | 1095 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/mpc8272_ads_defconfig b/arch/powerpc/configs/mpc8272_ads_defconfig index cb966ca2ce89..02716f72db6f 100644 --- a/arch/powerpc/configs/mpc8272_ads_defconfig +++ b/arch/powerpc/configs/mpc8272_ads_defconfig | |||
| @@ -1,25 +1,27 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:21:57 2009 | 4 | # Wed Jul 29 23:31:54 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_ALTIVEC is not set | 20 | # CONFIG_ALTIVEC is not set |
| 20 | CONFIG_PPC_STD_MMU=y | 21 | CONFIG_PPC_STD_MMU=y |
| 21 | CONFIG_PPC_STD_MMU_32=y | 22 | CONFIG_PPC_STD_MMU_32=y |
| 22 | # CONFIG_PPC_MM_SLICES is not set | 23 | # CONFIG_PPC_MM_SLICES is not set |
| 24 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 23 | # CONFIG_SMP is not set | 25 | # CONFIG_SMP is not set |
| 24 | CONFIG_PPC32=y | 26 | CONFIG_PPC32=y |
| 25 | CONFIG_WORD_SIZE=32 | 27 | CONFIG_WORD_SIZE=32 |
| @@ -30,15 +32,16 @@ CONFIG_GENERIC_TIME=y | |||
| 30 | CONFIG_GENERIC_TIME_VSYSCALL=y | 32 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 31 | CONFIG_GENERIC_CLOCKEVENTS=y | 33 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 32 | CONFIG_GENERIC_HARDIRQS=y | 34 | CONFIG_GENERIC_HARDIRQS=y |
| 35 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 33 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 36 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 34 | CONFIG_IRQ_PER_CPU=y | 37 | CONFIG_IRQ_PER_CPU=y |
| 35 | CONFIG_STACKTRACE_SUPPORT=y | 38 | CONFIG_STACKTRACE_SUPPORT=y |
| 36 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 39 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 40 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 37 | CONFIG_LOCKDEP_SUPPORT=y | 41 | CONFIG_LOCKDEP_SUPPORT=y |
| 38 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 39 | CONFIG_ARCH_HAS_ILOG2_U32=y | 43 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 40 | CONFIG_GENERIC_HWEIGHT=y | 44 | CONFIG_GENERIC_HWEIGHT=y |
| 41 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 42 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 45 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 43 | CONFIG_GENERIC_GPIO=y | 46 | CONFIG_GENERIC_GPIO=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -53,11 +56,13 @@ CONFIG_OF=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 57 | # CONFIG_PPC_DCR_NATIVE is not set | 61 | # CONFIG_PPC_DCR_NATIVE is not set |
| 58 | # CONFIG_PPC_DCR_MMIO is not set | 62 | # CONFIG_PPC_DCR_MMIO is not set |
| 59 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 63 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 60 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 64 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 65 | CONFIG_CONSTRUCTORS=y | ||
| 61 | 66 | ||
| 62 | # | 67 | # |
| 63 | # General setup | 68 | # General setup |
| @@ -99,7 +104,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 99 | CONFIG_KALLSYMS=y | 104 | CONFIG_KALLSYMS=y |
| 100 | CONFIG_KALLSYMS_ALL=y | 105 | CONFIG_KALLSYMS_ALL=y |
| 101 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 106 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 102 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 103 | CONFIG_HOTPLUG=y | 107 | CONFIG_HOTPLUG=y |
| 104 | CONFIG_PRINTK=y | 108 | CONFIG_PRINTK=y |
| 105 | CONFIG_BUG=y | 109 | CONFIG_BUG=y |
| @@ -112,9 +116,16 @@ CONFIG_TIMERFD=y | |||
| 112 | CONFIG_EVENTFD=y | 116 | CONFIG_EVENTFD=y |
| 113 | CONFIG_SHMEM=y | 117 | CONFIG_SHMEM=y |
| 114 | CONFIG_AIO=y | 118 | CONFIG_AIO=y |
| 119 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 120 | |||
| 121 | # | ||
| 122 | # Performance Counters | ||
| 123 | # | ||
| 124 | # CONFIG_PERF_COUNTERS is not set | ||
| 115 | CONFIG_VM_EVENT_COUNTERS=y | 125 | CONFIG_VM_EVENT_COUNTERS=y |
| 116 | CONFIG_PCI_QUIRKS=y | 126 | CONFIG_PCI_QUIRKS=y |
| 117 | CONFIG_SLUB_DEBUG=y | 127 | CONFIG_SLUB_DEBUG=y |
| 128 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 118 | CONFIG_COMPAT_BRK=y | 129 | CONFIG_COMPAT_BRK=y |
| 119 | # CONFIG_SLAB is not set | 130 | # CONFIG_SLAB is not set |
| 120 | CONFIG_SLUB=y | 131 | CONFIG_SLUB=y |
| @@ -128,6 +139,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 128 | CONFIG_HAVE_KRETPROBES=y | 139 | CONFIG_HAVE_KRETPROBES=y |
| 129 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 140 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 130 | CONFIG_HAVE_CLK=y | 141 | CONFIG_HAVE_CLK=y |
| 142 | |||
| 143 | # | ||
| 144 | # GCOV-based kernel profiling | ||
| 145 | # | ||
| 131 | # CONFIG_SLOW_WORK is not set | 146 | # CONFIG_SLOW_WORK is not set |
| 132 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 147 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 133 | CONFIG_SLABINFO=y | 148 | CONFIG_SLABINFO=y |
| @@ -135,7 +150,7 @@ CONFIG_RT_MUTEXES=y | |||
| 135 | CONFIG_BASE_SMALL=0 | 150 | CONFIG_BASE_SMALL=0 |
| 136 | # CONFIG_MODULES is not set | 151 | # CONFIG_MODULES is not set |
| 137 | CONFIG_BLOCK=y | 152 | CONFIG_BLOCK=y |
| 138 | # CONFIG_LBD is not set | 153 | CONFIG_LBDAF=y |
| 139 | # CONFIG_BLK_DEV_INTEGRITY is not set | 154 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 140 | 155 | ||
| 141 | # | 156 | # |
| @@ -216,6 +231,7 @@ CONFIG_BINFMT_ELF=y | |||
| 216 | # CONFIG_HAVE_AOUT is not set | 231 | # CONFIG_HAVE_AOUT is not set |
| 217 | CONFIG_BINFMT_MISC=y | 232 | CONFIG_BINFMT_MISC=y |
| 218 | # CONFIG_IOMMU_HELPER is not set | 233 | # CONFIG_IOMMU_HELPER is not set |
| 234 | # CONFIG_SWIOTLB is not set | ||
| 219 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 235 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 220 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 236 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 221 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 237 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -231,9 +247,9 @@ CONFIG_MIGRATION=y | |||
| 231 | CONFIG_ZONE_DMA_FLAG=1 | 247 | CONFIG_ZONE_DMA_FLAG=1 |
| 232 | CONFIG_BOUNCE=y | 248 | CONFIG_BOUNCE=y |
| 233 | CONFIG_VIRT_TO_BUS=y | 249 | CONFIG_VIRT_TO_BUS=y |
| 234 | CONFIG_UNEVICTABLE_LRU=y | ||
| 235 | CONFIG_HAVE_MLOCK=y | 250 | CONFIG_HAVE_MLOCK=y |
| 236 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 251 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 252 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 237 | CONFIG_PPC_4K_PAGES=y | 253 | CONFIG_PPC_4K_PAGES=y |
| 238 | # CONFIG_PPC_16K_PAGES is not set | 254 | # CONFIG_PPC_16K_PAGES is not set |
| 239 | # CONFIG_PPC_64K_PAGES is not set | 255 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -303,6 +319,7 @@ CONFIG_IP_PNP_BOOTP=y | |||
| 303 | # CONFIG_NET_IPIP is not set | 319 | # CONFIG_NET_IPIP is not set |
| 304 | # CONFIG_NET_IPGRE is not set | 320 | # CONFIG_NET_IPGRE is not set |
| 305 | # CONFIG_IP_MROUTE is not set | 321 | # CONFIG_IP_MROUTE is not set |
| 322 | # CONFIG_ARPD is not set | ||
| 306 | CONFIG_SYN_COOKIES=y | 323 | CONFIG_SYN_COOKIES=y |
| 307 | # CONFIG_INET_AH is not set | 324 | # CONFIG_INET_AH is not set |
| 308 | # CONFIG_INET_ESP is not set | 325 | # CONFIG_INET_ESP is not set |
| @@ -383,7 +400,11 @@ CONFIG_WIRELESS=y | |||
| 383 | CONFIG_WIRELESS_OLD_REGULATORY=y | 400 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 384 | # CONFIG_WIRELESS_EXT is not set | 401 | # CONFIG_WIRELESS_EXT is not set |
| 385 | # CONFIG_LIB80211 is not set | 402 | # CONFIG_LIB80211 is not set |
| 386 | # CONFIG_MAC80211 is not set | 403 | |
| 404 | # | ||
| 405 | # CFG80211 needs to be enabled for MAC80211 | ||
| 406 | # | ||
| 407 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 387 | # CONFIG_WIMAX is not set | 408 | # CONFIG_WIMAX is not set |
| 388 | # CONFIG_RFKILL is not set | 409 | # CONFIG_RFKILL is not set |
| 389 | 410 | ||
| @@ -489,6 +510,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 489 | # CONFIG_MTD_UBI is not set | 510 | # CONFIG_MTD_UBI is not set |
| 490 | CONFIG_OF_DEVICE=y | 511 | CONFIG_OF_DEVICE=y |
| 491 | CONFIG_OF_GPIO=y | 512 | CONFIG_OF_GPIO=y |
| 513 | CONFIG_OF_MDIO=y | ||
| 492 | # CONFIG_PARPORT is not set | 514 | # CONFIG_PARPORT is not set |
| 493 | CONFIG_BLK_DEV=y | 515 | CONFIG_BLK_DEV=y |
| 494 | # CONFIG_BLK_DEV_FD is not set | 516 | # CONFIG_BLK_DEV_FD is not set |
| @@ -524,13 +546,17 @@ CONFIG_HAVE_IDE=y | |||
| 524 | # | 546 | # |
| 525 | 547 | ||
| 526 | # | 548 | # |
| 527 | # A new alternative FireWire stack is available with EXPERIMENTAL=y | 549 | # You can enable one or both FireWire driver stacks. |
| 550 | # | ||
| 551 | |||
| 552 | # | ||
| 553 | # See the help texts for more information. | ||
| 528 | # | 554 | # |
| 555 | # CONFIG_FIREWIRE is not set | ||
| 529 | # CONFIG_IEEE1394 is not set | 556 | # CONFIG_IEEE1394 is not set |
| 530 | # CONFIG_I2O is not set | 557 | # CONFIG_I2O is not set |
| 531 | # CONFIG_MACINTOSH_DRIVERS is not set | 558 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 532 | CONFIG_NETDEVICES=y | 559 | CONFIG_NETDEVICES=y |
| 533 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 534 | # CONFIG_DUMMY is not set | 560 | # CONFIG_DUMMY is not set |
| 535 | # CONFIG_BONDING is not set | 561 | # CONFIG_BONDING is not set |
| 536 | # CONFIG_EQUALIZER is not set | 562 | # CONFIG_EQUALIZER is not set |
| @@ -577,6 +603,7 @@ CONFIG_MII=y | |||
| 577 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 603 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 578 | # CONFIG_NET_PCI is not set | 604 | # CONFIG_NET_PCI is not set |
| 579 | # CONFIG_B44 is not set | 605 | # CONFIG_B44 is not set |
| 606 | # CONFIG_KS8842 is not set | ||
| 580 | # CONFIG_ATL2 is not set | 607 | # CONFIG_ATL2 is not set |
| 581 | CONFIG_FS_ENET=y | 608 | CONFIG_FS_ENET=y |
| 582 | # CONFIG_FS_ENET_HAS_SCC is not set | 609 | # CONFIG_FS_ENET_HAS_SCC is not set |
| @@ -598,8 +625,10 @@ CONFIG_NETDEV_1000=y | |||
| 598 | # CONFIG_VIA_VELOCITY is not set | 625 | # CONFIG_VIA_VELOCITY is not set |
| 599 | # CONFIG_TIGON3 is not set | 626 | # CONFIG_TIGON3 is not set |
| 600 | # CONFIG_BNX2 is not set | 627 | # CONFIG_BNX2 is not set |
| 628 | # CONFIG_CNIC is not set | ||
| 601 | # CONFIG_FSL_PQ_MDIO is not set | 629 | # CONFIG_FSL_PQ_MDIO is not set |
| 602 | # CONFIG_GIANFAR is not set | 630 | # CONFIG_GIANFAR is not set |
| 631 | # CONFIG_MV643XX_ETH is not set | ||
| 603 | # CONFIG_QLA3XXX is not set | 632 | # CONFIG_QLA3XXX is not set |
| 604 | # CONFIG_ATL1 is not set | 633 | # CONFIG_ATL1 is not set |
| 605 | # CONFIG_JME is not set | 634 | # CONFIG_JME is not set |
| @@ -671,12 +700,13 @@ CONFIG_INPUT_EVDEV=y | |||
| 671 | # | 700 | # |
| 672 | CONFIG_INPUT_KEYBOARD=y | 701 | CONFIG_INPUT_KEYBOARD=y |
| 673 | CONFIG_KEYBOARD_ATKBD=y | 702 | CONFIG_KEYBOARD_ATKBD=y |
| 674 | # CONFIG_KEYBOARD_SUNKBD is not set | ||
| 675 | # CONFIG_KEYBOARD_LKKBD is not set | 703 | # CONFIG_KEYBOARD_LKKBD is not set |
| 676 | # CONFIG_KEYBOARD_XTKBD is not set | 704 | # CONFIG_KEYBOARD_GPIO is not set |
| 705 | # CONFIG_KEYBOARD_MATRIX is not set | ||
| 677 | # CONFIG_KEYBOARD_NEWTON is not set | 706 | # CONFIG_KEYBOARD_NEWTON is not set |
| 678 | # CONFIG_KEYBOARD_STOWAWAY is not set | 707 | # CONFIG_KEYBOARD_STOWAWAY is not set |
| 679 | # CONFIG_KEYBOARD_GPIO is not set | 708 | # CONFIG_KEYBOARD_SUNKBD is not set |
| 709 | # CONFIG_KEYBOARD_XTKBD is not set | ||
| 680 | CONFIG_INPUT_MOUSE=y | 710 | CONFIG_INPUT_MOUSE=y |
| 681 | CONFIG_MOUSE_PS2=y | 711 | CONFIG_MOUSE_PS2=y |
| 682 | CONFIG_MOUSE_PS2_ALPS=y | 712 | CONFIG_MOUSE_PS2_ALPS=y |
| @@ -741,6 +771,10 @@ CONFIG_HW_RANDOM=y | |||
| 741 | CONFIG_DEVPORT=y | 771 | CONFIG_DEVPORT=y |
| 742 | # CONFIG_I2C is not set | 772 | # CONFIG_I2C is not set |
| 743 | # CONFIG_SPI is not set | 773 | # CONFIG_SPI is not set |
| 774 | |||
| 775 | # | ||
| 776 | # PPS support | ||
| 777 | # | ||
| 744 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 778 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 745 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 779 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 746 | CONFIG_GPIOLIB=y | 780 | CONFIG_GPIOLIB=y |
| @@ -784,22 +818,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 784 | # CONFIG_HTC_PASIC3 is not set | 818 | # CONFIG_HTC_PASIC3 is not set |
| 785 | # CONFIG_MFD_TMIO is not set | 819 | # CONFIG_MFD_TMIO is not set |
| 786 | # CONFIG_REGULATOR is not set | 820 | # CONFIG_REGULATOR is not set |
| 787 | 821 | # CONFIG_MEDIA_SUPPORT is not set | |
| 788 | # | ||
| 789 | # Multimedia devices | ||
| 790 | # | ||
| 791 | |||
| 792 | # | ||
| 793 | # Multimedia core support | ||
| 794 | # | ||
| 795 | # CONFIG_VIDEO_DEV is not set | ||
| 796 | # CONFIG_DVB_CORE is not set | ||
| 797 | # CONFIG_VIDEO_MEDIA is not set | ||
| 798 | |||
| 799 | # | ||
| 800 | # Multimedia drivers | ||
| 801 | # | ||
| 802 | CONFIG_DAB=y | ||
| 803 | 822 | ||
| 804 | # | 823 | # |
| 805 | # Graphics support | 824 | # Graphics support |
| @@ -828,6 +847,10 @@ CONFIG_DAB=y | |||
| 828 | # CONFIG_DMADEVICES is not set | 847 | # CONFIG_DMADEVICES is not set |
| 829 | # CONFIG_AUXDISPLAY is not set | 848 | # CONFIG_AUXDISPLAY is not set |
| 830 | # CONFIG_UIO is not set | 849 | # CONFIG_UIO is not set |
| 850 | |||
| 851 | # | ||
| 852 | # TI VLYNQ | ||
| 853 | # | ||
| 831 | # CONFIG_STAGING is not set | 854 | # CONFIG_STAGING is not set |
| 832 | 855 | ||
| 833 | # | 856 | # |
| @@ -847,9 +870,10 @@ CONFIG_FS_MBCACHE=y | |||
| 847 | # CONFIG_REISERFS_FS is not set | 870 | # CONFIG_REISERFS_FS is not set |
| 848 | # CONFIG_JFS_FS is not set | 871 | # CONFIG_JFS_FS is not set |
| 849 | CONFIG_FS_POSIX_ACL=y | 872 | CONFIG_FS_POSIX_ACL=y |
| 850 | CONFIG_FILE_LOCKING=y | ||
| 851 | # CONFIG_XFS_FS is not set | 873 | # CONFIG_XFS_FS is not set |
| 852 | # CONFIG_OCFS2_FS is not set | 874 | # CONFIG_OCFS2_FS is not set |
| 875 | CONFIG_FILE_LOCKING=y | ||
| 876 | CONFIG_FSNOTIFY=y | ||
| 853 | CONFIG_DNOTIFY=y | 877 | CONFIG_DNOTIFY=y |
| 854 | CONFIG_INOTIFY=y | 878 | CONFIG_INOTIFY=y |
| 855 | CONFIG_INOTIFY_USER=y | 879 | CONFIG_INOTIFY_USER=y |
| @@ -998,6 +1022,7 @@ CONFIG_HAS_IOPORT=y | |||
| 998 | CONFIG_HAS_DMA=y | 1022 | CONFIG_HAS_DMA=y |
| 999 | CONFIG_HAVE_LMB=y | 1023 | CONFIG_HAVE_LMB=y |
| 1000 | CONFIG_NLATTR=y | 1024 | CONFIG_NLATTR=y |
| 1025 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1001 | 1026 | ||
| 1002 | # | 1027 | # |
| 1003 | # Kernel hacking | 1028 | # Kernel hacking |
| @@ -1028,6 +1053,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 1028 | # CONFIG_RT_MUTEX_TESTER is not set | 1053 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1029 | # CONFIG_DEBUG_SPINLOCK is not set | 1054 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1030 | # CONFIG_DEBUG_MUTEXES is not set | 1055 | # CONFIG_DEBUG_MUTEXES is not set |
| 1056 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1057 | # CONFIG_PROVE_LOCKING is not set | ||
| 1058 | # CONFIG_LOCK_STAT is not set | ||
| 1031 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1059 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1032 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1060 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1033 | # CONFIG_DEBUG_KOBJECT is not set | 1061 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1039,7 +1067,6 @@ CONFIG_DEBUG_INFO=y | |||
| 1039 | # CONFIG_DEBUG_LIST is not set | 1067 | # CONFIG_DEBUG_LIST is not set |
| 1040 | # CONFIG_DEBUG_SG is not set | 1068 | # CONFIG_DEBUG_SG is not set |
| 1041 | # CONFIG_DEBUG_NOTIFIERS is not set | 1069 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1042 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1043 | # CONFIG_RCU_TORTURE_TEST is not set | 1070 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1044 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1071 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1045 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1072 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1053,22 +1080,23 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1053 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1080 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1054 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1081 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1055 | CONFIG_TRACING_SUPPORT=y | 1082 | CONFIG_TRACING_SUPPORT=y |
| 1056 | 1083 | CONFIG_FTRACE=y | |
| 1057 | # | ||
| 1058 | # Tracers | ||
| 1059 | # | ||
| 1060 | # CONFIG_FUNCTION_TRACER is not set | 1084 | # CONFIG_FUNCTION_TRACER is not set |
| 1085 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1061 | # CONFIG_SCHED_TRACER is not set | 1086 | # CONFIG_SCHED_TRACER is not set |
| 1062 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1087 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1063 | # CONFIG_EVENT_TRACER is not set | ||
| 1064 | # CONFIG_BOOT_TRACER is not set | 1088 | # CONFIG_BOOT_TRACER is not set |
| 1065 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1089 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1090 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1091 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1066 | # CONFIG_STACK_TRACER is not set | 1092 | # CONFIG_STACK_TRACER is not set |
| 1067 | # CONFIG_KMEMTRACE is not set | 1093 | # CONFIG_KMEMTRACE is not set |
| 1068 | # CONFIG_WORKQUEUE_TRACER is not set | 1094 | # CONFIG_WORKQUEUE_TRACER is not set |
| 1069 | # CONFIG_BLK_DEV_IO_TRACE is not set | 1095 | # CONFIG_BLK_DEV_IO_TRACE is not set |
| 1070 | # CONFIG_SAMPLES is not set | 1096 | # CONFIG_SAMPLES is not set |
| 1071 | CONFIG_HAVE_ARCH_KGDB=y | 1097 | CONFIG_HAVE_ARCH_KGDB=y |
| 1098 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1099 | CONFIG_PPC_WERROR=y | ||
| 1072 | CONFIG_PRINT_STACK_DEPTH=64 | 1100 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1073 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1101 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1074 | # CONFIG_DEBUG_STACK_USAGE is not set | 1102 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/mpc83xx_defconfig b/arch/powerpc/configs/mpc83xx_defconfig index 433c303eb82b..4a96cb6925b4 100644 --- a/arch/powerpc/configs/mpc83xx_defconfig +++ b/arch/powerpc/configs/mpc83xx_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:21:58 2009 | 4 | # Wed Jul 29 23:31:55 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_FSL_EMB_PERFMON is not set | 20 | # CONFIG_FSL_EMB_PERFMON is not set |
| 20 | # CONFIG_ALTIVEC is not set | 21 | # CONFIG_ALTIVEC is not set |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | # CONFIG_SMP is not set | 26 | # CONFIG_SMP is not set |
| 25 | CONFIG_PPC32=y | 27 | CONFIG_PPC32=y |
| 26 | CONFIG_WORD_SIZE=32 | 28 | CONFIG_WORD_SIZE=32 |
| @@ -31,15 +33,16 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| 37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 41 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 38 | CONFIG_LOCKDEP_SUPPORT=y | 42 | CONFIG_LOCKDEP_SUPPORT=y |
| 39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 40 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 41 | CONFIG_GENERIC_HWEIGHT=y | 45 | CONFIG_GENERIC_HWEIGHT=y |
| 42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 44 | CONFIG_GENERIC_GPIO=y | 47 | CONFIG_GENERIC_GPIO=y |
| 45 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -54,6 +57,7 @@ CONFIG_PPC_UDBG_16550=y | |||
| 54 | # CONFIG_GENERIC_TBSYNC is not set | 57 | # CONFIG_GENERIC_TBSYNC is not set |
| 55 | CONFIG_AUDIT_ARCH=y | 58 | CONFIG_AUDIT_ARCH=y |
| 56 | CONFIG_GENERIC_BUG=y | 59 | CONFIG_GENERIC_BUG=y |
| 60 | CONFIG_DTC=y | ||
| 57 | CONFIG_DEFAULT_UIMAGE=y | 61 | CONFIG_DEFAULT_UIMAGE=y |
| 58 | CONFIG_REDBOOT=y | 62 | CONFIG_REDBOOT=y |
| 59 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 63 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| @@ -61,6 +65,7 @@ CONFIG_ARCH_SUSPEND_POSSIBLE=y | |||
| 61 | # CONFIG_PPC_DCR_MMIO is not set | 65 | # CONFIG_PPC_DCR_MMIO is not set |
| 62 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 66 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 63 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 67 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 68 | CONFIG_CONSTRUCTORS=y | ||
| 64 | 69 | ||
| 65 | # | 70 | # |
| 66 | # General setup | 71 | # General setup |
| @@ -110,7 +115,6 @@ CONFIG_EMBEDDED=y | |||
| 110 | CONFIG_SYSCTL_SYSCALL=y | 115 | CONFIG_SYSCTL_SYSCALL=y |
| 111 | CONFIG_KALLSYMS=y | 116 | CONFIG_KALLSYMS=y |
| 112 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 117 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 113 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 114 | CONFIG_HOTPLUG=y | 118 | CONFIG_HOTPLUG=y |
| 115 | CONFIG_PRINTK=y | 119 | CONFIG_PRINTK=y |
| 116 | CONFIG_BUG=y | 120 | CONFIG_BUG=y |
| @@ -123,8 +127,15 @@ CONFIG_TIMERFD=y | |||
| 123 | CONFIG_EVENTFD=y | 127 | CONFIG_EVENTFD=y |
| 124 | CONFIG_SHMEM=y | 128 | CONFIG_SHMEM=y |
| 125 | CONFIG_AIO=y | 129 | CONFIG_AIO=y |
| 130 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 131 | |||
| 132 | # | ||
| 133 | # Performance Counters | ||
| 134 | # | ||
| 135 | # CONFIG_PERF_COUNTERS is not set | ||
| 126 | CONFIG_VM_EVENT_COUNTERS=y | 136 | CONFIG_VM_EVENT_COUNTERS=y |
| 127 | CONFIG_PCI_QUIRKS=y | 137 | CONFIG_PCI_QUIRKS=y |
| 138 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 128 | CONFIG_COMPAT_BRK=y | 139 | CONFIG_COMPAT_BRK=y |
| 129 | CONFIG_SLAB=y | 140 | CONFIG_SLAB=y |
| 130 | # CONFIG_SLUB is not set | 141 | # CONFIG_SLUB is not set |
| @@ -138,6 +149,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 138 | CONFIG_HAVE_KPROBES=y | 149 | CONFIG_HAVE_KPROBES=y |
| 139 | CONFIG_HAVE_KRETPROBES=y | 150 | CONFIG_HAVE_KRETPROBES=y |
| 140 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 151 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 152 | |||
| 153 | # | ||
| 154 | # GCOV-based kernel profiling | ||
| 155 | # | ||
| 141 | # CONFIG_SLOW_WORK is not set | 156 | # CONFIG_SLOW_WORK is not set |
| 142 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 157 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 143 | CONFIG_SLABINFO=y | 158 | CONFIG_SLABINFO=y |
| @@ -150,7 +165,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 150 | # CONFIG_MODVERSIONS is not set | 165 | # CONFIG_MODVERSIONS is not set |
| 151 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 166 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 152 | CONFIG_BLOCK=y | 167 | CONFIG_BLOCK=y |
| 153 | # CONFIG_LBD is not set | 168 | CONFIG_LBDAF=y |
| 154 | # CONFIG_BLK_DEV_BSG is not set | 169 | # CONFIG_BLK_DEV_BSG is not set |
| 155 | # CONFIG_BLK_DEV_INTEGRITY is not set | 170 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 156 | 171 | ||
| @@ -192,6 +207,7 @@ CONFIG_MPC837x_MDS=y | |||
| 192 | CONFIG_MPC837x_RDB=y | 207 | CONFIG_MPC837x_RDB=y |
| 193 | CONFIG_SBC834x=y | 208 | CONFIG_SBC834x=y |
| 194 | CONFIG_ASP834x=y | 209 | CONFIG_ASP834x=y |
| 210 | # CONFIG_KMETER1 is not set | ||
| 195 | CONFIG_PPC_MPC831x=y | 211 | CONFIG_PPC_MPC831x=y |
| 196 | CONFIG_PPC_MPC832x=y | 212 | CONFIG_PPC_MPC832x=y |
| 197 | CONFIG_PPC_MPC834x=y | 213 | CONFIG_PPC_MPC834x=y |
| @@ -241,6 +257,7 @@ CONFIG_BINFMT_ELF=y | |||
| 241 | # CONFIG_BINFMT_MISC is not set | 257 | # CONFIG_BINFMT_MISC is not set |
| 242 | CONFIG_MATH_EMULATION=y | 258 | CONFIG_MATH_EMULATION=y |
| 243 | # CONFIG_IOMMU_HELPER is not set | 259 | # CONFIG_IOMMU_HELPER is not set |
| 260 | # CONFIG_SWIOTLB is not set | ||
| 244 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 261 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 245 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 262 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 246 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 263 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -261,9 +278,9 @@ CONFIG_MIGRATION=y | |||
| 261 | CONFIG_ZONE_DMA_FLAG=1 | 278 | CONFIG_ZONE_DMA_FLAG=1 |
| 262 | CONFIG_BOUNCE=y | 279 | CONFIG_BOUNCE=y |
| 263 | CONFIG_VIRT_TO_BUS=y | 280 | CONFIG_VIRT_TO_BUS=y |
| 264 | CONFIG_UNEVICTABLE_LRU=y | ||
| 265 | CONFIG_HAVE_MLOCK=y | 281 | CONFIG_HAVE_MLOCK=y |
| 266 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 282 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 283 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 267 | CONFIG_PPC_4K_PAGES=y | 284 | CONFIG_PPC_4K_PAGES=y |
| 268 | # CONFIG_PPC_16K_PAGES is not set | 285 | # CONFIG_PPC_16K_PAGES is not set |
| 269 | # CONFIG_PPC_64K_PAGES is not set | 286 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -374,6 +391,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 374 | # CONFIG_ECONET is not set | 391 | # CONFIG_ECONET is not set |
| 375 | # CONFIG_WAN_ROUTER is not set | 392 | # CONFIG_WAN_ROUTER is not set |
| 376 | # CONFIG_PHONET is not set | 393 | # CONFIG_PHONET is not set |
| 394 | # CONFIG_IEEE802154 is not set | ||
| 377 | # CONFIG_NET_SCHED is not set | 395 | # CONFIG_NET_SCHED is not set |
| 378 | # CONFIG_DCB is not set | 396 | # CONFIG_DCB is not set |
| 379 | 397 | ||
| @@ -391,7 +409,11 @@ CONFIG_WIRELESS=y | |||
| 391 | CONFIG_WIRELESS_OLD_REGULATORY=y | 409 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 392 | # CONFIG_WIRELESS_EXT is not set | 410 | # CONFIG_WIRELESS_EXT is not set |
| 393 | # CONFIG_LIB80211 is not set | 411 | # CONFIG_LIB80211 is not set |
| 394 | # CONFIG_MAC80211 is not set | 412 | |
| 413 | # | ||
| 414 | # CFG80211 needs to be enabled for MAC80211 | ||
| 415 | # | ||
| 416 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 395 | # CONFIG_WIMAX is not set | 417 | # CONFIG_WIMAX is not set |
| 396 | # CONFIG_RFKILL is not set | 418 | # CONFIG_RFKILL is not set |
| 397 | # CONFIG_NET_9P is not set | 419 | # CONFIG_NET_9P is not set |
| @@ -507,6 +529,7 @@ CONFIG_MTD_NAND_FSL_ELBC=y | |||
| 507 | CONFIG_OF_DEVICE=y | 529 | CONFIG_OF_DEVICE=y |
| 508 | CONFIG_OF_GPIO=y | 530 | CONFIG_OF_GPIO=y |
| 509 | CONFIG_OF_I2C=y | 531 | CONFIG_OF_I2C=y |
| 532 | CONFIG_OF_MDIO=y | ||
| 510 | # CONFIG_PARPORT is not set | 533 | # CONFIG_PARPORT is not set |
| 511 | CONFIG_BLK_DEV=y | 534 | CONFIG_BLK_DEV=y |
| 512 | # CONFIG_BLK_DEV_FD is not set | 535 | # CONFIG_BLK_DEV_FD is not set |
| @@ -542,7 +565,9 @@ CONFIG_MISC_DEVICES=y | |||
| 542 | # | 565 | # |
| 543 | # CONFIG_EEPROM_AT24 is not set | 566 | # CONFIG_EEPROM_AT24 is not set |
| 544 | # CONFIG_EEPROM_LEGACY is not set | 567 | # CONFIG_EEPROM_LEGACY is not set |
| 568 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 545 | # CONFIG_EEPROM_93CX6 is not set | 569 | # CONFIG_EEPROM_93CX6 is not set |
| 570 | # CONFIG_CB710_CORE is not set | ||
| 546 | CONFIG_HAVE_IDE=y | 571 | CONFIG_HAVE_IDE=y |
| 547 | # CONFIG_IDE is not set | 572 | # CONFIG_IDE is not set |
| 548 | 573 | ||
| @@ -565,10 +590,6 @@ CONFIG_BLK_DEV_SD=y | |||
| 565 | # CONFIG_BLK_DEV_SR is not set | 590 | # CONFIG_BLK_DEV_SR is not set |
| 566 | CONFIG_CHR_DEV_SG=y | 591 | CONFIG_CHR_DEV_SG=y |
| 567 | # CONFIG_CHR_DEV_SCH is not set | 592 | # CONFIG_CHR_DEV_SCH is not set |
| 568 | |||
| 569 | # | ||
| 570 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 571 | # | ||
| 572 | # CONFIG_SCSI_MULTI_LUN is not set | 593 | # CONFIG_SCSI_MULTI_LUN is not set |
| 573 | # CONFIG_SCSI_CONSTANTS is not set | 594 | # CONFIG_SCSI_CONSTANTS is not set |
| 574 | # CONFIG_SCSI_LOGGING is not set | 595 | # CONFIG_SCSI_LOGGING is not set |
| @@ -586,6 +607,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 586 | CONFIG_SCSI_LOWLEVEL=y | 607 | CONFIG_SCSI_LOWLEVEL=y |
| 587 | # CONFIG_ISCSI_TCP is not set | 608 | # CONFIG_ISCSI_TCP is not set |
| 588 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 609 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 610 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 589 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 611 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 590 | # CONFIG_SCSI_3W_9XXX is not set | 612 | # CONFIG_SCSI_3W_9XXX is not set |
| 591 | # CONFIG_SCSI_ACARD is not set | 613 | # CONFIG_SCSI_ACARD is not set |
| @@ -594,6 +616,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 594 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 616 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 595 | # CONFIG_SCSI_AIC79XX is not set | 617 | # CONFIG_SCSI_AIC79XX is not set |
| 596 | # CONFIG_SCSI_AIC94XX is not set | 618 | # CONFIG_SCSI_AIC94XX is not set |
| 619 | # CONFIG_SCSI_MVSAS is not set | ||
| 597 | # CONFIG_SCSI_DPT_I2O is not set | 620 | # CONFIG_SCSI_DPT_I2O is not set |
| 598 | # CONFIG_SCSI_ADVANSYS is not set | 621 | # CONFIG_SCSI_ADVANSYS is not set |
| 599 | # CONFIG_SCSI_ARCMSR is not set | 622 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -613,7 +636,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 613 | # CONFIG_SCSI_IPS is not set | 636 | # CONFIG_SCSI_IPS is not set |
| 614 | # CONFIG_SCSI_INITIO is not set | 637 | # CONFIG_SCSI_INITIO is not set |
| 615 | # CONFIG_SCSI_INIA100 is not set | 638 | # CONFIG_SCSI_INIA100 is not set |
| 616 | # CONFIG_SCSI_MVSAS is not set | ||
| 617 | # CONFIG_SCSI_STEX is not set | 639 | # CONFIG_SCSI_STEX is not set |
| 618 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 640 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 619 | # CONFIG_SCSI_IPR is not set | 641 | # CONFIG_SCSI_IPR is not set |
| @@ -697,14 +719,17 @@ CONFIG_ATA_SFF=y | |||
| 697 | # | 719 | # |
| 698 | 720 | ||
| 699 | # | 721 | # |
| 700 | # Enable only one of the two stacks, unless you know what you are doing | 722 | # You can enable one or both FireWire driver stacks. |
| 723 | # | ||
| 724 | |||
| 725 | # | ||
| 726 | # See the help texts for more information. | ||
| 701 | # | 727 | # |
| 702 | # CONFIG_FIREWIRE is not set | 728 | # CONFIG_FIREWIRE is not set |
| 703 | # CONFIG_IEEE1394 is not set | 729 | # CONFIG_IEEE1394 is not set |
| 704 | # CONFIG_I2O is not set | 730 | # CONFIG_I2O is not set |
| 705 | # CONFIG_MACINTOSH_DRIVERS is not set | 731 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 706 | CONFIG_NETDEVICES=y | 732 | CONFIG_NETDEVICES=y |
| 707 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 708 | # CONFIG_DUMMY is not set | 733 | # CONFIG_DUMMY is not set |
| 709 | # CONFIG_BONDING is not set | 734 | # CONFIG_BONDING is not set |
| 710 | # CONFIG_MACVLAN is not set | 735 | # CONFIG_MACVLAN is not set |
| @@ -751,6 +776,7 @@ CONFIG_MII=y | |||
| 751 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 776 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 752 | # CONFIG_NET_PCI is not set | 777 | # CONFIG_NET_PCI is not set |
| 753 | # CONFIG_B44 is not set | 778 | # CONFIG_B44 is not set |
| 779 | # CONFIG_KS8842 is not set | ||
| 754 | # CONFIG_ATL2 is not set | 780 | # CONFIG_ATL2 is not set |
| 755 | CONFIG_NETDEV_1000=y | 781 | CONFIG_NETDEV_1000=y |
| 756 | # CONFIG_ACENIC is not set | 782 | # CONFIG_ACENIC is not set |
| @@ -770,11 +796,13 @@ CONFIG_NETDEV_1000=y | |||
| 770 | # CONFIG_VIA_VELOCITY is not set | 796 | # CONFIG_VIA_VELOCITY is not set |
| 771 | # CONFIG_TIGON3 is not set | 797 | # CONFIG_TIGON3 is not set |
| 772 | # CONFIG_BNX2 is not set | 798 | # CONFIG_BNX2 is not set |
| 799 | # CONFIG_CNIC is not set | ||
| 773 | CONFIG_FSL_PQ_MDIO=y | 800 | CONFIG_FSL_PQ_MDIO=y |
| 774 | CONFIG_GIANFAR=y | 801 | CONFIG_GIANFAR=y |
| 775 | CONFIG_UCC_GETH=y | 802 | CONFIG_UCC_GETH=y |
| 776 | # CONFIG_UGETH_MAGIC_PACKET is not set | 803 | # CONFIG_UGETH_MAGIC_PACKET is not set |
| 777 | # CONFIG_UGETH_TX_ON_DEMAND is not set | 804 | # CONFIG_UGETH_TX_ON_DEMAND is not set |
| 805 | # CONFIG_MV643XX_ETH is not set | ||
| 778 | # CONFIG_QLA3XXX is not set | 806 | # CONFIG_QLA3XXX is not set |
| 779 | # CONFIG_ATL1 is not set | 807 | # CONFIG_ATL1 is not set |
| 780 | # CONFIG_ATL1E is not set | 808 | # CONFIG_ATL1E is not set |
| @@ -965,13 +993,17 @@ CONFIG_I2C_MPC=y | |||
| 965 | # CONFIG_SENSORS_PCF8574 is not set | 993 | # CONFIG_SENSORS_PCF8574 is not set |
| 966 | # CONFIG_PCF8575 is not set | 994 | # CONFIG_PCF8575 is not set |
| 967 | # CONFIG_SENSORS_PCA9539 is not set | 995 | # CONFIG_SENSORS_PCA9539 is not set |
| 968 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 969 | # CONFIG_SENSORS_TSL2550 is not set | 996 | # CONFIG_SENSORS_TSL2550 is not set |
| 970 | # CONFIG_I2C_DEBUG_CORE is not set | 997 | # CONFIG_I2C_DEBUG_CORE is not set |
| 971 | # CONFIG_I2C_DEBUG_ALGO is not set | 998 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 972 | # CONFIG_I2C_DEBUG_BUS is not set | 999 | # CONFIG_I2C_DEBUG_BUS is not set |
| 973 | # CONFIG_I2C_DEBUG_CHIP is not set | 1000 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 974 | # CONFIG_SPI is not set | 1001 | # CONFIG_SPI is not set |
| 1002 | |||
| 1003 | # | ||
| 1004 | # PPS support | ||
| 1005 | # | ||
| 1006 | # CONFIG_PPS is not set | ||
| 975 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 1007 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 976 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 1008 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 977 | CONFIG_GPIOLIB=y | 1009 | CONFIG_GPIOLIB=y |
| @@ -1050,6 +1082,7 @@ CONFIG_HWMON=y | |||
| 1050 | # CONFIG_SENSORS_SMSC47B397 is not set | 1082 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 1051 | # CONFIG_SENSORS_ADS7828 is not set | 1083 | # CONFIG_SENSORS_ADS7828 is not set |
| 1052 | # CONFIG_SENSORS_THMC50 is not set | 1084 | # CONFIG_SENSORS_THMC50 is not set |
| 1085 | # CONFIG_SENSORS_TMP401 is not set | ||
| 1053 | # CONFIG_SENSORS_VIA686A is not set | 1086 | # CONFIG_SENSORS_VIA686A is not set |
| 1054 | # CONFIG_SENSORS_VT1211 is not set | 1087 | # CONFIG_SENSORS_VT1211 is not set |
| 1055 | # CONFIG_SENSORS_VT8231 is not set | 1088 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -1104,24 +1137,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1104 | # CONFIG_MFD_WM8400 is not set | 1137 | # CONFIG_MFD_WM8400 is not set |
| 1105 | # CONFIG_MFD_WM8350_I2C is not set | 1138 | # CONFIG_MFD_WM8350_I2C is not set |
| 1106 | # CONFIG_MFD_PCF50633 is not set | 1139 | # CONFIG_MFD_PCF50633 is not set |
| 1140 | # CONFIG_AB3100_CORE is not set | ||
| 1107 | # CONFIG_REGULATOR is not set | 1141 | # CONFIG_REGULATOR is not set |
| 1108 | 1142 | # CONFIG_MEDIA_SUPPORT is not set | |
| 1109 | # | ||
| 1110 | # Multimedia devices | ||
| 1111 | # | ||
| 1112 | |||
| 1113 | # | ||
| 1114 | # Multimedia core support | ||
| 1115 | # | ||
| 1116 | # CONFIG_VIDEO_DEV is not set | ||
| 1117 | # CONFIG_DVB_CORE is not set | ||
| 1118 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1119 | |||
| 1120 | # | ||
| 1121 | # Multimedia drivers | ||
| 1122 | # | ||
| 1123 | CONFIG_DAB=y | ||
| 1124 | # CONFIG_USB_DABUSB is not set | ||
| 1125 | 1143 | ||
| 1126 | # | 1144 | # |
| 1127 | # Graphics support | 1145 | # Graphics support |
| @@ -1159,7 +1177,7 @@ CONFIG_HID_BELKIN=y | |||
| 1159 | CONFIG_HID_CHERRY=y | 1177 | CONFIG_HID_CHERRY=y |
| 1160 | CONFIG_HID_CHICONY=y | 1178 | CONFIG_HID_CHICONY=y |
| 1161 | CONFIG_HID_CYPRESS=y | 1179 | CONFIG_HID_CYPRESS=y |
| 1162 | # CONFIG_DRAGONRISE_FF is not set | 1180 | # CONFIG_HID_DRAGONRISE is not set |
| 1163 | CONFIG_HID_EZKEY=y | 1181 | CONFIG_HID_EZKEY=y |
| 1164 | # CONFIG_HID_KYE is not set | 1182 | # CONFIG_HID_KYE is not set |
| 1165 | CONFIG_HID_GYRATION=y | 1183 | CONFIG_HID_GYRATION=y |
| @@ -1176,10 +1194,11 @@ CONFIG_HID_PETALYNX=y | |||
| 1176 | CONFIG_HID_SAMSUNG=y | 1194 | CONFIG_HID_SAMSUNG=y |
| 1177 | CONFIG_HID_SONY=y | 1195 | CONFIG_HID_SONY=y |
| 1178 | CONFIG_HID_SUNPLUS=y | 1196 | CONFIG_HID_SUNPLUS=y |
| 1179 | # CONFIG_GREENASIA_FF is not set | 1197 | # CONFIG_HID_GREENASIA is not set |
| 1198 | # CONFIG_HID_SMARTJOYPLUS is not set | ||
| 1180 | # CONFIG_HID_TOPSEED is not set | 1199 | # CONFIG_HID_TOPSEED is not set |
| 1181 | CONFIG_THRUSTMASTER_FF=m | 1200 | # CONFIG_HID_THRUSTMASTER is not set |
| 1182 | CONFIG_ZEROPLUS_FF=m | 1201 | # CONFIG_HID_ZEROPLUS is not set |
| 1183 | CONFIG_USB_SUPPORT=y | 1202 | CONFIG_USB_SUPPORT=y |
| 1184 | CONFIG_USB_ARCH_HAS_HCD=y | 1203 | CONFIG_USB_ARCH_HAS_HCD=y |
| 1185 | CONFIG_USB_ARCH_HAS_OHCI=y | 1204 | CONFIG_USB_ARCH_HAS_OHCI=y |
| @@ -1205,6 +1224,7 @@ CONFIG_USB_MON=y | |||
| 1205 | # USB Host Controller Drivers | 1224 | # USB Host Controller Drivers |
| 1206 | # | 1225 | # |
| 1207 | # CONFIG_USB_C67X00_HCD is not set | 1226 | # CONFIG_USB_C67X00_HCD is not set |
| 1227 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1208 | CONFIG_USB_EHCI_HCD=y | 1228 | CONFIG_USB_EHCI_HCD=y |
| 1209 | CONFIG_USB_EHCI_ROOT_HUB_TT=y | 1229 | CONFIG_USB_EHCI_ROOT_HUB_TT=y |
| 1210 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1230 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1291,6 +1311,10 @@ CONFIG_USB_EHCI_HCD_PPC_OF=y | |||
| 1291 | # CONFIG_DMADEVICES is not set | 1311 | # CONFIG_DMADEVICES is not set |
| 1292 | # CONFIG_AUXDISPLAY is not set | 1312 | # CONFIG_AUXDISPLAY is not set |
| 1293 | # CONFIG_UIO is not set | 1313 | # CONFIG_UIO is not set |
| 1314 | |||
| 1315 | # | ||
| 1316 | # TI VLYNQ | ||
| 1317 | # | ||
| 1294 | # CONFIG_STAGING is not set | 1318 | # CONFIG_STAGING is not set |
| 1295 | 1319 | ||
| 1296 | # | 1320 | # |
| @@ -1310,10 +1334,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1310 | # CONFIG_REISERFS_FS is not set | 1334 | # CONFIG_REISERFS_FS is not set |
| 1311 | # CONFIG_JFS_FS is not set | 1335 | # CONFIG_JFS_FS is not set |
| 1312 | # CONFIG_FS_POSIX_ACL is not set | 1336 | # CONFIG_FS_POSIX_ACL is not set |
| 1313 | CONFIG_FILE_LOCKING=y | ||
| 1314 | # CONFIG_XFS_FS is not set | 1337 | # CONFIG_XFS_FS is not set |
| 1338 | # CONFIG_GFS2_FS is not set | ||
| 1315 | # CONFIG_OCFS2_FS is not set | 1339 | # CONFIG_OCFS2_FS is not set |
| 1316 | # CONFIG_BTRFS_FS is not set | 1340 | # CONFIG_BTRFS_FS is not set |
| 1341 | CONFIG_FILE_LOCKING=y | ||
| 1342 | CONFIG_FSNOTIFY=y | ||
| 1317 | CONFIG_DNOTIFY=y | 1343 | CONFIG_DNOTIFY=y |
| 1318 | CONFIG_INOTIFY=y | 1344 | CONFIG_INOTIFY=y |
| 1319 | CONFIG_INOTIFY_USER=y | 1345 | CONFIG_INOTIFY_USER=y |
| @@ -1377,6 +1403,7 @@ CONFIG_NFS_FS=y | |||
| 1377 | CONFIG_NFS_V3=y | 1403 | CONFIG_NFS_V3=y |
| 1378 | # CONFIG_NFS_V3_ACL is not set | 1404 | # CONFIG_NFS_V3_ACL is not set |
| 1379 | CONFIG_NFS_V4=y | 1405 | CONFIG_NFS_V4=y |
| 1406 | # CONFIG_NFS_V4_1 is not set | ||
| 1380 | CONFIG_ROOT_NFS=y | 1407 | CONFIG_ROOT_NFS=y |
| 1381 | # CONFIG_NFSD is not set | 1408 | # CONFIG_NFSD is not set |
| 1382 | CONFIG_LOCKD=y | 1409 | CONFIG_LOCKD=y |
| @@ -1413,7 +1440,46 @@ CONFIG_MSDOS_PARTITION=y | |||
| 1413 | # CONFIG_KARMA_PARTITION is not set | 1440 | # CONFIG_KARMA_PARTITION is not set |
| 1414 | # CONFIG_EFI_PARTITION is not set | 1441 | # CONFIG_EFI_PARTITION is not set |
| 1415 | # CONFIG_SYSV68_PARTITION is not set | 1442 | # CONFIG_SYSV68_PARTITION is not set |
| 1416 | # CONFIG_NLS is not set | 1443 | CONFIG_NLS=y |
| 1444 | CONFIG_NLS_DEFAULT="iso8859-1" | ||
| 1445 | # CONFIG_NLS_CODEPAGE_437 is not set | ||
| 1446 | # CONFIG_NLS_CODEPAGE_737 is not set | ||
| 1447 | # CONFIG_NLS_CODEPAGE_775 is not set | ||
| 1448 | # CONFIG_NLS_CODEPAGE_850 is not set | ||
| 1449 | # CONFIG_NLS_CODEPAGE_852 is not set | ||
| 1450 | # CONFIG_NLS_CODEPAGE_855 is not set | ||
| 1451 | # CONFIG_NLS_CODEPAGE_857 is not set | ||
| 1452 | # CONFIG_NLS_CODEPAGE_860 is not set | ||
| 1453 | # CONFIG_NLS_CODEPAGE_861 is not set | ||
| 1454 | # CONFIG_NLS_CODEPAGE_862 is not set | ||
| 1455 | # CONFIG_NLS_CODEPAGE_863 is not set | ||
| 1456 | # CONFIG_NLS_CODEPAGE_864 is not set | ||
| 1457 | # CONFIG_NLS_CODEPAGE_865 is not set | ||
| 1458 | # CONFIG_NLS_CODEPAGE_866 is not set | ||
| 1459 | # CONFIG_NLS_CODEPAGE_869 is not set | ||
| 1460 | # CONFIG_NLS_CODEPAGE_936 is not set | ||
| 1461 | # CONFIG_NLS_CODEPAGE_950 is not set | ||
| 1462 | # CONFIG_NLS_CODEPAGE_932 is not set | ||
| 1463 | # CONFIG_NLS_CODEPAGE_949 is not set | ||
| 1464 | # CONFIG_NLS_CODEPAGE_874 is not set | ||
| 1465 | # CONFIG_NLS_ISO8859_8 is not set | ||
| 1466 | # CONFIG_NLS_CODEPAGE_1250 is not set | ||
| 1467 | # CONFIG_NLS_CODEPAGE_1251 is not set | ||
| 1468 | # CONFIG_NLS_ASCII is not set | ||
| 1469 | # CONFIG_NLS_ISO8859_1 is not set | ||
| 1470 | # CONFIG_NLS_ISO8859_2 is not set | ||
| 1471 | # CONFIG_NLS_ISO8859_3 is not set | ||
| 1472 | # CONFIG_NLS_ISO8859_4 is not set | ||
| 1473 | # CONFIG_NLS_ISO8859_5 is not set | ||
| 1474 | # CONFIG_NLS_ISO8859_6 is not set | ||
| 1475 | # CONFIG_NLS_ISO8859_7 is not set | ||
| 1476 | # CONFIG_NLS_ISO8859_9 is not set | ||
| 1477 | # CONFIG_NLS_ISO8859_13 is not set | ||
| 1478 | # CONFIG_NLS_ISO8859_14 is not set | ||
| 1479 | # CONFIG_NLS_ISO8859_15 is not set | ||
| 1480 | # CONFIG_NLS_KOI8_R is not set | ||
| 1481 | # CONFIG_NLS_KOI8_U is not set | ||
| 1482 | # CONFIG_NLS_UTF8 is not set | ||
| 1417 | # CONFIG_DLM is not set | 1483 | # CONFIG_DLM is not set |
| 1418 | CONFIG_UCC_FAST=y | 1484 | CONFIG_UCC_FAST=y |
| 1419 | CONFIG_UCC=y | 1485 | CONFIG_UCC=y |
| @@ -1438,6 +1504,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1438 | CONFIG_HAS_DMA=y | 1504 | CONFIG_HAS_DMA=y |
| 1439 | CONFIG_HAVE_LMB=y | 1505 | CONFIG_HAVE_LMB=y |
| 1440 | CONFIG_NLATTR=y | 1506 | CONFIG_NLATTR=y |
| 1507 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1441 | 1508 | ||
| 1442 | # | 1509 | # |
| 1443 | # Kernel hacking | 1510 | # Kernel hacking |
| @@ -1461,22 +1528,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1461 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1528 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1462 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1529 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1463 | CONFIG_TRACING_SUPPORT=y | 1530 | CONFIG_TRACING_SUPPORT=y |
| 1464 | 1531 | # CONFIG_FTRACE is not set | |
| 1465 | # | ||
| 1466 | # Tracers | ||
| 1467 | # | ||
| 1468 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1469 | # CONFIG_SCHED_TRACER is not set | ||
| 1470 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1471 | # CONFIG_EVENT_TRACER is not set | ||
| 1472 | # CONFIG_BOOT_TRACER is not set | ||
| 1473 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1474 | # CONFIG_STACK_TRACER is not set | ||
| 1475 | # CONFIG_KMEMTRACE is not set | ||
| 1476 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1477 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1478 | # CONFIG_SAMPLES is not set | 1532 | # CONFIG_SAMPLES is not set |
| 1479 | CONFIG_HAVE_ARCH_KGDB=y | 1533 | CONFIG_HAVE_ARCH_KGDB=y |
| 1534 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1535 | CONFIG_PPC_WERROR=y | ||
| 1480 | CONFIG_PRINT_STACK_DEPTH=64 | 1536 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1481 | # CONFIG_IRQSTACKS is not set | 1537 | # CONFIG_IRQSTACKS is not set |
| 1482 | # CONFIG_BOOTX_TEXT is not set | 1538 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/mpc85xx_defconfig b/arch/powerpc/configs/mpc85xx_defconfig index c162724fed4f..ada595898af1 100644 --- a/arch/powerpc/configs/mpc85xx_defconfig +++ b/arch/powerpc/configs/mpc85xx_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc2 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Tue Apr 21 15:40:23 2009 | 4 | # Wed Jul 29 23:31:55 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -34,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 34 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 35 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 36 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 37 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 38 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 39 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 40 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 41 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 43 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 44 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 45 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 46 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 47 | CONFIG_GENERIC_GPIO=y | 48 | CONFIG_GENERIC_GPIO=y |
| 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 49 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -57,11 +58,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 57 | # CONFIG_GENERIC_TBSYNC is not set | 58 | # CONFIG_GENERIC_TBSYNC is not set |
| 58 | CONFIG_AUDIT_ARCH=y | 59 | CONFIG_AUDIT_ARCH=y |
| 59 | CONFIG_GENERIC_BUG=y | 60 | CONFIG_GENERIC_BUG=y |
| 61 | CONFIG_DTC=y | ||
| 60 | CONFIG_DEFAULT_UIMAGE=y | 62 | CONFIG_DEFAULT_UIMAGE=y |
| 61 | # CONFIG_PPC_DCR_NATIVE is not set | 63 | # CONFIG_PPC_DCR_NATIVE is not set |
| 62 | # CONFIG_PPC_DCR_MMIO is not set | 64 | # CONFIG_PPC_DCR_MMIO is not set |
| 63 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 65 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 64 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 66 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 67 | CONFIG_CONSTRUCTORS=y | ||
| 65 | 68 | ||
| 66 | # | 69 | # |
| 67 | # General setup | 70 | # General setup |
| @@ -116,7 +119,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 116 | CONFIG_KALLSYMS=y | 119 | CONFIG_KALLSYMS=y |
| 117 | CONFIG_KALLSYMS_ALL=y | 120 | CONFIG_KALLSYMS_ALL=y |
| 118 | CONFIG_KALLSYMS_EXTRA_PASS=y | 121 | CONFIG_KALLSYMS_EXTRA_PASS=y |
| 119 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 120 | CONFIG_HOTPLUG=y | 122 | CONFIG_HOTPLUG=y |
| 121 | CONFIG_PRINTK=y | 123 | CONFIG_PRINTK=y |
| 122 | CONFIG_BUG=y | 124 | CONFIG_BUG=y |
| @@ -129,9 +131,16 @@ CONFIG_TIMERFD=y | |||
| 129 | CONFIG_EVENTFD=y | 131 | CONFIG_EVENTFD=y |
| 130 | CONFIG_SHMEM=y | 132 | CONFIG_SHMEM=y |
| 131 | CONFIG_AIO=y | 133 | CONFIG_AIO=y |
| 134 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 135 | |||
| 136 | # | ||
| 137 | # Performance Counters | ||
| 138 | # | ||
| 139 | # CONFIG_PERF_COUNTERS is not set | ||
| 132 | CONFIG_VM_EVENT_COUNTERS=y | 140 | CONFIG_VM_EVENT_COUNTERS=y |
| 133 | CONFIG_PCI_QUIRKS=y | 141 | CONFIG_PCI_QUIRKS=y |
| 134 | CONFIG_SLUB_DEBUG=y | 142 | CONFIG_SLUB_DEBUG=y |
| 143 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 135 | CONFIG_COMPAT_BRK=y | 144 | CONFIG_COMPAT_BRK=y |
| 136 | # CONFIG_SLAB is not set | 145 | # CONFIG_SLAB is not set |
| 137 | CONFIG_SLUB=y | 146 | CONFIG_SLUB=y |
| @@ -146,6 +155,11 @@ CONFIG_HAVE_KPROBES=y | |||
| 146 | CONFIG_HAVE_KRETPROBES=y | 155 | CONFIG_HAVE_KRETPROBES=y |
| 147 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 156 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 148 | CONFIG_HAVE_CLK=y | 157 | CONFIG_HAVE_CLK=y |
| 158 | |||
| 159 | # | ||
| 160 | # GCOV-based kernel profiling | ||
| 161 | # | ||
| 162 | # CONFIG_GCOV_KERNEL is not set | ||
| 149 | # CONFIG_SLOW_WORK is not set | 163 | # CONFIG_SLOW_WORK is not set |
| 150 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 164 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 151 | CONFIG_SLABINFO=y | 165 | CONFIG_SLABINFO=y |
| @@ -158,7 +172,7 @@ CONFIG_MODULE_FORCE_UNLOAD=y | |||
| 158 | CONFIG_MODVERSIONS=y | 172 | CONFIG_MODVERSIONS=y |
| 159 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 173 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 160 | CONFIG_BLOCK=y | 174 | CONFIG_BLOCK=y |
| 161 | CONFIG_LBD=y | 175 | CONFIG_LBDAF=y |
| 162 | # CONFIG_BLK_DEV_BSG is not set | 176 | # CONFIG_BLK_DEV_BSG is not set |
| 163 | # CONFIG_BLK_DEV_INTEGRITY is not set | 177 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 164 | 178 | ||
| @@ -191,6 +205,7 @@ CONFIG_MPC8536_DS=y | |||
| 191 | CONFIG_MPC85xx_DS=y | 205 | CONFIG_MPC85xx_DS=y |
| 192 | CONFIG_SOCRATES=y | 206 | CONFIG_SOCRATES=y |
| 193 | CONFIG_KSI8560=y | 207 | CONFIG_KSI8560=y |
| 208 | # CONFIG_XES_MPC85xx is not set | ||
| 194 | CONFIG_STX_GP3=y | 209 | CONFIG_STX_GP3=y |
| 195 | CONFIG_TQM8540=y | 210 | CONFIG_TQM8540=y |
| 196 | CONFIG_TQM8541=y | 211 | CONFIG_TQM8541=y |
| @@ -241,7 +256,9 @@ CONFIG_BINFMT_ELF=y | |||
| 241 | # CONFIG_HAVE_AOUT is not set | 256 | # CONFIG_HAVE_AOUT is not set |
| 242 | CONFIG_BINFMT_MISC=m | 257 | CONFIG_BINFMT_MISC=m |
| 243 | CONFIG_MATH_EMULATION=y | 258 | CONFIG_MATH_EMULATION=y |
| 244 | # CONFIG_IOMMU_HELPER is not set | 259 | CONFIG_IOMMU_HELPER=y |
| 260 | CONFIG_SWIOTLB=y | ||
| 261 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y | ||
| 245 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 262 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 246 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 263 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 247 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 264 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -260,9 +277,9 @@ CONFIG_MIGRATION=y | |||
| 260 | CONFIG_ZONE_DMA_FLAG=1 | 277 | CONFIG_ZONE_DMA_FLAG=1 |
| 261 | CONFIG_BOUNCE=y | 278 | CONFIG_BOUNCE=y |
| 262 | CONFIG_VIRT_TO_BUS=y | 279 | CONFIG_VIRT_TO_BUS=y |
| 263 | CONFIG_UNEVICTABLE_LRU=y | ||
| 264 | CONFIG_HAVE_MLOCK=y | 280 | CONFIG_HAVE_MLOCK=y |
| 265 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 281 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 282 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 266 | CONFIG_PPC_4K_PAGES=y | 283 | CONFIG_PPC_4K_PAGES=y |
| 267 | # CONFIG_PPC_16K_PAGES is not set | 284 | # CONFIG_PPC_16K_PAGES is not set |
| 268 | # CONFIG_PPC_64K_PAGES is not set | 285 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -296,7 +313,8 @@ CONFIG_ARCH_SUPPORTS_MSI=y | |||
| 296 | # CONFIG_PCI_IOV is not set | 313 | # CONFIG_PCI_IOV is not set |
| 297 | # CONFIG_PCCARD is not set | 314 | # CONFIG_PCCARD is not set |
| 298 | # CONFIG_HOTPLUG_PCI is not set | 315 | # CONFIG_HOTPLUG_PCI is not set |
| 299 | # CONFIG_HAS_RAPIDIO is not set | 316 | CONFIG_HAS_RAPIDIO=y |
| 317 | # CONFIG_RAPIDIO is not set | ||
| 300 | 318 | ||
| 301 | # | 319 | # |
| 302 | # Advanced setup | 320 | # Advanced setup |
| @@ -406,6 +424,7 @@ CONFIG_SCTP_HMAC_MD5=y | |||
| 406 | # CONFIG_ECONET is not set | 424 | # CONFIG_ECONET is not set |
| 407 | # CONFIG_WAN_ROUTER is not set | 425 | # CONFIG_WAN_ROUTER is not set |
| 408 | # CONFIG_PHONET is not set | 426 | # CONFIG_PHONET is not set |
| 427 | # CONFIG_IEEE802154 is not set | ||
| 409 | # CONFIG_NET_SCHED is not set | 428 | # CONFIG_NET_SCHED is not set |
| 410 | # CONFIG_DCB is not set | 429 | # CONFIG_DCB is not set |
| 411 | 430 | ||
| @@ -424,7 +443,11 @@ CONFIG_WIRELESS=y | |||
| 424 | CONFIG_WIRELESS_OLD_REGULATORY=y | 443 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 425 | # CONFIG_WIRELESS_EXT is not set | 444 | # CONFIG_WIRELESS_EXT is not set |
| 426 | # CONFIG_LIB80211 is not set | 445 | # CONFIG_LIB80211 is not set |
| 427 | # CONFIG_MAC80211 is not set | 446 | |
| 447 | # | ||
| 448 | # CFG80211 needs to be enabled for MAC80211 | ||
| 449 | # | ||
| 450 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 428 | # CONFIG_WIMAX is not set | 451 | # CONFIG_WIMAX is not set |
| 429 | # CONFIG_RFKILL is not set | 452 | # CONFIG_RFKILL is not set |
| 430 | # CONFIG_NET_9P is not set | 453 | # CONFIG_NET_9P is not set |
| @@ -450,6 +473,7 @@ CONFIG_EXTRA_FIRMWARE="" | |||
| 450 | CONFIG_OF_DEVICE=y | 473 | CONFIG_OF_DEVICE=y |
| 451 | CONFIG_OF_GPIO=y | 474 | CONFIG_OF_GPIO=y |
| 452 | CONFIG_OF_I2C=y | 475 | CONFIG_OF_I2C=y |
| 476 | CONFIG_OF_MDIO=y | ||
| 453 | # CONFIG_PARPORT is not set | 477 | # CONFIG_PARPORT is not set |
| 454 | CONFIG_BLK_DEV=y | 478 | CONFIG_BLK_DEV=y |
| 455 | # CONFIG_BLK_DEV_FD is not set | 479 | # CONFIG_BLK_DEV_FD is not set |
| @@ -485,7 +509,9 @@ CONFIG_MISC_DEVICES=y | |||
| 485 | # | 509 | # |
| 486 | # CONFIG_EEPROM_AT24 is not set | 510 | # CONFIG_EEPROM_AT24 is not set |
| 487 | CONFIG_EEPROM_LEGACY=y | 511 | CONFIG_EEPROM_LEGACY=y |
| 512 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 488 | # CONFIG_EEPROM_93CX6 is not set | 513 | # CONFIG_EEPROM_93CX6 is not set |
| 514 | # CONFIG_CB710_CORE is not set | ||
| 489 | CONFIG_HAVE_IDE=y | 515 | CONFIG_HAVE_IDE=y |
| 490 | # CONFIG_IDE is not set | 516 | # CONFIG_IDE is not set |
| 491 | 517 | ||
| @@ -509,10 +535,6 @@ CONFIG_BLK_DEV_SR=y | |||
| 509 | # CONFIG_BLK_DEV_SR_VENDOR is not set | 535 | # CONFIG_BLK_DEV_SR_VENDOR is not set |
| 510 | CONFIG_CHR_DEV_SG=y | 536 | CONFIG_CHR_DEV_SG=y |
| 511 | # CONFIG_CHR_DEV_SCH is not set | 537 | # CONFIG_CHR_DEV_SCH is not set |
| 512 | |||
| 513 | # | ||
| 514 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 515 | # | ||
| 516 | CONFIG_SCSI_MULTI_LUN=y | 538 | CONFIG_SCSI_MULTI_LUN=y |
| 517 | # CONFIG_SCSI_CONSTANTS is not set | 539 | # CONFIG_SCSI_CONSTANTS is not set |
| 518 | CONFIG_SCSI_LOGGING=y | 540 | CONFIG_SCSI_LOGGING=y |
| @@ -530,6 +552,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 530 | CONFIG_SCSI_LOWLEVEL=y | 552 | CONFIG_SCSI_LOWLEVEL=y |
| 531 | # CONFIG_ISCSI_TCP is not set | 553 | # CONFIG_ISCSI_TCP is not set |
| 532 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 554 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 555 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 533 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 556 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 534 | # CONFIG_SCSI_3W_9XXX is not set | 557 | # CONFIG_SCSI_3W_9XXX is not set |
| 535 | # CONFIG_SCSI_ACARD is not set | 558 | # CONFIG_SCSI_ACARD is not set |
| @@ -538,6 +561,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 538 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 561 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 539 | # CONFIG_SCSI_AIC79XX is not set | 562 | # CONFIG_SCSI_AIC79XX is not set |
| 540 | # CONFIG_SCSI_AIC94XX is not set | 563 | # CONFIG_SCSI_AIC94XX is not set |
| 564 | # CONFIG_SCSI_MVSAS is not set | ||
| 541 | # CONFIG_SCSI_DPT_I2O is not set | 565 | # CONFIG_SCSI_DPT_I2O is not set |
| 542 | # CONFIG_SCSI_ADVANSYS is not set | 566 | # CONFIG_SCSI_ADVANSYS is not set |
| 543 | # CONFIG_SCSI_ARCMSR is not set | 567 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -557,7 +581,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 557 | # CONFIG_SCSI_IPS is not set | 581 | # CONFIG_SCSI_IPS is not set |
| 558 | # CONFIG_SCSI_INITIO is not set | 582 | # CONFIG_SCSI_INITIO is not set |
| 559 | # CONFIG_SCSI_INIA100 is not set | 583 | # CONFIG_SCSI_INIA100 is not set |
| 560 | # CONFIG_SCSI_MVSAS is not set | ||
| 561 | # CONFIG_SCSI_STEX is not set | 584 | # CONFIG_SCSI_STEX is not set |
| 562 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 585 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 563 | # CONFIG_SCSI_IPR is not set | 586 | # CONFIG_SCSI_IPR is not set |
| @@ -641,14 +664,17 @@ CONFIG_PATA_ALI=y | |||
| 641 | # | 664 | # |
| 642 | 665 | ||
| 643 | # | 666 | # |
| 644 | # Enable only one of the two stacks, unless you know what you are doing | 667 | # You can enable one or both FireWire driver stacks. |
| 668 | # | ||
| 669 | |||
| 670 | # | ||
| 671 | # See the help texts for more information. | ||
| 645 | # | 672 | # |
| 646 | # CONFIG_FIREWIRE is not set | 673 | # CONFIG_FIREWIRE is not set |
| 647 | # CONFIG_IEEE1394 is not set | 674 | # CONFIG_IEEE1394 is not set |
| 648 | # CONFIG_I2O is not set | 675 | # CONFIG_I2O is not set |
| 649 | # CONFIG_MACINTOSH_DRIVERS is not set | 676 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 650 | CONFIG_NETDEVICES=y | 677 | CONFIG_NETDEVICES=y |
| 651 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 652 | CONFIG_DUMMY=y | 678 | CONFIG_DUMMY=y |
| 653 | # CONFIG_BONDING is not set | 679 | # CONFIG_BONDING is not set |
| 654 | # CONFIG_MACVLAN is not set | 680 | # CONFIG_MACVLAN is not set |
| @@ -695,6 +721,7 @@ CONFIG_MII=y | |||
| 695 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 721 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 696 | # CONFIG_NET_PCI is not set | 722 | # CONFIG_NET_PCI is not set |
| 697 | # CONFIG_B44 is not set | 723 | # CONFIG_B44 is not set |
| 724 | # CONFIG_KS8842 is not set | ||
| 698 | # CONFIG_ATL2 is not set | 725 | # CONFIG_ATL2 is not set |
| 699 | CONFIG_FS_ENET=y | 726 | CONFIG_FS_ENET=y |
| 700 | CONFIG_FS_ENET_HAS_SCC=y | 727 | CONFIG_FS_ENET_HAS_SCC=y |
| @@ -718,11 +745,13 @@ CONFIG_NETDEV_1000=y | |||
| 718 | # CONFIG_VIA_VELOCITY is not set | 745 | # CONFIG_VIA_VELOCITY is not set |
| 719 | # CONFIG_TIGON3 is not set | 746 | # CONFIG_TIGON3 is not set |
| 720 | # CONFIG_BNX2 is not set | 747 | # CONFIG_BNX2 is not set |
| 748 | # CONFIG_CNIC is not set | ||
| 721 | CONFIG_FSL_PQ_MDIO=y | 749 | CONFIG_FSL_PQ_MDIO=y |
| 722 | CONFIG_GIANFAR=y | 750 | CONFIG_GIANFAR=y |
| 723 | CONFIG_UCC_GETH=y | 751 | CONFIG_UCC_GETH=y |
| 724 | # CONFIG_UGETH_MAGIC_PACKET is not set | 752 | # CONFIG_UGETH_MAGIC_PACKET is not set |
| 725 | # CONFIG_UGETH_TX_ON_DEMAND is not set | 753 | # CONFIG_UGETH_TX_ON_DEMAND is not set |
| 754 | # CONFIG_MV643XX_ETH is not set | ||
| 726 | # CONFIG_QLA3XXX is not set | 755 | # CONFIG_QLA3XXX is not set |
| 727 | # CONFIG_ATL1 is not set | 756 | # CONFIG_ATL1 is not set |
| 728 | # CONFIG_ATL1E is not set | 757 | # CONFIG_ATL1E is not set |
| @@ -897,6 +926,7 @@ CONFIG_I2C_HELPER_AUTO=y | |||
| 897 | # I2C system bus drivers (mostly embedded / system-on-chip) | 926 | # I2C system bus drivers (mostly embedded / system-on-chip) |
| 898 | # | 927 | # |
| 899 | CONFIG_I2C_CPM=m | 928 | CONFIG_I2C_CPM=m |
| 929 | # CONFIG_I2C_DESIGNWARE is not set | ||
| 900 | # CONFIG_I2C_GPIO is not set | 930 | # CONFIG_I2C_GPIO is not set |
| 901 | CONFIG_I2C_MPC=y | 931 | CONFIG_I2C_MPC=y |
| 902 | # CONFIG_I2C_OCORES is not set | 932 | # CONFIG_I2C_OCORES is not set |
| @@ -927,13 +957,17 @@ CONFIG_I2C_MPC=y | |||
| 927 | # CONFIG_SENSORS_PCF8574 is not set | 957 | # CONFIG_SENSORS_PCF8574 is not set |
| 928 | # CONFIG_PCF8575 is not set | 958 | # CONFIG_PCF8575 is not set |
| 929 | # CONFIG_SENSORS_PCA9539 is not set | 959 | # CONFIG_SENSORS_PCA9539 is not set |
| 930 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 931 | # CONFIG_SENSORS_TSL2550 is not set | 960 | # CONFIG_SENSORS_TSL2550 is not set |
| 932 | # CONFIG_I2C_DEBUG_CORE is not set | 961 | # CONFIG_I2C_DEBUG_CORE is not set |
| 933 | # CONFIG_I2C_DEBUG_ALGO is not set | 962 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 934 | # CONFIG_I2C_DEBUG_BUS is not set | 963 | # CONFIG_I2C_DEBUG_BUS is not set |
| 935 | # CONFIG_I2C_DEBUG_CHIP is not set | 964 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 936 | # CONFIG_SPI is not set | 965 | # CONFIG_SPI is not set |
| 966 | |||
| 967 | # | ||
| 968 | # PPS support | ||
| 969 | # | ||
| 970 | # CONFIG_PPS is not set | ||
| 937 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 971 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 938 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 972 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 939 | CONFIG_GPIOLIB=y | 973 | CONFIG_GPIOLIB=y |
| @@ -987,76 +1021,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 987 | # CONFIG_MFD_WM8400 is not set | 1021 | # CONFIG_MFD_WM8400 is not set |
| 988 | # CONFIG_MFD_WM8350_I2C is not set | 1022 | # CONFIG_MFD_WM8350_I2C is not set |
| 989 | # CONFIG_MFD_PCF50633 is not set | 1023 | # CONFIG_MFD_PCF50633 is not set |
| 1024 | # CONFIG_AB3100_CORE is not set | ||
| 990 | # CONFIG_REGULATOR is not set | 1025 | # CONFIG_REGULATOR is not set |
| 991 | 1026 | # CONFIG_MEDIA_SUPPORT is not set | |
| 992 | # | ||
| 993 | # Multimedia devices | ||
| 994 | # | ||
| 995 | |||
| 996 | # | ||
| 997 | # Multimedia core support | ||
| 998 | # | ||
| 999 | # CONFIG_VIDEO_DEV is not set | ||
| 1000 | CONFIG_DVB_CORE=m | ||
| 1001 | CONFIG_VIDEO_MEDIA=m | ||
| 1002 | |||
| 1003 | # | ||
| 1004 | # Multimedia drivers | ||
| 1005 | # | ||
| 1006 | # CONFIG_MEDIA_ATTACH is not set | ||
| 1007 | CONFIG_MEDIA_TUNER=m | ||
| 1008 | # CONFIG_MEDIA_TUNER_CUSTOMISE is not set | ||
| 1009 | CONFIG_MEDIA_TUNER_SIMPLE=m | ||
| 1010 | CONFIG_MEDIA_TUNER_TDA8290=m | ||
| 1011 | CONFIG_MEDIA_TUNER_TDA9887=m | ||
| 1012 | CONFIG_MEDIA_TUNER_TEA5761=m | ||
| 1013 | CONFIG_MEDIA_TUNER_TEA5767=m | ||
| 1014 | CONFIG_MEDIA_TUNER_MT20XX=m | ||
| 1015 | CONFIG_MEDIA_TUNER_XC2028=m | ||
| 1016 | CONFIG_MEDIA_TUNER_XC5000=m | ||
| 1017 | CONFIG_MEDIA_TUNER_MC44S803=m | ||
| 1018 | # CONFIG_DVB_DYNAMIC_MINORS is not set | ||
| 1019 | CONFIG_DVB_CAPTURE_DRIVERS=y | ||
| 1020 | |||
| 1021 | # | ||
| 1022 | # Supported SAA7146 based PCI Adapters | ||
| 1023 | # | ||
| 1024 | # CONFIG_TTPCI_EEPROM is not set | ||
| 1025 | # CONFIG_DVB_BUDGET_CORE is not set | ||
| 1026 | |||
| 1027 | # | ||
| 1028 | # Supported USB Adapters | ||
| 1029 | # | ||
| 1030 | # CONFIG_DVB_USB is not set | ||
| 1031 | # CONFIG_DVB_TTUSB_BUDGET is not set | ||
| 1032 | # CONFIG_DVB_TTUSB_DEC is not set | ||
| 1033 | # CONFIG_DVB_SIANO_SMS1XXX is not set | ||
| 1034 | |||
| 1035 | # | ||
| 1036 | # Supported FlexCopII (B2C2) Adapters | ||
| 1037 | # | ||
| 1038 | # CONFIG_DVB_B2C2_FLEXCOP is not set | ||
| 1039 | |||
| 1040 | # | ||
| 1041 | # Supported BT878 Adapters | ||
| 1042 | # | ||
| 1043 | |||
| 1044 | # | ||
| 1045 | # Supported Pluto2 Adapters | ||
| 1046 | # | ||
| 1047 | # CONFIG_DVB_PLUTO2 is not set | ||
| 1048 | |||
| 1049 | # | ||
| 1050 | # Supported SDMC DM1105 Adapters | ||
| 1051 | # | ||
| 1052 | # CONFIG_DVB_DM1105 is not set | ||
| 1053 | |||
| 1054 | # | ||
| 1055 | # Supported DVB Frontends | ||
| 1056 | # | ||
| 1057 | # CONFIG_DVB_FE_CUSTOMISE is not set | ||
| 1058 | CONFIG_DAB=y | ||
| 1059 | # CONFIG_USB_DABUSB is not set | ||
| 1060 | 1027 | ||
| 1061 | # | 1028 | # |
| 1062 | # Graphics support | 1029 | # Graphics support |
| @@ -1096,6 +1063,11 @@ CONFIG_SND_VERBOSE_PROCFS=y | |||
| 1096 | # CONFIG_SND_VERBOSE_PRINTK is not set | 1063 | # CONFIG_SND_VERBOSE_PRINTK is not set |
| 1097 | # CONFIG_SND_DEBUG is not set | 1064 | # CONFIG_SND_DEBUG is not set |
| 1098 | CONFIG_SND_VMASTER=y | 1065 | CONFIG_SND_VMASTER=y |
| 1066 | # CONFIG_SND_RAWMIDI_SEQ is not set | ||
| 1067 | # CONFIG_SND_OPL3_LIB_SEQ is not set | ||
| 1068 | # CONFIG_SND_OPL4_LIB_SEQ is not set | ||
| 1069 | # CONFIG_SND_SBAWE_SEQ is not set | ||
| 1070 | # CONFIG_SND_EMU10K1_SEQ is not set | ||
| 1099 | CONFIG_SND_AC97_CODEC=y | 1071 | CONFIG_SND_AC97_CODEC=y |
| 1100 | CONFIG_SND_DRIVERS=y | 1072 | CONFIG_SND_DRIVERS=y |
| 1101 | # CONFIG_SND_DUMMY is not set | 1073 | # CONFIG_SND_DUMMY is not set |
| @@ -1122,6 +1094,7 @@ CONFIG_SND_PCI=y | |||
| 1122 | # CONFIG_SND_CS4281 is not set | 1094 | # CONFIG_SND_CS4281 is not set |
| 1123 | # CONFIG_SND_CS46XX is not set | 1095 | # CONFIG_SND_CS46XX is not set |
| 1124 | # CONFIG_SND_CS5530 is not set | 1096 | # CONFIG_SND_CS5530 is not set |
| 1097 | # CONFIG_SND_CTXFI is not set | ||
| 1125 | # CONFIG_SND_DARLA20 is not set | 1098 | # CONFIG_SND_DARLA20 is not set |
| 1126 | # CONFIG_SND_GINA20 is not set | 1099 | # CONFIG_SND_GINA20 is not set |
| 1127 | # CONFIG_SND_LAYLA20 is not set | 1100 | # CONFIG_SND_LAYLA20 is not set |
| @@ -1152,6 +1125,7 @@ CONFIG_SND_PCI=y | |||
| 1152 | CONFIG_SND_INTEL8X0=y | 1125 | CONFIG_SND_INTEL8X0=y |
| 1153 | # CONFIG_SND_INTEL8X0M is not set | 1126 | # CONFIG_SND_INTEL8X0M is not set |
| 1154 | # CONFIG_SND_KORG1212 is not set | 1127 | # CONFIG_SND_KORG1212 is not set |
| 1128 | # CONFIG_SND_LX6464ES is not set | ||
| 1155 | # CONFIG_SND_MAESTRO3 is not set | 1129 | # CONFIG_SND_MAESTRO3 is not set |
| 1156 | # CONFIG_SND_MIXART is not set | 1130 | # CONFIG_SND_MIXART is not set |
| 1157 | # CONFIG_SND_NM256 is not set | 1131 | # CONFIG_SND_NM256 is not set |
| @@ -1196,7 +1170,7 @@ CONFIG_HID_BELKIN=y | |||
| 1196 | CONFIG_HID_CHERRY=y | 1170 | CONFIG_HID_CHERRY=y |
| 1197 | CONFIG_HID_CHICONY=y | 1171 | CONFIG_HID_CHICONY=y |
| 1198 | CONFIG_HID_CYPRESS=y | 1172 | CONFIG_HID_CYPRESS=y |
| 1199 | # CONFIG_DRAGONRISE_FF is not set | 1173 | # CONFIG_HID_DRAGONRISE is not set |
| 1200 | CONFIG_HID_EZKEY=y | 1174 | CONFIG_HID_EZKEY=y |
| 1201 | # CONFIG_HID_KYE is not set | 1175 | # CONFIG_HID_KYE is not set |
| 1202 | CONFIG_HID_GYRATION=y | 1176 | CONFIG_HID_GYRATION=y |
| @@ -1213,10 +1187,11 @@ CONFIG_HID_PETALYNX=y | |||
| 1213 | CONFIG_HID_SAMSUNG=y | 1187 | CONFIG_HID_SAMSUNG=y |
| 1214 | CONFIG_HID_SONY=y | 1188 | CONFIG_HID_SONY=y |
| 1215 | CONFIG_HID_SUNPLUS=y | 1189 | CONFIG_HID_SUNPLUS=y |
| 1216 | # CONFIG_GREENASIA_FF is not set | 1190 | # CONFIG_HID_GREENASIA is not set |
| 1191 | # CONFIG_HID_SMARTJOYPLUS is not set | ||
| 1217 | # CONFIG_HID_TOPSEED is not set | 1192 | # CONFIG_HID_TOPSEED is not set |
| 1218 | CONFIG_THRUSTMASTER_FF=m | 1193 | # CONFIG_HID_THRUSTMASTER is not set |
| 1219 | CONFIG_ZEROPLUS_FF=m | 1194 | # CONFIG_HID_ZEROPLUS is not set |
| 1220 | CONFIG_USB_SUPPORT=y | 1195 | CONFIG_USB_SUPPORT=y |
| 1221 | CONFIG_USB_ARCH_HAS_HCD=y | 1196 | CONFIG_USB_ARCH_HAS_HCD=y |
| 1222 | CONFIG_USB_ARCH_HAS_OHCI=y | 1197 | CONFIG_USB_ARCH_HAS_OHCI=y |
| @@ -1242,6 +1217,7 @@ CONFIG_USB_MON=y | |||
| 1242 | # USB Host Controller Drivers | 1217 | # USB Host Controller Drivers |
| 1243 | # | 1218 | # |
| 1244 | # CONFIG_USB_C67X00_HCD is not set | 1219 | # CONFIG_USB_C67X00_HCD is not set |
| 1220 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1245 | CONFIG_USB_EHCI_HCD=y | 1221 | CONFIG_USB_EHCI_HCD=y |
| 1246 | CONFIG_USB_EHCI_ROOT_HUB_TT=y | 1222 | CONFIG_USB_EHCI_ROOT_HUB_TT=y |
| 1247 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1223 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1251,9 +1227,9 @@ CONFIG_USB_EHCI_HCD_PPC_OF=y | |||
| 1251 | # CONFIG_USB_ISP116X_HCD is not set | 1227 | # CONFIG_USB_ISP116X_HCD is not set |
| 1252 | # CONFIG_USB_ISP1760_HCD is not set | 1228 | # CONFIG_USB_ISP1760_HCD is not set |
| 1253 | CONFIG_USB_OHCI_HCD=y | 1229 | CONFIG_USB_OHCI_HCD=y |
| 1254 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1255 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y | 1230 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y |
| 1256 | CONFIG_USB_OHCI_HCD_PPC_OF_LE=y | 1231 | CONFIG_USB_OHCI_HCD_PPC_OF_LE=y |
| 1232 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1257 | CONFIG_USB_OHCI_HCD_PCI=y | 1233 | CONFIG_USB_OHCI_HCD_PCI=y |
| 1258 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y | 1234 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y |
| 1259 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y | 1235 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y |
| @@ -1352,8 +1328,6 @@ CONFIG_EDAC=y | |||
| 1352 | # CONFIG_EDAC_DEBUG is not set | 1328 | # CONFIG_EDAC_DEBUG is not set |
| 1353 | CONFIG_EDAC_MM_EDAC=y | 1329 | CONFIG_EDAC_MM_EDAC=y |
| 1354 | CONFIG_EDAC_MPC85XX=y | 1330 | CONFIG_EDAC_MPC85XX=y |
| 1355 | # CONFIG_EDAC_AMD8131 is not set | ||
| 1356 | # CONFIG_EDAC_AMD8111 is not set | ||
| 1357 | CONFIG_RTC_LIB=y | 1331 | CONFIG_RTC_LIB=y |
| 1358 | CONFIG_RTC_CLASS=y | 1332 | CONFIG_RTC_CLASS=y |
| 1359 | CONFIG_RTC_HCTOSYS=y | 1333 | CONFIG_RTC_HCTOSYS=y |
| @@ -1385,6 +1359,7 @@ CONFIG_RTC_INTF_DEV=y | |||
| 1385 | # CONFIG_RTC_DRV_S35390A is not set | 1359 | # CONFIG_RTC_DRV_S35390A is not set |
| 1386 | # CONFIG_RTC_DRV_FM3130 is not set | 1360 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1387 | # CONFIG_RTC_DRV_RX8581 is not set | 1361 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1362 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1388 | 1363 | ||
| 1389 | # | 1364 | # |
| 1390 | # SPI RTC drivers | 1365 | # SPI RTC drivers |
| @@ -1425,6 +1400,10 @@ CONFIG_DMA_ENGINE=y | |||
| 1425 | # CONFIG_DMATEST is not set | 1400 | # CONFIG_DMATEST is not set |
| 1426 | # CONFIG_AUXDISPLAY is not set | 1401 | # CONFIG_AUXDISPLAY is not set |
| 1427 | # CONFIG_UIO is not set | 1402 | # CONFIG_UIO is not set |
| 1403 | |||
| 1404 | # | ||
| 1405 | # TI VLYNQ | ||
| 1406 | # | ||
| 1428 | # CONFIG_STAGING is not set | 1407 | # CONFIG_STAGING is not set |
| 1429 | 1408 | ||
| 1430 | # | 1409 | # |
| @@ -1445,11 +1424,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1445 | # CONFIG_REISERFS_FS is not set | 1424 | # CONFIG_REISERFS_FS is not set |
| 1446 | # CONFIG_JFS_FS is not set | 1425 | # CONFIG_JFS_FS is not set |
| 1447 | # CONFIG_FS_POSIX_ACL is not set | 1426 | # CONFIG_FS_POSIX_ACL is not set |
| 1448 | CONFIG_FILE_LOCKING=y | ||
| 1449 | # CONFIG_XFS_FS is not set | 1427 | # CONFIG_XFS_FS is not set |
| 1450 | # CONFIG_GFS2_FS is not set | 1428 | # CONFIG_GFS2_FS is not set |
| 1451 | # CONFIG_OCFS2_FS is not set | 1429 | # CONFIG_OCFS2_FS is not set |
| 1452 | # CONFIG_BTRFS_FS is not set | 1430 | # CONFIG_BTRFS_FS is not set |
| 1431 | CONFIG_FILE_LOCKING=y | ||
| 1432 | CONFIG_FSNOTIFY=y | ||
| 1453 | CONFIG_DNOTIFY=y | 1433 | CONFIG_DNOTIFY=y |
| 1454 | CONFIG_INOTIFY=y | 1434 | CONFIG_INOTIFY=y |
| 1455 | CONFIG_INOTIFY_USER=y | 1435 | CONFIG_INOTIFY_USER=y |
| @@ -1524,6 +1504,7 @@ CONFIG_NFS_FS=y | |||
| 1524 | CONFIG_NFS_V3=y | 1504 | CONFIG_NFS_V3=y |
| 1525 | # CONFIG_NFS_V3_ACL is not set | 1505 | # CONFIG_NFS_V3_ACL is not set |
| 1526 | CONFIG_NFS_V4=y | 1506 | CONFIG_NFS_V4=y |
| 1507 | # CONFIG_NFS_V4_1 is not set | ||
| 1527 | CONFIG_ROOT_NFS=y | 1508 | CONFIG_ROOT_NFS=y |
| 1528 | CONFIG_NFSD=y | 1509 | CONFIG_NFSD=y |
| 1529 | # CONFIG_NFSD_V3 is not set | 1510 | # CONFIG_NFSD_V3 is not set |
| @@ -1628,6 +1609,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1628 | CONFIG_HAS_DMA=y | 1609 | CONFIG_HAS_DMA=y |
| 1629 | CONFIG_HAVE_LMB=y | 1610 | CONFIG_HAVE_LMB=y |
| 1630 | CONFIG_NLATTR=y | 1611 | CONFIG_NLATTR=y |
| 1612 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1631 | 1613 | ||
| 1632 | # | 1614 | # |
| 1633 | # Kernel hacking | 1615 | # Kernel hacking |
| @@ -1658,6 +1640,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 1658 | # CONFIG_RT_MUTEX_TESTER is not set | 1640 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1659 | # CONFIG_DEBUG_SPINLOCK is not set | 1641 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1660 | # CONFIG_DEBUG_MUTEXES is not set | 1642 | # CONFIG_DEBUG_MUTEXES is not set |
| 1643 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1644 | # CONFIG_PROVE_LOCKING is not set | ||
| 1645 | # CONFIG_LOCK_STAT is not set | ||
| 1661 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1646 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1662 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1647 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1663 | # CONFIG_DEBUG_KOBJECT is not set | 1648 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1670,7 +1655,6 @@ CONFIG_DEBUG_INFO=y | |||
| 1670 | # CONFIG_DEBUG_LIST is not set | 1655 | # CONFIG_DEBUG_LIST is not set |
| 1671 | # CONFIG_DEBUG_SG is not set | 1656 | # CONFIG_DEBUG_SG is not set |
| 1672 | # CONFIG_DEBUG_NOTIFIERS is not set | 1657 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1673 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1674 | # CONFIG_RCU_TORTURE_TEST is not set | 1658 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1675 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1659 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1676 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1660 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1684,16 +1668,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1684 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1668 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1685 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1669 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1686 | CONFIG_TRACING_SUPPORT=y | 1670 | CONFIG_TRACING_SUPPORT=y |
| 1687 | 1671 | CONFIG_FTRACE=y | |
| 1688 | # | ||
| 1689 | # Tracers | ||
| 1690 | # | ||
| 1691 | # CONFIG_FUNCTION_TRACER is not set | 1672 | # CONFIG_FUNCTION_TRACER is not set |
| 1673 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1692 | # CONFIG_SCHED_TRACER is not set | 1674 | # CONFIG_SCHED_TRACER is not set |
| 1693 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1675 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1694 | # CONFIG_EVENT_TRACER is not set | ||
| 1695 | # CONFIG_BOOT_TRACER is not set | 1676 | # CONFIG_BOOT_TRACER is not set |
| 1696 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1677 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1678 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1679 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1697 | # CONFIG_STACK_TRACER is not set | 1680 | # CONFIG_STACK_TRACER is not set |
| 1698 | # CONFIG_KMEMTRACE is not set | 1681 | # CONFIG_KMEMTRACE is not set |
| 1699 | # CONFIG_WORKQUEUE_TRACER is not set | 1682 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -1702,9 +1685,13 @@ CONFIG_TRACING_SUPPORT=y | |||
| 1702 | # CONFIG_SAMPLES is not set | 1685 | # CONFIG_SAMPLES is not set |
| 1703 | CONFIG_HAVE_ARCH_KGDB=y | 1686 | CONFIG_HAVE_ARCH_KGDB=y |
| 1704 | # CONFIG_KGDB is not set | 1687 | # CONFIG_KGDB is not set |
| 1688 | # CONFIG_KMEMCHECK is not set | ||
| 1689 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1690 | CONFIG_PPC_WERROR=y | ||
| 1705 | CONFIG_PRINT_STACK_DEPTH=64 | 1691 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1706 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1692 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1707 | # CONFIG_DEBUG_STACK_USAGE is not set | 1693 | # CONFIG_DEBUG_STACK_USAGE is not set |
| 1694 | # CONFIG_PPC_EMULATED_STATS is not set | ||
| 1708 | # CONFIG_CODE_PATCHING_SELFTEST is not set | 1695 | # CONFIG_CODE_PATCHING_SELFTEST is not set |
| 1709 | # CONFIG_FTR_FIXUP_SELFTEST is not set | 1696 | # CONFIG_FTR_FIXUP_SELFTEST is not set |
| 1710 | # CONFIG_MSI_BITMAP_SELFTEST is not set | 1697 | # CONFIG_MSI_BITMAP_SELFTEST is not set |
diff --git a/arch/powerpc/configs/mpc85xx_smp_defconfig b/arch/powerpc/configs/mpc85xx_smp_defconfig index 1aa1c508d600..db082ce5a1c5 100644 --- a/arch/powerpc/configs/mpc85xx_smp_defconfig +++ b/arch/powerpc/configs/mpc85xx_smp_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc2 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Tue Apr 21 15:41:18 2009 | 4 | # Wed Jul 29 23:31:56 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | CONFIG_PPC_85xx=y | 12 | CONFIG_PPC_85xx=y |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -35,15 +35,16 @@ CONFIG_GENERIC_TIME=y | |||
| 35 | CONFIG_GENERIC_TIME_VSYSCALL=y | 35 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 36 | CONFIG_GENERIC_CLOCKEVENTS=y | 36 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 37 | CONFIG_GENERIC_HARDIRQS=y | 37 | CONFIG_GENERIC_HARDIRQS=y |
| 38 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 39 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 39 | CONFIG_IRQ_PER_CPU=y | 40 | CONFIG_IRQ_PER_CPU=y |
| 40 | CONFIG_STACKTRACE_SUPPORT=y | 41 | CONFIG_STACKTRACE_SUPPORT=y |
| 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 42 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 43 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 42 | CONFIG_LOCKDEP_SUPPORT=y | 44 | CONFIG_LOCKDEP_SUPPORT=y |
| 43 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 45 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 44 | CONFIG_ARCH_HAS_ILOG2_U32=y | 46 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 45 | CONFIG_GENERIC_HWEIGHT=y | 47 | CONFIG_GENERIC_HWEIGHT=y |
| 46 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 48 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 48 | CONFIG_GENERIC_GPIO=y | 49 | CONFIG_GENERIC_GPIO=y |
| 49 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 50 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -58,11 +59,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 58 | CONFIG_GENERIC_TBSYNC=y | 59 | CONFIG_GENERIC_TBSYNC=y |
| 59 | CONFIG_AUDIT_ARCH=y | 60 | CONFIG_AUDIT_ARCH=y |
| 60 | CONFIG_GENERIC_BUG=y | 61 | CONFIG_GENERIC_BUG=y |
| 62 | CONFIG_DTC=y | ||
| 61 | CONFIG_DEFAULT_UIMAGE=y | 63 | CONFIG_DEFAULT_UIMAGE=y |
| 62 | # CONFIG_PPC_DCR_NATIVE is not set | 64 | # CONFIG_PPC_DCR_NATIVE is not set |
| 63 | # CONFIG_PPC_DCR_MMIO is not set | 65 | # CONFIG_PPC_DCR_MMIO is not set |
| 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 66 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 67 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 68 | CONFIG_CONSTRUCTORS=y | ||
| 66 | 69 | ||
| 67 | # | 70 | # |
| 68 | # General setup | 71 | # General setup |
| @@ -117,7 +120,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 117 | CONFIG_KALLSYMS=y | 120 | CONFIG_KALLSYMS=y |
| 118 | CONFIG_KALLSYMS_ALL=y | 121 | CONFIG_KALLSYMS_ALL=y |
| 119 | CONFIG_KALLSYMS_EXTRA_PASS=y | 122 | CONFIG_KALLSYMS_EXTRA_PASS=y |
| 120 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 121 | CONFIG_HOTPLUG=y | 123 | CONFIG_HOTPLUG=y |
| 122 | CONFIG_PRINTK=y | 124 | CONFIG_PRINTK=y |
| 123 | CONFIG_BUG=y | 125 | CONFIG_BUG=y |
| @@ -130,9 +132,16 @@ CONFIG_TIMERFD=y | |||
| 130 | CONFIG_EVENTFD=y | 132 | CONFIG_EVENTFD=y |
| 131 | CONFIG_SHMEM=y | 133 | CONFIG_SHMEM=y |
| 132 | CONFIG_AIO=y | 134 | CONFIG_AIO=y |
| 135 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 136 | |||
| 137 | # | ||
| 138 | # Performance Counters | ||
| 139 | # | ||
| 140 | # CONFIG_PERF_COUNTERS is not set | ||
| 133 | CONFIG_VM_EVENT_COUNTERS=y | 141 | CONFIG_VM_EVENT_COUNTERS=y |
| 134 | CONFIG_PCI_QUIRKS=y | 142 | CONFIG_PCI_QUIRKS=y |
| 135 | CONFIG_SLUB_DEBUG=y | 143 | CONFIG_SLUB_DEBUG=y |
| 144 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 136 | CONFIG_COMPAT_BRK=y | 145 | CONFIG_COMPAT_BRK=y |
| 137 | # CONFIG_SLAB is not set | 146 | # CONFIG_SLAB is not set |
| 138 | CONFIG_SLUB=y | 147 | CONFIG_SLUB=y |
| @@ -148,6 +157,11 @@ CONFIG_HAVE_KRETPROBES=y | |||
| 148 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 157 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 149 | CONFIG_USE_GENERIC_SMP_HELPERS=y | 158 | CONFIG_USE_GENERIC_SMP_HELPERS=y |
| 150 | CONFIG_HAVE_CLK=y | 159 | CONFIG_HAVE_CLK=y |
| 160 | |||
| 161 | # | ||
| 162 | # GCOV-based kernel profiling | ||
| 163 | # | ||
| 164 | # CONFIG_GCOV_KERNEL is not set | ||
| 151 | # CONFIG_SLOW_WORK is not set | 165 | # CONFIG_SLOW_WORK is not set |
| 152 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 166 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 153 | CONFIG_SLABINFO=y | 167 | CONFIG_SLABINFO=y |
| @@ -161,7 +175,7 @@ CONFIG_MODVERSIONS=y | |||
| 161 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 175 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 162 | CONFIG_STOP_MACHINE=y | 176 | CONFIG_STOP_MACHINE=y |
| 163 | CONFIG_BLOCK=y | 177 | CONFIG_BLOCK=y |
| 164 | CONFIG_LBD=y | 178 | CONFIG_LBDAF=y |
| 165 | # CONFIG_BLK_DEV_BSG is not set | 179 | # CONFIG_BLK_DEV_BSG is not set |
| 166 | # CONFIG_BLK_DEV_INTEGRITY is not set | 180 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 167 | 181 | ||
| @@ -194,6 +208,7 @@ CONFIG_MPC8536_DS=y | |||
| 194 | CONFIG_MPC85xx_DS=y | 208 | CONFIG_MPC85xx_DS=y |
| 195 | CONFIG_SOCRATES=y | 209 | CONFIG_SOCRATES=y |
| 196 | CONFIG_KSI8560=y | 210 | CONFIG_KSI8560=y |
| 211 | # CONFIG_XES_MPC85xx is not set | ||
| 197 | CONFIG_STX_GP3=y | 212 | CONFIG_STX_GP3=y |
| 198 | CONFIG_TQM8540=y | 213 | CONFIG_TQM8540=y |
| 199 | CONFIG_TQM8541=y | 214 | CONFIG_TQM8541=y |
| @@ -244,7 +259,9 @@ CONFIG_BINFMT_ELF=y | |||
| 244 | # CONFIG_HAVE_AOUT is not set | 259 | # CONFIG_HAVE_AOUT is not set |
| 245 | CONFIG_BINFMT_MISC=m | 260 | CONFIG_BINFMT_MISC=m |
| 246 | CONFIG_MATH_EMULATION=y | 261 | CONFIG_MATH_EMULATION=y |
| 247 | # CONFIG_IOMMU_HELPER is not set | 262 | CONFIG_IOMMU_HELPER=y |
| 263 | CONFIG_SWIOTLB=y | ||
| 264 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y | ||
| 248 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 265 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 249 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 266 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 250 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 267 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -264,9 +281,9 @@ CONFIG_MIGRATION=y | |||
| 264 | CONFIG_ZONE_DMA_FLAG=1 | 281 | CONFIG_ZONE_DMA_FLAG=1 |
| 265 | CONFIG_BOUNCE=y | 282 | CONFIG_BOUNCE=y |
| 266 | CONFIG_VIRT_TO_BUS=y | 283 | CONFIG_VIRT_TO_BUS=y |
| 267 | CONFIG_UNEVICTABLE_LRU=y | ||
| 268 | CONFIG_HAVE_MLOCK=y | 284 | CONFIG_HAVE_MLOCK=y |
| 269 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 285 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 286 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 270 | CONFIG_PPC_4K_PAGES=y | 287 | CONFIG_PPC_4K_PAGES=y |
| 271 | # CONFIG_PPC_16K_PAGES is not set | 288 | # CONFIG_PPC_16K_PAGES is not set |
| 272 | # CONFIG_PPC_64K_PAGES is not set | 289 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -300,7 +317,8 @@ CONFIG_ARCH_SUPPORTS_MSI=y | |||
| 300 | # CONFIG_PCI_IOV is not set | 317 | # CONFIG_PCI_IOV is not set |
| 301 | # CONFIG_PCCARD is not set | 318 | # CONFIG_PCCARD is not set |
| 302 | # CONFIG_HOTPLUG_PCI is not set | 319 | # CONFIG_HOTPLUG_PCI is not set |
| 303 | # CONFIG_HAS_RAPIDIO is not set | 320 | CONFIG_HAS_RAPIDIO=y |
| 321 | # CONFIG_RAPIDIO is not set | ||
| 304 | 322 | ||
| 305 | # | 323 | # |
| 306 | # Advanced setup | 324 | # Advanced setup |
| @@ -410,6 +428,7 @@ CONFIG_SCTP_HMAC_MD5=y | |||
| 410 | # CONFIG_ECONET is not set | 428 | # CONFIG_ECONET is not set |
| 411 | # CONFIG_WAN_ROUTER is not set | 429 | # CONFIG_WAN_ROUTER is not set |
| 412 | # CONFIG_PHONET is not set | 430 | # CONFIG_PHONET is not set |
| 431 | # CONFIG_IEEE802154 is not set | ||
| 413 | # CONFIG_NET_SCHED is not set | 432 | # CONFIG_NET_SCHED is not set |
| 414 | # CONFIG_DCB is not set | 433 | # CONFIG_DCB is not set |
| 415 | 434 | ||
| @@ -428,7 +447,11 @@ CONFIG_WIRELESS=y | |||
| 428 | CONFIG_WIRELESS_OLD_REGULATORY=y | 447 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 429 | # CONFIG_WIRELESS_EXT is not set | 448 | # CONFIG_WIRELESS_EXT is not set |
| 430 | # CONFIG_LIB80211 is not set | 449 | # CONFIG_LIB80211 is not set |
| 431 | # CONFIG_MAC80211 is not set | 450 | |
| 451 | # | ||
| 452 | # CFG80211 needs to be enabled for MAC80211 | ||
| 453 | # | ||
| 454 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 432 | # CONFIG_WIMAX is not set | 455 | # CONFIG_WIMAX is not set |
| 433 | # CONFIG_RFKILL is not set | 456 | # CONFIG_RFKILL is not set |
| 434 | # CONFIG_NET_9P is not set | 457 | # CONFIG_NET_9P is not set |
| @@ -454,6 +477,7 @@ CONFIG_EXTRA_FIRMWARE="" | |||
| 454 | CONFIG_OF_DEVICE=y | 477 | CONFIG_OF_DEVICE=y |
| 455 | CONFIG_OF_GPIO=y | 478 | CONFIG_OF_GPIO=y |
| 456 | CONFIG_OF_I2C=y | 479 | CONFIG_OF_I2C=y |
| 480 | CONFIG_OF_MDIO=y | ||
| 457 | # CONFIG_PARPORT is not set | 481 | # CONFIG_PARPORT is not set |
| 458 | CONFIG_BLK_DEV=y | 482 | CONFIG_BLK_DEV=y |
| 459 | # CONFIG_BLK_DEV_FD is not set | 483 | # CONFIG_BLK_DEV_FD is not set |
| @@ -489,7 +513,9 @@ CONFIG_MISC_DEVICES=y | |||
| 489 | # | 513 | # |
| 490 | # CONFIG_EEPROM_AT24 is not set | 514 | # CONFIG_EEPROM_AT24 is not set |
| 491 | CONFIG_EEPROM_LEGACY=y | 515 | CONFIG_EEPROM_LEGACY=y |
| 516 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 492 | # CONFIG_EEPROM_93CX6 is not set | 517 | # CONFIG_EEPROM_93CX6 is not set |
| 518 | # CONFIG_CB710_CORE is not set | ||
| 493 | CONFIG_HAVE_IDE=y | 519 | CONFIG_HAVE_IDE=y |
| 494 | # CONFIG_IDE is not set | 520 | # CONFIG_IDE is not set |
| 495 | 521 | ||
| @@ -513,10 +539,6 @@ CONFIG_BLK_DEV_SR=y | |||
| 513 | # CONFIG_BLK_DEV_SR_VENDOR is not set | 539 | # CONFIG_BLK_DEV_SR_VENDOR is not set |
| 514 | CONFIG_CHR_DEV_SG=y | 540 | CONFIG_CHR_DEV_SG=y |
| 515 | # CONFIG_CHR_DEV_SCH is not set | 541 | # CONFIG_CHR_DEV_SCH is not set |
| 516 | |||
| 517 | # | ||
| 518 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 519 | # | ||
| 520 | CONFIG_SCSI_MULTI_LUN=y | 542 | CONFIG_SCSI_MULTI_LUN=y |
| 521 | # CONFIG_SCSI_CONSTANTS is not set | 543 | # CONFIG_SCSI_CONSTANTS is not set |
| 522 | CONFIG_SCSI_LOGGING=y | 544 | CONFIG_SCSI_LOGGING=y |
| @@ -534,6 +556,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 534 | CONFIG_SCSI_LOWLEVEL=y | 556 | CONFIG_SCSI_LOWLEVEL=y |
| 535 | # CONFIG_ISCSI_TCP is not set | 557 | # CONFIG_ISCSI_TCP is not set |
| 536 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 558 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 559 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 537 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 560 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 538 | # CONFIG_SCSI_3W_9XXX is not set | 561 | # CONFIG_SCSI_3W_9XXX is not set |
| 539 | # CONFIG_SCSI_ACARD is not set | 562 | # CONFIG_SCSI_ACARD is not set |
| @@ -542,6 +565,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 542 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 565 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 543 | # CONFIG_SCSI_AIC79XX is not set | 566 | # CONFIG_SCSI_AIC79XX is not set |
| 544 | # CONFIG_SCSI_AIC94XX is not set | 567 | # CONFIG_SCSI_AIC94XX is not set |
| 568 | # CONFIG_SCSI_MVSAS is not set | ||
| 545 | # CONFIG_SCSI_DPT_I2O is not set | 569 | # CONFIG_SCSI_DPT_I2O is not set |
| 546 | # CONFIG_SCSI_ADVANSYS is not set | 570 | # CONFIG_SCSI_ADVANSYS is not set |
| 547 | # CONFIG_SCSI_ARCMSR is not set | 571 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -561,7 +585,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 561 | # CONFIG_SCSI_IPS is not set | 585 | # CONFIG_SCSI_IPS is not set |
| 562 | # CONFIG_SCSI_INITIO is not set | 586 | # CONFIG_SCSI_INITIO is not set |
| 563 | # CONFIG_SCSI_INIA100 is not set | 587 | # CONFIG_SCSI_INIA100 is not set |
| 564 | # CONFIG_SCSI_MVSAS is not set | ||
| 565 | # CONFIG_SCSI_STEX is not set | 588 | # CONFIG_SCSI_STEX is not set |
| 566 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 589 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 567 | # CONFIG_SCSI_IPR is not set | 590 | # CONFIG_SCSI_IPR is not set |
| @@ -645,14 +668,17 @@ CONFIG_PATA_ALI=y | |||
| 645 | # | 668 | # |
| 646 | 669 | ||
| 647 | # | 670 | # |
| 648 | # Enable only one of the two stacks, unless you know what you are doing | 671 | # You can enable one or both FireWire driver stacks. |
| 672 | # | ||
| 673 | |||
| 674 | # | ||
| 675 | # See the help texts for more information. | ||
| 649 | # | 676 | # |
| 650 | # CONFIG_FIREWIRE is not set | 677 | # CONFIG_FIREWIRE is not set |
| 651 | # CONFIG_IEEE1394 is not set | 678 | # CONFIG_IEEE1394 is not set |
| 652 | # CONFIG_I2O is not set | 679 | # CONFIG_I2O is not set |
| 653 | # CONFIG_MACINTOSH_DRIVERS is not set | 680 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 654 | CONFIG_NETDEVICES=y | 681 | CONFIG_NETDEVICES=y |
| 655 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 656 | CONFIG_DUMMY=y | 682 | CONFIG_DUMMY=y |
| 657 | # CONFIG_BONDING is not set | 683 | # CONFIG_BONDING is not set |
| 658 | # CONFIG_MACVLAN is not set | 684 | # CONFIG_MACVLAN is not set |
| @@ -699,6 +725,7 @@ CONFIG_MII=y | |||
| 699 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 725 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 700 | # CONFIG_NET_PCI is not set | 726 | # CONFIG_NET_PCI is not set |
| 701 | # CONFIG_B44 is not set | 727 | # CONFIG_B44 is not set |
| 728 | # CONFIG_KS8842 is not set | ||
| 702 | # CONFIG_ATL2 is not set | 729 | # CONFIG_ATL2 is not set |
| 703 | CONFIG_FS_ENET=y | 730 | CONFIG_FS_ENET=y |
| 704 | CONFIG_FS_ENET_HAS_SCC=y | 731 | CONFIG_FS_ENET_HAS_SCC=y |
| @@ -722,11 +749,13 @@ CONFIG_NETDEV_1000=y | |||
| 722 | # CONFIG_VIA_VELOCITY is not set | 749 | # CONFIG_VIA_VELOCITY is not set |
| 723 | # CONFIG_TIGON3 is not set | 750 | # CONFIG_TIGON3 is not set |
| 724 | # CONFIG_BNX2 is not set | 751 | # CONFIG_BNX2 is not set |
| 752 | # CONFIG_CNIC is not set | ||
| 725 | CONFIG_FSL_PQ_MDIO=y | 753 | CONFIG_FSL_PQ_MDIO=y |
| 726 | CONFIG_GIANFAR=y | 754 | CONFIG_GIANFAR=y |
| 727 | CONFIG_UCC_GETH=y | 755 | CONFIG_UCC_GETH=y |
| 728 | # CONFIG_UGETH_MAGIC_PACKET is not set | 756 | # CONFIG_UGETH_MAGIC_PACKET is not set |
| 729 | # CONFIG_UGETH_TX_ON_DEMAND is not set | 757 | # CONFIG_UGETH_TX_ON_DEMAND is not set |
| 758 | # CONFIG_MV643XX_ETH is not set | ||
| 730 | # CONFIG_QLA3XXX is not set | 759 | # CONFIG_QLA3XXX is not set |
| 731 | # CONFIG_ATL1 is not set | 760 | # CONFIG_ATL1 is not set |
| 732 | # CONFIG_ATL1E is not set | 761 | # CONFIG_ATL1E is not set |
| @@ -901,6 +930,7 @@ CONFIG_I2C_HELPER_AUTO=y | |||
| 901 | # I2C system bus drivers (mostly embedded / system-on-chip) | 930 | # I2C system bus drivers (mostly embedded / system-on-chip) |
| 902 | # | 931 | # |
| 903 | CONFIG_I2C_CPM=m | 932 | CONFIG_I2C_CPM=m |
| 933 | # CONFIG_I2C_DESIGNWARE is not set | ||
| 904 | # CONFIG_I2C_GPIO is not set | 934 | # CONFIG_I2C_GPIO is not set |
| 905 | CONFIG_I2C_MPC=y | 935 | CONFIG_I2C_MPC=y |
| 906 | # CONFIG_I2C_OCORES is not set | 936 | # CONFIG_I2C_OCORES is not set |
| @@ -931,13 +961,17 @@ CONFIG_I2C_MPC=y | |||
| 931 | # CONFIG_SENSORS_PCF8574 is not set | 961 | # CONFIG_SENSORS_PCF8574 is not set |
| 932 | # CONFIG_PCF8575 is not set | 962 | # CONFIG_PCF8575 is not set |
| 933 | # CONFIG_SENSORS_PCA9539 is not set | 963 | # CONFIG_SENSORS_PCA9539 is not set |
| 934 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 935 | # CONFIG_SENSORS_TSL2550 is not set | 964 | # CONFIG_SENSORS_TSL2550 is not set |
| 936 | # CONFIG_I2C_DEBUG_CORE is not set | 965 | # CONFIG_I2C_DEBUG_CORE is not set |
| 937 | # CONFIG_I2C_DEBUG_ALGO is not set | 966 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 938 | # CONFIG_I2C_DEBUG_BUS is not set | 967 | # CONFIG_I2C_DEBUG_BUS is not set |
| 939 | # CONFIG_I2C_DEBUG_CHIP is not set | 968 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 940 | # CONFIG_SPI is not set | 969 | # CONFIG_SPI is not set |
| 970 | |||
| 971 | # | ||
| 972 | # PPS support | ||
| 973 | # | ||
| 974 | # CONFIG_PPS is not set | ||
| 941 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 975 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 942 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 976 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 943 | CONFIG_GPIOLIB=y | 977 | CONFIG_GPIOLIB=y |
| @@ -991,76 +1025,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 991 | # CONFIG_MFD_WM8400 is not set | 1025 | # CONFIG_MFD_WM8400 is not set |
| 992 | # CONFIG_MFD_WM8350_I2C is not set | 1026 | # CONFIG_MFD_WM8350_I2C is not set |
| 993 | # CONFIG_MFD_PCF50633 is not set | 1027 | # CONFIG_MFD_PCF50633 is not set |
| 1028 | # CONFIG_AB3100_CORE is not set | ||
| 994 | # CONFIG_REGULATOR is not set | 1029 | # CONFIG_REGULATOR is not set |
| 995 | 1030 | # CONFIG_MEDIA_SUPPORT is not set | |
| 996 | # | ||
| 997 | # Multimedia devices | ||
| 998 | # | ||
| 999 | |||
| 1000 | # | ||
| 1001 | # Multimedia core support | ||
| 1002 | # | ||
| 1003 | # CONFIG_VIDEO_DEV is not set | ||
| 1004 | CONFIG_DVB_CORE=m | ||
| 1005 | CONFIG_VIDEO_MEDIA=m | ||
| 1006 | |||
| 1007 | # | ||
| 1008 | # Multimedia drivers | ||
| 1009 | # | ||
| 1010 | # CONFIG_MEDIA_ATTACH is not set | ||
| 1011 | CONFIG_MEDIA_TUNER=m | ||
| 1012 | # CONFIG_MEDIA_TUNER_CUSTOMISE is not set | ||
| 1013 | CONFIG_MEDIA_TUNER_SIMPLE=m | ||
| 1014 | CONFIG_MEDIA_TUNER_TDA8290=m | ||
| 1015 | CONFIG_MEDIA_TUNER_TDA9887=m | ||
| 1016 | CONFIG_MEDIA_TUNER_TEA5761=m | ||
| 1017 | CONFIG_MEDIA_TUNER_TEA5767=m | ||
| 1018 | CONFIG_MEDIA_TUNER_MT20XX=m | ||
| 1019 | CONFIG_MEDIA_TUNER_XC2028=m | ||
| 1020 | CONFIG_MEDIA_TUNER_XC5000=m | ||
| 1021 | CONFIG_MEDIA_TUNER_MC44S803=m | ||
| 1022 | # CONFIG_DVB_DYNAMIC_MINORS is not set | ||
| 1023 | CONFIG_DVB_CAPTURE_DRIVERS=y | ||
| 1024 | |||
| 1025 | # | ||
| 1026 | # Supported SAA7146 based PCI Adapters | ||
| 1027 | # | ||
| 1028 | # CONFIG_TTPCI_EEPROM is not set | ||
| 1029 | # CONFIG_DVB_BUDGET_CORE is not set | ||
| 1030 | |||
| 1031 | # | ||
| 1032 | # Supported USB Adapters | ||
| 1033 | # | ||
| 1034 | # CONFIG_DVB_USB is not set | ||
| 1035 | # CONFIG_DVB_TTUSB_BUDGET is not set | ||
| 1036 | # CONFIG_DVB_TTUSB_DEC is not set | ||
| 1037 | # CONFIG_DVB_SIANO_SMS1XXX is not set | ||
| 1038 | |||
| 1039 | # | ||
| 1040 | # Supported FlexCopII (B2C2) Adapters | ||
| 1041 | # | ||
| 1042 | # CONFIG_DVB_B2C2_FLEXCOP is not set | ||
| 1043 | |||
| 1044 | # | ||
| 1045 | # Supported BT878 Adapters | ||
| 1046 | # | ||
| 1047 | |||
| 1048 | # | ||
| 1049 | # Supported Pluto2 Adapters | ||
| 1050 | # | ||
| 1051 | # CONFIG_DVB_PLUTO2 is not set | ||
| 1052 | |||
| 1053 | # | ||
| 1054 | # Supported SDMC DM1105 Adapters | ||
| 1055 | # | ||
| 1056 | # CONFIG_DVB_DM1105 is not set | ||
| 1057 | |||
| 1058 | # | ||
| 1059 | # Supported DVB Frontends | ||
| 1060 | # | ||
| 1061 | # CONFIG_DVB_FE_CUSTOMISE is not set | ||
| 1062 | CONFIG_DAB=y | ||
| 1063 | # CONFIG_USB_DABUSB is not set | ||
| 1064 | 1031 | ||
| 1065 | # | 1032 | # |
| 1066 | # Graphics support | 1033 | # Graphics support |
| @@ -1100,6 +1067,11 @@ CONFIG_SND_VERBOSE_PROCFS=y | |||
| 1100 | # CONFIG_SND_VERBOSE_PRINTK is not set | 1067 | # CONFIG_SND_VERBOSE_PRINTK is not set |
| 1101 | # CONFIG_SND_DEBUG is not set | 1068 | # CONFIG_SND_DEBUG is not set |
| 1102 | CONFIG_SND_VMASTER=y | 1069 | CONFIG_SND_VMASTER=y |
| 1070 | # CONFIG_SND_RAWMIDI_SEQ is not set | ||
| 1071 | # CONFIG_SND_OPL3_LIB_SEQ is not set | ||
| 1072 | # CONFIG_SND_OPL4_LIB_SEQ is not set | ||
| 1073 | # CONFIG_SND_SBAWE_SEQ is not set | ||
| 1074 | # CONFIG_SND_EMU10K1_SEQ is not set | ||
| 1103 | CONFIG_SND_AC97_CODEC=y | 1075 | CONFIG_SND_AC97_CODEC=y |
| 1104 | CONFIG_SND_DRIVERS=y | 1076 | CONFIG_SND_DRIVERS=y |
| 1105 | # CONFIG_SND_DUMMY is not set | 1077 | # CONFIG_SND_DUMMY is not set |
| @@ -1126,6 +1098,7 @@ CONFIG_SND_PCI=y | |||
| 1126 | # CONFIG_SND_CS4281 is not set | 1098 | # CONFIG_SND_CS4281 is not set |
| 1127 | # CONFIG_SND_CS46XX is not set | 1099 | # CONFIG_SND_CS46XX is not set |
| 1128 | # CONFIG_SND_CS5530 is not set | 1100 | # CONFIG_SND_CS5530 is not set |
| 1101 | # CONFIG_SND_CTXFI is not set | ||
| 1129 | # CONFIG_SND_DARLA20 is not set | 1102 | # CONFIG_SND_DARLA20 is not set |
| 1130 | # CONFIG_SND_GINA20 is not set | 1103 | # CONFIG_SND_GINA20 is not set |
| 1131 | # CONFIG_SND_LAYLA20 is not set | 1104 | # CONFIG_SND_LAYLA20 is not set |
| @@ -1156,6 +1129,7 @@ CONFIG_SND_PCI=y | |||
| 1156 | CONFIG_SND_INTEL8X0=y | 1129 | CONFIG_SND_INTEL8X0=y |
| 1157 | # CONFIG_SND_INTEL8X0M is not set | 1130 | # CONFIG_SND_INTEL8X0M is not set |
| 1158 | # CONFIG_SND_KORG1212 is not set | 1131 | # CONFIG_SND_KORG1212 is not set |
| 1132 | # CONFIG_SND_LX6464ES is not set | ||
| 1159 | # CONFIG_SND_MAESTRO3 is not set | 1133 | # CONFIG_SND_MAESTRO3 is not set |
| 1160 | # CONFIG_SND_MIXART is not set | 1134 | # CONFIG_SND_MIXART is not set |
| 1161 | # CONFIG_SND_NM256 is not set | 1135 | # CONFIG_SND_NM256 is not set |
| @@ -1200,7 +1174,7 @@ CONFIG_HID_BELKIN=y | |||
| 1200 | CONFIG_HID_CHERRY=y | 1174 | CONFIG_HID_CHERRY=y |
| 1201 | CONFIG_HID_CHICONY=y | 1175 | CONFIG_HID_CHICONY=y |
| 1202 | CONFIG_HID_CYPRESS=y | 1176 | CONFIG_HID_CYPRESS=y |
| 1203 | # CONFIG_DRAGONRISE_FF is not set | 1177 | # CONFIG_HID_DRAGONRISE is not set |
| 1204 | CONFIG_HID_EZKEY=y | 1178 | CONFIG_HID_EZKEY=y |
| 1205 | # CONFIG_HID_KYE is not set | 1179 | # CONFIG_HID_KYE is not set |
| 1206 | CONFIG_HID_GYRATION=y | 1180 | CONFIG_HID_GYRATION=y |
| @@ -1217,10 +1191,11 @@ CONFIG_HID_PETALYNX=y | |||
| 1217 | CONFIG_HID_SAMSUNG=y | 1191 | CONFIG_HID_SAMSUNG=y |
| 1218 | CONFIG_HID_SONY=y | 1192 | CONFIG_HID_SONY=y |
| 1219 | CONFIG_HID_SUNPLUS=y | 1193 | CONFIG_HID_SUNPLUS=y |
| 1220 | # CONFIG_GREENASIA_FF is not set | 1194 | # CONFIG_HID_GREENASIA is not set |
| 1195 | # CONFIG_HID_SMARTJOYPLUS is not set | ||
| 1221 | # CONFIG_HID_TOPSEED is not set | 1196 | # CONFIG_HID_TOPSEED is not set |
| 1222 | CONFIG_THRUSTMASTER_FF=m | 1197 | # CONFIG_HID_THRUSTMASTER is not set |
| 1223 | CONFIG_ZEROPLUS_FF=m | 1198 | # CONFIG_HID_ZEROPLUS is not set |
| 1224 | CONFIG_USB_SUPPORT=y | 1199 | CONFIG_USB_SUPPORT=y |
| 1225 | CONFIG_USB_ARCH_HAS_HCD=y | 1200 | CONFIG_USB_ARCH_HAS_HCD=y |
| 1226 | CONFIG_USB_ARCH_HAS_OHCI=y | 1201 | CONFIG_USB_ARCH_HAS_OHCI=y |
| @@ -1246,6 +1221,7 @@ CONFIG_USB_MON=y | |||
| 1246 | # USB Host Controller Drivers | 1221 | # USB Host Controller Drivers |
| 1247 | # | 1222 | # |
| 1248 | # CONFIG_USB_C67X00_HCD is not set | 1223 | # CONFIG_USB_C67X00_HCD is not set |
| 1224 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1249 | CONFIG_USB_EHCI_HCD=y | 1225 | CONFIG_USB_EHCI_HCD=y |
| 1250 | CONFIG_USB_EHCI_ROOT_HUB_TT=y | 1226 | CONFIG_USB_EHCI_ROOT_HUB_TT=y |
| 1251 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1227 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1255,9 +1231,9 @@ CONFIG_USB_EHCI_HCD_PPC_OF=y | |||
| 1255 | # CONFIG_USB_ISP116X_HCD is not set | 1231 | # CONFIG_USB_ISP116X_HCD is not set |
| 1256 | # CONFIG_USB_ISP1760_HCD is not set | 1232 | # CONFIG_USB_ISP1760_HCD is not set |
| 1257 | CONFIG_USB_OHCI_HCD=y | 1233 | CONFIG_USB_OHCI_HCD=y |
| 1258 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1259 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y | 1234 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y |
| 1260 | CONFIG_USB_OHCI_HCD_PPC_OF_LE=y | 1235 | CONFIG_USB_OHCI_HCD_PPC_OF_LE=y |
| 1236 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1261 | CONFIG_USB_OHCI_HCD_PCI=y | 1237 | CONFIG_USB_OHCI_HCD_PCI=y |
| 1262 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y | 1238 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y |
| 1263 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y | 1239 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y |
| @@ -1356,8 +1332,6 @@ CONFIG_EDAC=y | |||
| 1356 | # CONFIG_EDAC_DEBUG is not set | 1332 | # CONFIG_EDAC_DEBUG is not set |
| 1357 | CONFIG_EDAC_MM_EDAC=y | 1333 | CONFIG_EDAC_MM_EDAC=y |
| 1358 | CONFIG_EDAC_MPC85XX=y | 1334 | CONFIG_EDAC_MPC85XX=y |
| 1359 | # CONFIG_EDAC_AMD8131 is not set | ||
| 1360 | # CONFIG_EDAC_AMD8111 is not set | ||
| 1361 | CONFIG_RTC_LIB=y | 1335 | CONFIG_RTC_LIB=y |
| 1362 | CONFIG_RTC_CLASS=y | 1336 | CONFIG_RTC_CLASS=y |
| 1363 | CONFIG_RTC_HCTOSYS=y | 1337 | CONFIG_RTC_HCTOSYS=y |
| @@ -1389,6 +1363,7 @@ CONFIG_RTC_INTF_DEV=y | |||
| 1389 | # CONFIG_RTC_DRV_S35390A is not set | 1363 | # CONFIG_RTC_DRV_S35390A is not set |
| 1390 | # CONFIG_RTC_DRV_FM3130 is not set | 1364 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1391 | # CONFIG_RTC_DRV_RX8581 is not set | 1365 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1366 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1392 | 1367 | ||
| 1393 | # | 1368 | # |
| 1394 | # SPI RTC drivers | 1369 | # SPI RTC drivers |
| @@ -1429,6 +1404,10 @@ CONFIG_DMA_ENGINE=y | |||
| 1429 | # CONFIG_DMATEST is not set | 1404 | # CONFIG_DMATEST is not set |
| 1430 | # CONFIG_AUXDISPLAY is not set | 1405 | # CONFIG_AUXDISPLAY is not set |
| 1431 | # CONFIG_UIO is not set | 1406 | # CONFIG_UIO is not set |
| 1407 | |||
| 1408 | # | ||
| 1409 | # TI VLYNQ | ||
| 1410 | # | ||
| 1432 | # CONFIG_STAGING is not set | 1411 | # CONFIG_STAGING is not set |
| 1433 | 1412 | ||
| 1434 | # | 1413 | # |
| @@ -1449,11 +1428,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1449 | # CONFIG_REISERFS_FS is not set | 1428 | # CONFIG_REISERFS_FS is not set |
| 1450 | # CONFIG_JFS_FS is not set | 1429 | # CONFIG_JFS_FS is not set |
| 1451 | # CONFIG_FS_POSIX_ACL is not set | 1430 | # CONFIG_FS_POSIX_ACL is not set |
| 1452 | CONFIG_FILE_LOCKING=y | ||
| 1453 | # CONFIG_XFS_FS is not set | 1431 | # CONFIG_XFS_FS is not set |
| 1454 | # CONFIG_GFS2_FS is not set | 1432 | # CONFIG_GFS2_FS is not set |
| 1455 | # CONFIG_OCFS2_FS is not set | 1433 | # CONFIG_OCFS2_FS is not set |
| 1456 | # CONFIG_BTRFS_FS is not set | 1434 | # CONFIG_BTRFS_FS is not set |
| 1435 | CONFIG_FILE_LOCKING=y | ||
| 1436 | CONFIG_FSNOTIFY=y | ||
| 1457 | CONFIG_DNOTIFY=y | 1437 | CONFIG_DNOTIFY=y |
| 1458 | CONFIG_INOTIFY=y | 1438 | CONFIG_INOTIFY=y |
| 1459 | CONFIG_INOTIFY_USER=y | 1439 | CONFIG_INOTIFY_USER=y |
| @@ -1528,6 +1508,7 @@ CONFIG_NFS_FS=y | |||
| 1528 | CONFIG_NFS_V3=y | 1508 | CONFIG_NFS_V3=y |
| 1529 | # CONFIG_NFS_V3_ACL is not set | 1509 | # CONFIG_NFS_V3_ACL is not set |
| 1530 | CONFIG_NFS_V4=y | 1510 | CONFIG_NFS_V4=y |
| 1511 | # CONFIG_NFS_V4_1 is not set | ||
| 1531 | CONFIG_ROOT_NFS=y | 1512 | CONFIG_ROOT_NFS=y |
| 1532 | CONFIG_NFSD=y | 1513 | CONFIG_NFSD=y |
| 1533 | # CONFIG_NFSD_V3 is not set | 1514 | # CONFIG_NFSD_V3 is not set |
| @@ -1632,6 +1613,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1632 | CONFIG_HAS_DMA=y | 1613 | CONFIG_HAS_DMA=y |
| 1633 | CONFIG_HAVE_LMB=y | 1614 | CONFIG_HAVE_LMB=y |
| 1634 | CONFIG_NLATTR=y | 1615 | CONFIG_NLATTR=y |
| 1616 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1635 | 1617 | ||
| 1636 | # | 1618 | # |
| 1637 | # Kernel hacking | 1619 | # Kernel hacking |
| @@ -1662,6 +1644,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 1662 | # CONFIG_RT_MUTEX_TESTER is not set | 1644 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1663 | # CONFIG_DEBUG_SPINLOCK is not set | 1645 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1664 | # CONFIG_DEBUG_MUTEXES is not set | 1646 | # CONFIG_DEBUG_MUTEXES is not set |
| 1647 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1648 | # CONFIG_PROVE_LOCKING is not set | ||
| 1649 | # CONFIG_LOCK_STAT is not set | ||
| 1665 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1650 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1666 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1651 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1667 | # CONFIG_DEBUG_KOBJECT is not set | 1652 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1674,7 +1659,6 @@ CONFIG_DEBUG_INFO=y | |||
| 1674 | # CONFIG_DEBUG_LIST is not set | 1659 | # CONFIG_DEBUG_LIST is not set |
| 1675 | # CONFIG_DEBUG_SG is not set | 1660 | # CONFIG_DEBUG_SG is not set |
| 1676 | # CONFIG_DEBUG_NOTIFIERS is not set | 1661 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1677 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1678 | # CONFIG_RCU_TORTURE_TEST is not set | 1662 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1679 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1663 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1680 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1664 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1688,16 +1672,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1688 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1672 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1689 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1673 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1690 | CONFIG_TRACING_SUPPORT=y | 1674 | CONFIG_TRACING_SUPPORT=y |
| 1691 | 1675 | CONFIG_FTRACE=y | |
| 1692 | # | ||
| 1693 | # Tracers | ||
| 1694 | # | ||
| 1695 | # CONFIG_FUNCTION_TRACER is not set | 1676 | # CONFIG_FUNCTION_TRACER is not set |
| 1677 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1696 | # CONFIG_SCHED_TRACER is not set | 1678 | # CONFIG_SCHED_TRACER is not set |
| 1697 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1679 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1698 | # CONFIG_EVENT_TRACER is not set | ||
| 1699 | # CONFIG_BOOT_TRACER is not set | 1680 | # CONFIG_BOOT_TRACER is not set |
| 1700 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1681 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1682 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1683 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1701 | # CONFIG_STACK_TRACER is not set | 1684 | # CONFIG_STACK_TRACER is not set |
| 1702 | # CONFIG_KMEMTRACE is not set | 1685 | # CONFIG_KMEMTRACE is not set |
| 1703 | # CONFIG_WORKQUEUE_TRACER is not set | 1686 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -1706,9 +1689,13 @@ CONFIG_TRACING_SUPPORT=y | |||
| 1706 | # CONFIG_SAMPLES is not set | 1689 | # CONFIG_SAMPLES is not set |
| 1707 | CONFIG_HAVE_ARCH_KGDB=y | 1690 | CONFIG_HAVE_ARCH_KGDB=y |
| 1708 | # CONFIG_KGDB is not set | 1691 | # CONFIG_KGDB is not set |
| 1692 | # CONFIG_KMEMCHECK is not set | ||
| 1693 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1694 | CONFIG_PPC_WERROR=y | ||
| 1709 | CONFIG_PRINT_STACK_DEPTH=64 | 1695 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1710 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1696 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1711 | # CONFIG_DEBUG_STACK_USAGE is not set | 1697 | # CONFIG_DEBUG_STACK_USAGE is not set |
| 1698 | # CONFIG_PPC_EMULATED_STATS is not set | ||
| 1712 | # CONFIG_CODE_PATCHING_SELFTEST is not set | 1699 | # CONFIG_CODE_PATCHING_SELFTEST is not set |
| 1713 | # CONFIG_FTR_FIXUP_SELFTEST is not set | 1700 | # CONFIG_FTR_FIXUP_SELFTEST is not set |
| 1714 | # CONFIG_MSI_BITMAP_SELFTEST is not set | 1701 | # CONFIG_MSI_BITMAP_SELFTEST is not set |
diff --git a/arch/powerpc/configs/mpc866_ads_defconfig b/arch/powerpc/configs/mpc866_ads_defconfig index 3add6f62b21e..6809b61ed3de 100644 --- a/arch/powerpc/configs/mpc866_ads_defconfig +++ b/arch/powerpc/configs/mpc866_ads_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:00 2009 | 4 | # Wed Jul 29 23:31:57 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | CONFIG_PPC_8xx=y | 13 | CONFIG_PPC_8xx=y |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -27,15 +27,16 @@ CONFIG_GENERIC_TIME=y | |||
| 27 | CONFIG_GENERIC_TIME_VSYSCALL=y | 27 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 28 | CONFIG_GENERIC_CLOCKEVENTS=y | 28 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 29 | CONFIG_GENERIC_HARDIRQS=y | 29 | CONFIG_GENERIC_HARDIRQS=y |
| 30 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 30 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 31 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 31 | CONFIG_IRQ_PER_CPU=y | 32 | CONFIG_IRQ_PER_CPU=y |
| 32 | CONFIG_STACKTRACE_SUPPORT=y | 33 | CONFIG_STACKTRACE_SUPPORT=y |
| 33 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 34 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 35 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 34 | CONFIG_LOCKDEP_SUPPORT=y | 36 | CONFIG_LOCKDEP_SUPPORT=y |
| 35 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 37 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 36 | CONFIG_ARCH_HAS_ILOG2_U32=y | 38 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 37 | CONFIG_GENERIC_HWEIGHT=y | 39 | CONFIG_GENERIC_HWEIGHT=y |
| 38 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 39 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 40 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 40 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 41 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 41 | CONFIG_PPC=y | 42 | CONFIG_PPC=y |
| @@ -48,11 +49,13 @@ CONFIG_OF=y | |||
| 48 | # CONFIG_PPC_UDBG_16550 is not set | 49 | # CONFIG_PPC_UDBG_16550 is not set |
| 49 | # CONFIG_GENERIC_TBSYNC is not set | 50 | # CONFIG_GENERIC_TBSYNC is not set |
| 50 | CONFIG_AUDIT_ARCH=y | 51 | CONFIG_AUDIT_ARCH=y |
| 52 | CONFIG_DTC=y | ||
| 51 | # CONFIG_DEFAULT_UIMAGE is not set | 53 | # CONFIG_DEFAULT_UIMAGE is not set |
| 52 | # CONFIG_PPC_DCR_NATIVE is not set | 54 | # CONFIG_PPC_DCR_NATIVE is not set |
| 53 | # CONFIG_PPC_DCR_MMIO is not set | 55 | # CONFIG_PPC_DCR_MMIO is not set |
| 54 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 56 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 55 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 57 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 58 | CONFIG_CONSTRUCTORS=y | ||
| 56 | 59 | ||
| 57 | # | 60 | # |
| 58 | # General setup | 61 | # General setup |
| @@ -98,7 +101,6 @@ CONFIG_EMBEDDED=y | |||
| 98 | # CONFIG_SYSCTL_SYSCALL is not set | 101 | # CONFIG_SYSCTL_SYSCALL is not set |
| 99 | CONFIG_KALLSYMS=y | 102 | CONFIG_KALLSYMS=y |
| 100 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 103 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 101 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 102 | # CONFIG_HOTPLUG is not set | 104 | # CONFIG_HOTPLUG is not set |
| 103 | CONFIG_PRINTK=y | 105 | CONFIG_PRINTK=y |
| 104 | # CONFIG_BUG is not set | 106 | # CONFIG_BUG is not set |
| @@ -111,8 +113,15 @@ CONFIG_TIMERFD=y | |||
| 111 | CONFIG_EVENTFD=y | 113 | CONFIG_EVENTFD=y |
| 112 | CONFIG_SHMEM=y | 114 | CONFIG_SHMEM=y |
| 113 | CONFIG_AIO=y | 115 | CONFIG_AIO=y |
| 116 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 117 | |||
| 118 | # | ||
| 119 | # Performance Counters | ||
| 120 | # | ||
| 121 | # CONFIG_PERF_COUNTERS is not set | ||
| 114 | # CONFIG_VM_EVENT_COUNTERS is not set | 122 | # CONFIG_VM_EVENT_COUNTERS is not set |
| 115 | CONFIG_SLUB_DEBUG=y | 123 | CONFIG_SLUB_DEBUG=y |
| 124 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 116 | CONFIG_COMPAT_BRK=y | 125 | CONFIG_COMPAT_BRK=y |
| 117 | # CONFIG_SLAB is not set | 126 | # CONFIG_SLAB is not set |
| 118 | CONFIG_SLUB=y | 127 | CONFIG_SLUB=y |
| @@ -126,6 +135,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 126 | CONFIG_HAVE_KRETPROBES=y | 135 | CONFIG_HAVE_KRETPROBES=y |
| 127 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 136 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 128 | CONFIG_HAVE_CLK=y | 137 | CONFIG_HAVE_CLK=y |
| 138 | |||
| 139 | # | ||
| 140 | # GCOV-based kernel profiling | ||
| 141 | # | ||
| 129 | # CONFIG_SLOW_WORK is not set | 142 | # CONFIG_SLOW_WORK is not set |
| 130 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 143 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 131 | CONFIG_SLABINFO=y | 144 | CONFIG_SLABINFO=y |
| @@ -133,7 +146,7 @@ CONFIG_RT_MUTEXES=y | |||
| 133 | CONFIG_BASE_SMALL=1 | 146 | CONFIG_BASE_SMALL=1 |
| 134 | # CONFIG_MODULES is not set | 147 | # CONFIG_MODULES is not set |
| 135 | CONFIG_BLOCK=y | 148 | CONFIG_BLOCK=y |
| 136 | # CONFIG_LBD is not set | 149 | CONFIG_LBDAF=y |
| 137 | # CONFIG_BLK_DEV_BSG is not set | 150 | # CONFIG_BLK_DEV_BSG is not set |
| 138 | # CONFIG_BLK_DEV_INTEGRITY is not set | 151 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 139 | 152 | ||
| @@ -219,6 +232,7 @@ CONFIG_BINFMT_ELF=y | |||
| 219 | # CONFIG_BINFMT_MISC is not set | 232 | # CONFIG_BINFMT_MISC is not set |
| 220 | CONFIG_MATH_EMULATION=y | 233 | CONFIG_MATH_EMULATION=y |
| 221 | # CONFIG_IOMMU_HELPER is not set | 234 | # CONFIG_IOMMU_HELPER is not set |
| 235 | # CONFIG_SWIOTLB is not set | ||
| 222 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y | 236 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y |
| 223 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 237 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 224 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 238 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| @@ -238,9 +252,9 @@ CONFIG_MIGRATION=y | |||
| 238 | CONFIG_ZONE_DMA_FLAG=1 | 252 | CONFIG_ZONE_DMA_FLAG=1 |
| 239 | CONFIG_BOUNCE=y | 253 | CONFIG_BOUNCE=y |
| 240 | CONFIG_VIRT_TO_BUS=y | 254 | CONFIG_VIRT_TO_BUS=y |
| 241 | CONFIG_UNEVICTABLE_LRU=y | ||
| 242 | CONFIG_HAVE_MLOCK=y | 255 | CONFIG_HAVE_MLOCK=y |
| 243 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 256 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 257 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 244 | CONFIG_PPC_4K_PAGES=y | 258 | CONFIG_PPC_4K_PAGES=y |
| 245 | # CONFIG_PPC_16K_PAGES is not set | 259 | # CONFIG_PPC_16K_PAGES is not set |
| 246 | # CONFIG_PPC_64K_PAGES is not set | 260 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -278,6 +292,7 @@ CONFIG_PAGE_OFFSET=0xc0000000 | |||
| 278 | CONFIG_KERNEL_START=0xc0000000 | 292 | CONFIG_KERNEL_START=0xc0000000 |
| 279 | CONFIG_PHYSICAL_START=0x00000000 | 293 | CONFIG_PHYSICAL_START=0x00000000 |
| 280 | CONFIG_TASK_SIZE=0x80000000 | 294 | CONFIG_TASK_SIZE=0x80000000 |
| 295 | CONFIG_CONSISTENT_SIZE=0x00200000 | ||
| 281 | CONFIG_NET=y | 296 | CONFIG_NET=y |
| 282 | 297 | ||
| 283 | # | 298 | # |
| @@ -339,6 +354,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 339 | # CONFIG_ECONET is not set | 354 | # CONFIG_ECONET is not set |
| 340 | # CONFIG_WAN_ROUTER is not set | 355 | # CONFIG_WAN_ROUTER is not set |
| 341 | # CONFIG_PHONET is not set | 356 | # CONFIG_PHONET is not set |
| 357 | # CONFIG_IEEE802154 is not set | ||
| 342 | # CONFIG_NET_SCHED is not set | 358 | # CONFIG_NET_SCHED is not set |
| 343 | # CONFIG_DCB is not set | 359 | # CONFIG_DCB is not set |
| 344 | 360 | ||
| @@ -356,7 +372,11 @@ CONFIG_WIRELESS=y | |||
| 356 | CONFIG_WIRELESS_OLD_REGULATORY=y | 372 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 357 | # CONFIG_WIRELESS_EXT is not set | 373 | # CONFIG_WIRELESS_EXT is not set |
| 358 | # CONFIG_LIB80211 is not set | 374 | # CONFIG_LIB80211 is not set |
| 359 | # CONFIG_MAC80211 is not set | 375 | |
| 376 | # | ||
| 377 | # CFG80211 needs to be enabled for MAC80211 | ||
| 378 | # | ||
| 379 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 360 | # CONFIG_WIMAX is not set | 380 | # CONFIG_WIMAX is not set |
| 361 | # CONFIG_RFKILL is not set | 381 | # CONFIG_RFKILL is not set |
| 362 | # CONFIG_NET_9P is not set | 382 | # CONFIG_NET_9P is not set |
| @@ -374,6 +394,7 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 374 | # CONFIG_CONNECTOR is not set | 394 | # CONFIG_CONNECTOR is not set |
| 375 | # CONFIG_MTD is not set | 395 | # CONFIG_MTD is not set |
| 376 | CONFIG_OF_DEVICE=y | 396 | CONFIG_OF_DEVICE=y |
| 397 | CONFIG_OF_MDIO=y | ||
| 377 | # CONFIG_PARPORT is not set | 398 | # CONFIG_PARPORT is not set |
| 378 | CONFIG_BLK_DEV=y | 399 | CONFIG_BLK_DEV=y |
| 379 | # CONFIG_BLK_DEV_FD is not set | 400 | # CONFIG_BLK_DEV_FD is not set |
| @@ -407,7 +428,6 @@ CONFIG_HAVE_IDE=y | |||
| 407 | # CONFIG_MD is not set | 428 | # CONFIG_MD is not set |
| 408 | # CONFIG_MACINTOSH_DRIVERS is not set | 429 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 409 | CONFIG_NETDEVICES=y | 430 | CONFIG_NETDEVICES=y |
| 410 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 411 | # CONFIG_DUMMY is not set | 431 | # CONFIG_DUMMY is not set |
| 412 | # CONFIG_BONDING is not set | 432 | # CONFIG_BONDING is not set |
| 413 | # CONFIG_MACVLAN is not set | 433 | # CONFIG_MACVLAN is not set |
| @@ -446,6 +466,7 @@ CONFIG_MII=y | |||
| 446 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 466 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 447 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 467 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 448 | # CONFIG_B44 is not set | 468 | # CONFIG_B44 is not set |
| 469 | # CONFIG_KS8842 is not set | ||
| 449 | CONFIG_FS_ENET=y | 470 | CONFIG_FS_ENET=y |
| 450 | CONFIG_FS_ENET_HAS_SCC=y | 471 | CONFIG_FS_ENET_HAS_SCC=y |
| 451 | CONFIG_FS_ENET_HAS_FEC=y | 472 | CONFIG_FS_ENET_HAS_FEC=y |
| @@ -453,6 +474,7 @@ CONFIG_FS_ENET_MDIO_FEC=y | |||
| 453 | CONFIG_NETDEV_1000=y | 474 | CONFIG_NETDEV_1000=y |
| 454 | # CONFIG_FSL_PQ_MDIO is not set | 475 | # CONFIG_FSL_PQ_MDIO is not set |
| 455 | # CONFIG_GIANFAR is not set | 476 | # CONFIG_GIANFAR is not set |
| 477 | # CONFIG_MV643XX_ETH is not set | ||
| 456 | CONFIG_NETDEV_10000=y | 478 | CONFIG_NETDEV_10000=y |
| 457 | 479 | ||
| 458 | # | 480 | # |
| @@ -496,11 +518,11 @@ CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 | |||
| 496 | # | 518 | # |
| 497 | CONFIG_INPUT_KEYBOARD=y | 519 | CONFIG_INPUT_KEYBOARD=y |
| 498 | CONFIG_KEYBOARD_ATKBD=y | 520 | CONFIG_KEYBOARD_ATKBD=y |
| 499 | # CONFIG_KEYBOARD_SUNKBD is not set | ||
| 500 | # CONFIG_KEYBOARD_LKKBD is not set | 521 | # CONFIG_KEYBOARD_LKKBD is not set |
| 501 | # CONFIG_KEYBOARD_XTKBD is not set | ||
| 502 | # CONFIG_KEYBOARD_NEWTON is not set | 522 | # CONFIG_KEYBOARD_NEWTON is not set |
| 503 | # CONFIG_KEYBOARD_STOWAWAY is not set | 523 | # CONFIG_KEYBOARD_STOWAWAY is not set |
| 524 | # CONFIG_KEYBOARD_SUNKBD is not set | ||
| 525 | # CONFIG_KEYBOARD_XTKBD is not set | ||
| 504 | CONFIG_INPUT_MOUSE=y | 526 | CONFIG_INPUT_MOUSE=y |
| 505 | CONFIG_MOUSE_PS2=y | 527 | CONFIG_MOUSE_PS2=y |
| 506 | CONFIG_MOUSE_PS2_ALPS=y | 528 | CONFIG_MOUSE_PS2_ALPS=y |
| @@ -562,6 +584,11 @@ CONFIG_GEN_RTC=y | |||
| 562 | # CONFIG_TCG_TPM is not set | 584 | # CONFIG_TCG_TPM is not set |
| 563 | # CONFIG_I2C is not set | 585 | # CONFIG_I2C is not set |
| 564 | # CONFIG_SPI is not set | 586 | # CONFIG_SPI is not set |
| 587 | |||
| 588 | # | ||
| 589 | # PPS support | ||
| 590 | # | ||
| 591 | # CONFIG_PPS is not set | ||
| 565 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 592 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 566 | # CONFIG_GPIOLIB is not set | 593 | # CONFIG_GPIOLIB is not set |
| 567 | # CONFIG_W1 is not set | 594 | # CONFIG_W1 is not set |
| @@ -597,22 +624,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 597 | # CONFIG_HTC_PASIC3 is not set | 624 | # CONFIG_HTC_PASIC3 is not set |
| 598 | # CONFIG_MFD_TMIO is not set | 625 | # CONFIG_MFD_TMIO is not set |
| 599 | # CONFIG_REGULATOR is not set | 626 | # CONFIG_REGULATOR is not set |
| 600 | 627 | # CONFIG_MEDIA_SUPPORT is not set | |
| 601 | # | ||
| 602 | # Multimedia devices | ||
| 603 | # | ||
| 604 | |||
| 605 | # | ||
| 606 | # Multimedia core support | ||
| 607 | # | ||
| 608 | # CONFIG_VIDEO_DEV is not set | ||
| 609 | # CONFIG_DVB_CORE is not set | ||
| 610 | # CONFIG_VIDEO_MEDIA is not set | ||
| 611 | |||
| 612 | # | ||
| 613 | # Multimedia drivers | ||
| 614 | # | ||
| 615 | CONFIG_DAB=y | ||
| 616 | 628 | ||
| 617 | # | 629 | # |
| 618 | # Graphics support | 630 | # Graphics support |
| @@ -664,6 +676,10 @@ CONFIG_USB_SUPPORT=y | |||
| 664 | # CONFIG_DMADEVICES is not set | 676 | # CONFIG_DMADEVICES is not set |
| 665 | # CONFIG_AUXDISPLAY is not set | 677 | # CONFIG_AUXDISPLAY is not set |
| 666 | # CONFIG_UIO is not set | 678 | # CONFIG_UIO is not set |
| 679 | |||
| 680 | # | ||
| 681 | # TI VLYNQ | ||
| 682 | # | ||
| 667 | # CONFIG_STAGING is not set | 683 | # CONFIG_STAGING is not set |
| 668 | 684 | ||
| 669 | # | 685 | # |
| @@ -685,10 +701,12 @@ CONFIG_FS_MBCACHE=y | |||
| 685 | # CONFIG_REISERFS_FS is not set | 701 | # CONFIG_REISERFS_FS is not set |
| 686 | # CONFIG_JFS_FS is not set | 702 | # CONFIG_JFS_FS is not set |
| 687 | # CONFIG_FS_POSIX_ACL is not set | 703 | # CONFIG_FS_POSIX_ACL is not set |
| 688 | CONFIG_FILE_LOCKING=y | ||
| 689 | # CONFIG_XFS_FS is not set | 704 | # CONFIG_XFS_FS is not set |
| 705 | # CONFIG_GFS2_FS is not set | ||
| 690 | # CONFIG_OCFS2_FS is not set | 706 | # CONFIG_OCFS2_FS is not set |
| 691 | # CONFIG_BTRFS_FS is not set | 707 | # CONFIG_BTRFS_FS is not set |
| 708 | CONFIG_FILE_LOCKING=y | ||
| 709 | CONFIG_FSNOTIFY=y | ||
| 692 | CONFIG_DNOTIFY=y | 710 | CONFIG_DNOTIFY=y |
| 693 | CONFIG_INOTIFY=y | 711 | CONFIG_INOTIFY=y |
| 694 | CONFIG_INOTIFY_USER=y | 712 | CONFIG_INOTIFY_USER=y |
| @@ -808,6 +826,7 @@ CONFIG_HAS_IOPORT=y | |||
| 808 | CONFIG_HAS_DMA=y | 826 | CONFIG_HAS_DMA=y |
| 809 | CONFIG_HAVE_LMB=y | 827 | CONFIG_HAVE_LMB=y |
| 810 | CONFIG_NLATTR=y | 828 | CONFIG_NLATTR=y |
| 829 | CONFIG_GENERIC_ATOMIC64=y | ||
| 811 | 830 | ||
| 812 | # | 831 | # |
| 813 | # Kernel hacking | 832 | # Kernel hacking |
| @@ -831,22 +850,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 831 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 850 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 832 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 851 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 833 | CONFIG_TRACING_SUPPORT=y | 852 | CONFIG_TRACING_SUPPORT=y |
| 834 | 853 | # CONFIG_FTRACE is not set | |
| 835 | # | ||
| 836 | # Tracers | ||
| 837 | # | ||
| 838 | # CONFIG_FUNCTION_TRACER is not set | ||
| 839 | # CONFIG_SCHED_TRACER is not set | ||
| 840 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 841 | # CONFIG_EVENT_TRACER is not set | ||
| 842 | # CONFIG_BOOT_TRACER is not set | ||
| 843 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 844 | # CONFIG_STACK_TRACER is not set | ||
| 845 | # CONFIG_KMEMTRACE is not set | ||
| 846 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 847 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 848 | # CONFIG_SAMPLES is not set | 854 | # CONFIG_SAMPLES is not set |
| 849 | CONFIG_HAVE_ARCH_KGDB=y | 855 | CONFIG_HAVE_ARCH_KGDB=y |
| 856 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 857 | CONFIG_PPC_WERROR=y | ||
| 850 | CONFIG_PRINT_STACK_DEPTH=64 | 858 | CONFIG_PRINT_STACK_DEPTH=64 |
| 851 | # CONFIG_IRQSTACKS is not set | 859 | # CONFIG_IRQSTACKS is not set |
| 852 | # CONFIG_PPC_EARLY_DEBUG is not set | 860 | # CONFIG_PPC_EARLY_DEBUG is not set |
diff --git a/arch/powerpc/configs/mpc86xx_defconfig b/arch/powerpc/configs/mpc86xx_defconfig index 5bb1b8eb0b49..0e8684a3138d 100644 --- a/arch/powerpc/configs/mpc86xx_defconfig +++ b/arch/powerpc/configs/mpc86xx_defconfig | |||
| @@ -1,26 +1,28 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:00 2009 | 4 | # Wed Jul 29 23:31:58 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_PHYS_64BIT is not set | 20 | # CONFIG_PHYS_64BIT is not set |
| 20 | CONFIG_ALTIVEC=y | 21 | CONFIG_ALTIVEC=y |
| 21 | CONFIG_PPC_STD_MMU=y | 22 | CONFIG_PPC_STD_MMU=y |
| 22 | CONFIG_PPC_STD_MMU_32=y | 23 | CONFIG_PPC_STD_MMU_32=y |
| 23 | # CONFIG_PPC_MM_SLICES is not set | 24 | # CONFIG_PPC_MM_SLICES is not set |
| 25 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 24 | CONFIG_SMP=y | 26 | CONFIG_SMP=y |
| 25 | CONFIG_NR_CPUS=2 | 27 | CONFIG_NR_CPUS=2 |
| 26 | CONFIG_PPC32=y | 28 | CONFIG_PPC32=y |
| @@ -32,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 32 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 33 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 34 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 35 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 36 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 37 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 38 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 39 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 40 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 41 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 42 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 43 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 44 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 45 | CONFIG_GENERIC_GPIO=y | 48 | CONFIG_GENERIC_GPIO=y |
| 46 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 49 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -55,11 +58,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 55 | CONFIG_GENERIC_TBSYNC=y | 58 | CONFIG_GENERIC_TBSYNC=y |
| 56 | CONFIG_AUDIT_ARCH=y | 59 | CONFIG_AUDIT_ARCH=y |
| 57 | CONFIG_GENERIC_BUG=y | 60 | CONFIG_GENERIC_BUG=y |
| 61 | CONFIG_DTC=y | ||
| 58 | CONFIG_DEFAULT_UIMAGE=y | 62 | CONFIG_DEFAULT_UIMAGE=y |
| 59 | # CONFIG_PPC_DCR_NATIVE is not set | 63 | # CONFIG_PPC_DCR_NATIVE is not set |
| 60 | # CONFIG_PPC_DCR_MMIO is not set | 64 | # CONFIG_PPC_DCR_MMIO is not set |
| 61 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 65 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 62 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 66 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 67 | CONFIG_CONSTRUCTORS=y | ||
| 63 | 68 | ||
| 64 | # | 69 | # |
| 65 | # General setup | 70 | # General setup |
| @@ -114,7 +119,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 114 | CONFIG_KALLSYMS=y | 119 | CONFIG_KALLSYMS=y |
| 115 | CONFIG_KALLSYMS_ALL=y | 120 | CONFIG_KALLSYMS_ALL=y |
| 116 | CONFIG_KALLSYMS_EXTRA_PASS=y | 121 | CONFIG_KALLSYMS_EXTRA_PASS=y |
| 117 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 118 | CONFIG_HOTPLUG=y | 122 | CONFIG_HOTPLUG=y |
| 119 | CONFIG_PRINTK=y | 123 | CONFIG_PRINTK=y |
| 120 | CONFIG_BUG=y | 124 | CONFIG_BUG=y |
| @@ -127,9 +131,16 @@ CONFIG_TIMERFD=y | |||
| 127 | CONFIG_EVENTFD=y | 131 | CONFIG_EVENTFD=y |
| 128 | CONFIG_SHMEM=y | 132 | CONFIG_SHMEM=y |
| 129 | CONFIG_AIO=y | 133 | CONFIG_AIO=y |
| 134 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 135 | |||
| 136 | # | ||
| 137 | # Performance Counters | ||
| 138 | # | ||
| 139 | # CONFIG_PERF_COUNTERS is not set | ||
| 130 | CONFIG_VM_EVENT_COUNTERS=y | 140 | CONFIG_VM_EVENT_COUNTERS=y |
| 131 | CONFIG_PCI_QUIRKS=y | 141 | CONFIG_PCI_QUIRKS=y |
| 132 | CONFIG_SLUB_DEBUG=y | 142 | CONFIG_SLUB_DEBUG=y |
| 143 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 133 | CONFIG_COMPAT_BRK=y | 144 | CONFIG_COMPAT_BRK=y |
| 134 | # CONFIG_SLAB is not set | 145 | # CONFIG_SLAB is not set |
| 135 | CONFIG_SLUB=y | 146 | CONFIG_SLUB=y |
| @@ -144,6 +155,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 144 | CONFIG_HAVE_KRETPROBES=y | 155 | CONFIG_HAVE_KRETPROBES=y |
| 145 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 156 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 146 | CONFIG_USE_GENERIC_SMP_HELPERS=y | 157 | CONFIG_USE_GENERIC_SMP_HELPERS=y |
| 158 | |||
| 159 | # | ||
| 160 | # GCOV-based kernel profiling | ||
| 161 | # | ||
| 147 | # CONFIG_SLOW_WORK is not set | 162 | # CONFIG_SLOW_WORK is not set |
| 148 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 163 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 149 | CONFIG_SLABINFO=y | 164 | CONFIG_SLABINFO=y |
| @@ -157,7 +172,7 @@ CONFIG_MODVERSIONS=y | |||
| 157 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 172 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 158 | CONFIG_STOP_MACHINE=y | 173 | CONFIG_STOP_MACHINE=y |
| 159 | CONFIG_BLOCK=y | 174 | CONFIG_BLOCK=y |
| 160 | CONFIG_LBD=y | 175 | CONFIG_LBDAF=y |
| 161 | # CONFIG_BLK_DEV_BSG is not set | 176 | # CONFIG_BLK_DEV_BSG is not set |
| 162 | # CONFIG_BLK_DEV_INTEGRITY is not set | 177 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 163 | 178 | ||
| @@ -236,7 +251,9 @@ CONFIG_BINFMT_ELF=y | |||
| 236 | # CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set | 251 | # CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set |
| 237 | # CONFIG_HAVE_AOUT is not set | 252 | # CONFIG_HAVE_AOUT is not set |
| 238 | CONFIG_BINFMT_MISC=m | 253 | CONFIG_BINFMT_MISC=m |
| 239 | # CONFIG_IOMMU_HELPER is not set | 254 | CONFIG_IOMMU_HELPER=y |
| 255 | CONFIG_SWIOTLB=y | ||
| 256 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y | ||
| 240 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 257 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 241 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 258 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 242 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 259 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -258,9 +275,9 @@ CONFIG_MIGRATION=y | |||
| 258 | CONFIG_ZONE_DMA_FLAG=1 | 275 | CONFIG_ZONE_DMA_FLAG=1 |
| 259 | CONFIG_BOUNCE=y | 276 | CONFIG_BOUNCE=y |
| 260 | CONFIG_VIRT_TO_BUS=y | 277 | CONFIG_VIRT_TO_BUS=y |
| 261 | CONFIG_UNEVICTABLE_LRU=y | ||
| 262 | CONFIG_HAVE_MLOCK=y | 278 | CONFIG_HAVE_MLOCK=y |
| 263 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 279 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 280 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 264 | CONFIG_PPC_4K_PAGES=y | 281 | CONFIG_PPC_4K_PAGES=y |
| 265 | # CONFIG_PPC_16K_PAGES is not set | 282 | # CONFIG_PPC_16K_PAGES is not set |
| 266 | # CONFIG_PPC_64K_PAGES is not set | 283 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -403,6 +420,7 @@ CONFIG_SCTP_HMAC_MD5=y | |||
| 403 | # CONFIG_ECONET is not set | 420 | # CONFIG_ECONET is not set |
| 404 | # CONFIG_WAN_ROUTER is not set | 421 | # CONFIG_WAN_ROUTER is not set |
| 405 | # CONFIG_PHONET is not set | 422 | # CONFIG_PHONET is not set |
| 423 | # CONFIG_IEEE802154 is not set | ||
| 406 | # CONFIG_NET_SCHED is not set | 424 | # CONFIG_NET_SCHED is not set |
| 407 | # CONFIG_DCB is not set | 425 | # CONFIG_DCB is not set |
| 408 | 426 | ||
| @@ -421,7 +439,11 @@ CONFIG_WIRELESS=y | |||
| 421 | CONFIG_WIRELESS_OLD_REGULATORY=y | 439 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 422 | # CONFIG_WIRELESS_EXT is not set | 440 | # CONFIG_WIRELESS_EXT is not set |
| 423 | # CONFIG_LIB80211 is not set | 441 | # CONFIG_LIB80211 is not set |
| 424 | # CONFIG_MAC80211 is not set | 442 | |
| 443 | # | ||
| 444 | # CFG80211 needs to be enabled for MAC80211 | ||
| 445 | # | ||
| 446 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 425 | # CONFIG_WIMAX is not set | 447 | # CONFIG_WIMAX is not set |
| 426 | # CONFIG_RFKILL is not set | 448 | # CONFIG_RFKILL is not set |
| 427 | # CONFIG_NET_9P is not set | 449 | # CONFIG_NET_9P is not set |
| @@ -447,6 +469,7 @@ CONFIG_EXTRA_FIRMWARE="" | |||
| 447 | CONFIG_OF_DEVICE=y | 469 | CONFIG_OF_DEVICE=y |
| 448 | CONFIG_OF_GPIO=y | 470 | CONFIG_OF_GPIO=y |
| 449 | CONFIG_OF_I2C=y | 471 | CONFIG_OF_I2C=y |
| 472 | CONFIG_OF_MDIO=y | ||
| 450 | # CONFIG_PARPORT is not set | 473 | # CONFIG_PARPORT is not set |
| 451 | CONFIG_BLK_DEV=y | 474 | CONFIG_BLK_DEV=y |
| 452 | # CONFIG_BLK_DEV_FD is not set | 475 | # CONFIG_BLK_DEV_FD is not set |
| @@ -482,7 +505,9 @@ CONFIG_MISC_DEVICES=y | |||
| 482 | # | 505 | # |
| 483 | # CONFIG_EEPROM_AT24 is not set | 506 | # CONFIG_EEPROM_AT24 is not set |
| 484 | CONFIG_EEPROM_LEGACY=y | 507 | CONFIG_EEPROM_LEGACY=y |
| 508 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 485 | # CONFIG_EEPROM_93CX6 is not set | 509 | # CONFIG_EEPROM_93CX6 is not set |
| 510 | # CONFIG_CB710_CORE is not set | ||
| 486 | CONFIG_HAVE_IDE=y | 511 | CONFIG_HAVE_IDE=y |
| 487 | # CONFIG_IDE is not set | 512 | # CONFIG_IDE is not set |
| 488 | 513 | ||
| @@ -506,10 +531,6 @@ CONFIG_BLK_DEV_SR=y | |||
| 506 | # CONFIG_BLK_DEV_SR_VENDOR is not set | 531 | # CONFIG_BLK_DEV_SR_VENDOR is not set |
| 507 | CONFIG_CHR_DEV_SG=y | 532 | CONFIG_CHR_DEV_SG=y |
| 508 | # CONFIG_CHR_DEV_SCH is not set | 533 | # CONFIG_CHR_DEV_SCH is not set |
| 509 | |||
| 510 | # | ||
| 511 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 512 | # | ||
| 513 | CONFIG_SCSI_MULTI_LUN=y | 534 | CONFIG_SCSI_MULTI_LUN=y |
| 514 | # CONFIG_SCSI_CONSTANTS is not set | 535 | # CONFIG_SCSI_CONSTANTS is not set |
| 515 | CONFIG_SCSI_LOGGING=y | 536 | CONFIG_SCSI_LOGGING=y |
| @@ -527,6 +548,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
| 527 | CONFIG_SCSI_LOWLEVEL=y | 548 | CONFIG_SCSI_LOWLEVEL=y |
| 528 | # CONFIG_ISCSI_TCP is not set | 549 | # CONFIG_ISCSI_TCP is not set |
| 529 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 550 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 551 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 530 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 552 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 531 | # CONFIG_SCSI_3W_9XXX is not set | 553 | # CONFIG_SCSI_3W_9XXX is not set |
| 532 | # CONFIG_SCSI_ACARD is not set | 554 | # CONFIG_SCSI_ACARD is not set |
| @@ -535,6 +557,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 535 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 557 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 536 | # CONFIG_SCSI_AIC79XX is not set | 558 | # CONFIG_SCSI_AIC79XX is not set |
| 537 | # CONFIG_SCSI_AIC94XX is not set | 559 | # CONFIG_SCSI_AIC94XX is not set |
| 560 | # CONFIG_SCSI_MVSAS is not set | ||
| 538 | # CONFIG_SCSI_DPT_I2O is not set | 561 | # CONFIG_SCSI_DPT_I2O is not set |
| 539 | # CONFIG_SCSI_ADVANSYS is not set | 562 | # CONFIG_SCSI_ADVANSYS is not set |
| 540 | # CONFIG_SCSI_ARCMSR is not set | 563 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -554,7 +577,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 554 | # CONFIG_SCSI_IPS is not set | 577 | # CONFIG_SCSI_IPS is not set |
| 555 | # CONFIG_SCSI_INITIO is not set | 578 | # CONFIG_SCSI_INITIO is not set |
| 556 | # CONFIG_SCSI_INIA100 is not set | 579 | # CONFIG_SCSI_INIA100 is not set |
| 557 | # CONFIG_SCSI_MVSAS is not set | ||
| 558 | # CONFIG_SCSI_STEX is not set | 580 | # CONFIG_SCSI_STEX is not set |
| 559 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 581 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 560 | # CONFIG_SCSI_IPR is not set | 582 | # CONFIG_SCSI_IPR is not set |
| @@ -638,14 +660,17 @@ CONFIG_PATA_ALI=y | |||
| 638 | # | 660 | # |
| 639 | 661 | ||
| 640 | # | 662 | # |
| 641 | # Enable only one of the two stacks, unless you know what you are doing | 663 | # You can enable one or both FireWire driver stacks. |
| 664 | # | ||
| 665 | |||
| 666 | # | ||
| 667 | # See the help texts for more information. | ||
| 642 | # | 668 | # |
| 643 | # CONFIG_FIREWIRE is not set | 669 | # CONFIG_FIREWIRE is not set |
| 644 | # CONFIG_IEEE1394 is not set | 670 | # CONFIG_IEEE1394 is not set |
| 645 | # CONFIG_I2O is not set | 671 | # CONFIG_I2O is not set |
| 646 | # CONFIG_MACINTOSH_DRIVERS is not set | 672 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 647 | CONFIG_NETDEVICES=y | 673 | CONFIG_NETDEVICES=y |
| 648 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 649 | CONFIG_DUMMY=y | 674 | CONFIG_DUMMY=y |
| 650 | # CONFIG_BONDING is not set | 675 | # CONFIG_BONDING is not set |
| 651 | # CONFIG_MACVLAN is not set | 676 | # CONFIG_MACVLAN is not set |
| @@ -692,6 +717,7 @@ CONFIG_MII=y | |||
| 692 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 717 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 693 | # CONFIG_NET_PCI is not set | 718 | # CONFIG_NET_PCI is not set |
| 694 | # CONFIG_B44 is not set | 719 | # CONFIG_B44 is not set |
| 720 | # CONFIG_KS8842 is not set | ||
| 695 | # CONFIG_ATL2 is not set | 721 | # CONFIG_ATL2 is not set |
| 696 | CONFIG_NETDEV_1000=y | 722 | CONFIG_NETDEV_1000=y |
| 697 | # CONFIG_ACENIC is not set | 723 | # CONFIG_ACENIC is not set |
| @@ -711,8 +737,10 @@ CONFIG_NETDEV_1000=y | |||
| 711 | # CONFIG_VIA_VELOCITY is not set | 737 | # CONFIG_VIA_VELOCITY is not set |
| 712 | # CONFIG_TIGON3 is not set | 738 | # CONFIG_TIGON3 is not set |
| 713 | # CONFIG_BNX2 is not set | 739 | # CONFIG_BNX2 is not set |
| 740 | # CONFIG_CNIC is not set | ||
| 714 | CONFIG_FSL_PQ_MDIO=y | 741 | CONFIG_FSL_PQ_MDIO=y |
| 715 | CONFIG_GIANFAR=y | 742 | CONFIG_GIANFAR=y |
| 743 | # CONFIG_MV643XX_ETH is not set | ||
| 716 | # CONFIG_QLA3XXX is not set | 744 | # CONFIG_QLA3XXX is not set |
| 717 | # CONFIG_ATL1 is not set | 745 | # CONFIG_ATL1 is not set |
| 718 | # CONFIG_ATL1E is not set | 746 | # CONFIG_ATL1E is not set |
| @@ -913,13 +941,17 @@ CONFIG_I2C_MPC=y | |||
| 913 | # CONFIG_SENSORS_PCF8574 is not set | 941 | # CONFIG_SENSORS_PCF8574 is not set |
| 914 | # CONFIG_PCF8575 is not set | 942 | # CONFIG_PCF8575 is not set |
| 915 | # CONFIG_SENSORS_PCA9539 is not set | 943 | # CONFIG_SENSORS_PCA9539 is not set |
| 916 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 917 | # CONFIG_SENSORS_TSL2550 is not set | 944 | # CONFIG_SENSORS_TSL2550 is not set |
| 918 | # CONFIG_I2C_DEBUG_CORE is not set | 945 | # CONFIG_I2C_DEBUG_CORE is not set |
| 919 | # CONFIG_I2C_DEBUG_ALGO is not set | 946 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 920 | # CONFIG_I2C_DEBUG_BUS is not set | 947 | # CONFIG_I2C_DEBUG_BUS is not set |
| 921 | # CONFIG_I2C_DEBUG_CHIP is not set | 948 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 922 | # CONFIG_SPI is not set | 949 | # CONFIG_SPI is not set |
| 950 | |||
| 951 | # | ||
| 952 | # PPS support | ||
| 953 | # | ||
| 954 | # CONFIG_PPS is not set | ||
| 923 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 955 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 924 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 956 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 925 | CONFIG_GPIOLIB=y | 957 | CONFIG_GPIOLIB=y |
| @@ -973,76 +1005,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 973 | # CONFIG_MFD_WM8400 is not set | 1005 | # CONFIG_MFD_WM8400 is not set |
| 974 | # CONFIG_MFD_WM8350_I2C is not set | 1006 | # CONFIG_MFD_WM8350_I2C is not set |
| 975 | # CONFIG_MFD_PCF50633 is not set | 1007 | # CONFIG_MFD_PCF50633 is not set |
| 1008 | # CONFIG_AB3100_CORE is not set | ||
| 976 | # CONFIG_REGULATOR is not set | 1009 | # CONFIG_REGULATOR is not set |
| 977 | 1010 | # CONFIG_MEDIA_SUPPORT is not set | |
| 978 | # | ||
| 979 | # Multimedia devices | ||
| 980 | # | ||
| 981 | |||
| 982 | # | ||
| 983 | # Multimedia core support | ||
| 984 | # | ||
| 985 | # CONFIG_VIDEO_DEV is not set | ||
| 986 | CONFIG_DVB_CORE=m | ||
| 987 | CONFIG_VIDEO_MEDIA=m | ||
| 988 | |||
| 989 | # | ||
| 990 | # Multimedia drivers | ||
| 991 | # | ||
| 992 | # CONFIG_MEDIA_ATTACH is not set | ||
| 993 | CONFIG_MEDIA_TUNER=m | ||
| 994 | # CONFIG_MEDIA_TUNER_CUSTOMISE is not set | ||
| 995 | CONFIG_MEDIA_TUNER_SIMPLE=m | ||
| 996 | CONFIG_MEDIA_TUNER_TDA8290=m | ||
| 997 | CONFIG_MEDIA_TUNER_TDA9887=m | ||
| 998 | CONFIG_MEDIA_TUNER_TEA5761=m | ||
| 999 | CONFIG_MEDIA_TUNER_TEA5767=m | ||
| 1000 | CONFIG_MEDIA_TUNER_MT20XX=m | ||
| 1001 | CONFIG_MEDIA_TUNER_XC2028=m | ||
| 1002 | CONFIG_MEDIA_TUNER_XC5000=m | ||
| 1003 | CONFIG_MEDIA_TUNER_MC44S803=m | ||
| 1004 | # CONFIG_DVB_DYNAMIC_MINORS is not set | ||
| 1005 | CONFIG_DVB_CAPTURE_DRIVERS=y | ||
| 1006 | |||
| 1007 | # | ||
| 1008 | # Supported SAA7146 based PCI Adapters | ||
| 1009 | # | ||
| 1010 | # CONFIG_TTPCI_EEPROM is not set | ||
| 1011 | # CONFIG_DVB_BUDGET_CORE is not set | ||
| 1012 | |||
| 1013 | # | ||
| 1014 | # Supported USB Adapters | ||
| 1015 | # | ||
| 1016 | # CONFIG_DVB_USB is not set | ||
| 1017 | # CONFIG_DVB_TTUSB_BUDGET is not set | ||
| 1018 | # CONFIG_DVB_TTUSB_DEC is not set | ||
| 1019 | # CONFIG_DVB_SIANO_SMS1XXX is not set | ||
| 1020 | |||
| 1021 | # | ||
| 1022 | # Supported FlexCopII (B2C2) Adapters | ||
| 1023 | # | ||
| 1024 | # CONFIG_DVB_B2C2_FLEXCOP is not set | ||
| 1025 | |||
| 1026 | # | ||
| 1027 | # Supported BT878 Adapters | ||
| 1028 | # | ||
| 1029 | |||
| 1030 | # | ||
| 1031 | # Supported Pluto2 Adapters | ||
| 1032 | # | ||
| 1033 | # CONFIG_DVB_PLUTO2 is not set | ||
| 1034 | |||
| 1035 | # | ||
| 1036 | # Supported SDMC DM1105 Adapters | ||
| 1037 | # | ||
| 1038 | # CONFIG_DVB_DM1105 is not set | ||
| 1039 | |||
| 1040 | # | ||
| 1041 | # Supported DVB Frontends | ||
| 1042 | # | ||
| 1043 | # CONFIG_DVB_FE_CUSTOMISE is not set | ||
| 1044 | CONFIG_DAB=y | ||
| 1045 | # CONFIG_USB_DABUSB is not set | ||
| 1046 | 1011 | ||
| 1047 | # | 1012 | # |
| 1048 | # Graphics support | 1013 | # Graphics support |
| @@ -1082,6 +1047,11 @@ CONFIG_SND_VERBOSE_PROCFS=y | |||
| 1082 | # CONFIG_SND_VERBOSE_PRINTK is not set | 1047 | # CONFIG_SND_VERBOSE_PRINTK is not set |
| 1083 | # CONFIG_SND_DEBUG is not set | 1048 | # CONFIG_SND_DEBUG is not set |
| 1084 | CONFIG_SND_VMASTER=y | 1049 | CONFIG_SND_VMASTER=y |
| 1050 | # CONFIG_SND_RAWMIDI_SEQ is not set | ||
| 1051 | # CONFIG_SND_OPL3_LIB_SEQ is not set | ||
| 1052 | # CONFIG_SND_OPL4_LIB_SEQ is not set | ||
| 1053 | # CONFIG_SND_SBAWE_SEQ is not set | ||
| 1054 | # CONFIG_SND_EMU10K1_SEQ is not set | ||
| 1085 | CONFIG_SND_AC97_CODEC=y | 1055 | CONFIG_SND_AC97_CODEC=y |
| 1086 | CONFIG_SND_DRIVERS=y | 1056 | CONFIG_SND_DRIVERS=y |
| 1087 | # CONFIG_SND_DUMMY is not set | 1057 | # CONFIG_SND_DUMMY is not set |
| @@ -1108,6 +1078,7 @@ CONFIG_SND_PCI=y | |||
| 1108 | # CONFIG_SND_CS4281 is not set | 1078 | # CONFIG_SND_CS4281 is not set |
| 1109 | # CONFIG_SND_CS46XX is not set | 1079 | # CONFIG_SND_CS46XX is not set |
| 1110 | # CONFIG_SND_CS5530 is not set | 1080 | # CONFIG_SND_CS5530 is not set |
| 1081 | # CONFIG_SND_CTXFI is not set | ||
| 1111 | # CONFIG_SND_DARLA20 is not set | 1082 | # CONFIG_SND_DARLA20 is not set |
| 1112 | # CONFIG_SND_GINA20 is not set | 1083 | # CONFIG_SND_GINA20 is not set |
| 1113 | # CONFIG_SND_LAYLA20 is not set | 1084 | # CONFIG_SND_LAYLA20 is not set |
| @@ -1138,6 +1109,7 @@ CONFIG_SND_PCI=y | |||
| 1138 | CONFIG_SND_INTEL8X0=y | 1109 | CONFIG_SND_INTEL8X0=y |
| 1139 | # CONFIG_SND_INTEL8X0M is not set | 1110 | # CONFIG_SND_INTEL8X0M is not set |
| 1140 | # CONFIG_SND_KORG1212 is not set | 1111 | # CONFIG_SND_KORG1212 is not set |
| 1112 | # CONFIG_SND_LX6464ES is not set | ||
| 1141 | # CONFIG_SND_MAESTRO3 is not set | 1113 | # CONFIG_SND_MAESTRO3 is not set |
| 1142 | # CONFIG_SND_MIXART is not set | 1114 | # CONFIG_SND_MIXART is not set |
| 1143 | # CONFIG_SND_NM256 is not set | 1115 | # CONFIG_SND_NM256 is not set |
| @@ -1182,7 +1154,7 @@ CONFIG_HID_BELKIN=y | |||
| 1182 | CONFIG_HID_CHERRY=y | 1154 | CONFIG_HID_CHERRY=y |
| 1183 | CONFIG_HID_CHICONY=y | 1155 | CONFIG_HID_CHICONY=y |
| 1184 | CONFIG_HID_CYPRESS=y | 1156 | CONFIG_HID_CYPRESS=y |
| 1185 | # CONFIG_DRAGONRISE_FF is not set | 1157 | # CONFIG_HID_DRAGONRISE is not set |
| 1186 | CONFIG_HID_EZKEY=y | 1158 | CONFIG_HID_EZKEY=y |
| 1187 | # CONFIG_HID_KYE is not set | 1159 | # CONFIG_HID_KYE is not set |
| 1188 | CONFIG_HID_GYRATION=y | 1160 | CONFIG_HID_GYRATION=y |
| @@ -1199,10 +1171,11 @@ CONFIG_HID_PETALYNX=y | |||
| 1199 | CONFIG_HID_SAMSUNG=y | 1171 | CONFIG_HID_SAMSUNG=y |
| 1200 | CONFIG_HID_SONY=y | 1172 | CONFIG_HID_SONY=y |
| 1201 | CONFIG_HID_SUNPLUS=y | 1173 | CONFIG_HID_SUNPLUS=y |
| 1202 | # CONFIG_GREENASIA_FF is not set | 1174 | # CONFIG_HID_GREENASIA is not set |
| 1175 | # CONFIG_HID_SMARTJOYPLUS is not set | ||
| 1203 | # CONFIG_HID_TOPSEED is not set | 1176 | # CONFIG_HID_TOPSEED is not set |
| 1204 | CONFIG_THRUSTMASTER_FF=m | 1177 | # CONFIG_HID_THRUSTMASTER is not set |
| 1205 | CONFIG_ZEROPLUS_FF=m | 1178 | # CONFIG_HID_ZEROPLUS is not set |
| 1206 | CONFIG_USB_SUPPORT=y | 1179 | CONFIG_USB_SUPPORT=y |
| 1207 | CONFIG_USB_ARCH_HAS_HCD=y | 1180 | CONFIG_USB_ARCH_HAS_HCD=y |
| 1208 | CONFIG_USB_ARCH_HAS_OHCI=y | 1181 | CONFIG_USB_ARCH_HAS_OHCI=y |
| @@ -1228,6 +1201,7 @@ CONFIG_USB_MON=y | |||
| 1228 | # USB Host Controller Drivers | 1201 | # USB Host Controller Drivers |
| 1229 | # | 1202 | # |
| 1230 | # CONFIG_USB_C67X00_HCD is not set | 1203 | # CONFIG_USB_C67X00_HCD is not set |
| 1204 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1231 | CONFIG_USB_EHCI_HCD=y | 1205 | CONFIG_USB_EHCI_HCD=y |
| 1232 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set | 1206 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set |
| 1233 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1207 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1237,9 +1211,9 @@ CONFIG_USB_EHCI_HCD_PPC_OF=y | |||
| 1237 | # CONFIG_USB_ISP116X_HCD is not set | 1211 | # CONFIG_USB_ISP116X_HCD is not set |
| 1238 | # CONFIG_USB_ISP1760_HCD is not set | 1212 | # CONFIG_USB_ISP1760_HCD is not set |
| 1239 | CONFIG_USB_OHCI_HCD=y | 1213 | CONFIG_USB_OHCI_HCD=y |
| 1240 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1241 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y | 1214 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y |
| 1242 | CONFIG_USB_OHCI_HCD_PPC_OF_LE=y | 1215 | CONFIG_USB_OHCI_HCD_PPC_OF_LE=y |
| 1216 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
| 1243 | CONFIG_USB_OHCI_HCD_PCI=y | 1217 | CONFIG_USB_OHCI_HCD_PCI=y |
| 1244 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y | 1218 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y |
| 1245 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y | 1219 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y |
| @@ -1360,6 +1334,7 @@ CONFIG_RTC_INTF_DEV=y | |||
| 1360 | # CONFIG_RTC_DRV_S35390A is not set | 1334 | # CONFIG_RTC_DRV_S35390A is not set |
| 1361 | # CONFIG_RTC_DRV_FM3130 is not set | 1335 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1362 | # CONFIG_RTC_DRV_RX8581 is not set | 1336 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1337 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1363 | 1338 | ||
| 1364 | # | 1339 | # |
| 1365 | # SPI RTC drivers | 1340 | # SPI RTC drivers |
| @@ -1387,6 +1362,10 @@ CONFIG_RTC_DRV_CMOS=y | |||
| 1387 | # CONFIG_DMADEVICES is not set | 1362 | # CONFIG_DMADEVICES is not set |
| 1388 | # CONFIG_AUXDISPLAY is not set | 1363 | # CONFIG_AUXDISPLAY is not set |
| 1389 | # CONFIG_UIO is not set | 1364 | # CONFIG_UIO is not set |
| 1365 | |||
| 1366 | # | ||
| 1367 | # TI VLYNQ | ||
| 1368 | # | ||
| 1390 | # CONFIG_STAGING is not set | 1369 | # CONFIG_STAGING is not set |
| 1391 | 1370 | ||
| 1392 | # | 1371 | # |
| @@ -1406,11 +1385,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1406 | # CONFIG_REISERFS_FS is not set | 1385 | # CONFIG_REISERFS_FS is not set |
| 1407 | # CONFIG_JFS_FS is not set | 1386 | # CONFIG_JFS_FS is not set |
| 1408 | # CONFIG_FS_POSIX_ACL is not set | 1387 | # CONFIG_FS_POSIX_ACL is not set |
| 1409 | CONFIG_FILE_LOCKING=y | ||
| 1410 | # CONFIG_XFS_FS is not set | 1388 | # CONFIG_XFS_FS is not set |
| 1411 | # CONFIG_GFS2_FS is not set | 1389 | # CONFIG_GFS2_FS is not set |
| 1412 | # CONFIG_OCFS2_FS is not set | 1390 | # CONFIG_OCFS2_FS is not set |
| 1413 | # CONFIG_BTRFS_FS is not set | 1391 | # CONFIG_BTRFS_FS is not set |
| 1392 | CONFIG_FILE_LOCKING=y | ||
| 1393 | CONFIG_FSNOTIFY=y | ||
| 1414 | CONFIG_DNOTIFY=y | 1394 | CONFIG_DNOTIFY=y |
| 1415 | CONFIG_INOTIFY=y | 1395 | CONFIG_INOTIFY=y |
| 1416 | CONFIG_INOTIFY_USER=y | 1396 | CONFIG_INOTIFY_USER=y |
| @@ -1485,6 +1465,7 @@ CONFIG_NFS_FS=y | |||
| 1485 | CONFIG_NFS_V3=y | 1465 | CONFIG_NFS_V3=y |
| 1486 | # CONFIG_NFS_V3_ACL is not set | 1466 | # CONFIG_NFS_V3_ACL is not set |
| 1487 | CONFIG_NFS_V4=y | 1467 | CONFIG_NFS_V4=y |
| 1468 | # CONFIG_NFS_V4_1 is not set | ||
| 1488 | CONFIG_ROOT_NFS=y | 1469 | CONFIG_ROOT_NFS=y |
| 1489 | CONFIG_NFSD=y | 1470 | CONFIG_NFSD=y |
| 1490 | # CONFIG_NFSD_V3 is not set | 1471 | # CONFIG_NFSD_V3 is not set |
| @@ -1586,6 +1567,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1586 | CONFIG_HAS_DMA=y | 1567 | CONFIG_HAS_DMA=y |
| 1587 | CONFIG_HAVE_LMB=y | 1568 | CONFIG_HAVE_LMB=y |
| 1588 | CONFIG_NLATTR=y | 1569 | CONFIG_NLATTR=y |
| 1570 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1589 | 1571 | ||
| 1590 | # | 1572 | # |
| 1591 | # Kernel hacking | 1573 | # Kernel hacking |
| @@ -1616,6 +1598,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 1616 | # CONFIG_RT_MUTEX_TESTER is not set | 1598 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1617 | # CONFIG_DEBUG_SPINLOCK is not set | 1599 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1618 | # CONFIG_DEBUG_MUTEXES is not set | 1600 | # CONFIG_DEBUG_MUTEXES is not set |
| 1601 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1602 | # CONFIG_PROVE_LOCKING is not set | ||
| 1603 | # CONFIG_LOCK_STAT is not set | ||
| 1619 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1604 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1620 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1605 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1621 | # CONFIG_DEBUG_KOBJECT is not set | 1606 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1628,7 +1613,6 @@ CONFIG_DEBUG_INFO=y | |||
| 1628 | # CONFIG_DEBUG_LIST is not set | 1613 | # CONFIG_DEBUG_LIST is not set |
| 1629 | # CONFIG_DEBUG_SG is not set | 1614 | # CONFIG_DEBUG_SG is not set |
| 1630 | # CONFIG_DEBUG_NOTIFIERS is not set | 1615 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1631 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1632 | # CONFIG_RCU_TORTURE_TEST is not set | 1616 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1633 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1617 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1634 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1618 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1642,16 +1626,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1642 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1626 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1643 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1627 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1644 | CONFIG_TRACING_SUPPORT=y | 1628 | CONFIG_TRACING_SUPPORT=y |
| 1645 | 1629 | CONFIG_FTRACE=y | |
| 1646 | # | ||
| 1647 | # Tracers | ||
| 1648 | # | ||
| 1649 | # CONFIG_FUNCTION_TRACER is not set | 1630 | # CONFIG_FUNCTION_TRACER is not set |
| 1631 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1650 | # CONFIG_SCHED_TRACER is not set | 1632 | # CONFIG_SCHED_TRACER is not set |
| 1651 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1633 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1652 | # CONFIG_EVENT_TRACER is not set | ||
| 1653 | # CONFIG_BOOT_TRACER is not set | 1634 | # CONFIG_BOOT_TRACER is not set |
| 1654 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1635 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1636 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1637 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1655 | # CONFIG_STACK_TRACER is not set | 1638 | # CONFIG_STACK_TRACER is not set |
| 1656 | # CONFIG_KMEMTRACE is not set | 1639 | # CONFIG_KMEMTRACE is not set |
| 1657 | # CONFIG_WORKQUEUE_TRACER is not set | 1640 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -1659,6 +1642,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 1659 | # CONFIG_SAMPLES is not set | 1642 | # CONFIG_SAMPLES is not set |
| 1660 | CONFIG_HAVE_ARCH_KGDB=y | 1643 | CONFIG_HAVE_ARCH_KGDB=y |
| 1661 | # CONFIG_KGDB is not set | 1644 | # CONFIG_KGDB is not set |
| 1645 | # CONFIG_KMEMCHECK is not set | ||
| 1646 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1647 | CONFIG_PPC_WERROR=y | ||
| 1662 | CONFIG_PRINT_STACK_DEPTH=64 | 1648 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1663 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1649 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1664 | # CONFIG_DEBUG_STACK_USAGE is not set | 1650 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/mpc885_ads_defconfig b/arch/powerpc/configs/mpc885_ads_defconfig index 42e64ebc279d..dbe8e869a827 100644 --- a/arch/powerpc/configs/mpc885_ads_defconfig +++ b/arch/powerpc/configs/mpc885_ads_defconfig | |||
| @@ -1,14 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:01 2009 | 4 | # Wed Jul 29 23:31:59 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | # CONFIG_6xx is not set | 11 | # CONFIG_PPC_BOOK3S_32 is not set |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | CONFIG_PPC_8xx=y | 13 | CONFIG_PPC_8xx=y |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| @@ -27,15 +27,16 @@ CONFIG_GENERIC_TIME=y | |||
| 27 | CONFIG_GENERIC_TIME_VSYSCALL=y | 27 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 28 | CONFIG_GENERIC_CLOCKEVENTS=y | 28 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 29 | CONFIG_GENERIC_HARDIRQS=y | 29 | CONFIG_GENERIC_HARDIRQS=y |
| 30 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 30 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 31 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 31 | CONFIG_IRQ_PER_CPU=y | 32 | CONFIG_IRQ_PER_CPU=y |
| 32 | CONFIG_STACKTRACE_SUPPORT=y | 33 | CONFIG_STACKTRACE_SUPPORT=y |
| 33 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 34 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 35 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 34 | CONFIG_LOCKDEP_SUPPORT=y | 36 | CONFIG_LOCKDEP_SUPPORT=y |
| 35 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 37 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 36 | CONFIG_ARCH_HAS_ILOG2_U32=y | 38 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 37 | CONFIG_GENERIC_HWEIGHT=y | 39 | CONFIG_GENERIC_HWEIGHT=y |
| 38 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 39 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 40 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 40 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 41 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 41 | CONFIG_PPC=y | 42 | CONFIG_PPC=y |
| @@ -49,11 +50,13 @@ CONFIG_OF=y | |||
| 49 | # CONFIG_GENERIC_TBSYNC is not set | 50 | # CONFIG_GENERIC_TBSYNC is not set |
| 50 | CONFIG_AUDIT_ARCH=y | 51 | CONFIG_AUDIT_ARCH=y |
| 51 | CONFIG_GENERIC_BUG=y | 52 | CONFIG_GENERIC_BUG=y |
| 53 | CONFIG_DTC=y | ||
| 52 | # CONFIG_DEFAULT_UIMAGE is not set | 54 | # CONFIG_DEFAULT_UIMAGE is not set |
| 53 | # CONFIG_PPC_DCR_NATIVE is not set | 55 | # CONFIG_PPC_DCR_NATIVE is not set |
| 54 | # CONFIG_PPC_DCR_MMIO is not set | 56 | # CONFIG_PPC_DCR_MMIO is not set |
| 55 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 57 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 56 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 58 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 59 | CONFIG_CONSTRUCTORS=y | ||
| 57 | 60 | ||
| 58 | # | 61 | # |
| 59 | # General setup | 62 | # General setup |
| @@ -100,7 +103,6 @@ CONFIG_EMBEDDED=y | |||
| 100 | CONFIG_KALLSYMS=y | 103 | CONFIG_KALLSYMS=y |
| 101 | # CONFIG_KALLSYMS_ALL is not set | 104 | # CONFIG_KALLSYMS_ALL is not set |
| 102 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 105 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 103 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 104 | CONFIG_HOTPLUG=y | 106 | CONFIG_HOTPLUG=y |
| 105 | CONFIG_PRINTK=y | 107 | CONFIG_PRINTK=y |
| 106 | CONFIG_BUG=y | 108 | CONFIG_BUG=y |
| @@ -113,8 +115,15 @@ CONFIG_TIMERFD=y | |||
| 113 | CONFIG_EVENTFD=y | 115 | CONFIG_EVENTFD=y |
| 114 | CONFIG_SHMEM=y | 116 | CONFIG_SHMEM=y |
| 115 | CONFIG_AIO=y | 117 | CONFIG_AIO=y |
| 118 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 119 | |||
| 120 | # | ||
| 121 | # Performance Counters | ||
| 122 | # | ||
| 123 | # CONFIG_PERF_COUNTERS is not set | ||
| 116 | # CONFIG_VM_EVENT_COUNTERS is not set | 124 | # CONFIG_VM_EVENT_COUNTERS is not set |
| 117 | CONFIG_SLUB_DEBUG=y | 125 | CONFIG_SLUB_DEBUG=y |
| 126 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 118 | CONFIG_COMPAT_BRK=y | 127 | CONFIG_COMPAT_BRK=y |
| 119 | # CONFIG_SLAB is not set | 128 | # CONFIG_SLAB is not set |
| 120 | CONFIG_SLUB=y | 129 | CONFIG_SLUB=y |
| @@ -128,13 +137,17 @@ CONFIG_HAVE_KPROBES=y | |||
| 128 | CONFIG_HAVE_KRETPROBES=y | 137 | CONFIG_HAVE_KRETPROBES=y |
| 129 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 138 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 130 | CONFIG_HAVE_CLK=y | 139 | CONFIG_HAVE_CLK=y |
| 140 | |||
| 141 | # | ||
| 142 | # GCOV-based kernel profiling | ||
| 143 | # | ||
| 131 | # CONFIG_SLOW_WORK is not set | 144 | # CONFIG_SLOW_WORK is not set |
| 132 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 145 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 133 | CONFIG_SLABINFO=y | 146 | CONFIG_SLABINFO=y |
| 134 | CONFIG_BASE_SMALL=1 | 147 | CONFIG_BASE_SMALL=1 |
| 135 | # CONFIG_MODULES is not set | 148 | # CONFIG_MODULES is not set |
| 136 | CONFIG_BLOCK=y | 149 | CONFIG_BLOCK=y |
| 137 | # CONFIG_LBD is not set | 150 | CONFIG_LBDAF=y |
| 138 | # CONFIG_BLK_DEV_BSG is not set | 151 | # CONFIG_BLK_DEV_BSG is not set |
| 139 | # CONFIG_BLK_DEV_INTEGRITY is not set | 152 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 140 | 153 | ||
| @@ -227,6 +240,7 @@ CONFIG_BINFMT_ELF=y | |||
| 227 | # CONFIG_MATH_EMULATION is not set | 240 | # CONFIG_MATH_EMULATION is not set |
| 228 | CONFIG_8XX_MINIMAL_FPEMU=y | 241 | CONFIG_8XX_MINIMAL_FPEMU=y |
| 229 | # CONFIG_IOMMU_HELPER is not set | 242 | # CONFIG_IOMMU_HELPER is not set |
| 243 | # CONFIG_SWIOTLB is not set | ||
| 230 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y | 244 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y |
| 231 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 245 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 232 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 246 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| @@ -246,9 +260,9 @@ CONFIG_MIGRATION=y | |||
| 246 | CONFIG_ZONE_DMA_FLAG=1 | 260 | CONFIG_ZONE_DMA_FLAG=1 |
| 247 | CONFIG_BOUNCE=y | 261 | CONFIG_BOUNCE=y |
| 248 | CONFIG_VIRT_TO_BUS=y | 262 | CONFIG_VIRT_TO_BUS=y |
| 249 | CONFIG_UNEVICTABLE_LRU=y | ||
| 250 | CONFIG_HAVE_MLOCK=y | 263 | CONFIG_HAVE_MLOCK=y |
| 251 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 264 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 265 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 252 | CONFIG_PPC_4K_PAGES=y | 266 | CONFIG_PPC_4K_PAGES=y |
| 253 | # CONFIG_PPC_16K_PAGES is not set | 267 | # CONFIG_PPC_16K_PAGES is not set |
| 254 | # CONFIG_PPC_64K_PAGES is not set | 268 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -287,6 +301,7 @@ CONFIG_PAGE_OFFSET=0xc0000000 | |||
| 287 | CONFIG_KERNEL_START=0xc0000000 | 301 | CONFIG_KERNEL_START=0xc0000000 |
| 288 | CONFIG_PHYSICAL_START=0x00000000 | 302 | CONFIG_PHYSICAL_START=0x00000000 |
| 289 | CONFIG_TASK_SIZE=0x80000000 | 303 | CONFIG_TASK_SIZE=0x80000000 |
| 304 | CONFIG_CONSISTENT_SIZE=0x00200000 | ||
| 290 | CONFIG_NET=y | 305 | CONFIG_NET=y |
| 291 | 306 | ||
| 292 | # | 307 | # |
| @@ -343,6 +358,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 343 | # CONFIG_ECONET is not set | 358 | # CONFIG_ECONET is not set |
| 344 | # CONFIG_WAN_ROUTER is not set | 359 | # CONFIG_WAN_ROUTER is not set |
| 345 | # CONFIG_PHONET is not set | 360 | # CONFIG_PHONET is not set |
| 361 | # CONFIG_IEEE802154 is not set | ||
| 346 | # CONFIG_NET_SCHED is not set | 362 | # CONFIG_NET_SCHED is not set |
| 347 | # CONFIG_DCB is not set | 363 | # CONFIG_DCB is not set |
| 348 | 364 | ||
| @@ -360,7 +376,11 @@ CONFIG_WIRELESS=y | |||
| 360 | CONFIG_WIRELESS_OLD_REGULATORY=y | 376 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 361 | # CONFIG_WIRELESS_EXT is not set | 377 | # CONFIG_WIRELESS_EXT is not set |
| 362 | # CONFIG_LIB80211 is not set | 378 | # CONFIG_LIB80211 is not set |
| 363 | # CONFIG_MAC80211 is not set | 379 | |
| 380 | # | ||
| 381 | # CFG80211 needs to be enabled for MAC80211 | ||
| 382 | # | ||
| 383 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 364 | # CONFIG_WIMAX is not set | 384 | # CONFIG_WIMAX is not set |
| 365 | # CONFIG_RFKILL is not set | 385 | # CONFIG_RFKILL is not set |
| 366 | # CONFIG_NET_9P is not set | 386 | # CONFIG_NET_9P is not set |
| @@ -463,6 +483,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 463 | # | 483 | # |
| 464 | # CONFIG_MTD_UBI is not set | 484 | # CONFIG_MTD_UBI is not set |
| 465 | CONFIG_OF_DEVICE=y | 485 | CONFIG_OF_DEVICE=y |
| 486 | CONFIG_OF_MDIO=y | ||
| 466 | # CONFIG_PARPORT is not set | 487 | # CONFIG_PARPORT is not set |
| 467 | # CONFIG_BLK_DEV is not set | 488 | # CONFIG_BLK_DEV is not set |
| 468 | # CONFIG_MISC_DEVICES is not set | 489 | # CONFIG_MISC_DEVICES is not set |
| @@ -480,7 +501,6 @@ CONFIG_HAVE_IDE=y | |||
| 480 | # CONFIG_MD is not set | 501 | # CONFIG_MD is not set |
| 481 | # CONFIG_MACINTOSH_DRIVERS is not set | 502 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 482 | CONFIG_NETDEVICES=y | 503 | CONFIG_NETDEVICES=y |
| 483 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 484 | # CONFIG_DUMMY is not set | 504 | # CONFIG_DUMMY is not set |
| 485 | # CONFIG_BONDING is not set | 505 | # CONFIG_BONDING is not set |
| 486 | # CONFIG_MACVLAN is not set | 506 | # CONFIG_MACVLAN is not set |
| @@ -519,6 +539,7 @@ CONFIG_MII=y | |||
| 519 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 539 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 520 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 540 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 521 | # CONFIG_B44 is not set | 541 | # CONFIG_B44 is not set |
| 542 | # CONFIG_KS8842 is not set | ||
| 522 | CONFIG_FS_ENET=y | 543 | CONFIG_FS_ENET=y |
| 523 | # CONFIG_FS_ENET_HAS_SCC is not set | 544 | # CONFIG_FS_ENET_HAS_SCC is not set |
| 524 | CONFIG_FS_ENET_HAS_FEC=y | 545 | CONFIG_FS_ENET_HAS_FEC=y |
| @@ -590,6 +611,11 @@ CONFIG_GEN_RTC=y | |||
| 590 | # CONFIG_TCG_TPM is not set | 611 | # CONFIG_TCG_TPM is not set |
| 591 | # CONFIG_I2C is not set | 612 | # CONFIG_I2C is not set |
| 592 | # CONFIG_SPI is not set | 613 | # CONFIG_SPI is not set |
| 614 | |||
| 615 | # | ||
| 616 | # PPS support | ||
| 617 | # | ||
| 618 | # CONFIG_PPS is not set | ||
| 593 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 619 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 594 | # CONFIG_GPIOLIB is not set | 620 | # CONFIG_GPIOLIB is not set |
| 595 | # CONFIG_W1 is not set | 621 | # CONFIG_W1 is not set |
| @@ -613,22 +639,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 613 | # CONFIG_HTC_PASIC3 is not set | 639 | # CONFIG_HTC_PASIC3 is not set |
| 614 | # CONFIG_MFD_TMIO is not set | 640 | # CONFIG_MFD_TMIO is not set |
| 615 | # CONFIG_REGULATOR is not set | 641 | # CONFIG_REGULATOR is not set |
| 616 | 642 | # CONFIG_MEDIA_SUPPORT is not set | |
| 617 | # | ||
| 618 | # Multimedia devices | ||
| 619 | # | ||
| 620 | |||
| 621 | # | ||
| 622 | # Multimedia core support | ||
| 623 | # | ||
| 624 | # CONFIG_VIDEO_DEV is not set | ||
| 625 | # CONFIG_DVB_CORE is not set | ||
| 626 | # CONFIG_VIDEO_MEDIA is not set | ||
| 627 | |||
| 628 | # | ||
| 629 | # Multimedia drivers | ||
| 630 | # | ||
| 631 | CONFIG_DAB=y | ||
| 632 | 643 | ||
| 633 | # | 644 | # |
| 634 | # Graphics support | 645 | # Graphics support |
| @@ -653,6 +664,10 @@ CONFIG_DAB=y | |||
| 653 | # CONFIG_DMADEVICES is not set | 664 | # CONFIG_DMADEVICES is not set |
| 654 | # CONFIG_AUXDISPLAY is not set | 665 | # CONFIG_AUXDISPLAY is not set |
| 655 | # CONFIG_UIO is not set | 666 | # CONFIG_UIO is not set |
| 667 | |||
| 668 | # | ||
| 669 | # TI VLYNQ | ||
| 670 | # | ||
| 656 | # CONFIG_STAGING is not set | 671 | # CONFIG_STAGING is not set |
| 657 | 672 | ||
| 658 | # | 673 | # |
| @@ -664,12 +679,15 @@ CONFIG_DAB=y | |||
| 664 | # CONFIG_REISERFS_FS is not set | 679 | # CONFIG_REISERFS_FS is not set |
| 665 | # CONFIG_JFS_FS is not set | 680 | # CONFIG_JFS_FS is not set |
| 666 | # CONFIG_FS_POSIX_ACL is not set | 681 | # CONFIG_FS_POSIX_ACL is not set |
| 667 | CONFIG_FILE_LOCKING=y | ||
| 668 | # CONFIG_XFS_FS is not set | 682 | # CONFIG_XFS_FS is not set |
| 683 | # CONFIG_GFS2_FS is not set | ||
| 669 | # CONFIG_OCFS2_FS is not set | 684 | # CONFIG_OCFS2_FS is not set |
| 670 | # CONFIG_BTRFS_FS is not set | 685 | # CONFIG_BTRFS_FS is not set |
| 686 | CONFIG_FILE_LOCKING=y | ||
| 687 | CONFIG_FSNOTIFY=y | ||
| 671 | # CONFIG_DNOTIFY is not set | 688 | # CONFIG_DNOTIFY is not set |
| 672 | # CONFIG_INOTIFY is not set | 689 | # CONFIG_INOTIFY is not set |
| 690 | CONFIG_INOTIFY_USER=y | ||
| 673 | # CONFIG_QUOTA is not set | 691 | # CONFIG_QUOTA is not set |
| 674 | # CONFIG_AUTOFS_FS is not set | 692 | # CONFIG_AUTOFS_FS is not set |
| 675 | # CONFIG_AUTOFS4_FS is not set | 693 | # CONFIG_AUTOFS4_FS is not set |
| @@ -786,6 +804,7 @@ CONFIG_HAS_IOPORT=y | |||
| 786 | CONFIG_HAS_DMA=y | 804 | CONFIG_HAS_DMA=y |
| 787 | CONFIG_HAVE_LMB=y | 805 | CONFIG_HAVE_LMB=y |
| 788 | CONFIG_NLATTR=y | 806 | CONFIG_NLATTR=y |
| 807 | CONFIG_GENERIC_ATOMIC64=y | ||
| 789 | 808 | ||
| 790 | # | 809 | # |
| 791 | # Kernel hacking | 810 | # Kernel hacking |
| @@ -814,6 +833,9 @@ CONFIG_SCHED_DEBUG=y | |||
| 814 | # CONFIG_SLUB_STATS is not set | 833 | # CONFIG_SLUB_STATS is not set |
| 815 | # CONFIG_DEBUG_SPINLOCK is not set | 834 | # CONFIG_DEBUG_SPINLOCK is not set |
| 816 | # CONFIG_DEBUG_MUTEXES is not set | 835 | # CONFIG_DEBUG_MUTEXES is not set |
| 836 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 837 | # CONFIG_PROVE_LOCKING is not set | ||
| 838 | # CONFIG_LOCK_STAT is not set | ||
| 817 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 839 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 818 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 840 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 819 | # CONFIG_DEBUG_KOBJECT is not set | 841 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -825,7 +847,6 @@ CONFIG_DEBUG_INFO=y | |||
| 825 | # CONFIG_DEBUG_LIST is not set | 847 | # CONFIG_DEBUG_LIST is not set |
| 826 | # CONFIG_DEBUG_SG is not set | 848 | # CONFIG_DEBUG_SG is not set |
| 827 | # CONFIG_DEBUG_NOTIFIERS is not set | 849 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 828 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 829 | # CONFIG_RCU_TORTURE_TEST is not set | 850 | # CONFIG_RCU_TORTURE_TEST is not set |
| 830 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 851 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 831 | # CONFIG_BACKTRACE_SELF_TEST is not set | 852 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -838,16 +859,15 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 838 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 859 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 839 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 860 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 840 | CONFIG_TRACING_SUPPORT=y | 861 | CONFIG_TRACING_SUPPORT=y |
| 841 | 862 | CONFIG_FTRACE=y | |
| 842 | # | ||
| 843 | # Tracers | ||
| 844 | # | ||
| 845 | # CONFIG_FUNCTION_TRACER is not set | 863 | # CONFIG_FUNCTION_TRACER is not set |
| 864 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 846 | # CONFIG_SCHED_TRACER is not set | 865 | # CONFIG_SCHED_TRACER is not set |
| 847 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 866 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 848 | # CONFIG_EVENT_TRACER is not set | ||
| 849 | # CONFIG_BOOT_TRACER is not set | 867 | # CONFIG_BOOT_TRACER is not set |
| 850 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 868 | CONFIG_BRANCH_PROFILE_NONE=y |
| 869 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 870 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 851 | # CONFIG_STACK_TRACER is not set | 871 | # CONFIG_STACK_TRACER is not set |
| 852 | # CONFIG_KMEMTRACE is not set | 872 | # CONFIG_KMEMTRACE is not set |
| 853 | # CONFIG_WORKQUEUE_TRACER is not set | 873 | # CONFIG_WORKQUEUE_TRACER is not set |
| @@ -855,6 +875,9 @@ CONFIG_TRACING_SUPPORT=y | |||
| 855 | # CONFIG_SAMPLES is not set | 875 | # CONFIG_SAMPLES is not set |
| 856 | CONFIG_HAVE_ARCH_KGDB=y | 876 | CONFIG_HAVE_ARCH_KGDB=y |
| 857 | # CONFIG_KGDB is not set | 877 | # CONFIG_KGDB is not set |
| 878 | # CONFIG_KMEMCHECK is not set | ||
| 879 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 880 | CONFIG_PPC_WERROR=y | ||
| 858 | CONFIG_PRINT_STACK_DEPTH=64 | 881 | CONFIG_PRINT_STACK_DEPTH=64 |
| 859 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 882 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 860 | # CONFIG_DEBUG_STACK_USAGE is not set | 883 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/pq2fads_defconfig b/arch/powerpc/configs/pq2fads_defconfig index 129d80860f2a..ff96bb43c32d 100644 --- a/arch/powerpc/configs/pq2fads_defconfig +++ b/arch/powerpc/configs/pq2fads_defconfig | |||
| @@ -1,25 +1,27 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:02 2009 | 4 | # Wed Jul 29 23:32:00 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_ALTIVEC is not set | 20 | # CONFIG_ALTIVEC is not set |
| 20 | CONFIG_PPC_STD_MMU=y | 21 | CONFIG_PPC_STD_MMU=y |
| 21 | CONFIG_PPC_STD_MMU_32=y | 22 | CONFIG_PPC_STD_MMU_32=y |
| 22 | # CONFIG_PPC_MM_SLICES is not set | 23 | # CONFIG_PPC_MM_SLICES is not set |
| 24 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 23 | # CONFIG_SMP is not set | 25 | # CONFIG_SMP is not set |
| 24 | CONFIG_PPC32=y | 26 | CONFIG_PPC32=y |
| 25 | CONFIG_WORD_SIZE=32 | 27 | CONFIG_WORD_SIZE=32 |
| @@ -30,15 +32,16 @@ CONFIG_GENERIC_TIME=y | |||
| 30 | CONFIG_GENERIC_TIME_VSYSCALL=y | 32 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 31 | CONFIG_GENERIC_CLOCKEVENTS=y | 33 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 32 | CONFIG_GENERIC_HARDIRQS=y | 34 | CONFIG_GENERIC_HARDIRQS=y |
| 35 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 33 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 36 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 34 | CONFIG_IRQ_PER_CPU=y | 37 | CONFIG_IRQ_PER_CPU=y |
| 35 | CONFIG_STACKTRACE_SUPPORT=y | 38 | CONFIG_STACKTRACE_SUPPORT=y |
| 36 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 39 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 40 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 37 | CONFIG_LOCKDEP_SUPPORT=y | 41 | CONFIG_LOCKDEP_SUPPORT=y |
| 38 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 39 | CONFIG_ARCH_HAS_ILOG2_U32=y | 43 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 40 | CONFIG_GENERIC_HWEIGHT=y | 44 | CONFIG_GENERIC_HWEIGHT=y |
| 41 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 42 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 45 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 43 | CONFIG_GENERIC_GPIO=y | 46 | CONFIG_GENERIC_GPIO=y |
| 44 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 47 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| @@ -53,11 +56,13 @@ CONFIG_OF=y | |||
| 53 | # CONFIG_GENERIC_TBSYNC is not set | 56 | # CONFIG_GENERIC_TBSYNC is not set |
| 54 | CONFIG_AUDIT_ARCH=y | 57 | CONFIG_AUDIT_ARCH=y |
| 55 | CONFIG_GENERIC_BUG=y | 58 | CONFIG_GENERIC_BUG=y |
| 59 | CONFIG_DTC=y | ||
| 56 | CONFIG_DEFAULT_UIMAGE=y | 60 | CONFIG_DEFAULT_UIMAGE=y |
| 57 | # CONFIG_PPC_DCR_NATIVE is not set | 61 | # CONFIG_PPC_DCR_NATIVE is not set |
| 58 | # CONFIG_PPC_DCR_MMIO is not set | 62 | # CONFIG_PPC_DCR_MMIO is not set |
| 59 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 63 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 60 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 64 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 65 | CONFIG_CONSTRUCTORS=y | ||
| 61 | 66 | ||
| 62 | # | 67 | # |
| 63 | # General setup | 68 | # General setup |
| @@ -103,7 +108,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 103 | CONFIG_KALLSYMS=y | 108 | CONFIG_KALLSYMS=y |
| 104 | CONFIG_KALLSYMS_ALL=y | 109 | CONFIG_KALLSYMS_ALL=y |
| 105 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 110 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 106 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 107 | CONFIG_HOTPLUG=y | 111 | CONFIG_HOTPLUG=y |
| 108 | CONFIG_PRINTK=y | 112 | CONFIG_PRINTK=y |
| 109 | CONFIG_BUG=y | 113 | CONFIG_BUG=y |
| @@ -116,9 +120,16 @@ CONFIG_TIMERFD=y | |||
| 116 | CONFIG_EVENTFD=y | 120 | CONFIG_EVENTFD=y |
| 117 | CONFIG_SHMEM=y | 121 | CONFIG_SHMEM=y |
| 118 | CONFIG_AIO=y | 122 | CONFIG_AIO=y |
| 123 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 124 | |||
| 125 | # | ||
| 126 | # Performance Counters | ||
| 127 | # | ||
| 128 | # CONFIG_PERF_COUNTERS is not set | ||
| 119 | CONFIG_VM_EVENT_COUNTERS=y | 129 | CONFIG_VM_EVENT_COUNTERS=y |
| 120 | CONFIG_PCI_QUIRKS=y | 130 | CONFIG_PCI_QUIRKS=y |
| 121 | CONFIG_SLUB_DEBUG=y | 131 | CONFIG_SLUB_DEBUG=y |
| 132 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 122 | CONFIG_COMPAT_BRK=y | 133 | CONFIG_COMPAT_BRK=y |
| 123 | # CONFIG_SLAB is not set | 134 | # CONFIG_SLAB is not set |
| 124 | CONFIG_SLUB=y | 135 | CONFIG_SLUB=y |
| @@ -132,6 +143,10 @@ CONFIG_HAVE_KPROBES=y | |||
| 132 | CONFIG_HAVE_KRETPROBES=y | 143 | CONFIG_HAVE_KRETPROBES=y |
| 133 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 144 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 134 | CONFIG_HAVE_CLK=y | 145 | CONFIG_HAVE_CLK=y |
| 146 | |||
| 147 | # | ||
| 148 | # GCOV-based kernel profiling | ||
| 149 | # | ||
| 135 | # CONFIG_SLOW_WORK is not set | 150 | # CONFIG_SLOW_WORK is not set |
| 136 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 151 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 137 | CONFIG_SLABINFO=y | 152 | CONFIG_SLABINFO=y |
| @@ -139,7 +154,7 @@ CONFIG_RT_MUTEXES=y | |||
| 139 | CONFIG_BASE_SMALL=0 | 154 | CONFIG_BASE_SMALL=0 |
| 140 | # CONFIG_MODULES is not set | 155 | # CONFIG_MODULES is not set |
| 141 | CONFIG_BLOCK=y | 156 | CONFIG_BLOCK=y |
| 142 | # CONFIG_LBD is not set | 157 | CONFIG_LBDAF=y |
| 143 | # CONFIG_BLK_DEV_INTEGRITY is not set | 158 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 144 | 159 | ||
| 145 | # | 160 | # |
| @@ -219,6 +234,7 @@ CONFIG_BINFMT_ELF=y | |||
| 219 | # CONFIG_HAVE_AOUT is not set | 234 | # CONFIG_HAVE_AOUT is not set |
| 220 | CONFIG_BINFMT_MISC=y | 235 | CONFIG_BINFMT_MISC=y |
| 221 | # CONFIG_IOMMU_HELPER is not set | 236 | # CONFIG_IOMMU_HELPER is not set |
| 237 | # CONFIG_SWIOTLB is not set | ||
| 222 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 238 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 223 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 239 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 224 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 240 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -234,9 +250,9 @@ CONFIG_MIGRATION=y | |||
| 234 | CONFIG_ZONE_DMA_FLAG=1 | 250 | CONFIG_ZONE_DMA_FLAG=1 |
| 235 | CONFIG_BOUNCE=y | 251 | CONFIG_BOUNCE=y |
| 236 | CONFIG_VIRT_TO_BUS=y | 252 | CONFIG_VIRT_TO_BUS=y |
| 237 | CONFIG_UNEVICTABLE_LRU=y | ||
| 238 | CONFIG_HAVE_MLOCK=y | 253 | CONFIG_HAVE_MLOCK=y |
| 239 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 254 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 255 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 240 | CONFIG_PPC_4K_PAGES=y | 256 | CONFIG_PPC_4K_PAGES=y |
| 241 | # CONFIG_PPC_16K_PAGES is not set | 257 | # CONFIG_PPC_16K_PAGES is not set |
| 242 | # CONFIG_PPC_64K_PAGES is not set | 258 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -307,6 +323,7 @@ CONFIG_IP_PNP_BOOTP=y | |||
| 307 | # CONFIG_NET_IPIP is not set | 323 | # CONFIG_NET_IPIP is not set |
| 308 | # CONFIG_NET_IPGRE is not set | 324 | # CONFIG_NET_IPGRE is not set |
| 309 | # CONFIG_IP_MROUTE is not set | 325 | # CONFIG_IP_MROUTE is not set |
| 326 | # CONFIG_ARPD is not set | ||
| 310 | CONFIG_SYN_COOKIES=y | 327 | CONFIG_SYN_COOKIES=y |
| 311 | # CONFIG_INET_AH is not set | 328 | # CONFIG_INET_AH is not set |
| 312 | # CONFIG_INET_ESP is not set | 329 | # CONFIG_INET_ESP is not set |
| @@ -387,7 +404,11 @@ CONFIG_WIRELESS=y | |||
| 387 | CONFIG_WIRELESS_OLD_REGULATORY=y | 404 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 388 | # CONFIG_WIRELESS_EXT is not set | 405 | # CONFIG_WIRELESS_EXT is not set |
| 389 | # CONFIG_LIB80211 is not set | 406 | # CONFIG_LIB80211 is not set |
| 390 | # CONFIG_MAC80211 is not set | 407 | |
| 408 | # | ||
| 409 | # CFG80211 needs to be enabled for MAC80211 | ||
| 410 | # | ||
| 411 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 391 | # CONFIG_WIMAX is not set | 412 | # CONFIG_WIMAX is not set |
| 392 | # CONFIG_RFKILL is not set | 413 | # CONFIG_RFKILL is not set |
| 393 | 414 | ||
| @@ -493,6 +514,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 493 | # CONFIG_MTD_UBI is not set | 514 | # CONFIG_MTD_UBI is not set |
| 494 | CONFIG_OF_DEVICE=y | 515 | CONFIG_OF_DEVICE=y |
| 495 | CONFIG_OF_GPIO=y | 516 | CONFIG_OF_GPIO=y |
| 517 | CONFIG_OF_MDIO=y | ||
| 496 | # CONFIG_PARPORT is not set | 518 | # CONFIG_PARPORT is not set |
| 497 | CONFIG_BLK_DEV=y | 519 | CONFIG_BLK_DEV=y |
| 498 | # CONFIG_BLK_DEV_FD is not set | 520 | # CONFIG_BLK_DEV_FD is not set |
| @@ -518,6 +540,7 @@ CONFIG_MISC_DEVICES=y | |||
| 518 | # EEPROM support | 540 | # EEPROM support |
| 519 | # | 541 | # |
| 520 | # CONFIG_EEPROM_93CX6 is not set | 542 | # CONFIG_EEPROM_93CX6 is not set |
| 543 | # CONFIG_CB710_CORE is not set | ||
| 521 | CONFIG_HAVE_IDE=y | 544 | CONFIG_HAVE_IDE=y |
| 522 | CONFIG_IDE=y | 545 | CONFIG_IDE=y |
| 523 | 546 | ||
| @@ -583,13 +606,17 @@ CONFIG_IDE_PROC_FS=y | |||
| 583 | # | 606 | # |
| 584 | 607 | ||
| 585 | # | 608 | # |
| 586 | # A new alternative FireWire stack is available with EXPERIMENTAL=y | 609 | # You can enable one or both FireWire driver stacks. |
| 610 | # | ||
| 611 | |||
| 612 | # | ||
| 613 | # See the help texts for more information. | ||
| 587 | # | 614 | # |
| 615 | # CONFIG_FIREWIRE is not set | ||
| 588 | # CONFIG_IEEE1394 is not set | 616 | # CONFIG_IEEE1394 is not set |
| 589 | # CONFIG_I2O is not set | 617 | # CONFIG_I2O is not set |
| 590 | # CONFIG_MACINTOSH_DRIVERS is not set | 618 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 591 | CONFIG_NETDEVICES=y | 619 | CONFIG_NETDEVICES=y |
| 592 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 593 | # CONFIG_DUMMY is not set | 620 | # CONFIG_DUMMY is not set |
| 594 | # CONFIG_BONDING is not set | 621 | # CONFIG_BONDING is not set |
| 595 | # CONFIG_EQUALIZER is not set | 622 | # CONFIG_EQUALIZER is not set |
| @@ -636,6 +663,7 @@ CONFIG_MII=y | |||
| 636 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 663 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 637 | # CONFIG_NET_PCI is not set | 664 | # CONFIG_NET_PCI is not set |
| 638 | # CONFIG_B44 is not set | 665 | # CONFIG_B44 is not set |
| 666 | # CONFIG_KS8842 is not set | ||
| 639 | # CONFIG_ATL2 is not set | 667 | # CONFIG_ATL2 is not set |
| 640 | CONFIG_FS_ENET=y | 668 | CONFIG_FS_ENET=y |
| 641 | # CONFIG_FS_ENET_HAS_SCC is not set | 669 | # CONFIG_FS_ENET_HAS_SCC is not set |
| @@ -657,8 +685,10 @@ CONFIG_NETDEV_1000=y | |||
| 657 | # CONFIG_VIA_VELOCITY is not set | 685 | # CONFIG_VIA_VELOCITY is not set |
| 658 | # CONFIG_TIGON3 is not set | 686 | # CONFIG_TIGON3 is not set |
| 659 | # CONFIG_BNX2 is not set | 687 | # CONFIG_BNX2 is not set |
| 688 | # CONFIG_CNIC is not set | ||
| 660 | # CONFIG_FSL_PQ_MDIO is not set | 689 | # CONFIG_FSL_PQ_MDIO is not set |
| 661 | # CONFIG_GIANFAR is not set | 690 | # CONFIG_GIANFAR is not set |
| 691 | # CONFIG_MV643XX_ETH is not set | ||
| 662 | # CONFIG_QLA3XXX is not set | 692 | # CONFIG_QLA3XXX is not set |
| 663 | # CONFIG_ATL1 is not set | 693 | # CONFIG_ATL1 is not set |
| 664 | # CONFIG_JME is not set | 694 | # CONFIG_JME is not set |
| @@ -730,12 +760,13 @@ CONFIG_INPUT_EVDEV=y | |||
| 730 | # | 760 | # |
| 731 | CONFIG_INPUT_KEYBOARD=y | 761 | CONFIG_INPUT_KEYBOARD=y |
| 732 | CONFIG_KEYBOARD_ATKBD=y | 762 | CONFIG_KEYBOARD_ATKBD=y |
| 733 | # CONFIG_KEYBOARD_SUNKBD is not set | ||
| 734 | # CONFIG_KEYBOARD_LKKBD is not set | 763 | # CONFIG_KEYBOARD_LKKBD is not set |
| 735 | # CONFIG_KEYBOARD_XTKBD is not set | 764 | # CONFIG_KEYBOARD_GPIO is not set |
| 765 | # CONFIG_KEYBOARD_MATRIX is not set | ||
| 736 | # CONFIG_KEYBOARD_NEWTON is not set | 766 | # CONFIG_KEYBOARD_NEWTON is not set |
| 737 | # CONFIG_KEYBOARD_STOWAWAY is not set | 767 | # CONFIG_KEYBOARD_STOWAWAY is not set |
| 738 | # CONFIG_KEYBOARD_GPIO is not set | 768 | # CONFIG_KEYBOARD_SUNKBD is not set |
| 769 | # CONFIG_KEYBOARD_XTKBD is not set | ||
| 739 | CONFIG_INPUT_MOUSE=y | 770 | CONFIG_INPUT_MOUSE=y |
| 740 | CONFIG_MOUSE_PS2=y | 771 | CONFIG_MOUSE_PS2=y |
| 741 | CONFIG_MOUSE_PS2_ALPS=y | 772 | CONFIG_MOUSE_PS2_ALPS=y |
| @@ -802,6 +833,10 @@ CONFIG_HW_RANDOM=y | |||
| 802 | CONFIG_DEVPORT=y | 833 | CONFIG_DEVPORT=y |
| 803 | # CONFIG_I2C is not set | 834 | # CONFIG_I2C is not set |
| 804 | # CONFIG_SPI is not set | 835 | # CONFIG_SPI is not set |
| 836 | |||
| 837 | # | ||
| 838 | # PPS support | ||
| 839 | # | ||
| 805 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 840 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 806 | CONFIG_ARCH_REQUIRE_GPIOLIB=y | 841 | CONFIG_ARCH_REQUIRE_GPIOLIB=y |
| 807 | CONFIG_GPIOLIB=y | 842 | CONFIG_GPIOLIB=y |
| @@ -845,22 +880,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 845 | # CONFIG_HTC_PASIC3 is not set | 880 | # CONFIG_HTC_PASIC3 is not set |
| 846 | # CONFIG_MFD_TMIO is not set | 881 | # CONFIG_MFD_TMIO is not set |
| 847 | # CONFIG_REGULATOR is not set | 882 | # CONFIG_REGULATOR is not set |
| 848 | 883 | # CONFIG_MEDIA_SUPPORT is not set | |
| 849 | # | ||
| 850 | # Multimedia devices | ||
| 851 | # | ||
| 852 | |||
| 853 | # | ||
| 854 | # Multimedia core support | ||
| 855 | # | ||
| 856 | # CONFIG_VIDEO_DEV is not set | ||
| 857 | # CONFIG_DVB_CORE is not set | ||
| 858 | # CONFIG_VIDEO_MEDIA is not set | ||
| 859 | |||
| 860 | # | ||
| 861 | # Multimedia drivers | ||
| 862 | # | ||
| 863 | CONFIG_DAB=y | ||
| 864 | 884 | ||
| 865 | # | 885 | # |
| 866 | # Graphics support | 886 | # Graphics support |
| @@ -903,8 +923,9 @@ CONFIG_USB_GADGET_SELECTED=y | |||
| 903 | # CONFIG_USB_GADGET_OMAP is not set | 923 | # CONFIG_USB_GADGET_OMAP is not set |
| 904 | # CONFIG_USB_GADGET_PXA25X is not set | 924 | # CONFIG_USB_GADGET_PXA25X is not set |
| 905 | # CONFIG_USB_GADGET_PXA27X is not set | 925 | # CONFIG_USB_GADGET_PXA27X is not set |
| 906 | # CONFIG_USB_GADGET_S3C2410 is not set | 926 | # CONFIG_USB_GADGET_S3C_HSOTG is not set |
| 907 | # CONFIG_USB_GADGET_IMX is not set | 927 | # CONFIG_USB_GADGET_IMX is not set |
| 928 | # CONFIG_USB_GADGET_S3C2410 is not set | ||
| 908 | CONFIG_USB_GADGET_M66592=y | 929 | CONFIG_USB_GADGET_M66592=y |
| 909 | CONFIG_USB_M66592=y | 930 | CONFIG_USB_M66592=y |
| 910 | # CONFIG_USB_GADGET_AMD5536UDC is not set | 931 | # CONFIG_USB_GADGET_AMD5536UDC is not set |
| @@ -912,9 +933,11 @@ CONFIG_USB_M66592=y | |||
| 912 | # CONFIG_USB_GADGET_CI13XXX is not set | 933 | # CONFIG_USB_GADGET_CI13XXX is not set |
| 913 | # CONFIG_USB_GADGET_NET2280 is not set | 934 | # CONFIG_USB_GADGET_NET2280 is not set |
| 914 | # CONFIG_USB_GADGET_GOKU is not set | 935 | # CONFIG_USB_GADGET_GOKU is not set |
| 936 | # CONFIG_USB_GADGET_LANGWELL is not set | ||
| 915 | # CONFIG_USB_GADGET_DUMMY_HCD is not set | 937 | # CONFIG_USB_GADGET_DUMMY_HCD is not set |
| 916 | CONFIG_USB_GADGET_DUALSPEED=y | 938 | CONFIG_USB_GADGET_DUALSPEED=y |
| 917 | # CONFIG_USB_ZERO is not set | 939 | # CONFIG_USB_ZERO is not set |
| 940 | # CONFIG_USB_AUDIO is not set | ||
| 918 | CONFIG_USB_ETH=y | 941 | CONFIG_USB_ETH=y |
| 919 | CONFIG_USB_ETH_RNDIS=y | 942 | CONFIG_USB_ETH_RNDIS=y |
| 920 | # CONFIG_USB_GADGETFS is not set | 943 | # CONFIG_USB_GADGETFS is not set |
| @@ -939,6 +962,10 @@ CONFIG_USB_ETH_RNDIS=y | |||
| 939 | # CONFIG_DMADEVICES is not set | 962 | # CONFIG_DMADEVICES is not set |
| 940 | # CONFIG_AUXDISPLAY is not set | 963 | # CONFIG_AUXDISPLAY is not set |
| 941 | # CONFIG_UIO is not set | 964 | # CONFIG_UIO is not set |
| 965 | |||
| 966 | # | ||
| 967 | # TI VLYNQ | ||
| 968 | # | ||
| 942 | # CONFIG_STAGING is not set | 969 | # CONFIG_STAGING is not set |
| 943 | 970 | ||
| 944 | # | 971 | # |
| @@ -958,9 +985,10 @@ CONFIG_FS_MBCACHE=y | |||
| 958 | # CONFIG_REISERFS_FS is not set | 985 | # CONFIG_REISERFS_FS is not set |
| 959 | # CONFIG_JFS_FS is not set | 986 | # CONFIG_JFS_FS is not set |
| 960 | CONFIG_FS_POSIX_ACL=y | 987 | CONFIG_FS_POSIX_ACL=y |
| 961 | CONFIG_FILE_LOCKING=y | ||
| 962 | # CONFIG_XFS_FS is not set | 988 | # CONFIG_XFS_FS is not set |
| 963 | # CONFIG_OCFS2_FS is not set | 989 | # CONFIG_OCFS2_FS is not set |
| 990 | CONFIG_FILE_LOCKING=y | ||
| 991 | CONFIG_FSNOTIFY=y | ||
| 964 | CONFIG_DNOTIFY=y | 992 | CONFIG_DNOTIFY=y |
| 965 | CONFIG_INOTIFY=y | 993 | CONFIG_INOTIFY=y |
| 966 | CONFIG_INOTIFY_USER=y | 994 | CONFIG_INOTIFY_USER=y |
| @@ -1110,6 +1138,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1110 | CONFIG_HAS_DMA=y | 1138 | CONFIG_HAS_DMA=y |
| 1111 | CONFIG_HAVE_LMB=y | 1139 | CONFIG_HAVE_LMB=y |
| 1112 | CONFIG_NLATTR=y | 1140 | CONFIG_NLATTR=y |
| 1141 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1113 | 1142 | ||
| 1114 | # | 1143 | # |
| 1115 | # Kernel hacking | 1144 | # Kernel hacking |
| @@ -1140,6 +1169,9 @@ CONFIG_BOOTPARAM_HUNG_TASK_PANIC_VALUE=0 | |||
| 1140 | # CONFIG_RT_MUTEX_TESTER is not set | 1169 | # CONFIG_RT_MUTEX_TESTER is not set |
| 1141 | # CONFIG_DEBUG_SPINLOCK is not set | 1170 | # CONFIG_DEBUG_SPINLOCK is not set |
| 1142 | # CONFIG_DEBUG_MUTEXES is not set | 1171 | # CONFIG_DEBUG_MUTEXES is not set |
| 1172 | # CONFIG_DEBUG_LOCK_ALLOC is not set | ||
| 1173 | # CONFIG_PROVE_LOCKING is not set | ||
| 1174 | # CONFIG_LOCK_STAT is not set | ||
| 1143 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1175 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 1144 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1176 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
| 1145 | # CONFIG_DEBUG_KOBJECT is not set | 1177 | # CONFIG_DEBUG_KOBJECT is not set |
| @@ -1151,7 +1183,6 @@ CONFIG_DEBUG_INFO=y | |||
| 1151 | # CONFIG_DEBUG_LIST is not set | 1183 | # CONFIG_DEBUG_LIST is not set |
| 1152 | # CONFIG_DEBUG_SG is not set | 1184 | # CONFIG_DEBUG_SG is not set |
| 1153 | # CONFIG_DEBUG_NOTIFIERS is not set | 1185 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1154 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1155 | # CONFIG_RCU_TORTURE_TEST is not set | 1186 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1156 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1187 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1157 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1188 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1165,22 +1196,23 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1165 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1196 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1166 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1197 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1167 | CONFIG_TRACING_SUPPORT=y | 1198 | CONFIG_TRACING_SUPPORT=y |
| 1168 | 1199 | CONFIG_FTRACE=y | |
| 1169 | # | ||
| 1170 | # Tracers | ||
| 1171 | # | ||
| 1172 | # CONFIG_FUNCTION_TRACER is not set | 1200 | # CONFIG_FUNCTION_TRACER is not set |
| 1201 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1173 | # CONFIG_SCHED_TRACER is not set | 1202 | # CONFIG_SCHED_TRACER is not set |
| 1174 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | 1203 | # CONFIG_ENABLE_DEFAULT_TRACERS is not set |
| 1175 | # CONFIG_EVENT_TRACER is not set | ||
| 1176 | # CONFIG_BOOT_TRACER is not set | 1204 | # CONFIG_BOOT_TRACER is not set |
| 1177 | # CONFIG_TRACE_BRANCH_PROFILING is not set | 1205 | CONFIG_BRANCH_PROFILE_NONE=y |
| 1206 | # CONFIG_PROFILE_ANNOTATED_BRANCHES is not set | ||
| 1207 | # CONFIG_PROFILE_ALL_BRANCHES is not set | ||
| 1178 | # CONFIG_STACK_TRACER is not set | 1208 | # CONFIG_STACK_TRACER is not set |
| 1179 | # CONFIG_KMEMTRACE is not set | 1209 | # CONFIG_KMEMTRACE is not set |
| 1180 | # CONFIG_WORKQUEUE_TRACER is not set | 1210 | # CONFIG_WORKQUEUE_TRACER is not set |
| 1181 | # CONFIG_BLK_DEV_IO_TRACE is not set | 1211 | # CONFIG_BLK_DEV_IO_TRACE is not set |
| 1182 | # CONFIG_SAMPLES is not set | 1212 | # CONFIG_SAMPLES is not set |
| 1183 | CONFIG_HAVE_ARCH_KGDB=y | 1213 | CONFIG_HAVE_ARCH_KGDB=y |
| 1214 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1215 | CONFIG_PPC_WERROR=y | ||
| 1184 | CONFIG_PRINT_STACK_DEPTH=64 | 1216 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1185 | # CONFIG_DEBUG_STACKOVERFLOW is not set | 1217 | # CONFIG_DEBUG_STACKOVERFLOW is not set |
| 1186 | # CONFIG_DEBUG_STACK_USAGE is not set | 1218 | # CONFIG_DEBUG_STACK_USAGE is not set |
diff --git a/arch/powerpc/configs/prpmc2800_defconfig b/arch/powerpc/configs/prpmc2800_defconfig index e9f287f313fa..1293c465d7fa 100644 --- a/arch/powerpc/configs/prpmc2800_defconfig +++ b/arch/powerpc/configs/prpmc2800_defconfig | |||
| @@ -1,25 +1,27 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:03 2009 | 4 | # Wed Jul 29 23:32:01 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | CONFIG_ALTIVEC=y | 20 | CONFIG_ALTIVEC=y |
| 20 | CONFIG_PPC_STD_MMU=y | 21 | CONFIG_PPC_STD_MMU=y |
| 21 | CONFIG_PPC_STD_MMU_32=y | 22 | CONFIG_PPC_STD_MMU_32=y |
| 22 | # CONFIG_PPC_MM_SLICES is not set | 23 | # CONFIG_PPC_MM_SLICES is not set |
| 24 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 23 | # CONFIG_SMP is not set | 25 | # CONFIG_SMP is not set |
| 24 | CONFIG_NOT_COHERENT_CACHE=y | 26 | CONFIG_NOT_COHERENT_CACHE=y |
| 25 | CONFIG_CHECK_CACHE_COHERENCY=y | 27 | CONFIG_CHECK_CACHE_COHERENCY=y |
| @@ -32,15 +34,16 @@ CONFIG_GENERIC_TIME=y | |||
| 32 | CONFIG_GENERIC_TIME_VSYSCALL=y | 34 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 33 | CONFIG_GENERIC_CLOCKEVENTS=y | 35 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 34 | CONFIG_GENERIC_HARDIRQS=y | 36 | CONFIG_GENERIC_HARDIRQS=y |
| 37 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 35 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 38 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 36 | CONFIG_IRQ_PER_CPU=y | 39 | CONFIG_IRQ_PER_CPU=y |
| 37 | CONFIG_STACKTRACE_SUPPORT=y | 40 | CONFIG_STACKTRACE_SUPPORT=y |
| 38 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 41 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 42 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 39 | CONFIG_LOCKDEP_SUPPORT=y | 43 | CONFIG_LOCKDEP_SUPPORT=y |
| 40 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 44 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 41 | CONFIG_ARCH_HAS_ILOG2_U32=y | 45 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 42 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 43 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 44 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 45 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 48 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 46 | CONFIG_PPC=y | 49 | CONFIG_PPC=y |
| @@ -54,11 +57,13 @@ CONFIG_OF=y | |||
| 54 | # CONFIG_GENERIC_TBSYNC is not set | 57 | # CONFIG_GENERIC_TBSYNC is not set |
| 55 | CONFIG_AUDIT_ARCH=y | 58 | CONFIG_AUDIT_ARCH=y |
| 56 | CONFIG_GENERIC_BUG=y | 59 | CONFIG_GENERIC_BUG=y |
| 60 | CONFIG_DTC=y | ||
| 57 | # CONFIG_DEFAULT_UIMAGE is not set | 61 | # CONFIG_DEFAULT_UIMAGE is not set |
| 58 | # CONFIG_PPC_DCR_NATIVE is not set | 62 | # CONFIG_PPC_DCR_NATIVE is not set |
| 59 | # CONFIG_PPC_DCR_MMIO is not set | 63 | # CONFIG_PPC_DCR_MMIO is not set |
| 60 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 64 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 61 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 66 | CONFIG_CONSTRUCTORS=y | ||
| 62 | 67 | ||
| 63 | # | 68 | # |
| 64 | # General setup | 69 | # General setup |
| @@ -114,7 +119,6 @@ CONFIG_ANON_INODES=y | |||
| 114 | CONFIG_SYSCTL_SYSCALL=y | 119 | CONFIG_SYSCTL_SYSCALL=y |
| 115 | CONFIG_KALLSYMS=y | 120 | CONFIG_KALLSYMS=y |
| 116 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 121 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 117 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 118 | CONFIG_HOTPLUG=y | 122 | CONFIG_HOTPLUG=y |
| 119 | CONFIG_PRINTK=y | 123 | CONFIG_PRINTK=y |
| 120 | CONFIG_BUG=y | 124 | CONFIG_BUG=y |
| @@ -127,9 +131,16 @@ CONFIG_TIMERFD=y | |||
| 127 | CONFIG_EVENTFD=y | 131 | CONFIG_EVENTFD=y |
| 128 | CONFIG_SHMEM=y | 132 | CONFIG_SHMEM=y |
| 129 | CONFIG_AIO=y | 133 | CONFIG_AIO=y |
| 134 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 135 | |||
| 136 | # | ||
| 137 | # Performance Counters | ||
| 138 | # | ||
| 139 | # CONFIG_PERF_COUNTERS is not set | ||
| 130 | CONFIG_VM_EVENT_COUNTERS=y | 140 | CONFIG_VM_EVENT_COUNTERS=y |
| 131 | CONFIG_PCI_QUIRKS=y | 141 | CONFIG_PCI_QUIRKS=y |
| 132 | CONFIG_SLUB_DEBUG=y | 142 | CONFIG_SLUB_DEBUG=y |
| 143 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 133 | CONFIG_COMPAT_BRK=y | 144 | CONFIG_COMPAT_BRK=y |
| 134 | # CONFIG_SLAB is not set | 145 | # CONFIG_SLAB is not set |
| 135 | CONFIG_SLUB=y | 146 | CONFIG_SLUB=y |
| @@ -142,6 +153,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 142 | CONFIG_HAVE_KPROBES=y | 153 | CONFIG_HAVE_KPROBES=y |
| 143 | CONFIG_HAVE_KRETPROBES=y | 154 | CONFIG_HAVE_KRETPROBES=y |
| 144 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 155 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 156 | |||
| 157 | # | ||
| 158 | # GCOV-based kernel profiling | ||
| 159 | # | ||
| 145 | # CONFIG_SLOW_WORK is not set | 160 | # CONFIG_SLOW_WORK is not set |
| 146 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 161 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 147 | CONFIG_SLABINFO=y | 162 | CONFIG_SLABINFO=y |
| @@ -149,7 +164,7 @@ CONFIG_RT_MUTEXES=y | |||
| 149 | CONFIG_BASE_SMALL=0 | 164 | CONFIG_BASE_SMALL=0 |
| 150 | # CONFIG_MODULES is not set | 165 | # CONFIG_MODULES is not set |
| 151 | CONFIG_BLOCK=y | 166 | CONFIG_BLOCK=y |
| 152 | CONFIG_LBD=y | 167 | CONFIG_LBDAF=y |
| 153 | # CONFIG_BLK_DEV_BSG is not set | 168 | # CONFIG_BLK_DEV_BSG is not set |
| 154 | # CONFIG_BLK_DEV_INTEGRITY is not set | 169 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 155 | 170 | ||
| @@ -228,6 +243,7 @@ CONFIG_BINFMT_ELF=y | |||
| 228 | # CONFIG_HAVE_AOUT is not set | 243 | # CONFIG_HAVE_AOUT is not set |
| 229 | CONFIG_BINFMT_MISC=y | 244 | CONFIG_BINFMT_MISC=y |
| 230 | # CONFIG_IOMMU_HELPER is not set | 245 | # CONFIG_IOMMU_HELPER is not set |
| 246 | # CONFIG_SWIOTLB is not set | ||
| 231 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y | 247 | CONFIG_PPC_NEED_DMA_SYNC_OPS=y |
| 232 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 248 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 233 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 249 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| @@ -249,9 +265,9 @@ CONFIG_MIGRATION=y | |||
| 249 | CONFIG_ZONE_DMA_FLAG=1 | 265 | CONFIG_ZONE_DMA_FLAG=1 |
| 250 | CONFIG_BOUNCE=y | 266 | CONFIG_BOUNCE=y |
| 251 | CONFIG_VIRT_TO_BUS=y | 267 | CONFIG_VIRT_TO_BUS=y |
| 252 | CONFIG_UNEVICTABLE_LRU=y | ||
| 253 | CONFIG_HAVE_MLOCK=y | 268 | CONFIG_HAVE_MLOCK=y |
| 254 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 269 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 270 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 255 | CONFIG_PPC_4K_PAGES=y | 271 | CONFIG_PPC_4K_PAGES=y |
| 256 | # CONFIG_PPC_16K_PAGES is not set | 272 | # CONFIG_PPC_16K_PAGES is not set |
| 257 | # CONFIG_PPC_64K_PAGES is not set | 273 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -296,6 +312,7 @@ CONFIG_PAGE_OFFSET=0xc0000000 | |||
| 296 | CONFIG_KERNEL_START=0xc0000000 | 312 | CONFIG_KERNEL_START=0xc0000000 |
| 297 | CONFIG_PHYSICAL_START=0x00000000 | 313 | CONFIG_PHYSICAL_START=0x00000000 |
| 298 | CONFIG_TASK_SIZE=0xc0000000 | 314 | CONFIG_TASK_SIZE=0xc0000000 |
| 315 | CONFIG_CONSISTENT_SIZE=0x00200000 | ||
| 299 | CONFIG_NET=y | 316 | CONFIG_NET=y |
| 300 | 317 | ||
| 301 | # | 318 | # |
| @@ -357,6 +374,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 357 | # CONFIG_ECONET is not set | 374 | # CONFIG_ECONET is not set |
| 358 | # CONFIG_WAN_ROUTER is not set | 375 | # CONFIG_WAN_ROUTER is not set |
| 359 | # CONFIG_PHONET is not set | 376 | # CONFIG_PHONET is not set |
| 377 | # CONFIG_IEEE802154 is not set | ||
| 360 | # CONFIG_NET_SCHED is not set | 378 | # CONFIG_NET_SCHED is not set |
| 361 | # CONFIG_DCB is not set | 379 | # CONFIG_DCB is not set |
| 362 | 380 | ||
| @@ -374,7 +392,11 @@ CONFIG_WIRELESS=y | |||
| 374 | CONFIG_WIRELESS_OLD_REGULATORY=y | 392 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 375 | # CONFIG_WIRELESS_EXT is not set | 393 | # CONFIG_WIRELESS_EXT is not set |
| 376 | # CONFIG_LIB80211 is not set | 394 | # CONFIG_LIB80211 is not set |
| 377 | # CONFIG_MAC80211 is not set | 395 | |
| 396 | # | ||
| 397 | # CFG80211 needs to be enabled for MAC80211 | ||
| 398 | # | ||
| 399 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 378 | # CONFIG_WIMAX is not set | 400 | # CONFIG_WIMAX is not set |
| 379 | # CONFIG_RFKILL is not set | 401 | # CONFIG_RFKILL is not set |
| 380 | # CONFIG_NET_9P is not set | 402 | # CONFIG_NET_9P is not set |
| @@ -479,6 +501,7 @@ CONFIG_MTD_PHYSMAP_OF=y | |||
| 479 | # CONFIG_MTD_UBI is not set | 501 | # CONFIG_MTD_UBI is not set |
| 480 | CONFIG_OF_DEVICE=y | 502 | CONFIG_OF_DEVICE=y |
| 481 | CONFIG_OF_I2C=y | 503 | CONFIG_OF_I2C=y |
| 504 | CONFIG_OF_MDIO=y | ||
| 482 | # CONFIG_PARPORT is not set | 505 | # CONFIG_PARPORT is not set |
| 483 | CONFIG_BLK_DEV=y | 506 | CONFIG_BLK_DEV=y |
| 484 | # CONFIG_BLK_DEV_FD is not set | 507 | # CONFIG_BLK_DEV_FD is not set |
| @@ -514,7 +537,9 @@ CONFIG_MISC_DEVICES=y | |||
| 514 | # | 537 | # |
| 515 | # CONFIG_EEPROM_AT24 is not set | 538 | # CONFIG_EEPROM_AT24 is not set |
| 516 | # CONFIG_EEPROM_LEGACY is not set | 539 | # CONFIG_EEPROM_LEGACY is not set |
| 540 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 517 | # CONFIG_EEPROM_93CX6 is not set | 541 | # CONFIG_EEPROM_93CX6 is not set |
| 542 | # CONFIG_CB710_CORE is not set | ||
| 518 | CONFIG_HAVE_IDE=y | 543 | CONFIG_HAVE_IDE=y |
| 519 | CONFIG_IDE=y | 544 | CONFIG_IDE=y |
| 520 | 545 | ||
| @@ -591,10 +616,6 @@ CONFIG_BLK_DEV_SD=y | |||
| 591 | # CONFIG_BLK_DEV_SR is not set | 616 | # CONFIG_BLK_DEV_SR is not set |
| 592 | # CONFIG_CHR_DEV_SG is not set | 617 | # CONFIG_CHR_DEV_SG is not set |
| 593 | # CONFIG_CHR_DEV_SCH is not set | 618 | # CONFIG_CHR_DEV_SCH is not set |
| 594 | |||
| 595 | # | ||
| 596 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 597 | # | ||
| 598 | # CONFIG_SCSI_MULTI_LUN is not set | 619 | # CONFIG_SCSI_MULTI_LUN is not set |
| 599 | # CONFIG_SCSI_CONSTANTS is not set | 620 | # CONFIG_SCSI_CONSTANTS is not set |
| 600 | # CONFIG_SCSI_LOGGING is not set | 621 | # CONFIG_SCSI_LOGGING is not set |
| @@ -611,6 +632,7 @@ CONFIG_BLK_DEV_SD=y | |||
| 611 | CONFIG_SCSI_LOWLEVEL=y | 632 | CONFIG_SCSI_LOWLEVEL=y |
| 612 | # CONFIG_ISCSI_TCP is not set | 633 | # CONFIG_ISCSI_TCP is not set |
| 613 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 634 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 635 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 614 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 636 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 615 | # CONFIG_SCSI_3W_9XXX is not set | 637 | # CONFIG_SCSI_3W_9XXX is not set |
| 616 | # CONFIG_SCSI_ACARD is not set | 638 | # CONFIG_SCSI_ACARD is not set |
| @@ -619,6 +641,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 619 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 641 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 620 | # CONFIG_SCSI_AIC79XX is not set | 642 | # CONFIG_SCSI_AIC79XX is not set |
| 621 | # CONFIG_SCSI_AIC94XX is not set | 643 | # CONFIG_SCSI_AIC94XX is not set |
| 644 | # CONFIG_SCSI_MVSAS is not set | ||
| 622 | # CONFIG_SCSI_DPT_I2O is not set | 645 | # CONFIG_SCSI_DPT_I2O is not set |
| 623 | # CONFIG_SCSI_ADVANSYS is not set | 646 | # CONFIG_SCSI_ADVANSYS is not set |
| 624 | # CONFIG_SCSI_ARCMSR is not set | 647 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -638,7 +661,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 638 | # CONFIG_SCSI_IPS is not set | 661 | # CONFIG_SCSI_IPS is not set |
| 639 | # CONFIG_SCSI_INITIO is not set | 662 | # CONFIG_SCSI_INITIO is not set |
| 640 | # CONFIG_SCSI_INIA100 is not set | 663 | # CONFIG_SCSI_INIA100 is not set |
| 641 | # CONFIG_SCSI_MVSAS is not set | ||
| 642 | # CONFIG_SCSI_STEX is not set | 664 | # CONFIG_SCSI_STEX is not set |
| 643 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 665 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 644 | # CONFIG_SCSI_IPR is not set | 666 | # CONFIG_SCSI_IPR is not set |
| @@ -721,7 +743,11 @@ CONFIG_SATA_MV=y | |||
| 721 | # | 743 | # |
| 722 | 744 | ||
| 723 | # | 745 | # |
| 724 | # Enable only one of the two stacks, unless you know what you are doing | 746 | # You can enable one or both FireWire driver stacks. |
| 747 | # | ||
| 748 | |||
| 749 | # | ||
| 750 | # See the help texts for more information. | ||
| 725 | # | 751 | # |
| 726 | # CONFIG_FIREWIRE is not set | 752 | # CONFIG_FIREWIRE is not set |
| 727 | # CONFIG_IEEE1394 is not set | 753 | # CONFIG_IEEE1394 is not set |
| @@ -730,7 +756,6 @@ CONFIG_MACINTOSH_DRIVERS=y | |||
| 730 | # CONFIG_MAC_EMUMOUSEBTN is not set | 756 | # CONFIG_MAC_EMUMOUSEBTN is not set |
| 731 | # CONFIG_WINDFARM is not set | 757 | # CONFIG_WINDFARM is not set |
| 732 | CONFIG_NETDEVICES=y | 758 | CONFIG_NETDEVICES=y |
| 733 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 734 | # CONFIG_DUMMY is not set | 759 | # CONFIG_DUMMY is not set |
| 735 | # CONFIG_BONDING is not set | 760 | # CONFIG_BONDING is not set |
| 736 | # CONFIG_MACVLAN is not set | 761 | # CONFIG_MACVLAN is not set |
| @@ -797,6 +822,7 @@ CONFIG_8139TOO=y | |||
| 797 | # CONFIG_SMSC9420 is not set | 822 | # CONFIG_SMSC9420 is not set |
| 798 | # CONFIG_SUNDANCE is not set | 823 | # CONFIG_SUNDANCE is not set |
| 799 | # CONFIG_TLAN is not set | 824 | # CONFIG_TLAN is not set |
| 825 | # CONFIG_KS8842 is not set | ||
| 800 | # CONFIG_VIA_RHINE is not set | 826 | # CONFIG_VIA_RHINE is not set |
| 801 | # CONFIG_SC92031 is not set | 827 | # CONFIG_SC92031 is not set |
| 802 | # CONFIG_ATL2 is not set | 828 | # CONFIG_ATL2 is not set |
| @@ -818,6 +844,7 @@ CONFIG_E1000=y | |||
| 818 | # CONFIG_VIA_VELOCITY is not set | 844 | # CONFIG_VIA_VELOCITY is not set |
| 819 | # CONFIG_TIGON3 is not set | 845 | # CONFIG_TIGON3 is not set |
| 820 | # CONFIG_BNX2 is not set | 846 | # CONFIG_BNX2 is not set |
| 847 | # CONFIG_CNIC is not set | ||
| 821 | CONFIG_MV643XX_ETH=y | 848 | CONFIG_MV643XX_ETH=y |
| 822 | # CONFIG_QLA3XXX is not set | 849 | # CONFIG_QLA3XXX is not set |
| 823 | # CONFIG_ATL1 is not set | 850 | # CONFIG_ATL1 is not set |
| @@ -1007,13 +1034,17 @@ CONFIG_I2C_MV64XXX=y | |||
| 1007 | # CONFIG_SENSORS_PCF8574 is not set | 1034 | # CONFIG_SENSORS_PCF8574 is not set |
| 1008 | # CONFIG_PCF8575 is not set | 1035 | # CONFIG_PCF8575 is not set |
| 1009 | # CONFIG_SENSORS_PCA9539 is not set | 1036 | # CONFIG_SENSORS_PCA9539 is not set |
| 1010 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 1011 | # CONFIG_SENSORS_TSL2550 is not set | 1037 | # CONFIG_SENSORS_TSL2550 is not set |
| 1012 | # CONFIG_I2C_DEBUG_CORE is not set | 1038 | # CONFIG_I2C_DEBUG_CORE is not set |
| 1013 | # CONFIG_I2C_DEBUG_ALGO is not set | 1039 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 1014 | # CONFIG_I2C_DEBUG_BUS is not set | 1040 | # CONFIG_I2C_DEBUG_BUS is not set |
| 1015 | # CONFIG_I2C_DEBUG_CHIP is not set | 1041 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 1016 | # CONFIG_SPI is not set | 1042 | # CONFIG_SPI is not set |
| 1043 | |||
| 1044 | # | ||
| 1045 | # PPS support | ||
| 1046 | # | ||
| 1047 | # CONFIG_PPS is not set | ||
| 1017 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 1048 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 1018 | # CONFIG_GPIOLIB is not set | 1049 | # CONFIG_GPIOLIB is not set |
| 1019 | # CONFIG_W1 is not set | 1050 | # CONFIG_W1 is not set |
| @@ -1068,6 +1099,7 @@ CONFIG_HWMON=y | |||
| 1068 | # CONFIG_SENSORS_SMSC47B397 is not set | 1099 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 1069 | # CONFIG_SENSORS_ADS7828 is not set | 1100 | # CONFIG_SENSORS_ADS7828 is not set |
| 1070 | # CONFIG_SENSORS_THMC50 is not set | 1101 | # CONFIG_SENSORS_THMC50 is not set |
| 1102 | # CONFIG_SENSORS_TMP401 is not set | ||
| 1071 | # CONFIG_SENSORS_VIA686A is not set | 1103 | # CONFIG_SENSORS_VIA686A is not set |
| 1072 | # CONFIG_SENSORS_VT1211 is not set | 1104 | # CONFIG_SENSORS_VT1211 is not set |
| 1073 | # CONFIG_SENSORS_VT8231 is not set | 1105 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -1102,23 +1134,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1102 | # CONFIG_MFD_WM8400 is not set | 1134 | # CONFIG_MFD_WM8400 is not set |
| 1103 | # CONFIG_MFD_WM8350_I2C is not set | 1135 | # CONFIG_MFD_WM8350_I2C is not set |
| 1104 | # CONFIG_MFD_PCF50633 is not set | 1136 | # CONFIG_MFD_PCF50633 is not set |
| 1137 | # CONFIG_AB3100_CORE is not set | ||
| 1105 | # CONFIG_REGULATOR is not set | 1138 | # CONFIG_REGULATOR is not set |
| 1106 | 1139 | # CONFIG_MEDIA_SUPPORT is not set | |
| 1107 | # | ||
| 1108 | # Multimedia devices | ||
| 1109 | # | ||
| 1110 | |||
| 1111 | # | ||
| 1112 | # Multimedia core support | ||
| 1113 | # | ||
| 1114 | # CONFIG_VIDEO_DEV is not set | ||
| 1115 | # CONFIG_DVB_CORE is not set | ||
| 1116 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1117 | |||
| 1118 | # | ||
| 1119 | # Multimedia drivers | ||
| 1120 | # | ||
| 1121 | # CONFIG_DAB is not set | ||
| 1122 | 1140 | ||
| 1123 | # | 1141 | # |
| 1124 | # Graphics support | 1142 | # Graphics support |
| @@ -1163,6 +1181,7 @@ CONFIG_HID_BELKIN=y | |||
| 1163 | CONFIG_HID_CHERRY=y | 1181 | CONFIG_HID_CHERRY=y |
| 1164 | CONFIG_HID_CHICONY=y | 1182 | CONFIG_HID_CHICONY=y |
| 1165 | CONFIG_HID_CYPRESS=y | 1183 | CONFIG_HID_CYPRESS=y |
| 1184 | CONFIG_HID_DRAGONRISE=y | ||
| 1166 | # CONFIG_DRAGONRISE_FF is not set | 1185 | # CONFIG_DRAGONRISE_FF is not set |
| 1167 | CONFIG_HID_EZKEY=y | 1186 | CONFIG_HID_EZKEY=y |
| 1168 | CONFIG_HID_KYE=y | 1187 | CONFIG_HID_KYE=y |
| @@ -1180,9 +1199,14 @@ CONFIG_HID_PETALYNX=y | |||
| 1180 | CONFIG_HID_SAMSUNG=y | 1199 | CONFIG_HID_SAMSUNG=y |
| 1181 | CONFIG_HID_SONY=y | 1200 | CONFIG_HID_SONY=y |
| 1182 | CONFIG_HID_SUNPLUS=y | 1201 | CONFIG_HID_SUNPLUS=y |
| 1202 | CONFIG_HID_GREENASIA=y | ||
| 1183 | # CONFIG_GREENASIA_FF is not set | 1203 | # CONFIG_GREENASIA_FF is not set |
| 1204 | CONFIG_HID_SMARTJOYPLUS=y | ||
| 1205 | # CONFIG_SMARTJOYPLUS_FF is not set | ||
| 1184 | CONFIG_HID_TOPSEED=y | 1206 | CONFIG_HID_TOPSEED=y |
| 1207 | CONFIG_HID_THRUSTMASTER=y | ||
| 1185 | CONFIG_THRUSTMASTER_FF=y | 1208 | CONFIG_THRUSTMASTER_FF=y |
| 1209 | CONFIG_HID_ZEROPLUS=y | ||
| 1186 | CONFIG_ZEROPLUS_FF=y | 1210 | CONFIG_ZEROPLUS_FF=y |
| 1187 | CONFIG_USB_SUPPORT=y | 1211 | CONFIG_USB_SUPPORT=y |
| 1188 | CONFIG_USB_ARCH_HAS_HCD=y | 1212 | CONFIG_USB_ARCH_HAS_HCD=y |
| @@ -1207,6 +1231,7 @@ CONFIG_USB_MON=y | |||
| 1207 | # USB Host Controller Drivers | 1231 | # USB Host Controller Drivers |
| 1208 | # | 1232 | # |
| 1209 | # CONFIG_USB_C67X00_HCD is not set | 1233 | # CONFIG_USB_C67X00_HCD is not set |
| 1234 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1210 | CONFIG_USB_EHCI_HCD=y | 1235 | CONFIG_USB_EHCI_HCD=y |
| 1211 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set | 1236 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set |
| 1212 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1237 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1215,6 +1240,8 @@ CONFIG_USB_EHCI_HCD_PPC_OF=y | |||
| 1215 | # CONFIG_USB_ISP116X_HCD is not set | 1240 | # CONFIG_USB_ISP116X_HCD is not set |
| 1216 | # CONFIG_USB_ISP1760_HCD is not set | 1241 | # CONFIG_USB_ISP1760_HCD is not set |
| 1217 | CONFIG_USB_OHCI_HCD=y | 1242 | CONFIG_USB_OHCI_HCD=y |
| 1243 | # CONFIG_USB_OHCI_HCD_PPC_OF_BE is not set | ||
| 1244 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set | ||
| 1218 | # CONFIG_USB_OHCI_HCD_PPC_OF is not set | 1245 | # CONFIG_USB_OHCI_HCD_PPC_OF is not set |
| 1219 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set | 1246 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set |
| 1220 | # CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set | 1247 | # CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set |
| @@ -1322,6 +1349,7 @@ CONFIG_RTC_DRV_MAX6900=y | |||
| 1322 | # CONFIG_RTC_DRV_S35390A is not set | 1349 | # CONFIG_RTC_DRV_S35390A is not set |
| 1323 | # CONFIG_RTC_DRV_FM3130 is not set | 1350 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1324 | # CONFIG_RTC_DRV_RX8581 is not set | 1351 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1352 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1325 | 1353 | ||
| 1326 | # | 1354 | # |
| 1327 | # SPI RTC drivers | 1355 | # SPI RTC drivers |
| @@ -1349,6 +1377,10 @@ CONFIG_RTC_DRV_MAX6900=y | |||
| 1349 | # CONFIG_DMADEVICES is not set | 1377 | # CONFIG_DMADEVICES is not set |
| 1350 | # CONFIG_AUXDISPLAY is not set | 1378 | # CONFIG_AUXDISPLAY is not set |
| 1351 | # CONFIG_UIO is not set | 1379 | # CONFIG_UIO is not set |
| 1380 | |||
| 1381 | # | ||
| 1382 | # TI VLYNQ | ||
| 1383 | # | ||
| 1352 | # CONFIG_STAGING is not set | 1384 | # CONFIG_STAGING is not set |
| 1353 | 1385 | ||
| 1354 | # | 1386 | # |
| @@ -1368,11 +1400,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1368 | # CONFIG_REISERFS_FS is not set | 1400 | # CONFIG_REISERFS_FS is not set |
| 1369 | # CONFIG_JFS_FS is not set | 1401 | # CONFIG_JFS_FS is not set |
| 1370 | # CONFIG_FS_POSIX_ACL is not set | 1402 | # CONFIG_FS_POSIX_ACL is not set |
| 1371 | CONFIG_FILE_LOCKING=y | ||
| 1372 | # CONFIG_XFS_FS is not set | 1403 | # CONFIG_XFS_FS is not set |
| 1373 | # CONFIG_GFS2_FS is not set | 1404 | # CONFIG_GFS2_FS is not set |
| 1374 | # CONFIG_OCFS2_FS is not set | 1405 | # CONFIG_OCFS2_FS is not set |
| 1375 | # CONFIG_BTRFS_FS is not set | 1406 | # CONFIG_BTRFS_FS is not set |
| 1407 | CONFIG_FILE_LOCKING=y | ||
| 1408 | CONFIG_FSNOTIFY=y | ||
| 1376 | CONFIG_DNOTIFY=y | 1409 | CONFIG_DNOTIFY=y |
| 1377 | CONFIG_INOTIFY=y | 1410 | CONFIG_INOTIFY=y |
| 1378 | CONFIG_INOTIFY_USER=y | 1411 | CONFIG_INOTIFY_USER=y |
| @@ -1469,7 +1502,46 @@ CONFIG_MSDOS_PARTITION=y | |||
| 1469 | # CONFIG_KARMA_PARTITION is not set | 1502 | # CONFIG_KARMA_PARTITION is not set |
| 1470 | # CONFIG_EFI_PARTITION is not set | 1503 | # CONFIG_EFI_PARTITION is not set |
| 1471 | # CONFIG_SYSV68_PARTITION is not set | 1504 | # CONFIG_SYSV68_PARTITION is not set |
| 1472 | # CONFIG_NLS is not set | 1505 | CONFIG_NLS=y |
| 1506 | CONFIG_NLS_DEFAULT="iso8859-1" | ||
| 1507 | # CONFIG_NLS_CODEPAGE_437 is not set | ||
| 1508 | # CONFIG_NLS_CODEPAGE_737 is not set | ||
| 1509 | # CONFIG_NLS_CODEPAGE_775 is not set | ||
| 1510 | # CONFIG_NLS_CODEPAGE_850 is not set | ||
| 1511 | # CONFIG_NLS_CODEPAGE_852 is not set | ||
| 1512 | # CONFIG_NLS_CODEPAGE_855 is not set | ||
| 1513 | # CONFIG_NLS_CODEPAGE_857 is not set | ||
| 1514 | # CONFIG_NLS_CODEPAGE_860 is not set | ||
| 1515 | # CONFIG_NLS_CODEPAGE_861 is not set | ||
| 1516 | # CONFIG_NLS_CODEPAGE_862 is not set | ||
| 1517 | # CONFIG_NLS_CODEPAGE_863 is not set | ||
| 1518 | # CONFIG_NLS_CODEPAGE_864 is not set | ||
| 1519 | # CONFIG_NLS_CODEPAGE_865 is not set | ||
| 1520 | # CONFIG_NLS_CODEPAGE_866 is not set | ||
| 1521 | # CONFIG_NLS_CODEPAGE_869 is not set | ||
| 1522 | # CONFIG_NLS_CODEPAGE_936 is not set | ||
| 1523 | # CONFIG_NLS_CODEPAGE_950 is not set | ||
| 1524 | # CONFIG_NLS_CODEPAGE_932 is not set | ||
| 1525 | # CONFIG_NLS_CODEPAGE_949 is not set | ||
| 1526 | # CONFIG_NLS_CODEPAGE_874 is not set | ||
| 1527 | # CONFIG_NLS_ISO8859_8 is not set | ||
| 1528 | # CONFIG_NLS_CODEPAGE_1250 is not set | ||
| 1529 | # CONFIG_NLS_CODEPAGE_1251 is not set | ||
| 1530 | # CONFIG_NLS_ASCII is not set | ||
| 1531 | # CONFIG_NLS_ISO8859_1 is not set | ||
| 1532 | # CONFIG_NLS_ISO8859_2 is not set | ||
| 1533 | # CONFIG_NLS_ISO8859_3 is not set | ||
| 1534 | # CONFIG_NLS_ISO8859_4 is not set | ||
| 1535 | # CONFIG_NLS_ISO8859_5 is not set | ||
| 1536 | # CONFIG_NLS_ISO8859_6 is not set | ||
| 1537 | # CONFIG_NLS_ISO8859_7 is not set | ||
| 1538 | # CONFIG_NLS_ISO8859_9 is not set | ||
| 1539 | # CONFIG_NLS_ISO8859_13 is not set | ||
| 1540 | # CONFIG_NLS_ISO8859_14 is not set | ||
| 1541 | # CONFIG_NLS_ISO8859_15 is not set | ||
| 1542 | # CONFIG_NLS_KOI8_R is not set | ||
| 1543 | # CONFIG_NLS_KOI8_U is not set | ||
| 1544 | # CONFIG_NLS_UTF8 is not set | ||
| 1473 | # CONFIG_DLM is not set | 1545 | # CONFIG_DLM is not set |
| 1474 | # CONFIG_BINARY_PRINTF is not set | 1546 | # CONFIG_BINARY_PRINTF is not set |
| 1475 | 1547 | ||
| @@ -1494,6 +1566,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1494 | CONFIG_HAS_DMA=y | 1566 | CONFIG_HAS_DMA=y |
| 1495 | CONFIG_HAVE_LMB=y | 1567 | CONFIG_HAVE_LMB=y |
| 1496 | CONFIG_NLATTR=y | 1568 | CONFIG_NLATTR=y |
| 1569 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1497 | 1570 | ||
| 1498 | # | 1571 | # |
| 1499 | # Kernel hacking | 1572 | # Kernel hacking |
| @@ -1519,22 +1592,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1519 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1592 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1520 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1593 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1521 | CONFIG_TRACING_SUPPORT=y | 1594 | CONFIG_TRACING_SUPPORT=y |
| 1522 | 1595 | # CONFIG_FTRACE is not set | |
| 1523 | # | ||
| 1524 | # Tracers | ||
| 1525 | # | ||
| 1526 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1527 | # CONFIG_SCHED_TRACER is not set | ||
| 1528 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1529 | # CONFIG_EVENT_TRACER is not set | ||
| 1530 | # CONFIG_BOOT_TRACER is not set | ||
| 1531 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1532 | # CONFIG_STACK_TRACER is not set | ||
| 1533 | # CONFIG_KMEMTRACE is not set | ||
| 1534 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1535 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1536 | # CONFIG_SAMPLES is not set | 1596 | # CONFIG_SAMPLES is not set |
| 1537 | CONFIG_HAVE_ARCH_KGDB=y | 1597 | CONFIG_HAVE_ARCH_KGDB=y |
| 1598 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1599 | CONFIG_PPC_WERROR=y | ||
| 1538 | CONFIG_PRINT_STACK_DEPTH=64 | 1600 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1539 | # CONFIG_IRQSTACKS is not set | 1601 | # CONFIG_IRQSTACKS is not set |
| 1540 | # CONFIG_BOOTX_TEXT is not set | 1602 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/configs/ps3_defconfig b/arch/powerpc/configs/ps3_defconfig index e28e65e7a0e1..7de127e4ceef 100644 --- a/arch/powerpc/configs/ps3_defconfig +++ b/arch/powerpc/configs/ps3_defconfig | |||
| @@ -1,13 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc5 | 3 | # Linux kernel version: 2.6.31-rc7 |
| 4 | # Fri May 15 10:37:00 2009 | 4 | # Mon Aug 24 17:38:50 2009 |
| 5 | # | 5 | # |
| 6 | CONFIG_PPC64=y | 6 | CONFIG_PPC64=y |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_PPC_BOOK3S_64=y | ||
| 11 | CONFIG_PPC_BOOK3S=y | 12 | CONFIG_PPC_BOOK3S=y |
| 12 | # CONFIG_POWER4_ONLY is not set | 13 | # CONFIG_POWER4_ONLY is not set |
| 13 | CONFIG_POWER3=y | 14 | CONFIG_POWER3=y |
| @@ -20,6 +21,7 @@ CONFIG_PPC_STD_MMU=y | |||
| 20 | CONFIG_PPC_STD_MMU_64=y | 21 | CONFIG_PPC_STD_MMU_64=y |
| 21 | CONFIG_PPC_MM_SLICES=y | 22 | CONFIG_PPC_MM_SLICES=y |
| 22 | CONFIG_VIRT_CPU_ACCOUNTING=y | 23 | CONFIG_VIRT_CPU_ACCOUNTING=y |
| 24 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 23 | CONFIG_SMP=y | 25 | CONFIG_SMP=y |
| 24 | CONFIG_NR_CPUS=2 | 26 | CONFIG_NR_CPUS=2 |
| 25 | CONFIG_64BIT=y | 27 | CONFIG_64BIT=y |
| @@ -31,6 +33,7 @@ CONFIG_GENERIC_TIME=y | |||
| 31 | CONFIG_GENERIC_TIME_VSYSCALL=y | 33 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 32 | CONFIG_GENERIC_CLOCKEVENTS=y | 34 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 33 | CONFIG_GENERIC_HARDIRQS=y | 35 | CONFIG_GENERIC_HARDIRQS=y |
| 36 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 34 | CONFIG_HAVE_SETUP_PER_CPU_AREA=y | 37 | CONFIG_HAVE_SETUP_PER_CPU_AREA=y |
| 35 | CONFIG_IRQ_PER_CPU=y | 38 | CONFIG_IRQ_PER_CPU=y |
| 36 | CONFIG_STACKTRACE_SUPPORT=y | 39 | CONFIG_STACKTRACE_SUPPORT=y |
| @@ -41,7 +44,6 @@ CONFIG_RWSEM_XCHGADD_ALGORITHM=y | |||
| 41 | CONFIG_ARCH_HAS_ILOG2_U32=y | 44 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 42 | CONFIG_ARCH_HAS_ILOG2_U64=y | 45 | CONFIG_ARCH_HAS_ILOG2_U64=y |
| 43 | CONFIG_GENERIC_HWEIGHT=y | 46 | CONFIG_GENERIC_HWEIGHT=y |
| 44 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 45 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 47 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 46 | CONFIG_ARCH_NO_VIRT_TO_BUS=y | 48 | CONFIG_ARCH_NO_VIRT_TO_BUS=y |
| 47 | CONFIG_PPC=y | 49 | CONFIG_PPC=y |
| @@ -62,6 +64,7 @@ CONFIG_DTC=y | |||
| 62 | # CONFIG_PPC_DCR_MMIO is not set | 64 | # CONFIG_PPC_DCR_MMIO is not set |
| 63 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 65 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 64 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 66 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 67 | CONFIG_CONSTRUCTORS=y | ||
| 65 | 68 | ||
| 66 | # | 69 | # |
| 67 | # General setup | 70 | # General setup |
| @@ -113,7 +116,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 113 | CONFIG_KALLSYMS=y | 116 | CONFIG_KALLSYMS=y |
| 114 | CONFIG_KALLSYMS_ALL=y | 117 | CONFIG_KALLSYMS_ALL=y |
| 115 | CONFIG_KALLSYMS_EXTRA_PASS=y | 118 | CONFIG_KALLSYMS_EXTRA_PASS=y |
| 116 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 117 | CONFIG_HOTPLUG=y | 119 | CONFIG_HOTPLUG=y |
| 118 | CONFIG_PRINTK=y | 120 | CONFIG_PRINTK=y |
| 119 | CONFIG_BUG=y | 121 | CONFIG_BUG=y |
| @@ -126,7 +128,14 @@ CONFIG_TIMERFD=y | |||
| 126 | CONFIG_EVENTFD=y | 128 | CONFIG_EVENTFD=y |
| 127 | CONFIG_SHMEM=y | 129 | CONFIG_SHMEM=y |
| 128 | CONFIG_AIO=y | 130 | CONFIG_AIO=y |
| 131 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 132 | |||
| 133 | # | ||
| 134 | # Performance Counters | ||
| 135 | # | ||
| 136 | # CONFIG_PERF_COUNTERS is not set | ||
| 129 | CONFIG_VM_EVENT_COUNTERS=y | 137 | CONFIG_VM_EVENT_COUNTERS=y |
| 138 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 130 | # CONFIG_COMPAT_BRK is not set | 139 | # CONFIG_COMPAT_BRK is not set |
| 131 | CONFIG_SLAB=y | 140 | CONFIG_SLAB=y |
| 132 | # CONFIG_SLUB is not set | 141 | # CONFIG_SLUB is not set |
| @@ -145,6 +154,11 @@ CONFIG_HAVE_KRETPROBES=y | |||
| 145 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 154 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 146 | CONFIG_HAVE_DMA_ATTRS=y | 155 | CONFIG_HAVE_DMA_ATTRS=y |
| 147 | CONFIG_USE_GENERIC_SMP_HELPERS=y | 156 | CONFIG_USE_GENERIC_SMP_HELPERS=y |
| 157 | |||
| 158 | # | ||
| 159 | # GCOV-based kernel profiling | ||
| 160 | # | ||
| 161 | # CONFIG_GCOV_KERNEL is not set | ||
| 148 | # CONFIG_SLOW_WORK is not set | 162 | # CONFIG_SLOW_WORK is not set |
| 149 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 163 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 150 | CONFIG_SLABINFO=y | 164 | CONFIG_SLABINFO=y |
| @@ -210,7 +224,7 @@ CONFIG_PPC_CELL=y | |||
| 210 | # | 224 | # |
| 211 | # Cell Broadband Engine options | 225 | # Cell Broadband Engine options |
| 212 | # | 226 | # |
| 213 | CONFIG_SPU_FS=y | 227 | CONFIG_SPU_FS=m |
| 214 | CONFIG_SPU_FS_64K_LS=y | 228 | CONFIG_SPU_FS_64K_LS=y |
| 215 | # CONFIG_SPU_TRACE is not set | 229 | # CONFIG_SPU_TRACE is not set |
| 216 | CONFIG_SPU_BASE=y | 230 | CONFIG_SPU_BASE=y |
| @@ -255,6 +269,7 @@ CONFIG_BINFMT_MISC=y | |||
| 255 | CONFIG_HUGETLB_PAGE_SIZE_VARIABLE=y | 269 | CONFIG_HUGETLB_PAGE_SIZE_VARIABLE=y |
| 256 | # CONFIG_IOMMU_VMERGE is not set | 270 | # CONFIG_IOMMU_VMERGE is not set |
| 257 | CONFIG_IOMMU_HELPER=y | 271 | CONFIG_IOMMU_HELPER=y |
| 272 | # CONFIG_SWIOTLB is not set | ||
| 258 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 273 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 259 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 274 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 260 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 275 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -285,9 +300,9 @@ CONFIG_MIGRATION=y | |||
| 285 | CONFIG_PHYS_ADDR_T_64BIT=y | 300 | CONFIG_PHYS_ADDR_T_64BIT=y |
| 286 | CONFIG_ZONE_DMA_FLAG=1 | 301 | CONFIG_ZONE_DMA_FLAG=1 |
| 287 | CONFIG_BOUNCE=y | 302 | CONFIG_BOUNCE=y |
| 288 | CONFIG_UNEVICTABLE_LRU=y | ||
| 289 | CONFIG_HAVE_MLOCK=y | 303 | CONFIG_HAVE_MLOCK=y |
| 290 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 304 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 305 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 291 | CONFIG_ARCH_MEMORY_PROBE=y | 306 | CONFIG_ARCH_MEMORY_PROBE=y |
| 292 | CONFIG_PPC_HAS_HASH_64K=y | 307 | CONFIG_PPC_HAS_HASH_64K=y |
| 293 | CONFIG_PPC_4K_PAGES=y | 308 | CONFIG_PPC_4K_PAGES=y |
| @@ -399,6 +414,7 @@ CONFIG_IPV6_NDISC_NODETYPE=y | |||
| 399 | # CONFIG_ECONET is not set | 414 | # CONFIG_ECONET is not set |
| 400 | # CONFIG_WAN_ROUTER is not set | 415 | # CONFIG_WAN_ROUTER is not set |
| 401 | # CONFIG_PHONET is not set | 416 | # CONFIG_PHONET is not set |
| 417 | # CONFIG_IEEE802154 is not set | ||
| 402 | # CONFIG_NET_SCHED is not set | 418 | # CONFIG_NET_SCHED is not set |
| 403 | # CONFIG_DCB is not set | 419 | # CONFIG_DCB is not set |
| 404 | 420 | ||
| @@ -433,11 +449,14 @@ CONFIG_BT_HCIBTUSB=m | |||
| 433 | CONFIG_WIRELESS=y | 449 | CONFIG_WIRELESS=y |
| 434 | CONFIG_CFG80211=m | 450 | CONFIG_CFG80211=m |
| 435 | # CONFIG_CFG80211_REG_DEBUG is not set | 451 | # CONFIG_CFG80211_REG_DEBUG is not set |
| 452 | # CONFIG_CFG80211_DEBUGFS is not set | ||
| 436 | # CONFIG_WIRELESS_OLD_REGULATORY is not set | 453 | # CONFIG_WIRELESS_OLD_REGULATORY is not set |
| 437 | CONFIG_WIRELESS_EXT=y | 454 | CONFIG_WIRELESS_EXT=y |
| 438 | # CONFIG_WIRELESS_EXT_SYSFS is not set | 455 | # CONFIG_WIRELESS_EXT_SYSFS is not set |
| 439 | # CONFIG_LIB80211 is not set | 456 | # CONFIG_LIB80211 is not set |
| 440 | CONFIG_MAC80211=m | 457 | CONFIG_MAC80211=m |
| 458 | CONFIG_MAC80211_DEFAULT_PS=y | ||
| 459 | CONFIG_MAC80211_DEFAULT_PS_VALUE=1 | ||
| 441 | 460 | ||
| 442 | # | 461 | # |
| 443 | # Rate control algorithm selection | 462 | # Rate control algorithm selection |
| @@ -447,7 +466,6 @@ CONFIG_MAC80211_RC_PID=y | |||
| 447 | CONFIG_MAC80211_RC_DEFAULT_PID=y | 466 | CONFIG_MAC80211_RC_DEFAULT_PID=y |
| 448 | # CONFIG_MAC80211_RC_DEFAULT_MINSTREL is not set | 467 | # CONFIG_MAC80211_RC_DEFAULT_MINSTREL is not set |
| 449 | CONFIG_MAC80211_RC_DEFAULT="pid" | 468 | CONFIG_MAC80211_RC_DEFAULT="pid" |
| 450 | # CONFIG_MAC80211_MESH is not set | ||
| 451 | # CONFIG_MAC80211_LEDS is not set | 469 | # CONFIG_MAC80211_LEDS is not set |
| 452 | # CONFIG_MAC80211_DEBUGFS is not set | 470 | # CONFIG_MAC80211_DEBUGFS is not set |
| 453 | # CONFIG_MAC80211_DEBUG_MENU is not set | 471 | # CONFIG_MAC80211_DEBUG_MENU is not set |
| @@ -472,77 +490,7 @@ CONFIG_EXTRA_FIRMWARE="" | |||
| 472 | # CONFIG_DEBUG_DEVRES is not set | 490 | # CONFIG_DEBUG_DEVRES is not set |
| 473 | # CONFIG_SYS_HYPERVISOR is not set | 491 | # CONFIG_SYS_HYPERVISOR is not set |
| 474 | # CONFIG_CONNECTOR is not set | 492 | # CONFIG_CONNECTOR is not set |
| 475 | CONFIG_MTD=y | 493 | # CONFIG_MTD is not set |
| 476 | CONFIG_MTD_DEBUG=y | ||
| 477 | CONFIG_MTD_DEBUG_VERBOSE=0 | ||
| 478 | # CONFIG_MTD_CONCAT is not set | ||
| 479 | # CONFIG_MTD_PARTITIONS is not set | ||
| 480 | # CONFIG_MTD_TESTS is not set | ||
| 481 | |||
| 482 | # | ||
| 483 | # User Modules And Translation Layers | ||
| 484 | # | ||
| 485 | # CONFIG_MTD_CHAR is not set | ||
| 486 | CONFIG_MTD_BLKDEVS=y | ||
| 487 | CONFIG_MTD_BLOCK=y | ||
| 488 | # CONFIG_FTL is not set | ||
| 489 | # CONFIG_NFTL is not set | ||
| 490 | # CONFIG_INFTL is not set | ||
| 491 | # CONFIG_RFD_FTL is not set | ||
| 492 | # CONFIG_SSFDC is not set | ||
| 493 | # CONFIG_MTD_OOPS is not set | ||
| 494 | |||
| 495 | # | ||
| 496 | # RAM/ROM/Flash chip drivers | ||
| 497 | # | ||
| 498 | # CONFIG_MTD_CFI is not set | ||
| 499 | # CONFIG_MTD_JEDECPROBE is not set | ||
| 500 | CONFIG_MTD_MAP_BANK_WIDTH_1=y | ||
| 501 | CONFIG_MTD_MAP_BANK_WIDTH_2=y | ||
| 502 | CONFIG_MTD_MAP_BANK_WIDTH_4=y | ||
| 503 | # CONFIG_MTD_MAP_BANK_WIDTH_8 is not set | ||
| 504 | # CONFIG_MTD_MAP_BANK_WIDTH_16 is not set | ||
| 505 | # CONFIG_MTD_MAP_BANK_WIDTH_32 is not set | ||
| 506 | CONFIG_MTD_CFI_I1=y | ||
| 507 | CONFIG_MTD_CFI_I2=y | ||
| 508 | # CONFIG_MTD_CFI_I4 is not set | ||
| 509 | # CONFIG_MTD_CFI_I8 is not set | ||
| 510 | # CONFIG_MTD_RAM is not set | ||
| 511 | # CONFIG_MTD_ROM is not set | ||
| 512 | # CONFIG_MTD_ABSENT is not set | ||
| 513 | |||
| 514 | # | ||
| 515 | # Mapping drivers for chip access | ||
| 516 | # | ||
| 517 | # CONFIG_MTD_COMPLEX_MAPPINGS is not set | ||
| 518 | # CONFIG_MTD_PLATRAM is not set | ||
| 519 | |||
| 520 | # | ||
| 521 | # Self-contained MTD device drivers | ||
| 522 | # | ||
| 523 | # CONFIG_MTD_SLRAM is not set | ||
| 524 | # CONFIG_MTD_PHRAM is not set | ||
| 525 | # CONFIG_MTD_MTDRAM is not set | ||
| 526 | # CONFIG_MTD_BLOCK2MTD is not set | ||
| 527 | |||
| 528 | # | ||
| 529 | # Disk-On-Chip Device Drivers | ||
| 530 | # | ||
| 531 | # CONFIG_MTD_DOC2000 is not set | ||
| 532 | # CONFIG_MTD_DOC2001 is not set | ||
| 533 | # CONFIG_MTD_DOC2001PLUS is not set | ||
| 534 | # CONFIG_MTD_NAND is not set | ||
| 535 | # CONFIG_MTD_ONENAND is not set | ||
| 536 | |||
| 537 | # | ||
| 538 | # LPDDR flash memory drivers | ||
| 539 | # | ||
| 540 | # CONFIG_MTD_LPDDR is not set | ||
| 541 | |||
| 542 | # | ||
| 543 | # UBI - Unsorted block images | ||
| 544 | # | ||
| 545 | # CONFIG_MTD_UBI is not set | ||
| 546 | CONFIG_OF_DEVICE=y | 494 | CONFIG_OF_DEVICE=y |
| 547 | # CONFIG_PARPORT is not set | 495 | # CONFIG_PARPORT is not set |
| 548 | CONFIG_BLK_DEV=y | 496 | CONFIG_BLK_DEV=y |
| @@ -590,10 +538,6 @@ CONFIG_BLK_DEV_SR=y | |||
| 590 | # CONFIG_BLK_DEV_SR_VENDOR is not set | 538 | # CONFIG_BLK_DEV_SR_VENDOR is not set |
| 591 | CONFIG_CHR_DEV_SG=m | 539 | CONFIG_CHR_DEV_SG=m |
| 592 | # CONFIG_CHR_DEV_SCH is not set | 540 | # CONFIG_CHR_DEV_SCH is not set |
| 593 | |||
| 594 | # | ||
| 595 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 596 | # | ||
| 597 | CONFIG_SCSI_MULTI_LUN=y | 541 | CONFIG_SCSI_MULTI_LUN=y |
| 598 | # CONFIG_SCSI_CONSTANTS is not set | 542 | # CONFIG_SCSI_CONSTANTS is not set |
| 599 | # CONFIG_SCSI_LOGGING is not set | 543 | # CONFIG_SCSI_LOGGING is not set |
| @@ -626,7 +570,6 @@ CONFIG_BLK_DEV_DM=m | |||
| 626 | # CONFIG_DM_UEVENT is not set | 570 | # CONFIG_DM_UEVENT is not set |
| 627 | # CONFIG_MACINTOSH_DRIVERS is not set | 571 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 628 | CONFIG_NETDEVICES=y | 572 | CONFIG_NETDEVICES=y |
| 629 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 630 | # CONFIG_DUMMY is not set | 573 | # CONFIG_DUMMY is not set |
| 631 | # CONFIG_BONDING is not set | 574 | # CONFIG_BONDING is not set |
| 632 | # CONFIG_MACVLAN is not set | 575 | # CONFIG_MACVLAN is not set |
| @@ -646,10 +589,11 @@ CONFIG_MII=m | |||
| 646 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 589 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 647 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 590 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 648 | # CONFIG_B44 is not set | 591 | # CONFIG_B44 is not set |
| 592 | # CONFIG_KS8842 is not set | ||
| 649 | CONFIG_NETDEV_1000=y | 593 | CONFIG_NETDEV_1000=y |
| 650 | CONFIG_GELIC_NET=y | 594 | CONFIG_GELIC_NET=y |
| 651 | CONFIG_GELIC_WIRELESS=y | 595 | CONFIG_GELIC_WIRELESS=y |
| 652 | CONFIG_GELIC_WIRELESS_OLD_PSK_INTERFACE=y | 596 | # CONFIG_GELIC_WIRELESS_OLD_PSK_INTERFACE is not set |
| 653 | # CONFIG_NETDEV_10000 is not set | 597 | # CONFIG_NETDEV_10000 is not set |
| 654 | 598 | ||
| 655 | # | 599 | # |
| @@ -669,8 +613,7 @@ CONFIG_WLAN_80211=y | |||
| 669 | # CONFIG_HOSTAP is not set | 613 | # CONFIG_HOSTAP is not set |
| 670 | # CONFIG_B43 is not set | 614 | # CONFIG_B43 is not set |
| 671 | # CONFIG_B43LEGACY is not set | 615 | # CONFIG_B43LEGACY is not set |
| 672 | CONFIG_ZD1211RW=m | 616 | # CONFIG_ZD1211RW is not set |
| 673 | # CONFIG_ZD1211RW_DEBUG is not set | ||
| 674 | # CONFIG_RT2X00 is not set | 617 | # CONFIG_RT2X00 is not set |
| 675 | 618 | ||
| 676 | # | 619 | # |
| @@ -682,7 +625,7 @@ CONFIG_ZD1211RW=m | |||
| 682 | # | 625 | # |
| 683 | # CONFIG_USB_CATC is not set | 626 | # CONFIG_USB_CATC is not set |
| 684 | # CONFIG_USB_KAWETH is not set | 627 | # CONFIG_USB_KAWETH is not set |
| 685 | CONFIG_USB_PEGASUS=m | 628 | # CONFIG_USB_PEGASUS is not set |
| 686 | # CONFIG_USB_RTL8150 is not set | 629 | # CONFIG_USB_RTL8150 is not set |
| 687 | CONFIG_USB_USBNET=m | 630 | CONFIG_USB_USBNET=m |
| 688 | CONFIG_USB_NET_AX8817X=m | 631 | CONFIG_USB_NET_AX8817X=m |
| @@ -693,10 +636,11 @@ CONFIG_USB_NET_AX8817X=m | |||
| 693 | # CONFIG_USB_NET_GL620A is not set | 636 | # CONFIG_USB_NET_GL620A is not set |
| 694 | # CONFIG_USB_NET_NET1080 is not set | 637 | # CONFIG_USB_NET_NET1080 is not set |
| 695 | # CONFIG_USB_NET_PLUSB is not set | 638 | # CONFIG_USB_NET_PLUSB is not set |
| 696 | CONFIG_USB_NET_MCS7830=m | 639 | # CONFIG_USB_NET_MCS7830 is not set |
| 697 | # CONFIG_USB_NET_RNDIS_HOST is not set | 640 | # CONFIG_USB_NET_RNDIS_HOST is not set |
| 698 | # CONFIG_USB_NET_CDC_SUBSET is not set | 641 | # CONFIG_USB_NET_CDC_SUBSET is not set |
| 699 | # CONFIG_USB_NET_ZAURUS is not set | 642 | # CONFIG_USB_NET_ZAURUS is not set |
| 643 | # CONFIG_USB_NET_INT51X1 is not set | ||
| 700 | # CONFIG_WAN is not set | 644 | # CONFIG_WAN is not set |
| 701 | CONFIG_PPP=m | 645 | CONFIG_PPP=m |
| 702 | CONFIG_PPP_MULTILINK=y | 646 | CONFIG_PPP_MULTILINK=y |
| @@ -771,8 +715,7 @@ CONFIG_DEVKMEM=y | |||
| 771 | # | 715 | # |
| 772 | CONFIG_UNIX98_PTYS=y | 716 | CONFIG_UNIX98_PTYS=y |
| 773 | # CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set | 717 | # CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set |
| 774 | CONFIG_LEGACY_PTYS=y | 718 | # CONFIG_LEGACY_PTYS is not set |
| 775 | CONFIG_LEGACY_PTY_COUNT=16 | ||
| 776 | # CONFIG_HVC_UDBG is not set | 719 | # CONFIG_HVC_UDBG is not set |
| 777 | # CONFIG_IPMI_HANDLER is not set | 720 | # CONFIG_IPMI_HANDLER is not set |
| 778 | # CONFIG_HW_RANDOM is not set | 721 | # CONFIG_HW_RANDOM is not set |
| @@ -782,6 +725,11 @@ CONFIG_LEGACY_PTY_COUNT=16 | |||
| 782 | # CONFIG_TCG_TPM is not set | 725 | # CONFIG_TCG_TPM is not set |
| 783 | # CONFIG_I2C is not set | 726 | # CONFIG_I2C is not set |
| 784 | # CONFIG_SPI is not set | 727 | # CONFIG_SPI is not set |
| 728 | |||
| 729 | # | ||
| 730 | # PPS support | ||
| 731 | # | ||
| 732 | # CONFIG_PPS is not set | ||
| 785 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 733 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 786 | # CONFIG_GPIOLIB is not set | 734 | # CONFIG_GPIOLIB is not set |
| 787 | # CONFIG_W1 is not set | 735 | # CONFIG_W1 is not set |
| @@ -805,22 +753,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 805 | # CONFIG_HTC_PASIC3 is not set | 753 | # CONFIG_HTC_PASIC3 is not set |
| 806 | # CONFIG_MFD_TMIO is not set | 754 | # CONFIG_MFD_TMIO is not set |
| 807 | # CONFIG_REGULATOR is not set | 755 | # CONFIG_REGULATOR is not set |
| 808 | 756 | # CONFIG_MEDIA_SUPPORT is not set | |
| 809 | # | ||
| 810 | # Multimedia devices | ||
| 811 | # | ||
| 812 | |||
| 813 | # | ||
| 814 | # Multimedia core support | ||
| 815 | # | ||
| 816 | # CONFIG_VIDEO_DEV is not set | ||
| 817 | # CONFIG_DVB_CORE is not set | ||
| 818 | # CONFIG_VIDEO_MEDIA is not set | ||
| 819 | |||
| 820 | # | ||
| 821 | # Multimedia drivers | ||
| 822 | # | ||
| 823 | # CONFIG_DAB is not set | ||
| 824 | 757 | ||
| 825 | # | 758 | # |
| 826 | # Graphics support | 759 | # Graphics support |
| @@ -898,6 +831,11 @@ CONFIG_SND_SUPPORT_OLD_API=y | |||
| 898 | CONFIG_SND_VERBOSE_PROCFS=y | 831 | CONFIG_SND_VERBOSE_PROCFS=y |
| 899 | # CONFIG_SND_VERBOSE_PRINTK is not set | 832 | # CONFIG_SND_VERBOSE_PRINTK is not set |
| 900 | # CONFIG_SND_DEBUG is not set | 833 | # CONFIG_SND_DEBUG is not set |
| 834 | # CONFIG_SND_RAWMIDI_SEQ is not set | ||
| 835 | # CONFIG_SND_OPL3_LIB_SEQ is not set | ||
| 836 | # CONFIG_SND_OPL4_LIB_SEQ is not set | ||
| 837 | # CONFIG_SND_SBAWE_SEQ is not set | ||
| 838 | # CONFIG_SND_EMU10K1_SEQ is not set | ||
| 901 | # CONFIG_SND_DRIVERS is not set | 839 | # CONFIG_SND_DRIVERS is not set |
| 902 | CONFIG_SND_PPC=y | 840 | CONFIG_SND_PPC=y |
| 903 | CONFIG_SND_PS3=m | 841 | CONFIG_SND_PS3=m |
| @@ -930,29 +868,34 @@ CONFIG_USB_HIDDEV=y | |||
| 930 | # Special HID drivers | 868 | # Special HID drivers |
| 931 | # | 869 | # |
| 932 | # CONFIG_HID_A4TECH is not set | 870 | # CONFIG_HID_A4TECH is not set |
| 933 | # CONFIG_HID_APPLE is not set | 871 | CONFIG_HID_APPLE=m |
| 934 | # CONFIG_HID_BELKIN is not set | 872 | CONFIG_HID_BELKIN=m |
| 935 | # CONFIG_HID_CHERRY is not set | 873 | CONFIG_HID_CHERRY=m |
| 936 | # CONFIG_HID_CHICONY is not set | 874 | # CONFIG_HID_CHICONY is not set |
| 937 | # CONFIG_HID_CYPRESS is not set | 875 | # CONFIG_HID_CYPRESS is not set |
| 938 | # CONFIG_DRAGONRISE_FF is not set | 876 | # CONFIG_HID_DRAGONRISE is not set |
| 939 | # CONFIG_HID_EZKEY is not set | 877 | CONFIG_HID_EZKEY=m |
| 940 | # CONFIG_HID_KYE is not set | 878 | # CONFIG_HID_KYE is not set |
| 941 | # CONFIG_HID_GYRATION is not set | 879 | # CONFIG_HID_GYRATION is not set |
| 942 | # CONFIG_HID_KENSINGTON is not set | 880 | # CONFIG_HID_KENSINGTON is not set |
| 943 | # CONFIG_HID_LOGITECH is not set | 881 | CONFIG_HID_LOGITECH=m |
| 944 | # CONFIG_HID_MICROSOFT is not set | 882 | # CONFIG_LOGITECH_FF is not set |
| 883 | # CONFIG_LOGIRUMBLEPAD2_FF is not set | ||
| 884 | CONFIG_HID_MICROSOFT=m | ||
| 945 | # CONFIG_HID_MONTEREY is not set | 885 | # CONFIG_HID_MONTEREY is not set |
| 946 | # CONFIG_HID_NTRIG is not set | 886 | # CONFIG_HID_NTRIG is not set |
| 947 | # CONFIG_HID_PANTHERLORD is not set | 887 | # CONFIG_HID_PANTHERLORD is not set |
| 948 | # CONFIG_HID_PETALYNX is not set | 888 | # CONFIG_HID_PETALYNX is not set |
| 949 | # CONFIG_HID_SAMSUNG is not set | 889 | # CONFIG_HID_SAMSUNG is not set |
| 950 | CONFIG_HID_SONY=m | 890 | CONFIG_HID_SONY=m |
| 951 | # CONFIG_HID_SUNPLUS is not set | 891 | CONFIG_HID_SUNPLUS=m |
| 952 | # CONFIG_GREENASIA_FF is not set | 892 | # CONFIG_HID_GREENASIA is not set |
| 893 | CONFIG_HID_SMARTJOYPLUS=m | ||
| 894 | # CONFIG_SMARTJOYPLUS_FF is not set | ||
| 953 | # CONFIG_HID_TOPSEED is not set | 895 | # CONFIG_HID_TOPSEED is not set |
| 954 | # CONFIG_THRUSTMASTER_FF is not set | 896 | # CONFIG_HID_THRUSTMASTER is not set |
| 955 | # CONFIG_ZEROPLUS_FF is not set | 897 | # CONFIG_HID_WACOM is not set |
| 898 | # CONFIG_HID_ZEROPLUS is not set | ||
| 956 | CONFIG_USB_SUPPORT=y | 899 | CONFIG_USB_SUPPORT=y |
| 957 | CONFIG_USB_ARCH_HAS_HCD=y | 900 | CONFIG_USB_ARCH_HAS_HCD=y |
| 958 | CONFIG_USB_ARCH_HAS_OHCI=y | 901 | CONFIG_USB_ARCH_HAS_OHCI=y |
| @@ -988,6 +931,8 @@ CONFIG_USB_EHCI_BIG_ENDIAN_MMIO=y | |||
| 988 | # CONFIG_USB_ISP116X_HCD is not set | 931 | # CONFIG_USB_ISP116X_HCD is not set |
| 989 | # CONFIG_USB_ISP1760_HCD is not set | 932 | # CONFIG_USB_ISP1760_HCD is not set |
| 990 | CONFIG_USB_OHCI_HCD=m | 933 | CONFIG_USB_OHCI_HCD=m |
| 934 | # CONFIG_USB_OHCI_HCD_PPC_OF_BE is not set | ||
| 935 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set | ||
| 991 | # CONFIG_USB_OHCI_HCD_PPC_OF is not set | 936 | # CONFIG_USB_OHCI_HCD_PPC_OF is not set |
| 992 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set | 937 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set |
| 993 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y | 938 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y |
| @@ -1115,6 +1060,10 @@ CONFIG_RTC_DRV_PS3=m | |||
| 1115 | # CONFIG_DMADEVICES is not set | 1060 | # CONFIG_DMADEVICES is not set |
| 1116 | # CONFIG_AUXDISPLAY is not set | 1061 | # CONFIG_AUXDISPLAY is not set |
| 1117 | # CONFIG_UIO is not set | 1062 | # CONFIG_UIO is not set |
| 1063 | |||
| 1064 | # | ||
| 1065 | # TI VLYNQ | ||
| 1066 | # | ||
| 1118 | # CONFIG_STAGING is not set | 1067 | # CONFIG_STAGING is not set |
| 1119 | 1068 | ||
| 1120 | # | 1069 | # |
| @@ -1141,11 +1090,12 @@ CONFIG_FS_MBCACHE=y | |||
| 1141 | # CONFIG_REISERFS_FS is not set | 1090 | # CONFIG_REISERFS_FS is not set |
| 1142 | # CONFIG_JFS_FS is not set | 1091 | # CONFIG_JFS_FS is not set |
| 1143 | # CONFIG_FS_POSIX_ACL is not set | 1092 | # CONFIG_FS_POSIX_ACL is not set |
| 1144 | CONFIG_FILE_LOCKING=y | ||
| 1145 | # CONFIG_XFS_FS is not set | 1093 | # CONFIG_XFS_FS is not set |
| 1146 | # CONFIG_GFS2_FS is not set | 1094 | # CONFIG_GFS2_FS is not set |
| 1147 | # CONFIG_OCFS2_FS is not set | 1095 | # CONFIG_OCFS2_FS is not set |
| 1148 | # CONFIG_BTRFS_FS is not set | 1096 | # CONFIG_BTRFS_FS is not set |
| 1097 | CONFIG_FILE_LOCKING=y | ||
| 1098 | CONFIG_FSNOTIFY=y | ||
| 1149 | CONFIG_DNOTIFY=y | 1099 | CONFIG_DNOTIFY=y |
| 1150 | CONFIG_INOTIFY=y | 1100 | CONFIG_INOTIFY=y |
| 1151 | CONFIG_INOTIFY_USER=y | 1101 | CONFIG_INOTIFY_USER=y |
| @@ -1205,7 +1155,6 @@ CONFIG_MISC_FILESYSTEMS=y | |||
| 1205 | # CONFIG_BEFS_FS is not set | 1155 | # CONFIG_BEFS_FS is not set |
| 1206 | # CONFIG_BFS_FS is not set | 1156 | # CONFIG_BFS_FS is not set |
| 1207 | # CONFIG_EFS_FS is not set | 1157 | # CONFIG_EFS_FS is not set |
| 1208 | # CONFIG_JFFS2_FS is not set | ||
| 1209 | # CONFIG_CRAMFS is not set | 1158 | # CONFIG_CRAMFS is not set |
| 1210 | # CONFIG_SQUASHFS is not set | 1159 | # CONFIG_SQUASHFS is not set |
| 1211 | # CONFIG_VXFS_FS is not set | 1160 | # CONFIG_VXFS_FS is not set |
| @@ -1222,6 +1171,7 @@ CONFIG_NFS_FS=y | |||
| 1222 | CONFIG_NFS_V3=y | 1171 | CONFIG_NFS_V3=y |
| 1223 | # CONFIG_NFS_V3_ACL is not set | 1172 | # CONFIG_NFS_V3_ACL is not set |
| 1224 | CONFIG_NFS_V4=y | 1173 | CONFIG_NFS_V4=y |
| 1174 | # CONFIG_NFS_V4_1 is not set | ||
| 1225 | CONFIG_ROOT_NFS=y | 1175 | CONFIG_ROOT_NFS=y |
| 1226 | # CONFIG_NFSD is not set | 1176 | # CONFIG_NFSD is not set |
| 1227 | CONFIG_LOCKD=y | 1177 | CONFIG_LOCKD=y |
| @@ -1359,7 +1309,6 @@ CONFIG_DEBUG_MEMORY_INIT=y | |||
| 1359 | CONFIG_DEBUG_LIST=y | 1309 | CONFIG_DEBUG_LIST=y |
| 1360 | # CONFIG_DEBUG_SG is not set | 1310 | # CONFIG_DEBUG_SG is not set |
| 1361 | # CONFIG_DEBUG_NOTIFIERS is not set | 1311 | # CONFIG_DEBUG_NOTIFIERS is not set |
| 1362 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
| 1363 | # CONFIG_RCU_TORTURE_TEST is not set | 1312 | # CONFIG_RCU_TORTURE_TEST is not set |
| 1364 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | 1313 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set |
| 1365 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1314 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| @@ -1374,31 +1323,21 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1374 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1323 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1375 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1324 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1376 | CONFIG_RING_BUFFER=y | 1325 | CONFIG_RING_BUFFER=y |
| 1326 | CONFIG_EVENT_TRACING=y | ||
| 1327 | CONFIG_CONTEXT_SWITCH_TRACER=y | ||
| 1377 | CONFIG_TRACING=y | 1328 | CONFIG_TRACING=y |
| 1378 | CONFIG_TRACING_SUPPORT=y | 1329 | CONFIG_TRACING_SUPPORT=y |
| 1379 | 1330 | # CONFIG_FTRACE is not set | |
| 1380 | # | ||
| 1381 | # Tracers | ||
| 1382 | # | ||
| 1383 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1384 | # CONFIG_IRQSOFF_TRACER is not set | ||
| 1385 | # CONFIG_SCHED_TRACER is not set | ||
| 1386 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1387 | # CONFIG_EVENT_TRACER is not set | ||
| 1388 | # CONFIG_BOOT_TRACER is not set | ||
| 1389 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1390 | # CONFIG_STACK_TRACER is not set | ||
| 1391 | # CONFIG_KMEMTRACE is not set | ||
| 1392 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1393 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1394 | # CONFIG_FTRACE_STARTUP_TEST is not set | ||
| 1395 | # CONFIG_DYNAMIC_DEBUG is not set | 1331 | # CONFIG_DYNAMIC_DEBUG is not set |
| 1396 | # CONFIG_SAMPLES is not set | 1332 | # CONFIG_SAMPLES is not set |
| 1397 | CONFIG_HAVE_ARCH_KGDB=y | 1333 | CONFIG_HAVE_ARCH_KGDB=y |
| 1398 | # CONFIG_KGDB is not set | 1334 | # CONFIG_KGDB is not set |
| 1335 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1336 | CONFIG_PPC_WERROR=y | ||
| 1399 | CONFIG_PRINT_STACK_DEPTH=64 | 1337 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1400 | CONFIG_DEBUG_STACKOVERFLOW=y | 1338 | CONFIG_DEBUG_STACKOVERFLOW=y |
| 1401 | # CONFIG_DEBUG_STACK_USAGE is not set | 1339 | # CONFIG_DEBUG_STACK_USAGE is not set |
| 1340 | # CONFIG_PPC_EMULATED_STATS is not set | ||
| 1402 | # CONFIG_CODE_PATCHING_SELFTEST is not set | 1341 | # CONFIG_CODE_PATCHING_SELFTEST is not set |
| 1403 | # CONFIG_FTR_FIXUP_SELFTEST is not set | 1342 | # CONFIG_FTR_FIXUP_SELFTEST is not set |
| 1404 | # CONFIG_MSI_BITMAP_SELFTEST is not set | 1343 | # CONFIG_MSI_BITMAP_SELFTEST is not set |
diff --git a/arch/powerpc/configs/storcenter_defconfig b/arch/powerpc/configs/storcenter_defconfig index bd4a8d435c50..28384dc01003 100644 --- a/arch/powerpc/configs/storcenter_defconfig +++ b/arch/powerpc/configs/storcenter_defconfig | |||
| @@ -1,25 +1,27 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc3 | 3 | # Linux kernel version: 2.6.31-rc4 |
| 4 | # Wed May 13 17:22:04 2009 | 4 | # Wed Jul 29 23:32:01 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
| 7 | 7 | ||
| 8 | # | 8 | # |
| 9 | # Processor support | 9 | # Processor support |
| 10 | # | 10 | # |
| 11 | CONFIG_6xx=y | 11 | CONFIG_PPC_BOOK3S_32=y |
| 12 | # CONFIG_PPC_85xx is not set | 12 | # CONFIG_PPC_85xx is not set |
| 13 | # CONFIG_PPC_8xx is not set | 13 | # CONFIG_PPC_8xx is not set |
| 14 | # CONFIG_40x is not set | 14 | # CONFIG_40x is not set |
| 15 | # CONFIG_44x is not set | 15 | # CONFIG_44x is not set |
| 16 | # CONFIG_E200 is not set | 16 | # CONFIG_E200 is not set |
| 17 | CONFIG_PPC_BOOK3S=y | 17 | CONFIG_PPC_BOOK3S=y |
| 18 | CONFIG_6xx=y | ||
| 18 | CONFIG_PPC_FPU=y | 19 | CONFIG_PPC_FPU=y |
| 19 | # CONFIG_ALTIVEC is not set | 20 | # CONFIG_ALTIVEC is not set |
| 20 | CONFIG_PPC_STD_MMU=y | 21 | CONFIG_PPC_STD_MMU=y |
| 21 | CONFIG_PPC_STD_MMU_32=y | 22 | CONFIG_PPC_STD_MMU_32=y |
| 22 | # CONFIG_PPC_MM_SLICES is not set | 23 | # CONFIG_PPC_MM_SLICES is not set |
| 24 | CONFIG_PPC_HAVE_PMU_SUPPORT=y | ||
| 23 | # CONFIG_SMP is not set | 25 | # CONFIG_SMP is not set |
| 24 | CONFIG_PPC32=y | 26 | CONFIG_PPC32=y |
| 25 | CONFIG_WORD_SIZE=32 | 27 | CONFIG_WORD_SIZE=32 |
| @@ -30,15 +32,16 @@ CONFIG_GENERIC_TIME=y | |||
| 30 | CONFIG_GENERIC_TIME_VSYSCALL=y | 32 | CONFIG_GENERIC_TIME_VSYSCALL=y |
| 31 | CONFIG_GENERIC_CLOCKEVENTS=y | 33 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 32 | CONFIG_GENERIC_HARDIRQS=y | 34 | CONFIG_GENERIC_HARDIRQS=y |
| 35 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
| 33 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | 36 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set |
| 34 | CONFIG_IRQ_PER_CPU=y | 37 | CONFIG_IRQ_PER_CPU=y |
| 35 | CONFIG_STACKTRACE_SUPPORT=y | 38 | CONFIG_STACKTRACE_SUPPORT=y |
| 36 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 39 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 40 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 37 | CONFIG_LOCKDEP_SUPPORT=y | 41 | CONFIG_LOCKDEP_SUPPORT=y |
| 38 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 42 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
| 39 | CONFIG_ARCH_HAS_ILOG2_U32=y | 43 | CONFIG_ARCH_HAS_ILOG2_U32=y |
| 40 | CONFIG_GENERIC_HWEIGHT=y | 44 | CONFIG_GENERIC_HWEIGHT=y |
| 41 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 42 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 45 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
| 43 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | 46 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set |
| 44 | CONFIG_PPC=y | 47 | CONFIG_PPC=y |
| @@ -52,11 +55,13 @@ CONFIG_PPC_UDBG_16550=y | |||
| 52 | # CONFIG_GENERIC_TBSYNC is not set | 55 | # CONFIG_GENERIC_TBSYNC is not set |
| 53 | CONFIG_AUDIT_ARCH=y | 56 | CONFIG_AUDIT_ARCH=y |
| 54 | CONFIG_GENERIC_BUG=y | 57 | CONFIG_GENERIC_BUG=y |
| 58 | CONFIG_DTC=y | ||
| 55 | # CONFIG_DEFAULT_UIMAGE is not set | 59 | # CONFIG_DEFAULT_UIMAGE is not set |
| 56 | # CONFIG_PPC_DCR_NATIVE is not set | 60 | # CONFIG_PPC_DCR_NATIVE is not set |
| 57 | # CONFIG_PPC_DCR_MMIO is not set | 61 | # CONFIG_PPC_DCR_MMIO is not set |
| 58 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 62 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 59 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 63 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 64 | CONFIG_CONSTRUCTORS=y | ||
| 60 | 65 | ||
| 61 | # | 66 | # |
| 62 | # General setup | 67 | # General setup |
| @@ -101,7 +106,6 @@ CONFIG_ANON_INODES=y | |||
| 101 | CONFIG_EMBEDDED=y | 106 | CONFIG_EMBEDDED=y |
| 102 | CONFIG_SYSCTL_SYSCALL=y | 107 | CONFIG_SYSCTL_SYSCALL=y |
| 103 | # CONFIG_KALLSYMS is not set | 108 | # CONFIG_KALLSYMS is not set |
| 104 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 105 | CONFIG_HOTPLUG=y | 109 | CONFIG_HOTPLUG=y |
| 106 | CONFIG_PRINTK=y | 110 | CONFIG_PRINTK=y |
| 107 | CONFIG_BUG=y | 111 | CONFIG_BUG=y |
| @@ -114,9 +118,16 @@ CONFIG_TIMERFD=y | |||
| 114 | CONFIG_EVENTFD=y | 118 | CONFIG_EVENTFD=y |
| 115 | CONFIG_SHMEM=y | 119 | CONFIG_SHMEM=y |
| 116 | CONFIG_AIO=y | 120 | CONFIG_AIO=y |
| 121 | CONFIG_HAVE_PERF_COUNTERS=y | ||
| 122 | |||
| 123 | # | ||
| 124 | # Performance Counters | ||
| 125 | # | ||
| 126 | # CONFIG_PERF_COUNTERS is not set | ||
| 117 | CONFIG_VM_EVENT_COUNTERS=y | 127 | CONFIG_VM_EVENT_COUNTERS=y |
| 118 | CONFIG_PCI_QUIRKS=y | 128 | CONFIG_PCI_QUIRKS=y |
| 119 | CONFIG_SLUB_DEBUG=y | 129 | CONFIG_SLUB_DEBUG=y |
| 130 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 120 | CONFIG_COMPAT_BRK=y | 131 | CONFIG_COMPAT_BRK=y |
| 121 | # CONFIG_SLAB is not set | 132 | # CONFIG_SLAB is not set |
| 122 | CONFIG_SLUB=y | 133 | CONFIG_SLUB=y |
| @@ -129,6 +140,10 @@ CONFIG_HAVE_IOREMAP_PROT=y | |||
| 129 | CONFIG_HAVE_KPROBES=y | 140 | CONFIG_HAVE_KPROBES=y |
| 130 | CONFIG_HAVE_KRETPROBES=y | 141 | CONFIG_HAVE_KRETPROBES=y |
| 131 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 142 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 143 | |||
| 144 | # | ||
| 145 | # GCOV-based kernel profiling | ||
| 146 | # | ||
| 132 | # CONFIG_SLOW_WORK is not set | 147 | # CONFIG_SLOW_WORK is not set |
| 133 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 148 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 134 | CONFIG_SLABINFO=y | 149 | CONFIG_SLABINFO=y |
| @@ -141,7 +156,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 141 | # CONFIG_MODVERSIONS is not set | 156 | # CONFIG_MODVERSIONS is not set |
| 142 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 157 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 143 | CONFIG_BLOCK=y | 158 | CONFIG_BLOCK=y |
| 144 | CONFIG_LBD=y | 159 | CONFIG_LBDAF=y |
| 145 | # CONFIG_BLK_DEV_BSG is not set | 160 | # CONFIG_BLK_DEV_BSG is not set |
| 146 | # CONFIG_BLK_DEV_INTEGRITY is not set | 161 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 147 | 162 | ||
| @@ -222,6 +237,7 @@ CONFIG_BINFMT_ELF=y | |||
| 222 | # CONFIG_HAVE_AOUT is not set | 237 | # CONFIG_HAVE_AOUT is not set |
| 223 | CONFIG_BINFMT_MISC=y | 238 | CONFIG_BINFMT_MISC=y |
| 224 | # CONFIG_IOMMU_HELPER is not set | 239 | # CONFIG_IOMMU_HELPER is not set |
| 240 | # CONFIG_SWIOTLB is not set | ||
| 225 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 241 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
| 226 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 242 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
| 227 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 243 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
| @@ -242,9 +258,9 @@ CONFIG_MIGRATION=y | |||
| 242 | CONFIG_ZONE_DMA_FLAG=1 | 258 | CONFIG_ZONE_DMA_FLAG=1 |
| 243 | CONFIG_BOUNCE=y | 259 | CONFIG_BOUNCE=y |
| 244 | CONFIG_VIRT_TO_BUS=y | 260 | CONFIG_VIRT_TO_BUS=y |
| 245 | CONFIG_UNEVICTABLE_LRU=y | ||
| 246 | CONFIG_HAVE_MLOCK=y | 261 | CONFIG_HAVE_MLOCK=y |
| 247 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 262 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 263 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 248 | CONFIG_PPC_4K_PAGES=y | 264 | CONFIG_PPC_4K_PAGES=y |
| 249 | # CONFIG_PPC_16K_PAGES is not set | 265 | # CONFIG_PPC_16K_PAGES is not set |
| 250 | # CONFIG_PPC_64K_PAGES is not set | 266 | # CONFIG_PPC_64K_PAGES is not set |
| @@ -347,6 +363,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
| 347 | # CONFIG_ECONET is not set | 363 | # CONFIG_ECONET is not set |
| 348 | # CONFIG_WAN_ROUTER is not set | 364 | # CONFIG_WAN_ROUTER is not set |
| 349 | # CONFIG_PHONET is not set | 365 | # CONFIG_PHONET is not set |
| 366 | # CONFIG_IEEE802154 is not set | ||
| 350 | # CONFIG_NET_SCHED is not set | 367 | # CONFIG_NET_SCHED is not set |
| 351 | # CONFIG_DCB is not set | 368 | # CONFIG_DCB is not set |
| 352 | 369 | ||
| @@ -364,7 +381,11 @@ CONFIG_WIRELESS=y | |||
| 364 | CONFIG_WIRELESS_OLD_REGULATORY=y | 381 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 365 | # CONFIG_WIRELESS_EXT is not set | 382 | # CONFIG_WIRELESS_EXT is not set |
| 366 | # CONFIG_LIB80211 is not set | 383 | # CONFIG_LIB80211 is not set |
| 367 | # CONFIG_MAC80211 is not set | 384 | |
| 385 | # | ||
| 386 | # CFG80211 needs to be enabled for MAC80211 | ||
| 387 | # | ||
| 388 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 368 | # CONFIG_WIMAX is not set | 389 | # CONFIG_WIMAX is not set |
| 369 | # CONFIG_RFKILL is not set | 390 | # CONFIG_RFKILL is not set |
| 370 | # CONFIG_NET_9P is not set | 391 | # CONFIG_NET_9P is not set |
| @@ -501,7 +522,9 @@ CONFIG_MISC_DEVICES=y | |||
| 501 | # | 522 | # |
| 502 | # CONFIG_EEPROM_AT24 is not set | 523 | # CONFIG_EEPROM_AT24 is not set |
| 503 | # CONFIG_EEPROM_LEGACY is not set | 524 | # CONFIG_EEPROM_LEGACY is not set |
| 525 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 504 | # CONFIG_EEPROM_93CX6 is not set | 526 | # CONFIG_EEPROM_93CX6 is not set |
| 527 | # CONFIG_CB710_CORE is not set | ||
| 505 | CONFIG_HAVE_IDE=y | 528 | CONFIG_HAVE_IDE=y |
| 506 | CONFIG_IDE=y | 529 | CONFIG_IDE=y |
| 507 | 530 | ||
| @@ -579,10 +602,6 @@ CONFIG_BLK_DEV_SR=y | |||
| 579 | # CONFIG_BLK_DEV_SR_VENDOR is not set | 602 | # CONFIG_BLK_DEV_SR_VENDOR is not set |
| 580 | # CONFIG_CHR_DEV_SG is not set | 603 | # CONFIG_CHR_DEV_SG is not set |
| 581 | # CONFIG_CHR_DEV_SCH is not set | 604 | # CONFIG_CHR_DEV_SCH is not set |
| 582 | |||
| 583 | # | ||
| 584 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 585 | # | ||
| 586 | # CONFIG_SCSI_MULTI_LUN is not set | 605 | # CONFIG_SCSI_MULTI_LUN is not set |
| 587 | # CONFIG_SCSI_CONSTANTS is not set | 606 | # CONFIG_SCSI_CONSTANTS is not set |
| 588 | # CONFIG_SCSI_LOGGING is not set | 607 | # CONFIG_SCSI_LOGGING is not set |
| @@ -599,6 +618,7 @@ CONFIG_SCSI_SPI_ATTRS=y | |||
| 599 | # CONFIG_SCSI_SRP_ATTRS is not set | 618 | # CONFIG_SCSI_SRP_ATTRS is not set |
| 600 | CONFIG_SCSI_LOWLEVEL=y | 619 | CONFIG_SCSI_LOWLEVEL=y |
| 601 | # CONFIG_ISCSI_TCP is not set | 620 | # CONFIG_ISCSI_TCP is not set |
| 621 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 602 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 622 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 603 | # CONFIG_SCSI_3W_9XXX is not set | 623 | # CONFIG_SCSI_3W_9XXX is not set |
| 604 | # CONFIG_SCSI_ACARD is not set | 624 | # CONFIG_SCSI_ACARD is not set |
| @@ -607,6 +627,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 607 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 627 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 608 | # CONFIG_SCSI_AIC79XX is not set | 628 | # CONFIG_SCSI_AIC79XX is not set |
| 609 | # CONFIG_SCSI_AIC94XX is not set | 629 | # CONFIG_SCSI_AIC94XX is not set |
| 630 | # CONFIG_SCSI_MVSAS is not set | ||
| 610 | # CONFIG_SCSI_DPT_I2O is not set | 631 | # CONFIG_SCSI_DPT_I2O is not set |
| 611 | # CONFIG_SCSI_ADVANSYS is not set | 632 | # CONFIG_SCSI_ADVANSYS is not set |
| 612 | # CONFIG_SCSI_ARCMSR is not set | 633 | # CONFIG_SCSI_ARCMSR is not set |
| @@ -626,7 +647,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 626 | # CONFIG_SCSI_IPS is not set | 647 | # CONFIG_SCSI_IPS is not set |
| 627 | # CONFIG_SCSI_INITIO is not set | 648 | # CONFIG_SCSI_INITIO is not set |
| 628 | # CONFIG_SCSI_INIA100 is not set | 649 | # CONFIG_SCSI_INIA100 is not set |
| 629 | # CONFIG_SCSI_MVSAS is not set | ||
| 630 | # CONFIG_SCSI_STEX is not set | 650 | # CONFIG_SCSI_STEX is not set |
| 631 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 651 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 632 | # CONFIG_SCSI_QLOGIC_1280 is not set | 652 | # CONFIG_SCSI_QLOGIC_1280 is not set |
| @@ -660,14 +680,17 @@ CONFIG_MD_RAID6_PQ=y | |||
| 660 | # | 680 | # |
| 661 | 681 | ||
| 662 | # | 682 | # |
| 663 | # Enable only one of the two stacks, unless you know what you are doing | 683 | # You can enable one or both FireWire driver stacks. |
| 684 | # | ||
| 685 | |||
| 686 | # | ||
| 687 | # See the help texts for more information. | ||
| 664 | # | 688 | # |
| 665 | # CONFIG_FIREWIRE is not set | 689 | # CONFIG_FIREWIRE is not set |
| 666 | # CONFIG_IEEE1394 is not set | 690 | # CONFIG_IEEE1394 is not set |
| 667 | # CONFIG_I2O is not set | 691 | # CONFIG_I2O is not set |
| 668 | # CONFIG_MACINTOSH_DRIVERS is not set | 692 | # CONFIG_MACINTOSH_DRIVERS is not set |
| 669 | CONFIG_NETDEVICES=y | 693 | CONFIG_NETDEVICES=y |
| 670 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 671 | CONFIG_DUMMY=m | 694 | CONFIG_DUMMY=m |
| 672 | # CONFIG_BONDING is not set | 695 | # CONFIG_BONDING is not set |
| 673 | # CONFIG_MACVLAN is not set | 696 | # CONFIG_MACVLAN is not set |
| @@ -695,8 +718,10 @@ CONFIG_R8169=y | |||
| 695 | # CONFIG_VIA_VELOCITY is not set | 718 | # CONFIG_VIA_VELOCITY is not set |
| 696 | # CONFIG_TIGON3 is not set | 719 | # CONFIG_TIGON3 is not set |
| 697 | # CONFIG_BNX2 is not set | 720 | # CONFIG_BNX2 is not set |
| 721 | # CONFIG_CNIC is not set | ||
| 698 | # CONFIG_FSL_PQ_MDIO is not set | 722 | # CONFIG_FSL_PQ_MDIO is not set |
| 699 | # CONFIG_GIANFAR is not set | 723 | # CONFIG_GIANFAR is not set |
| 724 | # CONFIG_MV643XX_ETH is not set | ||
| 700 | # CONFIG_QLA3XXX is not set | 725 | # CONFIG_QLA3XXX is not set |
| 701 | # CONFIG_ATL1 is not set | 726 | # CONFIG_ATL1 is not set |
| 702 | # CONFIG_ATL1E is not set | 727 | # CONFIG_ATL1E is not set |
| @@ -845,13 +870,17 @@ CONFIG_I2C_MPC=y | |||
| 845 | # CONFIG_SENSORS_PCF8574 is not set | 870 | # CONFIG_SENSORS_PCF8574 is not set |
| 846 | # CONFIG_PCF8575 is not set | 871 | # CONFIG_PCF8575 is not set |
| 847 | # CONFIG_SENSORS_PCA9539 is not set | 872 | # CONFIG_SENSORS_PCA9539 is not set |
| 848 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 849 | # CONFIG_SENSORS_TSL2550 is not set | 873 | # CONFIG_SENSORS_TSL2550 is not set |
| 850 | # CONFIG_I2C_DEBUG_CORE is not set | 874 | # CONFIG_I2C_DEBUG_CORE is not set |
| 851 | # CONFIG_I2C_DEBUG_ALGO is not set | 875 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 852 | # CONFIG_I2C_DEBUG_BUS is not set | 876 | # CONFIG_I2C_DEBUG_BUS is not set |
| 853 | # CONFIG_I2C_DEBUG_CHIP is not set | 877 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 854 | # CONFIG_SPI is not set | 878 | # CONFIG_SPI is not set |
| 879 | |||
| 880 | # | ||
| 881 | # PPS support | ||
| 882 | # | ||
| 883 | # CONFIG_PPS is not set | ||
| 855 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 884 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 856 | # CONFIG_GPIOLIB is not set | 885 | # CONFIG_GPIOLIB is not set |
| 857 | # CONFIG_W1 is not set | 886 | # CONFIG_W1 is not set |
| @@ -879,23 +908,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 879 | # CONFIG_MFD_WM8400 is not set | 908 | # CONFIG_MFD_WM8400 is not set |
| 880 | # CONFIG_MFD_WM8350_I2C is not set | 909 | # CONFIG_MFD_WM8350_I2C is not set |
| 881 | # CONFIG_MFD_PCF50633 is not set | 910 | # CONFIG_MFD_PCF50633 is not set |
| 911 | # CONFIG_AB3100_CORE is not set | ||
| 882 | # CONFIG_REGULATOR is not set | 912 | # CONFIG_REGULATOR is not set |
| 883 | 913 | # CONFIG_MEDIA_SUPPORT is not set | |
| 884 | # | ||
| 885 | # Multimedia devices | ||
| 886 | # | ||
| 887 | |||
| 888 | # | ||
| 889 | # Multimedia core support | ||
| 890 | # | ||
| 891 | # CONFIG_VIDEO_DEV is not set | ||
| 892 | # CONFIG_DVB_CORE is not set | ||
| 893 | # CONFIG_VIDEO_MEDIA is not set | ||
| 894 | |||
| 895 | # | ||
| 896 | # Multimedia drivers | ||
| 897 | # | ||
| 898 | # CONFIG_DAB is not set | ||
| 899 | 914 | ||
| 900 | # | 915 | # |
| 901 | # Graphics support | 916 | # Graphics support |
| @@ -937,6 +952,7 @@ CONFIG_USB_DEVICE_CLASS=y | |||
| 937 | # USB Host Controller Drivers | 952 | # USB Host Controller Drivers |
| 938 | # | 953 | # |
| 939 | # CONFIG_USB_C67X00_HCD is not set | 954 | # CONFIG_USB_C67X00_HCD is not set |
| 955 | # CONFIG_USB_XHCI_HCD is not set | ||
| 940 | CONFIG_USB_EHCI_HCD=y | 956 | CONFIG_USB_EHCI_HCD=y |
| 941 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set | 957 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set |
| 942 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 958 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -946,6 +962,8 @@ CONFIG_USB_EHCI_HCD_PPC_OF=y | |||
| 946 | # CONFIG_USB_ISP116X_HCD is not set | 962 | # CONFIG_USB_ISP116X_HCD is not set |
| 947 | # CONFIG_USB_ISP1760_HCD is not set | 963 | # CONFIG_USB_ISP1760_HCD is not set |
| 948 | CONFIG_USB_OHCI_HCD=y | 964 | CONFIG_USB_OHCI_HCD=y |
| 965 | # CONFIG_USB_OHCI_HCD_PPC_OF_BE is not set | ||
| 966 | # CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set | ||
| 949 | # CONFIG_USB_OHCI_HCD_PPC_OF is not set | 967 | # CONFIG_USB_OHCI_HCD_PPC_OF is not set |
| 950 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set | 968 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set |
| 951 | # CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set | 969 | # CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set |
| @@ -1064,6 +1082,7 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 1064 | # CONFIG_RTC_DRV_S35390A is not set | 1082 | # CONFIG_RTC_DRV_S35390A is not set |
| 1065 | # CONFIG_RTC_DRV_FM3130 is not set | 1083 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1066 | # CONFIG_RTC_DRV_RX8581 is not set | 1084 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1085 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1067 | 1086 | ||
| 1068 | # | 1087 | # |
| 1069 | # SPI RTC drivers | 1088 | # SPI RTC drivers |
| @@ -1091,6 +1110,10 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 1091 | # CONFIG_DMADEVICES is not set | 1110 | # CONFIG_DMADEVICES is not set |
| 1092 | # CONFIG_AUXDISPLAY is not set | 1111 | # CONFIG_AUXDISPLAY is not set |
| 1093 | # CONFIG_UIO is not set | 1112 | # CONFIG_UIO is not set |
| 1113 | |||
| 1114 | # | ||
| 1115 | # TI VLYNQ | ||
| 1116 | # | ||
| 1094 | # CONFIG_STAGING is not set | 1117 | # CONFIG_STAGING is not set |
| 1095 | 1118 | ||
| 1096 | # | 1119 | # |
| @@ -1110,7 +1133,6 @@ CONFIG_FS_MBCACHE=y | |||
| 1110 | # CONFIG_REISERFS_FS is not set | 1133 | # CONFIG_REISERFS_FS is not set |
| 1111 | # CONFIG_JFS_FS is not set | 1134 | # CONFIG_JFS_FS is not set |
| 1112 | # CONFIG_FS_POSIX_ACL is not set | 1135 | # CONFIG_FS_POSIX_ACL is not set |
| 1113 | CONFIG_FILE_LOCKING=y | ||
| 1114 | CONFIG_XFS_FS=m | 1136 | CONFIG_XFS_FS=m |
| 1115 | # CONFIG_XFS_QUOTA is not set | 1137 | # CONFIG_XFS_QUOTA is not set |
| 1116 | # CONFIG_XFS_POSIX_ACL is not set | 1138 | # CONFIG_XFS_POSIX_ACL is not set |
| @@ -1119,6 +1141,8 @@ CONFIG_XFS_FS=m | |||
| 1119 | # CONFIG_GFS2_FS is not set | 1141 | # CONFIG_GFS2_FS is not set |
| 1120 | # CONFIG_OCFS2_FS is not set | 1142 | # CONFIG_OCFS2_FS is not set |
| 1121 | # CONFIG_BTRFS_FS is not set | 1143 | # CONFIG_BTRFS_FS is not set |
| 1144 | CONFIG_FILE_LOCKING=y | ||
| 1145 | CONFIG_FSNOTIFY=y | ||
| 1122 | CONFIG_DNOTIFY=y | 1146 | CONFIG_DNOTIFY=y |
| 1123 | CONFIG_INOTIFY=y | 1147 | CONFIG_INOTIFY=y |
| 1124 | CONFIG_INOTIFY_USER=y | 1148 | CONFIG_INOTIFY_USER=y |
| @@ -1273,6 +1297,7 @@ CONFIG_HAS_IOPORT=y | |||
| 1273 | CONFIG_HAS_DMA=y | 1297 | CONFIG_HAS_DMA=y |
| 1274 | CONFIG_HAVE_LMB=y | 1298 | CONFIG_HAVE_LMB=y |
| 1275 | CONFIG_NLATTR=y | 1299 | CONFIG_NLATTR=y |
| 1300 | CONFIG_GENERIC_ATOMIC64=y | ||
| 1276 | 1301 | ||
| 1277 | # | 1302 | # |
| 1278 | # Kernel hacking | 1303 | # Kernel hacking |
| @@ -1298,22 +1323,11 @@ CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y | |||
| 1298 | CONFIG_HAVE_DYNAMIC_FTRACE=y | 1323 | CONFIG_HAVE_DYNAMIC_FTRACE=y |
| 1299 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | 1324 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y |
| 1300 | CONFIG_TRACING_SUPPORT=y | 1325 | CONFIG_TRACING_SUPPORT=y |
| 1301 | 1326 | # CONFIG_FTRACE is not set | |
| 1302 | # | ||
| 1303 | # Tracers | ||
| 1304 | # | ||
| 1305 | # CONFIG_FUNCTION_TRACER is not set | ||
| 1306 | # CONFIG_SCHED_TRACER is not set | ||
| 1307 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
| 1308 | # CONFIG_EVENT_TRACER is not set | ||
| 1309 | # CONFIG_BOOT_TRACER is not set | ||
| 1310 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
| 1311 | # CONFIG_STACK_TRACER is not set | ||
| 1312 | # CONFIG_KMEMTRACE is not set | ||
| 1313 | # CONFIG_WORKQUEUE_TRACER is not set | ||
| 1314 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 1315 | # CONFIG_SAMPLES is not set | 1327 | # CONFIG_SAMPLES is not set |
| 1316 | CONFIG_HAVE_ARCH_KGDB=y | 1328 | CONFIG_HAVE_ARCH_KGDB=y |
| 1329 | # CONFIG_PPC_DISABLE_WERROR is not set | ||
| 1330 | CONFIG_PPC_WERROR=y | ||
| 1317 | CONFIG_PRINT_STACK_DEPTH=64 | 1331 | CONFIG_PRINT_STACK_DEPTH=64 |
| 1318 | # CONFIG_IRQSTACKS is not set | 1332 | # CONFIG_IRQSTACKS is not set |
| 1319 | # CONFIG_BOOTX_TEXT is not set | 1333 | # CONFIG_BOOTX_TEXT is not set |
diff --git a/arch/powerpc/include/asm/kvm_host.h b/arch/powerpc/include/asm/kvm_host.h index dfdf13c9fefd..fddc3ed715fa 100644 --- a/arch/powerpc/include/asm/kvm_host.h +++ b/arch/powerpc/include/asm/kvm_host.h | |||
| @@ -34,7 +34,7 @@ | |||
| 34 | #define KVM_COALESCED_MMIO_PAGE_OFFSET 1 | 34 | #define KVM_COALESCED_MMIO_PAGE_OFFSET 1 |
| 35 | 35 | ||
| 36 | /* We don't currently support large pages. */ | 36 | /* We don't currently support large pages. */ |
| 37 | #define KVM_PAGES_PER_HPAGE (1<<31) | 37 | #define KVM_PAGES_PER_HPAGE (1UL << 31) |
| 38 | 38 | ||
| 39 | struct kvm; | 39 | struct kvm; |
| 40 | struct kvm_run; | 40 | struct kvm_run; |
diff --git a/arch/powerpc/include/asm/pgalloc-32.h b/arch/powerpc/include/asm/pgalloc-32.h index 0815eb40acae..c9500d666a1d 100644 --- a/arch/powerpc/include/asm/pgalloc-32.h +++ b/arch/powerpc/include/asm/pgalloc-32.h | |||
| @@ -16,7 +16,7 @@ extern void pgd_free(struct mm_struct *mm, pgd_t *pgd); | |||
| 16 | */ | 16 | */ |
| 17 | /* #define pmd_alloc_one(mm,address) ({ BUG(); ((pmd_t *)2); }) */ | 17 | /* #define pmd_alloc_one(mm,address) ({ BUG(); ((pmd_t *)2); }) */ |
| 18 | #define pmd_free(mm, x) do { } while (0) | 18 | #define pmd_free(mm, x) do { } while (0) |
| 19 | #define __pmd_free_tlb(tlb,x) do { } while (0) | 19 | #define __pmd_free_tlb(tlb,x,a) do { } while (0) |
| 20 | /* #define pgd_populate(mm, pmd, pte) BUG() */ | 20 | /* #define pgd_populate(mm, pmd, pte) BUG() */ |
| 21 | 21 | ||
| 22 | #ifndef CONFIG_BOOKE | 22 | #ifndef CONFIG_BOOKE |
diff --git a/arch/powerpc/include/asm/pgalloc-64.h b/arch/powerpc/include/asm/pgalloc-64.h index afda2bdd860f..e6f069c4f713 100644 --- a/arch/powerpc/include/asm/pgalloc-64.h +++ b/arch/powerpc/include/asm/pgalloc-64.h | |||
| @@ -118,11 +118,11 @@ static inline void pgtable_free(pgtable_free_t pgf) | |||
| 118 | kmem_cache_free(pgtable_cache[cachenum], p); | 118 | kmem_cache_free(pgtable_cache[cachenum], p); |
| 119 | } | 119 | } |
| 120 | 120 | ||
| 121 | #define __pmd_free_tlb(tlb, pmd) \ | 121 | #define __pmd_free_tlb(tlb, pmd,addr) \ |
| 122 | pgtable_free_tlb(tlb, pgtable_free_cache(pmd, \ | 122 | pgtable_free_tlb(tlb, pgtable_free_cache(pmd, \ |
| 123 | PMD_CACHE_NUM, PMD_TABLE_SIZE-1)) | 123 | PMD_CACHE_NUM, PMD_TABLE_SIZE-1)) |
| 124 | #ifndef CONFIG_PPC_64K_PAGES | 124 | #ifndef CONFIG_PPC_64K_PAGES |
| 125 | #define __pud_free_tlb(tlb, pud) \ | 125 | #define __pud_free_tlb(tlb, pud, addr) \ |
| 126 | pgtable_free_tlb(tlb, pgtable_free_cache(pud, \ | 126 | pgtable_free_tlb(tlb, pgtable_free_cache(pud, \ |
| 127 | PUD_CACHE_NUM, PUD_TABLE_SIZE-1)) | 127 | PUD_CACHE_NUM, PUD_TABLE_SIZE-1)) |
| 128 | #endif /* CONFIG_PPC_64K_PAGES */ | 128 | #endif /* CONFIG_PPC_64K_PAGES */ |
diff --git a/arch/powerpc/include/asm/pgalloc.h b/arch/powerpc/include/asm/pgalloc.h index 5d8480265a77..1730e5e298d6 100644 --- a/arch/powerpc/include/asm/pgalloc.h +++ b/arch/powerpc/include/asm/pgalloc.h | |||
| @@ -38,14 +38,14 @@ static inline pgtable_free_t pgtable_free_cache(void *p, int cachenum, | |||
| 38 | extern void pgtable_free_tlb(struct mmu_gather *tlb, pgtable_free_t pgf); | 38 | extern void pgtable_free_tlb(struct mmu_gather *tlb, pgtable_free_t pgf); |
| 39 | 39 | ||
| 40 | #ifdef CONFIG_SMP | 40 | #ifdef CONFIG_SMP |
| 41 | #define __pte_free_tlb(tlb,ptepage) \ | 41 | #define __pte_free_tlb(tlb,ptepage,address) \ |
| 42 | do { \ | 42 | do { \ |
| 43 | pgtable_page_dtor(ptepage); \ | 43 | pgtable_page_dtor(ptepage); \ |
| 44 | pgtable_free_tlb(tlb, pgtable_free_cache(page_address(ptepage), \ | 44 | pgtable_free_tlb(tlb, pgtable_free_cache(page_address(ptepage), \ |
| 45 | PTE_NONCACHE_NUM, PTE_TABLE_SIZE-1)); \ | 45 | PTE_NONCACHE_NUM, PTE_TABLE_SIZE-1)); \ |
| 46 | } while (0) | 46 | } while (0) |
| 47 | #else | 47 | #else |
| 48 | #define __pte_free_tlb(tlb, pte) pte_free((tlb)->mm, (pte)) | 48 | #define __pte_free_tlb(tlb, pte, address) pte_free((tlb)->mm, (pte)) |
| 49 | #endif | 49 | #endif |
| 50 | 50 | ||
| 51 | 51 | ||
diff --git a/arch/powerpc/kernel/dma.c b/arch/powerpc/kernel/dma.c index 20a60d661ba8..ccf129d47d84 100644 --- a/arch/powerpc/kernel/dma.c +++ b/arch/powerpc/kernel/dma.c | |||
| @@ -7,6 +7,7 @@ | |||
| 7 | 7 | ||
| 8 | #include <linux/device.h> | 8 | #include <linux/device.h> |
| 9 | #include <linux/dma-mapping.h> | 9 | #include <linux/dma-mapping.h> |
| 10 | #include <linux/lmb.h> | ||
| 10 | #include <asm/bug.h> | 11 | #include <asm/bug.h> |
| 11 | #include <asm/abs_addr.h> | 12 | #include <asm/abs_addr.h> |
| 12 | 13 | ||
| @@ -90,11 +91,10 @@ static void dma_direct_unmap_sg(struct device *dev, struct scatterlist *sg, | |||
| 90 | static int dma_direct_dma_supported(struct device *dev, u64 mask) | 91 | static int dma_direct_dma_supported(struct device *dev, u64 mask) |
| 91 | { | 92 | { |
| 92 | #ifdef CONFIG_PPC64 | 93 | #ifdef CONFIG_PPC64 |
| 93 | /* Could be improved to check for memory though it better be | 94 | /* Could be improved so platforms can set the limit in case |
| 94 | * done via some global so platforms can set the limit in case | ||
| 95 | * they have limited DMA windows | 95 | * they have limited DMA windows |
| 96 | */ | 96 | */ |
| 97 | return mask >= DMA_BIT_MASK(32); | 97 | return mask >= (lmb_end_of_DRAM() - 1); |
| 98 | #else | 98 | #else |
| 99 | return 1; | 99 | return 1; |
| 100 | #endif | 100 | #endif |
diff --git a/arch/powerpc/kernel/mpc7450-pmu.c b/arch/powerpc/kernel/mpc7450-pmu.c index c244133c67a6..cc466d039af6 100644 --- a/arch/powerpc/kernel/mpc7450-pmu.c +++ b/arch/powerpc/kernel/mpc7450-pmu.c | |||
| @@ -407,7 +407,8 @@ struct power_pmu mpc7450_pmu = { | |||
| 407 | 407 | ||
| 408 | static int init_mpc7450_pmu(void) | 408 | static int init_mpc7450_pmu(void) |
| 409 | { | 409 | { |
| 410 | if (strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc/7450")) | 410 | if (!cur_cpu_spec->oprofile_cpu_type || |
| 411 | strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc/7450")) | ||
| 411 | return -ENODEV; | 412 | return -ENODEV; |
| 412 | 413 | ||
| 413 | return register_power_pmu(&mpc7450_pmu); | 414 | return register_power_pmu(&mpc7450_pmu); |
diff --git a/arch/powerpc/kernel/perf_counter.c b/arch/powerpc/kernel/perf_counter.c index 809fdf94b95f..70e1f57f7dd8 100644 --- a/arch/powerpc/kernel/perf_counter.c +++ b/arch/powerpc/kernel/perf_counter.c | |||
| @@ -518,6 +518,8 @@ void hw_perf_disable(void) | |||
| 518 | struct cpu_hw_counters *cpuhw; | 518 | struct cpu_hw_counters *cpuhw; |
| 519 | unsigned long flags; | 519 | unsigned long flags; |
| 520 | 520 | ||
| 521 | if (!ppmu) | ||
| 522 | return; | ||
| 521 | local_irq_save(flags); | 523 | local_irq_save(flags); |
| 522 | cpuhw = &__get_cpu_var(cpu_hw_counters); | 524 | cpuhw = &__get_cpu_var(cpu_hw_counters); |
| 523 | 525 | ||
| @@ -572,6 +574,8 @@ void hw_perf_enable(void) | |||
| 572 | int n_lim; | 574 | int n_lim; |
| 573 | int idx; | 575 | int idx; |
| 574 | 576 | ||
| 577 | if (!ppmu) | ||
| 578 | return; | ||
| 575 | local_irq_save(flags); | 579 | local_irq_save(flags); |
| 576 | cpuhw = &__get_cpu_var(cpu_hw_counters); | 580 | cpuhw = &__get_cpu_var(cpu_hw_counters); |
| 577 | if (!cpuhw->disabled) { | 581 | if (!cpuhw->disabled) { |
| @@ -737,6 +741,8 @@ int hw_perf_group_sched_in(struct perf_counter *group_leader, | |||
| 737 | long i, n, n0; | 741 | long i, n, n0; |
| 738 | struct perf_counter *sub; | 742 | struct perf_counter *sub; |
| 739 | 743 | ||
| 744 | if (!ppmu) | ||
| 745 | return 0; | ||
| 740 | cpuhw = &__get_cpu_var(cpu_hw_counters); | 746 | cpuhw = &__get_cpu_var(cpu_hw_counters); |
| 741 | n0 = cpuhw->n_counters; | 747 | n0 = cpuhw->n_counters; |
| 742 | n = collect_events(group_leader, ppmu->n_counter - n0, | 748 | n = collect_events(group_leader, ppmu->n_counter - n0, |
| @@ -1281,6 +1287,8 @@ void hw_perf_counter_setup(int cpu) | |||
| 1281 | { | 1287 | { |
| 1282 | struct cpu_hw_counters *cpuhw = &per_cpu(cpu_hw_counters, cpu); | 1288 | struct cpu_hw_counters *cpuhw = &per_cpu(cpu_hw_counters, cpu); |
| 1283 | 1289 | ||
| 1290 | if (!ppmu) | ||
| 1291 | return; | ||
| 1284 | memset(cpuhw, 0, sizeof(*cpuhw)); | 1292 | memset(cpuhw, 0, sizeof(*cpuhw)); |
| 1285 | cpuhw->mmcr[0] = MMCR0_FC; | 1293 | cpuhw->mmcr[0] = MMCR0_FC; |
| 1286 | } | 1294 | } |
diff --git a/arch/powerpc/kernel/power4-pmu.c b/arch/powerpc/kernel/power4-pmu.c index db90b0c5c27b..3c90a3d9173e 100644 --- a/arch/powerpc/kernel/power4-pmu.c +++ b/arch/powerpc/kernel/power4-pmu.c | |||
| @@ -606,7 +606,8 @@ static struct power_pmu power4_pmu = { | |||
| 606 | 606 | ||
| 607 | static int init_power4_pmu(void) | 607 | static int init_power4_pmu(void) |
| 608 | { | 608 | { |
| 609 | if (strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/power4")) | 609 | if (!cur_cpu_spec->oprofile_cpu_type || |
| 610 | strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/power4")) | ||
| 610 | return -ENODEV; | 611 | return -ENODEV; |
| 611 | 612 | ||
| 612 | return register_power_pmu(&power4_pmu); | 613 | return register_power_pmu(&power4_pmu); |
diff --git a/arch/powerpc/kernel/power5+-pmu.c b/arch/powerpc/kernel/power5+-pmu.c index f4adca8e98a4..31918af3e355 100644 --- a/arch/powerpc/kernel/power5+-pmu.c +++ b/arch/powerpc/kernel/power5+-pmu.c | |||
| @@ -678,8 +678,9 @@ static struct power_pmu power5p_pmu = { | |||
| 678 | 678 | ||
| 679 | static int init_power5p_pmu(void) | 679 | static int init_power5p_pmu(void) |
| 680 | { | 680 | { |
| 681 | if (strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/power5+") | 681 | if (!cur_cpu_spec->oprofile_cpu_type || |
| 682 | && strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/power5++")) | 682 | (strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/power5+") |
| 683 | && strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/power5++"))) | ||
| 683 | return -ENODEV; | 684 | return -ENODEV; |
| 684 | 685 | ||
| 685 | return register_power_pmu(&power5p_pmu); | 686 | return register_power_pmu(&power5p_pmu); |
diff --git a/arch/powerpc/kernel/power5-pmu.c b/arch/powerpc/kernel/power5-pmu.c index 29b2c6c0e83a..867f6f663963 100644 --- a/arch/powerpc/kernel/power5-pmu.c +++ b/arch/powerpc/kernel/power5-pmu.c | |||
| @@ -618,7 +618,8 @@ static struct power_pmu power5_pmu = { | |||
| 618 | 618 | ||
| 619 | static int init_power5_pmu(void) | 619 | static int init_power5_pmu(void) |
| 620 | { | 620 | { |
| 621 | if (strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/power5")) | 621 | if (!cur_cpu_spec->oprofile_cpu_type || |
| 622 | strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/power5")) | ||
| 622 | return -ENODEV; | 623 | return -ENODEV; |
| 623 | 624 | ||
| 624 | return register_power_pmu(&power5_pmu); | 625 | return register_power_pmu(&power5_pmu); |
diff --git a/arch/powerpc/kernel/power6-pmu.c b/arch/powerpc/kernel/power6-pmu.c index 09ae5bf5bda7..fa21890531da 100644 --- a/arch/powerpc/kernel/power6-pmu.c +++ b/arch/powerpc/kernel/power6-pmu.c | |||
| @@ -537,7 +537,8 @@ static struct power_pmu power6_pmu = { | |||
| 537 | 537 | ||
| 538 | static int init_power6_pmu(void) | 538 | static int init_power6_pmu(void) |
| 539 | { | 539 | { |
| 540 | if (strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/power6")) | 540 | if (!cur_cpu_spec->oprofile_cpu_type || |
| 541 | strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/power6")) | ||
| 541 | return -ENODEV; | 542 | return -ENODEV; |
| 542 | 543 | ||
| 543 | return register_power_pmu(&power6_pmu); | 544 | return register_power_pmu(&power6_pmu); |
diff --git a/arch/powerpc/kernel/power7-pmu.c b/arch/powerpc/kernel/power7-pmu.c index 5a9f5cbd40a4..388cf57ad827 100644 --- a/arch/powerpc/kernel/power7-pmu.c +++ b/arch/powerpc/kernel/power7-pmu.c | |||
| @@ -366,7 +366,8 @@ static struct power_pmu power7_pmu = { | |||
| 366 | 366 | ||
| 367 | static int init_power7_pmu(void) | 367 | static int init_power7_pmu(void) |
| 368 | { | 368 | { |
| 369 | if (strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/power7")) | 369 | if (!cur_cpu_spec->oprofile_cpu_type || |
| 370 | strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/power7")) | ||
| 370 | return -ENODEV; | 371 | return -ENODEV; |
| 371 | 372 | ||
| 372 | return register_power_pmu(&power7_pmu); | 373 | return register_power_pmu(&power7_pmu); |
diff --git a/arch/powerpc/kernel/ppc970-pmu.c b/arch/powerpc/kernel/ppc970-pmu.c index 833097ac45dc..75dccb71a043 100644 --- a/arch/powerpc/kernel/ppc970-pmu.c +++ b/arch/powerpc/kernel/ppc970-pmu.c | |||
| @@ -488,8 +488,9 @@ static struct power_pmu ppc970_pmu = { | |||
| 488 | 488 | ||
| 489 | static int init_ppc970_pmu(void) | 489 | static int init_ppc970_pmu(void) |
| 490 | { | 490 | { |
| 491 | if (strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/970") | 491 | if (!cur_cpu_spec->oprofile_cpu_type || |
| 492 | && strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/970MP")) | 492 | (strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/970") |
| 493 | && strcmp(cur_cpu_spec->oprofile_cpu_type, "ppc64/970MP"))) | ||
| 493 | return -ENODEV; | 494 | return -ENODEV; |
| 494 | 495 | ||
| 495 | return register_power_pmu(&ppc970_pmu); | 496 | return register_power_pmu(&ppc970_pmu); |
diff --git a/arch/powerpc/mm/hugetlbpage.c b/arch/powerpc/mm/hugetlbpage.c index 9920d6a7cf29..c46ef2ffa3d9 100644 --- a/arch/powerpc/mm/hugetlbpage.c +++ b/arch/powerpc/mm/hugetlbpage.c | |||
| @@ -305,7 +305,7 @@ static void hugetlb_free_pmd_range(struct mmu_gather *tlb, pud_t *pud, | |||
| 305 | 305 | ||
| 306 | pmd = pmd_offset(pud, start); | 306 | pmd = pmd_offset(pud, start); |
| 307 | pud_clear(pud); | 307 | pud_clear(pud); |
| 308 | pmd_free_tlb(tlb, pmd); | 308 | pmd_free_tlb(tlb, pmd, start); |
| 309 | } | 309 | } |
| 310 | 310 | ||
| 311 | static void hugetlb_free_pud_range(struct mmu_gather *tlb, pgd_t *pgd, | 311 | static void hugetlb_free_pud_range(struct mmu_gather *tlb, pgd_t *pgd, |
| @@ -348,7 +348,7 @@ static void hugetlb_free_pud_range(struct mmu_gather *tlb, pgd_t *pgd, | |||
| 348 | 348 | ||
| 349 | pud = pud_offset(pgd, start); | 349 | pud = pud_offset(pgd, start); |
| 350 | pgd_clear(pgd); | 350 | pgd_clear(pgd); |
| 351 | pud_free_tlb(tlb, pud); | 351 | pud_free_tlb(tlb, pud, start); |
| 352 | } | 352 | } |
| 353 | 353 | ||
| 354 | /* | 354 | /* |
diff --git a/arch/powerpc/mm/mmu_context_nohash.c b/arch/powerpc/mm/mmu_context_nohash.c index 92a197117d5b..b1a727def15b 100644 --- a/arch/powerpc/mm/mmu_context_nohash.c +++ b/arch/powerpc/mm/mmu_context_nohash.c | |||
| @@ -217,6 +217,7 @@ void switch_mmu_context(struct mm_struct *prev, struct mm_struct *next) | |||
| 217 | id = steal_context_smp(id); | 217 | id = steal_context_smp(id); |
| 218 | if (id == MMU_NO_CONTEXT) | 218 | if (id == MMU_NO_CONTEXT) |
| 219 | goto again; | 219 | goto again; |
| 220 | goto stolen; | ||
| 220 | } | 221 | } |
| 221 | #endif /* CONFIG_SMP */ | 222 | #endif /* CONFIG_SMP */ |
| 222 | id = steal_context_up(id); | 223 | id = steal_context_up(id); |
diff --git a/arch/powerpc/platforms/85xx/mpc85xx_mds.c b/arch/powerpc/platforms/85xx/mpc85xx_mds.c index 60ed9c067b1d..bfb32834ab0c 100644 --- a/arch/powerpc/platforms/85xx/mpc85xx_mds.c +++ b/arch/powerpc/platforms/85xx/mpc85xx_mds.c | |||
| @@ -233,6 +233,19 @@ static void __init mpc85xx_mds_setup_arch(void) | |||
| 233 | /* Turn UCC1 & UCC2 on */ | 233 | /* Turn UCC1 & UCC2 on */ |
| 234 | setbits8(&bcsr_regs[8], BCSR_UCC1_GETH_EN); | 234 | setbits8(&bcsr_regs[8], BCSR_UCC1_GETH_EN); |
| 235 | setbits8(&bcsr_regs[9], BCSR_UCC2_GETH_EN); | 235 | setbits8(&bcsr_regs[9], BCSR_UCC2_GETH_EN); |
| 236 | } else if (machine_is(mpc8569_mds)) { | ||
| 237 | #define BCSR7_UCC12_GETHnRST (0x1 << 2) | ||
| 238 | #define BCSR8_UEM_MARVELL_RST (0x1 << 1) | ||
| 239 | /* | ||
| 240 | * U-Boot mangles interrupt polarity for Marvell PHYs, | ||
| 241 | * so reset built-in and UEM Marvell PHYs, this puts | ||
| 242 | * the PHYs into their normal state. | ||
| 243 | */ | ||
| 244 | clrbits8(&bcsr_regs[7], BCSR7_UCC12_GETHnRST); | ||
| 245 | setbits8(&bcsr_regs[8], BCSR8_UEM_MARVELL_RST); | ||
| 246 | |||
| 247 | setbits8(&bcsr_regs[7], BCSR7_UCC12_GETHnRST); | ||
| 248 | clrbits8(&bcsr_regs[8], BCSR8_UEM_MARVELL_RST); | ||
| 236 | } | 249 | } |
| 237 | iounmap(bcsr_regs); | 250 | iounmap(bcsr_regs); |
| 238 | } | 251 | } |
diff --git a/arch/powerpc/platforms/ps3/time.c b/arch/powerpc/platforms/ps3/time.c index b178a1e66c91..40b5cb433005 100644 --- a/arch/powerpc/platforms/ps3/time.c +++ b/arch/powerpc/platforms/ps3/time.c | |||
| @@ -21,6 +21,7 @@ | |||
| 21 | #include <linux/kernel.h> | 21 | #include <linux/kernel.h> |
| 22 | #include <linux/platform_device.h> | 22 | #include <linux/platform_device.h> |
| 23 | 23 | ||
| 24 | #include <asm/firmware.h> | ||
| 24 | #include <asm/rtc.h> | 25 | #include <asm/rtc.h> |
| 25 | #include <asm/lv1call.h> | 26 | #include <asm/lv1call.h> |
| 26 | #include <asm/ps3.h> | 27 | #include <asm/ps3.h> |
| @@ -84,6 +85,9 @@ static int __init ps3_rtc_init(void) | |||
| 84 | { | 85 | { |
| 85 | struct platform_device *pdev; | 86 | struct platform_device *pdev; |
| 86 | 87 | ||
| 88 | if (!firmware_has_feature(FW_FEATURE_PS3_LV1)) | ||
| 89 | return -ENODEV; | ||
| 90 | |||
| 87 | pdev = platform_device_register_simple("rtc-ps3", -1, NULL, 0); | 91 | pdev = platform_device_register_simple("rtc-ps3", -1, NULL, 0); |
| 88 | if (IS_ERR(pdev)) | 92 | if (IS_ERR(pdev)) |
| 89 | return PTR_ERR(pdev); | 93 | return PTR_ERR(pdev); |
diff --git a/arch/s390/include/asm/tlb.h b/arch/s390/include/asm/tlb.h index 3d8a96d39d9d..81150b053689 100644 --- a/arch/s390/include/asm/tlb.h +++ b/arch/s390/include/asm/tlb.h | |||
| @@ -96,7 +96,8 @@ static inline void tlb_remove_page(struct mmu_gather *tlb, struct page *page) | |||
| 96 | * pte_free_tlb frees a pte table and clears the CRSTE for the | 96 | * pte_free_tlb frees a pte table and clears the CRSTE for the |
| 97 | * page table from the tlb. | 97 | * page table from the tlb. |
| 98 | */ | 98 | */ |
| 99 | static inline void pte_free_tlb(struct mmu_gather *tlb, pgtable_t pte) | 99 | static inline void pte_free_tlb(struct mmu_gather *tlb, pgtable_t pte, |
| 100 | unsigned long address) | ||
| 100 | { | 101 | { |
| 101 | if (!tlb->fullmm) { | 102 | if (!tlb->fullmm) { |
| 102 | tlb->array[tlb->nr_ptes++] = pte; | 103 | tlb->array[tlb->nr_ptes++] = pte; |
| @@ -113,7 +114,8 @@ static inline void pte_free_tlb(struct mmu_gather *tlb, pgtable_t pte) | |||
| 113 | * as the pgd. pmd_free_tlb checks the asce_limit against 2GB | 114 | * as the pgd. pmd_free_tlb checks the asce_limit against 2GB |
| 114 | * to avoid the double free of the pmd in this case. | 115 | * to avoid the double free of the pmd in this case. |
| 115 | */ | 116 | */ |
| 116 | static inline void pmd_free_tlb(struct mmu_gather *tlb, pmd_t *pmd) | 117 | static inline void pmd_free_tlb(struct mmu_gather *tlb, pmd_t *pmd, |
| 118 | unsigned long address) | ||
| 117 | { | 119 | { |
| 118 | #ifdef __s390x__ | 120 | #ifdef __s390x__ |
| 119 | if (tlb->mm->context.asce_limit <= (1UL << 31)) | 121 | if (tlb->mm->context.asce_limit <= (1UL << 31)) |
| @@ -134,7 +136,8 @@ static inline void pmd_free_tlb(struct mmu_gather *tlb, pmd_t *pmd) | |||
| 134 | * as the pgd. pud_free_tlb checks the asce_limit against 4TB | 136 | * as the pgd. pud_free_tlb checks the asce_limit against 4TB |
| 135 | * to avoid the double free of the pud in this case. | 137 | * to avoid the double free of the pud in this case. |
| 136 | */ | 138 | */ |
| 137 | static inline void pud_free_tlb(struct mmu_gather *tlb, pud_t *pud) | 139 | static inline void pud_free_tlb(struct mmu_gather *tlb, pud_t *pud, |
| 140 | unsigned long address) | ||
| 138 | { | 141 | { |
| 139 | #ifdef __s390x__ | 142 | #ifdef __s390x__ |
| 140 | if (tlb->mm->context.asce_limit <= (1UL << 42)) | 143 | if (tlb->mm->context.asce_limit <= (1UL << 42)) |
diff --git a/arch/s390/kernel/early.c b/arch/s390/kernel/early.c index f9b144049dc9..cae14c499511 100644 --- a/arch/s390/kernel/early.c +++ b/arch/s390/kernel/early.c | |||
| @@ -208,9 +208,12 @@ static noinline __init void detect_machine_type(void) | |||
| 208 | machine_flags |= MACHINE_FLAG_KVM; | 208 | machine_flags |= MACHINE_FLAG_KVM; |
| 209 | else | 209 | else |
| 210 | machine_flags |= MACHINE_FLAG_VM; | 210 | machine_flags |= MACHINE_FLAG_VM; |
| 211 | |||
| 212 | /* Store machine flags for setting up lowcore early */ | ||
| 213 | S390_lowcore.machine_flags = machine_flags; | ||
| 211 | } | 214 | } |
| 212 | 215 | ||
| 213 | static void early_pgm_check_handler(void) | 216 | static __init void early_pgm_check_handler(void) |
| 214 | { | 217 | { |
| 215 | unsigned long addr; | 218 | unsigned long addr; |
| 216 | const struct exception_table_entry *fixup; | 219 | const struct exception_table_entry *fixup; |
| @@ -222,7 +225,7 @@ static void early_pgm_check_handler(void) | |||
| 222 | S390_lowcore.program_old_psw.addr = fixup->fixup | PSW_ADDR_AMODE; | 225 | S390_lowcore.program_old_psw.addr = fixup->fixup | PSW_ADDR_AMODE; |
| 223 | } | 226 | } |
| 224 | 227 | ||
| 225 | void setup_lowcore_early(void) | 228 | static noinline __init void setup_lowcore_early(void) |
| 226 | { | 229 | { |
| 227 | psw_t psw; | 230 | psw_t psw; |
| 228 | 231 | ||
diff --git a/arch/s390/kernel/setup.c b/arch/s390/kernel/setup.c index 9717717c6fea..cbb897bc50bd 100644 --- a/arch/s390/kernel/setup.c +++ b/arch/s390/kernel/setup.c | |||
| @@ -154,6 +154,20 @@ static int __init condev_setup(char *str) | |||
| 154 | 154 | ||
| 155 | __setup("condev=", condev_setup); | 155 | __setup("condev=", condev_setup); |
| 156 | 156 | ||
| 157 | static void __init set_preferred_console(void) | ||
| 158 | { | ||
| 159 | if (MACHINE_IS_KVM) { | ||
| 160 | add_preferred_console("hvc", 0, NULL); | ||
| 161 | s390_virtio_console_init(); | ||
| 162 | return; | ||
| 163 | } | ||
| 164 | |||
| 165 | if (CONSOLE_IS_3215 || CONSOLE_IS_SCLP) | ||
| 166 | add_preferred_console("ttyS", 0, NULL); | ||
| 167 | if (CONSOLE_IS_3270) | ||
| 168 | add_preferred_console("tty3270", 0, NULL); | ||
| 169 | } | ||
| 170 | |||
| 157 | static int __init conmode_setup(char *str) | 171 | static int __init conmode_setup(char *str) |
| 158 | { | 172 | { |
| 159 | #if defined(CONFIG_SCLP_CONSOLE) || defined(CONFIG_SCLP_VT220_CONSOLE) | 173 | #if defined(CONFIG_SCLP_CONSOLE) || defined(CONFIG_SCLP_VT220_CONSOLE) |
| @@ -168,6 +182,7 @@ static int __init conmode_setup(char *str) | |||
| 168 | if (strncmp(str, "3270", 5) == 0) | 182 | if (strncmp(str, "3270", 5) == 0) |
| 169 | SET_CONSOLE_3270; | 183 | SET_CONSOLE_3270; |
| 170 | #endif | 184 | #endif |
| 185 | set_preferred_console(); | ||
| 171 | return 1; | 186 | return 1; |
| 172 | } | 187 | } |
| 173 | 188 | ||
| @@ -780,9 +795,6 @@ static void __init setup_hwcaps(void) | |||
| 780 | void __init | 795 | void __init |
| 781 | setup_arch(char **cmdline_p) | 796 | setup_arch(char **cmdline_p) |
| 782 | { | 797 | { |
| 783 | /* set up preferred console */ | ||
| 784 | add_preferred_console("ttyS", 0, NULL); | ||
| 785 | |||
| 786 | /* | 798 | /* |
| 787 | * print what head.S has found out about the machine | 799 | * print what head.S has found out about the machine |
| 788 | */ | 800 | */ |
| @@ -802,11 +814,9 @@ setup_arch(char **cmdline_p) | |||
| 802 | if (MACHINE_IS_VM) | 814 | if (MACHINE_IS_VM) |
| 803 | pr_info("Linux is running as a z/VM " | 815 | pr_info("Linux is running as a z/VM " |
| 804 | "guest operating system in 64-bit mode\n"); | 816 | "guest operating system in 64-bit mode\n"); |
| 805 | else if (MACHINE_IS_KVM) { | 817 | else if (MACHINE_IS_KVM) |
| 806 | pr_info("Linux is running under KVM in 64-bit mode\n"); | 818 | pr_info("Linux is running under KVM in 64-bit mode\n"); |
| 807 | add_preferred_console("hvc", 0, NULL); | 819 | else |
| 808 | s390_virtio_console_init(); | ||
| 809 | } else | ||
| 810 | pr_info("Linux is running natively in 64-bit mode\n"); | 820 | pr_info("Linux is running natively in 64-bit mode\n"); |
| 811 | #endif /* CONFIG_64BIT */ | 821 | #endif /* CONFIG_64BIT */ |
| 812 | 822 | ||
| @@ -851,6 +861,7 @@ setup_arch(char **cmdline_p) | |||
| 851 | 861 | ||
| 852 | /* Setup default console */ | 862 | /* Setup default console */ |
| 853 | conmode_default(); | 863 | conmode_default(); |
| 864 | set_preferred_console(); | ||
| 854 | 865 | ||
| 855 | /* Setup zfcpdump support */ | 866 | /* Setup zfcpdump support */ |
| 856 | setup_zfcpdump(console_devno); | 867 | setup_zfcpdump(console_devno); |
diff --git a/arch/s390/kernel/smp.c b/arch/s390/kernel/smp.c index 2270730f5354..be2cae083406 100644 --- a/arch/s390/kernel/smp.c +++ b/arch/s390/kernel/smp.c | |||
| @@ -687,13 +687,14 @@ void __init smp_prepare_cpus(unsigned int max_cpus) | |||
| 687 | #ifndef CONFIG_64BIT | 687 | #ifndef CONFIG_64BIT |
| 688 | if (MACHINE_HAS_IEEE) | 688 | if (MACHINE_HAS_IEEE) |
| 689 | lowcore->extended_save_area_addr = (u32) save_area; | 689 | lowcore->extended_save_area_addr = (u32) save_area; |
| 690 | #else | ||
| 691 | if (vdso_alloc_per_cpu(smp_processor_id(), lowcore)) | ||
| 692 | BUG(); | ||
| 693 | #endif | 690 | #endif |
| 694 | set_prefix((u32)(unsigned long) lowcore); | 691 | set_prefix((u32)(unsigned long) lowcore); |
| 695 | local_mcck_enable(); | 692 | local_mcck_enable(); |
| 696 | local_irq_enable(); | 693 | local_irq_enable(); |
| 694 | #ifdef CONFIG_64BIT | ||
| 695 | if (vdso_alloc_per_cpu(smp_processor_id(), &S390_lowcore)) | ||
| 696 | BUG(); | ||
| 697 | #endif | ||
| 697 | for_each_possible_cpu(cpu) | 698 | for_each_possible_cpu(cpu) |
| 698 | if (cpu != smp_processor_id()) | 699 | if (cpu != smp_processor_id()) |
| 699 | smp_create_idle(cpu); | 700 | smp_create_idle(cpu); |
diff --git a/arch/s390/kernel/vdso64/clock_gettime.S b/arch/s390/kernel/vdso64/clock_gettime.S index 79dbfee831ec..49106c6e6f88 100644 --- a/arch/s390/kernel/vdso64/clock_gettime.S +++ b/arch/s390/kernel/vdso64/clock_gettime.S | |||
| @@ -88,10 +88,17 @@ __kernel_clock_gettime: | |||
| 88 | llilh %r4,0x0100 | 88 | llilh %r4,0x0100 |
| 89 | sar %a4,%r4 | 89 | sar %a4,%r4 |
| 90 | lghi %r4,0 | 90 | lghi %r4,0 |
| 91 | epsw %r5,0 | ||
| 91 | sacf 512 /* Magic ectg instruction */ | 92 | sacf 512 /* Magic ectg instruction */ |
| 92 | .insn ssf,0xc80100000000,__VDSO_ECTG_BASE(4),__VDSO_ECTG_USER(4),4 | 93 | .insn ssf,0xc80100000000,__VDSO_ECTG_BASE(4),__VDSO_ECTG_USER(4),4 |
| 93 | sacf 0 | 94 | tml %r5,0x4000 |
| 94 | sar %a4,%r2 | 95 | jo 11f |
| 96 | tml %r5,0x8000 | ||
| 97 | jno 10f | ||
| 98 | sacf 256 | ||
| 99 | j 11f | ||
| 100 | 10: sacf 0 | ||
| 101 | 11: sar %a4,%r2 | ||
| 95 | algr %r1,%r0 /* r1 = cputime as TOD value */ | 102 | algr %r1,%r0 /* r1 = cputime as TOD value */ |
| 96 | mghi %r1,1000 /* convert to nanoseconds */ | 103 | mghi %r1,1000 /* convert to nanoseconds */ |
| 97 | srlg %r1,%r1,12 /* r1 = cputime in nanosec */ | 104 | srlg %r1,%r1,12 /* r1 = cputime in nanosec */ |
diff --git a/arch/s390/kvm/interrupt.c b/arch/s390/kvm/interrupt.c index f04f5301b1b4..4d613415c435 100644 --- a/arch/s390/kvm/interrupt.c +++ b/arch/s390/kvm/interrupt.c | |||
| @@ -386,7 +386,7 @@ no_timer: | |||
| 386 | } | 386 | } |
| 387 | __unset_cpu_idle(vcpu); | 387 | __unset_cpu_idle(vcpu); |
| 388 | __set_current_state(TASK_RUNNING); | 388 | __set_current_state(TASK_RUNNING); |
| 389 | remove_wait_queue(&vcpu->wq, &wait); | 389 | remove_wait_queue(&vcpu->arch.local_int.wq, &wait); |
| 390 | spin_unlock_bh(&vcpu->arch.local_int.lock); | 390 | spin_unlock_bh(&vcpu->arch.local_int.lock); |
| 391 | spin_unlock(&vcpu->arch.local_int.float_int->lock); | 391 | spin_unlock(&vcpu->arch.local_int.float_int->lock); |
| 392 | hrtimer_try_to_cancel(&vcpu->arch.ckc_timer); | 392 | hrtimer_try_to_cancel(&vcpu->arch.ckc_timer); |
diff --git a/arch/s390/kvm/sigp.c b/arch/s390/kvm/sigp.c index 36678835034d..0ef81d6776e9 100644 --- a/arch/s390/kvm/sigp.c +++ b/arch/s390/kvm/sigp.c | |||
| @@ -169,7 +169,7 @@ static int __sigp_set_prefix(struct kvm_vcpu *vcpu, u16 cpu_addr, u32 address, | |||
| 169 | unsigned long *reg) | 169 | unsigned long *reg) |
| 170 | { | 170 | { |
| 171 | struct kvm_s390_float_interrupt *fi = &vcpu->kvm->arch.float_int; | 171 | struct kvm_s390_float_interrupt *fi = &vcpu->kvm->arch.float_int; |
| 172 | struct kvm_s390_local_interrupt *li; | 172 | struct kvm_s390_local_interrupt *li = NULL; |
| 173 | struct kvm_s390_interrupt_info *inti; | 173 | struct kvm_s390_interrupt_info *inti; |
| 174 | int rc; | 174 | int rc; |
| 175 | u8 tmp; | 175 | u8 tmp; |
| @@ -189,9 +189,10 @@ static int __sigp_set_prefix(struct kvm_vcpu *vcpu, u16 cpu_addr, u32 address, | |||
| 189 | return 2; /* busy */ | 189 | return 2; /* busy */ |
| 190 | 190 | ||
| 191 | spin_lock(&fi->lock); | 191 | spin_lock(&fi->lock); |
| 192 | li = fi->local_int[cpu_addr]; | 192 | if (cpu_addr < KVM_MAX_VCPUS) |
| 193 | li = fi->local_int[cpu_addr]; | ||
| 193 | 194 | ||
| 194 | if ((cpu_addr >= KVM_MAX_VCPUS) || (li == NULL)) { | 195 | if (li == NULL) { |
| 195 | rc = 1; /* incorrect state */ | 196 | rc = 1; /* incorrect state */ |
| 196 | *reg &= SIGP_STAT_INCORRECT_STATE; | 197 | *reg &= SIGP_STAT_INCORRECT_STATE; |
| 197 | kfree(inti); | 198 | kfree(inti); |
diff --git a/arch/s390/power/swsusp.c b/arch/s390/power/swsusp.c index e6a4fe9f5f24..bd1f5c6b0b8c 100644 --- a/arch/s390/power/swsusp.c +++ b/arch/s390/power/swsusp.c | |||
| @@ -7,24 +7,36 @@ | |||
| 7 | * | 7 | * |
| 8 | */ | 8 | */ |
| 9 | 9 | ||
| 10 | #include <asm/system.h> | ||
| 10 | 11 | ||
| 11 | /* | ||
| 12 | * save CPU registers before creating a hibernation image and before | ||
| 13 | * restoring the memory state from it | ||
| 14 | */ | ||
| 15 | void save_processor_state(void) | 12 | void save_processor_state(void) |
| 16 | { | 13 | { |
| 17 | /* implentation contained in the | 14 | /* swsusp_arch_suspend() actually saves all cpu register contents. |
| 18 | * swsusp_arch_suspend function | 15 | * Machine checks must be disabled since swsusp_arch_suspend() stores |
| 16 | * register contents to their lowcore save areas. That's the same | ||
| 17 | * place where register contents on machine checks would be saved. | ||
| 18 | * To avoid register corruption disable machine checks. | ||
| 19 | * We must also disable machine checks in the new psw mask for | ||
| 20 | * program checks, since swsusp_arch_suspend() may generate program | ||
| 21 | * checks. Disabling machine checks for all other new psw masks is | ||
| 22 | * just paranoia. | ||
| 19 | */ | 23 | */ |
| 24 | local_mcck_disable(); | ||
| 25 | /* Disable lowcore protection */ | ||
| 26 | __ctl_clear_bit(0,28); | ||
| 27 | S390_lowcore.external_new_psw.mask &= ~PSW_MASK_MCHECK; | ||
| 28 | S390_lowcore.svc_new_psw.mask &= ~PSW_MASK_MCHECK; | ||
| 29 | S390_lowcore.io_new_psw.mask &= ~PSW_MASK_MCHECK; | ||
| 30 | S390_lowcore.program_new_psw.mask &= ~PSW_MASK_MCHECK; | ||
| 20 | } | 31 | } |
| 21 | 32 | ||
| 22 | /* | ||
| 23 | * restore the contents of CPU registers | ||
| 24 | */ | ||
| 25 | void restore_processor_state(void) | 33 | void restore_processor_state(void) |
| 26 | { | 34 | { |
| 27 | /* implentation contained in the | 35 | S390_lowcore.external_new_psw.mask |= PSW_MASK_MCHECK; |
| 28 | * swsusp_arch_resume function | 36 | S390_lowcore.svc_new_psw.mask |= PSW_MASK_MCHECK; |
| 29 | */ | 37 | S390_lowcore.io_new_psw.mask |= PSW_MASK_MCHECK; |
| 38 | S390_lowcore.program_new_psw.mask |= PSW_MASK_MCHECK; | ||
| 39 | /* Enable lowcore protection */ | ||
| 40 | __ctl_set_bit(0,28); | ||
| 41 | local_mcck_enable(); | ||
| 30 | } | 42 | } |
diff --git a/arch/s390/power/swsusp_asm64.S b/arch/s390/power/swsusp_asm64.S index 76d688da32fa..b26df5c5933e 100644 --- a/arch/s390/power/swsusp_asm64.S +++ b/arch/s390/power/swsusp_asm64.S | |||
| @@ -32,19 +32,14 @@ swsusp_arch_suspend: | |||
| 32 | /* Deactivate DAT */ | 32 | /* Deactivate DAT */ |
| 33 | stnsm __SF_EMPTY(%r15),0xfb | 33 | stnsm __SF_EMPTY(%r15),0xfb |
| 34 | 34 | ||
| 35 | /* Switch off lowcore protection */ | ||
| 36 | stctg %c0,%c0,__SF_EMPTY(%r15) | ||
| 37 | ni __SF_EMPTY+4(%r15),0xef | ||
| 38 | lctlg %c0,%c0,__SF_EMPTY(%r15) | ||
| 39 | |||
| 40 | /* Store prefix register on stack */ | 35 | /* Store prefix register on stack */ |
| 41 | stpx __SF_EMPTY(%r15) | 36 | stpx __SF_EMPTY(%r15) |
| 42 | 37 | ||
| 43 | /* Setup base register for lowcore (absolute 0) */ | 38 | /* Save prefix register contents for lowcore */ |
| 44 | llgf %r1,__SF_EMPTY(%r15) | 39 | llgf %r4,__SF_EMPTY(%r15) |
| 45 | 40 | ||
| 46 | /* Get pointer to save area */ | 41 | /* Get pointer to save area */ |
| 47 | aghi %r1,0x1000 | 42 | lghi %r1,0x1000 |
| 48 | 43 | ||
| 49 | /* Store registers */ | 44 | /* Store registers */ |
| 50 | mvc 0x318(4,%r1),__SF_EMPTY(%r15) /* move prefix to lowcore */ | 45 | mvc 0x318(4,%r1),__SF_EMPTY(%r15) /* move prefix to lowcore */ |
| @@ -79,17 +74,15 @@ swsusp_arch_suspend: | |||
| 79 | xc __SF_EMPTY(4,%r15),__SF_EMPTY(%r15) | 74 | xc __SF_EMPTY(4,%r15),__SF_EMPTY(%r15) |
| 80 | spx __SF_EMPTY(%r15) | 75 | spx __SF_EMPTY(%r15) |
| 81 | 76 | ||
| 82 | /* Setup lowcore */ | 77 | lghi %r2,0 |
| 83 | brasl %r14,setup_lowcore_early | 78 | lghi %r3,2*PAGE_SIZE |
| 79 | lghi %r5,2*PAGE_SIZE | ||
| 80 | 1: mvcle %r2,%r4,0 | ||
| 81 | jo 1b | ||
| 84 | 82 | ||
| 85 | /* Save image */ | 83 | /* Save image */ |
| 86 | brasl %r14,swsusp_save | 84 | brasl %r14,swsusp_save |
| 87 | 85 | ||
| 88 | /* Switch on lowcore protection */ | ||
| 89 | stctg %c0,%c0,__SF_EMPTY(%r15) | ||
| 90 | oi __SF_EMPTY+4(%r15),0x10 | ||
| 91 | lctlg %c0,%c0,__SF_EMPTY(%r15) | ||
| 92 | |||
| 93 | /* Restore prefix register and return */ | 86 | /* Restore prefix register and return */ |
| 94 | lghi %r1,0x1000 | 87 | lghi %r1,0x1000 |
| 95 | spx 0x318(%r1) | 88 | spx 0x318(%r1) |
| @@ -117,11 +110,6 @@ swsusp_arch_resume: | |||
| 117 | /* Deactivate DAT */ | 110 | /* Deactivate DAT */ |
| 118 | stnsm __SF_EMPTY(%r15),0xfb | 111 | stnsm __SF_EMPTY(%r15),0xfb |
| 119 | 112 | ||
| 120 | /* Switch off lowcore protection */ | ||
| 121 | stctg %c0,%c0,__SF_EMPTY(%r15) | ||
| 122 | ni __SF_EMPTY+4(%r15),0xef | ||
| 123 | lctlg %c0,%c0,__SF_EMPTY(%r15) | ||
| 124 | |||
| 125 | /* Set prefix page to zero */ | 113 | /* Set prefix page to zero */ |
| 126 | xc __SF_EMPTY(4,%r15),__SF_EMPTY(%r15) | 114 | xc __SF_EMPTY(4,%r15),__SF_EMPTY(%r15) |
| 127 | spx __SF_EMPTY(%r15) | 115 | spx __SF_EMPTY(%r15) |
| @@ -175,7 +163,7 @@ swsusp_arch_resume: | |||
| 175 | /* Load old stack */ | 163 | /* Load old stack */ |
| 176 | lg %r15,0x2f8(%r13) | 164 | lg %r15,0x2f8(%r13) |
| 177 | 165 | ||
| 178 | /* Pointer to save arae */ | 166 | /* Pointer to save area */ |
| 179 | lghi %r13,0x1000 | 167 | lghi %r13,0x1000 |
| 180 | 168 | ||
| 181 | #ifdef CONFIG_SMP | 169 | #ifdef CONFIG_SMP |
| @@ -187,11 +175,6 @@ swsusp_arch_resume: | |||
| 187 | /* Restore prefix register */ | 175 | /* Restore prefix register */ |
| 188 | spx 0x318(%r13) | 176 | spx 0x318(%r13) |
| 189 | 177 | ||
| 190 | /* Switch on lowcore protection */ | ||
| 191 | stctg %c0,%c0,__SF_EMPTY(%r15) | ||
| 192 | oi __SF_EMPTY+4(%r15),0x10 | ||
| 193 | lctlg %c0,%c0,__SF_EMPTY(%r15) | ||
| 194 | |||
| 195 | /* Activate DAT */ | 178 | /* Activate DAT */ |
| 196 | stosm __SF_EMPTY(%r15),0x04 | 179 | stosm __SF_EMPTY(%r15),0x04 |
| 197 | 180 | ||
diff --git a/arch/sh/boards/board-ap325rxa.c b/arch/sh/boards/board-ap325rxa.c index 7ffd1b4315bd..b9c88cc519e2 100644 --- a/arch/sh/boards/board-ap325rxa.c +++ b/arch/sh/boards/board-ap325rxa.c | |||
| @@ -547,7 +547,7 @@ static int __init ap325rxa_devices_setup(void) | |||
| 547 | return platform_add_devices(ap325rxa_devices, | 547 | return platform_add_devices(ap325rxa_devices, |
| 548 | ARRAY_SIZE(ap325rxa_devices)); | 548 | ARRAY_SIZE(ap325rxa_devices)); |
| 549 | } | 549 | } |
| 550 | device_initcall(ap325rxa_devices_setup); | 550 | arch_initcall(ap325rxa_devices_setup); |
| 551 | 551 | ||
| 552 | /* Return the board specific boot mode pin configuration */ | 552 | /* Return the board specific boot mode pin configuration */ |
| 553 | static int ap325rxa_mode_pins(void) | 553 | static int ap325rxa_mode_pins(void) |
diff --git a/arch/sh/boards/mach-migor/setup.c b/arch/sh/boards/mach-migor/setup.c index f70f4644deb4..f9b2e4df35b9 100644 --- a/arch/sh/boards/mach-migor/setup.c +++ b/arch/sh/boards/mach-migor/setup.c | |||
| @@ -608,7 +608,7 @@ static int __init migor_devices_setup(void) | |||
| 608 | 608 | ||
| 609 | return platform_add_devices(migor_devices, ARRAY_SIZE(migor_devices)); | 609 | return platform_add_devices(migor_devices, ARRAY_SIZE(migor_devices)); |
| 610 | } | 610 | } |
| 611 | __initcall(migor_devices_setup); | 611 | arch_initcall(migor_devices_setup); |
| 612 | 612 | ||
| 613 | /* Return the board specific boot mode pin configuration */ | 613 | /* Return the board specific boot mode pin configuration */ |
| 614 | static int migor_mode_pins(void) | 614 | static int migor_mode_pins(void) |
diff --git a/arch/sh/boards/mach-se/7724/setup.c b/arch/sh/boards/mach-se/7724/setup.c index 8fed45a2fb85..15456a0773bf 100644 --- a/arch/sh/boards/mach-se/7724/setup.c +++ b/arch/sh/boards/mach-se/7724/setup.c | |||
| @@ -238,7 +238,7 @@ static struct platform_device ceu1_device = { | |||
| 238 | }, | 238 | }, |
| 239 | }; | 239 | }; |
| 240 | 240 | ||
| 241 | /* KEYSC */ | 241 | /* KEYSC in SoC (Needs SW33-2 set to ON) */ |
| 242 | static struct sh_keysc_info keysc_info = { | 242 | static struct sh_keysc_info keysc_info = { |
| 243 | .mode = SH_KEYSC_MODE_1, | 243 | .mode = SH_KEYSC_MODE_1, |
| 244 | .scan_timing = 10, | 244 | .scan_timing = 10, |
| @@ -255,12 +255,13 @@ static struct sh_keysc_info keysc_info = { | |||
| 255 | 255 | ||
| 256 | static struct resource keysc_resources[] = { | 256 | static struct resource keysc_resources[] = { |
| 257 | [0] = { | 257 | [0] = { |
| 258 | .start = 0x1a204000, | 258 | .name = "KEYSC", |
| 259 | .end = 0x1a20400f, | 259 | .start = 0x044b0000, |
| 260 | .end = 0x044b000f, | ||
| 260 | .flags = IORESOURCE_MEM, | 261 | .flags = IORESOURCE_MEM, |
| 261 | }, | 262 | }, |
| 262 | [1] = { | 263 | [1] = { |
| 263 | .start = IRQ0_KEY, | 264 | .start = 79, |
| 264 | .flags = IORESOURCE_IRQ, | 265 | .flags = IORESOURCE_IRQ, |
| 265 | }, | 266 | }, |
| 266 | }; | 267 | }; |
diff --git a/arch/sh/include/asm/pgalloc.h b/arch/sh/include/asm/pgalloc.h index 84dd2db7104c..63ca37bd9a95 100644 --- a/arch/sh/include/asm/pgalloc.h +++ b/arch/sh/include/asm/pgalloc.h | |||
| @@ -73,20 +73,12 @@ static inline void pte_free(struct mm_struct *mm, pgtable_t pte) | |||
| 73 | quicklist_free_page(QUICK_PT, NULL, pte); | 73 | quicklist_free_page(QUICK_PT, NULL, pte); |
| 74 | } | 74 | } |
| 75 | 75 | ||
| 76 | #define __pte_free_tlb(tlb,pte) \ | 76 | #define __pte_free_tlb(tlb,pte,addr) \ |
| 77 | do { \ | 77 | do { \ |
| 78 | pgtable_page_dtor(pte); \ | 78 | pgtable_page_dtor(pte); \ |
| 79 | tlb_remove_page((tlb), (pte)); \ | 79 | tlb_remove_page((tlb), (pte)); \ |
| 80 | } while (0) | 80 | } while (0) |
| 81 | 81 | ||
| 82 | /* | ||
| 83 | * allocating and freeing a pmd is trivial: the 1-entry pmd is | ||
| 84 | * inside the pgd, so has no extra memory associated with it. | ||
| 85 | */ | ||
| 86 | |||
| 87 | #define pmd_free(mm, x) do { } while (0) | ||
| 88 | #define __pmd_free_tlb(tlb,x) do { } while (0) | ||
| 89 | |||
| 90 | static inline void check_pgt_cache(void) | 82 | static inline void check_pgt_cache(void) |
| 91 | { | 83 | { |
| 92 | quicklist_trim(QUICK_PGD, NULL, 25, 16); | 84 | quicklist_trim(QUICK_PGD, NULL, 25, 16); |
diff --git a/arch/sh/include/asm/tlb.h b/arch/sh/include/asm/tlb.h index 9c16f737074a..da8fe7ab8728 100644 --- a/arch/sh/include/asm/tlb.h +++ b/arch/sh/include/asm/tlb.h | |||
| @@ -91,9 +91,9 @@ tlb_end_vma(struct mmu_gather *tlb, struct vm_area_struct *vma) | |||
| 91 | } | 91 | } |
| 92 | 92 | ||
| 93 | #define tlb_remove_page(tlb,page) free_page_and_swap_cache(page) | 93 | #define tlb_remove_page(tlb,page) free_page_and_swap_cache(page) |
| 94 | #define pte_free_tlb(tlb, ptep) pte_free((tlb)->mm, ptep) | 94 | #define pte_free_tlb(tlb, ptep, addr) pte_free((tlb)->mm, ptep) |
| 95 | #define pmd_free_tlb(tlb, pmdp) pmd_free((tlb)->mm, pmdp) | 95 | #define pmd_free_tlb(tlb, pmdp, addr) pmd_free((tlb)->mm, pmdp) |
| 96 | #define pud_free_tlb(tlb, pudp) pud_free((tlb)->mm, pudp) | 96 | #define pud_free_tlb(tlb, pudp, addr) pud_free((tlb)->mm, pudp) |
| 97 | 97 | ||
| 98 | #define tlb_migrate_finish(mm) do { } while (0) | 98 | #define tlb_migrate_finish(mm) do { } while (0) |
| 99 | 99 | ||
diff --git a/arch/sh/kernel/cpu/sh2/setup-sh7619.c b/arch/sh/kernel/cpu/sh2/setup-sh7619.c index 13798733f2db..8555c05e8667 100644 --- a/arch/sh/kernel/cpu/sh2/setup-sh7619.c +++ b/arch/sh/kernel/cpu/sh2/setup-sh7619.c | |||
| @@ -187,7 +187,7 @@ static int __init sh7619_devices_setup(void) | |||
| 187 | return platform_add_devices(sh7619_devices, | 187 | return platform_add_devices(sh7619_devices, |
| 188 | ARRAY_SIZE(sh7619_devices)); | 188 | ARRAY_SIZE(sh7619_devices)); |
| 189 | } | 189 | } |
| 190 | __initcall(sh7619_devices_setup); | 190 | arch_initcall(sh7619_devices_setup); |
| 191 | 191 | ||
| 192 | void __init plat_irq_setup(void) | 192 | void __init plat_irq_setup(void) |
| 193 | { | 193 | { |
diff --git a/arch/sh/kernel/cpu/sh2a/setup-mxg.c b/arch/sh/kernel/cpu/sh2a/setup-mxg.c index 869c2da4820b..b67376445315 100644 --- a/arch/sh/kernel/cpu/sh2a/setup-mxg.c +++ b/arch/sh/kernel/cpu/sh2a/setup-mxg.c | |||
| @@ -238,7 +238,7 @@ static int __init mxg_devices_setup(void) | |||
| 238 | return platform_add_devices(mxg_devices, | 238 | return platform_add_devices(mxg_devices, |
| 239 | ARRAY_SIZE(mxg_devices)); | 239 | ARRAY_SIZE(mxg_devices)); |
| 240 | } | 240 | } |
| 241 | __initcall(mxg_devices_setup); | 241 | arch_initcall(mxg_devices_setup); |
| 242 | 242 | ||
| 243 | void __init plat_irq_setup(void) | 243 | void __init plat_irq_setup(void) |
| 244 | { | 244 | { |
diff --git a/arch/sh/kernel/cpu/sh2a/setup-sh7201.c b/arch/sh/kernel/cpu/sh2a/setup-sh7201.c index d8febe128066..fbde5b75deb9 100644 --- a/arch/sh/kernel/cpu/sh2a/setup-sh7201.c +++ b/arch/sh/kernel/cpu/sh2a/setup-sh7201.c | |||
| @@ -357,7 +357,7 @@ static int __init sh7201_devices_setup(void) | |||
| 357 | return platform_add_devices(sh7201_devices, | 357 | return platform_add_devices(sh7201_devices, |
| 358 | ARRAY_SIZE(sh7201_devices)); | 358 | ARRAY_SIZE(sh7201_devices)); |
| 359 | } | 359 | } |
| 360 | __initcall(sh7201_devices_setup); | 360 | arch_initcall(sh7201_devices_setup); |
| 361 | 361 | ||
| 362 | void __init plat_irq_setup(void) | 362 | void __init plat_irq_setup(void) |
| 363 | { | 363 | { |
diff --git a/arch/sh/kernel/cpu/sh2a/setup-sh7203.c b/arch/sh/kernel/cpu/sh2a/setup-sh7203.c index 62e3039d2398..d3fd536c9a84 100644 --- a/arch/sh/kernel/cpu/sh2a/setup-sh7203.c +++ b/arch/sh/kernel/cpu/sh2a/setup-sh7203.c | |||
| @@ -367,7 +367,7 @@ static int __init sh7203_devices_setup(void) | |||
| 367 | return platform_add_devices(sh7203_devices, | 367 | return platform_add_devices(sh7203_devices, |
| 368 | ARRAY_SIZE(sh7203_devices)); | 368 | ARRAY_SIZE(sh7203_devices)); |
| 369 | } | 369 | } |
| 370 | __initcall(sh7203_devices_setup); | 370 | arch_initcall(sh7203_devices_setup); |
| 371 | 371 | ||
| 372 | void __init plat_irq_setup(void) | 372 | void __init plat_irq_setup(void) |
| 373 | { | 373 | { |
diff --git a/arch/sh/kernel/cpu/sh2a/setup-sh7206.c b/arch/sh/kernel/cpu/sh2a/setup-sh7206.c index 3e6f3d7a58be..a9ccc5e8d9e9 100644 --- a/arch/sh/kernel/cpu/sh2a/setup-sh7206.c +++ b/arch/sh/kernel/cpu/sh2a/setup-sh7206.c | |||
| @@ -338,7 +338,7 @@ static int __init sh7206_devices_setup(void) | |||
| 338 | return platform_add_devices(sh7206_devices, | 338 | return platform_add_devices(sh7206_devices, |
| 339 | ARRAY_SIZE(sh7206_devices)); | 339 | ARRAY_SIZE(sh7206_devices)); |
| 340 | } | 340 | } |
| 341 | __initcall(sh7206_devices_setup); | 341 | arch_initcall(sh7206_devices_setup); |
| 342 | 342 | ||
| 343 | void __init plat_irq_setup(void) | 343 | void __init plat_irq_setup(void) |
| 344 | { | 344 | { |
diff --git a/arch/sh/kernel/cpu/sh3/setup-sh7705.c b/arch/sh/kernel/cpu/sh3/setup-sh7705.c index 88f742fed9ed..c23105983878 100644 --- a/arch/sh/kernel/cpu/sh3/setup-sh7705.c +++ b/arch/sh/kernel/cpu/sh3/setup-sh7705.c | |||
| @@ -222,7 +222,7 @@ static int __init sh7705_devices_setup(void) | |||
| 222 | return platform_add_devices(sh7705_devices, | 222 | return platform_add_devices(sh7705_devices, |
| 223 | ARRAY_SIZE(sh7705_devices)); | 223 | ARRAY_SIZE(sh7705_devices)); |
| 224 | } | 224 | } |
| 225 | __initcall(sh7705_devices_setup); | 225 | arch_initcall(sh7705_devices_setup); |
| 226 | 226 | ||
| 227 | static struct platform_device *sh7705_early_devices[] __initdata = { | 227 | static struct platform_device *sh7705_early_devices[] __initdata = { |
| 228 | &tmu0_device, | 228 | &tmu0_device, |
diff --git a/arch/sh/kernel/cpu/sh3/setup-sh770x.c b/arch/sh/kernel/cpu/sh3/setup-sh770x.c index c56306798584..347ab35d0697 100644 --- a/arch/sh/kernel/cpu/sh3/setup-sh770x.c +++ b/arch/sh/kernel/cpu/sh3/setup-sh770x.c | |||
| @@ -250,7 +250,7 @@ static int __init sh770x_devices_setup(void) | |||
| 250 | return platform_add_devices(sh770x_devices, | 250 | return platform_add_devices(sh770x_devices, |
| 251 | ARRAY_SIZE(sh770x_devices)); | 251 | ARRAY_SIZE(sh770x_devices)); |
| 252 | } | 252 | } |
| 253 | __initcall(sh770x_devices_setup); | 253 | arch_initcall(sh770x_devices_setup); |
| 254 | 254 | ||
| 255 | static struct platform_device *sh770x_early_devices[] __initdata = { | 255 | static struct platform_device *sh770x_early_devices[] __initdata = { |
| 256 | &tmu0_device, | 256 | &tmu0_device, |
diff --git a/arch/sh/kernel/cpu/sh3/setup-sh7710.c b/arch/sh/kernel/cpu/sh3/setup-sh7710.c index efa76c8148f4..717e90ae1097 100644 --- a/arch/sh/kernel/cpu/sh3/setup-sh7710.c +++ b/arch/sh/kernel/cpu/sh3/setup-sh7710.c | |||
| @@ -226,7 +226,7 @@ static int __init sh7710_devices_setup(void) | |||
| 226 | return platform_add_devices(sh7710_devices, | 226 | return platform_add_devices(sh7710_devices, |
| 227 | ARRAY_SIZE(sh7710_devices)); | 227 | ARRAY_SIZE(sh7710_devices)); |
| 228 | } | 228 | } |
| 229 | __initcall(sh7710_devices_setup); | 229 | arch_initcall(sh7710_devices_setup); |
| 230 | 230 | ||
| 231 | static struct platform_device *sh7710_early_devices[] __initdata = { | 231 | static struct platform_device *sh7710_early_devices[] __initdata = { |
| 232 | &tmu0_device, | 232 | &tmu0_device, |
diff --git a/arch/sh/kernel/cpu/sh3/setup-sh7720.c b/arch/sh/kernel/cpu/sh3/setup-sh7720.c index 5b2107798edb..74d8baaf8e96 100644 --- a/arch/sh/kernel/cpu/sh3/setup-sh7720.c +++ b/arch/sh/kernel/cpu/sh3/setup-sh7720.c | |||
| @@ -388,7 +388,7 @@ static int __init sh7720_devices_setup(void) | |||
| 388 | return platform_add_devices(sh7720_devices, | 388 | return platform_add_devices(sh7720_devices, |
| 389 | ARRAY_SIZE(sh7720_devices)); | 389 | ARRAY_SIZE(sh7720_devices)); |
| 390 | } | 390 | } |
| 391 | __initcall(sh7720_devices_setup); | 391 | arch_initcall(sh7720_devices_setup); |
| 392 | 392 | ||
| 393 | static struct platform_device *sh7720_early_devices[] __initdata = { | 393 | static struct platform_device *sh7720_early_devices[] __initdata = { |
| 394 | &cmt0_device, | 394 | &cmt0_device, |
diff --git a/arch/sh/kernel/cpu/sh4/setup-sh4-202.c b/arch/sh/kernel/cpu/sh4/setup-sh4-202.c index 6d088d123591..de4827df19aa 100644 --- a/arch/sh/kernel/cpu/sh4/setup-sh4-202.c +++ b/arch/sh/kernel/cpu/sh4/setup-sh4-202.c | |||
| @@ -138,7 +138,7 @@ static int __init sh4202_devices_setup(void) | |||
| 138 | return platform_add_devices(sh4202_devices, | 138 | return platform_add_devices(sh4202_devices, |
| 139 | ARRAY_SIZE(sh4202_devices)); | 139 | ARRAY_SIZE(sh4202_devices)); |
| 140 | } | 140 | } |
| 141 | __initcall(sh4202_devices_setup); | 141 | arch_initcall(sh4202_devices_setup); |
| 142 | 142 | ||
| 143 | static struct platform_device *sh4202_early_devices[] __initdata = { | 143 | static struct platform_device *sh4202_early_devices[] __initdata = { |
| 144 | &tmu0_device, | 144 | &tmu0_device, |
diff --git a/arch/sh/kernel/cpu/sh4/setup-sh7750.c b/arch/sh/kernel/cpu/sh4/setup-sh7750.c index 851672d15cf4..1b8b122e8f3d 100644 --- a/arch/sh/kernel/cpu/sh4/setup-sh7750.c +++ b/arch/sh/kernel/cpu/sh4/setup-sh7750.c | |||
| @@ -239,7 +239,7 @@ static int __init sh7750_devices_setup(void) | |||
| 239 | return platform_add_devices(sh7750_devices, | 239 | return platform_add_devices(sh7750_devices, |
| 240 | ARRAY_SIZE(sh7750_devices)); | 240 | ARRAY_SIZE(sh7750_devices)); |
| 241 | } | 241 | } |
| 242 | __initcall(sh7750_devices_setup); | 242 | arch_initcall(sh7750_devices_setup); |
| 243 | 243 | ||
| 244 | static struct platform_device *sh7750_early_devices[] __initdata = { | 244 | static struct platform_device *sh7750_early_devices[] __initdata = { |
| 245 | &tmu0_device, | 245 | &tmu0_device, |
diff --git a/arch/sh/kernel/cpu/sh4/setup-sh7760.c b/arch/sh/kernel/cpu/sh4/setup-sh7760.c index 5b822519bd90..7fbb7be9284c 100644 --- a/arch/sh/kernel/cpu/sh4/setup-sh7760.c +++ b/arch/sh/kernel/cpu/sh4/setup-sh7760.c | |||
| @@ -265,7 +265,7 @@ static int __init sh7760_devices_setup(void) | |||
| 265 | return platform_add_devices(sh7760_devices, | 265 | return platform_add_devices(sh7760_devices, |
| 266 | ARRAY_SIZE(sh7760_devices)); | 266 | ARRAY_SIZE(sh7760_devices)); |
| 267 | } | 267 | } |
| 268 | __initcall(sh7760_devices_setup); | 268 | arch_initcall(sh7760_devices_setup); |
| 269 | 269 | ||
| 270 | static struct platform_device *sh7760_early_devices[] __initdata = { | 270 | static struct platform_device *sh7760_early_devices[] __initdata = { |
| 271 | &tmu0_device, | 271 | &tmu0_device, |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7343.c b/arch/sh/kernel/cpu/sh4a/setup-sh7343.c index 6307e087c864..ac4d5672ec1a 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7343.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7343.c | |||
| @@ -325,7 +325,7 @@ static int __init sh7343_devices_setup(void) | |||
| 325 | return platform_add_devices(sh7343_devices, | 325 | return platform_add_devices(sh7343_devices, |
| 326 | ARRAY_SIZE(sh7343_devices)); | 326 | ARRAY_SIZE(sh7343_devices)); |
| 327 | } | 327 | } |
| 328 | __initcall(sh7343_devices_setup); | 328 | arch_initcall(sh7343_devices_setup); |
| 329 | 329 | ||
| 330 | static struct platform_device *sh7343_early_devices[] __initdata = { | 330 | static struct platform_device *sh7343_early_devices[] __initdata = { |
| 331 | &cmt_device, | 331 | &cmt_device, |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7366.c b/arch/sh/kernel/cpu/sh4a/setup-sh7366.c index c18f7d09281b..1a956b1beccc 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7366.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7366.c | |||
| @@ -318,7 +318,7 @@ static int __init sh7366_devices_setup(void) | |||
| 318 | return platform_add_devices(sh7366_devices, | 318 | return platform_add_devices(sh7366_devices, |
| 319 | ARRAY_SIZE(sh7366_devices)); | 319 | ARRAY_SIZE(sh7366_devices)); |
| 320 | } | 320 | } |
| 321 | __initcall(sh7366_devices_setup); | 321 | arch_initcall(sh7366_devices_setup); |
| 322 | 322 | ||
| 323 | static struct platform_device *sh7366_early_devices[] __initdata = { | 323 | static struct platform_device *sh7366_early_devices[] __initdata = { |
| 324 | &cmt_device, | 324 | &cmt_device, |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7722.c b/arch/sh/kernel/cpu/sh4a/setup-sh7722.c index ea524a2da3e4..cda76ebf87c3 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7722.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7722.c | |||
| @@ -359,7 +359,7 @@ static int __init sh7722_devices_setup(void) | |||
| 359 | return platform_add_devices(sh7722_devices, | 359 | return platform_add_devices(sh7722_devices, |
| 360 | ARRAY_SIZE(sh7722_devices)); | 360 | ARRAY_SIZE(sh7722_devices)); |
| 361 | } | 361 | } |
| 362 | __initcall(sh7722_devices_setup); | 362 | arch_initcall(sh7722_devices_setup); |
| 363 | 363 | ||
| 364 | static struct platform_device *sh7722_early_devices[] __initdata = { | 364 | static struct platform_device *sh7722_early_devices[] __initdata = { |
| 365 | &cmt_device, | 365 | &cmt_device, |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7723.c b/arch/sh/kernel/cpu/sh4a/setup-sh7723.c index e1bb80b2a27b..b45dace9539f 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7723.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7723.c | |||
| @@ -473,7 +473,7 @@ static int __init sh7723_devices_setup(void) | |||
| 473 | return platform_add_devices(sh7723_devices, | 473 | return platform_add_devices(sh7723_devices, |
| 474 | ARRAY_SIZE(sh7723_devices)); | 474 | ARRAY_SIZE(sh7723_devices)); |
| 475 | } | 475 | } |
| 476 | __initcall(sh7723_devices_setup); | 476 | arch_initcall(sh7723_devices_setup); |
| 477 | 477 | ||
| 478 | static struct platform_device *sh7723_early_devices[] __initdata = { | 478 | static struct platform_device *sh7723_early_devices[] __initdata = { |
| 479 | &cmt_device, | 479 | &cmt_device, |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7724.c b/arch/sh/kernel/cpu/sh4a/setup-sh7724.c index e5ac9eb11c63..a04edaab9a29 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7724.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7724.c | |||
| @@ -508,7 +508,7 @@ static int __init sh7724_devices_setup(void) | |||
| 508 | return platform_add_devices(sh7724_devices, | 508 | return platform_add_devices(sh7724_devices, |
| 509 | ARRAY_SIZE(sh7724_devices)); | 509 | ARRAY_SIZE(sh7724_devices)); |
| 510 | } | 510 | } |
| 511 | device_initcall(sh7724_devices_setup); | 511 | arch_initcall(sh7724_devices_setup); |
| 512 | 512 | ||
| 513 | static struct platform_device *sh7724_early_devices[] __initdata = { | 513 | static struct platform_device *sh7724_early_devices[] __initdata = { |
| 514 | &cmt_device, | 514 | &cmt_device, |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7763.c b/arch/sh/kernel/cpu/sh4a/setup-sh7763.c index f1e0c0d36da7..4659fff6b842 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7763.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7763.c | |||
| @@ -314,7 +314,7 @@ static int __init sh7763_devices_setup(void) | |||
| 314 | return platform_add_devices(sh7763_devices, | 314 | return platform_add_devices(sh7763_devices, |
| 315 | ARRAY_SIZE(sh7763_devices)); | 315 | ARRAY_SIZE(sh7763_devices)); |
| 316 | } | 316 | } |
| 317 | __initcall(sh7763_devices_setup); | 317 | arch_initcall(sh7763_devices_setup); |
| 318 | 318 | ||
| 319 | static struct platform_device *sh7763_early_devices[] __initdata = { | 319 | static struct platform_device *sh7763_early_devices[] __initdata = { |
| 320 | &tmu0_device, | 320 | &tmu0_device, |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7770.c b/arch/sh/kernel/cpu/sh4a/setup-sh7770.c index 1e86209db284..eead08d89d32 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7770.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7770.c | |||
| @@ -368,7 +368,7 @@ static int __init sh7770_devices_setup(void) | |||
| 368 | return platform_add_devices(sh7770_devices, | 368 | return platform_add_devices(sh7770_devices, |
| 369 | ARRAY_SIZE(sh7770_devices)); | 369 | ARRAY_SIZE(sh7770_devices)); |
| 370 | } | 370 | } |
| 371 | __initcall(sh7770_devices_setup); | 371 | arch_initcall(sh7770_devices_setup); |
| 372 | 372 | ||
| 373 | static struct platform_device *sh7770_early_devices[] __initdata = { | 373 | static struct platform_device *sh7770_early_devices[] __initdata = { |
| 374 | &tmu0_device, | 374 | &tmu0_device, |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7780.c b/arch/sh/kernel/cpu/sh4a/setup-sh7780.c index 715e05b431e5..2c901f446959 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7780.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7780.c | |||
| @@ -256,7 +256,7 @@ static int __init sh7780_devices_setup(void) | |||
| 256 | return platform_add_devices(sh7780_devices, | 256 | return platform_add_devices(sh7780_devices, |
| 257 | ARRAY_SIZE(sh7780_devices)); | 257 | ARRAY_SIZE(sh7780_devices)); |
| 258 | } | 258 | } |
| 259 | __initcall(sh7780_devices_setup); | 259 | arch_initcall(sh7780_devices_setup); |
| 260 | 260 | ||
| 261 | static struct platform_device *sh7780_early_devices[] __initdata = { | 261 | static struct platform_device *sh7780_early_devices[] __initdata = { |
| 262 | &tmu0_device, | 262 | &tmu0_device, |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7785.c b/arch/sh/kernel/cpu/sh4a/setup-sh7785.c index af561402570b..7f6c718b6c36 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7785.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7785.c | |||
| @@ -263,7 +263,7 @@ static int __init sh7785_devices_setup(void) | |||
| 263 | return platform_add_devices(sh7785_devices, | 263 | return platform_add_devices(sh7785_devices, |
| 264 | ARRAY_SIZE(sh7785_devices)); | 264 | ARRAY_SIZE(sh7785_devices)); |
| 265 | } | 265 | } |
| 266 | __initcall(sh7785_devices_setup); | 266 | arch_initcall(sh7785_devices_setup); |
| 267 | 267 | ||
| 268 | static struct platform_device *sh7785_early_devices[] __initdata = { | 268 | static struct platform_device *sh7785_early_devices[] __initdata = { |
| 269 | &tmu0_device, | 269 | &tmu0_device, |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7786.c b/arch/sh/kernel/cpu/sh4a/setup-sh7786.c index b70049470a0b..0104a8ec5369 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7786.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7786.c | |||
| @@ -547,7 +547,7 @@ static int __init sh7786_devices_setup(void) | |||
| 547 | return platform_add_devices(sh7786_devices, | 547 | return platform_add_devices(sh7786_devices, |
| 548 | ARRAY_SIZE(sh7786_devices)); | 548 | ARRAY_SIZE(sh7786_devices)); |
| 549 | } | 549 | } |
| 550 | device_initcall(sh7786_devices_setup); | 550 | arch_initcall(sh7786_devices_setup); |
| 551 | 551 | ||
| 552 | void __init plat_early_device_setup(void) | 552 | void __init plat_early_device_setup(void) |
| 553 | { | 553 | { |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-shx3.c b/arch/sh/kernel/cpu/sh4a/setup-shx3.c index 53c65fd9ccef..07f078961c71 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-shx3.c +++ b/arch/sh/kernel/cpu/sh4a/setup-shx3.c | |||
| @@ -256,7 +256,7 @@ static int __init shx3_devices_setup(void) | |||
| 256 | return platform_add_devices(shx3_devices, | 256 | return platform_add_devices(shx3_devices, |
| 257 | ARRAY_SIZE(shx3_devices)); | 257 | ARRAY_SIZE(shx3_devices)); |
| 258 | } | 258 | } |
| 259 | __initcall(shx3_devices_setup); | 259 | arch_initcall(shx3_devices_setup); |
| 260 | 260 | ||
| 261 | void __init plat_early_device_setup(void) | 261 | void __init plat_early_device_setup(void) |
| 262 | { | 262 | { |
diff --git a/arch/sh/kernel/cpu/sh5/setup-sh5.c b/arch/sh/kernel/cpu/sh5/setup-sh5.c index f5ff1ac57fc2..6a0f82f70032 100644 --- a/arch/sh/kernel/cpu/sh5/setup-sh5.c +++ b/arch/sh/kernel/cpu/sh5/setup-sh5.c | |||
| @@ -186,7 +186,7 @@ static int __init sh5_devices_setup(void) | |||
| 186 | return platform_add_devices(sh5_devices, | 186 | return platform_add_devices(sh5_devices, |
| 187 | ARRAY_SIZE(sh5_devices)); | 187 | ARRAY_SIZE(sh5_devices)); |
| 188 | } | 188 | } |
| 189 | __initcall(sh5_devices_setup); | 189 | arch_initcall(sh5_devices_setup); |
| 190 | 190 | ||
| 191 | void __init plat_early_device_setup(void) | 191 | void __init plat_early_device_setup(void) |
| 192 | { | 192 | { |
diff --git a/arch/sh/kernel/cpu/shmobile/sleep.S b/arch/sh/kernel/cpu/shmobile/sleep.S index 5d888ef53d82..baf2d7d46b05 100644 --- a/arch/sh/kernel/cpu/shmobile/sleep.S +++ b/arch/sh/kernel/cpu/shmobile/sleep.S | |||
| @@ -26,8 +26,30 @@ ENTRY(sh_mobile_standby) | |||
| 26 | 26 | ||
| 27 | tst #SUSP_SH_SF, r0 | 27 | tst #SUSP_SH_SF, r0 |
| 28 | bt skip_set_sf | 28 | bt skip_set_sf |
| 29 | #ifdef CONFIG_CPU_SUBTYPE_SH7724 | ||
| 30 | /* DBSC: put memory in self-refresh mode */ | ||
| 29 | 31 | ||
| 30 | /* SDRAM: disable power down and put in self-refresh mode */ | 32 | mov.l dben_reg, r4 |
| 33 | mov.l dben_data0, r1 | ||
| 34 | mov.l r1, @r4 | ||
| 35 | |||
| 36 | mov.l dbrfpdn0_reg, r4 | ||
| 37 | mov.l dbrfpdn0_data0, r1 | ||
| 38 | mov.l r1, @r4 | ||
| 39 | |||
| 40 | mov.l dbcmdcnt_reg, r4 | ||
| 41 | mov.l dbcmdcnt_data0, r1 | ||
| 42 | mov.l r1, @r4 | ||
| 43 | |||
| 44 | mov.l dbcmdcnt_reg, r4 | ||
| 45 | mov.l dbcmdcnt_data1, r1 | ||
| 46 | mov.l r1, @r4 | ||
| 47 | |||
| 48 | mov.l dbrfpdn0_reg, r4 | ||
| 49 | mov.l dbrfpdn0_data1, r1 | ||
| 50 | mov.l r1, @r4 | ||
| 51 | #else | ||
| 52 | /* SBSC: disable power down and put in self-refresh mode */ | ||
| 31 | mov.l 1f, r4 | 53 | mov.l 1f, r4 |
| 32 | mov.l 2f, r1 | 54 | mov.l 2f, r1 |
| 33 | mov.l @r4, r2 | 55 | mov.l @r4, r2 |
| @@ -35,6 +57,7 @@ ENTRY(sh_mobile_standby) | |||
| 35 | mov.l 3f, r3 | 57 | mov.l 3f, r3 |
| 36 | and r3, r2 | 58 | and r3, r2 |
| 37 | mov.l r2, @r4 | 59 | mov.l r2, @r4 |
| 60 | #endif | ||
| 38 | 61 | ||
| 39 | skip_set_sf: | 62 | skip_set_sf: |
| 40 | tst #SUSP_SH_SLEEP, r0 | 63 | tst #SUSP_SH_SLEEP, r0 |
| @@ -84,7 +107,36 @@ done_sleep: | |||
| 84 | tst #SUSP_SH_SF, r0 | 107 | tst #SUSP_SH_SF, r0 |
| 85 | bt skip_restore_sf | 108 | bt skip_restore_sf |
| 86 | 109 | ||
| 87 | /* SDRAM: set auto-refresh mode */ | 110 | #ifdef CONFIG_CPU_SUBTYPE_SH7724 |
| 111 | /* DBSC: put memory in auto-refresh mode */ | ||
| 112 | |||
| 113 | mov.l dbrfpdn0_reg, r4 | ||
| 114 | mov.l dbrfpdn0_data0, r1 | ||
| 115 | mov.l r1, @r4 | ||
| 116 | |||
| 117 | /* sleep 140 ns */ | ||
| 118 | nop | ||
| 119 | nop | ||
| 120 | nop | ||
| 121 | nop | ||
| 122 | |||
| 123 | mov.l dbcmdcnt_reg, r4 | ||
| 124 | mov.l dbcmdcnt_data0, r1 | ||
| 125 | mov.l r1, @r4 | ||
| 126 | |||
| 127 | mov.l dbcmdcnt_reg, r4 | ||
| 128 | mov.l dbcmdcnt_data1, r1 | ||
| 129 | mov.l r1, @r4 | ||
| 130 | |||
| 131 | mov.l dben_reg, r4 | ||
| 132 | mov.l dben_data1, r1 | ||
| 133 | mov.l r1, @r4 | ||
| 134 | |||
| 135 | mov.l dbrfpdn0_reg, r4 | ||
| 136 | mov.l dbrfpdn0_data2, r1 | ||
| 137 | mov.l r1, @r4 | ||
| 138 | #else | ||
| 139 | /* SBSC: set auto-refresh mode */ | ||
| 88 | mov.l 1f, r4 | 140 | mov.l 1f, r4 |
| 89 | mov.l @r4, r2 | 141 | mov.l @r4, r2 |
| 90 | mov.l 4f, r3 | 142 | mov.l 4f, r3 |
| @@ -98,15 +150,29 @@ done_sleep: | |||
| 98 | add r4, r3 | 150 | add r4, r3 |
| 99 | or r2, r3 | 151 | or r2, r3 |
| 100 | mov.l r3, @r1 | 152 | mov.l r3, @r1 |
| 153 | #endif | ||
| 101 | skip_restore_sf: | 154 | skip_restore_sf: |
| 102 | rts | 155 | rts |
| 103 | nop | 156 | nop |
| 104 | 157 | ||
| 105 | .balign 4 | 158 | .balign 4 |
| 159 | #ifdef CONFIG_CPU_SUBTYPE_SH7724 | ||
| 160 | dben_reg: .long 0xfd000010 /* DBEN */ | ||
| 161 | dben_data0: .long 0 | ||
| 162 | dben_data1: .long 1 | ||
| 163 | dbrfpdn0_reg: .long 0xfd000040 /* DBRFPDN0 */ | ||
| 164 | dbrfpdn0_data0: .long 0 | ||
| 165 | dbrfpdn0_data1: .long 1 | ||
| 166 | dbrfpdn0_data2: .long 0x00010000 | ||
| 167 | dbcmdcnt_reg: .long 0xfd000014 /* DBCMDCNT */ | ||
| 168 | dbcmdcnt_data0: .long 2 | ||
| 169 | dbcmdcnt_data1: .long 4 | ||
| 170 | #else | ||
| 106 | 1: .long 0xfe400008 /* SDCR0 */ | 171 | 1: .long 0xfe400008 /* SDCR0 */ |
| 107 | 2: .long 0x00000400 | 172 | 2: .long 0x00000400 |
| 108 | 3: .long 0xffff7fff | 173 | 3: .long 0xffff7fff |
| 109 | 4: .long 0xfffffbff | 174 | 4: .long 0xfffffbff |
| 175 | #endif | ||
| 110 | 5: .long 0xa4150020 /* STBCR */ | 176 | 5: .long 0xa4150020 /* STBCR */ |
| 111 | 6: .long 0xfe40001c /* RTCOR */ | 177 | 6: .long 0xfe40001c /* RTCOR */ |
| 112 | 7: .long 0xfe400018 /* RTCNT */ | 178 | 7: .long 0xfe400018 /* RTCNT */ |
diff --git a/arch/sparc/configs/sparc32_defconfig b/arch/sparc/configs/sparc32_defconfig index 8bcd27af724b..a0f62a808edb 100644 --- a/arch/sparc/configs/sparc32_defconfig +++ b/arch/sparc/configs/sparc32_defconfig | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30-rc2 | 3 | # Linux kernel version: 2.6.31-rc1 |
| 4 | # Fri Apr 17 04:04:46 2009 | 4 | # Tue Aug 18 23:45:52 2009 |
| 5 | # | 5 | # |
| 6 | # CONFIG_64BIT is not set | 6 | # CONFIG_64BIT is not set |
| 7 | CONFIG_SPARC=y | 7 | CONFIG_SPARC=y |
| @@ -17,6 +17,7 @@ CONFIG_GENERIC_ISA_DMA=y | |||
| 17 | CONFIG_ARCH_NO_VIRT_TO_BUS=y | 17 | CONFIG_ARCH_NO_VIRT_TO_BUS=y |
| 18 | CONFIG_OF=y | 18 | CONFIG_OF=y |
| 19 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 19 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 20 | CONFIG_CONSTRUCTORS=y | ||
| 20 | 21 | ||
| 21 | # | 22 | # |
| 22 | # General setup | 23 | # General setup |
| @@ -74,7 +75,6 @@ CONFIG_SYSCTL_SYSCALL=y | |||
| 74 | CONFIG_KALLSYMS=y | 75 | CONFIG_KALLSYMS=y |
| 75 | # CONFIG_KALLSYMS_ALL is not set | 76 | # CONFIG_KALLSYMS_ALL is not set |
| 76 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 77 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 77 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 78 | CONFIG_HOTPLUG=y | 78 | CONFIG_HOTPLUG=y |
| 79 | CONFIG_PRINTK=y | 79 | CONFIG_PRINTK=y |
| 80 | CONFIG_BUG=y | 80 | CONFIG_BUG=y |
| @@ -87,8 +87,13 @@ CONFIG_TIMERFD=y | |||
| 87 | CONFIG_EVENTFD=y | 87 | CONFIG_EVENTFD=y |
| 88 | CONFIG_SHMEM=y | 88 | CONFIG_SHMEM=y |
| 89 | CONFIG_AIO=y | 89 | CONFIG_AIO=y |
| 90 | |||
| 91 | # | ||
| 92 | # Performance Counters | ||
| 93 | # | ||
| 90 | CONFIG_VM_EVENT_COUNTERS=y | 94 | CONFIG_VM_EVENT_COUNTERS=y |
| 91 | CONFIG_PCI_QUIRKS=y | 95 | CONFIG_PCI_QUIRKS=y |
| 96 | # CONFIG_STRIP_ASM_SYMS is not set | ||
| 92 | CONFIG_COMPAT_BRK=y | 97 | CONFIG_COMPAT_BRK=y |
| 93 | CONFIG_SLAB=y | 98 | CONFIG_SLAB=y |
| 94 | # CONFIG_SLUB is not set | 99 | # CONFIG_SLUB is not set |
| @@ -97,6 +102,10 @@ CONFIG_SLAB=y | |||
| 97 | # CONFIG_MARKERS is not set | 102 | # CONFIG_MARKERS is not set |
| 98 | CONFIG_HAVE_OPROFILE=y | 103 | CONFIG_HAVE_OPROFILE=y |
| 99 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 104 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 105 | |||
| 106 | # | ||
| 107 | # GCOV-based kernel profiling | ||
| 108 | # | ||
| 100 | # CONFIG_SLOW_WORK is not set | 109 | # CONFIG_SLOW_WORK is not set |
| 101 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 110 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 102 | CONFIG_SLABINFO=y | 111 | CONFIG_SLABINFO=y |
| @@ -109,7 +118,7 @@ CONFIG_MODULE_UNLOAD=y | |||
| 109 | # CONFIG_MODVERSIONS is not set | 118 | # CONFIG_MODVERSIONS is not set |
| 110 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 119 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
| 111 | CONFIG_BLOCK=y | 120 | CONFIG_BLOCK=y |
| 112 | # CONFIG_LBD is not set | 121 | CONFIG_LBDAF=y |
| 113 | # CONFIG_BLK_DEV_BSG is not set | 122 | # CONFIG_BLK_DEV_BSG is not set |
| 114 | # CONFIG_BLK_DEV_INTEGRITY is not set | 123 | # CONFIG_BLK_DEV_INTEGRITY is not set |
| 115 | 124 | ||
| @@ -154,9 +163,9 @@ CONFIG_SPLIT_PTLOCK_CPUS=4 | |||
| 154 | # CONFIG_PHYS_ADDR_T_64BIT is not set | 163 | # CONFIG_PHYS_ADDR_T_64BIT is not set |
| 155 | CONFIG_ZONE_DMA_FLAG=1 | 164 | CONFIG_ZONE_DMA_FLAG=1 |
| 156 | CONFIG_BOUNCE=y | 165 | CONFIG_BOUNCE=y |
| 157 | CONFIG_UNEVICTABLE_LRU=y | ||
| 158 | CONFIG_HAVE_MLOCK=y | 166 | CONFIG_HAVE_MLOCK=y |
| 159 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 167 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 168 | CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 | ||
| 160 | CONFIG_SUN_PM=y | 169 | CONFIG_SUN_PM=y |
| 161 | # CONFIG_SPARC_LED is not set | 170 | # CONFIG_SPARC_LED is not set |
| 162 | CONFIG_SERIAL_CONSOLE=y | 171 | CONFIG_SERIAL_CONSOLE=y |
| @@ -264,6 +273,7 @@ CONFIG_IPV6_TUNNEL=m | |||
| 264 | # CONFIG_ECONET is not set | 273 | # CONFIG_ECONET is not set |
| 265 | # CONFIG_WAN_ROUTER is not set | 274 | # CONFIG_WAN_ROUTER is not set |
| 266 | # CONFIG_PHONET is not set | 275 | # CONFIG_PHONET is not set |
| 276 | # CONFIG_IEEE802154 is not set | ||
| 267 | # CONFIG_NET_SCHED is not set | 277 | # CONFIG_NET_SCHED is not set |
| 268 | # CONFIG_DCB is not set | 278 | # CONFIG_DCB is not set |
| 269 | 279 | ||
| @@ -281,7 +291,11 @@ CONFIG_WIRELESS=y | |||
| 281 | CONFIG_WIRELESS_OLD_REGULATORY=y | 291 | CONFIG_WIRELESS_OLD_REGULATORY=y |
| 282 | # CONFIG_WIRELESS_EXT is not set | 292 | # CONFIG_WIRELESS_EXT is not set |
| 283 | # CONFIG_LIB80211 is not set | 293 | # CONFIG_LIB80211 is not set |
| 284 | # CONFIG_MAC80211 is not set | 294 | |
| 295 | # | ||
| 296 | # CFG80211 needs to be enabled for MAC80211 | ||
| 297 | # | ||
| 298 | CONFIG_MAC80211_DEFAULT_PS_VALUE=0 | ||
| 285 | # CONFIG_WIMAX is not set | 299 | # CONFIG_WIMAX is not set |
| 286 | # CONFIG_RFKILL is not set | 300 | # CONFIG_RFKILL is not set |
| 287 | # CONFIG_NET_9P is not set | 301 | # CONFIG_NET_9P is not set |
| @@ -335,6 +349,7 @@ CONFIG_MISC_DEVICES=y | |||
| 335 | # EEPROM support | 349 | # EEPROM support |
| 336 | # | 350 | # |
| 337 | # CONFIG_EEPROM_93CX6 is not set | 351 | # CONFIG_EEPROM_93CX6 is not set |
| 352 | # CONFIG_CB710_CORE is not set | ||
| 338 | CONFIG_HAVE_IDE=y | 353 | CONFIG_HAVE_IDE=y |
| 339 | # CONFIG_IDE is not set | 354 | # CONFIG_IDE is not set |
| 340 | 355 | ||
| @@ -358,10 +373,6 @@ CONFIG_BLK_DEV_SR=m | |||
| 358 | # CONFIG_BLK_DEV_SR_VENDOR is not set | 373 | # CONFIG_BLK_DEV_SR_VENDOR is not set |
| 359 | CONFIG_CHR_DEV_SG=m | 374 | CONFIG_CHR_DEV_SG=m |
| 360 | # CONFIG_CHR_DEV_SCH is not set | 375 | # CONFIG_CHR_DEV_SCH is not set |
| 361 | |||
| 362 | # | ||
| 363 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 364 | # | ||
| 365 | # CONFIG_SCSI_MULTI_LUN is not set | 376 | # CONFIG_SCSI_MULTI_LUN is not set |
| 366 | # CONFIG_SCSI_CONSTANTS is not set | 377 | # CONFIG_SCSI_CONSTANTS is not set |
| 367 | # CONFIG_SCSI_LOGGING is not set | 378 | # CONFIG_SCSI_LOGGING is not set |
| @@ -379,6 +390,7 @@ CONFIG_SCSI_SPI_ATTRS=y | |||
| 379 | CONFIG_SCSI_LOWLEVEL=y | 390 | CONFIG_SCSI_LOWLEVEL=y |
| 380 | # CONFIG_ISCSI_TCP is not set | 391 | # CONFIG_ISCSI_TCP is not set |
| 381 | # CONFIG_SCSI_CXGB3_ISCSI is not set | 392 | # CONFIG_SCSI_CXGB3_ISCSI is not set |
| 393 | # CONFIG_SCSI_BNX2_ISCSI is not set | ||
| 382 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 394 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
| 383 | # CONFIG_SCSI_3W_9XXX is not set | 395 | # CONFIG_SCSI_3W_9XXX is not set |
| 384 | # CONFIG_SCSI_ACARD is not set | 396 | # CONFIG_SCSI_ACARD is not set |
| @@ -387,6 +399,7 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 387 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 399 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
| 388 | # CONFIG_SCSI_AIC79XX is not set | 400 | # CONFIG_SCSI_AIC79XX is not set |
| 389 | # CONFIG_SCSI_AIC94XX is not set | 401 | # CONFIG_SCSI_AIC94XX is not set |
| 402 | # CONFIG_SCSI_MVSAS is not set | ||
| 390 | # CONFIG_SCSI_ARCMSR is not set | 403 | # CONFIG_SCSI_ARCMSR is not set |
| 391 | # CONFIG_MEGARAID_NEWGEN is not set | 404 | # CONFIG_MEGARAID_NEWGEN is not set |
| 392 | # CONFIG_MEGARAID_LEGACY is not set | 405 | # CONFIG_MEGARAID_LEGACY is not set |
| @@ -401,7 +414,6 @@ CONFIG_SCSI_LOWLEVEL=y | |||
| 401 | # CONFIG_SCSI_IPS is not set | 414 | # CONFIG_SCSI_IPS is not set |
| 402 | # CONFIG_SCSI_INITIO is not set | 415 | # CONFIG_SCSI_INITIO is not set |
| 403 | # CONFIG_SCSI_INIA100 is not set | 416 | # CONFIG_SCSI_INIA100 is not set |
| 404 | # CONFIG_SCSI_MVSAS is not set | ||
| 405 | # CONFIG_SCSI_STEX is not set | 417 | # CONFIG_SCSI_STEX is not set |
| 406 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 418 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 407 | # CONFIG_SCSI_QLOGIC_1280 is not set | 419 | # CONFIG_SCSI_QLOGIC_1280 is not set |
| @@ -426,13 +438,16 @@ CONFIG_SCSI_SUNESP=y | |||
| 426 | # | 438 | # |
| 427 | 439 | ||
| 428 | # | 440 | # |
| 429 | # Enable only one of the two stacks, unless you know what you are doing | 441 | # You can enable one or both FireWire driver stacks. |
| 442 | # | ||
| 443 | |||
| 444 | # | ||
| 445 | # See the help texts for more information. | ||
| 430 | # | 446 | # |
| 431 | # CONFIG_FIREWIRE is not set | 447 | # CONFIG_FIREWIRE is not set |
| 432 | # CONFIG_IEEE1394 is not set | 448 | # CONFIG_IEEE1394 is not set |
| 433 | # CONFIG_I2O is not set | 449 | # CONFIG_I2O is not set |
| 434 | CONFIG_NETDEVICES=y | 450 | CONFIG_NETDEVICES=y |
| 435 | CONFIG_COMPAT_NET_DEV_OPS=y | ||
| 436 | CONFIG_DUMMY=m | 451 | CONFIG_DUMMY=m |
| 437 | # CONFIG_BONDING is not set | 452 | # CONFIG_BONDING is not set |
| 438 | # CONFIG_MACVLAN is not set | 453 | # CONFIG_MACVLAN is not set |
| @@ -463,6 +478,7 @@ CONFIG_SUNQE=m | |||
| 463 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 478 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 464 | # CONFIG_NET_PCI is not set | 479 | # CONFIG_NET_PCI is not set |
| 465 | # CONFIG_B44 is not set | 480 | # CONFIG_B44 is not set |
| 481 | # CONFIG_KS8842 is not set | ||
| 466 | # CONFIG_ATL2 is not set | 482 | # CONFIG_ATL2 is not set |
| 467 | CONFIG_NETDEV_1000=y | 483 | CONFIG_NETDEV_1000=y |
| 468 | # CONFIG_ACENIC is not set | 484 | # CONFIG_ACENIC is not set |
| @@ -482,6 +498,7 @@ CONFIG_NETDEV_1000=y | |||
| 482 | # CONFIG_VIA_VELOCITY is not set | 498 | # CONFIG_VIA_VELOCITY is not set |
| 483 | # CONFIG_TIGON3 is not set | 499 | # CONFIG_TIGON3 is not set |
| 484 | # CONFIG_BNX2 is not set | 500 | # CONFIG_BNX2 is not set |
| 501 | # CONFIG_CNIC is not set | ||
| 485 | # CONFIG_QLA3XXX is not set | 502 | # CONFIG_QLA3XXX is not set |
| 486 | # CONFIG_ATL1 is not set | 503 | # CONFIG_ATL1 is not set |
| 487 | # CONFIG_ATL1E is not set | 504 | # CONFIG_ATL1E is not set |
| @@ -629,6 +646,11 @@ CONFIG_HW_RANDOM=m | |||
| 629 | CONFIG_DEVPORT=y | 646 | CONFIG_DEVPORT=y |
| 630 | # CONFIG_I2C is not set | 647 | # CONFIG_I2C is not set |
| 631 | # CONFIG_SPI is not set | 648 | # CONFIG_SPI is not set |
| 649 | |||
| 650 | # | ||
| 651 | # PPS support | ||
| 652 | # | ||
| 653 | # CONFIG_PPS is not set | ||
| 632 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 654 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 633 | # CONFIG_GPIOLIB is not set | 655 | # CONFIG_GPIOLIB is not set |
| 634 | # CONFIG_W1 is not set | 656 | # CONFIG_W1 is not set |
| @@ -668,22 +690,7 @@ CONFIG_SSB_POSSIBLE=y | |||
| 668 | # CONFIG_HTC_PASIC3 is not set | 690 | # CONFIG_HTC_PASIC3 is not set |
| 669 | # CONFIG_MFD_TMIO is not set | 691 | # CONFIG_MFD_TMIO is not set |
| 670 | # CONFIG_REGULATOR is not set | 692 | # CONFIG_REGULATOR is not set |
| 671 | 693 | # CONFIG_MEDIA_SUPPORT is not set | |
| 672 | # | ||
| 673 | # Multimedia devices | ||
| 674 | # | ||
| 675 | |||
| 676 | # | ||
| 677 | # Multimedia core support | ||
| 678 | # | ||
| 679 | # CONFIG_VIDEO_DEV is not set | ||
| 680 | # CONFIG_DVB_CORE is not set | ||
| 681 | # CONFIG_VIDEO_MEDIA is not set | ||
| 682 | |||
| 683 | # | ||
| 684 | # Multimedia drivers | ||
| 685 | # | ||
| 686 | # CONFIG_DAB is not set | ||
| 687 | 694 | ||
| 688 | # | 695 | # |
| 689 | # Graphics support | 696 | # Graphics support |
| @@ -776,6 +783,10 @@ CONFIG_RTC_DRV_M48T59=y | |||
| 776 | # CONFIG_DMADEVICES is not set | 783 | # CONFIG_DMADEVICES is not set |
| 777 | # CONFIG_AUXDISPLAY is not set | 784 | # CONFIG_AUXDISPLAY is not set |
| 778 | # CONFIG_UIO is not set | 785 | # CONFIG_UIO is not set |
| 786 | |||
| 787 | # | ||
| 788 | # TI VLYNQ | ||
| 789 | # | ||
| 779 | # CONFIG_STAGING is not set | 790 | # CONFIG_STAGING is not set |
| 780 | 791 | ||
| 781 | # | 792 | # |
| @@ -799,10 +810,12 @@ CONFIG_FS_MBCACHE=y | |||
| 799 | # CONFIG_REISERFS_FS is not set | 810 | # CONFIG_REISERFS_FS is not set |
| 800 | # CONFIG_JFS_FS is not set | 811 | # CONFIG_JFS_FS is not set |
| 801 | CONFIG_FS_POSIX_ACL=y | 812 | CONFIG_FS_POSIX_ACL=y |
| 802 | CONFIG_FILE_LOCKING=y | ||
| 803 | # CONFIG_XFS_FS is not set | 813 | # CONFIG_XFS_FS is not set |
| 814 | # CONFIG_GFS2_FS is not set | ||
| 804 | # CONFIG_OCFS2_FS is not set | 815 | # CONFIG_OCFS2_FS is not set |
| 805 | # CONFIG_BTRFS_FS is not set | 816 | # CONFIG_BTRFS_FS is not set |
| 817 | CONFIG_FILE_LOCKING=y | ||
| 818 | CONFIG_FSNOTIFY=y | ||
| 806 | CONFIG_DNOTIFY=y | 819 | CONFIG_DNOTIFY=y |
| 807 | CONFIG_INOTIFY=y | 820 | CONFIG_INOTIFY=y |
| 808 | CONFIG_INOTIFY_USER=y | 821 | CONFIG_INOTIFY_USER=y |
| @@ -985,6 +998,7 @@ CONFIG_KGDB=y | |||
| 985 | CONFIG_KGDB_SERIAL_CONSOLE=y | 998 | CONFIG_KGDB_SERIAL_CONSOLE=y |
| 986 | CONFIG_KGDB_TESTS=y | 999 | CONFIG_KGDB_TESTS=y |
| 987 | # CONFIG_KGDB_TESTS_ON_BOOT is not set | 1000 | # CONFIG_KGDB_TESTS_ON_BOOT is not set |
| 1001 | # CONFIG_KMEMCHECK is not set | ||
| 988 | # CONFIG_DEBUG_STACK_USAGE is not set | 1002 | # CONFIG_DEBUG_STACK_USAGE is not set |
| 989 | # CONFIG_STACK_DEBUG is not set | 1003 | # CONFIG_STACK_DEBUG is not set |
| 990 | 1004 | ||
diff --git a/arch/sparc/configs/sparc64_defconfig b/arch/sparc/configs/sparc64_defconfig index 0123a4c596ce..fdddf7a6f725 100644 --- a/arch/sparc/configs/sparc64_defconfig +++ b/arch/sparc/configs/sparc64_defconfig | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.30 | 3 | # Linux kernel version: 2.6.31-rc1 |
| 4 | # Tue Jun 16 04:59:36 2009 | 4 | # Tue Aug 18 23:56:02 2009 |
| 5 | # | 5 | # |
| 6 | CONFIG_64BIT=y | 6 | CONFIG_64BIT=y |
| 7 | CONFIG_SPARC=y | 7 | CONFIG_SPARC=y |
| @@ -26,6 +26,7 @@ CONFIG_ARCH_NO_VIRT_TO_BUS=y | |||
| 26 | CONFIG_OF=y | 26 | CONFIG_OF=y |
| 27 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y | 27 | CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y |
| 28 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 28 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 29 | CONFIG_CONSTRUCTORS=y | ||
| 29 | 30 | ||
| 30 | # | 31 | # |
| 31 | # General setup | 32 | # General setup |
| @@ -119,6 +120,11 @@ CONFIG_HAVE_KPROBES=y | |||
| 119 | CONFIG_HAVE_KRETPROBES=y | 120 | CONFIG_HAVE_KRETPROBES=y |
| 120 | CONFIG_HAVE_ARCH_TRACEHOOK=y | 121 | CONFIG_HAVE_ARCH_TRACEHOOK=y |
| 121 | CONFIG_USE_GENERIC_SMP_HELPERS=y | 122 | CONFIG_USE_GENERIC_SMP_HELPERS=y |
| 123 | |||
| 124 | # | ||
| 125 | # GCOV-based kernel profiling | ||
| 126 | # | ||
| 127 | # CONFIG_GCOV_KERNEL is not set | ||
| 122 | # CONFIG_SLOW_WORK is not set | 128 | # CONFIG_SLOW_WORK is not set |
| 123 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set | 129 | # CONFIG_HAVE_GENERIC_DMA_COHERENT is not set |
| 124 | CONFIG_SLABINFO=y | 130 | CONFIG_SLABINFO=y |
| @@ -204,7 +210,6 @@ CONFIG_MIGRATION=y | |||
| 204 | CONFIG_PHYS_ADDR_T_64BIT=y | 210 | CONFIG_PHYS_ADDR_T_64BIT=y |
| 205 | CONFIG_ZONE_DMA_FLAG=0 | 211 | CONFIG_ZONE_DMA_FLAG=0 |
| 206 | CONFIG_NR_QUICK=1 | 212 | CONFIG_NR_QUICK=1 |
| 207 | CONFIG_UNEVICTABLE_LRU=y | ||
| 208 | CONFIG_HAVE_MLOCK=y | 213 | CONFIG_HAVE_MLOCK=y |
| 209 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | 214 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y |
| 210 | CONFIG_DEFAULT_MMAP_MIN_ADDR=8192 | 215 | CONFIG_DEFAULT_MMAP_MIN_ADDR=8192 |
| @@ -410,6 +415,7 @@ CONFIG_MISC_DEVICES=y | |||
| 410 | # | 415 | # |
| 411 | # CONFIG_EEPROM_AT24 is not set | 416 | # CONFIG_EEPROM_AT24 is not set |
| 412 | # CONFIG_EEPROM_LEGACY is not set | 417 | # CONFIG_EEPROM_LEGACY is not set |
| 418 | # CONFIG_EEPROM_MAX6875 is not set | ||
| 413 | # CONFIG_EEPROM_93CX6 is not set | 419 | # CONFIG_EEPROM_93CX6 is not set |
| 414 | # CONFIG_CB710_CORE is not set | 420 | # CONFIG_CB710_CORE is not set |
| 415 | CONFIG_HAVE_IDE=y | 421 | CONFIG_HAVE_IDE=y |
| @@ -562,6 +568,7 @@ CONFIG_BLK_DEV_DM=m | |||
| 562 | CONFIG_DM_CRYPT=m | 568 | CONFIG_DM_CRYPT=m |
| 563 | CONFIG_DM_SNAPSHOT=m | 569 | CONFIG_DM_SNAPSHOT=m |
| 564 | CONFIG_DM_MIRROR=m | 570 | CONFIG_DM_MIRROR=m |
| 571 | # CONFIG_DM_LOG_USERSPACE is not set | ||
| 565 | CONFIG_DM_ZERO=m | 572 | CONFIG_DM_ZERO=m |
| 566 | # CONFIG_DM_MULTIPATH is not set | 573 | # CONFIG_DM_MULTIPATH is not set |
| 567 | # CONFIG_DM_DELAY is not set | 574 | # CONFIG_DM_DELAY is not set |
| @@ -573,7 +580,11 @@ CONFIG_DM_ZERO=m | |||
| 573 | # | 580 | # |
| 574 | 581 | ||
| 575 | # | 582 | # |
| 576 | # Enable only one of the two stacks, unless you know what you are doing | 583 | # You can enable one or both FireWire driver stacks. |
| 584 | # | ||
| 585 | |||
| 586 | # | ||
| 587 | # See the help texts for more information. | ||
| 577 | # | 588 | # |
| 578 | # CONFIG_FIREWIRE is not set | 589 | # CONFIG_FIREWIRE is not set |
| 579 | # CONFIG_IEEE1394 is not set | 590 | # CONFIG_IEEE1394 is not set |
| @@ -667,6 +678,7 @@ CONFIG_E1000E=m | |||
| 667 | # CONFIG_VIA_VELOCITY is not set | 678 | # CONFIG_VIA_VELOCITY is not set |
| 668 | CONFIG_TIGON3=m | 679 | CONFIG_TIGON3=m |
| 669 | CONFIG_BNX2=m | 680 | CONFIG_BNX2=m |
| 681 | # CONFIG_CNIC is not set | ||
| 670 | # CONFIG_QLA3XXX is not set | 682 | # CONFIG_QLA3XXX is not set |
| 671 | # CONFIG_ATL1 is not set | 683 | # CONFIG_ATL1 is not set |
| 672 | # CONFIG_ATL1E is not set | 684 | # CONFIG_ATL1E is not set |
| @@ -773,6 +785,7 @@ CONFIG_MOUSE_SERIAL=y | |||
| 773 | # CONFIG_MOUSE_APPLETOUCH is not set | 785 | # CONFIG_MOUSE_APPLETOUCH is not set |
| 774 | # CONFIG_MOUSE_BCM5974 is not set | 786 | # CONFIG_MOUSE_BCM5974 is not set |
| 775 | # CONFIG_MOUSE_VSXXXAA is not set | 787 | # CONFIG_MOUSE_VSXXXAA is not set |
| 788 | # CONFIG_MOUSE_SYNAPTICS_I2C is not set | ||
| 776 | # CONFIG_INPUT_JOYSTICK is not set | 789 | # CONFIG_INPUT_JOYSTICK is not set |
| 777 | # CONFIG_INPUT_TABLET is not set | 790 | # CONFIG_INPUT_TABLET is not set |
| 778 | # CONFIG_INPUT_TOUCHSCREEN is not set | 791 | # CONFIG_INPUT_TOUCHSCREEN is not set |
| @@ -870,6 +883,7 @@ CONFIG_I2C_ALGOBIT=y | |||
| 870 | # | 883 | # |
| 871 | # I2C system bus drivers (mostly embedded / system-on-chip) | 884 | # I2C system bus drivers (mostly embedded / system-on-chip) |
| 872 | # | 885 | # |
| 886 | # CONFIG_I2C_DESIGNWARE is not set | ||
| 873 | # CONFIG_I2C_OCORES is not set | 887 | # CONFIG_I2C_OCORES is not set |
| 874 | # CONFIG_I2C_SIMTEC is not set | 888 | # CONFIG_I2C_SIMTEC is not set |
| 875 | 889 | ||
| @@ -898,13 +912,17 @@ CONFIG_I2C_ALGOBIT=y | |||
| 898 | # CONFIG_SENSORS_PCF8574 is not set | 912 | # CONFIG_SENSORS_PCF8574 is not set |
| 899 | # CONFIG_PCF8575 is not set | 913 | # CONFIG_PCF8575 is not set |
| 900 | # CONFIG_SENSORS_PCA9539 is not set | 914 | # CONFIG_SENSORS_PCA9539 is not set |
| 901 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 902 | # CONFIG_SENSORS_TSL2550 is not set | 915 | # CONFIG_SENSORS_TSL2550 is not set |
| 903 | # CONFIG_I2C_DEBUG_CORE is not set | 916 | # CONFIG_I2C_DEBUG_CORE is not set |
| 904 | # CONFIG_I2C_DEBUG_ALGO is not set | 917 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 905 | # CONFIG_I2C_DEBUG_BUS is not set | 918 | # CONFIG_I2C_DEBUG_BUS is not set |
| 906 | # CONFIG_I2C_DEBUG_CHIP is not set | 919 | # CONFIG_I2C_DEBUG_CHIP is not set |
| 907 | # CONFIG_SPI is not set | 920 | # CONFIG_SPI is not set |
| 921 | |||
| 922 | # | ||
| 923 | # PPS support | ||
| 924 | # | ||
| 925 | # CONFIG_PPS is not set | ||
| 908 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | 926 | CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y |
| 909 | # CONFIG_GPIOLIB is not set | 927 | # CONFIG_GPIOLIB is not set |
| 910 | # CONFIG_W1 is not set | 928 | # CONFIG_W1 is not set |
| @@ -959,6 +977,7 @@ CONFIG_HWMON=y | |||
| 959 | # CONFIG_SENSORS_SMSC47B397 is not set | 977 | # CONFIG_SENSORS_SMSC47B397 is not set |
| 960 | # CONFIG_SENSORS_ADS7828 is not set | 978 | # CONFIG_SENSORS_ADS7828 is not set |
| 961 | # CONFIG_SENSORS_THMC50 is not set | 979 | # CONFIG_SENSORS_THMC50 is not set |
| 980 | # CONFIG_SENSORS_TMP401 is not set | ||
| 962 | # CONFIG_SENSORS_VIA686A is not set | 981 | # CONFIG_SENSORS_VIA686A is not set |
| 963 | # CONFIG_SENSORS_VT1211 is not set | 982 | # CONFIG_SENSORS_VT1211 is not set |
| 964 | # CONFIG_SENSORS_VT8231 is not set | 983 | # CONFIG_SENSORS_VT8231 is not set |
| @@ -994,23 +1013,9 @@ CONFIG_SSB_POSSIBLE=y | |||
| 994 | # CONFIG_MFD_WM8400 is not set | 1013 | # CONFIG_MFD_WM8400 is not set |
| 995 | # CONFIG_MFD_WM8350_I2C is not set | 1014 | # CONFIG_MFD_WM8350_I2C is not set |
| 996 | # CONFIG_MFD_PCF50633 is not set | 1015 | # CONFIG_MFD_PCF50633 is not set |
| 1016 | # CONFIG_AB3100_CORE is not set | ||
| 997 | # CONFIG_REGULATOR is not set | 1017 | # CONFIG_REGULATOR is not set |
| 998 | 1018 | # CONFIG_MEDIA_SUPPORT is not set | |
| 999 | # | ||
| 1000 | # Multimedia devices | ||
| 1001 | # | ||
| 1002 | |||
| 1003 | # | ||
| 1004 | # Multimedia core support | ||
| 1005 | # | ||
| 1006 | # CONFIG_VIDEO_DEV is not set | ||
| 1007 | # CONFIG_DVB_CORE is not set | ||
| 1008 | # CONFIG_VIDEO_MEDIA is not set | ||
| 1009 | |||
| 1010 | # | ||
| 1011 | # Multimedia drivers | ||
| 1012 | # | ||
| 1013 | # CONFIG_DAB is not set | ||
| 1014 | 1019 | ||
| 1015 | # | 1020 | # |
| 1016 | # Graphics support | 1021 | # Graphics support |
| @@ -1284,7 +1289,6 @@ CONFIG_USB=y | |||
| 1284 | # | 1289 | # |
| 1285 | # Miscellaneous USB options | 1290 | # Miscellaneous USB options |
| 1286 | # | 1291 | # |
| 1287 | CONFIG_USB_DEVICEFS=y | ||
| 1288 | # CONFIG_USB_DEVICE_CLASS is not set | 1292 | # CONFIG_USB_DEVICE_CLASS is not set |
| 1289 | # CONFIG_USB_DYNAMIC_MINORS is not set | 1293 | # CONFIG_USB_DYNAMIC_MINORS is not set |
| 1290 | # CONFIG_USB_OTG is not set | 1294 | # CONFIG_USB_OTG is not set |
| @@ -1296,6 +1300,7 @@ CONFIG_USB_DEVICEFS=y | |||
| 1296 | # USB Host Controller Drivers | 1300 | # USB Host Controller Drivers |
| 1297 | # | 1301 | # |
| 1298 | # CONFIG_USB_C67X00_HCD is not set | 1302 | # CONFIG_USB_C67X00_HCD is not set |
| 1303 | # CONFIG_USB_XHCI_HCD is not set | ||
| 1299 | CONFIG_USB_EHCI_HCD=m | 1304 | CONFIG_USB_EHCI_HCD=m |
| 1300 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set | 1305 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set |
| 1301 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 1306 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
| @@ -1374,7 +1379,6 @@ CONFIG_USB_STORAGE=m | |||
| 1374 | # CONFIG_USB_LD is not set | 1379 | # CONFIG_USB_LD is not set |
| 1375 | # CONFIG_USB_TRANCEVIBRATOR is not set | 1380 | # CONFIG_USB_TRANCEVIBRATOR is not set |
| 1376 | # CONFIG_USB_IOWARRIOR is not set | 1381 | # CONFIG_USB_IOWARRIOR is not set |
| 1377 | # CONFIG_USB_TEST is not set | ||
| 1378 | # CONFIG_USB_ISIGHTFW is not set | 1382 | # CONFIG_USB_ISIGHTFW is not set |
| 1379 | # CONFIG_USB_VST is not set | 1383 | # CONFIG_USB_VST is not set |
| 1380 | # CONFIG_USB_GADGET is not set | 1384 | # CONFIG_USB_GADGET is not set |
| @@ -1420,6 +1424,7 @@ CONFIG_RTC_INTF_DEV=y | |||
| 1420 | # CONFIG_RTC_DRV_S35390A is not set | 1424 | # CONFIG_RTC_DRV_S35390A is not set |
| 1421 | # CONFIG_RTC_DRV_FM3130 is not set | 1425 | # CONFIG_RTC_DRV_FM3130 is not set |
| 1422 | # CONFIG_RTC_DRV_RX8581 is not set | 1426 | # CONFIG_RTC_DRV_RX8581 is not set |
| 1427 | # CONFIG_RTC_DRV_RX8025 is not set | ||
| 1423 | 1428 | ||
| 1424 | # | 1429 | # |
| 1425 | # SPI RTC drivers | 1430 | # SPI RTC drivers |
| @@ -1448,6 +1453,10 @@ CONFIG_RTC_DRV_STARFIRE=y | |||
| 1448 | # CONFIG_DMADEVICES is not set | 1453 | # CONFIG_DMADEVICES is not set |
| 1449 | # CONFIG_AUXDISPLAY is not set | 1454 | # CONFIG_AUXDISPLAY is not set |
| 1450 | # CONFIG_UIO is not set | 1455 | # CONFIG_UIO is not set |
| 1456 | |||
| 1457 | # | ||
| 1458 | # TI VLYNQ | ||
| 1459 | # | ||
| 1451 | # CONFIG_STAGING is not set | 1460 | # CONFIG_STAGING is not set |
| 1452 | 1461 | ||
| 1453 | # | 1462 | # |
| @@ -1480,11 +1489,11 @@ CONFIG_FS_MBCACHE=y | |||
| 1480 | # CONFIG_REISERFS_FS is not set | 1489 | # CONFIG_REISERFS_FS is not set |
| 1481 | # CONFIG_JFS_FS is not set | 1490 | # CONFIG_JFS_FS is not set |
| 1482 | CONFIG_FS_POSIX_ACL=y | 1491 | CONFIG_FS_POSIX_ACL=y |
| 1483 | CONFIG_FILE_LOCKING=y | ||
| 1484 | # CONFIG_XFS_FS is not set | 1492 | # CONFIG_XFS_FS is not set |
| 1485 | # CONFIG_GFS2_FS is not set | 1493 | # CONFIG_GFS2_FS is not set |
| 1486 | # CONFIG_OCFS2_FS is not set | 1494 | # CONFIG_OCFS2_FS is not set |
| 1487 | # CONFIG_BTRFS_FS is not set | 1495 | # CONFIG_BTRFS_FS is not set |
| 1496 | CONFIG_FILE_LOCKING=y | ||
| 1488 | CONFIG_FSNOTIFY=y | 1497 | CONFIG_FSNOTIFY=y |
| 1489 | CONFIG_DNOTIFY=y | 1498 | CONFIG_DNOTIFY=y |
| 1490 | CONFIG_INOTIFY=y | 1499 | CONFIG_INOTIFY=y |
| @@ -1560,7 +1569,7 @@ CONFIG_NETWORK_FILESYSTEMS=y | |||
| 1560 | # CONFIG_PARTITION_ADVANCED is not set | 1569 | # CONFIG_PARTITION_ADVANCED is not set |
| 1561 | CONFIG_MSDOS_PARTITION=y | 1570 | CONFIG_MSDOS_PARTITION=y |
| 1562 | CONFIG_SUN_PARTITION=y | 1571 | CONFIG_SUN_PARTITION=y |
| 1563 | CONFIG_NLS=m | 1572 | CONFIG_NLS=y |
| 1564 | CONFIG_NLS_DEFAULT="iso8859-1" | 1573 | CONFIG_NLS_DEFAULT="iso8859-1" |
| 1565 | # CONFIG_NLS_CODEPAGE_437 is not set | 1574 | # CONFIG_NLS_CODEPAGE_437 is not set |
| 1566 | # CONFIG_NLS_CODEPAGE_737 is not set | 1575 | # CONFIG_NLS_CODEPAGE_737 is not set |
diff --git a/arch/sparc/include/asm/pgalloc_32.h b/arch/sparc/include/asm/pgalloc_32.h index 681582d26969..ca2b34456c4b 100644 --- a/arch/sparc/include/asm/pgalloc_32.h +++ b/arch/sparc/include/asm/pgalloc_32.h | |||
| @@ -44,8 +44,8 @@ BTFIXUPDEF_CALL(pmd_t *, pmd_alloc_one, struct mm_struct *, unsigned long) | |||
| 44 | BTFIXUPDEF_CALL(void, free_pmd_fast, pmd_t *) | 44 | BTFIXUPDEF_CALL(void, free_pmd_fast, pmd_t *) |
| 45 | #define free_pmd_fast(pmd) BTFIXUP_CALL(free_pmd_fast)(pmd) | 45 | #define free_pmd_fast(pmd) BTFIXUP_CALL(free_pmd_fast)(pmd) |
| 46 | 46 | ||
| 47 | #define pmd_free(mm, pmd) free_pmd_fast(pmd) | 47 | #define pmd_free(mm, pmd) free_pmd_fast(pmd) |
| 48 | #define __pmd_free_tlb(tlb, pmd) pmd_free((tlb)->mm, pmd) | 48 | #define __pmd_free_tlb(tlb, pmd, addr) pmd_free((tlb)->mm, pmd) |
| 49 | 49 | ||
| 50 | BTFIXUPDEF_CALL(void, pmd_populate, pmd_t *, struct page *) | 50 | BTFIXUPDEF_CALL(void, pmd_populate, pmd_t *, struct page *) |
| 51 | #define pmd_populate(MM, PMD, PTE) BTFIXUP_CALL(pmd_populate)(PMD, PTE) | 51 | #define pmd_populate(MM, PMD, PTE) BTFIXUP_CALL(pmd_populate)(PMD, PTE) |
| @@ -62,7 +62,7 @@ BTFIXUPDEF_CALL(void, free_pte_fast, pte_t *) | |||
| 62 | #define pte_free_kernel(mm, pte) BTFIXUP_CALL(free_pte_fast)(pte) | 62 | #define pte_free_kernel(mm, pte) BTFIXUP_CALL(free_pte_fast)(pte) |
| 63 | 63 | ||
| 64 | BTFIXUPDEF_CALL(void, pte_free, pgtable_t ) | 64 | BTFIXUPDEF_CALL(void, pte_free, pgtable_t ) |
| 65 | #define pte_free(mm, pte) BTFIXUP_CALL(pte_free)(pte) | 65 | #define pte_free(mm, pte) BTFIXUP_CALL(pte_free)(pte) |
| 66 | #define __pte_free_tlb(tlb, pte) pte_free((tlb)->mm, pte) | 66 | #define __pte_free_tlb(tlb, pte, addr) pte_free((tlb)->mm, pte) |
| 67 | 67 | ||
| 68 | #endif /* _SPARC_PGALLOC_H */ | 68 | #endif /* _SPARC_PGALLOC_H */ |
diff --git a/arch/sparc/include/asm/pgtable_64.h b/arch/sparc/include/asm/pgtable_64.h index b049abf9902f..0ff92fa22064 100644 --- a/arch/sparc/include/asm/pgtable_64.h +++ b/arch/sparc/include/asm/pgtable_64.h | |||
| @@ -726,11 +726,17 @@ extern unsigned long pte_file(pte_t); | |||
| 726 | extern pte_t pgoff_to_pte(unsigned long); | 726 | extern pte_t pgoff_to_pte(unsigned long); |
| 727 | #define PTE_FILE_MAX_BITS (64UL - PAGE_SHIFT - 1UL) | 727 | #define PTE_FILE_MAX_BITS (64UL - PAGE_SHIFT - 1UL) |
| 728 | 728 | ||
| 729 | extern unsigned long *sparc64_valid_addr_bitmap; | 729 | extern unsigned long sparc64_valid_addr_bitmap[]; |
| 730 | 730 | ||
| 731 | /* Needs to be defined here and not in linux/mm.h, as it is arch dependent */ | 731 | /* Needs to be defined here and not in linux/mm.h, as it is arch dependent */ |
| 732 | #define kern_addr_valid(addr) \ | 732 | static inline bool kern_addr_valid(unsigned long addr) |
| 733 | (test_bit(__pa((unsigned long)(addr))>>22, sparc64_valid_addr_bitmap)) | 733 | { |
| 734 | unsigned long paddr = __pa(addr); | ||
| 735 | |||
| 736 | if ((paddr >> 41UL) != 0UL) | ||
| 737 | return false; | ||
| 738 | return test_bit(paddr >> 22, sparc64_valid_addr_bitmap); | ||
| 739 | } | ||
| 734 | 740 | ||
| 735 | extern int page_in_phys_avail(unsigned long paddr); | 741 | extern int page_in_phys_avail(unsigned long paddr); |
| 736 | 742 | ||
diff --git a/arch/sparc/include/asm/tlb_64.h b/arch/sparc/include/asm/tlb_64.h index ee38e731bfa6..dca406b9b6fc 100644 --- a/arch/sparc/include/asm/tlb_64.h +++ b/arch/sparc/include/asm/tlb_64.h | |||
| @@ -100,9 +100,9 @@ static inline void tlb_remove_page(struct mmu_gather *mp, struct page *page) | |||
| 100 | } | 100 | } |
| 101 | 101 | ||
| 102 | #define tlb_remove_tlb_entry(mp,ptep,addr) do { } while (0) | 102 | #define tlb_remove_tlb_entry(mp,ptep,addr) do { } while (0) |
| 103 | #define pte_free_tlb(mp, ptepage) pte_free((mp)->mm, ptepage) | 103 | #define pte_free_tlb(mp, ptepage, addr) pte_free((mp)->mm, ptepage) |
| 104 | #define pmd_free_tlb(mp, pmdp) pmd_free((mp)->mm, pmdp) | 104 | #define pmd_free_tlb(mp, pmdp, addr) pmd_free((mp)->mm, pmdp) |
| 105 | #define pud_free_tlb(tlb,pudp) __pud_free_tlb(tlb,pudp) | 105 | #define pud_free_tlb(tlb,pudp, addr) __pud_free_tlb(tlb,pudp,addr) |
| 106 | 106 | ||
| 107 | #define tlb_migrate_finish(mm) do { } while (0) | 107 | #define tlb_migrate_finish(mm) do { } while (0) |
| 108 | #define tlb_start_vma(tlb, vma) do { } while (0) | 108 | #define tlb_start_vma(tlb, vma) do { } while (0) |
diff --git a/arch/sparc/kernel/ktlb.S b/arch/sparc/kernel/ktlb.S index cef8defcd7a9..3ea6e8cde8c5 100644 --- a/arch/sparc/kernel/ktlb.S +++ b/arch/sparc/kernel/ktlb.S | |||
| @@ -151,12 +151,46 @@ kvmap_dtlb_4v: | |||
| 151 | * Must preserve %g1 and %g6 (TAG). | 151 | * Must preserve %g1 and %g6 (TAG). |
| 152 | */ | 152 | */ |
| 153 | kvmap_dtlb_tsb4m_miss: | 153 | kvmap_dtlb_tsb4m_miss: |
| 154 | sethi %hi(kpte_linear_bitmap), %g2 | 154 | /* Clear the PAGE_OFFSET top virtual bits, shift |
| 155 | or %g2, %lo(kpte_linear_bitmap), %g2 | 155 | * down to get PFN, and make sure PFN is in range. |
| 156 | */ | ||
| 157 | sllx %g4, 21, %g5 | ||
| 156 | 158 | ||
| 157 | /* Clear the PAGE_OFFSET top virtual bits, then shift | 159 | /* Check to see if we know about valid memory at the 4MB |
| 158 | * down to get a 256MB physical address index. | 160 | * chunk this physical address will reside within. |
| 159 | */ | 161 | */ |
| 162 | srlx %g5, 21 + 41, %g2 | ||
| 163 | brnz,pn %g2, kvmap_dtlb_longpath | ||
| 164 | nop | ||
| 165 | |||
| 166 | /* This unconditional branch and delay-slot nop gets patched | ||
| 167 | * by the sethi sequence once the bitmap is properly setup. | ||
| 168 | */ | ||
| 169 | .globl valid_addr_bitmap_insn | ||
| 170 | valid_addr_bitmap_insn: | ||
| 171 | ba,pt %xcc, 2f | ||
| 172 | nop | ||
| 173 | .subsection 2 | ||
| 174 | .globl valid_addr_bitmap_patch | ||
| 175 | valid_addr_bitmap_patch: | ||
| 176 | sethi %hi(sparc64_valid_addr_bitmap), %g7 | ||
| 177 | or %g7, %lo(sparc64_valid_addr_bitmap), %g7 | ||
| 178 | .previous | ||
| 179 | |||
| 180 | srlx %g5, 21 + 22, %g2 | ||
| 181 | srlx %g2, 6, %g5 | ||
| 182 | and %g2, 63, %g2 | ||
| 183 | sllx %g5, 3, %g5 | ||
| 184 | ldx [%g7 + %g5], %g5 | ||
| 185 | mov 1, %g7 | ||
| 186 | sllx %g7, %g2, %g7 | ||
| 187 | andcc %g5, %g7, %g0 | ||
| 188 | be,pn %xcc, kvmap_dtlb_longpath | ||
| 189 | |||
| 190 | 2: sethi %hi(kpte_linear_bitmap), %g2 | ||
| 191 | or %g2, %lo(kpte_linear_bitmap), %g2 | ||
| 192 | |||
| 193 | /* Get the 256MB physical address index. */ | ||
| 160 | sllx %g4, 21, %g5 | 194 | sllx %g4, 21, %g5 |
| 161 | mov 1, %g7 | 195 | mov 1, %g7 |
| 162 | srlx %g5, 21 + 28, %g5 | 196 | srlx %g5, 21 + 28, %g5 |
diff --git a/arch/sparc/kernel/smp_64.c b/arch/sparc/kernel/smp_64.c index fa44eaf8d897..3691907a43b4 100644 --- a/arch/sparc/kernel/smp_64.c +++ b/arch/sparc/kernel/smp_64.c | |||
| @@ -1499,7 +1499,7 @@ void __init setup_per_cpu_areas(void) | |||
| 1499 | dyn_size = pcpur_size - static_size - PERCPU_MODULE_RESERVE; | 1499 | dyn_size = pcpur_size - static_size - PERCPU_MODULE_RESERVE; |
| 1500 | 1500 | ||
| 1501 | 1501 | ||
| 1502 | ptrs_size = PFN_ALIGN(num_possible_cpus() * sizeof(pcpur_ptrs[0])); | 1502 | ptrs_size = PFN_ALIGN(nr_cpu_ids * sizeof(pcpur_ptrs[0])); |
| 1503 | pcpur_ptrs = alloc_bootmem(ptrs_size); | 1503 | pcpur_ptrs = alloc_bootmem(ptrs_size); |
| 1504 | 1504 | ||
| 1505 | for_each_possible_cpu(cpu) { | 1505 | for_each_possible_cpu(cpu) { |
| @@ -1514,7 +1514,7 @@ void __init setup_per_cpu_areas(void) | |||
| 1514 | 1514 | ||
| 1515 | /* allocate address and map */ | 1515 | /* allocate address and map */ |
| 1516 | vm.flags = VM_ALLOC; | 1516 | vm.flags = VM_ALLOC; |
| 1517 | vm.size = num_possible_cpus() * PCPU_CHUNK_SIZE; | 1517 | vm.size = nr_cpu_ids * PCPU_CHUNK_SIZE; |
| 1518 | vm_area_register_early(&vm, PCPU_CHUNK_SIZE); | 1518 | vm_area_register_early(&vm, PCPU_CHUNK_SIZE); |
| 1519 | 1519 | ||
| 1520 | for_each_possible_cpu(cpu) { | 1520 | for_each_possible_cpu(cpu) { |
diff --git a/arch/sparc/kernel/sun4d_smp.c b/arch/sparc/kernel/sun4d_smp.c index 54fb02468f0d..68791cad7b74 100644 --- a/arch/sparc/kernel/sun4d_smp.c +++ b/arch/sparc/kernel/sun4d_smp.c | |||
| @@ -162,9 +162,6 @@ extern void cpu_panic(void); | |||
| 162 | */ | 162 | */ |
| 163 | 163 | ||
| 164 | extern struct linux_prom_registers smp_penguin_ctable; | 164 | extern struct linux_prom_registers smp_penguin_ctable; |
| 165 | extern unsigned long trapbase_cpu1[]; | ||
| 166 | extern unsigned long trapbase_cpu2[]; | ||
| 167 | extern unsigned long trapbase_cpu3[]; | ||
| 168 | 165 | ||
| 169 | void __init smp4d_boot_cpus(void) | 166 | void __init smp4d_boot_cpus(void) |
| 170 | { | 167 | { |
| @@ -235,25 +232,6 @@ void __init smp4d_smp_done(void) | |||
| 235 | *prev = first; | 232 | *prev = first; |
| 236 | local_flush_cache_all(); | 233 | local_flush_cache_all(); |
| 237 | 234 | ||
| 238 | /* Free unneeded trap tables */ | ||
| 239 | ClearPageReserved(virt_to_page(trapbase_cpu1)); | ||
| 240 | init_page_count(virt_to_page(trapbase_cpu1)); | ||
| 241 | free_page((unsigned long)trapbase_cpu1); | ||
| 242 | totalram_pages++; | ||
| 243 | num_physpages++; | ||
| 244 | |||
| 245 | ClearPageReserved(virt_to_page(trapbase_cpu2)); | ||
| 246 | init_page_count(virt_to_page(trapbase_cpu2)); | ||
| 247 | free_page((unsigned long)trapbase_cpu2); | ||
| 248 | totalram_pages++; | ||
| 249 | num_physpages++; | ||
| 250 | |||
| 251 | ClearPageReserved(virt_to_page(trapbase_cpu3)); | ||
| 252 | init_page_count(virt_to_page(trapbase_cpu3)); | ||
| 253 | free_page((unsigned long)trapbase_cpu3); | ||
| 254 | totalram_pages++; | ||
| 255 | num_physpages++; | ||
| 256 | |||
| 257 | /* Ok, they are spinning and ready to go. */ | 235 | /* Ok, they are spinning and ready to go. */ |
| 258 | smp_processors_ready = 1; | 236 | smp_processors_ready = 1; |
| 259 | sun4d_distribute_irqs(); | 237 | sun4d_distribute_irqs(); |
diff --git a/arch/sparc/kernel/sun4m_smp.c b/arch/sparc/kernel/sun4m_smp.c index 960b113d0006..762d6eedd944 100644 --- a/arch/sparc/kernel/sun4m_smp.c +++ b/arch/sparc/kernel/sun4m_smp.c | |||
| @@ -121,9 +121,6 @@ void __cpuinit smp4m_callin(void) | |||
| 121 | */ | 121 | */ |
| 122 | 122 | ||
| 123 | extern struct linux_prom_registers smp_penguin_ctable; | 123 | extern struct linux_prom_registers smp_penguin_ctable; |
| 124 | extern unsigned long trapbase_cpu1[]; | ||
| 125 | extern unsigned long trapbase_cpu2[]; | ||
| 126 | extern unsigned long trapbase_cpu3[]; | ||
| 127 | 124 | ||
| 128 | void __init smp4m_boot_cpus(void) | 125 | void __init smp4m_boot_cpus(void) |
| 129 | { | 126 | { |
| @@ -193,29 +190,6 @@ void __init smp4m_smp_done(void) | |||
| 193 | *prev = first; | 190 | *prev = first; |
| 194 | local_flush_cache_all(); | 191 | local_flush_cache_all(); |
| 195 | 192 | ||
| 196 | /* Free unneeded trap tables */ | ||
| 197 | if (!cpu_isset(1, cpu_present_map)) { | ||
| 198 | ClearPageReserved(virt_to_page(trapbase_cpu1)); | ||
| 199 | init_page_count(virt_to_page(trapbase_cpu1)); | ||
| 200 | free_page((unsigned long)trapbase_cpu1); | ||
| 201 | totalram_pages++; | ||
| 202 | num_physpages++; | ||
| 203 | } | ||
| 204 | if (!cpu_isset(2, cpu_present_map)) { | ||
| 205 | ClearPageReserved(virt_to_page(trapbase_cpu2)); | ||
| 206 | init_page_count(virt_to_page(trapbase_cpu2)); | ||
| 207 | free_page((unsigned long)trapbase_cpu2); | ||
| 208 | totalram_pages++; | ||
| 209 | num_physpages++; | ||
| 210 | } | ||
| 211 | if (!cpu_isset(3, cpu_present_map)) { | ||
| 212 | ClearPageReserved(virt_to_page(trapbase_cpu3)); | ||
| 213 | init_page_count(virt_to_page(trapbase_cpu3)); | ||
| 214 | free_page((unsigned long)trapbase_cpu3); | ||
| 215 | totalram_pages++; | ||
| 216 | num_physpages++; | ||
| 217 | } | ||
| 218 | |||
| 219 | /* Ok, they are spinning and ready to go. */ | 193 | /* Ok, they are spinning and ready to go. */ |
| 220 | } | 194 | } |
| 221 | 195 | ||
diff --git a/arch/sparc/kernel/sys32.S b/arch/sparc/kernel/sys32.S index f061c4dda9ef..aed94869ad6a 100644 --- a/arch/sparc/kernel/sys32.S +++ b/arch/sparc/kernel/sys32.S | |||
| @@ -134,10 +134,12 @@ SIGN1(sys32_getpeername, sys_getpeername, %o0) | |||
| 134 | SIGN1(sys32_getsockname, sys_getsockname, %o0) | 134 | SIGN1(sys32_getsockname, sys_getsockname, %o0) |
| 135 | SIGN2(sys32_ioprio_get, sys_ioprio_get, %o0, %o1) | 135 | SIGN2(sys32_ioprio_get, sys_ioprio_get, %o0, %o1) |
| 136 | SIGN3(sys32_ioprio_set, sys_ioprio_set, %o0, %o1, %o2) | 136 | SIGN3(sys32_ioprio_set, sys_ioprio_set, %o0, %o1, %o2) |
| 137 | SIGN2(sys32_splice, sys_splice, %o0, %o1) | 137 | SIGN2(sys32_splice, sys_splice, %o0, %o2) |
| 138 | SIGN2(sys32_sync_file_range, compat_sync_file_range, %o0, %o5) | 138 | SIGN2(sys32_sync_file_range, compat_sync_file_range, %o0, %o5) |
| 139 | SIGN2(sys32_tee, sys_tee, %o0, %o1) | 139 | SIGN2(sys32_tee, sys_tee, %o0, %o1) |
| 140 | SIGN1(sys32_vmsplice, compat_sys_vmsplice, %o0) | 140 | SIGN1(sys32_vmsplice, compat_sys_vmsplice, %o0) |
| 141 | SIGN1(sys32_truncate, sys_truncate, %o1) | ||
| 142 | SIGN1(sys32_ftruncate, sys_ftruncate, %o1) | ||
| 141 | 143 | ||
| 142 | .globl sys32_mmap2 | 144 | .globl sys32_mmap2 |
| 143 | sys32_mmap2: | 145 | sys32_mmap2: |
diff --git a/arch/sparc/kernel/systbls_64.S b/arch/sparc/kernel/systbls_64.S index 6b3ee88e253c..2ee7250ba7ae 100644 --- a/arch/sparc/kernel/systbls_64.S +++ b/arch/sparc/kernel/systbls_64.S | |||
| @@ -43,8 +43,8 @@ sys_call_table32: | |||
| 43 | /*110*/ .word sys_setresgid, sys_getresgid, sys_setregid, sys_nis_syscall, sys_nis_syscall | 43 | /*110*/ .word sys_setresgid, sys_getresgid, sys_setregid, sys_nis_syscall, sys_nis_syscall |
| 44 | .word sys32_getgroups, compat_sys_gettimeofday, sys32_getrusage, sys_nis_syscall, sys_getcwd | 44 | .word sys32_getgroups, compat_sys_gettimeofday, sys32_getrusage, sys_nis_syscall, sys_getcwd |
| 45 | /*120*/ .word compat_sys_readv, compat_sys_writev, compat_sys_settimeofday, sys_fchown16, sys_fchmod | 45 | /*120*/ .word compat_sys_readv, compat_sys_writev, compat_sys_settimeofday, sys_fchown16, sys_fchmod |
| 46 | .word sys_nis_syscall, sys_setreuid16, sys_setregid16, sys_rename, sys_truncate | 46 | .word sys_nis_syscall, sys_setreuid16, sys_setregid16, sys_rename, sys32_truncate |
| 47 | /*130*/ .word sys_ftruncate, sys_flock, compat_sys_lstat64, sys_nis_syscall, sys_nis_syscall | 47 | /*130*/ .word sys32_ftruncate, sys_flock, compat_sys_lstat64, sys_nis_syscall, sys_nis_syscall |
| 48 | .word sys_nis_syscall, sys32_mkdir, sys_rmdir, compat_sys_utimes, compat_sys_stat64 | 48 | .word sys_nis_syscall, sys32_mkdir, sys_rmdir, compat_sys_utimes, compat_sys_stat64 |
| 49 | /*140*/ .word sys32_sendfile64, sys_nis_syscall, sys32_futex, sys_gettid, compat_sys_getrlimit | 49 | /*140*/ .word sys32_sendfile64, sys_nis_syscall, sys32_futex, sys_gettid, compat_sys_getrlimit |
| 50 | .word compat_sys_setrlimit, sys_pivot_root, sys32_prctl, sys_pciconfig_read, sys_pciconfig_write | 50 | .word compat_sys_setrlimit, sys_pivot_root, sys32_prctl, sys_pciconfig_read, sys_pciconfig_write |
diff --git a/arch/sparc/mm/fault_32.c b/arch/sparc/mm/fault_32.c index a5e30c642ee3..b99f81c4906f 100644 --- a/arch/sparc/mm/fault_32.c +++ b/arch/sparc/mm/fault_32.c | |||
| @@ -319,9 +319,10 @@ no_context: | |||
| 319 | */ | 319 | */ |
| 320 | out_of_memory: | 320 | out_of_memory: |
| 321 | up_read(&mm->mmap_sem); | 321 | up_read(&mm->mmap_sem); |
| 322 | printk("VM: killing process %s\n", tsk->comm); | 322 | if (from_user) { |
| 323 | if (from_user) | 323 | pagefault_out_of_memory(); |
| 324 | do_group_exit(SIGKILL); | 324 | return; |
| 325 | } | ||
| 325 | goto no_context; | 326 | goto no_context; |
| 326 | 327 | ||
| 327 | do_sigbus: | 328 | do_sigbus: |
diff --git a/arch/sparc/mm/fault_64.c b/arch/sparc/mm/fault_64.c index e5620b27c8bf..43b0da96a4fb 100644 --- a/arch/sparc/mm/fault_64.c +++ b/arch/sparc/mm/fault_64.c | |||
| @@ -447,9 +447,10 @@ handle_kernel_fault: | |||
| 447 | out_of_memory: | 447 | out_of_memory: |
| 448 | insn = get_fault_insn(regs, insn); | 448 | insn = get_fault_insn(regs, insn); |
| 449 | up_read(&mm->mmap_sem); | 449 | up_read(&mm->mmap_sem); |
| 450 | printk("VM: killing process %s\n", current->comm); | 450 | if (!(regs->tstate & TSTATE_PRIV)) { |
| 451 | if (!(regs->tstate & TSTATE_PRIV)) | 451 | pagefault_out_of_memory(); |
| 452 | do_group_exit(SIGKILL); | 452 | return; |
| 453 | } | ||
| 453 | goto handle_kernel_fault; | 454 | goto handle_kernel_fault; |
| 454 | 455 | ||
| 455 | intr_or_no_mm: | 456 | intr_or_no_mm: |
diff --git a/arch/sparc/mm/init_64.c b/arch/sparc/mm/init_64.c index ed6be6ba2f4e..a70a5e1904d9 100644 --- a/arch/sparc/mm/init_64.c +++ b/arch/sparc/mm/init_64.c | |||
| @@ -145,7 +145,8 @@ static void __init read_obp_memory(const char *property, | |||
| 145 | cmp_p64, NULL); | 145 | cmp_p64, NULL); |
| 146 | } | 146 | } |
| 147 | 147 | ||
| 148 | unsigned long *sparc64_valid_addr_bitmap __read_mostly; | 148 | unsigned long sparc64_valid_addr_bitmap[VALID_ADDR_BITMAP_BYTES / |
| 149 | sizeof(unsigned long)]; | ||
| 149 | EXPORT_SYMBOL(sparc64_valid_addr_bitmap); | 150 | EXPORT_SYMBOL(sparc64_valid_addr_bitmap); |
| 150 | 151 | ||
| 151 | /* Kernel physical address base and size in bytes. */ | 152 | /* Kernel physical address base and size in bytes. */ |
| @@ -1874,7 +1875,7 @@ static int pavail_rescan_ents __initdata; | |||
| 1874 | * memory list again, and make sure it provides at least as much | 1875 | * memory list again, and make sure it provides at least as much |
| 1875 | * memory as 'pavail' does. | 1876 | * memory as 'pavail' does. |
| 1876 | */ | 1877 | */ |
| 1877 | static void __init setup_valid_addr_bitmap_from_pavail(void) | 1878 | static void __init setup_valid_addr_bitmap_from_pavail(unsigned long *bitmap) |
| 1878 | { | 1879 | { |
| 1879 | int i; | 1880 | int i; |
| 1880 | 1881 | ||
| @@ -1897,8 +1898,7 @@ static void __init setup_valid_addr_bitmap_from_pavail(void) | |||
| 1897 | 1898 | ||
| 1898 | if (new_start <= old_start && | 1899 | if (new_start <= old_start && |
| 1899 | new_end >= (old_start + PAGE_SIZE)) { | 1900 | new_end >= (old_start + PAGE_SIZE)) { |
| 1900 | set_bit(old_start >> 22, | 1901 | set_bit(old_start >> 22, bitmap); |
| 1901 | sparc64_valid_addr_bitmap); | ||
| 1902 | goto do_next_page; | 1902 | goto do_next_page; |
| 1903 | } | 1903 | } |
| 1904 | } | 1904 | } |
| @@ -1919,20 +1919,21 @@ static void __init setup_valid_addr_bitmap_from_pavail(void) | |||
| 1919 | } | 1919 | } |
| 1920 | } | 1920 | } |
| 1921 | 1921 | ||
| 1922 | static void __init patch_tlb_miss_handler_bitmap(void) | ||
| 1923 | { | ||
| 1924 | extern unsigned int valid_addr_bitmap_insn[]; | ||
| 1925 | extern unsigned int valid_addr_bitmap_patch[]; | ||
| 1926 | |||
| 1927 | valid_addr_bitmap_insn[1] = valid_addr_bitmap_patch[1]; | ||
| 1928 | mb(); | ||
| 1929 | valid_addr_bitmap_insn[0] = valid_addr_bitmap_patch[0]; | ||
| 1930 | flushi(&valid_addr_bitmap_insn[0]); | ||
| 1931 | } | ||
| 1932 | |||
| 1922 | void __init mem_init(void) | 1933 | void __init mem_init(void) |
| 1923 | { | 1934 | { |
| 1924 | unsigned long codepages, datapages, initpages; | 1935 | unsigned long codepages, datapages, initpages; |
| 1925 | unsigned long addr, last; | 1936 | unsigned long addr, last; |
| 1926 | int i; | ||
| 1927 | |||
| 1928 | i = last_valid_pfn >> ((22 - PAGE_SHIFT) + 6); | ||
| 1929 | i += 1; | ||
| 1930 | sparc64_valid_addr_bitmap = (unsigned long *) alloc_bootmem(i << 3); | ||
| 1931 | if (sparc64_valid_addr_bitmap == NULL) { | ||
| 1932 | prom_printf("mem_init: Cannot alloc valid_addr_bitmap.\n"); | ||
| 1933 | prom_halt(); | ||
| 1934 | } | ||
| 1935 | memset(sparc64_valid_addr_bitmap, 0, i << 3); | ||
| 1936 | 1937 | ||
| 1937 | addr = PAGE_OFFSET + kern_base; | 1938 | addr = PAGE_OFFSET + kern_base; |
| 1938 | last = PAGE_ALIGN(kern_size) + addr; | 1939 | last = PAGE_ALIGN(kern_size) + addr; |
| @@ -1941,15 +1942,19 @@ void __init mem_init(void) | |||
| 1941 | addr += PAGE_SIZE; | 1942 | addr += PAGE_SIZE; |
| 1942 | } | 1943 | } |
| 1943 | 1944 | ||
| 1944 | setup_valid_addr_bitmap_from_pavail(); | 1945 | setup_valid_addr_bitmap_from_pavail(sparc64_valid_addr_bitmap); |
| 1946 | patch_tlb_miss_handler_bitmap(); | ||
| 1945 | 1947 | ||
| 1946 | high_memory = __va(last_valid_pfn << PAGE_SHIFT); | 1948 | high_memory = __va(last_valid_pfn << PAGE_SHIFT); |
| 1947 | 1949 | ||
| 1948 | #ifdef CONFIG_NEED_MULTIPLE_NODES | 1950 | #ifdef CONFIG_NEED_MULTIPLE_NODES |
| 1949 | for_each_online_node(i) { | 1951 | { |
| 1950 | if (NODE_DATA(i)->node_spanned_pages != 0) { | 1952 | int i; |
| 1951 | totalram_pages += | 1953 | for_each_online_node(i) { |
| 1952 | free_all_bootmem_node(NODE_DATA(i)); | 1954 | if (NODE_DATA(i)->node_spanned_pages != 0) { |
| 1955 | totalram_pages += | ||
| 1956 | free_all_bootmem_node(NODE_DATA(i)); | ||
| 1957 | } | ||
| 1953 | } | 1958 | } |
| 1954 | } | 1959 | } |
| 1955 | #else | 1960 | #else |
diff --git a/arch/sparc/mm/init_64.h b/arch/sparc/mm/init_64.h index 16063870a489..c2f772dbd556 100644 --- a/arch/sparc/mm/init_64.h +++ b/arch/sparc/mm/init_64.h | |||
| @@ -5,10 +5,13 @@ | |||
| 5 | * marked non-static so that assembler code can get at them. | 5 | * marked non-static so that assembler code can get at them. |
| 6 | */ | 6 | */ |
| 7 | 7 | ||
| 8 | #define MAX_PHYS_ADDRESS (1UL << 42UL) | 8 | #define MAX_PHYS_ADDRESS (1UL << 41UL) |
| 9 | #define KPTE_BITMAP_CHUNK_SZ (256UL * 1024UL * 1024UL) | 9 | #define KPTE_BITMAP_CHUNK_SZ (256UL * 1024UL * 1024UL) |
| 10 | #define KPTE_BITMAP_BYTES \ | 10 | #define KPTE_BITMAP_BYTES \ |
| 11 | ((MAX_PHYS_ADDRESS / KPTE_BITMAP_CHUNK_SZ) / 8) | 11 | ((MAX_PHYS_ADDRESS / KPTE_BITMAP_CHUNK_SZ) / 8) |
| 12 | #define VALID_ADDR_BITMAP_CHUNK_SZ (4UL * 1024UL * 1024UL) | ||
| 13 | #define VALID_ADDR_BITMAP_BYTES \ | ||
| 14 | ((MAX_PHYS_ADDRESS / VALID_ADDR_BITMAP_CHUNK_SZ) / 8) | ||
| 12 | 15 | ||
| 13 | extern unsigned long kern_linear_pte_xor[2]; | 16 | extern unsigned long kern_linear_pte_xor[2]; |
| 14 | extern unsigned long kpte_linear_bitmap[KPTE_BITMAP_BYTES / sizeof(unsigned long)]; | 17 | extern unsigned long kpte_linear_bitmap[KPTE_BITMAP_BYTES / sizeof(unsigned long)]; |
diff --git a/arch/um/include/asm/pgalloc.h b/arch/um/include/asm/pgalloc.h index 718984359f8c..32c8ce4e1515 100644 --- a/arch/um/include/asm/pgalloc.h +++ b/arch/um/include/asm/pgalloc.h | |||
| @@ -40,7 +40,7 @@ static inline void pte_free(struct mm_struct *mm, pgtable_t pte) | |||
| 40 | __free_page(pte); | 40 | __free_page(pte); |
| 41 | } | 41 | } |
| 42 | 42 | ||
| 43 | #define __pte_free_tlb(tlb,pte) \ | 43 | #define __pte_free_tlb(tlb,pte, address) \ |
| 44 | do { \ | 44 | do { \ |
| 45 | pgtable_page_dtor(pte); \ | 45 | pgtable_page_dtor(pte); \ |
| 46 | tlb_remove_page((tlb),(pte)); \ | 46 | tlb_remove_page((tlb),(pte)); \ |
| @@ -53,7 +53,7 @@ static inline void pmd_free(struct mm_struct *mm, pmd_t *pmd) | |||
| 53 | free_page((unsigned long)pmd); | 53 | free_page((unsigned long)pmd); |
| 54 | } | 54 | } |
| 55 | 55 | ||
| 56 | #define __pmd_free_tlb(tlb,x) tlb_remove_page((tlb),virt_to_page(x)) | 56 | #define __pmd_free_tlb(tlb,x, address) tlb_remove_page((tlb),virt_to_page(x)) |
| 57 | #endif | 57 | #endif |
| 58 | 58 | ||
| 59 | #define check_pgt_cache() do { } while (0) | 59 | #define check_pgt_cache() do { } while (0) |
diff --git a/arch/um/include/asm/tlb.h b/arch/um/include/asm/tlb.h index 5240fa1c5e08..660caedac9eb 100644 --- a/arch/um/include/asm/tlb.h +++ b/arch/um/include/asm/tlb.h | |||
| @@ -116,11 +116,11 @@ static inline void tlb_remove_page(struct mmu_gather *tlb, struct page *page) | |||
| 116 | __tlb_remove_tlb_entry(tlb, ptep, address); \ | 116 | __tlb_remove_tlb_entry(tlb, ptep, address); \ |
| 117 | } while (0) | 117 | } while (0) |
| 118 | 118 | ||
| 119 | #define pte_free_tlb(tlb, ptep) __pte_free_tlb(tlb, ptep) | 119 | #define pte_free_tlb(tlb, ptep, addr) __pte_free_tlb(tlb, ptep, addr) |
| 120 | 120 | ||
| 121 | #define pud_free_tlb(tlb, pudp) __pud_free_tlb(tlb, pudp) | 121 | #define pud_free_tlb(tlb, pudp, addr) __pud_free_tlb(tlb, pudp, addr) |
| 122 | 122 | ||
| 123 | #define pmd_free_tlb(tlb, pmdp) __pmd_free_tlb(tlb, pmdp) | 123 | #define pmd_free_tlb(tlb, pmdp, addr) __pmd_free_tlb(tlb, pmdp, addr) |
| 124 | 124 | ||
| 125 | #define tlb_migrate_finish(mm) do {} while (0) | 125 | #define tlb_migrate_finish(mm) do {} while (0) |
| 126 | 126 | ||
diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig index b66f2102c35d..1401d4f0ed48 100644 --- a/arch/x86/Kconfig +++ b/arch/x86/Kconfig | |||
| @@ -24,6 +24,7 @@ config X86 | |||
| 24 | select HAVE_UNSTABLE_SCHED_CLOCK | 24 | select HAVE_UNSTABLE_SCHED_CLOCK |
| 25 | select HAVE_IDE | 25 | select HAVE_IDE |
| 26 | select HAVE_OPROFILE | 26 | select HAVE_OPROFILE |
| 27 | select HAVE_PERF_COUNTERS if (!M386 && !M486) | ||
| 27 | select HAVE_IOREMAP_PROT | 28 | select HAVE_IOREMAP_PROT |
| 28 | select HAVE_KPROBES | 29 | select HAVE_KPROBES |
| 29 | select ARCH_WANT_OPTIONAL_GPIOLIB | 30 | select ARCH_WANT_OPTIONAL_GPIOLIB |
| @@ -746,7 +747,6 @@ config X86_UP_IOAPIC | |||
| 746 | config X86_LOCAL_APIC | 747 | config X86_LOCAL_APIC |
| 747 | def_bool y | 748 | def_bool y |
| 748 | depends on X86_64 || SMP || X86_32_NON_STANDARD || X86_UP_APIC | 749 | depends on X86_64 || SMP || X86_32_NON_STANDARD || X86_UP_APIC |
| 749 | select HAVE_PERF_COUNTERS if (!M386 && !M486) | ||
| 750 | 750 | ||
| 751 | config X86_IO_APIC | 751 | config X86_IO_APIC |
| 752 | def_bool y | 752 | def_bool y |
diff --git a/arch/x86/boot/compressed/Makefile b/arch/x86/boot/compressed/Makefile index e2ff504b4ddc..f8ed0658404c 100644 --- a/arch/x86/boot/compressed/Makefile +++ b/arch/x86/boot/compressed/Makefile | |||
| @@ -4,7 +4,7 @@ | |||
| 4 | # create a compressed vmlinux image from the original vmlinux | 4 | # create a compressed vmlinux image from the original vmlinux |
| 5 | # | 5 | # |
| 6 | 6 | ||
| 7 | targets := vmlinux vmlinux.bin vmlinux.bin.gz vmlinux.bin.bz2 vmlinux.bin.lzma head_$(BITS).o misc.o piggy.o | 7 | targets := vmlinux.lds vmlinux vmlinux.bin vmlinux.bin.gz vmlinux.bin.bz2 vmlinux.bin.lzma head_$(BITS).o misc.o piggy.o |
| 8 | 8 | ||
| 9 | KBUILD_CFLAGS := -m$(BITS) -D__KERNEL__ $(LINUX_INCLUDE) -O2 | 9 | KBUILD_CFLAGS := -m$(BITS) -D__KERNEL__ $(LINUX_INCLUDE) -O2 |
| 10 | KBUILD_CFLAGS += -fno-strict-aliasing -fPIC | 10 | KBUILD_CFLAGS += -fno-strict-aliasing -fPIC |
diff --git a/arch/x86/include/asm/efi.h b/arch/x86/include/asm/efi.h index edc90f23e708..8406ed7f9926 100644 --- a/arch/x86/include/asm/efi.h +++ b/arch/x86/include/asm/efi.h | |||
| @@ -33,7 +33,7 @@ extern unsigned long asmlinkage efi_call_phys(void *, ...); | |||
| 33 | #define efi_call_virt6(f, a1, a2, a3, a4, a5, a6) \ | 33 | #define efi_call_virt6(f, a1, a2, a3, a4, a5, a6) \ |
| 34 | efi_call_virt(f, a1, a2, a3, a4, a5, a6) | 34 | efi_call_virt(f, a1, a2, a3, a4, a5, a6) |
| 35 | 35 | ||
| 36 | #define efi_ioremap(addr, size) ioremap_cache(addr, size) | 36 | #define efi_ioremap(addr, size, type) ioremap_cache(addr, size) |
| 37 | 37 | ||
| 38 | #else /* !CONFIG_X86_32 */ | 38 | #else /* !CONFIG_X86_32 */ |
| 39 | 39 | ||
| @@ -84,7 +84,8 @@ extern u64 efi_call6(void *fp, u64 arg1, u64 arg2, u64 arg3, | |||
| 84 | efi_call6((void *)(efi.systab->runtime->f), (u64)(a1), (u64)(a2), \ | 84 | efi_call6((void *)(efi.systab->runtime->f), (u64)(a1), (u64)(a2), \ |
| 85 | (u64)(a3), (u64)(a4), (u64)(a5), (u64)(a6)) | 85 | (u64)(a3), (u64)(a4), (u64)(a5), (u64)(a6)) |
| 86 | 86 | ||
| 87 | extern void __iomem *efi_ioremap(unsigned long addr, unsigned long size); | 87 | extern void __iomem *efi_ioremap(unsigned long addr, unsigned long size, |
| 88 | u32 type); | ||
| 88 | 89 | ||
| 89 | #endif /* CONFIG_X86_32 */ | 90 | #endif /* CONFIG_X86_32 */ |
| 90 | 91 | ||
diff --git a/arch/x86/include/asm/irqflags.h b/arch/x86/include/asm/irqflags.h index 2bdab21f0898..c6ccbe7e81ad 100644 --- a/arch/x86/include/asm/irqflags.h +++ b/arch/x86/include/asm/irqflags.h | |||
| @@ -12,9 +12,15 @@ static inline unsigned long native_save_fl(void) | |||
| 12 | { | 12 | { |
| 13 | unsigned long flags; | 13 | unsigned long flags; |
| 14 | 14 | ||
| 15 | /* | ||
| 16 | * Note: this needs to be "=r" not "=rm", because we have the | ||
| 17 | * stack offset from what gcc expects at the time the "pop" is | ||
| 18 | * executed, and so a memory reference with respect to the stack | ||
| 19 | * would end up using the wrong address. | ||
| 20 | */ | ||
| 15 | asm volatile("# __raw_save_flags\n\t" | 21 | asm volatile("# __raw_save_flags\n\t" |
| 16 | "pushf ; pop %0" | 22 | "pushf ; pop %0" |
| 17 | : "=g" (flags) | 23 | : "=r" (flags) |
| 18 | : /* no input */ | 24 | : /* no input */ |
| 19 | : "memory"); | 25 | : "memory"); |
| 20 | 26 | ||
diff --git a/arch/x86/include/asm/lguest.h b/arch/x86/include/asm/lguest.h index 313389cd50d2..5136dad57cbb 100644 --- a/arch/x86/include/asm/lguest.h +++ b/arch/x86/include/asm/lguest.h | |||
| @@ -17,8 +17,7 @@ | |||
| 17 | /* Pages for switcher itself, then two pages per cpu */ | 17 | /* Pages for switcher itself, then two pages per cpu */ |
| 18 | #define TOTAL_SWITCHER_PAGES (SHARED_SWITCHER_PAGES + 2 * nr_cpu_ids) | 18 | #define TOTAL_SWITCHER_PAGES (SHARED_SWITCHER_PAGES + 2 * nr_cpu_ids) |
| 19 | 19 | ||
| 20 | /* We map at -4M (-2M when PAE is activated) for ease of mapping | 20 | /* We map at -4M (-2M for PAE) for ease of mapping (one PTE page). */ |
| 21 | * into the guest (one PTE page). */ | ||
| 22 | #ifdef CONFIG_X86_PAE | 21 | #ifdef CONFIG_X86_PAE |
| 23 | #define SWITCHER_ADDR 0xFFE00000 | 22 | #define SWITCHER_ADDR 0xFFE00000 |
| 24 | #else | 23 | #else |
diff --git a/arch/x86/include/asm/lguest_hcall.h b/arch/x86/include/asm/lguest_hcall.h index 33600a66755f..ba0eed8aa1a6 100644 --- a/arch/x86/include/asm/lguest_hcall.h +++ b/arch/x86/include/asm/lguest_hcall.h | |||
| @@ -30,27 +30,27 @@ | |||
| 30 | #include <asm/hw_irq.h> | 30 | #include <asm/hw_irq.h> |
| 31 | #include <asm/kvm_para.h> | 31 | #include <asm/kvm_para.h> |
| 32 | 32 | ||
| 33 | /*G:030 But first, how does our Guest contact the Host to ask for privileged | 33 | /*G:030 |
| 34 | * But first, how does our Guest contact the Host to ask for privileged | ||
| 34 | * operations? There are two ways: the direct way is to make a "hypercall", | 35 | * operations? There are two ways: the direct way is to make a "hypercall", |
| 35 | * to make requests of the Host Itself. | 36 | * to make requests of the Host Itself. |
| 36 | * | 37 | * |
| 37 | * We use the KVM hypercall mechanism. Seventeen hypercalls are | 38 | * We use the KVM hypercall mechanism, though completely different hypercall |
| 38 | * available: the hypercall number is put in the %eax register, and the | 39 | * numbers. Seventeen hypercalls are available: the hypercall number is put in |
| 39 | * arguments (when required) are placed in %ebx, %ecx, %edx and %esi. | 40 | * the %eax register, and the arguments (when required) are placed in %ebx, |
| 40 | * If a return value makes sense, it's returned in %eax. | 41 | * %ecx, %edx and %esi. If a return value makes sense, it's returned in %eax. |
| 41 | * | 42 | * |
| 42 | * Grossly invalid calls result in Sudden Death at the hands of the vengeful | 43 | * Grossly invalid calls result in Sudden Death at the hands of the vengeful |
| 43 | * Host, rather than returning failure. This reflects Winston Churchill's | 44 | * Host, rather than returning failure. This reflects Winston Churchill's |
| 44 | * definition of a gentleman: "someone who is only rude intentionally". */ | 45 | * definition of a gentleman: "someone who is only rude intentionally". |
| 45 | /*:*/ | 46 | :*/ |
| 46 | 47 | ||
| 47 | /* Can't use our min() macro here: needs to be a constant */ | 48 | /* Can't use our min() macro here: needs to be a constant */ |
| 48 | #define LGUEST_IRQS (NR_IRQS < 32 ? NR_IRQS: 32) | 49 | #define LGUEST_IRQS (NR_IRQS < 32 ? NR_IRQS: 32) |
| 49 | 50 | ||
| 50 | #define LHCALL_RING_SIZE 64 | 51 | #define LHCALL_RING_SIZE 64 |
| 51 | struct hcall_args { | 52 | struct hcall_args { |
| 52 | /* These map directly onto eax, ebx, ecx, edx and esi | 53 | /* These map directly onto eax/ebx/ecx/edx/esi in struct lguest_regs */ |
| 53 | * in struct lguest_regs */ | ||
| 54 | unsigned long arg0, arg1, arg2, arg3, arg4; | 54 | unsigned long arg0, arg1, arg2, arg3, arg4; |
| 55 | }; | 55 | }; |
| 56 | 56 | ||
diff --git a/arch/x86/include/asm/pgalloc.h b/arch/x86/include/asm/pgalloc.h index dd14c54ac718..0e8c2a0fd922 100644 --- a/arch/x86/include/asm/pgalloc.h +++ b/arch/x86/include/asm/pgalloc.h | |||
| @@ -46,7 +46,13 @@ static inline void pte_free(struct mm_struct *mm, struct page *pte) | |||
| 46 | __free_page(pte); | 46 | __free_page(pte); |
| 47 | } | 47 | } |
| 48 | 48 | ||
| 49 | extern void __pte_free_tlb(struct mmu_gather *tlb, struct page *pte); | 49 | extern void ___pte_free_tlb(struct mmu_gather *tlb, struct page *pte); |
| 50 | |||
| 51 | static inline void __pte_free_tlb(struct mmu_gather *tlb, struct page *pte, | ||
| 52 | unsigned long address) | ||
| 53 | { | ||
| 54 | ___pte_free_tlb(tlb, pte); | ||
| 55 | } | ||
| 50 | 56 | ||
| 51 | static inline void pmd_populate_kernel(struct mm_struct *mm, | 57 | static inline void pmd_populate_kernel(struct mm_struct *mm, |
| 52 | pmd_t *pmd, pte_t *pte) | 58 | pmd_t *pmd, pte_t *pte) |
| @@ -78,7 +84,13 @@ static inline void pmd_free(struct mm_struct *mm, pmd_t *pmd) | |||
| 78 | free_page((unsigned long)pmd); | 84 | free_page((unsigned long)pmd); |
| 79 | } | 85 | } |
| 80 | 86 | ||
| 81 | extern void __pmd_free_tlb(struct mmu_gather *tlb, pmd_t *pmd); | 87 | extern void ___pmd_free_tlb(struct mmu_gather *tlb, pmd_t *pmd); |
| 88 | |||
| 89 | static inline void __pmd_free_tlb(struct mmu_gather *tlb, pmd_t *pmd, | ||
| 90 | unsigned long adddress) | ||
| 91 | { | ||
| 92 | ___pmd_free_tlb(tlb, pmd); | ||
| 93 | } | ||
| 82 | 94 | ||
| 83 | #ifdef CONFIG_X86_PAE | 95 | #ifdef CONFIG_X86_PAE |
| 84 | extern void pud_populate(struct mm_struct *mm, pud_t *pudp, pmd_t *pmd); | 96 | extern void pud_populate(struct mm_struct *mm, pud_t *pudp, pmd_t *pmd); |
| @@ -108,7 +120,14 @@ static inline void pud_free(struct mm_struct *mm, pud_t *pud) | |||
| 108 | free_page((unsigned long)pud); | 120 | free_page((unsigned long)pud); |
| 109 | } | 121 | } |
| 110 | 122 | ||
| 111 | extern void __pud_free_tlb(struct mmu_gather *tlb, pud_t *pud); | 123 | extern void ___pud_free_tlb(struct mmu_gather *tlb, pud_t *pud); |
| 124 | |||
| 125 | static inline void __pud_free_tlb(struct mmu_gather *tlb, pud_t *pud, | ||
| 126 | unsigned long address) | ||
| 127 | { | ||
| 128 | ___pud_free_tlb(tlb, pud); | ||
| 129 | } | ||
| 130 | |||
| 112 | #endif /* PAGETABLE_LEVELS > 3 */ | 131 | #endif /* PAGETABLE_LEVELS > 3 */ |
| 113 | #endif /* PAGETABLE_LEVELS > 2 */ | 132 | #endif /* PAGETABLE_LEVELS > 2 */ |
| 114 | 133 | ||
diff --git a/arch/x86/include/asm/pgtable.h b/arch/x86/include/asm/pgtable.h index 3cc06e3fceb8..16748077559a 100644 --- a/arch/x86/include/asm/pgtable.h +++ b/arch/x86/include/asm/pgtable.h | |||
| @@ -2,6 +2,7 @@ | |||
| 2 | #define _ASM_X86_PGTABLE_H | 2 | #define _ASM_X86_PGTABLE_H |
| 3 | 3 | ||
| 4 | #include <asm/page.h> | 4 | #include <asm/page.h> |
| 5 | #include <asm/e820.h> | ||
| 5 | 6 | ||
| 6 | #include <asm/pgtable_types.h> | 7 | #include <asm/pgtable_types.h> |
| 7 | 8 | ||
| @@ -269,10 +270,17 @@ static inline pgprot_t pgprot_modify(pgprot_t oldprot, pgprot_t newprot) | |||
| 269 | 270 | ||
| 270 | #define canon_pgprot(p) __pgprot(massage_pgprot(p)) | 271 | #define canon_pgprot(p) __pgprot(massage_pgprot(p)) |
| 271 | 272 | ||
| 272 | static inline int is_new_memtype_allowed(unsigned long flags, | 273 | static inline int is_new_memtype_allowed(u64 paddr, unsigned long size, |
| 273 | unsigned long new_flags) | 274 | unsigned long flags, |
| 275 | unsigned long new_flags) | ||
| 274 | { | 276 | { |
| 275 | /* | 277 | /* |
| 278 | * PAT type is always WB for ISA. So no need to check. | ||
| 279 | */ | ||
| 280 | if (is_ISA_range(paddr, paddr + size - 1)) | ||
| 281 | return 1; | ||
| 282 | |||
| 283 | /* | ||
| 276 | * Certain new memtypes are not allowed with certain | 284 | * Certain new memtypes are not allowed with certain |
| 277 | * requested memtype: | 285 | * requested memtype: |
| 278 | * - request is uncached, return cannot be write-back | 286 | * - request is uncached, return cannot be write-back |
diff --git a/arch/x86/include/asm/uaccess.h b/arch/x86/include/asm/uaccess.h index 20e6a795e160..d2c6c930b491 100644 --- a/arch/x86/include/asm/uaccess.h +++ b/arch/x86/include/asm/uaccess.h | |||
| @@ -212,9 +212,9 @@ extern int __get_user_bad(void); | |||
| 212 | : "A" ((typeof(*(ptr)))(x)), "c" (ptr) : "ebx") | 212 | : "A" ((typeof(*(ptr)))(x)), "c" (ptr) : "ebx") |
| 213 | #else | 213 | #else |
| 214 | #define __put_user_asm_u64(x, ptr, retval, errret) \ | 214 | #define __put_user_asm_u64(x, ptr, retval, errret) \ |
| 215 | __put_user_asm(x, ptr, retval, "q", "", "Zr", errret) | 215 | __put_user_asm(x, ptr, retval, "q", "", "er", errret) |
| 216 | #define __put_user_asm_ex_u64(x, addr) \ | 216 | #define __put_user_asm_ex_u64(x, addr) \ |
| 217 | __put_user_asm_ex(x, addr, "q", "", "Zr") | 217 | __put_user_asm_ex(x, addr, "q", "", "er") |
| 218 | #define __put_user_x8(x, ptr, __ret_pu) __put_user_x(8, x, ptr, __ret_pu) | 218 | #define __put_user_x8(x, ptr, __ret_pu) __put_user_x(8, x, ptr, __ret_pu) |
| 219 | #endif | 219 | #endif |
| 220 | 220 | ||
diff --git a/arch/x86/include/asm/uaccess_64.h b/arch/x86/include/asm/uaccess_64.h index 8cc687326eb8..db24b215fc50 100644 --- a/arch/x86/include/asm/uaccess_64.h +++ b/arch/x86/include/asm/uaccess_64.h | |||
| @@ -88,11 +88,11 @@ int __copy_to_user(void __user *dst, const void *src, unsigned size) | |||
| 88 | ret, "l", "k", "ir", 4); | 88 | ret, "l", "k", "ir", 4); |
| 89 | return ret; | 89 | return ret; |
| 90 | case 8:__put_user_asm(*(u64 *)src, (u64 __user *)dst, | 90 | case 8:__put_user_asm(*(u64 *)src, (u64 __user *)dst, |
| 91 | ret, "q", "", "ir", 8); | 91 | ret, "q", "", "er", 8); |
| 92 | return ret; | 92 | return ret; |
| 93 | case 10: | 93 | case 10: |
| 94 | __put_user_asm(*(u64 *)src, (u64 __user *)dst, | 94 | __put_user_asm(*(u64 *)src, (u64 __user *)dst, |
| 95 | ret, "q", "", "ir", 10); | 95 | ret, "q", "", "er", 10); |
| 96 | if (unlikely(ret)) | 96 | if (unlikely(ret)) |
| 97 | return ret; | 97 | return ret; |
| 98 | asm("":::"memory"); | 98 | asm("":::"memory"); |
| @@ -101,12 +101,12 @@ int __copy_to_user(void __user *dst, const void *src, unsigned size) | |||
| 101 | return ret; | 101 | return ret; |
| 102 | case 16: | 102 | case 16: |
| 103 | __put_user_asm(*(u64 *)src, (u64 __user *)dst, | 103 | __put_user_asm(*(u64 *)src, (u64 __user *)dst, |
| 104 | ret, "q", "", "ir", 16); | 104 | ret, "q", "", "er", 16); |
| 105 | if (unlikely(ret)) | 105 | if (unlikely(ret)) |
| 106 | return ret; | 106 | return ret; |
| 107 | asm("":::"memory"); | 107 | asm("":::"memory"); |
| 108 | __put_user_asm(1[(u64 *)src], 1 + (u64 __user *)dst, | 108 | __put_user_asm(1[(u64 *)src], 1 + (u64 __user *)dst, |
| 109 | ret, "q", "", "ir", 8); | 109 | ret, "q", "", "er", 8); |
| 110 | return ret; | 110 | return ret; |
| 111 | default: | 111 | default: |
| 112 | return copy_user_generic((__force void *)dst, src, size); | 112 | return copy_user_generic((__force void *)dst, src, size); |
| @@ -157,7 +157,7 @@ int __copy_in_user(void __user *dst, const void __user *src, unsigned size) | |||
| 157 | ret, "q", "", "=r", 8); | 157 | ret, "q", "", "=r", 8); |
| 158 | if (likely(!ret)) | 158 | if (likely(!ret)) |
| 159 | __put_user_asm(tmp, (u64 __user *)dst, | 159 | __put_user_asm(tmp, (u64 __user *)dst, |
| 160 | ret, "q", "", "ir", 8); | 160 | ret, "q", "", "er", 8); |
| 161 | return ret; | 161 | return ret; |
| 162 | } | 162 | } |
| 163 | default: | 163 | default: |
diff --git a/arch/x86/include/asm/uv/uv_bau.h b/arch/x86/include/asm/uv/uv_bau.h index bddd44f2f0ab..80e2984f521c 100644 --- a/arch/x86/include/asm/uv/uv_bau.h +++ b/arch/x86/include/asm/uv/uv_bau.h | |||
| @@ -133,7 +133,7 @@ struct bau_msg_payload { | |||
| 133 | * see table 4.2.3.0.1 in broacast_assist spec. | 133 | * see table 4.2.3.0.1 in broacast_assist spec. |
| 134 | */ | 134 | */ |
| 135 | struct bau_msg_header { | 135 | struct bau_msg_header { |
| 136 | unsigned int dest_subnodeid:6; /* must be zero */ | 136 | unsigned int dest_subnodeid:6; /* must be 0x10, for the LB */ |
| 137 | /* bits 5:0 */ | 137 | /* bits 5:0 */ |
| 138 | unsigned int base_dest_nodeid:15; /* nasid>>1 (pnode) of */ | 138 | unsigned int base_dest_nodeid:15; /* nasid>>1 (pnode) of */ |
| 139 | /* bits 20:6 */ /* first bit in node_map */ | 139 | /* bits 20:6 */ /* first bit in node_map */ |
diff --git a/arch/x86/include/asm/uv/uv_hub.h b/arch/x86/include/asm/uv/uv_hub.h index 341070f7ad5c..77a68505419a 100644 --- a/arch/x86/include/asm/uv/uv_hub.h +++ b/arch/x86/include/asm/uv/uv_hub.h | |||
| @@ -175,7 +175,7 @@ DECLARE_PER_CPU(struct uv_hub_info_s, __uv_hub_info); | |||
| 175 | #define UV_GLOBAL_MMR32_PNODE_BITS(p) ((p) << (UV_GLOBAL_MMR32_PNODE_SHIFT)) | 175 | #define UV_GLOBAL_MMR32_PNODE_BITS(p) ((p) << (UV_GLOBAL_MMR32_PNODE_SHIFT)) |
| 176 | 176 | ||
| 177 | #define UV_GLOBAL_MMR64_PNODE_BITS(p) \ | 177 | #define UV_GLOBAL_MMR64_PNODE_BITS(p) \ |
| 178 | ((unsigned long)(UV_PNODE_TO_GNODE(p)) << UV_GLOBAL_MMR64_PNODE_SHIFT) | 178 | (((unsigned long)(p)) << UV_GLOBAL_MMR64_PNODE_SHIFT) |
| 179 | 179 | ||
| 180 | #define UV_APIC_PNODE_SHIFT 6 | 180 | #define UV_APIC_PNODE_SHIFT 6 |
| 181 | 181 | ||
| @@ -327,6 +327,7 @@ struct uv_blade_info { | |||
| 327 | unsigned short nr_possible_cpus; | 327 | unsigned short nr_possible_cpus; |
| 328 | unsigned short nr_online_cpus; | 328 | unsigned short nr_online_cpus; |
| 329 | unsigned short pnode; | 329 | unsigned short pnode; |
| 330 | short memory_nid; | ||
| 330 | }; | 331 | }; |
| 331 | extern struct uv_blade_info *uv_blade_info; | 332 | extern struct uv_blade_info *uv_blade_info; |
| 332 | extern short *uv_node_to_blade; | 333 | extern short *uv_node_to_blade; |
| @@ -363,6 +364,12 @@ static inline int uv_blade_to_pnode(int bid) | |||
| 363 | return uv_blade_info[bid].pnode; | 364 | return uv_blade_info[bid].pnode; |
| 364 | } | 365 | } |
| 365 | 366 | ||
| 367 | /* Nid of memory node on blade. -1 if no blade-local memory */ | ||
| 368 | static inline int uv_blade_to_memory_nid(int bid) | ||
| 369 | { | ||
| 370 | return uv_blade_info[bid].memory_nid; | ||
| 371 | } | ||
| 372 | |||
| 366 | /* Determine the number of possible cpus on a blade */ | 373 | /* Determine the number of possible cpus on a blade */ |
| 367 | static inline int uv_blade_nr_possible_cpus(int bid) | 374 | static inline int uv_blade_nr_possible_cpus(int bid) |
| 368 | { | 375 | { |
diff --git a/arch/x86/kernel/apic/io_apic.c b/arch/x86/kernel/apic/io_apic.c index 2284a4812b68..d2ed6c5ddc80 100644 --- a/arch/x86/kernel/apic/io_apic.c +++ b/arch/x86/kernel/apic/io_apic.c | |||
| @@ -3793,6 +3793,9 @@ int arch_enable_uv_irq(char *irq_name, unsigned int irq, int cpu, int mmr_blade, | |||
| 3793 | mmr_pnode = uv_blade_to_pnode(mmr_blade); | 3793 | mmr_pnode = uv_blade_to_pnode(mmr_blade); |
| 3794 | uv_write_global_mmr64(mmr_pnode, mmr_offset, mmr_value); | 3794 | uv_write_global_mmr64(mmr_pnode, mmr_offset, mmr_value); |
| 3795 | 3795 | ||
| 3796 | if (cfg->move_in_progress) | ||
| 3797 | send_cleanup_vector(cfg); | ||
| 3798 | |||
| 3796 | return irq; | 3799 | return irq; |
| 3797 | } | 3800 | } |
| 3798 | 3801 | ||
diff --git a/arch/x86/kernel/apic/ipi.c b/arch/x86/kernel/apic/ipi.c index dbf5445727a9..6ef00ba4c886 100644 --- a/arch/x86/kernel/apic/ipi.c +++ b/arch/x86/kernel/apic/ipi.c | |||
| @@ -106,6 +106,9 @@ void default_send_IPI_mask_logical(const struct cpumask *cpumask, int vector) | |||
| 106 | unsigned long mask = cpumask_bits(cpumask)[0]; | 106 | unsigned long mask = cpumask_bits(cpumask)[0]; |
| 107 | unsigned long flags; | 107 | unsigned long flags; |
| 108 | 108 | ||
| 109 | if (WARN_ONCE(!mask, "empty IPI mask")) | ||
| 110 | return; | ||
| 111 | |||
| 109 | local_irq_save(flags); | 112 | local_irq_save(flags); |
| 110 | WARN_ON(mask & ~cpumask_bits(cpu_online_mask)[0]); | 113 | WARN_ON(mask & ~cpumask_bits(cpu_online_mask)[0]); |
| 111 | __default_send_IPI_dest_field(mask, vector, apic->dest_logical); | 114 | __default_send_IPI_dest_field(mask, vector, apic->dest_logical); |
diff --git a/arch/x86/kernel/apic/x2apic_cluster.c b/arch/x86/kernel/apic/x2apic_cluster.c index 8e4cbb255c38..a5371ec36776 100644 --- a/arch/x86/kernel/apic/x2apic_cluster.c +++ b/arch/x86/kernel/apic/x2apic_cluster.c | |||
| @@ -17,11 +17,13 @@ static int x2apic_acpi_madt_oem_check(char *oem_id, char *oem_table_id) | |||
| 17 | return x2apic_enabled(); | 17 | return x2apic_enabled(); |
| 18 | } | 18 | } |
| 19 | 19 | ||
| 20 | /* Start with all IRQs pointing to boot CPU. IRQ balancing will shift them. */ | 20 | /* |
| 21 | 21 | * need to use more than cpu 0, because we need more vectors when | |
| 22 | * MSI-X are used. | ||
| 23 | */ | ||
| 22 | static const struct cpumask *x2apic_target_cpus(void) | 24 | static const struct cpumask *x2apic_target_cpus(void) |
| 23 | { | 25 | { |
| 24 | return cpumask_of(0); | 26 | return cpu_online_mask; |
| 25 | } | 27 | } |
| 26 | 28 | ||
| 27 | /* | 29 | /* |
| @@ -170,7 +172,7 @@ static unsigned long set_apic_id(unsigned int id) | |||
| 170 | 172 | ||
| 171 | static int x2apic_cluster_phys_pkg_id(int initial_apicid, int index_msb) | 173 | static int x2apic_cluster_phys_pkg_id(int initial_apicid, int index_msb) |
| 172 | { | 174 | { |
| 173 | return current_cpu_data.initial_apicid >> index_msb; | 175 | return initial_apicid >> index_msb; |
| 174 | } | 176 | } |
| 175 | 177 | ||
| 176 | static void x2apic_send_IPI_self(int vector) | 178 | static void x2apic_send_IPI_self(int vector) |
diff --git a/arch/x86/kernel/apic/x2apic_phys.c b/arch/x86/kernel/apic/x2apic_phys.c index a284359627e7..a8989aadc99a 100644 --- a/arch/x86/kernel/apic/x2apic_phys.c +++ b/arch/x86/kernel/apic/x2apic_phys.c | |||
| @@ -27,11 +27,13 @@ static int x2apic_acpi_madt_oem_check(char *oem_id, char *oem_table_id) | |||
| 27 | return 0; | 27 | return 0; |
| 28 | } | 28 | } |
| 29 | 29 | ||
| 30 | /* Start with all IRQs pointing to boot CPU. IRQ balancing will shift them. */ | 30 | /* |
| 31 | 31 | * need to use more than cpu 0, because we need more vectors when | |
| 32 | * MSI-X are used. | ||
| 33 | */ | ||
| 32 | static const struct cpumask *x2apic_target_cpus(void) | 34 | static const struct cpumask *x2apic_target_cpus(void) |
| 33 | { | 35 | { |
| 34 | return cpumask_of(0); | 36 | return cpu_online_mask; |
| 35 | } | 37 | } |
| 36 | 38 | ||
| 37 | static void x2apic_vector_allocation_domain(int cpu, struct cpumask *retmask) | 39 | static void x2apic_vector_allocation_domain(int cpu, struct cpumask *retmask) |
| @@ -162,7 +164,7 @@ static unsigned long set_apic_id(unsigned int id) | |||
| 162 | 164 | ||
| 163 | static int x2apic_phys_pkg_id(int initial_apicid, int index_msb) | 165 | static int x2apic_phys_pkg_id(int initial_apicid, int index_msb) |
| 164 | { | 166 | { |
| 165 | return current_cpu_data.initial_apicid >> index_msb; | 167 | return initial_apicid >> index_msb; |
| 166 | } | 168 | } |
| 167 | 169 | ||
| 168 | static void x2apic_send_IPI_self(int vector) | 170 | static void x2apic_send_IPI_self(int vector) |
diff --git a/arch/x86/kernel/apic/x2apic_uv_x.c b/arch/x86/kernel/apic/x2apic_uv_x.c index 096d19aea2f7..601159374e87 100644 --- a/arch/x86/kernel/apic/x2apic_uv_x.c +++ b/arch/x86/kernel/apic/x2apic_uv_x.c | |||
| @@ -46,7 +46,7 @@ static int early_get_nodeid(void) | |||
| 46 | return node_id.s.node_id; | 46 | return node_id.s.node_id; |
| 47 | } | 47 | } |
| 48 | 48 | ||
| 49 | static int uv_acpi_madt_oem_check(char *oem_id, char *oem_table_id) | 49 | static int __init uv_acpi_madt_oem_check(char *oem_id, char *oem_table_id) |
| 50 | { | 50 | { |
| 51 | if (!strcmp(oem_id, "SGI")) { | 51 | if (!strcmp(oem_id, "SGI")) { |
| 52 | if (!strcmp(oem_table_id, "UVL")) | 52 | if (!strcmp(oem_table_id, "UVL")) |
| @@ -253,7 +253,7 @@ static void uv_send_IPI_self(int vector) | |||
| 253 | apic_write(APIC_SELF_IPI, vector); | 253 | apic_write(APIC_SELF_IPI, vector); |
| 254 | } | 254 | } |
| 255 | 255 | ||
| 256 | struct apic apic_x2apic_uv_x = { | 256 | struct apic __refdata apic_x2apic_uv_x = { |
| 257 | 257 | ||
| 258 | .name = "UV large system", | 258 | .name = "UV large system", |
| 259 | .probe = NULL, | 259 | .probe = NULL, |
| @@ -261,7 +261,7 @@ struct apic apic_x2apic_uv_x = { | |||
| 261 | .apic_id_registered = uv_apic_id_registered, | 261 | .apic_id_registered = uv_apic_id_registered, |
| 262 | 262 | ||
| 263 | .irq_delivery_mode = dest_Fixed, | 263 | .irq_delivery_mode = dest_Fixed, |
| 264 | .irq_dest_mode = 1, /* logical */ | 264 | .irq_dest_mode = 0, /* physical */ |
| 265 | 265 | ||
| 266 | .target_cpus = uv_target_cpus, | 266 | .target_cpus = uv_target_cpus, |
| 267 | .disable_esr = 0, | 267 | .disable_esr = 0, |
| @@ -362,12 +362,6 @@ static __init void get_lowmem_redirect(unsigned long *base, unsigned long *size) | |||
| 362 | BUG(); | 362 | BUG(); |
| 363 | } | 363 | } |
| 364 | 364 | ||
| 365 | static __init void map_low_mmrs(void) | ||
| 366 | { | ||
| 367 | init_extra_mapping_uc(UV_GLOBAL_MMR32_BASE, UV_GLOBAL_MMR32_SIZE); | ||
| 368 | init_extra_mapping_uc(UV_LOCAL_MMR_BASE, UV_LOCAL_MMR_SIZE); | ||
| 369 | } | ||
| 370 | |||
| 371 | enum map_type {map_wb, map_uc}; | 365 | enum map_type {map_wb, map_uc}; |
| 372 | 366 | ||
| 373 | static __init void map_high(char *id, unsigned long base, int shift, | 367 | static __init void map_high(char *id, unsigned long base, int shift, |
| @@ -395,26 +389,6 @@ static __init void map_gru_high(int max_pnode) | |||
| 395 | map_high("GRU", gru.s.base, shift, max_pnode, map_wb); | 389 | map_high("GRU", gru.s.base, shift, max_pnode, map_wb); |
| 396 | } | 390 | } |
| 397 | 391 | ||
| 398 | static __init void map_config_high(int max_pnode) | ||
| 399 | { | ||
| 400 | union uvh_rh_gam_cfg_overlay_config_mmr_u cfg; | ||
| 401 | int shift = UVH_RH_GAM_CFG_OVERLAY_CONFIG_MMR_BASE_SHFT; | ||
| 402 | |||
| 403 | cfg.v = uv_read_local_mmr(UVH_RH_GAM_CFG_OVERLAY_CONFIG_MMR); | ||
| 404 | if (cfg.s.enable) | ||
| 405 | map_high("CONFIG", cfg.s.base, shift, max_pnode, map_uc); | ||
| 406 | } | ||
| 407 | |||
| 408 | static __init void map_mmr_high(int max_pnode) | ||
| 409 | { | ||
| 410 | union uvh_rh_gam_mmr_overlay_config_mmr_u mmr; | ||
| 411 | int shift = UVH_RH_GAM_MMR_OVERLAY_CONFIG_MMR_BASE_SHFT; | ||
| 412 | |||
| 413 | mmr.v = uv_read_local_mmr(UVH_RH_GAM_MMR_OVERLAY_CONFIG_MMR); | ||
| 414 | if (mmr.s.enable) | ||
| 415 | map_high("MMR", mmr.s.base, shift, max_pnode, map_uc); | ||
| 416 | } | ||
| 417 | |||
| 418 | static __init void map_mmioh_high(int max_pnode) | 392 | static __init void map_mmioh_high(int max_pnode) |
| 419 | { | 393 | { |
| 420 | union uvh_rh_gam_mmioh_overlay_config_mmr_u mmioh; | 394 | union uvh_rh_gam_mmioh_overlay_config_mmr_u mmioh; |
| @@ -566,8 +540,6 @@ void __init uv_system_init(void) | |||
| 566 | unsigned long mmr_base, present, paddr; | 540 | unsigned long mmr_base, present, paddr; |
| 567 | unsigned short pnode_mask; | 541 | unsigned short pnode_mask; |
| 568 | 542 | ||
| 569 | map_low_mmrs(); | ||
| 570 | |||
| 571 | m_n_config.v = uv_read_local_mmr(UVH_SI_ADDR_MAP_CONFIG); | 543 | m_n_config.v = uv_read_local_mmr(UVH_SI_ADDR_MAP_CONFIG); |
| 572 | m_val = m_n_config.s.m_skt; | 544 | m_val = m_n_config.s.m_skt; |
| 573 | n_val = m_n_config.s.n_skt; | 545 | n_val = m_n_config.s.n_skt; |
| @@ -591,6 +563,8 @@ void __init uv_system_init(void) | |||
| 591 | bytes = sizeof(struct uv_blade_info) * uv_num_possible_blades(); | 563 | bytes = sizeof(struct uv_blade_info) * uv_num_possible_blades(); |
| 592 | uv_blade_info = kmalloc(bytes, GFP_KERNEL); | 564 | uv_blade_info = kmalloc(bytes, GFP_KERNEL); |
| 593 | BUG_ON(!uv_blade_info); | 565 | BUG_ON(!uv_blade_info); |
| 566 | for (blade = 0; blade < uv_num_possible_blades(); blade++) | ||
| 567 | uv_blade_info[blade].memory_nid = -1; | ||
| 594 | 568 | ||
| 595 | get_lowmem_redirect(&lowmem_redir_base, &lowmem_redir_size); | 569 | get_lowmem_redirect(&lowmem_redir_base, &lowmem_redir_size); |
| 596 | 570 | ||
| @@ -629,6 +603,9 @@ void __init uv_system_init(void) | |||
| 629 | lcpu = uv_blade_info[blade].nr_possible_cpus; | 603 | lcpu = uv_blade_info[blade].nr_possible_cpus; |
| 630 | uv_blade_info[blade].nr_possible_cpus++; | 604 | uv_blade_info[blade].nr_possible_cpus++; |
| 631 | 605 | ||
| 606 | /* Any node on the blade, else will contain -1. */ | ||
| 607 | uv_blade_info[blade].memory_nid = nid; | ||
| 608 | |||
| 632 | uv_cpu_hub_info(cpu)->lowmem_remap_base = lowmem_redir_base; | 609 | uv_cpu_hub_info(cpu)->lowmem_remap_base = lowmem_redir_base; |
| 633 | uv_cpu_hub_info(cpu)->lowmem_remap_top = lowmem_redir_size; | 610 | uv_cpu_hub_info(cpu)->lowmem_remap_top = lowmem_redir_size; |
| 634 | uv_cpu_hub_info(cpu)->m_val = m_val; | 611 | uv_cpu_hub_info(cpu)->m_val = m_val; |
| @@ -662,11 +639,10 @@ void __init uv_system_init(void) | |||
| 662 | pnode = (paddr >> m_val) & pnode_mask; | 639 | pnode = (paddr >> m_val) & pnode_mask; |
| 663 | blade = boot_pnode_to_blade(pnode); | 640 | blade = boot_pnode_to_blade(pnode); |
| 664 | uv_node_to_blade[nid] = blade; | 641 | uv_node_to_blade[nid] = blade; |
| 642 | max_pnode = max(pnode, max_pnode); | ||
| 665 | } | 643 | } |
| 666 | 644 | ||
| 667 | map_gru_high(max_pnode); | 645 | map_gru_high(max_pnode); |
| 668 | map_mmr_high(max_pnode); | ||
| 669 | map_config_high(max_pnode); | ||
| 670 | map_mmioh_high(max_pnode); | 646 | map_mmioh_high(max_pnode); |
| 671 | 647 | ||
| 672 | uv_cpu_init(); | 648 | uv_cpu_init(); |
diff --git a/arch/x86/kernel/apm_32.c b/arch/x86/kernel/apm_32.c index 79302e9a33a4..442b5508893f 100644 --- a/arch/x86/kernel/apm_32.c +++ b/arch/x86/kernel/apm_32.c | |||
| @@ -811,7 +811,7 @@ static int apm_do_idle(void) | |||
| 811 | u8 ret = 0; | 811 | u8 ret = 0; |
| 812 | int idled = 0; | 812 | int idled = 0; |
| 813 | int polling; | 813 | int polling; |
| 814 | int err; | 814 | int err = 0; |
| 815 | 815 | ||
| 816 | polling = !!(current_thread_info()->status & TS_POLLING); | 816 | polling = !!(current_thread_info()->status & TS_POLLING); |
| 817 | if (polling) { | 817 | if (polling) { |
diff --git a/arch/x86/kernel/cpu/Makefile b/arch/x86/kernel/cpu/Makefile index 3efcb2b96a15..c1f253dac155 100644 --- a/arch/x86/kernel/cpu/Makefile +++ b/arch/x86/kernel/cpu/Makefile | |||
| @@ -7,6 +7,10 @@ ifdef CONFIG_FUNCTION_TRACER | |||
| 7 | CFLAGS_REMOVE_common.o = -pg | 7 | CFLAGS_REMOVE_common.o = -pg |
| 8 | endif | 8 | endif |
| 9 | 9 | ||
| 10 | # Make sure load_percpu_segment has no stackprotector | ||
| 11 | nostackp := $(call cc-option, -fno-stack-protector) | ||
| 12 | CFLAGS_common.o := $(nostackp) | ||
| 13 | |||
| 10 | obj-y := intel_cacheinfo.o addon_cpuid_features.o | 14 | obj-y := intel_cacheinfo.o addon_cpuid_features.o |
| 11 | obj-y += proc.o capflags.o powerflags.o common.o | 15 | obj-y += proc.o capflags.o powerflags.o common.o |
| 12 | obj-y += vmware.o hypervisor.o | 16 | obj-y += vmware.o hypervisor.o |
diff --git a/arch/x86/kernel/cpu/amd.c b/arch/x86/kernel/cpu/amd.c index 28e5f5956042..63fddcd082cd 100644 --- a/arch/x86/kernel/cpu/amd.c +++ b/arch/x86/kernel/cpu/amd.c | |||
| @@ -356,7 +356,7 @@ static void __cpuinit early_init_amd(struct cpuinfo_x86 *c) | |||
| 356 | #endif | 356 | #endif |
| 357 | #if defined(CONFIG_X86_LOCAL_APIC) && defined(CONFIG_PCI) | 357 | #if defined(CONFIG_X86_LOCAL_APIC) && defined(CONFIG_PCI) |
| 358 | /* check CPU config space for extended APIC ID */ | 358 | /* check CPU config space for extended APIC ID */ |
| 359 | if (c->x86 >= 0xf) { | 359 | if (cpu_has_apic && c->x86 >= 0xf) { |
| 360 | unsigned int val; | 360 | unsigned int val; |
| 361 | val = read_pci_config(0, 24, 0, 0x68); | 361 | val = read_pci_config(0, 24, 0, 0x68); |
| 362 | if ((val & ((1 << 17) | (1 << 18))) == ((1 << 17) | (1 << 18))) | 362 | if ((val & ((1 << 17) | (1 << 18))) == ((1 << 17) | (1 << 18))) |
| @@ -400,6 +400,13 @@ static void __cpuinit init_amd(struct cpuinfo_x86 *c) | |||
| 400 | level = cpuid_eax(1); | 400 | level = cpuid_eax(1); |
| 401 | if((level >= 0x0f48 && level < 0x0f50) || level >= 0x0f58) | 401 | if((level >= 0x0f48 && level < 0x0f50) || level >= 0x0f58) |
| 402 | set_cpu_cap(c, X86_FEATURE_REP_GOOD); | 402 | set_cpu_cap(c, X86_FEATURE_REP_GOOD); |
| 403 | |||
| 404 | /* | ||
| 405 | * Some BIOSes incorrectly force this feature, but only K8 | ||
| 406 | * revision D (model = 0x14) and later actually support it. | ||
| 407 | */ | ||
| 408 | if (c->x86_model < 0x14) | ||
| 409 | clear_cpu_cap(c, X86_FEATURE_LAHF_LM); | ||
| 403 | } | 410 | } |
| 404 | if (c->x86 == 0x10 || c->x86 == 0x11) | 411 | if (c->x86 == 0x10 || c->x86 == 0x11) |
| 405 | set_cpu_cap(c, X86_FEATURE_REP_GOOD); | 412 | set_cpu_cap(c, X86_FEATURE_REP_GOOD); |
diff --git a/arch/x86/kernel/cpu/common.c b/arch/x86/kernel/cpu/common.c index f1961c07af9a..5ce60a88027b 100644 --- a/arch/x86/kernel/cpu/common.c +++ b/arch/x86/kernel/cpu/common.c | |||
| @@ -59,7 +59,30 @@ void __init setup_cpu_local_masks(void) | |||
| 59 | alloc_bootmem_cpumask_var(&cpu_sibling_setup_mask); | 59 | alloc_bootmem_cpumask_var(&cpu_sibling_setup_mask); |
| 60 | } | 60 | } |
| 61 | 61 | ||
| 62 | static const struct cpu_dev *this_cpu __cpuinitdata; | 62 | static void __cpuinit default_init(struct cpuinfo_x86 *c) |
| 63 | { | ||
| 64 | #ifdef CONFIG_X86_64 | ||
| 65 | display_cacheinfo(c); | ||
| 66 | #else | ||
| 67 | /* Not much we can do here... */ | ||
| 68 | /* Check if at least it has cpuid */ | ||
| 69 | if (c->cpuid_level == -1) { | ||
| 70 | /* No cpuid. It must be an ancient CPU */ | ||
| 71 | if (c->x86 == 4) | ||
| 72 | strcpy(c->x86_model_id, "486"); | ||
| 73 | else if (c->x86 == 3) | ||
| 74 | strcpy(c->x86_model_id, "386"); | ||
| 75 | } | ||
| 76 | #endif | ||
| 77 | } | ||
| 78 | |||
| 79 | static const struct cpu_dev __cpuinitconst default_cpu = { | ||
| 80 | .c_init = default_init, | ||
| 81 | .c_vendor = "Unknown", | ||
| 82 | .c_x86_vendor = X86_VENDOR_UNKNOWN, | ||
| 83 | }; | ||
| 84 | |||
| 85 | static const struct cpu_dev *this_cpu __cpuinitdata = &default_cpu; | ||
| 63 | 86 | ||
| 64 | DEFINE_PER_CPU_PAGE_ALIGNED(struct gdt_page, gdt_page) = { .gdt = { | 87 | DEFINE_PER_CPU_PAGE_ALIGNED(struct gdt_page, gdt_page) = { .gdt = { |
| 65 | #ifdef CONFIG_X86_64 | 88 | #ifdef CONFIG_X86_64 |
| @@ -332,29 +355,6 @@ void switch_to_new_gdt(int cpu) | |||
| 332 | 355 | ||
| 333 | static const struct cpu_dev *__cpuinitdata cpu_devs[X86_VENDOR_NUM] = {}; | 356 | static const struct cpu_dev *__cpuinitdata cpu_devs[X86_VENDOR_NUM] = {}; |
| 334 | 357 | ||
| 335 | static void __cpuinit default_init(struct cpuinfo_x86 *c) | ||
| 336 | { | ||
| 337 | #ifdef CONFIG_X86_64 | ||
| 338 | display_cacheinfo(c); | ||
| 339 | #else | ||
| 340 | /* Not much we can do here... */ | ||
| 341 | /* Check if at least it has cpuid */ | ||
| 342 | if (c->cpuid_level == -1) { | ||
| 343 | /* No cpuid. It must be an ancient CPU */ | ||
| 344 | if (c->x86 == 4) | ||
| 345 | strcpy(c->x86_model_id, "486"); | ||
| 346 | else if (c->x86 == 3) | ||
| 347 | strcpy(c->x86_model_id, "386"); | ||
| 348 | } | ||
| 349 | #endif | ||
| 350 | } | ||
| 351 | |||
| 352 | static const struct cpu_dev __cpuinitconst default_cpu = { | ||
| 353 | .c_init = default_init, | ||
| 354 | .c_vendor = "Unknown", | ||
| 355 | .c_x86_vendor = X86_VENDOR_UNKNOWN, | ||
| 356 | }; | ||
| 357 | |||
| 358 | static void __cpuinit get_model_name(struct cpuinfo_x86 *c) | 358 | static void __cpuinit get_model_name(struct cpuinfo_x86 *c) |
| 359 | { | 359 | { |
| 360 | unsigned int *v; | 360 | unsigned int *v; |
diff --git a/arch/x86/kernel/cpu/mcheck/mce.c b/arch/x86/kernel/cpu/mcheck/mce.c index 484c1e5f658e..01213048f62f 100644 --- a/arch/x86/kernel/cpu/mcheck/mce.c +++ b/arch/x86/kernel/cpu/mcheck/mce.c | |||
| @@ -1226,8 +1226,13 @@ static void mce_init(void) | |||
| 1226 | } | 1226 | } |
| 1227 | 1227 | ||
| 1228 | /* Add per CPU specific workarounds here */ | 1228 | /* Add per CPU specific workarounds here */ |
| 1229 | static void mce_cpu_quirks(struct cpuinfo_x86 *c) | 1229 | static int mce_cpu_quirks(struct cpuinfo_x86 *c) |
| 1230 | { | 1230 | { |
| 1231 | if (c->x86_vendor == X86_VENDOR_UNKNOWN) { | ||
| 1232 | pr_info("MCE: unknown CPU type - not enabling MCE support.\n"); | ||
| 1233 | return -EOPNOTSUPP; | ||
| 1234 | } | ||
| 1235 | |||
| 1231 | /* This should be disabled by the BIOS, but isn't always */ | 1236 | /* This should be disabled by the BIOS, but isn't always */ |
| 1232 | if (c->x86_vendor == X86_VENDOR_AMD) { | 1237 | if (c->x86_vendor == X86_VENDOR_AMD) { |
| 1233 | if (c->x86 == 15 && banks > 4) { | 1238 | if (c->x86 == 15 && banks > 4) { |
| @@ -1273,11 +1278,20 @@ static void mce_cpu_quirks(struct cpuinfo_x86 *c) | |||
| 1273 | if ((c->x86 > 6 || (c->x86 == 6 && c->x86_model >= 0xe)) && | 1278 | if ((c->x86 > 6 || (c->x86 == 6 && c->x86_model >= 0xe)) && |
| 1274 | monarch_timeout < 0) | 1279 | monarch_timeout < 0) |
| 1275 | monarch_timeout = USEC_PER_SEC; | 1280 | monarch_timeout = USEC_PER_SEC; |
| 1281 | |||
| 1282 | /* | ||
| 1283 | * There are also broken BIOSes on some Pentium M and | ||
| 1284 | * earlier systems: | ||
| 1285 | */ | ||
| 1286 | if (c->x86 == 6 && c->x86_model <= 13 && mce_bootlog < 0) | ||
| 1287 | mce_bootlog = 0; | ||
| 1276 | } | 1288 | } |
| 1277 | if (monarch_timeout < 0) | 1289 | if (monarch_timeout < 0) |
| 1278 | monarch_timeout = 0; | 1290 | monarch_timeout = 0; |
| 1279 | if (mce_bootlog != 0) | 1291 | if (mce_bootlog != 0) |
| 1280 | mce_panic_timeout = 30; | 1292 | mce_panic_timeout = 30; |
| 1293 | |||
| 1294 | return 0; | ||
| 1281 | } | 1295 | } |
| 1282 | 1296 | ||
| 1283 | static void __cpuinit mce_ancient_init(struct cpuinfo_x86 *c) | 1297 | static void __cpuinit mce_ancient_init(struct cpuinfo_x86 *c) |
| @@ -1338,11 +1352,10 @@ void __cpuinit mcheck_init(struct cpuinfo_x86 *c) | |||
| 1338 | if (!mce_available(c)) | 1352 | if (!mce_available(c)) |
| 1339 | return; | 1353 | return; |
| 1340 | 1354 | ||
| 1341 | if (mce_cap_init() < 0) { | 1355 | if (mce_cap_init() < 0 || mce_cpu_quirks(c) < 0) { |
| 1342 | mce_disabled = 1; | 1356 | mce_disabled = 1; |
| 1343 | return; | 1357 | return; |
| 1344 | } | 1358 | } |
| 1345 | mce_cpu_quirks(c); | ||
| 1346 | 1359 | ||
| 1347 | machine_check_vector = do_machine_check; | 1360 | machine_check_vector = do_machine_check; |
| 1348 | 1361 | ||
| @@ -1692,17 +1705,15 @@ static ssize_t set_trigger(struct sys_device *s, struct sysdev_attribute *attr, | |||
| 1692 | const char *buf, size_t siz) | 1705 | const char *buf, size_t siz) |
| 1693 | { | 1706 | { |
| 1694 | char *p; | 1707 | char *p; |
| 1695 | int len; | ||
| 1696 | 1708 | ||
| 1697 | strncpy(mce_helper, buf, sizeof(mce_helper)); | 1709 | strncpy(mce_helper, buf, sizeof(mce_helper)); |
| 1698 | mce_helper[sizeof(mce_helper)-1] = 0; | 1710 | mce_helper[sizeof(mce_helper)-1] = 0; |
| 1699 | len = strlen(mce_helper); | ||
| 1700 | p = strchr(mce_helper, '\n'); | 1711 | p = strchr(mce_helper, '\n'); |
| 1701 | 1712 | ||
| 1702 | if (*p) | 1713 | if (p) |
| 1703 | *p = 0; | 1714 | *p = 0; |
| 1704 | 1715 | ||
| 1705 | return len; | 1716 | return strlen(mce_helper) + !!p; |
| 1706 | } | 1717 | } |
| 1707 | 1718 | ||
| 1708 | static ssize_t set_ignore_ce(struct sys_device *s, | 1719 | static ssize_t set_ignore_ce(struct sys_device *s, |
diff --git a/arch/x86/kernel/cpu/mcheck/therm_throt.c b/arch/x86/kernel/cpu/mcheck/therm_throt.c index bff8dd191dd5..5957a93e5173 100644 --- a/arch/x86/kernel/cpu/mcheck/therm_throt.c +++ b/arch/x86/kernel/cpu/mcheck/therm_throt.c | |||
| @@ -36,6 +36,7 @@ | |||
| 36 | 36 | ||
| 37 | static DEFINE_PER_CPU(__u64, next_check) = INITIAL_JIFFIES; | 37 | static DEFINE_PER_CPU(__u64, next_check) = INITIAL_JIFFIES; |
| 38 | static DEFINE_PER_CPU(unsigned long, thermal_throttle_count); | 38 | static DEFINE_PER_CPU(unsigned long, thermal_throttle_count); |
| 39 | static DEFINE_PER_CPU(bool, thermal_throttle_active); | ||
| 39 | 40 | ||
| 40 | static atomic_t therm_throt_en = ATOMIC_INIT(0); | 41 | static atomic_t therm_throt_en = ATOMIC_INIT(0); |
| 41 | 42 | ||
| @@ -96,27 +97,33 @@ static int therm_throt_process(int curr) | |||
| 96 | { | 97 | { |
| 97 | unsigned int cpu = smp_processor_id(); | 98 | unsigned int cpu = smp_processor_id(); |
| 98 | __u64 tmp_jiffs = get_jiffies_64(); | 99 | __u64 tmp_jiffs = get_jiffies_64(); |
| 100 | bool was_throttled = __get_cpu_var(thermal_throttle_active); | ||
| 101 | bool is_throttled = __get_cpu_var(thermal_throttle_active) = curr; | ||
| 99 | 102 | ||
| 100 | if (curr) | 103 | if (is_throttled) |
| 101 | __get_cpu_var(thermal_throttle_count)++; | 104 | __get_cpu_var(thermal_throttle_count)++; |
| 102 | 105 | ||
| 103 | if (time_before64(tmp_jiffs, __get_cpu_var(next_check))) | 106 | if (!(was_throttled ^ is_throttled) && |
| 107 | time_before64(tmp_jiffs, __get_cpu_var(next_check))) | ||
| 104 | return 0; | 108 | return 0; |
| 105 | 109 | ||
| 106 | __get_cpu_var(next_check) = tmp_jiffs + CHECK_INTERVAL; | 110 | __get_cpu_var(next_check) = tmp_jiffs + CHECK_INTERVAL; |
| 107 | 111 | ||
| 108 | /* if we just entered the thermal event */ | 112 | /* if we just entered the thermal event */ |
| 109 | if (curr) { | 113 | if (is_throttled) { |
| 110 | printk(KERN_CRIT "CPU%d: Temperature above threshold, " | 114 | printk(KERN_CRIT "CPU%d: Temperature above threshold, " |
| 111 | "cpu clock throttled (total events = %lu)\n", cpu, | 115 | "cpu clock throttled (total events = %lu)\n", |
| 112 | __get_cpu_var(thermal_throttle_count)); | 116 | cpu, __get_cpu_var(thermal_throttle_count)); |
| 113 | 117 | ||
| 114 | add_taint(TAINT_MACHINE_CHECK); | 118 | add_taint(TAINT_MACHINE_CHECK); |
| 115 | } else { | 119 | return 1; |
| 116 | printk(KERN_CRIT "CPU%d: Temperature/speed normal\n", cpu); | 120 | } |
| 121 | if (was_throttled) { | ||
| 122 | printk(KERN_INFO "CPU%d: Temperature/speed normal\n", cpu); | ||
| 123 | return 1; | ||
| 117 | } | 124 | } |
| 118 | 125 | ||
| 119 | return 1; | 126 | return 0; |
| 120 | } | 127 | } |
| 121 | 128 | ||
| 122 | #ifdef CONFIG_SYSFS | 129 | #ifdef CONFIG_SYSFS |
diff --git a/arch/x86/kernel/cpu/perf_counter.c b/arch/x86/kernel/cpu/perf_counter.c index 36c3dc7b8991..900332b800f8 100644 --- a/arch/x86/kernel/cpu/perf_counter.c +++ b/arch/x86/kernel/cpu/perf_counter.c | |||
| @@ -55,6 +55,7 @@ struct x86_pmu { | |||
| 55 | int num_counters_fixed; | 55 | int num_counters_fixed; |
| 56 | int counter_bits; | 56 | int counter_bits; |
| 57 | u64 counter_mask; | 57 | u64 counter_mask; |
| 58 | int apic; | ||
| 58 | u64 max_period; | 59 | u64 max_period; |
| 59 | u64 intel_ctrl; | 60 | u64 intel_ctrl; |
| 60 | }; | 61 | }; |
| @@ -66,6 +67,52 @@ static DEFINE_PER_CPU(struct cpu_hw_counters, cpu_hw_counters) = { | |||
| 66 | }; | 67 | }; |
| 67 | 68 | ||
| 68 | /* | 69 | /* |
| 70 | * Not sure about some of these | ||
| 71 | */ | ||
| 72 | static const u64 p6_perfmon_event_map[] = | ||
| 73 | { | ||
| 74 | [PERF_COUNT_HW_CPU_CYCLES] = 0x0079, | ||
| 75 | [PERF_COUNT_HW_INSTRUCTIONS] = 0x00c0, | ||
| 76 | [PERF_COUNT_HW_CACHE_REFERENCES] = 0x0f2e, | ||
| 77 | [PERF_COUNT_HW_CACHE_MISSES] = 0x012e, | ||
| 78 | [PERF_COUNT_HW_BRANCH_INSTRUCTIONS] = 0x00c4, | ||
| 79 | [PERF_COUNT_HW_BRANCH_MISSES] = 0x00c5, | ||
| 80 | [PERF_COUNT_HW_BUS_CYCLES] = 0x0062, | ||
| 81 | }; | ||
| 82 | |||
| 83 | static u64 p6_pmu_event_map(int event) | ||
| 84 | { | ||
| 85 | return p6_perfmon_event_map[event]; | ||
| 86 | } | ||
| 87 | |||
| 88 | /* | ||
| 89 | * Counter setting that is specified not to count anything. | ||
| 90 | * We use this to effectively disable a counter. | ||
| 91 | * | ||
| 92 | * L2_RQSTS with 0 MESI unit mask. | ||
| 93 | */ | ||
| 94 | #define P6_NOP_COUNTER 0x0000002EULL | ||
| 95 | |||
| 96 | static u64 p6_pmu_raw_event(u64 event) | ||
| 97 | { | ||
| 98 | #define P6_EVNTSEL_EVENT_MASK 0x000000FFULL | ||
| 99 | #define P6_EVNTSEL_UNIT_MASK 0x0000FF00ULL | ||
| 100 | #define P6_EVNTSEL_EDGE_MASK 0x00040000ULL | ||
| 101 | #define P6_EVNTSEL_INV_MASK 0x00800000ULL | ||
| 102 | #define P6_EVNTSEL_COUNTER_MASK 0xFF000000ULL | ||
| 103 | |||
| 104 | #define P6_EVNTSEL_MASK \ | ||
| 105 | (P6_EVNTSEL_EVENT_MASK | \ | ||
| 106 | P6_EVNTSEL_UNIT_MASK | \ | ||
| 107 | P6_EVNTSEL_EDGE_MASK | \ | ||
| 108 | P6_EVNTSEL_INV_MASK | \ | ||
| 109 | P6_EVNTSEL_COUNTER_MASK) | ||
| 110 | |||
| 111 | return event & P6_EVNTSEL_MASK; | ||
| 112 | } | ||
| 113 | |||
| 114 | |||
| 115 | /* | ||
| 69 | * Intel PerfMon v3. Used on Core2 and later. | 116 | * Intel PerfMon v3. Used on Core2 and later. |
| 70 | */ | 117 | */ |
| 71 | static const u64 intel_perfmon_event_map[] = | 118 | static const u64 intel_perfmon_event_map[] = |
| @@ -567,6 +614,7 @@ static DEFINE_MUTEX(pmc_reserve_mutex); | |||
| 567 | 614 | ||
| 568 | static bool reserve_pmc_hardware(void) | 615 | static bool reserve_pmc_hardware(void) |
| 569 | { | 616 | { |
| 617 | #ifdef CONFIG_X86_LOCAL_APIC | ||
| 570 | int i; | 618 | int i; |
| 571 | 619 | ||
| 572 | if (nmi_watchdog == NMI_LOCAL_APIC) | 620 | if (nmi_watchdog == NMI_LOCAL_APIC) |
| @@ -581,9 +629,11 @@ static bool reserve_pmc_hardware(void) | |||
| 581 | if (!reserve_evntsel_nmi(x86_pmu.eventsel + i)) | 629 | if (!reserve_evntsel_nmi(x86_pmu.eventsel + i)) |
| 582 | goto eventsel_fail; | 630 | goto eventsel_fail; |
| 583 | } | 631 | } |
| 632 | #endif | ||
| 584 | 633 | ||
| 585 | return true; | 634 | return true; |
| 586 | 635 | ||
| 636 | #ifdef CONFIG_X86_LOCAL_APIC | ||
| 587 | eventsel_fail: | 637 | eventsel_fail: |
| 588 | for (i--; i >= 0; i--) | 638 | for (i--; i >= 0; i--) |
| 589 | release_evntsel_nmi(x86_pmu.eventsel + i); | 639 | release_evntsel_nmi(x86_pmu.eventsel + i); |
| @@ -598,10 +648,12 @@ perfctr_fail: | |||
| 598 | enable_lapic_nmi_watchdog(); | 648 | enable_lapic_nmi_watchdog(); |
| 599 | 649 | ||
| 600 | return false; | 650 | return false; |
| 651 | #endif | ||
| 601 | } | 652 | } |
| 602 | 653 | ||
| 603 | static void release_pmc_hardware(void) | 654 | static void release_pmc_hardware(void) |
| 604 | { | 655 | { |
| 656 | #ifdef CONFIG_X86_LOCAL_APIC | ||
| 605 | int i; | 657 | int i; |
| 606 | 658 | ||
| 607 | for (i = 0; i < x86_pmu.num_counters; i++) { | 659 | for (i = 0; i < x86_pmu.num_counters; i++) { |
| @@ -611,6 +663,7 @@ static void release_pmc_hardware(void) | |||
| 611 | 663 | ||
| 612 | if (nmi_watchdog == NMI_LOCAL_APIC) | 664 | if (nmi_watchdog == NMI_LOCAL_APIC) |
| 613 | enable_lapic_nmi_watchdog(); | 665 | enable_lapic_nmi_watchdog(); |
| 666 | #endif | ||
| 614 | } | 667 | } |
| 615 | 668 | ||
| 616 | static void hw_perf_counter_destroy(struct perf_counter *counter) | 669 | static void hw_perf_counter_destroy(struct perf_counter *counter) |
| @@ -666,6 +719,7 @@ static int __hw_perf_counter_init(struct perf_counter *counter) | |||
| 666 | { | 719 | { |
| 667 | struct perf_counter_attr *attr = &counter->attr; | 720 | struct perf_counter_attr *attr = &counter->attr; |
| 668 | struct hw_perf_counter *hwc = &counter->hw; | 721 | struct hw_perf_counter *hwc = &counter->hw; |
| 722 | u64 config; | ||
| 669 | int err; | 723 | int err; |
| 670 | 724 | ||
| 671 | if (!x86_pmu_initialized()) | 725 | if (!x86_pmu_initialized()) |
| @@ -701,6 +755,15 @@ static int __hw_perf_counter_init(struct perf_counter *counter) | |||
| 701 | hwc->sample_period = x86_pmu.max_period; | 755 | hwc->sample_period = x86_pmu.max_period; |
| 702 | hwc->last_period = hwc->sample_period; | 756 | hwc->last_period = hwc->sample_period; |
| 703 | atomic64_set(&hwc->period_left, hwc->sample_period); | 757 | atomic64_set(&hwc->period_left, hwc->sample_period); |
| 758 | } else { | ||
| 759 | /* | ||
| 760 | * If we have a PMU initialized but no APIC | ||
| 761 | * interrupts, we cannot sample hardware | ||
| 762 | * counters (user-space has to fall back and | ||
| 763 | * sample via a hrtimer based software counter): | ||
| 764 | */ | ||
| 765 | if (!x86_pmu.apic) | ||
| 766 | return -EOPNOTSUPP; | ||
| 704 | } | 767 | } |
| 705 | 768 | ||
| 706 | counter->destroy = hw_perf_counter_destroy; | 769 | counter->destroy = hw_perf_counter_destroy; |
| @@ -718,14 +781,40 @@ static int __hw_perf_counter_init(struct perf_counter *counter) | |||
| 718 | 781 | ||
| 719 | if (attr->config >= x86_pmu.max_events) | 782 | if (attr->config >= x86_pmu.max_events) |
| 720 | return -EINVAL; | 783 | return -EINVAL; |
| 784 | |||
| 721 | /* | 785 | /* |
| 722 | * The generic map: | 786 | * The generic map: |
| 723 | */ | 787 | */ |
| 724 | hwc->config |= x86_pmu.event_map(attr->config); | 788 | config = x86_pmu.event_map(attr->config); |
| 789 | |||
| 790 | if (config == 0) | ||
| 791 | return -ENOENT; | ||
| 792 | |||
| 793 | if (config == -1LL) | ||
| 794 | return -EINVAL; | ||
| 795 | |||
| 796 | hwc->config |= config; | ||
| 725 | 797 | ||
| 726 | return 0; | 798 | return 0; |
| 727 | } | 799 | } |
| 728 | 800 | ||
| 801 | static void p6_pmu_disable_all(void) | ||
| 802 | { | ||
| 803 | struct cpu_hw_counters *cpuc = &__get_cpu_var(cpu_hw_counters); | ||
| 804 | u64 val; | ||
| 805 | |||
| 806 | if (!cpuc->enabled) | ||
| 807 | return; | ||
| 808 | |||
| 809 | cpuc->enabled = 0; | ||
| 810 | barrier(); | ||
| 811 | |||
| 812 | /* p6 only has one enable register */ | ||
| 813 | rdmsrl(MSR_P6_EVNTSEL0, val); | ||
| 814 | val &= ~ARCH_PERFMON_EVENTSEL0_ENABLE; | ||
| 815 | wrmsrl(MSR_P6_EVNTSEL0, val); | ||
| 816 | } | ||
| 817 | |||
| 729 | static void intel_pmu_disable_all(void) | 818 | static void intel_pmu_disable_all(void) |
| 730 | { | 819 | { |
| 731 | wrmsrl(MSR_CORE_PERF_GLOBAL_CTRL, 0); | 820 | wrmsrl(MSR_CORE_PERF_GLOBAL_CTRL, 0); |
| @@ -767,6 +856,23 @@ void hw_perf_disable(void) | |||
| 767 | return x86_pmu.disable_all(); | 856 | return x86_pmu.disable_all(); |
| 768 | } | 857 | } |
| 769 | 858 | ||
| 859 | static void p6_pmu_enable_all(void) | ||
| 860 | { | ||
| 861 | struct cpu_hw_counters *cpuc = &__get_cpu_var(cpu_hw_counters); | ||
| 862 | unsigned long val; | ||
| 863 | |||
| 864 | if (cpuc->enabled) | ||
| 865 | return; | ||
| 866 | |||
| 867 | cpuc->enabled = 1; | ||
| 868 | barrier(); | ||
| 869 | |||
| 870 | /* p6 only has one enable register */ | ||
| 871 | rdmsrl(MSR_P6_EVNTSEL0, val); | ||
| 872 | val |= ARCH_PERFMON_EVENTSEL0_ENABLE; | ||
| 873 | wrmsrl(MSR_P6_EVNTSEL0, val); | ||
| 874 | } | ||
| 875 | |||
| 770 | static void intel_pmu_enable_all(void) | 876 | static void intel_pmu_enable_all(void) |
| 771 | { | 877 | { |
| 772 | wrmsrl(MSR_CORE_PERF_GLOBAL_CTRL, x86_pmu.intel_ctrl); | 878 | wrmsrl(MSR_CORE_PERF_GLOBAL_CTRL, x86_pmu.intel_ctrl); |
| @@ -784,13 +890,13 @@ static void amd_pmu_enable_all(void) | |||
| 784 | barrier(); | 890 | barrier(); |
| 785 | 891 | ||
| 786 | for (idx = 0; idx < x86_pmu.num_counters; idx++) { | 892 | for (idx = 0; idx < x86_pmu.num_counters; idx++) { |
| 893 | struct perf_counter *counter = cpuc->counters[idx]; | ||
| 787 | u64 val; | 894 | u64 val; |
| 788 | 895 | ||
| 789 | if (!test_bit(idx, cpuc->active_mask)) | 896 | if (!test_bit(idx, cpuc->active_mask)) |
| 790 | continue; | 897 | continue; |
| 791 | rdmsrl(MSR_K7_EVNTSEL0 + idx, val); | 898 | |
| 792 | if (val & ARCH_PERFMON_EVENTSEL0_ENABLE) | 899 | val = counter->hw.config; |
| 793 | continue; | ||
| 794 | val |= ARCH_PERFMON_EVENTSEL0_ENABLE; | 900 | val |= ARCH_PERFMON_EVENTSEL0_ENABLE; |
| 795 | wrmsrl(MSR_K7_EVNTSEL0 + idx, val); | 901 | wrmsrl(MSR_K7_EVNTSEL0 + idx, val); |
| 796 | } | 902 | } |
| @@ -819,16 +925,13 @@ static inline void intel_pmu_ack_status(u64 ack) | |||
| 819 | 925 | ||
| 820 | static inline void x86_pmu_enable_counter(struct hw_perf_counter *hwc, int idx) | 926 | static inline void x86_pmu_enable_counter(struct hw_perf_counter *hwc, int idx) |
| 821 | { | 927 | { |
| 822 | int err; | 928 | (void)checking_wrmsrl(hwc->config_base + idx, |
| 823 | err = checking_wrmsrl(hwc->config_base + idx, | ||
| 824 | hwc->config | ARCH_PERFMON_EVENTSEL0_ENABLE); | 929 | hwc->config | ARCH_PERFMON_EVENTSEL0_ENABLE); |
| 825 | } | 930 | } |
| 826 | 931 | ||
| 827 | static inline void x86_pmu_disable_counter(struct hw_perf_counter *hwc, int idx) | 932 | static inline void x86_pmu_disable_counter(struct hw_perf_counter *hwc, int idx) |
| 828 | { | 933 | { |
| 829 | int err; | 934 | (void)checking_wrmsrl(hwc->config_base + idx, hwc->config); |
| 830 | err = checking_wrmsrl(hwc->config_base + idx, | ||
| 831 | hwc->config); | ||
| 832 | } | 935 | } |
| 833 | 936 | ||
| 834 | static inline void | 937 | static inline void |
| @@ -836,13 +939,24 @@ intel_pmu_disable_fixed(struct hw_perf_counter *hwc, int __idx) | |||
| 836 | { | 939 | { |
| 837 | int idx = __idx - X86_PMC_IDX_FIXED; | 940 | int idx = __idx - X86_PMC_IDX_FIXED; |
| 838 | u64 ctrl_val, mask; | 941 | u64 ctrl_val, mask; |
| 839 | int err; | ||
| 840 | 942 | ||
| 841 | mask = 0xfULL << (idx * 4); | 943 | mask = 0xfULL << (idx * 4); |
| 842 | 944 | ||
| 843 | rdmsrl(hwc->config_base, ctrl_val); | 945 | rdmsrl(hwc->config_base, ctrl_val); |
| 844 | ctrl_val &= ~mask; | 946 | ctrl_val &= ~mask; |
| 845 | err = checking_wrmsrl(hwc->config_base, ctrl_val); | 947 | (void)checking_wrmsrl(hwc->config_base, ctrl_val); |
| 948 | } | ||
| 949 | |||
| 950 | static inline void | ||
| 951 | p6_pmu_disable_counter(struct hw_perf_counter *hwc, int idx) | ||
| 952 | { | ||
| 953 | struct cpu_hw_counters *cpuc = &__get_cpu_var(cpu_hw_counters); | ||
| 954 | u64 val = P6_NOP_COUNTER; | ||
| 955 | |||
| 956 | if (cpuc->enabled) | ||
| 957 | val |= ARCH_PERFMON_EVENTSEL0_ENABLE; | ||
| 958 | |||
| 959 | (void)checking_wrmsrl(hwc->config_base + idx, val); | ||
| 846 | } | 960 | } |
| 847 | 961 | ||
| 848 | static inline void | 962 | static inline void |
| @@ -943,6 +1057,19 @@ intel_pmu_enable_fixed(struct hw_perf_counter *hwc, int __idx) | |||
| 943 | err = checking_wrmsrl(hwc->config_base, ctrl_val); | 1057 | err = checking_wrmsrl(hwc->config_base, ctrl_val); |
| 944 | } | 1058 | } |
| 945 | 1059 | ||
| 1060 | static void p6_pmu_enable_counter(struct hw_perf_counter *hwc, int idx) | ||
| 1061 | { | ||
| 1062 | struct cpu_hw_counters *cpuc = &__get_cpu_var(cpu_hw_counters); | ||
| 1063 | u64 val; | ||
| 1064 | |||
| 1065 | val = hwc->config; | ||
| 1066 | if (cpuc->enabled) | ||
| 1067 | val |= ARCH_PERFMON_EVENTSEL0_ENABLE; | ||
| 1068 | |||
| 1069 | (void)checking_wrmsrl(hwc->config_base + idx, val); | ||
| 1070 | } | ||
| 1071 | |||
| 1072 | |||
| 946 | static void intel_pmu_enable_counter(struct hw_perf_counter *hwc, int idx) | 1073 | static void intel_pmu_enable_counter(struct hw_perf_counter *hwc, int idx) |
| 947 | { | 1074 | { |
| 948 | if (unlikely(hwc->config_base == MSR_ARCH_PERFMON_FIXED_CTR_CTRL)) { | 1075 | if (unlikely(hwc->config_base == MSR_ARCH_PERFMON_FIXED_CTR_CTRL)) { |
| @@ -959,8 +1086,6 @@ static void amd_pmu_enable_counter(struct hw_perf_counter *hwc, int idx) | |||
| 959 | 1086 | ||
| 960 | if (cpuc->enabled) | 1087 | if (cpuc->enabled) |
| 961 | x86_pmu_enable_counter(hwc, idx); | 1088 | x86_pmu_enable_counter(hwc, idx); |
| 962 | else | ||
| 963 | x86_pmu_disable_counter(hwc, idx); | ||
| 964 | } | 1089 | } |
| 965 | 1090 | ||
| 966 | static int | 1091 | static int |
| @@ -1176,6 +1301,49 @@ static void intel_pmu_reset(void) | |||
| 1176 | local_irq_restore(flags); | 1301 | local_irq_restore(flags); |
| 1177 | } | 1302 | } |
| 1178 | 1303 | ||
| 1304 | static int p6_pmu_handle_irq(struct pt_regs *regs) | ||
| 1305 | { | ||
| 1306 | struct perf_sample_data data; | ||
| 1307 | struct cpu_hw_counters *cpuc; | ||
| 1308 | struct perf_counter *counter; | ||
| 1309 | struct hw_perf_counter *hwc; | ||
| 1310 | int idx, handled = 0; | ||
| 1311 | u64 val; | ||
| 1312 | |||
| 1313 | data.regs = regs; | ||
| 1314 | data.addr = 0; | ||
| 1315 | |||
| 1316 | cpuc = &__get_cpu_var(cpu_hw_counters); | ||
| 1317 | |||
| 1318 | for (idx = 0; idx < x86_pmu.num_counters; idx++) { | ||
| 1319 | if (!test_bit(idx, cpuc->active_mask)) | ||
| 1320 | continue; | ||
| 1321 | |||
| 1322 | counter = cpuc->counters[idx]; | ||
| 1323 | hwc = &counter->hw; | ||
| 1324 | |||
| 1325 | val = x86_perf_counter_update(counter, hwc, idx); | ||
| 1326 | if (val & (1ULL << (x86_pmu.counter_bits - 1))) | ||
| 1327 | continue; | ||
| 1328 | |||
| 1329 | /* | ||
| 1330 | * counter overflow | ||
| 1331 | */ | ||
| 1332 | handled = 1; | ||
| 1333 | data.period = counter->hw.last_period; | ||
| 1334 | |||
| 1335 | if (!x86_perf_counter_set_period(counter, hwc, idx)) | ||
| 1336 | continue; | ||
| 1337 | |||
| 1338 | if (perf_counter_overflow(counter, 1, &data)) | ||
| 1339 | p6_pmu_disable_counter(hwc, idx); | ||
| 1340 | } | ||
| 1341 | |||
| 1342 | if (handled) | ||
| 1343 | inc_irq_stat(apic_perf_irqs); | ||
| 1344 | |||
| 1345 | return handled; | ||
| 1346 | } | ||
| 1179 | 1347 | ||
| 1180 | /* | 1348 | /* |
| 1181 | * This handler is triggered by the local APIC, so the APIC IRQ handling | 1349 | * This handler is triggered by the local APIC, so the APIC IRQ handling |
| @@ -1185,14 +1353,13 @@ static int intel_pmu_handle_irq(struct pt_regs *regs) | |||
| 1185 | { | 1353 | { |
| 1186 | struct perf_sample_data data; | 1354 | struct perf_sample_data data; |
| 1187 | struct cpu_hw_counters *cpuc; | 1355 | struct cpu_hw_counters *cpuc; |
| 1188 | int bit, cpu, loops; | 1356 | int bit, loops; |
| 1189 | u64 ack, status; | 1357 | u64 ack, status; |
| 1190 | 1358 | ||
| 1191 | data.regs = regs; | 1359 | data.regs = regs; |
| 1192 | data.addr = 0; | 1360 | data.addr = 0; |
| 1193 | 1361 | ||
| 1194 | cpu = smp_processor_id(); | 1362 | cpuc = &__get_cpu_var(cpu_hw_counters); |
| 1195 | cpuc = &per_cpu(cpu_hw_counters, cpu); | ||
| 1196 | 1363 | ||
| 1197 | perf_disable(); | 1364 | perf_disable(); |
| 1198 | status = intel_pmu_get_status(); | 1365 | status = intel_pmu_get_status(); |
| @@ -1249,14 +1416,13 @@ static int amd_pmu_handle_irq(struct pt_regs *regs) | |||
| 1249 | struct cpu_hw_counters *cpuc; | 1416 | struct cpu_hw_counters *cpuc; |
| 1250 | struct perf_counter *counter; | 1417 | struct perf_counter *counter; |
| 1251 | struct hw_perf_counter *hwc; | 1418 | struct hw_perf_counter *hwc; |
| 1252 | int cpu, idx, handled = 0; | 1419 | int idx, handled = 0; |
| 1253 | u64 val; | 1420 | u64 val; |
| 1254 | 1421 | ||
| 1255 | data.regs = regs; | 1422 | data.regs = regs; |
| 1256 | data.addr = 0; | 1423 | data.addr = 0; |
| 1257 | 1424 | ||
| 1258 | cpu = smp_processor_id(); | 1425 | cpuc = &__get_cpu_var(cpu_hw_counters); |
| 1259 | cpuc = &per_cpu(cpu_hw_counters, cpu); | ||
| 1260 | 1426 | ||
| 1261 | for (idx = 0; idx < x86_pmu.num_counters; idx++) { | 1427 | for (idx = 0; idx < x86_pmu.num_counters; idx++) { |
| 1262 | if (!test_bit(idx, cpuc->active_mask)) | 1428 | if (!test_bit(idx, cpuc->active_mask)) |
| @@ -1299,18 +1465,22 @@ void smp_perf_pending_interrupt(struct pt_regs *regs) | |||
| 1299 | 1465 | ||
| 1300 | void set_perf_counter_pending(void) | 1466 | void set_perf_counter_pending(void) |
| 1301 | { | 1467 | { |
| 1468 | #ifdef CONFIG_X86_LOCAL_APIC | ||
| 1302 | apic->send_IPI_self(LOCAL_PENDING_VECTOR); | 1469 | apic->send_IPI_self(LOCAL_PENDING_VECTOR); |
| 1470 | #endif | ||
| 1303 | } | 1471 | } |
| 1304 | 1472 | ||
| 1305 | void perf_counters_lapic_init(void) | 1473 | void perf_counters_lapic_init(void) |
| 1306 | { | 1474 | { |
| 1307 | if (!x86_pmu_initialized()) | 1475 | #ifdef CONFIG_X86_LOCAL_APIC |
| 1476 | if (!x86_pmu.apic || !x86_pmu_initialized()) | ||
| 1308 | return; | 1477 | return; |
| 1309 | 1478 | ||
| 1310 | /* | 1479 | /* |
| 1311 | * Always use NMI for PMU | 1480 | * Always use NMI for PMU |
| 1312 | */ | 1481 | */ |
| 1313 | apic_write(APIC_LVTPC, APIC_DM_NMI); | 1482 | apic_write(APIC_LVTPC, APIC_DM_NMI); |
| 1483 | #endif | ||
| 1314 | } | 1484 | } |
| 1315 | 1485 | ||
| 1316 | static int __kprobes | 1486 | static int __kprobes |
| @@ -1334,7 +1504,9 @@ perf_counter_nmi_handler(struct notifier_block *self, | |||
| 1334 | 1504 | ||
| 1335 | regs = args->regs; | 1505 | regs = args->regs; |
| 1336 | 1506 | ||
| 1507 | #ifdef CONFIG_X86_LOCAL_APIC | ||
| 1337 | apic_write(APIC_LVTPC, APIC_DM_NMI); | 1508 | apic_write(APIC_LVTPC, APIC_DM_NMI); |
| 1509 | #endif | ||
| 1338 | /* | 1510 | /* |
| 1339 | * Can't rely on the handled return value to say it was our NMI, two | 1511 | * Can't rely on the handled return value to say it was our NMI, two |
| 1340 | * counters could trigger 'simultaneously' raising two back-to-back NMIs. | 1512 | * counters could trigger 'simultaneously' raising two back-to-back NMIs. |
| @@ -1353,6 +1525,33 @@ static __read_mostly struct notifier_block perf_counter_nmi_notifier = { | |||
| 1353 | .priority = 1 | 1525 | .priority = 1 |
| 1354 | }; | 1526 | }; |
| 1355 | 1527 | ||
| 1528 | static struct x86_pmu p6_pmu = { | ||
| 1529 | .name = "p6", | ||
| 1530 | .handle_irq = p6_pmu_handle_irq, | ||
| 1531 | .disable_all = p6_pmu_disable_all, | ||
| 1532 | .enable_all = p6_pmu_enable_all, | ||
| 1533 | .enable = p6_pmu_enable_counter, | ||
| 1534 | .disable = p6_pmu_disable_counter, | ||
| 1535 | .eventsel = MSR_P6_EVNTSEL0, | ||
| 1536 | .perfctr = MSR_P6_PERFCTR0, | ||
| 1537 | .event_map = p6_pmu_event_map, | ||
| 1538 | .raw_event = p6_pmu_raw_event, | ||
| 1539 | .max_events = ARRAY_SIZE(p6_perfmon_event_map), | ||
| 1540 | .apic = 1, | ||
| 1541 | .max_period = (1ULL << 31) - 1, | ||
| 1542 | .version = 0, | ||
| 1543 | .num_counters = 2, | ||
| 1544 | /* | ||
| 1545 | * Counters have 40 bits implemented. However they are designed such | ||
| 1546 | * that bits [32-39] are sign extensions of bit 31. As such the | ||
| 1547 | * effective width of a counter for P6-like PMU is 32 bits only. | ||
| 1548 | * | ||
| 1549 | * See IA-32 Intel Architecture Software developer manual Vol 3B | ||
| 1550 | */ | ||
| 1551 | .counter_bits = 32, | ||
| 1552 | .counter_mask = (1ULL << 32) - 1, | ||
| 1553 | }; | ||
| 1554 | |||
| 1356 | static struct x86_pmu intel_pmu = { | 1555 | static struct x86_pmu intel_pmu = { |
| 1357 | .name = "Intel", | 1556 | .name = "Intel", |
| 1358 | .handle_irq = intel_pmu_handle_irq, | 1557 | .handle_irq = intel_pmu_handle_irq, |
| @@ -1365,6 +1564,7 @@ static struct x86_pmu intel_pmu = { | |||
| 1365 | .event_map = intel_pmu_event_map, | 1564 | .event_map = intel_pmu_event_map, |
| 1366 | .raw_event = intel_pmu_raw_event, | 1565 | .raw_event = intel_pmu_raw_event, |
| 1367 | .max_events = ARRAY_SIZE(intel_perfmon_event_map), | 1566 | .max_events = ARRAY_SIZE(intel_perfmon_event_map), |
| 1567 | .apic = 1, | ||
| 1368 | /* | 1568 | /* |
| 1369 | * Intel PMCs cannot be accessed sanely above 32 bit width, | 1569 | * Intel PMCs cannot be accessed sanely above 32 bit width, |
| 1370 | * so we install an artificial 1<<31 period regardless of | 1570 | * so we install an artificial 1<<31 period regardless of |
| @@ -1388,10 +1588,43 @@ static struct x86_pmu amd_pmu = { | |||
| 1388 | .num_counters = 4, | 1588 | .num_counters = 4, |
| 1389 | .counter_bits = 48, | 1589 | .counter_bits = 48, |
| 1390 | .counter_mask = (1ULL << 48) - 1, | 1590 | .counter_mask = (1ULL << 48) - 1, |
| 1591 | .apic = 1, | ||
| 1391 | /* use highest bit to detect overflow */ | 1592 | /* use highest bit to detect overflow */ |
| 1392 | .max_period = (1ULL << 47) - 1, | 1593 | .max_period = (1ULL << 47) - 1, |
| 1393 | }; | 1594 | }; |
| 1394 | 1595 | ||
| 1596 | static int p6_pmu_init(void) | ||
| 1597 | { | ||
| 1598 | switch (boot_cpu_data.x86_model) { | ||
| 1599 | case 1: | ||
| 1600 | case 3: /* Pentium Pro */ | ||
| 1601 | case 5: | ||
| 1602 | case 6: /* Pentium II */ | ||
| 1603 | case 7: | ||
| 1604 | case 8: | ||
| 1605 | case 11: /* Pentium III */ | ||
| 1606 | break; | ||
| 1607 | case 9: | ||
| 1608 | case 13: | ||
| 1609 | /* Pentium M */ | ||
| 1610 | break; | ||
| 1611 | default: | ||
| 1612 | pr_cont("unsupported p6 CPU model %d ", | ||
| 1613 | boot_cpu_data.x86_model); | ||
| 1614 | return -ENODEV; | ||
| 1615 | } | ||
| 1616 | |||
| 1617 | x86_pmu = p6_pmu; | ||
| 1618 | |||
| 1619 | if (!cpu_has_apic) { | ||
| 1620 | pr_info("no APIC, boot with the \"lapic\" boot parameter to force-enable it.\n"); | ||
| 1621 | pr_info("no hardware sampling interrupt available.\n"); | ||
| 1622 | x86_pmu.apic = 0; | ||
| 1623 | } | ||
| 1624 | |||
| 1625 | return 0; | ||
| 1626 | } | ||
| 1627 | |||
| 1395 | static int intel_pmu_init(void) | 1628 | static int intel_pmu_init(void) |
| 1396 | { | 1629 | { |
| 1397 | union cpuid10_edx edx; | 1630 | union cpuid10_edx edx; |
| @@ -1400,8 +1633,14 @@ static int intel_pmu_init(void) | |||
| 1400 | unsigned int ebx; | 1633 | unsigned int ebx; |
| 1401 | int version; | 1634 | int version; |
| 1402 | 1635 | ||
| 1403 | if (!cpu_has(&boot_cpu_data, X86_FEATURE_ARCH_PERFMON)) | 1636 | if (!cpu_has(&boot_cpu_data, X86_FEATURE_ARCH_PERFMON)) { |
| 1637 | /* check for P6 processor family */ | ||
| 1638 | if (boot_cpu_data.x86 == 6) { | ||
| 1639 | return p6_pmu_init(); | ||
| 1640 | } else { | ||
| 1404 | return -ENODEV; | 1641 | return -ENODEV; |
| 1642 | } | ||
| 1643 | } | ||
| 1405 | 1644 | ||
| 1406 | /* | 1645 | /* |
| 1407 | * Check whether the Architectural PerfMon supports | 1646 | * Check whether the Architectural PerfMon supports |
diff --git a/arch/x86/kernel/efi.c b/arch/x86/kernel/efi.c index 96f7ac0bbf01..fe26ba3e3451 100644 --- a/arch/x86/kernel/efi.c +++ b/arch/x86/kernel/efi.c | |||
| @@ -354,7 +354,7 @@ void __init efi_init(void) | |||
| 354 | */ | 354 | */ |
| 355 | c16 = tmp = early_ioremap(efi.systab->fw_vendor, 2); | 355 | c16 = tmp = early_ioremap(efi.systab->fw_vendor, 2); |
| 356 | if (c16) { | 356 | if (c16) { |
| 357 | for (i = 0; i < sizeof(vendor) && *c16; ++i) | 357 | for (i = 0; i < sizeof(vendor) - 1 && *c16; ++i) |
| 358 | vendor[i] = *c16++; | 358 | vendor[i] = *c16++; |
| 359 | vendor[i] = '\0'; | 359 | vendor[i] = '\0'; |
| 360 | } else | 360 | } else |
| @@ -512,7 +512,7 @@ void __init efi_enter_virtual_mode(void) | |||
| 512 | && end_pfn <= max_pfn_mapped)) | 512 | && end_pfn <= max_pfn_mapped)) |
| 513 | va = __va(md->phys_addr); | 513 | va = __va(md->phys_addr); |
| 514 | else | 514 | else |
| 515 | va = efi_ioremap(md->phys_addr, size); | 515 | va = efi_ioremap(md->phys_addr, size, md->type); |
| 516 | 516 | ||
| 517 | md->virt_addr = (u64) (unsigned long) va; | 517 | md->virt_addr = (u64) (unsigned long) va; |
| 518 | 518 | ||
diff --git a/arch/x86/kernel/efi_64.c b/arch/x86/kernel/efi_64.c index 22c3b7828c50..ac0621a7ac3d 100644 --- a/arch/x86/kernel/efi_64.c +++ b/arch/x86/kernel/efi_64.c | |||
| @@ -98,10 +98,14 @@ void __init efi_call_phys_epilog(void) | |||
| 98 | early_runtime_code_mapping_set_exec(0); | 98 | early_runtime_code_mapping_set_exec(0); |
| 99 | } | 99 | } |
| 100 | 100 | ||
| 101 | void __iomem *__init efi_ioremap(unsigned long phys_addr, unsigned long size) | 101 | void __iomem *__init efi_ioremap(unsigned long phys_addr, unsigned long size, |
| 102 | u32 type) | ||
| 102 | { | 103 | { |
| 103 | unsigned long last_map_pfn; | 104 | unsigned long last_map_pfn; |
| 104 | 105 | ||
| 106 | if (type == EFI_MEMORY_MAPPED_IO) | ||
| 107 | return ioremap(phys_addr, size); | ||
| 108 | |||
| 105 | last_map_pfn = init_memory_mapping(phys_addr, phys_addr + size); | 109 | last_map_pfn = init_memory_mapping(phys_addr, phys_addr + size); |
| 106 | if ((last_map_pfn << PAGE_SHIFT) < phys_addr + size) | 110 | if ((last_map_pfn << PAGE_SHIFT) < phys_addr + size) |
| 107 | return NULL; | 111 | return NULL; |
diff --git a/arch/x86/kernel/head_32.S b/arch/x86/kernel/head_32.S index 8663afb56535..cc827ac9e8d3 100644 --- a/arch/x86/kernel/head_32.S +++ b/arch/x86/kernel/head_32.S | |||
| @@ -261,9 +261,7 @@ page_pde_offset = (__PAGE_OFFSET >> 20); | |||
| 261 | * which will be freed later | 261 | * which will be freed later |
| 262 | */ | 262 | */ |
| 263 | 263 | ||
| 264 | #ifndef CONFIG_HOTPLUG_CPU | 264 | __CPUINIT |
| 265 | .section .init.text,"ax",@progbits | ||
| 266 | #endif | ||
| 267 | 265 | ||
| 268 | #ifdef CONFIG_SMP | 266 | #ifdef CONFIG_SMP |
| 269 | ENTRY(startup_32_smp) | 267 | ENTRY(startup_32_smp) |
| @@ -602,7 +600,7 @@ ignore_int: | |||
| 602 | #endif | 600 | #endif |
| 603 | iret | 601 | iret |
| 604 | 602 | ||
| 605 | .section .cpuinit.data,"wa" | 603 | __REFDATA |
| 606 | .align 4 | 604 | .align 4 |
| 607 | ENTRY(initial_code) | 605 | ENTRY(initial_code) |
| 608 | .long i386_start_kernel | 606 | .long i386_start_kernel |
diff --git a/arch/x86/kernel/irqinit.c b/arch/x86/kernel/irqinit.c index 696f0e475c2d..92b7703d3d58 100644 --- a/arch/x86/kernel/irqinit.c +++ b/arch/x86/kernel/irqinit.c | |||
| @@ -187,7 +187,7 @@ static void __init apic_intr_init(void) | |||
| 187 | #ifdef CONFIG_X86_THERMAL_VECTOR | 187 | #ifdef CONFIG_X86_THERMAL_VECTOR |
| 188 | alloc_intr_gate(THERMAL_APIC_VECTOR, thermal_interrupt); | 188 | alloc_intr_gate(THERMAL_APIC_VECTOR, thermal_interrupt); |
| 189 | #endif | 189 | #endif |
| 190 | #ifdef CONFIG_X86_THRESHOLD | 190 | #ifdef CONFIG_X86_MCE_THRESHOLD |
| 191 | alloc_intr_gate(THRESHOLD_APIC_VECTOR, threshold_interrupt); | 191 | alloc_intr_gate(THRESHOLD_APIC_VECTOR, threshold_interrupt); |
| 192 | #endif | 192 | #endif |
| 193 | #if defined(CONFIG_X86_NEW_MCE) && defined(CONFIG_X86_LOCAL_APIC) | 193 | #if defined(CONFIG_X86_NEW_MCE) && defined(CONFIG_X86_LOCAL_APIC) |
diff --git a/arch/x86/kernel/mfgpt_32.c b/arch/x86/kernel/mfgpt_32.c index 846510b78a09..2a62d843f015 100644 --- a/arch/x86/kernel/mfgpt_32.c +++ b/arch/x86/kernel/mfgpt_32.c | |||
| @@ -347,7 +347,7 @@ static irqreturn_t mfgpt_tick(int irq, void *dev_id) | |||
| 347 | 347 | ||
| 348 | static struct irqaction mfgptirq = { | 348 | static struct irqaction mfgptirq = { |
| 349 | .handler = mfgpt_tick, | 349 | .handler = mfgpt_tick, |
| 350 | .flags = IRQF_DISABLED | IRQF_NOBALANCING, | 350 | .flags = IRQF_DISABLED | IRQF_NOBALANCING | IRQF_TIMER, |
| 351 | .name = "mfgpt-timer" | 351 | .name = "mfgpt-timer" |
| 352 | }; | 352 | }; |
| 353 | 353 | ||
diff --git a/arch/x86/kernel/process.c b/arch/x86/kernel/process.c index 994dd6a4a2a0..071166a4ba83 100644 --- a/arch/x86/kernel/process.c +++ b/arch/x86/kernel/process.c | |||
| @@ -519,16 +519,12 @@ static void c1e_idle(void) | |||
| 519 | if (!cpumask_test_cpu(cpu, c1e_mask)) { | 519 | if (!cpumask_test_cpu(cpu, c1e_mask)) { |
| 520 | cpumask_set_cpu(cpu, c1e_mask); | 520 | cpumask_set_cpu(cpu, c1e_mask); |
| 521 | /* | 521 | /* |
| 522 | * Force broadcast so ACPI can not interfere. Needs | 522 | * Force broadcast so ACPI can not interfere. |
| 523 | * to run with interrupts enabled as it uses | ||
| 524 | * smp_function_call. | ||
| 525 | */ | 523 | */ |
| 526 | local_irq_enable(); | ||
| 527 | clockevents_notify(CLOCK_EVT_NOTIFY_BROADCAST_FORCE, | 524 | clockevents_notify(CLOCK_EVT_NOTIFY_BROADCAST_FORCE, |
| 528 | &cpu); | 525 | &cpu); |
| 529 | printk(KERN_INFO "Switch to broadcast mode on CPU%d\n", | 526 | printk(KERN_INFO "Switch to broadcast mode on CPU%d\n", |
| 530 | cpu); | 527 | cpu); |
| 531 | local_irq_disable(); | ||
| 532 | } | 528 | } |
| 533 | clockevents_notify(CLOCK_EVT_NOTIFY_BROADCAST_ENTER, &cpu); | 529 | clockevents_notify(CLOCK_EVT_NOTIFY_BROADCAST_ENTER, &cpu); |
| 534 | 530 | ||
diff --git a/arch/x86/kernel/reboot.c b/arch/x86/kernel/reboot.c index 18ce5c04242a..27349f92a6d7 100644 --- a/arch/x86/kernel/reboot.c +++ b/arch/x86/kernel/reboot.c | |||
| @@ -3,6 +3,7 @@ | |||
| 3 | #include <linux/init.h> | 3 | #include <linux/init.h> |
| 4 | #include <linux/pm.h> | 4 | #include <linux/pm.h> |
| 5 | #include <linux/efi.h> | 5 | #include <linux/efi.h> |
| 6 | #include <linux/dmi.h> | ||
| 6 | #include <linux/tboot.h> | 7 | #include <linux/tboot.h> |
| 7 | #include <acpi/reboot.h> | 8 | #include <acpi/reboot.h> |
| 8 | #include <asm/io.h> | 9 | #include <asm/io.h> |
| @@ -18,7 +19,6 @@ | |||
| 18 | #include <asm/cpu.h> | 19 | #include <asm/cpu.h> |
| 19 | 20 | ||
| 20 | #ifdef CONFIG_X86_32 | 21 | #ifdef CONFIG_X86_32 |
| 21 | # include <linux/dmi.h> | ||
| 22 | # include <linux/ctype.h> | 22 | # include <linux/ctype.h> |
| 23 | # include <linux/mc146818rtc.h> | 23 | # include <linux/mc146818rtc.h> |
| 24 | #else | 24 | #else |
| @@ -250,6 +250,14 @@ static struct dmi_system_id __initdata reboot_dmi_table[] = { | |||
| 250 | DMI_MATCH(DMI_PRODUCT_NAME, "VGN-Z540N"), | 250 | DMI_MATCH(DMI_PRODUCT_NAME, "VGN-Z540N"), |
| 251 | }, | 251 | }, |
| 252 | }, | 252 | }, |
| 253 | { /* Handle problems with rebooting on CompuLab SBC-FITPC2 */ | ||
| 254 | .callback = set_bios_reboot, | ||
| 255 | .ident = "CompuLab SBC-FITPC2", | ||
| 256 | .matches = { | ||
| 257 | DMI_MATCH(DMI_SYS_VENDOR, "CompuLab"), | ||
| 258 | DMI_MATCH(DMI_PRODUCT_NAME, "SBC-FITPC2"), | ||
| 259 | }, | ||
| 260 | }, | ||
| 253 | { } | 261 | { } |
| 254 | }; | 262 | }; |
| 255 | 263 | ||
| @@ -397,6 +405,46 @@ EXPORT_SYMBOL(machine_real_restart); | |||
| 397 | 405 | ||
| 398 | #endif /* CONFIG_X86_32 */ | 406 | #endif /* CONFIG_X86_32 */ |
| 399 | 407 | ||
| 408 | /* | ||
| 409 | * Some Apple MacBook and MacBookPro's needs reboot=p to be able to reboot | ||
| 410 | */ | ||
| 411 | static int __init set_pci_reboot(const struct dmi_system_id *d) | ||
| 412 | { | ||
| 413 | if (reboot_type != BOOT_CF9) { | ||
| 414 | reboot_type = BOOT_CF9; | ||
| 415 | printk(KERN_INFO "%s series board detected. " | ||
| 416 | "Selecting PCI-method for reboots.\n", d->ident); | ||
| 417 | } | ||
| 418 | return 0; | ||
| 419 | } | ||
| 420 | |||
| 421 | static struct dmi_system_id __initdata pci_reboot_dmi_table[] = { | ||
| 422 | { /* Handle problems with rebooting on Apple MacBook5 */ | ||
| 423 | .callback = set_pci_reboot, | ||
| 424 | .ident = "Apple MacBook5", | ||
| 425 | .matches = { | ||
| 426 | DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | ||
| 427 | DMI_MATCH(DMI_PRODUCT_NAME, "MacBook5"), | ||
| 428 | }, | ||
| 429 | }, | ||
| 430 | { /* Handle problems with rebooting on Apple MacBookPro5 */ | ||
| 431 | .callback = set_pci_reboot, | ||
| 432 | .ident = "Apple MacBookPro5", | ||
| 433 | .matches = { | ||
| 434 | DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | ||
| 435 | DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro5"), | ||
| 436 | }, | ||
| 437 | }, | ||
| 438 | { } | ||
| 439 | }; | ||
| 440 | |||
| 441 | static int __init pci_reboot_init(void) | ||
| 442 | { | ||
| 443 | dmi_check_system(pci_reboot_dmi_table); | ||
| 444 | return 0; | ||
| 445 | } | ||
| 446 | core_initcall(pci_reboot_init); | ||
| 447 | |||
| 400 | static inline void kb_wait(void) | 448 | static inline void kb_wait(void) |
| 401 | { | 449 | { |
| 402 | int i; | 450 | int i; |
diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c index 6ce0d6f38f7f..61f86f241420 100644 --- a/arch/x86/kernel/setup.c +++ b/arch/x86/kernel/setup.c | |||
| @@ -673,6 +673,19 @@ static struct dmi_system_id __initdata bad_bios_dmi_table[] = { | |||
| 673 | DMI_MATCH(DMI_BIOS_VENDOR, "Phoenix Technologies"), | 673 | DMI_MATCH(DMI_BIOS_VENDOR, "Phoenix Technologies"), |
| 674 | }, | 674 | }, |
| 675 | }, | 675 | }, |
| 676 | { | ||
| 677 | /* | ||
| 678 | * AMI BIOS with low memory corruption was found on Intel DG45ID board. | ||
| 679 | * It hase different DMI_BIOS_VENDOR = "Intel Corp.", for now we will | ||
| 680 | * match only DMI_BOARD_NAME and see if there is more bad products | ||
| 681 | * with this vendor. | ||
| 682 | */ | ||
| 683 | .callback = dmi_low_memory_corruption, | ||
| 684 | .ident = "AMI BIOS", | ||
| 685 | .matches = { | ||
| 686 | DMI_MATCH(DMI_BOARD_NAME, "DG45ID"), | ||
| 687 | }, | ||
| 688 | }, | ||
| 676 | #endif | 689 | #endif |
| 677 | {} | 690 | {} |
| 678 | }; | 691 | }; |
diff --git a/arch/x86/kernel/setup_percpu.c b/arch/x86/kernel/setup_percpu.c index 29a3eef7cf4a..07d81916f212 100644 --- a/arch/x86/kernel/setup_percpu.c +++ b/arch/x86/kernel/setup_percpu.c | |||
| @@ -165,7 +165,7 @@ static ssize_t __init setup_pcpu_lpage(size_t static_size, bool chosen) | |||
| 165 | 165 | ||
| 166 | if (!chosen) { | 166 | if (!chosen) { |
| 167 | size_t vm_size = VMALLOC_END - VMALLOC_START; | 167 | size_t vm_size = VMALLOC_END - VMALLOC_START; |
| 168 | size_t tot_size = num_possible_cpus() * PMD_SIZE; | 168 | size_t tot_size = nr_cpu_ids * PMD_SIZE; |
| 169 | 169 | ||
| 170 | /* on non-NUMA, embedding is better */ | 170 | /* on non-NUMA, embedding is better */ |
| 171 | if (!pcpu_need_numa()) | 171 | if (!pcpu_need_numa()) |
| @@ -199,7 +199,7 @@ static ssize_t __init setup_pcpu_lpage(size_t static_size, bool chosen) | |||
| 199 | dyn_size = pcpul_size - static_size - PERCPU_FIRST_CHUNK_RESERVE; | 199 | dyn_size = pcpul_size - static_size - PERCPU_FIRST_CHUNK_RESERVE; |
| 200 | 200 | ||
| 201 | /* allocate pointer array and alloc large pages */ | 201 | /* allocate pointer array and alloc large pages */ |
| 202 | map_size = PFN_ALIGN(num_possible_cpus() * sizeof(pcpul_map[0])); | 202 | map_size = PFN_ALIGN(nr_cpu_ids * sizeof(pcpul_map[0])); |
| 203 | pcpul_map = alloc_bootmem(map_size); | 203 | pcpul_map = alloc_bootmem(map_size); |
| 204 | 204 | ||
| 205 | for_each_possible_cpu(cpu) { | 205 | for_each_possible_cpu(cpu) { |
| @@ -228,7 +228,7 @@ static ssize_t __init setup_pcpu_lpage(size_t static_size, bool chosen) | |||
| 228 | 228 | ||
| 229 | /* allocate address and map */ | 229 | /* allocate address and map */ |
| 230 | pcpul_vm.flags = VM_ALLOC; | 230 | pcpul_vm.flags = VM_ALLOC; |
| 231 | pcpul_vm.size = num_possible_cpus() * PMD_SIZE; | 231 | pcpul_vm.size = nr_cpu_ids * PMD_SIZE; |
| 232 | vm_area_register_early(&pcpul_vm, PMD_SIZE); | 232 | vm_area_register_early(&pcpul_vm, PMD_SIZE); |
| 233 | 233 | ||
| 234 | for_each_possible_cpu(cpu) { | 234 | for_each_possible_cpu(cpu) { |
| @@ -250,8 +250,8 @@ static ssize_t __init setup_pcpu_lpage(size_t static_size, bool chosen) | |||
| 250 | PMD_SIZE, pcpul_vm.addr, NULL); | 250 | PMD_SIZE, pcpul_vm.addr, NULL); |
| 251 | 251 | ||
| 252 | /* sort pcpul_map array for pcpu_lpage_remapped() */ | 252 | /* sort pcpul_map array for pcpu_lpage_remapped() */ |
| 253 | for (i = 0; i < num_possible_cpus() - 1; i++) | 253 | for (i = 0; i < nr_cpu_ids - 1; i++) |
| 254 | for (j = i + 1; j < num_possible_cpus(); j++) | 254 | for (j = i + 1; j < nr_cpu_ids; j++) |
| 255 | if (pcpul_map[i].ptr > pcpul_map[j].ptr) { | 255 | if (pcpul_map[i].ptr > pcpul_map[j].ptr) { |
| 256 | struct pcpul_ent tmp = pcpul_map[i]; | 256 | struct pcpul_ent tmp = pcpul_map[i]; |
| 257 | pcpul_map[i] = pcpul_map[j]; | 257 | pcpul_map[i] = pcpul_map[j]; |
| @@ -288,7 +288,7 @@ void *pcpu_lpage_remapped(void *kaddr) | |||
| 288 | { | 288 | { |
| 289 | void *pmd_addr = (void *)((unsigned long)kaddr & PMD_MASK); | 289 | void *pmd_addr = (void *)((unsigned long)kaddr & PMD_MASK); |
| 290 | unsigned long offset = (unsigned long)kaddr & ~PMD_MASK; | 290 | unsigned long offset = (unsigned long)kaddr & ~PMD_MASK; |
| 291 | int left = 0, right = num_possible_cpus() - 1; | 291 | int left = 0, right = nr_cpu_ids - 1; |
| 292 | int pos; | 292 | int pos; |
| 293 | 293 | ||
| 294 | /* pcpul in use at all? */ | 294 | /* pcpul in use at all? */ |
| @@ -377,7 +377,7 @@ static ssize_t __init setup_pcpu_4k(size_t static_size) | |||
| 377 | pcpu4k_nr_static_pages = PFN_UP(static_size); | 377 | pcpu4k_nr_static_pages = PFN_UP(static_size); |
| 378 | 378 | ||
| 379 | /* unaligned allocations can't be freed, round up to page size */ | 379 | /* unaligned allocations can't be freed, round up to page size */ |
| 380 | pages_size = PFN_ALIGN(pcpu4k_nr_static_pages * num_possible_cpus() | 380 | pages_size = PFN_ALIGN(pcpu4k_nr_static_pages * nr_cpu_ids |
| 381 | * sizeof(pcpu4k_pages[0])); | 381 | * sizeof(pcpu4k_pages[0])); |
| 382 | pcpu4k_pages = alloc_bootmem(pages_size); | 382 | pcpu4k_pages = alloc_bootmem(pages_size); |
| 383 | 383 | ||
diff --git a/arch/x86/kernel/tlb_uv.c b/arch/x86/kernel/tlb_uv.c index 8ccabb8a2f6a..77b9689f8edb 100644 --- a/arch/x86/kernel/tlb_uv.c +++ b/arch/x86/kernel/tlb_uv.c | |||
| @@ -744,6 +744,7 @@ uv_activation_descriptor_init(int node, int pnode) | |||
| 744 | * note that base_dest_nodeid is actually a nasid. | 744 | * note that base_dest_nodeid is actually a nasid. |
| 745 | */ | 745 | */ |
| 746 | ad2->header.base_dest_nodeid = uv_partition_base_pnode << 1; | 746 | ad2->header.base_dest_nodeid = uv_partition_base_pnode << 1; |
| 747 | ad2->header.dest_subnodeid = 0x10; /* the LB */ | ||
| 747 | ad2->header.command = UV_NET_ENDPOINT_INTD; | 748 | ad2->header.command = UV_NET_ENDPOINT_INTD; |
| 748 | ad2->header.int_both = 1; | 749 | ad2->header.int_both = 1; |
| 749 | /* | 750 | /* |
diff --git a/arch/x86/kernel/tsc.c b/arch/x86/kernel/tsc.c index 6e1a368d21d4..71f4368b357e 100644 --- a/arch/x86/kernel/tsc.c +++ b/arch/x86/kernel/tsc.c | |||
| @@ -275,15 +275,20 @@ static unsigned long pit_calibrate_tsc(u32 latch, unsigned long ms, int loopmin) | |||
| 275 | * use the TSC value at the transitions to calculate a pretty | 275 | * use the TSC value at the transitions to calculate a pretty |
| 276 | * good value for the TSC frequencty. | 276 | * good value for the TSC frequencty. |
| 277 | */ | 277 | */ |
| 278 | static inline int pit_verify_msb(unsigned char val) | ||
| 279 | { | ||
| 280 | /* Ignore LSB */ | ||
| 281 | inb(0x42); | ||
| 282 | return inb(0x42) == val; | ||
| 283 | } | ||
| 284 | |||
| 278 | static inline int pit_expect_msb(unsigned char val, u64 *tscp, unsigned long *deltap) | 285 | static inline int pit_expect_msb(unsigned char val, u64 *tscp, unsigned long *deltap) |
| 279 | { | 286 | { |
| 280 | int count; | 287 | int count; |
| 281 | u64 tsc = 0; | 288 | u64 tsc = 0; |
| 282 | 289 | ||
| 283 | for (count = 0; count < 50000; count++) { | 290 | for (count = 0; count < 50000; count++) { |
| 284 | /* Ignore LSB */ | 291 | if (!pit_verify_msb(val)) |
| 285 | inb(0x42); | ||
| 286 | if (inb(0x42) != val) | ||
| 287 | break; | 292 | break; |
| 288 | tsc = get_cycles(); | 293 | tsc = get_cycles(); |
| 289 | } | 294 | } |
| @@ -336,8 +341,7 @@ static unsigned long quick_pit_calibrate(void) | |||
| 336 | * to do that is to just read back the 16-bit counter | 341 | * to do that is to just read back the 16-bit counter |
| 337 | * once from the PIT. | 342 | * once from the PIT. |
| 338 | */ | 343 | */ |
| 339 | inb(0x42); | 344 | pit_verify_msb(0); |
| 340 | inb(0x42); | ||
| 341 | 345 | ||
| 342 | if (pit_expect_msb(0xff, &tsc, &d1)) { | 346 | if (pit_expect_msb(0xff, &tsc, &d1)) { |
| 343 | for (i = 1; i <= MAX_QUICK_PIT_ITERATIONS; i++) { | 347 | for (i = 1; i <= MAX_QUICK_PIT_ITERATIONS; i++) { |
| @@ -348,8 +352,19 @@ static unsigned long quick_pit_calibrate(void) | |||
| 348 | * Iterate until the error is less than 500 ppm | 352 | * Iterate until the error is less than 500 ppm |
| 349 | */ | 353 | */ |
| 350 | delta -= tsc; | 354 | delta -= tsc; |
| 351 | if (d1+d2 < delta >> 11) | 355 | if (d1+d2 >= delta >> 11) |
| 352 | goto success; | 356 | continue; |
| 357 | |||
| 358 | /* | ||
| 359 | * Check the PIT one more time to verify that | ||
| 360 | * all TSC reads were stable wrt the PIT. | ||
| 361 | * | ||
| 362 | * This also guarantees serialization of the | ||
| 363 | * last cycle read ('d2') in pit_expect_msb. | ||
| 364 | */ | ||
| 365 | if (!pit_verify_msb(0xfe - i)) | ||
| 366 | break; | ||
| 367 | goto success; | ||
| 353 | } | 368 | } |
| 354 | } | 369 | } |
| 355 | printk("Fast TSC calibration failed\n"); | 370 | printk("Fast TSC calibration failed\n"); |
diff --git a/arch/x86/kernel/vmi_32.c b/arch/x86/kernel/vmi_32.c index b263423fbe2a..95a7289e4b0c 100644 --- a/arch/x86/kernel/vmi_32.c +++ b/arch/x86/kernel/vmi_32.c | |||
| @@ -441,7 +441,7 @@ vmi_startup_ipi_hook(int phys_apicid, unsigned long start_eip, | |||
| 441 | ap.ds = __USER_DS; | 441 | ap.ds = __USER_DS; |
| 442 | ap.es = __USER_DS; | 442 | ap.es = __USER_DS; |
| 443 | ap.fs = __KERNEL_PERCPU; | 443 | ap.fs = __KERNEL_PERCPU; |
| 444 | ap.gs = 0; | 444 | ap.gs = __KERNEL_STACK_CANARY; |
| 445 | 445 | ||
| 446 | ap.eflags = 0; | 446 | ap.eflags = 0; |
| 447 | 447 | ||
diff --git a/arch/x86/kernel/vmlinux.lds.S b/arch/x86/kernel/vmlinux.lds.S index 367e87882041..9fc178255c04 100644 --- a/arch/x86/kernel/vmlinux.lds.S +++ b/arch/x86/kernel/vmlinux.lds.S | |||
| @@ -46,11 +46,10 @@ PHDRS { | |||
| 46 | data PT_LOAD FLAGS(7); /* RWE */ | 46 | data PT_LOAD FLAGS(7); /* RWE */ |
| 47 | #ifdef CONFIG_X86_64 | 47 | #ifdef CONFIG_X86_64 |
| 48 | user PT_LOAD FLAGS(7); /* RWE */ | 48 | user PT_LOAD FLAGS(7); /* RWE */ |
| 49 | data.init PT_LOAD FLAGS(7); /* RWE */ | ||
| 50 | #ifdef CONFIG_SMP | 49 | #ifdef CONFIG_SMP |
| 51 | percpu PT_LOAD FLAGS(7); /* RWE */ | 50 | percpu PT_LOAD FLAGS(7); /* RWE */ |
| 52 | #endif | 51 | #endif |
| 53 | data.init2 PT_LOAD FLAGS(7); /* RWE */ | 52 | init PT_LOAD FLAGS(7); /* RWE */ |
| 54 | #endif | 53 | #endif |
| 55 | note PT_NOTE FLAGS(0); /* ___ */ | 54 | note PT_NOTE FLAGS(0); /* ___ */ |
| 56 | } | 55 | } |
| @@ -103,72 +102,43 @@ SECTIONS | |||
| 103 | __stop___ex_table = .; | 102 | __stop___ex_table = .; |
| 104 | } :text = 0x9090 | 103 | } :text = 0x9090 |
| 105 | 104 | ||
| 106 | RODATA | 105 | RO_DATA(PAGE_SIZE) |
| 107 | 106 | ||
| 108 | /* Data */ | 107 | /* Data */ |
| 109 | . = ALIGN(PAGE_SIZE); | ||
| 110 | .data : AT(ADDR(.data) - LOAD_OFFSET) { | 108 | .data : AT(ADDR(.data) - LOAD_OFFSET) { |
| 111 | /* Start of data section */ | 109 | /* Start of data section */ |
| 112 | _sdata = .; | 110 | _sdata = .; |
| 113 | DATA_DATA | ||
| 114 | CONSTRUCTORS | ||
| 115 | 111 | ||
| 116 | #ifdef CONFIG_X86_64 | 112 | /* init_task */ |
| 117 | /* End of data section */ | 113 | INIT_TASK_DATA(THREAD_SIZE) |
| 118 | _edata = .; | ||
| 119 | #endif | ||
| 120 | } :data | ||
| 121 | 114 | ||
| 122 | #ifdef CONFIG_X86_32 | 115 | #ifdef CONFIG_X86_32 |
| 123 | /* 32 bit has nosave before _edata */ | 116 | /* 32 bit has nosave before _edata */ |
| 124 | . = ALIGN(PAGE_SIZE); | 117 | NOSAVE_DATA |
| 125 | .data_nosave : AT(ADDR(.data_nosave) - LOAD_OFFSET) { | ||
| 126 | __nosave_begin = .; | ||
| 127 | *(.data.nosave) | ||
| 128 | . = ALIGN(PAGE_SIZE); | ||
| 129 | __nosave_end = .; | ||
| 130 | } | ||
| 131 | #endif | 118 | #endif |
| 132 | 119 | ||
| 133 | . = ALIGN(PAGE_SIZE); | 120 | PAGE_ALIGNED_DATA(PAGE_SIZE) |
| 134 | .data.page_aligned : AT(ADDR(.data.page_aligned) - LOAD_OFFSET) { | ||
| 135 | *(.data.page_aligned) | ||
| 136 | *(.data.idt) | 121 | *(.data.idt) |
| 137 | } | ||
| 138 | 122 | ||
| 139 | #ifdef CONFIG_X86_32 | 123 | CACHELINE_ALIGNED_DATA(CONFIG_X86_L1_CACHE_BYTES) |
| 140 | . = ALIGN(32); | ||
| 141 | #else | ||
| 142 | . = ALIGN(PAGE_SIZE); | ||
| 143 | . = ALIGN(CONFIG_X86_L1_CACHE_BYTES); | ||
| 144 | #endif | ||
| 145 | .data.cacheline_aligned : | ||
| 146 | AT(ADDR(.data.cacheline_aligned) - LOAD_OFFSET) { | ||
| 147 | *(.data.cacheline_aligned) | ||
| 148 | } | ||
| 149 | 124 | ||
| 150 | /* rarely changed data like cpu maps */ | 125 | DATA_DATA |
| 151 | #ifdef CONFIG_X86_32 | 126 | CONSTRUCTORS |
| 152 | . = ALIGN(32); | 127 | |
| 153 | #else | 128 | /* rarely changed data like cpu maps */ |
| 154 | . = ALIGN(CONFIG_X86_INTERNODE_CACHE_BYTES); | 129 | READ_MOSTLY_DATA(CONFIG_X86_INTERNODE_CACHE_BYTES) |
| 155 | #endif | ||
| 156 | .data.read_mostly : AT(ADDR(.data.read_mostly) - LOAD_OFFSET) { | ||
| 157 | *(.data.read_mostly) | ||
| 158 | 130 | ||
| 159 | #ifdef CONFIG_X86_32 | ||
| 160 | /* End of data section */ | 131 | /* End of data section */ |
| 161 | _edata = .; | 132 | _edata = .; |
| 162 | #endif | 133 | } :data |
| 163 | } | ||
| 164 | 134 | ||
| 165 | #ifdef CONFIG_X86_64 | 135 | #ifdef CONFIG_X86_64 |
| 166 | 136 | ||
| 167 | #define VSYSCALL_ADDR (-10*1024*1024) | 137 | #define VSYSCALL_ADDR (-10*1024*1024) |
| 168 | #define VSYSCALL_PHYS_ADDR ((LOADADDR(.data.read_mostly) + \ | 138 | #define VSYSCALL_PHYS_ADDR ((LOADADDR(.data) + SIZEOF(.data) + \ |
| 169 | SIZEOF(.data.read_mostly) + 4095) & ~(4095)) | 139 | PAGE_SIZE - 1) & ~(PAGE_SIZE - 1)) |
| 170 | #define VSYSCALL_VIRT_ADDR ((ADDR(.data.read_mostly) + \ | 140 | #define VSYSCALL_VIRT_ADDR ((ADDR(.data) + SIZEOF(.data) + \ |
| 171 | SIZEOF(.data.read_mostly) + 4095) & ~(4095)) | 141 | PAGE_SIZE - 1) & ~(PAGE_SIZE - 1)) |
| 172 | 142 | ||
| 173 | #define VLOAD_OFFSET (VSYSCALL_ADDR - VSYSCALL_PHYS_ADDR) | 143 | #define VLOAD_OFFSET (VSYSCALL_ADDR - VSYSCALL_PHYS_ADDR) |
| 174 | #define VLOAD(x) (ADDR(x) - VLOAD_OFFSET) | 144 | #define VLOAD(x) (ADDR(x) - VLOAD_OFFSET) |
| @@ -234,35 +204,29 @@ SECTIONS | |||
| 234 | 204 | ||
| 235 | #endif /* CONFIG_X86_64 */ | 205 | #endif /* CONFIG_X86_64 */ |
| 236 | 206 | ||
| 237 | /* init_task */ | 207 | /* Init code and data - will be freed after init */ |
| 238 | . = ALIGN(THREAD_SIZE); | 208 | . = ALIGN(PAGE_SIZE); |
| 239 | .data.init_task : AT(ADDR(.data.init_task) - LOAD_OFFSET) { | 209 | .init.begin : AT(ADDR(.init.begin) - LOAD_OFFSET) { |
| 240 | *(.data.init_task) | 210 | __init_begin = .; /* paired with __init_end */ |
| 241 | } | 211 | } |
| 242 | #ifdef CONFIG_X86_64 | ||
| 243 | :data.init | ||
| 244 | #endif | ||
| 245 | 212 | ||
| 213 | #if defined(CONFIG_X86_64) && defined(CONFIG_SMP) | ||
| 246 | /* | 214 | /* |
| 247 | * smp_locks might be freed after init | 215 | * percpu offsets are zero-based on SMP. PERCPU_VADDR() changes the |
| 248 | * start/end must be page aligned | 216 | * output PHDR, so the next output section - .init.text - should |
| 217 | * start another segment - init. | ||
| 249 | */ | 218 | */ |
| 250 | . = ALIGN(PAGE_SIZE); | 219 | PERCPU_VADDR(0, :percpu) |
| 251 | .smp_locks : AT(ADDR(.smp_locks) - LOAD_OFFSET) { | 220 | #endif |
| 252 | __smp_locks = .; | ||
| 253 | *(.smp_locks) | ||
| 254 | __smp_locks_end = .; | ||
| 255 | . = ALIGN(PAGE_SIZE); | ||
| 256 | } | ||
| 257 | 221 | ||
| 258 | /* Init code and data - will be freed after init */ | ||
| 259 | . = ALIGN(PAGE_SIZE); | ||
| 260 | .init.text : AT(ADDR(.init.text) - LOAD_OFFSET) { | 222 | .init.text : AT(ADDR(.init.text) - LOAD_OFFSET) { |
| 261 | __init_begin = .; /* paired with __init_end */ | ||
| 262 | _sinittext = .; | 223 | _sinittext = .; |
| 263 | INIT_TEXT | 224 | INIT_TEXT |
| 264 | _einittext = .; | 225 | _einittext = .; |
| 265 | } | 226 | } |
| 227 | #ifdef CONFIG_X86_64 | ||
| 228 | :init | ||
| 229 | #endif | ||
| 266 | 230 | ||
| 267 | .init.data : AT(ADDR(.init.data) - LOAD_OFFSET) { | 231 | .init.data : AT(ADDR(.init.data) - LOAD_OFFSET) { |
| 268 | INIT_DATA | 232 | INIT_DATA |
| @@ -333,17 +297,7 @@ SECTIONS | |||
| 333 | } | 297 | } |
| 334 | #endif | 298 | #endif |
| 335 | 299 | ||
| 336 | #if defined(CONFIG_X86_64) && defined(CONFIG_SMP) | 300 | #if !defined(CONFIG_X86_64) || !defined(CONFIG_SMP) |
| 337 | /* | ||
| 338 | * percpu offsets are zero-based on SMP. PERCPU_VADDR() changes the | ||
| 339 | * output PHDR, so the next output section - __data_nosave - should | ||
| 340 | * start another section data.init2. Also, pda should be at the head of | ||
| 341 | * percpu area. Preallocate it and define the percpu offset symbol | ||
| 342 | * so that it can be accessed as a percpu variable. | ||
| 343 | */ | ||
| 344 | . = ALIGN(PAGE_SIZE); | ||
| 345 | PERCPU_VADDR(0, :percpu) | ||
| 346 | #else | ||
| 347 | PERCPU(PAGE_SIZE) | 301 | PERCPU(PAGE_SIZE) |
| 348 | #endif | 302 | #endif |
| 349 | 303 | ||
| @@ -354,15 +308,22 @@ SECTIONS | |||
| 354 | __init_end = .; | 308 | __init_end = .; |
| 355 | } | 309 | } |
| 356 | 310 | ||
| 311 | /* | ||
| 312 | * smp_locks might be freed after init | ||
| 313 | * start/end must be page aligned | ||
| 314 | */ | ||
| 315 | . = ALIGN(PAGE_SIZE); | ||
| 316 | .smp_locks : AT(ADDR(.smp_locks) - LOAD_OFFSET) { | ||
| 317 | __smp_locks = .; | ||
| 318 | *(.smp_locks) | ||
| 319 | __smp_locks_end = .; | ||
| 320 | . = ALIGN(PAGE_SIZE); | ||
| 321 | } | ||
| 322 | |||
| 357 | #ifdef CONFIG_X86_64 | 323 | #ifdef CONFIG_X86_64 |
| 358 | .data_nosave : AT(ADDR(.data_nosave) - LOAD_OFFSET) { | 324 | .data_nosave : AT(ADDR(.data_nosave) - LOAD_OFFSET) { |
| 359 | . = ALIGN(PAGE_SIZE); | 325 | NOSAVE_DATA |
| 360 | __nosave_begin = .; | 326 | } |
| 361 | *(.data.nosave) | ||
| 362 | . = ALIGN(PAGE_SIZE); | ||
| 363 | __nosave_end = .; | ||
| 364 | } :data.init2 | ||
| 365 | /* use another section data.init2, see PERCPU_VADDR() above */ | ||
| 366 | #endif | 327 | #endif |
| 367 | 328 | ||
| 368 | /* BSS */ | 329 | /* BSS */ |
| @@ -400,8 +361,8 @@ SECTIONS | |||
| 400 | 361 | ||
| 401 | 362 | ||
| 402 | #ifdef CONFIG_X86_32 | 363 | #ifdef CONFIG_X86_32 |
| 403 | ASSERT((_end - LOAD_OFFSET <= KERNEL_IMAGE_SIZE), | 364 | . = ASSERT((_end - LOAD_OFFSET <= KERNEL_IMAGE_SIZE), |
| 404 | "kernel image bigger than KERNEL_IMAGE_SIZE") | 365 | "kernel image bigger than KERNEL_IMAGE_SIZE"); |
| 405 | #else | 366 | #else |
| 406 | /* | 367 | /* |
| 407 | * Per-cpu symbols which need to be offset from __per_cpu_load | 368 | * Per-cpu symbols which need to be offset from __per_cpu_load |
| @@ -414,12 +375,12 @@ INIT_PER_CPU(irq_stack_union); | |||
| 414 | /* | 375 | /* |
| 415 | * Build-time check on the image size: | 376 | * Build-time check on the image size: |
| 416 | */ | 377 | */ |
| 417 | ASSERT((_end - _text <= KERNEL_IMAGE_SIZE), | 378 | . = ASSERT((_end - _text <= KERNEL_IMAGE_SIZE), |
| 418 | "kernel image bigger than KERNEL_IMAGE_SIZE") | 379 | "kernel image bigger than KERNEL_IMAGE_SIZE"); |
| 419 | 380 | ||
| 420 | #ifdef CONFIG_SMP | 381 | #ifdef CONFIG_SMP |
| 421 | ASSERT((per_cpu__irq_stack_union == 0), | 382 | . = ASSERT((per_cpu__irq_stack_union == 0), |
| 422 | "irq_stack_union is not at start of per-cpu area"); | 383 | "irq_stack_union is not at start of per-cpu area"); |
| 423 | #endif | 384 | #endif |
| 424 | 385 | ||
| 425 | #endif /* CONFIG_X86_32 */ | 386 | #endif /* CONFIG_X86_32 */ |
| @@ -427,7 +388,7 @@ ASSERT((per_cpu__irq_stack_union == 0), | |||
| 427 | #ifdef CONFIG_KEXEC | 388 | #ifdef CONFIG_KEXEC |
| 428 | #include <asm/kexec.h> | 389 | #include <asm/kexec.h> |
| 429 | 390 | ||
| 430 | ASSERT(kexec_control_code_size <= KEXEC_CONTROL_CODE_MAX_SIZE, | 391 | . = ASSERT(kexec_control_code_size <= KEXEC_CONTROL_CODE_MAX_SIZE, |
| 431 | "kexec control code size is too big") | 392 | "kexec control code size is too big"); |
| 432 | #endif | 393 | #endif |
| 433 | 394 | ||
diff --git a/arch/x86/kvm/i8254.c b/arch/x86/kvm/i8254.c index 4d6f0d293ee2..21f68e00524f 100644 --- a/arch/x86/kvm/i8254.c +++ b/arch/x86/kvm/i8254.c | |||
| @@ -104,6 +104,9 @@ static s64 __kpit_elapsed(struct kvm *kvm) | |||
| 104 | ktime_t remaining; | 104 | ktime_t remaining; |
| 105 | struct kvm_kpit_state *ps = &kvm->arch.vpit->pit_state; | 105 | struct kvm_kpit_state *ps = &kvm->arch.vpit->pit_state; |
| 106 | 106 | ||
| 107 | if (!ps->pit_timer.period) | ||
| 108 | return 0; | ||
| 109 | |||
| 107 | /* | 110 | /* |
| 108 | * The Counter does not stop when it reaches zero. In | 111 | * The Counter does not stop when it reaches zero. In |
| 109 | * Modes 0, 1, 4, and 5 the Counter ``wraps around'' to | 112 | * Modes 0, 1, 4, and 5 the Counter ``wraps around'' to |
diff --git a/arch/x86/kvm/mmu.c b/arch/x86/kvm/mmu.c index 7030b5f911bf..0ef5bb2b4043 100644 --- a/arch/x86/kvm/mmu.c +++ b/arch/x86/kvm/mmu.c | |||
| @@ -489,16 +489,20 @@ static unsigned long *gfn_to_rmap(struct kvm *kvm, gfn_t gfn, int lpage) | |||
| 489 | * | 489 | * |
| 490 | * If rmapp bit zero is one, (then rmap & ~1) points to a struct kvm_rmap_desc | 490 | * If rmapp bit zero is one, (then rmap & ~1) points to a struct kvm_rmap_desc |
| 491 | * containing more mappings. | 491 | * containing more mappings. |
| 492 | * | ||
| 493 | * Returns the number of rmap entries before the spte was added or zero if | ||
| 494 | * the spte was not added. | ||
| 495 | * | ||
| 492 | */ | 496 | */ |
| 493 | static void rmap_add(struct kvm_vcpu *vcpu, u64 *spte, gfn_t gfn, int lpage) | 497 | static int rmap_add(struct kvm_vcpu *vcpu, u64 *spte, gfn_t gfn, int lpage) |
| 494 | { | 498 | { |
| 495 | struct kvm_mmu_page *sp; | 499 | struct kvm_mmu_page *sp; |
| 496 | struct kvm_rmap_desc *desc; | 500 | struct kvm_rmap_desc *desc; |
| 497 | unsigned long *rmapp; | 501 | unsigned long *rmapp; |
| 498 | int i; | 502 | int i, count = 0; |
| 499 | 503 | ||
| 500 | if (!is_rmap_pte(*spte)) | 504 | if (!is_rmap_pte(*spte)) |
| 501 | return; | 505 | return count; |
| 502 | gfn = unalias_gfn(vcpu->kvm, gfn); | 506 | gfn = unalias_gfn(vcpu->kvm, gfn); |
| 503 | sp = page_header(__pa(spte)); | 507 | sp = page_header(__pa(spte)); |
| 504 | sp->gfns[spte - sp->spt] = gfn; | 508 | sp->gfns[spte - sp->spt] = gfn; |
| @@ -515,8 +519,10 @@ static void rmap_add(struct kvm_vcpu *vcpu, u64 *spte, gfn_t gfn, int lpage) | |||
| 515 | } else { | 519 | } else { |
| 516 | rmap_printk("rmap_add: %p %llx many->many\n", spte, *spte); | 520 | rmap_printk("rmap_add: %p %llx many->many\n", spte, *spte); |
| 517 | desc = (struct kvm_rmap_desc *)(*rmapp & ~1ul); | 521 | desc = (struct kvm_rmap_desc *)(*rmapp & ~1ul); |
| 518 | while (desc->shadow_ptes[RMAP_EXT-1] && desc->more) | 522 | while (desc->shadow_ptes[RMAP_EXT-1] && desc->more) { |
| 519 | desc = desc->more; | 523 | desc = desc->more; |
| 524 | count += RMAP_EXT; | ||
| 525 | } | ||
| 520 | if (desc->shadow_ptes[RMAP_EXT-1]) { | 526 | if (desc->shadow_ptes[RMAP_EXT-1]) { |
| 521 | desc->more = mmu_alloc_rmap_desc(vcpu); | 527 | desc->more = mmu_alloc_rmap_desc(vcpu); |
| 522 | desc = desc->more; | 528 | desc = desc->more; |
| @@ -525,6 +531,7 @@ static void rmap_add(struct kvm_vcpu *vcpu, u64 *spte, gfn_t gfn, int lpage) | |||
| 525 | ; | 531 | ; |
| 526 | desc->shadow_ptes[i] = spte; | 532 | desc->shadow_ptes[i] = spte; |
| 527 | } | 533 | } |
| 534 | return count; | ||
| 528 | } | 535 | } |
| 529 | 536 | ||
| 530 | static void rmap_desc_remove_entry(unsigned long *rmapp, | 537 | static void rmap_desc_remove_entry(unsigned long *rmapp, |
| @@ -754,6 +761,19 @@ static int kvm_age_rmapp(struct kvm *kvm, unsigned long *rmapp) | |||
| 754 | return young; | 761 | return young; |
| 755 | } | 762 | } |
| 756 | 763 | ||
| 764 | #define RMAP_RECYCLE_THRESHOLD 1000 | ||
| 765 | |||
| 766 | static void rmap_recycle(struct kvm_vcpu *vcpu, gfn_t gfn, int lpage) | ||
| 767 | { | ||
| 768 | unsigned long *rmapp; | ||
| 769 | |||
| 770 | gfn = unalias_gfn(vcpu->kvm, gfn); | ||
| 771 | rmapp = gfn_to_rmap(vcpu->kvm, gfn, lpage); | ||
| 772 | |||
| 773 | kvm_unmap_rmapp(vcpu->kvm, rmapp); | ||
| 774 | kvm_flush_remote_tlbs(vcpu->kvm); | ||
| 775 | } | ||
| 776 | |||
| 757 | int kvm_age_hva(struct kvm *kvm, unsigned long hva) | 777 | int kvm_age_hva(struct kvm *kvm, unsigned long hva) |
| 758 | { | 778 | { |
| 759 | return kvm_handle_hva(kvm, hva, kvm_age_rmapp); | 779 | return kvm_handle_hva(kvm, hva, kvm_age_rmapp); |
| @@ -1407,24 +1427,25 @@ static int kvm_mmu_zap_page(struct kvm *kvm, struct kvm_mmu_page *sp) | |||
| 1407 | */ | 1427 | */ |
| 1408 | void kvm_mmu_change_mmu_pages(struct kvm *kvm, unsigned int kvm_nr_mmu_pages) | 1428 | void kvm_mmu_change_mmu_pages(struct kvm *kvm, unsigned int kvm_nr_mmu_pages) |
| 1409 | { | 1429 | { |
| 1430 | int used_pages; | ||
| 1431 | |||
| 1432 | used_pages = kvm->arch.n_alloc_mmu_pages - kvm->arch.n_free_mmu_pages; | ||
| 1433 | used_pages = max(0, used_pages); | ||
| 1434 | |||
| 1410 | /* | 1435 | /* |
| 1411 | * If we set the number of mmu pages to be smaller be than the | 1436 | * If we set the number of mmu pages to be smaller be than the |
| 1412 | * number of actived pages , we must to free some mmu pages before we | 1437 | * number of actived pages , we must to free some mmu pages before we |
| 1413 | * change the value | 1438 | * change the value |
| 1414 | */ | 1439 | */ |
| 1415 | 1440 | ||
| 1416 | if ((kvm->arch.n_alloc_mmu_pages - kvm->arch.n_free_mmu_pages) > | 1441 | if (used_pages > kvm_nr_mmu_pages) { |
| 1417 | kvm_nr_mmu_pages) { | 1442 | while (used_pages > kvm_nr_mmu_pages) { |
| 1418 | int n_used_mmu_pages = kvm->arch.n_alloc_mmu_pages | ||
| 1419 | - kvm->arch.n_free_mmu_pages; | ||
| 1420 | |||
| 1421 | while (n_used_mmu_pages > kvm_nr_mmu_pages) { | ||
| 1422 | struct kvm_mmu_page *page; | 1443 | struct kvm_mmu_page *page; |
| 1423 | 1444 | ||
| 1424 | page = container_of(kvm->arch.active_mmu_pages.prev, | 1445 | page = container_of(kvm->arch.active_mmu_pages.prev, |
| 1425 | struct kvm_mmu_page, link); | 1446 | struct kvm_mmu_page, link); |
| 1426 | kvm_mmu_zap_page(kvm, page); | 1447 | kvm_mmu_zap_page(kvm, page); |
| 1427 | n_used_mmu_pages--; | 1448 | used_pages--; |
| 1428 | } | 1449 | } |
| 1429 | kvm->arch.n_free_mmu_pages = 0; | 1450 | kvm->arch.n_free_mmu_pages = 0; |
| 1430 | } | 1451 | } |
| @@ -1740,6 +1761,7 @@ static void mmu_set_spte(struct kvm_vcpu *vcpu, u64 *shadow_pte, | |||
| 1740 | { | 1761 | { |
| 1741 | int was_rmapped = 0; | 1762 | int was_rmapped = 0; |
| 1742 | int was_writeble = is_writeble_pte(*shadow_pte); | 1763 | int was_writeble = is_writeble_pte(*shadow_pte); |
| 1764 | int rmap_count; | ||
| 1743 | 1765 | ||
| 1744 | pgprintk("%s: spte %llx access %x write_fault %d" | 1766 | pgprintk("%s: spte %llx access %x write_fault %d" |
| 1745 | " user_fault %d gfn %lx\n", | 1767 | " user_fault %d gfn %lx\n", |
| @@ -1781,9 +1803,11 @@ static void mmu_set_spte(struct kvm_vcpu *vcpu, u64 *shadow_pte, | |||
| 1781 | 1803 | ||
| 1782 | page_header_update_slot(vcpu->kvm, shadow_pte, gfn); | 1804 | page_header_update_slot(vcpu->kvm, shadow_pte, gfn); |
| 1783 | if (!was_rmapped) { | 1805 | if (!was_rmapped) { |
| 1784 | rmap_add(vcpu, shadow_pte, gfn, largepage); | 1806 | rmap_count = rmap_add(vcpu, shadow_pte, gfn, largepage); |
| 1785 | if (!is_rmap_pte(*shadow_pte)) | 1807 | if (!is_rmap_pte(*shadow_pte)) |
| 1786 | kvm_release_pfn_clean(pfn); | 1808 | kvm_release_pfn_clean(pfn); |
| 1809 | if (rmap_count > RMAP_RECYCLE_THRESHOLD) | ||
| 1810 | rmap_recycle(vcpu, gfn, largepage); | ||
| 1787 | } else { | 1811 | } else { |
| 1788 | if (was_writeble) | 1812 | if (was_writeble) |
| 1789 | kvm_release_pfn_dirty(pfn); | 1813 | kvm_release_pfn_dirty(pfn); |
diff --git a/arch/x86/kvm/svm.c b/arch/x86/kvm/svm.c index 71510e07e69e..b1f658ad2f06 100644 --- a/arch/x86/kvm/svm.c +++ b/arch/x86/kvm/svm.c | |||
| @@ -711,6 +711,7 @@ static void svm_vcpu_load(struct kvm_vcpu *vcpu, int cpu) | |||
| 711 | svm->vmcb->control.tsc_offset += delta; | 711 | svm->vmcb->control.tsc_offset += delta; |
| 712 | vcpu->cpu = cpu; | 712 | vcpu->cpu = cpu; |
| 713 | kvm_migrate_timers(vcpu); | 713 | kvm_migrate_timers(vcpu); |
| 714 | svm->asid_generation = 0; | ||
| 714 | } | 715 | } |
| 715 | 716 | ||
| 716 | for (i = 0; i < NR_HOST_SAVE_USER_MSRS; i++) | 717 | for (i = 0; i < NR_HOST_SAVE_USER_MSRS; i++) |
| @@ -1031,7 +1032,6 @@ static void new_asid(struct vcpu_svm *svm, struct svm_cpu_data *svm_data) | |||
| 1031 | svm->vmcb->control.tlb_ctl = TLB_CONTROL_FLUSH_ALL_ASID; | 1032 | svm->vmcb->control.tlb_ctl = TLB_CONTROL_FLUSH_ALL_ASID; |
| 1032 | } | 1033 | } |
| 1033 | 1034 | ||
| 1034 | svm->vcpu.cpu = svm_data->cpu; | ||
| 1035 | svm->asid_generation = svm_data->asid_generation; | 1035 | svm->asid_generation = svm_data->asid_generation; |
| 1036 | svm->vmcb->control.asid = svm_data->next_asid++; | 1036 | svm->vmcb->control.asid = svm_data->next_asid++; |
| 1037 | } | 1037 | } |
| @@ -2300,8 +2300,8 @@ static void pre_svm_run(struct vcpu_svm *svm) | |||
| 2300 | struct svm_cpu_data *svm_data = per_cpu(svm_data, cpu); | 2300 | struct svm_cpu_data *svm_data = per_cpu(svm_data, cpu); |
| 2301 | 2301 | ||
| 2302 | svm->vmcb->control.tlb_ctl = TLB_CONTROL_DO_NOTHING; | 2302 | svm->vmcb->control.tlb_ctl = TLB_CONTROL_DO_NOTHING; |
| 2303 | if (svm->vcpu.cpu != cpu || | 2303 | /* FIXME: handle wraparound of asid_generation */ |
| 2304 | svm->asid_generation != svm_data->asid_generation) | 2304 | if (svm->asid_generation != svm_data->asid_generation) |
| 2305 | new_asid(svm, svm_data); | 2305 | new_asid(svm, svm_data); |
| 2306 | } | 2306 | } |
| 2307 | 2307 | ||
diff --git a/arch/x86/kvm/vmx.c b/arch/x86/kvm/vmx.c index 356a0ce85c68..29f912927a58 100644 --- a/arch/x86/kvm/vmx.c +++ b/arch/x86/kvm/vmx.c | |||
| @@ -3157,8 +3157,8 @@ static void handle_invalid_guest_state(struct kvm_vcpu *vcpu, | |||
| 3157 | struct vcpu_vmx *vmx = to_vmx(vcpu); | 3157 | struct vcpu_vmx *vmx = to_vmx(vcpu); |
| 3158 | enum emulation_result err = EMULATE_DONE; | 3158 | enum emulation_result err = EMULATE_DONE; |
| 3159 | 3159 | ||
| 3160 | preempt_enable(); | ||
| 3161 | local_irq_enable(); | 3160 | local_irq_enable(); |
| 3161 | preempt_enable(); | ||
| 3162 | 3162 | ||
| 3163 | while (!guest_state_valid(vcpu)) { | 3163 | while (!guest_state_valid(vcpu)) { |
| 3164 | err = emulate_instruction(vcpu, kvm_run, 0, 0, 0); | 3164 | err = emulate_instruction(vcpu, kvm_run, 0, 0, 0); |
| @@ -3168,7 +3168,7 @@ static void handle_invalid_guest_state(struct kvm_vcpu *vcpu, | |||
| 3168 | 3168 | ||
| 3169 | if (err != EMULATE_DONE) { | 3169 | if (err != EMULATE_DONE) { |
| 3170 | kvm_report_emulation_failure(vcpu, "emulation failure"); | 3170 | kvm_report_emulation_failure(vcpu, "emulation failure"); |
| 3171 | return; | 3171 | break; |
| 3172 | } | 3172 | } |
| 3173 | 3173 | ||
| 3174 | if (signal_pending(current)) | 3174 | if (signal_pending(current)) |
| @@ -3177,8 +3177,8 @@ static void handle_invalid_guest_state(struct kvm_vcpu *vcpu, | |||
| 3177 | schedule(); | 3177 | schedule(); |
| 3178 | } | 3178 | } |
| 3179 | 3179 | ||
| 3180 | local_irq_disable(); | ||
| 3181 | preempt_disable(); | 3180 | preempt_disable(); |
| 3181 | local_irq_disable(); | ||
| 3182 | 3182 | ||
| 3183 | vmx->invalid_state_emulation_result = err; | 3183 | vmx->invalid_state_emulation_result = err; |
| 3184 | } | 3184 | } |
diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index fe5474aec41a..3d4529011828 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c | |||
| @@ -704,11 +704,48 @@ static bool msr_mtrr_valid(unsigned msr) | |||
| 704 | return false; | 704 | return false; |
| 705 | } | 705 | } |
| 706 | 706 | ||
| 707 | static bool valid_pat_type(unsigned t) | ||
| 708 | { | ||
| 709 | return t < 8 && (1 << t) & 0xf3; /* 0, 1, 4, 5, 6, 7 */ | ||
| 710 | } | ||
| 711 | |||
| 712 | static bool valid_mtrr_type(unsigned t) | ||
| 713 | { | ||
| 714 | return t < 8 && (1 << t) & 0x73; /* 0, 1, 4, 5, 6 */ | ||
| 715 | } | ||
| 716 | |||
| 717 | static bool mtrr_valid(struct kvm_vcpu *vcpu, u32 msr, u64 data) | ||
| 718 | { | ||
| 719 | int i; | ||
| 720 | |||
| 721 | if (!msr_mtrr_valid(msr)) | ||
| 722 | return false; | ||
| 723 | |||
| 724 | if (msr == MSR_IA32_CR_PAT) { | ||
| 725 | for (i = 0; i < 8; i++) | ||
| 726 | if (!valid_pat_type((data >> (i * 8)) & 0xff)) | ||
| 727 | return false; | ||
| 728 | return true; | ||
| 729 | } else if (msr == MSR_MTRRdefType) { | ||
| 730 | if (data & ~0xcff) | ||
| 731 | return false; | ||
| 732 | return valid_mtrr_type(data & 0xff); | ||
| 733 | } else if (msr >= MSR_MTRRfix64K_00000 && msr <= MSR_MTRRfix4K_F8000) { | ||
| 734 | for (i = 0; i < 8 ; i++) | ||
| 735 | if (!valid_mtrr_type((data >> (i * 8)) & 0xff)) | ||
| 736 | return false; | ||
| 737 | return true; | ||
| 738 | } | ||
| 739 | |||
| 740 | /* variable MTRRs */ | ||
| 741 | return valid_mtrr_type(data & 0xff); | ||
| 742 | } | ||
| 743 | |||
| 707 | static int set_msr_mtrr(struct kvm_vcpu *vcpu, u32 msr, u64 data) | 744 | static int set_msr_mtrr(struct kvm_vcpu *vcpu, u32 msr, u64 data) |
| 708 | { | 745 | { |
| 709 | u64 *p = (u64 *)&vcpu->arch.mtrr_state.fixed_ranges; | 746 | u64 *p = (u64 *)&vcpu->arch.mtrr_state.fixed_ranges; |
| 710 | 747 | ||
| 711 | if (!msr_mtrr_valid(msr)) | 748 | if (!mtrr_valid(vcpu, msr, data)) |
| 712 | return 1; | 749 | return 1; |
| 713 | 750 | ||
| 714 | if (msr == MSR_MTRRdefType) { | 751 | if (msr == MSR_MTRRdefType) { |
| @@ -1079,14 +1116,13 @@ long kvm_arch_dev_ioctl(struct file *filp, | |||
| 1079 | if (copy_to_user(user_msr_list, &msr_list, sizeof msr_list)) | 1116 | if (copy_to_user(user_msr_list, &msr_list, sizeof msr_list)) |
| 1080 | goto out; | 1117 | goto out; |
| 1081 | r = -E2BIG; | 1118 | r = -E2BIG; |
| 1082 | if (n < num_msrs_to_save) | 1119 | if (n < msr_list.nmsrs) |
| 1083 | goto out; | 1120 | goto out; |
| 1084 | r = -EFAULT; | 1121 | r = -EFAULT; |
| 1085 | if (copy_to_user(user_msr_list->indices, &msrs_to_save, | 1122 | if (copy_to_user(user_msr_list->indices, &msrs_to_save, |
| 1086 | num_msrs_to_save * sizeof(u32))) | 1123 | num_msrs_to_save * sizeof(u32))) |
| 1087 | goto out; | 1124 | goto out; |
| 1088 | if (copy_to_user(user_msr_list->indices | 1125 | if (copy_to_user(user_msr_list->indices + num_msrs_to_save, |
| 1089 | + num_msrs_to_save * sizeof(u32), | ||
| 1090 | &emulated_msrs, | 1126 | &emulated_msrs, |
| 1091 | ARRAY_SIZE(emulated_msrs) * sizeof(u32))) | 1127 | ARRAY_SIZE(emulated_msrs) * sizeof(u32))) |
| 1092 | goto out; | 1128 | goto out; |
diff --git a/arch/x86/lguest/boot.c b/arch/x86/lguest/boot.c index f2bf1f73d468..d677fa9ca650 100644 --- a/arch/x86/lguest/boot.c +++ b/arch/x86/lguest/boot.c | |||
| @@ -22,7 +22,8 @@ | |||
| 22 | * | 22 | * |
| 23 | * So how does the kernel know it's a Guest? We'll see that later, but let's | 23 | * So how does the kernel know it's a Guest? We'll see that later, but let's |
| 24 | * just say that we end up here where we replace the native functions various | 24 | * just say that we end up here where we replace the native functions various |
| 25 | * "paravirt" structures with our Guest versions, then boot like normal. :*/ | 25 | * "paravirt" structures with our Guest versions, then boot like normal. |
| 26 | :*/ | ||
| 26 | 27 | ||
| 27 | /* | 28 | /* |
| 28 | * Copyright (C) 2006, Rusty Russell <rusty@rustcorp.com.au> IBM Corporation. | 29 | * Copyright (C) 2006, Rusty Russell <rusty@rustcorp.com.au> IBM Corporation. |
| @@ -74,7 +75,8 @@ | |||
| 74 | * | 75 | * |
| 75 | * The Guest in our tale is a simple creature: identical to the Host but | 76 | * The Guest in our tale is a simple creature: identical to the Host but |
| 76 | * behaving in simplified but equivalent ways. In particular, the Guest is the | 77 | * behaving in simplified but equivalent ways. In particular, the Guest is the |
| 77 | * same kernel as the Host (or at least, built from the same source code). :*/ | 78 | * same kernel as the Host (or at least, built from the same source code). |
| 79 | :*/ | ||
| 78 | 80 | ||
| 79 | struct lguest_data lguest_data = { | 81 | struct lguest_data lguest_data = { |
| 80 | .hcall_status = { [0 ... LHCALL_RING_SIZE-1] = 0xFF }, | 82 | .hcall_status = { [0 ... LHCALL_RING_SIZE-1] = 0xFF }, |
| @@ -85,7 +87,8 @@ struct lguest_data lguest_data = { | |||
| 85 | .syscall_vec = SYSCALL_VECTOR, | 87 | .syscall_vec = SYSCALL_VECTOR, |
| 86 | }; | 88 | }; |
| 87 | 89 | ||
| 88 | /*G:037 async_hcall() is pretty simple: I'm quite proud of it really. We have a | 90 | /*G:037 |
| 91 | * async_hcall() is pretty simple: I'm quite proud of it really. We have a | ||
| 89 | * ring buffer of stored hypercalls which the Host will run though next time we | 92 | * ring buffer of stored hypercalls which the Host will run though next time we |
| 90 | * do a normal hypercall. Each entry in the ring has 5 slots for the hypercall | 93 | * do a normal hypercall. Each entry in the ring has 5 slots for the hypercall |
| 91 | * arguments, and a "hcall_status" word which is 0 if the call is ready to go, | 94 | * arguments, and a "hcall_status" word which is 0 if the call is ready to go, |
| @@ -94,7 +97,8 @@ struct lguest_data lguest_data = { | |||
| 94 | * If we come around to a slot which hasn't been finished, then the table is | 97 | * If we come around to a slot which hasn't been finished, then the table is |
| 95 | * full and we just make the hypercall directly. This has the nice side | 98 | * full and we just make the hypercall directly. This has the nice side |
| 96 | * effect of causing the Host to run all the stored calls in the ring buffer | 99 | * effect of causing the Host to run all the stored calls in the ring buffer |
| 97 | * which empties it for next time! */ | 100 | * which empties it for next time! |
| 101 | */ | ||
| 98 | static void async_hcall(unsigned long call, unsigned long arg1, | 102 | static void async_hcall(unsigned long call, unsigned long arg1, |
| 99 | unsigned long arg2, unsigned long arg3, | 103 | unsigned long arg2, unsigned long arg3, |
| 100 | unsigned long arg4) | 104 | unsigned long arg4) |
| @@ -103,9 +107,11 @@ static void async_hcall(unsigned long call, unsigned long arg1, | |||
| 103 | static unsigned int next_call; | 107 | static unsigned int next_call; |
| 104 | unsigned long flags; | 108 | unsigned long flags; |
| 105 | 109 | ||
| 106 | /* Disable interrupts if not already disabled: we don't want an | 110 | /* |
| 111 | * Disable interrupts if not already disabled: we don't want an | ||
| 107 | * interrupt handler making a hypercall while we're already doing | 112 | * interrupt handler making a hypercall while we're already doing |
| 108 | * one! */ | 113 | * one! |
| 114 | */ | ||
| 109 | local_irq_save(flags); | 115 | local_irq_save(flags); |
| 110 | if (lguest_data.hcall_status[next_call] != 0xFF) { | 116 | if (lguest_data.hcall_status[next_call] != 0xFF) { |
| 111 | /* Table full, so do normal hcall which will flush table. */ | 117 | /* Table full, so do normal hcall which will flush table. */ |
| @@ -125,8 +131,9 @@ static void async_hcall(unsigned long call, unsigned long arg1, | |||
| 125 | local_irq_restore(flags); | 131 | local_irq_restore(flags); |
| 126 | } | 132 | } |
| 127 | 133 | ||
| 128 | /*G:035 Notice the lazy_hcall() above, rather than hcall(). This is our first | 134 | /*G:035 |
| 129 | * real optimization trick! | 135 | * Notice the lazy_hcall() above, rather than hcall(). This is our first real |
| 136 | * optimization trick! | ||
| 130 | * | 137 | * |
| 131 | * When lazy_mode is set, it means we're allowed to defer all hypercalls and do | 138 | * When lazy_mode is set, it means we're allowed to defer all hypercalls and do |
| 132 | * them as a batch when lazy_mode is eventually turned off. Because hypercalls | 139 | * them as a batch when lazy_mode is eventually turned off. Because hypercalls |
| @@ -136,7 +143,8 @@ static void async_hcall(unsigned long call, unsigned long arg1, | |||
| 136 | * lguest_leave_lazy_mode(). | 143 | * lguest_leave_lazy_mode(). |
| 137 | * | 144 | * |
| 138 | * So, when we're in lazy mode, we call async_hcall() to store the call for | 145 | * So, when we're in lazy mode, we call async_hcall() to store the call for |
| 139 | * future processing: */ | 146 | * future processing: |
| 147 | */ | ||
| 140 | static void lazy_hcall1(unsigned long call, | 148 | static void lazy_hcall1(unsigned long call, |
| 141 | unsigned long arg1) | 149 | unsigned long arg1) |
| 142 | { | 150 | { |
| @@ -146,6 +154,7 @@ static void lazy_hcall1(unsigned long call, | |||
| 146 | async_hcall(call, arg1, 0, 0, 0); | 154 | async_hcall(call, arg1, 0, 0, 0); |
| 147 | } | 155 | } |
| 148 | 156 | ||
| 157 | /* You can imagine what lazy_hcall2, 3 and 4 look like. :*/ | ||
| 149 | static void lazy_hcall2(unsigned long call, | 158 | static void lazy_hcall2(unsigned long call, |
| 150 | unsigned long arg1, | 159 | unsigned long arg1, |
| 151 | unsigned long arg2) | 160 | unsigned long arg2) |
| @@ -181,8 +190,10 @@ static void lazy_hcall4(unsigned long call, | |||
| 181 | } | 190 | } |
| 182 | #endif | 191 | #endif |
| 183 | 192 | ||
| 184 | /* When lazy mode is turned off reset the per-cpu lazy mode variable and then | 193 | /*G:036 |
| 185 | * issue the do-nothing hypercall to flush any stored calls. */ | 194 | * When lazy mode is turned off reset the per-cpu lazy mode variable and then |
| 195 | * issue the do-nothing hypercall to flush any stored calls. | ||
| 196 | :*/ | ||
| 186 | static void lguest_leave_lazy_mmu_mode(void) | 197 | static void lguest_leave_lazy_mmu_mode(void) |
| 187 | { | 198 | { |
| 188 | kvm_hypercall0(LHCALL_FLUSH_ASYNC); | 199 | kvm_hypercall0(LHCALL_FLUSH_ASYNC); |
| @@ -208,9 +219,11 @@ static void lguest_end_context_switch(struct task_struct *next) | |||
| 208 | * check there before it tries to deliver an interrupt. | 219 | * check there before it tries to deliver an interrupt. |
| 209 | */ | 220 | */ |
| 210 | 221 | ||
| 211 | /* save_flags() is expected to return the processor state (ie. "flags"). The | 222 | /* |
| 223 | * save_flags() is expected to return the processor state (ie. "flags"). The | ||
| 212 | * flags word contains all kind of stuff, but in practice Linux only cares | 224 | * flags word contains all kind of stuff, but in practice Linux only cares |
| 213 | * about the interrupt flag. Our "save_flags()" just returns that. */ | 225 | * about the interrupt flag. Our "save_flags()" just returns that. |
| 226 | */ | ||
| 214 | static unsigned long save_fl(void) | 227 | static unsigned long save_fl(void) |
| 215 | { | 228 | { |
| 216 | return lguest_data.irq_enabled; | 229 | return lguest_data.irq_enabled; |
| @@ -222,13 +235,15 @@ static void irq_disable(void) | |||
| 222 | lguest_data.irq_enabled = 0; | 235 | lguest_data.irq_enabled = 0; |
| 223 | } | 236 | } |
| 224 | 237 | ||
| 225 | /* Let's pause a moment. Remember how I said these are called so often? | 238 | /* |
| 239 | * Let's pause a moment. Remember how I said these are called so often? | ||
| 226 | * Jeremy Fitzhardinge optimized them so hard early in 2009 that he had to | 240 | * Jeremy Fitzhardinge optimized them so hard early in 2009 that he had to |
| 227 | * break some rules. In particular, these functions are assumed to save their | 241 | * break some rules. In particular, these functions are assumed to save their |
| 228 | * own registers if they need to: normal C functions assume they can trash the | 242 | * own registers if they need to: normal C functions assume they can trash the |
| 229 | * eax register. To use normal C functions, we use | 243 | * eax register. To use normal C functions, we use |
| 230 | * PV_CALLEE_SAVE_REGS_THUNK(), which pushes %eax onto the stack, calls the | 244 | * PV_CALLEE_SAVE_REGS_THUNK(), which pushes %eax onto the stack, calls the |
| 231 | * C function, then restores it. */ | 245 | * C function, then restores it. |
| 246 | */ | ||
| 232 | PV_CALLEE_SAVE_REGS_THUNK(save_fl); | 247 | PV_CALLEE_SAVE_REGS_THUNK(save_fl); |
| 233 | PV_CALLEE_SAVE_REGS_THUNK(irq_disable); | 248 | PV_CALLEE_SAVE_REGS_THUNK(irq_disable); |
| 234 | /*:*/ | 249 | /*:*/ |
| @@ -237,18 +252,18 @@ PV_CALLEE_SAVE_REGS_THUNK(irq_disable); | |||
| 237 | extern void lg_irq_enable(void); | 252 | extern void lg_irq_enable(void); |
| 238 | extern void lg_restore_fl(unsigned long flags); | 253 | extern void lg_restore_fl(unsigned long flags); |
| 239 | 254 | ||
| 240 | /*M:003 Note that we don't check for outstanding interrupts when we re-enable | 255 | /*M:003 |
| 241 | * them (or when we unmask an interrupt). This seems to work for the moment, | 256 | * We could be more efficient in our checking of outstanding interrupts, rather |
| 242 | * since interrupts are rare and we'll just get the interrupt on the next timer | 257 | * than using a branch. One way would be to put the "irq_enabled" field in a |
| 243 | * tick, but now we can run with CONFIG_NO_HZ, we should revisit this. One way | 258 | * page by itself, and have the Host write-protect it when an interrupt comes |
| 244 | * would be to put the "irq_enabled" field in a page by itself, and have the | 259 | * in when irqs are disabled. There will then be a page fault as soon as |
| 245 | * Host write-protect it when an interrupt comes in when irqs are disabled. | 260 | * interrupts are re-enabled. |
| 246 | * There will then be a page fault as soon as interrupts are re-enabled. | ||
| 247 | * | 261 | * |
| 248 | * A better method is to implement soft interrupt disable generally for x86: | 262 | * A better method is to implement soft interrupt disable generally for x86: |
| 249 | * instead of disabling interrupts, we set a flag. If an interrupt does come | 263 | * instead of disabling interrupts, we set a flag. If an interrupt does come |
| 250 | * in, we then disable them for real. This is uncommon, so we could simply use | 264 | * in, we then disable them for real. This is uncommon, so we could simply use |
| 251 | * a hypercall for interrupt control and not worry about efficiency. :*/ | 265 | * a hypercall for interrupt control and not worry about efficiency. |
| 266 | :*/ | ||
| 252 | 267 | ||
| 253 | /*G:034 | 268 | /*G:034 |
| 254 | * The Interrupt Descriptor Table (IDT). | 269 | * The Interrupt Descriptor Table (IDT). |
| @@ -261,10 +276,12 @@ extern void lg_restore_fl(unsigned long flags); | |||
| 261 | static void lguest_write_idt_entry(gate_desc *dt, | 276 | static void lguest_write_idt_entry(gate_desc *dt, |
| 262 | int entrynum, const gate_desc *g) | 277 | int entrynum, const gate_desc *g) |
| 263 | { | 278 | { |
| 264 | /* The gate_desc structure is 8 bytes long: we hand it to the Host in | 279 | /* |
| 280 | * The gate_desc structure is 8 bytes long: we hand it to the Host in | ||
| 265 | * two 32-bit chunks. The whole 32-bit kernel used to hand descriptors | 281 | * two 32-bit chunks. The whole 32-bit kernel used to hand descriptors |
| 266 | * around like this; typesafety wasn't a big concern in Linux's early | 282 | * around like this; typesafety wasn't a big concern in Linux's early |
| 267 | * years. */ | 283 | * years. |
| 284 | */ | ||
| 268 | u32 *desc = (u32 *)g; | 285 | u32 *desc = (u32 *)g; |
| 269 | /* Keep the local copy up to date. */ | 286 | /* Keep the local copy up to date. */ |
| 270 | native_write_idt_entry(dt, entrynum, g); | 287 | native_write_idt_entry(dt, entrynum, g); |
| @@ -272,9 +289,11 @@ static void lguest_write_idt_entry(gate_desc *dt, | |||
| 272 | kvm_hypercall3(LHCALL_LOAD_IDT_ENTRY, entrynum, desc[0], desc[1]); | 289 | kvm_hypercall3(LHCALL_LOAD_IDT_ENTRY, entrynum, desc[0], desc[1]); |
| 273 | } | 290 | } |
| 274 | 291 | ||
| 275 | /* Changing to a different IDT is very rare: we keep the IDT up-to-date every | 292 | /* |
| 293 | * Changing to a different IDT is very rare: we keep the IDT up-to-date every | ||
| 276 | * time it is written, so we can simply loop through all entries and tell the | 294 | * time it is written, so we can simply loop through all entries and tell the |
| 277 | * Host about them. */ | 295 | * Host about them. |
| 296 | */ | ||
| 278 | static void lguest_load_idt(const struct desc_ptr *desc) | 297 | static void lguest_load_idt(const struct desc_ptr *desc) |
| 279 | { | 298 | { |
| 280 | unsigned int i; | 299 | unsigned int i; |
| @@ -305,9 +324,11 @@ static void lguest_load_gdt(const struct desc_ptr *desc) | |||
| 305 | kvm_hypercall3(LHCALL_LOAD_GDT_ENTRY, i, gdt[i].a, gdt[i].b); | 324 | kvm_hypercall3(LHCALL_LOAD_GDT_ENTRY, i, gdt[i].a, gdt[i].b); |
| 306 | } | 325 | } |
| 307 | 326 | ||
| 308 | /* For a single GDT entry which changes, we do the lazy thing: alter our GDT, | 327 | /* |
| 328 | * For a single GDT entry which changes, we do the lazy thing: alter our GDT, | ||
| 309 | * then tell the Host to reload the entire thing. This operation is so rare | 329 | * then tell the Host to reload the entire thing. This operation is so rare |
| 310 | * that this naive implementation is reasonable. */ | 330 | * that this naive implementation is reasonable. |
| 331 | */ | ||
| 311 | static void lguest_write_gdt_entry(struct desc_struct *dt, int entrynum, | 332 | static void lguest_write_gdt_entry(struct desc_struct *dt, int entrynum, |
| 312 | const void *desc, int type) | 333 | const void *desc, int type) |
| 313 | { | 334 | { |
| @@ -317,29 +338,36 @@ static void lguest_write_gdt_entry(struct desc_struct *dt, int entrynum, | |||
| 317 | dt[entrynum].a, dt[entrynum].b); | 338 | dt[entrynum].a, dt[entrynum].b); |
| 318 | } | 339 | } |
| 319 | 340 | ||
| 320 | /* OK, I lied. There are three "thread local storage" GDT entries which change | 341 | /* |
| 342 | * OK, I lied. There are three "thread local storage" GDT entries which change | ||
| 321 | * on every context switch (these three entries are how glibc implements | 343 | * on every context switch (these three entries are how glibc implements |
| 322 | * __thread variables). So we have a hypercall specifically for this case. */ | 344 | * __thread variables). So we have a hypercall specifically for this case. |
| 345 | */ | ||
| 323 | static void lguest_load_tls(struct thread_struct *t, unsigned int cpu) | 346 | static void lguest_load_tls(struct thread_struct *t, unsigned int cpu) |
| 324 | { | 347 | { |
| 325 | /* There's one problem which normal hardware doesn't have: the Host | 348 | /* |
| 349 | * There's one problem which normal hardware doesn't have: the Host | ||
| 326 | * can't handle us removing entries we're currently using. So we clear | 350 | * can't handle us removing entries we're currently using. So we clear |
| 327 | * the GS register here: if it's needed it'll be reloaded anyway. */ | 351 | * the GS register here: if it's needed it'll be reloaded anyway. |
| 352 | */ | ||
| 328 | lazy_load_gs(0); | 353 | lazy_load_gs(0); |
| 329 | lazy_hcall2(LHCALL_LOAD_TLS, __pa(&t->tls_array), cpu); | 354 | lazy_hcall2(LHCALL_LOAD_TLS, __pa(&t->tls_array), cpu); |
| 330 | } | 355 | } |
| 331 | 356 | ||
| 332 | /*G:038 That's enough excitement for now, back to ploughing through each of | 357 | /*G:038 |
| 333 | * the different pv_ops structures (we're about 1/3 of the way through). | 358 | * That's enough excitement for now, back to ploughing through each of the |
| 359 | * different pv_ops structures (we're about 1/3 of the way through). | ||
| 334 | * | 360 | * |
| 335 | * This is the Local Descriptor Table, another weird Intel thingy. Linux only | 361 | * This is the Local Descriptor Table, another weird Intel thingy. Linux only |
| 336 | * uses this for some strange applications like Wine. We don't do anything | 362 | * uses this for some strange applications like Wine. We don't do anything |
| 337 | * here, so they'll get an informative and friendly Segmentation Fault. */ | 363 | * here, so they'll get an informative and friendly Segmentation Fault. |
| 364 | */ | ||
| 338 | static void lguest_set_ldt(const void *addr, unsigned entries) | 365 | static void lguest_set_ldt(const void *addr, unsigned entries) |
| 339 | { | 366 | { |
| 340 | } | 367 | } |
| 341 | 368 | ||
| 342 | /* This loads a GDT entry into the "Task Register": that entry points to a | 369 | /* |
| 370 | * This loads a GDT entry into the "Task Register": that entry points to a | ||
| 343 | * structure called the Task State Segment. Some comments scattered though the | 371 | * structure called the Task State Segment. Some comments scattered though the |
| 344 | * kernel code indicate that this used for task switching in ages past, along | 372 | * kernel code indicate that this used for task switching in ages past, along |
| 345 | * with blood sacrifice and astrology. | 373 | * with blood sacrifice and astrology. |
| @@ -347,19 +375,21 @@ static void lguest_set_ldt(const void *addr, unsigned entries) | |||
| 347 | * Now there's nothing interesting in here that we don't get told elsewhere. | 375 | * Now there's nothing interesting in here that we don't get told elsewhere. |
| 348 | * But the native version uses the "ltr" instruction, which makes the Host | 376 | * But the native version uses the "ltr" instruction, which makes the Host |
| 349 | * complain to the Guest about a Segmentation Fault and it'll oops. So we | 377 | * complain to the Guest about a Segmentation Fault and it'll oops. So we |
| 350 | * override the native version with a do-nothing version. */ | 378 | * override the native version with a do-nothing version. |
| 379 | */ | ||
| 351 | static void lguest_load_tr_desc(void) | 380 | static void lguest_load_tr_desc(void) |
| 352 | { | 381 | { |
| 353 | } | 382 | } |
| 354 | 383 | ||
| 355 | /* The "cpuid" instruction is a way of querying both the CPU identity | 384 | /* |
| 385 | * The "cpuid" instruction is a way of querying both the CPU identity | ||
| 356 | * (manufacturer, model, etc) and its features. It was introduced before the | 386 | * (manufacturer, model, etc) and its features. It was introduced before the |
| 357 | * Pentium in 1993 and keeps getting extended by both Intel, AMD and others. | 387 | * Pentium in 1993 and keeps getting extended by both Intel, AMD and others. |
| 358 | * As you might imagine, after a decade and a half this treatment, it is now a | 388 | * As you might imagine, after a decade and a half this treatment, it is now a |
| 359 | * giant ball of hair. Its entry in the current Intel manual runs to 28 pages. | 389 | * giant ball of hair. Its entry in the current Intel manual runs to 28 pages. |
| 360 | * | 390 | * |
| 361 | * This instruction even it has its own Wikipedia entry. The Wikipedia entry | 391 | * This instruction even it has its own Wikipedia entry. The Wikipedia entry |
| 362 | * has been translated into 4 languages. I am not making this up! | 392 | * has been translated into 5 languages. I am not making this up! |
| 363 | * | 393 | * |
| 364 | * We could get funky here and identify ourselves as "GenuineLguest", but | 394 | * We could get funky here and identify ourselves as "GenuineLguest", but |
| 365 | * instead we just use the real "cpuid" instruction. Then I pretty much turned | 395 | * instead we just use the real "cpuid" instruction. Then I pretty much turned |
| @@ -371,7 +401,8 @@ static void lguest_load_tr_desc(void) | |||
| 371 | * Replacing the cpuid so we can turn features off is great for the kernel, but | 401 | * Replacing the cpuid so we can turn features off is great for the kernel, but |
| 372 | * anyone (including userspace) can just use the raw "cpuid" instruction and | 402 | * anyone (including userspace) can just use the raw "cpuid" instruction and |
| 373 | * the Host won't even notice since it isn't privileged. So we try not to get | 403 | * the Host won't even notice since it isn't privileged. So we try not to get |
| 374 | * too worked up about it. */ | 404 | * too worked up about it. |
| 405 | */ | ||
| 375 | static void lguest_cpuid(unsigned int *ax, unsigned int *bx, | 406 | static void lguest_cpuid(unsigned int *ax, unsigned int *bx, |
| 376 | unsigned int *cx, unsigned int *dx) | 407 | unsigned int *cx, unsigned int *dx) |
| 377 | { | 408 | { |
| @@ -379,43 +410,63 @@ static void lguest_cpuid(unsigned int *ax, unsigned int *bx, | |||
| 379 | 410 | ||
| 380 | native_cpuid(ax, bx, cx, dx); | 411 | native_cpuid(ax, bx, cx, dx); |
| 381 | switch (function) { | 412 | switch (function) { |
| 382 | case 0: /* ID and highest CPUID. Futureproof a little by sticking to | 413 | /* |
| 383 | * older ones. */ | 414 | * CPUID 0 gives the highest legal CPUID number (and the ID string). |
| 415 | * We futureproof our code a little by sticking to known CPUID values. | ||
| 416 | */ | ||
| 417 | case 0: | ||
| 384 | if (*ax > 5) | 418 | if (*ax > 5) |
| 385 | *ax = 5; | 419 | *ax = 5; |
| 386 | break; | 420 | break; |
| 387 | case 1: /* Basic feature request. */ | 421 | |
| 388 | /* We only allow kernel to see SSE3, CMPXCHG16B and SSSE3 */ | 422 | /* |
| 423 | * CPUID 1 is a basic feature request. | ||
| 424 | * | ||
| 425 | * CX: we only allow kernel to see SSE3, CMPXCHG16B and SSSE3 | ||
| 426 | * DX: SSE, SSE2, FXSR, MMX, CMOV, CMPXCHG8B, TSC, FPU and PAE. | ||
| 427 | */ | ||
| 428 | case 1: | ||
| 389 | *cx &= 0x00002201; | 429 | *cx &= 0x00002201; |
| 390 | /* SSE, SSE2, FXSR, MMX, CMOV, CMPXCHG8B, TSC, FPU, PAE. */ | ||
| 391 | *dx &= 0x07808151; | 430 | *dx &= 0x07808151; |
| 392 | /* The Host can do a nice optimization if it knows that the | 431 | /* |
| 432 | * The Host can do a nice optimization if it knows that the | ||
| 393 | * kernel mappings (addresses above 0xC0000000 or whatever | 433 | * kernel mappings (addresses above 0xC0000000 or whatever |
| 394 | * PAGE_OFFSET is set to) haven't changed. But Linux calls | 434 | * PAGE_OFFSET is set to) haven't changed. But Linux calls |
| 395 | * flush_tlb_user() for both user and kernel mappings unless | 435 | * flush_tlb_user() for both user and kernel mappings unless |
| 396 | * the Page Global Enable (PGE) feature bit is set. */ | 436 | * the Page Global Enable (PGE) feature bit is set. |
| 437 | */ | ||
| 397 | *dx |= 0x00002000; | 438 | *dx |= 0x00002000; |
| 398 | /* We also lie, and say we're family id 5. 6 or greater | 439 | /* |
| 440 | * We also lie, and say we're family id 5. 6 or greater | ||
| 399 | * leads to a rdmsr in early_init_intel which we can't handle. | 441 | * leads to a rdmsr in early_init_intel which we can't handle. |
| 400 | * Family ID is returned as bits 8-12 in ax. */ | 442 | * Family ID is returned as bits 8-12 in ax. |
| 443 | */ | ||
| 401 | *ax &= 0xFFFFF0FF; | 444 | *ax &= 0xFFFFF0FF; |
| 402 | *ax |= 0x00000500; | 445 | *ax |= 0x00000500; |
| 403 | break; | 446 | break; |
| 447 | /* | ||
| 448 | * 0x80000000 returns the highest Extended Function, so we futureproof | ||
| 449 | * like we do above by limiting it to known fields. | ||
| 450 | */ | ||
| 404 | case 0x80000000: | 451 | case 0x80000000: |
| 405 | /* Futureproof this a little: if they ask how much extended | ||
| 406 | * processor information there is, limit it to known fields. */ | ||
| 407 | if (*ax > 0x80000008) | 452 | if (*ax > 0x80000008) |
| 408 | *ax = 0x80000008; | 453 | *ax = 0x80000008; |
| 409 | break; | 454 | break; |
| 455 | |||
| 456 | /* | ||
| 457 | * PAE systems can mark pages as non-executable. Linux calls this the | ||
| 458 | * NX bit. Intel calls it XD (eXecute Disable), AMD EVP (Enhanced | ||
| 459 | * Virus Protection). We just switch turn if off here, since we don't | ||
| 460 | * support it. | ||
| 461 | */ | ||
| 410 | case 0x80000001: | 462 | case 0x80000001: |
| 411 | /* Here we should fix nx cap depending on host. */ | ||
| 412 | /* For this version of PAE, we just clear NX bit. */ | ||
| 413 | *dx &= ~(1 << 20); | 463 | *dx &= ~(1 << 20); |
| 414 | break; | 464 | break; |
| 415 | } | 465 | } |
| 416 | } | 466 | } |
| 417 | 467 | ||
| 418 | /* Intel has four control registers, imaginatively named cr0, cr2, cr3 and cr4. | 468 | /* |
| 469 | * Intel has four control registers, imaginatively named cr0, cr2, cr3 and cr4. | ||
| 419 | * I assume there's a cr1, but it hasn't bothered us yet, so we'll not bother | 470 | * I assume there's a cr1, but it hasn't bothered us yet, so we'll not bother |
| 420 | * it. The Host needs to know when the Guest wants to change them, so we have | 471 | * it. The Host needs to know when the Guest wants to change them, so we have |
| 421 | * a whole series of functions like read_cr0() and write_cr0(). | 472 | * a whole series of functions like read_cr0() and write_cr0(). |
| @@ -430,7 +481,8 @@ static void lguest_cpuid(unsigned int *ax, unsigned int *bx, | |||
| 430 | * name like "FPUTRAP bit" be a little less cryptic? | 481 | * name like "FPUTRAP bit" be a little less cryptic? |
| 431 | * | 482 | * |
| 432 | * We store cr0 locally because the Host never changes it. The Guest sometimes | 483 | * We store cr0 locally because the Host never changes it. The Guest sometimes |
| 433 | * wants to read it and we'd prefer not to bother the Host unnecessarily. */ | 484 | * wants to read it and we'd prefer not to bother the Host unnecessarily. |
| 485 | */ | ||
| 434 | static unsigned long current_cr0; | 486 | static unsigned long current_cr0; |
| 435 | static void lguest_write_cr0(unsigned long val) | 487 | static void lguest_write_cr0(unsigned long val) |
| 436 | { | 488 | { |
| @@ -443,18 +495,22 @@ static unsigned long lguest_read_cr0(void) | |||
| 443 | return current_cr0; | 495 | return current_cr0; |
| 444 | } | 496 | } |
| 445 | 497 | ||
| 446 | /* Intel provided a special instruction to clear the TS bit for people too cool | 498 | /* |
| 499 | * Intel provided a special instruction to clear the TS bit for people too cool | ||
| 447 | * to use write_cr0() to do it. This "clts" instruction is faster, because all | 500 | * to use write_cr0() to do it. This "clts" instruction is faster, because all |
| 448 | * the vowels have been optimized out. */ | 501 | * the vowels have been optimized out. |
| 502 | */ | ||
| 449 | static void lguest_clts(void) | 503 | static void lguest_clts(void) |
| 450 | { | 504 | { |
| 451 | lazy_hcall1(LHCALL_TS, 0); | 505 | lazy_hcall1(LHCALL_TS, 0); |
| 452 | current_cr0 &= ~X86_CR0_TS; | 506 | current_cr0 &= ~X86_CR0_TS; |
| 453 | } | 507 | } |
| 454 | 508 | ||
| 455 | /* cr2 is the virtual address of the last page fault, which the Guest only ever | 509 | /* |
| 510 | * cr2 is the virtual address of the last page fault, which the Guest only ever | ||
| 456 | * reads. The Host kindly writes this into our "struct lguest_data", so we | 511 | * reads. The Host kindly writes this into our "struct lguest_data", so we |
| 457 | * just read it out of there. */ | 512 | * just read it out of there. |
| 513 | */ | ||
| 458 | static unsigned long lguest_read_cr2(void) | 514 | static unsigned long lguest_read_cr2(void) |
| 459 | { | 515 | { |
| 460 | return lguest_data.cr2; | 516 | return lguest_data.cr2; |
| @@ -463,10 +519,12 @@ static unsigned long lguest_read_cr2(void) | |||
| 463 | /* See lguest_set_pte() below. */ | 519 | /* See lguest_set_pte() below. */ |
| 464 | static bool cr3_changed = false; | 520 | static bool cr3_changed = false; |
| 465 | 521 | ||
| 466 | /* cr3 is the current toplevel pagetable page: the principle is the same as | 522 | /* |
| 523 | * cr3 is the current toplevel pagetable page: the principle is the same as | ||
| 467 | * cr0. Keep a local copy, and tell the Host when it changes. The only | 524 | * cr0. Keep a local copy, and tell the Host when it changes. The only |
| 468 | * difference is that our local copy is in lguest_data because the Host needs | 525 | * difference is that our local copy is in lguest_data because the Host needs |
| 469 | * to set it upon our initial hypercall. */ | 526 | * to set it upon our initial hypercall. |
| 527 | */ | ||
| 470 | static void lguest_write_cr3(unsigned long cr3) | 528 | static void lguest_write_cr3(unsigned long cr3) |
| 471 | { | 529 | { |
| 472 | lguest_data.pgdir = cr3; | 530 | lguest_data.pgdir = cr3; |
| @@ -511,7 +569,7 @@ static void lguest_write_cr4(unsigned long val) | |||
| 511 | * cr3 ---> +---------+ | 569 | * cr3 ---> +---------+ |
| 512 | * | --------->+---------+ | 570 | * | --------->+---------+ |
| 513 | * | | | PADDR1 | | 571 | * | | | PADDR1 | |
| 514 | * Top-level | | PADDR2 | | 572 | * Mid-level | | PADDR2 | |
| 515 | * (PMD) page | | | | 573 | * (PMD) page | | | |
| 516 | * | | Lower-level | | 574 | * | | Lower-level | |
| 517 | * | | (PTE) page | | 575 | * | | (PTE) page | |
| @@ -531,21 +589,62 @@ static void lguest_write_cr4(unsigned long val) | |||
| 531 | * Index into top Index into second Offset within page | 589 | * Index into top Index into second Offset within page |
| 532 | * page directory page pagetable page | 590 | * page directory page pagetable page |
| 533 | * | 591 | * |
| 534 | * The kernel spends a lot of time changing both the top-level page directory | 592 | * Now, unfortunately, this isn't the whole story: Intel added Physical Address |
| 535 | * and lower-level pagetable pages. The Guest doesn't know physical addresses, | 593 | * Extension (PAE) to allow 32 bit systems to use 64GB of memory (ie. 36 bits). |
| 536 | * so while it maintains these page tables exactly like normal, it also needs | 594 | * These are held in 64-bit page table entries, so we can now only fit 512 |
| 537 | * to keep the Host informed whenever it makes a change: the Host will create | 595 | * entries in a page, and the neat three-level tree breaks down. |
| 538 | * the real page tables based on the Guests'. | 596 | * |
| 597 | * The result is a four level page table: | ||
| 598 | * | ||
| 599 | * cr3 --> [ 4 Upper ] | ||
| 600 | * [ Level ] | ||
| 601 | * [ Entries ] | ||
| 602 | * [(PUD Page)]---> +---------+ | ||
| 603 | * | --------->+---------+ | ||
| 604 | * | | | PADDR1 | | ||
| 605 | * Mid-level | | PADDR2 | | ||
| 606 | * (PMD) page | | | | ||
| 607 | * | | Lower-level | | ||
| 608 | * | | (PTE) page | | ||
| 609 | * | | | | | ||
| 610 | * .... .... | ||
| 611 | * | ||
| 612 | * | ||
| 613 | * And the virtual address is decoded as: | ||
| 614 | * | ||
| 615 | * 1 1 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | ||
| 616 | * |<-2->|<--- 9 bits ---->|<---- 9 bits --->|<------ 12 bits ------>| | ||
| 617 | * Index into Index into mid Index into lower Offset within page | ||
| 618 | * top entries directory page pagetable page | ||
| 619 | * | ||
| 620 | * It's too hard to switch between these two formats at runtime, so Linux only | ||
| 621 | * supports one or the other depending on whether CONFIG_X86_PAE is set. Many | ||
| 622 | * distributions turn it on, and not just for people with silly amounts of | ||
| 623 | * memory: the larger PTE entries allow room for the NX bit, which lets the | ||
| 624 | * kernel disable execution of pages and increase security. | ||
| 625 | * | ||
| 626 | * This was a problem for lguest, which couldn't run on these distributions; | ||
| 627 | * then Matias Zabaljauregui figured it all out and implemented it, and only a | ||
| 628 | * handful of puppies were crushed in the process! | ||
| 629 | * | ||
| 630 | * Back to our point: the kernel spends a lot of time changing both the | ||
| 631 | * top-level page directory and lower-level pagetable pages. The Guest doesn't | ||
| 632 | * know physical addresses, so while it maintains these page tables exactly | ||
| 633 | * like normal, it also needs to keep the Host informed whenever it makes a | ||
| 634 | * change: the Host will create the real page tables based on the Guests'. | ||
| 539 | */ | 635 | */ |
| 540 | 636 | ||
| 541 | /* The Guest calls this to set a second-level entry (pte), ie. to map a page | 637 | /* |
| 542 | * into a process' address space. We set the entry then tell the Host the | 638 | * The Guest calls this after it has set a second-level entry (pte), ie. to map |
| 543 | * toplevel and address this corresponds to. The Guest uses one pagetable per | 639 | * a page into a process' address space. Wetell the Host the toplevel and |
| 544 | * process, so we need to tell the Host which one we're changing (mm->pgd). */ | 640 | * address this corresponds to. The Guest uses one pagetable per process, so |
| 641 | * we need to tell the Host which one we're changing (mm->pgd). | ||
| 642 | */ | ||
| 545 | static void lguest_pte_update(struct mm_struct *mm, unsigned long addr, | 643 | static void lguest_pte_update(struct mm_struct *mm, unsigned long addr, |
| 546 | pte_t *ptep) | 644 | pte_t *ptep) |
| 547 | { | 645 | { |
| 548 | #ifdef CONFIG_X86_PAE | 646 | #ifdef CONFIG_X86_PAE |
| 647 | /* PAE needs to hand a 64 bit page table entry, so it uses two args. */ | ||
| 549 | lazy_hcall4(LHCALL_SET_PTE, __pa(mm->pgd), addr, | 648 | lazy_hcall4(LHCALL_SET_PTE, __pa(mm->pgd), addr, |
| 550 | ptep->pte_low, ptep->pte_high); | 649 | ptep->pte_low, ptep->pte_high); |
| 551 | #else | 650 | #else |
| @@ -553,6 +652,7 @@ static void lguest_pte_update(struct mm_struct *mm, unsigned long addr, | |||
| 553 | #endif | 652 | #endif |
| 554 | } | 653 | } |
| 555 | 654 | ||
| 655 | /* This is the "set and update" combo-meal-deal version. */ | ||
| 556 | static void lguest_set_pte_at(struct mm_struct *mm, unsigned long addr, | 656 | static void lguest_set_pte_at(struct mm_struct *mm, unsigned long addr, |
| 557 | pte_t *ptep, pte_t pteval) | 657 | pte_t *ptep, pte_t pteval) |
| 558 | { | 658 | { |
| @@ -560,10 +660,13 @@ static void lguest_set_pte_at(struct mm_struct *mm, unsigned long addr, | |||
| 560 | lguest_pte_update(mm, addr, ptep); | 660 | lguest_pte_update(mm, addr, ptep); |
| 561 | } | 661 | } |
| 562 | 662 | ||
| 563 | /* The Guest calls lguest_set_pud to set a top-level entry and lguest_set_pmd | 663 | /* |
| 664 | * The Guest calls lguest_set_pud to set a top-level entry and lguest_set_pmd | ||
| 564 | * to set a middle-level entry when PAE is activated. | 665 | * to set a middle-level entry when PAE is activated. |
| 666 | * | ||
| 565 | * Again, we set the entry then tell the Host which page we changed, | 667 | * Again, we set the entry then tell the Host which page we changed, |
| 566 | * and the index of the entry we changed. */ | 668 | * and the index of the entry we changed. |
| 669 | */ | ||
| 567 | #ifdef CONFIG_X86_PAE | 670 | #ifdef CONFIG_X86_PAE |
| 568 | static void lguest_set_pud(pud_t *pudp, pud_t pudval) | 671 | static void lguest_set_pud(pud_t *pudp, pud_t pudval) |
| 569 | { | 672 | { |
| @@ -582,8 +685,7 @@ static void lguest_set_pmd(pmd_t *pmdp, pmd_t pmdval) | |||
| 582 | } | 685 | } |
| 583 | #else | 686 | #else |
| 584 | 687 | ||
| 585 | /* The Guest calls lguest_set_pmd to set a top-level entry when PAE is not | 688 | /* The Guest calls lguest_set_pmd to set a top-level entry when !PAE. */ |
| 586 | * activated. */ | ||
| 587 | static void lguest_set_pmd(pmd_t *pmdp, pmd_t pmdval) | 689 | static void lguest_set_pmd(pmd_t *pmdp, pmd_t pmdval) |
| 588 | { | 690 | { |
| 589 | native_set_pmd(pmdp, pmdval); | 691 | native_set_pmd(pmdp, pmdval); |
| @@ -592,7 +694,8 @@ static void lguest_set_pmd(pmd_t *pmdp, pmd_t pmdval) | |||
| 592 | } | 694 | } |
| 593 | #endif | 695 | #endif |
| 594 | 696 | ||
| 595 | /* There are a couple of legacy places where the kernel sets a PTE, but we | 697 | /* |
| 698 | * There are a couple of legacy places where the kernel sets a PTE, but we | ||
| 596 | * don't know the top level any more. This is useless for us, since we don't | 699 | * don't know the top level any more. This is useless for us, since we don't |
| 597 | * know which pagetable is changing or what address, so we just tell the Host | 700 | * know which pagetable is changing or what address, so we just tell the Host |
| 598 | * to forget all of them. Fortunately, this is very rare. | 701 | * to forget all of them. Fortunately, this is very rare. |
| @@ -600,7 +703,8 @@ static void lguest_set_pmd(pmd_t *pmdp, pmd_t pmdval) | |||
| 600 | * ... except in early boot when the kernel sets up the initial pagetables, | 703 | * ... except in early boot when the kernel sets up the initial pagetables, |
| 601 | * which makes booting astonishingly slow: 1.83 seconds! So we don't even tell | 704 | * which makes booting astonishingly slow: 1.83 seconds! So we don't even tell |
| 602 | * the Host anything changed until we've done the first page table switch, | 705 | * the Host anything changed until we've done the first page table switch, |
| 603 | * which brings boot back to 0.25 seconds. */ | 706 | * which brings boot back to 0.25 seconds. |
| 707 | */ | ||
| 604 | static void lguest_set_pte(pte_t *ptep, pte_t pteval) | 708 | static void lguest_set_pte(pte_t *ptep, pte_t pteval) |
| 605 | { | 709 | { |
| 606 | native_set_pte(ptep, pteval); | 710 | native_set_pte(ptep, pteval); |
| @@ -609,6 +713,11 @@ static void lguest_set_pte(pte_t *ptep, pte_t pteval) | |||
| 609 | } | 713 | } |
| 610 | 714 | ||
| 611 | #ifdef CONFIG_X86_PAE | 715 | #ifdef CONFIG_X86_PAE |
| 716 | /* | ||
| 717 | * With 64-bit PTE values, we need to be careful setting them: if we set 32 | ||
| 718 | * bits at a time, the hardware could see a weird half-set entry. These | ||
| 719 | * versions ensure we update all 64 bits at once. | ||
| 720 | */ | ||
| 612 | static void lguest_set_pte_atomic(pte_t *ptep, pte_t pte) | 721 | static void lguest_set_pte_atomic(pte_t *ptep, pte_t pte) |
| 613 | { | 722 | { |
| 614 | native_set_pte_atomic(ptep, pte); | 723 | native_set_pte_atomic(ptep, pte); |
| @@ -616,19 +725,21 @@ static void lguest_set_pte_atomic(pte_t *ptep, pte_t pte) | |||
| 616 | lazy_hcall1(LHCALL_FLUSH_TLB, 1); | 725 | lazy_hcall1(LHCALL_FLUSH_TLB, 1); |
| 617 | } | 726 | } |
| 618 | 727 | ||
| 619 | void lguest_pte_clear(struct mm_struct *mm, unsigned long addr, pte_t *ptep) | 728 | static void lguest_pte_clear(struct mm_struct *mm, unsigned long addr, |
| 729 | pte_t *ptep) | ||
| 620 | { | 730 | { |
| 621 | native_pte_clear(mm, addr, ptep); | 731 | native_pte_clear(mm, addr, ptep); |
| 622 | lguest_pte_update(mm, addr, ptep); | 732 | lguest_pte_update(mm, addr, ptep); |
| 623 | } | 733 | } |
| 624 | 734 | ||
| 625 | void lguest_pmd_clear(pmd_t *pmdp) | 735 | static void lguest_pmd_clear(pmd_t *pmdp) |
| 626 | { | 736 | { |
| 627 | lguest_set_pmd(pmdp, __pmd(0)); | 737 | lguest_set_pmd(pmdp, __pmd(0)); |
| 628 | } | 738 | } |
| 629 | #endif | 739 | #endif |
| 630 | 740 | ||
| 631 | /* Unfortunately for Lguest, the pv_mmu_ops for page tables were based on | 741 | /* |
| 742 | * Unfortunately for Lguest, the pv_mmu_ops for page tables were based on | ||
| 632 | * native page table operations. On native hardware you can set a new page | 743 | * native page table operations. On native hardware you can set a new page |
| 633 | * table entry whenever you want, but if you want to remove one you have to do | 744 | * table entry whenever you want, but if you want to remove one you have to do |
| 634 | * a TLB flush (a TLB is a little cache of page table entries kept by the CPU). | 745 | * a TLB flush (a TLB is a little cache of page table entries kept by the CPU). |
| @@ -637,24 +748,29 @@ void lguest_pmd_clear(pmd_t *pmdp) | |||
| 637 | * called when a valid entry is written, not when it's removed (ie. marked not | 748 | * called when a valid entry is written, not when it's removed (ie. marked not |
| 638 | * present). Instead, this is where we come when the Guest wants to remove a | 749 | * present). Instead, this is where we come when the Guest wants to remove a |
| 639 | * page table entry: we tell the Host to set that entry to 0 (ie. the present | 750 | * page table entry: we tell the Host to set that entry to 0 (ie. the present |
| 640 | * bit is zero). */ | 751 | * bit is zero). |
| 752 | */ | ||
| 641 | static void lguest_flush_tlb_single(unsigned long addr) | 753 | static void lguest_flush_tlb_single(unsigned long addr) |
| 642 | { | 754 | { |
| 643 | /* Simply set it to zero: if it was not, it will fault back in. */ | 755 | /* Simply set it to zero: if it was not, it will fault back in. */ |
| 644 | lazy_hcall3(LHCALL_SET_PTE, lguest_data.pgdir, addr, 0); | 756 | lazy_hcall3(LHCALL_SET_PTE, lguest_data.pgdir, addr, 0); |
| 645 | } | 757 | } |
| 646 | 758 | ||
| 647 | /* This is what happens after the Guest has removed a large number of entries. | 759 | /* |
| 760 | * This is what happens after the Guest has removed a large number of entries. | ||
| 648 | * This tells the Host that any of the page table entries for userspace might | 761 | * This tells the Host that any of the page table entries for userspace might |
| 649 | * have changed, ie. virtual addresses below PAGE_OFFSET. */ | 762 | * have changed, ie. virtual addresses below PAGE_OFFSET. |
| 763 | */ | ||
| 650 | static void lguest_flush_tlb_user(void) | 764 | static void lguest_flush_tlb_user(void) |
| 651 | { | 765 | { |
| 652 | lazy_hcall1(LHCALL_FLUSH_TLB, 0); | 766 | lazy_hcall1(LHCALL_FLUSH_TLB, 0); |
| 653 | } | 767 | } |
| 654 | 768 | ||
| 655 | /* This is called when the kernel page tables have changed. That's not very | 769 | /* |
| 770 | * This is called when the kernel page tables have changed. That's not very | ||
| 656 | * common (unless the Guest is using highmem, which makes the Guest extremely | 771 | * common (unless the Guest is using highmem, which makes the Guest extremely |
| 657 | * slow), so it's worth separating this from the user flushing above. */ | 772 | * slow), so it's worth separating this from the user flushing above. |
| 773 | */ | ||
| 658 | static void lguest_flush_tlb_kernel(void) | 774 | static void lguest_flush_tlb_kernel(void) |
| 659 | { | 775 | { |
| 660 | lazy_hcall1(LHCALL_FLUSH_TLB, 1); | 776 | lazy_hcall1(LHCALL_FLUSH_TLB, 1); |
| @@ -691,26 +807,38 @@ static struct irq_chip lguest_irq_controller = { | |||
| 691 | .unmask = enable_lguest_irq, | 807 | .unmask = enable_lguest_irq, |
| 692 | }; | 808 | }; |
| 693 | 809 | ||
| 694 | /* This sets up the Interrupt Descriptor Table (IDT) entry for each hardware | 810 | /* |
| 811 | * This sets up the Interrupt Descriptor Table (IDT) entry for each hardware | ||
| 695 | * interrupt (except 128, which is used for system calls), and then tells the | 812 | * interrupt (except 128, which is used for system calls), and then tells the |
| 696 | * Linux infrastructure that each interrupt is controlled by our level-based | 813 | * Linux infrastructure that each interrupt is controlled by our level-based |
| 697 | * lguest interrupt controller. */ | 814 | * lguest interrupt controller. |
| 815 | */ | ||
| 698 | static void __init lguest_init_IRQ(void) | 816 | static void __init lguest_init_IRQ(void) |
| 699 | { | 817 | { |
| 700 | unsigned int i; | 818 | unsigned int i; |
| 701 | 819 | ||
| 702 | for (i = FIRST_EXTERNAL_VECTOR; i < NR_VECTORS; i++) { | 820 | for (i = FIRST_EXTERNAL_VECTOR; i < NR_VECTORS; i++) { |
| 703 | /* Some systems map "vectors" to interrupts weirdly. Lguest has | 821 | /* Some systems map "vectors" to interrupts weirdly. Not us! */ |
| 704 | * a straightforward 1 to 1 mapping, so force that here. */ | ||
| 705 | __get_cpu_var(vector_irq)[i] = i - FIRST_EXTERNAL_VECTOR; | 822 | __get_cpu_var(vector_irq)[i] = i - FIRST_EXTERNAL_VECTOR; |
| 706 | if (i != SYSCALL_VECTOR) | 823 | if (i != SYSCALL_VECTOR) |
| 707 | set_intr_gate(i, interrupt[i - FIRST_EXTERNAL_VECTOR]); | 824 | set_intr_gate(i, interrupt[i - FIRST_EXTERNAL_VECTOR]); |
| 708 | } | 825 | } |
| 709 | /* This call is required to set up for 4k stacks, where we have | 826 | |
| 710 | * separate stacks for hard and soft interrupts. */ | 827 | /* |
| 828 | * This call is required to set up for 4k stacks, where we have | ||
| 829 | * separate stacks for hard and soft interrupts. | ||
| 830 | */ | ||
| 711 | irq_ctx_init(smp_processor_id()); | 831 | irq_ctx_init(smp_processor_id()); |
| 712 | } | 832 | } |
| 713 | 833 | ||
| 834 | /* | ||
| 835 | * With CONFIG_SPARSE_IRQ, interrupt descriptors are allocated as-needed, so | ||
| 836 | * rather than set them in lguest_init_IRQ we are called here every time an | ||
| 837 | * lguest device needs an interrupt. | ||
| 838 | * | ||
| 839 | * FIXME: irq_to_desc_alloc_node() can fail due to lack of memory, we should | ||
| 840 | * pass that up! | ||
| 841 | */ | ||
| 714 | void lguest_setup_irq(unsigned int irq) | 842 | void lguest_setup_irq(unsigned int irq) |
| 715 | { | 843 | { |
| 716 | irq_to_desc_alloc_node(irq, 0); | 844 | irq_to_desc_alloc_node(irq, 0); |
| @@ -729,31 +857,39 @@ static unsigned long lguest_get_wallclock(void) | |||
| 729 | return lguest_data.time.tv_sec; | 857 | return lguest_data.time.tv_sec; |
| 730 | } | 858 | } |
| 731 | 859 | ||
| 732 | /* The TSC is an Intel thing called the Time Stamp Counter. The Host tells us | 860 | /* |
| 861 | * The TSC is an Intel thing called the Time Stamp Counter. The Host tells us | ||
| 733 | * what speed it runs at, or 0 if it's unusable as a reliable clock source. | 862 | * what speed it runs at, or 0 if it's unusable as a reliable clock source. |
| 734 | * This matches what we want here: if we return 0 from this function, the x86 | 863 | * This matches what we want here: if we return 0 from this function, the x86 |
| 735 | * TSC clock will give up and not register itself. */ | 864 | * TSC clock will give up and not register itself. |
| 865 | */ | ||
| 736 | static unsigned long lguest_tsc_khz(void) | 866 | static unsigned long lguest_tsc_khz(void) |
| 737 | { | 867 | { |
| 738 | return lguest_data.tsc_khz; | 868 | return lguest_data.tsc_khz; |
| 739 | } | 869 | } |
| 740 | 870 | ||
| 741 | /* If we can't use the TSC, the kernel falls back to our lower-priority | 871 | /* |
| 742 | * "lguest_clock", where we read the time value given to us by the Host. */ | 872 | * If we can't use the TSC, the kernel falls back to our lower-priority |
| 873 | * "lguest_clock", where we read the time value given to us by the Host. | ||
| 874 | */ | ||
| 743 | static cycle_t lguest_clock_read(struct clocksource *cs) | 875 | static cycle_t lguest_clock_read(struct clocksource *cs) |
| 744 | { | 876 | { |
| 745 | unsigned long sec, nsec; | 877 | unsigned long sec, nsec; |
| 746 | 878 | ||
| 747 | /* Since the time is in two parts (seconds and nanoseconds), we risk | 879 | /* |
| 880 | * Since the time is in two parts (seconds and nanoseconds), we risk | ||
| 748 | * reading it just as it's changing from 99 & 0.999999999 to 100 and 0, | 881 | * reading it just as it's changing from 99 & 0.999999999 to 100 and 0, |
| 749 | * and getting 99 and 0. As Linux tends to come apart under the stress | 882 | * and getting 99 and 0. As Linux tends to come apart under the stress |
| 750 | * of time travel, we must be careful: */ | 883 | * of time travel, we must be careful: |
| 884 | */ | ||
| 751 | do { | 885 | do { |
| 752 | /* First we read the seconds part. */ | 886 | /* First we read the seconds part. */ |
| 753 | sec = lguest_data.time.tv_sec; | 887 | sec = lguest_data.time.tv_sec; |
| 754 | /* This read memory barrier tells the compiler and the CPU that | 888 | /* |
| 889 | * This read memory barrier tells the compiler and the CPU that | ||
| 755 | * this can't be reordered: we have to complete the above | 890 | * this can't be reordered: we have to complete the above |
| 756 | * before going on. */ | 891 | * before going on. |
| 892 | */ | ||
| 757 | rmb(); | 893 | rmb(); |
| 758 | /* Now we read the nanoseconds part. */ | 894 | /* Now we read the nanoseconds part. */ |
| 759 | nsec = lguest_data.time.tv_nsec; | 895 | nsec = lguest_data.time.tv_nsec; |
| @@ -777,9 +913,11 @@ static struct clocksource lguest_clock = { | |||
| 777 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | 913 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, |
| 778 | }; | 914 | }; |
| 779 | 915 | ||
| 780 | /* We also need a "struct clock_event_device": Linux asks us to set it to go | 916 | /* |
| 917 | * We also need a "struct clock_event_device": Linux asks us to set it to go | ||
| 781 | * off some time in the future. Actually, James Morris figured all this out, I | 918 | * off some time in the future. Actually, James Morris figured all this out, I |
| 782 | * just applied the patch. */ | 919 | * just applied the patch. |
| 920 | */ | ||
| 783 | static int lguest_clockevent_set_next_event(unsigned long delta, | 921 | static int lguest_clockevent_set_next_event(unsigned long delta, |
| 784 | struct clock_event_device *evt) | 922 | struct clock_event_device *evt) |
| 785 | { | 923 | { |
| @@ -829,8 +967,10 @@ static struct clock_event_device lguest_clockevent = { | |||
| 829 | .max_delta_ns = LG_CLOCK_MAX_DELTA, | 967 | .max_delta_ns = LG_CLOCK_MAX_DELTA, |
| 830 | }; | 968 | }; |
| 831 | 969 | ||
| 832 | /* This is the Guest timer interrupt handler (hardware interrupt 0). We just | 970 | /* |
| 833 | * call the clockevent infrastructure and it does whatever needs doing. */ | 971 | * This is the Guest timer interrupt handler (hardware interrupt 0). We just |
| 972 | * call the clockevent infrastructure and it does whatever needs doing. | ||
| 973 | */ | ||
| 834 | static void lguest_time_irq(unsigned int irq, struct irq_desc *desc) | 974 | static void lguest_time_irq(unsigned int irq, struct irq_desc *desc) |
| 835 | { | 975 | { |
| 836 | unsigned long flags; | 976 | unsigned long flags; |
| @@ -841,10 +981,12 @@ static void lguest_time_irq(unsigned int irq, struct irq_desc *desc) | |||
| 841 | local_irq_restore(flags); | 981 | local_irq_restore(flags); |
| 842 | } | 982 | } |
| 843 | 983 | ||
| 844 | /* At some point in the boot process, we get asked to set up our timing | 984 | /* |
| 985 | * At some point in the boot process, we get asked to set up our timing | ||
| 845 | * infrastructure. The kernel doesn't expect timer interrupts before this, but | 986 | * infrastructure. The kernel doesn't expect timer interrupts before this, but |
| 846 | * we cleverly initialized the "blocked_interrupts" field of "struct | 987 | * we cleverly initialized the "blocked_interrupts" field of "struct |
| 847 | * lguest_data" so that timer interrupts were blocked until now. */ | 988 | * lguest_data" so that timer interrupts were blocked until now. |
| 989 | */ | ||
| 848 | static void lguest_time_init(void) | 990 | static void lguest_time_init(void) |
| 849 | { | 991 | { |
| 850 | /* Set up the timer interrupt (0) to go to our simple timer routine */ | 992 | /* Set up the timer interrupt (0) to go to our simple timer routine */ |
| @@ -868,14 +1010,16 @@ static void lguest_time_init(void) | |||
| 868 | * to work. They're pretty simple. | 1010 | * to work. They're pretty simple. |
| 869 | */ | 1011 | */ |
| 870 | 1012 | ||
| 871 | /* The Guest needs to tell the Host what stack it expects traps to use. For | 1013 | /* |
| 1014 | * The Guest needs to tell the Host what stack it expects traps to use. For | ||
| 872 | * native hardware, this is part of the Task State Segment mentioned above in | 1015 | * native hardware, this is part of the Task State Segment mentioned above in |
| 873 | * lguest_load_tr_desc(), but to help hypervisors there's this special call. | 1016 | * lguest_load_tr_desc(), but to help hypervisors there's this special call. |
| 874 | * | 1017 | * |
| 875 | * We tell the Host the segment we want to use (__KERNEL_DS is the kernel data | 1018 | * We tell the Host the segment we want to use (__KERNEL_DS is the kernel data |
| 876 | * segment), the privilege level (we're privilege level 1, the Host is 0 and | 1019 | * segment), the privilege level (we're privilege level 1, the Host is 0 and |
| 877 | * will not tolerate us trying to use that), the stack pointer, and the number | 1020 | * will not tolerate us trying to use that), the stack pointer, and the number |
| 878 | * of pages in the stack. */ | 1021 | * of pages in the stack. |
| 1022 | */ | ||
| 879 | static void lguest_load_sp0(struct tss_struct *tss, | 1023 | static void lguest_load_sp0(struct tss_struct *tss, |
| 880 | struct thread_struct *thread) | 1024 | struct thread_struct *thread) |
| 881 | { | 1025 | { |
| @@ -889,7 +1033,8 @@ static void lguest_set_debugreg(int regno, unsigned long value) | |||
| 889 | /* FIXME: Implement */ | 1033 | /* FIXME: Implement */ |
| 890 | } | 1034 | } |
| 891 | 1035 | ||
| 892 | /* There are times when the kernel wants to make sure that no memory writes are | 1036 | /* |
| 1037 | * There are times when the kernel wants to make sure that no memory writes are | ||
| 893 | * caught in the cache (that they've all reached real hardware devices). This | 1038 | * caught in the cache (that they've all reached real hardware devices). This |
| 894 | * doesn't matter for the Guest which has virtual hardware. | 1039 | * doesn't matter for the Guest which has virtual hardware. |
| 895 | * | 1040 | * |
| @@ -903,11 +1048,13 @@ static void lguest_wbinvd(void) | |||
| 903 | { | 1048 | { |
| 904 | } | 1049 | } |
| 905 | 1050 | ||
| 906 | /* If the Guest expects to have an Advanced Programmable Interrupt Controller, | 1051 | /* |
| 1052 | * If the Guest expects to have an Advanced Programmable Interrupt Controller, | ||
| 907 | * we play dumb by ignoring writes and returning 0 for reads. So it's no | 1053 | * we play dumb by ignoring writes and returning 0 for reads. So it's no |
| 908 | * longer Programmable nor Controlling anything, and I don't think 8 lines of | 1054 | * longer Programmable nor Controlling anything, and I don't think 8 lines of |
| 909 | * code qualifies for Advanced. It will also never interrupt anything. It | 1055 | * code qualifies for Advanced. It will also never interrupt anything. It |
| 910 | * does, however, allow us to get through the Linux boot code. */ | 1056 | * does, however, allow us to get through the Linux boot code. |
| 1057 | */ | ||
| 911 | #ifdef CONFIG_X86_LOCAL_APIC | 1058 | #ifdef CONFIG_X86_LOCAL_APIC |
| 912 | static void lguest_apic_write(u32 reg, u32 v) | 1059 | static void lguest_apic_write(u32 reg, u32 v) |
| 913 | { | 1060 | { |
| @@ -956,11 +1103,13 @@ static void lguest_safe_halt(void) | |||
| 956 | kvm_hypercall0(LHCALL_HALT); | 1103 | kvm_hypercall0(LHCALL_HALT); |
| 957 | } | 1104 | } |
| 958 | 1105 | ||
| 959 | /* The SHUTDOWN hypercall takes a string to describe what's happening, and | 1106 | /* |
| 1107 | * The SHUTDOWN hypercall takes a string to describe what's happening, and | ||
| 960 | * an argument which says whether this to restart (reboot) the Guest or not. | 1108 | * an argument which says whether this to restart (reboot) the Guest or not. |
| 961 | * | 1109 | * |
| 962 | * Note that the Host always prefers that the Guest speak in physical addresses | 1110 | * Note that the Host always prefers that the Guest speak in physical addresses |
| 963 | * rather than virtual addresses, so we use __pa() here. */ | 1111 | * rather than virtual addresses, so we use __pa() here. |
| 1112 | */ | ||
| 964 | static void lguest_power_off(void) | 1113 | static void lguest_power_off(void) |
| 965 | { | 1114 | { |
| 966 | kvm_hypercall2(LHCALL_SHUTDOWN, __pa("Power down"), | 1115 | kvm_hypercall2(LHCALL_SHUTDOWN, __pa("Power down"), |
| @@ -991,8 +1140,10 @@ static __init char *lguest_memory_setup(void) | |||
| 991 | * nice to move it back to lguest_init. Patch welcome... */ | 1140 | * nice to move it back to lguest_init. Patch welcome... */ |
| 992 | atomic_notifier_chain_register(&panic_notifier_list, &paniced); | 1141 | atomic_notifier_chain_register(&panic_notifier_list, &paniced); |
| 993 | 1142 | ||
| 994 | /* The Linux bootloader header contains an "e820" memory map: the | 1143 | /* |
| 995 | * Launcher populated the first entry with our memory limit. */ | 1144 | *The Linux bootloader header contains an "e820" memory map: the |
| 1145 | * Launcher populated the first entry with our memory limit. | ||
| 1146 | */ | ||
| 996 | e820_add_region(boot_params.e820_map[0].addr, | 1147 | e820_add_region(boot_params.e820_map[0].addr, |
| 997 | boot_params.e820_map[0].size, | 1148 | boot_params.e820_map[0].size, |
| 998 | boot_params.e820_map[0].type); | 1149 | boot_params.e820_map[0].type); |
| @@ -1001,16 +1152,17 @@ static __init char *lguest_memory_setup(void) | |||
| 1001 | return "LGUEST"; | 1152 | return "LGUEST"; |
| 1002 | } | 1153 | } |
| 1003 | 1154 | ||
| 1004 | /* We will eventually use the virtio console device to produce console output, | 1155 | /* |
| 1156 | * We will eventually use the virtio console device to produce console output, | ||
| 1005 | * but before that is set up we use LHCALL_NOTIFY on normal memory to produce | 1157 | * but before that is set up we use LHCALL_NOTIFY on normal memory to produce |
| 1006 | * console output. */ | 1158 | * console output. |
| 1159 | */ | ||
| 1007 | static __init int early_put_chars(u32 vtermno, const char *buf, int count) | 1160 | static __init int early_put_chars(u32 vtermno, const char *buf, int count) |
| 1008 | { | 1161 | { |
| 1009 | char scratch[17]; | 1162 | char scratch[17]; |
| 1010 | unsigned int len = count; | 1163 | unsigned int len = count; |
| 1011 | 1164 | ||
| 1012 | /* We use a nul-terminated string, so we have to make a copy. Icky, | 1165 | /* We use a nul-terminated string, so we make a copy. Icky, huh? */ |
| 1013 | * huh? */ | ||
| 1014 | if (len > sizeof(scratch) - 1) | 1166 | if (len > sizeof(scratch) - 1) |
| 1015 | len = sizeof(scratch) - 1; | 1167 | len = sizeof(scratch) - 1; |
| 1016 | scratch[len] = '\0'; | 1168 | scratch[len] = '\0'; |
| @@ -1021,8 +1173,10 @@ static __init int early_put_chars(u32 vtermno, const char *buf, int count) | |||
| 1021 | return len; | 1173 | return len; |
| 1022 | } | 1174 | } |
| 1023 | 1175 | ||
| 1024 | /* Rebooting also tells the Host we're finished, but the RESTART flag tells the | 1176 | /* |
| 1025 | * Launcher to reboot us. */ | 1177 | * Rebooting also tells the Host we're finished, but the RESTART flag tells the |
| 1178 | * Launcher to reboot us. | ||
| 1179 | */ | ||
| 1026 | static void lguest_restart(char *reason) | 1180 | static void lguest_restart(char *reason) |
| 1027 | { | 1181 | { |
| 1028 | kvm_hypercall2(LHCALL_SHUTDOWN, __pa(reason), LGUEST_SHUTDOWN_RESTART); | 1182 | kvm_hypercall2(LHCALL_SHUTDOWN, __pa(reason), LGUEST_SHUTDOWN_RESTART); |
| @@ -1049,7 +1203,8 @@ static void lguest_restart(char *reason) | |||
| 1049 | * fit comfortably. | 1203 | * fit comfortably. |
| 1050 | * | 1204 | * |
| 1051 | * First we need assembly templates of each of the patchable Guest operations, | 1205 | * First we need assembly templates of each of the patchable Guest operations, |
| 1052 | * and these are in i386_head.S. */ | 1206 | * and these are in i386_head.S. |
| 1207 | */ | ||
| 1053 | 1208 | ||
| 1054 | /*G:060 We construct a table from the assembler templates: */ | 1209 | /*G:060 We construct a table from the assembler templates: */ |
| 1055 | static const struct lguest_insns | 1210 | static const struct lguest_insns |
| @@ -1060,9 +1215,11 @@ static const struct lguest_insns | |||
| 1060 | [PARAVIRT_PATCH(pv_irq_ops.save_fl)] = { lgstart_pushf, lgend_pushf }, | 1215 | [PARAVIRT_PATCH(pv_irq_ops.save_fl)] = { lgstart_pushf, lgend_pushf }, |
| 1061 | }; | 1216 | }; |
| 1062 | 1217 | ||
| 1063 | /* Now our patch routine is fairly simple (based on the native one in | 1218 | /* |
| 1219 | * Now our patch routine is fairly simple (based on the native one in | ||
| 1064 | * paravirt.c). If we have a replacement, we copy it in and return how much of | 1220 | * paravirt.c). If we have a replacement, we copy it in and return how much of |
| 1065 | * the available space we used. */ | 1221 | * the available space we used. |
| 1222 | */ | ||
| 1066 | static unsigned lguest_patch(u8 type, u16 clobber, void *ibuf, | 1223 | static unsigned lguest_patch(u8 type, u16 clobber, void *ibuf, |
| 1067 | unsigned long addr, unsigned len) | 1224 | unsigned long addr, unsigned len) |
| 1068 | { | 1225 | { |
| @@ -1074,8 +1231,7 @@ static unsigned lguest_patch(u8 type, u16 clobber, void *ibuf, | |||
| 1074 | 1231 | ||
| 1075 | insn_len = lguest_insns[type].end - lguest_insns[type].start; | 1232 | insn_len = lguest_insns[type].end - lguest_insns[type].start; |
| 1076 | 1233 | ||
| 1077 | /* Similarly if we can't fit replacement (shouldn't happen, but let's | 1234 | /* Similarly if it can't fit (doesn't happen, but let's be thorough). */ |
| 1078 | * be thorough). */ | ||
| 1079 | if (len < insn_len) | 1235 | if (len < insn_len) |
| 1080 | return paravirt_patch_default(type, clobber, ibuf, addr, len); | 1236 | return paravirt_patch_default(type, clobber, ibuf, addr, len); |
| 1081 | 1237 | ||
| @@ -1084,22 +1240,28 @@ static unsigned lguest_patch(u8 type, u16 clobber, void *ibuf, | |||
| 1084 | return insn_len; | 1240 | return insn_len; |
| 1085 | } | 1241 | } |
| 1086 | 1242 | ||
| 1087 | /*G:029 Once we get to lguest_init(), we know we're a Guest. The various | 1243 | /*G:029 |
| 1244 | * Once we get to lguest_init(), we know we're a Guest. The various | ||
| 1088 | * pv_ops structures in the kernel provide points for (almost) every routine we | 1245 | * pv_ops structures in the kernel provide points for (almost) every routine we |
| 1089 | * have to override to avoid privileged instructions. */ | 1246 | * have to override to avoid privileged instructions. |
| 1247 | */ | ||
| 1090 | __init void lguest_init(void) | 1248 | __init void lguest_init(void) |
| 1091 | { | 1249 | { |
| 1092 | /* We're under lguest, paravirt is enabled, and we're running at | 1250 | /* We're under lguest. */ |
| 1093 | * privilege level 1, not 0 as normal. */ | ||
| 1094 | pv_info.name = "lguest"; | 1251 | pv_info.name = "lguest"; |
| 1252 | /* Paravirt is enabled. */ | ||
| 1095 | pv_info.paravirt_enabled = 1; | 1253 | pv_info.paravirt_enabled = 1; |
| 1254 | /* We're running at privilege level 1, not 0 as normal. */ | ||
| 1096 | pv_info.kernel_rpl = 1; | 1255 | pv_info.kernel_rpl = 1; |
| 1256 | /* Everyone except Xen runs with this set. */ | ||
| 1097 | pv_info.shared_kernel_pmd = 1; | 1257 | pv_info.shared_kernel_pmd = 1; |
| 1098 | 1258 | ||
| 1099 | /* We set up all the lguest overrides for sensitive operations. These | 1259 | /* |
| 1100 | * are detailed with the operations themselves. */ | 1260 | * We set up all the lguest overrides for sensitive operations. These |
| 1261 | * are detailed with the operations themselves. | ||
| 1262 | */ | ||
| 1101 | 1263 | ||
| 1102 | /* interrupt-related operations */ | 1264 | /* Interrupt-related operations */ |
| 1103 | pv_irq_ops.init_IRQ = lguest_init_IRQ; | 1265 | pv_irq_ops.init_IRQ = lguest_init_IRQ; |
| 1104 | pv_irq_ops.save_fl = PV_CALLEE_SAVE(save_fl); | 1266 | pv_irq_ops.save_fl = PV_CALLEE_SAVE(save_fl); |
| 1105 | pv_irq_ops.restore_fl = __PV_IS_CALLEE_SAVE(lg_restore_fl); | 1267 | pv_irq_ops.restore_fl = __PV_IS_CALLEE_SAVE(lg_restore_fl); |
| @@ -1107,11 +1269,11 @@ __init void lguest_init(void) | |||
| 1107 | pv_irq_ops.irq_enable = __PV_IS_CALLEE_SAVE(lg_irq_enable); | 1269 | pv_irq_ops.irq_enable = __PV_IS_CALLEE_SAVE(lg_irq_enable); |
| 1108 | pv_irq_ops.safe_halt = lguest_safe_halt; | 1270 | pv_irq_ops.safe_halt = lguest_safe_halt; |
| 1109 | 1271 | ||
| 1110 | /* init-time operations */ | 1272 | /* Setup operations */ |
| 1111 | pv_init_ops.memory_setup = lguest_memory_setup; | 1273 | pv_init_ops.memory_setup = lguest_memory_setup; |
| 1112 | pv_init_ops.patch = lguest_patch; | 1274 | pv_init_ops.patch = lguest_patch; |
| 1113 | 1275 | ||
| 1114 | /* Intercepts of various cpu instructions */ | 1276 | /* Intercepts of various CPU instructions */ |
| 1115 | pv_cpu_ops.load_gdt = lguest_load_gdt; | 1277 | pv_cpu_ops.load_gdt = lguest_load_gdt; |
| 1116 | pv_cpu_ops.cpuid = lguest_cpuid; | 1278 | pv_cpu_ops.cpuid = lguest_cpuid; |
| 1117 | pv_cpu_ops.load_idt = lguest_load_idt; | 1279 | pv_cpu_ops.load_idt = lguest_load_idt; |
| @@ -1132,7 +1294,7 @@ __init void lguest_init(void) | |||
| 1132 | pv_cpu_ops.start_context_switch = paravirt_start_context_switch; | 1294 | pv_cpu_ops.start_context_switch = paravirt_start_context_switch; |
| 1133 | pv_cpu_ops.end_context_switch = lguest_end_context_switch; | 1295 | pv_cpu_ops.end_context_switch = lguest_end_context_switch; |
| 1134 | 1296 | ||
| 1135 | /* pagetable management */ | 1297 | /* Pagetable management */ |
| 1136 | pv_mmu_ops.write_cr3 = lguest_write_cr3; | 1298 | pv_mmu_ops.write_cr3 = lguest_write_cr3; |
| 1137 | pv_mmu_ops.flush_tlb_user = lguest_flush_tlb_user; | 1299 | pv_mmu_ops.flush_tlb_user = lguest_flush_tlb_user; |
| 1138 | pv_mmu_ops.flush_tlb_single = lguest_flush_tlb_single; | 1300 | pv_mmu_ops.flush_tlb_single = lguest_flush_tlb_single; |
| @@ -1154,54 +1316,71 @@ __init void lguest_init(void) | |||
| 1154 | pv_mmu_ops.pte_update_defer = lguest_pte_update; | 1316 | pv_mmu_ops.pte_update_defer = lguest_pte_update; |
| 1155 | 1317 | ||
| 1156 | #ifdef CONFIG_X86_LOCAL_APIC | 1318 | #ifdef CONFIG_X86_LOCAL_APIC |
| 1157 | /* apic read/write intercepts */ | 1319 | /* APIC read/write intercepts */ |
| 1158 | set_lguest_basic_apic_ops(); | 1320 | set_lguest_basic_apic_ops(); |
| 1159 | #endif | 1321 | #endif |
| 1160 | 1322 | ||
| 1161 | /* time operations */ | 1323 | /* Time operations */ |
| 1162 | pv_time_ops.get_wallclock = lguest_get_wallclock; | 1324 | pv_time_ops.get_wallclock = lguest_get_wallclock; |
| 1163 | pv_time_ops.time_init = lguest_time_init; | 1325 | pv_time_ops.time_init = lguest_time_init; |
| 1164 | pv_time_ops.get_tsc_khz = lguest_tsc_khz; | 1326 | pv_time_ops.get_tsc_khz = lguest_tsc_khz; |
| 1165 | 1327 | ||
| 1166 | /* Now is a good time to look at the implementations of these functions | 1328 | /* |
| 1167 | * before returning to the rest of lguest_init(). */ | 1329 | * Now is a good time to look at the implementations of these functions |
| 1330 | * before returning to the rest of lguest_init(). | ||
| 1331 | */ | ||
| 1168 | 1332 | ||
| 1169 | /*G:070 Now we've seen all the paravirt_ops, we return to | 1333 | /*G:070 |
| 1334 | * Now we've seen all the paravirt_ops, we return to | ||
| 1170 | * lguest_init() where the rest of the fairly chaotic boot setup | 1335 | * lguest_init() where the rest of the fairly chaotic boot setup |
| 1171 | * occurs. */ | 1336 | * occurs. |
| 1337 | */ | ||
| 1172 | 1338 | ||
| 1173 | /* The stack protector is a weird thing where gcc places a canary | 1339 | /* |
| 1340 | * The stack protector is a weird thing where gcc places a canary | ||
| 1174 | * value on the stack and then checks it on return. This file is | 1341 | * value on the stack and then checks it on return. This file is |
| 1175 | * compiled with -fno-stack-protector it, so we got this far without | 1342 | * compiled with -fno-stack-protector it, so we got this far without |
| 1176 | * problems. The value of the canary is kept at offset 20 from the | 1343 | * problems. The value of the canary is kept at offset 20 from the |
| 1177 | * %gs register, so we need to set that up before calling C functions | 1344 | * %gs register, so we need to set that up before calling C functions |
| 1178 | * in other files. */ | 1345 | * in other files. |
| 1346 | */ | ||
| 1179 | setup_stack_canary_segment(0); | 1347 | setup_stack_canary_segment(0); |
| 1180 | /* We could just call load_stack_canary_segment(), but we might as | 1348 | |
| 1181 | * call switch_to_new_gdt() which loads the whole table and sets up | 1349 | /* |
| 1182 | * the per-cpu segment descriptor register %fs as well. */ | 1350 | * We could just call load_stack_canary_segment(), but we might as well |
| 1351 | * call switch_to_new_gdt() which loads the whole table and sets up the | ||
| 1352 | * per-cpu segment descriptor register %fs as well. | ||
| 1353 | */ | ||
| 1183 | switch_to_new_gdt(0); | 1354 | switch_to_new_gdt(0); |
| 1184 | 1355 | ||
| 1185 | /* As described in head_32.S, we map the first 128M of memory. */ | 1356 | /* We actually boot with all memory mapped, but let's say 128MB. */ |
| 1186 | max_pfn_mapped = (128*1024*1024) >> PAGE_SHIFT; | 1357 | max_pfn_mapped = (128*1024*1024) >> PAGE_SHIFT; |
| 1187 | 1358 | ||
| 1188 | /* The Host<->Guest Switcher lives at the top of our address space, and | 1359 | /* |
| 1360 | * The Host<->Guest Switcher lives at the top of our address space, and | ||
| 1189 | * the Host told us how big it is when we made LGUEST_INIT hypercall: | 1361 | * the Host told us how big it is when we made LGUEST_INIT hypercall: |
| 1190 | * it put the answer in lguest_data.reserve_mem */ | 1362 | * it put the answer in lguest_data.reserve_mem |
| 1363 | */ | ||
| 1191 | reserve_top_address(lguest_data.reserve_mem); | 1364 | reserve_top_address(lguest_data.reserve_mem); |
| 1192 | 1365 | ||
| 1193 | /* If we don't initialize the lock dependency checker now, it crashes | 1366 | /* |
| 1194 | * paravirt_disable_iospace. */ | 1367 | * If we don't initialize the lock dependency checker now, it crashes |
| 1368 | * paravirt_disable_iospace. | ||
| 1369 | */ | ||
| 1195 | lockdep_init(); | 1370 | lockdep_init(); |
| 1196 | 1371 | ||
| 1197 | /* The IDE code spends about 3 seconds probing for disks: if we reserve | 1372 | /* |
| 1373 | * The IDE code spends about 3 seconds probing for disks: if we reserve | ||
| 1198 | * all the I/O ports up front it can't get them and so doesn't probe. | 1374 | * all the I/O ports up front it can't get them and so doesn't probe. |
| 1199 | * Other device drivers are similar (but less severe). This cuts the | 1375 | * Other device drivers are similar (but less severe). This cuts the |
| 1200 | * kernel boot time on my machine from 4.1 seconds to 0.45 seconds. */ | 1376 | * kernel boot time on my machine from 4.1 seconds to 0.45 seconds. |
| 1377 | */ | ||
| 1201 | paravirt_disable_iospace(); | 1378 | paravirt_disable_iospace(); |
| 1202 | 1379 | ||
| 1203 | /* This is messy CPU setup stuff which the native boot code does before | 1380 | /* |
| 1204 | * start_kernel, so we have to do, too: */ | 1381 | * This is messy CPU setup stuff which the native boot code does before |
| 1382 | * start_kernel, so we have to do, too: | ||
| 1383 | */ | ||
| 1205 | cpu_detect(&new_cpu_data); | 1384 | cpu_detect(&new_cpu_data); |
| 1206 | /* head.S usually sets up the first capability word, so do it here. */ | 1385 | /* head.S usually sets up the first capability word, so do it here. */ |
| 1207 | new_cpu_data.x86_capability[0] = cpuid_edx(1); | 1386 | new_cpu_data.x86_capability[0] = cpuid_edx(1); |
| @@ -1218,22 +1397,28 @@ __init void lguest_init(void) | |||
| 1218 | acpi_ht = 0; | 1397 | acpi_ht = 0; |
| 1219 | #endif | 1398 | #endif |
| 1220 | 1399 | ||
| 1221 | /* We set the preferred console to "hvc". This is the "hypervisor | 1400 | /* |
| 1401 | * We set the preferred console to "hvc". This is the "hypervisor | ||
| 1222 | * virtual console" driver written by the PowerPC people, which we also | 1402 | * virtual console" driver written by the PowerPC people, which we also |
| 1223 | * adapted for lguest's use. */ | 1403 | * adapted for lguest's use. |
| 1404 | */ | ||
| 1224 | add_preferred_console("hvc", 0, NULL); | 1405 | add_preferred_console("hvc", 0, NULL); |
| 1225 | 1406 | ||
| 1226 | /* Register our very early console. */ | 1407 | /* Register our very early console. */ |
| 1227 | virtio_cons_early_init(early_put_chars); | 1408 | virtio_cons_early_init(early_put_chars); |
| 1228 | 1409 | ||
| 1229 | /* Last of all, we set the power management poweroff hook to point to | 1410 | /* |
| 1411 | * Last of all, we set the power management poweroff hook to point to | ||
| 1230 | * the Guest routine to power off, and the reboot hook to our restart | 1412 | * the Guest routine to power off, and the reboot hook to our restart |
| 1231 | * routine. */ | 1413 | * routine. |
| 1414 | */ | ||
| 1232 | pm_power_off = lguest_power_off; | 1415 | pm_power_off = lguest_power_off; |
| 1233 | machine_ops.restart = lguest_restart; | 1416 | machine_ops.restart = lguest_restart; |
| 1234 | 1417 | ||
| 1235 | /* Now we're set up, call i386_start_kernel() in head32.c and we proceed | 1418 | /* |
| 1236 | * to boot as normal. It never returns. */ | 1419 | * Now we're set up, call i386_start_kernel() in head32.c and we proceed |
| 1420 | * to boot as normal. It never returns. | ||
| 1421 | */ | ||
| 1237 | i386_start_kernel(); | 1422 | i386_start_kernel(); |
| 1238 | } | 1423 | } |
| 1239 | /* | 1424 | /* |
diff --git a/arch/x86/lguest/i386_head.S b/arch/x86/lguest/i386_head.S index a9c8cfe61cd4..27eac0faee48 100644 --- a/arch/x86/lguest/i386_head.S +++ b/arch/x86/lguest/i386_head.S | |||
| @@ -5,7 +5,8 @@ | |||
| 5 | #include <asm/thread_info.h> | 5 | #include <asm/thread_info.h> |
| 6 | #include <asm/processor-flags.h> | 6 | #include <asm/processor-flags.h> |
| 7 | 7 | ||
| 8 | /*G:020 Our story starts with the kernel booting into startup_32 in | 8 | /*G:020 |
| 9 | * Our story starts with the kernel booting into startup_32 in | ||
| 9 | * arch/x86/kernel/head_32.S. It expects a boot header, which is created by | 10 | * arch/x86/kernel/head_32.S. It expects a boot header, which is created by |
| 10 | * the bootloader (the Launcher in our case). | 11 | * the bootloader (the Launcher in our case). |
| 11 | * | 12 | * |
| @@ -21,11 +22,14 @@ | |||
| 21 | * data without remembering to subtract __PAGE_OFFSET! | 22 | * data without remembering to subtract __PAGE_OFFSET! |
| 22 | * | 23 | * |
| 23 | * The .section line puts this code in .init.text so it will be discarded after | 24 | * The .section line puts this code in .init.text so it will be discarded after |
| 24 | * boot. */ | 25 | * boot. |
| 26 | */ | ||
| 25 | .section .init.text, "ax", @progbits | 27 | .section .init.text, "ax", @progbits |
| 26 | ENTRY(lguest_entry) | 28 | ENTRY(lguest_entry) |
| 27 | /* We make the "initialization" hypercall now to tell the Host about | 29 | /* |
| 28 | * us, and also find out where it put our page tables. */ | 30 | * We make the "initialization" hypercall now to tell the Host about |
| 31 | * us, and also find out where it put our page tables. | ||
| 32 | */ | ||
| 29 | movl $LHCALL_LGUEST_INIT, %eax | 33 | movl $LHCALL_LGUEST_INIT, %eax |
| 30 | movl $lguest_data - __PAGE_OFFSET, %ebx | 34 | movl $lguest_data - __PAGE_OFFSET, %ebx |
| 31 | .byte 0x0f,0x01,0xc1 /* KVM_HYPERCALL */ | 35 | .byte 0x0f,0x01,0xc1 /* KVM_HYPERCALL */ |
| @@ -33,13 +37,14 @@ ENTRY(lguest_entry) | |||
| 33 | /* Set up the initial stack so we can run C code. */ | 37 | /* Set up the initial stack so we can run C code. */ |
| 34 | movl $(init_thread_union+THREAD_SIZE),%esp | 38 | movl $(init_thread_union+THREAD_SIZE),%esp |
| 35 | 39 | ||
| 36 | /* Jumps are relative, and we're running __PAGE_OFFSET too low at the | 40 | /* Jumps are relative: we're running __PAGE_OFFSET too low. */ |
| 37 | * moment. */ | ||
| 38 | jmp lguest_init+__PAGE_OFFSET | 41 | jmp lguest_init+__PAGE_OFFSET |
| 39 | 42 | ||
| 40 | /*G:055 We create a macro which puts the assembler code between lgstart_ and | 43 | /*G:055 |
| 41 | * lgend_ markers. These templates are put in the .text section: they can't be | 44 | * We create a macro which puts the assembler code between lgstart_ and lgend_ |
| 42 | * discarded after boot as we may need to patch modules, too. */ | 45 | * markers. These templates are put in the .text section: they can't be |
| 46 | * discarded after boot as we may need to patch modules, too. | ||
| 47 | */ | ||
| 43 | .text | 48 | .text |
| 44 | #define LGUEST_PATCH(name, insns...) \ | 49 | #define LGUEST_PATCH(name, insns...) \ |
| 45 | lgstart_##name: insns; lgend_##name:; \ | 50 | lgstart_##name: insns; lgend_##name:; \ |
| @@ -48,83 +53,103 @@ ENTRY(lguest_entry) | |||
| 48 | LGUEST_PATCH(cli, movl $0, lguest_data+LGUEST_DATA_irq_enabled) | 53 | LGUEST_PATCH(cli, movl $0, lguest_data+LGUEST_DATA_irq_enabled) |
| 49 | LGUEST_PATCH(pushf, movl lguest_data+LGUEST_DATA_irq_enabled, %eax) | 54 | LGUEST_PATCH(pushf, movl lguest_data+LGUEST_DATA_irq_enabled, %eax) |
| 50 | 55 | ||
| 51 | /*G:033 But using those wrappers is inefficient (we'll see why that doesn't | 56 | /*G:033 |
| 52 | * matter for save_fl and irq_disable later). If we write our routines | 57 | * But using those wrappers is inefficient (we'll see why that doesn't matter |
| 53 | * carefully in assembler, we can avoid clobbering any registers and avoid | 58 | * for save_fl and irq_disable later). If we write our routines carefully in |
| 54 | * jumping through the wrapper functions. | 59 | * assembler, we can avoid clobbering any registers and avoid jumping through |
| 60 | * the wrapper functions. | ||
| 55 | * | 61 | * |
| 56 | * I skipped over our first piece of assembler, but this one is worth studying | 62 | * I skipped over our first piece of assembler, but this one is worth studying |
| 57 | * in a bit more detail so I'll describe in easy stages. First, the routine | 63 | * in a bit more detail so I'll describe in easy stages. First, the routine to |
| 58 | * to enable interrupts: */ | 64 | * enable interrupts: |
| 65 | */ | ||
| 59 | ENTRY(lg_irq_enable) | 66 | ENTRY(lg_irq_enable) |
| 60 | /* The reverse of irq_disable, this sets lguest_data.irq_enabled to | 67 | /* |
| 61 | * X86_EFLAGS_IF (ie. "Interrupts enabled"). */ | 68 | * The reverse of irq_disable, this sets lguest_data.irq_enabled to |
| 69 | * X86_EFLAGS_IF (ie. "Interrupts enabled"). | ||
| 70 | */ | ||
| 62 | movl $X86_EFLAGS_IF, lguest_data+LGUEST_DATA_irq_enabled | 71 | movl $X86_EFLAGS_IF, lguest_data+LGUEST_DATA_irq_enabled |
| 63 | /* But now we need to check if the Host wants to know: there might have | 72 | /* |
| 73 | * But now we need to check if the Host wants to know: there might have | ||
| 64 | * been interrupts waiting to be delivered, in which case it will have | 74 | * been interrupts waiting to be delivered, in which case it will have |
| 65 | * set lguest_data.irq_pending to X86_EFLAGS_IF. If it's not zero, we | 75 | * set lguest_data.irq_pending to X86_EFLAGS_IF. If it's not zero, we |
| 66 | * jump to send_interrupts, otherwise we're done. */ | 76 | * jump to send_interrupts, otherwise we're done. |
| 77 | */ | ||
| 67 | testl $0, lguest_data+LGUEST_DATA_irq_pending | 78 | testl $0, lguest_data+LGUEST_DATA_irq_pending |
| 68 | jnz send_interrupts | 79 | jnz send_interrupts |
| 69 | /* One cool thing about x86 is that you can do many things without using | 80 | /* |
| 81 | * One cool thing about x86 is that you can do many things without using | ||
| 70 | * a register. In this case, the normal path hasn't needed to save or | 82 | * a register. In this case, the normal path hasn't needed to save or |
| 71 | * restore any registers at all! */ | 83 | * restore any registers at all! |
| 84 | */ | ||
| 72 | ret | 85 | ret |
| 73 | send_interrupts: | 86 | send_interrupts: |
| 74 | /* OK, now we need a register: eax is used for the hypercall number, | 87 | /* |
| 88 | * OK, now we need a register: eax is used for the hypercall number, | ||
| 75 | * which is LHCALL_SEND_INTERRUPTS. | 89 | * which is LHCALL_SEND_INTERRUPTS. |
| 76 | * | 90 | * |
| 77 | * We used not to bother with this pending detection at all, which was | 91 | * We used not to bother with this pending detection at all, which was |
| 78 | * much simpler. Sooner or later the Host would realize it had to | 92 | * much simpler. Sooner or later the Host would realize it had to |
| 79 | * send us an interrupt. But that turns out to make performance 7 | 93 | * send us an interrupt. But that turns out to make performance 7 |
| 80 | * times worse on a simple tcp benchmark. So now we do this the hard | 94 | * times worse on a simple tcp benchmark. So now we do this the hard |
| 81 | * way. */ | 95 | * way. |
| 96 | */ | ||
| 82 | pushl %eax | 97 | pushl %eax |
| 83 | movl $LHCALL_SEND_INTERRUPTS, %eax | 98 | movl $LHCALL_SEND_INTERRUPTS, %eax |
| 84 | /* This is a vmcall instruction (same thing that KVM uses). Older | 99 | /* |
| 100 | * This is a vmcall instruction (same thing that KVM uses). Older | ||
| 85 | * assembler versions might not know the "vmcall" instruction, so we | 101 | * assembler versions might not know the "vmcall" instruction, so we |
| 86 | * create one manually here. */ | 102 | * create one manually here. |
| 103 | */ | ||
| 87 | .byte 0x0f,0x01,0xc1 /* KVM_HYPERCALL */ | 104 | .byte 0x0f,0x01,0xc1 /* KVM_HYPERCALL */ |
| 105 | /* Put eax back the way we found it. */ | ||
| 88 | popl %eax | 106 | popl %eax |
| 89 | ret | 107 | ret |
| 90 | 108 | ||
| 91 | /* Finally, the "popf" or "restore flags" routine. The %eax register holds the | 109 | /* |
| 110 | * Finally, the "popf" or "restore flags" routine. The %eax register holds the | ||
| 92 | * flags (in practice, either X86_EFLAGS_IF or 0): if it's X86_EFLAGS_IF we're | 111 | * flags (in practice, either X86_EFLAGS_IF or 0): if it's X86_EFLAGS_IF we're |
| 93 | * enabling interrupts again, if it's 0 we're leaving them off. */ | 112 | * enabling interrupts again, if it's 0 we're leaving them off. |
| 113 | */ | ||
| 94 | ENTRY(lg_restore_fl) | 114 | ENTRY(lg_restore_fl) |
| 95 | /* This is just "lguest_data.irq_enabled = flags;" */ | 115 | /* This is just "lguest_data.irq_enabled = flags;" */ |
| 96 | movl %eax, lguest_data+LGUEST_DATA_irq_enabled | 116 | movl %eax, lguest_data+LGUEST_DATA_irq_enabled |
| 97 | /* Now, if the %eax value has enabled interrupts and | 117 | /* |
| 118 | * Now, if the %eax value has enabled interrupts and | ||
| 98 | * lguest_data.irq_pending is set, we want to tell the Host so it can | 119 | * lguest_data.irq_pending is set, we want to tell the Host so it can |
| 99 | * deliver any outstanding interrupts. Fortunately, both values will | 120 | * deliver any outstanding interrupts. Fortunately, both values will |
| 100 | * be X86_EFLAGS_IF (ie. 512) in that case, and the "testl" | 121 | * be X86_EFLAGS_IF (ie. 512) in that case, and the "testl" |
| 101 | * instruction will AND them together for us. If both are set, we | 122 | * instruction will AND them together for us. If both are set, we |
| 102 | * jump to send_interrupts. */ | 123 | * jump to send_interrupts. |
| 124 | */ | ||
| 103 | testl lguest_data+LGUEST_DATA_irq_pending, %eax | 125 | testl lguest_data+LGUEST_DATA_irq_pending, %eax |
| 104 | jnz send_interrupts | 126 | jnz send_interrupts |
| 105 | /* Again, the normal path has used no extra registers. Clever, huh? */ | 127 | /* Again, the normal path has used no extra registers. Clever, huh? */ |
| 106 | ret | 128 | ret |
| 129 | /*:*/ | ||
| 107 | 130 | ||
| 108 | /* These demark the EIP range where host should never deliver interrupts. */ | 131 | /* These demark the EIP range where host should never deliver interrupts. */ |
| 109 | .global lguest_noirq_start | 132 | .global lguest_noirq_start |
| 110 | .global lguest_noirq_end | 133 | .global lguest_noirq_end |
| 111 | 134 | ||
| 112 | /*M:004 When the Host reflects a trap or injects an interrupt into the Guest, | 135 | /*M:004 |
| 113 | * it sets the eflags interrupt bit on the stack based on | 136 | * When the Host reflects a trap or injects an interrupt into the Guest, it |
| 114 | * lguest_data.irq_enabled, so the Guest iret logic does the right thing when | 137 | * sets the eflags interrupt bit on the stack based on lguest_data.irq_enabled, |
| 115 | * restoring it. However, when the Host sets the Guest up for direct traps, | 138 | * so the Guest iret logic does the right thing when restoring it. However, |
| 116 | * such as system calls, the processor is the one to push eflags onto the | 139 | * when the Host sets the Guest up for direct traps, such as system calls, the |
| 117 | * stack, and the interrupt bit will be 1 (in reality, interrupts are always | 140 | * processor is the one to push eflags onto the stack, and the interrupt bit |
| 118 | * enabled in the Guest). | 141 | * will be 1 (in reality, interrupts are always enabled in the Guest). |
| 119 | * | 142 | * |
| 120 | * This turns out to be harmless: the only trap which should happen under Linux | 143 | * This turns out to be harmless: the only trap which should happen under Linux |
| 121 | * with interrupts disabled is Page Fault (due to our lazy mapping of vmalloc | 144 | * with interrupts disabled is Page Fault (due to our lazy mapping of vmalloc |
| 122 | * regions), which has to be reflected through the Host anyway. If another | 145 | * regions), which has to be reflected through the Host anyway. If another |
| 123 | * trap *does* go off when interrupts are disabled, the Guest will panic, and | 146 | * trap *does* go off when interrupts are disabled, the Guest will panic, and |
| 124 | * we'll never get to this iret! :*/ | 147 | * we'll never get to this iret! |
| 148 | :*/ | ||
| 125 | 149 | ||
| 126 | /*G:045 There is one final paravirt_op that the Guest implements, and glancing | 150 | /*G:045 |
| 127 | * at it you can see why I left it to last. It's *cool*! It's in *assembler*! | 151 | * There is one final paravirt_op that the Guest implements, and glancing at it |
| 152 | * you can see why I left it to last. It's *cool*! It's in *assembler*! | ||
| 128 | * | 153 | * |
| 129 | * The "iret" instruction is used to return from an interrupt or trap. The | 154 | * The "iret" instruction is used to return from an interrupt or trap. The |
| 130 | * stack looks like this: | 155 | * stack looks like this: |
| @@ -148,15 +173,18 @@ ENTRY(lg_restore_fl) | |||
| 148 | * return to userspace or wherever. Our solution to this is to surround the | 173 | * return to userspace or wherever. Our solution to this is to surround the |
| 149 | * code with lguest_noirq_start: and lguest_noirq_end: labels. We tell the | 174 | * code with lguest_noirq_start: and lguest_noirq_end: labels. We tell the |
| 150 | * Host that it is *never* to interrupt us there, even if interrupts seem to be | 175 | * Host that it is *never* to interrupt us there, even if interrupts seem to be |
| 151 | * enabled. */ | 176 | * enabled. |
| 177 | */ | ||
| 152 | ENTRY(lguest_iret) | 178 | ENTRY(lguest_iret) |
| 153 | pushl %eax | 179 | pushl %eax |
| 154 | movl 12(%esp), %eax | 180 | movl 12(%esp), %eax |
| 155 | lguest_noirq_start: | 181 | lguest_noirq_start: |
| 156 | /* Note the %ss: segment prefix here. Normal data accesses use the | 182 | /* |
| 183 | * Note the %ss: segment prefix here. Normal data accesses use the | ||
| 157 | * "ds" segment, but that will have already been restored for whatever | 184 | * "ds" segment, but that will have already been restored for whatever |
| 158 | * we're returning to (such as userspace): we can't trust it. The %ss: | 185 | * we're returning to (such as userspace): we can't trust it. The %ss: |
| 159 | * prefix makes sure we use the stack segment, which is still valid. */ | 186 | * prefix makes sure we use the stack segment, which is still valid. |
| 187 | */ | ||
| 160 | movl %eax,%ss:lguest_data+LGUEST_DATA_irq_enabled | 188 | movl %eax,%ss:lguest_data+LGUEST_DATA_irq_enabled |
| 161 | popl %eax | 189 | popl %eax |
| 162 | iret | 190 | iret |
diff --git a/arch/x86/lib/msr.c b/arch/x86/lib/msr.c index 1440b9c0547e..caa24aca8115 100644 --- a/arch/x86/lib/msr.c +++ b/arch/x86/lib/msr.c | |||
| @@ -89,16 +89,13 @@ void rdmsr_on_cpus(const cpumask_t *mask, u32 msr_no, struct msr *msrs) | |||
| 89 | rv.msrs = msrs; | 89 | rv.msrs = msrs; |
| 90 | rv.msr_no = msr_no; | 90 | rv.msr_no = msr_no; |
| 91 | 91 | ||
| 92 | preempt_disable(); | 92 | this_cpu = get_cpu(); |
| 93 | /* | 93 | |
| 94 | * FIXME: handle the CPU we're executing on separately for now until | 94 | if (cpumask_test_cpu(this_cpu, mask)) |
| 95 | * smp_call_function_many has been fixed to not skip it. | 95 | __rdmsr_on_cpu(&rv); |
| 96 | */ | ||
| 97 | this_cpu = raw_smp_processor_id(); | ||
| 98 | smp_call_function_single(this_cpu, __rdmsr_on_cpu, &rv, 1); | ||
| 99 | 96 | ||
| 100 | smp_call_function_many(mask, __rdmsr_on_cpu, &rv, 1); | 97 | smp_call_function_many(mask, __rdmsr_on_cpu, &rv, 1); |
| 101 | preempt_enable(); | 98 | put_cpu(); |
| 102 | } | 99 | } |
| 103 | EXPORT_SYMBOL(rdmsr_on_cpus); | 100 | EXPORT_SYMBOL(rdmsr_on_cpus); |
| 104 | 101 | ||
| @@ -121,16 +118,13 @@ void wrmsr_on_cpus(const cpumask_t *mask, u32 msr_no, struct msr *msrs) | |||
| 121 | rv.msrs = msrs; | 118 | rv.msrs = msrs; |
| 122 | rv.msr_no = msr_no; | 119 | rv.msr_no = msr_no; |
| 123 | 120 | ||
| 124 | preempt_disable(); | 121 | this_cpu = get_cpu(); |
| 125 | /* | 122 | |
| 126 | * FIXME: handle the CPU we're executing on separately for now until | 123 | if (cpumask_test_cpu(this_cpu, mask)) |
| 127 | * smp_call_function_many has been fixed to not skip it. | 124 | __wrmsr_on_cpu(&rv); |
| 128 | */ | ||
| 129 | this_cpu = raw_smp_processor_id(); | ||
| 130 | smp_call_function_single(this_cpu, __wrmsr_on_cpu, &rv, 1); | ||
| 131 | 125 | ||
| 132 | smp_call_function_many(mask, __wrmsr_on_cpu, &rv, 1); | 126 | smp_call_function_many(mask, __wrmsr_on_cpu, &rv, 1); |
| 133 | preempt_enable(); | 127 | put_cpu(); |
| 134 | } | 128 | } |
| 135 | EXPORT_SYMBOL(wrmsr_on_cpus); | 129 | EXPORT_SYMBOL(wrmsr_on_cpus); |
| 136 | 130 | ||
diff --git a/arch/x86/mm/highmem_32.c b/arch/x86/mm/highmem_32.c index 58f621e81919..2112ed55e7ea 100644 --- a/arch/x86/mm/highmem_32.c +++ b/arch/x86/mm/highmem_32.c | |||
| @@ -103,6 +103,7 @@ EXPORT_SYMBOL(kmap); | |||
| 103 | EXPORT_SYMBOL(kunmap); | 103 | EXPORT_SYMBOL(kunmap); |
| 104 | EXPORT_SYMBOL(kmap_atomic); | 104 | EXPORT_SYMBOL(kmap_atomic); |
| 105 | EXPORT_SYMBOL(kunmap_atomic); | 105 | EXPORT_SYMBOL(kunmap_atomic); |
| 106 | EXPORT_SYMBOL(kmap_atomic_prot); | ||
| 106 | 107 | ||
| 107 | void __init set_highmem_pages_init(void) | 108 | void __init set_highmem_pages_init(void) |
| 108 | { | 109 | { |
diff --git a/arch/x86/mm/init_64.c b/arch/x86/mm/init_64.c index 6176fe8f29e0..ea56b8cbb6a6 100644 --- a/arch/x86/mm/init_64.c +++ b/arch/x86/mm/init_64.c | |||
| @@ -796,7 +796,7 @@ int __init reserve_bootmem_generic(unsigned long phys, unsigned long len, | |||
| 796 | return ret; | 796 | return ret; |
| 797 | 797 | ||
| 798 | #else | 798 | #else |
| 799 | reserve_bootmem(phys, len, BOOTMEM_DEFAULT); | 799 | reserve_bootmem(phys, len, flags); |
| 800 | #endif | 800 | #endif |
| 801 | 801 | ||
| 802 | if (phys+len <= MAX_DMA_PFN*PAGE_SIZE) { | 802 | if (phys+len <= MAX_DMA_PFN*PAGE_SIZE) { |
diff --git a/arch/x86/mm/pageattr.c b/arch/x86/mm/pageattr.c index 1b734d7a8966..7e600c1962db 100644 --- a/arch/x86/mm/pageattr.c +++ b/arch/x86/mm/pageattr.c | |||
| @@ -591,9 +591,12 @@ static int __change_page_attr(struct cpa_data *cpa, int primary) | |||
| 591 | unsigned int level; | 591 | unsigned int level; |
| 592 | pte_t *kpte, old_pte; | 592 | pte_t *kpte, old_pte; |
| 593 | 593 | ||
| 594 | if (cpa->flags & CPA_PAGES_ARRAY) | 594 | if (cpa->flags & CPA_PAGES_ARRAY) { |
| 595 | address = (unsigned long)page_address(cpa->pages[cpa->curpage]); | 595 | struct page *page = cpa->pages[cpa->curpage]; |
| 596 | else if (cpa->flags & CPA_ARRAY) | 596 | if (unlikely(PageHighMem(page))) |
| 597 | return 0; | ||
| 598 | address = (unsigned long)page_address(page); | ||
| 599 | } else if (cpa->flags & CPA_ARRAY) | ||
| 597 | address = cpa->vaddr[cpa->curpage]; | 600 | address = cpa->vaddr[cpa->curpage]; |
| 598 | else | 601 | else |
| 599 | address = *cpa->vaddr; | 602 | address = *cpa->vaddr; |
| @@ -697,9 +700,12 @@ static int cpa_process_alias(struct cpa_data *cpa) | |||
| 697 | * No need to redo, when the primary call touched the direct | 700 | * No need to redo, when the primary call touched the direct |
| 698 | * mapping already: | 701 | * mapping already: |
| 699 | */ | 702 | */ |
| 700 | if (cpa->flags & CPA_PAGES_ARRAY) | 703 | if (cpa->flags & CPA_PAGES_ARRAY) { |
| 701 | vaddr = (unsigned long)page_address(cpa->pages[cpa->curpage]); | 704 | struct page *page = cpa->pages[cpa->curpage]; |
| 702 | else if (cpa->flags & CPA_ARRAY) | 705 | if (unlikely(PageHighMem(page))) |
| 706 | return 0; | ||
| 707 | vaddr = (unsigned long)page_address(page); | ||
| 708 | } else if (cpa->flags & CPA_ARRAY) | ||
| 703 | vaddr = cpa->vaddr[cpa->curpage]; | 709 | vaddr = cpa->vaddr[cpa->curpage]; |
| 704 | else | 710 | else |
| 705 | vaddr = *cpa->vaddr; | 711 | vaddr = *cpa->vaddr; |
| @@ -997,12 +1003,15 @@ EXPORT_SYMBOL(set_memory_array_uc); | |||
| 997 | int _set_memory_wc(unsigned long addr, int numpages) | 1003 | int _set_memory_wc(unsigned long addr, int numpages) |
| 998 | { | 1004 | { |
| 999 | int ret; | 1005 | int ret; |
| 1006 | unsigned long addr_copy = addr; | ||
| 1007 | |||
| 1000 | ret = change_page_attr_set(&addr, numpages, | 1008 | ret = change_page_attr_set(&addr, numpages, |
| 1001 | __pgprot(_PAGE_CACHE_UC_MINUS), 0); | 1009 | __pgprot(_PAGE_CACHE_UC_MINUS), 0); |
| 1002 | |||
| 1003 | if (!ret) { | 1010 | if (!ret) { |
| 1004 | ret = change_page_attr_set(&addr, numpages, | 1011 | ret = change_page_attr_set_clr(&addr_copy, numpages, |
| 1005 | __pgprot(_PAGE_CACHE_WC), 0); | 1012 | __pgprot(_PAGE_CACHE_WC), |
| 1013 | __pgprot(_PAGE_CACHE_MASK), | ||
| 1014 | 0, 0, NULL); | ||
| 1006 | } | 1015 | } |
| 1007 | return ret; | 1016 | return ret; |
| 1008 | } | 1017 | } |
| @@ -1119,7 +1128,9 @@ int set_pages_array_uc(struct page **pages, int addrinarray) | |||
| 1119 | int free_idx; | 1128 | int free_idx; |
| 1120 | 1129 | ||
| 1121 | for (i = 0; i < addrinarray; i++) { | 1130 | for (i = 0; i < addrinarray; i++) { |
| 1122 | start = (unsigned long)page_address(pages[i]); | 1131 | if (PageHighMem(pages[i])) |
| 1132 | continue; | ||
| 1133 | start = page_to_pfn(pages[i]) << PAGE_SHIFT; | ||
| 1123 | end = start + PAGE_SIZE; | 1134 | end = start + PAGE_SIZE; |
| 1124 | if (reserve_memtype(start, end, _PAGE_CACHE_UC_MINUS, NULL)) | 1135 | if (reserve_memtype(start, end, _PAGE_CACHE_UC_MINUS, NULL)) |
| 1125 | goto err_out; | 1136 | goto err_out; |
| @@ -1132,7 +1143,9 @@ int set_pages_array_uc(struct page **pages, int addrinarray) | |||
| 1132 | err_out: | 1143 | err_out: |
| 1133 | free_idx = i; | 1144 | free_idx = i; |
| 1134 | for (i = 0; i < free_idx; i++) { | 1145 | for (i = 0; i < free_idx; i++) { |
| 1135 | start = (unsigned long)page_address(pages[i]); | 1146 | if (PageHighMem(pages[i])) |
| 1147 | continue; | ||
| 1148 | start = page_to_pfn(pages[i]) << PAGE_SHIFT; | ||
| 1136 | end = start + PAGE_SIZE; | 1149 | end = start + PAGE_SIZE; |
| 1137 | free_memtype(start, end); | 1150 | free_memtype(start, end); |
| 1138 | } | 1151 | } |
| @@ -1161,7 +1174,9 @@ int set_pages_array_wb(struct page **pages, int addrinarray) | |||
| 1161 | return retval; | 1174 | return retval; |
| 1162 | 1175 | ||
| 1163 | for (i = 0; i < addrinarray; i++) { | 1176 | for (i = 0; i < addrinarray; i++) { |
| 1164 | start = (unsigned long)page_address(pages[i]); | 1177 | if (PageHighMem(pages[i])) |
| 1178 | continue; | ||
| 1179 | start = page_to_pfn(pages[i]) << PAGE_SHIFT; | ||
| 1165 | end = start + PAGE_SIZE; | 1180 | end = start + PAGE_SIZE; |
| 1166 | free_memtype(start, end); | 1181 | free_memtype(start, end); |
| 1167 | } | 1182 | } |
diff --git a/arch/x86/mm/pat.c b/arch/x86/mm/pat.c index e6718bb28065..352aa9e927e2 100644 --- a/arch/x86/mm/pat.c +++ b/arch/x86/mm/pat.c | |||
| @@ -623,7 +623,8 @@ static int reserve_pfn_range(u64 paddr, unsigned long size, pgprot_t *vma_prot, | |||
| 623 | return ret; | 623 | return ret; |
| 624 | 624 | ||
| 625 | if (flags != want_flags) { | 625 | if (flags != want_flags) { |
| 626 | if (strict_prot || !is_new_memtype_allowed(want_flags, flags)) { | 626 | if (strict_prot || |
| 627 | !is_new_memtype_allowed(paddr, size, want_flags, flags)) { | ||
| 627 | free_memtype(paddr, paddr + size); | 628 | free_memtype(paddr, paddr + size); |
| 628 | printk(KERN_ERR "%s:%d map pfn expected mapping type %s" | 629 | printk(KERN_ERR "%s:%d map pfn expected mapping type %s" |
| 629 | " for %Lx-%Lx, got %s\n", | 630 | " for %Lx-%Lx, got %s\n", |
diff --git a/arch/x86/mm/pgtable.c b/arch/x86/mm/pgtable.c index 8e43bdd45456..ed34f5e35999 100644 --- a/arch/x86/mm/pgtable.c +++ b/arch/x86/mm/pgtable.c | |||
| @@ -25,7 +25,7 @@ pgtable_t pte_alloc_one(struct mm_struct *mm, unsigned long address) | |||
| 25 | return pte; | 25 | return pte; |
| 26 | } | 26 | } |
| 27 | 27 | ||
| 28 | void __pte_free_tlb(struct mmu_gather *tlb, struct page *pte) | 28 | void ___pte_free_tlb(struct mmu_gather *tlb, struct page *pte) |
| 29 | { | 29 | { |
| 30 | pgtable_page_dtor(pte); | 30 | pgtable_page_dtor(pte); |
| 31 | paravirt_release_pte(page_to_pfn(pte)); | 31 | paravirt_release_pte(page_to_pfn(pte)); |
| @@ -33,14 +33,14 @@ void __pte_free_tlb(struct mmu_gather *tlb, struct page *pte) | |||
| 33 | } | 33 | } |
| 34 | 34 | ||
| 35 | #if PAGETABLE_LEVELS > 2 | 35 | #if PAGETABLE_LEVELS > 2 |
| 36 | void __pmd_free_tlb(struct mmu_gather *tlb, pmd_t *pmd) | 36 | void ___pmd_free_tlb(struct mmu_gather *tlb, pmd_t *pmd) |
| 37 | { | 37 | { |
| 38 | paravirt_release_pmd(__pa(pmd) >> PAGE_SHIFT); | 38 | paravirt_release_pmd(__pa(pmd) >> PAGE_SHIFT); |
| 39 | tlb_remove_page(tlb, virt_to_page(pmd)); | 39 | tlb_remove_page(tlb, virt_to_page(pmd)); |
| 40 | } | 40 | } |
| 41 | 41 | ||
| 42 | #if PAGETABLE_LEVELS > 3 | 42 | #if PAGETABLE_LEVELS > 3 |
| 43 | void __pud_free_tlb(struct mmu_gather *tlb, pud_t *pud) | 43 | void ___pud_free_tlb(struct mmu_gather *tlb, pud_t *pud) |
| 44 | { | 44 | { |
| 45 | paravirt_release_pud(__pa(pud) >> PAGE_SHIFT); | 45 | paravirt_release_pud(__pa(pud) >> PAGE_SHIFT); |
| 46 | tlb_remove_page(tlb, virt_to_page(pud)); | 46 | tlb_remove_page(tlb, virt_to_page(pud)); |
| @@ -329,7 +329,6 @@ void __init reserve_top_address(unsigned long reserve) | |||
| 329 | printk(KERN_INFO "Reserving virtual address space above 0x%08x\n", | 329 | printk(KERN_INFO "Reserving virtual address space above 0x%08x\n", |
| 330 | (int)-reserve); | 330 | (int)-reserve); |
| 331 | __FIXADDR_TOP = -reserve - PAGE_SIZE; | 331 | __FIXADDR_TOP = -reserve - PAGE_SIZE; |
| 332 | __VMALLOC_RESERVE += reserve; | ||
| 333 | #endif | 332 | #endif |
| 334 | } | 333 | } |
| 335 | 334 | ||
diff --git a/arch/x86/mm/srat_64.c b/arch/x86/mm/srat_64.c index 2dfcbf9df2ae..dbb5381f7b3b 100644 --- a/arch/x86/mm/srat_64.c +++ b/arch/x86/mm/srat_64.c | |||
| @@ -79,8 +79,10 @@ static __init void bad_srat(void) | |||
| 79 | acpi_numa = -1; | 79 | acpi_numa = -1; |
| 80 | for (i = 0; i < MAX_LOCAL_APIC; i++) | 80 | for (i = 0; i < MAX_LOCAL_APIC; i++) |
| 81 | apicid_to_node[i] = NUMA_NO_NODE; | 81 | apicid_to_node[i] = NUMA_NO_NODE; |
| 82 | for (i = 0; i < MAX_NUMNODES; i++) | 82 | for (i = 0; i < MAX_NUMNODES; i++) { |
| 83 | nodes_add[i].start = nodes[i].end = 0; | 83 | nodes[i].start = nodes[i].end = 0; |
| 84 | nodes_add[i].start = nodes_add[i].end = 0; | ||
| 85 | } | ||
| 84 | remove_all_active_ranges(); | 86 | remove_all_active_ranges(); |
| 85 | } | 87 | } |
| 86 | 88 | ||
diff --git a/arch/x86/mm/tlb.c b/arch/x86/mm/tlb.c index 821e97017e95..c814e144a3f0 100644 --- a/arch/x86/mm/tlb.c +++ b/arch/x86/mm/tlb.c | |||
| @@ -183,18 +183,17 @@ static void flush_tlb_others_ipi(const struct cpumask *cpumask, | |||
| 183 | 183 | ||
| 184 | f->flush_mm = mm; | 184 | f->flush_mm = mm; |
| 185 | f->flush_va = va; | 185 | f->flush_va = va; |
| 186 | cpumask_andnot(to_cpumask(f->flush_cpumask), | 186 | if (cpumask_andnot(to_cpumask(f->flush_cpumask), cpumask, cpumask_of(smp_processor_id()))) { |
| 187 | cpumask, cpumask_of(smp_processor_id())); | 187 | /* |
| 188 | 188 | * We have to send the IPI only to | |
| 189 | /* | 189 | * CPUs affected. |
| 190 | * We have to send the IPI only to | 190 | */ |
| 191 | * CPUs affected. | 191 | apic->send_IPI_mask(to_cpumask(f->flush_cpumask), |
| 192 | */ | 192 | INVALIDATE_TLB_VECTOR_START + sender); |
| 193 | apic->send_IPI_mask(to_cpumask(f->flush_cpumask), | ||
| 194 | INVALIDATE_TLB_VECTOR_START + sender); | ||
| 195 | 193 | ||
| 196 | while (!cpumask_empty(to_cpumask(f->flush_cpumask))) | 194 | while (!cpumask_empty(to_cpumask(f->flush_cpumask))) |
| 197 | cpu_relax(); | 195 | cpu_relax(); |
| 196 | } | ||
| 198 | 197 | ||
| 199 | f->flush_mm = NULL; | 198 | f->flush_mm = NULL; |
| 200 | f->flush_va = 0; | 199 | f->flush_va = 0; |
diff --git a/arch/x86/xen/Makefile b/arch/x86/xen/Makefile index 172438f86a02..7410640db173 100644 --- a/arch/x86/xen/Makefile +++ b/arch/x86/xen/Makefile | |||
| @@ -5,6 +5,10 @@ CFLAGS_REMOVE_time.o = -pg | |||
| 5 | CFLAGS_REMOVE_irq.o = -pg | 5 | CFLAGS_REMOVE_irq.o = -pg |
| 6 | endif | 6 | endif |
| 7 | 7 | ||
| 8 | # Make sure early boot has no stackprotector | ||
| 9 | nostackp := $(call cc-option, -fno-stack-protector) | ||
| 10 | CFLAGS_enlighten.o := $(nostackp) | ||
| 11 | |||
| 8 | obj-y := enlighten.o setup.o multicalls.o mmu.o irq.o \ | 12 | obj-y := enlighten.o setup.o multicalls.o mmu.o irq.o \ |
| 9 | time.o xen-asm.o xen-asm_$(BITS).o \ | 13 | time.o xen-asm.o xen-asm_$(BITS).o \ |
| 10 | grant-table.o suspend.o | 14 | grant-table.o suspend.o |
diff --git a/arch/x86/xen/enlighten.c b/arch/x86/xen/enlighten.c index 0a1700a2be9c..e90540a46a0b 100644 --- a/arch/x86/xen/enlighten.c +++ b/arch/x86/xen/enlighten.c | |||
| @@ -974,10 +974,6 @@ asmlinkage void __init xen_start_kernel(void) | |||
| 974 | 974 | ||
| 975 | xen_domain_type = XEN_PV_DOMAIN; | 975 | xen_domain_type = XEN_PV_DOMAIN; |
| 976 | 976 | ||
| 977 | BUG_ON(memcmp(xen_start_info->magic, "xen-3", 5) != 0); | ||
| 978 | |||
| 979 | xen_setup_features(); | ||
| 980 | |||
| 981 | /* Install Xen paravirt ops */ | 977 | /* Install Xen paravirt ops */ |
| 982 | pv_info = xen_info; | 978 | pv_info = xen_info; |
| 983 | pv_init_ops = xen_init_ops; | 979 | pv_init_ops = xen_init_ops; |
| @@ -986,8 +982,15 @@ asmlinkage void __init xen_start_kernel(void) | |||
| 986 | pv_apic_ops = xen_apic_ops; | 982 | pv_apic_ops = xen_apic_ops; |
| 987 | pv_mmu_ops = xen_mmu_ops; | 983 | pv_mmu_ops = xen_mmu_ops; |
| 988 | 984 | ||
| 989 | xen_init_irq_ops(); | 985 | #ifdef CONFIG_X86_64 |
| 986 | /* | ||
| 987 | * Setup percpu state. We only need to do this for 64-bit | ||
| 988 | * because 32-bit already has %fs set properly. | ||
| 989 | */ | ||
| 990 | load_percpu_segment(0); | ||
| 991 | #endif | ||
| 990 | 992 | ||
| 993 | xen_init_irq_ops(); | ||
| 991 | xen_init_cpuid_mask(); | 994 | xen_init_cpuid_mask(); |
| 992 | 995 | ||
| 993 | #ifdef CONFIG_X86_LOCAL_APIC | 996 | #ifdef CONFIG_X86_LOCAL_APIC |
| @@ -997,6 +1000,8 @@ asmlinkage void __init xen_start_kernel(void) | |||
| 997 | set_xen_basic_apic_ops(); | 1000 | set_xen_basic_apic_ops(); |
| 998 | #endif | 1001 | #endif |
| 999 | 1002 | ||
| 1003 | xen_setup_features(); | ||
| 1004 | |||
| 1000 | if (xen_feature(XENFEAT_mmu_pt_update_preserve_ad)) { | 1005 | if (xen_feature(XENFEAT_mmu_pt_update_preserve_ad)) { |
| 1001 | pv_mmu_ops.ptep_modify_prot_start = xen_ptep_modify_prot_start; | 1006 | pv_mmu_ops.ptep_modify_prot_start = xen_ptep_modify_prot_start; |
| 1002 | pv_mmu_ops.ptep_modify_prot_commit = xen_ptep_modify_prot_commit; | 1007 | pv_mmu_ops.ptep_modify_prot_commit = xen_ptep_modify_prot_commit; |
| @@ -1004,13 +1009,6 @@ asmlinkage void __init xen_start_kernel(void) | |||
| 1004 | 1009 | ||
| 1005 | machine_ops = xen_machine_ops; | 1010 | machine_ops = xen_machine_ops; |
| 1006 | 1011 | ||
| 1007 | #ifdef CONFIG_X86_64 | ||
| 1008 | /* | ||
| 1009 | * Setup percpu state. We only need to do this for 64-bit | ||
| 1010 | * because 32-bit already has %fs set properly. | ||
| 1011 | */ | ||
| 1012 | load_percpu_segment(0); | ||
| 1013 | #endif | ||
| 1014 | /* | 1012 | /* |
| 1015 | * The only reliable way to retain the initial address of the | 1013 | * The only reliable way to retain the initial address of the |
| 1016 | * percpu gdt_page is to remember it here, so we can go and | 1014 | * percpu gdt_page is to remember it here, so we can go and |
diff --git a/arch/xtensa/include/asm/tlb.h b/arch/xtensa/include/asm/tlb.h index 31c220faca02..0d766f9c1083 100644 --- a/arch/xtensa/include/asm/tlb.h +++ b/arch/xtensa/include/asm/tlb.h | |||
| @@ -42,6 +42,6 @@ | |||
| 42 | 42 | ||
| 43 | #include <asm-generic/tlb.h> | 43 | #include <asm-generic/tlb.h> |
| 44 | 44 | ||
| 45 | #define __pte_free_tlb(tlb, pte) pte_free((tlb)->mm, pte) | 45 | #define __pte_free_tlb(tlb, pte, address) pte_free((tlb)->mm, pte) |
| 46 | 46 | ||
| 47 | #endif /* _XTENSA_TLB_H */ | 47 | #endif /* _XTENSA_TLB_H */ |
diff --git a/block/Kconfig b/block/Kconfig index 95a86adc33a1..9be0b56eaee1 100644 --- a/block/Kconfig +++ b/block/Kconfig | |||
| @@ -48,9 +48,9 @@ config LBDAF | |||
| 48 | If unsure, say Y. | 48 | If unsure, say Y. |
| 49 | 49 | ||
| 50 | config BLK_DEV_BSG | 50 | config BLK_DEV_BSG |
| 51 | bool "Block layer SG support v4 (EXPERIMENTAL)" | 51 | bool "Block layer SG support v4" |
| 52 | depends on EXPERIMENTAL | 52 | default y |
| 53 | ---help--- | 53 | help |
| 54 | Saying Y here will enable generic SG (SCSI generic) v4 support | 54 | Saying Y here will enable generic SG (SCSI generic) v4 support |
| 55 | for any block device. | 55 | for any block device. |
| 56 | 56 | ||
| @@ -60,7 +60,10 @@ config BLK_DEV_BSG | |||
| 60 | protocols (e.g. Task Management Functions and SMP in Serial | 60 | protocols (e.g. Task Management Functions and SMP in Serial |
| 61 | Attached SCSI). | 61 | Attached SCSI). |
| 62 | 62 | ||
| 63 | If unsure, say N. | 63 | This option is required by recent UDEV versions to properly |
| 64 | access device serial numbers, etc. | ||
| 65 | |||
| 66 | If unsure, say Y. | ||
| 64 | 67 | ||
| 65 | config BLK_DEV_INTEGRITY | 68 | config BLK_DEV_INTEGRITY |
| 66 | bool "Block layer data integrity support" | 69 | bool "Block layer data integrity support" |
diff --git a/block/blk-core.c b/block/blk-core.c index 4b45435c6eaf..e3299a77a0d8 100644 --- a/block/blk-core.c +++ b/block/blk-core.c | |||
| @@ -575,13 +575,6 @@ blk_init_queue_node(request_fn_proc *rfn, spinlock_t *lock, int node_id) | |||
| 575 | return NULL; | 575 | return NULL; |
| 576 | } | 576 | } |
| 577 | 577 | ||
| 578 | /* | ||
| 579 | * if caller didn't supply a lock, they get per-queue locking with | ||
| 580 | * our embedded lock | ||
| 581 | */ | ||
| 582 | if (!lock) | ||
| 583 | lock = &q->__queue_lock; | ||
| 584 | |||
| 585 | q->request_fn = rfn; | 578 | q->request_fn = rfn; |
| 586 | q->prep_rq_fn = NULL; | 579 | q->prep_rq_fn = NULL; |
| 587 | q->unplug_fn = generic_unplug_device; | 580 | q->unplug_fn = generic_unplug_device; |
| @@ -2143,7 +2136,7 @@ bool blk_end_request(struct request *rq, int error, unsigned int nr_bytes) | |||
| 2143 | { | 2136 | { |
| 2144 | return blk_end_bidi_request(rq, error, nr_bytes, 0); | 2137 | return blk_end_bidi_request(rq, error, nr_bytes, 0); |
| 2145 | } | 2138 | } |
| 2146 | EXPORT_SYMBOL_GPL(blk_end_request); | 2139 | EXPORT_SYMBOL(blk_end_request); |
| 2147 | 2140 | ||
| 2148 | /** | 2141 | /** |
| 2149 | * blk_end_request_all - Helper function for drives to finish the request. | 2142 | * blk_end_request_all - Helper function for drives to finish the request. |
| @@ -2164,7 +2157,7 @@ void blk_end_request_all(struct request *rq, int error) | |||
| 2164 | pending = blk_end_bidi_request(rq, error, blk_rq_bytes(rq), bidi_bytes); | 2157 | pending = blk_end_bidi_request(rq, error, blk_rq_bytes(rq), bidi_bytes); |
| 2165 | BUG_ON(pending); | 2158 | BUG_ON(pending); |
| 2166 | } | 2159 | } |
| 2167 | EXPORT_SYMBOL_GPL(blk_end_request_all); | 2160 | EXPORT_SYMBOL(blk_end_request_all); |
| 2168 | 2161 | ||
| 2169 | /** | 2162 | /** |
| 2170 | * blk_end_request_cur - Helper function to finish the current request chunk. | 2163 | * blk_end_request_cur - Helper function to finish the current request chunk. |
| @@ -2182,7 +2175,7 @@ bool blk_end_request_cur(struct request *rq, int error) | |||
| 2182 | { | 2175 | { |
| 2183 | return blk_end_request(rq, error, blk_rq_cur_bytes(rq)); | 2176 | return blk_end_request(rq, error, blk_rq_cur_bytes(rq)); |
| 2184 | } | 2177 | } |
| 2185 | EXPORT_SYMBOL_GPL(blk_end_request_cur); | 2178 | EXPORT_SYMBOL(blk_end_request_cur); |
| 2186 | 2179 | ||
| 2187 | /** | 2180 | /** |
| 2188 | * __blk_end_request - Helper function for drivers to complete the request. | 2181 | * __blk_end_request - Helper function for drivers to complete the request. |
| @@ -2201,7 +2194,7 @@ bool __blk_end_request(struct request *rq, int error, unsigned int nr_bytes) | |||
| 2201 | { | 2194 | { |
| 2202 | return __blk_end_bidi_request(rq, error, nr_bytes, 0); | 2195 | return __blk_end_bidi_request(rq, error, nr_bytes, 0); |
| 2203 | } | 2196 | } |
| 2204 | EXPORT_SYMBOL_GPL(__blk_end_request); | 2197 | EXPORT_SYMBOL(__blk_end_request); |
| 2205 | 2198 | ||
| 2206 | /** | 2199 | /** |
| 2207 | * __blk_end_request_all - Helper function for drives to finish the request. | 2200 | * __blk_end_request_all - Helper function for drives to finish the request. |
| @@ -2222,7 +2215,7 @@ void __blk_end_request_all(struct request *rq, int error) | |||
| 2222 | pending = __blk_end_bidi_request(rq, error, blk_rq_bytes(rq), bidi_bytes); | 2215 | pending = __blk_end_bidi_request(rq, error, blk_rq_bytes(rq), bidi_bytes); |
| 2223 | BUG_ON(pending); | 2216 | BUG_ON(pending); |
| 2224 | } | 2217 | } |
| 2225 | EXPORT_SYMBOL_GPL(__blk_end_request_all); | 2218 | EXPORT_SYMBOL(__blk_end_request_all); |
| 2226 | 2219 | ||
| 2227 | /** | 2220 | /** |
| 2228 | * __blk_end_request_cur - Helper function to finish the current request chunk. | 2221 | * __blk_end_request_cur - Helper function to finish the current request chunk. |
| @@ -2241,7 +2234,7 @@ bool __blk_end_request_cur(struct request *rq, int error) | |||
| 2241 | { | 2234 | { |
| 2242 | return __blk_end_request(rq, error, blk_rq_cur_bytes(rq)); | 2235 | return __blk_end_request(rq, error, blk_rq_cur_bytes(rq)); |
| 2243 | } | 2236 | } |
| 2244 | EXPORT_SYMBOL_GPL(__blk_end_request_cur); | 2237 | EXPORT_SYMBOL(__blk_end_request_cur); |
| 2245 | 2238 | ||
| 2246 | void blk_rq_bio_prep(struct request_queue *q, struct request *rq, | 2239 | void blk_rq_bio_prep(struct request_queue *q, struct request *rq, |
| 2247 | struct bio *bio) | 2240 | struct bio *bio) |
diff --git a/block/blk-integrity.c b/block/blk-integrity.c index 73e28d355688..15c630813b1c 100644 --- a/block/blk-integrity.c +++ b/block/blk-integrity.c | |||
| @@ -379,6 +379,7 @@ void blk_integrity_unregister(struct gendisk *disk) | |||
| 379 | 379 | ||
| 380 | kobject_uevent(&bi->kobj, KOBJ_REMOVE); | 380 | kobject_uevent(&bi->kobj, KOBJ_REMOVE); |
| 381 | kobject_del(&bi->kobj); | 381 | kobject_del(&bi->kobj); |
| 382 | kobject_put(&bi->kobj); | ||
| 382 | kmem_cache_free(integrity_cachep, bi); | 383 | kmem_cache_free(integrity_cachep, bi); |
| 383 | disk->integrity = NULL; | 384 | disk->integrity = NULL; |
| 384 | } | 385 | } |
diff --git a/block/blk-settings.c b/block/blk-settings.c index bd582a7f5310..476d87065073 100644 --- a/block/blk-settings.c +++ b/block/blk-settings.c | |||
| @@ -7,6 +7,7 @@ | |||
| 7 | #include <linux/bio.h> | 7 | #include <linux/bio.h> |
| 8 | #include <linux/blkdev.h> | 8 | #include <linux/blkdev.h> |
| 9 | #include <linux/bootmem.h> /* for max_pfn/max_low_pfn */ | 9 | #include <linux/bootmem.h> /* for max_pfn/max_low_pfn */ |
| 10 | #include <linux/gcd.h> | ||
| 10 | 11 | ||
| 11 | #include "blk.h" | 12 | #include "blk.h" |
| 12 | 13 | ||
| @@ -165,6 +166,13 @@ void blk_queue_make_request(struct request_queue *q, make_request_fn *mfn) | |||
| 165 | blk_set_default_limits(&q->limits); | 166 | blk_set_default_limits(&q->limits); |
| 166 | 167 | ||
| 167 | /* | 168 | /* |
| 169 | * If the caller didn't supply a lock, fall back to our embedded | ||
| 170 | * per-queue locks | ||
| 171 | */ | ||
| 172 | if (!q->queue_lock) | ||
| 173 | q->queue_lock = &q->__queue_lock; | ||
| 174 | |||
| 175 | /* | ||
| 168 | * by default assume old behaviour and bounce for any highmem page | 176 | * by default assume old behaviour and bounce for any highmem page |
| 169 | */ | 177 | */ |
| 170 | blk_queue_bounce_limit(q, BLK_BOUNCE_HIGH); | 178 | blk_queue_bounce_limit(q, BLK_BOUNCE_HIGH); |
| @@ -377,8 +385,8 @@ void blk_queue_alignment_offset(struct request_queue *q, unsigned int offset) | |||
| 377 | EXPORT_SYMBOL(blk_queue_alignment_offset); | 385 | EXPORT_SYMBOL(blk_queue_alignment_offset); |
| 378 | 386 | ||
| 379 | /** | 387 | /** |
| 380 | * blk_queue_io_min - set minimum request size for the queue | 388 | * blk_limits_io_min - set minimum request size for a device |
| 381 | * @q: the request queue for the device | 389 | * @limits: the queue limits |
| 382 | * @min: smallest I/O size in bytes | 390 | * @min: smallest I/O size in bytes |
| 383 | * | 391 | * |
| 384 | * Description: | 392 | * Description: |
| @@ -387,15 +395,35 @@ EXPORT_SYMBOL(blk_queue_alignment_offset); | |||
| 387 | * smallest I/O the device can perform without incurring a performance | 395 | * smallest I/O the device can perform without incurring a performance |
| 388 | * penalty. | 396 | * penalty. |
| 389 | */ | 397 | */ |
| 390 | void blk_queue_io_min(struct request_queue *q, unsigned int min) | 398 | void blk_limits_io_min(struct queue_limits *limits, unsigned int min) |
| 391 | { | 399 | { |
| 392 | q->limits.io_min = min; | 400 | limits->io_min = min; |
| 393 | 401 | ||
| 394 | if (q->limits.io_min < q->limits.logical_block_size) | 402 | if (limits->io_min < limits->logical_block_size) |
| 395 | q->limits.io_min = q->limits.logical_block_size; | 403 | limits->io_min = limits->logical_block_size; |
| 396 | 404 | ||
| 397 | if (q->limits.io_min < q->limits.physical_block_size) | 405 | if (limits->io_min < limits->physical_block_size) |
| 398 | q->limits.io_min = q->limits.physical_block_size; | 406 | limits->io_min = limits->physical_block_size; |
| 407 | } | ||
| 408 | EXPORT_SYMBOL(blk_limits_io_min); | ||
| 409 | |||
| 410 | /** | ||
| 411 | * blk_queue_io_min - set minimum request size for the queue | ||
| 412 | * @q: the request queue for the device | ||
| 413 | * @min: smallest I/O size in bytes | ||
| 414 | * | ||
| 415 | * Description: | ||
| 416 | * Storage devices may report a granularity or preferred minimum I/O | ||
| 417 | * size which is the smallest request the device can perform without | ||
| 418 | * incurring a performance penalty. For disk drives this is often the | ||
| 419 | * physical block size. For RAID arrays it is often the stripe chunk | ||
| 420 | * size. A properly aligned multiple of minimum_io_size is the | ||
| 421 | * preferred request size for workloads where a high number of I/O | ||
| 422 | * operations is desired. | ||
| 423 | */ | ||
| 424 | void blk_queue_io_min(struct request_queue *q, unsigned int min) | ||
| 425 | { | ||
| 426 | blk_limits_io_min(&q->limits, min); | ||
| 399 | } | 427 | } |
| 400 | EXPORT_SYMBOL(blk_queue_io_min); | 428 | EXPORT_SYMBOL(blk_queue_io_min); |
| 401 | 429 | ||
| @@ -405,8 +433,12 @@ EXPORT_SYMBOL(blk_queue_io_min); | |||
| 405 | * @opt: optimal request size in bytes | 433 | * @opt: optimal request size in bytes |
| 406 | * | 434 | * |
| 407 | * Description: | 435 | * Description: |
| 408 | * Drivers can call this function to set the preferred I/O request | 436 | * Storage devices may report an optimal I/O size, which is the |
| 409 | * size for devices that report such a value. | 437 | * device's preferred unit for sustained I/O. This is rarely reported |
| 438 | * for disk drives. For RAID arrays it is usually the stripe width or | ||
| 439 | * the internal track size. A properly aligned multiple of | ||
| 440 | * optimal_io_size is the preferred request size for workloads where | ||
| 441 | * sustained throughput is desired. | ||
| 410 | */ | 442 | */ |
| 411 | void blk_queue_io_opt(struct request_queue *q, unsigned int opt) | 443 | void blk_queue_io_opt(struct request_queue *q, unsigned int opt) |
| 412 | { | 444 | { |
| @@ -426,27 +458,7 @@ EXPORT_SYMBOL(blk_queue_io_opt); | |||
| 426 | **/ | 458 | **/ |
| 427 | void blk_queue_stack_limits(struct request_queue *t, struct request_queue *b) | 459 | void blk_queue_stack_limits(struct request_queue *t, struct request_queue *b) |
| 428 | { | 460 | { |
| 429 | /* zero is "infinity" */ | 461 | blk_stack_limits(&t->limits, &b->limits, 0); |
| 430 | t->limits.max_sectors = min_not_zero(queue_max_sectors(t), | ||
| 431 | queue_max_sectors(b)); | ||
| 432 | |||
| 433 | t->limits.max_hw_sectors = min_not_zero(queue_max_hw_sectors(t), | ||
| 434 | queue_max_hw_sectors(b)); | ||
| 435 | |||
| 436 | t->limits.seg_boundary_mask = min_not_zero(queue_segment_boundary(t), | ||
| 437 | queue_segment_boundary(b)); | ||
| 438 | |||
| 439 | t->limits.max_phys_segments = min_not_zero(queue_max_phys_segments(t), | ||
| 440 | queue_max_phys_segments(b)); | ||
| 441 | |||
| 442 | t->limits.max_hw_segments = min_not_zero(queue_max_hw_segments(t), | ||
| 443 | queue_max_hw_segments(b)); | ||
| 444 | |||
| 445 | t->limits.max_segment_size = min_not_zero(queue_max_segment_size(t), | ||
| 446 | queue_max_segment_size(b)); | ||
| 447 | |||
| 448 | t->limits.logical_block_size = max(queue_logical_block_size(t), | ||
| 449 | queue_logical_block_size(b)); | ||
| 450 | 462 | ||
| 451 | if (!t->queue_lock) | 463 | if (!t->queue_lock) |
| 452 | WARN_ON_ONCE(1); | 464 | WARN_ON_ONCE(1); |
| @@ -516,6 +528,16 @@ int blk_stack_limits(struct queue_limits *t, struct queue_limits *b, | |||
| 516 | return -1; | 528 | return -1; |
| 517 | } | 529 | } |
| 518 | 530 | ||
| 531 | /* Find lcm() of optimal I/O size */ | ||
| 532 | if (t->io_opt && b->io_opt) | ||
| 533 | t->io_opt = (t->io_opt * b->io_opt) / gcd(t->io_opt, b->io_opt); | ||
| 534 | else if (b->io_opt) | ||
| 535 | t->io_opt = b->io_opt; | ||
| 536 | |||
| 537 | /* Verify that optimal I/O size is a multiple of io_min */ | ||
| 538 | if (t->io_min && t->io_opt % t->io_min) | ||
| 539 | return -1; | ||
| 540 | |||
| 519 | return 0; | 541 | return 0; |
| 520 | } | 542 | } |
| 521 | EXPORT_SYMBOL(blk_stack_limits); | 543 | EXPORT_SYMBOL(blk_stack_limits); |
diff --git a/block/blk-sysfs.c b/block/blk-sysfs.c index b1cd04087d6a..418d63619680 100644 --- a/block/blk-sysfs.c +++ b/block/blk-sysfs.c | |||
| @@ -16,9 +16,9 @@ struct queue_sysfs_entry { | |||
| 16 | }; | 16 | }; |
| 17 | 17 | ||
| 18 | static ssize_t | 18 | static ssize_t |
| 19 | queue_var_show(unsigned int var, char *page) | 19 | queue_var_show(unsigned long var, char *page) |
| 20 | { | 20 | { |
| 21 | return sprintf(page, "%d\n", var); | 21 | return sprintf(page, "%lu\n", var); |
| 22 | } | 22 | } |
| 23 | 23 | ||
| 24 | static ssize_t | 24 | static ssize_t |
| @@ -77,7 +77,8 @@ queue_requests_store(struct request_queue *q, const char *page, size_t count) | |||
| 77 | 77 | ||
| 78 | static ssize_t queue_ra_show(struct request_queue *q, char *page) | 78 | static ssize_t queue_ra_show(struct request_queue *q, char *page) |
| 79 | { | 79 | { |
| 80 | int ra_kb = q->backing_dev_info.ra_pages << (PAGE_CACHE_SHIFT - 10); | 80 | unsigned long ra_kb = q->backing_dev_info.ra_pages << |
| 81 | (PAGE_CACHE_SHIFT - 10); | ||
| 81 | 82 | ||
| 82 | return queue_var_show(ra_kb, (page)); | 83 | return queue_var_show(ra_kb, (page)); |
| 83 | } | 84 | } |
| @@ -189,9 +190,9 @@ static ssize_t queue_nomerges_store(struct request_queue *q, const char *page, | |||
| 189 | 190 | ||
| 190 | static ssize_t queue_rq_affinity_show(struct request_queue *q, char *page) | 191 | static ssize_t queue_rq_affinity_show(struct request_queue *q, char *page) |
| 191 | { | 192 | { |
| 192 | unsigned int set = test_bit(QUEUE_FLAG_SAME_COMP, &q->queue_flags); | 193 | bool set = test_bit(QUEUE_FLAG_SAME_COMP, &q->queue_flags); |
| 193 | 194 | ||
| 194 | return queue_var_show(set != 0, page); | 195 | return queue_var_show(set, page); |
| 195 | } | 196 | } |
| 196 | 197 | ||
| 197 | static ssize_t | 198 | static ssize_t |
diff --git a/block/elevator.c b/block/elevator.c index 6f2375339a99..2d511f9105e1 100644 --- a/block/elevator.c +++ b/block/elevator.c | |||
| @@ -101,11 +101,16 @@ int elv_rq_merge_ok(struct request *rq, struct bio *bio) | |||
| 101 | return 0; | 101 | return 0; |
| 102 | 102 | ||
| 103 | /* | 103 | /* |
| 104 | * Don't merge if failfast settings don't match | 104 | * Don't merge if failfast settings don't match. |
| 105 | * | ||
| 106 | * FIXME: The negation in front of each condition is necessary | ||
| 107 | * because bio and request flags use different bit positions | ||
| 108 | * and the accessors return those bits directly. This | ||
| 109 | * ugliness will soon go away. | ||
| 105 | */ | 110 | */ |
| 106 | if (bio_failfast_dev(bio) != blk_failfast_dev(rq) || | 111 | if (!bio_failfast_dev(bio) != !blk_failfast_dev(rq) || |
| 107 | bio_failfast_transport(bio) != blk_failfast_transport(rq) || | 112 | !bio_failfast_transport(bio) != !blk_failfast_transport(rq) || |
| 108 | bio_failfast_driver(bio) != blk_failfast_driver(rq)) | 113 | !bio_failfast_driver(bio) != !blk_failfast_driver(rq)) |
| 109 | return 0; | 114 | return 0; |
| 110 | 115 | ||
| 111 | if (!elv_iosched_allow_merge(rq, bio)) | 116 | if (!elv_iosched_allow_merge(rq, bio)) |
diff --git a/crypto/async_tx/async_xor.c b/crypto/async_tx/async_xor.c index 95fe2c8d6c51..90dd3f8bd283 100644 --- a/crypto/async_tx/async_xor.c +++ b/crypto/async_tx/async_xor.c | |||
| @@ -300,7 +300,7 @@ EXPORT_SYMBOL_GPL(async_xor_zero_sum); | |||
| 300 | 300 | ||
| 301 | static int __init async_xor_init(void) | 301 | static int __init async_xor_init(void) |
| 302 | { | 302 | { |
| 303 | #ifdef CONFIG_DMA_ENGINE | 303 | #ifdef CONFIG_ASYNC_TX_DMA |
| 304 | /* To conserve stack space the input src_list (array of page pointers) | 304 | /* To conserve stack space the input src_list (array of page pointers) |
| 305 | * is reused to hold the array of dma addresses passed to the driver. | 305 | * is reused to hold the array of dma addresses passed to the driver. |
| 306 | * This conversion is only possible when dma_addr_t is less than the | 306 | * This conversion is only possible when dma_addr_t is less than the |
diff --git a/drivers/acpi/acpi_memhotplug.c b/drivers/acpi/acpi_memhotplug.c index 7a0f4aa4fa1e..9a62224cc278 100644 --- a/drivers/acpi/acpi_memhotplug.c +++ b/drivers/acpi/acpi_memhotplug.c | |||
| @@ -38,6 +38,9 @@ | |||
| 38 | 38 | ||
| 39 | #define _COMPONENT ACPI_MEMORY_DEVICE_COMPONENT | 39 | #define _COMPONENT ACPI_MEMORY_DEVICE_COMPONENT |
| 40 | 40 | ||
| 41 | #undef PREFIX | ||
| 42 | #define PREFIX "ACPI:memory_hp:" | ||
| 43 | |||
| 41 | ACPI_MODULE_NAME("acpi_memhotplug"); | 44 | ACPI_MODULE_NAME("acpi_memhotplug"); |
| 42 | MODULE_AUTHOR("Naveen B S <naveen.b.s@intel.com>"); | 45 | MODULE_AUTHOR("Naveen B S <naveen.b.s@intel.com>"); |
| 43 | MODULE_DESCRIPTION("Hotplug Mem Driver"); | 46 | MODULE_DESCRIPTION("Hotplug Mem Driver"); |
| @@ -153,6 +156,7 @@ acpi_memory_get_device(acpi_handle handle, | |||
| 153 | acpi_handle phandle; | 156 | acpi_handle phandle; |
| 154 | struct acpi_device *device = NULL; | 157 | struct acpi_device *device = NULL; |
| 155 | struct acpi_device *pdevice = NULL; | 158 | struct acpi_device *pdevice = NULL; |
| 159 | int result; | ||
| 156 | 160 | ||
| 157 | 161 | ||
| 158 | if (!acpi_bus_get_device(handle, &device) && device) | 162 | if (!acpi_bus_get_device(handle, &device) && device) |
| @@ -165,9 +169,9 @@ acpi_memory_get_device(acpi_handle handle, | |||
| 165 | } | 169 | } |
| 166 | 170 | ||
| 167 | /* Get the parent device */ | 171 | /* Get the parent device */ |
| 168 | status = acpi_bus_get_device(phandle, &pdevice); | 172 | result = acpi_bus_get_device(phandle, &pdevice); |
| 169 | if (ACPI_FAILURE(status)) { | 173 | if (result) { |
| 170 | ACPI_EXCEPTION((AE_INFO, status, "Cannot get acpi bus device")); | 174 | printk(KERN_WARNING PREFIX "Cannot get acpi bus device"); |
| 171 | return -EINVAL; | 175 | return -EINVAL; |
| 172 | } | 176 | } |
| 173 | 177 | ||
| @@ -175,9 +179,9 @@ acpi_memory_get_device(acpi_handle handle, | |||
| 175 | * Now add the notified device. This creates the acpi_device | 179 | * Now add the notified device. This creates the acpi_device |
| 176 | * and invokes .add function | 180 | * and invokes .add function |
| 177 | */ | 181 | */ |
| 178 | status = acpi_bus_add(&device, pdevice, handle, ACPI_BUS_TYPE_DEVICE); | 182 | result = acpi_bus_add(&device, pdevice, handle, ACPI_BUS_TYPE_DEVICE); |
| 179 | if (ACPI_FAILURE(status)) { | 183 | if (result) { |
| 180 | ACPI_EXCEPTION((AE_INFO, status, "Cannot add acpi bus")); | 184 | printk(KERN_WARNING PREFIX "Cannot add acpi bus"); |
| 181 | return -EINVAL; | 185 | return -EINVAL; |
| 182 | } | 186 | } |
| 183 | 187 | ||
| @@ -238,7 +242,12 @@ static int acpi_memory_enable_device(struct acpi_memory_device *mem_device) | |||
| 238 | num_enabled++; | 242 | num_enabled++; |
| 239 | continue; | 243 | continue; |
| 240 | } | 244 | } |
| 241 | 245 | /* | |
| 246 | * If the memory block size is zero, please ignore it. | ||
| 247 | * Don't try to do the following memory hotplug flowchart. | ||
| 248 | */ | ||
| 249 | if (!info->length) | ||
| 250 | continue; | ||
| 242 | if (node < 0) | 251 | if (node < 0) |
| 243 | node = memory_add_physaddr_to_nid(info->start_addr); | 252 | node = memory_add_physaddr_to_nid(info->start_addr); |
| 244 | 253 | ||
| @@ -253,8 +262,15 @@ static int acpi_memory_enable_device(struct acpi_memory_device *mem_device) | |||
| 253 | mem_device->state = MEMORY_INVALID_STATE; | 262 | mem_device->state = MEMORY_INVALID_STATE; |
| 254 | return -EINVAL; | 263 | return -EINVAL; |
| 255 | } | 264 | } |
| 256 | 265 | /* | |
| 257 | return result; | 266 | * Sometimes the memory device will contain several memory blocks. |
| 267 | * When one memory block is hot-added to the system memory, it will | ||
| 268 | * be regarded as a success. | ||
| 269 | * Otherwise if the last memory block can't be hot-added to the system | ||
| 270 | * memory, it will be failure and the memory device can't be bound with | ||
| 271 | * driver. | ||
| 272 | */ | ||
| 273 | return 0; | ||
| 258 | } | 274 | } |
| 259 | 275 | ||
| 260 | static int acpi_memory_powerdown_device(struct acpi_memory_device *mem_device) | 276 | static int acpi_memory_powerdown_device(struct acpi_memory_device *mem_device) |
diff --git a/drivers/acpi/acpica/acobject.h b/drivers/acpi/acpica/acobject.h index 544dcf834922..eb6f038b03d9 100644 --- a/drivers/acpi/acpica/acobject.h +++ b/drivers/acpi/acpica/acobject.h | |||
| @@ -97,6 +97,7 @@ | |||
| 97 | #define AOPOBJ_OBJECT_INITIALIZED 0x08 | 97 | #define AOPOBJ_OBJECT_INITIALIZED 0x08 |
| 98 | #define AOPOBJ_SETUP_COMPLETE 0x10 | 98 | #define AOPOBJ_SETUP_COMPLETE 0x10 |
| 99 | #define AOPOBJ_SINGLE_DATUM 0x20 | 99 | #define AOPOBJ_SINGLE_DATUM 0x20 |
| 100 | #define AOPOBJ_INVALID 0x40 /* Used if host OS won't allow an op_region address */ | ||
| 100 | 101 | ||
| 101 | /****************************************************************************** | 102 | /****************************************************************************** |
| 102 | * | 103 | * |
diff --git a/drivers/acpi/acpica/dsopcode.c b/drivers/acpi/acpica/dsopcode.c index 584d766e6f12..b79978f7bc71 100644 --- a/drivers/acpi/acpica/dsopcode.c +++ b/drivers/acpi/acpica/dsopcode.c | |||
| @@ -397,6 +397,30 @@ acpi_status acpi_ds_get_region_arguments(union acpi_operand_object *obj_desc) | |||
| 397 | status = acpi_ds_execute_arguments(node, acpi_ns_get_parent_node(node), | 397 | status = acpi_ds_execute_arguments(node, acpi_ns_get_parent_node(node), |
| 398 | extra_desc->extra.aml_length, | 398 | extra_desc->extra.aml_length, |
| 399 | extra_desc->extra.aml_start); | 399 | extra_desc->extra.aml_start); |
| 400 | if (ACPI_FAILURE(status)) { | ||
| 401 | return_ACPI_STATUS(status); | ||
| 402 | } | ||
| 403 | |||
| 404 | /* Validate the region address/length via the host OS */ | ||
| 405 | |||
| 406 | status = acpi_os_validate_address(obj_desc->region.space_id, | ||
| 407 | obj_desc->region.address, | ||
| 408 | (acpi_size) obj_desc->region.length, | ||
| 409 | acpi_ut_get_node_name(node)); | ||
| 410 | |||
| 411 | if (ACPI_FAILURE(status)) { | ||
| 412 | /* | ||
| 413 | * Invalid address/length. We will emit an error message and mark | ||
| 414 | * the region as invalid, so that it will cause an additional error if | ||
| 415 | * it is ever used. Then return AE_OK. | ||
| 416 | */ | ||
| 417 | ACPI_EXCEPTION((AE_INFO, status, | ||
| 418 | "During address validation of OpRegion [%4.4s]", | ||
| 419 | node->name.ascii)); | ||
| 420 | obj_desc->common.flags |= AOPOBJ_INVALID; | ||
| 421 | status = AE_OK; | ||
| 422 | } | ||
| 423 | |||
| 400 | return_ACPI_STATUS(status); | 424 | return_ACPI_STATUS(status); |
| 401 | } | 425 | } |
| 402 | 426 | ||
diff --git a/drivers/acpi/acpica/exfldio.c b/drivers/acpi/acpica/exfldio.c index d4075b821021..6687be167f5f 100644 --- a/drivers/acpi/acpica/exfldio.c +++ b/drivers/acpi/acpica/exfldio.c | |||
| @@ -113,6 +113,12 @@ acpi_ex_setup_region(union acpi_operand_object *obj_desc, | |||
| 113 | } | 113 | } |
| 114 | } | 114 | } |
| 115 | 115 | ||
| 116 | /* Exit if Address/Length have been disallowed by the host OS */ | ||
| 117 | |||
| 118 | if (rgn_desc->common.flags & AOPOBJ_INVALID) { | ||
| 119 | return_ACPI_STATUS(AE_AML_ILLEGAL_ADDRESS); | ||
| 120 | } | ||
| 121 | |||
| 116 | /* | 122 | /* |
| 117 | * Exit now for SMBus address space, it has a non-linear address space | 123 | * Exit now for SMBus address space, it has a non-linear address space |
| 118 | * and the request cannot be directly validated | 124 | * and the request cannot be directly validated |
diff --git a/drivers/acpi/osl.c b/drivers/acpi/osl.c index 71670719d61a..5691f165a952 100644 --- a/drivers/acpi/osl.c +++ b/drivers/acpi/osl.c | |||
| @@ -189,11 +189,36 @@ acpi_status __init acpi_os_initialize(void) | |||
| 189 | return AE_OK; | 189 | return AE_OK; |
| 190 | } | 190 | } |
| 191 | 191 | ||
| 192 | static void bind_to_cpu0(struct work_struct *work) | ||
| 193 | { | ||
| 194 | set_cpus_allowed(current, cpumask_of_cpu(0)); | ||
| 195 | kfree(work); | ||
| 196 | } | ||
| 197 | |||
| 198 | static void bind_workqueue(struct workqueue_struct *wq) | ||
| 199 | { | ||
| 200 | struct work_struct *work; | ||
| 201 | |||
| 202 | work = kzalloc(sizeof(struct work_struct), GFP_KERNEL); | ||
| 203 | INIT_WORK(work, bind_to_cpu0); | ||
| 204 | queue_work(wq, work); | ||
| 205 | } | ||
| 206 | |||
| 192 | acpi_status acpi_os_initialize1(void) | 207 | acpi_status acpi_os_initialize1(void) |
| 193 | { | 208 | { |
| 209 | /* | ||
| 210 | * On some machines, a software-initiated SMI causes corruption unless | ||
| 211 | * the SMI runs on CPU 0. An SMI can be initiated by any AML, but | ||
| 212 | * typically it's done in GPE-related methods that are run via | ||
| 213 | * workqueues, so we can avoid the known corruption cases by binding | ||
| 214 | * the workqueues to CPU 0. | ||
| 215 | */ | ||
| 194 | kacpid_wq = create_singlethread_workqueue("kacpid"); | 216 | kacpid_wq = create_singlethread_workqueue("kacpid"); |
| 217 | bind_workqueue(kacpid_wq); | ||
| 195 | kacpi_notify_wq = create_singlethread_workqueue("kacpi_notify"); | 218 | kacpi_notify_wq = create_singlethread_workqueue("kacpi_notify"); |
| 219 | bind_workqueue(kacpi_notify_wq); | ||
| 196 | kacpi_hotplug_wq = create_singlethread_workqueue("kacpi_hotplug"); | 220 | kacpi_hotplug_wq = create_singlethread_workqueue("kacpi_hotplug"); |
| 221 | bind_workqueue(kacpi_hotplug_wq); | ||
| 197 | BUG_ON(!kacpid_wq); | 222 | BUG_ON(!kacpid_wq); |
| 198 | BUG_ON(!kacpi_notify_wq); | 223 | BUG_ON(!kacpi_notify_wq); |
| 199 | BUG_ON(!kacpi_hotplug_wq); | 224 | BUG_ON(!kacpi_hotplug_wq); |
diff --git a/drivers/acpi/processor_core.c b/drivers/acpi/processor_core.c index 84e0f3c07442..2cc4b3033872 100644 --- a/drivers/acpi/processor_core.c +++ b/drivers/acpi/processor_core.c | |||
| @@ -1151,6 +1151,9 @@ static int __init acpi_processor_init(void) | |||
| 1151 | { | 1151 | { |
| 1152 | int result = 0; | 1152 | int result = 0; |
| 1153 | 1153 | ||
| 1154 | if (acpi_disabled) | ||
| 1155 | return 0; | ||
| 1156 | |||
| 1154 | memset(&errata, 0, sizeof(errata)); | 1157 | memset(&errata, 0, sizeof(errata)); |
| 1155 | 1158 | ||
| 1156 | #ifdef CONFIG_SMP | 1159 | #ifdef CONFIG_SMP |
| @@ -1197,6 +1200,9 @@ out_proc: | |||
| 1197 | 1200 | ||
| 1198 | static void __exit acpi_processor_exit(void) | 1201 | static void __exit acpi_processor_exit(void) |
| 1199 | { | 1202 | { |
| 1203 | if (acpi_disabled) | ||
| 1204 | return; | ||
| 1205 | |||
| 1200 | acpi_processor_ppc_exit(); | 1206 | acpi_processor_ppc_exit(); |
| 1201 | 1207 | ||
| 1202 | acpi_thermal_cpufreq_exit(); | 1208 | acpi_thermal_cpufreq_exit(); |
diff --git a/drivers/acpi/processor_idle.c b/drivers/acpi/processor_idle.c index 0efa59e7e3af..66393d5c4c7c 100644 --- a/drivers/acpi/processor_idle.c +++ b/drivers/acpi/processor_idle.c | |||
| @@ -162,8 +162,9 @@ static void lapic_timer_check_state(int state, struct acpi_processor *pr, | |||
| 162 | pr->power.timer_broadcast_on_state = state; | 162 | pr->power.timer_broadcast_on_state = state; |
| 163 | } | 163 | } |
| 164 | 164 | ||
| 165 | static void lapic_timer_propagate_broadcast(struct acpi_processor *pr) | 165 | static void lapic_timer_propagate_broadcast(void *arg) |
| 166 | { | 166 | { |
| 167 | struct acpi_processor *pr = (struct acpi_processor *) arg; | ||
| 167 | unsigned long reason; | 168 | unsigned long reason; |
| 168 | 169 | ||
| 169 | reason = pr->power.timer_broadcast_on_state < INT_MAX ? | 170 | reason = pr->power.timer_broadcast_on_state < INT_MAX ? |
| @@ -635,7 +636,8 @@ static int acpi_processor_power_verify(struct acpi_processor *pr) | |||
| 635 | working++; | 636 | working++; |
| 636 | } | 637 | } |
| 637 | 638 | ||
| 638 | lapic_timer_propagate_broadcast(pr); | 639 | smp_call_function_single(pr->id, lapic_timer_propagate_broadcast, |
| 640 | pr, 1); | ||
| 639 | 641 | ||
| 640 | return (working); | 642 | return (working); |
| 641 | } | 643 | } |
diff --git a/drivers/acpi/processor_thermal.c b/drivers/acpi/processor_thermal.c index 39838c666032..31adda1099e0 100644 --- a/drivers/acpi/processor_thermal.c +++ b/drivers/acpi/processor_thermal.c | |||
| @@ -66,7 +66,7 @@ static int acpi_processor_apply_limit(struct acpi_processor *pr) | |||
| 66 | if (pr->limit.thermal.tx > tx) | 66 | if (pr->limit.thermal.tx > tx) |
| 67 | tx = pr->limit.thermal.tx; | 67 | tx = pr->limit.thermal.tx; |
| 68 | 68 | ||
| 69 | result = acpi_processor_set_throttling(pr, tx); | 69 | result = acpi_processor_set_throttling(pr, tx, false); |
| 70 | if (result) | 70 | if (result) |
| 71 | goto end; | 71 | goto end; |
| 72 | } | 72 | } |
| @@ -421,12 +421,12 @@ processor_set_cur_state(struct thermal_cooling_device *cdev, | |||
| 421 | 421 | ||
| 422 | if (state <= max_pstate) { | 422 | if (state <= max_pstate) { |
| 423 | if (pr->flags.throttling && pr->throttling.state) | 423 | if (pr->flags.throttling && pr->throttling.state) |
| 424 | result = acpi_processor_set_throttling(pr, 0); | 424 | result = acpi_processor_set_throttling(pr, 0, false); |
| 425 | cpufreq_set_cur_state(pr->id, state); | 425 | cpufreq_set_cur_state(pr->id, state); |
| 426 | } else { | 426 | } else { |
| 427 | cpufreq_set_cur_state(pr->id, max_pstate); | 427 | cpufreq_set_cur_state(pr->id, max_pstate); |
| 428 | result = acpi_processor_set_throttling(pr, | 428 | result = acpi_processor_set_throttling(pr, |
| 429 | state - max_pstate); | 429 | state - max_pstate, false); |
| 430 | } | 430 | } |
| 431 | return result; | 431 | return result; |
| 432 | } | 432 | } |
diff --git a/drivers/acpi/processor_throttling.c b/drivers/acpi/processor_throttling.c index 227543789ba9..ae39797aab55 100644 --- a/drivers/acpi/processor_throttling.c +++ b/drivers/acpi/processor_throttling.c | |||
| @@ -62,7 +62,8 @@ struct throttling_tstate { | |||
| 62 | #define THROTTLING_POSTCHANGE (2) | 62 | #define THROTTLING_POSTCHANGE (2) |
| 63 | 63 | ||
| 64 | static int acpi_processor_get_throttling(struct acpi_processor *pr); | 64 | static int acpi_processor_get_throttling(struct acpi_processor *pr); |
| 65 | int acpi_processor_set_throttling(struct acpi_processor *pr, int state); | 65 | int acpi_processor_set_throttling(struct acpi_processor *pr, |
| 66 | int state, bool force); | ||
| 66 | 67 | ||
| 67 | static int acpi_processor_update_tsd_coord(void) | 68 | static int acpi_processor_update_tsd_coord(void) |
| 68 | { | 69 | { |
| @@ -361,7 +362,7 @@ int acpi_processor_tstate_has_changed(struct acpi_processor *pr) | |||
| 361 | */ | 362 | */ |
| 362 | target_state = throttling_limit; | 363 | target_state = throttling_limit; |
| 363 | } | 364 | } |
| 364 | return acpi_processor_set_throttling(pr, target_state); | 365 | return acpi_processor_set_throttling(pr, target_state, false); |
| 365 | } | 366 | } |
| 366 | 367 | ||
| 367 | /* | 368 | /* |
| @@ -839,10 +840,10 @@ static int acpi_processor_get_throttling_ptc(struct acpi_processor *pr) | |||
| 839 | if (ret >= 0) { | 840 | if (ret >= 0) { |
| 840 | state = acpi_get_throttling_state(pr, value); | 841 | state = acpi_get_throttling_state(pr, value); |
| 841 | if (state == -1) { | 842 | if (state == -1) { |
| 842 | ACPI_WARNING((AE_INFO, | 843 | ACPI_DEBUG_PRINT((ACPI_DB_INFO, |
| 843 | "Invalid throttling state, reset")); | 844 | "Invalid throttling state, reset\n")); |
| 844 | state = 0; | 845 | state = 0; |
| 845 | ret = acpi_processor_set_throttling(pr, state); | 846 | ret = acpi_processor_set_throttling(pr, state, true); |
| 846 | if (ret) | 847 | if (ret) |
| 847 | return ret; | 848 | return ret; |
| 848 | } | 849 | } |
| @@ -915,7 +916,7 @@ static int acpi_processor_get_fadt_info(struct acpi_processor *pr) | |||
| 915 | } | 916 | } |
| 916 | 917 | ||
| 917 | static int acpi_processor_set_throttling_fadt(struct acpi_processor *pr, | 918 | static int acpi_processor_set_throttling_fadt(struct acpi_processor *pr, |
| 918 | int state) | 919 | int state, bool force) |
| 919 | { | 920 | { |
| 920 | u32 value = 0; | 921 | u32 value = 0; |
| 921 | u32 duty_mask = 0; | 922 | u32 duty_mask = 0; |
| @@ -930,7 +931,7 @@ static int acpi_processor_set_throttling_fadt(struct acpi_processor *pr, | |||
| 930 | if (!pr->flags.throttling) | 931 | if (!pr->flags.throttling) |
| 931 | return -ENODEV; | 932 | return -ENODEV; |
| 932 | 933 | ||
| 933 | if (state == pr->throttling.state) | 934 | if (!force && (state == pr->throttling.state)) |
| 934 | return 0; | 935 | return 0; |
| 935 | 936 | ||
| 936 | if (state < pr->throttling_platform_limit) | 937 | if (state < pr->throttling_platform_limit) |
| @@ -988,7 +989,7 @@ static int acpi_processor_set_throttling_fadt(struct acpi_processor *pr, | |||
| 988 | } | 989 | } |
| 989 | 990 | ||
| 990 | static int acpi_processor_set_throttling_ptc(struct acpi_processor *pr, | 991 | static int acpi_processor_set_throttling_ptc(struct acpi_processor *pr, |
| 991 | int state) | 992 | int state, bool force) |
| 992 | { | 993 | { |
| 993 | int ret; | 994 | int ret; |
| 994 | acpi_integer value; | 995 | acpi_integer value; |
| @@ -1002,7 +1003,7 @@ static int acpi_processor_set_throttling_ptc(struct acpi_processor *pr, | |||
| 1002 | if (!pr->flags.throttling) | 1003 | if (!pr->flags.throttling) |
| 1003 | return -ENODEV; | 1004 | return -ENODEV; |
| 1004 | 1005 | ||
| 1005 | if (state == pr->throttling.state) | 1006 | if (!force && (state == pr->throttling.state)) |
| 1006 | return 0; | 1007 | return 0; |
| 1007 | 1008 | ||
| 1008 | if (state < pr->throttling_platform_limit) | 1009 | if (state < pr->throttling_platform_limit) |
| @@ -1018,7 +1019,8 @@ static int acpi_processor_set_throttling_ptc(struct acpi_processor *pr, | |||
| 1018 | return 0; | 1019 | return 0; |
| 1019 | } | 1020 | } |
| 1020 | 1021 | ||
| 1021 | int acpi_processor_set_throttling(struct acpi_processor *pr, int state) | 1022 | int acpi_processor_set_throttling(struct acpi_processor *pr, |
| 1023 | int state, bool force) | ||
| 1022 | { | 1024 | { |
| 1023 | cpumask_var_t saved_mask; | 1025 | cpumask_var_t saved_mask; |
| 1024 | int ret = 0; | 1026 | int ret = 0; |
| @@ -1070,7 +1072,7 @@ int acpi_processor_set_throttling(struct acpi_processor *pr, int state) | |||
| 1070 | /* FIXME: use work_on_cpu() */ | 1072 | /* FIXME: use work_on_cpu() */ |
| 1071 | set_cpus_allowed_ptr(current, cpumask_of(pr->id)); | 1073 | set_cpus_allowed_ptr(current, cpumask_of(pr->id)); |
| 1072 | ret = p_throttling->acpi_processor_set_throttling(pr, | 1074 | ret = p_throttling->acpi_processor_set_throttling(pr, |
| 1073 | t_state.target_state); | 1075 | t_state.target_state, force); |
| 1074 | } else { | 1076 | } else { |
| 1075 | /* | 1077 | /* |
| 1076 | * When the T-state coordination is SW_ALL or HW_ALL, | 1078 | * When the T-state coordination is SW_ALL or HW_ALL, |
| @@ -1103,7 +1105,7 @@ int acpi_processor_set_throttling(struct acpi_processor *pr, int state) | |||
| 1103 | set_cpus_allowed_ptr(current, cpumask_of(i)); | 1105 | set_cpus_allowed_ptr(current, cpumask_of(i)); |
| 1104 | ret = match_pr->throttling. | 1106 | ret = match_pr->throttling. |
| 1105 | acpi_processor_set_throttling( | 1107 | acpi_processor_set_throttling( |
| 1106 | match_pr, t_state.target_state); | 1108 | match_pr, t_state.target_state, force); |
| 1107 | } | 1109 | } |
| 1108 | } | 1110 | } |
| 1109 | /* | 1111 | /* |
| @@ -1201,7 +1203,7 @@ int acpi_processor_get_throttling_info(struct acpi_processor *pr) | |||
| 1201 | ACPI_DEBUG_PRINT((ACPI_DB_INFO, | 1203 | ACPI_DEBUG_PRINT((ACPI_DB_INFO, |
| 1202 | "Disabling throttling (was T%d)\n", | 1204 | "Disabling throttling (was T%d)\n", |
| 1203 | pr->throttling.state)); | 1205 | pr->throttling.state)); |
| 1204 | result = acpi_processor_set_throttling(pr, 0); | 1206 | result = acpi_processor_set_throttling(pr, 0, false); |
| 1205 | if (result) | 1207 | if (result) |
| 1206 | goto end; | 1208 | goto end; |
| 1207 | } | 1209 | } |
| @@ -1307,7 +1309,7 @@ static ssize_t acpi_processor_write_throttling(struct file *file, | |||
| 1307 | if (strcmp(tmpbuf, charp) != 0) | 1309 | if (strcmp(tmpbuf, charp) != 0) |
| 1308 | return -EINVAL; | 1310 | return -EINVAL; |
| 1309 | 1311 | ||
| 1310 | result = acpi_processor_set_throttling(pr, state_val); | 1312 | result = acpi_processor_set_throttling(pr, state_val, false); |
| 1311 | if (result) | 1313 | if (result) |
| 1312 | return result; | 1314 | return result; |
| 1313 | 1315 | ||
diff --git a/drivers/acpi/sleep.c b/drivers/acpi/sleep.c index 01574a066534..42159a28f433 100644 --- a/drivers/acpi/sleep.c +++ b/drivers/acpi/sleep.c | |||
| @@ -397,6 +397,14 @@ static struct dmi_system_id __initdata acpisleep_dmi_table[] = { | |||
| 397 | }, | 397 | }, |
| 398 | }, | 398 | }, |
| 399 | { | 399 | { |
| 400 | .callback = init_set_sci_en_on_resume, | ||
| 401 | .ident = "Hewlett-Packard HP G7000 Notebook PC", | ||
| 402 | .matches = { | ||
| 403 | DMI_MATCH(DMI_SYS_VENDOR, "Hewlett-Packard"), | ||
| 404 | DMI_MATCH(DMI_PRODUCT_NAME, "HP G7000 Notebook PC"), | ||
| 405 | }, | ||
| 406 | }, | ||
| 407 | { | ||
| 400 | .callback = init_old_suspend_ordering, | 408 | .callback = init_old_suspend_ordering, |
| 401 | .ident = "Panasonic CF51-2L", | 409 | .ident = "Panasonic CF51-2L", |
| 402 | .matches = { | 410 | .matches = { |
diff --git a/drivers/acpi/system.c b/drivers/acpi/system.c index 0944daec064f..9c61ab2177cf 100644 --- a/drivers/acpi/system.c +++ b/drivers/acpi/system.c | |||
| @@ -121,7 +121,7 @@ static void acpi_table_attr_init(struct acpi_table_attr *table_attr, | |||
| 121 | table_attr->attr.size = 0; | 121 | table_attr->attr.size = 0; |
| 122 | table_attr->attr.read = acpi_table_show; | 122 | table_attr->attr.read = acpi_table_show; |
| 123 | table_attr->attr.attr.name = table_attr->name; | 123 | table_attr->attr.attr.name = table_attr->name; |
| 124 | table_attr->attr.attr.mode = 0444; | 124 | table_attr->attr.attr.mode = 0400; |
| 125 | 125 | ||
| 126 | return; | 126 | return; |
| 127 | } | 127 | } |
diff --git a/drivers/ata/ahci.c b/drivers/ata/ahci.c index 336eb1ed73cc..fe3eba5d6b3e 100644 --- a/drivers/ata/ahci.c +++ b/drivers/ata/ahci.c | |||
| @@ -219,6 +219,8 @@ enum { | |||
| 219 | AHCI_HFLAG_SECT255 = (1 << 8), /* max 255 sectors */ | 219 | AHCI_HFLAG_SECT255 = (1 << 8), /* max 255 sectors */ |
| 220 | AHCI_HFLAG_YES_NCQ = (1 << 9), /* force NCQ cap on */ | 220 | AHCI_HFLAG_YES_NCQ = (1 << 9), /* force NCQ cap on */ |
| 221 | AHCI_HFLAG_NO_SUSPEND = (1 << 10), /* don't suspend */ | 221 | AHCI_HFLAG_NO_SUSPEND = (1 << 10), /* don't suspend */ |
| 222 | AHCI_HFLAG_SRST_TOUT_IS_OFFLINE = (1 << 11), /* treat SRST timeout as | ||
| 223 | link offline */ | ||
| 222 | 224 | ||
| 223 | /* ap->flags bits */ | 225 | /* ap->flags bits */ |
| 224 | 226 | ||
| @@ -515,10 +517,14 @@ static const struct pci_device_id ahci_pci_tbl[] = { | |||
| 515 | { PCI_VDEVICE(INTEL, 0x3a05), board_ahci }, /* ICH10 */ | 517 | { PCI_VDEVICE(INTEL, 0x3a05), board_ahci }, /* ICH10 */ |
| 516 | { PCI_VDEVICE(INTEL, 0x3a22), board_ahci }, /* ICH10 */ | 518 | { PCI_VDEVICE(INTEL, 0x3a22), board_ahci }, /* ICH10 */ |
| 517 | { PCI_VDEVICE(INTEL, 0x3a25), board_ahci }, /* ICH10 */ | 519 | { PCI_VDEVICE(INTEL, 0x3a25), board_ahci }, /* ICH10 */ |
| 520 | { PCI_VDEVICE(INTEL, 0x3b22), board_ahci }, /* PCH AHCI */ | ||
| 521 | { PCI_VDEVICE(INTEL, 0x3b23), board_ahci }, /* PCH AHCI */ | ||
| 518 | { PCI_VDEVICE(INTEL, 0x3b24), board_ahci }, /* PCH RAID */ | 522 | { PCI_VDEVICE(INTEL, 0x3b24), board_ahci }, /* PCH RAID */ |
| 519 | { PCI_VDEVICE(INTEL, 0x3b25), board_ahci }, /* PCH RAID */ | 523 | { PCI_VDEVICE(INTEL, 0x3b25), board_ahci }, /* PCH RAID */ |
| 524 | { PCI_VDEVICE(INTEL, 0x3b29), board_ahci }, /* PCH AHCI */ | ||
| 520 | { PCI_VDEVICE(INTEL, 0x3b2b), board_ahci }, /* PCH RAID */ | 525 | { PCI_VDEVICE(INTEL, 0x3b2b), board_ahci }, /* PCH RAID */ |
| 521 | { PCI_VDEVICE(INTEL, 0x3b2c), board_ahci }, /* PCH RAID */ | 526 | { PCI_VDEVICE(INTEL, 0x3b2c), board_ahci }, /* PCH RAID */ |
| 527 | { PCI_VDEVICE(INTEL, 0x3b2f), board_ahci }, /* PCH AHCI */ | ||
| 522 | 528 | ||
| 523 | /* JMicron 360/1/3/5/6, match class to avoid IDE function */ | 529 | /* JMicron 360/1/3/5/6, match class to avoid IDE function */ |
| 524 | { PCI_VENDOR_ID_JMICRON, PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID, | 530 | { PCI_VENDOR_ID_JMICRON, PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID, |
| @@ -1659,6 +1665,7 @@ static int ahci_do_softreset(struct ata_link *link, unsigned int *class, | |||
| 1659 | int (*check_ready)(struct ata_link *link)) | 1665 | int (*check_ready)(struct ata_link *link)) |
| 1660 | { | 1666 | { |
| 1661 | struct ata_port *ap = link->ap; | 1667 | struct ata_port *ap = link->ap; |
| 1668 | struct ahci_host_priv *hpriv = ap->host->private_data; | ||
| 1662 | const char *reason = NULL; | 1669 | const char *reason = NULL; |
| 1663 | unsigned long now, msecs; | 1670 | unsigned long now, msecs; |
| 1664 | struct ata_taskfile tf; | 1671 | struct ata_taskfile tf; |
| @@ -1697,12 +1704,21 @@ static int ahci_do_softreset(struct ata_link *link, unsigned int *class, | |||
| 1697 | 1704 | ||
| 1698 | /* wait for link to become ready */ | 1705 | /* wait for link to become ready */ |
| 1699 | rc = ata_wait_after_reset(link, deadline, check_ready); | 1706 | rc = ata_wait_after_reset(link, deadline, check_ready); |
| 1700 | /* link occupied, -ENODEV too is an error */ | 1707 | if (rc == -EBUSY && hpriv->flags & AHCI_HFLAG_SRST_TOUT_IS_OFFLINE) { |
| 1701 | if (rc) { | 1708 | /* |
| 1709 | * Workaround for cases where link online status can't | ||
| 1710 | * be trusted. Treat device readiness timeout as link | ||
| 1711 | * offline. | ||
| 1712 | */ | ||
| 1713 | ata_link_printk(link, KERN_INFO, | ||
| 1714 | "device not ready, treating as offline\n"); | ||
| 1715 | *class = ATA_DEV_NONE; | ||
| 1716 | } else if (rc) { | ||
| 1717 | /* link occupied, -ENODEV too is an error */ | ||
| 1702 | reason = "device not ready"; | 1718 | reason = "device not ready"; |
| 1703 | goto fail; | 1719 | goto fail; |
| 1704 | } | 1720 | } else |
| 1705 | *class = ahci_dev_classify(ap); | 1721 | *class = ahci_dev_classify(ap); |
| 1706 | 1722 | ||
| 1707 | DPRINTK("EXIT, class=%u\n", *class); | 1723 | DPRINTK("EXIT, class=%u\n", *class); |
| 1708 | return 0; | 1724 | return 0; |
| @@ -1769,7 +1785,8 @@ static int ahci_sb600_softreset(struct ata_link *link, unsigned int *class, | |||
| 1769 | irq_sts = readl(port_mmio + PORT_IRQ_STAT); | 1785 | irq_sts = readl(port_mmio + PORT_IRQ_STAT); |
| 1770 | if (irq_sts & PORT_IRQ_BAD_PMP) { | 1786 | if (irq_sts & PORT_IRQ_BAD_PMP) { |
| 1771 | ata_link_printk(link, KERN_WARNING, | 1787 | ata_link_printk(link, KERN_WARNING, |
| 1772 | "failed due to HW bug, retry pmp=0\n"); | 1788 | "applying SB600 PMP SRST workaround " |
| 1789 | "and retrying\n"); | ||
| 1773 | rc = ahci_do_softreset(link, class, 0, deadline, | 1790 | rc = ahci_do_softreset(link, class, 0, deadline, |
| 1774 | ahci_check_ready); | 1791 | ahci_check_ready); |
| 1775 | } | 1792 | } |
| @@ -2722,6 +2739,56 @@ static bool ahci_broken_suspend(struct pci_dev *pdev) | |||
| 2722 | return !ver || strcmp(ver, dmi->driver_data) < 0; | 2739 | return !ver || strcmp(ver, dmi->driver_data) < 0; |
| 2723 | } | 2740 | } |
| 2724 | 2741 | ||
| 2742 | static bool ahci_broken_online(struct pci_dev *pdev) | ||
| 2743 | { | ||
| 2744 | #define ENCODE_BUSDEVFN(bus, slot, func) \ | ||
| 2745 | (void *)(unsigned long)(((bus) << 8) | PCI_DEVFN((slot), (func))) | ||
| 2746 | static const struct dmi_system_id sysids[] = { | ||
| 2747 | /* | ||
| 2748 | * There are several gigabyte boards which use | ||
| 2749 | * SIMG5723s configured as hardware RAID. Certain | ||
| 2750 | * 5723 firmware revisions shipped there keep the link | ||
| 2751 | * online but fail to answer properly to SRST or | ||
| 2752 | * IDENTIFY when no device is attached downstream | ||
| 2753 | * causing libata to retry quite a few times leading | ||
| 2754 | * to excessive detection delay. | ||
| 2755 | * | ||
| 2756 | * As these firmwares respond to the second reset try | ||
| 2757 | * with invalid device signature, considering unknown | ||
| 2758 | * sig as offline works around the problem acceptably. | ||
| 2759 | */ | ||
| 2760 | { | ||
| 2761 | .ident = "EP45-DQ6", | ||
| 2762 | .matches = { | ||
| 2763 | DMI_MATCH(DMI_BOARD_VENDOR, | ||
| 2764 | "Gigabyte Technology Co., Ltd."), | ||
| 2765 | DMI_MATCH(DMI_BOARD_NAME, "EP45-DQ6"), | ||
| 2766 | }, | ||
| 2767 | .driver_data = ENCODE_BUSDEVFN(0x0a, 0x00, 0), | ||
| 2768 | }, | ||
| 2769 | { | ||
| 2770 | .ident = "EP45-DS5", | ||
| 2771 | .matches = { | ||
| 2772 | DMI_MATCH(DMI_BOARD_VENDOR, | ||
| 2773 | "Gigabyte Technology Co., Ltd."), | ||
| 2774 | DMI_MATCH(DMI_BOARD_NAME, "EP45-DS5"), | ||
| 2775 | }, | ||
| 2776 | .driver_data = ENCODE_BUSDEVFN(0x03, 0x00, 0), | ||
| 2777 | }, | ||
| 2778 | { } /* terminate list */ | ||
| 2779 | }; | ||
| 2780 | #undef ENCODE_BUSDEVFN | ||
| 2781 | const struct dmi_system_id *dmi = dmi_first_match(sysids); | ||
| 2782 | unsigned int val; | ||
| 2783 | |||
| 2784 | if (!dmi) | ||
| 2785 | return false; | ||
| 2786 | |||
| 2787 | val = (unsigned long)dmi->driver_data; | ||
| 2788 | |||
| 2789 | return pdev->bus->number == (val >> 8) && pdev->devfn == (val & 0xff); | ||
| 2790 | } | ||
| 2791 | |||
| 2725 | static int ahci_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | 2792 | static int ahci_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) |
| 2726 | { | 2793 | { |
| 2727 | static int printed_version; | 2794 | static int printed_version; |
| @@ -2837,6 +2904,12 @@ static int ahci_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 2837 | "BIOS update required for suspend/resume\n"); | 2904 | "BIOS update required for suspend/resume\n"); |
| 2838 | } | 2905 | } |
| 2839 | 2906 | ||
| 2907 | if (ahci_broken_online(pdev)) { | ||
| 2908 | hpriv->flags |= AHCI_HFLAG_SRST_TOUT_IS_OFFLINE; | ||
| 2909 | dev_info(&pdev->dev, | ||
| 2910 | "online status unreliable, applying workaround\n"); | ||
| 2911 | } | ||
| 2912 | |||
| 2840 | /* CAP.NP sometimes indicate the index of the last enabled | 2913 | /* CAP.NP sometimes indicate the index of the last enabled |
| 2841 | * port, at other times, that of the last possible port, so | 2914 | * port, at other times, that of the last possible port, so |
| 2842 | * determining the maximum port number requires looking at | 2915 | * determining the maximum port number requires looking at |
diff --git a/drivers/ata/ata_piix.c b/drivers/ata/ata_piix.c index d0a14cf2bd74..56b8a3ff1286 100644 --- a/drivers/ata/ata_piix.c +++ b/drivers/ata/ata_piix.c | |||
| @@ -596,9 +596,12 @@ static const struct ich_laptop ich_laptop[] = { | |||
| 596 | { 0x27DF, 0x0005, 0x0280 }, /* ICH7 on Acer 5602WLMi */ | 596 | { 0x27DF, 0x0005, 0x0280 }, /* ICH7 on Acer 5602WLMi */ |
| 597 | { 0x27DF, 0x1025, 0x0102 }, /* ICH7 on Acer 5602aWLMi */ | 597 | { 0x27DF, 0x1025, 0x0102 }, /* ICH7 on Acer 5602aWLMi */ |
| 598 | { 0x27DF, 0x1025, 0x0110 }, /* ICH7 on Acer 3682WLMi */ | 598 | { 0x27DF, 0x1025, 0x0110 }, /* ICH7 on Acer 3682WLMi */ |
| 599 | { 0x27DF, 0x1028, 0x02b0 }, /* ICH7 on unknown Dell */ | ||
| 599 | { 0x27DF, 0x1043, 0x1267 }, /* ICH7 on Asus W5F */ | 600 | { 0x27DF, 0x1043, 0x1267 }, /* ICH7 on Asus W5F */ |
| 600 | { 0x27DF, 0x103C, 0x30A1 }, /* ICH7 on HP Compaq nc2400 */ | 601 | { 0x27DF, 0x103C, 0x30A1 }, /* ICH7 on HP Compaq nc2400 */ |
| 602 | { 0x27DF, 0x103C, 0x361a }, /* ICH7 on unkown HP */ | ||
| 601 | { 0x27DF, 0x1071, 0xD221 }, /* ICH7 on Hercules EC-900 */ | 603 | { 0x27DF, 0x1071, 0xD221 }, /* ICH7 on Hercules EC-900 */ |
| 604 | { 0x27DF, 0x152D, 0x0778 }, /* ICH7 on unknown Intel */ | ||
| 602 | { 0x24CA, 0x1025, 0x0061 }, /* ICH4 on ACER Aspire 2023WLMi */ | 605 | { 0x24CA, 0x1025, 0x0061 }, /* ICH4 on ACER Aspire 2023WLMi */ |
| 603 | { 0x24CA, 0x1025, 0x003d }, /* ICH4 on ACER TM290 */ | 606 | { 0x24CA, 0x1025, 0x003d }, /* ICH4 on ACER TM290 */ |
| 604 | { 0x266F, 0x1025, 0x0066 }, /* ICH6 on ACER Aspire 1694WLMi */ | 607 | { 0x266F, 0x1025, 0x0066 }, /* ICH6 on ACER Aspire 1694WLMi */ |
diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c index 2c6aedaef718..072ba5ea138f 100644 --- a/drivers/ata/libata-core.c +++ b/drivers/ata/libata-core.c | |||
| @@ -1515,6 +1515,7 @@ static int ata_hpa_resize(struct ata_device *dev) | |||
| 1515 | 1515 | ||
| 1516 | return rc; | 1516 | return rc; |
| 1517 | } | 1517 | } |
| 1518 | dev->n_native_sectors = native_sectors; | ||
| 1518 | 1519 | ||
| 1519 | /* nothing to do? */ | 1520 | /* nothing to do? */ |
| 1520 | if (native_sectors <= sectors || !ata_ignore_hpa) { | 1521 | if (native_sectors <= sectors || !ata_ignore_hpa) { |
| @@ -4099,6 +4100,7 @@ int ata_dev_revalidate(struct ata_device *dev, unsigned int new_class, | |||
| 4099 | unsigned int readid_flags) | 4100 | unsigned int readid_flags) |
| 4100 | { | 4101 | { |
| 4101 | u64 n_sectors = dev->n_sectors; | 4102 | u64 n_sectors = dev->n_sectors; |
| 4103 | u64 n_native_sectors = dev->n_native_sectors; | ||
| 4102 | int rc; | 4104 | int rc; |
| 4103 | 4105 | ||
| 4104 | if (!ata_dev_enabled(dev)) | 4106 | if (!ata_dev_enabled(dev)) |
| @@ -4128,16 +4130,30 @@ int ata_dev_revalidate(struct ata_device *dev, unsigned int new_class, | |||
| 4128 | /* verify n_sectors hasn't changed */ | 4130 | /* verify n_sectors hasn't changed */ |
| 4129 | if (dev->class == ATA_DEV_ATA && n_sectors && | 4131 | if (dev->class == ATA_DEV_ATA && n_sectors && |
| 4130 | dev->n_sectors != n_sectors) { | 4132 | dev->n_sectors != n_sectors) { |
| 4131 | ata_dev_printk(dev, KERN_INFO, "n_sectors mismatch " | 4133 | ata_dev_printk(dev, KERN_WARNING, "n_sectors mismatch " |
| 4132 | "%llu != %llu\n", | 4134 | "%llu != %llu\n", |
| 4133 | (unsigned long long)n_sectors, | 4135 | (unsigned long long)n_sectors, |
| 4134 | (unsigned long long)dev->n_sectors); | 4136 | (unsigned long long)dev->n_sectors); |
| 4135 | 4137 | /* | |
| 4136 | /* restore original n_sectors */ | 4138 | * Something could have caused HPA to be unlocked |
| 4137 | dev->n_sectors = n_sectors; | 4139 | * involuntarily. If n_native_sectors hasn't changed |
| 4138 | 4140 | * and the new size matches it, keep the device. | |
| 4139 | rc = -ENODEV; | 4141 | */ |
| 4140 | goto fail; | 4142 | if (dev->n_native_sectors == n_native_sectors && |
| 4143 | dev->n_sectors > n_sectors && | ||
| 4144 | dev->n_sectors == n_native_sectors) { | ||
| 4145 | ata_dev_printk(dev, KERN_WARNING, | ||
| 4146 | "new n_sectors matches native, probably " | ||
| 4147 | "late HPA unlock, continuing\n"); | ||
| 4148 | /* keep using the old n_sectors */ | ||
| 4149 | dev->n_sectors = n_sectors; | ||
| 4150 | } else { | ||
| 4151 | /* restore original n_[native]_sectors and fail */ | ||
| 4152 | dev->n_native_sectors = n_native_sectors; | ||
| 4153 | dev->n_sectors = n_sectors; | ||
| 4154 | rc = -ENODEV; | ||
| 4155 | goto fail; | ||
| 4156 | } | ||
| 4141 | } | 4157 | } |
| 4142 | 4158 | ||
| 4143 | return 0; | 4159 | return 0; |
| @@ -4286,6 +4302,9 @@ static const struct ata_blacklist_entry ata_device_blacklist [] = { | |||
| 4286 | { "WDC WD2500JD-00HBB0", "WD-WMAL71490727", ATA_HORKAGE_BROKEN_HPA }, | 4302 | { "WDC WD2500JD-00HBB0", "WD-WMAL71490727", ATA_HORKAGE_BROKEN_HPA }, |
| 4287 | { "MAXTOR 6L080L4", "A93.0500", ATA_HORKAGE_BROKEN_HPA }, | 4303 | { "MAXTOR 6L080L4", "A93.0500", ATA_HORKAGE_BROKEN_HPA }, |
| 4288 | 4304 | ||
| 4305 | /* this one allows HPA unlocking but fails IOs on the area */ | ||
| 4306 | { "OCZ-VERTEX", "1.30", ATA_HORKAGE_BROKEN_HPA }, | ||
| 4307 | |||
| 4289 | /* Devices which report 1 sector over size HPA */ | 4308 | /* Devices which report 1 sector over size HPA */ |
| 4290 | { "ST340823A", NULL, ATA_HORKAGE_HPA_SIZE, }, | 4309 | { "ST340823A", NULL, ATA_HORKAGE_HPA_SIZE, }, |
| 4291 | { "ST320413A", NULL, ATA_HORKAGE_HPA_SIZE, }, | 4310 | { "ST320413A", NULL, ATA_HORKAGE_HPA_SIZE, }, |
diff --git a/drivers/ata/libata-eh.c b/drivers/ata/libata-eh.c index 1a07c061f644..79711b64054b 100644 --- a/drivers/ata/libata-eh.c +++ b/drivers/ata/libata-eh.c | |||
| @@ -2327,7 +2327,7 @@ int ata_eh_reset(struct ata_link *link, int classify, | |||
| 2327 | struct ata_port *ap = link->ap; | 2327 | struct ata_port *ap = link->ap; |
| 2328 | struct ata_link *slave = ap->slave_link; | 2328 | struct ata_link *slave = ap->slave_link; |
| 2329 | struct ata_eh_context *ehc = &link->eh_context; | 2329 | struct ata_eh_context *ehc = &link->eh_context; |
| 2330 | struct ata_eh_context *sehc = &slave->eh_context; | 2330 | struct ata_eh_context *sehc = slave ? &slave->eh_context : NULL; |
| 2331 | unsigned int *classes = ehc->classes; | 2331 | unsigned int *classes = ehc->classes; |
| 2332 | unsigned int lflags = link->flags; | 2332 | unsigned int lflags = link->flags; |
| 2333 | int verbose = !(ehc->i.flags & ATA_EHI_QUIET); | 2333 | int verbose = !(ehc->i.flags & ATA_EHI_QUIET); |
diff --git a/drivers/ata/pata_at91.c b/drivers/ata/pata_at91.c index 8561a9f195c1..41c94b1ae493 100644 --- a/drivers/ata/pata_at91.c +++ b/drivers/ata/pata_at91.c | |||
| @@ -26,9 +26,7 @@ | |||
| 26 | #include <linux/platform_device.h> | 26 | #include <linux/platform_device.h> |
| 27 | #include <linux/ata_platform.h> | 27 | #include <linux/ata_platform.h> |
| 28 | 28 | ||
| 29 | #include <mach/at91sam9260_matrix.h> | ||
| 30 | #include <mach/at91sam9_smc.h> | 29 | #include <mach/at91sam9_smc.h> |
| 31 | #include <mach/at91sam9260.h> | ||
| 32 | #include <mach/board.h> | 30 | #include <mach/board.h> |
| 33 | #include <mach/gpio.h> | 31 | #include <mach/gpio.h> |
| 34 | 32 | ||
| @@ -44,65 +42,62 @@ struct at91_ide_info { | |||
| 44 | unsigned long mode; | 42 | unsigned long mode; |
| 45 | unsigned int cs; | 43 | unsigned int cs; |
| 46 | 44 | ||
| 45 | struct clk *mck; | ||
| 46 | |||
| 47 | void __iomem *ide_addr; | 47 | void __iomem *ide_addr; |
| 48 | void __iomem *alt_addr; | 48 | void __iomem *alt_addr; |
| 49 | }; | 49 | }; |
| 50 | 50 | ||
| 51 | const struct ata_timing initial_timing = | 51 | static const struct ata_timing initial_timing = |
| 52 | {XFER_PIO_0, 70, 290, 240, 600, 165, 150, 600, 0}; | 52 | {XFER_PIO_0, 70, 290, 240, 600, 165, 150, 600, 0}; |
| 53 | 53 | ||
| 54 | static unsigned int calc_mck_cycles(unsigned int ns, unsigned int mck_hz) | 54 | static unsigned long calc_mck_cycles(unsigned long ns, unsigned long mck_hz) |
| 55 | { | 55 | { |
| 56 | unsigned long mul; | 56 | unsigned long mul; |
| 57 | 57 | ||
| 58 | /* | 58 | /* |
| 59 | * cycles = x [nsec] * f [Hz] / 10^9 [ns in sec] = | 59 | * cycles = x [nsec] * f [Hz] / 10^9 [ns in sec] = |
| 60 | * x * (f / 1_000_000_000) = | 60 | * x * (f / 1_000_000_000) = |
| 61 | * x * ((f * 65536) / 1_000_000_000) / 65536 = | 61 | * x * ((f * 65536) / 1_000_000_000) / 65536 = |
| 62 | * x * (((f / 10_000) * 65536) / 100_000) / 65536 = | 62 | * x * (((f / 10_000) * 65536) / 100_000) / 65536 = |
| 63 | */ | 63 | */ |
| 64 | 64 | ||
| 65 | mul = (mck_hz / 10000) << 16; | 65 | mul = (mck_hz / 10000) << 16; |
| 66 | mul /= 100000; | 66 | mul /= 100000; |
| 67 | 67 | ||
| 68 | return (ns * mul + 65536) >> 16; /* rounding */ | 68 | return (ns * mul + 65536) >> 16; /* rounding */ |
| 69 | } | 69 | } |
| 70 | 70 | ||
| 71 | static void set_smc_mode(struct at91_ide_info *info) | 71 | static void set_smc_mode(struct at91_ide_info *info) |
| 72 | { | 72 | { |
| 73 | at91_sys_write(AT91_SMC_MODE(info->cs), info->mode); | 73 | at91_sys_write(AT91_SMC_MODE(info->cs), info->mode); |
| 74 | return; | 74 | return; |
| 75 | } | 75 | } |
| 76 | 76 | ||
| 77 | static void set_smc_timing(struct device *dev, | 77 | static void set_smc_timing(struct device *dev, |
| 78 | struct at91_ide_info *info, const struct ata_timing *ata) | 78 | struct at91_ide_info *info, const struct ata_timing *ata) |
| 79 | { | 79 | { |
| 80 | int read_cycle, write_cycle, active, recover; | 80 | unsigned long read_cycle, write_cycle, active, recover; |
| 81 | int nrd_setup, nrd_pulse, nrd_recover; | 81 | unsigned long nrd_setup, nrd_pulse, nrd_recover; |
| 82 | int nwe_setup, nwe_pulse; | 82 | unsigned long nwe_setup, nwe_pulse; |
| 83 | 83 | ||
| 84 | int ncs_write_setup, ncs_write_pulse; | 84 | unsigned long ncs_write_setup, ncs_write_pulse; |
| 85 | int ncs_read_setup, ncs_read_pulse; | 85 | unsigned long ncs_read_setup, ncs_read_pulse; |
| 86 | 86 | ||
| 87 | unsigned int mck_hz; | 87 | unsigned long mck_hz; |
| 88 | struct clk *mck; | ||
| 89 | 88 | ||
| 90 | read_cycle = ata->cyc8b; | 89 | read_cycle = ata->cyc8b; |
| 91 | nrd_setup = ata->setup; | 90 | nrd_setup = ata->setup; |
| 92 | nrd_pulse = ata->act8b; | 91 | nrd_pulse = ata->act8b; |
| 93 | nrd_recover = ata->rec8b; | 92 | nrd_recover = ata->rec8b; |
| 94 | 93 | ||
| 95 | mck = clk_get(NULL, "mck"); | 94 | mck_hz = clk_get_rate(info->mck); |
| 96 | BUG_ON(IS_ERR(mck)); | ||
| 97 | mck_hz = clk_get_rate(mck); | ||
| 98 | 95 | ||
| 99 | read_cycle = calc_mck_cycles(read_cycle, mck_hz); | 96 | read_cycle = calc_mck_cycles(read_cycle, mck_hz); |
| 100 | nrd_setup = calc_mck_cycles(nrd_setup, mck_hz); | 97 | nrd_setup = calc_mck_cycles(nrd_setup, mck_hz); |
| 101 | nrd_pulse = calc_mck_cycles(nrd_pulse, mck_hz); | 98 | nrd_pulse = calc_mck_cycles(nrd_pulse, mck_hz); |
| 102 | nrd_recover = calc_mck_cycles(nrd_recover, mck_hz); | 99 | nrd_recover = calc_mck_cycles(nrd_recover, mck_hz); |
| 103 | 100 | ||
| 104 | clk_put(mck); | ||
| 105 | |||
| 106 | active = nrd_setup + nrd_pulse; | 101 | active = nrd_setup + nrd_pulse; |
| 107 | recover = read_cycle - active; | 102 | recover = read_cycle - active; |
| 108 | 103 | ||
| @@ -121,13 +116,13 @@ static void set_smc_timing(struct device *dev, | |||
| 121 | ncs_write_setup = ncs_read_setup; | 116 | ncs_write_setup = ncs_read_setup; |
| 122 | ncs_write_pulse = ncs_read_pulse; | 117 | ncs_write_pulse = ncs_read_pulse; |
| 123 | 118 | ||
| 124 | dev_dbg(dev, "ATA timings: nrd_setup = %d nrd_pulse = %d nrd_cycle = %d\n", | 119 | dev_dbg(dev, "ATA timings: nrd_setup = %lu nrd_pulse = %lu nrd_cycle = %lu\n", |
| 125 | nrd_setup, nrd_pulse, read_cycle); | 120 | nrd_setup, nrd_pulse, read_cycle); |
| 126 | dev_dbg(dev, "ATA timings: nwe_setup = %d nwe_pulse = %d nwe_cycle = %d\n", | 121 | dev_dbg(dev, "ATA timings: nwe_setup = %lu nwe_pulse = %lu nwe_cycle = %lu\n", |
| 127 | nwe_setup, nwe_pulse, write_cycle); | 122 | nwe_setup, nwe_pulse, write_cycle); |
| 128 | dev_dbg(dev, "ATA timings: ncs_read_setup = %d ncs_read_pulse = %d\n", | 123 | dev_dbg(dev, "ATA timings: ncs_read_setup = %lu ncs_read_pulse = %lu\n", |
| 129 | ncs_read_setup, ncs_read_pulse); | 124 | ncs_read_setup, ncs_read_pulse); |
| 130 | dev_dbg(dev, "ATA timings: ncs_write_setup = %d ncs_write_pulse = %d\n", | 125 | dev_dbg(dev, "ATA timings: ncs_write_setup = %lu ncs_write_pulse = %lu\n", |
| 131 | ncs_write_setup, ncs_write_pulse); | 126 | ncs_write_setup, ncs_write_pulse); |
| 132 | 127 | ||
| 133 | at91_sys_write(AT91_SMC_SETUP(info->cs), | 128 | at91_sys_write(AT91_SMC_SETUP(info->cs), |
| @@ -217,6 +212,7 @@ static int __devinit pata_at91_probe(struct platform_device *pdev) | |||
| 217 | struct resource *mem_res; | 212 | struct resource *mem_res; |
| 218 | struct ata_host *host; | 213 | struct ata_host *host; |
| 219 | struct ata_port *ap; | 214 | struct ata_port *ap; |
| 215 | |||
| 220 | int irq_flags = 0; | 216 | int irq_flags = 0; |
| 221 | int irq = 0; | 217 | int irq = 0; |
| 222 | int ret; | 218 | int ret; |
| @@ -254,13 +250,20 @@ static int __devinit pata_at91_probe(struct platform_device *pdev) | |||
| 254 | ata_port_desc(ap, "no IRQ, using PIO polling"); | 250 | ata_port_desc(ap, "no IRQ, using PIO polling"); |
| 255 | } | 251 | } |
| 256 | 252 | ||
| 257 | info = kzalloc(sizeof(*info), GFP_KERNEL); | 253 | info = devm_kzalloc(dev, sizeof(*info), GFP_KERNEL); |
| 258 | 254 | ||
| 259 | if (!info) { | 255 | if (!info) { |
| 260 | dev_err(dev, "failed to allocate memory for private data\n"); | 256 | dev_err(dev, "failed to allocate memory for private data\n"); |
| 261 | return -ENOMEM; | 257 | return -ENOMEM; |
| 262 | } | 258 | } |
| 263 | 259 | ||
| 260 | info->mck = clk_get(NULL, "mck"); | ||
| 261 | |||
| 262 | if (IS_ERR(info->mck)) { | ||
| 263 | dev_err(dev, "failed to get access to mck clock\n"); | ||
| 264 | return -ENODEV; | ||
| 265 | } | ||
| 266 | |||
| 264 | info->cs = board->chipselect; | 267 | info->cs = board->chipselect; |
| 265 | info->mode = AT91_SMC_READMODE | AT91_SMC_WRITEMODE | | 268 | info->mode = AT91_SMC_READMODE | AT91_SMC_WRITEMODE | |
| 266 | AT91_SMC_EXNWMODE_READY | AT91_SMC_BAT_SELECT | | 269 | AT91_SMC_EXNWMODE_READY | AT91_SMC_BAT_SELECT | |
| @@ -272,7 +275,7 @@ static int __devinit pata_at91_probe(struct platform_device *pdev) | |||
| 272 | if (!info->ide_addr) { | 275 | if (!info->ide_addr) { |
| 273 | dev_err(dev, "failed to map IO base\n"); | 276 | dev_err(dev, "failed to map IO base\n"); |
| 274 | ret = -ENOMEM; | 277 | ret = -ENOMEM; |
| 275 | goto err_ide_ioremap; | 278 | goto err_put; |
| 276 | } | 279 | } |
| 277 | 280 | ||
| 278 | info->alt_addr = devm_ioremap(dev, | 281 | info->alt_addr = devm_ioremap(dev, |
| @@ -281,7 +284,7 @@ static int __devinit pata_at91_probe(struct platform_device *pdev) | |||
| 281 | if (!info->alt_addr) { | 284 | if (!info->alt_addr) { |
| 282 | dev_err(dev, "failed to map CTL base\n"); | 285 | dev_err(dev, "failed to map CTL base\n"); |
| 283 | ret = -ENOMEM; | 286 | ret = -ENOMEM; |
| 284 | goto err_alt_ioremap; | 287 | goto err_put; |
| 285 | } | 288 | } |
| 286 | 289 | ||
| 287 | ap->ioaddr.cmd_addr = info->ide_addr; | 290 | ap->ioaddr.cmd_addr = info->ide_addr; |
| @@ -300,12 +303,8 @@ static int __devinit pata_at91_probe(struct platform_device *pdev) | |||
| 300 | irq ? ata_sff_interrupt : NULL, | 303 | irq ? ata_sff_interrupt : NULL, |
| 301 | irq_flags, &pata_at91_sht); | 304 | irq_flags, &pata_at91_sht); |
| 302 | 305 | ||
| 303 | err_alt_ioremap: | 306 | err_put: |
| 304 | devm_iounmap(dev, info->ide_addr); | 307 | clk_put(info->mck); |
| 305 | |||
| 306 | err_ide_ioremap: | ||
| 307 | kfree(info); | ||
| 308 | |||
| 309 | return ret; | 308 | return ret; |
| 310 | } | 309 | } |
| 311 | 310 | ||
| @@ -313,7 +312,6 @@ static int __devexit pata_at91_remove(struct platform_device *pdev) | |||
| 313 | { | 312 | { |
| 314 | struct ata_host *host = dev_get_drvdata(&pdev->dev); | 313 | struct ata_host *host = dev_get_drvdata(&pdev->dev); |
| 315 | struct at91_ide_info *info; | 314 | struct at91_ide_info *info; |
| 316 | struct device *dev = &pdev->dev; | ||
| 317 | 315 | ||
| 318 | if (!host) | 316 | if (!host) |
| 319 | return 0; | 317 | return 0; |
| @@ -324,10 +322,8 @@ static int __devexit pata_at91_remove(struct platform_device *pdev) | |||
| 324 | if (!info) | 322 | if (!info) |
| 325 | return 0; | 323 | return 0; |
| 326 | 324 | ||
| 327 | devm_iounmap(dev, info->ide_addr); | 325 | clk_put(info->mck); |
| 328 | devm_iounmap(dev, info->alt_addr); | ||
| 329 | 326 | ||
| 330 | kfree(info); | ||
| 331 | return 0; | 327 | return 0; |
| 332 | } | 328 | } |
| 333 | 329 | ||
diff --git a/drivers/ata/pata_atiixp.c b/drivers/ata/pata_atiixp.c index bec0b8ade66d..45915566e4e9 100644 --- a/drivers/ata/pata_atiixp.c +++ b/drivers/ata/pata_atiixp.c | |||
| @@ -1,6 +1,7 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * pata_atiixp.c - ATI PATA for new ATA layer | 2 | * pata_atiixp.c - ATI PATA for new ATA layer |
| 3 | * (C) 2005 Red Hat Inc | 3 | * (C) 2005 Red Hat Inc |
| 4 | * (C) 2009 Bartlomiej Zolnierkiewicz | ||
| 4 | * | 5 | * |
| 5 | * Based on | 6 | * Based on |
| 6 | * | 7 | * |
| @@ -61,20 +62,19 @@ static void atiixp_set_pio_timing(struct ata_port *ap, struct ata_device *adev, | |||
| 61 | 62 | ||
| 62 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 63 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
| 63 | int dn = 2 * ap->port_no + adev->devno; | 64 | int dn = 2 * ap->port_no + adev->devno; |
| 64 | |||
| 65 | /* Check this is correct - the order is odd in both drivers */ | ||
| 66 | int timing_shift = (16 * ap->port_no) + 8 * (adev->devno ^ 1); | 65 | int timing_shift = (16 * ap->port_no) + 8 * (adev->devno ^ 1); |
| 67 | u16 pio_mode_data, pio_timing_data; | 66 | u32 pio_timing_data; |
| 67 | u16 pio_mode_data; | ||
| 68 | 68 | ||
| 69 | pci_read_config_word(pdev, ATIIXP_IDE_PIO_MODE, &pio_mode_data); | 69 | pci_read_config_word(pdev, ATIIXP_IDE_PIO_MODE, &pio_mode_data); |
| 70 | pio_mode_data &= ~(0x7 << (4 * dn)); | 70 | pio_mode_data &= ~(0x7 << (4 * dn)); |
| 71 | pio_mode_data |= pio << (4 * dn); | 71 | pio_mode_data |= pio << (4 * dn); |
| 72 | pci_write_config_word(pdev, ATIIXP_IDE_PIO_MODE, pio_mode_data); | 72 | pci_write_config_word(pdev, ATIIXP_IDE_PIO_MODE, pio_mode_data); |
| 73 | 73 | ||
| 74 | pci_read_config_word(pdev, ATIIXP_IDE_PIO_TIMING, &pio_timing_data); | 74 | pci_read_config_dword(pdev, ATIIXP_IDE_PIO_TIMING, &pio_timing_data); |
| 75 | pio_timing_data &= ~(0xFF << timing_shift); | 75 | pio_timing_data &= ~(0xFF << timing_shift); |
| 76 | pio_timing_data |= (pio_timings[pio] << timing_shift); | 76 | pio_timing_data |= (pio_timings[pio] << timing_shift); |
| 77 | pci_write_config_word(pdev, ATIIXP_IDE_PIO_TIMING, pio_timing_data); | 77 | pci_write_config_dword(pdev, ATIIXP_IDE_PIO_TIMING, pio_timing_data); |
| 78 | } | 78 | } |
| 79 | 79 | ||
| 80 | /** | 80 | /** |
| @@ -119,16 +119,17 @@ static void atiixp_set_dmamode(struct ata_port *ap, struct ata_device *adev) | |||
| 119 | udma_mode_data |= dma << (4 * dn); | 119 | udma_mode_data |= dma << (4 * dn); |
| 120 | pci_write_config_word(pdev, ATIIXP_IDE_UDMA_MODE, udma_mode_data); | 120 | pci_write_config_word(pdev, ATIIXP_IDE_UDMA_MODE, udma_mode_data); |
| 121 | } else { | 121 | } else { |
| 122 | u16 mwdma_timing_data; | ||
| 123 | /* Check this is correct - the order is odd in both drivers */ | ||
| 124 | int timing_shift = (16 * ap->port_no) + 8 * (adev->devno ^ 1); | 122 | int timing_shift = (16 * ap->port_no) + 8 * (adev->devno ^ 1); |
| 123 | u32 mwdma_timing_data; | ||
| 125 | 124 | ||
| 126 | dma -= XFER_MW_DMA_0; | 125 | dma -= XFER_MW_DMA_0; |
| 127 | 126 | ||
| 128 | pci_read_config_word(pdev, ATIIXP_IDE_MWDMA_TIMING, &mwdma_timing_data); | 127 | pci_read_config_dword(pdev, ATIIXP_IDE_MWDMA_TIMING, |
| 128 | &mwdma_timing_data); | ||
| 129 | mwdma_timing_data &= ~(0xFF << timing_shift); | 129 | mwdma_timing_data &= ~(0xFF << timing_shift); |
| 130 | mwdma_timing_data |= (mwdma_timings[dma] << timing_shift); | 130 | mwdma_timing_data |= (mwdma_timings[dma] << timing_shift); |
| 131 | pci_write_config_word(pdev, ATIIXP_IDE_MWDMA_TIMING, mwdma_timing_data); | 131 | pci_write_config_dword(pdev, ATIIXP_IDE_MWDMA_TIMING, |
| 132 | mwdma_timing_data); | ||
| 132 | } | 133 | } |
| 133 | /* | 134 | /* |
| 134 | * We must now look at the PIO mode situation. We may need to | 135 | * We must now look at the PIO mode situation. We may need to |
diff --git a/drivers/ata/pata_octeon_cf.c b/drivers/ata/pata_octeon_cf.c index 8d9343accf3c..abdd19fe990a 100644 --- a/drivers/ata/pata_octeon_cf.c +++ b/drivers/ata/pata_octeon_cf.c | |||
| @@ -653,7 +653,8 @@ static irqreturn_t octeon_cf_interrupt(int irq, void *dev_instance) | |||
| 653 | 653 | ||
| 654 | ap = host->ports[i]; | 654 | ap = host->ports[i]; |
| 655 | ocd = ap->dev->platform_data; | 655 | ocd = ap->dev->platform_data; |
| 656 | if (!ap || (ap->flags & ATA_FLAG_DISABLED)) | 656 | |
| 657 | if (ap->flags & ATA_FLAG_DISABLED) | ||
| 657 | continue; | 658 | continue; |
| 658 | 659 | ||
| 659 | ocd = ap->dev->platform_data; | 660 | ocd = ap->dev->platform_data; |
diff --git a/drivers/ata/pata_pcmcia.c b/drivers/ata/pata_pcmcia.c index f4d009ed50ac..dc99e26f8e5b 100644 --- a/drivers/ata/pata_pcmcia.c +++ b/drivers/ata/pata_pcmcia.c | |||
| @@ -411,6 +411,7 @@ static struct pcmcia_device_id pcmcia_devices[] = { | |||
| 411 | PCMCIA_DEVICE_PROD_ID123("PCMCIA", "IDE CARD", "F1", 0x281f1c5d, 0x1907960c, 0xf7fde8b9), | 411 | PCMCIA_DEVICE_PROD_ID123("PCMCIA", "IDE CARD", "F1", 0x281f1c5d, 0x1907960c, 0xf7fde8b9), |
| 412 | PCMCIA_DEVICE_PROD_ID12("ARGOSY", "CD-ROM", 0x78f308dc, 0x66536591), | 412 | PCMCIA_DEVICE_PROD_ID12("ARGOSY", "CD-ROM", 0x78f308dc, 0x66536591), |
| 413 | PCMCIA_DEVICE_PROD_ID12("ARGOSY", "PnPIDE", 0x78f308dc, 0x0c694728), | 413 | PCMCIA_DEVICE_PROD_ID12("ARGOSY", "PnPIDE", 0x78f308dc, 0x0c694728), |
| 414 | PCMCIA_DEVICE_PROD_ID12("CNF ", "CD-ROM", 0x46d7db81, 0x66536591), | ||
| 414 | PCMCIA_DEVICE_PROD_ID12("CNF CD-M", "CD-ROM", 0x7d93b852, 0x66536591), | 415 | PCMCIA_DEVICE_PROD_ID12("CNF CD-M", "CD-ROM", 0x7d93b852, 0x66536591), |
| 415 | PCMCIA_DEVICE_PROD_ID12("Creative Technology Ltd.", "PCMCIA CD-ROM Interface Card", 0xff8c8a45, 0xfe8020c4), | 416 | PCMCIA_DEVICE_PROD_ID12("Creative Technology Ltd.", "PCMCIA CD-ROM Interface Card", 0xff8c8a45, 0xfe8020c4), |
| 416 | PCMCIA_DEVICE_PROD_ID12("Digital Equipment Corporation.", "Digital Mobile Media CD-ROM", 0x17692a66, 0xef1dcbde), | 417 | PCMCIA_DEVICE_PROD_ID12("Digital Equipment Corporation.", "Digital Mobile Media CD-ROM", 0x17692a66, 0xef1dcbde), |
diff --git a/drivers/ata/sata_mv.c b/drivers/ata/sata_mv.c index 23714aefb825..c19417e02208 100644 --- a/drivers/ata/sata_mv.c +++ b/drivers/ata/sata_mv.c | |||
| @@ -2514,7 +2514,7 @@ static void mv_unexpected_intr(struct ata_port *ap, int edma_was_enabled) | |||
| 2514 | char *when = "idle"; | 2514 | char *when = "idle"; |
| 2515 | 2515 | ||
| 2516 | ata_ehi_clear_desc(ehi); | 2516 | ata_ehi_clear_desc(ehi); |
| 2517 | if (!ap || (ap->flags & ATA_FLAG_DISABLED)) { | 2517 | if (ap->flags & ATA_FLAG_DISABLED) { |
| 2518 | when = "disabled"; | 2518 | when = "disabled"; |
| 2519 | } else if (edma_was_enabled) { | 2519 | } else if (edma_was_enabled) { |
| 2520 | when = "EDMA enabled"; | 2520 | when = "EDMA enabled"; |
diff --git a/drivers/ata/sata_nv.c b/drivers/ata/sata_nv.c index b2d11f300c39..86a40582999c 100644 --- a/drivers/ata/sata_nv.c +++ b/drivers/ata/sata_nv.c | |||
| @@ -602,6 +602,7 @@ MODULE_VERSION(DRV_VERSION); | |||
| 602 | 602 | ||
| 603 | static int adma_enabled; | 603 | static int adma_enabled; |
| 604 | static int swncq_enabled = 1; | 604 | static int swncq_enabled = 1; |
| 605 | static int msi_enabled; | ||
| 605 | 606 | ||
| 606 | static void nv_adma_register_mode(struct ata_port *ap) | 607 | static void nv_adma_register_mode(struct ata_port *ap) |
| 607 | { | 608 | { |
| @@ -2459,6 +2460,11 @@ static int nv_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 2459 | } else if (type == SWNCQ) | 2460 | } else if (type == SWNCQ) |
| 2460 | nv_swncq_host_init(host); | 2461 | nv_swncq_host_init(host); |
| 2461 | 2462 | ||
| 2463 | if (msi_enabled) { | ||
| 2464 | dev_printk(KERN_NOTICE, &pdev->dev, "Using MSI\n"); | ||
| 2465 | pci_enable_msi(pdev); | ||
| 2466 | } | ||
| 2467 | |||
| 2462 | pci_set_master(pdev); | 2468 | pci_set_master(pdev); |
| 2463 | return ata_host_activate(host, pdev->irq, ipriv->irq_handler, | 2469 | return ata_host_activate(host, pdev->irq, ipriv->irq_handler, |
| 2464 | IRQF_SHARED, ipriv->sht); | 2470 | IRQF_SHARED, ipriv->sht); |
| @@ -2558,4 +2564,6 @@ module_param_named(adma, adma_enabled, bool, 0444); | |||
| 2558 | MODULE_PARM_DESC(adma, "Enable use of ADMA (Default: false)"); | 2564 | MODULE_PARM_DESC(adma, "Enable use of ADMA (Default: false)"); |
| 2559 | module_param_named(swncq, swncq_enabled, bool, 0444); | 2565 | module_param_named(swncq, swncq_enabled, bool, 0444); |
| 2560 | MODULE_PARM_DESC(swncq, "Enable use of SWNCQ (Default: true)"); | 2566 | MODULE_PARM_DESC(swncq, "Enable use of SWNCQ (Default: true)"); |
| 2567 | module_param_named(msi, msi_enabled, bool, 0444); | ||
| 2568 | MODULE_PARM_DESC(msi, "Enable use of MSI (Default: false)"); | ||
| 2561 | 2569 | ||
diff --git a/drivers/ata/sata_sil.c b/drivers/ata/sata_sil.c index 030ec079b184..35bd5cc7f285 100644 --- a/drivers/ata/sata_sil.c +++ b/drivers/ata/sata_sil.c | |||
| @@ -532,7 +532,7 @@ static irqreturn_t sil_interrupt(int irq, void *dev_instance) | |||
| 532 | struct ata_port *ap = host->ports[i]; | 532 | struct ata_port *ap = host->ports[i]; |
| 533 | u32 bmdma2 = readl(mmio_base + sil_port[ap->port_no].bmdma2); | 533 | u32 bmdma2 = readl(mmio_base + sil_port[ap->port_no].bmdma2); |
| 534 | 534 | ||
| 535 | if (unlikely(!ap || ap->flags & ATA_FLAG_DISABLED)) | 535 | if (unlikely(ap->flags & ATA_FLAG_DISABLED)) |
| 536 | continue; | 536 | continue; |
| 537 | 537 | ||
| 538 | /* turn off SATA_IRQ if not supported */ | 538 | /* turn off SATA_IRQ if not supported */ |
diff --git a/drivers/base/firmware_class.c b/drivers/base/firmware_class.c index f285f441fab9..7376367bcb80 100644 --- a/drivers/base/firmware_class.c +++ b/drivers/base/firmware_class.c | |||
| @@ -180,7 +180,6 @@ static ssize_t firmware_loading_store(struct device *dev, | |||
| 180 | goto err; | 180 | goto err; |
| 181 | } | 181 | } |
| 182 | /* Pages will be freed by vfree() */ | 182 | /* Pages will be freed by vfree() */ |
| 183 | fw_priv->pages = NULL; | ||
| 184 | fw_priv->page_array_size = 0; | 183 | fw_priv->page_array_size = 0; |
| 185 | fw_priv->nr_pages = 0; | 184 | fw_priv->nr_pages = 0; |
| 186 | complete(&fw_priv->completion); | 185 | complete(&fw_priv->completion); |
diff --git a/drivers/base/platform.c b/drivers/base/platform.c index 81cb01bfc356..456594bd97bc 100644 --- a/drivers/base/platform.c +++ b/drivers/base/platform.c | |||
| @@ -483,9 +483,6 @@ int platform_driver_register(struct platform_driver *drv) | |||
| 483 | drv->driver.remove = platform_drv_remove; | 483 | drv->driver.remove = platform_drv_remove; |
| 484 | if (drv->shutdown) | 484 | if (drv->shutdown) |
| 485 | drv->driver.shutdown = platform_drv_shutdown; | 485 | drv->driver.shutdown = platform_drv_shutdown; |
| 486 | if (drv->suspend || drv->resume) | ||
| 487 | pr_warning("Platform driver '%s' needs updating - please use " | ||
| 488 | "dev_pm_ops\n", drv->driver.name); | ||
| 489 | 486 | ||
| 490 | return driver_register(&drv->driver); | 487 | return driver_register(&drv->driver); |
| 491 | } | 488 | } |
diff --git a/drivers/base/sys.c b/drivers/base/sys.c index 79a9ae5238ac..0d903909af7e 100644 --- a/drivers/base/sys.c +++ b/drivers/base/sys.c | |||
| @@ -275,9 +275,9 @@ int sysdev_register(struct sys_device *sysdev) | |||
| 275 | drv->add(sysdev); | 275 | drv->add(sysdev); |
| 276 | } | 276 | } |
| 277 | mutex_unlock(&sysdev_drivers_lock); | 277 | mutex_unlock(&sysdev_drivers_lock); |
| 278 | kobject_uevent(&sysdev->kobj, KOBJ_ADD); | ||
| 278 | } | 279 | } |
| 279 | 280 | ||
| 280 | kobject_uevent(&sysdev->kobj, KOBJ_ADD); | ||
| 281 | return error; | 281 | return error; |
| 282 | } | 282 | } |
| 283 | 283 | ||
diff --git a/drivers/block/ataflop.c b/drivers/block/ataflop.c index f5e7180d7f47..3ff02941b3dd 100644 --- a/drivers/block/ataflop.c +++ b/drivers/block/ataflop.c | |||
| @@ -1627,7 +1627,7 @@ static int fd_ioctl(struct block_device *bdev, fmode_t mode, | |||
| 1627 | drive, dtp->blocks, dtp->spt, dtp->stretch); | 1627 | drive, dtp->blocks, dtp->spt, dtp->stretch); |
| 1628 | 1628 | ||
| 1629 | /* sanity check */ | 1629 | /* sanity check */ |
| 1630 | if (!dtp || setprm.track != dtp->blocks/dtp->spt/2 || | 1630 | if (setprm.track != dtp->blocks/dtp->spt/2 || |
| 1631 | setprm.head != 2) { | 1631 | setprm.head != 2) { |
| 1632 | redo_fd_request(); | 1632 | redo_fd_request(); |
| 1633 | return -EINVAL; | 1633 | return -EINVAL; |
diff --git a/drivers/block/mg_disk.c b/drivers/block/mg_disk.c index f703f5478246..6d7fbaa92248 100644 --- a/drivers/block/mg_disk.c +++ b/drivers/block/mg_disk.c | |||
| @@ -36,7 +36,6 @@ | |||
| 36 | 36 | ||
| 37 | /* Register offsets */ | 37 | /* Register offsets */ |
| 38 | #define MG_BUFF_OFFSET 0x8000 | 38 | #define MG_BUFF_OFFSET 0x8000 |
| 39 | #define MG_STORAGE_BUFFER_SIZE 0x200 | ||
| 40 | #define MG_REG_OFFSET 0xC000 | 39 | #define MG_REG_OFFSET 0xC000 |
| 41 | #define MG_REG_FEATURE (MG_REG_OFFSET + 2) /* write case */ | 40 | #define MG_REG_FEATURE (MG_REG_OFFSET + 2) /* write case */ |
| 42 | #define MG_REG_ERROR (MG_REG_OFFSET + 2) /* read case */ | 41 | #define MG_REG_ERROR (MG_REG_OFFSET + 2) /* read case */ |
| @@ -219,6 +218,16 @@ static unsigned int mg_wait(struct mg_host *host, u32 expect, u32 msec) | |||
| 219 | host->error = MG_ERR_NONE; | 218 | host->error = MG_ERR_NONE; |
| 220 | expire = jiffies + msecs_to_jiffies(msec); | 219 | expire = jiffies + msecs_to_jiffies(msec); |
| 221 | 220 | ||
| 221 | /* These 2 times dummy status read prevents reading invalid | ||
| 222 | * status. A very little time (3 times of mflash operating clk) | ||
| 223 | * is required for busy bit is set. Use dummy read instead of | ||
| 224 | * busy wait, because mflash's PLL is machine dependent. | ||
| 225 | */ | ||
| 226 | if (prv_data->use_polling) { | ||
| 227 | status = inb((unsigned long)host->dev_base + MG_REG_STATUS); | ||
| 228 | status = inb((unsigned long)host->dev_base + MG_REG_STATUS); | ||
| 229 | } | ||
| 230 | |||
| 222 | status = inb((unsigned long)host->dev_base + MG_REG_STATUS); | 231 | status = inb((unsigned long)host->dev_base + MG_REG_STATUS); |
| 223 | 232 | ||
| 224 | do { | 233 | do { |
| @@ -245,8 +254,6 @@ static unsigned int mg_wait(struct mg_host *host, u32 expect, u32 msec) | |||
| 245 | mg_dump_status("not ready", status, host); | 254 | mg_dump_status("not ready", status, host); |
| 246 | return MG_ERR_INV_STAT; | 255 | return MG_ERR_INV_STAT; |
| 247 | } | 256 | } |
| 248 | if (prv_data->use_polling) | ||
| 249 | msleep(1); | ||
| 250 | 257 | ||
| 251 | status = inb((unsigned long)host->dev_base + MG_REG_STATUS); | 258 | status = inb((unsigned long)host->dev_base + MG_REG_STATUS); |
| 252 | } while (time_before(cur_jiffies, expire)); | 259 | } while (time_before(cur_jiffies, expire)); |
| @@ -469,9 +476,18 @@ static unsigned int mg_out(struct mg_host *host, | |||
| 469 | return MG_ERR_NONE; | 476 | return MG_ERR_NONE; |
| 470 | } | 477 | } |
| 471 | 478 | ||
| 479 | static void mg_read_one(struct mg_host *host, struct request *req) | ||
| 480 | { | ||
| 481 | u16 *buff = (u16 *)req->buffer; | ||
| 482 | u32 i; | ||
| 483 | |||
| 484 | for (i = 0; i < MG_SECTOR_SIZE >> 1; i++) | ||
| 485 | *buff++ = inw((unsigned long)host->dev_base + MG_BUFF_OFFSET + | ||
| 486 | (i << 1)); | ||
| 487 | } | ||
| 488 | |||
| 472 | static void mg_read(struct request *req) | 489 | static void mg_read(struct request *req) |
| 473 | { | 490 | { |
| 474 | u32 j; | ||
| 475 | struct mg_host *host = req->rq_disk->private_data; | 491 | struct mg_host *host = req->rq_disk->private_data; |
| 476 | 492 | ||
| 477 | if (mg_out(host, blk_rq_pos(req), blk_rq_sectors(req), | 493 | if (mg_out(host, blk_rq_pos(req), blk_rq_sectors(req), |
| @@ -482,49 +498,65 @@ static void mg_read(struct request *req) | |||
| 482 | blk_rq_sectors(req), blk_rq_pos(req), req->buffer); | 498 | blk_rq_sectors(req), blk_rq_pos(req), req->buffer); |
| 483 | 499 | ||
| 484 | do { | 500 | do { |
| 485 | u16 *buff = (u16 *)req->buffer; | ||
| 486 | |||
| 487 | if (mg_wait(host, ATA_DRQ, | 501 | if (mg_wait(host, ATA_DRQ, |
| 488 | MG_TMAX_WAIT_RD_DRQ) != MG_ERR_NONE) { | 502 | MG_TMAX_WAIT_RD_DRQ) != MG_ERR_NONE) { |
| 489 | mg_bad_rw_intr(host); | 503 | mg_bad_rw_intr(host); |
| 490 | return; | 504 | return; |
| 491 | } | 505 | } |
| 492 | for (j = 0; j < MG_SECTOR_SIZE >> 1; j++) | 506 | |
| 493 | *buff++ = inw((unsigned long)host->dev_base + | 507 | mg_read_one(host, req); |
| 494 | MG_BUFF_OFFSET + (j << 1)); | ||
| 495 | 508 | ||
| 496 | outb(MG_CMD_RD_CONF, (unsigned long)host->dev_base + | 509 | outb(MG_CMD_RD_CONF, (unsigned long)host->dev_base + |
| 497 | MG_REG_COMMAND); | 510 | MG_REG_COMMAND); |
| 498 | } while (mg_end_request(host, 0, MG_SECTOR_SIZE)); | 511 | } while (mg_end_request(host, 0, MG_SECTOR_SIZE)); |
| 499 | } | 512 | } |
| 500 | 513 | ||
| 514 | static void mg_write_one(struct mg_host *host, struct request *req) | ||
| 515 | { | ||
| 516 | u16 *buff = (u16 *)req->buffer; | ||
| 517 | u32 i; | ||
| 518 | |||
| 519 | for (i = 0; i < MG_SECTOR_SIZE >> 1; i++) | ||
| 520 | outw(*buff++, (unsigned long)host->dev_base + MG_BUFF_OFFSET + | ||
| 521 | (i << 1)); | ||
| 522 | } | ||
| 523 | |||
| 501 | static void mg_write(struct request *req) | 524 | static void mg_write(struct request *req) |
| 502 | { | 525 | { |
| 503 | u32 j; | ||
| 504 | struct mg_host *host = req->rq_disk->private_data; | 526 | struct mg_host *host = req->rq_disk->private_data; |
| 527 | unsigned int rem = blk_rq_sectors(req); | ||
| 505 | 528 | ||
| 506 | if (mg_out(host, blk_rq_pos(req), blk_rq_sectors(req), | 529 | if (mg_out(host, blk_rq_pos(req), rem, |
| 507 | MG_CMD_WR, NULL) != MG_ERR_NONE) { | 530 | MG_CMD_WR, NULL) != MG_ERR_NONE) { |
| 508 | mg_bad_rw_intr(host); | 531 | mg_bad_rw_intr(host); |
| 509 | return; | 532 | return; |
| 510 | } | 533 | } |
| 511 | 534 | ||
| 512 | MG_DBG("requested %d sects (from %ld), buffer=0x%p\n", | 535 | MG_DBG("requested %d sects (from %ld), buffer=0x%p\n", |
| 513 | blk_rq_sectors(req), blk_rq_pos(req), req->buffer); | 536 | rem, blk_rq_pos(req), req->buffer); |
| 537 | |||
| 538 | if (mg_wait(host, ATA_DRQ, | ||
| 539 | MG_TMAX_WAIT_WR_DRQ) != MG_ERR_NONE) { | ||
| 540 | mg_bad_rw_intr(host); | ||
| 541 | return; | ||
| 542 | } | ||
| 514 | 543 | ||
| 515 | do { | 544 | do { |
| 516 | u16 *buff = (u16 *)req->buffer; | 545 | mg_write_one(host, req); |
| 517 | 546 | ||
| 518 | if (mg_wait(host, ATA_DRQ, MG_TMAX_WAIT_WR_DRQ) != MG_ERR_NONE) { | 547 | outb(MG_CMD_WR_CONF, (unsigned long)host->dev_base + |
| 548 | MG_REG_COMMAND); | ||
| 549 | |||
| 550 | rem--; | ||
| 551 | if (rem > 1 && mg_wait(host, ATA_DRQ, | ||
| 552 | MG_TMAX_WAIT_WR_DRQ) != MG_ERR_NONE) { | ||
| 553 | mg_bad_rw_intr(host); | ||
| 554 | return; | ||
| 555 | } else if (mg_wait(host, MG_STAT_READY, | ||
| 556 | MG_TMAX_WAIT_WR_DRQ) != MG_ERR_NONE) { | ||
| 519 | mg_bad_rw_intr(host); | 557 | mg_bad_rw_intr(host); |
| 520 | return; | 558 | return; |
| 521 | } | 559 | } |
| 522 | for (j = 0; j < MG_SECTOR_SIZE >> 1; j++) | ||
| 523 | outw(*buff++, (unsigned long)host->dev_base + | ||
| 524 | MG_BUFF_OFFSET + (j << 1)); | ||
| 525 | |||
| 526 | outb(MG_CMD_WR_CONF, (unsigned long)host->dev_base + | ||
| 527 | MG_REG_COMMAND); | ||
| 528 | } while (mg_end_request(host, 0, MG_SECTOR_SIZE)); | 560 | } while (mg_end_request(host, 0, MG_SECTOR_SIZE)); |
| 529 | } | 561 | } |
| 530 | 562 | ||
| @@ -532,7 +564,6 @@ static void mg_read_intr(struct mg_host *host) | |||
| 532 | { | 564 | { |
| 533 | struct request *req = host->req; | 565 | struct request *req = host->req; |
| 534 | u32 i; | 566 | u32 i; |
| 535 | u16 *buff; | ||
| 536 | 567 | ||
| 537 | /* check status */ | 568 | /* check status */ |
| 538 | do { | 569 | do { |
| @@ -550,13 +581,7 @@ static void mg_read_intr(struct mg_host *host) | |||
| 550 | return; | 581 | return; |
| 551 | 582 | ||
| 552 | ok_to_read: | 583 | ok_to_read: |
| 553 | /* get current segment of request */ | 584 | mg_read_one(host, req); |
| 554 | buff = (u16 *)req->buffer; | ||
| 555 | |||
| 556 | /* read 1 sector */ | ||
| 557 | for (i = 0; i < MG_SECTOR_SIZE >> 1; i++) | ||
| 558 | *buff++ = inw((unsigned long)host->dev_base + MG_BUFF_OFFSET + | ||
| 559 | (i << 1)); | ||
| 560 | 585 | ||
| 561 | MG_DBG("sector %ld, remaining=%ld, buffer=0x%p\n", | 586 | MG_DBG("sector %ld, remaining=%ld, buffer=0x%p\n", |
| 562 | blk_rq_pos(req), blk_rq_sectors(req) - 1, req->buffer); | 587 | blk_rq_pos(req), blk_rq_sectors(req) - 1, req->buffer); |
| @@ -575,8 +600,7 @@ ok_to_read: | |||
| 575 | static void mg_write_intr(struct mg_host *host) | 600 | static void mg_write_intr(struct mg_host *host) |
| 576 | { | 601 | { |
| 577 | struct request *req = host->req; | 602 | struct request *req = host->req; |
| 578 | u32 i, j; | 603 | u32 i; |
| 579 | u16 *buff; | ||
| 580 | bool rem; | 604 | bool rem; |
| 581 | 605 | ||
| 582 | /* check status */ | 606 | /* check status */ |
| @@ -597,12 +621,7 @@ static void mg_write_intr(struct mg_host *host) | |||
| 597 | ok_to_write: | 621 | ok_to_write: |
| 598 | if ((rem = mg_end_request(host, 0, MG_SECTOR_SIZE))) { | 622 | if ((rem = mg_end_request(host, 0, MG_SECTOR_SIZE))) { |
| 599 | /* write 1 sector and set handler if remains */ | 623 | /* write 1 sector and set handler if remains */ |
| 600 | buff = (u16 *)req->buffer; | 624 | mg_write_one(host, req); |
| 601 | for (j = 0; j < MG_STORAGE_BUFFER_SIZE >> 1; j++) { | ||
| 602 | outw(*buff, (unsigned long)host->dev_base + | ||
| 603 | MG_BUFF_OFFSET + (j << 1)); | ||
| 604 | buff++; | ||
| 605 | } | ||
| 606 | MG_DBG("sector %ld, remaining=%ld, buffer=0x%p\n", | 625 | MG_DBG("sector %ld, remaining=%ld, buffer=0x%p\n", |
| 607 | blk_rq_pos(req), blk_rq_sectors(req), req->buffer); | 626 | blk_rq_pos(req), blk_rq_sectors(req), req->buffer); |
| 608 | host->mg_do_intr = mg_write_intr; | 627 | host->mg_do_intr = mg_write_intr; |
| @@ -667,9 +686,6 @@ static unsigned int mg_issue_req(struct request *req, | |||
| 667 | unsigned int sect_num, | 686 | unsigned int sect_num, |
| 668 | unsigned int sect_cnt) | 687 | unsigned int sect_cnt) |
| 669 | { | 688 | { |
| 670 | u16 *buff; | ||
| 671 | u32 i; | ||
| 672 | |||
| 673 | switch (rq_data_dir(req)) { | 689 | switch (rq_data_dir(req)) { |
| 674 | case READ: | 690 | case READ: |
| 675 | if (mg_out(host, sect_num, sect_cnt, MG_CMD_RD, &mg_read_intr) | 691 | if (mg_out(host, sect_num, sect_cnt, MG_CMD_RD, &mg_read_intr) |
| @@ -693,12 +709,7 @@ static unsigned int mg_issue_req(struct request *req, | |||
| 693 | mg_bad_rw_intr(host); | 709 | mg_bad_rw_intr(host); |
| 694 | return host->error; | 710 | return host->error; |
| 695 | } | 711 | } |
| 696 | buff = (u16 *)req->buffer; | 712 | mg_write_one(host, req); |
| 697 | for (i = 0; i < MG_SECTOR_SIZE >> 1; i++) { | ||
| 698 | outw(*buff, (unsigned long)host->dev_base + | ||
| 699 | MG_BUFF_OFFSET + (i << 1)); | ||
| 700 | buff++; | ||
| 701 | } | ||
| 702 | mod_timer(&host->timer, jiffies + 3 * HZ); | 713 | mod_timer(&host->timer, jiffies + 3 * HZ); |
| 703 | outb(MG_CMD_WR_CONF, (unsigned long)host->dev_base + | 714 | outb(MG_CMD_WR_CONF, (unsigned long)host->dev_base + |
| 704 | MG_REG_COMMAND); | 715 | MG_REG_COMMAND); |
diff --git a/drivers/block/virtio_blk.c b/drivers/block/virtio_blk.c index fbeefb68a31f..aa1a3d5a3e2b 100644 --- a/drivers/block/virtio_blk.c +++ b/drivers/block/virtio_blk.c | |||
| @@ -427,7 +427,12 @@ static unsigned int features[] = { | |||
| 427 | VIRTIO_BLK_F_SCSI, VIRTIO_BLK_F_IDENTIFY | 427 | VIRTIO_BLK_F_SCSI, VIRTIO_BLK_F_IDENTIFY |
| 428 | }; | 428 | }; |
| 429 | 429 | ||
| 430 | static struct virtio_driver virtio_blk = { | 430 | /* |
| 431 | * virtio_blk causes spurious section mismatch warning by | ||
| 432 | * simultaneously referring to a __devinit and a __devexit function. | ||
| 433 | * Use __refdata to avoid this warning. | ||
| 434 | */ | ||
| 435 | static struct virtio_driver __refdata virtio_blk = { | ||
| 431 | .feature_table = features, | 436 | .feature_table = features, |
| 432 | .feature_table_size = ARRAY_SIZE(features), | 437 | .feature_table_size = ARRAY_SIZE(features), |
| 433 | .driver.name = KBUILD_MODNAME, | 438 | .driver.name = KBUILD_MODNAME, |
diff --git a/drivers/block/z2ram.c b/drivers/block/z2ram.c index 4575171e5beb..b2590409f25e 100644 --- a/drivers/block/z2ram.c +++ b/drivers/block/z2ram.c | |||
| @@ -374,7 +374,7 @@ err: | |||
| 374 | static void __exit z2_exit(void) | 374 | static void __exit z2_exit(void) |
| 375 | { | 375 | { |
| 376 | int i, j; | 376 | int i, j; |
| 377 | blk_unregister_region(MKDEV(Z2RAM_MAJOR, 0), 256); | 377 | blk_unregister_region(MKDEV(Z2RAM_MAJOR, 0), Z2MINOR_COUNT); |
| 378 | unregister_blkdev(Z2RAM_MAJOR, DEVICE_NAME); | 378 | unregister_blkdev(Z2RAM_MAJOR, DEVICE_NAME); |
| 379 | del_gendisk(z2ram_gendisk); | 379 | del_gendisk(z2ram_gendisk); |
| 380 | put_disk(z2ram_gendisk); | 380 | put_disk(z2ram_gendisk); |
diff --git a/drivers/char/agp/parisc-agp.c b/drivers/char/agp/parisc-agp.c index f4bb43fb8016..e077701ae3d9 100644 --- a/drivers/char/agp/parisc-agp.c +++ b/drivers/char/agp/parisc-agp.c | |||
| @@ -225,7 +225,7 @@ static const struct agp_bridge_driver parisc_agp_driver = { | |||
| 225 | .configure = parisc_agp_configure, | 225 | .configure = parisc_agp_configure, |
| 226 | .fetch_size = parisc_agp_fetch_size, | 226 | .fetch_size = parisc_agp_fetch_size, |
| 227 | .tlb_flush = parisc_agp_tlbflush, | 227 | .tlb_flush = parisc_agp_tlbflush, |
| 228 | .mask_memory = parisc_agp_mask_memory, | 228 | .mask_memory = parisc_agp_page_mask_memory, |
| 229 | .masks = parisc_agp_masks, | 229 | .masks = parisc_agp_masks, |
| 230 | .agp_enable = parisc_agp_enable, | 230 | .agp_enable = parisc_agp_enable, |
| 231 | .cache_flush = global_cache_flush, | 231 | .cache_flush = global_cache_flush, |
diff --git a/drivers/char/n_tty.c b/drivers/char/n_tty.c index ff47907ff1bf..973be2f44195 100644 --- a/drivers/char/n_tty.c +++ b/drivers/char/n_tty.c | |||
| @@ -1583,6 +1583,7 @@ static int n_tty_open(struct tty_struct *tty) | |||
| 1583 | 1583 | ||
| 1584 | static inline int input_available_p(struct tty_struct *tty, int amt) | 1584 | static inline int input_available_p(struct tty_struct *tty, int amt) |
| 1585 | { | 1585 | { |
| 1586 | tty_flush_to_ldisc(tty); | ||
| 1586 | if (tty->icanon) { | 1587 | if (tty->icanon) { |
| 1587 | if (tty->canon_data) | 1588 | if (tty->canon_data) |
| 1588 | return 1; | 1589 | return 1; |
diff --git a/drivers/char/pty.c b/drivers/char/pty.c index 6e6942c45f5b..d083c73d784a 100644 --- a/drivers/char/pty.c +++ b/drivers/char/pty.c | |||
| @@ -144,6 +144,8 @@ static int pty_write(struct tty_struct *tty, const unsigned char *buf, | |||
| 144 | 144 | ||
| 145 | static int pty_write_room(struct tty_struct *tty) | 145 | static int pty_write_room(struct tty_struct *tty) |
| 146 | { | 146 | { |
| 147 | if (tty->stopped) | ||
| 148 | return 0; | ||
| 147 | return pty_space(tty->link); | 149 | return pty_space(tty->link); |
| 148 | } | 150 | } |
| 149 | 151 | ||
diff --git a/drivers/char/sysrq.c b/drivers/char/sysrq.c index 0db35857e4d8..5d7a02f63e1c 100644 --- a/drivers/char/sysrq.c +++ b/drivers/char/sysrq.c | |||
| @@ -35,7 +35,6 @@ | |||
| 35 | #include <linux/spinlock.h> | 35 | #include <linux/spinlock.h> |
| 36 | #include <linux/vt_kern.h> | 36 | #include <linux/vt_kern.h> |
| 37 | #include <linux/workqueue.h> | 37 | #include <linux/workqueue.h> |
| 38 | #include <linux/kexec.h> | ||
| 39 | #include <linux/hrtimer.h> | 38 | #include <linux/hrtimer.h> |
| 40 | #include <linux/oom.h> | 39 | #include <linux/oom.h> |
| 41 | 40 | ||
| @@ -124,9 +123,12 @@ static struct sysrq_key_op sysrq_unraw_op = { | |||
| 124 | static void sysrq_handle_crash(int key, struct tty_struct *tty) | 123 | static void sysrq_handle_crash(int key, struct tty_struct *tty) |
| 125 | { | 124 | { |
| 126 | char *killer = NULL; | 125 | char *killer = NULL; |
| 126 | |||
| 127 | panic_on_oops = 1; /* force panic */ | ||
| 128 | wmb(); | ||
| 127 | *killer = 1; | 129 | *killer = 1; |
| 128 | } | 130 | } |
| 129 | static struct sysrq_key_op sysrq_crashdump_op = { | 131 | static struct sysrq_key_op sysrq_crash_op = { |
| 130 | .handler = sysrq_handle_crash, | 132 | .handler = sysrq_handle_crash, |
| 131 | .help_msg = "Crash", | 133 | .help_msg = "Crash", |
| 132 | .action_msg = "Trigger a crash", | 134 | .action_msg = "Trigger a crash", |
| @@ -401,7 +403,7 @@ static struct sysrq_key_op *sysrq_key_table[36] = { | |||
| 401 | */ | 403 | */ |
| 402 | NULL, /* a */ | 404 | NULL, /* a */ |
| 403 | &sysrq_reboot_op, /* b */ | 405 | &sysrq_reboot_op, /* b */ |
| 404 | &sysrq_crashdump_op, /* c & ibm_emac driver debug */ | 406 | &sysrq_crash_op, /* c & ibm_emac driver debug */ |
| 405 | &sysrq_showlocks_op, /* d */ | 407 | &sysrq_showlocks_op, /* d */ |
| 406 | &sysrq_term_op, /* e */ | 408 | &sysrq_term_op, /* e */ |
| 407 | &sysrq_moom_op, /* f */ | 409 | &sysrq_moom_op, /* f */ |
diff --git a/drivers/char/tty_buffer.c b/drivers/char/tty_buffer.c index 810ee25d66a4..3108991c5c8b 100644 --- a/drivers/char/tty_buffer.c +++ b/drivers/char/tty_buffer.c | |||
| @@ -462,6 +462,19 @@ static void flush_to_ldisc(struct work_struct *work) | |||
| 462 | } | 462 | } |
| 463 | 463 | ||
| 464 | /** | 464 | /** |
| 465 | * tty_flush_to_ldisc | ||
| 466 | * @tty: tty to push | ||
| 467 | * | ||
| 468 | * Push the terminal flip buffers to the line discipline. | ||
| 469 | * | ||
| 470 | * Must not be called from IRQ context. | ||
| 471 | */ | ||
| 472 | void tty_flush_to_ldisc(struct tty_struct *tty) | ||
| 473 | { | ||
| 474 | flush_to_ldisc(&tty->buf.work.work); | ||
| 475 | } | ||
| 476 | |||
| 477 | /** | ||
| 465 | * tty_flip_buffer_push - terminal | 478 | * tty_flip_buffer_push - terminal |
| 466 | * @tty: tty to push | 479 | * @tty: tty to push |
| 467 | * | 480 | * |
diff --git a/drivers/char/tty_ldisc.c b/drivers/char/tty_ldisc.c index acd76b767d4c..e48af9f79219 100644 --- a/drivers/char/tty_ldisc.c +++ b/drivers/char/tty_ldisc.c | |||
| @@ -48,6 +48,41 @@ static DECLARE_WAIT_QUEUE_HEAD(tty_ldisc_wait); | |||
| 48 | /* Line disc dispatch table */ | 48 | /* Line disc dispatch table */ |
| 49 | static struct tty_ldisc_ops *tty_ldiscs[NR_LDISCS]; | 49 | static struct tty_ldisc_ops *tty_ldiscs[NR_LDISCS]; |
| 50 | 50 | ||
| 51 | static inline struct tty_ldisc *get_ldisc(struct tty_ldisc *ld) | ||
| 52 | { | ||
| 53 | if (ld) | ||
| 54 | atomic_inc(&ld->users); | ||
| 55 | return ld; | ||
| 56 | } | ||
| 57 | |||
| 58 | static void put_ldisc(struct tty_ldisc *ld) | ||
| 59 | { | ||
| 60 | unsigned long flags; | ||
| 61 | |||
| 62 | if (WARN_ON_ONCE(!ld)) | ||
| 63 | return; | ||
| 64 | |||
| 65 | /* | ||
| 66 | * If this is the last user, free the ldisc, and | ||
| 67 | * release the ldisc ops. | ||
| 68 | * | ||
| 69 | * We really want an "atomic_dec_and_lock_irqsave()", | ||
| 70 | * but we don't have it, so this does it by hand. | ||
| 71 | */ | ||
| 72 | local_irq_save(flags); | ||
| 73 | if (atomic_dec_and_lock(&ld->users, &tty_ldisc_lock)) { | ||
| 74 | struct tty_ldisc_ops *ldo = ld->ops; | ||
| 75 | |||
| 76 | ldo->refcount--; | ||
| 77 | module_put(ldo->owner); | ||
| 78 | spin_unlock_irqrestore(&tty_ldisc_lock, flags); | ||
| 79 | |||
| 80 | kfree(ld); | ||
| 81 | return; | ||
| 82 | } | ||
| 83 | local_irq_restore(flags); | ||
| 84 | } | ||
| 85 | |||
| 51 | /** | 86 | /** |
| 52 | * tty_register_ldisc - install a line discipline | 87 | * tty_register_ldisc - install a line discipline |
| 53 | * @disc: ldisc number | 88 | * @disc: ldisc number |
| @@ -142,7 +177,7 @@ static struct tty_ldisc *tty_ldisc_try_get(int disc) | |||
| 142 | /* lock it */ | 177 | /* lock it */ |
| 143 | ldops->refcount++; | 178 | ldops->refcount++; |
| 144 | ld->ops = ldops; | 179 | ld->ops = ldops; |
| 145 | ld->refcount = 0; | 180 | atomic_set(&ld->users, 1); |
| 146 | err = 0; | 181 | err = 0; |
| 147 | } | 182 | } |
| 148 | } | 183 | } |
| @@ -181,35 +216,6 @@ static struct tty_ldisc *tty_ldisc_get(int disc) | |||
| 181 | return ld; | 216 | return ld; |
| 182 | } | 217 | } |
| 183 | 218 | ||
| 184 | /** | ||
| 185 | * tty_ldisc_put - drop ldisc reference | ||
| 186 | * @ld: ldisc | ||
| 187 | * | ||
| 188 | * Drop a reference to a line discipline. Manage refcounts and | ||
| 189 | * module usage counts. Free the ldisc once the recount hits zero. | ||
| 190 | * | ||
| 191 | * Locking: | ||
| 192 | * takes tty_ldisc_lock to guard against ldisc races | ||
| 193 | */ | ||
| 194 | |||
| 195 | static void tty_ldisc_put(struct tty_ldisc *ld) | ||
| 196 | { | ||
| 197 | unsigned long flags; | ||
| 198 | int disc = ld->ops->num; | ||
| 199 | struct tty_ldisc_ops *ldo; | ||
| 200 | |||
| 201 | BUG_ON(disc < N_TTY || disc >= NR_LDISCS); | ||
| 202 | |||
| 203 | spin_lock_irqsave(&tty_ldisc_lock, flags); | ||
| 204 | ldo = tty_ldiscs[disc]; | ||
| 205 | BUG_ON(ldo->refcount == 0); | ||
| 206 | ldo->refcount--; | ||
| 207 | module_put(ldo->owner); | ||
| 208 | spin_unlock_irqrestore(&tty_ldisc_lock, flags); | ||
| 209 | WARN_ON(ld->refcount); | ||
| 210 | kfree(ld); | ||
| 211 | } | ||
| 212 | |||
| 213 | static void *tty_ldiscs_seq_start(struct seq_file *m, loff_t *pos) | 219 | static void *tty_ldiscs_seq_start(struct seq_file *m, loff_t *pos) |
| 214 | { | 220 | { |
| 215 | return (*pos < NR_LDISCS) ? pos : NULL; | 221 | return (*pos < NR_LDISCS) ? pos : NULL; |
| @@ -234,7 +240,7 @@ static int tty_ldiscs_seq_show(struct seq_file *m, void *v) | |||
| 234 | if (IS_ERR(ld)) | 240 | if (IS_ERR(ld)) |
| 235 | return 0; | 241 | return 0; |
| 236 | seq_printf(m, "%-10s %2d\n", ld->ops->name ? ld->ops->name : "???", i); | 242 | seq_printf(m, "%-10s %2d\n", ld->ops->name ? ld->ops->name : "???", i); |
| 237 | tty_ldisc_put(ld); | 243 | put_ldisc(ld); |
| 238 | return 0; | 244 | return 0; |
| 239 | } | 245 | } |
| 240 | 246 | ||
| @@ -288,20 +294,17 @@ static void tty_ldisc_assign(struct tty_struct *tty, struct tty_ldisc *ld) | |||
| 288 | * Locking: takes tty_ldisc_lock | 294 | * Locking: takes tty_ldisc_lock |
| 289 | */ | 295 | */ |
| 290 | 296 | ||
| 291 | static int tty_ldisc_try(struct tty_struct *tty) | 297 | static struct tty_ldisc *tty_ldisc_try(struct tty_struct *tty) |
| 292 | { | 298 | { |
| 293 | unsigned long flags; | 299 | unsigned long flags; |
| 294 | struct tty_ldisc *ld; | 300 | struct tty_ldisc *ld; |
| 295 | int ret = 0; | ||
| 296 | 301 | ||
| 297 | spin_lock_irqsave(&tty_ldisc_lock, flags); | 302 | spin_lock_irqsave(&tty_ldisc_lock, flags); |
| 298 | ld = tty->ldisc; | 303 | ld = NULL; |
| 299 | if (test_bit(TTY_LDISC, &tty->flags)) { | 304 | if (test_bit(TTY_LDISC, &tty->flags)) |
| 300 | ld->refcount++; | 305 | ld = get_ldisc(tty->ldisc); |
| 301 | ret = 1; | ||
| 302 | } | ||
| 303 | spin_unlock_irqrestore(&tty_ldisc_lock, flags); | 306 | spin_unlock_irqrestore(&tty_ldisc_lock, flags); |
| 304 | return ret; | 307 | return ld; |
| 305 | } | 308 | } |
| 306 | 309 | ||
| 307 | /** | 310 | /** |
| @@ -322,10 +325,11 @@ static int tty_ldisc_try(struct tty_struct *tty) | |||
| 322 | 325 | ||
| 323 | struct tty_ldisc *tty_ldisc_ref_wait(struct tty_struct *tty) | 326 | struct tty_ldisc *tty_ldisc_ref_wait(struct tty_struct *tty) |
| 324 | { | 327 | { |
| 328 | struct tty_ldisc *ld; | ||
| 329 | |||
| 325 | /* wait_event is a macro */ | 330 | /* wait_event is a macro */ |
| 326 | wait_event(tty_ldisc_wait, tty_ldisc_try(tty)); | 331 | wait_event(tty_ldisc_wait, (ld = tty_ldisc_try(tty)) != NULL); |
| 327 | WARN_ON(tty->ldisc->refcount == 0); | 332 | return ld; |
| 328 | return tty->ldisc; | ||
| 329 | } | 333 | } |
| 330 | EXPORT_SYMBOL_GPL(tty_ldisc_ref_wait); | 334 | EXPORT_SYMBOL_GPL(tty_ldisc_ref_wait); |
| 331 | 335 | ||
| @@ -342,9 +346,7 @@ EXPORT_SYMBOL_GPL(tty_ldisc_ref_wait); | |||
| 342 | 346 | ||
| 343 | struct tty_ldisc *tty_ldisc_ref(struct tty_struct *tty) | 347 | struct tty_ldisc *tty_ldisc_ref(struct tty_struct *tty) |
| 344 | { | 348 | { |
| 345 | if (tty_ldisc_try(tty)) | 349 | return tty_ldisc_try(tty); |
| 346 | return tty->ldisc; | ||
| 347 | return NULL; | ||
| 348 | } | 350 | } |
| 349 | EXPORT_SYMBOL_GPL(tty_ldisc_ref); | 351 | EXPORT_SYMBOL_GPL(tty_ldisc_ref); |
| 350 | 352 | ||
| @@ -360,21 +362,15 @@ EXPORT_SYMBOL_GPL(tty_ldisc_ref); | |||
| 360 | 362 | ||
| 361 | void tty_ldisc_deref(struct tty_ldisc *ld) | 363 | void tty_ldisc_deref(struct tty_ldisc *ld) |
| 362 | { | 364 | { |
| 363 | unsigned long flags; | 365 | put_ldisc(ld); |
| 364 | |||
| 365 | BUG_ON(ld == NULL); | ||
| 366 | |||
| 367 | spin_lock_irqsave(&tty_ldisc_lock, flags); | ||
| 368 | if (ld->refcount == 0) | ||
| 369 | printk(KERN_ERR "tty_ldisc_deref: no references.\n"); | ||
| 370 | else | ||
| 371 | ld->refcount--; | ||
| 372 | if (ld->refcount == 0) | ||
| 373 | wake_up(&tty_ldisc_wait); | ||
| 374 | spin_unlock_irqrestore(&tty_ldisc_lock, flags); | ||
| 375 | } | 366 | } |
| 376 | EXPORT_SYMBOL_GPL(tty_ldisc_deref); | 367 | EXPORT_SYMBOL_GPL(tty_ldisc_deref); |
| 377 | 368 | ||
| 369 | static inline void tty_ldisc_put(struct tty_ldisc *ld) | ||
| 370 | { | ||
| 371 | put_ldisc(ld); | ||
| 372 | } | ||
| 373 | |||
| 378 | /** | 374 | /** |
| 379 | * tty_ldisc_enable - allow ldisc use | 375 | * tty_ldisc_enable - allow ldisc use |
| 380 | * @tty: terminal to activate ldisc on | 376 | * @tty: terminal to activate ldisc on |
| @@ -512,8 +508,9 @@ static void tty_ldisc_restore(struct tty_struct *tty, struct tty_ldisc *old) | |||
| 512 | * be obtained while the delayed work queue halt ensures that no more | 508 | * be obtained while the delayed work queue halt ensures that no more |
| 513 | * data is fed to the ldisc. | 509 | * data is fed to the ldisc. |
| 514 | * | 510 | * |
| 515 | * In order to wait for any existing references to complete see | 511 | * You need to do a 'flush_scheduled_work()' (outside the ldisc_mutex) |
| 516 | * tty_ldisc_wait_idle. | 512 | * in order to make sure any currently executing ldisc work is also |
| 513 | * flushed. | ||
| 517 | */ | 514 | */ |
| 518 | 515 | ||
| 519 | static int tty_ldisc_halt(struct tty_struct *tty) | 516 | static int tty_ldisc_halt(struct tty_struct *tty) |
| @@ -523,31 +520,6 @@ static int tty_ldisc_halt(struct tty_struct *tty) | |||
| 523 | } | 520 | } |
| 524 | 521 | ||
| 525 | /** | 522 | /** |
| 526 | * tty_ldisc_wait_idle - wait for the ldisc to become idle | ||
| 527 | * @tty: tty to wait for | ||
| 528 | * | ||
| 529 | * Wait for the line discipline to become idle. The discipline must | ||
| 530 | * have been halted for this to guarantee it remains idle. | ||
| 531 | * | ||
| 532 | * tty_ldisc_lock protects the ref counts currently. | ||
| 533 | */ | ||
| 534 | |||
| 535 | static int tty_ldisc_wait_idle(struct tty_struct *tty) | ||
| 536 | { | ||
| 537 | unsigned long flags; | ||
| 538 | spin_lock_irqsave(&tty_ldisc_lock, flags); | ||
| 539 | while (tty->ldisc->refcount) { | ||
| 540 | spin_unlock_irqrestore(&tty_ldisc_lock, flags); | ||
| 541 | if (wait_event_timeout(tty_ldisc_wait, | ||
| 542 | tty->ldisc->refcount == 0, 5 * HZ) == 0) | ||
| 543 | return -EBUSY; | ||
| 544 | spin_lock_irqsave(&tty_ldisc_lock, flags); | ||
| 545 | } | ||
| 546 | spin_unlock_irqrestore(&tty_ldisc_lock, flags); | ||
| 547 | return 0; | ||
| 548 | } | ||
| 549 | |||
| 550 | /** | ||
| 551 | * tty_set_ldisc - set line discipline | 523 | * tty_set_ldisc - set line discipline |
| 552 | * @tty: the terminal to set | 524 | * @tty: the terminal to set |
| 553 | * @ldisc: the line discipline | 525 | * @ldisc: the line discipline |
| @@ -642,14 +614,6 @@ int tty_set_ldisc(struct tty_struct *tty, int ldisc) | |||
| 642 | 614 | ||
| 643 | flush_scheduled_work(); | 615 | flush_scheduled_work(); |
| 644 | 616 | ||
| 645 | /* Let any existing reference holders finish */ | ||
| 646 | retval = tty_ldisc_wait_idle(tty); | ||
| 647 | if (retval < 0) { | ||
| 648 | clear_bit(TTY_LDISC_CHANGING, &tty->flags); | ||
| 649 | tty_ldisc_put(new_ldisc); | ||
| 650 | return retval; | ||
| 651 | } | ||
| 652 | |||
| 653 | mutex_lock(&tty->ldisc_mutex); | 617 | mutex_lock(&tty->ldisc_mutex); |
| 654 | if (test_bit(TTY_HUPPED, &tty->flags)) { | 618 | if (test_bit(TTY_HUPPED, &tty->flags)) { |
| 655 | /* We were raced by the hangup method. It will have stomped | 619 | /* We were raced by the hangup method. It will have stomped |
| @@ -790,12 +754,14 @@ void tty_ldisc_hangup(struct tty_struct *tty) | |||
| 790 | * N_TTY. | 754 | * N_TTY. |
| 791 | */ | 755 | */ |
| 792 | if (tty->driver->flags & TTY_DRIVER_RESET_TERMIOS) { | 756 | if (tty->driver->flags & TTY_DRIVER_RESET_TERMIOS) { |
| 757 | /* Make sure the old ldisc is quiescent */ | ||
| 758 | tty_ldisc_halt(tty); | ||
| 759 | flush_scheduled_work(); | ||
| 760 | |||
| 793 | /* Avoid racing set_ldisc or tty_ldisc_release */ | 761 | /* Avoid racing set_ldisc or tty_ldisc_release */ |
| 794 | mutex_lock(&tty->ldisc_mutex); | 762 | mutex_lock(&tty->ldisc_mutex); |
| 795 | if (tty->ldisc) { /* Not yet closed */ | 763 | if (tty->ldisc) { /* Not yet closed */ |
| 796 | /* Switch back to N_TTY */ | 764 | /* Switch back to N_TTY */ |
| 797 | tty_ldisc_halt(tty); | ||
| 798 | tty_ldisc_wait_idle(tty); | ||
| 799 | tty_ldisc_reinit(tty); | 765 | tty_ldisc_reinit(tty); |
| 800 | /* At this point we have a closed ldisc and we want to | 766 | /* At this point we have a closed ldisc and we want to |
| 801 | reopen it. We could defer this to the next open but | 767 | reopen it. We could defer this to the next open but |
| @@ -860,14 +826,6 @@ void tty_ldisc_release(struct tty_struct *tty, struct tty_struct *o_tty) | |||
| 860 | tty_ldisc_halt(tty); | 826 | tty_ldisc_halt(tty); |
| 861 | flush_scheduled_work(); | 827 | flush_scheduled_work(); |
| 862 | 828 | ||
| 863 | /* | ||
| 864 | * Wait for any short term users (we know they are just driver | ||
| 865 | * side waiters as the file is closing so user count on the file | ||
| 866 | * side is zero. | ||
| 867 | */ | ||
| 868 | |||
| 869 | tty_ldisc_wait_idle(tty); | ||
| 870 | |||
| 871 | mutex_lock(&tty->ldisc_mutex); | 829 | mutex_lock(&tty->ldisc_mutex); |
| 872 | /* | 830 | /* |
| 873 | * Now kill off the ldisc | 831 | * Now kill off the ldisc |
diff --git a/drivers/char/vr41xx_giu.c b/drivers/char/vr41xx_giu.c deleted file mode 100644 index e69de29bb2d1..000000000000 --- a/drivers/char/vr41xx_giu.c +++ /dev/null | |||
diff --git a/drivers/clocksource/sh_cmt.c b/drivers/clocksource/sh_cmt.c index 2964f5f4a7ef..6b3e0c2f33e2 100644 --- a/drivers/clocksource/sh_cmt.c +++ b/drivers/clocksource/sh_cmt.c | |||
| @@ -40,6 +40,7 @@ struct sh_cmt_priv { | |||
| 40 | struct platform_device *pdev; | 40 | struct platform_device *pdev; |
| 41 | 41 | ||
| 42 | unsigned long flags; | 42 | unsigned long flags; |
| 43 | unsigned long flags_suspend; | ||
| 43 | unsigned long match_value; | 44 | unsigned long match_value; |
| 44 | unsigned long next_match_value; | 45 | unsigned long next_match_value; |
| 45 | unsigned long max_match_value; | 46 | unsigned long max_match_value; |
| @@ -667,11 +668,38 @@ static int __devexit sh_cmt_remove(struct platform_device *pdev) | |||
| 667 | return -EBUSY; /* cannot unregister clockevent and clocksource */ | 668 | return -EBUSY; /* cannot unregister clockevent and clocksource */ |
| 668 | } | 669 | } |
| 669 | 670 | ||
| 671 | static int sh_cmt_suspend(struct device *dev) | ||
| 672 | { | ||
| 673 | struct platform_device *pdev = to_platform_device(dev); | ||
| 674 | struct sh_cmt_priv *p = platform_get_drvdata(pdev); | ||
| 675 | |||
| 676 | /* save flag state and stop CMT channel */ | ||
| 677 | p->flags_suspend = p->flags; | ||
| 678 | sh_cmt_stop(p, p->flags); | ||
| 679 | return 0; | ||
| 680 | } | ||
| 681 | |||
| 682 | static int sh_cmt_resume(struct device *dev) | ||
| 683 | { | ||
| 684 | struct platform_device *pdev = to_platform_device(dev); | ||
| 685 | struct sh_cmt_priv *p = platform_get_drvdata(pdev); | ||
| 686 | |||
| 687 | /* start CMT channel from saved state */ | ||
| 688 | sh_cmt_start(p, p->flags_suspend); | ||
| 689 | return 0; | ||
| 690 | } | ||
| 691 | |||
| 692 | static struct dev_pm_ops sh_cmt_dev_pm_ops = { | ||
| 693 | .suspend = sh_cmt_suspend, | ||
| 694 | .resume = sh_cmt_resume, | ||
| 695 | }; | ||
| 696 | |||
| 670 | static struct platform_driver sh_cmt_device_driver = { | 697 | static struct platform_driver sh_cmt_device_driver = { |
| 671 | .probe = sh_cmt_probe, | 698 | .probe = sh_cmt_probe, |
| 672 | .remove = __devexit_p(sh_cmt_remove), | 699 | .remove = __devexit_p(sh_cmt_remove), |
| 673 | .driver = { | 700 | .driver = { |
| 674 | .name = "sh_cmt", | 701 | .name = "sh_cmt", |
| 702 | .pm = &sh_cmt_dev_pm_ops, | ||
| 675 | } | 703 | } |
| 676 | }; | 704 | }; |
| 677 | 705 | ||
diff --git a/drivers/connector/cn_queue.c b/drivers/connector/cn_queue.c index c769ef269fb5..408c2af25d50 100644 --- a/drivers/connector/cn_queue.c +++ b/drivers/connector/cn_queue.c | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * cn_queue.c | 2 | * cn_queue.c |
| 3 | * | 3 | * |
| 4 | * 2004-2005 Copyright (c) Evgeniy Polyakov <johnpol@2ka.mipt.ru> | 4 | * 2004+ Copyright (c) Evgeniy Polyakov <zbr@ioremap.net> |
| 5 | * All rights reserved. | 5 | * All rights reserved. |
| 6 | * | 6 | * |
| 7 | * This program is free software; you can redistribute it and/or modify | 7 | * This program is free software; you can redistribute it and/or modify |
diff --git a/drivers/connector/connector.c b/drivers/connector/connector.c index fd336c5a9057..08b2500f21ec 100644 --- a/drivers/connector/connector.c +++ b/drivers/connector/connector.c | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * connector.c | 2 | * connector.c |
| 3 | * | 3 | * |
| 4 | * 2004-2005 Copyright (c) Evgeniy Polyakov <johnpol@2ka.mipt.ru> | 4 | * 2004+ Copyright (c) Evgeniy Polyakov <zbr@ioremap.net> |
| 5 | * All rights reserved. | 5 | * All rights reserved. |
| 6 | * | 6 | * |
| 7 | * This program is free software; you can redistribute it and/or modify | 7 | * This program is free software; you can redistribute it and/or modify |
| @@ -33,7 +33,7 @@ | |||
| 33 | #include <net/sock.h> | 33 | #include <net/sock.h> |
| 34 | 34 | ||
| 35 | MODULE_LICENSE("GPL"); | 35 | MODULE_LICENSE("GPL"); |
| 36 | MODULE_AUTHOR("Evgeniy Polyakov <johnpol@2ka.mipt.ru>"); | 36 | MODULE_AUTHOR("Evgeniy Polyakov <zbr@ioremap.net>"); |
| 37 | MODULE_DESCRIPTION("Generic userspace <-> kernelspace connector."); | 37 | MODULE_DESCRIPTION("Generic userspace <-> kernelspace connector."); |
| 38 | 38 | ||
| 39 | static u32 cn_idx = CN_IDX_CONNECTOR; | 39 | static u32 cn_idx = CN_IDX_CONNECTOR; |
diff --git a/drivers/cpufreq/cpufreq.c b/drivers/cpufreq/cpufreq.c index b90eda8b3440..fd69086d08d5 100644 --- a/drivers/cpufreq/cpufreq.c +++ b/drivers/cpufreq/cpufreq.c | |||
| @@ -858,6 +858,8 @@ static int cpufreq_add_dev(struct sys_device *sys_dev) | |||
| 858 | 858 | ||
| 859 | /* Check for existing affected CPUs. | 859 | /* Check for existing affected CPUs. |
| 860 | * They may not be aware of it due to CPU Hotplug. | 860 | * They may not be aware of it due to CPU Hotplug. |
| 861 | * cpufreq_cpu_put is called when the device is removed | ||
| 862 | * in __cpufreq_remove_dev() | ||
| 861 | */ | 863 | */ |
| 862 | managed_policy = cpufreq_cpu_get(j); | 864 | managed_policy = cpufreq_cpu_get(j); |
| 863 | if (unlikely(managed_policy)) { | 865 | if (unlikely(managed_policy)) { |
| @@ -884,7 +886,7 @@ static int cpufreq_add_dev(struct sys_device *sys_dev) | |||
| 884 | ret = sysfs_create_link(&sys_dev->kobj, | 886 | ret = sysfs_create_link(&sys_dev->kobj, |
| 885 | &managed_policy->kobj, | 887 | &managed_policy->kobj, |
| 886 | "cpufreq"); | 888 | "cpufreq"); |
| 887 | if (!ret) | 889 | if (ret) |
| 888 | cpufreq_cpu_put(managed_policy); | 890 | cpufreq_cpu_put(managed_policy); |
| 889 | /* | 891 | /* |
| 890 | * Success. We only needed to be added to the mask. | 892 | * Success. We only needed to be added to the mask. |
| @@ -924,6 +926,8 @@ static int cpufreq_add_dev(struct sys_device *sys_dev) | |||
| 924 | 926 | ||
| 925 | spin_lock_irqsave(&cpufreq_driver_lock, flags); | 927 | spin_lock_irqsave(&cpufreq_driver_lock, flags); |
| 926 | for_each_cpu(j, policy->cpus) { | 928 | for_each_cpu(j, policy->cpus) { |
| 929 | if (!cpu_online(j)) | ||
| 930 | continue; | ||
| 927 | per_cpu(cpufreq_cpu_data, j) = policy; | 931 | per_cpu(cpufreq_cpu_data, j) = policy; |
| 928 | per_cpu(policy_cpu, j) = policy->cpu; | 932 | per_cpu(policy_cpu, j) = policy->cpu; |
| 929 | } | 933 | } |
| @@ -1244,13 +1248,22 @@ EXPORT_SYMBOL(cpufreq_get); | |||
| 1244 | 1248 | ||
| 1245 | static int cpufreq_suspend(struct sys_device *sysdev, pm_message_t pmsg) | 1249 | static int cpufreq_suspend(struct sys_device *sysdev, pm_message_t pmsg) |
| 1246 | { | 1250 | { |
| 1247 | int cpu = sysdev->id; | ||
| 1248 | int ret = 0; | 1251 | int ret = 0; |
| 1252 | |||
| 1253 | #ifdef __powerpc__ | ||
| 1254 | int cpu = sysdev->id; | ||
| 1249 | unsigned int cur_freq = 0; | 1255 | unsigned int cur_freq = 0; |
| 1250 | struct cpufreq_policy *cpu_policy; | 1256 | struct cpufreq_policy *cpu_policy; |
| 1251 | 1257 | ||
| 1252 | dprintk("suspending cpu %u\n", cpu); | 1258 | dprintk("suspending cpu %u\n", cpu); |
| 1253 | 1259 | ||
| 1260 | /* | ||
| 1261 | * This whole bogosity is here because Powerbooks are made of fail. | ||
| 1262 | * No sane platform should need any of the code below to be run. | ||
| 1263 | * (it's entirely the wrong thing to do, as driver->get may | ||
| 1264 | * reenable interrupts on some architectures). | ||
| 1265 | */ | ||
| 1266 | |||
| 1254 | if (!cpu_online(cpu)) | 1267 | if (!cpu_online(cpu)) |
| 1255 | return 0; | 1268 | return 0; |
| 1256 | 1269 | ||
| @@ -1309,6 +1322,7 @@ static int cpufreq_suspend(struct sys_device *sysdev, pm_message_t pmsg) | |||
| 1309 | 1322 | ||
| 1310 | out: | 1323 | out: |
| 1311 | cpufreq_cpu_put(cpu_policy); | 1324 | cpufreq_cpu_put(cpu_policy); |
| 1325 | #endif /* __powerpc__ */ | ||
| 1312 | return ret; | 1326 | return ret; |
| 1313 | } | 1327 | } |
| 1314 | 1328 | ||
| @@ -1322,12 +1336,18 @@ out: | |||
| 1322 | */ | 1336 | */ |
| 1323 | static int cpufreq_resume(struct sys_device *sysdev) | 1337 | static int cpufreq_resume(struct sys_device *sysdev) |
| 1324 | { | 1338 | { |
| 1325 | int cpu = sysdev->id; | ||
| 1326 | int ret = 0; | 1339 | int ret = 0; |
| 1340 | |||
| 1341 | #ifdef __powerpc__ | ||
| 1342 | int cpu = sysdev->id; | ||
| 1327 | struct cpufreq_policy *cpu_policy; | 1343 | struct cpufreq_policy *cpu_policy; |
| 1328 | 1344 | ||
| 1329 | dprintk("resuming cpu %u\n", cpu); | 1345 | dprintk("resuming cpu %u\n", cpu); |
| 1330 | 1346 | ||
| 1347 | /* As with the ->suspend method, all the code below is | ||
| 1348 | * only necessary because Powerbooks suck. | ||
| 1349 | * See commit 42d4dc3f4e1e for jokes. */ | ||
| 1350 | |||
| 1331 | if (!cpu_online(cpu)) | 1351 | if (!cpu_online(cpu)) |
| 1332 | return 0; | 1352 | return 0; |
| 1333 | 1353 | ||
| @@ -1391,6 +1411,7 @@ out: | |||
| 1391 | schedule_work(&cpu_policy->update); | 1411 | schedule_work(&cpu_policy->update); |
| 1392 | fail: | 1412 | fail: |
| 1393 | cpufreq_cpu_put(cpu_policy); | 1413 | cpufreq_cpu_put(cpu_policy); |
| 1414 | #endif /* __powerpc__ */ | ||
| 1394 | return ret; | 1415 | return ret; |
| 1395 | } | 1416 | } |
| 1396 | 1417 | ||
diff --git a/drivers/cpufreq/cpufreq_conservative.c b/drivers/cpufreq/cpufreq_conservative.c index 57490502b21c..bdea7e2f94ba 100644 --- a/drivers/cpufreq/cpufreq_conservative.c +++ b/drivers/cpufreq/cpufreq_conservative.c | |||
| @@ -63,6 +63,7 @@ struct cpu_dbs_info_s { | |||
| 63 | unsigned int down_skip; | 63 | unsigned int down_skip; |
| 64 | unsigned int requested_freq; | 64 | unsigned int requested_freq; |
| 65 | int cpu; | 65 | int cpu; |
| 66 | unsigned int enable:1; | ||
| 66 | /* | 67 | /* |
| 67 | * percpu mutex that serializes governor limit change with | 68 | * percpu mutex that serializes governor limit change with |
| 68 | * do_dbs_timer invocation. We do not want do_dbs_timer to run | 69 | * do_dbs_timer invocation. We do not want do_dbs_timer to run |
| @@ -141,6 +142,9 @@ dbs_cpufreq_notifier(struct notifier_block *nb, unsigned long val, | |||
| 141 | 142 | ||
| 142 | struct cpufreq_policy *policy; | 143 | struct cpufreq_policy *policy; |
| 143 | 144 | ||
| 145 | if (!this_dbs_info->enable) | ||
| 146 | return 0; | ||
| 147 | |||
| 144 | policy = this_dbs_info->cur_policy; | 148 | policy = this_dbs_info->cur_policy; |
| 145 | 149 | ||
| 146 | /* | 150 | /* |
| @@ -497,6 +501,7 @@ static inline void dbs_timer_init(struct cpu_dbs_info_s *dbs_info) | |||
| 497 | int delay = usecs_to_jiffies(dbs_tuners_ins.sampling_rate); | 501 | int delay = usecs_to_jiffies(dbs_tuners_ins.sampling_rate); |
| 498 | delay -= jiffies % delay; | 502 | delay -= jiffies % delay; |
| 499 | 503 | ||
| 504 | dbs_info->enable = 1; | ||
| 500 | INIT_DELAYED_WORK_DEFERRABLE(&dbs_info->work, do_dbs_timer); | 505 | INIT_DELAYED_WORK_DEFERRABLE(&dbs_info->work, do_dbs_timer); |
| 501 | queue_delayed_work_on(dbs_info->cpu, kconservative_wq, &dbs_info->work, | 506 | queue_delayed_work_on(dbs_info->cpu, kconservative_wq, &dbs_info->work, |
| 502 | delay); | 507 | delay); |
| @@ -504,6 +509,7 @@ static inline void dbs_timer_init(struct cpu_dbs_info_s *dbs_info) | |||
| 504 | 509 | ||
| 505 | static inline void dbs_timer_exit(struct cpu_dbs_info_s *dbs_info) | 510 | static inline void dbs_timer_exit(struct cpu_dbs_info_s *dbs_info) |
| 506 | { | 511 | { |
| 512 | dbs_info->enable = 0; | ||
| 507 | cancel_delayed_work_sync(&dbs_info->work); | 513 | cancel_delayed_work_sync(&dbs_info->work); |
| 508 | } | 514 | } |
| 509 | 515 | ||
diff --git a/drivers/dma/Kconfig b/drivers/dma/Kconfig index 070357aaedbc..81e1020fb514 100644 --- a/drivers/dma/Kconfig +++ b/drivers/dma/Kconfig | |||
| @@ -4,7 +4,7 @@ | |||
| 4 | 4 | ||
| 5 | menuconfig DMADEVICES | 5 | menuconfig DMADEVICES |
| 6 | bool "DMA Engine support" | 6 | bool "DMA Engine support" |
| 7 | depends on !HIGHMEM64G && HAS_DMA | 7 | depends on HAS_DMA |
| 8 | help | 8 | help |
| 9 | DMA engines can do asynchronous data transfers without | 9 | DMA engines can do asynchronous data transfers without |
| 10 | involving the host CPU. Currently, this framework can be | 10 | involving the host CPU. Currently, this framework can be |
| @@ -46,6 +46,14 @@ config DW_DMAC | |||
| 46 | Support the Synopsys DesignWare AHB DMA controller. This | 46 | Support the Synopsys DesignWare AHB DMA controller. This |
| 47 | can be integrated in chips such as the Atmel AT32ap7000. | 47 | can be integrated in chips such as the Atmel AT32ap7000. |
| 48 | 48 | ||
| 49 | config AT_HDMAC | ||
| 50 | tristate "Atmel AHB DMA support" | ||
| 51 | depends on ARCH_AT91SAM9RL | ||
| 52 | select DMA_ENGINE | ||
| 53 | help | ||
| 54 | Support the Atmel AHB DMA controller. This can be integrated in | ||
| 55 | chips such as the Atmel AT91SAM9RL. | ||
| 56 | |||
| 49 | config FSL_DMA | 57 | config FSL_DMA |
| 50 | tristate "Freescale Elo and Elo Plus DMA support" | 58 | tristate "Freescale Elo and Elo Plus DMA support" |
| 51 | depends on FSL_SOC | 59 | depends on FSL_SOC |
| @@ -108,7 +116,7 @@ config NET_DMA | |||
| 108 | 116 | ||
| 109 | config ASYNC_TX_DMA | 117 | config ASYNC_TX_DMA |
| 110 | bool "Async_tx: Offload support for the async_tx api" | 118 | bool "Async_tx: Offload support for the async_tx api" |
| 111 | depends on DMA_ENGINE | 119 | depends on DMA_ENGINE && !HIGHMEM64G |
| 112 | help | 120 | help |
| 113 | This allows the async_tx api to take advantage of offload engines for | 121 | This allows the async_tx api to take advantage of offload engines for |
| 114 | memcpy, memset, xor, and raid6 p+q operations. If your platform has | 122 | memcpy, memset, xor, and raid6 p+q operations. If your platform has |
diff --git a/drivers/dma/Makefile b/drivers/dma/Makefile index a0b6564800c4..40e1e0083571 100644 --- a/drivers/dma/Makefile +++ b/drivers/dma/Makefile | |||
| @@ -7,5 +7,6 @@ obj-$(CONFIG_INTEL_IOP_ADMA) += iop-adma.o | |||
| 7 | obj-$(CONFIG_FSL_DMA) += fsldma.o | 7 | obj-$(CONFIG_FSL_DMA) += fsldma.o |
| 8 | obj-$(CONFIG_MV_XOR) += mv_xor.o | 8 | obj-$(CONFIG_MV_XOR) += mv_xor.o |
| 9 | obj-$(CONFIG_DW_DMAC) += dw_dmac.o | 9 | obj-$(CONFIG_DW_DMAC) += dw_dmac.o |
| 10 | obj-$(CONFIG_AT_HDMAC) += at_hdmac.o | ||
| 10 | obj-$(CONFIG_MX3_IPU) += ipu/ | 11 | obj-$(CONFIG_MX3_IPU) += ipu/ |
| 11 | obj-$(CONFIG_TXX9_DMAC) += txx9dmac.o | 12 | obj-$(CONFIG_TXX9_DMAC) += txx9dmac.o |
diff --git a/drivers/dma/at_hdmac.c b/drivers/dma/at_hdmac.c new file mode 100644 index 000000000000..9a1e5fb412ed --- /dev/null +++ b/drivers/dma/at_hdmac.c | |||
| @@ -0,0 +1,1213 @@ | |||
| 1 | /* | ||
| 2 | * Driver for the Atmel AHB DMA Controller (aka HDMA or DMAC on AT91 systems) | ||
| 3 | * | ||
| 4 | * Copyright (C) 2008 Atmel Corporation | ||
| 5 | * | ||
| 6 | * This program is free software; you can redistribute it and/or modify | ||
| 7 | * it under the terms of the GNU General Public License as published by | ||
| 8 | * the Free Software Foundation; either version 2 of the License, or | ||
| 9 | * (at your option) any later version. | ||
| 10 | * | ||
| 11 | * | ||
| 12 | * This supports the Atmel AHB DMA Controller, | ||
| 13 | * | ||
| 14 | * The driver has currently been tested with the Atmel AT91SAM9RL | ||
| 15 | * and AT91SAM9G45 series. | ||
| 16 | */ | ||
| 17 | |||
| 18 | #include <linux/clk.h> | ||
| 19 | #include <linux/dmaengine.h> | ||
| 20 | #include <linux/dma-mapping.h> | ||
| 21 | #include <linux/dmapool.h> | ||
| 22 | #include <linux/interrupt.h> | ||
| 23 | #include <linux/module.h> | ||
| 24 | #include <linux/platform_device.h> | ||
| 25 | |||
| 26 | #include "at_hdmac_regs.h" | ||
| 27 | |||
| 28 | /* | ||
| 29 | * Glossary | ||
| 30 | * -------- | ||
| 31 | * | ||
| 32 | * at_hdmac : Name of the ATmel AHB DMA Controller | ||
| 33 | * at_dma_ / atdma : ATmel DMA controller entity related | ||
| 34 | * atc_ / atchan : ATmel DMA Channel entity related | ||
| 35 | */ | ||
| 36 | |||
| 37 | #define ATC_DEFAULT_CFG (ATC_FIFOCFG_HALFFIFO) | ||
| 38 | #define ATC_DEFAULT_CTRLA (0) | ||
| 39 | #define ATC_DEFAULT_CTRLB (ATC_SIF(0) \ | ||
| 40 | |ATC_DIF(1)) | ||
| 41 | |||
| 42 | /* | ||
| 43 | * Initial number of descriptors to allocate for each channel. This could | ||
| 44 | * be increased during dma usage. | ||
| 45 | */ | ||
| 46 | static unsigned int init_nr_desc_per_channel = 64; | ||
| 47 | module_param(init_nr_desc_per_channel, uint, 0644); | ||
| 48 | MODULE_PARM_DESC(init_nr_desc_per_channel, | ||
| 49 | "initial descriptors per channel (default: 64)"); | ||
| 50 | |||
| 51 | |||
| 52 | /* prototypes */ | ||
| 53 | static dma_cookie_t atc_tx_submit(struct dma_async_tx_descriptor *tx); | ||
| 54 | |||
| 55 | |||
| 56 | /*----------------------------------------------------------------------*/ | ||
| 57 | |||
| 58 | static struct at_desc *atc_first_active(struct at_dma_chan *atchan) | ||
| 59 | { | ||
| 60 | return list_first_entry(&atchan->active_list, | ||
| 61 | struct at_desc, desc_node); | ||
| 62 | } | ||
| 63 | |||
| 64 | static struct at_desc *atc_first_queued(struct at_dma_chan *atchan) | ||
| 65 | { | ||
| 66 | return list_first_entry(&atchan->queue, | ||
| 67 | struct at_desc, desc_node); | ||
| 68 | } | ||
| 69 | |||
| 70 | /** | ||
| 71 | * atc_alloc_descriptor - allocate and return an initilized descriptor | ||
| 72 | * @chan: the channel to allocate descriptors for | ||
| 73 | * @gfp_flags: GFP allocation flags | ||
| 74 | * | ||
| 75 | * Note: The ack-bit is positioned in the descriptor flag at creation time | ||
| 76 | * to make initial allocation more convenient. This bit will be cleared | ||
| 77 | * and control will be given to client at usage time (during | ||
| 78 | * preparation functions). | ||
| 79 | */ | ||
| 80 | static struct at_desc *atc_alloc_descriptor(struct dma_chan *chan, | ||
| 81 | gfp_t gfp_flags) | ||
| 82 | { | ||
| 83 | struct at_desc *desc = NULL; | ||
| 84 | struct at_dma *atdma = to_at_dma(chan->device); | ||
| 85 | dma_addr_t phys; | ||
| 86 | |||
| 87 | desc = dma_pool_alloc(atdma->dma_desc_pool, gfp_flags, &phys); | ||
| 88 | if (desc) { | ||
| 89 | memset(desc, 0, sizeof(struct at_desc)); | ||
| 90 | dma_async_tx_descriptor_init(&desc->txd, chan); | ||
| 91 | /* txd.flags will be overwritten in prep functions */ | ||
| 92 | desc->txd.flags = DMA_CTRL_ACK; | ||
| 93 | desc->txd.tx_submit = atc_tx_submit; | ||
| 94 | desc->txd.phys = phys; | ||
| 95 | } | ||
| 96 | |||
| 97 | return desc; | ||
| 98 | } | ||
| 99 | |||
| 100 | /** | ||
| 101 | * atc_desc_get - get a unsused descriptor from free_list | ||
| 102 | * @atchan: channel we want a new descriptor for | ||
| 103 | */ | ||
| 104 | static struct at_desc *atc_desc_get(struct at_dma_chan *atchan) | ||
| 105 | { | ||
| 106 | struct at_desc *desc, *_desc; | ||
| 107 | struct at_desc *ret = NULL; | ||
| 108 | unsigned int i = 0; | ||
| 109 | LIST_HEAD(tmp_list); | ||
| 110 | |||
| 111 | spin_lock_bh(&atchan->lock); | ||
| 112 | list_for_each_entry_safe(desc, _desc, &atchan->free_list, desc_node) { | ||
| 113 | i++; | ||
| 114 | if (async_tx_test_ack(&desc->txd)) { | ||
| 115 | list_del(&desc->desc_node); | ||
| 116 | ret = desc; | ||
| 117 | break; | ||
| 118 | } | ||
| 119 | dev_dbg(chan2dev(&atchan->chan_common), | ||
| 120 | "desc %p not ACKed\n", desc); | ||
| 121 | } | ||
| 122 | spin_unlock_bh(&atchan->lock); | ||
| 123 | dev_vdbg(chan2dev(&atchan->chan_common), | ||
| 124 | "scanned %u descriptors on freelist\n", i); | ||
| 125 | |||
| 126 | /* no more descriptor available in initial pool: create one more */ | ||
| 127 | if (!ret) { | ||
| 128 | ret = atc_alloc_descriptor(&atchan->chan_common, GFP_ATOMIC); | ||
| 129 | if (ret) { | ||
| 130 | spin_lock_bh(&atchan->lock); | ||
| 131 | atchan->descs_allocated++; | ||
| 132 | spin_unlock_bh(&atchan->lock); | ||
| 133 | } else { | ||
| 134 | dev_err(chan2dev(&atchan->chan_common), | ||
| 135 | "not enough descriptors available\n"); | ||
| 136 | } | ||
| 137 | } | ||
| 138 | |||
| 139 | return ret; | ||
| 140 | } | ||
| 141 | |||
| 142 | /** | ||
| 143 | * atc_desc_put - move a descriptor, including any children, to the free list | ||
| 144 | * @atchan: channel we work on | ||
| 145 | * @desc: descriptor, at the head of a chain, to move to free list | ||
| 146 | */ | ||
| 147 | static void atc_desc_put(struct at_dma_chan *atchan, struct at_desc *desc) | ||
| 148 | { | ||
| 149 | if (desc) { | ||
| 150 | struct at_desc *child; | ||
| 151 | |||
| 152 | spin_lock_bh(&atchan->lock); | ||
| 153 | list_for_each_entry(child, &desc->txd.tx_list, desc_node) | ||
| 154 | dev_vdbg(chan2dev(&atchan->chan_common), | ||
| 155 | "moving child desc %p to freelist\n", | ||
| 156 | child); | ||
| 157 | list_splice_init(&desc->txd.tx_list, &atchan->free_list); | ||
| 158 | dev_vdbg(chan2dev(&atchan->chan_common), | ||
| 159 | "moving desc %p to freelist\n", desc); | ||
| 160 | list_add(&desc->desc_node, &atchan->free_list); | ||
| 161 | spin_unlock_bh(&atchan->lock); | ||
| 162 | } | ||
| 163 | } | ||
| 164 | |||
| 165 | /** | ||
| 166 | * atc_assign_cookie - compute and assign new cookie | ||
| 167 | * @atchan: channel we work on | ||
| 168 | * @desc: descriptor to asign cookie for | ||
| 169 | * | ||
| 170 | * Called with atchan->lock held and bh disabled | ||
| 171 | */ | ||
| 172 | static dma_cookie_t | ||
| 173 | atc_assign_cookie(struct at_dma_chan *atchan, struct at_desc *desc) | ||
| 174 | { | ||
| 175 | dma_cookie_t cookie = atchan->chan_common.cookie; | ||
| 176 | |||
| 177 | if (++cookie < 0) | ||
| 178 | cookie = 1; | ||
| 179 | |||
| 180 | atchan->chan_common.cookie = cookie; | ||
| 181 | desc->txd.cookie = cookie; | ||
| 182 | |||
| 183 | return cookie; | ||
| 184 | } | ||
| 185 | |||
| 186 | /** | ||
| 187 | * atc_dostart - starts the DMA engine for real | ||
| 188 | * @atchan: the channel we want to start | ||
| 189 | * @first: first descriptor in the list we want to begin with | ||
| 190 | * | ||
| 191 | * Called with atchan->lock held and bh disabled | ||
| 192 | */ | ||
| 193 | static void atc_dostart(struct at_dma_chan *atchan, struct at_desc *first) | ||
| 194 | { | ||
| 195 | struct at_dma *atdma = to_at_dma(atchan->chan_common.device); | ||
| 196 | |||
| 197 | /* ASSERT: channel is idle */ | ||
| 198 | if (atc_chan_is_enabled(atchan)) { | ||
| 199 | dev_err(chan2dev(&atchan->chan_common), | ||
| 200 | "BUG: Attempted to start non-idle channel\n"); | ||
| 201 | dev_err(chan2dev(&atchan->chan_common), | ||
| 202 | " channel: s0x%x d0x%x ctrl0x%x:0x%x l0x%x\n", | ||
| 203 | channel_readl(atchan, SADDR), | ||
| 204 | channel_readl(atchan, DADDR), | ||
| 205 | channel_readl(atchan, CTRLA), | ||
| 206 | channel_readl(atchan, CTRLB), | ||
| 207 | channel_readl(atchan, DSCR)); | ||
| 208 | |||
| 209 | /* The tasklet will hopefully advance the queue... */ | ||
| 210 | return; | ||
| 211 | } | ||
| 212 | |||
| 213 | vdbg_dump_regs(atchan); | ||
| 214 | |||
| 215 | /* clear any pending interrupt */ | ||
| 216 | while (dma_readl(atdma, EBCISR)) | ||
| 217 | cpu_relax(); | ||
| 218 | |||
| 219 | channel_writel(atchan, SADDR, 0); | ||
| 220 | channel_writel(atchan, DADDR, 0); | ||
| 221 | channel_writel(atchan, CTRLA, 0); | ||
| 222 | channel_writel(atchan, CTRLB, 0); | ||
| 223 | channel_writel(atchan, DSCR, first->txd.phys); | ||
| 224 | dma_writel(atdma, CHER, atchan->mask); | ||
| 225 | |||
| 226 | vdbg_dump_regs(atchan); | ||
| 227 | } | ||
| 228 | |||
| 229 | /** | ||
| 230 | * atc_chain_complete - finish work for one transaction chain | ||
| 231 | * @atchan: channel we work on | ||
| 232 | * @desc: descriptor at the head of the chain we want do complete | ||
| 233 | * | ||
| 234 | * Called with atchan->lock held and bh disabled */ | ||
| 235 | static void | ||
| 236 | atc_chain_complete(struct at_dma_chan *atchan, struct at_desc *desc) | ||
| 237 | { | ||
| 238 | dma_async_tx_callback callback; | ||
| 239 | void *param; | ||
| 240 | struct dma_async_tx_descriptor *txd = &desc->txd; | ||
| 241 | |||
| 242 | dev_vdbg(chan2dev(&atchan->chan_common), | ||
| 243 | "descriptor %u complete\n", txd->cookie); | ||
| 244 | |||
| 245 | atchan->completed_cookie = txd->cookie; | ||
| 246 | callback = txd->callback; | ||
| 247 | param = txd->callback_param; | ||
| 248 | |||
| 249 | /* move children to free_list */ | ||
| 250 | list_splice_init(&txd->tx_list, &atchan->free_list); | ||
| 251 | /* move myself to free_list */ | ||
| 252 | list_move(&desc->desc_node, &atchan->free_list); | ||
| 253 | |||
| 254 | /* unmap dma addresses */ | ||
| 255 | if (!(txd->flags & DMA_COMPL_SKIP_DEST_UNMAP)) { | ||
| 256 | if (txd->flags & DMA_COMPL_DEST_UNMAP_SINGLE) | ||
| 257 | dma_unmap_single(chan2parent(&atchan->chan_common), | ||
| 258 | desc->lli.daddr, | ||
| 259 | desc->len, DMA_FROM_DEVICE); | ||
| 260 | else | ||
| 261 | dma_unmap_page(chan2parent(&atchan->chan_common), | ||
| 262 | desc->lli.daddr, | ||
| 263 | desc->len, DMA_FROM_DEVICE); | ||
| 264 | } | ||
| 265 | if (!(txd->flags & DMA_COMPL_SKIP_SRC_UNMAP)) { | ||
| 266 | if (txd->flags & DMA_COMPL_SRC_UNMAP_SINGLE) | ||
| 267 | dma_unmap_single(chan2parent(&atchan->chan_common), | ||
| 268 | desc->lli.saddr, | ||
| 269 | desc->len, DMA_TO_DEVICE); | ||
| 270 | else | ||
| 271 | dma_unmap_page(chan2parent(&atchan->chan_common), | ||
| 272 | desc->lli.saddr, | ||
| 273 | desc->len, DMA_TO_DEVICE); | ||
| 274 | } | ||
| 275 | |||
| 276 | /* | ||
| 277 | * The API requires that no submissions are done from a | ||
| 278 | * callback, so we don't need to drop the lock here | ||
| 279 | */ | ||
| 280 | if (callback) | ||
| 281 | callback(param); | ||
| 282 | |||
| 283 | dma_run_dependencies(txd); | ||
| 284 | } | ||
| 285 | |||
| 286 | /** | ||
| 287 | * atc_complete_all - finish work for all transactions | ||
| 288 | * @atchan: channel to complete transactions for | ||
| 289 | * | ||
| 290 | * Eventually submit queued descriptors if any | ||
| 291 | * | ||
| 292 | * Assume channel is idle while calling this function | ||
| 293 | * Called with atchan->lock held and bh disabled | ||
| 294 | */ | ||
| 295 | static void atc_complete_all(struct at_dma_chan *atchan) | ||
| 296 | { | ||
| 297 | struct at_desc *desc, *_desc; | ||
| 298 | LIST_HEAD(list); | ||
| 299 | |||
| 300 | dev_vdbg(chan2dev(&atchan->chan_common), "complete all\n"); | ||
| 301 | |||
| 302 | BUG_ON(atc_chan_is_enabled(atchan)); | ||
| 303 | |||
| 304 | /* | ||
| 305 | * Submit queued descriptors ASAP, i.e. before we go through | ||
| 306 | * the completed ones. | ||
| 307 | */ | ||
| 308 | if (!list_empty(&atchan->queue)) | ||
| 309 | atc_dostart(atchan, atc_first_queued(atchan)); | ||
| 310 | /* empty active_list now it is completed */ | ||
| 311 | list_splice_init(&atchan->active_list, &list); | ||
| 312 | /* empty queue list by moving descriptors (if any) to active_list */ | ||
| 313 | list_splice_init(&atchan->queue, &atchan->active_list); | ||
| 314 | |||
| 315 | list_for_each_entry_safe(desc, _desc, &list, desc_node) | ||
| 316 | atc_chain_complete(atchan, desc); | ||
| 317 | } | ||
| 318 | |||
| 319 | /** | ||
| 320 | * atc_cleanup_descriptors - cleanup up finished descriptors in active_list | ||
| 321 | * @atchan: channel to be cleaned up | ||
| 322 | * | ||
| 323 | * Called with atchan->lock held and bh disabled | ||
| 324 | */ | ||
| 325 | static void atc_cleanup_descriptors(struct at_dma_chan *atchan) | ||
| 326 | { | ||
| 327 | struct at_desc *desc, *_desc; | ||
| 328 | struct at_desc *child; | ||
| 329 | |||
| 330 | dev_vdbg(chan2dev(&atchan->chan_common), "cleanup descriptors\n"); | ||
| 331 | |||
| 332 | list_for_each_entry_safe(desc, _desc, &atchan->active_list, desc_node) { | ||
| 333 | if (!(desc->lli.ctrla & ATC_DONE)) | ||
| 334 | /* This one is currently in progress */ | ||
| 335 | return; | ||
| 336 | |||
| 337 | list_for_each_entry(child, &desc->txd.tx_list, desc_node) | ||
| 338 | if (!(child->lli.ctrla & ATC_DONE)) | ||
| 339 | /* Currently in progress */ | ||
| 340 | return; | ||
| 341 | |||
| 342 | /* | ||
| 343 | * No descriptors so far seem to be in progress, i.e. | ||
| 344 | * this chain must be done. | ||
| 345 | */ | ||
| 346 | atc_chain_complete(atchan, desc); | ||
| 347 | } | ||
| 348 | } | ||
| 349 | |||
| 350 | /** | ||
| 351 | * atc_advance_work - at the end of a transaction, move forward | ||
| 352 | * @atchan: channel where the transaction ended | ||
| 353 | * | ||
| 354 | * Called with atchan->lock held and bh disabled | ||
| 355 | */ | ||
| 356 | static void atc_advance_work(struct at_dma_chan *atchan) | ||
| 357 | { | ||
| 358 | dev_vdbg(chan2dev(&atchan->chan_common), "advance_work\n"); | ||
| 359 | |||
| 360 | if (list_empty(&atchan->active_list) || | ||
| 361 | list_is_singular(&atchan->active_list)) { | ||
| 362 | atc_complete_all(atchan); | ||
| 363 | } else { | ||
| 364 | atc_chain_complete(atchan, atc_first_active(atchan)); | ||
| 365 | /* advance work */ | ||
| 366 | atc_dostart(atchan, atc_first_active(atchan)); | ||
| 367 | } | ||
| 368 | } | ||
| 369 | |||
| 370 | |||
| 371 | /** | ||
| 372 | * atc_handle_error - handle errors reported by DMA controller | ||
| 373 | * @atchan: channel where error occurs | ||
| 374 | * | ||
| 375 | * Called with atchan->lock held and bh disabled | ||
| 376 | */ | ||
| 377 | static void atc_handle_error(struct at_dma_chan *atchan) | ||
| 378 | { | ||
| 379 | struct at_desc *bad_desc; | ||
| 380 | struct at_desc *child; | ||
| 381 | |||
| 382 | /* | ||
| 383 | * The descriptor currently at the head of the active list is | ||
| 384 | * broked. Since we don't have any way to report errors, we'll | ||
| 385 | * just have to scream loudly and try to carry on. | ||
| 386 | */ | ||
| 387 | bad_desc = atc_first_active(atchan); | ||
| 388 | list_del_init(&bad_desc->desc_node); | ||
| 389 | |||
| 390 | /* As we are stopped, take advantage to push queued descriptors | ||
| 391 | * in active_list */ | ||
| 392 | list_splice_init(&atchan->queue, atchan->active_list.prev); | ||
| 393 | |||
| 394 | /* Try to restart the controller */ | ||
| 395 | if (!list_empty(&atchan->active_list)) | ||
| 396 | atc_dostart(atchan, atc_first_active(atchan)); | ||
| 397 | |||
| 398 | /* | ||
| 399 | * KERN_CRITICAL may seem harsh, but since this only happens | ||
| 400 | * when someone submits a bad physical address in a | ||
| 401 | * descriptor, we should consider ourselves lucky that the | ||
| 402 | * controller flagged an error instead of scribbling over | ||
| 403 | * random memory locations. | ||
| 404 | */ | ||
| 405 | dev_crit(chan2dev(&atchan->chan_common), | ||
| 406 | "Bad descriptor submitted for DMA!\n"); | ||
| 407 | dev_crit(chan2dev(&atchan->chan_common), | ||
| 408 | " cookie: %d\n", bad_desc->txd.cookie); | ||
| 409 | atc_dump_lli(atchan, &bad_desc->lli); | ||
| 410 | list_for_each_entry(child, &bad_desc->txd.tx_list, desc_node) | ||
| 411 | atc_dump_lli(atchan, &child->lli); | ||
| 412 | |||
| 413 | /* Pretend the descriptor completed successfully */ | ||
| 414 | atc_chain_complete(atchan, bad_desc); | ||
| 415 | } | ||
| 416 | |||
| 417 | |||
| 418 | /*-- IRQ & Tasklet ---------------------------------------------------*/ | ||
| 419 | |||
| 420 | static void atc_tasklet(unsigned long data) | ||
| 421 | { | ||
| 422 | struct at_dma_chan *atchan = (struct at_dma_chan *)data; | ||
| 423 | |||
| 424 | /* Channel cannot be enabled here */ | ||
| 425 | if (atc_chan_is_enabled(atchan)) { | ||
| 426 | dev_err(chan2dev(&atchan->chan_common), | ||
| 427 | "BUG: channel enabled in tasklet\n"); | ||
| 428 | return; | ||
| 429 | } | ||
| 430 | |||
| 431 | spin_lock(&atchan->lock); | ||
| 432 | if (test_and_clear_bit(0, &atchan->error_status)) | ||
| 433 | atc_handle_error(atchan); | ||
| 434 | else | ||
| 435 | atc_advance_work(atchan); | ||
| 436 | |||
| 437 | spin_unlock(&atchan->lock); | ||
| 438 | } | ||
| 439 | |||
| 440 | static irqreturn_t at_dma_interrupt(int irq, void *dev_id) | ||
| 441 | { | ||
| 442 | struct at_dma *atdma = (struct at_dma *)dev_id; | ||
| 443 | struct at_dma_chan *atchan; | ||
| 444 | int i; | ||
| 445 | u32 status, pending, imr; | ||
| 446 | int ret = IRQ_NONE; | ||
| 447 | |||
| 448 | do { | ||
| 449 | imr = dma_readl(atdma, EBCIMR); | ||
| 450 | status = dma_readl(atdma, EBCISR); | ||
| 451 | pending = status & imr; | ||
| 452 | |||
| 453 | if (!pending) | ||
| 454 | break; | ||
| 455 | |||
| 456 | dev_vdbg(atdma->dma_common.dev, | ||
| 457 | "interrupt: status = 0x%08x, 0x%08x, 0x%08x\n", | ||
| 458 | status, imr, pending); | ||
| 459 | |||
| 460 | for (i = 0; i < atdma->dma_common.chancnt; i++) { | ||
| 461 | atchan = &atdma->chan[i]; | ||
| 462 | if (pending & (AT_DMA_CBTC(i) | AT_DMA_ERR(i))) { | ||
| 463 | if (pending & AT_DMA_ERR(i)) { | ||
| 464 | /* Disable channel on AHB error */ | ||
| 465 | dma_writel(atdma, CHDR, atchan->mask); | ||
| 466 | /* Give information to tasklet */ | ||
| 467 | set_bit(0, &atchan->error_status); | ||
| 468 | } | ||
| 469 | tasklet_schedule(&atchan->tasklet); | ||
| 470 | ret = IRQ_HANDLED; | ||
| 471 | } | ||
| 472 | } | ||
| 473 | |||
| 474 | } while (pending); | ||
| 475 | |||
| 476 | return ret; | ||
| 477 | } | ||
| 478 | |||
| 479 | |||
| 480 | /*-- DMA Engine API --------------------------------------------------*/ | ||
| 481 | |||
| 482 | /** | ||
| 483 | * atc_tx_submit - set the prepared descriptor(s) to be executed by the engine | ||
| 484 | * @desc: descriptor at the head of the transaction chain | ||
| 485 | * | ||
| 486 | * Queue chain if DMA engine is working already | ||
| 487 | * | ||
| 488 | * Cookie increment and adding to active_list or queue must be atomic | ||
| 489 | */ | ||
| 490 | static dma_cookie_t atc_tx_submit(struct dma_async_tx_descriptor *tx) | ||
| 491 | { | ||
| 492 | struct at_desc *desc = txd_to_at_desc(tx); | ||
| 493 | struct at_dma_chan *atchan = to_at_dma_chan(tx->chan); | ||
| 494 | dma_cookie_t cookie; | ||
| 495 | |||
| 496 | spin_lock_bh(&atchan->lock); | ||
| 497 | cookie = atc_assign_cookie(atchan, desc); | ||
| 498 | |||
| 499 | if (list_empty(&atchan->active_list)) { | ||
| 500 | dev_vdbg(chan2dev(tx->chan), "tx_submit: started %u\n", | ||
| 501 | desc->txd.cookie); | ||
| 502 | atc_dostart(atchan, desc); | ||
| 503 | list_add_tail(&desc->desc_node, &atchan->active_list); | ||
| 504 | } else { | ||
| 505 | dev_vdbg(chan2dev(tx->chan), "tx_submit: queued %u\n", | ||
| 506 | desc->txd.cookie); | ||
| 507 | list_add_tail(&desc->desc_node, &atchan->queue); | ||
| 508 | } | ||
| 509 | |||
| 510 | spin_unlock_bh(&atchan->lock); | ||
| 511 | |||
| 512 | return cookie; | ||
| 513 | } | ||
| 514 | |||
| 515 | /** | ||
| 516 | * atc_prep_dma_memcpy - prepare a memcpy operation | ||
| 517 | * @chan: the channel to prepare operation on | ||
| 518 | * @dest: operation virtual destination address | ||
| 519 | * @src: operation virtual source address | ||
| 520 | * @len: operation length | ||
| 521 | * @flags: tx descriptor status flags | ||
| 522 | */ | ||
| 523 | static struct dma_async_tx_descriptor * | ||
| 524 | atc_prep_dma_memcpy(struct dma_chan *chan, dma_addr_t dest, dma_addr_t src, | ||
| 525 | size_t len, unsigned long flags) | ||
| 526 | { | ||
| 527 | struct at_dma_chan *atchan = to_at_dma_chan(chan); | ||
| 528 | struct at_desc *desc = NULL; | ||
| 529 | struct at_desc *first = NULL; | ||
| 530 | struct at_desc *prev = NULL; | ||
| 531 | size_t xfer_count; | ||
| 532 | size_t offset; | ||
| 533 | unsigned int src_width; | ||
| 534 | unsigned int dst_width; | ||
| 535 | u32 ctrla; | ||
| 536 | u32 ctrlb; | ||
| 537 | |||
| 538 | dev_vdbg(chan2dev(chan), "prep_dma_memcpy: d0x%x s0x%x l0x%zx f0x%lx\n", | ||
| 539 | dest, src, len, flags); | ||
| 540 | |||
| 541 | if (unlikely(!len)) { | ||
| 542 | dev_dbg(chan2dev(chan), "prep_dma_memcpy: length is zero!\n"); | ||
| 543 | return NULL; | ||
| 544 | } | ||
| 545 | |||
| 546 | ctrla = ATC_DEFAULT_CTRLA; | ||
| 547 | ctrlb = ATC_DEFAULT_CTRLB | ||
| 548 | | ATC_SRC_ADDR_MODE_INCR | ||
| 549 | | ATC_DST_ADDR_MODE_INCR | ||
| 550 | | ATC_FC_MEM2MEM; | ||
| 551 | |||
| 552 | /* | ||
| 553 | * We can be a lot more clever here, but this should take care | ||
| 554 | * of the most common optimization. | ||
| 555 | */ | ||
| 556 | if (!((src | dest | len) & 3)) { | ||
| 557 | ctrla |= ATC_SRC_WIDTH_WORD | ATC_DST_WIDTH_WORD; | ||
| 558 | src_width = dst_width = 2; | ||
| 559 | } else if (!((src | dest | len) & 1)) { | ||
| 560 | ctrla |= ATC_SRC_WIDTH_HALFWORD | ATC_DST_WIDTH_HALFWORD; | ||
| 561 | src_width = dst_width = 1; | ||
| 562 | } else { | ||
| 563 | ctrla |= ATC_SRC_WIDTH_BYTE | ATC_DST_WIDTH_BYTE; | ||
| 564 | src_width = dst_width = 0; | ||
| 565 | } | ||
| 566 | |||
| 567 | for (offset = 0; offset < len; offset += xfer_count << src_width) { | ||
| 568 | xfer_count = min_t(size_t, (len - offset) >> src_width, | ||
| 569 | ATC_BTSIZE_MAX); | ||
| 570 | |||
| 571 | desc = atc_desc_get(atchan); | ||
| 572 | if (!desc) | ||
| 573 | goto err_desc_get; | ||
| 574 | |||
| 575 | desc->lli.saddr = src + offset; | ||
| 576 | desc->lli.daddr = dest + offset; | ||
| 577 | desc->lli.ctrla = ctrla | xfer_count; | ||
| 578 | desc->lli.ctrlb = ctrlb; | ||
| 579 | |||
| 580 | desc->txd.cookie = 0; | ||
| 581 | async_tx_ack(&desc->txd); | ||
| 582 | |||
| 583 | if (!first) { | ||
| 584 | first = desc; | ||
| 585 | } else { | ||
| 586 | /* inform the HW lli about chaining */ | ||
| 587 | prev->lli.dscr = desc->txd.phys; | ||
| 588 | /* insert the link descriptor to the LD ring */ | ||
| 589 | list_add_tail(&desc->desc_node, | ||
| 590 | &first->txd.tx_list); | ||
| 591 | } | ||
| 592 | prev = desc; | ||
| 593 | } | ||
| 594 | |||
| 595 | /* First descriptor of the chain embedds additional information */ | ||
| 596 | first->txd.cookie = -EBUSY; | ||
| 597 | first->len = len; | ||
| 598 | |||
| 599 | /* set end-of-link to the last link descriptor of list*/ | ||
| 600 | set_desc_eol(desc); | ||
| 601 | |||
| 602 | desc->txd.flags = flags; /* client is in control of this ack */ | ||
| 603 | |||
| 604 | return &first->txd; | ||
| 605 | |||
| 606 | err_desc_get: | ||
| 607 | atc_desc_put(atchan, first); | ||
| 608 | return NULL; | ||
| 609 | } | ||
| 610 | |||
| 611 | |||
| 612 | /** | ||
| 613 | * atc_prep_slave_sg - prepare descriptors for a DMA_SLAVE transaction | ||
| 614 | * @chan: DMA channel | ||
| 615 | * @sgl: scatterlist to transfer to/from | ||
| 616 | * @sg_len: number of entries in @scatterlist | ||
| 617 | * @direction: DMA direction | ||
| 618 | * @flags: tx descriptor status flags | ||
| 619 | */ | ||
| 620 | static struct dma_async_tx_descriptor * | ||
| 621 | atc_prep_slave_sg(struct dma_chan *chan, struct scatterlist *sgl, | ||
| 622 | unsigned int sg_len, enum dma_data_direction direction, | ||
| 623 | unsigned long flags) | ||
| 624 | { | ||
| 625 | struct at_dma_chan *atchan = to_at_dma_chan(chan); | ||
| 626 | struct at_dma_slave *atslave = chan->private; | ||
| 627 | struct at_desc *first = NULL; | ||
| 628 | struct at_desc *prev = NULL; | ||
| 629 | u32 ctrla; | ||
| 630 | u32 ctrlb; | ||
| 631 | dma_addr_t reg; | ||
| 632 | unsigned int reg_width; | ||
| 633 | unsigned int mem_width; | ||
| 634 | unsigned int i; | ||
| 635 | struct scatterlist *sg; | ||
| 636 | size_t total_len = 0; | ||
| 637 | |||
| 638 | dev_vdbg(chan2dev(chan), "prep_slave_sg: %s f0x%lx\n", | ||
| 639 | direction == DMA_TO_DEVICE ? "TO DEVICE" : "FROM DEVICE", | ||
| 640 | flags); | ||
| 641 | |||
| 642 | if (unlikely(!atslave || !sg_len)) { | ||
| 643 | dev_dbg(chan2dev(chan), "prep_dma_memcpy: length is zero!\n"); | ||
| 644 | return NULL; | ||
| 645 | } | ||
| 646 | |||
| 647 | reg_width = atslave->reg_width; | ||
| 648 | |||
| 649 | sg_len = dma_map_sg(chan2parent(chan), sgl, sg_len, direction); | ||
| 650 | |||
| 651 | ctrla = ATC_DEFAULT_CTRLA | atslave->ctrla; | ||
| 652 | ctrlb = ATC_DEFAULT_CTRLB | ATC_IEN; | ||
| 653 | |||
| 654 | switch (direction) { | ||
| 655 | case DMA_TO_DEVICE: | ||
| 656 | ctrla |= ATC_DST_WIDTH(reg_width); | ||
| 657 | ctrlb |= ATC_DST_ADDR_MODE_FIXED | ||
| 658 | | ATC_SRC_ADDR_MODE_INCR | ||
| 659 | | ATC_FC_MEM2PER; | ||
| 660 | reg = atslave->tx_reg; | ||
| 661 | for_each_sg(sgl, sg, sg_len, i) { | ||
| 662 | struct at_desc *desc; | ||
| 663 | u32 len; | ||
| 664 | u32 mem; | ||
| 665 | |||
| 666 | desc = atc_desc_get(atchan); | ||
| 667 | if (!desc) | ||
| 668 | goto err_desc_get; | ||
| 669 | |||
| 670 | mem = sg_phys(sg); | ||
| 671 | len = sg_dma_len(sg); | ||
| 672 | mem_width = 2; | ||
| 673 | if (unlikely(mem & 3 || len & 3)) | ||
| 674 | mem_width = 0; | ||
| 675 | |||
| 676 | desc->lli.saddr = mem; | ||
| 677 | desc->lli.daddr = reg; | ||
| 678 | desc->lli.ctrla = ctrla | ||
| 679 | | ATC_SRC_WIDTH(mem_width) | ||
| 680 | | len >> mem_width; | ||
| 681 | desc->lli.ctrlb = ctrlb; | ||
| 682 | |||
| 683 | if (!first) { | ||
| 684 | first = desc; | ||
| 685 | } else { | ||
| 686 | /* inform the HW lli about chaining */ | ||
| 687 | prev->lli.dscr = desc->txd.phys; | ||
| 688 | /* insert the link descriptor to the LD ring */ | ||
| 689 | list_add_tail(&desc->desc_node, | ||
| 690 | &first->txd.tx_list); | ||
| 691 | } | ||
| 692 | prev = desc; | ||
| 693 | total_len += len; | ||
| 694 | } | ||
| 695 | break; | ||
| 696 | case DMA_FROM_DEVICE: | ||
| 697 | ctrla |= ATC_SRC_WIDTH(reg_width); | ||
| 698 | ctrlb |= ATC_DST_ADDR_MODE_INCR | ||
| 699 | | ATC_SRC_ADDR_MODE_FIXED | ||
| 700 | | ATC_FC_PER2MEM; | ||
| 701 | |||
| 702 | reg = atslave->rx_reg; | ||
| 703 | for_each_sg(sgl, sg, sg_len, i) { | ||
| 704 | struct at_desc *desc; | ||
| 705 | u32 len; | ||
| 706 | u32 mem; | ||
| 707 | |||
| 708 | desc = atc_desc_get(atchan); | ||
| 709 | if (!desc) | ||
| 710 | goto err_desc_get; | ||
| 711 | |||
| 712 | mem = sg_phys(sg); | ||
| 713 | len = sg_dma_len(sg); | ||
| 714 | mem_width = 2; | ||
| 715 | if (unlikely(mem & 3 || len & 3)) | ||
| 716 | mem_width = 0; | ||
| 717 | |||
| 718 | desc->lli.saddr = reg; | ||
| 719 | desc->lli.daddr = mem; | ||
| 720 | desc->lli.ctrla = ctrla | ||
| 721 | | ATC_DST_WIDTH(mem_width) | ||
| 722 | | len >> mem_width; | ||
| 723 | desc->lli.ctrlb = ctrlb; | ||
| 724 | |||
| 725 | if (!first) { | ||
| 726 | first = desc; | ||
| 727 | } else { | ||
| 728 | /* inform the HW lli about chaining */ | ||
| 729 | prev->lli.dscr = desc->txd.phys; | ||
| 730 | /* insert the link descriptor to the LD ring */ | ||
| 731 | list_add_tail(&desc->desc_node, | ||
| 732 | &first->txd.tx_list); | ||
| 733 | } | ||
| 734 | prev = desc; | ||
| 735 | total_len += len; | ||
| 736 | } | ||
| 737 | break; | ||
| 738 | default: | ||
| 739 | return NULL; | ||
| 740 | } | ||
| 741 | |||
| 742 | /* set end-of-link to the last link descriptor of list*/ | ||
| 743 | set_desc_eol(prev); | ||
| 744 | |||
| 745 | /* First descriptor of the chain embedds additional information */ | ||
| 746 | first->txd.cookie = -EBUSY; | ||
| 747 | first->len = total_len; | ||
| 748 | |||
| 749 | /* last link descriptor of list is responsible of flags */ | ||
| 750 | prev->txd.flags = flags; /* client is in control of this ack */ | ||
| 751 | |||
| 752 | return &first->txd; | ||
| 753 | |||
| 754 | err_desc_get: | ||
| 755 | dev_err(chan2dev(chan), "not enough descriptors available\n"); | ||
| 756 | atc_desc_put(atchan, first); | ||
| 757 | return NULL; | ||
| 758 | } | ||
| 759 | |||
| 760 | static void atc_terminate_all(struct dma_chan *chan) | ||
| 761 | { | ||
| 762 | struct at_dma_chan *atchan = to_at_dma_chan(chan); | ||
| 763 | struct at_dma *atdma = to_at_dma(chan->device); | ||
| 764 | struct at_desc *desc, *_desc; | ||
| 765 | LIST_HEAD(list); | ||
| 766 | |||
| 767 | /* | ||
| 768 | * This is only called when something went wrong elsewhere, so | ||
| 769 | * we don't really care about the data. Just disable the | ||
| 770 | * channel. We still have to poll the channel enable bit due | ||
| 771 | * to AHB/HSB limitations. | ||
| 772 | */ | ||
| 773 | spin_lock_bh(&atchan->lock); | ||
| 774 | |||
| 775 | dma_writel(atdma, CHDR, atchan->mask); | ||
| 776 | |||
| 777 | /* confirm that this channel is disabled */ | ||
| 778 | while (dma_readl(atdma, CHSR) & atchan->mask) | ||
| 779 | cpu_relax(); | ||
| 780 | |||
| 781 | /* active_list entries will end up before queued entries */ | ||
| 782 | list_splice_init(&atchan->queue, &list); | ||
| 783 | list_splice_init(&atchan->active_list, &list); | ||
| 784 | |||
| 785 | spin_unlock_bh(&atchan->lock); | ||
| 786 | |||
| 787 | /* Flush all pending and queued descriptors */ | ||
| 788 | list_for_each_entry_safe(desc, _desc, &list, desc_node) | ||
| 789 | atc_chain_complete(atchan, desc); | ||
| 790 | } | ||
| 791 | |||
| 792 | /** | ||
| 793 | * atc_is_tx_complete - poll for transaction completion | ||
| 794 | * @chan: DMA channel | ||
| 795 | * @cookie: transaction identifier to check status of | ||
| 796 | * @done: if not %NULL, updated with last completed transaction | ||
| 797 | * @used: if not %NULL, updated with last used transaction | ||
| 798 | * | ||
| 799 | * If @done and @used are passed in, upon return they reflect the driver | ||
| 800 | * internal state and can be used with dma_async_is_complete() to check | ||
| 801 | * the status of multiple cookies without re-checking hardware state. | ||
| 802 | */ | ||
| 803 | static enum dma_status | ||
| 804 | atc_is_tx_complete(struct dma_chan *chan, | ||
| 805 | dma_cookie_t cookie, | ||
| 806 | dma_cookie_t *done, dma_cookie_t *used) | ||
| 807 | { | ||
| 808 | struct at_dma_chan *atchan = to_at_dma_chan(chan); | ||
| 809 | dma_cookie_t last_used; | ||
| 810 | dma_cookie_t last_complete; | ||
| 811 | enum dma_status ret; | ||
| 812 | |||
| 813 | dev_vdbg(chan2dev(chan), "is_tx_complete: %d (d%d, u%d)\n", | ||
| 814 | cookie, done ? *done : 0, used ? *used : 0); | ||
| 815 | |||
| 816 | spin_lock_bh(atchan->lock); | ||
| 817 | |||
| 818 | last_complete = atchan->completed_cookie; | ||
| 819 | last_used = chan->cookie; | ||
| 820 | |||
| 821 | ret = dma_async_is_complete(cookie, last_complete, last_used); | ||
| 822 | if (ret != DMA_SUCCESS) { | ||
| 823 | atc_cleanup_descriptors(atchan); | ||
| 824 | |||
| 825 | last_complete = atchan->completed_cookie; | ||
| 826 | last_used = chan->cookie; | ||
| 827 | |||
| 828 | ret = dma_async_is_complete(cookie, last_complete, last_used); | ||
| 829 | } | ||
| 830 | |||
| 831 | spin_unlock_bh(atchan->lock); | ||
| 832 | |||
| 833 | if (done) | ||
| 834 | *done = last_complete; | ||
| 835 | if (used) | ||
| 836 | *used = last_used; | ||
| 837 | |||
| 838 | return ret; | ||
| 839 | } | ||
| 840 | |||
| 841 | /** | ||
| 842 | * atc_issue_pending - try to finish work | ||
| 843 | * @chan: target DMA channel | ||
| 844 | */ | ||
| 845 | static void atc_issue_pending(struct dma_chan *chan) | ||
| 846 | { | ||
| 847 | struct at_dma_chan *atchan = to_at_dma_chan(chan); | ||
| 848 | |||
| 849 | dev_vdbg(chan2dev(chan), "issue_pending\n"); | ||
| 850 | |||
| 851 | if (!atc_chan_is_enabled(atchan)) { | ||
| 852 | spin_lock_bh(&atchan->lock); | ||
| 853 | atc_advance_work(atchan); | ||
| 854 | spin_unlock_bh(&atchan->lock); | ||
| 855 | } | ||
| 856 | } | ||
| 857 | |||
| 858 | /** | ||
| 859 | * atc_alloc_chan_resources - allocate resources for DMA channel | ||
| 860 | * @chan: allocate descriptor resources for this channel | ||
| 861 | * @client: current client requesting the channel be ready for requests | ||
| 862 | * | ||
| 863 | * return - the number of allocated descriptors | ||
| 864 | */ | ||
| 865 | static int atc_alloc_chan_resources(struct dma_chan *chan) | ||
| 866 | { | ||
| 867 | struct at_dma_chan *atchan = to_at_dma_chan(chan); | ||
| 868 | struct at_dma *atdma = to_at_dma(chan->device); | ||
| 869 | struct at_desc *desc; | ||
| 870 | struct at_dma_slave *atslave; | ||
| 871 | int i; | ||
| 872 | u32 cfg; | ||
| 873 | LIST_HEAD(tmp_list); | ||
| 874 | |||
| 875 | dev_vdbg(chan2dev(chan), "alloc_chan_resources\n"); | ||
| 876 | |||
| 877 | /* ASSERT: channel is idle */ | ||
| 878 | if (atc_chan_is_enabled(atchan)) { | ||
| 879 | dev_dbg(chan2dev(chan), "DMA channel not idle ?\n"); | ||
| 880 | return -EIO; | ||
| 881 | } | ||
| 882 | |||
| 883 | cfg = ATC_DEFAULT_CFG; | ||
| 884 | |||
| 885 | atslave = chan->private; | ||
| 886 | if (atslave) { | ||
| 887 | /* | ||
| 888 | * We need controller-specific data to set up slave | ||
| 889 | * transfers. | ||
| 890 | */ | ||
| 891 | BUG_ON(!atslave->dma_dev || atslave->dma_dev != atdma->dma_common.dev); | ||
| 892 | |||
| 893 | /* if cfg configuration specified take it instad of default */ | ||
| 894 | if (atslave->cfg) | ||
| 895 | cfg = atslave->cfg; | ||
| 896 | } | ||
| 897 | |||
| 898 | /* have we already been set up? | ||
| 899 | * reconfigure channel but no need to reallocate descriptors */ | ||
| 900 | if (!list_empty(&atchan->free_list)) | ||
| 901 | return atchan->descs_allocated; | ||
| 902 | |||
| 903 | /* Allocate initial pool of descriptors */ | ||
| 904 | for (i = 0; i < init_nr_desc_per_channel; i++) { | ||
| 905 | desc = atc_alloc_descriptor(chan, GFP_KERNEL); | ||
| 906 | if (!desc) { | ||
| 907 | dev_err(atdma->dma_common.dev, | ||
| 908 | "Only %d initial descriptors\n", i); | ||
| 909 | break; | ||
| 910 | } | ||
| 911 | list_add_tail(&desc->desc_node, &tmp_list); | ||
| 912 | } | ||
| 913 | |||
| 914 | spin_lock_bh(&atchan->lock); | ||
| 915 | atchan->descs_allocated = i; | ||
| 916 | list_splice(&tmp_list, &atchan->free_list); | ||
| 917 | atchan->completed_cookie = chan->cookie = 1; | ||
| 918 | spin_unlock_bh(&atchan->lock); | ||
| 919 | |||
| 920 | /* channel parameters */ | ||
| 921 | channel_writel(atchan, CFG, cfg); | ||
| 922 | |||
| 923 | dev_dbg(chan2dev(chan), | ||
| 924 | "alloc_chan_resources: allocated %d descriptors\n", | ||
| 925 | atchan->descs_allocated); | ||
| 926 | |||
| 927 | return atchan->descs_allocated; | ||
| 928 | } | ||
| 929 | |||
| 930 | /** | ||
| 931 | * atc_free_chan_resources - free all channel resources | ||
| 932 | * @chan: DMA channel | ||
| 933 | */ | ||
| 934 | static void atc_free_chan_resources(struct dma_chan *chan) | ||
| 935 | { | ||
| 936 | struct at_dma_chan *atchan = to_at_dma_chan(chan); | ||
| 937 | struct at_dma *atdma = to_at_dma(chan->device); | ||
| 938 | struct at_desc *desc, *_desc; | ||
| 939 | LIST_HEAD(list); | ||
| 940 | |||
| 941 | dev_dbg(chan2dev(chan), "free_chan_resources: (descs allocated=%u)\n", | ||
| 942 | atchan->descs_allocated); | ||
| 943 | |||
| 944 | /* ASSERT: channel is idle */ | ||
| 945 | BUG_ON(!list_empty(&atchan->active_list)); | ||
| 946 | BUG_ON(!list_empty(&atchan->queue)); | ||
| 947 | BUG_ON(atc_chan_is_enabled(atchan)); | ||
| 948 | |||
| 949 | list_for_each_entry_safe(desc, _desc, &atchan->free_list, desc_node) { | ||
| 950 | dev_vdbg(chan2dev(chan), " freeing descriptor %p\n", desc); | ||
| 951 | list_del(&desc->desc_node); | ||
| 952 | /* free link descriptor */ | ||
| 953 | dma_pool_free(atdma->dma_desc_pool, desc, desc->txd.phys); | ||
| 954 | } | ||
| 955 | list_splice_init(&atchan->free_list, &list); | ||
| 956 | atchan->descs_allocated = 0; | ||
| 957 | |||
| 958 | dev_vdbg(chan2dev(chan), "free_chan_resources: done\n"); | ||
| 959 | } | ||
| 960 | |||
| 961 | |||
| 962 | /*-- Module Management -----------------------------------------------*/ | ||
| 963 | |||
| 964 | /** | ||
| 965 | * at_dma_off - disable DMA controller | ||
| 966 | * @atdma: the Atmel HDAMC device | ||
| 967 | */ | ||
| 968 | static void at_dma_off(struct at_dma *atdma) | ||
| 969 | { | ||
| 970 | dma_writel(atdma, EN, 0); | ||
| 971 | |||
| 972 | /* disable all interrupts */ | ||
| 973 | dma_writel(atdma, EBCIDR, -1L); | ||
| 974 | |||
| 975 | /* confirm that all channels are disabled */ | ||
| 976 | while (dma_readl(atdma, CHSR) & atdma->all_chan_mask) | ||
| 977 | cpu_relax(); | ||
| 978 | } | ||
| 979 | |||
| 980 | static int __init at_dma_probe(struct platform_device *pdev) | ||
| 981 | { | ||
| 982 | struct at_dma_platform_data *pdata; | ||
| 983 | struct resource *io; | ||
| 984 | struct at_dma *atdma; | ||
| 985 | size_t size; | ||
| 986 | int irq; | ||
| 987 | int err; | ||
| 988 | int i; | ||
| 989 | |||
| 990 | /* get DMA Controller parameters from platform */ | ||
| 991 | pdata = pdev->dev.platform_data; | ||
| 992 | if (!pdata || pdata->nr_channels > AT_DMA_MAX_NR_CHANNELS) | ||
| 993 | return -EINVAL; | ||
| 994 | |||
| 995 | io = platform_get_resource(pdev, IORESOURCE_MEM, 0); | ||
| 996 | if (!io) | ||
| 997 | return -EINVAL; | ||
| 998 | |||
| 999 | irq = platform_get_irq(pdev, 0); | ||
| 1000 | if (irq < 0) | ||
| 1001 | return irq; | ||
| 1002 | |||
| 1003 | size = sizeof(struct at_dma); | ||
| 1004 | size += pdata->nr_channels * sizeof(struct at_dma_chan); | ||
| 1005 | atdma = kzalloc(size, GFP_KERNEL); | ||
| 1006 | if (!atdma) | ||
| 1007 | return -ENOMEM; | ||
| 1008 | |||
| 1009 | /* discover transaction capabilites from the platform data */ | ||
| 1010 | atdma->dma_common.cap_mask = pdata->cap_mask; | ||
| 1011 | atdma->all_chan_mask = (1 << pdata->nr_channels) - 1; | ||
| 1012 | |||
| 1013 | size = io->end - io->start + 1; | ||
| 1014 | if (!request_mem_region(io->start, size, pdev->dev.driver->name)) { | ||
| 1015 | err = -EBUSY; | ||
| 1016 | goto err_kfree; | ||
| 1017 | } | ||
| 1018 | |||
| 1019 | atdma->regs = ioremap(io->start, size); | ||
| 1020 | if (!atdma->regs) { | ||
| 1021 | err = -ENOMEM; | ||
| 1022 | goto err_release_r; | ||
| 1023 | } | ||
| 1024 | |||
| 1025 | atdma->clk = clk_get(&pdev->dev, "dma_clk"); | ||
| 1026 | if (IS_ERR(atdma->clk)) { | ||
| 1027 | err = PTR_ERR(atdma->clk); | ||
| 1028 | goto err_clk; | ||
| 1029 | } | ||
| 1030 | clk_enable(atdma->clk); | ||
| 1031 | |||
| 1032 | /* force dma off, just in case */ | ||
| 1033 | at_dma_off(atdma); | ||
| 1034 | |||
| 1035 | err = request_irq(irq, at_dma_interrupt, 0, "at_hdmac", atdma); | ||
| 1036 | if (err) | ||
| 1037 | goto err_irq; | ||
| 1038 | |||
| 1039 | platform_set_drvdata(pdev, atdma); | ||
| 1040 | |||
| 1041 | /* create a pool of consistent memory blocks for hardware descriptors */ | ||
| 1042 | atdma->dma_desc_pool = dma_pool_create("at_hdmac_desc_pool", | ||
| 1043 | &pdev->dev, sizeof(struct at_desc), | ||
| 1044 | 4 /* word alignment */, 0); | ||
| 1045 | if (!atdma->dma_desc_pool) { | ||
| 1046 | dev_err(&pdev->dev, "No memory for descriptors dma pool\n"); | ||
| 1047 | err = -ENOMEM; | ||
| 1048 | goto err_pool_create; | ||
| 1049 | } | ||
| 1050 | |||
| 1051 | /* clear any pending interrupt */ | ||
| 1052 | while (dma_readl(atdma, EBCISR)) | ||
| 1053 | cpu_relax(); | ||
| 1054 | |||
| 1055 | /* initialize channels related values */ | ||
| 1056 | INIT_LIST_HEAD(&atdma->dma_common.channels); | ||
| 1057 | for (i = 0; i < pdata->nr_channels; i++, atdma->dma_common.chancnt++) { | ||
| 1058 | struct at_dma_chan *atchan = &atdma->chan[i]; | ||
| 1059 | |||
| 1060 | atchan->chan_common.device = &atdma->dma_common; | ||
| 1061 | atchan->chan_common.cookie = atchan->completed_cookie = 1; | ||
| 1062 | atchan->chan_common.chan_id = i; | ||
| 1063 | list_add_tail(&atchan->chan_common.device_node, | ||
| 1064 | &atdma->dma_common.channels); | ||
| 1065 | |||
| 1066 | atchan->ch_regs = atdma->regs + ch_regs(i); | ||
| 1067 | spin_lock_init(&atchan->lock); | ||
| 1068 | atchan->mask = 1 << i; | ||
| 1069 | |||
| 1070 | INIT_LIST_HEAD(&atchan->active_list); | ||
| 1071 | INIT_LIST_HEAD(&atchan->queue); | ||
| 1072 | INIT_LIST_HEAD(&atchan->free_list); | ||
| 1073 | |||
| 1074 | tasklet_init(&atchan->tasklet, atc_tasklet, | ||
| 1075 | (unsigned long)atchan); | ||
| 1076 | atc_enable_irq(atchan); | ||
| 1077 | } | ||
| 1078 | |||
| 1079 | /* set base routines */ | ||
| 1080 | atdma->dma_common.device_alloc_chan_resources = atc_alloc_chan_resources; | ||
| 1081 | atdma->dma_common.device_free_chan_resources = atc_free_chan_resources; | ||
| 1082 | atdma->dma_common.device_is_tx_complete = atc_is_tx_complete; | ||
| 1083 | atdma->dma_common.device_issue_pending = atc_issue_pending; | ||
| 1084 | atdma->dma_common.dev = &pdev->dev; | ||
| 1085 | |||
| 1086 | /* set prep routines based on capability */ | ||
| 1087 | if (dma_has_cap(DMA_MEMCPY, atdma->dma_common.cap_mask)) | ||
| 1088 | atdma->dma_common.device_prep_dma_memcpy = atc_prep_dma_memcpy; | ||
| 1089 | |||
| 1090 | if (dma_has_cap(DMA_SLAVE, atdma->dma_common.cap_mask)) { | ||
| 1091 | atdma->dma_common.device_prep_slave_sg = atc_prep_slave_sg; | ||
| 1092 | atdma->dma_common.device_terminate_all = atc_terminate_all; | ||
| 1093 | } | ||
| 1094 | |||
| 1095 | dma_writel(atdma, EN, AT_DMA_ENABLE); | ||
| 1096 | |||
| 1097 | dev_info(&pdev->dev, "Atmel AHB DMA Controller ( %s%s), %d channels\n", | ||
| 1098 | dma_has_cap(DMA_MEMCPY, atdma->dma_common.cap_mask) ? "cpy " : "", | ||
| 1099 | dma_has_cap(DMA_SLAVE, atdma->dma_common.cap_mask) ? "slave " : "", | ||
| 1100 | atdma->dma_common.chancnt); | ||
| 1101 | |||
| 1102 | dma_async_device_register(&atdma->dma_common); | ||
| 1103 | |||
| 1104 | return 0; | ||
| 1105 | |||
| 1106 | err_pool_create: | ||
| 1107 | platform_set_drvdata(pdev, NULL); | ||
| 1108 | free_irq(platform_get_irq(pdev, 0), atdma); | ||
| 1109 | err_irq: | ||
| 1110 | clk_disable(atdma->clk); | ||
| 1111 | clk_put(atdma->clk); | ||
| 1112 | err_clk: | ||
| 1113 | iounmap(atdma->regs); | ||
| 1114 | atdma->regs = NULL; | ||
| 1115 | err_release_r: | ||
| 1116 | release_mem_region(io->start, size); | ||
| 1117 | err_kfree: | ||
| 1118 | kfree(atdma); | ||
| 1119 | return err; | ||
| 1120 | } | ||
| 1121 | |||
| 1122 | static int __exit at_dma_remove(struct platform_device *pdev) | ||
| 1123 | { | ||
| 1124 | struct at_dma *atdma = platform_get_drvdata(pdev); | ||
| 1125 | struct dma_chan *chan, *_chan; | ||
| 1126 | struct resource *io; | ||
| 1127 | |||
| 1128 | at_dma_off(atdma); | ||
| 1129 | dma_async_device_unregister(&atdma->dma_common); | ||
| 1130 | |||
| 1131 | dma_pool_destroy(atdma->dma_desc_pool); | ||
| 1132 | platform_set_drvdata(pdev, NULL); | ||
| 1133 | free_irq(platform_get_irq(pdev, 0), atdma); | ||
| 1134 | |||
| 1135 | list_for_each_entry_safe(chan, _chan, &atdma->dma_common.channels, | ||
| 1136 | device_node) { | ||
| 1137 | struct at_dma_chan *atchan = to_at_dma_chan(chan); | ||
| 1138 | |||
| 1139 | /* Disable interrupts */ | ||
| 1140 | atc_disable_irq(atchan); | ||
| 1141 | tasklet_disable(&atchan->tasklet); | ||
| 1142 | |||
| 1143 | tasklet_kill(&atchan->tasklet); | ||
| 1144 | list_del(&chan->device_node); | ||
| 1145 | } | ||
| 1146 | |||
| 1147 | clk_disable(atdma->clk); | ||
| 1148 | clk_put(atdma->clk); | ||
| 1149 | |||
| 1150 | iounmap(atdma->regs); | ||
| 1151 | atdma->regs = NULL; | ||
| 1152 | |||
| 1153 | io = platform_get_resource(pdev, IORESOURCE_MEM, 0); | ||
| 1154 | release_mem_region(io->start, io->end - io->start + 1); | ||
| 1155 | |||
| 1156 | kfree(atdma); | ||
| 1157 | |||
| 1158 | return 0; | ||
| 1159 | } | ||
| 1160 | |||
| 1161 | static void at_dma_shutdown(struct platform_device *pdev) | ||
| 1162 | { | ||
| 1163 | struct at_dma *atdma = platform_get_drvdata(pdev); | ||
| 1164 | |||
| 1165 | at_dma_off(platform_get_drvdata(pdev)); | ||
| 1166 | clk_disable(atdma->clk); | ||
| 1167 | } | ||
| 1168 | |||
| 1169 | static int at_dma_suspend_late(struct platform_device *pdev, pm_message_t mesg) | ||
| 1170 | { | ||
| 1171 | struct at_dma *atdma = platform_get_drvdata(pdev); | ||
| 1172 | |||
| 1173 | at_dma_off(platform_get_drvdata(pdev)); | ||
| 1174 | clk_disable(atdma->clk); | ||
| 1175 | return 0; | ||
| 1176 | } | ||
| 1177 | |||
| 1178 | static int at_dma_resume_early(struct platform_device *pdev) | ||
| 1179 | { | ||
| 1180 | struct at_dma *atdma = platform_get_drvdata(pdev); | ||
| 1181 | |||
| 1182 | clk_enable(atdma->clk); | ||
| 1183 | dma_writel(atdma, EN, AT_DMA_ENABLE); | ||
| 1184 | return 0; | ||
| 1185 | |||
| 1186 | } | ||
| 1187 | |||
| 1188 | static struct platform_driver at_dma_driver = { | ||
| 1189 | .remove = __exit_p(at_dma_remove), | ||
| 1190 | .shutdown = at_dma_shutdown, | ||
| 1191 | .suspend_late = at_dma_suspend_late, | ||
| 1192 | .resume_early = at_dma_resume_early, | ||
| 1193 | .driver = { | ||
| 1194 | .name = "at_hdmac", | ||
| 1195 | }, | ||
| 1196 | }; | ||
| 1197 | |||
| 1198 | static int __init at_dma_init(void) | ||
| 1199 | { | ||
| 1200 | return platform_driver_probe(&at_dma_driver, at_dma_probe); | ||
| 1201 | } | ||
| 1202 | module_init(at_dma_init); | ||
| 1203 | |||
| 1204 | static void __exit at_dma_exit(void) | ||
| 1205 | { | ||
| 1206 | platform_driver_unregister(&at_dma_driver); | ||
| 1207 | } | ||
| 1208 | module_exit(at_dma_exit); | ||
| 1209 | |||
| 1210 | MODULE_DESCRIPTION("Atmel AHB DMA Controller driver"); | ||
| 1211 | MODULE_AUTHOR("Nicolas Ferre <nicolas.ferre@atmel.com>"); | ||
| 1212 | MODULE_LICENSE("GPL"); | ||
| 1213 | MODULE_ALIAS("platform:at_hdmac"); | ||
diff --git a/drivers/dma/at_hdmac_regs.h b/drivers/dma/at_hdmac_regs.h new file mode 100644 index 000000000000..4c972afc49ec --- /dev/null +++ b/drivers/dma/at_hdmac_regs.h | |||
| @@ -0,0 +1,353 @@ | |||
| 1 | /* | ||
| 2 | * Header file for the Atmel AHB DMA Controller driver | ||
| 3 | * | ||
| 4 | * Copyright (C) 2008 Atmel Corporation | ||
| 5 | * | ||
| 6 | * This program is free software; you can redistribute it and/or modify | ||
| 7 | * it under the terms of the GNU General Public License as published by | ||
| 8 | * the Free Software Foundation; either version 2 of the License, or | ||
| 9 | * (at your option) any later version. | ||
| 10 | */ | ||
| 11 | #ifndef AT_HDMAC_REGS_H | ||
| 12 | #define AT_HDMAC_REGS_H | ||
| 13 | |||
| 14 | #include <mach/at_hdmac.h> | ||
| 15 | |||
| 16 | #define AT_DMA_MAX_NR_CHANNELS 8 | ||
| 17 | |||
| 18 | |||
| 19 | #define AT_DMA_GCFG 0x00 /* Global Configuration Register */ | ||
| 20 | #define AT_DMA_IF_BIGEND(i) (0x1 << (i)) /* AHB-Lite Interface i in Big-endian mode */ | ||
| 21 | #define AT_DMA_ARB_CFG (0x1 << 4) /* Arbiter mode. */ | ||
| 22 | #define AT_DMA_ARB_CFG_FIXED (0x0 << 4) | ||
| 23 | #define AT_DMA_ARB_CFG_ROUND_ROBIN (0x1 << 4) | ||
| 24 | |||
| 25 | #define AT_DMA_EN 0x04 /* Controller Enable Register */ | ||
| 26 | #define AT_DMA_ENABLE (0x1 << 0) | ||
| 27 | |||
| 28 | #define AT_DMA_SREQ 0x08 /* Software Single Request Register */ | ||
| 29 | #define AT_DMA_SSREQ(x) (0x1 << ((x) << 1)) /* Request a source single transfer on channel x */ | ||
| 30 | #define AT_DMA_DSREQ(x) (0x1 << (1 + ((x) << 1))) /* Request a destination single transfer on channel x */ | ||
| 31 | |||
| 32 | #define AT_DMA_CREQ 0x0C /* Software Chunk Transfer Request Register */ | ||
| 33 | #define AT_DMA_SCREQ(x) (0x1 << ((x) << 1)) /* Request a source chunk transfer on channel x */ | ||
| 34 | #define AT_DMA_DCREQ(x) (0x1 << (1 + ((x) << 1))) /* Request a destination chunk transfer on channel x */ | ||
| 35 | |||
| 36 | #define AT_DMA_LAST 0x10 /* Software Last Transfer Flag Register */ | ||
| 37 | #define AT_DMA_SLAST(x) (0x1 << ((x) << 1)) /* This src rq is last tx of buffer on channel x */ | ||
| 38 | #define AT_DMA_DLAST(x) (0x1 << (1 + ((x) << 1))) /* This dst rq is last tx of buffer on channel x */ | ||
| 39 | |||
| 40 | #define AT_DMA_SYNC 0x14 /* Request Synchronization Register */ | ||
| 41 | #define AT_DMA_SYR(h) (0x1 << (h)) /* Synchronize handshake line h */ | ||
| 42 | |||
| 43 | /* Error, Chained Buffer transfer completed and Buffer transfer completed Interrupt registers */ | ||
| 44 | #define AT_DMA_EBCIER 0x18 /* Enable register */ | ||
| 45 | #define AT_DMA_EBCIDR 0x1C /* Disable register */ | ||
| 46 | #define AT_DMA_EBCIMR 0x20 /* Mask Register */ | ||
| 47 | #define AT_DMA_EBCISR 0x24 /* Status Register */ | ||
| 48 | #define AT_DMA_CBTC_OFFSET 8 | ||
| 49 | #define AT_DMA_ERR_OFFSET 16 | ||
| 50 | #define AT_DMA_BTC(x) (0x1 << (x)) | ||
| 51 | #define AT_DMA_CBTC(x) (0x1 << (AT_DMA_CBTC_OFFSET + (x))) | ||
| 52 | #define AT_DMA_ERR(x) (0x1 << (AT_DMA_ERR_OFFSET + (x))) | ||
| 53 | |||
| 54 | #define AT_DMA_CHER 0x28 /* Channel Handler Enable Register */ | ||
| 55 | #define AT_DMA_ENA(x) (0x1 << (x)) | ||
| 56 | #define AT_DMA_SUSP(x) (0x1 << ( 8 + (x))) | ||
| 57 | #define AT_DMA_KEEP(x) (0x1 << (24 + (x))) | ||
| 58 | |||
| 59 | #define AT_DMA_CHDR 0x2C /* Channel Handler Disable Register */ | ||
| 60 | #define AT_DMA_DIS(x) (0x1 << (x)) | ||
| 61 | #define AT_DMA_RES(x) (0x1 << ( 8 + (x))) | ||
| 62 | |||
| 63 | #define AT_DMA_CHSR 0x30 /* Channel Handler Status Register */ | ||
| 64 | #define AT_DMA_EMPT(x) (0x1 << (16 + (x))) | ||
| 65 | #define AT_DMA_STAL(x) (0x1 << (24 + (x))) | ||
| 66 | |||
| 67 | |||
| 68 | #define AT_DMA_CH_REGS_BASE 0x3C /* Channel registers base address */ | ||
| 69 | #define ch_regs(x) (AT_DMA_CH_REGS_BASE + (x) * 0x28) /* Channel x base addr */ | ||
| 70 | |||
| 71 | /* Hardware register offset for each channel */ | ||
| 72 | #define ATC_SADDR_OFFSET 0x00 /* Source Address Register */ | ||
| 73 | #define ATC_DADDR_OFFSET 0x04 /* Destination Address Register */ | ||
| 74 | #define ATC_DSCR_OFFSET 0x08 /* Descriptor Address Register */ | ||
| 75 | #define ATC_CTRLA_OFFSET 0x0C /* Control A Register */ | ||
| 76 | #define ATC_CTRLB_OFFSET 0x10 /* Control B Register */ | ||
| 77 | #define ATC_CFG_OFFSET 0x14 /* Configuration Register */ | ||
| 78 | #define ATC_SPIP_OFFSET 0x18 /* Src PIP Configuration Register */ | ||
| 79 | #define ATC_DPIP_OFFSET 0x1C /* Dst PIP Configuration Register */ | ||
| 80 | |||
| 81 | |||
| 82 | /* Bitfield definitions */ | ||
| 83 | |||
| 84 | /* Bitfields in DSCR */ | ||
| 85 | #define ATC_DSCR_IF(i) (0x3 & (i)) /* Dsc feched via AHB-Lite Interface i */ | ||
| 86 | |||
| 87 | /* Bitfields in CTRLA */ | ||
| 88 | #define ATC_BTSIZE_MAX 0xFFFFUL /* Maximum Buffer Transfer Size */ | ||
| 89 | #define ATC_BTSIZE(x) (ATC_BTSIZE_MAX & (x)) /* Buffer Transfer Size */ | ||
| 90 | /* Chunck Tranfer size definitions are in at_hdmac.h */ | ||
| 91 | #define ATC_SRC_WIDTH_MASK (0x3 << 24) /* Source Single Transfer Size */ | ||
| 92 | #define ATC_SRC_WIDTH(x) ((x) << 24) | ||
| 93 | #define ATC_SRC_WIDTH_BYTE (0x0 << 24) | ||
| 94 | #define ATC_SRC_WIDTH_HALFWORD (0x1 << 24) | ||
| 95 | #define ATC_SRC_WIDTH_WORD (0x2 << 24) | ||
| 96 | #define ATC_DST_WIDTH_MASK (0x3 << 28) /* Destination Single Transfer Size */ | ||
| 97 | #define ATC_DST_WIDTH(x) ((x) << 28) | ||
| 98 | #define ATC_DST_WIDTH_BYTE (0x0 << 28) | ||
| 99 | #define ATC_DST_WIDTH_HALFWORD (0x1 << 28) | ||
| 100 | #define ATC_DST_WIDTH_WORD (0x2 << 28) | ||
| 101 | #define ATC_DONE (0x1 << 31) /* Tx Done (only written back in descriptor) */ | ||
| 102 | |||
| 103 | /* Bitfields in CTRLB */ | ||
| 104 | #define ATC_SIF(i) (0x3 & (i)) /* Src tx done via AHB-Lite Interface i */ | ||
| 105 | #define ATC_DIF(i) ((0x3 & (i)) << 4) /* Dst tx done via AHB-Lite Interface i */ | ||
| 106 | #define ATC_SRC_PIP (0x1 << 8) /* Source Picture-in-Picture enabled */ | ||
| 107 | #define ATC_DST_PIP (0x1 << 12) /* Destination Picture-in-Picture enabled */ | ||
| 108 | #define ATC_SRC_DSCR_DIS (0x1 << 16) /* Src Descriptor fetch disable */ | ||
| 109 | #define ATC_DST_DSCR_DIS (0x1 << 20) /* Dst Descriptor fetch disable */ | ||
| 110 | #define ATC_FC_MASK (0x7 << 21) /* Choose Flow Controller */ | ||
| 111 | #define ATC_FC_MEM2MEM (0x0 << 21) /* Mem-to-Mem (DMA) */ | ||
| 112 | #define ATC_FC_MEM2PER (0x1 << 21) /* Mem-to-Periph (DMA) */ | ||
| 113 | #define ATC_FC_PER2MEM (0x2 << 21) /* Periph-to-Mem (DMA) */ | ||
| 114 | #define ATC_FC_PER2PER (0x3 << 21) /* Periph-to-Periph (DMA) */ | ||
| 115 | #define ATC_FC_PER2MEM_PER (0x4 << 21) /* Periph-to-Mem (Peripheral) */ | ||
| 116 | #define ATC_FC_MEM2PER_PER (0x5 << 21) /* Mem-to-Periph (Peripheral) */ | ||
| 117 | #define ATC_FC_PER2PER_SRCPER (0x6 << 21) /* Periph-to-Periph (Src Peripheral) */ | ||
| 118 | #define ATC_FC_PER2PER_DSTPER (0x7 << 21) /* Periph-to-Periph (Dst Peripheral) */ | ||
| 119 | #define ATC_SRC_ADDR_MODE_MASK (0x3 << 24) | ||
| 120 | #define ATC_SRC_ADDR_MODE_INCR (0x0 << 24) /* Incrementing Mode */ | ||
| 121 | #define ATC_SRC_ADDR_MODE_DECR (0x1 << 24) /* Decrementing Mode */ | ||
| 122 | #define ATC_SRC_ADDR_MODE_FIXED (0x2 << 24) /* Fixed Mode */ | ||
| 123 | #define ATC_DST_ADDR_MODE_MASK (0x3 << 28) | ||
| 124 | #define ATC_DST_ADDR_MODE_INCR (0x0 << 28) /* Incrementing Mode */ | ||
| 125 | #define ATC_DST_ADDR_MODE_DECR (0x1 << 28) /* Decrementing Mode */ | ||
| 126 | #define ATC_DST_ADDR_MODE_FIXED (0x2 << 28) /* Fixed Mode */ | ||
| 127 | #define ATC_IEN (0x1 << 30) /* BTC interrupt enable (active low) */ | ||
| 128 | #define ATC_AUTO (0x1 << 31) /* Auto multiple buffer tx enable */ | ||
| 129 | |||
| 130 | /* Bitfields in CFG */ | ||
| 131 | /* are in at_hdmac.h */ | ||
| 132 | |||
| 133 | /* Bitfields in SPIP */ | ||
| 134 | #define ATC_SPIP_HOLE(x) (0xFFFFU & (x)) | ||
| 135 | #define ATC_SPIP_BOUNDARY(x) ((0x3FF & (x)) << 16) | ||
| 136 | |||
| 137 | /* Bitfields in DPIP */ | ||
| 138 | #define ATC_DPIP_HOLE(x) (0xFFFFU & (x)) | ||
| 139 | #define ATC_DPIP_BOUNDARY(x) ((0x3FF & (x)) << 16) | ||
| 140 | |||
| 141 | |||
| 142 | /*-- descriptors -----------------------------------------------------*/ | ||
| 143 | |||
| 144 | /* LLI == Linked List Item; aka DMA buffer descriptor */ | ||
| 145 | struct at_lli { | ||
| 146 | /* values that are not changed by hardware */ | ||
| 147 | dma_addr_t saddr; | ||
| 148 | dma_addr_t daddr; | ||
| 149 | /* value that may get written back: */ | ||
| 150 | u32 ctrla; | ||
| 151 | /* more values that are not changed by hardware */ | ||
| 152 | u32 ctrlb; | ||
| 153 | dma_addr_t dscr; /* chain to next lli */ | ||
| 154 | }; | ||
| 155 | |||
| 156 | /** | ||
| 157 | * struct at_desc - software descriptor | ||
| 158 | * @at_lli: hardware lli structure | ||
| 159 | * @txd: support for the async_tx api | ||
| 160 | * @desc_node: node on the channed descriptors list | ||
| 161 | * @len: total transaction bytecount | ||
| 162 | */ | ||
| 163 | struct at_desc { | ||
| 164 | /* FIRST values the hardware uses */ | ||
| 165 | struct at_lli lli; | ||
| 166 | |||
| 167 | /* THEN values for driver housekeeping */ | ||
| 168 | struct dma_async_tx_descriptor txd; | ||
| 169 | struct list_head desc_node; | ||
| 170 | size_t len; | ||
| 171 | }; | ||
| 172 | |||
| 173 | static inline struct at_desc * | ||
| 174 | txd_to_at_desc(struct dma_async_tx_descriptor *txd) | ||
| 175 | { | ||
| 176 | return container_of(txd, struct at_desc, txd); | ||
| 177 | } | ||
| 178 | |||
| 179 | |||
| 180 | /*-- Channels --------------------------------------------------------*/ | ||
| 181 | |||
| 182 | /** | ||
| 183 | * struct at_dma_chan - internal representation of an Atmel HDMAC channel | ||
| 184 | * @chan_common: common dmaengine channel object members | ||
| 185 | * @device: parent device | ||
| 186 | * @ch_regs: memory mapped register base | ||
| 187 | * @mask: channel index in a mask | ||
| 188 | * @error_status: transmit error status information from irq handler | ||
| 189 | * to tasklet (use atomic operations) | ||
| 190 | * @tasklet: bottom half to finish transaction work | ||
| 191 | * @lock: serializes enqueue/dequeue operations to descriptors lists | ||
| 192 | * @completed_cookie: identifier for the most recently completed operation | ||
| 193 | * @active_list: list of descriptors dmaengine is being running on | ||
| 194 | * @queue: list of descriptors ready to be submitted to engine | ||
| 195 | * @free_list: list of descriptors usable by the channel | ||
| 196 | * @descs_allocated: records the actual size of the descriptor pool | ||
| 197 | */ | ||
| 198 | struct at_dma_chan { | ||
| 199 | struct dma_chan chan_common; | ||
| 200 | struct at_dma *device; | ||
| 201 | void __iomem *ch_regs; | ||
| 202 | u8 mask; | ||
| 203 | unsigned long error_status; | ||
| 204 | struct tasklet_struct tasklet; | ||
| 205 | |||
| 206 | spinlock_t lock; | ||
| 207 | |||
| 208 | /* these other elements are all protected by lock */ | ||
| 209 | dma_cookie_t completed_cookie; | ||
| 210 | struct list_head active_list; | ||
| 211 | struct list_head queue; | ||
| 212 | struct list_head free_list; | ||
| 213 | unsigned int descs_allocated; | ||
| 214 | }; | ||
| 215 | |||
| 216 | #define channel_readl(atchan, name) \ | ||
| 217 | __raw_readl((atchan)->ch_regs + ATC_##name##_OFFSET) | ||
| 218 | |||
| 219 | #define channel_writel(atchan, name, val) \ | ||
| 220 | __raw_writel((val), (atchan)->ch_regs + ATC_##name##_OFFSET) | ||
| 221 | |||
| 222 | static inline struct at_dma_chan *to_at_dma_chan(struct dma_chan *dchan) | ||
| 223 | { | ||
| 224 | return container_of(dchan, struct at_dma_chan, chan_common); | ||
| 225 | } | ||
| 226 | |||
| 227 | |||
| 228 | /*-- Controller ------------------------------------------------------*/ | ||
| 229 | |||
| 230 | /** | ||
| 231 | * struct at_dma - internal representation of an Atmel HDMA Controller | ||
| 232 | * @chan_common: common dmaengine dma_device object members | ||
| 233 | * @ch_regs: memory mapped register base | ||
| 234 | * @clk: dma controller clock | ||
| 235 | * @all_chan_mask: all channels availlable in a mask | ||
| 236 | * @dma_desc_pool: base of DMA descriptor region (DMA address) | ||
| 237 | * @chan: channels table to store at_dma_chan structures | ||
| 238 | */ | ||
| 239 | struct at_dma { | ||
| 240 | struct dma_device dma_common; | ||
| 241 | void __iomem *regs; | ||
| 242 | struct clk *clk; | ||
| 243 | |||
| 244 | u8 all_chan_mask; | ||
| 245 | |||
| 246 | struct dma_pool *dma_desc_pool; | ||
| 247 | /* AT THE END channels table */ | ||
| 248 | struct at_dma_chan chan[0]; | ||
| 249 | }; | ||
| 250 | |||
| 251 | #define dma_readl(atdma, name) \ | ||
| 252 | __raw_readl((atdma)->regs + AT_DMA_##name) | ||
| 253 | #define dma_writel(atdma, name, val) \ | ||
| 254 | __raw_writel((val), (atdma)->regs + AT_DMA_##name) | ||
| 255 | |||
| 256 | static inline struct at_dma *to_at_dma(struct dma_device *ddev) | ||
| 257 | { | ||
| 258 | return container_of(ddev, struct at_dma, dma_common); | ||
| 259 | } | ||
| 260 | |||
| 261 | |||
| 262 | /*-- Helper functions ------------------------------------------------*/ | ||
| 263 | |||
| 264 | static struct device *chan2dev(struct dma_chan *chan) | ||
| 265 | { | ||
| 266 | return &chan->dev->device; | ||
| 267 | } | ||
| 268 | static struct device *chan2parent(struct dma_chan *chan) | ||
| 269 | { | ||
| 270 | return chan->dev->device.parent; | ||
| 271 | } | ||
| 272 | |||
| 273 | #if defined(VERBOSE_DEBUG) | ||
| 274 | static void vdbg_dump_regs(struct at_dma_chan *atchan) | ||
| 275 | { | ||
| 276 | struct at_dma *atdma = to_at_dma(atchan->chan_common.device); | ||
| 277 | |||
| 278 | dev_err(chan2dev(&atchan->chan_common), | ||
| 279 | " channel %d : imr = 0x%x, chsr = 0x%x\n", | ||
| 280 | atchan->chan_common.chan_id, | ||
| 281 | dma_readl(atdma, EBCIMR), | ||
| 282 | dma_readl(atdma, CHSR)); | ||
| 283 | |||
| 284 | dev_err(chan2dev(&atchan->chan_common), | ||
| 285 | " channel: s0x%x d0x%x ctrl0x%x:0x%x cfg0x%x l0x%x\n", | ||
| 286 | channel_readl(atchan, SADDR), | ||
| 287 | channel_readl(atchan, DADDR), | ||
| 288 | channel_readl(atchan, CTRLA), | ||
| 289 | channel_readl(atchan, CTRLB), | ||
| 290 | channel_readl(atchan, CFG), | ||
| 291 | channel_readl(atchan, DSCR)); | ||
| 292 | } | ||
| 293 | #else | ||
| 294 | static void vdbg_dump_regs(struct at_dma_chan *atchan) {} | ||
| 295 | #endif | ||
| 296 | |||
| 297 | static void atc_dump_lli(struct at_dma_chan *atchan, struct at_lli *lli) | ||
| 298 | { | ||
| 299 | dev_printk(KERN_CRIT, chan2dev(&atchan->chan_common), | ||
| 300 | " desc: s0x%x d0x%x ctrl0x%x:0x%x l0x%x\n", | ||
| 301 | lli->saddr, lli->daddr, | ||
| 302 | lli->ctrla, lli->ctrlb, lli->dscr); | ||
| 303 | } | ||
| 304 | |||
| 305 | |||
| 306 | static void atc_setup_irq(struct at_dma_chan *atchan, int on) | ||
| 307 | { | ||
| 308 | struct at_dma *atdma = to_at_dma(atchan->chan_common.device); | ||
| 309 | u32 ebci; | ||
| 310 | |||
| 311 | /* enable interrupts on buffer chain completion & error */ | ||
| 312 | ebci = AT_DMA_CBTC(atchan->chan_common.chan_id) | ||
| 313 | | AT_DMA_ERR(atchan->chan_common.chan_id); | ||
| 314 | if (on) | ||
| 315 | dma_writel(atdma, EBCIER, ebci); | ||
| 316 | else | ||
| 317 | dma_writel(atdma, EBCIDR, ebci); | ||
| 318 | } | ||
| 319 | |||
| 320 | static inline void atc_enable_irq(struct at_dma_chan *atchan) | ||
| 321 | { | ||
| 322 | atc_setup_irq(atchan, 1); | ||
| 323 | } | ||
| 324 | |||
| 325 | static inline void atc_disable_irq(struct at_dma_chan *atchan) | ||
| 326 | { | ||
| 327 | atc_setup_irq(atchan, 0); | ||
| 328 | } | ||
| 329 | |||
| 330 | |||
| 331 | /** | ||
| 332 | * atc_chan_is_enabled - test if given channel is enabled | ||
| 333 | * @atchan: channel we want to test status | ||
| 334 | */ | ||
| 335 | static inline int atc_chan_is_enabled(struct at_dma_chan *atchan) | ||
| 336 | { | ||
| 337 | struct at_dma *atdma = to_at_dma(atchan->chan_common.device); | ||
| 338 | |||
| 339 | return !!(dma_readl(atdma, CHSR) & atchan->mask); | ||
| 340 | } | ||
| 341 | |||
| 342 | |||
| 343 | /** | ||
| 344 | * set_desc_eol - set end-of-link to descriptor so it will end transfer | ||
| 345 | * @desc: descriptor, signle or at the end of a chain, to end chain on | ||
| 346 | */ | ||
| 347 | static void set_desc_eol(struct at_desc *desc) | ||
| 348 | { | ||
| 349 | desc->lli.ctrlb |= ATC_SRC_DSCR_DIS | ATC_DST_DSCR_DIS; | ||
| 350 | desc->lli.dscr = 0; | ||
| 351 | } | ||
| 352 | |||
| 353 | #endif /* AT_HDMAC_REGS_H */ | ||
diff --git a/drivers/dma/dmatest.c b/drivers/dma/dmatest.c index fb7da5141e96..d93017fc7872 100644 --- a/drivers/dma/dmatest.c +++ b/drivers/dma/dmatest.c | |||
| @@ -38,6 +38,11 @@ module_param(max_channels, uint, S_IRUGO); | |||
| 38 | MODULE_PARM_DESC(max_channels, | 38 | MODULE_PARM_DESC(max_channels, |
| 39 | "Maximum number of channels to use (default: all)"); | 39 | "Maximum number of channels to use (default: all)"); |
| 40 | 40 | ||
| 41 | static unsigned int iterations; | ||
| 42 | module_param(iterations, uint, S_IRUGO); | ||
| 43 | MODULE_PARM_DESC(iterations, | ||
| 44 | "Iterations before stopping test (default: infinite)"); | ||
| 45 | |||
| 41 | static unsigned int xor_sources = 3; | 46 | static unsigned int xor_sources = 3; |
| 42 | module_param(xor_sources, uint, S_IRUGO); | 47 | module_param(xor_sources, uint, S_IRUGO); |
| 43 | MODULE_PARM_DESC(xor_sources, | 48 | MODULE_PARM_DESC(xor_sources, |
| @@ -114,7 +119,7 @@ static void dmatest_init_srcs(u8 **bufs, unsigned int start, unsigned int len) | |||
| 114 | buf[i] = PATTERN_SRC | (~i & PATTERN_COUNT_MASK); | 119 | buf[i] = PATTERN_SRC | (~i & PATTERN_COUNT_MASK); |
| 115 | for ( ; i < start + len; i++) | 120 | for ( ; i < start + len; i++) |
| 116 | buf[i] = PATTERN_SRC | PATTERN_COPY | 121 | buf[i] = PATTERN_SRC | PATTERN_COPY |
| 117 | | (~i & PATTERN_COUNT_MASK);; | 122 | | (~i & PATTERN_COUNT_MASK); |
| 118 | for ( ; i < test_buf_size; i++) | 123 | for ( ; i < test_buf_size; i++) |
| 119 | buf[i] = PATTERN_SRC | (~i & PATTERN_COUNT_MASK); | 124 | buf[i] = PATTERN_SRC | (~i & PATTERN_COUNT_MASK); |
| 120 | buf++; | 125 | buf++; |
| @@ -270,7 +275,8 @@ static int dmatest_func(void *data) | |||
| 270 | 275 | ||
| 271 | flags = DMA_CTRL_ACK | DMA_COMPL_SKIP_DEST_UNMAP | DMA_PREP_INTERRUPT; | 276 | flags = DMA_CTRL_ACK | DMA_COMPL_SKIP_DEST_UNMAP | DMA_PREP_INTERRUPT; |
| 272 | 277 | ||
| 273 | while (!kthread_should_stop()) { | 278 | while (!kthread_should_stop() |
| 279 | && !(iterations && total_tests >= iterations)) { | ||
| 274 | struct dma_device *dev = chan->device; | 280 | struct dma_device *dev = chan->device; |
| 275 | struct dma_async_tx_descriptor *tx = NULL; | 281 | struct dma_async_tx_descriptor *tx = NULL; |
| 276 | dma_addr_t dma_srcs[src_cnt]; | 282 | dma_addr_t dma_srcs[src_cnt]; |
| @@ -416,6 +422,13 @@ err_srcbuf: | |||
| 416 | err_srcs: | 422 | err_srcs: |
| 417 | pr_notice("%s: terminating after %u tests, %u failures (status %d)\n", | 423 | pr_notice("%s: terminating after %u tests, %u failures (status %d)\n", |
| 418 | thread_name, total_tests, failed_tests, ret); | 424 | thread_name, total_tests, failed_tests, ret); |
| 425 | |||
| 426 | if (iterations > 0) | ||
| 427 | while (!kthread_should_stop()) { | ||
| 428 | DECLARE_WAIT_QUEUE_HEAD(wait_dmatest_exit); | ||
| 429 | interruptible_sleep_on(&wait_dmatest_exit); | ||
| 430 | } | ||
| 431 | |||
| 419 | return ret; | 432 | return ret; |
| 420 | } | 433 | } |
| 421 | 434 | ||
| @@ -495,11 +508,11 @@ static int dmatest_add_channel(struct dma_chan *chan) | |||
| 495 | 508 | ||
| 496 | if (dma_has_cap(DMA_MEMCPY, dma_dev->cap_mask)) { | 509 | if (dma_has_cap(DMA_MEMCPY, dma_dev->cap_mask)) { |
| 497 | cnt = dmatest_add_threads(dtc, DMA_MEMCPY); | 510 | cnt = dmatest_add_threads(dtc, DMA_MEMCPY); |
| 498 | thread_count += cnt > 0 ?: 0; | 511 | thread_count += cnt > 0 ? cnt : 0; |
| 499 | } | 512 | } |
| 500 | if (dma_has_cap(DMA_XOR, dma_dev->cap_mask)) { | 513 | if (dma_has_cap(DMA_XOR, dma_dev->cap_mask)) { |
| 501 | cnt = dmatest_add_threads(dtc, DMA_XOR); | 514 | cnt = dmatest_add_threads(dtc, DMA_XOR); |
| 502 | thread_count += cnt > 0 ?: 0; | 515 | thread_count += cnt > 0 ? cnt : 0; |
| 503 | } | 516 | } |
| 504 | 517 | ||
| 505 | pr_info("dmatest: Started %u threads using %s\n", | 518 | pr_info("dmatest: Started %u threads using %s\n", |
diff --git a/drivers/dma/fsldma.c b/drivers/dma/fsldma.c index f18d1bde0439..ef87a8984145 100644 --- a/drivers/dma/fsldma.c +++ b/drivers/dma/fsldma.c | |||
| @@ -12,6 +12,11 @@ | |||
| 12 | * also fit for MPC8560, MPC8555, MPC8548, MPC8641, and etc. | 12 | * also fit for MPC8560, MPC8555, MPC8548, MPC8641, and etc. |
| 13 | * The support for MPC8349 DMA contorller is also added. | 13 | * The support for MPC8349 DMA contorller is also added. |
| 14 | * | 14 | * |
| 15 | * This driver instructs the DMA controller to issue the PCI Read Multiple | ||
| 16 | * command for PCI read operations, instead of using the default PCI Read Line | ||
| 17 | * command. Please be aware that this setting may result in read pre-fetching | ||
| 18 | * on some platforms. | ||
| 19 | * | ||
| 15 | * This is free software; you can redistribute it and/or modify | 20 | * This is free software; you can redistribute it and/or modify |
| 16 | * it under the terms of the GNU General Public License as published by | 21 | * it under the terms of the GNU General Public License as published by |
| 17 | * the Free Software Foundation; either version 2 of the License, or | 22 | * the Free Software Foundation; either version 2 of the License, or |
| @@ -49,9 +54,10 @@ static void dma_init(struct fsl_dma_chan *fsl_chan) | |||
| 49 | case FSL_DMA_IP_83XX: | 54 | case FSL_DMA_IP_83XX: |
| 50 | /* Set the channel to below modes: | 55 | /* Set the channel to below modes: |
| 51 | * EOTIE - End-of-transfer interrupt enable | 56 | * EOTIE - End-of-transfer interrupt enable |
| 57 | * PRC_RM - PCI read multiple | ||
| 52 | */ | 58 | */ |
| 53 | DMA_OUT(fsl_chan, &fsl_chan->reg_base->mr, FSL_DMA_MR_EOTIE, | 59 | DMA_OUT(fsl_chan, &fsl_chan->reg_base->mr, FSL_DMA_MR_EOTIE |
| 54 | 32); | 60 | | FSL_DMA_MR_PRC_RM, 32); |
| 55 | break; | 61 | break; |
| 56 | } | 62 | } |
| 57 | 63 | ||
| @@ -136,15 +142,16 @@ static int dma_is_idle(struct fsl_dma_chan *fsl_chan) | |||
| 136 | 142 | ||
| 137 | static void dma_start(struct fsl_dma_chan *fsl_chan) | 143 | static void dma_start(struct fsl_dma_chan *fsl_chan) |
| 138 | { | 144 | { |
| 139 | u32 mr_set = 0;; | 145 | u32 mr_set = 0; |
| 140 | 146 | ||
| 141 | if (fsl_chan->feature & FSL_DMA_CHAN_PAUSE_EXT) { | 147 | if (fsl_chan->feature & FSL_DMA_CHAN_PAUSE_EXT) { |
| 142 | DMA_OUT(fsl_chan, &fsl_chan->reg_base->bcr, 0, 32); | 148 | DMA_OUT(fsl_chan, &fsl_chan->reg_base->bcr, 0, 32); |
| 143 | mr_set |= FSL_DMA_MR_EMP_EN; | 149 | mr_set |= FSL_DMA_MR_EMP_EN; |
| 144 | } else | 150 | } else if ((fsl_chan->feature & FSL_DMA_IP_MASK) == FSL_DMA_IP_85XX) { |
| 145 | DMA_OUT(fsl_chan, &fsl_chan->reg_base->mr, | 151 | DMA_OUT(fsl_chan, &fsl_chan->reg_base->mr, |
| 146 | DMA_IN(fsl_chan, &fsl_chan->reg_base->mr, 32) | 152 | DMA_IN(fsl_chan, &fsl_chan->reg_base->mr, 32) |
| 147 | & ~FSL_DMA_MR_EMP_EN, 32); | 153 | & ~FSL_DMA_MR_EMP_EN, 32); |
| 154 | } | ||
| 148 | 155 | ||
| 149 | if (fsl_chan->feature & FSL_DMA_CHAN_START_EXT) | 156 | if (fsl_chan->feature & FSL_DMA_CHAN_START_EXT) |
| 150 | mr_set |= FSL_DMA_MR_EMS_EN; | 157 | mr_set |= FSL_DMA_MR_EMS_EN; |
| @@ -871,9 +878,9 @@ static int __devinit fsl_dma_chan_probe(struct fsl_dma_device *fdev, | |||
| 871 | 878 | ||
| 872 | switch (new_fsl_chan->feature & FSL_DMA_IP_MASK) { | 879 | switch (new_fsl_chan->feature & FSL_DMA_IP_MASK) { |
| 873 | case FSL_DMA_IP_85XX: | 880 | case FSL_DMA_IP_85XX: |
| 874 | new_fsl_chan->toggle_ext_start = fsl_chan_toggle_ext_start; | ||
| 875 | new_fsl_chan->toggle_ext_pause = fsl_chan_toggle_ext_pause; | 881 | new_fsl_chan->toggle_ext_pause = fsl_chan_toggle_ext_pause; |
| 876 | case FSL_DMA_IP_83XX: | 882 | case FSL_DMA_IP_83XX: |
| 883 | new_fsl_chan->toggle_ext_start = fsl_chan_toggle_ext_start; | ||
| 877 | new_fsl_chan->set_src_loop_size = fsl_chan_set_src_loop_size; | 884 | new_fsl_chan->set_src_loop_size = fsl_chan_set_src_loop_size; |
| 878 | new_fsl_chan->set_dest_loop_size = fsl_chan_set_dest_loop_size; | 885 | new_fsl_chan->set_dest_loop_size = fsl_chan_set_dest_loop_size; |
| 879 | } | 886 | } |
diff --git a/drivers/dma/fsldma.h b/drivers/dma/fsldma.h index 4f21a512d848..dc7f26865797 100644 --- a/drivers/dma/fsldma.h +++ b/drivers/dma/fsldma.h | |||
| @@ -38,6 +38,7 @@ | |||
| 38 | 38 | ||
| 39 | /* Special MR definition for MPC8349 */ | 39 | /* Special MR definition for MPC8349 */ |
| 40 | #define FSL_DMA_MR_EOTIE 0x00000080 | 40 | #define FSL_DMA_MR_EOTIE 0x00000080 |
| 41 | #define FSL_DMA_MR_PRC_RM 0x00000800 | ||
| 41 | 42 | ||
| 42 | #define FSL_DMA_SR_CH 0x00000020 | 43 | #define FSL_DMA_SR_CH 0x00000020 |
| 43 | #define FSL_DMA_SR_PE 0x00000010 | 44 | #define FSL_DMA_SR_PE 0x00000010 |
diff --git a/drivers/dma/mv_xor.c b/drivers/dma/mv_xor.c index ddab94f51224..3f23eabe09f2 100644 --- a/drivers/dma/mv_xor.c +++ b/drivers/dma/mv_xor.c | |||
| @@ -1176,7 +1176,7 @@ static int __devinit mv_xor_probe(struct platform_device *pdev) | |||
| 1176 | if (dma_has_cap(DMA_MEMSET, dma_dev->cap_mask)) | 1176 | if (dma_has_cap(DMA_MEMSET, dma_dev->cap_mask)) |
| 1177 | dma_dev->device_prep_dma_memset = mv_xor_prep_dma_memset; | 1177 | dma_dev->device_prep_dma_memset = mv_xor_prep_dma_memset; |
| 1178 | if (dma_has_cap(DMA_XOR, dma_dev->cap_mask)) { | 1178 | if (dma_has_cap(DMA_XOR, dma_dev->cap_mask)) { |
| 1179 | dma_dev->max_xor = 8; ; | 1179 | dma_dev->max_xor = 8; |
| 1180 | dma_dev->device_prep_dma_xor = mv_xor_prep_dma_xor; | 1180 | dma_dev->device_prep_dma_xor = mv_xor_prep_dma_xor; |
| 1181 | } | 1181 | } |
| 1182 | 1182 | ||
diff --git a/drivers/edac/amd64_edac.c b/drivers/edac/amd64_edac.c index 858fe6037223..e2a10bcba7a1 100644 --- a/drivers/edac/amd64_edac.c +++ b/drivers/edac/amd64_edac.c | |||
| @@ -868,6 +868,8 @@ static void amd64_read_dbam_reg(struct amd64_pvt *pvt) | |||
| 868 | goto err_reg; | 868 | goto err_reg; |
| 869 | } | 869 | } |
| 870 | 870 | ||
| 871 | return; | ||
| 872 | |||
| 871 | err_reg: | 873 | err_reg: |
| 872 | debugf0("Error reading F2x%03x.\n", reg); | 874 | debugf0("Error reading F2x%03x.\n", reg); |
| 873 | } | 875 | } |
| @@ -970,7 +972,7 @@ static void amd64_read_dct_base_mask(struct amd64_pvt *pvt) | |||
| 970 | } | 972 | } |
| 971 | 973 | ||
| 972 | for (cs = 0; cs < pvt->num_dcsm; cs++) { | 974 | for (cs = 0; cs < pvt->num_dcsm; cs++) { |
| 973 | reg = K8_DCSB0 + (cs * 4); | 975 | reg = K8_DCSM0 + (cs * 4); |
| 974 | err = pci_read_config_dword(pvt->dram_f2_ctl, reg, | 976 | err = pci_read_config_dword(pvt->dram_f2_ctl, reg, |
| 975 | &pvt->dcsm0[cs]); | 977 | &pvt->dcsm0[cs]); |
| 976 | if (unlikely(err)) | 978 | if (unlikely(err)) |
| @@ -2634,6 +2636,8 @@ static void amd64_read_mc_registers(struct amd64_pvt *pvt) | |||
| 2634 | 2636 | ||
| 2635 | amd64_dump_misc_regs(pvt); | 2637 | amd64_dump_misc_regs(pvt); |
| 2636 | 2638 | ||
| 2639 | return; | ||
| 2640 | |||
| 2637 | err_reg: | 2641 | err_reg: |
| 2638 | debugf0("Reading an MC register failed\n"); | 2642 | debugf0("Reading an MC register failed\n"); |
| 2639 | 2643 | ||
| @@ -2977,6 +2981,9 @@ static int amd64_check_ecc_enabled(struct amd64_pvt *pvt) | |||
| 2977 | "ECC is enabled by BIOS, Proceeding " | 2981 | "ECC is enabled by BIOS, Proceeding " |
| 2978 | "with EDAC module initialization\n"); | 2982 | "with EDAC module initialization\n"); |
| 2979 | 2983 | ||
| 2984 | /* Signal good ECC status */ | ||
| 2985 | ret = 0; | ||
| 2986 | |||
| 2980 | /* CLEAR the override, since BIOS controlled it */ | 2987 | /* CLEAR the override, since BIOS controlled it */ |
| 2981 | ecc_enable_override = 0; | 2988 | ecc_enable_override = 0; |
| 2982 | } | 2989 | } |
diff --git a/drivers/edac/x38_edac.c b/drivers/edac/x38_edac.c index 2406c2ce2844..d4ec60593176 100644 --- a/drivers/edac/x38_edac.c +++ b/drivers/edac/x38_edac.c | |||
| @@ -30,7 +30,7 @@ | |||
| 30 | /* Intel X38 register addresses - device 0 function 0 - DRAM Controller */ | 30 | /* Intel X38 register addresses - device 0 function 0 - DRAM Controller */ |
| 31 | 31 | ||
| 32 | #define X38_MCHBAR_LOW 0x48 /* MCH Memory Mapped Register BAR */ | 32 | #define X38_MCHBAR_LOW 0x48 /* MCH Memory Mapped Register BAR */ |
| 33 | #define X38_MCHBAR_HIGH 0x4b | 33 | #define X38_MCHBAR_HIGH 0x4c |
| 34 | #define X38_MCHBAR_MASK 0xfffffc000ULL /* bits 35:14 */ | 34 | #define X38_MCHBAR_MASK 0xfffffc000ULL /* bits 35:14 */ |
| 35 | #define X38_MMR_WINDOW_SIZE 16384 | 35 | #define X38_MMR_WINDOW_SIZE 16384 |
| 36 | 36 | ||
diff --git a/drivers/gpu/drm/drm_crtc.c b/drivers/gpu/drm/drm_crtc.c index 8fab7890a363..2f631c75f704 100644 --- a/drivers/gpu/drm/drm_crtc.c +++ b/drivers/gpu/drm/drm_crtc.c | |||
| @@ -258,31 +258,6 @@ void *drm_mode_object_find(struct drm_device *dev, uint32_t id, uint32_t type) | |||
| 258 | EXPORT_SYMBOL(drm_mode_object_find); | 258 | EXPORT_SYMBOL(drm_mode_object_find); |
| 259 | 259 | ||
| 260 | /** | 260 | /** |
| 261 | * drm_crtc_from_fb - find the CRTC structure associated with an fb | ||
| 262 | * @dev: DRM device | ||
| 263 | * @fb: framebuffer in question | ||
| 264 | * | ||
| 265 | * LOCKING: | ||
| 266 | * Caller must hold mode_config lock. | ||
| 267 | * | ||
| 268 | * Find CRTC in the mode_config structure that matches @fb. | ||
| 269 | * | ||
| 270 | * RETURNS: | ||
| 271 | * Pointer to the CRTC or NULL if it wasn't found. | ||
| 272 | */ | ||
| 273 | struct drm_crtc *drm_crtc_from_fb(struct drm_device *dev, | ||
| 274 | struct drm_framebuffer *fb) | ||
| 275 | { | ||
| 276 | struct drm_crtc *crtc; | ||
| 277 | |||
| 278 | list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) { | ||
| 279 | if (crtc->fb == fb) | ||
| 280 | return crtc; | ||
| 281 | } | ||
| 282 | return NULL; | ||
| 283 | } | ||
| 284 | |||
| 285 | /** | ||
| 286 | * drm_framebuffer_init - initialize a framebuffer | 261 | * drm_framebuffer_init - initialize a framebuffer |
| 287 | * @dev: DRM device | 262 | * @dev: DRM device |
| 288 | * | 263 | * |
| @@ -328,11 +303,20 @@ void drm_framebuffer_cleanup(struct drm_framebuffer *fb) | |||
| 328 | { | 303 | { |
| 329 | struct drm_device *dev = fb->dev; | 304 | struct drm_device *dev = fb->dev; |
| 330 | struct drm_crtc *crtc; | 305 | struct drm_crtc *crtc; |
| 306 | struct drm_mode_set set; | ||
| 307 | int ret; | ||
| 331 | 308 | ||
| 332 | /* remove from any CRTC */ | 309 | /* remove from any CRTC */ |
| 333 | list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) { | 310 | list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) { |
| 334 | if (crtc->fb == fb) | 311 | if (crtc->fb == fb) { |
| 335 | crtc->fb = NULL; | 312 | /* should turn off the crtc */ |
| 313 | memset(&set, 0, sizeof(struct drm_mode_set)); | ||
| 314 | set.crtc = crtc; | ||
| 315 | set.fb = NULL; | ||
| 316 | ret = crtc->funcs->set_config(&set); | ||
| 317 | if (ret) | ||
| 318 | DRM_ERROR("failed to reset crtc %p when fb was deleted\n", crtc); | ||
| 319 | } | ||
| 336 | } | 320 | } |
| 337 | 321 | ||
| 338 | drm_mode_object_put(dev, &fb->base); | 322 | drm_mode_object_put(dev, &fb->base); |
| @@ -1461,7 +1445,7 @@ int drm_mode_setcrtc(struct drm_device *dev, void *data, | |||
| 1461 | goto out; | 1445 | goto out; |
| 1462 | } | 1446 | } |
| 1463 | 1447 | ||
| 1464 | if (crtc_req->count_connectors > 0 && !mode && !fb) { | 1448 | if (crtc_req->count_connectors > 0 && (!mode || !fb)) { |
| 1465 | DRM_DEBUG("Count connectors is %d but no mode or fb set\n", | 1449 | DRM_DEBUG("Count connectors is %d but no mode or fb set\n", |
| 1466 | crtc_req->count_connectors); | 1450 | crtc_req->count_connectors); |
| 1467 | ret = -EINVAL; | 1451 | ret = -EINVAL; |
| @@ -1511,7 +1495,7 @@ int drm_mode_setcrtc(struct drm_device *dev, void *data, | |||
| 1511 | set.mode = mode; | 1495 | set.mode = mode; |
| 1512 | set.connectors = connector_set; | 1496 | set.connectors = connector_set; |
| 1513 | set.num_connectors = crtc_req->count_connectors; | 1497 | set.num_connectors = crtc_req->count_connectors; |
| 1514 | set.fb =fb; | 1498 | set.fb = fb; |
| 1515 | ret = crtc->funcs->set_config(&set); | 1499 | ret = crtc->funcs->set_config(&set); |
| 1516 | 1500 | ||
| 1517 | out: | 1501 | out: |
diff --git a/drivers/gpu/drm/drm_crtc_helper.c b/drivers/gpu/drm/drm_crtc_helper.c index 3da9cfa31848..6aaa2cb23365 100644 --- a/drivers/gpu/drm/drm_crtc_helper.c +++ b/drivers/gpu/drm/drm_crtc_helper.c | |||
| @@ -706,8 +706,8 @@ int drm_crtc_helper_set_config(struct drm_mode_set *set) | |||
| 706 | struct drm_encoder **save_encoders, *new_encoder; | 706 | struct drm_encoder **save_encoders, *new_encoder; |
| 707 | struct drm_framebuffer *old_fb = NULL; | 707 | struct drm_framebuffer *old_fb = NULL; |
| 708 | bool save_enabled; | 708 | bool save_enabled; |
| 709 | bool mode_changed = false; | 709 | bool mode_changed = false; /* if true do a full mode set */ |
| 710 | bool fb_changed = false; | 710 | bool fb_changed = false; /* if true and !mode_changed just do a flip */ |
| 711 | struct drm_connector *connector; | 711 | struct drm_connector *connector; |
| 712 | int count = 0, ro, fail = 0; | 712 | int count = 0, ro, fail = 0; |
| 713 | struct drm_crtc_helper_funcs *crtc_funcs; | 713 | struct drm_crtc_helper_funcs *crtc_funcs; |
| @@ -758,6 +758,8 @@ int drm_crtc_helper_set_config(struct drm_mode_set *set) | |||
| 758 | if (set->crtc->fb == NULL) { | 758 | if (set->crtc->fb == NULL) { |
| 759 | DRM_DEBUG("crtc has no fb, full mode set\n"); | 759 | DRM_DEBUG("crtc has no fb, full mode set\n"); |
| 760 | mode_changed = true; | 760 | mode_changed = true; |
| 761 | } else if (set->fb == NULL) { | ||
| 762 | mode_changed = true; | ||
| 761 | } else if ((set->fb->bits_per_pixel != | 763 | } else if ((set->fb->bits_per_pixel != |
| 762 | set->crtc->fb->bits_per_pixel) || | 764 | set->crtc->fb->bits_per_pixel) || |
| 763 | set->fb->depth != set->crtc->fb->depth) | 765 | set->fb->depth != set->crtc->fb->depth) |
diff --git a/drivers/gpu/drm/drm_edid.c b/drivers/gpu/drm/drm_edid.c index 80cc6d06d61b..7f2728bbc16c 100644 --- a/drivers/gpu/drm/drm_edid.c +++ b/drivers/gpu/drm/drm_edid.c | |||
| @@ -502,12 +502,40 @@ static int add_detailed_info(struct drm_connector *connector, | |||
| 502 | struct detailed_non_pixel *data = &timing->data.other_data; | 502 | struct detailed_non_pixel *data = &timing->data.other_data; |
| 503 | struct drm_display_mode *newmode; | 503 | struct drm_display_mode *newmode; |
| 504 | 504 | ||
| 505 | /* EDID up to and including 1.2 may put monitor info here */ | 505 | /* X server check is version 1.1 or higher */ |
| 506 | if (edid->version == 1 && edid->revision < 3) | 506 | if (edid->version == 1 && edid->revision >= 1 && |
| 507 | continue; | 507 | !timing->pixel_clock) { |
| 508 | 508 | /* Other timing or info */ | |
| 509 | /* Detailed mode timing */ | 509 | switch (data->type) { |
| 510 | if (timing->pixel_clock) { | 510 | case EDID_DETAIL_MONITOR_SERIAL: |
| 511 | break; | ||
| 512 | case EDID_DETAIL_MONITOR_STRING: | ||
| 513 | break; | ||
| 514 | case EDID_DETAIL_MONITOR_RANGE: | ||
| 515 | /* Get monitor range data */ | ||
| 516 | break; | ||
| 517 | case EDID_DETAIL_MONITOR_NAME: | ||
| 518 | break; | ||
| 519 | case EDID_DETAIL_MONITOR_CPDATA: | ||
| 520 | break; | ||
| 521 | case EDID_DETAIL_STD_MODES: | ||
| 522 | /* Five modes per detailed section */ | ||
| 523 | for (j = 0; j < 5; i++) { | ||
| 524 | struct std_timing *std; | ||
| 525 | struct drm_display_mode *newmode; | ||
| 526 | |||
| 527 | std = &data->data.timings[j]; | ||
| 528 | newmode = drm_mode_std(dev, std); | ||
| 529 | if (newmode) { | ||
| 530 | drm_mode_probed_add(connector, newmode); | ||
| 531 | modes++; | ||
| 532 | } | ||
| 533 | } | ||
| 534 | break; | ||
| 535 | default: | ||
| 536 | break; | ||
| 537 | } | ||
| 538 | } else { | ||
| 511 | newmode = drm_mode_detailed(dev, edid, timing, quirks); | 539 | newmode = drm_mode_detailed(dev, edid, timing, quirks); |
| 512 | if (!newmode) | 540 | if (!newmode) |
| 513 | continue; | 541 | continue; |
| @@ -518,38 +546,6 @@ static int add_detailed_info(struct drm_connector *connector, | |||
| 518 | drm_mode_probed_add(connector, newmode); | 546 | drm_mode_probed_add(connector, newmode); |
| 519 | 547 | ||
| 520 | modes++; | 548 | modes++; |
| 521 | continue; | ||
| 522 | } | ||
| 523 | |||
| 524 | /* Other timing or info */ | ||
| 525 | switch (data->type) { | ||
| 526 | case EDID_DETAIL_MONITOR_SERIAL: | ||
| 527 | break; | ||
| 528 | case EDID_DETAIL_MONITOR_STRING: | ||
| 529 | break; | ||
| 530 | case EDID_DETAIL_MONITOR_RANGE: | ||
| 531 | /* Get monitor range data */ | ||
| 532 | break; | ||
| 533 | case EDID_DETAIL_MONITOR_NAME: | ||
| 534 | break; | ||
| 535 | case EDID_DETAIL_MONITOR_CPDATA: | ||
| 536 | break; | ||
| 537 | case EDID_DETAIL_STD_MODES: | ||
| 538 | /* Five modes per detailed section */ | ||
| 539 | for (j = 0; j < 5; i++) { | ||
| 540 | struct std_timing *std; | ||
| 541 | struct drm_display_mode *newmode; | ||
| 542 | |||
| 543 | std = &data->data.timings[j]; | ||
| 544 | newmode = drm_mode_std(dev, std); | ||
| 545 | if (newmode) { | ||
| 546 | drm_mode_probed_add(connector, newmode); | ||
| 547 | modes++; | ||
| 548 | } | ||
| 549 | } | ||
| 550 | break; | ||
| 551 | default: | ||
| 552 | break; | ||
| 553 | } | 549 | } |
| 554 | } | 550 | } |
| 555 | 551 | ||
diff --git a/drivers/gpu/drm/drm_irq.c b/drivers/gpu/drm/drm_irq.c index b4a3dbcebe9b..f85aaf21e783 100644 --- a/drivers/gpu/drm/drm_irq.c +++ b/drivers/gpu/drm/drm_irq.c | |||
| @@ -566,7 +566,7 @@ int drm_wait_vblank(struct drm_device *dev, void *data, | |||
| 566 | 566 | ||
| 567 | ret = drm_vblank_get(dev, crtc); | 567 | ret = drm_vblank_get(dev, crtc); |
| 568 | if (ret) { | 568 | if (ret) { |
| 569 | DRM_ERROR("failed to acquire vblank counter, %d\n", ret); | 569 | DRM_DEBUG("failed to acquire vblank counter, %d\n", ret); |
| 570 | return ret; | 570 | return ret; |
| 571 | } | 571 | } |
| 572 | seq = drm_vblank_count(dev, crtc); | 572 | seq = drm_vblank_count(dev, crtc); |
diff --git a/drivers/gpu/drm/drm_modes.c b/drivers/gpu/drm/drm_modes.c index 54f492a488a9..7914097b09c6 100644 --- a/drivers/gpu/drm/drm_modes.c +++ b/drivers/gpu/drm/drm_modes.c | |||
| @@ -566,6 +566,8 @@ void drm_mode_connector_list_update(struct drm_connector *connector) | |||
| 566 | found_it = 1; | 566 | found_it = 1; |
| 567 | /* if equal delete the probed mode */ | 567 | /* if equal delete the probed mode */ |
| 568 | mode->status = pmode->status; | 568 | mode->status = pmode->status; |
| 569 | /* Merge type bits together */ | ||
| 570 | mode->type |= pmode->type; | ||
| 569 | list_del(&pmode->head); | 571 | list_del(&pmode->head); |
| 570 | drm_mode_destroy(connector->dev, pmode); | 572 | drm_mode_destroy(connector->dev, pmode); |
| 571 | break; | 573 | break; |
diff --git a/drivers/gpu/drm/drm_sysfs.c b/drivers/gpu/drm/drm_sysfs.c index 85ec31b3ff00..f7a615b80c70 100644 --- a/drivers/gpu/drm/drm_sysfs.c +++ b/drivers/gpu/drm/drm_sysfs.c | |||
| @@ -22,44 +22,50 @@ | |||
| 22 | #define to_drm_minor(d) container_of(d, struct drm_minor, kdev) | 22 | #define to_drm_minor(d) container_of(d, struct drm_minor, kdev) |
| 23 | #define to_drm_connector(d) container_of(d, struct drm_connector, kdev) | 23 | #define to_drm_connector(d) container_of(d, struct drm_connector, kdev) |
| 24 | 24 | ||
| 25 | static struct device_type drm_sysfs_device_minor = { | ||
| 26 | .name = "drm_minor" | ||
| 27 | }; | ||
| 28 | |||
| 25 | /** | 29 | /** |
| 26 | * drm_sysfs_suspend - DRM class suspend hook | 30 | * drm_class_suspend - DRM class suspend hook |
| 27 | * @dev: Linux device to suspend | 31 | * @dev: Linux device to suspend |
| 28 | * @state: power state to enter | 32 | * @state: power state to enter |
| 29 | * | 33 | * |
| 30 | * Just figures out what the actual struct drm_device associated with | 34 | * Just figures out what the actual struct drm_device associated with |
| 31 | * @dev is and calls its suspend hook, if present. | 35 | * @dev is and calls its suspend hook, if present. |
| 32 | */ | 36 | */ |
| 33 | static int drm_sysfs_suspend(struct device *dev, pm_message_t state) | 37 | static int drm_class_suspend(struct device *dev, pm_message_t state) |
| 34 | { | 38 | { |
| 35 | struct drm_minor *drm_minor = to_drm_minor(dev); | 39 | if (dev->type == &drm_sysfs_device_minor) { |
| 36 | struct drm_device *drm_dev = drm_minor->dev; | 40 | struct drm_minor *drm_minor = to_drm_minor(dev); |
| 37 | 41 | struct drm_device *drm_dev = drm_minor->dev; | |
| 38 | if (drm_minor->type == DRM_MINOR_LEGACY && | 42 | |
| 39 | !drm_core_check_feature(drm_dev, DRIVER_MODESET) && | 43 | if (drm_minor->type == DRM_MINOR_LEGACY && |
| 40 | drm_dev->driver->suspend) | 44 | !drm_core_check_feature(drm_dev, DRIVER_MODESET) && |
| 41 | return drm_dev->driver->suspend(drm_dev, state); | 45 | drm_dev->driver->suspend) |
| 42 | 46 | return drm_dev->driver->suspend(drm_dev, state); | |
| 47 | } | ||
| 43 | return 0; | 48 | return 0; |
| 44 | } | 49 | } |
| 45 | 50 | ||
| 46 | /** | 51 | /** |
| 47 | * drm_sysfs_resume - DRM class resume hook | 52 | * drm_class_resume - DRM class resume hook |
| 48 | * @dev: Linux device to resume | 53 | * @dev: Linux device to resume |
| 49 | * | 54 | * |
| 50 | * Just figures out what the actual struct drm_device associated with | 55 | * Just figures out what the actual struct drm_device associated with |
| 51 | * @dev is and calls its resume hook, if present. | 56 | * @dev is and calls its resume hook, if present. |
| 52 | */ | 57 | */ |
| 53 | static int drm_sysfs_resume(struct device *dev) | 58 | static int drm_class_resume(struct device *dev) |
| 54 | { | 59 | { |
| 55 | struct drm_minor *drm_minor = to_drm_minor(dev); | 60 | if (dev->type == &drm_sysfs_device_minor) { |
| 56 | struct drm_device *drm_dev = drm_minor->dev; | 61 | struct drm_minor *drm_minor = to_drm_minor(dev); |
| 57 | 62 | struct drm_device *drm_dev = drm_minor->dev; | |
| 58 | if (drm_minor->type == DRM_MINOR_LEGACY && | 63 | |
| 59 | !drm_core_check_feature(drm_dev, DRIVER_MODESET) && | 64 | if (drm_minor->type == DRM_MINOR_LEGACY && |
| 60 | drm_dev->driver->resume) | 65 | !drm_core_check_feature(drm_dev, DRIVER_MODESET) && |
| 61 | return drm_dev->driver->resume(drm_dev); | 66 | drm_dev->driver->resume) |
| 62 | 67 | return drm_dev->driver->resume(drm_dev); | |
| 68 | } | ||
| 63 | return 0; | 69 | return 0; |
| 64 | } | 70 | } |
| 65 | 71 | ||
| @@ -99,8 +105,8 @@ struct class *drm_sysfs_create(struct module *owner, char *name) | |||
| 99 | goto err_out; | 105 | goto err_out; |
| 100 | } | 106 | } |
| 101 | 107 | ||
| 102 | class->suspend = drm_sysfs_suspend; | 108 | class->suspend = drm_class_suspend; |
| 103 | class->resume = drm_sysfs_resume; | 109 | class->resume = drm_class_resume; |
| 104 | 110 | ||
| 105 | err = class_create_file(class, &class_attr_version); | 111 | err = class_create_file(class, &class_attr_version); |
| 106 | if (err) | 112 | if (err) |
| @@ -480,6 +486,7 @@ int drm_sysfs_device_add(struct drm_minor *minor) | |||
| 480 | minor->kdev.class = drm_class; | 486 | minor->kdev.class = drm_class; |
| 481 | minor->kdev.release = drm_sysfs_device_release; | 487 | minor->kdev.release = drm_sysfs_device_release; |
| 482 | minor->kdev.devt = minor->device; | 488 | minor->kdev.devt = minor->device; |
| 489 | minor->kdev.type = &drm_sysfs_device_minor; | ||
| 483 | if (minor->type == DRM_MINOR_CONTROL) | 490 | if (minor->type == DRM_MINOR_CONTROL) |
| 484 | minor_str = "controlD%d"; | 491 | minor_str = "controlD%d"; |
| 485 | else if (minor->type == DRM_MINOR_RENDER) | 492 | else if (minor->type == DRM_MINOR_RENDER) |
diff --git a/drivers/gpu/drm/i915/i915_dma.c b/drivers/gpu/drm/i915/i915_dma.c index 8c4783180bf6..50d1f782768c 100644 --- a/drivers/gpu/drm/i915/i915_dma.c +++ b/drivers/gpu/drm/i915/i915_dma.c | |||
| @@ -1186,6 +1186,13 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags) | |||
| 1186 | if (ret) | 1186 | if (ret) |
| 1187 | goto out_iomapfree; | 1187 | goto out_iomapfree; |
| 1188 | 1188 | ||
| 1189 | dev_priv->wq = create_workqueue("i915"); | ||
| 1190 | if (dev_priv->wq == NULL) { | ||
| 1191 | DRM_ERROR("Failed to create our workqueue.\n"); | ||
| 1192 | ret = -ENOMEM; | ||
| 1193 | goto out_iomapfree; | ||
| 1194 | } | ||
| 1195 | |||
| 1189 | /* enable GEM by default */ | 1196 | /* enable GEM by default */ |
| 1190 | dev_priv->has_gem = 1; | 1197 | dev_priv->has_gem = 1; |
| 1191 | 1198 | ||
| @@ -1211,7 +1218,7 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags) | |||
| 1211 | if (!I915_NEED_GFX_HWS(dev)) { | 1218 | if (!I915_NEED_GFX_HWS(dev)) { |
| 1212 | ret = i915_init_phys_hws(dev); | 1219 | ret = i915_init_phys_hws(dev); |
| 1213 | if (ret != 0) | 1220 | if (ret != 0) |
| 1214 | goto out_iomapfree; | 1221 | goto out_workqueue_free; |
| 1215 | } | 1222 | } |
| 1216 | 1223 | ||
| 1217 | i915_get_mem_freq(dev); | 1224 | i915_get_mem_freq(dev); |
| @@ -1245,7 +1252,7 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags) | |||
| 1245 | ret = i915_load_modeset_init(dev, prealloc_size, agp_size); | 1252 | ret = i915_load_modeset_init(dev, prealloc_size, agp_size); |
| 1246 | if (ret < 0) { | 1253 | if (ret < 0) { |
| 1247 | DRM_ERROR("failed to init modeset\n"); | 1254 | DRM_ERROR("failed to init modeset\n"); |
| 1248 | goto out_rmmap; | 1255 | goto out_workqueue_free; |
| 1249 | } | 1256 | } |
| 1250 | } | 1257 | } |
| 1251 | 1258 | ||
| @@ -1256,6 +1263,8 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags) | |||
| 1256 | 1263 | ||
| 1257 | return 0; | 1264 | return 0; |
| 1258 | 1265 | ||
| 1266 | out_workqueue_free: | ||
| 1267 | destroy_workqueue(dev_priv->wq); | ||
| 1259 | out_iomapfree: | 1268 | out_iomapfree: |
| 1260 | io_mapping_free(dev_priv->mm.gtt_mapping); | 1269 | io_mapping_free(dev_priv->mm.gtt_mapping); |
| 1261 | out_rmmap: | 1270 | out_rmmap: |
| @@ -1269,6 +1278,8 @@ int i915_driver_unload(struct drm_device *dev) | |||
| 1269 | { | 1278 | { |
| 1270 | struct drm_i915_private *dev_priv = dev->dev_private; | 1279 | struct drm_i915_private *dev_priv = dev->dev_private; |
| 1271 | 1280 | ||
| 1281 | destroy_workqueue(dev_priv->wq); | ||
| 1282 | |||
| 1272 | io_mapping_free(dev_priv->mm.gtt_mapping); | 1283 | io_mapping_free(dev_priv->mm.gtt_mapping); |
| 1273 | if (dev_priv->mm.gtt_mtrr >= 0) { | 1284 | if (dev_priv->mm.gtt_mtrr >= 0) { |
| 1274 | mtrr_del(dev_priv->mm.gtt_mtrr, dev->agp->base, | 1285 | mtrr_del(dev_priv->mm.gtt_mtrr, dev->agp->base, |
diff --git a/drivers/gpu/drm/i915/i915_drv.h b/drivers/gpu/drm/i915/i915_drv.h index d08752875885..7537f57d8a87 100644 --- a/drivers/gpu/drm/i915/i915_drv.h +++ b/drivers/gpu/drm/i915/i915_drv.h | |||
| @@ -219,6 +219,7 @@ typedef struct drm_i915_private { | |||
| 219 | unsigned int lvds_vbt:1; | 219 | unsigned int lvds_vbt:1; |
| 220 | unsigned int int_crt_support:1; | 220 | unsigned int int_crt_support:1; |
| 221 | unsigned int lvds_use_ssc:1; | 221 | unsigned int lvds_use_ssc:1; |
| 222 | unsigned int edp_support:1; | ||
| 222 | int lvds_ssc_freq; | 223 | int lvds_ssc_freq; |
| 223 | 224 | ||
| 224 | struct drm_i915_fence_reg fence_regs[16]; /* assume 965 */ | 225 | struct drm_i915_fence_reg fence_regs[16]; /* assume 965 */ |
| @@ -229,6 +230,8 @@ typedef struct drm_i915_private { | |||
| 229 | 230 | ||
| 230 | spinlock_t error_lock; | 231 | spinlock_t error_lock; |
| 231 | struct drm_i915_error_state *first_error; | 232 | struct drm_i915_error_state *first_error; |
| 233 | struct work_struct error_work; | ||
| 234 | struct workqueue_struct *wq; | ||
| 232 | 235 | ||
| 233 | /* Register state */ | 236 | /* Register state */ |
| 234 | u8 saveLBB; | 237 | u8 saveLBB; |
| @@ -888,6 +891,7 @@ extern int i915_wait_ring(struct drm_device * dev, int n, const char *caller); | |||
| 888 | IS_I915GM(dev))) | 891 | IS_I915GM(dev))) |
| 889 | #define SUPPORTS_INTEGRATED_HDMI(dev) (IS_G4X(dev) || IS_IGDNG(dev)) | 892 | #define SUPPORTS_INTEGRATED_HDMI(dev) (IS_G4X(dev) || IS_IGDNG(dev)) |
| 890 | #define SUPPORTS_INTEGRATED_DP(dev) (IS_G4X(dev) || IS_IGDNG(dev)) | 893 | #define SUPPORTS_INTEGRATED_DP(dev) (IS_G4X(dev) || IS_IGDNG(dev)) |
| 894 | #define SUPPORTS_EDP(dev) (IS_IGDNG_M(dev)) | ||
| 891 | #define I915_HAS_HOTPLUG(dev) (IS_I945G(dev) || IS_I945GM(dev) || IS_I965G(dev)) | 895 | #define I915_HAS_HOTPLUG(dev) (IS_I945G(dev) || IS_I945GM(dev) || IS_I965G(dev)) |
| 892 | /* dsparb controlled by hw only */ | 896 | /* dsparb controlled by hw only */ |
| 893 | #define DSPARB_HWCONTROL(dev) (IS_G4X(dev) || IS_IGDNG(dev)) | 897 | #define DSPARB_HWCONTROL(dev) (IS_G4X(dev) || IS_IGDNG(dev)) |
diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c index 5bf420378b6d..140bee142fc2 100644 --- a/drivers/gpu/drm/i915/i915_gem.c +++ b/drivers/gpu/drm/i915/i915_gem.c | |||
| @@ -1570,7 +1570,7 @@ i915_add_request(struct drm_device *dev, struct drm_file *file_priv, | |||
| 1570 | } | 1570 | } |
| 1571 | 1571 | ||
| 1572 | if (was_empty && !dev_priv->mm.suspended) | 1572 | if (was_empty && !dev_priv->mm.suspended) |
| 1573 | schedule_delayed_work(&dev_priv->mm.retire_work, HZ); | 1573 | queue_delayed_work(dev_priv->wq, &dev_priv->mm.retire_work, HZ); |
| 1574 | return seqno; | 1574 | return seqno; |
| 1575 | } | 1575 | } |
| 1576 | 1576 | ||
| @@ -1719,7 +1719,7 @@ i915_gem_retire_work_handler(struct work_struct *work) | |||
| 1719 | i915_gem_retire_requests(dev); | 1719 | i915_gem_retire_requests(dev); |
| 1720 | if (!dev_priv->mm.suspended && | 1720 | if (!dev_priv->mm.suspended && |
| 1721 | !list_empty(&dev_priv->mm.request_list)) | 1721 | !list_empty(&dev_priv->mm.request_list)) |
| 1722 | schedule_delayed_work(&dev_priv->mm.retire_work, HZ); | 1722 | queue_delayed_work(dev_priv->wq, &dev_priv->mm.retire_work, HZ); |
| 1723 | mutex_unlock(&dev->struct_mutex); | 1723 | mutex_unlock(&dev->struct_mutex); |
| 1724 | } | 1724 | } |
| 1725 | 1725 | ||
diff --git a/drivers/gpu/drm/i915/i915_gem_debugfs.c b/drivers/gpu/drm/i915/i915_gem_debugfs.c index 9a44bfcb8139..cb3b97405fbf 100644 --- a/drivers/gpu/drm/i915/i915_gem_debugfs.c +++ b/drivers/gpu/drm/i915/i915_gem_debugfs.c | |||
| @@ -343,6 +343,8 @@ static int i915_error_state(struct seq_file *m, void *unused) | |||
| 343 | 343 | ||
| 344 | error = dev_priv->first_error; | 344 | error = dev_priv->first_error; |
| 345 | 345 | ||
| 346 | seq_printf(m, "Time: %ld s %ld us\n", error->time.tv_sec, | ||
| 347 | error->time.tv_usec); | ||
| 346 | seq_printf(m, "EIR: 0x%08x\n", error->eir); | 348 | seq_printf(m, "EIR: 0x%08x\n", error->eir); |
| 347 | seq_printf(m, " PGTBL_ER: 0x%08x\n", error->pgtbl_er); | 349 | seq_printf(m, " PGTBL_ER: 0x%08x\n", error->pgtbl_er); |
| 348 | seq_printf(m, " INSTPM: 0x%08x\n", error->instpm); | 350 | seq_printf(m, " INSTPM: 0x%08x\n", error->instpm); |
diff --git a/drivers/gpu/drm/i915/i915_irq.c b/drivers/gpu/drm/i915/i915_irq.c index 7ba23a69a0c0..7ebc84c2881e 100644 --- a/drivers/gpu/drm/i915/i915_irq.c +++ b/drivers/gpu/drm/i915/i915_irq.c | |||
| @@ -190,7 +190,7 @@ u32 i915_get_vblank_counter(struct drm_device *dev, int pipe) | |||
| 190 | low_frame = pipe ? PIPEBFRAMEPIXEL : PIPEAFRAMEPIXEL; | 190 | low_frame = pipe ? PIPEBFRAMEPIXEL : PIPEAFRAMEPIXEL; |
| 191 | 191 | ||
| 192 | if (!i915_pipe_enabled(dev, pipe)) { | 192 | if (!i915_pipe_enabled(dev, pipe)) { |
| 193 | DRM_ERROR("trying to get vblank count for disabled pipe %d\n", pipe); | 193 | DRM_DEBUG("trying to get vblank count for disabled pipe %d\n", pipe); |
| 194 | return 0; | 194 | return 0; |
| 195 | } | 195 | } |
| 196 | 196 | ||
| @@ -219,7 +219,7 @@ u32 gm45_get_vblank_counter(struct drm_device *dev, int pipe) | |||
| 219 | int reg = pipe ? PIPEB_FRMCOUNT_GM45 : PIPEA_FRMCOUNT_GM45; | 219 | int reg = pipe ? PIPEB_FRMCOUNT_GM45 : PIPEA_FRMCOUNT_GM45; |
| 220 | 220 | ||
| 221 | if (!i915_pipe_enabled(dev, pipe)) { | 221 | if (!i915_pipe_enabled(dev, pipe)) { |
| 222 | DRM_ERROR("trying to get vblank count for disabled pipe %d\n", pipe); | 222 | DRM_DEBUG("trying to get vblank count for disabled pipe %d\n", pipe); |
| 223 | return 0; | 223 | return 0; |
| 224 | } | 224 | } |
| 225 | 225 | ||
| @@ -290,6 +290,35 @@ irqreturn_t igdng_irq_handler(struct drm_device *dev) | |||
| 290 | return ret; | 290 | return ret; |
| 291 | } | 291 | } |
| 292 | 292 | ||
| 293 | /** | ||
| 294 | * i915_error_work_func - do process context error handling work | ||
| 295 | * @work: work struct | ||
| 296 | * | ||
| 297 | * Fire an error uevent so userspace can see that a hang or error | ||
| 298 | * was detected. | ||
| 299 | */ | ||
| 300 | static void i915_error_work_func(struct work_struct *work) | ||
| 301 | { | ||
| 302 | drm_i915_private_t *dev_priv = container_of(work, drm_i915_private_t, | ||
| 303 | error_work); | ||
| 304 | struct drm_device *dev = dev_priv->dev; | ||
| 305 | char *event_string = "ERROR=1"; | ||
| 306 | char *envp[] = { event_string, NULL }; | ||
| 307 | |||
| 308 | DRM_DEBUG("generating error event\n"); | ||
| 309 | |||
| 310 | kobject_uevent_env(&dev->primary->kdev.kobj, KOBJ_CHANGE, envp); | ||
| 311 | } | ||
| 312 | |||
| 313 | /** | ||
| 314 | * i915_capture_error_state - capture an error record for later analysis | ||
| 315 | * @dev: drm device | ||
| 316 | * | ||
| 317 | * Should be called when an error is detected (either a hang or an error | ||
| 318 | * interrupt) to capture error state from the time of the error. Fills | ||
| 319 | * out a structure which becomes available in debugfs for user level tools | ||
| 320 | * to pick up. | ||
| 321 | */ | ||
| 293 | static void i915_capture_error_state(struct drm_device *dev) | 322 | static void i915_capture_error_state(struct drm_device *dev) |
| 294 | { | 323 | { |
| 295 | struct drm_i915_private *dev_priv = dev->dev_private; | 324 | struct drm_i915_private *dev_priv = dev->dev_private; |
| @@ -325,12 +354,137 @@ static void i915_capture_error_state(struct drm_device *dev) | |||
| 325 | error->acthd = I915_READ(ACTHD_I965); | 354 | error->acthd = I915_READ(ACTHD_I965); |
| 326 | } | 355 | } |
| 327 | 356 | ||
| 357 | do_gettimeofday(&error->time); | ||
| 358 | |||
| 328 | dev_priv->first_error = error; | 359 | dev_priv->first_error = error; |
| 329 | 360 | ||
| 330 | out: | 361 | out: |
| 331 | spin_unlock_irqrestore(&dev_priv->error_lock, flags); | 362 | spin_unlock_irqrestore(&dev_priv->error_lock, flags); |
| 332 | } | 363 | } |
| 333 | 364 | ||
| 365 | /** | ||
| 366 | * i915_handle_error - handle an error interrupt | ||
| 367 | * @dev: drm device | ||
| 368 | * | ||
| 369 | * Do some basic checking of regsiter state at error interrupt time and | ||
| 370 | * dump it to the syslog. Also call i915_capture_error_state() to make | ||
| 371 | * sure we get a record and make it available in debugfs. Fire a uevent | ||
| 372 | * so userspace knows something bad happened (should trigger collection | ||
| 373 | * of a ring dump etc.). | ||
| 374 | */ | ||
| 375 | static void i915_handle_error(struct drm_device *dev) | ||
| 376 | { | ||
| 377 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
| 378 | u32 eir = I915_READ(EIR); | ||
| 379 | u32 pipea_stats = I915_READ(PIPEASTAT); | ||
| 380 | u32 pipeb_stats = I915_READ(PIPEBSTAT); | ||
| 381 | |||
| 382 | i915_capture_error_state(dev); | ||
| 383 | |||
| 384 | printk(KERN_ERR "render error detected, EIR: 0x%08x\n", | ||
| 385 | eir); | ||
| 386 | |||
| 387 | if (IS_G4X(dev)) { | ||
| 388 | if (eir & (GM45_ERROR_MEM_PRIV | GM45_ERROR_CP_PRIV)) { | ||
| 389 | u32 ipeir = I915_READ(IPEIR_I965); | ||
| 390 | |||
| 391 | printk(KERN_ERR " IPEIR: 0x%08x\n", | ||
| 392 | I915_READ(IPEIR_I965)); | ||
| 393 | printk(KERN_ERR " IPEHR: 0x%08x\n", | ||
| 394 | I915_READ(IPEHR_I965)); | ||
| 395 | printk(KERN_ERR " INSTDONE: 0x%08x\n", | ||
| 396 | I915_READ(INSTDONE_I965)); | ||
| 397 | printk(KERN_ERR " INSTPS: 0x%08x\n", | ||
| 398 | I915_READ(INSTPS)); | ||
| 399 | printk(KERN_ERR " INSTDONE1: 0x%08x\n", | ||
| 400 | I915_READ(INSTDONE1)); | ||
| 401 | printk(KERN_ERR " ACTHD: 0x%08x\n", | ||
| 402 | I915_READ(ACTHD_I965)); | ||
| 403 | I915_WRITE(IPEIR_I965, ipeir); | ||
| 404 | (void)I915_READ(IPEIR_I965); | ||
| 405 | } | ||
| 406 | if (eir & GM45_ERROR_PAGE_TABLE) { | ||
| 407 | u32 pgtbl_err = I915_READ(PGTBL_ER); | ||
| 408 | printk(KERN_ERR "page table error\n"); | ||
| 409 | printk(KERN_ERR " PGTBL_ER: 0x%08x\n", | ||
| 410 | pgtbl_err); | ||
| 411 | I915_WRITE(PGTBL_ER, pgtbl_err); | ||
| 412 | (void)I915_READ(PGTBL_ER); | ||
| 413 | } | ||
| 414 | } | ||
| 415 | |||
| 416 | if (IS_I9XX(dev)) { | ||
| 417 | if (eir & I915_ERROR_PAGE_TABLE) { | ||
| 418 | u32 pgtbl_err = I915_READ(PGTBL_ER); | ||
| 419 | printk(KERN_ERR "page table error\n"); | ||
| 420 | printk(KERN_ERR " PGTBL_ER: 0x%08x\n", | ||
| 421 | pgtbl_err); | ||
| 422 | I915_WRITE(PGTBL_ER, pgtbl_err); | ||
| 423 | (void)I915_READ(PGTBL_ER); | ||
| 424 | } | ||
| 425 | } | ||
| 426 | |||
| 427 | if (eir & I915_ERROR_MEMORY_REFRESH) { | ||
| 428 | printk(KERN_ERR "memory refresh error\n"); | ||
| 429 | printk(KERN_ERR "PIPEASTAT: 0x%08x\n", | ||
| 430 | pipea_stats); | ||
| 431 | printk(KERN_ERR "PIPEBSTAT: 0x%08x\n", | ||
| 432 | pipeb_stats); | ||
| 433 | /* pipestat has already been acked */ | ||
| 434 | } | ||
| 435 | if (eir & I915_ERROR_INSTRUCTION) { | ||
| 436 | printk(KERN_ERR "instruction error\n"); | ||
| 437 | printk(KERN_ERR " INSTPM: 0x%08x\n", | ||
| 438 | I915_READ(INSTPM)); | ||
| 439 | if (!IS_I965G(dev)) { | ||
| 440 | u32 ipeir = I915_READ(IPEIR); | ||
| 441 | |||
| 442 | printk(KERN_ERR " IPEIR: 0x%08x\n", | ||
| 443 | I915_READ(IPEIR)); | ||
| 444 | printk(KERN_ERR " IPEHR: 0x%08x\n", | ||
| 445 | I915_READ(IPEHR)); | ||
| 446 | printk(KERN_ERR " INSTDONE: 0x%08x\n", | ||
| 447 | I915_READ(INSTDONE)); | ||
| 448 | printk(KERN_ERR " ACTHD: 0x%08x\n", | ||
| 449 | I915_READ(ACTHD)); | ||
| 450 | I915_WRITE(IPEIR, ipeir); | ||
| 451 | (void)I915_READ(IPEIR); | ||
| 452 | } else { | ||
| 453 | u32 ipeir = I915_READ(IPEIR_I965); | ||
| 454 | |||
| 455 | printk(KERN_ERR " IPEIR: 0x%08x\n", | ||
| 456 | I915_READ(IPEIR_I965)); | ||
| 457 | printk(KERN_ERR " IPEHR: 0x%08x\n", | ||
| 458 | I915_READ(IPEHR_I965)); | ||
| 459 | printk(KERN_ERR " INSTDONE: 0x%08x\n", | ||
| 460 | I915_READ(INSTDONE_I965)); | ||
| 461 | printk(KERN_ERR " INSTPS: 0x%08x\n", | ||
| 462 | I915_READ(INSTPS)); | ||
| 463 | printk(KERN_ERR " INSTDONE1: 0x%08x\n", | ||
| 464 | I915_READ(INSTDONE1)); | ||
| 465 | printk(KERN_ERR " ACTHD: 0x%08x\n", | ||
| 466 | I915_READ(ACTHD_I965)); | ||
| 467 | I915_WRITE(IPEIR_I965, ipeir); | ||
| 468 | (void)I915_READ(IPEIR_I965); | ||
| 469 | } | ||
| 470 | } | ||
| 471 | |||
| 472 | I915_WRITE(EIR, eir); | ||
| 473 | (void)I915_READ(EIR); | ||
| 474 | eir = I915_READ(EIR); | ||
| 475 | if (eir) { | ||
| 476 | /* | ||
| 477 | * some errors might have become stuck, | ||
| 478 | * mask them. | ||
| 479 | */ | ||
| 480 | DRM_ERROR("EIR stuck: 0x%08x, masking\n", eir); | ||
| 481 | I915_WRITE(EMR, I915_READ(EMR) | eir); | ||
| 482 | I915_WRITE(IIR, I915_RENDER_COMMAND_PARSER_ERROR_INTERRUPT); | ||
| 483 | } | ||
| 484 | |||
| 485 | queue_work(dev_priv->wq, &dev_priv->error_work); | ||
| 486 | } | ||
| 487 | |||
| 334 | irqreturn_t i915_driver_irq_handler(DRM_IRQ_ARGS) | 488 | irqreturn_t i915_driver_irq_handler(DRM_IRQ_ARGS) |
| 335 | { | 489 | { |
| 336 | struct drm_device *dev = (struct drm_device *) arg; | 490 | struct drm_device *dev = (struct drm_device *) arg; |
| @@ -372,6 +526,9 @@ irqreturn_t i915_driver_irq_handler(DRM_IRQ_ARGS) | |||
| 372 | pipea_stats = I915_READ(PIPEASTAT); | 526 | pipea_stats = I915_READ(PIPEASTAT); |
| 373 | pipeb_stats = I915_READ(PIPEBSTAT); | 527 | pipeb_stats = I915_READ(PIPEBSTAT); |
| 374 | 528 | ||
| 529 | if (iir & I915_RENDER_COMMAND_PARSER_ERROR_INTERRUPT) | ||
| 530 | i915_handle_error(dev); | ||
| 531 | |||
| 375 | /* | 532 | /* |
| 376 | * Clear the PIPE(A|B)STAT regs before the IIR | 533 | * Clear the PIPE(A|B)STAT regs before the IIR |
| 377 | */ | 534 | */ |
| @@ -403,86 +560,13 @@ irqreturn_t i915_driver_irq_handler(DRM_IRQ_ARGS) | |||
| 403 | DRM_DEBUG("hotplug event received, stat 0x%08x\n", | 560 | DRM_DEBUG("hotplug event received, stat 0x%08x\n", |
| 404 | hotplug_status); | 561 | hotplug_status); |
| 405 | if (hotplug_status & dev_priv->hotplug_supported_mask) | 562 | if (hotplug_status & dev_priv->hotplug_supported_mask) |
| 406 | schedule_work(&dev_priv->hotplug_work); | 563 | queue_work(dev_priv->wq, |
| 564 | &dev_priv->hotplug_work); | ||
| 407 | 565 | ||
| 408 | I915_WRITE(PORT_HOTPLUG_STAT, hotplug_status); | 566 | I915_WRITE(PORT_HOTPLUG_STAT, hotplug_status); |
| 409 | I915_READ(PORT_HOTPLUG_STAT); | 567 | I915_READ(PORT_HOTPLUG_STAT); |
| 410 | } | 568 | } |
| 411 | 569 | ||
| 412 | if (iir & I915_RENDER_COMMAND_PARSER_ERROR_INTERRUPT) { | ||
| 413 | u32 eir = I915_READ(EIR); | ||
| 414 | |||
| 415 | i915_capture_error_state(dev); | ||
| 416 | |||
| 417 | printk(KERN_ERR "render error detected, EIR: 0x%08x\n", | ||
| 418 | eir); | ||
| 419 | if (eir & I915_ERROR_PAGE_TABLE) { | ||
| 420 | u32 pgtbl_err = I915_READ(PGTBL_ER); | ||
| 421 | printk(KERN_ERR "page table error\n"); | ||
| 422 | printk(KERN_ERR " PGTBL_ER: 0x%08x\n", | ||
| 423 | pgtbl_err); | ||
| 424 | I915_WRITE(PGTBL_ER, pgtbl_err); | ||
| 425 | (void)I915_READ(PGTBL_ER); | ||
| 426 | } | ||
| 427 | if (eir & I915_ERROR_MEMORY_REFRESH) { | ||
| 428 | printk(KERN_ERR "memory refresh error\n"); | ||
| 429 | printk(KERN_ERR "PIPEASTAT: 0x%08x\n", | ||
| 430 | pipea_stats); | ||
| 431 | printk(KERN_ERR "PIPEBSTAT: 0x%08x\n", | ||
| 432 | pipeb_stats); | ||
| 433 | /* pipestat has already been acked */ | ||
| 434 | } | ||
| 435 | if (eir & I915_ERROR_INSTRUCTION) { | ||
| 436 | printk(KERN_ERR "instruction error\n"); | ||
| 437 | printk(KERN_ERR " INSTPM: 0x%08x\n", | ||
| 438 | I915_READ(INSTPM)); | ||
| 439 | if (!IS_I965G(dev)) { | ||
| 440 | u32 ipeir = I915_READ(IPEIR); | ||
| 441 | |||
| 442 | printk(KERN_ERR " IPEIR: 0x%08x\n", | ||
| 443 | I915_READ(IPEIR)); | ||
| 444 | printk(KERN_ERR " IPEHR: 0x%08x\n", | ||
| 445 | I915_READ(IPEHR)); | ||
| 446 | printk(KERN_ERR " INSTDONE: 0x%08x\n", | ||
| 447 | I915_READ(INSTDONE)); | ||
| 448 | printk(KERN_ERR " ACTHD: 0x%08x\n", | ||
| 449 | I915_READ(ACTHD)); | ||
| 450 | I915_WRITE(IPEIR, ipeir); | ||
| 451 | (void)I915_READ(IPEIR); | ||
| 452 | } else { | ||
| 453 | u32 ipeir = I915_READ(IPEIR_I965); | ||
| 454 | |||
| 455 | printk(KERN_ERR " IPEIR: 0x%08x\n", | ||
| 456 | I915_READ(IPEIR_I965)); | ||
| 457 | printk(KERN_ERR " IPEHR: 0x%08x\n", | ||
| 458 | I915_READ(IPEHR_I965)); | ||
| 459 | printk(KERN_ERR " INSTDONE: 0x%08x\n", | ||
| 460 | I915_READ(INSTDONE_I965)); | ||
| 461 | printk(KERN_ERR " INSTPS: 0x%08x\n", | ||
| 462 | I915_READ(INSTPS)); | ||
| 463 | printk(KERN_ERR " INSTDONE1: 0x%08x\n", | ||
| 464 | I915_READ(INSTDONE1)); | ||
| 465 | printk(KERN_ERR " ACTHD: 0x%08x\n", | ||
| 466 | I915_READ(ACTHD_I965)); | ||
| 467 | I915_WRITE(IPEIR_I965, ipeir); | ||
| 468 | (void)I915_READ(IPEIR_I965); | ||
| 469 | } | ||
| 470 | } | ||
| 471 | |||
| 472 | I915_WRITE(EIR, eir); | ||
| 473 | (void)I915_READ(EIR); | ||
| 474 | eir = I915_READ(EIR); | ||
| 475 | if (eir) { | ||
| 476 | /* | ||
| 477 | * some errors might have become stuck, | ||
| 478 | * mask them. | ||
| 479 | */ | ||
| 480 | DRM_ERROR("EIR stuck: 0x%08x, masking\n", eir); | ||
| 481 | I915_WRITE(EMR, I915_READ(EMR) | eir); | ||
| 482 | I915_WRITE(IIR, I915_RENDER_COMMAND_PARSER_ERROR_INTERRUPT); | ||
| 483 | } | ||
| 484 | } | ||
| 485 | |||
| 486 | I915_WRITE(IIR, iir); | 570 | I915_WRITE(IIR, iir); |
| 487 | new_iir = I915_READ(IIR); /* Flush posted writes */ | 571 | new_iir = I915_READ(IIR); /* Flush posted writes */ |
| 488 | 572 | ||
| @@ -830,6 +914,7 @@ void i915_driver_irq_preinstall(struct drm_device * dev) | |||
| 830 | atomic_set(&dev_priv->irq_received, 0); | 914 | atomic_set(&dev_priv->irq_received, 0); |
| 831 | 915 | ||
| 832 | INIT_WORK(&dev_priv->hotplug_work, i915_hotplug_work_func); | 916 | INIT_WORK(&dev_priv->hotplug_work, i915_hotplug_work_func); |
| 917 | INIT_WORK(&dev_priv->error_work, i915_error_work_func); | ||
| 833 | 918 | ||
| 834 | if (IS_IGDNG(dev)) { | 919 | if (IS_IGDNG(dev)) { |
| 835 | igdng_irq_preinstall(dev); | 920 | igdng_irq_preinstall(dev); |
diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h index 6c0858484094..2955083aa471 100644 --- a/drivers/gpu/drm/i915/i915_reg.h +++ b/drivers/gpu/drm/i915/i915_reg.h | |||
| @@ -1395,6 +1395,7 @@ | |||
| 1395 | #define TV_V_CHROMA_42 0x684a8 | 1395 | #define TV_V_CHROMA_42 0x684a8 |
| 1396 | 1396 | ||
| 1397 | /* Display Port */ | 1397 | /* Display Port */ |
| 1398 | #define DP_A 0x64000 /* eDP */ | ||
| 1398 | #define DP_B 0x64100 | 1399 | #define DP_B 0x64100 |
| 1399 | #define DP_C 0x64200 | 1400 | #define DP_C 0x64200 |
| 1400 | #define DP_D 0x64300 | 1401 | #define DP_D 0x64300 |
| @@ -1437,13 +1438,22 @@ | |||
| 1437 | /* Mystic DPCD version 1.1 special mode */ | 1438 | /* Mystic DPCD version 1.1 special mode */ |
| 1438 | #define DP_ENHANCED_FRAMING (1 << 18) | 1439 | #define DP_ENHANCED_FRAMING (1 << 18) |
| 1439 | 1440 | ||
| 1441 | /* eDP */ | ||
| 1442 | #define DP_PLL_FREQ_270MHZ (0 << 16) | ||
| 1443 | #define DP_PLL_FREQ_160MHZ (1 << 16) | ||
| 1444 | #define DP_PLL_FREQ_MASK (3 << 16) | ||
| 1445 | |||
| 1440 | /** locked once port is enabled */ | 1446 | /** locked once port is enabled */ |
| 1441 | #define DP_PORT_REVERSAL (1 << 15) | 1447 | #define DP_PORT_REVERSAL (1 << 15) |
| 1442 | 1448 | ||
| 1449 | /* eDP */ | ||
| 1450 | #define DP_PLL_ENABLE (1 << 14) | ||
| 1451 | |||
| 1443 | /** sends the clock on lane 15 of the PEG for debug */ | 1452 | /** sends the clock on lane 15 of the PEG for debug */ |
| 1444 | #define DP_CLOCK_OUTPUT_ENABLE (1 << 13) | 1453 | #define DP_CLOCK_OUTPUT_ENABLE (1 << 13) |
| 1445 | 1454 | ||
| 1446 | #define DP_SCRAMBLING_DISABLE (1 << 12) | 1455 | #define DP_SCRAMBLING_DISABLE (1 << 12) |
| 1456 | #define DP_SCRAMBLING_DISABLE_IGDNG (1 << 7) | ||
| 1447 | 1457 | ||
| 1448 | /** limit RGB values to avoid confusing TVs */ | 1458 | /** limit RGB values to avoid confusing TVs */ |
| 1449 | #define DP_COLOR_RANGE_16_235 (1 << 8) | 1459 | #define DP_COLOR_RANGE_16_235 (1 << 8) |
| @@ -1463,6 +1473,13 @@ | |||
| 1463 | * is 20 bytes in each direction, hence the 5 fixed | 1473 | * is 20 bytes in each direction, hence the 5 fixed |
| 1464 | * data registers | 1474 | * data registers |
| 1465 | */ | 1475 | */ |
| 1476 | #define DPA_AUX_CH_CTL 0x64010 | ||
| 1477 | #define DPA_AUX_CH_DATA1 0x64014 | ||
| 1478 | #define DPA_AUX_CH_DATA2 0x64018 | ||
| 1479 | #define DPA_AUX_CH_DATA3 0x6401c | ||
| 1480 | #define DPA_AUX_CH_DATA4 0x64020 | ||
| 1481 | #define DPA_AUX_CH_DATA5 0x64024 | ||
| 1482 | |||
| 1466 | #define DPB_AUX_CH_CTL 0x64110 | 1483 | #define DPB_AUX_CH_CTL 0x64110 |
| 1467 | #define DPB_AUX_CH_DATA1 0x64114 | 1484 | #define DPB_AUX_CH_DATA1 0x64114 |
| 1468 | #define DPB_AUX_CH_DATA2 0x64118 | 1485 | #define DPB_AUX_CH_DATA2 0x64118 |
| @@ -1618,7 +1635,7 @@ | |||
| 1618 | #define I830_FIFO_LINE_SIZE 32 | 1635 | #define I830_FIFO_LINE_SIZE 32 |
| 1619 | #define I945_FIFO_SIZE 127 /* 945 & 965 */ | 1636 | #define I945_FIFO_SIZE 127 /* 945 & 965 */ |
| 1620 | #define I915_FIFO_SIZE 95 | 1637 | #define I915_FIFO_SIZE 95 |
| 1621 | #define I855GM_FIFO_SIZE 255 | 1638 | #define I855GM_FIFO_SIZE 127 /* In cachelines */ |
| 1622 | #define I830_FIFO_SIZE 95 | 1639 | #define I830_FIFO_SIZE 95 |
| 1623 | #define I915_MAX_WM 0x3f | 1640 | #define I915_MAX_WM 0x3f |
| 1624 | 1641 | ||
| @@ -1848,6 +1865,8 @@ | |||
| 1848 | #define PFA_CTL_1 0x68080 | 1865 | #define PFA_CTL_1 0x68080 |
| 1849 | #define PFB_CTL_1 0x68880 | 1866 | #define PFB_CTL_1 0x68880 |
| 1850 | #define PF_ENABLE (1<<31) | 1867 | #define PF_ENABLE (1<<31) |
| 1868 | #define PFA_WIN_SZ 0x68074 | ||
| 1869 | #define PFB_WIN_SZ 0x68874 | ||
| 1851 | 1870 | ||
| 1852 | /* legacy palette */ | 1871 | /* legacy palette */ |
| 1853 | #define LGC_PALETTE_A 0x4a000 | 1872 | #define LGC_PALETTE_A 0x4a000 |
| @@ -2208,4 +2227,28 @@ | |||
| 2208 | #define PCH_PP_OFF_DELAYS 0xc720c | 2227 | #define PCH_PP_OFF_DELAYS 0xc720c |
| 2209 | #define PCH_PP_DIVISOR 0xc7210 | 2228 | #define PCH_PP_DIVISOR 0xc7210 |
| 2210 | 2229 | ||
| 2230 | #define PCH_DP_B 0xe4100 | ||
| 2231 | #define PCH_DPB_AUX_CH_CTL 0xe4110 | ||
| 2232 | #define PCH_DPB_AUX_CH_DATA1 0xe4114 | ||
| 2233 | #define PCH_DPB_AUX_CH_DATA2 0xe4118 | ||
| 2234 | #define PCH_DPB_AUX_CH_DATA3 0xe411c | ||
| 2235 | #define PCH_DPB_AUX_CH_DATA4 0xe4120 | ||
| 2236 | #define PCH_DPB_AUX_CH_DATA5 0xe4124 | ||
| 2237 | |||
| 2238 | #define PCH_DP_C 0xe4200 | ||
| 2239 | #define PCH_DPC_AUX_CH_CTL 0xe4210 | ||
| 2240 | #define PCH_DPC_AUX_CH_DATA1 0xe4214 | ||
| 2241 | #define PCH_DPC_AUX_CH_DATA2 0xe4218 | ||
| 2242 | #define PCH_DPC_AUX_CH_DATA3 0xe421c | ||
| 2243 | #define PCH_DPC_AUX_CH_DATA4 0xe4220 | ||
| 2244 | #define PCH_DPC_AUX_CH_DATA5 0xe4224 | ||
| 2245 | |||
| 2246 | #define PCH_DP_D 0xe4300 | ||
| 2247 | #define PCH_DPD_AUX_CH_CTL 0xe4310 | ||
| 2248 | #define PCH_DPD_AUX_CH_DATA1 0xe4314 | ||
| 2249 | #define PCH_DPD_AUX_CH_DATA2 0xe4318 | ||
| 2250 | #define PCH_DPD_AUX_CH_DATA3 0xe431c | ||
| 2251 | #define PCH_DPD_AUX_CH_DATA4 0xe4320 | ||
| 2252 | #define PCH_DPD_AUX_CH_DATA5 0xe4324 | ||
| 2253 | |||
| 2211 | #endif /* _I915_REG_H_ */ | 2254 | #endif /* _I915_REG_H_ */ |
diff --git a/drivers/gpu/drm/i915/i915_suspend.c b/drivers/gpu/drm/i915/i915_suspend.c index 9e1d16e5c3ea..1d04e1904ac6 100644 --- a/drivers/gpu/drm/i915/i915_suspend.c +++ b/drivers/gpu/drm/i915/i915_suspend.c | |||
| @@ -598,7 +598,7 @@ int i915_restore_state(struct drm_device *dev) | |||
| 598 | 598 | ||
| 599 | for (i = 0; i < 16; i++) { | 599 | for (i = 0; i < 16; i++) { |
| 600 | I915_WRITE(SWF00 + (i << 2), dev_priv->saveSWF0[i]); | 600 | I915_WRITE(SWF00 + (i << 2), dev_priv->saveSWF0[i]); |
| 601 | I915_WRITE(SWF10 + (i << 2), dev_priv->saveSWF1[i+7]); | 601 | I915_WRITE(SWF10 + (i << 2), dev_priv->saveSWF1[i]); |
| 602 | } | 602 | } |
| 603 | for (i = 0; i < 3; i++) | 603 | for (i = 0; i < 3; i++) |
| 604 | I915_WRITE(SWF30 + (i << 2), dev_priv->saveSWF2[i]); | 604 | I915_WRITE(SWF30 + (i << 2), dev_priv->saveSWF2[i]); |
diff --git a/drivers/gpu/drm/i915/intel_bios.c b/drivers/gpu/drm/i915/intel_bios.c index 7cc447191028..300aee3296c2 100644 --- a/drivers/gpu/drm/i915/intel_bios.c +++ b/drivers/gpu/drm/i915/intel_bios.c | |||
| @@ -97,14 +97,13 @@ static void | |||
| 97 | parse_lfp_panel_data(struct drm_i915_private *dev_priv, | 97 | parse_lfp_panel_data(struct drm_i915_private *dev_priv, |
| 98 | struct bdb_header *bdb) | 98 | struct bdb_header *bdb) |
| 99 | { | 99 | { |
| 100 | struct drm_device *dev = dev_priv->dev; | ||
| 101 | struct bdb_lvds_options *lvds_options; | 100 | struct bdb_lvds_options *lvds_options; |
| 102 | struct bdb_lvds_lfp_data *lvds_lfp_data; | 101 | struct bdb_lvds_lfp_data *lvds_lfp_data; |
| 103 | struct bdb_lvds_lfp_data_ptrs *lvds_lfp_data_ptrs; | 102 | struct bdb_lvds_lfp_data_ptrs *lvds_lfp_data_ptrs; |
| 104 | struct bdb_lvds_lfp_data_entry *entry; | 103 | struct bdb_lvds_lfp_data_entry *entry; |
| 105 | struct lvds_dvo_timing *dvo_timing; | 104 | struct lvds_dvo_timing *dvo_timing; |
| 106 | struct drm_display_mode *panel_fixed_mode; | 105 | struct drm_display_mode *panel_fixed_mode; |
| 107 | int lfp_data_size; | 106 | int lfp_data_size, dvo_timing_offset; |
| 108 | 107 | ||
| 109 | /* Defaults if we can't find VBT info */ | 108 | /* Defaults if we can't find VBT info */ |
| 110 | dev_priv->lvds_dither = 0; | 109 | dev_priv->lvds_dither = 0; |
| @@ -133,14 +132,16 @@ parse_lfp_panel_data(struct drm_i915_private *dev_priv, | |||
| 133 | entry = (struct bdb_lvds_lfp_data_entry *) | 132 | entry = (struct bdb_lvds_lfp_data_entry *) |
| 134 | ((uint8_t *)lvds_lfp_data->data + (lfp_data_size * | 133 | ((uint8_t *)lvds_lfp_data->data + (lfp_data_size * |
| 135 | lvds_options->panel_type)); | 134 | lvds_options->panel_type)); |
| 135 | dvo_timing_offset = lvds_lfp_data_ptrs->ptr[0].dvo_timing_offset - | ||
| 136 | lvds_lfp_data_ptrs->ptr[0].fp_timing_offset; | ||
| 136 | 137 | ||
| 137 | /* On IGDNG mobile, LVDS data block removes panel fitting registers. | 138 | /* |
| 138 | So dec 2 dword from dvo_timing offset */ | 139 | * the size of fp_timing varies on the different platform. |
| 139 | if (IS_IGDNG(dev)) | 140 | * So calculate the DVO timing relative offset in LVDS data |
| 140 | dvo_timing = (struct lvds_dvo_timing *) | 141 | * entry to get the DVO timing entry |
| 141 | ((u8 *)&entry->dvo_timing - 8); | 142 | */ |
| 142 | else | 143 | dvo_timing = (struct lvds_dvo_timing *) |
| 143 | dvo_timing = &entry->dvo_timing; | 144 | ((unsigned char *)entry + dvo_timing_offset); |
| 144 | 145 | ||
| 145 | panel_fixed_mode = kzalloc(sizeof(*panel_fixed_mode), GFP_KERNEL); | 146 | panel_fixed_mode = kzalloc(sizeof(*panel_fixed_mode), GFP_KERNEL); |
| 146 | 147 | ||
| @@ -295,6 +296,25 @@ parse_sdvo_device_mapping(struct drm_i915_private *dev_priv, | |||
| 295 | } | 296 | } |
| 296 | return; | 297 | return; |
| 297 | } | 298 | } |
| 299 | |||
| 300 | static void | ||
| 301 | parse_driver_features(struct drm_i915_private *dev_priv, | ||
| 302 | struct bdb_header *bdb) | ||
| 303 | { | ||
| 304 | struct drm_device *dev = dev_priv->dev; | ||
| 305 | struct bdb_driver_features *driver; | ||
| 306 | |||
| 307 | /* set default for chips without eDP */ | ||
| 308 | if (!SUPPORTS_EDP(dev)) { | ||
| 309 | dev_priv->edp_support = 0; | ||
| 310 | return; | ||
| 311 | } | ||
| 312 | |||
| 313 | driver = find_section(bdb, BDB_DRIVER_FEATURES); | ||
| 314 | if (driver && driver->lvds_config == BDB_DRIVER_FEATURE_EDP) | ||
| 315 | dev_priv->edp_support = 1; | ||
| 316 | } | ||
| 317 | |||
| 298 | /** | 318 | /** |
| 299 | * intel_init_bios - initialize VBIOS settings & find VBT | 319 | * intel_init_bios - initialize VBIOS settings & find VBT |
| 300 | * @dev: DRM device | 320 | * @dev: DRM device |
| @@ -345,6 +365,8 @@ intel_init_bios(struct drm_device *dev) | |||
| 345 | parse_lfp_panel_data(dev_priv, bdb); | 365 | parse_lfp_panel_data(dev_priv, bdb); |
| 346 | parse_sdvo_panel_data(dev_priv, bdb); | 366 | parse_sdvo_panel_data(dev_priv, bdb); |
| 347 | parse_sdvo_device_mapping(dev_priv, bdb); | 367 | parse_sdvo_device_mapping(dev_priv, bdb); |
| 368 | parse_driver_features(dev_priv, bdb); | ||
| 369 | |||
| 348 | pci_unmap_rom(pdev, bios); | 370 | pci_unmap_rom(pdev, bios); |
| 349 | 371 | ||
| 350 | return 0; | 372 | return 0; |
diff --git a/drivers/gpu/drm/i915/intel_bios.h b/drivers/gpu/drm/i915/intel_bios.h index fe72e1c225d8..0f8e5f69ac7a 100644 --- a/drivers/gpu/drm/i915/intel_bios.h +++ b/drivers/gpu/drm/i915/intel_bios.h | |||
| @@ -381,6 +381,51 @@ struct bdb_sdvo_lvds_options { | |||
| 381 | } __attribute__((packed)); | 381 | } __attribute__((packed)); |
| 382 | 382 | ||
| 383 | 383 | ||
| 384 | #define BDB_DRIVER_FEATURE_NO_LVDS 0 | ||
| 385 | #define BDB_DRIVER_FEATURE_INT_LVDS 1 | ||
| 386 | #define BDB_DRIVER_FEATURE_SDVO_LVDS 2 | ||
| 387 | #define BDB_DRIVER_FEATURE_EDP 3 | ||
| 388 | |||
| 389 | struct bdb_driver_features { | ||
| 390 | u8 boot_dev_algorithm:1; | ||
| 391 | u8 block_display_switch:1; | ||
| 392 | u8 allow_display_switch:1; | ||
| 393 | u8 hotplug_dvo:1; | ||
| 394 | u8 dual_view_zoom:1; | ||
| 395 | u8 int15h_hook:1; | ||
| 396 | u8 sprite_in_clone:1; | ||
| 397 | u8 primary_lfp_id:1; | ||
| 398 | |||
| 399 | u16 boot_mode_x; | ||
| 400 | u16 boot_mode_y; | ||
| 401 | u8 boot_mode_bpp; | ||
| 402 | u8 boot_mode_refresh; | ||
| 403 | |||
| 404 | u16 enable_lfp_primary:1; | ||
| 405 | u16 selective_mode_pruning:1; | ||
| 406 | u16 dual_frequency:1; | ||
| 407 | u16 render_clock_freq:1; /* 0: high freq; 1: low freq */ | ||
| 408 | u16 nt_clone_support:1; | ||
| 409 | u16 power_scheme_ui:1; /* 0: CUI; 1: 3rd party */ | ||
| 410 | u16 sprite_display_assign:1; /* 0: secondary; 1: primary */ | ||
| 411 | u16 cui_aspect_scaling:1; | ||
| 412 | u16 preserve_aspect_ratio:1; | ||
| 413 | u16 sdvo_device_power_down:1; | ||
| 414 | u16 crt_hotplug:1; | ||
| 415 | u16 lvds_config:2; | ||
| 416 | u16 tv_hotplug:1; | ||
| 417 | u16 hdmi_config:2; | ||
| 418 | |||
| 419 | u8 static_display:1; | ||
| 420 | u8 reserved2:7; | ||
| 421 | u16 legacy_crt_max_x; | ||
| 422 | u16 legacy_crt_max_y; | ||
| 423 | u8 legacy_crt_max_refresh; | ||
| 424 | |||
| 425 | u8 hdmi_termination; | ||
| 426 | u8 custom_vbt_version; | ||
| 427 | } __attribute__((packed)); | ||
| 428 | |||
| 384 | bool intel_init_bios(struct drm_device *dev); | 429 | bool intel_init_bios(struct drm_device *dev); |
| 385 | 430 | ||
| 386 | /* | 431 | /* |
diff --git a/drivers/gpu/drm/i915/intel_crt.c b/drivers/gpu/drm/i915/intel_crt.c index d6a1a6e5539a..4cf8e2e88a40 100644 --- a/drivers/gpu/drm/i915/intel_crt.c +++ b/drivers/gpu/drm/i915/intel_crt.c | |||
| @@ -156,6 +156,9 @@ static bool intel_igdng_crt_detect_hotplug(struct drm_connector *connector) | |||
| 156 | 156 | ||
| 157 | temp = adpa = I915_READ(PCH_ADPA); | 157 | temp = adpa = I915_READ(PCH_ADPA); |
| 158 | 158 | ||
| 159 | adpa &= ~ADPA_DAC_ENABLE; | ||
| 160 | I915_WRITE(PCH_ADPA, adpa); | ||
| 161 | |||
| 159 | adpa &= ~ADPA_CRT_HOTPLUG_MASK; | 162 | adpa &= ~ADPA_CRT_HOTPLUG_MASK; |
| 160 | 163 | ||
| 161 | adpa |= (ADPA_CRT_HOTPLUG_PERIOD_128 | | 164 | adpa |= (ADPA_CRT_HOTPLUG_PERIOD_128 | |
| @@ -169,13 +172,14 @@ static bool intel_igdng_crt_detect_hotplug(struct drm_connector *connector) | |||
| 169 | DRM_DEBUG("pch crt adpa 0x%x", adpa); | 172 | DRM_DEBUG("pch crt adpa 0x%x", adpa); |
| 170 | I915_WRITE(PCH_ADPA, adpa); | 173 | I915_WRITE(PCH_ADPA, adpa); |
| 171 | 174 | ||
| 172 | /* This might not be needed as not specified in spec...*/ | 175 | while ((I915_READ(PCH_ADPA) & ADPA_CRT_HOTPLUG_FORCE_TRIGGER) != 0) |
| 173 | udelay(1000); | 176 | ; |
| 174 | 177 | ||
| 175 | /* Check the status to see if both blue and green are on now */ | 178 | /* Check the status to see if both blue and green are on now */ |
| 176 | adpa = I915_READ(PCH_ADPA); | 179 | adpa = I915_READ(PCH_ADPA); |
| 177 | if ((adpa & ADPA_CRT_HOTPLUG_MONITOR_MASK) == | 180 | adpa &= ADPA_CRT_HOTPLUG_MONITOR_MASK; |
| 178 | ADPA_CRT_HOTPLUG_MONITOR_COLOR) | 181 | if ((adpa == ADPA_CRT_HOTPLUG_MONITOR_COLOR) || |
| 182 | (adpa == ADPA_CRT_HOTPLUG_MONITOR_MONO)) | ||
| 179 | ret = true; | 183 | ret = true; |
| 180 | else | 184 | else |
| 181 | ret = false; | 185 | ret = false; |
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c index 508838ee31e0..d6fce2133413 100644 --- a/drivers/gpu/drm/i915/intel_display.c +++ b/drivers/gpu/drm/i915/intel_display.c | |||
| @@ -34,6 +34,8 @@ | |||
| 34 | 34 | ||
| 35 | #include "drm_crtc_helper.h" | 35 | #include "drm_crtc_helper.h" |
| 36 | 36 | ||
| 37 | #define HAS_eDP (intel_pipe_has_type(crtc, INTEL_OUTPUT_EDP)) | ||
| 38 | |||
| 37 | bool intel_pipe_has_type (struct drm_crtc *crtc, int type); | 39 | bool intel_pipe_has_type (struct drm_crtc *crtc, int type); |
| 38 | static void intel_update_watermarks(struct drm_device *dev); | 40 | static void intel_update_watermarks(struct drm_device *dev); |
| 39 | 41 | ||
| @@ -88,7 +90,7 @@ struct intel_limit { | |||
| 88 | #define I8XX_P2_SLOW 4 | 90 | #define I8XX_P2_SLOW 4 |
| 89 | #define I8XX_P2_FAST 2 | 91 | #define I8XX_P2_FAST 2 |
| 90 | #define I8XX_P2_LVDS_SLOW 14 | 92 | #define I8XX_P2_LVDS_SLOW 14 |
| 91 | #define I8XX_P2_LVDS_FAST 14 /* No fast option */ | 93 | #define I8XX_P2_LVDS_FAST 7 |
| 92 | #define I8XX_P2_SLOW_LIMIT 165000 | 94 | #define I8XX_P2_SLOW_LIMIT 165000 |
| 93 | 95 | ||
| 94 | #define I9XX_DOT_MIN 20000 | 96 | #define I9XX_DOT_MIN 20000 |
| @@ -268,6 +270,9 @@ intel_igdng_find_best_PLL(const intel_limit_t *limit, struct drm_crtc *crtc, | |||
| 268 | static bool | 270 | static bool |
| 269 | intel_find_pll_g4x_dp(const intel_limit_t *, struct drm_crtc *crtc, | 271 | intel_find_pll_g4x_dp(const intel_limit_t *, struct drm_crtc *crtc, |
| 270 | int target, int refclk, intel_clock_t *best_clock); | 272 | int target, int refclk, intel_clock_t *best_clock); |
| 273 | static bool | ||
| 274 | intel_find_pll_igdng_dp(const intel_limit_t *, struct drm_crtc *crtc, | ||
| 275 | int target, int refclk, intel_clock_t *best_clock); | ||
| 271 | 276 | ||
| 272 | static const intel_limit_t intel_limits_i8xx_dvo = { | 277 | static const intel_limit_t intel_limits_i8xx_dvo = { |
| 273 | .dot = { .min = I8XX_DOT_MIN, .max = I8XX_DOT_MAX }, | 278 | .dot = { .min = I8XX_DOT_MIN, .max = I8XX_DOT_MAX }, |
| @@ -598,6 +603,23 @@ bool intel_pipe_has_type (struct drm_crtc *crtc, int type) | |||
| 598 | return false; | 603 | return false; |
| 599 | } | 604 | } |
| 600 | 605 | ||
| 606 | struct drm_connector * | ||
| 607 | intel_pipe_get_output (struct drm_crtc *crtc) | ||
| 608 | { | ||
| 609 | struct drm_device *dev = crtc->dev; | ||
| 610 | struct drm_mode_config *mode_config = &dev->mode_config; | ||
| 611 | struct drm_connector *l_entry, *ret = NULL; | ||
| 612 | |||
| 613 | list_for_each_entry(l_entry, &mode_config->connector_list, head) { | ||
| 614 | if (l_entry->encoder && | ||
| 615 | l_entry->encoder->crtc == crtc) { | ||
| 616 | ret = l_entry; | ||
| 617 | break; | ||
| 618 | } | ||
| 619 | } | ||
| 620 | return ret; | ||
| 621 | } | ||
| 622 | |||
| 601 | #define INTELPllInvalid(s) do { /* DRM_DEBUG(s); */ return false; } while (0) | 623 | #define INTELPllInvalid(s) do { /* DRM_DEBUG(s); */ return false; } while (0) |
| 602 | /** | 624 | /** |
| 603 | * Returns whether the given set of divisors are valid for a given refclk with | 625 | * Returns whether the given set of divisors are valid for a given refclk with |
| @@ -645,7 +667,7 @@ intel_find_best_PLL(const intel_limit_t *limit, struct drm_crtc *crtc, | |||
| 645 | int err = target; | 667 | int err = target; |
| 646 | 668 | ||
| 647 | if (IS_I9XX(dev) && intel_pipe_has_type(crtc, INTEL_OUTPUT_LVDS) && | 669 | if (IS_I9XX(dev) && intel_pipe_has_type(crtc, INTEL_OUTPUT_LVDS) && |
| 648 | (I915_READ(LVDS) & LVDS_PORT_EN) != 0) { | 670 | (I915_READ(LVDS)) != 0) { |
| 649 | /* | 671 | /* |
| 650 | * For LVDS, if the panel is on, just rely on its current | 672 | * For LVDS, if the panel is on, just rely on its current |
| 651 | * settings for dual-channel. We haven't figured out how to | 673 | * settings for dual-channel. We haven't figured out how to |
| @@ -752,6 +774,30 @@ intel_g4x_find_best_PLL(const intel_limit_t *limit, struct drm_crtc *crtc, | |||
| 752 | } | 774 | } |
| 753 | 775 | ||
| 754 | static bool | 776 | static bool |
| 777 | intel_find_pll_igdng_dp(const intel_limit_t *limit, struct drm_crtc *crtc, | ||
| 778 | int target, int refclk, intel_clock_t *best_clock) | ||
| 779 | { | ||
| 780 | struct drm_device *dev = crtc->dev; | ||
| 781 | intel_clock_t clock; | ||
| 782 | if (target < 200000) { | ||
| 783 | clock.n = 1; | ||
| 784 | clock.p1 = 2; | ||
| 785 | clock.p2 = 10; | ||
| 786 | clock.m1 = 12; | ||
| 787 | clock.m2 = 9; | ||
| 788 | } else { | ||
| 789 | clock.n = 2; | ||
| 790 | clock.p1 = 1; | ||
| 791 | clock.p2 = 10; | ||
| 792 | clock.m1 = 14; | ||
| 793 | clock.m2 = 8; | ||
| 794 | } | ||
| 795 | intel_clock(dev, refclk, &clock); | ||
| 796 | memcpy(best_clock, &clock, sizeof(intel_clock_t)); | ||
| 797 | return true; | ||
| 798 | } | ||
| 799 | |||
| 800 | static bool | ||
| 755 | intel_igdng_find_best_PLL(const intel_limit_t *limit, struct drm_crtc *crtc, | 801 | intel_igdng_find_best_PLL(const intel_limit_t *limit, struct drm_crtc *crtc, |
| 756 | int target, int refclk, intel_clock_t *best_clock) | 802 | int target, int refclk, intel_clock_t *best_clock) |
| 757 | { | 803 | { |
| @@ -763,6 +809,14 @@ intel_igdng_find_best_PLL(const intel_limit_t *limit, struct drm_crtc *crtc, | |||
| 763 | int err_most = 47; | 809 | int err_most = 47; |
| 764 | found = false; | 810 | found = false; |
| 765 | 811 | ||
| 812 | /* eDP has only 2 clock choice, no n/m/p setting */ | ||
| 813 | if (HAS_eDP) | ||
| 814 | return true; | ||
| 815 | |||
| 816 | if (intel_pipe_has_type(crtc, INTEL_OUTPUT_DISPLAYPORT)) | ||
| 817 | return intel_find_pll_igdng_dp(limit, crtc, target, | ||
| 818 | refclk, best_clock); | ||
| 819 | |||
| 766 | if (intel_pipe_has_type(crtc, INTEL_OUTPUT_LVDS)) { | 820 | if (intel_pipe_has_type(crtc, INTEL_OUTPUT_LVDS)) { |
| 767 | if ((I915_READ(LVDS) & LVDS_CLKB_POWER_MASK) == | 821 | if ((I915_READ(LVDS) & LVDS_CLKB_POWER_MASK) == |
| 768 | LVDS_CLKB_POWER_UP) | 822 | LVDS_CLKB_POWER_UP) |
| @@ -998,6 +1052,90 @@ intel_pipe_set_base(struct drm_crtc *crtc, int x, int y, | |||
| 998 | return 0; | 1052 | return 0; |
| 999 | } | 1053 | } |
| 1000 | 1054 | ||
| 1055 | /* Disable the VGA plane that we never use */ | ||
| 1056 | static void i915_disable_vga (struct drm_device *dev) | ||
| 1057 | { | ||
| 1058 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
| 1059 | u8 sr1; | ||
| 1060 | u32 vga_reg; | ||
| 1061 | |||
| 1062 | if (IS_IGDNG(dev)) | ||
| 1063 | vga_reg = CPU_VGACNTRL; | ||
| 1064 | else | ||
| 1065 | vga_reg = VGACNTRL; | ||
| 1066 | |||
| 1067 | if (I915_READ(vga_reg) & VGA_DISP_DISABLE) | ||
| 1068 | return; | ||
| 1069 | |||
| 1070 | I915_WRITE8(VGA_SR_INDEX, 1); | ||
| 1071 | sr1 = I915_READ8(VGA_SR_DATA); | ||
| 1072 | I915_WRITE8(VGA_SR_DATA, sr1 | (1 << 5)); | ||
| 1073 | udelay(100); | ||
| 1074 | |||
| 1075 | I915_WRITE(vga_reg, VGA_DISP_DISABLE); | ||
| 1076 | } | ||
| 1077 | |||
| 1078 | static void igdng_disable_pll_edp (struct drm_crtc *crtc) | ||
| 1079 | { | ||
| 1080 | struct drm_device *dev = crtc->dev; | ||
| 1081 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
| 1082 | u32 dpa_ctl; | ||
| 1083 | |||
| 1084 | DRM_DEBUG("\n"); | ||
| 1085 | dpa_ctl = I915_READ(DP_A); | ||
| 1086 | dpa_ctl &= ~DP_PLL_ENABLE; | ||
| 1087 | I915_WRITE(DP_A, dpa_ctl); | ||
| 1088 | } | ||
| 1089 | |||
| 1090 | static void igdng_enable_pll_edp (struct drm_crtc *crtc) | ||
| 1091 | { | ||
| 1092 | struct drm_device *dev = crtc->dev; | ||
| 1093 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
| 1094 | u32 dpa_ctl; | ||
| 1095 | |||
| 1096 | dpa_ctl = I915_READ(DP_A); | ||
| 1097 | dpa_ctl |= DP_PLL_ENABLE; | ||
| 1098 | I915_WRITE(DP_A, dpa_ctl); | ||
| 1099 | udelay(200); | ||
| 1100 | } | ||
| 1101 | |||
| 1102 | |||
| 1103 | static void igdng_set_pll_edp (struct drm_crtc *crtc, int clock) | ||
| 1104 | { | ||
| 1105 | struct drm_device *dev = crtc->dev; | ||
| 1106 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
| 1107 | u32 dpa_ctl; | ||
| 1108 | |||
| 1109 | DRM_DEBUG("eDP PLL enable for clock %d\n", clock); | ||
| 1110 | dpa_ctl = I915_READ(DP_A); | ||
| 1111 | dpa_ctl &= ~DP_PLL_FREQ_MASK; | ||
| 1112 | |||
| 1113 | if (clock < 200000) { | ||
| 1114 | u32 temp; | ||
| 1115 | dpa_ctl |= DP_PLL_FREQ_160MHZ; | ||
| 1116 | /* workaround for 160Mhz: | ||
| 1117 | 1) program 0x4600c bits 15:0 = 0x8124 | ||
| 1118 | 2) program 0x46010 bit 0 = 1 | ||
| 1119 | 3) program 0x46034 bit 24 = 1 | ||
| 1120 | 4) program 0x64000 bit 14 = 1 | ||
| 1121 | */ | ||
| 1122 | temp = I915_READ(0x4600c); | ||
| 1123 | temp &= 0xffff0000; | ||
| 1124 | I915_WRITE(0x4600c, temp | 0x8124); | ||
| 1125 | |||
| 1126 | temp = I915_READ(0x46010); | ||
| 1127 | I915_WRITE(0x46010, temp | 1); | ||
| 1128 | |||
| 1129 | temp = I915_READ(0x46034); | ||
| 1130 | I915_WRITE(0x46034, temp | (1 << 24)); | ||
| 1131 | } else { | ||
| 1132 | dpa_ctl |= DP_PLL_FREQ_270MHZ; | ||
| 1133 | } | ||
| 1134 | I915_WRITE(DP_A, dpa_ctl); | ||
| 1135 | |||
| 1136 | udelay(500); | ||
| 1137 | } | ||
| 1138 | |||
| 1001 | static void igdng_crtc_dpms(struct drm_crtc *crtc, int mode) | 1139 | static void igdng_crtc_dpms(struct drm_crtc *crtc, int mode) |
| 1002 | { | 1140 | { |
| 1003 | struct drm_device *dev = crtc->dev; | 1141 | struct drm_device *dev = crtc->dev; |
| @@ -1015,6 +1153,7 @@ static void igdng_crtc_dpms(struct drm_crtc *crtc, int mode) | |||
| 1015 | int fdi_rx_imr_reg = (pipe == 0) ? FDI_RXA_IMR : FDI_RXB_IMR; | 1153 | int fdi_rx_imr_reg = (pipe == 0) ? FDI_RXA_IMR : FDI_RXB_IMR; |
| 1016 | int transconf_reg = (pipe == 0) ? TRANSACONF : TRANSBCONF; | 1154 | int transconf_reg = (pipe == 0) ? TRANSACONF : TRANSBCONF; |
| 1017 | int pf_ctl_reg = (pipe == 0) ? PFA_CTL_1 : PFB_CTL_1; | 1155 | int pf_ctl_reg = (pipe == 0) ? PFA_CTL_1 : PFB_CTL_1; |
| 1156 | int pf_win_size = (pipe == 0) ? PFA_WIN_SZ : PFB_WIN_SZ; | ||
| 1018 | int cpu_htot_reg = (pipe == 0) ? HTOTAL_A : HTOTAL_B; | 1157 | int cpu_htot_reg = (pipe == 0) ? HTOTAL_A : HTOTAL_B; |
| 1019 | int cpu_hblank_reg = (pipe == 0) ? HBLANK_A : HBLANK_B; | 1158 | int cpu_hblank_reg = (pipe == 0) ? HBLANK_A : HBLANK_B; |
| 1020 | int cpu_hsync_reg = (pipe == 0) ? HSYNC_A : HSYNC_B; | 1159 | int cpu_hsync_reg = (pipe == 0) ? HSYNC_A : HSYNC_B; |
| @@ -1028,7 +1167,7 @@ static void igdng_crtc_dpms(struct drm_crtc *crtc, int mode) | |||
| 1028 | int trans_vblank_reg = (pipe == 0) ? TRANS_VBLANK_A : TRANS_VBLANK_B; | 1167 | int trans_vblank_reg = (pipe == 0) ? TRANS_VBLANK_A : TRANS_VBLANK_B; |
| 1029 | int trans_vsync_reg = (pipe == 0) ? TRANS_VSYNC_A : TRANS_VSYNC_B; | 1168 | int trans_vsync_reg = (pipe == 0) ? TRANS_VSYNC_A : TRANS_VSYNC_B; |
| 1030 | u32 temp; | 1169 | u32 temp; |
| 1031 | int tries = 5, j; | 1170 | int tries = 5, j, n; |
| 1032 | 1171 | ||
| 1033 | /* XXX: When our outputs are all unaware of DPMS modes other than off | 1172 | /* XXX: When our outputs are all unaware of DPMS modes other than off |
| 1034 | * and on, we should map those modes to DRM_MODE_DPMS_OFF in the CRTC. | 1173 | * and on, we should map those modes to DRM_MODE_DPMS_OFF in the CRTC. |
| @@ -1038,27 +1177,32 @@ static void igdng_crtc_dpms(struct drm_crtc *crtc, int mode) | |||
| 1038 | case DRM_MODE_DPMS_STANDBY: | 1177 | case DRM_MODE_DPMS_STANDBY: |
| 1039 | case DRM_MODE_DPMS_SUSPEND: | 1178 | case DRM_MODE_DPMS_SUSPEND: |
| 1040 | DRM_DEBUG("crtc %d dpms on\n", pipe); | 1179 | DRM_DEBUG("crtc %d dpms on\n", pipe); |
| 1041 | /* enable PCH DPLL */ | 1180 | if (HAS_eDP) { |
| 1042 | temp = I915_READ(pch_dpll_reg); | 1181 | /* enable eDP PLL */ |
| 1043 | if ((temp & DPLL_VCO_ENABLE) == 0) { | 1182 | igdng_enable_pll_edp(crtc); |
| 1044 | I915_WRITE(pch_dpll_reg, temp | DPLL_VCO_ENABLE); | 1183 | } else { |
| 1045 | I915_READ(pch_dpll_reg); | 1184 | /* enable PCH DPLL */ |
| 1046 | } | 1185 | temp = I915_READ(pch_dpll_reg); |
| 1047 | 1186 | if ((temp & DPLL_VCO_ENABLE) == 0) { | |
| 1048 | /* enable PCH FDI RX PLL, wait warmup plus DMI latency */ | 1187 | I915_WRITE(pch_dpll_reg, temp | DPLL_VCO_ENABLE); |
| 1049 | temp = I915_READ(fdi_rx_reg); | 1188 | I915_READ(pch_dpll_reg); |
| 1050 | I915_WRITE(fdi_rx_reg, temp | FDI_RX_PLL_ENABLE | | 1189 | } |
| 1051 | FDI_SEL_PCDCLK | | ||
| 1052 | FDI_DP_PORT_WIDTH_X4); /* default 4 lanes */ | ||
| 1053 | I915_READ(fdi_rx_reg); | ||
| 1054 | udelay(200); | ||
| 1055 | 1190 | ||
| 1056 | /* Enable CPU FDI TX PLL, always on for IGDNG */ | 1191 | /* enable PCH FDI RX PLL, wait warmup plus DMI latency */ |
| 1057 | temp = I915_READ(fdi_tx_reg); | 1192 | temp = I915_READ(fdi_rx_reg); |
| 1058 | if ((temp & FDI_TX_PLL_ENABLE) == 0) { | 1193 | I915_WRITE(fdi_rx_reg, temp | FDI_RX_PLL_ENABLE | |
| 1059 | I915_WRITE(fdi_tx_reg, temp | FDI_TX_PLL_ENABLE); | 1194 | FDI_SEL_PCDCLK | |
| 1060 | I915_READ(fdi_tx_reg); | 1195 | FDI_DP_PORT_WIDTH_X4); /* default 4 lanes */ |
| 1061 | udelay(100); | 1196 | I915_READ(fdi_rx_reg); |
| 1197 | udelay(200); | ||
| 1198 | |||
| 1199 | /* Enable CPU FDI TX PLL, always on for IGDNG */ | ||
| 1200 | temp = I915_READ(fdi_tx_reg); | ||
| 1201 | if ((temp & FDI_TX_PLL_ENABLE) == 0) { | ||
| 1202 | I915_WRITE(fdi_tx_reg, temp | FDI_TX_PLL_ENABLE); | ||
| 1203 | I915_READ(fdi_tx_reg); | ||
| 1204 | udelay(100); | ||
| 1205 | } | ||
| 1062 | } | 1206 | } |
| 1063 | 1207 | ||
| 1064 | /* Enable CPU pipe */ | 1208 | /* Enable CPU pipe */ |
| @@ -1077,122 +1221,126 @@ static void igdng_crtc_dpms(struct drm_crtc *crtc, int mode) | |||
| 1077 | I915_WRITE(dspbase_reg, I915_READ(dspbase_reg)); | 1221 | I915_WRITE(dspbase_reg, I915_READ(dspbase_reg)); |
| 1078 | } | 1222 | } |
| 1079 | 1223 | ||
| 1080 | /* enable CPU FDI TX and PCH FDI RX */ | 1224 | if (!HAS_eDP) { |
| 1081 | temp = I915_READ(fdi_tx_reg); | 1225 | /* enable CPU FDI TX and PCH FDI RX */ |
| 1082 | temp |= FDI_TX_ENABLE; | 1226 | temp = I915_READ(fdi_tx_reg); |
| 1083 | temp |= FDI_DP_PORT_WIDTH_X4; /* default */ | 1227 | temp |= FDI_TX_ENABLE; |
| 1084 | temp &= ~FDI_LINK_TRAIN_NONE; | 1228 | temp |= FDI_DP_PORT_WIDTH_X4; /* default */ |
| 1085 | temp |= FDI_LINK_TRAIN_PATTERN_1; | 1229 | temp &= ~FDI_LINK_TRAIN_NONE; |
| 1086 | I915_WRITE(fdi_tx_reg, temp); | 1230 | temp |= FDI_LINK_TRAIN_PATTERN_1; |
| 1087 | I915_READ(fdi_tx_reg); | 1231 | I915_WRITE(fdi_tx_reg, temp); |
| 1232 | I915_READ(fdi_tx_reg); | ||
| 1088 | 1233 | ||
| 1089 | temp = I915_READ(fdi_rx_reg); | 1234 | temp = I915_READ(fdi_rx_reg); |
| 1090 | temp &= ~FDI_LINK_TRAIN_NONE; | 1235 | temp &= ~FDI_LINK_TRAIN_NONE; |
| 1091 | temp |= FDI_LINK_TRAIN_PATTERN_1; | 1236 | temp |= FDI_LINK_TRAIN_PATTERN_1; |
| 1092 | I915_WRITE(fdi_rx_reg, temp | FDI_RX_ENABLE); | 1237 | I915_WRITE(fdi_rx_reg, temp | FDI_RX_ENABLE); |
| 1093 | I915_READ(fdi_rx_reg); | 1238 | I915_READ(fdi_rx_reg); |
| 1094 | 1239 | ||
| 1095 | udelay(150); | 1240 | udelay(150); |
| 1096 | 1241 | ||
| 1097 | /* Train FDI. */ | 1242 | /* Train FDI. */ |
| 1098 | /* umask FDI RX Interrupt symbol_lock and bit_lock bit | 1243 | /* umask FDI RX Interrupt symbol_lock and bit_lock bit |
| 1099 | for train result */ | 1244 | for train result */ |
| 1100 | temp = I915_READ(fdi_rx_imr_reg); | 1245 | temp = I915_READ(fdi_rx_imr_reg); |
| 1101 | temp &= ~FDI_RX_SYMBOL_LOCK; | 1246 | temp &= ~FDI_RX_SYMBOL_LOCK; |
| 1102 | temp &= ~FDI_RX_BIT_LOCK; | 1247 | temp &= ~FDI_RX_BIT_LOCK; |
| 1103 | I915_WRITE(fdi_rx_imr_reg, temp); | 1248 | I915_WRITE(fdi_rx_imr_reg, temp); |
| 1104 | I915_READ(fdi_rx_imr_reg); | 1249 | I915_READ(fdi_rx_imr_reg); |
| 1105 | udelay(150); | 1250 | udelay(150); |
| 1106 | 1251 | ||
| 1107 | temp = I915_READ(fdi_rx_iir_reg); | 1252 | temp = I915_READ(fdi_rx_iir_reg); |
| 1108 | DRM_DEBUG("FDI_RX_IIR 0x%x\n", temp); | 1253 | DRM_DEBUG("FDI_RX_IIR 0x%x\n", temp); |
| 1109 | 1254 | ||
| 1110 | if ((temp & FDI_RX_BIT_LOCK) == 0) { | 1255 | if ((temp & FDI_RX_BIT_LOCK) == 0) { |
| 1111 | for (j = 0; j < tries; j++) { | 1256 | for (j = 0; j < tries; j++) { |
| 1112 | temp = I915_READ(fdi_rx_iir_reg); | 1257 | temp = I915_READ(fdi_rx_iir_reg); |
| 1113 | DRM_DEBUG("FDI_RX_IIR 0x%x\n", temp); | 1258 | DRM_DEBUG("FDI_RX_IIR 0x%x\n", temp); |
| 1114 | if (temp & FDI_RX_BIT_LOCK) | 1259 | if (temp & FDI_RX_BIT_LOCK) |
| 1115 | break; | 1260 | break; |
| 1116 | udelay(200); | 1261 | udelay(200); |
| 1117 | } | 1262 | } |
| 1118 | if (j != tries) | 1263 | if (j != tries) |
| 1264 | I915_WRITE(fdi_rx_iir_reg, | ||
| 1265 | temp | FDI_RX_BIT_LOCK); | ||
| 1266 | else | ||
| 1267 | DRM_DEBUG("train 1 fail\n"); | ||
| 1268 | } else { | ||
| 1119 | I915_WRITE(fdi_rx_iir_reg, | 1269 | I915_WRITE(fdi_rx_iir_reg, |
| 1120 | temp | FDI_RX_BIT_LOCK); | 1270 | temp | FDI_RX_BIT_LOCK); |
| 1121 | else | 1271 | DRM_DEBUG("train 1 ok 2!\n"); |
| 1122 | DRM_DEBUG("train 1 fail\n"); | 1272 | } |
| 1123 | } else { | 1273 | temp = I915_READ(fdi_tx_reg); |
| 1124 | I915_WRITE(fdi_rx_iir_reg, | 1274 | temp &= ~FDI_LINK_TRAIN_NONE; |
| 1125 | temp | FDI_RX_BIT_LOCK); | 1275 | temp |= FDI_LINK_TRAIN_PATTERN_2; |
| 1126 | DRM_DEBUG("train 1 ok 2!\n"); | 1276 | I915_WRITE(fdi_tx_reg, temp); |
| 1127 | } | 1277 | |
| 1128 | temp = I915_READ(fdi_tx_reg); | 1278 | temp = I915_READ(fdi_rx_reg); |
| 1129 | temp &= ~FDI_LINK_TRAIN_NONE; | 1279 | temp &= ~FDI_LINK_TRAIN_NONE; |
| 1130 | temp |= FDI_LINK_TRAIN_PATTERN_2; | 1280 | temp |= FDI_LINK_TRAIN_PATTERN_2; |
| 1131 | I915_WRITE(fdi_tx_reg, temp); | 1281 | I915_WRITE(fdi_rx_reg, temp); |
| 1132 | |||
| 1133 | temp = I915_READ(fdi_rx_reg); | ||
| 1134 | temp &= ~FDI_LINK_TRAIN_NONE; | ||
| 1135 | temp |= FDI_LINK_TRAIN_PATTERN_2; | ||
| 1136 | I915_WRITE(fdi_rx_reg, temp); | ||
| 1137 | 1282 | ||
| 1138 | udelay(150); | 1283 | udelay(150); |
| 1139 | 1284 | ||
| 1140 | temp = I915_READ(fdi_rx_iir_reg); | 1285 | temp = I915_READ(fdi_rx_iir_reg); |
| 1141 | DRM_DEBUG("FDI_RX_IIR 0x%x\n", temp); | 1286 | DRM_DEBUG("FDI_RX_IIR 0x%x\n", temp); |
| 1142 | 1287 | ||
| 1143 | if ((temp & FDI_RX_SYMBOL_LOCK) == 0) { | 1288 | if ((temp & FDI_RX_SYMBOL_LOCK) == 0) { |
| 1144 | for (j = 0; j < tries; j++) { | 1289 | for (j = 0; j < tries; j++) { |
| 1145 | temp = I915_READ(fdi_rx_iir_reg); | 1290 | temp = I915_READ(fdi_rx_iir_reg); |
| 1146 | DRM_DEBUG("FDI_RX_IIR 0x%x\n", temp); | 1291 | DRM_DEBUG("FDI_RX_IIR 0x%x\n", temp); |
| 1147 | if (temp & FDI_RX_SYMBOL_LOCK) | 1292 | if (temp & FDI_RX_SYMBOL_LOCK) |
| 1148 | break; | 1293 | break; |
| 1149 | udelay(200); | 1294 | udelay(200); |
| 1150 | } | 1295 | } |
| 1151 | if (j != tries) { | 1296 | if (j != tries) { |
| 1297 | I915_WRITE(fdi_rx_iir_reg, | ||
| 1298 | temp | FDI_RX_SYMBOL_LOCK); | ||
| 1299 | DRM_DEBUG("train 2 ok 1!\n"); | ||
| 1300 | } else | ||
| 1301 | DRM_DEBUG("train 2 fail\n"); | ||
| 1302 | } else { | ||
| 1152 | I915_WRITE(fdi_rx_iir_reg, | 1303 | I915_WRITE(fdi_rx_iir_reg, |
| 1153 | temp | FDI_RX_SYMBOL_LOCK); | 1304 | temp | FDI_RX_SYMBOL_LOCK); |
| 1154 | DRM_DEBUG("train 2 ok 1!\n"); | 1305 | DRM_DEBUG("train 2 ok 2!\n"); |
| 1155 | } else | 1306 | } |
| 1156 | DRM_DEBUG("train 2 fail\n"); | 1307 | DRM_DEBUG("train done\n"); |
| 1157 | } else { | ||
| 1158 | I915_WRITE(fdi_rx_iir_reg, temp | FDI_RX_SYMBOL_LOCK); | ||
| 1159 | DRM_DEBUG("train 2 ok 2!\n"); | ||
| 1160 | } | ||
| 1161 | DRM_DEBUG("train done\n"); | ||
| 1162 | 1308 | ||
| 1163 | /* set transcoder timing */ | 1309 | /* set transcoder timing */ |
| 1164 | I915_WRITE(trans_htot_reg, I915_READ(cpu_htot_reg)); | 1310 | I915_WRITE(trans_htot_reg, I915_READ(cpu_htot_reg)); |
| 1165 | I915_WRITE(trans_hblank_reg, I915_READ(cpu_hblank_reg)); | 1311 | I915_WRITE(trans_hblank_reg, I915_READ(cpu_hblank_reg)); |
| 1166 | I915_WRITE(trans_hsync_reg, I915_READ(cpu_hsync_reg)); | 1312 | I915_WRITE(trans_hsync_reg, I915_READ(cpu_hsync_reg)); |
| 1167 | 1313 | ||
| 1168 | I915_WRITE(trans_vtot_reg, I915_READ(cpu_vtot_reg)); | 1314 | I915_WRITE(trans_vtot_reg, I915_READ(cpu_vtot_reg)); |
| 1169 | I915_WRITE(trans_vblank_reg, I915_READ(cpu_vblank_reg)); | 1315 | I915_WRITE(trans_vblank_reg, I915_READ(cpu_vblank_reg)); |
| 1170 | I915_WRITE(trans_vsync_reg, I915_READ(cpu_vsync_reg)); | 1316 | I915_WRITE(trans_vsync_reg, I915_READ(cpu_vsync_reg)); |
| 1171 | 1317 | ||
| 1172 | /* enable PCH transcoder */ | 1318 | /* enable PCH transcoder */ |
| 1173 | temp = I915_READ(transconf_reg); | 1319 | temp = I915_READ(transconf_reg); |
| 1174 | I915_WRITE(transconf_reg, temp | TRANS_ENABLE); | 1320 | I915_WRITE(transconf_reg, temp | TRANS_ENABLE); |
| 1175 | I915_READ(transconf_reg); | 1321 | I915_READ(transconf_reg); |
| 1176 | 1322 | ||
| 1177 | while ((I915_READ(transconf_reg) & TRANS_STATE_ENABLE) == 0) | 1323 | while ((I915_READ(transconf_reg) & TRANS_STATE_ENABLE) == 0) |
| 1178 | ; | 1324 | ; |
| 1179 | 1325 | ||
| 1180 | /* enable normal */ | 1326 | /* enable normal */ |
| 1181 | 1327 | ||
| 1182 | temp = I915_READ(fdi_tx_reg); | 1328 | temp = I915_READ(fdi_tx_reg); |
| 1183 | temp &= ~FDI_LINK_TRAIN_NONE; | 1329 | temp &= ~FDI_LINK_TRAIN_NONE; |
| 1184 | I915_WRITE(fdi_tx_reg, temp | FDI_LINK_TRAIN_NONE | | 1330 | I915_WRITE(fdi_tx_reg, temp | FDI_LINK_TRAIN_NONE | |
| 1185 | FDI_TX_ENHANCE_FRAME_ENABLE); | 1331 | FDI_TX_ENHANCE_FRAME_ENABLE); |
| 1186 | I915_READ(fdi_tx_reg); | 1332 | I915_READ(fdi_tx_reg); |
| 1187 | 1333 | ||
| 1188 | temp = I915_READ(fdi_rx_reg); | 1334 | temp = I915_READ(fdi_rx_reg); |
| 1189 | temp &= ~FDI_LINK_TRAIN_NONE; | 1335 | temp &= ~FDI_LINK_TRAIN_NONE; |
| 1190 | I915_WRITE(fdi_rx_reg, temp | FDI_LINK_TRAIN_NONE | | 1336 | I915_WRITE(fdi_rx_reg, temp | FDI_LINK_TRAIN_NONE | |
| 1191 | FDI_RX_ENHANCE_FRAME_ENABLE); | 1337 | FDI_RX_ENHANCE_FRAME_ENABLE); |
| 1192 | I915_READ(fdi_rx_reg); | 1338 | I915_READ(fdi_rx_reg); |
| 1193 | 1339 | ||
| 1194 | /* wait one idle pattern time */ | 1340 | /* wait one idle pattern time */ |
| 1195 | udelay(100); | 1341 | udelay(100); |
| 1342 | |||
| 1343 | } | ||
| 1196 | 1344 | ||
| 1197 | intel_crtc_load_lut(crtc); | 1345 | intel_crtc_load_lut(crtc); |
| 1198 | 1346 | ||
| @@ -1200,8 +1348,7 @@ static void igdng_crtc_dpms(struct drm_crtc *crtc, int mode) | |||
| 1200 | case DRM_MODE_DPMS_OFF: | 1348 | case DRM_MODE_DPMS_OFF: |
| 1201 | DRM_DEBUG("crtc %d dpms off\n", pipe); | 1349 | DRM_DEBUG("crtc %d dpms off\n", pipe); |
| 1202 | 1350 | ||
| 1203 | /* Disable the VGA plane that we never use */ | 1351 | i915_disable_vga(dev); |
| 1204 | I915_WRITE(CPU_VGACNTRL, VGA_DISP_DISABLE); | ||
| 1205 | 1352 | ||
| 1206 | /* Disable display plane */ | 1353 | /* Disable display plane */ |
| 1207 | temp = I915_READ(dspcntr_reg); | 1354 | temp = I915_READ(dspcntr_reg); |
| @@ -1217,17 +1364,23 @@ static void igdng_crtc_dpms(struct drm_crtc *crtc, int mode) | |||
| 1217 | if ((temp & PIPEACONF_ENABLE) != 0) { | 1364 | if ((temp & PIPEACONF_ENABLE) != 0) { |
| 1218 | I915_WRITE(pipeconf_reg, temp & ~PIPEACONF_ENABLE); | 1365 | I915_WRITE(pipeconf_reg, temp & ~PIPEACONF_ENABLE); |
| 1219 | I915_READ(pipeconf_reg); | 1366 | I915_READ(pipeconf_reg); |
| 1367 | n = 0; | ||
| 1220 | /* wait for cpu pipe off, pipe state */ | 1368 | /* wait for cpu pipe off, pipe state */ |
| 1221 | while ((I915_READ(pipeconf_reg) & I965_PIPECONF_ACTIVE) != 0) | 1369 | while ((I915_READ(pipeconf_reg) & I965_PIPECONF_ACTIVE) != 0) { |
| 1222 | ; | 1370 | n++; |
| 1371 | if (n < 60) { | ||
| 1372 | udelay(500); | ||
| 1373 | continue; | ||
| 1374 | } else { | ||
| 1375 | DRM_DEBUG("pipe %d off delay\n", pipe); | ||
| 1376 | break; | ||
| 1377 | } | ||
| 1378 | } | ||
| 1223 | } else | 1379 | } else |
| 1224 | DRM_DEBUG("crtc %d is disabled\n", pipe); | 1380 | DRM_DEBUG("crtc %d is disabled\n", pipe); |
| 1225 | 1381 | ||
| 1226 | /* IGDNG-A : disable cpu panel fitter ? */ | 1382 | if (HAS_eDP) { |
| 1227 | temp = I915_READ(pf_ctl_reg); | 1383 | igdng_disable_pll_edp(crtc); |
| 1228 | if ((temp & PF_ENABLE) != 0) { | ||
| 1229 | I915_WRITE(pf_ctl_reg, temp & ~PF_ENABLE); | ||
| 1230 | I915_READ(pf_ctl_reg); | ||
| 1231 | } | 1384 | } |
| 1232 | 1385 | ||
| 1233 | /* disable CPU FDI tx and PCH FDI rx */ | 1386 | /* disable CPU FDI tx and PCH FDI rx */ |
| @@ -1239,6 +1392,8 @@ static void igdng_crtc_dpms(struct drm_crtc *crtc, int mode) | |||
| 1239 | I915_WRITE(fdi_rx_reg, temp & ~FDI_RX_ENABLE); | 1392 | I915_WRITE(fdi_rx_reg, temp & ~FDI_RX_ENABLE); |
| 1240 | I915_READ(fdi_rx_reg); | 1393 | I915_READ(fdi_rx_reg); |
| 1241 | 1394 | ||
| 1395 | udelay(100); | ||
| 1396 | |||
| 1242 | /* still set train pattern 1 */ | 1397 | /* still set train pattern 1 */ |
| 1243 | temp = I915_READ(fdi_tx_reg); | 1398 | temp = I915_READ(fdi_tx_reg); |
| 1244 | temp &= ~FDI_LINK_TRAIN_NONE; | 1399 | temp &= ~FDI_LINK_TRAIN_NONE; |
| @@ -1250,14 +1405,25 @@ static void igdng_crtc_dpms(struct drm_crtc *crtc, int mode) | |||
| 1250 | temp |= FDI_LINK_TRAIN_PATTERN_1; | 1405 | temp |= FDI_LINK_TRAIN_PATTERN_1; |
| 1251 | I915_WRITE(fdi_rx_reg, temp); | 1406 | I915_WRITE(fdi_rx_reg, temp); |
| 1252 | 1407 | ||
| 1408 | udelay(100); | ||
| 1409 | |||
| 1253 | /* disable PCH transcoder */ | 1410 | /* disable PCH transcoder */ |
| 1254 | temp = I915_READ(transconf_reg); | 1411 | temp = I915_READ(transconf_reg); |
| 1255 | if ((temp & TRANS_ENABLE) != 0) { | 1412 | if ((temp & TRANS_ENABLE) != 0) { |
| 1256 | I915_WRITE(transconf_reg, temp & ~TRANS_ENABLE); | 1413 | I915_WRITE(transconf_reg, temp & ~TRANS_ENABLE); |
| 1257 | I915_READ(transconf_reg); | 1414 | I915_READ(transconf_reg); |
| 1415 | n = 0; | ||
| 1258 | /* wait for PCH transcoder off, transcoder state */ | 1416 | /* wait for PCH transcoder off, transcoder state */ |
| 1259 | while ((I915_READ(transconf_reg) & TRANS_STATE_ENABLE) != 0) | 1417 | while ((I915_READ(transconf_reg) & TRANS_STATE_ENABLE) != 0) { |
| 1260 | ; | 1418 | n++; |
| 1419 | if (n < 60) { | ||
| 1420 | udelay(500); | ||
| 1421 | continue; | ||
| 1422 | } else { | ||
| 1423 | DRM_DEBUG("transcoder %d off delay\n", pipe); | ||
| 1424 | break; | ||
| 1425 | } | ||
| 1426 | } | ||
| 1261 | } | 1427 | } |
| 1262 | 1428 | ||
| 1263 | /* disable PCH DPLL */ | 1429 | /* disable PCH DPLL */ |
| @@ -1275,6 +1441,22 @@ static void igdng_crtc_dpms(struct drm_crtc *crtc, int mode) | |||
| 1275 | I915_READ(fdi_rx_reg); | 1441 | I915_READ(fdi_rx_reg); |
| 1276 | } | 1442 | } |
| 1277 | 1443 | ||
| 1444 | /* Disable CPU FDI TX PLL */ | ||
| 1445 | temp = I915_READ(fdi_tx_reg); | ||
| 1446 | if ((temp & FDI_TX_PLL_ENABLE) != 0) { | ||
| 1447 | I915_WRITE(fdi_tx_reg, temp & ~FDI_TX_PLL_ENABLE); | ||
| 1448 | I915_READ(fdi_tx_reg); | ||
| 1449 | udelay(100); | ||
| 1450 | } | ||
| 1451 | |||
| 1452 | /* Disable PF */ | ||
| 1453 | temp = I915_READ(pf_ctl_reg); | ||
| 1454 | if ((temp & PF_ENABLE) != 0) { | ||
| 1455 | I915_WRITE(pf_ctl_reg, temp & ~PF_ENABLE); | ||
| 1456 | I915_READ(pf_ctl_reg); | ||
| 1457 | } | ||
| 1458 | I915_WRITE(pf_win_size, 0); | ||
| 1459 | |||
| 1278 | /* Wait for the clocks to turn off. */ | 1460 | /* Wait for the clocks to turn off. */ |
| 1279 | udelay(150); | 1461 | udelay(150); |
| 1280 | break; | 1462 | break; |
| @@ -1342,7 +1524,7 @@ static void i9xx_crtc_dpms(struct drm_crtc *crtc, int mode) | |||
| 1342 | //intel_crtc_dpms_video(crtc, FALSE); TODO | 1524 | //intel_crtc_dpms_video(crtc, FALSE); TODO |
| 1343 | 1525 | ||
| 1344 | /* Disable the VGA plane that we never use */ | 1526 | /* Disable the VGA plane that we never use */ |
| 1345 | I915_WRITE(VGACNTRL, VGA_DISP_DISABLE); | 1527 | i915_disable_vga(dev); |
| 1346 | 1528 | ||
| 1347 | /* Disable display plane */ | 1529 | /* Disable display plane */ |
| 1348 | temp = I915_READ(dspcntr_reg); | 1530 | temp = I915_READ(dspcntr_reg); |
| @@ -1623,48 +1805,72 @@ static struct intel_watermark_params igd_cursor_hplloff_wm = { | |||
| 1623 | IGD_FIFO_LINE_SIZE | 1805 | IGD_FIFO_LINE_SIZE |
| 1624 | }; | 1806 | }; |
| 1625 | static struct intel_watermark_params i945_wm_info = { | 1807 | static struct intel_watermark_params i945_wm_info = { |
| 1626 | I915_FIFO_LINE_SIZE, | 1808 | I945_FIFO_SIZE, |
| 1627 | I915_MAX_WM, | 1809 | I915_MAX_WM, |
| 1628 | 1, | 1810 | 1, |
| 1629 | 0, | 1811 | 2, |
| 1630 | IGD_FIFO_LINE_SIZE | 1812 | I915_FIFO_LINE_SIZE |
| 1631 | }; | 1813 | }; |
| 1632 | static struct intel_watermark_params i915_wm_info = { | 1814 | static struct intel_watermark_params i915_wm_info = { |
| 1633 | I945_FIFO_SIZE, | 1815 | I915_FIFO_SIZE, |
| 1634 | I915_MAX_WM, | 1816 | I915_MAX_WM, |
| 1635 | 1, | 1817 | 1, |
| 1636 | 0, | 1818 | 2, |
| 1637 | I915_FIFO_LINE_SIZE | 1819 | I915_FIFO_LINE_SIZE |
| 1638 | }; | 1820 | }; |
| 1639 | static struct intel_watermark_params i855_wm_info = { | 1821 | static struct intel_watermark_params i855_wm_info = { |
| 1640 | I855GM_FIFO_SIZE, | 1822 | I855GM_FIFO_SIZE, |
| 1641 | I915_MAX_WM, | 1823 | I915_MAX_WM, |
| 1642 | 1, | 1824 | 1, |
| 1643 | 0, | 1825 | 2, |
| 1644 | I830_FIFO_LINE_SIZE | 1826 | I830_FIFO_LINE_SIZE |
| 1645 | }; | 1827 | }; |
| 1646 | static struct intel_watermark_params i830_wm_info = { | 1828 | static struct intel_watermark_params i830_wm_info = { |
| 1647 | I830_FIFO_SIZE, | 1829 | I830_FIFO_SIZE, |
| 1648 | I915_MAX_WM, | 1830 | I915_MAX_WM, |
| 1649 | 1, | 1831 | 1, |
| 1650 | 0, | 1832 | 2, |
| 1651 | I830_FIFO_LINE_SIZE | 1833 | I830_FIFO_LINE_SIZE |
| 1652 | }; | 1834 | }; |
| 1653 | 1835 | ||
| 1836 | /** | ||
| 1837 | * intel_calculate_wm - calculate watermark level | ||
| 1838 | * @clock_in_khz: pixel clock | ||
| 1839 | * @wm: chip FIFO params | ||
| 1840 | * @pixel_size: display pixel size | ||
| 1841 | * @latency_ns: memory latency for the platform | ||
| 1842 | * | ||
| 1843 | * Calculate the watermark level (the level at which the display plane will | ||
| 1844 | * start fetching from memory again). Each chip has a different display | ||
| 1845 | * FIFO size and allocation, so the caller needs to figure that out and pass | ||
| 1846 | * in the correct intel_watermark_params structure. | ||
| 1847 | * | ||
| 1848 | * As the pixel clock runs, the FIFO will be drained at a rate that depends | ||
| 1849 | * on the pixel size. When it reaches the watermark level, it'll start | ||
| 1850 | * fetching FIFO line sized based chunks from memory until the FIFO fills | ||
| 1851 | * past the watermark point. If the FIFO drains completely, a FIFO underrun | ||
| 1852 | * will occur, and a display engine hang could result. | ||
| 1853 | */ | ||
| 1654 | static unsigned long intel_calculate_wm(unsigned long clock_in_khz, | 1854 | static unsigned long intel_calculate_wm(unsigned long clock_in_khz, |
| 1655 | struct intel_watermark_params *wm, | 1855 | struct intel_watermark_params *wm, |
| 1656 | int pixel_size, | 1856 | int pixel_size, |
| 1657 | unsigned long latency_ns) | 1857 | unsigned long latency_ns) |
| 1658 | { | 1858 | { |
| 1659 | unsigned long bytes_required, wm_size; | 1859 | long entries_required, wm_size; |
| 1860 | |||
| 1861 | entries_required = (clock_in_khz * pixel_size * latency_ns) / 1000000; | ||
| 1862 | entries_required /= wm->cacheline_size; | ||
| 1660 | 1863 | ||
| 1661 | bytes_required = (clock_in_khz * pixel_size * latency_ns) / 1000000; | 1864 | DRM_DEBUG("FIFO entries required for mode: %d\n", entries_required); |
| 1662 | bytes_required /= wm->cacheline_size; | ||
| 1663 | wm_size = wm->fifo_size - bytes_required - wm->guard_size; | ||
| 1664 | 1865 | ||
| 1665 | if (wm_size > wm->max_wm) | 1866 | wm_size = wm->fifo_size - (entries_required + wm->guard_size); |
| 1867 | |||
| 1868 | DRM_DEBUG("FIFO watermark level: %d\n", wm_size); | ||
| 1869 | |||
| 1870 | /* Don't promote wm_size to unsigned... */ | ||
| 1871 | if (wm_size > (long)wm->max_wm) | ||
| 1666 | wm_size = wm->max_wm; | 1872 | wm_size = wm->max_wm; |
| 1667 | if (wm_size == 0) | 1873 | if (wm_size <= 0) |
| 1668 | wm_size = wm->default_wm; | 1874 | wm_size = wm->default_wm; |
| 1669 | return wm_size; | 1875 | return wm_size; |
| 1670 | } | 1876 | } |
| @@ -1799,8 +2005,40 @@ static void igd_enable_cxsr(struct drm_device *dev, unsigned long clock, | |||
| 1799 | return; | 2005 | return; |
| 1800 | } | 2006 | } |
| 1801 | 2007 | ||
| 1802 | const static int latency_ns = 5000; /* default for non-igd platforms */ | 2008 | const static int latency_ns = 3000; /* default for non-igd platforms */ |
| 1803 | 2009 | ||
| 2010 | static int intel_get_fifo_size(struct drm_device *dev, int plane) | ||
| 2011 | { | ||
| 2012 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
| 2013 | uint32_t dsparb = I915_READ(DSPARB); | ||
| 2014 | int size; | ||
| 2015 | |||
| 2016 | if (IS_I9XX(dev)) { | ||
| 2017 | if (plane == 0) | ||
| 2018 | size = dsparb & 0x7f; | ||
| 2019 | else | ||
| 2020 | size = ((dsparb >> DSPARB_CSTART_SHIFT) & 0x7f) - | ||
| 2021 | (dsparb & 0x7f); | ||
| 2022 | } else if (IS_I85X(dev)) { | ||
| 2023 | if (plane == 0) | ||
| 2024 | size = dsparb & 0x1ff; | ||
| 2025 | else | ||
| 2026 | size = ((dsparb >> DSPARB_BEND_SHIFT) & 0x1ff) - | ||
| 2027 | (dsparb & 0x1ff); | ||
| 2028 | size >>= 1; /* Convert to cachelines */ | ||
| 2029 | } else if (IS_845G(dev)) { | ||
| 2030 | size = dsparb & 0x7f; | ||
| 2031 | size >>= 2; /* Convert to cachelines */ | ||
| 2032 | } else { | ||
| 2033 | size = dsparb & 0x7f; | ||
| 2034 | size >>= 1; /* Convert to cachelines */ | ||
| 2035 | } | ||
| 2036 | |||
| 2037 | DRM_DEBUG("FIFO size - (0x%08x) %s: %d\n", dsparb, plane ? "B" : "A", | ||
| 2038 | size); | ||
| 2039 | |||
| 2040 | return size; | ||
| 2041 | } | ||
| 1804 | 2042 | ||
| 1805 | static void i965_update_wm(struct drm_device *dev) | 2043 | static void i965_update_wm(struct drm_device *dev) |
| 1806 | { | 2044 | { |
| @@ -1817,101 +2055,89 @@ static void i9xx_update_wm(struct drm_device *dev, int planea_clock, | |||
| 1817 | int planeb_clock, int sr_hdisplay, int pixel_size) | 2055 | int planeb_clock, int sr_hdisplay, int pixel_size) |
| 1818 | { | 2056 | { |
| 1819 | struct drm_i915_private *dev_priv = dev->dev_private; | 2057 | struct drm_i915_private *dev_priv = dev->dev_private; |
| 1820 | uint32_t fwater_lo = I915_READ(FW_BLC) & MM_FIFO_WATERMARK; | 2058 | uint32_t fwater_lo; |
| 1821 | uint32_t fwater_hi = I915_READ(FW_BLC2) & LM_FIFO_WATERMARK; | 2059 | uint32_t fwater_hi; |
| 1822 | int bsize, asize, cwm, bwm = 1, awm = 1, srwm = 1; | 2060 | int total_size, cacheline_size, cwm, srwm = 1; |
| 1823 | uint32_t dsparb = I915_READ(DSPARB); | 2061 | int planea_wm, planeb_wm; |
| 1824 | int planea_entries, planeb_entries; | 2062 | struct intel_watermark_params planea_params, planeb_params; |
| 1825 | struct intel_watermark_params *wm_params; | ||
| 1826 | unsigned long line_time_us; | 2063 | unsigned long line_time_us; |
| 1827 | int sr_clock, sr_entries = 0; | 2064 | int sr_clock, sr_entries = 0; |
| 1828 | 2065 | ||
| 2066 | /* Create copies of the base settings for each pipe */ | ||
| 1829 | if (IS_I965GM(dev) || IS_I945GM(dev)) | 2067 | if (IS_I965GM(dev) || IS_I945GM(dev)) |
| 1830 | wm_params = &i945_wm_info; | 2068 | planea_params = planeb_params = i945_wm_info; |
| 1831 | else if (IS_I9XX(dev)) | 2069 | else if (IS_I9XX(dev)) |
| 1832 | wm_params = &i915_wm_info; | 2070 | planea_params = planeb_params = i915_wm_info; |
| 1833 | else | 2071 | else |
| 1834 | wm_params = &i855_wm_info; | 2072 | planea_params = planeb_params = i855_wm_info; |
| 1835 | |||
| 1836 | planea_entries = intel_calculate_wm(planea_clock, wm_params, | ||
| 1837 | pixel_size, latency_ns); | ||
| 1838 | planeb_entries = intel_calculate_wm(planeb_clock, wm_params, | ||
| 1839 | pixel_size, latency_ns); | ||
| 1840 | |||
| 1841 | DRM_DEBUG("FIFO entries - A: %d, B: %d\n", planea_entries, | ||
| 1842 | planeb_entries); | ||
| 1843 | 2073 | ||
| 1844 | if (IS_I9XX(dev)) { | 2074 | /* Grab a couple of global values before we overwrite them */ |
| 1845 | asize = dsparb & 0x7f; | 2075 | total_size = planea_params.fifo_size; |
| 1846 | bsize = (dsparb >> DSPARB_CSTART_SHIFT) & 0x7f; | 2076 | cacheline_size = planea_params.cacheline_size; |
| 1847 | } else { | ||
| 1848 | asize = dsparb & 0x1ff; | ||
| 1849 | bsize = (dsparb >> DSPARB_BEND_SHIFT) & 0x1ff; | ||
| 1850 | } | ||
| 1851 | DRM_DEBUG("FIFO size - A: %d, B: %d\n", asize, bsize); | ||
| 1852 | 2077 | ||
| 1853 | /* Two extra entries for padding */ | 2078 | /* Update per-plane FIFO sizes */ |
| 1854 | awm = asize - (planea_entries + 2); | 2079 | planea_params.fifo_size = intel_get_fifo_size(dev, 0); |
| 1855 | bwm = bsize - (planeb_entries + 2); | 2080 | planeb_params.fifo_size = intel_get_fifo_size(dev, 1); |
| 1856 | 2081 | ||
| 1857 | /* Sanity check against potentially bad FIFO allocations */ | 2082 | planea_wm = intel_calculate_wm(planea_clock, &planea_params, |
| 1858 | if (awm <= 0) { | 2083 | pixel_size, latency_ns); |
| 1859 | /* pipe is on but has too few FIFO entries */ | 2084 | planeb_wm = intel_calculate_wm(planeb_clock, &planeb_params, |
| 1860 | if (planea_entries != 0) | 2085 | pixel_size, latency_ns); |
| 1861 | DRM_DEBUG("plane A needs more FIFO entries\n"); | 2086 | DRM_DEBUG("FIFO watermarks - A: %d, B: %d\n", planea_wm, planeb_wm); |
| 1862 | awm = 1; | ||
| 1863 | } | ||
| 1864 | if (bwm <= 0) { | ||
| 1865 | if (planeb_entries != 0) | ||
| 1866 | DRM_DEBUG("plane B needs more FIFO entries\n"); | ||
| 1867 | bwm = 1; | ||
| 1868 | } | ||
| 1869 | 2087 | ||
| 1870 | /* | 2088 | /* |
| 1871 | * Overlay gets an aggressive default since video jitter is bad. | 2089 | * Overlay gets an aggressive default since video jitter is bad. |
| 1872 | */ | 2090 | */ |
| 1873 | cwm = 2; | 2091 | cwm = 2; |
| 1874 | 2092 | ||
| 1875 | /* Calc sr entries for one pipe configs */ | 2093 | /* Calc sr entries for one plane configs */ |
| 1876 | if (!planea_clock || !planeb_clock) { | 2094 | if (sr_hdisplay && (!planea_clock || !planeb_clock)) { |
| 2095 | /* self-refresh has much higher latency */ | ||
| 2096 | const static int sr_latency_ns = 6000; | ||
| 2097 | |||
| 1877 | sr_clock = planea_clock ? planea_clock : planeb_clock; | 2098 | sr_clock = planea_clock ? planea_clock : planeb_clock; |
| 1878 | line_time_us = (sr_hdisplay * 1000) / sr_clock; | 2099 | line_time_us = ((sr_hdisplay * 1000) / sr_clock); |
| 1879 | sr_entries = (((latency_ns / line_time_us) + 1) * pixel_size * | 2100 | |
| 1880 | sr_hdisplay) / 1000; | 2101 | /* Use ns/us then divide to preserve precision */ |
| 1881 | sr_entries = roundup(sr_entries / wm_params->cacheline_size, 1); | 2102 | sr_entries = (((sr_latency_ns / line_time_us) + 1) * |
| 1882 | if (sr_entries < wm_params->fifo_size) | 2103 | pixel_size * sr_hdisplay) / 1000; |
| 1883 | srwm = wm_params->fifo_size - sr_entries; | 2104 | sr_entries = roundup(sr_entries / cacheline_size, 1); |
| 2105 | DRM_DEBUG("self-refresh entries: %d\n", sr_entries); | ||
| 2106 | srwm = total_size - sr_entries; | ||
| 2107 | if (srwm < 0) | ||
| 2108 | srwm = 1; | ||
| 2109 | if (IS_I9XX(dev)) | ||
| 2110 | I915_WRITE(FW_BLC_SELF, (srwm & 0x3f)); | ||
| 1884 | } | 2111 | } |
| 1885 | 2112 | ||
| 1886 | DRM_DEBUG("Setting FIFO watermarks - A: %d, B: %d, C: %d, SR %d\n", | 2113 | DRM_DEBUG("Setting FIFO watermarks - A: %d, B: %d, C: %d, SR %d\n", |
| 1887 | awm, bwm, cwm, srwm); | 2114 | planea_wm, planeb_wm, cwm, srwm); |
| 1888 | 2115 | ||
| 1889 | fwater_lo = fwater_lo | ((bwm & 0x3f) << 16) | (awm & 0x3f); | 2116 | fwater_lo = ((planeb_wm & 0x3f) << 16) | (planea_wm & 0x3f); |
| 1890 | fwater_hi = fwater_hi | (cwm & 0x1f); | 2117 | fwater_hi = (cwm & 0x1f); |
| 2118 | |||
| 2119 | /* Set request length to 8 cachelines per fetch */ | ||
| 2120 | fwater_lo = fwater_lo | (1 << 24) | (1 << 8); | ||
| 2121 | fwater_hi = fwater_hi | (1 << 8); | ||
| 1891 | 2122 | ||
| 1892 | I915_WRITE(FW_BLC, fwater_lo); | 2123 | I915_WRITE(FW_BLC, fwater_lo); |
| 1893 | I915_WRITE(FW_BLC2, fwater_hi); | 2124 | I915_WRITE(FW_BLC2, fwater_hi); |
| 1894 | if (IS_I9XX(dev)) | ||
| 1895 | I915_WRITE(FW_BLC_SELF, FW_BLC_SELF_EN | (srwm & 0x3f)); | ||
| 1896 | } | 2125 | } |
| 1897 | 2126 | ||
| 1898 | static void i830_update_wm(struct drm_device *dev, int planea_clock, | 2127 | static void i830_update_wm(struct drm_device *dev, int planea_clock, |
| 1899 | int pixel_size) | 2128 | int pixel_size) |
| 1900 | { | 2129 | { |
| 1901 | struct drm_i915_private *dev_priv = dev->dev_private; | 2130 | struct drm_i915_private *dev_priv = dev->dev_private; |
| 1902 | uint32_t dsparb = I915_READ(DSPARB); | 2131 | uint32_t fwater_lo = I915_READ(FW_BLC) & ~0xfff; |
| 1903 | uint32_t fwater_lo = I915_READ(FW_BLC) & MM_FIFO_WATERMARK; | 2132 | int planea_wm; |
| 1904 | unsigned int asize, awm; | ||
| 1905 | int planea_entries; | ||
| 1906 | |||
| 1907 | planea_entries = intel_calculate_wm(planea_clock, &i830_wm_info, | ||
| 1908 | pixel_size, latency_ns); | ||
| 1909 | 2133 | ||
| 1910 | asize = dsparb & 0x7f; | 2134 | i830_wm_info.fifo_size = intel_get_fifo_size(dev, 0); |
| 1911 | 2135 | ||
| 1912 | awm = asize - planea_entries; | 2136 | planea_wm = intel_calculate_wm(planea_clock, &i830_wm_info, |
| 2137 | pixel_size, latency_ns); | ||
| 2138 | fwater_lo |= (3<<8) | planea_wm; | ||
| 1913 | 2139 | ||
| 1914 | fwater_lo = fwater_lo | awm; | 2140 | DRM_DEBUG("Setting FIFO watermarks - A: %d\n", planea_wm); |
| 1915 | 2141 | ||
| 1916 | I915_WRITE(FW_BLC, fwater_lo); | 2142 | I915_WRITE(FW_BLC, fwater_lo); |
| 1917 | } | 2143 | } |
| @@ -1984,7 +2210,7 @@ static void intel_update_watermarks(struct drm_device *dev) | |||
| 1984 | if (enabled <= 0) | 2210 | if (enabled <= 0) |
| 1985 | return; | 2211 | return; |
| 1986 | 2212 | ||
| 1987 | /* Single pipe configs can enable self refresh */ | 2213 | /* Single plane configs can enable self refresh */ |
| 1988 | if (enabled == 1 && IS_IGD(dev)) | 2214 | if (enabled == 1 && IS_IGD(dev)) |
| 1989 | igd_enable_cxsr(dev, sr_clock, pixel_size); | 2215 | igd_enable_cxsr(dev, sr_clock, pixel_size); |
| 1990 | else if (IS_IGD(dev)) | 2216 | else if (IS_IGD(dev)) |
| @@ -2028,6 +2254,7 @@ static int intel_crtc_mode_set(struct drm_crtc *crtc, | |||
| 2028 | u32 dpll = 0, fp = 0, dspcntr, pipeconf; | 2254 | u32 dpll = 0, fp = 0, dspcntr, pipeconf; |
| 2029 | bool ok, is_sdvo = false, is_dvo = false; | 2255 | bool ok, is_sdvo = false, is_dvo = false; |
| 2030 | bool is_crt = false, is_lvds = false, is_tv = false, is_dp = false; | 2256 | bool is_crt = false, is_lvds = false, is_tv = false, is_dp = false; |
| 2257 | bool is_edp = false; | ||
| 2031 | struct drm_mode_config *mode_config = &dev->mode_config; | 2258 | struct drm_mode_config *mode_config = &dev->mode_config; |
| 2032 | struct drm_connector *connector; | 2259 | struct drm_connector *connector; |
| 2033 | const intel_limit_t *limit; | 2260 | const intel_limit_t *limit; |
| @@ -2043,6 +2270,7 @@ static int intel_crtc_mode_set(struct drm_crtc *crtc, | |||
| 2043 | int lvds_reg = LVDS; | 2270 | int lvds_reg = LVDS; |
| 2044 | u32 temp; | 2271 | u32 temp; |
| 2045 | int sdvo_pixel_multiply; | 2272 | int sdvo_pixel_multiply; |
| 2273 | int target_clock; | ||
| 2046 | 2274 | ||
| 2047 | drm_vblank_pre_modeset(dev, pipe); | 2275 | drm_vblank_pre_modeset(dev, pipe); |
| 2048 | 2276 | ||
| @@ -2074,6 +2302,9 @@ static int intel_crtc_mode_set(struct drm_crtc *crtc, | |||
| 2074 | case INTEL_OUTPUT_DISPLAYPORT: | 2302 | case INTEL_OUTPUT_DISPLAYPORT: |
| 2075 | is_dp = true; | 2303 | is_dp = true; |
| 2076 | break; | 2304 | break; |
| 2305 | case INTEL_OUTPUT_EDP: | ||
| 2306 | is_edp = true; | ||
| 2307 | break; | ||
| 2077 | } | 2308 | } |
| 2078 | 2309 | ||
| 2079 | num_outputs++; | 2310 | num_outputs++; |
| @@ -2125,11 +2356,29 @@ static int intel_crtc_mode_set(struct drm_crtc *crtc, | |||
| 2125 | } | 2356 | } |
| 2126 | 2357 | ||
| 2127 | /* FDI link */ | 2358 | /* FDI link */ |
| 2128 | if (IS_IGDNG(dev)) | 2359 | if (IS_IGDNG(dev)) { |
| 2129 | igdng_compute_m_n(3, 4, /* lane num 4 */ | 2360 | int lane, link_bw; |
| 2130 | adjusted_mode->clock, | 2361 | /* eDP doesn't require FDI link, so just set DP M/N |
| 2131 | 270000, /* lane clock */ | 2362 | according to current link config */ |
| 2132 | &m_n); | 2363 | if (is_edp) { |
| 2364 | struct drm_connector *edp; | ||
| 2365 | target_clock = mode->clock; | ||
| 2366 | edp = intel_pipe_get_output(crtc); | ||
| 2367 | intel_edp_link_config(to_intel_output(edp), | ||
| 2368 | &lane, &link_bw); | ||
| 2369 | } else { | ||
| 2370 | /* DP over FDI requires target mode clock | ||
| 2371 | instead of link clock */ | ||
| 2372 | if (is_dp) | ||
| 2373 | target_clock = mode->clock; | ||
| 2374 | else | ||
| 2375 | target_clock = adjusted_mode->clock; | ||
| 2376 | lane = 4; | ||
| 2377 | link_bw = 270000; | ||
| 2378 | } | ||
| 2379 | igdng_compute_m_n(3, lane, target_clock, | ||
| 2380 | link_bw, &m_n); | ||
| 2381 | } | ||
| 2133 | 2382 | ||
| 2134 | if (IS_IGD(dev)) | 2383 | if (IS_IGD(dev)) |
| 2135 | fp = (1 << clock.n) << 16 | clock.m1 << 8 | clock.m2; | 2384 | fp = (1 << clock.n) << 16 | clock.m1 << 8 | clock.m2; |
| @@ -2250,29 +2499,15 @@ static int intel_crtc_mode_set(struct drm_crtc *crtc, | |||
| 2250 | dpll_reg = pch_dpll_reg; | 2499 | dpll_reg = pch_dpll_reg; |
| 2251 | } | 2500 | } |
| 2252 | 2501 | ||
| 2253 | if (dpll & DPLL_VCO_ENABLE) { | 2502 | if (is_edp) { |
| 2503 | igdng_disable_pll_edp(crtc); | ||
| 2504 | } else if ((dpll & DPLL_VCO_ENABLE)) { | ||
| 2254 | I915_WRITE(fp_reg, fp); | 2505 | I915_WRITE(fp_reg, fp); |
| 2255 | I915_WRITE(dpll_reg, dpll & ~DPLL_VCO_ENABLE); | 2506 | I915_WRITE(dpll_reg, dpll & ~DPLL_VCO_ENABLE); |
| 2256 | I915_READ(dpll_reg); | 2507 | I915_READ(dpll_reg); |
| 2257 | udelay(150); | 2508 | udelay(150); |
| 2258 | } | 2509 | } |
| 2259 | 2510 | ||
| 2260 | if (IS_IGDNG(dev)) { | ||
| 2261 | /* enable PCH clock reference source */ | ||
| 2262 | /* XXX need to change the setting for other outputs */ | ||
| 2263 | u32 temp; | ||
| 2264 | temp = I915_READ(PCH_DREF_CONTROL); | ||
| 2265 | temp &= ~DREF_NONSPREAD_SOURCE_MASK; | ||
| 2266 | temp |= DREF_NONSPREAD_CK505_ENABLE; | ||
| 2267 | temp &= ~DREF_SSC_SOURCE_MASK; | ||
| 2268 | temp |= DREF_SSC_SOURCE_ENABLE; | ||
| 2269 | temp &= ~DREF_SSC1_ENABLE; | ||
| 2270 | /* if no eDP, disable source output to CPU */ | ||
| 2271 | temp &= ~DREF_CPU_SOURCE_OUTPUT_MASK; | ||
| 2272 | temp |= DREF_CPU_SOURCE_OUTPUT_DISABLE; | ||
| 2273 | I915_WRITE(PCH_DREF_CONTROL, temp); | ||
| 2274 | } | ||
| 2275 | |||
| 2276 | /* The LVDS pin pair needs to be on before the DPLLs are enabled. | 2511 | /* The LVDS pin pair needs to be on before the DPLLs are enabled. |
| 2277 | * This is an exception to the general rule that mode_set doesn't turn | 2512 | * This is an exception to the general rule that mode_set doesn't turn |
| 2278 | * things on. | 2513 | * things on. |
| @@ -2304,23 +2539,25 @@ static int intel_crtc_mode_set(struct drm_crtc *crtc, | |||
| 2304 | if (is_dp) | 2539 | if (is_dp) |
| 2305 | intel_dp_set_m_n(crtc, mode, adjusted_mode); | 2540 | intel_dp_set_m_n(crtc, mode, adjusted_mode); |
| 2306 | 2541 | ||
| 2307 | I915_WRITE(fp_reg, fp); | 2542 | if (!is_edp) { |
| 2308 | I915_WRITE(dpll_reg, dpll); | 2543 | I915_WRITE(fp_reg, fp); |
| 2309 | I915_READ(dpll_reg); | ||
| 2310 | /* Wait for the clocks to stabilize. */ | ||
| 2311 | udelay(150); | ||
| 2312 | |||
| 2313 | if (IS_I965G(dev) && !IS_IGDNG(dev)) { | ||
| 2314 | sdvo_pixel_multiply = adjusted_mode->clock / mode->clock; | ||
| 2315 | I915_WRITE(dpll_md_reg, (0 << DPLL_MD_UDI_DIVIDER_SHIFT) | | ||
| 2316 | ((sdvo_pixel_multiply - 1) << DPLL_MD_UDI_MULTIPLIER_SHIFT)); | ||
| 2317 | } else { | ||
| 2318 | /* write it again -- the BIOS does, after all */ | ||
| 2319 | I915_WRITE(dpll_reg, dpll); | 2544 | I915_WRITE(dpll_reg, dpll); |
| 2545 | I915_READ(dpll_reg); | ||
| 2546 | /* Wait for the clocks to stabilize. */ | ||
| 2547 | udelay(150); | ||
| 2548 | |||
| 2549 | if (IS_I965G(dev) && !IS_IGDNG(dev)) { | ||
| 2550 | sdvo_pixel_multiply = adjusted_mode->clock / mode->clock; | ||
| 2551 | I915_WRITE(dpll_md_reg, (0 << DPLL_MD_UDI_DIVIDER_SHIFT) | | ||
| 2552 | ((sdvo_pixel_multiply - 1) << DPLL_MD_UDI_MULTIPLIER_SHIFT)); | ||
| 2553 | } else { | ||
| 2554 | /* write it again -- the BIOS does, after all */ | ||
| 2555 | I915_WRITE(dpll_reg, dpll); | ||
| 2556 | } | ||
| 2557 | I915_READ(dpll_reg); | ||
| 2558 | /* Wait for the clocks to stabilize. */ | ||
| 2559 | udelay(150); | ||
| 2320 | } | 2560 | } |
| 2321 | I915_READ(dpll_reg); | ||
| 2322 | /* Wait for the clocks to stabilize. */ | ||
| 2323 | udelay(150); | ||
| 2324 | 2561 | ||
| 2325 | I915_WRITE(htot_reg, (adjusted_mode->crtc_hdisplay - 1) | | 2562 | I915_WRITE(htot_reg, (adjusted_mode->crtc_hdisplay - 1) | |
| 2326 | ((adjusted_mode->crtc_htotal - 1) << 16)); | 2563 | ((adjusted_mode->crtc_htotal - 1) << 16)); |
| @@ -2350,10 +2587,14 @@ static int intel_crtc_mode_set(struct drm_crtc *crtc, | |||
| 2350 | I915_WRITE(link_m1_reg, m_n.link_m); | 2587 | I915_WRITE(link_m1_reg, m_n.link_m); |
| 2351 | I915_WRITE(link_n1_reg, m_n.link_n); | 2588 | I915_WRITE(link_n1_reg, m_n.link_n); |
| 2352 | 2589 | ||
| 2353 | /* enable FDI RX PLL too */ | 2590 | if (is_edp) { |
| 2354 | temp = I915_READ(fdi_rx_reg); | 2591 | igdng_set_pll_edp(crtc, adjusted_mode->clock); |
| 2355 | I915_WRITE(fdi_rx_reg, temp | FDI_RX_PLL_ENABLE); | 2592 | } else { |
| 2356 | udelay(200); | 2593 | /* enable FDI RX PLL too */ |
| 2594 | temp = I915_READ(fdi_rx_reg); | ||
| 2595 | I915_WRITE(fdi_rx_reg, temp | FDI_RX_PLL_ENABLE); | ||
| 2596 | udelay(200); | ||
| 2597 | } | ||
| 2357 | } | 2598 | } |
| 2358 | 2599 | ||
| 2359 | I915_WRITE(pipeconf_reg, pipeconf); | 2600 | I915_WRITE(pipeconf_reg, pipeconf); |
| @@ -2951,12 +3192,17 @@ static void intel_setup_outputs(struct drm_device *dev) | |||
| 2951 | if (IS_IGDNG(dev)) { | 3192 | if (IS_IGDNG(dev)) { |
| 2952 | int found; | 3193 | int found; |
| 2953 | 3194 | ||
| 3195 | if (IS_MOBILE(dev) && (I915_READ(DP_A) & DP_DETECTED)) | ||
| 3196 | intel_dp_init(dev, DP_A); | ||
| 3197 | |||
| 2954 | if (I915_READ(HDMIB) & PORT_DETECTED) { | 3198 | if (I915_READ(HDMIB) & PORT_DETECTED) { |
| 2955 | /* check SDVOB */ | 3199 | /* check SDVOB */ |
| 2956 | /* found = intel_sdvo_init(dev, HDMIB); */ | 3200 | /* found = intel_sdvo_init(dev, HDMIB); */ |
| 2957 | found = 0; | 3201 | found = 0; |
| 2958 | if (!found) | 3202 | if (!found) |
| 2959 | intel_hdmi_init(dev, HDMIB); | 3203 | intel_hdmi_init(dev, HDMIB); |
| 3204 | if (!found && (I915_READ(PCH_DP_B) & DP_DETECTED)) | ||
| 3205 | intel_dp_init(dev, PCH_DP_B); | ||
| 2960 | } | 3206 | } |
| 2961 | 3207 | ||
| 2962 | if (I915_READ(HDMIC) & PORT_DETECTED) | 3208 | if (I915_READ(HDMIC) & PORT_DETECTED) |
| @@ -2965,6 +3211,12 @@ static void intel_setup_outputs(struct drm_device *dev) | |||
| 2965 | if (I915_READ(HDMID) & PORT_DETECTED) | 3211 | if (I915_READ(HDMID) & PORT_DETECTED) |
| 2966 | intel_hdmi_init(dev, HDMID); | 3212 | intel_hdmi_init(dev, HDMID); |
| 2967 | 3213 | ||
| 3214 | if (I915_READ(PCH_DP_C) & DP_DETECTED) | ||
| 3215 | intel_dp_init(dev, PCH_DP_C); | ||
| 3216 | |||
| 3217 | if (I915_READ(PCH_DP_D) & DP_DETECTED) | ||
| 3218 | intel_dp_init(dev, PCH_DP_D); | ||
| 3219 | |||
| 2968 | } else if (IS_I9XX(dev)) { | 3220 | } else if (IS_I9XX(dev)) { |
| 2969 | int found; | 3221 | int found; |
| 2970 | u32 reg; | 3222 | u32 reg; |
| @@ -3039,6 +3291,10 @@ static void intel_setup_outputs(struct drm_device *dev) | |||
| 3039 | (1 << 1)); | 3291 | (1 << 1)); |
| 3040 | clone_mask = (1 << INTEL_OUTPUT_DISPLAYPORT); | 3292 | clone_mask = (1 << INTEL_OUTPUT_DISPLAYPORT); |
| 3041 | break; | 3293 | break; |
| 3294 | case INTEL_OUTPUT_EDP: | ||
| 3295 | crtc_mask = (1 << 1); | ||
| 3296 | clone_mask = (1 << INTEL_OUTPUT_EDP); | ||
| 3297 | break; | ||
| 3042 | } | 3298 | } |
| 3043 | encoder->possible_crtcs = crtc_mask; | 3299 | encoder->possible_crtcs = crtc_mask; |
| 3044 | encoder->possible_clones = intel_connector_clones(dev, clone_mask); | 3300 | encoder->possible_clones = intel_connector_clones(dev, clone_mask); |
| @@ -3148,6 +3404,9 @@ void intel_modeset_init(struct drm_device *dev) | |||
| 3148 | if (IS_I965G(dev)) { | 3404 | if (IS_I965G(dev)) { |
| 3149 | dev->mode_config.max_width = 8192; | 3405 | dev->mode_config.max_width = 8192; |
| 3150 | dev->mode_config.max_height = 8192; | 3406 | dev->mode_config.max_height = 8192; |
| 3407 | } else if (IS_I9XX(dev)) { | ||
| 3408 | dev->mode_config.max_width = 4096; | ||
| 3409 | dev->mode_config.max_height = 4096; | ||
| 3151 | } else { | 3410 | } else { |
| 3152 | dev->mode_config.max_width = 2048; | 3411 | dev->mode_config.max_width = 2048; |
| 3153 | dev->mode_config.max_height = 2048; | 3412 | dev->mode_config.max_height = 2048; |
diff --git a/drivers/gpu/drm/i915/intel_dp.c b/drivers/gpu/drm/i915/intel_dp.c index 6770ae88370d..a6ff15ac548a 100644 --- a/drivers/gpu/drm/i915/intel_dp.c +++ b/drivers/gpu/drm/i915/intel_dp.c | |||
| @@ -40,6 +40,8 @@ | |||
| 40 | 40 | ||
| 41 | #define DP_LINK_CONFIGURATION_SIZE 9 | 41 | #define DP_LINK_CONFIGURATION_SIZE 9 |
| 42 | 42 | ||
| 43 | #define IS_eDP(i) ((i)->type == INTEL_OUTPUT_EDP) | ||
| 44 | |||
| 43 | struct intel_dp_priv { | 45 | struct intel_dp_priv { |
| 44 | uint32_t output_reg; | 46 | uint32_t output_reg; |
| 45 | uint32_t DP; | 47 | uint32_t DP; |
| @@ -63,6 +65,19 @@ intel_dp_link_train(struct intel_output *intel_output, uint32_t DP, | |||
| 63 | static void | 65 | static void |
| 64 | intel_dp_link_down(struct intel_output *intel_output, uint32_t DP); | 66 | intel_dp_link_down(struct intel_output *intel_output, uint32_t DP); |
| 65 | 67 | ||
| 68 | void | ||
| 69 | intel_edp_link_config (struct intel_output *intel_output, | ||
| 70 | int *lane_num, int *link_bw) | ||
| 71 | { | ||
| 72 | struct intel_dp_priv *dp_priv = intel_output->dev_priv; | ||
| 73 | |||
| 74 | *lane_num = dp_priv->lane_count; | ||
| 75 | if (dp_priv->link_bw == DP_LINK_BW_1_62) | ||
| 76 | *link_bw = 162000; | ||
| 77 | else if (dp_priv->link_bw == DP_LINK_BW_2_7) | ||
| 78 | *link_bw = 270000; | ||
| 79 | } | ||
| 80 | |||
| 66 | static int | 81 | static int |
| 67 | intel_dp_max_lane_count(struct intel_output *intel_output) | 82 | intel_dp_max_lane_count(struct intel_output *intel_output) |
| 68 | { | 83 | { |
| @@ -206,7 +221,13 @@ intel_dp_aux_ch(struct intel_output *intel_output, | |||
| 206 | * and would like to run at 2MHz. So, take the | 221 | * and would like to run at 2MHz. So, take the |
| 207 | * hrawclk value and divide by 2 and use that | 222 | * hrawclk value and divide by 2 and use that |
| 208 | */ | 223 | */ |
| 209 | aux_clock_divider = intel_hrawclk(dev) / 2; | 224 | if (IS_eDP(intel_output)) |
| 225 | aux_clock_divider = 225; /* eDP input clock at 450Mhz */ | ||
| 226 | else if (IS_IGDNG(dev)) | ||
| 227 | aux_clock_divider = 62; /* IGDNG: input clock fixed at 125Mhz */ | ||
| 228 | else | ||
| 229 | aux_clock_divider = intel_hrawclk(dev) / 2; | ||
| 230 | |||
| 210 | /* Must try at least 3 times according to DP spec */ | 231 | /* Must try at least 3 times according to DP spec */ |
| 211 | for (try = 0; try < 5; try++) { | 232 | for (try = 0; try < 5; try++) { |
| 212 | /* Load the send data into the aux channel data registers */ | 233 | /* Load the send data into the aux channel data registers */ |
| @@ -236,7 +257,7 @@ intel_dp_aux_ch(struct intel_output *intel_output, | |||
| 236 | } | 257 | } |
| 237 | 258 | ||
| 238 | /* Clear done status and any errors */ | 259 | /* Clear done status and any errors */ |
| 239 | I915_WRITE(ch_ctl, (ctl | | 260 | I915_WRITE(ch_ctl, (status | |
| 240 | DP_AUX_CH_CTL_DONE | | 261 | DP_AUX_CH_CTL_DONE | |
| 241 | DP_AUX_CH_CTL_TIME_OUT_ERROR | | 262 | DP_AUX_CH_CTL_TIME_OUT_ERROR | |
| 242 | DP_AUX_CH_CTL_RECEIVE_ERROR)); | 263 | DP_AUX_CH_CTL_RECEIVE_ERROR)); |
| @@ -295,7 +316,7 @@ intel_dp_aux_native_write(struct intel_output *intel_output, | |||
| 295 | return -1; | 316 | return -1; |
| 296 | msg[0] = AUX_NATIVE_WRITE << 4; | 317 | msg[0] = AUX_NATIVE_WRITE << 4; |
| 297 | msg[1] = address >> 8; | 318 | msg[1] = address >> 8; |
| 298 | msg[2] = address; | 319 | msg[2] = address & 0xff; |
| 299 | msg[3] = send_bytes - 1; | 320 | msg[3] = send_bytes - 1; |
| 300 | memcpy(&msg[4], send, send_bytes); | 321 | memcpy(&msg[4], send, send_bytes); |
| 301 | msg_bytes = send_bytes + 4; | 322 | msg_bytes = send_bytes + 4; |
| @@ -387,8 +408,8 @@ intel_dp_i2c_init(struct intel_output *intel_output, const char *name) | |||
| 387 | memset(&dp_priv->adapter, '\0', sizeof (dp_priv->adapter)); | 408 | memset(&dp_priv->adapter, '\0', sizeof (dp_priv->adapter)); |
| 388 | dp_priv->adapter.owner = THIS_MODULE; | 409 | dp_priv->adapter.owner = THIS_MODULE; |
| 389 | dp_priv->adapter.class = I2C_CLASS_DDC; | 410 | dp_priv->adapter.class = I2C_CLASS_DDC; |
| 390 | strncpy (dp_priv->adapter.name, name, sizeof dp_priv->adapter.name - 1); | 411 | strncpy (dp_priv->adapter.name, name, sizeof(dp_priv->adapter.name) - 1); |
| 391 | dp_priv->adapter.name[sizeof dp_priv->adapter.name - 1] = '\0'; | 412 | dp_priv->adapter.name[sizeof(dp_priv->adapter.name) - 1] = '\0'; |
| 392 | dp_priv->adapter.algo_data = &dp_priv->algo; | 413 | dp_priv->adapter.algo_data = &dp_priv->algo; |
| 393 | dp_priv->adapter.dev.parent = &intel_output->base.kdev; | 414 | dp_priv->adapter.dev.parent = &intel_output->base.kdev; |
| 394 | 415 | ||
| @@ -493,22 +514,40 @@ intel_dp_set_m_n(struct drm_crtc *crtc, struct drm_display_mode *mode, | |||
| 493 | intel_dp_compute_m_n(3, lane_count, | 514 | intel_dp_compute_m_n(3, lane_count, |
| 494 | mode->clock, adjusted_mode->clock, &m_n); | 515 | mode->clock, adjusted_mode->clock, &m_n); |
| 495 | 516 | ||
| 496 | if (intel_crtc->pipe == 0) { | 517 | if (IS_IGDNG(dev)) { |
| 497 | I915_WRITE(PIPEA_GMCH_DATA_M, | 518 | if (intel_crtc->pipe == 0) { |
| 498 | ((m_n.tu - 1) << PIPE_GMCH_DATA_M_TU_SIZE_SHIFT) | | 519 | I915_WRITE(TRANSA_DATA_M1, |
| 499 | m_n.gmch_m); | 520 | ((m_n.tu - 1) << PIPE_GMCH_DATA_M_TU_SIZE_SHIFT) | |
| 500 | I915_WRITE(PIPEA_GMCH_DATA_N, | 521 | m_n.gmch_m); |
| 501 | m_n.gmch_n); | 522 | I915_WRITE(TRANSA_DATA_N1, m_n.gmch_n); |
| 502 | I915_WRITE(PIPEA_DP_LINK_M, m_n.link_m); | 523 | I915_WRITE(TRANSA_DP_LINK_M1, m_n.link_m); |
| 503 | I915_WRITE(PIPEA_DP_LINK_N, m_n.link_n); | 524 | I915_WRITE(TRANSA_DP_LINK_N1, m_n.link_n); |
| 525 | } else { | ||
| 526 | I915_WRITE(TRANSB_DATA_M1, | ||
| 527 | ((m_n.tu - 1) << PIPE_GMCH_DATA_M_TU_SIZE_SHIFT) | | ||
| 528 | m_n.gmch_m); | ||
| 529 | I915_WRITE(TRANSB_DATA_N1, m_n.gmch_n); | ||
| 530 | I915_WRITE(TRANSB_DP_LINK_M1, m_n.link_m); | ||
| 531 | I915_WRITE(TRANSB_DP_LINK_N1, m_n.link_n); | ||
| 532 | } | ||
| 504 | } else { | 533 | } else { |
| 505 | I915_WRITE(PIPEB_GMCH_DATA_M, | 534 | if (intel_crtc->pipe == 0) { |
| 506 | ((m_n.tu - 1) << PIPE_GMCH_DATA_M_TU_SIZE_SHIFT) | | 535 | I915_WRITE(PIPEA_GMCH_DATA_M, |
| 507 | m_n.gmch_m); | 536 | ((m_n.tu - 1) << PIPE_GMCH_DATA_M_TU_SIZE_SHIFT) | |
| 508 | I915_WRITE(PIPEB_GMCH_DATA_N, | 537 | m_n.gmch_m); |
| 509 | m_n.gmch_n); | 538 | I915_WRITE(PIPEA_GMCH_DATA_N, |
| 510 | I915_WRITE(PIPEB_DP_LINK_M, m_n.link_m); | 539 | m_n.gmch_n); |
| 511 | I915_WRITE(PIPEB_DP_LINK_N, m_n.link_n); | 540 | I915_WRITE(PIPEA_DP_LINK_M, m_n.link_m); |
| 541 | I915_WRITE(PIPEA_DP_LINK_N, m_n.link_n); | ||
| 542 | } else { | ||
| 543 | I915_WRITE(PIPEB_GMCH_DATA_M, | ||
| 544 | ((m_n.tu - 1) << PIPE_GMCH_DATA_M_TU_SIZE_SHIFT) | | ||
| 545 | m_n.gmch_m); | ||
| 546 | I915_WRITE(PIPEB_GMCH_DATA_N, | ||
| 547 | m_n.gmch_n); | ||
| 548 | I915_WRITE(PIPEB_DP_LINK_M, m_n.link_m); | ||
| 549 | I915_WRITE(PIPEB_DP_LINK_N, m_n.link_n); | ||
| 550 | } | ||
| 512 | } | 551 | } |
| 513 | } | 552 | } |
| 514 | 553 | ||
| @@ -556,8 +595,38 @@ intel_dp_mode_set(struct drm_encoder *encoder, struct drm_display_mode *mode, | |||
| 556 | 595 | ||
| 557 | if (intel_crtc->pipe == 1) | 596 | if (intel_crtc->pipe == 1) |
| 558 | dp_priv->DP |= DP_PIPEB_SELECT; | 597 | dp_priv->DP |= DP_PIPEB_SELECT; |
| 598 | |||
| 599 | if (IS_eDP(intel_output)) { | ||
| 600 | /* don't miss out required setting for eDP */ | ||
| 601 | dp_priv->DP |= DP_PLL_ENABLE; | ||
| 602 | if (adjusted_mode->clock < 200000) | ||
| 603 | dp_priv->DP |= DP_PLL_FREQ_160MHZ; | ||
| 604 | else | ||
| 605 | dp_priv->DP |= DP_PLL_FREQ_270MHZ; | ||
| 606 | } | ||
| 559 | } | 607 | } |
| 560 | 608 | ||
| 609 | static void igdng_edp_backlight_on (struct drm_device *dev) | ||
| 610 | { | ||
| 611 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
| 612 | u32 pp; | ||
| 613 | |||
| 614 | DRM_DEBUG("\n"); | ||
| 615 | pp = I915_READ(PCH_PP_CONTROL); | ||
| 616 | pp |= EDP_BLC_ENABLE; | ||
| 617 | I915_WRITE(PCH_PP_CONTROL, pp); | ||
| 618 | } | ||
| 619 | |||
| 620 | static void igdng_edp_backlight_off (struct drm_device *dev) | ||
| 621 | { | ||
| 622 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
| 623 | u32 pp; | ||
| 624 | |||
| 625 | DRM_DEBUG("\n"); | ||
| 626 | pp = I915_READ(PCH_PP_CONTROL); | ||
| 627 | pp &= ~EDP_BLC_ENABLE; | ||
| 628 | I915_WRITE(PCH_PP_CONTROL, pp); | ||
| 629 | } | ||
| 561 | 630 | ||
| 562 | static void | 631 | static void |
| 563 | intel_dp_dpms(struct drm_encoder *encoder, int mode) | 632 | intel_dp_dpms(struct drm_encoder *encoder, int mode) |
| @@ -569,11 +638,17 @@ intel_dp_dpms(struct drm_encoder *encoder, int mode) | |||
| 569 | uint32_t dp_reg = I915_READ(dp_priv->output_reg); | 638 | uint32_t dp_reg = I915_READ(dp_priv->output_reg); |
| 570 | 639 | ||
| 571 | if (mode != DRM_MODE_DPMS_ON) { | 640 | if (mode != DRM_MODE_DPMS_ON) { |
| 572 | if (dp_reg & DP_PORT_EN) | 641 | if (dp_reg & DP_PORT_EN) { |
| 573 | intel_dp_link_down(intel_output, dp_priv->DP); | 642 | intel_dp_link_down(intel_output, dp_priv->DP); |
| 643 | if (IS_eDP(intel_output)) | ||
| 644 | igdng_edp_backlight_off(dev); | ||
| 645 | } | ||
| 574 | } else { | 646 | } else { |
| 575 | if (!(dp_reg & DP_PORT_EN)) | 647 | if (!(dp_reg & DP_PORT_EN)) { |
| 576 | intel_dp_link_train(intel_output, dp_priv->DP, dp_priv->link_configuration); | 648 | intel_dp_link_train(intel_output, dp_priv->DP, dp_priv->link_configuration); |
| 649 | if (IS_eDP(intel_output)) | ||
| 650 | igdng_edp_backlight_on(dev); | ||
| 651 | } | ||
| 577 | } | 652 | } |
| 578 | dp_priv->dpms_mode = mode; | 653 | dp_priv->dpms_mode = mode; |
| 579 | } | 654 | } |
| @@ -935,6 +1010,23 @@ intel_dp_link_down(struct intel_output *intel_output, uint32_t DP) | |||
| 935 | struct drm_i915_private *dev_priv = dev->dev_private; | 1010 | struct drm_i915_private *dev_priv = dev->dev_private; |
| 936 | struct intel_dp_priv *dp_priv = intel_output->dev_priv; | 1011 | struct intel_dp_priv *dp_priv = intel_output->dev_priv; |
| 937 | 1012 | ||
| 1013 | DRM_DEBUG("\n"); | ||
| 1014 | |||
| 1015 | if (IS_eDP(intel_output)) { | ||
| 1016 | DP &= ~DP_PLL_ENABLE; | ||
| 1017 | I915_WRITE(dp_priv->output_reg, DP); | ||
| 1018 | POSTING_READ(dp_priv->output_reg); | ||
| 1019 | udelay(100); | ||
| 1020 | } | ||
| 1021 | |||
| 1022 | DP &= ~DP_LINK_TRAIN_MASK; | ||
| 1023 | I915_WRITE(dp_priv->output_reg, DP | DP_LINK_TRAIN_PAT_IDLE); | ||
| 1024 | POSTING_READ(dp_priv->output_reg); | ||
| 1025 | |||
| 1026 | udelay(17000); | ||
| 1027 | |||
| 1028 | if (IS_eDP(intel_output)) | ||
| 1029 | DP |= DP_LINK_TRAIN_OFF; | ||
| 938 | I915_WRITE(dp_priv->output_reg, DP & ~DP_PORT_EN); | 1030 | I915_WRITE(dp_priv->output_reg, DP & ~DP_PORT_EN); |
| 939 | POSTING_READ(dp_priv->output_reg); | 1031 | POSTING_READ(dp_priv->output_reg); |
| 940 | } | 1032 | } |
| @@ -978,6 +1070,24 @@ intel_dp_check_link_status(struct intel_output *intel_output) | |||
| 978 | intel_dp_link_train(intel_output, dp_priv->DP, dp_priv->link_configuration); | 1070 | intel_dp_link_train(intel_output, dp_priv->DP, dp_priv->link_configuration); |
| 979 | } | 1071 | } |
| 980 | 1072 | ||
| 1073 | static enum drm_connector_status | ||
| 1074 | igdng_dp_detect(struct drm_connector *connector) | ||
| 1075 | { | ||
| 1076 | struct intel_output *intel_output = to_intel_output(connector); | ||
| 1077 | struct intel_dp_priv *dp_priv = intel_output->dev_priv; | ||
| 1078 | enum drm_connector_status status; | ||
| 1079 | |||
| 1080 | status = connector_status_disconnected; | ||
| 1081 | if (intel_dp_aux_native_read(intel_output, | ||
| 1082 | 0x000, dp_priv->dpcd, | ||
| 1083 | sizeof (dp_priv->dpcd)) == sizeof (dp_priv->dpcd)) | ||
| 1084 | { | ||
| 1085 | if (dp_priv->dpcd[0] != 0) | ||
| 1086 | status = connector_status_connected; | ||
| 1087 | } | ||
| 1088 | return status; | ||
| 1089 | } | ||
| 1090 | |||
| 981 | /** | 1091 | /** |
| 982 | * Uses CRT_HOTPLUG_EN and CRT_HOTPLUG_STAT to detect DP connection. | 1092 | * Uses CRT_HOTPLUG_EN and CRT_HOTPLUG_STAT to detect DP connection. |
| 983 | * | 1093 | * |
| @@ -996,6 +1106,9 @@ intel_dp_detect(struct drm_connector *connector) | |||
| 996 | 1106 | ||
| 997 | dp_priv->has_audio = false; | 1107 | dp_priv->has_audio = false; |
| 998 | 1108 | ||
| 1109 | if (IS_IGDNG(dev)) | ||
| 1110 | return igdng_dp_detect(connector); | ||
| 1111 | |||
| 999 | temp = I915_READ(PORT_HOTPLUG_EN); | 1112 | temp = I915_READ(PORT_HOTPLUG_EN); |
| 1000 | 1113 | ||
| 1001 | I915_WRITE(PORT_HOTPLUG_EN, | 1114 | I915_WRITE(PORT_HOTPLUG_EN, |
| @@ -1039,11 +1152,27 @@ intel_dp_detect(struct drm_connector *connector) | |||
| 1039 | static int intel_dp_get_modes(struct drm_connector *connector) | 1152 | static int intel_dp_get_modes(struct drm_connector *connector) |
| 1040 | { | 1153 | { |
| 1041 | struct intel_output *intel_output = to_intel_output(connector); | 1154 | struct intel_output *intel_output = to_intel_output(connector); |
| 1155 | struct drm_device *dev = intel_output->base.dev; | ||
| 1156 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
| 1157 | int ret; | ||
| 1042 | 1158 | ||
| 1043 | /* We should parse the EDID data and find out if it has an audio sink | 1159 | /* We should parse the EDID data and find out if it has an audio sink |
| 1044 | */ | 1160 | */ |
| 1045 | 1161 | ||
| 1046 | return intel_ddc_get_modes(intel_output); | 1162 | ret = intel_ddc_get_modes(intel_output); |
| 1163 | if (ret) | ||
| 1164 | return ret; | ||
| 1165 | |||
| 1166 | /* if eDP has no EDID, try to use fixed panel mode from VBT */ | ||
| 1167 | if (IS_eDP(intel_output)) { | ||
| 1168 | if (dev_priv->panel_fixed_mode != NULL) { | ||
| 1169 | struct drm_display_mode *mode; | ||
| 1170 | mode = drm_mode_duplicate(dev, dev_priv->panel_fixed_mode); | ||
| 1171 | drm_mode_probed_add(connector, mode); | ||
| 1172 | return 1; | ||
| 1173 | } | ||
| 1174 | } | ||
| 1175 | return 0; | ||
| 1047 | } | 1176 | } |
| 1048 | 1177 | ||
| 1049 | static void | 1178 | static void |
| @@ -1106,6 +1235,7 @@ intel_dp_init(struct drm_device *dev, int output_reg) | |||
| 1106 | struct drm_connector *connector; | 1235 | struct drm_connector *connector; |
| 1107 | struct intel_output *intel_output; | 1236 | struct intel_output *intel_output; |
| 1108 | struct intel_dp_priv *dp_priv; | 1237 | struct intel_dp_priv *dp_priv; |
| 1238 | const char *name = NULL; | ||
| 1109 | 1239 | ||
| 1110 | intel_output = kcalloc(sizeof(struct intel_output) + | 1240 | intel_output = kcalloc(sizeof(struct intel_output) + |
| 1111 | sizeof(struct intel_dp_priv), 1, GFP_KERNEL); | 1241 | sizeof(struct intel_dp_priv), 1, GFP_KERNEL); |
| @@ -1119,7 +1249,10 @@ intel_dp_init(struct drm_device *dev, int output_reg) | |||
| 1119 | DRM_MODE_CONNECTOR_DisplayPort); | 1249 | DRM_MODE_CONNECTOR_DisplayPort); |
| 1120 | drm_connector_helper_add(connector, &intel_dp_connector_helper_funcs); | 1250 | drm_connector_helper_add(connector, &intel_dp_connector_helper_funcs); |
| 1121 | 1251 | ||
| 1122 | intel_output->type = INTEL_OUTPUT_DISPLAYPORT; | 1252 | if (output_reg == DP_A) |
| 1253 | intel_output->type = INTEL_OUTPUT_EDP; | ||
| 1254 | else | ||
| 1255 | intel_output->type = INTEL_OUTPUT_DISPLAYPORT; | ||
| 1123 | 1256 | ||
| 1124 | connector->interlace_allowed = true; | 1257 | connector->interlace_allowed = true; |
| 1125 | connector->doublescan_allowed = 0; | 1258 | connector->doublescan_allowed = 0; |
| @@ -1139,12 +1272,41 @@ intel_dp_init(struct drm_device *dev, int output_reg) | |||
| 1139 | drm_sysfs_connector_add(connector); | 1272 | drm_sysfs_connector_add(connector); |
| 1140 | 1273 | ||
| 1141 | /* Set up the DDC bus. */ | 1274 | /* Set up the DDC bus. */ |
| 1142 | intel_dp_i2c_init(intel_output, | 1275 | switch (output_reg) { |
| 1143 | (output_reg == DP_B) ? "DPDDC-B" : | 1276 | case DP_A: |
| 1144 | (output_reg == DP_C) ? "DPDDC-C" : "DPDDC-D"); | 1277 | name = "DPDDC-A"; |
| 1278 | break; | ||
| 1279 | case DP_B: | ||
| 1280 | case PCH_DP_B: | ||
| 1281 | name = "DPDDC-B"; | ||
| 1282 | break; | ||
| 1283 | case DP_C: | ||
| 1284 | case PCH_DP_C: | ||
| 1285 | name = "DPDDC-C"; | ||
| 1286 | break; | ||
| 1287 | case DP_D: | ||
| 1288 | case PCH_DP_D: | ||
| 1289 | name = "DPDDC-D"; | ||
| 1290 | break; | ||
| 1291 | } | ||
| 1292 | |||
| 1293 | intel_dp_i2c_init(intel_output, name); | ||
| 1294 | |||
| 1145 | intel_output->ddc_bus = &dp_priv->adapter; | 1295 | intel_output->ddc_bus = &dp_priv->adapter; |
| 1146 | intel_output->hot_plug = intel_dp_hot_plug; | 1296 | intel_output->hot_plug = intel_dp_hot_plug; |
| 1147 | 1297 | ||
| 1298 | if (output_reg == DP_A) { | ||
| 1299 | /* initialize panel mode from VBT if available for eDP */ | ||
| 1300 | if (dev_priv->lfp_lvds_vbt_mode) { | ||
| 1301 | dev_priv->panel_fixed_mode = | ||
| 1302 | drm_mode_duplicate(dev, dev_priv->lfp_lvds_vbt_mode); | ||
| 1303 | if (dev_priv->panel_fixed_mode) { | ||
| 1304 | dev_priv->panel_fixed_mode->type |= | ||
| 1305 | DRM_MODE_TYPE_PREFERRED; | ||
| 1306 | } | ||
| 1307 | } | ||
| 1308 | } | ||
| 1309 | |||
| 1148 | /* For G4X desktop chip, PEG_BAND_GAP_DATA 3:0 must first be written | 1310 | /* For G4X desktop chip, PEG_BAND_GAP_DATA 3:0 must first be written |
| 1149 | * 0xd. Failure to do so will result in spurious interrupts being | 1311 | * 0xd. Failure to do so will result in spurious interrupts being |
| 1150 | * generated on the port when a cable is not attached. | 1312 | * generated on the port when a cable is not attached. |
diff --git a/drivers/gpu/drm/i915/intel_drv.h b/drivers/gpu/drm/i915/intel_drv.h index 004541c935a8..d6f92ea1b553 100644 --- a/drivers/gpu/drm/i915/intel_drv.h +++ b/drivers/gpu/drm/i915/intel_drv.h | |||
| @@ -55,6 +55,7 @@ | |||
| 55 | #define INTEL_OUTPUT_TVOUT 5 | 55 | #define INTEL_OUTPUT_TVOUT 5 |
| 56 | #define INTEL_OUTPUT_HDMI 6 | 56 | #define INTEL_OUTPUT_HDMI 6 |
| 57 | #define INTEL_OUTPUT_DISPLAYPORT 7 | 57 | #define INTEL_OUTPUT_DISPLAYPORT 7 |
| 58 | #define INTEL_OUTPUT_EDP 8 | ||
| 58 | 59 | ||
| 59 | #define INTEL_DVO_CHIP_NONE 0 | 60 | #define INTEL_DVO_CHIP_NONE 0 |
| 60 | #define INTEL_DVO_CHIP_LVDS 1 | 61 | #define INTEL_DVO_CHIP_LVDS 1 |
| @@ -121,6 +122,8 @@ extern void intel_dp_init(struct drm_device *dev, int dp_reg); | |||
| 121 | void | 122 | void |
| 122 | intel_dp_set_m_n(struct drm_crtc *crtc, struct drm_display_mode *mode, | 123 | intel_dp_set_m_n(struct drm_crtc *crtc, struct drm_display_mode *mode, |
| 123 | struct drm_display_mode *adjusted_mode); | 124 | struct drm_display_mode *adjusted_mode); |
| 125 | extern void intel_edp_link_config (struct intel_output *, int *, int *); | ||
| 126 | |||
| 124 | 127 | ||
| 125 | extern void intel_crtc_load_lut(struct drm_crtc *crtc); | 128 | extern void intel_crtc_load_lut(struct drm_crtc *crtc); |
| 126 | extern void intel_encoder_prepare (struct drm_encoder *encoder); | 129 | extern void intel_encoder_prepare (struct drm_encoder *encoder); |
diff --git a/drivers/gpu/drm/i915/intel_hdmi.c b/drivers/gpu/drm/i915/intel_hdmi.c index 9e30daae37dc..1842290cded3 100644 --- a/drivers/gpu/drm/i915/intel_hdmi.c +++ b/drivers/gpu/drm/i915/intel_hdmi.c | |||
| @@ -130,16 +130,17 @@ static bool intel_hdmi_mode_fixup(struct drm_encoder *encoder, | |||
| 130 | } | 130 | } |
| 131 | 131 | ||
| 132 | static enum drm_connector_status | 132 | static enum drm_connector_status |
| 133 | intel_hdmi_edid_detect(struct drm_connector *connector) | 133 | intel_hdmi_detect(struct drm_connector *connector) |
| 134 | { | 134 | { |
| 135 | struct intel_output *intel_output = to_intel_output(connector); | 135 | struct intel_output *intel_output = to_intel_output(connector); |
| 136 | struct intel_hdmi_priv *hdmi_priv = intel_output->dev_priv; | 136 | struct intel_hdmi_priv *hdmi_priv = intel_output->dev_priv; |
| 137 | struct edid *edid = NULL; | 137 | struct edid *edid = NULL; |
| 138 | enum drm_connector_status status = connector_status_disconnected; | 138 | enum drm_connector_status status = connector_status_disconnected; |
| 139 | 139 | ||
| 140 | hdmi_priv->has_hdmi_sink = false; | ||
| 140 | edid = drm_get_edid(&intel_output->base, | 141 | edid = drm_get_edid(&intel_output->base, |
| 141 | intel_output->ddc_bus); | 142 | intel_output->ddc_bus); |
| 142 | hdmi_priv->has_hdmi_sink = false; | 143 | |
| 143 | if (edid) { | 144 | if (edid) { |
| 144 | if (edid->input & DRM_EDID_INPUT_DIGITAL) { | 145 | if (edid->input & DRM_EDID_INPUT_DIGITAL) { |
| 145 | status = connector_status_connected; | 146 | status = connector_status_connected; |
| @@ -148,65 +149,8 @@ intel_hdmi_edid_detect(struct drm_connector *connector) | |||
| 148 | intel_output->base.display_info.raw_edid = NULL; | 149 | intel_output->base.display_info.raw_edid = NULL; |
| 149 | kfree(edid); | 150 | kfree(edid); |
| 150 | } | 151 | } |
| 151 | return status; | ||
| 152 | } | ||
| 153 | |||
| 154 | static enum drm_connector_status | ||
| 155 | igdng_hdmi_detect(struct drm_connector *connector) | ||
| 156 | { | ||
| 157 | struct intel_output *intel_output = to_intel_output(connector); | ||
| 158 | struct intel_hdmi_priv *hdmi_priv = intel_output->dev_priv; | ||
| 159 | |||
| 160 | /* FIXME hotplug detect */ | ||
| 161 | |||
| 162 | hdmi_priv->has_hdmi_sink = false; | ||
| 163 | return intel_hdmi_edid_detect(connector); | ||
| 164 | } | ||
| 165 | 152 | ||
| 166 | static enum drm_connector_status | 153 | return status; |
| 167 | intel_hdmi_detect(struct drm_connector *connector) | ||
| 168 | { | ||
| 169 | struct drm_device *dev = connector->dev; | ||
| 170 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
| 171 | struct intel_output *intel_output = to_intel_output(connector); | ||
| 172 | struct intel_hdmi_priv *hdmi_priv = intel_output->dev_priv; | ||
| 173 | u32 temp, bit; | ||
| 174 | |||
| 175 | if (IS_IGDNG(dev)) | ||
| 176 | return igdng_hdmi_detect(connector); | ||
| 177 | |||
| 178 | temp = I915_READ(PORT_HOTPLUG_EN); | ||
| 179 | |||
| 180 | switch (hdmi_priv->sdvox_reg) { | ||
| 181 | case SDVOB: | ||
| 182 | temp |= HDMIB_HOTPLUG_INT_EN; | ||
| 183 | break; | ||
| 184 | case SDVOC: | ||
| 185 | temp |= HDMIC_HOTPLUG_INT_EN; | ||
| 186 | break; | ||
| 187 | default: | ||
| 188 | return connector_status_unknown; | ||
| 189 | } | ||
| 190 | |||
| 191 | I915_WRITE(PORT_HOTPLUG_EN, temp); | ||
| 192 | |||
| 193 | POSTING_READ(PORT_HOTPLUG_EN); | ||
| 194 | |||
| 195 | switch (hdmi_priv->sdvox_reg) { | ||
| 196 | case SDVOB: | ||
| 197 | bit = HDMIB_HOTPLUG_INT_STATUS; | ||
| 198 | break; | ||
| 199 | case SDVOC: | ||
| 200 | bit = HDMIC_HOTPLUG_INT_STATUS; | ||
| 201 | break; | ||
| 202 | default: | ||
| 203 | return connector_status_unknown; | ||
| 204 | } | ||
| 205 | |||
| 206 | if ((I915_READ(PORT_HOTPLUG_STAT) & bit) != 0) | ||
| 207 | return intel_hdmi_edid_detect(connector); | ||
| 208 | else | ||
| 209 | return connector_status_disconnected; | ||
| 210 | } | 154 | } |
| 211 | 155 | ||
| 212 | static int intel_hdmi_get_modes(struct drm_connector *connector) | 156 | static int intel_hdmi_get_modes(struct drm_connector *connector) |
diff --git a/drivers/gpu/drm/i915/intel_lvds.c b/drivers/gpu/drm/i915/intel_lvds.c index 9ab38efffecf..3f445a80c552 100644 --- a/drivers/gpu/drm/i915/intel_lvds.c +++ b/drivers/gpu/drm/i915/intel_lvds.c | |||
| @@ -780,6 +780,14 @@ static const struct dmi_system_id intel_no_lvds[] = { | |||
| 780 | }, | 780 | }, |
| 781 | { | 781 | { |
| 782 | .callback = intel_no_lvds_dmi_callback, | 782 | .callback = intel_no_lvds_dmi_callback, |
| 783 | .ident = "AOpen Mini PC MP915", | ||
| 784 | .matches = { | ||
| 785 | DMI_MATCH(DMI_BOARD_VENDOR, "AOpen"), | ||
| 786 | DMI_MATCH(DMI_BOARD_NAME, "i915GMx-F"), | ||
| 787 | }, | ||
| 788 | }, | ||
| 789 | { | ||
| 790 | .callback = intel_no_lvds_dmi_callback, | ||
| 783 | .ident = "Aopen i945GTt-VFA", | 791 | .ident = "Aopen i945GTt-VFA", |
| 784 | .matches = { | 792 | .matches = { |
| 785 | DMI_MATCH(DMI_PRODUCT_VERSION, "AO00001JW"), | 793 | DMI_MATCH(DMI_PRODUCT_VERSION, "AO00001JW"), |
| @@ -884,6 +892,10 @@ void intel_lvds_init(struct drm_device *dev) | |||
| 884 | if (IS_IGDNG(dev)) { | 892 | if (IS_IGDNG(dev)) { |
| 885 | if ((I915_READ(PCH_LVDS) & LVDS_DETECTED) == 0) | 893 | if ((I915_READ(PCH_LVDS) & LVDS_DETECTED) == 0) |
| 886 | return; | 894 | return; |
| 895 | if (dev_priv->edp_support) { | ||
| 896 | DRM_DEBUG("disable LVDS for eDP support\n"); | ||
| 897 | return; | ||
| 898 | } | ||
| 887 | gpio = PCH_GPIOC; | 899 | gpio = PCH_GPIOC; |
| 888 | } | 900 | } |
| 889 | 901 | ||
diff --git a/drivers/gpu/drm/i915/intel_sdvo.c b/drivers/gpu/drm/i915/intel_sdvo.c index 4f0c30948bc4..5371d9332554 100644 --- a/drivers/gpu/drm/i915/intel_sdvo.c +++ b/drivers/gpu/drm/i915/intel_sdvo.c | |||
| @@ -31,6 +31,7 @@ | |||
| 31 | #include "drm.h" | 31 | #include "drm.h" |
| 32 | #include "drm_crtc.h" | 32 | #include "drm_crtc.h" |
| 33 | #include "intel_drv.h" | 33 | #include "intel_drv.h" |
| 34 | #include "drm_edid.h" | ||
| 34 | #include "i915_drm.h" | 35 | #include "i915_drm.h" |
| 35 | #include "i915_drv.h" | 36 | #include "i915_drv.h" |
| 36 | #include "intel_sdvo_regs.h" | 37 | #include "intel_sdvo_regs.h" |
| @@ -55,6 +56,12 @@ struct intel_sdvo_priv { | |||
| 55 | /* Pixel clock limitations reported by the SDVO device, in kHz */ | 56 | /* Pixel clock limitations reported by the SDVO device, in kHz */ |
| 56 | int pixel_clock_min, pixel_clock_max; | 57 | int pixel_clock_min, pixel_clock_max; |
| 57 | 58 | ||
| 59 | /* | ||
| 60 | * For multiple function SDVO device, | ||
| 61 | * this is for current attached outputs. | ||
| 62 | */ | ||
| 63 | uint16_t attached_output; | ||
| 64 | |||
| 58 | /** | 65 | /** |
| 59 | * This is set if we're going to treat the device as TV-out. | 66 | * This is set if we're going to treat the device as TV-out. |
| 60 | * | 67 | * |
| @@ -114,6 +121,9 @@ struct intel_sdvo_priv { | |||
| 114 | u32 save_SDVOX; | 121 | u32 save_SDVOX; |
| 115 | }; | 122 | }; |
| 116 | 123 | ||
| 124 | static bool | ||
| 125 | intel_sdvo_output_setup(struct intel_output *intel_output, uint16_t flags); | ||
| 126 | |||
| 117 | /** | 127 | /** |
| 118 | * Writes the SDVOB or SDVOC with the given value, but always writes both | 128 | * Writes the SDVOB or SDVOC with the given value, but always writes both |
| 119 | * SDVOB and SDVOC to work around apparent hardware issues (according to | 129 | * SDVOB and SDVOC to work around apparent hardware issues (according to |
| @@ -1435,41 +1445,96 @@ void intel_sdvo_set_hotplug(struct drm_connector *connector, int on) | |||
| 1435 | intel_sdvo_read_response(intel_output, &response, 2); | 1445 | intel_sdvo_read_response(intel_output, &response, 2); |
| 1436 | } | 1446 | } |
| 1437 | 1447 | ||
| 1438 | static void | 1448 | static bool |
| 1439 | intel_sdvo_hdmi_sink_detect(struct drm_connector *connector) | 1449 | intel_sdvo_multifunc_encoder(struct intel_output *intel_output) |
| 1450 | { | ||
| 1451 | struct intel_sdvo_priv *sdvo_priv = intel_output->dev_priv; | ||
| 1452 | int caps = 0; | ||
| 1453 | |||
| 1454 | if (sdvo_priv->caps.output_flags & | ||
| 1455 | (SDVO_OUTPUT_TMDS0 | SDVO_OUTPUT_TMDS1)) | ||
| 1456 | caps++; | ||
| 1457 | if (sdvo_priv->caps.output_flags & | ||
| 1458 | (SDVO_OUTPUT_RGB0 | SDVO_OUTPUT_RGB1)) | ||
| 1459 | caps++; | ||
| 1460 | if (sdvo_priv->caps.output_flags & | ||
| 1461 | (SDVO_OUTPUT_SVID0 | SDVO_OUTPUT_SVID0)) | ||
| 1462 | caps++; | ||
| 1463 | if (sdvo_priv->caps.output_flags & | ||
| 1464 | (SDVO_OUTPUT_CVBS0 | SDVO_OUTPUT_CVBS1)) | ||
| 1465 | caps++; | ||
| 1466 | if (sdvo_priv->caps.output_flags & | ||
| 1467 | (SDVO_OUTPUT_YPRPB0 | SDVO_OUTPUT_YPRPB1)) | ||
| 1468 | caps++; | ||
| 1469 | |||
| 1470 | if (sdvo_priv->caps.output_flags & | ||
| 1471 | (SDVO_OUTPUT_SCART0 | SDVO_OUTPUT_SCART1)) | ||
| 1472 | caps++; | ||
| 1473 | |||
| 1474 | if (sdvo_priv->caps.output_flags & | ||
| 1475 | (SDVO_OUTPUT_LVDS0 | SDVO_OUTPUT_LVDS1)) | ||
| 1476 | caps++; | ||
| 1477 | |||
| 1478 | return (caps > 1); | ||
| 1479 | } | ||
| 1480 | |||
| 1481 | enum drm_connector_status | ||
| 1482 | intel_sdvo_hdmi_sink_detect(struct drm_connector *connector, u16 response) | ||
| 1440 | { | 1483 | { |
| 1441 | struct intel_output *intel_output = to_intel_output(connector); | 1484 | struct intel_output *intel_output = to_intel_output(connector); |
| 1442 | struct intel_sdvo_priv *sdvo_priv = intel_output->dev_priv; | 1485 | struct intel_sdvo_priv *sdvo_priv = intel_output->dev_priv; |
| 1486 | enum drm_connector_status status = connector_status_connected; | ||
| 1443 | struct edid *edid = NULL; | 1487 | struct edid *edid = NULL; |
| 1444 | 1488 | ||
| 1445 | edid = drm_get_edid(&intel_output->base, | 1489 | edid = drm_get_edid(&intel_output->base, |
| 1446 | intel_output->ddc_bus); | 1490 | intel_output->ddc_bus); |
| 1447 | if (edid != NULL) { | 1491 | if (edid != NULL) { |
| 1448 | sdvo_priv->is_hdmi = drm_detect_hdmi_monitor(edid); | 1492 | /* Don't report the output as connected if it's a DVI-I |
| 1493 | * connector with a non-digital EDID coming out. | ||
| 1494 | */ | ||
| 1495 | if (response & (SDVO_OUTPUT_TMDS0 | SDVO_OUTPUT_TMDS1)) { | ||
| 1496 | if (edid->input & DRM_EDID_INPUT_DIGITAL) | ||
| 1497 | sdvo_priv->is_hdmi = | ||
| 1498 | drm_detect_hdmi_monitor(edid); | ||
| 1499 | else | ||
| 1500 | status = connector_status_disconnected; | ||
| 1501 | } | ||
| 1502 | |||
| 1449 | kfree(edid); | 1503 | kfree(edid); |
| 1450 | intel_output->base.display_info.raw_edid = NULL; | 1504 | intel_output->base.display_info.raw_edid = NULL; |
| 1451 | } | 1505 | |
| 1506 | } else if (response & (SDVO_OUTPUT_TMDS0 | SDVO_OUTPUT_TMDS1)) | ||
| 1507 | status = connector_status_disconnected; | ||
| 1508 | |||
| 1509 | return status; | ||
| 1452 | } | 1510 | } |
| 1453 | 1511 | ||
| 1454 | static enum drm_connector_status intel_sdvo_detect(struct drm_connector *connector) | 1512 | static enum drm_connector_status intel_sdvo_detect(struct drm_connector *connector) |
| 1455 | { | 1513 | { |
| 1456 | u8 response[2]; | 1514 | uint16_t response; |
| 1457 | u8 status; | 1515 | u8 status; |
| 1458 | struct intel_output *intel_output = to_intel_output(connector); | 1516 | struct intel_output *intel_output = to_intel_output(connector); |
| 1517 | struct intel_sdvo_priv *sdvo_priv = intel_output->dev_priv; | ||
| 1459 | 1518 | ||
| 1460 | intel_sdvo_write_cmd(intel_output, SDVO_CMD_GET_ATTACHED_DISPLAYS, NULL, 0); | 1519 | intel_sdvo_write_cmd(intel_output, SDVO_CMD_GET_ATTACHED_DISPLAYS, NULL, 0); |
| 1461 | status = intel_sdvo_read_response(intel_output, &response, 2); | 1520 | status = intel_sdvo_read_response(intel_output, &response, 2); |
| 1462 | 1521 | ||
| 1463 | DRM_DEBUG("SDVO response %d %d\n", response[0], response[1]); | 1522 | DRM_DEBUG("SDVO response %d %d\n", response & 0xff, response >> 8); |
| 1464 | 1523 | ||
| 1465 | if (status != SDVO_CMD_STATUS_SUCCESS) | 1524 | if (status != SDVO_CMD_STATUS_SUCCESS) |
| 1466 | return connector_status_unknown; | 1525 | return connector_status_unknown; |
| 1467 | 1526 | ||
| 1468 | if ((response[0] != 0) || (response[1] != 0)) { | 1527 | if (response == 0) |
| 1469 | intel_sdvo_hdmi_sink_detect(connector); | ||
| 1470 | return connector_status_connected; | ||
| 1471 | } else | ||
| 1472 | return connector_status_disconnected; | 1528 | return connector_status_disconnected; |
| 1529 | |||
| 1530 | if (intel_sdvo_multifunc_encoder(intel_output) && | ||
| 1531 | sdvo_priv->attached_output != response) { | ||
| 1532 | if (sdvo_priv->controlled_output != response && | ||
| 1533 | intel_sdvo_output_setup(intel_output, response) != true) | ||
| 1534 | return connector_status_unknown; | ||
| 1535 | sdvo_priv->attached_output = response; | ||
| 1536 | } | ||
| 1537 | return intel_sdvo_hdmi_sink_detect(connector, response); | ||
| 1473 | } | 1538 | } |
| 1474 | 1539 | ||
| 1475 | static void intel_sdvo_get_ddc_modes(struct drm_connector *connector) | 1540 | static void intel_sdvo_get_ddc_modes(struct drm_connector *connector) |
| @@ -1866,16 +1931,101 @@ intel_sdvo_get_slave_addr(struct drm_device *dev, int output_device) | |||
| 1866 | return 0x72; | 1931 | return 0x72; |
| 1867 | } | 1932 | } |
| 1868 | 1933 | ||
| 1934 | static bool | ||
| 1935 | intel_sdvo_output_setup(struct intel_output *intel_output, uint16_t flags) | ||
| 1936 | { | ||
| 1937 | struct drm_connector *connector = &intel_output->base; | ||
| 1938 | struct drm_encoder *encoder = &intel_output->enc; | ||
| 1939 | struct intel_sdvo_priv *sdvo_priv = intel_output->dev_priv; | ||
| 1940 | bool ret = true, registered = false; | ||
| 1941 | |||
| 1942 | sdvo_priv->is_tv = false; | ||
| 1943 | intel_output->needs_tv_clock = false; | ||
| 1944 | sdvo_priv->is_lvds = false; | ||
| 1945 | |||
| 1946 | if (device_is_registered(&connector->kdev)) { | ||
| 1947 | drm_sysfs_connector_remove(connector); | ||
| 1948 | registered = true; | ||
| 1949 | } | ||
| 1950 | |||
| 1951 | if (flags & | ||
| 1952 | (SDVO_OUTPUT_TMDS0 | SDVO_OUTPUT_TMDS1)) { | ||
| 1953 | if (sdvo_priv->caps.output_flags & SDVO_OUTPUT_TMDS0) | ||
| 1954 | sdvo_priv->controlled_output = SDVO_OUTPUT_TMDS0; | ||
| 1955 | else | ||
| 1956 | sdvo_priv->controlled_output = SDVO_OUTPUT_TMDS1; | ||
| 1957 | |||
| 1958 | encoder->encoder_type = DRM_MODE_ENCODER_TMDS; | ||
| 1959 | connector->connector_type = DRM_MODE_CONNECTOR_DVID; | ||
| 1960 | |||
| 1961 | if (intel_sdvo_get_supp_encode(intel_output, | ||
| 1962 | &sdvo_priv->encode) && | ||
| 1963 | intel_sdvo_get_digital_encoding_mode(intel_output) && | ||
| 1964 | sdvo_priv->is_hdmi) { | ||
| 1965 | /* enable hdmi encoding mode if supported */ | ||
| 1966 | intel_sdvo_set_encode(intel_output, SDVO_ENCODE_HDMI); | ||
| 1967 | intel_sdvo_set_colorimetry(intel_output, | ||
| 1968 | SDVO_COLORIMETRY_RGB256); | ||
| 1969 | connector->connector_type = DRM_MODE_CONNECTOR_HDMIA; | ||
| 1970 | } | ||
| 1971 | } else if (flags & SDVO_OUTPUT_SVID0) { | ||
| 1972 | |||
| 1973 | sdvo_priv->controlled_output = SDVO_OUTPUT_SVID0; | ||
| 1974 | encoder->encoder_type = DRM_MODE_ENCODER_TVDAC; | ||
| 1975 | connector->connector_type = DRM_MODE_CONNECTOR_SVIDEO; | ||
| 1976 | sdvo_priv->is_tv = true; | ||
| 1977 | intel_output->needs_tv_clock = true; | ||
| 1978 | } else if (flags & SDVO_OUTPUT_RGB0) { | ||
| 1979 | |||
| 1980 | sdvo_priv->controlled_output = SDVO_OUTPUT_RGB0; | ||
| 1981 | encoder->encoder_type = DRM_MODE_ENCODER_DAC; | ||
| 1982 | connector->connector_type = DRM_MODE_CONNECTOR_VGA; | ||
| 1983 | } else if (flags & SDVO_OUTPUT_RGB1) { | ||
| 1984 | |||
| 1985 | sdvo_priv->controlled_output = SDVO_OUTPUT_RGB1; | ||
| 1986 | encoder->encoder_type = DRM_MODE_ENCODER_DAC; | ||
| 1987 | connector->connector_type = DRM_MODE_CONNECTOR_VGA; | ||
| 1988 | } else if (flags & SDVO_OUTPUT_LVDS0) { | ||
| 1989 | |||
| 1990 | sdvo_priv->controlled_output = SDVO_OUTPUT_LVDS0; | ||
| 1991 | encoder->encoder_type = DRM_MODE_ENCODER_LVDS; | ||
| 1992 | connector->connector_type = DRM_MODE_CONNECTOR_LVDS; | ||
| 1993 | sdvo_priv->is_lvds = true; | ||
| 1994 | } else if (flags & SDVO_OUTPUT_LVDS1) { | ||
| 1995 | |||
| 1996 | sdvo_priv->controlled_output = SDVO_OUTPUT_LVDS1; | ||
| 1997 | encoder->encoder_type = DRM_MODE_ENCODER_LVDS; | ||
| 1998 | connector->connector_type = DRM_MODE_CONNECTOR_LVDS; | ||
| 1999 | sdvo_priv->is_lvds = true; | ||
| 2000 | } else { | ||
| 2001 | |||
| 2002 | unsigned char bytes[2]; | ||
| 2003 | |||
| 2004 | sdvo_priv->controlled_output = 0; | ||
| 2005 | memcpy(bytes, &sdvo_priv->caps.output_flags, 2); | ||
| 2006 | DRM_DEBUG_KMS(I915_SDVO, | ||
| 2007 | "%s: Unknown SDVO output type (0x%02x%02x)\n", | ||
| 2008 | SDVO_NAME(sdvo_priv), | ||
| 2009 | bytes[0], bytes[1]); | ||
| 2010 | ret = false; | ||
| 2011 | } | ||
| 2012 | |||
| 2013 | if (ret && registered) | ||
| 2014 | ret = drm_sysfs_connector_add(connector) == 0 ? true : false; | ||
| 2015 | |||
| 2016 | |||
| 2017 | return ret; | ||
| 2018 | |||
| 2019 | } | ||
| 2020 | |||
| 1869 | bool intel_sdvo_init(struct drm_device *dev, int output_device) | 2021 | bool intel_sdvo_init(struct drm_device *dev, int output_device) |
| 1870 | { | 2022 | { |
| 1871 | struct drm_connector *connector; | 2023 | struct drm_connector *connector; |
| 1872 | struct intel_output *intel_output; | 2024 | struct intel_output *intel_output; |
| 1873 | struct intel_sdvo_priv *sdvo_priv; | 2025 | struct intel_sdvo_priv *sdvo_priv; |
| 1874 | 2026 | ||
| 1875 | int connector_type; | ||
| 1876 | u8 ch[0x40]; | 2027 | u8 ch[0x40]; |
| 1877 | int i; | 2028 | int i; |
| 1878 | int encoder_type; | ||
| 1879 | 2029 | ||
| 1880 | intel_output = kcalloc(sizeof(struct intel_output)+sizeof(struct intel_sdvo_priv), 1, GFP_KERNEL); | 2030 | intel_output = kcalloc(sizeof(struct intel_output)+sizeof(struct intel_sdvo_priv), 1, GFP_KERNEL); |
| 1881 | if (!intel_output) { | 2031 | if (!intel_output) { |
| @@ -1925,88 +2075,28 @@ bool intel_sdvo_init(struct drm_device *dev, int output_device) | |||
| 1925 | intel_output->ddc_bus->algo = &intel_sdvo_i2c_bit_algo; | 2075 | intel_output->ddc_bus->algo = &intel_sdvo_i2c_bit_algo; |
| 1926 | 2076 | ||
| 1927 | /* In defaut case sdvo lvds is false */ | 2077 | /* In defaut case sdvo lvds is false */ |
| 1928 | sdvo_priv->is_lvds = false; | ||
| 1929 | intel_sdvo_get_capabilities(intel_output, &sdvo_priv->caps); | 2078 | intel_sdvo_get_capabilities(intel_output, &sdvo_priv->caps); |
| 1930 | 2079 | ||
| 1931 | if (sdvo_priv->caps.output_flags & | 2080 | if (intel_sdvo_output_setup(intel_output, |
| 1932 | (SDVO_OUTPUT_TMDS0 | SDVO_OUTPUT_TMDS1)) { | 2081 | sdvo_priv->caps.output_flags) != true) { |
| 1933 | if (sdvo_priv->caps.output_flags & SDVO_OUTPUT_TMDS0) | 2082 | DRM_DEBUG("SDVO output failed to setup on SDVO%c\n", |
| 1934 | sdvo_priv->controlled_output = SDVO_OUTPUT_TMDS0; | 2083 | output_device == SDVOB ? 'B' : 'C'); |
| 1935 | else | ||
| 1936 | sdvo_priv->controlled_output = SDVO_OUTPUT_TMDS1; | ||
| 1937 | |||
| 1938 | encoder_type = DRM_MODE_ENCODER_TMDS; | ||
| 1939 | connector_type = DRM_MODE_CONNECTOR_DVID; | ||
| 1940 | |||
| 1941 | if (intel_sdvo_get_supp_encode(intel_output, | ||
| 1942 | &sdvo_priv->encode) && | ||
| 1943 | intel_sdvo_get_digital_encoding_mode(intel_output) && | ||
| 1944 | sdvo_priv->is_hdmi) { | ||
| 1945 | /* enable hdmi encoding mode if supported */ | ||
| 1946 | intel_sdvo_set_encode(intel_output, SDVO_ENCODE_HDMI); | ||
| 1947 | intel_sdvo_set_colorimetry(intel_output, | ||
| 1948 | SDVO_COLORIMETRY_RGB256); | ||
| 1949 | connector_type = DRM_MODE_CONNECTOR_HDMIA; | ||
| 1950 | } | ||
| 1951 | } | ||
| 1952 | else if (sdvo_priv->caps.output_flags & SDVO_OUTPUT_SVID0) | ||
| 1953 | { | ||
| 1954 | sdvo_priv->controlled_output = SDVO_OUTPUT_SVID0; | ||
| 1955 | encoder_type = DRM_MODE_ENCODER_TVDAC; | ||
| 1956 | connector_type = DRM_MODE_CONNECTOR_SVIDEO; | ||
| 1957 | sdvo_priv->is_tv = true; | ||
| 1958 | intel_output->needs_tv_clock = true; | ||
| 1959 | } | ||
| 1960 | else if (sdvo_priv->caps.output_flags & SDVO_OUTPUT_RGB0) | ||
| 1961 | { | ||
| 1962 | sdvo_priv->controlled_output = SDVO_OUTPUT_RGB0; | ||
| 1963 | encoder_type = DRM_MODE_ENCODER_DAC; | ||
| 1964 | connector_type = DRM_MODE_CONNECTOR_VGA; | ||
| 1965 | } | ||
| 1966 | else if (sdvo_priv->caps.output_flags & SDVO_OUTPUT_RGB1) | ||
| 1967 | { | ||
| 1968 | sdvo_priv->controlled_output = SDVO_OUTPUT_RGB1; | ||
| 1969 | encoder_type = DRM_MODE_ENCODER_DAC; | ||
| 1970 | connector_type = DRM_MODE_CONNECTOR_VGA; | ||
| 1971 | } | ||
| 1972 | else if (sdvo_priv->caps.output_flags & SDVO_OUTPUT_LVDS0) | ||
| 1973 | { | ||
| 1974 | sdvo_priv->controlled_output = SDVO_OUTPUT_LVDS0; | ||
| 1975 | encoder_type = DRM_MODE_ENCODER_LVDS; | ||
| 1976 | connector_type = DRM_MODE_CONNECTOR_LVDS; | ||
| 1977 | sdvo_priv->is_lvds = true; | ||
| 1978 | } | ||
| 1979 | else if (sdvo_priv->caps.output_flags & SDVO_OUTPUT_LVDS1) | ||
| 1980 | { | ||
| 1981 | sdvo_priv->controlled_output = SDVO_OUTPUT_LVDS1; | ||
| 1982 | encoder_type = DRM_MODE_ENCODER_LVDS; | ||
| 1983 | connector_type = DRM_MODE_CONNECTOR_LVDS; | ||
| 1984 | sdvo_priv->is_lvds = true; | ||
| 1985 | } | ||
| 1986 | else | ||
| 1987 | { | ||
| 1988 | unsigned char bytes[2]; | ||
| 1989 | |||
| 1990 | sdvo_priv->controlled_output = 0; | ||
| 1991 | memcpy (bytes, &sdvo_priv->caps.output_flags, 2); | ||
| 1992 | DRM_DEBUG_KMS(I915_SDVO, | ||
| 1993 | "%s: Unknown SDVO output type (0x%02x%02x)\n", | ||
| 1994 | SDVO_NAME(sdvo_priv), | ||
| 1995 | bytes[0], bytes[1]); | ||
| 1996 | encoder_type = DRM_MODE_ENCODER_NONE; | ||
| 1997 | connector_type = DRM_MODE_CONNECTOR_Unknown; | ||
| 1998 | goto err_i2c; | 2084 | goto err_i2c; |
| 1999 | } | 2085 | } |
| 2000 | 2086 | ||
| 2087 | |||
| 2001 | connector = &intel_output->base; | 2088 | connector = &intel_output->base; |
| 2002 | drm_connector_init(dev, connector, &intel_sdvo_connector_funcs, | 2089 | drm_connector_init(dev, connector, &intel_sdvo_connector_funcs, |
| 2003 | connector_type); | 2090 | connector->connector_type); |
| 2091 | |||
| 2004 | drm_connector_helper_add(connector, &intel_sdvo_connector_helper_funcs); | 2092 | drm_connector_helper_add(connector, &intel_sdvo_connector_helper_funcs); |
| 2005 | connector->interlace_allowed = 0; | 2093 | connector->interlace_allowed = 0; |
| 2006 | connector->doublescan_allowed = 0; | 2094 | connector->doublescan_allowed = 0; |
| 2007 | connector->display_info.subpixel_order = SubPixelHorizontalRGB; | 2095 | connector->display_info.subpixel_order = SubPixelHorizontalRGB; |
| 2008 | 2096 | ||
| 2009 | drm_encoder_init(dev, &intel_output->enc, &intel_sdvo_enc_funcs, encoder_type); | 2097 | drm_encoder_init(dev, &intel_output->enc, |
| 2098 | &intel_sdvo_enc_funcs, intel_output->enc.encoder_type); | ||
| 2099 | |||
| 2010 | drm_encoder_helper_add(&intel_output->enc, &intel_sdvo_helper_funcs); | 2100 | drm_encoder_helper_add(&intel_output->enc, &intel_sdvo_helper_funcs); |
| 2011 | 2101 | ||
| 2012 | drm_mode_connector_attach_encoder(&intel_output->base, &intel_output->enc); | 2102 | drm_mode_connector_attach_encoder(&intel_output->base, &intel_output->enc); |
diff --git a/drivers/gpu/drm/i915/intel_tv.c b/drivers/gpu/drm/i915/intel_tv.c index a43c98e3f077..da4ab4dc1630 100644 --- a/drivers/gpu/drm/i915/intel_tv.c +++ b/drivers/gpu/drm/i915/intel_tv.c | |||
| @@ -1490,6 +1490,27 @@ static struct input_res { | |||
| 1490 | {"1920x1080", 1920, 1080}, | 1490 | {"1920x1080", 1920, 1080}, |
| 1491 | }; | 1491 | }; |
| 1492 | 1492 | ||
| 1493 | /* | ||
| 1494 | * Chose preferred mode according to line number of TV format | ||
| 1495 | */ | ||
| 1496 | static void | ||
| 1497 | intel_tv_chose_preferred_modes(struct drm_connector *connector, | ||
| 1498 | struct drm_display_mode *mode_ptr) | ||
| 1499 | { | ||
| 1500 | struct intel_output *intel_output = to_intel_output(connector); | ||
| 1501 | const struct tv_mode *tv_mode = intel_tv_mode_find(intel_output); | ||
| 1502 | |||
| 1503 | if (tv_mode->nbr_end < 480 && mode_ptr->vdisplay == 480) | ||
| 1504 | mode_ptr->type |= DRM_MODE_TYPE_PREFERRED; | ||
| 1505 | else if (tv_mode->nbr_end > 480) { | ||
| 1506 | if (tv_mode->progressive == true && tv_mode->nbr_end < 720) { | ||
| 1507 | if (mode_ptr->vdisplay == 720) | ||
| 1508 | mode_ptr->type |= DRM_MODE_TYPE_PREFERRED; | ||
| 1509 | } else if (mode_ptr->vdisplay == 1080) | ||
| 1510 | mode_ptr->type |= DRM_MODE_TYPE_PREFERRED; | ||
| 1511 | } | ||
| 1512 | } | ||
| 1513 | |||
| 1493 | /** | 1514 | /** |
| 1494 | * Stub get_modes function. | 1515 | * Stub get_modes function. |
| 1495 | * | 1516 | * |
| @@ -1544,6 +1565,7 @@ intel_tv_get_modes(struct drm_connector *connector) | |||
| 1544 | mode_ptr->clock = (int) tmp; | 1565 | mode_ptr->clock = (int) tmp; |
| 1545 | 1566 | ||
| 1546 | mode_ptr->type = DRM_MODE_TYPE_DRIVER; | 1567 | mode_ptr->type = DRM_MODE_TYPE_DRIVER; |
| 1568 | intel_tv_chose_preferred_modes(connector, mode_ptr); | ||
| 1547 | drm_mode_probed_add(connector, mode_ptr); | 1569 | drm_mode_probed_add(connector, mode_ptr); |
| 1548 | count++; | 1570 | count++; |
| 1549 | } | 1571 | } |
diff --git a/drivers/gpu/drm/radeon/Makefile b/drivers/gpu/drm/radeon/Makefile index 5fae1e074b4b..013d38059943 100644 --- a/drivers/gpu/drm/radeon/Makefile +++ b/drivers/gpu/drm/radeon/Makefile | |||
| @@ -13,7 +13,8 @@ radeon-$(CONFIG_DRM_RADEON_KMS) += radeon_device.o radeon_kms.o \ | |||
| 13 | radeon_encoders.o radeon_display.o radeon_cursor.o radeon_i2c.o \ | 13 | radeon_encoders.o radeon_display.o radeon_cursor.o radeon_i2c.o \ |
| 14 | radeon_clocks.o radeon_fb.o radeon_gem.o radeon_ring.o radeon_irq_kms.o \ | 14 | radeon_clocks.o radeon_fb.o radeon_gem.o radeon_ring.o radeon_irq_kms.o \ |
| 15 | radeon_cs.o radeon_bios.o radeon_benchmark.o r100.o r300.o r420.o \ | 15 | radeon_cs.o radeon_bios.o radeon_benchmark.o r100.o r300.o r420.o \ |
| 16 | rs400.o rs600.o rs690.o rv515.o r520.o r600.o rs780.o rv770.o | 16 | rs400.o rs600.o rs690.o rv515.o r520.o r600.o rs780.o rv770.o \ |
| 17 | radeon_test.o | ||
| 17 | 18 | ||
| 18 | radeon-$(CONFIG_COMPAT) += radeon_ioc32.o | 19 | radeon-$(CONFIG_COMPAT) += radeon_ioc32.o |
| 19 | 20 | ||
diff --git a/drivers/gpu/drm/radeon/atombios_crtc.c b/drivers/gpu/drm/radeon/atombios_crtc.c index c0080cc9bf8d..74d034f77c6b 100644 --- a/drivers/gpu/drm/radeon/atombios_crtc.c +++ b/drivers/gpu/drm/radeon/atombios_crtc.c | |||
| @@ -31,6 +31,132 @@ | |||
| 31 | #include "atom.h" | 31 | #include "atom.h" |
| 32 | #include "atom-bits.h" | 32 | #include "atom-bits.h" |
| 33 | 33 | ||
| 34 | static void atombios_overscan_setup(struct drm_crtc *crtc, | ||
| 35 | struct drm_display_mode *mode, | ||
| 36 | struct drm_display_mode *adjusted_mode) | ||
| 37 | { | ||
| 38 | struct drm_device *dev = crtc->dev; | ||
| 39 | struct radeon_device *rdev = dev->dev_private; | ||
| 40 | struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); | ||
| 41 | SET_CRTC_OVERSCAN_PS_ALLOCATION args; | ||
| 42 | int index = GetIndexIntoMasterTable(COMMAND, SetCRTC_OverScan); | ||
| 43 | int a1, a2; | ||
| 44 | |||
| 45 | memset(&args, 0, sizeof(args)); | ||
| 46 | |||
| 47 | args.usOverscanRight = 0; | ||
| 48 | args.usOverscanLeft = 0; | ||
| 49 | args.usOverscanBottom = 0; | ||
| 50 | args.usOverscanTop = 0; | ||
| 51 | args.ucCRTC = radeon_crtc->crtc_id; | ||
| 52 | |||
| 53 | switch (radeon_crtc->rmx_type) { | ||
| 54 | case RMX_CENTER: | ||
| 55 | args.usOverscanTop = (adjusted_mode->crtc_vdisplay - mode->crtc_vdisplay) / 2; | ||
| 56 | args.usOverscanBottom = (adjusted_mode->crtc_vdisplay - mode->crtc_vdisplay) / 2; | ||
| 57 | args.usOverscanLeft = (adjusted_mode->crtc_hdisplay - mode->crtc_hdisplay) / 2; | ||
| 58 | args.usOverscanRight = (adjusted_mode->crtc_hdisplay - mode->crtc_hdisplay) / 2; | ||
| 59 | atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args); | ||
| 60 | break; | ||
| 61 | case RMX_ASPECT: | ||
| 62 | a1 = mode->crtc_vdisplay * adjusted_mode->crtc_hdisplay; | ||
| 63 | a2 = adjusted_mode->crtc_vdisplay * mode->crtc_hdisplay; | ||
| 64 | |||
| 65 | if (a1 > a2) { | ||
| 66 | args.usOverscanLeft = (adjusted_mode->crtc_hdisplay - (a2 / mode->crtc_vdisplay)) / 2; | ||
| 67 | args.usOverscanRight = (adjusted_mode->crtc_hdisplay - (a2 / mode->crtc_vdisplay)) / 2; | ||
| 68 | } else if (a2 > a1) { | ||
| 69 | args.usOverscanLeft = (adjusted_mode->crtc_vdisplay - (a1 / mode->crtc_hdisplay)) / 2; | ||
| 70 | args.usOverscanRight = (adjusted_mode->crtc_vdisplay - (a1 / mode->crtc_hdisplay)) / 2; | ||
| 71 | } | ||
| 72 | atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args); | ||
| 73 | break; | ||
| 74 | case RMX_FULL: | ||
| 75 | default: | ||
| 76 | args.usOverscanRight = 0; | ||
| 77 | args.usOverscanLeft = 0; | ||
| 78 | args.usOverscanBottom = 0; | ||
| 79 | args.usOverscanTop = 0; | ||
| 80 | atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args); | ||
| 81 | break; | ||
| 82 | } | ||
| 83 | } | ||
| 84 | |||
| 85 | static void atombios_scaler_setup(struct drm_crtc *crtc) | ||
| 86 | { | ||
| 87 | struct drm_device *dev = crtc->dev; | ||
| 88 | struct radeon_device *rdev = dev->dev_private; | ||
| 89 | struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); | ||
| 90 | ENABLE_SCALER_PS_ALLOCATION args; | ||
| 91 | int index = GetIndexIntoMasterTable(COMMAND, EnableScaler); | ||
| 92 | /* fixme - fill in enc_priv for atom dac */ | ||
| 93 | enum radeon_tv_std tv_std = TV_STD_NTSC; | ||
| 94 | |||
| 95 | if (!ASIC_IS_AVIVO(rdev) && radeon_crtc->crtc_id) | ||
| 96 | return; | ||
| 97 | |||
| 98 | memset(&args, 0, sizeof(args)); | ||
| 99 | |||
| 100 | args.ucScaler = radeon_crtc->crtc_id; | ||
| 101 | |||
| 102 | if (radeon_crtc->devices & (ATOM_DEVICE_TV_SUPPORT)) { | ||
| 103 | switch (tv_std) { | ||
| 104 | case TV_STD_NTSC: | ||
| 105 | default: | ||
| 106 | args.ucTVStandard = ATOM_TV_NTSC; | ||
| 107 | break; | ||
| 108 | case TV_STD_PAL: | ||
| 109 | args.ucTVStandard = ATOM_TV_PAL; | ||
| 110 | break; | ||
| 111 | case TV_STD_PAL_M: | ||
| 112 | args.ucTVStandard = ATOM_TV_PALM; | ||
| 113 | break; | ||
| 114 | case TV_STD_PAL_60: | ||
| 115 | args.ucTVStandard = ATOM_TV_PAL60; | ||
| 116 | break; | ||
| 117 | case TV_STD_NTSC_J: | ||
| 118 | args.ucTVStandard = ATOM_TV_NTSCJ; | ||
| 119 | break; | ||
| 120 | case TV_STD_SCART_PAL: | ||
| 121 | args.ucTVStandard = ATOM_TV_PAL; /* ??? */ | ||
| 122 | break; | ||
| 123 | case TV_STD_SECAM: | ||
| 124 | args.ucTVStandard = ATOM_TV_SECAM; | ||
| 125 | break; | ||
| 126 | case TV_STD_PAL_CN: | ||
| 127 | args.ucTVStandard = ATOM_TV_PALCN; | ||
| 128 | break; | ||
| 129 | } | ||
| 130 | args.ucEnable = SCALER_ENABLE_MULTITAP_MODE; | ||
| 131 | } else if (radeon_crtc->devices & (ATOM_DEVICE_CV_SUPPORT)) { | ||
| 132 | args.ucTVStandard = ATOM_TV_CV; | ||
| 133 | args.ucEnable = SCALER_ENABLE_MULTITAP_MODE; | ||
| 134 | } else { | ||
| 135 | switch (radeon_crtc->rmx_type) { | ||
| 136 | case RMX_FULL: | ||
| 137 | args.ucEnable = ATOM_SCALER_EXPANSION; | ||
| 138 | break; | ||
| 139 | case RMX_CENTER: | ||
| 140 | args.ucEnable = ATOM_SCALER_CENTER; | ||
| 141 | break; | ||
| 142 | case RMX_ASPECT: | ||
| 143 | args.ucEnable = ATOM_SCALER_EXPANSION; | ||
| 144 | break; | ||
| 145 | default: | ||
| 146 | if (ASIC_IS_AVIVO(rdev)) | ||
| 147 | args.ucEnable = ATOM_SCALER_DISABLE; | ||
| 148 | else | ||
| 149 | args.ucEnable = ATOM_SCALER_CENTER; | ||
| 150 | break; | ||
| 151 | } | ||
| 152 | } | ||
| 153 | atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args); | ||
| 154 | if (radeon_crtc->devices & (ATOM_DEVICE_CV_SUPPORT | ATOM_DEVICE_TV_SUPPORT) | ||
| 155 | && rdev->family >= CHIP_RV515 && rdev->family <= CHIP_RV570) { | ||
| 156 | atom_rv515_force_tv_scaler(rdev); | ||
| 157 | } | ||
| 158 | } | ||
| 159 | |||
| 34 | static void atombios_lock_crtc(struct drm_crtc *crtc, int lock) | 160 | static void atombios_lock_crtc(struct drm_crtc *crtc, int lock) |
| 35 | { | 161 | { |
| 36 | struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); | 162 | struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); |
| @@ -203,6 +329,12 @@ void atombios_crtc_set_pll(struct drm_crtc *crtc, struct drm_display_mode *mode) | |||
| 203 | if (ASIC_IS_AVIVO(rdev)) { | 329 | if (ASIC_IS_AVIVO(rdev)) { |
| 204 | uint32_t ss_cntl; | 330 | uint32_t ss_cntl; |
| 205 | 331 | ||
| 332 | if ((rdev->family == CHIP_RS600) || | ||
| 333 | (rdev->family == CHIP_RS690) || | ||
| 334 | (rdev->family == CHIP_RS740)) | ||
| 335 | pll_flags |= (RADEON_PLL_USE_FRAC_FB_DIV | | ||
| 336 | RADEON_PLL_PREFER_CLOSEST_LOWER); | ||
| 337 | |||
| 206 | if (ASIC_IS_DCE32(rdev) && mode->clock > 200000) /* range limits??? */ | 338 | if (ASIC_IS_DCE32(rdev) && mode->clock > 200000) /* range limits??? */ |
| 207 | pll_flags |= RADEON_PLL_PREFER_HIGH_FB_DIV; | 339 | pll_flags |= RADEON_PLL_PREFER_HIGH_FB_DIV; |
| 208 | else | 340 | else |
| @@ -321,7 +453,7 @@ int atombios_crtc_set_base(struct drm_crtc *crtc, int x, int y, | |||
| 321 | struct drm_gem_object *obj; | 453 | struct drm_gem_object *obj; |
| 322 | struct drm_radeon_gem_object *obj_priv; | 454 | struct drm_radeon_gem_object *obj_priv; |
| 323 | uint64_t fb_location; | 455 | uint64_t fb_location; |
| 324 | uint32_t fb_format, fb_pitch_pixels; | 456 | uint32_t fb_format, fb_pitch_pixels, tiling_flags; |
| 325 | 457 | ||
| 326 | if (!crtc->fb) | 458 | if (!crtc->fb) |
| 327 | return -EINVAL; | 459 | return -EINVAL; |
| @@ -358,7 +490,14 @@ int atombios_crtc_set_base(struct drm_crtc *crtc, int x, int y, | |||
| 358 | return -EINVAL; | 490 | return -EINVAL; |
| 359 | } | 491 | } |
| 360 | 492 | ||
| 361 | /* TODO tiling */ | 493 | radeon_object_get_tiling_flags(obj->driver_private, |
| 494 | &tiling_flags, NULL); | ||
| 495 | if (tiling_flags & RADEON_TILING_MACRO) | ||
| 496 | fb_format |= AVIVO_D1GRPH_MACRO_ADDRESS_MODE; | ||
| 497 | |||
| 498 | if (tiling_flags & RADEON_TILING_MICRO) | ||
| 499 | fb_format |= AVIVO_D1GRPH_TILED; | ||
| 500 | |||
| 362 | if (radeon_crtc->crtc_id == 0) | 501 | if (radeon_crtc->crtc_id == 0) |
| 363 | WREG32(AVIVO_D1VGA_CONTROL, 0); | 502 | WREG32(AVIVO_D1VGA_CONTROL, 0); |
| 364 | else | 503 | else |
| @@ -509,6 +648,9 @@ int atombios_crtc_mode_set(struct drm_crtc *crtc, | |||
| 509 | radeon_crtc_set_base(crtc, x, y, old_fb); | 648 | radeon_crtc_set_base(crtc, x, y, old_fb); |
| 510 | radeon_legacy_atom_set_surface(crtc); | 649 | radeon_legacy_atom_set_surface(crtc); |
| 511 | } | 650 | } |
| 651 | atombios_overscan_setup(crtc, mode, adjusted_mode); | ||
| 652 | atombios_scaler_setup(crtc); | ||
| 653 | radeon_bandwidth_update(rdev); | ||
| 512 | return 0; | 654 | return 0; |
| 513 | } | 655 | } |
| 514 | 656 | ||
| @@ -516,6 +658,8 @@ static bool atombios_crtc_mode_fixup(struct drm_crtc *crtc, | |||
| 516 | struct drm_display_mode *mode, | 658 | struct drm_display_mode *mode, |
| 517 | struct drm_display_mode *adjusted_mode) | 659 | struct drm_display_mode *adjusted_mode) |
| 518 | { | 660 | { |
| 661 | if (!radeon_crtc_scaling_mode_fixup(crtc, mode, adjusted_mode)) | ||
| 662 | return false; | ||
| 519 | return true; | 663 | return true; |
| 520 | } | 664 | } |
| 521 | 665 | ||
| @@ -548,148 +692,3 @@ void radeon_atombios_init_crtc(struct drm_device *dev, | |||
| 548 | AVIVO_D2CRTC_H_TOTAL - AVIVO_D1CRTC_H_TOTAL; | 692 | AVIVO_D2CRTC_H_TOTAL - AVIVO_D1CRTC_H_TOTAL; |
| 549 | drm_crtc_helper_add(&radeon_crtc->base, &atombios_helper_funcs); | 693 | drm_crtc_helper_add(&radeon_crtc->base, &atombios_helper_funcs); |
| 550 | } | 694 | } |
| 551 | |||
| 552 | void radeon_init_disp_bw_avivo(struct drm_device *dev, | ||
| 553 | struct drm_display_mode *mode1, | ||
| 554 | uint32_t pixel_bytes1, | ||
| 555 | struct drm_display_mode *mode2, | ||
| 556 | uint32_t pixel_bytes2) | ||
| 557 | { | ||
| 558 | struct radeon_device *rdev = dev->dev_private; | ||
| 559 | fixed20_12 min_mem_eff; | ||
| 560 | fixed20_12 peak_disp_bw, mem_bw, pix_clk, pix_clk2, temp_ff; | ||
| 561 | fixed20_12 sclk_ff, mclk_ff; | ||
| 562 | uint32_t dc_lb_memory_split, temp; | ||
| 563 | |||
| 564 | min_mem_eff.full = rfixed_const_8(0); | ||
| 565 | if (rdev->disp_priority == 2) { | ||
| 566 | uint32_t mc_init_misc_lat_timer = 0; | ||
| 567 | if (rdev->family == CHIP_RV515) | ||
| 568 | mc_init_misc_lat_timer = | ||
| 569 | RREG32_MC(RV515_MC_INIT_MISC_LAT_TIMER); | ||
| 570 | else if (rdev->family == CHIP_RS690) | ||
| 571 | mc_init_misc_lat_timer = | ||
| 572 | RREG32_MC(RS690_MC_INIT_MISC_LAT_TIMER); | ||
| 573 | |||
| 574 | mc_init_misc_lat_timer &= | ||
| 575 | ~(R300_MC_DISP1R_INIT_LAT_MASK << | ||
| 576 | R300_MC_DISP1R_INIT_LAT_SHIFT); | ||
| 577 | mc_init_misc_lat_timer &= | ||
| 578 | ~(R300_MC_DISP0R_INIT_LAT_MASK << | ||
| 579 | R300_MC_DISP0R_INIT_LAT_SHIFT); | ||
| 580 | |||
| 581 | if (mode2) | ||
| 582 | mc_init_misc_lat_timer |= | ||
| 583 | (1 << R300_MC_DISP1R_INIT_LAT_SHIFT); | ||
| 584 | if (mode1) | ||
| 585 | mc_init_misc_lat_timer |= | ||
| 586 | (1 << R300_MC_DISP0R_INIT_LAT_SHIFT); | ||
| 587 | |||
| 588 | if (rdev->family == CHIP_RV515) | ||
| 589 | WREG32_MC(RV515_MC_INIT_MISC_LAT_TIMER, | ||
| 590 | mc_init_misc_lat_timer); | ||
| 591 | else if (rdev->family == CHIP_RS690) | ||
| 592 | WREG32_MC(RS690_MC_INIT_MISC_LAT_TIMER, | ||
| 593 | mc_init_misc_lat_timer); | ||
| 594 | } | ||
| 595 | |||
| 596 | /* | ||
| 597 | * determine is there is enough bw for current mode | ||
| 598 | */ | ||
| 599 | temp_ff.full = rfixed_const(100); | ||
| 600 | mclk_ff.full = rfixed_const(rdev->clock.default_mclk); | ||
| 601 | mclk_ff.full = rfixed_div(mclk_ff, temp_ff); | ||
| 602 | sclk_ff.full = rfixed_const(rdev->clock.default_sclk); | ||
| 603 | sclk_ff.full = rfixed_div(sclk_ff, temp_ff); | ||
| 604 | |||
| 605 | temp = (rdev->mc.vram_width / 8) * (rdev->mc.vram_is_ddr ? 2 : 1); | ||
| 606 | temp_ff.full = rfixed_const(temp); | ||
| 607 | mem_bw.full = rfixed_mul(mclk_ff, temp_ff); | ||
| 608 | mem_bw.full = rfixed_mul(mem_bw, min_mem_eff); | ||
| 609 | |||
| 610 | pix_clk.full = 0; | ||
| 611 | pix_clk2.full = 0; | ||
| 612 | peak_disp_bw.full = 0; | ||
| 613 | if (mode1) { | ||
| 614 | temp_ff.full = rfixed_const(1000); | ||
| 615 | pix_clk.full = rfixed_const(mode1->clock); /* convert to fixed point */ | ||
| 616 | pix_clk.full = rfixed_div(pix_clk, temp_ff); | ||
| 617 | temp_ff.full = rfixed_const(pixel_bytes1); | ||
| 618 | peak_disp_bw.full += rfixed_mul(pix_clk, temp_ff); | ||
| 619 | } | ||
| 620 | if (mode2) { | ||
| 621 | temp_ff.full = rfixed_const(1000); | ||
| 622 | pix_clk2.full = rfixed_const(mode2->clock); /* convert to fixed point */ | ||
| 623 | pix_clk2.full = rfixed_div(pix_clk2, temp_ff); | ||
| 624 | temp_ff.full = rfixed_const(pixel_bytes2); | ||
| 625 | peak_disp_bw.full += rfixed_mul(pix_clk2, temp_ff); | ||
| 626 | } | ||
| 627 | |||
| 628 | if (peak_disp_bw.full >= mem_bw.full) { | ||
| 629 | DRM_ERROR | ||
| 630 | ("You may not have enough display bandwidth for current mode\n" | ||
| 631 | "If you have flickering problem, try to lower resolution, refresh rate, or color depth\n"); | ||
| 632 | printk("peak disp bw %d, mem_bw %d\n", | ||
| 633 | rfixed_trunc(peak_disp_bw), rfixed_trunc(mem_bw)); | ||
| 634 | } | ||
| 635 | |||
| 636 | /* | ||
| 637 | * Line Buffer Setup | ||
| 638 | * There is a single line buffer shared by both display controllers. | ||
| 639 | * DC_LB_MEMORY_SPLIT controls how that line buffer is shared between the display | ||
| 640 | * controllers. The paritioning can either be done manually or via one of four | ||
| 641 | * preset allocations specified in bits 1:0: | ||
| 642 | * 0 - line buffer is divided in half and shared between each display controller | ||
| 643 | * 1 - D1 gets 3/4 of the line buffer, D2 gets 1/4 | ||
| 644 | * 2 - D1 gets the whole buffer | ||
| 645 | * 3 - D1 gets 1/4 of the line buffer, D2 gets 3/4 | ||
| 646 | * Setting bit 2 of DC_LB_MEMORY_SPLIT controls switches to manual allocation mode. | ||
| 647 | * In manual allocation mode, D1 always starts at 0, D1 end/2 is specified in bits | ||
| 648 | * 14:4; D2 allocation follows D1. | ||
| 649 | */ | ||
| 650 | |||
| 651 | /* is auto or manual better ? */ | ||
| 652 | dc_lb_memory_split = | ||
| 653 | RREG32(AVIVO_DC_LB_MEMORY_SPLIT) & ~AVIVO_DC_LB_MEMORY_SPLIT_MASK; | ||
| 654 | dc_lb_memory_split &= ~AVIVO_DC_LB_MEMORY_SPLIT_SHIFT_MODE; | ||
| 655 | #if 1 | ||
| 656 | /* auto */ | ||
| 657 | if (mode1 && mode2) { | ||
| 658 | if (mode1->hdisplay > mode2->hdisplay) { | ||
| 659 | if (mode1->hdisplay > 2560) | ||
| 660 | dc_lb_memory_split |= | ||
| 661 | AVIVO_DC_LB_MEMORY_SPLIT_D1_3Q_D2_1Q; | ||
| 662 | else | ||
| 663 | dc_lb_memory_split |= | ||
| 664 | AVIVO_DC_LB_MEMORY_SPLIT_D1HALF_D2HALF; | ||
| 665 | } else if (mode2->hdisplay > mode1->hdisplay) { | ||
| 666 | if (mode2->hdisplay > 2560) | ||
| 667 | dc_lb_memory_split |= | ||
| 668 | AVIVO_DC_LB_MEMORY_SPLIT_D1_1Q_D2_3Q; | ||
| 669 | else | ||
| 670 | dc_lb_memory_split |= | ||
| 671 | AVIVO_DC_LB_MEMORY_SPLIT_D1HALF_D2HALF; | ||
| 672 | } else | ||
| 673 | dc_lb_memory_split |= | ||
| 674 | AVIVO_DC_LB_MEMORY_SPLIT_D1HALF_D2HALF; | ||
| 675 | } else if (mode1) { | ||
| 676 | dc_lb_memory_split |= AVIVO_DC_LB_MEMORY_SPLIT_D1_ONLY; | ||
| 677 | } else if (mode2) { | ||
| 678 | dc_lb_memory_split |= AVIVO_DC_LB_MEMORY_SPLIT_D1_1Q_D2_3Q; | ||
| 679 | } | ||
| 680 | #else | ||
| 681 | /* manual */ | ||
| 682 | dc_lb_memory_split |= AVIVO_DC_LB_MEMORY_SPLIT_SHIFT_MODE; | ||
| 683 | dc_lb_memory_split &= | ||
| 684 | ~(AVIVO_DC_LB_DISP1_END_ADR_MASK << | ||
| 685 | AVIVO_DC_LB_DISP1_END_ADR_SHIFT); | ||
| 686 | if (mode1) { | ||
| 687 | dc_lb_memory_split |= | ||
| 688 | ((((mode1->hdisplay / 2) + 64) & AVIVO_DC_LB_DISP1_END_ADR_MASK) | ||
| 689 | << AVIVO_DC_LB_DISP1_END_ADR_SHIFT); | ||
| 690 | } else if (mode2) { | ||
| 691 | dc_lb_memory_split |= (0 << AVIVO_DC_LB_DISP1_END_ADR_SHIFT); | ||
| 692 | } | ||
| 693 | #endif | ||
| 694 | WREG32(AVIVO_DC_LB_MEMORY_SPLIT, dc_lb_memory_split); | ||
| 695 | } | ||
diff --git a/drivers/gpu/drm/radeon/r100.c b/drivers/gpu/drm/radeon/r100.c index c550932a108f..68e728e8be4d 100644 --- a/drivers/gpu/drm/radeon/r100.c +++ b/drivers/gpu/drm/radeon/r100.c | |||
| @@ -110,7 +110,7 @@ int r100_pci_gart_set_page(struct radeon_device *rdev, int i, uint64_t addr) | |||
| 110 | if (i < 0 || i > rdev->gart.num_gpu_pages) { | 110 | if (i < 0 || i > rdev->gart.num_gpu_pages) { |
| 111 | return -EINVAL; | 111 | return -EINVAL; |
| 112 | } | 112 | } |
| 113 | rdev->gart.table.ram.ptr[i] = cpu_to_le32((uint32_t)addr); | 113 | rdev->gart.table.ram.ptr[i] = cpu_to_le32(lower_32_bits(addr)); |
| 114 | return 0; | 114 | return 0; |
| 115 | } | 115 | } |
| 116 | 116 | ||
| @@ -173,8 +173,12 @@ void r100_mc_setup(struct radeon_device *rdev) | |||
| 173 | DRM_ERROR("Failed to register debugfs file for R100 MC !\n"); | 173 | DRM_ERROR("Failed to register debugfs file for R100 MC !\n"); |
| 174 | } | 174 | } |
| 175 | /* Write VRAM size in case we are limiting it */ | 175 | /* Write VRAM size in case we are limiting it */ |
| 176 | WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.vram_size); | 176 | WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.real_vram_size); |
| 177 | tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; | 177 | /* Novell bug 204882 for RN50/M6/M7 with 8/16/32MB VRAM, |
| 178 | * if the aperture is 64MB but we have 32MB VRAM | ||
| 179 | * we report only 32MB VRAM but we have to set MC_FB_LOCATION | ||
| 180 | * to 64MB, otherwise the gpu accidentially dies */ | ||
| 181 | tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1; | ||
| 178 | tmp = REG_SET(RADEON_MC_FB_TOP, tmp >> 16); | 182 | tmp = REG_SET(RADEON_MC_FB_TOP, tmp >> 16); |
| 179 | tmp |= REG_SET(RADEON_MC_FB_START, rdev->mc.vram_location >> 16); | 183 | tmp |= REG_SET(RADEON_MC_FB_START, rdev->mc.vram_location >> 16); |
| 180 | WREG32(RADEON_MC_FB_LOCATION, tmp); | 184 | WREG32(RADEON_MC_FB_LOCATION, tmp); |
| @@ -215,7 +219,6 @@ int r100_mc_init(struct radeon_device *rdev) | |||
| 215 | r100_pci_gart_disable(rdev); | 219 | r100_pci_gart_disable(rdev); |
| 216 | 220 | ||
| 217 | /* Setup GPU memory space */ | 221 | /* Setup GPU memory space */ |
| 218 | rdev->mc.vram_location = 0xFFFFFFFFUL; | ||
| 219 | rdev->mc.gtt_location = 0xFFFFFFFFUL; | 222 | rdev->mc.gtt_location = 0xFFFFFFFFUL; |
| 220 | if (rdev->flags & RADEON_IS_AGP) { | 223 | if (rdev->flags & RADEON_IS_AGP) { |
| 221 | r = radeon_agp_init(rdev); | 224 | r = radeon_agp_init(rdev); |
| @@ -251,6 +254,72 @@ void r100_mc_fini(struct radeon_device *rdev) | |||
| 251 | 254 | ||
| 252 | 255 | ||
| 253 | /* | 256 | /* |
| 257 | * Interrupts | ||
| 258 | */ | ||
| 259 | int r100_irq_set(struct radeon_device *rdev) | ||
| 260 | { | ||
| 261 | uint32_t tmp = 0; | ||
| 262 | |||
| 263 | if (rdev->irq.sw_int) { | ||
| 264 | tmp |= RADEON_SW_INT_ENABLE; | ||
| 265 | } | ||
| 266 | if (rdev->irq.crtc_vblank_int[0]) { | ||
| 267 | tmp |= RADEON_CRTC_VBLANK_MASK; | ||
| 268 | } | ||
| 269 | if (rdev->irq.crtc_vblank_int[1]) { | ||
| 270 | tmp |= RADEON_CRTC2_VBLANK_MASK; | ||
| 271 | } | ||
| 272 | WREG32(RADEON_GEN_INT_CNTL, tmp); | ||
| 273 | return 0; | ||
| 274 | } | ||
| 275 | |||
| 276 | static inline uint32_t r100_irq_ack(struct radeon_device *rdev) | ||
| 277 | { | ||
| 278 | uint32_t irqs = RREG32(RADEON_GEN_INT_STATUS); | ||
| 279 | uint32_t irq_mask = RADEON_SW_INT_TEST | RADEON_CRTC_VBLANK_STAT | | ||
| 280 | RADEON_CRTC2_VBLANK_STAT; | ||
| 281 | |||
| 282 | if (irqs) { | ||
| 283 | WREG32(RADEON_GEN_INT_STATUS, irqs); | ||
| 284 | } | ||
| 285 | return irqs & irq_mask; | ||
| 286 | } | ||
| 287 | |||
| 288 | int r100_irq_process(struct radeon_device *rdev) | ||
| 289 | { | ||
| 290 | uint32_t status; | ||
| 291 | |||
| 292 | status = r100_irq_ack(rdev); | ||
| 293 | if (!status) { | ||
| 294 | return IRQ_NONE; | ||
| 295 | } | ||
| 296 | while (status) { | ||
| 297 | /* SW interrupt */ | ||
| 298 | if (status & RADEON_SW_INT_TEST) { | ||
| 299 | radeon_fence_process(rdev); | ||
| 300 | } | ||
| 301 | /* Vertical blank interrupts */ | ||
| 302 | if (status & RADEON_CRTC_VBLANK_STAT) { | ||
| 303 | drm_handle_vblank(rdev->ddev, 0); | ||
| 304 | } | ||
| 305 | if (status & RADEON_CRTC2_VBLANK_STAT) { | ||
| 306 | drm_handle_vblank(rdev->ddev, 1); | ||
| 307 | } | ||
| 308 | status = r100_irq_ack(rdev); | ||
| 309 | } | ||
| 310 | return IRQ_HANDLED; | ||
| 311 | } | ||
| 312 | |||
| 313 | u32 r100_get_vblank_counter(struct radeon_device *rdev, int crtc) | ||
| 314 | { | ||
| 315 | if (crtc == 0) | ||
| 316 | return RREG32(RADEON_CRTC_CRNT_FRAME); | ||
| 317 | else | ||
| 318 | return RREG32(RADEON_CRTC2_CRNT_FRAME); | ||
| 319 | } | ||
| 320 | |||
| 321 | |||
| 322 | /* | ||
| 254 | * Fence emission | 323 | * Fence emission |
| 255 | */ | 324 | */ |
| 256 | void r100_fence_ring_emit(struct radeon_device *rdev, | 325 | void r100_fence_ring_emit(struct radeon_device *rdev, |
| @@ -719,13 +788,14 @@ int r100_cs_packet_parse(struct radeon_cs_parser *p, | |||
| 719 | unsigned idx) | 788 | unsigned idx) |
| 720 | { | 789 | { |
| 721 | struct radeon_cs_chunk *ib_chunk = &p->chunks[p->chunk_ib_idx]; | 790 | struct radeon_cs_chunk *ib_chunk = &p->chunks[p->chunk_ib_idx]; |
| 722 | uint32_t header = ib_chunk->kdata[idx]; | 791 | uint32_t header; |
| 723 | 792 | ||
| 724 | if (idx >= ib_chunk->length_dw) { | 793 | if (idx >= ib_chunk->length_dw) { |
| 725 | DRM_ERROR("Can not parse packet at %d after CS end %d !\n", | 794 | DRM_ERROR("Can not parse packet at %d after CS end %d !\n", |
| 726 | idx, ib_chunk->length_dw); | 795 | idx, ib_chunk->length_dw); |
| 727 | return -EINVAL; | 796 | return -EINVAL; |
| 728 | } | 797 | } |
| 798 | header = ib_chunk->kdata[idx]; | ||
| 729 | pkt->idx = idx; | 799 | pkt->idx = idx; |
| 730 | pkt->type = CP_PACKET_GET_TYPE(header); | 800 | pkt->type = CP_PACKET_GET_TYPE(header); |
| 731 | pkt->count = CP_PACKET_GET_COUNT(header); | 801 | pkt->count = CP_PACKET_GET_COUNT(header); |
| @@ -753,6 +823,102 @@ int r100_cs_packet_parse(struct radeon_cs_parser *p, | |||
| 753 | } | 823 | } |
| 754 | 824 | ||
| 755 | /** | 825 | /** |
| 826 | * r100_cs_packet_next_vline() - parse userspace VLINE packet | ||
| 827 | * @parser: parser structure holding parsing context. | ||
| 828 | * | ||
| 829 | * Userspace sends a special sequence for VLINE waits. | ||
| 830 | * PACKET0 - VLINE_START_END + value | ||
| 831 | * PACKET0 - WAIT_UNTIL +_value | ||
| 832 | * RELOC (P3) - crtc_id in reloc. | ||
| 833 | * | ||
| 834 | * This function parses this and relocates the VLINE START END | ||
| 835 | * and WAIT UNTIL packets to the correct crtc. | ||
| 836 | * It also detects a switched off crtc and nulls out the | ||
| 837 | * wait in that case. | ||
| 838 | */ | ||
| 839 | int r100_cs_packet_parse_vline(struct radeon_cs_parser *p) | ||
| 840 | { | ||
| 841 | struct radeon_cs_chunk *ib_chunk; | ||
| 842 | struct drm_mode_object *obj; | ||
| 843 | struct drm_crtc *crtc; | ||
| 844 | struct radeon_crtc *radeon_crtc; | ||
| 845 | struct radeon_cs_packet p3reloc, waitreloc; | ||
| 846 | int crtc_id; | ||
| 847 | int r; | ||
| 848 | uint32_t header, h_idx, reg; | ||
| 849 | |||
| 850 | ib_chunk = &p->chunks[p->chunk_ib_idx]; | ||
| 851 | |||
| 852 | /* parse the wait until */ | ||
| 853 | r = r100_cs_packet_parse(p, &waitreloc, p->idx); | ||
| 854 | if (r) | ||
| 855 | return r; | ||
| 856 | |||
| 857 | /* check its a wait until and only 1 count */ | ||
| 858 | if (waitreloc.reg != RADEON_WAIT_UNTIL || | ||
| 859 | waitreloc.count != 0) { | ||
| 860 | DRM_ERROR("vline wait had illegal wait until segment\n"); | ||
| 861 | r = -EINVAL; | ||
| 862 | return r; | ||
| 863 | } | ||
| 864 | |||
| 865 | if (ib_chunk->kdata[waitreloc.idx + 1] != RADEON_WAIT_CRTC_VLINE) { | ||
| 866 | DRM_ERROR("vline wait had illegal wait until\n"); | ||
| 867 | r = -EINVAL; | ||
| 868 | return r; | ||
| 869 | } | ||
| 870 | |||
| 871 | /* jump over the NOP */ | ||
| 872 | r = r100_cs_packet_parse(p, &p3reloc, p->idx); | ||
| 873 | if (r) | ||
| 874 | return r; | ||
| 875 | |||
| 876 | h_idx = p->idx - 2; | ||
| 877 | p->idx += waitreloc.count; | ||
| 878 | p->idx += p3reloc.count; | ||
| 879 | |||
| 880 | header = ib_chunk->kdata[h_idx]; | ||
| 881 | crtc_id = ib_chunk->kdata[h_idx + 5]; | ||
| 882 | reg = ib_chunk->kdata[h_idx] >> 2; | ||
| 883 | mutex_lock(&p->rdev->ddev->mode_config.mutex); | ||
| 884 | obj = drm_mode_object_find(p->rdev->ddev, crtc_id, DRM_MODE_OBJECT_CRTC); | ||
| 885 | if (!obj) { | ||
| 886 | DRM_ERROR("cannot find crtc %d\n", crtc_id); | ||
| 887 | r = -EINVAL; | ||
| 888 | goto out; | ||
| 889 | } | ||
| 890 | crtc = obj_to_crtc(obj); | ||
| 891 | radeon_crtc = to_radeon_crtc(crtc); | ||
| 892 | crtc_id = radeon_crtc->crtc_id; | ||
| 893 | |||
| 894 | if (!crtc->enabled) { | ||
| 895 | /* if the CRTC isn't enabled - we need to nop out the wait until */ | ||
| 896 | ib_chunk->kdata[h_idx + 2] = PACKET2(0); | ||
| 897 | ib_chunk->kdata[h_idx + 3] = PACKET2(0); | ||
| 898 | } else if (crtc_id == 1) { | ||
| 899 | switch (reg) { | ||
| 900 | case AVIVO_D1MODE_VLINE_START_END: | ||
| 901 | header &= R300_CP_PACKET0_REG_MASK; | ||
| 902 | header |= AVIVO_D2MODE_VLINE_START_END >> 2; | ||
| 903 | break; | ||
| 904 | case RADEON_CRTC_GUI_TRIG_VLINE: | ||
| 905 | header &= R300_CP_PACKET0_REG_MASK; | ||
| 906 | header |= RADEON_CRTC2_GUI_TRIG_VLINE >> 2; | ||
| 907 | break; | ||
| 908 | default: | ||
| 909 | DRM_ERROR("unknown crtc reloc\n"); | ||
| 910 | r = -EINVAL; | ||
| 911 | goto out; | ||
| 912 | } | ||
| 913 | ib_chunk->kdata[h_idx] = header; | ||
| 914 | ib_chunk->kdata[h_idx + 3] |= RADEON_ENG_DISPLAY_SELECT_CRTC1; | ||
| 915 | } | ||
| 916 | out: | ||
| 917 | mutex_unlock(&p->rdev->ddev->mode_config.mutex); | ||
| 918 | return r; | ||
| 919 | } | ||
| 920 | |||
| 921 | /** | ||
| 756 | * r100_cs_packet_next_reloc() - parse next packet which should be reloc packet3 | 922 | * r100_cs_packet_next_reloc() - parse next packet which should be reloc packet3 |
| 757 | * @parser: parser structure holding parsing context. | 923 | * @parser: parser structure holding parsing context. |
| 758 | * @data: pointer to relocation data | 924 | * @data: pointer to relocation data |
| @@ -814,6 +980,7 @@ static int r100_packet0_check(struct radeon_cs_parser *p, | |||
| 814 | unsigned idx; | 980 | unsigned idx; |
| 815 | bool onereg; | 981 | bool onereg; |
| 816 | int r; | 982 | int r; |
| 983 | u32 tile_flags = 0; | ||
| 817 | 984 | ||
| 818 | ib = p->ib->ptr; | 985 | ib = p->ib->ptr; |
| 819 | ib_chunk = &p->chunks[p->chunk_ib_idx]; | 986 | ib_chunk = &p->chunks[p->chunk_ib_idx]; |
| @@ -825,6 +992,15 @@ static int r100_packet0_check(struct radeon_cs_parser *p, | |||
| 825 | } | 992 | } |
| 826 | for (i = 0; i <= pkt->count; i++, idx++, reg += 4) { | 993 | for (i = 0; i <= pkt->count; i++, idx++, reg += 4) { |
| 827 | switch (reg) { | 994 | switch (reg) { |
| 995 | case RADEON_CRTC_GUI_TRIG_VLINE: | ||
| 996 | r = r100_cs_packet_parse_vline(p); | ||
| 997 | if (r) { | ||
| 998 | DRM_ERROR("No reloc for ib[%d]=0x%04X\n", | ||
| 999 | idx, reg); | ||
| 1000 | r100_cs_dump_packet(p, pkt); | ||
| 1001 | return r; | ||
| 1002 | } | ||
| 1003 | break; | ||
| 828 | /* FIXME: only allow PACKET3 blit? easier to check for out of | 1004 | /* FIXME: only allow PACKET3 blit? easier to check for out of |
| 829 | * range access */ | 1005 | * range access */ |
| 830 | case RADEON_DST_PITCH_OFFSET: | 1006 | case RADEON_DST_PITCH_OFFSET: |
| @@ -838,7 +1014,20 @@ static int r100_packet0_check(struct radeon_cs_parser *p, | |||
| 838 | } | 1014 | } |
| 839 | tmp = ib_chunk->kdata[idx] & 0x003fffff; | 1015 | tmp = ib_chunk->kdata[idx] & 0x003fffff; |
| 840 | tmp += (((u32)reloc->lobj.gpu_offset) >> 10); | 1016 | tmp += (((u32)reloc->lobj.gpu_offset) >> 10); |
| 841 | ib[idx] = (ib_chunk->kdata[idx] & 0xffc00000) | tmp; | 1017 | |
| 1018 | if (reloc->lobj.tiling_flags & RADEON_TILING_MACRO) | ||
| 1019 | tile_flags |= RADEON_DST_TILE_MACRO; | ||
| 1020 | if (reloc->lobj.tiling_flags & RADEON_TILING_MICRO) { | ||
| 1021 | if (reg == RADEON_SRC_PITCH_OFFSET) { | ||
| 1022 | DRM_ERROR("Cannot src blit from microtiled surface\n"); | ||
| 1023 | r100_cs_dump_packet(p, pkt); | ||
| 1024 | return -EINVAL; | ||
| 1025 | } | ||
| 1026 | tile_flags |= RADEON_DST_TILE_MICRO; | ||
| 1027 | } | ||
| 1028 | |||
| 1029 | tmp |= tile_flags; | ||
| 1030 | ib[idx] = (ib_chunk->kdata[idx] & 0x3fc00000) | tmp; | ||
| 842 | break; | 1031 | break; |
| 843 | case RADEON_RB3D_DEPTHOFFSET: | 1032 | case RADEON_RB3D_DEPTHOFFSET: |
| 844 | case RADEON_RB3D_COLOROFFSET: | 1033 | case RADEON_RB3D_COLOROFFSET: |
| @@ -869,6 +1058,40 @@ static int r100_packet0_check(struct radeon_cs_parser *p, | |||
| 869 | case R300_TX_OFFSET_0+52: | 1058 | case R300_TX_OFFSET_0+52: |
| 870 | case R300_TX_OFFSET_0+56: | 1059 | case R300_TX_OFFSET_0+56: |
| 871 | case R300_TX_OFFSET_0+60: | 1060 | case R300_TX_OFFSET_0+60: |
| 1061 | /* rn50 has no 3D engine so fail on any 3d setup */ | ||
| 1062 | if (ASIC_IS_RN50(p->rdev)) { | ||
| 1063 | DRM_ERROR("attempt to use RN50 3D engine failed\n"); | ||
| 1064 | return -EINVAL; | ||
| 1065 | } | ||
| 1066 | r = r100_cs_packet_next_reloc(p, &reloc); | ||
| 1067 | if (r) { | ||
| 1068 | DRM_ERROR("No reloc for ib[%d]=0x%04X\n", | ||
| 1069 | idx, reg); | ||
| 1070 | r100_cs_dump_packet(p, pkt); | ||
| 1071 | return r; | ||
| 1072 | } | ||
| 1073 | ib[idx] = ib_chunk->kdata[idx] + ((u32)reloc->lobj.gpu_offset); | ||
| 1074 | break; | ||
| 1075 | case R300_RB3D_COLORPITCH0: | ||
| 1076 | case RADEON_RB3D_COLORPITCH: | ||
| 1077 | r = r100_cs_packet_next_reloc(p, &reloc); | ||
| 1078 | if (r) { | ||
| 1079 | DRM_ERROR("No reloc for ib[%d]=0x%04X\n", | ||
| 1080 | idx, reg); | ||
| 1081 | r100_cs_dump_packet(p, pkt); | ||
| 1082 | return r; | ||
| 1083 | } | ||
| 1084 | |||
| 1085 | if (reloc->lobj.tiling_flags & RADEON_TILING_MACRO) | ||
| 1086 | tile_flags |= RADEON_COLOR_TILE_ENABLE; | ||
| 1087 | if (reloc->lobj.tiling_flags & RADEON_TILING_MICRO) | ||
| 1088 | tile_flags |= RADEON_COLOR_MICROTILE_ENABLE; | ||
| 1089 | |||
| 1090 | tmp = ib_chunk->kdata[idx] & ~(0x7 << 16); | ||
| 1091 | tmp |= tile_flags; | ||
| 1092 | ib[idx] = tmp; | ||
| 1093 | break; | ||
| 1094 | case RADEON_RB3D_ZPASS_ADDR: | ||
| 872 | r = r100_cs_packet_next_reloc(p, &reloc); | 1095 | r = r100_cs_packet_next_reloc(p, &reloc); |
| 873 | if (r) { | 1096 | if (r) { |
| 874 | DRM_ERROR("No reloc for ib[%d]=0x%04X\n", | 1097 | DRM_ERROR("No reloc for ib[%d]=0x%04X\n", |
| @@ -1256,29 +1479,100 @@ static void r100_vram_get_type(struct radeon_device *rdev) | |||
| 1256 | } | 1479 | } |
| 1257 | } | 1480 | } |
| 1258 | 1481 | ||
| 1259 | void r100_vram_info(struct radeon_device *rdev) | 1482 | static u32 r100_get_accessible_vram(struct radeon_device *rdev) |
| 1260 | { | 1483 | { |
| 1261 | r100_vram_get_type(rdev); | 1484 | u32 aper_size; |
| 1485 | u8 byte; | ||
| 1486 | |||
| 1487 | aper_size = RREG32(RADEON_CONFIG_APER_SIZE); | ||
| 1488 | |||
| 1489 | /* Set HDP_APER_CNTL only on cards that are known not to be broken, | ||
| 1490 | * that is has the 2nd generation multifunction PCI interface | ||
| 1491 | */ | ||
| 1492 | if (rdev->family == CHIP_RV280 || | ||
| 1493 | rdev->family >= CHIP_RV350) { | ||
| 1494 | WREG32_P(RADEON_HOST_PATH_CNTL, RADEON_HDP_APER_CNTL, | ||
| 1495 | ~RADEON_HDP_APER_CNTL); | ||
| 1496 | DRM_INFO("Generation 2 PCI interface, using max accessible memory\n"); | ||
| 1497 | return aper_size * 2; | ||
| 1498 | } | ||
| 1499 | |||
| 1500 | /* Older cards have all sorts of funny issues to deal with. First | ||
| 1501 | * check if it's a multifunction card by reading the PCI config | ||
| 1502 | * header type... Limit those to one aperture size | ||
| 1503 | */ | ||
| 1504 | pci_read_config_byte(rdev->pdev, 0xe, &byte); | ||
| 1505 | if (byte & 0x80) { | ||
| 1506 | DRM_INFO("Generation 1 PCI interface in multifunction mode\n"); | ||
| 1507 | DRM_INFO("Limiting VRAM to one aperture\n"); | ||
| 1508 | return aper_size; | ||
| 1509 | } | ||
| 1510 | |||
| 1511 | /* Single function older card. We read HDP_APER_CNTL to see how the BIOS | ||
| 1512 | * have set it up. We don't write this as it's broken on some ASICs but | ||
| 1513 | * we expect the BIOS to have done the right thing (might be too optimistic...) | ||
| 1514 | */ | ||
| 1515 | if (RREG32(RADEON_HOST_PATH_CNTL) & RADEON_HDP_APER_CNTL) | ||
| 1516 | return aper_size * 2; | ||
| 1517 | return aper_size; | ||
| 1518 | } | ||
| 1519 | |||
| 1520 | void r100_vram_init_sizes(struct radeon_device *rdev) | ||
| 1521 | { | ||
| 1522 | u64 config_aper_size; | ||
| 1523 | u32 accessible; | ||
| 1524 | |||
| 1525 | config_aper_size = RREG32(RADEON_CONFIG_APER_SIZE); | ||
| 1262 | 1526 | ||
| 1263 | if (rdev->flags & RADEON_IS_IGP) { | 1527 | if (rdev->flags & RADEON_IS_IGP) { |
| 1264 | uint32_t tom; | 1528 | uint32_t tom; |
| 1265 | /* read NB_TOM to get the amount of ram stolen for the GPU */ | 1529 | /* read NB_TOM to get the amount of ram stolen for the GPU */ |
| 1266 | tom = RREG32(RADEON_NB_TOM); | 1530 | tom = RREG32(RADEON_NB_TOM); |
| 1267 | rdev->mc.vram_size = (((tom >> 16) - (tom & 0xffff) + 1) << 16); | 1531 | rdev->mc.real_vram_size = (((tom >> 16) - (tom & 0xffff) + 1) << 16); |
| 1268 | WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.vram_size); | 1532 | /* for IGPs we need to keep VRAM where it was put by the BIOS */ |
| 1533 | rdev->mc.vram_location = (tom & 0xffff) << 16; | ||
| 1534 | WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.real_vram_size); | ||
| 1535 | rdev->mc.mc_vram_size = rdev->mc.real_vram_size; | ||
| 1269 | } else { | 1536 | } else { |
| 1270 | rdev->mc.vram_size = RREG32(RADEON_CONFIG_MEMSIZE); | 1537 | rdev->mc.real_vram_size = RREG32(RADEON_CONFIG_MEMSIZE); |
| 1271 | /* Some production boards of m6 will report 0 | 1538 | /* Some production boards of m6 will report 0 |
| 1272 | * if it's 8 MB | 1539 | * if it's 8 MB |
| 1273 | */ | 1540 | */ |
| 1274 | if (rdev->mc.vram_size == 0) { | 1541 | if (rdev->mc.real_vram_size == 0) { |
| 1275 | rdev->mc.vram_size = 8192 * 1024; | 1542 | rdev->mc.real_vram_size = 8192 * 1024; |
| 1276 | WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.vram_size); | 1543 | WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.real_vram_size); |
| 1277 | } | 1544 | } |
| 1545 | /* let driver place VRAM */ | ||
| 1546 | rdev->mc.vram_location = 0xFFFFFFFFUL; | ||
| 1547 | /* Fix for RN50, M6, M7 with 8/16/32(??) MBs of VRAM - | ||
| 1548 | * Novell bug 204882 + along with lots of ubuntu ones */ | ||
| 1549 | if (config_aper_size > rdev->mc.real_vram_size) | ||
| 1550 | rdev->mc.mc_vram_size = config_aper_size; | ||
| 1551 | else | ||
| 1552 | rdev->mc.mc_vram_size = rdev->mc.real_vram_size; | ||
| 1278 | } | 1553 | } |
| 1279 | 1554 | ||
| 1555 | /* work out accessible VRAM */ | ||
| 1556 | accessible = r100_get_accessible_vram(rdev); | ||
| 1557 | |||
| 1280 | rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); | 1558 | rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); |
| 1281 | rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0); | 1559 | rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0); |
| 1560 | |||
| 1561 | if (accessible > rdev->mc.aper_size) | ||
| 1562 | accessible = rdev->mc.aper_size; | ||
| 1563 | |||
| 1564 | if (rdev->mc.mc_vram_size > rdev->mc.aper_size) | ||
| 1565 | rdev->mc.mc_vram_size = rdev->mc.aper_size; | ||
| 1566 | |||
| 1567 | if (rdev->mc.real_vram_size > rdev->mc.aper_size) | ||
| 1568 | rdev->mc.real_vram_size = rdev->mc.aper_size; | ||
| 1569 | } | ||
| 1570 | |||
| 1571 | void r100_vram_info(struct radeon_device *rdev) | ||
| 1572 | { | ||
| 1573 | r100_vram_get_type(rdev); | ||
| 1574 | |||
| 1575 | r100_vram_init_sizes(rdev); | ||
| 1282 | } | 1576 | } |
| 1283 | 1577 | ||
| 1284 | 1578 | ||
| @@ -1338,26 +1632,6 @@ void r100_pll_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v) | |||
| 1338 | r100_pll_errata_after_data(rdev); | 1632 | r100_pll_errata_after_data(rdev); |
| 1339 | } | 1633 | } |
| 1340 | 1634 | ||
| 1341 | uint32_t r100_mm_rreg(struct radeon_device *rdev, uint32_t reg) | ||
| 1342 | { | ||
| 1343 | if (reg < 0x10000) | ||
| 1344 | return readl(((void __iomem *)rdev->rmmio) + reg); | ||
| 1345 | else { | ||
| 1346 | writel(reg, ((void __iomem *)rdev->rmmio) + RADEON_MM_INDEX); | ||
| 1347 | return readl(((void __iomem *)rdev->rmmio) + RADEON_MM_DATA); | ||
| 1348 | } | ||
| 1349 | } | ||
| 1350 | |||
| 1351 | void r100_mm_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v) | ||
| 1352 | { | ||
| 1353 | if (reg < 0x10000) | ||
| 1354 | writel(v, ((void __iomem *)rdev->rmmio) + reg); | ||
| 1355 | else { | ||
| 1356 | writel(reg, ((void __iomem *)rdev->rmmio) + RADEON_MM_INDEX); | ||
| 1357 | writel(v, ((void __iomem *)rdev->rmmio) + RADEON_MM_DATA); | ||
| 1358 | } | ||
| 1359 | } | ||
| 1360 | |||
| 1361 | int r100_init(struct radeon_device *rdev) | 1635 | int r100_init(struct radeon_device *rdev) |
| 1362 | { | 1636 | { |
| 1363 | return 0; | 1637 | return 0; |
| @@ -1533,3 +1807,530 @@ int r100_debugfs_mc_info_init(struct radeon_device *rdev) | |||
| 1533 | return 0; | 1807 | return 0; |
| 1534 | #endif | 1808 | #endif |
| 1535 | } | 1809 | } |
| 1810 | |||
| 1811 | int r100_set_surface_reg(struct radeon_device *rdev, int reg, | ||
| 1812 | uint32_t tiling_flags, uint32_t pitch, | ||
| 1813 | uint32_t offset, uint32_t obj_size) | ||
| 1814 | { | ||
| 1815 | int surf_index = reg * 16; | ||
| 1816 | int flags = 0; | ||
| 1817 | |||
| 1818 | /* r100/r200 divide by 16 */ | ||
| 1819 | if (rdev->family < CHIP_R300) | ||
| 1820 | flags = pitch / 16; | ||
| 1821 | else | ||
| 1822 | flags = pitch / 8; | ||
| 1823 | |||
| 1824 | if (rdev->family <= CHIP_RS200) { | ||
| 1825 | if ((tiling_flags & (RADEON_TILING_MACRO|RADEON_TILING_MICRO)) | ||
| 1826 | == (RADEON_TILING_MACRO|RADEON_TILING_MICRO)) | ||
| 1827 | flags |= RADEON_SURF_TILE_COLOR_BOTH; | ||
| 1828 | if (tiling_flags & RADEON_TILING_MACRO) | ||
| 1829 | flags |= RADEON_SURF_TILE_COLOR_MACRO; | ||
| 1830 | } else if (rdev->family <= CHIP_RV280) { | ||
| 1831 | if (tiling_flags & (RADEON_TILING_MACRO)) | ||
| 1832 | flags |= R200_SURF_TILE_COLOR_MACRO; | ||
| 1833 | if (tiling_flags & RADEON_TILING_MICRO) | ||
| 1834 | flags |= R200_SURF_TILE_COLOR_MICRO; | ||
| 1835 | } else { | ||
| 1836 | if (tiling_flags & RADEON_TILING_MACRO) | ||
| 1837 | flags |= R300_SURF_TILE_MACRO; | ||
| 1838 | if (tiling_flags & RADEON_TILING_MICRO) | ||
| 1839 | flags |= R300_SURF_TILE_MICRO; | ||
| 1840 | } | ||
| 1841 | |||
| 1842 | DRM_DEBUG("writing surface %d %d %x %x\n", reg, flags, offset, offset+obj_size-1); | ||
| 1843 | WREG32(RADEON_SURFACE0_INFO + surf_index, flags); | ||
| 1844 | WREG32(RADEON_SURFACE0_LOWER_BOUND + surf_index, offset); | ||
| 1845 | WREG32(RADEON_SURFACE0_UPPER_BOUND + surf_index, offset + obj_size - 1); | ||
| 1846 | return 0; | ||
| 1847 | } | ||
| 1848 | |||
| 1849 | void r100_clear_surface_reg(struct radeon_device *rdev, int reg) | ||
| 1850 | { | ||
| 1851 | int surf_index = reg * 16; | ||
| 1852 | WREG32(RADEON_SURFACE0_INFO + surf_index, 0); | ||
| 1853 | } | ||
| 1854 | |||
| 1855 | void r100_bandwidth_update(struct radeon_device *rdev) | ||
| 1856 | { | ||
| 1857 | fixed20_12 trcd_ff, trp_ff, tras_ff, trbs_ff, tcas_ff; | ||
| 1858 | fixed20_12 sclk_ff, mclk_ff, sclk_eff_ff, sclk_delay_ff; | ||
| 1859 | fixed20_12 peak_disp_bw, mem_bw, pix_clk, pix_clk2, temp_ff, crit_point_ff; | ||
| 1860 | uint32_t temp, data, mem_trcd, mem_trp, mem_tras; | ||
| 1861 | fixed20_12 memtcas_ff[8] = { | ||
| 1862 | fixed_init(1), | ||
| 1863 | fixed_init(2), | ||
| 1864 | fixed_init(3), | ||
| 1865 | fixed_init(0), | ||
| 1866 | fixed_init_half(1), | ||
| 1867 | fixed_init_half(2), | ||
| 1868 | fixed_init(0), | ||
| 1869 | }; | ||
| 1870 | fixed20_12 memtcas_rs480_ff[8] = { | ||
| 1871 | fixed_init(0), | ||
| 1872 | fixed_init(1), | ||
| 1873 | fixed_init(2), | ||
| 1874 | fixed_init(3), | ||
| 1875 | fixed_init(0), | ||
| 1876 | fixed_init_half(1), | ||
| 1877 | fixed_init_half(2), | ||
| 1878 | fixed_init_half(3), | ||
| 1879 | }; | ||
| 1880 | fixed20_12 memtcas2_ff[8] = { | ||
| 1881 | fixed_init(0), | ||
| 1882 | fixed_init(1), | ||
| 1883 | fixed_init(2), | ||
| 1884 | fixed_init(3), | ||
| 1885 | fixed_init(4), | ||
| 1886 | fixed_init(5), | ||
| 1887 | fixed_init(6), | ||
| 1888 | fixed_init(7), | ||
| 1889 | }; | ||
| 1890 | fixed20_12 memtrbs[8] = { | ||
| 1891 | fixed_init(1), | ||
| 1892 | fixed_init_half(1), | ||
| 1893 | fixed_init(2), | ||
| 1894 | fixed_init_half(2), | ||
| 1895 | fixed_init(3), | ||
| 1896 | fixed_init_half(3), | ||
| 1897 | fixed_init(4), | ||
| 1898 | fixed_init_half(4) | ||
| 1899 | }; | ||
| 1900 | fixed20_12 memtrbs_r4xx[8] = { | ||
| 1901 | fixed_init(4), | ||
| 1902 | fixed_init(5), | ||
| 1903 | fixed_init(6), | ||
| 1904 | fixed_init(7), | ||
| 1905 | fixed_init(8), | ||
| 1906 | fixed_init(9), | ||
| 1907 | fixed_init(10), | ||
| 1908 | fixed_init(11) | ||
| 1909 | }; | ||
| 1910 | fixed20_12 min_mem_eff; | ||
| 1911 | fixed20_12 mc_latency_sclk, mc_latency_mclk, k1; | ||
| 1912 | fixed20_12 cur_latency_mclk, cur_latency_sclk; | ||
| 1913 | fixed20_12 disp_latency, disp_latency_overhead, disp_drain_rate, | ||
| 1914 | disp_drain_rate2, read_return_rate; | ||
| 1915 | fixed20_12 time_disp1_drop_priority; | ||
| 1916 | int c; | ||
| 1917 | int cur_size = 16; /* in octawords */ | ||
| 1918 | int critical_point = 0, critical_point2; | ||
| 1919 | /* uint32_t read_return_rate, time_disp1_drop_priority; */ | ||
| 1920 | int stop_req, max_stop_req; | ||
| 1921 | struct drm_display_mode *mode1 = NULL; | ||
| 1922 | struct drm_display_mode *mode2 = NULL; | ||
| 1923 | uint32_t pixel_bytes1 = 0; | ||
| 1924 | uint32_t pixel_bytes2 = 0; | ||
| 1925 | |||
| 1926 | if (rdev->mode_info.crtcs[0]->base.enabled) { | ||
| 1927 | mode1 = &rdev->mode_info.crtcs[0]->base.mode; | ||
| 1928 | pixel_bytes1 = rdev->mode_info.crtcs[0]->base.fb->bits_per_pixel / 8; | ||
| 1929 | } | ||
| 1930 | if (rdev->mode_info.crtcs[1]->base.enabled) { | ||
| 1931 | mode2 = &rdev->mode_info.crtcs[1]->base.mode; | ||
| 1932 | pixel_bytes2 = rdev->mode_info.crtcs[1]->base.fb->bits_per_pixel / 8; | ||
| 1933 | } | ||
| 1934 | |||
| 1935 | min_mem_eff.full = rfixed_const_8(0); | ||
| 1936 | /* get modes */ | ||
| 1937 | if ((rdev->disp_priority == 2) && ASIC_IS_R300(rdev)) { | ||
| 1938 | uint32_t mc_init_misc_lat_timer = RREG32(R300_MC_INIT_MISC_LAT_TIMER); | ||
| 1939 | mc_init_misc_lat_timer &= ~(R300_MC_DISP1R_INIT_LAT_MASK << R300_MC_DISP1R_INIT_LAT_SHIFT); | ||
| 1940 | mc_init_misc_lat_timer &= ~(R300_MC_DISP0R_INIT_LAT_MASK << R300_MC_DISP0R_INIT_LAT_SHIFT); | ||
| 1941 | /* check crtc enables */ | ||
| 1942 | if (mode2) | ||
| 1943 | mc_init_misc_lat_timer |= (1 << R300_MC_DISP1R_INIT_LAT_SHIFT); | ||
| 1944 | if (mode1) | ||
| 1945 | mc_init_misc_lat_timer |= (1 << R300_MC_DISP0R_INIT_LAT_SHIFT); | ||
| 1946 | WREG32(R300_MC_INIT_MISC_LAT_TIMER, mc_init_misc_lat_timer); | ||
| 1947 | } | ||
| 1948 | |||
| 1949 | /* | ||
| 1950 | * determine is there is enough bw for current mode | ||
| 1951 | */ | ||
| 1952 | mclk_ff.full = rfixed_const(rdev->clock.default_mclk); | ||
| 1953 | temp_ff.full = rfixed_const(100); | ||
| 1954 | mclk_ff.full = rfixed_div(mclk_ff, temp_ff); | ||
| 1955 | sclk_ff.full = rfixed_const(rdev->clock.default_sclk); | ||
| 1956 | sclk_ff.full = rfixed_div(sclk_ff, temp_ff); | ||
| 1957 | |||
| 1958 | temp = (rdev->mc.vram_width / 8) * (rdev->mc.vram_is_ddr ? 2 : 1); | ||
| 1959 | temp_ff.full = rfixed_const(temp); | ||
| 1960 | mem_bw.full = rfixed_mul(mclk_ff, temp_ff); | ||
| 1961 | |||
| 1962 | pix_clk.full = 0; | ||
| 1963 | pix_clk2.full = 0; | ||
| 1964 | peak_disp_bw.full = 0; | ||
| 1965 | if (mode1) { | ||
| 1966 | temp_ff.full = rfixed_const(1000); | ||
| 1967 | pix_clk.full = rfixed_const(mode1->clock); /* convert to fixed point */ | ||
| 1968 | pix_clk.full = rfixed_div(pix_clk, temp_ff); | ||
| 1969 | temp_ff.full = rfixed_const(pixel_bytes1); | ||
| 1970 | peak_disp_bw.full += rfixed_mul(pix_clk, temp_ff); | ||
| 1971 | } | ||
| 1972 | if (mode2) { | ||
| 1973 | temp_ff.full = rfixed_const(1000); | ||
| 1974 | pix_clk2.full = rfixed_const(mode2->clock); /* convert to fixed point */ | ||
| 1975 | pix_clk2.full = rfixed_div(pix_clk2, temp_ff); | ||
| 1976 | temp_ff.full = rfixed_const(pixel_bytes2); | ||
| 1977 | peak_disp_bw.full += rfixed_mul(pix_clk2, temp_ff); | ||
| 1978 | } | ||
| 1979 | |||
| 1980 | mem_bw.full = rfixed_mul(mem_bw, min_mem_eff); | ||
| 1981 | if (peak_disp_bw.full >= mem_bw.full) { | ||
| 1982 | DRM_ERROR("You may not have enough display bandwidth for current mode\n" | ||
| 1983 | "If you have flickering problem, try to lower resolution, refresh rate, or color depth\n"); | ||
| 1984 | } | ||
| 1985 | |||
| 1986 | /* Get values from the EXT_MEM_CNTL register...converting its contents. */ | ||
| 1987 | temp = RREG32(RADEON_MEM_TIMING_CNTL); | ||
| 1988 | if ((rdev->family == CHIP_RV100) || (rdev->flags & RADEON_IS_IGP)) { /* RV100, M6, IGPs */ | ||
| 1989 | mem_trcd = ((temp >> 2) & 0x3) + 1; | ||
| 1990 | mem_trp = ((temp & 0x3)) + 1; | ||
| 1991 | mem_tras = ((temp & 0x70) >> 4) + 1; | ||
| 1992 | } else if (rdev->family == CHIP_R300 || | ||
| 1993 | rdev->family == CHIP_R350) { /* r300, r350 */ | ||
| 1994 | mem_trcd = (temp & 0x7) + 1; | ||
| 1995 | mem_trp = ((temp >> 8) & 0x7) + 1; | ||
| 1996 | mem_tras = ((temp >> 11) & 0xf) + 4; | ||
| 1997 | } else if (rdev->family == CHIP_RV350 || | ||
| 1998 | rdev->family <= CHIP_RV380) { | ||
| 1999 | /* rv3x0 */ | ||
| 2000 | mem_trcd = (temp & 0x7) + 3; | ||
| 2001 | mem_trp = ((temp >> 8) & 0x7) + 3; | ||
| 2002 | mem_tras = ((temp >> 11) & 0xf) + 6; | ||
| 2003 | } else if (rdev->family == CHIP_R420 || | ||
| 2004 | rdev->family == CHIP_R423 || | ||
| 2005 | rdev->family == CHIP_RV410) { | ||
| 2006 | /* r4xx */ | ||
| 2007 | mem_trcd = (temp & 0xf) + 3; | ||
| 2008 | if (mem_trcd > 15) | ||
| 2009 | mem_trcd = 15; | ||
| 2010 | mem_trp = ((temp >> 8) & 0xf) + 3; | ||
| 2011 | if (mem_trp > 15) | ||
| 2012 | mem_trp = 15; | ||
| 2013 | mem_tras = ((temp >> 12) & 0x1f) + 6; | ||
| 2014 | if (mem_tras > 31) | ||
| 2015 | mem_tras = 31; | ||
| 2016 | } else { /* RV200, R200 */ | ||
| 2017 | mem_trcd = (temp & 0x7) + 1; | ||
| 2018 | mem_trp = ((temp >> 8) & 0x7) + 1; | ||
| 2019 | mem_tras = ((temp >> 12) & 0xf) + 4; | ||
| 2020 | } | ||
| 2021 | /* convert to FF */ | ||
| 2022 | trcd_ff.full = rfixed_const(mem_trcd); | ||
| 2023 | trp_ff.full = rfixed_const(mem_trp); | ||
| 2024 | tras_ff.full = rfixed_const(mem_tras); | ||
| 2025 | |||
| 2026 | /* Get values from the MEM_SDRAM_MODE_REG register...converting its */ | ||
| 2027 | temp = RREG32(RADEON_MEM_SDRAM_MODE_REG); | ||
| 2028 | data = (temp & (7 << 20)) >> 20; | ||
| 2029 | if ((rdev->family == CHIP_RV100) || rdev->flags & RADEON_IS_IGP) { | ||
| 2030 | if (rdev->family == CHIP_RS480) /* don't think rs400 */ | ||
| 2031 | tcas_ff = memtcas_rs480_ff[data]; | ||
| 2032 | else | ||
| 2033 | tcas_ff = memtcas_ff[data]; | ||
| 2034 | } else | ||
| 2035 | tcas_ff = memtcas2_ff[data]; | ||
| 2036 | |||
| 2037 | if (rdev->family == CHIP_RS400 || | ||
| 2038 | rdev->family == CHIP_RS480) { | ||
| 2039 | /* extra cas latency stored in bits 23-25 0-4 clocks */ | ||
| 2040 | data = (temp >> 23) & 0x7; | ||
| 2041 | if (data < 5) | ||
| 2042 | tcas_ff.full += rfixed_const(data); | ||
| 2043 | } | ||
| 2044 | |||
| 2045 | if (ASIC_IS_R300(rdev) && !(rdev->flags & RADEON_IS_IGP)) { | ||
| 2046 | /* on the R300, Tcas is included in Trbs. | ||
| 2047 | */ | ||
| 2048 | temp = RREG32(RADEON_MEM_CNTL); | ||
| 2049 | data = (R300_MEM_NUM_CHANNELS_MASK & temp); | ||
| 2050 | if (data == 1) { | ||
| 2051 | if (R300_MEM_USE_CD_CH_ONLY & temp) { | ||
| 2052 | temp = RREG32(R300_MC_IND_INDEX); | ||
| 2053 | temp &= ~R300_MC_IND_ADDR_MASK; | ||
| 2054 | temp |= R300_MC_READ_CNTL_CD_mcind; | ||
| 2055 | WREG32(R300_MC_IND_INDEX, temp); | ||
| 2056 | temp = RREG32(R300_MC_IND_DATA); | ||
| 2057 | data = (R300_MEM_RBS_POSITION_C_MASK & temp); | ||
| 2058 | } else { | ||
| 2059 | temp = RREG32(R300_MC_READ_CNTL_AB); | ||
| 2060 | data = (R300_MEM_RBS_POSITION_A_MASK & temp); | ||
| 2061 | } | ||
| 2062 | } else { | ||
| 2063 | temp = RREG32(R300_MC_READ_CNTL_AB); | ||
| 2064 | data = (R300_MEM_RBS_POSITION_A_MASK & temp); | ||
| 2065 | } | ||
| 2066 | if (rdev->family == CHIP_RV410 || | ||
| 2067 | rdev->family == CHIP_R420 || | ||
| 2068 | rdev->family == CHIP_R423) | ||
| 2069 | trbs_ff = memtrbs_r4xx[data]; | ||
| 2070 | else | ||
| 2071 | trbs_ff = memtrbs[data]; | ||
| 2072 | tcas_ff.full += trbs_ff.full; | ||
| 2073 | } | ||
| 2074 | |||
| 2075 | sclk_eff_ff.full = sclk_ff.full; | ||
| 2076 | |||
| 2077 | if (rdev->flags & RADEON_IS_AGP) { | ||
| 2078 | fixed20_12 agpmode_ff; | ||
| 2079 | agpmode_ff.full = rfixed_const(radeon_agpmode); | ||
| 2080 | temp_ff.full = rfixed_const_666(16); | ||
| 2081 | sclk_eff_ff.full -= rfixed_mul(agpmode_ff, temp_ff); | ||
| 2082 | } | ||
| 2083 | /* TODO PCIE lanes may affect this - agpmode == 16?? */ | ||
| 2084 | |||
| 2085 | if (ASIC_IS_R300(rdev)) { | ||
| 2086 | sclk_delay_ff.full = rfixed_const(250); | ||
| 2087 | } else { | ||
| 2088 | if ((rdev->family == CHIP_RV100) || | ||
| 2089 | rdev->flags & RADEON_IS_IGP) { | ||
| 2090 | if (rdev->mc.vram_is_ddr) | ||
| 2091 | sclk_delay_ff.full = rfixed_const(41); | ||
| 2092 | else | ||
| 2093 | sclk_delay_ff.full = rfixed_const(33); | ||
| 2094 | } else { | ||
| 2095 | if (rdev->mc.vram_width == 128) | ||
| 2096 | sclk_delay_ff.full = rfixed_const(57); | ||
| 2097 | else | ||
| 2098 | sclk_delay_ff.full = rfixed_const(41); | ||
| 2099 | } | ||
| 2100 | } | ||
| 2101 | |||
| 2102 | mc_latency_sclk.full = rfixed_div(sclk_delay_ff, sclk_eff_ff); | ||
| 2103 | |||
| 2104 | if (rdev->mc.vram_is_ddr) { | ||
| 2105 | if (rdev->mc.vram_width == 32) { | ||
| 2106 | k1.full = rfixed_const(40); | ||
| 2107 | c = 3; | ||
| 2108 | } else { | ||
| 2109 | k1.full = rfixed_const(20); | ||
| 2110 | c = 1; | ||
| 2111 | } | ||
| 2112 | } else { | ||
| 2113 | k1.full = rfixed_const(40); | ||
| 2114 | c = 3; | ||
| 2115 | } | ||
| 2116 | |||
| 2117 | temp_ff.full = rfixed_const(2); | ||
| 2118 | mc_latency_mclk.full = rfixed_mul(trcd_ff, temp_ff); | ||
| 2119 | temp_ff.full = rfixed_const(c); | ||
| 2120 | mc_latency_mclk.full += rfixed_mul(tcas_ff, temp_ff); | ||
| 2121 | temp_ff.full = rfixed_const(4); | ||
| 2122 | mc_latency_mclk.full += rfixed_mul(tras_ff, temp_ff); | ||
| 2123 | mc_latency_mclk.full += rfixed_mul(trp_ff, temp_ff); | ||
| 2124 | mc_latency_mclk.full += k1.full; | ||
| 2125 | |||
| 2126 | mc_latency_mclk.full = rfixed_div(mc_latency_mclk, mclk_ff); | ||
| 2127 | mc_latency_mclk.full += rfixed_div(temp_ff, sclk_eff_ff); | ||
| 2128 | |||
| 2129 | /* | ||
| 2130 | HW cursor time assuming worst case of full size colour cursor. | ||
| 2131 | */ | ||
| 2132 | temp_ff.full = rfixed_const((2 * (cur_size - (rdev->mc.vram_is_ddr + 1)))); | ||
| 2133 | temp_ff.full += trcd_ff.full; | ||
| 2134 | if (temp_ff.full < tras_ff.full) | ||
| 2135 | temp_ff.full = tras_ff.full; | ||
| 2136 | cur_latency_mclk.full = rfixed_div(temp_ff, mclk_ff); | ||
| 2137 | |||
| 2138 | temp_ff.full = rfixed_const(cur_size); | ||
| 2139 | cur_latency_sclk.full = rfixed_div(temp_ff, sclk_eff_ff); | ||
| 2140 | /* | ||
| 2141 | Find the total latency for the display data. | ||
| 2142 | */ | ||
| 2143 | disp_latency_overhead.full = rfixed_const(80); | ||
| 2144 | disp_latency_overhead.full = rfixed_div(disp_latency_overhead, sclk_ff); | ||
| 2145 | mc_latency_mclk.full += disp_latency_overhead.full + cur_latency_mclk.full; | ||
| 2146 | mc_latency_sclk.full += disp_latency_overhead.full + cur_latency_sclk.full; | ||
| 2147 | |||
| 2148 | if (mc_latency_mclk.full > mc_latency_sclk.full) | ||
| 2149 | disp_latency.full = mc_latency_mclk.full; | ||
| 2150 | else | ||
| 2151 | disp_latency.full = mc_latency_sclk.full; | ||
| 2152 | |||
| 2153 | /* setup Max GRPH_STOP_REQ default value */ | ||
| 2154 | if (ASIC_IS_RV100(rdev)) | ||
| 2155 | max_stop_req = 0x5c; | ||
| 2156 | else | ||
| 2157 | max_stop_req = 0x7c; | ||
| 2158 | |||
| 2159 | if (mode1) { | ||
| 2160 | /* CRTC1 | ||
| 2161 | Set GRPH_BUFFER_CNTL register using h/w defined optimal values. | ||
| 2162 | GRPH_STOP_REQ <= MIN[ 0x7C, (CRTC_H_DISP + 1) * (bit depth) / 0x10 ] | ||
| 2163 | */ | ||
| 2164 | stop_req = mode1->hdisplay * pixel_bytes1 / 16; | ||
| 2165 | |||
| 2166 | if (stop_req > max_stop_req) | ||
| 2167 | stop_req = max_stop_req; | ||
| 2168 | |||
| 2169 | /* | ||
| 2170 | Find the drain rate of the display buffer. | ||
| 2171 | */ | ||
| 2172 | temp_ff.full = rfixed_const((16/pixel_bytes1)); | ||
| 2173 | disp_drain_rate.full = rfixed_div(pix_clk, temp_ff); | ||
| 2174 | |||
| 2175 | /* | ||
| 2176 | Find the critical point of the display buffer. | ||
| 2177 | */ | ||
| 2178 | crit_point_ff.full = rfixed_mul(disp_drain_rate, disp_latency); | ||
| 2179 | crit_point_ff.full += rfixed_const_half(0); | ||
| 2180 | |||
| 2181 | critical_point = rfixed_trunc(crit_point_ff); | ||
| 2182 | |||
| 2183 | if (rdev->disp_priority == 2) { | ||
| 2184 | critical_point = 0; | ||
| 2185 | } | ||
| 2186 | |||
| 2187 | /* | ||
| 2188 | The critical point should never be above max_stop_req-4. Setting | ||
| 2189 | GRPH_CRITICAL_CNTL = 0 will thus force high priority all the time. | ||
| 2190 | */ | ||
| 2191 | if (max_stop_req - critical_point < 4) | ||
| 2192 | critical_point = 0; | ||
| 2193 | |||
| 2194 | if (critical_point == 0 && mode2 && rdev->family == CHIP_R300) { | ||
| 2195 | /* some R300 cards have problem with this set to 0, when CRTC2 is enabled.*/ | ||
| 2196 | critical_point = 0x10; | ||
| 2197 | } | ||
| 2198 | |||
| 2199 | temp = RREG32(RADEON_GRPH_BUFFER_CNTL); | ||
| 2200 | temp &= ~(RADEON_GRPH_STOP_REQ_MASK); | ||
| 2201 | temp |= (stop_req << RADEON_GRPH_STOP_REQ_SHIFT); | ||
| 2202 | temp &= ~(RADEON_GRPH_START_REQ_MASK); | ||
| 2203 | if ((rdev->family == CHIP_R350) && | ||
| 2204 | (stop_req > 0x15)) { | ||
| 2205 | stop_req -= 0x10; | ||
| 2206 | } | ||
| 2207 | temp |= (stop_req << RADEON_GRPH_START_REQ_SHIFT); | ||
| 2208 | temp |= RADEON_GRPH_BUFFER_SIZE; | ||
| 2209 | temp &= ~(RADEON_GRPH_CRITICAL_CNTL | | ||
| 2210 | RADEON_GRPH_CRITICAL_AT_SOF | | ||
| 2211 | RADEON_GRPH_STOP_CNTL); | ||
| 2212 | /* | ||
| 2213 | Write the result into the register. | ||
| 2214 | */ | ||
| 2215 | WREG32(RADEON_GRPH_BUFFER_CNTL, ((temp & ~RADEON_GRPH_CRITICAL_POINT_MASK) | | ||
| 2216 | (critical_point << RADEON_GRPH_CRITICAL_POINT_SHIFT))); | ||
| 2217 | |||
| 2218 | #if 0 | ||
| 2219 | if ((rdev->family == CHIP_RS400) || | ||
| 2220 | (rdev->family == CHIP_RS480)) { | ||
| 2221 | /* attempt to program RS400 disp regs correctly ??? */ | ||
| 2222 | temp = RREG32(RS400_DISP1_REG_CNTL); | ||
| 2223 | temp &= ~(RS400_DISP1_START_REQ_LEVEL_MASK | | ||
| 2224 | RS400_DISP1_STOP_REQ_LEVEL_MASK); | ||
| 2225 | WREG32(RS400_DISP1_REQ_CNTL1, (temp | | ||
| 2226 | (critical_point << RS400_DISP1_START_REQ_LEVEL_SHIFT) | | ||
| 2227 | (critical_point << RS400_DISP1_STOP_REQ_LEVEL_SHIFT))); | ||
| 2228 | temp = RREG32(RS400_DMIF_MEM_CNTL1); | ||
| 2229 | temp &= ~(RS400_DISP1_CRITICAL_POINT_START_MASK | | ||
| 2230 | RS400_DISP1_CRITICAL_POINT_STOP_MASK); | ||
| 2231 | WREG32(RS400_DMIF_MEM_CNTL1, (temp | | ||
| 2232 | (critical_point << RS400_DISP1_CRITICAL_POINT_START_SHIFT) | | ||
| 2233 | (critical_point << RS400_DISP1_CRITICAL_POINT_STOP_SHIFT))); | ||
| 2234 | } | ||
| 2235 | #endif | ||
| 2236 | |||
| 2237 | DRM_DEBUG("GRPH_BUFFER_CNTL from to %x\n", | ||
| 2238 | /* (unsigned int)info->SavedReg->grph_buffer_cntl, */ | ||
| 2239 | (unsigned int)RREG32(RADEON_GRPH_BUFFER_CNTL)); | ||
| 2240 | } | ||
| 2241 | |||
| 2242 | if (mode2) { | ||
| 2243 | u32 grph2_cntl; | ||
| 2244 | stop_req = mode2->hdisplay * pixel_bytes2 / 16; | ||
| 2245 | |||
| 2246 | if (stop_req > max_stop_req) | ||
| 2247 | stop_req = max_stop_req; | ||
| 2248 | |||
| 2249 | /* | ||
| 2250 | Find the drain rate of the display buffer. | ||
| 2251 | */ | ||
| 2252 | temp_ff.full = rfixed_const((16/pixel_bytes2)); | ||
| 2253 | disp_drain_rate2.full = rfixed_div(pix_clk2, temp_ff); | ||
| 2254 | |||
| 2255 | grph2_cntl = RREG32(RADEON_GRPH2_BUFFER_CNTL); | ||
| 2256 | grph2_cntl &= ~(RADEON_GRPH_STOP_REQ_MASK); | ||
| 2257 | grph2_cntl |= (stop_req << RADEON_GRPH_STOP_REQ_SHIFT); | ||
| 2258 | grph2_cntl &= ~(RADEON_GRPH_START_REQ_MASK); | ||
| 2259 | if ((rdev->family == CHIP_R350) && | ||
| 2260 | (stop_req > 0x15)) { | ||
| 2261 | stop_req -= 0x10; | ||
| 2262 | } | ||
| 2263 | grph2_cntl |= (stop_req << RADEON_GRPH_START_REQ_SHIFT); | ||
| 2264 | grph2_cntl |= RADEON_GRPH_BUFFER_SIZE; | ||
| 2265 | grph2_cntl &= ~(RADEON_GRPH_CRITICAL_CNTL | | ||
| 2266 | RADEON_GRPH_CRITICAL_AT_SOF | | ||
| 2267 | RADEON_GRPH_STOP_CNTL); | ||
| 2268 | |||
| 2269 | if ((rdev->family == CHIP_RS100) || | ||
| 2270 | (rdev->family == CHIP_RS200)) | ||
| 2271 | critical_point2 = 0; | ||
| 2272 | else { | ||
| 2273 | temp = (rdev->mc.vram_width * rdev->mc.vram_is_ddr + 1)/128; | ||
| 2274 | temp_ff.full = rfixed_const(temp); | ||
| 2275 | temp_ff.full = rfixed_mul(mclk_ff, temp_ff); | ||
| 2276 | if (sclk_ff.full < temp_ff.full) | ||
| 2277 | temp_ff.full = sclk_ff.full; | ||
| 2278 | |||
| 2279 | read_return_rate.full = temp_ff.full; | ||
| 2280 | |||
| 2281 | if (mode1) { | ||
| 2282 | temp_ff.full = read_return_rate.full - disp_drain_rate.full; | ||
| 2283 | time_disp1_drop_priority.full = rfixed_div(crit_point_ff, temp_ff); | ||
| 2284 | } else { | ||
| 2285 | time_disp1_drop_priority.full = 0; | ||
| 2286 | } | ||
| 2287 | crit_point_ff.full = disp_latency.full + time_disp1_drop_priority.full + disp_latency.full; | ||
| 2288 | crit_point_ff.full = rfixed_mul(crit_point_ff, disp_drain_rate2); | ||
| 2289 | crit_point_ff.full += rfixed_const_half(0); | ||
| 2290 | |||
| 2291 | critical_point2 = rfixed_trunc(crit_point_ff); | ||
| 2292 | |||
| 2293 | if (rdev->disp_priority == 2) { | ||
| 2294 | critical_point2 = 0; | ||
| 2295 | } | ||
| 2296 | |||
| 2297 | if (max_stop_req - critical_point2 < 4) | ||
| 2298 | critical_point2 = 0; | ||
| 2299 | |||
| 2300 | } | ||
| 2301 | |||
| 2302 | if (critical_point2 == 0 && rdev->family == CHIP_R300) { | ||
| 2303 | /* some R300 cards have problem with this set to 0 */ | ||
| 2304 | critical_point2 = 0x10; | ||
| 2305 | } | ||
| 2306 | |||
| 2307 | WREG32(RADEON_GRPH2_BUFFER_CNTL, ((grph2_cntl & ~RADEON_GRPH_CRITICAL_POINT_MASK) | | ||
| 2308 | (critical_point2 << RADEON_GRPH_CRITICAL_POINT_SHIFT))); | ||
| 2309 | |||
| 2310 | if ((rdev->family == CHIP_RS400) || | ||
| 2311 | (rdev->family == CHIP_RS480)) { | ||
| 2312 | #if 0 | ||
| 2313 | /* attempt to program RS400 disp2 regs correctly ??? */ | ||
| 2314 | temp = RREG32(RS400_DISP2_REQ_CNTL1); | ||
| 2315 | temp &= ~(RS400_DISP2_START_REQ_LEVEL_MASK | | ||
| 2316 | RS400_DISP2_STOP_REQ_LEVEL_MASK); | ||
| 2317 | WREG32(RS400_DISP2_REQ_CNTL1, (temp | | ||
| 2318 | (critical_point2 << RS400_DISP1_START_REQ_LEVEL_SHIFT) | | ||
| 2319 | (critical_point2 << RS400_DISP1_STOP_REQ_LEVEL_SHIFT))); | ||
| 2320 | temp = RREG32(RS400_DISP2_REQ_CNTL2); | ||
| 2321 | temp &= ~(RS400_DISP2_CRITICAL_POINT_START_MASK | | ||
| 2322 | RS400_DISP2_CRITICAL_POINT_STOP_MASK); | ||
| 2323 | WREG32(RS400_DISP2_REQ_CNTL2, (temp | | ||
| 2324 | (critical_point2 << RS400_DISP2_CRITICAL_POINT_START_SHIFT) | | ||
| 2325 | (critical_point2 << RS400_DISP2_CRITICAL_POINT_STOP_SHIFT))); | ||
| 2326 | #endif | ||
| 2327 | WREG32(RS400_DISP2_REQ_CNTL1, 0x105DC1CC); | ||
| 2328 | WREG32(RS400_DISP2_REQ_CNTL2, 0x2749D000); | ||
| 2329 | WREG32(RS400_DMIF_MEM_CNTL1, 0x29CA71DC); | ||
| 2330 | WREG32(RS400_DISP1_REQ_CNTL1, 0x28FBC3AC); | ||
| 2331 | } | ||
| 2332 | |||
| 2333 | DRM_DEBUG("GRPH2_BUFFER_CNTL from to %x\n", | ||
| 2334 | (unsigned int)RREG32(RADEON_GRPH2_BUFFER_CNTL)); | ||
| 2335 | } | ||
| 2336 | } | ||
diff --git a/drivers/gpu/drm/radeon/r300.c b/drivers/gpu/drm/radeon/r300.c index e2ed5bc08170..053f4ec397f7 100644 --- a/drivers/gpu/drm/radeon/r300.c +++ b/drivers/gpu/drm/radeon/r300.c | |||
| @@ -30,6 +30,8 @@ | |||
| 30 | #include "drm.h" | 30 | #include "drm.h" |
| 31 | #include "radeon_reg.h" | 31 | #include "radeon_reg.h" |
| 32 | #include "radeon.h" | 32 | #include "radeon.h" |
| 33 | #include "radeon_drm.h" | ||
| 34 | #include "radeon_share.h" | ||
| 33 | 35 | ||
| 34 | /* r300,r350,rv350,rv370,rv380 depends on : */ | 36 | /* r300,r350,rv350,rv370,rv380 depends on : */ |
| 35 | void r100_hdp_reset(struct radeon_device *rdev); | 37 | void r100_hdp_reset(struct radeon_device *rdev); |
| @@ -44,6 +46,7 @@ int r100_gui_wait_for_idle(struct radeon_device *rdev); | |||
| 44 | int r100_cs_packet_parse(struct radeon_cs_parser *p, | 46 | int r100_cs_packet_parse(struct radeon_cs_parser *p, |
| 45 | struct radeon_cs_packet *pkt, | 47 | struct radeon_cs_packet *pkt, |
| 46 | unsigned idx); | 48 | unsigned idx); |
| 49 | int r100_cs_packet_parse_vline(struct radeon_cs_parser *p); | ||
| 47 | int r100_cs_packet_next_reloc(struct radeon_cs_parser *p, | 50 | int r100_cs_packet_next_reloc(struct radeon_cs_parser *p, |
| 48 | struct radeon_cs_reloc **cs_reloc); | 51 | struct radeon_cs_reloc **cs_reloc); |
| 49 | int r100_cs_parse_packet0(struct radeon_cs_parser *p, | 52 | int r100_cs_parse_packet0(struct radeon_cs_parser *p, |
| @@ -80,8 +83,8 @@ void rv370_pcie_gart_tlb_flush(struct radeon_device *rdev) | |||
| 80 | WREG32_PCIE(RADEON_PCIE_TX_GART_CNTL, tmp | RADEON_PCIE_TX_GART_INVALIDATE_TLB); | 83 | WREG32_PCIE(RADEON_PCIE_TX_GART_CNTL, tmp | RADEON_PCIE_TX_GART_INVALIDATE_TLB); |
| 81 | (void)RREG32_PCIE(RADEON_PCIE_TX_GART_CNTL); | 84 | (void)RREG32_PCIE(RADEON_PCIE_TX_GART_CNTL); |
| 82 | WREG32_PCIE(RADEON_PCIE_TX_GART_CNTL, tmp); | 85 | WREG32_PCIE(RADEON_PCIE_TX_GART_CNTL, tmp); |
| 83 | mb(); | ||
| 84 | } | 86 | } |
| 87 | mb(); | ||
| 85 | } | 88 | } |
| 86 | 89 | ||
| 87 | int rv370_pcie_gart_enable(struct radeon_device *rdev) | 90 | int rv370_pcie_gart_enable(struct radeon_device *rdev) |
| @@ -150,8 +153,13 @@ int rv370_pcie_gart_set_page(struct radeon_device *rdev, int i, uint64_t addr) | |||
| 150 | if (i < 0 || i > rdev->gart.num_gpu_pages) { | 153 | if (i < 0 || i > rdev->gart.num_gpu_pages) { |
| 151 | return -EINVAL; | 154 | return -EINVAL; |
| 152 | } | 155 | } |
| 153 | addr = (((u32)addr) >> 8) | ((upper_32_bits(addr) & 0xff) << 4) | 0xC; | 156 | addr = (lower_32_bits(addr) >> 8) | |
| 154 | writel(cpu_to_le32(addr), ((void __iomem *)ptr) + (i * 4)); | 157 | ((upper_32_bits(addr) & 0xff) << 24) | |
| 158 | 0xc; | ||
| 159 | /* on x86 we want this to be CPU endian, on powerpc | ||
| 160 | * on powerpc without HW swappers, it'll get swapped on way | ||
| 161 | * into VRAM - so no need for cpu_to_le32 on VRAM tables */ | ||
| 162 | writel(addr, ((void __iomem *)ptr) + (i * 4)); | ||
| 155 | return 0; | 163 | return 0; |
| 156 | } | 164 | } |
| 157 | 165 | ||
| @@ -440,6 +448,7 @@ void r300_gpu_init(struct radeon_device *rdev) | |||
| 440 | /* rv350,rv370,rv380 */ | 448 | /* rv350,rv370,rv380 */ |
| 441 | rdev->num_gb_pipes = 1; | 449 | rdev->num_gb_pipes = 1; |
| 442 | } | 450 | } |
| 451 | rdev->num_z_pipes = 1; | ||
| 443 | gb_tile_config = (R300_ENABLE_TILING | R300_TILE_SIZE_16); | 452 | gb_tile_config = (R300_ENABLE_TILING | R300_TILE_SIZE_16); |
| 444 | switch (rdev->num_gb_pipes) { | 453 | switch (rdev->num_gb_pipes) { |
| 445 | case 2: | 454 | case 2: |
| @@ -478,7 +487,8 @@ void r300_gpu_init(struct radeon_device *rdev) | |||
| 478 | printk(KERN_WARNING "Failed to wait MC idle while " | 487 | printk(KERN_WARNING "Failed to wait MC idle while " |
| 479 | "programming pipes. Bad things might happen.\n"); | 488 | "programming pipes. Bad things might happen.\n"); |
| 480 | } | 489 | } |
| 481 | DRM_INFO("radeon: %d pipes initialized.\n", rdev->num_gb_pipes); | 490 | DRM_INFO("radeon: %d quad pipes, %d Z pipes initialized.\n", |
| 491 | rdev->num_gb_pipes, rdev->num_z_pipes); | ||
| 482 | } | 492 | } |
| 483 | 493 | ||
| 484 | int r300_ga_reset(struct radeon_device *rdev) | 494 | int r300_ga_reset(struct radeon_device *rdev) |
| @@ -579,35 +589,12 @@ void r300_vram_info(struct radeon_device *rdev) | |||
| 579 | } else { | 589 | } else { |
| 580 | rdev->mc.vram_width = 64; | 590 | rdev->mc.vram_width = 64; |
| 581 | } | 591 | } |
| 582 | rdev->mc.vram_size = RREG32(RADEON_CONFIG_MEMSIZE); | ||
| 583 | 592 | ||
| 584 | rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); | 593 | r100_vram_init_sizes(rdev); |
| 585 | rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0); | ||
| 586 | } | 594 | } |
| 587 | 595 | ||
| 588 | 596 | ||
| 589 | /* | 597 | /* |
| 590 | * Indirect registers accessor | ||
| 591 | */ | ||
| 592 | uint32_t rv370_pcie_rreg(struct radeon_device *rdev, uint32_t reg) | ||
| 593 | { | ||
| 594 | uint32_t r; | ||
| 595 | |||
| 596 | WREG8(RADEON_PCIE_INDEX, ((reg) & 0xff)); | ||
| 597 | (void)RREG32(RADEON_PCIE_INDEX); | ||
| 598 | r = RREG32(RADEON_PCIE_DATA); | ||
| 599 | return r; | ||
| 600 | } | ||
| 601 | |||
| 602 | void rv370_pcie_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v) | ||
| 603 | { | ||
| 604 | WREG8(RADEON_PCIE_INDEX, ((reg) & 0xff)); | ||
| 605 | (void)RREG32(RADEON_PCIE_INDEX); | ||
| 606 | WREG32(RADEON_PCIE_DATA, (v)); | ||
| 607 | (void)RREG32(RADEON_PCIE_DATA); | ||
| 608 | } | ||
| 609 | |||
| 610 | /* | ||
| 611 | * PCIE Lanes | 598 | * PCIE Lanes |
| 612 | */ | 599 | */ |
| 613 | 600 | ||
| @@ -970,7 +957,7 @@ static inline void r300_cs_track_clear(struct r300_cs_track *track) | |||
| 970 | 957 | ||
| 971 | static const unsigned r300_reg_safe_bm[159] = { | 958 | static const unsigned r300_reg_safe_bm[159] = { |
| 972 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | 959 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, |
| 973 | 0xFFFFFFBF, 0xFFFFFFFF, 0xFFFFFFBF, 0xFFFFFFFF, | 960 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, |
| 974 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | 961 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, |
| 975 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | 962 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, |
| 976 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | 963 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, |
| @@ -1019,7 +1006,7 @@ static int r300_packet0_check(struct radeon_cs_parser *p, | |||
| 1019 | struct radeon_cs_reloc *reloc; | 1006 | struct radeon_cs_reloc *reloc; |
| 1020 | struct r300_cs_track *track; | 1007 | struct r300_cs_track *track; |
| 1021 | volatile uint32_t *ib; | 1008 | volatile uint32_t *ib; |
| 1022 | uint32_t tmp; | 1009 | uint32_t tmp, tile_flags = 0; |
| 1023 | unsigned i; | 1010 | unsigned i; |
| 1024 | int r; | 1011 | int r; |
| 1025 | 1012 | ||
| @@ -1027,6 +1014,16 @@ static int r300_packet0_check(struct radeon_cs_parser *p, | |||
| 1027 | ib_chunk = &p->chunks[p->chunk_ib_idx]; | 1014 | ib_chunk = &p->chunks[p->chunk_ib_idx]; |
| 1028 | track = (struct r300_cs_track*)p->track; | 1015 | track = (struct r300_cs_track*)p->track; |
| 1029 | switch(reg) { | 1016 | switch(reg) { |
| 1017 | case AVIVO_D1MODE_VLINE_START_END: | ||
| 1018 | case RADEON_CRTC_GUI_TRIG_VLINE: | ||
| 1019 | r = r100_cs_packet_parse_vline(p); | ||
| 1020 | if (r) { | ||
| 1021 | DRM_ERROR("No reloc for ib[%d]=0x%04X\n", | ||
| 1022 | idx, reg); | ||
| 1023 | r100_cs_dump_packet(p, pkt); | ||
| 1024 | return r; | ||
| 1025 | } | ||
| 1026 | break; | ||
| 1030 | case RADEON_DST_PITCH_OFFSET: | 1027 | case RADEON_DST_PITCH_OFFSET: |
| 1031 | case RADEON_SRC_PITCH_OFFSET: | 1028 | case RADEON_SRC_PITCH_OFFSET: |
| 1032 | r = r100_cs_packet_next_reloc(p, &reloc); | 1029 | r = r100_cs_packet_next_reloc(p, &reloc); |
| @@ -1038,7 +1035,19 @@ static int r300_packet0_check(struct radeon_cs_parser *p, | |||
| 1038 | } | 1035 | } |
| 1039 | tmp = ib_chunk->kdata[idx] & 0x003fffff; | 1036 | tmp = ib_chunk->kdata[idx] & 0x003fffff; |
| 1040 | tmp += (((u32)reloc->lobj.gpu_offset) >> 10); | 1037 | tmp += (((u32)reloc->lobj.gpu_offset) >> 10); |
| 1041 | ib[idx] = (ib_chunk->kdata[idx] & 0xffc00000) | tmp; | 1038 | |
| 1039 | if (reloc->lobj.tiling_flags & RADEON_TILING_MACRO) | ||
| 1040 | tile_flags |= RADEON_DST_TILE_MACRO; | ||
| 1041 | if (reloc->lobj.tiling_flags & RADEON_TILING_MICRO) { | ||
| 1042 | if (reg == RADEON_SRC_PITCH_OFFSET) { | ||
| 1043 | DRM_ERROR("Cannot src blit from microtiled surface\n"); | ||
| 1044 | r100_cs_dump_packet(p, pkt); | ||
| 1045 | return -EINVAL; | ||
| 1046 | } | ||
| 1047 | tile_flags |= RADEON_DST_TILE_MICRO; | ||
| 1048 | } | ||
| 1049 | tmp |= tile_flags; | ||
| 1050 | ib[idx] = (ib_chunk->kdata[idx] & 0x3fc00000) | tmp; | ||
| 1042 | break; | 1051 | break; |
| 1043 | case R300_RB3D_COLOROFFSET0: | 1052 | case R300_RB3D_COLOROFFSET0: |
| 1044 | case R300_RB3D_COLOROFFSET1: | 1053 | case R300_RB3D_COLOROFFSET1: |
| @@ -1127,6 +1136,23 @@ static int r300_packet0_check(struct radeon_cs_parser *p, | |||
| 1127 | /* RB3D_COLORPITCH1 */ | 1136 | /* RB3D_COLORPITCH1 */ |
| 1128 | /* RB3D_COLORPITCH2 */ | 1137 | /* RB3D_COLORPITCH2 */ |
| 1129 | /* RB3D_COLORPITCH3 */ | 1138 | /* RB3D_COLORPITCH3 */ |
| 1139 | r = r100_cs_packet_next_reloc(p, &reloc); | ||
| 1140 | if (r) { | ||
| 1141 | DRM_ERROR("No reloc for ib[%d]=0x%04X\n", | ||
| 1142 | idx, reg); | ||
| 1143 | r100_cs_dump_packet(p, pkt); | ||
| 1144 | return r; | ||
| 1145 | } | ||
| 1146 | |||
| 1147 | if (reloc->lobj.tiling_flags & RADEON_TILING_MACRO) | ||
| 1148 | tile_flags |= R300_COLOR_TILE_ENABLE; | ||
| 1149 | if (reloc->lobj.tiling_flags & RADEON_TILING_MICRO) | ||
| 1150 | tile_flags |= R300_COLOR_MICROTILE_ENABLE; | ||
| 1151 | |||
| 1152 | tmp = ib_chunk->kdata[idx] & ~(0x7 << 16); | ||
| 1153 | tmp |= tile_flags; | ||
| 1154 | ib[idx] = tmp; | ||
| 1155 | |||
| 1130 | i = (reg - 0x4E38) >> 2; | 1156 | i = (reg - 0x4E38) >> 2; |
| 1131 | track->cb[i].pitch = ib_chunk->kdata[idx] & 0x3FFE; | 1157 | track->cb[i].pitch = ib_chunk->kdata[idx] & 0x3FFE; |
| 1132 | switch (((ib_chunk->kdata[idx] >> 21) & 0xF)) { | 1158 | switch (((ib_chunk->kdata[idx] >> 21) & 0xF)) { |
| @@ -1182,6 +1208,23 @@ static int r300_packet0_check(struct radeon_cs_parser *p, | |||
| 1182 | break; | 1208 | break; |
| 1183 | case 0x4F24: | 1209 | case 0x4F24: |
| 1184 | /* ZB_DEPTHPITCH */ | 1210 | /* ZB_DEPTHPITCH */ |
| 1211 | r = r100_cs_packet_next_reloc(p, &reloc); | ||
| 1212 | if (r) { | ||
| 1213 | DRM_ERROR("No reloc for ib[%d]=0x%04X\n", | ||
| 1214 | idx, reg); | ||
| 1215 | r100_cs_dump_packet(p, pkt); | ||
| 1216 | return r; | ||
| 1217 | } | ||
| 1218 | |||
| 1219 | if (reloc->lobj.tiling_flags & RADEON_TILING_MACRO) | ||
| 1220 | tile_flags |= R300_DEPTHMACROTILE_ENABLE; | ||
| 1221 | if (reloc->lobj.tiling_flags & RADEON_TILING_MICRO) | ||
| 1222 | tile_flags |= R300_DEPTHMICROTILE_TILED;; | ||
| 1223 | |||
| 1224 | tmp = ib_chunk->kdata[idx] & ~(0x7 << 16); | ||
| 1225 | tmp |= tile_flags; | ||
| 1226 | ib[idx] = tmp; | ||
| 1227 | |||
| 1185 | track->zb.pitch = ib_chunk->kdata[idx] & 0x3FFC; | 1228 | track->zb.pitch = ib_chunk->kdata[idx] & 0x3FFC; |
| 1186 | break; | 1229 | break; |
| 1187 | case 0x4104: | 1230 | case 0x4104: |
| @@ -1341,6 +1384,21 @@ static int r300_packet0_check(struct radeon_cs_parser *p, | |||
| 1341 | tmp = (ib_chunk->kdata[idx] >> 22) & 0xF; | 1384 | tmp = (ib_chunk->kdata[idx] >> 22) & 0xF; |
| 1342 | track->textures[i].txdepth = tmp; | 1385 | track->textures[i].txdepth = tmp; |
| 1343 | break; | 1386 | break; |
| 1387 | case R300_ZB_ZPASS_ADDR: | ||
| 1388 | r = r100_cs_packet_next_reloc(p, &reloc); | ||
| 1389 | if (r) { | ||
| 1390 | DRM_ERROR("No reloc for ib[%d]=0x%04X\n", | ||
| 1391 | idx, reg); | ||
| 1392 | r100_cs_dump_packet(p, pkt); | ||
| 1393 | return r; | ||
| 1394 | } | ||
| 1395 | ib[idx] = ib_chunk->kdata[idx] + ((u32)reloc->lobj.gpu_offset); | ||
| 1396 | break; | ||
| 1397 | case 0x4be8: | ||
| 1398 | /* valid register only on RV530 */ | ||
| 1399 | if (p->rdev->family == CHIP_RV530) | ||
| 1400 | break; | ||
| 1401 | /* fallthrough do not move */ | ||
| 1344 | default: | 1402 | default: |
| 1345 | printk(KERN_ERR "Forbidden register 0x%04X in cs at %d\n", | 1403 | printk(KERN_ERR "Forbidden register 0x%04X in cs at %d\n", |
| 1346 | reg, idx); | 1404 | reg, idx); |
diff --git a/drivers/gpu/drm/radeon/r300_reg.h b/drivers/gpu/drm/radeon/r300_reg.h index 70f48609515e..4b7afef35a65 100644 --- a/drivers/gpu/drm/radeon/r300_reg.h +++ b/drivers/gpu/drm/radeon/r300_reg.h | |||
| @@ -27,7 +27,9 @@ | |||
| 27 | #ifndef _R300_REG_H_ | 27 | #ifndef _R300_REG_H_ |
| 28 | #define _R300_REG_H_ | 28 | #define _R300_REG_H_ |
| 29 | 29 | ||
| 30 | 30 | #define R300_SURF_TILE_MACRO (1<<16) | |
| 31 | #define R300_SURF_TILE_MICRO (2<<16) | ||
| 32 | #define R300_SURF_TILE_BOTH (3<<16) | ||
| 31 | 33 | ||
| 32 | 34 | ||
| 33 | #define R300_MC_INIT_MISC_LAT_TIMER 0x180 | 35 | #define R300_MC_INIT_MISC_LAT_TIMER 0x180 |
diff --git a/drivers/gpu/drm/radeon/r420.c b/drivers/gpu/drm/radeon/r420.c index dea497a979f2..97426a6f370f 100644 --- a/drivers/gpu/drm/radeon/r420.c +++ b/drivers/gpu/drm/radeon/r420.c | |||
| @@ -165,7 +165,18 @@ void r420_pipes_init(struct radeon_device *rdev) | |||
| 165 | printk(KERN_WARNING "Failed to wait GUI idle while " | 165 | printk(KERN_WARNING "Failed to wait GUI idle while " |
| 166 | "programming pipes. Bad things might happen.\n"); | 166 | "programming pipes. Bad things might happen.\n"); |
| 167 | } | 167 | } |
| 168 | DRM_INFO("radeon: %d pipes initialized.\n", rdev->num_gb_pipes); | 168 | |
| 169 | if (rdev->family == CHIP_RV530) { | ||
| 170 | tmp = RREG32(RV530_GB_PIPE_SELECT2); | ||
| 171 | if ((tmp & 3) == 3) | ||
| 172 | rdev->num_z_pipes = 2; | ||
| 173 | else | ||
| 174 | rdev->num_z_pipes = 1; | ||
| 175 | } else | ||
| 176 | rdev->num_z_pipes = 1; | ||
| 177 | |||
| 178 | DRM_INFO("radeon: %d quad pipes, %d z pipes initialized.\n", | ||
| 179 | rdev->num_gb_pipes, rdev->num_z_pipes); | ||
| 169 | } | 180 | } |
| 170 | 181 | ||
| 171 | void r420_gpu_init(struct radeon_device *rdev) | 182 | void r420_gpu_init(struct radeon_device *rdev) |
diff --git a/drivers/gpu/drm/radeon/r500_reg.h b/drivers/gpu/drm/radeon/r500_reg.h index 9070a1c2ce23..e1d5e0331e19 100644 --- a/drivers/gpu/drm/radeon/r500_reg.h +++ b/drivers/gpu/drm/radeon/r500_reg.h | |||
| @@ -350,6 +350,7 @@ | |||
| 350 | #define AVIVO_D1CRTC_BLANK_CONTROL 0x6084 | 350 | #define AVIVO_D1CRTC_BLANK_CONTROL 0x6084 |
| 351 | #define AVIVO_D1CRTC_INTERLACE_CONTROL 0x6088 | 351 | #define AVIVO_D1CRTC_INTERLACE_CONTROL 0x6088 |
| 352 | #define AVIVO_D1CRTC_INTERLACE_STATUS 0x608c | 352 | #define AVIVO_D1CRTC_INTERLACE_STATUS 0x608c |
| 353 | #define AVIVO_D1CRTC_FRAME_COUNT 0x60a4 | ||
| 353 | #define AVIVO_D1CRTC_STEREO_CONTROL 0x60c4 | 354 | #define AVIVO_D1CRTC_STEREO_CONTROL 0x60c4 |
| 354 | 355 | ||
| 355 | /* master controls */ | 356 | /* master controls */ |
| @@ -438,13 +439,15 @@ | |||
| 438 | # define AVIVO_DC_LB_DISP1_END_ADR_SHIFT 4 | 439 | # define AVIVO_DC_LB_DISP1_END_ADR_SHIFT 4 |
| 439 | # define AVIVO_DC_LB_DISP1_END_ADR_MASK 0x7ff | 440 | # define AVIVO_DC_LB_DISP1_END_ADR_MASK 0x7ff |
| 440 | 441 | ||
| 441 | #define R500_DxMODE_INT_MASK 0x6540 | ||
| 442 | #define R500_D1MODE_INT_MASK (1<<0) | ||
| 443 | #define R500_D2MODE_INT_MASK (1<<8) | ||
| 444 | |||
| 445 | #define AVIVO_D1MODE_DATA_FORMAT 0x6528 | 442 | #define AVIVO_D1MODE_DATA_FORMAT 0x6528 |
| 446 | # define AVIVO_D1MODE_INTERLEAVE_EN (1 << 0) | 443 | # define AVIVO_D1MODE_INTERLEAVE_EN (1 << 0) |
| 447 | #define AVIVO_D1MODE_DESKTOP_HEIGHT 0x652C | 444 | #define AVIVO_D1MODE_DESKTOP_HEIGHT 0x652C |
| 445 | #define AVIVO_D1MODE_VBLANK_STATUS 0x6534 | ||
| 446 | # define AVIVO_VBLANK_ACK (1 << 4) | ||
| 447 | #define AVIVO_D1MODE_VLINE_START_END 0x6538 | ||
| 448 | #define AVIVO_DxMODE_INT_MASK 0x6540 | ||
| 449 | # define AVIVO_D1MODE_INT_MASK (1 << 0) | ||
| 450 | # define AVIVO_D2MODE_INT_MASK (1 << 8) | ||
| 448 | #define AVIVO_D1MODE_VIEWPORT_START 0x6580 | 451 | #define AVIVO_D1MODE_VIEWPORT_START 0x6580 |
| 449 | #define AVIVO_D1MODE_VIEWPORT_SIZE 0x6584 | 452 | #define AVIVO_D1MODE_VIEWPORT_SIZE 0x6584 |
| 450 | #define AVIVO_D1MODE_EXT_OVERSCAN_LEFT_RIGHT 0x6588 | 453 | #define AVIVO_D1MODE_EXT_OVERSCAN_LEFT_RIGHT 0x6588 |
| @@ -474,6 +477,7 @@ | |||
| 474 | #define AVIVO_D2CRTC_BLANK_CONTROL 0x6884 | 477 | #define AVIVO_D2CRTC_BLANK_CONTROL 0x6884 |
| 475 | #define AVIVO_D2CRTC_INTERLACE_CONTROL 0x6888 | 478 | #define AVIVO_D2CRTC_INTERLACE_CONTROL 0x6888 |
| 476 | #define AVIVO_D2CRTC_INTERLACE_STATUS 0x688c | 479 | #define AVIVO_D2CRTC_INTERLACE_STATUS 0x688c |
| 480 | #define AVIVO_D2CRTC_FRAME_COUNT 0x68a4 | ||
| 477 | #define AVIVO_D2CRTC_STEREO_CONTROL 0x68c4 | 481 | #define AVIVO_D2CRTC_STEREO_CONTROL 0x68c4 |
| 478 | 482 | ||
| 479 | #define AVIVO_D2GRPH_ENABLE 0x6900 | 483 | #define AVIVO_D2GRPH_ENABLE 0x6900 |
| @@ -496,6 +500,8 @@ | |||
| 496 | #define AVIVO_D2CUR_SIZE 0x6c10 | 500 | #define AVIVO_D2CUR_SIZE 0x6c10 |
| 497 | #define AVIVO_D2CUR_POSITION 0x6c14 | 501 | #define AVIVO_D2CUR_POSITION 0x6c14 |
| 498 | 502 | ||
| 503 | #define AVIVO_D2MODE_VBLANK_STATUS 0x6d34 | ||
| 504 | #define AVIVO_D2MODE_VLINE_START_END 0x6d38 | ||
| 499 | #define AVIVO_D2MODE_VIEWPORT_START 0x6d80 | 505 | #define AVIVO_D2MODE_VIEWPORT_START 0x6d80 |
| 500 | #define AVIVO_D2MODE_VIEWPORT_SIZE 0x6d84 | 506 | #define AVIVO_D2MODE_VIEWPORT_SIZE 0x6d84 |
| 501 | #define AVIVO_D2MODE_EXT_OVERSCAN_LEFT_RIGHT 0x6d88 | 507 | #define AVIVO_D2MODE_EXT_OVERSCAN_LEFT_RIGHT 0x6d88 |
| @@ -746,4 +752,8 @@ | |||
| 746 | # define AVIVO_I2C_EN (1 << 0) | 752 | # define AVIVO_I2C_EN (1 << 0) |
| 747 | # define AVIVO_I2C_RESET (1 << 8) | 753 | # define AVIVO_I2C_RESET (1 << 8) |
| 748 | 754 | ||
| 755 | #define AVIVO_DISP_INTERRUPT_STATUS 0x7edc | ||
| 756 | # define AVIVO_D1_VBLANK_INTERRUPT (1 << 4) | ||
| 757 | # define AVIVO_D2_VBLANK_INTERRUPT (1 << 5) | ||
| 758 | |||
| 749 | #endif | 759 | #endif |
diff --git a/drivers/gpu/drm/radeon/r520.c b/drivers/gpu/drm/radeon/r520.c index 570a244bd88b..ebd6b0f7bdff 100644 --- a/drivers/gpu/drm/radeon/r520.c +++ b/drivers/gpu/drm/radeon/r520.c | |||
| @@ -28,6 +28,7 @@ | |||
| 28 | #include "drmP.h" | 28 | #include "drmP.h" |
| 29 | #include "radeon_reg.h" | 29 | #include "radeon_reg.h" |
| 30 | #include "radeon.h" | 30 | #include "radeon.h" |
| 31 | #include "radeon_share.h" | ||
| 31 | 32 | ||
| 32 | /* r520,rv530,rv560,rv570,r580 depends on : */ | 33 | /* r520,rv530,rv560,rv570,r580 depends on : */ |
| 33 | void r100_hdp_reset(struct radeon_device *rdev); | 34 | void r100_hdp_reset(struct radeon_device *rdev); |
| @@ -94,8 +95,8 @@ int r520_mc_init(struct radeon_device *rdev) | |||
| 94 | "programming pipes. Bad things might happen.\n"); | 95 | "programming pipes. Bad things might happen.\n"); |
| 95 | } | 96 | } |
| 96 | /* Write VRAM size in case we are limiting it */ | 97 | /* Write VRAM size in case we are limiting it */ |
| 97 | WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.vram_size); | 98 | WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.real_vram_size); |
| 98 | tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; | 99 | tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1; |
| 99 | tmp = REG_SET(R520_MC_FB_TOP, tmp >> 16); | 100 | tmp = REG_SET(R520_MC_FB_TOP, tmp >> 16); |
| 100 | tmp |= REG_SET(R520_MC_FB_START, rdev->mc.vram_location >> 16); | 101 | tmp |= REG_SET(R520_MC_FB_START, rdev->mc.vram_location >> 16); |
| 101 | WREG32_MC(R520_MC_FB_LOCATION, tmp); | 102 | WREG32_MC(R520_MC_FB_LOCATION, tmp); |
| @@ -176,7 +177,6 @@ void r520_gpu_init(struct radeon_device *rdev) | |||
| 176 | */ | 177 | */ |
| 177 | /* workaround for RV530 */ | 178 | /* workaround for RV530 */ |
| 178 | if (rdev->family == CHIP_RV530) { | 179 | if (rdev->family == CHIP_RV530) { |
| 179 | WREG32(0x4124, 1); | ||
| 180 | WREG32(0x4128, 0xFF); | 180 | WREG32(0x4128, 0xFF); |
| 181 | } | 181 | } |
| 182 | r420_pipes_init(rdev); | 182 | r420_pipes_init(rdev); |
| @@ -226,9 +226,20 @@ static void r520_vram_get_type(struct radeon_device *rdev) | |||
| 226 | 226 | ||
| 227 | void r520_vram_info(struct radeon_device *rdev) | 227 | void r520_vram_info(struct radeon_device *rdev) |
| 228 | { | 228 | { |
| 229 | fixed20_12 a; | ||
| 230 | |||
| 229 | r520_vram_get_type(rdev); | 231 | r520_vram_get_type(rdev); |
| 230 | rdev->mc.vram_size = RREG32(RADEON_CONFIG_MEMSIZE); | ||
| 231 | 232 | ||
| 232 | rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); | 233 | r100_vram_init_sizes(rdev); |
| 233 | rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0); | 234 | /* FIXME: we should enforce default clock in case GPU is not in |
| 235 | * default setup | ||
| 236 | */ | ||
| 237 | a.full = rfixed_const(100); | ||
| 238 | rdev->pm.sclk.full = rfixed_const(rdev->clock.default_sclk); | ||
| 239 | rdev->pm.sclk.full = rfixed_div(rdev->pm.sclk, a); | ||
| 240 | } | ||
| 241 | |||
| 242 | void r520_bandwidth_update(struct radeon_device *rdev) | ||
| 243 | { | ||
| 244 | rv515_bandwidth_avivo_update(rdev); | ||
| 234 | } | 245 | } |
diff --git a/drivers/gpu/drm/radeon/r600.c b/drivers/gpu/drm/radeon/r600.c index c45559fc97fd..538cd907df69 100644 --- a/drivers/gpu/drm/radeon/r600.c +++ b/drivers/gpu/drm/radeon/r600.c | |||
| @@ -67,7 +67,7 @@ int r600_mc_init(struct radeon_device *rdev) | |||
| 67 | "programming pipes. Bad things might happen.\n"); | 67 | "programming pipes. Bad things might happen.\n"); |
| 68 | } | 68 | } |
| 69 | 69 | ||
| 70 | tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; | 70 | tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1; |
| 71 | tmp = REG_SET(R600_MC_FB_TOP, tmp >> 24); | 71 | tmp = REG_SET(R600_MC_FB_TOP, tmp >> 24); |
| 72 | tmp |= REG_SET(R600_MC_FB_BASE, rdev->mc.vram_location >> 24); | 72 | tmp |= REG_SET(R600_MC_FB_BASE, rdev->mc.vram_location >> 24); |
| 73 | WREG32(R600_MC_VM_FB_LOCATION, tmp); | 73 | WREG32(R600_MC_VM_FB_LOCATION, tmp); |
| @@ -140,7 +140,8 @@ void r600_vram_get_type(struct radeon_device *rdev) | |||
| 140 | void r600_vram_info(struct radeon_device *rdev) | 140 | void r600_vram_info(struct radeon_device *rdev) |
| 141 | { | 141 | { |
| 142 | r600_vram_get_type(rdev); | 142 | r600_vram_get_type(rdev); |
| 143 | rdev->mc.vram_size = RREG32(R600_CONFIG_MEMSIZE); | 143 | rdev->mc.real_vram_size = RREG32(R600_CONFIG_MEMSIZE); |
| 144 | rdev->mc.mc_vram_size = rdev->mc.real_vram_size; | ||
| 144 | 145 | ||
| 145 | /* Could aper size report 0 ? */ | 146 | /* Could aper size report 0 ? */ |
| 146 | rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); | 147 | rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); |
diff --git a/drivers/gpu/drm/radeon/r600_cp.c b/drivers/gpu/drm/radeon/r600_cp.c index 146f3570af8e..20f17908b036 100644 --- a/drivers/gpu/drm/radeon/r600_cp.c +++ b/drivers/gpu/drm/radeon/r600_cp.c | |||
| @@ -384,8 +384,9 @@ static void r600_cp_load_microcode(drm_radeon_private_t *dev_priv) | |||
| 384 | DRM_INFO("Loading RV670 PFP Microcode\n"); | 384 | DRM_INFO("Loading RV670 PFP Microcode\n"); |
| 385 | for (i = 0; i < PFP_UCODE_SIZE; i++) | 385 | for (i = 0; i < PFP_UCODE_SIZE; i++) |
| 386 | RADEON_WRITE(R600_CP_PFP_UCODE_DATA, RV670_pfp_microcode[i]); | 386 | RADEON_WRITE(R600_CP_PFP_UCODE_DATA, RV670_pfp_microcode[i]); |
| 387 | } else if (((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS780)) { | 387 | } else if (((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS780) || |
| 388 | DRM_INFO("Loading RS780 CP Microcode\n"); | 388 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS880)) { |
| 389 | DRM_INFO("Loading RS780/RS880 CP Microcode\n"); | ||
| 389 | for (i = 0; i < PM4_UCODE_SIZE; i++) { | 390 | for (i = 0; i < PM4_UCODE_SIZE; i++) { |
| 390 | RADEON_WRITE(R600_CP_ME_RAM_DATA, | 391 | RADEON_WRITE(R600_CP_ME_RAM_DATA, |
| 391 | RS780_cp_microcode[i][0]); | 392 | RS780_cp_microcode[i][0]); |
| @@ -396,7 +397,7 @@ static void r600_cp_load_microcode(drm_radeon_private_t *dev_priv) | |||
| 396 | } | 397 | } |
| 397 | 398 | ||
| 398 | RADEON_WRITE(R600_CP_PFP_UCODE_ADDR, 0); | 399 | RADEON_WRITE(R600_CP_PFP_UCODE_ADDR, 0); |
| 399 | DRM_INFO("Loading RS780 PFP Microcode\n"); | 400 | DRM_INFO("Loading RS780/RS880 PFP Microcode\n"); |
| 400 | for (i = 0; i < PFP_UCODE_SIZE; i++) | 401 | for (i = 0; i < PFP_UCODE_SIZE; i++) |
| 401 | RADEON_WRITE(R600_CP_PFP_UCODE_DATA, RS780_pfp_microcode[i]); | 402 | RADEON_WRITE(R600_CP_PFP_UCODE_DATA, RS780_pfp_microcode[i]); |
| 402 | } | 403 | } |
| @@ -783,6 +784,7 @@ static void r600_gfx_init(struct drm_device *dev, | |||
| 783 | break; | 784 | break; |
| 784 | case CHIP_RV610: | 785 | case CHIP_RV610: |
| 785 | case CHIP_RS780: | 786 | case CHIP_RS780: |
| 787 | case CHIP_RS880: | ||
| 786 | case CHIP_RV620: | 788 | case CHIP_RV620: |
| 787 | dev_priv->r600_max_pipes = 1; | 789 | dev_priv->r600_max_pipes = 1; |
| 788 | dev_priv->r600_max_tile_pipes = 1; | 790 | dev_priv->r600_max_tile_pipes = 1; |
| @@ -917,7 +919,8 @@ static void r600_gfx_init(struct drm_device *dev, | |||
| 917 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV630) || | 919 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV630) || |
| 918 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV610) || | 920 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV610) || |
| 919 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV620) || | 921 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV620) || |
| 920 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS780)) | 922 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS780) || |
| 923 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS880)) | ||
| 921 | RADEON_WRITE(R600_DB_DEBUG, R600_PREZ_MUST_WAIT_FOR_POSTZ_DONE); | 924 | RADEON_WRITE(R600_DB_DEBUG, R600_PREZ_MUST_WAIT_FOR_POSTZ_DONE); |
| 922 | else | 925 | else |
| 923 | RADEON_WRITE(R600_DB_DEBUG, 0); | 926 | RADEON_WRITE(R600_DB_DEBUG, 0); |
| @@ -935,7 +938,8 @@ static void r600_gfx_init(struct drm_device *dev, | |||
| 935 | sq_ms_fifo_sizes = RADEON_READ(R600_SQ_MS_FIFO_SIZES); | 938 | sq_ms_fifo_sizes = RADEON_READ(R600_SQ_MS_FIFO_SIZES); |
| 936 | if (((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV610) || | 939 | if (((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV610) || |
| 937 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV620) || | 940 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV620) || |
| 938 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS780)) { | 941 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS780) || |
| 942 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS880)) { | ||
| 939 | sq_ms_fifo_sizes = (R600_CACHE_FIFO_SIZE(0xa) | | 943 | sq_ms_fifo_sizes = (R600_CACHE_FIFO_SIZE(0xa) | |
| 940 | R600_FETCH_FIFO_HIWATER(0xa) | | 944 | R600_FETCH_FIFO_HIWATER(0xa) | |
| 941 | R600_DONE_FIFO_HIWATER(0xe0) | | 945 | R600_DONE_FIFO_HIWATER(0xe0) | |
| @@ -978,7 +982,8 @@ static void r600_gfx_init(struct drm_device *dev, | |||
| 978 | R600_NUM_ES_STACK_ENTRIES(0)); | 982 | R600_NUM_ES_STACK_ENTRIES(0)); |
| 979 | } else if (((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV610) || | 983 | } else if (((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV610) || |
| 980 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV620) || | 984 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV620) || |
| 981 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS780)) { | 985 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS780) || |
| 986 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS880)) { | ||
| 982 | /* no vertex cache */ | 987 | /* no vertex cache */ |
| 983 | sq_config &= ~R600_VC_ENABLE; | 988 | sq_config &= ~R600_VC_ENABLE; |
| 984 | 989 | ||
| @@ -1035,7 +1040,8 @@ static void r600_gfx_init(struct drm_device *dev, | |||
| 1035 | 1040 | ||
| 1036 | if (((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV610) || | 1041 | if (((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV610) || |
| 1037 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV620) || | 1042 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV620) || |
| 1038 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS780)) | 1043 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS780) || |
| 1044 | ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RS880)) | ||
| 1039 | RADEON_WRITE(R600_VGT_CACHE_INVALIDATION, R600_CACHE_INVALIDATION(R600_TC_ONLY)); | 1045 | RADEON_WRITE(R600_VGT_CACHE_INVALIDATION, R600_CACHE_INVALIDATION(R600_TC_ONLY)); |
| 1040 | else | 1046 | else |
| 1041 | RADEON_WRITE(R600_VGT_CACHE_INVALIDATION, R600_CACHE_INVALIDATION(R600_VC_AND_TC)); | 1047 | RADEON_WRITE(R600_VGT_CACHE_INVALIDATION, R600_CACHE_INVALIDATION(R600_VC_AND_TC)); |
| @@ -1078,6 +1084,7 @@ static void r600_gfx_init(struct drm_device *dev, | |||
| 1078 | break; | 1084 | break; |
| 1079 | case CHIP_RV610: | 1085 | case CHIP_RV610: |
| 1080 | case CHIP_RS780: | 1086 | case CHIP_RS780: |
| 1087 | case CHIP_RS880: | ||
| 1081 | case CHIP_RV620: | 1088 | case CHIP_RV620: |
| 1082 | gs_prim_buffer_depth = 32; | 1089 | gs_prim_buffer_depth = 32; |
| 1083 | break; | 1090 | break; |
| @@ -1123,6 +1130,7 @@ static void r600_gfx_init(struct drm_device *dev, | |||
| 1123 | switch (dev_priv->flags & RADEON_FAMILY_MASK) { | 1130 | switch (dev_priv->flags & RADEON_FAMILY_MASK) { |
| 1124 | case CHIP_RV610: | 1131 | case CHIP_RV610: |
| 1125 | case CHIP_RS780: | 1132 | case CHIP_RS780: |
| 1133 | case CHIP_RS880: | ||
| 1126 | case CHIP_RV620: | 1134 | case CHIP_RV620: |
| 1127 | tc_cntl = R600_TC_L2_SIZE(8); | 1135 | tc_cntl = R600_TC_L2_SIZE(8); |
| 1128 | break; | 1136 | break; |
diff --git a/drivers/gpu/drm/radeon/radeon.h b/drivers/gpu/drm/radeon/radeon.h index d61f2fc61df5..b519fb2fecbb 100644 --- a/drivers/gpu/drm/radeon/radeon.h +++ b/drivers/gpu/drm/radeon/radeon.h | |||
| @@ -64,6 +64,7 @@ extern int radeon_agpmode; | |||
| 64 | extern int radeon_vram_limit; | 64 | extern int radeon_vram_limit; |
| 65 | extern int radeon_gart_size; | 65 | extern int radeon_gart_size; |
| 66 | extern int radeon_benchmarking; | 66 | extern int radeon_benchmarking; |
| 67 | extern int radeon_testing; | ||
| 67 | extern int radeon_connector_table; | 68 | extern int radeon_connector_table; |
| 68 | 69 | ||
| 69 | /* | 70 | /* |
| @@ -113,6 +114,7 @@ enum radeon_family { | |||
| 113 | CHIP_RV770, | 114 | CHIP_RV770, |
| 114 | CHIP_RV730, | 115 | CHIP_RV730, |
| 115 | CHIP_RV710, | 116 | CHIP_RV710, |
| 117 | CHIP_RS880, | ||
| 116 | CHIP_LAST, | 118 | CHIP_LAST, |
| 117 | }; | 119 | }; |
| 118 | 120 | ||
| @@ -201,6 +203,14 @@ int radeon_fence_wait_last(struct radeon_device *rdev); | |||
| 201 | struct radeon_fence *radeon_fence_ref(struct radeon_fence *fence); | 203 | struct radeon_fence *radeon_fence_ref(struct radeon_fence *fence); |
| 202 | void radeon_fence_unref(struct radeon_fence **fence); | 204 | void radeon_fence_unref(struct radeon_fence **fence); |
| 203 | 205 | ||
| 206 | /* | ||
| 207 | * Tiling registers | ||
| 208 | */ | ||
| 209 | struct radeon_surface_reg { | ||
| 210 | struct radeon_object *robj; | ||
| 211 | }; | ||
| 212 | |||
| 213 | #define RADEON_GEM_MAX_SURFACES 8 | ||
| 204 | 214 | ||
| 205 | /* | 215 | /* |
| 206 | * Radeon buffer. | 216 | * Radeon buffer. |
| @@ -213,6 +223,7 @@ struct radeon_object_list { | |||
| 213 | uint64_t gpu_offset; | 223 | uint64_t gpu_offset; |
| 214 | unsigned rdomain; | 224 | unsigned rdomain; |
| 215 | unsigned wdomain; | 225 | unsigned wdomain; |
| 226 | uint32_t tiling_flags; | ||
| 216 | }; | 227 | }; |
| 217 | 228 | ||
| 218 | int radeon_object_init(struct radeon_device *rdev); | 229 | int radeon_object_init(struct radeon_device *rdev); |
| @@ -231,6 +242,7 @@ int radeon_object_pin(struct radeon_object *robj, uint32_t domain, | |||
| 231 | uint64_t *gpu_addr); | 242 | uint64_t *gpu_addr); |
| 232 | void radeon_object_unpin(struct radeon_object *robj); | 243 | void radeon_object_unpin(struct radeon_object *robj); |
| 233 | int radeon_object_wait(struct radeon_object *robj); | 244 | int radeon_object_wait(struct radeon_object *robj); |
| 245 | int radeon_object_busy_domain(struct radeon_object *robj, uint32_t *cur_placement); | ||
| 234 | int radeon_object_evict_vram(struct radeon_device *rdev); | 246 | int radeon_object_evict_vram(struct radeon_device *rdev); |
| 235 | int radeon_object_mmap(struct radeon_object *robj, uint64_t *offset); | 247 | int radeon_object_mmap(struct radeon_object *robj, uint64_t *offset); |
| 236 | void radeon_object_force_delete(struct radeon_device *rdev); | 248 | void radeon_object_force_delete(struct radeon_device *rdev); |
| @@ -242,8 +254,15 @@ void radeon_object_list_clean(struct list_head *head); | |||
| 242 | int radeon_object_fbdev_mmap(struct radeon_object *robj, | 254 | int radeon_object_fbdev_mmap(struct radeon_object *robj, |
| 243 | struct vm_area_struct *vma); | 255 | struct vm_area_struct *vma); |
| 244 | unsigned long radeon_object_size(struct radeon_object *robj); | 256 | unsigned long radeon_object_size(struct radeon_object *robj); |
| 245 | 257 | void radeon_object_clear_surface_reg(struct radeon_object *robj); | |
| 246 | 258 | int radeon_object_check_tiling(struct radeon_object *robj, bool has_moved, | |
| 259 | bool force_drop); | ||
| 260 | void radeon_object_set_tiling_flags(struct radeon_object *robj, | ||
| 261 | uint32_t tiling_flags, uint32_t pitch); | ||
| 262 | void radeon_object_get_tiling_flags(struct radeon_object *robj, uint32_t *tiling_flags, uint32_t *pitch); | ||
| 263 | void radeon_bo_move_notify(struct ttm_buffer_object *bo, | ||
| 264 | struct ttm_mem_reg *mem); | ||
| 265 | void radeon_bo_fault_reserve_notify(struct ttm_buffer_object *bo); | ||
| 247 | /* | 266 | /* |
| 248 | * GEM objects. | 267 | * GEM objects. |
| 249 | */ | 268 | */ |
| @@ -315,8 +334,11 @@ struct radeon_mc { | |||
| 315 | unsigned gtt_location; | 334 | unsigned gtt_location; |
| 316 | unsigned gtt_size; | 335 | unsigned gtt_size; |
| 317 | unsigned vram_location; | 336 | unsigned vram_location; |
| 318 | unsigned vram_size; | 337 | /* for some chips with <= 32MB we need to lie |
| 338 | * about vram size near mc fb location */ | ||
| 339 | unsigned mc_vram_size; | ||
| 319 | unsigned vram_width; | 340 | unsigned vram_width; |
| 341 | unsigned real_vram_size; | ||
| 320 | int vram_mtrr; | 342 | int vram_mtrr; |
| 321 | bool vram_is_ddr; | 343 | bool vram_is_ddr; |
| 322 | }; | 344 | }; |
| @@ -474,6 +496,39 @@ struct radeon_wb { | |||
| 474 | uint64_t gpu_addr; | 496 | uint64_t gpu_addr; |
| 475 | }; | 497 | }; |
| 476 | 498 | ||
| 499 | /** | ||
| 500 | * struct radeon_pm - power management datas | ||
| 501 | * @max_bandwidth: maximum bandwidth the gpu has (MByte/s) | ||
| 502 | * @igp_sideport_mclk: sideport memory clock Mhz (rs690,rs740,rs780,rs880) | ||
| 503 | * @igp_system_mclk: system clock Mhz (rs690,rs740,rs780,rs880) | ||
| 504 | * @igp_ht_link_clk: ht link clock Mhz (rs690,rs740,rs780,rs880) | ||
| 505 | * @igp_ht_link_width: ht link width in bits (rs690,rs740,rs780,rs880) | ||
| 506 | * @k8_bandwidth: k8 bandwidth the gpu has (MByte/s) (IGP) | ||
| 507 | * @sideport_bandwidth: sideport bandwidth the gpu has (MByte/s) (IGP) | ||
| 508 | * @ht_bandwidth: ht bandwidth the gpu has (MByte/s) (IGP) | ||
| 509 | * @core_bandwidth: core GPU bandwidth the gpu has (MByte/s) (IGP) | ||
| 510 | * @sclk: GPU clock Mhz (core bandwith depends of this clock) | ||
| 511 | * @needed_bandwidth: current bandwidth needs | ||
| 512 | * | ||
| 513 | * It keeps track of various data needed to take powermanagement decision. | ||
| 514 | * Bandwith need is used to determine minimun clock of the GPU and memory. | ||
| 515 | * Equation between gpu/memory clock and available bandwidth is hw dependent | ||
| 516 | * (type of memory, bus size, efficiency, ...) | ||
| 517 | */ | ||
| 518 | struct radeon_pm { | ||
| 519 | fixed20_12 max_bandwidth; | ||
| 520 | fixed20_12 igp_sideport_mclk; | ||
| 521 | fixed20_12 igp_system_mclk; | ||
| 522 | fixed20_12 igp_ht_link_clk; | ||
| 523 | fixed20_12 igp_ht_link_width; | ||
| 524 | fixed20_12 k8_bandwidth; | ||
| 525 | fixed20_12 sideport_bandwidth; | ||
| 526 | fixed20_12 ht_bandwidth; | ||
| 527 | fixed20_12 core_bandwidth; | ||
| 528 | fixed20_12 sclk; | ||
| 529 | fixed20_12 needed_bandwidth; | ||
| 530 | }; | ||
| 531 | |||
| 477 | 532 | ||
| 478 | /* | 533 | /* |
| 479 | * Benchmarking | 534 | * Benchmarking |
| @@ -482,6 +537,12 @@ void radeon_benchmark(struct radeon_device *rdev); | |||
| 482 | 537 | ||
| 483 | 538 | ||
| 484 | /* | 539 | /* |
| 540 | * Testing | ||
| 541 | */ | ||
| 542 | void radeon_test_moves(struct radeon_device *rdev); | ||
| 543 | |||
| 544 | |||
| 545 | /* | ||
| 485 | * Debugfs | 546 | * Debugfs |
| 486 | */ | 547 | */ |
| 487 | int radeon_debugfs_add_files(struct radeon_device *rdev, | 548 | int radeon_debugfs_add_files(struct radeon_device *rdev, |
| @@ -514,6 +575,7 @@ struct radeon_asic { | |||
| 514 | void (*ring_start)(struct radeon_device *rdev); | 575 | void (*ring_start)(struct radeon_device *rdev); |
| 515 | int (*irq_set)(struct radeon_device *rdev); | 576 | int (*irq_set)(struct radeon_device *rdev); |
| 516 | int (*irq_process)(struct radeon_device *rdev); | 577 | int (*irq_process)(struct radeon_device *rdev); |
| 578 | u32 (*get_vblank_counter)(struct radeon_device *rdev, int crtc); | ||
| 517 | void (*fence_ring_emit)(struct radeon_device *rdev, struct radeon_fence *fence); | 579 | void (*fence_ring_emit)(struct radeon_device *rdev, struct radeon_fence *fence); |
| 518 | int (*cs_parse)(struct radeon_cs_parser *p); | 580 | int (*cs_parse)(struct radeon_cs_parser *p); |
| 519 | int (*copy_blit)(struct radeon_device *rdev, | 581 | int (*copy_blit)(struct radeon_device *rdev, |
| @@ -535,6 +597,11 @@ struct radeon_asic { | |||
| 535 | void (*set_memory_clock)(struct radeon_device *rdev, uint32_t mem_clock); | 597 | void (*set_memory_clock)(struct radeon_device *rdev, uint32_t mem_clock); |
| 536 | void (*set_pcie_lanes)(struct radeon_device *rdev, int lanes); | 598 | void (*set_pcie_lanes)(struct radeon_device *rdev, int lanes); |
| 537 | void (*set_clock_gating)(struct radeon_device *rdev, int enable); | 599 | void (*set_clock_gating)(struct radeon_device *rdev, int enable); |
| 600 | int (*set_surface_reg)(struct radeon_device *rdev, int reg, | ||
| 601 | uint32_t tiling_flags, uint32_t pitch, | ||
| 602 | uint32_t offset, uint32_t obj_size); | ||
| 603 | int (*clear_surface_reg)(struct radeon_device *rdev, int reg); | ||
| 604 | void (*bandwidth_update)(struct radeon_device *rdev); | ||
| 538 | }; | 605 | }; |
| 539 | 606 | ||
| 540 | union radeon_asic_config { | 607 | union radeon_asic_config { |
| @@ -566,6 +633,10 @@ int radeon_gem_busy_ioctl(struct drm_device *dev, void *data, | |||
| 566 | int radeon_gem_wait_idle_ioctl(struct drm_device *dev, void *data, | 633 | int radeon_gem_wait_idle_ioctl(struct drm_device *dev, void *data, |
| 567 | struct drm_file *filp); | 634 | struct drm_file *filp); |
| 568 | int radeon_cs_ioctl(struct drm_device *dev, void *data, struct drm_file *filp); | 635 | int radeon_cs_ioctl(struct drm_device *dev, void *data, struct drm_file *filp); |
| 636 | int radeon_gem_set_tiling_ioctl(struct drm_device *dev, void *data, | ||
| 637 | struct drm_file *filp); | ||
| 638 | int radeon_gem_get_tiling_ioctl(struct drm_device *dev, void *data, | ||
| 639 | struct drm_file *filp); | ||
| 569 | 640 | ||
| 570 | 641 | ||
| 571 | /* | 642 | /* |
| @@ -584,6 +655,7 @@ struct radeon_device { | |||
| 584 | int usec_timeout; | 655 | int usec_timeout; |
| 585 | enum radeon_pll_errata pll_errata; | 656 | enum radeon_pll_errata pll_errata; |
| 586 | int num_gb_pipes; | 657 | int num_gb_pipes; |
| 658 | int num_z_pipes; | ||
| 587 | int disp_priority; | 659 | int disp_priority; |
| 588 | /* BIOS */ | 660 | /* BIOS */ |
| 589 | uint8_t *bios; | 661 | uint8_t *bios; |
| @@ -594,17 +666,14 @@ struct radeon_device { | |||
| 594 | struct radeon_object *fbdev_robj; | 666 | struct radeon_object *fbdev_robj; |
| 595 | struct radeon_framebuffer *fbdev_rfb; | 667 | struct radeon_framebuffer *fbdev_rfb; |
| 596 | /* Register mmio */ | 668 | /* Register mmio */ |
| 597 | unsigned long rmmio_base; | 669 | resource_size_t rmmio_base; |
| 598 | unsigned long rmmio_size; | 670 | resource_size_t rmmio_size; |
| 599 | void *rmmio; | 671 | void *rmmio; |
| 600 | radeon_rreg_t mm_rreg; | ||
| 601 | radeon_wreg_t mm_wreg; | ||
| 602 | radeon_rreg_t mc_rreg; | 672 | radeon_rreg_t mc_rreg; |
| 603 | radeon_wreg_t mc_wreg; | 673 | radeon_wreg_t mc_wreg; |
| 604 | radeon_rreg_t pll_rreg; | 674 | radeon_rreg_t pll_rreg; |
| 605 | radeon_wreg_t pll_wreg; | 675 | radeon_wreg_t pll_wreg; |
| 606 | radeon_rreg_t pcie_rreg; | 676 | uint32_t pcie_reg_mask; |
| 607 | radeon_wreg_t pcie_wreg; | ||
| 608 | radeon_rreg_t pciep_rreg; | 677 | radeon_rreg_t pciep_rreg; |
| 609 | radeon_wreg_t pciep_wreg; | 678 | radeon_wreg_t pciep_wreg; |
| 610 | struct radeon_clock clock; | 679 | struct radeon_clock clock; |
| @@ -619,11 +688,14 @@ struct radeon_device { | |||
| 619 | struct radeon_irq irq; | 688 | struct radeon_irq irq; |
| 620 | struct radeon_asic *asic; | 689 | struct radeon_asic *asic; |
| 621 | struct radeon_gem gem; | 690 | struct radeon_gem gem; |
| 691 | struct radeon_pm pm; | ||
| 622 | struct mutex cs_mutex; | 692 | struct mutex cs_mutex; |
| 623 | struct radeon_wb wb; | 693 | struct radeon_wb wb; |
| 624 | bool gpu_lockup; | 694 | bool gpu_lockup; |
| 625 | bool shutdown; | 695 | bool shutdown; |
| 626 | bool suspend; | 696 | bool suspend; |
| 697 | bool need_dma32; | ||
| 698 | struct radeon_surface_reg surface_regs[RADEON_GEM_MAX_SURFACES]; | ||
| 627 | }; | 699 | }; |
| 628 | 700 | ||
| 629 | int radeon_device_init(struct radeon_device *rdev, | 701 | int radeon_device_init(struct radeon_device *rdev, |
| @@ -633,22 +705,42 @@ int radeon_device_init(struct radeon_device *rdev, | |||
| 633 | void radeon_device_fini(struct radeon_device *rdev); | 705 | void radeon_device_fini(struct radeon_device *rdev); |
| 634 | int radeon_gpu_wait_for_idle(struct radeon_device *rdev); | 706 | int radeon_gpu_wait_for_idle(struct radeon_device *rdev); |
| 635 | 707 | ||
| 708 | static inline uint32_t r100_mm_rreg(struct radeon_device *rdev, uint32_t reg) | ||
| 709 | { | ||
| 710 | if (reg < 0x10000) | ||
| 711 | return readl(((void __iomem *)rdev->rmmio) + reg); | ||
| 712 | else { | ||
| 713 | writel(reg, ((void __iomem *)rdev->rmmio) + RADEON_MM_INDEX); | ||
| 714 | return readl(((void __iomem *)rdev->rmmio) + RADEON_MM_DATA); | ||
| 715 | } | ||
| 716 | } | ||
| 717 | |||
| 718 | static inline void r100_mm_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v) | ||
| 719 | { | ||
| 720 | if (reg < 0x10000) | ||
| 721 | writel(v, ((void __iomem *)rdev->rmmio) + reg); | ||
| 722 | else { | ||
| 723 | writel(reg, ((void __iomem *)rdev->rmmio) + RADEON_MM_INDEX); | ||
| 724 | writel(v, ((void __iomem *)rdev->rmmio) + RADEON_MM_DATA); | ||
| 725 | } | ||
| 726 | } | ||
| 727 | |||
| 636 | 728 | ||
| 637 | /* | 729 | /* |
| 638 | * Registers read & write functions. | 730 | * Registers read & write functions. |
| 639 | */ | 731 | */ |
| 640 | #define RREG8(reg) readb(((void __iomem *)rdev->rmmio) + (reg)) | 732 | #define RREG8(reg) readb(((void __iomem *)rdev->rmmio) + (reg)) |
| 641 | #define WREG8(reg, v) writeb(v, ((void __iomem *)rdev->rmmio) + (reg)) | 733 | #define WREG8(reg, v) writeb(v, ((void __iomem *)rdev->rmmio) + (reg)) |
| 642 | #define RREG32(reg) rdev->mm_rreg(rdev, (reg)) | 734 | #define RREG32(reg) r100_mm_rreg(rdev, (reg)) |
| 643 | #define WREG32(reg, v) rdev->mm_wreg(rdev, (reg), (v)) | 735 | #define WREG32(reg, v) r100_mm_wreg(rdev, (reg), (v)) |
| 644 | #define REG_SET(FIELD, v) (((v) << FIELD##_SHIFT) & FIELD##_MASK) | 736 | #define REG_SET(FIELD, v) (((v) << FIELD##_SHIFT) & FIELD##_MASK) |
| 645 | #define REG_GET(FIELD, v) (((v) << FIELD##_SHIFT) & FIELD##_MASK) | 737 | #define REG_GET(FIELD, v) (((v) << FIELD##_SHIFT) & FIELD##_MASK) |
| 646 | #define RREG32_PLL(reg) rdev->pll_rreg(rdev, (reg)) | 738 | #define RREG32_PLL(reg) rdev->pll_rreg(rdev, (reg)) |
| 647 | #define WREG32_PLL(reg, v) rdev->pll_wreg(rdev, (reg), (v)) | 739 | #define WREG32_PLL(reg, v) rdev->pll_wreg(rdev, (reg), (v)) |
| 648 | #define RREG32_MC(reg) rdev->mc_rreg(rdev, (reg)) | 740 | #define RREG32_MC(reg) rdev->mc_rreg(rdev, (reg)) |
| 649 | #define WREG32_MC(reg, v) rdev->mc_wreg(rdev, (reg), (v)) | 741 | #define WREG32_MC(reg, v) rdev->mc_wreg(rdev, (reg), (v)) |
| 650 | #define RREG32_PCIE(reg) rdev->pcie_rreg(rdev, (reg)) | 742 | #define RREG32_PCIE(reg) rv370_pcie_rreg(rdev, (reg)) |
| 651 | #define WREG32_PCIE(reg, v) rdev->pcie_wreg(rdev, (reg), (v)) | 743 | #define WREG32_PCIE(reg, v) rv370_pcie_wreg(rdev, (reg), (v)) |
| 652 | #define WREG32_P(reg, val, mask) \ | 744 | #define WREG32_P(reg, val, mask) \ |
| 653 | do { \ | 745 | do { \ |
| 654 | uint32_t tmp_ = RREG32(reg); \ | 746 | uint32_t tmp_ = RREG32(reg); \ |
| @@ -664,12 +756,32 @@ int radeon_gpu_wait_for_idle(struct radeon_device *rdev); | |||
| 664 | WREG32_PLL(reg, tmp_); \ | 756 | WREG32_PLL(reg, tmp_); \ |
| 665 | } while (0) | 757 | } while (0) |
| 666 | 758 | ||
| 759 | /* | ||
| 760 | * Indirect registers accessor | ||
| 761 | */ | ||
| 762 | static inline uint32_t rv370_pcie_rreg(struct radeon_device *rdev, uint32_t reg) | ||
| 763 | { | ||
| 764 | uint32_t r; | ||
| 765 | |||
| 766 | WREG32(RADEON_PCIE_INDEX, ((reg) & rdev->pcie_reg_mask)); | ||
| 767 | r = RREG32(RADEON_PCIE_DATA); | ||
| 768 | return r; | ||
| 769 | } | ||
| 770 | |||
| 771 | static inline void rv370_pcie_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v) | ||
| 772 | { | ||
| 773 | WREG32(RADEON_PCIE_INDEX, ((reg) & rdev->pcie_reg_mask)); | ||
| 774 | WREG32(RADEON_PCIE_DATA, (v)); | ||
| 775 | } | ||
| 776 | |||
| 667 | void r100_pll_errata_after_index(struct radeon_device *rdev); | 777 | void r100_pll_errata_after_index(struct radeon_device *rdev); |
| 668 | 778 | ||
| 669 | 779 | ||
| 670 | /* | 780 | /* |
| 671 | * ASICs helpers. | 781 | * ASICs helpers. |
| 672 | */ | 782 | */ |
| 783 | #define ASIC_IS_RN50(rdev) ((rdev->pdev->device == 0x515e) || \ | ||
| 784 | (rdev->pdev->device == 0x5969)) | ||
| 673 | #define ASIC_IS_RV100(rdev) ((rdev->family == CHIP_RV100) || \ | 785 | #define ASIC_IS_RV100(rdev) ((rdev->family == CHIP_RV100) || \ |
| 674 | (rdev->family == CHIP_RV200) || \ | 786 | (rdev->family == CHIP_RV200) || \ |
| 675 | (rdev->family == CHIP_RS100) || \ | 787 | (rdev->family == CHIP_RS100) || \ |
| @@ -788,6 +900,7 @@ static inline void radeon_ring_write(struct radeon_device *rdev, uint32_t v) | |||
| 788 | #define radeon_ring_start(rdev) (rdev)->asic->ring_start((rdev)) | 900 | #define radeon_ring_start(rdev) (rdev)->asic->ring_start((rdev)) |
| 789 | #define radeon_irq_set(rdev) (rdev)->asic->irq_set((rdev)) | 901 | #define radeon_irq_set(rdev) (rdev)->asic->irq_set((rdev)) |
| 790 | #define radeon_irq_process(rdev) (rdev)->asic->irq_process((rdev)) | 902 | #define radeon_irq_process(rdev) (rdev)->asic->irq_process((rdev)) |
| 903 | #define radeon_get_vblank_counter(rdev, crtc) (rdev)->asic->get_vblank_counter((rdev), (crtc)) | ||
| 791 | #define radeon_fence_ring_emit(rdev, fence) (rdev)->asic->fence_ring_emit((rdev), (fence)) | 904 | #define radeon_fence_ring_emit(rdev, fence) (rdev)->asic->fence_ring_emit((rdev), (fence)) |
| 792 | #define radeon_copy_blit(rdev, s, d, np, f) (rdev)->asic->copy_blit((rdev), (s), (d), (np), (f)) | 905 | #define radeon_copy_blit(rdev, s, d, np, f) (rdev)->asic->copy_blit((rdev), (s), (d), (np), (f)) |
| 793 | #define radeon_copy_dma(rdev, s, d, np, f) (rdev)->asic->copy_dma((rdev), (s), (d), (np), (f)) | 906 | #define radeon_copy_dma(rdev, s, d, np, f) (rdev)->asic->copy_dma((rdev), (s), (d), (np), (f)) |
| @@ -796,5 +909,8 @@ static inline void radeon_ring_write(struct radeon_device *rdev, uint32_t v) | |||
| 796 | #define radeon_set_memory_clock(rdev, e) (rdev)->asic->set_engine_clock((rdev), (e)) | 909 | #define radeon_set_memory_clock(rdev, e) (rdev)->asic->set_engine_clock((rdev), (e)) |
| 797 | #define radeon_set_pcie_lanes(rdev, l) (rdev)->asic->set_pcie_lanes((rdev), (l)) | 910 | #define radeon_set_pcie_lanes(rdev, l) (rdev)->asic->set_pcie_lanes((rdev), (l)) |
| 798 | #define radeon_set_clock_gating(rdev, e) (rdev)->asic->set_clock_gating((rdev), (e)) | 911 | #define radeon_set_clock_gating(rdev, e) (rdev)->asic->set_clock_gating((rdev), (e)) |
| 912 | #define radeon_set_surface_reg(rdev, r, f, p, o, s) ((rdev)->asic->set_surface_reg((rdev), (r), (f), (p), (o), (s))) | ||
| 913 | #define radeon_clear_surface_reg(rdev, r) ((rdev)->asic->clear_surface_reg((rdev), (r))) | ||
| 914 | #define radeon_bandwidth_update(rdev) (rdev)->asic->bandwidth_update((rdev)) | ||
| 799 | 915 | ||
| 800 | #endif | 916 | #endif |
diff --git a/drivers/gpu/drm/radeon/radeon_asic.h b/drivers/gpu/drm/radeon/radeon_asic.h index e2e567395df8..7ca6c13569b5 100644 --- a/drivers/gpu/drm/radeon/radeon_asic.h +++ b/drivers/gpu/drm/radeon/radeon_asic.h | |||
| @@ -49,6 +49,7 @@ void r100_vram_info(struct radeon_device *rdev); | |||
| 49 | int r100_gpu_reset(struct radeon_device *rdev); | 49 | int r100_gpu_reset(struct radeon_device *rdev); |
| 50 | int r100_mc_init(struct radeon_device *rdev); | 50 | int r100_mc_init(struct radeon_device *rdev); |
| 51 | void r100_mc_fini(struct radeon_device *rdev); | 51 | void r100_mc_fini(struct radeon_device *rdev); |
| 52 | u32 r100_get_vblank_counter(struct radeon_device *rdev, int crtc); | ||
| 52 | int r100_wb_init(struct radeon_device *rdev); | 53 | int r100_wb_init(struct radeon_device *rdev); |
| 53 | void r100_wb_fini(struct radeon_device *rdev); | 54 | void r100_wb_fini(struct radeon_device *rdev); |
| 54 | int r100_gart_enable(struct radeon_device *rdev); | 55 | int r100_gart_enable(struct radeon_device *rdev); |
| @@ -71,6 +72,11 @@ int r100_copy_blit(struct radeon_device *rdev, | |||
| 71 | uint64_t dst_offset, | 72 | uint64_t dst_offset, |
| 72 | unsigned num_pages, | 73 | unsigned num_pages, |
| 73 | struct radeon_fence *fence); | 74 | struct radeon_fence *fence); |
| 75 | int r100_set_surface_reg(struct radeon_device *rdev, int reg, | ||
| 76 | uint32_t tiling_flags, uint32_t pitch, | ||
| 77 | uint32_t offset, uint32_t obj_size); | ||
| 78 | int r100_clear_surface_reg(struct radeon_device *rdev, int reg); | ||
| 79 | void r100_bandwidth_update(struct radeon_device *rdev); | ||
| 74 | 80 | ||
| 75 | static struct radeon_asic r100_asic = { | 81 | static struct radeon_asic r100_asic = { |
| 76 | .init = &r100_init, | 82 | .init = &r100_init, |
| @@ -91,6 +97,7 @@ static struct radeon_asic r100_asic = { | |||
| 91 | .ring_start = &r100_ring_start, | 97 | .ring_start = &r100_ring_start, |
| 92 | .irq_set = &r100_irq_set, | 98 | .irq_set = &r100_irq_set, |
| 93 | .irq_process = &r100_irq_process, | 99 | .irq_process = &r100_irq_process, |
| 100 | .get_vblank_counter = &r100_get_vblank_counter, | ||
| 94 | .fence_ring_emit = &r100_fence_ring_emit, | 101 | .fence_ring_emit = &r100_fence_ring_emit, |
| 95 | .cs_parse = &r100_cs_parse, | 102 | .cs_parse = &r100_cs_parse, |
| 96 | .copy_blit = &r100_copy_blit, | 103 | .copy_blit = &r100_copy_blit, |
| @@ -100,6 +107,9 @@ static struct radeon_asic r100_asic = { | |||
| 100 | .set_memory_clock = NULL, | 107 | .set_memory_clock = NULL, |
| 101 | .set_pcie_lanes = NULL, | 108 | .set_pcie_lanes = NULL, |
| 102 | .set_clock_gating = &radeon_legacy_set_clock_gating, | 109 | .set_clock_gating = &radeon_legacy_set_clock_gating, |
| 110 | .set_surface_reg = r100_set_surface_reg, | ||
| 111 | .clear_surface_reg = r100_clear_surface_reg, | ||
| 112 | .bandwidth_update = &r100_bandwidth_update, | ||
| 103 | }; | 113 | }; |
| 104 | 114 | ||
| 105 | 115 | ||
| @@ -128,6 +138,7 @@ int r300_copy_dma(struct radeon_device *rdev, | |||
| 128 | uint64_t dst_offset, | 138 | uint64_t dst_offset, |
| 129 | unsigned num_pages, | 139 | unsigned num_pages, |
| 130 | struct radeon_fence *fence); | 140 | struct radeon_fence *fence); |
| 141 | |||
| 131 | static struct radeon_asic r300_asic = { | 142 | static struct radeon_asic r300_asic = { |
| 132 | .init = &r300_init, | 143 | .init = &r300_init, |
| 133 | .errata = &r300_errata, | 144 | .errata = &r300_errata, |
| @@ -147,6 +158,7 @@ static struct radeon_asic r300_asic = { | |||
| 147 | .ring_start = &r300_ring_start, | 158 | .ring_start = &r300_ring_start, |
| 148 | .irq_set = &r100_irq_set, | 159 | .irq_set = &r100_irq_set, |
| 149 | .irq_process = &r100_irq_process, | 160 | .irq_process = &r100_irq_process, |
| 161 | .get_vblank_counter = &r100_get_vblank_counter, | ||
| 150 | .fence_ring_emit = &r300_fence_ring_emit, | 162 | .fence_ring_emit = &r300_fence_ring_emit, |
| 151 | .cs_parse = &r300_cs_parse, | 163 | .cs_parse = &r300_cs_parse, |
| 152 | .copy_blit = &r100_copy_blit, | 164 | .copy_blit = &r100_copy_blit, |
| @@ -156,6 +168,9 @@ static struct radeon_asic r300_asic = { | |||
| 156 | .set_memory_clock = NULL, | 168 | .set_memory_clock = NULL, |
| 157 | .set_pcie_lanes = &rv370_set_pcie_lanes, | 169 | .set_pcie_lanes = &rv370_set_pcie_lanes, |
| 158 | .set_clock_gating = &radeon_legacy_set_clock_gating, | 170 | .set_clock_gating = &radeon_legacy_set_clock_gating, |
| 171 | .set_surface_reg = r100_set_surface_reg, | ||
| 172 | .clear_surface_reg = r100_clear_surface_reg, | ||
| 173 | .bandwidth_update = &r100_bandwidth_update, | ||
| 159 | }; | 174 | }; |
| 160 | 175 | ||
| 161 | /* | 176 | /* |
| @@ -184,6 +199,7 @@ static struct radeon_asic r420_asic = { | |||
| 184 | .ring_start = &r300_ring_start, | 199 | .ring_start = &r300_ring_start, |
| 185 | .irq_set = &r100_irq_set, | 200 | .irq_set = &r100_irq_set, |
| 186 | .irq_process = &r100_irq_process, | 201 | .irq_process = &r100_irq_process, |
| 202 | .get_vblank_counter = &r100_get_vblank_counter, | ||
| 187 | .fence_ring_emit = &r300_fence_ring_emit, | 203 | .fence_ring_emit = &r300_fence_ring_emit, |
| 188 | .cs_parse = &r300_cs_parse, | 204 | .cs_parse = &r300_cs_parse, |
| 189 | .copy_blit = &r100_copy_blit, | 205 | .copy_blit = &r100_copy_blit, |
| @@ -193,6 +209,9 @@ static struct radeon_asic r420_asic = { | |||
| 193 | .set_memory_clock = &radeon_atom_set_memory_clock, | 209 | .set_memory_clock = &radeon_atom_set_memory_clock, |
| 194 | .set_pcie_lanes = &rv370_set_pcie_lanes, | 210 | .set_pcie_lanes = &rv370_set_pcie_lanes, |
| 195 | .set_clock_gating = &radeon_atom_set_clock_gating, | 211 | .set_clock_gating = &radeon_atom_set_clock_gating, |
| 212 | .set_surface_reg = r100_set_surface_reg, | ||
| 213 | .clear_surface_reg = r100_clear_surface_reg, | ||
| 214 | .bandwidth_update = &r100_bandwidth_update, | ||
| 196 | }; | 215 | }; |
| 197 | 216 | ||
| 198 | 217 | ||
| @@ -228,6 +247,7 @@ static struct radeon_asic rs400_asic = { | |||
| 228 | .ring_start = &r300_ring_start, | 247 | .ring_start = &r300_ring_start, |
| 229 | .irq_set = &r100_irq_set, | 248 | .irq_set = &r100_irq_set, |
| 230 | .irq_process = &r100_irq_process, | 249 | .irq_process = &r100_irq_process, |
| 250 | .get_vblank_counter = &r100_get_vblank_counter, | ||
| 231 | .fence_ring_emit = &r300_fence_ring_emit, | 251 | .fence_ring_emit = &r300_fence_ring_emit, |
| 232 | .cs_parse = &r300_cs_parse, | 252 | .cs_parse = &r300_cs_parse, |
| 233 | .copy_blit = &r100_copy_blit, | 253 | .copy_blit = &r100_copy_blit, |
| @@ -237,6 +257,9 @@ static struct radeon_asic rs400_asic = { | |||
| 237 | .set_memory_clock = NULL, | 257 | .set_memory_clock = NULL, |
| 238 | .set_pcie_lanes = NULL, | 258 | .set_pcie_lanes = NULL, |
| 239 | .set_clock_gating = &radeon_legacy_set_clock_gating, | 259 | .set_clock_gating = &radeon_legacy_set_clock_gating, |
| 260 | .set_surface_reg = r100_set_surface_reg, | ||
| 261 | .clear_surface_reg = r100_clear_surface_reg, | ||
| 262 | .bandwidth_update = &r100_bandwidth_update, | ||
| 240 | }; | 263 | }; |
| 241 | 264 | ||
| 242 | 265 | ||
| @@ -248,12 +271,15 @@ void rs600_vram_info(struct radeon_device *rdev); | |||
| 248 | int rs600_mc_init(struct radeon_device *rdev); | 271 | int rs600_mc_init(struct radeon_device *rdev); |
| 249 | void rs600_mc_fini(struct radeon_device *rdev); | 272 | void rs600_mc_fini(struct radeon_device *rdev); |
| 250 | int rs600_irq_set(struct radeon_device *rdev); | 273 | int rs600_irq_set(struct radeon_device *rdev); |
| 274 | int rs600_irq_process(struct radeon_device *rdev); | ||
| 275 | u32 rs600_get_vblank_counter(struct radeon_device *rdev, int crtc); | ||
| 251 | int rs600_gart_enable(struct radeon_device *rdev); | 276 | int rs600_gart_enable(struct radeon_device *rdev); |
| 252 | void rs600_gart_disable(struct radeon_device *rdev); | 277 | void rs600_gart_disable(struct radeon_device *rdev); |
| 253 | void rs600_gart_tlb_flush(struct radeon_device *rdev); | 278 | void rs600_gart_tlb_flush(struct radeon_device *rdev); |
| 254 | int rs600_gart_set_page(struct radeon_device *rdev, int i, uint64_t addr); | 279 | int rs600_gart_set_page(struct radeon_device *rdev, int i, uint64_t addr); |
| 255 | uint32_t rs600_mc_rreg(struct radeon_device *rdev, uint32_t reg); | 280 | uint32_t rs600_mc_rreg(struct radeon_device *rdev, uint32_t reg); |
| 256 | void rs600_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v); | 281 | void rs600_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v); |
| 282 | void rs600_bandwidth_update(struct radeon_device *rdev); | ||
| 257 | static struct radeon_asic rs600_asic = { | 283 | static struct radeon_asic rs600_asic = { |
| 258 | .init = &r300_init, | 284 | .init = &r300_init, |
| 259 | .errata = &rs600_errata, | 285 | .errata = &rs600_errata, |
| @@ -272,7 +298,8 @@ static struct radeon_asic rs600_asic = { | |||
| 272 | .cp_disable = &r100_cp_disable, | 298 | .cp_disable = &r100_cp_disable, |
| 273 | .ring_start = &r300_ring_start, | 299 | .ring_start = &r300_ring_start, |
| 274 | .irq_set = &rs600_irq_set, | 300 | .irq_set = &rs600_irq_set, |
| 275 | .irq_process = &r100_irq_process, | 301 | .irq_process = &rs600_irq_process, |
| 302 | .get_vblank_counter = &rs600_get_vblank_counter, | ||
| 276 | .fence_ring_emit = &r300_fence_ring_emit, | 303 | .fence_ring_emit = &r300_fence_ring_emit, |
| 277 | .cs_parse = &r300_cs_parse, | 304 | .cs_parse = &r300_cs_parse, |
| 278 | .copy_blit = &r100_copy_blit, | 305 | .copy_blit = &r100_copy_blit, |
| @@ -282,20 +309,23 @@ static struct radeon_asic rs600_asic = { | |||
| 282 | .set_memory_clock = &radeon_atom_set_memory_clock, | 309 | .set_memory_clock = &radeon_atom_set_memory_clock, |
| 283 | .set_pcie_lanes = NULL, | 310 | .set_pcie_lanes = NULL, |
| 284 | .set_clock_gating = &radeon_atom_set_clock_gating, | 311 | .set_clock_gating = &radeon_atom_set_clock_gating, |
| 312 | .bandwidth_update = &rs600_bandwidth_update, | ||
| 285 | }; | 313 | }; |
| 286 | 314 | ||
| 287 | 315 | ||
| 288 | /* | 316 | /* |
| 289 | * rs690,rs740 | 317 | * rs690,rs740 |
| 290 | */ | 318 | */ |
| 319 | int rs690_init(struct radeon_device *rdev); | ||
| 291 | void rs690_errata(struct radeon_device *rdev); | 320 | void rs690_errata(struct radeon_device *rdev); |
| 292 | void rs690_vram_info(struct radeon_device *rdev); | 321 | void rs690_vram_info(struct radeon_device *rdev); |
| 293 | int rs690_mc_init(struct radeon_device *rdev); | 322 | int rs690_mc_init(struct radeon_device *rdev); |
| 294 | void rs690_mc_fini(struct radeon_device *rdev); | 323 | void rs690_mc_fini(struct radeon_device *rdev); |
| 295 | uint32_t rs690_mc_rreg(struct radeon_device *rdev, uint32_t reg); | 324 | uint32_t rs690_mc_rreg(struct radeon_device *rdev, uint32_t reg); |
| 296 | void rs690_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v); | 325 | void rs690_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v); |
| 326 | void rs690_bandwidth_update(struct radeon_device *rdev); | ||
| 297 | static struct radeon_asic rs690_asic = { | 327 | static struct radeon_asic rs690_asic = { |
| 298 | .init = &r300_init, | 328 | .init = &rs690_init, |
| 299 | .errata = &rs690_errata, | 329 | .errata = &rs690_errata, |
| 300 | .vram_info = &rs690_vram_info, | 330 | .vram_info = &rs690_vram_info, |
| 301 | .gpu_reset = &r300_gpu_reset, | 331 | .gpu_reset = &r300_gpu_reset, |
| @@ -312,7 +342,8 @@ static struct radeon_asic rs690_asic = { | |||
| 312 | .cp_disable = &r100_cp_disable, | 342 | .cp_disable = &r100_cp_disable, |
| 313 | .ring_start = &r300_ring_start, | 343 | .ring_start = &r300_ring_start, |
| 314 | .irq_set = &rs600_irq_set, | 344 | .irq_set = &rs600_irq_set, |
| 315 | .irq_process = &r100_irq_process, | 345 | .irq_process = &rs600_irq_process, |
| 346 | .get_vblank_counter = &rs600_get_vblank_counter, | ||
| 316 | .fence_ring_emit = &r300_fence_ring_emit, | 347 | .fence_ring_emit = &r300_fence_ring_emit, |
| 317 | .cs_parse = &r300_cs_parse, | 348 | .cs_parse = &r300_cs_parse, |
| 318 | .copy_blit = &r100_copy_blit, | 349 | .copy_blit = &r100_copy_blit, |
| @@ -322,6 +353,9 @@ static struct radeon_asic rs690_asic = { | |||
| 322 | .set_memory_clock = &radeon_atom_set_memory_clock, | 353 | .set_memory_clock = &radeon_atom_set_memory_clock, |
| 323 | .set_pcie_lanes = NULL, | 354 | .set_pcie_lanes = NULL, |
| 324 | .set_clock_gating = &radeon_atom_set_clock_gating, | 355 | .set_clock_gating = &radeon_atom_set_clock_gating, |
| 356 | .set_surface_reg = r100_set_surface_reg, | ||
| 357 | .clear_surface_reg = r100_clear_surface_reg, | ||
| 358 | .bandwidth_update = &rs690_bandwidth_update, | ||
| 325 | }; | 359 | }; |
| 326 | 360 | ||
| 327 | 361 | ||
| @@ -339,6 +373,7 @@ void rv515_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v); | |||
| 339 | void rv515_ring_start(struct radeon_device *rdev); | 373 | void rv515_ring_start(struct radeon_device *rdev); |
| 340 | uint32_t rv515_pcie_rreg(struct radeon_device *rdev, uint32_t reg); | 374 | uint32_t rv515_pcie_rreg(struct radeon_device *rdev, uint32_t reg); |
| 341 | void rv515_pcie_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v); | 375 | void rv515_pcie_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v); |
| 376 | void rv515_bandwidth_update(struct radeon_device *rdev); | ||
| 342 | static struct radeon_asic rv515_asic = { | 377 | static struct radeon_asic rv515_asic = { |
| 343 | .init = &rv515_init, | 378 | .init = &rv515_init, |
| 344 | .errata = &rv515_errata, | 379 | .errata = &rv515_errata, |
| @@ -356,8 +391,9 @@ static struct radeon_asic rv515_asic = { | |||
| 356 | .cp_fini = &r100_cp_fini, | 391 | .cp_fini = &r100_cp_fini, |
| 357 | .cp_disable = &r100_cp_disable, | 392 | .cp_disable = &r100_cp_disable, |
| 358 | .ring_start = &rv515_ring_start, | 393 | .ring_start = &rv515_ring_start, |
| 359 | .irq_set = &r100_irq_set, | 394 | .irq_set = &rs600_irq_set, |
| 360 | .irq_process = &r100_irq_process, | 395 | .irq_process = &rs600_irq_process, |
| 396 | .get_vblank_counter = &rs600_get_vblank_counter, | ||
| 361 | .fence_ring_emit = &r300_fence_ring_emit, | 397 | .fence_ring_emit = &r300_fence_ring_emit, |
| 362 | .cs_parse = &r300_cs_parse, | 398 | .cs_parse = &r300_cs_parse, |
| 363 | .copy_blit = &r100_copy_blit, | 399 | .copy_blit = &r100_copy_blit, |
| @@ -367,6 +403,9 @@ static struct radeon_asic rv515_asic = { | |||
| 367 | .set_memory_clock = &radeon_atom_set_memory_clock, | 403 | .set_memory_clock = &radeon_atom_set_memory_clock, |
| 368 | .set_pcie_lanes = &rv370_set_pcie_lanes, | 404 | .set_pcie_lanes = &rv370_set_pcie_lanes, |
| 369 | .set_clock_gating = &radeon_atom_set_clock_gating, | 405 | .set_clock_gating = &radeon_atom_set_clock_gating, |
| 406 | .set_surface_reg = r100_set_surface_reg, | ||
| 407 | .clear_surface_reg = r100_clear_surface_reg, | ||
| 408 | .bandwidth_update = &rv515_bandwidth_update, | ||
| 370 | }; | 409 | }; |
| 371 | 410 | ||
| 372 | 411 | ||
| @@ -377,6 +416,7 @@ void r520_errata(struct radeon_device *rdev); | |||
| 377 | void r520_vram_info(struct radeon_device *rdev); | 416 | void r520_vram_info(struct radeon_device *rdev); |
| 378 | int r520_mc_init(struct radeon_device *rdev); | 417 | int r520_mc_init(struct radeon_device *rdev); |
| 379 | void r520_mc_fini(struct radeon_device *rdev); | 418 | void r520_mc_fini(struct radeon_device *rdev); |
| 419 | void r520_bandwidth_update(struct radeon_device *rdev); | ||
| 380 | static struct radeon_asic r520_asic = { | 420 | static struct radeon_asic r520_asic = { |
| 381 | .init = &rv515_init, | 421 | .init = &rv515_init, |
| 382 | .errata = &r520_errata, | 422 | .errata = &r520_errata, |
| @@ -394,8 +434,9 @@ static struct radeon_asic r520_asic = { | |||
| 394 | .cp_fini = &r100_cp_fini, | 434 | .cp_fini = &r100_cp_fini, |
| 395 | .cp_disable = &r100_cp_disable, | 435 | .cp_disable = &r100_cp_disable, |
| 396 | .ring_start = &rv515_ring_start, | 436 | .ring_start = &rv515_ring_start, |
| 397 | .irq_set = &r100_irq_set, | 437 | .irq_set = &rs600_irq_set, |
| 398 | .irq_process = &r100_irq_process, | 438 | .irq_process = &rs600_irq_process, |
| 439 | .get_vblank_counter = &rs600_get_vblank_counter, | ||
| 399 | .fence_ring_emit = &r300_fence_ring_emit, | 440 | .fence_ring_emit = &r300_fence_ring_emit, |
| 400 | .cs_parse = &r300_cs_parse, | 441 | .cs_parse = &r300_cs_parse, |
| 401 | .copy_blit = &r100_copy_blit, | 442 | .copy_blit = &r100_copy_blit, |
| @@ -405,6 +446,9 @@ static struct radeon_asic r520_asic = { | |||
| 405 | .set_memory_clock = &radeon_atom_set_memory_clock, | 446 | .set_memory_clock = &radeon_atom_set_memory_clock, |
| 406 | .set_pcie_lanes = &rv370_set_pcie_lanes, | 447 | .set_pcie_lanes = &rv370_set_pcie_lanes, |
| 407 | .set_clock_gating = &radeon_atom_set_clock_gating, | 448 | .set_clock_gating = &radeon_atom_set_clock_gating, |
| 449 | .set_surface_reg = r100_set_surface_reg, | ||
| 450 | .clear_surface_reg = r100_clear_surface_reg, | ||
| 451 | .bandwidth_update = &r520_bandwidth_update, | ||
| 408 | }; | 452 | }; |
| 409 | 453 | ||
| 410 | /* | 454 | /* |
diff --git a/drivers/gpu/drm/radeon/radeon_atombios.c b/drivers/gpu/drm/radeon/radeon_atombios.c index 1f5a1a490984..fcfe5c02d744 100644 --- a/drivers/gpu/drm/radeon/radeon_atombios.c +++ b/drivers/gpu/drm/radeon/radeon_atombios.c | |||
| @@ -103,7 +103,8 @@ static inline struct radeon_i2c_bus_rec radeon_lookup_gpio(struct drm_device | |||
| 103 | static bool radeon_atom_apply_quirks(struct drm_device *dev, | 103 | static bool radeon_atom_apply_quirks(struct drm_device *dev, |
| 104 | uint32_t supported_device, | 104 | uint32_t supported_device, |
| 105 | int *connector_type, | 105 | int *connector_type, |
| 106 | struct radeon_i2c_bus_rec *i2c_bus) | 106 | struct radeon_i2c_bus_rec *i2c_bus, |
| 107 | uint8_t *line_mux) | ||
| 107 | { | 108 | { |
| 108 | 109 | ||
| 109 | /* Asus M2A-VM HDMI board lists the DVI port as HDMI */ | 110 | /* Asus M2A-VM HDMI board lists the DVI port as HDMI */ |
| @@ -127,8 +128,10 @@ static bool radeon_atom_apply_quirks(struct drm_device *dev, | |||
| 127 | if ((dev->pdev->device == 0x5653) && | 128 | if ((dev->pdev->device == 0x5653) && |
| 128 | (dev->pdev->subsystem_vendor == 0x1462) && | 129 | (dev->pdev->subsystem_vendor == 0x1462) && |
| 129 | (dev->pdev->subsystem_device == 0x0291)) { | 130 | (dev->pdev->subsystem_device == 0x0291)) { |
| 130 | if (*connector_type == DRM_MODE_CONNECTOR_LVDS) | 131 | if (*connector_type == DRM_MODE_CONNECTOR_LVDS) { |
| 131 | i2c_bus->valid = false; | 132 | i2c_bus->valid = false; |
| 133 | *line_mux = 53; | ||
| 134 | } | ||
| 132 | } | 135 | } |
| 133 | 136 | ||
| 134 | /* Funky macbooks */ | 137 | /* Funky macbooks */ |
| @@ -526,7 +529,7 @@ bool radeon_get_atom_connector_info_from_supported_devices_table(struct | |||
| 526 | 529 | ||
| 527 | if (!radeon_atom_apply_quirks | 530 | if (!radeon_atom_apply_quirks |
| 528 | (dev, (1 << i), &bios_connectors[i].connector_type, | 531 | (dev, (1 << i), &bios_connectors[i].connector_type, |
| 529 | &bios_connectors[i].ddc_bus)) | 532 | &bios_connectors[i].ddc_bus, &bios_connectors[i].line_mux)) |
| 530 | continue; | 533 | continue; |
| 531 | 534 | ||
| 532 | bios_connectors[i].valid = true; | 535 | bios_connectors[i].valid = true; |
diff --git a/drivers/gpu/drm/radeon/radeon_benchmark.c b/drivers/gpu/drm/radeon/radeon_benchmark.c index c44403a2ca76..2e938f7496fb 100644 --- a/drivers/gpu/drm/radeon/radeon_benchmark.c +++ b/drivers/gpu/drm/radeon/radeon_benchmark.c | |||
| @@ -63,7 +63,7 @@ void radeon_benchmark_move(struct radeon_device *rdev, unsigned bsize, | |||
| 63 | if (r) { | 63 | if (r) { |
| 64 | goto out_cleanup; | 64 | goto out_cleanup; |
| 65 | } | 65 | } |
| 66 | r = radeon_copy_dma(rdev, saddr, daddr, size >> 14, fence); | 66 | r = radeon_copy_dma(rdev, saddr, daddr, size / 4096, fence); |
| 67 | if (r) { | 67 | if (r) { |
| 68 | goto out_cleanup; | 68 | goto out_cleanup; |
| 69 | } | 69 | } |
| @@ -88,7 +88,7 @@ void radeon_benchmark_move(struct radeon_device *rdev, unsigned bsize, | |||
| 88 | if (r) { | 88 | if (r) { |
| 89 | goto out_cleanup; | 89 | goto out_cleanup; |
| 90 | } | 90 | } |
| 91 | r = radeon_copy_blit(rdev, saddr, daddr, size >> 14, fence); | 91 | r = radeon_copy_blit(rdev, saddr, daddr, size / 4096, fence); |
| 92 | if (r) { | 92 | if (r) { |
| 93 | goto out_cleanup; | 93 | goto out_cleanup; |
| 94 | } | 94 | } |
diff --git a/drivers/gpu/drm/radeon/radeon_combios.c b/drivers/gpu/drm/radeon/radeon_combios.c index afc4db280b94..2a027e00762a 100644 --- a/drivers/gpu/drm/radeon/radeon_combios.c +++ b/drivers/gpu/drm/radeon/radeon_combios.c | |||
| @@ -685,23 +685,15 @@ static const uint32_t default_tvdac_adj[CHIP_LAST] = { | |||
| 685 | 0x00780000, /* rs480 */ | 685 | 0x00780000, /* rs480 */ |
| 686 | }; | 686 | }; |
| 687 | 687 | ||
| 688 | static struct radeon_encoder_tv_dac | 688 | static void radeon_legacy_get_tv_dac_info_from_table(struct radeon_device *rdev, |
| 689 | *radeon_legacy_get_tv_dac_info_from_table(struct radeon_device *rdev) | 689 | struct radeon_encoder_tv_dac *tv_dac) |
| 690 | { | 690 | { |
| 691 | struct radeon_encoder_tv_dac *tv_dac = NULL; | ||
| 692 | |||
| 693 | tv_dac = kzalloc(sizeof(struct radeon_encoder_tv_dac), GFP_KERNEL); | ||
| 694 | |||
| 695 | if (!tv_dac) | ||
| 696 | return NULL; | ||
| 697 | |||
| 698 | tv_dac->ps2_tvdac_adj = default_tvdac_adj[rdev->family]; | 691 | tv_dac->ps2_tvdac_adj = default_tvdac_adj[rdev->family]; |
| 699 | if ((rdev->flags & RADEON_IS_MOBILITY) && (rdev->family == CHIP_RV250)) | 692 | if ((rdev->flags & RADEON_IS_MOBILITY) && (rdev->family == CHIP_RV250)) |
| 700 | tv_dac->ps2_tvdac_adj = 0x00880000; | 693 | tv_dac->ps2_tvdac_adj = 0x00880000; |
| 701 | tv_dac->pal_tvdac_adj = tv_dac->ps2_tvdac_adj; | 694 | tv_dac->pal_tvdac_adj = tv_dac->ps2_tvdac_adj; |
| 702 | tv_dac->ntsc_tvdac_adj = tv_dac->ps2_tvdac_adj; | 695 | tv_dac->ntsc_tvdac_adj = tv_dac->ps2_tvdac_adj; |
| 703 | 696 | return; | |
| 704 | return tv_dac; | ||
| 705 | } | 697 | } |
| 706 | 698 | ||
| 707 | struct radeon_encoder_tv_dac *radeon_combios_get_tv_dac_info(struct | 699 | struct radeon_encoder_tv_dac *radeon_combios_get_tv_dac_info(struct |
| @@ -713,19 +705,18 @@ struct radeon_encoder_tv_dac *radeon_combios_get_tv_dac_info(struct | |||
| 713 | uint16_t dac_info; | 705 | uint16_t dac_info; |
| 714 | uint8_t rev, bg, dac; | 706 | uint8_t rev, bg, dac; |
| 715 | struct radeon_encoder_tv_dac *tv_dac = NULL; | 707 | struct radeon_encoder_tv_dac *tv_dac = NULL; |
| 708 | int found = 0; | ||
| 709 | |||
| 710 | tv_dac = kzalloc(sizeof(struct radeon_encoder_tv_dac), GFP_KERNEL); | ||
| 711 | if (!tv_dac) | ||
| 712 | return NULL; | ||
| 716 | 713 | ||
| 717 | if (rdev->bios == NULL) | 714 | if (rdev->bios == NULL) |
| 718 | return radeon_legacy_get_tv_dac_info_from_table(rdev); | 715 | goto out; |
| 719 | 716 | ||
| 720 | /* first check TV table */ | 717 | /* first check TV table */ |
| 721 | dac_info = combios_get_table_offset(dev, COMBIOS_TV_INFO_TABLE); | 718 | dac_info = combios_get_table_offset(dev, COMBIOS_TV_INFO_TABLE); |
| 722 | if (dac_info) { | 719 | if (dac_info) { |
| 723 | tv_dac = | ||
| 724 | kzalloc(sizeof(struct radeon_encoder_tv_dac), GFP_KERNEL); | ||
| 725 | |||
| 726 | if (!tv_dac) | ||
| 727 | return NULL; | ||
| 728 | |||
| 729 | rev = RBIOS8(dac_info + 0x3); | 720 | rev = RBIOS8(dac_info + 0x3); |
| 730 | if (rev > 4) { | 721 | if (rev > 4) { |
| 731 | bg = RBIOS8(dac_info + 0xc) & 0xf; | 722 | bg = RBIOS8(dac_info + 0xc) & 0xf; |
| @@ -739,6 +730,7 @@ struct radeon_encoder_tv_dac *radeon_combios_get_tv_dac_info(struct | |||
| 739 | bg = RBIOS8(dac_info + 0x10) & 0xf; | 730 | bg = RBIOS8(dac_info + 0x10) & 0xf; |
| 740 | dac = RBIOS8(dac_info + 0x11) & 0xf; | 731 | dac = RBIOS8(dac_info + 0x11) & 0xf; |
| 741 | tv_dac->ntsc_tvdac_adj = (bg << 16) | (dac << 20); | 732 | tv_dac->ntsc_tvdac_adj = (bg << 16) | (dac << 20); |
| 733 | found = 1; | ||
| 742 | } else if (rev > 1) { | 734 | } else if (rev > 1) { |
| 743 | bg = RBIOS8(dac_info + 0xc) & 0xf; | 735 | bg = RBIOS8(dac_info + 0xc) & 0xf; |
| 744 | dac = (RBIOS8(dac_info + 0xc) >> 4) & 0xf; | 736 | dac = (RBIOS8(dac_info + 0xc) >> 4) & 0xf; |
| @@ -751,22 +743,15 @@ struct radeon_encoder_tv_dac *radeon_combios_get_tv_dac_info(struct | |||
| 751 | bg = RBIOS8(dac_info + 0xe) & 0xf; | 743 | bg = RBIOS8(dac_info + 0xe) & 0xf; |
| 752 | dac = (RBIOS8(dac_info + 0xe) >> 4) & 0xf; | 744 | dac = (RBIOS8(dac_info + 0xe) >> 4) & 0xf; |
| 753 | tv_dac->ntsc_tvdac_adj = (bg << 16) | (dac << 20); | 745 | tv_dac->ntsc_tvdac_adj = (bg << 16) | (dac << 20); |
| 746 | found = 1; | ||
| 754 | } | 747 | } |
| 755 | |||
| 756 | tv_dac->tv_std = radeon_combios_get_tv_info(encoder); | 748 | tv_dac->tv_std = radeon_combios_get_tv_info(encoder); |
| 757 | 749 | } | |
| 758 | } else { | 750 | if (!found) { |
| 759 | /* then check CRT table */ | 751 | /* then check CRT table */ |
| 760 | dac_info = | 752 | dac_info = |
| 761 | combios_get_table_offset(dev, COMBIOS_CRT_INFO_TABLE); | 753 | combios_get_table_offset(dev, COMBIOS_CRT_INFO_TABLE); |
| 762 | if (dac_info) { | 754 | if (dac_info) { |
| 763 | tv_dac = | ||
| 764 | kzalloc(sizeof(struct radeon_encoder_tv_dac), | ||
| 765 | GFP_KERNEL); | ||
| 766 | |||
| 767 | if (!tv_dac) | ||
| 768 | return NULL; | ||
| 769 | |||
| 770 | rev = RBIOS8(dac_info) & 0x3; | 755 | rev = RBIOS8(dac_info) & 0x3; |
| 771 | if (rev < 2) { | 756 | if (rev < 2) { |
| 772 | bg = RBIOS8(dac_info + 0x3) & 0xf; | 757 | bg = RBIOS8(dac_info + 0x3) & 0xf; |
| @@ -775,6 +760,7 @@ struct radeon_encoder_tv_dac *radeon_combios_get_tv_dac_info(struct | |||
| 775 | (bg << 16) | (dac << 20); | 760 | (bg << 16) | (dac << 20); |
| 776 | tv_dac->pal_tvdac_adj = tv_dac->ps2_tvdac_adj; | 761 | tv_dac->pal_tvdac_adj = tv_dac->ps2_tvdac_adj; |
| 777 | tv_dac->ntsc_tvdac_adj = tv_dac->ps2_tvdac_adj; | 762 | tv_dac->ntsc_tvdac_adj = tv_dac->ps2_tvdac_adj; |
| 763 | found = 1; | ||
| 778 | } else { | 764 | } else { |
| 779 | bg = RBIOS8(dac_info + 0x4) & 0xf; | 765 | bg = RBIOS8(dac_info + 0x4) & 0xf; |
| 780 | dac = RBIOS8(dac_info + 0x5) & 0xf; | 766 | dac = RBIOS8(dac_info + 0x5) & 0xf; |
| @@ -782,13 +768,17 @@ struct radeon_encoder_tv_dac *radeon_combios_get_tv_dac_info(struct | |||
| 782 | (bg << 16) | (dac << 20); | 768 | (bg << 16) | (dac << 20); |
| 783 | tv_dac->pal_tvdac_adj = tv_dac->ps2_tvdac_adj; | 769 | tv_dac->pal_tvdac_adj = tv_dac->ps2_tvdac_adj; |
| 784 | tv_dac->ntsc_tvdac_adj = tv_dac->ps2_tvdac_adj; | 770 | tv_dac->ntsc_tvdac_adj = tv_dac->ps2_tvdac_adj; |
| 771 | found = 1; | ||
| 785 | } | 772 | } |
| 786 | } else { | 773 | } else { |
| 787 | DRM_INFO("No TV DAC info found in BIOS\n"); | 774 | DRM_INFO("No TV DAC info found in BIOS\n"); |
| 788 | return radeon_legacy_get_tv_dac_info_from_table(rdev); | ||
| 789 | } | 775 | } |
| 790 | } | 776 | } |
| 791 | 777 | ||
| 778 | out: | ||
| 779 | if (!found) /* fallback to defaults */ | ||
| 780 | radeon_legacy_get_tv_dac_info_from_table(rdev, tv_dac); | ||
| 781 | |||
| 792 | return tv_dac; | 782 | return tv_dac; |
| 793 | } | 783 | } |
| 794 | 784 | ||
diff --git a/drivers/gpu/drm/radeon/radeon_cp.c b/drivers/gpu/drm/radeon/radeon_cp.c index d8356827ef17..7a52c461145c 100644 --- a/drivers/gpu/drm/radeon/radeon_cp.c +++ b/drivers/gpu/drm/radeon/radeon_cp.c | |||
| @@ -406,6 +406,15 @@ static void radeon_init_pipes(drm_radeon_private_t *dev_priv) | |||
| 406 | { | 406 | { |
| 407 | uint32_t gb_tile_config, gb_pipe_sel = 0; | 407 | uint32_t gb_tile_config, gb_pipe_sel = 0; |
| 408 | 408 | ||
| 409 | if ((dev_priv->flags & RADEON_FAMILY_MASK) == CHIP_RV530) { | ||
| 410 | uint32_t z_pipe_sel = RADEON_READ(RV530_GB_PIPE_SELECT2); | ||
| 411 | if ((z_pipe_sel & 3) == 3) | ||
| 412 | dev_priv->num_z_pipes = 2; | ||
| 413 | else | ||
| 414 | dev_priv->num_z_pipes = 1; | ||
| 415 | } else | ||
| 416 | dev_priv->num_z_pipes = 1; | ||
| 417 | |||
| 409 | /* RS4xx/RS6xx/R4xx/R5xx */ | 418 | /* RS4xx/RS6xx/R4xx/R5xx */ |
| 410 | if ((dev_priv->flags & RADEON_FAMILY_MASK) >= CHIP_R420) { | 419 | if ((dev_priv->flags & RADEON_FAMILY_MASK) >= CHIP_R420) { |
| 411 | gb_pipe_sel = RADEON_READ(R400_GB_PIPE_SELECT); | 420 | gb_pipe_sel = RADEON_READ(R400_GB_PIPE_SELECT); |
diff --git a/drivers/gpu/drm/radeon/radeon_cs.c b/drivers/gpu/drm/radeon/radeon_cs.c index b843f9bdfb14..a169067efc4e 100644 --- a/drivers/gpu/drm/radeon/radeon_cs.c +++ b/drivers/gpu/drm/radeon/radeon_cs.c | |||
| @@ -127,17 +127,23 @@ int radeon_cs_parser_init(struct radeon_cs_parser *p, void *data) | |||
| 127 | sizeof(struct drm_radeon_cs_chunk))) { | 127 | sizeof(struct drm_radeon_cs_chunk))) { |
| 128 | return -EFAULT; | 128 | return -EFAULT; |
| 129 | } | 129 | } |
| 130 | p->chunks[i].length_dw = user_chunk.length_dw; | ||
| 131 | p->chunks[i].kdata = NULL; | ||
| 130 | p->chunks[i].chunk_id = user_chunk.chunk_id; | 132 | p->chunks[i].chunk_id = user_chunk.chunk_id; |
| 133 | |||
| 131 | if (p->chunks[i].chunk_id == RADEON_CHUNK_ID_RELOCS) { | 134 | if (p->chunks[i].chunk_id == RADEON_CHUNK_ID_RELOCS) { |
| 132 | p->chunk_relocs_idx = i; | 135 | p->chunk_relocs_idx = i; |
| 133 | } | 136 | } |
| 134 | if (p->chunks[i].chunk_id == RADEON_CHUNK_ID_IB) { | 137 | if (p->chunks[i].chunk_id == RADEON_CHUNK_ID_IB) { |
| 135 | p->chunk_ib_idx = i; | 138 | p->chunk_ib_idx = i; |
| 139 | /* zero length IB isn't useful */ | ||
| 140 | if (p->chunks[i].length_dw == 0) | ||
| 141 | return -EINVAL; | ||
| 136 | } | 142 | } |
| 143 | |||
| 137 | p->chunks[i].length_dw = user_chunk.length_dw; | 144 | p->chunks[i].length_dw = user_chunk.length_dw; |
| 138 | cdata = (uint32_t *)(unsigned long)user_chunk.chunk_data; | 145 | cdata = (uint32_t *)(unsigned long)user_chunk.chunk_data; |
| 139 | 146 | ||
| 140 | p->chunks[i].kdata = NULL; | ||
| 141 | size = p->chunks[i].length_dw * sizeof(uint32_t); | 147 | size = p->chunks[i].length_dw * sizeof(uint32_t); |
| 142 | p->chunks[i].kdata = kzalloc(size, GFP_KERNEL); | 148 | p->chunks[i].kdata = kzalloc(size, GFP_KERNEL); |
| 143 | if (p->chunks[i].kdata == NULL) { | 149 | if (p->chunks[i].kdata == NULL) { |
diff --git a/drivers/gpu/drm/radeon/radeon_cursor.c b/drivers/gpu/drm/radeon/radeon_cursor.c index 5232441f119b..b13c79e38bc0 100644 --- a/drivers/gpu/drm/radeon/radeon_cursor.c +++ b/drivers/gpu/drm/radeon/radeon_cursor.c | |||
| @@ -111,9 +111,11 @@ static void radeon_set_cursor(struct drm_crtc *crtc, struct drm_gem_object *obj, | |||
| 111 | 111 | ||
| 112 | if (ASIC_IS_AVIVO(rdev)) | 112 | if (ASIC_IS_AVIVO(rdev)) |
| 113 | WREG32(AVIVO_D1CUR_SURFACE_ADDRESS + radeon_crtc->crtc_offset, gpu_addr); | 113 | WREG32(AVIVO_D1CUR_SURFACE_ADDRESS + radeon_crtc->crtc_offset, gpu_addr); |
| 114 | else | 114 | else { |
| 115 | radeon_crtc->legacy_cursor_offset = gpu_addr - radeon_crtc->legacy_display_base_addr; | ||
| 115 | /* offset is from DISP(2)_BASE_ADDRESS */ | 116 | /* offset is from DISP(2)_BASE_ADDRESS */ |
| 116 | WREG32(RADEON_CUR_OFFSET + radeon_crtc->crtc_offset, gpu_addr); | 117 | WREG32(RADEON_CUR_OFFSET + radeon_crtc->crtc_offset, radeon_crtc->legacy_cursor_offset); |
| 118 | } | ||
| 117 | } | 119 | } |
| 118 | 120 | ||
| 119 | int radeon_crtc_cursor_set(struct drm_crtc *crtc, | 121 | int radeon_crtc_cursor_set(struct drm_crtc *crtc, |
| @@ -245,6 +247,9 @@ int radeon_crtc_cursor_move(struct drm_crtc *crtc, | |||
| 245 | (RADEON_CUR_LOCK | 247 | (RADEON_CUR_LOCK |
| 246 | | ((xorigin ? 0 : x) << 16) | 248 | | ((xorigin ? 0 : x) << 16) |
| 247 | | (yorigin ? 0 : y))); | 249 | | (yorigin ? 0 : y))); |
| 250 | /* offset is from DISP(2)_BASE_ADDRESS */ | ||
| 251 | WREG32(RADEON_CUR_OFFSET + radeon_crtc->crtc_offset, (radeon_crtc->legacy_cursor_offset + | ||
| 252 | (yorigin * 256))); | ||
| 248 | } | 253 | } |
| 249 | radeon_lock_cursor(crtc, false); | 254 | radeon_lock_cursor(crtc, false); |
| 250 | 255 | ||
diff --git a/drivers/gpu/drm/radeon/radeon_device.c b/drivers/gpu/drm/radeon/radeon_device.c index f97563db4e59..7693f7c67bd3 100644 --- a/drivers/gpu/drm/radeon/radeon_device.c +++ b/drivers/gpu/drm/radeon/radeon_device.c | |||
| @@ -48,6 +48,8 @@ static void radeon_surface_init(struct radeon_device *rdev) | |||
| 48 | i * (RADEON_SURFACE1_INFO - RADEON_SURFACE0_INFO), | 48 | i * (RADEON_SURFACE1_INFO - RADEON_SURFACE0_INFO), |
| 49 | 0); | 49 | 0); |
| 50 | } | 50 | } |
| 51 | /* enable surfaces */ | ||
| 52 | WREG32(RADEON_SURFACE_CNTL, 0); | ||
| 51 | } | 53 | } |
| 52 | } | 54 | } |
| 53 | 55 | ||
| @@ -119,7 +121,7 @@ int radeon_mc_setup(struct radeon_device *rdev) | |||
| 119 | if (rdev->mc.vram_location != 0xFFFFFFFFUL) { | 121 | if (rdev->mc.vram_location != 0xFFFFFFFFUL) { |
| 120 | /* vram location was already setup try to put gtt after | 122 | /* vram location was already setup try to put gtt after |
| 121 | * if it fits */ | 123 | * if it fits */ |
| 122 | tmp = rdev->mc.vram_location + rdev->mc.vram_size; | 124 | tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size; |
| 123 | tmp = (tmp + rdev->mc.gtt_size - 1) & ~(rdev->mc.gtt_size - 1); | 125 | tmp = (tmp + rdev->mc.gtt_size - 1) & ~(rdev->mc.gtt_size - 1); |
| 124 | if ((0xFFFFFFFFUL - tmp) >= rdev->mc.gtt_size) { | 126 | if ((0xFFFFFFFFUL - tmp) >= rdev->mc.gtt_size) { |
| 125 | rdev->mc.gtt_location = tmp; | 127 | rdev->mc.gtt_location = tmp; |
| @@ -134,13 +136,13 @@ int radeon_mc_setup(struct radeon_device *rdev) | |||
| 134 | } else if (rdev->mc.gtt_location != 0xFFFFFFFFUL) { | 136 | } else if (rdev->mc.gtt_location != 0xFFFFFFFFUL) { |
| 135 | /* gtt location was already setup try to put vram before | 137 | /* gtt location was already setup try to put vram before |
| 136 | * if it fits */ | 138 | * if it fits */ |
| 137 | if (rdev->mc.vram_size < rdev->mc.gtt_location) { | 139 | if (rdev->mc.mc_vram_size < rdev->mc.gtt_location) { |
| 138 | rdev->mc.vram_location = 0; | 140 | rdev->mc.vram_location = 0; |
| 139 | } else { | 141 | } else { |
| 140 | tmp = rdev->mc.gtt_location + rdev->mc.gtt_size; | 142 | tmp = rdev->mc.gtt_location + rdev->mc.gtt_size; |
| 141 | tmp += (rdev->mc.vram_size - 1); | 143 | tmp += (rdev->mc.mc_vram_size - 1); |
| 142 | tmp &= ~(rdev->mc.vram_size - 1); | 144 | tmp &= ~(rdev->mc.mc_vram_size - 1); |
| 143 | if ((0xFFFFFFFFUL - tmp) >= rdev->mc.vram_size) { | 145 | if ((0xFFFFFFFFUL - tmp) >= rdev->mc.mc_vram_size) { |
| 144 | rdev->mc.vram_location = tmp; | 146 | rdev->mc.vram_location = tmp; |
| 145 | } else { | 147 | } else { |
| 146 | printk(KERN_ERR "[drm] vram too big to fit " | 148 | printk(KERN_ERR "[drm] vram too big to fit " |
| @@ -150,12 +152,16 @@ int radeon_mc_setup(struct radeon_device *rdev) | |||
| 150 | } | 152 | } |
| 151 | } else { | 153 | } else { |
| 152 | rdev->mc.vram_location = 0; | 154 | rdev->mc.vram_location = 0; |
| 153 | rdev->mc.gtt_location = rdev->mc.vram_size; | 155 | tmp = rdev->mc.mc_vram_size; |
| 156 | tmp = (tmp + rdev->mc.gtt_size - 1) & ~(rdev->mc.gtt_size - 1); | ||
| 157 | rdev->mc.gtt_location = tmp; | ||
| 154 | } | 158 | } |
| 155 | DRM_INFO("radeon: VRAM %uM\n", rdev->mc.vram_size >> 20); | 159 | DRM_INFO("radeon: VRAM %uM\n", rdev->mc.real_vram_size >> 20); |
| 156 | DRM_INFO("radeon: VRAM from 0x%08X to 0x%08X\n", | 160 | DRM_INFO("radeon: VRAM from 0x%08X to 0x%08X\n", |
| 157 | rdev->mc.vram_location, | 161 | rdev->mc.vram_location, |
| 158 | rdev->mc.vram_location + rdev->mc.vram_size - 1); | 162 | rdev->mc.vram_location + rdev->mc.mc_vram_size - 1); |
| 163 | if (rdev->mc.real_vram_size != rdev->mc.mc_vram_size) | ||
| 164 | DRM_INFO("radeon: VRAM less than aperture workaround enabled\n"); | ||
| 159 | DRM_INFO("radeon: GTT %uM\n", rdev->mc.gtt_size >> 20); | 165 | DRM_INFO("radeon: GTT %uM\n", rdev->mc.gtt_size >> 20); |
| 160 | DRM_INFO("radeon: GTT from 0x%08X to 0x%08X\n", | 166 | DRM_INFO("radeon: GTT from 0x%08X to 0x%08X\n", |
| 161 | rdev->mc.gtt_location, | 167 | rdev->mc.gtt_location, |
| @@ -219,25 +225,18 @@ void radeon_invalid_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v) | |||
| 219 | 225 | ||
| 220 | void radeon_register_accessor_init(struct radeon_device *rdev) | 226 | void radeon_register_accessor_init(struct radeon_device *rdev) |
| 221 | { | 227 | { |
| 222 | rdev->mm_rreg = &r100_mm_rreg; | ||
| 223 | rdev->mm_wreg = &r100_mm_wreg; | ||
| 224 | rdev->mc_rreg = &radeon_invalid_rreg; | 228 | rdev->mc_rreg = &radeon_invalid_rreg; |
| 225 | rdev->mc_wreg = &radeon_invalid_wreg; | 229 | rdev->mc_wreg = &radeon_invalid_wreg; |
| 226 | rdev->pll_rreg = &radeon_invalid_rreg; | 230 | rdev->pll_rreg = &radeon_invalid_rreg; |
| 227 | rdev->pll_wreg = &radeon_invalid_wreg; | 231 | rdev->pll_wreg = &radeon_invalid_wreg; |
| 228 | rdev->pcie_rreg = &radeon_invalid_rreg; | ||
| 229 | rdev->pcie_wreg = &radeon_invalid_wreg; | ||
| 230 | rdev->pciep_rreg = &radeon_invalid_rreg; | 232 | rdev->pciep_rreg = &radeon_invalid_rreg; |
| 231 | rdev->pciep_wreg = &radeon_invalid_wreg; | 233 | rdev->pciep_wreg = &radeon_invalid_wreg; |
| 232 | 234 | ||
| 233 | /* Don't change order as we are overridding accessor. */ | 235 | /* Don't change order as we are overridding accessor. */ |
| 234 | if (rdev->family < CHIP_RV515) { | 236 | if (rdev->family < CHIP_RV515) { |
| 235 | rdev->pcie_rreg = &rv370_pcie_rreg; | 237 | rdev->pcie_reg_mask = 0xff; |
| 236 | rdev->pcie_wreg = &rv370_pcie_wreg; | 238 | } else { |
| 237 | } | 239 | rdev->pcie_reg_mask = 0x7ff; |
| 238 | if (rdev->family >= CHIP_RV515) { | ||
| 239 | rdev->pcie_rreg = &rv515_pcie_rreg; | ||
| 240 | rdev->pcie_wreg = &rv515_pcie_wreg; | ||
| 241 | } | 240 | } |
| 242 | /* FIXME: not sure here */ | 241 | /* FIXME: not sure here */ |
| 243 | if (rdev->family <= CHIP_R580) { | 242 | if (rdev->family <= CHIP_R580) { |
| @@ -450,6 +449,7 @@ int radeon_device_init(struct radeon_device *rdev, | |||
| 450 | uint32_t flags) | 449 | uint32_t flags) |
| 451 | { | 450 | { |
| 452 | int r, ret; | 451 | int r, ret; |
| 452 | int dma_bits; | ||
| 453 | 453 | ||
| 454 | DRM_INFO("radeon: Initializing kernel modesetting.\n"); | 454 | DRM_INFO("radeon: Initializing kernel modesetting.\n"); |
| 455 | rdev->shutdown = false; | 455 | rdev->shutdown = false; |
| @@ -492,8 +492,20 @@ int radeon_device_init(struct radeon_device *rdev, | |||
| 492 | return r; | 492 | return r; |
| 493 | } | 493 | } |
| 494 | 494 | ||
| 495 | /* Report DMA addressing limitation */ | 495 | /* set DMA mask + need_dma32 flags. |
| 496 | r = pci_set_dma_mask(rdev->pdev, DMA_BIT_MASK(32)); | 496 | * PCIE - can handle 40-bits. |
| 497 | * IGP - can handle 40-bits (in theory) | ||
| 498 | * AGP - generally dma32 is safest | ||
| 499 | * PCI - only dma32 | ||
| 500 | */ | ||
| 501 | rdev->need_dma32 = false; | ||
| 502 | if (rdev->flags & RADEON_IS_AGP) | ||
| 503 | rdev->need_dma32 = true; | ||
| 504 | if (rdev->flags & RADEON_IS_PCI) | ||
| 505 | rdev->need_dma32 = true; | ||
| 506 | |||
| 507 | dma_bits = rdev->need_dma32 ? 32 : 40; | ||
| 508 | r = pci_set_dma_mask(rdev->pdev, DMA_BIT_MASK(dma_bits)); | ||
| 497 | if (r) { | 509 | if (r) { |
| 498 | printk(KERN_WARNING "radeon: No suitable DMA available.\n"); | 510 | printk(KERN_WARNING "radeon: No suitable DMA available.\n"); |
| 499 | } | 511 | } |
| @@ -546,27 +558,22 @@ int radeon_device_init(struct radeon_device *rdev, | |||
| 546 | radeon_combios_asic_init(rdev->ddev); | 558 | radeon_combios_asic_init(rdev->ddev); |
| 547 | } | 559 | } |
| 548 | } | 560 | } |
| 561 | /* Initialize clocks */ | ||
| 562 | r = radeon_clocks_init(rdev); | ||
| 563 | if (r) { | ||
| 564 | return r; | ||
| 565 | } | ||
| 549 | /* Get vram informations */ | 566 | /* Get vram informations */ |
| 550 | radeon_vram_info(rdev); | 567 | radeon_vram_info(rdev); |
| 551 | /* Device is severly broken if aper size > vram size. | 568 | |
| 552 | * for RN50/M6/M7 - Novell bug 204882 ? | ||
| 553 | */ | ||
| 554 | if (rdev->mc.vram_size < rdev->mc.aper_size) { | ||
| 555 | rdev->mc.aper_size = rdev->mc.vram_size; | ||
| 556 | } | ||
| 557 | /* Add an MTRR for the VRAM */ | 569 | /* Add an MTRR for the VRAM */ |
| 558 | rdev->mc.vram_mtrr = mtrr_add(rdev->mc.aper_base, rdev->mc.aper_size, | 570 | rdev->mc.vram_mtrr = mtrr_add(rdev->mc.aper_base, rdev->mc.aper_size, |
| 559 | MTRR_TYPE_WRCOMB, 1); | 571 | MTRR_TYPE_WRCOMB, 1); |
| 560 | DRM_INFO("Detected VRAM RAM=%uM, BAR=%uM\n", | 572 | DRM_INFO("Detected VRAM RAM=%uM, BAR=%uM\n", |
| 561 | rdev->mc.vram_size >> 20, | 573 | rdev->mc.real_vram_size >> 20, |
| 562 | (unsigned)rdev->mc.aper_size >> 20); | 574 | (unsigned)rdev->mc.aper_size >> 20); |
| 563 | DRM_INFO("RAM width %dbits %cDR\n", | 575 | DRM_INFO("RAM width %dbits %cDR\n", |
| 564 | rdev->mc.vram_width, rdev->mc.vram_is_ddr ? 'D' : 'S'); | 576 | rdev->mc.vram_width, rdev->mc.vram_is_ddr ? 'D' : 'S'); |
| 565 | /* Initialize clocks */ | ||
| 566 | r = radeon_clocks_init(rdev); | ||
| 567 | if (r) { | ||
| 568 | return r; | ||
| 569 | } | ||
| 570 | /* Initialize memory controller (also test AGP) */ | 577 | /* Initialize memory controller (also test AGP) */ |
| 571 | r = radeon_mc_init(rdev); | 578 | r = radeon_mc_init(rdev); |
| 572 | if (r) { | 579 | if (r) { |
| @@ -626,6 +633,9 @@ int radeon_device_init(struct radeon_device *rdev, | |||
| 626 | if (!ret) { | 633 | if (!ret) { |
| 627 | DRM_INFO("radeon: kernel modesetting successfully initialized.\n"); | 634 | DRM_INFO("radeon: kernel modesetting successfully initialized.\n"); |
| 628 | } | 635 | } |
| 636 | if (radeon_testing) { | ||
| 637 | radeon_test_moves(rdev); | ||
| 638 | } | ||
| 629 | if (radeon_benchmarking) { | 639 | if (radeon_benchmarking) { |
| 630 | radeon_benchmark(rdev); | 640 | radeon_benchmark(rdev); |
| 631 | } | 641 | } |
diff --git a/drivers/gpu/drm/radeon/radeon_display.c b/drivers/gpu/drm/radeon/radeon_display.c index 3efcf1a526be..a8fa1bb84cf7 100644 --- a/drivers/gpu/drm/radeon/radeon_display.c +++ b/drivers/gpu/drm/radeon/radeon_display.c | |||
| @@ -187,6 +187,7 @@ static void radeon_crtc_init(struct drm_device *dev, int index) | |||
| 187 | 187 | ||
| 188 | drm_mode_crtc_set_gamma_size(&radeon_crtc->base, 256); | 188 | drm_mode_crtc_set_gamma_size(&radeon_crtc->base, 256); |
| 189 | radeon_crtc->crtc_id = index; | 189 | radeon_crtc->crtc_id = index; |
| 190 | rdev->mode_info.crtcs[index] = radeon_crtc; | ||
| 190 | 191 | ||
| 191 | radeon_crtc->mode_set.crtc = &radeon_crtc->base; | 192 | radeon_crtc->mode_set.crtc = &radeon_crtc->base; |
| 192 | radeon_crtc->mode_set.connectors = (struct drm_connector **)(radeon_crtc + 1); | 193 | radeon_crtc->mode_set.connectors = (struct drm_connector **)(radeon_crtc + 1); |
| @@ -491,7 +492,11 @@ void radeon_compute_pll(struct radeon_pll *pll, | |||
| 491 | tmp += (uint64_t)pll->reference_freq * 1000 * frac_feedback_div; | 492 | tmp += (uint64_t)pll->reference_freq * 1000 * frac_feedback_div; |
| 492 | current_freq = radeon_div(tmp, ref_div * post_div); | 493 | current_freq = radeon_div(tmp, ref_div * post_div); |
| 493 | 494 | ||
| 494 | error = abs(current_freq - freq); | 495 | if (flags & RADEON_PLL_PREFER_CLOSEST_LOWER) { |
| 496 | error = freq - current_freq; | ||
| 497 | error = error < 0 ? 0xffffffff : error; | ||
| 498 | } else | ||
| 499 | error = abs(current_freq - freq); | ||
| 495 | vco_diff = abs(vco - best_vco); | 500 | vco_diff = abs(vco - best_vco); |
| 496 | 501 | ||
| 497 | if ((best_vco == 0 && error < best_error) || | 502 | if ((best_vco == 0 && error < best_error) || |
| @@ -657,36 +662,51 @@ void radeon_modeset_fini(struct radeon_device *rdev) | |||
| 657 | } | 662 | } |
| 658 | } | 663 | } |
| 659 | 664 | ||
| 660 | void radeon_init_disp_bandwidth(struct drm_device *dev) | 665 | bool radeon_crtc_scaling_mode_fixup(struct drm_crtc *crtc, |
| 666 | struct drm_display_mode *mode, | ||
| 667 | struct drm_display_mode *adjusted_mode) | ||
| 661 | { | 668 | { |
| 662 | struct radeon_device *rdev = dev->dev_private; | 669 | struct drm_device *dev = crtc->dev; |
| 663 | struct drm_display_mode *modes[2]; | 670 | struct drm_encoder *encoder; |
| 664 | int pixel_bytes[2]; | 671 | struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); |
| 665 | struct drm_crtc *crtc; | 672 | struct radeon_encoder *radeon_encoder; |
| 666 | 673 | bool first = true; | |
| 667 | pixel_bytes[0] = pixel_bytes[1] = 0; | ||
| 668 | modes[0] = modes[1] = NULL; | ||
| 669 | |||
| 670 | list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) { | ||
| 671 | struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); | ||
| 672 | 674 | ||
| 673 | if (crtc->enabled && crtc->fb) { | 675 | list_for_each_entry(encoder, &dev->mode_config.encoder_list, head) { |
| 674 | modes[radeon_crtc->crtc_id] = &crtc->mode; | 676 | radeon_encoder = to_radeon_encoder(encoder); |
| 675 | pixel_bytes[radeon_crtc->crtc_id] = crtc->fb->bits_per_pixel / 8; | 677 | if (encoder->crtc != crtc) |
| 678 | continue; | ||
| 679 | if (first) { | ||
| 680 | radeon_crtc->rmx_type = radeon_encoder->rmx_type; | ||
| 681 | radeon_crtc->devices = radeon_encoder->devices; | ||
| 682 | memcpy(&radeon_crtc->native_mode, | ||
| 683 | &radeon_encoder->native_mode, | ||
| 684 | sizeof(struct radeon_native_mode)); | ||
| 685 | first = false; | ||
| 686 | } else { | ||
| 687 | if (radeon_crtc->rmx_type != radeon_encoder->rmx_type) { | ||
| 688 | /* WARNING: Right now this can't happen but | ||
| 689 | * in the future we need to check that scaling | ||
| 690 | * are consistent accross different encoder | ||
| 691 | * (ie all encoder can work with the same | ||
| 692 | * scaling). | ||
| 693 | */ | ||
| 694 | DRM_ERROR("Scaling not consistent accross encoder.\n"); | ||
| 695 | return false; | ||
| 696 | } | ||
| 676 | } | 697 | } |
| 677 | } | 698 | } |
| 678 | 699 | if (radeon_crtc->rmx_type != RMX_OFF) { | |
| 679 | if (ASIC_IS_AVIVO(rdev)) { | 700 | fixed20_12 a, b; |
| 680 | radeon_init_disp_bw_avivo(dev, | 701 | a.full = rfixed_const(crtc->mode.vdisplay); |
| 681 | modes[0], | 702 | b.full = rfixed_const(radeon_crtc->native_mode.panel_xres); |
| 682 | pixel_bytes[0], | 703 | radeon_crtc->vsc.full = rfixed_div(a, b); |
| 683 | modes[1], | 704 | a.full = rfixed_const(crtc->mode.hdisplay); |
| 684 | pixel_bytes[1]); | 705 | b.full = rfixed_const(radeon_crtc->native_mode.panel_yres); |
| 706 | radeon_crtc->hsc.full = rfixed_div(a, b); | ||
| 685 | } else { | 707 | } else { |
| 686 | radeon_init_disp_bw_legacy(dev, | 708 | radeon_crtc->vsc.full = rfixed_const(1); |
| 687 | modes[0], | 709 | radeon_crtc->hsc.full = rfixed_const(1); |
| 688 | pixel_bytes[0], | ||
| 689 | modes[1], | ||
| 690 | pixel_bytes[1]); | ||
| 691 | } | 710 | } |
| 711 | return true; | ||
| 692 | } | 712 | } |
diff --git a/drivers/gpu/drm/radeon/radeon_drv.c b/drivers/gpu/drm/radeon/radeon_drv.c index 84ba69f48784..0bd5879a4957 100644 --- a/drivers/gpu/drm/radeon/radeon_drv.c +++ b/drivers/gpu/drm/radeon/radeon_drv.c | |||
| @@ -89,6 +89,7 @@ int radeon_agpmode = 0; | |||
| 89 | int radeon_vram_limit = 0; | 89 | int radeon_vram_limit = 0; |
| 90 | int radeon_gart_size = 512; /* default gart size */ | 90 | int radeon_gart_size = 512; /* default gart size */ |
| 91 | int radeon_benchmarking = 0; | 91 | int radeon_benchmarking = 0; |
| 92 | int radeon_testing = 0; | ||
| 92 | int radeon_connector_table = 0; | 93 | int radeon_connector_table = 0; |
| 93 | #endif | 94 | #endif |
| 94 | 95 | ||
| @@ -117,6 +118,9 @@ module_param_named(gartsize, radeon_gart_size, int, 0600); | |||
| 117 | MODULE_PARM_DESC(benchmark, "Run benchmark"); | 118 | MODULE_PARM_DESC(benchmark, "Run benchmark"); |
| 118 | module_param_named(benchmark, radeon_benchmarking, int, 0444); | 119 | module_param_named(benchmark, radeon_benchmarking, int, 0444); |
| 119 | 120 | ||
| 121 | MODULE_PARM_DESC(test, "Run tests"); | ||
| 122 | module_param_named(test, radeon_testing, int, 0444); | ||
| 123 | |||
| 120 | MODULE_PARM_DESC(connector_table, "Force connector table"); | 124 | MODULE_PARM_DESC(connector_table, "Force connector table"); |
| 121 | module_param_named(connector_table, radeon_connector_table, int, 0444); | 125 | module_param_named(connector_table, radeon_connector_table, int, 0444); |
| 122 | #endif | 126 | #endif |
| @@ -314,6 +318,14 @@ static int __init radeon_init(void) | |||
| 314 | driver = &driver_old; | 318 | driver = &driver_old; |
| 315 | driver->num_ioctls = radeon_max_ioctl; | 319 | driver->num_ioctls = radeon_max_ioctl; |
| 316 | #if defined(CONFIG_DRM_RADEON_KMS) | 320 | #if defined(CONFIG_DRM_RADEON_KMS) |
| 321 | #ifdef CONFIG_VGA_CONSOLE | ||
| 322 | if (vgacon_text_force() && radeon_modeset == -1) { | ||
| 323 | DRM_INFO("VGACON disable radeon kernel modesetting.\n"); | ||
| 324 | driver = &driver_old; | ||
| 325 | driver->driver_features &= ~DRIVER_MODESET; | ||
| 326 | radeon_modeset = 0; | ||
| 327 | } | ||
| 328 | #endif | ||
| 317 | /* if enabled by default */ | 329 | /* if enabled by default */ |
| 318 | if (radeon_modeset == -1) { | 330 | if (radeon_modeset == -1) { |
| 319 | DRM_INFO("radeon default to kernel modesetting.\n"); | 331 | DRM_INFO("radeon default to kernel modesetting.\n"); |
| @@ -325,17 +337,8 @@ static int __init radeon_init(void) | |||
| 325 | driver->driver_features |= DRIVER_MODESET; | 337 | driver->driver_features |= DRIVER_MODESET; |
| 326 | driver->num_ioctls = radeon_max_kms_ioctl; | 338 | driver->num_ioctls = radeon_max_kms_ioctl; |
| 327 | } | 339 | } |
| 328 | |||
| 329 | /* if the vga console setting is enabled still | 340 | /* if the vga console setting is enabled still |
| 330 | * let modprobe override it */ | 341 | * let modprobe override it */ |
| 331 | #ifdef CONFIG_VGA_CONSOLE | ||
| 332 | if (vgacon_text_force() && radeon_modeset == -1) { | ||
| 333 | DRM_INFO("VGACON disable radeon kernel modesetting.\n"); | ||
| 334 | driver = &driver_old; | ||
| 335 | driver->driver_features &= ~DRIVER_MODESET; | ||
| 336 | radeon_modeset = 0; | ||
| 337 | } | ||
| 338 | #endif | ||
| 339 | #endif | 342 | #endif |
| 340 | return drm_init(driver); | 343 | return drm_init(driver); |
| 341 | } | 344 | } |
diff --git a/drivers/gpu/drm/radeon/radeon_drv.h b/drivers/gpu/drm/radeon/radeon_drv.h index 127d0456f628..6fa32dac4e97 100644 --- a/drivers/gpu/drm/radeon/radeon_drv.h +++ b/drivers/gpu/drm/radeon/radeon_drv.h | |||
| @@ -100,9 +100,10 @@ | |||
| 100 | * 1.28- Add support for VBL on CRTC2 | 100 | * 1.28- Add support for VBL on CRTC2 |
| 101 | * 1.29- R500 3D cmd buffer support | 101 | * 1.29- R500 3D cmd buffer support |
| 102 | * 1.30- Add support for occlusion queries | 102 | * 1.30- Add support for occlusion queries |
| 103 | * 1.31- Add support for num Z pipes from GET_PARAM | ||
| 103 | */ | 104 | */ |
| 104 | #define DRIVER_MAJOR 1 | 105 | #define DRIVER_MAJOR 1 |
| 105 | #define DRIVER_MINOR 30 | 106 | #define DRIVER_MINOR 31 |
| 106 | #define DRIVER_PATCHLEVEL 0 | 107 | #define DRIVER_PATCHLEVEL 0 |
| 107 | 108 | ||
| 108 | /* | 109 | /* |
| @@ -143,6 +144,7 @@ enum radeon_family { | |||
| 143 | CHIP_RV635, | 144 | CHIP_RV635, |
| 144 | CHIP_RV670, | 145 | CHIP_RV670, |
| 145 | CHIP_RS780, | 146 | CHIP_RS780, |
| 147 | CHIP_RS880, | ||
| 146 | CHIP_RV770, | 148 | CHIP_RV770, |
| 147 | CHIP_RV730, | 149 | CHIP_RV730, |
| 148 | CHIP_RV710, | 150 | CHIP_RV710, |
| @@ -328,6 +330,7 @@ typedef struct drm_radeon_private { | |||
| 328 | resource_size_t fb_aper_offset; | 330 | resource_size_t fb_aper_offset; |
| 329 | 331 | ||
| 330 | int num_gb_pipes; | 332 | int num_gb_pipes; |
| 333 | int num_z_pipes; | ||
| 331 | int track_flush; | 334 | int track_flush; |
| 332 | drm_local_map_t *mmio; | 335 | drm_local_map_t *mmio; |
| 333 | 336 | ||
| @@ -688,6 +691,7 @@ extern void r600_page_table_cleanup(struct drm_device *dev, struct drm_ati_pciga | |||
| 688 | 691 | ||
| 689 | /* pipe config regs */ | 692 | /* pipe config regs */ |
| 690 | #define R400_GB_PIPE_SELECT 0x402c | 693 | #define R400_GB_PIPE_SELECT 0x402c |
| 694 | #define RV530_GB_PIPE_SELECT2 0x4124 | ||
| 691 | #define R500_DYN_SCLK_PWMEM_PIPE 0x000d /* PLL */ | 695 | #define R500_DYN_SCLK_PWMEM_PIPE 0x000d /* PLL */ |
| 692 | #define R300_GB_TILE_CONFIG 0x4018 | 696 | #define R300_GB_TILE_CONFIG 0x4018 |
| 693 | # define R300_ENABLE_TILING (1 << 0) | 697 | # define R300_ENABLE_TILING (1 << 0) |
diff --git a/drivers/gpu/drm/radeon/radeon_encoders.c b/drivers/gpu/drm/radeon/radeon_encoders.c index c8ef0d14ffab..0a92706eac19 100644 --- a/drivers/gpu/drm/radeon/radeon_encoders.c +++ b/drivers/gpu/drm/radeon/radeon_encoders.c | |||
| @@ -154,7 +154,6 @@ void radeon_rmx_mode_fixup(struct drm_encoder *encoder, | |||
| 154 | 154 | ||
| 155 | if (mode->hdisplay < native_mode->panel_xres || | 155 | if (mode->hdisplay < native_mode->panel_xres || |
| 156 | mode->vdisplay < native_mode->panel_yres) { | 156 | mode->vdisplay < native_mode->panel_yres) { |
| 157 | radeon_encoder->flags |= RADEON_USE_RMX; | ||
| 158 | if (ASIC_IS_AVIVO(rdev)) { | 157 | if (ASIC_IS_AVIVO(rdev)) { |
| 159 | adjusted_mode->hdisplay = native_mode->panel_xres; | 158 | adjusted_mode->hdisplay = native_mode->panel_xres; |
| 160 | adjusted_mode->vdisplay = native_mode->panel_yres; | 159 | adjusted_mode->vdisplay = native_mode->panel_yres; |
| @@ -197,15 +196,13 @@ void radeon_rmx_mode_fixup(struct drm_encoder *encoder, | |||
| 197 | } | 196 | } |
| 198 | } | 197 | } |
| 199 | 198 | ||
| 199 | |||
| 200 | static bool radeon_atom_mode_fixup(struct drm_encoder *encoder, | 200 | static bool radeon_atom_mode_fixup(struct drm_encoder *encoder, |
| 201 | struct drm_display_mode *mode, | 201 | struct drm_display_mode *mode, |
| 202 | struct drm_display_mode *adjusted_mode) | 202 | struct drm_display_mode *adjusted_mode) |
| 203 | { | 203 | { |
| 204 | |||
| 205 | struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder); | 204 | struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder); |
| 206 | 205 | ||
| 207 | radeon_encoder->flags &= ~RADEON_USE_RMX; | ||
| 208 | |||
| 209 | drm_mode_set_crtcinfo(adjusted_mode, 0); | 206 | drm_mode_set_crtcinfo(adjusted_mode, 0); |
| 210 | 207 | ||
| 211 | if (radeon_encoder->rmx_type != RMX_OFF) | 208 | if (radeon_encoder->rmx_type != RMX_OFF) |
| @@ -808,234 +805,6 @@ atombios_dig_transmitter_setup(struct drm_encoder *encoder, int action) | |||
| 808 | 805 | ||
| 809 | } | 806 | } |
| 810 | 807 | ||
| 811 | static void atom_rv515_force_tv_scaler(struct radeon_device *rdev) | ||
| 812 | { | ||
| 813 | |||
| 814 | WREG32(0x659C, 0x0); | ||
| 815 | WREG32(0x6594, 0x705); | ||
| 816 | WREG32(0x65A4, 0x10001); | ||
| 817 | WREG32(0x65D8, 0x0); | ||
| 818 | WREG32(0x65B0, 0x0); | ||
| 819 | WREG32(0x65C0, 0x0); | ||
| 820 | WREG32(0x65D4, 0x0); | ||
| 821 | WREG32(0x6578, 0x0); | ||
| 822 | WREG32(0x657C, 0x841880A8); | ||
| 823 | WREG32(0x6578, 0x1); | ||
| 824 | WREG32(0x657C, 0x84208680); | ||
| 825 | WREG32(0x6578, 0x2); | ||
| 826 | WREG32(0x657C, 0xBFF880B0); | ||
| 827 | WREG32(0x6578, 0x100); | ||
| 828 | WREG32(0x657C, 0x83D88088); | ||
| 829 | WREG32(0x6578, 0x101); | ||
| 830 | WREG32(0x657C, 0x84608680); | ||
| 831 | WREG32(0x6578, 0x102); | ||
| 832 | WREG32(0x657C, 0xBFF080D0); | ||
| 833 | WREG32(0x6578, 0x200); | ||
| 834 | WREG32(0x657C, 0x83988068); | ||
| 835 | WREG32(0x6578, 0x201); | ||
| 836 | WREG32(0x657C, 0x84A08680); | ||
| 837 | WREG32(0x6578, 0x202); | ||
| 838 | WREG32(0x657C, 0xBFF080F8); | ||
| 839 | WREG32(0x6578, 0x300); | ||
| 840 | WREG32(0x657C, 0x83588058); | ||
| 841 | WREG32(0x6578, 0x301); | ||
| 842 | WREG32(0x657C, 0x84E08660); | ||
| 843 | WREG32(0x6578, 0x302); | ||
| 844 | WREG32(0x657C, 0xBFF88120); | ||
| 845 | WREG32(0x6578, 0x400); | ||
| 846 | WREG32(0x657C, 0x83188040); | ||
| 847 | WREG32(0x6578, 0x401); | ||
| 848 | WREG32(0x657C, 0x85008660); | ||
| 849 | WREG32(0x6578, 0x402); | ||
| 850 | WREG32(0x657C, 0xBFF88150); | ||
| 851 | WREG32(0x6578, 0x500); | ||
| 852 | WREG32(0x657C, 0x82D88030); | ||
| 853 | WREG32(0x6578, 0x501); | ||
| 854 | WREG32(0x657C, 0x85408640); | ||
| 855 | WREG32(0x6578, 0x502); | ||
| 856 | WREG32(0x657C, 0xBFF88180); | ||
| 857 | WREG32(0x6578, 0x600); | ||
| 858 | WREG32(0x657C, 0x82A08018); | ||
| 859 | WREG32(0x6578, 0x601); | ||
| 860 | WREG32(0x657C, 0x85808620); | ||
| 861 | WREG32(0x6578, 0x602); | ||
| 862 | WREG32(0x657C, 0xBFF081B8); | ||
| 863 | WREG32(0x6578, 0x700); | ||
| 864 | WREG32(0x657C, 0x82608010); | ||
| 865 | WREG32(0x6578, 0x701); | ||
| 866 | WREG32(0x657C, 0x85A08600); | ||
| 867 | WREG32(0x6578, 0x702); | ||
| 868 | WREG32(0x657C, 0x800081F0); | ||
| 869 | WREG32(0x6578, 0x800); | ||
| 870 | WREG32(0x657C, 0x8228BFF8); | ||
| 871 | WREG32(0x6578, 0x801); | ||
| 872 | WREG32(0x657C, 0x85E085E0); | ||
| 873 | WREG32(0x6578, 0x802); | ||
| 874 | WREG32(0x657C, 0xBFF88228); | ||
| 875 | WREG32(0x6578, 0x10000); | ||
| 876 | WREG32(0x657C, 0x82A8BF00); | ||
| 877 | WREG32(0x6578, 0x10001); | ||
| 878 | WREG32(0x657C, 0x82A08CC0); | ||
| 879 | WREG32(0x6578, 0x10002); | ||
| 880 | WREG32(0x657C, 0x8008BEF8); | ||
| 881 | WREG32(0x6578, 0x10100); | ||
| 882 | WREG32(0x657C, 0x81F0BF28); | ||
| 883 | WREG32(0x6578, 0x10101); | ||
| 884 | WREG32(0x657C, 0x83608CA0); | ||
| 885 | WREG32(0x6578, 0x10102); | ||
| 886 | WREG32(0x657C, 0x8018BED0); | ||
| 887 | WREG32(0x6578, 0x10200); | ||
| 888 | WREG32(0x657C, 0x8148BF38); | ||
| 889 | WREG32(0x6578, 0x10201); | ||
| 890 | WREG32(0x657C, 0x84408C80); | ||
| 891 | WREG32(0x6578, 0x10202); | ||
| 892 | WREG32(0x657C, 0x8008BEB8); | ||
| 893 | WREG32(0x6578, 0x10300); | ||
| 894 | WREG32(0x657C, 0x80B0BF78); | ||
| 895 | WREG32(0x6578, 0x10301); | ||
| 896 | WREG32(0x657C, 0x85008C20); | ||
| 897 | WREG32(0x6578, 0x10302); | ||
| 898 | WREG32(0x657C, 0x8020BEA0); | ||
| 899 | WREG32(0x6578, 0x10400); | ||
| 900 | WREG32(0x657C, 0x8028BF90); | ||
| 901 | WREG32(0x6578, 0x10401); | ||
| 902 | WREG32(0x657C, 0x85E08BC0); | ||
| 903 | WREG32(0x6578, 0x10402); | ||
| 904 | WREG32(0x657C, 0x8018BE90); | ||
| 905 | WREG32(0x6578, 0x10500); | ||
| 906 | WREG32(0x657C, 0xBFB8BFB0); | ||
| 907 | WREG32(0x6578, 0x10501); | ||
| 908 | WREG32(0x657C, 0x86C08B40); | ||
| 909 | WREG32(0x6578, 0x10502); | ||
| 910 | WREG32(0x657C, 0x8010BE90); | ||
| 911 | WREG32(0x6578, 0x10600); | ||
| 912 | WREG32(0x657C, 0xBF58BFC8); | ||
| 913 | WREG32(0x6578, 0x10601); | ||
| 914 | WREG32(0x657C, 0x87A08AA0); | ||
| 915 | WREG32(0x6578, 0x10602); | ||
| 916 | WREG32(0x657C, 0x8010BE98); | ||
| 917 | WREG32(0x6578, 0x10700); | ||
| 918 | WREG32(0x657C, 0xBF10BFF0); | ||
| 919 | WREG32(0x6578, 0x10701); | ||
| 920 | WREG32(0x657C, 0x886089E0); | ||
| 921 | WREG32(0x6578, 0x10702); | ||
| 922 | WREG32(0x657C, 0x8018BEB0); | ||
| 923 | WREG32(0x6578, 0x10800); | ||
| 924 | WREG32(0x657C, 0xBED8BFE8); | ||
| 925 | WREG32(0x6578, 0x10801); | ||
| 926 | WREG32(0x657C, 0x89408940); | ||
| 927 | WREG32(0x6578, 0x10802); | ||
| 928 | WREG32(0x657C, 0xBFE8BED8); | ||
| 929 | WREG32(0x6578, 0x20000); | ||
| 930 | WREG32(0x657C, 0x80008000); | ||
| 931 | WREG32(0x6578, 0x20001); | ||
| 932 | WREG32(0x657C, 0x90008000); | ||
| 933 | WREG32(0x6578, 0x20002); | ||
| 934 | WREG32(0x657C, 0x80008000); | ||
| 935 | WREG32(0x6578, 0x20003); | ||
| 936 | WREG32(0x657C, 0x80008000); | ||
| 937 | WREG32(0x6578, 0x20100); | ||
| 938 | WREG32(0x657C, 0x80108000); | ||
| 939 | WREG32(0x6578, 0x20101); | ||
| 940 | WREG32(0x657C, 0x8FE0BF70); | ||
| 941 | WREG32(0x6578, 0x20102); | ||
| 942 | WREG32(0x657C, 0xBFE880C0); | ||
| 943 | WREG32(0x6578, 0x20103); | ||
| 944 | WREG32(0x657C, 0x80008000); | ||
| 945 | WREG32(0x6578, 0x20200); | ||
| 946 | WREG32(0x657C, 0x8018BFF8); | ||
| 947 | WREG32(0x6578, 0x20201); | ||
| 948 | WREG32(0x657C, 0x8F80BF08); | ||
| 949 | WREG32(0x6578, 0x20202); | ||
| 950 | WREG32(0x657C, 0xBFD081A0); | ||
| 951 | WREG32(0x6578, 0x20203); | ||
| 952 | WREG32(0x657C, 0xBFF88000); | ||
| 953 | WREG32(0x6578, 0x20300); | ||
| 954 | WREG32(0x657C, 0x80188000); | ||
| 955 | WREG32(0x6578, 0x20301); | ||
| 956 | WREG32(0x657C, 0x8EE0BEC0); | ||
| 957 | WREG32(0x6578, 0x20302); | ||
| 958 | WREG32(0x657C, 0xBFB082A0); | ||
| 959 | WREG32(0x6578, 0x20303); | ||
| 960 | WREG32(0x657C, 0x80008000); | ||
| 961 | WREG32(0x6578, 0x20400); | ||
| 962 | WREG32(0x657C, 0x80188000); | ||
| 963 | WREG32(0x6578, 0x20401); | ||
| 964 | WREG32(0x657C, 0x8E00BEA0); | ||
| 965 | WREG32(0x6578, 0x20402); | ||
| 966 | WREG32(0x657C, 0xBF8883C0); | ||
| 967 | WREG32(0x6578, 0x20403); | ||
| 968 | WREG32(0x657C, 0x80008000); | ||
| 969 | WREG32(0x6578, 0x20500); | ||
| 970 | WREG32(0x657C, 0x80188000); | ||
| 971 | WREG32(0x6578, 0x20501); | ||
| 972 | WREG32(0x657C, 0x8D00BE90); | ||
| 973 | WREG32(0x6578, 0x20502); | ||
| 974 | WREG32(0x657C, 0xBF588500); | ||
| 975 | WREG32(0x6578, 0x20503); | ||
| 976 | WREG32(0x657C, 0x80008008); | ||
| 977 | WREG32(0x6578, 0x20600); | ||
| 978 | WREG32(0x657C, 0x80188000); | ||
| 979 | WREG32(0x6578, 0x20601); | ||
| 980 | WREG32(0x657C, 0x8BC0BE98); | ||
| 981 | WREG32(0x6578, 0x20602); | ||
| 982 | WREG32(0x657C, 0xBF308660); | ||
| 983 | WREG32(0x6578, 0x20603); | ||
| 984 | WREG32(0x657C, 0x80008008); | ||
| 985 | WREG32(0x6578, 0x20700); | ||
| 986 | WREG32(0x657C, 0x80108000); | ||
| 987 | WREG32(0x6578, 0x20701); | ||
| 988 | WREG32(0x657C, 0x8A80BEB0); | ||
| 989 | WREG32(0x6578, 0x20702); | ||
| 990 | WREG32(0x657C, 0xBF0087C0); | ||
| 991 | WREG32(0x6578, 0x20703); | ||
| 992 | WREG32(0x657C, 0x80008008); | ||
| 993 | WREG32(0x6578, 0x20800); | ||
| 994 | WREG32(0x657C, 0x80108000); | ||
| 995 | WREG32(0x6578, 0x20801); | ||
| 996 | WREG32(0x657C, 0x8920BED0); | ||
| 997 | WREG32(0x6578, 0x20802); | ||
| 998 | WREG32(0x657C, 0xBED08920); | ||
| 999 | WREG32(0x6578, 0x20803); | ||
| 1000 | WREG32(0x657C, 0x80008010); | ||
| 1001 | WREG32(0x6578, 0x30000); | ||
| 1002 | WREG32(0x657C, 0x90008000); | ||
| 1003 | WREG32(0x6578, 0x30001); | ||
| 1004 | WREG32(0x657C, 0x80008000); | ||
| 1005 | WREG32(0x6578, 0x30100); | ||
| 1006 | WREG32(0x657C, 0x8FE0BF90); | ||
| 1007 | WREG32(0x6578, 0x30101); | ||
| 1008 | WREG32(0x657C, 0xBFF880A0); | ||
| 1009 | WREG32(0x6578, 0x30200); | ||
| 1010 | WREG32(0x657C, 0x8F60BF40); | ||
| 1011 | WREG32(0x6578, 0x30201); | ||
| 1012 | WREG32(0x657C, 0xBFE88180); | ||
| 1013 | WREG32(0x6578, 0x30300); | ||
| 1014 | WREG32(0x657C, 0x8EC0BF00); | ||
| 1015 | WREG32(0x6578, 0x30301); | ||
| 1016 | WREG32(0x657C, 0xBFC88280); | ||
| 1017 | WREG32(0x6578, 0x30400); | ||
| 1018 | WREG32(0x657C, 0x8DE0BEE0); | ||
| 1019 | WREG32(0x6578, 0x30401); | ||
| 1020 | WREG32(0x657C, 0xBFA083A0); | ||
| 1021 | WREG32(0x6578, 0x30500); | ||
| 1022 | WREG32(0x657C, 0x8CE0BED0); | ||
| 1023 | WREG32(0x6578, 0x30501); | ||
| 1024 | WREG32(0x657C, 0xBF7884E0); | ||
| 1025 | WREG32(0x6578, 0x30600); | ||
| 1026 | WREG32(0x657C, 0x8BA0BED8); | ||
| 1027 | WREG32(0x6578, 0x30601); | ||
| 1028 | WREG32(0x657C, 0xBF508640); | ||
| 1029 | WREG32(0x6578, 0x30700); | ||
| 1030 | WREG32(0x657C, 0x8A60BEE8); | ||
| 1031 | WREG32(0x6578, 0x30701); | ||
| 1032 | WREG32(0x657C, 0xBF2087A0); | ||
| 1033 | WREG32(0x6578, 0x30800); | ||
| 1034 | WREG32(0x657C, 0x8900BF00); | ||
| 1035 | WREG32(0x6578, 0x30801); | ||
| 1036 | WREG32(0x657C, 0xBF008900); | ||
| 1037 | } | ||
| 1038 | |||
| 1039 | static void | 808 | static void |
| 1040 | atombios_yuv_setup(struct drm_encoder *encoder, bool enable) | 809 | atombios_yuv_setup(struct drm_encoder *encoder, bool enable) |
| 1041 | { | 810 | { |
| @@ -1074,129 +843,6 @@ atombios_yuv_setup(struct drm_encoder *encoder, bool enable) | |||
| 1074 | } | 843 | } |
| 1075 | 844 | ||
| 1076 | static void | 845 | static void |
| 1077 | atombios_overscan_setup(struct drm_encoder *encoder, | ||
| 1078 | struct drm_display_mode *mode, | ||
| 1079 | struct drm_display_mode *adjusted_mode) | ||
| 1080 | { | ||
| 1081 | struct drm_device *dev = encoder->dev; | ||
| 1082 | struct radeon_device *rdev = dev->dev_private; | ||
| 1083 | struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder); | ||
| 1084 | struct radeon_crtc *radeon_crtc = to_radeon_crtc(encoder->crtc); | ||
| 1085 | SET_CRTC_OVERSCAN_PS_ALLOCATION args; | ||
| 1086 | int index = GetIndexIntoMasterTable(COMMAND, SetCRTC_OverScan); | ||
| 1087 | |||
| 1088 | memset(&args, 0, sizeof(args)); | ||
| 1089 | |||
| 1090 | args.usOverscanRight = 0; | ||
| 1091 | args.usOverscanLeft = 0; | ||
| 1092 | args.usOverscanBottom = 0; | ||
| 1093 | args.usOverscanTop = 0; | ||
| 1094 | args.ucCRTC = radeon_crtc->crtc_id; | ||
| 1095 | |||
| 1096 | if (radeon_encoder->flags & RADEON_USE_RMX) { | ||
| 1097 | if (radeon_encoder->rmx_type == RMX_FULL) { | ||
| 1098 | args.usOverscanRight = 0; | ||
| 1099 | args.usOverscanLeft = 0; | ||
| 1100 | args.usOverscanBottom = 0; | ||
| 1101 | args.usOverscanTop = 0; | ||
| 1102 | } else if (radeon_encoder->rmx_type == RMX_CENTER) { | ||
| 1103 | args.usOverscanTop = (adjusted_mode->crtc_vdisplay - mode->crtc_vdisplay) / 2; | ||
| 1104 | args.usOverscanBottom = (adjusted_mode->crtc_vdisplay - mode->crtc_vdisplay) / 2; | ||
| 1105 | args.usOverscanLeft = (adjusted_mode->crtc_hdisplay - mode->crtc_hdisplay) / 2; | ||
| 1106 | args.usOverscanRight = (adjusted_mode->crtc_hdisplay - mode->crtc_hdisplay) / 2; | ||
| 1107 | } else if (radeon_encoder->rmx_type == RMX_ASPECT) { | ||
| 1108 | int a1 = mode->crtc_vdisplay * adjusted_mode->crtc_hdisplay; | ||
| 1109 | int a2 = adjusted_mode->crtc_vdisplay * mode->crtc_hdisplay; | ||
| 1110 | |||
| 1111 | if (a1 > a2) { | ||
| 1112 | args.usOverscanLeft = (adjusted_mode->crtc_hdisplay - (a2 / mode->crtc_vdisplay)) / 2; | ||
| 1113 | args.usOverscanRight = (adjusted_mode->crtc_hdisplay - (a2 / mode->crtc_vdisplay)) / 2; | ||
| 1114 | } else if (a2 > a1) { | ||
| 1115 | args.usOverscanLeft = (adjusted_mode->crtc_vdisplay - (a1 / mode->crtc_hdisplay)) / 2; | ||
| 1116 | args.usOverscanRight = (adjusted_mode->crtc_vdisplay - (a1 / mode->crtc_hdisplay)) / 2; | ||
| 1117 | } | ||
| 1118 | } | ||
| 1119 | } | ||
| 1120 | |||
| 1121 | atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args); | ||
| 1122 | |||
| 1123 | } | ||
| 1124 | |||
| 1125 | static void | ||
| 1126 | atombios_scaler_setup(struct drm_encoder *encoder) | ||
| 1127 | { | ||
| 1128 | struct drm_device *dev = encoder->dev; | ||
| 1129 | struct radeon_device *rdev = dev->dev_private; | ||
| 1130 | struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder); | ||
| 1131 | struct radeon_crtc *radeon_crtc = to_radeon_crtc(encoder->crtc); | ||
| 1132 | ENABLE_SCALER_PS_ALLOCATION args; | ||
| 1133 | int index = GetIndexIntoMasterTable(COMMAND, EnableScaler); | ||
| 1134 | /* fixme - fill in enc_priv for atom dac */ | ||
| 1135 | enum radeon_tv_std tv_std = TV_STD_NTSC; | ||
| 1136 | |||
| 1137 | if (!ASIC_IS_AVIVO(rdev) && radeon_crtc->crtc_id) | ||
| 1138 | return; | ||
| 1139 | |||
| 1140 | memset(&args, 0, sizeof(args)); | ||
| 1141 | |||
| 1142 | args.ucScaler = radeon_crtc->crtc_id; | ||
| 1143 | |||
| 1144 | if (radeon_encoder->devices & (ATOM_DEVICE_TV_SUPPORT)) { | ||
| 1145 | switch (tv_std) { | ||
| 1146 | case TV_STD_NTSC: | ||
| 1147 | default: | ||
| 1148 | args.ucTVStandard = ATOM_TV_NTSC; | ||
| 1149 | break; | ||
| 1150 | case TV_STD_PAL: | ||
| 1151 | args.ucTVStandard = ATOM_TV_PAL; | ||
| 1152 | break; | ||
| 1153 | case TV_STD_PAL_M: | ||
| 1154 | args.ucTVStandard = ATOM_TV_PALM; | ||
| 1155 | break; | ||
| 1156 | case TV_STD_PAL_60: | ||
| 1157 | args.ucTVStandard = ATOM_TV_PAL60; | ||
| 1158 | break; | ||
| 1159 | case TV_STD_NTSC_J: | ||
| 1160 | args.ucTVStandard = ATOM_TV_NTSCJ; | ||
| 1161 | break; | ||
| 1162 | case TV_STD_SCART_PAL: | ||
| 1163 | args.ucTVStandard = ATOM_TV_PAL; /* ??? */ | ||
| 1164 | break; | ||
| 1165 | case TV_STD_SECAM: | ||
| 1166 | args.ucTVStandard = ATOM_TV_SECAM; | ||
| 1167 | break; | ||
| 1168 | case TV_STD_PAL_CN: | ||
| 1169 | args.ucTVStandard = ATOM_TV_PALCN; | ||
| 1170 | break; | ||
| 1171 | } | ||
| 1172 | args.ucEnable = SCALER_ENABLE_MULTITAP_MODE; | ||
| 1173 | } else if (radeon_encoder->devices & (ATOM_DEVICE_CV_SUPPORT)) { | ||
| 1174 | args.ucTVStandard = ATOM_TV_CV; | ||
| 1175 | args.ucEnable = SCALER_ENABLE_MULTITAP_MODE; | ||
| 1176 | } else if (radeon_encoder->flags & RADEON_USE_RMX) { | ||
| 1177 | if (radeon_encoder->rmx_type == RMX_FULL) | ||
| 1178 | args.ucEnable = ATOM_SCALER_EXPANSION; | ||
| 1179 | else if (radeon_encoder->rmx_type == RMX_CENTER) | ||
| 1180 | args.ucEnable = ATOM_SCALER_CENTER; | ||
| 1181 | else if (radeon_encoder->rmx_type == RMX_ASPECT) | ||
| 1182 | args.ucEnable = ATOM_SCALER_EXPANSION; | ||
| 1183 | } else { | ||
| 1184 | if (ASIC_IS_AVIVO(rdev)) | ||
| 1185 | args.ucEnable = ATOM_SCALER_DISABLE; | ||
| 1186 | else | ||
| 1187 | args.ucEnable = ATOM_SCALER_CENTER; | ||
| 1188 | } | ||
| 1189 | |||
| 1190 | atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args); | ||
| 1191 | |||
| 1192 | if (radeon_encoder->devices & (ATOM_DEVICE_CV_SUPPORT | ATOM_DEVICE_TV_SUPPORT) | ||
| 1193 | && rdev->family >= CHIP_RV515 && rdev->family <= CHIP_RV570) { | ||
| 1194 | atom_rv515_force_tv_scaler(rdev); | ||
| 1195 | } | ||
| 1196 | |||
| 1197 | } | ||
| 1198 | |||
| 1199 | static void | ||
| 1200 | radeon_atom_encoder_dpms(struct drm_encoder *encoder, int mode) | 846 | radeon_atom_encoder_dpms(struct drm_encoder *encoder, int mode) |
| 1201 | { | 847 | { |
| 1202 | struct drm_device *dev = encoder->dev; | 848 | struct drm_device *dev = encoder->dev; |
| @@ -1448,8 +1094,6 @@ radeon_atom_encoder_mode_set(struct drm_encoder *encoder, | |||
| 1448 | radeon_encoder->pixel_clock = adjusted_mode->clock; | 1094 | radeon_encoder->pixel_clock = adjusted_mode->clock; |
| 1449 | 1095 | ||
| 1450 | radeon_atombios_encoder_crtc_scratch_regs(encoder, radeon_crtc->crtc_id); | 1096 | radeon_atombios_encoder_crtc_scratch_regs(encoder, radeon_crtc->crtc_id); |
| 1451 | atombios_overscan_setup(encoder, mode, adjusted_mode); | ||
| 1452 | atombios_scaler_setup(encoder); | ||
| 1453 | atombios_set_encoder_crtc_source(encoder); | 1097 | atombios_set_encoder_crtc_source(encoder); |
| 1454 | 1098 | ||
| 1455 | if (ASIC_IS_AVIVO(rdev)) { | 1099 | if (ASIC_IS_AVIVO(rdev)) { |
| @@ -1667,6 +1311,7 @@ radeon_add_atom_encoder(struct drm_device *dev, uint32_t encoder_id, uint32_t su | |||
| 1667 | 1311 | ||
| 1668 | radeon_encoder->encoder_id = encoder_id; | 1312 | radeon_encoder->encoder_id = encoder_id; |
| 1669 | radeon_encoder->devices = supported_device; | 1313 | radeon_encoder->devices = supported_device; |
| 1314 | radeon_encoder->rmx_type = RMX_OFF; | ||
| 1670 | 1315 | ||
| 1671 | switch (radeon_encoder->encoder_id) { | 1316 | switch (radeon_encoder->encoder_id) { |
| 1672 | case ENCODER_OBJECT_ID_INTERNAL_LVDS: | 1317 | case ENCODER_OBJECT_ID_INTERNAL_LVDS: |
diff --git a/drivers/gpu/drm/radeon/radeon_fb.c b/drivers/gpu/drm/radeon/radeon_fb.c index 9e8f191eb64a..ec383edf5f38 100644 --- a/drivers/gpu/drm/radeon/radeon_fb.c +++ b/drivers/gpu/drm/radeon/radeon_fb.c | |||
| @@ -101,9 +101,10 @@ static int radeonfb_setcolreg(unsigned regno, | |||
| 101 | break; | 101 | break; |
| 102 | case 24: | 102 | case 24: |
| 103 | case 32: | 103 | case 32: |
| 104 | fb->pseudo_palette[regno] = ((red & 0xff00) << 8) | | 104 | fb->pseudo_palette[regno] = |
| 105 | (green & 0xff00) | | 105 | (((red >> 8) & 0xff) << info->var.red.offset) | |
| 106 | ((blue & 0xff00) >> 8); | 106 | (((green >> 8) & 0xff) << info->var.green.offset) | |
| 107 | (((blue >> 8) & 0xff) << info->var.blue.offset); | ||
| 107 | break; | 108 | break; |
| 108 | } | 109 | } |
| 109 | } | 110 | } |
| @@ -154,6 +155,7 @@ static int radeonfb_check_var(struct fb_var_screeninfo *var, | |||
| 154 | var->transp.length = 0; | 155 | var->transp.length = 0; |
| 155 | var->transp.offset = 0; | 156 | var->transp.offset = 0; |
| 156 | break; | 157 | break; |
| 158 | #ifdef __LITTLE_ENDIAN | ||
| 157 | case 15: | 159 | case 15: |
| 158 | var->red.offset = 10; | 160 | var->red.offset = 10; |
| 159 | var->green.offset = 5; | 161 | var->green.offset = 5; |
| @@ -194,6 +196,28 @@ static int radeonfb_check_var(struct fb_var_screeninfo *var, | |||
| 194 | var->transp.length = 8; | 196 | var->transp.length = 8; |
| 195 | var->transp.offset = 24; | 197 | var->transp.offset = 24; |
| 196 | break; | 198 | break; |
| 199 | #else | ||
| 200 | case 24: | ||
| 201 | var->red.offset = 8; | ||
| 202 | var->green.offset = 16; | ||
| 203 | var->blue.offset = 24; | ||
| 204 | var->red.length = 8; | ||
| 205 | var->green.length = 8; | ||
| 206 | var->blue.length = 8; | ||
| 207 | var->transp.length = 0; | ||
| 208 | var->transp.offset = 0; | ||
| 209 | break; | ||
| 210 | case 32: | ||
| 211 | var->red.offset = 8; | ||
| 212 | var->green.offset = 16; | ||
| 213 | var->blue.offset = 24; | ||
| 214 | var->red.length = 8; | ||
| 215 | var->green.length = 8; | ||
| 216 | var->blue.length = 8; | ||
| 217 | var->transp.length = 8; | ||
| 218 | var->transp.offset = 0; | ||
| 219 | break; | ||
| 220 | #endif | ||
| 197 | default: | 221 | default: |
| 198 | return -EINVAL; | 222 | return -EINVAL; |
| 199 | } | 223 | } |
| @@ -447,10 +471,10 @@ static struct notifier_block paniced = { | |||
| 447 | .notifier_call = radeonfb_panic, | 471 | .notifier_call = radeonfb_panic, |
| 448 | }; | 472 | }; |
| 449 | 473 | ||
| 450 | static int radeon_align_pitch(struct radeon_device *rdev, int width, int bpp) | 474 | static int radeon_align_pitch(struct radeon_device *rdev, int width, int bpp, bool tiled) |
| 451 | { | 475 | { |
| 452 | int aligned = width; | 476 | int aligned = width; |
| 453 | int align_large = (ASIC_IS_AVIVO(rdev)); | 477 | int align_large = (ASIC_IS_AVIVO(rdev)) || tiled; |
| 454 | int pitch_mask = 0; | 478 | int pitch_mask = 0; |
| 455 | 479 | ||
| 456 | switch (bpp / 8) { | 480 | switch (bpp / 8) { |
| @@ -488,12 +512,13 @@ int radeonfb_create(struct radeon_device *rdev, | |||
| 488 | u64 fb_gpuaddr; | 512 | u64 fb_gpuaddr; |
| 489 | void *fbptr = NULL; | 513 | void *fbptr = NULL; |
| 490 | unsigned long tmp; | 514 | unsigned long tmp; |
| 515 | bool fb_tiled = false; /* useful for testing */ | ||
| 491 | 516 | ||
| 492 | mode_cmd.width = surface_width; | 517 | mode_cmd.width = surface_width; |
| 493 | mode_cmd.height = surface_height; | 518 | mode_cmd.height = surface_height; |
| 494 | mode_cmd.bpp = 32; | 519 | mode_cmd.bpp = 32; |
| 495 | /* need to align pitch with crtc limits */ | 520 | /* need to align pitch with crtc limits */ |
| 496 | mode_cmd.pitch = radeon_align_pitch(rdev, mode_cmd.width, mode_cmd.bpp) * ((mode_cmd.bpp + 1) / 8); | 521 | mode_cmd.pitch = radeon_align_pitch(rdev, mode_cmd.width, mode_cmd.bpp, fb_tiled) * ((mode_cmd.bpp + 1) / 8); |
| 497 | mode_cmd.depth = 24; | 522 | mode_cmd.depth = 24; |
| 498 | 523 | ||
| 499 | size = mode_cmd.pitch * mode_cmd.height; | 524 | size = mode_cmd.pitch * mode_cmd.height; |
| @@ -511,6 +536,8 @@ int radeonfb_create(struct radeon_device *rdev, | |||
| 511 | } | 536 | } |
| 512 | robj = gobj->driver_private; | 537 | robj = gobj->driver_private; |
| 513 | 538 | ||
| 539 | if (fb_tiled) | ||
| 540 | radeon_object_set_tiling_flags(robj, RADEON_TILING_MACRO|RADEON_TILING_SURFACE, mode_cmd.pitch); | ||
| 514 | mutex_lock(&rdev->ddev->struct_mutex); | 541 | mutex_lock(&rdev->ddev->struct_mutex); |
| 515 | fb = radeon_framebuffer_create(rdev->ddev, &mode_cmd, gobj); | 542 | fb = radeon_framebuffer_create(rdev->ddev, &mode_cmd, gobj); |
| 516 | if (fb == NULL) { | 543 | if (fb == NULL) { |
| @@ -539,11 +566,16 @@ int radeonfb_create(struct radeon_device *rdev, | |||
| 539 | } | 566 | } |
| 540 | rfbdev = info->par; | 567 | rfbdev = info->par; |
| 541 | 568 | ||
| 569 | if (fb_tiled) | ||
| 570 | radeon_object_check_tiling(robj, 0, 0); | ||
| 571 | |||
| 542 | ret = radeon_object_kmap(robj, &fbptr); | 572 | ret = radeon_object_kmap(robj, &fbptr); |
| 543 | if (ret) { | 573 | if (ret) { |
| 544 | goto out_unref; | 574 | goto out_unref; |
| 545 | } | 575 | } |
| 546 | 576 | ||
| 577 | memset_io(fbptr, 0, aligned_size); | ||
| 578 | |||
| 547 | strcpy(info->fix.id, "radeondrmfb"); | 579 | strcpy(info->fix.id, "radeondrmfb"); |
| 548 | info->fix.type = FB_TYPE_PACKED_PIXELS; | 580 | info->fix.type = FB_TYPE_PACKED_PIXELS; |
| 549 | info->fix.visual = FB_VISUAL_TRUECOLOR; | 581 | info->fix.visual = FB_VISUAL_TRUECOLOR; |
| @@ -572,6 +604,11 @@ int radeonfb_create(struct radeon_device *rdev, | |||
| 572 | info->var.width = -1; | 604 | info->var.width = -1; |
| 573 | info->var.xres = fb_width; | 605 | info->var.xres = fb_width; |
| 574 | info->var.yres = fb_height; | 606 | info->var.yres = fb_height; |
| 607 | |||
| 608 | /* setup aperture base/size for vesafb takeover */ | ||
| 609 | info->aperture_base = rdev->ddev->mode_config.fb_base; | ||
| 610 | info->aperture_size = rdev->mc.real_vram_size; | ||
| 611 | |||
| 575 | info->fix.mmio_start = 0; | 612 | info->fix.mmio_start = 0; |
| 576 | info->fix.mmio_len = 0; | 613 | info->fix.mmio_len = 0; |
| 577 | info->pixmap.size = 64*1024; | 614 | info->pixmap.size = 64*1024; |
| @@ -600,6 +637,7 @@ int radeonfb_create(struct radeon_device *rdev, | |||
| 600 | info->var.transp.offset = 0; | 637 | info->var.transp.offset = 0; |
| 601 | info->var.transp.length = 0; | 638 | info->var.transp.length = 0; |
| 602 | break; | 639 | break; |
| 640 | #ifdef __LITTLE_ENDIAN | ||
| 603 | case 15: | 641 | case 15: |
| 604 | info->var.red.offset = 10; | 642 | info->var.red.offset = 10; |
| 605 | info->var.green.offset = 5; | 643 | info->var.green.offset = 5; |
| @@ -639,7 +677,29 @@ int radeonfb_create(struct radeon_device *rdev, | |||
| 639 | info->var.transp.offset = 24; | 677 | info->var.transp.offset = 24; |
| 640 | info->var.transp.length = 8; | 678 | info->var.transp.length = 8; |
| 641 | break; | 679 | break; |
| 680 | #else | ||
| 681 | case 24: | ||
| 682 | info->var.red.offset = 8; | ||
| 683 | info->var.green.offset = 16; | ||
| 684 | info->var.blue.offset = 24; | ||
| 685 | info->var.red.length = 8; | ||
| 686 | info->var.green.length = 8; | ||
| 687 | info->var.blue.length = 8; | ||
| 688 | info->var.transp.offset = 0; | ||
| 689 | info->var.transp.length = 0; | ||
| 690 | break; | ||
| 691 | case 32: | ||
| 692 | info->var.red.offset = 8; | ||
| 693 | info->var.green.offset = 16; | ||
| 694 | info->var.blue.offset = 24; | ||
| 695 | info->var.red.length = 8; | ||
| 696 | info->var.green.length = 8; | ||
| 697 | info->var.blue.length = 8; | ||
| 698 | info->var.transp.offset = 0; | ||
| 699 | info->var.transp.length = 8; | ||
| 700 | break; | ||
| 642 | default: | 701 | default: |
| 702 | #endif | ||
| 643 | break; | 703 | break; |
| 644 | } | 704 | } |
| 645 | 705 | ||
diff --git a/drivers/gpu/drm/radeon/radeon_fence.c b/drivers/gpu/drm/radeon/radeon_fence.c index 96afbf5ae2ad..b4e48dd2e859 100644 --- a/drivers/gpu/drm/radeon/radeon_fence.c +++ b/drivers/gpu/drm/radeon/radeon_fence.c | |||
| @@ -195,7 +195,7 @@ retry: | |||
| 195 | r = wait_event_interruptible_timeout(rdev->fence_drv.queue, | 195 | r = wait_event_interruptible_timeout(rdev->fence_drv.queue, |
| 196 | radeon_fence_signaled(fence), timeout); | 196 | radeon_fence_signaled(fence), timeout); |
| 197 | if (unlikely(r == -ERESTARTSYS)) { | 197 | if (unlikely(r == -ERESTARTSYS)) { |
| 198 | return -ERESTART; | 198 | return -EBUSY; |
| 199 | } | 199 | } |
| 200 | } else { | 200 | } else { |
| 201 | r = wait_event_timeout(rdev->fence_drv.queue, | 201 | r = wait_event_timeout(rdev->fence_drv.queue, |
diff --git a/drivers/gpu/drm/radeon/radeon_gart.c b/drivers/gpu/drm/radeon/radeon_gart.c index d343a15316ec..2977539880fb 100644 --- a/drivers/gpu/drm/radeon/radeon_gart.c +++ b/drivers/gpu/drm/radeon/radeon_gart.c | |||
| @@ -177,7 +177,7 @@ int radeon_gart_bind(struct radeon_device *rdev, unsigned offset, | |||
| 177 | return -ENOMEM; | 177 | return -ENOMEM; |
| 178 | } | 178 | } |
| 179 | rdev->gart.pages[p] = pagelist[i]; | 179 | rdev->gart.pages[p] = pagelist[i]; |
| 180 | page_base = (uint32_t)rdev->gart.pages_addr[p]; | 180 | page_base = rdev->gart.pages_addr[p]; |
| 181 | for (j = 0; j < (PAGE_SIZE / 4096); j++, t++) { | 181 | for (j = 0; j < (PAGE_SIZE / 4096); j++, t++) { |
| 182 | radeon_gart_set_page(rdev, t, page_base); | 182 | radeon_gart_set_page(rdev, t, page_base); |
| 183 | page_base += 4096; | 183 | page_base += 4096; |
diff --git a/drivers/gpu/drm/radeon/radeon_gem.c b/drivers/gpu/drm/radeon/radeon_gem.c index eb516034235d..d880edf254db 100644 --- a/drivers/gpu/drm/radeon/radeon_gem.c +++ b/drivers/gpu/drm/radeon/radeon_gem.c | |||
| @@ -157,9 +157,9 @@ int radeon_gem_info_ioctl(struct drm_device *dev, void *data, | |||
| 157 | struct radeon_device *rdev = dev->dev_private; | 157 | struct radeon_device *rdev = dev->dev_private; |
| 158 | struct drm_radeon_gem_info *args = data; | 158 | struct drm_radeon_gem_info *args = data; |
| 159 | 159 | ||
| 160 | args->vram_size = rdev->mc.vram_size; | 160 | args->vram_size = rdev->mc.real_vram_size; |
| 161 | /* FIXME: report somethings that makes sense */ | 161 | /* FIXME: report somethings that makes sense */ |
| 162 | args->vram_visible = rdev->mc.vram_size - (4 * 1024 * 1024); | 162 | args->vram_visible = rdev->mc.real_vram_size - (4 * 1024 * 1024); |
| 163 | args->gart_size = rdev->mc.gtt_size; | 163 | args->gart_size = rdev->mc.gtt_size; |
| 164 | return 0; | 164 | return 0; |
| 165 | } | 165 | } |
| @@ -262,8 +262,34 @@ int radeon_gem_mmap_ioctl(struct drm_device *dev, void *data, | |||
| 262 | int radeon_gem_busy_ioctl(struct drm_device *dev, void *data, | 262 | int radeon_gem_busy_ioctl(struct drm_device *dev, void *data, |
| 263 | struct drm_file *filp) | 263 | struct drm_file *filp) |
| 264 | { | 264 | { |
| 265 | /* FIXME: implement */ | 265 | struct drm_radeon_gem_busy *args = data; |
| 266 | return 0; | 266 | struct drm_gem_object *gobj; |
| 267 | struct radeon_object *robj; | ||
| 268 | int r; | ||
| 269 | uint32_t cur_placement; | ||
| 270 | |||
| 271 | gobj = drm_gem_object_lookup(dev, filp, args->handle); | ||
| 272 | if (gobj == NULL) { | ||
| 273 | return -EINVAL; | ||
| 274 | } | ||
| 275 | robj = gobj->driver_private; | ||
| 276 | r = radeon_object_busy_domain(robj, &cur_placement); | ||
| 277 | switch (cur_placement) { | ||
| 278 | case TTM_PL_VRAM: | ||
| 279 | args->domain = RADEON_GEM_DOMAIN_VRAM; | ||
| 280 | break; | ||
| 281 | case TTM_PL_TT: | ||
| 282 | args->domain = RADEON_GEM_DOMAIN_GTT; | ||
| 283 | break; | ||
| 284 | case TTM_PL_SYSTEM: | ||
| 285 | args->domain = RADEON_GEM_DOMAIN_CPU; | ||
| 286 | default: | ||
| 287 | break; | ||
| 288 | } | ||
| 289 | mutex_lock(&dev->struct_mutex); | ||
| 290 | drm_gem_object_unreference(gobj); | ||
| 291 | mutex_unlock(&dev->struct_mutex); | ||
| 292 | return r; | ||
| 267 | } | 293 | } |
| 268 | 294 | ||
| 269 | int radeon_gem_wait_idle_ioctl(struct drm_device *dev, void *data, | 295 | int radeon_gem_wait_idle_ioctl(struct drm_device *dev, void *data, |
| @@ -285,3 +311,44 @@ int radeon_gem_wait_idle_ioctl(struct drm_device *dev, void *data, | |||
| 285 | mutex_unlock(&dev->struct_mutex); | 311 | mutex_unlock(&dev->struct_mutex); |
| 286 | return r; | 312 | return r; |
| 287 | } | 313 | } |
| 314 | |||
| 315 | int radeon_gem_set_tiling_ioctl(struct drm_device *dev, void *data, | ||
| 316 | struct drm_file *filp) | ||
| 317 | { | ||
| 318 | struct drm_radeon_gem_set_tiling *args = data; | ||
| 319 | struct drm_gem_object *gobj; | ||
| 320 | struct radeon_object *robj; | ||
| 321 | int r = 0; | ||
| 322 | |||
| 323 | DRM_DEBUG("%d \n", args->handle); | ||
| 324 | gobj = drm_gem_object_lookup(dev, filp, args->handle); | ||
| 325 | if (gobj == NULL) | ||
| 326 | return -EINVAL; | ||
| 327 | robj = gobj->driver_private; | ||
| 328 | radeon_object_set_tiling_flags(robj, args->tiling_flags, args->pitch); | ||
| 329 | mutex_lock(&dev->struct_mutex); | ||
| 330 | drm_gem_object_unreference(gobj); | ||
| 331 | mutex_unlock(&dev->struct_mutex); | ||
| 332 | return r; | ||
| 333 | } | ||
| 334 | |||
| 335 | int radeon_gem_get_tiling_ioctl(struct drm_device *dev, void *data, | ||
| 336 | struct drm_file *filp) | ||
| 337 | { | ||
| 338 | struct drm_radeon_gem_get_tiling *args = data; | ||
| 339 | struct drm_gem_object *gobj; | ||
| 340 | struct radeon_object *robj; | ||
| 341 | int r = 0; | ||
| 342 | |||
| 343 | DRM_DEBUG("\n"); | ||
| 344 | gobj = drm_gem_object_lookup(dev, filp, args->handle); | ||
| 345 | if (gobj == NULL) | ||
| 346 | return -EINVAL; | ||
| 347 | robj = gobj->driver_private; | ||
| 348 | radeon_object_get_tiling_flags(robj, &args->tiling_flags, | ||
| 349 | &args->pitch); | ||
| 350 | mutex_lock(&dev->struct_mutex); | ||
| 351 | drm_gem_object_unreference(gobj); | ||
| 352 | mutex_unlock(&dev->struct_mutex); | ||
| 353 | return r; | ||
| 354 | } | ||
diff --git a/drivers/gpu/drm/radeon/radeon_irq_kms.c b/drivers/gpu/drm/radeon/radeon_irq_kms.c index 491d569deb0e..9805e4b6ca1b 100644 --- a/drivers/gpu/drm/radeon/radeon_irq_kms.c +++ b/drivers/gpu/drm/radeon/radeon_irq_kms.c | |||
| @@ -32,60 +32,6 @@ | |||
| 32 | #include "radeon.h" | 32 | #include "radeon.h" |
| 33 | #include "atom.h" | 33 | #include "atom.h" |
| 34 | 34 | ||
| 35 | static inline uint32_t r100_irq_ack(struct radeon_device *rdev) | ||
| 36 | { | ||
| 37 | uint32_t irqs = RREG32(RADEON_GEN_INT_STATUS); | ||
| 38 | uint32_t irq_mask = RADEON_SW_INT_TEST; | ||
| 39 | |||
| 40 | if (irqs) { | ||
| 41 | WREG32(RADEON_GEN_INT_STATUS, irqs); | ||
| 42 | } | ||
| 43 | return irqs & irq_mask; | ||
| 44 | } | ||
| 45 | |||
| 46 | int r100_irq_set(struct radeon_device *rdev) | ||
| 47 | { | ||
| 48 | uint32_t tmp = 0; | ||
| 49 | |||
| 50 | if (rdev->irq.sw_int) { | ||
| 51 | tmp |= RADEON_SW_INT_ENABLE; | ||
| 52 | } | ||
| 53 | /* Todo go through CRTC and enable vblank int or not */ | ||
| 54 | WREG32(RADEON_GEN_INT_CNTL, tmp); | ||
| 55 | return 0; | ||
| 56 | } | ||
| 57 | |||
| 58 | int r100_irq_process(struct radeon_device *rdev) | ||
| 59 | { | ||
| 60 | uint32_t status; | ||
| 61 | |||
| 62 | status = r100_irq_ack(rdev); | ||
| 63 | if (!status) { | ||
| 64 | return IRQ_NONE; | ||
| 65 | } | ||
| 66 | while (status) { | ||
| 67 | /* SW interrupt */ | ||
| 68 | if (status & RADEON_SW_INT_TEST) { | ||
| 69 | radeon_fence_process(rdev); | ||
| 70 | } | ||
| 71 | status = r100_irq_ack(rdev); | ||
| 72 | } | ||
| 73 | return IRQ_HANDLED; | ||
| 74 | } | ||
| 75 | |||
| 76 | int rs600_irq_set(struct radeon_device *rdev) | ||
| 77 | { | ||
| 78 | uint32_t tmp = 0; | ||
| 79 | |||
| 80 | if (rdev->irq.sw_int) { | ||
| 81 | tmp |= RADEON_SW_INT_ENABLE; | ||
| 82 | } | ||
| 83 | WREG32(RADEON_GEN_INT_CNTL, tmp); | ||
| 84 | /* Todo go through CRTC and enable vblank int or not */ | ||
| 85 | WREG32(R500_DxMODE_INT_MASK, 0); | ||
| 86 | return 0; | ||
| 87 | } | ||
| 88 | |||
| 89 | irqreturn_t radeon_driver_irq_handler_kms(DRM_IRQ_ARGS) | 35 | irqreturn_t radeon_driver_irq_handler_kms(DRM_IRQ_ARGS) |
| 90 | { | 36 | { |
| 91 | struct drm_device *dev = (struct drm_device *) arg; | 37 | struct drm_device *dev = (struct drm_device *) arg; |
diff --git a/drivers/gpu/drm/radeon/radeon_kms.c b/drivers/gpu/drm/radeon/radeon_kms.c index 4612a7c146d1..dce09ada32bc 100644 --- a/drivers/gpu/drm/radeon/radeon_kms.c +++ b/drivers/gpu/drm/radeon/radeon_kms.c | |||
| @@ -58,6 +58,8 @@ int radeon_driver_load_kms(struct drm_device *dev, unsigned long flags) | |||
| 58 | if (r) { | 58 | if (r) { |
| 59 | DRM_ERROR("Failed to initialize radeon, disabling IOCTL\n"); | 59 | DRM_ERROR("Failed to initialize radeon, disabling IOCTL\n"); |
| 60 | radeon_device_fini(rdev); | 60 | radeon_device_fini(rdev); |
| 61 | kfree(rdev); | ||
| 62 | dev->dev_private = NULL; | ||
| 61 | return r; | 63 | return r; |
| 62 | } | 64 | } |
| 63 | return 0; | 65 | return 0; |
| @@ -93,6 +95,9 @@ int radeon_info_ioctl(struct drm_device *dev, void *data, struct drm_file *filp) | |||
| 93 | case RADEON_INFO_NUM_GB_PIPES: | 95 | case RADEON_INFO_NUM_GB_PIPES: |
| 94 | value = rdev->num_gb_pipes; | 96 | value = rdev->num_gb_pipes; |
| 95 | break; | 97 | break; |
| 98 | case RADEON_INFO_NUM_Z_PIPES: | ||
| 99 | value = rdev->num_z_pipes; | ||
| 100 | break; | ||
| 96 | default: | 101 | default: |
| 97 | DRM_DEBUG("Invalid request %d\n", info->request); | 102 | DRM_DEBUG("Invalid request %d\n", info->request); |
| 98 | return -EINVAL; | 103 | return -EINVAL; |
| @@ -139,19 +144,42 @@ void radeon_driver_preclose_kms(struct drm_device *dev, | |||
| 139 | */ | 144 | */ |
| 140 | u32 radeon_get_vblank_counter_kms(struct drm_device *dev, int crtc) | 145 | u32 radeon_get_vblank_counter_kms(struct drm_device *dev, int crtc) |
| 141 | { | 146 | { |
| 142 | /* FIXME: implement */ | 147 | struct radeon_device *rdev = dev->dev_private; |
| 143 | return 0; | 148 | |
| 149 | if (crtc < 0 || crtc > 1) { | ||
| 150 | DRM_ERROR("Invalid crtc %d\n", crtc); | ||
| 151 | return -EINVAL; | ||
| 152 | } | ||
| 153 | |||
| 154 | return radeon_get_vblank_counter(rdev, crtc); | ||
| 144 | } | 155 | } |
| 145 | 156 | ||
| 146 | int radeon_enable_vblank_kms(struct drm_device *dev, int crtc) | 157 | int radeon_enable_vblank_kms(struct drm_device *dev, int crtc) |
| 147 | { | 158 | { |
| 148 | /* FIXME: implement */ | 159 | struct radeon_device *rdev = dev->dev_private; |
| 149 | return 0; | 160 | |
| 161 | if (crtc < 0 || crtc > 1) { | ||
| 162 | DRM_ERROR("Invalid crtc %d\n", crtc); | ||
| 163 | return -EINVAL; | ||
| 164 | } | ||
| 165 | |||
| 166 | rdev->irq.crtc_vblank_int[crtc] = true; | ||
| 167 | |||
| 168 | return radeon_irq_set(rdev); | ||
| 150 | } | 169 | } |
| 151 | 170 | ||
| 152 | void radeon_disable_vblank_kms(struct drm_device *dev, int crtc) | 171 | void radeon_disable_vblank_kms(struct drm_device *dev, int crtc) |
| 153 | { | 172 | { |
| 154 | /* FIXME: implement */ | 173 | struct radeon_device *rdev = dev->dev_private; |
| 174 | |||
| 175 | if (crtc < 0 || crtc > 1) { | ||
| 176 | DRM_ERROR("Invalid crtc %d\n", crtc); | ||
| 177 | return; | ||
| 178 | } | ||
| 179 | |||
| 180 | rdev->irq.crtc_vblank_int[crtc] = false; | ||
| 181 | |||
| 182 | radeon_irq_set(rdev); | ||
| 155 | } | 183 | } |
| 156 | 184 | ||
| 157 | 185 | ||
| @@ -291,5 +319,8 @@ struct drm_ioctl_desc radeon_ioctls_kms[] = { | |||
| 291 | DRM_IOCTL_DEF(DRM_RADEON_GEM_WAIT_IDLE, radeon_gem_wait_idle_ioctl, DRM_AUTH), | 319 | DRM_IOCTL_DEF(DRM_RADEON_GEM_WAIT_IDLE, radeon_gem_wait_idle_ioctl, DRM_AUTH), |
| 292 | DRM_IOCTL_DEF(DRM_RADEON_CS, radeon_cs_ioctl, DRM_AUTH), | 320 | DRM_IOCTL_DEF(DRM_RADEON_CS, radeon_cs_ioctl, DRM_AUTH), |
| 293 | DRM_IOCTL_DEF(DRM_RADEON_INFO, radeon_info_ioctl, DRM_AUTH), | 321 | DRM_IOCTL_DEF(DRM_RADEON_INFO, radeon_info_ioctl, DRM_AUTH), |
| 322 | DRM_IOCTL_DEF(DRM_RADEON_GEM_SET_TILING, radeon_gem_set_tiling_ioctl, DRM_AUTH), | ||
| 323 | DRM_IOCTL_DEF(DRM_RADEON_GEM_GET_TILING, radeon_gem_get_tiling_ioctl, DRM_AUTH), | ||
| 324 | DRM_IOCTL_DEF(DRM_RADEON_GEM_BUSY, radeon_gem_busy_ioctl, DRM_AUTH), | ||
| 294 | }; | 325 | }; |
| 295 | int radeon_max_kms_ioctl = DRM_ARRAY_SIZE(radeon_ioctls_kms); | 326 | int radeon_max_kms_ioctl = DRM_ARRAY_SIZE(radeon_ioctls_kms); |
diff --git a/drivers/gpu/drm/radeon/radeon_legacy_crtc.c b/drivers/gpu/drm/radeon/radeon_legacy_crtc.c index 8086ecf7f03d..0da72f18fd3a 100644 --- a/drivers/gpu/drm/radeon/radeon_legacy_crtc.c +++ b/drivers/gpu/drm/radeon/radeon_legacy_crtc.c | |||
| @@ -29,6 +29,171 @@ | |||
| 29 | #include "radeon_fixed.h" | 29 | #include "radeon_fixed.h" |
| 30 | #include "radeon.h" | 30 | #include "radeon.h" |
| 31 | 31 | ||
| 32 | static void radeon_legacy_rmx_mode_set(struct drm_crtc *crtc, | ||
| 33 | struct drm_display_mode *mode, | ||
| 34 | struct drm_display_mode *adjusted_mode) | ||
| 35 | { | ||
| 36 | struct drm_device *dev = crtc->dev; | ||
| 37 | struct radeon_device *rdev = dev->dev_private; | ||
| 38 | struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); | ||
| 39 | int xres = mode->hdisplay; | ||
| 40 | int yres = mode->vdisplay; | ||
| 41 | bool hscale = true, vscale = true; | ||
| 42 | int hsync_wid; | ||
| 43 | int vsync_wid; | ||
| 44 | int hsync_start; | ||
| 45 | int blank_width; | ||
| 46 | u32 scale, inc, crtc_more_cntl; | ||
| 47 | u32 fp_horz_stretch, fp_vert_stretch, fp_horz_vert_active; | ||
| 48 | u32 fp_h_sync_strt_wid, fp_crtc_h_total_disp; | ||
| 49 | u32 fp_v_sync_strt_wid, fp_crtc_v_total_disp; | ||
| 50 | struct radeon_native_mode *native_mode = &radeon_crtc->native_mode; | ||
| 51 | |||
| 52 | fp_vert_stretch = RREG32(RADEON_FP_VERT_STRETCH) & | ||
| 53 | (RADEON_VERT_STRETCH_RESERVED | | ||
| 54 | RADEON_VERT_AUTO_RATIO_INC); | ||
| 55 | fp_horz_stretch = RREG32(RADEON_FP_HORZ_STRETCH) & | ||
| 56 | (RADEON_HORZ_FP_LOOP_STRETCH | | ||
| 57 | RADEON_HORZ_AUTO_RATIO_INC); | ||
| 58 | |||
| 59 | crtc_more_cntl = 0; | ||
| 60 | if ((rdev->family == CHIP_RS100) || | ||
| 61 | (rdev->family == CHIP_RS200)) { | ||
| 62 | /* This is to workaround the asic bug for RMX, some versions | ||
| 63 | of BIOS dosen't have this register initialized correctly. */ | ||
| 64 | crtc_more_cntl |= RADEON_CRTC_H_CUTOFF_ACTIVE_EN; | ||
| 65 | } | ||
| 66 | |||
| 67 | |||
| 68 | fp_crtc_h_total_disp = ((((mode->crtc_htotal / 8) - 1) & 0x3ff) | ||
| 69 | | ((((mode->crtc_hdisplay / 8) - 1) & 0x1ff) << 16)); | ||
| 70 | |||
| 71 | hsync_wid = (mode->crtc_hsync_end - mode->crtc_hsync_start) / 8; | ||
| 72 | if (!hsync_wid) | ||
| 73 | hsync_wid = 1; | ||
| 74 | hsync_start = mode->crtc_hsync_start - 8; | ||
| 75 | |||
| 76 | fp_h_sync_strt_wid = ((hsync_start & 0x1fff) | ||
| 77 | | ((hsync_wid & 0x3f) << 16) | ||
| 78 | | ((mode->flags & DRM_MODE_FLAG_NHSYNC) | ||
| 79 | ? RADEON_CRTC_H_SYNC_POL | ||
| 80 | : 0)); | ||
| 81 | |||
| 82 | fp_crtc_v_total_disp = (((mode->crtc_vtotal - 1) & 0xffff) | ||
| 83 | | ((mode->crtc_vdisplay - 1) << 16)); | ||
| 84 | |||
| 85 | vsync_wid = mode->crtc_vsync_end - mode->crtc_vsync_start; | ||
| 86 | if (!vsync_wid) | ||
| 87 | vsync_wid = 1; | ||
| 88 | |||
| 89 | fp_v_sync_strt_wid = (((mode->crtc_vsync_start - 1) & 0xfff) | ||
| 90 | | ((vsync_wid & 0x1f) << 16) | ||
| 91 | | ((mode->flags & DRM_MODE_FLAG_NVSYNC) | ||
| 92 | ? RADEON_CRTC_V_SYNC_POL | ||
| 93 | : 0)); | ||
| 94 | |||
| 95 | fp_horz_vert_active = 0; | ||
| 96 | |||
| 97 | if (native_mode->panel_xres == 0 || | ||
| 98 | native_mode->panel_yres == 0) { | ||
| 99 | hscale = false; | ||
| 100 | vscale = false; | ||
| 101 | } else { | ||
| 102 | if (xres > native_mode->panel_xres) | ||
| 103 | xres = native_mode->panel_xres; | ||
| 104 | if (yres > native_mode->panel_yres) | ||
| 105 | yres = native_mode->panel_yres; | ||
| 106 | |||
| 107 | if (xres == native_mode->panel_xres) | ||
| 108 | hscale = false; | ||
| 109 | if (yres == native_mode->panel_yres) | ||
| 110 | vscale = false; | ||
| 111 | } | ||
| 112 | |||
| 113 | switch (radeon_crtc->rmx_type) { | ||
| 114 | case RMX_FULL: | ||
| 115 | case RMX_ASPECT: | ||
| 116 | if (!hscale) | ||
| 117 | fp_horz_stretch |= ((xres/8-1) << 16); | ||
| 118 | else { | ||
| 119 | inc = (fp_horz_stretch & RADEON_HORZ_AUTO_RATIO_INC) ? 1 : 0; | ||
| 120 | scale = ((xres + inc) * RADEON_HORZ_STRETCH_RATIO_MAX) | ||
| 121 | / native_mode->panel_xres + 1; | ||
| 122 | fp_horz_stretch |= (((scale) & RADEON_HORZ_STRETCH_RATIO_MASK) | | ||
| 123 | RADEON_HORZ_STRETCH_BLEND | | ||
| 124 | RADEON_HORZ_STRETCH_ENABLE | | ||
| 125 | ((native_mode->panel_xres/8-1) << 16)); | ||
| 126 | } | ||
| 127 | |||
| 128 | if (!vscale) | ||
| 129 | fp_vert_stretch |= ((yres-1) << 12); | ||
| 130 | else { | ||
| 131 | inc = (fp_vert_stretch & RADEON_VERT_AUTO_RATIO_INC) ? 1 : 0; | ||
| 132 | scale = ((yres + inc) * RADEON_VERT_STRETCH_RATIO_MAX) | ||
| 133 | / native_mode->panel_yres + 1; | ||
| 134 | fp_vert_stretch |= (((scale) & RADEON_VERT_STRETCH_RATIO_MASK) | | ||
| 135 | RADEON_VERT_STRETCH_ENABLE | | ||
| 136 | RADEON_VERT_STRETCH_BLEND | | ||
| 137 | ((native_mode->panel_yres-1) << 12)); | ||
| 138 | } | ||
| 139 | break; | ||
| 140 | case RMX_CENTER: | ||
| 141 | fp_horz_stretch |= ((xres/8-1) << 16); | ||
| 142 | fp_vert_stretch |= ((yres-1) << 12); | ||
| 143 | |||
| 144 | crtc_more_cntl |= (RADEON_CRTC_AUTO_HORZ_CENTER_EN | | ||
| 145 | RADEON_CRTC_AUTO_VERT_CENTER_EN); | ||
| 146 | |||
| 147 | blank_width = (mode->crtc_hblank_end - mode->crtc_hblank_start) / 8; | ||
| 148 | if (blank_width > 110) | ||
| 149 | blank_width = 110; | ||
| 150 | |||
| 151 | fp_crtc_h_total_disp = (((blank_width) & 0x3ff) | ||
| 152 | | ((((mode->crtc_hdisplay / 8) - 1) & 0x1ff) << 16)); | ||
| 153 | |||
| 154 | hsync_wid = (mode->crtc_hsync_end - mode->crtc_hsync_start) / 8; | ||
| 155 | if (!hsync_wid) | ||
| 156 | hsync_wid = 1; | ||
| 157 | |||
| 158 | fp_h_sync_strt_wid = ((((mode->crtc_hsync_start - mode->crtc_hblank_start) / 8) & 0x1fff) | ||
| 159 | | ((hsync_wid & 0x3f) << 16) | ||
| 160 | | ((mode->flags & DRM_MODE_FLAG_NHSYNC) | ||
| 161 | ? RADEON_CRTC_H_SYNC_POL | ||
| 162 | : 0)); | ||
| 163 | |||
| 164 | fp_crtc_v_total_disp = (((mode->crtc_vblank_end - mode->crtc_vblank_start) & 0xffff) | ||
| 165 | | ((mode->crtc_vdisplay - 1) << 16)); | ||
| 166 | |||
| 167 | vsync_wid = mode->crtc_vsync_end - mode->crtc_vsync_start; | ||
| 168 | if (!vsync_wid) | ||
| 169 | vsync_wid = 1; | ||
| 170 | |||
| 171 | fp_v_sync_strt_wid = ((((mode->crtc_vsync_start - mode->crtc_vblank_start) & 0xfff) | ||
| 172 | | ((vsync_wid & 0x1f) << 16) | ||
| 173 | | ((mode->flags & DRM_MODE_FLAG_NVSYNC) | ||
| 174 | ? RADEON_CRTC_V_SYNC_POL | ||
| 175 | : 0))); | ||
| 176 | |||
| 177 | fp_horz_vert_active = (((native_mode->panel_yres) & 0xfff) | | ||
| 178 | (((native_mode->panel_xres / 8) & 0x1ff) << 16)); | ||
| 179 | break; | ||
| 180 | case RMX_OFF: | ||
| 181 | default: | ||
| 182 | fp_horz_stretch |= ((xres/8-1) << 16); | ||
| 183 | fp_vert_stretch |= ((yres-1) << 12); | ||
| 184 | break; | ||
| 185 | } | ||
| 186 | |||
| 187 | WREG32(RADEON_FP_HORZ_STRETCH, fp_horz_stretch); | ||
| 188 | WREG32(RADEON_FP_VERT_STRETCH, fp_vert_stretch); | ||
| 189 | WREG32(RADEON_CRTC_MORE_CNTL, crtc_more_cntl); | ||
| 190 | WREG32(RADEON_FP_HORZ_VERT_ACTIVE, fp_horz_vert_active); | ||
| 191 | WREG32(RADEON_FP_H_SYNC_STRT_WID, fp_h_sync_strt_wid); | ||
| 192 | WREG32(RADEON_FP_V_SYNC_STRT_WID, fp_v_sync_strt_wid); | ||
| 193 | WREG32(RADEON_FP_CRTC_H_TOTAL_DISP, fp_crtc_h_total_disp); | ||
| 194 | WREG32(RADEON_FP_CRTC_V_TOTAL_DISP, fp_crtc_v_total_disp); | ||
| 195 | } | ||
| 196 | |||
| 32 | void radeon_restore_common_regs(struct drm_device *dev) | 197 | void radeon_restore_common_regs(struct drm_device *dev) |
| 33 | { | 198 | { |
| 34 | /* don't need this yet */ | 199 | /* don't need this yet */ |
| @@ -145,10 +310,13 @@ void radeon_crtc_dpms(struct drm_crtc *crtc, int mode) | |||
| 145 | RADEON_CRTC_DISP_REQ_EN_B)); | 310 | RADEON_CRTC_DISP_REQ_EN_B)); |
| 146 | WREG32_P(RADEON_CRTC_EXT_CNTL, 0, ~mask); | 311 | WREG32_P(RADEON_CRTC_EXT_CNTL, 0, ~mask); |
| 147 | } | 312 | } |
| 313 | drm_vblank_post_modeset(dev, radeon_crtc->crtc_id); | ||
| 314 | radeon_crtc_load_lut(crtc); | ||
| 148 | break; | 315 | break; |
| 149 | case DRM_MODE_DPMS_STANDBY: | 316 | case DRM_MODE_DPMS_STANDBY: |
| 150 | case DRM_MODE_DPMS_SUSPEND: | 317 | case DRM_MODE_DPMS_SUSPEND: |
| 151 | case DRM_MODE_DPMS_OFF: | 318 | case DRM_MODE_DPMS_OFF: |
| 319 | drm_vblank_pre_modeset(dev, radeon_crtc->crtc_id); | ||
| 152 | if (radeon_crtc->crtc_id) | 320 | if (radeon_crtc->crtc_id) |
| 153 | WREG32_P(RADEON_CRTC2_GEN_CNTL, mask, ~mask); | 321 | WREG32_P(RADEON_CRTC2_GEN_CNTL, mask, ~mask); |
| 154 | else { | 322 | else { |
| @@ -158,10 +326,6 @@ void radeon_crtc_dpms(struct drm_crtc *crtc, int mode) | |||
| 158 | } | 326 | } |
| 159 | break; | 327 | break; |
| 160 | } | 328 | } |
| 161 | |||
| 162 | if (mode != DRM_MODE_DPMS_OFF) { | ||
| 163 | radeon_crtc_load_lut(crtc); | ||
| 164 | } | ||
| 165 | } | 329 | } |
| 166 | 330 | ||
| 167 | /* properly set crtc bpp when using atombios */ | 331 | /* properly set crtc bpp when using atombios */ |
| @@ -235,6 +399,7 @@ int radeon_crtc_set_base(struct drm_crtc *crtc, int x, int y, | |||
| 235 | uint64_t base; | 399 | uint64_t base; |
| 236 | uint32_t crtc_offset, crtc_offset_cntl, crtc_tile_x0_y0 = 0; | 400 | uint32_t crtc_offset, crtc_offset_cntl, crtc_tile_x0_y0 = 0; |
| 237 | uint32_t crtc_pitch, pitch_pixels; | 401 | uint32_t crtc_pitch, pitch_pixels; |
| 402 | uint32_t tiling_flags; | ||
| 238 | 403 | ||
| 239 | DRM_DEBUG("\n"); | 404 | DRM_DEBUG("\n"); |
| 240 | 405 | ||
| @@ -244,7 +409,12 @@ int radeon_crtc_set_base(struct drm_crtc *crtc, int x, int y, | |||
| 244 | if (radeon_gem_object_pin(obj, RADEON_GEM_DOMAIN_VRAM, &base)) { | 409 | if (radeon_gem_object_pin(obj, RADEON_GEM_DOMAIN_VRAM, &base)) { |
| 245 | return -EINVAL; | 410 | return -EINVAL; |
| 246 | } | 411 | } |
| 247 | crtc_offset = (u32)base; | 412 | /* if scanout was in GTT this really wouldn't work */ |
| 413 | /* crtc offset is from display base addr not FB location */ | ||
| 414 | radeon_crtc->legacy_display_base_addr = rdev->mc.vram_location; | ||
| 415 | |||
| 416 | base -= radeon_crtc->legacy_display_base_addr; | ||
| 417 | |||
| 248 | crtc_offset_cntl = 0; | 418 | crtc_offset_cntl = 0; |
| 249 | 419 | ||
| 250 | pitch_pixels = crtc->fb->pitch / (crtc->fb->bits_per_pixel / 8); | 420 | pitch_pixels = crtc->fb->pitch / (crtc->fb->bits_per_pixel / 8); |
| @@ -253,8 +423,12 @@ int radeon_crtc_set_base(struct drm_crtc *crtc, int x, int y, | |||
| 253 | (crtc->fb->bits_per_pixel * 8)); | 423 | (crtc->fb->bits_per_pixel * 8)); |
| 254 | crtc_pitch |= crtc_pitch << 16; | 424 | crtc_pitch |= crtc_pitch << 16; |
| 255 | 425 | ||
| 256 | /* TODO tiling */ | 426 | radeon_object_get_tiling_flags(obj->driver_private, |
| 257 | if (0) { | 427 | &tiling_flags, NULL); |
| 428 | if (tiling_flags & RADEON_TILING_MICRO) | ||
| 429 | DRM_ERROR("trying to scanout microtiled buffer\n"); | ||
| 430 | |||
| 431 | if (tiling_flags & RADEON_TILING_MACRO) { | ||
| 258 | if (ASIC_IS_R300(rdev)) | 432 | if (ASIC_IS_R300(rdev)) |
| 259 | crtc_offset_cntl |= (R300_CRTC_X_Y_MODE_EN | | 433 | crtc_offset_cntl |= (R300_CRTC_X_Y_MODE_EN | |
| 260 | R300_CRTC_MICRO_TILE_BUFFER_DIS | | 434 | R300_CRTC_MICRO_TILE_BUFFER_DIS | |
| @@ -270,15 +444,13 @@ int radeon_crtc_set_base(struct drm_crtc *crtc, int x, int y, | |||
| 270 | crtc_offset_cntl &= ~RADEON_CRTC_TILE_EN; | 444 | crtc_offset_cntl &= ~RADEON_CRTC_TILE_EN; |
| 271 | } | 445 | } |
| 272 | 446 | ||
| 273 | 447 | if (tiling_flags & RADEON_TILING_MACRO) { | |
| 274 | /* TODO more tiling */ | ||
| 275 | if (0) { | ||
| 276 | if (ASIC_IS_R300(rdev)) { | 448 | if (ASIC_IS_R300(rdev)) { |
| 277 | crtc_tile_x0_y0 = x | (y << 16); | 449 | crtc_tile_x0_y0 = x | (y << 16); |
| 278 | base &= ~0x7ff; | 450 | base &= ~0x7ff; |
| 279 | } else { | 451 | } else { |
| 280 | int byteshift = crtc->fb->bits_per_pixel >> 4; | 452 | int byteshift = crtc->fb->bits_per_pixel >> 4; |
| 281 | int tile_addr = (((y >> 3) * crtc->fb->width + x) >> (8 - byteshift)) << 11; | 453 | int tile_addr = (((y >> 3) * pitch_pixels + x) >> (8 - byteshift)) << 11; |
| 282 | base += tile_addr + ((x << byteshift) % 256) + ((y % 8) << 8); | 454 | base += tile_addr + ((x << byteshift) % 256) + ((y % 8) << 8); |
| 283 | crtc_offset_cntl |= (y % 16); | 455 | crtc_offset_cntl |= (y % 16); |
| 284 | } | 456 | } |
| @@ -303,11 +475,9 @@ int radeon_crtc_set_base(struct drm_crtc *crtc, int x, int y, | |||
| 303 | 475 | ||
| 304 | base &= ~7; | 476 | base &= ~7; |
| 305 | 477 | ||
| 306 | /* update sarea TODO */ | ||
| 307 | |||
| 308 | crtc_offset = (u32)base; | 478 | crtc_offset = (u32)base; |
| 309 | 479 | ||
| 310 | WREG32(RADEON_DISPLAY_BASE_ADDR + radeon_crtc->crtc_offset, rdev->mc.vram_location); | 480 | WREG32(RADEON_DISPLAY_BASE_ADDR + radeon_crtc->crtc_offset, radeon_crtc->legacy_display_base_addr); |
| 311 | 481 | ||
| 312 | if (ASIC_IS_R300(rdev)) { | 482 | if (ASIC_IS_R300(rdev)) { |
| 313 | if (radeon_crtc->crtc_id) | 483 | if (radeon_crtc->crtc_id) |
| @@ -751,6 +921,8 @@ static bool radeon_crtc_mode_fixup(struct drm_crtc *crtc, | |||
| 751 | struct drm_display_mode *mode, | 921 | struct drm_display_mode *mode, |
| 752 | struct drm_display_mode *adjusted_mode) | 922 | struct drm_display_mode *adjusted_mode) |
| 753 | { | 923 | { |
| 924 | if (!radeon_crtc_scaling_mode_fixup(crtc, mode, adjusted_mode)) | ||
| 925 | return false; | ||
| 754 | return true; | 926 | return true; |
| 755 | } | 927 | } |
| 756 | 928 | ||
| @@ -759,16 +931,25 @@ static int radeon_crtc_mode_set(struct drm_crtc *crtc, | |||
| 759 | struct drm_display_mode *adjusted_mode, | 931 | struct drm_display_mode *adjusted_mode, |
| 760 | int x, int y, struct drm_framebuffer *old_fb) | 932 | int x, int y, struct drm_framebuffer *old_fb) |
| 761 | { | 933 | { |
| 762 | 934 | struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); | |
| 763 | DRM_DEBUG("\n"); | 935 | struct drm_device *dev = crtc->dev; |
| 936 | struct radeon_device *rdev = dev->dev_private; | ||
| 764 | 937 | ||
| 765 | /* TODO TV */ | 938 | /* TODO TV */ |
| 766 | |||
| 767 | radeon_crtc_set_base(crtc, x, y, old_fb); | 939 | radeon_crtc_set_base(crtc, x, y, old_fb); |
| 768 | radeon_set_crtc_timing(crtc, adjusted_mode); | 940 | radeon_set_crtc_timing(crtc, adjusted_mode); |
| 769 | radeon_set_pll(crtc, adjusted_mode); | 941 | radeon_set_pll(crtc, adjusted_mode); |
| 770 | radeon_init_disp_bandwidth(crtc->dev); | 942 | radeon_bandwidth_update(rdev); |
| 771 | 943 | if (radeon_crtc->crtc_id == 0) { | |
| 944 | radeon_legacy_rmx_mode_set(crtc, mode, adjusted_mode); | ||
| 945 | } else { | ||
| 946 | if (radeon_crtc->rmx_type != RMX_OFF) { | ||
| 947 | /* FIXME: only first crtc has rmx what should we | ||
| 948 | * do ? | ||
| 949 | */ | ||
| 950 | DRM_ERROR("Mode need scaling but only first crtc can do that.\n"); | ||
| 951 | } | ||
| 952 | } | ||
| 772 | return 0; | 953 | return 0; |
| 773 | } | 954 | } |
| 774 | 955 | ||
| @@ -799,478 +980,3 @@ void radeon_legacy_init_crtc(struct drm_device *dev, | |||
| 799 | radeon_crtc->crtc_offset = RADEON_CRTC2_H_TOTAL_DISP - RADEON_CRTC_H_TOTAL_DISP; | 980 | radeon_crtc->crtc_offset = RADEON_CRTC2_H_TOTAL_DISP - RADEON_CRTC_H_TOTAL_DISP; |
| 800 | drm_crtc_helper_add(&radeon_crtc->base, &legacy_helper_funcs); | 981 | drm_crtc_helper_add(&radeon_crtc->base, &legacy_helper_funcs); |
| 801 | } | 982 | } |
| 802 | |||
| 803 | void radeon_init_disp_bw_legacy(struct drm_device *dev, | ||
| 804 | struct drm_display_mode *mode1, | ||
| 805 | uint32_t pixel_bytes1, | ||
| 806 | struct drm_display_mode *mode2, | ||
| 807 | uint32_t pixel_bytes2) | ||
| 808 | { | ||
| 809 | struct radeon_device *rdev = dev->dev_private; | ||
| 810 | fixed20_12 trcd_ff, trp_ff, tras_ff, trbs_ff, tcas_ff; | ||
| 811 | fixed20_12 sclk_ff, mclk_ff, sclk_eff_ff, sclk_delay_ff; | ||
| 812 | fixed20_12 peak_disp_bw, mem_bw, pix_clk, pix_clk2, temp_ff, crit_point_ff; | ||
| 813 | uint32_t temp, data, mem_trcd, mem_trp, mem_tras; | ||
| 814 | fixed20_12 memtcas_ff[8] = { | ||
| 815 | fixed_init(1), | ||
| 816 | fixed_init(2), | ||
| 817 | fixed_init(3), | ||
| 818 | fixed_init(0), | ||
| 819 | fixed_init_half(1), | ||
| 820 | fixed_init_half(2), | ||
| 821 | fixed_init(0), | ||
| 822 | }; | ||
| 823 | fixed20_12 memtcas_rs480_ff[8] = { | ||
| 824 | fixed_init(0), | ||
| 825 | fixed_init(1), | ||
| 826 | fixed_init(2), | ||
| 827 | fixed_init(3), | ||
| 828 | fixed_init(0), | ||
| 829 | fixed_init_half(1), | ||
| 830 | fixed_init_half(2), | ||
| 831 | fixed_init_half(3), | ||
| 832 | }; | ||
| 833 | fixed20_12 memtcas2_ff[8] = { | ||
| 834 | fixed_init(0), | ||
| 835 | fixed_init(1), | ||
| 836 | fixed_init(2), | ||
| 837 | fixed_init(3), | ||
| 838 | fixed_init(4), | ||
| 839 | fixed_init(5), | ||
| 840 | fixed_init(6), | ||
| 841 | fixed_init(7), | ||
| 842 | }; | ||
| 843 | fixed20_12 memtrbs[8] = { | ||
| 844 | fixed_init(1), | ||
| 845 | fixed_init_half(1), | ||
| 846 | fixed_init(2), | ||
| 847 | fixed_init_half(2), | ||
| 848 | fixed_init(3), | ||
| 849 | fixed_init_half(3), | ||
| 850 | fixed_init(4), | ||
| 851 | fixed_init_half(4) | ||
| 852 | }; | ||
| 853 | fixed20_12 memtrbs_r4xx[8] = { | ||
| 854 | fixed_init(4), | ||
| 855 | fixed_init(5), | ||
| 856 | fixed_init(6), | ||
| 857 | fixed_init(7), | ||
| 858 | fixed_init(8), | ||
| 859 | fixed_init(9), | ||
| 860 | fixed_init(10), | ||
| 861 | fixed_init(11) | ||
| 862 | }; | ||
| 863 | fixed20_12 min_mem_eff; | ||
| 864 | fixed20_12 mc_latency_sclk, mc_latency_mclk, k1; | ||
| 865 | fixed20_12 cur_latency_mclk, cur_latency_sclk; | ||
| 866 | fixed20_12 disp_latency, disp_latency_overhead, disp_drain_rate, | ||
| 867 | disp_drain_rate2, read_return_rate; | ||
| 868 | fixed20_12 time_disp1_drop_priority; | ||
| 869 | int c; | ||
| 870 | int cur_size = 16; /* in octawords */ | ||
| 871 | int critical_point = 0, critical_point2; | ||
| 872 | /* uint32_t read_return_rate, time_disp1_drop_priority; */ | ||
| 873 | int stop_req, max_stop_req; | ||
| 874 | |||
| 875 | min_mem_eff.full = rfixed_const_8(0); | ||
| 876 | /* get modes */ | ||
| 877 | if ((rdev->disp_priority == 2) && ASIC_IS_R300(rdev)) { | ||
| 878 | uint32_t mc_init_misc_lat_timer = RREG32(R300_MC_INIT_MISC_LAT_TIMER); | ||
| 879 | mc_init_misc_lat_timer &= ~(R300_MC_DISP1R_INIT_LAT_MASK << R300_MC_DISP1R_INIT_LAT_SHIFT); | ||
| 880 | mc_init_misc_lat_timer &= ~(R300_MC_DISP0R_INIT_LAT_MASK << R300_MC_DISP0R_INIT_LAT_SHIFT); | ||
| 881 | /* check crtc enables */ | ||
| 882 | if (mode2) | ||
| 883 | mc_init_misc_lat_timer |= (1 << R300_MC_DISP1R_INIT_LAT_SHIFT); | ||
| 884 | if (mode1) | ||
| 885 | mc_init_misc_lat_timer |= (1 << R300_MC_DISP0R_INIT_LAT_SHIFT); | ||
| 886 | WREG32(R300_MC_INIT_MISC_LAT_TIMER, mc_init_misc_lat_timer); | ||
| 887 | } | ||
| 888 | |||
| 889 | /* | ||
| 890 | * determine is there is enough bw for current mode | ||
| 891 | */ | ||
| 892 | mclk_ff.full = rfixed_const(rdev->clock.default_mclk); | ||
| 893 | temp_ff.full = rfixed_const(100); | ||
| 894 | mclk_ff.full = rfixed_div(mclk_ff, temp_ff); | ||
| 895 | sclk_ff.full = rfixed_const(rdev->clock.default_sclk); | ||
| 896 | sclk_ff.full = rfixed_div(sclk_ff, temp_ff); | ||
| 897 | |||
| 898 | temp = (rdev->mc.vram_width / 8) * (rdev->mc.vram_is_ddr ? 2 : 1); | ||
| 899 | temp_ff.full = rfixed_const(temp); | ||
| 900 | mem_bw.full = rfixed_mul(mclk_ff, temp_ff); | ||
| 901 | |||
| 902 | pix_clk.full = 0; | ||
| 903 | pix_clk2.full = 0; | ||
| 904 | peak_disp_bw.full = 0; | ||
| 905 | if (mode1) { | ||
| 906 | temp_ff.full = rfixed_const(1000); | ||
| 907 | pix_clk.full = rfixed_const(mode1->clock); /* convert to fixed point */ | ||
| 908 | pix_clk.full = rfixed_div(pix_clk, temp_ff); | ||
| 909 | temp_ff.full = rfixed_const(pixel_bytes1); | ||
| 910 | peak_disp_bw.full += rfixed_mul(pix_clk, temp_ff); | ||
| 911 | } | ||
| 912 | if (mode2) { | ||
| 913 | temp_ff.full = rfixed_const(1000); | ||
| 914 | pix_clk2.full = rfixed_const(mode2->clock); /* convert to fixed point */ | ||
| 915 | pix_clk2.full = rfixed_div(pix_clk2, temp_ff); | ||
| 916 | temp_ff.full = rfixed_const(pixel_bytes2); | ||
| 917 | peak_disp_bw.full += rfixed_mul(pix_clk2, temp_ff); | ||
| 918 | } | ||
| 919 | |||
| 920 | mem_bw.full = rfixed_mul(mem_bw, min_mem_eff); | ||
| 921 | if (peak_disp_bw.full >= mem_bw.full) { | ||
| 922 | DRM_ERROR("You may not have enough display bandwidth for current mode\n" | ||
| 923 | "If you have flickering problem, try to lower resolution, refresh rate, or color depth\n"); | ||
| 924 | } | ||
| 925 | |||
| 926 | /* Get values from the EXT_MEM_CNTL register...converting its contents. */ | ||
| 927 | temp = RREG32(RADEON_MEM_TIMING_CNTL); | ||
| 928 | if ((rdev->family == CHIP_RV100) || (rdev->flags & RADEON_IS_IGP)) { /* RV100, M6, IGPs */ | ||
| 929 | mem_trcd = ((temp >> 2) & 0x3) + 1; | ||
| 930 | mem_trp = ((temp & 0x3)) + 1; | ||
| 931 | mem_tras = ((temp & 0x70) >> 4) + 1; | ||
| 932 | } else if (rdev->family == CHIP_R300 || | ||
| 933 | rdev->family == CHIP_R350) { /* r300, r350 */ | ||
| 934 | mem_trcd = (temp & 0x7) + 1; | ||
| 935 | mem_trp = ((temp >> 8) & 0x7) + 1; | ||
| 936 | mem_tras = ((temp >> 11) & 0xf) + 4; | ||
| 937 | } else if (rdev->family == CHIP_RV350 || | ||
| 938 | rdev->family <= CHIP_RV380) { | ||
| 939 | /* rv3x0 */ | ||
| 940 | mem_trcd = (temp & 0x7) + 3; | ||
| 941 | mem_trp = ((temp >> 8) & 0x7) + 3; | ||
| 942 | mem_tras = ((temp >> 11) & 0xf) + 6; | ||
| 943 | } else if (rdev->family == CHIP_R420 || | ||
| 944 | rdev->family == CHIP_R423 || | ||
| 945 | rdev->family == CHIP_RV410) { | ||
| 946 | /* r4xx */ | ||
| 947 | mem_trcd = (temp & 0xf) + 3; | ||
| 948 | if (mem_trcd > 15) | ||
| 949 | mem_trcd = 15; | ||
| 950 | mem_trp = ((temp >> 8) & 0xf) + 3; | ||
| 951 | if (mem_trp > 15) | ||
| 952 | mem_trp = 15; | ||
| 953 | mem_tras = ((temp >> 12) & 0x1f) + 6; | ||
| 954 | if (mem_tras > 31) | ||
| 955 | mem_tras = 31; | ||
| 956 | } else { /* RV200, R200 */ | ||
| 957 | mem_trcd = (temp & 0x7) + 1; | ||
| 958 | mem_trp = ((temp >> 8) & 0x7) + 1; | ||
| 959 | mem_tras = ((temp >> 12) & 0xf) + 4; | ||
| 960 | } | ||
| 961 | /* convert to FF */ | ||
| 962 | trcd_ff.full = rfixed_const(mem_trcd); | ||
| 963 | trp_ff.full = rfixed_const(mem_trp); | ||
| 964 | tras_ff.full = rfixed_const(mem_tras); | ||
| 965 | |||
| 966 | /* Get values from the MEM_SDRAM_MODE_REG register...converting its */ | ||
| 967 | temp = RREG32(RADEON_MEM_SDRAM_MODE_REG); | ||
| 968 | data = (temp & (7 << 20)) >> 20; | ||
| 969 | if ((rdev->family == CHIP_RV100) || rdev->flags & RADEON_IS_IGP) { | ||
| 970 | if (rdev->family == CHIP_RS480) /* don't think rs400 */ | ||
| 971 | tcas_ff = memtcas_rs480_ff[data]; | ||
| 972 | else | ||
| 973 | tcas_ff = memtcas_ff[data]; | ||
| 974 | } else | ||
| 975 | tcas_ff = memtcas2_ff[data]; | ||
| 976 | |||
| 977 | if (rdev->family == CHIP_RS400 || | ||
| 978 | rdev->family == CHIP_RS480) { | ||
| 979 | /* extra cas latency stored in bits 23-25 0-4 clocks */ | ||
| 980 | data = (temp >> 23) & 0x7; | ||
| 981 | if (data < 5) | ||
| 982 | tcas_ff.full += rfixed_const(data); | ||
| 983 | } | ||
| 984 | |||
| 985 | if (ASIC_IS_R300(rdev) && !(rdev->flags & RADEON_IS_IGP)) { | ||
| 986 | /* on the R300, Tcas is included in Trbs. | ||
| 987 | */ | ||
| 988 | temp = RREG32(RADEON_MEM_CNTL); | ||
| 989 | data = (R300_MEM_NUM_CHANNELS_MASK & temp); | ||
| 990 | if (data == 1) { | ||
| 991 | if (R300_MEM_USE_CD_CH_ONLY & temp) { | ||
| 992 | temp = RREG32(R300_MC_IND_INDEX); | ||
| 993 | temp &= ~R300_MC_IND_ADDR_MASK; | ||
| 994 | temp |= R300_MC_READ_CNTL_CD_mcind; | ||
| 995 | WREG32(R300_MC_IND_INDEX, temp); | ||
| 996 | temp = RREG32(R300_MC_IND_DATA); | ||
| 997 | data = (R300_MEM_RBS_POSITION_C_MASK & temp); | ||
| 998 | } else { | ||
| 999 | temp = RREG32(R300_MC_READ_CNTL_AB); | ||
| 1000 | data = (R300_MEM_RBS_POSITION_A_MASK & temp); | ||
| 1001 | } | ||
| 1002 | } else { | ||
| 1003 | temp = RREG32(R300_MC_READ_CNTL_AB); | ||
| 1004 | data = (R300_MEM_RBS_POSITION_A_MASK & temp); | ||
| 1005 | } | ||
| 1006 | if (rdev->family == CHIP_RV410 || | ||
| 1007 | rdev->family == CHIP_R420 || | ||
| 1008 | rdev->family == CHIP_R423) | ||
| 1009 | trbs_ff = memtrbs_r4xx[data]; | ||
| 1010 | else | ||
| 1011 | trbs_ff = memtrbs[data]; | ||
| 1012 | tcas_ff.full += trbs_ff.full; | ||
| 1013 | } | ||
| 1014 | |||
| 1015 | sclk_eff_ff.full = sclk_ff.full; | ||
| 1016 | |||
| 1017 | if (rdev->flags & RADEON_IS_AGP) { | ||
| 1018 | fixed20_12 agpmode_ff; | ||
| 1019 | agpmode_ff.full = rfixed_const(radeon_agpmode); | ||
| 1020 | temp_ff.full = rfixed_const_666(16); | ||
| 1021 | sclk_eff_ff.full -= rfixed_mul(agpmode_ff, temp_ff); | ||
| 1022 | } | ||
| 1023 | /* TODO PCIE lanes may affect this - agpmode == 16?? */ | ||
| 1024 | |||
| 1025 | if (ASIC_IS_R300(rdev)) { | ||
| 1026 | sclk_delay_ff.full = rfixed_const(250); | ||
| 1027 | } else { | ||
| 1028 | if ((rdev->family == CHIP_RV100) || | ||
| 1029 | rdev->flags & RADEON_IS_IGP) { | ||
| 1030 | if (rdev->mc.vram_is_ddr) | ||
| 1031 | sclk_delay_ff.full = rfixed_const(41); | ||
| 1032 | else | ||
| 1033 | sclk_delay_ff.full = rfixed_const(33); | ||
| 1034 | } else { | ||
| 1035 | if (rdev->mc.vram_width == 128) | ||
| 1036 | sclk_delay_ff.full = rfixed_const(57); | ||
| 1037 | else | ||
| 1038 | sclk_delay_ff.full = rfixed_const(41); | ||
| 1039 | } | ||
| 1040 | } | ||
| 1041 | |||
| 1042 | mc_latency_sclk.full = rfixed_div(sclk_delay_ff, sclk_eff_ff); | ||
| 1043 | |||
| 1044 | if (rdev->mc.vram_is_ddr) { | ||
| 1045 | if (rdev->mc.vram_width == 32) { | ||
| 1046 | k1.full = rfixed_const(40); | ||
| 1047 | c = 3; | ||
| 1048 | } else { | ||
| 1049 | k1.full = rfixed_const(20); | ||
| 1050 | c = 1; | ||
| 1051 | } | ||
| 1052 | } else { | ||
| 1053 | k1.full = rfixed_const(40); | ||
| 1054 | c = 3; | ||
| 1055 | } | ||
| 1056 | |||
| 1057 | temp_ff.full = rfixed_const(2); | ||
| 1058 | mc_latency_mclk.full = rfixed_mul(trcd_ff, temp_ff); | ||
| 1059 | temp_ff.full = rfixed_const(c); | ||
| 1060 | mc_latency_mclk.full += rfixed_mul(tcas_ff, temp_ff); | ||
| 1061 | temp_ff.full = rfixed_const(4); | ||
| 1062 | mc_latency_mclk.full += rfixed_mul(tras_ff, temp_ff); | ||
| 1063 | mc_latency_mclk.full += rfixed_mul(trp_ff, temp_ff); | ||
| 1064 | mc_latency_mclk.full += k1.full; | ||
| 1065 | |||
| 1066 | mc_latency_mclk.full = rfixed_div(mc_latency_mclk, mclk_ff); | ||
| 1067 | mc_latency_mclk.full += rfixed_div(temp_ff, sclk_eff_ff); | ||
| 1068 | |||
| 1069 | /* | ||
| 1070 | HW cursor time assuming worst case of full size colour cursor. | ||
| 1071 | */ | ||
| 1072 | temp_ff.full = rfixed_const((2 * (cur_size - (rdev->mc.vram_is_ddr + 1)))); | ||
| 1073 | temp_ff.full += trcd_ff.full; | ||
| 1074 | if (temp_ff.full < tras_ff.full) | ||
| 1075 | temp_ff.full = tras_ff.full; | ||
| 1076 | cur_latency_mclk.full = rfixed_div(temp_ff, mclk_ff); | ||
| 1077 | |||
| 1078 | temp_ff.full = rfixed_const(cur_size); | ||
| 1079 | cur_latency_sclk.full = rfixed_div(temp_ff, sclk_eff_ff); | ||
| 1080 | /* | ||
| 1081 | Find the total latency for the display data. | ||
| 1082 | */ | ||
| 1083 | disp_latency_overhead.full = rfixed_const(80); | ||
| 1084 | disp_latency_overhead.full = rfixed_div(disp_latency_overhead, sclk_ff); | ||
| 1085 | mc_latency_mclk.full += disp_latency_overhead.full + cur_latency_mclk.full; | ||
| 1086 | mc_latency_sclk.full += disp_latency_overhead.full + cur_latency_sclk.full; | ||
| 1087 | |||
| 1088 | if (mc_latency_mclk.full > mc_latency_sclk.full) | ||
| 1089 | disp_latency.full = mc_latency_mclk.full; | ||
| 1090 | else | ||
| 1091 | disp_latency.full = mc_latency_sclk.full; | ||
| 1092 | |||
| 1093 | /* setup Max GRPH_STOP_REQ default value */ | ||
| 1094 | if (ASIC_IS_RV100(rdev)) | ||
| 1095 | max_stop_req = 0x5c; | ||
| 1096 | else | ||
| 1097 | max_stop_req = 0x7c; | ||
| 1098 | |||
| 1099 | if (mode1) { | ||
| 1100 | /* CRTC1 | ||
| 1101 | Set GRPH_BUFFER_CNTL register using h/w defined optimal values. | ||
| 1102 | GRPH_STOP_REQ <= MIN[ 0x7C, (CRTC_H_DISP + 1) * (bit depth) / 0x10 ] | ||
| 1103 | */ | ||
| 1104 | stop_req = mode1->hdisplay * pixel_bytes1 / 16; | ||
| 1105 | |||
| 1106 | if (stop_req > max_stop_req) | ||
| 1107 | stop_req = max_stop_req; | ||
| 1108 | |||
| 1109 | /* | ||
| 1110 | Find the drain rate of the display buffer. | ||
| 1111 | */ | ||
| 1112 | temp_ff.full = rfixed_const((16/pixel_bytes1)); | ||
| 1113 | disp_drain_rate.full = rfixed_div(pix_clk, temp_ff); | ||
| 1114 | |||
| 1115 | /* | ||
| 1116 | Find the critical point of the display buffer. | ||
| 1117 | */ | ||
| 1118 | crit_point_ff.full = rfixed_mul(disp_drain_rate, disp_latency); | ||
| 1119 | crit_point_ff.full += rfixed_const_half(0); | ||
| 1120 | |||
| 1121 | critical_point = rfixed_trunc(crit_point_ff); | ||
| 1122 | |||
| 1123 | if (rdev->disp_priority == 2) { | ||
| 1124 | critical_point = 0; | ||
| 1125 | } | ||
| 1126 | |||
| 1127 | /* | ||
| 1128 | The critical point should never be above max_stop_req-4. Setting | ||
| 1129 | GRPH_CRITICAL_CNTL = 0 will thus force high priority all the time. | ||
| 1130 | */ | ||
| 1131 | if (max_stop_req - critical_point < 4) | ||
| 1132 | critical_point = 0; | ||
| 1133 | |||
| 1134 | if (critical_point == 0 && mode2 && rdev->family == CHIP_R300) { | ||
| 1135 | /* some R300 cards have problem with this set to 0, when CRTC2 is enabled.*/ | ||
| 1136 | critical_point = 0x10; | ||
| 1137 | } | ||
| 1138 | |||
| 1139 | temp = RREG32(RADEON_GRPH_BUFFER_CNTL); | ||
| 1140 | temp &= ~(RADEON_GRPH_STOP_REQ_MASK); | ||
| 1141 | temp |= (stop_req << RADEON_GRPH_STOP_REQ_SHIFT); | ||
| 1142 | temp &= ~(RADEON_GRPH_START_REQ_MASK); | ||
| 1143 | if ((rdev->family == CHIP_R350) && | ||
| 1144 | (stop_req > 0x15)) { | ||
| 1145 | stop_req -= 0x10; | ||
| 1146 | } | ||
| 1147 | temp |= (stop_req << RADEON_GRPH_START_REQ_SHIFT); | ||
| 1148 | temp |= RADEON_GRPH_BUFFER_SIZE; | ||
| 1149 | temp &= ~(RADEON_GRPH_CRITICAL_CNTL | | ||
| 1150 | RADEON_GRPH_CRITICAL_AT_SOF | | ||
| 1151 | RADEON_GRPH_STOP_CNTL); | ||
| 1152 | /* | ||
| 1153 | Write the result into the register. | ||
| 1154 | */ | ||
| 1155 | WREG32(RADEON_GRPH_BUFFER_CNTL, ((temp & ~RADEON_GRPH_CRITICAL_POINT_MASK) | | ||
| 1156 | (critical_point << RADEON_GRPH_CRITICAL_POINT_SHIFT))); | ||
| 1157 | |||
| 1158 | #if 0 | ||
| 1159 | if ((rdev->family == CHIP_RS400) || | ||
| 1160 | (rdev->family == CHIP_RS480)) { | ||
| 1161 | /* attempt to program RS400 disp regs correctly ??? */ | ||
| 1162 | temp = RREG32(RS400_DISP1_REG_CNTL); | ||
| 1163 | temp &= ~(RS400_DISP1_START_REQ_LEVEL_MASK | | ||
| 1164 | RS400_DISP1_STOP_REQ_LEVEL_MASK); | ||
| 1165 | WREG32(RS400_DISP1_REQ_CNTL1, (temp | | ||
| 1166 | (critical_point << RS400_DISP1_START_REQ_LEVEL_SHIFT) | | ||
| 1167 | (critical_point << RS400_DISP1_STOP_REQ_LEVEL_SHIFT))); | ||
| 1168 | temp = RREG32(RS400_DMIF_MEM_CNTL1); | ||
| 1169 | temp &= ~(RS400_DISP1_CRITICAL_POINT_START_MASK | | ||
| 1170 | RS400_DISP1_CRITICAL_POINT_STOP_MASK); | ||
| 1171 | WREG32(RS400_DMIF_MEM_CNTL1, (temp | | ||
| 1172 | (critical_point << RS400_DISP1_CRITICAL_POINT_START_SHIFT) | | ||
| 1173 | (critical_point << RS400_DISP1_CRITICAL_POINT_STOP_SHIFT))); | ||
| 1174 | } | ||
| 1175 | #endif | ||
| 1176 | |||
| 1177 | DRM_DEBUG("GRPH_BUFFER_CNTL from to %x\n", | ||
| 1178 | /* (unsigned int)info->SavedReg->grph_buffer_cntl, */ | ||
| 1179 | (unsigned int)RREG32(RADEON_GRPH_BUFFER_CNTL)); | ||
| 1180 | } | ||
| 1181 | |||
| 1182 | if (mode2) { | ||
| 1183 | u32 grph2_cntl; | ||
| 1184 | stop_req = mode2->hdisplay * pixel_bytes2 / 16; | ||
| 1185 | |||
| 1186 | if (stop_req > max_stop_req) | ||
| 1187 | stop_req = max_stop_req; | ||
| 1188 | |||
| 1189 | /* | ||
| 1190 | Find the drain rate of the display buffer. | ||
| 1191 | */ | ||
| 1192 | temp_ff.full = rfixed_const((16/pixel_bytes2)); | ||
| 1193 | disp_drain_rate2.full = rfixed_div(pix_clk2, temp_ff); | ||
| 1194 | |||
| 1195 | grph2_cntl = RREG32(RADEON_GRPH2_BUFFER_CNTL); | ||
| 1196 | grph2_cntl &= ~(RADEON_GRPH_STOP_REQ_MASK); | ||
| 1197 | grph2_cntl |= (stop_req << RADEON_GRPH_STOP_REQ_SHIFT); | ||
| 1198 | grph2_cntl &= ~(RADEON_GRPH_START_REQ_MASK); | ||
| 1199 | if ((rdev->family == CHIP_R350) && | ||
| 1200 | (stop_req > 0x15)) { | ||
| 1201 | stop_req -= 0x10; | ||
| 1202 | } | ||
| 1203 | grph2_cntl |= (stop_req << RADEON_GRPH_START_REQ_SHIFT); | ||
| 1204 | grph2_cntl |= RADEON_GRPH_BUFFER_SIZE; | ||
| 1205 | grph2_cntl &= ~(RADEON_GRPH_CRITICAL_CNTL | | ||
| 1206 | RADEON_GRPH_CRITICAL_AT_SOF | | ||
| 1207 | RADEON_GRPH_STOP_CNTL); | ||
| 1208 | |||
| 1209 | if ((rdev->family == CHIP_RS100) || | ||
| 1210 | (rdev->family == CHIP_RS200)) | ||
| 1211 | critical_point2 = 0; | ||
| 1212 | else { | ||
| 1213 | temp = (rdev->mc.vram_width * rdev->mc.vram_is_ddr + 1)/128; | ||
| 1214 | temp_ff.full = rfixed_const(temp); | ||
| 1215 | temp_ff.full = rfixed_mul(mclk_ff, temp_ff); | ||
| 1216 | if (sclk_ff.full < temp_ff.full) | ||
| 1217 | temp_ff.full = sclk_ff.full; | ||
| 1218 | |||
| 1219 | read_return_rate.full = temp_ff.full; | ||
| 1220 | |||
| 1221 | if (mode1) { | ||
| 1222 | temp_ff.full = read_return_rate.full - disp_drain_rate.full; | ||
| 1223 | time_disp1_drop_priority.full = rfixed_div(crit_point_ff, temp_ff); | ||
| 1224 | } else { | ||
| 1225 | time_disp1_drop_priority.full = 0; | ||
| 1226 | } | ||
| 1227 | crit_point_ff.full = disp_latency.full + time_disp1_drop_priority.full + disp_latency.full; | ||
| 1228 | crit_point_ff.full = rfixed_mul(crit_point_ff, disp_drain_rate2); | ||
| 1229 | crit_point_ff.full += rfixed_const_half(0); | ||
| 1230 | |||
| 1231 | critical_point2 = rfixed_trunc(crit_point_ff); | ||
| 1232 | |||
| 1233 | if (rdev->disp_priority == 2) { | ||
| 1234 | critical_point2 = 0; | ||
| 1235 | } | ||
| 1236 | |||
| 1237 | if (max_stop_req - critical_point2 < 4) | ||
| 1238 | critical_point2 = 0; | ||
| 1239 | |||
| 1240 | } | ||
| 1241 | |||
| 1242 | if (critical_point2 == 0 && rdev->family == CHIP_R300) { | ||
| 1243 | /* some R300 cards have problem with this set to 0 */ | ||
| 1244 | critical_point2 = 0x10; | ||
| 1245 | } | ||
| 1246 | |||
| 1247 | WREG32(RADEON_GRPH2_BUFFER_CNTL, ((grph2_cntl & ~RADEON_GRPH_CRITICAL_POINT_MASK) | | ||
| 1248 | (critical_point2 << RADEON_GRPH_CRITICAL_POINT_SHIFT))); | ||
| 1249 | |||
| 1250 | if ((rdev->family == CHIP_RS400) || | ||
| 1251 | (rdev->family == CHIP_RS480)) { | ||
| 1252 | #if 0 | ||
| 1253 | /* attempt to program RS400 disp2 regs correctly ??? */ | ||
| 1254 | temp = RREG32(RS400_DISP2_REQ_CNTL1); | ||
| 1255 | temp &= ~(RS400_DISP2_START_REQ_LEVEL_MASK | | ||
| 1256 | RS400_DISP2_STOP_REQ_LEVEL_MASK); | ||
| 1257 | WREG32(RS400_DISP2_REQ_CNTL1, (temp | | ||
| 1258 | (critical_point2 << RS400_DISP1_START_REQ_LEVEL_SHIFT) | | ||
| 1259 | (critical_point2 << RS400_DISP1_STOP_REQ_LEVEL_SHIFT))); | ||
| 1260 | temp = RREG32(RS400_DISP2_REQ_CNTL2); | ||
| 1261 | temp &= ~(RS400_DISP2_CRITICAL_POINT_START_MASK | | ||
| 1262 | RS400_DISP2_CRITICAL_POINT_STOP_MASK); | ||
| 1263 | WREG32(RS400_DISP2_REQ_CNTL2, (temp | | ||
| 1264 | (critical_point2 << RS400_DISP2_CRITICAL_POINT_START_SHIFT) | | ||
| 1265 | (critical_point2 << RS400_DISP2_CRITICAL_POINT_STOP_SHIFT))); | ||
| 1266 | #endif | ||
| 1267 | WREG32(RS400_DISP2_REQ_CNTL1, 0x105DC1CC); | ||
| 1268 | WREG32(RS400_DISP2_REQ_CNTL2, 0x2749D000); | ||
| 1269 | WREG32(RS400_DMIF_MEM_CNTL1, 0x29CA71DC); | ||
| 1270 | WREG32(RS400_DISP1_REQ_CNTL1, 0x28FBC3AC); | ||
| 1271 | } | ||
| 1272 | |||
| 1273 | DRM_DEBUG("GRPH2_BUFFER_CNTL from to %x\n", | ||
| 1274 | (unsigned int)RREG32(RADEON_GRPH2_BUFFER_CNTL)); | ||
| 1275 | } | ||
| 1276 | } | ||
diff --git a/drivers/gpu/drm/radeon/radeon_legacy_encoders.c b/drivers/gpu/drm/radeon/radeon_legacy_encoders.c index 2c2f42de1d4c..9322675ef6d0 100644 --- a/drivers/gpu/drm/radeon/radeon_legacy_encoders.c +++ b/drivers/gpu/drm/radeon/radeon_legacy_encoders.c | |||
| @@ -30,170 +30,6 @@ | |||
| 30 | #include "atom.h" | 30 | #include "atom.h" |
| 31 | 31 | ||
| 32 | 32 | ||
| 33 | static void radeon_legacy_rmx_mode_set(struct drm_encoder *encoder, | ||
| 34 | struct drm_display_mode *mode, | ||
| 35 | struct drm_display_mode *adjusted_mode) | ||
| 36 | { | ||
| 37 | struct drm_device *dev = encoder->dev; | ||
| 38 | struct radeon_device *rdev = dev->dev_private; | ||
| 39 | struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder); | ||
| 40 | int xres = mode->hdisplay; | ||
| 41 | int yres = mode->vdisplay; | ||
| 42 | bool hscale = true, vscale = true; | ||
| 43 | int hsync_wid; | ||
| 44 | int vsync_wid; | ||
| 45 | int hsync_start; | ||
| 46 | uint32_t scale, inc; | ||
| 47 | uint32_t fp_horz_stretch, fp_vert_stretch, crtc_more_cntl, fp_horz_vert_active; | ||
| 48 | uint32_t fp_h_sync_strt_wid, fp_v_sync_strt_wid, fp_crtc_h_total_disp, fp_crtc_v_total_disp; | ||
| 49 | struct radeon_native_mode *native_mode = &radeon_encoder->native_mode; | ||
| 50 | |||
| 51 | DRM_DEBUG("\n"); | ||
| 52 | |||
| 53 | fp_vert_stretch = RREG32(RADEON_FP_VERT_STRETCH) & | ||
| 54 | (RADEON_VERT_STRETCH_RESERVED | | ||
| 55 | RADEON_VERT_AUTO_RATIO_INC); | ||
| 56 | fp_horz_stretch = RREG32(RADEON_FP_HORZ_STRETCH) & | ||
| 57 | (RADEON_HORZ_FP_LOOP_STRETCH | | ||
| 58 | RADEON_HORZ_AUTO_RATIO_INC); | ||
| 59 | |||
| 60 | crtc_more_cntl = 0; | ||
| 61 | if ((rdev->family == CHIP_RS100) || | ||
| 62 | (rdev->family == CHIP_RS200)) { | ||
| 63 | /* This is to workaround the asic bug for RMX, some versions | ||
| 64 | of BIOS dosen't have this register initialized correctly. */ | ||
| 65 | crtc_more_cntl |= RADEON_CRTC_H_CUTOFF_ACTIVE_EN; | ||
| 66 | } | ||
| 67 | |||
| 68 | |||
| 69 | fp_crtc_h_total_disp = ((((mode->crtc_htotal / 8) - 1) & 0x3ff) | ||
| 70 | | ((((mode->crtc_hdisplay / 8) - 1) & 0x1ff) << 16)); | ||
| 71 | |||
| 72 | hsync_wid = (mode->crtc_hsync_end - mode->crtc_hsync_start) / 8; | ||
| 73 | if (!hsync_wid) | ||
| 74 | hsync_wid = 1; | ||
| 75 | hsync_start = mode->crtc_hsync_start - 8; | ||
| 76 | |||
| 77 | fp_h_sync_strt_wid = ((hsync_start & 0x1fff) | ||
| 78 | | ((hsync_wid & 0x3f) << 16) | ||
| 79 | | ((mode->flags & DRM_MODE_FLAG_NHSYNC) | ||
| 80 | ? RADEON_CRTC_H_SYNC_POL | ||
| 81 | : 0)); | ||
| 82 | |||
| 83 | fp_crtc_v_total_disp = (((mode->crtc_vtotal - 1) & 0xffff) | ||
| 84 | | ((mode->crtc_vdisplay - 1) << 16)); | ||
| 85 | |||
| 86 | vsync_wid = mode->crtc_vsync_end - mode->crtc_vsync_start; | ||
| 87 | if (!vsync_wid) | ||
| 88 | vsync_wid = 1; | ||
| 89 | |||
| 90 | fp_v_sync_strt_wid = (((mode->crtc_vsync_start - 1) & 0xfff) | ||
| 91 | | ((vsync_wid & 0x1f) << 16) | ||
| 92 | | ((mode->flags & DRM_MODE_FLAG_NVSYNC) | ||
| 93 | ? RADEON_CRTC_V_SYNC_POL | ||
| 94 | : 0)); | ||
| 95 | |||
| 96 | fp_horz_vert_active = 0; | ||
| 97 | |||
| 98 | if (native_mode->panel_xres == 0 || | ||
| 99 | native_mode->panel_yres == 0) { | ||
| 100 | hscale = false; | ||
| 101 | vscale = false; | ||
| 102 | } else { | ||
| 103 | if (xres > native_mode->panel_xres) | ||
| 104 | xres = native_mode->panel_xres; | ||
| 105 | if (yres > native_mode->panel_yres) | ||
| 106 | yres = native_mode->panel_yres; | ||
| 107 | |||
| 108 | if (xres == native_mode->panel_xres) | ||
| 109 | hscale = false; | ||
| 110 | if (yres == native_mode->panel_yres) | ||
| 111 | vscale = false; | ||
| 112 | } | ||
| 113 | |||
| 114 | if (radeon_encoder->flags & RADEON_USE_RMX) { | ||
| 115 | if (radeon_encoder->rmx_type != RMX_CENTER) { | ||
| 116 | if (!hscale) | ||
| 117 | fp_horz_stretch |= ((xres/8-1) << 16); | ||
| 118 | else { | ||
| 119 | inc = (fp_horz_stretch & RADEON_HORZ_AUTO_RATIO_INC) ? 1 : 0; | ||
| 120 | scale = ((xres + inc) * RADEON_HORZ_STRETCH_RATIO_MAX) | ||
| 121 | / native_mode->panel_xres + 1; | ||
| 122 | fp_horz_stretch |= (((scale) & RADEON_HORZ_STRETCH_RATIO_MASK) | | ||
| 123 | RADEON_HORZ_STRETCH_BLEND | | ||
| 124 | RADEON_HORZ_STRETCH_ENABLE | | ||
| 125 | ((native_mode->panel_xres/8-1) << 16)); | ||
| 126 | } | ||
| 127 | |||
| 128 | if (!vscale) | ||
| 129 | fp_vert_stretch |= ((yres-1) << 12); | ||
| 130 | else { | ||
| 131 | inc = (fp_vert_stretch & RADEON_VERT_AUTO_RATIO_INC) ? 1 : 0; | ||
| 132 | scale = ((yres + inc) * RADEON_VERT_STRETCH_RATIO_MAX) | ||
| 133 | / native_mode->panel_yres + 1; | ||
| 134 | fp_vert_stretch |= (((scale) & RADEON_VERT_STRETCH_RATIO_MASK) | | ||
| 135 | RADEON_VERT_STRETCH_ENABLE | | ||
| 136 | RADEON_VERT_STRETCH_BLEND | | ||
| 137 | ((native_mode->panel_yres-1) << 12)); | ||
| 138 | } | ||
| 139 | } else if (radeon_encoder->rmx_type == RMX_CENTER) { | ||
| 140 | int blank_width; | ||
| 141 | |||
| 142 | fp_horz_stretch |= ((xres/8-1) << 16); | ||
| 143 | fp_vert_stretch |= ((yres-1) << 12); | ||
| 144 | |||
| 145 | crtc_more_cntl |= (RADEON_CRTC_AUTO_HORZ_CENTER_EN | | ||
| 146 | RADEON_CRTC_AUTO_VERT_CENTER_EN); | ||
| 147 | |||
| 148 | blank_width = (mode->crtc_hblank_end - mode->crtc_hblank_start) / 8; | ||
| 149 | if (blank_width > 110) | ||
| 150 | blank_width = 110; | ||
| 151 | |||
| 152 | fp_crtc_h_total_disp = (((blank_width) & 0x3ff) | ||
| 153 | | ((((mode->crtc_hdisplay / 8) - 1) & 0x1ff) << 16)); | ||
| 154 | |||
| 155 | hsync_wid = (mode->crtc_hsync_end - mode->crtc_hsync_start) / 8; | ||
| 156 | if (!hsync_wid) | ||
| 157 | hsync_wid = 1; | ||
| 158 | |||
| 159 | fp_h_sync_strt_wid = ((((mode->crtc_hsync_start - mode->crtc_hblank_start) / 8) & 0x1fff) | ||
| 160 | | ((hsync_wid & 0x3f) << 16) | ||
| 161 | | ((mode->flags & DRM_MODE_FLAG_NHSYNC) | ||
| 162 | ? RADEON_CRTC_H_SYNC_POL | ||
| 163 | : 0)); | ||
| 164 | |||
| 165 | fp_crtc_v_total_disp = (((mode->crtc_vblank_end - mode->crtc_vblank_start) & 0xffff) | ||
| 166 | | ((mode->crtc_vdisplay - 1) << 16)); | ||
| 167 | |||
| 168 | vsync_wid = mode->crtc_vsync_end - mode->crtc_vsync_start; | ||
| 169 | if (!vsync_wid) | ||
| 170 | vsync_wid = 1; | ||
| 171 | |||
| 172 | fp_v_sync_strt_wid = ((((mode->crtc_vsync_start - mode->crtc_vblank_start) & 0xfff) | ||
| 173 | | ((vsync_wid & 0x1f) << 16) | ||
| 174 | | ((mode->flags & DRM_MODE_FLAG_NVSYNC) | ||
| 175 | ? RADEON_CRTC_V_SYNC_POL | ||
| 176 | : 0))); | ||
| 177 | |||
| 178 | fp_horz_vert_active = (((native_mode->panel_yres) & 0xfff) | | ||
| 179 | (((native_mode->panel_xres / 8) & 0x1ff) << 16)); | ||
| 180 | } | ||
| 181 | } else { | ||
| 182 | fp_horz_stretch |= ((xres/8-1) << 16); | ||
| 183 | fp_vert_stretch |= ((yres-1) << 12); | ||
| 184 | } | ||
| 185 | |||
| 186 | WREG32(RADEON_FP_HORZ_STRETCH, fp_horz_stretch); | ||
| 187 | WREG32(RADEON_FP_VERT_STRETCH, fp_vert_stretch); | ||
| 188 | WREG32(RADEON_CRTC_MORE_CNTL, crtc_more_cntl); | ||
| 189 | WREG32(RADEON_FP_HORZ_VERT_ACTIVE, fp_horz_vert_active); | ||
| 190 | WREG32(RADEON_FP_H_SYNC_STRT_WID, fp_h_sync_strt_wid); | ||
| 191 | WREG32(RADEON_FP_V_SYNC_STRT_WID, fp_v_sync_strt_wid); | ||
| 192 | WREG32(RADEON_FP_CRTC_H_TOTAL_DISP, fp_crtc_h_total_disp); | ||
| 193 | WREG32(RADEON_FP_CRTC_V_TOTAL_DISP, fp_crtc_v_total_disp); | ||
| 194 | |||
| 195 | } | ||
| 196 | |||
| 197 | static void radeon_legacy_lvds_dpms(struct drm_encoder *encoder, int mode) | 33 | static void radeon_legacy_lvds_dpms(struct drm_encoder *encoder, int mode) |
| 198 | { | 34 | { |
| 199 | struct drm_device *dev = encoder->dev; | 35 | struct drm_device *dev = encoder->dev; |
| @@ -287,9 +123,6 @@ static void radeon_legacy_lvds_mode_set(struct drm_encoder *encoder, | |||
| 287 | 123 | ||
| 288 | DRM_DEBUG("\n"); | 124 | DRM_DEBUG("\n"); |
| 289 | 125 | ||
| 290 | if (radeon_crtc->crtc_id == 0) | ||
| 291 | radeon_legacy_rmx_mode_set(encoder, mode, adjusted_mode); | ||
| 292 | |||
| 293 | lvds_pll_cntl = RREG32(RADEON_LVDS_PLL_CNTL); | 126 | lvds_pll_cntl = RREG32(RADEON_LVDS_PLL_CNTL); |
| 294 | lvds_pll_cntl &= ~RADEON_LVDS_PLL_EN; | 127 | lvds_pll_cntl &= ~RADEON_LVDS_PLL_EN; |
| 295 | 128 | ||
| @@ -318,7 +151,7 @@ static void radeon_legacy_lvds_mode_set(struct drm_encoder *encoder, | |||
| 318 | 151 | ||
| 319 | if (radeon_crtc->crtc_id == 0) { | 152 | if (radeon_crtc->crtc_id == 0) { |
| 320 | if (ASIC_IS_R300(rdev)) { | 153 | if (ASIC_IS_R300(rdev)) { |
| 321 | if (radeon_encoder->flags & RADEON_USE_RMX) | 154 | if (radeon_encoder->rmx_type != RMX_OFF) |
| 322 | lvds_pll_cntl |= R300_LVDS_SRC_SEL_RMX; | 155 | lvds_pll_cntl |= R300_LVDS_SRC_SEL_RMX; |
| 323 | } else | 156 | } else |
| 324 | lvds_gen_cntl &= ~RADEON_LVDS_SEL_CRTC2; | 157 | lvds_gen_cntl &= ~RADEON_LVDS_SEL_CRTC2; |
| @@ -350,8 +183,6 @@ static bool radeon_legacy_lvds_mode_fixup(struct drm_encoder *encoder, | |||
| 350 | 183 | ||
| 351 | drm_mode_set_crtcinfo(adjusted_mode, 0); | 184 | drm_mode_set_crtcinfo(adjusted_mode, 0); |
| 352 | 185 | ||
| 353 | radeon_encoder->flags &= ~RADEON_USE_RMX; | ||
| 354 | |||
| 355 | if (radeon_encoder->rmx_type != RMX_OFF) | 186 | if (radeon_encoder->rmx_type != RMX_OFF) |
| 356 | radeon_rmx_mode_fixup(encoder, mode, adjusted_mode); | 187 | radeon_rmx_mode_fixup(encoder, mode, adjusted_mode); |
| 357 | 188 | ||
| @@ -455,9 +286,6 @@ static void radeon_legacy_primary_dac_mode_set(struct drm_encoder *encoder, | |||
| 455 | 286 | ||
| 456 | DRM_DEBUG("\n"); | 287 | DRM_DEBUG("\n"); |
| 457 | 288 | ||
| 458 | if (radeon_crtc->crtc_id == 0) | ||
| 459 | radeon_legacy_rmx_mode_set(encoder, mode, adjusted_mode); | ||
| 460 | |||
| 461 | if (radeon_crtc->crtc_id == 0) { | 289 | if (radeon_crtc->crtc_id == 0) { |
| 462 | if (rdev->family == CHIP_R200 || ASIC_IS_R300(rdev)) { | 290 | if (rdev->family == CHIP_R200 || ASIC_IS_R300(rdev)) { |
| 463 | disp_output_cntl = RREG32(RADEON_DISP_OUTPUT_CNTL) & | 291 | disp_output_cntl = RREG32(RADEON_DISP_OUTPUT_CNTL) & |
| @@ -653,9 +481,6 @@ static void radeon_legacy_tmds_int_mode_set(struct drm_encoder *encoder, | |||
| 653 | 481 | ||
| 654 | DRM_DEBUG("\n"); | 482 | DRM_DEBUG("\n"); |
| 655 | 483 | ||
| 656 | if (radeon_crtc->crtc_id == 0) | ||
| 657 | radeon_legacy_rmx_mode_set(encoder, mode, adjusted_mode); | ||
| 658 | |||
| 659 | tmp = tmds_pll_cntl = RREG32(RADEON_TMDS_PLL_CNTL); | 484 | tmp = tmds_pll_cntl = RREG32(RADEON_TMDS_PLL_CNTL); |
| 660 | tmp &= 0xfffff; | 485 | tmp &= 0xfffff; |
| 661 | if (rdev->family == CHIP_RV280) { | 486 | if (rdev->family == CHIP_RV280) { |
| @@ -711,7 +536,7 @@ static void radeon_legacy_tmds_int_mode_set(struct drm_encoder *encoder, | |||
| 711 | if (radeon_crtc->crtc_id == 0) { | 536 | if (radeon_crtc->crtc_id == 0) { |
| 712 | if (ASIC_IS_R300(rdev) || rdev->family == CHIP_R200) { | 537 | if (ASIC_IS_R300(rdev) || rdev->family == CHIP_R200) { |
| 713 | fp_gen_cntl &= ~R200_FP_SOURCE_SEL_MASK; | 538 | fp_gen_cntl &= ~R200_FP_SOURCE_SEL_MASK; |
| 714 | if (radeon_encoder->flags & RADEON_USE_RMX) | 539 | if (radeon_encoder->rmx_type != RMX_OFF) |
| 715 | fp_gen_cntl |= R200_FP_SOURCE_SEL_RMX; | 540 | fp_gen_cntl |= R200_FP_SOURCE_SEL_RMX; |
| 716 | else | 541 | else |
| 717 | fp_gen_cntl |= R200_FP_SOURCE_SEL_CRTC1; | 542 | fp_gen_cntl |= R200_FP_SOURCE_SEL_CRTC1; |
| @@ -820,9 +645,6 @@ static void radeon_legacy_tmds_ext_mode_set(struct drm_encoder *encoder, | |||
| 820 | 645 | ||
| 821 | DRM_DEBUG("\n"); | 646 | DRM_DEBUG("\n"); |
| 822 | 647 | ||
| 823 | if (radeon_crtc->crtc_id == 0) | ||
| 824 | radeon_legacy_rmx_mode_set(encoder, mode, adjusted_mode); | ||
| 825 | |||
| 826 | if (rdev->is_atom_bios) { | 648 | if (rdev->is_atom_bios) { |
| 827 | radeon_encoder->pixel_clock = adjusted_mode->clock; | 649 | radeon_encoder->pixel_clock = adjusted_mode->clock; |
| 828 | atombios_external_tmds_setup(encoder, ATOM_ENABLE); | 650 | atombios_external_tmds_setup(encoder, ATOM_ENABLE); |
| @@ -856,7 +678,7 @@ static void radeon_legacy_tmds_ext_mode_set(struct drm_encoder *encoder, | |||
| 856 | if (radeon_crtc->crtc_id == 0) { | 678 | if (radeon_crtc->crtc_id == 0) { |
| 857 | if ((rdev->family == CHIP_R200) || ASIC_IS_R300(rdev)) { | 679 | if ((rdev->family == CHIP_R200) || ASIC_IS_R300(rdev)) { |
| 858 | fp2_gen_cntl &= ~R200_FP2_SOURCE_SEL_MASK; | 680 | fp2_gen_cntl &= ~R200_FP2_SOURCE_SEL_MASK; |
| 859 | if (radeon_encoder->flags & RADEON_USE_RMX) | 681 | if (radeon_encoder->rmx_type != RMX_OFF) |
| 860 | fp2_gen_cntl |= R200_FP2_SOURCE_SEL_RMX; | 682 | fp2_gen_cntl |= R200_FP2_SOURCE_SEL_RMX; |
| 861 | else | 683 | else |
| 862 | fp2_gen_cntl |= R200_FP2_SOURCE_SEL_CRTC1; | 684 | fp2_gen_cntl |= R200_FP2_SOURCE_SEL_CRTC1; |
| @@ -1014,9 +836,6 @@ static void radeon_legacy_tv_dac_mode_set(struct drm_encoder *encoder, | |||
| 1014 | 836 | ||
| 1015 | DRM_DEBUG("\n"); | 837 | DRM_DEBUG("\n"); |
| 1016 | 838 | ||
| 1017 | if (radeon_crtc->crtc_id == 0) | ||
| 1018 | radeon_legacy_rmx_mode_set(encoder, mode, adjusted_mode); | ||
| 1019 | |||
| 1020 | if (rdev->family != CHIP_R200) { | 839 | if (rdev->family != CHIP_R200) { |
| 1021 | tv_dac_cntl = RREG32(RADEON_TV_DAC_CNTL); | 840 | tv_dac_cntl = RREG32(RADEON_TV_DAC_CNTL); |
| 1022 | if (rdev->family == CHIP_R420 || | 841 | if (rdev->family == CHIP_R420 || |
| @@ -1243,9 +1062,11 @@ radeon_add_legacy_encoder(struct drm_device *dev, uint32_t encoder_id, uint32_t | |||
| 1243 | 1062 | ||
| 1244 | radeon_encoder->encoder_id = encoder_id; | 1063 | radeon_encoder->encoder_id = encoder_id; |
| 1245 | radeon_encoder->devices = supported_device; | 1064 | radeon_encoder->devices = supported_device; |
| 1065 | radeon_encoder->rmx_type = RMX_OFF; | ||
| 1246 | 1066 | ||
| 1247 | switch (radeon_encoder->encoder_id) { | 1067 | switch (radeon_encoder->encoder_id) { |
| 1248 | case ENCODER_OBJECT_ID_INTERNAL_LVDS: | 1068 | case ENCODER_OBJECT_ID_INTERNAL_LVDS: |
| 1069 | encoder->possible_crtcs = 0x1; | ||
| 1249 | drm_encoder_init(dev, encoder, &radeon_legacy_lvds_enc_funcs, DRM_MODE_ENCODER_LVDS); | 1070 | drm_encoder_init(dev, encoder, &radeon_legacy_lvds_enc_funcs, DRM_MODE_ENCODER_LVDS); |
| 1250 | drm_encoder_helper_add(encoder, &radeon_legacy_lvds_helper_funcs); | 1071 | drm_encoder_helper_add(encoder, &radeon_legacy_lvds_helper_funcs); |
| 1251 | if (rdev->is_atom_bios) | 1072 | if (rdev->is_atom_bios) |
diff --git a/drivers/gpu/drm/radeon/radeon_mode.h b/drivers/gpu/drm/radeon/radeon_mode.h index 9173b687462b..3b09a1f2d8f9 100644 --- a/drivers/gpu/drm/radeon/radeon_mode.h +++ b/drivers/gpu/drm/radeon/radeon_mode.h | |||
| @@ -36,6 +36,9 @@ | |||
| 36 | #include <linux/i2c.h> | 36 | #include <linux/i2c.h> |
| 37 | #include <linux/i2c-id.h> | 37 | #include <linux/i2c-id.h> |
| 38 | #include <linux/i2c-algo-bit.h> | 38 | #include <linux/i2c-algo-bit.h> |
| 39 | #include "radeon_fixed.h" | ||
| 40 | |||
| 41 | struct radeon_device; | ||
| 39 | 42 | ||
| 40 | #define to_radeon_crtc(x) container_of(x, struct radeon_crtc, base) | 43 | #define to_radeon_crtc(x) container_of(x, struct radeon_crtc, base) |
| 41 | #define to_radeon_connector(x) container_of(x, struct radeon_connector, base) | 44 | #define to_radeon_connector(x) container_of(x, struct radeon_connector, base) |
| @@ -124,6 +127,7 @@ struct radeon_tmds_pll { | |||
| 124 | #define RADEON_PLL_PREFER_LOW_POST_DIV (1 << 8) | 127 | #define RADEON_PLL_PREFER_LOW_POST_DIV (1 << 8) |
| 125 | #define RADEON_PLL_PREFER_HIGH_POST_DIV (1 << 9) | 128 | #define RADEON_PLL_PREFER_HIGH_POST_DIV (1 << 9) |
| 126 | #define RADEON_PLL_USE_FRAC_FB_DIV (1 << 10) | 129 | #define RADEON_PLL_USE_FRAC_FB_DIV (1 << 10) |
| 130 | #define RADEON_PLL_PREFER_CLOSEST_LOWER (1 << 11) | ||
| 127 | 131 | ||
| 128 | struct radeon_pll { | 132 | struct radeon_pll { |
| 129 | uint16_t reference_freq; | 133 | uint16_t reference_freq; |
| @@ -170,6 +174,18 @@ struct radeon_mode_info { | |||
| 170 | struct atom_context *atom_context; | 174 | struct atom_context *atom_context; |
| 171 | enum radeon_connector_table connector_table; | 175 | enum radeon_connector_table connector_table; |
| 172 | bool mode_config_initialized; | 176 | bool mode_config_initialized; |
| 177 | struct radeon_crtc *crtcs[2]; | ||
| 178 | }; | ||
| 179 | |||
| 180 | struct radeon_native_mode { | ||
| 181 | /* preferred mode */ | ||
| 182 | uint32_t panel_xres, panel_yres; | ||
| 183 | uint32_t hoverplus, hsync_width; | ||
| 184 | uint32_t hblank; | ||
| 185 | uint32_t voverplus, vsync_width; | ||
| 186 | uint32_t vblank; | ||
| 187 | uint32_t dotclock; | ||
| 188 | uint32_t flags; | ||
| 173 | }; | 189 | }; |
| 174 | 190 | ||
| 175 | struct radeon_crtc { | 191 | struct radeon_crtc { |
| @@ -185,19 +201,13 @@ struct radeon_crtc { | |||
| 185 | uint64_t cursor_addr; | 201 | uint64_t cursor_addr; |
| 186 | int cursor_width; | 202 | int cursor_width; |
| 187 | int cursor_height; | 203 | int cursor_height; |
| 188 | }; | 204 | uint32_t legacy_display_base_addr; |
| 189 | 205 | uint32_t legacy_cursor_offset; | |
| 190 | #define RADEON_USE_RMX 1 | 206 | enum radeon_rmx_type rmx_type; |
| 191 | 207 | uint32_t devices; | |
| 192 | struct radeon_native_mode { | 208 | fixed20_12 vsc; |
| 193 | /* preferred mode */ | 209 | fixed20_12 hsc; |
| 194 | uint32_t panel_xres, panel_yres; | 210 | struct radeon_native_mode native_mode; |
| 195 | uint32_t hoverplus, hsync_width; | ||
| 196 | uint32_t hblank; | ||
| 197 | uint32_t voverplus, vsync_width; | ||
| 198 | uint32_t vblank; | ||
| 199 | uint32_t dotclock; | ||
| 200 | uint32_t flags; | ||
| 201 | }; | 211 | }; |
| 202 | 212 | ||
| 203 | struct radeon_encoder_primary_dac { | 213 | struct radeon_encoder_primary_dac { |
| @@ -383,16 +393,9 @@ void radeon_enc_destroy(struct drm_encoder *encoder); | |||
| 383 | void radeon_copy_fb(struct drm_device *dev, struct drm_gem_object *dst_obj); | 393 | void radeon_copy_fb(struct drm_device *dev, struct drm_gem_object *dst_obj); |
| 384 | void radeon_combios_asic_init(struct drm_device *dev); | 394 | void radeon_combios_asic_init(struct drm_device *dev); |
| 385 | extern int radeon_static_clocks_init(struct drm_device *dev); | 395 | extern int radeon_static_clocks_init(struct drm_device *dev); |
| 386 | void radeon_init_disp_bw_legacy(struct drm_device *dev, | 396 | bool radeon_crtc_scaling_mode_fixup(struct drm_crtc *crtc, |
| 387 | struct drm_display_mode *mode1, | 397 | struct drm_display_mode *mode, |
| 388 | uint32_t pixel_bytes1, | 398 | struct drm_display_mode *adjusted_mode); |
| 389 | struct drm_display_mode *mode2, | 399 | void atom_rv515_force_tv_scaler(struct radeon_device *rdev); |
| 390 | uint32_t pixel_bytes2); | ||
| 391 | void radeon_init_disp_bw_avivo(struct drm_device *dev, | ||
| 392 | struct drm_display_mode *mode1, | ||
| 393 | uint32_t pixel_bytes1, | ||
| 394 | struct drm_display_mode *mode2, | ||
| 395 | uint32_t pixel_bytes2); | ||
| 396 | void radeon_init_disp_bandwidth(struct drm_device *dev); | ||
| 397 | 400 | ||
| 398 | #endif | 401 | #endif |
diff --git a/drivers/gpu/drm/radeon/radeon_object.c b/drivers/gpu/drm/radeon/radeon_object.c index bac0d06c52ac..b85fb83d7ae8 100644 --- a/drivers/gpu/drm/radeon/radeon_object.c +++ b/drivers/gpu/drm/radeon/radeon_object.c | |||
| @@ -44,6 +44,9 @@ struct radeon_object { | |||
| 44 | uint64_t gpu_addr; | 44 | uint64_t gpu_addr; |
| 45 | void *kptr; | 45 | void *kptr; |
| 46 | bool is_iomem; | 46 | bool is_iomem; |
| 47 | uint32_t tiling_flags; | ||
| 48 | uint32_t pitch; | ||
| 49 | int surface_reg; | ||
| 47 | }; | 50 | }; |
| 48 | 51 | ||
| 49 | int radeon_ttm_init(struct radeon_device *rdev); | 52 | int radeon_ttm_init(struct radeon_device *rdev); |
| @@ -70,6 +73,7 @@ static void radeon_ttm_object_object_destroy(struct ttm_buffer_object *tobj) | |||
| 70 | 73 | ||
| 71 | robj = container_of(tobj, struct radeon_object, tobj); | 74 | robj = container_of(tobj, struct radeon_object, tobj); |
| 72 | list_del_init(&robj->list); | 75 | list_del_init(&robj->list); |
| 76 | radeon_object_clear_surface_reg(robj); | ||
| 73 | kfree(robj); | 77 | kfree(robj); |
| 74 | } | 78 | } |
| 75 | 79 | ||
| @@ -99,16 +103,16 @@ static inline uint32_t radeon_object_flags_from_domain(uint32_t domain) | |||
| 99 | { | 103 | { |
| 100 | uint32_t flags = 0; | 104 | uint32_t flags = 0; |
| 101 | if (domain & RADEON_GEM_DOMAIN_VRAM) { | 105 | if (domain & RADEON_GEM_DOMAIN_VRAM) { |
| 102 | flags |= TTM_PL_FLAG_VRAM; | 106 | flags |= TTM_PL_FLAG_VRAM | TTM_PL_FLAG_WC | TTM_PL_FLAG_UNCACHED; |
| 103 | } | 107 | } |
| 104 | if (domain & RADEON_GEM_DOMAIN_GTT) { | 108 | if (domain & RADEON_GEM_DOMAIN_GTT) { |
| 105 | flags |= TTM_PL_FLAG_TT; | 109 | flags |= TTM_PL_FLAG_TT | TTM_PL_MASK_CACHING; |
| 106 | } | 110 | } |
| 107 | if (domain & RADEON_GEM_DOMAIN_CPU) { | 111 | if (domain & RADEON_GEM_DOMAIN_CPU) { |
| 108 | flags |= TTM_PL_FLAG_SYSTEM; | 112 | flags |= TTM_PL_FLAG_SYSTEM | TTM_PL_MASK_CACHING; |
| 109 | } | 113 | } |
| 110 | if (!flags) { | 114 | if (!flags) { |
| 111 | flags |= TTM_PL_FLAG_SYSTEM; | 115 | flags |= TTM_PL_FLAG_SYSTEM | TTM_PL_MASK_CACHING; |
| 112 | } | 116 | } |
| 113 | return flags; | 117 | return flags; |
| 114 | } | 118 | } |
| @@ -141,6 +145,7 @@ int radeon_object_create(struct radeon_device *rdev, | |||
| 141 | } | 145 | } |
| 142 | robj->rdev = rdev; | 146 | robj->rdev = rdev; |
| 143 | robj->gobj = gobj; | 147 | robj->gobj = gobj; |
| 148 | robj->surface_reg = -1; | ||
| 144 | INIT_LIST_HEAD(&robj->list); | 149 | INIT_LIST_HEAD(&robj->list); |
| 145 | 150 | ||
| 146 | flags = radeon_object_flags_from_domain(domain); | 151 | flags = radeon_object_flags_from_domain(domain); |
| @@ -304,7 +309,26 @@ int radeon_object_wait(struct radeon_object *robj) | |||
| 304 | } | 309 | } |
| 305 | spin_lock(&robj->tobj.lock); | 310 | spin_lock(&robj->tobj.lock); |
| 306 | if (robj->tobj.sync_obj) { | 311 | if (robj->tobj.sync_obj) { |
| 307 | r = ttm_bo_wait(&robj->tobj, true, false, false); | 312 | r = ttm_bo_wait(&robj->tobj, true, true, false); |
| 313 | } | ||
| 314 | spin_unlock(&robj->tobj.lock); | ||
| 315 | radeon_object_unreserve(robj); | ||
| 316 | return r; | ||
| 317 | } | ||
| 318 | |||
| 319 | int radeon_object_busy_domain(struct radeon_object *robj, uint32_t *cur_placement) | ||
| 320 | { | ||
| 321 | int r = 0; | ||
| 322 | |||
| 323 | r = radeon_object_reserve(robj, true); | ||
| 324 | if (unlikely(r != 0)) { | ||
| 325 | DRM_ERROR("radeon: failed to reserve object for waiting.\n"); | ||
| 326 | return r; | ||
| 327 | } | ||
| 328 | spin_lock(&robj->tobj.lock); | ||
| 329 | *cur_placement = robj->tobj.mem.mem_type; | ||
| 330 | if (robj->tobj.sync_obj) { | ||
| 331 | r = ttm_bo_wait(&robj->tobj, true, true, true); | ||
| 308 | } | 332 | } |
| 309 | spin_unlock(&robj->tobj.lock); | 333 | spin_unlock(&robj->tobj.lock); |
| 310 | radeon_object_unreserve(robj); | 334 | radeon_object_unreserve(robj); |
| @@ -403,7 +427,6 @@ int radeon_object_list_validate(struct list_head *head, void *fence) | |||
| 403 | struct radeon_object *robj; | 427 | struct radeon_object *robj; |
| 404 | struct radeon_fence *old_fence = NULL; | 428 | struct radeon_fence *old_fence = NULL; |
| 405 | struct list_head *i; | 429 | struct list_head *i; |
| 406 | uint32_t flags; | ||
| 407 | int r; | 430 | int r; |
| 408 | 431 | ||
| 409 | r = radeon_object_list_reserve(head); | 432 | r = radeon_object_list_reserve(head); |
| @@ -414,27 +437,25 @@ int radeon_object_list_validate(struct list_head *head, void *fence) | |||
| 414 | list_for_each(i, head) { | 437 | list_for_each(i, head) { |
| 415 | lobj = list_entry(i, struct radeon_object_list, list); | 438 | lobj = list_entry(i, struct radeon_object_list, list); |
| 416 | robj = lobj->robj; | 439 | robj = lobj->robj; |
| 417 | if (lobj->wdomain) { | ||
| 418 | flags = radeon_object_flags_from_domain(lobj->wdomain); | ||
| 419 | flags |= TTM_PL_FLAG_TT; | ||
| 420 | } else { | ||
| 421 | flags = radeon_object_flags_from_domain(lobj->rdomain); | ||
| 422 | flags |= TTM_PL_FLAG_TT; | ||
| 423 | flags |= TTM_PL_FLAG_VRAM; | ||
| 424 | } | ||
| 425 | if (!robj->pin_count) { | 440 | if (!robj->pin_count) { |
| 426 | robj->tobj.proposed_placement = flags | TTM_PL_MASK_CACHING; | 441 | if (lobj->wdomain) { |
| 442 | robj->tobj.proposed_placement = | ||
| 443 | radeon_object_flags_from_domain(lobj->wdomain); | ||
| 444 | } else { | ||
| 445 | robj->tobj.proposed_placement = | ||
| 446 | radeon_object_flags_from_domain(lobj->rdomain); | ||
| 447 | } | ||
| 427 | r = ttm_buffer_object_validate(&robj->tobj, | 448 | r = ttm_buffer_object_validate(&robj->tobj, |
| 428 | robj->tobj.proposed_placement, | 449 | robj->tobj.proposed_placement, |
| 429 | true, false); | 450 | true, false); |
| 430 | if (unlikely(r)) { | 451 | if (unlikely(r)) { |
| 431 | radeon_object_list_unreserve(head); | ||
| 432 | DRM_ERROR("radeon: failed to validate.\n"); | 452 | DRM_ERROR("radeon: failed to validate.\n"); |
| 433 | return r; | 453 | return r; |
| 434 | } | 454 | } |
| 435 | radeon_object_gpu_addr(robj); | 455 | radeon_object_gpu_addr(robj); |
| 436 | } | 456 | } |
| 437 | lobj->gpu_offset = robj->gpu_addr; | 457 | lobj->gpu_offset = robj->gpu_addr; |
| 458 | lobj->tiling_flags = robj->tiling_flags; | ||
| 438 | if (fence) { | 459 | if (fence) { |
| 439 | old_fence = (struct radeon_fence *)robj->tobj.sync_obj; | 460 | old_fence = (struct radeon_fence *)robj->tobj.sync_obj; |
| 440 | robj->tobj.sync_obj = radeon_fence_ref(fence); | 461 | robj->tobj.sync_obj = radeon_fence_ref(fence); |
| @@ -479,3 +500,127 @@ unsigned long radeon_object_size(struct radeon_object *robj) | |||
| 479 | { | 500 | { |
| 480 | return robj->tobj.num_pages << PAGE_SHIFT; | 501 | return robj->tobj.num_pages << PAGE_SHIFT; |
| 481 | } | 502 | } |
| 503 | |||
| 504 | int radeon_object_get_surface_reg(struct radeon_object *robj) | ||
| 505 | { | ||
| 506 | struct radeon_device *rdev = robj->rdev; | ||
| 507 | struct radeon_surface_reg *reg; | ||
| 508 | struct radeon_object *old_object; | ||
| 509 | int steal; | ||
| 510 | int i; | ||
| 511 | |||
| 512 | if (!robj->tiling_flags) | ||
| 513 | return 0; | ||
| 514 | |||
| 515 | if (robj->surface_reg >= 0) { | ||
| 516 | reg = &rdev->surface_regs[robj->surface_reg]; | ||
| 517 | i = robj->surface_reg; | ||
| 518 | goto out; | ||
| 519 | } | ||
| 520 | |||
| 521 | steal = -1; | ||
| 522 | for (i = 0; i < RADEON_GEM_MAX_SURFACES; i++) { | ||
| 523 | |||
| 524 | reg = &rdev->surface_regs[i]; | ||
| 525 | if (!reg->robj) | ||
| 526 | break; | ||
| 527 | |||
| 528 | old_object = reg->robj; | ||
| 529 | if (old_object->pin_count == 0) | ||
| 530 | steal = i; | ||
| 531 | } | ||
| 532 | |||
| 533 | /* if we are all out */ | ||
| 534 | if (i == RADEON_GEM_MAX_SURFACES) { | ||
| 535 | if (steal == -1) | ||
| 536 | return -ENOMEM; | ||
| 537 | /* find someone with a surface reg and nuke their BO */ | ||
| 538 | reg = &rdev->surface_regs[steal]; | ||
| 539 | old_object = reg->robj; | ||
| 540 | /* blow away the mapping */ | ||
| 541 | DRM_DEBUG("stealing surface reg %d from %p\n", steal, old_object); | ||
| 542 | ttm_bo_unmap_virtual(&old_object->tobj); | ||
| 543 | old_object->surface_reg = -1; | ||
| 544 | i = steal; | ||
| 545 | } | ||
| 546 | |||
| 547 | robj->surface_reg = i; | ||
| 548 | reg->robj = robj; | ||
| 549 | |||
| 550 | out: | ||
| 551 | radeon_set_surface_reg(rdev, i, robj->tiling_flags, robj->pitch, | ||
| 552 | robj->tobj.mem.mm_node->start << PAGE_SHIFT, | ||
| 553 | robj->tobj.num_pages << PAGE_SHIFT); | ||
| 554 | return 0; | ||
| 555 | } | ||
| 556 | |||
| 557 | void radeon_object_clear_surface_reg(struct radeon_object *robj) | ||
| 558 | { | ||
| 559 | struct radeon_device *rdev = robj->rdev; | ||
| 560 | struct radeon_surface_reg *reg; | ||
| 561 | |||
| 562 | if (robj->surface_reg == -1) | ||
| 563 | return; | ||
| 564 | |||
| 565 | reg = &rdev->surface_regs[robj->surface_reg]; | ||
| 566 | radeon_clear_surface_reg(rdev, robj->surface_reg); | ||
| 567 | |||
| 568 | reg->robj = NULL; | ||
| 569 | robj->surface_reg = -1; | ||
| 570 | } | ||
| 571 | |||
| 572 | void radeon_object_set_tiling_flags(struct radeon_object *robj, | ||
| 573 | uint32_t tiling_flags, uint32_t pitch) | ||
| 574 | { | ||
| 575 | robj->tiling_flags = tiling_flags; | ||
| 576 | robj->pitch = pitch; | ||
| 577 | } | ||
| 578 | |||
| 579 | void radeon_object_get_tiling_flags(struct radeon_object *robj, | ||
| 580 | uint32_t *tiling_flags, | ||
| 581 | uint32_t *pitch) | ||
| 582 | { | ||
| 583 | if (tiling_flags) | ||
| 584 | *tiling_flags = robj->tiling_flags; | ||
| 585 | if (pitch) | ||
| 586 | *pitch = robj->pitch; | ||
| 587 | } | ||
| 588 | |||
| 589 | int radeon_object_check_tiling(struct radeon_object *robj, bool has_moved, | ||
| 590 | bool force_drop) | ||
| 591 | { | ||
| 592 | if (!(robj->tiling_flags & RADEON_TILING_SURFACE)) | ||
| 593 | return 0; | ||
| 594 | |||
| 595 | if (force_drop) { | ||
| 596 | radeon_object_clear_surface_reg(robj); | ||
| 597 | return 0; | ||
| 598 | } | ||
| 599 | |||
| 600 | if (robj->tobj.mem.mem_type != TTM_PL_VRAM) { | ||
| 601 | if (!has_moved) | ||
| 602 | return 0; | ||
| 603 | |||
| 604 | if (robj->surface_reg >= 0) | ||
| 605 | radeon_object_clear_surface_reg(robj); | ||
| 606 | return 0; | ||
| 607 | } | ||
| 608 | |||
| 609 | if ((robj->surface_reg >= 0) && !has_moved) | ||
| 610 | return 0; | ||
| 611 | |||
| 612 | return radeon_object_get_surface_reg(robj); | ||
| 613 | } | ||
| 614 | |||
| 615 | void radeon_bo_move_notify(struct ttm_buffer_object *bo, | ||
| 616 | struct ttm_mem_reg *mem) | ||
| 617 | { | ||
| 618 | struct radeon_object *robj = container_of(bo, struct radeon_object, tobj); | ||
| 619 | radeon_object_check_tiling(robj, 0, 1); | ||
| 620 | } | ||
| 621 | |||
| 622 | void radeon_bo_fault_reserve_notify(struct ttm_buffer_object *bo) | ||
| 623 | { | ||
| 624 | struct radeon_object *robj = container_of(bo, struct radeon_object, tobj); | ||
| 625 | radeon_object_check_tiling(robj, 0, 0); | ||
| 626 | } | ||
diff --git a/drivers/gpu/drm/radeon/radeon_reg.h b/drivers/gpu/drm/radeon/radeon_reg.h index e1b618574461..4df43f62c678 100644 --- a/drivers/gpu/drm/radeon/radeon_reg.h +++ b/drivers/gpu/drm/radeon/radeon_reg.h | |||
| @@ -982,12 +982,15 @@ | |||
| 982 | # define RS400_TMDS2_PLLRST (1 << 1) | 982 | # define RS400_TMDS2_PLLRST (1 << 1) |
| 983 | 983 | ||
| 984 | #define RADEON_GEN_INT_CNTL 0x0040 | 984 | #define RADEON_GEN_INT_CNTL 0x0040 |
| 985 | # define RADEON_CRTC_VBLANK_MASK (1 << 0) | ||
| 986 | # define RADEON_CRTC2_VBLANK_MASK (1 << 9) | ||
| 985 | # define RADEON_SW_INT_ENABLE (1 << 25) | 987 | # define RADEON_SW_INT_ENABLE (1 << 25) |
| 986 | #define RADEON_GEN_INT_STATUS 0x0044 | 988 | #define RADEON_GEN_INT_STATUS 0x0044 |
| 987 | # define RADEON_VSYNC_INT_AK (1 << 2) | 989 | # define AVIVO_DISPLAY_INT_STATUS (1 << 0) |
| 988 | # define RADEON_VSYNC_INT (1 << 2) | 990 | # define RADEON_CRTC_VBLANK_STAT (1 << 0) |
| 989 | # define RADEON_VSYNC2_INT_AK (1 << 6) | 991 | # define RADEON_CRTC_VBLANK_STAT_ACK (1 << 0) |
| 990 | # define RADEON_VSYNC2_INT (1 << 6) | 992 | # define RADEON_CRTC2_VBLANK_STAT (1 << 9) |
| 993 | # define RADEON_CRTC2_VBLANK_STAT_ACK (1 << 9) | ||
| 991 | # define RADEON_SW_INT_FIRE (1 << 26) | 994 | # define RADEON_SW_INT_FIRE (1 << 26) |
| 992 | # define RADEON_SW_INT_TEST (1 << 25) | 995 | # define RADEON_SW_INT_TEST (1 << 25) |
| 993 | # define RADEON_SW_INT_TEST_ACK (1 << 25) | 996 | # define RADEON_SW_INT_TEST_ACK (1 << 25) |
| @@ -2334,6 +2337,9 @@ | |||
| 2334 | # define RADEON_RE_WIDTH_SHIFT 0 | 2337 | # define RADEON_RE_WIDTH_SHIFT 0 |
| 2335 | # define RADEON_RE_HEIGHT_SHIFT 16 | 2338 | # define RADEON_RE_HEIGHT_SHIFT 16 |
| 2336 | 2339 | ||
| 2340 | #define RADEON_RB3D_ZPASS_DATA 0x3290 | ||
| 2341 | #define RADEON_RB3D_ZPASS_ADDR 0x3294 | ||
| 2342 | |||
| 2337 | #define RADEON_SE_CNTL 0x1c4c | 2343 | #define RADEON_SE_CNTL 0x1c4c |
| 2338 | # define RADEON_FFACE_CULL_CW (0 << 0) | 2344 | # define RADEON_FFACE_CULL_CW (0 << 0) |
| 2339 | # define RADEON_FFACE_CULL_CCW (1 << 0) | 2345 | # define RADEON_FFACE_CULL_CCW (1 << 0) |
| @@ -3568,4 +3574,6 @@ | |||
| 3568 | #define RADEON_SCRATCH_REG4 0x15f0 | 3574 | #define RADEON_SCRATCH_REG4 0x15f0 |
| 3569 | #define RADEON_SCRATCH_REG5 0x15f4 | 3575 | #define RADEON_SCRATCH_REG5 0x15f4 |
| 3570 | 3576 | ||
| 3577 | #define RV530_GB_PIPE_SELECT2 0x4124 | ||
| 3578 | |||
| 3571 | #endif | 3579 | #endif |
diff --git a/drivers/gpu/drm/radeon/radeon_ring.c b/drivers/gpu/drm/radeon/radeon_ring.c index a853261d1881..60d159308b88 100644 --- a/drivers/gpu/drm/radeon/radeon_ring.c +++ b/drivers/gpu/drm/radeon/radeon_ring.c | |||
| @@ -126,32 +126,19 @@ static void radeon_ib_align(struct radeon_device *rdev, struct radeon_ib *ib) | |||
| 126 | } | 126 | } |
| 127 | } | 127 | } |
| 128 | 128 | ||
| 129 | static void radeon_ib_cpu_flush(struct radeon_device *rdev, | ||
| 130 | struct radeon_ib *ib) | ||
| 131 | { | ||
| 132 | unsigned long tmp; | ||
| 133 | unsigned i; | ||
| 134 | |||
| 135 | /* To force CPU cache flush ugly but seems reliable */ | ||
| 136 | for (i = 0; i < ib->length_dw; i += (rdev->cp.align_mask + 1)) { | ||
| 137 | tmp = readl(&ib->ptr[i]); | ||
| 138 | } | ||
| 139 | } | ||
| 140 | |||
| 141 | int radeon_ib_schedule(struct radeon_device *rdev, struct radeon_ib *ib) | 129 | int radeon_ib_schedule(struct radeon_device *rdev, struct radeon_ib *ib) |
| 142 | { | 130 | { |
| 143 | int r = 0; | 131 | int r = 0; |
| 144 | 132 | ||
| 145 | mutex_lock(&rdev->ib_pool.mutex); | 133 | mutex_lock(&rdev->ib_pool.mutex); |
| 146 | radeon_ib_align(rdev, ib); | 134 | radeon_ib_align(rdev, ib); |
| 147 | radeon_ib_cpu_flush(rdev, ib); | ||
| 148 | if (!ib->length_dw || !rdev->cp.ready) { | 135 | if (!ib->length_dw || !rdev->cp.ready) { |
| 149 | /* TODO: Nothings in the ib we should report. */ | 136 | /* TODO: Nothings in the ib we should report. */ |
| 150 | mutex_unlock(&rdev->ib_pool.mutex); | 137 | mutex_unlock(&rdev->ib_pool.mutex); |
| 151 | DRM_ERROR("radeon: couldn't schedule IB(%lu).\n", ib->idx); | 138 | DRM_ERROR("radeon: couldn't schedule IB(%lu).\n", ib->idx); |
| 152 | return -EINVAL; | 139 | return -EINVAL; |
| 153 | } | 140 | } |
| 154 | /* 64 dwords should be enought for fence too */ | 141 | /* 64 dwords should be enough for fence too */ |
| 155 | r = radeon_ring_lock(rdev, 64); | 142 | r = radeon_ring_lock(rdev, 64); |
| 156 | if (r) { | 143 | if (r) { |
| 157 | DRM_ERROR("radeon: scheduling IB failled (%d).\n", r); | 144 | DRM_ERROR("radeon: scheduling IB failled (%d).\n", r); |
diff --git a/drivers/gpu/drm/radeon/radeon_share.h b/drivers/gpu/drm/radeon/radeon_share.h new file mode 100644 index 000000000000..63a773578f17 --- /dev/null +++ b/drivers/gpu/drm/radeon/radeon_share.h | |||
| @@ -0,0 +1,39 @@ | |||
| 1 | /* | ||
| 2 | * Copyright 2008 Advanced Micro Devices, Inc. | ||
| 3 | * Copyright 2008 Red Hat Inc. | ||
| 4 | * Copyright 2009 Jerome Glisse. | ||
| 5 | * | ||
| 6 | * Permission is hereby granted, free of charge, to any person obtaining a | ||
| 7 | * copy of this software and associated documentation files (the "Software"), | ||
| 8 | * to deal in the Software without restriction, including without limitation | ||
| 9 | * the rights to use, copy, modify, merge, publish, distribute, sublicense, | ||
| 10 | * and/or sell copies of the Software, and to permit persons to whom the | ||
| 11 | * Software is furnished to do so, subject to the following conditions: | ||
| 12 | * | ||
| 13 | * The above copyright notice and this permission notice shall be included in | ||
| 14 | * all copies or substantial portions of the Software. | ||
| 15 | * | ||
| 16 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
| 17 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
| 18 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL | ||
| 19 | * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR | ||
| 20 | * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, | ||
| 21 | * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR | ||
| 22 | * OTHER DEALINGS IN THE SOFTWARE. | ||
| 23 | * | ||
| 24 | * Authors: Dave Airlie | ||
| 25 | * Alex Deucher | ||
| 26 | * Jerome Glisse | ||
| 27 | */ | ||
| 28 | #ifndef __RADEON_SHARE_H__ | ||
| 29 | #define __RADEON_SHARE_H__ | ||
| 30 | |||
| 31 | void r100_vram_init_sizes(struct radeon_device *rdev); | ||
| 32 | |||
| 33 | void rs690_line_buffer_adjust(struct radeon_device *rdev, | ||
| 34 | struct drm_display_mode *mode1, | ||
| 35 | struct drm_display_mode *mode2); | ||
| 36 | |||
| 37 | void rv515_bandwidth_avivo_update(struct radeon_device *rdev); | ||
| 38 | |||
| 39 | #endif | ||
diff --git a/drivers/gpu/drm/radeon/radeon_state.c b/drivers/gpu/drm/radeon/radeon_state.c index 46645f3e0328..2882f40d5ec5 100644 --- a/drivers/gpu/drm/radeon/radeon_state.c +++ b/drivers/gpu/drm/radeon/radeon_state.c | |||
| @@ -3081,6 +3081,9 @@ static int radeon_cp_getparam(struct drm_device *dev, void *data, struct drm_fil | |||
| 3081 | case RADEON_PARAM_NUM_GB_PIPES: | 3081 | case RADEON_PARAM_NUM_GB_PIPES: |
| 3082 | value = dev_priv->num_gb_pipes; | 3082 | value = dev_priv->num_gb_pipes; |
| 3083 | break; | 3083 | break; |
| 3084 | case RADEON_PARAM_NUM_Z_PIPES: | ||
| 3085 | value = dev_priv->num_z_pipes; | ||
| 3086 | break; | ||
| 3084 | default: | 3087 | default: |
| 3085 | DRM_DEBUG("Invalid parameter %d\n", param->param); | 3088 | DRM_DEBUG("Invalid parameter %d\n", param->param); |
| 3086 | return -EINVAL; | 3089 | return -EINVAL; |
diff --git a/drivers/gpu/drm/radeon/radeon_test.c b/drivers/gpu/drm/radeon/radeon_test.c new file mode 100644 index 000000000000..03c33cf4e14c --- /dev/null +++ b/drivers/gpu/drm/radeon/radeon_test.c | |||
| @@ -0,0 +1,209 @@ | |||
| 1 | /* | ||
| 2 | * Copyright 2009 VMware, Inc. | ||
| 3 | * | ||
| 4 | * Permission is hereby granted, free of charge, to any person obtaining a | ||
| 5 | * copy of this software and associated documentation files (the "Software"), | ||
| 6 | * to deal in the Software without restriction, including without limitation | ||
| 7 | * the rights to use, copy, modify, merge, publish, distribute, sublicense, | ||
| 8 | * and/or sell copies of the Software, and to permit persons to whom the | ||
| 9 | * Software is furnished to do so, subject to the following conditions: | ||
| 10 | * | ||
| 11 | * The above copyright notice and this permission notice shall be included in | ||
| 12 | * all copies or substantial portions of the Software. | ||
| 13 | * | ||
| 14 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
| 15 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
| 16 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL | ||
| 17 | * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR | ||
| 18 | * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, | ||
| 19 | * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR | ||
| 20 | * OTHER DEALINGS IN THE SOFTWARE. | ||
| 21 | * | ||
| 22 | * Authors: Michel Dänzer | ||
| 23 | */ | ||
| 24 | #include <drm/drmP.h> | ||
| 25 | #include <drm/radeon_drm.h> | ||
| 26 | #include "radeon_reg.h" | ||
| 27 | #include "radeon.h" | ||
| 28 | |||
| 29 | |||
| 30 | /* Test BO GTT->VRAM and VRAM->GTT GPU copies across the whole GTT aperture */ | ||
| 31 | void radeon_test_moves(struct radeon_device *rdev) | ||
| 32 | { | ||
| 33 | struct radeon_object *vram_obj = NULL; | ||
| 34 | struct radeon_object **gtt_obj = NULL; | ||
| 35 | struct radeon_fence *fence = NULL; | ||
| 36 | uint64_t gtt_addr, vram_addr; | ||
| 37 | unsigned i, n, size; | ||
| 38 | int r; | ||
| 39 | |||
| 40 | size = 1024 * 1024; | ||
| 41 | |||
| 42 | /* Number of tests = | ||
| 43 | * (Total GTT - IB pool - writeback page - ring buffer) / test size | ||
| 44 | */ | ||
| 45 | n = (rdev->mc.gtt_size - RADEON_IB_POOL_SIZE*64*1024 - 4096 - | ||
| 46 | rdev->cp.ring_size) / size; | ||
| 47 | |||
| 48 | gtt_obj = kzalloc(n * sizeof(*gtt_obj), GFP_KERNEL); | ||
| 49 | if (!gtt_obj) { | ||
| 50 | DRM_ERROR("Failed to allocate %d pointers\n", n); | ||
| 51 | r = 1; | ||
| 52 | goto out_cleanup; | ||
| 53 | } | ||
| 54 | |||
| 55 | r = radeon_object_create(rdev, NULL, size, true, RADEON_GEM_DOMAIN_VRAM, | ||
| 56 | false, &vram_obj); | ||
| 57 | if (r) { | ||
| 58 | DRM_ERROR("Failed to create VRAM object\n"); | ||
| 59 | goto out_cleanup; | ||
| 60 | } | ||
| 61 | |||
| 62 | r = radeon_object_pin(vram_obj, RADEON_GEM_DOMAIN_VRAM, &vram_addr); | ||
| 63 | if (r) { | ||
| 64 | DRM_ERROR("Failed to pin VRAM object\n"); | ||
| 65 | goto out_cleanup; | ||
| 66 | } | ||
| 67 | |||
| 68 | for (i = 0; i < n; i++) { | ||
| 69 | void *gtt_map, *vram_map; | ||
| 70 | void **gtt_start, **gtt_end; | ||
| 71 | void **vram_start, **vram_end; | ||
| 72 | |||
| 73 | r = radeon_object_create(rdev, NULL, size, true, | ||
| 74 | RADEON_GEM_DOMAIN_GTT, false, gtt_obj + i); | ||
| 75 | if (r) { | ||
| 76 | DRM_ERROR("Failed to create GTT object %d\n", i); | ||
| 77 | goto out_cleanup; | ||
| 78 | } | ||
| 79 | |||
| 80 | r = radeon_object_pin(gtt_obj[i], RADEON_GEM_DOMAIN_GTT, >t_addr); | ||
| 81 | if (r) { | ||
| 82 | DRM_ERROR("Failed to pin GTT object %d\n", i); | ||
| 83 | goto out_cleanup; | ||
| 84 | } | ||
| 85 | |||
| 86 | r = radeon_object_kmap(gtt_obj[i], >t_map); | ||
| 87 | if (r) { | ||
| 88 | DRM_ERROR("Failed to map GTT object %d\n", i); | ||
| 89 | goto out_cleanup; | ||
| 90 | } | ||
| 91 | |||
| 92 | for (gtt_start = gtt_map, gtt_end = gtt_map + size; | ||
| 93 | gtt_start < gtt_end; | ||
| 94 | gtt_start++) | ||
| 95 | *gtt_start = gtt_start; | ||
| 96 | |||
| 97 | radeon_object_kunmap(gtt_obj[i]); | ||
| 98 | |||
| 99 | r = radeon_fence_create(rdev, &fence); | ||
| 100 | if (r) { | ||
| 101 | DRM_ERROR("Failed to create GTT->VRAM fence %d\n", i); | ||
| 102 | goto out_cleanup; | ||
| 103 | } | ||
| 104 | |||
| 105 | r = radeon_copy(rdev, gtt_addr, vram_addr, size / 4096, fence); | ||
| 106 | if (r) { | ||
| 107 | DRM_ERROR("Failed GTT->VRAM copy %d\n", i); | ||
| 108 | goto out_cleanup; | ||
| 109 | } | ||
| 110 | |||
| 111 | r = radeon_fence_wait(fence, false); | ||
| 112 | if (r) { | ||
| 113 | DRM_ERROR("Failed to wait for GTT->VRAM fence %d\n", i); | ||
| 114 | goto out_cleanup; | ||
| 115 | } | ||
| 116 | |||
| 117 | radeon_fence_unref(&fence); | ||
| 118 | |||
| 119 | r = radeon_object_kmap(vram_obj, &vram_map); | ||
| 120 | if (r) { | ||
| 121 | DRM_ERROR("Failed to map VRAM object after copy %d\n", i); | ||
| 122 | goto out_cleanup; | ||
| 123 | } | ||
| 124 | |||
| 125 | for (gtt_start = gtt_map, gtt_end = gtt_map + size, | ||
| 126 | vram_start = vram_map, vram_end = vram_map + size; | ||
| 127 | vram_start < vram_end; | ||
| 128 | gtt_start++, vram_start++) { | ||
| 129 | if (*vram_start != gtt_start) { | ||
| 130 | DRM_ERROR("Incorrect GTT->VRAM copy %d: Got 0x%p, " | ||
| 131 | "expected 0x%p (GTT map 0x%p-0x%p)\n", | ||
| 132 | i, *vram_start, gtt_start, gtt_map, | ||
| 133 | gtt_end); | ||
| 134 | radeon_object_kunmap(vram_obj); | ||
| 135 | goto out_cleanup; | ||
| 136 | } | ||
| 137 | *vram_start = vram_start; | ||
| 138 | } | ||
| 139 | |||
| 140 | radeon_object_kunmap(vram_obj); | ||
| 141 | |||
| 142 | r = radeon_fence_create(rdev, &fence); | ||
| 143 | if (r) { | ||
| 144 | DRM_ERROR("Failed to create VRAM->GTT fence %d\n", i); | ||
| 145 | goto out_cleanup; | ||
| 146 | } | ||
| 147 | |||
| 148 | r = radeon_copy(rdev, vram_addr, gtt_addr, size / 4096, fence); | ||
| 149 | if (r) { | ||
| 150 | DRM_ERROR("Failed VRAM->GTT copy %d\n", i); | ||
| 151 | goto out_cleanup; | ||
| 152 | } | ||
| 153 | |||
| 154 | r = radeon_fence_wait(fence, false); | ||
| 155 | if (r) { | ||
| 156 | DRM_ERROR("Failed to wait for VRAM->GTT fence %d\n", i); | ||
| 157 | goto out_cleanup; | ||
| 158 | } | ||
| 159 | |||
| 160 | radeon_fence_unref(&fence); | ||
| 161 | |||
| 162 | r = radeon_object_kmap(gtt_obj[i], >t_map); | ||
| 163 | if (r) { | ||
| 164 | DRM_ERROR("Failed to map GTT object after copy %d\n", i); | ||
| 165 | goto out_cleanup; | ||
| 166 | } | ||
| 167 | |||
| 168 | for (gtt_start = gtt_map, gtt_end = gtt_map + size, | ||
| 169 | vram_start = vram_map, vram_end = vram_map + size; | ||
| 170 | gtt_start < gtt_end; | ||
| 171 | gtt_start++, vram_start++) { | ||
| 172 | if (*gtt_start != vram_start) { | ||
| 173 | DRM_ERROR("Incorrect VRAM->GTT copy %d: Got 0x%p, " | ||
| 174 | "expected 0x%p (VRAM map 0x%p-0x%p)\n", | ||
| 175 | i, *gtt_start, vram_start, vram_map, | ||
| 176 | vram_end); | ||
| 177 | radeon_object_kunmap(gtt_obj[i]); | ||
| 178 | goto out_cleanup; | ||
| 179 | } | ||
| 180 | } | ||
| 181 | |||
| 182 | radeon_object_kunmap(gtt_obj[i]); | ||
| 183 | |||
| 184 | DRM_INFO("Tested GTT->VRAM and VRAM->GTT copy for GTT offset 0x%llx\n", | ||
| 185 | gtt_addr - rdev->mc.gtt_location); | ||
| 186 | } | ||
| 187 | |||
| 188 | out_cleanup: | ||
| 189 | if (vram_obj) { | ||
| 190 | radeon_object_unpin(vram_obj); | ||
| 191 | radeon_object_unref(&vram_obj); | ||
| 192 | } | ||
| 193 | if (gtt_obj) { | ||
| 194 | for (i = 0; i < n; i++) { | ||
| 195 | if (gtt_obj[i]) { | ||
| 196 | radeon_object_unpin(gtt_obj[i]); | ||
| 197 | radeon_object_unref(>t_obj[i]); | ||
| 198 | } | ||
| 199 | } | ||
| 200 | kfree(gtt_obj); | ||
| 201 | } | ||
| 202 | if (fence) { | ||
| 203 | radeon_fence_unref(&fence); | ||
| 204 | } | ||
| 205 | if (r) { | ||
| 206 | printk(KERN_WARNING "Error while testing BO move.\n"); | ||
| 207 | } | ||
| 208 | } | ||
| 209 | |||
diff --git a/drivers/gpu/drm/radeon/radeon_ttm.c b/drivers/gpu/drm/radeon/radeon_ttm.c index 1227a97f5169..15c3531377ed 100644 --- a/drivers/gpu/drm/radeon/radeon_ttm.c +++ b/drivers/gpu/drm/radeon/radeon_ttm.c | |||
| @@ -355,23 +355,26 @@ static int radeon_bo_move(struct ttm_buffer_object *bo, | |||
| 355 | if (!rdev->cp.ready) { | 355 | if (!rdev->cp.ready) { |
| 356 | /* use memcpy */ | 356 | /* use memcpy */ |
| 357 | DRM_ERROR("CP is not ready use memcpy.\n"); | 357 | DRM_ERROR("CP is not ready use memcpy.\n"); |
| 358 | return ttm_bo_move_memcpy(bo, evict, no_wait, new_mem); | 358 | goto memcpy; |
| 359 | } | 359 | } |
| 360 | 360 | ||
| 361 | if (old_mem->mem_type == TTM_PL_VRAM && | 361 | if (old_mem->mem_type == TTM_PL_VRAM && |
| 362 | new_mem->mem_type == TTM_PL_SYSTEM) { | 362 | new_mem->mem_type == TTM_PL_SYSTEM) { |
| 363 | return radeon_move_vram_ram(bo, evict, interruptible, | 363 | r = radeon_move_vram_ram(bo, evict, interruptible, |
| 364 | no_wait, new_mem); | 364 | no_wait, new_mem); |
| 365 | } else if (old_mem->mem_type == TTM_PL_SYSTEM && | 365 | } else if (old_mem->mem_type == TTM_PL_SYSTEM && |
| 366 | new_mem->mem_type == TTM_PL_VRAM) { | 366 | new_mem->mem_type == TTM_PL_VRAM) { |
| 367 | return radeon_move_ram_vram(bo, evict, interruptible, | 367 | r = radeon_move_ram_vram(bo, evict, interruptible, |
| 368 | no_wait, new_mem); | 368 | no_wait, new_mem); |
| 369 | } else { | 369 | } else { |
| 370 | r = radeon_move_blit(bo, evict, no_wait, new_mem, old_mem); | 370 | r = radeon_move_blit(bo, evict, no_wait, new_mem, old_mem); |
| 371 | if (unlikely(r)) { | ||
| 372 | return r; | ||
| 373 | } | ||
| 374 | } | 371 | } |
| 372 | |||
| 373 | if (r) { | ||
| 374 | memcpy: | ||
| 375 | r = ttm_bo_move_memcpy(bo, evict, no_wait, new_mem); | ||
| 376 | } | ||
| 377 | |||
| 375 | return r; | 378 | return r; |
| 376 | } | 379 | } |
| 377 | 380 | ||
| @@ -429,6 +432,8 @@ static struct ttm_bo_driver radeon_bo_driver = { | |||
| 429 | .sync_obj_flush = &radeon_sync_obj_flush, | 432 | .sync_obj_flush = &radeon_sync_obj_flush, |
| 430 | .sync_obj_unref = &radeon_sync_obj_unref, | 433 | .sync_obj_unref = &radeon_sync_obj_unref, |
| 431 | .sync_obj_ref = &radeon_sync_obj_ref, | 434 | .sync_obj_ref = &radeon_sync_obj_ref, |
| 435 | .move_notify = &radeon_bo_move_notify, | ||
| 436 | .fault_reserve_notify = &radeon_bo_fault_reserve_notify, | ||
| 432 | }; | 437 | }; |
| 433 | 438 | ||
| 434 | int radeon_ttm_init(struct radeon_device *rdev) | 439 | int radeon_ttm_init(struct radeon_device *rdev) |
| @@ -442,13 +447,14 @@ int radeon_ttm_init(struct radeon_device *rdev) | |||
| 442 | /* No others user of address space so set it to 0 */ | 447 | /* No others user of address space so set it to 0 */ |
| 443 | r = ttm_bo_device_init(&rdev->mman.bdev, | 448 | r = ttm_bo_device_init(&rdev->mman.bdev, |
| 444 | rdev->mman.mem_global_ref.object, | 449 | rdev->mman.mem_global_ref.object, |
| 445 | &radeon_bo_driver, DRM_FILE_PAGE_OFFSET); | 450 | &radeon_bo_driver, DRM_FILE_PAGE_OFFSET, |
| 451 | rdev->need_dma32); | ||
| 446 | if (r) { | 452 | if (r) { |
| 447 | DRM_ERROR("failed initializing buffer object driver(%d).\n", r); | 453 | DRM_ERROR("failed initializing buffer object driver(%d).\n", r); |
| 448 | return r; | 454 | return r; |
| 449 | } | 455 | } |
| 450 | r = ttm_bo_init_mm(&rdev->mman.bdev, TTM_PL_VRAM, 0, | 456 | r = ttm_bo_init_mm(&rdev->mman.bdev, TTM_PL_VRAM, 0, |
| 451 | ((rdev->mc.aper_size) >> PAGE_SHIFT)); | 457 | ((rdev->mc.real_vram_size) >> PAGE_SHIFT)); |
| 452 | if (r) { | 458 | if (r) { |
| 453 | DRM_ERROR("Failed initializing VRAM heap.\n"); | 459 | DRM_ERROR("Failed initializing VRAM heap.\n"); |
| 454 | return r; | 460 | return r; |
| @@ -465,7 +471,7 @@ int radeon_ttm_init(struct radeon_device *rdev) | |||
| 465 | return r; | 471 | return r; |
| 466 | } | 472 | } |
| 467 | DRM_INFO("radeon: %uM of VRAM memory ready\n", | 473 | DRM_INFO("radeon: %uM of VRAM memory ready\n", |
| 468 | rdev->mc.vram_size / (1024 * 1024)); | 474 | rdev->mc.real_vram_size / (1024 * 1024)); |
| 469 | r = ttm_bo_init_mm(&rdev->mman.bdev, TTM_PL_TT, 0, | 475 | r = ttm_bo_init_mm(&rdev->mman.bdev, TTM_PL_TT, 0, |
| 470 | ((rdev->mc.gtt_size) >> PAGE_SHIFT)); | 476 | ((rdev->mc.gtt_size) >> PAGE_SHIFT)); |
| 471 | if (r) { | 477 | if (r) { |
diff --git a/drivers/gpu/drm/radeon/rs400.c b/drivers/gpu/drm/radeon/rs400.c index cc074b5a8f74..b29affd9c5d8 100644 --- a/drivers/gpu/drm/radeon/rs400.c +++ b/drivers/gpu/drm/radeon/rs400.c | |||
| @@ -29,6 +29,7 @@ | |||
| 29 | #include <drm/drmP.h> | 29 | #include <drm/drmP.h> |
| 30 | #include "radeon_reg.h" | 30 | #include "radeon_reg.h" |
| 31 | #include "radeon.h" | 31 | #include "radeon.h" |
| 32 | #include "radeon_share.h" | ||
| 32 | 33 | ||
| 33 | /* rs400,rs480 depends on : */ | 34 | /* rs400,rs480 depends on : */ |
| 34 | void r100_hdp_reset(struct radeon_device *rdev); | 35 | void r100_hdp_reset(struct radeon_device *rdev); |
| @@ -164,7 +165,9 @@ int rs400_gart_enable(struct radeon_device *rdev) | |||
| 164 | WREG32(RADEON_BUS_CNTL, tmp); | 165 | WREG32(RADEON_BUS_CNTL, tmp); |
| 165 | } | 166 | } |
| 166 | /* Table should be in 32bits address space so ignore bits above. */ | 167 | /* Table should be in 32bits address space so ignore bits above. */ |
| 167 | tmp = rdev->gart.table_addr & 0xfffff000; | 168 | tmp = (u32)rdev->gart.table_addr & 0xfffff000; |
| 169 | tmp |= (upper_32_bits(rdev->gart.table_addr) & 0xff) << 4; | ||
| 170 | |||
| 168 | WREG32_MC(RS480_GART_BASE, tmp); | 171 | WREG32_MC(RS480_GART_BASE, tmp); |
| 169 | /* TODO: more tweaking here */ | 172 | /* TODO: more tweaking here */ |
| 170 | WREG32_MC(RS480_GART_FEATURE_ID, | 173 | WREG32_MC(RS480_GART_FEATURE_ID, |
| @@ -201,10 +204,17 @@ void rs400_gart_disable(struct radeon_device *rdev) | |||
| 201 | 204 | ||
| 202 | int rs400_gart_set_page(struct radeon_device *rdev, int i, uint64_t addr) | 205 | int rs400_gart_set_page(struct radeon_device *rdev, int i, uint64_t addr) |
| 203 | { | 206 | { |
| 207 | uint32_t entry; | ||
| 208 | |||
| 204 | if (i < 0 || i > rdev->gart.num_gpu_pages) { | 209 | if (i < 0 || i > rdev->gart.num_gpu_pages) { |
| 205 | return -EINVAL; | 210 | return -EINVAL; |
| 206 | } | 211 | } |
| 207 | rdev->gart.table.ram.ptr[i] = cpu_to_le32(((uint32_t)addr) | 0xC); | 212 | |
| 213 | entry = (lower_32_bits(addr) & PAGE_MASK) | | ||
| 214 | ((upper_32_bits(addr) & 0xff) << 4) | | ||
| 215 | 0xc; | ||
| 216 | entry = cpu_to_le32(entry); | ||
| 217 | rdev->gart.table.ram.ptr[i] = entry; | ||
| 208 | return 0; | 218 | return 0; |
| 209 | } | 219 | } |
| 210 | 220 | ||
| @@ -223,10 +233,9 @@ int rs400_mc_init(struct radeon_device *rdev) | |||
| 223 | 233 | ||
| 224 | rs400_gpu_init(rdev); | 234 | rs400_gpu_init(rdev); |
| 225 | rs400_gart_disable(rdev); | 235 | rs400_gart_disable(rdev); |
| 226 | rdev->mc.gtt_location = rdev->mc.vram_size; | 236 | rdev->mc.gtt_location = rdev->mc.mc_vram_size; |
| 227 | rdev->mc.gtt_location += (rdev->mc.gtt_size - 1); | 237 | rdev->mc.gtt_location += (rdev->mc.gtt_size - 1); |
| 228 | rdev->mc.gtt_location &= ~(rdev->mc.gtt_size - 1); | 238 | rdev->mc.gtt_location &= ~(rdev->mc.gtt_size - 1); |
| 229 | rdev->mc.vram_location = 0xFFFFFFFFUL; | ||
| 230 | r = radeon_mc_setup(rdev); | 239 | r = radeon_mc_setup(rdev); |
| 231 | if (r) { | 240 | if (r) { |
| 232 | return r; | 241 | return r; |
| @@ -238,7 +247,7 @@ int rs400_mc_init(struct radeon_device *rdev) | |||
| 238 | "programming pipes. Bad things might happen.\n"); | 247 | "programming pipes. Bad things might happen.\n"); |
| 239 | } | 248 | } |
| 240 | 249 | ||
| 241 | tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; | 250 | tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1; |
| 242 | tmp = REG_SET(RADEON_MC_FB_TOP, tmp >> 16); | 251 | tmp = REG_SET(RADEON_MC_FB_TOP, tmp >> 16); |
| 243 | tmp |= REG_SET(RADEON_MC_FB_START, rdev->mc.vram_location >> 16); | 252 | tmp |= REG_SET(RADEON_MC_FB_START, rdev->mc.vram_location >> 16); |
| 244 | WREG32(RADEON_MC_FB_LOCATION, tmp); | 253 | WREG32(RADEON_MC_FB_LOCATION, tmp); |
| @@ -284,21 +293,12 @@ void rs400_gpu_init(struct radeon_device *rdev) | |||
| 284 | */ | 293 | */ |
| 285 | void rs400_vram_info(struct radeon_device *rdev) | 294 | void rs400_vram_info(struct radeon_device *rdev) |
| 286 | { | 295 | { |
| 287 | uint32_t tom; | ||
| 288 | |||
| 289 | rs400_gart_adjust_size(rdev); | 296 | rs400_gart_adjust_size(rdev); |
| 290 | /* DDR for all card after R300 & IGP */ | 297 | /* DDR for all card after R300 & IGP */ |
| 291 | rdev->mc.vram_is_ddr = true; | 298 | rdev->mc.vram_is_ddr = true; |
| 292 | rdev->mc.vram_width = 128; | 299 | rdev->mc.vram_width = 128; |
| 293 | 300 | ||
| 294 | /* read NB_TOM to get the amount of ram stolen for the GPU */ | 301 | r100_vram_init_sizes(rdev); |
| 295 | tom = RREG32(RADEON_NB_TOM); | ||
| 296 | rdev->mc.vram_size = (((tom >> 16) - (tom & 0xffff) + 1) << 16); | ||
| 297 | WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.vram_size); | ||
| 298 | |||
| 299 | /* Could aper size report 0 ? */ | ||
| 300 | rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); | ||
| 301 | rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0); | ||
| 302 | } | 302 | } |
| 303 | 303 | ||
| 304 | 304 | ||
diff --git a/drivers/gpu/drm/radeon/rs600.c b/drivers/gpu/drm/radeon/rs600.c index ab0c967553e6..7e8ce983a908 100644 --- a/drivers/gpu/drm/radeon/rs600.c +++ b/drivers/gpu/drm/radeon/rs600.c | |||
| @@ -223,7 +223,7 @@ int rs600_mc_init(struct radeon_device *rdev) | |||
| 223 | printk(KERN_WARNING "Failed to wait MC idle while " | 223 | printk(KERN_WARNING "Failed to wait MC idle while " |
| 224 | "programming pipes. Bad things might happen.\n"); | 224 | "programming pipes. Bad things might happen.\n"); |
| 225 | } | 225 | } |
| 226 | tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; | 226 | tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1; |
| 227 | tmp = REG_SET(RS600_MC_FB_TOP, tmp >> 16); | 227 | tmp = REG_SET(RS600_MC_FB_TOP, tmp >> 16); |
| 228 | tmp |= REG_SET(RS600_MC_FB_START, rdev->mc.vram_location >> 16); | 228 | tmp |= REG_SET(RS600_MC_FB_START, rdev->mc.vram_location >> 16); |
| 229 | WREG32_MC(RS600_MC_FB_LOCATION, tmp); | 229 | WREG32_MC(RS600_MC_FB_LOCATION, tmp); |
| @@ -240,6 +240,88 @@ void rs600_mc_fini(struct radeon_device *rdev) | |||
| 240 | 240 | ||
| 241 | 241 | ||
| 242 | /* | 242 | /* |
| 243 | * Interrupts | ||
| 244 | */ | ||
| 245 | int rs600_irq_set(struct radeon_device *rdev) | ||
| 246 | { | ||
| 247 | uint32_t tmp = 0; | ||
| 248 | uint32_t mode_int = 0; | ||
| 249 | |||
| 250 | if (rdev->irq.sw_int) { | ||
| 251 | tmp |= RADEON_SW_INT_ENABLE; | ||
| 252 | } | ||
| 253 | if (rdev->irq.crtc_vblank_int[0]) { | ||
| 254 | tmp |= AVIVO_DISPLAY_INT_STATUS; | ||
| 255 | mode_int |= AVIVO_D1MODE_INT_MASK; | ||
| 256 | } | ||
| 257 | if (rdev->irq.crtc_vblank_int[1]) { | ||
| 258 | tmp |= AVIVO_DISPLAY_INT_STATUS; | ||
| 259 | mode_int |= AVIVO_D2MODE_INT_MASK; | ||
| 260 | } | ||
| 261 | WREG32(RADEON_GEN_INT_CNTL, tmp); | ||
| 262 | WREG32(AVIVO_DxMODE_INT_MASK, mode_int); | ||
| 263 | return 0; | ||
| 264 | } | ||
| 265 | |||
| 266 | static inline uint32_t rs600_irq_ack(struct radeon_device *rdev, u32 *r500_disp_int) | ||
| 267 | { | ||
| 268 | uint32_t irqs = RREG32(RADEON_GEN_INT_STATUS); | ||
| 269 | uint32_t irq_mask = RADEON_SW_INT_TEST; | ||
| 270 | |||
| 271 | if (irqs & AVIVO_DISPLAY_INT_STATUS) { | ||
| 272 | *r500_disp_int = RREG32(AVIVO_DISP_INTERRUPT_STATUS); | ||
| 273 | if (*r500_disp_int & AVIVO_D1_VBLANK_INTERRUPT) { | ||
| 274 | WREG32(AVIVO_D1MODE_VBLANK_STATUS, AVIVO_VBLANK_ACK); | ||
| 275 | } | ||
| 276 | if (*r500_disp_int & AVIVO_D2_VBLANK_INTERRUPT) { | ||
| 277 | WREG32(AVIVO_D2MODE_VBLANK_STATUS, AVIVO_VBLANK_ACK); | ||
| 278 | } | ||
| 279 | } else { | ||
| 280 | *r500_disp_int = 0; | ||
| 281 | } | ||
| 282 | |||
| 283 | if (irqs) { | ||
| 284 | WREG32(RADEON_GEN_INT_STATUS, irqs); | ||
| 285 | } | ||
| 286 | return irqs & irq_mask; | ||
| 287 | } | ||
| 288 | |||
| 289 | int rs600_irq_process(struct radeon_device *rdev) | ||
| 290 | { | ||
| 291 | uint32_t status; | ||
| 292 | uint32_t r500_disp_int; | ||
| 293 | |||
| 294 | status = rs600_irq_ack(rdev, &r500_disp_int); | ||
| 295 | if (!status && !r500_disp_int) { | ||
| 296 | return IRQ_NONE; | ||
| 297 | } | ||
| 298 | while (status || r500_disp_int) { | ||
| 299 | /* SW interrupt */ | ||
| 300 | if (status & RADEON_SW_INT_TEST) { | ||
| 301 | radeon_fence_process(rdev); | ||
| 302 | } | ||
| 303 | /* Vertical blank interrupts */ | ||
| 304 | if (r500_disp_int & AVIVO_D1_VBLANK_INTERRUPT) { | ||
| 305 | drm_handle_vblank(rdev->ddev, 0); | ||
| 306 | } | ||
| 307 | if (r500_disp_int & AVIVO_D2_VBLANK_INTERRUPT) { | ||
| 308 | drm_handle_vblank(rdev->ddev, 1); | ||
| 309 | } | ||
| 310 | status = rs600_irq_ack(rdev, &r500_disp_int); | ||
| 311 | } | ||
| 312 | return IRQ_HANDLED; | ||
| 313 | } | ||
| 314 | |||
| 315 | u32 rs600_get_vblank_counter(struct radeon_device *rdev, int crtc) | ||
| 316 | { | ||
| 317 | if (crtc == 0) | ||
| 318 | return RREG32(AVIVO_D1CRTC_FRAME_COUNT); | ||
| 319 | else | ||
| 320 | return RREG32(AVIVO_D2CRTC_FRAME_COUNT); | ||
| 321 | } | ||
| 322 | |||
| 323 | |||
| 324 | /* | ||
| 243 | * Global GPU functions | 325 | * Global GPU functions |
| 244 | */ | 326 | */ |
| 245 | void rs600_disable_vga(struct radeon_device *rdev) | 327 | void rs600_disable_vga(struct radeon_device *rdev) |
| @@ -301,6 +383,11 @@ void rs600_vram_info(struct radeon_device *rdev) | |||
| 301 | rdev->mc.vram_width = 128; | 383 | rdev->mc.vram_width = 128; |
| 302 | } | 384 | } |
| 303 | 385 | ||
| 386 | void rs600_bandwidth_update(struct radeon_device *rdev) | ||
| 387 | { | ||
| 388 | /* FIXME: implement, should this be like rs690 ? */ | ||
| 389 | } | ||
| 390 | |||
| 304 | 391 | ||
| 305 | /* | 392 | /* |
| 306 | * Indirect registers accessor | 393 | * Indirect registers accessor |
diff --git a/drivers/gpu/drm/radeon/rs690.c b/drivers/gpu/drm/radeon/rs690.c index 79ba85042b5f..bc6b7c5339bc 100644 --- a/drivers/gpu/drm/radeon/rs690.c +++ b/drivers/gpu/drm/radeon/rs690.c | |||
| @@ -28,6 +28,9 @@ | |||
| 28 | #include "drmP.h" | 28 | #include "drmP.h" |
| 29 | #include "radeon_reg.h" | 29 | #include "radeon_reg.h" |
| 30 | #include "radeon.h" | 30 | #include "radeon.h" |
| 31 | #include "rs690r.h" | ||
| 32 | #include "atom.h" | ||
| 33 | #include "atom-bits.h" | ||
| 31 | 34 | ||
| 32 | /* rs690,rs740 depends on : */ | 35 | /* rs690,rs740 depends on : */ |
| 33 | void r100_hdp_reset(struct radeon_device *rdev); | 36 | void r100_hdp_reset(struct radeon_device *rdev); |
| @@ -64,7 +67,7 @@ int rs690_mc_init(struct radeon_device *rdev) | |||
| 64 | rs400_gart_disable(rdev); | 67 | rs400_gart_disable(rdev); |
| 65 | 68 | ||
| 66 | /* Setup GPU memory space */ | 69 | /* Setup GPU memory space */ |
| 67 | rdev->mc.gtt_location = rdev->mc.vram_size; | 70 | rdev->mc.gtt_location = rdev->mc.mc_vram_size; |
| 68 | rdev->mc.gtt_location += (rdev->mc.gtt_size - 1); | 71 | rdev->mc.gtt_location += (rdev->mc.gtt_size - 1); |
| 69 | rdev->mc.gtt_location &= ~(rdev->mc.gtt_size - 1); | 72 | rdev->mc.gtt_location &= ~(rdev->mc.gtt_size - 1); |
| 70 | rdev->mc.vram_location = 0xFFFFFFFFUL; | 73 | rdev->mc.vram_location = 0xFFFFFFFFUL; |
| @@ -79,7 +82,7 @@ int rs690_mc_init(struct radeon_device *rdev) | |||
| 79 | printk(KERN_WARNING "Failed to wait MC idle while " | 82 | printk(KERN_WARNING "Failed to wait MC idle while " |
| 80 | "programming pipes. Bad things might happen.\n"); | 83 | "programming pipes. Bad things might happen.\n"); |
| 81 | } | 84 | } |
| 82 | tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; | 85 | tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1; |
| 83 | tmp = REG_SET(RS690_MC_FB_TOP, tmp >> 16); | 86 | tmp = REG_SET(RS690_MC_FB_TOP, tmp >> 16); |
| 84 | tmp |= REG_SET(RS690_MC_FB_START, rdev->mc.vram_location >> 16); | 87 | tmp |= REG_SET(RS690_MC_FB_START, rdev->mc.vram_location >> 16); |
| 85 | WREG32_MC(RS690_MCCFG_FB_LOCATION, tmp); | 88 | WREG32_MC(RS690_MCCFG_FB_LOCATION, tmp); |
| @@ -138,9 +141,82 @@ void rs690_gpu_init(struct radeon_device *rdev) | |||
| 138 | /* | 141 | /* |
| 139 | * VRAM info. | 142 | * VRAM info. |
| 140 | */ | 143 | */ |
| 144 | void rs690_pm_info(struct radeon_device *rdev) | ||
| 145 | { | ||
| 146 | int index = GetIndexIntoMasterTable(DATA, IntegratedSystemInfo); | ||
| 147 | struct _ATOM_INTEGRATED_SYSTEM_INFO *info; | ||
| 148 | struct _ATOM_INTEGRATED_SYSTEM_INFO_V2 *info_v2; | ||
| 149 | void *ptr; | ||
| 150 | uint16_t data_offset; | ||
| 151 | uint8_t frev, crev; | ||
| 152 | fixed20_12 tmp; | ||
| 153 | |||
| 154 | atom_parse_data_header(rdev->mode_info.atom_context, index, NULL, | ||
| 155 | &frev, &crev, &data_offset); | ||
| 156 | ptr = rdev->mode_info.atom_context->bios + data_offset; | ||
| 157 | info = (struct _ATOM_INTEGRATED_SYSTEM_INFO *)ptr; | ||
| 158 | info_v2 = (struct _ATOM_INTEGRATED_SYSTEM_INFO_V2 *)ptr; | ||
| 159 | /* Get various system informations from bios */ | ||
| 160 | switch (crev) { | ||
| 161 | case 1: | ||
| 162 | tmp.full = rfixed_const(100); | ||
| 163 | rdev->pm.igp_sideport_mclk.full = rfixed_const(info->ulBootUpMemoryClock); | ||
| 164 | rdev->pm.igp_sideport_mclk.full = rfixed_div(rdev->pm.igp_sideport_mclk, tmp); | ||
| 165 | rdev->pm.igp_system_mclk.full = rfixed_const(le16_to_cpu(info->usK8MemoryClock)); | ||
| 166 | rdev->pm.igp_ht_link_clk.full = rfixed_const(le16_to_cpu(info->usFSBClock)); | ||
| 167 | rdev->pm.igp_ht_link_width.full = rfixed_const(info->ucHTLinkWidth); | ||
| 168 | break; | ||
| 169 | case 2: | ||
| 170 | tmp.full = rfixed_const(100); | ||
| 171 | rdev->pm.igp_sideport_mclk.full = rfixed_const(info_v2->ulBootUpSidePortClock); | ||
| 172 | rdev->pm.igp_sideport_mclk.full = rfixed_div(rdev->pm.igp_sideport_mclk, tmp); | ||
| 173 | rdev->pm.igp_system_mclk.full = rfixed_const(info_v2->ulBootUpUMAClock); | ||
| 174 | rdev->pm.igp_system_mclk.full = rfixed_div(rdev->pm.igp_system_mclk, tmp); | ||
| 175 | rdev->pm.igp_ht_link_clk.full = rfixed_const(info_v2->ulHTLinkFreq); | ||
| 176 | rdev->pm.igp_ht_link_clk.full = rfixed_div(rdev->pm.igp_ht_link_clk, tmp); | ||
| 177 | rdev->pm.igp_ht_link_width.full = rfixed_const(le16_to_cpu(info_v2->usMinHTLinkWidth)); | ||
| 178 | break; | ||
| 179 | default: | ||
| 180 | tmp.full = rfixed_const(100); | ||
| 181 | /* We assume the slower possible clock ie worst case */ | ||
| 182 | /* DDR 333Mhz */ | ||
| 183 | rdev->pm.igp_sideport_mclk.full = rfixed_const(333); | ||
| 184 | /* FIXME: system clock ? */ | ||
| 185 | rdev->pm.igp_system_mclk.full = rfixed_const(100); | ||
| 186 | rdev->pm.igp_system_mclk.full = rfixed_div(rdev->pm.igp_system_mclk, tmp); | ||
| 187 | rdev->pm.igp_ht_link_clk.full = rfixed_const(200); | ||
| 188 | rdev->pm.igp_ht_link_width.full = rfixed_const(8); | ||
| 189 | DRM_ERROR("No integrated system info for your GPU, using safe default\n"); | ||
| 190 | break; | ||
| 191 | } | ||
| 192 | /* Compute various bandwidth */ | ||
| 193 | /* k8_bandwidth = (memory_clk / 2) * 2 * 8 * 0.5 = memory_clk * 4 */ | ||
| 194 | tmp.full = rfixed_const(4); | ||
| 195 | rdev->pm.k8_bandwidth.full = rfixed_mul(rdev->pm.igp_system_mclk, tmp); | ||
| 196 | /* ht_bandwidth = ht_clk * 2 * ht_width / 8 * 0.8 | ||
| 197 | * = ht_clk * ht_width / 5 | ||
| 198 | */ | ||
| 199 | tmp.full = rfixed_const(5); | ||
| 200 | rdev->pm.ht_bandwidth.full = rfixed_mul(rdev->pm.igp_ht_link_clk, | ||
| 201 | rdev->pm.igp_ht_link_width); | ||
| 202 | rdev->pm.ht_bandwidth.full = rfixed_div(rdev->pm.ht_bandwidth, tmp); | ||
| 203 | if (tmp.full < rdev->pm.max_bandwidth.full) { | ||
| 204 | /* HT link is a limiting factor */ | ||
| 205 | rdev->pm.max_bandwidth.full = tmp.full; | ||
| 206 | } | ||
| 207 | /* sideport_bandwidth = (sideport_clk / 2) * 2 * 2 * 0.7 | ||
| 208 | * = (sideport_clk * 14) / 10 | ||
| 209 | */ | ||
| 210 | tmp.full = rfixed_const(14); | ||
| 211 | rdev->pm.sideport_bandwidth.full = rfixed_mul(rdev->pm.igp_sideport_mclk, tmp); | ||
| 212 | tmp.full = rfixed_const(10); | ||
| 213 | rdev->pm.sideport_bandwidth.full = rfixed_div(rdev->pm.sideport_bandwidth, tmp); | ||
| 214 | } | ||
| 215 | |||
| 141 | void rs690_vram_info(struct radeon_device *rdev) | 216 | void rs690_vram_info(struct radeon_device *rdev) |
| 142 | { | 217 | { |
| 143 | uint32_t tmp; | 218 | uint32_t tmp; |
| 219 | fixed20_12 a; | ||
| 144 | 220 | ||
| 145 | rs400_gart_adjust_size(rdev); | 221 | rs400_gart_adjust_size(rdev); |
| 146 | /* DDR for all card after R300 & IGP */ | 222 | /* DDR for all card after R300 & IGP */ |
| @@ -152,12 +228,409 @@ void rs690_vram_info(struct radeon_device *rdev) | |||
| 152 | } else { | 228 | } else { |
| 153 | rdev->mc.vram_width = 64; | 229 | rdev->mc.vram_width = 64; |
| 154 | } | 230 | } |
| 155 | rdev->mc.vram_size = RREG32(RADEON_CONFIG_MEMSIZE); | 231 | rdev->mc.real_vram_size = RREG32(RADEON_CONFIG_MEMSIZE); |
| 232 | rdev->mc.mc_vram_size = rdev->mc.real_vram_size; | ||
| 156 | 233 | ||
| 157 | rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); | 234 | rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); |
| 158 | rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0); | 235 | rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0); |
| 236 | rs690_pm_info(rdev); | ||
| 237 | /* FIXME: we should enforce default clock in case GPU is not in | ||
| 238 | * default setup | ||
| 239 | */ | ||
| 240 | a.full = rfixed_const(100); | ||
| 241 | rdev->pm.sclk.full = rfixed_const(rdev->clock.default_sclk); | ||
| 242 | rdev->pm.sclk.full = rfixed_div(rdev->pm.sclk, a); | ||
| 243 | a.full = rfixed_const(16); | ||
| 244 | /* core_bandwidth = sclk(Mhz) * 16 */ | ||
| 245 | rdev->pm.core_bandwidth.full = rfixed_div(rdev->pm.sclk, a); | ||
| 246 | } | ||
| 247 | |||
| 248 | void rs690_line_buffer_adjust(struct radeon_device *rdev, | ||
| 249 | struct drm_display_mode *mode1, | ||
| 250 | struct drm_display_mode *mode2) | ||
| 251 | { | ||
| 252 | u32 tmp; | ||
| 253 | |||
| 254 | /* | ||
| 255 | * Line Buffer Setup | ||
| 256 | * There is a single line buffer shared by both display controllers. | ||
| 257 | * DC_LB_MEMORY_SPLIT controls how that line buffer is shared between | ||
| 258 | * the display controllers. The paritioning can either be done | ||
| 259 | * manually or via one of four preset allocations specified in bits 1:0: | ||
| 260 | * 0 - line buffer is divided in half and shared between crtc | ||
| 261 | * 1 - D1 gets 3/4 of the line buffer, D2 gets 1/4 | ||
| 262 | * 2 - D1 gets the whole buffer | ||
| 263 | * 3 - D1 gets 1/4 of the line buffer, D2 gets 3/4 | ||
| 264 | * Setting bit 2 of DC_LB_MEMORY_SPLIT controls switches to manual | ||
| 265 | * allocation mode. In manual allocation mode, D1 always starts at 0, | ||
| 266 | * D1 end/2 is specified in bits 14:4; D2 allocation follows D1. | ||
| 267 | */ | ||
| 268 | tmp = RREG32(DC_LB_MEMORY_SPLIT) & ~DC_LB_MEMORY_SPLIT_MASK; | ||
| 269 | tmp &= ~DC_LB_MEMORY_SPLIT_SHIFT_MODE; | ||
| 270 | /* auto */ | ||
| 271 | if (mode1 && mode2) { | ||
| 272 | if (mode1->hdisplay > mode2->hdisplay) { | ||
| 273 | if (mode1->hdisplay > 2560) | ||
| 274 | tmp |= DC_LB_MEMORY_SPLIT_D1_3Q_D2_1Q; | ||
| 275 | else | ||
| 276 | tmp |= DC_LB_MEMORY_SPLIT_D1HALF_D2HALF; | ||
| 277 | } else if (mode2->hdisplay > mode1->hdisplay) { | ||
| 278 | if (mode2->hdisplay > 2560) | ||
| 279 | tmp |= DC_LB_MEMORY_SPLIT_D1_1Q_D2_3Q; | ||
| 280 | else | ||
| 281 | tmp |= DC_LB_MEMORY_SPLIT_D1HALF_D2HALF; | ||
| 282 | } else | ||
| 283 | tmp |= AVIVO_DC_LB_MEMORY_SPLIT_D1HALF_D2HALF; | ||
| 284 | } else if (mode1) { | ||
| 285 | tmp |= DC_LB_MEMORY_SPLIT_D1_ONLY; | ||
| 286 | } else if (mode2) { | ||
| 287 | tmp |= DC_LB_MEMORY_SPLIT_D1_1Q_D2_3Q; | ||
| 288 | } | ||
| 289 | WREG32(DC_LB_MEMORY_SPLIT, tmp); | ||
| 290 | } | ||
| 291 | |||
| 292 | struct rs690_watermark { | ||
| 293 | u32 lb_request_fifo_depth; | ||
| 294 | fixed20_12 num_line_pair; | ||
| 295 | fixed20_12 estimated_width; | ||
| 296 | fixed20_12 worst_case_latency; | ||
| 297 | fixed20_12 consumption_rate; | ||
| 298 | fixed20_12 active_time; | ||
| 299 | fixed20_12 dbpp; | ||
| 300 | fixed20_12 priority_mark_max; | ||
| 301 | fixed20_12 priority_mark; | ||
| 302 | fixed20_12 sclk; | ||
| 303 | }; | ||
| 304 | |||
| 305 | void rs690_crtc_bandwidth_compute(struct radeon_device *rdev, | ||
| 306 | struct radeon_crtc *crtc, | ||
| 307 | struct rs690_watermark *wm) | ||
| 308 | { | ||
| 309 | struct drm_display_mode *mode = &crtc->base.mode; | ||
| 310 | fixed20_12 a, b, c; | ||
| 311 | fixed20_12 pclk, request_fifo_depth, tolerable_latency, estimated_width; | ||
| 312 | fixed20_12 consumption_time, line_time, chunk_time, read_delay_latency; | ||
| 313 | /* FIXME: detect IGP with sideport memory, i don't think there is any | ||
| 314 | * such product available | ||
| 315 | */ | ||
| 316 | bool sideport = false; | ||
| 317 | |||
| 318 | if (!crtc->base.enabled) { | ||
| 319 | /* FIXME: wouldn't it better to set priority mark to maximum */ | ||
| 320 | wm->lb_request_fifo_depth = 4; | ||
| 321 | return; | ||
| 322 | } | ||
| 323 | |||
| 324 | if (crtc->vsc.full > rfixed_const(2)) | ||
| 325 | wm->num_line_pair.full = rfixed_const(2); | ||
| 326 | else | ||
| 327 | wm->num_line_pair.full = rfixed_const(1); | ||
| 328 | |||
| 329 | b.full = rfixed_const(mode->crtc_hdisplay); | ||
| 330 | c.full = rfixed_const(256); | ||
| 331 | a.full = rfixed_mul(wm->num_line_pair, b); | ||
| 332 | request_fifo_depth.full = rfixed_div(a, c); | ||
| 333 | if (a.full < rfixed_const(4)) { | ||
| 334 | wm->lb_request_fifo_depth = 4; | ||
| 335 | } else { | ||
| 336 | wm->lb_request_fifo_depth = rfixed_trunc(request_fifo_depth); | ||
| 337 | } | ||
| 338 | |||
| 339 | /* Determine consumption rate | ||
| 340 | * pclk = pixel clock period(ns) = 1000 / (mode.clock / 1000) | ||
| 341 | * vtaps = number of vertical taps, | ||
| 342 | * vsc = vertical scaling ratio, defined as source/destination | ||
| 343 | * hsc = horizontal scaling ration, defined as source/destination | ||
| 344 | */ | ||
| 345 | a.full = rfixed_const(mode->clock); | ||
| 346 | b.full = rfixed_const(1000); | ||
| 347 | a.full = rfixed_div(a, b); | ||
| 348 | pclk.full = rfixed_div(b, a); | ||
| 349 | if (crtc->rmx_type != RMX_OFF) { | ||
| 350 | b.full = rfixed_const(2); | ||
| 351 | if (crtc->vsc.full > b.full) | ||
| 352 | b.full = crtc->vsc.full; | ||
| 353 | b.full = rfixed_mul(b, crtc->hsc); | ||
| 354 | c.full = rfixed_const(2); | ||
| 355 | b.full = rfixed_div(b, c); | ||
| 356 | consumption_time.full = rfixed_div(pclk, b); | ||
| 357 | } else { | ||
| 358 | consumption_time.full = pclk.full; | ||
| 359 | } | ||
| 360 | a.full = rfixed_const(1); | ||
| 361 | wm->consumption_rate.full = rfixed_div(a, consumption_time); | ||
| 362 | |||
| 363 | |||
| 364 | /* Determine line time | ||
| 365 | * LineTime = total time for one line of displayhtotal | ||
| 366 | * LineTime = total number of horizontal pixels | ||
| 367 | * pclk = pixel clock period(ns) | ||
| 368 | */ | ||
| 369 | a.full = rfixed_const(crtc->base.mode.crtc_htotal); | ||
| 370 | line_time.full = rfixed_mul(a, pclk); | ||
| 371 | |||
| 372 | /* Determine active time | ||
| 373 | * ActiveTime = time of active region of display within one line, | ||
| 374 | * hactive = total number of horizontal active pixels | ||
| 375 | * htotal = total number of horizontal pixels | ||
| 376 | */ | ||
| 377 | a.full = rfixed_const(crtc->base.mode.crtc_htotal); | ||
| 378 | b.full = rfixed_const(crtc->base.mode.crtc_hdisplay); | ||
| 379 | wm->active_time.full = rfixed_mul(line_time, b); | ||
| 380 | wm->active_time.full = rfixed_div(wm->active_time, a); | ||
| 381 | |||
| 382 | /* Maximun bandwidth is the minimun bandwidth of all component */ | ||
| 383 | rdev->pm.max_bandwidth = rdev->pm.core_bandwidth; | ||
| 384 | if (sideport) { | ||
| 385 | if (rdev->pm.max_bandwidth.full > rdev->pm.sideport_bandwidth.full && | ||
| 386 | rdev->pm.sideport_bandwidth.full) | ||
| 387 | rdev->pm.max_bandwidth = rdev->pm.sideport_bandwidth; | ||
| 388 | read_delay_latency.full = rfixed_const(370 * 800 * 1000); | ||
| 389 | read_delay_latency.full = rfixed_div(read_delay_latency, | ||
| 390 | rdev->pm.igp_sideport_mclk); | ||
| 391 | } else { | ||
| 392 | if (rdev->pm.max_bandwidth.full > rdev->pm.k8_bandwidth.full && | ||
| 393 | rdev->pm.k8_bandwidth.full) | ||
| 394 | rdev->pm.max_bandwidth = rdev->pm.k8_bandwidth; | ||
| 395 | if (rdev->pm.max_bandwidth.full > rdev->pm.ht_bandwidth.full && | ||
| 396 | rdev->pm.ht_bandwidth.full) | ||
| 397 | rdev->pm.max_bandwidth = rdev->pm.ht_bandwidth; | ||
| 398 | read_delay_latency.full = rfixed_const(5000); | ||
| 399 | } | ||
| 400 | |||
| 401 | /* sclk = system clocks(ns) = 1000 / max_bandwidth / 16 */ | ||
| 402 | a.full = rfixed_const(16); | ||
| 403 | rdev->pm.sclk.full = rfixed_mul(rdev->pm.max_bandwidth, a); | ||
| 404 | a.full = rfixed_const(1000); | ||
| 405 | rdev->pm.sclk.full = rfixed_div(a, rdev->pm.sclk); | ||
| 406 | /* Determine chunk time | ||
| 407 | * ChunkTime = the time it takes the DCP to send one chunk of data | ||
| 408 | * to the LB which consists of pipeline delay and inter chunk gap | ||
| 409 | * sclk = system clock(ns) | ||
| 410 | */ | ||
| 411 | a.full = rfixed_const(256 * 13); | ||
| 412 | chunk_time.full = rfixed_mul(rdev->pm.sclk, a); | ||
| 413 | a.full = rfixed_const(10); | ||
| 414 | chunk_time.full = rfixed_div(chunk_time, a); | ||
| 415 | |||
| 416 | /* Determine the worst case latency | ||
| 417 | * NumLinePair = Number of line pairs to request(1=2 lines, 2=4 lines) | ||
| 418 | * WorstCaseLatency = worst case time from urgent to when the MC starts | ||
| 419 | * to return data | ||
| 420 | * READ_DELAY_IDLE_MAX = constant of 1us | ||
| 421 | * ChunkTime = time it takes the DCP to send one chunk of data to the LB | ||
| 422 | * which consists of pipeline delay and inter chunk gap | ||
| 423 | */ | ||
| 424 | if (rfixed_trunc(wm->num_line_pair) > 1) { | ||
| 425 | a.full = rfixed_const(3); | ||
| 426 | wm->worst_case_latency.full = rfixed_mul(a, chunk_time); | ||
| 427 | wm->worst_case_latency.full += read_delay_latency.full; | ||
| 428 | } else { | ||
| 429 | a.full = rfixed_const(2); | ||
| 430 | wm->worst_case_latency.full = rfixed_mul(a, chunk_time); | ||
| 431 | wm->worst_case_latency.full += read_delay_latency.full; | ||
| 432 | } | ||
| 433 | |||
| 434 | /* Determine the tolerable latency | ||
| 435 | * TolerableLatency = Any given request has only 1 line time | ||
| 436 | * for the data to be returned | ||
| 437 | * LBRequestFifoDepth = Number of chunk requests the LB can | ||
| 438 | * put into the request FIFO for a display | ||
| 439 | * LineTime = total time for one line of display | ||
| 440 | * ChunkTime = the time it takes the DCP to send one chunk | ||
| 441 | * of data to the LB which consists of | ||
| 442 | * pipeline delay and inter chunk gap | ||
| 443 | */ | ||
| 444 | if ((2+wm->lb_request_fifo_depth) >= rfixed_trunc(request_fifo_depth)) { | ||
| 445 | tolerable_latency.full = line_time.full; | ||
| 446 | } else { | ||
| 447 | tolerable_latency.full = rfixed_const(wm->lb_request_fifo_depth - 2); | ||
| 448 | tolerable_latency.full = request_fifo_depth.full - tolerable_latency.full; | ||
| 449 | tolerable_latency.full = rfixed_mul(tolerable_latency, chunk_time); | ||
| 450 | tolerable_latency.full = line_time.full - tolerable_latency.full; | ||
| 451 | } | ||
| 452 | /* We assume worst case 32bits (4 bytes) */ | ||
| 453 | wm->dbpp.full = rfixed_const(4 * 8); | ||
| 454 | |||
| 455 | /* Determine the maximum priority mark | ||
| 456 | * width = viewport width in pixels | ||
| 457 | */ | ||
| 458 | a.full = rfixed_const(16); | ||
| 459 | wm->priority_mark_max.full = rfixed_const(crtc->base.mode.crtc_hdisplay); | ||
| 460 | wm->priority_mark_max.full = rfixed_div(wm->priority_mark_max, a); | ||
| 461 | |||
| 462 | /* Determine estimated width */ | ||
| 463 | estimated_width.full = tolerable_latency.full - wm->worst_case_latency.full; | ||
| 464 | estimated_width.full = rfixed_div(estimated_width, consumption_time); | ||
| 465 | if (rfixed_trunc(estimated_width) > crtc->base.mode.crtc_hdisplay) { | ||
| 466 | wm->priority_mark.full = rfixed_const(10); | ||
| 467 | } else { | ||
| 468 | a.full = rfixed_const(16); | ||
| 469 | wm->priority_mark.full = rfixed_div(estimated_width, a); | ||
| 470 | wm->priority_mark.full = wm->priority_mark_max.full - wm->priority_mark.full; | ||
| 471 | } | ||
| 159 | } | 472 | } |
| 160 | 473 | ||
| 474 | void rs690_bandwidth_update(struct radeon_device *rdev) | ||
| 475 | { | ||
| 476 | struct drm_display_mode *mode0 = NULL; | ||
| 477 | struct drm_display_mode *mode1 = NULL; | ||
| 478 | struct rs690_watermark wm0; | ||
| 479 | struct rs690_watermark wm1; | ||
| 480 | u32 tmp; | ||
| 481 | fixed20_12 priority_mark02, priority_mark12, fill_rate; | ||
| 482 | fixed20_12 a, b; | ||
| 483 | |||
| 484 | if (rdev->mode_info.crtcs[0]->base.enabled) | ||
| 485 | mode0 = &rdev->mode_info.crtcs[0]->base.mode; | ||
| 486 | if (rdev->mode_info.crtcs[1]->base.enabled) | ||
| 487 | mode1 = &rdev->mode_info.crtcs[1]->base.mode; | ||
| 488 | /* | ||
| 489 | * Set display0/1 priority up in the memory controller for | ||
| 490 | * modes if the user specifies HIGH for displaypriority | ||
| 491 | * option. | ||
| 492 | */ | ||
| 493 | if (rdev->disp_priority == 2) { | ||
| 494 | tmp = RREG32_MC(MC_INIT_MISC_LAT_TIMER); | ||
| 495 | tmp &= ~MC_DISP1R_INIT_LAT_MASK; | ||
| 496 | tmp &= ~MC_DISP0R_INIT_LAT_MASK; | ||
| 497 | if (mode1) | ||
| 498 | tmp |= (1 << MC_DISP1R_INIT_LAT_SHIFT); | ||
| 499 | if (mode0) | ||
| 500 | tmp |= (1 << MC_DISP0R_INIT_LAT_SHIFT); | ||
| 501 | WREG32_MC(MC_INIT_MISC_LAT_TIMER, tmp); | ||
| 502 | } | ||
| 503 | rs690_line_buffer_adjust(rdev, mode0, mode1); | ||
| 504 | |||
| 505 | if ((rdev->family == CHIP_RS690) || (rdev->family == CHIP_RS740)) | ||
| 506 | WREG32(DCP_CONTROL, 0); | ||
| 507 | if ((rdev->family == CHIP_RS780) || (rdev->family == CHIP_RS880)) | ||
| 508 | WREG32(DCP_CONTROL, 2); | ||
| 509 | |||
| 510 | rs690_crtc_bandwidth_compute(rdev, rdev->mode_info.crtcs[0], &wm0); | ||
| 511 | rs690_crtc_bandwidth_compute(rdev, rdev->mode_info.crtcs[1], &wm1); | ||
| 512 | |||
| 513 | tmp = (wm0.lb_request_fifo_depth - 1); | ||
| 514 | tmp |= (wm1.lb_request_fifo_depth - 1) << 16; | ||
| 515 | WREG32(LB_MAX_REQ_OUTSTANDING, tmp); | ||
| 516 | |||
| 517 | if (mode0 && mode1) { | ||
| 518 | if (rfixed_trunc(wm0.dbpp) > 64) | ||
| 519 | a.full = rfixed_mul(wm0.dbpp, wm0.num_line_pair); | ||
| 520 | else | ||
| 521 | a.full = wm0.num_line_pair.full; | ||
| 522 | if (rfixed_trunc(wm1.dbpp) > 64) | ||
| 523 | b.full = rfixed_mul(wm1.dbpp, wm1.num_line_pair); | ||
| 524 | else | ||
| 525 | b.full = wm1.num_line_pair.full; | ||
| 526 | a.full += b.full; | ||
| 527 | fill_rate.full = rfixed_div(wm0.sclk, a); | ||
| 528 | if (wm0.consumption_rate.full > fill_rate.full) { | ||
| 529 | b.full = wm0.consumption_rate.full - fill_rate.full; | ||
| 530 | b.full = rfixed_mul(b, wm0.active_time); | ||
| 531 | a.full = rfixed_mul(wm0.worst_case_latency, | ||
| 532 | wm0.consumption_rate); | ||
| 533 | a.full = a.full + b.full; | ||
| 534 | b.full = rfixed_const(16 * 1000); | ||
| 535 | priority_mark02.full = rfixed_div(a, b); | ||
| 536 | } else { | ||
| 537 | a.full = rfixed_mul(wm0.worst_case_latency, | ||
| 538 | wm0.consumption_rate); | ||
| 539 | b.full = rfixed_const(16 * 1000); | ||
| 540 | priority_mark02.full = rfixed_div(a, b); | ||
| 541 | } | ||
| 542 | if (wm1.consumption_rate.full > fill_rate.full) { | ||
| 543 | b.full = wm1.consumption_rate.full - fill_rate.full; | ||
| 544 | b.full = rfixed_mul(b, wm1.active_time); | ||
| 545 | a.full = rfixed_mul(wm1.worst_case_latency, | ||
| 546 | wm1.consumption_rate); | ||
| 547 | a.full = a.full + b.full; | ||
| 548 | b.full = rfixed_const(16 * 1000); | ||
| 549 | priority_mark12.full = rfixed_div(a, b); | ||
| 550 | } else { | ||
| 551 | a.full = rfixed_mul(wm1.worst_case_latency, | ||
| 552 | wm1.consumption_rate); | ||
| 553 | b.full = rfixed_const(16 * 1000); | ||
| 554 | priority_mark12.full = rfixed_div(a, b); | ||
| 555 | } | ||
| 556 | if (wm0.priority_mark.full > priority_mark02.full) | ||
| 557 | priority_mark02.full = wm0.priority_mark.full; | ||
| 558 | if (rfixed_trunc(priority_mark02) < 0) | ||
| 559 | priority_mark02.full = 0; | ||
| 560 | if (wm0.priority_mark_max.full > priority_mark02.full) | ||
| 561 | priority_mark02.full = wm0.priority_mark_max.full; | ||
| 562 | if (wm1.priority_mark.full > priority_mark12.full) | ||
| 563 | priority_mark12.full = wm1.priority_mark.full; | ||
| 564 | if (rfixed_trunc(priority_mark12) < 0) | ||
| 565 | priority_mark12.full = 0; | ||
| 566 | if (wm1.priority_mark_max.full > priority_mark12.full) | ||
| 567 | priority_mark12.full = wm1.priority_mark_max.full; | ||
| 568 | WREG32(D1MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark02)); | ||
| 569 | WREG32(D1MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark02)); | ||
| 570 | WREG32(D2MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark12)); | ||
| 571 | WREG32(D2MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark12)); | ||
| 572 | } else if (mode0) { | ||
| 573 | if (rfixed_trunc(wm0.dbpp) > 64) | ||
| 574 | a.full = rfixed_mul(wm0.dbpp, wm0.num_line_pair); | ||
| 575 | else | ||
| 576 | a.full = wm0.num_line_pair.full; | ||
| 577 | fill_rate.full = rfixed_div(wm0.sclk, a); | ||
| 578 | if (wm0.consumption_rate.full > fill_rate.full) { | ||
| 579 | b.full = wm0.consumption_rate.full - fill_rate.full; | ||
| 580 | b.full = rfixed_mul(b, wm0.active_time); | ||
| 581 | a.full = rfixed_mul(wm0.worst_case_latency, | ||
| 582 | wm0.consumption_rate); | ||
| 583 | a.full = a.full + b.full; | ||
| 584 | b.full = rfixed_const(16 * 1000); | ||
| 585 | priority_mark02.full = rfixed_div(a, b); | ||
| 586 | } else { | ||
| 587 | a.full = rfixed_mul(wm0.worst_case_latency, | ||
| 588 | wm0.consumption_rate); | ||
| 589 | b.full = rfixed_const(16 * 1000); | ||
| 590 | priority_mark02.full = rfixed_div(a, b); | ||
| 591 | } | ||
| 592 | if (wm0.priority_mark.full > priority_mark02.full) | ||
| 593 | priority_mark02.full = wm0.priority_mark.full; | ||
| 594 | if (rfixed_trunc(priority_mark02) < 0) | ||
| 595 | priority_mark02.full = 0; | ||
| 596 | if (wm0.priority_mark_max.full > priority_mark02.full) | ||
| 597 | priority_mark02.full = wm0.priority_mark_max.full; | ||
| 598 | WREG32(D1MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark02)); | ||
| 599 | WREG32(D1MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark02)); | ||
| 600 | WREG32(D2MODE_PRIORITY_A_CNT, MODE_PRIORITY_OFF); | ||
| 601 | WREG32(D2MODE_PRIORITY_B_CNT, MODE_PRIORITY_OFF); | ||
| 602 | } else { | ||
| 603 | if (rfixed_trunc(wm1.dbpp) > 64) | ||
| 604 | a.full = rfixed_mul(wm1.dbpp, wm1.num_line_pair); | ||
| 605 | else | ||
| 606 | a.full = wm1.num_line_pair.full; | ||
| 607 | fill_rate.full = rfixed_div(wm1.sclk, a); | ||
| 608 | if (wm1.consumption_rate.full > fill_rate.full) { | ||
| 609 | b.full = wm1.consumption_rate.full - fill_rate.full; | ||
| 610 | b.full = rfixed_mul(b, wm1.active_time); | ||
| 611 | a.full = rfixed_mul(wm1.worst_case_latency, | ||
| 612 | wm1.consumption_rate); | ||
| 613 | a.full = a.full + b.full; | ||
| 614 | b.full = rfixed_const(16 * 1000); | ||
| 615 | priority_mark12.full = rfixed_div(a, b); | ||
| 616 | } else { | ||
| 617 | a.full = rfixed_mul(wm1.worst_case_latency, | ||
| 618 | wm1.consumption_rate); | ||
| 619 | b.full = rfixed_const(16 * 1000); | ||
| 620 | priority_mark12.full = rfixed_div(a, b); | ||
| 621 | } | ||
| 622 | if (wm1.priority_mark.full > priority_mark12.full) | ||
| 623 | priority_mark12.full = wm1.priority_mark.full; | ||
| 624 | if (rfixed_trunc(priority_mark12) < 0) | ||
| 625 | priority_mark12.full = 0; | ||
| 626 | if (wm1.priority_mark_max.full > priority_mark12.full) | ||
| 627 | priority_mark12.full = wm1.priority_mark_max.full; | ||
| 628 | WREG32(D1MODE_PRIORITY_A_CNT, MODE_PRIORITY_OFF); | ||
| 629 | WREG32(D1MODE_PRIORITY_B_CNT, MODE_PRIORITY_OFF); | ||
| 630 | WREG32(D2MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark12)); | ||
| 631 | WREG32(D2MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark12)); | ||
| 632 | } | ||
| 633 | } | ||
| 161 | 634 | ||
| 162 | /* | 635 | /* |
| 163 | * Indirect registers accessor | 636 | * Indirect registers accessor |
| @@ -179,3 +652,68 @@ void rs690_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v) | |||
| 179 | WREG32(RS690_MC_DATA, v); | 652 | WREG32(RS690_MC_DATA, v); |
| 180 | WREG32(RS690_MC_INDEX, RS690_MC_INDEX_WR_ACK); | 653 | WREG32(RS690_MC_INDEX, RS690_MC_INDEX_WR_ACK); |
| 181 | } | 654 | } |
| 655 | |||
| 656 | static const unsigned rs690_reg_safe_bm[219] = { | ||
| 657 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 658 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 659 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 660 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 661 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 662 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 663 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 664 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 665 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 666 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 667 | 0x17FF1FFF,0xFFFFFFFC,0xFFFFFFFF,0xFF30FFBF, | ||
| 668 | 0xFFFFFFF8,0xC3E6FFFF,0xFFFFF6DF,0xFFFFFFFF, | ||
| 669 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 670 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 671 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFF03F, | ||
| 672 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 673 | 0xFFFFFFFF,0xFFFFEFCE,0xF00EBFFF,0x007C0000, | ||
| 674 | 0xF0000078,0xFF000009,0xFFFFFFFF,0xFFFFFFFF, | ||
| 675 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 676 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 677 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 678 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 679 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 680 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 681 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 682 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 683 | 0xFFFFF7FF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 684 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 685 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 686 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 687 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 688 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 689 | 0xFFFFFC78,0xFFFFFFFF,0xFFFFFFFE,0xFFFFFFFF, | ||
| 690 | 0x38FF8F50,0xFFF88082,0xF000000C,0xFAE009FF, | ||
| 691 | 0x0000FFFF,0xFFFFFFFF,0xFFFFFFFF,0x00000000, | ||
| 692 | 0x00000000,0x0000C100,0x00000000,0x00000000, | ||
| 693 | 0x00000000,0x00000000,0x00000000,0x00000000, | ||
| 694 | 0x00000000,0xFFFF0000,0xFFFFFFFF,0xFF80FFFF, | ||
| 695 | 0x00000000,0x00000000,0x00000000,0x00000000, | ||
| 696 | 0x0003FC01,0xFFFFFFF8,0xFE800B19,0xFFFFFFFF, | ||
| 697 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 698 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 699 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 700 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 701 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 702 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 703 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 704 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 705 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 706 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 707 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 708 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 709 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 710 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 711 | 0xFFFFFFFF,0xFFFFFFFF,0xFFFFFFFF, | ||
| 712 | }; | ||
| 713 | |||
| 714 | int rs690_init(struct radeon_device *rdev) | ||
| 715 | { | ||
| 716 | rdev->config.r300.reg_safe_bm = rs690_reg_safe_bm; | ||
| 717 | rdev->config.r300.reg_safe_bm_size = ARRAY_SIZE(rs690_reg_safe_bm); | ||
| 718 | return 0; | ||
| 719 | } | ||
diff --git a/drivers/gpu/drm/radeon/rs690r.h b/drivers/gpu/drm/radeon/rs690r.h new file mode 100644 index 000000000000..c0d9faa2175b --- /dev/null +++ b/drivers/gpu/drm/radeon/rs690r.h | |||
| @@ -0,0 +1,99 @@ | |||
| 1 | /* | ||
| 2 | * Copyright 2008 Advanced Micro Devices, Inc. | ||
| 3 | * Copyright 2008 Red Hat Inc. | ||
| 4 | * Copyright 2009 Jerome Glisse. | ||
| 5 | * | ||
| 6 | * Permission is hereby granted, free of charge, to any person obtaining a | ||
| 7 | * copy of this software and associated documentation files (the "Software"), | ||
| 8 | * to deal in the Software without restriction, including without limitation | ||
| 9 | * the rights to use, copy, modify, merge, publish, distribute, sublicense, | ||
| 10 | * and/or sell copies of the Software, and to permit persons to whom the | ||
| 11 | * Software is furnished to do so, subject to the following conditions: | ||
| 12 | * | ||
| 13 | * The above copyright notice and this permission notice shall be included in | ||
| 14 | * all copies or substantial portions of the Software. | ||
| 15 | * | ||
| 16 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
| 17 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
| 18 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL | ||
| 19 | * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR | ||
| 20 | * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, | ||
| 21 | * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR | ||
| 22 | * OTHER DEALINGS IN THE SOFTWARE. | ||
| 23 | * | ||
| 24 | * Authors: Dave Airlie | ||
| 25 | * Alex Deucher | ||
| 26 | * Jerome Glisse | ||
| 27 | */ | ||
| 28 | #ifndef RS690R_H | ||
| 29 | #define RS690R_H | ||
| 30 | |||
| 31 | /* RS690/RS740 registers */ | ||
| 32 | #define MC_INDEX 0x0078 | ||
| 33 | # define MC_INDEX_MASK 0x1FF | ||
| 34 | # define MC_INDEX_WR_EN (1 << 9) | ||
| 35 | # define MC_INDEX_WR_ACK 0x7F | ||
| 36 | #define MC_DATA 0x007C | ||
| 37 | #define HDP_FB_LOCATION 0x0134 | ||
| 38 | #define DC_LB_MEMORY_SPLIT 0x6520 | ||
| 39 | #define DC_LB_MEMORY_SPLIT_MASK 0x00000003 | ||
| 40 | #define DC_LB_MEMORY_SPLIT_SHIFT 0 | ||
| 41 | #define DC_LB_MEMORY_SPLIT_D1HALF_D2HALF 0 | ||
| 42 | #define DC_LB_MEMORY_SPLIT_D1_3Q_D2_1Q 1 | ||
| 43 | #define DC_LB_MEMORY_SPLIT_D1_ONLY 2 | ||
| 44 | #define DC_LB_MEMORY_SPLIT_D1_1Q_D2_3Q 3 | ||
| 45 | #define DC_LB_MEMORY_SPLIT_SHIFT_MODE (1 << 2) | ||
| 46 | #define DC_LB_DISP1_END_ADR_SHIFT 4 | ||
| 47 | #define DC_LB_DISP1_END_ADR_MASK 0x00007FF0 | ||
| 48 | #define D1MODE_PRIORITY_A_CNT 0x6548 | ||
| 49 | #define MODE_PRIORITY_MARK_MASK 0x00007FFF | ||
| 50 | #define MODE_PRIORITY_OFF (1 << 16) | ||
| 51 | #define MODE_PRIORITY_ALWAYS_ON (1 << 20) | ||
| 52 | #define MODE_PRIORITY_FORCE_MASK (1 << 24) | ||
| 53 | #define D1MODE_PRIORITY_B_CNT 0x654C | ||
| 54 | #define LB_MAX_REQ_OUTSTANDING 0x6D58 | ||
| 55 | #define LB_D1_MAX_REQ_OUTSTANDING_MASK 0x0000000F | ||
| 56 | #define LB_D1_MAX_REQ_OUTSTANDING_SHIFT 0 | ||
| 57 | #define LB_D2_MAX_REQ_OUTSTANDING_MASK 0x000F0000 | ||
| 58 | #define LB_D2_MAX_REQ_OUTSTANDING_SHIFT 16 | ||
| 59 | #define DCP_CONTROL 0x6C9C | ||
| 60 | #define D2MODE_PRIORITY_A_CNT 0x6D48 | ||
| 61 | #define D2MODE_PRIORITY_B_CNT 0x6D4C | ||
| 62 | |||
| 63 | /* MC indirect registers */ | ||
| 64 | #define MC_STATUS_IDLE (1 << 0) | ||
| 65 | #define MC_MISC_CNTL 0x18 | ||
| 66 | #define DISABLE_GTW (1 << 1) | ||
| 67 | #define GART_INDEX_REG_EN (1 << 12) | ||
| 68 | #define BLOCK_GFX_D3_EN (1 << 14) | ||
| 69 | #define GART_FEATURE_ID 0x2B | ||
| 70 | #define HANG_EN (1 << 11) | ||
| 71 | #define TLB_ENABLE (1 << 18) | ||
| 72 | #define P2P_ENABLE (1 << 19) | ||
| 73 | #define GTW_LAC_EN (1 << 25) | ||
| 74 | #define LEVEL2_GART (0 << 30) | ||
| 75 | #define LEVEL1_GART (1 << 30) | ||
| 76 | #define PDC_EN (1 << 31) | ||
| 77 | #define GART_BASE 0x2C | ||
| 78 | #define GART_CACHE_CNTRL 0x2E | ||
| 79 | # define GART_CACHE_INVALIDATE (1 << 0) | ||
| 80 | #define MC_STATUS 0x90 | ||
| 81 | #define MCCFG_FB_LOCATION 0x100 | ||
| 82 | #define MC_FB_START_MASK 0x0000FFFF | ||
| 83 | #define MC_FB_START_SHIFT 0 | ||
| 84 | #define MC_FB_TOP_MASK 0xFFFF0000 | ||
| 85 | #define MC_FB_TOP_SHIFT 16 | ||
| 86 | #define MCCFG_AGP_LOCATION 0x101 | ||
| 87 | #define MC_AGP_START_MASK 0x0000FFFF | ||
| 88 | #define MC_AGP_START_SHIFT 0 | ||
| 89 | #define MC_AGP_TOP_MASK 0xFFFF0000 | ||
| 90 | #define MC_AGP_TOP_SHIFT 16 | ||
| 91 | #define MCCFG_AGP_BASE 0x102 | ||
| 92 | #define MCCFG_AGP_BASE_2 0x103 | ||
| 93 | #define MC_INIT_MISC_LAT_TIMER 0x104 | ||
| 94 | #define MC_DISP0R_INIT_LAT_SHIFT 8 | ||
| 95 | #define MC_DISP0R_INIT_LAT_MASK 0x00000F00 | ||
| 96 | #define MC_DISP1R_INIT_LAT_SHIFT 12 | ||
| 97 | #define MC_DISP1R_INIT_LAT_MASK 0x0000F000 | ||
| 98 | |||
| 99 | #endif | ||
diff --git a/drivers/gpu/drm/radeon/rv515.c b/drivers/gpu/drm/radeon/rv515.c index ffea37b1b3e2..31a7f668ae5a 100644 --- a/drivers/gpu/drm/radeon/rv515.c +++ b/drivers/gpu/drm/radeon/rv515.c | |||
| @@ -27,8 +27,9 @@ | |||
| 27 | */ | 27 | */ |
| 28 | #include <linux/seq_file.h> | 28 | #include <linux/seq_file.h> |
| 29 | #include "drmP.h" | 29 | #include "drmP.h" |
| 30 | #include "radeon_reg.h" | 30 | #include "rv515r.h" |
| 31 | #include "radeon.h" | 31 | #include "radeon.h" |
| 32 | #include "radeon_share.h" | ||
| 32 | 33 | ||
| 33 | /* rv515 depends on : */ | 34 | /* rv515 depends on : */ |
| 34 | void r100_hdp_reset(struct radeon_device *rdev); | 35 | void r100_hdp_reset(struct radeon_device *rdev); |
| @@ -99,26 +100,26 @@ int rv515_mc_init(struct radeon_device *rdev) | |||
| 99 | "programming pipes. Bad things might happen.\n"); | 100 | "programming pipes. Bad things might happen.\n"); |
| 100 | } | 101 | } |
| 101 | /* Write VRAM size in case we are limiting it */ | 102 | /* Write VRAM size in case we are limiting it */ |
| 102 | WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.vram_size); | 103 | WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.real_vram_size); |
| 103 | tmp = REG_SET(RV515_MC_FB_START, rdev->mc.vram_location >> 16); | 104 | tmp = REG_SET(MC_FB_START, rdev->mc.vram_location >> 16); |
| 104 | WREG32(0x134, tmp); | 105 | WREG32(0x134, tmp); |
| 105 | tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; | 106 | tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1; |
| 106 | tmp = REG_SET(RV515_MC_FB_TOP, tmp >> 16); | 107 | tmp = REG_SET(MC_FB_TOP, tmp >> 16); |
| 107 | tmp |= REG_SET(RV515_MC_FB_START, rdev->mc.vram_location >> 16); | 108 | tmp |= REG_SET(MC_FB_START, rdev->mc.vram_location >> 16); |
| 108 | WREG32_MC(RV515_MC_FB_LOCATION, tmp); | 109 | WREG32_MC(MC_FB_LOCATION, tmp); |
| 109 | WREG32(RS690_HDP_FB_LOCATION, rdev->mc.vram_location >> 16); | 110 | WREG32(HDP_FB_LOCATION, rdev->mc.vram_location >> 16); |
| 110 | WREG32(0x310, rdev->mc.vram_location); | 111 | WREG32(0x310, rdev->mc.vram_location); |
| 111 | if (rdev->flags & RADEON_IS_AGP) { | 112 | if (rdev->flags & RADEON_IS_AGP) { |
| 112 | tmp = rdev->mc.gtt_location + rdev->mc.gtt_size - 1; | 113 | tmp = rdev->mc.gtt_location + rdev->mc.gtt_size - 1; |
| 113 | tmp = REG_SET(RV515_MC_AGP_TOP, tmp >> 16); | 114 | tmp = REG_SET(MC_AGP_TOP, tmp >> 16); |
| 114 | tmp |= REG_SET(RV515_MC_AGP_START, rdev->mc.gtt_location >> 16); | 115 | tmp |= REG_SET(MC_AGP_START, rdev->mc.gtt_location >> 16); |
| 115 | WREG32_MC(RV515_MC_AGP_LOCATION, tmp); | 116 | WREG32_MC(MC_AGP_LOCATION, tmp); |
| 116 | WREG32_MC(RV515_MC_AGP_BASE, rdev->mc.agp_base); | 117 | WREG32_MC(MC_AGP_BASE, rdev->mc.agp_base); |
| 117 | WREG32_MC(RV515_MC_AGP_BASE_2, 0); | 118 | WREG32_MC(MC_AGP_BASE_2, 0); |
| 118 | } else { | 119 | } else { |
| 119 | WREG32_MC(RV515_MC_AGP_LOCATION, 0x0FFFFFFF); | 120 | WREG32_MC(MC_AGP_LOCATION, 0x0FFFFFFF); |
| 120 | WREG32_MC(RV515_MC_AGP_BASE, 0); | 121 | WREG32_MC(MC_AGP_BASE, 0); |
| 121 | WREG32_MC(RV515_MC_AGP_BASE_2, 0); | 122 | WREG32_MC(MC_AGP_BASE_2, 0); |
| 122 | } | 123 | } |
| 123 | return 0; | 124 | return 0; |
| 124 | } | 125 | } |
| @@ -136,95 +137,67 @@ void rv515_mc_fini(struct radeon_device *rdev) | |||
| 136 | */ | 137 | */ |
| 137 | void rv515_ring_start(struct radeon_device *rdev) | 138 | void rv515_ring_start(struct radeon_device *rdev) |
| 138 | { | 139 | { |
| 139 | unsigned gb_tile_config; | ||
| 140 | int r; | 140 | int r; |
| 141 | 141 | ||
| 142 | /* Sub pixel 1/12 so we can have 4K rendering according to doc */ | ||
| 143 | gb_tile_config = R300_ENABLE_TILING | R300_TILE_SIZE_16; | ||
| 144 | switch (rdev->num_gb_pipes) { | ||
| 145 | case 2: | ||
| 146 | gb_tile_config |= R300_PIPE_COUNT_R300; | ||
| 147 | break; | ||
| 148 | case 3: | ||
| 149 | gb_tile_config |= R300_PIPE_COUNT_R420_3P; | ||
| 150 | break; | ||
| 151 | case 4: | ||
| 152 | gb_tile_config |= R300_PIPE_COUNT_R420; | ||
| 153 | break; | ||
| 154 | case 1: | ||
| 155 | default: | ||
| 156 | gb_tile_config |= R300_PIPE_COUNT_RV350; | ||
| 157 | break; | ||
| 158 | } | ||
| 159 | |||
| 160 | r = radeon_ring_lock(rdev, 64); | 142 | r = radeon_ring_lock(rdev, 64); |
| 161 | if (r) { | 143 | if (r) { |
| 162 | return; | 144 | return; |
| 163 | } | 145 | } |
| 164 | radeon_ring_write(rdev, PACKET0(RADEON_ISYNC_CNTL, 0)); | 146 | radeon_ring_write(rdev, PACKET0(ISYNC_CNTL, 0)); |
| 165 | radeon_ring_write(rdev, | ||
| 166 | RADEON_ISYNC_ANY2D_IDLE3D | | ||
| 167 | RADEON_ISYNC_ANY3D_IDLE2D | | ||
| 168 | RADEON_ISYNC_WAIT_IDLEGUI | | ||
| 169 | RADEON_ISYNC_CPSCRATCH_IDLEGUI); | ||
| 170 | radeon_ring_write(rdev, PACKET0(R300_GB_TILE_CONFIG, 0)); | ||
| 171 | radeon_ring_write(rdev, gb_tile_config); | ||
| 172 | radeon_ring_write(rdev, PACKET0(RADEON_WAIT_UNTIL, 0)); | ||
| 173 | radeon_ring_write(rdev, | 147 | radeon_ring_write(rdev, |
| 174 | RADEON_WAIT_2D_IDLECLEAN | | 148 | ISYNC_ANY2D_IDLE3D | |
| 175 | RADEON_WAIT_3D_IDLECLEAN); | 149 | ISYNC_ANY3D_IDLE2D | |
| 150 | ISYNC_WAIT_IDLEGUI | | ||
| 151 | ISYNC_CPSCRATCH_IDLEGUI); | ||
| 152 | radeon_ring_write(rdev, PACKET0(WAIT_UNTIL, 0)); | ||
| 153 | radeon_ring_write(rdev, WAIT_2D_IDLECLEAN | WAIT_3D_IDLECLEAN); | ||
| 176 | radeon_ring_write(rdev, PACKET0(0x170C, 0)); | 154 | radeon_ring_write(rdev, PACKET0(0x170C, 0)); |
| 177 | radeon_ring_write(rdev, 1 << 31); | 155 | radeon_ring_write(rdev, 1 << 31); |
| 178 | radeon_ring_write(rdev, PACKET0(R300_GB_SELECT, 0)); | 156 | radeon_ring_write(rdev, PACKET0(GB_SELECT, 0)); |
| 179 | radeon_ring_write(rdev, 0); | 157 | radeon_ring_write(rdev, 0); |
| 180 | radeon_ring_write(rdev, PACKET0(R300_GB_ENABLE, 0)); | 158 | radeon_ring_write(rdev, PACKET0(GB_ENABLE, 0)); |
| 181 | radeon_ring_write(rdev, 0); | 159 | radeon_ring_write(rdev, 0); |
| 182 | radeon_ring_write(rdev, PACKET0(0x42C8, 0)); | 160 | radeon_ring_write(rdev, PACKET0(0x42C8, 0)); |
| 183 | radeon_ring_write(rdev, (1 << rdev->num_gb_pipes) - 1); | 161 | radeon_ring_write(rdev, (1 << rdev->num_gb_pipes) - 1); |
| 184 | radeon_ring_write(rdev, PACKET0(R500_VAP_INDEX_OFFSET, 0)); | 162 | radeon_ring_write(rdev, PACKET0(VAP_INDEX_OFFSET, 0)); |
| 185 | radeon_ring_write(rdev, 0); | 163 | radeon_ring_write(rdev, 0); |
| 186 | radeon_ring_write(rdev, PACKET0(R300_RB3D_DSTCACHE_CTLSTAT, 0)); | 164 | radeon_ring_write(rdev, PACKET0(RB3D_DSTCACHE_CTLSTAT, 0)); |
| 187 | radeon_ring_write(rdev, R300_RB3D_DC_FLUSH | R300_RB3D_DC_FREE); | 165 | radeon_ring_write(rdev, RB3D_DC_FLUSH | RB3D_DC_FREE); |
| 188 | radeon_ring_write(rdev, PACKET0(R300_RB3D_ZCACHE_CTLSTAT, 0)); | 166 | radeon_ring_write(rdev, PACKET0(ZB_ZCACHE_CTLSTAT, 0)); |
| 189 | radeon_ring_write(rdev, R300_ZC_FLUSH | R300_ZC_FREE); | 167 | radeon_ring_write(rdev, ZC_FLUSH | ZC_FREE); |
| 190 | radeon_ring_write(rdev, PACKET0(RADEON_WAIT_UNTIL, 0)); | 168 | radeon_ring_write(rdev, PACKET0(WAIT_UNTIL, 0)); |
| 191 | radeon_ring_write(rdev, | 169 | radeon_ring_write(rdev, WAIT_2D_IDLECLEAN | WAIT_3D_IDLECLEAN); |
| 192 | RADEON_WAIT_2D_IDLECLEAN | | 170 | radeon_ring_write(rdev, PACKET0(GB_AA_CONFIG, 0)); |
| 193 | RADEON_WAIT_3D_IDLECLEAN); | ||
| 194 | radeon_ring_write(rdev, PACKET0(R300_GB_AA_CONFIG, 0)); | ||
| 195 | radeon_ring_write(rdev, 0); | 171 | radeon_ring_write(rdev, 0); |
| 196 | radeon_ring_write(rdev, PACKET0(R300_RB3D_DSTCACHE_CTLSTAT, 0)); | 172 | radeon_ring_write(rdev, PACKET0(RB3D_DSTCACHE_CTLSTAT, 0)); |
| 197 | radeon_ring_write(rdev, R300_RB3D_DC_FLUSH | R300_RB3D_DC_FREE); | 173 | radeon_ring_write(rdev, RB3D_DC_FLUSH | RB3D_DC_FREE); |
| 198 | radeon_ring_write(rdev, PACKET0(R300_RB3D_ZCACHE_CTLSTAT, 0)); | 174 | radeon_ring_write(rdev, PACKET0(ZB_ZCACHE_CTLSTAT, 0)); |
| 199 | radeon_ring_write(rdev, R300_ZC_FLUSH | R300_ZC_FREE); | 175 | radeon_ring_write(rdev, ZC_FLUSH | ZC_FREE); |
| 200 | radeon_ring_write(rdev, PACKET0(R300_GB_MSPOS0, 0)); | 176 | radeon_ring_write(rdev, PACKET0(GB_MSPOS0, 0)); |
| 201 | radeon_ring_write(rdev, | ||
| 202 | ((6 << R300_MS_X0_SHIFT) | | ||
| 203 | (6 << R300_MS_Y0_SHIFT) | | ||
| 204 | (6 << R300_MS_X1_SHIFT) | | ||
| 205 | (6 << R300_MS_Y1_SHIFT) | | ||
| 206 | (6 << R300_MS_X2_SHIFT) | | ||
| 207 | (6 << R300_MS_Y2_SHIFT) | | ||
| 208 | (6 << R300_MSBD0_Y_SHIFT) | | ||
| 209 | (6 << R300_MSBD0_X_SHIFT))); | ||
| 210 | radeon_ring_write(rdev, PACKET0(R300_GB_MSPOS1, 0)); | ||
| 211 | radeon_ring_write(rdev, | ||
| 212 | ((6 << R300_MS_X3_SHIFT) | | ||
| 213 | (6 << R300_MS_Y3_SHIFT) | | ||
| 214 | (6 << R300_MS_X4_SHIFT) | | ||
| 215 | (6 << R300_MS_Y4_SHIFT) | | ||
| 216 | (6 << R300_MS_X5_SHIFT) | | ||
| 217 | (6 << R300_MS_Y5_SHIFT) | | ||
| 218 | (6 << R300_MSBD1_SHIFT))); | ||
| 219 | radeon_ring_write(rdev, PACKET0(R300_GA_ENHANCE, 0)); | ||
| 220 | radeon_ring_write(rdev, R300_GA_DEADLOCK_CNTL | R300_GA_FASTSYNC_CNTL); | ||
| 221 | radeon_ring_write(rdev, PACKET0(R300_GA_POLY_MODE, 0)); | ||
| 222 | radeon_ring_write(rdev, | 177 | radeon_ring_write(rdev, |
| 223 | R300_FRONT_PTYPE_TRIANGE | R300_BACK_PTYPE_TRIANGE); | 178 | ((6 << MS_X0_SHIFT) | |
| 224 | radeon_ring_write(rdev, PACKET0(R300_GA_ROUND_MODE, 0)); | 179 | (6 << MS_Y0_SHIFT) | |
| 180 | (6 << MS_X1_SHIFT) | | ||
| 181 | (6 << MS_Y1_SHIFT) | | ||
| 182 | (6 << MS_X2_SHIFT) | | ||
| 183 | (6 << MS_Y2_SHIFT) | | ||
| 184 | (6 << MSBD0_Y_SHIFT) | | ||
| 185 | (6 << MSBD0_X_SHIFT))); | ||
| 186 | radeon_ring_write(rdev, PACKET0(GB_MSPOS1, 0)); | ||
| 225 | radeon_ring_write(rdev, | 187 | radeon_ring_write(rdev, |
| 226 | R300_GEOMETRY_ROUND_NEAREST | | 188 | ((6 << MS_X3_SHIFT) | |
| 227 | R300_COLOR_ROUND_NEAREST); | 189 | (6 << MS_Y3_SHIFT) | |
| 190 | (6 << MS_X4_SHIFT) | | ||
| 191 | (6 << MS_Y4_SHIFT) | | ||
| 192 | (6 << MS_X5_SHIFT) | | ||
| 193 | (6 << MS_Y5_SHIFT) | | ||
| 194 | (6 << MSBD1_SHIFT))); | ||
| 195 | radeon_ring_write(rdev, PACKET0(GA_ENHANCE, 0)); | ||
| 196 | radeon_ring_write(rdev, GA_DEADLOCK_CNTL | GA_FASTSYNC_CNTL); | ||
| 197 | radeon_ring_write(rdev, PACKET0(GA_POLY_MODE, 0)); | ||
| 198 | radeon_ring_write(rdev, FRONT_PTYPE_TRIANGE | BACK_PTYPE_TRIANGE); | ||
| 199 | radeon_ring_write(rdev, PACKET0(GA_ROUND_MODE, 0)); | ||
| 200 | radeon_ring_write(rdev, GEOMETRY_ROUND_NEAREST | COLOR_ROUND_NEAREST); | ||
| 228 | radeon_ring_write(rdev, PACKET0(0x20C8, 0)); | 201 | radeon_ring_write(rdev, PACKET0(0x20C8, 0)); |
| 229 | radeon_ring_write(rdev, 0); | 202 | radeon_ring_write(rdev, 0); |
| 230 | radeon_ring_unlock_commit(rdev); | 203 | radeon_ring_unlock_commit(rdev); |
| @@ -242,8 +215,8 @@ int rv515_mc_wait_for_idle(struct radeon_device *rdev) | |||
| 242 | 215 | ||
| 243 | for (i = 0; i < rdev->usec_timeout; i++) { | 216 | for (i = 0; i < rdev->usec_timeout; i++) { |
| 244 | /* read MC_STATUS */ | 217 | /* read MC_STATUS */ |
| 245 | tmp = RREG32_MC(RV515_MC_STATUS); | 218 | tmp = RREG32_MC(MC_STATUS); |
| 246 | if (tmp & RV515_MC_STATUS_IDLE) { | 219 | if (tmp & MC_STATUS_IDLE) { |
| 247 | return 0; | 220 | return 0; |
| 248 | } | 221 | } |
| 249 | DRM_UDELAY(1); | 222 | DRM_UDELAY(1); |
| @@ -291,33 +264,33 @@ int rv515_ga_reset(struct radeon_device *rdev) | |||
| 291 | reinit_cp = rdev->cp.ready; | 264 | reinit_cp = rdev->cp.ready; |
| 292 | rdev->cp.ready = false; | 265 | rdev->cp.ready = false; |
| 293 | for (i = 0; i < rdev->usec_timeout; i++) { | 266 | for (i = 0; i < rdev->usec_timeout; i++) { |
| 294 | WREG32(RADEON_CP_CSQ_MODE, 0); | 267 | WREG32(CP_CSQ_MODE, 0); |
| 295 | WREG32(RADEON_CP_CSQ_CNTL, 0); | 268 | WREG32(CP_CSQ_CNTL, 0); |
| 296 | WREG32(RADEON_RBBM_SOFT_RESET, 0x32005); | 269 | WREG32(RBBM_SOFT_RESET, 0x32005); |
| 297 | (void)RREG32(RADEON_RBBM_SOFT_RESET); | 270 | (void)RREG32(RBBM_SOFT_RESET); |
| 298 | udelay(200); | 271 | udelay(200); |
| 299 | WREG32(RADEON_RBBM_SOFT_RESET, 0); | 272 | WREG32(RBBM_SOFT_RESET, 0); |
| 300 | /* Wait to prevent race in RBBM_STATUS */ | 273 | /* Wait to prevent race in RBBM_STATUS */ |
| 301 | mdelay(1); | 274 | mdelay(1); |
| 302 | tmp = RREG32(RADEON_RBBM_STATUS); | 275 | tmp = RREG32(RBBM_STATUS); |
| 303 | if (tmp & ((1 << 20) | (1 << 26))) { | 276 | if (tmp & ((1 << 20) | (1 << 26))) { |
| 304 | DRM_ERROR("VAP & CP still busy (RBBM_STATUS=0x%08X)\n", tmp); | 277 | DRM_ERROR("VAP & CP still busy (RBBM_STATUS=0x%08X)\n", tmp); |
| 305 | /* GA still busy soft reset it */ | 278 | /* GA still busy soft reset it */ |
| 306 | WREG32(0x429C, 0x200); | 279 | WREG32(0x429C, 0x200); |
| 307 | WREG32(R300_VAP_PVS_STATE_FLUSH_REG, 0); | 280 | WREG32(VAP_PVS_STATE_FLUSH_REG, 0); |
| 308 | WREG32(0x43E0, 0); | 281 | WREG32(0x43E0, 0); |
| 309 | WREG32(0x43E4, 0); | 282 | WREG32(0x43E4, 0); |
| 310 | WREG32(0x24AC, 0); | 283 | WREG32(0x24AC, 0); |
| 311 | } | 284 | } |
| 312 | /* Wait to prevent race in RBBM_STATUS */ | 285 | /* Wait to prevent race in RBBM_STATUS */ |
| 313 | mdelay(1); | 286 | mdelay(1); |
| 314 | tmp = RREG32(RADEON_RBBM_STATUS); | 287 | tmp = RREG32(RBBM_STATUS); |
| 315 | if (!(tmp & ((1 << 20) | (1 << 26)))) { | 288 | if (!(tmp & ((1 << 20) | (1 << 26)))) { |
| 316 | break; | 289 | break; |
| 317 | } | 290 | } |
| 318 | } | 291 | } |
| 319 | for (i = 0; i < rdev->usec_timeout; i++) { | 292 | for (i = 0; i < rdev->usec_timeout; i++) { |
| 320 | tmp = RREG32(RADEON_RBBM_STATUS); | 293 | tmp = RREG32(RBBM_STATUS); |
| 321 | if (!(tmp & ((1 << 20) | (1 << 26)))) { | 294 | if (!(tmp & ((1 << 20) | (1 << 26)))) { |
| 322 | DRM_INFO("GA reset succeed (RBBM_STATUS=0x%08X)\n", | 295 | DRM_INFO("GA reset succeed (RBBM_STATUS=0x%08X)\n", |
| 323 | tmp); | 296 | tmp); |
| @@ -331,7 +304,7 @@ int rv515_ga_reset(struct radeon_device *rdev) | |||
| 331 | } | 304 | } |
| 332 | DRM_UDELAY(1); | 305 | DRM_UDELAY(1); |
| 333 | } | 306 | } |
| 334 | tmp = RREG32(RADEON_RBBM_STATUS); | 307 | tmp = RREG32(RBBM_STATUS); |
| 335 | DRM_ERROR("Failed to reset GA ! (RBBM_STATUS=0x%08X)\n", tmp); | 308 | DRM_ERROR("Failed to reset GA ! (RBBM_STATUS=0x%08X)\n", tmp); |
| 336 | return -1; | 309 | return -1; |
| 337 | } | 310 | } |
| @@ -341,7 +314,7 @@ int rv515_gpu_reset(struct radeon_device *rdev) | |||
| 341 | uint32_t status; | 314 | uint32_t status; |
| 342 | 315 | ||
| 343 | /* reset order likely matter */ | 316 | /* reset order likely matter */ |
| 344 | status = RREG32(RADEON_RBBM_STATUS); | 317 | status = RREG32(RBBM_STATUS); |
| 345 | /* reset HDP */ | 318 | /* reset HDP */ |
| 346 | r100_hdp_reset(rdev); | 319 | r100_hdp_reset(rdev); |
| 347 | /* reset rb2d */ | 320 | /* reset rb2d */ |
| @@ -353,12 +326,12 @@ int rv515_gpu_reset(struct radeon_device *rdev) | |||
| 353 | rv515_ga_reset(rdev); | 326 | rv515_ga_reset(rdev); |
| 354 | } | 327 | } |
| 355 | /* reset CP */ | 328 | /* reset CP */ |
| 356 | status = RREG32(RADEON_RBBM_STATUS); | 329 | status = RREG32(RBBM_STATUS); |
| 357 | if (status & (1 << 16)) { | 330 | if (status & (1 << 16)) { |
| 358 | r100_cp_reset(rdev); | 331 | r100_cp_reset(rdev); |
| 359 | } | 332 | } |
| 360 | /* Check if GPU is idle */ | 333 | /* Check if GPU is idle */ |
| 361 | status = RREG32(RADEON_RBBM_STATUS); | 334 | status = RREG32(RBBM_STATUS); |
| 362 | if (status & (1 << 31)) { | 335 | if (status & (1 << 31)) { |
| 363 | DRM_ERROR("Failed to reset GPU (RBBM_STATUS=0x%08X)\n", status); | 336 | DRM_ERROR("Failed to reset GPU (RBBM_STATUS=0x%08X)\n", status); |
| 364 | return -1; | 337 | return -1; |
| @@ -377,8 +350,7 @@ static void rv515_vram_get_type(struct radeon_device *rdev) | |||
| 377 | 350 | ||
| 378 | rdev->mc.vram_width = 128; | 351 | rdev->mc.vram_width = 128; |
| 379 | rdev->mc.vram_is_ddr = true; | 352 | rdev->mc.vram_is_ddr = true; |
| 380 | tmp = RREG32_MC(RV515_MC_CNTL); | 353 | tmp = RREG32_MC(RV515_MC_CNTL) & MEM_NUM_CHANNELS_MASK; |
| 381 | tmp &= RV515_MEM_NUM_CHANNELS_MASK; | ||
| 382 | switch (tmp) { | 354 | switch (tmp) { |
| 383 | case 0: | 355 | case 0: |
| 384 | rdev->mc.vram_width = 64; | 356 | rdev->mc.vram_width = 64; |
| @@ -394,11 +366,17 @@ static void rv515_vram_get_type(struct radeon_device *rdev) | |||
| 394 | 366 | ||
| 395 | void rv515_vram_info(struct radeon_device *rdev) | 367 | void rv515_vram_info(struct radeon_device *rdev) |
| 396 | { | 368 | { |
| 369 | fixed20_12 a; | ||
| 370 | |||
| 397 | rv515_vram_get_type(rdev); | 371 | rv515_vram_get_type(rdev); |
| 398 | rdev->mc.vram_size = RREG32(RADEON_CONFIG_MEMSIZE); | ||
| 399 | 372 | ||
| 400 | rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); | 373 | r100_vram_init_sizes(rdev); |
| 401 | rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0); | 374 | /* FIXME: we should enforce default clock in case GPU is not in |
| 375 | * default setup | ||
| 376 | */ | ||
| 377 | a.full = rfixed_const(100); | ||
| 378 | rdev->pm.sclk.full = rfixed_const(rdev->clock.default_sclk); | ||
| 379 | rdev->pm.sclk.full = rfixed_div(rdev->pm.sclk, a); | ||
| 402 | } | 380 | } |
| 403 | 381 | ||
| 404 | 382 | ||
| @@ -409,38 +387,19 @@ uint32_t rv515_mc_rreg(struct radeon_device *rdev, uint32_t reg) | |||
| 409 | { | 387 | { |
| 410 | uint32_t r; | 388 | uint32_t r; |
| 411 | 389 | ||
| 412 | WREG32(R520_MC_IND_INDEX, 0x7f0000 | (reg & 0xffff)); | 390 | WREG32(MC_IND_INDEX, 0x7f0000 | (reg & 0xffff)); |
| 413 | r = RREG32(R520_MC_IND_DATA); | 391 | r = RREG32(MC_IND_DATA); |
| 414 | WREG32(R520_MC_IND_INDEX, 0); | 392 | WREG32(MC_IND_INDEX, 0); |
| 415 | return r; | 393 | return r; |
| 416 | } | 394 | } |
| 417 | 395 | ||
| 418 | void rv515_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v) | 396 | void rv515_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v) |
| 419 | { | 397 | { |
| 420 | WREG32(R520_MC_IND_INDEX, 0xff0000 | ((reg) & 0xffff)); | 398 | WREG32(MC_IND_INDEX, 0xff0000 | ((reg) & 0xffff)); |
| 421 | WREG32(R520_MC_IND_DATA, (v)); | 399 | WREG32(MC_IND_DATA, (v)); |
| 422 | WREG32(R520_MC_IND_INDEX, 0); | 400 | WREG32(MC_IND_INDEX, 0); |
| 423 | } | ||
| 424 | |||
| 425 | uint32_t rv515_pcie_rreg(struct radeon_device *rdev, uint32_t reg) | ||
| 426 | { | ||
| 427 | uint32_t r; | ||
| 428 | |||
| 429 | WREG32(RADEON_PCIE_INDEX, ((reg) & 0x7ff)); | ||
| 430 | (void)RREG32(RADEON_PCIE_INDEX); | ||
| 431 | r = RREG32(RADEON_PCIE_DATA); | ||
| 432 | return r; | ||
| 433 | } | ||
| 434 | |||
| 435 | void rv515_pcie_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v) | ||
| 436 | { | ||
| 437 | WREG32(RADEON_PCIE_INDEX, ((reg) & 0x7ff)); | ||
| 438 | (void)RREG32(RADEON_PCIE_INDEX); | ||
| 439 | WREG32(RADEON_PCIE_DATA, (v)); | ||
| 440 | (void)RREG32(RADEON_PCIE_DATA); | ||
| 441 | } | 401 | } |
| 442 | 402 | ||
| 443 | |||
| 444 | /* | 403 | /* |
| 445 | * Debugfs info | 404 | * Debugfs info |
| 446 | */ | 405 | */ |
| @@ -452,13 +411,13 @@ static int rv515_debugfs_pipes_info(struct seq_file *m, void *data) | |||
| 452 | struct radeon_device *rdev = dev->dev_private; | 411 | struct radeon_device *rdev = dev->dev_private; |
| 453 | uint32_t tmp; | 412 | uint32_t tmp; |
| 454 | 413 | ||
| 455 | tmp = RREG32(R400_GB_PIPE_SELECT); | 414 | tmp = RREG32(GB_PIPE_SELECT); |
| 456 | seq_printf(m, "GB_PIPE_SELECT 0x%08x\n", tmp); | 415 | seq_printf(m, "GB_PIPE_SELECT 0x%08x\n", tmp); |
| 457 | tmp = RREG32(R500_SU_REG_DEST); | 416 | tmp = RREG32(SU_REG_DEST); |
| 458 | seq_printf(m, "SU_REG_DEST 0x%08x\n", tmp); | 417 | seq_printf(m, "SU_REG_DEST 0x%08x\n", tmp); |
| 459 | tmp = RREG32(R300_GB_TILE_CONFIG); | 418 | tmp = RREG32(GB_TILE_CONFIG); |
| 460 | seq_printf(m, "GB_TILE_CONFIG 0x%08x\n", tmp); | 419 | seq_printf(m, "GB_TILE_CONFIG 0x%08x\n", tmp); |
| 461 | tmp = RREG32(R300_DST_PIPE_CONFIG); | 420 | tmp = RREG32(DST_PIPE_CONFIG); |
| 462 | seq_printf(m, "DST_PIPE_CONFIG 0x%08x\n", tmp); | 421 | seq_printf(m, "DST_PIPE_CONFIG 0x%08x\n", tmp); |
| 463 | return 0; | 422 | return 0; |
| 464 | } | 423 | } |
| @@ -509,9 +468,9 @@ int rv515_debugfs_ga_info_init(struct radeon_device *rdev) | |||
| 509 | /* | 468 | /* |
| 510 | * Asic initialization | 469 | * Asic initialization |
| 511 | */ | 470 | */ |
| 512 | static const unsigned r500_reg_safe_bm[159] = { | 471 | static const unsigned r500_reg_safe_bm[219] = { |
| 472 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 513 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | 473 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, |
| 514 | 0xFFFFFFBF, 0xFFFFFFFF, 0xFFFFFFBF, 0xFFFFFFFF, | ||
| 515 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | 474 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, |
| 516 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | 475 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, |
| 517 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | 476 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, |
| @@ -549,14 +508,575 @@ static const unsigned r500_reg_safe_bm[159] = { | |||
| 549 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | 508 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, |
| 550 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFF80FFFF, | 509 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFF80FFFF, |
| 551 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, | 510 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
| 552 | 0x0003FC01, 0x3FFFFCF8, 0xFE800B19, | 511 | 0x0003FC01, 0x3FFFFCF8, 0xFE800B19, 0xFFFFFFFF, |
| 512 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 513 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 514 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 515 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 516 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 517 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 518 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 519 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 520 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 521 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 522 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 523 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 524 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 525 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 526 | 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, | ||
| 553 | }; | 527 | }; |
| 554 | 528 | ||
| 555 | |||
| 556 | |||
| 557 | int rv515_init(struct radeon_device *rdev) | 529 | int rv515_init(struct radeon_device *rdev) |
| 558 | { | 530 | { |
| 559 | rdev->config.r300.reg_safe_bm = r500_reg_safe_bm; | 531 | rdev->config.r300.reg_safe_bm = r500_reg_safe_bm; |
| 560 | rdev->config.r300.reg_safe_bm_size = ARRAY_SIZE(r500_reg_safe_bm); | 532 | rdev->config.r300.reg_safe_bm_size = ARRAY_SIZE(r500_reg_safe_bm); |
| 561 | return 0; | 533 | return 0; |
| 562 | } | 534 | } |
| 535 | |||
| 536 | void atom_rv515_force_tv_scaler(struct radeon_device *rdev) | ||
| 537 | { | ||
| 538 | |||
| 539 | WREG32(0x659C, 0x0); | ||
| 540 | WREG32(0x6594, 0x705); | ||
| 541 | WREG32(0x65A4, 0x10001); | ||
| 542 | WREG32(0x65D8, 0x0); | ||
| 543 | WREG32(0x65B0, 0x0); | ||
| 544 | WREG32(0x65C0, 0x0); | ||
| 545 | WREG32(0x65D4, 0x0); | ||
| 546 | WREG32(0x6578, 0x0); | ||
| 547 | WREG32(0x657C, 0x841880A8); | ||
| 548 | WREG32(0x6578, 0x1); | ||
| 549 | WREG32(0x657C, 0x84208680); | ||
| 550 | WREG32(0x6578, 0x2); | ||
| 551 | WREG32(0x657C, 0xBFF880B0); | ||
| 552 | WREG32(0x6578, 0x100); | ||
| 553 | WREG32(0x657C, 0x83D88088); | ||
| 554 | WREG32(0x6578, 0x101); | ||
| 555 | WREG32(0x657C, 0x84608680); | ||
| 556 | WREG32(0x6578, 0x102); | ||
| 557 | WREG32(0x657C, 0xBFF080D0); | ||
| 558 | WREG32(0x6578, 0x200); | ||
| 559 | WREG32(0x657C, 0x83988068); | ||
| 560 | WREG32(0x6578, 0x201); | ||
| 561 | WREG32(0x657C, 0x84A08680); | ||
| 562 | WREG32(0x6578, 0x202); | ||
| 563 | WREG32(0x657C, 0xBFF080F8); | ||
| 564 | WREG32(0x6578, 0x300); | ||
| 565 | WREG32(0x657C, 0x83588058); | ||
| 566 | WREG32(0x6578, 0x301); | ||
| 567 | WREG32(0x657C, 0x84E08660); | ||
| 568 | WREG32(0x6578, 0x302); | ||
| 569 | WREG32(0x657C, 0xBFF88120); | ||
| 570 | WREG32(0x6578, 0x400); | ||
| 571 | WREG32(0x657C, 0x83188040); | ||
| 572 | WREG32(0x6578, 0x401); | ||
| 573 | WREG32(0x657C, 0x85008660); | ||
| 574 | WREG32(0x6578, 0x402); | ||
| 575 | WREG32(0x657C, 0xBFF88150); | ||
| 576 | WREG32(0x6578, 0x500); | ||
| 577 | WREG32(0x657C, 0x82D88030); | ||
| 578 | WREG32(0x6578, 0x501); | ||
| 579 | WREG32(0x657C, 0x85408640); | ||
| 580 | WREG32(0x6578, 0x502); | ||
| 581 | WREG32(0x657C, 0xBFF88180); | ||
| 582 | WREG32(0x6578, 0x600); | ||
| 583 | WREG32(0x657C, 0x82A08018); | ||
| 584 | WREG32(0x6578, 0x601); | ||
| 585 | WREG32(0x657C, 0x85808620); | ||
| 586 | WREG32(0x6578, 0x602); | ||
| 587 | WREG32(0x657C, 0xBFF081B8); | ||
| 588 | WREG32(0x6578, 0x700); | ||
| 589 | WREG32(0x657C, 0x82608010); | ||
| 590 | WREG32(0x6578, 0x701); | ||
| 591 | WREG32(0x657C, 0x85A08600); | ||
| 592 | WREG32(0x6578, 0x702); | ||
| 593 | WREG32(0x657C, 0x800081F0); | ||
| 594 | WREG32(0x6578, 0x800); | ||
| 595 | WREG32(0x657C, 0x8228BFF8); | ||
| 596 | WREG32(0x6578, 0x801); | ||
| 597 | WREG32(0x657C, 0x85E085E0); | ||
| 598 | WREG32(0x6578, 0x802); | ||
| 599 | WREG32(0x657C, 0xBFF88228); | ||
| 600 | WREG32(0x6578, 0x10000); | ||
| 601 | WREG32(0x657C, 0x82A8BF00); | ||
| 602 | WREG32(0x6578, 0x10001); | ||
| 603 | WREG32(0x657C, 0x82A08CC0); | ||
| 604 | WREG32(0x6578, 0x10002); | ||
| 605 | WREG32(0x657C, 0x8008BEF8); | ||
| 606 | WREG32(0x6578, 0x10100); | ||
| 607 | WREG32(0x657C, 0x81F0BF28); | ||
| 608 | WREG32(0x6578, 0x10101); | ||
| 609 | WREG32(0x657C, 0x83608CA0); | ||
| 610 | WREG32(0x6578, 0x10102); | ||
| 611 | WREG32(0x657C, 0x8018BED0); | ||
| 612 | WREG32(0x6578, 0x10200); | ||
| 613 | WREG32(0x657C, 0x8148BF38); | ||
| 614 | WREG32(0x6578, 0x10201); | ||
| 615 | WREG32(0x657C, 0x84408C80); | ||
| 616 | WREG32(0x6578, 0x10202); | ||
| 617 | WREG32(0x657C, 0x8008BEB8); | ||
| 618 | WREG32(0x6578, 0x10300); | ||
| 619 | WREG32(0x657C, 0x80B0BF78); | ||
| 620 | WREG32(0x6578, 0x10301); | ||
| 621 | WREG32(0x657C, 0x85008C20); | ||
| 622 | WREG32(0x6578, 0x10302); | ||
| 623 | WREG32(0x657C, 0x8020BEA0); | ||
| 624 | WREG32(0x6578, 0x10400); | ||
| 625 | WREG32(0x657C, 0x8028BF90); | ||
| 626 | WREG32(0x6578, 0x10401); | ||
| 627 | WREG32(0x657C, 0x85E08BC0); | ||
| 628 | WREG32(0x6578, 0x10402); | ||
| 629 | WREG32(0x657C, 0x8018BE90); | ||
| 630 | WREG32(0x6578, 0x10500); | ||
| 631 | WREG32(0x657C, 0xBFB8BFB0); | ||
| 632 | WREG32(0x6578, 0x10501); | ||
| 633 | WREG32(0x657C, 0x86C08B40); | ||
| 634 | WREG32(0x6578, 0x10502); | ||
| 635 | WREG32(0x657C, 0x8010BE90); | ||
| 636 | WREG32(0x6578, 0x10600); | ||
| 637 | WREG32(0x657C, 0xBF58BFC8); | ||
| 638 | WREG32(0x6578, 0x10601); | ||
| 639 | WREG32(0x657C, 0x87A08AA0); | ||
| 640 | WREG32(0x6578, 0x10602); | ||
| 641 | WREG32(0x657C, 0x8010BE98); | ||
| 642 | WREG32(0x6578, 0x10700); | ||
| 643 | WREG32(0x657C, 0xBF10BFF0); | ||
| 644 | WREG32(0x6578, 0x10701); | ||
| 645 | WREG32(0x657C, 0x886089E0); | ||
| 646 | WREG32(0x6578, 0x10702); | ||
| 647 | WREG32(0x657C, 0x8018BEB0); | ||
| 648 | WREG32(0x6578, 0x10800); | ||
| 649 | WREG32(0x657C, 0xBED8BFE8); | ||
| 650 | WREG32(0x6578, 0x10801); | ||
| 651 | WREG32(0x657C, 0x89408940); | ||
| 652 | WREG32(0x6578, 0x10802); | ||
| 653 | WREG32(0x657C, 0xBFE8BED8); | ||
| 654 | WREG32(0x6578, 0x20000); | ||
| 655 | WREG32(0x657C, 0x80008000); | ||
| 656 | WREG32(0x6578, 0x20001); | ||
| 657 | WREG32(0x657C, 0x90008000); | ||
| 658 | WREG32(0x6578, 0x20002); | ||
| 659 | WREG32(0x657C, 0x80008000); | ||
| 660 | WREG32(0x6578, 0x20003); | ||
| 661 | WREG32(0x657C, 0x80008000); | ||
| 662 | WREG32(0x6578, 0x20100); | ||
| 663 | WREG32(0x657C, 0x80108000); | ||
| 664 | WREG32(0x6578, 0x20101); | ||
| 665 | WREG32(0x657C, 0x8FE0BF70); | ||
| 666 | WREG32(0x6578, 0x20102); | ||
| 667 | WREG32(0x657C, 0xBFE880C0); | ||
| 668 | WREG32(0x6578, 0x20103); | ||
| 669 | WREG32(0x657C, 0x80008000); | ||
| 670 | WREG32(0x6578, 0x20200); | ||
| 671 | WREG32(0x657C, 0x8018BFF8); | ||
| 672 | WREG32(0x6578, 0x20201); | ||
| 673 | WREG32(0x657C, 0x8F80BF08); | ||
| 674 | WREG32(0x6578, 0x20202); | ||
| 675 | WREG32(0x657C, 0xBFD081A0); | ||
| 676 | WREG32(0x6578, 0x20203); | ||
| 677 | WREG32(0x657C, 0xBFF88000); | ||
| 678 | WREG32(0x6578, 0x20300); | ||
| 679 | WREG32(0x657C, 0x80188000); | ||
| 680 | WREG32(0x6578, 0x20301); | ||
| 681 | WREG32(0x657C, 0x8EE0BEC0); | ||
| 682 | WREG32(0x6578, 0x20302); | ||
| 683 | WREG32(0x657C, 0xBFB082A0); | ||
| 684 | WREG32(0x6578, 0x20303); | ||
| 685 | WREG32(0x657C, 0x80008000); | ||
| 686 | WREG32(0x6578, 0x20400); | ||
| 687 | WREG32(0x657C, 0x80188000); | ||
| 688 | WREG32(0x6578, 0x20401); | ||
| 689 | WREG32(0x657C, 0x8E00BEA0); | ||
| 690 | WREG32(0x6578, 0x20402); | ||
| 691 | WREG32(0x657C, 0xBF8883C0); | ||
| 692 | WREG32(0x6578, 0x20403); | ||
| 693 | WREG32(0x657C, 0x80008000); | ||
| 694 | WREG32(0x6578, 0x20500); | ||
| 695 | WREG32(0x657C, 0x80188000); | ||
| 696 | WREG32(0x6578, 0x20501); | ||
| 697 | WREG32(0x657C, 0x8D00BE90); | ||
| 698 | WREG32(0x6578, 0x20502); | ||
| 699 | WREG32(0x657C, 0xBF588500); | ||
| 700 | WREG32(0x6578, 0x20503); | ||
| 701 | WREG32(0x657C, 0x80008008); | ||
| 702 | WREG32(0x6578, 0x20600); | ||
| 703 | WREG32(0x657C, 0x80188000); | ||
| 704 | WREG32(0x6578, 0x20601); | ||
| 705 | WREG32(0x657C, 0x8BC0BE98); | ||
| 706 | WREG32(0x6578, 0x20602); | ||
| 707 | WREG32(0x657C, 0xBF308660); | ||
| 708 | WREG32(0x6578, 0x20603); | ||
| 709 | WREG32(0x657C, 0x80008008); | ||
| 710 | WREG32(0x6578, 0x20700); | ||
| 711 | WREG32(0x657C, 0x80108000); | ||
| 712 | WREG32(0x6578, 0x20701); | ||
| 713 | WREG32(0x657C, 0x8A80BEB0); | ||
| 714 | WREG32(0x6578, 0x20702); | ||
| 715 | WREG32(0x657C, 0xBF0087C0); | ||
| 716 | WREG32(0x6578, 0x20703); | ||
| 717 | WREG32(0x657C, 0x80008008); | ||
| 718 | WREG32(0x6578, 0x20800); | ||
| 719 | WREG32(0x657C, 0x80108000); | ||
| 720 | WREG32(0x6578, 0x20801); | ||
| 721 | WREG32(0x657C, 0x8920BED0); | ||
| 722 | WREG32(0x6578, 0x20802); | ||
| 723 | WREG32(0x657C, 0xBED08920); | ||
| 724 | WREG32(0x6578, 0x20803); | ||
| 725 | WREG32(0x657C, 0x80008010); | ||
| 726 | WREG32(0x6578, 0x30000); | ||
| 727 | WREG32(0x657C, 0x90008000); | ||
| 728 | WREG32(0x6578, 0x30001); | ||
| 729 | WREG32(0x657C, 0x80008000); | ||
| 730 | WREG32(0x6578, 0x30100); | ||
| 731 | WREG32(0x657C, 0x8FE0BF90); | ||
| 732 | WREG32(0x6578, 0x30101); | ||
| 733 | WREG32(0x657C, 0xBFF880A0); | ||
| 734 | WREG32(0x6578, 0x30200); | ||
| 735 | WREG32(0x657C, 0x8F60BF40); | ||
| 736 | WREG32(0x6578, 0x30201); | ||
| 737 | WREG32(0x657C, 0xBFE88180); | ||
| 738 | WREG32(0x6578, 0x30300); | ||
| 739 | WREG32(0x657C, 0x8EC0BF00); | ||
| 740 | WREG32(0x6578, 0x30301); | ||
| 741 | WREG32(0x657C, 0xBFC88280); | ||
| 742 | WREG32(0x6578, 0x30400); | ||
| 743 | WREG32(0x657C, 0x8DE0BEE0); | ||
| 744 | WREG32(0x6578, 0x30401); | ||
| 745 | WREG32(0x657C, 0xBFA083A0); | ||
| 746 | WREG32(0x6578, 0x30500); | ||
| 747 | WREG32(0x657C, 0x8CE0BED0); | ||
| 748 | WREG32(0x6578, 0x30501); | ||
| 749 | WREG32(0x657C, 0xBF7884E0); | ||
| 750 | WREG32(0x6578, 0x30600); | ||
| 751 | WREG32(0x657C, 0x8BA0BED8); | ||
| 752 | WREG32(0x6578, 0x30601); | ||
| 753 | WREG32(0x657C, 0xBF508640); | ||
| 754 | WREG32(0x6578, 0x30700); | ||
| 755 | WREG32(0x657C, 0x8A60BEE8); | ||
| 756 | WREG32(0x6578, 0x30701); | ||
| 757 | WREG32(0x657C, 0xBF2087A0); | ||
| 758 | WREG32(0x6578, 0x30800); | ||
| 759 | WREG32(0x657C, 0x8900BF00); | ||
| 760 | WREG32(0x6578, 0x30801); | ||
| 761 | WREG32(0x657C, 0xBF008900); | ||
| 762 | } | ||
| 763 | |||
| 764 | struct rv515_watermark { | ||
| 765 | u32 lb_request_fifo_depth; | ||
| 766 | fixed20_12 num_line_pair; | ||
| 767 | fixed20_12 estimated_width; | ||
| 768 | fixed20_12 worst_case_latency; | ||
| 769 | fixed20_12 consumption_rate; | ||
| 770 | fixed20_12 active_time; | ||
| 771 | fixed20_12 dbpp; | ||
| 772 | fixed20_12 priority_mark_max; | ||
| 773 | fixed20_12 priority_mark; | ||
| 774 | fixed20_12 sclk; | ||
| 775 | }; | ||
| 776 | |||
| 777 | void rv515_crtc_bandwidth_compute(struct radeon_device *rdev, | ||
| 778 | struct radeon_crtc *crtc, | ||
| 779 | struct rv515_watermark *wm) | ||
| 780 | { | ||
| 781 | struct drm_display_mode *mode = &crtc->base.mode; | ||
| 782 | fixed20_12 a, b, c; | ||
| 783 | fixed20_12 pclk, request_fifo_depth, tolerable_latency, estimated_width; | ||
| 784 | fixed20_12 consumption_time, line_time, chunk_time, read_delay_latency; | ||
| 785 | |||
| 786 | if (!crtc->base.enabled) { | ||
| 787 | /* FIXME: wouldn't it better to set priority mark to maximum */ | ||
| 788 | wm->lb_request_fifo_depth = 4; | ||
| 789 | return; | ||
| 790 | } | ||
| 791 | |||
| 792 | if (crtc->vsc.full > rfixed_const(2)) | ||
| 793 | wm->num_line_pair.full = rfixed_const(2); | ||
| 794 | else | ||
| 795 | wm->num_line_pair.full = rfixed_const(1); | ||
| 796 | |||
| 797 | b.full = rfixed_const(mode->crtc_hdisplay); | ||
| 798 | c.full = rfixed_const(256); | ||
| 799 | a.full = rfixed_mul(wm->num_line_pair, b); | ||
| 800 | request_fifo_depth.full = rfixed_div(a, c); | ||
| 801 | if (a.full < rfixed_const(4)) { | ||
| 802 | wm->lb_request_fifo_depth = 4; | ||
| 803 | } else { | ||
| 804 | wm->lb_request_fifo_depth = rfixed_trunc(request_fifo_depth); | ||
| 805 | } | ||
| 806 | |||
| 807 | /* Determine consumption rate | ||
| 808 | * pclk = pixel clock period(ns) = 1000 / (mode.clock / 1000) | ||
| 809 | * vtaps = number of vertical taps, | ||
| 810 | * vsc = vertical scaling ratio, defined as source/destination | ||
| 811 | * hsc = horizontal scaling ration, defined as source/destination | ||
| 812 | */ | ||
| 813 | a.full = rfixed_const(mode->clock); | ||
| 814 | b.full = rfixed_const(1000); | ||
| 815 | a.full = rfixed_div(a, b); | ||
| 816 | pclk.full = rfixed_div(b, a); | ||
| 817 | if (crtc->rmx_type != RMX_OFF) { | ||
| 818 | b.full = rfixed_const(2); | ||
| 819 | if (crtc->vsc.full > b.full) | ||
| 820 | b.full = crtc->vsc.full; | ||
| 821 | b.full = rfixed_mul(b, crtc->hsc); | ||
| 822 | c.full = rfixed_const(2); | ||
| 823 | b.full = rfixed_div(b, c); | ||
| 824 | consumption_time.full = rfixed_div(pclk, b); | ||
| 825 | } else { | ||
| 826 | consumption_time.full = pclk.full; | ||
| 827 | } | ||
| 828 | a.full = rfixed_const(1); | ||
| 829 | wm->consumption_rate.full = rfixed_div(a, consumption_time); | ||
| 830 | |||
| 831 | |||
| 832 | /* Determine line time | ||
| 833 | * LineTime = total time for one line of displayhtotal | ||
| 834 | * LineTime = total number of horizontal pixels | ||
| 835 | * pclk = pixel clock period(ns) | ||
| 836 | */ | ||
| 837 | a.full = rfixed_const(crtc->base.mode.crtc_htotal); | ||
| 838 | line_time.full = rfixed_mul(a, pclk); | ||
| 839 | |||
| 840 | /* Determine active time | ||
| 841 | * ActiveTime = time of active region of display within one line, | ||
| 842 | * hactive = total number of horizontal active pixels | ||
| 843 | * htotal = total number of horizontal pixels | ||
| 844 | */ | ||
| 845 | a.full = rfixed_const(crtc->base.mode.crtc_htotal); | ||
| 846 | b.full = rfixed_const(crtc->base.mode.crtc_hdisplay); | ||
| 847 | wm->active_time.full = rfixed_mul(line_time, b); | ||
| 848 | wm->active_time.full = rfixed_div(wm->active_time, a); | ||
| 849 | |||
| 850 | /* Determine chunk time | ||
| 851 | * ChunkTime = the time it takes the DCP to send one chunk of data | ||
| 852 | * to the LB which consists of pipeline delay and inter chunk gap | ||
| 853 | * sclk = system clock(Mhz) | ||
| 854 | */ | ||
| 855 | a.full = rfixed_const(600 * 1000); | ||
| 856 | chunk_time.full = rfixed_div(a, rdev->pm.sclk); | ||
| 857 | read_delay_latency.full = rfixed_const(1000); | ||
| 858 | |||
| 859 | /* Determine the worst case latency | ||
| 860 | * NumLinePair = Number of line pairs to request(1=2 lines, 2=4 lines) | ||
| 861 | * WorstCaseLatency = worst case time from urgent to when the MC starts | ||
| 862 | * to return data | ||
| 863 | * READ_DELAY_IDLE_MAX = constant of 1us | ||
| 864 | * ChunkTime = time it takes the DCP to send one chunk of data to the LB | ||
| 865 | * which consists of pipeline delay and inter chunk gap | ||
| 866 | */ | ||
| 867 | if (rfixed_trunc(wm->num_line_pair) > 1) { | ||
| 868 | a.full = rfixed_const(3); | ||
| 869 | wm->worst_case_latency.full = rfixed_mul(a, chunk_time); | ||
| 870 | wm->worst_case_latency.full += read_delay_latency.full; | ||
| 871 | } else { | ||
| 872 | wm->worst_case_latency.full = chunk_time.full + read_delay_latency.full; | ||
| 873 | } | ||
| 874 | |||
| 875 | /* Determine the tolerable latency | ||
| 876 | * TolerableLatency = Any given request has only 1 line time | ||
| 877 | * for the data to be returned | ||
| 878 | * LBRequestFifoDepth = Number of chunk requests the LB can | ||
| 879 | * put into the request FIFO for a display | ||
| 880 | * LineTime = total time for one line of display | ||
| 881 | * ChunkTime = the time it takes the DCP to send one chunk | ||
| 882 | * of data to the LB which consists of | ||
| 883 | * pipeline delay and inter chunk gap | ||
| 884 | */ | ||
| 885 | if ((2+wm->lb_request_fifo_depth) >= rfixed_trunc(request_fifo_depth)) { | ||
| 886 | tolerable_latency.full = line_time.full; | ||
| 887 | } else { | ||
| 888 | tolerable_latency.full = rfixed_const(wm->lb_request_fifo_depth - 2); | ||
| 889 | tolerable_latency.full = request_fifo_depth.full - tolerable_latency.full; | ||
| 890 | tolerable_latency.full = rfixed_mul(tolerable_latency, chunk_time); | ||
| 891 | tolerable_latency.full = line_time.full - tolerable_latency.full; | ||
| 892 | } | ||
| 893 | /* We assume worst case 32bits (4 bytes) */ | ||
| 894 | wm->dbpp.full = rfixed_const(2 * 16); | ||
| 895 | |||
| 896 | /* Determine the maximum priority mark | ||
| 897 | * width = viewport width in pixels | ||
| 898 | */ | ||
| 899 | a.full = rfixed_const(16); | ||
| 900 | wm->priority_mark_max.full = rfixed_const(crtc->base.mode.crtc_hdisplay); | ||
| 901 | wm->priority_mark_max.full = rfixed_div(wm->priority_mark_max, a); | ||
| 902 | |||
| 903 | /* Determine estimated width */ | ||
| 904 | estimated_width.full = tolerable_latency.full - wm->worst_case_latency.full; | ||
| 905 | estimated_width.full = rfixed_div(estimated_width, consumption_time); | ||
| 906 | if (rfixed_trunc(estimated_width) > crtc->base.mode.crtc_hdisplay) { | ||
| 907 | wm->priority_mark.full = rfixed_const(10); | ||
| 908 | } else { | ||
| 909 | a.full = rfixed_const(16); | ||
| 910 | wm->priority_mark.full = rfixed_div(estimated_width, a); | ||
| 911 | wm->priority_mark.full = wm->priority_mark_max.full - wm->priority_mark.full; | ||
| 912 | } | ||
| 913 | } | ||
| 914 | |||
| 915 | void rv515_bandwidth_avivo_update(struct radeon_device *rdev) | ||
| 916 | { | ||
| 917 | struct drm_display_mode *mode0 = NULL; | ||
| 918 | struct drm_display_mode *mode1 = NULL; | ||
| 919 | struct rv515_watermark wm0; | ||
| 920 | struct rv515_watermark wm1; | ||
| 921 | u32 tmp; | ||
| 922 | fixed20_12 priority_mark02, priority_mark12, fill_rate; | ||
| 923 | fixed20_12 a, b; | ||
| 924 | |||
| 925 | if (rdev->mode_info.crtcs[0]->base.enabled) | ||
| 926 | mode0 = &rdev->mode_info.crtcs[0]->base.mode; | ||
| 927 | if (rdev->mode_info.crtcs[1]->base.enabled) | ||
| 928 | mode1 = &rdev->mode_info.crtcs[1]->base.mode; | ||
| 929 | rs690_line_buffer_adjust(rdev, mode0, mode1); | ||
| 930 | |||
| 931 | rv515_crtc_bandwidth_compute(rdev, rdev->mode_info.crtcs[0], &wm0); | ||
| 932 | rv515_crtc_bandwidth_compute(rdev, rdev->mode_info.crtcs[1], &wm1); | ||
| 933 | |||
| 934 | tmp = wm0.lb_request_fifo_depth; | ||
| 935 | tmp |= wm1.lb_request_fifo_depth << 16; | ||
| 936 | WREG32(LB_MAX_REQ_OUTSTANDING, tmp); | ||
| 937 | |||
| 938 | if (mode0 && mode1) { | ||
| 939 | if (rfixed_trunc(wm0.dbpp) > 64) | ||
| 940 | a.full = rfixed_div(wm0.dbpp, wm0.num_line_pair); | ||
| 941 | else | ||
| 942 | a.full = wm0.num_line_pair.full; | ||
| 943 | if (rfixed_trunc(wm1.dbpp) > 64) | ||
| 944 | b.full = rfixed_div(wm1.dbpp, wm1.num_line_pair); | ||
| 945 | else | ||
| 946 | b.full = wm1.num_line_pair.full; | ||
| 947 | a.full += b.full; | ||
| 948 | fill_rate.full = rfixed_div(wm0.sclk, a); | ||
| 949 | if (wm0.consumption_rate.full > fill_rate.full) { | ||
| 950 | b.full = wm0.consumption_rate.full - fill_rate.full; | ||
| 951 | b.full = rfixed_mul(b, wm0.active_time); | ||
| 952 | a.full = rfixed_const(16); | ||
| 953 | b.full = rfixed_div(b, a); | ||
| 954 | a.full = rfixed_mul(wm0.worst_case_latency, | ||
| 955 | wm0.consumption_rate); | ||
| 956 | priority_mark02.full = a.full + b.full; | ||
| 957 | } else { | ||
| 958 | a.full = rfixed_mul(wm0.worst_case_latency, | ||
| 959 | wm0.consumption_rate); | ||
| 960 | b.full = rfixed_const(16 * 1000); | ||
| 961 | priority_mark02.full = rfixed_div(a, b); | ||
| 962 | } | ||
| 963 | if (wm1.consumption_rate.full > fill_rate.full) { | ||
| 964 | b.full = wm1.consumption_rate.full - fill_rate.full; | ||
| 965 | b.full = rfixed_mul(b, wm1.active_time); | ||
| 966 | a.full = rfixed_const(16); | ||
| 967 | b.full = rfixed_div(b, a); | ||
| 968 | a.full = rfixed_mul(wm1.worst_case_latency, | ||
| 969 | wm1.consumption_rate); | ||
| 970 | priority_mark12.full = a.full + b.full; | ||
| 971 | } else { | ||
| 972 | a.full = rfixed_mul(wm1.worst_case_latency, | ||
| 973 | wm1.consumption_rate); | ||
| 974 | b.full = rfixed_const(16 * 1000); | ||
| 975 | priority_mark12.full = rfixed_div(a, b); | ||
| 976 | } | ||
| 977 | if (wm0.priority_mark.full > priority_mark02.full) | ||
| 978 | priority_mark02.full = wm0.priority_mark.full; | ||
| 979 | if (rfixed_trunc(priority_mark02) < 0) | ||
| 980 | priority_mark02.full = 0; | ||
| 981 | if (wm0.priority_mark_max.full > priority_mark02.full) | ||
| 982 | priority_mark02.full = wm0.priority_mark_max.full; | ||
| 983 | if (wm1.priority_mark.full > priority_mark12.full) | ||
| 984 | priority_mark12.full = wm1.priority_mark.full; | ||
| 985 | if (rfixed_trunc(priority_mark12) < 0) | ||
| 986 | priority_mark12.full = 0; | ||
| 987 | if (wm1.priority_mark_max.full > priority_mark12.full) | ||
| 988 | priority_mark12.full = wm1.priority_mark_max.full; | ||
| 989 | WREG32(D1MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark02)); | ||
| 990 | WREG32(D1MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark02)); | ||
| 991 | WREG32(D2MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark12)); | ||
| 992 | WREG32(D2MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark12)); | ||
| 993 | } else if (mode0) { | ||
| 994 | if (rfixed_trunc(wm0.dbpp) > 64) | ||
| 995 | a.full = rfixed_div(wm0.dbpp, wm0.num_line_pair); | ||
| 996 | else | ||
| 997 | a.full = wm0.num_line_pair.full; | ||
| 998 | fill_rate.full = rfixed_div(wm0.sclk, a); | ||
| 999 | if (wm0.consumption_rate.full > fill_rate.full) { | ||
| 1000 | b.full = wm0.consumption_rate.full - fill_rate.full; | ||
| 1001 | b.full = rfixed_mul(b, wm0.active_time); | ||
| 1002 | a.full = rfixed_const(16); | ||
| 1003 | b.full = rfixed_div(b, a); | ||
| 1004 | a.full = rfixed_mul(wm0.worst_case_latency, | ||
| 1005 | wm0.consumption_rate); | ||
| 1006 | priority_mark02.full = a.full + b.full; | ||
| 1007 | } else { | ||
| 1008 | a.full = rfixed_mul(wm0.worst_case_latency, | ||
| 1009 | wm0.consumption_rate); | ||
| 1010 | b.full = rfixed_const(16); | ||
| 1011 | priority_mark02.full = rfixed_div(a, b); | ||
| 1012 | } | ||
| 1013 | if (wm0.priority_mark.full > priority_mark02.full) | ||
| 1014 | priority_mark02.full = wm0.priority_mark.full; | ||
| 1015 | if (rfixed_trunc(priority_mark02) < 0) | ||
| 1016 | priority_mark02.full = 0; | ||
| 1017 | if (wm0.priority_mark_max.full > priority_mark02.full) | ||
| 1018 | priority_mark02.full = wm0.priority_mark_max.full; | ||
| 1019 | WREG32(D1MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark02)); | ||
| 1020 | WREG32(D1MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark02)); | ||
| 1021 | WREG32(D2MODE_PRIORITY_A_CNT, MODE_PRIORITY_OFF); | ||
| 1022 | WREG32(D2MODE_PRIORITY_B_CNT, MODE_PRIORITY_OFF); | ||
| 1023 | } else { | ||
| 1024 | if (rfixed_trunc(wm1.dbpp) > 64) | ||
| 1025 | a.full = rfixed_div(wm1.dbpp, wm1.num_line_pair); | ||
| 1026 | else | ||
| 1027 | a.full = wm1.num_line_pair.full; | ||
| 1028 | fill_rate.full = rfixed_div(wm1.sclk, a); | ||
| 1029 | if (wm1.consumption_rate.full > fill_rate.full) { | ||
| 1030 | b.full = wm1.consumption_rate.full - fill_rate.full; | ||
| 1031 | b.full = rfixed_mul(b, wm1.active_time); | ||
| 1032 | a.full = rfixed_const(16); | ||
| 1033 | b.full = rfixed_div(b, a); | ||
| 1034 | a.full = rfixed_mul(wm1.worst_case_latency, | ||
| 1035 | wm1.consumption_rate); | ||
| 1036 | priority_mark12.full = a.full + b.full; | ||
| 1037 | } else { | ||
| 1038 | a.full = rfixed_mul(wm1.worst_case_latency, | ||
| 1039 | wm1.consumption_rate); | ||
| 1040 | b.full = rfixed_const(16 * 1000); | ||
| 1041 | priority_mark12.full = rfixed_div(a, b); | ||
| 1042 | } | ||
| 1043 | if (wm1.priority_mark.full > priority_mark12.full) | ||
| 1044 | priority_mark12.full = wm1.priority_mark.full; | ||
| 1045 | if (rfixed_trunc(priority_mark12) < 0) | ||
| 1046 | priority_mark12.full = 0; | ||
| 1047 | if (wm1.priority_mark_max.full > priority_mark12.full) | ||
| 1048 | priority_mark12.full = wm1.priority_mark_max.full; | ||
| 1049 | WREG32(D1MODE_PRIORITY_A_CNT, MODE_PRIORITY_OFF); | ||
| 1050 | WREG32(D1MODE_PRIORITY_B_CNT, MODE_PRIORITY_OFF); | ||
| 1051 | WREG32(D2MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark12)); | ||
| 1052 | WREG32(D2MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark12)); | ||
| 1053 | } | ||
| 1054 | } | ||
| 1055 | |||
| 1056 | void rv515_bandwidth_update(struct radeon_device *rdev) | ||
| 1057 | { | ||
| 1058 | uint32_t tmp; | ||
| 1059 | struct drm_display_mode *mode0 = NULL; | ||
| 1060 | struct drm_display_mode *mode1 = NULL; | ||
| 1061 | |||
| 1062 | if (rdev->mode_info.crtcs[0]->base.enabled) | ||
| 1063 | mode0 = &rdev->mode_info.crtcs[0]->base.mode; | ||
| 1064 | if (rdev->mode_info.crtcs[1]->base.enabled) | ||
| 1065 | mode1 = &rdev->mode_info.crtcs[1]->base.mode; | ||
| 1066 | /* | ||
| 1067 | * Set display0/1 priority up in the memory controller for | ||
| 1068 | * modes if the user specifies HIGH for displaypriority | ||
| 1069 | * option. | ||
| 1070 | */ | ||
| 1071 | if (rdev->disp_priority == 2) { | ||
| 1072 | tmp = RREG32_MC(MC_MISC_LAT_TIMER); | ||
| 1073 | tmp &= ~MC_DISP1R_INIT_LAT_MASK; | ||
| 1074 | tmp &= ~MC_DISP0R_INIT_LAT_MASK; | ||
| 1075 | if (mode1) | ||
| 1076 | tmp |= (1 << MC_DISP1R_INIT_LAT_SHIFT); | ||
| 1077 | if (mode0) | ||
| 1078 | tmp |= (1 << MC_DISP0R_INIT_LAT_SHIFT); | ||
| 1079 | WREG32_MC(MC_MISC_LAT_TIMER, tmp); | ||
| 1080 | } | ||
| 1081 | rv515_bandwidth_avivo_update(rdev); | ||
| 1082 | } | ||
diff --git a/drivers/gpu/drm/radeon/rv515r.h b/drivers/gpu/drm/radeon/rv515r.h new file mode 100644 index 000000000000..f3cf84039906 --- /dev/null +++ b/drivers/gpu/drm/radeon/rv515r.h | |||
| @@ -0,0 +1,170 @@ | |||
| 1 | /* | ||
| 2 | * Copyright 2008 Advanced Micro Devices, Inc. | ||
| 3 | * Copyright 2008 Red Hat Inc. | ||
| 4 | * Copyright 2009 Jerome Glisse. | ||
| 5 | * | ||
| 6 | * Permission is hereby granted, free of charge, to any person obtaining a | ||
| 7 | * copy of this software and associated documentation files (the "Software"), | ||
| 8 | * to deal in the Software without restriction, including without limitation | ||
| 9 | * the rights to use, copy, modify, merge, publish, distribute, sublicense, | ||
| 10 | * and/or sell copies of the Software, and to permit persons to whom the | ||
| 11 | * Software is furnished to do so, subject to the following conditions: | ||
| 12 | * | ||
| 13 | * The above copyright notice and this permission notice shall be included in | ||
| 14 | * all copies or substantial portions of the Software. | ||
| 15 | * | ||
| 16 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
| 17 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
| 18 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL | ||
| 19 | * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR | ||
| 20 | * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, | ||
| 21 | * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR | ||
| 22 | * OTHER DEALINGS IN THE SOFTWARE. | ||
| 23 | * | ||
| 24 | * Authors: Dave Airlie | ||
| 25 | * Alex Deucher | ||
| 26 | * Jerome Glisse | ||
| 27 | */ | ||
| 28 | #ifndef RV515R_H | ||
| 29 | #define RV515R_H | ||
| 30 | |||
| 31 | /* RV515 registers */ | ||
| 32 | #define PCIE_INDEX 0x0030 | ||
| 33 | #define PCIE_DATA 0x0034 | ||
| 34 | #define MC_IND_INDEX 0x0070 | ||
| 35 | #define MC_IND_WR_EN (1 << 24) | ||
| 36 | #define MC_IND_DATA 0x0074 | ||
| 37 | #define RBBM_SOFT_RESET 0x00F0 | ||
| 38 | #define CONFIG_MEMSIZE 0x00F8 | ||
| 39 | #define HDP_FB_LOCATION 0x0134 | ||
| 40 | #define CP_CSQ_CNTL 0x0740 | ||
| 41 | #define CP_CSQ_MODE 0x0744 | ||
| 42 | #define CP_CSQ_ADDR 0x07F0 | ||
| 43 | #define CP_CSQ_DATA 0x07F4 | ||
| 44 | #define CP_CSQ_STAT 0x07F8 | ||
| 45 | #define CP_CSQ2_STAT 0x07FC | ||
| 46 | #define RBBM_STATUS 0x0E40 | ||
| 47 | #define DST_PIPE_CONFIG 0x170C | ||
| 48 | #define WAIT_UNTIL 0x1720 | ||
| 49 | #define WAIT_2D_IDLE (1 << 14) | ||
| 50 | #define WAIT_3D_IDLE (1 << 15) | ||
| 51 | #define WAIT_2D_IDLECLEAN (1 << 16) | ||
| 52 | #define WAIT_3D_IDLECLEAN (1 << 17) | ||
| 53 | #define ISYNC_CNTL 0x1724 | ||
| 54 | #define ISYNC_ANY2D_IDLE3D (1 << 0) | ||
| 55 | #define ISYNC_ANY3D_IDLE2D (1 << 1) | ||
| 56 | #define ISYNC_TRIG2D_IDLE3D (1 << 2) | ||
| 57 | #define ISYNC_TRIG3D_IDLE2D (1 << 3) | ||
| 58 | #define ISYNC_WAIT_IDLEGUI (1 << 4) | ||
| 59 | #define ISYNC_CPSCRATCH_IDLEGUI (1 << 5) | ||
| 60 | #define VAP_INDEX_OFFSET 0x208C | ||
| 61 | #define VAP_PVS_STATE_FLUSH_REG 0x2284 | ||
| 62 | #define GB_ENABLE 0x4008 | ||
| 63 | #define GB_MSPOS0 0x4010 | ||
| 64 | #define MS_X0_SHIFT 0 | ||
| 65 | #define MS_Y0_SHIFT 4 | ||
| 66 | #define MS_X1_SHIFT 8 | ||
| 67 | #define MS_Y1_SHIFT 12 | ||
| 68 | #define MS_X2_SHIFT 16 | ||
| 69 | #define MS_Y2_SHIFT 20 | ||
| 70 | #define MSBD0_Y_SHIFT 24 | ||
| 71 | #define MSBD0_X_SHIFT 28 | ||
| 72 | #define GB_MSPOS1 0x4014 | ||
| 73 | #define MS_X3_SHIFT 0 | ||
| 74 | #define MS_Y3_SHIFT 4 | ||
| 75 | #define MS_X4_SHIFT 8 | ||
| 76 | #define MS_Y4_SHIFT 12 | ||
| 77 | #define MS_X5_SHIFT 16 | ||
| 78 | #define MS_Y5_SHIFT 20 | ||
| 79 | #define MSBD1_SHIFT 24 | ||
| 80 | #define GB_TILE_CONFIG 0x4018 | ||
| 81 | #define ENABLE_TILING (1 << 0) | ||
| 82 | #define PIPE_COUNT_MASK 0x0000000E | ||
| 83 | #define PIPE_COUNT_SHIFT 1 | ||
| 84 | #define TILE_SIZE_8 (0 << 4) | ||
| 85 | #define TILE_SIZE_16 (1 << 4) | ||
| 86 | #define TILE_SIZE_32 (2 << 4) | ||
| 87 | #define SUBPIXEL_1_12 (0 << 16) | ||
| 88 | #define SUBPIXEL_1_16 (1 << 16) | ||
| 89 | #define GB_SELECT 0x401C | ||
| 90 | #define GB_AA_CONFIG 0x4020 | ||
| 91 | #define GB_PIPE_SELECT 0x402C | ||
| 92 | #define GA_ENHANCE 0x4274 | ||
| 93 | #define GA_DEADLOCK_CNTL (1 << 0) | ||
| 94 | #define GA_FASTSYNC_CNTL (1 << 1) | ||
| 95 | #define GA_POLY_MODE 0x4288 | ||
| 96 | #define FRONT_PTYPE_POINT (0 << 4) | ||
| 97 | #define FRONT_PTYPE_LINE (1 << 4) | ||
| 98 | #define FRONT_PTYPE_TRIANGE (2 << 4) | ||
| 99 | #define BACK_PTYPE_POINT (0 << 7) | ||
| 100 | #define BACK_PTYPE_LINE (1 << 7) | ||
| 101 | #define BACK_PTYPE_TRIANGE (2 << 7) | ||
| 102 | #define GA_ROUND_MODE 0x428C | ||
| 103 | #define GEOMETRY_ROUND_TRUNC (0 << 0) | ||
| 104 | #define GEOMETRY_ROUND_NEAREST (1 << 0) | ||
| 105 | #define COLOR_ROUND_TRUNC (0 << 2) | ||
| 106 | #define COLOR_ROUND_NEAREST (1 << 2) | ||
| 107 | #define SU_REG_DEST 0x42C8 | ||
| 108 | #define RB3D_DSTCACHE_CTLSTAT 0x4E4C | ||
| 109 | #define RB3D_DC_FLUSH (2 << 0) | ||
| 110 | #define RB3D_DC_FREE (2 << 2) | ||
| 111 | #define RB3D_DC_FINISH (1 << 4) | ||
| 112 | #define ZB_ZCACHE_CTLSTAT 0x4F18 | ||
| 113 | #define ZC_FLUSH (1 << 0) | ||
| 114 | #define ZC_FREE (1 << 1) | ||
| 115 | #define DC_LB_MEMORY_SPLIT 0x6520 | ||
| 116 | #define DC_LB_MEMORY_SPLIT_MASK 0x00000003 | ||
| 117 | #define DC_LB_MEMORY_SPLIT_SHIFT 0 | ||
| 118 | #define DC_LB_MEMORY_SPLIT_D1HALF_D2HALF 0 | ||
| 119 | #define DC_LB_MEMORY_SPLIT_D1_3Q_D2_1Q 1 | ||
| 120 | #define DC_LB_MEMORY_SPLIT_D1_ONLY 2 | ||
| 121 | #define DC_LB_MEMORY_SPLIT_D1_1Q_D2_3Q 3 | ||
| 122 | #define DC_LB_MEMORY_SPLIT_SHIFT_MODE (1 << 2) | ||
| 123 | #define DC_LB_DISP1_END_ADR_SHIFT 4 | ||
| 124 | #define DC_LB_DISP1_END_ADR_MASK 0x00007FF0 | ||
| 125 | #define D1MODE_PRIORITY_A_CNT 0x6548 | ||
| 126 | #define MODE_PRIORITY_MARK_MASK 0x00007FFF | ||
| 127 | #define MODE_PRIORITY_OFF (1 << 16) | ||
| 128 | #define MODE_PRIORITY_ALWAYS_ON (1 << 20) | ||
| 129 | #define MODE_PRIORITY_FORCE_MASK (1 << 24) | ||
| 130 | #define D1MODE_PRIORITY_B_CNT 0x654C | ||
| 131 | #define LB_MAX_REQ_OUTSTANDING 0x6D58 | ||
| 132 | #define LB_D1_MAX_REQ_OUTSTANDING_MASK 0x0000000F | ||
| 133 | #define LB_D1_MAX_REQ_OUTSTANDING_SHIFT 0 | ||
| 134 | #define LB_D2_MAX_REQ_OUTSTANDING_MASK 0x000F0000 | ||
| 135 | #define LB_D2_MAX_REQ_OUTSTANDING_SHIFT 16 | ||
| 136 | #define D2MODE_PRIORITY_A_CNT 0x6D48 | ||
| 137 | #define D2MODE_PRIORITY_B_CNT 0x6D4C | ||
| 138 | |||
| 139 | /* ix[MC] registers */ | ||
| 140 | #define MC_FB_LOCATION 0x01 | ||
| 141 | #define MC_FB_START_MASK 0x0000FFFF | ||
| 142 | #define MC_FB_START_SHIFT 0 | ||
| 143 | #define MC_FB_TOP_MASK 0xFFFF0000 | ||
| 144 | #define MC_FB_TOP_SHIFT 16 | ||
| 145 | #define MC_AGP_LOCATION 0x02 | ||
| 146 | #define MC_AGP_START_MASK 0x0000FFFF | ||
| 147 | #define MC_AGP_START_SHIFT 0 | ||
| 148 | #define MC_AGP_TOP_MASK 0xFFFF0000 | ||
| 149 | #define MC_AGP_TOP_SHIFT 16 | ||
| 150 | #define MC_AGP_BASE 0x03 | ||
| 151 | #define MC_AGP_BASE_2 0x04 | ||
| 152 | #define MC_CNTL 0x5 | ||
| 153 | #define MEM_NUM_CHANNELS_MASK 0x00000003 | ||
| 154 | #define MC_STATUS 0x08 | ||
| 155 | #define MC_STATUS_IDLE (1 << 4) | ||
| 156 | #define MC_MISC_LAT_TIMER 0x09 | ||
| 157 | #define MC_CPR_INIT_LAT_MASK 0x0000000F | ||
| 158 | #define MC_VF_INIT_LAT_MASK 0x000000F0 | ||
| 159 | #define MC_DISP0R_INIT_LAT_MASK 0x00000F00 | ||
| 160 | #define MC_DISP0R_INIT_LAT_SHIFT 8 | ||
| 161 | #define MC_DISP1R_INIT_LAT_MASK 0x0000F000 | ||
| 162 | #define MC_DISP1R_INIT_LAT_SHIFT 12 | ||
| 163 | #define MC_FIXED_INIT_LAT_MASK 0x000F0000 | ||
| 164 | #define MC_E2R_INIT_LAT_MASK 0x00F00000 | ||
| 165 | #define SAME_PAGE_PRIO_MASK 0x0F000000 | ||
| 166 | #define MC_GLOBW_INIT_LAT_MASK 0xF0000000 | ||
| 167 | |||
| 168 | |||
| 169 | #endif | ||
| 170 | |||
diff --git a/drivers/gpu/drm/radeon/rv770.c b/drivers/gpu/drm/radeon/rv770.c index da50cc51ede3..21d8ffd57308 100644 --- a/drivers/gpu/drm/radeon/rv770.c +++ b/drivers/gpu/drm/radeon/rv770.c | |||
| @@ -67,7 +67,7 @@ int rv770_mc_init(struct radeon_device *rdev) | |||
| 67 | "programming pipes. Bad things might happen.\n"); | 67 | "programming pipes. Bad things might happen.\n"); |
| 68 | } | 68 | } |
| 69 | 69 | ||
| 70 | tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; | 70 | tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1; |
| 71 | tmp = REG_SET(R700_MC_FB_TOP, tmp >> 24); | 71 | tmp = REG_SET(R700_MC_FB_TOP, tmp >> 24); |
| 72 | tmp |= REG_SET(R700_MC_FB_BASE, rdev->mc.vram_location >> 24); | 72 | tmp |= REG_SET(R700_MC_FB_BASE, rdev->mc.vram_location >> 24); |
| 73 | WREG32(R700_MC_VM_FB_LOCATION, tmp); | 73 | WREG32(R700_MC_VM_FB_LOCATION, tmp); |
diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c index c1c407f7cca3..c2b0d710d10f 100644 --- a/drivers/gpu/drm/ttm/ttm_bo.c +++ b/drivers/gpu/drm/ttm/ttm_bo.c | |||
| @@ -43,7 +43,6 @@ | |||
| 43 | #define TTM_BO_HASH_ORDER 13 | 43 | #define TTM_BO_HASH_ORDER 13 |
| 44 | 44 | ||
| 45 | static int ttm_bo_setup_vm(struct ttm_buffer_object *bo); | 45 | static int ttm_bo_setup_vm(struct ttm_buffer_object *bo); |
| 46 | static void ttm_bo_unmap_virtual(struct ttm_buffer_object *bo); | ||
| 47 | static int ttm_bo_swapout(struct ttm_mem_shrink *shrink); | 46 | static int ttm_bo_swapout(struct ttm_mem_shrink *shrink); |
| 48 | 47 | ||
| 49 | static inline uint32_t ttm_bo_type_flags(unsigned type) | 48 | static inline uint32_t ttm_bo_type_flags(unsigned type) |
| @@ -224,6 +223,9 @@ static int ttm_bo_add_ttm(struct ttm_buffer_object *bo, bool zero_alloc) | |||
| 224 | TTM_ASSERT_LOCKED(&bo->mutex); | 223 | TTM_ASSERT_LOCKED(&bo->mutex); |
| 225 | bo->ttm = NULL; | 224 | bo->ttm = NULL; |
| 226 | 225 | ||
| 226 | if (bdev->need_dma32) | ||
| 227 | page_flags |= TTM_PAGE_FLAG_DMA32; | ||
| 228 | |||
| 227 | switch (bo->type) { | 229 | switch (bo->type) { |
| 228 | case ttm_bo_type_device: | 230 | case ttm_bo_type_device: |
| 229 | if (zero_alloc) | 231 | if (zero_alloc) |
| @@ -304,6 +306,9 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo, | |||
| 304 | 306 | ||
| 305 | } | 307 | } |
| 306 | 308 | ||
| 309 | if (bdev->driver->move_notify) | ||
| 310 | bdev->driver->move_notify(bo, mem); | ||
| 311 | |||
| 307 | if (!(old_man->flags & TTM_MEMTYPE_FLAG_FIXED) && | 312 | if (!(old_man->flags & TTM_MEMTYPE_FLAG_FIXED) && |
| 308 | !(new_man->flags & TTM_MEMTYPE_FLAG_FIXED)) | 313 | !(new_man->flags & TTM_MEMTYPE_FLAG_FIXED)) |
| 309 | ret = ttm_bo_move_ttm(bo, evict, no_wait, mem); | 314 | ret = ttm_bo_move_ttm(bo, evict, no_wait, mem); |
| @@ -655,31 +660,52 @@ retry_pre_get: | |||
| 655 | return 0; | 660 | return 0; |
| 656 | } | 661 | } |
| 657 | 662 | ||
| 663 | static uint32_t ttm_bo_select_caching(struct ttm_mem_type_manager *man, | ||
| 664 | uint32_t cur_placement, | ||
| 665 | uint32_t proposed_placement) | ||
| 666 | { | ||
| 667 | uint32_t caching = proposed_placement & TTM_PL_MASK_CACHING; | ||
| 668 | uint32_t result = proposed_placement & ~TTM_PL_MASK_CACHING; | ||
| 669 | |||
| 670 | /** | ||
| 671 | * Keep current caching if possible. | ||
| 672 | */ | ||
| 673 | |||
| 674 | if ((cur_placement & caching) != 0) | ||
| 675 | result |= (cur_placement & caching); | ||
| 676 | else if ((man->default_caching & caching) != 0) | ||
| 677 | result |= man->default_caching; | ||
| 678 | else if ((TTM_PL_FLAG_CACHED & caching) != 0) | ||
| 679 | result |= TTM_PL_FLAG_CACHED; | ||
| 680 | else if ((TTM_PL_FLAG_WC & caching) != 0) | ||
| 681 | result |= TTM_PL_FLAG_WC; | ||
| 682 | else if ((TTM_PL_FLAG_UNCACHED & caching) != 0) | ||
| 683 | result |= TTM_PL_FLAG_UNCACHED; | ||
| 684 | |||
| 685 | return result; | ||
| 686 | } | ||
| 687 | |||
| 688 | |||
| 658 | static bool ttm_bo_mt_compatible(struct ttm_mem_type_manager *man, | 689 | static bool ttm_bo_mt_compatible(struct ttm_mem_type_manager *man, |
| 659 | bool disallow_fixed, | 690 | bool disallow_fixed, |
| 660 | uint32_t mem_type, | 691 | uint32_t mem_type, |
| 661 | uint32_t mask, uint32_t *res_mask) | 692 | uint32_t proposed_placement, |
| 693 | uint32_t *masked_placement) | ||
| 662 | { | 694 | { |
| 663 | uint32_t cur_flags = ttm_bo_type_flags(mem_type); | 695 | uint32_t cur_flags = ttm_bo_type_flags(mem_type); |
| 664 | 696 | ||
| 665 | if ((man->flags & TTM_MEMTYPE_FLAG_FIXED) && disallow_fixed) | 697 | if ((man->flags & TTM_MEMTYPE_FLAG_FIXED) && disallow_fixed) |
| 666 | return false; | 698 | return false; |
| 667 | 699 | ||
| 668 | if ((cur_flags & mask & TTM_PL_MASK_MEM) == 0) | 700 | if ((cur_flags & proposed_placement & TTM_PL_MASK_MEM) == 0) |
| 669 | return false; | 701 | return false; |
| 670 | 702 | ||
| 671 | if ((mask & man->available_caching) == 0) | 703 | if ((proposed_placement & man->available_caching) == 0) |
| 672 | return false; | 704 | return false; |
| 673 | if (mask & man->default_caching) | ||
| 674 | cur_flags |= man->default_caching; | ||
| 675 | else if (mask & TTM_PL_FLAG_CACHED) | ||
| 676 | cur_flags |= TTM_PL_FLAG_CACHED; | ||
| 677 | else if (mask & TTM_PL_FLAG_WC) | ||
| 678 | cur_flags |= TTM_PL_FLAG_WC; | ||
| 679 | else | ||
| 680 | cur_flags |= TTM_PL_FLAG_UNCACHED; | ||
| 681 | 705 | ||
| 682 | *res_mask = cur_flags; | 706 | cur_flags |= (proposed_placement & man->available_caching); |
| 707 | |||
| 708 | *masked_placement = cur_flags; | ||
| 683 | return true; | 709 | return true; |
| 684 | } | 710 | } |
| 685 | 711 | ||
| @@ -723,6 +749,9 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo, | |||
| 723 | if (!type_ok) | 749 | if (!type_ok) |
| 724 | continue; | 750 | continue; |
| 725 | 751 | ||
| 752 | cur_flags = ttm_bo_select_caching(man, bo->mem.placement, | ||
| 753 | cur_flags); | ||
| 754 | |||
| 726 | if (mem_type == TTM_PL_SYSTEM) | 755 | if (mem_type == TTM_PL_SYSTEM) |
| 727 | break; | 756 | break; |
| 728 | 757 | ||
| @@ -779,6 +808,9 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo, | |||
| 779 | proposed_placement, &cur_flags)) | 808 | proposed_placement, &cur_flags)) |
| 780 | continue; | 809 | continue; |
| 781 | 810 | ||
| 811 | cur_flags = ttm_bo_select_caching(man, bo->mem.placement, | ||
| 812 | cur_flags); | ||
| 813 | |||
| 782 | ret = ttm_bo_mem_force_space(bdev, mem, mem_type, | 814 | ret = ttm_bo_mem_force_space(bdev, mem, mem_type, |
| 783 | interruptible, no_wait); | 815 | interruptible, no_wait); |
| 784 | 816 | ||
| @@ -1150,13 +1182,14 @@ static int ttm_bo_force_list_clean(struct ttm_bo_device *bdev, | |||
| 1150 | 1182 | ||
| 1151 | int ttm_bo_clean_mm(struct ttm_bo_device *bdev, unsigned mem_type) | 1183 | int ttm_bo_clean_mm(struct ttm_bo_device *bdev, unsigned mem_type) |
| 1152 | { | 1184 | { |
| 1153 | struct ttm_mem_type_manager *man = &bdev->man[mem_type]; | 1185 | struct ttm_mem_type_manager *man; |
| 1154 | int ret = -EINVAL; | 1186 | int ret = -EINVAL; |
| 1155 | 1187 | ||
| 1156 | if (mem_type >= TTM_NUM_MEM_TYPES) { | 1188 | if (mem_type >= TTM_NUM_MEM_TYPES) { |
| 1157 | printk(KERN_ERR TTM_PFX "Illegal memory type %d\n", mem_type); | 1189 | printk(KERN_ERR TTM_PFX "Illegal memory type %d\n", mem_type); |
| 1158 | return ret; | 1190 | return ret; |
| 1159 | } | 1191 | } |
| 1192 | man = &bdev->man[mem_type]; | ||
| 1160 | 1193 | ||
| 1161 | if (!man->has_type) { | 1194 | if (!man->has_type) { |
| 1162 | printk(KERN_ERR TTM_PFX "Trying to take down uninitialized " | 1195 | printk(KERN_ERR TTM_PFX "Trying to take down uninitialized " |
| @@ -1305,7 +1338,8 @@ EXPORT_SYMBOL(ttm_bo_device_release); | |||
| 1305 | 1338 | ||
| 1306 | int ttm_bo_device_init(struct ttm_bo_device *bdev, | 1339 | int ttm_bo_device_init(struct ttm_bo_device *bdev, |
| 1307 | struct ttm_mem_global *mem_glob, | 1340 | struct ttm_mem_global *mem_glob, |
| 1308 | struct ttm_bo_driver *driver, uint64_t file_page_offset) | 1341 | struct ttm_bo_driver *driver, uint64_t file_page_offset, |
| 1342 | bool need_dma32) | ||
| 1309 | { | 1343 | { |
| 1310 | int ret = -EINVAL; | 1344 | int ret = -EINVAL; |
| 1311 | 1345 | ||
| @@ -1342,6 +1376,7 @@ int ttm_bo_device_init(struct ttm_bo_device *bdev, | |||
| 1342 | INIT_LIST_HEAD(&bdev->ddestroy); | 1376 | INIT_LIST_HEAD(&bdev->ddestroy); |
| 1343 | INIT_LIST_HEAD(&bdev->swap_lru); | 1377 | INIT_LIST_HEAD(&bdev->swap_lru); |
| 1344 | bdev->dev_mapping = NULL; | 1378 | bdev->dev_mapping = NULL; |
| 1379 | bdev->need_dma32 = need_dma32; | ||
| 1345 | ttm_mem_init_shrink(&bdev->shrink, ttm_bo_swapout); | 1380 | ttm_mem_init_shrink(&bdev->shrink, ttm_bo_swapout); |
| 1346 | ret = ttm_mem_register_shrink(mem_glob, &bdev->shrink); | 1381 | ret = ttm_mem_register_shrink(mem_glob, &bdev->shrink); |
| 1347 | if (unlikely(ret != 0)) { | 1382 | if (unlikely(ret != 0)) { |
| @@ -1419,6 +1454,7 @@ void ttm_bo_unmap_virtual(struct ttm_buffer_object *bo) | |||
| 1419 | 1454 | ||
| 1420 | unmap_mapping_range(bdev->dev_mapping, offset, holelen, 1); | 1455 | unmap_mapping_range(bdev->dev_mapping, offset, holelen, 1); |
| 1421 | } | 1456 | } |
| 1457 | EXPORT_SYMBOL(ttm_bo_unmap_virtual); | ||
| 1422 | 1458 | ||
| 1423 | static void ttm_bo_vm_insert_rb(struct ttm_buffer_object *bo) | 1459 | static void ttm_bo_vm_insert_rb(struct ttm_buffer_object *bo) |
| 1424 | { | 1460 | { |
| @@ -1540,6 +1576,10 @@ int ttm_bo_wait(struct ttm_buffer_object *bo, | |||
| 1540 | driver->sync_obj_unref(&sync_obj); | 1576 | driver->sync_obj_unref(&sync_obj); |
| 1541 | driver->sync_obj_unref(&tmp_obj); | 1577 | driver->sync_obj_unref(&tmp_obj); |
| 1542 | spin_lock(&bo->lock); | 1578 | spin_lock(&bo->lock); |
| 1579 | } else { | ||
| 1580 | spin_unlock(&bo->lock); | ||
| 1581 | driver->sync_obj_unref(&sync_obj); | ||
| 1582 | spin_lock(&bo->lock); | ||
| 1543 | } | 1583 | } |
| 1544 | } | 1584 | } |
| 1545 | return 0; | 1585 | return 0; |
diff --git a/drivers/gpu/drm/ttm/ttm_bo_util.c b/drivers/gpu/drm/ttm/ttm_bo_util.c index bdec583901eb..ad4ada07c6cf 100644 --- a/drivers/gpu/drm/ttm/ttm_bo_util.c +++ b/drivers/gpu/drm/ttm/ttm_bo_util.c | |||
| @@ -136,7 +136,8 @@ static int ttm_copy_io_page(void *dst, void *src, unsigned long page) | |||
| 136 | } | 136 | } |
| 137 | 137 | ||
| 138 | static int ttm_copy_io_ttm_page(struct ttm_tt *ttm, void *src, | 138 | static int ttm_copy_io_ttm_page(struct ttm_tt *ttm, void *src, |
| 139 | unsigned long page) | 139 | unsigned long page, |
| 140 | pgprot_t prot) | ||
| 140 | { | 141 | { |
| 141 | struct page *d = ttm_tt_get_page(ttm, page); | 142 | struct page *d = ttm_tt_get_page(ttm, page); |
| 142 | void *dst; | 143 | void *dst; |
| @@ -145,17 +146,35 @@ static int ttm_copy_io_ttm_page(struct ttm_tt *ttm, void *src, | |||
| 145 | return -ENOMEM; | 146 | return -ENOMEM; |
| 146 | 147 | ||
| 147 | src = (void *)((unsigned long)src + (page << PAGE_SHIFT)); | 148 | src = (void *)((unsigned long)src + (page << PAGE_SHIFT)); |
| 148 | dst = kmap(d); | 149 | |
| 150 | #ifdef CONFIG_X86 | ||
| 151 | dst = kmap_atomic_prot(d, KM_USER0, prot); | ||
| 152 | #else | ||
| 153 | if (pgprot_val(prot) != pgprot_val(PAGE_KERNEL)) | ||
| 154 | dst = vmap(&d, 1, 0, prot); | ||
| 155 | else | ||
| 156 | dst = kmap(d); | ||
| 157 | #endif | ||
| 149 | if (!dst) | 158 | if (!dst) |
| 150 | return -ENOMEM; | 159 | return -ENOMEM; |
| 151 | 160 | ||
| 152 | memcpy_fromio(dst, src, PAGE_SIZE); | 161 | memcpy_fromio(dst, src, PAGE_SIZE); |
| 153 | kunmap(d); | 162 | |
| 163 | #ifdef CONFIG_X86 | ||
| 164 | kunmap_atomic(dst, KM_USER0); | ||
| 165 | #else | ||
| 166 | if (pgprot_val(prot) != pgprot_val(PAGE_KERNEL)) | ||
| 167 | vunmap(dst); | ||
| 168 | else | ||
| 169 | kunmap(d); | ||
| 170 | #endif | ||
| 171 | |||
| 154 | return 0; | 172 | return 0; |
| 155 | } | 173 | } |
| 156 | 174 | ||
| 157 | static int ttm_copy_ttm_io_page(struct ttm_tt *ttm, void *dst, | 175 | static int ttm_copy_ttm_io_page(struct ttm_tt *ttm, void *dst, |
| 158 | unsigned long page) | 176 | unsigned long page, |
| 177 | pgprot_t prot) | ||
| 159 | { | 178 | { |
| 160 | struct page *s = ttm_tt_get_page(ttm, page); | 179 | struct page *s = ttm_tt_get_page(ttm, page); |
| 161 | void *src; | 180 | void *src; |
| @@ -164,12 +183,28 @@ static int ttm_copy_ttm_io_page(struct ttm_tt *ttm, void *dst, | |||
| 164 | return -ENOMEM; | 183 | return -ENOMEM; |
| 165 | 184 | ||
| 166 | dst = (void *)((unsigned long)dst + (page << PAGE_SHIFT)); | 185 | dst = (void *)((unsigned long)dst + (page << PAGE_SHIFT)); |
| 167 | src = kmap(s); | 186 | #ifdef CONFIG_X86 |
| 187 | src = kmap_atomic_prot(s, KM_USER0, prot); | ||
| 188 | #else | ||
| 189 | if (pgprot_val(prot) != pgprot_val(PAGE_KERNEL)) | ||
| 190 | src = vmap(&s, 1, 0, prot); | ||
| 191 | else | ||
| 192 | src = kmap(s); | ||
| 193 | #endif | ||
| 168 | if (!src) | 194 | if (!src) |
| 169 | return -ENOMEM; | 195 | return -ENOMEM; |
| 170 | 196 | ||
| 171 | memcpy_toio(dst, src, PAGE_SIZE); | 197 | memcpy_toio(dst, src, PAGE_SIZE); |
| 172 | kunmap(s); | 198 | |
| 199 | #ifdef CONFIG_X86 | ||
| 200 | kunmap_atomic(src, KM_USER0); | ||
| 201 | #else | ||
| 202 | if (pgprot_val(prot) != pgprot_val(PAGE_KERNEL)) | ||
| 203 | vunmap(src); | ||
| 204 | else | ||
| 205 | kunmap(s); | ||
| 206 | #endif | ||
| 207 | |||
| 173 | return 0; | 208 | return 0; |
| 174 | } | 209 | } |
| 175 | 210 | ||
| @@ -214,11 +249,17 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo, | |||
| 214 | 249 | ||
| 215 | for (i = 0; i < new_mem->num_pages; ++i) { | 250 | for (i = 0; i < new_mem->num_pages; ++i) { |
| 216 | page = i * dir + add; | 251 | page = i * dir + add; |
| 217 | if (old_iomap == NULL) | 252 | if (old_iomap == NULL) { |
| 218 | ret = ttm_copy_ttm_io_page(ttm, new_iomap, page); | 253 | pgprot_t prot = ttm_io_prot(old_mem->placement, |
| 219 | else if (new_iomap == NULL) | 254 | PAGE_KERNEL); |
| 220 | ret = ttm_copy_io_ttm_page(ttm, old_iomap, page); | 255 | ret = ttm_copy_ttm_io_page(ttm, new_iomap, page, |
| 221 | else | 256 | prot); |
| 257 | } else if (new_iomap == NULL) { | ||
| 258 | pgprot_t prot = ttm_io_prot(new_mem->placement, | ||
| 259 | PAGE_KERNEL); | ||
| 260 | ret = ttm_copy_io_ttm_page(ttm, old_iomap, page, | ||
| 261 | prot); | ||
| 262 | } else | ||
| 222 | ret = ttm_copy_io_page(new_iomap, old_iomap, page); | 263 | ret = ttm_copy_io_page(new_iomap, old_iomap, page); |
| 223 | if (ret) | 264 | if (ret) |
| 224 | goto out1; | 265 | goto out1; |
| @@ -509,8 +550,8 @@ int ttm_bo_move_accel_cleanup(struct ttm_buffer_object *bo, | |||
| 509 | if (evict) { | 550 | if (evict) { |
| 510 | ret = ttm_bo_wait(bo, false, false, false); | 551 | ret = ttm_bo_wait(bo, false, false, false); |
| 511 | spin_unlock(&bo->lock); | 552 | spin_unlock(&bo->lock); |
| 512 | driver->sync_obj_unref(&bo->sync_obj); | 553 | if (tmp_obj) |
| 513 | 554 | driver->sync_obj_unref(&tmp_obj); | |
| 514 | if (ret) | 555 | if (ret) |
| 515 | return ret; | 556 | return ret; |
| 516 | 557 | ||
| @@ -532,6 +573,8 @@ int ttm_bo_move_accel_cleanup(struct ttm_buffer_object *bo, | |||
| 532 | 573 | ||
| 533 | set_bit(TTM_BO_PRIV_FLAG_MOVING, &bo->priv_flags); | 574 | set_bit(TTM_BO_PRIV_FLAG_MOVING, &bo->priv_flags); |
| 534 | spin_unlock(&bo->lock); | 575 | spin_unlock(&bo->lock); |
| 576 | if (tmp_obj) | ||
| 577 | driver->sync_obj_unref(&tmp_obj); | ||
| 535 | 578 | ||
| 536 | ret = ttm_buffer_object_transfer(bo, &ghost_obj); | 579 | ret = ttm_buffer_object_transfer(bo, &ghost_obj); |
| 537 | if (ret) | 580 | if (ret) |
diff --git a/drivers/gpu/drm/ttm/ttm_bo_vm.c b/drivers/gpu/drm/ttm/ttm_bo_vm.c index fe949a12fe40..33de7637c0c6 100644 --- a/drivers/gpu/drm/ttm/ttm_bo_vm.c +++ b/drivers/gpu/drm/ttm/ttm_bo_vm.c | |||
| @@ -101,6 +101,9 @@ static int ttm_bo_vm_fault(struct vm_area_struct *vma, struct vm_fault *vmf) | |||
| 101 | return VM_FAULT_NOPAGE; | 101 | return VM_FAULT_NOPAGE; |
| 102 | } | 102 | } |
| 103 | 103 | ||
| 104 | if (bdev->driver->fault_reserve_notify) | ||
| 105 | bdev->driver->fault_reserve_notify(bo); | ||
| 106 | |||
| 104 | /* | 107 | /* |
| 105 | * Wait for buffer data in transit, due to a pipelined | 108 | * Wait for buffer data in transit, due to a pipelined |
| 106 | * move. | 109 | * move. |
diff --git a/drivers/gpu/drm/ttm/ttm_tt.c b/drivers/gpu/drm/ttm/ttm_tt.c index 75dc8bd24592..b8b6c4a5f983 100644 --- a/drivers/gpu/drm/ttm/ttm_tt.c +++ b/drivers/gpu/drm/ttm/ttm_tt.c | |||
| @@ -86,10 +86,16 @@ void ttm_tt_cache_flush(struct page *pages[], unsigned long num_pages) | |||
| 86 | unsigned long i; | 86 | unsigned long i; |
| 87 | 87 | ||
| 88 | for (i = 0; i < num_pages; ++i) { | 88 | for (i = 0; i < num_pages; ++i) { |
| 89 | if (pages[i]) { | 89 | struct page *page = pages[i]; |
| 90 | unsigned long start = (unsigned long)page_address(pages[i]); | 90 | void *page_virtual; |
| 91 | flush_dcache_range(start, start + PAGE_SIZE); | 91 | |
| 92 | } | 92 | if (unlikely(page == NULL)) |
| 93 | continue; | ||
| 94 | |||
| 95 | page_virtual = kmap_atomic(page, KM_USER0); | ||
| 96 | flush_dcache_range((unsigned long) page_virtual, | ||
| 97 | (unsigned long) page_virtual + PAGE_SIZE); | ||
| 98 | kunmap_atomic(page_virtual, KM_USER0); | ||
| 93 | } | 99 | } |
| 94 | #else | 100 | #else |
| 95 | if (on_each_cpu(ttm_tt_ipi_handler, NULL, 1) != 0) | 101 | if (on_each_cpu(ttm_tt_ipi_handler, NULL, 1) != 0) |
| @@ -131,10 +137,17 @@ static void ttm_tt_free_page_directory(struct ttm_tt *ttm) | |||
| 131 | 137 | ||
| 132 | static struct page *ttm_tt_alloc_page(unsigned page_flags) | 138 | static struct page *ttm_tt_alloc_page(unsigned page_flags) |
| 133 | { | 139 | { |
| 140 | gfp_t gfp_flags = GFP_USER; | ||
| 141 | |||
| 134 | if (page_flags & TTM_PAGE_FLAG_ZERO_ALLOC) | 142 | if (page_flags & TTM_PAGE_FLAG_ZERO_ALLOC) |
| 135 | return alloc_page(GFP_HIGHUSER | __GFP_ZERO); | 143 | gfp_flags |= __GFP_ZERO; |
| 144 | |||
| 145 | if (page_flags & TTM_PAGE_FLAG_DMA32) | ||
| 146 | gfp_flags |= __GFP_DMA32; | ||
| 147 | else | ||
| 148 | gfp_flags |= __GFP_HIGHMEM; | ||
| 136 | 149 | ||
| 137 | return alloc_page(GFP_HIGHUSER); | 150 | return alloc_page(gfp_flags); |
| 138 | } | 151 | } |
| 139 | 152 | ||
| 140 | static void ttm_tt_free_user_pages(struct ttm_tt *ttm) | 153 | static void ttm_tt_free_user_pages(struct ttm_tt *ttm) |
diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c index f2c21d5d24e8..5eb10c2ce665 100644 --- a/drivers/hid/hid-core.c +++ b/drivers/hid/hid-core.c | |||
| @@ -1075,14 +1075,16 @@ EXPORT_SYMBOL_GPL(hid_report_raw_event); | |||
| 1075 | */ | 1075 | */ |
| 1076 | int hid_input_report(struct hid_device *hid, int type, u8 *data, int size, int interrupt) | 1076 | int hid_input_report(struct hid_device *hid, int type, u8 *data, int size, int interrupt) |
| 1077 | { | 1077 | { |
| 1078 | struct hid_report_enum *report_enum = hid->report_enum + type; | 1078 | struct hid_report_enum *report_enum; |
| 1079 | struct hid_driver *hdrv = hid->driver; | 1079 | struct hid_driver *hdrv; |
| 1080 | struct hid_report *report; | 1080 | struct hid_report *report; |
| 1081 | unsigned int i; | 1081 | unsigned int i; |
| 1082 | int ret; | 1082 | int ret; |
| 1083 | 1083 | ||
| 1084 | if (!hid || !hid->driver) | 1084 | if (!hid || !hid->driver) |
| 1085 | return -ENODEV; | 1085 | return -ENODEV; |
| 1086 | report_enum = hid->report_enum + type; | ||
| 1087 | hdrv = hid->driver; | ||
| 1086 | 1088 | ||
| 1087 | if (!size) { | 1089 | if (!size) { |
| 1088 | dbg_hid("empty report\n"); | 1090 | dbg_hid("empty report\n"); |
diff --git a/drivers/hid/usbhid/hiddev.c b/drivers/hid/usbhid/hiddev.c index 9e9421525fb9..215b2addddbb 100644 --- a/drivers/hid/usbhid/hiddev.c +++ b/drivers/hid/usbhid/hiddev.c | |||
| @@ -527,8 +527,10 @@ static noinline int hiddev_ioctl_usage(struct hiddev *hiddev, unsigned int cmd, | |||
| 527 | goto goodreturn; | 527 | goto goodreturn; |
| 528 | 528 | ||
| 529 | case HIDIOCGCOLLECTIONINDEX: | 529 | case HIDIOCGCOLLECTIONINDEX: |
| 530 | i = field->usage[uref->usage_index].collection_index; | ||
| 531 | unlock_kernel(); | ||
| 530 | kfree(uref_multi); | 532 | kfree(uref_multi); |
| 531 | return field->usage[uref->usage_index].collection_index; | 533 | return i; |
| 532 | case HIDIOCGUSAGES: | 534 | case HIDIOCGUSAGES: |
| 533 | for (i = 0; i < uref_multi->num_values; i++) | 535 | for (i = 0; i < uref_multi->num_values; i++) |
| 534 | uref_multi->values[i] = | 536 | uref_multi->values[i] = |
diff --git a/drivers/hwmon/asus_atk0110.c b/drivers/hwmon/asus_atk0110.c index bff0103610c1..fe4fa29c9219 100644 --- a/drivers/hwmon/asus_atk0110.c +++ b/drivers/hwmon/asus_atk0110.c | |||
| @@ -593,7 +593,11 @@ static int atk_add_sensor(struct atk_data *data, union acpi_object *obj) | |||
| 593 | sensor->data = data; | 593 | sensor->data = data; |
| 594 | sensor->id = flags->integer.value; | 594 | sensor->id = flags->integer.value; |
| 595 | sensor->limit1 = limit1->integer.value; | 595 | sensor->limit1 = limit1->integer.value; |
| 596 | sensor->limit2 = limit2->integer.value; | 596 | if (data->old_interface) |
| 597 | sensor->limit2 = limit2->integer.value; | ||
| 598 | else | ||
| 599 | /* The upper limit is expressed as delta from lower limit */ | ||
| 600 | sensor->limit2 = sensor->limit1 + limit2->integer.value; | ||
| 597 | 601 | ||
| 598 | snprintf(sensor->input_attr_name, ATTR_NAME_SIZE, | 602 | snprintf(sensor->input_attr_name, ATTR_NAME_SIZE, |
| 599 | "%s%d_input", base_name, start + *num); | 603 | "%s%d_input", base_name, start + *num); |
diff --git a/drivers/hwmon/smsc47m1.c b/drivers/hwmon/smsc47m1.c index a92dbb97ee99..ba75bfcf14ce 100644 --- a/drivers/hwmon/smsc47m1.c +++ b/drivers/hwmon/smsc47m1.c | |||
| @@ -86,6 +86,7 @@ superio_exit(void) | |||
| 86 | #define SUPERIO_REG_ACT 0x30 | 86 | #define SUPERIO_REG_ACT 0x30 |
| 87 | #define SUPERIO_REG_BASE 0x60 | 87 | #define SUPERIO_REG_BASE 0x60 |
| 88 | #define SUPERIO_REG_DEVID 0x20 | 88 | #define SUPERIO_REG_DEVID 0x20 |
| 89 | #define SUPERIO_REG_DEVREV 0x21 | ||
| 89 | 90 | ||
| 90 | /* Logical device registers */ | 91 | /* Logical device registers */ |
| 91 | 92 | ||
| @@ -429,6 +430,9 @@ static int __init smsc47m1_find(unsigned short *addr, | |||
| 429 | * The LPC47M292 (device id 0x6B) is somewhat compatible, but it | 430 | * The LPC47M292 (device id 0x6B) is somewhat compatible, but it |
| 430 | * supports a 3rd fan, and the pin configuration registers are | 431 | * supports a 3rd fan, and the pin configuration registers are |
| 431 | * unfortunately different. | 432 | * unfortunately different. |
| 433 | * The LPC47M233 has the same device id (0x6B) but is not compatible. | ||
| 434 | * We check the high bit of the device revision register to | ||
| 435 | * differentiate them. | ||
| 432 | */ | 436 | */ |
| 433 | switch (val) { | 437 | switch (val) { |
| 434 | case 0x51: | 438 | case 0x51: |
| @@ -448,6 +452,13 @@ static int __init smsc47m1_find(unsigned short *addr, | |||
| 448 | sio_data->type = smsc47m1; | 452 | sio_data->type = smsc47m1; |
| 449 | break; | 453 | break; |
| 450 | case 0x6B: | 454 | case 0x6B: |
| 455 | if (superio_inb(SUPERIO_REG_DEVREV) & 0x80) { | ||
| 456 | pr_debug(DRVNAME ": " | ||
| 457 | "Found SMSC LPC47M233, unsupported\n"); | ||
| 458 | superio_exit(); | ||
| 459 | return -ENODEV; | ||
| 460 | } | ||
| 461 | |||
| 451 | pr_info(DRVNAME ": Found SMSC LPC47M292\n"); | 462 | pr_info(DRVNAME ": Found SMSC LPC47M292\n"); |
| 452 | sio_data->type = smsc47m2; | 463 | sio_data->type = smsc47m2; |
| 453 | break; | 464 | break; |
diff --git a/drivers/i2c/busses/i2c-omap.c b/drivers/i2c/busses/i2c-omap.c index fdd83277c8a8..827da0858136 100644 --- a/drivers/i2c/busses/i2c-omap.c +++ b/drivers/i2c/busses/i2c-omap.c | |||
| @@ -672,9 +672,17 @@ omap_i2c_isr(int this_irq, void *dev_id) | |||
| 672 | break; | 672 | break; |
| 673 | } | 673 | } |
| 674 | 674 | ||
| 675 | omap_i2c_write_reg(dev, OMAP_I2C_STAT_REG, stat); | ||
| 676 | |||
| 677 | err = 0; | 675 | err = 0; |
| 676 | complete: | ||
| 677 | /* | ||
| 678 | * Ack the stat in one go, but [R/X]DR and [R/X]RDY should be | ||
| 679 | * acked after the data operation is complete. | ||
| 680 | * Ref: TRM SWPU114Q Figure 18-31 | ||
| 681 | */ | ||
| 682 | omap_i2c_write_reg(dev, OMAP_I2C_STAT_REG, stat & | ||
| 683 | ~(OMAP_I2C_STAT_RRDY | OMAP_I2C_STAT_RDR | | ||
| 684 | OMAP_I2C_STAT_XRDY | OMAP_I2C_STAT_XDR)); | ||
| 685 | |||
| 678 | if (stat & OMAP_I2C_STAT_NACK) { | 686 | if (stat & OMAP_I2C_STAT_NACK) { |
| 679 | err |= OMAP_I2C_STAT_NACK; | 687 | err |= OMAP_I2C_STAT_NACK; |
| 680 | omap_i2c_write_reg(dev, OMAP_I2C_CON_REG, | 688 | omap_i2c_write_reg(dev, OMAP_I2C_CON_REG, |
| @@ -685,16 +693,22 @@ omap_i2c_isr(int this_irq, void *dev_id) | |||
| 685 | err |= OMAP_I2C_STAT_AL; | 693 | err |= OMAP_I2C_STAT_AL; |
| 686 | } | 694 | } |
| 687 | if (stat & (OMAP_I2C_STAT_ARDY | OMAP_I2C_STAT_NACK | | 695 | if (stat & (OMAP_I2C_STAT_ARDY | OMAP_I2C_STAT_NACK | |
| 688 | OMAP_I2C_STAT_AL)) | 696 | OMAP_I2C_STAT_AL)) { |
| 697 | omap_i2c_ack_stat(dev, stat & | ||
| 698 | (OMAP_I2C_STAT_RRDY | OMAP_I2C_STAT_RDR | | ||
| 699 | OMAP_I2C_STAT_XRDY | OMAP_I2C_STAT_XDR)); | ||
| 689 | omap_i2c_complete_cmd(dev, err); | 700 | omap_i2c_complete_cmd(dev, err); |
| 701 | return IRQ_HANDLED; | ||
| 702 | } | ||
| 690 | if (stat & (OMAP_I2C_STAT_RRDY | OMAP_I2C_STAT_RDR)) { | 703 | if (stat & (OMAP_I2C_STAT_RRDY | OMAP_I2C_STAT_RDR)) { |
| 691 | u8 num_bytes = 1; | 704 | u8 num_bytes = 1; |
| 692 | if (dev->fifo_size) { | 705 | if (dev->fifo_size) { |
| 693 | if (stat & OMAP_I2C_STAT_RRDY) | 706 | if (stat & OMAP_I2C_STAT_RRDY) |
| 694 | num_bytes = dev->fifo_size; | 707 | num_bytes = dev->fifo_size; |
| 695 | else | 708 | else /* read RXSTAT on RDR interrupt */ |
| 696 | num_bytes = omap_i2c_read_reg(dev, | 709 | num_bytes = (omap_i2c_read_reg(dev, |
| 697 | OMAP_I2C_BUFSTAT_REG); | 710 | OMAP_I2C_BUFSTAT_REG) |
| 711 | >> 8) & 0x3F; | ||
| 698 | } | 712 | } |
| 699 | while (num_bytes) { | 713 | while (num_bytes) { |
| 700 | num_bytes--; | 714 | num_bytes--; |
| @@ -731,9 +745,10 @@ omap_i2c_isr(int this_irq, void *dev_id) | |||
| 731 | if (dev->fifo_size) { | 745 | if (dev->fifo_size) { |
| 732 | if (stat & OMAP_I2C_STAT_XRDY) | 746 | if (stat & OMAP_I2C_STAT_XRDY) |
| 733 | num_bytes = dev->fifo_size; | 747 | num_bytes = dev->fifo_size; |
| 734 | else | 748 | else /* read TXSTAT on XDR interrupt */ |
| 735 | num_bytes = omap_i2c_read_reg(dev, | 749 | num_bytes = omap_i2c_read_reg(dev, |
| 736 | OMAP_I2C_BUFSTAT_REG); | 750 | OMAP_I2C_BUFSTAT_REG) |
| 751 | & 0x3F; | ||
| 737 | } | 752 | } |
| 738 | while (num_bytes) { | 753 | while (num_bytes) { |
| 739 | num_bytes--; | 754 | num_bytes--; |
| @@ -760,6 +775,27 @@ omap_i2c_isr(int this_irq, void *dev_id) | |||
| 760 | "data to send\n"); | 775 | "data to send\n"); |
| 761 | break; | 776 | break; |
| 762 | } | 777 | } |
| 778 | |||
| 779 | /* | ||
| 780 | * OMAP3430 Errata 1.153: When an XRDY/XDR | ||
| 781 | * is hit, wait for XUDF before writing data | ||
| 782 | * to DATA_REG. Otherwise some data bytes can | ||
| 783 | * be lost while transferring them from the | ||
| 784 | * memory to the I2C interface. | ||
| 785 | */ | ||
| 786 | |||
| 787 | if (dev->rev <= OMAP_I2C_REV_ON_3430) { | ||
| 788 | while (!(stat & OMAP_I2C_STAT_XUDF)) { | ||
| 789 | if (stat & (OMAP_I2C_STAT_NACK | OMAP_I2C_STAT_AL)) { | ||
| 790 | omap_i2c_ack_stat(dev, stat & (OMAP_I2C_STAT_XRDY | OMAP_I2C_STAT_XDR)); | ||
| 791 | err |= OMAP_I2C_STAT_XUDF; | ||
| 792 | goto complete; | ||
| 793 | } | ||
| 794 | cpu_relax(); | ||
| 795 | stat = omap_i2c_read_reg(dev, OMAP_I2C_STAT_REG); | ||
| 796 | } | ||
| 797 | } | ||
| 798 | |||
| 763 | omap_i2c_write_reg(dev, OMAP_I2C_DATA_REG, w); | 799 | omap_i2c_write_reg(dev, OMAP_I2C_DATA_REG, w); |
| 764 | } | 800 | } |
| 765 | omap_i2c_ack_stat(dev, | 801 | omap_i2c_ack_stat(dev, |
| @@ -879,7 +915,7 @@ omap_i2c_probe(struct platform_device *pdev) | |||
| 879 | i2c_set_adapdata(adap, dev); | 915 | i2c_set_adapdata(adap, dev); |
| 880 | adap->owner = THIS_MODULE; | 916 | adap->owner = THIS_MODULE; |
| 881 | adap->class = I2C_CLASS_HWMON; | 917 | adap->class = I2C_CLASS_HWMON; |
| 882 | strncpy(adap->name, "OMAP I2C adapter", sizeof(adap->name)); | 918 | strlcpy(adap->name, "OMAP I2C adapter", sizeof(adap->name)); |
| 883 | adap->algo = &omap_i2c_algo; | 919 | adap->algo = &omap_i2c_algo; |
| 884 | adap->dev.parent = &pdev->dev; | 920 | adap->dev.parent = &pdev->dev; |
| 885 | 921 | ||
diff --git a/drivers/i2c/busses/i2c-s3c2410.c b/drivers/i2c/busses/i2c-s3c2410.c index 8f42a4536cdf..20bb0ceb027b 100644 --- a/drivers/i2c/busses/i2c-s3c2410.c +++ b/drivers/i2c/busses/i2c-s3c2410.c | |||
| @@ -763,11 +763,6 @@ static int s3c24xx_i2c_init(struct s3c24xx_i2c *i2c) | |||
| 763 | dev_info(i2c->dev, "bus frequency set to %d KHz\n", freq); | 763 | dev_info(i2c->dev, "bus frequency set to %d KHz\n", freq); |
| 764 | dev_dbg(i2c->dev, "S3C2410_IICCON=0x%02lx\n", iicon); | 764 | dev_dbg(i2c->dev, "S3C2410_IICCON=0x%02lx\n", iicon); |
| 765 | 765 | ||
| 766 | /* check for s3c2440 i2c controller */ | ||
| 767 | |||
| 768 | if (s3c24xx_i2c_is2440(i2c)) | ||
| 769 | writel(0x0, i2c->regs + S3C2440_IICLC); | ||
| 770 | |||
| 771 | return 0; | 766 | return 0; |
| 772 | } | 767 | } |
| 773 | 768 | ||
diff --git a/drivers/i2c/busses/i2c-sh_mobile.c b/drivers/i2c/busses/i2c-sh_mobile.c index 4f3d99cd1692..820487d0d5c7 100644 --- a/drivers/i2c/busses/i2c-sh_mobile.c +++ b/drivers/i2c/busses/i2c-sh_mobile.c | |||
| @@ -637,7 +637,7 @@ static void __exit sh_mobile_i2c_adap_exit(void) | |||
| 637 | platform_driver_unregister(&sh_mobile_i2c_driver); | 637 | platform_driver_unregister(&sh_mobile_i2c_driver); |
| 638 | } | 638 | } |
| 639 | 639 | ||
| 640 | module_init(sh_mobile_i2c_adap_init); | 640 | subsys_initcall(sh_mobile_i2c_adap_init); |
| 641 | module_exit(sh_mobile_i2c_adap_exit); | 641 | module_exit(sh_mobile_i2c_adap_exit); |
| 642 | 642 | ||
| 643 | MODULE_DESCRIPTION("SuperH Mobile I2C Bus Controller driver"); | 643 | MODULE_DESCRIPTION("SuperH Mobile I2C Bus Controller driver"); |
diff --git a/drivers/i2c/busses/i2c-stu300.c b/drivers/i2c/busses/i2c-stu300.c index 182e711318ba..d2728a28a8db 100644 --- a/drivers/i2c/busses/i2c-stu300.c +++ b/drivers/i2c/busses/i2c-stu300.c | |||
| @@ -117,7 +117,8 @@ enum stu300_error { | |||
| 117 | STU300_ERROR_NONE = 0, | 117 | STU300_ERROR_NONE = 0, |
| 118 | STU300_ERROR_ACKNOWLEDGE_FAILURE, | 118 | STU300_ERROR_ACKNOWLEDGE_FAILURE, |
| 119 | STU300_ERROR_BUS_ERROR, | 119 | STU300_ERROR_BUS_ERROR, |
| 120 | STU300_ERROR_ARBITRATION_LOST | 120 | STU300_ERROR_ARBITRATION_LOST, |
| 121 | STU300_ERROR_UNKNOWN | ||
| 121 | }; | 122 | }; |
| 122 | 123 | ||
| 123 | /* timeout waiting for the controller to respond */ | 124 | /* timeout waiting for the controller to respond */ |
| @@ -127,7 +128,7 @@ enum stu300_error { | |||
| 127 | * The number of address send athemps tried before giving up. | 128 | * The number of address send athemps tried before giving up. |
| 128 | * If the first one failes it seems like 5 to 8 attempts are required. | 129 | * If the first one failes it seems like 5 to 8 attempts are required. |
| 129 | */ | 130 | */ |
| 130 | #define NUM_ADDR_RESEND_ATTEMPTS 10 | 131 | #define NUM_ADDR_RESEND_ATTEMPTS 12 |
| 131 | 132 | ||
| 132 | /* I2C clock speed, in Hz 0-400kHz*/ | 133 | /* I2C clock speed, in Hz 0-400kHz*/ |
| 133 | static unsigned int scl_frequency = 100000; | 134 | static unsigned int scl_frequency = 100000; |
| @@ -149,6 +150,7 @@ module_param(scl_frequency, uint, 0644); | |||
| 149 | * @msg_index: index of current message | 150 | * @msg_index: index of current message |
| 150 | * @msg_len: length of current message | 151 | * @msg_len: length of current message |
| 151 | */ | 152 | */ |
| 153 | |||
| 152 | struct stu300_dev { | 154 | struct stu300_dev { |
| 153 | struct platform_device *pdev; | 155 | struct platform_device *pdev; |
| 154 | struct i2c_adapter adapter; | 156 | struct i2c_adapter adapter; |
| @@ -188,6 +190,27 @@ static inline u32 stu300_r8(void __iomem *address) | |||
| 188 | return readl(address) & 0x000000FFU; | 190 | return readl(address) & 0x000000FFU; |
| 189 | } | 191 | } |
| 190 | 192 | ||
| 193 | static void stu300_irq_enable(struct stu300_dev *dev) | ||
| 194 | { | ||
| 195 | u32 val; | ||
| 196 | val = stu300_r8(dev->virtbase + I2C_CR); | ||
| 197 | val |= I2C_CR_INTERRUPT_ENABLE; | ||
| 198 | /* Twice paranoia (possible HW glitch) */ | ||
| 199 | stu300_wr8(val, dev->virtbase + I2C_CR); | ||
| 200 | stu300_wr8(val, dev->virtbase + I2C_CR); | ||
| 201 | } | ||
| 202 | |||
| 203 | static void stu300_irq_disable(struct stu300_dev *dev) | ||
| 204 | { | ||
| 205 | u32 val; | ||
| 206 | val = stu300_r8(dev->virtbase + I2C_CR); | ||
| 207 | val &= ~I2C_CR_INTERRUPT_ENABLE; | ||
| 208 | /* Twice paranoia (possible HW glitch) */ | ||
| 209 | stu300_wr8(val, dev->virtbase + I2C_CR); | ||
| 210 | stu300_wr8(val, dev->virtbase + I2C_CR); | ||
| 211 | } | ||
| 212 | |||
| 213 | |||
| 191 | /* | 214 | /* |
| 192 | * Tells whether a certain event or events occurred in | 215 | * Tells whether a certain event or events occurred in |
| 193 | * response to a command. The events represent states in | 216 | * response to a command. The events represent states in |
| @@ -196,9 +219,10 @@ static inline u32 stu300_r8(void __iomem *address) | |||
| 196 | * documentation and can only be treated as abstract state | 219 | * documentation and can only be treated as abstract state |
| 197 | * machine states. | 220 | * machine states. |
| 198 | * | 221 | * |
| 199 | * @ret 0 = event has not occurred, any other value means | 222 | * @ret 0 = event has not occurred or unknown error, any |
| 200 | * the event occurred. | 223 | * other value means the correct event occurred or an error. |
| 201 | */ | 224 | */ |
| 225 | |||
| 202 | static int stu300_event_occurred(struct stu300_dev *dev, | 226 | static int stu300_event_occurred(struct stu300_dev *dev, |
| 203 | enum stu300_event mr_event) { | 227 | enum stu300_event mr_event) { |
| 204 | u32 status1; | 228 | u32 status1; |
| @@ -206,11 +230,28 @@ static int stu300_event_occurred(struct stu300_dev *dev, | |||
| 206 | 230 | ||
| 207 | /* What event happened? */ | 231 | /* What event happened? */ |
| 208 | status1 = stu300_r8(dev->virtbase + I2C_SR1); | 232 | status1 = stu300_r8(dev->virtbase + I2C_SR1); |
| 233 | |||
| 209 | if (!(status1 & I2C_SR1_EVF_IND)) | 234 | if (!(status1 & I2C_SR1_EVF_IND)) |
| 210 | /* No event at all */ | 235 | /* No event at all */ |
| 211 | return 0; | 236 | return 0; |
| 237 | |||
| 212 | status2 = stu300_r8(dev->virtbase + I2C_SR2); | 238 | status2 = stu300_r8(dev->virtbase + I2C_SR2); |
| 213 | 239 | ||
| 240 | /* Block any multiple interrupts */ | ||
| 241 | stu300_irq_disable(dev); | ||
| 242 | |||
| 243 | /* Check for errors first */ | ||
| 244 | if (status2 & I2C_SR2_AF_IND) { | ||
| 245 | dev->cmd_err = STU300_ERROR_ACKNOWLEDGE_FAILURE; | ||
| 246 | return 1; | ||
| 247 | } else if (status2 & I2C_SR2_BERR_IND) { | ||
| 248 | dev->cmd_err = STU300_ERROR_BUS_ERROR; | ||
| 249 | return 1; | ||
| 250 | } else if (status2 & I2C_SR2_ARLO_IND) { | ||
| 251 | dev->cmd_err = STU300_ERROR_ARBITRATION_LOST; | ||
| 252 | return 1; | ||
| 253 | } | ||
| 254 | |||
| 214 | switch (mr_event) { | 255 | switch (mr_event) { |
| 215 | case STU300_EVENT_1: | 256 | case STU300_EVENT_1: |
| 216 | if (status1 & I2C_SR1_ADSL_IND) | 257 | if (status1 & I2C_SR1_ADSL_IND) |
| @@ -221,10 +262,6 @@ static int stu300_event_occurred(struct stu300_dev *dev, | |||
| 221 | case STU300_EVENT_7: | 262 | case STU300_EVENT_7: |
| 222 | case STU300_EVENT_8: | 263 | case STU300_EVENT_8: |
| 223 | if (status1 & I2C_SR1_BTF_IND) { | 264 | if (status1 & I2C_SR1_BTF_IND) { |
| 224 | if (status2 & I2C_SR2_AF_IND) | ||
| 225 | dev->cmd_err = STU300_ERROR_ACKNOWLEDGE_FAILURE; | ||
| 226 | else if (status2 & I2C_SR2_BERR_IND) | ||
| 227 | dev->cmd_err = STU300_ERROR_BUS_ERROR; | ||
| 228 | return 1; | 265 | return 1; |
| 229 | } | 266 | } |
| 230 | break; | 267 | break; |
| @@ -240,8 +277,6 @@ static int stu300_event_occurred(struct stu300_dev *dev, | |||
| 240 | case STU300_EVENT_6: | 277 | case STU300_EVENT_6: |
| 241 | if (status2 & I2C_SR2_ENDAD_IND) { | 278 | if (status2 & I2C_SR2_ENDAD_IND) { |
| 242 | /* First check for any errors */ | 279 | /* First check for any errors */ |
| 243 | if (status2 & I2C_SR2_AF_IND) | ||
| 244 | dev->cmd_err = STU300_ERROR_ACKNOWLEDGE_FAILURE; | ||
| 245 | return 1; | 280 | return 1; |
| 246 | } | 281 | } |
| 247 | break; | 282 | break; |
| @@ -252,8 +287,15 @@ static int stu300_event_occurred(struct stu300_dev *dev, | |||
| 252 | default: | 287 | default: |
| 253 | break; | 288 | break; |
| 254 | } | 289 | } |
| 255 | if (status2 & I2C_SR2_ARLO_IND) | 290 | /* If we get here, we're on thin ice. |
| 256 | dev->cmd_err = STU300_ERROR_ARBITRATION_LOST; | 291 | * Here we are in a status where we have |
| 292 | * gotten a response that does not match | ||
| 293 | * what we requested. | ||
| 294 | */ | ||
| 295 | dev->cmd_err = STU300_ERROR_UNKNOWN; | ||
| 296 | dev_err(&dev->pdev->dev, | ||
| 297 | "Unhandled interrupt! %d sr1: 0x%x sr2: 0x%x\n", | ||
| 298 | mr_event, status1, status2); | ||
| 257 | return 0; | 299 | return 0; |
| 258 | } | 300 | } |
| 259 | 301 | ||
| @@ -262,21 +304,20 @@ static irqreturn_t stu300_irh(int irq, void *data) | |||
| 262 | struct stu300_dev *dev = data; | 304 | struct stu300_dev *dev = data; |
| 263 | int res; | 305 | int res; |
| 264 | 306 | ||
| 307 | /* Just make sure that the block is clocked */ | ||
| 308 | clk_enable(dev->clk); | ||
| 309 | |||
| 265 | /* See if this was what we were waiting for */ | 310 | /* See if this was what we were waiting for */ |
| 266 | spin_lock(&dev->cmd_issue_lock); | 311 | spin_lock(&dev->cmd_issue_lock); |
| 267 | if (dev->cmd_event != STU300_EVENT_NONE) { | 312 | |
| 268 | res = stu300_event_occurred(dev, dev->cmd_event); | 313 | res = stu300_event_occurred(dev, dev->cmd_event); |
| 269 | if (res || dev->cmd_err != STU300_ERROR_NONE) { | 314 | if (res || dev->cmd_err != STU300_ERROR_NONE) |
| 270 | u32 val; | 315 | complete(&dev->cmd_complete); |
| 271 | 316 | ||
| 272 | complete(&dev->cmd_complete); | ||
| 273 | /* Block any multiple interrupts */ | ||
| 274 | val = stu300_r8(dev->virtbase + I2C_CR); | ||
| 275 | val &= ~I2C_CR_INTERRUPT_ENABLE; | ||
| 276 | stu300_wr8(val, dev->virtbase + I2C_CR); | ||
| 277 | } | ||
| 278 | } | ||
| 279 | spin_unlock(&dev->cmd_issue_lock); | 317 | spin_unlock(&dev->cmd_issue_lock); |
| 318 | |||
| 319 | clk_disable(dev->clk); | ||
| 320 | |||
| 280 | return IRQ_HANDLED; | 321 | return IRQ_HANDLED; |
| 281 | } | 322 | } |
| 282 | 323 | ||
| @@ -308,7 +349,6 @@ static int stu300_start_and_await_event(struct stu300_dev *dev, | |||
| 308 | stu300_wr8(cr_value, dev->virtbase + I2C_CR); | 349 | stu300_wr8(cr_value, dev->virtbase + I2C_CR); |
| 309 | ret = wait_for_completion_interruptible_timeout(&dev->cmd_complete, | 350 | ret = wait_for_completion_interruptible_timeout(&dev->cmd_complete, |
| 310 | STU300_TIMEOUT); | 351 | STU300_TIMEOUT); |
| 311 | |||
| 312 | if (ret < 0) { | 352 | if (ret < 0) { |
| 313 | dev_err(&dev->pdev->dev, | 353 | dev_err(&dev->pdev->dev, |
| 314 | "wait_for_completion_interruptible_timeout() " | 354 | "wait_for_completion_interruptible_timeout() " |
| @@ -342,7 +382,6 @@ static int stu300_await_event(struct stu300_dev *dev, | |||
| 342 | enum stu300_event mr_event) | 382 | enum stu300_event mr_event) |
| 343 | { | 383 | { |
| 344 | int ret; | 384 | int ret; |
| 345 | u32 val; | ||
| 346 | 385 | ||
| 347 | if (unlikely(irqs_disabled())) { | 386 | if (unlikely(irqs_disabled())) { |
| 348 | /* TODO: implement polling for this case if need be. */ | 387 | /* TODO: implement polling for this case if need be. */ |
| @@ -354,36 +393,18 @@ static int stu300_await_event(struct stu300_dev *dev, | |||
| 354 | /* Is it already here? */ | 393 | /* Is it already here? */ |
| 355 | spin_lock_irq(&dev->cmd_issue_lock); | 394 | spin_lock_irq(&dev->cmd_issue_lock); |
| 356 | dev->cmd_err = STU300_ERROR_NONE; | 395 | dev->cmd_err = STU300_ERROR_NONE; |
| 357 | if (stu300_event_occurred(dev, mr_event)) { | ||
| 358 | spin_unlock_irq(&dev->cmd_issue_lock); | ||
| 359 | goto exit_await_check_err; | ||
| 360 | } | ||
| 361 | init_completion(&dev->cmd_complete); | ||
| 362 | dev->cmd_err = STU300_ERROR_NONE; | ||
| 363 | dev->cmd_event = mr_event; | 396 | dev->cmd_event = mr_event; |
| 364 | 397 | ||
| 365 | /* Turn on the I2C interrupt for current operation */ | 398 | init_completion(&dev->cmd_complete); |
| 366 | val = stu300_r8(dev->virtbase + I2C_CR); | ||
| 367 | val |= I2C_CR_INTERRUPT_ENABLE; | ||
| 368 | stu300_wr8(val, dev->virtbase + I2C_CR); | ||
| 369 | |||
| 370 | /* Twice paranoia (possible HW glitch) */ | ||
| 371 | stu300_wr8(val, dev->virtbase + I2C_CR); | ||
| 372 | 399 | ||
| 373 | /* Check again: is it already here? */ | 400 | /* Turn on the I2C interrupt for current operation */ |
| 374 | if (unlikely(stu300_event_occurred(dev, mr_event))) { | 401 | stu300_irq_enable(dev); |
| 375 | /* Disable IRQ again. */ | ||
| 376 | val &= ~I2C_CR_INTERRUPT_ENABLE; | ||
| 377 | stu300_wr8(val, dev->virtbase + I2C_CR); | ||
| 378 | spin_unlock_irq(&dev->cmd_issue_lock); | ||
| 379 | goto exit_await_check_err; | ||
| 380 | } | ||
| 381 | 402 | ||
| 382 | /* Unlock the command block and wait for the event to occur */ | 403 | /* Unlock the command block and wait for the event to occur */ |
| 383 | spin_unlock_irq(&dev->cmd_issue_lock); | 404 | spin_unlock_irq(&dev->cmd_issue_lock); |
| 405 | |||
| 384 | ret = wait_for_completion_interruptible_timeout(&dev->cmd_complete, | 406 | ret = wait_for_completion_interruptible_timeout(&dev->cmd_complete, |
| 385 | STU300_TIMEOUT); | 407 | STU300_TIMEOUT); |
| 386 | |||
| 387 | if (ret < 0) { | 408 | if (ret < 0) { |
| 388 | dev_err(&dev->pdev->dev, | 409 | dev_err(&dev->pdev->dev, |
| 389 | "wait_for_completion_interruptible_timeout()" | 410 | "wait_for_completion_interruptible_timeout()" |
| @@ -401,7 +422,6 @@ static int stu300_await_event(struct stu300_dev *dev, | |||
| 401 | return -ETIMEDOUT; | 422 | return -ETIMEDOUT; |
| 402 | } | 423 | } |
| 403 | 424 | ||
| 404 | exit_await_check_err: | ||
| 405 | if (dev->cmd_err != STU300_ERROR_NONE) { | 425 | if (dev->cmd_err != STU300_ERROR_NONE) { |
| 406 | if (mr_event != STU300_EVENT_6) { | 426 | if (mr_event != STU300_EVENT_6) { |
| 407 | dev_err(&dev->pdev->dev, "controller " | 427 | dev_err(&dev->pdev->dev, "controller " |
| @@ -457,18 +477,19 @@ struct stu300_clkset { | |||
| 457 | }; | 477 | }; |
| 458 | 478 | ||
| 459 | static const struct stu300_clkset stu300_clktable[] = { | 479 | static const struct stu300_clkset stu300_clktable[] = { |
| 460 | { 0, 0xFFU }, | 480 | { 0, 0xFFU }, |
| 461 | { 2500000, I2C_OAR2_FR_25_10MHZ }, | 481 | { 2500000, I2C_OAR2_FR_25_10MHZ }, |
| 462 | { 10000000, I2C_OAR2_FR_10_1667MHZ }, | 482 | { 10000000, I2C_OAR2_FR_10_1667MHZ }, |
| 463 | { 16670000, I2C_OAR2_FR_1667_2667MHZ }, | 483 | { 16670000, I2C_OAR2_FR_1667_2667MHZ }, |
| 464 | { 26670000, I2C_OAR2_FR_2667_40MHZ }, | 484 | { 26670000, I2C_OAR2_FR_2667_40MHZ }, |
| 465 | { 40000000, I2C_OAR2_FR_40_5333MHZ }, | 485 | { 40000000, I2C_OAR2_FR_40_5333MHZ }, |
| 466 | { 53330000, I2C_OAR2_FR_5333_66MHZ }, | 486 | { 53330000, I2C_OAR2_FR_5333_66MHZ }, |
| 467 | { 66000000, I2C_OAR2_FR_66_80MHZ }, | 487 | { 66000000, I2C_OAR2_FR_66_80MHZ }, |
| 468 | { 80000000, I2C_OAR2_FR_80_100MHZ }, | 488 | { 80000000, I2C_OAR2_FR_80_100MHZ }, |
| 469 | { 100000000, 0xFFU }, | 489 | { 100000000, 0xFFU }, |
| 470 | }; | 490 | }; |
| 471 | 491 | ||
| 492 | |||
| 472 | static int stu300_set_clk(struct stu300_dev *dev, unsigned long clkrate) | 493 | static int stu300_set_clk(struct stu300_dev *dev, unsigned long clkrate) |
| 473 | { | 494 | { |
| 474 | 495 | ||
| @@ -494,10 +515,10 @@ static int stu300_set_clk(struct stu300_dev *dev, unsigned long clkrate) | |||
| 494 | 515 | ||
| 495 | if (dev->speed > 100000) | 516 | if (dev->speed > 100000) |
| 496 | /* Fast Mode I2C */ | 517 | /* Fast Mode I2C */ |
| 497 | val = ((clkrate/dev->speed)-9)/3; | 518 | val = ((clkrate/dev->speed) - 9)/3 + 1; |
| 498 | else | 519 | else |
| 499 | /* Standard Mode I2C */ | 520 | /* Standard Mode I2C */ |
| 500 | val = ((clkrate/dev->speed)-7)/2; | 521 | val = ((clkrate/dev->speed) - 7)/2 + 1; |
| 501 | 522 | ||
| 502 | /* According to spec the divider must be > 2 */ | 523 | /* According to spec the divider must be > 2 */ |
| 503 | if (val < 0x002) { | 524 | if (val < 0x002) { |
| @@ -557,6 +578,7 @@ static int stu300_init_hw(struct stu300_dev *dev) | |||
| 557 | */ | 578 | */ |
| 558 | clkrate = clk_get_rate(dev->clk); | 579 | clkrate = clk_get_rate(dev->clk); |
| 559 | ret = stu300_set_clk(dev, clkrate); | 580 | ret = stu300_set_clk(dev, clkrate); |
| 581 | |||
| 560 | if (ret) | 582 | if (ret) |
| 561 | return ret; | 583 | return ret; |
| 562 | /* | 584 | /* |
| @@ -641,7 +663,6 @@ static int stu300_xfer_msg(struct i2c_adapter *adap, | |||
| 641 | int attempts = 0; | 663 | int attempts = 0; |
| 642 | struct stu300_dev *dev = i2c_get_adapdata(adap); | 664 | struct stu300_dev *dev = i2c_get_adapdata(adap); |
| 643 | 665 | ||
| 644 | |||
| 645 | clk_enable(dev->clk); | 666 | clk_enable(dev->clk); |
| 646 | 667 | ||
| 647 | /* Remove this if (0) to trace each and every message. */ | 668 | /* Remove this if (0) to trace each and every message. */ |
| @@ -715,14 +736,15 @@ static int stu300_xfer_msg(struct i2c_adapter *adap, | |||
| 715 | 736 | ||
| 716 | if (attempts < NUM_ADDR_RESEND_ATTEMPTS && attempts > 0) { | 737 | if (attempts < NUM_ADDR_RESEND_ATTEMPTS && attempts > 0) { |
| 717 | dev_dbg(&dev->pdev->dev, "managed to get address " | 738 | dev_dbg(&dev->pdev->dev, "managed to get address " |
| 718 | "through after %d attempts\n", attempts); | 739 | "through after %d attempts\n", attempts); |
| 719 | } else if (attempts == NUM_ADDR_RESEND_ATTEMPTS) { | 740 | } else if (attempts == NUM_ADDR_RESEND_ATTEMPTS) { |
| 720 | dev_dbg(&dev->pdev->dev, "I give up, tried %d times " | 741 | dev_dbg(&dev->pdev->dev, "I give up, tried %d times " |
| 721 | "to resend address.\n", | 742 | "to resend address.\n", |
| 722 | NUM_ADDR_RESEND_ATTEMPTS); | 743 | NUM_ADDR_RESEND_ATTEMPTS); |
| 723 | goto exit_disable; | 744 | goto exit_disable; |
| 724 | } | 745 | } |
| 725 | 746 | ||
| 747 | |||
| 726 | if (msg->flags & I2C_M_RD) { | 748 | if (msg->flags & I2C_M_RD) { |
| 727 | /* READ: we read the actual bytes one at a time */ | 749 | /* READ: we read the actual bytes one at a time */ |
| 728 | for (i = 0; i < msg->len; i++) { | 750 | for (i = 0; i < msg->len; i++) { |
| @@ -804,8 +826,10 @@ static int stu300_xfer(struct i2c_adapter *adap, struct i2c_msg *msgs, | |||
| 804 | { | 826 | { |
| 805 | int ret = -1; | 827 | int ret = -1; |
| 806 | int i; | 828 | int i; |
| 829 | |||
| 807 | struct stu300_dev *dev = i2c_get_adapdata(adap); | 830 | struct stu300_dev *dev = i2c_get_adapdata(adap); |
| 808 | dev->msg_len = num; | 831 | dev->msg_len = num; |
| 832 | |||
| 809 | for (i = 0; i < num; i++) { | 833 | for (i = 0; i < num; i++) { |
| 810 | /* | 834 | /* |
| 811 | * Another driver appears to send stop for each message, | 835 | * Another driver appears to send stop for each message, |
| @@ -817,6 +841,7 @@ static int stu300_xfer(struct i2c_adapter *adap, struct i2c_msg *msgs, | |||
| 817 | dev->msg_index = i; | 841 | dev->msg_index = i; |
| 818 | 842 | ||
| 819 | ret = stu300_xfer_msg(adap, &msgs[i], (i == (num - 1))); | 843 | ret = stu300_xfer_msg(adap, &msgs[i], (i == (num - 1))); |
| 844 | |||
| 820 | if (ret != 0) { | 845 | if (ret != 0) { |
| 821 | num = ret; | 846 | num = ret; |
| 822 | break; | 847 | break; |
| @@ -845,6 +870,7 @@ stu300_probe(struct platform_device *pdev) | |||
| 845 | struct resource *res; | 870 | struct resource *res; |
| 846 | int bus_nr; | 871 | int bus_nr; |
| 847 | int ret = 0; | 872 | int ret = 0; |
| 873 | char clk_name[] = "I2C0"; | ||
| 848 | 874 | ||
| 849 | dev = kzalloc(sizeof(struct stu300_dev), GFP_KERNEL); | 875 | dev = kzalloc(sizeof(struct stu300_dev), GFP_KERNEL); |
| 850 | if (!dev) { | 876 | if (!dev) { |
| @@ -854,7 +880,8 @@ stu300_probe(struct platform_device *pdev) | |||
| 854 | } | 880 | } |
| 855 | 881 | ||
| 856 | bus_nr = pdev->id; | 882 | bus_nr = pdev->id; |
| 857 | dev->clk = clk_get(&pdev->dev, NULL); | 883 | clk_name[3] += (char)bus_nr; |
| 884 | dev->clk = clk_get(&pdev->dev, clk_name); | ||
| 858 | if (IS_ERR(dev->clk)) { | 885 | if (IS_ERR(dev->clk)) { |
| 859 | ret = PTR_ERR(dev->clk); | 886 | ret = PTR_ERR(dev->clk); |
| 860 | dev_err(&pdev->dev, "could not retrieve i2c bus clock\n"); | 887 | dev_err(&pdev->dev, "could not retrieve i2c bus clock\n"); |
diff --git a/drivers/i2c/chips/tsl2550.c b/drivers/i2c/chips/tsl2550.c index 1a9cc135219f..b96f3025e588 100644 --- a/drivers/i2c/chips/tsl2550.c +++ b/drivers/i2c/chips/tsl2550.c | |||
| @@ -27,7 +27,7 @@ | |||
| 27 | #include <linux/delay.h> | 27 | #include <linux/delay.h> |
| 28 | 28 | ||
| 29 | #define TSL2550_DRV_NAME "tsl2550" | 29 | #define TSL2550_DRV_NAME "tsl2550" |
| 30 | #define DRIVER_VERSION "1.1.1" | 30 | #define DRIVER_VERSION "1.1.2" |
| 31 | 31 | ||
| 32 | /* | 32 | /* |
| 33 | * Defines | 33 | * Defines |
| @@ -189,13 +189,16 @@ static int tsl2550_calculate_lux(u8 ch0, u8 ch1) | |||
| 189 | u8 r = 128; | 189 | u8 r = 128; |
| 190 | 190 | ||
| 191 | /* Avoid division by 0 and count 1 cannot be greater than count 0 */ | 191 | /* Avoid division by 0 and count 1 cannot be greater than count 0 */ |
| 192 | if (c0 && (c1 <= c0)) | 192 | if (c1 <= c0) |
| 193 | r = c1 * 128 / c0; | 193 | if (c0) { |
| 194 | r = c1 * 128 / c0; | ||
| 195 | |||
| 196 | /* Calculate LUX */ | ||
| 197 | lux = ((c0 - c1) * ratio_lut[r]) / 256; | ||
| 198 | } else | ||
| 199 | lux = 0; | ||
| 194 | else | 200 | else |
| 195 | return -1; | 201 | return -EAGAIN; |
| 196 | |||
| 197 | /* Calculate LUX */ | ||
| 198 | lux = ((c0 - c1) * ratio_lut[r]) / 256; | ||
| 199 | 202 | ||
| 200 | /* LUX range check */ | 203 | /* LUX range check */ |
| 201 | return lux > TSL2550_MAX_LUX ? TSL2550_MAX_LUX : lux; | 204 | return lux > TSL2550_MAX_LUX ? TSL2550_MAX_LUX : lux; |
diff --git a/drivers/ide/ide-disk.c b/drivers/ide/ide-disk.c index 695181120cdb..7f878017b736 100644 --- a/drivers/ide/ide-disk.c +++ b/drivers/ide/ide-disk.c | |||
| @@ -455,6 +455,7 @@ static void idedisk_prepare_flush(struct request_queue *q, struct request *rq) | |||
| 455 | 455 | ||
| 456 | rq->cmd_type = REQ_TYPE_ATA_TASKFILE; | 456 | rq->cmd_type = REQ_TYPE_ATA_TASKFILE; |
| 457 | rq->special = cmd; | 457 | rq->special = cmd; |
| 458 | cmd->rq = rq; | ||
| 458 | } | 459 | } |
| 459 | 460 | ||
| 460 | ide_devset_get(multcount, mult_count); | 461 | ide_devset_get(multcount, mult_count); |
diff --git a/drivers/ide/ide-tape.c b/drivers/ide/ide-tape.c index 013dc595fab6..bc5fb12b913c 100644 --- a/drivers/ide/ide-tape.c +++ b/drivers/ide/ide-tape.c | |||
| @@ -1064,6 +1064,7 @@ static int idetape_blkdev_ioctl(ide_drive_t *drive, unsigned int cmd, | |||
| 1064 | tape->best_dsc_rw_freq = config.dsc_rw_frequency; | 1064 | tape->best_dsc_rw_freq = config.dsc_rw_frequency; |
| 1065 | break; | 1065 | break; |
| 1066 | case 0x0350: | 1066 | case 0x0350: |
| 1067 | memset(&config, 0, sizeof(config)); | ||
| 1067 | config.dsc_rw_frequency = (int) tape->best_dsc_rw_freq; | 1068 | config.dsc_rw_frequency = (int) tape->best_dsc_rw_freq; |
| 1068 | config.nr_stages = 1; | 1069 | config.nr_stages = 1; |
| 1069 | if (copy_to_user(argp, &config, sizeof(config))) | 1070 | if (copy_to_user(argp, &config, sizeof(config))) |
diff --git a/drivers/input/evdev.c b/drivers/input/evdev.c index 114efd8dc8f5..1148140d08a1 100644 --- a/drivers/input/evdev.c +++ b/drivers/input/evdev.c | |||
| @@ -608,8 +608,7 @@ static long evdev_do_ioctl(struct file *file, unsigned int cmd, | |||
| 608 | p, compat_mode); | 608 | p, compat_mode); |
| 609 | 609 | ||
| 610 | if (_IOC_NR(cmd) == _IOC_NR(EVIOCGNAME(0))) | 610 | if (_IOC_NR(cmd) == _IOC_NR(EVIOCGNAME(0))) |
| 611 | return str_to_user(dev_name(&evdev->dev), | 611 | return str_to_user(dev->name, _IOC_SIZE(cmd), p); |
| 612 | _IOC_SIZE(cmd), p); | ||
| 613 | 612 | ||
| 614 | if (_IOC_NR(cmd) == _IOC_NR(EVIOCGPHYS(0))) | 613 | if (_IOC_NR(cmd) == _IOC_NR(EVIOCGPHYS(0))) |
| 615 | return str_to_user(dev->phys, _IOC_SIZE(cmd), p); | 614 | return str_to_user(dev->phys, _IOC_SIZE(cmd), p); |
diff --git a/drivers/input/joydev.c b/drivers/input/joydev.c index 0e12f89276a3..9a1d55b74d7a 100644 --- a/drivers/input/joydev.c +++ b/drivers/input/joydev.c | |||
| @@ -456,8 +456,11 @@ static int joydev_ioctl_common(struct joydev *joydev, | |||
| 456 | unsigned int cmd, void __user *argp) | 456 | unsigned int cmd, void __user *argp) |
| 457 | { | 457 | { |
| 458 | struct input_dev *dev = joydev->handle.dev; | 458 | struct input_dev *dev = joydev->handle.dev; |
| 459 | size_t len; | ||
| 459 | int i, j; | 460 | int i, j; |
| 461 | const char *name; | ||
| 460 | 462 | ||
| 463 | /* Process fixed-sized commands. */ | ||
| 461 | switch (cmd) { | 464 | switch (cmd) { |
| 462 | 465 | ||
| 463 | case JS_SET_CAL: | 466 | case JS_SET_CAL: |
| @@ -499,9 +502,22 @@ static int joydev_ioctl_common(struct joydev *joydev, | |||
| 499 | return copy_to_user(argp, joydev->corr, | 502 | return copy_to_user(argp, joydev->corr, |
| 500 | sizeof(joydev->corr[0]) * joydev->nabs) ? -EFAULT : 0; | 503 | sizeof(joydev->corr[0]) * joydev->nabs) ? -EFAULT : 0; |
| 501 | 504 | ||
| 502 | case JSIOCSAXMAP: | 505 | } |
| 503 | if (copy_from_user(joydev->abspam, argp, | 506 | |
| 504 | sizeof(__u8) * (ABS_MAX + 1))) | 507 | /* |
| 508 | * Process variable-sized commands (the axis and button map commands | ||
| 509 | * are considered variable-sized to decouple them from the values of | ||
| 510 | * ABS_MAX and KEY_MAX). | ||
| 511 | */ | ||
| 512 | switch (cmd & ~IOCSIZE_MASK) { | ||
| 513 | |||
| 514 | case (JSIOCSAXMAP & ~IOCSIZE_MASK): | ||
| 515 | len = min_t(size_t, _IOC_SIZE(cmd), sizeof(joydev->abspam)); | ||
| 516 | /* | ||
| 517 | * FIXME: we should not copy into our axis map before | ||
| 518 | * validating the data. | ||
| 519 | */ | ||
| 520 | if (copy_from_user(joydev->abspam, argp, len)) | ||
| 505 | return -EFAULT; | 521 | return -EFAULT; |
| 506 | 522 | ||
| 507 | for (i = 0; i < joydev->nabs; i++) { | 523 | for (i = 0; i < joydev->nabs; i++) { |
| @@ -511,13 +527,17 @@ static int joydev_ioctl_common(struct joydev *joydev, | |||
| 511 | } | 527 | } |
| 512 | return 0; | 528 | return 0; |
| 513 | 529 | ||
| 514 | case JSIOCGAXMAP: | 530 | case (JSIOCGAXMAP & ~IOCSIZE_MASK): |
| 515 | return copy_to_user(argp, joydev->abspam, | 531 | len = min_t(size_t, _IOC_SIZE(cmd), sizeof(joydev->abspam)); |
| 516 | sizeof(__u8) * (ABS_MAX + 1)) ? -EFAULT : 0; | 532 | return copy_to_user(argp, joydev->abspam, len) ? -EFAULT : 0; |
| 517 | 533 | ||
| 518 | case JSIOCSBTNMAP: | 534 | case (JSIOCSBTNMAP & ~IOCSIZE_MASK): |
| 519 | if (copy_from_user(joydev->keypam, argp, | 535 | len = min_t(size_t, _IOC_SIZE(cmd), sizeof(joydev->keypam)); |
| 520 | sizeof(__u16) * (KEY_MAX - BTN_MISC + 1))) | 536 | /* |
| 537 | * FIXME: we should not copy into our keymap before | ||
| 538 | * validating the data. | ||
| 539 | */ | ||
| 540 | if (copy_from_user(joydev->keypam, argp, len)) | ||
| 521 | return -EFAULT; | 541 | return -EFAULT; |
| 522 | 542 | ||
| 523 | for (i = 0; i < joydev->nkey; i++) { | 543 | for (i = 0; i < joydev->nkey; i++) { |
| @@ -529,25 +549,19 @@ static int joydev_ioctl_common(struct joydev *joydev, | |||
| 529 | 549 | ||
| 530 | return 0; | 550 | return 0; |
| 531 | 551 | ||
| 532 | case JSIOCGBTNMAP: | 552 | case (JSIOCGBTNMAP & ~IOCSIZE_MASK): |
| 533 | return copy_to_user(argp, joydev->keypam, | 553 | len = min_t(size_t, _IOC_SIZE(cmd), sizeof(joydev->keypam)); |
| 534 | sizeof(__u16) * (KEY_MAX - BTN_MISC + 1)) ? -EFAULT : 0; | 554 | return copy_to_user(argp, joydev->keypam, len) ? -EFAULT : 0; |
| 535 | 555 | ||
| 536 | default: | 556 | case JSIOCGNAME(0): |
| 537 | if ((cmd & ~IOCSIZE_MASK) == JSIOCGNAME(0)) { | 557 | name = dev->name; |
| 538 | int len; | 558 | if (!name) |
| 539 | const char *name = dev_name(&dev->dev); | 559 | return 0; |
| 540 | 560 | ||
| 541 | if (!name) | 561 | len = min_t(size_t, _IOC_SIZE(cmd), strlen(name) + 1); |
| 542 | return 0; | 562 | return copy_to_user(argp, name, len) ? -EFAULT : len; |
| 543 | len = strlen(name) + 1; | ||
| 544 | if (len > _IOC_SIZE(cmd)) | ||
| 545 | len = _IOC_SIZE(cmd); | ||
| 546 | if (copy_to_user(argp, name, len)) | ||
| 547 | return -EFAULT; | ||
| 548 | return len; | ||
| 549 | } | ||
| 550 | } | 563 | } |
| 564 | |||
| 551 | return -EINVAL; | 565 | return -EINVAL; |
| 552 | } | 566 | } |
| 553 | 567 | ||
diff --git a/drivers/input/joystick/iforce/iforce-main.c b/drivers/input/joystick/iforce/iforce-main.c index baabf8302645..f6c688cae334 100644 --- a/drivers/input/joystick/iforce/iforce-main.c +++ b/drivers/input/joystick/iforce/iforce-main.c | |||
| @@ -74,6 +74,7 @@ static struct iforce_device iforce_device[] = { | |||
| 74 | { 0x05ef, 0x8884, "AVB Mag Turbo Force", btn_avb_wheel, abs_wheel, ff_iforce }, | 74 | { 0x05ef, 0x8884, "AVB Mag Turbo Force", btn_avb_wheel, abs_wheel, ff_iforce }, |
| 75 | { 0x05ef, 0x8888, "AVB Top Shot Force Feedback Racing Wheel", btn_avb_tw, abs_wheel, ff_iforce }, //? | 75 | { 0x05ef, 0x8888, "AVB Top Shot Force Feedback Racing Wheel", btn_avb_tw, abs_wheel, ff_iforce }, //? |
| 76 | { 0x061c, 0xc0a4, "ACT LABS Force RS", btn_wheel, abs_wheel, ff_iforce }, //? | 76 | { 0x061c, 0xc0a4, "ACT LABS Force RS", btn_wheel, abs_wheel, ff_iforce }, //? |
| 77 | { 0x061c, 0xc084, "ACT LABS Force RS", btn_wheel, abs_wheel, ff_iforce }, | ||
| 77 | { 0x06f8, 0x0001, "Guillemot Race Leader Force Feedback", btn_wheel, abs_wheel, ff_iforce }, //? | 78 | { 0x06f8, 0x0001, "Guillemot Race Leader Force Feedback", btn_wheel, abs_wheel, ff_iforce }, //? |
| 78 | { 0x06f8, 0x0004, "Guillemot Force Feedback Racing Wheel", btn_wheel, abs_wheel, ff_iforce }, //? | 79 | { 0x06f8, 0x0004, "Guillemot Force Feedback Racing Wheel", btn_wheel, abs_wheel, ff_iforce }, //? |
| 79 | { 0x06f8, 0x0004, "Gullemot Jet Leader 3D", btn_joystick, abs_joystick, ff_iforce }, //? | 80 | { 0x06f8, 0x0004, "Gullemot Jet Leader 3D", btn_joystick, abs_joystick, ff_iforce }, //? |
diff --git a/drivers/input/joystick/iforce/iforce-usb.c b/drivers/input/joystick/iforce/iforce-usb.c index f83185aeb511..9f289d8f52c6 100644 --- a/drivers/input/joystick/iforce/iforce-usb.c +++ b/drivers/input/joystick/iforce/iforce-usb.c | |||
| @@ -223,6 +223,7 @@ static struct usb_device_id iforce_usb_ids [] = { | |||
| 223 | { USB_DEVICE(0x05ef, 0x8884) }, /* AVB Mag Turbo Force */ | 223 | { USB_DEVICE(0x05ef, 0x8884) }, /* AVB Mag Turbo Force */ |
| 224 | { USB_DEVICE(0x05ef, 0x8888) }, /* AVB Top Shot FFB Racing Wheel */ | 224 | { USB_DEVICE(0x05ef, 0x8888) }, /* AVB Top Shot FFB Racing Wheel */ |
| 225 | { USB_DEVICE(0x061c, 0xc0a4) }, /* ACT LABS Force RS */ | 225 | { USB_DEVICE(0x061c, 0xc0a4) }, /* ACT LABS Force RS */ |
| 226 | { USB_DEVICE(0x061c, 0xc084) }, /* ACT LABS Force RS */ | ||
| 226 | { USB_DEVICE(0x06f8, 0x0001) }, /* Guillemot Race Leader Force Feedback */ | 227 | { USB_DEVICE(0x06f8, 0x0001) }, /* Guillemot Race Leader Force Feedback */ |
| 227 | { USB_DEVICE(0x06f8, 0x0004) }, /* Guillemot Force Feedback Racing Wheel */ | 228 | { USB_DEVICE(0x06f8, 0x0004) }, /* Guillemot Force Feedback Racing Wheel */ |
| 228 | { USB_DEVICE(0x06f8, 0xa302) }, /* Guillemot Jet Leader 3D */ | 229 | { USB_DEVICE(0x06f8, 0xa302) }, /* Guillemot Jet Leader 3D */ |
diff --git a/drivers/input/joystick/xpad.c b/drivers/input/joystick/xpad.c index b868b8d5fbb3..f155ad8cdae7 100644 --- a/drivers/input/joystick/xpad.c +++ b/drivers/input/joystick/xpad.c | |||
| @@ -470,20 +470,20 @@ static void xpad_irq_out(struct urb *urb) | |||
| 470 | status = urb->status; | 470 | status = urb->status; |
| 471 | 471 | ||
| 472 | switch (status) { | 472 | switch (status) { |
| 473 | case 0: | 473 | case 0: |
| 474 | /* success */ | 474 | /* success */ |
| 475 | break; | 475 | return; |
| 476 | case -ECONNRESET: | 476 | |
| 477 | case -ENOENT: | 477 | case -ECONNRESET: |
| 478 | case -ESHUTDOWN: | 478 | case -ENOENT: |
| 479 | /* this urb is terminated, clean up */ | 479 | case -ESHUTDOWN: |
| 480 | dbg("%s - urb shutting down with status: %d", | 480 | /* this urb is terminated, clean up */ |
| 481 | __func__, status); | 481 | dbg("%s - urb shutting down with status: %d", __func__, status); |
| 482 | return; | 482 | return; |
| 483 | default: | 483 | |
| 484 | dbg("%s - nonzero urb status received: %d", | 484 | default: |
| 485 | __func__, status); | 485 | dbg("%s - nonzero urb status received: %d", __func__, status); |
| 486 | goto exit; | 486 | goto exit; |
| 487 | } | 487 | } |
| 488 | 488 | ||
| 489 | exit: | 489 | exit: |
diff --git a/drivers/input/keyboard/atkbd.c b/drivers/input/keyboard/atkbd.c index df3f8aa68115..95fe0452dae4 100644 --- a/drivers/input/keyboard/atkbd.c +++ b/drivers/input/keyboard/atkbd.c | |||
| @@ -895,6 +895,13 @@ static unsigned int atkbd_amilo_pa1510_forced_release_keys[] = { | |||
| 895 | }; | 895 | }; |
| 896 | 896 | ||
| 897 | /* | 897 | /* |
| 898 | * Amilo Pi 3525 key release for Fn+Volume keys not working | ||
| 899 | */ | ||
| 900 | static unsigned int atkbd_amilo_pi3525_forced_release_keys[] = { | ||
| 901 | 0x20, 0xa0, 0x2e, 0xae, 0x30, 0xb0, -1U | ||
| 902 | }; | ||
| 903 | |||
| 904 | /* | ||
| 898 | * Amilo Xi 3650 key release for light touch bar not working | 905 | * Amilo Xi 3650 key release for light touch bar not working |
| 899 | */ | 906 | */ |
| 900 | static unsigned int atkbd_amilo_xi3650_forced_release_keys[] = { | 907 | static unsigned int atkbd_amilo_xi3650_forced_release_keys[] = { |
| @@ -902,6 +909,13 @@ static unsigned int atkbd_amilo_xi3650_forced_release_keys[] = { | |||
| 902 | }; | 909 | }; |
| 903 | 910 | ||
| 904 | /* | 911 | /* |
| 912 | * Soltech TA12 system with broken key release on volume keys and mute key | ||
| 913 | */ | ||
| 914 | static unsigned int atkdb_soltech_ta12_forced_release_keys[] = { | ||
| 915 | 0xa0, 0xae, 0xb0, -1U | ||
| 916 | }; | ||
| 917 | |||
| 918 | /* | ||
| 905 | * atkbd_set_keycode_table() initializes keyboard's keycode table | 919 | * atkbd_set_keycode_table() initializes keyboard's keycode table |
| 906 | * according to the selected scancode set | 920 | * according to the selected scancode set |
| 907 | */ | 921 | */ |
| @@ -1568,6 +1582,15 @@ static struct dmi_system_id atkbd_dmi_quirk_table[] __initdata = { | |||
| 1568 | .driver_data = atkbd_amilo_pa1510_forced_release_keys, | 1582 | .driver_data = atkbd_amilo_pa1510_forced_release_keys, |
| 1569 | }, | 1583 | }, |
| 1570 | { | 1584 | { |
| 1585 | .ident = "Fujitsu Amilo Pi 3525", | ||
| 1586 | .matches = { | ||
| 1587 | DMI_MATCH(DMI_SYS_VENDOR, "FUJITSU SIEMENS"), | ||
| 1588 | DMI_MATCH(DMI_PRODUCT_NAME, "AMILO Pi 3525"), | ||
| 1589 | }, | ||
| 1590 | .callback = atkbd_setup_forced_release, | ||
| 1591 | .driver_data = atkbd_amilo_pi3525_forced_release_keys, | ||
| 1592 | }, | ||
| 1593 | { | ||
| 1571 | .ident = "Fujitsu Amilo Xi 3650", | 1594 | .ident = "Fujitsu Amilo Xi 3650", |
| 1572 | .matches = { | 1595 | .matches = { |
| 1573 | DMI_MATCH(DMI_SYS_VENDOR, "FUJITSU SIEMENS"), | 1596 | DMI_MATCH(DMI_SYS_VENDOR, "FUJITSU SIEMENS"), |
| @@ -1576,6 +1599,15 @@ static struct dmi_system_id atkbd_dmi_quirk_table[] __initdata = { | |||
| 1576 | .callback = atkbd_setup_forced_release, | 1599 | .callback = atkbd_setup_forced_release, |
| 1577 | .driver_data = atkbd_amilo_xi3650_forced_release_keys, | 1600 | .driver_data = atkbd_amilo_xi3650_forced_release_keys, |
| 1578 | }, | 1601 | }, |
| 1602 | { | ||
| 1603 | .ident = "Soltech Corporation TA12", | ||
| 1604 | .matches = { | ||
| 1605 | DMI_MATCH(DMI_SYS_VENDOR, "Soltech Corporation"), | ||
| 1606 | DMI_MATCH(DMI_PRODUCT_NAME, "TA12"), | ||
| 1607 | }, | ||
| 1608 | .callback = atkbd_setup_forced_release, | ||
| 1609 | .driver_data = atkdb_soltech_ta12_forced_release_keys, | ||
| 1610 | }, | ||
| 1579 | { } | 1611 | { } |
| 1580 | }; | 1612 | }; |
| 1581 | 1613 | ||
diff --git a/drivers/input/keyboard/matrix_keypad.c b/drivers/input/keyboard/matrix_keypad.c index e9b2e7cb05be..541b981ff075 100644 --- a/drivers/input/keyboard/matrix_keypad.c +++ b/drivers/input/keyboard/matrix_keypad.c | |||
| @@ -27,6 +27,7 @@ struct matrix_keypad { | |||
| 27 | const struct matrix_keypad_platform_data *pdata; | 27 | const struct matrix_keypad_platform_data *pdata; |
| 28 | struct input_dev *input_dev; | 28 | struct input_dev *input_dev; |
| 29 | unsigned short *keycodes; | 29 | unsigned short *keycodes; |
| 30 | unsigned int row_shift; | ||
| 30 | 31 | ||
| 31 | uint32_t last_key_state[MATRIX_MAX_COLS]; | 32 | uint32_t last_key_state[MATRIX_MAX_COLS]; |
| 32 | struct delayed_work work; | 33 | struct delayed_work work; |
| @@ -136,7 +137,7 @@ static void matrix_keypad_scan(struct work_struct *work) | |||
| 136 | if ((bits_changed & (1 << row)) == 0) | 137 | if ((bits_changed & (1 << row)) == 0) |
| 137 | continue; | 138 | continue; |
| 138 | 139 | ||
| 139 | code = (row << 4) + col; | 140 | code = MATRIX_SCAN_CODE(row, col, keypad->row_shift); |
| 140 | input_event(input_dev, EV_MSC, MSC_SCAN, code); | 141 | input_event(input_dev, EV_MSC, MSC_SCAN, code); |
| 141 | input_report_key(input_dev, | 142 | input_report_key(input_dev, |
| 142 | keypad->keycodes[code], | 143 | keypad->keycodes[code], |
| @@ -317,6 +318,7 @@ static int __devinit matrix_keypad_probe(struct platform_device *pdev) | |||
| 317 | struct matrix_keypad *keypad; | 318 | struct matrix_keypad *keypad; |
| 318 | struct input_dev *input_dev; | 319 | struct input_dev *input_dev; |
| 319 | unsigned short *keycodes; | 320 | unsigned short *keycodes; |
| 321 | unsigned int row_shift; | ||
| 320 | int i; | 322 | int i; |
| 321 | int err; | 323 | int err; |
| 322 | 324 | ||
| @@ -332,14 +334,11 @@ static int __devinit matrix_keypad_probe(struct platform_device *pdev) | |||
| 332 | return -EINVAL; | 334 | return -EINVAL; |
| 333 | } | 335 | } |
| 334 | 336 | ||
| 335 | if (!keymap_data->max_keymap_size) { | 337 | row_shift = get_count_order(pdata->num_col_gpios); |
| 336 | dev_err(&pdev->dev, "invalid keymap data supplied\n"); | ||
| 337 | return -EINVAL; | ||
| 338 | } | ||
| 339 | 338 | ||
| 340 | keypad = kzalloc(sizeof(struct matrix_keypad), GFP_KERNEL); | 339 | keypad = kzalloc(sizeof(struct matrix_keypad), GFP_KERNEL); |
| 341 | keycodes = kzalloc(keymap_data->max_keymap_size * | 340 | keycodes = kzalloc((pdata->num_row_gpios << row_shift) * |
| 342 | sizeof(keypad->keycodes), | 341 | sizeof(*keycodes), |
| 343 | GFP_KERNEL); | 342 | GFP_KERNEL); |
| 344 | input_dev = input_allocate_device(); | 343 | input_dev = input_allocate_device(); |
| 345 | if (!keypad || !keycodes || !input_dev) { | 344 | if (!keypad || !keycodes || !input_dev) { |
| @@ -350,6 +349,7 @@ static int __devinit matrix_keypad_probe(struct platform_device *pdev) | |||
| 350 | keypad->input_dev = input_dev; | 349 | keypad->input_dev = input_dev; |
| 351 | keypad->pdata = pdata; | 350 | keypad->pdata = pdata; |
| 352 | keypad->keycodes = keycodes; | 351 | keypad->keycodes = keycodes; |
| 352 | keypad->row_shift = row_shift; | ||
| 353 | keypad->stopped = true; | 353 | keypad->stopped = true; |
| 354 | INIT_DELAYED_WORK(&keypad->work, matrix_keypad_scan); | 354 | INIT_DELAYED_WORK(&keypad->work, matrix_keypad_scan); |
| 355 | spin_lock_init(&keypad->lock); | 355 | spin_lock_init(&keypad->lock); |
| @@ -363,7 +363,7 @@ static int __devinit matrix_keypad_probe(struct platform_device *pdev) | |||
| 363 | 363 | ||
| 364 | input_dev->keycode = keycodes; | 364 | input_dev->keycode = keycodes; |
| 365 | input_dev->keycodesize = sizeof(*keycodes); | 365 | input_dev->keycodesize = sizeof(*keycodes); |
| 366 | input_dev->keycodemax = keymap_data->max_keymap_size; | 366 | input_dev->keycodemax = pdata->num_row_gpios << keypad->row_shift; |
| 367 | 367 | ||
| 368 | for (i = 0; i < keymap_data->keymap_size; i++) { | 368 | for (i = 0; i < keymap_data->keymap_size; i++) { |
| 369 | unsigned int key = keymap_data->keymap[i]; | 369 | unsigned int key = keymap_data->keymap[i]; |
| @@ -371,7 +371,7 @@ static int __devinit matrix_keypad_probe(struct platform_device *pdev) | |||
| 371 | unsigned int col = KEY_COL(key); | 371 | unsigned int col = KEY_COL(key); |
| 372 | unsigned short code = KEY_VAL(key); | 372 | unsigned short code = KEY_VAL(key); |
| 373 | 373 | ||
| 374 | keycodes[(row << 4) + col] = code; | 374 | keycodes[MATRIX_SCAN_CODE(row, col, row_shift)] = code; |
| 375 | __set_bit(code, input_dev->keybit); | 375 | __set_bit(code, input_dev->keybit); |
| 376 | } | 376 | } |
| 377 | __clear_bit(KEY_RESERVED, input_dev->keybit); | 377 | __clear_bit(KEY_RESERVED, input_dev->keybit); |
diff --git a/drivers/input/misc/pcspkr.c b/drivers/input/misc/pcspkr.c index 6d67af5387ad..21cb755a54fb 100644 --- a/drivers/input/misc/pcspkr.c +++ b/drivers/input/misc/pcspkr.c | |||
| @@ -114,7 +114,7 @@ static int __devexit pcspkr_remove(struct platform_device *dev) | |||
| 114 | return 0; | 114 | return 0; |
| 115 | } | 115 | } |
| 116 | 116 | ||
| 117 | static int pcspkr_suspend(struct platform_device *dev, pm_message_t state) | 117 | static int pcspkr_suspend(struct device *dev) |
| 118 | { | 118 | { |
| 119 | pcspkr_event(NULL, EV_SND, SND_BELL, 0); | 119 | pcspkr_event(NULL, EV_SND, SND_BELL, 0); |
| 120 | 120 | ||
| @@ -127,14 +127,18 @@ static void pcspkr_shutdown(struct platform_device *dev) | |||
| 127 | pcspkr_event(NULL, EV_SND, SND_BELL, 0); | 127 | pcspkr_event(NULL, EV_SND, SND_BELL, 0); |
| 128 | } | 128 | } |
| 129 | 129 | ||
| 130 | static struct dev_pm_ops pcspkr_pm_ops = { | ||
| 131 | .suspend = pcspkr_suspend, | ||
| 132 | }; | ||
| 133 | |||
| 130 | static struct platform_driver pcspkr_platform_driver = { | 134 | static struct platform_driver pcspkr_platform_driver = { |
| 131 | .driver = { | 135 | .driver = { |
| 132 | .name = "pcspkr", | 136 | .name = "pcspkr", |
| 133 | .owner = THIS_MODULE, | 137 | .owner = THIS_MODULE, |
| 138 | .pm = &pcspkr_pm_ops, | ||
| 134 | }, | 139 | }, |
| 135 | .probe = pcspkr_probe, | 140 | .probe = pcspkr_probe, |
| 136 | .remove = __devexit_p(pcspkr_remove), | 141 | .remove = __devexit_p(pcspkr_remove), |
| 137 | .suspend = pcspkr_suspend, | ||
| 138 | .shutdown = pcspkr_shutdown, | 142 | .shutdown = pcspkr_shutdown, |
| 139 | }; | 143 | }; |
| 140 | 144 | ||
diff --git a/drivers/input/misc/wistron_btns.c b/drivers/input/misc/wistron_btns.c index 7c8957dd22c0..27ee976eb54c 100644 --- a/drivers/input/misc/wistron_btns.c +++ b/drivers/input/misc/wistron_btns.c | |||
| @@ -611,6 +611,20 @@ static struct key_entry keymap_wistron_generic[] __initdata = { | |||
| 611 | { KE_END, 0 } | 611 | { KE_END, 0 } |
| 612 | }; | 612 | }; |
| 613 | 613 | ||
| 614 | static struct key_entry keymap_prestigio[] __initdata = { | ||
| 615 | { KE_KEY, 0x11, {KEY_PROG1} }, | ||
| 616 | { KE_KEY, 0x12, {KEY_PROG2} }, | ||
| 617 | { KE_WIFI, 0x30 }, | ||
| 618 | { KE_KEY, 0x22, {KEY_REWIND} }, | ||
| 619 | { KE_KEY, 0x23, {KEY_FORWARD} }, | ||
| 620 | { KE_KEY, 0x24, {KEY_PLAYPAUSE} }, | ||
| 621 | { KE_KEY, 0x25, {KEY_STOPCD} }, | ||
| 622 | { KE_KEY, 0x31, {KEY_MAIL} }, | ||
| 623 | { KE_KEY, 0x36, {KEY_WWW} }, | ||
| 624 | { KE_END, 0 } | ||
| 625 | }; | ||
| 626 | |||
| 627 | |||
| 614 | /* | 628 | /* |
| 615 | * If your machine is not here (which is currently rather likely), please send | 629 | * If your machine is not here (which is currently rather likely), please send |
| 616 | * a list of buttons and their key codes (reported when loading this module | 630 | * a list of buttons and their key codes (reported when loading this module |
| @@ -646,6 +660,15 @@ static struct dmi_system_id dmi_ids[] __initdata = { | |||
| 646 | }, | 660 | }, |
| 647 | { | 661 | { |
| 648 | .callback = dmi_matched, | 662 | .callback = dmi_matched, |
| 663 | .ident = "Maxdata Pro 7000 DX", | ||
| 664 | .matches = { | ||
| 665 | DMI_MATCH(DMI_SYS_VENDOR, "MAXDATA"), | ||
| 666 | DMI_MATCH(DMI_PRODUCT_NAME, "Pro 7000"), | ||
| 667 | }, | ||
| 668 | .driver_data = keymap_fs_amilo_pro_v2000 | ||
| 669 | }, | ||
| 670 | { | ||
| 671 | .callback = dmi_matched, | ||
| 649 | .ident = "Fujitsu N3510", | 672 | .ident = "Fujitsu N3510", |
| 650 | .matches = { | 673 | .matches = { |
| 651 | DMI_MATCH(DMI_SYS_VENDOR, "FUJITSU"), | 674 | DMI_MATCH(DMI_SYS_VENDOR, "FUJITSU"), |
| @@ -962,6 +985,8 @@ static int __init select_keymap(void) | |||
| 962 | if (keymap_name != NULL) { | 985 | if (keymap_name != NULL) { |
| 963 | if (strcmp (keymap_name, "1557/MS2141") == 0) | 986 | if (strcmp (keymap_name, "1557/MS2141") == 0) |
| 964 | keymap = keymap_wistron_ms2141; | 987 | keymap = keymap_wistron_ms2141; |
| 988 | else if (strcmp (keymap_name, "prestigio") == 0) | ||
| 989 | keymap = keymap_prestigio; | ||
| 965 | else if (strcmp (keymap_name, "generic") == 0) | 990 | else if (strcmp (keymap_name, "generic") == 0) |
| 966 | keymap = keymap_wistron_generic; | 991 | keymap = keymap_wistron_generic; |
| 967 | else { | 992 | else { |
diff --git a/drivers/input/serio/hp_sdc_mlc.c b/drivers/input/serio/hp_sdc_mlc.c index b587e2d576ac..820e51673b26 100644 --- a/drivers/input/serio/hp_sdc_mlc.c +++ b/drivers/input/serio/hp_sdc_mlc.c | |||
| @@ -296,7 +296,7 @@ static void hp_sdc_mlc_out(hil_mlc *mlc) | |||
| 296 | priv->tseq[3] = 0; | 296 | priv->tseq[3] = 0; |
| 297 | if (mlc->opacket & HIL_CTRL_APE) { | 297 | if (mlc->opacket & HIL_CTRL_APE) { |
| 298 | priv->tseq[3] |= HP_SDC_LPC_APE_IPF; | 298 | priv->tseq[3] |= HP_SDC_LPC_APE_IPF; |
| 299 | down_trylock(&mlc->csem); | 299 | BUG_ON(down_trylock(&mlc->csem)); |
| 300 | } | 300 | } |
| 301 | enqueue: | 301 | enqueue: |
| 302 | hp_sdc_enqueue_transaction(&priv->trans); | 302 | hp_sdc_enqueue_transaction(&priv->trans); |
diff --git a/drivers/input/serio/i8042-x86ia64io.h b/drivers/input/serio/i8042-x86ia64io.h index 924e8ed7f2cf..ae04d8a494e5 100644 --- a/drivers/input/serio/i8042-x86ia64io.h +++ b/drivers/input/serio/i8042-x86ia64io.h | |||
| @@ -78,6 +78,14 @@ static struct dmi_system_id __initdata i8042_dmi_noloop_table[] = { | |||
| 78 | }, | 78 | }, |
| 79 | }, | 79 | }, |
| 80 | { | 80 | { |
| 81 | .ident = "ASUS G1S", | ||
| 82 | .matches = { | ||
| 83 | DMI_MATCH(DMI_BOARD_VENDOR, "ASUSTeK Computer Inc."), | ||
| 84 | DMI_MATCH(DMI_BOARD_NAME, "G1S"), | ||
| 85 | DMI_MATCH(DMI_BOARD_VERSION, "1.0"), | ||
| 86 | }, | ||
| 87 | }, | ||
| 88 | { | ||
| 81 | /* AUX LOOP command does not raise AUX IRQ */ | 89 | /* AUX LOOP command does not raise AUX IRQ */ |
| 82 | .ident = "ASUS P65UP5", | 90 | .ident = "ASUS P65UP5", |
| 83 | .matches = { | 91 | .matches = { |
diff --git a/drivers/input/tablet/wacom_sys.c b/drivers/input/tablet/wacom_sys.c index a9d5031b855e..ea30c983a33e 100644 --- a/drivers/input/tablet/wacom_sys.c +++ b/drivers/input/tablet/wacom_sys.c | |||
| @@ -388,6 +388,32 @@ static int wacom_parse_hid(struct usb_interface *intf, struct hid_descriptor *hi | |||
| 388 | return result; | 388 | return result; |
| 389 | } | 389 | } |
| 390 | 390 | ||
| 391 | static int wacom_query_tablet_data(struct usb_interface *intf) | ||
| 392 | { | ||
| 393 | unsigned char *rep_data; | ||
| 394 | int limit = 0; | ||
| 395 | int error; | ||
| 396 | |||
| 397 | rep_data = kmalloc(2, GFP_KERNEL); | ||
| 398 | if (!rep_data) | ||
| 399 | return -ENOMEM; | ||
| 400 | |||
| 401 | do { | ||
| 402 | rep_data[0] = 2; | ||
| 403 | rep_data[1] = 2; | ||
| 404 | error = usb_set_report(intf, WAC_HID_FEATURE_REPORT, | ||
| 405 | 2, rep_data, 2); | ||
| 406 | if (error >= 0) | ||
| 407 | error = usb_get_report(intf, | ||
| 408 | WAC_HID_FEATURE_REPORT, 2, | ||
| 409 | rep_data, 2); | ||
| 410 | } while ((error < 0 || rep_data[1] != 2) && limit++ < 5); | ||
| 411 | |||
| 412 | kfree(rep_data); | ||
| 413 | |||
| 414 | return error < 0 ? error : 0; | ||
| 415 | } | ||
| 416 | |||
| 391 | static int wacom_probe(struct usb_interface *intf, const struct usb_device_id *id) | 417 | static int wacom_probe(struct usb_interface *intf, const struct usb_device_id *id) |
| 392 | { | 418 | { |
| 393 | struct usb_device *dev = interface_to_usbdev(intf); | 419 | struct usb_device *dev = interface_to_usbdev(intf); |
| @@ -398,7 +424,6 @@ static int wacom_probe(struct usb_interface *intf, const struct usb_device_id *i | |||
| 398 | struct wacom_features *features; | 424 | struct wacom_features *features; |
| 399 | struct input_dev *input_dev; | 425 | struct input_dev *input_dev; |
| 400 | int error = -ENOMEM; | 426 | int error = -ENOMEM; |
| 401 | char rep_data[2], limit = 0; | ||
| 402 | struct hid_descriptor *hid_desc; | 427 | struct hid_descriptor *hid_desc; |
| 403 | 428 | ||
| 404 | wacom = kzalloc(sizeof(struct wacom), GFP_KERNEL); | 429 | wacom = kzalloc(sizeof(struct wacom), GFP_KERNEL); |
| @@ -489,20 +514,10 @@ static int wacom_probe(struct usb_interface *intf, const struct usb_device_id *i | |||
| 489 | 514 | ||
| 490 | /* | 515 | /* |
| 491 | * Ask the tablet to report tablet data if it is not a Tablet PC. | 516 | * Ask the tablet to report tablet data if it is not a Tablet PC. |
| 492 | * Repeat until it succeeds | 517 | * Note that if query fails it is not a hard failure. |
| 493 | */ | 518 | */ |
| 494 | if (wacom_wac->features->type != TABLETPC) { | 519 | if (wacom_wac->features->type != TABLETPC) |
| 495 | do { | 520 | wacom_query_tablet_data(intf); |
| 496 | rep_data[0] = 2; | ||
| 497 | rep_data[1] = 2; | ||
| 498 | error = usb_set_report(intf, WAC_HID_FEATURE_REPORT, | ||
| 499 | 2, rep_data, 2); | ||
| 500 | if (error >= 0) | ||
| 501 | error = usb_get_report(intf, | ||
| 502 | WAC_HID_FEATURE_REPORT, 2, | ||
| 503 | rep_data, 2); | ||
| 504 | } while ((error < 0 || rep_data[1] != 2) && limit++ < 5); | ||
| 505 | } | ||
| 506 | 521 | ||
| 507 | usb_set_intfdata(intf, wacom); | 522 | usb_set_intfdata(intf, wacom); |
| 508 | return 0; | 523 | return 0; |
diff --git a/drivers/input/touchscreen/ucb1400_ts.c b/drivers/input/touchscreen/ucb1400_ts.c index 6954f5500108..3a7a58222f83 100644 --- a/drivers/input/touchscreen/ucb1400_ts.c +++ b/drivers/input/touchscreen/ucb1400_ts.c | |||
| @@ -170,11 +170,11 @@ static void ucb1400_handle_pending_irq(struct ucb1400_ts *ucb) | |||
| 170 | ucb1400_reg_write(ucb->ac97, UCB_IE_CLEAR, isr); | 170 | ucb1400_reg_write(ucb->ac97, UCB_IE_CLEAR, isr); |
| 171 | ucb1400_reg_write(ucb->ac97, UCB_IE_CLEAR, 0); | 171 | ucb1400_reg_write(ucb->ac97, UCB_IE_CLEAR, 0); |
| 172 | 172 | ||
| 173 | if (isr & UCB_IE_TSPX) { | 173 | if (isr & UCB_IE_TSPX) |
| 174 | ucb1400_ts_irq_disable(ucb->ac97); | 174 | ucb1400_ts_irq_disable(ucb->ac97); |
| 175 | enable_irq(ucb->irq); | 175 | else |
| 176 | } else | 176 | dev_dbg(&ucb->ts_idev->dev, "ucb1400: unexpected IE_STATUS = %#x\n", isr); |
| 177 | printk(KERN_ERR "ucb1400: unexpected IE_STATUS = %#x\n", isr); | 177 | enable_irq(ucb->irq); |
| 178 | } | 178 | } |
| 179 | 179 | ||
| 180 | static int ucb1400_ts_thread(void *_ucb) | 180 | static int ucb1400_ts_thread(void *_ucb) |
| @@ -345,6 +345,7 @@ static int ucb1400_ts_detect_irq(struct ucb1400_ts *ucb) | |||
| 345 | static int ucb1400_ts_probe(struct platform_device *dev) | 345 | static int ucb1400_ts_probe(struct platform_device *dev) |
| 346 | { | 346 | { |
| 347 | int error, x_res, y_res; | 347 | int error, x_res, y_res; |
| 348 | u16 fcsr; | ||
| 348 | struct ucb1400_ts *ucb = dev->dev.platform_data; | 349 | struct ucb1400_ts *ucb = dev->dev.platform_data; |
| 349 | 350 | ||
| 350 | ucb->ts_idev = input_allocate_device(); | 351 | ucb->ts_idev = input_allocate_device(); |
| @@ -382,6 +383,14 @@ static int ucb1400_ts_probe(struct platform_device *dev) | |||
| 382 | ucb->ts_idev->evbit[0] = BIT_MASK(EV_ABS) | BIT_MASK(EV_KEY); | 383 | ucb->ts_idev->evbit[0] = BIT_MASK(EV_ABS) | BIT_MASK(EV_KEY); |
| 383 | ucb->ts_idev->keybit[BIT_WORD(BTN_TOUCH)] = BIT_MASK(BTN_TOUCH); | 384 | ucb->ts_idev->keybit[BIT_WORD(BTN_TOUCH)] = BIT_MASK(BTN_TOUCH); |
| 384 | 385 | ||
| 386 | /* | ||
| 387 | * Enable ADC filter to prevent horrible jitter on Colibri. | ||
| 388 | * This also further reduces jitter on boards where ADCSYNC | ||
| 389 | * pin is connected. | ||
| 390 | */ | ||
| 391 | fcsr = ucb1400_reg_read(ucb->ac97, UCB_FCSR); | ||
| 392 | ucb1400_reg_write(ucb->ac97, UCB_FCSR, fcsr | UCB_FCSR_AVE); | ||
| 393 | |||
| 385 | ucb1400_adc_enable(ucb->ac97); | 394 | ucb1400_adc_enable(ucb->ac97); |
| 386 | x_res = ucb1400_ts_read_xres(ucb); | 395 | x_res = ucb1400_ts_read_xres(ucb); |
| 387 | y_res = ucb1400_ts_read_yres(ucb); | 396 | y_res = ucb1400_ts_read_yres(ucb); |
diff --git a/drivers/isdn/mISDN/l1oip_core.c b/drivers/isdn/mISDN/l1oip_core.c index 990e6a7e6674..7e5f30dbc0a0 100644 --- a/drivers/isdn/mISDN/l1oip_core.c +++ b/drivers/isdn/mISDN/l1oip_core.c | |||
| @@ -731,10 +731,10 @@ l1oip_socket_thread(void *data) | |||
| 731 | while (!signal_pending(current)) { | 731 | while (!signal_pending(current)) { |
| 732 | struct kvec iov = { | 732 | struct kvec iov = { |
| 733 | .iov_base = recvbuf, | 733 | .iov_base = recvbuf, |
| 734 | .iov_len = sizeof(recvbuf), | 734 | .iov_len = recvbuf_size, |
| 735 | }; | 735 | }; |
| 736 | recvlen = kernel_recvmsg(socket, &msg, &iov, 1, | 736 | recvlen = kernel_recvmsg(socket, &msg, &iov, 1, |
| 737 | sizeof(recvbuf), 0); | 737 | recvbuf_size, 0); |
| 738 | if (recvlen > 0) { | 738 | if (recvlen > 0) { |
| 739 | l1oip_socket_parse(hc, &sin_rx, recvbuf, recvlen); | 739 | l1oip_socket_parse(hc, &sin_rx, recvbuf, recvlen); |
| 740 | } else { | 740 | } else { |
| @@ -1480,7 +1480,7 @@ l1oip_init(void) | |||
| 1480 | return -ENOMEM; | 1480 | return -ENOMEM; |
| 1481 | 1481 | ||
| 1482 | l1oip_cnt = 0; | 1482 | l1oip_cnt = 0; |
| 1483 | while (type[l1oip_cnt] && l1oip_cnt < MAX_CARDS) { | 1483 | while (l1oip_cnt < MAX_CARDS && type[l1oip_cnt]) { |
| 1484 | switch (type[l1oip_cnt] & 0xff) { | 1484 | switch (type[l1oip_cnt] & 0xff) { |
| 1485 | case 1: | 1485 | case 1: |
| 1486 | pri = 0; | 1486 | pri = 0; |
diff --git a/drivers/leds/ledtrig-gpio.c b/drivers/leds/ledtrig-gpio.c index a247ae63374f..1bc5db4ece0d 100644 --- a/drivers/leds/ledtrig-gpio.c +++ b/drivers/leds/ledtrig-gpio.c | |||
| @@ -117,6 +117,9 @@ static ssize_t gpio_trig_inverted_store(struct device *dev, | |||
| 117 | 117 | ||
| 118 | gpio_data->inverted = !!inverted; | 118 | gpio_data->inverted = !!inverted; |
| 119 | 119 | ||
| 120 | /* After inverting, we need to update the LED. */ | ||
| 121 | schedule_work(&gpio_data->work); | ||
| 122 | |||
| 120 | return n; | 123 | return n; |
| 121 | } | 124 | } |
| 122 | static DEVICE_ATTR(inverted, 0644, gpio_trig_inverted_show, | 125 | static DEVICE_ATTR(inverted, 0644, gpio_trig_inverted_show, |
| @@ -146,20 +149,26 @@ static ssize_t gpio_trig_gpio_store(struct device *dev, | |||
| 146 | return -EINVAL; | 149 | return -EINVAL; |
| 147 | } | 150 | } |
| 148 | 151 | ||
| 152 | if (gpio_data->gpio == gpio) | ||
| 153 | return n; | ||
| 154 | |||
| 149 | if (!gpio) { | 155 | if (!gpio) { |
| 150 | free_irq(gpio_to_irq(gpio_data->gpio), led); | 156 | if (gpio_data->gpio != 0) |
| 157 | free_irq(gpio_to_irq(gpio_data->gpio), led); | ||
| 158 | gpio_data->gpio = 0; | ||
| 151 | return n; | 159 | return n; |
| 152 | } | 160 | } |
| 153 | 161 | ||
| 154 | if (gpio_data->gpio > 0 && gpio_data->gpio != gpio) | ||
| 155 | free_irq(gpio_to_irq(gpio_data->gpio), led); | ||
| 156 | |||
| 157 | gpio_data->gpio = gpio; | ||
| 158 | ret = request_irq(gpio_to_irq(gpio), gpio_trig_irq, | 162 | ret = request_irq(gpio_to_irq(gpio), gpio_trig_irq, |
| 159 | IRQF_SHARED | IRQF_TRIGGER_RISING | 163 | IRQF_SHARED | IRQF_TRIGGER_RISING |
| 160 | | IRQF_TRIGGER_FALLING, "ledtrig-gpio", led); | 164 | | IRQF_TRIGGER_FALLING, "ledtrig-gpio", led); |
| 161 | if (ret) | 165 | if (ret) { |
| 162 | dev_err(dev, "request_irq failed with error %d\n", ret); | 166 | dev_err(dev, "request_irq failed with error %d\n", ret); |
| 167 | } else { | ||
| 168 | if (gpio_data->gpio != 0) | ||
| 169 | free_irq(gpio_to_irq(gpio_data->gpio), led); | ||
| 170 | gpio_data->gpio = gpio; | ||
| 171 | } | ||
| 163 | 172 | ||
| 164 | return ret ? ret : n; | 173 | return ret ? ret : n; |
| 165 | } | 174 | } |
| @@ -211,7 +220,8 @@ static void gpio_trig_deactivate(struct led_classdev *led) | |||
| 211 | device_remove_file(led->dev, &dev_attr_inverted); | 220 | device_remove_file(led->dev, &dev_attr_inverted); |
| 212 | device_remove_file(led->dev, &dev_attr_desired_brightness); | 221 | device_remove_file(led->dev, &dev_attr_desired_brightness); |
| 213 | flush_work(&gpio_data->work); | 222 | flush_work(&gpio_data->work); |
| 214 | free_irq(gpio_to_irq(gpio_data->gpio),led); | 223 | if (gpio_data->gpio != 0) |
| 224 | free_irq(gpio_to_irq(gpio_data->gpio), led); | ||
| 215 | kfree(gpio_data); | 225 | kfree(gpio_data); |
| 216 | } | 226 | } |
| 217 | } | 227 | } |
diff --git a/drivers/lguest/core.c b/drivers/lguest/core.c index a6974e9b8ebf..1e2cb846b3c9 100644 --- a/drivers/lguest/core.c +++ b/drivers/lguest/core.c | |||
| @@ -1,6 +1,8 @@ | |||
| 1 | /*P:400 This contains run_guest() which actually calls into the Host<->Guest | 1 | /*P:400 |
| 2 | * This contains run_guest() which actually calls into the Host<->Guest | ||
| 2 | * Switcher and analyzes the return, such as determining if the Guest wants the | 3 | * Switcher and analyzes the return, such as determining if the Guest wants the |
| 3 | * Host to do something. This file also contains useful helper routines. :*/ | 4 | * Host to do something. This file also contains useful helper routines. |
| 5 | :*/ | ||
| 4 | #include <linux/module.h> | 6 | #include <linux/module.h> |
| 5 | #include <linux/stringify.h> | 7 | #include <linux/stringify.h> |
| 6 | #include <linux/stddef.h> | 8 | #include <linux/stddef.h> |
| @@ -24,7 +26,8 @@ static struct page **switcher_page; | |||
| 24 | /* This One Big lock protects all inter-guest data structures. */ | 26 | /* This One Big lock protects all inter-guest data structures. */ |
| 25 | DEFINE_MUTEX(lguest_lock); | 27 | DEFINE_MUTEX(lguest_lock); |
| 26 | 28 | ||
| 27 | /*H:010 We need to set up the Switcher at a high virtual address. Remember the | 29 | /*H:010 |
| 30 | * We need to set up the Switcher at a high virtual address. Remember the | ||
| 28 | * Switcher is a few hundred bytes of assembler code which actually changes the | 31 | * Switcher is a few hundred bytes of assembler code which actually changes the |
| 29 | * CPU to run the Guest, and then changes back to the Host when a trap or | 32 | * CPU to run the Guest, and then changes back to the Host when a trap or |
| 30 | * interrupt happens. | 33 | * interrupt happens. |
| @@ -33,7 +36,8 @@ DEFINE_MUTEX(lguest_lock); | |||
| 33 | * Host since it will be running as the switchover occurs. | 36 | * Host since it will be running as the switchover occurs. |
| 34 | * | 37 | * |
| 35 | * Trying to map memory at a particular address is an unusual thing to do, so | 38 | * Trying to map memory at a particular address is an unusual thing to do, so |
| 36 | * it's not a simple one-liner. */ | 39 | * it's not a simple one-liner. |
| 40 | */ | ||
| 37 | static __init int map_switcher(void) | 41 | static __init int map_switcher(void) |
| 38 | { | 42 | { |
| 39 | int i, err; | 43 | int i, err; |
| @@ -47,8 +51,10 @@ static __init int map_switcher(void) | |||
| 47 | * easy. | 51 | * easy. |
| 48 | */ | 52 | */ |
| 49 | 53 | ||
| 50 | /* We allocate an array of struct page pointers. map_vm_area() wants | 54 | /* |
| 51 | * this, rather than just an array of pages. */ | 55 | * We allocate an array of struct page pointers. map_vm_area() wants |
| 56 | * this, rather than just an array of pages. | ||
| 57 | */ | ||
| 52 | switcher_page = kmalloc(sizeof(switcher_page[0])*TOTAL_SWITCHER_PAGES, | 58 | switcher_page = kmalloc(sizeof(switcher_page[0])*TOTAL_SWITCHER_PAGES, |
| 53 | GFP_KERNEL); | 59 | GFP_KERNEL); |
| 54 | if (!switcher_page) { | 60 | if (!switcher_page) { |
| @@ -56,8 +62,10 @@ static __init int map_switcher(void) | |||
| 56 | goto out; | 62 | goto out; |
| 57 | } | 63 | } |
| 58 | 64 | ||
| 59 | /* Now we actually allocate the pages. The Guest will see these pages, | 65 | /* |
| 60 | * so we make sure they're zeroed. */ | 66 | * Now we actually allocate the pages. The Guest will see these pages, |
| 67 | * so we make sure they're zeroed. | ||
| 68 | */ | ||
| 61 | for (i = 0; i < TOTAL_SWITCHER_PAGES; i++) { | 69 | for (i = 0; i < TOTAL_SWITCHER_PAGES; i++) { |
| 62 | unsigned long addr = get_zeroed_page(GFP_KERNEL); | 70 | unsigned long addr = get_zeroed_page(GFP_KERNEL); |
| 63 | if (!addr) { | 71 | if (!addr) { |
| @@ -67,19 +75,23 @@ static __init int map_switcher(void) | |||
| 67 | switcher_page[i] = virt_to_page(addr); | 75 | switcher_page[i] = virt_to_page(addr); |
| 68 | } | 76 | } |
| 69 | 77 | ||
| 70 | /* First we check that the Switcher won't overlap the fixmap area at | 78 | /* |
| 79 | * First we check that the Switcher won't overlap the fixmap area at | ||
| 71 | * the top of memory. It's currently nowhere near, but it could have | 80 | * the top of memory. It's currently nowhere near, but it could have |
| 72 | * very strange effects if it ever happened. */ | 81 | * very strange effects if it ever happened. |
| 82 | */ | ||
| 73 | if (SWITCHER_ADDR + (TOTAL_SWITCHER_PAGES+1)*PAGE_SIZE > FIXADDR_START){ | 83 | if (SWITCHER_ADDR + (TOTAL_SWITCHER_PAGES+1)*PAGE_SIZE > FIXADDR_START){ |
| 74 | err = -ENOMEM; | 84 | err = -ENOMEM; |
| 75 | printk("lguest: mapping switcher would thwack fixmap\n"); | 85 | printk("lguest: mapping switcher would thwack fixmap\n"); |
| 76 | goto free_pages; | 86 | goto free_pages; |
| 77 | } | 87 | } |
| 78 | 88 | ||
| 79 | /* Now we reserve the "virtual memory area" we want: 0xFFC00000 | 89 | /* |
| 90 | * Now we reserve the "virtual memory area" we want: 0xFFC00000 | ||
| 80 | * (SWITCHER_ADDR). We might not get it in theory, but in practice | 91 | * (SWITCHER_ADDR). We might not get it in theory, but in practice |
| 81 | * it's worked so far. The end address needs +1 because __get_vm_area | 92 | * it's worked so far. The end address needs +1 because __get_vm_area |
| 82 | * allocates an extra guard page, so we need space for that. */ | 93 | * allocates an extra guard page, so we need space for that. |
| 94 | */ | ||
| 83 | switcher_vma = __get_vm_area(TOTAL_SWITCHER_PAGES * PAGE_SIZE, | 95 | switcher_vma = __get_vm_area(TOTAL_SWITCHER_PAGES * PAGE_SIZE, |
| 84 | VM_ALLOC, SWITCHER_ADDR, SWITCHER_ADDR | 96 | VM_ALLOC, SWITCHER_ADDR, SWITCHER_ADDR |
| 85 | + (TOTAL_SWITCHER_PAGES+1) * PAGE_SIZE); | 97 | + (TOTAL_SWITCHER_PAGES+1) * PAGE_SIZE); |
| @@ -89,11 +101,13 @@ static __init int map_switcher(void) | |||
| 89 | goto free_pages; | 101 | goto free_pages; |
| 90 | } | 102 | } |
| 91 | 103 | ||
| 92 | /* This code actually sets up the pages we've allocated to appear at | 104 | /* |
| 105 | * This code actually sets up the pages we've allocated to appear at | ||
| 93 | * SWITCHER_ADDR. map_vm_area() takes the vma we allocated above, the | 106 | * SWITCHER_ADDR. map_vm_area() takes the vma we allocated above, the |
| 94 | * kind of pages we're mapping (kernel pages), and a pointer to our | 107 | * kind of pages we're mapping (kernel pages), and a pointer to our |
| 95 | * array of struct pages. It increments that pointer, but we don't | 108 | * array of struct pages. It increments that pointer, but we don't |
| 96 | * care. */ | 109 | * care. |
| 110 | */ | ||
| 97 | pagep = switcher_page; | 111 | pagep = switcher_page; |
| 98 | err = map_vm_area(switcher_vma, PAGE_KERNEL_EXEC, &pagep); | 112 | err = map_vm_area(switcher_vma, PAGE_KERNEL_EXEC, &pagep); |
| 99 | if (err) { | 113 | if (err) { |
| @@ -101,8 +115,10 @@ static __init int map_switcher(void) | |||
| 101 | goto free_vma; | 115 | goto free_vma; |
| 102 | } | 116 | } |
| 103 | 117 | ||
| 104 | /* Now the Switcher is mapped at the right address, we can't fail! | 118 | /* |
| 105 | * Copy in the compiled-in Switcher code (from <arch>_switcher.S). */ | 119 | * Now the Switcher is mapped at the right address, we can't fail! |
| 120 | * Copy in the compiled-in Switcher code (from <arch>_switcher.S). | ||
| 121 | */ | ||
| 106 | memcpy(switcher_vma->addr, start_switcher_text, | 122 | memcpy(switcher_vma->addr, start_switcher_text, |
| 107 | end_switcher_text - start_switcher_text); | 123 | end_switcher_text - start_switcher_text); |
| 108 | 124 | ||
| @@ -124,8 +140,7 @@ out: | |||
| 124 | } | 140 | } |
| 125 | /*:*/ | 141 | /*:*/ |
| 126 | 142 | ||
| 127 | /* Cleaning up the mapping when the module is unloaded is almost... | 143 | /* Cleaning up the mapping when the module is unloaded is almost... too easy. */ |
| 128 | * too easy. */ | ||
| 129 | static void unmap_switcher(void) | 144 | static void unmap_switcher(void) |
| 130 | { | 145 | { |
| 131 | unsigned int i; | 146 | unsigned int i; |
| @@ -151,16 +166,19 @@ static void unmap_switcher(void) | |||
| 151 | * But we can't trust the Guest: it might be trying to access the Launcher | 166 | * But we can't trust the Guest: it might be trying to access the Launcher |
| 152 | * code. We have to check that the range is below the pfn_limit the Launcher | 167 | * code. We have to check that the range is below the pfn_limit the Launcher |
| 153 | * gave us. We have to make sure that addr + len doesn't give us a false | 168 | * gave us. We have to make sure that addr + len doesn't give us a false |
| 154 | * positive by overflowing, too. */ | 169 | * positive by overflowing, too. |
| 170 | */ | ||
| 155 | bool lguest_address_ok(const struct lguest *lg, | 171 | bool lguest_address_ok(const struct lguest *lg, |
| 156 | unsigned long addr, unsigned long len) | 172 | unsigned long addr, unsigned long len) |
| 157 | { | 173 | { |
| 158 | return (addr+len) / PAGE_SIZE < lg->pfn_limit && (addr+len >= addr); | 174 | return (addr+len) / PAGE_SIZE < lg->pfn_limit && (addr+len >= addr); |
| 159 | } | 175 | } |
| 160 | 176 | ||
| 161 | /* This routine copies memory from the Guest. Here we can see how useful the | 177 | /* |
| 178 | * This routine copies memory from the Guest. Here we can see how useful the | ||
| 162 | * kill_lguest() routine we met in the Launcher can be: we return a random | 179 | * kill_lguest() routine we met in the Launcher can be: we return a random |
| 163 | * value (all zeroes) instead of needing to return an error. */ | 180 | * value (all zeroes) instead of needing to return an error. |
| 181 | */ | ||
| 164 | void __lgread(struct lg_cpu *cpu, void *b, unsigned long addr, unsigned bytes) | 182 | void __lgread(struct lg_cpu *cpu, void *b, unsigned long addr, unsigned bytes) |
| 165 | { | 183 | { |
| 166 | if (!lguest_address_ok(cpu->lg, addr, bytes) | 184 | if (!lguest_address_ok(cpu->lg, addr, bytes) |
| @@ -181,9 +199,11 @@ void __lgwrite(struct lg_cpu *cpu, unsigned long addr, const void *b, | |||
| 181 | } | 199 | } |
| 182 | /*:*/ | 200 | /*:*/ |
| 183 | 201 | ||
| 184 | /*H:030 Let's jump straight to the the main loop which runs the Guest. | 202 | /*H:030 |
| 203 | * Let's jump straight to the the main loop which runs the Guest. | ||
| 185 | * Remember, this is called by the Launcher reading /dev/lguest, and we keep | 204 | * Remember, this is called by the Launcher reading /dev/lguest, and we keep |
| 186 | * going around and around until something interesting happens. */ | 205 | * going around and around until something interesting happens. |
| 206 | */ | ||
| 187 | int run_guest(struct lg_cpu *cpu, unsigned long __user *user) | 207 | int run_guest(struct lg_cpu *cpu, unsigned long __user *user) |
| 188 | { | 208 | { |
| 189 | /* We stop running once the Guest is dead. */ | 209 | /* We stop running once the Guest is dead. */ |
| @@ -195,10 +215,17 @@ int run_guest(struct lg_cpu *cpu, unsigned long __user *user) | |||
| 195 | if (cpu->hcall) | 215 | if (cpu->hcall) |
| 196 | do_hypercalls(cpu); | 216 | do_hypercalls(cpu); |
| 197 | 217 | ||
| 198 | /* It's possible the Guest did a NOTIFY hypercall to the | 218 | /* |
| 199 | * Launcher, in which case we return from the read() now. */ | 219 | * It's possible the Guest did a NOTIFY hypercall to the |
| 220 | * Launcher. | ||
| 221 | */ | ||
| 200 | if (cpu->pending_notify) { | 222 | if (cpu->pending_notify) { |
| 223 | /* | ||
| 224 | * Does it just needs to write to a registered | ||
| 225 | * eventfd (ie. the appropriate virtqueue thread)? | ||
| 226 | */ | ||
| 201 | if (!send_notify_to_eventfd(cpu)) { | 227 | if (!send_notify_to_eventfd(cpu)) { |
| 228 | /* OK, we tell the main Laucher. */ | ||
| 202 | if (put_user(cpu->pending_notify, user)) | 229 | if (put_user(cpu->pending_notify, user)) |
| 203 | return -EFAULT; | 230 | return -EFAULT; |
| 204 | return sizeof(cpu->pending_notify); | 231 | return sizeof(cpu->pending_notify); |
| @@ -209,29 +236,39 @@ int run_guest(struct lg_cpu *cpu, unsigned long __user *user) | |||
| 209 | if (signal_pending(current)) | 236 | if (signal_pending(current)) |
| 210 | return -ERESTARTSYS; | 237 | return -ERESTARTSYS; |
| 211 | 238 | ||
| 212 | /* Check if there are any interrupts which can be delivered now: | 239 | /* |
| 240 | * Check if there are any interrupts which can be delivered now: | ||
| 213 | * if so, this sets up the hander to be executed when we next | 241 | * if so, this sets up the hander to be executed when we next |
| 214 | * run the Guest. */ | 242 | * run the Guest. |
| 243 | */ | ||
| 215 | irq = interrupt_pending(cpu, &more); | 244 | irq = interrupt_pending(cpu, &more); |
| 216 | if (irq < LGUEST_IRQS) | 245 | if (irq < LGUEST_IRQS) |
| 217 | try_deliver_interrupt(cpu, irq, more); | 246 | try_deliver_interrupt(cpu, irq, more); |
| 218 | 247 | ||
| 219 | /* All long-lived kernel loops need to check with this horrible | 248 | /* |
| 249 | * All long-lived kernel loops need to check with this horrible | ||
| 220 | * thing called the freezer. If the Host is trying to suspend, | 250 | * thing called the freezer. If the Host is trying to suspend, |
| 221 | * it stops us. */ | 251 | * it stops us. |
| 252 | */ | ||
| 222 | try_to_freeze(); | 253 | try_to_freeze(); |
| 223 | 254 | ||
| 224 | /* Just make absolutely sure the Guest is still alive. One of | 255 | /* |
| 225 | * those hypercalls could have been fatal, for example. */ | 256 | * Just make absolutely sure the Guest is still alive. One of |
| 257 | * those hypercalls could have been fatal, for example. | ||
| 258 | */ | ||
| 226 | if (cpu->lg->dead) | 259 | if (cpu->lg->dead) |
| 227 | break; | 260 | break; |
| 228 | 261 | ||
| 229 | /* If the Guest asked to be stopped, we sleep. The Guest's | 262 | /* |
| 230 | * clock timer will wake us. */ | 263 | * If the Guest asked to be stopped, we sleep. The Guest's |
| 264 | * clock timer will wake us. | ||
| 265 | */ | ||
| 231 | if (cpu->halted) { | 266 | if (cpu->halted) { |
| 232 | set_current_state(TASK_INTERRUPTIBLE); | 267 | set_current_state(TASK_INTERRUPTIBLE); |
| 233 | /* Just before we sleep, make sure no interrupt snuck in | 268 | /* |
| 234 | * which we should be doing. */ | 269 | * Just before we sleep, make sure no interrupt snuck in |
| 270 | * which we should be doing. | ||
| 271 | */ | ||
| 235 | if (interrupt_pending(cpu, &more) < LGUEST_IRQS) | 272 | if (interrupt_pending(cpu, &more) < LGUEST_IRQS) |
| 236 | set_current_state(TASK_RUNNING); | 273 | set_current_state(TASK_RUNNING); |
| 237 | else | 274 | else |
| @@ -239,8 +276,10 @@ int run_guest(struct lg_cpu *cpu, unsigned long __user *user) | |||
| 239 | continue; | 276 | continue; |
| 240 | } | 277 | } |
| 241 | 278 | ||
| 242 | /* OK, now we're ready to jump into the Guest. First we put up | 279 | /* |
| 243 | * the "Do Not Disturb" sign: */ | 280 | * OK, now we're ready to jump into the Guest. First we put up |
| 281 | * the "Do Not Disturb" sign: | ||
| 282 | */ | ||
| 244 | local_irq_disable(); | 283 | local_irq_disable(); |
| 245 | 284 | ||
| 246 | /* Actually run the Guest until something happens. */ | 285 | /* Actually run the Guest until something happens. */ |
| @@ -327,8 +366,10 @@ static void __exit fini(void) | |||
| 327 | } | 366 | } |
| 328 | /*:*/ | 367 | /*:*/ |
| 329 | 368 | ||
| 330 | /* The Host side of lguest can be a module. This is a nice way for people to | 369 | /* |
| 331 | * play with it. */ | 370 | * The Host side of lguest can be a module. This is a nice way for people to |
| 371 | * play with it. | ||
| 372 | */ | ||
| 332 | module_init(init); | 373 | module_init(init); |
| 333 | module_exit(fini); | 374 | module_exit(fini); |
| 334 | MODULE_LICENSE("GPL"); | 375 | MODULE_LICENSE("GPL"); |
diff --git a/drivers/lguest/hypercalls.c b/drivers/lguest/hypercalls.c index c29ffa19cb74..83511eb0923d 100644 --- a/drivers/lguest/hypercalls.c +++ b/drivers/lguest/hypercalls.c | |||
| @@ -1,8 +1,10 @@ | |||
| 1 | /*P:500 Just as userspace programs request kernel operations through a system | 1 | /*P:500 |
| 2 | * Just as userspace programs request kernel operations through a system | ||
| 2 | * call, the Guest requests Host operations through a "hypercall". You might | 3 | * call, the Guest requests Host operations through a "hypercall". You might |
| 3 | * notice this nomenclature doesn't really follow any logic, but the name has | 4 | * notice this nomenclature doesn't really follow any logic, but the name has |
| 4 | * been around for long enough that we're stuck with it. As you'd expect, this | 5 | * been around for long enough that we're stuck with it. As you'd expect, this |
| 5 | * code is basically a one big switch statement. :*/ | 6 | * code is basically a one big switch statement. |
| 7 | :*/ | ||
| 6 | 8 | ||
| 7 | /* Copyright (C) 2006 Rusty Russell IBM Corporation | 9 | /* Copyright (C) 2006 Rusty Russell IBM Corporation |
| 8 | 10 | ||
| @@ -28,30 +30,41 @@ | |||
| 28 | #include <asm/pgtable.h> | 30 | #include <asm/pgtable.h> |
| 29 | #include "lg.h" | 31 | #include "lg.h" |
| 30 | 32 | ||
| 31 | /*H:120 This is the core hypercall routine: where the Guest gets what it wants. | 33 | /*H:120 |
| 32 | * Or gets killed. Or, in the case of LHCALL_SHUTDOWN, both. */ | 34 | * This is the core hypercall routine: where the Guest gets what it wants. |
| 35 | * Or gets killed. Or, in the case of LHCALL_SHUTDOWN, both. | ||
| 36 | */ | ||
| 33 | static void do_hcall(struct lg_cpu *cpu, struct hcall_args *args) | 37 | static void do_hcall(struct lg_cpu *cpu, struct hcall_args *args) |
| 34 | { | 38 | { |
| 35 | switch (args->arg0) { | 39 | switch (args->arg0) { |
| 36 | case LHCALL_FLUSH_ASYNC: | 40 | case LHCALL_FLUSH_ASYNC: |
| 37 | /* This call does nothing, except by breaking out of the Guest | 41 | /* |
| 38 | * it makes us process all the asynchronous hypercalls. */ | 42 | * This call does nothing, except by breaking out of the Guest |
| 43 | * it makes us process all the asynchronous hypercalls. | ||
| 44 | */ | ||
| 39 | break; | 45 | break; |
| 40 | case LHCALL_SEND_INTERRUPTS: | 46 | case LHCALL_SEND_INTERRUPTS: |
| 41 | /* This call does nothing too, but by breaking out of the Guest | 47 | /* |
| 42 | * it makes us process any pending interrupts. */ | 48 | * This call does nothing too, but by breaking out of the Guest |
| 49 | * it makes us process any pending interrupts. | ||
| 50 | */ | ||
| 43 | break; | 51 | break; |
| 44 | case LHCALL_LGUEST_INIT: | 52 | case LHCALL_LGUEST_INIT: |
| 45 | /* You can't get here unless you're already initialized. Don't | 53 | /* |
| 46 | * do that. */ | 54 | * You can't get here unless you're already initialized. Don't |
| 55 | * do that. | ||
| 56 | */ | ||
| 47 | kill_guest(cpu, "already have lguest_data"); | 57 | kill_guest(cpu, "already have lguest_data"); |
| 48 | break; | 58 | break; |
| 49 | case LHCALL_SHUTDOWN: { | 59 | case LHCALL_SHUTDOWN: { |
| 50 | /* Shutdown is such a trivial hypercall that we do it in four | ||
| 51 | * lines right here. */ | ||
| 52 | char msg[128]; | 60 | char msg[128]; |
| 53 | /* If the lgread fails, it will call kill_guest() itself; the | 61 | /* |
| 54 | * kill_guest() with the message will be ignored. */ | 62 | * Shutdown is such a trivial hypercall that we do it in five |
| 63 | * lines right here. | ||
| 64 | * | ||
| 65 | * If the lgread fails, it will call kill_guest() itself; the | ||
| 66 | * kill_guest() with the message will be ignored. | ||
| 67 | */ | ||
| 55 | __lgread(cpu, msg, args->arg1, sizeof(msg)); | 68 | __lgread(cpu, msg, args->arg1, sizeof(msg)); |
| 56 | msg[sizeof(msg)-1] = '\0'; | 69 | msg[sizeof(msg)-1] = '\0'; |
| 57 | kill_guest(cpu, "CRASH: %s", msg); | 70 | kill_guest(cpu, "CRASH: %s", msg); |
| @@ -60,16 +73,17 @@ static void do_hcall(struct lg_cpu *cpu, struct hcall_args *args) | |||
| 60 | break; | 73 | break; |
| 61 | } | 74 | } |
| 62 | case LHCALL_FLUSH_TLB: | 75 | case LHCALL_FLUSH_TLB: |
| 63 | /* FLUSH_TLB comes in two flavors, depending on the | 76 | /* FLUSH_TLB comes in two flavors, depending on the argument: */ |
| 64 | * argument: */ | ||
| 65 | if (args->arg1) | 77 | if (args->arg1) |
| 66 | guest_pagetable_clear_all(cpu); | 78 | guest_pagetable_clear_all(cpu); |
| 67 | else | 79 | else |
| 68 | guest_pagetable_flush_user(cpu); | 80 | guest_pagetable_flush_user(cpu); |
| 69 | break; | 81 | break; |
| 70 | 82 | ||
| 71 | /* All these calls simply pass the arguments through to the right | 83 | /* |
| 72 | * routines. */ | 84 | * All these calls simply pass the arguments through to the right |
| 85 | * routines. | ||
| 86 | */ | ||
| 73 | case LHCALL_NEW_PGTABLE: | 87 | case LHCALL_NEW_PGTABLE: |
| 74 | guest_new_pagetable(cpu, args->arg1); | 88 | guest_new_pagetable(cpu, args->arg1); |
| 75 | break; | 89 | break; |
| @@ -112,15 +126,16 @@ static void do_hcall(struct lg_cpu *cpu, struct hcall_args *args) | |||
| 112 | kill_guest(cpu, "Bad hypercall %li\n", args->arg0); | 126 | kill_guest(cpu, "Bad hypercall %li\n", args->arg0); |
| 113 | } | 127 | } |
| 114 | } | 128 | } |
| 115 | /*:*/ | ||
| 116 | 129 | ||
| 117 | /*H:124 Asynchronous hypercalls are easy: we just look in the array in the | 130 | /*H:124 |
| 131 | * Asynchronous hypercalls are easy: we just look in the array in the | ||
| 118 | * Guest's "struct lguest_data" to see if any new ones are marked "ready". | 132 | * Guest's "struct lguest_data" to see if any new ones are marked "ready". |
| 119 | * | 133 | * |
| 120 | * We are careful to do these in order: obviously we respect the order the | 134 | * We are careful to do these in order: obviously we respect the order the |
| 121 | * Guest put them in the ring, but we also promise the Guest that they will | 135 | * Guest put them in the ring, but we also promise the Guest that they will |
| 122 | * happen before any normal hypercall (which is why we check this before | 136 | * happen before any normal hypercall (which is why we check this before |
| 123 | * checking for a normal hcall). */ | 137 | * checking for a normal hcall). |
| 138 | */ | ||
| 124 | static void do_async_hcalls(struct lg_cpu *cpu) | 139 | static void do_async_hcalls(struct lg_cpu *cpu) |
| 125 | { | 140 | { |
| 126 | unsigned int i; | 141 | unsigned int i; |
| @@ -133,22 +148,28 @@ static void do_async_hcalls(struct lg_cpu *cpu) | |||
| 133 | /* We process "struct lguest_data"s hcalls[] ring once. */ | 148 | /* We process "struct lguest_data"s hcalls[] ring once. */ |
| 134 | for (i = 0; i < ARRAY_SIZE(st); i++) { | 149 | for (i = 0; i < ARRAY_SIZE(st); i++) { |
| 135 | struct hcall_args args; | 150 | struct hcall_args args; |
| 136 | /* We remember where we were up to from last time. This makes | 151 | /* |
| 152 | * We remember where we were up to from last time. This makes | ||
| 137 | * sure that the hypercalls are done in the order the Guest | 153 | * sure that the hypercalls are done in the order the Guest |
| 138 | * places them in the ring. */ | 154 | * places them in the ring. |
| 155 | */ | ||
| 139 | unsigned int n = cpu->next_hcall; | 156 | unsigned int n = cpu->next_hcall; |
| 140 | 157 | ||
| 141 | /* 0xFF means there's no call here (yet). */ | 158 | /* 0xFF means there's no call here (yet). */ |
| 142 | if (st[n] == 0xFF) | 159 | if (st[n] == 0xFF) |
| 143 | break; | 160 | break; |
| 144 | 161 | ||
| 145 | /* OK, we have hypercall. Increment the "next_hcall" cursor, | 162 | /* |
| 146 | * and wrap back to 0 if we reach the end. */ | 163 | * OK, we have hypercall. Increment the "next_hcall" cursor, |
| 164 | * and wrap back to 0 if we reach the end. | ||
| 165 | */ | ||
| 147 | if (++cpu->next_hcall == LHCALL_RING_SIZE) | 166 | if (++cpu->next_hcall == LHCALL_RING_SIZE) |
| 148 | cpu->next_hcall = 0; | 167 | cpu->next_hcall = 0; |
| 149 | 168 | ||
| 150 | /* Copy the hypercall arguments into a local copy of | 169 | /* |
| 151 | * the hcall_args struct. */ | 170 | * Copy the hypercall arguments into a local copy of the |
| 171 | * hcall_args struct. | ||
| 172 | */ | ||
| 152 | if (copy_from_user(&args, &cpu->lg->lguest_data->hcalls[n], | 173 | if (copy_from_user(&args, &cpu->lg->lguest_data->hcalls[n], |
| 153 | sizeof(struct hcall_args))) { | 174 | sizeof(struct hcall_args))) { |
| 154 | kill_guest(cpu, "Fetching async hypercalls"); | 175 | kill_guest(cpu, "Fetching async hypercalls"); |
| @@ -164,19 +185,25 @@ static void do_async_hcalls(struct lg_cpu *cpu) | |||
| 164 | break; | 185 | break; |
| 165 | } | 186 | } |
| 166 | 187 | ||
| 167 | /* Stop doing hypercalls if they want to notify the Launcher: | 188 | /* |
| 168 | * it needs to service this first. */ | 189 | * Stop doing hypercalls if they want to notify the Launcher: |
| 190 | * it needs to service this first. | ||
| 191 | */ | ||
| 169 | if (cpu->pending_notify) | 192 | if (cpu->pending_notify) |
| 170 | break; | 193 | break; |
| 171 | } | 194 | } |
| 172 | } | 195 | } |
| 173 | 196 | ||
| 174 | /* Last of all, we look at what happens first of all. The very first time the | 197 | /* |
| 175 | * Guest makes a hypercall, we end up here to set things up: */ | 198 | * Last of all, we look at what happens first of all. The very first time the |
| 199 | * Guest makes a hypercall, we end up here to set things up: | ||
| 200 | */ | ||
| 176 | static void initialize(struct lg_cpu *cpu) | 201 | static void initialize(struct lg_cpu *cpu) |
| 177 | { | 202 | { |
| 178 | /* You can't do anything until you're initialized. The Guest knows the | 203 | /* |
| 179 | * rules, so we're unforgiving here. */ | 204 | * You can't do anything until you're initialized. The Guest knows the |
| 205 | * rules, so we're unforgiving here. | ||
| 206 | */ | ||
| 180 | if (cpu->hcall->arg0 != LHCALL_LGUEST_INIT) { | 207 | if (cpu->hcall->arg0 != LHCALL_LGUEST_INIT) { |
| 181 | kill_guest(cpu, "hypercall %li before INIT", cpu->hcall->arg0); | 208 | kill_guest(cpu, "hypercall %li before INIT", cpu->hcall->arg0); |
| 182 | return; | 209 | return; |
| @@ -185,32 +212,44 @@ static void initialize(struct lg_cpu *cpu) | |||
| 185 | if (lguest_arch_init_hypercalls(cpu)) | 212 | if (lguest_arch_init_hypercalls(cpu)) |
| 186 | kill_guest(cpu, "bad guest page %p", cpu->lg->lguest_data); | 213 | kill_guest(cpu, "bad guest page %p", cpu->lg->lguest_data); |
| 187 | 214 | ||
| 188 | /* The Guest tells us where we're not to deliver interrupts by putting | 215 | /* |
| 189 | * the range of addresses into "struct lguest_data". */ | 216 | * The Guest tells us where we're not to deliver interrupts by putting |
| 217 | * the range of addresses into "struct lguest_data". | ||
| 218 | */ | ||
| 190 | if (get_user(cpu->lg->noirq_start, &cpu->lg->lguest_data->noirq_start) | 219 | if (get_user(cpu->lg->noirq_start, &cpu->lg->lguest_data->noirq_start) |
| 191 | || get_user(cpu->lg->noirq_end, &cpu->lg->lguest_data->noirq_end)) | 220 | || get_user(cpu->lg->noirq_end, &cpu->lg->lguest_data->noirq_end)) |
| 192 | kill_guest(cpu, "bad guest page %p", cpu->lg->lguest_data); | 221 | kill_guest(cpu, "bad guest page %p", cpu->lg->lguest_data); |
| 193 | 222 | ||
| 194 | /* We write the current time into the Guest's data page once so it can | 223 | /* |
| 195 | * set its clock. */ | 224 | * We write the current time into the Guest's data page once so it can |
| 225 | * set its clock. | ||
| 226 | */ | ||
| 196 | write_timestamp(cpu); | 227 | write_timestamp(cpu); |
| 197 | 228 | ||
| 198 | /* page_tables.c will also do some setup. */ | 229 | /* page_tables.c will also do some setup. */ |
| 199 | page_table_guest_data_init(cpu); | 230 | page_table_guest_data_init(cpu); |
| 200 | 231 | ||
| 201 | /* This is the one case where the above accesses might have been the | 232 | /* |
| 233 | * This is the one case where the above accesses might have been the | ||
| 202 | * first write to a Guest page. This may have caused a copy-on-write | 234 | * first write to a Guest page. This may have caused a copy-on-write |
| 203 | * fault, but the old page might be (read-only) in the Guest | 235 | * fault, but the old page might be (read-only) in the Guest |
| 204 | * pagetable. */ | 236 | * pagetable. |
| 237 | */ | ||
| 205 | guest_pagetable_clear_all(cpu); | 238 | guest_pagetable_clear_all(cpu); |
| 206 | } | 239 | } |
| 207 | /*:*/ | 240 | /*:*/ |
| 208 | 241 | ||
| 209 | /*M:013 If a Guest reads from a page (so creates a mapping) that it has never | 242 | /*M:013 |
| 243 | * If a Guest reads from a page (so creates a mapping) that it has never | ||
| 210 | * written to, and then the Launcher writes to it (ie. the output of a virtual | 244 | * written to, and then the Launcher writes to it (ie. the output of a virtual |
| 211 | * device), the Guest will still see the old page. In practice, this never | 245 | * device), the Guest will still see the old page. In practice, this never |
| 212 | * happens: why would the Guest read a page which it has never written to? But | 246 | * happens: why would the Guest read a page which it has never written to? But |
| 213 | * a similar scenario might one day bite us, so it's worth mentioning. :*/ | 247 | * a similar scenario might one day bite us, so it's worth mentioning. |
| 248 | * | ||
| 249 | * Note that if we used a shared anonymous mapping in the Launcher instead of | ||
| 250 | * mapping /dev/zero private, we wouldn't worry about cop-on-write. And we | ||
| 251 | * need that to switch the Launcher to processes (away from threads) anyway. | ||
| 252 | :*/ | ||
| 214 | 253 | ||
| 215 | /*H:100 | 254 | /*H:100 |
| 216 | * Hypercalls | 255 | * Hypercalls |
| @@ -229,17 +268,22 @@ void do_hypercalls(struct lg_cpu *cpu) | |||
| 229 | return; | 268 | return; |
| 230 | } | 269 | } |
| 231 | 270 | ||
| 232 | /* The Guest has initialized. | 271 | /* |
| 272 | * The Guest has initialized. | ||
| 233 | * | 273 | * |
| 234 | * Look in the hypercall ring for the async hypercalls: */ | 274 | * Look in the hypercall ring for the async hypercalls: |
| 275 | */ | ||
| 235 | do_async_hcalls(cpu); | 276 | do_async_hcalls(cpu); |
| 236 | 277 | ||
| 237 | /* If we stopped reading the hypercall ring because the Guest did a | 278 | /* |
| 279 | * If we stopped reading the hypercall ring because the Guest did a | ||
| 238 | * NOTIFY to the Launcher, we want to return now. Otherwise we do | 280 | * NOTIFY to the Launcher, we want to return now. Otherwise we do |
| 239 | * the hypercall. */ | 281 | * the hypercall. |
| 282 | */ | ||
| 240 | if (!cpu->pending_notify) { | 283 | if (!cpu->pending_notify) { |
| 241 | do_hcall(cpu, cpu->hcall); | 284 | do_hcall(cpu, cpu->hcall); |
| 242 | /* Tricky point: we reset the hcall pointer to mark the | 285 | /* |
| 286 | * Tricky point: we reset the hcall pointer to mark the | ||
| 243 | * hypercall as "done". We use the hcall pointer rather than | 287 | * hypercall as "done". We use the hcall pointer rather than |
| 244 | * the trap number to indicate a hypercall is pending. | 288 | * the trap number to indicate a hypercall is pending. |
| 245 | * Normally it doesn't matter: the Guest will run again and | 289 | * Normally it doesn't matter: the Guest will run again and |
| @@ -248,13 +292,16 @@ void do_hypercalls(struct lg_cpu *cpu) | |||
| 248 | * However, if we are signalled or the Guest sends I/O to the | 292 | * However, if we are signalled or the Guest sends I/O to the |
| 249 | * Launcher, the run_guest() loop will exit without running the | 293 | * Launcher, the run_guest() loop will exit without running the |
| 250 | * Guest. When it comes back it would try to re-run the | 294 | * Guest. When it comes back it would try to re-run the |
| 251 | * hypercall. Finding that bug sucked. */ | 295 | * hypercall. Finding that bug sucked. |
| 296 | */ | ||
| 252 | cpu->hcall = NULL; | 297 | cpu->hcall = NULL; |
| 253 | } | 298 | } |
| 254 | } | 299 | } |
| 255 | 300 | ||
| 256 | /* This routine supplies the Guest with time: it's used for wallclock time at | 301 | /* |
| 257 | * initial boot and as a rough time source if the TSC isn't available. */ | 302 | * This routine supplies the Guest with time: it's used for wallclock time at |
| 303 | * initial boot and as a rough time source if the TSC isn't available. | ||
| 304 | */ | ||
| 258 | void write_timestamp(struct lg_cpu *cpu) | 305 | void write_timestamp(struct lg_cpu *cpu) |
| 259 | { | 306 | { |
| 260 | struct timespec now; | 307 | struct timespec now; |
diff --git a/drivers/lguest/interrupts_and_traps.c b/drivers/lguest/interrupts_and_traps.c index 0e9067b0d507..18648180db02 100644 --- a/drivers/lguest/interrupts_and_traps.c +++ b/drivers/lguest/interrupts_and_traps.c | |||
| @@ -1,4 +1,5 @@ | |||
| 1 | /*P:800 Interrupts (traps) are complicated enough to earn their own file. | 1 | /*P:800 |
| 2 | * Interrupts (traps) are complicated enough to earn their own file. | ||
| 2 | * There are three classes of interrupts: | 3 | * There are three classes of interrupts: |
| 3 | * | 4 | * |
| 4 | * 1) Real hardware interrupts which occur while we're running the Guest, | 5 | * 1) Real hardware interrupts which occur while we're running the Guest, |
| @@ -10,7 +11,8 @@ | |||
| 10 | * just like real hardware would deliver them. Traps from the Guest can be set | 11 | * just like real hardware would deliver them. Traps from the Guest can be set |
| 11 | * up to go directly back into the Guest, but sometimes the Host wants to see | 12 | * up to go directly back into the Guest, but sometimes the Host wants to see |
| 12 | * them first, so we also have a way of "reflecting" them into the Guest as if | 13 | * them first, so we also have a way of "reflecting" them into the Guest as if |
| 13 | * they had been delivered to it directly. :*/ | 14 | * they had been delivered to it directly. |
| 15 | :*/ | ||
| 14 | #include <linux/uaccess.h> | 16 | #include <linux/uaccess.h> |
| 15 | #include <linux/interrupt.h> | 17 | #include <linux/interrupt.h> |
| 16 | #include <linux/module.h> | 18 | #include <linux/module.h> |
| @@ -26,8 +28,10 @@ static unsigned long idt_address(u32 lo, u32 hi) | |||
| 26 | return (lo & 0x0000FFFF) | (hi & 0xFFFF0000); | 28 | return (lo & 0x0000FFFF) | (hi & 0xFFFF0000); |
| 27 | } | 29 | } |
| 28 | 30 | ||
| 29 | /* The "type" of the interrupt handler is a 4 bit field: we only support a | 31 | /* |
| 30 | * couple of types. */ | 32 | * The "type" of the interrupt handler is a 4 bit field: we only support a |
| 33 | * couple of types. | ||
| 34 | */ | ||
| 31 | static int idt_type(u32 lo, u32 hi) | 35 | static int idt_type(u32 lo, u32 hi) |
| 32 | { | 36 | { |
| 33 | return (hi >> 8) & 0xF; | 37 | return (hi >> 8) & 0xF; |
| @@ -39,8 +43,10 @@ static bool idt_present(u32 lo, u32 hi) | |||
| 39 | return (hi & 0x8000); | 43 | return (hi & 0x8000); |
| 40 | } | 44 | } |
| 41 | 45 | ||
| 42 | /* We need a helper to "push" a value onto the Guest's stack, since that's a | 46 | /* |
| 43 | * big part of what delivering an interrupt does. */ | 47 | * We need a helper to "push" a value onto the Guest's stack, since that's a |
| 48 | * big part of what delivering an interrupt does. | ||
| 49 | */ | ||
| 44 | static void push_guest_stack(struct lg_cpu *cpu, unsigned long *gstack, u32 val) | 50 | static void push_guest_stack(struct lg_cpu *cpu, unsigned long *gstack, u32 val) |
| 45 | { | 51 | { |
| 46 | /* Stack grows upwards: move stack then write value. */ | 52 | /* Stack grows upwards: move stack then write value. */ |
| @@ -48,7 +54,8 @@ static void push_guest_stack(struct lg_cpu *cpu, unsigned long *gstack, u32 val) | |||
| 48 | lgwrite(cpu, *gstack, u32, val); | 54 | lgwrite(cpu, *gstack, u32, val); |
| 49 | } | 55 | } |
| 50 | 56 | ||
| 51 | /*H:210 The set_guest_interrupt() routine actually delivers the interrupt or | 57 | /*H:210 |
| 58 | * The set_guest_interrupt() routine actually delivers the interrupt or | ||
| 52 | * trap. The mechanics of delivering traps and interrupts to the Guest are the | 59 | * trap. The mechanics of delivering traps and interrupts to the Guest are the |
| 53 | * same, except some traps have an "error code" which gets pushed onto the | 60 | * same, except some traps have an "error code" which gets pushed onto the |
| 54 | * stack as well: the caller tells us if this is one. | 61 | * stack as well: the caller tells us if this is one. |
| @@ -59,7 +66,8 @@ static void push_guest_stack(struct lg_cpu *cpu, unsigned long *gstack, u32 val) | |||
| 59 | * | 66 | * |
| 60 | * We set up the stack just like the CPU does for a real interrupt, so it's | 67 | * We set up the stack just like the CPU does for a real interrupt, so it's |
| 61 | * identical for the Guest (and the standard "iret" instruction will undo | 68 | * identical for the Guest (and the standard "iret" instruction will undo |
| 62 | * it). */ | 69 | * it). |
| 70 | */ | ||
| 63 | static void set_guest_interrupt(struct lg_cpu *cpu, u32 lo, u32 hi, | 71 | static void set_guest_interrupt(struct lg_cpu *cpu, u32 lo, u32 hi, |
| 64 | bool has_err) | 72 | bool has_err) |
| 65 | { | 73 | { |
| @@ -67,20 +75,26 @@ static void set_guest_interrupt(struct lg_cpu *cpu, u32 lo, u32 hi, | |||
| 67 | u32 eflags, ss, irq_enable; | 75 | u32 eflags, ss, irq_enable; |
| 68 | unsigned long virtstack; | 76 | unsigned long virtstack; |
| 69 | 77 | ||
| 70 | /* There are two cases for interrupts: one where the Guest is already | 78 | /* |
| 79 | * There are two cases for interrupts: one where the Guest is already | ||
| 71 | * in the kernel, and a more complex one where the Guest is in | 80 | * in the kernel, and a more complex one where the Guest is in |
| 72 | * userspace. We check the privilege level to find out. */ | 81 | * userspace. We check the privilege level to find out. |
| 82 | */ | ||
| 73 | if ((cpu->regs->ss&0x3) != GUEST_PL) { | 83 | if ((cpu->regs->ss&0x3) != GUEST_PL) { |
| 74 | /* The Guest told us their kernel stack with the SET_STACK | 84 | /* |
| 75 | * hypercall: both the virtual address and the segment */ | 85 | * The Guest told us their kernel stack with the SET_STACK |
| 86 | * hypercall: both the virtual address and the segment. | ||
| 87 | */ | ||
| 76 | virtstack = cpu->esp1; | 88 | virtstack = cpu->esp1; |
| 77 | ss = cpu->ss1; | 89 | ss = cpu->ss1; |
| 78 | 90 | ||
| 79 | origstack = gstack = guest_pa(cpu, virtstack); | 91 | origstack = gstack = guest_pa(cpu, virtstack); |
| 80 | /* We push the old stack segment and pointer onto the new | 92 | /* |
| 93 | * We push the old stack segment and pointer onto the new | ||
| 81 | * stack: when the Guest does an "iret" back from the interrupt | 94 | * stack: when the Guest does an "iret" back from the interrupt |
| 82 | * handler the CPU will notice they're dropping privilege | 95 | * handler the CPU will notice they're dropping privilege |
| 83 | * levels and expect these here. */ | 96 | * levels and expect these here. |
| 97 | */ | ||
| 84 | push_guest_stack(cpu, &gstack, cpu->regs->ss); | 98 | push_guest_stack(cpu, &gstack, cpu->regs->ss); |
| 85 | push_guest_stack(cpu, &gstack, cpu->regs->esp); | 99 | push_guest_stack(cpu, &gstack, cpu->regs->esp); |
| 86 | } else { | 100 | } else { |
| @@ -91,18 +105,22 @@ static void set_guest_interrupt(struct lg_cpu *cpu, u32 lo, u32 hi, | |||
| 91 | origstack = gstack = guest_pa(cpu, virtstack); | 105 | origstack = gstack = guest_pa(cpu, virtstack); |
| 92 | } | 106 | } |
| 93 | 107 | ||
| 94 | /* Remember that we never let the Guest actually disable interrupts, so | 108 | /* |
| 109 | * Remember that we never let the Guest actually disable interrupts, so | ||
| 95 | * the "Interrupt Flag" bit is always set. We copy that bit from the | 110 | * the "Interrupt Flag" bit is always set. We copy that bit from the |
| 96 | * Guest's "irq_enabled" field into the eflags word: we saw the Guest | 111 | * Guest's "irq_enabled" field into the eflags word: we saw the Guest |
| 97 | * copy it back in "lguest_iret". */ | 112 | * copy it back in "lguest_iret". |
| 113 | */ | ||
| 98 | eflags = cpu->regs->eflags; | 114 | eflags = cpu->regs->eflags; |
| 99 | if (get_user(irq_enable, &cpu->lg->lguest_data->irq_enabled) == 0 | 115 | if (get_user(irq_enable, &cpu->lg->lguest_data->irq_enabled) == 0 |
| 100 | && !(irq_enable & X86_EFLAGS_IF)) | 116 | && !(irq_enable & X86_EFLAGS_IF)) |
| 101 | eflags &= ~X86_EFLAGS_IF; | 117 | eflags &= ~X86_EFLAGS_IF; |
| 102 | 118 | ||
| 103 | /* An interrupt is expected to push three things on the stack: the old | 119 | /* |
| 120 | * An interrupt is expected to push three things on the stack: the old | ||
| 104 | * "eflags" word, the old code segment, and the old instruction | 121 | * "eflags" word, the old code segment, and the old instruction |
| 105 | * pointer. */ | 122 | * pointer. |
| 123 | */ | ||
| 106 | push_guest_stack(cpu, &gstack, eflags); | 124 | push_guest_stack(cpu, &gstack, eflags); |
| 107 | push_guest_stack(cpu, &gstack, cpu->regs->cs); | 125 | push_guest_stack(cpu, &gstack, cpu->regs->cs); |
| 108 | push_guest_stack(cpu, &gstack, cpu->regs->eip); | 126 | push_guest_stack(cpu, &gstack, cpu->regs->eip); |
| @@ -111,15 +129,19 @@ static void set_guest_interrupt(struct lg_cpu *cpu, u32 lo, u32 hi, | |||
| 111 | if (has_err) | 129 | if (has_err) |
| 112 | push_guest_stack(cpu, &gstack, cpu->regs->errcode); | 130 | push_guest_stack(cpu, &gstack, cpu->regs->errcode); |
| 113 | 131 | ||
| 114 | /* Now we've pushed all the old state, we change the stack, the code | 132 | /* |
| 115 | * segment and the address to execute. */ | 133 | * Now we've pushed all the old state, we change the stack, the code |
| 134 | * segment and the address to execute. | ||
| 135 | */ | ||
| 116 | cpu->regs->ss = ss; | 136 | cpu->regs->ss = ss; |
| 117 | cpu->regs->esp = virtstack + (gstack - origstack); | 137 | cpu->regs->esp = virtstack + (gstack - origstack); |
| 118 | cpu->regs->cs = (__KERNEL_CS|GUEST_PL); | 138 | cpu->regs->cs = (__KERNEL_CS|GUEST_PL); |
| 119 | cpu->regs->eip = idt_address(lo, hi); | 139 | cpu->regs->eip = idt_address(lo, hi); |
| 120 | 140 | ||
| 121 | /* There are two kinds of interrupt handlers: 0xE is an "interrupt | 141 | /* |
| 122 | * gate" which expects interrupts to be disabled on entry. */ | 142 | * There are two kinds of interrupt handlers: 0xE is an "interrupt |
| 143 | * gate" which expects interrupts to be disabled on entry. | ||
| 144 | */ | ||
| 123 | if (idt_type(lo, hi) == 0xE) | 145 | if (idt_type(lo, hi) == 0xE) |
| 124 | if (put_user(0, &cpu->lg->lguest_data->irq_enabled)) | 146 | if (put_user(0, &cpu->lg->lguest_data->irq_enabled)) |
| 125 | kill_guest(cpu, "Disabling interrupts"); | 147 | kill_guest(cpu, "Disabling interrupts"); |
| @@ -130,7 +152,8 @@ static void set_guest_interrupt(struct lg_cpu *cpu, u32 lo, u32 hi, | |||
| 130 | * | 152 | * |
| 131 | * interrupt_pending() returns the first pending interrupt which isn't blocked | 153 | * interrupt_pending() returns the first pending interrupt which isn't blocked |
| 132 | * by the Guest. It is called before every entry to the Guest, and just before | 154 | * by the Guest. It is called before every entry to the Guest, and just before |
| 133 | * we go to sleep when the Guest has halted itself. */ | 155 | * we go to sleep when the Guest has halted itself. |
| 156 | */ | ||
| 134 | unsigned int interrupt_pending(struct lg_cpu *cpu, bool *more) | 157 | unsigned int interrupt_pending(struct lg_cpu *cpu, bool *more) |
| 135 | { | 158 | { |
| 136 | unsigned int irq; | 159 | unsigned int irq; |
| @@ -140,8 +163,10 @@ unsigned int interrupt_pending(struct lg_cpu *cpu, bool *more) | |||
| 140 | if (!cpu->lg->lguest_data) | 163 | if (!cpu->lg->lguest_data) |
| 141 | return LGUEST_IRQS; | 164 | return LGUEST_IRQS; |
| 142 | 165 | ||
| 143 | /* Take our "irqs_pending" array and remove any interrupts the Guest | 166 | /* |
| 144 | * wants blocked: the result ends up in "blk". */ | 167 | * Take our "irqs_pending" array and remove any interrupts the Guest |
| 168 | * wants blocked: the result ends up in "blk". | ||
| 169 | */ | ||
| 145 | if (copy_from_user(&blk, cpu->lg->lguest_data->blocked_interrupts, | 170 | if (copy_from_user(&blk, cpu->lg->lguest_data->blocked_interrupts, |
| 146 | sizeof(blk))) | 171 | sizeof(blk))) |
| 147 | return LGUEST_IRQS; | 172 | return LGUEST_IRQS; |
| @@ -154,16 +179,20 @@ unsigned int interrupt_pending(struct lg_cpu *cpu, bool *more) | |||
| 154 | return irq; | 179 | return irq; |
| 155 | } | 180 | } |
| 156 | 181 | ||
| 157 | /* This actually diverts the Guest to running an interrupt handler, once an | 182 | /* |
| 158 | * interrupt has been identified by interrupt_pending(). */ | 183 | * This actually diverts the Guest to running an interrupt handler, once an |
| 184 | * interrupt has been identified by interrupt_pending(). | ||
| 185 | */ | ||
| 159 | void try_deliver_interrupt(struct lg_cpu *cpu, unsigned int irq, bool more) | 186 | void try_deliver_interrupt(struct lg_cpu *cpu, unsigned int irq, bool more) |
| 160 | { | 187 | { |
| 161 | struct desc_struct *idt; | 188 | struct desc_struct *idt; |
| 162 | 189 | ||
| 163 | BUG_ON(irq >= LGUEST_IRQS); | 190 | BUG_ON(irq >= LGUEST_IRQS); |
| 164 | 191 | ||
| 165 | /* They may be in the middle of an iret, where they asked us never to | 192 | /* |
| 166 | * deliver interrupts. */ | 193 | * They may be in the middle of an iret, where they asked us never to |
| 194 | * deliver interrupts. | ||
| 195 | */ | ||
| 167 | if (cpu->regs->eip >= cpu->lg->noirq_start && | 196 | if (cpu->regs->eip >= cpu->lg->noirq_start && |
| 168 | (cpu->regs->eip < cpu->lg->noirq_end)) | 197 | (cpu->regs->eip < cpu->lg->noirq_end)) |
| 169 | return; | 198 | return; |
| @@ -187,29 +216,37 @@ void try_deliver_interrupt(struct lg_cpu *cpu, unsigned int irq, bool more) | |||
| 187 | } | 216 | } |
| 188 | } | 217 | } |
| 189 | 218 | ||
| 190 | /* Look at the IDT entry the Guest gave us for this interrupt. The | 219 | /* |
| 220 | * Look at the IDT entry the Guest gave us for this interrupt. The | ||
| 191 | * first 32 (FIRST_EXTERNAL_VECTOR) entries are for traps, so we skip | 221 | * first 32 (FIRST_EXTERNAL_VECTOR) entries are for traps, so we skip |
| 192 | * over them. */ | 222 | * over them. |
| 223 | */ | ||
| 193 | idt = &cpu->arch.idt[FIRST_EXTERNAL_VECTOR+irq]; | 224 | idt = &cpu->arch.idt[FIRST_EXTERNAL_VECTOR+irq]; |
| 194 | /* If they don't have a handler (yet?), we just ignore it */ | 225 | /* If they don't have a handler (yet?), we just ignore it */ |
| 195 | if (idt_present(idt->a, idt->b)) { | 226 | if (idt_present(idt->a, idt->b)) { |
| 196 | /* OK, mark it no longer pending and deliver it. */ | 227 | /* OK, mark it no longer pending and deliver it. */ |
| 197 | clear_bit(irq, cpu->irqs_pending); | 228 | clear_bit(irq, cpu->irqs_pending); |
| 198 | /* set_guest_interrupt() takes the interrupt descriptor and a | 229 | /* |
| 230 | * set_guest_interrupt() takes the interrupt descriptor and a | ||
| 199 | * flag to say whether this interrupt pushes an error code onto | 231 | * flag to say whether this interrupt pushes an error code onto |
| 200 | * the stack as well: virtual interrupts never do. */ | 232 | * the stack as well: virtual interrupts never do. |
| 233 | */ | ||
| 201 | set_guest_interrupt(cpu, idt->a, idt->b, false); | 234 | set_guest_interrupt(cpu, idt->a, idt->b, false); |
| 202 | } | 235 | } |
| 203 | 236 | ||
| 204 | /* Every time we deliver an interrupt, we update the timestamp in the | 237 | /* |
| 238 | * Every time we deliver an interrupt, we update the timestamp in the | ||
| 205 | * Guest's lguest_data struct. It would be better for the Guest if we | 239 | * Guest's lguest_data struct. It would be better for the Guest if we |
| 206 | * did this more often, but it can actually be quite slow: doing it | 240 | * did this more often, but it can actually be quite slow: doing it |
| 207 | * here is a compromise which means at least it gets updated every | 241 | * here is a compromise which means at least it gets updated every |
| 208 | * timer interrupt. */ | 242 | * timer interrupt. |
| 243 | */ | ||
| 209 | write_timestamp(cpu); | 244 | write_timestamp(cpu); |
| 210 | 245 | ||
| 211 | /* If there are no other interrupts we want to deliver, clear | 246 | /* |
| 212 | * the pending flag. */ | 247 | * If there are no other interrupts we want to deliver, clear |
| 248 | * the pending flag. | ||
| 249 | */ | ||
| 213 | if (!more) | 250 | if (!more) |
| 214 | put_user(0, &cpu->lg->lguest_data->irq_pending); | 251 | put_user(0, &cpu->lg->lguest_data->irq_pending); |
| 215 | } | 252 | } |
| @@ -217,24 +254,29 @@ void try_deliver_interrupt(struct lg_cpu *cpu, unsigned int irq, bool more) | |||
| 217 | /* And this is the routine when we want to set an interrupt for the Guest. */ | 254 | /* And this is the routine when we want to set an interrupt for the Guest. */ |
| 218 | void set_interrupt(struct lg_cpu *cpu, unsigned int irq) | 255 | void set_interrupt(struct lg_cpu *cpu, unsigned int irq) |
| 219 | { | 256 | { |
| 220 | /* Next time the Guest runs, the core code will see if it can deliver | 257 | /* |
| 221 | * this interrupt. */ | 258 | * Next time the Guest runs, the core code will see if it can deliver |
| 259 | * this interrupt. | ||
| 260 | */ | ||
| 222 | set_bit(irq, cpu->irqs_pending); | 261 | set_bit(irq, cpu->irqs_pending); |
| 223 | 262 | ||
| 224 | /* Make sure it sees it; it might be asleep (eg. halted), or | 263 | /* |
| 225 | * running the Guest right now, in which case kick_process() | 264 | * Make sure it sees it; it might be asleep (eg. halted), or running |
| 226 | * will knock it out. */ | 265 | * the Guest right now, in which case kick_process() will knock it out. |
| 266 | */ | ||
| 227 | if (!wake_up_process(cpu->tsk)) | 267 | if (!wake_up_process(cpu->tsk)) |
| 228 | kick_process(cpu->tsk); | 268 | kick_process(cpu->tsk); |
| 229 | } | 269 | } |
| 230 | /*:*/ | 270 | /*:*/ |
| 231 | 271 | ||
| 232 | /* Linux uses trap 128 for system calls. Plan9 uses 64, and Ron Minnich sent | 272 | /* |
| 273 | * Linux uses trap 128 for system calls. Plan9 uses 64, and Ron Minnich sent | ||
| 233 | * me a patch, so we support that too. It'd be a big step for lguest if half | 274 | * me a patch, so we support that too. It'd be a big step for lguest if half |
| 234 | * the Plan 9 user base were to start using it. | 275 | * the Plan 9 user base were to start using it. |
| 235 | * | 276 | * |
| 236 | * Actually now I think of it, it's possible that Ron *is* half the Plan 9 | 277 | * Actually now I think of it, it's possible that Ron *is* half the Plan 9 |
| 237 | * userbase. Oh well. */ | 278 | * userbase. Oh well. |
| 279 | */ | ||
| 238 | static bool could_be_syscall(unsigned int num) | 280 | static bool could_be_syscall(unsigned int num) |
| 239 | { | 281 | { |
| 240 | /* Normal Linux SYSCALL_VECTOR or reserved vector? */ | 282 | /* Normal Linux SYSCALL_VECTOR or reserved vector? */ |
| @@ -274,9 +316,11 @@ void free_interrupts(void) | |||
| 274 | clear_bit(syscall_vector, used_vectors); | 316 | clear_bit(syscall_vector, used_vectors); |
| 275 | } | 317 | } |
| 276 | 318 | ||
| 277 | /*H:220 Now we've got the routines to deliver interrupts, delivering traps like | 319 | /*H:220 |
| 320 | * Now we've got the routines to deliver interrupts, delivering traps like | ||
| 278 | * page fault is easy. The only trick is that Intel decided that some traps | 321 | * page fault is easy. The only trick is that Intel decided that some traps |
| 279 | * should have error codes: */ | 322 | * should have error codes: |
| 323 | */ | ||
| 280 | static bool has_err(unsigned int trap) | 324 | static bool has_err(unsigned int trap) |
| 281 | { | 325 | { |
| 282 | return (trap == 8 || (trap >= 10 && trap <= 14) || trap == 17); | 326 | return (trap == 8 || (trap >= 10 && trap <= 14) || trap == 17); |
| @@ -285,13 +329,17 @@ static bool has_err(unsigned int trap) | |||
| 285 | /* deliver_trap() returns true if it could deliver the trap. */ | 329 | /* deliver_trap() returns true if it could deliver the trap. */ |
| 286 | bool deliver_trap(struct lg_cpu *cpu, unsigned int num) | 330 | bool deliver_trap(struct lg_cpu *cpu, unsigned int num) |
| 287 | { | 331 | { |
| 288 | /* Trap numbers are always 8 bit, but we set an impossible trap number | 332 | /* |
| 289 | * for traps inside the Switcher, so check that here. */ | 333 | * Trap numbers are always 8 bit, but we set an impossible trap number |
| 334 | * for traps inside the Switcher, so check that here. | ||
| 335 | */ | ||
| 290 | if (num >= ARRAY_SIZE(cpu->arch.idt)) | 336 | if (num >= ARRAY_SIZE(cpu->arch.idt)) |
| 291 | return false; | 337 | return false; |
| 292 | 338 | ||
| 293 | /* Early on the Guest hasn't set the IDT entries (or maybe it put a | 339 | /* |
| 294 | * bogus one in): if we fail here, the Guest will be killed. */ | 340 | * Early on the Guest hasn't set the IDT entries (or maybe it put a |
| 341 | * bogus one in): if we fail here, the Guest will be killed. | ||
| 342 | */ | ||
| 295 | if (!idt_present(cpu->arch.idt[num].a, cpu->arch.idt[num].b)) | 343 | if (!idt_present(cpu->arch.idt[num].a, cpu->arch.idt[num].b)) |
| 296 | return false; | 344 | return false; |
| 297 | set_guest_interrupt(cpu, cpu->arch.idt[num].a, | 345 | set_guest_interrupt(cpu, cpu->arch.idt[num].a, |
| @@ -299,7 +347,8 @@ bool deliver_trap(struct lg_cpu *cpu, unsigned int num) | |||
| 299 | return true; | 347 | return true; |
| 300 | } | 348 | } |
| 301 | 349 | ||
| 302 | /*H:250 Here's the hard part: returning to the Host every time a trap happens | 350 | /*H:250 |
| 351 | * Here's the hard part: returning to the Host every time a trap happens | ||
| 303 | * and then calling deliver_trap() and re-entering the Guest is slow. | 352 | * and then calling deliver_trap() and re-entering the Guest is slow. |
| 304 | * Particularly because Guest userspace system calls are traps (usually trap | 353 | * Particularly because Guest userspace system calls are traps (usually trap |
| 305 | * 128). | 354 | * 128). |
| @@ -311,69 +360,87 @@ bool deliver_trap(struct lg_cpu *cpu, unsigned int num) | |||
| 311 | * the other hypervisors would beat it up at lunchtime. | 360 | * the other hypervisors would beat it up at lunchtime. |
| 312 | * | 361 | * |
| 313 | * This routine indicates if a particular trap number could be delivered | 362 | * This routine indicates if a particular trap number could be delivered |
| 314 | * directly. */ | 363 | * directly. |
| 364 | */ | ||
| 315 | static bool direct_trap(unsigned int num) | 365 | static bool direct_trap(unsigned int num) |
| 316 | { | 366 | { |
| 317 | /* Hardware interrupts don't go to the Guest at all (except system | 367 | /* |
| 318 | * call). */ | 368 | * Hardware interrupts don't go to the Guest at all (except system |
| 369 | * call). | ||
| 370 | */ | ||
| 319 | if (num >= FIRST_EXTERNAL_VECTOR && !could_be_syscall(num)) | 371 | if (num >= FIRST_EXTERNAL_VECTOR && !could_be_syscall(num)) |
| 320 | return false; | 372 | return false; |
| 321 | 373 | ||
| 322 | /* The Host needs to see page faults (for shadow paging and to save the | 374 | /* |
| 375 | * The Host needs to see page faults (for shadow paging and to save the | ||
| 323 | * fault address), general protection faults (in/out emulation) and | 376 | * fault address), general protection faults (in/out emulation) and |
| 324 | * device not available (TS handling), invalid opcode fault (kvm hcall), | 377 | * device not available (TS handling), invalid opcode fault (kvm hcall), |
| 325 | * and of course, the hypercall trap. */ | 378 | * and of course, the hypercall trap. |
| 379 | */ | ||
| 326 | return num != 14 && num != 13 && num != 7 && | 380 | return num != 14 && num != 13 && num != 7 && |
| 327 | num != 6 && num != LGUEST_TRAP_ENTRY; | 381 | num != 6 && num != LGUEST_TRAP_ENTRY; |
| 328 | } | 382 | } |
| 329 | /*:*/ | 383 | /*:*/ |
| 330 | 384 | ||
| 331 | /*M:005 The Guest has the ability to turn its interrupt gates into trap gates, | 385 | /*M:005 |
| 386 | * The Guest has the ability to turn its interrupt gates into trap gates, | ||
| 332 | * if it is careful. The Host will let trap gates can go directly to the | 387 | * if it is careful. The Host will let trap gates can go directly to the |
| 333 | * Guest, but the Guest needs the interrupts atomically disabled for an | 388 | * Guest, but the Guest needs the interrupts atomically disabled for an |
| 334 | * interrupt gate. It can do this by pointing the trap gate at instructions | 389 | * interrupt gate. It can do this by pointing the trap gate at instructions |
| 335 | * within noirq_start and noirq_end, where it can safely disable interrupts. */ | 390 | * within noirq_start and noirq_end, where it can safely disable interrupts. |
| 391 | */ | ||
| 336 | 392 | ||
| 337 | /*M:006 The Guests do not use the sysenter (fast system call) instruction, | 393 | /*M:006 |
| 394 | * The Guests do not use the sysenter (fast system call) instruction, | ||
| 338 | * because it's hardcoded to enter privilege level 0 and so can't go direct. | 395 | * because it's hardcoded to enter privilege level 0 and so can't go direct. |
| 339 | * It's about twice as fast as the older "int 0x80" system call, so it might | 396 | * It's about twice as fast as the older "int 0x80" system call, so it might |
| 340 | * still be worthwhile to handle it in the Switcher and lcall down to the | 397 | * still be worthwhile to handle it in the Switcher and lcall down to the |
| 341 | * Guest. The sysenter semantics are hairy tho: search for that keyword in | 398 | * Guest. The sysenter semantics are hairy tho: search for that keyword in |
| 342 | * entry.S :*/ | 399 | * entry.S |
| 400 | :*/ | ||
| 343 | 401 | ||
| 344 | /*H:260 When we make traps go directly into the Guest, we need to make sure | 402 | /*H:260 |
| 403 | * When we make traps go directly into the Guest, we need to make sure | ||
| 345 | * the kernel stack is valid (ie. mapped in the page tables). Otherwise, the | 404 | * the kernel stack is valid (ie. mapped in the page tables). Otherwise, the |
| 346 | * CPU trying to deliver the trap will fault while trying to push the interrupt | 405 | * CPU trying to deliver the trap will fault while trying to push the interrupt |
| 347 | * words on the stack: this is called a double fault, and it forces us to kill | 406 | * words on the stack: this is called a double fault, and it forces us to kill |
| 348 | * the Guest. | 407 | * the Guest. |
| 349 | * | 408 | * |
| 350 | * Which is deeply unfair, because (literally!) it wasn't the Guests' fault. */ | 409 | * Which is deeply unfair, because (literally!) it wasn't the Guests' fault. |
| 410 | */ | ||
| 351 | void pin_stack_pages(struct lg_cpu *cpu) | 411 | void pin_stack_pages(struct lg_cpu *cpu) |
| 352 | { | 412 | { |
| 353 | unsigned int i; | 413 | unsigned int i; |
| 354 | 414 | ||
| 355 | /* Depending on the CONFIG_4KSTACKS option, the Guest can have one or | 415 | /* |
| 356 | * two pages of stack space. */ | 416 | * Depending on the CONFIG_4KSTACKS option, the Guest can have one or |
| 417 | * two pages of stack space. | ||
| 418 | */ | ||
| 357 | for (i = 0; i < cpu->lg->stack_pages; i++) | 419 | for (i = 0; i < cpu->lg->stack_pages; i++) |
| 358 | /* The stack grows *upwards*, so the address we're given is the | 420 | /* |
| 421 | * The stack grows *upwards*, so the address we're given is the | ||
| 359 | * start of the page after the kernel stack. Subtract one to | 422 | * start of the page after the kernel stack. Subtract one to |
| 360 | * get back onto the first stack page, and keep subtracting to | 423 | * get back onto the first stack page, and keep subtracting to |
| 361 | * get to the rest of the stack pages. */ | 424 | * get to the rest of the stack pages. |
| 425 | */ | ||
| 362 | pin_page(cpu, cpu->esp1 - 1 - i * PAGE_SIZE); | 426 | pin_page(cpu, cpu->esp1 - 1 - i * PAGE_SIZE); |
| 363 | } | 427 | } |
| 364 | 428 | ||
| 365 | /* Direct traps also mean that we need to know whenever the Guest wants to use | 429 | /* |
| 430 | * Direct traps also mean that we need to know whenever the Guest wants to use | ||
| 366 | * a different kernel stack, so we can change the IDT entries to use that | 431 | * a different kernel stack, so we can change the IDT entries to use that |
| 367 | * stack. The IDT entries expect a virtual address, so unlike most addresses | 432 | * stack. The IDT entries expect a virtual address, so unlike most addresses |
| 368 | * the Guest gives us, the "esp" (stack pointer) value here is virtual, not | 433 | * the Guest gives us, the "esp" (stack pointer) value here is virtual, not |
| 369 | * physical. | 434 | * physical. |
| 370 | * | 435 | * |
| 371 | * In Linux each process has its own kernel stack, so this happens a lot: we | 436 | * In Linux each process has its own kernel stack, so this happens a lot: we |
| 372 | * change stacks on each context switch. */ | 437 | * change stacks on each context switch. |
| 438 | */ | ||
| 373 | void guest_set_stack(struct lg_cpu *cpu, u32 seg, u32 esp, unsigned int pages) | 439 | void guest_set_stack(struct lg_cpu *cpu, u32 seg, u32 esp, unsigned int pages) |
| 374 | { | 440 | { |
| 375 | /* You are not allowed have a stack segment with privilege level 0: bad | 441 | /* |
| 376 | * Guest! */ | 442 | * You're not allowed a stack segment with privilege level 0: bad Guest! |
| 443 | */ | ||
| 377 | if ((seg & 0x3) != GUEST_PL) | 444 | if ((seg & 0x3) != GUEST_PL) |
| 378 | kill_guest(cpu, "bad stack segment %i", seg); | 445 | kill_guest(cpu, "bad stack segment %i", seg); |
| 379 | /* We only expect one or two stack pages. */ | 446 | /* We only expect one or two stack pages. */ |
| @@ -387,11 +454,15 @@ void guest_set_stack(struct lg_cpu *cpu, u32 seg, u32 esp, unsigned int pages) | |||
| 387 | pin_stack_pages(cpu); | 454 | pin_stack_pages(cpu); |
| 388 | } | 455 | } |
| 389 | 456 | ||
| 390 | /* All this reference to mapping stacks leads us neatly into the other complex | 457 | /* |
| 391 | * part of the Host: page table handling. */ | 458 | * All this reference to mapping stacks leads us neatly into the other complex |
| 459 | * part of the Host: page table handling. | ||
| 460 | */ | ||
| 392 | 461 | ||
| 393 | /*H:235 This is the routine which actually checks the Guest's IDT entry and | 462 | /*H:235 |
| 394 | * transfers it into the entry in "struct lguest": */ | 463 | * This is the routine which actually checks the Guest's IDT entry and |
| 464 | * transfers it into the entry in "struct lguest": | ||
| 465 | */ | ||
| 395 | static void set_trap(struct lg_cpu *cpu, struct desc_struct *trap, | 466 | static void set_trap(struct lg_cpu *cpu, struct desc_struct *trap, |
| 396 | unsigned int num, u32 lo, u32 hi) | 467 | unsigned int num, u32 lo, u32 hi) |
| 397 | { | 468 | { |
| @@ -407,30 +478,38 @@ static void set_trap(struct lg_cpu *cpu, struct desc_struct *trap, | |||
| 407 | if (type != 0xE && type != 0xF) | 478 | if (type != 0xE && type != 0xF) |
| 408 | kill_guest(cpu, "bad IDT type %i", type); | 479 | kill_guest(cpu, "bad IDT type %i", type); |
| 409 | 480 | ||
| 410 | /* We only copy the handler address, present bit, privilege level and | 481 | /* |
| 482 | * We only copy the handler address, present bit, privilege level and | ||
| 411 | * type. The privilege level controls where the trap can be triggered | 483 | * type. The privilege level controls where the trap can be triggered |
| 412 | * manually with an "int" instruction. This is usually GUEST_PL, | 484 | * manually with an "int" instruction. This is usually GUEST_PL, |
| 413 | * except for system calls which userspace can use. */ | 485 | * except for system calls which userspace can use. |
| 486 | */ | ||
| 414 | trap->a = ((__KERNEL_CS|GUEST_PL)<<16) | (lo&0x0000FFFF); | 487 | trap->a = ((__KERNEL_CS|GUEST_PL)<<16) | (lo&0x0000FFFF); |
| 415 | trap->b = (hi&0xFFFFEF00); | 488 | trap->b = (hi&0xFFFFEF00); |
| 416 | } | 489 | } |
| 417 | 490 | ||
| 418 | /*H:230 While we're here, dealing with delivering traps and interrupts to the | 491 | /*H:230 |
| 492 | * While we're here, dealing with delivering traps and interrupts to the | ||
| 419 | * Guest, we might as well complete the picture: how the Guest tells us where | 493 | * Guest, we might as well complete the picture: how the Guest tells us where |
| 420 | * it wants them to go. This would be simple, except making traps fast | 494 | * it wants them to go. This would be simple, except making traps fast |
| 421 | * requires some tricks. | 495 | * requires some tricks. |
| 422 | * | 496 | * |
| 423 | * We saw the Guest setting Interrupt Descriptor Table (IDT) entries with the | 497 | * We saw the Guest setting Interrupt Descriptor Table (IDT) entries with the |
| 424 | * LHCALL_LOAD_IDT_ENTRY hypercall before: that comes here. */ | 498 | * LHCALL_LOAD_IDT_ENTRY hypercall before: that comes here. |
| 499 | */ | ||
| 425 | void load_guest_idt_entry(struct lg_cpu *cpu, unsigned int num, u32 lo, u32 hi) | 500 | void load_guest_idt_entry(struct lg_cpu *cpu, unsigned int num, u32 lo, u32 hi) |
| 426 | { | 501 | { |
| 427 | /* Guest never handles: NMI, doublefault, spurious interrupt or | 502 | /* |
| 428 | * hypercall. We ignore when it tries to set them. */ | 503 | * Guest never handles: NMI, doublefault, spurious interrupt or |
| 504 | * hypercall. We ignore when it tries to set them. | ||
| 505 | */ | ||
| 429 | if (num == 2 || num == 8 || num == 15 || num == LGUEST_TRAP_ENTRY) | 506 | if (num == 2 || num == 8 || num == 15 || num == LGUEST_TRAP_ENTRY) |
| 430 | return; | 507 | return; |
| 431 | 508 | ||
| 432 | /* Mark the IDT as changed: next time the Guest runs we'll know we have | 509 | /* |
| 433 | * to copy this again. */ | 510 | * Mark the IDT as changed: next time the Guest runs we'll know we have |
| 511 | * to copy this again. | ||
| 512 | */ | ||
| 434 | cpu->changed |= CHANGED_IDT; | 513 | cpu->changed |= CHANGED_IDT; |
| 435 | 514 | ||
| 436 | /* Check that the Guest doesn't try to step outside the bounds. */ | 515 | /* Check that the Guest doesn't try to step outside the bounds. */ |
| @@ -440,9 +519,11 @@ void load_guest_idt_entry(struct lg_cpu *cpu, unsigned int num, u32 lo, u32 hi) | |||
| 440 | set_trap(cpu, &cpu->arch.idt[num], num, lo, hi); | 519 | set_trap(cpu, &cpu->arch.idt[num], num, lo, hi); |
| 441 | } | 520 | } |
| 442 | 521 | ||
| 443 | /* The default entry for each interrupt points into the Switcher routines which | 522 | /* |
| 523 | * The default entry for each interrupt points into the Switcher routines which | ||
| 444 | * simply return to the Host. The run_guest() loop will then call | 524 | * simply return to the Host. The run_guest() loop will then call |
| 445 | * deliver_trap() to bounce it back into the Guest. */ | 525 | * deliver_trap() to bounce it back into the Guest. |
| 526 | */ | ||
| 446 | static void default_idt_entry(struct desc_struct *idt, | 527 | static void default_idt_entry(struct desc_struct *idt, |
| 447 | int trap, | 528 | int trap, |
| 448 | const unsigned long handler, | 529 | const unsigned long handler, |
| @@ -451,13 +532,17 @@ static void default_idt_entry(struct desc_struct *idt, | |||
| 451 | /* A present interrupt gate. */ | 532 | /* A present interrupt gate. */ |
| 452 | u32 flags = 0x8e00; | 533 | u32 flags = 0x8e00; |
| 453 | 534 | ||
| 454 | /* Set the privilege level on the entry for the hypercall: this allows | 535 | /* |
| 455 | * the Guest to use the "int" instruction to trigger it. */ | 536 | * Set the privilege level on the entry for the hypercall: this allows |
| 537 | * the Guest to use the "int" instruction to trigger it. | ||
| 538 | */ | ||
| 456 | if (trap == LGUEST_TRAP_ENTRY) | 539 | if (trap == LGUEST_TRAP_ENTRY) |
| 457 | flags |= (GUEST_PL << 13); | 540 | flags |= (GUEST_PL << 13); |
| 458 | else if (base) | 541 | else if (base) |
| 459 | /* Copy priv. level from what Guest asked for. This allows | 542 | /* |
| 460 | * debug (int 3) traps from Guest userspace, for example. */ | 543 | * Copy privilege level from what Guest asked for. This allows |
| 544 | * debug (int 3) traps from Guest userspace, for example. | ||
| 545 | */ | ||
| 461 | flags |= (base->b & 0x6000); | 546 | flags |= (base->b & 0x6000); |
| 462 | 547 | ||
| 463 | /* Now pack it into the IDT entry in its weird format. */ | 548 | /* Now pack it into the IDT entry in its weird format. */ |
| @@ -475,16 +560,20 @@ void setup_default_idt_entries(struct lguest_ro_state *state, | |||
| 475 | default_idt_entry(&state->guest_idt[i], i, def[i], NULL); | 560 | default_idt_entry(&state->guest_idt[i], i, def[i], NULL); |
| 476 | } | 561 | } |
| 477 | 562 | ||
| 478 | /*H:240 We don't use the IDT entries in the "struct lguest" directly, instead | 563 | /*H:240 |
| 564 | * We don't use the IDT entries in the "struct lguest" directly, instead | ||
| 479 | * we copy them into the IDT which we've set up for Guests on this CPU, just | 565 | * we copy them into the IDT which we've set up for Guests on this CPU, just |
| 480 | * before we run the Guest. This routine does that copy. */ | 566 | * before we run the Guest. This routine does that copy. |
| 567 | */ | ||
| 481 | void copy_traps(const struct lg_cpu *cpu, struct desc_struct *idt, | 568 | void copy_traps(const struct lg_cpu *cpu, struct desc_struct *idt, |
| 482 | const unsigned long *def) | 569 | const unsigned long *def) |
| 483 | { | 570 | { |
| 484 | unsigned int i; | 571 | unsigned int i; |
| 485 | 572 | ||
| 486 | /* We can simply copy the direct traps, otherwise we use the default | 573 | /* |
| 487 | * ones in the Switcher: they will return to the Host. */ | 574 | * We can simply copy the direct traps, otherwise we use the default |
| 575 | * ones in the Switcher: they will return to the Host. | ||
| 576 | */ | ||
| 488 | for (i = 0; i < ARRAY_SIZE(cpu->arch.idt); i++) { | 577 | for (i = 0; i < ARRAY_SIZE(cpu->arch.idt); i++) { |
| 489 | const struct desc_struct *gidt = &cpu->arch.idt[i]; | 578 | const struct desc_struct *gidt = &cpu->arch.idt[i]; |
| 490 | 579 | ||
| @@ -492,14 +581,16 @@ void copy_traps(const struct lg_cpu *cpu, struct desc_struct *idt, | |||
| 492 | if (!direct_trap(i)) | 581 | if (!direct_trap(i)) |
| 493 | continue; | 582 | continue; |
| 494 | 583 | ||
| 495 | /* Only trap gates (type 15) can go direct to the Guest. | 584 | /* |
| 585 | * Only trap gates (type 15) can go direct to the Guest. | ||
| 496 | * Interrupt gates (type 14) disable interrupts as they are | 586 | * Interrupt gates (type 14) disable interrupts as they are |
| 497 | * entered, which we never let the Guest do. Not present | 587 | * entered, which we never let the Guest do. Not present |
| 498 | * entries (type 0x0) also can't go direct, of course. | 588 | * entries (type 0x0) also can't go direct, of course. |
| 499 | * | 589 | * |
| 500 | * If it can't go direct, we still need to copy the priv. level: | 590 | * If it can't go direct, we still need to copy the priv. level: |
| 501 | * they might want to give userspace access to a software | 591 | * they might want to give userspace access to a software |
| 502 | * interrupt. */ | 592 | * interrupt. |
| 593 | */ | ||
| 503 | if (idt_type(gidt->a, gidt->b) == 0xF) | 594 | if (idt_type(gidt->a, gidt->b) == 0xF) |
| 504 | idt[i] = *gidt; | 595 | idt[i] = *gidt; |
| 505 | else | 596 | else |
| @@ -518,7 +609,8 @@ void copy_traps(const struct lg_cpu *cpu, struct desc_struct *idt, | |||
| 518 | * the next timer interrupt (in nanoseconds). We use the high-resolution timer | 609 | * the next timer interrupt (in nanoseconds). We use the high-resolution timer |
| 519 | * infrastructure to set a callback at that time. | 610 | * infrastructure to set a callback at that time. |
| 520 | * | 611 | * |
| 521 | * 0 means "turn off the clock". */ | 612 | * 0 means "turn off the clock". |
| 613 | */ | ||
| 522 | void guest_set_clockevent(struct lg_cpu *cpu, unsigned long delta) | 614 | void guest_set_clockevent(struct lg_cpu *cpu, unsigned long delta) |
| 523 | { | 615 | { |
| 524 | ktime_t expires; | 616 | ktime_t expires; |
| @@ -529,9 +621,11 @@ void guest_set_clockevent(struct lg_cpu *cpu, unsigned long delta) | |||
| 529 | return; | 621 | return; |
| 530 | } | 622 | } |
| 531 | 623 | ||
| 532 | /* We use wallclock time here, so the Guest might not be running for | 624 | /* |
| 625 | * We use wallclock time here, so the Guest might not be running for | ||
| 533 | * all the time between now and the timer interrupt it asked for. This | 626 | * all the time between now and the timer interrupt it asked for. This |
| 534 | * is almost always the right thing to do. */ | 627 | * is almost always the right thing to do. |
| 628 | */ | ||
| 535 | expires = ktime_add_ns(ktime_get_real(), delta); | 629 | expires = ktime_add_ns(ktime_get_real(), delta); |
| 536 | hrtimer_start(&cpu->hrt, expires, HRTIMER_MODE_ABS); | 630 | hrtimer_start(&cpu->hrt, expires, HRTIMER_MODE_ABS); |
| 537 | } | 631 | } |
diff --git a/drivers/lguest/lg.h b/drivers/lguest/lg.h index 01c591923793..bc28745d05af 100644 --- a/drivers/lguest/lg.h +++ b/drivers/lguest/lg.h | |||
| @@ -16,15 +16,13 @@ | |||
| 16 | void free_pagetables(void); | 16 | void free_pagetables(void); |
| 17 | int init_pagetables(struct page **switcher_page, unsigned int pages); | 17 | int init_pagetables(struct page **switcher_page, unsigned int pages); |
| 18 | 18 | ||
| 19 | struct pgdir | 19 | struct pgdir { |
| 20 | { | ||
| 21 | unsigned long gpgdir; | 20 | unsigned long gpgdir; |
| 22 | pgd_t *pgdir; | 21 | pgd_t *pgdir; |
| 23 | }; | 22 | }; |
| 24 | 23 | ||
| 25 | /* We have two pages shared with guests, per cpu. */ | 24 | /* We have two pages shared with guests, per cpu. */ |
| 26 | struct lguest_pages | 25 | struct lguest_pages { |
| 27 | { | ||
| 28 | /* This is the stack page mapped rw in guest */ | 26 | /* This is the stack page mapped rw in guest */ |
| 29 | char spare[PAGE_SIZE - sizeof(struct lguest_regs)]; | 27 | char spare[PAGE_SIZE - sizeof(struct lguest_regs)]; |
| 30 | struct lguest_regs regs; | 28 | struct lguest_regs regs; |
| @@ -54,13 +52,13 @@ struct lg_cpu { | |||
| 54 | 52 | ||
| 55 | unsigned long pending_notify; /* pfn from LHCALL_NOTIFY */ | 53 | unsigned long pending_notify; /* pfn from LHCALL_NOTIFY */ |
| 56 | 54 | ||
| 57 | /* At end of a page shared mapped over lguest_pages in guest. */ | 55 | /* At end of a page shared mapped over lguest_pages in guest. */ |
| 58 | unsigned long regs_page; | 56 | unsigned long regs_page; |
| 59 | struct lguest_regs *regs; | 57 | struct lguest_regs *regs; |
| 60 | 58 | ||
| 61 | struct lguest_pages *last_pages; | 59 | struct lguest_pages *last_pages; |
| 62 | 60 | ||
| 63 | int cpu_pgd; /* which pgd this cpu is currently using */ | 61 | int cpu_pgd; /* Which pgd this cpu is currently using */ |
| 64 | 62 | ||
| 65 | /* If a hypercall was asked for, this points to the arguments. */ | 63 | /* If a hypercall was asked for, this points to the arguments. */ |
| 66 | struct hcall_args *hcall; | 64 | struct hcall_args *hcall; |
| @@ -89,15 +87,17 @@ struct lg_eventfd_map { | |||
| 89 | }; | 87 | }; |
| 90 | 88 | ||
| 91 | /* The private info the thread maintains about the guest. */ | 89 | /* The private info the thread maintains about the guest. */ |
| 92 | struct lguest | 90 | struct lguest { |
| 93 | { | ||
| 94 | struct lguest_data __user *lguest_data; | 91 | struct lguest_data __user *lguest_data; |
| 95 | struct lg_cpu cpus[NR_CPUS]; | 92 | struct lg_cpu cpus[NR_CPUS]; |
| 96 | unsigned int nr_cpus; | 93 | unsigned int nr_cpus; |
| 97 | 94 | ||
| 98 | u32 pfn_limit; | 95 | u32 pfn_limit; |
| 99 | /* This provides the offset to the base of guest-physical | 96 | |
| 100 | * memory in the Launcher. */ | 97 | /* |
| 98 | * This provides the offset to the base of guest-physical memory in the | ||
| 99 | * Launcher. | ||
| 100 | */ | ||
| 101 | void __user *mem_base; | 101 | void __user *mem_base; |
| 102 | unsigned long kernel_address; | 102 | unsigned long kernel_address; |
| 103 | 103 | ||
| @@ -122,11 +122,13 @@ bool lguest_address_ok(const struct lguest *lg, | |||
| 122 | void __lgread(struct lg_cpu *, void *, unsigned long, unsigned); | 122 | void __lgread(struct lg_cpu *, void *, unsigned long, unsigned); |
| 123 | void __lgwrite(struct lg_cpu *, unsigned long, const void *, unsigned); | 123 | void __lgwrite(struct lg_cpu *, unsigned long, const void *, unsigned); |
| 124 | 124 | ||
| 125 | /*H:035 Using memory-copy operations like that is usually inconvient, so we | 125 | /*H:035 |
| 126 | * Using memory-copy operations like that is usually inconvient, so we | ||
| 126 | * have the following helper macros which read and write a specific type (often | 127 | * have the following helper macros which read and write a specific type (often |
| 127 | * an unsigned long). | 128 | * an unsigned long). |
| 128 | * | 129 | * |
| 129 | * This reads into a variable of the given type then returns that. */ | 130 | * This reads into a variable of the given type then returns that. |
| 131 | */ | ||
| 130 | #define lgread(cpu, addr, type) \ | 132 | #define lgread(cpu, addr, type) \ |
| 131 | ({ type _v; __lgread((cpu), &_v, (addr), sizeof(_v)); _v; }) | 133 | ({ type _v; __lgread((cpu), &_v, (addr), sizeof(_v)); _v; }) |
| 132 | 134 | ||
| @@ -140,9 +142,11 @@ void __lgwrite(struct lg_cpu *, unsigned long, const void *, unsigned); | |||
| 140 | 142 | ||
| 141 | int run_guest(struct lg_cpu *cpu, unsigned long __user *user); | 143 | int run_guest(struct lg_cpu *cpu, unsigned long __user *user); |
| 142 | 144 | ||
| 143 | /* Helper macros to obtain the first 12 or the last 20 bits, this is only the | 145 | /* |
| 146 | * Helper macros to obtain the first 12 or the last 20 bits, this is only the | ||
| 144 | * first step in the migration to the kernel types. pte_pfn is already defined | 147 | * first step in the migration to the kernel types. pte_pfn is already defined |
| 145 | * in the kernel. */ | 148 | * in the kernel. |
| 149 | */ | ||
| 146 | #define pgd_flags(x) (pgd_val(x) & ~PAGE_MASK) | 150 | #define pgd_flags(x) (pgd_val(x) & ~PAGE_MASK) |
| 147 | #define pgd_pfn(x) (pgd_val(x) >> PAGE_SHIFT) | 151 | #define pgd_pfn(x) (pgd_val(x) >> PAGE_SHIFT) |
| 148 | #define pmd_flags(x) (pmd_val(x) & ~PAGE_MASK) | 152 | #define pmd_flags(x) (pmd_val(x) & ~PAGE_MASK) |
diff --git a/drivers/lguest/lguest_device.c b/drivers/lguest/lguest_device.c index e082cdac88b4..b6200bc39b58 100644 --- a/drivers/lguest/lguest_device.c +++ b/drivers/lguest/lguest_device.c | |||
| @@ -1,10 +1,12 @@ | |||
| 1 | /*P:050 Lguest guests use a very simple method to describe devices. It's a | 1 | /*P:050 |
| 2 | * Lguest guests use a very simple method to describe devices. It's a | ||
| 2 | * series of device descriptors contained just above the top of normal Guest | 3 | * series of device descriptors contained just above the top of normal Guest |
| 3 | * memory. | 4 | * memory. |
| 4 | * | 5 | * |
| 5 | * We use the standard "virtio" device infrastructure, which provides us with a | 6 | * We use the standard "virtio" device infrastructure, which provides us with a |
| 6 | * console, a network and a block driver. Each one expects some configuration | 7 | * console, a network and a block driver. Each one expects some configuration |
| 7 | * information and a "virtqueue" or two to send and receive data. :*/ | 8 | * information and a "virtqueue" or two to send and receive data. |
| 9 | :*/ | ||
| 8 | #include <linux/init.h> | 10 | #include <linux/init.h> |
| 9 | #include <linux/bootmem.h> | 11 | #include <linux/bootmem.h> |
| 10 | #include <linux/lguest_launcher.h> | 12 | #include <linux/lguest_launcher.h> |
| @@ -20,8 +22,10 @@ | |||
| 20 | /* The pointer to our (page) of device descriptions. */ | 22 | /* The pointer to our (page) of device descriptions. */ |
| 21 | static void *lguest_devices; | 23 | static void *lguest_devices; |
| 22 | 24 | ||
| 23 | /* For Guests, device memory can be used as normal memory, so we cast away the | 25 | /* |
| 24 | * __iomem to quieten sparse. */ | 26 | * For Guests, device memory can be used as normal memory, so we cast away the |
| 27 | * __iomem to quieten sparse. | ||
| 28 | */ | ||
| 25 | static inline void *lguest_map(unsigned long phys_addr, unsigned long pages) | 29 | static inline void *lguest_map(unsigned long phys_addr, unsigned long pages) |
| 26 | { | 30 | { |
| 27 | return (__force void *)ioremap_cache(phys_addr, PAGE_SIZE*pages); | 31 | return (__force void *)ioremap_cache(phys_addr, PAGE_SIZE*pages); |
| @@ -32,8 +36,10 @@ static inline void lguest_unmap(void *addr) | |||
| 32 | iounmap((__force void __iomem *)addr); | 36 | iounmap((__force void __iomem *)addr); |
| 33 | } | 37 | } |
| 34 | 38 | ||
| 35 | /*D:100 Each lguest device is just a virtio device plus a pointer to its entry | 39 | /*D:100 |
| 36 | * in the lguest_devices page. */ | 40 | * Each lguest device is just a virtio device plus a pointer to its entry |
| 41 | * in the lguest_devices page. | ||
| 42 | */ | ||
| 37 | struct lguest_device { | 43 | struct lguest_device { |
| 38 | struct virtio_device vdev; | 44 | struct virtio_device vdev; |
| 39 | 45 | ||
| @@ -41,9 +47,11 @@ struct lguest_device { | |||
| 41 | struct lguest_device_desc *desc; | 47 | struct lguest_device_desc *desc; |
| 42 | }; | 48 | }; |
| 43 | 49 | ||
| 44 | /* Since the virtio infrastructure hands us a pointer to the virtio_device all | 50 | /* |
| 51 | * Since the virtio infrastructure hands us a pointer to the virtio_device all | ||
| 45 | * the time, it helps to have a curt macro to get a pointer to the struct | 52 | * the time, it helps to have a curt macro to get a pointer to the struct |
| 46 | * lguest_device it's enclosed in. */ | 53 | * lguest_device it's enclosed in. |
| 54 | */ | ||
| 47 | #define to_lgdev(vd) container_of(vd, struct lguest_device, vdev) | 55 | #define to_lgdev(vd) container_of(vd, struct lguest_device, vdev) |
| 48 | 56 | ||
| 49 | /*D:130 | 57 | /*D:130 |
| @@ -55,7 +63,8 @@ struct lguest_device { | |||
| 55 | * the driver will look at them during setup. | 63 | * the driver will look at them during setup. |
| 56 | * | 64 | * |
| 57 | * A convenient routine to return the device's virtqueue config array: | 65 | * A convenient routine to return the device's virtqueue config array: |
| 58 | * immediately after the descriptor. */ | 66 | * immediately after the descriptor. |
| 67 | */ | ||
| 59 | static struct lguest_vqconfig *lg_vq(const struct lguest_device_desc *desc) | 68 | static struct lguest_vqconfig *lg_vq(const struct lguest_device_desc *desc) |
| 60 | { | 69 | { |
| 61 | return (void *)(desc + 1); | 70 | return (void *)(desc + 1); |
| @@ -98,10 +107,12 @@ static u32 lg_get_features(struct virtio_device *vdev) | |||
| 98 | return features; | 107 | return features; |
| 99 | } | 108 | } |
| 100 | 109 | ||
| 101 | /* The virtio core takes the features the Host offers, and copies the | 110 | /* |
| 102 | * ones supported by the driver into the vdev->features array. Once | 111 | * The virtio core takes the features the Host offers, and copies the ones |
| 103 | * that's all sorted out, this routine is called so we can tell the | 112 | * supported by the driver into the vdev->features array. Once that's all |
| 104 | * Host which features we understand and accept. */ | 113 | * sorted out, this routine is called so we can tell the Host which features we |
| 114 | * understand and accept. | ||
| 115 | */ | ||
| 105 | static void lg_finalize_features(struct virtio_device *vdev) | 116 | static void lg_finalize_features(struct virtio_device *vdev) |
| 106 | { | 117 | { |
| 107 | unsigned int i, bits; | 118 | unsigned int i, bits; |
| @@ -112,10 +123,11 @@ static void lg_finalize_features(struct virtio_device *vdev) | |||
| 112 | /* Give virtio_ring a chance to accept features. */ | 123 | /* Give virtio_ring a chance to accept features. */ |
| 113 | vring_transport_features(vdev); | 124 | vring_transport_features(vdev); |
| 114 | 125 | ||
| 115 | /* The vdev->feature array is a Linux bitmask: this isn't the | 126 | /* |
| 116 | * same as a the simple array of bits used by lguest devices | 127 | * The vdev->feature array is a Linux bitmask: this isn't the same as a |
| 117 | * for features. So we do this slow, manual conversion which is | 128 | * the simple array of bits used by lguest devices for features. So we |
| 118 | * completely general. */ | 129 | * do this slow, manual conversion which is completely general. |
| 130 | */ | ||
| 119 | memset(out_features, 0, desc->feature_len); | 131 | memset(out_features, 0, desc->feature_len); |
| 120 | bits = min_t(unsigned, desc->feature_len, sizeof(vdev->features)) * 8; | 132 | bits = min_t(unsigned, desc->feature_len, sizeof(vdev->features)) * 8; |
| 121 | for (i = 0; i < bits; i++) { | 133 | for (i = 0; i < bits; i++) { |
| @@ -146,15 +158,19 @@ static void lg_set(struct virtio_device *vdev, unsigned int offset, | |||
| 146 | memcpy(lg_config(desc) + offset, buf, len); | 158 | memcpy(lg_config(desc) + offset, buf, len); |
| 147 | } | 159 | } |
| 148 | 160 | ||
| 149 | /* The operations to get and set the status word just access the status field | 161 | /* |
| 150 | * of the device descriptor. */ | 162 | * The operations to get and set the status word just access the status field |
| 163 | * of the device descriptor. | ||
| 164 | */ | ||
| 151 | static u8 lg_get_status(struct virtio_device *vdev) | 165 | static u8 lg_get_status(struct virtio_device *vdev) |
| 152 | { | 166 | { |
| 153 | return to_lgdev(vdev)->desc->status; | 167 | return to_lgdev(vdev)->desc->status; |
| 154 | } | 168 | } |
| 155 | 169 | ||
| 156 | /* To notify on status updates, we (ab)use the NOTIFY hypercall, with the | 170 | /* |
| 157 | * descriptor address of the device. A zero status means "reset". */ | 171 | * To notify on status updates, we (ab)use the NOTIFY hypercall, with the |
| 172 | * descriptor address of the device. A zero status means "reset". | ||
| 173 | */ | ||
| 158 | static void set_status(struct virtio_device *vdev, u8 status) | 174 | static void set_status(struct virtio_device *vdev, u8 status) |
| 159 | { | 175 | { |
| 160 | unsigned long offset = (void *)to_lgdev(vdev)->desc - lguest_devices; | 176 | unsigned long offset = (void *)to_lgdev(vdev)->desc - lguest_devices; |
| @@ -191,8 +207,7 @@ static void lg_reset(struct virtio_device *vdev) | |||
| 191 | */ | 207 | */ |
| 192 | 208 | ||
| 193 | /*D:140 This is the information we remember about each virtqueue. */ | 209 | /*D:140 This is the information we remember about each virtqueue. */ |
| 194 | struct lguest_vq_info | 210 | struct lguest_vq_info { |
| 195 | { | ||
| 196 | /* A copy of the information contained in the device config. */ | 211 | /* A copy of the information contained in the device config. */ |
| 197 | struct lguest_vqconfig config; | 212 | struct lguest_vqconfig config; |
| 198 | 213 | ||
| @@ -200,13 +215,17 @@ struct lguest_vq_info | |||
| 200 | void *pages; | 215 | void *pages; |
| 201 | }; | 216 | }; |
| 202 | 217 | ||
| 203 | /* When the virtio_ring code wants to prod the Host, it calls us here and we | 218 | /* |
| 219 | * When the virtio_ring code wants to prod the Host, it calls us here and we | ||
| 204 | * make a hypercall. We hand the physical address of the virtqueue so the Host | 220 | * make a hypercall. We hand the physical address of the virtqueue so the Host |
| 205 | * knows which virtqueue we're talking about. */ | 221 | * knows which virtqueue we're talking about. |
| 222 | */ | ||
| 206 | static void lg_notify(struct virtqueue *vq) | 223 | static void lg_notify(struct virtqueue *vq) |
| 207 | { | 224 | { |
| 208 | /* We store our virtqueue information in the "priv" pointer of the | 225 | /* |
| 209 | * virtqueue structure. */ | 226 | * We store our virtqueue information in the "priv" pointer of the |
| 227 | * virtqueue structure. | ||
| 228 | */ | ||
| 210 | struct lguest_vq_info *lvq = vq->priv; | 229 | struct lguest_vq_info *lvq = vq->priv; |
| 211 | 230 | ||
| 212 | kvm_hypercall1(LHCALL_NOTIFY, lvq->config.pfn << PAGE_SHIFT); | 231 | kvm_hypercall1(LHCALL_NOTIFY, lvq->config.pfn << PAGE_SHIFT); |
| @@ -215,7 +234,8 @@ static void lg_notify(struct virtqueue *vq) | |||
| 215 | /* An extern declaration inside a C file is bad form. Don't do it. */ | 234 | /* An extern declaration inside a C file is bad form. Don't do it. */ |
| 216 | extern void lguest_setup_irq(unsigned int irq); | 235 | extern void lguest_setup_irq(unsigned int irq); |
| 217 | 236 | ||
| 218 | /* This routine finds the first virtqueue described in the configuration of | 237 | /* |
| 238 | * This routine finds the Nth virtqueue described in the configuration of | ||
| 219 | * this device and sets it up. | 239 | * this device and sets it up. |
| 220 | * | 240 | * |
| 221 | * This is kind of an ugly duckling. It'd be nicer to have a standard | 241 | * This is kind of an ugly duckling. It'd be nicer to have a standard |
| @@ -223,9 +243,7 @@ extern void lguest_setup_irq(unsigned int irq); | |||
| 223 | * everyone wants to do it differently. The KVM coders want the Guest to | 243 | * everyone wants to do it differently. The KVM coders want the Guest to |
| 224 | * allocate its own pages and tell the Host where they are, but for lguest it's | 244 | * allocate its own pages and tell the Host where they are, but for lguest it's |
| 225 | * simpler for the Host to simply tell us where the pages are. | 245 | * simpler for the Host to simply tell us where the pages are. |
| 226 | * | 246 | */ |
| 227 | * So we provide drivers with a "find the Nth virtqueue and set it up" | ||
| 228 | * function. */ | ||
| 229 | static struct virtqueue *lg_find_vq(struct virtio_device *vdev, | 247 | static struct virtqueue *lg_find_vq(struct virtio_device *vdev, |
| 230 | unsigned index, | 248 | unsigned index, |
| 231 | void (*callback)(struct virtqueue *vq), | 249 | void (*callback)(struct virtqueue *vq), |
| @@ -244,9 +262,11 @@ static struct virtqueue *lg_find_vq(struct virtio_device *vdev, | |||
| 244 | if (!lvq) | 262 | if (!lvq) |
| 245 | return ERR_PTR(-ENOMEM); | 263 | return ERR_PTR(-ENOMEM); |
| 246 | 264 | ||
| 247 | /* Make a copy of the "struct lguest_vqconfig" entry, which sits after | 265 | /* |
| 266 | * Make a copy of the "struct lguest_vqconfig" entry, which sits after | ||
| 248 | * the descriptor. We need a copy because the config space might not | 267 | * the descriptor. We need a copy because the config space might not |
| 249 | * be aligned correctly. */ | 268 | * be aligned correctly. |
| 269 | */ | ||
| 250 | memcpy(&lvq->config, lg_vq(ldev->desc)+index, sizeof(lvq->config)); | 270 | memcpy(&lvq->config, lg_vq(ldev->desc)+index, sizeof(lvq->config)); |
| 251 | 271 | ||
| 252 | printk("Mapping virtqueue %i addr %lx\n", index, | 272 | printk("Mapping virtqueue %i addr %lx\n", index, |
| @@ -261,8 +281,10 @@ static struct virtqueue *lg_find_vq(struct virtio_device *vdev, | |||
| 261 | goto free_lvq; | 281 | goto free_lvq; |
| 262 | } | 282 | } |
| 263 | 283 | ||
| 264 | /* OK, tell virtio_ring.c to set up a virtqueue now we know its size | 284 | /* |
| 265 | * and we've got a pointer to its pages. */ | 285 | * OK, tell virtio_ring.c to set up a virtqueue now we know its size |
| 286 | * and we've got a pointer to its pages. | ||
| 287 | */ | ||
| 266 | vq = vring_new_virtqueue(lvq->config.num, LGUEST_VRING_ALIGN, | 288 | vq = vring_new_virtqueue(lvq->config.num, LGUEST_VRING_ALIGN, |
| 267 | vdev, lvq->pages, lg_notify, callback, name); | 289 | vdev, lvq->pages, lg_notify, callback, name); |
| 268 | if (!vq) { | 290 | if (!vq) { |
| @@ -273,18 +295,23 @@ static struct virtqueue *lg_find_vq(struct virtio_device *vdev, | |||
| 273 | /* Make sure the interrupt is allocated. */ | 295 | /* Make sure the interrupt is allocated. */ |
| 274 | lguest_setup_irq(lvq->config.irq); | 296 | lguest_setup_irq(lvq->config.irq); |
| 275 | 297 | ||
| 276 | /* Tell the interrupt for this virtqueue to go to the virtio_ring | 298 | /* |
| 277 | * interrupt handler. */ | 299 | * Tell the interrupt for this virtqueue to go to the virtio_ring |
| 278 | /* FIXME: We used to have a flag for the Host to tell us we could use | 300 | * interrupt handler. |
| 301 | * | ||
| 302 | * FIXME: We used to have a flag for the Host to tell us we could use | ||
| 279 | * the interrupt as a source of randomness: it'd be nice to have that | 303 | * the interrupt as a source of randomness: it'd be nice to have that |
| 280 | * back.. */ | 304 | * back. |
| 305 | */ | ||
| 281 | err = request_irq(lvq->config.irq, vring_interrupt, IRQF_SHARED, | 306 | err = request_irq(lvq->config.irq, vring_interrupt, IRQF_SHARED, |
| 282 | dev_name(&vdev->dev), vq); | 307 | dev_name(&vdev->dev), vq); |
| 283 | if (err) | 308 | if (err) |
| 284 | goto destroy_vring; | 309 | goto destroy_vring; |
| 285 | 310 | ||
| 286 | /* Last of all we hook up our 'struct lguest_vq_info" to the | 311 | /* |
| 287 | * virtqueue's priv pointer. */ | 312 | * Last of all we hook up our 'struct lguest_vq_info" to the |
| 313 | * virtqueue's priv pointer. | ||
| 314 | */ | ||
| 288 | vq->priv = lvq; | 315 | vq->priv = lvq; |
| 289 | return vq; | 316 | return vq; |
| 290 | 317 | ||
| @@ -358,11 +385,14 @@ static struct virtio_config_ops lguest_config_ops = { | |||
| 358 | .del_vqs = lg_del_vqs, | 385 | .del_vqs = lg_del_vqs, |
| 359 | }; | 386 | }; |
| 360 | 387 | ||
| 361 | /* The root device for the lguest virtio devices. This makes them appear as | 388 | /* |
| 362 | * /sys/devices/lguest/0,1,2 not /sys/devices/0,1,2. */ | 389 | * The root device for the lguest virtio devices. This makes them appear as |
| 390 | * /sys/devices/lguest/0,1,2 not /sys/devices/0,1,2. | ||
| 391 | */ | ||
| 363 | static struct device *lguest_root; | 392 | static struct device *lguest_root; |
| 364 | 393 | ||
| 365 | /*D:120 This is the core of the lguest bus: actually adding a new device. | 394 | /*D:120 |
| 395 | * This is the core of the lguest bus: actually adding a new device. | ||
| 366 | * It's a separate function because it's neater that way, and because an | 396 | * It's a separate function because it's neater that way, and because an |
| 367 | * earlier version of the code supported hotplug and unplug. They were removed | 397 | * earlier version of the code supported hotplug and unplug. They were removed |
| 368 | * early on because they were never used. | 398 | * early on because they were never used. |
| @@ -371,14 +401,14 @@ static struct device *lguest_root; | |||
| 371 | * | 401 | * |
| 372 | * It's worth reading this carefully: we start with a pointer to the new device | 402 | * It's worth reading this carefully: we start with a pointer to the new device |
| 373 | * descriptor in the "lguest_devices" page, and the offset into the device | 403 | * descriptor in the "lguest_devices" page, and the offset into the device |
| 374 | * descriptor page so we can uniquely identify it if things go badly wrong. */ | 404 | * descriptor page so we can uniquely identify it if things go badly wrong. |
| 405 | */ | ||
| 375 | static void add_lguest_device(struct lguest_device_desc *d, | 406 | static void add_lguest_device(struct lguest_device_desc *d, |
| 376 | unsigned int offset) | 407 | unsigned int offset) |
| 377 | { | 408 | { |
| 378 | struct lguest_device *ldev; | 409 | struct lguest_device *ldev; |
| 379 | 410 | ||
| 380 | /* Start with zeroed memory; Linux's device layer seems to count on | 411 | /* Start with zeroed memory; Linux's device layer counts on it. */ |
| 381 | * it. */ | ||
| 382 | ldev = kzalloc(sizeof(*ldev), GFP_KERNEL); | 412 | ldev = kzalloc(sizeof(*ldev), GFP_KERNEL); |
| 383 | if (!ldev) { | 413 | if (!ldev) { |
| 384 | printk(KERN_EMERG "Cannot allocate lguest dev %u type %u\n", | 414 | printk(KERN_EMERG "Cannot allocate lguest dev %u type %u\n", |
| @@ -388,17 +418,25 @@ static void add_lguest_device(struct lguest_device_desc *d, | |||
| 388 | 418 | ||
| 389 | /* This devices' parent is the lguest/ dir. */ | 419 | /* This devices' parent is the lguest/ dir. */ |
| 390 | ldev->vdev.dev.parent = lguest_root; | 420 | ldev->vdev.dev.parent = lguest_root; |
| 391 | /* We have a unique device index thanks to the dev_index counter. */ | 421 | /* |
| 422 | * The device type comes straight from the descriptor. There's also a | ||
| 423 | * device vendor field in the virtio_device struct, which we leave as | ||
| 424 | * 0. | ||
| 425 | */ | ||
| 392 | ldev->vdev.id.device = d->type; | 426 | ldev->vdev.id.device = d->type; |
| 393 | /* We have a simple set of routines for querying the device's | 427 | /* |
| 394 | * configuration information and setting its status. */ | 428 | * We have a simple set of routines for querying the device's |
| 429 | * configuration information and setting its status. | ||
| 430 | */ | ||
| 395 | ldev->vdev.config = &lguest_config_ops; | 431 | ldev->vdev.config = &lguest_config_ops; |
| 396 | /* And we remember the device's descriptor for lguest_config_ops. */ | 432 | /* And we remember the device's descriptor for lguest_config_ops. */ |
| 397 | ldev->desc = d; | 433 | ldev->desc = d; |
| 398 | 434 | ||
| 399 | /* register_virtio_device() sets up the generic fields for the struct | 435 | /* |
| 436 | * register_virtio_device() sets up the generic fields for the struct | ||
| 400 | * virtio_device and calls device_register(). This makes the bus | 437 | * virtio_device and calls device_register(). This makes the bus |
| 401 | * infrastructure look for a matching driver. */ | 438 | * infrastructure look for a matching driver. |
| 439 | */ | ||
| 402 | if (register_virtio_device(&ldev->vdev) != 0) { | 440 | if (register_virtio_device(&ldev->vdev) != 0) { |
| 403 | printk(KERN_ERR "Failed to register lguest dev %u type %u\n", | 441 | printk(KERN_ERR "Failed to register lguest dev %u type %u\n", |
| 404 | offset, d->type); | 442 | offset, d->type); |
| @@ -406,8 +444,10 @@ static void add_lguest_device(struct lguest_device_desc *d, | |||
| 406 | } | 444 | } |
| 407 | } | 445 | } |
| 408 | 446 | ||
| 409 | /*D:110 scan_devices() simply iterates through the device page. The type 0 is | 447 | /*D:110 |
| 410 | * reserved to mean "end of devices". */ | 448 | * scan_devices() simply iterates through the device page. The type 0 is |
| 449 | * reserved to mean "end of devices". | ||
| 450 | */ | ||
| 411 | static void scan_devices(void) | 451 | static void scan_devices(void) |
| 412 | { | 452 | { |
| 413 | unsigned int i; | 453 | unsigned int i; |
| @@ -426,7 +466,8 @@ static void scan_devices(void) | |||
| 426 | } | 466 | } |
| 427 | } | 467 | } |
| 428 | 468 | ||
| 429 | /*D:105 Fairly early in boot, lguest_devices_init() is called to set up the | 469 | /*D:105 |
| 470 | * Fairly early in boot, lguest_devices_init() is called to set up the | ||
| 430 | * lguest device infrastructure. We check that we are a Guest by checking | 471 | * lguest device infrastructure. We check that we are a Guest by checking |
| 431 | * pv_info.name: there are other ways of checking, but this seems most | 472 | * pv_info.name: there are other ways of checking, but this seems most |
| 432 | * obvious to me. | 473 | * obvious to me. |
| @@ -437,7 +478,8 @@ static void scan_devices(void) | |||
| 437 | * correct sysfs incantation). | 478 | * correct sysfs incantation). |
| 438 | * | 479 | * |
| 439 | * Finally we call scan_devices() which adds all the devices found in the | 480 | * Finally we call scan_devices() which adds all the devices found in the |
| 440 | * lguest_devices page. */ | 481 | * lguest_devices page. |
| 482 | */ | ||
| 441 | static int __init lguest_devices_init(void) | 483 | static int __init lguest_devices_init(void) |
| 442 | { | 484 | { |
| 443 | if (strcmp(pv_info.name, "lguest") != 0) | 485 | if (strcmp(pv_info.name, "lguest") != 0) |
| @@ -456,11 +498,13 @@ static int __init lguest_devices_init(void) | |||
| 456 | /* We do this after core stuff, but before the drivers. */ | 498 | /* We do this after core stuff, but before the drivers. */ |
| 457 | postcore_initcall(lguest_devices_init); | 499 | postcore_initcall(lguest_devices_init); |
| 458 | 500 | ||
| 459 | /*D:150 At this point in the journey we used to now wade through the lguest | 501 | /*D:150 |
| 502 | * At this point in the journey we used to now wade through the lguest | ||
| 460 | * devices themselves: net, block and console. Since they're all now virtio | 503 | * devices themselves: net, block and console. Since they're all now virtio |
| 461 | * devices rather than lguest-specific, I've decided to ignore them. Mostly, | 504 | * devices rather than lguest-specific, I've decided to ignore them. Mostly, |
| 462 | * they're kind of boring. But this does mean you'll never experience the | 505 | * they're kind of boring. But this does mean you'll never experience the |
| 463 | * thrill of reading the forbidden love scene buried deep in the block driver. | 506 | * thrill of reading the forbidden love scene buried deep in the block driver. |
| 464 | * | 507 | * |
| 465 | * "make Launcher" beckons, where we answer questions like "Where do Guests | 508 | * "make Launcher" beckons, where we answer questions like "Where do Guests |
| 466 | * come from?", and "What do you do when someone asks for optimization?". */ | 509 | * come from?", and "What do you do when someone asks for optimization?". |
| 510 | */ | ||
diff --git a/drivers/lguest/lguest_user.c b/drivers/lguest/lguest_user.c index 9f9a2953b383..b4d3f7ca554f 100644 --- a/drivers/lguest/lguest_user.c +++ b/drivers/lguest/lguest_user.c | |||
| @@ -1,8 +1,9 @@ | |||
| 1 | /*P:200 This contains all the /dev/lguest code, whereby the userspace launcher | 1 | /*P:200 This contains all the /dev/lguest code, whereby the userspace launcher |
| 2 | * controls and communicates with the Guest. For example, the first write will | 2 | * controls and communicates with the Guest. For example, the first write will |
| 3 | * tell us the Guest's memory layout, pagetable, entry point and kernel address | 3 | * tell us the Guest's memory layout and entry point. A read will run the |
| 4 | * offset. A read will run the Guest until something happens, such as a signal | 4 | * Guest until something happens, such as a signal or the Guest doing a NOTIFY |
| 5 | * or the Guest doing a NOTIFY out to the Launcher. :*/ | 5 | * out to the Launcher. |
| 6 | :*/ | ||
| 6 | #include <linux/uaccess.h> | 7 | #include <linux/uaccess.h> |
| 7 | #include <linux/miscdevice.h> | 8 | #include <linux/miscdevice.h> |
| 8 | #include <linux/fs.h> | 9 | #include <linux/fs.h> |
| @@ -11,14 +12,41 @@ | |||
| 11 | #include <linux/file.h> | 12 | #include <linux/file.h> |
| 12 | #include "lg.h" | 13 | #include "lg.h" |
| 13 | 14 | ||
| 15 | /*L:056 | ||
| 16 | * Before we move on, let's jump ahead and look at what the kernel does when | ||
| 17 | * it needs to look up the eventfds. That will complete our picture of how we | ||
| 18 | * use RCU. | ||
| 19 | * | ||
| 20 | * The notification value is in cpu->pending_notify: we return true if it went | ||
| 21 | * to an eventfd. | ||
| 22 | */ | ||
| 14 | bool send_notify_to_eventfd(struct lg_cpu *cpu) | 23 | bool send_notify_to_eventfd(struct lg_cpu *cpu) |
| 15 | { | 24 | { |
| 16 | unsigned int i; | 25 | unsigned int i; |
| 17 | struct lg_eventfd_map *map; | 26 | struct lg_eventfd_map *map; |
| 18 | 27 | ||
| 19 | /* lg->eventfds is RCU-protected */ | 28 | /* |
| 29 | * This "rcu_read_lock()" helps track when someone is still looking at | ||
| 30 | * the (RCU-using) eventfds array. It's not actually a lock at all; | ||
| 31 | * indeed it's a noop in many configurations. (You didn't expect me to | ||
| 32 | * explain all the RCU secrets here, did you?) | ||
| 33 | */ | ||
| 20 | rcu_read_lock(); | 34 | rcu_read_lock(); |
| 35 | /* | ||
| 36 | * rcu_dereference is the counter-side of rcu_assign_pointer(); it | ||
| 37 | * makes sure we don't access the memory pointed to by | ||
| 38 | * cpu->lg->eventfds before cpu->lg->eventfds is set. Sounds crazy, | ||
| 39 | * but Alpha allows this! Paul McKenney points out that a really | ||
| 40 | * aggressive compiler could have the same effect: | ||
| 41 | * http://lists.ozlabs.org/pipermail/lguest/2009-July/001560.html | ||
| 42 | * | ||
| 43 | * So play safe, use rcu_dereference to get the rcu-protected pointer: | ||
| 44 | */ | ||
| 21 | map = rcu_dereference(cpu->lg->eventfds); | 45 | map = rcu_dereference(cpu->lg->eventfds); |
| 46 | /* | ||
| 47 | * Simple array search: even if they add an eventfd while we do this, | ||
| 48 | * we'll continue to use the old array and just won't see the new one. | ||
| 49 | */ | ||
| 22 | for (i = 0; i < map->num; i++) { | 50 | for (i = 0; i < map->num; i++) { |
| 23 | if (map->map[i].addr == cpu->pending_notify) { | 51 | if (map->map[i].addr == cpu->pending_notify) { |
| 24 | eventfd_signal(map->map[i].event, 1); | 52 | eventfd_signal(map->map[i].event, 1); |
| @@ -26,19 +54,50 @@ bool send_notify_to_eventfd(struct lg_cpu *cpu) | |||
| 26 | break; | 54 | break; |
| 27 | } | 55 | } |
| 28 | } | 56 | } |
| 57 | /* We're done with the rcu-protected variable cpu->lg->eventfds. */ | ||
| 29 | rcu_read_unlock(); | 58 | rcu_read_unlock(); |
| 59 | |||
| 60 | /* If we cleared the notification, it's because we found a match. */ | ||
| 30 | return cpu->pending_notify == 0; | 61 | return cpu->pending_notify == 0; |
| 31 | } | 62 | } |
| 32 | 63 | ||
| 64 | /*L:055 | ||
| 65 | * One of the more tricksy tricks in the Linux Kernel is a technique called | ||
| 66 | * Read Copy Update. Since one point of lguest is to teach lguest journeyers | ||
| 67 | * about kernel coding, I use it here. (In case you're curious, other purposes | ||
| 68 | * include learning about virtualization and instilling a deep appreciation for | ||
| 69 | * simplicity and puppies). | ||
| 70 | * | ||
| 71 | * We keep a simple array which maps LHCALL_NOTIFY values to eventfds, but we | ||
| 72 | * add new eventfds without ever blocking readers from accessing the array. | ||
| 73 | * The current Launcher only does this during boot, so that never happens. But | ||
| 74 | * Read Copy Update is cool, and adding a lock risks damaging even more puppies | ||
| 75 | * than this code does. | ||
| 76 | * | ||
| 77 | * We allocate a brand new one-larger array, copy the old one and add our new | ||
| 78 | * element. Then we make the lg eventfd pointer point to the new array. | ||
| 79 | * That's the easy part: now we need to free the old one, but we need to make | ||
| 80 | * sure no slow CPU somewhere is still looking at it. That's what | ||
| 81 | * synchronize_rcu does for us: waits until every CPU has indicated that it has | ||
| 82 | * moved on to know it's no longer using the old one. | ||
| 83 | * | ||
| 84 | * If that's unclear, see http://en.wikipedia.org/wiki/Read-copy-update. | ||
| 85 | */ | ||
| 33 | static int add_eventfd(struct lguest *lg, unsigned long addr, int fd) | 86 | static int add_eventfd(struct lguest *lg, unsigned long addr, int fd) |
| 34 | { | 87 | { |
| 35 | struct lg_eventfd_map *new, *old = lg->eventfds; | 88 | struct lg_eventfd_map *new, *old = lg->eventfds; |
| 36 | 89 | ||
| 90 | /* | ||
| 91 | * We don't allow notifications on value 0 anyway (pending_notify of | ||
| 92 | * 0 means "nothing pending"). | ||
| 93 | */ | ||
| 37 | if (!addr) | 94 | if (!addr) |
| 38 | return -EINVAL; | 95 | return -EINVAL; |
| 39 | 96 | ||
| 40 | /* Replace the old array with the new one, carefully: others can | 97 | /* |
| 41 | * be accessing it at the same time */ | 98 | * Replace the old array with the new one, carefully: others can |
| 99 | * be accessing it at the same time. | ||
| 100 | */ | ||
| 42 | new = kmalloc(sizeof(*new) + sizeof(new->map[0]) * (old->num + 1), | 101 | new = kmalloc(sizeof(*new) + sizeof(new->map[0]) * (old->num + 1), |
| 43 | GFP_KERNEL); | 102 | GFP_KERNEL); |
| 44 | if (!new) | 103 | if (!new) |
| @@ -52,22 +111,41 @@ static int add_eventfd(struct lguest *lg, unsigned long addr, int fd) | |||
| 52 | new->map[new->num].addr = addr; | 111 | new->map[new->num].addr = addr; |
| 53 | new->map[new->num].event = eventfd_ctx_fdget(fd); | 112 | new->map[new->num].event = eventfd_ctx_fdget(fd); |
| 54 | if (IS_ERR(new->map[new->num].event)) { | 113 | if (IS_ERR(new->map[new->num].event)) { |
| 114 | int err = PTR_ERR(new->map[new->num].event); | ||
| 55 | kfree(new); | 115 | kfree(new); |
| 56 | return PTR_ERR(new->map[new->num].event); | 116 | return err; |
| 57 | } | 117 | } |
| 58 | new->num++; | 118 | new->num++; |
| 59 | 119 | ||
| 60 | /* Now put new one in place. */ | 120 | /* |
| 121 | * Now put new one in place: rcu_assign_pointer() is a fancy way of | ||
| 122 | * doing "lg->eventfds = new", but it uses memory barriers to make | ||
| 123 | * absolutely sure that the contents of "new" written above is nailed | ||
| 124 | * down before we actually do the assignment. | ||
| 125 | * | ||
| 126 | * We have to think about these kinds of things when we're operating on | ||
| 127 | * live data without locks. | ||
| 128 | */ | ||
| 61 | rcu_assign_pointer(lg->eventfds, new); | 129 | rcu_assign_pointer(lg->eventfds, new); |
| 62 | 130 | ||
| 63 | /* We're not in a big hurry. Wait until noone's looking at old | 131 | /* |
| 64 | * version, then delete it. */ | 132 | * We're not in a big hurry. Wait until noone's looking at old |
| 133 | * version, then free it. | ||
| 134 | */ | ||
| 65 | synchronize_rcu(); | 135 | synchronize_rcu(); |
| 66 | kfree(old); | 136 | kfree(old); |
| 67 | 137 | ||
| 68 | return 0; | 138 | return 0; |
| 69 | } | 139 | } |
| 70 | 140 | ||
| 141 | /*L:052 | ||
| 142 | * Receiving notifications from the Guest is usually done by attaching a | ||
| 143 | * particular LHCALL_NOTIFY value to an event filedescriptor. The eventfd will | ||
| 144 | * become readable when the Guest does an LHCALL_NOTIFY with that value. | ||
| 145 | * | ||
| 146 | * This is really convenient for processing each virtqueue in a separate | ||
| 147 | * thread. | ||
| 148 | */ | ||
| 71 | static int attach_eventfd(struct lguest *lg, const unsigned long __user *input) | 149 | static int attach_eventfd(struct lguest *lg, const unsigned long __user *input) |
| 72 | { | 150 | { |
| 73 | unsigned long addr, fd; | 151 | unsigned long addr, fd; |
| @@ -79,15 +157,22 @@ static int attach_eventfd(struct lguest *lg, const unsigned long __user *input) | |||
| 79 | if (get_user(fd, input) != 0) | 157 | if (get_user(fd, input) != 0) |
| 80 | return -EFAULT; | 158 | return -EFAULT; |
| 81 | 159 | ||
| 160 | /* | ||
| 161 | * Just make sure two callers don't add eventfds at once. We really | ||
| 162 | * only need to lock against callers adding to the same Guest, so using | ||
| 163 | * the Big Lguest Lock is overkill. But this is setup, not a fast path. | ||
| 164 | */ | ||
| 82 | mutex_lock(&lguest_lock); | 165 | mutex_lock(&lguest_lock); |
| 83 | err = add_eventfd(lg, addr, fd); | 166 | err = add_eventfd(lg, addr, fd); |
| 84 | mutex_unlock(&lguest_lock); | 167 | mutex_unlock(&lguest_lock); |
| 85 | 168 | ||
| 86 | return 0; | 169 | return err; |
| 87 | } | 170 | } |
| 88 | 171 | ||
| 89 | /*L:050 Sending an interrupt is done by writing LHREQ_IRQ and an interrupt | 172 | /*L:050 |
| 90 | * number to /dev/lguest. */ | 173 | * Sending an interrupt is done by writing LHREQ_IRQ and an interrupt |
| 174 | * number to /dev/lguest. | ||
| 175 | */ | ||
| 91 | static int user_send_irq(struct lg_cpu *cpu, const unsigned long __user *input) | 176 | static int user_send_irq(struct lg_cpu *cpu, const unsigned long __user *input) |
| 92 | { | 177 | { |
| 93 | unsigned long irq; | 178 | unsigned long irq; |
| @@ -97,12 +182,18 @@ static int user_send_irq(struct lg_cpu *cpu, const unsigned long __user *input) | |||
| 97 | if (irq >= LGUEST_IRQS) | 182 | if (irq >= LGUEST_IRQS) |
| 98 | return -EINVAL; | 183 | return -EINVAL; |
| 99 | 184 | ||
| 185 | /* | ||
| 186 | * Next time the Guest runs, the core code will see if it can deliver | ||
| 187 | * this interrupt. | ||
| 188 | */ | ||
| 100 | set_interrupt(cpu, irq); | 189 | set_interrupt(cpu, irq); |
| 101 | return 0; | 190 | return 0; |
| 102 | } | 191 | } |
| 103 | 192 | ||
| 104 | /*L:040 Once our Guest is initialized, the Launcher makes it run by reading | 193 | /*L:040 |
| 105 | * from /dev/lguest. */ | 194 | * Once our Guest is initialized, the Launcher makes it run by reading |
| 195 | * from /dev/lguest. | ||
| 196 | */ | ||
| 106 | static ssize_t read(struct file *file, char __user *user, size_t size,loff_t*o) | 197 | static ssize_t read(struct file *file, char __user *user, size_t size,loff_t*o) |
| 107 | { | 198 | { |
| 108 | struct lguest *lg = file->private_data; | 199 | struct lguest *lg = file->private_data; |
| @@ -138,8 +229,10 @@ static ssize_t read(struct file *file, char __user *user, size_t size,loff_t*o) | |||
| 138 | return len; | 229 | return len; |
| 139 | } | 230 | } |
| 140 | 231 | ||
| 141 | /* If we returned from read() last time because the Guest sent I/O, | 232 | /* |
| 142 | * clear the flag. */ | 233 | * If we returned from read() last time because the Guest sent I/O, |
| 234 | * clear the flag. | ||
| 235 | */ | ||
| 143 | if (cpu->pending_notify) | 236 | if (cpu->pending_notify) |
| 144 | cpu->pending_notify = 0; | 237 | cpu->pending_notify = 0; |
| 145 | 238 | ||
| @@ -147,8 +240,10 @@ static ssize_t read(struct file *file, char __user *user, size_t size,loff_t*o) | |||
| 147 | return run_guest(cpu, (unsigned long __user *)user); | 240 | return run_guest(cpu, (unsigned long __user *)user); |
| 148 | } | 241 | } |
| 149 | 242 | ||
| 150 | /*L:025 This actually initializes a CPU. For the moment, a Guest is only | 243 | /*L:025 |
| 151 | * uniprocessor, so "id" is always 0. */ | 244 | * This actually initializes a CPU. For the moment, a Guest is only |
| 245 | * uniprocessor, so "id" is always 0. | ||
| 246 | */ | ||
| 152 | static int lg_cpu_start(struct lg_cpu *cpu, unsigned id, unsigned long start_ip) | 247 | static int lg_cpu_start(struct lg_cpu *cpu, unsigned id, unsigned long start_ip) |
| 153 | { | 248 | { |
| 154 | /* We have a limited number the number of CPUs in the lguest struct. */ | 249 | /* We have a limited number the number of CPUs in the lguest struct. */ |
| @@ -163,8 +258,10 @@ static int lg_cpu_start(struct lg_cpu *cpu, unsigned id, unsigned long start_ip) | |||
| 163 | /* Each CPU has a timer it can set. */ | 258 | /* Each CPU has a timer it can set. */ |
| 164 | init_clockdev(cpu); | 259 | init_clockdev(cpu); |
| 165 | 260 | ||
| 166 | /* We need a complete page for the Guest registers: they are accessible | 261 | /* |
| 167 | * to the Guest and we can only grant it access to whole pages. */ | 262 | * We need a complete page for the Guest registers: they are accessible |
| 263 | * to the Guest and we can only grant it access to whole pages. | ||
| 264 | */ | ||
| 168 | cpu->regs_page = get_zeroed_page(GFP_KERNEL); | 265 | cpu->regs_page = get_zeroed_page(GFP_KERNEL); |
| 169 | if (!cpu->regs_page) | 266 | if (!cpu->regs_page) |
| 170 | return -ENOMEM; | 267 | return -ENOMEM; |
| @@ -172,29 +269,38 @@ static int lg_cpu_start(struct lg_cpu *cpu, unsigned id, unsigned long start_ip) | |||
| 172 | /* We actually put the registers at the bottom of the page. */ | 269 | /* We actually put the registers at the bottom of the page. */ |
| 173 | cpu->regs = (void *)cpu->regs_page + PAGE_SIZE - sizeof(*cpu->regs); | 270 | cpu->regs = (void *)cpu->regs_page + PAGE_SIZE - sizeof(*cpu->regs); |
| 174 | 271 | ||
| 175 | /* Now we initialize the Guest's registers, handing it the start | 272 | /* |
| 176 | * address. */ | 273 | * Now we initialize the Guest's registers, handing it the start |
| 274 | * address. | ||
| 275 | */ | ||
| 177 | lguest_arch_setup_regs(cpu, start_ip); | 276 | lguest_arch_setup_regs(cpu, start_ip); |
| 178 | 277 | ||
| 179 | /* We keep a pointer to the Launcher task (ie. current task) for when | 278 | /* |
| 180 | * other Guests want to wake this one (eg. console input). */ | 279 | * We keep a pointer to the Launcher task (ie. current task) for when |
| 280 | * other Guests want to wake this one (eg. console input). | ||
| 281 | */ | ||
| 181 | cpu->tsk = current; | 282 | cpu->tsk = current; |
| 182 | 283 | ||
| 183 | /* We need to keep a pointer to the Launcher's memory map, because if | 284 | /* |
| 285 | * We need to keep a pointer to the Launcher's memory map, because if | ||
| 184 | * the Launcher dies we need to clean it up. If we don't keep a | 286 | * the Launcher dies we need to clean it up. If we don't keep a |
| 185 | * reference, it is destroyed before close() is called. */ | 287 | * reference, it is destroyed before close() is called. |
| 288 | */ | ||
| 186 | cpu->mm = get_task_mm(cpu->tsk); | 289 | cpu->mm = get_task_mm(cpu->tsk); |
| 187 | 290 | ||
| 188 | /* We remember which CPU's pages this Guest used last, for optimization | 291 | /* |
| 189 | * when the same Guest runs on the same CPU twice. */ | 292 | * We remember which CPU's pages this Guest used last, for optimization |
| 293 | * when the same Guest runs on the same CPU twice. | ||
| 294 | */ | ||
| 190 | cpu->last_pages = NULL; | 295 | cpu->last_pages = NULL; |
| 191 | 296 | ||
| 192 | /* No error == success. */ | 297 | /* No error == success. */ |
| 193 | return 0; | 298 | return 0; |
| 194 | } | 299 | } |
| 195 | 300 | ||
| 196 | /*L:020 The initialization write supplies 3 pointer sized (32 or 64 bit) | 301 | /*L:020 |
| 197 | * values (in addition to the LHREQ_INITIALIZE value). These are: | 302 | * The initialization write supplies 3 pointer sized (32 or 64 bit) values (in |
| 303 | * addition to the LHREQ_INITIALIZE value). These are: | ||
| 198 | * | 304 | * |
| 199 | * base: The start of the Guest-physical memory inside the Launcher memory. | 305 | * base: The start of the Guest-physical memory inside the Launcher memory. |
| 200 | * | 306 | * |
| @@ -206,14 +312,15 @@ static int lg_cpu_start(struct lg_cpu *cpu, unsigned id, unsigned long start_ip) | |||
| 206 | */ | 312 | */ |
| 207 | static int initialize(struct file *file, const unsigned long __user *input) | 313 | static int initialize(struct file *file, const unsigned long __user *input) |
| 208 | { | 314 | { |
| 209 | /* "struct lguest" contains everything we (the Host) know about a | 315 | /* "struct lguest" contains all we (the Host) know about a Guest. */ |
| 210 | * Guest. */ | ||
| 211 | struct lguest *lg; | 316 | struct lguest *lg; |
| 212 | int err; | 317 | int err; |
| 213 | unsigned long args[3]; | 318 | unsigned long args[3]; |
| 214 | 319 | ||
| 215 | /* We grab the Big Lguest lock, which protects against multiple | 320 | /* |
| 216 | * simultaneous initializations. */ | 321 | * We grab the Big Lguest lock, which protects against multiple |
| 322 | * simultaneous initializations. | ||
| 323 | */ | ||
| 217 | mutex_lock(&lguest_lock); | 324 | mutex_lock(&lguest_lock); |
| 218 | /* You can't initialize twice! Close the device and start again... */ | 325 | /* You can't initialize twice! Close the device and start again... */ |
| 219 | if (file->private_data) { | 326 | if (file->private_data) { |
| @@ -248,8 +355,10 @@ static int initialize(struct file *file, const unsigned long __user *input) | |||
| 248 | if (err) | 355 | if (err) |
| 249 | goto free_eventfds; | 356 | goto free_eventfds; |
| 250 | 357 | ||
| 251 | /* Initialize the Guest's shadow page tables, using the toplevel | 358 | /* |
| 252 | * address the Launcher gave us. This allocates memory, so can fail. */ | 359 | * Initialize the Guest's shadow page tables, using the toplevel |
| 360 | * address the Launcher gave us. This allocates memory, so can fail. | ||
| 361 | */ | ||
| 253 | err = init_guest_pagetable(lg); | 362 | err = init_guest_pagetable(lg); |
| 254 | if (err) | 363 | if (err) |
| 255 | goto free_regs; | 364 | goto free_regs; |
| @@ -274,20 +383,24 @@ unlock: | |||
| 274 | return err; | 383 | return err; |
| 275 | } | 384 | } |
| 276 | 385 | ||
| 277 | /*L:010 The first operation the Launcher does must be a write. All writes | 386 | /*L:010 |
| 387 | * The first operation the Launcher does must be a write. All writes | ||
| 278 | * start with an unsigned long number: for the first write this must be | 388 | * start with an unsigned long number: for the first write this must be |
| 279 | * LHREQ_INITIALIZE to set up the Guest. After that the Launcher can use | 389 | * LHREQ_INITIALIZE to set up the Guest. After that the Launcher can use |
| 280 | * writes of other values to send interrupts. | 390 | * writes of other values to send interrupts or set up receipt of notifications. |
| 281 | * | 391 | * |
| 282 | * Note that we overload the "offset" in the /dev/lguest file to indicate what | 392 | * Note that we overload the "offset" in the /dev/lguest file to indicate what |
| 283 | * CPU number we're dealing with. Currently this is always 0, since we only | 393 | * CPU number we're dealing with. Currently this is always 0 since we only |
| 284 | * support uniprocessor Guests, but you can see the beginnings of SMP support | 394 | * support uniprocessor Guests, but you can see the beginnings of SMP support |
| 285 | * here. */ | 395 | * here. |
| 396 | */ | ||
| 286 | static ssize_t write(struct file *file, const char __user *in, | 397 | static ssize_t write(struct file *file, const char __user *in, |
| 287 | size_t size, loff_t *off) | 398 | size_t size, loff_t *off) |
| 288 | { | 399 | { |
| 289 | /* Once the Guest is initialized, we hold the "struct lguest" in the | 400 | /* |
| 290 | * file private data. */ | 401 | * Once the Guest is initialized, we hold the "struct lguest" in the |
| 402 | * file private data. | ||
| 403 | */ | ||
| 291 | struct lguest *lg = file->private_data; | 404 | struct lguest *lg = file->private_data; |
| 292 | const unsigned long __user *input = (const unsigned long __user *)in; | 405 | const unsigned long __user *input = (const unsigned long __user *)in; |
| 293 | unsigned long req; | 406 | unsigned long req; |
| @@ -322,13 +435,15 @@ static ssize_t write(struct file *file, const char __user *in, | |||
| 322 | } | 435 | } |
| 323 | } | 436 | } |
| 324 | 437 | ||
| 325 | /*L:060 The final piece of interface code is the close() routine. It reverses | 438 | /*L:060 |
| 439 | * The final piece of interface code is the close() routine. It reverses | ||
| 326 | * everything done in initialize(). This is usually called because the | 440 | * everything done in initialize(). This is usually called because the |
| 327 | * Launcher exited. | 441 | * Launcher exited. |
| 328 | * | 442 | * |
| 329 | * Note that the close routine returns 0 or a negative error number: it can't | 443 | * Note that the close routine returns 0 or a negative error number: it can't |
| 330 | * really fail, but it can whine. I blame Sun for this wart, and K&R C for | 444 | * really fail, but it can whine. I blame Sun for this wart, and K&R C for |
| 331 | * letting them do it. :*/ | 445 | * letting them do it. |
| 446 | :*/ | ||
| 332 | static int close(struct inode *inode, struct file *file) | 447 | static int close(struct inode *inode, struct file *file) |
| 333 | { | 448 | { |
| 334 | struct lguest *lg = file->private_data; | 449 | struct lguest *lg = file->private_data; |
| @@ -338,8 +453,10 @@ static int close(struct inode *inode, struct file *file) | |||
| 338 | if (!lg) | 453 | if (!lg) |
| 339 | return 0; | 454 | return 0; |
| 340 | 455 | ||
| 341 | /* We need the big lock, to protect from inter-guest I/O and other | 456 | /* |
| 342 | * Launchers initializing guests. */ | 457 | * We need the big lock, to protect from inter-guest I/O and other |
| 458 | * Launchers initializing guests. | ||
| 459 | */ | ||
| 343 | mutex_lock(&lguest_lock); | 460 | mutex_lock(&lguest_lock); |
| 344 | 461 | ||
| 345 | /* Free up the shadow page tables for the Guest. */ | 462 | /* Free up the shadow page tables for the Guest. */ |
| @@ -350,8 +467,10 @@ static int close(struct inode *inode, struct file *file) | |||
| 350 | hrtimer_cancel(&lg->cpus[i].hrt); | 467 | hrtimer_cancel(&lg->cpus[i].hrt); |
| 351 | /* We can free up the register page we allocated. */ | 468 | /* We can free up the register page we allocated. */ |
| 352 | free_page(lg->cpus[i].regs_page); | 469 | free_page(lg->cpus[i].regs_page); |
| 353 | /* Now all the memory cleanups are done, it's safe to release | 470 | /* |
| 354 | * the Launcher's memory management structure. */ | 471 | * Now all the memory cleanups are done, it's safe to release |
| 472 | * the Launcher's memory management structure. | ||
| 473 | */ | ||
| 355 | mmput(lg->cpus[i].mm); | 474 | mmput(lg->cpus[i].mm); |
| 356 | } | 475 | } |
| 357 | 476 | ||
| @@ -360,8 +479,10 @@ static int close(struct inode *inode, struct file *file) | |||
| 360 | eventfd_ctx_put(lg->eventfds->map[i].event); | 479 | eventfd_ctx_put(lg->eventfds->map[i].event); |
| 361 | kfree(lg->eventfds); | 480 | kfree(lg->eventfds); |
| 362 | 481 | ||
| 363 | /* If lg->dead doesn't contain an error code it will be NULL or a | 482 | /* |
| 364 | * kmalloc()ed string, either of which is ok to hand to kfree(). */ | 483 | * If lg->dead doesn't contain an error code it will be NULL or a |
| 484 | * kmalloc()ed string, either of which is ok to hand to kfree(). | ||
| 485 | */ | ||
| 365 | if (!IS_ERR(lg->dead)) | 486 | if (!IS_ERR(lg->dead)) |
| 366 | kfree(lg->dead); | 487 | kfree(lg->dead); |
| 367 | /* Free the memory allocated to the lguest_struct */ | 488 | /* Free the memory allocated to the lguest_struct */ |
| @@ -385,7 +506,8 @@ static int close(struct inode *inode, struct file *file) | |||
| 385 | * | 506 | * |
| 386 | * We begin our understanding with the Host kernel interface which the Launcher | 507 | * We begin our understanding with the Host kernel interface which the Launcher |
| 387 | * uses: reading and writing a character device called /dev/lguest. All the | 508 | * uses: reading and writing a character device called /dev/lguest. All the |
| 388 | * work happens in the read(), write() and close() routines: */ | 509 | * work happens in the read(), write() and close() routines: |
| 510 | */ | ||
| 389 | static struct file_operations lguest_fops = { | 511 | static struct file_operations lguest_fops = { |
| 390 | .owner = THIS_MODULE, | 512 | .owner = THIS_MODULE, |
| 391 | .release = close, | 513 | .release = close, |
| @@ -393,8 +515,10 @@ static struct file_operations lguest_fops = { | |||
| 393 | .read = read, | 515 | .read = read, |
| 394 | }; | 516 | }; |
| 395 | 517 | ||
| 396 | /* This is a textbook example of a "misc" character device. Populate a "struct | 518 | /* |
| 397 | * miscdevice" and register it with misc_register(). */ | 519 | * This is a textbook example of a "misc" character device. Populate a "struct |
| 520 | * miscdevice" and register it with misc_register(). | ||
| 521 | */ | ||
| 398 | static struct miscdevice lguest_dev = { | 522 | static struct miscdevice lguest_dev = { |
| 399 | .minor = MISC_DYNAMIC_MINOR, | 523 | .minor = MISC_DYNAMIC_MINOR, |
| 400 | .name = "lguest", | 524 | .name = "lguest", |
diff --git a/drivers/lguest/page_tables.c b/drivers/lguest/page_tables.c index a6fe1abda240..a8d0aee3bc0e 100644 --- a/drivers/lguest/page_tables.c +++ b/drivers/lguest/page_tables.c | |||
| @@ -1,9 +1,11 @@ | |||
| 1 | /*P:700 The pagetable code, on the other hand, still shows the scars of | 1 | /*P:700 |
| 2 | * The pagetable code, on the other hand, still shows the scars of | ||
| 2 | * previous encounters. It's functional, and as neat as it can be in the | 3 | * previous encounters. It's functional, and as neat as it can be in the |
| 3 | * circumstances, but be wary, for these things are subtle and break easily. | 4 | * circumstances, but be wary, for these things are subtle and break easily. |
| 4 | * The Guest provides a virtual to physical mapping, but we can neither trust | 5 | * The Guest provides a virtual to physical mapping, but we can neither trust |
| 5 | * it nor use it: we verify and convert it here then point the CPU to the | 6 | * it nor use it: we verify and convert it here then point the CPU to the |
| 6 | * converted Guest pages when running the Guest. :*/ | 7 | * converted Guest pages when running the Guest. |
| 8 | :*/ | ||
| 7 | 9 | ||
| 8 | /* Copyright (C) Rusty Russell IBM Corporation 2006. | 10 | /* Copyright (C) Rusty Russell IBM Corporation 2006. |
| 9 | * GPL v2 and any later version */ | 11 | * GPL v2 and any later version */ |
| @@ -17,18 +19,20 @@ | |||
| 17 | #include <asm/bootparam.h> | 19 | #include <asm/bootparam.h> |
| 18 | #include "lg.h" | 20 | #include "lg.h" |
| 19 | 21 | ||
| 20 | /*M:008 We hold reference to pages, which prevents them from being swapped. | 22 | /*M:008 |
| 23 | * We hold reference to pages, which prevents them from being swapped. | ||
| 21 | * It'd be nice to have a callback in the "struct mm_struct" when Linux wants | 24 | * It'd be nice to have a callback in the "struct mm_struct" when Linux wants |
| 22 | * to swap out. If we had this, and a shrinker callback to trim PTE pages, we | 25 | * to swap out. If we had this, and a shrinker callback to trim PTE pages, we |
| 23 | * could probably consider launching Guests as non-root. :*/ | 26 | * could probably consider launching Guests as non-root. |
| 27 | :*/ | ||
| 24 | 28 | ||
| 25 | /*H:300 | 29 | /*H:300 |
| 26 | * The Page Table Code | 30 | * The Page Table Code |
| 27 | * | 31 | * |
| 28 | * We use two-level page tables for the Guest. If you're not entirely | 32 | * We use two-level page tables for the Guest, or three-level with PAE. If |
| 29 | * comfortable with virtual addresses, physical addresses and page tables then | 33 | * you're not entirely comfortable with virtual addresses, physical addresses |
| 30 | * I recommend you review arch/x86/lguest/boot.c's "Page Table Handling" (with | 34 | * and page tables then I recommend you review arch/x86/lguest/boot.c's "Page |
| 31 | * diagrams!). | 35 | * Table Handling" (with diagrams!). |
| 32 | * | 36 | * |
| 33 | * The Guest keeps page tables, but we maintain the actual ones here: these are | 37 | * The Guest keeps page tables, but we maintain the actual ones here: these are |
| 34 | * called "shadow" page tables. Which is a very Guest-centric name: these are | 38 | * called "shadow" page tables. Which is a very Guest-centric name: these are |
| @@ -45,16 +49,18 @@ | |||
| 45 | * (v) Flushing (throwing away) page tables, | 49 | * (v) Flushing (throwing away) page tables, |
| 46 | * (vi) Mapping the Switcher when the Guest is about to run, | 50 | * (vi) Mapping the Switcher when the Guest is about to run, |
| 47 | * (vii) Setting up the page tables initially. | 51 | * (vii) Setting up the page tables initially. |
| 48 | :*/ | 52 | :*/ |
| 49 | 53 | ||
| 50 | 54 | /* | |
| 51 | /* 1024 entries in a page table page maps 1024 pages: 4MB. The Switcher is | 55 | * The Switcher uses the complete top PTE page. That's 1024 PTE entries (4MB) |
| 52 | * conveniently placed at the top 4MB, so it uses a separate, complete PTE | 56 | * or 512 PTE entries with PAE (2MB). |
| 53 | * page. */ | 57 | */ |
| 54 | #define SWITCHER_PGD_INDEX (PTRS_PER_PGD - 1) | 58 | #define SWITCHER_PGD_INDEX (PTRS_PER_PGD - 1) |
| 55 | 59 | ||
| 56 | /* For PAE we need the PMD index as well. We use the last 2MB, so we | 60 | /* |
| 57 | * will need the last pmd entry of the last pmd page. */ | 61 | * For PAE we need the PMD index as well. We use the last 2MB, so we |
| 62 | * will need the last pmd entry of the last pmd page. | ||
| 63 | */ | ||
| 58 | #ifdef CONFIG_X86_PAE | 64 | #ifdef CONFIG_X86_PAE |
| 59 | #define SWITCHER_PMD_INDEX (PTRS_PER_PMD - 1) | 65 | #define SWITCHER_PMD_INDEX (PTRS_PER_PMD - 1) |
| 60 | #define RESERVE_MEM 2U | 66 | #define RESERVE_MEM 2U |
| @@ -64,14 +70,18 @@ | |||
| 64 | #define CHECK_GPGD_MASK _PAGE_TABLE | 70 | #define CHECK_GPGD_MASK _PAGE_TABLE |
| 65 | #endif | 71 | #endif |
| 66 | 72 | ||
| 67 | /* We actually need a separate PTE page for each CPU. Remember that after the | 73 | /* |
| 74 | * We actually need a separate PTE page for each CPU. Remember that after the | ||
| 68 | * Switcher code itself comes two pages for each CPU, and we don't want this | 75 | * Switcher code itself comes two pages for each CPU, and we don't want this |
| 69 | * CPU's guest to see the pages of any other CPU. */ | 76 | * CPU's guest to see the pages of any other CPU. |
| 77 | */ | ||
| 70 | static DEFINE_PER_CPU(pte_t *, switcher_pte_pages); | 78 | static DEFINE_PER_CPU(pte_t *, switcher_pte_pages); |
| 71 | #define switcher_pte_page(cpu) per_cpu(switcher_pte_pages, cpu) | 79 | #define switcher_pte_page(cpu) per_cpu(switcher_pte_pages, cpu) |
| 72 | 80 | ||
| 73 | /*H:320 The page table code is curly enough to need helper functions to keep it | 81 | /*H:320 |
| 74 | * clear and clean. | 82 | * The page table code is curly enough to need helper functions to keep it |
| 83 | * clear and clean. The kernel itself provides many of them; one advantage | ||
| 84 | * of insisting that the Guest and Host use the same CONFIG_PAE setting. | ||
| 75 | * | 85 | * |
| 76 | * There are two functions which return pointers to the shadow (aka "real") | 86 | * There are two functions which return pointers to the shadow (aka "real") |
| 77 | * page tables. | 87 | * page tables. |
| @@ -79,7 +89,8 @@ static DEFINE_PER_CPU(pte_t *, switcher_pte_pages); | |||
| 79 | * spgd_addr() takes the virtual address and returns a pointer to the top-level | 89 | * spgd_addr() takes the virtual address and returns a pointer to the top-level |
| 80 | * page directory entry (PGD) for that address. Since we keep track of several | 90 | * page directory entry (PGD) for that address. Since we keep track of several |
| 81 | * page tables, the "i" argument tells us which one we're interested in (it's | 91 | * page tables, the "i" argument tells us which one we're interested in (it's |
| 82 | * usually the current one). */ | 92 | * usually the current one). |
| 93 | */ | ||
| 83 | static pgd_t *spgd_addr(struct lg_cpu *cpu, u32 i, unsigned long vaddr) | 94 | static pgd_t *spgd_addr(struct lg_cpu *cpu, u32 i, unsigned long vaddr) |
| 84 | { | 95 | { |
| 85 | unsigned int index = pgd_index(vaddr); | 96 | unsigned int index = pgd_index(vaddr); |
| @@ -96,9 +107,11 @@ static pgd_t *spgd_addr(struct lg_cpu *cpu, u32 i, unsigned long vaddr) | |||
| 96 | } | 107 | } |
| 97 | 108 | ||
| 98 | #ifdef CONFIG_X86_PAE | 109 | #ifdef CONFIG_X86_PAE |
| 99 | /* This routine then takes the PGD entry given above, which contains the | 110 | /* |
| 111 | * This routine then takes the PGD entry given above, which contains the | ||
| 100 | * address of the PMD page. It then returns a pointer to the PMD entry for the | 112 | * address of the PMD page. It then returns a pointer to the PMD entry for the |
| 101 | * given address. */ | 113 | * given address. |
| 114 | */ | ||
| 102 | static pmd_t *spmd_addr(struct lg_cpu *cpu, pgd_t spgd, unsigned long vaddr) | 115 | static pmd_t *spmd_addr(struct lg_cpu *cpu, pgd_t spgd, unsigned long vaddr) |
| 103 | { | 116 | { |
| 104 | unsigned int index = pmd_index(vaddr); | 117 | unsigned int index = pmd_index(vaddr); |
| @@ -119,9 +132,11 @@ static pmd_t *spmd_addr(struct lg_cpu *cpu, pgd_t spgd, unsigned long vaddr) | |||
| 119 | } | 132 | } |
| 120 | #endif | 133 | #endif |
| 121 | 134 | ||
| 122 | /* This routine then takes the page directory entry returned above, which | 135 | /* |
| 136 | * This routine then takes the page directory entry returned above, which | ||
| 123 | * contains the address of the page table entry (PTE) page. It then returns a | 137 | * contains the address of the page table entry (PTE) page. It then returns a |
| 124 | * pointer to the PTE entry for the given address. */ | 138 | * pointer to the PTE entry for the given address. |
| 139 | */ | ||
| 125 | static pte_t *spte_addr(struct lg_cpu *cpu, pgd_t spgd, unsigned long vaddr) | 140 | static pte_t *spte_addr(struct lg_cpu *cpu, pgd_t spgd, unsigned long vaddr) |
| 126 | { | 141 | { |
| 127 | #ifdef CONFIG_X86_PAE | 142 | #ifdef CONFIG_X86_PAE |
| @@ -139,8 +154,10 @@ static pte_t *spte_addr(struct lg_cpu *cpu, pgd_t spgd, unsigned long vaddr) | |||
| 139 | return &page[pte_index(vaddr)]; | 154 | return &page[pte_index(vaddr)]; |
| 140 | } | 155 | } |
| 141 | 156 | ||
| 142 | /* These two functions just like the above two, except they access the Guest | 157 | /* |
| 143 | * page tables. Hence they return a Guest address. */ | 158 | * These functions are just like the above two, except they access the Guest |
| 159 | * page tables. Hence they return a Guest address. | ||
| 160 | */ | ||
| 144 | static unsigned long gpgd_addr(struct lg_cpu *cpu, unsigned long vaddr) | 161 | static unsigned long gpgd_addr(struct lg_cpu *cpu, unsigned long vaddr) |
| 145 | { | 162 | { |
| 146 | unsigned int index = vaddr >> (PGDIR_SHIFT); | 163 | unsigned int index = vaddr >> (PGDIR_SHIFT); |
| @@ -148,6 +165,7 @@ static unsigned long gpgd_addr(struct lg_cpu *cpu, unsigned long vaddr) | |||
| 148 | } | 165 | } |
| 149 | 166 | ||
| 150 | #ifdef CONFIG_X86_PAE | 167 | #ifdef CONFIG_X86_PAE |
| 168 | /* Follow the PGD to the PMD. */ | ||
| 151 | static unsigned long gpmd_addr(pgd_t gpgd, unsigned long vaddr) | 169 | static unsigned long gpmd_addr(pgd_t gpgd, unsigned long vaddr) |
| 152 | { | 170 | { |
| 153 | unsigned long gpage = pgd_pfn(gpgd) << PAGE_SHIFT; | 171 | unsigned long gpage = pgd_pfn(gpgd) << PAGE_SHIFT; |
| @@ -155,6 +173,7 @@ static unsigned long gpmd_addr(pgd_t gpgd, unsigned long vaddr) | |||
| 155 | return gpage + pmd_index(vaddr) * sizeof(pmd_t); | 173 | return gpage + pmd_index(vaddr) * sizeof(pmd_t); |
| 156 | } | 174 | } |
| 157 | 175 | ||
| 176 | /* Follow the PMD to the PTE. */ | ||
| 158 | static unsigned long gpte_addr(struct lg_cpu *cpu, | 177 | static unsigned long gpte_addr(struct lg_cpu *cpu, |
| 159 | pmd_t gpmd, unsigned long vaddr) | 178 | pmd_t gpmd, unsigned long vaddr) |
| 160 | { | 179 | { |
| @@ -164,6 +183,7 @@ static unsigned long gpte_addr(struct lg_cpu *cpu, | |||
| 164 | return gpage + pte_index(vaddr) * sizeof(pte_t); | 183 | return gpage + pte_index(vaddr) * sizeof(pte_t); |
| 165 | } | 184 | } |
| 166 | #else | 185 | #else |
| 186 | /* Follow the PGD to the PTE (no mid-level for !PAE). */ | ||
| 167 | static unsigned long gpte_addr(struct lg_cpu *cpu, | 187 | static unsigned long gpte_addr(struct lg_cpu *cpu, |
| 168 | pgd_t gpgd, unsigned long vaddr) | 188 | pgd_t gpgd, unsigned long vaddr) |
| 169 | { | 189 | { |
| @@ -175,17 +195,21 @@ static unsigned long gpte_addr(struct lg_cpu *cpu, | |||
| 175 | #endif | 195 | #endif |
| 176 | /*:*/ | 196 | /*:*/ |
| 177 | 197 | ||
| 178 | /*M:014 get_pfn is slow: we could probably try to grab batches of pages here as | 198 | /*M:014 |
| 179 | * an optimization (ie. pre-faulting). :*/ | 199 | * get_pfn is slow: we could probably try to grab batches of pages here as |
| 200 | * an optimization (ie. pre-faulting). | ||
| 201 | :*/ | ||
| 180 | 202 | ||
| 181 | /*H:350 This routine takes a page number given by the Guest and converts it to | 203 | /*H:350 |
| 204 | * This routine takes a page number given by the Guest and converts it to | ||
| 182 | * an actual, physical page number. It can fail for several reasons: the | 205 | * an actual, physical page number. It can fail for several reasons: the |
| 183 | * virtual address might not be mapped by the Launcher, the write flag is set | 206 | * virtual address might not be mapped by the Launcher, the write flag is set |
| 184 | * and the page is read-only, or the write flag was set and the page was | 207 | * and the page is read-only, or the write flag was set and the page was |
| 185 | * shared so had to be copied, but we ran out of memory. | 208 | * shared so had to be copied, but we ran out of memory. |
| 186 | * | 209 | * |
| 187 | * This holds a reference to the page, so release_pte() is careful to put that | 210 | * This holds a reference to the page, so release_pte() is careful to put that |
| 188 | * back. */ | 211 | * back. |
| 212 | */ | ||
| 189 | static unsigned long get_pfn(unsigned long virtpfn, int write) | 213 | static unsigned long get_pfn(unsigned long virtpfn, int write) |
| 190 | { | 214 | { |
| 191 | struct page *page; | 215 | struct page *page; |
| @@ -198,33 +222,41 @@ static unsigned long get_pfn(unsigned long virtpfn, int write) | |||
| 198 | return -1UL; | 222 | return -1UL; |
| 199 | } | 223 | } |
| 200 | 224 | ||
| 201 | /*H:340 Converting a Guest page table entry to a shadow (ie. real) page table | 225 | /*H:340 |
| 226 | * Converting a Guest page table entry to a shadow (ie. real) page table | ||
| 202 | * entry can be a little tricky. The flags are (almost) the same, but the | 227 | * entry can be a little tricky. The flags are (almost) the same, but the |
| 203 | * Guest PTE contains a virtual page number: the CPU needs the real page | 228 | * Guest PTE contains a virtual page number: the CPU needs the real page |
| 204 | * number. */ | 229 | * number. |
| 230 | */ | ||
| 205 | static pte_t gpte_to_spte(struct lg_cpu *cpu, pte_t gpte, int write) | 231 | static pte_t gpte_to_spte(struct lg_cpu *cpu, pte_t gpte, int write) |
| 206 | { | 232 | { |
| 207 | unsigned long pfn, base, flags; | 233 | unsigned long pfn, base, flags; |
| 208 | 234 | ||
| 209 | /* The Guest sets the global flag, because it thinks that it is using | 235 | /* |
| 236 | * The Guest sets the global flag, because it thinks that it is using | ||
| 210 | * PGE. We only told it to use PGE so it would tell us whether it was | 237 | * PGE. We only told it to use PGE so it would tell us whether it was |
| 211 | * flushing a kernel mapping or a userspace mapping. We don't actually | 238 | * flushing a kernel mapping or a userspace mapping. We don't actually |
| 212 | * use the global bit, so throw it away. */ | 239 | * use the global bit, so throw it away. |
| 240 | */ | ||
| 213 | flags = (pte_flags(gpte) & ~_PAGE_GLOBAL); | 241 | flags = (pte_flags(gpte) & ~_PAGE_GLOBAL); |
| 214 | 242 | ||
| 215 | /* The Guest's pages are offset inside the Launcher. */ | 243 | /* The Guest's pages are offset inside the Launcher. */ |
| 216 | base = (unsigned long)cpu->lg->mem_base / PAGE_SIZE; | 244 | base = (unsigned long)cpu->lg->mem_base / PAGE_SIZE; |
| 217 | 245 | ||
| 218 | /* We need a temporary "unsigned long" variable to hold the answer from | 246 | /* |
| 247 | * We need a temporary "unsigned long" variable to hold the answer from | ||
| 219 | * get_pfn(), because it returns 0xFFFFFFFF on failure, which wouldn't | 248 | * get_pfn(), because it returns 0xFFFFFFFF on failure, which wouldn't |
| 220 | * fit in spte.pfn. get_pfn() finds the real physical number of the | 249 | * fit in spte.pfn. get_pfn() finds the real physical number of the |
| 221 | * page, given the virtual number. */ | 250 | * page, given the virtual number. |
| 251 | */ | ||
| 222 | pfn = get_pfn(base + pte_pfn(gpte), write); | 252 | pfn = get_pfn(base + pte_pfn(gpte), write); |
| 223 | if (pfn == -1UL) { | 253 | if (pfn == -1UL) { |
| 224 | kill_guest(cpu, "failed to get page %lu", pte_pfn(gpte)); | 254 | kill_guest(cpu, "failed to get page %lu", pte_pfn(gpte)); |
| 225 | /* When we destroy the Guest, we'll go through the shadow page | 255 | /* |
| 256 | * When we destroy the Guest, we'll go through the shadow page | ||
| 226 | * tables and release_pte() them. Make sure we don't think | 257 | * tables and release_pte() them. Make sure we don't think |
| 227 | * this one is valid! */ | 258 | * this one is valid! |
| 259 | */ | ||
| 228 | flags = 0; | 260 | flags = 0; |
| 229 | } | 261 | } |
| 230 | /* Now we assemble our shadow PTE from the page number and flags. */ | 262 | /* Now we assemble our shadow PTE from the page number and flags. */ |
| @@ -234,8 +266,10 @@ static pte_t gpte_to_spte(struct lg_cpu *cpu, pte_t gpte, int write) | |||
| 234 | /*H:460 And to complete the chain, release_pte() looks like this: */ | 266 | /*H:460 And to complete the chain, release_pte() looks like this: */ |
| 235 | static void release_pte(pte_t pte) | 267 | static void release_pte(pte_t pte) |
| 236 | { | 268 | { |
| 237 | /* Remember that get_user_pages_fast() took a reference to the page, in | 269 | /* |
| 238 | * get_pfn()? We have to put it back now. */ | 270 | * Remember that get_user_pages_fast() took a reference to the page, in |
| 271 | * get_pfn()? We have to put it back now. | ||
| 272 | */ | ||
| 239 | if (pte_flags(pte) & _PAGE_PRESENT) | 273 | if (pte_flags(pte) & _PAGE_PRESENT) |
| 240 | put_page(pte_page(pte)); | 274 | put_page(pte_page(pte)); |
| 241 | } | 275 | } |
| @@ -273,7 +307,8 @@ static void check_gpmd(struct lg_cpu *cpu, pmd_t gpmd) | |||
| 273 | * and return to the Guest without it knowing. | 307 | * and return to the Guest without it knowing. |
| 274 | * | 308 | * |
| 275 | * If we fixed up the fault (ie. we mapped the address), this routine returns | 309 | * If we fixed up the fault (ie. we mapped the address), this routine returns |
| 276 | * true. Otherwise, it was a real fault and we need to tell the Guest. */ | 310 | * true. Otherwise, it was a real fault and we need to tell the Guest. |
| 311 | */ | ||
| 277 | bool demand_page(struct lg_cpu *cpu, unsigned long vaddr, int errcode) | 312 | bool demand_page(struct lg_cpu *cpu, unsigned long vaddr, int errcode) |
| 278 | { | 313 | { |
| 279 | pgd_t gpgd; | 314 | pgd_t gpgd; |
| @@ -282,6 +317,7 @@ bool demand_page(struct lg_cpu *cpu, unsigned long vaddr, int errcode) | |||
| 282 | pte_t gpte; | 317 | pte_t gpte; |
| 283 | pte_t *spte; | 318 | pte_t *spte; |
| 284 | 319 | ||
| 320 | /* Mid level for PAE. */ | ||
| 285 | #ifdef CONFIG_X86_PAE | 321 | #ifdef CONFIG_X86_PAE |
| 286 | pmd_t *spmd; | 322 | pmd_t *spmd; |
| 287 | pmd_t gpmd; | 323 | pmd_t gpmd; |
| @@ -298,22 +334,26 @@ bool demand_page(struct lg_cpu *cpu, unsigned long vaddr, int errcode) | |||
| 298 | if (!(pgd_flags(*spgd) & _PAGE_PRESENT)) { | 334 | if (!(pgd_flags(*spgd) & _PAGE_PRESENT)) { |
| 299 | /* No shadow entry: allocate a new shadow PTE page. */ | 335 | /* No shadow entry: allocate a new shadow PTE page. */ |
| 300 | unsigned long ptepage = get_zeroed_page(GFP_KERNEL); | 336 | unsigned long ptepage = get_zeroed_page(GFP_KERNEL); |
| 301 | /* This is not really the Guest's fault, but killing it is | 337 | /* |
| 302 | * simple for this corner case. */ | 338 | * This is not really the Guest's fault, but killing it is |
| 339 | * simple for this corner case. | ||
| 340 | */ | ||
| 303 | if (!ptepage) { | 341 | if (!ptepage) { |
| 304 | kill_guest(cpu, "out of memory allocating pte page"); | 342 | kill_guest(cpu, "out of memory allocating pte page"); |
| 305 | return false; | 343 | return false; |
| 306 | } | 344 | } |
| 307 | /* We check that the Guest pgd is OK. */ | 345 | /* We check that the Guest pgd is OK. */ |
| 308 | check_gpgd(cpu, gpgd); | 346 | check_gpgd(cpu, gpgd); |
| 309 | /* And we copy the flags to the shadow PGD entry. The page | 347 | /* |
| 310 | * number in the shadow PGD is the page we just allocated. */ | 348 | * And we copy the flags to the shadow PGD entry. The page |
| 349 | * number in the shadow PGD is the page we just allocated. | ||
| 350 | */ | ||
| 311 | set_pgd(spgd, __pgd(__pa(ptepage) | pgd_flags(gpgd))); | 351 | set_pgd(spgd, __pgd(__pa(ptepage) | pgd_flags(gpgd))); |
| 312 | } | 352 | } |
| 313 | 353 | ||
| 314 | #ifdef CONFIG_X86_PAE | 354 | #ifdef CONFIG_X86_PAE |
| 315 | gpmd = lgread(cpu, gpmd_addr(gpgd, vaddr), pmd_t); | 355 | gpmd = lgread(cpu, gpmd_addr(gpgd, vaddr), pmd_t); |
| 316 | /* middle level not present? We can't map it in. */ | 356 | /* Middle level not present? We can't map it in. */ |
| 317 | if (!(pmd_flags(gpmd) & _PAGE_PRESENT)) | 357 | if (!(pmd_flags(gpmd) & _PAGE_PRESENT)) |
| 318 | return false; | 358 | return false; |
| 319 | 359 | ||
| @@ -324,8 +364,10 @@ bool demand_page(struct lg_cpu *cpu, unsigned long vaddr, int errcode) | |||
| 324 | /* No shadow entry: allocate a new shadow PTE page. */ | 364 | /* No shadow entry: allocate a new shadow PTE page. */ |
| 325 | unsigned long ptepage = get_zeroed_page(GFP_KERNEL); | 365 | unsigned long ptepage = get_zeroed_page(GFP_KERNEL); |
| 326 | 366 | ||
| 327 | /* This is not really the Guest's fault, but killing it is | 367 | /* |
| 328 | * simple for this corner case. */ | 368 | * This is not really the Guest's fault, but killing it is |
| 369 | * simple for this corner case. | ||
| 370 | */ | ||
| 329 | if (!ptepage) { | 371 | if (!ptepage) { |
| 330 | kill_guest(cpu, "out of memory allocating pte page"); | 372 | kill_guest(cpu, "out of memory allocating pte page"); |
| 331 | return false; | 373 | return false; |
| @@ -334,27 +376,37 @@ bool demand_page(struct lg_cpu *cpu, unsigned long vaddr, int errcode) | |||
| 334 | /* We check that the Guest pmd is OK. */ | 376 | /* We check that the Guest pmd is OK. */ |
| 335 | check_gpmd(cpu, gpmd); | 377 | check_gpmd(cpu, gpmd); |
| 336 | 378 | ||
| 337 | /* And we copy the flags to the shadow PMD entry. The page | 379 | /* |
| 338 | * number in the shadow PMD is the page we just allocated. */ | 380 | * And we copy the flags to the shadow PMD entry. The page |
| 381 | * number in the shadow PMD is the page we just allocated. | ||
| 382 | */ | ||
| 339 | native_set_pmd(spmd, __pmd(__pa(ptepage) | pmd_flags(gpmd))); | 383 | native_set_pmd(spmd, __pmd(__pa(ptepage) | pmd_flags(gpmd))); |
| 340 | } | 384 | } |
| 341 | 385 | ||
| 342 | /* OK, now we look at the lower level in the Guest page table: keep its | 386 | /* |
| 343 | * address, because we might update it later. */ | 387 | * OK, now we look at the lower level in the Guest page table: keep its |
| 388 | * address, because we might update it later. | ||
| 389 | */ | ||
| 344 | gpte_ptr = gpte_addr(cpu, gpmd, vaddr); | 390 | gpte_ptr = gpte_addr(cpu, gpmd, vaddr); |
| 345 | #else | 391 | #else |
| 346 | /* OK, now we look at the lower level in the Guest page table: keep its | 392 | /* |
| 347 | * address, because we might update it later. */ | 393 | * OK, now we look at the lower level in the Guest page table: keep its |
| 394 | * address, because we might update it later. | ||
| 395 | */ | ||
| 348 | gpte_ptr = gpte_addr(cpu, gpgd, vaddr); | 396 | gpte_ptr = gpte_addr(cpu, gpgd, vaddr); |
| 349 | #endif | 397 | #endif |
| 398 | |||
| 399 | /* Read the actual PTE value. */ | ||
| 350 | gpte = lgread(cpu, gpte_ptr, pte_t); | 400 | gpte = lgread(cpu, gpte_ptr, pte_t); |
| 351 | 401 | ||
| 352 | /* If this page isn't in the Guest page tables, we can't page it in. */ | 402 | /* If this page isn't in the Guest page tables, we can't page it in. */ |
| 353 | if (!(pte_flags(gpte) & _PAGE_PRESENT)) | 403 | if (!(pte_flags(gpte) & _PAGE_PRESENT)) |
| 354 | return false; | 404 | return false; |
| 355 | 405 | ||
| 356 | /* Check they're not trying to write to a page the Guest wants | 406 | /* |
| 357 | * read-only (bit 2 of errcode == write). */ | 407 | * Check they're not trying to write to a page the Guest wants |
| 408 | * read-only (bit 2 of errcode == write). | ||
| 409 | */ | ||
| 358 | if ((errcode & 2) && !(pte_flags(gpte) & _PAGE_RW)) | 410 | if ((errcode & 2) && !(pte_flags(gpte) & _PAGE_RW)) |
| 359 | return false; | 411 | return false; |
| 360 | 412 | ||
| @@ -362,8 +414,10 @@ bool demand_page(struct lg_cpu *cpu, unsigned long vaddr, int errcode) | |||
| 362 | if ((errcode & 4) && !(pte_flags(gpte) & _PAGE_USER)) | 414 | if ((errcode & 4) && !(pte_flags(gpte) & _PAGE_USER)) |
| 363 | return false; | 415 | return false; |
| 364 | 416 | ||
| 365 | /* Check that the Guest PTE flags are OK, and the page number is below | 417 | /* |
| 366 | * the pfn_limit (ie. not mapping the Launcher binary). */ | 418 | * Check that the Guest PTE flags are OK, and the page number is below |
| 419 | * the pfn_limit (ie. not mapping the Launcher binary). | ||
| 420 | */ | ||
| 367 | check_gpte(cpu, gpte); | 421 | check_gpte(cpu, gpte); |
| 368 | 422 | ||
| 369 | /* Add the _PAGE_ACCESSED and (for a write) _PAGE_DIRTY flag */ | 423 | /* Add the _PAGE_ACCESSED and (for a write) _PAGE_DIRTY flag */ |
| @@ -373,29 +427,40 @@ bool demand_page(struct lg_cpu *cpu, unsigned long vaddr, int errcode) | |||
| 373 | 427 | ||
| 374 | /* Get the pointer to the shadow PTE entry we're going to set. */ | 428 | /* Get the pointer to the shadow PTE entry we're going to set. */ |
| 375 | spte = spte_addr(cpu, *spgd, vaddr); | 429 | spte = spte_addr(cpu, *spgd, vaddr); |
| 376 | /* If there was a valid shadow PTE entry here before, we release it. | 430 | |
| 377 | * This can happen with a write to a previously read-only entry. */ | 431 | /* |
| 432 | * If there was a valid shadow PTE entry here before, we release it. | ||
| 433 | * This can happen with a write to a previously read-only entry. | ||
| 434 | */ | ||
| 378 | release_pte(*spte); | 435 | release_pte(*spte); |
| 379 | 436 | ||
| 380 | /* If this is a write, we insist that the Guest page is writable (the | 437 | /* |
| 381 | * final arg to gpte_to_spte()). */ | 438 | * If this is a write, we insist that the Guest page is writable (the |
| 439 | * final arg to gpte_to_spte()). | ||
| 440 | */ | ||
| 382 | if (pte_dirty(gpte)) | 441 | if (pte_dirty(gpte)) |
| 383 | *spte = gpte_to_spte(cpu, gpte, 1); | 442 | *spte = gpte_to_spte(cpu, gpte, 1); |
| 384 | else | 443 | else |
| 385 | /* If this is a read, don't set the "writable" bit in the page | 444 | /* |
| 445 | * If this is a read, don't set the "writable" bit in the page | ||
| 386 | * table entry, even if the Guest says it's writable. That way | 446 | * table entry, even if the Guest says it's writable. That way |
| 387 | * we will come back here when a write does actually occur, so | 447 | * we will come back here when a write does actually occur, so |
| 388 | * we can update the Guest's _PAGE_DIRTY flag. */ | 448 | * we can update the Guest's _PAGE_DIRTY flag. |
| 449 | */ | ||
| 389 | native_set_pte(spte, gpte_to_spte(cpu, pte_wrprotect(gpte), 0)); | 450 | native_set_pte(spte, gpte_to_spte(cpu, pte_wrprotect(gpte), 0)); |
| 390 | 451 | ||
| 391 | /* Finally, we write the Guest PTE entry back: we've set the | 452 | /* |
| 392 | * _PAGE_ACCESSED and maybe the _PAGE_DIRTY flags. */ | 453 | * Finally, we write the Guest PTE entry back: we've set the |
| 454 | * _PAGE_ACCESSED and maybe the _PAGE_DIRTY flags. | ||
| 455 | */ | ||
| 393 | lgwrite(cpu, gpte_ptr, pte_t, gpte); | 456 | lgwrite(cpu, gpte_ptr, pte_t, gpte); |
| 394 | 457 | ||
| 395 | /* The fault is fixed, the page table is populated, the mapping | 458 | /* |
| 459 | * The fault is fixed, the page table is populated, the mapping | ||
| 396 | * manipulated, the result returned and the code complete. A small | 460 | * manipulated, the result returned and the code complete. A small |
| 397 | * delay and a trace of alliteration are the only indications the Guest | 461 | * delay and a trace of alliteration are the only indications the Guest |
| 398 | * has that a page fault occurred at all. */ | 462 | * has that a page fault occurred at all. |
| 463 | */ | ||
| 399 | return true; | 464 | return true; |
| 400 | } | 465 | } |
| 401 | 466 | ||
| @@ -408,7 +473,8 @@ bool demand_page(struct lg_cpu *cpu, unsigned long vaddr, int errcode) | |||
| 408 | * mapped, so it's overkill. | 473 | * mapped, so it's overkill. |
| 409 | * | 474 | * |
| 410 | * This is a quick version which answers the question: is this virtual address | 475 | * This is a quick version which answers the question: is this virtual address |
| 411 | * mapped by the shadow page tables, and is it writable? */ | 476 | * mapped by the shadow page tables, and is it writable? |
| 477 | */ | ||
| 412 | static bool page_writable(struct lg_cpu *cpu, unsigned long vaddr) | 478 | static bool page_writable(struct lg_cpu *cpu, unsigned long vaddr) |
| 413 | { | 479 | { |
| 414 | pgd_t *spgd; | 480 | pgd_t *spgd; |
| @@ -428,21 +494,26 @@ static bool page_writable(struct lg_cpu *cpu, unsigned long vaddr) | |||
| 428 | return false; | 494 | return false; |
| 429 | #endif | 495 | #endif |
| 430 | 496 | ||
| 431 | /* Check the flags on the pte entry itself: it must be present and | 497 | /* |
| 432 | * writable. */ | 498 | * Check the flags on the pte entry itself: it must be present and |
| 499 | * writable. | ||
| 500 | */ | ||
| 433 | flags = pte_flags(*(spte_addr(cpu, *spgd, vaddr))); | 501 | flags = pte_flags(*(spte_addr(cpu, *spgd, vaddr))); |
| 434 | 502 | ||
| 435 | return (flags & (_PAGE_PRESENT|_PAGE_RW)) == (_PAGE_PRESENT|_PAGE_RW); | 503 | return (flags & (_PAGE_PRESENT|_PAGE_RW)) == (_PAGE_PRESENT|_PAGE_RW); |
| 436 | } | 504 | } |
| 437 | 505 | ||
| 438 | /* So, when pin_stack_pages() asks us to pin a page, we check if it's already | 506 | /* |
| 507 | * So, when pin_stack_pages() asks us to pin a page, we check if it's already | ||
| 439 | * in the page tables, and if not, we call demand_page() with error code 2 | 508 | * in the page tables, and if not, we call demand_page() with error code 2 |
| 440 | * (meaning "write"). */ | 509 | * (meaning "write"). |
| 510 | */ | ||
| 441 | void pin_page(struct lg_cpu *cpu, unsigned long vaddr) | 511 | void pin_page(struct lg_cpu *cpu, unsigned long vaddr) |
| 442 | { | 512 | { |
| 443 | if (!page_writable(cpu, vaddr) && !demand_page(cpu, vaddr, 2)) | 513 | if (!page_writable(cpu, vaddr) && !demand_page(cpu, vaddr, 2)) |
| 444 | kill_guest(cpu, "bad stack page %#lx", vaddr); | 514 | kill_guest(cpu, "bad stack page %#lx", vaddr); |
| 445 | } | 515 | } |
| 516 | /*:*/ | ||
| 446 | 517 | ||
| 447 | #ifdef CONFIG_X86_PAE | 518 | #ifdef CONFIG_X86_PAE |
| 448 | static void release_pmd(pmd_t *spmd) | 519 | static void release_pmd(pmd_t *spmd) |
| @@ -479,15 +550,21 @@ static void release_pgd(pgd_t *spgd) | |||
| 479 | } | 550 | } |
| 480 | 551 | ||
| 481 | #else /* !CONFIG_X86_PAE */ | 552 | #else /* !CONFIG_X86_PAE */ |
| 482 | /*H:450 If we chase down the release_pgd() code, it looks like this: */ | 553 | /*H:450 |
| 554 | * If we chase down the release_pgd() code, the non-PAE version looks like | ||
| 555 | * this. The PAE version is almost identical, but instead of calling | ||
| 556 | * release_pte it calls release_pmd(), which looks much like this. | ||
| 557 | */ | ||
| 483 | static void release_pgd(pgd_t *spgd) | 558 | static void release_pgd(pgd_t *spgd) |
| 484 | { | 559 | { |
| 485 | /* If the entry's not present, there's nothing to release. */ | 560 | /* If the entry's not present, there's nothing to release. */ |
| 486 | if (pgd_flags(*spgd) & _PAGE_PRESENT) { | 561 | if (pgd_flags(*spgd) & _PAGE_PRESENT) { |
| 487 | unsigned int i; | 562 | unsigned int i; |
| 488 | /* Converting the pfn to find the actual PTE page is easy: turn | 563 | /* |
| 564 | * Converting the pfn to find the actual PTE page is easy: turn | ||
| 489 | * the page number into a physical address, then convert to a | 565 | * the page number into a physical address, then convert to a |
| 490 | * virtual address (easy for kernel pages like this one). */ | 566 | * virtual address (easy for kernel pages like this one). |
| 567 | */ | ||
| 491 | pte_t *ptepage = __va(pgd_pfn(*spgd) << PAGE_SHIFT); | 568 | pte_t *ptepage = __va(pgd_pfn(*spgd) << PAGE_SHIFT); |
| 492 | /* For each entry in the page, we might need to release it. */ | 569 | /* For each entry in the page, we might need to release it. */ |
| 493 | for (i = 0; i < PTRS_PER_PTE; i++) | 570 | for (i = 0; i < PTRS_PER_PTE; i++) |
| @@ -499,9 +576,12 @@ static void release_pgd(pgd_t *spgd) | |||
| 499 | } | 576 | } |
| 500 | } | 577 | } |
| 501 | #endif | 578 | #endif |
| 502 | /*H:445 We saw flush_user_mappings() twice: once from the flush_user_mappings() | 579 | |
| 580 | /*H:445 | ||
| 581 | * We saw flush_user_mappings() twice: once from the flush_user_mappings() | ||
| 503 | * hypercall and once in new_pgdir() when we re-used a top-level pgdir page. | 582 | * hypercall and once in new_pgdir() when we re-used a top-level pgdir page. |
| 504 | * It simply releases every PTE page from 0 up to the Guest's kernel address. */ | 583 | * It simply releases every PTE page from 0 up to the Guest's kernel address. |
| 584 | */ | ||
| 505 | static void flush_user_mappings(struct lguest *lg, int idx) | 585 | static void flush_user_mappings(struct lguest *lg, int idx) |
| 506 | { | 586 | { |
| 507 | unsigned int i; | 587 | unsigned int i; |
| @@ -510,10 +590,12 @@ static void flush_user_mappings(struct lguest *lg, int idx) | |||
| 510 | release_pgd(lg->pgdirs[idx].pgdir + i); | 590 | release_pgd(lg->pgdirs[idx].pgdir + i); |
| 511 | } | 591 | } |
| 512 | 592 | ||
| 513 | /*H:440 (v) Flushing (throwing away) page tables, | 593 | /*H:440 |
| 594 | * (v) Flushing (throwing away) page tables, | ||
| 514 | * | 595 | * |
| 515 | * The Guest has a hypercall to throw away the page tables: it's used when a | 596 | * The Guest has a hypercall to throw away the page tables: it's used when a |
| 516 | * large number of mappings have been changed. */ | 597 | * large number of mappings have been changed. |
| 598 | */ | ||
| 517 | void guest_pagetable_flush_user(struct lg_cpu *cpu) | 599 | void guest_pagetable_flush_user(struct lg_cpu *cpu) |
| 518 | { | 600 | { |
| 519 | /* Drop the userspace part of the current page table. */ | 601 | /* Drop the userspace part of the current page table. */ |
| @@ -551,9 +633,11 @@ unsigned long guest_pa(struct lg_cpu *cpu, unsigned long vaddr) | |||
| 551 | return pte_pfn(gpte) * PAGE_SIZE | (vaddr & ~PAGE_MASK); | 633 | return pte_pfn(gpte) * PAGE_SIZE | (vaddr & ~PAGE_MASK); |
| 552 | } | 634 | } |
| 553 | 635 | ||
| 554 | /* We keep several page tables. This is a simple routine to find the page | 636 | /* |
| 637 | * We keep several page tables. This is a simple routine to find the page | ||
| 555 | * table (if any) corresponding to this top-level address the Guest has given | 638 | * table (if any) corresponding to this top-level address the Guest has given |
| 556 | * us. */ | 639 | * us. |
| 640 | */ | ||
| 557 | static unsigned int find_pgdir(struct lguest *lg, unsigned long pgtable) | 641 | static unsigned int find_pgdir(struct lguest *lg, unsigned long pgtable) |
| 558 | { | 642 | { |
| 559 | unsigned int i; | 643 | unsigned int i; |
| @@ -563,9 +647,11 @@ static unsigned int find_pgdir(struct lguest *lg, unsigned long pgtable) | |||
| 563 | return i; | 647 | return i; |
| 564 | } | 648 | } |
| 565 | 649 | ||
| 566 | /*H:435 And this is us, creating the new page directory. If we really do | 650 | /*H:435 |
| 651 | * And this is us, creating the new page directory. If we really do | ||
| 567 | * allocate a new one (and so the kernel parts are not there), we set | 652 | * allocate a new one (and so the kernel parts are not there), we set |
| 568 | * blank_pgdir. */ | 653 | * blank_pgdir. |
| 654 | */ | ||
| 569 | static unsigned int new_pgdir(struct lg_cpu *cpu, | 655 | static unsigned int new_pgdir(struct lg_cpu *cpu, |
| 570 | unsigned long gpgdir, | 656 | unsigned long gpgdir, |
| 571 | int *blank_pgdir) | 657 | int *blank_pgdir) |
| @@ -575,8 +661,10 @@ static unsigned int new_pgdir(struct lg_cpu *cpu, | |||
| 575 | pmd_t *pmd_table; | 661 | pmd_t *pmd_table; |
| 576 | #endif | 662 | #endif |
| 577 | 663 | ||
| 578 | /* We pick one entry at random to throw out. Choosing the Least | 664 | /* |
| 579 | * Recently Used might be better, but this is easy. */ | 665 | * We pick one entry at random to throw out. Choosing the Least |
| 666 | * Recently Used might be better, but this is easy. | ||
| 667 | */ | ||
| 580 | next = random32() % ARRAY_SIZE(cpu->lg->pgdirs); | 668 | next = random32() % ARRAY_SIZE(cpu->lg->pgdirs); |
| 581 | /* If it's never been allocated at all before, try now. */ | 669 | /* If it's never been allocated at all before, try now. */ |
| 582 | if (!cpu->lg->pgdirs[next].pgdir) { | 670 | if (!cpu->lg->pgdirs[next].pgdir) { |
| @@ -587,8 +675,10 @@ static unsigned int new_pgdir(struct lg_cpu *cpu, | |||
| 587 | next = cpu->cpu_pgd; | 675 | next = cpu->cpu_pgd; |
| 588 | else { | 676 | else { |
| 589 | #ifdef CONFIG_X86_PAE | 677 | #ifdef CONFIG_X86_PAE |
| 590 | /* In PAE mode, allocate a pmd page and populate the | 678 | /* |
| 591 | * last pgd entry. */ | 679 | * In PAE mode, allocate a pmd page and populate the |
| 680 | * last pgd entry. | ||
| 681 | */ | ||
| 592 | pmd_table = (pmd_t *)get_zeroed_page(GFP_KERNEL); | 682 | pmd_table = (pmd_t *)get_zeroed_page(GFP_KERNEL); |
| 593 | if (!pmd_table) { | 683 | if (!pmd_table) { |
| 594 | free_page((long)cpu->lg->pgdirs[next].pgdir); | 684 | free_page((long)cpu->lg->pgdirs[next].pgdir); |
| @@ -598,8 +688,10 @@ static unsigned int new_pgdir(struct lg_cpu *cpu, | |||
| 598 | set_pgd(cpu->lg->pgdirs[next].pgdir + | 688 | set_pgd(cpu->lg->pgdirs[next].pgdir + |
| 599 | SWITCHER_PGD_INDEX, | 689 | SWITCHER_PGD_INDEX, |
| 600 | __pgd(__pa(pmd_table) | _PAGE_PRESENT)); | 690 | __pgd(__pa(pmd_table) | _PAGE_PRESENT)); |
| 601 | /* This is a blank page, so there are no kernel | 691 | /* |
| 602 | * mappings: caller must map the stack! */ | 692 | * This is a blank page, so there are no kernel |
| 693 | * mappings: caller must map the stack! | ||
| 694 | */ | ||
| 603 | *blank_pgdir = 1; | 695 | *blank_pgdir = 1; |
| 604 | } | 696 | } |
| 605 | #else | 697 | #else |
| @@ -615,19 +707,23 @@ static unsigned int new_pgdir(struct lg_cpu *cpu, | |||
| 615 | return next; | 707 | return next; |
| 616 | } | 708 | } |
| 617 | 709 | ||
| 618 | /*H:430 (iv) Switching page tables | 710 | /*H:430 |
| 711 | * (iv) Switching page tables | ||
| 619 | * | 712 | * |
| 620 | * Now we've seen all the page table setting and manipulation, let's see | 713 | * Now we've seen all the page table setting and manipulation, let's see |
| 621 | * what happens when the Guest changes page tables (ie. changes the top-level | 714 | * what happens when the Guest changes page tables (ie. changes the top-level |
| 622 | * pgdir). This occurs on almost every context switch. */ | 715 | * pgdir). This occurs on almost every context switch. |
| 716 | */ | ||
| 623 | void guest_new_pagetable(struct lg_cpu *cpu, unsigned long pgtable) | 717 | void guest_new_pagetable(struct lg_cpu *cpu, unsigned long pgtable) |
| 624 | { | 718 | { |
| 625 | int newpgdir, repin = 0; | 719 | int newpgdir, repin = 0; |
| 626 | 720 | ||
| 627 | /* Look to see if we have this one already. */ | 721 | /* Look to see if we have this one already. */ |
| 628 | newpgdir = find_pgdir(cpu->lg, pgtable); | 722 | newpgdir = find_pgdir(cpu->lg, pgtable); |
| 629 | /* If not, we allocate or mug an existing one: if it's a fresh one, | 723 | /* |
| 630 | * repin gets set to 1. */ | 724 | * If not, we allocate or mug an existing one: if it's a fresh one, |
| 725 | * repin gets set to 1. | ||
| 726 | */ | ||
| 631 | if (newpgdir == ARRAY_SIZE(cpu->lg->pgdirs)) | 727 | if (newpgdir == ARRAY_SIZE(cpu->lg->pgdirs)) |
| 632 | newpgdir = new_pgdir(cpu, pgtable, &repin); | 728 | newpgdir = new_pgdir(cpu, pgtable, &repin); |
| 633 | /* Change the current pgd index to the new one. */ | 729 | /* Change the current pgd index to the new one. */ |
| @@ -637,9 +733,11 @@ void guest_new_pagetable(struct lg_cpu *cpu, unsigned long pgtable) | |||
| 637 | pin_stack_pages(cpu); | 733 | pin_stack_pages(cpu); |
| 638 | } | 734 | } |
| 639 | 735 | ||
| 640 | /*H:470 Finally, a routine which throws away everything: all PGD entries in all | 736 | /*H:470 |
| 737 | * Finally, a routine which throws away everything: all PGD entries in all | ||
| 641 | * the shadow page tables, including the Guest's kernel mappings. This is used | 738 | * the shadow page tables, including the Guest's kernel mappings. This is used |
| 642 | * when we destroy the Guest. */ | 739 | * when we destroy the Guest. |
| 740 | */ | ||
| 643 | static void release_all_pagetables(struct lguest *lg) | 741 | static void release_all_pagetables(struct lguest *lg) |
| 644 | { | 742 | { |
| 645 | unsigned int i, j; | 743 | unsigned int i, j; |
| @@ -656,8 +754,10 @@ static void release_all_pagetables(struct lguest *lg) | |||
| 656 | spgd = lg->pgdirs[i].pgdir + SWITCHER_PGD_INDEX; | 754 | spgd = lg->pgdirs[i].pgdir + SWITCHER_PGD_INDEX; |
| 657 | pmdpage = __va(pgd_pfn(*spgd) << PAGE_SHIFT); | 755 | pmdpage = __va(pgd_pfn(*spgd) << PAGE_SHIFT); |
| 658 | 756 | ||
| 659 | /* And release the pmd entries of that pmd page, | 757 | /* |
| 660 | * except for the switcher pmd. */ | 758 | * And release the pmd entries of that pmd page, |
| 759 | * except for the switcher pmd. | ||
| 760 | */ | ||
| 661 | for (k = 0; k < SWITCHER_PMD_INDEX; k++) | 761 | for (k = 0; k < SWITCHER_PMD_INDEX; k++) |
| 662 | release_pmd(&pmdpage[k]); | 762 | release_pmd(&pmdpage[k]); |
| 663 | #endif | 763 | #endif |
| @@ -667,10 +767,12 @@ static void release_all_pagetables(struct lguest *lg) | |||
| 667 | } | 767 | } |
| 668 | } | 768 | } |
| 669 | 769 | ||
| 670 | /* We also throw away everything when a Guest tells us it's changed a kernel | 770 | /* |
| 771 | * We also throw away everything when a Guest tells us it's changed a kernel | ||
| 671 | * mapping. Since kernel mappings are in every page table, it's easiest to | 772 | * mapping. Since kernel mappings are in every page table, it's easiest to |
| 672 | * throw them all away. This traps the Guest in amber for a while as | 773 | * throw them all away. This traps the Guest in amber for a while as |
| 673 | * everything faults back in, but it's rare. */ | 774 | * everything faults back in, but it's rare. |
| 775 | */ | ||
| 674 | void guest_pagetable_clear_all(struct lg_cpu *cpu) | 776 | void guest_pagetable_clear_all(struct lg_cpu *cpu) |
| 675 | { | 777 | { |
| 676 | release_all_pagetables(cpu->lg); | 778 | release_all_pagetables(cpu->lg); |
| @@ -678,15 +780,19 @@ void guest_pagetable_clear_all(struct lg_cpu *cpu) | |||
| 678 | pin_stack_pages(cpu); | 780 | pin_stack_pages(cpu); |
| 679 | } | 781 | } |
| 680 | /*:*/ | 782 | /*:*/ |
| 681 | /*M:009 Since we throw away all mappings when a kernel mapping changes, our | 783 | |
| 784 | /*M:009 | ||
| 785 | * Since we throw away all mappings when a kernel mapping changes, our | ||
| 682 | * performance sucks for guests using highmem. In fact, a guest with | 786 | * performance sucks for guests using highmem. In fact, a guest with |
| 683 | * PAGE_OFFSET 0xc0000000 (the default) and more than about 700MB of RAM is | 787 | * PAGE_OFFSET 0xc0000000 (the default) and more than about 700MB of RAM is |
| 684 | * usually slower than a Guest with less memory. | 788 | * usually slower than a Guest with less memory. |
| 685 | * | 789 | * |
| 686 | * This, of course, cannot be fixed. It would take some kind of... well, I | 790 | * This, of course, cannot be fixed. It would take some kind of... well, I |
| 687 | * don't know, but the term "puissant code-fu" comes to mind. :*/ | 791 | * don't know, but the term "puissant code-fu" comes to mind. |
| 792 | :*/ | ||
| 688 | 793 | ||
| 689 | /*H:420 This is the routine which actually sets the page table entry for then | 794 | /*H:420 |
| 795 | * This is the routine which actually sets the page table entry for then | ||
| 690 | * "idx"'th shadow page table. | 796 | * "idx"'th shadow page table. |
| 691 | * | 797 | * |
| 692 | * Normally, we can just throw out the old entry and replace it with 0: if they | 798 | * Normally, we can just throw out the old entry and replace it with 0: if they |
| @@ -715,31 +821,36 @@ static void do_set_pte(struct lg_cpu *cpu, int idx, | |||
| 715 | spmd = spmd_addr(cpu, *spgd, vaddr); | 821 | spmd = spmd_addr(cpu, *spgd, vaddr); |
| 716 | if (pmd_flags(*spmd) & _PAGE_PRESENT) { | 822 | if (pmd_flags(*spmd) & _PAGE_PRESENT) { |
| 717 | #endif | 823 | #endif |
| 718 | /* Otherwise, we start by releasing | 824 | /* Otherwise, start by releasing the existing entry. */ |
| 719 | * the existing entry. */ | ||
| 720 | pte_t *spte = spte_addr(cpu, *spgd, vaddr); | 825 | pte_t *spte = spte_addr(cpu, *spgd, vaddr); |
| 721 | release_pte(*spte); | 826 | release_pte(*spte); |
| 722 | 827 | ||
| 723 | /* If they're setting this entry as dirty or accessed, | 828 | /* |
| 724 | * we might as well put that entry they've given us | 829 | * If they're setting this entry as dirty or accessed, |
| 725 | * in now. This shaves 10% off a | 830 | * we might as well put that entry they've given us in |
| 726 | * copy-on-write micro-benchmark. */ | 831 | * now. This shaves 10% off a copy-on-write |
| 832 | * micro-benchmark. | ||
| 833 | */ | ||
| 727 | if (pte_flags(gpte) & (_PAGE_DIRTY | _PAGE_ACCESSED)) { | 834 | if (pte_flags(gpte) & (_PAGE_DIRTY | _PAGE_ACCESSED)) { |
| 728 | check_gpte(cpu, gpte); | 835 | check_gpte(cpu, gpte); |
| 729 | native_set_pte(spte, | 836 | native_set_pte(spte, |
| 730 | gpte_to_spte(cpu, gpte, | 837 | gpte_to_spte(cpu, gpte, |
| 731 | pte_flags(gpte) & _PAGE_DIRTY)); | 838 | pte_flags(gpte) & _PAGE_DIRTY)); |
| 732 | } else | 839 | } else { |
| 733 | /* Otherwise kill it and we can demand_page() | 840 | /* |
| 734 | * it in later. */ | 841 | * Otherwise kill it and we can demand_page() |
| 842 | * it in later. | ||
| 843 | */ | ||
| 735 | native_set_pte(spte, __pte(0)); | 844 | native_set_pte(spte, __pte(0)); |
| 845 | } | ||
| 736 | #ifdef CONFIG_X86_PAE | 846 | #ifdef CONFIG_X86_PAE |
| 737 | } | 847 | } |
| 738 | #endif | 848 | #endif |
| 739 | } | 849 | } |
| 740 | } | 850 | } |
| 741 | 851 | ||
| 742 | /*H:410 Updating a PTE entry is a little trickier. | 852 | /*H:410 |
| 853 | * Updating a PTE entry is a little trickier. | ||
| 743 | * | 854 | * |
| 744 | * We keep track of several different page tables (the Guest uses one for each | 855 | * We keep track of several different page tables (the Guest uses one for each |
| 745 | * process, so it makes sense to cache at least a few). Each of these have | 856 | * process, so it makes sense to cache at least a few). Each of these have |
| @@ -748,12 +859,15 @@ static void do_set_pte(struct lg_cpu *cpu, int idx, | |||
| 748 | * all the page tables, not just the current one. This is rare. | 859 | * all the page tables, not just the current one. This is rare. |
| 749 | * | 860 | * |
| 750 | * The benefit is that when we have to track a new page table, we can keep all | 861 | * The benefit is that when we have to track a new page table, we can keep all |
| 751 | * the kernel mappings. This speeds up context switch immensely. */ | 862 | * the kernel mappings. This speeds up context switch immensely. |
| 863 | */ | ||
| 752 | void guest_set_pte(struct lg_cpu *cpu, | 864 | void guest_set_pte(struct lg_cpu *cpu, |
| 753 | unsigned long gpgdir, unsigned long vaddr, pte_t gpte) | 865 | unsigned long gpgdir, unsigned long vaddr, pte_t gpte) |
| 754 | { | 866 | { |
| 755 | /* Kernel mappings must be changed on all top levels. Slow, but doesn't | 867 | /* |
| 756 | * happen often. */ | 868 | * Kernel mappings must be changed on all top levels. Slow, but doesn't |
| 869 | * happen often. | ||
| 870 | */ | ||
| 757 | if (vaddr >= cpu->lg->kernel_address) { | 871 | if (vaddr >= cpu->lg->kernel_address) { |
| 758 | unsigned int i; | 872 | unsigned int i; |
| 759 | for (i = 0; i < ARRAY_SIZE(cpu->lg->pgdirs); i++) | 873 | for (i = 0; i < ARRAY_SIZE(cpu->lg->pgdirs); i++) |
| @@ -795,19 +909,25 @@ void guest_set_pgd(struct lguest *lg, unsigned long gpgdir, u32 idx) | |||
| 795 | /* ... throw it away. */ | 909 | /* ... throw it away. */ |
| 796 | release_pgd(lg->pgdirs[pgdir].pgdir + idx); | 910 | release_pgd(lg->pgdirs[pgdir].pgdir + idx); |
| 797 | } | 911 | } |
| 912 | |||
| 798 | #ifdef CONFIG_X86_PAE | 913 | #ifdef CONFIG_X86_PAE |
| 914 | /* For setting a mid-level, we just throw everything away. It's easy. */ | ||
| 799 | void guest_set_pmd(struct lguest *lg, unsigned long pmdp, u32 idx) | 915 | void guest_set_pmd(struct lguest *lg, unsigned long pmdp, u32 idx) |
| 800 | { | 916 | { |
| 801 | guest_pagetable_clear_all(&lg->cpus[0]); | 917 | guest_pagetable_clear_all(&lg->cpus[0]); |
| 802 | } | 918 | } |
| 803 | #endif | 919 | #endif |
| 804 | 920 | ||
| 805 | /* Once we know how much memory we have we can construct simple identity | 921 | /*H:505 |
| 806 | * (which set virtual == physical) and linear mappings | 922 | * To get through boot, we construct simple identity page mappings (which |
| 807 | * which will get the Guest far enough into the boot to create its own. | 923 | * set virtual == physical) and linear mappings which will get the Guest far |
| 924 | * enough into the boot to create its own. The linear mapping means we | ||
| 925 | * simplify the Guest boot, but it makes assumptions about their PAGE_OFFSET, | ||
| 926 | * as you'll see. | ||
| 808 | * | 927 | * |
| 809 | * We lay them out of the way, just below the initrd (which is why we need to | 928 | * We lay them out of the way, just below the initrd (which is why we need to |
| 810 | * know its size here). */ | 929 | * know its size here). |
| 930 | */ | ||
| 811 | static unsigned long setup_pagetables(struct lguest *lg, | 931 | static unsigned long setup_pagetables(struct lguest *lg, |
| 812 | unsigned long mem, | 932 | unsigned long mem, |
| 813 | unsigned long initrd_size) | 933 | unsigned long initrd_size) |
| @@ -825,8 +945,10 @@ static unsigned long setup_pagetables(struct lguest *lg, | |||
| 825 | unsigned int phys_linear; | 945 | unsigned int phys_linear; |
| 826 | #endif | 946 | #endif |
| 827 | 947 | ||
| 828 | /* We have mapped_pages frames to map, so we need | 948 | /* |
| 829 | * linear_pages page tables to map them. */ | 949 | * We have mapped_pages frames to map, so we need linear_pages page |
| 950 | * tables to map them. | ||
| 951 | */ | ||
| 830 | mapped_pages = mem / PAGE_SIZE; | 952 | mapped_pages = mem / PAGE_SIZE; |
| 831 | linear_pages = (mapped_pages + PTRS_PER_PTE - 1) / PTRS_PER_PTE; | 953 | linear_pages = (mapped_pages + PTRS_PER_PTE - 1) / PTRS_PER_PTE; |
| 832 | 954 | ||
| @@ -837,10 +959,16 @@ static unsigned long setup_pagetables(struct lguest *lg, | |||
| 837 | linear = (void *)pgdir - linear_pages * PAGE_SIZE; | 959 | linear = (void *)pgdir - linear_pages * PAGE_SIZE; |
| 838 | 960 | ||
| 839 | #ifdef CONFIG_X86_PAE | 961 | #ifdef CONFIG_X86_PAE |
| 962 | /* | ||
| 963 | * And the single mid page goes below that. We only use one, but | ||
| 964 | * that's enough to map 1G, which definitely gets us through boot. | ||
| 965 | */ | ||
| 840 | pmds = (void *)linear - PAGE_SIZE; | 966 | pmds = (void *)linear - PAGE_SIZE; |
| 841 | #endif | 967 | #endif |
| 842 | /* Linear mapping is easy: put every page's address into the | 968 | /* |
| 843 | * mapping in order. */ | 969 | * Linear mapping is easy: put every page's address into the |
| 970 | * mapping in order. | ||
| 971 | */ | ||
| 844 | for (i = 0; i < mapped_pages; i++) { | 972 | for (i = 0; i < mapped_pages; i++) { |
| 845 | pte_t pte; | 973 | pte_t pte; |
| 846 | pte = pfn_pte(i, __pgprot(_PAGE_PRESENT|_PAGE_RW|_PAGE_USER)); | 974 | pte = pfn_pte(i, __pgprot(_PAGE_PRESENT|_PAGE_RW|_PAGE_USER)); |
| @@ -848,11 +976,14 @@ static unsigned long setup_pagetables(struct lguest *lg, | |||
| 848 | return -EFAULT; | 976 | return -EFAULT; |
| 849 | } | 977 | } |
| 850 | 978 | ||
| 851 | /* The top level points to the linear page table pages above. | ||
| 852 | * We setup the identity and linear mappings here. */ | ||
| 853 | #ifdef CONFIG_X86_PAE | 979 | #ifdef CONFIG_X86_PAE |
| 980 | /* | ||
| 981 | * Make the Guest PMD entries point to the corresponding place in the | ||
| 982 | * linear mapping (up to one page worth of PMD). | ||
| 983 | */ | ||
| 854 | for (i = j = 0; i < mapped_pages && j < PTRS_PER_PMD; | 984 | for (i = j = 0; i < mapped_pages && j < PTRS_PER_PMD; |
| 855 | i += PTRS_PER_PTE, j++) { | 985 | i += PTRS_PER_PTE, j++) { |
| 986 | /* FIXME: native_set_pmd is overkill here. */ | ||
| 856 | native_set_pmd(&pmd, __pmd(((unsigned long)(linear + i) | 987 | native_set_pmd(&pmd, __pmd(((unsigned long)(linear + i) |
| 857 | - mem_base) | _PAGE_PRESENT | _PAGE_RW | _PAGE_USER)); | 988 | - mem_base) | _PAGE_PRESENT | _PAGE_RW | _PAGE_USER)); |
| 858 | 989 | ||
| @@ -860,18 +991,36 @@ static unsigned long setup_pagetables(struct lguest *lg, | |||
| 860 | return -EFAULT; | 991 | return -EFAULT; |
| 861 | } | 992 | } |
| 862 | 993 | ||
| 994 | /* One PGD entry, pointing to that PMD page. */ | ||
| 863 | set_pgd(&pgd, __pgd(((u32)pmds - mem_base) | _PAGE_PRESENT)); | 995 | set_pgd(&pgd, __pgd(((u32)pmds - mem_base) | _PAGE_PRESENT)); |
| 996 | /* Copy it in as the first PGD entry (ie. addresses 0-1G). */ | ||
| 864 | if (copy_to_user(&pgdir[0], &pgd, sizeof(pgd)) != 0) | 997 | if (copy_to_user(&pgdir[0], &pgd, sizeof(pgd)) != 0) |
| 865 | return -EFAULT; | 998 | return -EFAULT; |
| 999 | /* | ||
| 1000 | * And the third PGD entry (ie. addresses 3G-4G). | ||
| 1001 | * | ||
| 1002 | * FIXME: This assumes that PAGE_OFFSET for the Guest is 0xC0000000. | ||
| 1003 | */ | ||
| 866 | if (copy_to_user(&pgdir[3], &pgd, sizeof(pgd)) != 0) | 1004 | if (copy_to_user(&pgdir[3], &pgd, sizeof(pgd)) != 0) |
| 867 | return -EFAULT; | 1005 | return -EFAULT; |
| 868 | #else | 1006 | #else |
| 1007 | /* | ||
| 1008 | * The top level points to the linear page table pages above. | ||
| 1009 | * We setup the identity and linear mappings here. | ||
| 1010 | */ | ||
| 869 | phys_linear = (unsigned long)linear - mem_base; | 1011 | phys_linear = (unsigned long)linear - mem_base; |
| 870 | for (i = 0; i < mapped_pages; i += PTRS_PER_PTE) { | 1012 | for (i = 0; i < mapped_pages; i += PTRS_PER_PTE) { |
| 871 | pgd_t pgd; | 1013 | pgd_t pgd; |
| 1014 | /* | ||
| 1015 | * Create a PGD entry which points to the right part of the | ||
| 1016 | * linear PTE pages. | ||
| 1017 | */ | ||
| 872 | pgd = __pgd((phys_linear + i * sizeof(pte_t)) | | 1018 | pgd = __pgd((phys_linear + i * sizeof(pte_t)) | |
| 873 | (_PAGE_PRESENT | _PAGE_RW | _PAGE_USER)); | 1019 | (_PAGE_PRESENT | _PAGE_RW | _PAGE_USER)); |
| 874 | 1020 | ||
| 1021 | /* | ||
| 1022 | * Copy it into the PGD page at 0 and PAGE_OFFSET. | ||
| 1023 | */ | ||
| 875 | if (copy_to_user(&pgdir[i / PTRS_PER_PTE], &pgd, sizeof(pgd)) | 1024 | if (copy_to_user(&pgdir[i / PTRS_PER_PTE], &pgd, sizeof(pgd)) |
| 876 | || copy_to_user(&pgdir[pgd_index(PAGE_OFFSET) | 1025 | || copy_to_user(&pgdir[pgd_index(PAGE_OFFSET) |
| 877 | + i / PTRS_PER_PTE], | 1026 | + i / PTRS_PER_PTE], |
| @@ -880,15 +1029,19 @@ static unsigned long setup_pagetables(struct lguest *lg, | |||
| 880 | } | 1029 | } |
| 881 | #endif | 1030 | #endif |
| 882 | 1031 | ||
| 883 | /* We return the top level (guest-physical) address: remember where | 1032 | /* |
| 884 | * this is. */ | 1033 | * We return the top level (guest-physical) address: we remember where |
| 1034 | * this is to write it into lguest_data when the Guest initializes. | ||
| 1035 | */ | ||
| 885 | return (unsigned long)pgdir - mem_base; | 1036 | return (unsigned long)pgdir - mem_base; |
| 886 | } | 1037 | } |
| 887 | 1038 | ||
| 888 | /*H:500 (vii) Setting up the page tables initially. | 1039 | /*H:500 |
| 1040 | * (vii) Setting up the page tables initially. | ||
| 889 | * | 1041 | * |
| 890 | * When a Guest is first created, the Launcher tells us where the toplevel of | 1042 | * When a Guest is first created, the Launcher tells us where the toplevel of |
| 891 | * its first page table is. We set some things up here: */ | 1043 | * its first page table is. We set some things up here: |
| 1044 | */ | ||
| 892 | int init_guest_pagetable(struct lguest *lg) | 1045 | int init_guest_pagetable(struct lguest *lg) |
| 893 | { | 1046 | { |
| 894 | u64 mem; | 1047 | u64 mem; |
| @@ -898,21 +1051,27 @@ int init_guest_pagetable(struct lguest *lg) | |||
| 898 | pgd_t *pgd; | 1051 | pgd_t *pgd; |
| 899 | pmd_t *pmd_table; | 1052 | pmd_t *pmd_table; |
| 900 | #endif | 1053 | #endif |
| 901 | /* Get the Guest memory size and the ramdisk size from the boot header | 1054 | /* |
| 902 | * located at lg->mem_base (Guest address 0). */ | 1055 | * Get the Guest memory size and the ramdisk size from the boot header |
| 1056 | * located at lg->mem_base (Guest address 0). | ||
| 1057 | */ | ||
| 903 | if (copy_from_user(&mem, &boot->e820_map[0].size, sizeof(mem)) | 1058 | if (copy_from_user(&mem, &boot->e820_map[0].size, sizeof(mem)) |
| 904 | || get_user(initrd_size, &boot->hdr.ramdisk_size)) | 1059 | || get_user(initrd_size, &boot->hdr.ramdisk_size)) |
| 905 | return -EFAULT; | 1060 | return -EFAULT; |
| 906 | 1061 | ||
| 907 | /* We start on the first shadow page table, and give it a blank PGD | 1062 | /* |
| 908 | * page. */ | 1063 | * We start on the first shadow page table, and give it a blank PGD |
| 1064 | * page. | ||
| 1065 | */ | ||
| 909 | lg->pgdirs[0].gpgdir = setup_pagetables(lg, mem, initrd_size); | 1066 | lg->pgdirs[0].gpgdir = setup_pagetables(lg, mem, initrd_size); |
| 910 | if (IS_ERR_VALUE(lg->pgdirs[0].gpgdir)) | 1067 | if (IS_ERR_VALUE(lg->pgdirs[0].gpgdir)) |
| 911 | return lg->pgdirs[0].gpgdir; | 1068 | return lg->pgdirs[0].gpgdir; |
| 912 | lg->pgdirs[0].pgdir = (pgd_t *)get_zeroed_page(GFP_KERNEL); | 1069 | lg->pgdirs[0].pgdir = (pgd_t *)get_zeroed_page(GFP_KERNEL); |
| 913 | if (!lg->pgdirs[0].pgdir) | 1070 | if (!lg->pgdirs[0].pgdir) |
| 914 | return -ENOMEM; | 1071 | return -ENOMEM; |
| 1072 | |||
| 915 | #ifdef CONFIG_X86_PAE | 1073 | #ifdef CONFIG_X86_PAE |
| 1074 | /* For PAE, we also create the initial mid-level. */ | ||
| 916 | pgd = lg->pgdirs[0].pgdir; | 1075 | pgd = lg->pgdirs[0].pgdir; |
| 917 | pmd_table = (pmd_t *) get_zeroed_page(GFP_KERNEL); | 1076 | pmd_table = (pmd_t *) get_zeroed_page(GFP_KERNEL); |
| 918 | if (!pmd_table) | 1077 | if (!pmd_table) |
| @@ -921,27 +1080,33 @@ int init_guest_pagetable(struct lguest *lg) | |||
| 921 | set_pgd(pgd + SWITCHER_PGD_INDEX, | 1080 | set_pgd(pgd + SWITCHER_PGD_INDEX, |
| 922 | __pgd(__pa(pmd_table) | _PAGE_PRESENT)); | 1081 | __pgd(__pa(pmd_table) | _PAGE_PRESENT)); |
| 923 | #endif | 1082 | #endif |
| 1083 | |||
| 1084 | /* This is the current page table. */ | ||
| 924 | lg->cpus[0].cpu_pgd = 0; | 1085 | lg->cpus[0].cpu_pgd = 0; |
| 925 | return 0; | 1086 | return 0; |
| 926 | } | 1087 | } |
| 927 | 1088 | ||
| 928 | /* When the Guest calls LHCALL_LGUEST_INIT we do more setup. */ | 1089 | /*H:508 When the Guest calls LHCALL_LGUEST_INIT we do more setup. */ |
| 929 | void page_table_guest_data_init(struct lg_cpu *cpu) | 1090 | void page_table_guest_data_init(struct lg_cpu *cpu) |
| 930 | { | 1091 | { |
| 931 | /* We get the kernel address: above this is all kernel memory. */ | 1092 | /* We get the kernel address: above this is all kernel memory. */ |
| 932 | if (get_user(cpu->lg->kernel_address, | 1093 | if (get_user(cpu->lg->kernel_address, |
| 933 | &cpu->lg->lguest_data->kernel_address) | 1094 | &cpu->lg->lguest_data->kernel_address) |
| 934 | /* We tell the Guest that it can't use the top 2 or 4 MB | 1095 | /* |
| 935 | * of virtual addresses used by the Switcher. */ | 1096 | * We tell the Guest that it can't use the top 2 or 4 MB |
| 1097 | * of virtual addresses used by the Switcher. | ||
| 1098 | */ | ||
| 936 | || put_user(RESERVE_MEM * 1024 * 1024, | 1099 | || put_user(RESERVE_MEM * 1024 * 1024, |
| 937 | &cpu->lg->lguest_data->reserve_mem) | 1100 | &cpu->lg->lguest_data->reserve_mem) |
| 938 | || put_user(cpu->lg->pgdirs[0].gpgdir, | 1101 | || put_user(cpu->lg->pgdirs[0].gpgdir, |
| 939 | &cpu->lg->lguest_data->pgdir)) | 1102 | &cpu->lg->lguest_data->pgdir)) |
| 940 | kill_guest(cpu, "bad guest page %p", cpu->lg->lguest_data); | 1103 | kill_guest(cpu, "bad guest page %p", cpu->lg->lguest_data); |
| 941 | 1104 | ||
| 942 | /* In flush_user_mappings() we loop from 0 to | 1105 | /* |
| 1106 | * In flush_user_mappings() we loop from 0 to | ||
| 943 | * "pgd_index(lg->kernel_address)". This assumes it won't hit the | 1107 | * "pgd_index(lg->kernel_address)". This assumes it won't hit the |
| 944 | * Switcher mappings, so check that now. */ | 1108 | * Switcher mappings, so check that now. |
| 1109 | */ | ||
| 945 | #ifdef CONFIG_X86_PAE | 1110 | #ifdef CONFIG_X86_PAE |
| 946 | if (pgd_index(cpu->lg->kernel_address) == SWITCHER_PGD_INDEX && | 1111 | if (pgd_index(cpu->lg->kernel_address) == SWITCHER_PGD_INDEX && |
| 947 | pmd_index(cpu->lg->kernel_address) == SWITCHER_PMD_INDEX) | 1112 | pmd_index(cpu->lg->kernel_address) == SWITCHER_PMD_INDEX) |
| @@ -964,12 +1129,14 @@ void free_guest_pagetable(struct lguest *lg) | |||
| 964 | free_page((long)lg->pgdirs[i].pgdir); | 1129 | free_page((long)lg->pgdirs[i].pgdir); |
| 965 | } | 1130 | } |
| 966 | 1131 | ||
| 967 | /*H:480 (vi) Mapping the Switcher when the Guest is about to run. | 1132 | /*H:480 |
| 1133 | * (vi) Mapping the Switcher when the Guest is about to run. | ||
| 968 | * | 1134 | * |
| 969 | * The Switcher and the two pages for this CPU need to be visible in the | 1135 | * The Switcher and the two pages for this CPU need to be visible in the |
| 970 | * Guest (and not the pages for other CPUs). We have the appropriate PTE pages | 1136 | * Guest (and not the pages for other CPUs). We have the appropriate PTE pages |
| 971 | * for each CPU already set up, we just need to hook them in now we know which | 1137 | * for each CPU already set up, we just need to hook them in now we know which |
| 972 | * Guest is about to run on this CPU. */ | 1138 | * Guest is about to run on this CPU. |
| 1139 | */ | ||
| 973 | void map_switcher_in_guest(struct lg_cpu *cpu, struct lguest_pages *pages) | 1140 | void map_switcher_in_guest(struct lg_cpu *cpu, struct lguest_pages *pages) |
| 974 | { | 1141 | { |
| 975 | pte_t *switcher_pte_page = __get_cpu_var(switcher_pte_pages); | 1142 | pte_t *switcher_pte_page = __get_cpu_var(switcher_pte_pages); |
| @@ -980,30 +1147,38 @@ void map_switcher_in_guest(struct lg_cpu *cpu, struct lguest_pages *pages) | |||
| 980 | pmd_t switcher_pmd; | 1147 | pmd_t switcher_pmd; |
| 981 | pmd_t *pmd_table; | 1148 | pmd_t *pmd_table; |
| 982 | 1149 | ||
| 1150 | /* FIXME: native_set_pmd is overkill here. */ | ||
| 983 | native_set_pmd(&switcher_pmd, pfn_pmd(__pa(switcher_pte_page) >> | 1151 | native_set_pmd(&switcher_pmd, pfn_pmd(__pa(switcher_pte_page) >> |
| 984 | PAGE_SHIFT, PAGE_KERNEL_EXEC)); | 1152 | PAGE_SHIFT, PAGE_KERNEL_EXEC)); |
| 985 | 1153 | ||
| 1154 | /* Figure out where the pmd page is, by reading the PGD, and converting | ||
| 1155 | * it to a virtual address. */ | ||
| 986 | pmd_table = __va(pgd_pfn(cpu->lg-> | 1156 | pmd_table = __va(pgd_pfn(cpu->lg-> |
| 987 | pgdirs[cpu->cpu_pgd].pgdir[SWITCHER_PGD_INDEX]) | 1157 | pgdirs[cpu->cpu_pgd].pgdir[SWITCHER_PGD_INDEX]) |
| 988 | << PAGE_SHIFT); | 1158 | << PAGE_SHIFT); |
| 1159 | /* Now write it into the shadow page table. */ | ||
| 989 | native_set_pmd(&pmd_table[SWITCHER_PMD_INDEX], switcher_pmd); | 1160 | native_set_pmd(&pmd_table[SWITCHER_PMD_INDEX], switcher_pmd); |
| 990 | #else | 1161 | #else |
| 991 | pgd_t switcher_pgd; | 1162 | pgd_t switcher_pgd; |
| 992 | 1163 | ||
| 993 | /* Make the last PGD entry for this Guest point to the Switcher's PTE | 1164 | /* |
| 994 | * page for this CPU (with appropriate flags). */ | 1165 | * Make the last PGD entry for this Guest point to the Switcher's PTE |
| 1166 | * page for this CPU (with appropriate flags). | ||
| 1167 | */ | ||
| 995 | switcher_pgd = __pgd(__pa(switcher_pte_page) | __PAGE_KERNEL_EXEC); | 1168 | switcher_pgd = __pgd(__pa(switcher_pte_page) | __PAGE_KERNEL_EXEC); |
| 996 | 1169 | ||
| 997 | cpu->lg->pgdirs[cpu->cpu_pgd].pgdir[SWITCHER_PGD_INDEX] = switcher_pgd; | 1170 | cpu->lg->pgdirs[cpu->cpu_pgd].pgdir[SWITCHER_PGD_INDEX] = switcher_pgd; |
| 998 | 1171 | ||
| 999 | #endif | 1172 | #endif |
| 1000 | /* We also change the Switcher PTE page. When we're running the Guest, | 1173 | /* |
| 1174 | * We also change the Switcher PTE page. When we're running the Guest, | ||
| 1001 | * we want the Guest's "regs" page to appear where the first Switcher | 1175 | * we want the Guest's "regs" page to appear where the first Switcher |
| 1002 | * page for this CPU is. This is an optimization: when the Switcher | 1176 | * page for this CPU is. This is an optimization: when the Switcher |
| 1003 | * saves the Guest registers, it saves them into the first page of this | 1177 | * saves the Guest registers, it saves them into the first page of this |
| 1004 | * CPU's "struct lguest_pages": if we make sure the Guest's register | 1178 | * CPU's "struct lguest_pages": if we make sure the Guest's register |
| 1005 | * page is already mapped there, we don't have to copy them out | 1179 | * page is already mapped there, we don't have to copy them out |
| 1006 | * again. */ | 1180 | * again. |
| 1181 | */ | ||
| 1007 | pfn = __pa(cpu->regs_page) >> PAGE_SHIFT; | 1182 | pfn = __pa(cpu->regs_page) >> PAGE_SHIFT; |
| 1008 | native_set_pte(®s_pte, pfn_pte(pfn, PAGE_KERNEL)); | 1183 | native_set_pte(®s_pte, pfn_pte(pfn, PAGE_KERNEL)); |
| 1009 | native_set_pte(&switcher_pte_page[pte_index((unsigned long)pages)], | 1184 | native_set_pte(&switcher_pte_page[pte_index((unsigned long)pages)], |
| @@ -1019,10 +1194,12 @@ static void free_switcher_pte_pages(void) | |||
| 1019 | free_page((long)switcher_pte_page(i)); | 1194 | free_page((long)switcher_pte_page(i)); |
| 1020 | } | 1195 | } |
| 1021 | 1196 | ||
| 1022 | /*H:520 Setting up the Switcher PTE page for given CPU is fairly easy, given | 1197 | /*H:520 |
| 1198 | * Setting up the Switcher PTE page for given CPU is fairly easy, given | ||
| 1023 | * the CPU number and the "struct page"s for the Switcher code itself. | 1199 | * the CPU number and the "struct page"s for the Switcher code itself. |
| 1024 | * | 1200 | * |
| 1025 | * Currently the Switcher is less than a page long, so "pages" is always 1. */ | 1201 | * Currently the Switcher is less than a page long, so "pages" is always 1. |
| 1202 | */ | ||
| 1026 | static __init void populate_switcher_pte_page(unsigned int cpu, | 1203 | static __init void populate_switcher_pte_page(unsigned int cpu, |
| 1027 | struct page *switcher_page[], | 1204 | struct page *switcher_page[], |
| 1028 | unsigned int pages) | 1205 | unsigned int pages) |
| @@ -1043,13 +1220,16 @@ static __init void populate_switcher_pte_page(unsigned int cpu, | |||
| 1043 | native_set_pte(&pte[i], pfn_pte(page_to_pfn(switcher_page[i]), | 1220 | native_set_pte(&pte[i], pfn_pte(page_to_pfn(switcher_page[i]), |
| 1044 | __pgprot(_PAGE_PRESENT|_PAGE_ACCESSED|_PAGE_RW))); | 1221 | __pgprot(_PAGE_PRESENT|_PAGE_ACCESSED|_PAGE_RW))); |
| 1045 | 1222 | ||
| 1046 | /* The second page contains the "struct lguest_ro_state", and is | 1223 | /* |
| 1047 | * read-only. */ | 1224 | * The second page contains the "struct lguest_ro_state", and is |
| 1225 | * read-only. | ||
| 1226 | */ | ||
| 1048 | native_set_pte(&pte[i+1], pfn_pte(page_to_pfn(switcher_page[i+1]), | 1227 | native_set_pte(&pte[i+1], pfn_pte(page_to_pfn(switcher_page[i+1]), |
| 1049 | __pgprot(_PAGE_PRESENT|_PAGE_ACCESSED))); | 1228 | __pgprot(_PAGE_PRESENT|_PAGE_ACCESSED))); |
| 1050 | } | 1229 | } |
| 1051 | 1230 | ||
| 1052 | /* We've made it through the page table code. Perhaps our tired brains are | 1231 | /* |
| 1232 | * We've made it through the page table code. Perhaps our tired brains are | ||
| 1053 | * still processing the details, or perhaps we're simply glad it's over. | 1233 | * still processing the details, or perhaps we're simply glad it's over. |
| 1054 | * | 1234 | * |
| 1055 | * If nothing else, note that all this complexity in juggling shadow page tables | 1235 | * If nothing else, note that all this complexity in juggling shadow page tables |
| @@ -1058,10 +1238,13 @@ static __init void populate_switcher_pte_page(unsigned int cpu, | |||
| 1058 | * uses exotic direct Guest pagetable manipulation, and why both Intel and AMD | 1238 | * uses exotic direct Guest pagetable manipulation, and why both Intel and AMD |
| 1059 | * have implemented shadow page table support directly into hardware. | 1239 | * have implemented shadow page table support directly into hardware. |
| 1060 | * | 1240 | * |
| 1061 | * There is just one file remaining in the Host. */ | 1241 | * There is just one file remaining in the Host. |
| 1242 | */ | ||
| 1062 | 1243 | ||
| 1063 | /*H:510 At boot or module load time, init_pagetables() allocates and populates | 1244 | /*H:510 |
| 1064 | * the Switcher PTE page for each CPU. */ | 1245 | * At boot or module load time, init_pagetables() allocates and populates |
| 1246 | * the Switcher PTE page for each CPU. | ||
| 1247 | */ | ||
| 1065 | __init int init_pagetables(struct page **switcher_page, unsigned int pages) | 1248 | __init int init_pagetables(struct page **switcher_page, unsigned int pages) |
| 1066 | { | 1249 | { |
| 1067 | unsigned int i; | 1250 | unsigned int i; |
diff --git a/drivers/lguest/segments.c b/drivers/lguest/segments.c index 482ed5a18750..951c57b0a7e0 100644 --- a/drivers/lguest/segments.c +++ b/drivers/lguest/segments.c | |||
| @@ -1,4 +1,5 @@ | |||
| 1 | /*P:600 The x86 architecture has segments, which involve a table of descriptors | 1 | /*P:600 |
| 2 | * The x86 architecture has segments, which involve a table of descriptors | ||
| 2 | * which can be used to do funky things with virtual address interpretation. | 3 | * which can be used to do funky things with virtual address interpretation. |
| 3 | * We originally used to use segments so the Guest couldn't alter the | 4 | * We originally used to use segments so the Guest couldn't alter the |
| 4 | * Guest<->Host Switcher, and then we had to trim Guest segments, and restore | 5 | * Guest<->Host Switcher, and then we had to trim Guest segments, and restore |
| @@ -8,7 +9,8 @@ | |||
| 8 | * | 9 | * |
| 9 | * In these modern times, the segment handling code consists of simple sanity | 10 | * In these modern times, the segment handling code consists of simple sanity |
| 10 | * checks, and the worst you'll experience reading this code is butterfly-rash | 11 | * checks, and the worst you'll experience reading this code is butterfly-rash |
| 11 | * from frolicking through its parklike serenity. :*/ | 12 | * from frolicking through its parklike serenity. |
| 13 | :*/ | ||
| 12 | #include "lg.h" | 14 | #include "lg.h" |
| 13 | 15 | ||
| 14 | /*H:600 | 16 | /*H:600 |
| @@ -41,10 +43,12 @@ | |||
| 41 | * begin. | 43 | * begin. |
| 42 | */ | 44 | */ |
| 43 | 45 | ||
| 44 | /* There are several entries we don't let the Guest set. The TSS entry is the | 46 | /* |
| 47 | * There are several entries we don't let the Guest set. The TSS entry is the | ||
| 45 | * "Task State Segment" which controls all kinds of delicate things. The | 48 | * "Task State Segment" which controls all kinds of delicate things. The |
| 46 | * LGUEST_CS and LGUEST_DS entries are reserved for the Switcher, and the | 49 | * LGUEST_CS and LGUEST_DS entries are reserved for the Switcher, and the |
| 47 | * the Guest can't be trusted to deal with double faults. */ | 50 | * the Guest can't be trusted to deal with double faults. |
| 51 | */ | ||
| 48 | static bool ignored_gdt(unsigned int num) | 52 | static bool ignored_gdt(unsigned int num) |
| 49 | { | 53 | { |
| 50 | return (num == GDT_ENTRY_TSS | 54 | return (num == GDT_ENTRY_TSS |
| @@ -53,42 +57,52 @@ static bool ignored_gdt(unsigned int num) | |||
| 53 | || num == GDT_ENTRY_DOUBLEFAULT_TSS); | 57 | || num == GDT_ENTRY_DOUBLEFAULT_TSS); |
| 54 | } | 58 | } |
| 55 | 59 | ||
| 56 | /*H:630 Once the Guest gave us new GDT entries, we fix them up a little. We | 60 | /*H:630 |
| 61 | * Once the Guest gave us new GDT entries, we fix them up a little. We | ||
| 57 | * don't care if they're invalid: the worst that can happen is a General | 62 | * don't care if they're invalid: the worst that can happen is a General |
| 58 | * Protection Fault in the Switcher when it restores a Guest segment register | 63 | * Protection Fault in the Switcher when it restores a Guest segment register |
| 59 | * which tries to use that entry. Then we kill the Guest for causing such a | 64 | * which tries to use that entry. Then we kill the Guest for causing such a |
| 60 | * mess: the message will be "unhandled trap 256". */ | 65 | * mess: the message will be "unhandled trap 256". |
| 66 | */ | ||
| 61 | static void fixup_gdt_table(struct lg_cpu *cpu, unsigned start, unsigned end) | 67 | static void fixup_gdt_table(struct lg_cpu *cpu, unsigned start, unsigned end) |
| 62 | { | 68 | { |
| 63 | unsigned int i; | 69 | unsigned int i; |
| 64 | 70 | ||
| 65 | for (i = start; i < end; i++) { | 71 | for (i = start; i < end; i++) { |
| 66 | /* We never copy these ones to real GDT, so we don't care what | 72 | /* |
| 67 | * they say */ | 73 | * We never copy these ones to real GDT, so we don't care what |
| 74 | * they say | ||
| 75 | */ | ||
| 68 | if (ignored_gdt(i)) | 76 | if (ignored_gdt(i)) |
| 69 | continue; | 77 | continue; |
| 70 | 78 | ||
| 71 | /* Segment descriptors contain a privilege level: the Guest is | 79 | /* |
| 80 | * Segment descriptors contain a privilege level: the Guest is | ||
| 72 | * sometimes careless and leaves this as 0, even though it's | 81 | * sometimes careless and leaves this as 0, even though it's |
| 73 | * running at privilege level 1. If so, we fix it here. */ | 82 | * running at privilege level 1. If so, we fix it here. |
| 83 | */ | ||
| 74 | if ((cpu->arch.gdt[i].b & 0x00006000) == 0) | 84 | if ((cpu->arch.gdt[i].b & 0x00006000) == 0) |
| 75 | cpu->arch.gdt[i].b |= (GUEST_PL << 13); | 85 | cpu->arch.gdt[i].b |= (GUEST_PL << 13); |
| 76 | 86 | ||
| 77 | /* Each descriptor has an "accessed" bit. If we don't set it | 87 | /* |
| 88 | * Each descriptor has an "accessed" bit. If we don't set it | ||
| 78 | * now, the CPU will try to set it when the Guest first loads | 89 | * now, the CPU will try to set it when the Guest first loads |
| 79 | * that entry into a segment register. But the GDT isn't | 90 | * that entry into a segment register. But the GDT isn't |
| 80 | * writable by the Guest, so bad things can happen. */ | 91 | * writable by the Guest, so bad things can happen. |
| 92 | */ | ||
| 81 | cpu->arch.gdt[i].b |= 0x00000100; | 93 | cpu->arch.gdt[i].b |= 0x00000100; |
| 82 | } | 94 | } |
| 83 | } | 95 | } |
| 84 | 96 | ||
| 85 | /*H:610 Like the IDT, we never simply use the GDT the Guest gives us. We keep | 97 | /*H:610 |
| 98 | * Like the IDT, we never simply use the GDT the Guest gives us. We keep | ||
| 86 | * a GDT for each CPU, and copy across the Guest's entries each time we want to | 99 | * a GDT for each CPU, and copy across the Guest's entries each time we want to |
| 87 | * run the Guest on that CPU. | 100 | * run the Guest on that CPU. |
| 88 | * | 101 | * |
| 89 | * This routine is called at boot or modprobe time for each CPU to set up the | 102 | * This routine is called at boot or modprobe time for each CPU to set up the |
| 90 | * constant GDT entries: the ones which are the same no matter what Guest we're | 103 | * constant GDT entries: the ones which are the same no matter what Guest we're |
| 91 | * running. */ | 104 | * running. |
| 105 | */ | ||
| 92 | void setup_default_gdt_entries(struct lguest_ro_state *state) | 106 | void setup_default_gdt_entries(struct lguest_ro_state *state) |
| 93 | { | 107 | { |
| 94 | struct desc_struct *gdt = state->guest_gdt; | 108 | struct desc_struct *gdt = state->guest_gdt; |
| @@ -98,30 +112,37 @@ void setup_default_gdt_entries(struct lguest_ro_state *state) | |||
| 98 | gdt[GDT_ENTRY_LGUEST_CS] = FULL_EXEC_SEGMENT; | 112 | gdt[GDT_ENTRY_LGUEST_CS] = FULL_EXEC_SEGMENT; |
| 99 | gdt[GDT_ENTRY_LGUEST_DS] = FULL_SEGMENT; | 113 | gdt[GDT_ENTRY_LGUEST_DS] = FULL_SEGMENT; |
| 100 | 114 | ||
| 101 | /* The TSS segment refers to the TSS entry for this particular CPU. | 115 | /* |
| 116 | * The TSS segment refers to the TSS entry for this particular CPU. | ||
| 102 | * Forgive the magic flags: the 0x8900 means the entry is Present, it's | 117 | * Forgive the magic flags: the 0x8900 means the entry is Present, it's |
| 103 | * privilege level 0 Available 386 TSS system segment, and the 0x67 | 118 | * privilege level 0 Available 386 TSS system segment, and the 0x67 |
| 104 | * means Saturn is eclipsed by Mercury in the twelfth house. */ | 119 | * means Saturn is eclipsed by Mercury in the twelfth house. |
| 120 | */ | ||
| 105 | gdt[GDT_ENTRY_TSS].a = 0x00000067 | (tss << 16); | 121 | gdt[GDT_ENTRY_TSS].a = 0x00000067 | (tss << 16); |
| 106 | gdt[GDT_ENTRY_TSS].b = 0x00008900 | (tss & 0xFF000000) | 122 | gdt[GDT_ENTRY_TSS].b = 0x00008900 | (tss & 0xFF000000) |
| 107 | | ((tss >> 16) & 0x000000FF); | 123 | | ((tss >> 16) & 0x000000FF); |
| 108 | } | 124 | } |
| 109 | 125 | ||
| 110 | /* This routine sets up the initial Guest GDT for booting. All entries start | 126 | /* |
| 111 | * as 0 (unusable). */ | 127 | * This routine sets up the initial Guest GDT for booting. All entries start |
| 128 | * as 0 (unusable). | ||
| 129 | */ | ||
| 112 | void setup_guest_gdt(struct lg_cpu *cpu) | 130 | void setup_guest_gdt(struct lg_cpu *cpu) |
| 113 | { | 131 | { |
| 114 | /* Start with full 0-4G segments... */ | 132 | /* |
| 133 | * Start with full 0-4G segments...except the Guest is allowed to use | ||
| 134 | * them, so set the privilege level appropriately in the flags. | ||
| 135 | */ | ||
| 115 | cpu->arch.gdt[GDT_ENTRY_KERNEL_CS] = FULL_EXEC_SEGMENT; | 136 | cpu->arch.gdt[GDT_ENTRY_KERNEL_CS] = FULL_EXEC_SEGMENT; |
| 116 | cpu->arch.gdt[GDT_ENTRY_KERNEL_DS] = FULL_SEGMENT; | 137 | cpu->arch.gdt[GDT_ENTRY_KERNEL_DS] = FULL_SEGMENT; |
| 117 | /* ...except the Guest is allowed to use them, so set the privilege | ||
| 118 | * level appropriately in the flags. */ | ||
| 119 | cpu->arch.gdt[GDT_ENTRY_KERNEL_CS].b |= (GUEST_PL << 13); | 138 | cpu->arch.gdt[GDT_ENTRY_KERNEL_CS].b |= (GUEST_PL << 13); |
| 120 | cpu->arch.gdt[GDT_ENTRY_KERNEL_DS].b |= (GUEST_PL << 13); | 139 | cpu->arch.gdt[GDT_ENTRY_KERNEL_DS].b |= (GUEST_PL << 13); |
| 121 | } | 140 | } |
| 122 | 141 | ||
| 123 | /*H:650 An optimization of copy_gdt(), for just the three "thead-local storage" | 142 | /*H:650 |
| 124 | * entries. */ | 143 | * An optimization of copy_gdt(), for just the three "thead-local storage" |
| 144 | * entries. | ||
| 145 | */ | ||
| 125 | void copy_gdt_tls(const struct lg_cpu *cpu, struct desc_struct *gdt) | 146 | void copy_gdt_tls(const struct lg_cpu *cpu, struct desc_struct *gdt) |
| 126 | { | 147 | { |
| 127 | unsigned int i; | 148 | unsigned int i; |
| @@ -130,26 +151,34 @@ void copy_gdt_tls(const struct lg_cpu *cpu, struct desc_struct *gdt) | |||
| 130 | gdt[i] = cpu->arch.gdt[i]; | 151 | gdt[i] = cpu->arch.gdt[i]; |
| 131 | } | 152 | } |
| 132 | 153 | ||
| 133 | /*H:640 When the Guest is run on a different CPU, or the GDT entries have | 154 | /*H:640 |
| 134 | * changed, copy_gdt() is called to copy the Guest's GDT entries across to this | 155 | * When the Guest is run on a different CPU, or the GDT entries have changed, |
| 135 | * CPU's GDT. */ | 156 | * copy_gdt() is called to copy the Guest's GDT entries across to this CPU's |
| 157 | * GDT. | ||
| 158 | */ | ||
| 136 | void copy_gdt(const struct lg_cpu *cpu, struct desc_struct *gdt) | 159 | void copy_gdt(const struct lg_cpu *cpu, struct desc_struct *gdt) |
| 137 | { | 160 | { |
| 138 | unsigned int i; | 161 | unsigned int i; |
| 139 | 162 | ||
| 140 | /* The default entries from setup_default_gdt_entries() are not | 163 | /* |
| 141 | * replaced. See ignored_gdt() above. */ | 164 | * The default entries from setup_default_gdt_entries() are not |
| 165 | * replaced. See ignored_gdt() above. | ||
| 166 | */ | ||
| 142 | for (i = 0; i < GDT_ENTRIES; i++) | 167 | for (i = 0; i < GDT_ENTRIES; i++) |
| 143 | if (!ignored_gdt(i)) | 168 | if (!ignored_gdt(i)) |
| 144 | gdt[i] = cpu->arch.gdt[i]; | 169 | gdt[i] = cpu->arch.gdt[i]; |
| 145 | } | 170 | } |
| 146 | 171 | ||
| 147 | /*H:620 This is where the Guest asks us to load a new GDT entry | 172 | /*H:620 |
| 148 | * (LHCALL_LOAD_GDT_ENTRY). We tweak the entry and copy it in. */ | 173 | * This is where the Guest asks us to load a new GDT entry |
| 174 | * (LHCALL_LOAD_GDT_ENTRY). We tweak the entry and copy it in. | ||
| 175 | */ | ||
| 149 | void load_guest_gdt_entry(struct lg_cpu *cpu, u32 num, u32 lo, u32 hi) | 176 | void load_guest_gdt_entry(struct lg_cpu *cpu, u32 num, u32 lo, u32 hi) |
| 150 | { | 177 | { |
| 151 | /* We assume the Guest has the same number of GDT entries as the | 178 | /* |
| 152 | * Host, otherwise we'd have to dynamically allocate the Guest GDT. */ | 179 | * We assume the Guest has the same number of GDT entries as the |
| 180 | * Host, otherwise we'd have to dynamically allocate the Guest GDT. | ||
| 181 | */ | ||
| 153 | if (num >= ARRAY_SIZE(cpu->arch.gdt)) | 182 | if (num >= ARRAY_SIZE(cpu->arch.gdt)) |
| 154 | kill_guest(cpu, "too many gdt entries %i", num); | 183 | kill_guest(cpu, "too many gdt entries %i", num); |
| 155 | 184 | ||
| @@ -157,15 +186,19 @@ void load_guest_gdt_entry(struct lg_cpu *cpu, u32 num, u32 lo, u32 hi) | |||
| 157 | cpu->arch.gdt[num].a = lo; | 186 | cpu->arch.gdt[num].a = lo; |
| 158 | cpu->arch.gdt[num].b = hi; | 187 | cpu->arch.gdt[num].b = hi; |
| 159 | fixup_gdt_table(cpu, num, num+1); | 188 | fixup_gdt_table(cpu, num, num+1); |
| 160 | /* Mark that the GDT changed so the core knows it has to copy it again, | 189 | /* |
| 161 | * even if the Guest is run on the same CPU. */ | 190 | * Mark that the GDT changed so the core knows it has to copy it again, |
| 191 | * even if the Guest is run on the same CPU. | ||
| 192 | */ | ||
| 162 | cpu->changed |= CHANGED_GDT; | 193 | cpu->changed |= CHANGED_GDT; |
| 163 | } | 194 | } |
| 164 | 195 | ||
| 165 | /* This is the fast-track version for just changing the three TLS entries. | 196 | /* |
| 197 | * This is the fast-track version for just changing the three TLS entries. | ||
| 166 | * Remember that this happens on every context switch, so it's worth | 198 | * Remember that this happens on every context switch, so it's worth |
| 167 | * optimizing. But wouldn't it be neater to have a single hypercall to cover | 199 | * optimizing. But wouldn't it be neater to have a single hypercall to cover |
| 168 | * both cases? */ | 200 | * both cases? |
| 201 | */ | ||
| 169 | void guest_load_tls(struct lg_cpu *cpu, unsigned long gtls) | 202 | void guest_load_tls(struct lg_cpu *cpu, unsigned long gtls) |
| 170 | { | 203 | { |
| 171 | struct desc_struct *tls = &cpu->arch.gdt[GDT_ENTRY_TLS_MIN]; | 204 | struct desc_struct *tls = &cpu->arch.gdt[GDT_ENTRY_TLS_MIN]; |
| @@ -175,7 +208,6 @@ void guest_load_tls(struct lg_cpu *cpu, unsigned long gtls) | |||
| 175 | /* Note that just the TLS entries have changed. */ | 208 | /* Note that just the TLS entries have changed. */ |
| 176 | cpu->changed |= CHANGED_GDT_TLS; | 209 | cpu->changed |= CHANGED_GDT_TLS; |
| 177 | } | 210 | } |
| 178 | /*:*/ | ||
| 179 | 211 | ||
| 180 | /*H:660 | 212 | /*H:660 |
| 181 | * With this, we have finished the Host. | 213 | * With this, we have finished the Host. |
diff --git a/drivers/lguest/x86/core.c b/drivers/lguest/x86/core.c index eaf722fe309a..6ae388849a3b 100644 --- a/drivers/lguest/x86/core.c +++ b/drivers/lguest/x86/core.c | |||
| @@ -17,13 +17,15 @@ | |||
| 17 | * along with this program; if not, write to the Free Software | 17 | * along with this program; if not, write to the Free Software |
| 18 | * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | 18 | * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
| 19 | */ | 19 | */ |
| 20 | /*P:450 This file contains the x86-specific lguest code. It used to be all | 20 | /*P:450 |
| 21 | * This file contains the x86-specific lguest code. It used to be all | ||
| 21 | * mixed in with drivers/lguest/core.c but several foolhardy code slashers | 22 | * mixed in with drivers/lguest/core.c but several foolhardy code slashers |
| 22 | * wrestled most of the dependencies out to here in preparation for porting | 23 | * wrestled most of the dependencies out to here in preparation for porting |
| 23 | * lguest to other architectures (see what I mean by foolhardy?). | 24 | * lguest to other architectures (see what I mean by foolhardy?). |
| 24 | * | 25 | * |
| 25 | * This also contains a couple of non-obvious setup and teardown pieces which | 26 | * This also contains a couple of non-obvious setup and teardown pieces which |
| 26 | * were implemented after days of debugging pain. :*/ | 27 | * were implemented after days of debugging pain. |
| 28 | :*/ | ||
| 27 | #include <linux/kernel.h> | 29 | #include <linux/kernel.h> |
| 28 | #include <linux/start_kernel.h> | 30 | #include <linux/start_kernel.h> |
| 29 | #include <linux/string.h> | 31 | #include <linux/string.h> |
| @@ -82,25 +84,33 @@ static DEFINE_PER_CPU(struct lg_cpu *, last_cpu); | |||
| 82 | */ | 84 | */ |
| 83 | static void copy_in_guest_info(struct lg_cpu *cpu, struct lguest_pages *pages) | 85 | static void copy_in_guest_info(struct lg_cpu *cpu, struct lguest_pages *pages) |
| 84 | { | 86 | { |
| 85 | /* Copying all this data can be quite expensive. We usually run the | 87 | /* |
| 88 | * Copying all this data can be quite expensive. We usually run the | ||
| 86 | * same Guest we ran last time (and that Guest hasn't run anywhere else | 89 | * same Guest we ran last time (and that Guest hasn't run anywhere else |
| 87 | * meanwhile). If that's not the case, we pretend everything in the | 90 | * meanwhile). If that's not the case, we pretend everything in the |
| 88 | * Guest has changed. */ | 91 | * Guest has changed. |
| 92 | */ | ||
| 89 | if (__get_cpu_var(last_cpu) != cpu || cpu->last_pages != pages) { | 93 | if (__get_cpu_var(last_cpu) != cpu || cpu->last_pages != pages) { |
| 90 | __get_cpu_var(last_cpu) = cpu; | 94 | __get_cpu_var(last_cpu) = cpu; |
| 91 | cpu->last_pages = pages; | 95 | cpu->last_pages = pages; |
| 92 | cpu->changed = CHANGED_ALL; | 96 | cpu->changed = CHANGED_ALL; |
| 93 | } | 97 | } |
| 94 | 98 | ||
| 95 | /* These copies are pretty cheap, so we do them unconditionally: */ | 99 | /* |
| 96 | /* Save the current Host top-level page directory. */ | 100 | * These copies are pretty cheap, so we do them unconditionally: */ |
| 101 | /* Save the current Host top-level page directory. | ||
| 102 | */ | ||
| 97 | pages->state.host_cr3 = __pa(current->mm->pgd); | 103 | pages->state.host_cr3 = __pa(current->mm->pgd); |
| 98 | /* Set up the Guest's page tables to see this CPU's pages (and no | 104 | /* |
| 99 | * other CPU's pages). */ | 105 | * Set up the Guest's page tables to see this CPU's pages (and no |
| 106 | * other CPU's pages). | ||
| 107 | */ | ||
| 100 | map_switcher_in_guest(cpu, pages); | 108 | map_switcher_in_guest(cpu, pages); |
| 101 | /* Set up the two "TSS" members which tell the CPU what stack to use | 109 | /* |
| 110 | * Set up the two "TSS" members which tell the CPU what stack to use | ||
| 102 | * for traps which do directly into the Guest (ie. traps at privilege | 111 | * for traps which do directly into the Guest (ie. traps at privilege |
| 103 | * level 1). */ | 112 | * level 1). |
| 113 | */ | ||
| 104 | pages->state.guest_tss.sp1 = cpu->esp1; | 114 | pages->state.guest_tss.sp1 = cpu->esp1; |
| 105 | pages->state.guest_tss.ss1 = cpu->ss1; | 115 | pages->state.guest_tss.ss1 = cpu->ss1; |
| 106 | 116 | ||
| @@ -125,97 +135,126 @@ static void run_guest_once(struct lg_cpu *cpu, struct lguest_pages *pages) | |||
| 125 | /* This is a dummy value we need for GCC's sake. */ | 135 | /* This is a dummy value we need for GCC's sake. */ |
| 126 | unsigned int clobber; | 136 | unsigned int clobber; |
| 127 | 137 | ||
| 128 | /* Copy the guest-specific information into this CPU's "struct | 138 | /* |
| 129 | * lguest_pages". */ | 139 | * Copy the guest-specific information into this CPU's "struct |
| 140 | * lguest_pages". | ||
| 141 | */ | ||
| 130 | copy_in_guest_info(cpu, pages); | 142 | copy_in_guest_info(cpu, pages); |
| 131 | 143 | ||
| 132 | /* Set the trap number to 256 (impossible value). If we fault while | 144 | /* |
| 145 | * Set the trap number to 256 (impossible value). If we fault while | ||
| 133 | * switching to the Guest (bad segment registers or bug), this will | 146 | * switching to the Guest (bad segment registers or bug), this will |
| 134 | * cause us to abort the Guest. */ | 147 | * cause us to abort the Guest. |
| 148 | */ | ||
| 135 | cpu->regs->trapnum = 256; | 149 | cpu->regs->trapnum = 256; |
| 136 | 150 | ||
| 137 | /* Now: we push the "eflags" register on the stack, then do an "lcall". | 151 | /* |
| 152 | * Now: we push the "eflags" register on the stack, then do an "lcall". | ||
| 138 | * This is how we change from using the kernel code segment to using | 153 | * This is how we change from using the kernel code segment to using |
| 139 | * the dedicated lguest code segment, as well as jumping into the | 154 | * the dedicated lguest code segment, as well as jumping into the |
| 140 | * Switcher. | 155 | * Switcher. |
| 141 | * | 156 | * |
| 142 | * The lcall also pushes the old code segment (KERNEL_CS) onto the | 157 | * The lcall also pushes the old code segment (KERNEL_CS) onto the |
| 143 | * stack, then the address of this call. This stack layout happens to | 158 | * stack, then the address of this call. This stack layout happens to |
| 144 | * exactly match the stack layout created by an interrupt... */ | 159 | * exactly match the stack layout created by an interrupt... |
| 160 | */ | ||
| 145 | asm volatile("pushf; lcall *lguest_entry" | 161 | asm volatile("pushf; lcall *lguest_entry" |
| 146 | /* This is how we tell GCC that %eax ("a") and %ebx ("b") | 162 | /* |
| 147 | * are changed by this routine. The "=" means output. */ | 163 | * This is how we tell GCC that %eax ("a") and %ebx ("b") |
| 164 | * are changed by this routine. The "=" means output. | ||
| 165 | */ | ||
| 148 | : "=a"(clobber), "=b"(clobber) | 166 | : "=a"(clobber), "=b"(clobber) |
| 149 | /* %eax contains the pages pointer. ("0" refers to the | 167 | /* |
| 168 | * %eax contains the pages pointer. ("0" refers to the | ||
| 150 | * 0-th argument above, ie "a"). %ebx contains the | 169 | * 0-th argument above, ie "a"). %ebx contains the |
| 151 | * physical address of the Guest's top-level page | 170 | * physical address of the Guest's top-level page |
| 152 | * directory. */ | 171 | * directory. |
| 172 | */ | ||
| 153 | : "0"(pages), "1"(__pa(cpu->lg->pgdirs[cpu->cpu_pgd].pgdir)) | 173 | : "0"(pages), "1"(__pa(cpu->lg->pgdirs[cpu->cpu_pgd].pgdir)) |
| 154 | /* We tell gcc that all these registers could change, | 174 | /* |
| 175 | * We tell gcc that all these registers could change, | ||
| 155 | * which means we don't have to save and restore them in | 176 | * which means we don't have to save and restore them in |
| 156 | * the Switcher. */ | 177 | * the Switcher. |
| 178 | */ | ||
| 157 | : "memory", "%edx", "%ecx", "%edi", "%esi"); | 179 | : "memory", "%edx", "%ecx", "%edi", "%esi"); |
| 158 | } | 180 | } |
| 159 | /*:*/ | 181 | /*:*/ |
| 160 | 182 | ||
| 161 | /*M:002 There are hooks in the scheduler which we can register to tell when we | 183 | /*M:002 |
| 184 | * There are hooks in the scheduler which we can register to tell when we | ||
| 162 | * get kicked off the CPU (preempt_notifier_register()). This would allow us | 185 | * get kicked off the CPU (preempt_notifier_register()). This would allow us |
| 163 | * to lazily disable SYSENTER which would regain some performance, and should | 186 | * to lazily disable SYSENTER which would regain some performance, and should |
| 164 | * also simplify copy_in_guest_info(). Note that we'd still need to restore | 187 | * also simplify copy_in_guest_info(). Note that we'd still need to restore |
| 165 | * things when we exit to Launcher userspace, but that's fairly easy. | 188 | * things when we exit to Launcher userspace, but that's fairly easy. |
| 166 | * | 189 | * |
| 167 | * We could also try using this hooks for PGE, but that might be too expensive. | 190 | * We could also try using these hooks for PGE, but that might be too expensive. |
| 168 | * | 191 | * |
| 169 | * The hooks were designed for KVM, but we can also put them to good use. :*/ | 192 | * The hooks were designed for KVM, but we can also put them to good use. |
| 193 | :*/ | ||
| 170 | 194 | ||
| 171 | /*H:040 This is the i386-specific code to setup and run the Guest. Interrupts | 195 | /*H:040 |
| 172 | * are disabled: we own the CPU. */ | 196 | * This is the i386-specific code to setup and run the Guest. Interrupts |
| 197 | * are disabled: we own the CPU. | ||
| 198 | */ | ||
| 173 | void lguest_arch_run_guest(struct lg_cpu *cpu) | 199 | void lguest_arch_run_guest(struct lg_cpu *cpu) |
| 174 | { | 200 | { |
| 175 | /* Remember the awfully-named TS bit? If the Guest has asked to set it | 201 | /* |
| 202 | * Remember the awfully-named TS bit? If the Guest has asked to set it | ||
| 176 | * we set it now, so we can trap and pass that trap to the Guest if it | 203 | * we set it now, so we can trap and pass that trap to the Guest if it |
| 177 | * uses the FPU. */ | 204 | * uses the FPU. |
| 205 | */ | ||
| 178 | if (cpu->ts) | 206 | if (cpu->ts) |
| 179 | unlazy_fpu(current); | 207 | unlazy_fpu(current); |
| 180 | 208 | ||
| 181 | /* SYSENTER is an optimized way of doing system calls. We can't allow | 209 | /* |
| 210 | * SYSENTER is an optimized way of doing system calls. We can't allow | ||
| 182 | * it because it always jumps to privilege level 0. A normal Guest | 211 | * it because it always jumps to privilege level 0. A normal Guest |
| 183 | * won't try it because we don't advertise it in CPUID, but a malicious | 212 | * won't try it because we don't advertise it in CPUID, but a malicious |
| 184 | * Guest (or malicious Guest userspace program) could, so we tell the | 213 | * Guest (or malicious Guest userspace program) could, so we tell the |
| 185 | * CPU to disable it before running the Guest. */ | 214 | * CPU to disable it before running the Guest. |
| 215 | */ | ||
| 186 | if (boot_cpu_has(X86_FEATURE_SEP)) | 216 | if (boot_cpu_has(X86_FEATURE_SEP)) |
| 187 | wrmsr(MSR_IA32_SYSENTER_CS, 0, 0); | 217 | wrmsr(MSR_IA32_SYSENTER_CS, 0, 0); |
| 188 | 218 | ||
| 189 | /* Now we actually run the Guest. It will return when something | 219 | /* |
| 220 | * Now we actually run the Guest. It will return when something | ||
| 190 | * interesting happens, and we can examine its registers to see what it | 221 | * interesting happens, and we can examine its registers to see what it |
| 191 | * was doing. */ | 222 | * was doing. |
| 223 | */ | ||
| 192 | run_guest_once(cpu, lguest_pages(raw_smp_processor_id())); | 224 | run_guest_once(cpu, lguest_pages(raw_smp_processor_id())); |
| 193 | 225 | ||
| 194 | /* Note that the "regs" structure contains two extra entries which are | 226 | /* |
| 227 | * Note that the "regs" structure contains two extra entries which are | ||
| 195 | * not really registers: a trap number which says what interrupt or | 228 | * not really registers: a trap number which says what interrupt or |
| 196 | * trap made the switcher code come back, and an error code which some | 229 | * trap made the switcher code come back, and an error code which some |
| 197 | * traps set. */ | 230 | * traps set. |
| 231 | */ | ||
| 198 | 232 | ||
| 199 | /* Restore SYSENTER if it's supposed to be on. */ | 233 | /* Restore SYSENTER if it's supposed to be on. */ |
| 200 | if (boot_cpu_has(X86_FEATURE_SEP)) | 234 | if (boot_cpu_has(X86_FEATURE_SEP)) |
| 201 | wrmsr(MSR_IA32_SYSENTER_CS, __KERNEL_CS, 0); | 235 | wrmsr(MSR_IA32_SYSENTER_CS, __KERNEL_CS, 0); |
| 202 | 236 | ||
| 203 | /* If the Guest page faulted, then the cr2 register will tell us the | 237 | /* |
| 238 | * If the Guest page faulted, then the cr2 register will tell us the | ||
| 204 | * bad virtual address. We have to grab this now, because once we | 239 | * bad virtual address. We have to grab this now, because once we |
| 205 | * re-enable interrupts an interrupt could fault and thus overwrite | 240 | * re-enable interrupts an interrupt could fault and thus overwrite |
| 206 | * cr2, or we could even move off to a different CPU. */ | 241 | * cr2, or we could even move off to a different CPU. |
| 242 | */ | ||
| 207 | if (cpu->regs->trapnum == 14) | 243 | if (cpu->regs->trapnum == 14) |
| 208 | cpu->arch.last_pagefault = read_cr2(); | 244 | cpu->arch.last_pagefault = read_cr2(); |
| 209 | /* Similarly, if we took a trap because the Guest used the FPU, | 245 | /* |
| 246 | * Similarly, if we took a trap because the Guest used the FPU, | ||
| 210 | * we have to restore the FPU it expects to see. | 247 | * we have to restore the FPU it expects to see. |
| 211 | * math_state_restore() may sleep and we may even move off to | 248 | * math_state_restore() may sleep and we may even move off to |
| 212 | * a different CPU. So all the critical stuff should be done | 249 | * a different CPU. So all the critical stuff should be done |
| 213 | * before this. */ | 250 | * before this. |
| 251 | */ | ||
| 214 | else if (cpu->regs->trapnum == 7) | 252 | else if (cpu->regs->trapnum == 7) |
| 215 | math_state_restore(); | 253 | math_state_restore(); |
| 216 | } | 254 | } |
| 217 | 255 | ||
| 218 | /*H:130 Now we've examined the hypercall code; our Guest can make requests. | 256 | /*H:130 |
| 257 | * Now we've examined the hypercall code; our Guest can make requests. | ||
| 219 | * Our Guest is usually so well behaved; it never tries to do things it isn't | 258 | * Our Guest is usually so well behaved; it never tries to do things it isn't |
| 220 | * allowed to, and uses hypercalls instead. Unfortunately, Linux's paravirtual | 259 | * allowed to, and uses hypercalls instead. Unfortunately, Linux's paravirtual |
| 221 | * infrastructure isn't quite complete, because it doesn't contain replacements | 260 | * infrastructure isn't quite complete, because it doesn't contain replacements |
| @@ -225,26 +264,33 @@ void lguest_arch_run_guest(struct lg_cpu *cpu) | |||
| 225 | * | 264 | * |
| 226 | * When the Guest uses one of these instructions, we get a trap (General | 265 | * When the Guest uses one of these instructions, we get a trap (General |
| 227 | * Protection Fault) and come here. We see if it's one of those troublesome | 266 | * Protection Fault) and come here. We see if it's one of those troublesome |
| 228 | * instructions and skip over it. We return true if we did. */ | 267 | * instructions and skip over it. We return true if we did. |
| 268 | */ | ||
| 229 | static int emulate_insn(struct lg_cpu *cpu) | 269 | static int emulate_insn(struct lg_cpu *cpu) |
| 230 | { | 270 | { |
| 231 | u8 insn; | 271 | u8 insn; |
| 232 | unsigned int insnlen = 0, in = 0, shift = 0; | 272 | unsigned int insnlen = 0, in = 0, shift = 0; |
| 233 | /* The eip contains the *virtual* address of the Guest's instruction: | 273 | /* |
| 234 | * guest_pa just subtracts the Guest's page_offset. */ | 274 | * The eip contains the *virtual* address of the Guest's instruction: |
| 275 | * guest_pa just subtracts the Guest's page_offset. | ||
| 276 | */ | ||
| 235 | unsigned long physaddr = guest_pa(cpu, cpu->regs->eip); | 277 | unsigned long physaddr = guest_pa(cpu, cpu->regs->eip); |
| 236 | 278 | ||
| 237 | /* This must be the Guest kernel trying to do something, not userspace! | 279 | /* |
| 280 | * This must be the Guest kernel trying to do something, not userspace! | ||
| 238 | * The bottom two bits of the CS segment register are the privilege | 281 | * The bottom two bits of the CS segment register are the privilege |
| 239 | * level. */ | 282 | * level. |
| 283 | */ | ||
| 240 | if ((cpu->regs->cs & 3) != GUEST_PL) | 284 | if ((cpu->regs->cs & 3) != GUEST_PL) |
| 241 | return 0; | 285 | return 0; |
| 242 | 286 | ||
| 243 | /* Decoding x86 instructions is icky. */ | 287 | /* Decoding x86 instructions is icky. */ |
| 244 | insn = lgread(cpu, physaddr, u8); | 288 | insn = lgread(cpu, physaddr, u8); |
| 245 | 289 | ||
| 246 | /* 0x66 is an "operand prefix". It means it's using the upper 16 bits | 290 | /* |
| 247 | of the eax register. */ | 291 | * 0x66 is an "operand prefix". It means it's using the upper 16 bits |
| 292 | * of the eax register. | ||
| 293 | */ | ||
| 248 | if (insn == 0x66) { | 294 | if (insn == 0x66) { |
| 249 | shift = 16; | 295 | shift = 16; |
| 250 | /* The instruction is 1 byte so far, read the next byte. */ | 296 | /* The instruction is 1 byte so far, read the next byte. */ |
| @@ -252,8 +298,10 @@ static int emulate_insn(struct lg_cpu *cpu) | |||
| 252 | insn = lgread(cpu, physaddr + insnlen, u8); | 298 | insn = lgread(cpu, physaddr + insnlen, u8); |
| 253 | } | 299 | } |
| 254 | 300 | ||
| 255 | /* We can ignore the lower bit for the moment and decode the 4 opcodes | 301 | /* |
| 256 | * we need to emulate. */ | 302 | * We can ignore the lower bit for the moment and decode the 4 opcodes |
| 303 | * we need to emulate. | ||
| 304 | */ | ||
| 257 | switch (insn & 0xFE) { | 305 | switch (insn & 0xFE) { |
| 258 | case 0xE4: /* in <next byte>,%al */ | 306 | case 0xE4: /* in <next byte>,%al */ |
| 259 | insnlen += 2; | 307 | insnlen += 2; |
| @@ -274,9 +322,11 @@ static int emulate_insn(struct lg_cpu *cpu) | |||
| 274 | return 0; | 322 | return 0; |
| 275 | } | 323 | } |
| 276 | 324 | ||
| 277 | /* If it was an "IN" instruction, they expect the result to be read | 325 | /* |
| 326 | * If it was an "IN" instruction, they expect the result to be read | ||
| 278 | * into %eax, so we change %eax. We always return all-ones, which | 327 | * into %eax, so we change %eax. We always return all-ones, which |
| 279 | * traditionally means "there's nothing there". */ | 328 | * traditionally means "there's nothing there". |
| 329 | */ | ||
| 280 | if (in) { | 330 | if (in) { |
| 281 | /* Lower bit tells is whether it's a 16 or 32 bit access */ | 331 | /* Lower bit tells is whether it's a 16 or 32 bit access */ |
| 282 | if (insn & 0x1) | 332 | if (insn & 0x1) |
| @@ -290,7 +340,8 @@ static int emulate_insn(struct lg_cpu *cpu) | |||
| 290 | return 1; | 340 | return 1; |
| 291 | } | 341 | } |
| 292 | 342 | ||
| 293 | /* Our hypercalls mechanism used to be based on direct software interrupts. | 343 | /* |
| 344 | * Our hypercalls mechanism used to be based on direct software interrupts. | ||
| 294 | * After Anthony's "Refactor hypercall infrastructure" kvm patch, we decided to | 345 | * After Anthony's "Refactor hypercall infrastructure" kvm patch, we decided to |
| 295 | * change over to using kvm hypercalls. | 346 | * change over to using kvm hypercalls. |
| 296 | * | 347 | * |
| @@ -318,16 +369,20 @@ static int emulate_insn(struct lg_cpu *cpu) | |||
| 318 | */ | 369 | */ |
| 319 | static void rewrite_hypercall(struct lg_cpu *cpu) | 370 | static void rewrite_hypercall(struct lg_cpu *cpu) |
| 320 | { | 371 | { |
| 321 | /* This are the opcodes we use to patch the Guest. The opcode for "int | 372 | /* |
| 373 | * This are the opcodes we use to patch the Guest. The opcode for "int | ||
| 322 | * $0x1f" is "0xcd 0x1f" but vmcall instruction is 3 bytes long, so we | 374 | * $0x1f" is "0xcd 0x1f" but vmcall instruction is 3 bytes long, so we |
| 323 | * complete the sequence with a NOP (0x90). */ | 375 | * complete the sequence with a NOP (0x90). |
| 376 | */ | ||
| 324 | u8 insn[3] = {0xcd, 0x1f, 0x90}; | 377 | u8 insn[3] = {0xcd, 0x1f, 0x90}; |
| 325 | 378 | ||
| 326 | __lgwrite(cpu, guest_pa(cpu, cpu->regs->eip), insn, sizeof(insn)); | 379 | __lgwrite(cpu, guest_pa(cpu, cpu->regs->eip), insn, sizeof(insn)); |
| 327 | /* The above write might have caused a copy of that page to be made | 380 | /* |
| 381 | * The above write might have caused a copy of that page to be made | ||
| 328 | * (if it was read-only). We need to make sure the Guest has | 382 | * (if it was read-only). We need to make sure the Guest has |
| 329 | * up-to-date pagetables. As this doesn't happen often, we can just | 383 | * up-to-date pagetables. As this doesn't happen often, we can just |
| 330 | * drop them all. */ | 384 | * drop them all. |
| 385 | */ | ||
| 331 | guest_pagetable_clear_all(cpu); | 386 | guest_pagetable_clear_all(cpu); |
| 332 | } | 387 | } |
| 333 | 388 | ||
| @@ -335,9 +390,11 @@ static bool is_hypercall(struct lg_cpu *cpu) | |||
| 335 | { | 390 | { |
| 336 | u8 insn[3]; | 391 | u8 insn[3]; |
| 337 | 392 | ||
| 338 | /* This must be the Guest kernel trying to do something. | 393 | /* |
| 394 | * This must be the Guest kernel trying to do something. | ||
| 339 | * The bottom two bits of the CS segment register are the privilege | 395 | * The bottom two bits of the CS segment register are the privilege |
| 340 | * level. */ | 396 | * level. |
| 397 | */ | ||
| 341 | if ((cpu->regs->cs & 3) != GUEST_PL) | 398 | if ((cpu->regs->cs & 3) != GUEST_PL) |
| 342 | return false; | 399 | return false; |
| 343 | 400 | ||
| @@ -351,86 +408,105 @@ void lguest_arch_handle_trap(struct lg_cpu *cpu) | |||
| 351 | { | 408 | { |
| 352 | switch (cpu->regs->trapnum) { | 409 | switch (cpu->regs->trapnum) { |
| 353 | case 13: /* We've intercepted a General Protection Fault. */ | 410 | case 13: /* We've intercepted a General Protection Fault. */ |
| 354 | /* Check if this was one of those annoying IN or OUT | 411 | /* |
| 412 | * Check if this was one of those annoying IN or OUT | ||
| 355 | * instructions which we need to emulate. If so, we just go | 413 | * instructions which we need to emulate. If so, we just go |
| 356 | * back into the Guest after we've done it. */ | 414 | * back into the Guest after we've done it. |
| 415 | */ | ||
| 357 | if (cpu->regs->errcode == 0) { | 416 | if (cpu->regs->errcode == 0) { |
| 358 | if (emulate_insn(cpu)) | 417 | if (emulate_insn(cpu)) |
| 359 | return; | 418 | return; |
| 360 | } | 419 | } |
| 361 | /* If KVM is active, the vmcall instruction triggers a | 420 | /* |
| 362 | * General Protection Fault. Normally it triggers an | 421 | * If KVM is active, the vmcall instruction triggers a General |
| 363 | * invalid opcode fault (6): */ | 422 | * Protection Fault. Normally it triggers an invalid opcode |
| 423 | * fault (6): | ||
| 424 | */ | ||
| 364 | case 6: | 425 | case 6: |
| 365 | /* We need to check if ring == GUEST_PL and | 426 | /* |
| 366 | * faulting instruction == vmcall. */ | 427 | * We need to check if ring == GUEST_PL and faulting |
| 428 | * instruction == vmcall. | ||
| 429 | */ | ||
| 367 | if (is_hypercall(cpu)) { | 430 | if (is_hypercall(cpu)) { |
| 368 | rewrite_hypercall(cpu); | 431 | rewrite_hypercall(cpu); |
| 369 | return; | 432 | return; |
| 370 | } | 433 | } |
| 371 | break; | 434 | break; |
| 372 | case 14: /* We've intercepted a Page Fault. */ | 435 | case 14: /* We've intercepted a Page Fault. */ |
| 373 | /* The Guest accessed a virtual address that wasn't mapped. | 436 | /* |
| 437 | * The Guest accessed a virtual address that wasn't mapped. | ||
| 374 | * This happens a lot: we don't actually set up most of the page | 438 | * This happens a lot: we don't actually set up most of the page |
| 375 | * tables for the Guest at all when we start: as it runs it asks | 439 | * tables for the Guest at all when we start: as it runs it asks |
| 376 | * for more and more, and we set them up as required. In this | 440 | * for more and more, and we set them up as required. In this |
| 377 | * case, we don't even tell the Guest that the fault happened. | 441 | * case, we don't even tell the Guest that the fault happened. |
| 378 | * | 442 | * |
| 379 | * The errcode tells whether this was a read or a write, and | 443 | * The errcode tells whether this was a read or a write, and |
| 380 | * whether kernel or userspace code. */ | 444 | * whether kernel or userspace code. |
| 445 | */ | ||
| 381 | if (demand_page(cpu, cpu->arch.last_pagefault, | 446 | if (demand_page(cpu, cpu->arch.last_pagefault, |
| 382 | cpu->regs->errcode)) | 447 | cpu->regs->errcode)) |
| 383 | return; | 448 | return; |
| 384 | 449 | ||
| 385 | /* OK, it's really not there (or not OK): the Guest needs to | 450 | /* |
| 451 | * OK, it's really not there (or not OK): the Guest needs to | ||
| 386 | * know. We write out the cr2 value so it knows where the | 452 | * know. We write out the cr2 value so it knows where the |
| 387 | * fault occurred. | 453 | * fault occurred. |
| 388 | * | 454 | * |
| 389 | * Note that if the Guest were really messed up, this could | 455 | * Note that if the Guest were really messed up, this could |
| 390 | * happen before it's done the LHCALL_LGUEST_INIT hypercall, so | 456 | * happen before it's done the LHCALL_LGUEST_INIT hypercall, so |
| 391 | * lg->lguest_data could be NULL */ | 457 | * lg->lguest_data could be NULL |
| 458 | */ | ||
| 392 | if (cpu->lg->lguest_data && | 459 | if (cpu->lg->lguest_data && |
| 393 | put_user(cpu->arch.last_pagefault, | 460 | put_user(cpu->arch.last_pagefault, |
| 394 | &cpu->lg->lguest_data->cr2)) | 461 | &cpu->lg->lguest_data->cr2)) |
| 395 | kill_guest(cpu, "Writing cr2"); | 462 | kill_guest(cpu, "Writing cr2"); |
| 396 | break; | 463 | break; |
| 397 | case 7: /* We've intercepted a Device Not Available fault. */ | 464 | case 7: /* We've intercepted a Device Not Available fault. */ |
| 398 | /* If the Guest doesn't want to know, we already restored the | 465 | /* |
| 399 | * Floating Point Unit, so we just continue without telling | 466 | * If the Guest doesn't want to know, we already restored the |
| 400 | * it. */ | 467 | * Floating Point Unit, so we just continue without telling it. |
| 468 | */ | ||
| 401 | if (!cpu->ts) | 469 | if (!cpu->ts) |
| 402 | return; | 470 | return; |
| 403 | break; | 471 | break; |
| 404 | case 32 ... 255: | 472 | case 32 ... 255: |
| 405 | /* These values mean a real interrupt occurred, in which case | 473 | /* |
| 474 | * These values mean a real interrupt occurred, in which case | ||
| 406 | * the Host handler has already been run. We just do a | 475 | * the Host handler has already been run. We just do a |
| 407 | * friendly check if another process should now be run, then | 476 | * friendly check if another process should now be run, then |
| 408 | * return to run the Guest again */ | 477 | * return to run the Guest again |
| 478 | */ | ||
| 409 | cond_resched(); | 479 | cond_resched(); |
| 410 | return; | 480 | return; |
| 411 | case LGUEST_TRAP_ENTRY: | 481 | case LGUEST_TRAP_ENTRY: |
| 412 | /* Our 'struct hcall_args' maps directly over our regs: we set | 482 | /* |
| 413 | * up the pointer now to indicate a hypercall is pending. */ | 483 | * Our 'struct hcall_args' maps directly over our regs: we set |
| 484 | * up the pointer now to indicate a hypercall is pending. | ||
| 485 | */ | ||
| 414 | cpu->hcall = (struct hcall_args *)cpu->regs; | 486 | cpu->hcall = (struct hcall_args *)cpu->regs; |
| 415 | return; | 487 | return; |
| 416 | } | 488 | } |
| 417 | 489 | ||
| 418 | /* We didn't handle the trap, so it needs to go to the Guest. */ | 490 | /* We didn't handle the trap, so it needs to go to the Guest. */ |
| 419 | if (!deliver_trap(cpu, cpu->regs->trapnum)) | 491 | if (!deliver_trap(cpu, cpu->regs->trapnum)) |
| 420 | /* If the Guest doesn't have a handler (either it hasn't | 492 | /* |
| 493 | * If the Guest doesn't have a handler (either it hasn't | ||
| 421 | * registered any yet, or it's one of the faults we don't let | 494 | * registered any yet, or it's one of the faults we don't let |
| 422 | * it handle), it dies with this cryptic error message. */ | 495 | * it handle), it dies with this cryptic error message. |
| 496 | */ | ||
| 423 | kill_guest(cpu, "unhandled trap %li at %#lx (%#lx)", | 497 | kill_guest(cpu, "unhandled trap %li at %#lx (%#lx)", |
| 424 | cpu->regs->trapnum, cpu->regs->eip, | 498 | cpu->regs->trapnum, cpu->regs->eip, |
| 425 | cpu->regs->trapnum == 14 ? cpu->arch.last_pagefault | 499 | cpu->regs->trapnum == 14 ? cpu->arch.last_pagefault |
| 426 | : cpu->regs->errcode); | 500 | : cpu->regs->errcode); |
| 427 | } | 501 | } |
| 428 | 502 | ||
| 429 | /* Now we can look at each of the routines this calls, in increasing order of | 503 | /* |
| 504 | * Now we can look at each of the routines this calls, in increasing order of | ||
| 430 | * complexity: do_hypercalls(), emulate_insn(), maybe_do_interrupt(), | 505 | * complexity: do_hypercalls(), emulate_insn(), maybe_do_interrupt(), |
| 431 | * deliver_trap() and demand_page(). After all those, we'll be ready to | 506 | * deliver_trap() and demand_page(). After all those, we'll be ready to |
| 432 | * examine the Switcher, and our philosophical understanding of the Host/Guest | 507 | * examine the Switcher, and our philosophical understanding of the Host/Guest |
| 433 | * duality will be complete. :*/ | 508 | * duality will be complete. |
| 509 | :*/ | ||
| 434 | static void adjust_pge(void *on) | 510 | static void adjust_pge(void *on) |
| 435 | { | 511 | { |
| 436 | if (on) | 512 | if (on) |
| @@ -439,13 +515,16 @@ static void adjust_pge(void *on) | |||
| 439 | write_cr4(read_cr4() & ~X86_CR4_PGE); | 515 | write_cr4(read_cr4() & ~X86_CR4_PGE); |
| 440 | } | 516 | } |
| 441 | 517 | ||
| 442 | /*H:020 Now the Switcher is mapped and every thing else is ready, we need to do | 518 | /*H:020 |
| 443 | * some more i386-specific initialization. */ | 519 | * Now the Switcher is mapped and every thing else is ready, we need to do |
| 520 | * some more i386-specific initialization. | ||
| 521 | */ | ||
| 444 | void __init lguest_arch_host_init(void) | 522 | void __init lguest_arch_host_init(void) |
| 445 | { | 523 | { |
| 446 | int i; | 524 | int i; |
| 447 | 525 | ||
| 448 | /* Most of the i386/switcher.S doesn't care that it's been moved; on | 526 | /* |
| 527 | * Most of the i386/switcher.S doesn't care that it's been moved; on | ||
| 449 | * Intel, jumps are relative, and it doesn't access any references to | 528 | * Intel, jumps are relative, and it doesn't access any references to |
| 450 | * external code or data. | 529 | * external code or data. |
| 451 | * | 530 | * |
| @@ -453,7 +532,8 @@ void __init lguest_arch_host_init(void) | |||
| 453 | * addresses are placed in a table (default_idt_entries), so we need to | 532 | * addresses are placed in a table (default_idt_entries), so we need to |
| 454 | * update the table with the new addresses. switcher_offset() is a | 533 | * update the table with the new addresses. switcher_offset() is a |
| 455 | * convenience function which returns the distance between the | 534 | * convenience function which returns the distance between the |
| 456 | * compiled-in switcher code and the high-mapped copy we just made. */ | 535 | * compiled-in switcher code and the high-mapped copy we just made. |
| 536 | */ | ||
| 457 | for (i = 0; i < IDT_ENTRIES; i++) | 537 | for (i = 0; i < IDT_ENTRIES; i++) |
| 458 | default_idt_entries[i] += switcher_offset(); | 538 | default_idt_entries[i] += switcher_offset(); |
| 459 | 539 | ||
| @@ -468,63 +548,81 @@ void __init lguest_arch_host_init(void) | |||
| 468 | for_each_possible_cpu(i) { | 548 | for_each_possible_cpu(i) { |
| 469 | /* lguest_pages() returns this CPU's two pages. */ | 549 | /* lguest_pages() returns this CPU's two pages. */ |
| 470 | struct lguest_pages *pages = lguest_pages(i); | 550 | struct lguest_pages *pages = lguest_pages(i); |
| 471 | /* This is a convenience pointer to make the code fit one | 551 | /* This is a convenience pointer to make the code neater. */ |
| 472 | * statement to a line. */ | ||
| 473 | struct lguest_ro_state *state = &pages->state; | 552 | struct lguest_ro_state *state = &pages->state; |
| 474 | 553 | ||
| 475 | /* The Global Descriptor Table: the Host has a different one | 554 | /* |
| 555 | * The Global Descriptor Table: the Host has a different one | ||
| 476 | * for each CPU. We keep a descriptor for the GDT which says | 556 | * for each CPU. We keep a descriptor for the GDT which says |
| 477 | * where it is and how big it is (the size is actually the last | 557 | * where it is and how big it is (the size is actually the last |
| 478 | * byte, not the size, hence the "-1"). */ | 558 | * byte, not the size, hence the "-1"). |
| 559 | */ | ||
| 479 | state->host_gdt_desc.size = GDT_SIZE-1; | 560 | state->host_gdt_desc.size = GDT_SIZE-1; |
| 480 | state->host_gdt_desc.address = (long)get_cpu_gdt_table(i); | 561 | state->host_gdt_desc.address = (long)get_cpu_gdt_table(i); |
| 481 | 562 | ||
| 482 | /* All CPUs on the Host use the same Interrupt Descriptor | 563 | /* |
| 564 | * All CPUs on the Host use the same Interrupt Descriptor | ||
| 483 | * Table, so we just use store_idt(), which gets this CPU's IDT | 565 | * Table, so we just use store_idt(), which gets this CPU's IDT |
| 484 | * descriptor. */ | 566 | * descriptor. |
| 567 | */ | ||
| 485 | store_idt(&state->host_idt_desc); | 568 | store_idt(&state->host_idt_desc); |
| 486 | 569 | ||
| 487 | /* The descriptors for the Guest's GDT and IDT can be filled | 570 | /* |
| 571 | * The descriptors for the Guest's GDT and IDT can be filled | ||
| 488 | * out now, too. We copy the GDT & IDT into ->guest_gdt and | 572 | * out now, too. We copy the GDT & IDT into ->guest_gdt and |
| 489 | * ->guest_idt before actually running the Guest. */ | 573 | * ->guest_idt before actually running the Guest. |
| 574 | */ | ||
| 490 | state->guest_idt_desc.size = sizeof(state->guest_idt)-1; | 575 | state->guest_idt_desc.size = sizeof(state->guest_idt)-1; |
| 491 | state->guest_idt_desc.address = (long)&state->guest_idt; | 576 | state->guest_idt_desc.address = (long)&state->guest_idt; |
| 492 | state->guest_gdt_desc.size = sizeof(state->guest_gdt)-1; | 577 | state->guest_gdt_desc.size = sizeof(state->guest_gdt)-1; |
| 493 | state->guest_gdt_desc.address = (long)&state->guest_gdt; | 578 | state->guest_gdt_desc.address = (long)&state->guest_gdt; |
| 494 | 579 | ||
| 495 | /* We know where we want the stack to be when the Guest enters | 580 | /* |
| 581 | * We know where we want the stack to be when the Guest enters | ||
| 496 | * the Switcher: in pages->regs. The stack grows upwards, so | 582 | * the Switcher: in pages->regs. The stack grows upwards, so |
| 497 | * we start it at the end of that structure. */ | 583 | * we start it at the end of that structure. |
| 584 | */ | ||
| 498 | state->guest_tss.sp0 = (long)(&pages->regs + 1); | 585 | state->guest_tss.sp0 = (long)(&pages->regs + 1); |
| 499 | /* And this is the GDT entry to use for the stack: we keep a | 586 | /* |
| 500 | * couple of special LGUEST entries. */ | 587 | * And this is the GDT entry to use for the stack: we keep a |
| 588 | * couple of special LGUEST entries. | ||
| 589 | */ | ||
| 501 | state->guest_tss.ss0 = LGUEST_DS; | 590 | state->guest_tss.ss0 = LGUEST_DS; |
| 502 | 591 | ||
| 503 | /* x86 can have a finegrained bitmap which indicates what I/O | 592 | /* |
| 593 | * x86 can have a finegrained bitmap which indicates what I/O | ||
| 504 | * ports the process can use. We set it to the end of our | 594 | * ports the process can use. We set it to the end of our |
| 505 | * structure, meaning "none". */ | 595 | * structure, meaning "none". |
| 596 | */ | ||
| 506 | state->guest_tss.io_bitmap_base = sizeof(state->guest_tss); | 597 | state->guest_tss.io_bitmap_base = sizeof(state->guest_tss); |
| 507 | 598 | ||
| 508 | /* Some GDT entries are the same across all Guests, so we can | 599 | /* |
| 509 | * set them up now. */ | 600 | * Some GDT entries are the same across all Guests, so we can |
| 601 | * set them up now. | ||
| 602 | */ | ||
| 510 | setup_default_gdt_entries(state); | 603 | setup_default_gdt_entries(state); |
| 511 | /* Most IDT entries are the same for all Guests, too.*/ | 604 | /* Most IDT entries are the same for all Guests, too.*/ |
| 512 | setup_default_idt_entries(state, default_idt_entries); | 605 | setup_default_idt_entries(state, default_idt_entries); |
| 513 | 606 | ||
| 514 | /* The Host needs to be able to use the LGUEST segments on this | 607 | /* |
| 515 | * CPU, too, so put them in the Host GDT. */ | 608 | * The Host needs to be able to use the LGUEST segments on this |
| 609 | * CPU, too, so put them in the Host GDT. | ||
| 610 | */ | ||
| 516 | get_cpu_gdt_table(i)[GDT_ENTRY_LGUEST_CS] = FULL_EXEC_SEGMENT; | 611 | get_cpu_gdt_table(i)[GDT_ENTRY_LGUEST_CS] = FULL_EXEC_SEGMENT; |
| 517 | get_cpu_gdt_table(i)[GDT_ENTRY_LGUEST_DS] = FULL_SEGMENT; | 612 | get_cpu_gdt_table(i)[GDT_ENTRY_LGUEST_DS] = FULL_SEGMENT; |
| 518 | } | 613 | } |
| 519 | 614 | ||
| 520 | /* In the Switcher, we want the %cs segment register to use the | 615 | /* |
| 616 | * In the Switcher, we want the %cs segment register to use the | ||
| 521 | * LGUEST_CS GDT entry: we've put that in the Host and Guest GDTs, so | 617 | * LGUEST_CS GDT entry: we've put that in the Host and Guest GDTs, so |
| 522 | * it will be undisturbed when we switch. To change %cs and jump we | 618 | * it will be undisturbed when we switch. To change %cs and jump we |
| 523 | * need this structure to feed to Intel's "lcall" instruction. */ | 619 | * need this structure to feed to Intel's "lcall" instruction. |
| 620 | */ | ||
| 524 | lguest_entry.offset = (long)switch_to_guest + switcher_offset(); | 621 | lguest_entry.offset = (long)switch_to_guest + switcher_offset(); |
| 525 | lguest_entry.segment = LGUEST_CS; | 622 | lguest_entry.segment = LGUEST_CS; |
| 526 | 623 | ||
| 527 | /* Finally, we need to turn off "Page Global Enable". PGE is an | 624 | /* |
| 625 | * Finally, we need to turn off "Page Global Enable". PGE is an | ||
| 528 | * optimization where page table entries are specially marked to show | 626 | * optimization where page table entries are specially marked to show |
| 529 | * they never change. The Host kernel marks all the kernel pages this | 627 | * they never change. The Host kernel marks all the kernel pages this |
| 530 | * way because it's always present, even when userspace is running. | 628 | * way because it's always present, even when userspace is running. |
| @@ -534,16 +632,21 @@ void __init lguest_arch_host_init(void) | |||
| 534 | * you'll get really weird bugs that you'll chase for two days. | 632 | * you'll get really weird bugs that you'll chase for two days. |
| 535 | * | 633 | * |
| 536 | * I used to turn PGE off every time we switched to the Guest and back | 634 | * I used to turn PGE off every time we switched to the Guest and back |
| 537 | * on when we return, but that slowed the Switcher down noticibly. */ | 635 | * on when we return, but that slowed the Switcher down noticibly. |
| 636 | */ | ||
| 538 | 637 | ||
| 539 | /* We don't need the complexity of CPUs coming and going while we're | 638 | /* |
| 540 | * doing this. */ | 639 | * We don't need the complexity of CPUs coming and going while we're |
| 640 | * doing this. | ||
| 641 | */ | ||
| 541 | get_online_cpus(); | 642 | get_online_cpus(); |
| 542 | if (cpu_has_pge) { /* We have a broader idea of "global". */ | 643 | if (cpu_has_pge) { /* We have a broader idea of "global". */ |
| 543 | /* Remember that this was originally set (for cleanup). */ | 644 | /* Remember that this was originally set (for cleanup). */ |
| 544 | cpu_had_pge = 1; | 645 | cpu_had_pge = 1; |
| 545 | /* adjust_pge is a helper function which sets or unsets the PGE | 646 | /* |
| 546 | * bit on its CPU, depending on the argument (0 == unset). */ | 647 | * adjust_pge is a helper function which sets or unsets the PGE |
| 648 | * bit on its CPU, depending on the argument (0 == unset). | ||
| 649 | */ | ||
| 547 | on_each_cpu(adjust_pge, (void *)0, 1); | 650 | on_each_cpu(adjust_pge, (void *)0, 1); |
| 548 | /* Turn off the feature in the global feature set. */ | 651 | /* Turn off the feature in the global feature set. */ |
| 549 | clear_cpu_cap(&boot_cpu_data, X86_FEATURE_PGE); | 652 | clear_cpu_cap(&boot_cpu_data, X86_FEATURE_PGE); |
| @@ -590,26 +693,32 @@ int lguest_arch_init_hypercalls(struct lg_cpu *cpu) | |||
| 590 | { | 693 | { |
| 591 | u32 tsc_speed; | 694 | u32 tsc_speed; |
| 592 | 695 | ||
| 593 | /* The pointer to the Guest's "struct lguest_data" is the only argument. | 696 | /* |
| 594 | * We check that address now. */ | 697 | * The pointer to the Guest's "struct lguest_data" is the only argument. |
| 698 | * We check that address now. | ||
| 699 | */ | ||
| 595 | if (!lguest_address_ok(cpu->lg, cpu->hcall->arg1, | 700 | if (!lguest_address_ok(cpu->lg, cpu->hcall->arg1, |
| 596 | sizeof(*cpu->lg->lguest_data))) | 701 | sizeof(*cpu->lg->lguest_data))) |
| 597 | return -EFAULT; | 702 | return -EFAULT; |
| 598 | 703 | ||
| 599 | /* Having checked it, we simply set lg->lguest_data to point straight | 704 | /* |
| 705 | * Having checked it, we simply set lg->lguest_data to point straight | ||
| 600 | * into the Launcher's memory at the right place and then use | 706 | * into the Launcher's memory at the right place and then use |
| 601 | * copy_to_user/from_user from now on, instead of lgread/write. I put | 707 | * copy_to_user/from_user from now on, instead of lgread/write. I put |
| 602 | * this in to show that I'm not immune to writing stupid | 708 | * this in to show that I'm not immune to writing stupid |
| 603 | * optimizations. */ | 709 | * optimizations. |
| 710 | */ | ||
| 604 | cpu->lg->lguest_data = cpu->lg->mem_base + cpu->hcall->arg1; | 711 | cpu->lg->lguest_data = cpu->lg->mem_base + cpu->hcall->arg1; |
| 605 | 712 | ||
| 606 | /* We insist that the Time Stamp Counter exist and doesn't change with | 713 | /* |
| 714 | * We insist that the Time Stamp Counter exist and doesn't change with | ||
| 607 | * cpu frequency. Some devious chip manufacturers decided that TSC | 715 | * cpu frequency. Some devious chip manufacturers decided that TSC |
| 608 | * changes could be handled in software. I decided that time going | 716 | * changes could be handled in software. I decided that time going |
| 609 | * backwards might be good for benchmarks, but it's bad for users. | 717 | * backwards might be good for benchmarks, but it's bad for users. |
| 610 | * | 718 | * |
| 611 | * We also insist that the TSC be stable: the kernel detects unreliable | 719 | * We also insist that the TSC be stable: the kernel detects unreliable |
| 612 | * TSCs for its own purposes, and we use that here. */ | 720 | * TSCs for its own purposes, and we use that here. |
| 721 | */ | ||
| 613 | if (boot_cpu_has(X86_FEATURE_CONSTANT_TSC) && !check_tsc_unstable()) | 722 | if (boot_cpu_has(X86_FEATURE_CONSTANT_TSC) && !check_tsc_unstable()) |
| 614 | tsc_speed = tsc_khz; | 723 | tsc_speed = tsc_khz; |
| 615 | else | 724 | else |
| @@ -625,38 +734,47 @@ int lguest_arch_init_hypercalls(struct lg_cpu *cpu) | |||
| 625 | } | 734 | } |
| 626 | /*:*/ | 735 | /*:*/ |
| 627 | 736 | ||
| 628 | /*L:030 lguest_arch_setup_regs() | 737 | /*L:030 |
| 738 | * lguest_arch_setup_regs() | ||
| 629 | * | 739 | * |
| 630 | * Most of the Guest's registers are left alone: we used get_zeroed_page() to | 740 | * Most of the Guest's registers are left alone: we used get_zeroed_page() to |
| 631 | * allocate the structure, so they will be 0. */ | 741 | * allocate the structure, so they will be 0. |
| 742 | */ | ||
| 632 | void lguest_arch_setup_regs(struct lg_cpu *cpu, unsigned long start) | 743 | void lguest_arch_setup_regs(struct lg_cpu *cpu, unsigned long start) |
| 633 | { | 744 | { |
| 634 | struct lguest_regs *regs = cpu->regs; | 745 | struct lguest_regs *regs = cpu->regs; |
| 635 | 746 | ||
| 636 | /* There are four "segment" registers which the Guest needs to boot: | 747 | /* |
| 748 | * There are four "segment" registers which the Guest needs to boot: | ||
| 637 | * The "code segment" register (cs) refers to the kernel code segment | 749 | * The "code segment" register (cs) refers to the kernel code segment |
| 638 | * __KERNEL_CS, and the "data", "extra" and "stack" segment registers | 750 | * __KERNEL_CS, and the "data", "extra" and "stack" segment registers |
| 639 | * refer to the kernel data segment __KERNEL_DS. | 751 | * refer to the kernel data segment __KERNEL_DS. |
| 640 | * | 752 | * |
| 641 | * The privilege level is packed into the lower bits. The Guest runs | 753 | * The privilege level is packed into the lower bits. The Guest runs |
| 642 | * at privilege level 1 (GUEST_PL).*/ | 754 | * at privilege level 1 (GUEST_PL). |
| 755 | */ | ||
| 643 | regs->ds = regs->es = regs->ss = __KERNEL_DS|GUEST_PL; | 756 | regs->ds = regs->es = regs->ss = __KERNEL_DS|GUEST_PL; |
| 644 | regs->cs = __KERNEL_CS|GUEST_PL; | 757 | regs->cs = __KERNEL_CS|GUEST_PL; |
| 645 | 758 | ||
| 646 | /* The "eflags" register contains miscellaneous flags. Bit 1 (0x002) | 759 | /* |
| 760 | * The "eflags" register contains miscellaneous flags. Bit 1 (0x002) | ||
| 647 | * is supposed to always be "1". Bit 9 (0x200) controls whether | 761 | * is supposed to always be "1". Bit 9 (0x200) controls whether |
| 648 | * interrupts are enabled. We always leave interrupts enabled while | 762 | * interrupts are enabled. We always leave interrupts enabled while |
| 649 | * running the Guest. */ | 763 | * running the Guest. |
| 764 | */ | ||
| 650 | regs->eflags = X86_EFLAGS_IF | 0x2; | 765 | regs->eflags = X86_EFLAGS_IF | 0x2; |
| 651 | 766 | ||
| 652 | /* The "Extended Instruction Pointer" register says where the Guest is | 767 | /* |
| 653 | * running. */ | 768 | * The "Extended Instruction Pointer" register says where the Guest is |
| 769 | * running. | ||
| 770 | */ | ||
| 654 | regs->eip = start; | 771 | regs->eip = start; |
| 655 | 772 | ||
| 656 | /* %esi points to our boot information, at physical address 0, so don't | 773 | /* |
| 657 | * touch it. */ | 774 | * %esi points to our boot information, at physical address 0, so don't |
| 775 | * touch it. | ||
| 776 | */ | ||
| 658 | 777 | ||
| 659 | /* There are a couple of GDT entries the Guest expects when first | 778 | /* There are a couple of GDT entries the Guest expects at boot. */ |
| 660 | * booting. */ | ||
| 661 | setup_guest_gdt(cpu); | 779 | setup_guest_gdt(cpu); |
| 662 | } | 780 | } |
diff --git a/drivers/lguest/x86/switcher_32.S b/drivers/lguest/x86/switcher_32.S index 3fc15318a80f..40634b0db9f7 100644 --- a/drivers/lguest/x86/switcher_32.S +++ b/drivers/lguest/x86/switcher_32.S | |||
| @@ -1,12 +1,15 @@ | |||
| 1 | /*P:900 This is the Switcher: code which sits at 0xFFC00000 astride both the | 1 | /*P:900 |
| 2 | * Host and Guest to do the low-level Guest<->Host switch. It is as simple as | 2 | * This is the Switcher: code which sits at 0xFFC00000 (or 0xFFE00000) astride |
| 3 | * it can be made, but it's naturally very specific to x86. | 3 | * both the Host and Guest to do the low-level Guest<->Host switch. It is as |
| 4 | * simple as it can be made, but it's naturally very specific to x86. | ||
| 4 | * | 5 | * |
| 5 | * You have now completed Preparation. If this has whet your appetite; if you | 6 | * You have now completed Preparation. If this has whet your appetite; if you |
| 6 | * are feeling invigorated and refreshed then the next, more challenging stage | 7 | * are feeling invigorated and refreshed then the next, more challenging stage |
| 7 | * can be found in "make Guest". :*/ | 8 | * can be found in "make Guest". |
| 9 | :*/ | ||
| 8 | 10 | ||
| 9 | /*M:012 Lguest is meant to be simple: my rule of thumb is that 1% more LOC must | 11 | /*M:012 |
| 12 | * Lguest is meant to be simple: my rule of thumb is that 1% more LOC must | ||
| 10 | * gain at least 1% more performance. Since neither LOC nor performance can be | 13 | * gain at least 1% more performance. Since neither LOC nor performance can be |
| 11 | * measured beforehand, it generally means implementing a feature then deciding | 14 | * measured beforehand, it generally means implementing a feature then deciding |
| 12 | * if it's worth it. And once it's implemented, who can say no? | 15 | * if it's worth it. And once it's implemented, who can say no? |
| @@ -31,11 +34,14 @@ | |||
| 31 | * Host (which is actually really easy). | 34 | * Host (which is actually really easy). |
| 32 | * | 35 | * |
| 33 | * Two questions remain. Would the performance gain outweigh the complexity? | 36 | * Two questions remain. Would the performance gain outweigh the complexity? |
| 34 | * And who would write the verse documenting it? :*/ | 37 | * And who would write the verse documenting it? |
| 38 | :*/ | ||
| 35 | 39 | ||
| 36 | /*M:011 Lguest64 handles NMI. This gave me NMI envy (until I looked at their | 40 | /*M:011 |
| 41 | * Lguest64 handles NMI. This gave me NMI envy (until I looked at their | ||
| 37 | * code). It's worth doing though, since it would let us use oprofile in the | 42 | * code). It's worth doing though, since it would let us use oprofile in the |
| 38 | * Host when a Guest is running. :*/ | 43 | * Host when a Guest is running. |
| 44 | :*/ | ||
| 39 | 45 | ||
| 40 | /*S:100 | 46 | /*S:100 |
| 41 | * Welcome to the Switcher itself! | 47 | * Welcome to the Switcher itself! |
diff --git a/drivers/macintosh/via-maciisi.c b/drivers/macintosh/via-maciisi.c index 4d686c0bdea0..9ab5b0c34f0d 100644 --- a/drivers/macintosh/via-maciisi.c +++ b/drivers/macintosh/via-maciisi.c | |||
| @@ -288,7 +288,7 @@ static void maciisi_sync(struct adb_request *req) | |||
| 288 | } | 288 | } |
| 289 | /* This could be BAD... when the ADB controller doesn't respond | 289 | /* This could be BAD... when the ADB controller doesn't respond |
| 290 | * for this long, it's probably not coming back :-( */ | 290 | * for this long, it's probably not coming back :-( */ |
| 291 | if(count >= 50) /* Hopefully shouldn't happen */ | 291 | if (count > 50) /* Hopefully shouldn't happen */ |
| 292 | printk(KERN_ERR "maciisi_send_request: poll timed out!\n"); | 292 | printk(KERN_ERR "maciisi_send_request: poll timed out!\n"); |
| 293 | } | 293 | } |
| 294 | 294 | ||
diff --git a/drivers/md/dm-crypt.c b/drivers/md/dm-crypt.c index 529e2ba505c3..ed1038164019 100644 --- a/drivers/md/dm-crypt.c +++ b/drivers/md/dm-crypt.c | |||
| @@ -1318,7 +1318,7 @@ static int crypt_iterate_devices(struct dm_target *ti, | |||
| 1318 | { | 1318 | { |
| 1319 | struct crypt_config *cc = ti->private; | 1319 | struct crypt_config *cc = ti->private; |
| 1320 | 1320 | ||
| 1321 | return fn(ti, cc->dev, cc->start, data); | 1321 | return fn(ti, cc->dev, cc->start, ti->len, data); |
| 1322 | } | 1322 | } |
| 1323 | 1323 | ||
| 1324 | static struct target_type crypt_target = { | 1324 | static struct target_type crypt_target = { |
diff --git a/drivers/md/dm-delay.c b/drivers/md/dm-delay.c index 4e5b843cd4d7..ebe7381f47c8 100644 --- a/drivers/md/dm-delay.c +++ b/drivers/md/dm-delay.c | |||
| @@ -324,12 +324,12 @@ static int delay_iterate_devices(struct dm_target *ti, | |||
| 324 | struct delay_c *dc = ti->private; | 324 | struct delay_c *dc = ti->private; |
| 325 | int ret = 0; | 325 | int ret = 0; |
| 326 | 326 | ||
| 327 | ret = fn(ti, dc->dev_read, dc->start_read, data); | 327 | ret = fn(ti, dc->dev_read, dc->start_read, ti->len, data); |
| 328 | if (ret) | 328 | if (ret) |
| 329 | goto out; | 329 | goto out; |
| 330 | 330 | ||
| 331 | if (dc->dev_write) | 331 | if (dc->dev_write) |
| 332 | ret = fn(ti, dc->dev_write, dc->start_write, data); | 332 | ret = fn(ti, dc->dev_write, dc->start_write, ti->len, data); |
| 333 | 333 | ||
| 334 | out: | 334 | out: |
| 335 | return ret; | 335 | return ret; |
diff --git a/drivers/md/dm-linear.c b/drivers/md/dm-linear.c index 9184b6deb868..82f7d6e6b1ea 100644 --- a/drivers/md/dm-linear.c +++ b/drivers/md/dm-linear.c | |||
| @@ -139,7 +139,7 @@ static int linear_iterate_devices(struct dm_target *ti, | |||
| 139 | { | 139 | { |
| 140 | struct linear_c *lc = ti->private; | 140 | struct linear_c *lc = ti->private; |
| 141 | 141 | ||
| 142 | return fn(ti, lc->dev, lc->start, data); | 142 | return fn(ti, lc->dev, lc->start, ti->len, data); |
| 143 | } | 143 | } |
| 144 | 144 | ||
| 145 | static struct target_type linear_target = { | 145 | static struct target_type linear_target = { |
diff --git a/drivers/md/dm-log-userspace-transfer.c b/drivers/md/dm-log-userspace-transfer.c index 0ca1ee768a1f..8ce74d95ae4d 100644 --- a/drivers/md/dm-log-userspace-transfer.c +++ b/drivers/md/dm-log-userspace-transfer.c | |||
| @@ -108,7 +108,7 @@ static int fill_pkg(struct cn_msg *msg, struct dm_ulog_request *tfr) | |||
| 108 | *(pkg->data_size) = 0; | 108 | *(pkg->data_size) = 0; |
| 109 | } else if (tfr->data_size > *(pkg->data_size)) { | 109 | } else if (tfr->data_size > *(pkg->data_size)) { |
| 110 | DMERR("Insufficient space to receive package [%u] " | 110 | DMERR("Insufficient space to receive package [%u] " |
| 111 | "(%u vs %lu)", tfr->request_type, | 111 | "(%u vs %zu)", tfr->request_type, |
| 112 | tfr->data_size, *(pkg->data_size)); | 112 | tfr->data_size, *(pkg->data_size)); |
| 113 | 113 | ||
| 114 | *(pkg->data_size) = 0; | 114 | *(pkg->data_size) = 0; |
diff --git a/drivers/md/dm-mpath.c b/drivers/md/dm-mpath.c index c70604a20897..6f0d90d4a541 100644 --- a/drivers/md/dm-mpath.c +++ b/drivers/md/dm-mpath.c | |||
| @@ -1453,7 +1453,7 @@ static int multipath_iterate_devices(struct dm_target *ti, | |||
| 1453 | 1453 | ||
| 1454 | list_for_each_entry(pg, &m->priority_groups, list) { | 1454 | list_for_each_entry(pg, &m->priority_groups, list) { |
| 1455 | list_for_each_entry(p, &pg->pgpaths, list) { | 1455 | list_for_each_entry(p, &pg->pgpaths, list) { |
| 1456 | ret = fn(ti, p->path.dev, ti->begin, data); | 1456 | ret = fn(ti, p->path.dev, ti->begin, ti->len, data); |
| 1457 | if (ret) | 1457 | if (ret) |
| 1458 | goto out; | 1458 | goto out; |
| 1459 | } | 1459 | } |
diff --git a/drivers/md/dm-raid1.c b/drivers/md/dm-raid1.c index ce8868c768cc..9726577cde49 100644 --- a/drivers/md/dm-raid1.c +++ b/drivers/md/dm-raid1.c | |||
| @@ -638,6 +638,7 @@ static void do_writes(struct mirror_set *ms, struct bio_list *writes) | |||
| 638 | spin_lock_irq(&ms->lock); | 638 | spin_lock_irq(&ms->lock); |
| 639 | bio_list_merge(&ms->writes, &requeue); | 639 | bio_list_merge(&ms->writes, &requeue); |
| 640 | spin_unlock_irq(&ms->lock); | 640 | spin_unlock_irq(&ms->lock); |
| 641 | delayed_wake(ms); | ||
| 641 | } | 642 | } |
| 642 | 643 | ||
| 643 | /* | 644 | /* |
| @@ -1292,7 +1293,7 @@ static int mirror_iterate_devices(struct dm_target *ti, | |||
| 1292 | 1293 | ||
| 1293 | for (i = 0; !ret && i < ms->nr_mirrors; i++) | 1294 | for (i = 0; !ret && i < ms->nr_mirrors; i++) |
| 1294 | ret = fn(ti, ms->mirror[i].dev, | 1295 | ret = fn(ti, ms->mirror[i].dev, |
| 1295 | ms->mirror[i].offset, data); | 1296 | ms->mirror[i].offset, ti->len, data); |
| 1296 | 1297 | ||
| 1297 | return ret; | 1298 | return ret; |
| 1298 | } | 1299 | } |
diff --git a/drivers/md/dm-stripe.c b/drivers/md/dm-stripe.c index b240e85ae39a..4e0e5937e42a 100644 --- a/drivers/md/dm-stripe.c +++ b/drivers/md/dm-stripe.c | |||
| @@ -320,10 +320,11 @@ static int stripe_iterate_devices(struct dm_target *ti, | |||
| 320 | int ret = 0; | 320 | int ret = 0; |
| 321 | unsigned i = 0; | 321 | unsigned i = 0; |
| 322 | 322 | ||
| 323 | do | 323 | do { |
| 324 | ret = fn(ti, sc->stripe[i].dev, | 324 | ret = fn(ti, sc->stripe[i].dev, |
| 325 | sc->stripe[i].physical_start, data); | 325 | sc->stripe[i].physical_start, |
| 326 | while (!ret && ++i < sc->stripes); | 326 | sc->stripe_width, data); |
| 327 | } while (!ret && ++i < sc->stripes); | ||
| 327 | 328 | ||
| 328 | return ret; | 329 | return ret; |
| 329 | } | 330 | } |
diff --git a/drivers/md/dm-table.c b/drivers/md/dm-table.c index 2cba557d9e61..d952b3441913 100644 --- a/drivers/md/dm-table.c +++ b/drivers/md/dm-table.c | |||
| @@ -346,7 +346,7 @@ static void close_dev(struct dm_dev_internal *d, struct mapped_device *md) | |||
| 346 | * If possible, this checks an area of a destination device is valid. | 346 | * If possible, this checks an area of a destination device is valid. |
| 347 | */ | 347 | */ |
| 348 | static int device_area_is_valid(struct dm_target *ti, struct dm_dev *dev, | 348 | static int device_area_is_valid(struct dm_target *ti, struct dm_dev *dev, |
| 349 | sector_t start, void *data) | 349 | sector_t start, sector_t len, void *data) |
| 350 | { | 350 | { |
| 351 | struct queue_limits *limits = data; | 351 | struct queue_limits *limits = data; |
| 352 | struct block_device *bdev = dev->bdev; | 352 | struct block_device *bdev = dev->bdev; |
| @@ -359,7 +359,7 @@ static int device_area_is_valid(struct dm_target *ti, struct dm_dev *dev, | |||
| 359 | if (!dev_size) | 359 | if (!dev_size) |
| 360 | return 1; | 360 | return 1; |
| 361 | 361 | ||
| 362 | if ((start >= dev_size) || (start + ti->len > dev_size)) { | 362 | if ((start >= dev_size) || (start + len > dev_size)) { |
| 363 | DMWARN("%s: %s too small for target", | 363 | DMWARN("%s: %s too small for target", |
| 364 | dm_device_name(ti->table->md), bdevname(bdev, b)); | 364 | dm_device_name(ti->table->md), bdevname(bdev, b)); |
| 365 | return 0; | 365 | return 0; |
| @@ -377,11 +377,11 @@ static int device_area_is_valid(struct dm_target *ti, struct dm_dev *dev, | |||
| 377 | return 0; | 377 | return 0; |
| 378 | } | 378 | } |
| 379 | 379 | ||
| 380 | if (ti->len & (logical_block_size_sectors - 1)) { | 380 | if (len & (logical_block_size_sectors - 1)) { |
| 381 | DMWARN("%s: len=%llu not aligned to h/w " | 381 | DMWARN("%s: len=%llu not aligned to h/w " |
| 382 | "logical block size %hu of %s", | 382 | "logical block size %hu of %s", |
| 383 | dm_device_name(ti->table->md), | 383 | dm_device_name(ti->table->md), |
| 384 | (unsigned long long)ti->len, | 384 | (unsigned long long)len, |
| 385 | limits->logical_block_size, bdevname(bdev, b)); | 385 | limits->logical_block_size, bdevname(bdev, b)); |
| 386 | return 0; | 386 | return 0; |
| 387 | } | 387 | } |
| @@ -482,7 +482,7 @@ static int __table_get_device(struct dm_table *t, struct dm_target *ti, | |||
| 482 | #define min_not_zero(l, r) (l == 0) ? r : ((r == 0) ? l : min(l, r)) | 482 | #define min_not_zero(l, r) (l == 0) ? r : ((r == 0) ? l : min(l, r)) |
| 483 | 483 | ||
| 484 | int dm_set_device_limits(struct dm_target *ti, struct dm_dev *dev, | 484 | int dm_set_device_limits(struct dm_target *ti, struct dm_dev *dev, |
| 485 | sector_t start, void *data) | 485 | sector_t start, sector_t len, void *data) |
| 486 | { | 486 | { |
| 487 | struct queue_limits *limits = data; | 487 | struct queue_limits *limits = data; |
| 488 | struct block_device *bdev = dev->bdev; | 488 | struct block_device *bdev = dev->bdev; |
| @@ -830,11 +830,6 @@ unsigned dm_table_get_type(struct dm_table *t) | |||
| 830 | return t->type; | 830 | return t->type; |
| 831 | } | 831 | } |
| 832 | 832 | ||
| 833 | bool dm_table_bio_based(struct dm_table *t) | ||
| 834 | { | ||
| 835 | return dm_table_get_type(t) == DM_TYPE_BIO_BASED; | ||
| 836 | } | ||
| 837 | |||
| 838 | bool dm_table_request_based(struct dm_table *t) | 833 | bool dm_table_request_based(struct dm_table *t) |
| 839 | { | 834 | { |
| 840 | return dm_table_get_type(t) == DM_TYPE_REQUEST_BASED; | 835 | return dm_table_get_type(t) == DM_TYPE_REQUEST_BASED; |
diff --git a/drivers/md/dm.c b/drivers/md/dm.c index 9acd54a5cffb..8a311ea0d441 100644 --- a/drivers/md/dm.c +++ b/drivers/md/dm.c | |||
| @@ -2203,16 +2203,6 @@ int dm_swap_table(struct mapped_device *md, struct dm_table *table) | |||
| 2203 | goto out; | 2203 | goto out; |
| 2204 | } | 2204 | } |
| 2205 | 2205 | ||
| 2206 | /* | ||
| 2207 | * It is enought that blk_queue_ordered() is called only once when | ||
| 2208 | * the first bio-based table is bound. | ||
| 2209 | * | ||
| 2210 | * This setting should be moved to alloc_dev() when request-based dm | ||
| 2211 | * supports barrier. | ||
| 2212 | */ | ||
| 2213 | if (!md->map && dm_table_bio_based(table)) | ||
| 2214 | blk_queue_ordered(md->queue, QUEUE_ORDERED_DRAIN, NULL); | ||
| 2215 | |||
| 2216 | __unbind(md); | 2206 | __unbind(md); |
| 2217 | r = __bind(md, table, &limits); | 2207 | r = __bind(md, table, &limits); |
| 2218 | 2208 | ||
diff --git a/drivers/md/dm.h b/drivers/md/dm.h index 23278ae80f08..a7663eba17e2 100644 --- a/drivers/md/dm.h +++ b/drivers/md/dm.h | |||
| @@ -61,7 +61,6 @@ int dm_table_any_congested(struct dm_table *t, int bdi_bits); | |||
| 61 | int dm_table_any_busy_target(struct dm_table *t); | 61 | int dm_table_any_busy_target(struct dm_table *t); |
| 62 | int dm_table_set_type(struct dm_table *t); | 62 | int dm_table_set_type(struct dm_table *t); |
| 63 | unsigned dm_table_get_type(struct dm_table *t); | 63 | unsigned dm_table_get_type(struct dm_table *t); |
| 64 | bool dm_table_bio_based(struct dm_table *t); | ||
| 65 | bool dm_table_request_based(struct dm_table *t); | 64 | bool dm_table_request_based(struct dm_table *t); |
| 66 | int dm_table_alloc_md_mempools(struct dm_table *t); | 65 | int dm_table_alloc_md_mempools(struct dm_table *t); |
| 67 | void dm_table_free_md_mempools(struct dm_table *t); | 66 | void dm_table_free_md_mempools(struct dm_table *t); |
diff --git a/drivers/md/linear.c b/drivers/md/linear.c index 5810fa906af0..5fe39c2a3d2b 100644 --- a/drivers/md/linear.c +++ b/drivers/md/linear.c | |||
| @@ -220,6 +220,7 @@ static int linear_run (mddev_t *mddev) | |||
| 220 | mddev->queue->unplug_fn = linear_unplug; | 220 | mddev->queue->unplug_fn = linear_unplug; |
| 221 | mddev->queue->backing_dev_info.congested_fn = linear_congested; | 221 | mddev->queue->backing_dev_info.congested_fn = linear_congested; |
| 222 | mddev->queue->backing_dev_info.congested_data = mddev; | 222 | mddev->queue->backing_dev_info.congested_data = mddev; |
| 223 | md_integrity_register(mddev); | ||
| 223 | return 0; | 224 | return 0; |
| 224 | } | 225 | } |
| 225 | 226 | ||
| @@ -256,6 +257,7 @@ static int linear_add(mddev_t *mddev, mdk_rdev_t *rdev) | |||
| 256 | rcu_assign_pointer(mddev->private, newconf); | 257 | rcu_assign_pointer(mddev->private, newconf); |
| 257 | md_set_array_sectors(mddev, linear_size(mddev, 0, 0)); | 258 | md_set_array_sectors(mddev, linear_size(mddev, 0, 0)); |
| 258 | set_capacity(mddev->gendisk, mddev->array_sectors); | 259 | set_capacity(mddev->gendisk, mddev->array_sectors); |
| 260 | revalidate_disk(mddev->gendisk); | ||
| 259 | call_rcu(&oldconf->rcu, free_conf); | 261 | call_rcu(&oldconf->rcu, free_conf); |
| 260 | return 0; | 262 | return 0; |
| 261 | } | 263 | } |
diff --git a/drivers/md/md.c b/drivers/md/md.c index d4351ff0849f..9dd872000cec 100644 --- a/drivers/md/md.c +++ b/drivers/md/md.c | |||
| @@ -359,6 +359,7 @@ static mddev_t * mddev_find(dev_t unit) | |||
| 359 | else | 359 | else |
| 360 | new->md_minor = MINOR(unit) >> MdpMinorShift; | 360 | new->md_minor = MINOR(unit) >> MdpMinorShift; |
| 361 | 361 | ||
| 362 | mutex_init(&new->open_mutex); | ||
| 362 | mutex_init(&new->reconfig_mutex); | 363 | mutex_init(&new->reconfig_mutex); |
| 363 | INIT_LIST_HEAD(&new->disks); | 364 | INIT_LIST_HEAD(&new->disks); |
| 364 | INIT_LIST_HEAD(&new->all_mddevs); | 365 | INIT_LIST_HEAD(&new->all_mddevs); |
| @@ -1308,7 +1309,12 @@ static int super_1_validate(mddev_t *mddev, mdk_rdev_t *rdev) | |||
| 1308 | } | 1309 | } |
| 1309 | if (mddev->level != LEVEL_MULTIPATH) { | 1310 | if (mddev->level != LEVEL_MULTIPATH) { |
| 1310 | int role; | 1311 | int role; |
| 1311 | role = le16_to_cpu(sb->dev_roles[rdev->desc_nr]); | 1312 | if (rdev->desc_nr < 0 || |
| 1313 | rdev->desc_nr >= le32_to_cpu(sb->max_dev)) { | ||
| 1314 | role = 0xffff; | ||
| 1315 | rdev->desc_nr = -1; | ||
| 1316 | } else | ||
| 1317 | role = le16_to_cpu(sb->dev_roles[rdev->desc_nr]); | ||
| 1312 | switch(role) { | 1318 | switch(role) { |
| 1313 | case 0xffff: /* spare */ | 1319 | case 0xffff: /* spare */ |
| 1314 | break; | 1320 | break; |
| @@ -1394,8 +1400,14 @@ static void super_1_sync(mddev_t *mddev, mdk_rdev_t *rdev) | |||
| 1394 | if (rdev2->desc_nr+1 > max_dev) | 1400 | if (rdev2->desc_nr+1 > max_dev) |
| 1395 | max_dev = rdev2->desc_nr+1; | 1401 | max_dev = rdev2->desc_nr+1; |
| 1396 | 1402 | ||
| 1397 | if (max_dev > le32_to_cpu(sb->max_dev)) | 1403 | if (max_dev > le32_to_cpu(sb->max_dev)) { |
| 1404 | int bmask; | ||
| 1398 | sb->max_dev = cpu_to_le32(max_dev); | 1405 | sb->max_dev = cpu_to_le32(max_dev); |
| 1406 | rdev->sb_size = max_dev * 2 + 256; | ||
| 1407 | bmask = queue_logical_block_size(rdev->bdev->bd_disk->queue)-1; | ||
| 1408 | if (rdev->sb_size & bmask) | ||
| 1409 | rdev->sb_size = (rdev->sb_size | bmask) + 1; | ||
| 1410 | } | ||
| 1399 | for (i=0; i<max_dev;i++) | 1411 | for (i=0; i<max_dev;i++) |
| 1400 | sb->dev_roles[i] = cpu_to_le16(0xfffe); | 1412 | sb->dev_roles[i] = cpu_to_le16(0xfffe); |
| 1401 | 1413 | ||
| @@ -1487,37 +1499,76 @@ static int match_mddev_units(mddev_t *mddev1, mddev_t *mddev2) | |||
| 1487 | 1499 | ||
| 1488 | static LIST_HEAD(pending_raid_disks); | 1500 | static LIST_HEAD(pending_raid_disks); |
| 1489 | 1501 | ||
| 1490 | static void md_integrity_check(mdk_rdev_t *rdev, mddev_t *mddev) | 1502 | /* |
| 1503 | * Try to register data integrity profile for an mddev | ||
| 1504 | * | ||
| 1505 | * This is called when an array is started and after a disk has been kicked | ||
| 1506 | * from the array. It only succeeds if all working and active component devices | ||
| 1507 | * are integrity capable with matching profiles. | ||
| 1508 | */ | ||
| 1509 | int md_integrity_register(mddev_t *mddev) | ||
| 1510 | { | ||
| 1511 | mdk_rdev_t *rdev, *reference = NULL; | ||
| 1512 | |||
| 1513 | if (list_empty(&mddev->disks)) | ||
| 1514 | return 0; /* nothing to do */ | ||
| 1515 | if (blk_get_integrity(mddev->gendisk)) | ||
| 1516 | return 0; /* already registered */ | ||
| 1517 | list_for_each_entry(rdev, &mddev->disks, same_set) { | ||
| 1518 | /* skip spares and non-functional disks */ | ||
| 1519 | if (test_bit(Faulty, &rdev->flags)) | ||
| 1520 | continue; | ||
| 1521 | if (rdev->raid_disk < 0) | ||
| 1522 | continue; | ||
| 1523 | /* | ||
| 1524 | * If at least one rdev is not integrity capable, we can not | ||
| 1525 | * enable data integrity for the md device. | ||
| 1526 | */ | ||
| 1527 | if (!bdev_get_integrity(rdev->bdev)) | ||
| 1528 | return -EINVAL; | ||
| 1529 | if (!reference) { | ||
| 1530 | /* Use the first rdev as the reference */ | ||
| 1531 | reference = rdev; | ||
| 1532 | continue; | ||
| 1533 | } | ||
| 1534 | /* does this rdev's profile match the reference profile? */ | ||
| 1535 | if (blk_integrity_compare(reference->bdev->bd_disk, | ||
| 1536 | rdev->bdev->bd_disk) < 0) | ||
| 1537 | return -EINVAL; | ||
| 1538 | } | ||
| 1539 | /* | ||
| 1540 | * All component devices are integrity capable and have matching | ||
| 1541 | * profiles, register the common profile for the md device. | ||
| 1542 | */ | ||
| 1543 | if (blk_integrity_register(mddev->gendisk, | ||
| 1544 | bdev_get_integrity(reference->bdev)) != 0) { | ||
| 1545 | printk(KERN_ERR "md: failed to register integrity for %s\n", | ||
| 1546 | mdname(mddev)); | ||
| 1547 | return -EINVAL; | ||
| 1548 | } | ||
| 1549 | printk(KERN_NOTICE "md: data integrity on %s enabled\n", | ||
| 1550 | mdname(mddev)); | ||
| 1551 | return 0; | ||
| 1552 | } | ||
| 1553 | EXPORT_SYMBOL(md_integrity_register); | ||
| 1554 | |||
| 1555 | /* Disable data integrity if non-capable/non-matching disk is being added */ | ||
| 1556 | void md_integrity_add_rdev(mdk_rdev_t *rdev, mddev_t *mddev) | ||
| 1491 | { | 1557 | { |
| 1492 | struct mdk_personality *pers = mddev->pers; | ||
| 1493 | struct gendisk *disk = mddev->gendisk; | ||
| 1494 | struct blk_integrity *bi_rdev = bdev_get_integrity(rdev->bdev); | 1558 | struct blk_integrity *bi_rdev = bdev_get_integrity(rdev->bdev); |
| 1495 | struct blk_integrity *bi_mddev = blk_get_integrity(disk); | 1559 | struct blk_integrity *bi_mddev = blk_get_integrity(mddev->gendisk); |
| 1496 | 1560 | ||
| 1497 | /* Data integrity passthrough not supported on RAID 4, 5 and 6 */ | 1561 | if (!bi_mddev) /* nothing to do */ |
| 1498 | if (pers && pers->level >= 4 && pers->level <= 6) | ||
| 1499 | return; | 1562 | return; |
| 1500 | 1563 | if (rdev->raid_disk < 0) /* skip spares */ | |
| 1501 | /* If rdev is integrity capable, register profile for mddev */ | ||
| 1502 | if (!bi_mddev && bi_rdev) { | ||
| 1503 | if (blk_integrity_register(disk, bi_rdev)) | ||
| 1504 | printk(KERN_ERR "%s: %s Could not register integrity!\n", | ||
| 1505 | __func__, disk->disk_name); | ||
| 1506 | else | ||
| 1507 | printk(KERN_NOTICE "Enabling data integrity on %s\n", | ||
| 1508 | disk->disk_name); | ||
| 1509 | return; | 1564 | return; |
| 1510 | } | 1565 | if (bi_rdev && blk_integrity_compare(mddev->gendisk, |
| 1511 | 1566 | rdev->bdev->bd_disk) >= 0) | |
| 1512 | /* Check that mddev and rdev have matching profiles */ | 1567 | return; |
| 1513 | if (blk_integrity_compare(disk, rdev->bdev->bd_disk) < 0) { | 1568 | printk(KERN_NOTICE "disabling data integrity on %s\n", mdname(mddev)); |
| 1514 | printk(KERN_ERR "%s: %s/%s integrity mismatch!\n", __func__, | 1569 | blk_integrity_unregister(mddev->gendisk); |
| 1515 | disk->disk_name, rdev->bdev->bd_disk->disk_name); | ||
| 1516 | printk(KERN_NOTICE "Disabling data integrity on %s\n", | ||
| 1517 | disk->disk_name); | ||
| 1518 | blk_integrity_unregister(disk); | ||
| 1519 | } | ||
| 1520 | } | 1570 | } |
| 1571 | EXPORT_SYMBOL(md_integrity_add_rdev); | ||
| 1521 | 1572 | ||
| 1522 | static int bind_rdev_to_array(mdk_rdev_t * rdev, mddev_t * mddev) | 1573 | static int bind_rdev_to_array(mdk_rdev_t * rdev, mddev_t * mddev) |
| 1523 | { | 1574 | { |
| @@ -1591,7 +1642,6 @@ static int bind_rdev_to_array(mdk_rdev_t * rdev, mddev_t * mddev) | |||
| 1591 | /* May as well allow recovery to be retried once */ | 1642 | /* May as well allow recovery to be retried once */ |
| 1592 | mddev->recovery_disabled = 0; | 1643 | mddev->recovery_disabled = 0; |
| 1593 | 1644 | ||
| 1594 | md_integrity_check(rdev, mddev); | ||
| 1595 | return 0; | 1645 | return 0; |
| 1596 | 1646 | ||
| 1597 | fail: | 1647 | fail: |
| @@ -1925,17 +1975,14 @@ repeat: | |||
| 1925 | /* otherwise we have to go forward and ... */ | 1975 | /* otherwise we have to go forward and ... */ |
| 1926 | mddev->events ++; | 1976 | mddev->events ++; |
| 1927 | if (!mddev->in_sync || mddev->recovery_cp != MaxSector) { /* not clean */ | 1977 | if (!mddev->in_sync || mddev->recovery_cp != MaxSector) { /* not clean */ |
| 1928 | /* .. if the array isn't clean, insist on an odd 'events' */ | 1978 | /* .. if the array isn't clean, an 'even' event must also go |
| 1929 | if ((mddev->events&1)==0) { | 1979 | * to spares. */ |
| 1930 | mddev->events++; | 1980 | if ((mddev->events&1)==0) |
| 1931 | nospares = 0; | 1981 | nospares = 0; |
| 1932 | } | ||
| 1933 | } else { | 1982 | } else { |
| 1934 | /* otherwise insist on an even 'events' (for clean states) */ | 1983 | /* otherwise an 'odd' event must go to spares */ |
| 1935 | if ((mddev->events&1)) { | 1984 | if ((mddev->events&1)) |
| 1936 | mddev->events++; | ||
| 1937 | nospares = 0; | 1985 | nospares = 0; |
| 1938 | } | ||
| 1939 | } | 1986 | } |
| 1940 | } | 1987 | } |
| 1941 | 1988 | ||
| @@ -2657,6 +2704,7 @@ level_store(mddev_t *mddev, const char *buf, size_t len) | |||
| 2657 | ssize_t rv = len; | 2704 | ssize_t rv = len; |
| 2658 | struct mdk_personality *pers; | 2705 | struct mdk_personality *pers; |
| 2659 | void *priv; | 2706 | void *priv; |
| 2707 | mdk_rdev_t *rdev; | ||
| 2660 | 2708 | ||
| 2661 | if (mddev->pers == NULL) { | 2709 | if (mddev->pers == NULL) { |
| 2662 | if (len == 0) | 2710 | if (len == 0) |
| @@ -2736,6 +2784,12 @@ level_store(mddev_t *mddev, const char *buf, size_t len) | |||
| 2736 | mddev_suspend(mddev); | 2784 | mddev_suspend(mddev); |
| 2737 | mddev->pers->stop(mddev); | 2785 | mddev->pers->stop(mddev); |
| 2738 | module_put(mddev->pers->owner); | 2786 | module_put(mddev->pers->owner); |
| 2787 | /* Invalidate devices that are now superfluous */ | ||
| 2788 | list_for_each_entry(rdev, &mddev->disks, same_set) | ||
| 2789 | if (rdev->raid_disk >= mddev->raid_disks) { | ||
| 2790 | rdev->raid_disk = -1; | ||
| 2791 | clear_bit(In_sync, &rdev->flags); | ||
| 2792 | } | ||
| 2739 | mddev->pers = pers; | 2793 | mddev->pers = pers; |
| 2740 | mddev->private = priv; | 2794 | mddev->private = priv; |
| 2741 | strlcpy(mddev->clevel, pers->name, sizeof(mddev->clevel)); | 2795 | strlcpy(mddev->clevel, pers->name, sizeof(mddev->clevel)); |
| @@ -3545,6 +3599,7 @@ max_sync_store(mddev_t *mddev, const char *buf, size_t len) | |||
| 3545 | if (max < mddev->resync_min) | 3599 | if (max < mddev->resync_min) |
| 3546 | return -EINVAL; | 3600 | return -EINVAL; |
| 3547 | if (max < mddev->resync_max && | 3601 | if (max < mddev->resync_max && |
| 3602 | mddev->ro == 0 && | ||
| 3548 | test_bit(MD_RECOVERY_RUNNING, &mddev->recovery)) | 3603 | test_bit(MD_RECOVERY_RUNNING, &mddev->recovery)) |
| 3549 | return -EBUSY; | 3604 | return -EBUSY; |
| 3550 | 3605 | ||
| @@ -3685,17 +3740,8 @@ array_size_store(mddev_t *mddev, const char *buf, size_t len) | |||
| 3685 | 3740 | ||
| 3686 | mddev->array_sectors = sectors; | 3741 | mddev->array_sectors = sectors; |
| 3687 | set_capacity(mddev->gendisk, mddev->array_sectors); | 3742 | set_capacity(mddev->gendisk, mddev->array_sectors); |
| 3688 | if (mddev->pers) { | 3743 | if (mddev->pers) |
| 3689 | struct block_device *bdev = bdget_disk(mddev->gendisk, 0); | 3744 | revalidate_disk(mddev->gendisk); |
| 3690 | |||
| 3691 | if (bdev) { | ||
| 3692 | mutex_lock(&bdev->bd_inode->i_mutex); | ||
| 3693 | i_size_write(bdev->bd_inode, | ||
| 3694 | (loff_t)mddev->array_sectors << 9); | ||
| 3695 | mutex_unlock(&bdev->bd_inode->i_mutex); | ||
| 3696 | bdput(bdev); | ||
| 3697 | } | ||
| 3698 | } | ||
| 3699 | 3745 | ||
| 3700 | return len; | 3746 | return len; |
| 3701 | } | 3747 | } |
| @@ -4048,10 +4094,6 @@ static int do_md_run(mddev_t * mddev) | |||
| 4048 | } | 4094 | } |
| 4049 | strlcpy(mddev->clevel, pers->name, sizeof(mddev->clevel)); | 4095 | strlcpy(mddev->clevel, pers->name, sizeof(mddev->clevel)); |
| 4050 | 4096 | ||
| 4051 | if (pers->level >= 4 && pers->level <= 6) | ||
| 4052 | /* Cannot support integrity (yet) */ | ||
| 4053 | blk_integrity_unregister(mddev->gendisk); | ||
| 4054 | |||
| 4055 | if (mddev->reshape_position != MaxSector && | 4097 | if (mddev->reshape_position != MaxSector && |
| 4056 | pers->start_reshape == NULL) { | 4098 | pers->start_reshape == NULL) { |
| 4057 | /* This personality cannot handle reshaping... */ | 4099 | /* This personality cannot handle reshaping... */ |
| @@ -4189,6 +4231,7 @@ static int do_md_run(mddev_t * mddev) | |||
| 4189 | md_wakeup_thread(mddev->thread); | 4231 | md_wakeup_thread(mddev->thread); |
| 4190 | md_wakeup_thread(mddev->sync_thread); /* possibly kick off a reshape */ | 4232 | md_wakeup_thread(mddev->sync_thread); /* possibly kick off a reshape */ |
| 4191 | 4233 | ||
| 4234 | revalidate_disk(mddev->gendisk); | ||
| 4192 | mddev->changed = 1; | 4235 | mddev->changed = 1; |
| 4193 | md_new_event(mddev); | 4236 | md_new_event(mddev); |
| 4194 | sysfs_notify_dirent(mddev->sysfs_state); | 4237 | sysfs_notify_dirent(mddev->sysfs_state); |
| @@ -4260,12 +4303,11 @@ static int do_md_stop(mddev_t * mddev, int mode, int is_open) | |||
| 4260 | struct gendisk *disk = mddev->gendisk; | 4303 | struct gendisk *disk = mddev->gendisk; |
| 4261 | mdk_rdev_t *rdev; | 4304 | mdk_rdev_t *rdev; |
| 4262 | 4305 | ||
| 4306 | mutex_lock(&mddev->open_mutex); | ||
| 4263 | if (atomic_read(&mddev->openers) > is_open) { | 4307 | if (atomic_read(&mddev->openers) > is_open) { |
| 4264 | printk("md: %s still in use.\n",mdname(mddev)); | 4308 | printk("md: %s still in use.\n",mdname(mddev)); |
| 4265 | return -EBUSY; | 4309 | err = -EBUSY; |
| 4266 | } | 4310 | } else if (mddev->pers) { |
| 4267 | |||
| 4268 | if (mddev->pers) { | ||
| 4269 | 4311 | ||
| 4270 | if (mddev->sync_thread) { | 4312 | if (mddev->sync_thread) { |
| 4271 | set_bit(MD_RECOVERY_FROZEN, &mddev->recovery); | 4313 | set_bit(MD_RECOVERY_FROZEN, &mddev->recovery); |
| @@ -4322,8 +4364,12 @@ static int do_md_stop(mddev_t * mddev, int mode, int is_open) | |||
| 4322 | if (mode == 1) | 4364 | if (mode == 1) |
| 4323 | set_disk_ro(disk, 1); | 4365 | set_disk_ro(disk, 1); |
| 4324 | clear_bit(MD_RECOVERY_FROZEN, &mddev->recovery); | 4366 | clear_bit(MD_RECOVERY_FROZEN, &mddev->recovery); |
| 4367 | err = 0; | ||
| 4325 | } | 4368 | } |
| 4326 | 4369 | out: | |
| 4370 | mutex_unlock(&mddev->open_mutex); | ||
| 4371 | if (err) | ||
| 4372 | return err; | ||
| 4327 | /* | 4373 | /* |
| 4328 | * Free resources if final stop | 4374 | * Free resources if final stop |
| 4329 | */ | 4375 | */ |
| @@ -4389,7 +4435,6 @@ static int do_md_stop(mddev_t * mddev, int mode, int is_open) | |||
| 4389 | blk_integrity_unregister(disk); | 4435 | blk_integrity_unregister(disk); |
| 4390 | md_new_event(mddev); | 4436 | md_new_event(mddev); |
| 4391 | sysfs_notify_dirent(mddev->sysfs_state); | 4437 | sysfs_notify_dirent(mddev->sysfs_state); |
| 4392 | out: | ||
| 4393 | return err; | 4438 | return err; |
| 4394 | } | 4439 | } |
| 4395 | 4440 | ||
| @@ -5087,18 +5132,8 @@ static int update_size(mddev_t *mddev, sector_t num_sectors) | |||
| 5087 | return -ENOSPC; | 5132 | return -ENOSPC; |
| 5088 | } | 5133 | } |
| 5089 | rv = mddev->pers->resize(mddev, num_sectors); | 5134 | rv = mddev->pers->resize(mddev, num_sectors); |
| 5090 | if (!rv) { | 5135 | if (!rv) |
| 5091 | struct block_device *bdev; | 5136 | revalidate_disk(mddev->gendisk); |
| 5092 | |||
| 5093 | bdev = bdget_disk(mddev->gendisk, 0); | ||
| 5094 | if (bdev) { | ||
| 5095 | mutex_lock(&bdev->bd_inode->i_mutex); | ||
| 5096 | i_size_write(bdev->bd_inode, | ||
| 5097 | (loff_t)mddev->array_sectors << 9); | ||
| 5098 | mutex_unlock(&bdev->bd_inode->i_mutex); | ||
| 5099 | bdput(bdev); | ||
| 5100 | } | ||
| 5101 | } | ||
| 5102 | return rv; | 5137 | return rv; |
| 5103 | } | 5138 | } |
| 5104 | 5139 | ||
| @@ -5484,12 +5519,12 @@ static int md_open(struct block_device *bdev, fmode_t mode) | |||
| 5484 | } | 5519 | } |
| 5485 | BUG_ON(mddev != bdev->bd_disk->private_data); | 5520 | BUG_ON(mddev != bdev->bd_disk->private_data); |
| 5486 | 5521 | ||
| 5487 | if ((err = mutex_lock_interruptible_nested(&mddev->reconfig_mutex, 1))) | 5522 | if ((err = mutex_lock_interruptible(&mddev->open_mutex))) |
| 5488 | goto out; | 5523 | goto out; |
| 5489 | 5524 | ||
| 5490 | err = 0; | 5525 | err = 0; |
| 5491 | atomic_inc(&mddev->openers); | 5526 | atomic_inc(&mddev->openers); |
| 5492 | mddev_unlock(mddev); | 5527 | mutex_unlock(&mddev->open_mutex); |
| 5493 | 5528 | ||
| 5494 | check_disk_change(bdev); | 5529 | check_disk_change(bdev); |
| 5495 | out: | 5530 | out: |
diff --git a/drivers/md/md.h b/drivers/md/md.h index 9430a110db93..f8fc188bc762 100644 --- a/drivers/md/md.h +++ b/drivers/md/md.h | |||
| @@ -223,6 +223,16 @@ struct mddev_s | |||
| 223 | * so we don't loop trying */ | 223 | * so we don't loop trying */ |
| 224 | 224 | ||
| 225 | int in_sync; /* know to not need resync */ | 225 | int in_sync; /* know to not need resync */ |
| 226 | /* 'open_mutex' avoids races between 'md_open' and 'do_md_stop', so | ||
| 227 | * that we are never stopping an array while it is open. | ||
| 228 | * 'reconfig_mutex' protects all other reconfiguration. | ||
| 229 | * These locks are separate due to conflicting interactions | ||
| 230 | * with bdev->bd_mutex. | ||
| 231 | * Lock ordering is: | ||
| 232 | * reconfig_mutex -> bd_mutex : e.g. do_md_run -> revalidate_disk | ||
| 233 | * bd_mutex -> open_mutex: e.g. __blkdev_get -> md_open | ||
| 234 | */ | ||
| 235 | struct mutex open_mutex; | ||
| 226 | struct mutex reconfig_mutex; | 236 | struct mutex reconfig_mutex; |
| 227 | atomic_t active; /* general refcount */ | 237 | atomic_t active; /* general refcount */ |
| 228 | atomic_t openers; /* number of active opens */ | 238 | atomic_t openers; /* number of active opens */ |
| @@ -431,5 +441,7 @@ extern int md_allow_write(mddev_t *mddev); | |||
| 431 | extern void md_wait_for_blocked_rdev(mdk_rdev_t *rdev, mddev_t *mddev); | 441 | extern void md_wait_for_blocked_rdev(mdk_rdev_t *rdev, mddev_t *mddev); |
| 432 | extern void md_set_array_sectors(mddev_t *mddev, sector_t array_sectors); | 442 | extern void md_set_array_sectors(mddev_t *mddev, sector_t array_sectors); |
| 433 | extern int md_check_no_bitmap(mddev_t *mddev); | 443 | extern int md_check_no_bitmap(mddev_t *mddev); |
| 444 | extern int md_integrity_register(mddev_t *mddev); | ||
| 445 | void md_integrity_add_rdev(mdk_rdev_t *rdev, mddev_t *mddev); | ||
| 434 | 446 | ||
| 435 | #endif /* _MD_MD_H */ | 447 | #endif /* _MD_MD_H */ |
diff --git a/drivers/md/multipath.c b/drivers/md/multipath.c index 237fe3fd235c..7140909f6662 100644 --- a/drivers/md/multipath.c +++ b/drivers/md/multipath.c | |||
| @@ -313,6 +313,7 @@ static int multipath_add_disk(mddev_t *mddev, mdk_rdev_t *rdev) | |||
| 313 | set_bit(In_sync, &rdev->flags); | 313 | set_bit(In_sync, &rdev->flags); |
| 314 | rcu_assign_pointer(p->rdev, rdev); | 314 | rcu_assign_pointer(p->rdev, rdev); |
| 315 | err = 0; | 315 | err = 0; |
| 316 | md_integrity_add_rdev(rdev, mddev); | ||
| 316 | break; | 317 | break; |
| 317 | } | 318 | } |
| 318 | 319 | ||
| @@ -345,7 +346,9 @@ static int multipath_remove_disk(mddev_t *mddev, int number) | |||
| 345 | /* lost the race, try later */ | 346 | /* lost the race, try later */ |
| 346 | err = -EBUSY; | 347 | err = -EBUSY; |
| 347 | p->rdev = rdev; | 348 | p->rdev = rdev; |
| 349 | goto abort; | ||
| 348 | } | 350 | } |
| 351 | md_integrity_register(mddev); | ||
| 349 | } | 352 | } |
| 350 | abort: | 353 | abort: |
| 351 | 354 | ||
| @@ -519,7 +522,7 @@ static int multipath_run (mddev_t *mddev) | |||
| 519 | mddev->queue->unplug_fn = multipath_unplug; | 522 | mddev->queue->unplug_fn = multipath_unplug; |
| 520 | mddev->queue->backing_dev_info.congested_fn = multipath_congested; | 523 | mddev->queue->backing_dev_info.congested_fn = multipath_congested; |
| 521 | mddev->queue->backing_dev_info.congested_data = mddev; | 524 | mddev->queue->backing_dev_info.congested_data = mddev; |
| 522 | 525 | md_integrity_register(mddev); | |
| 523 | return 0; | 526 | return 0; |
| 524 | 527 | ||
| 525 | out_free_conf: | 528 | out_free_conf: |
diff --git a/drivers/md/raid0.c b/drivers/md/raid0.c index 335f490dcad6..898e2bdfee47 100644 --- a/drivers/md/raid0.c +++ b/drivers/md/raid0.c | |||
| @@ -351,6 +351,7 @@ static int raid0_run(mddev_t *mddev) | |||
| 351 | 351 | ||
| 352 | blk_queue_merge_bvec(mddev->queue, raid0_mergeable_bvec); | 352 | blk_queue_merge_bvec(mddev->queue, raid0_mergeable_bvec); |
| 353 | dump_zones(mddev); | 353 | dump_zones(mddev); |
| 354 | md_integrity_register(mddev); | ||
| 354 | return 0; | 355 | return 0; |
| 355 | } | 356 | } |
| 356 | 357 | ||
diff --git a/drivers/md/raid1.c b/drivers/md/raid1.c index 0569efba0c02..8726fd7ebce5 100644 --- a/drivers/md/raid1.c +++ b/drivers/md/raid1.c | |||
| @@ -1144,7 +1144,7 @@ static int raid1_add_disk(mddev_t *mddev, mdk_rdev_t *rdev) | |||
| 1144 | rcu_assign_pointer(p->rdev, rdev); | 1144 | rcu_assign_pointer(p->rdev, rdev); |
| 1145 | break; | 1145 | break; |
| 1146 | } | 1146 | } |
| 1147 | 1147 | md_integrity_add_rdev(rdev, mddev); | |
| 1148 | print_conf(conf); | 1148 | print_conf(conf); |
| 1149 | return err; | 1149 | return err; |
| 1150 | } | 1150 | } |
| @@ -1178,7 +1178,9 @@ static int raid1_remove_disk(mddev_t *mddev, int number) | |||
| 1178 | /* lost the race, try later */ | 1178 | /* lost the race, try later */ |
| 1179 | err = -EBUSY; | 1179 | err = -EBUSY; |
| 1180 | p->rdev = rdev; | 1180 | p->rdev = rdev; |
| 1181 | goto abort; | ||
| 1181 | } | 1182 | } |
| 1183 | md_integrity_register(mddev); | ||
| 1182 | } | 1184 | } |
| 1183 | abort: | 1185 | abort: |
| 1184 | 1186 | ||
| @@ -2067,7 +2069,7 @@ static int run(mddev_t *mddev) | |||
| 2067 | mddev->queue->unplug_fn = raid1_unplug; | 2069 | mddev->queue->unplug_fn = raid1_unplug; |
| 2068 | mddev->queue->backing_dev_info.congested_fn = raid1_congested; | 2070 | mddev->queue->backing_dev_info.congested_fn = raid1_congested; |
| 2069 | mddev->queue->backing_dev_info.congested_data = mddev; | 2071 | mddev->queue->backing_dev_info.congested_data = mddev; |
| 2070 | 2072 | md_integrity_register(mddev); | |
| 2071 | return 0; | 2073 | return 0; |
| 2072 | 2074 | ||
| 2073 | out_no_mem: | 2075 | out_no_mem: |
| @@ -2132,6 +2134,7 @@ static int raid1_resize(mddev_t *mddev, sector_t sectors) | |||
| 2132 | return -EINVAL; | 2134 | return -EINVAL; |
| 2133 | set_capacity(mddev->gendisk, mddev->array_sectors); | 2135 | set_capacity(mddev->gendisk, mddev->array_sectors); |
| 2134 | mddev->changed = 1; | 2136 | mddev->changed = 1; |
| 2137 | revalidate_disk(mddev->gendisk); | ||
| 2135 | if (sectors > mddev->dev_sectors && | 2138 | if (sectors > mddev->dev_sectors && |
| 2136 | mddev->recovery_cp == MaxSector) { | 2139 | mddev->recovery_cp == MaxSector) { |
| 2137 | mddev->recovery_cp = mddev->dev_sectors; | 2140 | mddev->recovery_cp = mddev->dev_sectors; |
diff --git a/drivers/md/raid10.c b/drivers/md/raid10.c index 7298a5e5a183..3d9020cf6f6e 100644 --- a/drivers/md/raid10.c +++ b/drivers/md/raid10.c | |||
| @@ -1170,6 +1170,7 @@ static int raid10_add_disk(mddev_t *mddev, mdk_rdev_t *rdev) | |||
| 1170 | break; | 1170 | break; |
| 1171 | } | 1171 | } |
| 1172 | 1172 | ||
| 1173 | md_integrity_add_rdev(rdev, mddev); | ||
| 1173 | print_conf(conf); | 1174 | print_conf(conf); |
| 1174 | return err; | 1175 | return err; |
| 1175 | } | 1176 | } |
| @@ -1203,7 +1204,9 @@ static int raid10_remove_disk(mddev_t *mddev, int number) | |||
| 1203 | /* lost the race, try later */ | 1204 | /* lost the race, try later */ |
| 1204 | err = -EBUSY; | 1205 | err = -EBUSY; |
| 1205 | p->rdev = rdev; | 1206 | p->rdev = rdev; |
| 1207 | goto abort; | ||
| 1206 | } | 1208 | } |
| 1209 | md_integrity_register(mddev); | ||
| 1207 | } | 1210 | } |
| 1208 | abort: | 1211 | abort: |
| 1209 | 1212 | ||
| @@ -2225,6 +2228,7 @@ static int run(mddev_t *mddev) | |||
| 2225 | 2228 | ||
| 2226 | if (conf->near_copies < mddev->raid_disks) | 2229 | if (conf->near_copies < mddev->raid_disks) |
| 2227 | blk_queue_merge_bvec(mddev->queue, raid10_mergeable_bvec); | 2230 | blk_queue_merge_bvec(mddev->queue, raid10_mergeable_bvec); |
| 2231 | md_integrity_register(mddev); | ||
| 2228 | return 0; | 2232 | return 0; |
| 2229 | 2233 | ||
| 2230 | out_free_conf: | 2234 | out_free_conf: |
diff --git a/drivers/md/raid5.c b/drivers/md/raid5.c index 37835538b58e..b8a2c5dc67ba 100644 --- a/drivers/md/raid5.c +++ b/drivers/md/raid5.c | |||
| @@ -3785,7 +3785,7 @@ static sector_t reshape_request(mddev_t *mddev, sector_t sector_nr, int *skipped | |||
| 3785 | conf->reshape_progress < raid5_size(mddev, 0, 0)) { | 3785 | conf->reshape_progress < raid5_size(mddev, 0, 0)) { |
| 3786 | sector_nr = raid5_size(mddev, 0, 0) | 3786 | sector_nr = raid5_size(mddev, 0, 0) |
| 3787 | - conf->reshape_progress; | 3787 | - conf->reshape_progress; |
| 3788 | } else if (mddev->delta_disks > 0 && | 3788 | } else if (mddev->delta_disks >= 0 && |
| 3789 | conf->reshape_progress > 0) | 3789 | conf->reshape_progress > 0) |
| 3790 | sector_nr = conf->reshape_progress; | 3790 | sector_nr = conf->reshape_progress; |
| 3791 | sector_div(sector_nr, new_data_disks); | 3791 | sector_div(sector_nr, new_data_disks); |
| @@ -3999,6 +3999,9 @@ static inline sector_t sync_request(mddev_t *mddev, sector_t sector_nr, int *ski | |||
| 3999 | return 0; | 3999 | return 0; |
| 4000 | } | 4000 | } |
| 4001 | 4001 | ||
| 4002 | /* Allow raid5_quiesce to complete */ | ||
| 4003 | wait_event(conf->wait_for_overlap, conf->quiesce != 2); | ||
| 4004 | |||
| 4002 | if (test_bit(MD_RECOVERY_RESHAPE, &mddev->recovery)) | 4005 | if (test_bit(MD_RECOVERY_RESHAPE, &mddev->recovery)) |
| 4003 | return reshape_request(mddev, sector_nr, skipped); | 4006 | return reshape_request(mddev, sector_nr, skipped); |
| 4004 | 4007 | ||
| @@ -4316,6 +4319,15 @@ raid5_size(mddev_t *mddev, sector_t sectors, int raid_disks) | |||
| 4316 | return sectors * (raid_disks - conf->max_degraded); | 4319 | return sectors * (raid_disks - conf->max_degraded); |
| 4317 | } | 4320 | } |
| 4318 | 4321 | ||
| 4322 | static void free_conf(raid5_conf_t *conf) | ||
| 4323 | { | ||
| 4324 | shrink_stripes(conf); | ||
| 4325 | safe_put_page(conf->spare_page); | ||
| 4326 | kfree(conf->disks); | ||
| 4327 | kfree(conf->stripe_hashtbl); | ||
| 4328 | kfree(conf); | ||
| 4329 | } | ||
| 4330 | |||
| 4319 | static raid5_conf_t *setup_conf(mddev_t *mddev) | 4331 | static raid5_conf_t *setup_conf(mddev_t *mddev) |
| 4320 | { | 4332 | { |
| 4321 | raid5_conf_t *conf; | 4333 | raid5_conf_t *conf; |
| @@ -4447,11 +4459,7 @@ static raid5_conf_t *setup_conf(mddev_t *mddev) | |||
| 4447 | 4459 | ||
| 4448 | abort: | 4460 | abort: |
| 4449 | if (conf) { | 4461 | if (conf) { |
| 4450 | shrink_stripes(conf); | 4462 | free_conf(conf); |
| 4451 | safe_put_page(conf->spare_page); | ||
| 4452 | kfree(conf->disks); | ||
| 4453 | kfree(conf->stripe_hashtbl); | ||
| 4454 | kfree(conf); | ||
| 4455 | return ERR_PTR(-EIO); | 4463 | return ERR_PTR(-EIO); |
| 4456 | } else | 4464 | } else |
| 4457 | return ERR_PTR(-ENOMEM); | 4465 | return ERR_PTR(-ENOMEM); |
| @@ -4501,7 +4509,26 @@ static int run(mddev_t *mddev) | |||
| 4501 | (old_disks-max_degraded)); | 4509 | (old_disks-max_degraded)); |
| 4502 | /* here_old is the first stripe that we might need to read | 4510 | /* here_old is the first stripe that we might need to read |
| 4503 | * from */ | 4511 | * from */ |
| 4504 | if (here_new >= here_old) { | 4512 | if (mddev->delta_disks == 0) { |
| 4513 | /* We cannot be sure it is safe to start an in-place | ||
| 4514 | * reshape. It is only safe if user-space if monitoring | ||
| 4515 | * and taking constant backups. | ||
| 4516 | * mdadm always starts a situation like this in | ||
| 4517 | * readonly mode so it can take control before | ||
| 4518 | * allowing any writes. So just check for that. | ||
| 4519 | */ | ||
| 4520 | if ((here_new * mddev->new_chunk_sectors != | ||
| 4521 | here_old * mddev->chunk_sectors) || | ||
| 4522 | mddev->ro == 0) { | ||
| 4523 | printk(KERN_ERR "raid5: in-place reshape must be started" | ||
| 4524 | " in read-only mode - aborting\n"); | ||
| 4525 | return -EINVAL; | ||
| 4526 | } | ||
| 4527 | } else if (mddev->delta_disks < 0 | ||
| 4528 | ? (here_new * mddev->new_chunk_sectors <= | ||
| 4529 | here_old * mddev->chunk_sectors) | ||
| 4530 | : (here_new * mddev->new_chunk_sectors >= | ||
| 4531 | here_old * mddev->chunk_sectors)) { | ||
| 4505 | /* Reading from the same stripe as writing to - bad */ | 4532 | /* Reading from the same stripe as writing to - bad */ |
| 4506 | printk(KERN_ERR "raid5: reshape_position too early for " | 4533 | printk(KERN_ERR "raid5: reshape_position too early for " |
| 4507 | "auto-recovery - aborting.\n"); | 4534 | "auto-recovery - aborting.\n"); |
| @@ -4629,12 +4656,8 @@ abort: | |||
| 4629 | md_unregister_thread(mddev->thread); | 4656 | md_unregister_thread(mddev->thread); |
| 4630 | mddev->thread = NULL; | 4657 | mddev->thread = NULL; |
| 4631 | if (conf) { | 4658 | if (conf) { |
| 4632 | shrink_stripes(conf); | ||
| 4633 | print_raid5_conf(conf); | 4659 | print_raid5_conf(conf); |
| 4634 | safe_put_page(conf->spare_page); | 4660 | free_conf(conf); |
| 4635 | kfree(conf->disks); | ||
| 4636 | kfree(conf->stripe_hashtbl); | ||
| 4637 | kfree(conf); | ||
| 4638 | } | 4661 | } |
| 4639 | mddev->private = NULL; | 4662 | mddev->private = NULL; |
| 4640 | printk(KERN_ALERT "raid5: failed to run raid set %s\n", mdname(mddev)); | 4663 | printk(KERN_ALERT "raid5: failed to run raid set %s\n", mdname(mddev)); |
| @@ -4649,13 +4672,10 @@ static int stop(mddev_t *mddev) | |||
| 4649 | 4672 | ||
| 4650 | md_unregister_thread(mddev->thread); | 4673 | md_unregister_thread(mddev->thread); |
| 4651 | mddev->thread = NULL; | 4674 | mddev->thread = NULL; |
| 4652 | shrink_stripes(conf); | ||
| 4653 | kfree(conf->stripe_hashtbl); | ||
| 4654 | mddev->queue->backing_dev_info.congested_fn = NULL; | 4675 | mddev->queue->backing_dev_info.congested_fn = NULL; |
| 4655 | blk_sync_queue(mddev->queue); /* the unplug fn references 'conf'*/ | 4676 | blk_sync_queue(mddev->queue); /* the unplug fn references 'conf'*/ |
| 4656 | sysfs_remove_group(&mddev->kobj, &raid5_attrs_group); | 4677 | sysfs_remove_group(&mddev->kobj, &raid5_attrs_group); |
| 4657 | kfree(conf->disks); | 4678 | free_conf(conf); |
| 4658 | kfree(conf); | ||
| 4659 | mddev->private = NULL; | 4679 | mddev->private = NULL; |
| 4660 | return 0; | 4680 | return 0; |
| 4661 | } | 4681 | } |
| @@ -4857,6 +4877,7 @@ static int raid5_resize(mddev_t *mddev, sector_t sectors) | |||
| 4857 | return -EINVAL; | 4877 | return -EINVAL; |
| 4858 | set_capacity(mddev->gendisk, mddev->array_sectors); | 4878 | set_capacity(mddev->gendisk, mddev->array_sectors); |
| 4859 | mddev->changed = 1; | 4879 | mddev->changed = 1; |
| 4880 | revalidate_disk(mddev->gendisk); | ||
| 4860 | if (sectors > mddev->dev_sectors && mddev->recovery_cp == MaxSector) { | 4881 | if (sectors > mddev->dev_sectors && mddev->recovery_cp == MaxSector) { |
| 4861 | mddev->recovery_cp = mddev->dev_sectors; | 4882 | mddev->recovery_cp = mddev->dev_sectors; |
| 4862 | set_bit(MD_RECOVERY_NEEDED, &mddev->recovery); | 4883 | set_bit(MD_RECOVERY_NEEDED, &mddev->recovery); |
| @@ -5002,7 +5023,7 @@ static int raid5_start_reshape(mddev_t *mddev) | |||
| 5002 | spin_unlock_irqrestore(&conf->device_lock, flags); | 5023 | spin_unlock_irqrestore(&conf->device_lock, flags); |
| 5003 | } | 5024 | } |
| 5004 | mddev->raid_disks = conf->raid_disks; | 5025 | mddev->raid_disks = conf->raid_disks; |
| 5005 | mddev->reshape_position = 0; | 5026 | mddev->reshape_position = conf->reshape_progress; |
| 5006 | set_bit(MD_CHANGE_DEVS, &mddev->flags); | 5027 | set_bit(MD_CHANGE_DEVS, &mddev->flags); |
| 5007 | 5028 | ||
| 5008 | clear_bit(MD_RECOVERY_SYNC, &mddev->recovery); | 5029 | clear_bit(MD_RECOVERY_SYNC, &mddev->recovery); |
| @@ -5057,7 +5078,6 @@ static void end_reshape(raid5_conf_t *conf) | |||
| 5057 | */ | 5078 | */ |
| 5058 | static void raid5_finish_reshape(mddev_t *mddev) | 5079 | static void raid5_finish_reshape(mddev_t *mddev) |
| 5059 | { | 5080 | { |
| 5060 | struct block_device *bdev; | ||
| 5061 | raid5_conf_t *conf = mddev->private; | 5081 | raid5_conf_t *conf = mddev->private; |
| 5062 | 5082 | ||
| 5063 | if (!test_bit(MD_RECOVERY_INTR, &mddev->recovery)) { | 5083 | if (!test_bit(MD_RECOVERY_INTR, &mddev->recovery)) { |
| @@ -5066,15 +5086,7 @@ static void raid5_finish_reshape(mddev_t *mddev) | |||
| 5066 | md_set_array_sectors(mddev, raid5_size(mddev, 0, 0)); | 5086 | md_set_array_sectors(mddev, raid5_size(mddev, 0, 0)); |
| 5067 | set_capacity(mddev->gendisk, mddev->array_sectors); | 5087 | set_capacity(mddev->gendisk, mddev->array_sectors); |
| 5068 | mddev->changed = 1; | 5088 | mddev->changed = 1; |
| 5069 | 5089 | revalidate_disk(mddev->gendisk); | |
| 5070 | bdev = bdget_disk(mddev->gendisk, 0); | ||
| 5071 | if (bdev) { | ||
| 5072 | mutex_lock(&bdev->bd_inode->i_mutex); | ||
| 5073 | i_size_write(bdev->bd_inode, | ||
| 5074 | (loff_t)mddev->array_sectors << 9); | ||
| 5075 | mutex_unlock(&bdev->bd_inode->i_mutex); | ||
| 5076 | bdput(bdev); | ||
| 5077 | } | ||
| 5078 | } else { | 5090 | } else { |
| 5079 | int d; | 5091 | int d; |
| 5080 | mddev->degraded = conf->raid_disks; | 5092 | mddev->degraded = conf->raid_disks; |
| @@ -5085,8 +5097,15 @@ static void raid5_finish_reshape(mddev_t *mddev) | |||
| 5085 | mddev->degraded--; | 5097 | mddev->degraded--; |
| 5086 | for (d = conf->raid_disks ; | 5098 | for (d = conf->raid_disks ; |
| 5087 | d < conf->raid_disks - mddev->delta_disks; | 5099 | d < conf->raid_disks - mddev->delta_disks; |
| 5088 | d++) | 5100 | d++) { |
| 5089 | raid5_remove_disk(mddev, d); | 5101 | mdk_rdev_t *rdev = conf->disks[d].rdev; |
| 5102 | if (rdev && raid5_remove_disk(mddev, d) == 0) { | ||
| 5103 | char nm[20]; | ||
| 5104 | sprintf(nm, "rd%d", rdev->raid_disk); | ||
| 5105 | sysfs_remove_link(&mddev->kobj, nm); | ||
| 5106 | rdev->raid_disk = -1; | ||
| 5107 | } | ||
| 5108 | } | ||
| 5090 | } | 5109 | } |
| 5091 | mddev->layout = conf->algorithm; | 5110 | mddev->layout = conf->algorithm; |
| 5092 | mddev->chunk_sectors = conf->chunk_sectors; | 5111 | mddev->chunk_sectors = conf->chunk_sectors; |
| @@ -5106,12 +5125,18 @@ static void raid5_quiesce(mddev_t *mddev, int state) | |||
| 5106 | 5125 | ||
| 5107 | case 1: /* stop all writes */ | 5126 | case 1: /* stop all writes */ |
| 5108 | spin_lock_irq(&conf->device_lock); | 5127 | spin_lock_irq(&conf->device_lock); |
| 5109 | conf->quiesce = 1; | 5128 | /* '2' tells resync/reshape to pause so that all |
| 5129 | * active stripes can drain | ||
| 5130 | */ | ||
| 5131 | conf->quiesce = 2; | ||
| 5110 | wait_event_lock_irq(conf->wait_for_stripe, | 5132 | wait_event_lock_irq(conf->wait_for_stripe, |
| 5111 | atomic_read(&conf->active_stripes) == 0 && | 5133 | atomic_read(&conf->active_stripes) == 0 && |
| 5112 | atomic_read(&conf->active_aligned_reads) == 0, | 5134 | atomic_read(&conf->active_aligned_reads) == 0, |
| 5113 | conf->device_lock, /* nothing */); | 5135 | conf->device_lock, /* nothing */); |
| 5136 | conf->quiesce = 1; | ||
| 5114 | spin_unlock_irq(&conf->device_lock); | 5137 | spin_unlock_irq(&conf->device_lock); |
| 5138 | /* allow reshape to continue */ | ||
| 5139 | wake_up(&conf->wait_for_overlap); | ||
| 5115 | break; | 5140 | break; |
| 5116 | 5141 | ||
| 5117 | case 0: /* re-enable writes */ | 5142 | case 0: /* re-enable writes */ |
diff --git a/drivers/media/common/tuners/qt1010.c b/drivers/media/common/tuners/qt1010.c index 825aa1412e6f..9f5dba244cb8 100644 --- a/drivers/media/common/tuners/qt1010.c +++ b/drivers/media/common/tuners/qt1010.c | |||
| @@ -64,24 +64,22 @@ static int qt1010_writereg(struct qt1010_priv *priv, u8 reg, u8 val) | |||
| 64 | /* dump all registers */ | 64 | /* dump all registers */ |
| 65 | static void qt1010_dump_regs(struct qt1010_priv *priv) | 65 | static void qt1010_dump_regs(struct qt1010_priv *priv) |
| 66 | { | 66 | { |
| 67 | char buf[52], buf2[4]; | ||
| 68 | u8 reg, val; | 67 | u8 reg, val; |
| 69 | 68 | ||
| 70 | for (reg = 0; ; reg++) { | 69 | for (reg = 0; ; reg++) { |
| 71 | if (reg % 16 == 0) { | 70 | if (reg % 16 == 0) { |
| 72 | if (reg) | 71 | if (reg) |
| 73 | printk("%s\n", buf); | 72 | printk(KERN_CONT "\n"); |
| 74 | sprintf(buf, "%02x: ", reg); | 73 | printk(KERN_DEBUG "%02x:", reg); |
| 75 | } | 74 | } |
| 76 | if (qt1010_readreg(priv, reg, &val) == 0) | 75 | if (qt1010_readreg(priv, reg, &val) == 0) |
| 77 | sprintf(buf2, "%02x ", val); | 76 | printk(KERN_CONT " %02x", val); |
| 78 | else | 77 | else |
| 79 | strcpy(buf2, "-- "); | 78 | printk(KERN_CONT " --"); |
| 80 | strcat(buf, buf2); | ||
| 81 | if (reg == 0x2f) | 79 | if (reg == 0x2f) |
| 82 | break; | 80 | break; |
| 83 | } | 81 | } |
| 84 | printk("%s\n", buf); | 82 | printk(KERN_CONT "\n"); |
| 85 | } | 83 | } |
| 86 | 84 | ||
| 87 | static int qt1010_set_params(struct dvb_frontend *fe, | 85 | static int qt1010_set_params(struct dvb_frontend *fe, |
diff --git a/drivers/media/common/tuners/tuner-xc2028.c b/drivers/media/common/tuners/tuner-xc2028.c index aa20ce8cc668..f270e605da83 100644 --- a/drivers/media/common/tuners/tuner-xc2028.c +++ b/drivers/media/common/tuners/tuner-xc2028.c | |||
| @@ -1119,8 +1119,8 @@ static int xc2028_sleep(struct dvb_frontend *fe) | |||
| 1119 | struct xc2028_data *priv = fe->tuner_priv; | 1119 | struct xc2028_data *priv = fe->tuner_priv; |
| 1120 | int rc = 0; | 1120 | int rc = 0; |
| 1121 | 1121 | ||
| 1122 | /* Avoid firmware reload on slow devices */ | 1122 | /* Avoid firmware reload on slow devices or if PM disabled */ |
| 1123 | if (no_poweroff) | 1123 | if (no_poweroff || priv->ctrl.disable_power_mgmt) |
| 1124 | return 0; | 1124 | return 0; |
| 1125 | 1125 | ||
| 1126 | tuner_dbg("Putting xc2028/3028 into poweroff mode.\n"); | 1126 | tuner_dbg("Putting xc2028/3028 into poweroff mode.\n"); |
diff --git a/drivers/media/common/tuners/tuner-xc2028.h b/drivers/media/common/tuners/tuner-xc2028.h index 19de7928a74e..a90c35d50add 100644 --- a/drivers/media/common/tuners/tuner-xc2028.h +++ b/drivers/media/common/tuners/tuner-xc2028.h | |||
| @@ -38,6 +38,7 @@ struct xc2028_ctrl { | |||
| 38 | unsigned int input1:1; | 38 | unsigned int input1:1; |
| 39 | unsigned int vhfbw7:1; | 39 | unsigned int vhfbw7:1; |
| 40 | unsigned int uhfbw8:1; | 40 | unsigned int uhfbw8:1; |
| 41 | unsigned int disable_power_mgmt:1; | ||
| 41 | unsigned int demod; | 42 | unsigned int demod; |
| 42 | enum firmware_type type:2; | 43 | enum firmware_type type:2; |
| 43 | }; | 44 | }; |
diff --git a/drivers/media/dvb/b2c2/flexcop-fe-tuner.c b/drivers/media/dvb/b2c2/flexcop-fe-tuner.c index efb4a6c2b57a..9a6307a347b2 100644 --- a/drivers/media/dvb/b2c2/flexcop-fe-tuner.c +++ b/drivers/media/dvb/b2c2/flexcop-fe-tuner.c | |||
| @@ -20,8 +20,14 @@ | |||
| 20 | #include "tuner-simple.h" | 20 | #include "tuner-simple.h" |
| 21 | #include "stv0297.h" | 21 | #include "stv0297.h" |
| 22 | 22 | ||
| 23 | |||
| 24 | /* Can we use the specified front-end? Remember that if we are compiled | ||
| 25 | * into the kernel we can't call code that's in modules. */ | ||
| 26 | #define FE_SUPPORTED(fe) (defined(CONFIG_DVB_##fe) || \ | ||
| 27 | (defined(CONFIG_DVB_##fe##_MODULE) && defined(MODULE))) | ||
| 28 | |||
| 23 | /* lnb control */ | 29 | /* lnb control */ |
| 24 | #if defined(CONFIG_DVB_MT312_MODULE) || defined(CONFIG_DVB_STV0299_MODULE) | 30 | #if FE_SUPPORTED(MT312) || FE_SUPPORTED(STV0299) |
| 25 | static int flexcop_set_voltage(struct dvb_frontend *fe, fe_sec_voltage_t voltage) | 31 | static int flexcop_set_voltage(struct dvb_frontend *fe, fe_sec_voltage_t voltage) |
| 26 | { | 32 | { |
| 27 | struct flexcop_device *fc = fe->dvb->priv; | 33 | struct flexcop_device *fc = fe->dvb->priv; |
| @@ -49,8 +55,7 @@ static int flexcop_set_voltage(struct dvb_frontend *fe, fe_sec_voltage_t voltage | |||
| 49 | } | 55 | } |
| 50 | #endif | 56 | #endif |
| 51 | 57 | ||
| 52 | #if defined(CONFIG_DVB_S5H1420_MODULE) || defined(CONFIG_DVB_STV0299_MODULE) \ | 58 | #if FE_SUPPORTED(S5H1420) || FE_SUPPORTED(STV0299) || FE_SUPPORTED(MT312) |
| 53 | || defined(CONFIG_DVB_MT312_MODULE) | ||
| 54 | static int flexcop_sleep(struct dvb_frontend* fe) | 59 | static int flexcop_sleep(struct dvb_frontend* fe) |
| 55 | { | 60 | { |
| 56 | struct flexcop_device *fc = fe->dvb->priv; | 61 | struct flexcop_device *fc = fe->dvb->priv; |
| @@ -61,7 +66,7 @@ static int flexcop_sleep(struct dvb_frontend* fe) | |||
| 61 | #endif | 66 | #endif |
| 62 | 67 | ||
| 63 | /* SkyStar2 DVB-S rev 2.3 */ | 68 | /* SkyStar2 DVB-S rev 2.3 */ |
| 64 | #if defined(CONFIG_DVB_MT312_MODULE) | 69 | #if FE_SUPPORTED(MT312) |
| 65 | static int flexcop_set_tone(struct dvb_frontend *fe, fe_sec_tone_mode_t tone) | 70 | static int flexcop_set_tone(struct dvb_frontend *fe, fe_sec_tone_mode_t tone) |
| 66 | { | 71 | { |
| 67 | /* u16 wz_half_period_for_45_mhz[] = { 0x01ff, 0x0154, 0x00ff, 0x00cc }; */ | 72 | /* u16 wz_half_period_for_45_mhz[] = { 0x01ff, 0x0154, 0x00ff, 0x00cc }; */ |
| @@ -193,10 +198,12 @@ static int skystar2_rev23_attach(struct flexcop_device *fc, | |||
| 193 | } | 198 | } |
| 194 | return 0; | 199 | return 0; |
| 195 | } | 200 | } |
| 201 | #else | ||
| 202 | #define skystar2_rev23_attach NULL | ||
| 196 | #endif | 203 | #endif |
| 197 | 204 | ||
| 198 | /* SkyStar2 DVB-S rev 2.6 */ | 205 | /* SkyStar2 DVB-S rev 2.6 */ |
| 199 | #if defined(CONFIG_DVB_STV0299_MODULE) | 206 | #if FE_SUPPORTED(STV0299) |
| 200 | static int samsung_tbmu24112_set_symbol_rate(struct dvb_frontend *fe, | 207 | static int samsung_tbmu24112_set_symbol_rate(struct dvb_frontend *fe, |
| 201 | u32 srate, u32 ratio) | 208 | u32 srate, u32 ratio) |
| 202 | { | 209 | { |
| @@ -321,10 +328,12 @@ static int skystar2_rev26_attach(struct flexcop_device *fc, | |||
| 321 | } | 328 | } |
| 322 | return 0; | 329 | return 0; |
| 323 | } | 330 | } |
| 331 | #else | ||
| 332 | #define skystar2_rev26_attach NULL | ||
| 324 | #endif | 333 | #endif |
| 325 | 334 | ||
| 326 | /* SkyStar2 DVB-S rev 2.7 */ | 335 | /* SkyStar2 DVB-S rev 2.7 */ |
| 327 | #if defined(CONFIG_DVB_S5H1420_MODULE) | 336 | #if FE_SUPPORTED(S5H1420) && FE_SUPPORTED(ISL6421) && FE_SUPPORTED(TUNER_ITD1000) |
| 328 | static struct s5h1420_config skystar2_rev2_7_s5h1420_config = { | 337 | static struct s5h1420_config skystar2_rev2_7_s5h1420_config = { |
| 329 | .demod_address = 0x53, | 338 | .demod_address = 0x53, |
| 330 | .invert = 1, | 339 | .invert = 1, |
| @@ -385,10 +394,12 @@ fail: | |||
| 385 | fc->fc_i2c_adap[0].no_base_addr = 0; | 394 | fc->fc_i2c_adap[0].no_base_addr = 0; |
| 386 | return 0; | 395 | return 0; |
| 387 | } | 396 | } |
| 397 | #else | ||
| 398 | #define skystar2_rev27_attach NULL | ||
| 388 | #endif | 399 | #endif |
| 389 | 400 | ||
| 390 | /* SkyStar2 rev 2.8 */ | 401 | /* SkyStar2 rev 2.8 */ |
| 391 | #if defined(CONFIG_DVB_CX24123_MODULE) | 402 | #if FE_SUPPORTED(CX24123) && FE_SUPPORTED(ISL6421) && FE_SUPPORTED(TUNER_CX24113) |
| 392 | static struct cx24123_config skystar2_rev2_8_cx24123_config = { | 403 | static struct cx24123_config skystar2_rev2_8_cx24123_config = { |
| 393 | .demod_address = 0x55, | 404 | .demod_address = 0x55, |
| 394 | .dont_use_pll = 1, | 405 | .dont_use_pll = 1, |
| @@ -433,10 +444,12 @@ static int skystar2_rev28_attach(struct flexcop_device *fc, | |||
| 433 | * IR-receiver (PIC16F818) - but the card has no input for that ??? */ | 444 | * IR-receiver (PIC16F818) - but the card has no input for that ??? */ |
| 434 | return 1; | 445 | return 1; |
| 435 | } | 446 | } |
| 447 | #else | ||
| 448 | #define skystar2_rev28_attach NULL | ||
| 436 | #endif | 449 | #endif |
| 437 | 450 | ||
| 438 | /* AirStar DVB-T */ | 451 | /* AirStar DVB-T */ |
| 439 | #if defined(CONFIG_DVB_MT352_MODULE) | 452 | #if FE_SUPPORTED(MT352) |
| 440 | static int samsung_tdtc9251dh0_demod_init(struct dvb_frontend *fe) | 453 | static int samsung_tdtc9251dh0_demod_init(struct dvb_frontend *fe) |
| 441 | { | 454 | { |
| 442 | static u8 mt352_clock_config[] = { 0x89, 0x18, 0x2d }; | 455 | static u8 mt352_clock_config[] = { 0x89, 0x18, 0x2d }; |
| @@ -495,10 +508,12 @@ static int airstar_dvbt_attach(struct flexcop_device *fc, | |||
| 495 | } | 508 | } |
| 496 | return 0; | 509 | return 0; |
| 497 | } | 510 | } |
| 511 | #else | ||
| 512 | #define airstar_dvbt_attach NULL | ||
| 498 | #endif | 513 | #endif |
| 499 | 514 | ||
| 500 | /* AirStar ATSC 1st generation */ | 515 | /* AirStar ATSC 1st generation */ |
| 501 | #if defined(CONFIG_DVB_BCM3510_MODULE) | 516 | #if FE_SUPPORTED(BCM3510) |
| 502 | static int flexcop_fe_request_firmware(struct dvb_frontend *fe, | 517 | static int flexcop_fe_request_firmware(struct dvb_frontend *fe, |
| 503 | const struct firmware **fw, char* name) | 518 | const struct firmware **fw, char* name) |
| 504 | { | 519 | { |
| @@ -517,10 +532,12 @@ static int airstar_atsc1_attach(struct flexcop_device *fc, | |||
| 517 | fc->fe = dvb_attach(bcm3510_attach, &air2pc_atsc_first_gen_config, i2c); | 532 | fc->fe = dvb_attach(bcm3510_attach, &air2pc_atsc_first_gen_config, i2c); |
| 518 | return fc->fe != NULL; | 533 | return fc->fe != NULL; |
| 519 | } | 534 | } |
| 535 | #else | ||
| 536 | #define airstar_atsc1_attach NULL | ||
| 520 | #endif | 537 | #endif |
| 521 | 538 | ||
| 522 | /* AirStar ATSC 2nd generation */ | 539 | /* AirStar ATSC 2nd generation */ |
| 523 | #if defined(CONFIG_DVB_NXT200X_MODULE) | 540 | #if FE_SUPPORTED(NXT200X) && FE_SUPPORTED(PLL) |
| 524 | static struct nxt200x_config samsung_tbmv_config = { | 541 | static struct nxt200x_config samsung_tbmv_config = { |
| 525 | .demod_address = 0x0a, | 542 | .demod_address = 0x0a, |
| 526 | }; | 543 | }; |
| @@ -535,10 +552,12 @@ static int airstar_atsc2_attach(struct flexcop_device *fc, | |||
| 535 | return !!dvb_attach(dvb_pll_attach, fc->fe, 0x61, NULL, | 552 | return !!dvb_attach(dvb_pll_attach, fc->fe, 0x61, NULL, |
| 536 | DVB_PLL_SAMSUNG_TBMV); | 553 | DVB_PLL_SAMSUNG_TBMV); |
| 537 | } | 554 | } |
| 555 | #else | ||
| 556 | #define airstar_atsc2_attach NULL | ||
| 538 | #endif | 557 | #endif |
| 539 | 558 | ||
| 540 | /* AirStar ATSC 3rd generation */ | 559 | /* AirStar ATSC 3rd generation */ |
| 541 | #if defined(CONFIG_DVB_LGDT330X_MODULE) | 560 | #if FE_SUPPORTED(LGDT330X) |
| 542 | static struct lgdt330x_config air2pc_atsc_hd5000_config = { | 561 | static struct lgdt330x_config air2pc_atsc_hd5000_config = { |
| 543 | .demod_address = 0x59, | 562 | .demod_address = 0x59, |
| 544 | .demod_chip = LGDT3303, | 563 | .demod_chip = LGDT3303, |
| @@ -556,10 +575,12 @@ static int airstar_atsc3_attach(struct flexcop_device *fc, | |||
| 556 | return !!dvb_attach(simple_tuner_attach, fc->fe, i2c, 0x61, | 575 | return !!dvb_attach(simple_tuner_attach, fc->fe, i2c, 0x61, |
| 557 | TUNER_LG_TDVS_H06XF); | 576 | TUNER_LG_TDVS_H06XF); |
| 558 | } | 577 | } |
| 578 | #else | ||
| 579 | #define airstar_atsc3_attach NULL | ||
| 559 | #endif | 580 | #endif |
| 560 | 581 | ||
| 561 | /* CableStar2 DVB-C */ | 582 | /* CableStar2 DVB-C */ |
| 562 | #if defined(CONFIG_DVB_STV0297_MODULE) | 583 | #if FE_SUPPORTED(STV0297) |
| 563 | static int alps_tdee4_stv0297_tuner_set_params(struct dvb_frontend* fe, | 584 | static int alps_tdee4_stv0297_tuner_set_params(struct dvb_frontend* fe, |
| 564 | struct dvb_frontend_parameters *fep) | 585 | struct dvb_frontend_parameters *fep) |
| 565 | { | 586 | { |
| @@ -698,39 +719,23 @@ static int cablestar2_attach(struct flexcop_device *fc, | |||
| 698 | fc->fe->ops.tuner_ops.set_params = alps_tdee4_stv0297_tuner_set_params; | 719 | fc->fe->ops.tuner_ops.set_params = alps_tdee4_stv0297_tuner_set_params; |
| 699 | return 1; | 720 | return 1; |
| 700 | } | 721 | } |
| 722 | #else | ||
| 723 | #define cablestar2_attach NULL | ||
| 701 | #endif | 724 | #endif |
| 702 | 725 | ||
| 703 | static struct { | 726 | static struct { |
| 704 | flexcop_device_type_t type; | 727 | flexcop_device_type_t type; |
| 705 | int (*attach)(struct flexcop_device *, struct i2c_adapter *); | 728 | int (*attach)(struct flexcop_device *, struct i2c_adapter *); |
| 706 | } flexcop_frontends[] = { | 729 | } flexcop_frontends[] = { |
| 707 | #if defined(CONFIG_DVB_S5H1420_MODULE) | ||
| 708 | { FC_SKY_REV27, skystar2_rev27_attach }, | 730 | { FC_SKY_REV27, skystar2_rev27_attach }, |
| 709 | #endif | ||
| 710 | #if defined(CONFIG_DVB_CX24123_MODULE) | ||
| 711 | { FC_SKY_REV28, skystar2_rev28_attach }, | 731 | { FC_SKY_REV28, skystar2_rev28_attach }, |
| 712 | #endif | ||
| 713 | #if defined(CONFIG_DVB_STV0299_MODULE) | ||
| 714 | { FC_SKY_REV26, skystar2_rev26_attach }, | 732 | { FC_SKY_REV26, skystar2_rev26_attach }, |
| 715 | #endif | ||
| 716 | #if defined(CONFIG_DVB_MT352_MODULE) | ||
| 717 | { FC_AIR_DVBT, airstar_dvbt_attach }, | 733 | { FC_AIR_DVBT, airstar_dvbt_attach }, |
| 718 | #endif | ||
| 719 | #if defined(CONFIG_DVB_NXT200X_MODULE) | ||
| 720 | { FC_AIR_ATSC2, airstar_atsc2_attach }, | 734 | { FC_AIR_ATSC2, airstar_atsc2_attach }, |
| 721 | #endif | ||
| 722 | #if defined(CONFIG_DVB_LGDT330X_MODULE) | ||
| 723 | { FC_AIR_ATSC3, airstar_atsc3_attach }, | 735 | { FC_AIR_ATSC3, airstar_atsc3_attach }, |
| 724 | #endif | ||
| 725 | #if defined(CONFIG_DVB_BCM3510_MODULE) | ||
| 726 | { FC_AIR_ATSC1, airstar_atsc1_attach }, | 736 | { FC_AIR_ATSC1, airstar_atsc1_attach }, |
| 727 | #endif | ||
| 728 | #if defined(CONFIG_DVB_STV0297_MODULE) | ||
| 729 | { FC_CABLE, cablestar2_attach }, | 737 | { FC_CABLE, cablestar2_attach }, |
| 730 | #endif | ||
| 731 | #if defined(CONFIG_DVB_MT312_MODULE) | ||
| 732 | { FC_SKY_REV23, skystar2_rev23_attach }, | 738 | { FC_SKY_REV23, skystar2_rev23_attach }, |
| 733 | #endif | ||
| 734 | }; | 739 | }; |
| 735 | 740 | ||
| 736 | /* try to figure out the frontend */ | 741 | /* try to figure out the frontend */ |
| @@ -738,6 +743,8 @@ int flexcop_frontend_init(struct flexcop_device *fc) | |||
| 738 | { | 743 | { |
| 739 | int i; | 744 | int i; |
| 740 | for (i = 0; i < ARRAY_SIZE(flexcop_frontends); i++) { | 745 | for (i = 0; i < ARRAY_SIZE(flexcop_frontends); i++) { |
| 746 | if (!flexcop_frontends[i].attach) | ||
| 747 | continue; | ||
| 741 | /* type needs to be set before, because of some workarounds | 748 | /* type needs to be set before, because of some workarounds |
| 742 | * done based on the probed card type */ | 749 | * done based on the probed card type */ |
| 743 | fc->dev_type = flexcop_frontends[i].type; | 750 | fc->dev_type = flexcop_frontends[i].type; |
diff --git a/drivers/media/dvb/dvb-usb/af9015.c b/drivers/media/dvb/dvb-usb/af9015.c index 4cb31e7c13c2..26690dfb3260 100644 --- a/drivers/media/dvb/dvb-usb/af9015.c +++ b/drivers/media/dvb/dvb-usb/af9015.c | |||
| @@ -81,7 +81,6 @@ static int af9015_rw_udev(struct usb_device *udev, struct req_t *req) | |||
| 81 | 81 | ||
| 82 | switch (req->cmd) { | 82 | switch (req->cmd) { |
| 83 | case GET_CONFIG: | 83 | case GET_CONFIG: |
| 84 | case BOOT: | ||
| 85 | case READ_MEMORY: | 84 | case READ_MEMORY: |
| 86 | case RECONNECT_USB: | 85 | case RECONNECT_USB: |
| 87 | case GET_IR_CODE: | 86 | case GET_IR_CODE: |
| @@ -100,6 +99,7 @@ static int af9015_rw_udev(struct usb_device *udev, struct req_t *req) | |||
| 100 | case WRITE_VIRTUAL_MEMORY: | 99 | case WRITE_VIRTUAL_MEMORY: |
| 101 | case COPY_FIRMWARE: | 100 | case COPY_FIRMWARE: |
| 102 | case DOWNLOAD_FIRMWARE: | 101 | case DOWNLOAD_FIRMWARE: |
| 102 | case BOOT: | ||
| 103 | break; | 103 | break; |
| 104 | default: | 104 | default: |
| 105 | err("unknown command:%d", req->cmd); | 105 | err("unknown command:%d", req->cmd); |
diff --git a/drivers/media/dvb/frontends/af9013.c b/drivers/media/dvb/frontends/af9013.c index 136c5863d81b..12e018b4107d 100644 --- a/drivers/media/dvb/frontends/af9013.c +++ b/drivers/media/dvb/frontends/af9013.c | |||
| @@ -527,6 +527,10 @@ static int af9013_set_ofdm_params(struct af9013_state *state, | |||
| 527 | u8 i, buf[3] = {0, 0, 0}; | 527 | u8 i, buf[3] = {0, 0, 0}; |
| 528 | *auto_mode = 0; /* set if parameters are requested to auto set */ | 528 | *auto_mode = 0; /* set if parameters are requested to auto set */ |
| 529 | 529 | ||
| 530 | /* Try auto-detect transmission parameters in case of AUTO requested or | ||
| 531 | garbage parameters given by application for compatibility. | ||
| 532 | MPlayer seems to provide garbage parameters currently. */ | ||
| 533 | |||
| 530 | switch (params->transmission_mode) { | 534 | switch (params->transmission_mode) { |
| 531 | case TRANSMISSION_MODE_AUTO: | 535 | case TRANSMISSION_MODE_AUTO: |
| 532 | *auto_mode = 1; | 536 | *auto_mode = 1; |
| @@ -536,7 +540,8 @@ static int af9013_set_ofdm_params(struct af9013_state *state, | |||
| 536 | buf[0] |= (1 << 0); | 540 | buf[0] |= (1 << 0); |
| 537 | break; | 541 | break; |
| 538 | default: | 542 | default: |
| 539 | return -EINVAL; | 543 | deb_info("%s: invalid transmission_mode\n", __func__); |
| 544 | *auto_mode = 1; | ||
| 540 | } | 545 | } |
| 541 | 546 | ||
| 542 | switch (params->guard_interval) { | 547 | switch (params->guard_interval) { |
| @@ -554,7 +559,8 @@ static int af9013_set_ofdm_params(struct af9013_state *state, | |||
| 554 | buf[0] |= (3 << 2); | 559 | buf[0] |= (3 << 2); |
| 555 | break; | 560 | break; |
| 556 | default: | 561 | default: |
| 557 | return -EINVAL; | 562 | deb_info("%s: invalid guard_interval\n", __func__); |
| 563 | *auto_mode = 1; | ||
| 558 | } | 564 | } |
| 559 | 565 | ||
| 560 | switch (params->hierarchy_information) { | 566 | switch (params->hierarchy_information) { |
| @@ -572,7 +578,8 @@ static int af9013_set_ofdm_params(struct af9013_state *state, | |||
| 572 | buf[0] |= (3 << 4); | 578 | buf[0] |= (3 << 4); |
| 573 | break; | 579 | break; |
| 574 | default: | 580 | default: |
| 575 | return -EINVAL; | 581 | deb_info("%s: invalid hierarchy_information\n", __func__); |
| 582 | *auto_mode = 1; | ||
| 576 | }; | 583 | }; |
| 577 | 584 | ||
| 578 | switch (params->constellation) { | 585 | switch (params->constellation) { |
| @@ -587,7 +594,8 @@ static int af9013_set_ofdm_params(struct af9013_state *state, | |||
| 587 | buf[1] |= (2 << 6); | 594 | buf[1] |= (2 << 6); |
| 588 | break; | 595 | break; |
| 589 | default: | 596 | default: |
| 590 | return -EINVAL; | 597 | deb_info("%s: invalid constellation\n", __func__); |
| 598 | *auto_mode = 1; | ||
| 591 | } | 599 | } |
| 592 | 600 | ||
| 593 | /* Use HP. How and which case we can switch to LP? */ | 601 | /* Use HP. How and which case we can switch to LP? */ |
| @@ -611,7 +619,8 @@ static int af9013_set_ofdm_params(struct af9013_state *state, | |||
| 611 | buf[2] |= (4 << 0); | 619 | buf[2] |= (4 << 0); |
| 612 | break; | 620 | break; |
| 613 | default: | 621 | default: |
| 614 | return -EINVAL; | 622 | deb_info("%s: invalid code_rate_HP\n", __func__); |
| 623 | *auto_mode = 1; | ||
| 615 | } | 624 | } |
| 616 | 625 | ||
| 617 | switch (params->code_rate_LP) { | 626 | switch (params->code_rate_LP) { |
| @@ -638,7 +647,8 @@ static int af9013_set_ofdm_params(struct af9013_state *state, | |||
| 638 | if (params->hierarchy_information == HIERARCHY_AUTO) | 647 | if (params->hierarchy_information == HIERARCHY_AUTO) |
| 639 | break; | 648 | break; |
| 640 | default: | 649 | default: |
| 641 | return -EINVAL; | 650 | deb_info("%s: invalid code_rate_LP\n", __func__); |
| 651 | *auto_mode = 1; | ||
| 642 | } | 652 | } |
| 643 | 653 | ||
| 644 | switch (params->bandwidth) { | 654 | switch (params->bandwidth) { |
| @@ -651,7 +661,8 @@ static int af9013_set_ofdm_params(struct af9013_state *state, | |||
| 651 | buf[1] |= (2 << 2); | 661 | buf[1] |= (2 << 2); |
| 652 | break; | 662 | break; |
| 653 | default: | 663 | default: |
| 654 | return -EINVAL; | 664 | deb_info("%s: invalid bandwidth\n", __func__); |
| 665 | buf[1] |= (2 << 2); /* cannot auto-detect BW, try 8 MHz */ | ||
| 655 | } | 666 | } |
| 656 | 667 | ||
| 657 | /* program */ | 668 | /* program */ |
diff --git a/drivers/media/dvb/frontends/cx22700.c b/drivers/media/dvb/frontends/cx22700.c index ace5cb17165d..fbd838eca268 100644 --- a/drivers/media/dvb/frontends/cx22700.c +++ b/drivers/media/dvb/frontends/cx22700.c | |||
| @@ -380,7 +380,7 @@ struct dvb_frontend* cx22700_attach(const struct cx22700_config* config, | |||
| 380 | struct cx22700_state* state = NULL; | 380 | struct cx22700_state* state = NULL; |
| 381 | 381 | ||
| 382 | /* allocate memory for the internal state */ | 382 | /* allocate memory for the internal state */ |
| 383 | state = kmalloc(sizeof(struct cx22700_state), GFP_KERNEL); | 383 | state = kzalloc(sizeof(struct cx22700_state), GFP_KERNEL); |
| 384 | if (state == NULL) goto error; | 384 | if (state == NULL) goto error; |
| 385 | 385 | ||
| 386 | /* setup the state */ | 386 | /* setup the state */ |
diff --git a/drivers/media/dvb/frontends/cx22702.c b/drivers/media/dvb/frontends/cx22702.c index 5d1abe34bddb..00b5c7e91d5d 100644 --- a/drivers/media/dvb/frontends/cx22702.c +++ b/drivers/media/dvb/frontends/cx22702.c | |||
| @@ -580,7 +580,7 @@ struct dvb_frontend *cx22702_attach(const struct cx22702_config *config, | |||
| 580 | struct cx22702_state *state = NULL; | 580 | struct cx22702_state *state = NULL; |
| 581 | 581 | ||
| 582 | /* allocate memory for the internal state */ | 582 | /* allocate memory for the internal state */ |
| 583 | state = kmalloc(sizeof(struct cx22702_state), GFP_KERNEL); | 583 | state = kzalloc(sizeof(struct cx22702_state), GFP_KERNEL); |
| 584 | if (state == NULL) | 584 | if (state == NULL) |
| 585 | goto error; | 585 | goto error; |
| 586 | 586 | ||
diff --git a/drivers/media/dvb/frontends/cx24110.c b/drivers/media/dvb/frontends/cx24110.c index 87ae29db024f..ffbcfabd83f0 100644 --- a/drivers/media/dvb/frontends/cx24110.c +++ b/drivers/media/dvb/frontends/cx24110.c | |||
| @@ -598,7 +598,7 @@ struct dvb_frontend* cx24110_attach(const struct cx24110_config* config, | |||
| 598 | int ret; | 598 | int ret; |
| 599 | 599 | ||
| 600 | /* allocate memory for the internal state */ | 600 | /* allocate memory for the internal state */ |
| 601 | state = kmalloc(sizeof(struct cx24110_state), GFP_KERNEL); | 601 | state = kzalloc(sizeof(struct cx24110_state), GFP_KERNEL); |
| 602 | if (state == NULL) goto error; | 602 | if (state == NULL) goto error; |
| 603 | 603 | ||
| 604 | /* setup the state */ | 604 | /* setup the state */ |
diff --git a/drivers/media/dvb/frontends/dvb_dummy_fe.c b/drivers/media/dvb/frontends/dvb_dummy_fe.c index db8a937cc630..a7fc7e53a551 100644 --- a/drivers/media/dvb/frontends/dvb_dummy_fe.c +++ b/drivers/media/dvb/frontends/dvb_dummy_fe.c | |||
| @@ -117,7 +117,7 @@ struct dvb_frontend* dvb_dummy_fe_ofdm_attach(void) | |||
| 117 | struct dvb_dummy_fe_state* state = NULL; | 117 | struct dvb_dummy_fe_state* state = NULL; |
| 118 | 118 | ||
| 119 | /* allocate memory for the internal state */ | 119 | /* allocate memory for the internal state */ |
| 120 | state = kmalloc(sizeof(struct dvb_dummy_fe_state), GFP_KERNEL); | 120 | state = kzalloc(sizeof(struct dvb_dummy_fe_state), GFP_KERNEL); |
| 121 | if (state == NULL) goto error; | 121 | if (state == NULL) goto error; |
| 122 | 122 | ||
| 123 | /* create dvb_frontend */ | 123 | /* create dvb_frontend */ |
| @@ -137,7 +137,7 @@ struct dvb_frontend *dvb_dummy_fe_qpsk_attach(void) | |||
| 137 | struct dvb_dummy_fe_state* state = NULL; | 137 | struct dvb_dummy_fe_state* state = NULL; |
| 138 | 138 | ||
| 139 | /* allocate memory for the internal state */ | 139 | /* allocate memory for the internal state */ |
| 140 | state = kmalloc(sizeof(struct dvb_dummy_fe_state), GFP_KERNEL); | 140 | state = kzalloc(sizeof(struct dvb_dummy_fe_state), GFP_KERNEL); |
| 141 | if (state == NULL) goto error; | 141 | if (state == NULL) goto error; |
| 142 | 142 | ||
| 143 | /* create dvb_frontend */ | 143 | /* create dvb_frontend */ |
| @@ -157,7 +157,7 @@ struct dvb_frontend *dvb_dummy_fe_qam_attach(void) | |||
| 157 | struct dvb_dummy_fe_state* state = NULL; | 157 | struct dvb_dummy_fe_state* state = NULL; |
| 158 | 158 | ||
| 159 | /* allocate memory for the internal state */ | 159 | /* allocate memory for the internal state */ |
| 160 | state = kmalloc(sizeof(struct dvb_dummy_fe_state), GFP_KERNEL); | 160 | state = kzalloc(sizeof(struct dvb_dummy_fe_state), GFP_KERNEL); |
| 161 | if (state == NULL) goto error; | 161 | if (state == NULL) goto error; |
| 162 | 162 | ||
| 163 | /* create dvb_frontend */ | 163 | /* create dvb_frontend */ |
diff --git a/drivers/media/dvb/frontends/l64781.c b/drivers/media/dvb/frontends/l64781.c index e1e70e9e0cb9..3051b64aa17c 100644 --- a/drivers/media/dvb/frontends/l64781.c +++ b/drivers/media/dvb/frontends/l64781.c | |||
| @@ -501,7 +501,7 @@ struct dvb_frontend* l64781_attach(const struct l64781_config* config, | |||
| 501 | { .addr = config->demod_address, .flags = I2C_M_RD, .buf = b1, .len = 1 } }; | 501 | { .addr = config->demod_address, .flags = I2C_M_RD, .buf = b1, .len = 1 } }; |
| 502 | 502 | ||
| 503 | /* allocate memory for the internal state */ | 503 | /* allocate memory for the internal state */ |
| 504 | state = kmalloc(sizeof(struct l64781_state), GFP_KERNEL); | 504 | state = kzalloc(sizeof(struct l64781_state), GFP_KERNEL); |
| 505 | if (state == NULL) goto error; | 505 | if (state == NULL) goto error; |
| 506 | 506 | ||
| 507 | /* setup the state */ | 507 | /* setup the state */ |
diff --git a/drivers/media/dvb/frontends/lgs8gl5.c b/drivers/media/dvb/frontends/lgs8gl5.c index 855852fddf22..bb37ed289a05 100644 --- a/drivers/media/dvb/frontends/lgs8gl5.c +++ b/drivers/media/dvb/frontends/lgs8gl5.c | |||
| @@ -387,7 +387,7 @@ lgs8gl5_attach(const struct lgs8gl5_config *config, struct i2c_adapter *i2c) | |||
| 387 | dprintk("%s\n", __func__); | 387 | dprintk("%s\n", __func__); |
| 388 | 388 | ||
| 389 | /* Allocate memory for the internal state */ | 389 | /* Allocate memory for the internal state */ |
| 390 | state = kmalloc(sizeof(struct lgs8gl5_state), GFP_KERNEL); | 390 | state = kzalloc(sizeof(struct lgs8gl5_state), GFP_KERNEL); |
| 391 | if (state == NULL) | 391 | if (state == NULL) |
| 392 | goto error; | 392 | goto error; |
| 393 | 393 | ||
diff --git a/drivers/media/dvb/frontends/mt312.c b/drivers/media/dvb/frontends/mt312.c index a621f727935f..f69daaac78c9 100644 --- a/drivers/media/dvb/frontends/mt312.c +++ b/drivers/media/dvb/frontends/mt312.c | |||
| @@ -782,7 +782,7 @@ struct dvb_frontend *mt312_attach(const struct mt312_config *config, | |||
| 782 | struct mt312_state *state = NULL; | 782 | struct mt312_state *state = NULL; |
| 783 | 783 | ||
| 784 | /* allocate memory for the internal state */ | 784 | /* allocate memory for the internal state */ |
| 785 | state = kmalloc(sizeof(struct mt312_state), GFP_KERNEL); | 785 | state = kzalloc(sizeof(struct mt312_state), GFP_KERNEL); |
| 786 | if (state == NULL) | 786 | if (state == NULL) |
| 787 | goto error; | 787 | goto error; |
| 788 | 788 | ||
diff --git a/drivers/media/dvb/frontends/nxt6000.c b/drivers/media/dvb/frontends/nxt6000.c index 0eef22dbf8a0..a763ec756f7f 100644 --- a/drivers/media/dvb/frontends/nxt6000.c +++ b/drivers/media/dvb/frontends/nxt6000.c | |||
| @@ -545,7 +545,7 @@ struct dvb_frontend* nxt6000_attach(const struct nxt6000_config* config, | |||
| 545 | struct nxt6000_state* state = NULL; | 545 | struct nxt6000_state* state = NULL; |
| 546 | 546 | ||
| 547 | /* allocate memory for the internal state */ | 547 | /* allocate memory for the internal state */ |
| 548 | state = kmalloc(sizeof(struct nxt6000_state), GFP_KERNEL); | 548 | state = kzalloc(sizeof(struct nxt6000_state), GFP_KERNEL); |
| 549 | if (state == NULL) goto error; | 549 | if (state == NULL) goto error; |
| 550 | 550 | ||
| 551 | /* setup the state */ | 551 | /* setup the state */ |
diff --git a/drivers/media/dvb/frontends/or51132.c b/drivers/media/dvb/frontends/or51132.c index 8133ea3cddd7..38e67accb8c3 100644 --- a/drivers/media/dvb/frontends/or51132.c +++ b/drivers/media/dvb/frontends/or51132.c | |||
| @@ -562,7 +562,7 @@ struct dvb_frontend* or51132_attach(const struct or51132_config* config, | |||
| 562 | struct or51132_state* state = NULL; | 562 | struct or51132_state* state = NULL; |
| 563 | 563 | ||
| 564 | /* Allocate memory for the internal state */ | 564 | /* Allocate memory for the internal state */ |
| 565 | state = kmalloc(sizeof(struct or51132_state), GFP_KERNEL); | 565 | state = kzalloc(sizeof(struct or51132_state), GFP_KERNEL); |
| 566 | if (state == NULL) | 566 | if (state == NULL) |
| 567 | return NULL; | 567 | return NULL; |
| 568 | 568 | ||
diff --git a/drivers/media/dvb/frontends/or51211.c b/drivers/media/dvb/frontends/or51211.c index 16cf2fdd5d7d..c709ce6771c8 100644 --- a/drivers/media/dvb/frontends/or51211.c +++ b/drivers/media/dvb/frontends/or51211.c | |||
| @@ -527,7 +527,7 @@ struct dvb_frontend* or51211_attach(const struct or51211_config* config, | |||
| 527 | struct or51211_state* state = NULL; | 527 | struct or51211_state* state = NULL; |
| 528 | 528 | ||
| 529 | /* Allocate memory for the internal state */ | 529 | /* Allocate memory for the internal state */ |
| 530 | state = kmalloc(sizeof(struct or51211_state), GFP_KERNEL); | 530 | state = kzalloc(sizeof(struct or51211_state), GFP_KERNEL); |
| 531 | if (state == NULL) | 531 | if (state == NULL) |
| 532 | return NULL; | 532 | return NULL; |
| 533 | 533 | ||
diff --git a/drivers/media/dvb/frontends/s5h1409.c b/drivers/media/dvb/frontends/s5h1409.c index 3e08d985d6e5..fb3011518427 100644 --- a/drivers/media/dvb/frontends/s5h1409.c +++ b/drivers/media/dvb/frontends/s5h1409.c | |||
| @@ -796,7 +796,7 @@ struct dvb_frontend *s5h1409_attach(const struct s5h1409_config *config, | |||
| 796 | u16 reg; | 796 | u16 reg; |
| 797 | 797 | ||
| 798 | /* allocate memory for the internal state */ | 798 | /* allocate memory for the internal state */ |
| 799 | state = kmalloc(sizeof(struct s5h1409_state), GFP_KERNEL); | 799 | state = kzalloc(sizeof(struct s5h1409_state), GFP_KERNEL); |
| 800 | if (state == NULL) | 800 | if (state == NULL) |
| 801 | goto error; | 801 | goto error; |
| 802 | 802 | ||
diff --git a/drivers/media/dvb/frontends/s5h1411.c b/drivers/media/dvb/frontends/s5h1411.c index 66e2dd6d6fe4..d8adf1e32019 100644 --- a/drivers/media/dvb/frontends/s5h1411.c +++ b/drivers/media/dvb/frontends/s5h1411.c | |||
| @@ -844,7 +844,7 @@ struct dvb_frontend *s5h1411_attach(const struct s5h1411_config *config, | |||
| 844 | u16 reg; | 844 | u16 reg; |
| 845 | 845 | ||
| 846 | /* allocate memory for the internal state */ | 846 | /* allocate memory for the internal state */ |
| 847 | state = kmalloc(sizeof(struct s5h1411_state), GFP_KERNEL); | 847 | state = kzalloc(sizeof(struct s5h1411_state), GFP_KERNEL); |
| 848 | if (state == NULL) | 848 | if (state == NULL) |
| 849 | goto error; | 849 | goto error; |
| 850 | 850 | ||
diff --git a/drivers/media/dvb/frontends/si21xx.c b/drivers/media/dvb/frontends/si21xx.c index 0bd16af8a6cd..9552a22ccffb 100644 --- a/drivers/media/dvb/frontends/si21xx.c +++ b/drivers/media/dvb/frontends/si21xx.c | |||
| @@ -928,7 +928,7 @@ struct dvb_frontend *si21xx_attach(const struct si21xx_config *config, | |||
| 928 | dprintk("%s\n", __func__); | 928 | dprintk("%s\n", __func__); |
| 929 | 929 | ||
| 930 | /* allocate memory for the internal state */ | 930 | /* allocate memory for the internal state */ |
| 931 | state = kmalloc(sizeof(struct si21xx_state), GFP_KERNEL); | 931 | state = kzalloc(sizeof(struct si21xx_state), GFP_KERNEL); |
| 932 | if (state == NULL) | 932 | if (state == NULL) |
| 933 | goto error; | 933 | goto error; |
| 934 | 934 | ||
diff --git a/drivers/media/dvb/frontends/sp8870.c b/drivers/media/dvb/frontends/sp8870.c index 1c9a9b4051b9..b85eb60a893e 100644 --- a/drivers/media/dvb/frontends/sp8870.c +++ b/drivers/media/dvb/frontends/sp8870.c | |||
| @@ -557,7 +557,7 @@ struct dvb_frontend* sp8870_attach(const struct sp8870_config* config, | |||
| 557 | struct sp8870_state* state = NULL; | 557 | struct sp8870_state* state = NULL; |
| 558 | 558 | ||
| 559 | /* allocate memory for the internal state */ | 559 | /* allocate memory for the internal state */ |
| 560 | state = kmalloc(sizeof(struct sp8870_state), GFP_KERNEL); | 560 | state = kzalloc(sizeof(struct sp8870_state), GFP_KERNEL); |
| 561 | if (state == NULL) goto error; | 561 | if (state == NULL) goto error; |
| 562 | 562 | ||
| 563 | /* setup the state */ | 563 | /* setup the state */ |
diff --git a/drivers/media/dvb/frontends/sp887x.c b/drivers/media/dvb/frontends/sp887x.c index 559509ab4dab..4a7c3d842608 100644 --- a/drivers/media/dvb/frontends/sp887x.c +++ b/drivers/media/dvb/frontends/sp887x.c | |||
| @@ -557,7 +557,7 @@ struct dvb_frontend* sp887x_attach(const struct sp887x_config* config, | |||
| 557 | struct sp887x_state* state = NULL; | 557 | struct sp887x_state* state = NULL; |
| 558 | 558 | ||
| 559 | /* allocate memory for the internal state */ | 559 | /* allocate memory for the internal state */ |
| 560 | state = kmalloc(sizeof(struct sp887x_state), GFP_KERNEL); | 560 | state = kzalloc(sizeof(struct sp887x_state), GFP_KERNEL); |
| 561 | if (state == NULL) goto error; | 561 | if (state == NULL) goto error; |
| 562 | 562 | ||
| 563 | /* setup the state */ | 563 | /* setup the state */ |
diff --git a/drivers/media/dvb/frontends/stv0288.c b/drivers/media/dvb/frontends/stv0288.c index ff1194de34c0..2930a5d6768a 100644 --- a/drivers/media/dvb/frontends/stv0288.c +++ b/drivers/media/dvb/frontends/stv0288.c | |||
| @@ -570,7 +570,7 @@ struct dvb_frontend *stv0288_attach(const struct stv0288_config *config, | |||
| 570 | int id; | 570 | int id; |
| 571 | 571 | ||
| 572 | /* allocate memory for the internal state */ | 572 | /* allocate memory for the internal state */ |
| 573 | state = kmalloc(sizeof(struct stv0288_state), GFP_KERNEL); | 573 | state = kzalloc(sizeof(struct stv0288_state), GFP_KERNEL); |
| 574 | if (state == NULL) | 574 | if (state == NULL) |
| 575 | goto error; | 575 | goto error; |
| 576 | 576 | ||
diff --git a/drivers/media/dvb/frontends/stv0297.c b/drivers/media/dvb/frontends/stv0297.c index 62caf802ed99..4fd7479bb62b 100644 --- a/drivers/media/dvb/frontends/stv0297.c +++ b/drivers/media/dvb/frontends/stv0297.c | |||
| @@ -663,7 +663,7 @@ struct dvb_frontend *stv0297_attach(const struct stv0297_config *config, | |||
| 663 | struct stv0297_state *state = NULL; | 663 | struct stv0297_state *state = NULL; |
| 664 | 664 | ||
| 665 | /* allocate memory for the internal state */ | 665 | /* allocate memory for the internal state */ |
| 666 | state = kmalloc(sizeof(struct stv0297_state), GFP_KERNEL); | 666 | state = kzalloc(sizeof(struct stv0297_state), GFP_KERNEL); |
| 667 | if (state == NULL) | 667 | if (state == NULL) |
| 668 | goto error; | 668 | goto error; |
| 669 | 669 | ||
diff --git a/drivers/media/dvb/frontends/stv0299.c b/drivers/media/dvb/frontends/stv0299.c index 6c1cb1973c6e..968874469726 100644 --- a/drivers/media/dvb/frontends/stv0299.c +++ b/drivers/media/dvb/frontends/stv0299.c | |||
| @@ -667,7 +667,7 @@ struct dvb_frontend* stv0299_attach(const struct stv0299_config* config, | |||
| 667 | int id; | 667 | int id; |
| 668 | 668 | ||
| 669 | /* allocate memory for the internal state */ | 669 | /* allocate memory for the internal state */ |
| 670 | state = kmalloc(sizeof(struct stv0299_state), GFP_KERNEL); | 670 | state = kzalloc(sizeof(struct stv0299_state), GFP_KERNEL); |
| 671 | if (state == NULL) goto error; | 671 | if (state == NULL) goto error; |
| 672 | 672 | ||
| 673 | /* setup the state */ | 673 | /* setup the state */ |
diff --git a/drivers/media/dvb/frontends/tda10021.c b/drivers/media/dvb/frontends/tda10021.c index f648fdb64bb7..f5d7b3277a2f 100644 --- a/drivers/media/dvb/frontends/tda10021.c +++ b/drivers/media/dvb/frontends/tda10021.c | |||
| @@ -413,7 +413,7 @@ struct dvb_frontend* tda10021_attach(const struct tda1002x_config* config, | |||
| 413 | u8 id; | 413 | u8 id; |
| 414 | 414 | ||
| 415 | /* allocate memory for the internal state */ | 415 | /* allocate memory for the internal state */ |
| 416 | state = kmalloc(sizeof(struct tda10021_state), GFP_KERNEL); | 416 | state = kzalloc(sizeof(struct tda10021_state), GFP_KERNEL); |
| 417 | if (state == NULL) goto error; | 417 | if (state == NULL) goto error; |
| 418 | 418 | ||
| 419 | /* setup the state */ | 419 | /* setup the state */ |
diff --git a/drivers/media/dvb/frontends/tda10048.c b/drivers/media/dvb/frontends/tda10048.c index cc8862ce4aae..4e2a7c8b2f62 100644 --- a/drivers/media/dvb/frontends/tda10048.c +++ b/drivers/media/dvb/frontends/tda10048.c | |||
| @@ -1095,7 +1095,7 @@ struct dvb_frontend *tda10048_attach(const struct tda10048_config *config, | |||
| 1095 | dprintk(1, "%s()\n", __func__); | 1095 | dprintk(1, "%s()\n", __func__); |
| 1096 | 1096 | ||
| 1097 | /* allocate memory for the internal state */ | 1097 | /* allocate memory for the internal state */ |
| 1098 | state = kmalloc(sizeof(struct tda10048_state), GFP_KERNEL); | 1098 | state = kzalloc(sizeof(struct tda10048_state), GFP_KERNEL); |
| 1099 | if (state == NULL) | 1099 | if (state == NULL) |
| 1100 | goto error; | 1100 | goto error; |
| 1101 | 1101 | ||
diff --git a/drivers/media/dvb/frontends/tda1004x.c b/drivers/media/dvb/frontends/tda1004x.c index 4981cef8b444..f2a8abe0a243 100644 --- a/drivers/media/dvb/frontends/tda1004x.c +++ b/drivers/media/dvb/frontends/tda1004x.c | |||
| @@ -1269,7 +1269,7 @@ struct dvb_frontend* tda10045_attach(const struct tda1004x_config* config, | |||
| 1269 | int id; | 1269 | int id; |
| 1270 | 1270 | ||
| 1271 | /* allocate memory for the internal state */ | 1271 | /* allocate memory for the internal state */ |
| 1272 | state = kmalloc(sizeof(struct tda1004x_state), GFP_KERNEL); | 1272 | state = kzalloc(sizeof(struct tda1004x_state), GFP_KERNEL); |
| 1273 | if (!state) { | 1273 | if (!state) { |
| 1274 | printk(KERN_ERR "Can't alocate memory for tda10045 state\n"); | 1274 | printk(KERN_ERR "Can't alocate memory for tda10045 state\n"); |
| 1275 | return NULL; | 1275 | return NULL; |
| @@ -1339,7 +1339,7 @@ struct dvb_frontend* tda10046_attach(const struct tda1004x_config* config, | |||
| 1339 | int id; | 1339 | int id; |
| 1340 | 1340 | ||
| 1341 | /* allocate memory for the internal state */ | 1341 | /* allocate memory for the internal state */ |
| 1342 | state = kmalloc(sizeof(struct tda1004x_state), GFP_KERNEL); | 1342 | state = kzalloc(sizeof(struct tda1004x_state), GFP_KERNEL); |
| 1343 | if (!state) { | 1343 | if (!state) { |
| 1344 | printk(KERN_ERR "Can't alocate memory for tda10046 state\n"); | 1344 | printk(KERN_ERR "Can't alocate memory for tda10046 state\n"); |
| 1345 | return NULL; | 1345 | return NULL; |
diff --git a/drivers/media/dvb/frontends/tda10086.c b/drivers/media/dvb/frontends/tda10086.c index a17ce3c4ad86..f2c8faac6f36 100644 --- a/drivers/media/dvb/frontends/tda10086.c +++ b/drivers/media/dvb/frontends/tda10086.c | |||
| @@ -745,7 +745,7 @@ struct dvb_frontend* tda10086_attach(const struct tda10086_config* config, | |||
| 745 | dprintk ("%s\n", __func__); | 745 | dprintk ("%s\n", __func__); |
| 746 | 746 | ||
| 747 | /* allocate memory for the internal state */ | 747 | /* allocate memory for the internal state */ |
| 748 | state = kmalloc(sizeof(struct tda10086_state), GFP_KERNEL); | 748 | state = kzalloc(sizeof(struct tda10086_state), GFP_KERNEL); |
| 749 | if (!state) | 749 | if (!state) |
| 750 | return NULL; | 750 | return NULL; |
| 751 | 751 | ||
diff --git a/drivers/media/dvb/frontends/tda8083.c b/drivers/media/dvb/frontends/tda8083.c index 5b843b2e67e8..9369f7442f27 100644 --- a/drivers/media/dvb/frontends/tda8083.c +++ b/drivers/media/dvb/frontends/tda8083.c | |||
| @@ -417,7 +417,7 @@ struct dvb_frontend* tda8083_attach(const struct tda8083_config* config, | |||
| 417 | struct tda8083_state* state = NULL; | 417 | struct tda8083_state* state = NULL; |
| 418 | 418 | ||
| 419 | /* allocate memory for the internal state */ | 419 | /* allocate memory for the internal state */ |
| 420 | state = kmalloc(sizeof(struct tda8083_state), GFP_KERNEL); | 420 | state = kzalloc(sizeof(struct tda8083_state), GFP_KERNEL); |
| 421 | if (state == NULL) goto error; | 421 | if (state == NULL) goto error; |
| 422 | 422 | ||
| 423 | /* setup the state */ | 423 | /* setup the state */ |
diff --git a/drivers/media/dvb/frontends/ves1820.c b/drivers/media/dvb/frontends/ves1820.c index a184597f1d9b..6e78e4865515 100644 --- a/drivers/media/dvb/frontends/ves1820.c +++ b/drivers/media/dvb/frontends/ves1820.c | |||
| @@ -374,7 +374,7 @@ struct dvb_frontend* ves1820_attach(const struct ves1820_config* config, | |||
| 374 | struct ves1820_state* state = NULL; | 374 | struct ves1820_state* state = NULL; |
| 375 | 375 | ||
| 376 | /* allocate memory for the internal state */ | 376 | /* allocate memory for the internal state */ |
| 377 | state = kmalloc(sizeof(struct ves1820_state), GFP_KERNEL); | 377 | state = kzalloc(sizeof(struct ves1820_state), GFP_KERNEL); |
| 378 | if (state == NULL) | 378 | if (state == NULL) |
| 379 | goto error; | 379 | goto error; |
| 380 | 380 | ||
diff --git a/drivers/media/dvb/frontends/ves1x93.c b/drivers/media/dvb/frontends/ves1x93.c index bd558960bd87..8d7854c2fb0c 100644 --- a/drivers/media/dvb/frontends/ves1x93.c +++ b/drivers/media/dvb/frontends/ves1x93.c | |||
| @@ -456,7 +456,7 @@ struct dvb_frontend* ves1x93_attach(const struct ves1x93_config* config, | |||
| 456 | u8 identity; | 456 | u8 identity; |
| 457 | 457 | ||
| 458 | /* allocate memory for the internal state */ | 458 | /* allocate memory for the internal state */ |
| 459 | state = kmalloc(sizeof(struct ves1x93_state), GFP_KERNEL); | 459 | state = kzalloc(sizeof(struct ves1x93_state), GFP_KERNEL); |
| 460 | if (state == NULL) goto error; | 460 | if (state == NULL) goto error; |
| 461 | 461 | ||
| 462 | /* setup the state */ | 462 | /* setup the state */ |
diff --git a/drivers/media/dvb/frontends/zl10353.c b/drivers/media/dvb/frontends/zl10353.c index 148b6f7f6cb2..66f5c1fb3074 100644 --- a/drivers/media/dvb/frontends/zl10353.c +++ b/drivers/media/dvb/frontends/zl10353.c | |||
| @@ -98,7 +98,6 @@ static int zl10353_read_register(struct zl10353_state *state, u8 reg) | |||
| 98 | static void zl10353_dump_regs(struct dvb_frontend *fe) | 98 | static void zl10353_dump_regs(struct dvb_frontend *fe) |
| 99 | { | 99 | { |
| 100 | struct zl10353_state *state = fe->demodulator_priv; | 100 | struct zl10353_state *state = fe->demodulator_priv; |
| 101 | char buf[52], buf2[4]; | ||
| 102 | int ret; | 101 | int ret; |
| 103 | u8 reg; | 102 | u8 reg; |
| 104 | 103 | ||
| @@ -106,19 +105,18 @@ static void zl10353_dump_regs(struct dvb_frontend *fe) | |||
| 106 | for (reg = 0; ; reg++) { | 105 | for (reg = 0; ; reg++) { |
| 107 | if (reg % 16 == 0) { | 106 | if (reg % 16 == 0) { |
| 108 | if (reg) | 107 | if (reg) |
| 109 | printk(KERN_DEBUG "%s\n", buf); | 108 | printk(KERN_CONT "\n"); |
| 110 | sprintf(buf, "%02x: ", reg); | 109 | printk(KERN_DEBUG "%02x:", reg); |
| 111 | } | 110 | } |
| 112 | ret = zl10353_read_register(state, reg); | 111 | ret = zl10353_read_register(state, reg); |
| 113 | if (ret >= 0) | 112 | if (ret >= 0) |
| 114 | sprintf(buf2, "%02x ", (u8)ret); | 113 | printk(KERN_CONT " %02x", (u8)ret); |
| 115 | else | 114 | else |
| 116 | strcpy(buf2, "-- "); | 115 | printk(KERN_CONT " --"); |
| 117 | strcat(buf, buf2); | ||
| 118 | if (reg == 0xff) | 116 | if (reg == 0xff) |
| 119 | break; | 117 | break; |
| 120 | } | 118 | } |
| 121 | printk(KERN_DEBUG "%s\n", buf); | 119 | printk(KERN_CONT "\n"); |
| 122 | } | 120 | } |
| 123 | 121 | ||
| 124 | static void zl10353_calc_nominal_rate(struct dvb_frontend *fe, | 122 | static void zl10353_calc_nominal_rate(struct dvb_frontend *fe, |
diff --git a/drivers/media/dvb/siano/Kconfig b/drivers/media/dvb/siano/Kconfig index dd863f261672..88847d1dcbb5 100644 --- a/drivers/media/dvb/siano/Kconfig +++ b/drivers/media/dvb/siano/Kconfig | |||
| @@ -4,7 +4,7 @@ | |||
| 4 | 4 | ||
| 5 | config DVB_SIANO_SMS1XXX | 5 | config DVB_SIANO_SMS1XXX |
| 6 | tristate "Siano SMS1XXX USB dongle support" | 6 | tristate "Siano SMS1XXX USB dongle support" |
| 7 | depends on DVB_CORE && USB | 7 | depends on DVB_CORE && USB && INPUT |
| 8 | ---help--- | 8 | ---help--- |
| 9 | Choose Y here if you have a USB dongle with a SMS1XXX chipset. | 9 | Choose Y here if you have a USB dongle with a SMS1XXX chipset. |
| 10 | 10 | ||
diff --git a/drivers/media/dvb/siano/sms-cards.c b/drivers/media/dvb/siano/sms-cards.c index d8b15d583bde..0420e2885e75 100644 --- a/drivers/media/dvb/siano/sms-cards.c +++ b/drivers/media/dvb/siano/sms-cards.c | |||
| @@ -116,99 +116,21 @@ static inline void sms_gpio_assign_11xx_default_led_config( | |||
| 116 | 116 | ||
| 117 | int sms_board_event(struct smscore_device_t *coredev, | 117 | int sms_board_event(struct smscore_device_t *coredev, |
| 118 | enum SMS_BOARD_EVENTS gevent) { | 118 | enum SMS_BOARD_EVENTS gevent) { |
| 119 | int board_id = smscore_get_board_id(coredev); | ||
| 120 | struct sms_board *board = sms_get_board(board_id); | ||
| 121 | struct smscore_gpio_config MyGpioConfig; | 119 | struct smscore_gpio_config MyGpioConfig; |
| 122 | 120 | ||
| 123 | sms_gpio_assign_11xx_default_led_config(&MyGpioConfig); | 121 | sms_gpio_assign_11xx_default_led_config(&MyGpioConfig); |
| 124 | 122 | ||
| 125 | switch (gevent) { | 123 | switch (gevent) { |
| 126 | case BOARD_EVENT_POWER_INIT: /* including hotplug */ | 124 | case BOARD_EVENT_POWER_INIT: /* including hotplug */ |
| 127 | switch (board_id) { | ||
| 128 | case SMS1XXX_BOARD_HAUPPAUGE_WINDHAM: | ||
| 129 | /* set I/O and turn off all LEDs */ | ||
| 130 | smscore_gpio_configure(coredev, | ||
| 131 | board->board_cfg.leds_power, | ||
| 132 | &MyGpioConfig); | ||
| 133 | smscore_gpio_set_level(coredev, | ||
| 134 | board->board_cfg.leds_power, 0); | ||
| 135 | smscore_gpio_configure(coredev, board->board_cfg.led0, | ||
| 136 | &MyGpioConfig); | ||
| 137 | smscore_gpio_set_level(coredev, | ||
| 138 | board->board_cfg.led0, 0); | ||
| 139 | smscore_gpio_configure(coredev, board->board_cfg.led1, | ||
| 140 | &MyGpioConfig); | ||
| 141 | smscore_gpio_set_level(coredev, | ||
| 142 | board->board_cfg.led1, 0); | ||
| 143 | break; | ||
| 144 | case SMS1XXX_BOARD_HAUPPAUGE_TIGER_MINICARD_R2: | ||
| 145 | case SMS1XXX_BOARD_HAUPPAUGE_TIGER_MINICARD: | ||
| 146 | /* set I/O and turn off LNA */ | ||
| 147 | smscore_gpio_configure(coredev, | ||
| 148 | board->board_cfg.foreign_lna0_ctrl, | ||
| 149 | &MyGpioConfig); | ||
| 150 | smscore_gpio_set_level(coredev, | ||
| 151 | board->board_cfg.foreign_lna0_ctrl, | ||
| 152 | 0); | ||
| 153 | break; | ||
| 154 | } | ||
| 155 | break; /* BOARD_EVENT_BIND */ | 125 | break; /* BOARD_EVENT_BIND */ |
| 156 | 126 | ||
| 157 | case BOARD_EVENT_POWER_SUSPEND: | 127 | case BOARD_EVENT_POWER_SUSPEND: |
| 158 | switch (board_id) { | ||
| 159 | case SMS1XXX_BOARD_HAUPPAUGE_WINDHAM: | ||
| 160 | smscore_gpio_set_level(coredev, | ||
| 161 | board->board_cfg.leds_power, 0); | ||
| 162 | smscore_gpio_set_level(coredev, | ||
| 163 | board->board_cfg.led0, 0); | ||
| 164 | smscore_gpio_set_level(coredev, | ||
| 165 | board->board_cfg.led1, 0); | ||
| 166 | break; | ||
| 167 | case SMS1XXX_BOARD_HAUPPAUGE_TIGER_MINICARD_R2: | ||
| 168 | case SMS1XXX_BOARD_HAUPPAUGE_TIGER_MINICARD: | ||
| 169 | smscore_gpio_set_level(coredev, | ||
| 170 | board->board_cfg.foreign_lna0_ctrl, | ||
| 171 | 0); | ||
| 172 | break; | ||
| 173 | } | ||
| 174 | break; /* BOARD_EVENT_POWER_SUSPEND */ | 128 | break; /* BOARD_EVENT_POWER_SUSPEND */ |
| 175 | 129 | ||
| 176 | case BOARD_EVENT_POWER_RESUME: | 130 | case BOARD_EVENT_POWER_RESUME: |
| 177 | switch (board_id) { | ||
| 178 | case SMS1XXX_BOARD_HAUPPAUGE_WINDHAM: | ||
| 179 | smscore_gpio_set_level(coredev, | ||
| 180 | board->board_cfg.leds_power, 1); | ||
| 181 | smscore_gpio_set_level(coredev, | ||
| 182 | board->board_cfg.led0, 1); | ||
| 183 | smscore_gpio_set_level(coredev, | ||
| 184 | board->board_cfg.led1, 0); | ||
| 185 | break; | ||
| 186 | case SMS1XXX_BOARD_HAUPPAUGE_TIGER_MINICARD_R2: | ||
| 187 | case SMS1XXX_BOARD_HAUPPAUGE_TIGER_MINICARD: | ||
| 188 | smscore_gpio_set_level(coredev, | ||
| 189 | board->board_cfg.foreign_lna0_ctrl, | ||
| 190 | 1); | ||
| 191 | break; | ||
| 192 | } | ||
| 193 | break; /* BOARD_EVENT_POWER_RESUME */ | 131 | break; /* BOARD_EVENT_POWER_RESUME */ |
| 194 | 132 | ||
| 195 | case BOARD_EVENT_BIND: | 133 | case BOARD_EVENT_BIND: |
| 196 | switch (board_id) { | ||
| 197 | case SMS1XXX_BOARD_HAUPPAUGE_WINDHAM: | ||
| 198 | smscore_gpio_set_level(coredev, | ||
| 199 | board->board_cfg.leds_power, 1); | ||
| 200 | smscore_gpio_set_level(coredev, | ||
| 201 | board->board_cfg.led0, 1); | ||
| 202 | smscore_gpio_set_level(coredev, | ||
| 203 | board->board_cfg.led1, 0); | ||
| 204 | break; | ||
| 205 | case SMS1XXX_BOARD_HAUPPAUGE_TIGER_MINICARD_R2: | ||
| 206 | case SMS1XXX_BOARD_HAUPPAUGE_TIGER_MINICARD: | ||
| 207 | smscore_gpio_set_level(coredev, | ||
| 208 | board->board_cfg.foreign_lna0_ctrl, | ||
| 209 | 1); | ||
| 210 | break; | ||
| 211 | } | ||
| 212 | break; /* BOARD_EVENT_BIND */ | 134 | break; /* BOARD_EVENT_BIND */ |
| 213 | 135 | ||
| 214 | case BOARD_EVENT_SCAN_PROG: | 136 | case BOARD_EVENT_SCAN_PROG: |
| @@ -218,20 +140,8 @@ int sms_board_event(struct smscore_device_t *coredev, | |||
| 218 | case BOARD_EVENT_EMERGENCY_WARNING_SIGNAL: | 140 | case BOARD_EVENT_EMERGENCY_WARNING_SIGNAL: |
| 219 | break; /* BOARD_EVENT_EMERGENCY_WARNING_SIGNAL */ | 141 | break; /* BOARD_EVENT_EMERGENCY_WARNING_SIGNAL */ |
| 220 | case BOARD_EVENT_FE_LOCK: | 142 | case BOARD_EVENT_FE_LOCK: |
| 221 | switch (board_id) { | ||
| 222 | case SMS1XXX_BOARD_HAUPPAUGE_WINDHAM: | ||
| 223 | smscore_gpio_set_level(coredev, | ||
| 224 | board->board_cfg.led1, 1); | ||
| 225 | break; | ||
| 226 | } | ||
| 227 | break; /* BOARD_EVENT_FE_LOCK */ | 143 | break; /* BOARD_EVENT_FE_LOCK */ |
| 228 | case BOARD_EVENT_FE_UNLOCK: | 144 | case BOARD_EVENT_FE_UNLOCK: |
| 229 | switch (board_id) { | ||
| 230 | case SMS1XXX_BOARD_HAUPPAUGE_WINDHAM: | ||
| 231 | smscore_gpio_set_level(coredev, | ||
| 232 | board->board_cfg.led1, 0); | ||
| 233 | break; | ||
| 234 | } | ||
| 235 | break; /* BOARD_EVENT_FE_UNLOCK */ | 145 | break; /* BOARD_EVENT_FE_UNLOCK */ |
| 236 | case BOARD_EVENT_DEMOD_LOCK: | 146 | case BOARD_EVENT_DEMOD_LOCK: |
| 237 | break; /* BOARD_EVENT_DEMOD_LOCK */ | 147 | break; /* BOARD_EVENT_DEMOD_LOCK */ |
| @@ -248,20 +158,8 @@ int sms_board_event(struct smscore_device_t *coredev, | |||
| 248 | case BOARD_EVENT_RECEPTION_LOST_0: | 158 | case BOARD_EVENT_RECEPTION_LOST_0: |
| 249 | break; /* BOARD_EVENT_RECEPTION_LOST_0 */ | 159 | break; /* BOARD_EVENT_RECEPTION_LOST_0 */ |
| 250 | case BOARD_EVENT_MULTIPLEX_OK: | 160 | case BOARD_EVENT_MULTIPLEX_OK: |
| 251 | switch (board_id) { | ||
| 252 | case SMS1XXX_BOARD_HAUPPAUGE_WINDHAM: | ||
| 253 | smscore_gpio_set_level(coredev, | ||
| 254 | board->board_cfg.led1, 1); | ||
| 255 | break; | ||
| 256 | } | ||
| 257 | break; /* BOARD_EVENT_MULTIPLEX_OK */ | 161 | break; /* BOARD_EVENT_MULTIPLEX_OK */ |
| 258 | case BOARD_EVENT_MULTIPLEX_ERRORS: | 162 | case BOARD_EVENT_MULTIPLEX_ERRORS: |
| 259 | switch (board_id) { | ||
| 260 | case SMS1XXX_BOARD_HAUPPAUGE_WINDHAM: | ||
| 261 | smscore_gpio_set_level(coredev, | ||
| 262 | board->board_cfg.led1, 0); | ||
| 263 | break; | ||
| 264 | } | ||
| 265 | break; /* BOARD_EVENT_MULTIPLEX_ERRORS */ | 163 | break; /* BOARD_EVENT_MULTIPLEX_ERRORS */ |
| 266 | 164 | ||
| 267 | default: | 165 | default: |
diff --git a/drivers/media/dvb/siano/smscoreapi.c b/drivers/media/dvb/siano/smscoreapi.c index a246903c3341..bd9ab9d0d12a 100644 --- a/drivers/media/dvb/siano/smscoreapi.c +++ b/drivers/media/dvb/siano/smscoreapi.c | |||
| @@ -816,7 +816,7 @@ int smscore_set_device_mode(struct smscore_device_t *coredev, int mode) | |||
| 816 | 816 | ||
| 817 | sms_debug("set device mode to %d", mode); | 817 | sms_debug("set device mode to %d", mode); |
| 818 | if (coredev->device_flags & SMS_DEVICE_FAMILY2) { | 818 | if (coredev->device_flags & SMS_DEVICE_FAMILY2) { |
| 819 | if (mode < DEVICE_MODE_DVBT || mode > DEVICE_MODE_RAW_TUNER) { | 819 | if (mode < DEVICE_MODE_DVBT || mode >= DEVICE_MODE_RAW_TUNER) { |
| 820 | sms_err("invalid mode specified %d", mode); | 820 | sms_err("invalid mode specified %d", mode); |
| 821 | return -EINVAL; | 821 | return -EINVAL; |
| 822 | } | 822 | } |
diff --git a/drivers/media/video/Kconfig b/drivers/media/video/Kconfig index 84b6fc15519d..dcf9fa9264bb 100644 --- a/drivers/media/video/Kconfig +++ b/drivers/media/video/Kconfig | |||
| @@ -920,6 +920,8 @@ source "drivers/media/video/pwc/Kconfig" | |||
| 920 | config USB_ZR364XX | 920 | config USB_ZR364XX |
| 921 | tristate "USB ZR364XX Camera support" | 921 | tristate "USB ZR364XX Camera support" |
| 922 | depends on VIDEO_V4L2 | 922 | depends on VIDEO_V4L2 |
| 923 | select VIDEOBUF_GEN | ||
| 924 | select VIDEOBUF_VMALLOC | ||
| 923 | ---help--- | 925 | ---help--- |
| 924 | Say Y here if you want to connect this type of camera to your | 926 | Say Y here if you want to connect this type of camera to your |
| 925 | computer's USB port. | 927 | computer's USB port. |
diff --git a/drivers/media/video/bt8xx/bttv-cards.c b/drivers/media/video/bt8xx/bttv-cards.c index fdb4adff3d28..ca6558c394be 100644 --- a/drivers/media/video/bt8xx/bttv-cards.c +++ b/drivers/media/video/bt8xx/bttv-cards.c | |||
| @@ -3324,8 +3324,6 @@ void __devinit bttv_init_card1(struct bttv *btv) | |||
| 3324 | /* initialization part two -- after registering i2c bus */ | 3324 | /* initialization part two -- after registering i2c bus */ |
| 3325 | void __devinit bttv_init_card2(struct bttv *btv) | 3325 | void __devinit bttv_init_card2(struct bttv *btv) |
| 3326 | { | 3326 | { |
| 3327 | int addr=ADDR_UNSET; | ||
| 3328 | |||
| 3329 | btv->tuner_type = UNSET; | 3327 | btv->tuner_type = UNSET; |
| 3330 | 3328 | ||
| 3331 | if (BTTV_BOARD_UNKNOWN == btv->c.type) { | 3329 | if (BTTV_BOARD_UNKNOWN == btv->c.type) { |
| @@ -3470,9 +3468,6 @@ void __devinit bttv_init_card2(struct bttv *btv) | |||
| 3470 | btv->pll.pll_current = -1; | 3468 | btv->pll.pll_current = -1; |
| 3471 | 3469 | ||
| 3472 | /* tuner configuration (from card list / autodetect / insmod option) */ | 3470 | /* tuner configuration (from card list / autodetect / insmod option) */ |
| 3473 | if (ADDR_UNSET != bttv_tvcards[btv->c.type].tuner_addr) | ||
| 3474 | addr = bttv_tvcards[btv->c.type].tuner_addr; | ||
| 3475 | |||
| 3476 | if (UNSET != bttv_tvcards[btv->c.type].tuner_type) | 3471 | if (UNSET != bttv_tvcards[btv->c.type].tuner_type) |
| 3477 | if (UNSET == btv->tuner_type) | 3472 | if (UNSET == btv->tuner_type) |
| 3478 | btv->tuner_type = bttv_tvcards[btv->c.type].tuner_type; | 3473 | btv->tuner_type = bttv_tvcards[btv->c.type].tuner_type; |
| @@ -3496,40 +3491,6 @@ void __devinit bttv_init_card2(struct bttv *btv) | |||
| 3496 | if (UNSET == btv->tuner_type) | 3491 | if (UNSET == btv->tuner_type) |
| 3497 | btv->tuner_type = TUNER_ABSENT; | 3492 | btv->tuner_type = TUNER_ABSENT; |
| 3498 | 3493 | ||
| 3499 | if (btv->tuner_type != TUNER_ABSENT) { | ||
| 3500 | struct tuner_setup tun_setup; | ||
| 3501 | |||
| 3502 | /* Load tuner module before issuing tuner config call! */ | ||
| 3503 | if (bttv_tvcards[btv->c.type].has_radio) | ||
| 3504 | v4l2_i2c_new_probed_subdev(&btv->c.v4l2_dev, | ||
| 3505 | &btv->c.i2c_adap, "tuner", "tuner", | ||
| 3506 | v4l2_i2c_tuner_addrs(ADDRS_RADIO)); | ||
| 3507 | v4l2_i2c_new_probed_subdev(&btv->c.v4l2_dev, | ||
| 3508 | &btv->c.i2c_adap, "tuner", "tuner", | ||
| 3509 | v4l2_i2c_tuner_addrs(ADDRS_DEMOD)); | ||
| 3510 | v4l2_i2c_new_probed_subdev(&btv->c.v4l2_dev, | ||
| 3511 | &btv->c.i2c_adap, "tuner", "tuner", | ||
| 3512 | v4l2_i2c_tuner_addrs(ADDRS_TV_WITH_DEMOD)); | ||
| 3513 | |||
| 3514 | tun_setup.mode_mask = T_ANALOG_TV | T_DIGITAL_TV; | ||
| 3515 | tun_setup.type = btv->tuner_type; | ||
| 3516 | tun_setup.addr = addr; | ||
| 3517 | |||
| 3518 | if (bttv_tvcards[btv->c.type].has_radio) | ||
| 3519 | tun_setup.mode_mask |= T_RADIO; | ||
| 3520 | |||
| 3521 | bttv_call_all(btv, tuner, s_type_addr, &tun_setup); | ||
| 3522 | } | ||
| 3523 | |||
| 3524 | if (btv->tda9887_conf) { | ||
| 3525 | struct v4l2_priv_tun_config tda9887_cfg; | ||
| 3526 | |||
| 3527 | tda9887_cfg.tuner = TUNER_TDA9887; | ||
| 3528 | tda9887_cfg.priv = &btv->tda9887_conf; | ||
| 3529 | |||
| 3530 | bttv_call_all(btv, tuner, s_config, &tda9887_cfg); | ||
| 3531 | } | ||
| 3532 | |||
| 3533 | btv->dig = bttv_tvcards[btv->c.type].has_dig_in ? | 3494 | btv->dig = bttv_tvcards[btv->c.type].has_dig_in ? |
| 3534 | bttv_tvcards[btv->c.type].video_inputs - 1 : UNSET; | 3495 | bttv_tvcards[btv->c.type].video_inputs - 1 : UNSET; |
| 3535 | btv->svhs = bttv_tvcards[btv->c.type].svhs == NO_SVHS ? | 3496 | btv->svhs = bttv_tvcards[btv->c.type].svhs == NO_SVHS ? |
| @@ -3540,15 +3501,15 @@ void __devinit bttv_init_card2(struct bttv *btv) | |||
| 3540 | btv->has_remote = remote[btv->c.nr]; | 3501 | btv->has_remote = remote[btv->c.nr]; |
| 3541 | 3502 | ||
| 3542 | if (bttv_tvcards[btv->c.type].has_radio) | 3503 | if (bttv_tvcards[btv->c.type].has_radio) |
| 3543 | btv->has_radio=1; | 3504 | btv->has_radio = 1; |
| 3544 | if (bttv_tvcards[btv->c.type].has_remote) | 3505 | if (bttv_tvcards[btv->c.type].has_remote) |
| 3545 | btv->has_remote=1; | 3506 | btv->has_remote = 1; |
| 3546 | if (!bttv_tvcards[btv->c.type].no_gpioirq) | 3507 | if (!bttv_tvcards[btv->c.type].no_gpioirq) |
| 3547 | btv->gpioirq=1; | 3508 | btv->gpioirq = 1; |
| 3548 | if (bttv_tvcards[btv->c.type].volume_gpio) | 3509 | if (bttv_tvcards[btv->c.type].volume_gpio) |
| 3549 | btv->volume_gpio=bttv_tvcards[btv->c.type].volume_gpio; | 3510 | btv->volume_gpio = bttv_tvcards[btv->c.type].volume_gpio; |
| 3550 | if (bttv_tvcards[btv->c.type].audio_mode_gpio) | 3511 | if (bttv_tvcards[btv->c.type].audio_mode_gpio) |
| 3551 | btv->audio_mode_gpio=bttv_tvcards[btv->c.type].audio_mode_gpio; | 3512 | btv->audio_mode_gpio = bttv_tvcards[btv->c.type].audio_mode_gpio; |
| 3552 | 3513 | ||
| 3553 | if (btv->tuner_type == TUNER_ABSENT) | 3514 | if (btv->tuner_type == TUNER_ABSENT) |
| 3554 | return; /* no tuner or related drivers to load */ | 3515 | return; /* no tuner or related drivers to load */ |
| @@ -3666,6 +3627,49 @@ no_audio: | |||
| 3666 | } | 3627 | } |
| 3667 | 3628 | ||
| 3668 | 3629 | ||
| 3630 | /* initialize the tuner */ | ||
| 3631 | void __devinit bttv_init_tuner(struct bttv *btv) | ||
| 3632 | { | ||
| 3633 | int addr = ADDR_UNSET; | ||
| 3634 | |||
| 3635 | if (ADDR_UNSET != bttv_tvcards[btv->c.type].tuner_addr) | ||
| 3636 | addr = bttv_tvcards[btv->c.type].tuner_addr; | ||
| 3637 | |||
| 3638 | if (btv->tuner_type != TUNER_ABSENT) { | ||
| 3639 | struct tuner_setup tun_setup; | ||
| 3640 | |||
| 3641 | /* Load tuner module before issuing tuner config call! */ | ||
| 3642 | if (bttv_tvcards[btv->c.type].has_radio) | ||
| 3643 | v4l2_i2c_new_probed_subdev(&btv->c.v4l2_dev, | ||
| 3644 | &btv->c.i2c_adap, "tuner", "tuner", | ||
| 3645 | v4l2_i2c_tuner_addrs(ADDRS_RADIO)); | ||
| 3646 | v4l2_i2c_new_probed_subdev(&btv->c.v4l2_dev, | ||
| 3647 | &btv->c.i2c_adap, "tuner", "tuner", | ||
| 3648 | v4l2_i2c_tuner_addrs(ADDRS_DEMOD)); | ||
| 3649 | v4l2_i2c_new_probed_subdev(&btv->c.v4l2_dev, | ||
| 3650 | &btv->c.i2c_adap, "tuner", "tuner", | ||
| 3651 | v4l2_i2c_tuner_addrs(ADDRS_TV_WITH_DEMOD)); | ||
| 3652 | |||
| 3653 | tun_setup.mode_mask = T_ANALOG_TV | T_DIGITAL_TV; | ||
| 3654 | tun_setup.type = btv->tuner_type; | ||
| 3655 | tun_setup.addr = addr; | ||
| 3656 | |||
| 3657 | if (bttv_tvcards[btv->c.type].has_radio) | ||
| 3658 | tun_setup.mode_mask |= T_RADIO; | ||
| 3659 | |||
| 3660 | bttv_call_all(btv, tuner, s_type_addr, &tun_setup); | ||
| 3661 | } | ||
| 3662 | |||
| 3663 | if (btv->tda9887_conf) { | ||
| 3664 | struct v4l2_priv_tun_config tda9887_cfg; | ||
| 3665 | |||
| 3666 | tda9887_cfg.tuner = TUNER_TDA9887; | ||
| 3667 | tda9887_cfg.priv = &btv->tda9887_conf; | ||
| 3668 | |||
| 3669 | bttv_call_all(btv, tuner, s_config, &tda9887_cfg); | ||
| 3670 | } | ||
| 3671 | } | ||
| 3672 | |||
| 3669 | /* ----------------------------------------------------------------------- */ | 3673 | /* ----------------------------------------------------------------------- */ |
| 3670 | 3674 | ||
| 3671 | static void modtec_eeprom(struct bttv *btv) | 3675 | static void modtec_eeprom(struct bttv *btv) |
diff --git a/drivers/media/video/bt8xx/bttv-driver.c b/drivers/media/video/bt8xx/bttv-driver.c index d147d29bb0d3..8cc6dd28d6a7 100644 --- a/drivers/media/video/bt8xx/bttv-driver.c +++ b/drivers/media/video/bt8xx/bttv-driver.c | |||
| @@ -4419,6 +4419,7 @@ static int __devinit bttv_probe(struct pci_dev *dev, | |||
| 4419 | 4419 | ||
| 4420 | /* some card-specific stuff (needs working i2c) */ | 4420 | /* some card-specific stuff (needs working i2c) */ |
| 4421 | bttv_init_card2(btv); | 4421 | bttv_init_card2(btv); |
| 4422 | bttv_init_tuner(btv); | ||
| 4422 | init_irqreg(btv); | 4423 | init_irqreg(btv); |
| 4423 | 4424 | ||
| 4424 | /* register video4linux + input */ | 4425 | /* register video4linux + input */ |
diff --git a/drivers/media/video/bt8xx/bttv.h b/drivers/media/video/bt8xx/bttv.h index 3d36daf206f3..3ec2402c6b4a 100644 --- a/drivers/media/video/bt8xx/bttv.h +++ b/drivers/media/video/bt8xx/bttv.h | |||
| @@ -283,6 +283,7 @@ extern struct tvcard bttv_tvcards[]; | |||
| 283 | extern void bttv_idcard(struct bttv *btv); | 283 | extern void bttv_idcard(struct bttv *btv); |
| 284 | extern void bttv_init_card1(struct bttv *btv); | 284 | extern void bttv_init_card1(struct bttv *btv); |
| 285 | extern void bttv_init_card2(struct bttv *btv); | 285 | extern void bttv_init_card2(struct bttv *btv); |
| 286 | extern void bttv_init_tuner(struct bttv *btv); | ||
| 286 | 287 | ||
| 287 | /* card-specific funtions */ | 288 | /* card-specific funtions */ |
| 288 | extern void tea5757_set_freq(struct bttv *btv, unsigned short freq); | 289 | extern void tea5757_set_freq(struct bttv *btv, unsigned short freq); |
diff --git a/drivers/media/video/bw-qcam.c b/drivers/media/video/bw-qcam.c index 10dbd4a11b30..9e39bc5f7b00 100644 --- a/drivers/media/video/bw-qcam.c +++ b/drivers/media/video/bw-qcam.c | |||
| @@ -992,7 +992,7 @@ static int accept_bwqcam(struct parport *port) | |||
| 992 | 992 | ||
| 993 | if (parport[0] && strncmp(parport[0], "auto", 4) != 0) { | 993 | if (parport[0] && strncmp(parport[0], "auto", 4) != 0) { |
| 994 | /* user gave parport parameters */ | 994 | /* user gave parport parameters */ |
| 995 | for(n=0; parport[n] && n<MAX_CAMS; n++){ | 995 | for (n = 0; n < MAX_CAMS && parport[n]; n++) { |
| 996 | char *ep; | 996 | char *ep; |
| 997 | unsigned long r; | 997 | unsigned long r; |
| 998 | r = simple_strtoul(parport[n], &ep, 0); | 998 | r = simple_strtoul(parport[n], &ep, 0); |
diff --git a/drivers/media/video/cx18/cx18-controls.c b/drivers/media/video/cx18/cx18-controls.c index 5136df198338..93f0dae01350 100644 --- a/drivers/media/video/cx18/cx18-controls.c +++ b/drivers/media/video/cx18/cx18-controls.c | |||
| @@ -20,6 +20,7 @@ | |||
| 20 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA | 20 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA |
| 21 | * 02111-1307 USA | 21 | * 02111-1307 USA |
| 22 | */ | 22 | */ |
| 23 | #include <linux/kernel.h> | ||
| 23 | 24 | ||
| 24 | #include "cx18-driver.h" | 25 | #include "cx18-driver.h" |
| 25 | #include "cx18-cards.h" | 26 | #include "cx18-cards.h" |
| @@ -317,7 +318,7 @@ int cx18_s_ext_ctrls(struct file *file, void *fh, struct v4l2_ext_controls *c) | |||
| 317 | idx = p.audio_properties & 0x03; | 318 | idx = p.audio_properties & 0x03; |
| 318 | /* The audio clock of the digitizer must match the codec sample | 319 | /* The audio clock of the digitizer must match the codec sample |
| 319 | rate otherwise you get some very strange effects. */ | 320 | rate otherwise you get some very strange effects. */ |
| 320 | if (idx < sizeof(freqs)) | 321 | if (idx < ARRAY_SIZE(freqs)) |
| 321 | cx18_call_all(cx, audio, s_clock_freq, freqs[idx]); | 322 | cx18_call_all(cx, audio, s_clock_freq, freqs[idx]); |
| 322 | return err; | 323 | return err; |
| 323 | } | 324 | } |
diff --git a/drivers/media/video/cx23885/cx23885-417.c b/drivers/media/video/cx23885/cx23885-417.c index 428f0c45e6b7..1a1048b18f70 100644 --- a/drivers/media/video/cx23885/cx23885-417.c +++ b/drivers/media/video/cx23885/cx23885-417.c | |||
| @@ -58,7 +58,8 @@ MODULE_PARM_DESC(v4l_debug, "enable V4L debug messages"); | |||
| 58 | 58 | ||
| 59 | #define dprintk(level, fmt, arg...)\ | 59 | #define dprintk(level, fmt, arg...)\ |
| 60 | do { if (v4l_debug >= level) \ | 60 | do { if (v4l_debug >= level) \ |
| 61 | printk(KERN_DEBUG "%s: " fmt, dev->name , ## arg);\ | 61 | printk(KERN_DEBUG "%s: " fmt, \ |
| 62 | (dev) ? dev->name : "cx23885[?]", ## arg); \ | ||
| 62 | } while (0) | 63 | } while (0) |
| 63 | 64 | ||
| 64 | static struct cx23885_tvnorm cx23885_tvnorms[] = { | 65 | static struct cx23885_tvnorm cx23885_tvnorms[] = { |
| @@ -1677,6 +1678,7 @@ static struct v4l2_file_operations mpeg_fops = { | |||
| 1677 | .read = mpeg_read, | 1678 | .read = mpeg_read, |
| 1678 | .poll = mpeg_poll, | 1679 | .poll = mpeg_poll, |
| 1679 | .mmap = mpeg_mmap, | 1680 | .mmap = mpeg_mmap, |
| 1681 | .ioctl = video_ioctl2, | ||
| 1680 | }; | 1682 | }; |
| 1681 | 1683 | ||
| 1682 | static const struct v4l2_ioctl_ops mpeg_ioctl_ops = { | 1684 | static const struct v4l2_ioctl_ops mpeg_ioctl_ops = { |
| @@ -1713,6 +1715,8 @@ static struct video_device cx23885_mpeg_template = { | |||
| 1713 | .fops = &mpeg_fops, | 1715 | .fops = &mpeg_fops, |
| 1714 | .ioctl_ops = &mpeg_ioctl_ops, | 1716 | .ioctl_ops = &mpeg_ioctl_ops, |
| 1715 | .minor = -1, | 1717 | .minor = -1, |
| 1718 | .tvnorms = CX23885_NORMS, | ||
| 1719 | .current_norm = V4L2_STD_NTSC_M, | ||
| 1716 | }; | 1720 | }; |
| 1717 | 1721 | ||
| 1718 | void cx23885_417_unregister(struct cx23885_dev *dev) | 1722 | void cx23885_417_unregister(struct cx23885_dev *dev) |
diff --git a/drivers/media/video/cx88/cx88-cards.c b/drivers/media/video/cx88/cx88-cards.c index a5cc1c1fc2d6..39465301ec94 100644 --- a/drivers/media/video/cx88/cx88-cards.c +++ b/drivers/media/video/cx88/cx88-cards.c | |||
| @@ -3003,6 +3003,14 @@ void cx88_setup_xc3028(struct cx88_core *core, struct xc2028_ctrl *ctl) | |||
| 3003 | case CX88_BOARD_DVICO_FUSIONHDTV_5_PCI_NANO: | 3003 | case CX88_BOARD_DVICO_FUSIONHDTV_5_PCI_NANO: |
| 3004 | ctl->demod = XC3028_FE_OREN538; | 3004 | ctl->demod = XC3028_FE_OREN538; |
| 3005 | break; | 3005 | break; |
| 3006 | case CX88_BOARD_GENIATECH_X8000_MT: | ||
| 3007 | /* FIXME: For this board, the xc3028 never recovers after being | ||
| 3008 | powered down (the reset GPIO probably is not set properly). | ||
| 3009 | We don't have access to the hardware so we cannot determine | ||
| 3010 | which GPIO is used for xc3028, so just disable power xc3028 | ||
| 3011 | power management for now */ | ||
| 3012 | ctl->disable_power_mgmt = 1; | ||
| 3013 | break; | ||
| 3006 | case CX88_BOARD_WINFAST_TV2000_XP_GLOBAL: | 3014 | case CX88_BOARD_WINFAST_TV2000_XP_GLOBAL: |
| 3007 | case CX88_BOARD_PROLINK_PV_GLOBAL_XTREME: | 3015 | case CX88_BOARD_PROLINK_PV_GLOBAL_XTREME: |
| 3008 | case CX88_BOARD_PROLINK_PV_8000GT: | 3016 | case CX88_BOARD_PROLINK_PV_8000GT: |
diff --git a/drivers/media/video/cx88/cx88-dvb.c b/drivers/media/video/cx88/cx88-dvb.c index c44e87600219..e237b507659b 100644 --- a/drivers/media/video/cx88/cx88-dvb.c +++ b/drivers/media/video/cx88/cx88-dvb.c | |||
| @@ -501,6 +501,7 @@ static struct zl10353_config cx88_pinnacle_hybrid_pctv = { | |||
| 501 | static struct zl10353_config cx88_geniatech_x8000_mt = { | 501 | static struct zl10353_config cx88_geniatech_x8000_mt = { |
| 502 | .demod_address = (0x1e >> 1), | 502 | .demod_address = (0x1e >> 1), |
| 503 | .no_tuner = 1, | 503 | .no_tuner = 1, |
| 504 | .disable_i2c_gate_ctrl = 1, | ||
| 504 | }; | 505 | }; |
| 505 | 506 | ||
| 506 | static struct s5h1411_config dvico_fusionhdtv7_config = { | 507 | static struct s5h1411_config dvico_fusionhdtv7_config = { |
diff --git a/drivers/media/video/cx88/cx88-mpeg.c b/drivers/media/video/cx88/cx88-mpeg.c index da4e3912cd37..7172dcf2a4fa 100644 --- a/drivers/media/video/cx88/cx88-mpeg.c +++ b/drivers/media/video/cx88/cx88-mpeg.c | |||
| @@ -116,6 +116,10 @@ static int cx8802_start_dma(struct cx8802_dev *dev, | |||
| 116 | udelay(100); | 116 | udelay(100); |
| 117 | break; | 117 | break; |
| 118 | case CX88_BOARD_HAUPPAUGE_HVR1300: | 118 | case CX88_BOARD_HAUPPAUGE_HVR1300: |
| 119 | /* Enable MPEG parallel IO and video signal pins */ | ||
| 120 | cx_write(MO_PINMUX_IO, 0x88); | ||
| 121 | cx_write(TS_SOP_STAT, 0); | ||
| 122 | cx_write(TS_VALERR_CNTRL, 0); | ||
| 119 | break; | 123 | break; |
| 120 | case CX88_BOARD_PINNACLE_PCTV_HD_800i: | 124 | case CX88_BOARD_PINNACLE_PCTV_HD_800i: |
| 121 | /* Enable MPEG parallel IO and video signal pins */ | 125 | /* Enable MPEG parallel IO and video signal pins */ |
diff --git a/drivers/media/video/em28xx/em28xx-cards.c b/drivers/media/video/em28xx/em28xx-cards.c index ebd24a25fb85..ed281f565945 100644 --- a/drivers/media/video/em28xx/em28xx-cards.c +++ b/drivers/media/video/em28xx/em28xx-cards.c | |||
| @@ -58,8 +58,6 @@ static unsigned int card[] = {[0 ... (EM28XX_MAXBOARDS - 1)] = UNSET }; | |||
| 58 | module_param_array(card, int, NULL, 0444); | 58 | module_param_array(card, int, NULL, 0444); |
| 59 | MODULE_PARM_DESC(card, "card type"); | 59 | MODULE_PARM_DESC(card, "card type"); |
| 60 | 60 | ||
| 61 | #define MT9V011_VERSION 0x8243 | ||
| 62 | |||
| 63 | /* Bitmask marking allocated devices from 0 to EM28XX_MAXBOARDS */ | 61 | /* Bitmask marking allocated devices from 0 to EM28XX_MAXBOARDS */ |
| 64 | static unsigned long em28xx_devused; | 62 | static unsigned long em28xx_devused; |
| 65 | 63 | ||
| @@ -159,6 +157,20 @@ static struct em28xx_reg_seq evga_indtube_digital[] = { | |||
| 159 | { -1, -1, -1, -1}, | 157 | { -1, -1, -1, -1}, |
| 160 | }; | 158 | }; |
| 161 | 159 | ||
| 160 | /* Pinnacle Hybrid Pro eb1a:2881 */ | ||
| 161 | static struct em28xx_reg_seq pinnacle_hybrid_pro_analog[] = { | ||
| 162 | {EM28XX_R08_GPIO, 0xfd, ~EM_GPIO_4, 10}, | ||
| 163 | { -1, -1, -1, -1}, | ||
| 164 | }; | ||
| 165 | |||
| 166 | static struct em28xx_reg_seq pinnacle_hybrid_pro_digital[] = { | ||
| 167 | {EM28XX_R08_GPIO, 0x6e, ~EM_GPIO_4, 10}, | ||
| 168 | {EM2880_R04_GPO, 0x04, 0xff, 100},/* zl10353 reset */ | ||
| 169 | {EM2880_R04_GPO, 0x0c, 0xff, 1}, | ||
| 170 | { -1, -1, -1, -1}, | ||
| 171 | }; | ||
| 172 | |||
| 173 | |||
| 162 | /* Callback for the most boards */ | 174 | /* Callback for the most boards */ |
| 163 | static struct em28xx_reg_seq default_tuner_gpio[] = { | 175 | static struct em28xx_reg_seq default_tuner_gpio[] = { |
| 164 | {EM28XX_R08_GPIO, EM_GPIO_4, EM_GPIO_4, 10}, | 176 | {EM28XX_R08_GPIO, EM_GPIO_4, EM_GPIO_4, 10}, |
| @@ -205,13 +217,15 @@ static struct em28xx_reg_seq silvercrest_reg_seq[] = { | |||
| 205 | */ | 217 | */ |
| 206 | struct em28xx_board em28xx_boards[] = { | 218 | struct em28xx_board em28xx_boards[] = { |
| 207 | [EM2750_BOARD_UNKNOWN] = { | 219 | [EM2750_BOARD_UNKNOWN] = { |
| 208 | .name = "Unknown EM2750/EM2751 webcam grabber", | 220 | .name = "EM2710/EM2750/EM2751 webcam grabber", |
| 209 | .xclk = EM28XX_XCLK_FREQUENCY_48MHZ, | 221 | .xclk = EM28XX_XCLK_FREQUENCY_20MHZ, |
| 210 | .tuner_type = TUNER_ABSENT, /* This is a webcam */ | 222 | .tuner_type = TUNER_ABSENT, |
| 223 | .is_webcam = 1, | ||
| 211 | .input = { { | 224 | .input = { { |
| 212 | .type = EM28XX_VMUX_COMPOSITE1, | 225 | .type = EM28XX_VMUX_COMPOSITE1, |
| 213 | .vmux = 0, | 226 | .vmux = 0, |
| 214 | .amux = EM28XX_AMUX_VIDEO, | 227 | .amux = EM28XX_AMUX_VIDEO, |
| 228 | .gpio = silvercrest_reg_seq, | ||
| 215 | } }, | 229 | } }, |
| 216 | }, | 230 | }, |
| 217 | [EM2800_BOARD_UNKNOWN] = { | 231 | [EM2800_BOARD_UNKNOWN] = { |
| @@ -233,13 +247,15 @@ struct em28xx_board em28xx_boards[] = { | |||
| 233 | [EM2820_BOARD_UNKNOWN] = { | 247 | [EM2820_BOARD_UNKNOWN] = { |
| 234 | .name = "Unknown EM2750/28xx video grabber", | 248 | .name = "Unknown EM2750/28xx video grabber", |
| 235 | .tuner_type = TUNER_ABSENT, | 249 | .tuner_type = TUNER_ABSENT, |
| 250 | .is_webcam = 1, /* To enable sensor probe */ | ||
| 236 | }, | 251 | }, |
| 237 | [EM2750_BOARD_DLCW_130] = { | 252 | [EM2750_BOARD_DLCW_130] = { |
| 238 | /* Beijing Huaqi Information Digital Technology Co., Ltd */ | 253 | /* Beijing Huaqi Information Digital Technology Co., Ltd */ |
| 239 | .name = "Huaqi DLCW-130", | 254 | .name = "Huaqi DLCW-130", |
| 240 | .valid = EM28XX_BOARD_NOT_VALIDATED, | 255 | .valid = EM28XX_BOARD_NOT_VALIDATED, |
| 241 | .xclk = EM28XX_XCLK_FREQUENCY_48MHZ, | 256 | .xclk = EM28XX_XCLK_FREQUENCY_48MHZ, |
| 242 | .tuner_type = TUNER_ABSENT, /* This is a webcam */ | 257 | .tuner_type = TUNER_ABSENT, |
| 258 | .is_webcam = 1, | ||
| 243 | .input = { { | 259 | .input = { { |
| 244 | .type = EM28XX_VMUX_COMPOSITE1, | 260 | .type = EM28XX_VMUX_COMPOSITE1, |
| 245 | .vmux = 0, | 261 | .vmux = 0, |
| @@ -440,7 +456,8 @@ struct em28xx_board em28xx_boards[] = { | |||
| 440 | [EM2820_BOARD_VIDEOLOGY_20K14XUSB] = { | 456 | [EM2820_BOARD_VIDEOLOGY_20K14XUSB] = { |
| 441 | .name = "Videology 20K14XUSB USB2.0", | 457 | .name = "Videology 20K14XUSB USB2.0", |
| 442 | .valid = EM28XX_BOARD_NOT_VALIDATED, | 458 | .valid = EM28XX_BOARD_NOT_VALIDATED, |
| 443 | .tuner_type = TUNER_ABSENT, /* This is a webcam */ | 459 | .tuner_type = TUNER_ABSENT, |
| 460 | .is_webcam = 1, | ||
| 444 | .input = { { | 461 | .input = { { |
| 445 | .type = EM28XX_VMUX_COMPOSITE1, | 462 | .type = EM28XX_VMUX_COMPOSITE1, |
| 446 | .vmux = 0, | 463 | .vmux = 0, |
| @@ -450,8 +467,7 @@ struct em28xx_board em28xx_boards[] = { | |||
| 450 | [EM2820_BOARD_SILVERCREST_WEBCAM] = { | 467 | [EM2820_BOARD_SILVERCREST_WEBCAM] = { |
| 451 | .name = "Silvercrest Webcam 1.3mpix", | 468 | .name = "Silvercrest Webcam 1.3mpix", |
| 452 | .tuner_type = TUNER_ABSENT, | 469 | .tuner_type = TUNER_ABSENT, |
| 453 | .is_27xx = 1, | 470 | .is_webcam = 1, |
| 454 | .decoder = EM28XX_MT9V011, | ||
| 455 | .input = { { | 471 | .input = { { |
| 456 | .type = EM28XX_VMUX_COMPOSITE1, | 472 | .type = EM28XX_VMUX_COMPOSITE1, |
| 457 | .vmux = 0, | 473 | .vmux = 0, |
| @@ -500,7 +516,8 @@ struct em28xx_board em28xx_boards[] = { | |||
| 500 | /* Beijing Huaqi Information Digital Technology Co., Ltd */ | 516 | /* Beijing Huaqi Information Digital Technology Co., Ltd */ |
| 501 | .name = "NetGMBH Cam", | 517 | .name = "NetGMBH Cam", |
| 502 | .valid = EM28XX_BOARD_NOT_VALIDATED, | 518 | .valid = EM28XX_BOARD_NOT_VALIDATED, |
| 503 | .tuner_type = TUNER_ABSENT, /* This is a webcam */ | 519 | .tuner_type = TUNER_ABSENT, |
| 520 | .is_webcam = 1, | ||
| 504 | .input = { { | 521 | .input = { { |
| 505 | .type = EM28XX_VMUX_COMPOSITE1, | 522 | .type = EM28XX_VMUX_COMPOSITE1, |
| 506 | .vmux = 0, | 523 | .vmux = 0, |
| @@ -605,22 +622,27 @@ struct em28xx_board em28xx_boards[] = { | |||
| 605 | }, | 622 | }, |
| 606 | [EM2861_BOARD_PLEXTOR_PX_TV100U] = { | 623 | [EM2861_BOARD_PLEXTOR_PX_TV100U] = { |
| 607 | .name = "Plextor ConvertX PX-TV100U", | 624 | .name = "Plextor ConvertX PX-TV100U", |
| 608 | .valid = EM28XX_BOARD_NOT_VALIDATED, | ||
| 609 | .tuner_type = TUNER_TNF_5335MF, | 625 | .tuner_type = TUNER_TNF_5335MF, |
| 626 | .xclk = EM28XX_XCLK_I2S_MSB_TIMING | | ||
| 627 | EM28XX_XCLK_FREQUENCY_12MHZ, | ||
| 610 | .tda9887_conf = TDA9887_PRESENT, | 628 | .tda9887_conf = TDA9887_PRESENT, |
| 611 | .decoder = EM28XX_TVP5150, | 629 | .decoder = EM28XX_TVP5150, |
| 630 | .has_msp34xx = 1, | ||
| 612 | .input = { { | 631 | .input = { { |
| 613 | .type = EM28XX_VMUX_TELEVISION, | 632 | .type = EM28XX_VMUX_TELEVISION, |
| 614 | .vmux = TVP5150_COMPOSITE0, | 633 | .vmux = TVP5150_COMPOSITE0, |
| 615 | .amux = EM28XX_AMUX_LINE_IN, | 634 | .amux = EM28XX_AMUX_LINE_IN, |
| 635 | .gpio = pinnacle_hybrid_pro_analog, | ||
| 616 | }, { | 636 | }, { |
| 617 | .type = EM28XX_VMUX_COMPOSITE1, | 637 | .type = EM28XX_VMUX_COMPOSITE1, |
| 618 | .vmux = TVP5150_COMPOSITE1, | 638 | .vmux = TVP5150_COMPOSITE1, |
| 619 | .amux = EM28XX_AMUX_LINE_IN, | 639 | .amux = EM28XX_AMUX_LINE_IN, |
| 640 | .gpio = pinnacle_hybrid_pro_analog, | ||
| 620 | }, { | 641 | }, { |
| 621 | .type = EM28XX_VMUX_SVIDEO, | 642 | .type = EM28XX_VMUX_SVIDEO, |
| 622 | .vmux = TVP5150_SVIDEO, | 643 | .vmux = TVP5150_SVIDEO, |
| 623 | .amux = EM28XX_AMUX_LINE_IN, | 644 | .amux = EM28XX_AMUX_LINE_IN, |
| 645 | .gpio = pinnacle_hybrid_pro_analog, | ||
| 624 | } }, | 646 | } }, |
| 625 | }, | 647 | }, |
| 626 | 648 | ||
| @@ -1250,25 +1272,26 @@ struct em28xx_board em28xx_boards[] = { | |||
| 1250 | }, | 1272 | }, |
| 1251 | [EM2881_BOARD_PINNACLE_HYBRID_PRO] = { | 1273 | [EM2881_BOARD_PINNACLE_HYBRID_PRO] = { |
| 1252 | .name = "Pinnacle Hybrid Pro", | 1274 | .name = "Pinnacle Hybrid Pro", |
| 1253 | .valid = EM28XX_BOARD_NOT_VALIDATED, | ||
| 1254 | .tuner_type = TUNER_XC2028, | 1275 | .tuner_type = TUNER_XC2028, |
| 1255 | .tuner_gpio = default_tuner_gpio, | 1276 | .tuner_gpio = default_tuner_gpio, |
| 1256 | .decoder = EM28XX_TVP5150, | 1277 | .decoder = EM28XX_TVP5150, |
| 1278 | .has_dvb = 1, | ||
| 1279 | .dvb_gpio = pinnacle_hybrid_pro_digital, | ||
| 1257 | .input = { { | 1280 | .input = { { |
| 1258 | .type = EM28XX_VMUX_TELEVISION, | 1281 | .type = EM28XX_VMUX_TELEVISION, |
| 1259 | .vmux = TVP5150_COMPOSITE0, | 1282 | .vmux = TVP5150_COMPOSITE0, |
| 1260 | .amux = EM28XX_AMUX_VIDEO, | 1283 | .amux = EM28XX_AMUX_VIDEO, |
| 1261 | .gpio = default_analog, | 1284 | .gpio = pinnacle_hybrid_pro_analog, |
| 1262 | }, { | 1285 | }, { |
| 1263 | .type = EM28XX_VMUX_COMPOSITE1, | 1286 | .type = EM28XX_VMUX_COMPOSITE1, |
| 1264 | .vmux = TVP5150_COMPOSITE1, | 1287 | .vmux = TVP5150_COMPOSITE1, |
| 1265 | .amux = EM28XX_AMUX_LINE_IN, | 1288 | .amux = EM28XX_AMUX_LINE_IN, |
| 1266 | .gpio = default_analog, | 1289 | .gpio = pinnacle_hybrid_pro_analog, |
| 1267 | }, { | 1290 | }, { |
| 1268 | .type = EM28XX_VMUX_SVIDEO, | 1291 | .type = EM28XX_VMUX_SVIDEO, |
| 1269 | .vmux = TVP5150_SVIDEO, | 1292 | .vmux = TVP5150_SVIDEO, |
| 1270 | .amux = EM28XX_AMUX_LINE_IN, | 1293 | .amux = EM28XX_AMUX_LINE_IN, |
| 1271 | .gpio = default_analog, | 1294 | .gpio = pinnacle_hybrid_pro_analog, |
| 1272 | } }, | 1295 | } }, |
| 1273 | }, | 1296 | }, |
| 1274 | [EM2882_BOARD_PINNACLE_HYBRID_PRO] = { | 1297 | [EM2882_BOARD_PINNACLE_HYBRID_PRO] = { |
| @@ -1526,6 +1549,8 @@ struct usb_device_id em28xx_id_table[] = { | |||
| 1526 | .driver_info = EM2750_BOARD_UNKNOWN }, | 1549 | .driver_info = EM2750_BOARD_UNKNOWN }, |
| 1527 | { USB_DEVICE(0xeb1a, 0x2800), | 1550 | { USB_DEVICE(0xeb1a, 0x2800), |
| 1528 | .driver_info = EM2800_BOARD_UNKNOWN }, | 1551 | .driver_info = EM2800_BOARD_UNKNOWN }, |
| 1552 | { USB_DEVICE(0xeb1a, 0x2710), | ||
| 1553 | .driver_info = EM2820_BOARD_UNKNOWN }, | ||
| 1529 | { USB_DEVICE(0xeb1a, 0x2820), | 1554 | { USB_DEVICE(0xeb1a, 0x2820), |
| 1530 | .driver_info = EM2820_BOARD_UNKNOWN }, | 1555 | .driver_info = EM2820_BOARD_UNKNOWN }, |
| 1531 | { USB_DEVICE(0xeb1a, 0x2821), | 1556 | { USB_DEVICE(0xeb1a, 0x2821), |
| @@ -1638,6 +1663,7 @@ static struct em28xx_hash_table em28xx_eeprom_hash[] = { | |||
| 1638 | {0x966a0441, EM2880_BOARD_KWORLD_DVB_310U, TUNER_XC2028}, | 1663 | {0x966a0441, EM2880_BOARD_KWORLD_DVB_310U, TUNER_XC2028}, |
| 1639 | {0x9567eb1a, EM2880_BOARD_EMPIRE_DUAL_TV, TUNER_XC2028}, | 1664 | {0x9567eb1a, EM2880_BOARD_EMPIRE_DUAL_TV, TUNER_XC2028}, |
| 1640 | {0xcee44a99, EM2882_BOARD_EVGA_INDTUBE, TUNER_XC2028}, | 1665 | {0xcee44a99, EM2882_BOARD_EVGA_INDTUBE, TUNER_XC2028}, |
| 1666 | {0xb8846b20, EM2881_BOARD_PINNACLE_HYBRID_PRO, TUNER_XC2028}, | ||
| 1641 | }; | 1667 | }; |
| 1642 | 1668 | ||
| 1643 | /* I2C devicelist hash table for devices with generic USB IDs */ | 1669 | /* I2C devicelist hash table for devices with generic USB IDs */ |
| @@ -1704,6 +1730,32 @@ static inline void em28xx_set_model(struct em28xx *dev) | |||
| 1704 | EM28XX_I2C_FREQ_100_KHZ; | 1730 | EM28XX_I2C_FREQ_100_KHZ; |
| 1705 | } | 1731 | } |
| 1706 | 1732 | ||
| 1733 | /* FIXME: Should be replaced by a proper mt9m001 driver */ | ||
| 1734 | static int em28xx_initialize_mt9m001(struct em28xx *dev) | ||
| 1735 | { | ||
| 1736 | int i; | ||
| 1737 | unsigned char regs[][3] = { | ||
| 1738 | { 0x0d, 0x00, 0x01, }, | ||
| 1739 | { 0x0d, 0x00, 0x00, }, | ||
| 1740 | { 0x04, 0x05, 0x00, }, /* hres = 1280 */ | ||
| 1741 | { 0x03, 0x04, 0x00, }, /* vres = 1024 */ | ||
| 1742 | { 0x20, 0x11, 0x00, }, | ||
| 1743 | { 0x06, 0x00, 0x10, }, | ||
| 1744 | { 0x2b, 0x00, 0x24, }, | ||
| 1745 | { 0x2e, 0x00, 0x24, }, | ||
| 1746 | { 0x35, 0x00, 0x24, }, | ||
| 1747 | { 0x2d, 0x00, 0x20, }, | ||
| 1748 | { 0x2c, 0x00, 0x20, }, | ||
| 1749 | { 0x09, 0x0a, 0xd4, }, | ||
| 1750 | { 0x35, 0x00, 0x57, }, | ||
| 1751 | }; | ||
| 1752 | |||
| 1753 | for (i = 0; i < ARRAY_SIZE(regs); i++) | ||
| 1754 | i2c_master_send(&dev->i2c_client, ®s[i][0], 3); | ||
| 1755 | |||
| 1756 | return 0; | ||
| 1757 | } | ||
| 1758 | |||
| 1707 | /* HINT method: webcam I2C chips | 1759 | /* HINT method: webcam I2C chips |
| 1708 | * | 1760 | * |
| 1709 | * This method work for webcams with Micron sensors | 1761 | * This method work for webcams with Micron sensors |
| @@ -1716,9 +1768,7 @@ static int em28xx_hint_sensor(struct em28xx *dev) | |||
| 1716 | __be16 version_be; | 1768 | __be16 version_be; |
| 1717 | u16 version; | 1769 | u16 version; |
| 1718 | 1770 | ||
| 1719 | if (dev->model != EM2820_BOARD_UNKNOWN) | 1771 | /* Micron sensor detection */ |
| 1720 | return 0; | ||
| 1721 | |||
| 1722 | dev->i2c_client.addr = 0xba >> 1; | 1772 | dev->i2c_client.addr = 0xba >> 1; |
| 1723 | cmd = 0; | 1773 | cmd = 0; |
| 1724 | i2c_master_send(&dev->i2c_client, &cmd, 1); | 1774 | i2c_master_send(&dev->i2c_client, &cmd, 1); |
| @@ -1727,18 +1777,57 @@ static int em28xx_hint_sensor(struct em28xx *dev) | |||
| 1727 | return -EINVAL; | 1777 | return -EINVAL; |
| 1728 | 1778 | ||
| 1729 | version = be16_to_cpu(version_be); | 1779 | version = be16_to_cpu(version_be); |
| 1730 | |||
| 1731 | switch (version) { | 1780 | switch (version) { |
| 1732 | case MT9V011_VERSION: | 1781 | case 0x8232: /* mt9v011 640x480 1.3 Mpix sensor */ |
| 1782 | case 0x8243: /* mt9v011 rev B 640x480 1.3 Mpix sensor */ | ||
| 1733 | dev->model = EM2820_BOARD_SILVERCREST_WEBCAM; | 1783 | dev->model = EM2820_BOARD_SILVERCREST_WEBCAM; |
| 1784 | em28xx_set_model(dev); | ||
| 1785 | |||
| 1734 | sensor_name = "mt9v011"; | 1786 | sensor_name = "mt9v011"; |
| 1787 | dev->em28xx_sensor = EM28XX_MT9V011; | ||
| 1788 | dev->sensor_xres = 640; | ||
| 1789 | dev->sensor_yres = 480; | ||
| 1790 | /* | ||
| 1791 | * FIXME: mt9v011 uses I2S speed as xtal clk - at least with | ||
| 1792 | * the Silvercrest cam I have here for testing - for higher | ||
| 1793 | * resolutions, a high clock cause horizontal artifacts, so we | ||
| 1794 | * need to use a lower xclk frequency. | ||
| 1795 | * Yet, it would be possible to adjust xclk depending on the | ||
| 1796 | * desired resolution, since this affects directly the | ||
| 1797 | * frame rate. | ||
| 1798 | */ | ||
| 1799 | dev->board.xclk = EM28XX_XCLK_FREQUENCY_4_3MHZ; | ||
| 1800 | dev->sensor_xtal = 4300000; | ||
| 1801 | |||
| 1802 | /* probably means GRGB 16 bit bayer */ | ||
| 1803 | dev->vinmode = 0x0d; | ||
| 1804 | dev->vinctl = 0x00; | ||
| 1805 | |||
| 1806 | break; | ||
| 1807 | case 0x8431: | ||
| 1808 | dev->model = EM2750_BOARD_UNKNOWN; | ||
| 1809 | em28xx_set_model(dev); | ||
| 1810 | |||
| 1811 | sensor_name = "mt9m001"; | ||
| 1812 | dev->em28xx_sensor = EM28XX_MT9M001; | ||
| 1813 | em28xx_initialize_mt9m001(dev); | ||
| 1814 | dev->sensor_xres = 1280; | ||
| 1815 | dev->sensor_yres = 1024; | ||
| 1816 | |||
| 1817 | /* probably means BGGR 16 bit bayer */ | ||
| 1818 | dev->vinmode = 0x0c; | ||
| 1819 | dev->vinctl = 0x00; | ||
| 1820 | |||
| 1735 | break; | 1821 | break; |
| 1736 | default: | 1822 | default: |
| 1737 | printk("Unknown Sensor 0x%04x\n", be16_to_cpu(version)); | 1823 | printk("Unknown Micron Sensor 0x%04x\n", be16_to_cpu(version)); |
| 1738 | return -EINVAL; | 1824 | return -EINVAL; |
| 1739 | } | 1825 | } |
| 1740 | 1826 | ||
| 1741 | em28xx_errdev("Sensor is %s, assuming that webcam is %s\n", | 1827 | /* Setup webcam defaults */ |
| 1828 | em28xx_pre_card_setup(dev); | ||
| 1829 | |||
| 1830 | em28xx_errdev("Sensor is %s, using model %s entry.\n", | ||
| 1742 | sensor_name, em28xx_boards[dev->model].name); | 1831 | sensor_name, em28xx_boards[dev->model].name); |
| 1743 | 1832 | ||
| 1744 | return 0; | 1833 | return 0; |
| @@ -1749,63 +1838,6 @@ static int em28xx_hint_sensor(struct em28xx *dev) | |||
| 1749 | */ | 1838 | */ |
| 1750 | void em28xx_pre_card_setup(struct em28xx *dev) | 1839 | void em28xx_pre_card_setup(struct em28xx *dev) |
| 1751 | { | 1840 | { |
| 1752 | int rc; | ||
| 1753 | |||
| 1754 | em28xx_set_model(dev); | ||
| 1755 | |||
| 1756 | em28xx_info("Identified as %s (card=%d)\n", | ||
| 1757 | dev->board.name, dev->model); | ||
| 1758 | |||
| 1759 | /* Set the default GPO/GPIO for legacy devices */ | ||
| 1760 | dev->reg_gpo_num = EM2880_R04_GPO; | ||
| 1761 | dev->reg_gpio_num = EM28XX_R08_GPIO; | ||
| 1762 | |||
| 1763 | dev->wait_after_write = 5; | ||
| 1764 | |||
| 1765 | /* Based on the Chip ID, set the device configuration */ | ||
| 1766 | rc = em28xx_read_reg(dev, EM28XX_R0A_CHIPID); | ||
| 1767 | if (rc > 0) { | ||
| 1768 | dev->chip_id = rc; | ||
| 1769 | |||
| 1770 | switch (dev->chip_id) { | ||
| 1771 | case CHIP_ID_EM2750: | ||
| 1772 | em28xx_info("chip ID is em2750\n"); | ||
| 1773 | break; | ||
| 1774 | case CHIP_ID_EM2820: | ||
| 1775 | if (dev->board.is_27xx) | ||
| 1776 | em28xx_info("chip is em2710\n"); | ||
| 1777 | else | ||
| 1778 | em28xx_info("chip ID is em2820\n"); | ||
| 1779 | break; | ||
| 1780 | case CHIP_ID_EM2840: | ||
| 1781 | em28xx_info("chip ID is em2840\n"); | ||
| 1782 | break; | ||
| 1783 | case CHIP_ID_EM2860: | ||
| 1784 | em28xx_info("chip ID is em2860\n"); | ||
| 1785 | break; | ||
| 1786 | case CHIP_ID_EM2870: | ||
| 1787 | em28xx_info("chip ID is em2870\n"); | ||
| 1788 | dev->wait_after_write = 0; | ||
| 1789 | break; | ||
| 1790 | case CHIP_ID_EM2874: | ||
| 1791 | em28xx_info("chip ID is em2874\n"); | ||
| 1792 | dev->reg_gpio_num = EM2874_R80_GPIO; | ||
| 1793 | dev->wait_after_write = 0; | ||
| 1794 | break; | ||
| 1795 | case CHIP_ID_EM2883: | ||
| 1796 | em28xx_info("chip ID is em2882/em2883\n"); | ||
| 1797 | dev->wait_after_write = 0; | ||
| 1798 | break; | ||
| 1799 | default: | ||
| 1800 | em28xx_info("em28xx chip ID = %d\n", dev->chip_id); | ||
| 1801 | } | ||
| 1802 | } | ||
| 1803 | |||
| 1804 | /* Prepopulate cached GPO register content */ | ||
| 1805 | rc = em28xx_read_reg(dev, dev->reg_gpo_num); | ||
| 1806 | if (rc >= 0) | ||
| 1807 | dev->reg_gpo = rc; | ||
| 1808 | |||
| 1809 | /* Set the initial XCLK and I2C clock values based on the board | 1841 | /* Set the initial XCLK and I2C clock values based on the board |
| 1810 | definition */ | 1842 | definition */ |
| 1811 | em28xx_write_reg(dev, EM28XX_R0F_XCLK, dev->board.xclk & 0x7f); | 1843 | em28xx_write_reg(dev, EM28XX_R0F_XCLK, dev->board.xclk & 0x7f); |
| @@ -1815,9 +1847,8 @@ void em28xx_pre_card_setup(struct em28xx *dev) | |||
| 1815 | /* request some modules */ | 1847 | /* request some modules */ |
| 1816 | switch (dev->model) { | 1848 | switch (dev->model) { |
| 1817 | case EM2861_BOARD_PLEXTOR_PX_TV100U: | 1849 | case EM2861_BOARD_PLEXTOR_PX_TV100U: |
| 1818 | /* FIXME guess */ | 1850 | /* Sets the msp34xx I2S speed */ |
| 1819 | /* Turn on analog audio output */ | 1851 | dev->i2s_speed = 2048000; |
| 1820 | em28xx_write_reg(dev, EM28XX_R08_GPIO, 0xfd); | ||
| 1821 | break; | 1852 | break; |
| 1822 | case EM2861_BOARD_KWORLD_PVRTV_300U: | 1853 | case EM2861_BOARD_KWORLD_PVRTV_300U: |
| 1823 | case EM2880_BOARD_KWORLD_DVB_305U: | 1854 | case EM2880_BOARD_KWORLD_DVB_305U: |
| @@ -1929,6 +1960,7 @@ static void em28xx_setup_xc3028(struct em28xx *dev, struct xc2028_ctrl *ctl) | |||
| 1929 | ctl->demod = XC3028_FE_ZARLINK456; | 1960 | ctl->demod = XC3028_FE_ZARLINK456; |
| 1930 | break; | 1961 | break; |
| 1931 | case EM2880_BOARD_TERRATEC_HYBRID_XS: | 1962 | case EM2880_BOARD_TERRATEC_HYBRID_XS: |
| 1963 | case EM2881_BOARD_PINNACLE_HYBRID_PRO: | ||
| 1932 | ctl->demod = XC3028_FE_ZARLINK456; | 1964 | ctl->demod = XC3028_FE_ZARLINK456; |
| 1933 | break; | 1965 | break; |
| 1934 | case EM2880_BOARD_HAUPPAUGE_WINTV_HVR_900_R2: | 1966 | case EM2880_BOARD_HAUPPAUGE_WINTV_HVR_900_R2: |
| @@ -2154,7 +2186,20 @@ void em28xx_register_i2c_ir(struct em28xx *dev) | |||
| 2154 | 2186 | ||
| 2155 | void em28xx_card_setup(struct em28xx *dev) | 2187 | void em28xx_card_setup(struct em28xx *dev) |
| 2156 | { | 2188 | { |
| 2157 | em28xx_set_model(dev); | 2189 | /* |
| 2190 | * If the device can be a webcam, seek for a sensor. | ||
| 2191 | * If sensor is not found, then it isn't a webcam. | ||
| 2192 | */ | ||
| 2193 | if (dev->board.is_webcam) { | ||
| 2194 | if (em28xx_hint_sensor(dev) < 0) | ||
| 2195 | dev->board.is_webcam = 0; | ||
| 2196 | else | ||
| 2197 | dev->progressive = 1; | ||
| 2198 | } else | ||
| 2199 | em28xx_set_model(dev); | ||
| 2200 | |||
| 2201 | em28xx_info("Identified as %s (card=%d)\n", | ||
| 2202 | dev->board.name, dev->model); | ||
| 2158 | 2203 | ||
| 2159 | dev->tuner_type = em28xx_boards[dev->model].tuner_type; | 2204 | dev->tuner_type = em28xx_boards[dev->model].tuner_type; |
| 2160 | if (em28xx_boards[dev->model].tuner_addr) | 2205 | if (em28xx_boards[dev->model].tuner_addr) |
| @@ -2225,12 +2270,9 @@ void em28xx_card_setup(struct em28xx *dev) | |||
| 2225 | em28xx_set_mode() in em28xx_pre_card_setup() was a no-op, | 2270 | em28xx_set_mode() in em28xx_pre_card_setup() was a no-op, |
| 2226 | so make the call now so the analog GPIOs are set properly | 2271 | so make the call now so the analog GPIOs are set properly |
| 2227 | before probing the i2c bus. */ | 2272 | before probing the i2c bus. */ |
| 2273 | em28xx_gpio_set(dev, dev->board.tuner_gpio); | ||
| 2228 | em28xx_set_mode(dev, EM28XX_ANALOG_MODE); | 2274 | em28xx_set_mode(dev, EM28XX_ANALOG_MODE); |
| 2229 | break; | 2275 | break; |
| 2230 | case EM2820_BOARD_SILVERCREST_WEBCAM: | ||
| 2231 | /* FIXME: need to document the registers bellow */ | ||
| 2232 | em28xx_write_reg(dev, 0x0d, 0x42); | ||
| 2233 | em28xx_write_reg(dev, 0x13, 0x08); | ||
| 2234 | } | 2276 | } |
| 2235 | 2277 | ||
| 2236 | if (dev->board.has_snapshot_button) | 2278 | if (dev->board.has_snapshot_button) |
| @@ -2262,9 +2304,14 @@ void em28xx_card_setup(struct em28xx *dev) | |||
| 2262 | v4l2_i2c_new_probed_subdev(&dev->v4l2_dev, &dev->i2c_adap, | 2304 | v4l2_i2c_new_probed_subdev(&dev->v4l2_dev, &dev->i2c_adap, |
| 2263 | "tvp5150", "tvp5150", tvp5150_addrs); | 2305 | "tvp5150", "tvp5150", tvp5150_addrs); |
| 2264 | 2306 | ||
| 2265 | if (dev->board.decoder == EM28XX_MT9V011) | 2307 | if (dev->em28xx_sensor == EM28XX_MT9V011) { |
| 2266 | v4l2_i2c_new_probed_subdev(&dev->v4l2_dev, &dev->i2c_adap, | 2308 | struct v4l2_subdev *sd; |
| 2267 | "mt9v011", "mt9v011", mt9v011_addrs); | 2309 | |
| 2310 | sd = v4l2_i2c_new_probed_subdev(&dev->v4l2_dev, | ||
| 2311 | &dev->i2c_adap, "mt9v011", "mt9v011", mt9v011_addrs); | ||
| 2312 | v4l2_subdev_call(sd, core, s_config, 0, &dev->sensor_xtal); | ||
| 2313 | } | ||
| 2314 | |||
| 2268 | 2315 | ||
| 2269 | if (dev->board.adecoder == EM28XX_TVAUDIO) | 2316 | if (dev->board.adecoder == EM28XX_TVAUDIO) |
| 2270 | v4l2_i2c_new_subdev(&dev->v4l2_dev, &dev->i2c_adap, | 2317 | v4l2_i2c_new_subdev(&dev->v4l2_dev, &dev->i2c_adap, |
| @@ -2365,7 +2412,7 @@ static int em28xx_init_dev(struct em28xx **devhandle, struct usb_device *udev, | |||
| 2365 | int minor) | 2412 | int minor) |
| 2366 | { | 2413 | { |
| 2367 | struct em28xx *dev = *devhandle; | 2414 | struct em28xx *dev = *devhandle; |
| 2368 | int retval = -ENOMEM; | 2415 | int retval; |
| 2369 | int errCode; | 2416 | int errCode; |
| 2370 | 2417 | ||
| 2371 | dev->udev = udev; | 2418 | dev->udev = udev; |
| @@ -2382,6 +2429,58 @@ static int em28xx_init_dev(struct em28xx **devhandle, struct usb_device *udev, | |||
| 2382 | dev->em28xx_read_reg_req = em28xx_read_reg_req; | 2429 | dev->em28xx_read_reg_req = em28xx_read_reg_req; |
| 2383 | dev->board.is_em2800 = em28xx_boards[dev->model].is_em2800; | 2430 | dev->board.is_em2800 = em28xx_boards[dev->model].is_em2800; |
| 2384 | 2431 | ||
| 2432 | em28xx_set_model(dev); | ||
| 2433 | |||
| 2434 | /* Set the default GPO/GPIO for legacy devices */ | ||
| 2435 | dev->reg_gpo_num = EM2880_R04_GPO; | ||
| 2436 | dev->reg_gpio_num = EM28XX_R08_GPIO; | ||
| 2437 | |||
| 2438 | dev->wait_after_write = 5; | ||
| 2439 | |||
| 2440 | /* Based on the Chip ID, set the device configuration */ | ||
| 2441 | retval = em28xx_read_reg(dev, EM28XX_R0A_CHIPID); | ||
| 2442 | if (retval > 0) { | ||
| 2443 | dev->chip_id = retval; | ||
| 2444 | |||
| 2445 | switch (dev->chip_id) { | ||
| 2446 | case CHIP_ID_EM2710: | ||
| 2447 | em28xx_info("chip ID is em2710\n"); | ||
| 2448 | break; | ||
| 2449 | case CHIP_ID_EM2750: | ||
| 2450 | em28xx_info("chip ID is em2750\n"); | ||
| 2451 | break; | ||
| 2452 | case CHIP_ID_EM2820: | ||
| 2453 | em28xx_info("chip ID is em2820 (or em2710)\n"); | ||
| 2454 | break; | ||
| 2455 | case CHIP_ID_EM2840: | ||
| 2456 | em28xx_info("chip ID is em2840\n"); | ||
| 2457 | break; | ||
| 2458 | case CHIP_ID_EM2860: | ||
| 2459 | em28xx_info("chip ID is em2860\n"); | ||
| 2460 | break; | ||
| 2461 | case CHIP_ID_EM2870: | ||
| 2462 | em28xx_info("chip ID is em2870\n"); | ||
| 2463 | dev->wait_after_write = 0; | ||
| 2464 | break; | ||
| 2465 | case CHIP_ID_EM2874: | ||
| 2466 | em28xx_info("chip ID is em2874\n"); | ||
| 2467 | dev->reg_gpio_num = EM2874_R80_GPIO; | ||
| 2468 | dev->wait_after_write = 0; | ||
| 2469 | break; | ||
| 2470 | case CHIP_ID_EM2883: | ||
| 2471 | em28xx_info("chip ID is em2882/em2883\n"); | ||
| 2472 | dev->wait_after_write = 0; | ||
| 2473 | break; | ||
| 2474 | default: | ||
| 2475 | em28xx_info("em28xx chip ID = %d\n", dev->chip_id); | ||
| 2476 | } | ||
| 2477 | } | ||
| 2478 | |||
| 2479 | /* Prepopulate cached GPO register content */ | ||
| 2480 | retval = em28xx_read_reg(dev, dev->reg_gpo_num); | ||
| 2481 | if (retval >= 0) | ||
| 2482 | dev->reg_gpo = retval; | ||
| 2483 | |||
| 2385 | em28xx_pre_card_setup(dev); | 2484 | em28xx_pre_card_setup(dev); |
| 2386 | 2485 | ||
| 2387 | if (!dev->board.is_em2800) { | 2486 | if (!dev->board.is_em2800) { |
| @@ -2410,7 +2509,11 @@ static int em28xx_init_dev(struct em28xx **devhandle, struct usb_device *udev, | |||
| 2410 | return errCode; | 2509 | return errCode; |
| 2411 | } | 2510 | } |
| 2412 | 2511 | ||
| 2413 | em28xx_hint_sensor(dev); | 2512 | /* |
| 2513 | * Default format, used for tvp5150 or saa711x output formats | ||
| 2514 | */ | ||
| 2515 | dev->vinmode = 0x10; | ||
| 2516 | dev->vinctl = 0x11; | ||
| 2414 | 2517 | ||
| 2415 | /* Do board specific init and eeprom reading */ | 2518 | /* Do board specific init and eeprom reading */ |
| 2416 | em28xx_card_setup(dev); | 2519 | em28xx_card_setup(dev); |
diff --git a/drivers/media/video/em28xx/em28xx-core.c b/drivers/media/video/em28xx/em28xx-core.c index 079ab4d563a6..98e140b5d95e 100644 --- a/drivers/media/video/em28xx/em28xx-core.c +++ b/drivers/media/video/em28xx/em28xx-core.c | |||
| @@ -632,6 +632,9 @@ int em28xx_capture_start(struct em28xx *dev, int start) | |||
| 632 | return rc; | 632 | return rc; |
| 633 | } | 633 | } |
| 634 | 634 | ||
| 635 | if (dev->board.is_webcam) | ||
| 636 | rc = em28xx_write_reg(dev, 0x13, 0x0c); | ||
| 637 | |||
| 635 | /* enable video capture */ | 638 | /* enable video capture */ |
| 636 | rc = em28xx_write_reg(dev, 0x48, 0x00); | 639 | rc = em28xx_write_reg(dev, 0x48, 0x00); |
| 637 | 640 | ||
| @@ -648,28 +651,17 @@ int em28xx_capture_start(struct em28xx *dev, int start) | |||
| 648 | int em28xx_set_outfmt(struct em28xx *dev) | 651 | int em28xx_set_outfmt(struct em28xx *dev) |
| 649 | { | 652 | { |
| 650 | int ret; | 653 | int ret; |
| 651 | int vinmode, vinctl, outfmt; | ||
| 652 | |||
| 653 | outfmt = dev->format->reg; | ||
| 654 | |||
| 655 | if (dev->board.is_27xx) { | ||
| 656 | vinmode = 0x0d; | ||
| 657 | vinctl = 0x00; | ||
| 658 | } else { | ||
| 659 | vinmode = 0x10; | ||
| 660 | vinctl = 0x11; | ||
| 661 | } | ||
| 662 | 654 | ||
| 663 | ret = em28xx_write_reg_bits(dev, EM28XX_R27_OUTFMT, | 655 | ret = em28xx_write_reg_bits(dev, EM28XX_R27_OUTFMT, |
| 664 | outfmt | 0x20, 0xff); | 656 | dev->format->reg | 0x20, 0xff); |
| 665 | if (ret < 0) | 657 | if (ret < 0) |
| 666 | return ret; | 658 | return ret; |
| 667 | 659 | ||
| 668 | ret = em28xx_write_reg(dev, EM28XX_R10_VINMODE, vinmode); | 660 | ret = em28xx_write_reg(dev, EM28XX_R10_VINMODE, dev->vinmode); |
| 669 | if (ret < 0) | 661 | if (ret < 0) |
| 670 | return ret; | 662 | return ret; |
| 671 | 663 | ||
| 672 | return em28xx_write_reg(dev, EM28XX_R11_VINCTRL, vinctl); | 664 | return em28xx_write_reg(dev, EM28XX_R11_VINCTRL, dev->vinctl); |
| 673 | } | 665 | } |
| 674 | 666 | ||
| 675 | static int em28xx_accumulator_set(struct em28xx *dev, u8 xmin, u8 xmax, | 667 | static int em28xx_accumulator_set(struct em28xx *dev, u8 xmin, u8 xmax, |
| @@ -707,10 +699,7 @@ static int em28xx_scaler_set(struct em28xx *dev, u16 h, u16 v) | |||
| 707 | u8 mode; | 699 | u8 mode; |
| 708 | /* the em2800 scaler only supports scaling down to 50% */ | 700 | /* the em2800 scaler only supports scaling down to 50% */ |
| 709 | 701 | ||
| 710 | if (dev->board.is_27xx) { | 702 | if (dev->board.is_em2800) { |
| 711 | /* FIXME: Don't use the scaler yet */ | ||
| 712 | mode = 0; | ||
| 713 | } else if (dev->board.is_em2800) { | ||
| 714 | mode = (v ? 0x20 : 0x00) | (h ? 0x10 : 0x00); | 703 | mode = (v ? 0x20 : 0x00) | (h ? 0x10 : 0x00); |
| 715 | } else { | 704 | } else { |
| 716 | u8 buf[2]; | 705 | u8 buf[2]; |
| @@ -734,7 +723,10 @@ int em28xx_resolution_set(struct em28xx *dev) | |||
| 734 | { | 723 | { |
| 735 | int width, height; | 724 | int width, height; |
| 736 | width = norm_maxw(dev); | 725 | width = norm_maxw(dev); |
| 737 | height = norm_maxh(dev) >> 1; | 726 | height = norm_maxh(dev); |
| 727 | |||
| 728 | if (!dev->progressive) | ||
| 729 | height >>= norm_maxh(dev); | ||
| 738 | 730 | ||
| 739 | em28xx_set_outfmt(dev); | 731 | em28xx_set_outfmt(dev); |
| 740 | 732 | ||
diff --git a/drivers/media/video/em28xx/em28xx-dvb.c b/drivers/media/video/em28xx/em28xx-dvb.c index 3da97c32b8fa..d603575431b4 100644 --- a/drivers/media/video/em28xx/em28xx-dvb.c +++ b/drivers/media/video/em28xx/em28xx-dvb.c | |||
| @@ -31,6 +31,8 @@ | |||
| 31 | #include "lgdt330x.h" | 31 | #include "lgdt330x.h" |
| 32 | #include "zl10353.h" | 32 | #include "zl10353.h" |
| 33 | #include "s5h1409.h" | 33 | #include "s5h1409.h" |
| 34 | #include "mt352.h" | ||
| 35 | #include "mt352_priv.h" /* FIXME */ | ||
| 34 | 36 | ||
| 35 | MODULE_DESCRIPTION("driver for em28xx based DVB cards"); | 37 | MODULE_DESCRIPTION("driver for em28xx based DVB cards"); |
| 36 | MODULE_AUTHOR("Mauro Carvalho Chehab <mchehab@infradead.org>"); | 38 | MODULE_AUTHOR("Mauro Carvalho Chehab <mchehab@infradead.org>"); |
| @@ -243,7 +245,7 @@ static struct s5h1409_config em28xx_s5h1409_with_xc3028 = { | |||
| 243 | .mpeg_timing = S5H1409_MPEGTIMING_CONTINOUS_NONINVERTING_CLOCK | 245 | .mpeg_timing = S5H1409_MPEGTIMING_CONTINOUS_NONINVERTING_CLOCK |
| 244 | }; | 246 | }; |
| 245 | 247 | ||
| 246 | static struct zl10353_config em28xx_terratec_xs_zl10353_xc3028 = { | 248 | static struct zl10353_config em28xx_zl10353_xc3028_no_i2c_gate = { |
| 247 | .demod_address = (0x1e >> 1), | 249 | .demod_address = (0x1e >> 1), |
| 248 | .no_tuner = 1, | 250 | .no_tuner = 1, |
| 249 | .disable_i2c_gate_ctrl = 1, | 251 | .disable_i2c_gate_ctrl = 1, |
| @@ -258,6 +260,41 @@ static struct drx397xD_config em28xx_drx397xD_with_xc3028 = { | |||
| 258 | }; | 260 | }; |
| 259 | #endif | 261 | #endif |
| 260 | 262 | ||
| 263 | static int mt352_terratec_xs_init(struct dvb_frontend *fe) | ||
| 264 | { | ||
| 265 | /* Values extracted from a USB trace of the Terratec Windows driver */ | ||
| 266 | static u8 clock_config[] = { CLOCK_CTL, 0x38, 0x2c }; | ||
| 267 | static u8 reset[] = { RESET, 0x80 }; | ||
| 268 | static u8 adc_ctl_1_cfg[] = { ADC_CTL_1, 0x40 }; | ||
| 269 | static u8 agc_cfg[] = { AGC_TARGET, 0x28, 0xa0 }; | ||
| 270 | static u8 input_freq_cfg[] = { INPUT_FREQ_1, 0x31, 0xb8 }; | ||
| 271 | static u8 rs_err_cfg[] = { RS_ERR_PER_1, 0x00, 0x4d }; | ||
| 272 | static u8 capt_range_cfg[] = { CAPT_RANGE, 0x32 }; | ||
| 273 | static u8 trl_nom_cfg[] = { TRL_NOMINAL_RATE_1, 0x64, 0x00 }; | ||
| 274 | static u8 tps_given_cfg[] = { TPS_GIVEN_1, 0x40, 0x80, 0x50 }; | ||
| 275 | static u8 tuner_go[] = { TUNER_GO, 0x01}; | ||
| 276 | |||
| 277 | mt352_write(fe, clock_config, sizeof(clock_config)); | ||
| 278 | udelay(200); | ||
| 279 | mt352_write(fe, reset, sizeof(reset)); | ||
| 280 | mt352_write(fe, adc_ctl_1_cfg, sizeof(adc_ctl_1_cfg)); | ||
| 281 | mt352_write(fe, agc_cfg, sizeof(agc_cfg)); | ||
| 282 | mt352_write(fe, input_freq_cfg, sizeof(input_freq_cfg)); | ||
| 283 | mt352_write(fe, rs_err_cfg, sizeof(rs_err_cfg)); | ||
| 284 | mt352_write(fe, capt_range_cfg, sizeof(capt_range_cfg)); | ||
| 285 | mt352_write(fe, trl_nom_cfg, sizeof(trl_nom_cfg)); | ||
| 286 | mt352_write(fe, tps_given_cfg, sizeof(tps_given_cfg)); | ||
| 287 | mt352_write(fe, tuner_go, sizeof(tuner_go)); | ||
| 288 | return 0; | ||
| 289 | } | ||
| 290 | |||
| 291 | static struct mt352_config terratec_xs_mt352_cfg = { | ||
| 292 | .demod_address = (0x1e >> 1), | ||
| 293 | .no_tuner = 1, | ||
| 294 | .if2 = 45600, | ||
| 295 | .demod_init = mt352_terratec_xs_init, | ||
| 296 | }; | ||
| 297 | |||
| 261 | /* ------------------------------------------------------------------ */ | 298 | /* ------------------------------------------------------------------ */ |
| 262 | 299 | ||
| 263 | static int attach_xc3028(u8 addr, struct em28xx *dev) | 300 | static int attach_xc3028(u8 addr, struct em28xx *dev) |
| @@ -440,9 +477,7 @@ static int dvb_init(struct em28xx *dev) | |||
| 440 | goto out_free; | 477 | goto out_free; |
| 441 | } | 478 | } |
| 442 | break; | 479 | break; |
| 443 | case EM2880_BOARD_HAUPPAUGE_WINTV_HVR_900: | ||
| 444 | case EM2880_BOARD_KWORLD_DVB_310U: | 480 | case EM2880_BOARD_KWORLD_DVB_310U: |
| 445 | case EM2880_BOARD_EMPIRE_DUAL_TV: | ||
| 446 | dvb->frontend = dvb_attach(zl10353_attach, | 481 | dvb->frontend = dvb_attach(zl10353_attach, |
| 447 | &em28xx_zl10353_with_xc3028, | 482 | &em28xx_zl10353_with_xc3028, |
| 448 | &dev->i2c_adap); | 483 | &dev->i2c_adap); |
| @@ -451,20 +486,29 @@ static int dvb_init(struct em28xx *dev) | |||
| 451 | goto out_free; | 486 | goto out_free; |
| 452 | } | 487 | } |
| 453 | break; | 488 | break; |
| 489 | case EM2880_BOARD_HAUPPAUGE_WINTV_HVR_900: | ||
| 490 | case EM2880_BOARD_EMPIRE_DUAL_TV: | ||
| 491 | dvb->frontend = dvb_attach(zl10353_attach, | ||
| 492 | &em28xx_zl10353_xc3028_no_i2c_gate, | ||
| 493 | &dev->i2c_adap); | ||
| 494 | if (attach_xc3028(0x61, dev) < 0) { | ||
| 495 | result = -EINVAL; | ||
| 496 | goto out_free; | ||
| 497 | } | ||
| 498 | break; | ||
| 454 | case EM2880_BOARD_TERRATEC_HYBRID_XS: | 499 | case EM2880_BOARD_TERRATEC_HYBRID_XS: |
| 500 | case EM2881_BOARD_PINNACLE_HYBRID_PRO: | ||
| 455 | dvb->frontend = dvb_attach(zl10353_attach, | 501 | dvb->frontend = dvb_attach(zl10353_attach, |
| 456 | &em28xx_terratec_xs_zl10353_xc3028, | 502 | &em28xx_zl10353_xc3028_no_i2c_gate, |
| 457 | &dev->i2c_adap); | 503 | &dev->i2c_adap); |
| 458 | if (dvb->frontend == NULL) { | 504 | if (dvb->frontend == NULL) { |
| 459 | /* This board could have either a zl10353 or a mt352. | 505 | /* This board could have either a zl10353 or a mt352. |
| 460 | If the chip id isn't for zl10353, try mt352 */ | 506 | If the chip id isn't for zl10353, try mt352 */ |
| 461 | 507 | dvb->frontend = dvb_attach(mt352_attach, | |
| 462 | /* FIXME: make support for mt352 work */ | 508 | &terratec_xs_mt352_cfg, |
| 463 | printk(KERN_ERR "version of this board with mt352 not " | 509 | &dev->i2c_adap); |
| 464 | "currently supported\n"); | ||
| 465 | result = -EINVAL; | ||
| 466 | goto out_free; | ||
| 467 | } | 510 | } |
| 511 | |||
| 468 | if (attach_xc3028(0x61, dev) < 0) { | 512 | if (attach_xc3028(0x61, dev) < 0) { |
| 469 | result = -EINVAL; | 513 | result = -EINVAL; |
| 470 | goto out_free; | 514 | goto out_free; |
diff --git a/drivers/media/video/em28xx/em28xx-reg.h b/drivers/media/video/em28xx/em28xx-reg.h index a2676d63cfd0..6bf84bd787df 100644 --- a/drivers/media/video/em28xx/em28xx-reg.h +++ b/drivers/media/video/em28xx/em28xx-reg.h | |||
| @@ -176,7 +176,8 @@ | |||
| 176 | 176 | ||
| 177 | /* FIXME: Need to be populated with the other chip ID's */ | 177 | /* FIXME: Need to be populated with the other chip ID's */ |
| 178 | enum em28xx_chip_id { | 178 | enum em28xx_chip_id { |
| 179 | CHIP_ID_EM2820 = 18, /* Also used by em2710 */ | 179 | CHIP_ID_EM2710 = 17, |
| 180 | CHIP_ID_EM2820 = 18, /* Also used by some em2710 */ | ||
| 180 | CHIP_ID_EM2840 = 20, | 181 | CHIP_ID_EM2840 = 20, |
| 181 | CHIP_ID_EM2750 = 33, | 182 | CHIP_ID_EM2750 = 33, |
| 182 | CHIP_ID_EM2860 = 34, | 183 | CHIP_ID_EM2860 = 34, |
diff --git a/drivers/media/video/em28xx/em28xx-video.c b/drivers/media/video/em28xx/em28xx-video.c index 14316c912179..ab079d9256c4 100644 --- a/drivers/media/video/em28xx/em28xx-video.c +++ b/drivers/media/video/em28xx/em28xx-video.c | |||
| @@ -194,15 +194,24 @@ static void em28xx_copy_video(struct em28xx *dev, | |||
| 194 | startread = p; | 194 | startread = p; |
| 195 | remain = len; | 195 | remain = len; |
| 196 | 196 | ||
| 197 | /* Interlaces frame */ | 197 | if (dev->progressive) |
| 198 | if (buf->top_field) | ||
| 199 | fieldstart = outp; | 198 | fieldstart = outp; |
| 200 | else | 199 | else { |
| 201 | fieldstart = outp + bytesperline; | 200 | /* Interlaces two half frames */ |
| 201 | if (buf->top_field) | ||
| 202 | fieldstart = outp; | ||
| 203 | else | ||
| 204 | fieldstart = outp + bytesperline; | ||
| 205 | } | ||
| 202 | 206 | ||
| 203 | linesdone = dma_q->pos / bytesperline; | 207 | linesdone = dma_q->pos / bytesperline; |
| 204 | currlinedone = dma_q->pos % bytesperline; | 208 | currlinedone = dma_q->pos % bytesperline; |
| 205 | offset = linesdone * bytesperline * 2 + currlinedone; | 209 | |
| 210 | if (dev->progressive) | ||
| 211 | offset = linesdone * bytesperline + currlinedone; | ||
| 212 | else | ||
| 213 | offset = linesdone * bytesperline * 2 + currlinedone; | ||
| 214 | |||
| 206 | startwrite = fieldstart + offset; | 215 | startwrite = fieldstart + offset; |
| 207 | lencopy = bytesperline - currlinedone; | 216 | lencopy = bytesperline - currlinedone; |
| 208 | lencopy = lencopy > remain ? remain : lencopy; | 217 | lencopy = lencopy > remain ? remain : lencopy; |
| @@ -376,7 +385,7 @@ static inline int em28xx_isoc_copy(struct em28xx *dev, struct urb *urb) | |||
| 376 | em28xx_isocdbg("Video frame %d, length=%i, %s\n", p[2], | 385 | em28xx_isocdbg("Video frame %d, length=%i, %s\n", p[2], |
| 377 | len, (p[2] & 1) ? "odd" : "even"); | 386 | len, (p[2] & 1) ? "odd" : "even"); |
| 378 | 387 | ||
| 379 | if (!(p[2] & 1)) { | 388 | if (dev->progressive || !(p[2] & 1)) { |
| 380 | if (buf != NULL) | 389 | if (buf != NULL) |
| 381 | buffer_filled(dev, dma_q, buf); | 390 | buffer_filled(dev, dma_q, buf); |
| 382 | get_next_buf(dma_q, &buf); | 391 | get_next_buf(dma_q, &buf); |
| @@ -657,8 +666,8 @@ static void get_scale(struct em28xx *dev, | |||
| 657 | unsigned int width, unsigned int height, | 666 | unsigned int width, unsigned int height, |
| 658 | unsigned int *hscale, unsigned int *vscale) | 667 | unsigned int *hscale, unsigned int *vscale) |
| 659 | { | 668 | { |
| 660 | unsigned int maxw = norm_maxw(dev); | 669 | unsigned int maxw = norm_maxw(dev); |
| 661 | unsigned int maxh = norm_maxh(dev); | 670 | unsigned int maxh = norm_maxh(dev); |
| 662 | 671 | ||
| 663 | *hscale = (((unsigned long)maxw) << 12) / width - 4096L; | 672 | *hscale = (((unsigned long)maxw) << 12) / width - 4096L; |
| 664 | if (*hscale >= 0x4000) | 673 | if (*hscale >= 0x4000) |
| @@ -689,7 +698,10 @@ static int vidioc_g_fmt_vid_cap(struct file *file, void *priv, | |||
| 689 | f->fmt.pix.colorspace = V4L2_COLORSPACE_SMPTE170M; | 698 | f->fmt.pix.colorspace = V4L2_COLORSPACE_SMPTE170M; |
| 690 | 699 | ||
| 691 | /* FIXME: TOP? NONE? BOTTOM? ALTENATE? */ | 700 | /* FIXME: TOP? NONE? BOTTOM? ALTENATE? */ |
| 692 | f->fmt.pix.field = dev->interlaced ? | 701 | if (dev->progressive) |
| 702 | f->fmt.pix.field = V4L2_FIELD_NONE; | ||
| 703 | else | ||
| 704 | f->fmt.pix.field = dev->interlaced ? | ||
| 693 | V4L2_FIELD_INTERLACED : V4L2_FIELD_TOP; | 705 | V4L2_FIELD_INTERLACED : V4L2_FIELD_TOP; |
| 694 | 706 | ||
| 695 | mutex_unlock(&dev->lock); | 707 | mutex_unlock(&dev->lock); |
| @@ -726,11 +738,7 @@ static int vidioc_try_fmt_vid_cap(struct file *file, void *priv, | |||
| 726 | return -EINVAL; | 738 | return -EINVAL; |
| 727 | } | 739 | } |
| 728 | 740 | ||
| 729 | if (dev->board.is_27xx) { | 741 | if (dev->board.is_em2800) { |
| 730 | /* FIXME: This is the only supported fmt */ | ||
| 731 | width = 640; | ||
| 732 | height = 480; | ||
| 733 | } else if (dev->board.is_em2800) { | ||
| 734 | /* the em2800 can only scale down to 50% */ | 742 | /* the em2800 can only scale down to 50% */ |
| 735 | height = height > (3 * maxh / 4) ? maxh : maxh / 2; | 743 | height = height > (3 * maxh / 4) ? maxh : maxh / 2; |
| 736 | width = width > (3 * maxw / 4) ? maxw : maxw / 2; | 744 | width = width > (3 * maxw / 4) ? maxw : maxw / 2; |
| @@ -757,7 +765,11 @@ static int vidioc_try_fmt_vid_cap(struct file *file, void *priv, | |||
| 757 | f->fmt.pix.bytesperline = (dev->width * fmt->depth + 7) >> 3; | 765 | f->fmt.pix.bytesperline = (dev->width * fmt->depth + 7) >> 3; |
| 758 | f->fmt.pix.sizeimage = f->fmt.pix.bytesperline * height; | 766 | f->fmt.pix.sizeimage = f->fmt.pix.bytesperline * height; |
| 759 | f->fmt.pix.colorspace = V4L2_COLORSPACE_SMPTE170M; | 767 | f->fmt.pix.colorspace = V4L2_COLORSPACE_SMPTE170M; |
| 760 | f->fmt.pix.field = V4L2_FIELD_INTERLACED; | 768 | if (dev->progressive) |
| 769 | f->fmt.pix.field = V4L2_FIELD_NONE; | ||
| 770 | else | ||
| 771 | f->fmt.pix.field = dev->interlaced ? | ||
| 772 | V4L2_FIELD_INTERLACED : V4L2_FIELD_TOP; | ||
| 761 | 773 | ||
| 762 | return 0; | 774 | return 0; |
| 763 | } | 775 | } |
| @@ -767,12 +779,6 @@ static int em28xx_set_video_format(struct em28xx *dev, unsigned int fourcc, | |||
| 767 | { | 779 | { |
| 768 | struct em28xx_fmt *fmt; | 780 | struct em28xx_fmt *fmt; |
| 769 | 781 | ||
| 770 | /* FIXME: This is the only supported fmt */ | ||
| 771 | if (dev->board.is_27xx) { | ||
| 772 | width = 640; | ||
| 773 | height = 480; | ||
| 774 | } | ||
| 775 | |||
| 776 | fmt = format_by_fourcc(fourcc); | 782 | fmt = format_by_fourcc(fourcc); |
| 777 | if (!fmt) | 783 | if (!fmt) |
| 778 | return -EINVAL; | 784 | return -EINVAL; |
| @@ -856,6 +862,41 @@ static int vidioc_s_std(struct file *file, void *priv, v4l2_std_id *norm) | |||
| 856 | return 0; | 862 | return 0; |
| 857 | } | 863 | } |
| 858 | 864 | ||
| 865 | static int vidioc_g_parm(struct file *file, void *priv, | ||
| 866 | struct v4l2_streamparm *p) | ||
| 867 | { | ||
| 868 | struct em28xx_fh *fh = priv; | ||
| 869 | struct em28xx *dev = fh->dev; | ||
| 870 | int rc = 0; | ||
| 871 | |||
| 872 | if (p->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) | ||
| 873 | return -EINVAL; | ||
| 874 | |||
| 875 | if (dev->board.is_webcam) | ||
| 876 | rc = v4l2_device_call_until_err(&dev->v4l2_dev, 0, | ||
| 877 | video, g_parm, p); | ||
| 878 | else | ||
| 879 | v4l2_video_std_frame_period(dev->norm, | ||
| 880 | &p->parm.capture.timeperframe); | ||
| 881 | |||
| 882 | return rc; | ||
| 883 | } | ||
| 884 | |||
| 885 | static int vidioc_s_parm(struct file *file, void *priv, | ||
| 886 | struct v4l2_streamparm *p) | ||
| 887 | { | ||
| 888 | struct em28xx_fh *fh = priv; | ||
| 889 | struct em28xx *dev = fh->dev; | ||
| 890 | |||
| 891 | if (!dev->board.is_webcam) | ||
| 892 | return -EINVAL; | ||
| 893 | |||
| 894 | if (p->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) | ||
| 895 | return -EINVAL; | ||
| 896 | |||
| 897 | return v4l2_device_call_until_err(&dev->v4l2_dev, 0, video, s_parm, p); | ||
| 898 | } | ||
| 899 | |||
| 859 | static const char *iname[] = { | 900 | static const char *iname[] = { |
| 860 | [EM28XX_VMUX_COMPOSITE1] = "Composite1", | 901 | [EM28XX_VMUX_COMPOSITE1] = "Composite1", |
| 861 | [EM28XX_VMUX_COMPOSITE2] = "Composite2", | 902 | [EM28XX_VMUX_COMPOSITE2] = "Composite2", |
| @@ -1634,6 +1675,7 @@ static int em28xx_v4l2_open(struct file *filp) | |||
| 1634 | struct em28xx *dev; | 1675 | struct em28xx *dev; |
| 1635 | enum v4l2_buf_type fh_type; | 1676 | enum v4l2_buf_type fh_type; |
| 1636 | struct em28xx_fh *fh; | 1677 | struct em28xx_fh *fh; |
| 1678 | enum v4l2_field field; | ||
| 1637 | 1679 | ||
| 1638 | dev = em28xx_get_device(minor, &fh_type, &radio); | 1680 | dev = em28xx_get_device(minor, &fh_type, &radio); |
| 1639 | 1681 | ||
| @@ -1675,8 +1717,13 @@ static int em28xx_v4l2_open(struct file *filp) | |||
| 1675 | 1717 | ||
| 1676 | dev->users++; | 1718 | dev->users++; |
| 1677 | 1719 | ||
| 1720 | if (dev->progressive) | ||
| 1721 | field = V4L2_FIELD_NONE; | ||
| 1722 | else | ||
| 1723 | field = V4L2_FIELD_INTERLACED; | ||
| 1724 | |||
| 1678 | videobuf_queue_vmalloc_init(&fh->vb_vidq, &em28xx_video_qops, | 1725 | videobuf_queue_vmalloc_init(&fh->vb_vidq, &em28xx_video_qops, |
| 1679 | NULL, &dev->slock, fh->type, V4L2_FIELD_INTERLACED, | 1726 | NULL, &dev->slock, fh->type, field, |
| 1680 | sizeof(struct em28xx_buffer), fh); | 1727 | sizeof(struct em28xx_buffer), fh); |
| 1681 | 1728 | ||
| 1682 | mutex_unlock(&dev->lock); | 1729 | mutex_unlock(&dev->lock); |
| @@ -1895,6 +1942,8 @@ static const struct v4l2_ioctl_ops video_ioctl_ops = { | |||
| 1895 | .vidioc_qbuf = vidioc_qbuf, | 1942 | .vidioc_qbuf = vidioc_qbuf, |
| 1896 | .vidioc_dqbuf = vidioc_dqbuf, | 1943 | .vidioc_dqbuf = vidioc_dqbuf, |
| 1897 | .vidioc_s_std = vidioc_s_std, | 1944 | .vidioc_s_std = vidioc_s_std, |
| 1945 | .vidioc_g_parm = vidioc_g_parm, | ||
| 1946 | .vidioc_s_parm = vidioc_s_parm, | ||
| 1898 | .vidioc_enum_input = vidioc_enum_input, | 1947 | .vidioc_enum_input = vidioc_enum_input, |
| 1899 | .vidioc_g_input = vidioc_g_input, | 1948 | .vidioc_g_input = vidioc_g_input, |
| 1900 | .vidioc_s_input = vidioc_s_input, | 1949 | .vidioc_s_input = vidioc_s_input, |
diff --git a/drivers/media/video/em28xx/em28xx.h b/drivers/media/video/em28xx/em28xx.h index d90fef463764..8c2dc38bca9f 100644 --- a/drivers/media/video/em28xx/em28xx.h +++ b/drivers/media/video/em28xx/em28xx.h | |||
| @@ -358,10 +358,15 @@ struct em28xx_input { | |||
| 358 | #define INPUT(nr) (&em28xx_boards[dev->model].input[nr]) | 358 | #define INPUT(nr) (&em28xx_boards[dev->model].input[nr]) |
| 359 | 359 | ||
| 360 | enum em28xx_decoder { | 360 | enum em28xx_decoder { |
| 361 | EM28XX_NODECODER, | 361 | EM28XX_NODECODER = 0, |
| 362 | EM28XX_TVP5150, | 362 | EM28XX_TVP5150, |
| 363 | EM28XX_SAA711X, | 363 | EM28XX_SAA711X, |
| 364 | }; | ||
| 365 | |||
| 366 | enum em28xx_sensor { | ||
| 367 | EM28XX_NOSENSOR = 0, | ||
| 364 | EM28XX_MT9V011, | 368 | EM28XX_MT9V011, |
| 369 | EM28XX_MT9M001, | ||
| 365 | }; | 370 | }; |
| 366 | 371 | ||
| 367 | enum em28xx_adecoder { | 372 | enum em28xx_adecoder { |
| @@ -390,7 +395,7 @@ struct em28xx_board { | |||
| 390 | unsigned int max_range_640_480:1; | 395 | unsigned int max_range_640_480:1; |
| 391 | unsigned int has_dvb:1; | 396 | unsigned int has_dvb:1; |
| 392 | unsigned int has_snapshot_button:1; | 397 | unsigned int has_snapshot_button:1; |
| 393 | unsigned int is_27xx:1; | 398 | unsigned int is_webcam:1; |
| 394 | unsigned int valid:1; | 399 | unsigned int valid:1; |
| 395 | 400 | ||
| 396 | unsigned char xclk, i2c_speed; | 401 | unsigned char xclk, i2c_speed; |
| @@ -474,6 +479,17 @@ struct em28xx { | |||
| 474 | struct v4l2_device v4l2_dev; | 479 | struct v4l2_device v4l2_dev; |
| 475 | struct em28xx_board board; | 480 | struct em28xx_board board; |
| 476 | 481 | ||
| 482 | /* Webcam specific fields */ | ||
| 483 | enum em28xx_sensor em28xx_sensor; | ||
| 484 | int sensor_xres, sensor_yres; | ||
| 485 | int sensor_xtal; | ||
| 486 | |||
| 487 | /* Allows progressive (e. g. non-interlaced) mode */ | ||
| 488 | int progressive; | ||
| 489 | |||
| 490 | /* Vinmode/Vinctl used at the driver */ | ||
| 491 | int vinmode, vinctl; | ||
| 492 | |||
| 477 | unsigned int stream_on:1; /* Locks streams */ | 493 | unsigned int stream_on:1; /* Locks streams */ |
| 478 | unsigned int has_audio_class:1; | 494 | unsigned int has_audio_class:1; |
| 479 | unsigned int has_alsa_audio:1; | 495 | unsigned int has_alsa_audio:1; |
| @@ -754,17 +770,23 @@ static inline int em28xx_gamma_set(struct em28xx *dev, s32 val) | |||
| 754 | /*FIXME: maxw should be dependent of alt mode */ | 770 | /*FIXME: maxw should be dependent of alt mode */ |
| 755 | static inline unsigned int norm_maxw(struct em28xx *dev) | 771 | static inline unsigned int norm_maxw(struct em28xx *dev) |
| 756 | { | 772 | { |
| 773 | if (dev->board.is_webcam) | ||
| 774 | return dev->sensor_xres; | ||
| 775 | |||
| 757 | if (dev->board.max_range_640_480) | 776 | if (dev->board.max_range_640_480) |
| 758 | return 640; | 777 | return 640; |
| 759 | else | 778 | |
| 760 | return 720; | 779 | return 720; |
| 761 | } | 780 | } |
| 762 | 781 | ||
| 763 | static inline unsigned int norm_maxh(struct em28xx *dev) | 782 | static inline unsigned int norm_maxh(struct em28xx *dev) |
| 764 | { | 783 | { |
| 784 | if (dev->board.is_webcam) | ||
| 785 | return dev->sensor_yres; | ||
| 786 | |||
| 765 | if (dev->board.max_range_640_480) | 787 | if (dev->board.max_range_640_480) |
| 766 | return 480; | 788 | return 480; |
| 767 | else | 789 | |
| 768 | return (dev->norm & V4L2_STD_625_50) ? 576 : 480; | 790 | return (dev->norm & V4L2_STD_625_50) ? 576 : 480; |
| 769 | } | 791 | } |
| 770 | #endif | 792 | #endif |
diff --git a/drivers/media/video/gspca/Kconfig b/drivers/media/video/gspca/Kconfig index 578dc4ffc965..34f46f2bc040 100644 --- a/drivers/media/video/gspca/Kconfig +++ b/drivers/media/video/gspca/Kconfig | |||
| @@ -102,6 +102,22 @@ config USB_GSPCA_PAC7311 | |||
| 102 | To compile this driver as a module, choose M here: the | 102 | To compile this driver as a module, choose M here: the |
| 103 | module will be called gspca_pac7311. | 103 | module will be called gspca_pac7311. |
| 104 | 104 | ||
| 105 | config USB_GSPCA_SN9C20X | ||
| 106 | tristate "SN9C20X USB Camera Driver" | ||
| 107 | depends on VIDEO_V4L2 && USB_GSPCA | ||
| 108 | help | ||
| 109 | Say Y here if you want support for cameras based on the | ||
| 110 | sn9c20x chips (SN9C201 and SN9C202). | ||
| 111 | |||
| 112 | To compile this driver as a module, choose M here: the | ||
| 113 | module will be called gspca_sn9c20x. | ||
| 114 | |||
| 115 | config USB_GSPCA_SN9C20X_EVDEV | ||
| 116 | bool "Enable evdev support" | ||
| 117 | depends on USB_GSPCA_SN9C20X | ||
| 118 | ---help--- | ||
| 119 | Say Y here in order to enable evdev support for sn9c20x webcam button. | ||
| 120 | |||
| 105 | config USB_GSPCA_SONIXB | 121 | config USB_GSPCA_SONIXB |
| 106 | tristate "SONIX Bayer USB Camera Driver" | 122 | tristate "SONIX Bayer USB Camera Driver" |
| 107 | depends on VIDEO_V4L2 && USB_GSPCA | 123 | depends on VIDEO_V4L2 && USB_GSPCA |
diff --git a/drivers/media/video/gspca/Makefile b/drivers/media/video/gspca/Makefile index 8a6643e8eb96..f6d3b86e9ad5 100644 --- a/drivers/media/video/gspca/Makefile +++ b/drivers/media/video/gspca/Makefile | |||
| @@ -8,6 +8,7 @@ obj-$(CONFIG_USB_GSPCA_OV519) += gspca_ov519.o | |||
| 8 | obj-$(CONFIG_USB_GSPCA_OV534) += gspca_ov534.o | 8 | obj-$(CONFIG_USB_GSPCA_OV534) += gspca_ov534.o |
| 9 | obj-$(CONFIG_USB_GSPCA_PAC207) += gspca_pac207.o | 9 | obj-$(CONFIG_USB_GSPCA_PAC207) += gspca_pac207.o |
| 10 | obj-$(CONFIG_USB_GSPCA_PAC7311) += gspca_pac7311.o | 10 | obj-$(CONFIG_USB_GSPCA_PAC7311) += gspca_pac7311.o |
| 11 | obj-$(CONFIG_USB_GSPCA_SN9C20X) += gspca_sn9c20x.o | ||
| 11 | obj-$(CONFIG_USB_GSPCA_SONIXB) += gspca_sonixb.o | 12 | obj-$(CONFIG_USB_GSPCA_SONIXB) += gspca_sonixb.o |
| 12 | obj-$(CONFIG_USB_GSPCA_SONIXJ) += gspca_sonixj.o | 13 | obj-$(CONFIG_USB_GSPCA_SONIXJ) += gspca_sonixj.o |
| 13 | obj-$(CONFIG_USB_GSPCA_SPCA500) += gspca_spca500.o | 14 | obj-$(CONFIG_USB_GSPCA_SPCA500) += gspca_spca500.o |
| @@ -35,6 +36,7 @@ gspca_ov519-objs := ov519.o | |||
| 35 | gspca_ov534-objs := ov534.o | 36 | gspca_ov534-objs := ov534.o |
| 36 | gspca_pac207-objs := pac207.o | 37 | gspca_pac207-objs := pac207.o |
| 37 | gspca_pac7311-objs := pac7311.o | 38 | gspca_pac7311-objs := pac7311.o |
| 39 | gspca_sn9c20x-objs := sn9c20x.o | ||
| 38 | gspca_sonixb-objs := sonixb.o | 40 | gspca_sonixb-objs := sonixb.o |
| 39 | gspca_sonixj-objs := sonixj.o | 41 | gspca_sonixj-objs := sonixj.o |
| 40 | gspca_spca500-objs := spca500.o | 42 | gspca_spca500-objs := spca500.o |
diff --git a/drivers/media/video/gspca/conex.c b/drivers/media/video/gspca/conex.c index 219cfa6fb877..8d48ea1742c2 100644 --- a/drivers/media/video/gspca/conex.c +++ b/drivers/media/video/gspca/conex.c | |||
| @@ -846,6 +846,8 @@ static int sd_start(struct gspca_dev *gspca_dev) | |||
| 846 | 846 | ||
| 847 | /* create the JPEG header */ | 847 | /* create the JPEG header */ |
| 848 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); | 848 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); |
| 849 | if (!sd->jpeg_hdr) | ||
| 850 | return -ENOMEM; | ||
| 849 | jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width, | 851 | jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width, |
| 850 | 0x22); /* JPEG 411 */ | 852 | 0x22); /* JPEG 411 */ |
| 851 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); | 853 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); |
diff --git a/drivers/media/video/gspca/gspca.c b/drivers/media/video/gspca/gspca.c index 1e89600986c8..b8561dfb6c8c 100644 --- a/drivers/media/video/gspca/gspca.c +++ b/drivers/media/video/gspca/gspca.c | |||
| @@ -727,6 +727,74 @@ static int gspca_get_mode(struct gspca_dev *gspca_dev, | |||
| 727 | return -EINVAL; | 727 | return -EINVAL; |
| 728 | } | 728 | } |
| 729 | 729 | ||
| 730 | #ifdef CONFIG_VIDEO_ADV_DEBUG | ||
| 731 | static int vidioc_g_register(struct file *file, void *priv, | ||
| 732 | struct v4l2_dbg_register *reg) | ||
| 733 | { | ||
| 734 | int ret; | ||
| 735 | struct gspca_dev *gspca_dev = priv; | ||
| 736 | |||
| 737 | if (!gspca_dev->sd_desc->get_chip_ident) | ||
| 738 | return -EINVAL; | ||
| 739 | |||
| 740 | if (!gspca_dev->sd_desc->get_register) | ||
| 741 | return -EINVAL; | ||
| 742 | |||
| 743 | if (mutex_lock_interruptible(&gspca_dev->usb_lock)) | ||
| 744 | return -ERESTARTSYS; | ||
| 745 | if (gspca_dev->present) | ||
| 746 | ret = gspca_dev->sd_desc->get_register(gspca_dev, reg); | ||
| 747 | else | ||
| 748 | ret = -ENODEV; | ||
| 749 | mutex_unlock(&gspca_dev->usb_lock); | ||
| 750 | |||
| 751 | return ret; | ||
| 752 | } | ||
| 753 | |||
| 754 | static int vidioc_s_register(struct file *file, void *priv, | ||
| 755 | struct v4l2_dbg_register *reg) | ||
| 756 | { | ||
| 757 | int ret; | ||
| 758 | struct gspca_dev *gspca_dev = priv; | ||
| 759 | |||
| 760 | if (!gspca_dev->sd_desc->get_chip_ident) | ||
| 761 | return -EINVAL; | ||
| 762 | |||
| 763 | if (!gspca_dev->sd_desc->set_register) | ||
| 764 | return -EINVAL; | ||
| 765 | |||
| 766 | if (mutex_lock_interruptible(&gspca_dev->usb_lock)) | ||
| 767 | return -ERESTARTSYS; | ||
| 768 | if (gspca_dev->present) | ||
| 769 | ret = gspca_dev->sd_desc->set_register(gspca_dev, reg); | ||
| 770 | else | ||
| 771 | ret = -ENODEV; | ||
| 772 | mutex_unlock(&gspca_dev->usb_lock); | ||
| 773 | |||
| 774 | return ret; | ||
| 775 | } | ||
| 776 | #endif | ||
| 777 | |||
| 778 | static int vidioc_g_chip_ident(struct file *file, void *priv, | ||
| 779 | struct v4l2_dbg_chip_ident *chip) | ||
| 780 | { | ||
| 781 | int ret; | ||
| 782 | struct gspca_dev *gspca_dev = priv; | ||
| 783 | |||
| 784 | if (!gspca_dev->sd_desc->get_chip_ident) | ||
| 785 | return -EINVAL; | ||
| 786 | |||
| 787 | if (mutex_lock_interruptible(&gspca_dev->usb_lock)) | ||
| 788 | return -ERESTARTSYS; | ||
| 789 | if (gspca_dev->present) | ||
| 790 | ret = gspca_dev->sd_desc->get_chip_ident(gspca_dev, chip); | ||
| 791 | else | ||
| 792 | ret = -ENODEV; | ||
| 793 | mutex_unlock(&gspca_dev->usb_lock); | ||
| 794 | |||
| 795 | return ret; | ||
| 796 | } | ||
| 797 | |||
| 730 | static int vidioc_enum_fmt_vid_cap(struct file *file, void *priv, | 798 | static int vidioc_enum_fmt_vid_cap(struct file *file, void *priv, |
| 731 | struct v4l2_fmtdesc *fmtdesc) | 799 | struct v4l2_fmtdesc *fmtdesc) |
| 732 | { | 800 | { |
| @@ -1883,6 +1951,11 @@ static const struct v4l2_ioctl_ops dev_ioctl_ops = { | |||
| 1883 | .vidioc_s_parm = vidioc_s_parm, | 1951 | .vidioc_s_parm = vidioc_s_parm, |
| 1884 | .vidioc_s_std = vidioc_s_std, | 1952 | .vidioc_s_std = vidioc_s_std, |
| 1885 | .vidioc_enum_framesizes = vidioc_enum_framesizes, | 1953 | .vidioc_enum_framesizes = vidioc_enum_framesizes, |
| 1954 | #ifdef CONFIG_VIDEO_ADV_DEBUG | ||
| 1955 | .vidioc_g_register = vidioc_g_register, | ||
| 1956 | .vidioc_s_register = vidioc_s_register, | ||
| 1957 | #endif | ||
| 1958 | .vidioc_g_chip_ident = vidioc_g_chip_ident, | ||
| 1886 | #ifdef CONFIG_VIDEO_V4L1_COMPAT | 1959 | #ifdef CONFIG_VIDEO_V4L1_COMPAT |
| 1887 | .vidiocgmbuf = vidiocgmbuf, | 1960 | .vidiocgmbuf = vidiocgmbuf, |
| 1888 | #endif | 1961 | #endif |
diff --git a/drivers/media/video/gspca/gspca.h b/drivers/media/video/gspca/gspca.h index bd1faff88644..46c4effdfcd5 100644 --- a/drivers/media/video/gspca/gspca.h +++ b/drivers/media/video/gspca/gspca.h | |||
| @@ -69,6 +69,10 @@ typedef void (*cam_v_op) (struct gspca_dev *); | |||
| 69 | typedef int (*cam_cf_op) (struct gspca_dev *, const struct usb_device_id *); | 69 | typedef int (*cam_cf_op) (struct gspca_dev *, const struct usb_device_id *); |
| 70 | typedef int (*cam_jpg_op) (struct gspca_dev *, | 70 | typedef int (*cam_jpg_op) (struct gspca_dev *, |
| 71 | struct v4l2_jpegcompression *); | 71 | struct v4l2_jpegcompression *); |
| 72 | typedef int (*cam_reg_op) (struct gspca_dev *, | ||
| 73 | struct v4l2_dbg_register *); | ||
| 74 | typedef int (*cam_ident_op) (struct gspca_dev *, | ||
| 75 | struct v4l2_dbg_chip_ident *); | ||
| 72 | typedef int (*cam_streamparm_op) (struct gspca_dev *, | 76 | typedef int (*cam_streamparm_op) (struct gspca_dev *, |
| 73 | struct v4l2_streamparm *); | 77 | struct v4l2_streamparm *); |
| 74 | typedef int (*cam_qmnu_op) (struct gspca_dev *, | 78 | typedef int (*cam_qmnu_op) (struct gspca_dev *, |
| @@ -105,6 +109,11 @@ struct sd_desc { | |||
| 105 | cam_qmnu_op querymenu; | 109 | cam_qmnu_op querymenu; |
| 106 | cam_streamparm_op get_streamparm; | 110 | cam_streamparm_op get_streamparm; |
| 107 | cam_streamparm_op set_streamparm; | 111 | cam_streamparm_op set_streamparm; |
| 112 | #ifdef CONFIG_VIDEO_ADV_DEBUG | ||
| 113 | cam_reg_op set_register; | ||
| 114 | cam_reg_op get_register; | ||
| 115 | #endif | ||
| 116 | cam_ident_op get_chip_ident; | ||
| 108 | }; | 117 | }; |
| 109 | 118 | ||
| 110 | /* packet types when moving from iso buf to frame buf */ | 119 | /* packet types when moving from iso buf to frame buf */ |
diff --git a/drivers/media/video/gspca/m5602/m5602_s5k4aa.c b/drivers/media/video/gspca/m5602/m5602_s5k4aa.c index 191bcd718979..0163903d1c0f 100644 --- a/drivers/media/video/gspca/m5602/m5602_s5k4aa.c +++ b/drivers/media/video/gspca/m5602/m5602_s5k4aa.c | |||
| @@ -476,9 +476,6 @@ static int s5k4aa_set_vflip(struct gspca_dev *gspca_dev, __s32 val) | |||
| 476 | err = m5602_write_sensor(sd, S5K4AA_PAGE_MAP, &data, 1); | 476 | err = m5602_write_sensor(sd, S5K4AA_PAGE_MAP, &data, 1); |
| 477 | if (err < 0) | 477 | if (err < 0) |
| 478 | return err; | 478 | return err; |
| 479 | err = m5602_write_sensor(sd, S5K4AA_READ_MODE, &data, 1); | ||
| 480 | if (err < 0) | ||
| 481 | return err; | ||
| 482 | 479 | ||
| 483 | err = m5602_read_sensor(sd, S5K4AA_READ_MODE, &data, 1); | 480 | err = m5602_read_sensor(sd, S5K4AA_READ_MODE, &data, 1); |
| 484 | if (err < 0) | 481 | if (err < 0) |
| @@ -524,9 +521,6 @@ static int s5k4aa_set_hflip(struct gspca_dev *gspca_dev, __s32 val) | |||
| 524 | err = m5602_write_sensor(sd, S5K4AA_PAGE_MAP, &data, 1); | 521 | err = m5602_write_sensor(sd, S5K4AA_PAGE_MAP, &data, 1); |
| 525 | if (err < 0) | 522 | if (err < 0) |
| 526 | return err; | 523 | return err; |
| 527 | err = m5602_write_sensor(sd, S5K4AA_READ_MODE, &data, 1); | ||
| 528 | if (err < 0) | ||
| 529 | return err; | ||
| 530 | 524 | ||
| 531 | err = m5602_read_sensor(sd, S5K4AA_READ_MODE, &data, 1); | 525 | err = m5602_read_sensor(sd, S5K4AA_READ_MODE, &data, 1); |
| 532 | if (err < 0) | 526 | if (err < 0) |
diff --git a/drivers/media/video/gspca/mars.c b/drivers/media/video/gspca/mars.c index 75e8d14e4ac7..de769caf013d 100644 --- a/drivers/media/video/gspca/mars.c +++ b/drivers/media/video/gspca/mars.c | |||
| @@ -201,6 +201,8 @@ static int sd_start(struct gspca_dev *gspca_dev) | |||
| 201 | 201 | ||
| 202 | /* create the JPEG header */ | 202 | /* create the JPEG header */ |
| 203 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); | 203 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); |
| 204 | if (!sd->jpeg_hdr) | ||
| 205 | return -ENOMEM; | ||
| 204 | jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width, | 206 | jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width, |
| 205 | 0x21); /* JPEG 422 */ | 207 | 0x21); /* JPEG 422 */ |
| 206 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); | 208 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); |
diff --git a/drivers/media/video/gspca/sn9c20x.c b/drivers/media/video/gspca/sn9c20x.c new file mode 100644 index 000000000000..fcfbbd329b4c --- /dev/null +++ b/drivers/media/video/gspca/sn9c20x.c | |||
| @@ -0,0 +1,2434 @@ | |||
| 1 | /* | ||
| 2 | * Sonix sn9c201 sn9c202 library | ||
| 3 | * Copyright (C) 2008-2009 microdia project <microdia@googlegroups.com> | ||
| 4 | * Copyright (C) 2009 Brian Johnson <brijohn@gmail.com> | ||
| 5 | * | ||
| 6 | * This program is free software; you can redistribute it and/or modify | ||
| 7 | * it under the terms of the GNU General Public License as published by | ||
| 8 | * the Free Software Foundation; either version 2 of the License, or | ||
| 9 | * any later version. | ||
| 10 | * | ||
| 11 | * This program is distributed in the hope that it will be useful, | ||
| 12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 14 | * GNU General Public License for more details. | ||
| 15 | * | ||
| 16 | * You should have received a copy of the GNU General Public License | ||
| 17 | * along with this program; if not, write to the Free Software | ||
| 18 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
| 19 | */ | ||
| 20 | |||
| 21 | #ifdef CONFIG_USB_GSPCA_SN9C20X_EVDEV | ||
| 22 | #include <linux/kthread.h> | ||
| 23 | #include <linux/freezer.h> | ||
| 24 | #include <linux/usb/input.h> | ||
| 25 | #include <linux/input.h> | ||
| 26 | #endif | ||
| 27 | |||
| 28 | #include "gspca.h" | ||
| 29 | #include "jpeg.h" | ||
| 30 | |||
| 31 | #include <media/v4l2-chip-ident.h> | ||
| 32 | |||
| 33 | MODULE_AUTHOR("Brian Johnson <brijohn@gmail.com>, " | ||
| 34 | "microdia project <microdia@googlegroups.com>"); | ||
| 35 | MODULE_DESCRIPTION("GSPCA/SN9C20X USB Camera Driver"); | ||
| 36 | MODULE_LICENSE("GPL"); | ||
| 37 | |||
| 38 | #define MODULE_NAME "sn9c20x" | ||
| 39 | |||
| 40 | #define MODE_RAW 0x10 | ||
| 41 | #define MODE_JPEG 0x20 | ||
| 42 | #define MODE_SXGA 0x80 | ||
| 43 | |||
| 44 | #define SENSOR_OV9650 0 | ||
| 45 | #define SENSOR_OV9655 1 | ||
| 46 | #define SENSOR_SOI968 2 | ||
| 47 | #define SENSOR_OV7660 3 | ||
| 48 | #define SENSOR_OV7670 4 | ||
| 49 | #define SENSOR_MT9V011 5 | ||
| 50 | #define SENSOR_MT9V111 6 | ||
| 51 | #define SENSOR_MT9V112 7 | ||
| 52 | #define SENSOR_MT9M001 8 | ||
| 53 | #define SENSOR_MT9M111 9 | ||
| 54 | #define SENSOR_HV7131R 10 | ||
| 55 | #define SENSOR_MT9VPRB 20 | ||
| 56 | |||
| 57 | /* specific webcam descriptor */ | ||
| 58 | struct sd { | ||
| 59 | struct gspca_dev gspca_dev; | ||
| 60 | |||
| 61 | #define MIN_AVG_LUM 80 | ||
| 62 | #define MAX_AVG_LUM 130 | ||
| 63 | atomic_t avg_lum; | ||
| 64 | u8 old_step; | ||
| 65 | u8 older_step; | ||
| 66 | u8 exposure_step; | ||
| 67 | |||
| 68 | u8 brightness; | ||
| 69 | u8 contrast; | ||
| 70 | u8 saturation; | ||
| 71 | s16 hue; | ||
| 72 | u8 gamma; | ||
| 73 | u8 red; | ||
| 74 | u8 blue; | ||
| 75 | |||
| 76 | u8 hflip; | ||
| 77 | u8 vflip; | ||
| 78 | u8 gain; | ||
| 79 | u16 exposure; | ||
| 80 | u8 auto_exposure; | ||
| 81 | |||
| 82 | u8 i2c_addr; | ||
| 83 | u8 sensor; | ||
| 84 | u8 hstart; | ||
| 85 | u8 vstart; | ||
| 86 | |||
| 87 | u8 *jpeg_hdr; | ||
| 88 | u8 quality; | ||
| 89 | |||
| 90 | #ifdef CONFIG_USB_GSPCA_SN9C20X_EVDEV | ||
| 91 | struct input_dev *input_dev; | ||
| 92 | u8 input_gpio; | ||
| 93 | struct task_struct *input_task; | ||
| 94 | #endif | ||
| 95 | }; | ||
| 96 | |||
| 97 | static int sd_setbrightness(struct gspca_dev *gspca_dev, s32 val); | ||
| 98 | static int sd_getbrightness(struct gspca_dev *gspca_dev, s32 *val); | ||
| 99 | static int sd_setcontrast(struct gspca_dev *gspca_dev, s32 val); | ||
| 100 | static int sd_getcontrast(struct gspca_dev *gspca_dev, s32 *val); | ||
| 101 | static int sd_setsaturation(struct gspca_dev *gspca_dev, s32 val); | ||
| 102 | static int sd_getsaturation(struct gspca_dev *gspca_dev, s32 *val); | ||
| 103 | static int sd_sethue(struct gspca_dev *gspca_dev, s32 val); | ||
| 104 | static int sd_gethue(struct gspca_dev *gspca_dev, s32 *val); | ||
| 105 | static int sd_setgamma(struct gspca_dev *gspca_dev, s32 val); | ||
| 106 | static int sd_getgamma(struct gspca_dev *gspca_dev, s32 *val); | ||
| 107 | static int sd_setredbalance(struct gspca_dev *gspca_dev, s32 val); | ||
| 108 | static int sd_getredbalance(struct gspca_dev *gspca_dev, s32 *val); | ||
| 109 | static int sd_setbluebalance(struct gspca_dev *gspca_dev, s32 val); | ||
| 110 | static int sd_getbluebalance(struct gspca_dev *gspca_dev, s32 *val); | ||
| 111 | static int sd_setvflip(struct gspca_dev *gspca_dev, s32 val); | ||
| 112 | static int sd_getvflip(struct gspca_dev *gspca_dev, s32 *val); | ||
| 113 | static int sd_sethflip(struct gspca_dev *gspca_dev, s32 val); | ||
| 114 | static int sd_gethflip(struct gspca_dev *gspca_dev, s32 *val); | ||
| 115 | static int sd_setgain(struct gspca_dev *gspca_dev, s32 val); | ||
| 116 | static int sd_getgain(struct gspca_dev *gspca_dev, s32 *val); | ||
| 117 | static int sd_setexposure(struct gspca_dev *gspca_dev, s32 val); | ||
| 118 | static int sd_getexposure(struct gspca_dev *gspca_dev, s32 *val); | ||
| 119 | static int sd_setautoexposure(struct gspca_dev *gspca_dev, s32 val); | ||
| 120 | static int sd_getautoexposure(struct gspca_dev *gspca_dev, s32 *val); | ||
| 121 | |||
| 122 | static struct ctrl sd_ctrls[] = { | ||
| 123 | { | ||
| 124 | #define BRIGHTNESS_IDX 0 | ||
| 125 | { | ||
| 126 | .id = V4L2_CID_BRIGHTNESS, | ||
| 127 | .type = V4L2_CTRL_TYPE_INTEGER, | ||
| 128 | .name = "Brightness", | ||
| 129 | .minimum = 0, | ||
| 130 | .maximum = 0xff, | ||
| 131 | .step = 1, | ||
| 132 | #define BRIGHTNESS_DEFAULT 0x7f | ||
| 133 | .default_value = BRIGHTNESS_DEFAULT, | ||
| 134 | }, | ||
| 135 | .set = sd_setbrightness, | ||
| 136 | .get = sd_getbrightness, | ||
| 137 | }, | ||
| 138 | { | ||
| 139 | #define CONTRAST_IDX 1 | ||
| 140 | { | ||
| 141 | .id = V4L2_CID_CONTRAST, | ||
| 142 | .type = V4L2_CTRL_TYPE_INTEGER, | ||
| 143 | .name = "Contrast", | ||
| 144 | .minimum = 0, | ||
| 145 | .maximum = 0xff, | ||
| 146 | .step = 1, | ||
| 147 | #define CONTRAST_DEFAULT 0x7f | ||
| 148 | .default_value = CONTRAST_DEFAULT, | ||
| 149 | }, | ||
| 150 | .set = sd_setcontrast, | ||
| 151 | .get = sd_getcontrast, | ||
| 152 | }, | ||
| 153 | { | ||
| 154 | #define SATURATION_IDX 2 | ||
| 155 | { | ||
| 156 | .id = V4L2_CID_SATURATION, | ||
| 157 | .type = V4L2_CTRL_TYPE_INTEGER, | ||
| 158 | .name = "Saturation", | ||
| 159 | .minimum = 0, | ||
| 160 | .maximum = 0xff, | ||
| 161 | .step = 1, | ||
| 162 | #define SATURATION_DEFAULT 0x7f | ||
| 163 | .default_value = SATURATION_DEFAULT, | ||
| 164 | }, | ||
| 165 | .set = sd_setsaturation, | ||
| 166 | .get = sd_getsaturation, | ||
| 167 | }, | ||
| 168 | { | ||
| 169 | #define HUE_IDX 3 | ||
| 170 | { | ||
| 171 | .id = V4L2_CID_HUE, | ||
| 172 | .type = V4L2_CTRL_TYPE_INTEGER, | ||
| 173 | .name = "Hue", | ||
| 174 | .minimum = -180, | ||
| 175 | .maximum = 180, | ||
| 176 | .step = 1, | ||
| 177 | #define HUE_DEFAULT 0 | ||
| 178 | .default_value = HUE_DEFAULT, | ||
| 179 | }, | ||
| 180 | .set = sd_sethue, | ||
| 181 | .get = sd_gethue, | ||
| 182 | }, | ||
| 183 | { | ||
| 184 | #define GAMMA_IDX 4 | ||
| 185 | { | ||
| 186 | .id = V4L2_CID_GAMMA, | ||
| 187 | .type = V4L2_CTRL_TYPE_INTEGER, | ||
| 188 | .name = "Gamma", | ||
| 189 | .minimum = 0, | ||
| 190 | .maximum = 0xff, | ||
| 191 | .step = 1, | ||
| 192 | #define GAMMA_DEFAULT 0x10 | ||
| 193 | .default_value = GAMMA_DEFAULT, | ||
| 194 | }, | ||
| 195 | .set = sd_setgamma, | ||
| 196 | .get = sd_getgamma, | ||
| 197 | }, | ||
| 198 | { | ||
| 199 | #define BLUE_IDX 5 | ||
| 200 | { | ||
| 201 | .id = V4L2_CID_BLUE_BALANCE, | ||
| 202 | .type = V4L2_CTRL_TYPE_INTEGER, | ||
| 203 | .name = "Blue Balance", | ||
| 204 | .minimum = 0, | ||
| 205 | .maximum = 0x7f, | ||
| 206 | .step = 1, | ||
| 207 | #define BLUE_DEFAULT 0x28 | ||
| 208 | .default_value = BLUE_DEFAULT, | ||
| 209 | }, | ||
| 210 | .set = sd_setbluebalance, | ||
| 211 | .get = sd_getbluebalance, | ||
| 212 | }, | ||
| 213 | { | ||
| 214 | #define RED_IDX 6 | ||
| 215 | { | ||
| 216 | .id = V4L2_CID_RED_BALANCE, | ||
| 217 | .type = V4L2_CTRL_TYPE_INTEGER, | ||
| 218 | .name = "Red Balance", | ||
| 219 | .minimum = 0, | ||
| 220 | .maximum = 0x7f, | ||
| 221 | .step = 1, | ||
| 222 | #define RED_DEFAULT 0x28 | ||
| 223 | .default_value = RED_DEFAULT, | ||
| 224 | }, | ||
| 225 | .set = sd_setredbalance, | ||
| 226 | .get = sd_getredbalance, | ||
| 227 | }, | ||
| 228 | { | ||
| 229 | #define HFLIP_IDX 7 | ||
| 230 | { | ||
| 231 | .id = V4L2_CID_HFLIP, | ||
| 232 | .type = V4L2_CTRL_TYPE_BOOLEAN, | ||
| 233 | .name = "Horizontal Flip", | ||
| 234 | .minimum = 0, | ||
| 235 | .maximum = 1, | ||
| 236 | .step = 1, | ||
| 237 | #define HFLIP_DEFAULT 0 | ||
| 238 | .default_value = HFLIP_DEFAULT, | ||
| 239 | }, | ||
| 240 | .set = sd_sethflip, | ||
| 241 | .get = sd_gethflip, | ||
| 242 | }, | ||
| 243 | { | ||
| 244 | #define VFLIP_IDX 8 | ||
| 245 | { | ||
| 246 | .id = V4L2_CID_VFLIP, | ||
| 247 | .type = V4L2_CTRL_TYPE_BOOLEAN, | ||
| 248 | .name = "Vertical Flip", | ||
| 249 | .minimum = 0, | ||
| 250 | .maximum = 1, | ||
| 251 | .step = 1, | ||
| 252 | #define VFLIP_DEFAULT 0 | ||
| 253 | .default_value = VFLIP_DEFAULT, | ||
| 254 | }, | ||
| 255 | .set = sd_setvflip, | ||
| 256 | .get = sd_getvflip, | ||
| 257 | }, | ||
| 258 | { | ||
| 259 | #define EXPOSURE_IDX 9 | ||
| 260 | { | ||
| 261 | .id = V4L2_CID_EXPOSURE, | ||
| 262 | .type = V4L2_CTRL_TYPE_INTEGER, | ||
| 263 | .name = "Exposure", | ||
| 264 | .minimum = 0, | ||
| 265 | .maximum = 0x1780, | ||
| 266 | .step = 1, | ||
| 267 | #define EXPOSURE_DEFAULT 0x33 | ||
| 268 | .default_value = EXPOSURE_DEFAULT, | ||
| 269 | }, | ||
| 270 | .set = sd_setexposure, | ||
| 271 | .get = sd_getexposure, | ||
| 272 | }, | ||
| 273 | { | ||
| 274 | #define GAIN_IDX 10 | ||
| 275 | { | ||
| 276 | .id = V4L2_CID_GAIN, | ||
| 277 | .type = V4L2_CTRL_TYPE_INTEGER, | ||
| 278 | .name = "Gain", | ||
| 279 | .minimum = 0, | ||
| 280 | .maximum = 28, | ||
| 281 | .step = 1, | ||
| 282 | #define GAIN_DEFAULT 0x00 | ||
| 283 | .default_value = GAIN_DEFAULT, | ||
| 284 | }, | ||
| 285 | .set = sd_setgain, | ||
| 286 | .get = sd_getgain, | ||
| 287 | }, | ||
| 288 | { | ||
| 289 | #define AUTOGAIN_IDX 11 | ||
| 290 | { | ||
| 291 | .id = V4L2_CID_AUTOGAIN, | ||
| 292 | .type = V4L2_CTRL_TYPE_BOOLEAN, | ||
| 293 | .name = "Auto Exposure", | ||
| 294 | .minimum = 0, | ||
| 295 | .maximum = 1, | ||
| 296 | .step = 1, | ||
| 297 | #define AUTO_EXPOSURE_DEFAULT 1 | ||
| 298 | .default_value = AUTO_EXPOSURE_DEFAULT, | ||
| 299 | }, | ||
| 300 | .set = sd_setautoexposure, | ||
| 301 | .get = sd_getautoexposure, | ||
| 302 | }, | ||
| 303 | }; | ||
| 304 | |||
| 305 | static const struct v4l2_pix_format vga_mode[] = { | ||
| 306 | {160, 120, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE, | ||
| 307 | .bytesperline = 240, | ||
| 308 | .sizeimage = 240 * 120, | ||
| 309 | .colorspace = V4L2_COLORSPACE_JPEG, | ||
| 310 | .priv = 0 | MODE_JPEG}, | ||
| 311 | {160, 120, V4L2_PIX_FMT_SBGGR8, V4L2_FIELD_NONE, | ||
| 312 | .bytesperline = 160, | ||
| 313 | .sizeimage = 160 * 120, | ||
| 314 | .colorspace = V4L2_COLORSPACE_SRGB, | ||
| 315 | .priv = 0 | MODE_RAW}, | ||
| 316 | {160, 120, V4L2_PIX_FMT_SN9C20X_I420, V4L2_FIELD_NONE, | ||
| 317 | .bytesperline = 240, | ||
| 318 | .sizeimage = 240 * 120, | ||
| 319 | .colorspace = V4L2_COLORSPACE_SRGB, | ||
| 320 | .priv = 0}, | ||
| 321 | {320, 240, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE, | ||
| 322 | .bytesperline = 480, | ||
| 323 | .sizeimage = 480 * 240 , | ||
| 324 | .colorspace = V4L2_COLORSPACE_JPEG, | ||
| 325 | .priv = 1 | MODE_JPEG}, | ||
| 326 | {320, 240, V4L2_PIX_FMT_SBGGR8, V4L2_FIELD_NONE, | ||
| 327 | .bytesperline = 320, | ||
| 328 | .sizeimage = 320 * 240 , | ||
| 329 | .colorspace = V4L2_COLORSPACE_SRGB, | ||
| 330 | .priv = 1 | MODE_RAW}, | ||
| 331 | {320, 240, V4L2_PIX_FMT_SN9C20X_I420, V4L2_FIELD_NONE, | ||
| 332 | .bytesperline = 480, | ||
| 333 | .sizeimage = 480 * 240 , | ||
| 334 | .colorspace = V4L2_COLORSPACE_SRGB, | ||
| 335 | .priv = 1}, | ||
| 336 | {640, 480, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE, | ||
| 337 | .bytesperline = 960, | ||
| 338 | .sizeimage = 960 * 480, | ||
| 339 | .colorspace = V4L2_COLORSPACE_JPEG, | ||
| 340 | .priv = 2 | MODE_JPEG}, | ||
| 341 | {640, 480, V4L2_PIX_FMT_SBGGR8, V4L2_FIELD_NONE, | ||
| 342 | .bytesperline = 640, | ||
| 343 | .sizeimage = 640 * 480, | ||
| 344 | .colorspace = V4L2_COLORSPACE_SRGB, | ||
| 345 | .priv = 2 | MODE_RAW}, | ||
| 346 | {640, 480, V4L2_PIX_FMT_SN9C20X_I420, V4L2_FIELD_NONE, | ||
| 347 | .bytesperline = 960, | ||
| 348 | .sizeimage = 960 * 480, | ||
| 349 | .colorspace = V4L2_COLORSPACE_SRGB, | ||
| 350 | .priv = 2}, | ||
| 351 | }; | ||
| 352 | |||
| 353 | static const struct v4l2_pix_format sxga_mode[] = { | ||
| 354 | {160, 120, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE, | ||
| 355 | .bytesperline = 240, | ||
| 356 | .sizeimage = 240 * 120, | ||
| 357 | .colorspace = V4L2_COLORSPACE_JPEG, | ||
| 358 | .priv = 0 | MODE_JPEG}, | ||
| 359 | {160, 120, V4L2_PIX_FMT_SBGGR8, V4L2_FIELD_NONE, | ||
| 360 | .bytesperline = 160, | ||
| 361 | .sizeimage = 160 * 120, | ||
| 362 | .colorspace = V4L2_COLORSPACE_SRGB, | ||
| 363 | .priv = 0 | MODE_RAW}, | ||
| 364 | {160, 120, V4L2_PIX_FMT_SN9C20X_I420, V4L2_FIELD_NONE, | ||
| 365 | .bytesperline = 240, | ||
| 366 | .sizeimage = 240 * 120, | ||
| 367 | .colorspace = V4L2_COLORSPACE_SRGB, | ||
| 368 | .priv = 0}, | ||
| 369 | {320, 240, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE, | ||
| 370 | .bytesperline = 480, | ||
| 371 | .sizeimage = 480 * 240 , | ||
| 372 | .colorspace = V4L2_COLORSPACE_JPEG, | ||
| 373 | .priv = 1 | MODE_JPEG}, | ||
| 374 | {320, 240, V4L2_PIX_FMT_SBGGR8, V4L2_FIELD_NONE, | ||
| 375 | .bytesperline = 320, | ||
| 376 | .sizeimage = 320 * 240 , | ||
| 377 | .colorspace = V4L2_COLORSPACE_SRGB, | ||
| 378 | .priv = 1 | MODE_RAW}, | ||
| 379 | {320, 240, V4L2_PIX_FMT_SN9C20X_I420, V4L2_FIELD_NONE, | ||
| 380 | .bytesperline = 480, | ||
| 381 | .sizeimage = 480 * 240 , | ||
| 382 | .colorspace = V4L2_COLORSPACE_SRGB, | ||
| 383 | .priv = 1}, | ||
| 384 | {640, 480, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE, | ||
| 385 | .bytesperline = 960, | ||
| 386 | .sizeimage = 960 * 480, | ||
| 387 | .colorspace = V4L2_COLORSPACE_JPEG, | ||
| 388 | .priv = 2 | MODE_JPEG}, | ||
| 389 | {640, 480, V4L2_PIX_FMT_SBGGR8, V4L2_FIELD_NONE, | ||
| 390 | .bytesperline = 640, | ||
| 391 | .sizeimage = 640 * 480, | ||
| 392 | .colorspace = V4L2_COLORSPACE_SRGB, | ||
| 393 | .priv = 2 | MODE_RAW}, | ||
| 394 | {640, 480, V4L2_PIX_FMT_SN9C20X_I420, V4L2_FIELD_NONE, | ||
| 395 | .bytesperline = 960, | ||
| 396 | .sizeimage = 960 * 480, | ||
| 397 | .colorspace = V4L2_COLORSPACE_SRGB, | ||
| 398 | .priv = 2}, | ||
| 399 | {1280, 1024, V4L2_PIX_FMT_SBGGR8, V4L2_FIELD_NONE, | ||
| 400 | .bytesperline = 1280, | ||
| 401 | .sizeimage = (1280 * 1024) + 64, | ||
| 402 | .colorspace = V4L2_COLORSPACE_SRGB, | ||
| 403 | .priv = 3 | MODE_RAW | MODE_SXGA}, | ||
| 404 | }; | ||
| 405 | |||
| 406 | static const int hsv_red_x[] = { | ||
| 407 | 41, 44, 46, 48, 50, 52, 54, 56, | ||
| 408 | 58, 60, 62, 64, 66, 68, 70, 72, | ||
| 409 | 74, 76, 78, 80, 81, 83, 85, 87, | ||
| 410 | 88, 90, 92, 93, 95, 97, 98, 100, | ||
| 411 | 101, 102, 104, 105, 107, 108, 109, 110, | ||
| 412 | 112, 113, 114, 115, 116, 117, 118, 119, | ||
| 413 | 120, 121, 122, 123, 123, 124, 125, 125, | ||
| 414 | 126, 127, 127, 128, 128, 129, 129, 129, | ||
| 415 | 130, 130, 130, 130, 131, 131, 131, 131, | ||
| 416 | 131, 131, 131, 131, 130, 130, 130, 130, | ||
| 417 | 129, 129, 129, 128, 128, 127, 127, 126, | ||
| 418 | 125, 125, 124, 123, 122, 122, 121, 120, | ||
| 419 | 119, 118, 117, 116, 115, 114, 112, 111, | ||
| 420 | 110, 109, 107, 106, 105, 103, 102, 101, | ||
| 421 | 99, 98, 96, 94, 93, 91, 90, 88, | ||
| 422 | 86, 84, 83, 81, 79, 77, 75, 74, | ||
| 423 | 72, 70, 68, 66, 64, 62, 60, 58, | ||
| 424 | 56, 54, 52, 49, 47, 45, 43, 41, | ||
| 425 | 39, 36, 34, 32, 30, 28, 25, 23, | ||
| 426 | 21, 19, 16, 14, 12, 9, 7, 5, | ||
| 427 | 3, 0, -1, -3, -6, -8, -10, -12, | ||
| 428 | -15, -17, -19, -22, -24, -26, -28, -30, | ||
| 429 | -33, -35, -37, -39, -41, -44, -46, -48, | ||
| 430 | -50, -52, -54, -56, -58, -60, -62, -64, | ||
| 431 | -66, -68, -70, -72, -74, -76, -78, -80, | ||
| 432 | -81, -83, -85, -87, -88, -90, -92, -93, | ||
| 433 | -95, -97, -98, -100, -101, -102, -104, -105, | ||
| 434 | -107, -108, -109, -110, -112, -113, -114, -115, | ||
| 435 | -116, -117, -118, -119, -120, -121, -122, -123, | ||
| 436 | -123, -124, -125, -125, -126, -127, -127, -128, | ||
| 437 | -128, -128, -128, -128, -128, -128, -128, -128, | ||
| 438 | -128, -128, -128, -128, -128, -128, -128, -128, | ||
| 439 | -128, -128, -128, -128, -128, -128, -128, -128, | ||
| 440 | -128, -127, -127, -126, -125, -125, -124, -123, | ||
| 441 | -122, -122, -121, -120, -119, -118, -117, -116, | ||
| 442 | -115, -114, -112, -111, -110, -109, -107, -106, | ||
| 443 | -105, -103, -102, -101, -99, -98, -96, -94, | ||
| 444 | -93, -91, -90, -88, -86, -84, -83, -81, | ||
| 445 | -79, -77, -75, -74, -72, -70, -68, -66, | ||
| 446 | -64, -62, -60, -58, -56, -54, -52, -49, | ||
| 447 | -47, -45, -43, -41, -39, -36, -34, -32, | ||
| 448 | -30, -28, -25, -23, -21, -19, -16, -14, | ||
| 449 | -12, -9, -7, -5, -3, 0, 1, 3, | ||
| 450 | 6, 8, 10, 12, 15, 17, 19, 22, | ||
| 451 | 24, 26, 28, 30, 33, 35, 37, 39, 41 | ||
| 452 | }; | ||
| 453 | |||
| 454 | static const int hsv_red_y[] = { | ||
| 455 | 82, 80, 78, 76, 74, 73, 71, 69, | ||
| 456 | 67, 65, 63, 61, 58, 56, 54, 52, | ||
| 457 | 50, 48, 46, 44, 41, 39, 37, 35, | ||
| 458 | 32, 30, 28, 26, 23, 21, 19, 16, | ||
| 459 | 14, 12, 10, 7, 5, 3, 0, -1, | ||
| 460 | -3, -6, -8, -10, -13, -15, -17, -19, | ||
| 461 | -22, -24, -26, -29, -31, -33, -35, -38, | ||
| 462 | -40, -42, -44, -46, -48, -51, -53, -55, | ||
| 463 | -57, -59, -61, -63, -65, -67, -69, -71, | ||
| 464 | -73, -75, -77, -79, -81, -82, -84, -86, | ||
| 465 | -88, -89, -91, -93, -94, -96, -98, -99, | ||
| 466 | -101, -102, -104, -105, -106, -108, -109, -110, | ||
| 467 | -112, -113, -114, -115, -116, -117, -119, -120, | ||
| 468 | -120, -121, -122, -123, -124, -125, -126, -126, | ||
| 469 | -127, -128, -128, -128, -128, -128, -128, -128, | ||
| 470 | -128, -128, -128, -128, -128, -128, -128, -128, | ||
| 471 | -128, -128, -128, -128, -128, -128, -128, -128, | ||
| 472 | -128, -128, -128, -128, -128, -128, -128, -128, | ||
| 473 | -127, -127, -126, -125, -125, -124, -123, -122, | ||
| 474 | -121, -120, -119, -118, -117, -116, -115, -114, | ||
| 475 | -113, -111, -110, -109, -107, -106, -105, -103, | ||
| 476 | -102, -100, -99, -97, -96, -94, -92, -91, | ||
| 477 | -89, -87, -85, -84, -82, -80, -78, -76, | ||
| 478 | -74, -73, -71, -69, -67, -65, -63, -61, | ||
| 479 | -58, -56, -54, -52, -50, -48, -46, -44, | ||
| 480 | -41, -39, -37, -35, -32, -30, -28, -26, | ||
| 481 | -23, -21, -19, -16, -14, -12, -10, -7, | ||
| 482 | -5, -3, 0, 1, 3, 6, 8, 10, | ||
| 483 | 13, 15, 17, 19, 22, 24, 26, 29, | ||
| 484 | 31, 33, 35, 38, 40, 42, 44, 46, | ||
| 485 | 48, 51, 53, 55, 57, 59, 61, 63, | ||
| 486 | 65, 67, 69, 71, 73, 75, 77, 79, | ||
| 487 | 81, 82, 84, 86, 88, 89, 91, 93, | ||
| 488 | 94, 96, 98, 99, 101, 102, 104, 105, | ||
| 489 | 106, 108, 109, 110, 112, 113, 114, 115, | ||
| 490 | 116, 117, 119, 120, 120, 121, 122, 123, | ||
| 491 | 124, 125, 126, 126, 127, 128, 128, 129, | ||
| 492 | 129, 130, 130, 131, 131, 131, 131, 132, | ||
| 493 | 132, 132, 132, 132, 132, 132, 132, 132, | ||
| 494 | 132, 132, 132, 131, 131, 131, 130, 130, | ||
| 495 | 130, 129, 129, 128, 127, 127, 126, 125, | ||
| 496 | 125, 124, 123, 122, 121, 120, 119, 118, | ||
| 497 | 117, 116, 115, 114, 113, 111, 110, 109, | ||
| 498 | 107, 106, 105, 103, 102, 100, 99, 97, | ||
| 499 | 96, 94, 92, 91, 89, 87, 85, 84, 82 | ||
| 500 | }; | ||
| 501 | |||
| 502 | static const int hsv_green_x[] = { | ||
| 503 | -124, -124, -125, -125, -125, -125, -125, -125, | ||
| 504 | -125, -126, -126, -125, -125, -125, -125, -125, | ||
| 505 | -125, -124, -124, -124, -123, -123, -122, -122, | ||
| 506 | -121, -121, -120, -120, -119, -118, -117, -117, | ||
| 507 | -116, -115, -114, -113, -112, -111, -110, -109, | ||
| 508 | -108, -107, -105, -104, -103, -102, -100, -99, | ||
| 509 | -98, -96, -95, -93, -92, -91, -89, -87, | ||
| 510 | -86, -84, -83, -81, -79, -77, -76, -74, | ||
| 511 | -72, -70, -69, -67, -65, -63, -61, -59, | ||
| 512 | -57, -55, -53, -51, -49, -47, -45, -43, | ||
| 513 | -41, -39, -37, -35, -33, -30, -28, -26, | ||
| 514 | -24, -22, -20, -18, -15, -13, -11, -9, | ||
| 515 | -7, -4, -2, 0, 1, 3, 6, 8, | ||
| 516 | 10, 12, 14, 17, 19, 21, 23, 25, | ||
| 517 | 27, 29, 32, 34, 36, 38, 40, 42, | ||
| 518 | 44, 46, 48, 50, 52, 54, 56, 58, | ||
| 519 | 60, 62, 64, 66, 68, 70, 71, 73, | ||
| 520 | 75, 77, 78, 80, 82, 83, 85, 87, | ||
| 521 | 88, 90, 91, 93, 94, 96, 97, 98, | ||
| 522 | 100, 101, 102, 104, 105, 106, 107, 108, | ||
| 523 | 109, 111, 112, 113, 113, 114, 115, 116, | ||
| 524 | 117, 118, 118, 119, 120, 120, 121, 122, | ||
| 525 | 122, 123, 123, 124, 124, 124, 125, 125, | ||
| 526 | 125, 125, 125, 125, 125, 126, 126, 125, | ||
| 527 | 125, 125, 125, 125, 125, 124, 124, 124, | ||
| 528 | 123, 123, 122, 122, 121, 121, 120, 120, | ||
| 529 | 119, 118, 117, 117, 116, 115, 114, 113, | ||
| 530 | 112, 111, 110, 109, 108, 107, 105, 104, | ||
| 531 | 103, 102, 100, 99, 98, 96, 95, 93, | ||
| 532 | 92, 91, 89, 87, 86, 84, 83, 81, | ||
| 533 | 79, 77, 76, 74, 72, 70, 69, 67, | ||
| 534 | 65, 63, 61, 59, 57, 55, 53, 51, | ||
| 535 | 49, 47, 45, 43, 41, 39, 37, 35, | ||
| 536 | 33, 30, 28, 26, 24, 22, 20, 18, | ||
| 537 | 15, 13, 11, 9, 7, 4, 2, 0, | ||
| 538 | -1, -3, -6, -8, -10, -12, -14, -17, | ||
| 539 | -19, -21, -23, -25, -27, -29, -32, -34, | ||
| 540 | -36, -38, -40, -42, -44, -46, -48, -50, | ||
| 541 | -52, -54, -56, -58, -60, -62, -64, -66, | ||
| 542 | -68, -70, -71, -73, -75, -77, -78, -80, | ||
| 543 | -82, -83, -85, -87, -88, -90, -91, -93, | ||
| 544 | -94, -96, -97, -98, -100, -101, -102, -104, | ||
| 545 | -105, -106, -107, -108, -109, -111, -112, -113, | ||
| 546 | -113, -114, -115, -116, -117, -118, -118, -119, | ||
| 547 | -120, -120, -121, -122, -122, -123, -123, -124, -124 | ||
| 548 | }; | ||
| 549 | |||
| 550 | static const int hsv_green_y[] = { | ||
| 551 | -100, -99, -98, -97, -95, -94, -93, -91, | ||
| 552 | -90, -89, -87, -86, -84, -83, -81, -80, | ||
| 553 | -78, -76, -75, -73, -71, -70, -68, -66, | ||
| 554 | -64, -63, -61, -59, -57, -55, -53, -51, | ||
| 555 | -49, -48, -46, -44, -42, -40, -38, -36, | ||
| 556 | -34, -32, -30, -27, -25, -23, -21, -19, | ||
| 557 | -17, -15, -13, -11, -9, -7, -4, -2, | ||
| 558 | 0, 1, 3, 5, 7, 9, 11, 14, | ||
| 559 | 16, 18, 20, 22, 24, 26, 28, 30, | ||
| 560 | 32, 34, 36, 38, 40, 42, 44, 46, | ||
| 561 | 48, 50, 52, 54, 56, 58, 59, 61, | ||
| 562 | 63, 65, 67, 68, 70, 72, 74, 75, | ||
| 563 | 77, 78, 80, 82, 83, 85, 86, 88, | ||
| 564 | 89, 90, 92, 93, 95, 96, 97, 98, | ||
| 565 | 100, 101, 102, 103, 104, 105, 106, 107, | ||
| 566 | 108, 109, 110, 111, 112, 112, 113, 114, | ||
| 567 | 115, 115, 116, 116, 117, 117, 118, 118, | ||
| 568 | 119, 119, 119, 120, 120, 120, 120, 120, | ||
| 569 | 121, 121, 121, 121, 121, 121, 120, 120, | ||
| 570 | 120, 120, 120, 119, 119, 119, 118, 118, | ||
| 571 | 117, 117, 116, 116, 115, 114, 114, 113, | ||
| 572 | 112, 111, 111, 110, 109, 108, 107, 106, | ||
| 573 | 105, 104, 103, 102, 100, 99, 98, 97, | ||
| 574 | 95, 94, 93, 91, 90, 89, 87, 86, | ||
| 575 | 84, 83, 81, 80, 78, 76, 75, 73, | ||
| 576 | 71, 70, 68, 66, 64, 63, 61, 59, | ||
| 577 | 57, 55, 53, 51, 49, 48, 46, 44, | ||
| 578 | 42, 40, 38, 36, 34, 32, 30, 27, | ||
| 579 | 25, 23, 21, 19, 17, 15, 13, 11, | ||
| 580 | 9, 7, 4, 2, 0, -1, -3, -5, | ||
| 581 | -7, -9, -11, -14, -16, -18, -20, -22, | ||
| 582 | -24, -26, -28, -30, -32, -34, -36, -38, | ||
| 583 | -40, -42, -44, -46, -48, -50, -52, -54, | ||
| 584 | -56, -58, -59, -61, -63, -65, -67, -68, | ||
| 585 | -70, -72, -74, -75, -77, -78, -80, -82, | ||
| 586 | -83, -85, -86, -88, -89, -90, -92, -93, | ||
| 587 | -95, -96, -97, -98, -100, -101, -102, -103, | ||
| 588 | -104, -105, -106, -107, -108, -109, -110, -111, | ||
| 589 | -112, -112, -113, -114, -115, -115, -116, -116, | ||
| 590 | -117, -117, -118, -118, -119, -119, -119, -120, | ||
| 591 | -120, -120, -120, -120, -121, -121, -121, -121, | ||
| 592 | -121, -121, -120, -120, -120, -120, -120, -119, | ||
| 593 | -119, -119, -118, -118, -117, -117, -116, -116, | ||
| 594 | -115, -114, -114, -113, -112, -111, -111, -110, | ||
| 595 | -109, -108, -107, -106, -105, -104, -103, -102, -100 | ||
| 596 | }; | ||
| 597 | |||
| 598 | static const int hsv_blue_x[] = { | ||
| 599 | 112, 113, 114, 114, 115, 116, 117, 117, | ||
| 600 | 118, 118, 119, 119, 120, 120, 120, 121, | ||
| 601 | 121, 121, 122, 122, 122, 122, 122, 122, | ||
| 602 | 122, 122, 122, 122, 122, 122, 121, 121, | ||
| 603 | 121, 120, 120, 120, 119, 119, 118, 118, | ||
| 604 | 117, 116, 116, 115, 114, 113, 113, 112, | ||
| 605 | 111, 110, 109, 108, 107, 106, 105, 104, | ||
| 606 | 103, 102, 100, 99, 98, 97, 95, 94, | ||
| 607 | 93, 91, 90, 88, 87, 85, 84, 82, | ||
| 608 | 80, 79, 77, 76, 74, 72, 70, 69, | ||
| 609 | 67, 65, 63, 61, 60, 58, 56, 54, | ||
| 610 | 52, 50, 48, 46, 44, 42, 40, 38, | ||
| 611 | 36, 34, 32, 30, 28, 26, 24, 22, | ||
| 612 | 19, 17, 15, 13, 11, 9, 7, 5, | ||
| 613 | 2, 0, -1, -3, -5, -7, -9, -12, | ||
| 614 | -14, -16, -18, -20, -22, -24, -26, -28, | ||
| 615 | -31, -33, -35, -37, -39, -41, -43, -45, | ||
| 616 | -47, -49, -51, -53, -54, -56, -58, -60, | ||
| 617 | -62, -64, -66, -67, -69, -71, -73, -74, | ||
| 618 | -76, -78, -79, -81, -83, -84, -86, -87, | ||
| 619 | -89, -90, -92, -93, -94, -96, -97, -98, | ||
| 620 | -99, -101, -102, -103, -104, -105, -106, -107, | ||
| 621 | -108, -109, -110, -111, -112, -113, -114, -114, | ||
| 622 | -115, -116, -117, -117, -118, -118, -119, -119, | ||
| 623 | -120, -120, -120, -121, -121, -121, -122, -122, | ||
| 624 | -122, -122, -122, -122, -122, -122, -122, -122, | ||
| 625 | -122, -122, -121, -121, -121, -120, -120, -120, | ||
| 626 | -119, -119, -118, -118, -117, -116, -116, -115, | ||
| 627 | -114, -113, -113, -112, -111, -110, -109, -108, | ||
| 628 | -107, -106, -105, -104, -103, -102, -100, -99, | ||
| 629 | -98, -97, -95, -94, -93, -91, -90, -88, | ||
| 630 | -87, -85, -84, -82, -80, -79, -77, -76, | ||
| 631 | -74, -72, -70, -69, -67, -65, -63, -61, | ||
| 632 | -60, -58, -56, -54, -52, -50, -48, -46, | ||
| 633 | -44, -42, -40, -38, -36, -34, -32, -30, | ||
| 634 | -28, -26, -24, -22, -19, -17, -15, -13, | ||
| 635 | -11, -9, -7, -5, -2, 0, 1, 3, | ||
| 636 | 5, 7, 9, 12, 14, 16, 18, 20, | ||
| 637 | 22, 24, 26, 28, 31, 33, 35, 37, | ||
| 638 | 39, 41, 43, 45, 47, 49, 51, 53, | ||
| 639 | 54, 56, 58, 60, 62, 64, 66, 67, | ||
| 640 | 69, 71, 73, 74, 76, 78, 79, 81, | ||
| 641 | 83, 84, 86, 87, 89, 90, 92, 93, | ||
| 642 | 94, 96, 97, 98, 99, 101, 102, 103, | ||
| 643 | 104, 105, 106, 107, 108, 109, 110, 111, 112 | ||
| 644 | }; | ||
| 645 | |||
| 646 | static const int hsv_blue_y[] = { | ||
| 647 | -11, -13, -15, -17, -19, -21, -23, -25, | ||
| 648 | -27, -29, -31, -33, -35, -37, -39, -41, | ||
| 649 | -43, -45, -46, -48, -50, -52, -54, -55, | ||
| 650 | -57, -59, -61, -62, -64, -66, -67, -69, | ||
| 651 | -71, -72, -74, -75, -77, -78, -80, -81, | ||
| 652 | -83, -84, -86, -87, -88, -90, -91, -92, | ||
| 653 | -93, -95, -96, -97, -98, -99, -100, -101, | ||
| 654 | -102, -103, -104, -105, -106, -106, -107, -108, | ||
| 655 | -109, -109, -110, -111, -111, -112, -112, -113, | ||
| 656 | -113, -114, -114, -114, -115, -115, -115, -115, | ||
| 657 | -116, -116, -116, -116, -116, -116, -116, -116, | ||
| 658 | -116, -115, -115, -115, -115, -114, -114, -114, | ||
| 659 | -113, -113, -112, -112, -111, -111, -110, -110, | ||
| 660 | -109, -108, -108, -107, -106, -105, -104, -103, | ||
| 661 | -102, -101, -100, -99, -98, -97, -96, -95, | ||
| 662 | -94, -93, -91, -90, -89, -88, -86, -85, | ||
| 663 | -84, -82, -81, -79, -78, -76, -75, -73, | ||
| 664 | -71, -70, -68, -67, -65, -63, -62, -60, | ||
| 665 | -58, -56, -55, -53, -51, -49, -47, -45, | ||
| 666 | -44, -42, -40, -38, -36, -34, -32, -30, | ||
| 667 | -28, -26, -24, -22, -20, -18, -16, -14, | ||
| 668 | -12, -10, -8, -6, -4, -2, 0, 1, | ||
| 669 | 3, 5, 7, 9, 11, 13, 15, 17, | ||
| 670 | 19, 21, 23, 25, 27, 29, 31, 33, | ||
| 671 | 35, 37, 39, 41, 43, 45, 46, 48, | ||
| 672 | 50, 52, 54, 55, 57, 59, 61, 62, | ||
| 673 | 64, 66, 67, 69, 71, 72, 74, 75, | ||
| 674 | 77, 78, 80, 81, 83, 84, 86, 87, | ||
| 675 | 88, 90, 91, 92, 93, 95, 96, 97, | ||
| 676 | 98, 99, 100, 101, 102, 103, 104, 105, | ||
| 677 | 106, 106, 107, 108, 109, 109, 110, 111, | ||
| 678 | 111, 112, 112, 113, 113, 114, 114, 114, | ||
| 679 | 115, 115, 115, 115, 116, 116, 116, 116, | ||
| 680 | 116, 116, 116, 116, 116, 115, 115, 115, | ||
| 681 | 115, 114, 114, 114, 113, 113, 112, 112, | ||
| 682 | 111, 111, 110, 110, 109, 108, 108, 107, | ||
| 683 | 106, 105, 104, 103, 102, 101, 100, 99, | ||
| 684 | 98, 97, 96, 95, 94, 93, 91, 90, | ||
| 685 | 89, 88, 86, 85, 84, 82, 81, 79, | ||
| 686 | 78, 76, 75, 73, 71, 70, 68, 67, | ||
| 687 | 65, 63, 62, 60, 58, 56, 55, 53, | ||
| 688 | 51, 49, 47, 45, 44, 42, 40, 38, | ||
| 689 | 36, 34, 32, 30, 28, 26, 24, 22, | ||
| 690 | 20, 18, 16, 14, 12, 10, 8, 6, | ||
| 691 | 4, 2, 0, -1, -3, -5, -7, -9, -11 | ||
| 692 | }; | ||
| 693 | |||
| 694 | static u16 i2c_ident[] = { | ||
| 695 | V4L2_IDENT_OV9650, | ||
| 696 | V4L2_IDENT_OV9655, | ||
| 697 | V4L2_IDENT_SOI968, | ||
| 698 | V4L2_IDENT_OV7660, | ||
| 699 | V4L2_IDENT_OV7670, | ||
| 700 | V4L2_IDENT_MT9V011, | ||
| 701 | V4L2_IDENT_MT9V111, | ||
| 702 | V4L2_IDENT_MT9V112, | ||
| 703 | V4L2_IDENT_MT9M001C12ST, | ||
| 704 | V4L2_IDENT_MT9M111, | ||
| 705 | V4L2_IDENT_HV7131R, | ||
| 706 | }; | ||
| 707 | |||
| 708 | static u16 bridge_init[][2] = { | ||
| 709 | {0x1000, 0x78}, {0x1001, 0x40}, {0x1002, 0x1c}, | ||
| 710 | {0x1020, 0x80}, {0x1061, 0x01}, {0x1067, 0x40}, | ||
| 711 | {0x1068, 0x30}, {0x1069, 0x20}, {0x106a, 0x10}, | ||
| 712 | {0x106b, 0x08}, {0x1188, 0x87}, {0x11a1, 0x00}, | ||
| 713 | {0x11a2, 0x00}, {0x11a3, 0x6a}, {0x11a4, 0x50}, | ||
| 714 | {0x11ab, 0x00}, {0x11ac, 0x00}, {0x11ad, 0x50}, | ||
| 715 | {0x11ae, 0x3c}, {0x118a, 0x04}, {0x0395, 0x04}, | ||
| 716 | {0x11b8, 0x3a}, {0x118b, 0x0e}, {0x10f7, 0x05}, | ||
| 717 | {0x10f8, 0x14}, {0x10fa, 0xff}, {0x10f9, 0x00}, | ||
| 718 | {0x11ba, 0x0a}, {0x11a5, 0x2d}, {0x11a6, 0x2d}, | ||
| 719 | {0x11a7, 0x3a}, {0x11a8, 0x05}, {0x11a9, 0x04}, | ||
| 720 | {0x11aa, 0x3f}, {0x11af, 0x28}, {0x11b0, 0xd8}, | ||
| 721 | {0x11b1, 0x14}, {0x11b2, 0xec}, {0x11b3, 0x32}, | ||
| 722 | {0x11b4, 0xdd}, {0x11b5, 0x32}, {0x11b6, 0xdd}, | ||
| 723 | {0x10e0, 0x2c}, {0x11bc, 0x40}, {0x11bd, 0x01}, | ||
| 724 | {0x11be, 0xf0}, {0x11bf, 0x00}, {0x118c, 0x1f}, | ||
| 725 | {0x118d, 0x1f}, {0x118e, 0x1f}, {0x118f, 0x1f}, | ||
| 726 | {0x1180, 0x01}, {0x1181, 0x00}, {0x1182, 0x01}, | ||
| 727 | {0x1183, 0x00}, {0x1184, 0x50}, {0x1185, 0x80} | ||
| 728 | }; | ||
| 729 | |||
| 730 | /* Gain = (bit[3:0] / 16 + 1) * (bit[4] + 1) * (bit[5] + 1) * (bit[6] + 1) */ | ||
| 731 | static u8 ov_gain[] = { | ||
| 732 | 0x00 /* 1x */, 0x04 /* 1.25x */, 0x08 /* 1.5x */, 0x0c /* 1.75x */, | ||
| 733 | 0x10 /* 2x */, 0x12 /* 2.25x */, 0x14 /* 2.5x */, 0x16 /* 2.75x */, | ||
| 734 | 0x18 /* 3x */, 0x1a /* 3.25x */, 0x1c /* 3.5x */, 0x1e /* 3.75x */, | ||
| 735 | 0x30 /* 4x */, 0x31 /* 4.25x */, 0x32 /* 4.5x */, 0x33 /* 4.75x */, | ||
| 736 | 0x34 /* 5x */, 0x35 /* 5.25x */, 0x36 /* 5.5x */, 0x37 /* 5.75x */, | ||
| 737 | 0x38 /* 6x */, 0x39 /* 6.25x */, 0x3a /* 6.5x */, 0x3b /* 6.75x */, | ||
| 738 | 0x3c /* 7x */, 0x3d /* 7.25x */, 0x3e /* 7.5x */, 0x3f /* 7.75x */, | ||
| 739 | 0x70 /* 8x */ | ||
| 740 | }; | ||
| 741 | |||
| 742 | /* Gain = (bit[8] + 1) * (bit[7] + 1) * (bit[6:0] * 0.03125) */ | ||
| 743 | static u16 micron1_gain[] = { | ||
| 744 | /* 1x 1.25x 1.5x 1.75x */ | ||
| 745 | 0x0020, 0x0028, 0x0030, 0x0038, | ||
| 746 | /* 2x 2.25x 2.5x 2.75x */ | ||
| 747 | 0x00a0, 0x00a4, 0x00a8, 0x00ac, | ||
| 748 | /* 3x 3.25x 3.5x 3.75x */ | ||
| 749 | 0x00b0, 0x00b4, 0x00b8, 0x00bc, | ||
| 750 | /* 4x 4.25x 4.5x 4.75x */ | ||
| 751 | 0x00c0, 0x00c4, 0x00c8, 0x00cc, | ||
| 752 | /* 5x 5.25x 5.5x 5.75x */ | ||
| 753 | 0x00d0, 0x00d4, 0x00d8, 0x00dc, | ||
| 754 | /* 6x 6.25x 6.5x 6.75x */ | ||
| 755 | 0x00e0, 0x00e4, 0x00e8, 0x00ec, | ||
| 756 | /* 7x 7.25x 7.5x 7.75x */ | ||
| 757 | 0x00f0, 0x00f4, 0x00f8, 0x00fc, | ||
| 758 | /* 8x */ | ||
| 759 | 0x01c0 | ||
| 760 | }; | ||
| 761 | |||
| 762 | /* mt9m001 sensor uses a different gain formula then other micron sensors */ | ||
| 763 | /* Gain = (bit[6] + 1) * (bit[5-0] * 0.125) */ | ||
| 764 | static u16 micron2_gain[] = { | ||
| 765 | /* 1x 1.25x 1.5x 1.75x */ | ||
| 766 | 0x0008, 0x000a, 0x000c, 0x000e, | ||
| 767 | /* 2x 2.25x 2.5x 2.75x */ | ||
| 768 | 0x0010, 0x0012, 0x0014, 0x0016, | ||
| 769 | /* 3x 3.25x 3.5x 3.75x */ | ||
| 770 | 0x0018, 0x001a, 0x001c, 0x001e, | ||
| 771 | /* 4x 4.25x 4.5x 4.75x */ | ||
| 772 | 0x0020, 0x0051, 0x0052, 0x0053, | ||
| 773 | /* 5x 5.25x 5.5x 5.75x */ | ||
| 774 | 0x0054, 0x0055, 0x0056, 0x0057, | ||
| 775 | /* 6x 6.25x 6.5x 6.75x */ | ||
| 776 | 0x0058, 0x0059, 0x005a, 0x005b, | ||
| 777 | /* 7x 7.25x 7.5x 7.75x */ | ||
| 778 | 0x005c, 0x005d, 0x005e, 0x005f, | ||
| 779 | /* 8x */ | ||
| 780 | 0x0060 | ||
| 781 | }; | ||
| 782 | |||
| 783 | /* Gain = .5 + bit[7:0] / 16 */ | ||
| 784 | static u8 hv7131r_gain[] = { | ||
| 785 | 0x08 /* 1x */, 0x0c /* 1.25x */, 0x10 /* 1.5x */, 0x14 /* 1.75x */, | ||
| 786 | 0x18 /* 2x */, 0x1c /* 2.25x */, 0x20 /* 2.5x */, 0x24 /* 2.75x */, | ||
| 787 | 0x28 /* 3x */, 0x2c /* 3.25x */, 0x30 /* 3.5x */, 0x34 /* 3.75x */, | ||
| 788 | 0x38 /* 4x */, 0x3c /* 4.25x */, 0x40 /* 4.5x */, 0x44 /* 4.75x */, | ||
| 789 | 0x48 /* 5x */, 0x4c /* 5.25x */, 0x50 /* 5.5x */, 0x54 /* 5.75x */, | ||
| 790 | 0x58 /* 6x */, 0x5c /* 6.25x */, 0x60 /* 6.5x */, 0x64 /* 6.75x */, | ||
| 791 | 0x68 /* 7x */, 0x6c /* 7.25x */, 0x70 /* 7.5x */, 0x74 /* 7.75x */, | ||
| 792 | 0x78 /* 8x */ | ||
| 793 | }; | ||
| 794 | |||
| 795 | static u8 soi968_init[][2] = { | ||
| 796 | {0x12, 0x80}, {0x0c, 0x00}, {0x0f, 0x1f}, | ||
| 797 | {0x11, 0x80}, {0x38, 0x52}, {0x1e, 0x00}, | ||
| 798 | {0x33, 0x08}, {0x35, 0x8c}, {0x36, 0x0c}, | ||
| 799 | {0x37, 0x04}, {0x45, 0x04}, {0x47, 0xff}, | ||
| 800 | {0x3e, 0x00}, {0x3f, 0x00}, {0x3b, 0x20}, | ||
| 801 | {0x3a, 0x96}, {0x3d, 0x0a}, {0x14, 0x8e}, | ||
| 802 | {0x13, 0x8a}, {0x12, 0x40}, {0x17, 0x13}, | ||
| 803 | {0x18, 0x63}, {0x19, 0x01}, {0x1a, 0x79}, | ||
| 804 | {0x32, 0x24}, {0x03, 0x00}, {0x11, 0x40}, | ||
| 805 | {0x2a, 0x10}, {0x2b, 0xe0}, {0x10, 0x32}, | ||
| 806 | {0x00, 0x00}, {0x01, 0x80}, {0x02, 0x80}, | ||
| 807 | }; | ||
| 808 | |||
| 809 | static u8 ov7660_init[][2] = { | ||
| 810 | {0x0e, 0x80}, {0x0d, 0x08}, {0x0f, 0xc3}, | ||
| 811 | {0x04, 0xc3}, {0x10, 0x40}, {0x11, 0x40}, | ||
| 812 | {0x12, 0x05}, {0x13, 0xba}, {0x14, 0x2a}, | ||
| 813 | {0x37, 0x0f}, {0x38, 0x02}, {0x39, 0x43}, | ||
| 814 | {0x3a, 0x00}, {0x69, 0x90}, {0x2d, 0xf6}, | ||
| 815 | {0x2e, 0x0b}, {0x01, 0x78}, {0x02, 0x50}, | ||
| 816 | }; | ||
| 817 | |||
| 818 | static u8 ov7670_init[][2] = { | ||
| 819 | {0x12, 0x80}, {0x11, 0x80}, {0x3a, 0x04}, {0x12, 0x01}, | ||
| 820 | {0x32, 0xb6}, {0x03, 0x0a}, {0x0c, 0x00}, {0x3e, 0x00}, | ||
| 821 | {0x70, 0x3a}, {0x71, 0x35}, {0x72, 0x11}, {0x73, 0xf0}, | ||
| 822 | {0xa2, 0x02}, {0x13, 0xe0}, {0x00, 0x00}, {0x10, 0x00}, | ||
| 823 | {0x0d, 0x40}, {0x14, 0x28}, {0xa5, 0x05}, {0xab, 0x07}, | ||
| 824 | {0x24, 0x95}, {0x25, 0x33}, {0x26, 0xe3}, {0x9f, 0x75}, | ||
| 825 | {0xa0, 0x65}, {0xa1, 0x0b}, {0xa6, 0xd8}, {0xa7, 0xd8}, | ||
| 826 | {0xa8, 0xf0}, {0xa9, 0x90}, {0xaa, 0x94}, {0x13, 0xe5}, | ||
| 827 | {0x0e, 0x61}, {0x0f, 0x4b}, {0x16, 0x02}, {0x1e, 0x27}, | ||
| 828 | {0x21, 0x02}, {0x22, 0x91}, {0x29, 0x07}, {0x33, 0x0b}, | ||
| 829 | {0x35, 0x0b}, {0x37, 0x1d}, {0x38, 0x71}, {0x39, 0x2a}, | ||
| 830 | {0x3c, 0x78}, {0x4d, 0x40}, {0x4e, 0x20}, {0x69, 0x00}, | ||
| 831 | {0x74, 0x19}, {0x8d, 0x4f}, {0x8e, 0x00}, {0x8f, 0x00}, | ||
| 832 | {0x90, 0x00}, {0x91, 0x00}, {0x96, 0x00}, {0x9a, 0x80}, | ||
| 833 | {0xb0, 0x84}, {0xb1, 0x0c}, {0xb2, 0x0e}, {0xb3, 0x82}, | ||
| 834 | {0xb8, 0x0a}, {0x43, 0x0a}, {0x44, 0xf0}, {0x45, 0x20}, | ||
| 835 | {0x46, 0x7d}, {0x47, 0x29}, {0x48, 0x4a}, {0x59, 0x8c}, | ||
| 836 | {0x5a, 0xa5}, {0x5b, 0xde}, {0x5c, 0x96}, {0x5d, 0x66}, | ||
| 837 | {0x5e, 0x10}, {0x6c, 0x0a}, {0x6d, 0x55}, {0x6e, 0x11}, | ||
| 838 | {0x6f, 0x9e}, {0x6a, 0x40}, {0x01, 0x40}, {0x02, 0x40}, | ||
| 839 | {0x13, 0xe7}, {0x4f, 0x6e}, {0x50, 0x70}, {0x51, 0x02}, | ||
| 840 | {0x52, 0x1d}, {0x53, 0x56}, {0x54, 0x73}, {0x55, 0x0a}, | ||
| 841 | {0x56, 0x55}, {0x57, 0x80}, {0x58, 0x9e}, {0x41, 0x08}, | ||
| 842 | {0x3f, 0x02}, {0x75, 0x03}, {0x76, 0x63}, {0x4c, 0x04}, | ||
| 843 | {0x77, 0x06}, {0x3d, 0x02}, {0x4b, 0x09}, {0xc9, 0x30}, | ||
| 844 | {0x41, 0x08}, {0x56, 0x48}, {0x34, 0x11}, {0xa4, 0x88}, | ||
| 845 | {0x96, 0x00}, {0x97, 0x30}, {0x98, 0x20}, {0x99, 0x30}, | ||
| 846 | {0x9a, 0x84}, {0x9b, 0x29}, {0x9c, 0x03}, {0x9d, 0x99}, | ||
| 847 | {0x9e, 0x7f}, {0x78, 0x04}, {0x79, 0x01}, {0xc8, 0xf0}, | ||
| 848 | {0x79, 0x0f}, {0xc8, 0x00}, {0x79, 0x10}, {0xc8, 0x7e}, | ||
| 849 | {0x79, 0x0a}, {0xc8, 0x80}, {0x79, 0x0b}, {0xc8, 0x01}, | ||
| 850 | {0x79, 0x0c}, {0xc8, 0x0f}, {0x79, 0x0d}, {0xc8, 0x20}, | ||
| 851 | {0x79, 0x09}, {0xc8, 0x80}, {0x79, 0x02}, {0xc8, 0xc0}, | ||
| 852 | {0x79, 0x03}, {0xc8, 0x40}, {0x79, 0x05}, {0xc8, 0x30}, | ||
| 853 | {0x79, 0x26}, {0x62, 0x20}, {0x63, 0x00}, {0x64, 0x06}, | ||
| 854 | {0x65, 0x00}, {0x66, 0x05}, {0x94, 0x05}, {0x95, 0x0a}, | ||
| 855 | {0x17, 0x13}, {0x18, 0x01}, {0x19, 0x02}, {0x1a, 0x7a}, | ||
| 856 | {0x46, 0x59}, {0x47, 0x30}, {0x58, 0x9a}, {0x59, 0x84}, | ||
| 857 | {0x5a, 0x91}, {0x5b, 0x57}, {0x5c, 0x75}, {0x5d, 0x6d}, | ||
| 858 | {0x5e, 0x13}, {0x64, 0x07}, {0x94, 0x07}, {0x95, 0x0d}, | ||
| 859 | {0xa6, 0xdf}, {0xa7, 0xdf}, {0x48, 0x4d}, {0x51, 0x00}, | ||
| 860 | {0x6b, 0x0a}, {0x11, 0x80}, {0x2a, 0x00}, {0x2b, 0x00}, | ||
| 861 | {0x92, 0x00}, {0x93, 0x00}, {0x55, 0x0a}, {0x56, 0x60}, | ||
| 862 | {0x4f, 0x6e}, {0x50, 0x70}, {0x51, 0x00}, {0x52, 0x1d}, | ||
| 863 | {0x53, 0x56}, {0x54, 0x73}, {0x58, 0x9a}, {0x4f, 0x6e}, | ||
| 864 | {0x50, 0x70}, {0x51, 0x00}, {0x52, 0x1d}, {0x53, 0x56}, | ||
| 865 | {0x54, 0x73}, {0x58, 0x9a}, {0x3f, 0x01}, {0x7b, 0x03}, | ||
| 866 | {0x7c, 0x09}, {0x7d, 0x16}, {0x7e, 0x38}, {0x7f, 0x47}, | ||
| 867 | {0x80, 0x53}, {0x81, 0x5e}, {0x82, 0x6a}, {0x83, 0x74}, | ||
| 868 | {0x84, 0x80}, {0x85, 0x8c}, {0x86, 0x9b}, {0x87, 0xb2}, | ||
| 869 | {0x88, 0xcc}, {0x89, 0xe5}, {0x7a, 0x24}, {0x3b, 0x00}, | ||
| 870 | {0x9f, 0x76}, {0xa0, 0x65}, {0x13, 0xe2}, {0x6b, 0x0a}, | ||
| 871 | {0x11, 0x80}, {0x2a, 0x00}, {0x2b, 0x00}, {0x92, 0x00}, | ||
| 872 | {0x93, 0x00}, | ||
| 873 | }; | ||
| 874 | |||
| 875 | static u8 ov9650_init[][2] = { | ||
| 876 | {0x12, 0x80}, {0x00, 0x00}, {0x01, 0x78}, | ||
| 877 | {0x02, 0x78}, {0x03, 0x36}, {0x04, 0x03}, | ||
| 878 | {0x05, 0x00}, {0x06, 0x00}, {0x08, 0x00}, | ||
| 879 | {0x09, 0x01}, {0x0c, 0x00}, {0x0d, 0x00}, | ||
| 880 | {0x0e, 0xa0}, {0x0f, 0x52}, {0x10, 0x7c}, | ||
| 881 | {0x11, 0x80}, {0x12, 0x45}, {0x13, 0xc2}, | ||
| 882 | {0x14, 0x2e}, {0x15, 0x00}, {0x16, 0x07}, | ||
| 883 | {0x17, 0x24}, {0x18, 0xc5}, {0x19, 0x00}, | ||
| 884 | {0x1a, 0x3c}, {0x1b, 0x00}, {0x1e, 0x04}, | ||
| 885 | {0x1f, 0x00}, {0x24, 0x78}, {0x25, 0x68}, | ||
| 886 | {0x26, 0xd4}, {0x27, 0x80}, {0x28, 0x80}, | ||
| 887 | {0x29, 0x30}, {0x2a, 0x00}, {0x2b, 0x00}, | ||
| 888 | {0x2c, 0x80}, {0x2d, 0x00}, {0x2e, 0x00}, | ||
| 889 | {0x2f, 0x00}, {0x30, 0x08}, {0x31, 0x30}, | ||
| 890 | {0x32, 0x84}, {0x33, 0xe2}, {0x34, 0xbf}, | ||
| 891 | {0x35, 0x81}, {0x36, 0xf9}, {0x37, 0x00}, | ||
| 892 | {0x38, 0x93}, {0x39, 0x50}, {0x3a, 0x01}, | ||
| 893 | {0x3b, 0x01}, {0x3c, 0x73}, {0x3d, 0x19}, | ||
| 894 | {0x3e, 0x0b}, {0x3f, 0x80}, {0x40, 0xc1}, | ||
| 895 | {0x41, 0x00}, {0x42, 0x08}, {0x67, 0x80}, | ||
| 896 | {0x68, 0x80}, {0x69, 0x40}, {0x6a, 0x00}, | ||
| 897 | {0x6b, 0x0a}, {0x8b, 0x06}, {0x8c, 0x20}, | ||
| 898 | {0x8d, 0x00}, {0x8e, 0x00}, {0x8f, 0xdf}, | ||
| 899 | {0x92, 0x00}, {0x93, 0x00}, {0x94, 0x88}, | ||
| 900 | {0x95, 0x88}, {0x96, 0x04}, {0xa1, 0x00}, | ||
| 901 | {0xa5, 0x80}, {0xa8, 0x80}, {0xa9, 0xb8}, | ||
| 902 | {0xaa, 0x92}, {0xab, 0x0a}, | ||
| 903 | }; | ||
| 904 | |||
| 905 | static u8 ov9655_init[][2] = { | ||
| 906 | {0x12, 0x80}, {0x12, 0x01}, {0x0d, 0x00}, {0x0e, 0x61}, | ||
| 907 | {0x11, 0x80}, {0x13, 0xba}, {0x14, 0x2e}, {0x16, 0x24}, | ||
| 908 | {0x1e, 0x04}, {0x1e, 0x04}, {0x1e, 0x04}, {0x27, 0x08}, | ||
| 909 | {0x28, 0x08}, {0x29, 0x15}, {0x2c, 0x08}, {0x32, 0xbf}, | ||
| 910 | {0x34, 0x3d}, {0x35, 0x00}, {0x36, 0xf8}, {0x38, 0x12}, | ||
| 911 | {0x39, 0x57}, {0x3a, 0x00}, {0x3b, 0xcc}, {0x3c, 0x0c}, | ||
| 912 | {0x3d, 0x19}, {0x3e, 0x0c}, {0x3f, 0x01}, {0x41, 0x40}, | ||
| 913 | {0x42, 0x80}, {0x45, 0x46}, {0x46, 0x62}, {0x47, 0x2a}, | ||
| 914 | {0x48, 0x3c}, {0x4a, 0xf0}, {0x4b, 0xdc}, {0x4c, 0xdc}, | ||
| 915 | {0x4d, 0xdc}, {0x4e, 0xdc}, {0x69, 0x02}, {0x6c, 0x04}, | ||
| 916 | {0x6f, 0x9e}, {0x70, 0x05}, {0x71, 0x78}, {0x77, 0x02}, | ||
| 917 | {0x8a, 0x23}, {0x8c, 0x0d}, {0x90, 0x7e}, {0x91, 0x7c}, | ||
| 918 | {0x9f, 0x6e}, {0xa0, 0x6e}, {0xa5, 0x68}, {0xa6, 0x60}, | ||
| 919 | {0xa8, 0xc1}, {0xa9, 0xfa}, {0xaa, 0x92}, {0xab, 0x04}, | ||
| 920 | {0xac, 0x80}, {0xad, 0x80}, {0xae, 0x80}, {0xaf, 0x80}, | ||
| 921 | {0xb2, 0xf2}, {0xb3, 0x20}, {0xb5, 0x00}, {0xb6, 0xaf}, | ||
| 922 | {0xbb, 0xae}, {0xbc, 0x44}, {0xbd, 0x44}, {0xbe, 0x3b}, | ||
| 923 | {0xbf, 0x3a}, {0xc0, 0xe2}, {0xc1, 0xc8}, {0xc2, 0x01}, | ||
| 924 | {0xc4, 0x00}, {0xc6, 0x85}, {0xc7, 0x81}, {0xc9, 0xe0}, | ||
| 925 | {0xca, 0xe8}, {0xcc, 0xd8}, {0xcd, 0x93}, {0x12, 0x61}, | ||
| 926 | {0x36, 0xfa}, {0x8c, 0x8d}, {0xc0, 0xaa}, {0x69, 0x0a}, | ||
| 927 | {0x03, 0x12}, {0x17, 0x14}, {0x18, 0x00}, {0x19, 0x01}, | ||
| 928 | {0x1a, 0x3d}, {0x32, 0xbf}, {0x11, 0x80}, {0x2a, 0x10}, | ||
| 929 | {0x2b, 0x0a}, {0x92, 0x00}, {0x93, 0x00}, {0x1e, 0x04}, | ||
| 930 | {0x1e, 0x04}, {0x10, 0x7c}, {0x04, 0x03}, {0xa1, 0x00}, | ||
| 931 | {0x2d, 0x00}, {0x2e, 0x00}, {0x00, 0x00}, {0x01, 0x80}, | ||
| 932 | {0x02, 0x80}, {0x12, 0x61}, {0x36, 0xfa}, {0x8c, 0x8d}, | ||
| 933 | {0xc0, 0xaa}, {0x69, 0x0a}, {0x03, 0x12}, {0x17, 0x14}, | ||
| 934 | {0x18, 0x00}, {0x19, 0x01}, {0x1a, 0x3d}, {0x32, 0xbf}, | ||
| 935 | {0x11, 0x80}, {0x2a, 0x10}, {0x2b, 0x0a}, {0x92, 0x00}, | ||
| 936 | {0x93, 0x00}, {0x04, 0x01}, {0x10, 0x1f}, {0xa1, 0x00}, | ||
| 937 | {0x00, 0x0a}, {0xa1, 0x00}, {0x10, 0x5d}, {0x04, 0x03}, | ||
| 938 | {0x00, 0x01}, {0xa1, 0x00}, {0x10, 0x7c}, {0x04, 0x03}, | ||
| 939 | {0x00, 0x03}, {0x00, 0x0a}, {0x00, 0x10}, {0x00, 0x13}, | ||
| 940 | }; | ||
| 941 | |||
| 942 | static u16 mt9v112_init[][2] = { | ||
| 943 | {0xf0, 0x0000}, {0x0d, 0x0021}, {0x0d, 0x0020}, | ||
| 944 | {0x34, 0xc019}, {0x0a, 0x0011}, {0x0b, 0x000b}, | ||
| 945 | {0x20, 0x0703}, {0x35, 0x2022}, {0xf0, 0x0001}, | ||
| 946 | {0x05, 0x0000}, {0x06, 0x340c}, {0x3b, 0x042a}, | ||
| 947 | {0x3c, 0x0400}, {0xf0, 0x0002}, {0x2e, 0x0c58}, | ||
| 948 | {0x5b, 0x0001}, {0xc8, 0x9f0b}, {0xf0, 0x0001}, | ||
| 949 | {0x9b, 0x5300}, {0xf0, 0x0000}, {0x2b, 0x0020}, | ||
| 950 | {0x2c, 0x002a}, {0x2d, 0x0032}, {0x2e, 0x0020}, | ||
| 951 | {0x09, 0x01dc}, {0x01, 0x000c}, {0x02, 0x0020}, | ||
| 952 | {0x03, 0x01e0}, {0x04, 0x0280}, {0x06, 0x000c}, | ||
| 953 | {0x05, 0x0098}, {0x20, 0x0703}, {0x09, 0x01f2}, | ||
| 954 | {0x2b, 0x00a0}, {0x2c, 0x00a0}, {0x2d, 0x00a0}, | ||
| 955 | {0x2e, 0x00a0}, {0x01, 0x000c}, {0x02, 0x0020}, | ||
| 956 | {0x03, 0x01e0}, {0x04, 0x0280}, {0x06, 0x000c}, | ||
| 957 | {0x05, 0x0098}, {0x09, 0x01c1}, {0x2b, 0x00ae}, | ||
| 958 | {0x2c, 0x00ae}, {0x2d, 0x00ae}, {0x2e, 0x00ae}, | ||
| 959 | }; | ||
| 960 | |||
| 961 | static u16 mt9v111_init[][2] = { | ||
| 962 | {0x01, 0x0004}, {0x0d, 0x0001}, {0x0d, 0x0000}, | ||
| 963 | {0x01, 0x0001}, {0x02, 0x0016}, {0x03, 0x01e1}, | ||
| 964 | {0x04, 0x0281}, {0x05, 0x0004}, {0x07, 0x3002}, | ||
| 965 | {0x21, 0x0000}, {0x25, 0x4024}, {0x26, 0xff03}, | ||
| 966 | {0x27, 0xff10}, {0x2b, 0x7828}, {0x2c, 0xb43c}, | ||
| 967 | {0x2d, 0xf0a0}, {0x2e, 0x0c64}, {0x2f, 0x0064}, | ||
| 968 | {0x67, 0x4010}, {0x06, 0x301e}, {0x08, 0x0480}, | ||
| 969 | {0x01, 0x0004}, {0x02, 0x0016}, {0x03, 0x01e6}, | ||
| 970 | {0x04, 0x0286}, {0x05, 0x0004}, {0x06, 0x0000}, | ||
| 971 | {0x07, 0x3002}, {0x08, 0x0008}, {0x0c, 0x0000}, | ||
| 972 | {0x0d, 0x0000}, {0x0e, 0x0000}, {0x0f, 0x0000}, | ||
| 973 | {0x10, 0x0000}, {0x11, 0x0000}, {0x12, 0x00b0}, | ||
| 974 | {0x13, 0x007c}, {0x14, 0x0000}, {0x15, 0x0000}, | ||
| 975 | {0x16, 0x0000}, {0x17, 0x0000}, {0x18, 0x0000}, | ||
| 976 | {0x19, 0x0000}, {0x1a, 0x0000}, {0x1b, 0x0000}, | ||
| 977 | {0x1c, 0x0000}, {0x1d, 0x0000}, {0x30, 0x0000}, | ||
| 978 | {0x30, 0x0005}, {0x31, 0x0000}, {0x02, 0x0016}, | ||
| 979 | {0x03, 0x01e1}, {0x04, 0x0281}, {0x05, 0x0004}, | ||
| 980 | {0x06, 0x0000}, {0x07, 0x3002}, {0x06, 0x002d}, | ||
| 981 | {0x05, 0x0004}, {0x09, 0x0064}, {0x2b, 0x00a0}, | ||
| 982 | {0x2c, 0x00a0}, {0x2d, 0x00a0}, {0x2e, 0x00a0}, | ||
| 983 | {0x02, 0x0016}, {0x03, 0x01e1}, {0x04, 0x0281}, | ||
| 984 | {0x05, 0x0004}, {0x06, 0x002d}, {0x07, 0x3002}, | ||
| 985 | {0x0e, 0x0008}, {0x06, 0x002d}, {0x05, 0x0004}, | ||
| 986 | }; | ||
| 987 | |||
| 988 | static u16 mt9v011_init[][2] = { | ||
| 989 | {0x07, 0x0002}, {0x0d, 0x0001}, {0x0d, 0x0000}, | ||
| 990 | {0x01, 0x0008}, {0x02, 0x0016}, {0x03, 0x01e1}, | ||
| 991 | {0x04, 0x0281}, {0x05, 0x0083}, {0x06, 0x0006}, | ||
| 992 | {0x0d, 0x0002}, {0x0a, 0x0000}, {0x0b, 0x0000}, | ||
| 993 | {0x0c, 0x0000}, {0x0d, 0x0000}, {0x0e, 0x0000}, | ||
| 994 | {0x0f, 0x0000}, {0x10, 0x0000}, {0x11, 0x0000}, | ||
| 995 | {0x12, 0x0000}, {0x13, 0x0000}, {0x14, 0x0000}, | ||
| 996 | {0x15, 0x0000}, {0x16, 0x0000}, {0x17, 0x0000}, | ||
| 997 | {0x18, 0x0000}, {0x19, 0x0000}, {0x1a, 0x0000}, | ||
| 998 | {0x1b, 0x0000}, {0x1c, 0x0000}, {0x1d, 0x0000}, | ||
| 999 | {0x32, 0x0000}, {0x20, 0x1101}, {0x21, 0x0000}, | ||
| 1000 | {0x22, 0x0000}, {0x23, 0x0000}, {0x24, 0x0000}, | ||
| 1001 | {0x25, 0x0000}, {0x26, 0x0000}, {0x27, 0x0024}, | ||
| 1002 | {0x2f, 0xf7b0}, {0x30, 0x0005}, {0x31, 0x0000}, | ||
| 1003 | {0x32, 0x0000}, {0x33, 0x0000}, {0x34, 0x0100}, | ||
| 1004 | {0x3d, 0x068f}, {0x40, 0x01e0}, {0x41, 0x00d1}, | ||
| 1005 | {0x44, 0x0082}, {0x5a, 0x0000}, {0x5b, 0x0000}, | ||
| 1006 | {0x5c, 0x0000}, {0x5d, 0x0000}, {0x5e, 0x0000}, | ||
| 1007 | {0x5f, 0xa31d}, {0x62, 0x0611}, {0x0a, 0x0000}, | ||
| 1008 | {0x06, 0x0029}, {0x05, 0x0009}, {0x20, 0x1101}, | ||
| 1009 | {0x20, 0x1101}, {0x09, 0x0064}, {0x07, 0x0003}, | ||
| 1010 | {0x2b, 0x0033}, {0x2c, 0x00a0}, {0x2d, 0x00a0}, | ||
| 1011 | {0x2e, 0x0033}, {0x07, 0x0002}, {0x06, 0x0000}, | ||
| 1012 | {0x06, 0x0029}, {0x05, 0x0009}, | ||
| 1013 | }; | ||
| 1014 | |||
| 1015 | static u16 mt9m001_init[][2] = { | ||
| 1016 | {0x0d, 0x0001}, {0x0d, 0x0000}, {0x01, 0x000e}, | ||
| 1017 | {0x02, 0x0014}, {0x03, 0x03c1}, {0x04, 0x0501}, | ||
| 1018 | {0x05, 0x0083}, {0x06, 0x0006}, {0x0d, 0x0002}, | ||
| 1019 | {0x0a, 0x0000}, {0x0c, 0x0000}, {0x11, 0x0000}, | ||
| 1020 | {0x1e, 0x8000}, {0x5f, 0x8904}, {0x60, 0x0000}, | ||
| 1021 | {0x61, 0x0000}, {0x62, 0x0498}, {0x63, 0x0000}, | ||
| 1022 | {0x64, 0x0000}, {0x20, 0x111d}, {0x06, 0x00f2}, | ||
| 1023 | {0x05, 0x0013}, {0x09, 0x10f2}, {0x07, 0x0003}, | ||
| 1024 | {0x2b, 0x002a}, {0x2d, 0x002a}, {0x2c, 0x002a}, | ||
| 1025 | {0x2e, 0x0029}, {0x07, 0x0002}, | ||
| 1026 | }; | ||
| 1027 | |||
| 1028 | static u16 mt9m111_init[][2] = { | ||
| 1029 | {0xf0, 0x0000}, {0x0d, 0x0008}, {0x0d, 0x0009}, | ||
| 1030 | {0x0d, 0x0008}, {0xf0, 0x0001}, {0x3a, 0x4300}, | ||
| 1031 | {0x9b, 0x4300}, {0xa1, 0x0280}, {0xa4, 0x0200}, | ||
| 1032 | {0x06, 0x308e}, {0xf0, 0x0000}, | ||
| 1033 | }; | ||
| 1034 | |||
| 1035 | static u8 hv7131r_init[][2] = { | ||
| 1036 | {0x02, 0x08}, {0x02, 0x00}, {0x01, 0x08}, | ||
| 1037 | {0x02, 0x00}, {0x20, 0x00}, {0x21, 0xd0}, | ||
| 1038 | {0x22, 0x00}, {0x23, 0x09}, {0x01, 0x08}, | ||
| 1039 | {0x01, 0x08}, {0x01, 0x08}, {0x25, 0x07}, | ||
| 1040 | {0x26, 0xc3}, {0x27, 0x50}, {0x30, 0x62}, | ||
| 1041 | {0x31, 0x10}, {0x32, 0x06}, {0x33, 0x10}, | ||
| 1042 | {0x20, 0x00}, {0x21, 0xd0}, {0x22, 0x00}, | ||
| 1043 | {0x23, 0x09}, {0x01, 0x08}, | ||
| 1044 | }; | ||
| 1045 | |||
| 1046 | int reg_r(struct gspca_dev *gspca_dev, u16 reg, u16 length) | ||
| 1047 | { | ||
| 1048 | struct usb_device *dev = gspca_dev->dev; | ||
| 1049 | int result; | ||
| 1050 | result = usb_control_msg(dev, usb_rcvctrlpipe(dev, 0), | ||
| 1051 | 0x00, | ||
| 1052 | USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_INTERFACE, | ||
| 1053 | reg, | ||
| 1054 | 0x00, | ||
| 1055 | gspca_dev->usb_buf, | ||
| 1056 | length, | ||
| 1057 | 500); | ||
| 1058 | if (unlikely(result < 0 || result != length)) { | ||
| 1059 | err("Read register failed 0x%02X", reg); | ||
| 1060 | return -EIO; | ||
| 1061 | } | ||
| 1062 | return 0; | ||
| 1063 | } | ||
| 1064 | |||
| 1065 | int reg_w(struct gspca_dev *gspca_dev, u16 reg, const u8 *buffer, int length) | ||
| 1066 | { | ||
| 1067 | struct usb_device *dev = gspca_dev->dev; | ||
| 1068 | int result; | ||
| 1069 | memcpy(gspca_dev->usb_buf, buffer, length); | ||
| 1070 | result = usb_control_msg(dev, usb_sndctrlpipe(dev, 0), | ||
| 1071 | 0x08, | ||
| 1072 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_INTERFACE, | ||
| 1073 | reg, | ||
| 1074 | 0x00, | ||
| 1075 | gspca_dev->usb_buf, | ||
| 1076 | length, | ||
| 1077 | 500); | ||
| 1078 | if (unlikely(result < 0 || result != length)) { | ||
| 1079 | err("Write register failed index 0x%02X", reg); | ||
| 1080 | return -EIO; | ||
| 1081 | } | ||
| 1082 | return 0; | ||
| 1083 | } | ||
| 1084 | |||
| 1085 | int reg_w1(struct gspca_dev *gspca_dev, u16 reg, const u8 value) | ||
| 1086 | { | ||
| 1087 | u8 data[1] = {value}; | ||
| 1088 | return reg_w(gspca_dev, reg, data, 1); | ||
| 1089 | } | ||
| 1090 | |||
| 1091 | int i2c_w(struct gspca_dev *gspca_dev, const u8 *buffer) | ||
| 1092 | { | ||
| 1093 | int i; | ||
| 1094 | reg_w(gspca_dev, 0x10c0, buffer, 8); | ||
| 1095 | for (i = 0; i < 5; i++) { | ||
| 1096 | reg_r(gspca_dev, 0x10c0, 1); | ||
| 1097 | if (gspca_dev->usb_buf[0] & 0x04) { | ||
| 1098 | if (gspca_dev->usb_buf[0] & 0x08) | ||
| 1099 | return -1; | ||
| 1100 | return 0; | ||
| 1101 | } | ||
| 1102 | msleep(1); | ||
| 1103 | } | ||
| 1104 | return -1; | ||
| 1105 | } | ||
| 1106 | |||
| 1107 | int i2c_w1(struct gspca_dev *gspca_dev, u8 reg, u8 val) | ||
| 1108 | { | ||
| 1109 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1110 | |||
| 1111 | u8 row[8]; | ||
| 1112 | |||
| 1113 | /* | ||
| 1114 | * from the point of view of the bridge, the length | ||
| 1115 | * includes the address | ||
| 1116 | */ | ||
| 1117 | row[0] = 0x81 | (2 << 4); | ||
| 1118 | row[1] = sd->i2c_addr; | ||
| 1119 | row[2] = reg; | ||
| 1120 | row[3] = val; | ||
| 1121 | row[4] = 0x00; | ||
| 1122 | row[5] = 0x00; | ||
| 1123 | row[6] = 0x00; | ||
| 1124 | row[7] = 0x10; | ||
| 1125 | |||
| 1126 | return i2c_w(gspca_dev, row); | ||
| 1127 | } | ||
| 1128 | |||
| 1129 | int i2c_w2(struct gspca_dev *gspca_dev, u8 reg, u16 val) | ||
| 1130 | { | ||
| 1131 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1132 | u8 row[8]; | ||
| 1133 | |||
| 1134 | /* | ||
| 1135 | * from the point of view of the bridge, the length | ||
| 1136 | * includes the address | ||
| 1137 | */ | ||
| 1138 | row[0] = 0x81 | (3 << 4); | ||
| 1139 | row[1] = sd->i2c_addr; | ||
| 1140 | row[2] = reg; | ||
| 1141 | row[3] = (val >> 8) & 0xff; | ||
| 1142 | row[4] = val & 0xff; | ||
| 1143 | row[5] = 0x00; | ||
| 1144 | row[6] = 0x00; | ||
| 1145 | row[7] = 0x10; | ||
| 1146 | |||
| 1147 | return i2c_w(gspca_dev, row); | ||
| 1148 | } | ||
| 1149 | |||
| 1150 | int i2c_r1(struct gspca_dev *gspca_dev, u8 reg, u8 *val) | ||
| 1151 | { | ||
| 1152 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1153 | u8 row[8]; | ||
| 1154 | |||
| 1155 | row[0] = 0x81 | 0x10; | ||
| 1156 | row[1] = sd->i2c_addr; | ||
| 1157 | row[2] = reg; | ||
| 1158 | row[3] = 0; | ||
| 1159 | row[4] = 0; | ||
| 1160 | row[5] = 0; | ||
| 1161 | row[6] = 0; | ||
| 1162 | row[7] = 0x10; | ||
| 1163 | reg_w(gspca_dev, 0x10c0, row, 8); | ||
| 1164 | msleep(1); | ||
| 1165 | row[0] = 0x81 | (2 << 4) | 0x02; | ||
| 1166 | row[2] = 0; | ||
| 1167 | reg_w(gspca_dev, 0x10c0, row, 8); | ||
| 1168 | msleep(1); | ||
| 1169 | reg_r(gspca_dev, 0x10c2, 5); | ||
| 1170 | *val = gspca_dev->usb_buf[3]; | ||
| 1171 | return 0; | ||
| 1172 | } | ||
| 1173 | |||
| 1174 | int i2c_r2(struct gspca_dev *gspca_dev, u8 reg, u16 *val) | ||
| 1175 | { | ||
| 1176 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1177 | u8 row[8]; | ||
| 1178 | |||
| 1179 | row[0] = 0x81 | 0x10; | ||
| 1180 | row[1] = sd->i2c_addr; | ||
| 1181 | row[2] = reg; | ||
| 1182 | row[3] = 0; | ||
| 1183 | row[4] = 0; | ||
| 1184 | row[5] = 0; | ||
| 1185 | row[6] = 0; | ||
| 1186 | row[7] = 0x10; | ||
| 1187 | reg_w(gspca_dev, 0x10c0, row, 8); | ||
| 1188 | msleep(1); | ||
| 1189 | row[0] = 0x81 | (3 << 4) | 0x02; | ||
| 1190 | row[2] = 0; | ||
| 1191 | reg_w(gspca_dev, 0x10c0, row, 8); | ||
| 1192 | msleep(1); | ||
| 1193 | reg_r(gspca_dev, 0x10c2, 5); | ||
| 1194 | *val = (gspca_dev->usb_buf[2] << 8) | gspca_dev->usb_buf[3]; | ||
| 1195 | return 0; | ||
| 1196 | } | ||
| 1197 | |||
| 1198 | static int ov9650_init_sensor(struct gspca_dev *gspca_dev) | ||
| 1199 | { | ||
| 1200 | int i; | ||
| 1201 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1202 | |||
| 1203 | for (i = 0; i < ARRAY_SIZE(ov9650_init); i++) { | ||
| 1204 | if (i2c_w1(gspca_dev, ov9650_init[i][0], | ||
| 1205 | ov9650_init[i][1]) < 0) { | ||
| 1206 | err("OV9650 sensor initialization failed"); | ||
| 1207 | return -ENODEV; | ||
| 1208 | } | ||
| 1209 | } | ||
| 1210 | sd->hstart = 1; | ||
| 1211 | sd->vstart = 7; | ||
| 1212 | return 0; | ||
| 1213 | } | ||
| 1214 | |||
| 1215 | static int ov9655_init_sensor(struct gspca_dev *gspca_dev) | ||
| 1216 | { | ||
| 1217 | int i; | ||
| 1218 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1219 | |||
| 1220 | for (i = 0; i < ARRAY_SIZE(ov9655_init); i++) { | ||
| 1221 | if (i2c_w1(gspca_dev, ov9655_init[i][0], | ||
| 1222 | ov9655_init[i][1]) < 0) { | ||
| 1223 | err("OV9655 sensor initialization failed"); | ||
| 1224 | return -ENODEV; | ||
| 1225 | } | ||
| 1226 | } | ||
| 1227 | /* disable hflip and vflip */ | ||
| 1228 | gspca_dev->ctrl_dis = (1 << HFLIP_IDX) | (1 << VFLIP_IDX); | ||
| 1229 | sd->hstart = 0; | ||
| 1230 | sd->vstart = 7; | ||
| 1231 | return 0; | ||
| 1232 | } | ||
| 1233 | |||
| 1234 | static int soi968_init_sensor(struct gspca_dev *gspca_dev) | ||
| 1235 | { | ||
| 1236 | int i; | ||
| 1237 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1238 | |||
| 1239 | for (i = 0; i < ARRAY_SIZE(soi968_init); i++) { | ||
| 1240 | if (i2c_w1(gspca_dev, soi968_init[i][0], | ||
| 1241 | soi968_init[i][1]) < 0) { | ||
| 1242 | err("SOI968 sensor initialization failed"); | ||
| 1243 | return -ENODEV; | ||
| 1244 | } | ||
| 1245 | } | ||
| 1246 | /* disable hflip and vflip */ | ||
| 1247 | gspca_dev->ctrl_dis = (1 << HFLIP_IDX) | (1 << VFLIP_IDX); | ||
| 1248 | sd->hstart = 60; | ||
| 1249 | sd->vstart = 11; | ||
| 1250 | return 0; | ||
| 1251 | } | ||
| 1252 | |||
| 1253 | static int ov7660_init_sensor(struct gspca_dev *gspca_dev) | ||
| 1254 | { | ||
| 1255 | int i; | ||
| 1256 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1257 | |||
| 1258 | for (i = 0; i < ARRAY_SIZE(ov7660_init); i++) { | ||
| 1259 | if (i2c_w1(gspca_dev, ov7660_init[i][0], | ||
| 1260 | ov7660_init[i][1]) < 0) { | ||
| 1261 | err("OV7660 sensor initialization failed"); | ||
| 1262 | return -ENODEV; | ||
| 1263 | } | ||
| 1264 | } | ||
| 1265 | /* disable hflip and vflip */ | ||
| 1266 | gspca_dev->ctrl_dis = (1 << HFLIP_IDX) | (1 << VFLIP_IDX); | ||
| 1267 | sd->hstart = 1; | ||
| 1268 | sd->vstart = 1; | ||
| 1269 | return 0; | ||
| 1270 | } | ||
| 1271 | |||
| 1272 | static int ov7670_init_sensor(struct gspca_dev *gspca_dev) | ||
| 1273 | { | ||
| 1274 | int i; | ||
| 1275 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1276 | |||
| 1277 | for (i = 0; i < ARRAY_SIZE(ov7670_init); i++) { | ||
| 1278 | if (i2c_w1(gspca_dev, ov7670_init[i][0], | ||
| 1279 | ov7670_init[i][1]) < 0) { | ||
| 1280 | err("OV7670 sensor initialization failed"); | ||
| 1281 | return -ENODEV; | ||
| 1282 | } | ||
| 1283 | } | ||
| 1284 | /* disable hflip and vflip */ | ||
| 1285 | gspca_dev->ctrl_dis = (1 << HFLIP_IDX) | (1 << VFLIP_IDX); | ||
| 1286 | sd->hstart = 0; | ||
| 1287 | sd->vstart = 1; | ||
| 1288 | return 0; | ||
| 1289 | } | ||
| 1290 | |||
| 1291 | static int mt9v_init_sensor(struct gspca_dev *gspca_dev) | ||
| 1292 | { | ||
| 1293 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1294 | int i; | ||
| 1295 | u16 value; | ||
| 1296 | int ret; | ||
| 1297 | |||
| 1298 | sd->i2c_addr = 0x5d; | ||
| 1299 | ret = i2c_r2(gspca_dev, 0xff, &value); | ||
| 1300 | if ((ret == 0) && (value == 0x8243)) { | ||
| 1301 | for (i = 0; i < ARRAY_SIZE(mt9v011_init); i++) { | ||
| 1302 | if (i2c_w2(gspca_dev, mt9v011_init[i][0], | ||
| 1303 | mt9v011_init[i][1]) < 0) { | ||
| 1304 | err("MT9V011 sensor initialization failed"); | ||
| 1305 | return -ENODEV; | ||
| 1306 | } | ||
| 1307 | } | ||
| 1308 | sd->hstart = 2; | ||
| 1309 | sd->vstart = 2; | ||
| 1310 | sd->sensor = SENSOR_MT9V011; | ||
| 1311 | info("MT9V011 sensor detected"); | ||
| 1312 | return 0; | ||
| 1313 | } | ||
| 1314 | |||
| 1315 | sd->i2c_addr = 0x5c; | ||
| 1316 | i2c_w2(gspca_dev, 0x01, 0x0004); | ||
| 1317 | ret = i2c_r2(gspca_dev, 0xff, &value); | ||
| 1318 | if ((ret == 0) && (value == 0x823a)) { | ||
| 1319 | for (i = 0; i < ARRAY_SIZE(mt9v111_init); i++) { | ||
| 1320 | if (i2c_w2(gspca_dev, mt9v111_init[i][0], | ||
| 1321 | mt9v111_init[i][1]) < 0) { | ||
| 1322 | err("MT9V111 sensor initialization failed"); | ||
| 1323 | return -ENODEV; | ||
| 1324 | } | ||
| 1325 | } | ||
| 1326 | sd->hstart = 2; | ||
| 1327 | sd->vstart = 2; | ||
| 1328 | sd->sensor = SENSOR_MT9V111; | ||
| 1329 | info("MT9V111 sensor detected"); | ||
| 1330 | return 0; | ||
| 1331 | } | ||
| 1332 | |||
| 1333 | sd->i2c_addr = 0x5d; | ||
| 1334 | ret = i2c_w2(gspca_dev, 0xf0, 0x0000); | ||
| 1335 | if (ret < 0) { | ||
| 1336 | sd->i2c_addr = 0x48; | ||
| 1337 | i2c_w2(gspca_dev, 0xf0, 0x0000); | ||
| 1338 | } | ||
| 1339 | ret = i2c_r2(gspca_dev, 0x00, &value); | ||
| 1340 | if ((ret == 0) && (value == 0x1229)) { | ||
| 1341 | for (i = 0; i < ARRAY_SIZE(mt9v112_init); i++) { | ||
| 1342 | if (i2c_w2(gspca_dev, mt9v112_init[i][0], | ||
| 1343 | mt9v112_init[i][1]) < 0) { | ||
| 1344 | err("MT9V112 sensor initialization failed"); | ||
| 1345 | return -ENODEV; | ||
| 1346 | } | ||
| 1347 | } | ||
| 1348 | sd->hstart = 6; | ||
| 1349 | sd->vstart = 2; | ||
| 1350 | sd->sensor = SENSOR_MT9V112; | ||
| 1351 | info("MT9V112 sensor detected"); | ||
| 1352 | return 0; | ||
| 1353 | } | ||
| 1354 | |||
| 1355 | return -ENODEV; | ||
| 1356 | } | ||
| 1357 | |||
| 1358 | static int mt9m111_init_sensor(struct gspca_dev *gspca_dev) | ||
| 1359 | { | ||
| 1360 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1361 | int i; | ||
| 1362 | for (i = 0; i < ARRAY_SIZE(mt9m111_init); i++) { | ||
| 1363 | if (i2c_w2(gspca_dev, mt9m111_init[i][0], | ||
| 1364 | mt9m111_init[i][1]) < 0) { | ||
| 1365 | err("MT9M111 sensor initialization failed"); | ||
| 1366 | return -ENODEV; | ||
| 1367 | } | ||
| 1368 | } | ||
| 1369 | sd->hstart = 0; | ||
| 1370 | sd->vstart = 2; | ||
| 1371 | return 0; | ||
| 1372 | } | ||
| 1373 | |||
| 1374 | static int mt9m001_init_sensor(struct gspca_dev *gspca_dev) | ||
| 1375 | { | ||
| 1376 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1377 | int i; | ||
| 1378 | for (i = 0; i < ARRAY_SIZE(mt9m001_init); i++) { | ||
| 1379 | if (i2c_w2(gspca_dev, mt9m001_init[i][0], | ||
| 1380 | mt9m001_init[i][1]) < 0) { | ||
| 1381 | err("MT9M001 sensor initialization failed"); | ||
| 1382 | return -ENODEV; | ||
| 1383 | } | ||
| 1384 | } | ||
| 1385 | /* disable hflip and vflip */ | ||
| 1386 | gspca_dev->ctrl_dis = (1 << HFLIP_IDX) | (1 << VFLIP_IDX); | ||
| 1387 | sd->hstart = 2; | ||
| 1388 | sd->vstart = 2; | ||
| 1389 | return 0; | ||
| 1390 | } | ||
| 1391 | |||
| 1392 | static int hv7131r_init_sensor(struct gspca_dev *gspca_dev) | ||
| 1393 | { | ||
| 1394 | int i; | ||
| 1395 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1396 | |||
| 1397 | for (i = 0; i < ARRAY_SIZE(hv7131r_init); i++) { | ||
| 1398 | if (i2c_w1(gspca_dev, hv7131r_init[i][0], | ||
| 1399 | hv7131r_init[i][1]) < 0) { | ||
| 1400 | err("HV7131R Sensor initialization failed"); | ||
| 1401 | return -ENODEV; | ||
| 1402 | } | ||
| 1403 | } | ||
| 1404 | sd->hstart = 0; | ||
| 1405 | sd->vstart = 1; | ||
| 1406 | return 0; | ||
| 1407 | } | ||
| 1408 | |||
| 1409 | #ifdef CONFIG_USB_GSPCA_SN9C20X_EVDEV | ||
| 1410 | static int input_kthread(void *data) | ||
| 1411 | { | ||
| 1412 | struct gspca_dev *gspca_dev = (struct gspca_dev *)data; | ||
| 1413 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1414 | |||
| 1415 | DECLARE_WAIT_QUEUE_HEAD(wait); | ||
| 1416 | set_freezable(); | ||
| 1417 | for (;;) { | ||
| 1418 | if (kthread_should_stop()) | ||
| 1419 | break; | ||
| 1420 | |||
| 1421 | if (reg_r(gspca_dev, 0x1005, 1) < 0) | ||
| 1422 | continue; | ||
| 1423 | |||
| 1424 | input_report_key(sd->input_dev, | ||
| 1425 | KEY_CAMERA, | ||
| 1426 | gspca_dev->usb_buf[0] & sd->input_gpio); | ||
| 1427 | input_sync(sd->input_dev); | ||
| 1428 | |||
| 1429 | wait_event_freezable_timeout(wait, | ||
| 1430 | kthread_should_stop(), | ||
| 1431 | msecs_to_jiffies(100)); | ||
| 1432 | } | ||
| 1433 | return 0; | ||
| 1434 | } | ||
| 1435 | |||
| 1436 | |||
| 1437 | static int sn9c20x_input_init(struct gspca_dev *gspca_dev) | ||
| 1438 | { | ||
| 1439 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1440 | if (sd->input_gpio == 0) | ||
| 1441 | return 0; | ||
| 1442 | |||
| 1443 | sd->input_dev = input_allocate_device(); | ||
| 1444 | if (!sd->input_dev) | ||
| 1445 | return -ENOMEM; | ||
| 1446 | |||
| 1447 | sd->input_dev->name = "SN9C20X Webcam"; | ||
| 1448 | |||
| 1449 | sd->input_dev->phys = kasprintf(GFP_KERNEL, "usb-%s-%s", | ||
| 1450 | gspca_dev->dev->bus->bus_name, | ||
| 1451 | gspca_dev->dev->devpath); | ||
| 1452 | |||
| 1453 | if (!sd->input_dev->phys) | ||
| 1454 | return -ENOMEM; | ||
| 1455 | |||
| 1456 | usb_to_input_id(gspca_dev->dev, &sd->input_dev->id); | ||
| 1457 | sd->input_dev->dev.parent = &gspca_dev->dev->dev; | ||
| 1458 | |||
| 1459 | set_bit(EV_KEY, sd->input_dev->evbit); | ||
| 1460 | set_bit(KEY_CAMERA, sd->input_dev->keybit); | ||
| 1461 | |||
| 1462 | if (input_register_device(sd->input_dev)) | ||
| 1463 | return -EINVAL; | ||
| 1464 | |||
| 1465 | sd->input_task = kthread_run(input_kthread, gspca_dev, "sn9c20x/%d", | ||
| 1466 | gspca_dev->vdev.minor); | ||
| 1467 | |||
| 1468 | if (IS_ERR(sd->input_task)) | ||
| 1469 | return -EINVAL; | ||
| 1470 | |||
| 1471 | return 0; | ||
| 1472 | } | ||
| 1473 | |||
| 1474 | static void sn9c20x_input_cleanup(struct gspca_dev *gspca_dev) | ||
| 1475 | { | ||
| 1476 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1477 | if (sd->input_task != NULL && !IS_ERR(sd->input_task)) | ||
| 1478 | kthread_stop(sd->input_task); | ||
| 1479 | |||
| 1480 | if (sd->input_dev != NULL) { | ||
| 1481 | input_unregister_device(sd->input_dev); | ||
| 1482 | kfree(sd->input_dev->phys); | ||
| 1483 | input_free_device(sd->input_dev); | ||
| 1484 | sd->input_dev = NULL; | ||
| 1485 | } | ||
| 1486 | } | ||
| 1487 | #endif | ||
| 1488 | |||
| 1489 | static int set_cmatrix(struct gspca_dev *gspca_dev) | ||
| 1490 | { | ||
| 1491 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1492 | s32 hue_coord, hue_index = 180 + sd->hue; | ||
| 1493 | u8 cmatrix[21]; | ||
| 1494 | memset(cmatrix, 0, 21); | ||
| 1495 | |||
| 1496 | cmatrix[2] = (sd->contrast * 0x25 / 0x100) + 0x26; | ||
| 1497 | cmatrix[0] = 0x13 + (cmatrix[2] - 0x26) * 0x13 / 0x25; | ||
| 1498 | cmatrix[4] = 0x07 + (cmatrix[2] - 0x26) * 0x07 / 0x25; | ||
| 1499 | cmatrix[18] = sd->brightness - 0x80; | ||
| 1500 | |||
| 1501 | hue_coord = (hsv_red_x[hue_index] * sd->saturation) >> 8; | ||
| 1502 | cmatrix[6] = (unsigned char)(hue_coord & 0xff); | ||
| 1503 | cmatrix[7] = (unsigned char)((hue_coord >> 8) & 0x0f); | ||
| 1504 | |||
| 1505 | hue_coord = (hsv_red_y[hue_index] * sd->saturation) >> 8; | ||
| 1506 | cmatrix[8] = (unsigned char)(hue_coord & 0xff); | ||
| 1507 | cmatrix[9] = (unsigned char)((hue_coord >> 8) & 0x0f); | ||
| 1508 | |||
| 1509 | hue_coord = (hsv_green_x[hue_index] * sd->saturation) >> 8; | ||
| 1510 | cmatrix[10] = (unsigned char)(hue_coord & 0xff); | ||
| 1511 | cmatrix[11] = (unsigned char)((hue_coord >> 8) & 0x0f); | ||
| 1512 | |||
| 1513 | hue_coord = (hsv_green_y[hue_index] * sd->saturation) >> 8; | ||
| 1514 | cmatrix[12] = (unsigned char)(hue_coord & 0xff); | ||
| 1515 | cmatrix[13] = (unsigned char)((hue_coord >> 8) & 0x0f); | ||
| 1516 | |||
| 1517 | hue_coord = (hsv_blue_x[hue_index] * sd->saturation) >> 8; | ||
| 1518 | cmatrix[14] = (unsigned char)(hue_coord & 0xff); | ||
| 1519 | cmatrix[15] = (unsigned char)((hue_coord >> 8) & 0x0f); | ||
| 1520 | |||
| 1521 | hue_coord = (hsv_blue_y[hue_index] * sd->saturation) >> 8; | ||
| 1522 | cmatrix[16] = (unsigned char)(hue_coord & 0xff); | ||
| 1523 | cmatrix[17] = (unsigned char)((hue_coord >> 8) & 0x0f); | ||
| 1524 | |||
| 1525 | return reg_w(gspca_dev, 0x10e1, cmatrix, 21); | ||
| 1526 | } | ||
| 1527 | |||
| 1528 | static int set_gamma(struct gspca_dev *gspca_dev) | ||
| 1529 | { | ||
| 1530 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1531 | u8 gamma[17]; | ||
| 1532 | u8 gval = sd->gamma * 0xb8 / 0x100; | ||
| 1533 | |||
| 1534 | |||
| 1535 | gamma[0] = 0x0a; | ||
| 1536 | gamma[1] = 0x13 + (gval * (0xcb - 0x13) / 0xb8); | ||
| 1537 | gamma[2] = 0x25 + (gval * (0xee - 0x25) / 0xb8); | ||
| 1538 | gamma[3] = 0x37 + (gval * (0xfa - 0x37) / 0xb8); | ||
| 1539 | gamma[4] = 0x45 + (gval * (0xfc - 0x45) / 0xb8); | ||
| 1540 | gamma[5] = 0x55 + (gval * (0xfb - 0x55) / 0xb8); | ||
| 1541 | gamma[6] = 0x65 + (gval * (0xfc - 0x65) / 0xb8); | ||
| 1542 | gamma[7] = 0x74 + (gval * (0xfd - 0x74) / 0xb8); | ||
| 1543 | gamma[8] = 0x83 + (gval * (0xfe - 0x83) / 0xb8); | ||
| 1544 | gamma[9] = 0x92 + (gval * (0xfc - 0x92) / 0xb8); | ||
| 1545 | gamma[10] = 0xa1 + (gval * (0xfc - 0xa1) / 0xb8); | ||
| 1546 | gamma[11] = 0xb0 + (gval * (0xfc - 0xb0) / 0xb8); | ||
| 1547 | gamma[12] = 0xbf + (gval * (0xfb - 0xbf) / 0xb8); | ||
| 1548 | gamma[13] = 0xce + (gval * (0xfb - 0xce) / 0xb8); | ||
| 1549 | gamma[14] = 0xdf + (gval * (0xfd - 0xdf) / 0xb8); | ||
| 1550 | gamma[15] = 0xea + (gval * (0xf9 - 0xea) / 0xb8); | ||
| 1551 | gamma[16] = 0xf5; | ||
| 1552 | |||
| 1553 | return reg_w(gspca_dev, 0x1190, gamma, 17); | ||
| 1554 | } | ||
| 1555 | |||
| 1556 | static int set_redblue(struct gspca_dev *gspca_dev) | ||
| 1557 | { | ||
| 1558 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1559 | reg_w1(gspca_dev, 0x118c, sd->red); | ||
| 1560 | reg_w1(gspca_dev, 0x118f, sd->blue); | ||
| 1561 | return 0; | ||
| 1562 | } | ||
| 1563 | |||
| 1564 | static int set_hvflip(struct gspca_dev *gspca_dev) | ||
| 1565 | { | ||
| 1566 | u8 value, tslb; | ||
| 1567 | u16 value2; | ||
| 1568 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1569 | switch (sd->sensor) { | ||
| 1570 | case SENSOR_OV9650: | ||
| 1571 | i2c_r1(gspca_dev, 0x1e, &value); | ||
| 1572 | value &= ~0x30; | ||
| 1573 | tslb = 0x01; | ||
| 1574 | if (sd->hflip) | ||
| 1575 | value |= 0x20; | ||
| 1576 | if (sd->vflip) { | ||
| 1577 | value |= 0x10; | ||
| 1578 | tslb = 0x49; | ||
| 1579 | } | ||
| 1580 | i2c_w1(gspca_dev, 0x1e, value); | ||
| 1581 | i2c_w1(gspca_dev, 0x3a, tslb); | ||
| 1582 | break; | ||
| 1583 | case SENSOR_MT9V111: | ||
| 1584 | case SENSOR_MT9V011: | ||
| 1585 | i2c_r2(gspca_dev, 0x20, &value2); | ||
| 1586 | value2 &= ~0xc0a0; | ||
| 1587 | if (sd->hflip) | ||
| 1588 | value2 |= 0x8080; | ||
| 1589 | if (sd->vflip) | ||
| 1590 | value2 |= 0x4020; | ||
| 1591 | i2c_w2(gspca_dev, 0x20, value2); | ||
| 1592 | break; | ||
| 1593 | case SENSOR_MT9M111: | ||
| 1594 | case SENSOR_MT9V112: | ||
| 1595 | i2c_r2(gspca_dev, 0x20, &value2); | ||
| 1596 | value2 &= ~0x0003; | ||
| 1597 | if (sd->hflip) | ||
| 1598 | value2 |= 0x0002; | ||
| 1599 | if (sd->vflip) | ||
| 1600 | value2 |= 0x0001; | ||
| 1601 | i2c_w2(gspca_dev, 0x20, value2); | ||
| 1602 | break; | ||
| 1603 | case SENSOR_HV7131R: | ||
| 1604 | i2c_r1(gspca_dev, 0x01, &value); | ||
| 1605 | value &= ~0x03; | ||
| 1606 | if (sd->vflip) | ||
| 1607 | value |= 0x01; | ||
| 1608 | if (sd->hflip) | ||
| 1609 | value |= 0x02; | ||
| 1610 | i2c_w1(gspca_dev, 0x01, value); | ||
| 1611 | break; | ||
| 1612 | } | ||
| 1613 | return 0; | ||
| 1614 | } | ||
| 1615 | |||
| 1616 | static int set_exposure(struct gspca_dev *gspca_dev) | ||
| 1617 | { | ||
| 1618 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1619 | u8 exp[8] = {0x81, sd->i2c_addr, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1e}; | ||
| 1620 | switch (sd->sensor) { | ||
| 1621 | case SENSOR_OV7660: | ||
| 1622 | case SENSOR_OV7670: | ||
| 1623 | case SENSOR_SOI968: | ||
| 1624 | case SENSOR_OV9655: | ||
| 1625 | case SENSOR_OV9650: | ||
| 1626 | exp[0] |= (3 << 4); | ||
| 1627 | exp[2] = 0x2d; | ||
| 1628 | exp[3] = sd->exposure & 0xff; | ||
| 1629 | exp[4] = sd->exposure >> 8; | ||
| 1630 | break; | ||
| 1631 | case SENSOR_MT9M001: | ||
| 1632 | case SENSOR_MT9M111: | ||
| 1633 | case SENSOR_MT9V112: | ||
| 1634 | case SENSOR_MT9V111: | ||
| 1635 | case SENSOR_MT9V011: | ||
| 1636 | exp[0] |= (3 << 4); | ||
| 1637 | exp[2] = 0x09; | ||
| 1638 | exp[3] = sd->exposure >> 8; | ||
| 1639 | exp[4] = sd->exposure & 0xff; | ||
| 1640 | break; | ||
| 1641 | case SENSOR_HV7131R: | ||
| 1642 | exp[0] |= (4 << 4); | ||
| 1643 | exp[2] = 0x25; | ||
| 1644 | exp[3] = ((sd->exposure * 0xffffff) / 0xffff) >> 16; | ||
| 1645 | exp[4] = ((sd->exposure * 0xffffff) / 0xffff) >> 8; | ||
| 1646 | exp[5] = ((sd->exposure * 0xffffff) / 0xffff) & 0xff; | ||
| 1647 | break; | ||
| 1648 | } | ||
| 1649 | i2c_w(gspca_dev, exp); | ||
| 1650 | return 0; | ||
| 1651 | } | ||
| 1652 | |||
| 1653 | static int set_gain(struct gspca_dev *gspca_dev) | ||
| 1654 | { | ||
| 1655 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1656 | u8 gain[8] = {0x81, sd->i2c_addr, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1d}; | ||
| 1657 | switch (sd->sensor) { | ||
| 1658 | case SENSOR_OV7660: | ||
| 1659 | case SENSOR_OV7670: | ||
| 1660 | case SENSOR_SOI968: | ||
| 1661 | case SENSOR_OV9655: | ||
| 1662 | case SENSOR_OV9650: | ||
| 1663 | gain[0] |= (2 << 4); | ||
| 1664 | gain[3] = ov_gain[sd->gain]; | ||
| 1665 | break; | ||
| 1666 | case SENSOR_MT9V011: | ||
| 1667 | case SENSOR_MT9V111: | ||
| 1668 | gain[0] |= (3 << 4); | ||
| 1669 | gain[2] = 0x35; | ||
| 1670 | gain[3] = micron1_gain[sd->gain] >> 8; | ||
| 1671 | gain[4] = micron1_gain[sd->gain] & 0xff; | ||
| 1672 | break; | ||
| 1673 | case SENSOR_MT9V112: | ||
| 1674 | case SENSOR_MT9M111: | ||
| 1675 | gain[0] |= (3 << 4); | ||
| 1676 | gain[2] = 0x2f; | ||
| 1677 | gain[3] = micron1_gain[sd->gain] >> 8; | ||
| 1678 | gain[4] = micron1_gain[sd->gain] & 0xff; | ||
| 1679 | break; | ||
| 1680 | case SENSOR_MT9M001: | ||
| 1681 | gain[0] |= (3 << 4); | ||
| 1682 | gain[2] = 0x2f; | ||
| 1683 | gain[3] = micron2_gain[sd->gain] >> 8; | ||
| 1684 | gain[4] = micron2_gain[sd->gain] & 0xff; | ||
| 1685 | break; | ||
| 1686 | case SENSOR_HV7131R: | ||
| 1687 | gain[0] |= (2 << 4); | ||
| 1688 | gain[2] = 0x30; | ||
| 1689 | gain[3] = hv7131r_gain[sd->gain]; | ||
| 1690 | break; | ||
| 1691 | } | ||
| 1692 | i2c_w(gspca_dev, gain); | ||
| 1693 | return 0; | ||
| 1694 | } | ||
| 1695 | |||
| 1696 | static int sd_setbrightness(struct gspca_dev *gspca_dev, s32 val) | ||
| 1697 | { | ||
| 1698 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1699 | |||
| 1700 | sd->brightness = val; | ||
| 1701 | if (gspca_dev->streaming) | ||
| 1702 | return set_cmatrix(gspca_dev); | ||
| 1703 | return 0; | ||
| 1704 | } | ||
| 1705 | |||
| 1706 | static int sd_getbrightness(struct gspca_dev *gspca_dev, s32 *val) | ||
| 1707 | { | ||
| 1708 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1709 | *val = sd->brightness; | ||
| 1710 | return 0; | ||
| 1711 | } | ||
| 1712 | |||
| 1713 | |||
| 1714 | static int sd_setcontrast(struct gspca_dev *gspca_dev, s32 val) | ||
| 1715 | { | ||
| 1716 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1717 | |||
| 1718 | sd->contrast = val; | ||
| 1719 | if (gspca_dev->streaming) | ||
| 1720 | return set_cmatrix(gspca_dev); | ||
| 1721 | return 0; | ||
| 1722 | } | ||
| 1723 | |||
| 1724 | static int sd_getcontrast(struct gspca_dev *gspca_dev, s32 *val) | ||
| 1725 | { | ||
| 1726 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1727 | *val = sd->contrast; | ||
| 1728 | return 0; | ||
| 1729 | } | ||
| 1730 | |||
| 1731 | static int sd_setsaturation(struct gspca_dev *gspca_dev, s32 val) | ||
| 1732 | { | ||
| 1733 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1734 | |||
| 1735 | sd->saturation = val; | ||
| 1736 | if (gspca_dev->streaming) | ||
| 1737 | return set_cmatrix(gspca_dev); | ||
| 1738 | return 0; | ||
| 1739 | } | ||
| 1740 | |||
| 1741 | static int sd_getsaturation(struct gspca_dev *gspca_dev, s32 *val) | ||
| 1742 | { | ||
| 1743 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1744 | *val = sd->saturation; | ||
| 1745 | return 0; | ||
| 1746 | } | ||
| 1747 | |||
| 1748 | static int sd_sethue(struct gspca_dev *gspca_dev, s32 val) | ||
| 1749 | { | ||
| 1750 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1751 | |||
| 1752 | sd->hue = val; | ||
| 1753 | if (gspca_dev->streaming) | ||
| 1754 | return set_cmatrix(gspca_dev); | ||
| 1755 | return 0; | ||
| 1756 | } | ||
| 1757 | |||
| 1758 | static int sd_gethue(struct gspca_dev *gspca_dev, s32 *val) | ||
| 1759 | { | ||
| 1760 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1761 | *val = sd->hue; | ||
| 1762 | return 0; | ||
| 1763 | } | ||
| 1764 | |||
| 1765 | static int sd_setgamma(struct gspca_dev *gspca_dev, s32 val) | ||
| 1766 | { | ||
| 1767 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1768 | |||
| 1769 | sd->gamma = val; | ||
| 1770 | if (gspca_dev->streaming) | ||
| 1771 | return set_gamma(gspca_dev); | ||
| 1772 | return 0; | ||
| 1773 | } | ||
| 1774 | |||
| 1775 | static int sd_getgamma(struct gspca_dev *gspca_dev, s32 *val) | ||
| 1776 | { | ||
| 1777 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1778 | *val = sd->gamma; | ||
| 1779 | return 0; | ||
| 1780 | } | ||
| 1781 | |||
| 1782 | static int sd_setredbalance(struct gspca_dev *gspca_dev, s32 val) | ||
| 1783 | { | ||
| 1784 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1785 | |||
| 1786 | sd->red = val; | ||
| 1787 | if (gspca_dev->streaming) | ||
| 1788 | return set_redblue(gspca_dev); | ||
| 1789 | return 0; | ||
| 1790 | } | ||
| 1791 | |||
| 1792 | static int sd_getredbalance(struct gspca_dev *gspca_dev, s32 *val) | ||
| 1793 | { | ||
| 1794 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1795 | *val = sd->red; | ||
| 1796 | return 0; | ||
| 1797 | } | ||
| 1798 | |||
| 1799 | static int sd_setbluebalance(struct gspca_dev *gspca_dev, s32 val) | ||
| 1800 | { | ||
| 1801 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1802 | |||
| 1803 | sd->blue = val; | ||
| 1804 | if (gspca_dev->streaming) | ||
| 1805 | return set_redblue(gspca_dev); | ||
| 1806 | return 0; | ||
| 1807 | } | ||
| 1808 | |||
| 1809 | static int sd_getbluebalance(struct gspca_dev *gspca_dev, s32 *val) | ||
| 1810 | { | ||
| 1811 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1812 | *val = sd->blue; | ||
| 1813 | return 0; | ||
| 1814 | } | ||
| 1815 | |||
| 1816 | static int sd_sethflip(struct gspca_dev *gspca_dev, s32 val) | ||
| 1817 | { | ||
| 1818 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1819 | |||
| 1820 | sd->hflip = val; | ||
| 1821 | if (gspca_dev->streaming) | ||
| 1822 | return set_hvflip(gspca_dev); | ||
| 1823 | return 0; | ||
| 1824 | } | ||
| 1825 | |||
| 1826 | static int sd_gethflip(struct gspca_dev *gspca_dev, s32 *val) | ||
| 1827 | { | ||
| 1828 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1829 | *val = sd->hflip; | ||
| 1830 | return 0; | ||
| 1831 | } | ||
| 1832 | |||
| 1833 | static int sd_setvflip(struct gspca_dev *gspca_dev, s32 val) | ||
| 1834 | { | ||
| 1835 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1836 | |||
| 1837 | sd->vflip = val; | ||
| 1838 | if (gspca_dev->streaming) | ||
| 1839 | return set_hvflip(gspca_dev); | ||
| 1840 | return 0; | ||
| 1841 | } | ||
| 1842 | |||
| 1843 | static int sd_getvflip(struct gspca_dev *gspca_dev, s32 *val) | ||
| 1844 | { | ||
| 1845 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1846 | *val = sd->vflip; | ||
| 1847 | return 0; | ||
| 1848 | } | ||
| 1849 | |||
| 1850 | static int sd_setexposure(struct gspca_dev *gspca_dev, s32 val) | ||
| 1851 | { | ||
| 1852 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1853 | |||
| 1854 | sd->exposure = val; | ||
| 1855 | if (gspca_dev->streaming) | ||
| 1856 | return set_exposure(gspca_dev); | ||
| 1857 | return 0; | ||
| 1858 | } | ||
| 1859 | |||
| 1860 | static int sd_getexposure(struct gspca_dev *gspca_dev, s32 *val) | ||
| 1861 | { | ||
| 1862 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1863 | *val = sd->exposure; | ||
| 1864 | return 0; | ||
| 1865 | } | ||
| 1866 | |||
| 1867 | static int sd_setgain(struct gspca_dev *gspca_dev, s32 val) | ||
| 1868 | { | ||
| 1869 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1870 | |||
| 1871 | sd->gain = val; | ||
| 1872 | if (gspca_dev->streaming) | ||
| 1873 | return set_gain(gspca_dev); | ||
| 1874 | return 0; | ||
| 1875 | } | ||
| 1876 | |||
| 1877 | static int sd_getgain(struct gspca_dev *gspca_dev, s32 *val) | ||
| 1878 | { | ||
| 1879 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1880 | *val = sd->gain; | ||
| 1881 | return 0; | ||
| 1882 | } | ||
| 1883 | |||
| 1884 | static int sd_setautoexposure(struct gspca_dev *gspca_dev, s32 val) | ||
| 1885 | { | ||
| 1886 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1887 | sd->auto_exposure = val; | ||
| 1888 | return 0; | ||
| 1889 | } | ||
| 1890 | |||
| 1891 | static int sd_getautoexposure(struct gspca_dev *gspca_dev, s32 *val) | ||
| 1892 | { | ||
| 1893 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1894 | *val = sd->auto_exposure; | ||
| 1895 | return 0; | ||
| 1896 | } | ||
| 1897 | |||
| 1898 | #ifdef CONFIG_VIDEO_ADV_DEBUG | ||
| 1899 | static int sd_dbg_g_register(struct gspca_dev *gspca_dev, | ||
| 1900 | struct v4l2_dbg_register *reg) | ||
| 1901 | { | ||
| 1902 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1903 | switch (reg->match.type) { | ||
| 1904 | case V4L2_CHIP_MATCH_HOST: | ||
| 1905 | if (reg->match.addr != 0) | ||
| 1906 | return -EINVAL; | ||
| 1907 | if (reg->reg < 0x1000 || reg->reg > 0x11ff) | ||
| 1908 | return -EINVAL; | ||
| 1909 | if (reg_r(gspca_dev, reg->reg, 1) < 0) | ||
| 1910 | return -EINVAL; | ||
| 1911 | reg->val = gspca_dev->usb_buf[0]; | ||
| 1912 | return 0; | ||
| 1913 | case V4L2_CHIP_MATCH_I2C_ADDR: | ||
| 1914 | if (reg->match.addr != sd->i2c_addr) | ||
| 1915 | return -EINVAL; | ||
| 1916 | if (sd->sensor >= SENSOR_MT9V011 && | ||
| 1917 | sd->sensor <= SENSOR_MT9M111) { | ||
| 1918 | if (i2c_r2(gspca_dev, reg->reg, (u16 *)®->val) < 0) | ||
| 1919 | return -EINVAL; | ||
| 1920 | } else { | ||
| 1921 | if (i2c_r1(gspca_dev, reg->reg, (u8 *)®->val) < 0) | ||
| 1922 | return -EINVAL; | ||
| 1923 | } | ||
| 1924 | return 0; | ||
| 1925 | } | ||
| 1926 | return -EINVAL; | ||
| 1927 | } | ||
| 1928 | |||
| 1929 | static int sd_dbg_s_register(struct gspca_dev *gspca_dev, | ||
| 1930 | struct v4l2_dbg_register *reg) | ||
| 1931 | { | ||
| 1932 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1933 | switch (reg->match.type) { | ||
| 1934 | case V4L2_CHIP_MATCH_HOST: | ||
| 1935 | if (reg->match.addr != 0) | ||
| 1936 | return -EINVAL; | ||
| 1937 | if (reg->reg < 0x1000 || reg->reg > 0x11ff) | ||
| 1938 | return -EINVAL; | ||
| 1939 | if (reg_w1(gspca_dev, reg->reg, reg->val) < 0) | ||
| 1940 | return -EINVAL; | ||
| 1941 | return 0; | ||
| 1942 | case V4L2_CHIP_MATCH_I2C_ADDR: | ||
| 1943 | if (reg->match.addr != sd->i2c_addr) | ||
| 1944 | return -EINVAL; | ||
| 1945 | if (sd->sensor >= SENSOR_MT9V011 && | ||
| 1946 | sd->sensor <= SENSOR_MT9M111) { | ||
| 1947 | if (i2c_w2(gspca_dev, reg->reg, reg->val) < 0) | ||
| 1948 | return -EINVAL; | ||
| 1949 | } else { | ||
| 1950 | if (i2c_w1(gspca_dev, reg->reg, reg->val) < 0) | ||
| 1951 | return -EINVAL; | ||
| 1952 | } | ||
| 1953 | return 0; | ||
| 1954 | } | ||
| 1955 | return -EINVAL; | ||
| 1956 | } | ||
| 1957 | #endif | ||
| 1958 | |||
| 1959 | static int sd_chip_ident(struct gspca_dev *gspca_dev, | ||
| 1960 | struct v4l2_dbg_chip_ident *chip) | ||
| 1961 | { | ||
| 1962 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1963 | |||
| 1964 | switch (chip->match.type) { | ||
| 1965 | case V4L2_CHIP_MATCH_HOST: | ||
| 1966 | if (chip->match.addr != 0) | ||
| 1967 | return -EINVAL; | ||
| 1968 | chip->revision = 0; | ||
| 1969 | chip->ident = V4L2_IDENT_SN9C20X; | ||
| 1970 | return 0; | ||
| 1971 | case V4L2_CHIP_MATCH_I2C_ADDR: | ||
| 1972 | if (chip->match.addr != sd->i2c_addr) | ||
| 1973 | return -EINVAL; | ||
| 1974 | chip->revision = 0; | ||
| 1975 | chip->ident = i2c_ident[sd->sensor]; | ||
| 1976 | return 0; | ||
| 1977 | } | ||
| 1978 | return -EINVAL; | ||
| 1979 | } | ||
| 1980 | |||
| 1981 | static int sd_config(struct gspca_dev *gspca_dev, | ||
| 1982 | const struct usb_device_id *id) | ||
| 1983 | { | ||
| 1984 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 1985 | struct cam *cam; | ||
| 1986 | |||
| 1987 | cam = &gspca_dev->cam; | ||
| 1988 | |||
| 1989 | sd->sensor = (id->driver_info >> 8) & 0xff; | ||
| 1990 | sd->i2c_addr = id->driver_info & 0xff; | ||
| 1991 | |||
| 1992 | switch (sd->sensor) { | ||
| 1993 | case SENSOR_OV9650: | ||
| 1994 | cam->cam_mode = sxga_mode; | ||
| 1995 | cam->nmodes = ARRAY_SIZE(sxga_mode); | ||
| 1996 | break; | ||
| 1997 | default: | ||
| 1998 | cam->cam_mode = vga_mode; | ||
| 1999 | cam->nmodes = ARRAY_SIZE(vga_mode); | ||
| 2000 | } | ||
| 2001 | |||
| 2002 | sd->old_step = 0; | ||
| 2003 | sd->older_step = 0; | ||
| 2004 | sd->exposure_step = 16; | ||
| 2005 | |||
| 2006 | sd->brightness = BRIGHTNESS_DEFAULT; | ||
| 2007 | sd->contrast = CONTRAST_DEFAULT; | ||
| 2008 | sd->saturation = SATURATION_DEFAULT; | ||
| 2009 | sd->hue = HUE_DEFAULT; | ||
| 2010 | sd->gamma = GAMMA_DEFAULT; | ||
| 2011 | sd->red = RED_DEFAULT; | ||
| 2012 | sd->blue = BLUE_DEFAULT; | ||
| 2013 | |||
| 2014 | sd->hflip = HFLIP_DEFAULT; | ||
| 2015 | sd->vflip = VFLIP_DEFAULT; | ||
| 2016 | sd->exposure = EXPOSURE_DEFAULT; | ||
| 2017 | sd->gain = GAIN_DEFAULT; | ||
| 2018 | sd->auto_exposure = AUTO_EXPOSURE_DEFAULT; | ||
| 2019 | |||
| 2020 | sd->quality = 95; | ||
| 2021 | |||
| 2022 | #ifdef CONFIG_USB_GSPCA_SN9C20X_EVDEV | ||
| 2023 | sd->input_gpio = (id->driver_info >> 16) & 0xff; | ||
| 2024 | if (sn9c20x_input_init(gspca_dev) < 0) | ||
| 2025 | return -ENODEV; | ||
| 2026 | #endif | ||
| 2027 | return 0; | ||
| 2028 | } | ||
| 2029 | |||
| 2030 | static int sd_init(struct gspca_dev *gspca_dev) | ||
| 2031 | { | ||
| 2032 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 2033 | int i; | ||
| 2034 | u8 value; | ||
| 2035 | u8 i2c_init[9] = | ||
| 2036 | {0x80, sd->i2c_addr, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03}; | ||
| 2037 | |||
| 2038 | for (i = 0; i < ARRAY_SIZE(bridge_init); i++) { | ||
| 2039 | value = bridge_init[i][1]; | ||
| 2040 | if (reg_w(gspca_dev, bridge_init[i][0], &value, 1) < 0) { | ||
| 2041 | err("Device initialization failed"); | ||
| 2042 | return -ENODEV; | ||
| 2043 | } | ||
| 2044 | } | ||
| 2045 | |||
| 2046 | if (reg_w(gspca_dev, 0x10c0, i2c_init, 9) < 0) { | ||
| 2047 | err("Device initialization failed"); | ||
| 2048 | return -ENODEV; | ||
| 2049 | } | ||
| 2050 | |||
| 2051 | switch (sd->sensor) { | ||
| 2052 | case SENSOR_OV9650: | ||
| 2053 | if (ov9650_init_sensor(gspca_dev) < 0) | ||
| 2054 | return -ENODEV; | ||
| 2055 | info("OV9650 sensor detected"); | ||
| 2056 | break; | ||
| 2057 | case SENSOR_OV9655: | ||
| 2058 | if (ov9655_init_sensor(gspca_dev) < 0) | ||
| 2059 | return -ENODEV; | ||
| 2060 | info("OV9655 sensor detected"); | ||
| 2061 | break; | ||
| 2062 | case SENSOR_SOI968: | ||
| 2063 | if (soi968_init_sensor(gspca_dev) < 0) | ||
| 2064 | return -ENODEV; | ||
| 2065 | info("SOI968 sensor detected"); | ||
| 2066 | break; | ||
| 2067 | case SENSOR_OV7660: | ||
| 2068 | if (ov7660_init_sensor(gspca_dev) < 0) | ||
| 2069 | return -ENODEV; | ||
| 2070 | info("OV7660 sensor detected"); | ||
| 2071 | break; | ||
| 2072 | case SENSOR_OV7670: | ||
| 2073 | if (ov7670_init_sensor(gspca_dev) < 0) | ||
| 2074 | return -ENODEV; | ||
| 2075 | info("OV7670 sensor detected"); | ||
| 2076 | break; | ||
| 2077 | case SENSOR_MT9VPRB: | ||
| 2078 | if (mt9v_init_sensor(gspca_dev) < 0) | ||
| 2079 | return -ENODEV; | ||
| 2080 | break; | ||
| 2081 | case SENSOR_MT9M111: | ||
| 2082 | if (mt9m111_init_sensor(gspca_dev) < 0) | ||
| 2083 | return -ENODEV; | ||
| 2084 | info("MT9M111 sensor detected"); | ||
| 2085 | break; | ||
| 2086 | case SENSOR_MT9M001: | ||
| 2087 | if (mt9m001_init_sensor(gspca_dev) < 0) | ||
| 2088 | return -ENODEV; | ||
| 2089 | info("MT9M001 sensor detected"); | ||
| 2090 | break; | ||
| 2091 | case SENSOR_HV7131R: | ||
| 2092 | if (hv7131r_init_sensor(gspca_dev) < 0) | ||
| 2093 | return -ENODEV; | ||
| 2094 | info("HV7131R sensor detected"); | ||
| 2095 | break; | ||
| 2096 | default: | ||
| 2097 | info("Unsupported Sensor"); | ||
| 2098 | return -ENODEV; | ||
| 2099 | } | ||
| 2100 | |||
| 2101 | return 0; | ||
| 2102 | } | ||
| 2103 | |||
| 2104 | static void configure_sensor_output(struct gspca_dev *gspca_dev, int mode) | ||
| 2105 | { | ||
| 2106 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 2107 | u8 value; | ||
| 2108 | switch (sd->sensor) { | ||
| 2109 | case SENSOR_OV9650: | ||
| 2110 | if (mode & MODE_SXGA) { | ||
| 2111 | i2c_w1(gspca_dev, 0x17, 0x1b); | ||
| 2112 | i2c_w1(gspca_dev, 0x18, 0xbc); | ||
| 2113 | i2c_w1(gspca_dev, 0x19, 0x01); | ||
| 2114 | i2c_w1(gspca_dev, 0x1a, 0x82); | ||
| 2115 | i2c_r1(gspca_dev, 0x12, &value); | ||
| 2116 | i2c_w1(gspca_dev, 0x12, value & 0x07); | ||
| 2117 | } else { | ||
| 2118 | i2c_w1(gspca_dev, 0x17, 0x24); | ||
| 2119 | i2c_w1(gspca_dev, 0x18, 0xc5); | ||
| 2120 | i2c_w1(gspca_dev, 0x19, 0x00); | ||
| 2121 | i2c_w1(gspca_dev, 0x1a, 0x3c); | ||
| 2122 | i2c_r1(gspca_dev, 0x12, &value); | ||
| 2123 | i2c_w1(gspca_dev, 0x12, (value & 0x7) | 0x40); | ||
| 2124 | } | ||
| 2125 | break; | ||
| 2126 | } | ||
| 2127 | } | ||
| 2128 | |||
| 2129 | #define HW_WIN(mode, hstart, vstart) \ | ||
| 2130 | ((const u8 []){hstart & 0xff, hstart >> 8, \ | ||
| 2131 | vstart & 0xff, vstart >> 8, \ | ||
| 2132 | (mode & MODE_SXGA ? 1280 >> 4 : 640 >> 4), \ | ||
| 2133 | (mode & MODE_SXGA ? 1024 >> 3 : 480 >> 3)}) | ||
| 2134 | |||
| 2135 | #define CLR_WIN(width, height) \ | ||
| 2136 | ((const u8 [])\ | ||
| 2137 | {0, width >> 2, 0, height >> 1,\ | ||
| 2138 | ((width >> 10) & 0x01) | ((height >> 8) & 0x6)}) | ||
| 2139 | |||
| 2140 | static int sd_start(struct gspca_dev *gspca_dev) | ||
| 2141 | { | ||
| 2142 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 2143 | int mode = gspca_dev->cam.cam_mode[(int) gspca_dev->curr_mode].priv; | ||
| 2144 | int width = gspca_dev->width; | ||
| 2145 | int height = gspca_dev->height; | ||
| 2146 | u8 fmt, scale = 0; | ||
| 2147 | |||
| 2148 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); | ||
| 2149 | if (sd->jpeg_hdr == NULL) | ||
| 2150 | return -ENOMEM; | ||
| 2151 | |||
| 2152 | jpeg_define(sd->jpeg_hdr, height, width, | ||
| 2153 | 0x21); | ||
| 2154 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); | ||
| 2155 | |||
| 2156 | if (mode & MODE_RAW) | ||
| 2157 | fmt = 0x2d; | ||
| 2158 | else if (mode & MODE_JPEG) | ||
| 2159 | fmt = 0x2c; | ||
| 2160 | else | ||
| 2161 | fmt = 0x2f; | ||
| 2162 | |||
| 2163 | switch (mode & 0x0f) { | ||
| 2164 | case 3: | ||
| 2165 | scale = 0xc0; | ||
| 2166 | info("Set 1280x1024"); | ||
| 2167 | break; | ||
| 2168 | case 2: | ||
| 2169 | scale = 0x80; | ||
| 2170 | info("Set 640x480"); | ||
| 2171 | break; | ||
| 2172 | case 1: | ||
| 2173 | scale = 0x90; | ||
| 2174 | info("Set 320x240"); | ||
| 2175 | break; | ||
| 2176 | case 0: | ||
| 2177 | scale = 0xa0; | ||
| 2178 | info("Set 160x120"); | ||
| 2179 | break; | ||
| 2180 | } | ||
| 2181 | |||
| 2182 | configure_sensor_output(gspca_dev, mode); | ||
| 2183 | reg_w(gspca_dev, 0x1100, sd->jpeg_hdr + JPEG_QT0_OFFSET, 64); | ||
| 2184 | reg_w(gspca_dev, 0x1140, sd->jpeg_hdr + JPEG_QT1_OFFSET, 64); | ||
| 2185 | reg_w(gspca_dev, 0x10fb, CLR_WIN(width, height), 5); | ||
| 2186 | reg_w(gspca_dev, 0x1180, HW_WIN(mode, sd->hstart, sd->vstart), 6); | ||
| 2187 | reg_w1(gspca_dev, 0x1189, scale); | ||
| 2188 | reg_w1(gspca_dev, 0x10e0, fmt); | ||
| 2189 | |||
| 2190 | set_cmatrix(gspca_dev); | ||
| 2191 | set_gamma(gspca_dev); | ||
| 2192 | set_redblue(gspca_dev); | ||
| 2193 | set_gain(gspca_dev); | ||
| 2194 | set_exposure(gspca_dev); | ||
| 2195 | set_hvflip(gspca_dev); | ||
| 2196 | |||
| 2197 | reg_r(gspca_dev, 0x1061, 1); | ||
| 2198 | reg_w1(gspca_dev, 0x1061, gspca_dev->usb_buf[0] | 0x02); | ||
| 2199 | return 0; | ||
| 2200 | } | ||
| 2201 | |||
| 2202 | static void sd_stopN(struct gspca_dev *gspca_dev) | ||
| 2203 | { | ||
| 2204 | reg_r(gspca_dev, 0x1061, 1); | ||
| 2205 | reg_w1(gspca_dev, 0x1061, gspca_dev->usb_buf[0] & ~0x02); | ||
| 2206 | } | ||
| 2207 | |||
| 2208 | static void sd_stop0(struct gspca_dev *gspca_dev) | ||
| 2209 | { | ||
| 2210 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 2211 | kfree(sd->jpeg_hdr); | ||
| 2212 | } | ||
| 2213 | |||
| 2214 | static void do_autoexposure(struct gspca_dev *gspca_dev) | ||
| 2215 | { | ||
| 2216 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 2217 | int avg_lum, new_exp; | ||
| 2218 | |||
| 2219 | if (!sd->auto_exposure) | ||
| 2220 | return; | ||
| 2221 | |||
| 2222 | avg_lum = atomic_read(&sd->avg_lum); | ||
| 2223 | |||
| 2224 | /* | ||
| 2225 | * some hardcoded values are present | ||
| 2226 | * like those for maximal/minimal exposure | ||
| 2227 | * and exposure steps | ||
| 2228 | */ | ||
| 2229 | if (avg_lum < MIN_AVG_LUM) { | ||
| 2230 | if (sd->exposure > 0x1770) | ||
| 2231 | return; | ||
| 2232 | |||
| 2233 | new_exp = sd->exposure + sd->exposure_step; | ||
| 2234 | if (new_exp > 0x1770) | ||
| 2235 | new_exp = 0x1770; | ||
| 2236 | if (new_exp < 0x10) | ||
| 2237 | new_exp = 0x10; | ||
| 2238 | sd->exposure = new_exp; | ||
| 2239 | set_exposure(gspca_dev); | ||
| 2240 | |||
| 2241 | sd->older_step = sd->old_step; | ||
| 2242 | sd->old_step = 1; | ||
| 2243 | |||
| 2244 | if (sd->old_step ^ sd->older_step) | ||
| 2245 | sd->exposure_step /= 2; | ||
| 2246 | else | ||
| 2247 | sd->exposure_step += 2; | ||
| 2248 | } | ||
| 2249 | if (avg_lum > MAX_AVG_LUM) { | ||
| 2250 | if (sd->exposure < 0x10) | ||
| 2251 | return; | ||
| 2252 | new_exp = sd->exposure - sd->exposure_step; | ||
| 2253 | if (new_exp > 0x1700) | ||
| 2254 | new_exp = 0x1770; | ||
| 2255 | if (new_exp < 0x10) | ||
| 2256 | new_exp = 0x10; | ||
| 2257 | sd->exposure = new_exp; | ||
| 2258 | set_exposure(gspca_dev); | ||
| 2259 | sd->older_step = sd->old_step; | ||
| 2260 | sd->old_step = 0; | ||
| 2261 | |||
| 2262 | if (sd->old_step ^ sd->older_step) | ||
| 2263 | sd->exposure_step /= 2; | ||
| 2264 | else | ||
| 2265 | sd->exposure_step += 2; | ||
| 2266 | } | ||
| 2267 | } | ||
| 2268 | |||
| 2269 | static void sd_pkt_scan(struct gspca_dev *gspca_dev, | ||
| 2270 | struct gspca_frame *frame, /* target */ | ||
| 2271 | u8 *data, /* isoc packet */ | ||
| 2272 | int len) /* iso packet length */ | ||
| 2273 | { | ||
| 2274 | struct sd *sd = (struct sd *) gspca_dev; | ||
| 2275 | int avg_lum; | ||
| 2276 | static unsigned char frame_header[] = | ||
| 2277 | {0xff, 0xff, 0x00, 0xc4, 0xc4, 0x96}; | ||
| 2278 | if (len == 64 && memcmp(data, frame_header, 6) == 0) { | ||
| 2279 | avg_lum = ((data[35] >> 2) & 3) | | ||
| 2280 | (data[20] << 2) | | ||
| 2281 | (data[19] << 10); | ||
| 2282 | avg_lum += ((data[35] >> 4) & 3) | | ||
| 2283 | (data[22] << 2) | | ||
| 2284 | (data[21] << 10); | ||
| 2285 | avg_lum += ((data[35] >> 6) & 3) | | ||
| 2286 | (data[24] << 2) | | ||
| 2287 | (data[23] << 10); | ||
| 2288 | avg_lum += (data[36] & 3) | | ||
| 2289 | (data[26] << 2) | | ||
| 2290 | (data[25] << 10); | ||
| 2291 | avg_lum += ((data[36] >> 2) & 3) | | ||
| 2292 | (data[28] << 2) | | ||
| 2293 | (data[27] << 10); | ||
| 2294 | avg_lum += ((data[36] >> 4) & 3) | | ||
| 2295 | (data[30] << 2) | | ||
| 2296 | (data[29] << 10); | ||
| 2297 | avg_lum += ((data[36] >> 6) & 3) | | ||
| 2298 | (data[32] << 2) | | ||
| 2299 | (data[31] << 10); | ||
| 2300 | avg_lum += ((data[44] >> 4) & 3) | | ||
| 2301 | (data[34] << 2) | | ||
| 2302 | (data[33] << 10); | ||
| 2303 | avg_lum >>= 9; | ||
| 2304 | atomic_set(&sd->avg_lum, avg_lum); | ||
| 2305 | gspca_frame_add(gspca_dev, LAST_PACKET, | ||
| 2306 | frame, data, len); | ||
| 2307 | return; | ||
| 2308 | } | ||
| 2309 | if (gspca_dev->last_packet_type == LAST_PACKET) { | ||
| 2310 | if (gspca_dev->cam.cam_mode[(int) gspca_dev->curr_mode].priv | ||
| 2311 | & MODE_JPEG) { | ||
| 2312 | gspca_frame_add(gspca_dev, FIRST_PACKET, frame, | ||
| 2313 | sd->jpeg_hdr, JPEG_HDR_SZ); | ||
| 2314 | gspca_frame_add(gspca_dev, INTER_PACKET, frame, | ||
| 2315 | data, len); | ||
| 2316 | } else { | ||
| 2317 | gspca_frame_add(gspca_dev, FIRST_PACKET, frame, | ||
| 2318 | data, len); | ||
| 2319 | } | ||
| 2320 | } else { | ||
| 2321 | gspca_frame_add(gspca_dev, INTER_PACKET, frame, data, len); | ||
| 2322 | } | ||
| 2323 | } | ||
| 2324 | |||
| 2325 | /* sub-driver description */ | ||
| 2326 | static const struct sd_desc sd_desc = { | ||
| 2327 | .name = MODULE_NAME, | ||
| 2328 | .ctrls = sd_ctrls, | ||
| 2329 | .nctrls = ARRAY_SIZE(sd_ctrls), | ||
| 2330 | .config = sd_config, | ||
| 2331 | .init = sd_init, | ||
| 2332 | .start = sd_start, | ||
| 2333 | .stopN = sd_stopN, | ||
| 2334 | .stop0 = sd_stop0, | ||
| 2335 | .pkt_scan = sd_pkt_scan, | ||
| 2336 | .dq_callback = do_autoexposure, | ||
| 2337 | #ifdef CONFIG_VIDEO_ADV_DEBUG | ||
| 2338 | .set_register = sd_dbg_s_register, | ||
| 2339 | .get_register = sd_dbg_g_register, | ||
| 2340 | #endif | ||
| 2341 | .get_chip_ident = sd_chip_ident, | ||
| 2342 | }; | ||
| 2343 | |||
| 2344 | #define SN9C20X(sensor, i2c_addr, button_mask) \ | ||
| 2345 | .driver_info = (button_mask << 16) \ | ||
| 2346 | | (SENSOR_ ## sensor << 8) \ | ||
| 2347 | | (i2c_addr) | ||
| 2348 | |||
| 2349 | static const __devinitdata struct usb_device_id device_table[] = { | ||
| 2350 | {USB_DEVICE(0x0c45, 0x6240), SN9C20X(MT9M001, 0x5d, 0)}, | ||
| 2351 | {USB_DEVICE(0x0c45, 0x6242), SN9C20X(MT9M111, 0x5d, 0)}, | ||
| 2352 | {USB_DEVICE(0x0c45, 0x6248), SN9C20X(OV9655, 0x30, 0)}, | ||
| 2353 | {USB_DEVICE(0x0c45, 0x624e), SN9C20X(SOI968, 0x30, 0x10)}, | ||
| 2354 | {USB_DEVICE(0x0c45, 0x624f), SN9C20X(OV9650, 0x30, 0)}, | ||
| 2355 | {USB_DEVICE(0x0c45, 0x6251), SN9C20X(OV9650, 0x30, 0)}, | ||
| 2356 | {USB_DEVICE(0x0c45, 0x6253), SN9C20X(OV9650, 0x30, 0)}, | ||
| 2357 | {USB_DEVICE(0x0c45, 0x6260), SN9C20X(OV7670, 0x21, 0)}, | ||
| 2358 | {USB_DEVICE(0x0c45, 0x6270), SN9C20X(MT9VPRB, 0x00, 0)}, | ||
| 2359 | {USB_DEVICE(0x0c45, 0x627b), SN9C20X(OV7660, 0x21, 0)}, | ||
| 2360 | {USB_DEVICE(0x0c45, 0x627c), SN9C20X(HV7131R, 0x11, 0)}, | ||
| 2361 | {USB_DEVICE(0x0c45, 0x627f), SN9C20X(OV9650, 0x30, 0)}, | ||
| 2362 | {USB_DEVICE(0x0c45, 0x6280), SN9C20X(MT9M001, 0x5d, 0)}, | ||
| 2363 | {USB_DEVICE(0x0c45, 0x6282), SN9C20X(MT9M111, 0x5d, 0)}, | ||
| 2364 | {USB_DEVICE(0x0c45, 0x6288), SN9C20X(OV9655, 0x30, 0)}, | ||
| 2365 | {USB_DEVICE(0x0c45, 0x628e), SN9C20X(SOI968, 0x30, 0)}, | ||
| 2366 | {USB_DEVICE(0x0c45, 0x628f), SN9C20X(OV9650, 0x30, 0)}, | ||
| 2367 | {USB_DEVICE(0x0c45, 0x62a0), SN9C20X(OV7670, 0x21, 0)}, | ||
| 2368 | {USB_DEVICE(0x0c45, 0x62b0), SN9C20X(MT9VPRB, 0x00, 0)}, | ||
| 2369 | {USB_DEVICE(0x0c45, 0x62b3), SN9C20X(OV9655, 0x30, 0)}, | ||
| 2370 | {USB_DEVICE(0x0c45, 0x62bb), SN9C20X(OV7660, 0x21, 0)}, | ||
| 2371 | {USB_DEVICE(0x0c45, 0x62bc), SN9C20X(HV7131R, 0x11, 0)}, | ||
| 2372 | {USB_DEVICE(0x045e, 0x00f4), SN9C20X(OV9650, 0x30, 0)}, | ||
| 2373 | {USB_DEVICE(0x145f, 0x013d), SN9C20X(OV7660, 0x21, 0)}, | ||
| 2374 | {USB_DEVICE(0x0458, 0x7029), SN9C20X(HV7131R, 0x11, 0)}, | ||
| 2375 | {USB_DEVICE(0xa168, 0x0610), SN9C20X(HV7131R, 0x11, 0)}, | ||
| 2376 | {USB_DEVICE(0xa168, 0x0611), SN9C20X(HV7131R, 0x11, 0)}, | ||
| 2377 | {USB_DEVICE(0xa168, 0x0613), SN9C20X(HV7131R, 0x11, 0)}, | ||
| 2378 | {USB_DEVICE(0xa168, 0x0618), SN9C20X(HV7131R, 0x11, 0)}, | ||
| 2379 | {USB_DEVICE(0xa168, 0x0614), SN9C20X(MT9M111, 0x5d, 0)}, | ||
| 2380 | {USB_DEVICE(0xa168, 0x0615), SN9C20X(MT9M111, 0x5d, 0)}, | ||
| 2381 | {USB_DEVICE(0xa168, 0x0617), SN9C20X(MT9M111, 0x5d, 0)}, | ||
| 2382 | {} | ||
| 2383 | }; | ||
| 2384 | MODULE_DEVICE_TABLE(usb, device_table); | ||
| 2385 | |||
| 2386 | /* -- device connect -- */ | ||
| 2387 | static int sd_probe(struct usb_interface *intf, | ||
| 2388 | const struct usb_device_id *id) | ||
| 2389 | { | ||
| 2390 | return gspca_dev_probe(intf, id, &sd_desc, sizeof(struct sd), | ||
| 2391 | THIS_MODULE); | ||
| 2392 | } | ||
| 2393 | |||
| 2394 | static void sd_disconnect(struct usb_interface *intf) | ||
| 2395 | { | ||
| 2396 | #ifdef CONFIG_USB_GSPCA_SN9C20X_EVDEV | ||
| 2397 | struct gspca_dev *gspca_dev = usb_get_intfdata(intf); | ||
| 2398 | |||
| 2399 | sn9c20x_input_cleanup(gspca_dev); | ||
| 2400 | #endif | ||
| 2401 | |||
| 2402 | gspca_disconnect(intf); | ||
| 2403 | } | ||
| 2404 | |||
| 2405 | static struct usb_driver sd_driver = { | ||
| 2406 | .name = MODULE_NAME, | ||
| 2407 | .id_table = device_table, | ||
| 2408 | .probe = sd_probe, | ||
| 2409 | .disconnect = sd_disconnect, | ||
| 2410 | #ifdef CONFIG_PM | ||
| 2411 | .suspend = gspca_suspend, | ||
| 2412 | .resume = gspca_resume, | ||
| 2413 | .reset_resume = gspca_resume, | ||
| 2414 | #endif | ||
| 2415 | }; | ||
| 2416 | |||
| 2417 | /* -- module insert / remove -- */ | ||
| 2418 | static int __init sd_mod_init(void) | ||
| 2419 | { | ||
| 2420 | int ret; | ||
| 2421 | ret = usb_register(&sd_driver); | ||
| 2422 | if (ret < 0) | ||
| 2423 | return ret; | ||
| 2424 | info("registered"); | ||
| 2425 | return 0; | ||
| 2426 | } | ||
| 2427 | static void __exit sd_mod_exit(void) | ||
| 2428 | { | ||
| 2429 | usb_deregister(&sd_driver); | ||
| 2430 | info("deregistered"); | ||
| 2431 | } | ||
| 2432 | |||
| 2433 | module_init(sd_mod_init); | ||
| 2434 | module_exit(sd_mod_exit); | ||
diff --git a/drivers/media/video/gspca/sonixj.c b/drivers/media/video/gspca/sonixj.c index 0d02f41fa7d0..d6332ab80669 100644 --- a/drivers/media/video/gspca/sonixj.c +++ b/drivers/media/video/gspca/sonixj.c | |||
| @@ -1634,6 +1634,8 @@ static void setfreq(struct gspca_dev *gspca_dev) | |||
| 1634 | { | 1634 | { |
| 1635 | struct sd *sd = (struct sd *) gspca_dev; | 1635 | struct sd *sd = (struct sd *) gspca_dev; |
| 1636 | 1636 | ||
| 1637 | if (gspca_dev->ctrl_dis & (1 << FREQ_IDX)) | ||
| 1638 | return; | ||
| 1637 | if (sd->sensor == SENSOR_OV7660) { | 1639 | if (sd->sensor == SENSOR_OV7660) { |
| 1638 | switch (sd->freq) { | 1640 | switch (sd->freq) { |
| 1639 | case 0: /* Banding filter disabled */ | 1641 | case 0: /* Banding filter disabled */ |
| @@ -1735,6 +1737,8 @@ static int sd_start(struct gspca_dev *gspca_dev) | |||
| 1735 | 1737 | ||
| 1736 | /* create the JPEG header */ | 1738 | /* create the JPEG header */ |
| 1737 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); | 1739 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); |
| 1740 | if (!sd->jpeg_hdr) | ||
| 1741 | return -ENOMEM; | ||
| 1738 | jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width, | 1742 | jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width, |
| 1739 | 0x21); /* JPEG 422 */ | 1743 | 0x21); /* JPEG 422 */ |
| 1740 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); | 1744 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); |
diff --git a/drivers/media/video/gspca/spca500.c b/drivers/media/video/gspca/spca500.c index 8806b2ff82be..fab7ef85a6c1 100644 --- a/drivers/media/video/gspca/spca500.c +++ b/drivers/media/video/gspca/spca500.c | |||
| @@ -670,6 +670,8 @@ static int sd_start(struct gspca_dev *gspca_dev) | |||
| 670 | 670 | ||
| 671 | /* create the JPEG header */ | 671 | /* create the JPEG header */ |
| 672 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); | 672 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); |
| 673 | if (!sd->jpeg_hdr) | ||
| 674 | return -ENOMEM; | ||
| 673 | jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width, | 675 | jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width, |
| 674 | 0x22); /* JPEG 411 */ | 676 | 0x22); /* JPEG 411 */ |
| 675 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); | 677 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); |
diff --git a/drivers/media/video/gspca/stk014.c b/drivers/media/video/gspca/stk014.c index f25be20cf1a6..47628964801e 100644 --- a/drivers/media/video/gspca/stk014.c +++ b/drivers/media/video/gspca/stk014.c | |||
| @@ -333,6 +333,8 @@ static int sd_start(struct gspca_dev *gspca_dev) | |||
| 333 | 333 | ||
| 334 | /* create the JPEG header */ | 334 | /* create the JPEG header */ |
| 335 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); | 335 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); |
| 336 | if (!sd->jpeg_hdr) | ||
| 337 | return -ENOMEM; | ||
| 336 | jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width, | 338 | jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width, |
| 337 | 0x22); /* JPEG 411 */ | 339 | 0x22); /* JPEG 411 */ |
| 338 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); | 340 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); |
diff --git a/drivers/media/video/gspca/stv06xx/stv06xx_hdcs.c b/drivers/media/video/gspca/stv06xx/stv06xx_hdcs.c index 3039ec208f3a..e5024c8496ef 100644 --- a/drivers/media/video/gspca/stv06xx/stv06xx_hdcs.c +++ b/drivers/media/video/gspca/stv06xx/stv06xx_hdcs.c | |||
| @@ -64,7 +64,7 @@ static struct v4l2_pix_format hdcs1x00_mode[] = { | |||
| 64 | { | 64 | { |
| 65 | HDCS_1X00_DEF_WIDTH, | 65 | HDCS_1X00_DEF_WIDTH, |
| 66 | HDCS_1X00_DEF_HEIGHT, | 66 | HDCS_1X00_DEF_HEIGHT, |
| 67 | V4L2_PIX_FMT_SBGGR8, | 67 | V4L2_PIX_FMT_SGRBG8, |
| 68 | V4L2_FIELD_NONE, | 68 | V4L2_FIELD_NONE, |
| 69 | .sizeimage = | 69 | .sizeimage = |
| 70 | HDCS_1X00_DEF_WIDTH * HDCS_1X00_DEF_HEIGHT, | 70 | HDCS_1X00_DEF_WIDTH * HDCS_1X00_DEF_HEIGHT, |
| @@ -80,7 +80,7 @@ static struct v4l2_pix_format hdcs1020_mode[] = { | |||
| 80 | { | 80 | { |
| 81 | HDCS_1020_DEF_WIDTH, | 81 | HDCS_1020_DEF_WIDTH, |
| 82 | HDCS_1020_DEF_HEIGHT, | 82 | HDCS_1020_DEF_HEIGHT, |
| 83 | V4L2_PIX_FMT_SBGGR8, | 83 | V4L2_PIX_FMT_SGRBG8, |
| 84 | V4L2_FIELD_NONE, | 84 | V4L2_FIELD_NONE, |
| 85 | .sizeimage = | 85 | .sizeimage = |
| 86 | HDCS_1020_DEF_WIDTH * HDCS_1020_DEF_HEIGHT, | 86 | HDCS_1020_DEF_WIDTH * HDCS_1020_DEF_HEIGHT, |
| @@ -131,9 +131,11 @@ static int hdcs_reg_write_seq(struct sd *sd, u8 reg, u8 *vals, u8 len) | |||
| 131 | (reg + len > 0xff))) | 131 | (reg + len > 0xff))) |
| 132 | return -EINVAL; | 132 | return -EINVAL; |
| 133 | 133 | ||
| 134 | for (i = 0; i < len; i++, reg++) { | 134 | for (i = 0; i < len; i++) { |
| 135 | regs[2*i] = reg; | 135 | regs[2 * i] = reg; |
| 136 | regs[2*i+1] = vals[i]; | 136 | regs[2 * i + 1] = vals[i]; |
| 137 | /* All addresses are shifted left one bit as bit 0 toggles r/w */ | ||
| 138 | reg += 2; | ||
| 137 | } | 139 | } |
| 138 | 140 | ||
| 139 | return stv06xx_write_sensor_bytes(sd, regs, len); | 141 | return stv06xx_write_sensor_bytes(sd, regs, len); |
| @@ -174,7 +176,9 @@ static int hdcs_set_state(struct sd *sd, enum hdcs_power_state state) | |||
| 174 | } | 176 | } |
| 175 | 177 | ||
| 176 | ret = stv06xx_write_sensor(sd, HDCS_REG_CONTROL(sd), val); | 178 | ret = stv06xx_write_sensor(sd, HDCS_REG_CONTROL(sd), val); |
| 177 | if (ret < 0) | 179 | |
| 180 | /* Update the state if the write succeeded */ | ||
| 181 | if (!ret) | ||
| 178 | hdcs->state = state; | 182 | hdcs->state = state; |
| 179 | 183 | ||
| 180 | return ret; | 184 | return ret; |
diff --git a/drivers/media/video/gspca/sunplus.c b/drivers/media/video/gspca/sunplus.c index 9623f294bdac..5127bbf9dd26 100644 --- a/drivers/media/video/gspca/sunplus.c +++ b/drivers/media/video/gspca/sunplus.c | |||
| @@ -973,6 +973,8 @@ static int sd_start(struct gspca_dev *gspca_dev) | |||
| 973 | 973 | ||
| 974 | /* create the JPEG header */ | 974 | /* create the JPEG header */ |
| 975 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); | 975 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); |
| 976 | if (!sd->jpeg_hdr) | ||
| 977 | return -ENOMEM; | ||
| 976 | jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width, | 978 | jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width, |
| 977 | 0x22); /* JPEG 411 */ | 979 | 0x22); /* JPEG 411 */ |
| 978 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); | 980 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); |
diff --git a/drivers/media/video/gspca/zc3xx.c b/drivers/media/video/gspca/zc3xx.c index 08422d315e68..3d2756f7874a 100644 --- a/drivers/media/video/gspca/zc3xx.c +++ b/drivers/media/video/gspca/zc3xx.c | |||
| @@ -7243,6 +7243,8 @@ static int sd_start(struct gspca_dev *gspca_dev) | |||
| 7243 | 7243 | ||
| 7244 | /* create the JPEG header */ | 7244 | /* create the JPEG header */ |
| 7245 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); | 7245 | sd->jpeg_hdr = kmalloc(JPEG_HDR_SZ, GFP_KERNEL); |
| 7246 | if (!sd->jpeg_hdr) | ||
| 7247 | return -ENOMEM; | ||
| 7246 | jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width, | 7248 | jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width, |
| 7247 | 0x21); /* JPEG 422 */ | 7249 | 0x21); /* JPEG 422 */ |
| 7248 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); | 7250 | jpeg_set_qual(sd->jpeg_hdr, sd->quality); |
diff --git a/drivers/media/video/hdpvr/hdpvr-video.c b/drivers/media/video/hdpvr/hdpvr-video.c index ccd47f57f42c..d678765cbba2 100644 --- a/drivers/media/video/hdpvr/hdpvr-video.c +++ b/drivers/media/video/hdpvr/hdpvr-video.c | |||
| @@ -1220,6 +1220,8 @@ static const struct video_device hdpvr_video_template = { | |||
| 1220 | V4L2_STD_PAL_G | V4L2_STD_PAL_H | V4L2_STD_PAL_I | | 1220 | V4L2_STD_PAL_G | V4L2_STD_PAL_H | V4L2_STD_PAL_I | |
| 1221 | V4L2_STD_PAL_D | V4L2_STD_PAL_M | V4L2_STD_PAL_N | | 1221 | V4L2_STD_PAL_D | V4L2_STD_PAL_M | V4L2_STD_PAL_N | |
| 1222 | V4L2_STD_PAL_60, | 1222 | V4L2_STD_PAL_60, |
| 1223 | .current_norm = V4L2_STD_NTSC | V4L2_STD_PAL_M | | ||
| 1224 | V4L2_STD_PAL_60, | ||
| 1223 | }; | 1225 | }; |
| 1224 | 1226 | ||
| 1225 | int hdpvr_register_videodev(struct hdpvr_device *dev, struct device *parent, | 1227 | int hdpvr_register_videodev(struct hdpvr_device *dev, struct device *parent, |
diff --git a/drivers/media/video/ivtv/ivtv-controls.c b/drivers/media/video/ivtv/ivtv-controls.c index a3b77ed3f089..4a9c8ce0ecb3 100644 --- a/drivers/media/video/ivtv/ivtv-controls.c +++ b/drivers/media/video/ivtv/ivtv-controls.c | |||
| @@ -17,6 +17,7 @@ | |||
| 17 | along with this program; if not, write to the Free Software | 17 | along with this program; if not, write to the Free Software |
| 18 | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | 18 | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
| 19 | */ | 19 | */ |
| 20 | #include <linux/kernel.h> | ||
| 20 | 21 | ||
| 21 | #include "ivtv-driver.h" | 22 | #include "ivtv-driver.h" |
| 22 | #include "ivtv-cards.h" | 23 | #include "ivtv-cards.h" |
| @@ -281,7 +282,7 @@ int ivtv_s_ext_ctrls(struct file *file, void *fh, struct v4l2_ext_controls *c) | |||
| 281 | idx = p.audio_properties & 0x03; | 282 | idx = p.audio_properties & 0x03; |
| 282 | /* The audio clock of the digitizer must match the codec sample | 283 | /* The audio clock of the digitizer must match the codec sample |
| 283 | rate otherwise you get some very strange effects. */ | 284 | rate otherwise you get some very strange effects. */ |
| 284 | if (idx < sizeof(freqs)) | 285 | if (idx < ARRAY_SIZE(freqs)) |
| 285 | ivtv_call_all(itv, audio, s_clock_freq, freqs[idx]); | 286 | ivtv_call_all(itv, audio, s_clock_freq, freqs[idx]); |
| 286 | return err; | 287 | return err; |
| 287 | } | 288 | } |
diff --git a/drivers/media/video/mt9v011.c b/drivers/media/video/mt9v011.c index 1fe8fc9183a7..cc85f77a5706 100644 --- a/drivers/media/video/mt9v011.c +++ b/drivers/media/video/mt9v011.c | |||
| @@ -8,6 +8,7 @@ | |||
| 8 | #include <linux/i2c.h> | 8 | #include <linux/i2c.h> |
| 9 | #include <linux/videodev2.h> | 9 | #include <linux/videodev2.h> |
| 10 | #include <linux/delay.h> | 10 | #include <linux/delay.h> |
| 11 | #include <asm/div64.h> | ||
| 11 | #include <media/v4l2-device.h> | 12 | #include <media/v4l2-device.h> |
| 12 | #include "mt9v011.h" | 13 | #include "mt9v011.h" |
| 13 | #include <media/v4l2-i2c-drv.h> | 14 | #include <media/v4l2-i2c-drv.h> |
| @@ -51,12 +52,34 @@ static struct v4l2_queryctrl mt9v011_qctrl[] = { | |||
| 51 | .step = 1, | 52 | .step = 1, |
| 52 | .default_value = 0, | 53 | .default_value = 0, |
| 53 | .flags = 0, | 54 | .flags = 0, |
| 54 | }, | 55 | }, { |
| 56 | .id = V4L2_CID_HFLIP, | ||
| 57 | .type = V4L2_CTRL_TYPE_BOOLEAN, | ||
| 58 | .name = "Mirror", | ||
| 59 | .minimum = 0, | ||
| 60 | .maximum = 1, | ||
| 61 | .step = 1, | ||
| 62 | .default_value = 0, | ||
| 63 | .flags = 0, | ||
| 64 | }, { | ||
| 65 | .id = V4L2_CID_VFLIP, | ||
| 66 | .type = V4L2_CTRL_TYPE_BOOLEAN, | ||
| 67 | .name = "Vflip", | ||
| 68 | .minimum = 0, | ||
| 69 | .maximum = 1, | ||
| 70 | .step = 1, | ||
| 71 | .default_value = 0, | ||
| 72 | .flags = 0, | ||
| 73 | }, { | ||
| 74 | } | ||
| 55 | }; | 75 | }; |
| 56 | 76 | ||
| 57 | struct mt9v011 { | 77 | struct mt9v011 { |
| 58 | struct v4l2_subdev sd; | 78 | struct v4l2_subdev sd; |
| 59 | unsigned width, height; | 79 | unsigned width, height; |
| 80 | unsigned xtal; | ||
| 81 | unsigned hflip:1; | ||
| 82 | unsigned vflip:1; | ||
| 60 | 83 | ||
| 61 | u16 global_gain, red_bal, blue_bal; | 84 | u16 global_gain, red_bal, blue_bal; |
| 62 | }; | 85 | }; |
| @@ -129,9 +152,8 @@ static const struct i2c_reg_value mt9v011_init_default[] = { | |||
| 129 | 152 | ||
| 130 | { R0A_MT9V011_CLK_SPEED, 0x0000 }, | 153 | { R0A_MT9V011_CLK_SPEED, 0x0000 }, |
| 131 | { R1E_MT9V011_DIGITAL_ZOOM, 0x0000 }, | 154 | { R1E_MT9V011_DIGITAL_ZOOM, 0x0000 }, |
| 132 | { R20_MT9V011_READ_MODE, 0x1000 }, | ||
| 133 | 155 | ||
| 134 | { R07_MT9V011_OUT_CTRL, 0x000a }, /* chip enable */ | 156 | { R07_MT9V011_OUT_CTRL, 0x0002 }, /* chip enable */ |
| 135 | }; | 157 | }; |
| 136 | 158 | ||
| 137 | static void set_balance(struct v4l2_subdev *sd) | 159 | static void set_balance(struct v4l2_subdev *sd) |
| @@ -154,6 +176,76 @@ static void set_balance(struct v4l2_subdev *sd) | |||
| 154 | mt9v011_write(sd, R2D_MT9V011_RED_GAIN, red_gain); | 176 | mt9v011_write(sd, R2D_MT9V011_RED_GAIN, red_gain); |
| 155 | } | 177 | } |
| 156 | 178 | ||
| 179 | static void calc_fps(struct v4l2_subdev *sd, u32 *numerator, u32 *denominator) | ||
| 180 | { | ||
| 181 | struct mt9v011 *core = to_mt9v011(sd); | ||
| 182 | unsigned height, width, hblank, vblank, speed; | ||
| 183 | unsigned row_time, t_time; | ||
| 184 | u64 frames_per_ms; | ||
| 185 | unsigned tmp; | ||
| 186 | |||
| 187 | height = mt9v011_read(sd, R03_MT9V011_HEIGHT); | ||
| 188 | width = mt9v011_read(sd, R04_MT9V011_WIDTH); | ||
| 189 | hblank = mt9v011_read(sd, R05_MT9V011_HBLANK); | ||
| 190 | vblank = mt9v011_read(sd, R06_MT9V011_VBLANK); | ||
| 191 | speed = mt9v011_read(sd, R0A_MT9V011_CLK_SPEED); | ||
| 192 | |||
| 193 | row_time = (width + 113 + hblank) * (speed + 2); | ||
| 194 | t_time = row_time * (height + vblank + 1); | ||
| 195 | |||
| 196 | frames_per_ms = core->xtal * 1000l; | ||
| 197 | do_div(frames_per_ms, t_time); | ||
| 198 | tmp = frames_per_ms; | ||
| 199 | |||
| 200 | v4l2_dbg(1, debug, sd, "Programmed to %u.%03u fps (%d pixel clcks)\n", | ||
| 201 | tmp / 1000, tmp % 1000, t_time); | ||
| 202 | |||
| 203 | if (numerator && denominator) { | ||
| 204 | *numerator = 1000; | ||
| 205 | *denominator = (u32)frames_per_ms; | ||
| 206 | } | ||
| 207 | } | ||
| 208 | |||
| 209 | static u16 calc_speed(struct v4l2_subdev *sd, u32 numerator, u32 denominator) | ||
| 210 | { | ||
| 211 | struct mt9v011 *core = to_mt9v011(sd); | ||
| 212 | unsigned height, width, hblank, vblank; | ||
| 213 | unsigned row_time, line_time; | ||
| 214 | u64 t_time, speed; | ||
| 215 | |||
| 216 | /* Avoid bogus calculus */ | ||
| 217 | if (!numerator || !denominator) | ||
| 218 | return 0; | ||
| 219 | |||
| 220 | height = mt9v011_read(sd, R03_MT9V011_HEIGHT); | ||
| 221 | width = mt9v011_read(sd, R04_MT9V011_WIDTH); | ||
| 222 | hblank = mt9v011_read(sd, R05_MT9V011_HBLANK); | ||
| 223 | vblank = mt9v011_read(sd, R06_MT9V011_VBLANK); | ||
| 224 | |||
| 225 | row_time = width + 113 + hblank; | ||
| 226 | line_time = height + vblank + 1; | ||
| 227 | |||
| 228 | t_time = core->xtal * ((u64)numerator); | ||
| 229 | /* round to the closest value */ | ||
| 230 | t_time += denominator / 2; | ||
| 231 | do_div(t_time, denominator); | ||
| 232 | |||
| 233 | speed = t_time; | ||
| 234 | do_div(speed, row_time * line_time); | ||
| 235 | |||
| 236 | /* Avoid having a negative value for speed */ | ||
| 237 | if (speed < 2) | ||
| 238 | speed = 0; | ||
| 239 | else | ||
| 240 | speed -= 2; | ||
| 241 | |||
| 242 | /* Avoid speed overflow */ | ||
| 243 | if (speed > 15) | ||
| 244 | return 15; | ||
| 245 | |||
| 246 | return (u16)speed; | ||
| 247 | } | ||
| 248 | |||
| 157 | static void set_res(struct v4l2_subdev *sd) | 249 | static void set_res(struct v4l2_subdev *sd) |
| 158 | { | 250 | { |
| 159 | struct mt9v011 *core = to_mt9v011(sd); | 251 | struct mt9v011 *core = to_mt9v011(sd); |
| @@ -175,12 +267,28 @@ static void set_res(struct v4l2_subdev *sd) | |||
| 175 | mt9v011_write(sd, R04_MT9V011_WIDTH, core->width); | 267 | mt9v011_write(sd, R04_MT9V011_WIDTH, core->width); |
| 176 | mt9v011_write(sd, R05_MT9V011_HBLANK, 771 - core->width); | 268 | mt9v011_write(sd, R05_MT9V011_HBLANK, 771 - core->width); |
| 177 | 269 | ||
| 178 | vstart = 8 + (640 - core->height) / 2; | 270 | vstart = 8 + (480 - core->height) / 2; |
| 179 | mt9v011_write(sd, R01_MT9V011_ROWSTART, vstart); | 271 | mt9v011_write(sd, R01_MT9V011_ROWSTART, vstart); |
| 180 | mt9v011_write(sd, R03_MT9V011_HEIGHT, core->height); | 272 | mt9v011_write(sd, R03_MT9V011_HEIGHT, core->height); |
| 181 | mt9v011_write(sd, R06_MT9V011_VBLANK, 508 - core->height); | 273 | mt9v011_write(sd, R06_MT9V011_VBLANK, 508 - core->height); |
| 274 | |||
| 275 | calc_fps(sd, NULL, NULL); | ||
| 182 | }; | 276 | }; |
| 183 | 277 | ||
| 278 | static void set_read_mode(struct v4l2_subdev *sd) | ||
| 279 | { | ||
| 280 | struct mt9v011 *core = to_mt9v011(sd); | ||
| 281 | unsigned mode = 0x1000; | ||
| 282 | |||
| 283 | if (core->hflip) | ||
| 284 | mode |= 0x4000; | ||
| 285 | |||
| 286 | if (core->vflip) | ||
| 287 | mode |= 0x8000; | ||
| 288 | |||
| 289 | mt9v011_write(sd, R20_MT9V011_READ_MODE, mode); | ||
| 290 | } | ||
| 291 | |||
| 184 | static int mt9v011_reset(struct v4l2_subdev *sd, u32 val) | 292 | static int mt9v011_reset(struct v4l2_subdev *sd, u32 val) |
| 185 | { | 293 | { |
| 186 | int i; | 294 | int i; |
| @@ -191,6 +299,7 @@ static int mt9v011_reset(struct v4l2_subdev *sd, u32 val) | |||
| 191 | 299 | ||
| 192 | set_balance(sd); | 300 | set_balance(sd); |
| 193 | set_res(sd); | 301 | set_res(sd); |
| 302 | set_read_mode(sd); | ||
| 194 | 303 | ||
| 195 | return 0; | 304 | return 0; |
| 196 | }; | 305 | }; |
| @@ -211,10 +320,33 @@ static int mt9v011_g_ctrl(struct v4l2_subdev *sd, struct v4l2_control *ctrl) | |||
| 211 | case V4L2_CID_BLUE_BALANCE: | 320 | case V4L2_CID_BLUE_BALANCE: |
| 212 | ctrl->value = core->blue_bal; | 321 | ctrl->value = core->blue_bal; |
| 213 | return 0; | 322 | return 0; |
| 323 | case V4L2_CID_HFLIP: | ||
| 324 | ctrl->value = core->hflip ? 1 : 0; | ||
| 325 | return 0; | ||
| 326 | case V4L2_CID_VFLIP: | ||
| 327 | ctrl->value = core->vflip ? 1 : 0; | ||
| 328 | return 0; | ||
| 214 | } | 329 | } |
| 215 | return -EINVAL; | 330 | return -EINVAL; |
| 216 | } | 331 | } |
| 217 | 332 | ||
| 333 | static int mt9v011_queryctrl(struct v4l2_subdev *sd, struct v4l2_queryctrl *qc) | ||
| 334 | { | ||
| 335 | int i; | ||
| 336 | |||
| 337 | v4l2_dbg(1, debug, sd, "queryctrl called\n"); | ||
| 338 | |||
| 339 | for (i = 0; i < ARRAY_SIZE(mt9v011_qctrl); i++) | ||
| 340 | if (qc->id && qc->id == mt9v011_qctrl[i].id) { | ||
| 341 | memcpy(qc, &(mt9v011_qctrl[i]), | ||
| 342 | sizeof(*qc)); | ||
| 343 | return 0; | ||
| 344 | } | ||
| 345 | |||
| 346 | return -EINVAL; | ||
| 347 | } | ||
| 348 | |||
| 349 | |||
| 218 | static int mt9v011_s_ctrl(struct v4l2_subdev *sd, struct v4l2_control *ctrl) | 350 | static int mt9v011_s_ctrl(struct v4l2_subdev *sd, struct v4l2_control *ctrl) |
| 219 | { | 351 | { |
| 220 | struct mt9v011 *core = to_mt9v011(sd); | 352 | struct mt9v011 *core = to_mt9v011(sd); |
| @@ -242,6 +374,14 @@ static int mt9v011_s_ctrl(struct v4l2_subdev *sd, struct v4l2_control *ctrl) | |||
| 242 | case V4L2_CID_BLUE_BALANCE: | 374 | case V4L2_CID_BLUE_BALANCE: |
| 243 | core->blue_bal = ctrl->value; | 375 | core->blue_bal = ctrl->value; |
| 244 | break; | 376 | break; |
| 377 | case V4L2_CID_HFLIP: | ||
| 378 | core->hflip = ctrl->value; | ||
| 379 | set_read_mode(sd); | ||
| 380 | return 0; | ||
| 381 | case V4L2_CID_VFLIP: | ||
| 382 | core->vflip = ctrl->value; | ||
| 383 | set_read_mode(sd); | ||
| 384 | return 0; | ||
| 245 | default: | 385 | default: |
| 246 | return -EINVAL; | 386 | return -EINVAL; |
| 247 | } | 387 | } |
| @@ -276,6 +416,44 @@ static int mt9v011_try_fmt(struct v4l2_subdev *sd, struct v4l2_format *fmt) | |||
| 276 | return 0; | 416 | return 0; |
| 277 | } | 417 | } |
| 278 | 418 | ||
| 419 | static int mt9v011_g_parm(struct v4l2_subdev *sd, struct v4l2_streamparm *parms) | ||
| 420 | { | ||
| 421 | struct v4l2_captureparm *cp = &parms->parm.capture; | ||
| 422 | |||
| 423 | if (parms->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) | ||
| 424 | return -EINVAL; | ||
| 425 | |||
| 426 | memset(cp, 0, sizeof(struct v4l2_captureparm)); | ||
| 427 | cp->capability = V4L2_CAP_TIMEPERFRAME; | ||
| 428 | calc_fps(sd, | ||
| 429 | &cp->timeperframe.numerator, | ||
| 430 | &cp->timeperframe.denominator); | ||
| 431 | |||
| 432 | return 0; | ||
| 433 | } | ||
| 434 | |||
| 435 | static int mt9v011_s_parm(struct v4l2_subdev *sd, struct v4l2_streamparm *parms) | ||
| 436 | { | ||
| 437 | struct v4l2_captureparm *cp = &parms->parm.capture; | ||
| 438 | struct v4l2_fract *tpf = &cp->timeperframe; | ||
| 439 | u16 speed; | ||
| 440 | |||
| 441 | if (parms->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) | ||
| 442 | return -EINVAL; | ||
| 443 | if (cp->extendedmode != 0) | ||
| 444 | return -EINVAL; | ||
| 445 | |||
| 446 | speed = calc_speed(sd, tpf->numerator, tpf->denominator); | ||
| 447 | |||
| 448 | mt9v011_write(sd, R0A_MT9V011_CLK_SPEED, speed); | ||
| 449 | v4l2_dbg(1, debug, sd, "Setting speed to %d\n", speed); | ||
| 450 | |||
| 451 | /* Recalculate and update fps info */ | ||
| 452 | calc_fps(sd, &tpf->numerator, &tpf->denominator); | ||
| 453 | |||
| 454 | return 0; | ||
| 455 | } | ||
| 456 | |||
| 279 | static int mt9v011_s_fmt(struct v4l2_subdev *sd, struct v4l2_format *fmt) | 457 | static int mt9v011_s_fmt(struct v4l2_subdev *sd, struct v4l2_format *fmt) |
| 280 | { | 458 | { |
| 281 | struct v4l2_pix_format *pix = &fmt->fmt.pix; | 459 | struct v4l2_pix_format *pix = &fmt->fmt.pix; |
| @@ -294,6 +472,22 @@ static int mt9v011_s_fmt(struct v4l2_subdev *sd, struct v4l2_format *fmt) | |||
| 294 | return 0; | 472 | return 0; |
| 295 | } | 473 | } |
| 296 | 474 | ||
| 475 | static int mt9v011_s_config(struct v4l2_subdev *sd, int dumb, void *data) | ||
| 476 | { | ||
| 477 | struct mt9v011 *core = to_mt9v011(sd); | ||
| 478 | unsigned *xtal = data; | ||
| 479 | |||
| 480 | v4l2_dbg(1, debug, sd, "s_config called\n"); | ||
| 481 | |||
| 482 | if (xtal) { | ||
| 483 | core->xtal = *xtal; | ||
| 484 | v4l2_dbg(1, debug, sd, "xtal set to %d.%03d MHz\n", | ||
| 485 | *xtal / 1000000, (*xtal / 1000) % 1000); | ||
| 486 | } | ||
| 487 | |||
| 488 | return 0; | ||
| 489 | } | ||
| 490 | |||
| 297 | 491 | ||
| 298 | #ifdef CONFIG_VIDEO_ADV_DEBUG | 492 | #ifdef CONFIG_VIDEO_ADV_DEBUG |
| 299 | static int mt9v011_g_register(struct v4l2_subdev *sd, | 493 | static int mt9v011_g_register(struct v4l2_subdev *sd, |
| @@ -331,16 +525,21 @@ static int mt9v011_s_register(struct v4l2_subdev *sd, | |||
| 331 | static int mt9v011_g_chip_ident(struct v4l2_subdev *sd, | 525 | static int mt9v011_g_chip_ident(struct v4l2_subdev *sd, |
| 332 | struct v4l2_dbg_chip_ident *chip) | 526 | struct v4l2_dbg_chip_ident *chip) |
| 333 | { | 527 | { |
| 528 | u16 version; | ||
| 334 | struct i2c_client *client = v4l2_get_subdevdata(sd); | 529 | struct i2c_client *client = v4l2_get_subdevdata(sd); |
| 335 | 530 | ||
| 531 | version = mt9v011_read(sd, R00_MT9V011_CHIP_VERSION); | ||
| 532 | |||
| 336 | return v4l2_chip_ident_i2c_client(client, chip, V4L2_IDENT_MT9V011, | 533 | return v4l2_chip_ident_i2c_client(client, chip, V4L2_IDENT_MT9V011, |
| 337 | MT9V011_VERSION); | 534 | version); |
| 338 | } | 535 | } |
| 339 | 536 | ||
| 340 | static const struct v4l2_subdev_core_ops mt9v011_core_ops = { | 537 | static const struct v4l2_subdev_core_ops mt9v011_core_ops = { |
| 538 | .queryctrl = mt9v011_queryctrl, | ||
| 341 | .g_ctrl = mt9v011_g_ctrl, | 539 | .g_ctrl = mt9v011_g_ctrl, |
| 342 | .s_ctrl = mt9v011_s_ctrl, | 540 | .s_ctrl = mt9v011_s_ctrl, |
| 343 | .reset = mt9v011_reset, | 541 | .reset = mt9v011_reset, |
| 542 | .s_config = mt9v011_s_config, | ||
| 344 | .g_chip_ident = mt9v011_g_chip_ident, | 543 | .g_chip_ident = mt9v011_g_chip_ident, |
| 345 | #ifdef CONFIG_VIDEO_ADV_DEBUG | 544 | #ifdef CONFIG_VIDEO_ADV_DEBUG |
| 346 | .g_register = mt9v011_g_register, | 545 | .g_register = mt9v011_g_register, |
| @@ -352,6 +551,8 @@ static const struct v4l2_subdev_video_ops mt9v011_video_ops = { | |||
| 352 | .enum_fmt = mt9v011_enum_fmt, | 551 | .enum_fmt = mt9v011_enum_fmt, |
| 353 | .try_fmt = mt9v011_try_fmt, | 552 | .try_fmt = mt9v011_try_fmt, |
| 354 | .s_fmt = mt9v011_s_fmt, | 553 | .s_fmt = mt9v011_s_fmt, |
| 554 | .g_parm = mt9v011_g_parm, | ||
| 555 | .s_parm = mt9v011_s_parm, | ||
| 355 | }; | 556 | }; |
| 356 | 557 | ||
| 357 | static const struct v4l2_subdev_ops mt9v011_ops = { | 558 | static const struct v4l2_subdev_ops mt9v011_ops = { |
| @@ -385,8 +586,9 @@ static int mt9v011_probe(struct i2c_client *c, | |||
| 385 | 586 | ||
| 386 | /* Check if the sensor is really a MT9V011 */ | 587 | /* Check if the sensor is really a MT9V011 */ |
| 387 | version = mt9v011_read(sd, R00_MT9V011_CHIP_VERSION); | 588 | version = mt9v011_read(sd, R00_MT9V011_CHIP_VERSION); |
| 388 | if (version != MT9V011_VERSION) { | 589 | if ((version != MT9V011_VERSION) && |
| 389 | v4l2_info(sd, "*** unknown micron chip detected (0x%04x.\n", | 590 | (version != MT9V011_REV_B_VERSION)) { |
| 591 | v4l2_info(sd, "*** unknown micron chip detected (0x%04x).\n", | ||
| 390 | version); | 592 | version); |
| 391 | kfree(core); | 593 | kfree(core); |
| 392 | return -EINVAL; | 594 | return -EINVAL; |
| @@ -395,9 +597,10 @@ static int mt9v011_probe(struct i2c_client *c, | |||
| 395 | core->global_gain = 0x0024; | 597 | core->global_gain = 0x0024; |
| 396 | core->width = 640; | 598 | core->width = 640; |
| 397 | core->height = 480; | 599 | core->height = 480; |
| 600 | core->xtal = 27000000; /* Hz */ | ||
| 398 | 601 | ||
| 399 | v4l_info(c, "chip found @ 0x%02x (%s)\n", | 602 | v4l_info(c, "chip found @ 0x%02x (%s - chip version 0x%04x)\n", |
| 400 | c->addr << 1, c->adapter->name); | 603 | c->addr << 1, c->adapter->name, version); |
| 401 | 604 | ||
| 402 | return 0; | 605 | return 0; |
| 403 | } | 606 | } |
diff --git a/drivers/media/video/mt9v011.h b/drivers/media/video/mt9v011.h index 9e443ee30558..3350fd6083c3 100644 --- a/drivers/media/video/mt9v011.h +++ b/drivers/media/video/mt9v011.h | |||
| @@ -30,6 +30,7 @@ | |||
| 30 | #define R35_MT9V011_GLOBAL_GAIN 0x35 | 30 | #define R35_MT9V011_GLOBAL_GAIN 0x35 |
| 31 | #define RF1_MT9V011_CHIP_ENABLE 0xf1 | 31 | #define RF1_MT9V011_CHIP_ENABLE 0xf1 |
| 32 | 32 | ||
| 33 | #define MT9V011_VERSION 0x8243 | 33 | #define MT9V011_VERSION 0x8232 |
| 34 | #define MT9V011_REV_B_VERSION 0x8243 | ||
| 34 | 35 | ||
| 35 | #endif | 36 | #endif |
diff --git a/drivers/media/video/mx1_camera.c b/drivers/media/video/mx1_camera.c index 2d075205bdfe..736c31d23194 100644 --- a/drivers/media/video/mx1_camera.c +++ b/drivers/media/video/mx1_camera.c | |||
| @@ -234,6 +234,7 @@ static int mx1_camera_setup_dma(struct mx1_camera_dev *pcdev) | |||
| 234 | return ret; | 234 | return ret; |
| 235 | } | 235 | } |
| 236 | 236 | ||
| 237 | /* Called under spinlock_irqsave(&pcdev->lock, ...) */ | ||
| 237 | static void mx1_videobuf_queue(struct videobuf_queue *vq, | 238 | static void mx1_videobuf_queue(struct videobuf_queue *vq, |
| 238 | struct videobuf_buffer *vb) | 239 | struct videobuf_buffer *vb) |
| 239 | { | 240 | { |
| @@ -241,13 +242,10 @@ static void mx1_videobuf_queue(struct videobuf_queue *vq, | |||
| 241 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 242 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); |
| 242 | struct mx1_camera_dev *pcdev = ici->priv; | 243 | struct mx1_camera_dev *pcdev = ici->priv; |
| 243 | struct mx1_buffer *buf = container_of(vb, struct mx1_buffer, vb); | 244 | struct mx1_buffer *buf = container_of(vb, struct mx1_buffer, vb); |
| 244 | unsigned long flags; | ||
| 245 | 245 | ||
| 246 | dev_dbg(&icd->dev, "%s (vb=0x%p) 0x%08lx %d\n", __func__, | 246 | dev_dbg(&icd->dev, "%s (vb=0x%p) 0x%08lx %d\n", __func__, |
| 247 | vb, vb->baddr, vb->bsize); | 247 | vb, vb->baddr, vb->bsize); |
| 248 | 248 | ||
| 249 | spin_lock_irqsave(&pcdev->lock, flags); | ||
| 250 | |||
| 251 | list_add_tail(&vb->queue, &pcdev->capture); | 249 | list_add_tail(&vb->queue, &pcdev->capture); |
| 252 | 250 | ||
| 253 | vb->state = VIDEOBUF_ACTIVE; | 251 | vb->state = VIDEOBUF_ACTIVE; |
| @@ -264,8 +262,6 @@ static void mx1_videobuf_queue(struct videobuf_queue *vq, | |||
| 264 | __raw_writel(temp, pcdev->base + CSICR1); | 262 | __raw_writel(temp, pcdev->base + CSICR1); |
| 265 | } | 263 | } |
| 266 | } | 264 | } |
| 267 | |||
| 268 | spin_unlock_irqrestore(&pcdev->lock, flags); | ||
| 269 | } | 265 | } |
| 270 | 266 | ||
| 271 | static void mx1_videobuf_release(struct videobuf_queue *vq, | 267 | static void mx1_videobuf_release(struct videobuf_queue *vq, |
diff --git a/drivers/media/video/mx3_camera.c b/drivers/media/video/mx3_camera.c index e605c076ed89..9770cb7932ca 100644 --- a/drivers/media/video/mx3_camera.c +++ b/drivers/media/video/mx3_camera.c | |||
| @@ -332,7 +332,10 @@ static enum pixel_fmt fourcc_to_ipu_pix(__u32 fourcc) | |||
| 332 | } | 332 | } |
| 333 | } | 333 | } |
| 334 | 334 | ||
| 335 | /* Called with .vb_lock held */ | 335 | /* |
| 336 | * Called with .vb_lock mutex held and | ||
| 337 | * under spinlock_irqsave(&mx3_cam->lock, ...) | ||
| 338 | */ | ||
| 336 | static void mx3_videobuf_queue(struct videobuf_queue *vq, | 339 | static void mx3_videobuf_queue(struct videobuf_queue *vq, |
| 337 | struct videobuf_buffer *vb) | 340 | struct videobuf_buffer *vb) |
| 338 | { | 341 | { |
| @@ -346,7 +349,8 @@ static void mx3_videobuf_queue(struct videobuf_queue *vq, | |||
| 346 | struct idmac_video_param *video = &ichan->params.video; | 349 | struct idmac_video_param *video = &ichan->params.video; |
| 347 | const struct soc_camera_data_format *data_fmt = icd->current_fmt; | 350 | const struct soc_camera_data_format *data_fmt = icd->current_fmt; |
| 348 | dma_cookie_t cookie; | 351 | dma_cookie_t cookie; |
| 349 | unsigned long flags; | 352 | |
| 353 | BUG_ON(!irqs_disabled()); | ||
| 350 | 354 | ||
| 351 | /* This is the configuration of one sg-element */ | 355 | /* This is the configuration of one sg-element */ |
| 352 | video->out_pixel_fmt = fourcc_to_ipu_pix(data_fmt->fourcc); | 356 | video->out_pixel_fmt = fourcc_to_ipu_pix(data_fmt->fourcc); |
| @@ -359,8 +363,6 @@ static void mx3_videobuf_queue(struct videobuf_queue *vq, | |||
| 359 | memset((void *)vb->baddr, 0xaa, vb->bsize); | 363 | memset((void *)vb->baddr, 0xaa, vb->bsize); |
| 360 | #endif | 364 | #endif |
| 361 | 365 | ||
| 362 | spin_lock_irqsave(&mx3_cam->lock, flags); | ||
| 363 | |||
| 364 | list_add_tail(&vb->queue, &mx3_cam->capture); | 366 | list_add_tail(&vb->queue, &mx3_cam->capture); |
| 365 | 367 | ||
| 366 | if (!mx3_cam->active) { | 368 | if (!mx3_cam->active) { |
| @@ -370,24 +372,23 @@ static void mx3_videobuf_queue(struct videobuf_queue *vq, | |||
| 370 | vb->state = VIDEOBUF_QUEUED; | 372 | vb->state = VIDEOBUF_QUEUED; |
| 371 | } | 373 | } |
| 372 | 374 | ||
| 373 | spin_unlock_irqrestore(&mx3_cam->lock, flags); | 375 | spin_unlock_irq(&mx3_cam->lock); |
| 374 | 376 | ||
| 375 | cookie = txd->tx_submit(txd); | 377 | cookie = txd->tx_submit(txd); |
| 376 | dev_dbg(&icd->dev, "Submitted cookie %d DMA 0x%08x\n", cookie, sg_dma_address(&buf->sg)); | 378 | dev_dbg(&icd->dev, "Submitted cookie %d DMA 0x%08x\n", cookie, sg_dma_address(&buf->sg)); |
| 379 | |||
| 380 | spin_lock_irq(&mx3_cam->lock); | ||
| 381 | |||
| 377 | if (cookie >= 0) | 382 | if (cookie >= 0) |
| 378 | return; | 383 | return; |
| 379 | 384 | ||
| 380 | /* Submit error */ | 385 | /* Submit error */ |
| 381 | vb->state = VIDEOBUF_PREPARED; | 386 | vb->state = VIDEOBUF_PREPARED; |
| 382 | 387 | ||
| 383 | spin_lock_irqsave(&mx3_cam->lock, flags); | ||
| 384 | |||
| 385 | list_del_init(&vb->queue); | 388 | list_del_init(&vb->queue); |
| 386 | 389 | ||
| 387 | if (mx3_cam->active == buf) | 390 | if (mx3_cam->active == buf) |
| 388 | mx3_cam->active = NULL; | 391 | mx3_cam->active = NULL; |
| 389 | |||
| 390 | spin_unlock_irqrestore(&mx3_cam->lock, flags); | ||
| 391 | } | 392 | } |
| 392 | 393 | ||
| 393 | /* Called with .vb_lock held */ | 394 | /* Called with .vb_lock held */ |
diff --git a/drivers/media/video/pxa_camera.c b/drivers/media/video/pxa_camera.c index 46e0d8ad880f..016bb45ba0c3 100644 --- a/drivers/media/video/pxa_camera.c +++ b/drivers/media/video/pxa_camera.c | |||
| @@ -612,6 +612,7 @@ static void pxa_camera_stop_capture(struct pxa_camera_dev *pcdev) | |||
| 612 | dev_dbg(pcdev->soc_host.dev, "%s\n", __func__); | 612 | dev_dbg(pcdev->soc_host.dev, "%s\n", __func__); |
| 613 | } | 613 | } |
| 614 | 614 | ||
| 615 | /* Called under spinlock_irqsave(&pcdev->lock, ...) */ | ||
| 615 | static void pxa_videobuf_queue(struct videobuf_queue *vq, | 616 | static void pxa_videobuf_queue(struct videobuf_queue *vq, |
| 616 | struct videobuf_buffer *vb) | 617 | struct videobuf_buffer *vb) |
| 617 | { | 618 | { |
| @@ -619,13 +620,10 @@ static void pxa_videobuf_queue(struct videobuf_queue *vq, | |||
| 619 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 620 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); |
| 620 | struct pxa_camera_dev *pcdev = ici->priv; | 621 | struct pxa_camera_dev *pcdev = ici->priv; |
| 621 | struct pxa_buffer *buf = container_of(vb, struct pxa_buffer, vb); | 622 | struct pxa_buffer *buf = container_of(vb, struct pxa_buffer, vb); |
| 622 | unsigned long flags; | ||
| 623 | 623 | ||
| 624 | dev_dbg(&icd->dev, "%s (vb=0x%p) 0x%08lx %d active=%p\n", __func__, | 624 | dev_dbg(&icd->dev, "%s (vb=0x%p) 0x%08lx %d active=%p\n", __func__, |
| 625 | vb, vb->baddr, vb->bsize, pcdev->active); | 625 | vb, vb->baddr, vb->bsize, pcdev->active); |
| 626 | 626 | ||
| 627 | spin_lock_irqsave(&pcdev->lock, flags); | ||
| 628 | |||
| 629 | list_add_tail(&vb->queue, &pcdev->capture); | 627 | list_add_tail(&vb->queue, &pcdev->capture); |
| 630 | 628 | ||
| 631 | vb->state = VIDEOBUF_ACTIVE; | 629 | vb->state = VIDEOBUF_ACTIVE; |
| @@ -633,8 +631,6 @@ static void pxa_videobuf_queue(struct videobuf_queue *vq, | |||
| 633 | 631 | ||
| 634 | if (!pcdev->active) | 632 | if (!pcdev->active) |
| 635 | pxa_camera_start_capture(pcdev); | 633 | pxa_camera_start_capture(pcdev); |
| 636 | |||
| 637 | spin_unlock_irqrestore(&pcdev->lock, flags); | ||
| 638 | } | 634 | } |
| 639 | 635 | ||
| 640 | static void pxa_videobuf_release(struct videobuf_queue *vq, | 636 | static void pxa_videobuf_release(struct videobuf_queue *vq, |
| @@ -1579,6 +1575,7 @@ static int __devinit pxa_camera_probe(struct platform_device *pdev) | |||
| 1579 | pcdev->mclk = 20000000; | 1575 | pcdev->mclk = 20000000; |
| 1580 | } | 1576 | } |
| 1581 | 1577 | ||
| 1578 | pcdev->soc_host.dev = &pdev->dev; | ||
| 1582 | pcdev->mclk_divisor = mclk_get_divisor(pcdev); | 1579 | pcdev->mclk_divisor = mclk_get_divisor(pcdev); |
| 1583 | 1580 | ||
| 1584 | INIT_LIST_HEAD(&pcdev->capture); | 1581 | INIT_LIST_HEAD(&pcdev->capture); |
| @@ -1644,7 +1641,6 @@ static int __devinit pxa_camera_probe(struct platform_device *pdev) | |||
| 1644 | pcdev->soc_host.drv_name = PXA_CAM_DRV_NAME; | 1641 | pcdev->soc_host.drv_name = PXA_CAM_DRV_NAME; |
| 1645 | pcdev->soc_host.ops = &pxa_soc_camera_host_ops; | 1642 | pcdev->soc_host.ops = &pxa_soc_camera_host_ops; |
| 1646 | pcdev->soc_host.priv = pcdev; | 1643 | pcdev->soc_host.priv = pcdev; |
| 1647 | pcdev->soc_host.dev = &pdev->dev; | ||
| 1648 | pcdev->soc_host.nr = pdev->id; | 1644 | pcdev->soc_host.nr = pdev->id; |
| 1649 | 1645 | ||
| 1650 | err = soc_camera_host_register(&pcdev->soc_host); | 1646 | err = soc_camera_host_register(&pcdev->soc_host); |
diff --git a/drivers/media/video/saa7134/saa7134-cards.c b/drivers/media/video/saa7134/saa7134-cards.c index 06861b782b95..6eebe3ef97d3 100644 --- a/drivers/media/video/saa7134/saa7134-cards.c +++ b/drivers/media/video/saa7134/saa7134-cards.c | |||
| @@ -3331,8 +3331,8 @@ struct saa7134_board saa7134_boards[] = { | |||
| 3331 | .gpio = 0x0200100, | 3331 | .gpio = 0x0200100, |
| 3332 | }, | 3332 | }, |
| 3333 | }, | 3333 | }, |
| 3334 | [SAA7134_BOARD_HAUPPAUGE_HVR1120] = { | 3334 | [SAA7134_BOARD_HAUPPAUGE_HVR1150] = { |
| 3335 | .name = "Hauppauge WinTV-HVR1120 ATSC/QAM-Hybrid", | 3335 | .name = "Hauppauge WinTV-HVR1150 ATSC/QAM-Hybrid", |
| 3336 | .audio_clock = 0x00187de7, | 3336 | .audio_clock = 0x00187de7, |
| 3337 | .tuner_type = TUNER_PHILIPS_TDA8290, | 3337 | .tuner_type = TUNER_PHILIPS_TDA8290, |
| 3338 | .radio_type = UNSET, | 3338 | .radio_type = UNSET, |
| @@ -3363,8 +3363,8 @@ struct saa7134_board saa7134_boards[] = { | |||
| 3363 | .gpio = 0x0800100, /* GPIO 23 HI for FM */ | 3363 | .gpio = 0x0800100, /* GPIO 23 HI for FM */ |
| 3364 | }, | 3364 | }, |
| 3365 | }, | 3365 | }, |
| 3366 | [SAA7134_BOARD_HAUPPAUGE_HVR1110R3] = { | 3366 | [SAA7134_BOARD_HAUPPAUGE_HVR1120] = { |
| 3367 | .name = "Hauppauge WinTV-HVR1110r3 DVB-T/Hybrid", | 3367 | .name = "Hauppauge WinTV-HVR1120 DVB-T/Hybrid", |
| 3368 | .audio_clock = 0x00187de7, | 3368 | .audio_clock = 0x00187de7, |
| 3369 | .tuner_type = TUNER_PHILIPS_TDA8290, | 3369 | .tuner_type = TUNER_PHILIPS_TDA8290, |
| 3370 | .radio_type = UNSET, | 3370 | .radio_type = UNSET, |
| @@ -5862,31 +5862,31 @@ struct pci_device_id saa7134_pci_tbl[] = { | |||
| 5862 | .device = PCI_DEVICE_ID_PHILIPS_SAA7133, | 5862 | .device = PCI_DEVICE_ID_PHILIPS_SAA7133, |
| 5863 | .subvendor = 0x0070, | 5863 | .subvendor = 0x0070, |
| 5864 | .subdevice = 0x6706, | 5864 | .subdevice = 0x6706, |
| 5865 | .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1120, | 5865 | .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1150, |
| 5866 | },{ | 5866 | },{ |
| 5867 | .vendor = PCI_VENDOR_ID_PHILIPS, | 5867 | .vendor = PCI_VENDOR_ID_PHILIPS, |
| 5868 | .device = PCI_DEVICE_ID_PHILIPS_SAA7133, | 5868 | .device = PCI_DEVICE_ID_PHILIPS_SAA7133, |
| 5869 | .subvendor = 0x0070, | 5869 | .subvendor = 0x0070, |
| 5870 | .subdevice = 0x6707, | 5870 | .subdevice = 0x6707, |
| 5871 | .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110R3, | 5871 | .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1120, |
| 5872 | },{ | 5872 | },{ |
| 5873 | .vendor = PCI_VENDOR_ID_PHILIPS, | 5873 | .vendor = PCI_VENDOR_ID_PHILIPS, |
| 5874 | .device = PCI_DEVICE_ID_PHILIPS_SAA7133, | 5874 | .device = PCI_DEVICE_ID_PHILIPS_SAA7133, |
| 5875 | .subvendor = 0x0070, | 5875 | .subvendor = 0x0070, |
| 5876 | .subdevice = 0x6708, | 5876 | .subdevice = 0x6708, |
| 5877 | .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1120, | 5877 | .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1150, |
| 5878 | },{ | 5878 | },{ |
| 5879 | .vendor = PCI_VENDOR_ID_PHILIPS, | 5879 | .vendor = PCI_VENDOR_ID_PHILIPS, |
| 5880 | .device = PCI_DEVICE_ID_PHILIPS_SAA7133, | 5880 | .device = PCI_DEVICE_ID_PHILIPS_SAA7133, |
| 5881 | .subvendor = 0x0070, | 5881 | .subvendor = 0x0070, |
| 5882 | .subdevice = 0x6709, | 5882 | .subdevice = 0x6709, |
| 5883 | .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110R3, | 5883 | .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1120, |
| 5884 | },{ | 5884 | },{ |
| 5885 | .vendor = PCI_VENDOR_ID_PHILIPS, | 5885 | .vendor = PCI_VENDOR_ID_PHILIPS, |
| 5886 | .device = PCI_DEVICE_ID_PHILIPS_SAA7133, | 5886 | .device = PCI_DEVICE_ID_PHILIPS_SAA7133, |
| 5887 | .subvendor = 0x0070, | 5887 | .subvendor = 0x0070, |
| 5888 | .subdevice = 0x670a, | 5888 | .subdevice = 0x670a, |
| 5889 | .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110R3, | 5889 | .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1120, |
| 5890 | },{ | 5890 | },{ |
| 5891 | .vendor = PCI_VENDOR_ID_PHILIPS, | 5891 | .vendor = PCI_VENDOR_ID_PHILIPS, |
| 5892 | .device = PCI_DEVICE_ID_PHILIPS_SAA7133, | 5892 | .device = PCI_DEVICE_ID_PHILIPS_SAA7133, |
| @@ -6363,8 +6363,8 @@ static int saa7134_tda8290_18271_callback(struct saa7134_dev *dev, | |||
| 6363 | switch (command) { | 6363 | switch (command) { |
| 6364 | case TDA18271_CALLBACK_CMD_AGC_ENABLE: /* 0 */ | 6364 | case TDA18271_CALLBACK_CMD_AGC_ENABLE: /* 0 */ |
| 6365 | switch (dev->board) { | 6365 | switch (dev->board) { |
| 6366 | case SAA7134_BOARD_HAUPPAUGE_HVR1150: | ||
| 6366 | case SAA7134_BOARD_HAUPPAUGE_HVR1120: | 6367 | case SAA7134_BOARD_HAUPPAUGE_HVR1120: |
| 6367 | case SAA7134_BOARD_HAUPPAUGE_HVR1110R3: | ||
| 6368 | ret = saa7134_tda18271_hvr11x0_toggle_agc(dev, arg); | 6368 | ret = saa7134_tda18271_hvr11x0_toggle_agc(dev, arg); |
| 6369 | break; | 6369 | break; |
| 6370 | default: | 6370 | default: |
| @@ -6384,8 +6384,8 @@ static int saa7134_tda8290_callback(struct saa7134_dev *dev, | |||
| 6384 | int ret; | 6384 | int ret; |
| 6385 | 6385 | ||
| 6386 | switch (dev->board) { | 6386 | switch (dev->board) { |
| 6387 | case SAA7134_BOARD_HAUPPAUGE_HVR1150: | ||
| 6387 | case SAA7134_BOARD_HAUPPAUGE_HVR1120: | 6388 | case SAA7134_BOARD_HAUPPAUGE_HVR1120: |
| 6388 | case SAA7134_BOARD_HAUPPAUGE_HVR1110R3: | ||
| 6389 | /* tda8290 + tda18271 */ | 6389 | /* tda8290 + tda18271 */ |
| 6390 | ret = saa7134_tda8290_18271_callback(dev, command, arg); | 6390 | ret = saa7134_tda8290_18271_callback(dev, command, arg); |
| 6391 | break; | 6391 | break; |
| @@ -6427,7 +6427,7 @@ static void hauppauge_eeprom(struct saa7134_dev *dev, u8 *eeprom_data) | |||
| 6427 | switch (tv.model) { | 6427 | switch (tv.model) { |
| 6428 | case 67019: /* WinTV-HVR1110 (Retail, IR Blaster, hybrid, FM, SVid/Comp, 3.5mm audio in) */ | 6428 | case 67019: /* WinTV-HVR1110 (Retail, IR Blaster, hybrid, FM, SVid/Comp, 3.5mm audio in) */ |
| 6429 | case 67109: /* WinTV-HVR1000 (Retail, IR Receive, analog, no FM, SVid/Comp, 3.5mm audio in) */ | 6429 | case 67109: /* WinTV-HVR1000 (Retail, IR Receive, analog, no FM, SVid/Comp, 3.5mm audio in) */ |
| 6430 | case 67201: /* WinTV-HVR1120 (Retail, IR Receive, hybrid, FM, SVid/Comp, 3.5mm audio in) */ | 6430 | case 67201: /* WinTV-HVR1150 (Retail, IR Receive, hybrid, FM, SVid/Comp, 3.5mm audio in) */ |
| 6431 | case 67301: /* WinTV-HVR1000 (Retail, IR Receive, analog, no FM, SVid/Comp, 3.5mm audio in) */ | 6431 | case 67301: /* WinTV-HVR1000 (Retail, IR Receive, analog, no FM, SVid/Comp, 3.5mm audio in) */ |
| 6432 | case 67209: /* WinTV-HVR1110 (Retail, IR Receive, hybrid, FM, SVid/Comp, 3.5mm audio in) */ | 6432 | case 67209: /* WinTV-HVR1110 (Retail, IR Receive, hybrid, FM, SVid/Comp, 3.5mm audio in) */ |
| 6433 | case 67559: /* WinTV-HVR1110 (OEM, no IR, hybrid, FM, SVid/Comp, RCA aud) */ | 6433 | case 67559: /* WinTV-HVR1110 (OEM, no IR, hybrid, FM, SVid/Comp, RCA aud) */ |
| @@ -6435,7 +6435,7 @@ static void hauppauge_eeprom(struct saa7134_dev *dev, u8 *eeprom_data) | |||
| 6435 | case 67579: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM) */ | 6435 | case 67579: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM) */ |
| 6436 | case 67589: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM, SVid/Comp, RCA aud) */ | 6436 | case 67589: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM, SVid/Comp, RCA aud) */ |
| 6437 | case 67599: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM, SVid/Comp, RCA aud) */ | 6437 | case 67599: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM, SVid/Comp, RCA aud) */ |
| 6438 | case 67651: /* WinTV-HVR1120 (OEM, no IR, hybrid, FM, SVid/Comp, RCA aud) */ | 6438 | case 67651: /* WinTV-HVR1150 (OEM, no IR, hybrid, FM, SVid/Comp, RCA aud) */ |
| 6439 | case 67659: /* WinTV-HVR1110 (OEM, no IR, hybrid, FM, SVid/Comp, RCA aud) */ | 6439 | case 67659: /* WinTV-HVR1110 (OEM, no IR, hybrid, FM, SVid/Comp, RCA aud) */ |
| 6440 | break; | 6440 | break; |
| 6441 | default: | 6441 | default: |
| @@ -6625,8 +6625,8 @@ int saa7134_board_init1(struct saa7134_dev *dev) | |||
| 6625 | 6625 | ||
| 6626 | saa_writeb (SAA7134_PRODUCTION_TEST_MODE, 0x00); | 6626 | saa_writeb (SAA7134_PRODUCTION_TEST_MODE, 0x00); |
| 6627 | break; | 6627 | break; |
| 6628 | case SAA7134_BOARD_HAUPPAUGE_HVR1150: | ||
| 6628 | case SAA7134_BOARD_HAUPPAUGE_HVR1120: | 6629 | case SAA7134_BOARD_HAUPPAUGE_HVR1120: |
| 6629 | case SAA7134_BOARD_HAUPPAUGE_HVR1110R3: | ||
| 6630 | /* GPIO 26 high for digital, low for analog */ | 6630 | /* GPIO 26 high for digital, low for analog */ |
| 6631 | saa7134_set_gpio(dev, 26, 0); | 6631 | saa7134_set_gpio(dev, 26, 0); |
| 6632 | msleep(1); | 6632 | msleep(1); |
| @@ -6891,8 +6891,8 @@ int saa7134_board_init2(struct saa7134_dev *dev) | |||
| 6891 | dev->name, saa7134_boards[dev->board].name); | 6891 | dev->name, saa7134_boards[dev->board].name); |
| 6892 | } | 6892 | } |
| 6893 | break; | 6893 | break; |
| 6894 | case SAA7134_BOARD_HAUPPAUGE_HVR1150: | ||
| 6894 | case SAA7134_BOARD_HAUPPAUGE_HVR1120: | 6895 | case SAA7134_BOARD_HAUPPAUGE_HVR1120: |
| 6895 | case SAA7134_BOARD_HAUPPAUGE_HVR1110R3: | ||
| 6896 | hauppauge_eeprom(dev, dev->eedata+0x80); | 6896 | hauppauge_eeprom(dev, dev->eedata+0x80); |
| 6897 | break; | 6897 | break; |
| 6898 | case SAA7134_BOARD_HAUPPAUGE_HVR1110: | 6898 | case SAA7134_BOARD_HAUPPAUGE_HVR1110: |
diff --git a/drivers/media/video/saa7134/saa7134-dvb.c b/drivers/media/video/saa7134/saa7134-dvb.c index 31930f26ffc7..98f3efd1e944 100644 --- a/drivers/media/video/saa7134/saa7134-dvb.c +++ b/drivers/media/video/saa7134/saa7134-dvb.c | |||
| @@ -1119,7 +1119,7 @@ static int dvb_init(struct saa7134_dev *dev) | |||
| 1119 | &tda827x_cfg_2) < 0) | 1119 | &tda827x_cfg_2) < 0) |
| 1120 | goto dettach_frontend; | 1120 | goto dettach_frontend; |
| 1121 | break; | 1121 | break; |
| 1122 | case SAA7134_BOARD_HAUPPAUGE_HVR1110R3: | 1122 | case SAA7134_BOARD_HAUPPAUGE_HVR1120: |
| 1123 | fe0->dvb.frontend = dvb_attach(tda10048_attach, | 1123 | fe0->dvb.frontend = dvb_attach(tda10048_attach, |
| 1124 | &hcw_tda10048_config, | 1124 | &hcw_tda10048_config, |
| 1125 | &dev->i2c_adap); | 1125 | &dev->i2c_adap); |
| @@ -1147,7 +1147,7 @@ static int dvb_init(struct saa7134_dev *dev) | |||
| 1147 | &tda827x_cfg_1) < 0) | 1147 | &tda827x_cfg_1) < 0) |
| 1148 | goto dettach_frontend; | 1148 | goto dettach_frontend; |
| 1149 | break; | 1149 | break; |
| 1150 | case SAA7134_BOARD_HAUPPAUGE_HVR1120: | 1150 | case SAA7134_BOARD_HAUPPAUGE_HVR1150: |
| 1151 | fe0->dvb.frontend = dvb_attach(lgdt3305_attach, | 1151 | fe0->dvb.frontend = dvb_attach(lgdt3305_attach, |
| 1152 | &hcw_lgdt3305_config, | 1152 | &hcw_lgdt3305_config, |
| 1153 | &dev->i2c_adap); | 1153 | &dev->i2c_adap); |
diff --git a/drivers/media/video/saa7134/saa7134.h b/drivers/media/video/saa7134/saa7134.h index 82268848f26a..fb564f14887c 100644 --- a/drivers/media/video/saa7134/saa7134.h +++ b/drivers/media/video/saa7134/saa7134.h | |||
| @@ -278,8 +278,8 @@ struct saa7134_format { | |||
| 278 | #define SAA7134_BOARD_ASUSTeK_TIGER 152 | 278 | #define SAA7134_BOARD_ASUSTeK_TIGER 152 |
| 279 | #define SAA7134_BOARD_KWORLD_PLUS_TV_ANALOG 153 | 279 | #define SAA7134_BOARD_KWORLD_PLUS_TV_ANALOG 153 |
| 280 | #define SAA7134_BOARD_AVERMEDIA_GO_007_FM_PLUS 154 | 280 | #define SAA7134_BOARD_AVERMEDIA_GO_007_FM_PLUS 154 |
| 281 | #define SAA7134_BOARD_HAUPPAUGE_HVR1120 155 | 281 | #define SAA7134_BOARD_HAUPPAUGE_HVR1150 155 |
| 282 | #define SAA7134_BOARD_HAUPPAUGE_HVR1110R3 156 | 282 | #define SAA7134_BOARD_HAUPPAUGE_HVR1120 156 |
| 283 | #define SAA7134_BOARD_AVERMEDIA_STUDIO_507UA 157 | 283 | #define SAA7134_BOARD_AVERMEDIA_STUDIO_507UA 157 |
| 284 | #define SAA7134_BOARD_AVERMEDIA_CARDBUS_501 158 | 284 | #define SAA7134_BOARD_AVERMEDIA_CARDBUS_501 158 |
| 285 | #define SAA7134_BOARD_BEHOLD_505RDS 159 | 285 | #define SAA7134_BOARD_BEHOLD_505RDS 159 |
diff --git a/drivers/media/video/sh_mobile_ceu_camera.c b/drivers/media/video/sh_mobile_ceu_camera.c index 0db88a53d92c..e86878deea71 100644 --- a/drivers/media/video/sh_mobile_ceu_camera.c +++ b/drivers/media/video/sh_mobile_ceu_camera.c | |||
| @@ -282,27 +282,24 @@ out: | |||
| 282 | return ret; | 282 | return ret; |
| 283 | } | 283 | } |
| 284 | 284 | ||
| 285 | /* Called under spinlock_irqsave(&pcdev->lock, ...) */ | ||
| 285 | static void sh_mobile_ceu_videobuf_queue(struct videobuf_queue *vq, | 286 | static void sh_mobile_ceu_videobuf_queue(struct videobuf_queue *vq, |
| 286 | struct videobuf_buffer *vb) | 287 | struct videobuf_buffer *vb) |
| 287 | { | 288 | { |
| 288 | struct soc_camera_device *icd = vq->priv_data; | 289 | struct soc_camera_device *icd = vq->priv_data; |
| 289 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 290 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); |
| 290 | struct sh_mobile_ceu_dev *pcdev = ici->priv; | 291 | struct sh_mobile_ceu_dev *pcdev = ici->priv; |
| 291 | unsigned long flags; | ||
| 292 | 292 | ||
| 293 | dev_dbg(&icd->dev, "%s (vb=0x%p) 0x%08lx %zd\n", __func__, | 293 | dev_dbg(&icd->dev, "%s (vb=0x%p) 0x%08lx %zd\n", __func__, |
| 294 | vb, vb->baddr, vb->bsize); | 294 | vb, vb->baddr, vb->bsize); |
| 295 | 295 | ||
| 296 | vb->state = VIDEOBUF_QUEUED; | 296 | vb->state = VIDEOBUF_QUEUED; |
| 297 | spin_lock_irqsave(&pcdev->lock, flags); | ||
| 298 | list_add_tail(&vb->queue, &pcdev->capture); | 297 | list_add_tail(&vb->queue, &pcdev->capture); |
| 299 | 298 | ||
| 300 | if (!pcdev->active) { | 299 | if (!pcdev->active) { |
| 301 | pcdev->active = vb; | 300 | pcdev->active = vb; |
| 302 | sh_mobile_ceu_capture(pcdev); | 301 | sh_mobile_ceu_capture(pcdev); |
| 303 | } | 302 | } |
| 304 | |||
| 305 | spin_unlock_irqrestore(&pcdev->lock, flags); | ||
| 306 | } | 303 | } |
| 307 | 304 | ||
| 308 | static void sh_mobile_ceu_videobuf_release(struct videobuf_queue *vq, | 305 | static void sh_mobile_ceu_videobuf_release(struct videobuf_queue *vq, |
diff --git a/drivers/media/video/stk-webcam.c b/drivers/media/video/stk-webcam.c index 4d6785e63455..b154bd961e3b 100644 --- a/drivers/media/video/stk-webcam.c +++ b/drivers/media/video/stk-webcam.c | |||
| @@ -1050,8 +1050,8 @@ static int stk_setup_format(struct stk_camera *dev) | |||
| 1050 | depth = 1; | 1050 | depth = 1; |
| 1051 | else | 1051 | else |
| 1052 | depth = 2; | 1052 | depth = 2; |
| 1053 | while (stk_sizes[i].m != dev->vsettings.mode | 1053 | while (i < ARRAY_SIZE(stk_sizes) && |
| 1054 | && i < ARRAY_SIZE(stk_sizes)) | 1054 | stk_sizes[i].m != dev->vsettings.mode) |
| 1055 | i++; | 1055 | i++; |
| 1056 | if (i == ARRAY_SIZE(stk_sizes)) { | 1056 | if (i == ARRAY_SIZE(stk_sizes)) { |
| 1057 | STK_ERROR("Something is broken in %s\n", __func__); | 1057 | STK_ERROR("Something is broken in %s\n", __func__); |
diff --git a/drivers/media/video/uvc/uvc_driver.c b/drivers/media/video/uvc/uvc_driver.c index 89927b7aec28..04b47832fa0a 100644 --- a/drivers/media/video/uvc/uvc_driver.c +++ b/drivers/media/video/uvc/uvc_driver.c | |||
| @@ -1845,11 +1845,29 @@ static struct usb_device_id uvc_ids[] = { | |||
| 1845 | .bInterfaceSubClass = 1, | 1845 | .bInterfaceSubClass = 1, |
| 1846 | .bInterfaceProtocol = 0, | 1846 | .bInterfaceProtocol = 0, |
| 1847 | .driver_info = UVC_QUIRK_STREAM_NO_FID }, | 1847 | .driver_info = UVC_QUIRK_STREAM_NO_FID }, |
| 1848 | /* ViMicro */ | 1848 | /* ViMicro Vega */ |
| 1849 | { .match_flags = USB_DEVICE_ID_MATCH_VENDOR | 1849 | { .match_flags = USB_DEVICE_ID_MATCH_DEVICE |
| 1850 | | USB_DEVICE_ID_MATCH_INT_INFO, | ||
| 1851 | .idVendor = 0x0ac8, | ||
| 1852 | .idProduct = 0x332d, | ||
| 1853 | .bInterfaceClass = USB_CLASS_VIDEO, | ||
| 1854 | .bInterfaceSubClass = 1, | ||
| 1855 | .bInterfaceProtocol = 0, | ||
| 1856 | .driver_info = UVC_QUIRK_FIX_BANDWIDTH }, | ||
| 1857 | /* ViMicro - Minoru3D */ | ||
| 1858 | { .match_flags = USB_DEVICE_ID_MATCH_DEVICE | ||
| 1859 | | USB_DEVICE_ID_MATCH_INT_INFO, | ||
| 1860 | .idVendor = 0x0ac8, | ||
| 1861 | .idProduct = 0x3410, | ||
| 1862 | .bInterfaceClass = USB_CLASS_VIDEO, | ||
| 1863 | .bInterfaceSubClass = 1, | ||
| 1864 | .bInterfaceProtocol = 0, | ||
| 1865 | .driver_info = UVC_QUIRK_FIX_BANDWIDTH }, | ||
| 1866 | /* ViMicro Venus - Minoru3D */ | ||
| 1867 | { .match_flags = USB_DEVICE_ID_MATCH_DEVICE | ||
| 1850 | | USB_DEVICE_ID_MATCH_INT_INFO, | 1868 | | USB_DEVICE_ID_MATCH_INT_INFO, |
| 1851 | .idVendor = 0x0ac8, | 1869 | .idVendor = 0x0ac8, |
| 1852 | .idProduct = 0x0000, | 1870 | .idProduct = 0x3420, |
| 1853 | .bInterfaceClass = USB_CLASS_VIDEO, | 1871 | .bInterfaceClass = USB_CLASS_VIDEO, |
| 1854 | .bInterfaceSubClass = 1, | 1872 | .bInterfaceSubClass = 1, |
| 1855 | .bInterfaceProtocol = 0, | 1873 | .bInterfaceProtocol = 0, |
diff --git a/drivers/media/video/uvc/uvc_status.c b/drivers/media/video/uvc/uvc_status.c index f152a9903862..1ca6dff73612 100644 --- a/drivers/media/video/uvc/uvc_status.c +++ b/drivers/media/video/uvc/uvc_status.c | |||
| @@ -145,8 +145,8 @@ static void uvc_status_complete(struct urb *urb) | |||
| 145 | break; | 145 | break; |
| 146 | 146 | ||
| 147 | default: | 147 | default: |
| 148 | uvc_printk(KERN_INFO, "unknown event type %u.\n", | 148 | uvc_trace(UVC_TRACE_STATUS, "Unknown status event " |
| 149 | dev->status[0]); | 149 | "type %u.\n", dev->status[0]); |
| 150 | break; | 150 | break; |
| 151 | } | 151 | } |
| 152 | } | 152 | } |
diff --git a/drivers/media/video/v4l2-ioctl.c b/drivers/media/video/v4l2-ioctl.c index be64a502ea27..f2afc4e08379 100644 --- a/drivers/media/video/v4l2-ioctl.c +++ b/drivers/media/video/v4l2-ioctl.c | |||
| @@ -1081,8 +1081,10 @@ static long __video_do_ioctl(struct file *file, | |||
| 1081 | /* Calls the specific handler */ | 1081 | /* Calls the specific handler */ |
| 1082 | if (ops->vidioc_g_std) | 1082 | if (ops->vidioc_g_std) |
| 1083 | ret = ops->vidioc_g_std(file, fh, id); | 1083 | ret = ops->vidioc_g_std(file, fh, id); |
| 1084 | else | 1084 | else if (vfd->current_norm) |
| 1085 | *id = vfd->current_norm; | 1085 | *id = vfd->current_norm; |
| 1086 | else | ||
| 1087 | ret = -EINVAL; | ||
| 1086 | 1088 | ||
| 1087 | if (!ret) | 1089 | if (!ret) |
| 1088 | dbgarg(cmd, "std=0x%08Lx\n", (long long unsigned)*id); | 1090 | dbgarg(cmd, "std=0x%08Lx\n", (long long unsigned)*id); |
| @@ -1553,12 +1555,19 @@ static long __video_do_ioctl(struct file *file, | |||
| 1553 | break; | 1555 | break; |
| 1554 | ret = ops->vidioc_g_parm(file, fh, p); | 1556 | ret = ops->vidioc_g_parm(file, fh, p); |
| 1555 | } else { | 1557 | } else { |
| 1558 | v4l2_std_id std = vfd->current_norm; | ||
| 1559 | |||
| 1556 | if (p->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) | 1560 | if (p->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) |
| 1557 | return -EINVAL; | 1561 | return -EINVAL; |
| 1558 | 1562 | ||
| 1559 | v4l2_video_std_frame_period(vfd->current_norm, | ||
| 1560 | &p->parm.capture.timeperframe); | ||
| 1561 | ret = 0; | 1563 | ret = 0; |
| 1564 | if (ops->vidioc_g_std) | ||
| 1565 | ret = ops->vidioc_g_std(file, fh, &std); | ||
| 1566 | else if (std == 0) | ||
| 1567 | ret = -EINVAL; | ||
| 1568 | if (ret == 0) | ||
| 1569 | v4l2_video_std_frame_period(std, | ||
| 1570 | &p->parm.capture.timeperframe); | ||
| 1562 | } | 1571 | } |
| 1563 | 1572 | ||
| 1564 | dbgarg(cmd, "type=%d\n", p->type); | 1573 | dbgarg(cmd, "type=%d\n", p->type); |
diff --git a/drivers/mfd/twl4030-irq.c b/drivers/mfd/twl4030-irq.c index bae61b22501c..7d430835655f 100644 --- a/drivers/mfd/twl4030-irq.c +++ b/drivers/mfd/twl4030-irq.c | |||
| @@ -180,14 +180,9 @@ static struct completion irq_event; | |||
| 180 | static int twl4030_irq_thread(void *data) | 180 | static int twl4030_irq_thread(void *data) |
| 181 | { | 181 | { |
| 182 | long irq = (long)data; | 182 | long irq = (long)data; |
| 183 | struct irq_desc *desc = irq_to_desc(irq); | ||
| 184 | static unsigned i2c_errors; | 183 | static unsigned i2c_errors; |
| 185 | static const unsigned max_i2c_errors = 100; | 184 | static const unsigned max_i2c_errors = 100; |
| 186 | 185 | ||
| 187 | if (!desc) { | ||
| 188 | pr_err("twl4030: Invalid IRQ: %ld\n", irq); | ||
| 189 | return -EINVAL; | ||
| 190 | } | ||
| 191 | 186 | ||
| 192 | current->flags |= PF_NOFREEZE; | 187 | current->flags |= PF_NOFREEZE; |
| 193 | 188 | ||
| @@ -240,7 +235,7 @@ static int twl4030_irq_thread(void *data) | |||
| 240 | } | 235 | } |
| 241 | local_irq_enable(); | 236 | local_irq_enable(); |
| 242 | 237 | ||
| 243 | desc->chip->unmask(irq); | 238 | enable_irq(irq); |
| 244 | } | 239 | } |
| 245 | 240 | ||
| 246 | return 0; | 241 | return 0; |
| @@ -255,25 +250,13 @@ static int twl4030_irq_thread(void *data) | |||
| 255 | * thread. All we do here is acknowledge and mask the interrupt and wakeup | 250 | * thread. All we do here is acknowledge and mask the interrupt and wakeup |
| 256 | * the kernel thread. | 251 | * the kernel thread. |
| 257 | */ | 252 | */ |
| 258 | static void handle_twl4030_pih(unsigned int irq, struct irq_desc *desc) | 253 | static irqreturn_t handle_twl4030_pih(int irq, void *devid) |
| 259 | { | 254 | { |
| 260 | /* Acknowledge, clear *AND* mask the interrupt... */ | 255 | /* Acknowledge, clear *AND* mask the interrupt... */ |
| 261 | desc->chip->ack(irq); | 256 | disable_irq_nosync(irq); |
| 262 | complete(&irq_event); | 257 | complete(devid); |
| 263 | } | 258 | return IRQ_HANDLED; |
| 264 | |||
| 265 | static struct task_struct *start_twl4030_irq_thread(long irq) | ||
| 266 | { | ||
| 267 | struct task_struct *thread; | ||
| 268 | |||
| 269 | init_completion(&irq_event); | ||
| 270 | thread = kthread_run(twl4030_irq_thread, (void *)irq, "twl4030-irq"); | ||
| 271 | if (!thread) | ||
| 272 | pr_err("twl4030: could not create irq %ld thread!\n", irq); | ||
| 273 | |||
| 274 | return thread; | ||
| 275 | } | 259 | } |
| 276 | |||
| 277 | /*----------------------------------------------------------------------*/ | 260 | /*----------------------------------------------------------------------*/ |
| 278 | 261 | ||
| 279 | /* | 262 | /* |
| @@ -734,18 +717,28 @@ int twl_init_irq(int irq_num, unsigned irq_base, unsigned irq_end) | |||
| 734 | } | 717 | } |
| 735 | 718 | ||
| 736 | /* install an irq handler to demultiplex the TWL4030 interrupt */ | 719 | /* install an irq handler to demultiplex the TWL4030 interrupt */ |
| 737 | task = start_twl4030_irq_thread(irq_num); | ||
| 738 | if (!task) { | ||
| 739 | pr_err("twl4030: irq thread FAIL\n"); | ||
| 740 | status = -ESRCH; | ||
| 741 | goto fail; | ||
| 742 | } | ||
| 743 | 720 | ||
| 744 | set_irq_data(irq_num, task); | ||
| 745 | set_irq_chained_handler(irq_num, handle_twl4030_pih); | ||
| 746 | 721 | ||
| 747 | return status; | 722 | init_completion(&irq_event); |
| 748 | 723 | ||
| 724 | status = request_irq(irq_num, handle_twl4030_pih, IRQF_DISABLED, | ||
| 725 | "TWL4030-PIH", &irq_event); | ||
| 726 | if (status < 0) { | ||
| 727 | pr_err("twl4030: could not claim irq%d: %d\n", irq_num, status); | ||
| 728 | goto fail_rqirq; | ||
| 729 | } | ||
| 730 | |||
| 731 | task = kthread_run(twl4030_irq_thread, (void *)irq_num, "twl4030-irq"); | ||
| 732 | if (IS_ERR(task)) { | ||
| 733 | pr_err("twl4030: could not create irq %d thread!\n", irq_num); | ||
| 734 | status = PTR_ERR(task); | ||
| 735 | goto fail_kthread; | ||
| 736 | } | ||
| 737 | return status; | ||
| 738 | fail_kthread: | ||
| 739 | free_irq(irq_num, &irq_event); | ||
| 740 | fail_rqirq: | ||
| 741 | /* clean up twl4030_sih_setup */ | ||
| 749 | fail: | 742 | fail: |
| 750 | for (i = irq_base; i < irq_end; i++) | 743 | for (i = irq_base; i < irq_end; i++) |
| 751 | set_irq_chip_and_handler(i, NULL, NULL); | 744 | set_irq_chip_and_handler(i, NULL, NULL); |
diff --git a/drivers/misc/cb710/sgbuf2.c b/drivers/misc/cb710/sgbuf2.c index d38a7acdb6ec..d019746551f3 100644 --- a/drivers/misc/cb710/sgbuf2.c +++ b/drivers/misc/cb710/sgbuf2.c | |||
| @@ -114,7 +114,6 @@ static void sg_dwiter_write_slow(struct sg_mapping_iter *miter, uint32_t data) | |||
| 114 | if (!left) | 114 | if (!left) |
| 115 | return; | 115 | return; |
| 116 | addr += len; | 116 | addr += len; |
| 117 | flush_kernel_dcache_page(miter->page); | ||
| 118 | } while (sg_dwiter_next(miter)); | 117 | } while (sg_dwiter_next(miter)); |
| 119 | } | 118 | } |
| 120 | 119 | ||
| @@ -142,9 +141,6 @@ void cb710_sg_dwiter_write_next_block(struct sg_mapping_iter *miter, uint32_t da | |||
| 142 | return; | 141 | return; |
| 143 | } else | 142 | } else |
| 144 | sg_dwiter_write_slow(miter, data); | 143 | sg_dwiter_write_slow(miter, data); |
| 145 | |||
| 146 | if (miter->length == miter->consumed) | ||
| 147 | flush_kernel_dcache_page(miter->page); | ||
| 148 | } | 144 | } |
| 149 | EXPORT_SYMBOL_GPL(cb710_sg_dwiter_write_next_block); | 145 | EXPORT_SYMBOL_GPL(cb710_sg_dwiter_write_next_block); |
| 150 | 146 | ||
diff --git a/drivers/misc/eeprom/at25.c b/drivers/misc/eeprom/at25.c index b34cb5f79eea..2e535a0ccd5e 100644 --- a/drivers/misc/eeprom/at25.c +++ b/drivers/misc/eeprom/at25.c | |||
| @@ -173,6 +173,7 @@ at25_ee_write(struct at25_data *at25, const char *buf, loff_t off, | |||
| 173 | unsigned segment; | 173 | unsigned segment; |
| 174 | unsigned offset = (unsigned) off; | 174 | unsigned offset = (unsigned) off; |
| 175 | u8 *cp = bounce + 1; | 175 | u8 *cp = bounce + 1; |
| 176 | int sr; | ||
| 176 | 177 | ||
| 177 | *cp = AT25_WREN; | 178 | *cp = AT25_WREN; |
| 178 | status = spi_write(at25->spi, cp, 1); | 179 | status = spi_write(at25->spi, cp, 1); |
| @@ -214,7 +215,6 @@ at25_ee_write(struct at25_data *at25, const char *buf, loff_t off, | |||
| 214 | timeout = jiffies + msecs_to_jiffies(EE_TIMEOUT); | 215 | timeout = jiffies + msecs_to_jiffies(EE_TIMEOUT); |
| 215 | retries = 0; | 216 | retries = 0; |
| 216 | do { | 217 | do { |
| 217 | int sr; | ||
| 218 | 218 | ||
| 219 | sr = spi_w8r8(at25->spi, AT25_RDSR); | 219 | sr = spi_w8r8(at25->spi, AT25_RDSR); |
| 220 | if (sr < 0 || (sr & AT25_SR_nRDY)) { | 220 | if (sr < 0 || (sr & AT25_SR_nRDY)) { |
| @@ -228,7 +228,7 @@ at25_ee_write(struct at25_data *at25, const char *buf, loff_t off, | |||
| 228 | break; | 228 | break; |
| 229 | } while (retries++ < 3 || time_before_eq(jiffies, timeout)); | 229 | } while (retries++ < 3 || time_before_eq(jiffies, timeout)); |
| 230 | 230 | ||
| 231 | if (time_after(jiffies, timeout)) { | 231 | if ((sr < 0) || (sr & AT25_SR_nRDY)) { |
| 232 | dev_err(&at25->spi->dev, | 232 | dev_err(&at25->spi->dev, |
| 233 | "write %d bytes offset %d, " | 233 | "write %d bytes offset %d, " |
| 234 | "timeout after %u msecs\n", | 234 | "timeout after %u msecs\n", |
diff --git a/drivers/mmc/host/cb710-mmc.c b/drivers/mmc/host/cb710-mmc.c index 11efefb1af51..4e72964a7b43 100644 --- a/drivers/mmc/host/cb710-mmc.c +++ b/drivers/mmc/host/cb710-mmc.c | |||
| @@ -278,7 +278,7 @@ static int cb710_mmc_receive(struct cb710_slot *slot, struct mmc_data *data) | |||
| 278 | if (unlikely(data->blksz & 15 && (data->blocks != 1 || data->blksz != 8))) | 278 | if (unlikely(data->blksz & 15 && (data->blocks != 1 || data->blksz != 8))) |
| 279 | return -EINVAL; | 279 | return -EINVAL; |
| 280 | 280 | ||
| 281 | sg_miter_start(&miter, data->sg, data->sg_len, 0); | 281 | sg_miter_start(&miter, data->sg, data->sg_len, SG_MITER_TO_SG); |
| 282 | 282 | ||
| 283 | cb710_modify_port_8(slot, CB710_MMC_CONFIG2_PORT, | 283 | cb710_modify_port_8(slot, CB710_MMC_CONFIG2_PORT, |
| 284 | 15, CB710_MMC_C2_READ_PIO_SIZE_MASK); | 284 | 15, CB710_MMC_C2_READ_PIO_SIZE_MASK); |
| @@ -307,7 +307,7 @@ static int cb710_mmc_receive(struct cb710_slot *slot, struct mmc_data *data) | |||
| 307 | goto out; | 307 | goto out; |
| 308 | } | 308 | } |
| 309 | out: | 309 | out: |
| 310 | cb710_sg_miter_stop_writing(&miter); | 310 | sg_miter_stop(&miter); |
| 311 | return err; | 311 | return err; |
| 312 | } | 312 | } |
| 313 | 313 | ||
| @@ -322,7 +322,7 @@ static int cb710_mmc_send(struct cb710_slot *slot, struct mmc_data *data) | |||
| 322 | if (unlikely(data->blocks > 1 && data->blksz & 15)) | 322 | if (unlikely(data->blocks > 1 && data->blksz & 15)) |
| 323 | return -EINVAL; | 323 | return -EINVAL; |
| 324 | 324 | ||
| 325 | sg_miter_start(&miter, data->sg, data->sg_len, 0); | 325 | sg_miter_start(&miter, data->sg, data->sg_len, SG_MITER_FROM_SG); |
| 326 | 326 | ||
| 327 | cb710_modify_port_8(slot, CB710_MMC_CONFIG2_PORT, | 327 | cb710_modify_port_8(slot, CB710_MMC_CONFIG2_PORT, |
| 328 | 0, CB710_MMC_C2_READ_PIO_SIZE_MASK); | 328 | 0, CB710_MMC_C2_READ_PIO_SIZE_MASK); |
diff --git a/drivers/mmc/host/imxmmc.c b/drivers/mmc/host/imxmmc.c index e0be21a4a696..bf98d7cc928a 100644 --- a/drivers/mmc/host/imxmmc.c +++ b/drivers/mmc/host/imxmmc.c | |||
| @@ -652,7 +652,7 @@ static irqreturn_t imxmci_irq(int irq, void *devid) | |||
| 652 | set_bit(IMXMCI_PEND_STARTED_b, &host->pending_events); | 652 | set_bit(IMXMCI_PEND_STARTED_b, &host->pending_events); |
| 653 | tasklet_schedule(&host->tasklet); | 653 | tasklet_schedule(&host->tasklet); |
| 654 | 654 | ||
| 655 | return IRQ_RETVAL(handled);; | 655 | return IRQ_RETVAL(handled); |
| 656 | } | 656 | } |
| 657 | 657 | ||
| 658 | static void imxmci_tasklet_fnc(unsigned long data) | 658 | static void imxmci_tasklet_fnc(unsigned long data) |
diff --git a/drivers/mmc/host/sdhci-of.c b/drivers/mmc/host/sdhci-of.c index d79fa55c3b89..1e8aa590bb39 100644 --- a/drivers/mmc/host/sdhci-of.c +++ b/drivers/mmc/host/sdhci-of.c | |||
| @@ -158,6 +158,13 @@ static unsigned int esdhc_get_max_clock(struct sdhci_host *host) | |||
| 158 | return of_host->clock; | 158 | return of_host->clock; |
| 159 | } | 159 | } |
| 160 | 160 | ||
| 161 | static unsigned int esdhc_get_min_clock(struct sdhci_host *host) | ||
| 162 | { | ||
| 163 | struct sdhci_of_host *of_host = sdhci_priv(host); | ||
| 164 | |||
| 165 | return of_host->clock / 256 / 16; | ||
| 166 | } | ||
| 167 | |||
| 161 | static unsigned int esdhc_get_timeout_clock(struct sdhci_host *host) | 168 | static unsigned int esdhc_get_timeout_clock(struct sdhci_host *host) |
| 162 | { | 169 | { |
| 163 | struct sdhci_of_host *of_host = sdhci_priv(host); | 170 | struct sdhci_of_host *of_host = sdhci_priv(host); |
| @@ -184,6 +191,7 @@ static struct sdhci_of_data sdhci_esdhc = { | |||
| 184 | .set_clock = esdhc_set_clock, | 191 | .set_clock = esdhc_set_clock, |
| 185 | .enable_dma = esdhc_enable_dma, | 192 | .enable_dma = esdhc_enable_dma, |
| 186 | .get_max_clock = esdhc_get_max_clock, | 193 | .get_max_clock = esdhc_get_max_clock, |
| 194 | .get_min_clock = esdhc_get_min_clock, | ||
| 187 | .get_timeout_clock = esdhc_get_timeout_clock, | 195 | .get_timeout_clock = esdhc_get_timeout_clock, |
| 188 | }, | 196 | }, |
| 189 | }; | 197 | }; |
| @@ -226,7 +234,7 @@ static int __devinit sdhci_of_probe(struct of_device *ofdev, | |||
| 226 | return -ENODEV; | 234 | return -ENODEV; |
| 227 | 235 | ||
| 228 | host = sdhci_alloc_host(&ofdev->dev, sizeof(*of_host)); | 236 | host = sdhci_alloc_host(&ofdev->dev, sizeof(*of_host)); |
| 229 | if (!host) | 237 | if (IS_ERR(host)) |
| 230 | return -ENOMEM; | 238 | return -ENOMEM; |
| 231 | 239 | ||
| 232 | of_host = sdhci_priv(host); | 240 | of_host = sdhci_priv(host); |
diff --git a/drivers/mmc/host/sdhci.c b/drivers/mmc/host/sdhci.c index 6779b4ecab18..fc96f8cb9c0b 100644 --- a/drivers/mmc/host/sdhci.c +++ b/drivers/mmc/host/sdhci.c | |||
| @@ -773,8 +773,14 @@ static void sdhci_prepare_data(struct sdhci_host *host, struct mmc_data *data) | |||
| 773 | } | 773 | } |
| 774 | 774 | ||
| 775 | if (!(host->flags & SDHCI_REQ_USE_DMA)) { | 775 | if (!(host->flags & SDHCI_REQ_USE_DMA)) { |
| 776 | sg_miter_start(&host->sg_miter, | 776 | int flags; |
| 777 | data->sg, data->sg_len, SG_MITER_ATOMIC); | 777 | |
| 778 | flags = SG_MITER_ATOMIC; | ||
| 779 | if (host->data->flags & MMC_DATA_READ) | ||
| 780 | flags |= SG_MITER_TO_SG; | ||
| 781 | else | ||
| 782 | flags |= SG_MITER_FROM_SG; | ||
| 783 | sg_miter_start(&host->sg_miter, data->sg, data->sg_len, flags); | ||
| 778 | host->blocks = data->blocks; | 784 | host->blocks = data->blocks; |
| 779 | } | 785 | } |
| 780 | 786 | ||
| @@ -1766,7 +1772,10 @@ int sdhci_add_host(struct sdhci_host *host) | |||
| 1766 | * Set host parameters. | 1772 | * Set host parameters. |
| 1767 | */ | 1773 | */ |
| 1768 | mmc->ops = &sdhci_ops; | 1774 | mmc->ops = &sdhci_ops; |
| 1769 | mmc->f_min = host->max_clk / 256; | 1775 | if (host->ops->get_min_clock) |
| 1776 | mmc->f_min = host->ops->get_min_clock(host); | ||
| 1777 | else | ||
| 1778 | mmc->f_min = host->max_clk / 256; | ||
| 1770 | mmc->f_max = host->max_clk; | 1779 | mmc->f_max = host->max_clk; |
| 1771 | mmc->caps = MMC_CAP_SDIO_IRQ; | 1780 | mmc->caps = MMC_CAP_SDIO_IRQ; |
| 1772 | 1781 | ||
diff --git a/drivers/mmc/host/sdhci.h b/drivers/mmc/host/sdhci.h index 831ddf7dcb49..c77e9ff30223 100644 --- a/drivers/mmc/host/sdhci.h +++ b/drivers/mmc/host/sdhci.h | |||
| @@ -302,6 +302,7 @@ struct sdhci_ops { | |||
| 302 | 302 | ||
| 303 | int (*enable_dma)(struct sdhci_host *host); | 303 | int (*enable_dma)(struct sdhci_host *host); |
| 304 | unsigned int (*get_max_clock)(struct sdhci_host *host); | 304 | unsigned int (*get_max_clock)(struct sdhci_host *host); |
| 305 | unsigned int (*get_min_clock)(struct sdhci_host *host); | ||
| 305 | unsigned int (*get_timeout_clock)(struct sdhci_host *host); | 306 | unsigned int (*get_timeout_clock)(struct sdhci_host *host); |
| 306 | }; | 307 | }; |
| 307 | 308 | ||
diff --git a/drivers/mtd/maps/Kconfig b/drivers/mtd/maps/Kconfig index 0b98654d8eed..7a58bd5522fd 100644 --- a/drivers/mtd/maps/Kconfig +++ b/drivers/mtd/maps/Kconfig | |||
| @@ -284,13 +284,6 @@ config MTD_L440GX | |||
| 284 | 284 | ||
| 285 | BE VERY CAREFUL. | 285 | BE VERY CAREFUL. |
| 286 | 286 | ||
| 287 | config MTD_SBC8240 | ||
| 288 | tristate "Flash device on SBC8240" | ||
| 289 | depends on MTD_JEDECPROBE && 8260 | ||
| 290 | help | ||
| 291 | Flash access on the SBC8240 board from Wind River. See | ||
| 292 | <http://www.windriver.com/products/sbc8240/> | ||
| 293 | |||
| 294 | config MTD_TQM8XXL | 287 | config MTD_TQM8XXL |
| 295 | tristate "CFI Flash device mapped on TQM8XXL" | 288 | tristate "CFI Flash device mapped on TQM8XXL" |
| 296 | depends on MTD_CFI && TQM8xxL | 289 | depends on MTD_CFI && TQM8xxL |
diff --git a/drivers/mtd/maps/Makefile b/drivers/mtd/maps/Makefile index 8bae7f9850c0..5beb0662d724 100644 --- a/drivers/mtd/maps/Makefile +++ b/drivers/mtd/maps/Makefile | |||
| @@ -50,7 +50,6 @@ obj-$(CONFIG_MTD_UCLINUX) += uclinux.o | |||
| 50 | obj-$(CONFIG_MTD_NETtel) += nettel.o | 50 | obj-$(CONFIG_MTD_NETtel) += nettel.o |
| 51 | obj-$(CONFIG_MTD_SCB2_FLASH) += scb2_flash.o | 51 | obj-$(CONFIG_MTD_SCB2_FLASH) += scb2_flash.o |
| 52 | obj-$(CONFIG_MTD_H720X) += h720x-flash.o | 52 | obj-$(CONFIG_MTD_H720X) += h720x-flash.o |
| 53 | obj-$(CONFIG_MTD_SBC8240) += sbc8240.o | ||
| 54 | obj-$(CONFIG_MTD_IXP4XX) += ixp4xx.o | 53 | obj-$(CONFIG_MTD_IXP4XX) += ixp4xx.o |
| 55 | obj-$(CONFIG_MTD_IXP2000) += ixp2000.o | 54 | obj-$(CONFIG_MTD_IXP2000) += ixp2000.o |
| 56 | obj-$(CONFIG_MTD_WRSBC8260) += wr_sbc82xx_flash.o | 55 | obj-$(CONFIG_MTD_WRSBC8260) += wr_sbc82xx_flash.o |
diff --git a/drivers/mtd/maps/sbc8240.c b/drivers/mtd/maps/sbc8240.c deleted file mode 100644 index d5374cdcb163..000000000000 --- a/drivers/mtd/maps/sbc8240.c +++ /dev/null | |||
| @@ -1,250 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * Handle mapping of the flash memory access routines on the SBC8240 board. | ||
| 3 | * | ||
| 4 | * Carolyn Smith, Tektronix, Inc. | ||
| 5 | * | ||
| 6 | * This code is GPLed | ||
| 7 | */ | ||
| 8 | |||
| 9 | /* | ||
| 10 | * The SBC8240 has 2 flash banks. | ||
| 11 | * Bank 0 is a 512 KiB AMD AM29F040B; 8 x 64 KiB sectors. | ||
| 12 | * It contains the U-Boot code (7 sectors) and the environment (1 sector). | ||
| 13 | * Bank 1 is 4 x 1 MiB AMD AM29LV800BT; 15 x 64 KiB sectors, 1 x 32 KiB sector, | ||
| 14 | * 2 x 8 KiB sectors, 1 x 16 KiB sectors. | ||
| 15 | * Both parts are JEDEC compatible. | ||
| 16 | */ | ||
| 17 | |||
| 18 | #include <linux/module.h> | ||
| 19 | #include <linux/types.h> | ||
| 20 | #include <linux/kernel.h> | ||
| 21 | #include <asm/io.h> | ||
| 22 | |||
| 23 | #include <linux/mtd/mtd.h> | ||
| 24 | #include <linux/mtd/map.h> | ||
| 25 | #include <linux/mtd/cfi.h> | ||
| 26 | |||
| 27 | #ifdef CONFIG_MTD_PARTITIONS | ||
| 28 | #include <linux/mtd/partitions.h> | ||
| 29 | #endif | ||
| 30 | |||
| 31 | #define DEBUG | ||
| 32 | |||
| 33 | #ifdef DEBUG | ||
| 34 | # define debugk(fmt,args...) printk(fmt ,##args) | ||
| 35 | #else | ||
| 36 | # define debugk(fmt,args...) | ||
| 37 | #endif | ||
| 38 | |||
| 39 | |||
| 40 | #define WINDOW_ADDR0 0xFFF00000 /* 512 KiB */ | ||
| 41 | #define WINDOW_SIZE0 0x00080000 | ||
| 42 | #define BUSWIDTH0 1 | ||
| 43 | |||
| 44 | #define WINDOW_ADDR1 0xFF000000 /* 4 MiB */ | ||
| 45 | #define WINDOW_SIZE1 0x00400000 | ||
| 46 | #define BUSWIDTH1 8 | ||
| 47 | |||
| 48 | #define MSG_PREFIX "sbc8240:" /* prefix for our printk()'s */ | ||
| 49 | #define MTDID "sbc8240-%d" /* for mtdparts= partitioning */ | ||
| 50 | |||
| 51 | |||
| 52 | static struct map_info sbc8240_map[2] = { | ||
| 53 | { | ||
| 54 | .name = "sbc8240 Flash Bank #0", | ||
| 55 | .size = WINDOW_SIZE0, | ||
| 56 | .bankwidth = BUSWIDTH0, | ||
| 57 | }, | ||
| 58 | { | ||
| 59 | .name = "sbc8240 Flash Bank #1", | ||
| 60 | .size = WINDOW_SIZE1, | ||
| 61 | .bankwidth = BUSWIDTH1, | ||
| 62 | } | ||
| 63 | }; | ||
| 64 | |||
| 65 | #define NUM_FLASH_BANKS ARRAY_SIZE(sbc8240_map) | ||
| 66 | |||
| 67 | /* | ||
| 68 | * The following defines the partition layout of SBC8240 boards. | ||
| 69 | * | ||
| 70 | * See include/linux/mtd/partitions.h for definition of the | ||
| 71 | * mtd_partition structure. | ||
| 72 | * | ||
| 73 | * The *_max_flash_size is the maximum possible mapped flash size | ||
| 74 | * which is not necessarily the actual flash size. It must correspond | ||
| 75 | * to the value specified in the mapping definition defined by the | ||
| 76 | * "struct map_desc *_io_desc" for the corresponding machine. | ||
| 77 | */ | ||
| 78 | |||
| 79 | #ifdef CONFIG_MTD_PARTITIONS | ||
| 80 | |||
| 81 | static struct mtd_partition sbc8240_uboot_partitions [] = { | ||
| 82 | /* Bank 0 */ | ||
| 83 | { | ||
| 84 | .name = "U-boot", /* U-Boot Firmware */ | ||
| 85 | .offset = 0, | ||
| 86 | .size = 0x00070000, /* 7 x 64 KiB sectors */ | ||
| 87 | .mask_flags = MTD_WRITEABLE, /* force read-only */ | ||
| 88 | }, | ||
| 89 | { | ||
| 90 | .name = "environment", /* U-Boot environment */ | ||
| 91 | .offset = 0x00070000, | ||
| 92 | .size = 0x00010000, /* 1 x 64 KiB sector */ | ||
| 93 | }, | ||
| 94 | }; | ||
| 95 | |||
| 96 | static struct mtd_partition sbc8240_fs_partitions [] = { | ||
| 97 | { | ||
| 98 | .name = "jffs", /* JFFS filesystem */ | ||
| 99 | .offset = 0, | ||
| 100 | .size = 0x003C0000, /* 4 * 15 * 64KiB */ | ||
| 101 | }, | ||
| 102 | { | ||
| 103 | .name = "tmp32", | ||
| 104 | .offset = 0x003C0000, | ||
| 105 | .size = 0x00020000, /* 4 * 32KiB */ | ||
| 106 | }, | ||
| 107 | { | ||
| 108 | .name = "tmp8a", | ||
| 109 | .offset = 0x003E0000, | ||
| 110 | .size = 0x00008000, /* 4 * 8KiB */ | ||
| 111 | }, | ||
| 112 | { | ||
| 113 | .name = "tmp8b", | ||
| 114 | .offset = 0x003E8000, | ||
| 115 | .size = 0x00008000, /* 4 * 8KiB */ | ||
| 116 | }, | ||
| 117 | { | ||
| 118 | .name = "tmp16", | ||
| 119 | .offset = 0x003F0000, | ||
| 120 | .size = 0x00010000, /* 4 * 16KiB */ | ||
| 121 | } | ||
| 122 | }; | ||
| 123 | |||
| 124 | /* trivial struct to describe partition information */ | ||
| 125 | struct mtd_part_def | ||
| 126 | { | ||
| 127 | int nums; | ||
| 128 | unsigned char *type; | ||
| 129 | struct mtd_partition* mtd_part; | ||
| 130 | }; | ||
| 131 | |||
| 132 | static struct mtd_info *sbc8240_mtd[NUM_FLASH_BANKS]; | ||
| 133 | static struct mtd_part_def sbc8240_part_banks[NUM_FLASH_BANKS]; | ||
| 134 | |||
| 135 | |||
| 136 | #endif /* CONFIG_MTD_PARTITIONS */ | ||
| 137 | |||
| 138 | |||
| 139 | static int __init init_sbc8240_mtd (void) | ||
| 140 | { | ||
| 141 | static struct _cjs { | ||
| 142 | u_long addr; | ||
| 143 | u_long size; | ||
| 144 | } pt[NUM_FLASH_BANKS] = { | ||
| 145 | { | ||
| 146 | .addr = WINDOW_ADDR0, | ||
| 147 | .size = WINDOW_SIZE0 | ||
| 148 | }, | ||
| 149 | { | ||
| 150 | .addr = WINDOW_ADDR1, | ||
| 151 | .size = WINDOW_SIZE1 | ||
| 152 | }, | ||
| 153 | }; | ||
| 154 | |||
| 155 | int devicesfound = 0; | ||
| 156 | int i,j; | ||
| 157 | |||
| 158 | for (i = 0; i < NUM_FLASH_BANKS; i++) { | ||
| 159 | printk (KERN_NOTICE MSG_PREFIX | ||
| 160 | "Probing 0x%08lx at 0x%08lx\n", pt[i].size, pt[i].addr); | ||
| 161 | |||
| 162 | sbc8240_map[i].map_priv_1 = | ||
| 163 | (unsigned long) ioremap (pt[i].addr, pt[i].size); | ||
| 164 | if (!sbc8240_map[i].map_priv_1) { | ||
| 165 | printk (MSG_PREFIX "failed to ioremap\n"); | ||
| 166 | for (j = 0; j < i; j++) { | ||
| 167 | iounmap((void *) sbc8240_map[j].map_priv_1); | ||
| 168 | sbc8240_map[j].map_priv_1 = 0; | ||
| 169 | } | ||
| 170 | return -EIO; | ||
| 171 | } | ||
| 172 | simple_map_init(&sbc8240_mtd[i]); | ||
| 173 | |||
| 174 | sbc8240_mtd[i] = do_map_probe("jedec_probe", &sbc8240_map[i]); | ||
| 175 | |||
| 176 | if (sbc8240_mtd[i]) { | ||
| 177 | sbc8240_mtd[i]->module = THIS_MODULE; | ||
| 178 | devicesfound++; | ||
| 179 | } else { | ||
| 180 | if (sbc8240_map[i].map_priv_1) { | ||
| 181 | iounmap((void *) sbc8240_map[i].map_priv_1); | ||
| 182 | sbc8240_map[i].map_priv_1 = 0; | ||
| 183 | } | ||
| 184 | } | ||
| 185 | } | ||
| 186 | |||
| 187 | if (!devicesfound) { | ||
| 188 | printk(KERN_NOTICE MSG_PREFIX | ||
| 189 | "No suppported flash chips found!\n"); | ||
| 190 | return -ENXIO; | ||
| 191 | } | ||
| 192 | |||
| 193 | #ifdef CONFIG_MTD_PARTITIONS | ||
| 194 | sbc8240_part_banks[0].mtd_part = sbc8240_uboot_partitions; | ||
| 195 | sbc8240_part_banks[0].type = "static image"; | ||
| 196 | sbc8240_part_banks[0].nums = ARRAY_SIZE(sbc8240_uboot_partitions); | ||
| 197 | sbc8240_part_banks[1].mtd_part = sbc8240_fs_partitions; | ||
| 198 | sbc8240_part_banks[1].type = "static file system"; | ||
| 199 | sbc8240_part_banks[1].nums = ARRAY_SIZE(sbc8240_fs_partitions); | ||
| 200 | |||
| 201 | for (i = 0; i < NUM_FLASH_BANKS; i++) { | ||
| 202 | |||
| 203 | if (!sbc8240_mtd[i]) continue; | ||
| 204 | if (sbc8240_part_banks[i].nums == 0) { | ||
| 205 | printk (KERN_NOTICE MSG_PREFIX | ||
| 206 | "No partition info available, registering whole device\n"); | ||
| 207 | add_mtd_device(sbc8240_mtd[i]); | ||
| 208 | } else { | ||
| 209 | printk (KERN_NOTICE MSG_PREFIX | ||
| 210 | "Using %s partition definition\n", sbc8240_part_banks[i].mtd_part->name); | ||
| 211 | add_mtd_partitions (sbc8240_mtd[i], | ||
| 212 | sbc8240_part_banks[i].mtd_part, | ||
| 213 | sbc8240_part_banks[i].nums); | ||
| 214 | } | ||
| 215 | } | ||
| 216 | #else | ||
| 217 | printk(KERN_NOTICE MSG_PREFIX | ||
| 218 | "Registering %d flash banks at once\n", devicesfound); | ||
| 219 | |||
| 220 | for (i = 0; i < devicesfound; i++) { | ||
| 221 | add_mtd_device(sbc8240_mtd[i]); | ||
| 222 | } | ||
| 223 | #endif /* CONFIG_MTD_PARTITIONS */ | ||
| 224 | |||
| 225 | return devicesfound == 0 ? -ENXIO : 0; | ||
| 226 | } | ||
| 227 | |||
| 228 | static void __exit cleanup_sbc8240_mtd (void) | ||
| 229 | { | ||
| 230 | int i; | ||
| 231 | |||
| 232 | for (i = 0; i < NUM_FLASH_BANKS; i++) { | ||
| 233 | if (sbc8240_mtd[i]) { | ||
| 234 | del_mtd_device (sbc8240_mtd[i]); | ||
| 235 | map_destroy (sbc8240_mtd[i]); | ||
| 236 | } | ||
| 237 | if (sbc8240_map[i].map_priv_1) { | ||
| 238 | iounmap ((void *) sbc8240_map[i].map_priv_1); | ||
| 239 | sbc8240_map[i].map_priv_1 = 0; | ||
| 240 | } | ||
| 241 | } | ||
| 242 | } | ||
| 243 | |||
| 244 | module_init (init_sbc8240_mtd); | ||
| 245 | module_exit (cleanup_sbc8240_mtd); | ||
| 246 | |||
| 247 | MODULE_LICENSE ("GPL"); | ||
| 248 | MODULE_AUTHOR ("Carolyn Smith <carolyn.smith@tektronix.com>"); | ||
| 249 | MODULE_DESCRIPTION ("MTD map driver for SBC8240 boards"); | ||
| 250 | |||
diff --git a/drivers/mtd/mtd_blkdevs.c b/drivers/mtd/mtd_blkdevs.c index c3f62654b6df..7baba40c1ed2 100644 --- a/drivers/mtd/mtd_blkdevs.c +++ b/drivers/mtd/mtd_blkdevs.c | |||
| @@ -144,7 +144,7 @@ static int blktrans_open(struct block_device *bdev, fmode_t mode) | |||
| 144 | struct mtd_blktrans_ops *tr = dev->tr; | 144 | struct mtd_blktrans_ops *tr = dev->tr; |
| 145 | int ret = -ENODEV; | 145 | int ret = -ENODEV; |
| 146 | 146 | ||
| 147 | if (!try_module_get(dev->mtd->owner)) | 147 | if (!get_mtd_device(NULL, dev->mtd->index)) |
| 148 | goto out; | 148 | goto out; |
| 149 | 149 | ||
| 150 | if (!try_module_get(tr->owner)) | 150 | if (!try_module_get(tr->owner)) |
| @@ -158,7 +158,7 @@ static int blktrans_open(struct block_device *bdev, fmode_t mode) | |||
| 158 | ret = 0; | 158 | ret = 0; |
| 159 | if (tr->open && (ret = tr->open(dev))) { | 159 | if (tr->open && (ret = tr->open(dev))) { |
| 160 | dev->mtd->usecount--; | 160 | dev->mtd->usecount--; |
| 161 | module_put(dev->mtd->owner); | 161 | put_mtd_device(dev->mtd); |
| 162 | out_tr: | 162 | out_tr: |
| 163 | module_put(tr->owner); | 163 | module_put(tr->owner); |
| 164 | } | 164 | } |
| @@ -177,7 +177,7 @@ static int blktrans_release(struct gendisk *disk, fmode_t mode) | |||
| 177 | 177 | ||
| 178 | if (!ret) { | 178 | if (!ret) { |
| 179 | dev->mtd->usecount--; | 179 | dev->mtd->usecount--; |
| 180 | module_put(dev->mtd->owner); | 180 | put_mtd_device(dev->mtd); |
| 181 | module_put(tr->owner); | 181 | module_put(tr->owner); |
| 182 | } | 182 | } |
| 183 | 183 | ||
diff --git a/drivers/mtd/mtdblock.c b/drivers/mtd/mtdblock.c index 208c6faa0358..77db5ce24d92 100644 --- a/drivers/mtd/mtdblock.c +++ b/drivers/mtd/mtdblock.c | |||
| @@ -29,6 +29,8 @@ static struct mtdblk_dev { | |||
| 29 | enum { STATE_EMPTY, STATE_CLEAN, STATE_DIRTY } cache_state; | 29 | enum { STATE_EMPTY, STATE_CLEAN, STATE_DIRTY } cache_state; |
| 30 | } *mtdblks[MAX_MTD_DEVICES]; | 30 | } *mtdblks[MAX_MTD_DEVICES]; |
| 31 | 31 | ||
| 32 | static struct mutex mtdblks_lock; | ||
| 33 | |||
| 32 | /* | 34 | /* |
| 33 | * Cache stuff... | 35 | * Cache stuff... |
| 34 | * | 36 | * |
| @@ -270,15 +272,19 @@ static int mtdblock_open(struct mtd_blktrans_dev *mbd) | |||
| 270 | 272 | ||
| 271 | DEBUG(MTD_DEBUG_LEVEL1,"mtdblock_open\n"); | 273 | DEBUG(MTD_DEBUG_LEVEL1,"mtdblock_open\n"); |
| 272 | 274 | ||
| 275 | mutex_lock(&mtdblks_lock); | ||
| 273 | if (mtdblks[dev]) { | 276 | if (mtdblks[dev]) { |
| 274 | mtdblks[dev]->count++; | 277 | mtdblks[dev]->count++; |
| 278 | mutex_unlock(&mtdblks_lock); | ||
| 275 | return 0; | 279 | return 0; |
| 276 | } | 280 | } |
| 277 | 281 | ||
| 278 | /* OK, it's not open. Create cache info for it */ | 282 | /* OK, it's not open. Create cache info for it */ |
| 279 | mtdblk = kzalloc(sizeof(struct mtdblk_dev), GFP_KERNEL); | 283 | mtdblk = kzalloc(sizeof(struct mtdblk_dev), GFP_KERNEL); |
| 280 | if (!mtdblk) | 284 | if (!mtdblk) { |
| 285 | mutex_unlock(&mtdblks_lock); | ||
| 281 | return -ENOMEM; | 286 | return -ENOMEM; |
| 287 | } | ||
| 282 | 288 | ||
| 283 | mtdblk->count = 1; | 289 | mtdblk->count = 1; |
| 284 | mtdblk->mtd = mtd; | 290 | mtdblk->mtd = mtd; |
| @@ -291,6 +297,7 @@ static int mtdblock_open(struct mtd_blktrans_dev *mbd) | |||
| 291 | } | 297 | } |
| 292 | 298 | ||
| 293 | mtdblks[dev] = mtdblk; | 299 | mtdblks[dev] = mtdblk; |
| 300 | mutex_unlock(&mtdblks_lock); | ||
| 294 | 301 | ||
| 295 | DEBUG(MTD_DEBUG_LEVEL1, "ok\n"); | 302 | DEBUG(MTD_DEBUG_LEVEL1, "ok\n"); |
| 296 | 303 | ||
| @@ -304,6 +311,8 @@ static int mtdblock_release(struct mtd_blktrans_dev *mbd) | |||
| 304 | 311 | ||
| 305 | DEBUG(MTD_DEBUG_LEVEL1, "mtdblock_release\n"); | 312 | DEBUG(MTD_DEBUG_LEVEL1, "mtdblock_release\n"); |
| 306 | 313 | ||
| 314 | mutex_lock(&mtdblks_lock); | ||
| 315 | |||
| 307 | mutex_lock(&mtdblk->cache_mutex); | 316 | mutex_lock(&mtdblk->cache_mutex); |
| 308 | write_cached_data(mtdblk); | 317 | write_cached_data(mtdblk); |
| 309 | mutex_unlock(&mtdblk->cache_mutex); | 318 | mutex_unlock(&mtdblk->cache_mutex); |
| @@ -316,6 +325,9 @@ static int mtdblock_release(struct mtd_blktrans_dev *mbd) | |||
| 316 | vfree(mtdblk->cache_data); | 325 | vfree(mtdblk->cache_data); |
| 317 | kfree(mtdblk); | 326 | kfree(mtdblk); |
| 318 | } | 327 | } |
| 328 | |||
| 329 | mutex_unlock(&mtdblks_lock); | ||
| 330 | |||
| 319 | DEBUG(MTD_DEBUG_LEVEL1, "ok\n"); | 331 | DEBUG(MTD_DEBUG_LEVEL1, "ok\n"); |
| 320 | 332 | ||
| 321 | return 0; | 333 | return 0; |
| @@ -376,6 +388,8 @@ static struct mtd_blktrans_ops mtdblock_tr = { | |||
| 376 | 388 | ||
| 377 | static int __init init_mtdblock(void) | 389 | static int __init init_mtdblock(void) |
| 378 | { | 390 | { |
| 391 | mutex_init(&mtdblks_lock); | ||
| 392 | |||
| 379 | return register_mtd_blktrans(&mtdblock_tr); | 393 | return register_mtd_blktrans(&mtdblock_tr); |
| 380 | } | 394 | } |
| 381 | 395 | ||
diff --git a/drivers/mtd/mtdcore.c b/drivers/mtd/mtdcore.c index fac54a3fa3f1..00ebf7af7467 100644 --- a/drivers/mtd/mtdcore.c +++ b/drivers/mtd/mtdcore.c | |||
| @@ -65,8 +65,8 @@ static void mtd_release(struct device *dev) | |||
| 65 | static int mtd_cls_suspend(struct device *dev, pm_message_t state) | 65 | static int mtd_cls_suspend(struct device *dev, pm_message_t state) |
| 66 | { | 66 | { |
| 67 | struct mtd_info *mtd = dev_to_mtd(dev); | 67 | struct mtd_info *mtd = dev_to_mtd(dev); |
| 68 | 68 | ||
| 69 | if (mtd->suspend) | 69 | if (mtd && mtd->suspend) |
| 70 | return mtd->suspend(mtd); | 70 | return mtd->suspend(mtd); |
| 71 | else | 71 | else |
| 72 | return 0; | 72 | return 0; |
| @@ -76,7 +76,7 @@ static int mtd_cls_resume(struct device *dev) | |||
| 76 | { | 76 | { |
| 77 | struct mtd_info *mtd = dev_to_mtd(dev); | 77 | struct mtd_info *mtd = dev_to_mtd(dev); |
| 78 | 78 | ||
| 79 | if (mtd->resume) | 79 | if (mtd && mtd->resume) |
| 80 | mtd->resume(mtd); | 80 | mtd->resume(mtd); |
| 81 | return 0; | 81 | return 0; |
| 82 | } | 82 | } |
| @@ -298,6 +298,7 @@ int add_mtd_device(struct mtd_info *mtd) | |||
| 298 | mtd->dev.class = &mtd_class; | 298 | mtd->dev.class = &mtd_class; |
| 299 | mtd->dev.devt = MTD_DEVT(i); | 299 | mtd->dev.devt = MTD_DEVT(i); |
| 300 | dev_set_name(&mtd->dev, "mtd%d", i); | 300 | dev_set_name(&mtd->dev, "mtd%d", i); |
| 301 | dev_set_drvdata(&mtd->dev, mtd); | ||
| 301 | if (device_register(&mtd->dev) != 0) { | 302 | if (device_register(&mtd->dev) != 0) { |
| 302 | mtd_table[i] = NULL; | 303 | mtd_table[i] = NULL; |
| 303 | break; | 304 | break; |
diff --git a/drivers/mtd/nand/orion_nand.c b/drivers/mtd/nand/orion_nand.c index 7ad972229db4..0d9d4bc9c762 100644 --- a/drivers/mtd/nand/orion_nand.c +++ b/drivers/mtd/nand/orion_nand.c | |||
| @@ -61,7 +61,7 @@ static void orion_nand_read_buf(struct mtd_info *mtd, uint8_t *buf, int len) | |||
| 61 | buf64 = (uint64_t *)buf; | 61 | buf64 = (uint64_t *)buf; |
| 62 | while (i < len/8) { | 62 | while (i < len/8) { |
| 63 | uint64_t x; | 63 | uint64_t x; |
| 64 | asm ("ldrd\t%0, [%1]" : "=r" (x) : "r" (io_base)); | 64 | asm volatile ("ldrd\t%0, [%1]" : "=&r" (x) : "r" (io_base)); |
| 65 | buf64[i++] = x; | 65 | buf64[i++] = x; |
| 66 | } | 66 | } |
| 67 | i *= 8; | 67 | i *= 8; |
diff --git a/drivers/mtd/onenand/omap2.c b/drivers/mtd/onenand/omap2.c index 38d656b9b2ee..0108ed42e877 100644 --- a/drivers/mtd/onenand/omap2.c +++ b/drivers/mtd/onenand/omap2.c | |||
| @@ -266,7 +266,7 @@ static inline int omap2_onenand_bufferram_offset(struct mtd_info *mtd, int area) | |||
| 266 | 266 | ||
| 267 | if (ONENAND_CURRENT_BUFFERRAM(this)) { | 267 | if (ONENAND_CURRENT_BUFFERRAM(this)) { |
| 268 | if (area == ONENAND_DATARAM) | 268 | if (area == ONENAND_DATARAM) |
| 269 | return mtd->writesize; | 269 | return this->writesize; |
| 270 | if (area == ONENAND_SPARERAM) | 270 | if (area == ONENAND_SPARERAM) |
| 271 | return mtd->oobsize; | 271 | return mtd->oobsize; |
| 272 | } | 272 | } |
| @@ -770,6 +770,7 @@ static int __devexit omap2_onenand_remove(struct platform_device *pdev) | |||
| 770 | } | 770 | } |
| 771 | iounmap(c->onenand.base); | 771 | iounmap(c->onenand.base); |
| 772 | release_mem_region(c->phys_base, ONENAND_IO_SIZE); | 772 | release_mem_region(c->phys_base, ONENAND_IO_SIZE); |
| 773 | gpmc_cs_free(c->gpmc_cs); | ||
| 773 | kfree(c); | 774 | kfree(c); |
| 774 | 775 | ||
| 775 | return 0; | 776 | return 0; |
diff --git a/drivers/mtd/ubi/eba.c b/drivers/mtd/ubi/eba.c index 0f2034c3ed2f..e4d9ef0c965a 100644 --- a/drivers/mtd/ubi/eba.c +++ b/drivers/mtd/ubi/eba.c | |||
| @@ -1254,6 +1254,7 @@ out_free: | |||
| 1254 | if (!ubi->volumes[i]) | 1254 | if (!ubi->volumes[i]) |
| 1255 | continue; | 1255 | continue; |
| 1256 | kfree(ubi->volumes[i]->eba_tbl); | 1256 | kfree(ubi->volumes[i]->eba_tbl); |
| 1257 | ubi->volumes[i]->eba_tbl = NULL; | ||
| 1257 | } | 1258 | } |
| 1258 | return err; | 1259 | return err; |
| 1259 | } | 1260 | } |
diff --git a/drivers/mtd/ubi/gluebi.c b/drivers/mtd/ubi/gluebi.c index 95aaac03f938..b5e478fa2661 100644 --- a/drivers/mtd/ubi/gluebi.c +++ b/drivers/mtd/ubi/gluebi.c | |||
| @@ -332,6 +332,7 @@ static int gluebi_create(struct ubi_device_info *di, | |||
| 332 | } | 332 | } |
| 333 | 333 | ||
| 334 | gluebi->vol_id = vi->vol_id; | 334 | gluebi->vol_id = vi->vol_id; |
| 335 | gluebi->ubi_num = vi->ubi_num; | ||
| 335 | mtd->type = MTD_UBIVOLUME; | 336 | mtd->type = MTD_UBIVOLUME; |
| 336 | if (!di->ro_mode) | 337 | if (!di->ro_mode) |
| 337 | mtd->flags = MTD_WRITEABLE; | 338 | mtd->flags = MTD_WRITEABLE; |
diff --git a/drivers/mtd/ubi/scan.c b/drivers/mtd/ubi/scan.c index f60895ee0aeb..b847745394b4 100644 --- a/drivers/mtd/ubi/scan.c +++ b/drivers/mtd/ubi/scan.c | |||
| @@ -781,11 +781,22 @@ static int process_eb(struct ubi_device *ubi, struct ubi_scan_info *si, | |||
| 781 | return -EINVAL; | 781 | return -EINVAL; |
| 782 | } | 782 | } |
| 783 | 783 | ||
| 784 | image_seq = be32_to_cpu(ech->ec); | 784 | /* |
| 785 | * Make sure that all PEBs have the same image sequence number. | ||
| 786 | * This allows us to detect situations when users flash UBI | ||
| 787 | * images incorrectly, so that the flash has the new UBI image | ||
| 788 | * and leftovers from the old one. This feature was added | ||
| 789 | * relatively recently, and the sequence number was always | ||
| 790 | * zero, because old UBI implementations always set it to zero. | ||
| 791 | * For this reasons, we do not panic if some PEBs have zero | ||
| 792 | * sequence number, while other PEBs have non-zero sequence | ||
| 793 | * number. | ||
| 794 | */ | ||
| 795 | image_seq = be32_to_cpu(ech->image_seq); | ||
| 785 | if (!si->image_seq_set) { | 796 | if (!si->image_seq_set) { |
| 786 | ubi->image_seq = image_seq; | 797 | ubi->image_seq = image_seq; |
| 787 | si->image_seq_set = 1; | 798 | si->image_seq_set = 1; |
| 788 | } else if (ubi->image_seq != image_seq) { | 799 | } else if (ubi->image_seq && ubi->image_seq != image_seq) { |
| 789 | ubi_err("bad image sequence number %d in PEB %d, " | 800 | ubi_err("bad image sequence number %d in PEB %d, " |
| 790 | "expected %d", image_seq, pnum, ubi->image_seq); | 801 | "expected %d", image_seq, pnum, ubi->image_seq); |
| 791 | ubi_dbg_dump_ec_hdr(ech); | 802 | ubi_dbg_dump_ec_hdr(ech); |
diff --git a/drivers/net/3c515.c b/drivers/net/3c515.c index 3e00fa8ea65f..4a7c32895be5 100644 --- a/drivers/net/3c515.c +++ b/drivers/net/3c515.c | |||
| @@ -832,7 +832,9 @@ static int corkscrew_open(struct net_device *dev) | |||
| 832 | skb_reserve(skb, 2); /* Align IP on 16 byte boundaries */ | 832 | skb_reserve(skb, 2); /* Align IP on 16 byte boundaries */ |
| 833 | vp->rx_ring[i].addr = isa_virt_to_bus(skb->data); | 833 | vp->rx_ring[i].addr = isa_virt_to_bus(skb->data); |
| 834 | } | 834 | } |
| 835 | vp->rx_ring[i - 1].next = isa_virt_to_bus(&vp->rx_ring[0]); /* Wrap the ring. */ | 835 | if (i != 0) |
| 836 | vp->rx_ring[i - 1].next = | ||
| 837 | isa_virt_to_bus(&vp->rx_ring[0]); /* Wrap the ring. */ | ||
| 836 | outl(isa_virt_to_bus(&vp->rx_ring[0]), ioaddr + UpListPtr); | 838 | outl(isa_virt_to_bus(&vp->rx_ring[0]), ioaddr + UpListPtr); |
| 837 | } | 839 | } |
| 838 | if (vp->full_bus_master_tx) { /* Boomerang bus master Tx. */ | 840 | if (vp->full_bus_master_tx) { /* Boomerang bus master Tx. */ |
diff --git a/drivers/net/3c59x.c b/drivers/net/3c59x.c index c34aee91250b..45675889850b 100644 --- a/drivers/net/3c59x.c +++ b/drivers/net/3c59x.c | |||
| @@ -235,6 +235,7 @@ enum vortex_chips { | |||
| 235 | CH_3C900B_FL, | 235 | CH_3C900B_FL, |
| 236 | CH_3C905_1, | 236 | CH_3C905_1, |
| 237 | CH_3C905_2, | 237 | CH_3C905_2, |
| 238 | CH_3C905B_TX, | ||
| 238 | CH_3C905B_1, | 239 | CH_3C905B_1, |
| 239 | 240 | ||
| 240 | CH_3C905B_2, | 241 | CH_3C905B_2, |
| @@ -307,6 +308,8 @@ static struct vortex_chip_info { | |||
| 307 | PCI_USES_MASTER, IS_BOOMERANG|HAS_MII|EEPROM_RESET, 64, }, | 308 | PCI_USES_MASTER, IS_BOOMERANG|HAS_MII|EEPROM_RESET, 64, }, |
| 308 | {"3c905 Boomerang 100baseT4", | 309 | {"3c905 Boomerang 100baseT4", |
| 309 | PCI_USES_MASTER, IS_BOOMERANG|HAS_MII|EEPROM_RESET, 64, }, | 310 | PCI_USES_MASTER, IS_BOOMERANG|HAS_MII|EEPROM_RESET, 64, }, |
| 311 | {"3C905B-TX Fast Etherlink XL PCI", | ||
| 312 | PCI_USES_MASTER, IS_CYCLONE|HAS_NWAY|HAS_HWCKSM|EXTRA_PREAMBLE, 128, }, | ||
| 310 | {"3c905B Cyclone 100baseTx", | 313 | {"3c905B Cyclone 100baseTx", |
| 311 | PCI_USES_MASTER, IS_CYCLONE|HAS_NWAY|HAS_HWCKSM|EXTRA_PREAMBLE, 128, }, | 314 | PCI_USES_MASTER, IS_CYCLONE|HAS_NWAY|HAS_HWCKSM|EXTRA_PREAMBLE, 128, }, |
| 312 | 315 | ||
| @@ -389,6 +392,7 @@ static struct pci_device_id vortex_pci_tbl[] = { | |||
| 389 | { 0x10B7, 0x900A, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CH_3C900B_FL }, | 392 | { 0x10B7, 0x900A, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CH_3C900B_FL }, |
| 390 | { 0x10B7, 0x9050, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CH_3C905_1 }, | 393 | { 0x10B7, 0x9050, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CH_3C905_1 }, |
| 391 | { 0x10B7, 0x9051, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CH_3C905_2 }, | 394 | { 0x10B7, 0x9051, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CH_3C905_2 }, |
| 395 | { 0x10B7, 0x9054, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CH_3C905B_TX }, | ||
| 392 | { 0x10B7, 0x9055, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CH_3C905B_1 }, | 396 | { 0x10B7, 0x9055, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CH_3C905B_1 }, |
| 393 | 397 | ||
| 394 | { 0x10B7, 0x9058, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CH_3C905B_2 }, | 398 | { 0x10B7, 0x9058, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CH_3C905B_2 }, |
| @@ -2721,13 +2725,15 @@ dump_tx_ring(struct net_device *dev) | |||
| 2721 | &vp->tx_ring[vp->dirty_tx % TX_RING_SIZE]); | 2725 | &vp->tx_ring[vp->dirty_tx % TX_RING_SIZE]); |
| 2722 | issue_and_wait(dev, DownStall); | 2726 | issue_and_wait(dev, DownStall); |
| 2723 | for (i = 0; i < TX_RING_SIZE; i++) { | 2727 | for (i = 0; i < TX_RING_SIZE; i++) { |
| 2724 | pr_err(" %d: @%p length %8.8x status %8.8x\n", i, | 2728 | unsigned int length; |
| 2725 | &vp->tx_ring[i], | 2729 | |
| 2726 | #if DO_ZEROCOPY | 2730 | #if DO_ZEROCOPY |
| 2727 | le32_to_cpu(vp->tx_ring[i].frag[0].length), | 2731 | length = le32_to_cpu(vp->tx_ring[i].frag[0].length); |
| 2728 | #else | 2732 | #else |
| 2729 | le32_to_cpu(vp->tx_ring[i].length), | 2733 | length = le32_to_cpu(vp->tx_ring[i].length); |
| 2730 | #endif | 2734 | #endif |
| 2735 | pr_err(" %d: @%p length %8.8x status %8.8x\n", | ||
| 2736 | i, &vp->tx_ring[i], length, | ||
| 2731 | le32_to_cpu(vp->tx_ring[i].status)); | 2737 | le32_to_cpu(vp->tx_ring[i].status)); |
| 2732 | } | 2738 | } |
| 2733 | if (!stalled) | 2739 | if (!stalled) |
diff --git a/drivers/net/8139cp.c b/drivers/net/8139cp.c index 50efde11ea6c..d0dbbf39349a 100644 --- a/drivers/net/8139cp.c +++ b/drivers/net/8139cp.c | |||
| @@ -515,7 +515,7 @@ rx_status_loop: | |||
| 515 | dma_addr_t mapping; | 515 | dma_addr_t mapping; |
| 516 | struct sk_buff *skb, *new_skb; | 516 | struct sk_buff *skb, *new_skb; |
| 517 | struct cp_desc *desc; | 517 | struct cp_desc *desc; |
| 518 | unsigned buflen; | 518 | const unsigned buflen = cp->rx_buf_sz; |
| 519 | 519 | ||
| 520 | skb = cp->rx_skb[rx_tail]; | 520 | skb = cp->rx_skb[rx_tail]; |
| 521 | BUG_ON(!skb); | 521 | BUG_ON(!skb); |
| @@ -549,8 +549,7 @@ rx_status_loop: | |||
| 549 | pr_debug("%s: rx slot %d status 0x%x len %d\n", | 549 | pr_debug("%s: rx slot %d status 0x%x len %d\n", |
| 550 | dev->name, rx_tail, status, len); | 550 | dev->name, rx_tail, status, len); |
| 551 | 551 | ||
| 552 | buflen = cp->rx_buf_sz + NET_IP_ALIGN; | 552 | new_skb = netdev_alloc_skb(dev, buflen + NET_IP_ALIGN); |
| 553 | new_skb = netdev_alloc_skb(dev, buflen); | ||
| 554 | if (!new_skb) { | 553 | if (!new_skb) { |
| 555 | dev->stats.rx_dropped++; | 554 | dev->stats.rx_dropped++; |
| 556 | goto rx_next; | 555 | goto rx_next; |
diff --git a/drivers/net/Kconfig b/drivers/net/Kconfig index c155bd3ec9f1..5ce7cbabd7a7 100644 --- a/drivers/net/Kconfig +++ b/drivers/net/Kconfig | |||
| @@ -1727,7 +1727,16 @@ config KS8842 | |||
| 1727 | tristate "Micrel KSZ8842" | 1727 | tristate "Micrel KSZ8842" |
| 1728 | depends on HAS_IOMEM | 1728 | depends on HAS_IOMEM |
| 1729 | help | 1729 | help |
| 1730 | This platform driver is for Micrel KSZ8842 chip. | 1730 | This platform driver is for Micrel KSZ8842 / KS8842 |
| 1731 | 2-port ethernet switch chip (managed, VLAN, QoS). | ||
| 1732 | |||
| 1733 | config KS8851 | ||
| 1734 | tristate "Micrel KS8851 SPI" | ||
| 1735 | depends on SPI | ||
| 1736 | select MII | ||
| 1737 | select CRC32 | ||
| 1738 | help | ||
| 1739 | SPI driver for Micrel KS8851 SPI attached network chip. | ||
| 1731 | 1740 | ||
| 1732 | config VIA_RHINE | 1741 | config VIA_RHINE |
| 1733 | tristate "VIA Rhine support" | 1742 | tristate "VIA Rhine support" |
diff --git a/drivers/net/Makefile b/drivers/net/Makefile index 4b58a59f211b..ead8cab3cfe1 100644 --- a/drivers/net/Makefile +++ b/drivers/net/Makefile | |||
| @@ -88,6 +88,7 @@ obj-$(CONFIG_SKGE) += skge.o | |||
| 88 | obj-$(CONFIG_SKY2) += sky2.o | 88 | obj-$(CONFIG_SKY2) += sky2.o |
| 89 | obj-$(CONFIG_SKFP) += skfp/ | 89 | obj-$(CONFIG_SKFP) += skfp/ |
| 90 | obj-$(CONFIG_KS8842) += ks8842.o | 90 | obj-$(CONFIG_KS8842) += ks8842.o |
| 91 | obj-$(CONFIG_KS8851) += ks8851.o | ||
| 91 | obj-$(CONFIG_VIA_RHINE) += via-rhine.o | 92 | obj-$(CONFIG_VIA_RHINE) += via-rhine.o |
| 92 | obj-$(CONFIG_VIA_VELOCITY) += via-velocity.o | 93 | obj-$(CONFIG_VIA_VELOCITY) += via-velocity.o |
| 93 | obj-$(CONFIG_ADAPTEC_STARFIRE) += starfire.o | 94 | obj-$(CONFIG_ADAPTEC_STARFIRE) += starfire.o |
diff --git a/drivers/net/arm/Kconfig b/drivers/net/arm/Kconfig index 2895db13bfa4..c37ee9e6b67b 100644 --- a/drivers/net/arm/Kconfig +++ b/drivers/net/arm/Kconfig | |||
| @@ -63,3 +63,11 @@ config IXP4XX_ETH | |||
| 63 | help | 63 | help |
| 64 | Say Y here if you want to use built-in Ethernet ports | 64 | Say Y here if you want to use built-in Ethernet ports |
| 65 | on IXP4xx processor. | 65 | on IXP4xx processor. |
| 66 | |||
| 67 | config W90P910_ETH | ||
| 68 | tristate "Nuvoton w90p910 Ethernet support" | ||
| 69 | depends on ARM && ARCH_W90X900 | ||
| 70 | select PHYLIB | ||
| 71 | help | ||
| 72 | Say Y here if you want to use built-in Ethernet ports | ||
| 73 | on w90p910 processor. | ||
diff --git a/drivers/net/arm/Makefile b/drivers/net/arm/Makefile index 811a3ccd14c1..303171f589e6 100644 --- a/drivers/net/arm/Makefile +++ b/drivers/net/arm/Makefile | |||
| @@ -11,3 +11,4 @@ obj-$(CONFIG_ARM_AT91_ETHER) += at91_ether.o | |||
| 11 | obj-$(CONFIG_ARM_KS8695_ETHER) += ks8695net.o | 11 | obj-$(CONFIG_ARM_KS8695_ETHER) += ks8695net.o |
| 12 | obj-$(CONFIG_EP93XX_ETH) += ep93xx_eth.o | 12 | obj-$(CONFIG_EP93XX_ETH) += ep93xx_eth.o |
| 13 | obj-$(CONFIG_IXP4XX_ETH) += ixp4xx_eth.o | 13 | obj-$(CONFIG_IXP4XX_ETH) += ixp4xx_eth.o |
| 14 | obj-$(CONFIG_W90P910_ETH) += w90p910_ether.o | ||
diff --git a/drivers/net/arm/at91_ether.c b/drivers/net/arm/at91_ether.c index 2e7419a61191..5041d10bae9d 100644 --- a/drivers/net/arm/at91_ether.c +++ b/drivers/net/arm/at91_ether.c | |||
| @@ -1228,7 +1228,6 @@ static int at91ether_resume(struct platform_device *pdev) | |||
| 1228 | #endif | 1228 | #endif |
| 1229 | 1229 | ||
| 1230 | static struct platform_driver at91ether_driver = { | 1230 | static struct platform_driver at91ether_driver = { |
| 1231 | .probe = at91ether_probe, | ||
| 1232 | .remove = __devexit_p(at91ether_remove), | 1231 | .remove = __devexit_p(at91ether_remove), |
| 1233 | .suspend = at91ether_suspend, | 1232 | .suspend = at91ether_suspend, |
| 1234 | .resume = at91ether_resume, | 1233 | .resume = at91ether_resume, |
| @@ -1240,7 +1239,7 @@ static struct platform_driver at91ether_driver = { | |||
| 1240 | 1239 | ||
| 1241 | static int __init at91ether_init(void) | 1240 | static int __init at91ether_init(void) |
| 1242 | { | 1241 | { |
| 1243 | return platform_driver_register(&at91ether_driver); | 1242 | return platform_driver_probe(&at91ether_driver, at91ether_probe); |
| 1244 | } | 1243 | } |
| 1245 | 1244 | ||
| 1246 | static void __exit at91ether_exit(void) | 1245 | static void __exit at91ether_exit(void) |
diff --git a/drivers/net/arm/w90p910_ether.c b/drivers/net/arm/w90p910_ether.c new file mode 100644 index 000000000000..ddd231cb54b7 --- /dev/null +++ b/drivers/net/arm/w90p910_ether.c | |||
| @@ -0,0 +1,1105 @@ | |||
| 1 | /* | ||
| 2 | * Copyright (c) 2008-2009 Nuvoton technology corporation. | ||
| 3 | * | ||
| 4 | * Wan ZongShun <mcuos.com@gmail.com> | ||
| 5 | * | ||
| 6 | * This program is free software; you can redistribute it and/or modify | ||
| 7 | * it under the terms of the GNU General Public License as published by | ||
| 8 | * the Free Software Foundation;version 2 of the License. | ||
| 9 | * | ||
| 10 | */ | ||
| 11 | |||
| 12 | #include <linux/module.h> | ||
| 13 | #include <linux/init.h> | ||
| 14 | #include <linux/mii.h> | ||
| 15 | #include <linux/netdevice.h> | ||
| 16 | #include <linux/etherdevice.h> | ||
| 17 | #include <linux/skbuff.h> | ||
| 18 | #include <linux/ethtool.h> | ||
| 19 | #include <linux/platform_device.h> | ||
| 20 | #include <linux/clk.h> | ||
| 21 | |||
| 22 | #define DRV_MODULE_NAME "w90p910-emc" | ||
| 23 | #define DRV_MODULE_VERSION "0.1" | ||
| 24 | |||
| 25 | /* Ethernet MAC Registers */ | ||
| 26 | #define REG_CAMCMR 0x00 | ||
| 27 | #define REG_CAMEN 0x04 | ||
| 28 | #define REG_CAMM_BASE 0x08 | ||
| 29 | #define REG_CAML_BASE 0x0c | ||
| 30 | #define REG_TXDLSA 0x88 | ||
| 31 | #define REG_RXDLSA 0x8C | ||
| 32 | #define REG_MCMDR 0x90 | ||
| 33 | #define REG_MIID 0x94 | ||
| 34 | #define REG_MIIDA 0x98 | ||
| 35 | #define REG_FFTCR 0x9C | ||
| 36 | #define REG_TSDR 0xa0 | ||
| 37 | #define REG_RSDR 0xa4 | ||
| 38 | #define REG_DMARFC 0xa8 | ||
| 39 | #define REG_MIEN 0xac | ||
| 40 | #define REG_MISTA 0xb0 | ||
| 41 | #define REG_CTXDSA 0xcc | ||
| 42 | #define REG_CTXBSA 0xd0 | ||
| 43 | #define REG_CRXDSA 0xd4 | ||
| 44 | #define REG_CRXBSA 0xd8 | ||
| 45 | |||
| 46 | /* mac controller bit */ | ||
| 47 | #define MCMDR_RXON 0x01 | ||
| 48 | #define MCMDR_ACP (0x01 << 3) | ||
| 49 | #define MCMDR_SPCRC (0x01 << 5) | ||
| 50 | #define MCMDR_TXON (0x01 << 8) | ||
| 51 | #define MCMDR_FDUP (0x01 << 18) | ||
| 52 | #define MCMDR_ENMDC (0x01 << 19) | ||
| 53 | #define MCMDR_OPMOD (0x01 << 20) | ||
| 54 | #define SWR (0x01 << 24) | ||
| 55 | |||
| 56 | /* cam command regiser */ | ||
| 57 | #define CAMCMR_AUP 0x01 | ||
| 58 | #define CAMCMR_AMP (0x01 << 1) | ||
| 59 | #define CAMCMR_ABP (0x01 << 2) | ||
| 60 | #define CAMCMR_CCAM (0x01 << 3) | ||
| 61 | #define CAMCMR_ECMP (0x01 << 4) | ||
| 62 | #define CAM0EN 0x01 | ||
| 63 | |||
| 64 | /* mac mii controller bit */ | ||
| 65 | #define MDCCR (0x0a << 20) | ||
| 66 | #define PHYAD (0x01 << 8) | ||
| 67 | #define PHYWR (0x01 << 16) | ||
| 68 | #define PHYBUSY (0x01 << 17) | ||
| 69 | #define PHYPRESP (0x01 << 18) | ||
| 70 | #define CAM_ENTRY_SIZE 0x08 | ||
| 71 | |||
| 72 | /* rx and tx status */ | ||
| 73 | #define TXDS_TXCP (0x01 << 19) | ||
| 74 | #define RXDS_CRCE (0x01 << 17) | ||
| 75 | #define RXDS_PTLE (0x01 << 19) | ||
| 76 | #define RXDS_RXGD (0x01 << 20) | ||
| 77 | #define RXDS_ALIE (0x01 << 21) | ||
| 78 | #define RXDS_RP (0x01 << 22) | ||
| 79 | |||
| 80 | /* mac interrupt status*/ | ||
| 81 | #define MISTA_EXDEF (0x01 << 19) | ||
| 82 | #define MISTA_TXBERR (0x01 << 24) | ||
| 83 | #define MISTA_TDU (0x01 << 23) | ||
| 84 | #define MISTA_RDU (0x01 << 10) | ||
| 85 | #define MISTA_RXBERR (0x01 << 11) | ||
| 86 | |||
| 87 | #define ENSTART 0x01 | ||
| 88 | #define ENRXINTR 0x01 | ||
| 89 | #define ENRXGD (0x01 << 4) | ||
| 90 | #define ENRXBERR (0x01 << 11) | ||
| 91 | #define ENTXINTR (0x01 << 16) | ||
| 92 | #define ENTXCP (0x01 << 18) | ||
| 93 | #define ENTXABT (0x01 << 21) | ||
| 94 | #define ENTXBERR (0x01 << 24) | ||
| 95 | #define ENMDC (0x01 << 19) | ||
| 96 | #define PHYBUSY (0x01 << 17) | ||
| 97 | #define MDCCR_VAL 0xa00000 | ||
| 98 | |||
| 99 | /* rx and tx owner bit */ | ||
| 100 | #define RX_OWEN_DMA (0x01 << 31) | ||
| 101 | #define RX_OWEN_CPU (~(0x03 << 30)) | ||
| 102 | #define TX_OWEN_DMA (0x01 << 31) | ||
| 103 | #define TX_OWEN_CPU (~(0x01 << 31)) | ||
| 104 | |||
| 105 | /* tx frame desc controller bit */ | ||
| 106 | #define MACTXINTEN 0x04 | ||
| 107 | #define CRCMODE 0x02 | ||
| 108 | #define PADDINGMODE 0x01 | ||
| 109 | |||
| 110 | /* fftcr controller bit */ | ||
| 111 | #define TXTHD (0x03 << 8) | ||
| 112 | #define BLENGTH (0x01 << 20) | ||
| 113 | |||
| 114 | /* global setting for driver */ | ||
| 115 | #define RX_DESC_SIZE 50 | ||
| 116 | #define TX_DESC_SIZE 10 | ||
| 117 | #define MAX_RBUFF_SZ 0x600 | ||
| 118 | #define MAX_TBUFF_SZ 0x600 | ||
| 119 | #define TX_TIMEOUT 50 | ||
| 120 | #define DELAY 1000 | ||
| 121 | #define CAM0 0x0 | ||
| 122 | |||
| 123 | static int w90p910_mdio_read(struct net_device *dev, int phy_id, int reg); | ||
| 124 | |||
| 125 | struct w90p910_rxbd { | ||
| 126 | unsigned int sl; | ||
| 127 | unsigned int buffer; | ||
| 128 | unsigned int reserved; | ||
| 129 | unsigned int next; | ||
| 130 | }; | ||
| 131 | |||
| 132 | struct w90p910_txbd { | ||
| 133 | unsigned int mode; | ||
| 134 | unsigned int buffer; | ||
| 135 | unsigned int sl; | ||
| 136 | unsigned int next; | ||
| 137 | }; | ||
| 138 | |||
| 139 | struct recv_pdesc { | ||
| 140 | struct w90p910_rxbd desclist[RX_DESC_SIZE]; | ||
| 141 | char recv_buf[RX_DESC_SIZE][MAX_RBUFF_SZ]; | ||
| 142 | }; | ||
| 143 | |||
| 144 | struct tran_pdesc { | ||
| 145 | struct w90p910_txbd desclist[TX_DESC_SIZE]; | ||
| 146 | char tran_buf[RX_DESC_SIZE][MAX_TBUFF_SZ]; | ||
| 147 | }; | ||
| 148 | |||
| 149 | struct w90p910_ether { | ||
| 150 | struct recv_pdesc *rdesc; | ||
| 151 | struct recv_pdesc *rdesc_phys; | ||
| 152 | struct tran_pdesc *tdesc; | ||
| 153 | struct tran_pdesc *tdesc_phys; | ||
| 154 | struct net_device_stats stats; | ||
| 155 | struct platform_device *pdev; | ||
| 156 | struct sk_buff *skb; | ||
| 157 | struct clk *clk; | ||
| 158 | struct clk *rmiiclk; | ||
| 159 | struct mii_if_info mii; | ||
| 160 | struct timer_list check_timer; | ||
| 161 | void __iomem *reg; | ||
| 162 | unsigned int rxirq; | ||
| 163 | unsigned int txirq; | ||
| 164 | unsigned int cur_tx; | ||
| 165 | unsigned int cur_rx; | ||
| 166 | unsigned int finish_tx; | ||
| 167 | unsigned int rx_packets; | ||
| 168 | unsigned int rx_bytes; | ||
| 169 | unsigned int start_tx_ptr; | ||
| 170 | unsigned int start_rx_ptr; | ||
| 171 | unsigned int linkflag; | ||
| 172 | spinlock_t lock; | ||
| 173 | }; | ||
| 174 | |||
| 175 | static void update_linkspeed_register(struct net_device *dev, | ||
| 176 | unsigned int speed, unsigned int duplex) | ||
| 177 | { | ||
| 178 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 179 | unsigned int val; | ||
| 180 | |||
| 181 | val = __raw_readl(ether->reg + REG_MCMDR); | ||
| 182 | |||
| 183 | if (speed == SPEED_100) { | ||
| 184 | /* 100 full/half duplex */ | ||
| 185 | if (duplex == DUPLEX_FULL) { | ||
| 186 | val |= (MCMDR_OPMOD | MCMDR_FDUP); | ||
| 187 | } else { | ||
| 188 | val |= MCMDR_OPMOD; | ||
| 189 | val &= ~MCMDR_FDUP; | ||
| 190 | } | ||
| 191 | } else { | ||
| 192 | /* 10 full/half duplex */ | ||
| 193 | if (duplex == DUPLEX_FULL) { | ||
| 194 | val |= MCMDR_FDUP; | ||
| 195 | val &= ~MCMDR_OPMOD; | ||
| 196 | } else { | ||
| 197 | val &= ~(MCMDR_FDUP | MCMDR_OPMOD); | ||
| 198 | } | ||
| 199 | } | ||
| 200 | |||
| 201 | __raw_writel(val, ether->reg + REG_MCMDR); | ||
| 202 | } | ||
| 203 | |||
| 204 | static void update_linkspeed(struct net_device *dev) | ||
| 205 | { | ||
| 206 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 207 | struct platform_device *pdev; | ||
| 208 | unsigned int bmsr, bmcr, lpa, speed, duplex; | ||
| 209 | |||
| 210 | pdev = ether->pdev; | ||
| 211 | |||
| 212 | if (!mii_link_ok(ðer->mii)) { | ||
| 213 | ether->linkflag = 0x0; | ||
| 214 | netif_carrier_off(dev); | ||
| 215 | dev_warn(&pdev->dev, "%s: Link down.\n", dev->name); | ||
| 216 | return; | ||
| 217 | } | ||
| 218 | |||
| 219 | if (ether->linkflag == 1) | ||
| 220 | return; | ||
| 221 | |||
| 222 | bmsr = w90p910_mdio_read(dev, ether->mii.phy_id, MII_BMSR); | ||
| 223 | bmcr = w90p910_mdio_read(dev, ether->mii.phy_id, MII_BMCR); | ||
| 224 | |||
| 225 | if (bmcr & BMCR_ANENABLE) { | ||
| 226 | if (!(bmsr & BMSR_ANEGCOMPLETE)) | ||
| 227 | return; | ||
| 228 | |||
| 229 | lpa = w90p910_mdio_read(dev, ether->mii.phy_id, MII_LPA); | ||
| 230 | |||
| 231 | if ((lpa & LPA_100FULL) || (lpa & LPA_100HALF)) | ||
| 232 | speed = SPEED_100; | ||
| 233 | else | ||
| 234 | speed = SPEED_10; | ||
| 235 | |||
| 236 | if ((lpa & LPA_100FULL) || (lpa & LPA_10FULL)) | ||
| 237 | duplex = DUPLEX_FULL; | ||
| 238 | else | ||
| 239 | duplex = DUPLEX_HALF; | ||
| 240 | |||
| 241 | } else { | ||
| 242 | speed = (bmcr & BMCR_SPEED100) ? SPEED_100 : SPEED_10; | ||
| 243 | duplex = (bmcr & BMCR_FULLDPLX) ? DUPLEX_FULL : DUPLEX_HALF; | ||
| 244 | } | ||
| 245 | |||
| 246 | update_linkspeed_register(dev, speed, duplex); | ||
| 247 | |||
| 248 | dev_info(&pdev->dev, "%s: Link now %i-%s\n", dev->name, speed, | ||
| 249 | (duplex == DUPLEX_FULL) ? "FullDuplex" : "HalfDuplex"); | ||
| 250 | ether->linkflag = 0x01; | ||
| 251 | |||
| 252 | netif_carrier_on(dev); | ||
| 253 | } | ||
| 254 | |||
| 255 | static void w90p910_check_link(unsigned long dev_id) | ||
| 256 | { | ||
| 257 | struct net_device *dev = (struct net_device *) dev_id; | ||
| 258 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 259 | |||
| 260 | update_linkspeed(dev); | ||
| 261 | mod_timer(ðer->check_timer, jiffies + msecs_to_jiffies(1000)); | ||
| 262 | } | ||
| 263 | |||
| 264 | static void w90p910_write_cam(struct net_device *dev, | ||
| 265 | unsigned int x, unsigned char *pval) | ||
| 266 | { | ||
| 267 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 268 | unsigned int msw, lsw; | ||
| 269 | |||
| 270 | msw = (pval[0] << 24) | (pval[1] << 16) | (pval[2] << 8) | pval[3]; | ||
| 271 | |||
| 272 | lsw = (pval[4] << 24) | (pval[5] << 16); | ||
| 273 | |||
| 274 | __raw_writel(lsw, ether->reg + REG_CAML_BASE + x * CAM_ENTRY_SIZE); | ||
| 275 | __raw_writel(msw, ether->reg + REG_CAMM_BASE + x * CAM_ENTRY_SIZE); | ||
| 276 | } | ||
| 277 | |||
| 278 | static void w90p910_init_desc(struct net_device *dev) | ||
| 279 | { | ||
| 280 | struct w90p910_ether *ether; | ||
| 281 | struct w90p910_txbd *tdesc, *tdesc_phys; | ||
| 282 | struct w90p910_rxbd *rdesc, *rdesc_phys; | ||
| 283 | unsigned int i, j; | ||
| 284 | |||
| 285 | ether = netdev_priv(dev); | ||
| 286 | |||
| 287 | ether->tdesc = (struct tran_pdesc *) | ||
| 288 | dma_alloc_coherent(NULL, sizeof(struct tran_pdesc), | ||
| 289 | (dma_addr_t *) ðer->tdesc_phys, GFP_KERNEL); | ||
| 290 | |||
| 291 | ether->rdesc = (struct recv_pdesc *) | ||
| 292 | dma_alloc_coherent(NULL, sizeof(struct recv_pdesc), | ||
| 293 | (dma_addr_t *) ðer->rdesc_phys, GFP_KERNEL); | ||
| 294 | |||
| 295 | for (i = 0; i < TX_DESC_SIZE; i++) { | ||
| 296 | tdesc = &(ether->tdesc->desclist[i]); | ||
| 297 | |||
| 298 | j = ((i + 1) / TX_DESC_SIZE); | ||
| 299 | |||
| 300 | if (j != 0) { | ||
| 301 | tdesc_phys = &(ether->tdesc_phys->desclist[0]); | ||
| 302 | ether->start_tx_ptr = (unsigned int)tdesc_phys; | ||
| 303 | tdesc->next = (unsigned int)ether->start_tx_ptr; | ||
| 304 | } else { | ||
| 305 | tdesc_phys = &(ether->tdesc_phys->desclist[i+1]); | ||
| 306 | tdesc->next = (unsigned int)tdesc_phys; | ||
| 307 | } | ||
| 308 | |||
| 309 | tdesc->buffer = (unsigned int)ether->tdesc_phys->tran_buf[i]; | ||
| 310 | tdesc->sl = 0; | ||
| 311 | tdesc->mode = 0; | ||
| 312 | } | ||
| 313 | |||
| 314 | for (i = 0; i < RX_DESC_SIZE; i++) { | ||
| 315 | rdesc = &(ether->rdesc->desclist[i]); | ||
| 316 | |||
| 317 | j = ((i + 1) / RX_DESC_SIZE); | ||
| 318 | |||
| 319 | if (j != 0) { | ||
| 320 | rdesc_phys = &(ether->rdesc_phys->desclist[0]); | ||
| 321 | ether->start_rx_ptr = (unsigned int)rdesc_phys; | ||
| 322 | rdesc->next = (unsigned int)ether->start_rx_ptr; | ||
| 323 | } else { | ||
| 324 | rdesc_phys = &(ether->rdesc_phys->desclist[i+1]); | ||
| 325 | rdesc->next = (unsigned int)rdesc_phys; | ||
| 326 | } | ||
| 327 | |||
| 328 | rdesc->sl = RX_OWEN_DMA; | ||
| 329 | rdesc->buffer = (unsigned int)ether->rdesc_phys->recv_buf[i]; | ||
| 330 | } | ||
| 331 | } | ||
| 332 | |||
| 333 | static void w90p910_set_fifo_threshold(struct net_device *dev) | ||
| 334 | { | ||
| 335 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 336 | unsigned int val; | ||
| 337 | |||
| 338 | val = TXTHD | BLENGTH; | ||
| 339 | __raw_writel(val, ether->reg + REG_FFTCR); | ||
| 340 | } | ||
| 341 | |||
| 342 | static void w90p910_return_default_idle(struct net_device *dev) | ||
| 343 | { | ||
| 344 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 345 | unsigned int val; | ||
| 346 | |||
| 347 | val = __raw_readl(ether->reg + REG_MCMDR); | ||
| 348 | val |= SWR; | ||
| 349 | __raw_writel(val, ether->reg + REG_MCMDR); | ||
| 350 | } | ||
| 351 | |||
| 352 | static void w90p910_trigger_rx(struct net_device *dev) | ||
| 353 | { | ||
| 354 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 355 | |||
| 356 | __raw_writel(ENSTART, ether->reg + REG_RSDR); | ||
| 357 | } | ||
| 358 | |||
| 359 | static void w90p910_trigger_tx(struct net_device *dev) | ||
| 360 | { | ||
| 361 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 362 | |||
| 363 | __raw_writel(ENSTART, ether->reg + REG_TSDR); | ||
| 364 | } | ||
| 365 | |||
| 366 | static void w90p910_enable_mac_interrupt(struct net_device *dev) | ||
| 367 | { | ||
| 368 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 369 | unsigned int val; | ||
| 370 | |||
| 371 | val = ENTXINTR | ENRXINTR | ENRXGD | ENTXCP; | ||
| 372 | val |= ENTXBERR | ENRXBERR | ENTXABT; | ||
| 373 | |||
| 374 | __raw_writel(val, ether->reg + REG_MIEN); | ||
| 375 | } | ||
| 376 | |||
| 377 | static void w90p910_get_and_clear_int(struct net_device *dev, | ||
| 378 | unsigned int *val) | ||
| 379 | { | ||
| 380 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 381 | |||
| 382 | *val = __raw_readl(ether->reg + REG_MISTA); | ||
| 383 | __raw_writel(*val, ether->reg + REG_MISTA); | ||
| 384 | } | ||
| 385 | |||
| 386 | static void w90p910_set_global_maccmd(struct net_device *dev) | ||
| 387 | { | ||
| 388 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 389 | unsigned int val; | ||
| 390 | |||
| 391 | val = __raw_readl(ether->reg + REG_MCMDR); | ||
| 392 | val |= MCMDR_SPCRC | MCMDR_ENMDC | MCMDR_ACP | ENMDC; | ||
| 393 | __raw_writel(val, ether->reg + REG_MCMDR); | ||
| 394 | } | ||
| 395 | |||
| 396 | static void w90p910_enable_cam(struct net_device *dev) | ||
| 397 | { | ||
| 398 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 399 | unsigned int val; | ||
| 400 | |||
| 401 | w90p910_write_cam(dev, CAM0, dev->dev_addr); | ||
| 402 | |||
| 403 | val = __raw_readl(ether->reg + REG_CAMEN); | ||
| 404 | val |= CAM0EN; | ||
| 405 | __raw_writel(val, ether->reg + REG_CAMEN); | ||
| 406 | } | ||
| 407 | |||
| 408 | static void w90p910_enable_cam_command(struct net_device *dev) | ||
| 409 | { | ||
| 410 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 411 | unsigned int val; | ||
| 412 | |||
| 413 | val = CAMCMR_ECMP | CAMCMR_ABP | CAMCMR_AMP; | ||
| 414 | __raw_writel(val, ether->reg + REG_CAMCMR); | ||
| 415 | } | ||
| 416 | |||
| 417 | static void w90p910_enable_tx(struct net_device *dev, unsigned int enable) | ||
| 418 | { | ||
| 419 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 420 | unsigned int val; | ||
| 421 | |||
| 422 | val = __raw_readl(ether->reg + REG_MCMDR); | ||
| 423 | |||
| 424 | if (enable) | ||
| 425 | val |= MCMDR_TXON; | ||
| 426 | else | ||
| 427 | val &= ~MCMDR_TXON; | ||
| 428 | |||
| 429 | __raw_writel(val, ether->reg + REG_MCMDR); | ||
| 430 | } | ||
| 431 | |||
| 432 | static void w90p910_enable_rx(struct net_device *dev, unsigned int enable) | ||
| 433 | { | ||
| 434 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 435 | unsigned int val; | ||
| 436 | |||
| 437 | val = __raw_readl(ether->reg + REG_MCMDR); | ||
| 438 | |||
| 439 | if (enable) | ||
| 440 | val |= MCMDR_RXON; | ||
| 441 | else | ||
| 442 | val &= ~MCMDR_RXON; | ||
| 443 | |||
| 444 | __raw_writel(val, ether->reg + REG_MCMDR); | ||
| 445 | } | ||
| 446 | |||
| 447 | static void w90p910_set_curdest(struct net_device *dev) | ||
| 448 | { | ||
| 449 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 450 | |||
| 451 | __raw_writel(ether->start_rx_ptr, ether->reg + REG_RXDLSA); | ||
| 452 | __raw_writel(ether->start_tx_ptr, ether->reg + REG_TXDLSA); | ||
| 453 | } | ||
| 454 | |||
| 455 | static void w90p910_reset_mac(struct net_device *dev) | ||
| 456 | { | ||
| 457 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 458 | |||
| 459 | spin_lock(ðer->lock); | ||
| 460 | |||
| 461 | w90p910_enable_tx(dev, 0); | ||
| 462 | w90p910_enable_rx(dev, 0); | ||
| 463 | w90p910_set_fifo_threshold(dev); | ||
| 464 | w90p910_return_default_idle(dev); | ||
| 465 | |||
| 466 | if (!netif_queue_stopped(dev)) | ||
| 467 | netif_stop_queue(dev); | ||
| 468 | |||
| 469 | w90p910_init_desc(dev); | ||
| 470 | |||
| 471 | dev->trans_start = jiffies; | ||
| 472 | ether->cur_tx = 0x0; | ||
| 473 | ether->finish_tx = 0x0; | ||
| 474 | ether->cur_rx = 0x0; | ||
| 475 | |||
| 476 | w90p910_set_curdest(dev); | ||
| 477 | w90p910_enable_cam(dev); | ||
| 478 | w90p910_enable_cam_command(dev); | ||
| 479 | w90p910_enable_mac_interrupt(dev); | ||
| 480 | w90p910_enable_tx(dev, 1); | ||
| 481 | w90p910_enable_rx(dev, 1); | ||
| 482 | w90p910_trigger_tx(dev); | ||
| 483 | w90p910_trigger_rx(dev); | ||
| 484 | |||
| 485 | dev->trans_start = jiffies; | ||
| 486 | |||
| 487 | if (netif_queue_stopped(dev)) | ||
| 488 | netif_wake_queue(dev); | ||
| 489 | |||
| 490 | spin_unlock(ðer->lock); | ||
| 491 | } | ||
| 492 | |||
| 493 | static void w90p910_mdio_write(struct net_device *dev, | ||
| 494 | int phy_id, int reg, int data) | ||
| 495 | { | ||
| 496 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 497 | struct platform_device *pdev; | ||
| 498 | unsigned int val, i; | ||
| 499 | |||
| 500 | pdev = ether->pdev; | ||
| 501 | |||
| 502 | __raw_writel(data, ether->reg + REG_MIID); | ||
| 503 | |||
| 504 | val = (phy_id << 0x08) | reg; | ||
| 505 | val |= PHYBUSY | PHYWR | MDCCR_VAL; | ||
| 506 | __raw_writel(val, ether->reg + REG_MIIDA); | ||
| 507 | |||
| 508 | for (i = 0; i < DELAY; i++) { | ||
| 509 | if ((__raw_readl(ether->reg + REG_MIIDA) & PHYBUSY) == 0) | ||
| 510 | break; | ||
| 511 | } | ||
| 512 | |||
| 513 | if (i == DELAY) | ||
| 514 | dev_warn(&pdev->dev, "mdio write timed out\n"); | ||
| 515 | } | ||
| 516 | |||
| 517 | static int w90p910_mdio_read(struct net_device *dev, int phy_id, int reg) | ||
| 518 | { | ||
| 519 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 520 | struct platform_device *pdev; | ||
| 521 | unsigned int val, i, data; | ||
| 522 | |||
| 523 | pdev = ether->pdev; | ||
| 524 | |||
| 525 | val = (phy_id << 0x08) | reg; | ||
| 526 | val |= PHYBUSY | MDCCR_VAL; | ||
| 527 | __raw_writel(val, ether->reg + REG_MIIDA); | ||
| 528 | |||
| 529 | for (i = 0; i < DELAY; i++) { | ||
| 530 | if ((__raw_readl(ether->reg + REG_MIIDA) & PHYBUSY) == 0) | ||
| 531 | break; | ||
| 532 | } | ||
| 533 | |||
| 534 | if (i == DELAY) { | ||
| 535 | dev_warn(&pdev->dev, "mdio read timed out\n"); | ||
| 536 | data = 0xffff; | ||
| 537 | } else { | ||
| 538 | data = __raw_readl(ether->reg + REG_MIID); | ||
| 539 | } | ||
| 540 | |||
| 541 | return data; | ||
| 542 | } | ||
| 543 | |||
| 544 | static int set_mac_address(struct net_device *dev, void *addr) | ||
| 545 | { | ||
| 546 | struct sockaddr *address = addr; | ||
| 547 | |||
| 548 | if (!is_valid_ether_addr(address->sa_data)) | ||
| 549 | return -EADDRNOTAVAIL; | ||
| 550 | |||
| 551 | memcpy(dev->dev_addr, address->sa_data, dev->addr_len); | ||
| 552 | w90p910_write_cam(dev, CAM0, dev->dev_addr); | ||
| 553 | |||
| 554 | return 0; | ||
| 555 | } | ||
| 556 | |||
| 557 | static int w90p910_ether_close(struct net_device *dev) | ||
| 558 | { | ||
| 559 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 560 | |||
| 561 | dma_free_writecombine(NULL, sizeof(struct w90p910_rxbd), | ||
| 562 | ether->rdesc, (dma_addr_t)ether->rdesc_phys); | ||
| 563 | dma_free_writecombine(NULL, sizeof(struct w90p910_txbd), | ||
| 564 | ether->tdesc, (dma_addr_t)ether->tdesc_phys); | ||
| 565 | |||
| 566 | netif_stop_queue(dev); | ||
| 567 | |||
| 568 | del_timer_sync(ðer->check_timer); | ||
| 569 | clk_disable(ether->rmiiclk); | ||
| 570 | clk_disable(ether->clk); | ||
| 571 | |||
| 572 | free_irq(ether->txirq, dev); | ||
| 573 | free_irq(ether->rxirq, dev); | ||
| 574 | |||
| 575 | return 0; | ||
| 576 | } | ||
| 577 | |||
| 578 | static struct net_device_stats *w90p910_ether_stats(struct net_device *dev) | ||
| 579 | { | ||
| 580 | struct w90p910_ether *ether; | ||
| 581 | |||
| 582 | ether = netdev_priv(dev); | ||
| 583 | |||
| 584 | return ðer->stats; | ||
| 585 | } | ||
| 586 | |||
| 587 | static int w90p910_send_frame(struct net_device *dev, | ||
| 588 | unsigned char *data, int length) | ||
| 589 | { | ||
| 590 | struct w90p910_ether *ether; | ||
| 591 | struct w90p910_txbd *txbd; | ||
| 592 | struct platform_device *pdev; | ||
| 593 | unsigned char *buffer; | ||
| 594 | |||
| 595 | ether = netdev_priv(dev); | ||
| 596 | pdev = ether->pdev; | ||
| 597 | |||
| 598 | txbd = ðer->tdesc->desclist[ether->cur_tx]; | ||
| 599 | buffer = ether->tdesc->tran_buf[ether->cur_tx]; | ||
| 600 | if (length > 1514) { | ||
| 601 | dev_err(&pdev->dev, "send data %d bytes, check it\n", length); | ||
| 602 | length = 1514; | ||
| 603 | } | ||
| 604 | |||
| 605 | txbd->sl = length & 0xFFFF; | ||
| 606 | |||
| 607 | memcpy(buffer, data, length); | ||
| 608 | |||
| 609 | txbd->mode = TX_OWEN_DMA | PADDINGMODE | CRCMODE | MACTXINTEN; | ||
| 610 | |||
| 611 | w90p910_enable_tx(dev, 1); | ||
| 612 | |||
| 613 | w90p910_trigger_tx(dev); | ||
| 614 | |||
| 615 | ether->cur_tx = (ether->cur_tx+1) % TX_DESC_SIZE; | ||
| 616 | txbd = ðer->tdesc->desclist[ether->cur_tx]; | ||
| 617 | |||
| 618 | dev->trans_start = jiffies; | ||
| 619 | |||
| 620 | if (txbd->mode & TX_OWEN_DMA) | ||
| 621 | netif_stop_queue(dev); | ||
| 622 | |||
| 623 | return 0; | ||
| 624 | } | ||
| 625 | |||
| 626 | static int w90p910_ether_start_xmit(struct sk_buff *skb, struct net_device *dev) | ||
| 627 | { | ||
| 628 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 629 | |||
| 630 | if (!(w90p910_send_frame(dev, skb->data, skb->len))) { | ||
| 631 | ether->skb = skb; | ||
| 632 | dev_kfree_skb_irq(skb); | ||
| 633 | return 0; | ||
| 634 | } | ||
| 635 | return -1; | ||
| 636 | } | ||
| 637 | |||
| 638 | static irqreturn_t w90p910_tx_interrupt(int irq, void *dev_id) | ||
| 639 | { | ||
| 640 | struct w90p910_ether *ether; | ||
| 641 | struct w90p910_txbd *txbd; | ||
| 642 | struct platform_device *pdev; | ||
| 643 | struct tran_pdesc *tran_pdesc; | ||
| 644 | struct net_device *dev; | ||
| 645 | unsigned int cur_entry, entry, status; | ||
| 646 | |||
| 647 | dev = (struct net_device *)dev_id; | ||
| 648 | ether = netdev_priv(dev); | ||
| 649 | pdev = ether->pdev; | ||
| 650 | |||
| 651 | spin_lock(ðer->lock); | ||
| 652 | |||
| 653 | w90p910_get_and_clear_int(dev, &status); | ||
| 654 | |||
| 655 | cur_entry = __raw_readl(ether->reg + REG_CTXDSA); | ||
| 656 | |||
| 657 | tran_pdesc = ether->tdesc_phys; | ||
| 658 | entry = (unsigned int)(&tran_pdesc->desclist[ether->finish_tx]); | ||
| 659 | |||
| 660 | while (entry != cur_entry) { | ||
| 661 | txbd = ðer->tdesc->desclist[ether->finish_tx]; | ||
| 662 | |||
| 663 | ether->finish_tx = (ether->finish_tx + 1) % TX_DESC_SIZE; | ||
| 664 | |||
| 665 | if (txbd->sl & TXDS_TXCP) { | ||
| 666 | ether->stats.tx_packets++; | ||
| 667 | ether->stats.tx_bytes += txbd->sl & 0xFFFF; | ||
| 668 | } else { | ||
| 669 | ether->stats.tx_errors++; | ||
| 670 | } | ||
| 671 | |||
| 672 | txbd->sl = 0x0; | ||
| 673 | txbd->mode = 0x0; | ||
| 674 | |||
| 675 | if (netif_queue_stopped(dev)) | ||
| 676 | netif_wake_queue(dev); | ||
| 677 | |||
| 678 | entry = (unsigned int)(&tran_pdesc->desclist[ether->finish_tx]); | ||
| 679 | } | ||
| 680 | |||
| 681 | if (status & MISTA_EXDEF) { | ||
| 682 | dev_err(&pdev->dev, "emc defer exceed interrupt\n"); | ||
| 683 | } else if (status & MISTA_TXBERR) { | ||
| 684 | dev_err(&pdev->dev, "emc bus error interrupt\n"); | ||
| 685 | w90p910_reset_mac(dev); | ||
| 686 | } else if (status & MISTA_TDU) { | ||
| 687 | if (netif_queue_stopped(dev)) | ||
| 688 | netif_wake_queue(dev); | ||
| 689 | } | ||
| 690 | |||
| 691 | spin_unlock(ðer->lock); | ||
| 692 | |||
| 693 | return IRQ_HANDLED; | ||
| 694 | } | ||
| 695 | |||
| 696 | static void netdev_rx(struct net_device *dev) | ||
| 697 | { | ||
| 698 | struct w90p910_ether *ether; | ||
| 699 | struct w90p910_rxbd *rxbd; | ||
| 700 | struct platform_device *pdev; | ||
| 701 | struct recv_pdesc *rdesc_phys; | ||
| 702 | struct sk_buff *skb; | ||
| 703 | unsigned char *data; | ||
| 704 | unsigned int length, status, val, entry; | ||
| 705 | |||
| 706 | ether = netdev_priv(dev); | ||
| 707 | pdev = ether->pdev; | ||
| 708 | rdesc_phys = ether->rdesc_phys; | ||
| 709 | |||
| 710 | rxbd = ðer->rdesc->desclist[ether->cur_rx]; | ||
| 711 | |||
| 712 | do { | ||
| 713 | val = __raw_readl(ether->reg + REG_CRXDSA); | ||
| 714 | entry = (unsigned int)&rdesc_phys->desclist[ether->cur_rx]; | ||
| 715 | |||
| 716 | if (val == entry) | ||
| 717 | break; | ||
| 718 | |||
| 719 | status = rxbd->sl; | ||
| 720 | length = status & 0xFFFF; | ||
| 721 | |||
| 722 | if (status & RXDS_RXGD) { | ||
| 723 | data = ether->rdesc->recv_buf[ether->cur_rx]; | ||
| 724 | skb = dev_alloc_skb(length+2); | ||
| 725 | if (!skb) { | ||
| 726 | dev_err(&pdev->dev, "get skb buffer error\n"); | ||
| 727 | ether->stats.rx_dropped++; | ||
| 728 | return; | ||
| 729 | } | ||
| 730 | |||
| 731 | skb->dev = dev; | ||
| 732 | skb_reserve(skb, 2); | ||
| 733 | skb_put(skb, length); | ||
| 734 | skb_copy_to_linear_data(skb, data, length); | ||
| 735 | skb->protocol = eth_type_trans(skb, dev); | ||
| 736 | ether->stats.rx_packets++; | ||
| 737 | ether->stats.rx_bytes += length; | ||
| 738 | netif_rx(skb); | ||
| 739 | } else { | ||
| 740 | ether->stats.rx_errors++; | ||
| 741 | |||
| 742 | if (status & RXDS_RP) { | ||
| 743 | dev_err(&pdev->dev, "rx runt err\n"); | ||
| 744 | ether->stats.rx_length_errors++; | ||
| 745 | } else if (status & RXDS_CRCE) { | ||
| 746 | dev_err(&pdev->dev, "rx crc err\n"); | ||
| 747 | ether->stats.rx_crc_errors++; | ||
| 748 | } | ||
| 749 | |||
| 750 | if (status & RXDS_ALIE) { | ||
| 751 | dev_err(&pdev->dev, "rx aligment err\n"); | ||
| 752 | ether->stats.rx_frame_errors++; | ||
| 753 | } else if (status & RXDS_PTLE) { | ||
| 754 | dev_err(&pdev->dev, "rx longer err\n"); | ||
| 755 | ether->stats.rx_over_errors++; | ||
| 756 | } | ||
| 757 | } | ||
| 758 | |||
| 759 | rxbd->sl = RX_OWEN_DMA; | ||
| 760 | rxbd->reserved = 0x0; | ||
| 761 | ether->cur_rx = (ether->cur_rx+1) % RX_DESC_SIZE; | ||
| 762 | rxbd = ðer->rdesc->desclist[ether->cur_rx]; | ||
| 763 | |||
| 764 | dev->last_rx = jiffies; | ||
| 765 | } while (1); | ||
| 766 | } | ||
| 767 | |||
| 768 | static irqreturn_t w90p910_rx_interrupt(int irq, void *dev_id) | ||
| 769 | { | ||
| 770 | struct net_device *dev; | ||
| 771 | struct w90p910_ether *ether; | ||
| 772 | struct platform_device *pdev; | ||
| 773 | unsigned int status; | ||
| 774 | |||
| 775 | dev = (struct net_device *)dev_id; | ||
| 776 | ether = netdev_priv(dev); | ||
| 777 | pdev = ether->pdev; | ||
| 778 | |||
| 779 | spin_lock(ðer->lock); | ||
| 780 | |||
| 781 | w90p910_get_and_clear_int(dev, &status); | ||
| 782 | |||
| 783 | if (status & MISTA_RDU) { | ||
| 784 | netdev_rx(dev); | ||
| 785 | |||
| 786 | w90p910_trigger_rx(dev); | ||
| 787 | |||
| 788 | spin_unlock(ðer->lock); | ||
| 789 | return IRQ_HANDLED; | ||
| 790 | } else if (status & MISTA_RXBERR) { | ||
| 791 | dev_err(&pdev->dev, "emc rx bus error\n"); | ||
| 792 | w90p910_reset_mac(dev); | ||
| 793 | } | ||
| 794 | |||
| 795 | netdev_rx(dev); | ||
| 796 | spin_unlock(ðer->lock); | ||
| 797 | return IRQ_HANDLED; | ||
| 798 | } | ||
| 799 | |||
| 800 | static int w90p910_ether_open(struct net_device *dev) | ||
| 801 | { | ||
| 802 | struct w90p910_ether *ether; | ||
| 803 | struct platform_device *pdev; | ||
| 804 | |||
| 805 | ether = netdev_priv(dev); | ||
| 806 | pdev = ether->pdev; | ||
| 807 | |||
| 808 | w90p910_reset_mac(dev); | ||
| 809 | w90p910_set_fifo_threshold(dev); | ||
| 810 | w90p910_set_curdest(dev); | ||
| 811 | w90p910_enable_cam(dev); | ||
| 812 | w90p910_enable_cam_command(dev); | ||
| 813 | w90p910_enable_mac_interrupt(dev); | ||
| 814 | w90p910_set_global_maccmd(dev); | ||
| 815 | w90p910_enable_rx(dev, 1); | ||
| 816 | |||
| 817 | ether->rx_packets = 0x0; | ||
| 818 | ether->rx_bytes = 0x0; | ||
| 819 | |||
| 820 | if (request_irq(ether->txirq, w90p910_tx_interrupt, | ||
| 821 | 0x0, pdev->name, dev)) { | ||
| 822 | dev_err(&pdev->dev, "register irq tx failed\n"); | ||
| 823 | return -EAGAIN; | ||
| 824 | } | ||
| 825 | |||
| 826 | if (request_irq(ether->rxirq, w90p910_rx_interrupt, | ||
| 827 | 0x0, pdev->name, dev)) { | ||
| 828 | dev_err(&pdev->dev, "register irq rx failed\n"); | ||
| 829 | return -EAGAIN; | ||
| 830 | } | ||
| 831 | |||
| 832 | mod_timer(ðer->check_timer, jiffies + msecs_to_jiffies(1000)); | ||
| 833 | netif_start_queue(dev); | ||
| 834 | w90p910_trigger_rx(dev); | ||
| 835 | |||
| 836 | dev_info(&pdev->dev, "%s is OPENED\n", dev->name); | ||
| 837 | |||
| 838 | return 0; | ||
| 839 | } | ||
| 840 | |||
| 841 | static void w90p910_ether_set_multicast_list(struct net_device *dev) | ||
| 842 | { | ||
| 843 | struct w90p910_ether *ether; | ||
| 844 | unsigned int rx_mode; | ||
| 845 | |||
| 846 | ether = netdev_priv(dev); | ||
| 847 | |||
| 848 | if (dev->flags & IFF_PROMISC) | ||
| 849 | rx_mode = CAMCMR_AUP | CAMCMR_AMP | CAMCMR_ABP | CAMCMR_ECMP; | ||
| 850 | else if ((dev->flags & IFF_ALLMULTI) || dev->mc_list) | ||
| 851 | rx_mode = CAMCMR_AMP | CAMCMR_ABP | CAMCMR_ECMP; | ||
| 852 | else | ||
| 853 | rx_mode = CAMCMR_ECMP | CAMCMR_ABP; | ||
| 854 | __raw_writel(rx_mode, ether->reg + REG_CAMCMR); | ||
| 855 | } | ||
| 856 | |||
| 857 | static int w90p910_ether_ioctl(struct net_device *dev, | ||
| 858 | struct ifreq *ifr, int cmd) | ||
| 859 | { | ||
| 860 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 861 | struct mii_ioctl_data *data = if_mii(ifr); | ||
| 862 | |||
| 863 | return generic_mii_ioctl(ðer->mii, data, cmd, NULL); | ||
| 864 | } | ||
| 865 | |||
| 866 | static void w90p910_get_drvinfo(struct net_device *dev, | ||
| 867 | struct ethtool_drvinfo *info) | ||
| 868 | { | ||
| 869 | strcpy(info->driver, DRV_MODULE_NAME); | ||
| 870 | strcpy(info->version, DRV_MODULE_VERSION); | ||
| 871 | } | ||
| 872 | |||
| 873 | static int w90p910_get_settings(struct net_device *dev, struct ethtool_cmd *cmd) | ||
| 874 | { | ||
| 875 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 876 | return mii_ethtool_gset(ðer->mii, cmd); | ||
| 877 | } | ||
| 878 | |||
| 879 | static int w90p910_set_settings(struct net_device *dev, struct ethtool_cmd *cmd) | ||
| 880 | { | ||
| 881 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 882 | return mii_ethtool_sset(ðer->mii, cmd); | ||
| 883 | } | ||
| 884 | |||
| 885 | static int w90p910_nway_reset(struct net_device *dev) | ||
| 886 | { | ||
| 887 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 888 | return mii_nway_restart(ðer->mii); | ||
| 889 | } | ||
| 890 | |||
| 891 | static u32 w90p910_get_link(struct net_device *dev) | ||
| 892 | { | ||
| 893 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 894 | return mii_link_ok(ðer->mii); | ||
| 895 | } | ||
| 896 | |||
| 897 | static const struct ethtool_ops w90p910_ether_ethtool_ops = { | ||
| 898 | .get_settings = w90p910_get_settings, | ||
| 899 | .set_settings = w90p910_set_settings, | ||
| 900 | .get_drvinfo = w90p910_get_drvinfo, | ||
| 901 | .nway_reset = w90p910_nway_reset, | ||
| 902 | .get_link = w90p910_get_link, | ||
| 903 | }; | ||
| 904 | |||
| 905 | static const struct net_device_ops w90p910_ether_netdev_ops = { | ||
| 906 | .ndo_open = w90p910_ether_open, | ||
| 907 | .ndo_stop = w90p910_ether_close, | ||
| 908 | .ndo_start_xmit = w90p910_ether_start_xmit, | ||
| 909 | .ndo_get_stats = w90p910_ether_stats, | ||
| 910 | .ndo_set_multicast_list = w90p910_ether_set_multicast_list, | ||
| 911 | .ndo_set_mac_address = set_mac_address, | ||
| 912 | .ndo_do_ioctl = w90p910_ether_ioctl, | ||
| 913 | .ndo_validate_addr = eth_validate_addr, | ||
| 914 | .ndo_change_mtu = eth_change_mtu, | ||
| 915 | }; | ||
| 916 | |||
| 917 | static void __init get_mac_address(struct net_device *dev) | ||
| 918 | { | ||
| 919 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 920 | struct platform_device *pdev; | ||
| 921 | char addr[6]; | ||
| 922 | |||
| 923 | pdev = ether->pdev; | ||
| 924 | |||
| 925 | addr[0] = 0x00; | ||
| 926 | addr[1] = 0x02; | ||
| 927 | addr[2] = 0xac; | ||
| 928 | addr[3] = 0x55; | ||
| 929 | addr[4] = 0x88; | ||
| 930 | addr[5] = 0xa8; | ||
| 931 | |||
| 932 | if (is_valid_ether_addr(addr)) | ||
| 933 | memcpy(dev->dev_addr, &addr, 0x06); | ||
| 934 | else | ||
| 935 | dev_err(&pdev->dev, "invalid mac address\n"); | ||
| 936 | } | ||
| 937 | |||
| 938 | static int w90p910_ether_setup(struct net_device *dev) | ||
| 939 | { | ||
| 940 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 941 | |||
| 942 | ether_setup(dev); | ||
| 943 | dev->netdev_ops = &w90p910_ether_netdev_ops; | ||
| 944 | dev->ethtool_ops = &w90p910_ether_ethtool_ops; | ||
| 945 | |||
| 946 | dev->tx_queue_len = 16; | ||
| 947 | dev->dma = 0x0; | ||
| 948 | dev->watchdog_timeo = TX_TIMEOUT; | ||
| 949 | |||
| 950 | get_mac_address(dev); | ||
| 951 | |||
| 952 | spin_lock_init(ðer->lock); | ||
| 953 | |||
| 954 | ether->cur_tx = 0x0; | ||
| 955 | ether->cur_rx = 0x0; | ||
| 956 | ether->finish_tx = 0x0; | ||
| 957 | ether->linkflag = 0x0; | ||
| 958 | ether->mii.phy_id = 0x01; | ||
| 959 | ether->mii.phy_id_mask = 0x1f; | ||
| 960 | ether->mii.reg_num_mask = 0x1f; | ||
| 961 | ether->mii.dev = dev; | ||
| 962 | ether->mii.mdio_read = w90p910_mdio_read; | ||
| 963 | ether->mii.mdio_write = w90p910_mdio_write; | ||
| 964 | |||
| 965 | setup_timer(ðer->check_timer, w90p910_check_link, | ||
| 966 | (unsigned long)dev); | ||
| 967 | |||
| 968 | return 0; | ||
| 969 | } | ||
| 970 | |||
| 971 | static int __devinit w90p910_ether_probe(struct platform_device *pdev) | ||
| 972 | { | ||
| 973 | struct w90p910_ether *ether; | ||
| 974 | struct net_device *dev; | ||
| 975 | struct resource *res; | ||
| 976 | int error; | ||
| 977 | |||
| 978 | dev = alloc_etherdev(sizeof(struct w90p910_ether)); | ||
| 979 | if (!dev) | ||
| 980 | return -ENOMEM; | ||
| 981 | |||
| 982 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | ||
| 983 | if (res == NULL) { | ||
| 984 | dev_err(&pdev->dev, "failed to get I/O memory\n"); | ||
| 985 | error = -ENXIO; | ||
| 986 | goto failed_free; | ||
| 987 | } | ||
| 988 | |||
| 989 | res = request_mem_region(res->start, resource_size(res), pdev->name); | ||
| 990 | if (res == NULL) { | ||
| 991 | dev_err(&pdev->dev, "failed to request I/O memory\n"); | ||
| 992 | error = -EBUSY; | ||
| 993 | goto failed_free; | ||
| 994 | } | ||
| 995 | |||
| 996 | ether = netdev_priv(dev); | ||
| 997 | |||
| 998 | ether->reg = ioremap(res->start, resource_size(res)); | ||
| 999 | if (ether->reg == NULL) { | ||
| 1000 | dev_err(&pdev->dev, "failed to remap I/O memory\n"); | ||
| 1001 | error = -ENXIO; | ||
| 1002 | goto failed_free_mem; | ||
| 1003 | } | ||
| 1004 | |||
| 1005 | ether->txirq = platform_get_irq(pdev, 0); | ||
| 1006 | if (ether->txirq < 0) { | ||
| 1007 | dev_err(&pdev->dev, "failed to get ether tx irq\n"); | ||
| 1008 | error = -ENXIO; | ||
| 1009 | goto failed_free_io; | ||
| 1010 | } | ||
| 1011 | |||
| 1012 | ether->rxirq = platform_get_irq(pdev, 1); | ||
| 1013 | if (ether->rxirq < 0) { | ||
| 1014 | dev_err(&pdev->dev, "failed to get ether rx irq\n"); | ||
| 1015 | error = -ENXIO; | ||
| 1016 | goto failed_free_txirq; | ||
| 1017 | } | ||
| 1018 | |||
| 1019 | platform_set_drvdata(pdev, dev); | ||
| 1020 | |||
| 1021 | ether->clk = clk_get(&pdev->dev, NULL); | ||
| 1022 | if (IS_ERR(ether->clk)) { | ||
| 1023 | dev_err(&pdev->dev, "failed to get ether clock\n"); | ||
| 1024 | error = PTR_ERR(ether->clk); | ||
| 1025 | goto failed_free_rxirq; | ||
| 1026 | } | ||
| 1027 | |||
| 1028 | ether->rmiiclk = clk_get(&pdev->dev, "RMII"); | ||
| 1029 | if (IS_ERR(ether->rmiiclk)) { | ||
| 1030 | dev_err(&pdev->dev, "failed to get ether clock\n"); | ||
| 1031 | error = PTR_ERR(ether->rmiiclk); | ||
| 1032 | goto failed_put_clk; | ||
| 1033 | } | ||
| 1034 | |||
| 1035 | ether->pdev = pdev; | ||
| 1036 | |||
| 1037 | w90p910_ether_setup(dev); | ||
| 1038 | |||
| 1039 | error = register_netdev(dev); | ||
| 1040 | if (error != 0) { | ||
| 1041 | dev_err(&pdev->dev, "Regiter EMC w90p910 FAILED\n"); | ||
| 1042 | error = -ENODEV; | ||
| 1043 | goto failed_put_rmiiclk; | ||
| 1044 | } | ||
| 1045 | |||
| 1046 | return 0; | ||
| 1047 | failed_put_rmiiclk: | ||
| 1048 | clk_put(ether->rmiiclk); | ||
| 1049 | failed_put_clk: | ||
| 1050 | clk_put(ether->clk); | ||
| 1051 | failed_free_rxirq: | ||
| 1052 | free_irq(ether->rxirq, pdev); | ||
| 1053 | platform_set_drvdata(pdev, NULL); | ||
| 1054 | failed_free_txirq: | ||
| 1055 | free_irq(ether->txirq, pdev); | ||
| 1056 | failed_free_io: | ||
| 1057 | iounmap(ether->reg); | ||
| 1058 | failed_free_mem: | ||
| 1059 | release_mem_region(res->start, resource_size(res)); | ||
| 1060 | failed_free: | ||
| 1061 | free_netdev(dev); | ||
| 1062 | return error; | ||
| 1063 | } | ||
| 1064 | |||
| 1065 | static int __devexit w90p910_ether_remove(struct platform_device *pdev) | ||
| 1066 | { | ||
| 1067 | struct net_device *dev = platform_get_drvdata(pdev); | ||
| 1068 | struct w90p910_ether *ether = netdev_priv(dev); | ||
| 1069 | |||
| 1070 | unregister_netdev(dev); | ||
| 1071 | clk_put(ether->rmiiclk); | ||
| 1072 | clk_put(ether->clk); | ||
| 1073 | del_timer_sync(ðer->check_timer); | ||
| 1074 | platform_set_drvdata(pdev, NULL); | ||
| 1075 | free_netdev(dev); | ||
| 1076 | return 0; | ||
| 1077 | } | ||
| 1078 | |||
| 1079 | static struct platform_driver w90p910_ether_driver = { | ||
| 1080 | .probe = w90p910_ether_probe, | ||
| 1081 | .remove = __devexit_p(w90p910_ether_remove), | ||
| 1082 | .driver = { | ||
| 1083 | .name = "nuc900-emc", | ||
| 1084 | .owner = THIS_MODULE, | ||
| 1085 | }, | ||
| 1086 | }; | ||
| 1087 | |||
| 1088 | static int __init w90p910_ether_init(void) | ||
| 1089 | { | ||
| 1090 | return platform_driver_register(&w90p910_ether_driver); | ||
| 1091 | } | ||
| 1092 | |||
| 1093 | static void __exit w90p910_ether_exit(void) | ||
| 1094 | { | ||
| 1095 | platform_driver_unregister(&w90p910_ether_driver); | ||
| 1096 | } | ||
| 1097 | |||
| 1098 | module_init(w90p910_ether_init); | ||
| 1099 | module_exit(w90p910_ether_exit); | ||
| 1100 | |||
| 1101 | MODULE_AUTHOR("Wan ZongShun <mcuos.com@gmail.com>"); | ||
| 1102 | MODULE_DESCRIPTION("w90p910 MAC driver!"); | ||
| 1103 | MODULE_LICENSE("GPL"); | ||
| 1104 | MODULE_ALIAS("platform:nuc900-emc"); | ||
| 1105 | |||
diff --git a/drivers/net/at1700.c b/drivers/net/at1700.c index 18b566ad4fd1..cf30e278f182 100644 --- a/drivers/net/at1700.c +++ b/drivers/net/at1700.c | |||
| @@ -318,7 +318,7 @@ static int __init at1700_probe1(struct net_device *dev, int ioaddr) | |||
| 318 | pos3 = mca_read_stored_pos( slot, 3 ); | 318 | pos3 = mca_read_stored_pos( slot, 3 ); |
| 319 | pos4 = mca_read_stored_pos( slot, 4 ); | 319 | pos4 = mca_read_stored_pos( slot, 4 ); |
| 320 | 320 | ||
| 321 | for (l_i = 0; l_i < 0x09; l_i++) | 321 | for (l_i = 0; l_i < 8; l_i++) |
| 322 | if (( pos3 & 0x07) == at1700_ioaddr_pattern[l_i]) | 322 | if (( pos3 & 0x07) == at1700_ioaddr_pattern[l_i]) |
| 323 | break; | 323 | break; |
| 324 | ioaddr = at1700_mca_probe_list[l_i]; | 324 | ioaddr = at1700_mca_probe_list[l_i]; |
diff --git a/drivers/net/atl1c/atl1c.h b/drivers/net/atl1c/atl1c.h index e1658ef3fcdf..2a1120ad2e74 100644 --- a/drivers/net/atl1c/atl1c.h +++ b/drivers/net/atl1c/atl1c.h | |||
| @@ -188,14 +188,14 @@ struct atl1c_tpd_ext_desc { | |||
| 188 | #define RRS_HDS_TYPE_DATA 2 | 188 | #define RRS_HDS_TYPE_DATA 2 |
| 189 | 189 | ||
| 190 | #define RRS_IS_NO_HDS_TYPE(flag) \ | 190 | #define RRS_IS_NO_HDS_TYPE(flag) \ |
| 191 | (((flag) >> (RRS_HDS_TYPE_SHIFT)) & RRS_HDS_TYPE_MASK == 0) | 191 | ((((flag) >> (RRS_HDS_TYPE_SHIFT)) & RRS_HDS_TYPE_MASK) == 0) |
| 192 | 192 | ||
| 193 | #define RRS_IS_HDS_HEAD(flag) \ | 193 | #define RRS_IS_HDS_HEAD(flag) \ |
| 194 | (((flag) >> (RRS_HDS_TYPE_SHIFT)) & RRS_HDS_TYPE_MASK == \ | 194 | ((((flag) >> (RRS_HDS_TYPE_SHIFT)) & RRS_HDS_TYPE_MASK) == \ |
| 195 | RRS_HDS_TYPE_HEAD) | 195 | RRS_HDS_TYPE_HEAD) |
| 196 | 196 | ||
| 197 | #define RRS_IS_HDS_DATA(flag) \ | 197 | #define RRS_IS_HDS_DATA(flag) \ |
| 198 | (((flag) >> (RRS_HDS_TYPE_SHIFT)) & RRS_HDS_TYPE_MASK == \ | 198 | ((((flag) >> (RRS_HDS_TYPE_SHIFT)) & RRS_HDS_TYPE_MASK) == \ |
| 199 | RRS_HDS_TYPE_DATA) | 199 | RRS_HDS_TYPE_DATA) |
| 200 | 200 | ||
| 201 | /* rrs word 3 bit 0:31 */ | 201 | /* rrs word 3 bit 0:31 */ |
| @@ -245,7 +245,7 @@ struct atl1c_tpd_ext_desc { | |||
| 245 | #define RRS_PACKET_TYPE_802_3 1 | 245 | #define RRS_PACKET_TYPE_802_3 1 |
| 246 | #define RRS_PACKET_TYPE_ETH 0 | 246 | #define RRS_PACKET_TYPE_ETH 0 |
| 247 | #define RRS_PACKET_IS_ETH(word) \ | 247 | #define RRS_PACKET_IS_ETH(word) \ |
| 248 | (((word) >> RRS_PACKET_TYPE_SHIFT) & RRS_PACKET_TYPE_MASK == \ | 248 | ((((word) >> RRS_PACKET_TYPE_SHIFT) & RRS_PACKET_TYPE_MASK) == \ |
| 249 | RRS_PACKET_TYPE_ETH) | 249 | RRS_PACKET_TYPE_ETH) |
| 250 | #define RRS_RXD_IS_VALID(word) \ | 250 | #define RRS_RXD_IS_VALID(word) \ |
| 251 | ((((word) >> RRS_RXD_UPDATED_SHIFT) & RRS_RXD_UPDATED_MASK) == 1) | 251 | ((((word) >> RRS_RXD_UPDATED_SHIFT) & RRS_RXD_UPDATED_MASK) == 1) |
diff --git a/drivers/net/atl1c/atl1c_ethtool.c b/drivers/net/atl1c/atl1c_ethtool.c index 607007d75b6f..00d11b480af3 100644 --- a/drivers/net/atl1c/atl1c_ethtool.c +++ b/drivers/net/atl1c/atl1c_ethtool.c | |||
| @@ -232,11 +232,11 @@ static void atl1c_get_drvinfo(struct net_device *netdev, | |||
| 232 | { | 232 | { |
| 233 | struct atl1c_adapter *adapter = netdev_priv(netdev); | 233 | struct atl1c_adapter *adapter = netdev_priv(netdev); |
| 234 | 234 | ||
| 235 | strncpy(drvinfo->driver, atl1c_driver_name, sizeof(drvinfo->driver)); | 235 | strlcpy(drvinfo->driver, atl1c_driver_name, sizeof(drvinfo->driver)); |
| 236 | strncpy(drvinfo->version, atl1c_driver_version, | 236 | strlcpy(drvinfo->version, atl1c_driver_version, |
| 237 | sizeof(drvinfo->version)); | 237 | sizeof(drvinfo->version)); |
| 238 | strncpy(drvinfo->fw_version, "N/A", sizeof(drvinfo->fw_version)); | 238 | strlcpy(drvinfo->fw_version, "N/A", sizeof(drvinfo->fw_version)); |
| 239 | strncpy(drvinfo->bus_info, pci_name(adapter->pdev), | 239 | strlcpy(drvinfo->bus_info, pci_name(adapter->pdev), |
| 240 | sizeof(drvinfo->bus_info)); | 240 | sizeof(drvinfo->bus_info)); |
| 241 | drvinfo->n_stats = 0; | 241 | drvinfo->n_stats = 0; |
| 242 | drvinfo->testinfo_len = 0; | 242 | drvinfo->testinfo_len = 0; |
diff --git a/drivers/net/atl1c/atl1c_main.c b/drivers/net/atl1c/atl1c_main.c index cd547a205fb9..a383122679de 100644 --- a/drivers/net/atl1c/atl1c_main.c +++ b/drivers/net/atl1c/atl1c_main.c | |||
| @@ -1689,7 +1689,7 @@ static void atl1c_clean_rx_irq(struct atl1c_adapter *adapter, u8 que, | |||
| 1689 | if (likely(RRS_RXD_IS_VALID(rrs->word3))) { | 1689 | if (likely(RRS_RXD_IS_VALID(rrs->word3))) { |
| 1690 | rfd_num = (rrs->word0 >> RRS_RX_RFD_CNT_SHIFT) & | 1690 | rfd_num = (rrs->word0 >> RRS_RX_RFD_CNT_SHIFT) & |
| 1691 | RRS_RX_RFD_CNT_MASK; | 1691 | RRS_RX_RFD_CNT_MASK; |
| 1692 | if (unlikely(rfd_num) != 1) | 1692 | if (unlikely(rfd_num != 1)) |
| 1693 | /* TODO support mul rfd*/ | 1693 | /* TODO support mul rfd*/ |
| 1694 | if (netif_msg_rx_err(adapter)) | 1694 | if (netif_msg_rx_err(adapter)) |
| 1695 | dev_warn(&pdev->dev, | 1695 | dev_warn(&pdev->dev, |
diff --git a/drivers/net/atlx/atl1.c b/drivers/net/atlx/atl1.c index 94d7325caf4f..8bca12f71390 100644 --- a/drivers/net/atlx/atl1.c +++ b/drivers/net/atlx/atl1.c | |||
| @@ -3378,11 +3378,11 @@ static void atl1_get_drvinfo(struct net_device *netdev, | |||
| 3378 | { | 3378 | { |
| 3379 | struct atl1_adapter *adapter = netdev_priv(netdev); | 3379 | struct atl1_adapter *adapter = netdev_priv(netdev); |
| 3380 | 3380 | ||
| 3381 | strncpy(drvinfo->driver, ATLX_DRIVER_NAME, sizeof(drvinfo->driver)); | 3381 | strlcpy(drvinfo->driver, ATLX_DRIVER_NAME, sizeof(drvinfo->driver)); |
| 3382 | strncpy(drvinfo->version, ATLX_DRIVER_VERSION, | 3382 | strlcpy(drvinfo->version, ATLX_DRIVER_VERSION, |
| 3383 | sizeof(drvinfo->version)); | 3383 | sizeof(drvinfo->version)); |
| 3384 | strncpy(drvinfo->fw_version, "N/A", sizeof(drvinfo->fw_version)); | 3384 | strlcpy(drvinfo->fw_version, "N/A", sizeof(drvinfo->fw_version)); |
| 3385 | strncpy(drvinfo->bus_info, pci_name(adapter->pdev), | 3385 | strlcpy(drvinfo->bus_info, pci_name(adapter->pdev), |
| 3386 | sizeof(drvinfo->bus_info)); | 3386 | sizeof(drvinfo->bus_info)); |
| 3387 | drvinfo->eedump_len = ATL1_EEDUMP_LEN; | 3387 | drvinfo->eedump_len = ATL1_EEDUMP_LEN; |
| 3388 | } | 3388 | } |
diff --git a/drivers/net/b44.c b/drivers/net/b44.c index 36d4d377ec2f..bafca672ea7d 100644 --- a/drivers/net/b44.c +++ b/drivers/net/b44.c | |||
| @@ -952,9 +952,10 @@ static int b44_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 952 | int rc = NETDEV_TX_OK; | 952 | int rc = NETDEV_TX_OK; |
| 953 | dma_addr_t mapping; | 953 | dma_addr_t mapping; |
| 954 | u32 len, entry, ctrl; | 954 | u32 len, entry, ctrl; |
| 955 | unsigned long flags; | ||
| 955 | 956 | ||
| 956 | len = skb->len; | 957 | len = skb->len; |
| 957 | spin_lock_irq(&bp->lock); | 958 | spin_lock_irqsave(&bp->lock, flags); |
| 958 | 959 | ||
| 959 | /* This is a hard error, log it. */ | 960 | /* This is a hard error, log it. */ |
| 960 | if (unlikely(TX_BUFFS_AVAIL(bp) < 1)) { | 961 | if (unlikely(TX_BUFFS_AVAIL(bp) < 1)) { |
| @@ -1027,7 +1028,7 @@ static int b44_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 1027 | dev->trans_start = jiffies; | 1028 | dev->trans_start = jiffies; |
| 1028 | 1029 | ||
| 1029 | out_unlock: | 1030 | out_unlock: |
| 1030 | spin_unlock_irq(&bp->lock); | 1031 | spin_unlock_irqrestore(&bp->lock, flags); |
| 1031 | 1032 | ||
| 1032 | return rc; | 1033 | return rc; |
| 1033 | 1034 | ||
diff --git a/drivers/net/benet/be_main.c b/drivers/net/benet/be_main.c index c43f6a119295..dea3155688bb 100644 --- a/drivers/net/benet/be_main.c +++ b/drivers/net/benet/be_main.c | |||
| @@ -667,7 +667,7 @@ static void skb_fill_rx_data(struct be_adapter *adapter, | |||
| 667 | struct be_queue_info *rxq = &adapter->rx_obj.q; | 667 | struct be_queue_info *rxq = &adapter->rx_obj.q; |
| 668 | struct be_rx_page_info *page_info; | 668 | struct be_rx_page_info *page_info; |
| 669 | u16 rxq_idx, i, num_rcvd, j; | 669 | u16 rxq_idx, i, num_rcvd, j; |
| 670 | u32 pktsize, hdr_len, curr_frag_len; | 670 | u32 pktsize, hdr_len, curr_frag_len, size; |
| 671 | u8 *start; | 671 | u8 *start; |
| 672 | 672 | ||
| 673 | rxq_idx = AMAP_GET_BITS(struct amap_eth_rx_compl, fragndx, rxcp); | 673 | rxq_idx = AMAP_GET_BITS(struct amap_eth_rx_compl, fragndx, rxcp); |
| @@ -708,12 +708,13 @@ static void skb_fill_rx_data(struct be_adapter *adapter, | |||
| 708 | } | 708 | } |
| 709 | 709 | ||
| 710 | /* More frags present for this completion */ | 710 | /* More frags present for this completion */ |
| 711 | pktsize -= curr_frag_len; /* account for above copied frag */ | 711 | size = pktsize; |
| 712 | for (i = 1, j = 0; i < num_rcvd; i++) { | 712 | for (i = 1, j = 0; i < num_rcvd; i++) { |
| 713 | size -= curr_frag_len; | ||
| 713 | index_inc(&rxq_idx, rxq->len); | 714 | index_inc(&rxq_idx, rxq->len); |
| 714 | page_info = get_rx_page_info(adapter, rxq_idx); | 715 | page_info = get_rx_page_info(adapter, rxq_idx); |
| 715 | 716 | ||
| 716 | curr_frag_len = min(pktsize, rx_frag_size); | 717 | curr_frag_len = min(size, rx_frag_size); |
| 717 | 718 | ||
| 718 | /* Coalesce all frags from the same physical page in one slot */ | 719 | /* Coalesce all frags from the same physical page in one slot */ |
| 719 | if (page_info->page_offset == 0) { | 720 | if (page_info->page_offset == 0) { |
| @@ -731,7 +732,6 @@ static void skb_fill_rx_data(struct be_adapter *adapter, | |||
| 731 | skb_shinfo(skb)->frags[j].size += curr_frag_len; | 732 | skb_shinfo(skb)->frags[j].size += curr_frag_len; |
| 732 | skb->len += curr_frag_len; | 733 | skb->len += curr_frag_len; |
| 733 | skb->data_len += curr_frag_len; | 734 | skb->data_len += curr_frag_len; |
| 734 | pktsize -= curr_frag_len; | ||
| 735 | 735 | ||
| 736 | memset(page_info, 0, sizeof(*page_info)); | 736 | memset(page_info, 0, sizeof(*page_info)); |
| 737 | } | 737 | } |
diff --git a/drivers/net/bnx2.c b/drivers/net/bnx2.c index b70cc99962fc..06b901152d44 100644 --- a/drivers/net/bnx2.c +++ b/drivers/net/bnx2.c | |||
| @@ -399,9 +399,11 @@ static int bnx2_unregister_cnic(struct net_device *dev) | |||
| 399 | struct bnx2_napi *bnapi = &bp->bnx2_napi[0]; | 399 | struct bnx2_napi *bnapi = &bp->bnx2_napi[0]; |
| 400 | struct cnic_eth_dev *cp = &bp->cnic_eth_dev; | 400 | struct cnic_eth_dev *cp = &bp->cnic_eth_dev; |
| 401 | 401 | ||
| 402 | mutex_lock(&bp->cnic_lock); | ||
| 402 | cp->drv_state = 0; | 403 | cp->drv_state = 0; |
| 403 | bnapi->cnic_present = 0; | 404 | bnapi->cnic_present = 0; |
| 404 | rcu_assign_pointer(bp->cnic_ops, NULL); | 405 | rcu_assign_pointer(bp->cnic_ops, NULL); |
| 406 | mutex_unlock(&bp->cnic_lock); | ||
| 405 | synchronize_rcu(); | 407 | synchronize_rcu(); |
| 406 | return 0; | 408 | return 0; |
| 407 | } | 409 | } |
| @@ -429,13 +431,13 @@ bnx2_cnic_stop(struct bnx2 *bp) | |||
| 429 | struct cnic_ops *c_ops; | 431 | struct cnic_ops *c_ops; |
| 430 | struct cnic_ctl_info info; | 432 | struct cnic_ctl_info info; |
| 431 | 433 | ||
| 432 | rcu_read_lock(); | 434 | mutex_lock(&bp->cnic_lock); |
| 433 | c_ops = rcu_dereference(bp->cnic_ops); | 435 | c_ops = bp->cnic_ops; |
| 434 | if (c_ops) { | 436 | if (c_ops) { |
| 435 | info.cmd = CNIC_CTL_STOP_CMD; | 437 | info.cmd = CNIC_CTL_STOP_CMD; |
| 436 | c_ops->cnic_ctl(bp->cnic_data, &info); | 438 | c_ops->cnic_ctl(bp->cnic_data, &info); |
| 437 | } | 439 | } |
| 438 | rcu_read_unlock(); | 440 | mutex_unlock(&bp->cnic_lock); |
| 439 | } | 441 | } |
| 440 | 442 | ||
| 441 | static void | 443 | static void |
| @@ -444,8 +446,8 @@ bnx2_cnic_start(struct bnx2 *bp) | |||
| 444 | struct cnic_ops *c_ops; | 446 | struct cnic_ops *c_ops; |
| 445 | struct cnic_ctl_info info; | 447 | struct cnic_ctl_info info; |
| 446 | 448 | ||
| 447 | rcu_read_lock(); | 449 | mutex_lock(&bp->cnic_lock); |
| 448 | c_ops = rcu_dereference(bp->cnic_ops); | 450 | c_ops = bp->cnic_ops; |
| 449 | if (c_ops) { | 451 | if (c_ops) { |
| 450 | if (!(bp->flags & BNX2_FLAG_USING_MSIX)) { | 452 | if (!(bp->flags & BNX2_FLAG_USING_MSIX)) { |
| 451 | struct bnx2_napi *bnapi = &bp->bnx2_napi[0]; | 453 | struct bnx2_napi *bnapi = &bp->bnx2_napi[0]; |
| @@ -455,7 +457,7 @@ bnx2_cnic_start(struct bnx2 *bp) | |||
| 455 | info.cmd = CNIC_CTL_START_CMD; | 457 | info.cmd = CNIC_CTL_START_CMD; |
| 456 | c_ops->cnic_ctl(bp->cnic_data, &info); | 458 | c_ops->cnic_ctl(bp->cnic_data, &info); |
| 457 | } | 459 | } |
| 458 | rcu_read_unlock(); | 460 | mutex_unlock(&bp->cnic_lock); |
| 459 | } | 461 | } |
| 460 | 462 | ||
| 461 | #else | 463 | #else |
| @@ -7663,6 +7665,9 @@ bnx2_init_board(struct pci_dev *pdev, struct net_device *dev) | |||
| 7663 | 7665 | ||
| 7664 | spin_lock_init(&bp->phy_lock); | 7666 | spin_lock_init(&bp->phy_lock); |
| 7665 | spin_lock_init(&bp->indirect_lock); | 7667 | spin_lock_init(&bp->indirect_lock); |
| 7668 | #ifdef BCM_CNIC | ||
| 7669 | mutex_init(&bp->cnic_lock); | ||
| 7670 | #endif | ||
| 7666 | INIT_WORK(&bp->reset_task, bnx2_reset_task); | 7671 | INIT_WORK(&bp->reset_task, bnx2_reset_task); |
| 7667 | 7672 | ||
| 7668 | dev->base_addr = dev->mem_start = pci_resource_start(pdev, 0); | 7673 | dev->base_addr = dev->mem_start = pci_resource_start(pdev, 0); |
diff --git a/drivers/net/bnx2.h b/drivers/net/bnx2.h index f1edfaa9e56a..a4f12fd0ecd2 100644 --- a/drivers/net/bnx2.h +++ b/drivers/net/bnx2.h | |||
| @@ -6902,6 +6902,7 @@ struct bnx2 { | |||
| 6902 | u32 idle_chk_status_idx; | 6902 | u32 idle_chk_status_idx; |
| 6903 | 6903 | ||
| 6904 | #ifdef BCM_CNIC | 6904 | #ifdef BCM_CNIC |
| 6905 | struct mutex cnic_lock; | ||
| 6905 | struct cnic_eth_dev cnic_eth_dev; | 6906 | struct cnic_eth_dev cnic_eth_dev; |
| 6906 | #endif | 6907 | #endif |
| 6907 | 6908 | ||
diff --git a/drivers/net/bnx2x_link.c b/drivers/net/bnx2x_link.c index ed648acef7cf..2ee581a2cdec 100644 --- a/drivers/net/bnx2x_link.c +++ b/drivers/net/bnx2x_link.c | |||
| @@ -4212,13 +4212,14 @@ static void bnx2x_turn_off_sf(struct bnx2x *bp, u8 port) | |||
| 4212 | u8 bnx2x_get_ext_phy_fw_version(struct link_params *params, u8 driver_loaded, | 4212 | u8 bnx2x_get_ext_phy_fw_version(struct link_params *params, u8 driver_loaded, |
| 4213 | u8 *version, u16 len) | 4213 | u8 *version, u16 len) |
| 4214 | { | 4214 | { |
| 4215 | struct bnx2x *bp = params->bp; | 4215 | struct bnx2x *bp; |
| 4216 | u32 ext_phy_type = 0; | 4216 | u32 ext_phy_type = 0; |
| 4217 | u32 spirom_ver = 0; | 4217 | u32 spirom_ver = 0; |
| 4218 | u8 status = 0 ; | 4218 | u8 status = 0 ; |
| 4219 | 4219 | ||
| 4220 | if (version == NULL || params == NULL) | 4220 | if (version == NULL || params == NULL) |
| 4221 | return -EINVAL; | 4221 | return -EINVAL; |
| 4222 | bp = params->bp; | ||
| 4222 | 4223 | ||
| 4223 | spirom_ver = REG_RD(bp, params->shmem_base + | 4224 | spirom_ver = REG_RD(bp, params->shmem_base + |
| 4224 | offsetof(struct shmem_region, | 4225 | offsetof(struct shmem_region, |
diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c index d927f71af8a3..aa1be1feceed 100644 --- a/drivers/net/bonding/bond_main.c +++ b/drivers/net/bonding/bond_main.c | |||
| @@ -1459,8 +1459,16 @@ int bond_enslave(struct net_device *bond_dev, struct net_device *slave_dev) | |||
| 1459 | * ether type (eg ARPHRD_ETHER and ARPHRD_INFINIBAND) share the same bond | 1459 | * ether type (eg ARPHRD_ETHER and ARPHRD_INFINIBAND) share the same bond |
| 1460 | */ | 1460 | */ |
| 1461 | if (bond->slave_cnt == 0) { | 1461 | if (bond->slave_cnt == 0) { |
| 1462 | if (slave_dev->type != ARPHRD_ETHER) | 1462 | if (bond_dev->type != slave_dev->type) { |
| 1463 | bond_setup_by_slave(bond_dev, slave_dev); | 1463 | dev_close(bond_dev); |
| 1464 | pr_debug("%s: change device type from %d to %d\n", | ||
| 1465 | bond_dev->name, bond_dev->type, slave_dev->type); | ||
| 1466 | if (slave_dev->type != ARPHRD_ETHER) | ||
| 1467 | bond_setup_by_slave(bond_dev, slave_dev); | ||
| 1468 | else | ||
| 1469 | ether_setup(bond_dev); | ||
| 1470 | dev_open(bond_dev); | ||
| 1471 | } | ||
| 1464 | } else if (bond_dev->type != slave_dev->type) { | 1472 | } else if (bond_dev->type != slave_dev->type) { |
| 1465 | pr_err(DRV_NAME ": %s ether type (%d) is different " | 1473 | pr_err(DRV_NAME ": %s ether type (%d) is different " |
| 1466 | "from other slaves (%d), can not enslave it.\n", | 1474 | "from other slaves (%d), can not enslave it.\n", |
diff --git a/drivers/net/can/dev.c b/drivers/net/can/dev.c index 574daddc21bf..e1a4f8214239 100644 --- a/drivers/net/can/dev.c +++ b/drivers/net/can/dev.c | |||
| @@ -346,7 +346,7 @@ void can_restart(unsigned long data) | |||
| 346 | skb = dev_alloc_skb(sizeof(struct can_frame)); | 346 | skb = dev_alloc_skb(sizeof(struct can_frame)); |
| 347 | if (skb == NULL) { | 347 | if (skb == NULL) { |
| 348 | err = -ENOMEM; | 348 | err = -ENOMEM; |
| 349 | goto out; | 349 | goto restart; |
| 350 | } | 350 | } |
| 351 | skb->dev = dev; | 351 | skb->dev = dev; |
| 352 | skb->protocol = htons(ETH_P_CAN); | 352 | skb->protocol = htons(ETH_P_CAN); |
| @@ -361,13 +361,13 @@ void can_restart(unsigned long data) | |||
| 361 | stats->rx_packets++; | 361 | stats->rx_packets++; |
| 362 | stats->rx_bytes += cf->can_dlc; | 362 | stats->rx_bytes += cf->can_dlc; |
| 363 | 363 | ||
| 364 | restart: | ||
| 364 | dev_dbg(dev->dev.parent, "restarted\n"); | 365 | dev_dbg(dev->dev.parent, "restarted\n"); |
| 365 | priv->can_stats.restarts++; | 366 | priv->can_stats.restarts++; |
| 366 | 367 | ||
| 367 | /* Now restart the device */ | 368 | /* Now restart the device */ |
| 368 | err = priv->do_set_mode(dev, CAN_MODE_START); | 369 | err = priv->do_set_mode(dev, CAN_MODE_START); |
| 369 | 370 | ||
| 370 | out: | ||
| 371 | netif_carrier_on(dev); | 371 | netif_carrier_on(dev); |
| 372 | if (err) | 372 | if (err) |
| 373 | dev_err(dev->dev.parent, "Error %d during restart", err); | 373 | dev_err(dev->dev.parent, "Error %d during restart", err); |
| @@ -473,6 +473,10 @@ int open_candev(struct net_device *dev) | |||
| 473 | return -EINVAL; | 473 | return -EINVAL; |
| 474 | } | 474 | } |
| 475 | 475 | ||
| 476 | /* Switch carrier on if device was stopped while in bus-off state */ | ||
| 477 | if (!netif_carrier_ok(dev)) | ||
| 478 | netif_carrier_on(dev); | ||
| 479 | |||
| 476 | setup_timer(&priv->restart_timer, can_restart, (unsigned long)dev); | 480 | setup_timer(&priv->restart_timer, can_restart, (unsigned long)dev); |
| 477 | 481 | ||
| 478 | return 0; | 482 | return 0; |
| @@ -607,11 +611,18 @@ nla_put_failure: | |||
| 607 | return -EMSGSIZE; | 611 | return -EMSGSIZE; |
| 608 | } | 612 | } |
| 609 | 613 | ||
| 614 | static int can_newlink(struct net_device *dev, | ||
| 615 | struct nlattr *tb[], struct nlattr *data[]) | ||
| 616 | { | ||
| 617 | return -EOPNOTSUPP; | ||
| 618 | } | ||
| 619 | |||
| 610 | static struct rtnl_link_ops can_link_ops __read_mostly = { | 620 | static struct rtnl_link_ops can_link_ops __read_mostly = { |
| 611 | .kind = "can", | 621 | .kind = "can", |
| 612 | .maxtype = IFLA_CAN_MAX, | 622 | .maxtype = IFLA_CAN_MAX, |
| 613 | .policy = can_policy, | 623 | .policy = can_policy, |
| 614 | .setup = can_setup, | 624 | .setup = can_setup, |
| 625 | .newlink = can_newlink, | ||
| 615 | .changelink = can_changelink, | 626 | .changelink = can_changelink, |
| 616 | .fill_info = can_fill_info, | 627 | .fill_info = can_fill_info, |
| 617 | .fill_xstats = can_fill_xstats, | 628 | .fill_xstats = can_fill_xstats, |
diff --git a/drivers/net/can/sja1000/sja1000.c b/drivers/net/can/sja1000/sja1000.c index 571f133a8fec..08ebee79d8a6 100644 --- a/drivers/net/can/sja1000/sja1000.c +++ b/drivers/net/can/sja1000/sja1000.c | |||
| @@ -63,7 +63,6 @@ | |||
| 63 | #include <linux/can.h> | 63 | #include <linux/can.h> |
| 64 | #include <linux/can/dev.h> | 64 | #include <linux/can/dev.h> |
| 65 | #include <linux/can/error.h> | 65 | #include <linux/can/error.h> |
| 66 | #include <linux/can/dev.h> | ||
| 67 | 66 | ||
| 68 | #include "sja1000.h" | 67 | #include "sja1000.h" |
| 69 | 68 | ||
diff --git a/drivers/net/cnic.c b/drivers/net/cnic.c index 4d1515f45ba2..74c342959b7b 100644 --- a/drivers/net/cnic.c +++ b/drivers/net/cnic.c | |||
| @@ -138,6 +138,16 @@ static struct cnic_dev *cnic_from_netdev(struct net_device *netdev) | |||
| 138 | return NULL; | 138 | return NULL; |
| 139 | } | 139 | } |
| 140 | 140 | ||
| 141 | static inline void ulp_get(struct cnic_ulp_ops *ulp_ops) | ||
| 142 | { | ||
| 143 | atomic_inc(&ulp_ops->ref_count); | ||
| 144 | } | ||
| 145 | |||
| 146 | static inline void ulp_put(struct cnic_ulp_ops *ulp_ops) | ||
| 147 | { | ||
| 148 | atomic_dec(&ulp_ops->ref_count); | ||
| 149 | } | ||
| 150 | |||
| 141 | static void cnic_ctx_wr(struct cnic_dev *dev, u32 cid_addr, u32 off, u32 val) | 151 | static void cnic_ctx_wr(struct cnic_dev *dev, u32 cid_addr, u32 off, u32 val) |
| 142 | { | 152 | { |
| 143 | struct cnic_local *cp = dev->cnic_priv; | 153 | struct cnic_local *cp = dev->cnic_priv; |
| @@ -227,7 +237,7 @@ static int cnic_send_nlmsg(struct cnic_local *cp, u32 type, | |||
| 227 | } | 237 | } |
| 228 | 238 | ||
| 229 | rcu_read_lock(); | 239 | rcu_read_lock(); |
| 230 | ulp_ops = rcu_dereference(cp->ulp_ops[CNIC_ULP_ISCSI]); | 240 | ulp_ops = rcu_dereference(cnic_ulp_tbl[CNIC_ULP_ISCSI]); |
| 231 | if (ulp_ops) | 241 | if (ulp_ops) |
| 232 | ulp_ops->iscsi_nl_send_msg(cp->dev, msg_type, buf, len); | 242 | ulp_ops->iscsi_nl_send_msg(cp->dev, msg_type, buf, len); |
| 233 | rcu_read_unlock(); | 243 | rcu_read_unlock(); |
| @@ -319,6 +329,20 @@ static int cnic_abort_prep(struct cnic_sock *csk) | |||
| 319 | return 0; | 329 | return 0; |
| 320 | } | 330 | } |
| 321 | 331 | ||
| 332 | static void cnic_uio_stop(void) | ||
| 333 | { | ||
| 334 | struct cnic_dev *dev; | ||
| 335 | |||
| 336 | read_lock(&cnic_dev_lock); | ||
| 337 | list_for_each_entry(dev, &cnic_dev_list, list) { | ||
| 338 | struct cnic_local *cp = dev->cnic_priv; | ||
| 339 | |||
| 340 | if (cp->cnic_uinfo) | ||
| 341 | cnic_send_nlmsg(cp, ISCSI_KEVENT_IF_DOWN, NULL); | ||
| 342 | } | ||
| 343 | read_unlock(&cnic_dev_lock); | ||
| 344 | } | ||
| 345 | |||
| 322 | int cnic_register_driver(int ulp_type, struct cnic_ulp_ops *ulp_ops) | 346 | int cnic_register_driver(int ulp_type, struct cnic_ulp_ops *ulp_ops) |
| 323 | { | 347 | { |
| 324 | struct cnic_dev *dev; | 348 | struct cnic_dev *dev; |
| @@ -344,6 +368,7 @@ int cnic_register_driver(int ulp_type, struct cnic_ulp_ops *ulp_ops) | |||
| 344 | } | 368 | } |
| 345 | read_unlock(&cnic_dev_lock); | 369 | read_unlock(&cnic_dev_lock); |
| 346 | 370 | ||
| 371 | atomic_set(&ulp_ops->ref_count, 0); | ||
| 347 | rcu_assign_pointer(cnic_ulp_tbl[ulp_type], ulp_ops); | 372 | rcu_assign_pointer(cnic_ulp_tbl[ulp_type], ulp_ops); |
| 348 | mutex_unlock(&cnic_lock); | 373 | mutex_unlock(&cnic_lock); |
| 349 | 374 | ||
| @@ -365,6 +390,8 @@ int cnic_register_driver(int ulp_type, struct cnic_ulp_ops *ulp_ops) | |||
| 365 | int cnic_unregister_driver(int ulp_type) | 390 | int cnic_unregister_driver(int ulp_type) |
| 366 | { | 391 | { |
| 367 | struct cnic_dev *dev; | 392 | struct cnic_dev *dev; |
| 393 | struct cnic_ulp_ops *ulp_ops; | ||
| 394 | int i = 0; | ||
| 368 | 395 | ||
| 369 | if (ulp_type >= MAX_CNIC_ULP_TYPE) { | 396 | if (ulp_type >= MAX_CNIC_ULP_TYPE) { |
| 370 | printk(KERN_ERR PFX "cnic_unregister_driver: Bad type %d\n", | 397 | printk(KERN_ERR PFX "cnic_unregister_driver: Bad type %d\n", |
| @@ -372,7 +399,8 @@ int cnic_unregister_driver(int ulp_type) | |||
| 372 | return -EINVAL; | 399 | return -EINVAL; |
| 373 | } | 400 | } |
| 374 | mutex_lock(&cnic_lock); | 401 | mutex_lock(&cnic_lock); |
| 375 | if (!cnic_ulp_tbl[ulp_type]) { | 402 | ulp_ops = cnic_ulp_tbl[ulp_type]; |
| 403 | if (!ulp_ops) { | ||
| 376 | printk(KERN_ERR PFX "cnic_unregister_driver: Type %d has not " | 404 | printk(KERN_ERR PFX "cnic_unregister_driver: Type %d has not " |
| 377 | "been registered\n", ulp_type); | 405 | "been registered\n", ulp_type); |
| 378 | goto out_unlock; | 406 | goto out_unlock; |
| @@ -390,10 +418,21 @@ int cnic_unregister_driver(int ulp_type) | |||
| 390 | } | 418 | } |
| 391 | read_unlock(&cnic_dev_lock); | 419 | read_unlock(&cnic_dev_lock); |
| 392 | 420 | ||
| 421 | if (ulp_type == CNIC_ULP_ISCSI) | ||
| 422 | cnic_uio_stop(); | ||
| 423 | |||
| 393 | rcu_assign_pointer(cnic_ulp_tbl[ulp_type], NULL); | 424 | rcu_assign_pointer(cnic_ulp_tbl[ulp_type], NULL); |
| 394 | 425 | ||
| 395 | mutex_unlock(&cnic_lock); | 426 | mutex_unlock(&cnic_lock); |
| 396 | synchronize_rcu(); | 427 | synchronize_rcu(); |
| 428 | while ((atomic_read(&ulp_ops->ref_count) != 0) && (i < 20)) { | ||
| 429 | msleep(100); | ||
| 430 | i++; | ||
| 431 | } | ||
| 432 | |||
| 433 | if (atomic_read(&ulp_ops->ref_count) != 0) | ||
| 434 | printk(KERN_WARNING PFX "%s: Failed waiting for ref count to go" | ||
| 435 | " to zero.\n", dev->netdev->name); | ||
| 397 | return 0; | 436 | return 0; |
| 398 | 437 | ||
| 399 | out_unlock: | 438 | out_unlock: |
| @@ -449,6 +488,7 @@ EXPORT_SYMBOL(cnic_register_driver); | |||
| 449 | static int cnic_unregister_device(struct cnic_dev *dev, int ulp_type) | 488 | static int cnic_unregister_device(struct cnic_dev *dev, int ulp_type) |
| 450 | { | 489 | { |
| 451 | struct cnic_local *cp = dev->cnic_priv; | 490 | struct cnic_local *cp = dev->cnic_priv; |
| 491 | int i = 0; | ||
| 452 | 492 | ||
| 453 | if (ulp_type >= MAX_CNIC_ULP_TYPE) { | 493 | if (ulp_type >= MAX_CNIC_ULP_TYPE) { |
| 454 | printk(KERN_ERR PFX "cnic_unregister_device: Bad type %d\n", | 494 | printk(KERN_ERR PFX "cnic_unregister_device: Bad type %d\n", |
| @@ -469,6 +509,15 @@ static int cnic_unregister_device(struct cnic_dev *dev, int ulp_type) | |||
| 469 | 509 | ||
| 470 | synchronize_rcu(); | 510 | synchronize_rcu(); |
| 471 | 511 | ||
| 512 | while (test_bit(ULP_F_CALL_PENDING, &cp->ulp_flags[ulp_type]) && | ||
| 513 | i < 20) { | ||
| 514 | msleep(100); | ||
| 515 | i++; | ||
| 516 | } | ||
| 517 | if (test_bit(ULP_F_CALL_PENDING, &cp->ulp_flags[ulp_type])) | ||
| 518 | printk(KERN_WARNING PFX "%s: Failed waiting for ULP up call" | ||
| 519 | " to complete.\n", dev->netdev->name); | ||
| 520 | |||
| 472 | return 0; | 521 | return 0; |
| 473 | } | 522 | } |
| 474 | EXPORT_SYMBOL(cnic_unregister_driver); | 523 | EXPORT_SYMBOL(cnic_unregister_driver); |
| @@ -632,7 +681,6 @@ static void cnic_free_resc(struct cnic_dev *dev) | |||
| 632 | int i = 0; | 681 | int i = 0; |
| 633 | 682 | ||
| 634 | if (cp->cnic_uinfo) { | 683 | if (cp->cnic_uinfo) { |
| 635 | cnic_send_nlmsg(cp, ISCSI_KEVENT_IF_DOWN, NULL); | ||
| 636 | while (cp->uio_dev != -1 && i < 15) { | 684 | while (cp->uio_dev != -1 && i < 15) { |
| 637 | msleep(100); | 685 | msleep(100); |
| 638 | i++; | 686 | i++; |
| @@ -1057,18 +1105,26 @@ static void cnic_ulp_stop(struct cnic_dev *dev) | |||
| 1057 | struct cnic_local *cp = dev->cnic_priv; | 1105 | struct cnic_local *cp = dev->cnic_priv; |
| 1058 | int if_type; | 1106 | int if_type; |
| 1059 | 1107 | ||
| 1060 | rcu_read_lock(); | 1108 | if (cp->cnic_uinfo) |
| 1109 | cnic_send_nlmsg(cp, ISCSI_KEVENT_IF_DOWN, NULL); | ||
| 1110 | |||
| 1061 | for (if_type = 0; if_type < MAX_CNIC_ULP_TYPE; if_type++) { | 1111 | for (if_type = 0; if_type < MAX_CNIC_ULP_TYPE; if_type++) { |
| 1062 | struct cnic_ulp_ops *ulp_ops; | 1112 | struct cnic_ulp_ops *ulp_ops; |
| 1063 | 1113 | ||
| 1064 | ulp_ops = rcu_dereference(cp->ulp_ops[if_type]); | 1114 | mutex_lock(&cnic_lock); |
| 1065 | if (!ulp_ops) | 1115 | ulp_ops = cp->ulp_ops[if_type]; |
| 1116 | if (!ulp_ops) { | ||
| 1117 | mutex_unlock(&cnic_lock); | ||
| 1066 | continue; | 1118 | continue; |
| 1119 | } | ||
| 1120 | set_bit(ULP_F_CALL_PENDING, &cp->ulp_flags[if_type]); | ||
| 1121 | mutex_unlock(&cnic_lock); | ||
| 1067 | 1122 | ||
| 1068 | if (test_and_clear_bit(ULP_F_START, &cp->ulp_flags[if_type])) | 1123 | if (test_and_clear_bit(ULP_F_START, &cp->ulp_flags[if_type])) |
| 1069 | ulp_ops->cnic_stop(cp->ulp_handle[if_type]); | 1124 | ulp_ops->cnic_stop(cp->ulp_handle[if_type]); |
| 1125 | |||
| 1126 | clear_bit(ULP_F_CALL_PENDING, &cp->ulp_flags[if_type]); | ||
| 1070 | } | 1127 | } |
| 1071 | rcu_read_unlock(); | ||
| 1072 | } | 1128 | } |
| 1073 | 1129 | ||
| 1074 | static void cnic_ulp_start(struct cnic_dev *dev) | 1130 | static void cnic_ulp_start(struct cnic_dev *dev) |
| @@ -1076,18 +1132,23 @@ static void cnic_ulp_start(struct cnic_dev *dev) | |||
| 1076 | struct cnic_local *cp = dev->cnic_priv; | 1132 | struct cnic_local *cp = dev->cnic_priv; |
| 1077 | int if_type; | 1133 | int if_type; |
| 1078 | 1134 | ||
| 1079 | rcu_read_lock(); | ||
| 1080 | for (if_type = 0; if_type < MAX_CNIC_ULP_TYPE; if_type++) { | 1135 | for (if_type = 0; if_type < MAX_CNIC_ULP_TYPE; if_type++) { |
| 1081 | struct cnic_ulp_ops *ulp_ops; | 1136 | struct cnic_ulp_ops *ulp_ops; |
| 1082 | 1137 | ||
| 1083 | ulp_ops = rcu_dereference(cp->ulp_ops[if_type]); | 1138 | mutex_lock(&cnic_lock); |
| 1084 | if (!ulp_ops || !ulp_ops->cnic_start) | 1139 | ulp_ops = cp->ulp_ops[if_type]; |
| 1140 | if (!ulp_ops || !ulp_ops->cnic_start) { | ||
| 1141 | mutex_unlock(&cnic_lock); | ||
| 1085 | continue; | 1142 | continue; |
| 1143 | } | ||
| 1144 | set_bit(ULP_F_CALL_PENDING, &cp->ulp_flags[if_type]); | ||
| 1145 | mutex_unlock(&cnic_lock); | ||
| 1086 | 1146 | ||
| 1087 | if (!test_and_set_bit(ULP_F_START, &cp->ulp_flags[if_type])) | 1147 | if (!test_and_set_bit(ULP_F_START, &cp->ulp_flags[if_type])) |
| 1088 | ulp_ops->cnic_start(cp->ulp_handle[if_type]); | 1148 | ulp_ops->cnic_start(cp->ulp_handle[if_type]); |
| 1149 | |||
| 1150 | clear_bit(ULP_F_CALL_PENDING, &cp->ulp_flags[if_type]); | ||
| 1089 | } | 1151 | } |
| 1090 | rcu_read_unlock(); | ||
| 1091 | } | 1152 | } |
| 1092 | 1153 | ||
| 1093 | static int cnic_ctl(void *data, struct cnic_ctl_info *info) | 1154 | static int cnic_ctl(void *data, struct cnic_ctl_info *info) |
| @@ -1097,22 +1158,18 @@ static int cnic_ctl(void *data, struct cnic_ctl_info *info) | |||
| 1097 | switch (info->cmd) { | 1158 | switch (info->cmd) { |
| 1098 | case CNIC_CTL_STOP_CMD: | 1159 | case CNIC_CTL_STOP_CMD: |
| 1099 | cnic_hold(dev); | 1160 | cnic_hold(dev); |
| 1100 | mutex_lock(&cnic_lock); | ||
| 1101 | 1161 | ||
| 1102 | cnic_ulp_stop(dev); | 1162 | cnic_ulp_stop(dev); |
| 1103 | cnic_stop_hw(dev); | 1163 | cnic_stop_hw(dev); |
| 1104 | 1164 | ||
| 1105 | mutex_unlock(&cnic_lock); | ||
| 1106 | cnic_put(dev); | 1165 | cnic_put(dev); |
| 1107 | break; | 1166 | break; |
| 1108 | case CNIC_CTL_START_CMD: | 1167 | case CNIC_CTL_START_CMD: |
| 1109 | cnic_hold(dev); | 1168 | cnic_hold(dev); |
| 1110 | mutex_lock(&cnic_lock); | ||
| 1111 | 1169 | ||
| 1112 | if (!cnic_start_hw(dev)) | 1170 | if (!cnic_start_hw(dev)) |
| 1113 | cnic_ulp_start(dev); | 1171 | cnic_ulp_start(dev); |
| 1114 | 1172 | ||
| 1115 | mutex_unlock(&cnic_lock); | ||
| 1116 | cnic_put(dev); | 1173 | cnic_put(dev); |
| 1117 | break; | 1174 | break; |
| 1118 | default: | 1175 | default: |
| @@ -1126,19 +1183,23 @@ static void cnic_ulp_init(struct cnic_dev *dev) | |||
| 1126 | int i; | 1183 | int i; |
| 1127 | struct cnic_local *cp = dev->cnic_priv; | 1184 | struct cnic_local *cp = dev->cnic_priv; |
| 1128 | 1185 | ||
| 1129 | rcu_read_lock(); | ||
| 1130 | for (i = 0; i < MAX_CNIC_ULP_TYPE_EXT; i++) { | 1186 | for (i = 0; i < MAX_CNIC_ULP_TYPE_EXT; i++) { |
| 1131 | struct cnic_ulp_ops *ulp_ops; | 1187 | struct cnic_ulp_ops *ulp_ops; |
| 1132 | 1188 | ||
| 1133 | ulp_ops = rcu_dereference(cnic_ulp_tbl[i]); | 1189 | mutex_lock(&cnic_lock); |
| 1134 | if (!ulp_ops || !ulp_ops->cnic_init) | 1190 | ulp_ops = cnic_ulp_tbl[i]; |
| 1191 | if (!ulp_ops || !ulp_ops->cnic_init) { | ||
| 1192 | mutex_unlock(&cnic_lock); | ||
| 1135 | continue; | 1193 | continue; |
| 1194 | } | ||
| 1195 | ulp_get(ulp_ops); | ||
| 1196 | mutex_unlock(&cnic_lock); | ||
| 1136 | 1197 | ||
| 1137 | if (!test_and_set_bit(ULP_F_INIT, &cp->ulp_flags[i])) | 1198 | if (!test_and_set_bit(ULP_F_INIT, &cp->ulp_flags[i])) |
| 1138 | ulp_ops->cnic_init(dev); | 1199 | ulp_ops->cnic_init(dev); |
| 1139 | 1200 | ||
| 1201 | ulp_put(ulp_ops); | ||
| 1140 | } | 1202 | } |
| 1141 | rcu_read_unlock(); | ||
| 1142 | } | 1203 | } |
| 1143 | 1204 | ||
| 1144 | static void cnic_ulp_exit(struct cnic_dev *dev) | 1205 | static void cnic_ulp_exit(struct cnic_dev *dev) |
| @@ -1146,19 +1207,23 @@ static void cnic_ulp_exit(struct cnic_dev *dev) | |||
| 1146 | int i; | 1207 | int i; |
| 1147 | struct cnic_local *cp = dev->cnic_priv; | 1208 | struct cnic_local *cp = dev->cnic_priv; |
| 1148 | 1209 | ||
| 1149 | rcu_read_lock(); | ||
| 1150 | for (i = 0; i < MAX_CNIC_ULP_TYPE_EXT; i++) { | 1210 | for (i = 0; i < MAX_CNIC_ULP_TYPE_EXT; i++) { |
| 1151 | struct cnic_ulp_ops *ulp_ops; | 1211 | struct cnic_ulp_ops *ulp_ops; |
| 1152 | 1212 | ||
| 1153 | ulp_ops = rcu_dereference(cnic_ulp_tbl[i]); | 1213 | mutex_lock(&cnic_lock); |
| 1154 | if (!ulp_ops || !ulp_ops->cnic_exit) | 1214 | ulp_ops = cnic_ulp_tbl[i]; |
| 1215 | if (!ulp_ops || !ulp_ops->cnic_exit) { | ||
| 1216 | mutex_unlock(&cnic_lock); | ||
| 1155 | continue; | 1217 | continue; |
| 1218 | } | ||
| 1219 | ulp_get(ulp_ops); | ||
| 1220 | mutex_unlock(&cnic_lock); | ||
| 1156 | 1221 | ||
| 1157 | if (test_and_clear_bit(ULP_F_INIT, &cp->ulp_flags[i])) | 1222 | if (test_and_clear_bit(ULP_F_INIT, &cp->ulp_flags[i])) |
| 1158 | ulp_ops->cnic_exit(dev); | 1223 | ulp_ops->cnic_exit(dev); |
| 1159 | 1224 | ||
| 1225 | ulp_put(ulp_ops); | ||
| 1160 | } | 1226 | } |
| 1161 | rcu_read_unlock(); | ||
| 1162 | } | 1227 | } |
| 1163 | 1228 | ||
| 1164 | static int cnic_cm_offload_pg(struct cnic_sock *csk) | 1229 | static int cnic_cm_offload_pg(struct cnic_sock *csk) |
| @@ -2374,21 +2439,45 @@ static int cnic_start_bnx2_hw(struct cnic_dev *dev) | |||
| 2374 | return 0; | 2439 | return 0; |
| 2375 | } | 2440 | } |
| 2376 | 2441 | ||
| 2377 | static int cnic_start_hw(struct cnic_dev *dev) | 2442 | static int cnic_register_netdev(struct cnic_dev *dev) |
| 2378 | { | 2443 | { |
| 2379 | struct cnic_local *cp = dev->cnic_priv; | 2444 | struct cnic_local *cp = dev->cnic_priv; |
| 2380 | struct cnic_eth_dev *ethdev = cp->ethdev; | 2445 | struct cnic_eth_dev *ethdev = cp->ethdev; |
| 2381 | int err; | 2446 | int err; |
| 2382 | 2447 | ||
| 2383 | if (test_bit(CNIC_F_CNIC_UP, &dev->flags)) | 2448 | if (!ethdev) |
| 2384 | return -EALREADY; | 2449 | return -ENODEV; |
| 2450 | |||
| 2451 | if (ethdev->drv_state & CNIC_DRV_STATE_REGD) | ||
| 2452 | return 0; | ||
| 2385 | 2453 | ||
| 2386 | err = ethdev->drv_register_cnic(dev->netdev, cp->cnic_ops, dev); | 2454 | err = ethdev->drv_register_cnic(dev->netdev, cp->cnic_ops, dev); |
| 2387 | if (err) { | 2455 | if (err) |
| 2388 | printk(KERN_ERR PFX "%s: register_cnic failed\n", | 2456 | printk(KERN_ERR PFX "%s: register_cnic failed\n", |
| 2389 | dev->netdev->name); | 2457 | dev->netdev->name); |
| 2390 | goto err2; | 2458 | |
| 2391 | } | 2459 | return err; |
| 2460 | } | ||
| 2461 | |||
| 2462 | static void cnic_unregister_netdev(struct cnic_dev *dev) | ||
| 2463 | { | ||
| 2464 | struct cnic_local *cp = dev->cnic_priv; | ||
| 2465 | struct cnic_eth_dev *ethdev = cp->ethdev; | ||
| 2466 | |||
| 2467 | if (!ethdev) | ||
| 2468 | return; | ||
| 2469 | |||
| 2470 | ethdev->drv_unregister_cnic(dev->netdev); | ||
| 2471 | } | ||
| 2472 | |||
| 2473 | static int cnic_start_hw(struct cnic_dev *dev) | ||
| 2474 | { | ||
| 2475 | struct cnic_local *cp = dev->cnic_priv; | ||
| 2476 | struct cnic_eth_dev *ethdev = cp->ethdev; | ||
| 2477 | int err; | ||
| 2478 | |||
| 2479 | if (test_bit(CNIC_F_CNIC_UP, &dev->flags)) | ||
| 2480 | return -EALREADY; | ||
| 2392 | 2481 | ||
| 2393 | dev->regview = ethdev->io_base; | 2482 | dev->regview = ethdev->io_base; |
| 2394 | cp->chip_id = ethdev->chip_id; | 2483 | cp->chip_id = ethdev->chip_id; |
| @@ -2419,18 +2508,13 @@ static int cnic_start_hw(struct cnic_dev *dev) | |||
| 2419 | return 0; | 2508 | return 0; |
| 2420 | 2509 | ||
| 2421 | err1: | 2510 | err1: |
| 2422 | ethdev->drv_unregister_cnic(dev->netdev); | ||
| 2423 | cp->free_resc(dev); | 2511 | cp->free_resc(dev); |
| 2424 | pci_dev_put(dev->pcidev); | 2512 | pci_dev_put(dev->pcidev); |
| 2425 | err2: | ||
| 2426 | return err; | 2513 | return err; |
| 2427 | } | 2514 | } |
| 2428 | 2515 | ||
| 2429 | static void cnic_stop_bnx2_hw(struct cnic_dev *dev) | 2516 | static void cnic_stop_bnx2_hw(struct cnic_dev *dev) |
| 2430 | { | 2517 | { |
| 2431 | struct cnic_local *cp = dev->cnic_priv; | ||
| 2432 | struct cnic_eth_dev *ethdev = cp->ethdev; | ||
| 2433 | |||
| 2434 | cnic_disable_bnx2_int_sync(dev); | 2518 | cnic_disable_bnx2_int_sync(dev); |
| 2435 | 2519 | ||
| 2436 | cnic_reg_wr_ind(dev, BNX2_CP_SCRATCH + 0x20, 0); | 2520 | cnic_reg_wr_ind(dev, BNX2_CP_SCRATCH + 0x20, 0); |
| @@ -2442,8 +2526,6 @@ static void cnic_stop_bnx2_hw(struct cnic_dev *dev) | |||
| 2442 | cnic_setup_5709_context(dev, 0); | 2526 | cnic_setup_5709_context(dev, 0); |
| 2443 | cnic_free_irq(dev); | 2527 | cnic_free_irq(dev); |
| 2444 | 2528 | ||
| 2445 | ethdev->drv_unregister_cnic(dev->netdev); | ||
| 2446 | |||
| 2447 | cnic_free_resc(dev); | 2529 | cnic_free_resc(dev); |
| 2448 | } | 2530 | } |
| 2449 | 2531 | ||
| @@ -2524,7 +2606,7 @@ static struct cnic_dev *init_bnx2_cnic(struct net_device *dev) | |||
| 2524 | probe = symbol_get(bnx2_cnic_probe); | 2606 | probe = symbol_get(bnx2_cnic_probe); |
| 2525 | if (probe) { | 2607 | if (probe) { |
| 2526 | ethdev = (*probe)(dev); | 2608 | ethdev = (*probe)(dev); |
| 2527 | symbol_put_addr(probe); | 2609 | symbol_put(bnx2_cnic_probe); |
| 2528 | } | 2610 | } |
| 2529 | if (!ethdev) | 2611 | if (!ethdev) |
| 2530 | return NULL; | 2612 | return NULL; |
| @@ -2627,10 +2709,12 @@ static int cnic_netdev_event(struct notifier_block *this, unsigned long event, | |||
| 2627 | else if (event == NETDEV_UNREGISTER) | 2709 | else if (event == NETDEV_UNREGISTER) |
| 2628 | cnic_ulp_exit(dev); | 2710 | cnic_ulp_exit(dev); |
| 2629 | else if (event == NETDEV_UP) { | 2711 | else if (event == NETDEV_UP) { |
| 2630 | mutex_lock(&cnic_lock); | 2712 | if (cnic_register_netdev(dev) != 0) { |
| 2713 | cnic_put(dev); | ||
| 2714 | goto done; | ||
| 2715 | } | ||
| 2631 | if (!cnic_start_hw(dev)) | 2716 | if (!cnic_start_hw(dev)) |
| 2632 | cnic_ulp_start(dev); | 2717 | cnic_ulp_start(dev); |
| 2633 | mutex_unlock(&cnic_lock); | ||
| 2634 | } | 2718 | } |
| 2635 | 2719 | ||
| 2636 | rcu_read_lock(); | 2720 | rcu_read_lock(); |
| @@ -2649,10 +2733,9 @@ static int cnic_netdev_event(struct notifier_block *this, unsigned long event, | |||
| 2649 | rcu_read_unlock(); | 2733 | rcu_read_unlock(); |
| 2650 | 2734 | ||
| 2651 | if (event == NETDEV_GOING_DOWN) { | 2735 | if (event == NETDEV_GOING_DOWN) { |
| 2652 | mutex_lock(&cnic_lock); | ||
| 2653 | cnic_ulp_stop(dev); | 2736 | cnic_ulp_stop(dev); |
| 2654 | cnic_stop_hw(dev); | 2737 | cnic_stop_hw(dev); |
| 2655 | mutex_unlock(&cnic_lock); | 2738 | cnic_unregister_netdev(dev); |
| 2656 | } else if (event == NETDEV_UNREGISTER) { | 2739 | } else if (event == NETDEV_UNREGISTER) { |
| 2657 | write_lock(&cnic_dev_lock); | 2740 | write_lock(&cnic_dev_lock); |
| 2658 | list_del_init(&dev->list); | 2741 | list_del_init(&dev->list); |
| @@ -2684,6 +2767,7 @@ static void cnic_release(void) | |||
| 2684 | } | 2767 | } |
| 2685 | 2768 | ||
| 2686 | cnic_ulp_exit(dev); | 2769 | cnic_ulp_exit(dev); |
| 2770 | cnic_unregister_netdev(dev); | ||
| 2687 | list_del_init(&dev->list); | 2771 | list_del_init(&dev->list); |
| 2688 | cnic_free_dev(dev); | 2772 | cnic_free_dev(dev); |
| 2689 | } | 2773 | } |
diff --git a/drivers/net/cnic.h b/drivers/net/cnic.h index 5192d4a9df5a..a94b302bb464 100644 --- a/drivers/net/cnic.h +++ b/drivers/net/cnic.h | |||
| @@ -176,6 +176,7 @@ struct cnic_local { | |||
| 176 | unsigned long ulp_flags[MAX_CNIC_ULP_TYPE]; | 176 | unsigned long ulp_flags[MAX_CNIC_ULP_TYPE]; |
| 177 | #define ULP_F_INIT 0 | 177 | #define ULP_F_INIT 0 |
| 178 | #define ULP_F_START 1 | 178 | #define ULP_F_START 1 |
| 179 | #define ULP_F_CALL_PENDING 2 | ||
| 179 | struct cnic_ulp_ops *ulp_ops[MAX_CNIC_ULP_TYPE]; | 180 | struct cnic_ulp_ops *ulp_ops[MAX_CNIC_ULP_TYPE]; |
| 180 | 181 | ||
| 181 | /* protected by ulp_lock */ | 182 | /* protected by ulp_lock */ |
diff --git a/drivers/net/cnic_if.h b/drivers/net/cnic_if.h index d1bce27ee99e..a49235739eef 100644 --- a/drivers/net/cnic_if.h +++ b/drivers/net/cnic_if.h | |||
| @@ -290,6 +290,7 @@ struct cnic_ulp_ops { | |||
| 290 | void (*iscsi_nl_send_msg)(struct cnic_dev *dev, u32 msg_type, | 290 | void (*iscsi_nl_send_msg)(struct cnic_dev *dev, u32 msg_type, |
| 291 | char *data, u16 data_size); | 291 | char *data, u16 data_size); |
| 292 | struct module *owner; | 292 | struct module *owner; |
| 293 | atomic_t ref_count; | ||
| 293 | }; | 294 | }; |
| 294 | 295 | ||
| 295 | extern int cnic_register_driver(int ulp_type, struct cnic_ulp_ops *ulp_ops); | 296 | extern int cnic_register_driver(int ulp_type, struct cnic_ulp_ops *ulp_ops); |
diff --git a/drivers/net/e100.c b/drivers/net/e100.c index efa680f4b8dd..3a6735dc9f6a 100644 --- a/drivers/net/e100.c +++ b/drivers/net/e100.c | |||
| @@ -1897,6 +1897,9 @@ static int e100_rx_indicate(struct nic *nic, struct rx *rx, | |||
| 1897 | 1897 | ||
| 1898 | if (ioread8(&nic->csr->scb.status) & rus_no_res) | 1898 | if (ioread8(&nic->csr->scb.status) & rus_no_res) |
| 1899 | nic->ru_running = RU_SUSPENDED; | 1899 | nic->ru_running = RU_SUSPENDED; |
| 1900 | pci_dma_sync_single_for_device(nic->pdev, rx->dma_addr, | ||
| 1901 | sizeof(struct rfd), | ||
| 1902 | PCI_DMA_FROMDEVICE); | ||
| 1900 | return -ENODATA; | 1903 | return -ENODATA; |
| 1901 | } | 1904 | } |
| 1902 | 1905 | ||
diff --git a/drivers/net/e1000e/ich8lan.c b/drivers/net/e1000e/ich8lan.c index d56c7473144a..99df2abf82a9 100644 --- a/drivers/net/e1000e/ich8lan.c +++ b/drivers/net/e1000e/ich8lan.c | |||
| @@ -338,10 +338,7 @@ static s32 e1000_init_nvm_params_ich8lan(struct e1000_hw *hw) | |||
| 338 | { | 338 | { |
| 339 | struct e1000_nvm_info *nvm = &hw->nvm; | 339 | struct e1000_nvm_info *nvm = &hw->nvm; |
| 340 | struct e1000_dev_spec_ich8lan *dev_spec = &hw->dev_spec.ich8lan; | 340 | struct e1000_dev_spec_ich8lan *dev_spec = &hw->dev_spec.ich8lan; |
| 341 | union ich8_hws_flash_status hsfsts; | 341 | u32 gfpreg, sector_base_addr, sector_end_addr; |
| 342 | u32 gfpreg; | ||
| 343 | u32 sector_base_addr; | ||
| 344 | u32 sector_end_addr; | ||
| 345 | u16 i; | 342 | u16 i; |
| 346 | 343 | ||
| 347 | /* Can't read flash registers if the register set isn't mapped. */ | 344 | /* Can't read flash registers if the register set isn't mapped. */ |
| @@ -375,20 +372,6 @@ static s32 e1000_init_nvm_params_ich8lan(struct e1000_hw *hw) | |||
| 375 | /* Adjust to word count */ | 372 | /* Adjust to word count */ |
| 376 | nvm->flash_bank_size /= sizeof(u16); | 373 | nvm->flash_bank_size /= sizeof(u16); |
| 377 | 374 | ||
| 378 | /* | ||
| 379 | * Make sure the flash bank size does not overwrite the 4k | ||
| 380 | * sector ranges. We may have 64k allotted to us but we only care | ||
| 381 | * about the first 2 4k sectors. Therefore, if we have anything less | ||
| 382 | * than 64k set in the HSFSTS register, we will reduce the bank size | ||
| 383 | * down to 4k and let the rest remain unused. If berasesz == 3, then | ||
| 384 | * we are working in 64k mode. Otherwise we are not. | ||
| 385 | */ | ||
| 386 | if (nvm->flash_bank_size > E1000_ICH8_SHADOW_RAM_WORDS) { | ||
| 387 | hsfsts.regval = er16flash(ICH_FLASH_HSFSTS); | ||
| 388 | if (hsfsts.hsf_status.berasesz != 3) | ||
| 389 | nvm->flash_bank_size = E1000_ICH8_SHADOW_RAM_WORDS; | ||
| 390 | } | ||
| 391 | |||
| 392 | nvm->word_size = E1000_ICH8_SHADOW_RAM_WORDS; | 375 | nvm->word_size = E1000_ICH8_SHADOW_RAM_WORDS; |
| 393 | 376 | ||
| 394 | /* Clear shadow ram */ | 377 | /* Clear shadow ram */ |
| @@ -594,8 +577,8 @@ static DEFINE_MUTEX(nvm_mutex); | |||
| 594 | **/ | 577 | **/ |
| 595 | static s32 e1000_acquire_swflag_ich8lan(struct e1000_hw *hw) | 578 | static s32 e1000_acquire_swflag_ich8lan(struct e1000_hw *hw) |
| 596 | { | 579 | { |
| 597 | u32 extcnf_ctrl; | 580 | u32 extcnf_ctrl, timeout = PHY_CFG_TIMEOUT; |
| 598 | u32 timeout = PHY_CFG_TIMEOUT; | 581 | s32 ret_val = 0; |
| 599 | 582 | ||
| 600 | might_sleep(); | 583 | might_sleep(); |
| 601 | 584 | ||
| @@ -603,28 +586,46 @@ static s32 e1000_acquire_swflag_ich8lan(struct e1000_hw *hw) | |||
| 603 | 586 | ||
| 604 | while (timeout) { | 587 | while (timeout) { |
| 605 | extcnf_ctrl = er32(EXTCNF_CTRL); | 588 | extcnf_ctrl = er32(EXTCNF_CTRL); |
| 589 | if (!(extcnf_ctrl & E1000_EXTCNF_CTRL_SWFLAG)) | ||
| 590 | break; | ||
| 606 | 591 | ||
| 607 | if (!(extcnf_ctrl & E1000_EXTCNF_CTRL_SWFLAG)) { | 592 | mdelay(1); |
| 608 | extcnf_ctrl |= E1000_EXTCNF_CTRL_SWFLAG; | 593 | timeout--; |
| 609 | ew32(EXTCNF_CTRL, extcnf_ctrl); | 594 | } |
| 595 | |||
| 596 | if (!timeout) { | ||
| 597 | hw_dbg(hw, "SW/FW/HW has locked the resource for too long.\n"); | ||
| 598 | ret_val = -E1000_ERR_CONFIG; | ||
| 599 | goto out; | ||
| 600 | } | ||
| 601 | |||
| 602 | timeout = PHY_CFG_TIMEOUT * 2; | ||
| 603 | |||
| 604 | extcnf_ctrl |= E1000_EXTCNF_CTRL_SWFLAG; | ||
| 605 | ew32(EXTCNF_CTRL, extcnf_ctrl); | ||
| 606 | |||
| 607 | while (timeout) { | ||
| 608 | extcnf_ctrl = er32(EXTCNF_CTRL); | ||
| 609 | if (extcnf_ctrl & E1000_EXTCNF_CTRL_SWFLAG) | ||
| 610 | break; | ||
| 610 | 611 | ||
| 611 | extcnf_ctrl = er32(EXTCNF_CTRL); | ||
| 612 | if (extcnf_ctrl & E1000_EXTCNF_CTRL_SWFLAG) | ||
| 613 | break; | ||
| 614 | } | ||
| 615 | mdelay(1); | 612 | mdelay(1); |
| 616 | timeout--; | 613 | timeout--; |
| 617 | } | 614 | } |
| 618 | 615 | ||
| 619 | if (!timeout) { | 616 | if (!timeout) { |
| 620 | hw_dbg(hw, "FW or HW has locked the resource for too long.\n"); | 617 | hw_dbg(hw, "Failed to acquire the semaphore.\n"); |
| 621 | extcnf_ctrl &= ~E1000_EXTCNF_CTRL_SWFLAG; | 618 | extcnf_ctrl &= ~E1000_EXTCNF_CTRL_SWFLAG; |
| 622 | ew32(EXTCNF_CTRL, extcnf_ctrl); | 619 | ew32(EXTCNF_CTRL, extcnf_ctrl); |
| 623 | mutex_unlock(&nvm_mutex); | 620 | ret_val = -E1000_ERR_CONFIG; |
| 624 | return -E1000_ERR_CONFIG; | 621 | goto out; |
| 625 | } | 622 | } |
| 626 | 623 | ||
| 627 | return 0; | 624 | out: |
| 625 | if (ret_val) | ||
| 626 | mutex_unlock(&nvm_mutex); | ||
| 627 | |||
| 628 | return ret_val; | ||
| 628 | } | 629 | } |
| 629 | 630 | ||
| 630 | /** | 631 | /** |
| @@ -1306,7 +1307,7 @@ static s32 e1000_read_nvm_ich8lan(struct e1000_hw *hw, u16 offset, u16 words, | |||
| 1306 | struct e1000_nvm_info *nvm = &hw->nvm; | 1307 | struct e1000_nvm_info *nvm = &hw->nvm; |
| 1307 | struct e1000_dev_spec_ich8lan *dev_spec = &hw->dev_spec.ich8lan; | 1308 | struct e1000_dev_spec_ich8lan *dev_spec = &hw->dev_spec.ich8lan; |
| 1308 | u32 act_offset; | 1309 | u32 act_offset; |
| 1309 | s32 ret_val; | 1310 | s32 ret_val = 0; |
| 1310 | u32 bank = 0; | 1311 | u32 bank = 0; |
| 1311 | u16 i, word; | 1312 | u16 i, word; |
| 1312 | 1313 | ||
| @@ -1321,12 +1322,15 @@ static s32 e1000_read_nvm_ich8lan(struct e1000_hw *hw, u16 offset, u16 words, | |||
| 1321 | goto out; | 1322 | goto out; |
| 1322 | 1323 | ||
| 1323 | ret_val = e1000_valid_nvm_bank_detect_ich8lan(hw, &bank); | 1324 | ret_val = e1000_valid_nvm_bank_detect_ich8lan(hw, &bank); |
| 1324 | if (ret_val) | 1325 | if (ret_val) { |
| 1325 | goto release; | 1326 | hw_dbg(hw, "Could not detect valid bank, assuming bank 0\n"); |
| 1327 | bank = 0; | ||
| 1328 | } | ||
| 1326 | 1329 | ||
| 1327 | act_offset = (bank) ? nvm->flash_bank_size : 0; | 1330 | act_offset = (bank) ? nvm->flash_bank_size : 0; |
| 1328 | act_offset += offset; | 1331 | act_offset += offset; |
| 1329 | 1332 | ||
| 1333 | ret_val = 0; | ||
| 1330 | for (i = 0; i < words; i++) { | 1334 | for (i = 0; i < words; i++) { |
| 1331 | if ((dev_spec->shadow_ram) && | 1335 | if ((dev_spec->shadow_ram) && |
| 1332 | (dev_spec->shadow_ram[offset+i].modified)) { | 1336 | (dev_spec->shadow_ram[offset+i].modified)) { |
| @@ -1341,7 +1345,6 @@ static s32 e1000_read_nvm_ich8lan(struct e1000_hw *hw, u16 offset, u16 words, | |||
| 1341 | } | 1345 | } |
| 1342 | } | 1346 | } |
| 1343 | 1347 | ||
| 1344 | release: | ||
| 1345 | e1000_release_swflag_ich8lan(hw); | 1348 | e1000_release_swflag_ich8lan(hw); |
| 1346 | 1349 | ||
| 1347 | out: | 1350 | out: |
| @@ -1592,7 +1595,6 @@ static s32 e1000_write_nvm_ich8lan(struct e1000_hw *hw, u16 offset, u16 words, | |||
| 1592 | { | 1595 | { |
| 1593 | struct e1000_nvm_info *nvm = &hw->nvm; | 1596 | struct e1000_nvm_info *nvm = &hw->nvm; |
| 1594 | struct e1000_dev_spec_ich8lan *dev_spec = &hw->dev_spec.ich8lan; | 1597 | struct e1000_dev_spec_ich8lan *dev_spec = &hw->dev_spec.ich8lan; |
| 1595 | s32 ret_val; | ||
| 1596 | u16 i; | 1598 | u16 i; |
| 1597 | 1599 | ||
| 1598 | if ((offset >= nvm->word_size) || (words > nvm->word_size - offset) || | 1600 | if ((offset >= nvm->word_size) || (words > nvm->word_size - offset) || |
| @@ -1601,17 +1603,11 @@ static s32 e1000_write_nvm_ich8lan(struct e1000_hw *hw, u16 offset, u16 words, | |||
| 1601 | return -E1000_ERR_NVM; | 1603 | return -E1000_ERR_NVM; |
| 1602 | } | 1604 | } |
| 1603 | 1605 | ||
| 1604 | ret_val = e1000_acquire_swflag_ich8lan(hw); | ||
| 1605 | if (ret_val) | ||
| 1606 | return ret_val; | ||
| 1607 | |||
| 1608 | for (i = 0; i < words; i++) { | 1606 | for (i = 0; i < words; i++) { |
| 1609 | dev_spec->shadow_ram[offset+i].modified = 1; | 1607 | dev_spec->shadow_ram[offset+i].modified = 1; |
| 1610 | dev_spec->shadow_ram[offset+i].value = data[i]; | 1608 | dev_spec->shadow_ram[offset+i].value = data[i]; |
| 1611 | } | 1609 | } |
| 1612 | 1610 | ||
| 1613 | e1000_release_swflag_ich8lan(hw); | ||
| 1614 | |||
| 1615 | return 0; | 1611 | return 0; |
| 1616 | } | 1612 | } |
| 1617 | 1613 | ||
| @@ -1652,8 +1648,8 @@ static s32 e1000_update_nvm_checksum_ich8lan(struct e1000_hw *hw) | |||
| 1652 | */ | 1648 | */ |
| 1653 | ret_val = e1000_valid_nvm_bank_detect_ich8lan(hw, &bank); | 1649 | ret_val = e1000_valid_nvm_bank_detect_ich8lan(hw, &bank); |
| 1654 | if (ret_val) { | 1650 | if (ret_val) { |
| 1655 | e1000_release_swflag_ich8lan(hw); | 1651 | hw_dbg(hw, "Could not detect valid bank, assuming bank 0\n"); |
| 1656 | goto out; | 1652 | bank = 0; |
| 1657 | } | 1653 | } |
| 1658 | 1654 | ||
| 1659 | if (bank == 0) { | 1655 | if (bank == 0) { |
| @@ -2039,12 +2035,8 @@ static s32 e1000_erase_flash_bank_ich8lan(struct e1000_hw *hw, u32 bank) | |||
| 2039 | iteration = 1; | 2035 | iteration = 1; |
| 2040 | break; | 2036 | break; |
| 2041 | case 2: | 2037 | case 2: |
| 2042 | if (hw->mac.type == e1000_ich9lan) { | 2038 | sector_size = ICH_FLASH_SEG_SIZE_8K; |
| 2043 | sector_size = ICH_FLASH_SEG_SIZE_8K; | 2039 | iteration = 1; |
| 2044 | iteration = flash_bank_size / ICH_FLASH_SEG_SIZE_8K; | ||
| 2045 | } else { | ||
| 2046 | return -E1000_ERR_NVM; | ||
| 2047 | } | ||
| 2048 | break; | 2040 | break; |
| 2049 | case 3: | 2041 | case 3: |
| 2050 | sector_size = ICH_FLASH_SEG_SIZE_64K; | 2042 | sector_size = ICH_FLASH_SEG_SIZE_64K; |
| @@ -2056,7 +2048,7 @@ static s32 e1000_erase_flash_bank_ich8lan(struct e1000_hw *hw, u32 bank) | |||
| 2056 | 2048 | ||
| 2057 | /* Start with the base address, then add the sector offset. */ | 2049 | /* Start with the base address, then add the sector offset. */ |
| 2058 | flash_linear_addr = hw->nvm.flash_base_addr; | 2050 | flash_linear_addr = hw->nvm.flash_base_addr; |
| 2059 | flash_linear_addr += (bank) ? (sector_size * iteration) : 0; | 2051 | flash_linear_addr += (bank) ? flash_bank_size : 0; |
| 2060 | 2052 | ||
| 2061 | for (j = 0; j < iteration ; j++) { | 2053 | for (j = 0; j < iteration ; j++) { |
| 2062 | do { | 2054 | do { |
diff --git a/drivers/net/e1000e/netdev.c b/drivers/net/e1000e/netdev.c index 63415bb6f48f..fa92a683aefd 100644 --- a/drivers/net/e1000e/netdev.c +++ b/drivers/net/e1000e/netdev.c | |||
| @@ -4538,8 +4538,7 @@ static int __e1000_shutdown(struct pci_dev *pdev, bool *enable_wake) | |||
| 4538 | /* Allow time for pending master requests to run */ | 4538 | /* Allow time for pending master requests to run */ |
| 4539 | e1000e_disable_pcie_master(&adapter->hw); | 4539 | e1000e_disable_pcie_master(&adapter->hw); |
| 4540 | 4540 | ||
| 4541 | if ((adapter->flags2 & FLAG2_HAS_PHY_WAKEUP) && | 4541 | if (adapter->flags2 & FLAG2_HAS_PHY_WAKEUP) { |
| 4542 | !(hw->mac.ops.check_mng_mode(hw))) { | ||
| 4543 | /* enable wakeup by the PHY */ | 4542 | /* enable wakeup by the PHY */ |
| 4544 | retval = e1000_init_phy_wakeup(adapter, wufc); | 4543 | retval = e1000_init_phy_wakeup(adapter, wufc); |
| 4545 | if (retval) | 4544 | if (retval) |
| @@ -4557,7 +4556,8 @@ static int __e1000_shutdown(struct pci_dev *pdev, bool *enable_wake) | |||
| 4557 | *enable_wake = !!wufc; | 4556 | *enable_wake = !!wufc; |
| 4558 | 4557 | ||
| 4559 | /* make sure adapter isn't asleep if manageability is enabled */ | 4558 | /* make sure adapter isn't asleep if manageability is enabled */ |
| 4560 | if (adapter->flags & FLAG_MNG_PT_ENABLED) | 4559 | if ((adapter->flags & FLAG_MNG_PT_ENABLED) || |
| 4560 | (hw->mac.ops.check_mng_mode(hw))) | ||
| 4561 | *enable_wake = true; | 4561 | *enable_wake = true; |
| 4562 | 4562 | ||
| 4563 | if (adapter->hw.phy.type == e1000_phy_igp_3) | 4563 | if (adapter->hw.phy.type == e1000_phy_igp_3) |
| @@ -4670,14 +4670,6 @@ static int e1000_resume(struct pci_dev *pdev) | |||
| 4670 | return err; | 4670 | return err; |
| 4671 | } | 4671 | } |
| 4672 | 4672 | ||
| 4673 | /* AER (Advanced Error Reporting) hooks */ | ||
| 4674 | err = pci_enable_pcie_error_reporting(pdev); | ||
| 4675 | if (err) { | ||
| 4676 | dev_err(&pdev->dev, "pci_enable_pcie_error_reporting failed " | ||
| 4677 | "0x%x\n", err); | ||
| 4678 | /* non-fatal, continue */ | ||
| 4679 | } | ||
| 4680 | |||
| 4681 | pci_set_master(pdev); | 4673 | pci_set_master(pdev); |
| 4682 | 4674 | ||
| 4683 | pci_enable_wake(pdev, PCI_D3hot, 0); | 4675 | pci_enable_wake(pdev, PCI_D3hot, 0); |
| @@ -4990,6 +4982,14 @@ static int __devinit e1000_probe(struct pci_dev *pdev, | |||
| 4990 | if (err) | 4982 | if (err) |
| 4991 | goto err_pci_reg; | 4983 | goto err_pci_reg; |
| 4992 | 4984 | ||
| 4985 | /* AER (Advanced Error Reporting) hooks */ | ||
| 4986 | err = pci_enable_pcie_error_reporting(pdev); | ||
| 4987 | if (err) { | ||
| 4988 | dev_err(&pdev->dev, "pci_enable_pcie_error_reporting failed " | ||
| 4989 | "0x%x\n", err); | ||
| 4990 | /* non-fatal, continue */ | ||
| 4991 | } | ||
| 4992 | |||
| 4993 | pci_set_master(pdev); | 4993 | pci_set_master(pdev); |
| 4994 | /* PCI config space info */ | 4994 | /* PCI config space info */ |
| 4995 | err = pci_save_state(pdev); | 4995 | err = pci_save_state(pdev); |
diff --git a/drivers/net/eepro.c b/drivers/net/eepro.c index cc2ab6412c73..4f7003485348 100644 --- a/drivers/net/eepro.c +++ b/drivers/net/eepro.c | |||
| @@ -1784,7 +1784,7 @@ int __init init_module(void) | |||
| 1784 | printk(KERN_INFO "eepro_init_module: Auto-detecting boards (May God protect us...)\n"); | 1784 | printk(KERN_INFO "eepro_init_module: Auto-detecting boards (May God protect us...)\n"); |
| 1785 | } | 1785 | } |
| 1786 | 1786 | ||
| 1787 | for (i = 0; io[i] != -1 && i < MAX_EEPRO; i++) { | 1787 | for (i = 0; i < MAX_EEPRO && io[i] != -1; i++) { |
| 1788 | dev = alloc_etherdev(sizeof(struct eepro_local)); | 1788 | dev = alloc_etherdev(sizeof(struct eepro_local)); |
| 1789 | if (!dev) | 1789 | if (!dev) |
| 1790 | break; | 1790 | break; |
diff --git a/drivers/net/eexpress.c b/drivers/net/eexpress.c index 1686dca28748..1f016d66684a 100644 --- a/drivers/net/eexpress.c +++ b/drivers/net/eexpress.c | |||
| @@ -1474,13 +1474,13 @@ static void eexp_hw_init586(struct net_device *dev) | |||
| 1474 | outw(0x0000, ioaddr + 0x800c); | 1474 | outw(0x0000, ioaddr + 0x800c); |
| 1475 | outw(0x0000, ioaddr + 0x800e); | 1475 | outw(0x0000, ioaddr + 0x800e); |
| 1476 | 1476 | ||
| 1477 | for (i = 0; i < (sizeof(start_code)); i+=32) { | 1477 | for (i = 0; i < ARRAY_SIZE(start_code) * 2; i+=32) { |
| 1478 | int j; | 1478 | int j; |
| 1479 | outw(i, ioaddr + SM_PTR); | 1479 | outw(i, ioaddr + SM_PTR); |
| 1480 | for (j = 0; j < 16; j+=2) | 1480 | for (j = 0; j < 16 && (i+j)/2 < ARRAY_SIZE(start_code); j+=2) |
| 1481 | outw(start_code[(i+j)/2], | 1481 | outw(start_code[(i+j)/2], |
| 1482 | ioaddr+0x4000+j); | 1482 | ioaddr+0x4000+j); |
| 1483 | for (j = 0; j < 16; j+=2) | 1483 | for (j = 0; j < 16 && (i+j+16)/2 < ARRAY_SIZE(start_code); j+=2) |
| 1484 | outw(start_code[(i+j+16)/2], | 1484 | outw(start_code[(i+j+16)/2], |
| 1485 | ioaddr+0x8000+j); | 1485 | ioaddr+0x8000+j); |
| 1486 | } | 1486 | } |
diff --git a/drivers/net/ehea/ehea.h b/drivers/net/ehea/ehea.h index 78952f8324e2..fa311a950996 100644 --- a/drivers/net/ehea/ehea.h +++ b/drivers/net/ehea/ehea.h | |||
| @@ -40,7 +40,7 @@ | |||
| 40 | #include <asm/io.h> | 40 | #include <asm/io.h> |
| 41 | 41 | ||
| 42 | #define DRV_NAME "ehea" | 42 | #define DRV_NAME "ehea" |
| 43 | #define DRV_VERSION "EHEA_0101" | 43 | #define DRV_VERSION "EHEA_0102" |
| 44 | 44 | ||
| 45 | /* eHEA capability flags */ | 45 | /* eHEA capability flags */ |
| 46 | #define DLPAR_PORT_ADD_REM 1 | 46 | #define DLPAR_PORT_ADD_REM 1 |
diff --git a/drivers/net/ehea/ehea_main.c b/drivers/net/ehea/ehea_main.c index e8d46cc1bec2..977c3d358279 100644 --- a/drivers/net/ehea/ehea_main.c +++ b/drivers/net/ehea/ehea_main.c | |||
| @@ -1545,6 +1545,9 @@ static int ehea_clean_portres(struct ehea_port *port, struct ehea_port_res *pr) | |||
| 1545 | { | 1545 | { |
| 1546 | int ret, i; | 1546 | int ret, i; |
| 1547 | 1547 | ||
| 1548 | if (pr->qp) | ||
| 1549 | netif_napi_del(&pr->napi); | ||
| 1550 | |||
| 1548 | ret = ehea_destroy_qp(pr->qp); | 1551 | ret = ehea_destroy_qp(pr->qp); |
| 1549 | 1552 | ||
| 1550 | if (!ret) { | 1553 | if (!ret) { |
diff --git a/drivers/net/fealnx.c b/drivers/net/fealnx.c index 48385c42ab57..160655d24581 100644 --- a/drivers/net/fealnx.c +++ b/drivers/net/fealnx.c | |||
| @@ -584,7 +584,8 @@ static int __devinit fealnx_init_one(struct pci_dev *pdev, | |||
| 584 | if (np->flags == HAS_MII_XCVR) { | 584 | if (np->flags == HAS_MII_XCVR) { |
| 585 | int phy, phy_idx = 0; | 585 | int phy, phy_idx = 0; |
| 586 | 586 | ||
| 587 | for (phy = 1; phy < 32 && phy_idx < 4; phy++) { | 587 | for (phy = 1; phy < 32 && phy_idx < ARRAY_SIZE(np->phys); |
| 588 | phy++) { | ||
| 588 | int mii_status = mdio_read(dev, phy, 1); | 589 | int mii_status = mdio_read(dev, phy, 1); |
| 589 | 590 | ||
| 590 | if (mii_status != 0xffff && mii_status != 0x0000) { | 591 | if (mii_status != 0xffff && mii_status != 0x0000) { |
diff --git a/drivers/net/fec.c b/drivers/net/fec.c index d4b98074b1b7..c9fd82d3a80d 100644 --- a/drivers/net/fec.c +++ b/drivers/net/fec.c | |||
| @@ -285,6 +285,7 @@ fec_enet_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 285 | { | 285 | { |
| 286 | struct fec_enet_private *fep = netdev_priv(dev); | 286 | struct fec_enet_private *fep = netdev_priv(dev); |
| 287 | struct bufdesc *bdp; | 287 | struct bufdesc *bdp; |
| 288 | void *bufaddr; | ||
| 288 | unsigned short status; | 289 | unsigned short status; |
| 289 | unsigned long flags; | 290 | unsigned long flags; |
| 290 | 291 | ||
| @@ -312,7 +313,7 @@ fec_enet_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 312 | status &= ~BD_ENET_TX_STATS; | 313 | status &= ~BD_ENET_TX_STATS; |
| 313 | 314 | ||
| 314 | /* Set buffer length and buffer pointer */ | 315 | /* Set buffer length and buffer pointer */ |
| 315 | bdp->cbd_bufaddr = __pa(skb->data); | 316 | bufaddr = skb->data; |
| 316 | bdp->cbd_datlen = skb->len; | 317 | bdp->cbd_datlen = skb->len; |
| 317 | 318 | ||
| 318 | /* | 319 | /* |
| @@ -320,11 +321,11 @@ fec_enet_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 320 | * 4-byte boundaries. Use bounce buffers to copy data | 321 | * 4-byte boundaries. Use bounce buffers to copy data |
| 321 | * and get it aligned. Ugh. | 322 | * and get it aligned. Ugh. |
| 322 | */ | 323 | */ |
| 323 | if (bdp->cbd_bufaddr & FEC_ALIGNMENT) { | 324 | if (((unsigned long) bufaddr) & FEC_ALIGNMENT) { |
| 324 | unsigned int index; | 325 | unsigned int index; |
| 325 | index = bdp - fep->tx_bd_base; | 326 | index = bdp - fep->tx_bd_base; |
| 326 | memcpy(fep->tx_bounce[index], (void *)skb->data, skb->len); | 327 | memcpy(fep->tx_bounce[index], (void *)skb->data, skb->len); |
| 327 | bdp->cbd_bufaddr = __pa(fep->tx_bounce[index]); | 328 | bufaddr = fep->tx_bounce[index]; |
| 328 | } | 329 | } |
| 329 | 330 | ||
| 330 | /* Save skb pointer */ | 331 | /* Save skb pointer */ |
| @@ -336,7 +337,7 @@ fec_enet_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 336 | /* Push the data cache so the CPM does not get stale memory | 337 | /* Push the data cache so the CPM does not get stale memory |
| 337 | * data. | 338 | * data. |
| 338 | */ | 339 | */ |
| 339 | bdp->cbd_bufaddr = dma_map_single(&dev->dev, skb->data, | 340 | bdp->cbd_bufaddr = dma_map_single(&dev->dev, bufaddr, |
| 340 | FEC_ENET_TX_FRSIZE, DMA_TO_DEVICE); | 341 | FEC_ENET_TX_FRSIZE, DMA_TO_DEVICE); |
| 341 | 342 | ||
| 342 | /* Send it on its way. Tell FEC it's ready, interrupt when done, | 343 | /* Send it on its way. Tell FEC it's ready, interrupt when done, |
diff --git a/drivers/net/fec_mpc52xx.c b/drivers/net/fec_mpc52xx.c index cc786333d95c..c40113f58963 100644 --- a/drivers/net/fec_mpc52xx.c +++ b/drivers/net/fec_mpc52xx.c | |||
| @@ -309,6 +309,7 @@ static int mpc52xx_fec_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 309 | { | 309 | { |
| 310 | struct mpc52xx_fec_priv *priv = netdev_priv(dev); | 310 | struct mpc52xx_fec_priv *priv = netdev_priv(dev); |
| 311 | struct bcom_fec_bd *bd; | 311 | struct bcom_fec_bd *bd; |
| 312 | unsigned long flags; | ||
| 312 | 313 | ||
| 313 | if (bcom_queue_full(priv->tx_dmatsk)) { | 314 | if (bcom_queue_full(priv->tx_dmatsk)) { |
| 314 | if (net_ratelimit()) | 315 | if (net_ratelimit()) |
| @@ -316,7 +317,7 @@ static int mpc52xx_fec_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 316 | return NETDEV_TX_BUSY; | 317 | return NETDEV_TX_BUSY; |
| 317 | } | 318 | } |
| 318 | 319 | ||
| 319 | spin_lock_irq(&priv->lock); | 320 | spin_lock_irqsave(&priv->lock, flags); |
| 320 | dev->trans_start = jiffies; | 321 | dev->trans_start = jiffies; |
| 321 | 322 | ||
| 322 | bd = (struct bcom_fec_bd *) | 323 | bd = (struct bcom_fec_bd *) |
| @@ -332,7 +333,7 @@ static int mpc52xx_fec_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 332 | netif_stop_queue(dev); | 333 | netif_stop_queue(dev); |
| 333 | } | 334 | } |
| 334 | 335 | ||
| 335 | spin_unlock_irq(&priv->lock); | 336 | spin_unlock_irqrestore(&priv->lock, flags); |
| 336 | 337 | ||
| 337 | return NETDEV_TX_OK; | 338 | return NETDEV_TX_OK; |
| 338 | } | 339 | } |
diff --git a/drivers/net/fs_enet/fs_enet-main.c b/drivers/net/fs_enet/fs_enet-main.c index b892c3ad9a74..2bc2d2b20644 100644 --- a/drivers/net/fs_enet/fs_enet-main.c +++ b/drivers/net/fs_enet/fs_enet-main.c | |||
| @@ -754,17 +754,16 @@ static int fs_init_phy(struct net_device *dev) | |||
| 754 | fep->oldlink = 0; | 754 | fep->oldlink = 0; |
| 755 | fep->oldspeed = 0; | 755 | fep->oldspeed = 0; |
| 756 | fep->oldduplex = -1; | 756 | fep->oldduplex = -1; |
| 757 | if(fep->fpi->phy_node) | 757 | |
| 758 | phydev = of_phy_connect(dev, fep->fpi->phy_node, | 758 | phydev = of_phy_connect(dev, fep->fpi->phy_node, &fs_adjust_link, 0, |
| 759 | &fs_adjust_link, 0, | 759 | PHY_INTERFACE_MODE_MII); |
| 760 | PHY_INTERFACE_MODE_MII); | 760 | if (!phydev) { |
| 761 | else { | 761 | phydev = of_phy_connect_fixed_link(dev, &fs_adjust_link, |
| 762 | printk("No phy bus ID specified in BSP code\n"); | 762 | PHY_INTERFACE_MODE_MII); |
| 763 | return -EINVAL; | ||
| 764 | } | 763 | } |
| 765 | if (IS_ERR(phydev)) { | 764 | if (!phydev) { |
| 766 | printk(KERN_ERR "%s: Could not attach to PHY\n", dev->name); | 765 | dev_err(&dev->dev, "Could not attach to PHY\n"); |
| 767 | return PTR_ERR(phydev); | 766 | return -ENODEV; |
| 768 | } | 767 | } |
| 769 | 768 | ||
| 770 | fep->phydev = phydev; | 769 | fep->phydev = phydev; |
| @@ -1005,6 +1004,7 @@ static int __devinit fs_enet_probe(struct of_device *ofdev, | |||
| 1005 | goto out_free_fpi; | 1004 | goto out_free_fpi; |
| 1006 | } | 1005 | } |
| 1007 | 1006 | ||
| 1007 | SET_NETDEV_DEV(ndev, &ofdev->dev); | ||
| 1008 | dev_set_drvdata(&ofdev->dev, ndev); | 1008 | dev_set_drvdata(&ofdev->dev, ndev); |
| 1009 | 1009 | ||
| 1010 | fep = netdev_priv(ndev); | 1010 | fep = netdev_priv(ndev); |
diff --git a/drivers/net/gianfar.c b/drivers/net/gianfar.c index 43d813ed9f45..e212f2c5448b 100644 --- a/drivers/net/gianfar.c +++ b/drivers/net/gianfar.c | |||
| @@ -264,15 +264,6 @@ static int gfar_of_init(struct net_device *dev) | |||
| 264 | priv->device_flags |= FSL_GIANFAR_DEV_HAS_MAGIC_PACKET; | 264 | priv->device_flags |= FSL_GIANFAR_DEV_HAS_MAGIC_PACKET; |
| 265 | 265 | ||
| 266 | priv->phy_node = of_parse_phandle(np, "phy-handle", 0); | 266 | priv->phy_node = of_parse_phandle(np, "phy-handle", 0); |
| 267 | if (!priv->phy_node) { | ||
| 268 | u32 *fixed_link; | ||
| 269 | |||
| 270 | fixed_link = (u32 *)of_get_property(np, "fixed-link", NULL); | ||
| 271 | if (!fixed_link) { | ||
| 272 | err = -ENODEV; | ||
| 273 | goto err_out; | ||
| 274 | } | ||
| 275 | } | ||
| 276 | 267 | ||
| 277 | /* Find the TBI PHY. If it's not there, we don't support SGMII */ | 268 | /* Find the TBI PHY. If it's not there, we don't support SGMII */ |
| 278 | priv->tbi_node = of_parse_phandle(np, "tbi-handle", 0); | 269 | priv->tbi_node = of_parse_phandle(np, "tbi-handle", 0); |
| @@ -659,13 +650,14 @@ static int init_phy(struct net_device *dev) | |||
| 659 | 650 | ||
| 660 | interface = gfar_get_interface(dev); | 651 | interface = gfar_get_interface(dev); |
| 661 | 652 | ||
| 662 | if (priv->phy_node) { | 653 | priv->phydev = of_phy_connect(dev, priv->phy_node, &adjust_link, 0, |
| 663 | priv->phydev = of_phy_connect(dev, priv->phy_node, &adjust_link, | 654 | interface); |
| 664 | 0, interface); | 655 | if (!priv->phydev) |
| 665 | if (!priv->phydev) { | 656 | priv->phydev = of_phy_connect_fixed_link(dev, &adjust_link, |
| 666 | dev_err(&dev->dev, "error: Could not attach to PHY\n"); | 657 | interface); |
| 667 | return -ENODEV; | 658 | if (!priv->phydev) { |
| 668 | } | 659 | dev_err(&dev->dev, "could not attach to PHY\n"); |
| 660 | return -ENODEV; | ||
| 669 | } | 661 | } |
| 670 | 662 | ||
| 671 | if (interface == PHY_INTERFACE_MODE_SGMII) | 663 | if (interface == PHY_INTERFACE_MODE_SGMII) |
| @@ -944,6 +936,7 @@ int startup_gfar(struct net_device *dev) | |||
| 944 | struct gfar __iomem *regs = priv->regs; | 936 | struct gfar __iomem *regs = priv->regs; |
| 945 | int err = 0; | 937 | int err = 0; |
| 946 | u32 rctrl = 0; | 938 | u32 rctrl = 0; |
| 939 | u32 tctrl = 0; | ||
| 947 | u32 attrs = 0; | 940 | u32 attrs = 0; |
| 948 | 941 | ||
| 949 | gfar_write(®s->imask, IMASK_INIT_CLEAR); | 942 | gfar_write(®s->imask, IMASK_INIT_CLEAR); |
| @@ -1119,11 +1112,19 @@ int startup_gfar(struct net_device *dev) | |||
| 1119 | rctrl |= RCTRL_PADDING(priv->padding); | 1112 | rctrl |= RCTRL_PADDING(priv->padding); |
| 1120 | } | 1113 | } |
| 1121 | 1114 | ||
| 1115 | /* keep vlan related bits if it's enabled */ | ||
| 1116 | if (priv->vlgrp) { | ||
| 1117 | rctrl |= RCTRL_VLEX | RCTRL_PRSDEP_INIT; | ||
| 1118 | tctrl |= TCTRL_VLINS; | ||
| 1119 | } | ||
| 1120 | |||
| 1122 | /* Init rctrl based on our settings */ | 1121 | /* Init rctrl based on our settings */ |
| 1123 | gfar_write(&priv->regs->rctrl, rctrl); | 1122 | gfar_write(&priv->regs->rctrl, rctrl); |
| 1124 | 1123 | ||
| 1125 | if (dev->features & NETIF_F_IP_CSUM) | 1124 | if (dev->features & NETIF_F_IP_CSUM) |
| 1126 | gfar_write(&priv->regs->tctrl, TCTRL_INIT_CSUM); | 1125 | tctrl |= TCTRL_INIT_CSUM; |
| 1126 | |||
| 1127 | gfar_write(&priv->regs->tctrl, tctrl); | ||
| 1127 | 1128 | ||
| 1128 | /* Set the extraction length and index */ | 1129 | /* Set the extraction length and index */ |
| 1129 | attrs = ATTRELI_EL(priv->rx_stash_size) | | 1130 | attrs = ATTRELI_EL(priv->rx_stash_size) | |
| @@ -1458,7 +1459,6 @@ static void gfar_vlan_rx_register(struct net_device *dev, | |||
| 1458 | 1459 | ||
| 1459 | /* Enable VLAN tag extraction */ | 1460 | /* Enable VLAN tag extraction */ |
| 1460 | tempval = gfar_read(&priv->regs->rctrl); | 1461 | tempval = gfar_read(&priv->regs->rctrl); |
| 1461 | tempval |= RCTRL_VLEX; | ||
| 1462 | tempval |= (RCTRL_VLEX | RCTRL_PRSDEP_INIT); | 1462 | tempval |= (RCTRL_VLEX | RCTRL_PRSDEP_INIT); |
| 1463 | gfar_write(&priv->regs->rctrl, tempval); | 1463 | gfar_write(&priv->regs->rctrl, tempval); |
| 1464 | } else { | 1464 | } else { |
diff --git a/drivers/net/gianfar_ethtool.c b/drivers/net/gianfar_ethtool.c index dbf06e9313cc..2234118eedbb 100644 --- a/drivers/net/gianfar_ethtool.c +++ b/drivers/net/gianfar_ethtool.c | |||
| @@ -366,9 +366,8 @@ static int gfar_scoalesce(struct net_device *dev, struct ethtool_coalesce *cvals | |||
| 366 | return -EINVAL; | 366 | return -EINVAL; |
| 367 | } | 367 | } |
| 368 | 368 | ||
| 369 | priv->rxic = mk_ic_value( | 369 | priv->rxic = mk_ic_value(cvals->rx_max_coalesced_frames, |
| 370 | gfar_usecs2ticks(priv, cvals->rx_coalesce_usecs), | 370 | gfar_usecs2ticks(priv, cvals->rx_coalesce_usecs)); |
| 371 | cvals->rx_max_coalesced_frames); | ||
| 372 | 371 | ||
| 373 | /* Set up tx coalescing */ | 372 | /* Set up tx coalescing */ |
| 374 | if ((cvals->tx_coalesce_usecs == 0) || | 373 | if ((cvals->tx_coalesce_usecs == 0) || |
| @@ -390,9 +389,8 @@ static int gfar_scoalesce(struct net_device *dev, struct ethtool_coalesce *cvals | |||
| 390 | return -EINVAL; | 389 | return -EINVAL; |
| 391 | } | 390 | } |
| 392 | 391 | ||
| 393 | priv->txic = mk_ic_value( | 392 | priv->txic = mk_ic_value(cvals->tx_max_coalesced_frames, |
| 394 | gfar_usecs2ticks(priv, cvals->tx_coalesce_usecs), | 393 | gfar_usecs2ticks(priv, cvals->tx_coalesce_usecs)); |
| 395 | cvals->tx_max_coalesced_frames); | ||
| 396 | 394 | ||
| 397 | gfar_write(&priv->regs->rxic, 0); | 395 | gfar_write(&priv->regs->rxic, 0); |
| 398 | if (priv->rxcoalescing) | 396 | if (priv->rxcoalescing) |
diff --git a/drivers/net/hamradio/6pack.c b/drivers/net/hamradio/6pack.c index 155160052c8b..981ab530e9ac 100644 --- a/drivers/net/hamradio/6pack.c +++ b/drivers/net/hamradio/6pack.c | |||
| @@ -3,7 +3,7 @@ | |||
| 3 | * devices like TTY. It interfaces between a raw TTY and the | 3 | * devices like TTY. It interfaces between a raw TTY and the |
| 4 | * kernel's AX.25 protocol layers. | 4 | * kernel's AX.25 protocol layers. |
| 5 | * | 5 | * |
| 6 | * Authors: Andreas Könsgen <ajk@iehk.rwth-aachen.de> | 6 | * Authors: Andreas Könsgen <ajk@comnets.uni-bremen.de> |
| 7 | * Ralf Baechle DL5RB <ralf@linux-mips.org> | 7 | * Ralf Baechle DL5RB <ralf@linux-mips.org> |
| 8 | * | 8 | * |
| 9 | * Quite a lot of stuff "stolen" by Joerg Reuter from slip.c, written by | 9 | * Quite a lot of stuff "stolen" by Joerg Reuter from slip.c, written by |
diff --git a/drivers/net/ibm_newemac/core.c b/drivers/net/ibm_newemac/core.c index beb84213b671..f0f890803710 100644 --- a/drivers/net/ibm_newemac/core.c +++ b/drivers/net/ibm_newemac/core.c | |||
| @@ -1305,6 +1305,8 @@ static int emac_close(struct net_device *ndev) | |||
| 1305 | 1305 | ||
| 1306 | free_irq(dev->emac_irq, dev); | 1306 | free_irq(dev->emac_irq, dev); |
| 1307 | 1307 | ||
| 1308 | netif_carrier_off(ndev); | ||
| 1309 | |||
| 1308 | return 0; | 1310 | return 0; |
| 1309 | } | 1311 | } |
| 1310 | 1312 | ||
diff --git a/drivers/net/ibm_newemac/rgmii.c b/drivers/net/ibm_newemac/rgmii.c index 1d5379de6900..8d76cb89dbd6 100644 --- a/drivers/net/ibm_newemac/rgmii.c +++ b/drivers/net/ibm_newemac/rgmii.c | |||
| @@ -188,11 +188,12 @@ void rgmii_put_mdio(struct of_device *ofdev, int input) | |||
| 188 | void rgmii_detach(struct of_device *ofdev, int input) | 188 | void rgmii_detach(struct of_device *ofdev, int input) |
| 189 | { | 189 | { |
| 190 | struct rgmii_instance *dev = dev_get_drvdata(&ofdev->dev); | 190 | struct rgmii_instance *dev = dev_get_drvdata(&ofdev->dev); |
| 191 | struct rgmii_regs __iomem *p = dev->base; | 191 | struct rgmii_regs __iomem *p; |
| 192 | |||
| 193 | mutex_lock(&dev->lock); | ||
| 194 | 192 | ||
| 195 | BUG_ON(!dev || dev->users == 0); | 193 | BUG_ON(!dev || dev->users == 0); |
| 194 | p = dev->base; | ||
| 195 | |||
| 196 | mutex_lock(&dev->lock); | ||
| 196 | 197 | ||
| 197 | RGMII_DBG(dev, "detach(%d)" NL, input); | 198 | RGMII_DBG(dev, "detach(%d)" NL, input); |
| 198 | 199 | ||
diff --git a/drivers/net/igbvf/vf.c b/drivers/net/igbvf/vf.c index 2a4faf9ade69..a9a61efa964c 100644 --- a/drivers/net/igbvf/vf.c +++ b/drivers/net/igbvf/vf.c | |||
| @@ -274,6 +274,8 @@ static s32 e1000_set_vfta_vf(struct e1000_hw *hw, u16 vid, bool set) | |||
| 274 | 274 | ||
| 275 | err = mbx->ops.read_posted(hw, msgbuf, 2); | 275 | err = mbx->ops.read_posted(hw, msgbuf, 2); |
| 276 | 276 | ||
| 277 | msgbuf[0] &= ~E1000_VT_MSGTYPE_CTS; | ||
| 278 | |||
| 277 | /* if nacked the vlan was rejected */ | 279 | /* if nacked the vlan was rejected */ |
| 278 | if (!err && (msgbuf[0] == (E1000_VF_SET_VLAN | E1000_VT_MSGTYPE_NACK))) | 280 | if (!err && (msgbuf[0] == (E1000_VF_SET_VLAN | E1000_VT_MSGTYPE_NACK))) |
| 279 | err = -E1000_ERR_MAC_INIT; | 281 | err = -E1000_ERR_MAC_INIT; |
| @@ -317,6 +319,8 @@ static void e1000_rar_set_vf(struct e1000_hw *hw, u8 * addr, u32 index) | |||
| 317 | if (!ret_val) | 319 | if (!ret_val) |
| 318 | ret_val = mbx->ops.read_posted(hw, msgbuf, 3); | 320 | ret_val = mbx->ops.read_posted(hw, msgbuf, 3); |
| 319 | 321 | ||
| 322 | msgbuf[0] &= ~E1000_VT_MSGTYPE_CTS; | ||
| 323 | |||
| 320 | /* if nacked the address was rejected, use "perm_addr" */ | 324 | /* if nacked the address was rejected, use "perm_addr" */ |
| 321 | if (!ret_val && | 325 | if (!ret_val && |
| 322 | (msgbuf[0] == (E1000_VF_SET_MAC_ADDR | E1000_VT_MSGTYPE_NACK))) | 326 | (msgbuf[0] == (E1000_VF_SET_MAC_ADDR | E1000_VT_MSGTYPE_NACK))) |
diff --git a/drivers/net/irda/au1k_ir.c b/drivers/net/irda/au1k_ir.c index c4361d466597..ee1cff5c9b21 100644 --- a/drivers/net/irda/au1k_ir.c +++ b/drivers/net/irda/au1k_ir.c | |||
| @@ -23,7 +23,6 @@ | |||
| 23 | #include <linux/init.h> | 23 | #include <linux/init.h> |
| 24 | #include <linux/errno.h> | 24 | #include <linux/errno.h> |
| 25 | #include <linux/netdevice.h> | 25 | #include <linux/netdevice.h> |
| 26 | #include <linux/etherdevice.h> | ||
| 27 | #include <linux/slab.h> | 26 | #include <linux/slab.h> |
| 28 | #include <linux/rtnetlink.h> | 27 | #include <linux/rtnetlink.h> |
| 29 | #include <linux/interrupt.h> | 28 | #include <linux/interrupt.h> |
| @@ -205,9 +204,6 @@ static const struct net_device_ops au1k_irda_netdev_ops = { | |||
| 205 | .ndo_start_xmit = au1k_irda_hard_xmit, | 204 | .ndo_start_xmit = au1k_irda_hard_xmit, |
| 206 | .ndo_tx_timeout = au1k_tx_timeout, | 205 | .ndo_tx_timeout = au1k_tx_timeout, |
| 207 | .ndo_do_ioctl = au1k_irda_ioctl, | 206 | .ndo_do_ioctl = au1k_irda_ioctl, |
| 208 | .ndo_change_mtu = eth_change_mtu, | ||
| 209 | .ndo_validate_addr = eth_validate_addr, | ||
| 210 | .ndo_set_mac_address = eth_mac_addr, | ||
| 211 | }; | 207 | }; |
| 212 | 208 | ||
| 213 | static int au1k_irda_net_init(struct net_device *dev) | 209 | static int au1k_irda_net_init(struct net_device *dev) |
diff --git a/drivers/net/irda/pxaficp_ir.c b/drivers/net/irda/pxaficp_ir.c index 3376a4f39e0a..77d10edefd25 100644 --- a/drivers/net/irda/pxaficp_ir.c +++ b/drivers/net/irda/pxaficp_ir.c | |||
| @@ -803,9 +803,6 @@ static const struct net_device_ops pxa_irda_netdev_ops = { | |||
| 803 | .ndo_stop = pxa_irda_stop, | 803 | .ndo_stop = pxa_irda_stop, |
| 804 | .ndo_start_xmit = pxa_irda_hard_xmit, | 804 | .ndo_start_xmit = pxa_irda_hard_xmit, |
| 805 | .ndo_do_ioctl = pxa_irda_ioctl, | 805 | .ndo_do_ioctl = pxa_irda_ioctl, |
| 806 | .ndo_change_mtu = eth_change_mtu, | ||
| 807 | .ndo_validate_addr = eth_validate_addr, | ||
| 808 | .ndo_set_mac_address = eth_mac_addr, | ||
| 809 | }; | 806 | }; |
| 810 | 807 | ||
| 811 | static int pxa_irda_probe(struct platform_device *pdev) | 808 | static int pxa_irda_probe(struct platform_device *pdev) |
| @@ -830,6 +827,7 @@ static int pxa_irda_probe(struct platform_device *pdev) | |||
| 830 | if (!dev) | 827 | if (!dev) |
| 831 | goto err_mem_3; | 828 | goto err_mem_3; |
| 832 | 829 | ||
| 830 | SET_NETDEV_DEV(dev, &pdev->dev); | ||
| 833 | si = netdev_priv(dev); | 831 | si = netdev_priv(dev); |
| 834 | si->dev = &pdev->dev; | 832 | si->dev = &pdev->dev; |
| 835 | si->pdata = pdev->dev.platform_data; | 833 | si->pdata = pdev->dev.platform_data; |
diff --git a/drivers/net/irda/sa1100_ir.c b/drivers/net/irda/sa1100_ir.c index 2aeb2e6aec1b..b039cb081e94 100644 --- a/drivers/net/irda/sa1100_ir.c +++ b/drivers/net/irda/sa1100_ir.c | |||
| @@ -24,7 +24,6 @@ | |||
| 24 | #include <linux/init.h> | 24 | #include <linux/init.h> |
| 25 | #include <linux/errno.h> | 25 | #include <linux/errno.h> |
| 26 | #include <linux/netdevice.h> | 26 | #include <linux/netdevice.h> |
| 27 | #include <linux/etherdevice.h> | ||
| 28 | #include <linux/slab.h> | 27 | #include <linux/slab.h> |
| 29 | #include <linux/rtnetlink.h> | 28 | #include <linux/rtnetlink.h> |
| 30 | #include <linux/interrupt.h> | 29 | #include <linux/interrupt.h> |
| @@ -881,9 +880,6 @@ static const struct net_device_ops sa1100_irda_netdev_ops = { | |||
| 881 | .ndo_stop = sa1100_irda_stop, | 880 | .ndo_stop = sa1100_irda_stop, |
| 882 | .ndo_start_xmit = sa1100_irda_hard_xmit, | 881 | .ndo_start_xmit = sa1100_irda_hard_xmit, |
| 883 | .ndo_do_ioctl = sa1100_irda_ioctl, | 882 | .ndo_do_ioctl = sa1100_irda_ioctl, |
| 884 | .ndo_change_mtu = eth_change_mtu, | ||
| 885 | .ndo_validate_addr = eth_validate_addr, | ||
| 886 | .ndo_set_mac_address = eth_mac_addr, | ||
| 887 | }; | 883 | }; |
| 888 | 884 | ||
| 889 | static int sa1100_irda_probe(struct platform_device *pdev) | 885 | static int sa1100_irda_probe(struct platform_device *pdev) |
diff --git a/drivers/net/irda/w83977af_ir.c b/drivers/net/irda/w83977af_ir.c index d0883835b0c6..fe4f2b2bff96 100644 --- a/drivers/net/irda/w83977af_ir.c +++ b/drivers/net/irda/w83977af_ir.c | |||
| @@ -115,7 +115,7 @@ static int __init w83977af_init(void) | |||
| 115 | 115 | ||
| 116 | IRDA_DEBUG(0, "%s()\n", __func__ ); | 116 | IRDA_DEBUG(0, "%s()\n", __func__ ); |
| 117 | 117 | ||
| 118 | for (i=0; (io[i] < 2000) && (i < ARRAY_SIZE(dev_self)); i++) { | 118 | for (i=0; i < ARRAY_SIZE(dev_self) && io[i] < 2000; i++) { |
| 119 | if (w83977af_open(i, io[i], irq[i], dma[i]) == 0) | 119 | if (w83977af_open(i, io[i], irq[i], dma[i]) == 0) |
| 120 | return 0; | 120 | return 0; |
| 121 | } | 121 | } |
diff --git a/drivers/net/ixgbe/ixgbe.h b/drivers/net/ixgbe/ixgbe.h index cd22323cfd22..2c4dc8221dcd 100644 --- a/drivers/net/ixgbe/ixgbe.h +++ b/drivers/net/ixgbe/ixgbe.h | |||
| @@ -96,6 +96,8 @@ | |||
| 96 | #define IXGBE_TX_FLAGS_VLAN_PRIO_MASK 0x0000e000 | 96 | #define IXGBE_TX_FLAGS_VLAN_PRIO_MASK 0x0000e000 |
| 97 | #define IXGBE_TX_FLAGS_VLAN_SHIFT 16 | 97 | #define IXGBE_TX_FLAGS_VLAN_SHIFT 16 |
| 98 | 98 | ||
| 99 | #define IXGBE_MAX_RSC_INT_RATE 162760 | ||
| 100 | |||
| 99 | /* wrapper around a pointer to a socket buffer, | 101 | /* wrapper around a pointer to a socket buffer, |
| 100 | * so a DMA handle can be stored along with the buffer */ | 102 | * so a DMA handle can be stored along with the buffer */ |
| 101 | struct ixgbe_tx_buffer { | 103 | struct ixgbe_tx_buffer { |
| @@ -134,6 +136,8 @@ struct ixgbe_ring { | |||
| 134 | 136 | ||
| 135 | u8 queue_index; /* needed for multiqueue queue management */ | 137 | u8 queue_index; /* needed for multiqueue queue management */ |
| 136 | 138 | ||
| 139 | #define IXGBE_RING_RX_PS_ENABLED (u8)(1) | ||
| 140 | u8 flags; /* per ring feature flags */ | ||
| 137 | u16 head; | 141 | u16 head; |
| 138 | u16 tail; | 142 | u16 tail; |
| 139 | 143 | ||
| @@ -327,6 +331,7 @@ struct ixgbe_adapter { | |||
| 327 | #define IXGBE_FLAG_IN_SFP_MOD_TASK (u32)(1 << 25) | 331 | #define IXGBE_FLAG_IN_SFP_MOD_TASK (u32)(1 << 25) |
| 328 | #define IXGBE_FLAG_FDIR_HASH_CAPABLE (u32)(1 << 26) | 332 | #define IXGBE_FLAG_FDIR_HASH_CAPABLE (u32)(1 << 26) |
| 329 | #define IXGBE_FLAG_FDIR_PERFECT_CAPABLE (u32)(1 << 27) | 333 | #define IXGBE_FLAG_FDIR_PERFECT_CAPABLE (u32)(1 << 27) |
| 334 | #define IXGBE_FLAG_FCOE_CAPABLE (u32)(1 << 28) | ||
| 330 | #define IXGBE_FLAG_FCOE_ENABLED (u32)(1 << 29) | 335 | #define IXGBE_FLAG_FCOE_ENABLED (u32)(1 << 29) |
| 331 | 336 | ||
| 332 | u32 flags2; | 337 | u32 flags2; |
diff --git a/drivers/net/ixgbe/ixgbe_82598.c b/drivers/net/ixgbe/ixgbe_82598.c index b9923047ce11..522c03bc1dad 100644 --- a/drivers/net/ixgbe/ixgbe_82598.c +++ b/drivers/net/ixgbe/ixgbe_82598.c | |||
| @@ -50,6 +50,51 @@ static s32 ixgbe_read_i2c_eeprom_82598(struct ixgbe_hw *hw, u8 byte_offset, | |||
| 50 | u8 *eeprom_data); | 50 | u8 *eeprom_data); |
| 51 | 51 | ||
| 52 | /** | 52 | /** |
| 53 | * ixgbe_set_pcie_completion_timeout - set pci-e completion timeout | ||
| 54 | * @hw: pointer to the HW structure | ||
| 55 | * | ||
| 56 | * The defaults for 82598 should be in the range of 50us to 50ms, | ||
| 57 | * however the hardware default for these parts is 500us to 1ms which is less | ||
| 58 | * than the 10ms recommended by the pci-e spec. To address this we need to | ||
| 59 | * increase the value to either 10ms to 250ms for capability version 1 config, | ||
| 60 | * or 16ms to 55ms for version 2. | ||
| 61 | **/ | ||
| 62 | void ixgbe_set_pcie_completion_timeout(struct ixgbe_hw *hw) | ||
| 63 | { | ||
| 64 | struct ixgbe_adapter *adapter = hw->back; | ||
| 65 | u32 gcr = IXGBE_READ_REG(hw, IXGBE_GCR); | ||
| 66 | u16 pcie_devctl2; | ||
| 67 | |||
| 68 | /* only take action if timeout value is defaulted to 0 */ | ||
| 69 | if (gcr & IXGBE_GCR_CMPL_TMOUT_MASK) | ||
| 70 | goto out; | ||
| 71 | |||
| 72 | /* | ||
| 73 | * if capababilities version is type 1 we can write the | ||
| 74 | * timeout of 10ms to 250ms through the GCR register | ||
| 75 | */ | ||
| 76 | if (!(gcr & IXGBE_GCR_CAP_VER2)) { | ||
| 77 | gcr |= IXGBE_GCR_CMPL_TMOUT_10ms; | ||
| 78 | goto out; | ||
| 79 | } | ||
| 80 | |||
| 81 | /* | ||
| 82 | * for version 2 capabilities we need to write the config space | ||
| 83 | * directly in order to set the completion timeout value for | ||
| 84 | * 16ms to 55ms | ||
| 85 | */ | ||
| 86 | pci_read_config_word(adapter->pdev, | ||
| 87 | IXGBE_PCI_DEVICE_CONTROL2, &pcie_devctl2); | ||
| 88 | pcie_devctl2 |= IXGBE_PCI_DEVICE_CONTROL2_16ms; | ||
| 89 | pci_write_config_word(adapter->pdev, | ||
| 90 | IXGBE_PCI_DEVICE_CONTROL2, pcie_devctl2); | ||
| 91 | out: | ||
| 92 | /* disable completion timeout resend */ | ||
| 93 | gcr &= ~IXGBE_GCR_CMPL_TMOUT_RESEND; | ||
| 94 | IXGBE_WRITE_REG(hw, IXGBE_GCR, gcr); | ||
| 95 | } | ||
| 96 | |||
| 97 | /** | ||
| 53 | * ixgbe_get_pcie_msix_count_82598 - Gets MSI-X vector count | 98 | * ixgbe_get_pcie_msix_count_82598 - Gets MSI-X vector count |
| 54 | * @hw: pointer to hardware structure | 99 | * @hw: pointer to hardware structure |
| 55 | * | 100 | * |
| @@ -153,6 +198,26 @@ out: | |||
| 153 | } | 198 | } |
| 154 | 199 | ||
| 155 | /** | 200 | /** |
| 201 | * ixgbe_start_hw_82598 - Prepare hardware for Tx/Rx | ||
| 202 | * @hw: pointer to hardware structure | ||
| 203 | * | ||
| 204 | * Starts the hardware using the generic start_hw function. | ||
| 205 | * Then set pcie completion timeout | ||
| 206 | **/ | ||
| 207 | s32 ixgbe_start_hw_82598(struct ixgbe_hw *hw) | ||
| 208 | { | ||
| 209 | s32 ret_val = 0; | ||
| 210 | |||
| 211 | ret_val = ixgbe_start_hw_generic(hw); | ||
| 212 | |||
| 213 | /* set the completion timeout for interface */ | ||
| 214 | if (ret_val == 0) | ||
| 215 | ixgbe_set_pcie_completion_timeout(hw); | ||
| 216 | |||
| 217 | return ret_val; | ||
| 218 | } | ||
| 219 | |||
| 220 | /** | ||
| 156 | * ixgbe_get_link_capabilities_82598 - Determines link capabilities | 221 | * ixgbe_get_link_capabilities_82598 - Determines link capabilities |
| 157 | * @hw: pointer to hardware structure | 222 | * @hw: pointer to hardware structure |
| 158 | * @speed: pointer to link speed | 223 | * @speed: pointer to link speed |
| @@ -1085,7 +1150,7 @@ out: | |||
| 1085 | static struct ixgbe_mac_operations mac_ops_82598 = { | 1150 | static struct ixgbe_mac_operations mac_ops_82598 = { |
| 1086 | .init_hw = &ixgbe_init_hw_generic, | 1151 | .init_hw = &ixgbe_init_hw_generic, |
| 1087 | .reset_hw = &ixgbe_reset_hw_82598, | 1152 | .reset_hw = &ixgbe_reset_hw_82598, |
| 1088 | .start_hw = &ixgbe_start_hw_generic, | 1153 | .start_hw = &ixgbe_start_hw_82598, |
| 1089 | .clear_hw_cntrs = &ixgbe_clear_hw_cntrs_generic, | 1154 | .clear_hw_cntrs = &ixgbe_clear_hw_cntrs_generic, |
| 1090 | .get_media_type = &ixgbe_get_media_type_82598, | 1155 | .get_media_type = &ixgbe_get_media_type_82598, |
| 1091 | .get_supported_physical_layer = &ixgbe_get_supported_physical_layer_82598, | 1156 | .get_supported_physical_layer = &ixgbe_get_supported_physical_layer_82598, |
diff --git a/drivers/net/ixgbe/ixgbe_dcb_nl.c b/drivers/net/ixgbe/ixgbe_dcb_nl.c index 7c5978ad929a..1c7265732900 100644 --- a/drivers/net/ixgbe/ixgbe_dcb_nl.c +++ b/drivers/net/ixgbe/ixgbe_dcb_nl.c | |||
| @@ -106,8 +106,6 @@ static u8 ixgbe_dcbnl_get_state(struct net_device *netdev) | |||
| 106 | { | 106 | { |
| 107 | struct ixgbe_adapter *adapter = netdev_priv(netdev); | 107 | struct ixgbe_adapter *adapter = netdev_priv(netdev); |
| 108 | 108 | ||
| 109 | DPRINTK(DRV, INFO, "Get DCB Admin Mode.\n"); | ||
| 110 | |||
| 111 | return !!(adapter->flags & IXGBE_FLAG_DCB_ENABLED); | 109 | return !!(adapter->flags & IXGBE_FLAG_DCB_ENABLED); |
| 112 | } | 110 | } |
| 113 | 111 | ||
| @@ -116,8 +114,6 @@ static u8 ixgbe_dcbnl_set_state(struct net_device *netdev, u8 state) | |||
| 116 | u8 err = 0; | 114 | u8 err = 0; |
| 117 | struct ixgbe_adapter *adapter = netdev_priv(netdev); | 115 | struct ixgbe_adapter *adapter = netdev_priv(netdev); |
| 118 | 116 | ||
| 119 | DPRINTK(DRV, INFO, "Set DCB Admin Mode.\n"); | ||
| 120 | |||
| 121 | if (state > 0) { | 117 | if (state > 0) { |
| 122 | /* Turn on DCB */ | 118 | /* Turn on DCB */ |
| 123 | if (adapter->flags & IXGBE_FLAG_DCB_ENABLED) | 119 | if (adapter->flags & IXGBE_FLAG_DCB_ENABLED) |
| @@ -143,6 +139,18 @@ static u8 ixgbe_dcbnl_set_state(struct net_device *netdev, u8 state) | |||
| 143 | adapter->flags &= ~IXGBE_FLAG_FDIR_PERFECT_CAPABLE; | 139 | adapter->flags &= ~IXGBE_FLAG_FDIR_PERFECT_CAPABLE; |
| 144 | } | 140 | } |
| 145 | adapter->flags |= IXGBE_FLAG_DCB_ENABLED; | 141 | adapter->flags |= IXGBE_FLAG_DCB_ENABLED; |
| 142 | #ifdef IXGBE_FCOE | ||
| 143 | /* Turn on FCoE offload */ | ||
| 144 | if ((adapter->flags & IXGBE_FLAG_FCOE_CAPABLE) && | ||
| 145 | (!(adapter->flags & IXGBE_FLAG_FCOE_ENABLED))) { | ||
| 146 | adapter->flags |= IXGBE_FLAG_FCOE_ENABLED; | ||
| 147 | adapter->ring_feature[RING_F_FCOE].indices = | ||
| 148 | IXGBE_FCRETA_SIZE; | ||
| 149 | netdev->features |= NETIF_F_FCOE_CRC; | ||
| 150 | netdev->features |= NETIF_F_FSO; | ||
| 151 | netdev->fcoe_ddp_xid = IXGBE_FCOE_DDP_MAX - 1; | ||
| 152 | } | ||
| 153 | #endif /* IXGBE_FCOE */ | ||
| 146 | ixgbe_init_interrupt_scheme(adapter); | 154 | ixgbe_init_interrupt_scheme(adapter); |
| 147 | if (netif_running(netdev)) | 155 | if (netif_running(netdev)) |
| 148 | netdev->netdev_ops->ndo_open(netdev); | 156 | netdev->netdev_ops->ndo_open(netdev); |
| @@ -160,6 +168,18 @@ static u8 ixgbe_dcbnl_set_state(struct net_device *netdev, u8 state) | |||
| 160 | adapter->flags |= IXGBE_FLAG_RSS_ENABLED; | 168 | adapter->flags |= IXGBE_FLAG_RSS_ENABLED; |
| 161 | if (adapter->hw.mac.type == ixgbe_mac_82599EB) | 169 | if (adapter->hw.mac.type == ixgbe_mac_82599EB) |
| 162 | adapter->flags |= IXGBE_FLAG_FDIR_HASH_CAPABLE; | 170 | adapter->flags |= IXGBE_FLAG_FDIR_HASH_CAPABLE; |
| 171 | |||
| 172 | #ifdef IXGBE_FCOE | ||
| 173 | /* Turn off FCoE offload */ | ||
| 174 | if (adapter->flags & (IXGBE_FLAG_FCOE_CAPABLE | | ||
| 175 | IXGBE_FLAG_FCOE_ENABLED)) { | ||
| 176 | adapter->flags &= ~IXGBE_FLAG_FCOE_ENABLED; | ||
| 177 | adapter->ring_feature[RING_F_FCOE].indices = 0; | ||
| 178 | netdev->features &= ~NETIF_F_FCOE_CRC; | ||
| 179 | netdev->features &= ~NETIF_F_FSO; | ||
| 180 | netdev->fcoe_ddp_xid = 0; | ||
| 181 | } | ||
| 182 | #endif /* IXGBE_FCOE */ | ||
| 163 | ixgbe_init_interrupt_scheme(adapter); | 183 | ixgbe_init_interrupt_scheme(adapter); |
| 164 | if (netif_running(netdev)) | 184 | if (netif_running(netdev)) |
| 165 | netdev->netdev_ops->ndo_open(netdev); | 185 | netdev->netdev_ops->ndo_open(netdev); |
| @@ -175,6 +195,8 @@ static void ixgbe_dcbnl_get_perm_hw_addr(struct net_device *netdev, | |||
| 175 | struct ixgbe_adapter *adapter = netdev_priv(netdev); | 195 | struct ixgbe_adapter *adapter = netdev_priv(netdev); |
| 176 | int i, j; | 196 | int i, j; |
| 177 | 197 | ||
| 198 | memset(perm_addr, 0xff, MAX_ADDR_LEN); | ||
| 199 | |||
| 178 | for (i = 0; i < netdev->addr_len; i++) | 200 | for (i = 0; i < netdev->addr_len; i++) |
| 179 | perm_addr[i] = adapter->hw.mac.perm_addr[i]; | 201 | perm_addr[i] = adapter->hw.mac.perm_addr[i]; |
| 180 | 202 | ||
diff --git a/drivers/net/ixgbe/ixgbe_ethtool.c b/drivers/net/ixgbe/ixgbe_ethtool.c index 2a978008fd6e..dff8dfac7ed9 100644 --- a/drivers/net/ixgbe/ixgbe_ethtool.c +++ b/drivers/net/ixgbe/ixgbe_ethtool.c | |||
| @@ -1948,6 +1948,7 @@ static int ixgbe_set_coalesce(struct net_device *netdev, | |||
| 1948 | struct ethtool_coalesce *ec) | 1948 | struct ethtool_coalesce *ec) |
| 1949 | { | 1949 | { |
| 1950 | struct ixgbe_adapter *adapter = netdev_priv(netdev); | 1950 | struct ixgbe_adapter *adapter = netdev_priv(netdev); |
| 1951 | struct ixgbe_q_vector *q_vector; | ||
| 1951 | int i; | 1952 | int i; |
| 1952 | 1953 | ||
| 1953 | if (ec->tx_max_coalesced_frames_irq) | 1954 | if (ec->tx_max_coalesced_frames_irq) |
| @@ -1975,18 +1976,31 @@ static int ixgbe_set_coalesce(struct net_device *netdev, | |||
| 1975 | * any other value means disable eitr, which is best | 1976 | * any other value means disable eitr, which is best |
| 1976 | * served by setting the interrupt rate very high | 1977 | * served by setting the interrupt rate very high |
| 1977 | */ | 1978 | */ |
| 1978 | adapter->eitr_param = IXGBE_MAX_INT_RATE; | 1979 | if (adapter->flags2 & IXGBE_FLAG2_RSC_ENABLED) |
| 1980 | adapter->eitr_param = IXGBE_MAX_RSC_INT_RATE; | ||
| 1981 | else | ||
| 1982 | adapter->eitr_param = IXGBE_MAX_INT_RATE; | ||
| 1979 | adapter->itr_setting = 0; | 1983 | adapter->itr_setting = 0; |
| 1980 | } | 1984 | } |
| 1981 | 1985 | ||
| 1982 | for (i = 0; i < adapter->num_msix_vectors - NON_Q_VECTORS; i++) { | 1986 | /* MSI/MSIx Interrupt Mode */ |
| 1983 | struct ixgbe_q_vector *q_vector = adapter->q_vector[i]; | 1987 | if (adapter->flags & |
| 1984 | if (q_vector->txr_count && !q_vector->rxr_count) | 1988 | (IXGBE_FLAG_MSIX_ENABLED | IXGBE_FLAG_MSI_ENABLED)) { |
| 1985 | /* tx vector gets half the rate */ | 1989 | int num_vectors = adapter->num_msix_vectors - NON_Q_VECTORS; |
| 1986 | q_vector->eitr = (adapter->eitr_param >> 1); | 1990 | for (i = 0; i < num_vectors; i++) { |
| 1987 | else | 1991 | q_vector = adapter->q_vector[i]; |
| 1988 | /* rx only or mixed */ | 1992 | if (q_vector->txr_count && !q_vector->rxr_count) |
| 1989 | q_vector->eitr = adapter->eitr_param; | 1993 | /* tx vector gets half the rate */ |
| 1994 | q_vector->eitr = (adapter->eitr_param >> 1); | ||
| 1995 | else | ||
| 1996 | /* rx only or mixed */ | ||
| 1997 | q_vector->eitr = adapter->eitr_param; | ||
| 1998 | ixgbe_write_eitr(q_vector); | ||
| 1999 | } | ||
| 2000 | /* Legacy Interrupt Mode */ | ||
| 2001 | } else { | ||
| 2002 | q_vector = adapter->q_vector[0]; | ||
| 2003 | q_vector->eitr = adapter->eitr_param; | ||
| 1990 | ixgbe_write_eitr(q_vector); | 2004 | ixgbe_write_eitr(q_vector); |
| 1991 | } | 2005 | } |
| 1992 | 2006 | ||
| @@ -1999,13 +2013,13 @@ static int ixgbe_set_flags(struct net_device *netdev, u32 data) | |||
| 1999 | 2013 | ||
| 2000 | ethtool_op_set_flags(netdev, data); | 2014 | ethtool_op_set_flags(netdev, data); |
| 2001 | 2015 | ||
| 2002 | if (!(adapter->flags & IXGBE_FLAG2_RSC_CAPABLE)) | 2016 | if (!(adapter->flags2 & IXGBE_FLAG2_RSC_CAPABLE)) |
| 2003 | return 0; | 2017 | return 0; |
| 2004 | 2018 | ||
| 2005 | /* if state changes we need to update adapter->flags and reset */ | 2019 | /* if state changes we need to update adapter->flags and reset */ |
| 2006 | if ((!!(data & ETH_FLAG_LRO)) != | 2020 | if ((!!(data & ETH_FLAG_LRO)) != |
| 2007 | (!!(adapter->flags & IXGBE_FLAG2_RSC_ENABLED))) { | 2021 | (!!(adapter->flags2 & IXGBE_FLAG2_RSC_ENABLED))) { |
| 2008 | adapter->flags ^= IXGBE_FLAG2_RSC_ENABLED; | 2022 | adapter->flags2 ^= IXGBE_FLAG2_RSC_ENABLED; |
| 2009 | if (netif_running(netdev)) | 2023 | if (netif_running(netdev)) |
| 2010 | ixgbe_reinit_locked(adapter); | 2024 | ixgbe_reinit_locked(adapter); |
| 2011 | else | 2025 | else |
diff --git a/drivers/net/ixgbe/ixgbe_fcoe.c b/drivers/net/ixgbe/ixgbe_fcoe.c index fa9f24e23683..28cf104e36cc 100644 --- a/drivers/net/ixgbe/ixgbe_fcoe.c +++ b/drivers/net/ixgbe/ixgbe_fcoe.c | |||
| @@ -336,7 +336,7 @@ int ixgbe_fcoe_ddp(struct ixgbe_adapter *adapter, | |||
| 336 | /* return 0 to bypass going to ULD for DDPed data */ | 336 | /* return 0 to bypass going to ULD for DDPed data */ |
| 337 | if (fcstat == IXGBE_RXDADV_STAT_FCSTAT_DDP) | 337 | if (fcstat == IXGBE_RXDADV_STAT_FCSTAT_DDP) |
| 338 | rc = 0; | 338 | rc = 0; |
| 339 | else | 339 | else if (ddp->len) |
| 340 | rc = ddp->len; | 340 | rc = ddp->len; |
| 341 | } | 341 | } |
| 342 | 342 | ||
diff --git a/drivers/net/ixgbe/ixgbe_main.c b/drivers/net/ixgbe/ixgbe_main.c index e3442f47f932..77b0381a2b5c 100644 --- a/drivers/net/ixgbe/ixgbe_main.c +++ b/drivers/net/ixgbe/ixgbe_main.c | |||
| @@ -34,6 +34,7 @@ | |||
| 34 | #include <linux/in.h> | 34 | #include <linux/in.h> |
| 35 | #include <linux/ip.h> | 35 | #include <linux/ip.h> |
| 36 | #include <linux/tcp.h> | 36 | #include <linux/tcp.h> |
| 37 | #include <linux/pkt_sched.h> | ||
| 37 | #include <linux/ipv6.h> | 38 | #include <linux/ipv6.h> |
| 38 | #include <net/checksum.h> | 39 | #include <net/checksum.h> |
| 39 | #include <net/ip6_checksum.h> | 40 | #include <net/ip6_checksum.h> |
| @@ -491,12 +492,12 @@ static void ixgbe_receive_skb(struct ixgbe_q_vector *q_vector, | |||
| 491 | 492 | ||
| 492 | skb_record_rx_queue(skb, ring->queue_index); | 493 | skb_record_rx_queue(skb, ring->queue_index); |
| 493 | if (!(adapter->flags & IXGBE_FLAG_IN_NETPOLL)) { | 494 | if (!(adapter->flags & IXGBE_FLAG_IN_NETPOLL)) { |
| 494 | if (adapter->vlgrp && is_vlan && (tag != 0)) | 495 | if (adapter->vlgrp && is_vlan && (tag & VLAN_VID_MASK)) |
| 495 | vlan_gro_receive(napi, adapter->vlgrp, tag, skb); | 496 | vlan_gro_receive(napi, adapter->vlgrp, tag, skb); |
| 496 | else | 497 | else |
| 497 | napi_gro_receive(napi, skb); | 498 | napi_gro_receive(napi, skb); |
| 498 | } else { | 499 | } else { |
| 499 | if (adapter->vlgrp && is_vlan && (tag != 0)) | 500 | if (adapter->vlgrp && is_vlan && (tag & VLAN_VID_MASK)) |
| 500 | vlan_hwaccel_rx(skb, adapter->vlgrp, tag); | 501 | vlan_hwaccel_rx(skb, adapter->vlgrp, tag); |
| 501 | else | 502 | else |
| 502 | netif_rx(skb); | 503 | netif_rx(skb); |
| @@ -510,8 +511,11 @@ static void ixgbe_receive_skb(struct ixgbe_q_vector *q_vector, | |||
| 510 | * @skb: skb currently being received and modified | 511 | * @skb: skb currently being received and modified |
| 511 | **/ | 512 | **/ |
| 512 | static inline void ixgbe_rx_checksum(struct ixgbe_adapter *adapter, | 513 | static inline void ixgbe_rx_checksum(struct ixgbe_adapter *adapter, |
| 513 | u32 status_err, struct sk_buff *skb) | 514 | union ixgbe_adv_rx_desc *rx_desc, |
| 515 | struct sk_buff *skb) | ||
| 514 | { | 516 | { |
| 517 | u32 status_err = le32_to_cpu(rx_desc->wb.upper.status_error); | ||
| 518 | |||
| 515 | skb->ip_summed = CHECKSUM_NONE; | 519 | skb->ip_summed = CHECKSUM_NONE; |
| 516 | 520 | ||
| 517 | /* Rx csum disabled */ | 521 | /* Rx csum disabled */ |
| @@ -529,6 +533,16 @@ static inline void ixgbe_rx_checksum(struct ixgbe_adapter *adapter, | |||
| 529 | return; | 533 | return; |
| 530 | 534 | ||
| 531 | if (status_err & IXGBE_RXDADV_ERR_TCPE) { | 535 | if (status_err & IXGBE_RXDADV_ERR_TCPE) { |
| 536 | u16 pkt_info = rx_desc->wb.lower.lo_dword.hs_rss.pkt_info; | ||
| 537 | |||
| 538 | /* | ||
| 539 | * 82599 errata, UDP frames with a 0 checksum can be marked as | ||
| 540 | * checksum errors. | ||
| 541 | */ | ||
| 542 | if ((pkt_info & IXGBE_RXDADV_PKTTYPE_UDP) && | ||
| 543 | (adapter->hw.mac.type == ixgbe_mac_82599EB)) | ||
| 544 | return; | ||
| 545 | |||
| 532 | adapter->hw_csum_rx_error++; | 546 | adapter->hw_csum_rx_error++; |
| 533 | return; | 547 | return; |
| 534 | } | 548 | } |
| @@ -571,7 +585,7 @@ static void ixgbe_alloc_rx_buffers(struct ixgbe_adapter *adapter, | |||
| 571 | rx_desc = IXGBE_RX_DESC_ADV(*rx_ring, i); | 585 | rx_desc = IXGBE_RX_DESC_ADV(*rx_ring, i); |
| 572 | 586 | ||
| 573 | if (!bi->page_dma && | 587 | if (!bi->page_dma && |
| 574 | (adapter->flags & IXGBE_FLAG_RX_PS_ENABLED)) { | 588 | (rx_ring->flags & IXGBE_RING_RX_PS_ENABLED)) { |
| 575 | if (!bi->page) { | 589 | if (!bi->page) { |
| 576 | bi->page = alloc_page(GFP_ATOMIC); | 590 | bi->page = alloc_page(GFP_ATOMIC); |
| 577 | if (!bi->page) { | 591 | if (!bi->page) { |
| @@ -615,7 +629,7 @@ static void ixgbe_alloc_rx_buffers(struct ixgbe_adapter *adapter, | |||
| 615 | } | 629 | } |
| 616 | /* Refresh the desc even if buffer_addrs didn't change because | 630 | /* Refresh the desc even if buffer_addrs didn't change because |
| 617 | * each write-back erases this info. */ | 631 | * each write-back erases this info. */ |
| 618 | if (adapter->flags & IXGBE_FLAG_RX_PS_ENABLED) { | 632 | if (rx_ring->flags & IXGBE_RING_RX_PS_ENABLED) { |
| 619 | rx_desc->read.pkt_addr = cpu_to_le64(bi->page_dma); | 633 | rx_desc->read.pkt_addr = cpu_to_le64(bi->page_dma); |
| 620 | rx_desc->read.hdr_addr = cpu_to_le64(bi->dma); | 634 | rx_desc->read.hdr_addr = cpu_to_le64(bi->dma); |
| 621 | } else { | 635 | } else { |
| @@ -712,7 +726,7 @@ static bool ixgbe_clean_rx_irq(struct ixgbe_q_vector *q_vector, | |||
| 712 | break; | 726 | break; |
| 713 | (*work_done)++; | 727 | (*work_done)++; |
| 714 | 728 | ||
| 715 | if (adapter->flags & IXGBE_FLAG_RX_PS_ENABLED) { | 729 | if (rx_ring->flags & IXGBE_RING_RX_PS_ENABLED) { |
| 716 | hdr_info = le16_to_cpu(ixgbe_get_hdr_info(rx_desc)); | 730 | hdr_info = le16_to_cpu(ixgbe_get_hdr_info(rx_desc)); |
| 717 | len = (hdr_info & IXGBE_RXDADV_HDRBUFLEN_MASK) >> | 731 | len = (hdr_info & IXGBE_RXDADV_HDRBUFLEN_MASK) >> |
| 718 | IXGBE_RXDADV_HDRBUFLEN_SHIFT; | 732 | IXGBE_RXDADV_HDRBUFLEN_SHIFT; |
| @@ -766,7 +780,7 @@ static bool ixgbe_clean_rx_irq(struct ixgbe_q_vector *q_vector, | |||
| 766 | prefetch(next_rxd); | 780 | prefetch(next_rxd); |
| 767 | cleaned_count++; | 781 | cleaned_count++; |
| 768 | 782 | ||
| 769 | if (adapter->flags & IXGBE_FLAG2_RSC_CAPABLE) | 783 | if (adapter->flags2 & IXGBE_FLAG2_RSC_CAPABLE) |
| 770 | rsc_count = ixgbe_get_rsc_count(rx_desc); | 784 | rsc_count = ixgbe_get_rsc_count(rx_desc); |
| 771 | 785 | ||
| 772 | if (rsc_count) { | 786 | if (rsc_count) { |
| @@ -784,7 +798,7 @@ static bool ixgbe_clean_rx_irq(struct ixgbe_q_vector *q_vector, | |||
| 784 | rx_ring->stats.packets++; | 798 | rx_ring->stats.packets++; |
| 785 | rx_ring->stats.bytes += skb->len; | 799 | rx_ring->stats.bytes += skb->len; |
| 786 | } else { | 800 | } else { |
| 787 | if (adapter->flags & IXGBE_FLAG_RX_PS_ENABLED) { | 801 | if (rx_ring->flags & IXGBE_RING_RX_PS_ENABLED) { |
| 788 | rx_buffer_info->skb = next_buffer->skb; | 802 | rx_buffer_info->skb = next_buffer->skb; |
| 789 | rx_buffer_info->dma = next_buffer->dma; | 803 | rx_buffer_info->dma = next_buffer->dma; |
| 790 | next_buffer->skb = skb; | 804 | next_buffer->skb = skb; |
| @@ -802,7 +816,7 @@ static bool ixgbe_clean_rx_irq(struct ixgbe_q_vector *q_vector, | |||
| 802 | goto next_desc; | 816 | goto next_desc; |
| 803 | } | 817 | } |
| 804 | 818 | ||
| 805 | ixgbe_rx_checksum(adapter, staterr, skb); | 819 | ixgbe_rx_checksum(adapter, rx_desc, skb); |
| 806 | 820 | ||
| 807 | /* probably a little skewed due to removing CRC */ | 821 | /* probably a little skewed due to removing CRC */ |
| 808 | total_rx_bytes += skb->len; | 822 | total_rx_bytes += skb->len; |
| @@ -1884,46 +1898,19 @@ static void ixgbe_configure_tx(struct ixgbe_adapter *adapter) | |||
| 1884 | 1898 | ||
| 1885 | #define IXGBE_SRRCTL_BSIZEHDRSIZE_SHIFT 2 | 1899 | #define IXGBE_SRRCTL_BSIZEHDRSIZE_SHIFT 2 |
| 1886 | 1900 | ||
| 1887 | static void ixgbe_configure_srrctl(struct ixgbe_adapter *adapter, int index) | 1901 | static void ixgbe_configure_srrctl(struct ixgbe_adapter *adapter, |
| 1902 | struct ixgbe_ring *rx_ring) | ||
| 1888 | { | 1903 | { |
| 1889 | struct ixgbe_ring *rx_ring; | ||
| 1890 | u32 srrctl; | 1904 | u32 srrctl; |
| 1891 | int queue0 = 0; | 1905 | int index; |
| 1892 | unsigned long mask; | ||
| 1893 | struct ixgbe_ring_feature *feature = adapter->ring_feature; | 1906 | struct ixgbe_ring_feature *feature = adapter->ring_feature; |
| 1894 | 1907 | ||
| 1895 | if (adapter->hw.mac.type == ixgbe_mac_82599EB) { | 1908 | index = rx_ring->reg_idx; |
| 1896 | if (adapter->flags & IXGBE_FLAG_DCB_ENABLED) { | 1909 | if (adapter->hw.mac.type == ixgbe_mac_82598EB) { |
| 1897 | int dcb_i = feature[RING_F_DCB].indices; | 1910 | unsigned long mask; |
| 1898 | if (dcb_i == 8) | ||
| 1899 | queue0 = index >> 4; | ||
| 1900 | else if (dcb_i == 4) | ||
| 1901 | queue0 = index >> 5; | ||
| 1902 | else | ||
| 1903 | dev_err(&adapter->pdev->dev, "Invalid DCB " | ||
| 1904 | "configuration\n"); | ||
| 1905 | #ifdef IXGBE_FCOE | ||
| 1906 | if (adapter->flags & IXGBE_FLAG_FCOE_ENABLED) { | ||
| 1907 | struct ixgbe_ring_feature *f; | ||
| 1908 | |||
| 1909 | rx_ring = &adapter->rx_ring[queue0]; | ||
| 1910 | f = &adapter->ring_feature[RING_F_FCOE]; | ||
| 1911 | if ((queue0 == 0) && (index > rx_ring->reg_idx)) | ||
| 1912 | queue0 = f->mask + index - | ||
| 1913 | rx_ring->reg_idx - 1; | ||
| 1914 | } | ||
| 1915 | #endif /* IXGBE_FCOE */ | ||
| 1916 | } else { | ||
| 1917 | queue0 = index; | ||
| 1918 | } | ||
| 1919 | } else { | ||
| 1920 | mask = (unsigned long) feature[RING_F_RSS].mask; | 1911 | mask = (unsigned long) feature[RING_F_RSS].mask; |
| 1921 | queue0 = index & mask; | ||
| 1922 | index = index & mask; | 1912 | index = index & mask; |
| 1923 | } | 1913 | } |
| 1924 | |||
| 1925 | rx_ring = &adapter->rx_ring[queue0]; | ||
| 1926 | |||
| 1927 | srrctl = IXGBE_READ_REG(&adapter->hw, IXGBE_SRRCTL(index)); | 1914 | srrctl = IXGBE_READ_REG(&adapter->hw, IXGBE_SRRCTL(index)); |
| 1928 | 1915 | ||
| 1929 | srrctl &= ~IXGBE_SRRCTL_BSIZEHDR_MASK; | 1916 | srrctl &= ~IXGBE_SRRCTL_BSIZEHDR_MASK; |
| @@ -1932,7 +1919,7 @@ static void ixgbe_configure_srrctl(struct ixgbe_adapter *adapter, int index) | |||
| 1932 | srrctl |= (IXGBE_RX_HDR_SIZE << IXGBE_SRRCTL_BSIZEHDRSIZE_SHIFT) & | 1919 | srrctl |= (IXGBE_RX_HDR_SIZE << IXGBE_SRRCTL_BSIZEHDRSIZE_SHIFT) & |
| 1933 | IXGBE_SRRCTL_BSIZEHDR_MASK; | 1920 | IXGBE_SRRCTL_BSIZEHDR_MASK; |
| 1934 | 1921 | ||
| 1935 | if (adapter->flags & IXGBE_FLAG_RX_PS_ENABLED) { | 1922 | if (rx_ring->flags & IXGBE_RING_RX_PS_ENABLED) { |
| 1936 | #if (PAGE_SIZE / 2) > IXGBE_MAX_RXBUFFER | 1923 | #if (PAGE_SIZE / 2) > IXGBE_MAX_RXBUFFER |
| 1937 | srrctl |= IXGBE_MAX_RXBUFFER >> IXGBE_SRRCTL_BSIZEPKT_SHIFT; | 1924 | srrctl |= IXGBE_MAX_RXBUFFER >> IXGBE_SRRCTL_BSIZEPKT_SHIFT; |
| 1938 | #else | 1925 | #else |
| @@ -1988,6 +1975,7 @@ static void ixgbe_configure_rx(struct ixgbe_adapter *adapter) | |||
| 1988 | { | 1975 | { |
| 1989 | u64 rdba; | 1976 | u64 rdba; |
| 1990 | struct ixgbe_hw *hw = &adapter->hw; | 1977 | struct ixgbe_hw *hw = &adapter->hw; |
| 1978 | struct ixgbe_ring *rx_ring; | ||
| 1991 | struct net_device *netdev = adapter->netdev; | 1979 | struct net_device *netdev = adapter->netdev; |
| 1992 | int max_frame = netdev->mtu + ETH_HLEN + ETH_FCS_LEN; | 1980 | int max_frame = netdev->mtu + ETH_HLEN + ETH_FCS_LEN; |
| 1993 | int i, j; | 1981 | int i, j; |
| @@ -2004,11 +1992,6 @@ static void ixgbe_configure_rx(struct ixgbe_adapter *adapter) | |||
| 2004 | /* Decide whether to use packet split mode or not */ | 1992 | /* Decide whether to use packet split mode or not */ |
| 2005 | adapter->flags |= IXGBE_FLAG_RX_PS_ENABLED; | 1993 | adapter->flags |= IXGBE_FLAG_RX_PS_ENABLED; |
| 2006 | 1994 | ||
| 2007 | #ifdef IXGBE_FCOE | ||
| 2008 | if (adapter->flags & IXGBE_FLAG_FCOE_ENABLED) | ||
| 2009 | adapter->flags &= ~IXGBE_FLAG_RX_PS_ENABLED; | ||
| 2010 | #endif /* IXGBE_FCOE */ | ||
| 2011 | |||
| 2012 | /* Set the RX buffer length according to the mode */ | 1995 | /* Set the RX buffer length according to the mode */ |
| 2013 | if (adapter->flags & IXGBE_FLAG_RX_PS_ENABLED) { | 1996 | if (adapter->flags & IXGBE_FLAG_RX_PS_ENABLED) { |
| 2014 | rx_buf_len = IXGBE_RX_HDR_SIZE; | 1997 | rx_buf_len = IXGBE_RX_HDR_SIZE; |
| @@ -2022,7 +2005,7 @@ static void ixgbe_configure_rx(struct ixgbe_adapter *adapter) | |||
| 2022 | IXGBE_WRITE_REG(hw, IXGBE_PSRTYPE(0), psrtype); | 2005 | IXGBE_WRITE_REG(hw, IXGBE_PSRTYPE(0), psrtype); |
| 2023 | } | 2006 | } |
| 2024 | } else { | 2007 | } else { |
| 2025 | if (!(adapter->flags & IXGBE_FLAG2_RSC_ENABLED) && | 2008 | if (!(adapter->flags2 & IXGBE_FLAG2_RSC_ENABLED) && |
| 2026 | (netdev->mtu <= ETH_DATA_LEN)) | 2009 | (netdev->mtu <= ETH_DATA_LEN)) |
| 2027 | rx_buf_len = MAXIMUM_ETHERNET_VLAN_SIZE; | 2010 | rx_buf_len = MAXIMUM_ETHERNET_VLAN_SIZE; |
| 2028 | else | 2011 | else |
| @@ -2056,29 +2039,35 @@ static void ixgbe_configure_rx(struct ixgbe_adapter *adapter) | |||
| 2056 | * the Base and Length of the Rx Descriptor Ring | 2039 | * the Base and Length of the Rx Descriptor Ring |
| 2057 | */ | 2040 | */ |
| 2058 | for (i = 0; i < adapter->num_rx_queues; i++) { | 2041 | for (i = 0; i < adapter->num_rx_queues; i++) { |
| 2059 | rdba = adapter->rx_ring[i].dma; | 2042 | rx_ring = &adapter->rx_ring[i]; |
| 2060 | j = adapter->rx_ring[i].reg_idx; | 2043 | rdba = rx_ring->dma; |
| 2044 | j = rx_ring->reg_idx; | ||
| 2061 | IXGBE_WRITE_REG(hw, IXGBE_RDBAL(j), (rdba & DMA_BIT_MASK(32))); | 2045 | IXGBE_WRITE_REG(hw, IXGBE_RDBAL(j), (rdba & DMA_BIT_MASK(32))); |
| 2062 | IXGBE_WRITE_REG(hw, IXGBE_RDBAH(j), (rdba >> 32)); | 2046 | IXGBE_WRITE_REG(hw, IXGBE_RDBAH(j), (rdba >> 32)); |
| 2063 | IXGBE_WRITE_REG(hw, IXGBE_RDLEN(j), rdlen); | 2047 | IXGBE_WRITE_REG(hw, IXGBE_RDLEN(j), rdlen); |
| 2064 | IXGBE_WRITE_REG(hw, IXGBE_RDH(j), 0); | 2048 | IXGBE_WRITE_REG(hw, IXGBE_RDH(j), 0); |
| 2065 | IXGBE_WRITE_REG(hw, IXGBE_RDT(j), 0); | 2049 | IXGBE_WRITE_REG(hw, IXGBE_RDT(j), 0); |
| 2066 | adapter->rx_ring[i].head = IXGBE_RDH(j); | 2050 | rx_ring->head = IXGBE_RDH(j); |
| 2067 | adapter->rx_ring[i].tail = IXGBE_RDT(j); | 2051 | rx_ring->tail = IXGBE_RDT(j); |
| 2068 | adapter->rx_ring[i].rx_buf_len = rx_buf_len; | 2052 | rx_ring->rx_buf_len = rx_buf_len; |
| 2053 | |||
| 2054 | if (adapter->flags & IXGBE_FLAG_RX_PS_ENABLED) | ||
| 2055 | rx_ring->flags |= IXGBE_RING_RX_PS_ENABLED; | ||
| 2069 | 2056 | ||
| 2070 | #ifdef IXGBE_FCOE | 2057 | #ifdef IXGBE_FCOE |
| 2071 | if (adapter->flags & IXGBE_FLAG_FCOE_ENABLED) { | 2058 | if (adapter->flags & IXGBE_FLAG_FCOE_ENABLED) { |
| 2072 | struct ixgbe_ring_feature *f; | 2059 | struct ixgbe_ring_feature *f; |
| 2073 | f = &adapter->ring_feature[RING_F_FCOE]; | 2060 | f = &adapter->ring_feature[RING_F_FCOE]; |
| 2074 | if ((rx_buf_len < IXGBE_FCOE_JUMBO_FRAME_SIZE) && | 2061 | if ((i >= f->mask) && (i < f->mask + f->indices)) { |
| 2075 | (i >= f->mask) && (i < f->mask + f->indices)) | 2062 | rx_ring->flags &= ~IXGBE_RING_RX_PS_ENABLED; |
| 2076 | adapter->rx_ring[i].rx_buf_len = | 2063 | if (rx_buf_len < IXGBE_FCOE_JUMBO_FRAME_SIZE) |
| 2077 | IXGBE_FCOE_JUMBO_FRAME_SIZE; | 2064 | rx_ring->rx_buf_len = |
| 2065 | IXGBE_FCOE_JUMBO_FRAME_SIZE; | ||
| 2066 | } | ||
| 2078 | } | 2067 | } |
| 2079 | 2068 | ||
| 2080 | #endif /* IXGBE_FCOE */ | 2069 | #endif /* IXGBE_FCOE */ |
| 2081 | ixgbe_configure_srrctl(adapter, j); | 2070 | ixgbe_configure_srrctl(adapter, rx_ring); |
| 2082 | } | 2071 | } |
| 2083 | 2072 | ||
| 2084 | if (hw->mac.type == ixgbe_mac_82598EB) { | 2073 | if (hw->mac.type == ixgbe_mac_82598EB) { |
| @@ -2151,10 +2140,11 @@ static void ixgbe_configure_rx(struct ixgbe_adapter *adapter) | |||
| 2151 | IXGBE_WRITE_REG(hw, IXGBE_RDRXCTL, rdrxctl); | 2140 | IXGBE_WRITE_REG(hw, IXGBE_RDRXCTL, rdrxctl); |
| 2152 | } | 2141 | } |
| 2153 | 2142 | ||
| 2154 | if (adapter->flags & IXGBE_FLAG2_RSC_ENABLED) { | 2143 | if (adapter->flags2 & IXGBE_FLAG2_RSC_ENABLED) { |
| 2155 | /* Enable 82599 HW-RSC */ | 2144 | /* Enable 82599 HW-RSC */ |
| 2156 | for (i = 0; i < adapter->num_rx_queues; i++) { | 2145 | for (i = 0; i < adapter->num_rx_queues; i++) { |
| 2157 | j = adapter->rx_ring[i].reg_idx; | 2146 | rx_ring = &adapter->rx_ring[i]; |
| 2147 | j = rx_ring->reg_idx; | ||
| 2158 | rscctrl = IXGBE_READ_REG(hw, IXGBE_RSCCTL(j)); | 2148 | rscctrl = IXGBE_READ_REG(hw, IXGBE_RSCCTL(j)); |
| 2159 | rscctrl |= IXGBE_RSCCTL_RSCEN; | 2149 | rscctrl |= IXGBE_RSCCTL_RSCEN; |
| 2160 | /* | 2150 | /* |
| @@ -2162,7 +2152,7 @@ static void ixgbe_configure_rx(struct ixgbe_adapter *adapter) | |||
| 2162 | * total size of max desc * buf_len is not greater | 2152 | * total size of max desc * buf_len is not greater |
| 2163 | * than 65535 | 2153 | * than 65535 |
| 2164 | */ | 2154 | */ |
| 2165 | if (adapter->flags & IXGBE_FLAG_RX_PS_ENABLED) { | 2155 | if (rx_ring->flags & IXGBE_RING_RX_PS_ENABLED) { |
| 2166 | #if (MAX_SKB_FRAGS > 16) | 2156 | #if (MAX_SKB_FRAGS > 16) |
| 2167 | rscctrl |= IXGBE_RSCCTL_MAXDESC_16; | 2157 | rscctrl |= IXGBE_RSCCTL_MAXDESC_16; |
| 2168 | #elif (MAX_SKB_FRAGS > 8) | 2158 | #elif (MAX_SKB_FRAGS > 8) |
| @@ -3798,16 +3788,17 @@ static int __devinit ixgbe_sw_init(struct ixgbe_adapter *adapter) | |||
| 3798 | adapter->max_msix_q_vectors = MAX_MSIX_Q_VECTORS_82598; | 3788 | adapter->max_msix_q_vectors = MAX_MSIX_Q_VECTORS_82598; |
| 3799 | } else if (hw->mac.type == ixgbe_mac_82599EB) { | 3789 | } else if (hw->mac.type == ixgbe_mac_82599EB) { |
| 3800 | adapter->max_msix_q_vectors = MAX_MSIX_Q_VECTORS_82599; | 3790 | adapter->max_msix_q_vectors = MAX_MSIX_Q_VECTORS_82599; |
| 3801 | adapter->flags |= IXGBE_FLAG2_RSC_CAPABLE; | 3791 | adapter->flags2 |= IXGBE_FLAG2_RSC_CAPABLE; |
| 3802 | adapter->flags |= IXGBE_FLAG2_RSC_ENABLED; | 3792 | adapter->flags2 |= IXGBE_FLAG2_RSC_ENABLED; |
| 3803 | adapter->flags |= IXGBE_FLAG_FDIR_HASH_CAPABLE; | 3793 | adapter->flags |= IXGBE_FLAG_FDIR_HASH_CAPABLE; |
| 3804 | adapter->ring_feature[RING_F_FDIR].indices = | 3794 | adapter->ring_feature[RING_F_FDIR].indices = |
| 3805 | IXGBE_MAX_FDIR_INDICES; | 3795 | IXGBE_MAX_FDIR_INDICES; |
| 3806 | adapter->atr_sample_rate = 20; | 3796 | adapter->atr_sample_rate = 20; |
| 3807 | adapter->fdir_pballoc = 0; | 3797 | adapter->fdir_pballoc = 0; |
| 3808 | #ifdef IXGBE_FCOE | 3798 | #ifdef IXGBE_FCOE |
| 3809 | adapter->flags |= IXGBE_FLAG_FCOE_ENABLED; | 3799 | adapter->flags |= IXGBE_FLAG_FCOE_CAPABLE; |
| 3810 | adapter->ring_feature[RING_F_FCOE].indices = IXGBE_FCRETA_SIZE; | 3800 | adapter->flags &= ~IXGBE_FLAG_FCOE_ENABLED; |
| 3801 | adapter->ring_feature[RING_F_FCOE].indices = 0; | ||
| 3811 | #endif /* IXGBE_FCOE */ | 3802 | #endif /* IXGBE_FCOE */ |
| 3812 | } | 3803 | } |
| 3813 | 3804 | ||
| @@ -5125,9 +5116,6 @@ static int ixgbe_xmit_frame(struct sk_buff *skb, struct net_device *netdev) | |||
| 5125 | int count = 0; | 5116 | int count = 0; |
| 5126 | unsigned int f; | 5117 | unsigned int f; |
| 5127 | 5118 | ||
| 5128 | r_idx = skb->queue_mapping; | ||
| 5129 | tx_ring = &adapter->tx_ring[r_idx]; | ||
| 5130 | |||
| 5131 | if (adapter->vlgrp && vlan_tx_tag_present(skb)) { | 5119 | if (adapter->vlgrp && vlan_tx_tag_present(skb)) { |
| 5132 | tx_flags |= vlan_tx_tag_get(skb); | 5120 | tx_flags |= vlan_tx_tag_get(skb); |
| 5133 | if (adapter->flags & IXGBE_FLAG_DCB_ENABLED) { | 5121 | if (adapter->flags & IXGBE_FLAG_DCB_ENABLED) { |
| @@ -5137,11 +5125,19 @@ static int ixgbe_xmit_frame(struct sk_buff *skb, struct net_device *netdev) | |||
| 5137 | tx_flags <<= IXGBE_TX_FLAGS_VLAN_SHIFT; | 5125 | tx_flags <<= IXGBE_TX_FLAGS_VLAN_SHIFT; |
| 5138 | tx_flags |= IXGBE_TX_FLAGS_VLAN; | 5126 | tx_flags |= IXGBE_TX_FLAGS_VLAN; |
| 5139 | } else if (adapter->flags & IXGBE_FLAG_DCB_ENABLED) { | 5127 | } else if (adapter->flags & IXGBE_FLAG_DCB_ENABLED) { |
| 5140 | tx_flags |= (skb->queue_mapping << 13); | 5128 | if (skb->priority != TC_PRIO_CONTROL) { |
| 5141 | tx_flags <<= IXGBE_TX_FLAGS_VLAN_SHIFT; | 5129 | tx_flags |= (skb->queue_mapping << 13); |
| 5142 | tx_flags |= IXGBE_TX_FLAGS_VLAN; | 5130 | tx_flags <<= IXGBE_TX_FLAGS_VLAN_SHIFT; |
| 5131 | tx_flags |= IXGBE_TX_FLAGS_VLAN; | ||
| 5132 | } else { | ||
| 5133 | skb->queue_mapping = | ||
| 5134 | adapter->ring_feature[RING_F_DCB].indices-1; | ||
| 5135 | } | ||
| 5143 | } | 5136 | } |
| 5144 | 5137 | ||
| 5138 | r_idx = skb->queue_mapping; | ||
| 5139 | tx_ring = &adapter->tx_ring[r_idx]; | ||
| 5140 | |||
| 5145 | if ((adapter->flags & IXGBE_FLAG_FCOE_ENABLED) && | 5141 | if ((adapter->flags & IXGBE_FLAG_FCOE_ENABLED) && |
| 5146 | (skb->protocol == htons(ETH_P_FCOE))) | 5142 | (skb->protocol == htons(ETH_P_FCOE))) |
| 5147 | tx_flags |= IXGBE_TX_FLAGS_FCOE; | 5143 | tx_flags |= IXGBE_TX_FLAGS_FCOE; |
| @@ -5340,12 +5336,19 @@ static int ixgbe_del_sanmac_netdev(struct net_device *dev) | |||
| 5340 | static void ixgbe_netpoll(struct net_device *netdev) | 5336 | static void ixgbe_netpoll(struct net_device *netdev) |
| 5341 | { | 5337 | { |
| 5342 | struct ixgbe_adapter *adapter = netdev_priv(netdev); | 5338 | struct ixgbe_adapter *adapter = netdev_priv(netdev); |
| 5339 | int i; | ||
| 5343 | 5340 | ||
| 5344 | disable_irq(adapter->pdev->irq); | ||
| 5345 | adapter->flags |= IXGBE_FLAG_IN_NETPOLL; | 5341 | adapter->flags |= IXGBE_FLAG_IN_NETPOLL; |
| 5346 | ixgbe_intr(adapter->pdev->irq, netdev); | 5342 | if (adapter->flags & IXGBE_FLAG_MSIX_ENABLED) { |
| 5343 | int num_q_vectors = adapter->num_msix_vectors - NON_Q_VECTORS; | ||
| 5344 | for (i = 0; i < num_q_vectors; i++) { | ||
| 5345 | struct ixgbe_q_vector *q_vector = adapter->q_vector[i]; | ||
| 5346 | ixgbe_msix_clean_many(0, q_vector); | ||
| 5347 | } | ||
| 5348 | } else { | ||
| 5349 | ixgbe_intr(adapter->pdev->irq, netdev); | ||
| 5350 | } | ||
| 5347 | adapter->flags &= ~IXGBE_FLAG_IN_NETPOLL; | 5351 | adapter->flags &= ~IXGBE_FLAG_IN_NETPOLL; |
| 5348 | enable_irq(adapter->pdev->irq); | ||
| 5349 | } | 5352 | } |
| 5350 | #endif | 5353 | #endif |
| 5351 | 5354 | ||
| @@ -5580,23 +5583,18 @@ static int __devinit ixgbe_probe(struct pci_dev *pdev, | |||
| 5580 | #endif | 5583 | #endif |
| 5581 | 5584 | ||
| 5582 | #ifdef IXGBE_FCOE | 5585 | #ifdef IXGBE_FCOE |
| 5583 | if (adapter->flags & IXGBE_FLAG_FCOE_ENABLED) { | 5586 | if (adapter->flags & IXGBE_FLAG_FCOE_CAPABLE) { |
| 5584 | if (hw->mac.ops.get_device_caps) { | 5587 | if (hw->mac.ops.get_device_caps) { |
| 5585 | hw->mac.ops.get_device_caps(hw, &device_caps); | 5588 | hw->mac.ops.get_device_caps(hw, &device_caps); |
| 5586 | if (!(device_caps & IXGBE_DEVICE_CAPS_FCOE_OFFLOADS)) { | 5589 | if (device_caps & IXGBE_DEVICE_CAPS_FCOE_OFFLOADS) |
| 5587 | netdev->features |= NETIF_F_FCOE_CRC; | 5590 | adapter->flags &= ~IXGBE_FLAG_FCOE_CAPABLE; |
| 5588 | netdev->features |= NETIF_F_FSO; | ||
| 5589 | netdev->fcoe_ddp_xid = IXGBE_FCOE_DDP_MAX - 1; | ||
| 5590 | } else { | ||
| 5591 | adapter->flags &= ~IXGBE_FLAG_FCOE_ENABLED; | ||
| 5592 | } | ||
| 5593 | } | 5591 | } |
| 5594 | } | 5592 | } |
| 5595 | #endif /* IXGBE_FCOE */ | 5593 | #endif /* IXGBE_FCOE */ |
| 5596 | if (pci_using_dac) | 5594 | if (pci_using_dac) |
| 5597 | netdev->features |= NETIF_F_HIGHDMA; | 5595 | netdev->features |= NETIF_F_HIGHDMA; |
| 5598 | 5596 | ||
| 5599 | if (adapter->flags & IXGBE_FLAG2_RSC_ENABLED) | 5597 | if (adapter->flags2 & IXGBE_FLAG2_RSC_ENABLED) |
| 5600 | netdev->features |= NETIF_F_LRO; | 5598 | netdev->features |= NETIF_F_LRO; |
| 5601 | 5599 | ||
| 5602 | /* make sure the EEPROM is good */ | 5600 | /* make sure the EEPROM is good */ |
| @@ -5638,7 +5636,6 @@ static int __devinit ixgbe_probe(struct pci_dev *pdev, | |||
| 5638 | adapter->wol = 0; | 5636 | adapter->wol = 0; |
| 5639 | break; | 5637 | break; |
| 5640 | } | 5638 | } |
| 5641 | device_init_wakeup(&adapter->pdev->dev, true); | ||
| 5642 | device_set_wakeup_enable(&adapter->pdev->dev, adapter->wol); | 5639 | device_set_wakeup_enable(&adapter->pdev->dev, adapter->wol); |
| 5643 | 5640 | ||
| 5644 | /* pick up the PCI bus settings for reporting later */ | 5641 | /* pick up the PCI bus settings for reporting later */ |
diff --git a/drivers/net/ixgbe/ixgbe_type.h b/drivers/net/ixgbe/ixgbe_type.h index fa87309dc087..be90eb4575f6 100644 --- a/drivers/net/ixgbe/ixgbe_type.h +++ b/drivers/net/ixgbe/ixgbe_type.h | |||
| @@ -718,6 +718,12 @@ | |||
| 718 | #define IXGBE_ECC_STATUS_82599 0x110E0 | 718 | #define IXGBE_ECC_STATUS_82599 0x110E0 |
| 719 | #define IXGBE_BAR_CTRL_82599 0x110F4 | 719 | #define IXGBE_BAR_CTRL_82599 0x110F4 |
| 720 | 720 | ||
| 721 | /* PCI Express Control */ | ||
| 722 | #define IXGBE_GCR_CMPL_TMOUT_MASK 0x0000F000 | ||
| 723 | #define IXGBE_GCR_CMPL_TMOUT_10ms 0x00001000 | ||
| 724 | #define IXGBE_GCR_CMPL_TMOUT_RESEND 0x00010000 | ||
| 725 | #define IXGBE_GCR_CAP_VER2 0x00040000 | ||
| 726 | |||
| 721 | /* Time Sync Registers */ | 727 | /* Time Sync Registers */ |
| 722 | #define IXGBE_TSYNCRXCTL 0x05188 /* Rx Time Sync Control register - RW */ | 728 | #define IXGBE_TSYNCRXCTL 0x05188 /* Rx Time Sync Control register - RW */ |
| 723 | #define IXGBE_TSYNCTXCTL 0x08C00 /* Tx Time Sync Control register - RW */ | 729 | #define IXGBE_TSYNCTXCTL 0x08C00 /* Tx Time Sync Control register - RW */ |
| @@ -1521,6 +1527,7 @@ | |||
| 1521 | 1527 | ||
| 1522 | /* PCI Bus Info */ | 1528 | /* PCI Bus Info */ |
| 1523 | #define IXGBE_PCI_LINK_STATUS 0xB2 | 1529 | #define IXGBE_PCI_LINK_STATUS 0xB2 |
| 1530 | #define IXGBE_PCI_DEVICE_CONTROL2 0xC8 | ||
| 1524 | #define IXGBE_PCI_LINK_WIDTH 0x3F0 | 1531 | #define IXGBE_PCI_LINK_WIDTH 0x3F0 |
| 1525 | #define IXGBE_PCI_LINK_WIDTH_1 0x10 | 1532 | #define IXGBE_PCI_LINK_WIDTH_1 0x10 |
| 1526 | #define IXGBE_PCI_LINK_WIDTH_2 0x20 | 1533 | #define IXGBE_PCI_LINK_WIDTH_2 0x20 |
| @@ -1531,6 +1538,7 @@ | |||
| 1531 | #define IXGBE_PCI_LINK_SPEED_5000 0x2 | 1538 | #define IXGBE_PCI_LINK_SPEED_5000 0x2 |
| 1532 | #define IXGBE_PCI_HEADER_TYPE_REGISTER 0x0E | 1539 | #define IXGBE_PCI_HEADER_TYPE_REGISTER 0x0E |
| 1533 | #define IXGBE_PCI_HEADER_TYPE_MULTIFUNC 0x80 | 1540 | #define IXGBE_PCI_HEADER_TYPE_MULTIFUNC 0x80 |
| 1541 | #define IXGBE_PCI_DEVICE_CONTROL2_16ms 0x0005 | ||
| 1534 | 1542 | ||
| 1535 | /* Number of 100 microseconds we wait for PCI Express master disable */ | 1543 | /* Number of 100 microseconds we wait for PCI Express master disable */ |
| 1536 | #define IXGBE_PCI_MASTER_DISABLE_TIMEOUT 800 | 1544 | #define IXGBE_PCI_MASTER_DISABLE_TIMEOUT 800 |
diff --git a/drivers/net/ixp2000/ixpdev.c b/drivers/net/ixp2000/ixpdev.c index 2a0174b62e96..92fb8235c766 100644 --- a/drivers/net/ixp2000/ixpdev.c +++ b/drivers/net/ixp2000/ixpdev.c | |||
| @@ -41,6 +41,7 @@ static int ixpdev_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 41 | struct ixpdev_priv *ip = netdev_priv(dev); | 41 | struct ixpdev_priv *ip = netdev_priv(dev); |
| 42 | struct ixpdev_tx_desc *desc; | 42 | struct ixpdev_tx_desc *desc; |
| 43 | int entry; | 43 | int entry; |
| 44 | unsigned long flags; | ||
| 44 | 45 | ||
| 45 | if (unlikely(skb->len > PAGE_SIZE)) { | 46 | if (unlikely(skb->len > PAGE_SIZE)) { |
| 46 | /* @@@ Count drops. */ | 47 | /* @@@ Count drops. */ |
| @@ -63,11 +64,11 @@ static int ixpdev_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 63 | 64 | ||
| 64 | dev->trans_start = jiffies; | 65 | dev->trans_start = jiffies; |
| 65 | 66 | ||
| 66 | local_irq_disable(); | 67 | local_irq_save(flags); |
| 67 | ip->tx_queue_entries++; | 68 | ip->tx_queue_entries++; |
| 68 | if (ip->tx_queue_entries == TX_BUF_COUNT_PER_CHAN) | 69 | if (ip->tx_queue_entries == TX_BUF_COUNT_PER_CHAN) |
| 69 | netif_stop_queue(dev); | 70 | netif_stop_queue(dev); |
| 70 | local_irq_enable(); | 71 | local_irq_restore(flags); |
| 71 | 72 | ||
| 72 | return 0; | 73 | return 0; |
| 73 | } | 74 | } |
diff --git a/drivers/net/jazzsonic.c b/drivers/net/jazzsonic.c index d12106b47bf2..2f286091394d 100644 --- a/drivers/net/jazzsonic.c +++ b/drivers/net/jazzsonic.c | |||
| @@ -229,6 +229,7 @@ static int __init jazz_sonic_probe(struct platform_device *pdev) | |||
| 229 | lp = netdev_priv(dev); | 229 | lp = netdev_priv(dev); |
| 230 | lp->device = &pdev->dev; | 230 | lp->device = &pdev->dev; |
| 231 | SET_NETDEV_DEV(dev, &pdev->dev); | 231 | SET_NETDEV_DEV(dev, &pdev->dev); |
| 232 | platform_set_drvdata(pdev, dev); | ||
| 232 | 233 | ||
| 233 | netdev_boot_setup_check(dev); | 234 | netdev_boot_setup_check(dev); |
| 234 | 235 | ||
diff --git a/drivers/net/ks8851.c b/drivers/net/ks8851.c new file mode 100644 index 000000000000..9a1dea60c1c4 --- /dev/null +++ b/drivers/net/ks8851.c | |||
| @@ -0,0 +1,1322 @@ | |||
| 1 | /* drivers/net/ks8651.c | ||
| 2 | * | ||
| 3 | * Copyright 2009 Simtec Electronics | ||
| 4 | * http://www.simtec.co.uk/ | ||
| 5 | * Ben Dooks <ben@simtec.co.uk> | ||
| 6 | * | ||
| 7 | * This program is free software; you can redistribute it and/or modify | ||
| 8 | * it under the terms of the GNU General Public License version 2 as | ||
| 9 | * published by the Free Software Foundation. | ||
| 10 | */ | ||
| 11 | |||
| 12 | #define DEBUG | ||
| 13 | |||
| 14 | #include <linux/module.h> | ||
| 15 | #include <linux/kernel.h> | ||
| 16 | #include <linux/netdevice.h> | ||
| 17 | #include <linux/etherdevice.h> | ||
| 18 | #include <linux/ethtool.h> | ||
| 19 | #include <linux/cache.h> | ||
| 20 | #include <linux/crc32.h> | ||
| 21 | #include <linux/mii.h> | ||
| 22 | |||
| 23 | #include <linux/spi/spi.h> | ||
| 24 | |||
| 25 | #include "ks8851.h" | ||
| 26 | |||
| 27 | /** | ||
| 28 | * struct ks8851_rxctrl - KS8851 driver rx control | ||
| 29 | * @mchash: Multicast hash-table data. | ||
| 30 | * @rxcr1: KS_RXCR1 register setting | ||
| 31 | * @rxcr2: KS_RXCR2 register setting | ||
| 32 | * | ||
| 33 | * Representation of the settings needs to control the receive filtering | ||
| 34 | * such as the multicast hash-filter and the receive register settings. This | ||
| 35 | * is used to make the job of working out if the receive settings change and | ||
| 36 | * then issuing the new settings to the worker that will send the necessary | ||
| 37 | * commands. | ||
| 38 | */ | ||
| 39 | struct ks8851_rxctrl { | ||
| 40 | u16 mchash[4]; | ||
| 41 | u16 rxcr1; | ||
| 42 | u16 rxcr2; | ||
| 43 | }; | ||
| 44 | |||
| 45 | /** | ||
| 46 | * union ks8851_tx_hdr - tx header data | ||
| 47 | * @txb: The header as bytes | ||
| 48 | * @txw: The header as 16bit, little-endian words | ||
| 49 | * | ||
| 50 | * A dual representation of the tx header data to allow | ||
| 51 | * access to individual bytes, and to allow 16bit accesses | ||
| 52 | * with 16bit alignment. | ||
| 53 | */ | ||
| 54 | union ks8851_tx_hdr { | ||
| 55 | u8 txb[6]; | ||
| 56 | __le16 txw[3]; | ||
| 57 | }; | ||
| 58 | |||
| 59 | /** | ||
| 60 | * struct ks8851_net - KS8851 driver private data | ||
| 61 | * @netdev: The network device we're bound to | ||
| 62 | * @spidev: The spi device we're bound to. | ||
| 63 | * @lock: Lock to ensure that the device is not accessed when busy. | ||
| 64 | * @statelock: Lock on this structure for tx list. | ||
| 65 | * @mii: The MII state information for the mii calls. | ||
| 66 | * @rxctrl: RX settings for @rxctrl_work. | ||
| 67 | * @tx_work: Work queue for tx packets | ||
| 68 | * @irq_work: Work queue for servicing interrupts | ||
| 69 | * @rxctrl_work: Work queue for updating RX mode and multicast lists | ||
| 70 | * @txq: Queue of packets for transmission. | ||
| 71 | * @spi_msg1: pre-setup SPI transfer with one message, @spi_xfer1. | ||
| 72 | * @spi_msg2: pre-setup SPI transfer with two messages, @spi_xfer2. | ||
| 73 | * @txh: Space for generating packet TX header in DMA-able data | ||
| 74 | * @rxd: Space for receiving SPI data, in DMA-able space. | ||
| 75 | * @txd: Space for transmitting SPI data, in DMA-able space. | ||
| 76 | * @msg_enable: The message flags controlling driver output (see ethtool). | ||
| 77 | * @fid: Incrementing frame id tag. | ||
| 78 | * @rc_ier: Cached copy of KS_IER. | ||
| 79 | * @rc_rxqcr: Cached copy of KS_RXQCR. | ||
| 80 | * | ||
| 81 | * The @lock ensures that the chip is protected when certain operations are | ||
| 82 | * in progress. When the read or write packet transfer is in progress, most | ||
| 83 | * of the chip registers are not ccessible until the transfer is finished and | ||
| 84 | * the DMA has been de-asserted. | ||
| 85 | * | ||
| 86 | * The @statelock is used to protect information in the structure which may | ||
| 87 | * need to be accessed via several sources, such as the network driver layer | ||
| 88 | * or one of the work queues. | ||
| 89 | * | ||
| 90 | * We align the buffers we may use for rx/tx to ensure that if the SPI driver | ||
| 91 | * wants to DMA map them, it will not have any problems with data the driver | ||
| 92 | * modifies. | ||
| 93 | */ | ||
| 94 | struct ks8851_net { | ||
| 95 | struct net_device *netdev; | ||
| 96 | struct spi_device *spidev; | ||
| 97 | struct mutex lock; | ||
| 98 | spinlock_t statelock; | ||
| 99 | |||
| 100 | union ks8851_tx_hdr txh ____cacheline_aligned; | ||
| 101 | u8 rxd[8]; | ||
| 102 | u8 txd[8]; | ||
| 103 | |||
| 104 | u32 msg_enable ____cacheline_aligned; | ||
| 105 | u16 tx_space; | ||
| 106 | u8 fid; | ||
| 107 | |||
| 108 | u16 rc_ier; | ||
| 109 | u16 rc_rxqcr; | ||
| 110 | |||
| 111 | struct mii_if_info mii; | ||
| 112 | struct ks8851_rxctrl rxctrl; | ||
| 113 | |||
| 114 | struct work_struct tx_work; | ||
| 115 | struct work_struct irq_work; | ||
| 116 | struct work_struct rxctrl_work; | ||
| 117 | |||
| 118 | struct sk_buff_head txq; | ||
| 119 | |||
| 120 | struct spi_message spi_msg1; | ||
| 121 | struct spi_message spi_msg2; | ||
| 122 | struct spi_transfer spi_xfer1; | ||
| 123 | struct spi_transfer spi_xfer2[2]; | ||
| 124 | }; | ||
| 125 | |||
| 126 | static int msg_enable; | ||
| 127 | |||
| 128 | #define ks_info(_ks, _msg...) dev_info(&(_ks)->spidev->dev, _msg) | ||
| 129 | #define ks_warn(_ks, _msg...) dev_warn(&(_ks)->spidev->dev, _msg) | ||
| 130 | #define ks_dbg(_ks, _msg...) dev_dbg(&(_ks)->spidev->dev, _msg) | ||
| 131 | #define ks_err(_ks, _msg...) dev_err(&(_ks)->spidev->dev, _msg) | ||
| 132 | |||
| 133 | /* shift for byte-enable data */ | ||
| 134 | #define BYTE_EN(_x) ((_x) << 2) | ||
| 135 | |||
| 136 | /* turn register number and byte-enable mask into data for start of packet */ | ||
| 137 | #define MK_OP(_byteen, _reg) (BYTE_EN(_byteen) | (_reg) << (8+2) | (_reg) >> 6) | ||
| 138 | |||
| 139 | /* SPI register read/write calls. | ||
| 140 | * | ||
| 141 | * All these calls issue SPI transactions to access the chip's registers. They | ||
| 142 | * all require that the necessary lock is held to prevent accesses when the | ||
| 143 | * chip is busy transfering packet data (RX/TX FIFO accesses). | ||
| 144 | */ | ||
| 145 | |||
| 146 | /** | ||
| 147 | * ks8851_wrreg16 - write 16bit register value to chip | ||
| 148 | * @ks: The chip state | ||
| 149 | * @reg: The register address | ||
| 150 | * @val: The value to write | ||
| 151 | * | ||
| 152 | * Issue a write to put the value @val into the register specified in @reg. | ||
| 153 | */ | ||
| 154 | static void ks8851_wrreg16(struct ks8851_net *ks, unsigned reg, unsigned val) | ||
| 155 | { | ||
| 156 | struct spi_transfer *xfer = &ks->spi_xfer1; | ||
| 157 | struct spi_message *msg = &ks->spi_msg1; | ||
| 158 | __le16 txb[2]; | ||
| 159 | int ret; | ||
| 160 | |||
| 161 | txb[0] = cpu_to_le16(MK_OP(reg & 2 ? 0xC : 0x03, reg) | KS_SPIOP_WR); | ||
| 162 | txb[1] = cpu_to_le16(val); | ||
| 163 | |||
| 164 | xfer->tx_buf = txb; | ||
| 165 | xfer->rx_buf = NULL; | ||
| 166 | xfer->len = 4; | ||
| 167 | |||
| 168 | ret = spi_sync(ks->spidev, msg); | ||
| 169 | if (ret < 0) | ||
| 170 | ks_err(ks, "spi_sync() failed\n"); | ||
| 171 | } | ||
| 172 | |||
| 173 | /** | ||
| 174 | * ks8851_rx_1msg - select whether to use one or two messages for spi read | ||
| 175 | * @ks: The device structure | ||
| 176 | * | ||
| 177 | * Return whether to generate a single message with a tx and rx buffer | ||
| 178 | * supplied to spi_sync(), or alternatively send the tx and rx buffers | ||
| 179 | * as separate messages. | ||
| 180 | * | ||
| 181 | * Depending on the hardware in use, a single message may be more efficient | ||
| 182 | * on interrupts or work done by the driver. | ||
| 183 | * | ||
| 184 | * This currently always returns true until we add some per-device data passed | ||
| 185 | * from the platform code to specify which mode is better. | ||
| 186 | */ | ||
| 187 | static inline bool ks8851_rx_1msg(struct ks8851_net *ks) | ||
| 188 | { | ||
| 189 | return true; | ||
| 190 | } | ||
| 191 | |||
| 192 | /** | ||
| 193 | * ks8851_rdreg - issue read register command and return the data | ||
| 194 | * @ks: The device state | ||
| 195 | * @op: The register address and byte enables in message format. | ||
| 196 | * @rxb: The RX buffer to return the result into | ||
| 197 | * @rxl: The length of data expected. | ||
| 198 | * | ||
| 199 | * This is the low level read call that issues the necessary spi message(s) | ||
| 200 | * to read data from the register specified in @op. | ||
| 201 | */ | ||
| 202 | static void ks8851_rdreg(struct ks8851_net *ks, unsigned op, | ||
| 203 | u8 *rxb, unsigned rxl) | ||
| 204 | { | ||
| 205 | struct spi_transfer *xfer; | ||
| 206 | struct spi_message *msg; | ||
| 207 | __le16 *txb = (__le16 *)ks->txd; | ||
| 208 | u8 *trx = ks->rxd; | ||
| 209 | int ret; | ||
| 210 | |||
| 211 | txb[0] = cpu_to_le16(op | KS_SPIOP_RD); | ||
| 212 | |||
| 213 | if (ks8851_rx_1msg(ks)) { | ||
| 214 | msg = &ks->spi_msg1; | ||
| 215 | xfer = &ks->spi_xfer1; | ||
| 216 | |||
| 217 | xfer->tx_buf = txb; | ||
| 218 | xfer->rx_buf = trx; | ||
| 219 | xfer->len = rxl + 2; | ||
| 220 | } else { | ||
| 221 | msg = &ks->spi_msg2; | ||
| 222 | xfer = ks->spi_xfer2; | ||
| 223 | |||
| 224 | xfer->tx_buf = txb; | ||
| 225 | xfer->rx_buf = NULL; | ||
| 226 | xfer->len = 2; | ||
| 227 | |||
| 228 | xfer++; | ||
| 229 | xfer->tx_buf = NULL; | ||
| 230 | xfer->rx_buf = trx; | ||
| 231 | xfer->len = rxl; | ||
| 232 | } | ||
| 233 | |||
| 234 | ret = spi_sync(ks->spidev, msg); | ||
| 235 | if (ret < 0) | ||
| 236 | ks_err(ks, "read: spi_sync() failed\n"); | ||
| 237 | else if (ks8851_rx_1msg(ks)) | ||
| 238 | memcpy(rxb, trx + 2, rxl); | ||
| 239 | else | ||
| 240 | memcpy(rxb, trx, rxl); | ||
| 241 | } | ||
| 242 | |||
| 243 | /** | ||
| 244 | * ks8851_rdreg8 - read 8 bit register from device | ||
| 245 | * @ks: The chip information | ||
| 246 | * @reg: The register address | ||
| 247 | * | ||
| 248 | * Read a 8bit register from the chip, returning the result | ||
| 249 | */ | ||
| 250 | static unsigned ks8851_rdreg8(struct ks8851_net *ks, unsigned reg) | ||
| 251 | { | ||
| 252 | u8 rxb[1]; | ||
| 253 | |||
| 254 | ks8851_rdreg(ks, MK_OP(1 << (reg & 3), reg), rxb, 1); | ||
| 255 | return rxb[0]; | ||
| 256 | } | ||
| 257 | |||
| 258 | /** | ||
| 259 | * ks8851_rdreg16 - read 16 bit register from device | ||
| 260 | * @ks: The chip information | ||
| 261 | * @reg: The register address | ||
| 262 | * | ||
| 263 | * Read a 16bit register from the chip, returning the result | ||
| 264 | */ | ||
| 265 | static unsigned ks8851_rdreg16(struct ks8851_net *ks, unsigned reg) | ||
| 266 | { | ||
| 267 | __le16 rx = 0; | ||
| 268 | |||
| 269 | ks8851_rdreg(ks, MK_OP(reg & 2 ? 0xC : 0x3, reg), (u8 *)&rx, 2); | ||
| 270 | return le16_to_cpu(rx); | ||
| 271 | } | ||
| 272 | |||
| 273 | /** | ||
| 274 | * ks8851_rdreg32 - read 32 bit register from device | ||
| 275 | * @ks: The chip information | ||
| 276 | * @reg: The register address | ||
| 277 | * | ||
| 278 | * Read a 32bit register from the chip. | ||
| 279 | * | ||
| 280 | * Note, this read requires the address be aligned to 4 bytes. | ||
| 281 | */ | ||
| 282 | static unsigned ks8851_rdreg32(struct ks8851_net *ks, unsigned reg) | ||
| 283 | { | ||
| 284 | __le32 rx = 0; | ||
| 285 | |||
| 286 | WARN_ON(reg & 3); | ||
| 287 | |||
| 288 | ks8851_rdreg(ks, MK_OP(0xf, reg), (u8 *)&rx, 4); | ||
| 289 | return le32_to_cpu(rx); | ||
| 290 | } | ||
| 291 | |||
| 292 | /** | ||
| 293 | * ks8851_soft_reset - issue one of the soft reset to the device | ||
| 294 | * @ks: The device state. | ||
| 295 | * @op: The bit(s) to set in the GRR | ||
| 296 | * | ||
| 297 | * Issue the relevant soft-reset command to the device's GRR register | ||
| 298 | * specified by @op. | ||
| 299 | * | ||
| 300 | * Note, the delays are in there as a caution to ensure that the reset | ||
| 301 | * has time to take effect and then complete. Since the datasheet does | ||
| 302 | * not currently specify the exact sequence, we have chosen something | ||
| 303 | * that seems to work with our device. | ||
| 304 | */ | ||
| 305 | static void ks8851_soft_reset(struct ks8851_net *ks, unsigned op) | ||
| 306 | { | ||
| 307 | ks8851_wrreg16(ks, KS_GRR, op); | ||
| 308 | mdelay(1); /* wait a short time to effect reset */ | ||
| 309 | ks8851_wrreg16(ks, KS_GRR, 0); | ||
| 310 | mdelay(1); /* wait for condition to clear */ | ||
| 311 | } | ||
| 312 | |||
| 313 | /** | ||
| 314 | * ks8851_write_mac_addr - write mac address to device registers | ||
| 315 | * @dev: The network device | ||
| 316 | * | ||
| 317 | * Update the KS8851 MAC address registers from the address in @dev. | ||
| 318 | * | ||
| 319 | * This call assumes that the chip is not running, so there is no need to | ||
| 320 | * shutdown the RXQ process whilst setting this. | ||
| 321 | */ | ||
| 322 | static int ks8851_write_mac_addr(struct net_device *dev) | ||
| 323 | { | ||
| 324 | struct ks8851_net *ks = netdev_priv(dev); | ||
| 325 | u16 *mcp = (u16 *)dev->dev_addr; | ||
| 326 | |||
| 327 | mutex_lock(&ks->lock); | ||
| 328 | |||
| 329 | ks8851_wrreg16(ks, KS_MARL, mcp[0]); | ||
| 330 | ks8851_wrreg16(ks, KS_MARM, mcp[1]); | ||
| 331 | ks8851_wrreg16(ks, KS_MARH, mcp[2]); | ||
| 332 | |||
| 333 | mutex_unlock(&ks->lock); | ||
| 334 | |||
| 335 | return 0; | ||
| 336 | } | ||
| 337 | |||
| 338 | /** | ||
| 339 | * ks8851_init_mac - initialise the mac address | ||
| 340 | * @ks: The device structure | ||
| 341 | * | ||
| 342 | * Get or create the initial mac address for the device and then set that | ||
| 343 | * into the station address register. Currently we assume that the device | ||
| 344 | * does not have a valid mac address in it, and so we use random_ether_addr() | ||
| 345 | * to create a new one. | ||
| 346 | * | ||
| 347 | * In future, the driver should check to see if the device has an EEPROM | ||
| 348 | * attached and whether that has a valid ethernet address in it. | ||
| 349 | */ | ||
| 350 | static void ks8851_init_mac(struct ks8851_net *ks) | ||
| 351 | { | ||
| 352 | struct net_device *dev = ks->netdev; | ||
| 353 | |||
| 354 | random_ether_addr(dev->dev_addr); | ||
| 355 | ks8851_write_mac_addr(dev); | ||
| 356 | } | ||
| 357 | |||
| 358 | /** | ||
| 359 | * ks8851_irq - device interrupt handler | ||
| 360 | * @irq: Interrupt number passed from the IRQ hnalder. | ||
| 361 | * @pw: The private word passed to register_irq(), our struct ks8851_net. | ||
| 362 | * | ||
| 363 | * Disable the interrupt from happening again until we've processed the | ||
| 364 | * current status by scheduling ks8851_irq_work(). | ||
| 365 | */ | ||
| 366 | static irqreturn_t ks8851_irq(int irq, void *pw) | ||
| 367 | { | ||
| 368 | struct ks8851_net *ks = pw; | ||
| 369 | |||
| 370 | disable_irq_nosync(irq); | ||
| 371 | schedule_work(&ks->irq_work); | ||
| 372 | return IRQ_HANDLED; | ||
| 373 | } | ||
| 374 | |||
| 375 | /** | ||
| 376 | * ks8851_rdfifo - read data from the receive fifo | ||
| 377 | * @ks: The device state. | ||
| 378 | * @buff: The buffer address | ||
| 379 | * @len: The length of the data to read | ||
| 380 | * | ||
| 381 | * Issue an RXQ FIFO read command and read the @len ammount of data from | ||
| 382 | * the FIFO into the buffer specified by @buff. | ||
| 383 | */ | ||
| 384 | static void ks8851_rdfifo(struct ks8851_net *ks, u8 *buff, unsigned len) | ||
| 385 | { | ||
| 386 | struct spi_transfer *xfer = ks->spi_xfer2; | ||
| 387 | struct spi_message *msg = &ks->spi_msg2; | ||
| 388 | u8 txb[1]; | ||
| 389 | int ret; | ||
| 390 | |||
| 391 | if (netif_msg_rx_status(ks)) | ||
| 392 | ks_dbg(ks, "%s: %d@%p\n", __func__, len, buff); | ||
| 393 | |||
| 394 | /* set the operation we're issuing */ | ||
| 395 | txb[0] = KS_SPIOP_RXFIFO; | ||
| 396 | |||
| 397 | xfer->tx_buf = txb; | ||
| 398 | xfer->rx_buf = NULL; | ||
| 399 | xfer->len = 1; | ||
| 400 | |||
| 401 | xfer++; | ||
| 402 | xfer->rx_buf = buff; | ||
| 403 | xfer->tx_buf = NULL; | ||
| 404 | xfer->len = len; | ||
| 405 | |||
| 406 | ret = spi_sync(ks->spidev, msg); | ||
| 407 | if (ret < 0) | ||
| 408 | ks_err(ks, "%s: spi_sync() failed\n", __func__); | ||
| 409 | } | ||
| 410 | |||
| 411 | /** | ||
| 412 | * ks8851_dbg_dumpkkt - dump initial packet contents to debug | ||
| 413 | * @ks: The device state | ||
| 414 | * @rxpkt: The data for the received packet | ||
| 415 | * | ||
| 416 | * Dump the initial data from the packet to dev_dbg(). | ||
| 417 | */ | ||
| 418 | static void ks8851_dbg_dumpkkt(struct ks8851_net *ks, u8 *rxpkt) | ||
| 419 | { | ||
| 420 | ks_dbg(ks, "pkt %02x%02x%02x%02x %02x%02x%02x%02x %02x%02x%02x%02x\n", | ||
| 421 | rxpkt[4], rxpkt[5], rxpkt[6], rxpkt[7], | ||
| 422 | rxpkt[8], rxpkt[9], rxpkt[10], rxpkt[11], | ||
| 423 | rxpkt[12], rxpkt[13], rxpkt[14], rxpkt[15]); | ||
| 424 | } | ||
| 425 | |||
| 426 | /** | ||
| 427 | * ks8851_rx_pkts - receive packets from the host | ||
| 428 | * @ks: The device information. | ||
| 429 | * | ||
| 430 | * This is called from the IRQ work queue when the system detects that there | ||
| 431 | * are packets in the receive queue. Find out how many packets there are and | ||
| 432 | * read them from the FIFO. | ||
| 433 | */ | ||
| 434 | static void ks8851_rx_pkts(struct ks8851_net *ks) | ||
| 435 | { | ||
| 436 | struct sk_buff *skb; | ||
| 437 | unsigned rxfc; | ||
| 438 | unsigned rxlen; | ||
| 439 | unsigned rxstat; | ||
| 440 | u32 rxh; | ||
| 441 | u8 *rxpkt; | ||
| 442 | |||
| 443 | rxfc = ks8851_rdreg8(ks, KS_RXFC); | ||
| 444 | |||
| 445 | if (netif_msg_rx_status(ks)) | ||
| 446 | ks_dbg(ks, "%s: %d packets\n", __func__, rxfc); | ||
| 447 | |||
| 448 | /* Currently we're issuing a read per packet, but we could possibly | ||
| 449 | * improve the code by issuing a single read, getting the receive | ||
| 450 | * header, allocating the packet and then reading the packet data | ||
| 451 | * out in one go. | ||
| 452 | * | ||
| 453 | * This form of operation would require us to hold the SPI bus' | ||
| 454 | * chipselect low during the entie transaction to avoid any | ||
| 455 | * reset to the data stream comming from the chip. | ||
| 456 | */ | ||
| 457 | |||
| 458 | for (; rxfc != 0; rxfc--) { | ||
| 459 | rxh = ks8851_rdreg32(ks, KS_RXFHSR); | ||
| 460 | rxstat = rxh & 0xffff; | ||
| 461 | rxlen = rxh >> 16; | ||
| 462 | |||
| 463 | if (netif_msg_rx_status(ks)) | ||
| 464 | ks_dbg(ks, "rx: stat 0x%04x, len 0x%04x\n", | ||
| 465 | rxstat, rxlen); | ||
| 466 | |||
| 467 | /* the length of the packet includes the 32bit CRC */ | ||
| 468 | |||
| 469 | /* set dma read address */ | ||
| 470 | ks8851_wrreg16(ks, KS_RXFDPR, RXFDPR_RXFPAI | 0x00); | ||
| 471 | |||
| 472 | /* start the packet dma process, and set auto-dequeue rx */ | ||
| 473 | ks8851_wrreg16(ks, KS_RXQCR, | ||
| 474 | ks->rc_rxqcr | RXQCR_SDA | RXQCR_ADRFE); | ||
| 475 | |||
| 476 | if (rxlen > 0) { | ||
| 477 | skb = netdev_alloc_skb(ks->netdev, rxlen + 2 + 8); | ||
| 478 | if (!skb) { | ||
| 479 | /* todo - dump frame and move on */ | ||
| 480 | } | ||
| 481 | |||
| 482 | /* two bytes to ensure ip is aligned, and four bytes | ||
| 483 | * for the status header and 4 bytes of garbage */ | ||
| 484 | skb_reserve(skb, 2 + 4 + 4); | ||
| 485 | |||
| 486 | rxpkt = skb_put(skb, rxlen - 4) - 8; | ||
| 487 | |||
| 488 | /* align the packet length to 4 bytes, and add 4 bytes | ||
| 489 | * as we're getting the rx status header as well */ | ||
| 490 | ks8851_rdfifo(ks, rxpkt, ALIGN(rxlen, 4) + 8); | ||
| 491 | |||
| 492 | if (netif_msg_pktdata(ks)) | ||
| 493 | ks8851_dbg_dumpkkt(ks, rxpkt); | ||
| 494 | |||
| 495 | skb->protocol = eth_type_trans(skb, ks->netdev); | ||
| 496 | netif_rx(skb); | ||
| 497 | |||
| 498 | ks->netdev->stats.rx_packets++; | ||
| 499 | ks->netdev->stats.rx_bytes += rxlen - 4; | ||
| 500 | } | ||
| 501 | |||
| 502 | ks8851_wrreg16(ks, KS_RXQCR, ks->rc_rxqcr); | ||
| 503 | } | ||
| 504 | } | ||
| 505 | |||
| 506 | /** | ||
| 507 | * ks8851_irq_work - work queue handler for dealing with interrupt requests | ||
| 508 | * @work: The work structure that was scheduled by schedule_work() | ||
| 509 | * | ||
| 510 | * This is the handler invoked when the ks8851_irq() is called to find out | ||
| 511 | * what happened, as we cannot allow ourselves to sleep whilst waiting for | ||
| 512 | * anything other process has the chip's lock. | ||
| 513 | * | ||
| 514 | * Read the interrupt status, work out what needs to be done and then clear | ||
| 515 | * any of the interrupts that are not needed. | ||
| 516 | */ | ||
| 517 | static void ks8851_irq_work(struct work_struct *work) | ||
| 518 | { | ||
| 519 | struct ks8851_net *ks = container_of(work, struct ks8851_net, irq_work); | ||
| 520 | unsigned status; | ||
| 521 | unsigned handled = 0; | ||
| 522 | |||
| 523 | mutex_lock(&ks->lock); | ||
| 524 | |||
| 525 | status = ks8851_rdreg16(ks, KS_ISR); | ||
| 526 | |||
| 527 | if (netif_msg_intr(ks)) | ||
| 528 | dev_dbg(&ks->spidev->dev, "%s: status 0x%04x\n", | ||
| 529 | __func__, status); | ||
| 530 | |||
| 531 | if (status & IRQ_LCI) { | ||
| 532 | /* should do something about checking link status */ | ||
| 533 | handled |= IRQ_LCI; | ||
| 534 | } | ||
| 535 | |||
| 536 | if (status & IRQ_LDI) { | ||
| 537 | u16 pmecr = ks8851_rdreg16(ks, KS_PMECR); | ||
| 538 | pmecr &= ~PMECR_WKEVT_MASK; | ||
| 539 | ks8851_wrreg16(ks, KS_PMECR, pmecr | PMECR_WKEVT_LINK); | ||
| 540 | |||
| 541 | handled |= IRQ_LDI; | ||
| 542 | } | ||
| 543 | |||
| 544 | if (status & IRQ_RXPSI) | ||
| 545 | handled |= IRQ_RXPSI; | ||
| 546 | |||
| 547 | if (status & IRQ_TXI) { | ||
| 548 | handled |= IRQ_TXI; | ||
| 549 | |||
| 550 | /* no lock here, tx queue should have been stopped */ | ||
| 551 | |||
| 552 | /* update our idea of how much tx space is available to the | ||
| 553 | * system */ | ||
| 554 | ks->tx_space = ks8851_rdreg16(ks, KS_TXMIR); | ||
| 555 | |||
| 556 | if (netif_msg_intr(ks)) | ||
| 557 | ks_dbg(ks, "%s: txspace %d\n", __func__, ks->tx_space); | ||
| 558 | } | ||
| 559 | |||
| 560 | if (status & IRQ_RXI) | ||
| 561 | handled |= IRQ_RXI; | ||
| 562 | |||
| 563 | if (status & IRQ_SPIBEI) { | ||
| 564 | dev_err(&ks->spidev->dev, "%s: spi bus error\n", __func__); | ||
| 565 | handled |= IRQ_SPIBEI; | ||
| 566 | } | ||
| 567 | |||
| 568 | ks8851_wrreg16(ks, KS_ISR, handled); | ||
| 569 | |||
| 570 | if (status & IRQ_RXI) { | ||
| 571 | /* the datasheet says to disable the rx interrupt during | ||
| 572 | * packet read-out, however we're masking the interrupt | ||
| 573 | * from the device so do not bother masking just the RX | ||
| 574 | * from the device. */ | ||
| 575 | |||
| 576 | ks8851_rx_pkts(ks); | ||
| 577 | } | ||
| 578 | |||
| 579 | /* if something stopped the rx process, probably due to wanting | ||
| 580 | * to change the rx settings, then do something about restarting | ||
| 581 | * it. */ | ||
| 582 | if (status & IRQ_RXPSI) { | ||
| 583 | struct ks8851_rxctrl *rxc = &ks->rxctrl; | ||
| 584 | |||
| 585 | /* update the multicast hash table */ | ||
| 586 | ks8851_wrreg16(ks, KS_MAHTR0, rxc->mchash[0]); | ||
| 587 | ks8851_wrreg16(ks, KS_MAHTR1, rxc->mchash[1]); | ||
| 588 | ks8851_wrreg16(ks, KS_MAHTR2, rxc->mchash[2]); | ||
| 589 | ks8851_wrreg16(ks, KS_MAHTR3, rxc->mchash[3]); | ||
| 590 | |||
| 591 | ks8851_wrreg16(ks, KS_RXCR2, rxc->rxcr2); | ||
| 592 | ks8851_wrreg16(ks, KS_RXCR1, rxc->rxcr1); | ||
| 593 | } | ||
| 594 | |||
| 595 | mutex_unlock(&ks->lock); | ||
| 596 | |||
| 597 | if (status & IRQ_TXI) | ||
| 598 | netif_wake_queue(ks->netdev); | ||
| 599 | |||
| 600 | enable_irq(ks->netdev->irq); | ||
| 601 | } | ||
| 602 | |||
| 603 | /** | ||
| 604 | * calc_txlen - calculate size of message to send packet | ||
| 605 | * @len: Lenght of data | ||
| 606 | * | ||
| 607 | * Returns the size of the TXFIFO message needed to send | ||
| 608 | * this packet. | ||
| 609 | */ | ||
| 610 | static inline unsigned calc_txlen(unsigned len) | ||
| 611 | { | ||
| 612 | return ALIGN(len + 4, 4); | ||
| 613 | } | ||
| 614 | |||
| 615 | /** | ||
| 616 | * ks8851_wrpkt - write packet to TX FIFO | ||
| 617 | * @ks: The device state. | ||
| 618 | * @txp: The sk_buff to transmit. | ||
| 619 | * @irq: IRQ on completion of the packet. | ||
| 620 | * | ||
| 621 | * Send the @txp to the chip. This means creating the relevant packet header | ||
| 622 | * specifying the length of the packet and the other information the chip | ||
| 623 | * needs, such as IRQ on completion. Send the header and the packet data to | ||
| 624 | * the device. | ||
| 625 | */ | ||
| 626 | static void ks8851_wrpkt(struct ks8851_net *ks, struct sk_buff *txp, bool irq) | ||
| 627 | { | ||
| 628 | struct spi_transfer *xfer = ks->spi_xfer2; | ||
| 629 | struct spi_message *msg = &ks->spi_msg2; | ||
| 630 | unsigned fid = 0; | ||
| 631 | int ret; | ||
| 632 | |||
| 633 | if (netif_msg_tx_queued(ks)) | ||
| 634 | dev_dbg(&ks->spidev->dev, "%s: skb %p, %d@%p, irq %d\n", | ||
| 635 | __func__, txp, txp->len, txp->data, irq); | ||
| 636 | |||
| 637 | fid = ks->fid++; | ||
| 638 | fid &= TXFR_TXFID_MASK; | ||
| 639 | |||
| 640 | if (irq) | ||
| 641 | fid |= TXFR_TXIC; /* irq on completion */ | ||
| 642 | |||
| 643 | /* start header at txb[1] to align txw entries */ | ||
| 644 | ks->txh.txb[1] = KS_SPIOP_TXFIFO; | ||
| 645 | ks->txh.txw[1] = cpu_to_le16(fid); | ||
| 646 | ks->txh.txw[2] = cpu_to_le16(txp->len); | ||
| 647 | |||
| 648 | xfer->tx_buf = &ks->txh.txb[1]; | ||
| 649 | xfer->rx_buf = NULL; | ||
| 650 | xfer->len = 5; | ||
| 651 | |||
| 652 | xfer++; | ||
| 653 | xfer->tx_buf = txp->data; | ||
| 654 | xfer->rx_buf = NULL; | ||
| 655 | xfer->len = ALIGN(txp->len, 4); | ||
| 656 | |||
| 657 | ret = spi_sync(ks->spidev, msg); | ||
| 658 | if (ret < 0) | ||
| 659 | ks_err(ks, "%s: spi_sync() failed\n", __func__); | ||
| 660 | } | ||
| 661 | |||
| 662 | /** | ||
| 663 | * ks8851_done_tx - update and then free skbuff after transmitting | ||
| 664 | * @ks: The device state | ||
| 665 | * @txb: The buffer transmitted | ||
| 666 | */ | ||
| 667 | static void ks8851_done_tx(struct ks8851_net *ks, struct sk_buff *txb) | ||
| 668 | { | ||
| 669 | struct net_device *dev = ks->netdev; | ||
| 670 | |||
| 671 | dev->stats.tx_bytes += txb->len; | ||
| 672 | dev->stats.tx_packets++; | ||
| 673 | |||
| 674 | dev_kfree_skb(txb); | ||
| 675 | } | ||
| 676 | |||
| 677 | /** | ||
| 678 | * ks8851_tx_work - process tx packet(s) | ||
| 679 | * @work: The work strucutre what was scheduled. | ||
| 680 | * | ||
| 681 | * This is called when a number of packets have been scheduled for | ||
| 682 | * transmission and need to be sent to the device. | ||
| 683 | */ | ||
| 684 | static void ks8851_tx_work(struct work_struct *work) | ||
| 685 | { | ||
| 686 | struct ks8851_net *ks = container_of(work, struct ks8851_net, tx_work); | ||
| 687 | struct sk_buff *txb; | ||
| 688 | bool last = false; | ||
| 689 | |||
| 690 | mutex_lock(&ks->lock); | ||
| 691 | |||
| 692 | while (!last) { | ||
| 693 | txb = skb_dequeue(&ks->txq); | ||
| 694 | last = skb_queue_empty(&ks->txq); | ||
| 695 | |||
| 696 | ks8851_wrreg16(ks, KS_RXQCR, ks->rc_rxqcr | RXQCR_SDA); | ||
| 697 | ks8851_wrpkt(ks, txb, last); | ||
| 698 | ks8851_wrreg16(ks, KS_RXQCR, ks->rc_rxqcr); | ||
| 699 | ks8851_wrreg16(ks, KS_TXQCR, TXQCR_METFE); | ||
| 700 | |||
| 701 | ks8851_done_tx(ks, txb); | ||
| 702 | } | ||
| 703 | |||
| 704 | mutex_unlock(&ks->lock); | ||
| 705 | } | ||
| 706 | |||
| 707 | /** | ||
| 708 | * ks8851_set_powermode - set power mode of the device | ||
| 709 | * @ks: The device state | ||
| 710 | * @pwrmode: The power mode value to write to KS_PMECR. | ||
| 711 | * | ||
| 712 | * Change the power mode of the chip. | ||
| 713 | */ | ||
| 714 | static void ks8851_set_powermode(struct ks8851_net *ks, unsigned pwrmode) | ||
| 715 | { | ||
| 716 | unsigned pmecr; | ||
| 717 | |||
| 718 | if (netif_msg_hw(ks)) | ||
| 719 | ks_dbg(ks, "setting power mode %d\n", pwrmode); | ||
| 720 | |||
| 721 | pmecr = ks8851_rdreg16(ks, KS_PMECR); | ||
| 722 | pmecr &= ~PMECR_PM_MASK; | ||
| 723 | pmecr |= pwrmode; | ||
| 724 | |||
| 725 | ks8851_wrreg16(ks, KS_PMECR, pmecr); | ||
| 726 | } | ||
| 727 | |||
| 728 | /** | ||
| 729 | * ks8851_net_open - open network device | ||
| 730 | * @dev: The network device being opened. | ||
| 731 | * | ||
| 732 | * Called when the network device is marked active, such as a user executing | ||
| 733 | * 'ifconfig up' on the device. | ||
| 734 | */ | ||
| 735 | static int ks8851_net_open(struct net_device *dev) | ||
| 736 | { | ||
| 737 | struct ks8851_net *ks = netdev_priv(dev); | ||
| 738 | |||
| 739 | /* lock the card, even if we may not actually be doing anything | ||
| 740 | * else at the moment */ | ||
| 741 | mutex_lock(&ks->lock); | ||
| 742 | |||
| 743 | if (netif_msg_ifup(ks)) | ||
| 744 | ks_dbg(ks, "opening %s\n", dev->name); | ||
| 745 | |||
| 746 | /* bring chip out of any power saving mode it was in */ | ||
| 747 | ks8851_set_powermode(ks, PMECR_PM_NORMAL); | ||
| 748 | |||
| 749 | /* issue a soft reset to the RX/TX QMU to put it into a known | ||
| 750 | * state. */ | ||
| 751 | ks8851_soft_reset(ks, GRR_QMU); | ||
| 752 | |||
| 753 | /* setup transmission parameters */ | ||
| 754 | |||
| 755 | ks8851_wrreg16(ks, KS_TXCR, (TXCR_TXE | /* enable transmit process */ | ||
| 756 | TXCR_TXPE | /* pad to min length */ | ||
| 757 | TXCR_TXCRC | /* add CRC */ | ||
| 758 | TXCR_TXFCE)); /* enable flow control */ | ||
| 759 | |||
| 760 | /* auto-increment tx data, reset tx pointer */ | ||
| 761 | ks8851_wrreg16(ks, KS_TXFDPR, TXFDPR_TXFPAI); | ||
| 762 | |||
| 763 | /* setup receiver control */ | ||
| 764 | |||
| 765 | ks8851_wrreg16(ks, KS_RXCR1, (RXCR1_RXPAFMA | /* from mac filter */ | ||
| 766 | RXCR1_RXFCE | /* enable flow control */ | ||
| 767 | RXCR1_RXBE | /* broadcast enable */ | ||
| 768 | RXCR1_RXUE | /* unicast enable */ | ||
| 769 | RXCR1_RXE)); /* enable rx block */ | ||
| 770 | |||
| 771 | /* transfer entire frames out in one go */ | ||
| 772 | ks8851_wrreg16(ks, KS_RXCR2, RXCR2_SRDBL_FRAME); | ||
| 773 | |||
| 774 | /* set receive counter timeouts */ | ||
| 775 | ks8851_wrreg16(ks, KS_RXDTTR, 1000); /* 1ms after first frame to IRQ */ | ||
| 776 | ks8851_wrreg16(ks, KS_RXDBCTR, 4096); /* >4Kbytes in buffer to IRQ */ | ||
| 777 | ks8851_wrreg16(ks, KS_RXFCTR, 10); /* 10 frames to IRQ */ | ||
| 778 | |||
| 779 | ks->rc_rxqcr = (RXQCR_RXFCTE | /* IRQ on frame count exceeded */ | ||
| 780 | RXQCR_RXDBCTE | /* IRQ on byte count exceeded */ | ||
| 781 | RXQCR_RXDTTE); /* IRQ on time exceeded */ | ||
| 782 | |||
| 783 | ks8851_wrreg16(ks, KS_RXQCR, ks->rc_rxqcr); | ||
| 784 | |||
| 785 | /* clear then enable interrupts */ | ||
| 786 | |||
| 787 | #define STD_IRQ (IRQ_LCI | /* Link Change */ \ | ||
| 788 | IRQ_TXI | /* TX done */ \ | ||
| 789 | IRQ_RXI | /* RX done */ \ | ||
| 790 | IRQ_SPIBEI | /* SPI bus error */ \ | ||
| 791 | IRQ_TXPSI | /* TX process stop */ \ | ||
| 792 | IRQ_RXPSI) /* RX process stop */ | ||
| 793 | |||
| 794 | ks->rc_ier = STD_IRQ; | ||
| 795 | ks8851_wrreg16(ks, KS_ISR, STD_IRQ); | ||
| 796 | ks8851_wrreg16(ks, KS_IER, STD_IRQ); | ||
| 797 | |||
| 798 | netif_start_queue(ks->netdev); | ||
| 799 | |||
| 800 | if (netif_msg_ifup(ks)) | ||
| 801 | ks_dbg(ks, "network device %s up\n", dev->name); | ||
| 802 | |||
| 803 | mutex_unlock(&ks->lock); | ||
| 804 | return 0; | ||
| 805 | } | ||
| 806 | |||
| 807 | /** | ||
| 808 | * ks8851_net_stop - close network device | ||
| 809 | * @dev: The device being closed. | ||
| 810 | * | ||
| 811 | * Called to close down a network device which has been active. Cancell any | ||
| 812 | * work, shutdown the RX and TX process and then place the chip into a low | ||
| 813 | * power state whilst it is not being used. | ||
| 814 | */ | ||
| 815 | static int ks8851_net_stop(struct net_device *dev) | ||
| 816 | { | ||
| 817 | struct ks8851_net *ks = netdev_priv(dev); | ||
| 818 | |||
| 819 | if (netif_msg_ifdown(ks)) | ||
| 820 | ks_info(ks, "%s: shutting down\n", dev->name); | ||
| 821 | |||
| 822 | netif_stop_queue(dev); | ||
| 823 | |||
| 824 | mutex_lock(&ks->lock); | ||
| 825 | |||
| 826 | /* stop any outstanding work */ | ||
| 827 | flush_work(&ks->irq_work); | ||
| 828 | flush_work(&ks->tx_work); | ||
| 829 | flush_work(&ks->rxctrl_work); | ||
| 830 | |||
| 831 | /* turn off the IRQs and ack any outstanding */ | ||
| 832 | ks8851_wrreg16(ks, KS_IER, 0x0000); | ||
| 833 | ks8851_wrreg16(ks, KS_ISR, 0xffff); | ||
| 834 | |||
| 835 | /* shutdown RX process */ | ||
| 836 | ks8851_wrreg16(ks, KS_RXCR1, 0x0000); | ||
| 837 | |||
| 838 | /* shutdown TX process */ | ||
| 839 | ks8851_wrreg16(ks, KS_TXCR, 0x0000); | ||
| 840 | |||
| 841 | /* set powermode to soft power down to save power */ | ||
| 842 | ks8851_set_powermode(ks, PMECR_PM_SOFTDOWN); | ||
| 843 | |||
| 844 | /* ensure any queued tx buffers are dumped */ | ||
| 845 | while (!skb_queue_empty(&ks->txq)) { | ||
| 846 | struct sk_buff *txb = skb_dequeue(&ks->txq); | ||
| 847 | |||
| 848 | if (netif_msg_ifdown(ks)) | ||
| 849 | ks_dbg(ks, "%s: freeing txb %p\n", __func__, txb); | ||
| 850 | |||
| 851 | dev_kfree_skb(txb); | ||
| 852 | } | ||
| 853 | |||
| 854 | mutex_unlock(&ks->lock); | ||
| 855 | return 0; | ||
| 856 | } | ||
| 857 | |||
| 858 | /** | ||
| 859 | * ks8851_start_xmit - transmit packet | ||
| 860 | * @skb: The buffer to transmit | ||
| 861 | * @dev: The device used to transmit the packet. | ||
| 862 | * | ||
| 863 | * Called by the network layer to transmit the @skb. Queue the packet for | ||
| 864 | * the device and schedule the necessary work to transmit the packet when | ||
| 865 | * it is free. | ||
| 866 | * | ||
| 867 | * We do this to firstly avoid sleeping with the network device locked, | ||
| 868 | * and secondly so we can round up more than one packet to transmit which | ||
| 869 | * means we can try and avoid generating too many transmit done interrupts. | ||
| 870 | */ | ||
| 871 | static int ks8851_start_xmit(struct sk_buff *skb, struct net_device *dev) | ||
| 872 | { | ||
| 873 | struct ks8851_net *ks = netdev_priv(dev); | ||
| 874 | unsigned needed = calc_txlen(skb->len); | ||
| 875 | int ret = NETDEV_TX_OK; | ||
| 876 | |||
| 877 | if (netif_msg_tx_queued(ks)) | ||
| 878 | ks_dbg(ks, "%s: skb %p, %d@%p\n", __func__, | ||
| 879 | skb, skb->len, skb->data); | ||
| 880 | |||
| 881 | spin_lock(&ks->statelock); | ||
| 882 | |||
| 883 | if (needed > ks->tx_space) { | ||
| 884 | netif_stop_queue(dev); | ||
| 885 | ret = NETDEV_TX_BUSY; | ||
| 886 | } else { | ||
| 887 | ks->tx_space -= needed; | ||
| 888 | skb_queue_tail(&ks->txq, skb); | ||
| 889 | } | ||
| 890 | |||
| 891 | spin_unlock(&ks->statelock); | ||
| 892 | schedule_work(&ks->tx_work); | ||
| 893 | |||
| 894 | return ret; | ||
| 895 | } | ||
| 896 | |||
| 897 | /** | ||
| 898 | * ks8851_rxctrl_work - work handler to change rx mode | ||
| 899 | * @work: The work structure this belongs to. | ||
| 900 | * | ||
| 901 | * Lock the device and issue the necessary changes to the receive mode from | ||
| 902 | * the network device layer. This is done so that we can do this without | ||
| 903 | * having to sleep whilst holding the network device lock. | ||
| 904 | * | ||
| 905 | * Since the recommendation from Micrel is that the RXQ is shutdown whilst the | ||
| 906 | * receive parameters are programmed, we issue a write to disable the RXQ and | ||
| 907 | * then wait for the interrupt handler to be triggered once the RXQ shutdown is | ||
| 908 | * complete. The interrupt handler then writes the new values into the chip. | ||
| 909 | */ | ||
| 910 | static void ks8851_rxctrl_work(struct work_struct *work) | ||
| 911 | { | ||
| 912 | struct ks8851_net *ks = container_of(work, struct ks8851_net, rxctrl_work); | ||
| 913 | |||
| 914 | mutex_lock(&ks->lock); | ||
| 915 | |||
| 916 | /* need to shutdown RXQ before modifying filter parameters */ | ||
| 917 | ks8851_wrreg16(ks, KS_RXCR1, 0x00); | ||
| 918 | |||
| 919 | mutex_unlock(&ks->lock); | ||
| 920 | } | ||
| 921 | |||
| 922 | static void ks8851_set_rx_mode(struct net_device *dev) | ||
| 923 | { | ||
| 924 | struct ks8851_net *ks = netdev_priv(dev); | ||
| 925 | struct ks8851_rxctrl rxctrl; | ||
| 926 | |||
| 927 | memset(&rxctrl, 0, sizeof(rxctrl)); | ||
| 928 | |||
| 929 | if (dev->flags & IFF_PROMISC) { | ||
| 930 | /* interface to receive everything */ | ||
| 931 | |||
| 932 | rxctrl.rxcr1 = RXCR1_RXAE | RXCR1_RXINVF; | ||
| 933 | } else if (dev->flags & IFF_ALLMULTI) { | ||
| 934 | /* accept all multicast packets */ | ||
| 935 | |||
| 936 | rxctrl.rxcr1 = (RXCR1_RXME | RXCR1_RXAE | | ||
| 937 | RXCR1_RXPAFMA | RXCR1_RXMAFMA); | ||
| 938 | } else if (dev->flags & IFF_MULTICAST && dev->mc_count > 0) { | ||
| 939 | struct dev_mc_list *mcptr = dev->mc_list; | ||
| 940 | u32 crc; | ||
| 941 | int i; | ||
| 942 | |||
| 943 | /* accept some multicast */ | ||
| 944 | |||
| 945 | for (i = dev->mc_count; i > 0; i--) { | ||
| 946 | crc = ether_crc(ETH_ALEN, mcptr->dmi_addr); | ||
| 947 | crc >>= (32 - 6); /* get top six bits */ | ||
| 948 | |||
| 949 | rxctrl.mchash[crc >> 4] |= (1 << (crc & 0xf)); | ||
| 950 | mcptr = mcptr->next; | ||
| 951 | } | ||
| 952 | |||
| 953 | rxctrl.rxcr1 = RXCR1_RXME | RXCR1_RXAE | RXCR1_RXPAFMA; | ||
| 954 | } else { | ||
| 955 | /* just accept broadcast / unicast */ | ||
| 956 | rxctrl.rxcr1 = RXCR1_RXPAFMA; | ||
| 957 | } | ||
| 958 | |||
| 959 | rxctrl.rxcr1 |= (RXCR1_RXUE | /* unicast enable */ | ||
| 960 | RXCR1_RXBE | /* broadcast enable */ | ||
| 961 | RXCR1_RXE | /* RX process enable */ | ||
| 962 | RXCR1_RXFCE); /* enable flow control */ | ||
| 963 | |||
| 964 | rxctrl.rxcr2 |= RXCR2_SRDBL_FRAME; | ||
| 965 | |||
| 966 | /* schedule work to do the actual set of the data if needed */ | ||
| 967 | |||
| 968 | spin_lock(&ks->statelock); | ||
| 969 | |||
| 970 | if (memcmp(&rxctrl, &ks->rxctrl, sizeof(rxctrl)) != 0) { | ||
| 971 | memcpy(&ks->rxctrl, &rxctrl, sizeof(ks->rxctrl)); | ||
| 972 | schedule_work(&ks->rxctrl_work); | ||
| 973 | } | ||
| 974 | |||
| 975 | spin_unlock(&ks->statelock); | ||
| 976 | } | ||
| 977 | |||
| 978 | static int ks8851_set_mac_address(struct net_device *dev, void *addr) | ||
| 979 | { | ||
| 980 | struct sockaddr *sa = addr; | ||
| 981 | |||
| 982 | if (netif_running(dev)) | ||
| 983 | return -EBUSY; | ||
| 984 | |||
| 985 | if (!is_valid_ether_addr(sa->sa_data)) | ||
| 986 | return -EADDRNOTAVAIL; | ||
| 987 | |||
| 988 | memcpy(dev->dev_addr, sa->sa_data, ETH_ALEN); | ||
| 989 | return ks8851_write_mac_addr(dev); | ||
| 990 | } | ||
| 991 | |||
| 992 | static int ks8851_net_ioctl(struct net_device *dev, struct ifreq *req, int cmd) | ||
| 993 | { | ||
| 994 | struct ks8851_net *ks = netdev_priv(dev); | ||
| 995 | |||
| 996 | if (!netif_running(dev)) | ||
| 997 | return -EINVAL; | ||
| 998 | |||
| 999 | return generic_mii_ioctl(&ks->mii, if_mii(req), cmd, NULL); | ||
| 1000 | } | ||
| 1001 | |||
| 1002 | static const struct net_device_ops ks8851_netdev_ops = { | ||
| 1003 | .ndo_open = ks8851_net_open, | ||
| 1004 | .ndo_stop = ks8851_net_stop, | ||
| 1005 | .ndo_do_ioctl = ks8851_net_ioctl, | ||
| 1006 | .ndo_start_xmit = ks8851_start_xmit, | ||
| 1007 | .ndo_set_mac_address = ks8851_set_mac_address, | ||
| 1008 | .ndo_set_rx_mode = ks8851_set_rx_mode, | ||
| 1009 | .ndo_change_mtu = eth_change_mtu, | ||
| 1010 | .ndo_validate_addr = eth_validate_addr, | ||
| 1011 | }; | ||
| 1012 | |||
| 1013 | /* ethtool support */ | ||
| 1014 | |||
| 1015 | static void ks8851_get_drvinfo(struct net_device *dev, | ||
| 1016 | struct ethtool_drvinfo *di) | ||
| 1017 | { | ||
| 1018 | strlcpy(di->driver, "KS8851", sizeof(di->driver)); | ||
| 1019 | strlcpy(di->version, "1.00", sizeof(di->version)); | ||
| 1020 | strlcpy(di->bus_info, dev_name(dev->dev.parent), sizeof(di->bus_info)); | ||
| 1021 | } | ||
| 1022 | |||
| 1023 | static u32 ks8851_get_msglevel(struct net_device *dev) | ||
| 1024 | { | ||
| 1025 | struct ks8851_net *ks = netdev_priv(dev); | ||
| 1026 | return ks->msg_enable; | ||
| 1027 | } | ||
| 1028 | |||
| 1029 | static void ks8851_set_msglevel(struct net_device *dev, u32 to) | ||
| 1030 | { | ||
| 1031 | struct ks8851_net *ks = netdev_priv(dev); | ||
| 1032 | ks->msg_enable = to; | ||
| 1033 | } | ||
| 1034 | |||
| 1035 | static int ks8851_get_settings(struct net_device *dev, struct ethtool_cmd *cmd) | ||
| 1036 | { | ||
| 1037 | struct ks8851_net *ks = netdev_priv(dev); | ||
| 1038 | return mii_ethtool_gset(&ks->mii, cmd); | ||
| 1039 | } | ||
| 1040 | |||
| 1041 | static int ks8851_set_settings(struct net_device *dev, struct ethtool_cmd *cmd) | ||
| 1042 | { | ||
| 1043 | struct ks8851_net *ks = netdev_priv(dev); | ||
| 1044 | return mii_ethtool_sset(&ks->mii, cmd); | ||
| 1045 | } | ||
| 1046 | |||
| 1047 | static u32 ks8851_get_link(struct net_device *dev) | ||
| 1048 | { | ||
| 1049 | struct ks8851_net *ks = netdev_priv(dev); | ||
| 1050 | return mii_link_ok(&ks->mii); | ||
| 1051 | } | ||
| 1052 | |||
| 1053 | static int ks8851_nway_reset(struct net_device *dev) | ||
| 1054 | { | ||
| 1055 | struct ks8851_net *ks = netdev_priv(dev); | ||
| 1056 | return mii_nway_restart(&ks->mii); | ||
| 1057 | } | ||
| 1058 | |||
| 1059 | static const struct ethtool_ops ks8851_ethtool_ops = { | ||
| 1060 | .get_drvinfo = ks8851_get_drvinfo, | ||
| 1061 | .get_msglevel = ks8851_get_msglevel, | ||
| 1062 | .set_msglevel = ks8851_set_msglevel, | ||
| 1063 | .get_settings = ks8851_get_settings, | ||
| 1064 | .set_settings = ks8851_set_settings, | ||
| 1065 | .get_link = ks8851_get_link, | ||
| 1066 | .nway_reset = ks8851_nway_reset, | ||
| 1067 | }; | ||
| 1068 | |||
| 1069 | /* MII interface controls */ | ||
| 1070 | |||
| 1071 | /** | ||
| 1072 | * ks8851_phy_reg - convert MII register into a KS8851 register | ||
| 1073 | * @reg: MII register number. | ||
| 1074 | * | ||
| 1075 | * Return the KS8851 register number for the corresponding MII PHY register | ||
| 1076 | * if possible. Return zero if the MII register has no direct mapping to the | ||
| 1077 | * KS8851 register set. | ||
| 1078 | */ | ||
| 1079 | static int ks8851_phy_reg(int reg) | ||
| 1080 | { | ||
| 1081 | switch (reg) { | ||
| 1082 | case MII_BMCR: | ||
| 1083 | return KS_P1MBCR; | ||
| 1084 | case MII_BMSR: | ||
| 1085 | return KS_P1MBSR; | ||
| 1086 | case MII_PHYSID1: | ||
| 1087 | return KS_PHY1ILR; | ||
| 1088 | case MII_PHYSID2: | ||
| 1089 | return KS_PHY1IHR; | ||
| 1090 | case MII_ADVERTISE: | ||
| 1091 | return KS_P1ANAR; | ||
| 1092 | case MII_LPA: | ||
| 1093 | return KS_P1ANLPR; | ||
| 1094 | } | ||
| 1095 | |||
| 1096 | return 0x0; | ||
| 1097 | } | ||
| 1098 | |||
| 1099 | /** | ||
| 1100 | * ks8851_phy_read - MII interface PHY register read. | ||
| 1101 | * @dev: The network device the PHY is on. | ||
| 1102 | * @phy_addr: Address of PHY (ignored as we only have one) | ||
| 1103 | * @reg: The register to read. | ||
| 1104 | * | ||
| 1105 | * This call reads data from the PHY register specified in @reg. Since the | ||
| 1106 | * device does not support all the MII registers, the non-existant values | ||
| 1107 | * are always returned as zero. | ||
| 1108 | * | ||
| 1109 | * We return zero for unsupported registers as the MII code does not check | ||
| 1110 | * the value returned for any error status, and simply returns it to the | ||
| 1111 | * caller. The mii-tool that the driver was tested with takes any -ve error | ||
| 1112 | * as real PHY capabilities, thus displaying incorrect data to the user. | ||
| 1113 | */ | ||
| 1114 | static int ks8851_phy_read(struct net_device *dev, int phy_addr, int reg) | ||
| 1115 | { | ||
| 1116 | struct ks8851_net *ks = netdev_priv(dev); | ||
| 1117 | int ksreg; | ||
| 1118 | int result; | ||
| 1119 | |||
| 1120 | ksreg = ks8851_phy_reg(reg); | ||
| 1121 | if (!ksreg) | ||
| 1122 | return 0x0; /* no error return allowed, so use zero */ | ||
| 1123 | |||
| 1124 | mutex_lock(&ks->lock); | ||
| 1125 | result = ks8851_rdreg16(ks, ksreg); | ||
| 1126 | mutex_unlock(&ks->lock); | ||
| 1127 | |||
| 1128 | return result; | ||
| 1129 | } | ||
| 1130 | |||
| 1131 | static void ks8851_phy_write(struct net_device *dev, | ||
| 1132 | int phy, int reg, int value) | ||
| 1133 | { | ||
| 1134 | struct ks8851_net *ks = netdev_priv(dev); | ||
| 1135 | int ksreg; | ||
| 1136 | |||
| 1137 | ksreg = ks8851_phy_reg(reg); | ||
| 1138 | if (ksreg) { | ||
| 1139 | mutex_lock(&ks->lock); | ||
| 1140 | ks8851_wrreg16(ks, ksreg, value); | ||
| 1141 | mutex_unlock(&ks->lock); | ||
| 1142 | } | ||
| 1143 | } | ||
| 1144 | |||
| 1145 | /** | ||
| 1146 | * ks8851_read_selftest - read the selftest memory info. | ||
| 1147 | * @ks: The device state | ||
| 1148 | * | ||
| 1149 | * Read and check the TX/RX memory selftest information. | ||
| 1150 | */ | ||
| 1151 | static int ks8851_read_selftest(struct ks8851_net *ks) | ||
| 1152 | { | ||
| 1153 | unsigned both_done = MBIR_TXMBF | MBIR_RXMBF; | ||
| 1154 | int ret = 0; | ||
| 1155 | unsigned rd; | ||
| 1156 | |||
| 1157 | rd = ks8851_rdreg16(ks, KS_MBIR); | ||
| 1158 | |||
| 1159 | if ((rd & both_done) != both_done) { | ||
| 1160 | ks_warn(ks, "Memory selftest not finished\n"); | ||
| 1161 | return 0; | ||
| 1162 | } | ||
| 1163 | |||
| 1164 | if (rd & MBIR_TXMBFA) { | ||
| 1165 | ks_err(ks, "TX memory selftest fail\n"); | ||
| 1166 | ret |= 1; | ||
| 1167 | } | ||
| 1168 | |||
| 1169 | if (rd & MBIR_RXMBFA) { | ||
| 1170 | ks_err(ks, "RX memory selftest fail\n"); | ||
| 1171 | ret |= 2; | ||
| 1172 | } | ||
| 1173 | |||
| 1174 | return 0; | ||
| 1175 | } | ||
| 1176 | |||
| 1177 | /* driver bus management functions */ | ||
| 1178 | |||
| 1179 | static int __devinit ks8851_probe(struct spi_device *spi) | ||
| 1180 | { | ||
| 1181 | struct net_device *ndev; | ||
| 1182 | struct ks8851_net *ks; | ||
| 1183 | int ret; | ||
| 1184 | |||
| 1185 | ndev = alloc_etherdev(sizeof(struct ks8851_net)); | ||
| 1186 | if (!ndev) { | ||
| 1187 | dev_err(&spi->dev, "failed to alloc ethernet device\n"); | ||
| 1188 | return -ENOMEM; | ||
| 1189 | } | ||
| 1190 | |||
| 1191 | spi->bits_per_word = 8; | ||
| 1192 | |||
| 1193 | ks = netdev_priv(ndev); | ||
| 1194 | |||
| 1195 | ks->netdev = ndev; | ||
| 1196 | ks->spidev = spi; | ||
| 1197 | ks->tx_space = 6144; | ||
| 1198 | |||
| 1199 | mutex_init(&ks->lock); | ||
| 1200 | spin_lock_init(&ks->statelock); | ||
| 1201 | |||
| 1202 | INIT_WORK(&ks->tx_work, ks8851_tx_work); | ||
| 1203 | INIT_WORK(&ks->irq_work, ks8851_irq_work); | ||
| 1204 | INIT_WORK(&ks->rxctrl_work, ks8851_rxctrl_work); | ||
| 1205 | |||
| 1206 | /* initialise pre-made spi transfer messages */ | ||
| 1207 | |||
| 1208 | spi_message_init(&ks->spi_msg1); | ||
| 1209 | spi_message_add_tail(&ks->spi_xfer1, &ks->spi_msg1); | ||
| 1210 | |||
| 1211 | spi_message_init(&ks->spi_msg2); | ||
| 1212 | spi_message_add_tail(&ks->spi_xfer2[0], &ks->spi_msg2); | ||
| 1213 | spi_message_add_tail(&ks->spi_xfer2[1], &ks->spi_msg2); | ||
| 1214 | |||
| 1215 | /* setup mii state */ | ||
| 1216 | ks->mii.dev = ndev; | ||
| 1217 | ks->mii.phy_id = 1, | ||
| 1218 | ks->mii.phy_id_mask = 1; | ||
| 1219 | ks->mii.reg_num_mask = 0xf; | ||
| 1220 | ks->mii.mdio_read = ks8851_phy_read; | ||
| 1221 | ks->mii.mdio_write = ks8851_phy_write; | ||
| 1222 | |||
| 1223 | dev_info(&spi->dev, "message enable is %d\n", msg_enable); | ||
| 1224 | |||
| 1225 | /* set the default message enable */ | ||
| 1226 | ks->msg_enable = netif_msg_init(msg_enable, (NETIF_MSG_DRV | | ||
| 1227 | NETIF_MSG_PROBE | | ||
| 1228 | NETIF_MSG_LINK)); | ||
| 1229 | |||
| 1230 | skb_queue_head_init(&ks->txq); | ||
| 1231 | |||
| 1232 | SET_ETHTOOL_OPS(ndev, &ks8851_ethtool_ops); | ||
| 1233 | SET_NETDEV_DEV(ndev, &spi->dev); | ||
| 1234 | |||
| 1235 | dev_set_drvdata(&spi->dev, ks); | ||
| 1236 | |||
| 1237 | ndev->if_port = IF_PORT_100BASET; | ||
| 1238 | ndev->netdev_ops = &ks8851_netdev_ops; | ||
| 1239 | ndev->irq = spi->irq; | ||
| 1240 | |||
| 1241 | /* simple check for a valid chip being connected to the bus */ | ||
| 1242 | |||
| 1243 | if ((ks8851_rdreg16(ks, KS_CIDER) & ~CIDER_REV_MASK) != CIDER_ID) { | ||
| 1244 | dev_err(&spi->dev, "failed to read device ID\n"); | ||
| 1245 | ret = -ENODEV; | ||
| 1246 | goto err_id; | ||
| 1247 | } | ||
| 1248 | |||
| 1249 | ks8851_read_selftest(ks); | ||
| 1250 | ks8851_init_mac(ks); | ||
| 1251 | |||
| 1252 | ret = request_irq(spi->irq, ks8851_irq, IRQF_TRIGGER_LOW, | ||
| 1253 | ndev->name, ks); | ||
| 1254 | if (ret < 0) { | ||
| 1255 | dev_err(&spi->dev, "failed to get irq\n"); | ||
| 1256 | goto err_irq; | ||
| 1257 | } | ||
| 1258 | |||
| 1259 | ret = register_netdev(ndev); | ||
| 1260 | if (ret) { | ||
| 1261 | dev_err(&spi->dev, "failed to register network device\n"); | ||
| 1262 | goto err_netdev; | ||
| 1263 | } | ||
| 1264 | |||
| 1265 | dev_info(&spi->dev, "revision %d, MAC %pM, IRQ %d\n", | ||
| 1266 | CIDER_REV_GET(ks8851_rdreg16(ks, KS_CIDER)), | ||
| 1267 | ndev->dev_addr, ndev->irq); | ||
| 1268 | |||
| 1269 | return 0; | ||
| 1270 | |||
| 1271 | |||
| 1272 | err_netdev: | ||
| 1273 | free_irq(ndev->irq, ndev); | ||
| 1274 | |||
| 1275 | err_id: | ||
| 1276 | err_irq: | ||
| 1277 | free_netdev(ndev); | ||
| 1278 | return ret; | ||
| 1279 | } | ||
| 1280 | |||
| 1281 | static int __devexit ks8851_remove(struct spi_device *spi) | ||
| 1282 | { | ||
| 1283 | struct ks8851_net *priv = dev_get_drvdata(&spi->dev); | ||
| 1284 | |||
| 1285 | if (netif_msg_drv(priv)) | ||
| 1286 | dev_info(&spi->dev, "remove"); | ||
| 1287 | |||
| 1288 | unregister_netdev(priv->netdev); | ||
| 1289 | free_irq(spi->irq, priv); | ||
| 1290 | free_netdev(priv->netdev); | ||
| 1291 | |||
| 1292 | return 0; | ||
| 1293 | } | ||
| 1294 | |||
| 1295 | static struct spi_driver ks8851_driver = { | ||
| 1296 | .driver = { | ||
| 1297 | .name = "ks8851", | ||
| 1298 | .owner = THIS_MODULE, | ||
| 1299 | }, | ||
| 1300 | .probe = ks8851_probe, | ||
| 1301 | .remove = __devexit_p(ks8851_remove), | ||
| 1302 | }; | ||
| 1303 | |||
| 1304 | static int __init ks8851_init(void) | ||
| 1305 | { | ||
| 1306 | return spi_register_driver(&ks8851_driver); | ||
| 1307 | } | ||
| 1308 | |||
| 1309 | static void __exit ks8851_exit(void) | ||
| 1310 | { | ||
| 1311 | spi_unregister_driver(&ks8851_driver); | ||
| 1312 | } | ||
| 1313 | |||
| 1314 | module_init(ks8851_init); | ||
| 1315 | module_exit(ks8851_exit); | ||
| 1316 | |||
| 1317 | MODULE_DESCRIPTION("KS8851 Network driver"); | ||
| 1318 | MODULE_AUTHOR("Ben Dooks <ben@simtec.co.uk>"); | ||
| 1319 | MODULE_LICENSE("GPL"); | ||
| 1320 | |||
| 1321 | module_param_named(message, msg_enable, int, 0); | ||
| 1322 | MODULE_PARM_DESC(message, "Message verbosity level (0=none, 31=all)"); | ||
diff --git a/drivers/net/ks8851.h b/drivers/net/ks8851.h new file mode 100644 index 000000000000..85abe147afbf --- /dev/null +++ b/drivers/net/ks8851.h | |||
| @@ -0,0 +1,296 @@ | |||
| 1 | /* drivers/net/ks8851.h | ||
| 2 | * | ||
| 3 | * Copyright 2009 Simtec Electronics | ||
| 4 | * Ben Dooks <ben@simtec.co.uk> | ||
| 5 | * | ||
| 6 | * KS8851 register definitions | ||
| 7 | * | ||
| 8 | * This program is free software; you can redistribute it and/or modify | ||
| 9 | * it under the terms of the GNU General Public License version 2 as | ||
| 10 | * published by the Free Software Foundation. | ||
| 11 | */ | ||
| 12 | |||
| 13 | #define KS_CCR 0x08 | ||
| 14 | #define CCR_EEPROM (1 << 9) | ||
| 15 | #define CCR_SPI (1 << 8) | ||
| 16 | #define CCR_32PIN (1 << 0) | ||
| 17 | |||
| 18 | /* MAC address registers */ | ||
| 19 | #define KS_MARL 0x10 | ||
| 20 | #define KS_MARM 0x12 | ||
| 21 | #define KS_MARH 0x14 | ||
| 22 | |||
| 23 | #define KS_OBCR 0x20 | ||
| 24 | #define OBCR_ODS_16mA (1 << 6) | ||
| 25 | |||
| 26 | #define KS_EEPCR 0x22 | ||
| 27 | #define EEPCR_EESA (1 << 4) | ||
| 28 | #define EEPCR_EESB (1 << 3) | ||
| 29 | #define EEPCR_EEDO (1 << 2) | ||
| 30 | #define EEPCR_EESCK (1 << 1) | ||
| 31 | #define EEPCR_EECS (1 << 0) | ||
| 32 | |||
| 33 | #define KS_MBIR 0x24 | ||
| 34 | #define MBIR_TXMBF (1 << 12) | ||
| 35 | #define MBIR_TXMBFA (1 << 11) | ||
| 36 | #define MBIR_RXMBF (1 << 4) | ||
| 37 | #define MBIR_RXMBFA (1 << 3) | ||
| 38 | |||
| 39 | #define KS_GRR 0x26 | ||
| 40 | #define GRR_QMU (1 << 1) | ||
| 41 | #define GRR_GSR (1 << 0) | ||
| 42 | |||
| 43 | #define KS_WFCR 0x2A | ||
| 44 | #define WFCR_MPRXE (1 << 7) | ||
| 45 | #define WFCR_WF3E (1 << 3) | ||
| 46 | #define WFCR_WF2E (1 << 2) | ||
| 47 | #define WFCR_WF1E (1 << 1) | ||
| 48 | #define WFCR_WF0E (1 << 0) | ||
| 49 | |||
| 50 | #define KS_WF0CRC0 0x30 | ||
| 51 | #define KS_WF0CRC1 0x32 | ||
| 52 | #define KS_WF0BM0 0x34 | ||
| 53 | #define KS_WF0BM1 0x36 | ||
| 54 | #define KS_WF0BM2 0x38 | ||
| 55 | #define KS_WF0BM3 0x3A | ||
| 56 | |||
| 57 | #define KS_WF1CRC0 0x40 | ||
| 58 | #define KS_WF1CRC1 0x42 | ||
| 59 | #define KS_WF1BM0 0x44 | ||
| 60 | #define KS_WF1BM1 0x46 | ||
| 61 | #define KS_WF1BM2 0x48 | ||
| 62 | #define KS_WF1BM3 0x4A | ||
| 63 | |||
| 64 | #define KS_WF2CRC0 0x50 | ||
| 65 | #define KS_WF2CRC1 0x52 | ||
| 66 | #define KS_WF2BM0 0x54 | ||
| 67 | #define KS_WF2BM1 0x56 | ||
| 68 | #define KS_WF2BM2 0x58 | ||
| 69 | #define KS_WF2BM3 0x5A | ||
| 70 | |||
| 71 | #define KS_WF3CRC0 0x60 | ||
| 72 | #define KS_WF3CRC1 0x62 | ||
| 73 | #define KS_WF3BM0 0x64 | ||
| 74 | #define KS_WF3BM1 0x66 | ||
| 75 | #define KS_WF3BM2 0x68 | ||
| 76 | #define KS_WF3BM3 0x6A | ||
| 77 | |||
| 78 | #define KS_TXCR 0x70 | ||
| 79 | #define TXCR_TCGICMP (1 << 8) | ||
| 80 | #define TXCR_TCGUDP (1 << 7) | ||
| 81 | #define TXCR_TCGTCP (1 << 6) | ||
| 82 | #define TXCR_TCGIP (1 << 5) | ||
| 83 | #define TXCR_FTXQ (1 << 4) | ||
| 84 | #define TXCR_TXFCE (1 << 3) | ||
| 85 | #define TXCR_TXPE (1 << 2) | ||
| 86 | #define TXCR_TXCRC (1 << 1) | ||
| 87 | #define TXCR_TXE (1 << 0) | ||
| 88 | |||
| 89 | #define KS_TXSR 0x72 | ||
| 90 | #define TXSR_TXLC (1 << 13) | ||
| 91 | #define TXSR_TXMC (1 << 12) | ||
| 92 | #define TXSR_TXFID_MASK (0x3f << 0) | ||
| 93 | #define TXSR_TXFID_SHIFT (0) | ||
| 94 | #define TXSR_TXFID_GET(_v) (((_v) >> 0) & 0x3f) | ||
| 95 | |||
| 96 | #define KS_RXCR1 0x74 | ||
| 97 | #define RXCR1_FRXQ (1 << 15) | ||
| 98 | #define RXCR1_RXUDPFCC (1 << 14) | ||
| 99 | #define RXCR1_RXTCPFCC (1 << 13) | ||
| 100 | #define RXCR1_RXIPFCC (1 << 12) | ||
| 101 | #define RXCR1_RXPAFMA (1 << 11) | ||
| 102 | #define RXCR1_RXFCE (1 << 10) | ||
| 103 | #define RXCR1_RXEFE (1 << 9) | ||
| 104 | #define RXCR1_RXMAFMA (1 << 8) | ||
| 105 | #define RXCR1_RXBE (1 << 7) | ||
| 106 | #define RXCR1_RXME (1 << 6) | ||
| 107 | #define RXCR1_RXUE (1 << 5) | ||
| 108 | #define RXCR1_RXAE (1 << 4) | ||
| 109 | #define RXCR1_RXINVF (1 << 1) | ||
| 110 | #define RXCR1_RXE (1 << 0) | ||
| 111 | |||
| 112 | #define KS_RXCR2 0x76 | ||
| 113 | #define RXCR2_SRDBL_MASK (0x7 << 5) | ||
| 114 | #define RXCR2_SRDBL_SHIFT (5) | ||
| 115 | #define RXCR2_SRDBL_4B (0x0 << 5) | ||
| 116 | #define RXCR2_SRDBL_8B (0x1 << 5) | ||
| 117 | #define RXCR2_SRDBL_16B (0x2 << 5) | ||
| 118 | #define RXCR2_SRDBL_32B (0x3 << 5) | ||
| 119 | #define RXCR2_SRDBL_FRAME (0x4 << 5) | ||
| 120 | #define RXCR2_IUFFP (1 << 4) | ||
| 121 | #define RXCR2_RXIUFCEZ (1 << 3) | ||
| 122 | #define RXCR2_UDPLFE (1 << 2) | ||
| 123 | #define RXCR2_RXICMPFCC (1 << 1) | ||
| 124 | #define RXCR2_RXSAF (1 << 0) | ||
| 125 | |||
| 126 | #define KS_TXMIR 0x78 | ||
| 127 | |||
| 128 | #define KS_RXFHSR 0x7C | ||
| 129 | #define RXFSHR_RXFV (1 << 15) | ||
| 130 | #define RXFSHR_RXICMPFCS (1 << 13) | ||
| 131 | #define RXFSHR_RXIPFCS (1 << 12) | ||
| 132 | #define RXFSHR_RXTCPFCS (1 << 11) | ||
| 133 | #define RXFSHR_RXUDPFCS (1 << 10) | ||
| 134 | #define RXFSHR_RXBF (1 << 7) | ||
| 135 | #define RXFSHR_RXMF (1 << 6) | ||
| 136 | #define RXFSHR_RXUF (1 << 5) | ||
| 137 | #define RXFSHR_RXMR (1 << 4) | ||
| 138 | #define RXFSHR_RXFT (1 << 3) | ||
| 139 | #define RXFSHR_RXFTL (1 << 2) | ||
| 140 | #define RXFSHR_RXRF (1 << 1) | ||
| 141 | #define RXFSHR_RXCE (1 << 0) | ||
| 142 | |||
| 143 | #define KS_RXFHBCR 0x7E | ||
| 144 | #define KS_TXQCR 0x80 | ||
| 145 | #define TXQCR_AETFE (1 << 2) | ||
| 146 | #define TXQCR_TXQMAM (1 << 1) | ||
| 147 | #define TXQCR_METFE (1 << 0) | ||
| 148 | |||
| 149 | #define KS_RXQCR 0x82 | ||
| 150 | #define RXQCR_RXDTTS (1 << 12) | ||
| 151 | #define RXQCR_RXDBCTS (1 << 11) | ||
| 152 | #define RXQCR_RXFCTS (1 << 10) | ||
| 153 | #define RXQCR_RXIPHTOE (1 << 9) | ||
| 154 | #define RXQCR_RXDTTE (1 << 7) | ||
| 155 | #define RXQCR_RXDBCTE (1 << 6) | ||
| 156 | #define RXQCR_RXFCTE (1 << 5) | ||
| 157 | #define RXQCR_ADRFE (1 << 4) | ||
| 158 | #define RXQCR_SDA (1 << 3) | ||
| 159 | #define RXQCR_RRXEF (1 << 0) | ||
| 160 | |||
| 161 | #define KS_TXFDPR 0x84 | ||
| 162 | #define TXFDPR_TXFPAI (1 << 14) | ||
| 163 | #define TXFDPR_TXFP_MASK (0x7ff << 0) | ||
| 164 | #define TXFDPR_TXFP_SHIFT (0) | ||
| 165 | |||
| 166 | #define KS_RXFDPR 0x86 | ||
| 167 | #define RXFDPR_RXFPAI (1 << 14) | ||
| 168 | |||
| 169 | #define KS_RXDTTR 0x8C | ||
| 170 | #define KS_RXDBCTR 0x8E | ||
| 171 | |||
| 172 | #define KS_IER 0x90 | ||
| 173 | #define KS_ISR 0x92 | ||
| 174 | #define IRQ_LCI (1 << 15) | ||
| 175 | #define IRQ_TXI (1 << 14) | ||
| 176 | #define IRQ_RXI (1 << 13) | ||
| 177 | #define IRQ_RXOI (1 << 11) | ||
| 178 | #define IRQ_TXPSI (1 << 9) | ||
| 179 | #define IRQ_RXPSI (1 << 8) | ||
| 180 | #define IRQ_TXSAI (1 << 6) | ||
| 181 | #define IRQ_RXWFDI (1 << 5) | ||
| 182 | #define IRQ_RXMPDI (1 << 4) | ||
| 183 | #define IRQ_LDI (1 << 3) | ||
| 184 | #define IRQ_EDI (1 << 2) | ||
| 185 | #define IRQ_SPIBEI (1 << 1) | ||
| 186 | #define IRQ_DEDI (1 << 0) | ||
| 187 | |||
| 188 | #define KS_RXFCTR 0x9C | ||
| 189 | #define KS_RXFC 0x9D | ||
| 190 | #define RXFCTR_RXFC_MASK (0xff << 8) | ||
| 191 | #define RXFCTR_RXFC_SHIFT (8) | ||
| 192 | #define RXFCTR_RXFC_GET(_v) (((_v) >> 8) & 0xff) | ||
| 193 | #define RXFCTR_RXFCT_MASK (0xff << 0) | ||
| 194 | #define RXFCTR_RXFCT_SHIFT (0) | ||
| 195 | |||
| 196 | #define KS_TXNTFSR 0x9E | ||
| 197 | |||
| 198 | #define KS_MAHTR0 0xA0 | ||
| 199 | #define KS_MAHTR1 0xA2 | ||
| 200 | #define KS_MAHTR2 0xA4 | ||
| 201 | #define KS_MAHTR3 0xA6 | ||
| 202 | |||
| 203 | #define KS_FCLWR 0xB0 | ||
| 204 | #define KS_FCHWR 0xB2 | ||
| 205 | #define KS_FCOWR 0xB4 | ||
| 206 | |||
| 207 | #define KS_CIDER 0xC0 | ||
| 208 | #define CIDER_ID 0x8870 | ||
| 209 | #define CIDER_REV_MASK (0x7 << 1) | ||
| 210 | #define CIDER_REV_SHIFT (1) | ||
| 211 | #define CIDER_REV_GET(_v) (((_v) >> 1) & 0x7) | ||
| 212 | |||
| 213 | #define KS_CGCR 0xC6 | ||
| 214 | |||
| 215 | #define KS_IACR 0xC8 | ||
| 216 | #define IACR_RDEN (1 << 12) | ||
| 217 | #define IACR_TSEL_MASK (0x3 << 10) | ||
| 218 | #define IACR_TSEL_SHIFT (10) | ||
| 219 | #define IACR_TSEL_MIB (0x3 << 10) | ||
| 220 | #define IACR_ADDR_MASK (0x1f << 0) | ||
| 221 | #define IACR_ADDR_SHIFT (0) | ||
| 222 | |||
| 223 | #define KS_IADLR 0xD0 | ||
| 224 | #define KS_IAHDR 0xD2 | ||
| 225 | |||
| 226 | #define KS_PMECR 0xD4 | ||
| 227 | #define PMECR_PME_DELAY (1 << 14) | ||
| 228 | #define PMECR_PME_POL (1 << 12) | ||
| 229 | #define PMECR_WOL_WAKEUP (1 << 11) | ||
| 230 | #define PMECR_WOL_MAGICPKT (1 << 10) | ||
| 231 | #define PMECR_WOL_LINKUP (1 << 9) | ||
| 232 | #define PMECR_WOL_ENERGY (1 << 8) | ||
| 233 | #define PMECR_AUTO_WAKE_EN (1 << 7) | ||
| 234 | #define PMECR_WAKEUP_NORMAL (1 << 6) | ||
| 235 | #define PMECR_WKEVT_MASK (0xf << 2) | ||
| 236 | #define PMECR_WKEVT_SHIFT (2) | ||
| 237 | #define PMECR_WKEVT_GET(_v) (((_v) >> 2) & 0xf) | ||
| 238 | #define PMECR_WKEVT_ENERGY (0x1 << 2) | ||
| 239 | #define PMECR_WKEVT_LINK (0x2 << 2) | ||
| 240 | #define PMECR_WKEVT_MAGICPKT (0x4 << 2) | ||
| 241 | #define PMECR_WKEVT_FRAME (0x8 << 2) | ||
| 242 | #define PMECR_PM_MASK (0x3 << 0) | ||
| 243 | #define PMECR_PM_SHIFT (0) | ||
| 244 | #define PMECR_PM_NORMAL (0x0 << 0) | ||
| 245 | #define PMECR_PM_ENERGY (0x1 << 0) | ||
| 246 | #define PMECR_PM_SOFTDOWN (0x2 << 0) | ||
| 247 | #define PMECR_PM_POWERSAVE (0x3 << 0) | ||
| 248 | |||
| 249 | /* Standard MII PHY data */ | ||
| 250 | #define KS_P1MBCR 0xE4 | ||
| 251 | #define KS_P1MBSR 0xE6 | ||
| 252 | #define KS_PHY1ILR 0xE8 | ||
| 253 | #define KS_PHY1IHR 0xEA | ||
| 254 | #define KS_P1ANAR 0xEC | ||
| 255 | #define KS_P1ANLPR 0xEE | ||
| 256 | |||
| 257 | #define KS_P1SCLMD 0xF4 | ||
| 258 | #define P1SCLMD_LEDOFF (1 << 15) | ||
| 259 | #define P1SCLMD_TXIDS (1 << 14) | ||
| 260 | #define P1SCLMD_RESTARTAN (1 << 13) | ||
| 261 | #define P1SCLMD_DISAUTOMDIX (1 << 10) | ||
| 262 | #define P1SCLMD_FORCEMDIX (1 << 9) | ||
| 263 | #define P1SCLMD_AUTONEGEN (1 << 7) | ||
| 264 | #define P1SCLMD_FORCE100 (1 << 6) | ||
| 265 | #define P1SCLMD_FORCEFDX (1 << 5) | ||
| 266 | #define P1SCLMD_ADV_FLOW (1 << 4) | ||
| 267 | #define P1SCLMD_ADV_100BT_FDX (1 << 3) | ||
| 268 | #define P1SCLMD_ADV_100BT_HDX (1 << 2) | ||
| 269 | #define P1SCLMD_ADV_10BT_FDX (1 << 1) | ||
| 270 | #define P1SCLMD_ADV_10BT_HDX (1 << 0) | ||
| 271 | |||
| 272 | #define KS_P1CR 0xF6 | ||
| 273 | #define P1CR_HP_MDIX (1 << 15) | ||
| 274 | #define P1CR_REV_POL (1 << 13) | ||
| 275 | #define P1CR_OP_100M (1 << 10) | ||
| 276 | #define P1CR_OP_FDX (1 << 9) | ||
| 277 | #define P1CR_OP_MDI (1 << 7) | ||
| 278 | #define P1CR_AN_DONE (1 << 6) | ||
| 279 | #define P1CR_LINK_GOOD (1 << 5) | ||
| 280 | #define P1CR_PNTR_FLOW (1 << 4) | ||
| 281 | #define P1CR_PNTR_100BT_FDX (1 << 3) | ||
| 282 | #define P1CR_PNTR_100BT_HDX (1 << 2) | ||
| 283 | #define P1CR_PNTR_10BT_FDX (1 << 1) | ||
| 284 | #define P1CR_PNTR_10BT_HDX (1 << 0) | ||
| 285 | |||
| 286 | /* TX Frame control */ | ||
| 287 | |||
| 288 | #define TXFR_TXIC (1 << 15) | ||
| 289 | #define TXFR_TXFID_MASK (0x3f << 0) | ||
| 290 | #define TXFR_TXFID_SHIFT (0) | ||
| 291 | |||
| 292 | /* SPI frame opcodes */ | ||
| 293 | #define KS_SPIOP_RD (0x00) | ||
| 294 | #define KS_SPIOP_WR (0x40) | ||
| 295 | #define KS_SPIOP_RXFIFO (0x80) | ||
| 296 | #define KS_SPIOP_TXFIFO (0xC0) | ||
diff --git a/drivers/net/macb.c b/drivers/net/macb.c index 5b5c25368d1e..e3601cf3f931 100644 --- a/drivers/net/macb.c +++ b/drivers/net/macb.c | |||
| @@ -620,6 +620,7 @@ static int macb_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 620 | dma_addr_t mapping; | 620 | dma_addr_t mapping; |
| 621 | unsigned int len, entry; | 621 | unsigned int len, entry; |
| 622 | u32 ctrl; | 622 | u32 ctrl; |
| 623 | unsigned long flags; | ||
| 623 | 624 | ||
| 624 | #ifdef DEBUG | 625 | #ifdef DEBUG |
| 625 | int i; | 626 | int i; |
| @@ -635,12 +636,12 @@ static int macb_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 635 | #endif | 636 | #endif |
| 636 | 637 | ||
| 637 | len = skb->len; | 638 | len = skb->len; |
| 638 | spin_lock_irq(&bp->lock); | 639 | spin_lock_irqsave(&bp->lock, flags); |
| 639 | 640 | ||
| 640 | /* This is a hard error, log it. */ | 641 | /* This is a hard error, log it. */ |
| 641 | if (TX_BUFFS_AVAIL(bp) < 1) { | 642 | if (TX_BUFFS_AVAIL(bp) < 1) { |
| 642 | netif_stop_queue(dev); | 643 | netif_stop_queue(dev); |
| 643 | spin_unlock_irq(&bp->lock); | 644 | spin_unlock_irqrestore(&bp->lock, flags); |
| 644 | dev_err(&bp->pdev->dev, | 645 | dev_err(&bp->pdev->dev, |
| 645 | "BUG! Tx Ring full when queue awake!\n"); | 646 | "BUG! Tx Ring full when queue awake!\n"); |
| 646 | dev_dbg(&bp->pdev->dev, "tx_head = %u, tx_tail = %u\n", | 647 | dev_dbg(&bp->pdev->dev, "tx_head = %u, tx_tail = %u\n", |
| @@ -674,7 +675,7 @@ static int macb_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 674 | if (TX_BUFFS_AVAIL(bp) < 1) | 675 | if (TX_BUFFS_AVAIL(bp) < 1) |
| 675 | netif_stop_queue(dev); | 676 | netif_stop_queue(dev); |
| 676 | 677 | ||
| 677 | spin_unlock_irq(&bp->lock); | 678 | spin_unlock_irqrestore(&bp->lock, flags); |
| 678 | 679 | ||
| 679 | dev->trans_start = jiffies; | 680 | dev->trans_start = jiffies; |
| 680 | 681 | ||
diff --git a/drivers/net/macsonic.c b/drivers/net/macsonic.c index acd143da161d..61eabcac734c 100644 --- a/drivers/net/macsonic.c +++ b/drivers/net/macsonic.c | |||
| @@ -179,7 +179,7 @@ static const struct net_device_ops macsonic_netdev_ops = { | |||
| 179 | .ndo_set_mac_address = eth_mac_addr, | 179 | .ndo_set_mac_address = eth_mac_addr, |
| 180 | }; | 180 | }; |
| 181 | 181 | ||
| 182 | static int __init macsonic_init(struct net_device *dev) | 182 | static int __devinit macsonic_init(struct net_device *dev) |
| 183 | { | 183 | { |
| 184 | struct sonic_local* lp = netdev_priv(dev); | 184 | struct sonic_local* lp = netdev_priv(dev); |
| 185 | 185 | ||
| @@ -223,7 +223,7 @@ static int __init macsonic_init(struct net_device *dev) | |||
| 223 | return 0; | 223 | return 0; |
| 224 | } | 224 | } |
| 225 | 225 | ||
| 226 | static int __init mac_onboard_sonic_ethernet_addr(struct net_device *dev) | 226 | static int __devinit mac_onboard_sonic_ethernet_addr(struct net_device *dev) |
| 227 | { | 227 | { |
| 228 | struct sonic_local *lp = netdev_priv(dev); | 228 | struct sonic_local *lp = netdev_priv(dev); |
| 229 | const int prom_addr = ONBOARD_SONIC_PROM_BASE; | 229 | const int prom_addr = ONBOARD_SONIC_PROM_BASE; |
| @@ -288,7 +288,7 @@ static int __init mac_onboard_sonic_ethernet_addr(struct net_device *dev) | |||
| 288 | } else return 0; | 288 | } else return 0; |
| 289 | } | 289 | } |
| 290 | 290 | ||
| 291 | static int __init mac_onboard_sonic_probe(struct net_device *dev) | 291 | static int __devinit mac_onboard_sonic_probe(struct net_device *dev) |
| 292 | { | 292 | { |
| 293 | /* Bwahahaha */ | 293 | /* Bwahahaha */ |
| 294 | static int once_is_more_than_enough; | 294 | static int once_is_more_than_enough; |
| @@ -409,7 +409,7 @@ static int __init mac_onboard_sonic_probe(struct net_device *dev) | |||
| 409 | return macsonic_init(dev); | 409 | return macsonic_init(dev); |
| 410 | } | 410 | } |
| 411 | 411 | ||
| 412 | static int __init mac_nubus_sonic_ethernet_addr(struct net_device *dev, | 412 | static int __devinit mac_nubus_sonic_ethernet_addr(struct net_device *dev, |
| 413 | unsigned long prom_addr, | 413 | unsigned long prom_addr, |
| 414 | int id) | 414 | int id) |
| 415 | { | 415 | { |
| @@ -424,7 +424,7 @@ static int __init mac_nubus_sonic_ethernet_addr(struct net_device *dev, | |||
| 424 | return 0; | 424 | return 0; |
| 425 | } | 425 | } |
| 426 | 426 | ||
| 427 | static int __init macsonic_ident(struct nubus_dev *ndev) | 427 | static int __devinit macsonic_ident(struct nubus_dev *ndev) |
| 428 | { | 428 | { |
| 429 | if (ndev->dr_hw == NUBUS_DRHW_ASANTE_LC && | 429 | if (ndev->dr_hw == NUBUS_DRHW_ASANTE_LC && |
| 430 | ndev->dr_sw == NUBUS_DRSW_SONIC_LC) | 430 | ndev->dr_sw == NUBUS_DRSW_SONIC_LC) |
| @@ -449,7 +449,7 @@ static int __init macsonic_ident(struct nubus_dev *ndev) | |||
| 449 | return -1; | 449 | return -1; |
| 450 | } | 450 | } |
| 451 | 451 | ||
| 452 | static int __init mac_nubus_sonic_probe(struct net_device *dev) | 452 | static int __devinit mac_nubus_sonic_probe(struct net_device *dev) |
| 453 | { | 453 | { |
| 454 | static int slots; | 454 | static int slots; |
| 455 | struct nubus_dev* ndev = NULL; | 455 | struct nubus_dev* ndev = NULL; |
| @@ -562,7 +562,7 @@ static int __init mac_nubus_sonic_probe(struct net_device *dev) | |||
| 562 | return macsonic_init(dev); | 562 | return macsonic_init(dev); |
| 563 | } | 563 | } |
| 564 | 564 | ||
| 565 | static int __init mac_sonic_probe(struct platform_device *pdev) | 565 | static int __devinit mac_sonic_probe(struct platform_device *pdev) |
| 566 | { | 566 | { |
| 567 | struct net_device *dev; | 567 | struct net_device *dev; |
| 568 | struct sonic_local *lp; | 568 | struct sonic_local *lp; |
| @@ -575,6 +575,7 @@ static int __init mac_sonic_probe(struct platform_device *pdev) | |||
| 575 | lp = netdev_priv(dev); | 575 | lp = netdev_priv(dev); |
| 576 | lp->device = &pdev->dev; | 576 | lp->device = &pdev->dev; |
| 577 | SET_NETDEV_DEV(dev, &pdev->dev); | 577 | SET_NETDEV_DEV(dev, &pdev->dev); |
| 578 | platform_set_drvdata(pdev, dev); | ||
| 578 | 579 | ||
| 579 | /* This will catch fatal stuff like -ENOMEM as well as success */ | 580 | /* This will catch fatal stuff like -ENOMEM as well as success */ |
| 580 | err = mac_onboard_sonic_probe(dev); | 581 | err = mac_onboard_sonic_probe(dev); |
diff --git a/drivers/net/mlx4/en_ethtool.c b/drivers/net/mlx4/en_ethtool.c index 091f99052c91..86467b444ac6 100644 --- a/drivers/net/mlx4/en_ethtool.c +++ b/drivers/net/mlx4/en_ethtool.c | |||
| @@ -220,7 +220,7 @@ static int mlx4_en_get_settings(struct net_device *dev, struct ethtool_cmd *cmd) | |||
| 220 | { | 220 | { |
| 221 | cmd->autoneg = AUTONEG_DISABLE; | 221 | cmd->autoneg = AUTONEG_DISABLE; |
| 222 | cmd->supported = SUPPORTED_10000baseT_Full; | 222 | cmd->supported = SUPPORTED_10000baseT_Full; |
| 223 | cmd->advertising = SUPPORTED_10000baseT_Full; | 223 | cmd->advertising = ADVERTISED_1000baseT_Full; |
| 224 | if (netif_carrier_ok(dev)) { | 224 | if (netif_carrier_ok(dev)) { |
| 225 | cmd->speed = SPEED_10000; | 225 | cmd->speed = SPEED_10000; |
| 226 | cmd->duplex = DUPLEX_FULL; | 226 | cmd->duplex = DUPLEX_FULL; |
diff --git a/drivers/net/mlx4/en_rx.c b/drivers/net/mlx4/en_rx.c index 91bdfdfd431f..3ac0404d0d11 100644 --- a/drivers/net/mlx4/en_rx.c +++ b/drivers/net/mlx4/en_rx.c | |||
| @@ -506,8 +506,9 @@ static int mlx4_en_complete_rx_desc(struct mlx4_en_priv *priv, | |||
| 506 | PCI_DMA_FROMDEVICE); | 506 | PCI_DMA_FROMDEVICE); |
| 507 | } | 507 | } |
| 508 | /* Adjust size of last fragment to match actual length */ | 508 | /* Adjust size of last fragment to match actual length */ |
| 509 | skb_frags_rx[nr - 1].size = length - | 509 | if (nr > 0) |
| 510 | priv->frag_info[nr - 1].frag_prefix_size; | 510 | skb_frags_rx[nr - 1].size = length - |
| 511 | priv->frag_info[nr - 1].frag_prefix_size; | ||
| 511 | return nr; | 512 | return nr; |
| 512 | 513 | ||
| 513 | fail: | 514 | fail: |
diff --git a/drivers/net/mlx4/en_tx.c b/drivers/net/mlx4/en_tx.c index 08c43f2ae72b..62208401c4df 100644 --- a/drivers/net/mlx4/en_tx.c +++ b/drivers/net/mlx4/en_tx.c | |||
| @@ -249,6 +249,7 @@ static u32 mlx4_en_free_tx_desc(struct mlx4_en_priv *priv, | |||
| 249 | pci_unmap_page(mdev->pdev, | 249 | pci_unmap_page(mdev->pdev, |
| 250 | (dma_addr_t) be64_to_cpu(data->addr), | 250 | (dma_addr_t) be64_to_cpu(data->addr), |
| 251 | frag->size, PCI_DMA_TODEVICE); | 251 | frag->size, PCI_DMA_TODEVICE); |
| 252 | ++data; | ||
| 252 | } | 253 | } |
| 253 | } | 254 | } |
| 254 | /* Stamp the freed descriptor */ | 255 | /* Stamp the freed descriptor */ |
| @@ -436,6 +437,7 @@ static inline void mlx4_en_xmit_poll(struct mlx4_en_priv *priv, int tx_ind) | |||
| 436 | { | 437 | { |
| 437 | struct mlx4_en_cq *cq = &priv->tx_cq[tx_ind]; | 438 | struct mlx4_en_cq *cq = &priv->tx_cq[tx_ind]; |
| 438 | struct mlx4_en_tx_ring *ring = &priv->tx_ring[tx_ind]; | 439 | struct mlx4_en_tx_ring *ring = &priv->tx_ring[tx_ind]; |
| 440 | unsigned long flags; | ||
| 439 | 441 | ||
| 440 | /* If we don't have a pending timer, set one up to catch our recent | 442 | /* If we don't have a pending timer, set one up to catch our recent |
| 441 | post in case the interface becomes idle */ | 443 | post in case the interface becomes idle */ |
| @@ -444,9 +446,9 @@ static inline void mlx4_en_xmit_poll(struct mlx4_en_priv *priv, int tx_ind) | |||
| 444 | 446 | ||
| 445 | /* Poll the CQ every mlx4_en_TX_MODER_POLL packets */ | 447 | /* Poll the CQ every mlx4_en_TX_MODER_POLL packets */ |
| 446 | if ((++ring->poll_cnt & (MLX4_EN_TX_POLL_MODER - 1)) == 0) | 448 | if ((++ring->poll_cnt & (MLX4_EN_TX_POLL_MODER - 1)) == 0) |
| 447 | if (spin_trylock_irq(&ring->comp_lock)) { | 449 | if (spin_trylock_irqsave(&ring->comp_lock, flags)) { |
| 448 | mlx4_en_process_tx_cq(priv->dev, cq); | 450 | mlx4_en_process_tx_cq(priv->dev, cq); |
| 449 | spin_unlock_irq(&ring->comp_lock); | 451 | spin_unlock_irqrestore(&ring->comp_lock, flags); |
| 450 | } | 452 | } |
| 451 | } | 453 | } |
| 452 | 454 | ||
diff --git a/drivers/net/netxen/netxen_nic.h b/drivers/net/netxen/netxen_nic.h index e1cdba752e09..a9c1fcca5e75 100644 --- a/drivers/net/netxen/netxen_nic.h +++ b/drivers/net/netxen/netxen_nic.h | |||
| @@ -210,6 +210,7 @@ | |||
| 210 | #define NETXEN_CTX_SIGNATURE 0xdee0 | 210 | #define NETXEN_CTX_SIGNATURE 0xdee0 |
| 211 | #define NETXEN_CTX_SIGNATURE_V2 0x0002dee0 | 211 | #define NETXEN_CTX_SIGNATURE_V2 0x0002dee0 |
| 212 | #define NETXEN_CTX_RESET 0xbad0 | 212 | #define NETXEN_CTX_RESET 0xbad0 |
| 213 | #define NETXEN_CTX_D3_RESET 0xacc0 | ||
| 213 | #define NETXEN_RCV_PRODUCER(ringid) (ringid) | 214 | #define NETXEN_RCV_PRODUCER(ringid) (ringid) |
| 214 | 215 | ||
| 215 | #define PHAN_PEG_RCV_INITIALIZED 0xff01 | 216 | #define PHAN_PEG_RCV_INITIALIZED 0xff01 |
| @@ -773,6 +774,8 @@ struct nx_host_tx_ring { | |||
| 773 | u32 crb_cmd_consumer; | 774 | u32 crb_cmd_consumer; |
| 774 | u32 num_desc; | 775 | u32 num_desc; |
| 775 | 776 | ||
| 777 | struct netdev_queue *txq; | ||
| 778 | |||
| 776 | struct netxen_cmd_buffer *cmd_buf_arr; | 779 | struct netxen_cmd_buffer *cmd_buf_arr; |
| 777 | struct cmd_desc_type0 *desc_head; | 780 | struct cmd_desc_type0 *desc_head; |
| 778 | dma_addr_t phys_addr; | 781 | dma_addr_t phys_addr; |
| @@ -1251,7 +1254,7 @@ struct netxen_adapter { | |||
| 1251 | u8 mc_enabled; | 1254 | u8 mc_enabled; |
| 1252 | u8 max_mc_count; | 1255 | u8 max_mc_count; |
| 1253 | u8 rss_supported; | 1256 | u8 rss_supported; |
| 1254 | u8 resv2; | 1257 | u8 link_changed; |
| 1255 | u32 resv3; | 1258 | u32 resv3; |
| 1256 | 1259 | ||
| 1257 | u8 has_link_events; | 1260 | u8 has_link_events; |
diff --git a/drivers/net/netxen/netxen_nic_ctx.c b/drivers/net/netxen/netxen_nic_ctx.c index 4754f5cffad0..9f8ae4719e2f 100644 --- a/drivers/net/netxen/netxen_nic_ctx.c +++ b/drivers/net/netxen/netxen_nic_ctx.c | |||
| @@ -684,10 +684,8 @@ int netxen_alloc_hw_resources(struct netxen_adapter *adapter) | |||
| 684 | goto err_out_free; | 684 | goto err_out_free; |
| 685 | } else { | 685 | } else { |
| 686 | err = netxen_init_old_ctx(adapter); | 686 | err = netxen_init_old_ctx(adapter); |
| 687 | if (err) { | 687 | if (err) |
| 688 | netxen_free_hw_resources(adapter); | 688 | goto err_out_free; |
| 689 | return err; | ||
| 690 | } | ||
| 691 | } | 689 | } |
| 692 | 690 | ||
| 693 | return 0; | 691 | return 0; |
| @@ -708,15 +706,18 @@ void netxen_free_hw_resources(struct netxen_adapter *adapter) | |||
| 708 | int port = adapter->portnum; | 706 | int port = adapter->portnum; |
| 709 | 707 | ||
| 710 | if (adapter->fw_major >= 4) { | 708 | if (adapter->fw_major >= 4) { |
| 711 | nx_fw_cmd_destroy_tx_ctx(adapter); | ||
| 712 | nx_fw_cmd_destroy_rx_ctx(adapter); | 709 | nx_fw_cmd_destroy_rx_ctx(adapter); |
| 710 | nx_fw_cmd_destroy_tx_ctx(adapter); | ||
| 713 | } else { | 711 | } else { |
| 714 | netxen_api_lock(adapter); | 712 | netxen_api_lock(adapter); |
| 715 | NXWR32(adapter, CRB_CTX_SIGNATURE_REG(port), | 713 | NXWR32(adapter, CRB_CTX_SIGNATURE_REG(port), |
| 716 | NETXEN_CTX_RESET | port); | 714 | NETXEN_CTX_D3_RESET | port); |
| 717 | netxen_api_unlock(adapter); | 715 | netxen_api_unlock(adapter); |
| 718 | } | 716 | } |
| 719 | 717 | ||
| 718 | /* Allow dma queues to drain after context reset */ | ||
| 719 | msleep(20); | ||
| 720 | |||
| 720 | recv_ctx = &adapter->recv_ctx; | 721 | recv_ctx = &adapter->recv_ctx; |
| 721 | 722 | ||
| 722 | if (recv_ctx->hwctx != NULL) { | 723 | if (recv_ctx->hwctx != NULL) { |
diff --git a/drivers/net/netxen/netxen_nic_hw.c b/drivers/net/netxen/netxen_nic_hw.c index ce3b89d2cbb6..b9123d445c96 100644 --- a/drivers/net/netxen/netxen_nic_hw.c +++ b/drivers/net/netxen/netxen_nic_hw.c | |||
| @@ -461,13 +461,14 @@ netxen_send_cmd_descs(struct netxen_adapter *adapter, | |||
| 461 | i = 0; | 461 | i = 0; |
| 462 | 462 | ||
| 463 | tx_ring = adapter->tx_ring; | 463 | tx_ring = adapter->tx_ring; |
| 464 | netif_tx_lock_bh(adapter->netdev); | 464 | __netif_tx_lock_bh(tx_ring->txq); |
| 465 | 465 | ||
| 466 | producer = tx_ring->producer; | 466 | producer = tx_ring->producer; |
| 467 | consumer = tx_ring->sw_consumer; | 467 | consumer = tx_ring->sw_consumer; |
| 468 | 468 | ||
| 469 | if (nr_desc >= find_diff_among(producer, consumer, tx_ring->num_desc)) { | 469 | if (nr_desc >= netxen_tx_avail(tx_ring)) { |
| 470 | netif_tx_unlock_bh(adapter->netdev); | 470 | netif_tx_stop_queue(tx_ring->txq); |
| 471 | __netif_tx_unlock_bh(tx_ring->txq); | ||
| 471 | return -EBUSY; | 472 | return -EBUSY; |
| 472 | } | 473 | } |
| 473 | 474 | ||
| @@ -490,7 +491,7 @@ netxen_send_cmd_descs(struct netxen_adapter *adapter, | |||
| 490 | 491 | ||
| 491 | netxen_nic_update_cmd_producer(adapter, tx_ring); | 492 | netxen_nic_update_cmd_producer(adapter, tx_ring); |
| 492 | 493 | ||
| 493 | netif_tx_unlock_bh(adapter->netdev); | 494 | __netif_tx_unlock_bh(tx_ring->txq); |
| 494 | 495 | ||
| 495 | return 0; | 496 | return 0; |
| 496 | } | 497 | } |
diff --git a/drivers/net/netxen/netxen_nic_init.c b/drivers/net/netxen/netxen_nic_init.c index b899bd51fcd8..5d3343ef3d86 100644 --- a/drivers/net/netxen/netxen_nic_init.c +++ b/drivers/net/netxen/netxen_nic_init.c | |||
| @@ -214,6 +214,7 @@ int netxen_alloc_sw_resources(struct netxen_adapter *adapter) | |||
| 214 | adapter->tx_ring = tx_ring; | 214 | adapter->tx_ring = tx_ring; |
| 215 | 215 | ||
| 216 | tx_ring->num_desc = adapter->num_txd; | 216 | tx_ring->num_desc = adapter->num_txd; |
| 217 | tx_ring->txq = netdev_get_tx_queue(netdev, 0); | ||
| 217 | 218 | ||
| 218 | cmd_buf_arr = vmalloc(TX_BUFF_RINGSIZE(tx_ring)); | 219 | cmd_buf_arr = vmalloc(TX_BUFF_RINGSIZE(tx_ring)); |
| 219 | if (cmd_buf_arr == NULL) { | 220 | if (cmd_buf_arr == NULL) { |
| @@ -1400,10 +1401,10 @@ int netxen_process_cmd_ring(struct netxen_adapter *adapter) | |||
| 1400 | smp_mb(); | 1401 | smp_mb(); |
| 1401 | 1402 | ||
| 1402 | if (netif_queue_stopped(netdev) && netif_carrier_ok(netdev)) { | 1403 | if (netif_queue_stopped(netdev) && netif_carrier_ok(netdev)) { |
| 1403 | netif_tx_lock(netdev); | 1404 | __netif_tx_lock(tx_ring->txq, smp_processor_id()); |
| 1404 | if (netxen_tx_avail(tx_ring) > TX_STOP_THRESH) | 1405 | if (netxen_tx_avail(tx_ring) > TX_STOP_THRESH) |
| 1405 | netif_wake_queue(netdev); | 1406 | netif_wake_queue(netdev); |
| 1406 | netif_tx_unlock(netdev); | 1407 | __netif_tx_unlock(tx_ring->txq); |
| 1407 | } | 1408 | } |
| 1408 | } | 1409 | } |
| 1409 | /* | 1410 | /* |
diff --git a/drivers/net/netxen/netxen_nic_main.c b/drivers/net/netxen/netxen_nic_main.c index 27539ddf94c4..28f270f5ac78 100644 --- a/drivers/net/netxen/netxen_nic_main.c +++ b/drivers/net/netxen/netxen_nic_main.c | |||
| @@ -94,10 +94,6 @@ static struct pci_device_id netxen_pci_tbl[] __devinitdata = { | |||
| 94 | 94 | ||
| 95 | MODULE_DEVICE_TABLE(pci, netxen_pci_tbl); | 95 | MODULE_DEVICE_TABLE(pci, netxen_pci_tbl); |
| 96 | 96 | ||
| 97 | static struct workqueue_struct *netxen_workq; | ||
| 98 | #define SCHEDULE_WORK(tp) queue_work(netxen_workq, tp) | ||
| 99 | #define FLUSH_SCHEDULED_WORK() flush_workqueue(netxen_workq) | ||
| 100 | |||
| 101 | static void netxen_watchdog(unsigned long); | 97 | static void netxen_watchdog(unsigned long); |
| 102 | 98 | ||
| 103 | static uint32_t crb_cmd_producer[4] = { | 99 | static uint32_t crb_cmd_producer[4] = { |
| @@ -171,6 +167,8 @@ netxen_free_sds_rings(struct netxen_recv_context *recv_ctx) | |||
| 171 | { | 167 | { |
| 172 | if (recv_ctx->sds_rings != NULL) | 168 | if (recv_ctx->sds_rings != NULL) |
| 173 | kfree(recv_ctx->sds_rings); | 169 | kfree(recv_ctx->sds_rings); |
| 170 | |||
| 171 | recv_ctx->sds_rings = NULL; | ||
| 174 | } | 172 | } |
| 175 | 173 | ||
| 176 | static int | 174 | static int |
| @@ -193,6 +191,21 @@ netxen_napi_add(struct netxen_adapter *adapter, struct net_device *netdev) | |||
| 193 | } | 191 | } |
| 194 | 192 | ||
| 195 | static void | 193 | static void |
| 194 | netxen_napi_del(struct netxen_adapter *adapter) | ||
| 195 | { | ||
| 196 | int ring; | ||
| 197 | struct nx_host_sds_ring *sds_ring; | ||
| 198 | struct netxen_recv_context *recv_ctx = &adapter->recv_ctx; | ||
| 199 | |||
| 200 | for (ring = 0; ring < adapter->max_sds_rings; ring++) { | ||
| 201 | sds_ring = &recv_ctx->sds_rings[ring]; | ||
| 202 | netif_napi_del(&sds_ring->napi); | ||
| 203 | } | ||
| 204 | |||
| 205 | netxen_free_sds_rings(&adapter->recv_ctx); | ||
| 206 | } | ||
| 207 | |||
| 208 | static void | ||
| 196 | netxen_napi_enable(struct netxen_adapter *adapter) | 209 | netxen_napi_enable(struct netxen_adapter *adapter) |
| 197 | { | 210 | { |
| 198 | int ring; | 211 | int ring; |
| @@ -215,13 +228,13 @@ netxen_napi_disable(struct netxen_adapter *adapter) | |||
| 215 | 228 | ||
| 216 | for (ring = 0; ring < adapter->max_sds_rings; ring++) { | 229 | for (ring = 0; ring < adapter->max_sds_rings; ring++) { |
| 217 | sds_ring = &recv_ctx->sds_rings[ring]; | 230 | sds_ring = &recv_ctx->sds_rings[ring]; |
| 218 | napi_disable(&sds_ring->napi); | ||
| 219 | netxen_nic_disable_int(sds_ring); | 231 | netxen_nic_disable_int(sds_ring); |
| 220 | synchronize_irq(sds_ring->irq); | 232 | napi_synchronize(&sds_ring->napi); |
| 233 | napi_disable(&sds_ring->napi); | ||
| 221 | } | 234 | } |
| 222 | } | 235 | } |
| 223 | 236 | ||
| 224 | static int nx_set_dma_mask(struct netxen_adapter *adapter, uint8_t revision_id) | 237 | static int nx_set_dma_mask(struct netxen_adapter *adapter) |
| 225 | { | 238 | { |
| 226 | struct pci_dev *pdev = adapter->pdev; | 239 | struct pci_dev *pdev = adapter->pdev; |
| 227 | uint64_t mask, cmask; | 240 | uint64_t mask, cmask; |
| @@ -229,19 +242,17 @@ static int nx_set_dma_mask(struct netxen_adapter *adapter, uint8_t revision_id) | |||
| 229 | adapter->pci_using_dac = 0; | 242 | adapter->pci_using_dac = 0; |
| 230 | 243 | ||
| 231 | mask = DMA_BIT_MASK(32); | 244 | mask = DMA_BIT_MASK(32); |
| 232 | /* | ||
| 233 | * Consistent DMA mask is set to 32 bit because it cannot be set to | ||
| 234 | * 35 bits. For P3 also leave it at 32 bits for now. Only the rings | ||
| 235 | * come off this pool. | ||
| 236 | */ | ||
| 237 | cmask = DMA_BIT_MASK(32); | 245 | cmask = DMA_BIT_MASK(32); |
| 238 | 246 | ||
| 247 | if (NX_IS_REVISION_P2(adapter->ahw.revision_id)) { | ||
| 239 | #ifndef CONFIG_IA64 | 248 | #ifndef CONFIG_IA64 |
| 240 | if (revision_id >= NX_P3_B0) | ||
| 241 | mask = DMA_BIT_MASK(39); | ||
| 242 | else if (revision_id == NX_P2_C1) | ||
| 243 | mask = DMA_BIT_MASK(35); | 249 | mask = DMA_BIT_MASK(35); |
| 244 | #endif | 250 | #endif |
| 251 | } else { | ||
| 252 | mask = DMA_BIT_MASK(39); | ||
| 253 | cmask = mask; | ||
| 254 | } | ||
| 255 | |||
| 245 | if (pci_set_dma_mask(pdev, mask) == 0 && | 256 | if (pci_set_dma_mask(pdev, mask) == 0 && |
| 246 | pci_set_consistent_dma_mask(pdev, cmask) == 0) { | 257 | pci_set_consistent_dma_mask(pdev, cmask) == 0) { |
| 247 | adapter->pci_using_dac = 1; | 258 | adapter->pci_using_dac = 1; |
| @@ -256,13 +267,13 @@ static int | |||
| 256 | nx_update_dma_mask(struct netxen_adapter *adapter) | 267 | nx_update_dma_mask(struct netxen_adapter *adapter) |
| 257 | { | 268 | { |
| 258 | int change, shift, err; | 269 | int change, shift, err; |
| 259 | uint64_t mask, old_mask; | 270 | uint64_t mask, old_mask, old_cmask; |
| 260 | struct pci_dev *pdev = adapter->pdev; | 271 | struct pci_dev *pdev = adapter->pdev; |
| 261 | 272 | ||
| 262 | change = 0; | 273 | change = 0; |
| 263 | 274 | ||
| 264 | shift = NXRD32(adapter, CRB_DMA_SHIFT); | 275 | shift = NXRD32(adapter, CRB_DMA_SHIFT); |
| 265 | if (shift >= 32) | 276 | if (shift > 32) |
| 266 | return 0; | 277 | return 0; |
| 267 | 278 | ||
| 268 | if (NX_IS_REVISION_P3(adapter->ahw.revision_id) && (shift > 9)) | 279 | if (NX_IS_REVISION_P3(adapter->ahw.revision_id) && (shift > 9)) |
| @@ -272,14 +283,29 @@ nx_update_dma_mask(struct netxen_adapter *adapter) | |||
| 272 | 283 | ||
| 273 | if (change) { | 284 | if (change) { |
| 274 | old_mask = pdev->dma_mask; | 285 | old_mask = pdev->dma_mask; |
| 275 | mask = (1ULL<<(32+shift)) - 1; | 286 | old_cmask = pdev->dev.coherent_dma_mask; |
| 287 | |||
| 288 | mask = DMA_BIT_MASK(32+shift); | ||
| 276 | 289 | ||
| 277 | err = pci_set_dma_mask(pdev, mask); | 290 | err = pci_set_dma_mask(pdev, mask); |
| 278 | if (err) | 291 | if (err) |
| 279 | return pci_set_dma_mask(pdev, old_mask); | 292 | goto err_out; |
| 293 | |||
| 294 | if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) { | ||
| 295 | |||
| 296 | err = pci_set_consistent_dma_mask(pdev, mask); | ||
| 297 | if (err) | ||
| 298 | goto err_out; | ||
| 299 | } | ||
| 300 | dev_info(&pdev->dev, "using %d-bit dma mask\n", 32+shift); | ||
| 280 | } | 301 | } |
| 281 | 302 | ||
| 282 | return 0; | 303 | return 0; |
| 304 | |||
| 305 | err_out: | ||
| 306 | pci_set_dma_mask(pdev, old_mask); | ||
| 307 | pci_set_consistent_dma_mask(pdev, old_cmask); | ||
| 308 | return err; | ||
| 283 | } | 309 | } |
| 284 | 310 | ||
| 285 | static void netxen_check_options(struct netxen_adapter *adapter) | 311 | static void netxen_check_options(struct netxen_adapter *adapter) |
| @@ -833,11 +859,11 @@ netxen_nic_up(struct netxen_adapter *adapter, struct net_device *netdev) | |||
| 833 | 859 | ||
| 834 | adapter->ahw.linkup = 0; | 860 | adapter->ahw.linkup = 0; |
| 835 | 861 | ||
| 836 | netxen_napi_enable(adapter); | ||
| 837 | |||
| 838 | if (adapter->max_sds_rings > 1) | 862 | if (adapter->max_sds_rings > 1) |
| 839 | netxen_config_rss(adapter, 1); | 863 | netxen_config_rss(adapter, 1); |
| 840 | 864 | ||
| 865 | netxen_napi_enable(adapter); | ||
| 866 | |||
| 841 | if (adapter->capabilities & NX_FW_CAPABILITY_LINK_NOTIFICATION) | 867 | if (adapter->capabilities & NX_FW_CAPABILITY_LINK_NOTIFICATION) |
| 842 | netxen_linkevent_request(adapter, 1); | 868 | netxen_linkevent_request(adapter, 1); |
| 843 | else | 869 | else |
| @@ -851,8 +877,9 @@ netxen_nic_up(struct netxen_adapter *adapter, struct net_device *netdev) | |||
| 851 | static void | 877 | static void |
| 852 | netxen_nic_down(struct netxen_adapter *adapter, struct net_device *netdev) | 878 | netxen_nic_down(struct netxen_adapter *adapter, struct net_device *netdev) |
| 853 | { | 879 | { |
| 880 | spin_lock(&adapter->tx_clean_lock); | ||
| 854 | netif_carrier_off(netdev); | 881 | netif_carrier_off(netdev); |
| 855 | netif_stop_queue(netdev); | 882 | netif_tx_disable(netdev); |
| 856 | 883 | ||
| 857 | if (adapter->stop_port) | 884 | if (adapter->stop_port) |
| 858 | adapter->stop_port(adapter); | 885 | adapter->stop_port(adapter); |
| @@ -863,8 +890,8 @@ netxen_nic_down(struct netxen_adapter *adapter, struct net_device *netdev) | |||
| 863 | netxen_napi_disable(adapter); | 890 | netxen_napi_disable(adapter); |
| 864 | 891 | ||
| 865 | netxen_release_tx_buffers(adapter); | 892 | netxen_release_tx_buffers(adapter); |
| 893 | spin_unlock(&adapter->tx_clean_lock); | ||
| 866 | 894 | ||
| 867 | FLUSH_SCHEDULED_WORK(); | ||
| 868 | del_timer_sync(&adapter->watchdog_timer); | 895 | del_timer_sync(&adapter->watchdog_timer); |
| 869 | } | 896 | } |
| 870 | 897 | ||
| @@ -879,10 +906,12 @@ netxen_nic_attach(struct netxen_adapter *adapter) | |||
| 879 | struct nx_host_tx_ring *tx_ring; | 906 | struct nx_host_tx_ring *tx_ring; |
| 880 | 907 | ||
| 881 | err = netxen_init_firmware(adapter); | 908 | err = netxen_init_firmware(adapter); |
| 882 | if (err != 0) { | 909 | if (err) |
| 883 | printk(KERN_ERR "Failed to init firmware\n"); | 910 | return err; |
| 884 | return -EIO; | 911 | |
| 885 | } | 912 | err = netxen_napi_add(adapter, netdev); |
| 913 | if (err) | ||
| 914 | return err; | ||
| 886 | 915 | ||
| 887 | if (adapter->fw_major < 4) | 916 | if (adapter->fw_major < 4) |
| 888 | adapter->max_rds_rings = 3; | 917 | adapter->max_rds_rings = 3; |
| @@ -943,9 +972,10 @@ err_out_free_sw: | |||
| 943 | static void | 972 | static void |
| 944 | netxen_nic_detach(struct netxen_adapter *adapter) | 973 | netxen_nic_detach(struct netxen_adapter *adapter) |
| 945 | { | 974 | { |
| 946 | netxen_release_rx_buffers(adapter); | ||
| 947 | netxen_free_hw_resources(adapter); | 975 | netxen_free_hw_resources(adapter); |
| 976 | netxen_release_rx_buffers(adapter); | ||
| 948 | netxen_nic_free_irq(adapter); | 977 | netxen_nic_free_irq(adapter); |
| 978 | netxen_napi_del(adapter); | ||
| 949 | netxen_free_sw_resources(adapter); | 979 | netxen_free_sw_resources(adapter); |
| 950 | 980 | ||
| 951 | adapter->is_up = 0; | 981 | adapter->is_up = 0; |
| @@ -1004,7 +1034,7 @@ netxen_nic_probe(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 1004 | revision_id = pdev->revision; | 1034 | revision_id = pdev->revision; |
| 1005 | adapter->ahw.revision_id = revision_id; | 1035 | adapter->ahw.revision_id = revision_id; |
| 1006 | 1036 | ||
| 1007 | err = nx_set_dma_mask(adapter, revision_id); | 1037 | err = nx_set_dma_mask(adapter); |
| 1008 | if (err) | 1038 | if (err) |
| 1009 | goto err_out_free_netdev; | 1039 | goto err_out_free_netdev; |
| 1010 | 1040 | ||
| @@ -1090,9 +1120,6 @@ netxen_nic_probe(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 1090 | 1120 | ||
| 1091 | netdev->irq = adapter->msix_entries[0].vector; | 1121 | netdev->irq = adapter->msix_entries[0].vector; |
| 1092 | 1122 | ||
| 1093 | if (netxen_napi_add(adapter, netdev)) | ||
| 1094 | goto err_out_disable_msi; | ||
| 1095 | |||
| 1096 | init_timer(&adapter->watchdog_timer); | 1123 | init_timer(&adapter->watchdog_timer); |
| 1097 | adapter->watchdog_timer.function = &netxen_watchdog; | 1124 | adapter->watchdog_timer.function = &netxen_watchdog; |
| 1098 | adapter->watchdog_timer.data = (unsigned long)adapter; | 1125 | adapter->watchdog_timer.data = (unsigned long)adapter; |
| @@ -1162,6 +1189,9 @@ static void __devexit netxen_nic_remove(struct pci_dev *pdev) | |||
| 1162 | 1189 | ||
| 1163 | unregister_netdev(netdev); | 1190 | unregister_netdev(netdev); |
| 1164 | 1191 | ||
| 1192 | cancel_work_sync(&adapter->watchdog_task); | ||
| 1193 | cancel_work_sync(&adapter->tx_timeout_task); | ||
| 1194 | |||
| 1165 | if (adapter->is_up == NETXEN_ADAPTER_UP_MAGIC) { | 1195 | if (adapter->is_up == NETXEN_ADAPTER_UP_MAGIC) { |
| 1166 | netxen_nic_detach(adapter); | 1196 | netxen_nic_detach(adapter); |
| 1167 | } | 1197 | } |
| @@ -1170,7 +1200,6 @@ static void __devexit netxen_nic_remove(struct pci_dev *pdev) | |||
| 1170 | netxen_free_adapter_offload(adapter); | 1200 | netxen_free_adapter_offload(adapter); |
| 1171 | 1201 | ||
| 1172 | netxen_teardown_intr(adapter); | 1202 | netxen_teardown_intr(adapter); |
| 1173 | netxen_free_sds_rings(&adapter->recv_ctx); | ||
| 1174 | 1203 | ||
| 1175 | netxen_cleanup_pci_map(adapter); | 1204 | netxen_cleanup_pci_map(adapter); |
| 1176 | 1205 | ||
| @@ -1196,6 +1225,9 @@ netxen_nic_suspend(struct pci_dev *pdev, pm_message_t state) | |||
| 1196 | if (netif_running(netdev)) | 1225 | if (netif_running(netdev)) |
| 1197 | netxen_nic_down(adapter, netdev); | 1226 | netxen_nic_down(adapter, netdev); |
| 1198 | 1227 | ||
| 1228 | cancel_work_sync(&adapter->watchdog_task); | ||
| 1229 | cancel_work_sync(&adapter->tx_timeout_task); | ||
| 1230 | |||
| 1199 | if (adapter->is_up == NETXEN_ADAPTER_UP_MAGIC) | 1231 | if (adapter->is_up == NETXEN_ADAPTER_UP_MAGIC) |
| 1200 | netxen_nic_detach(adapter); | 1232 | netxen_nic_detach(adapter); |
| 1201 | 1233 | ||
| @@ -1533,10 +1565,7 @@ static int netxen_nic_check_temp(struct netxen_adapter *adapter) | |||
| 1533 | printk(KERN_ALERT | 1565 | printk(KERN_ALERT |
| 1534 | "%s: Device temperature %d degrees C exceeds" | 1566 | "%s: Device temperature %d degrees C exceeds" |
| 1535 | " maximum allowed. Hardware has been shut down.\n", | 1567 | " maximum allowed. Hardware has been shut down.\n", |
| 1536 | netxen_nic_driver_name, temp_val); | 1568 | netdev->name, temp_val); |
| 1537 | |||
| 1538 | netif_carrier_off(netdev); | ||
| 1539 | netif_stop_queue(netdev); | ||
| 1540 | rv = 1; | 1569 | rv = 1; |
| 1541 | } else if (temp_state == NX_TEMP_WARN) { | 1570 | } else if (temp_state == NX_TEMP_WARN) { |
| 1542 | if (adapter->temp == NX_TEMP_NORMAL) { | 1571 | if (adapter->temp == NX_TEMP_NORMAL) { |
| @@ -1544,13 +1573,13 @@ static int netxen_nic_check_temp(struct netxen_adapter *adapter) | |||
| 1544 | "%s: Device temperature %d degrees C " | 1573 | "%s: Device temperature %d degrees C " |
| 1545 | "exceeds operating range." | 1574 | "exceeds operating range." |
| 1546 | " Immediate action needed.\n", | 1575 | " Immediate action needed.\n", |
| 1547 | netxen_nic_driver_name, temp_val); | 1576 | netdev->name, temp_val); |
| 1548 | } | 1577 | } |
| 1549 | } else { | 1578 | } else { |
| 1550 | if (adapter->temp == NX_TEMP_WARN) { | 1579 | if (adapter->temp == NX_TEMP_WARN) { |
| 1551 | printk(KERN_INFO | 1580 | printk(KERN_INFO |
| 1552 | "%s: Device temperature is now %d degrees C" | 1581 | "%s: Device temperature is now %d degrees C" |
| 1553 | " in normal range.\n", netxen_nic_driver_name, | 1582 | " in normal range.\n", netdev->name, |
| 1554 | temp_val); | 1583 | temp_val); |
| 1555 | } | 1584 | } |
| 1556 | } | 1585 | } |
| @@ -1570,10 +1599,7 @@ void netxen_advert_link_change(struct netxen_adapter *adapter, int linkup) | |||
| 1570 | netif_carrier_off(netdev); | 1599 | netif_carrier_off(netdev); |
| 1571 | netif_stop_queue(netdev); | 1600 | netif_stop_queue(netdev); |
| 1572 | } | 1601 | } |
| 1573 | 1602 | adapter->link_changed = !adapter->has_link_events; | |
| 1574 | if (!adapter->has_link_events) | ||
| 1575 | netxen_nic_set_link_parameters(adapter); | ||
| 1576 | |||
| 1577 | } else if (!adapter->ahw.linkup && linkup) { | 1603 | } else if (!adapter->ahw.linkup && linkup) { |
| 1578 | printk(KERN_INFO "%s: %s NIC Link is up\n", | 1604 | printk(KERN_INFO "%s: %s NIC Link is up\n", |
| 1579 | netxen_nic_driver_name, netdev->name); | 1605 | netxen_nic_driver_name, netdev->name); |
| @@ -1582,9 +1608,7 @@ void netxen_advert_link_change(struct netxen_adapter *adapter, int linkup) | |||
| 1582 | netif_carrier_on(netdev); | 1608 | netif_carrier_on(netdev); |
| 1583 | netif_wake_queue(netdev); | 1609 | netif_wake_queue(netdev); |
| 1584 | } | 1610 | } |
| 1585 | 1611 | adapter->link_changed = !adapter->has_link_events; | |
| 1586 | if (!adapter->has_link_events) | ||
| 1587 | netxen_nic_set_link_parameters(adapter); | ||
| 1588 | } | 1612 | } |
| 1589 | } | 1613 | } |
| 1590 | 1614 | ||
| @@ -1611,11 +1635,36 @@ static void netxen_nic_handle_phy_intr(struct netxen_adapter *adapter) | |||
| 1611 | netxen_advert_link_change(adapter, linkup); | 1635 | netxen_advert_link_change(adapter, linkup); |
| 1612 | } | 1636 | } |
| 1613 | 1637 | ||
| 1638 | static void netxen_nic_thermal_shutdown(struct netxen_adapter *adapter) | ||
| 1639 | { | ||
| 1640 | struct net_device *netdev = adapter->netdev; | ||
| 1641 | |||
| 1642 | netif_device_detach(netdev); | ||
| 1643 | netxen_nic_down(adapter, netdev); | ||
| 1644 | netxen_nic_detach(adapter); | ||
| 1645 | } | ||
| 1646 | |||
| 1614 | static void netxen_watchdog(unsigned long v) | 1647 | static void netxen_watchdog(unsigned long v) |
| 1615 | { | 1648 | { |
| 1616 | struct netxen_adapter *adapter = (struct netxen_adapter *)v; | 1649 | struct netxen_adapter *adapter = (struct netxen_adapter *)v; |
| 1617 | 1650 | ||
| 1618 | SCHEDULE_WORK(&adapter->watchdog_task); | 1651 | if (netxen_nic_check_temp(adapter)) |
| 1652 | goto do_sched; | ||
| 1653 | |||
| 1654 | if (!adapter->has_link_events) { | ||
| 1655 | netxen_nic_handle_phy_intr(adapter); | ||
| 1656 | |||
| 1657 | if (adapter->link_changed) | ||
| 1658 | goto do_sched; | ||
| 1659 | } | ||
| 1660 | |||
| 1661 | if (netif_running(adapter->netdev)) | ||
| 1662 | mod_timer(&adapter->watchdog_timer, jiffies + 2 * HZ); | ||
| 1663 | |||
| 1664 | return; | ||
| 1665 | |||
| 1666 | do_sched: | ||
| 1667 | schedule_work(&adapter->watchdog_task); | ||
| 1619 | } | 1668 | } |
| 1620 | 1669 | ||
| 1621 | void netxen_watchdog_task(struct work_struct *work) | 1670 | void netxen_watchdog_task(struct work_struct *work) |
| @@ -1623,11 +1672,13 @@ void netxen_watchdog_task(struct work_struct *work) | |||
| 1623 | struct netxen_adapter *adapter = | 1672 | struct netxen_adapter *adapter = |
| 1624 | container_of(work, struct netxen_adapter, watchdog_task); | 1673 | container_of(work, struct netxen_adapter, watchdog_task); |
| 1625 | 1674 | ||
| 1626 | if ((adapter->portnum == 0) && netxen_nic_check_temp(adapter)) | 1675 | if (adapter->temp == NX_TEMP_PANIC) { |
| 1676 | netxen_nic_thermal_shutdown(adapter); | ||
| 1627 | return; | 1677 | return; |
| 1678 | } | ||
| 1628 | 1679 | ||
| 1629 | if (!adapter->has_link_events) | 1680 | if (adapter->link_changed) |
| 1630 | netxen_nic_handle_phy_intr(adapter); | 1681 | netxen_nic_set_link_parameters(adapter); |
| 1631 | 1682 | ||
| 1632 | if (netif_running(adapter->netdev)) | 1683 | if (netif_running(adapter->netdev)) |
| 1633 | mod_timer(&adapter->watchdog_timer, jiffies + 2 * HZ); | 1684 | mod_timer(&adapter->watchdog_timer, jiffies + 2 * HZ); |
| @@ -1635,9 +1686,8 @@ void netxen_watchdog_task(struct work_struct *work) | |||
| 1635 | 1686 | ||
| 1636 | static void netxen_tx_timeout(struct net_device *netdev) | 1687 | static void netxen_tx_timeout(struct net_device *netdev) |
| 1637 | { | 1688 | { |
| 1638 | struct netxen_adapter *adapter = (struct netxen_adapter *) | 1689 | struct netxen_adapter *adapter = netdev_priv(netdev); |
| 1639 | netdev_priv(netdev); | 1690 | schedule_work(&adapter->tx_timeout_task); |
| 1640 | SCHEDULE_WORK(&adapter->tx_timeout_task); | ||
| 1641 | } | 1691 | } |
| 1642 | 1692 | ||
| 1643 | static void netxen_tx_timeout_task(struct work_struct *work) | 1693 | static void netxen_tx_timeout_task(struct work_struct *work) |
| @@ -1645,6 +1695,9 @@ static void netxen_tx_timeout_task(struct work_struct *work) | |||
| 1645 | struct netxen_adapter *adapter = | 1695 | struct netxen_adapter *adapter = |
| 1646 | container_of(work, struct netxen_adapter, tx_timeout_task); | 1696 | container_of(work, struct netxen_adapter, tx_timeout_task); |
| 1647 | 1697 | ||
| 1698 | if (!netif_running(adapter->netdev)) | ||
| 1699 | return; | ||
| 1700 | |||
| 1648 | printk(KERN_ERR "%s %s: transmit timeout, resetting.\n", | 1701 | printk(KERN_ERR "%s %s: transmit timeout, resetting.\n", |
| 1649 | netxen_nic_driver_name, adapter->netdev->name); | 1702 | netxen_nic_driver_name, adapter->netdev->name); |
| 1650 | 1703 | ||
| @@ -1757,7 +1810,8 @@ static int netxen_nic_poll(struct napi_struct *napi, int budget) | |||
| 1757 | 1810 | ||
| 1758 | if ((work_done < budget) && tx_complete) { | 1811 | if ((work_done < budget) && tx_complete) { |
| 1759 | napi_complete(&sds_ring->napi); | 1812 | napi_complete(&sds_ring->napi); |
| 1760 | netxen_nic_enable_int(sds_ring); | 1813 | if (netif_running(adapter->netdev)) |
| 1814 | netxen_nic_enable_int(sds_ring); | ||
| 1761 | } | 1815 | } |
| 1762 | 1816 | ||
| 1763 | return work_done; | 1817 | return work_done; |
| @@ -1790,9 +1844,6 @@ static int __init netxen_init_module(void) | |||
| 1790 | { | 1844 | { |
| 1791 | printk(KERN_INFO "%s\n", netxen_nic_driver_string); | 1845 | printk(KERN_INFO "%s\n", netxen_nic_driver_string); |
| 1792 | 1846 | ||
| 1793 | if ((netxen_workq = create_singlethread_workqueue("netxen")) == NULL) | ||
| 1794 | return -ENOMEM; | ||
| 1795 | |||
| 1796 | return pci_register_driver(&netxen_driver); | 1847 | return pci_register_driver(&netxen_driver); |
| 1797 | } | 1848 | } |
| 1798 | 1849 | ||
| @@ -1801,7 +1852,6 @@ module_init(netxen_init_module); | |||
| 1801 | static void __exit netxen_exit_module(void) | 1852 | static void __exit netxen_exit_module(void) |
| 1802 | { | 1853 | { |
| 1803 | pci_unregister_driver(&netxen_driver); | 1854 | pci_unregister_driver(&netxen_driver); |
| 1804 | destroy_workqueue(netxen_workq); | ||
| 1805 | } | 1855 | } |
| 1806 | 1856 | ||
| 1807 | module_exit(netxen_exit_module); | 1857 | module_exit(netxen_exit_module); |
diff --git a/drivers/net/pcmcia/3c589_cs.c b/drivers/net/pcmcia/3c589_cs.c index ec7cf5ac4f05..690b9c76d34e 100644 --- a/drivers/net/pcmcia/3c589_cs.c +++ b/drivers/net/pcmcia/3c589_cs.c | |||
| @@ -156,6 +156,7 @@ static struct net_device_stats *el3_get_stats(struct net_device *dev); | |||
| 156 | static int el3_rx(struct net_device *dev); | 156 | static int el3_rx(struct net_device *dev); |
| 157 | static int el3_close(struct net_device *dev); | 157 | static int el3_close(struct net_device *dev); |
| 158 | static void el3_tx_timeout(struct net_device *dev); | 158 | static void el3_tx_timeout(struct net_device *dev); |
| 159 | static void set_rx_mode(struct net_device *dev); | ||
| 159 | static void set_multicast_list(struct net_device *dev); | 160 | static void set_multicast_list(struct net_device *dev); |
| 160 | static const struct ethtool_ops netdev_ethtool_ops; | 161 | static const struct ethtool_ops netdev_ethtool_ops; |
| 161 | 162 | ||
| @@ -488,8 +489,7 @@ static void tc589_reset(struct net_device *dev) | |||
| 488 | /* Switch to register set 1 for normal use. */ | 489 | /* Switch to register set 1 for normal use. */ |
| 489 | EL3WINDOW(1); | 490 | EL3WINDOW(1); |
| 490 | 491 | ||
| 491 | /* Accept b-cast and phys addr only. */ | 492 | set_rx_mode(dev); |
| 492 | outw(SetRxFilter | RxStation | RxBroadcast, ioaddr + EL3_CMD); | ||
| 493 | outw(StatsEnable, ioaddr + EL3_CMD); /* Turn on statistics. */ | 493 | outw(StatsEnable, ioaddr + EL3_CMD); /* Turn on statistics. */ |
| 494 | outw(RxEnable, ioaddr + EL3_CMD); /* Enable the receiver. */ | 494 | outw(RxEnable, ioaddr + EL3_CMD); /* Enable the receiver. */ |
| 495 | outw(TxEnable, ioaddr + EL3_CMD); /* Enable transmitter. */ | 495 | outw(TxEnable, ioaddr + EL3_CMD); /* Enable transmitter. */ |
| @@ -700,7 +700,7 @@ static irqreturn_t el3_interrupt(int irq, void *dev_id) | |||
| 700 | if (fifo_diag & 0x2000) { | 700 | if (fifo_diag & 0x2000) { |
| 701 | /* Rx underrun */ | 701 | /* Rx underrun */ |
| 702 | tc589_wait_for_completion(dev, RxReset); | 702 | tc589_wait_for_completion(dev, RxReset); |
| 703 | set_multicast_list(dev); | 703 | set_rx_mode(dev); |
| 704 | outw(RxEnable, ioaddr + EL3_CMD); | 704 | outw(RxEnable, ioaddr + EL3_CMD); |
| 705 | } | 705 | } |
| 706 | outw(AckIntr | AdapterFailure, ioaddr + EL3_CMD); | 706 | outw(AckIntr | AdapterFailure, ioaddr + EL3_CMD); |
| @@ -905,14 +905,11 @@ static int el3_rx(struct net_device *dev) | |||
| 905 | return 0; | 905 | return 0; |
| 906 | } | 906 | } |
| 907 | 907 | ||
| 908 | static void set_multicast_list(struct net_device *dev) | 908 | static void set_rx_mode(struct net_device *dev) |
| 909 | { | 909 | { |
| 910 | struct el3_private *lp = netdev_priv(dev); | ||
| 911 | struct pcmcia_device *link = lp->p_dev; | ||
| 912 | unsigned int ioaddr = dev->base_addr; | 910 | unsigned int ioaddr = dev->base_addr; |
| 913 | u16 opts = SetRxFilter | RxStation | RxBroadcast; | 911 | u16 opts = SetRxFilter | RxStation | RxBroadcast; |
| 914 | 912 | ||
| 915 | if (!pcmcia_dev_present(link)) return; | ||
| 916 | if (dev->flags & IFF_PROMISC) | 913 | if (dev->flags & IFF_PROMISC) |
| 917 | opts |= RxMulticast | RxProm; | 914 | opts |= RxMulticast | RxProm; |
| 918 | else if (dev->mc_count || (dev->flags & IFF_ALLMULTI)) | 915 | else if (dev->mc_count || (dev->flags & IFF_ALLMULTI)) |
| @@ -920,6 +917,16 @@ static void set_multicast_list(struct net_device *dev) | |||
| 920 | outw(opts, ioaddr + EL3_CMD); | 917 | outw(opts, ioaddr + EL3_CMD); |
| 921 | } | 918 | } |
| 922 | 919 | ||
| 920 | static void set_multicast_list(struct net_device *dev) | ||
| 921 | { | ||
| 922 | struct el3_private *priv = netdev_priv(dev); | ||
| 923 | unsigned long flags; | ||
| 924 | |||
| 925 | spin_lock_irqsave(&priv->lock, flags); | ||
| 926 | set_rx_mode(dev); | ||
| 927 | spin_unlock_irqrestore(&priv->lock, flags); | ||
| 928 | } | ||
| 929 | |||
| 923 | static int el3_close(struct net_device *dev) | 930 | static int el3_close(struct net_device *dev) |
| 924 | { | 931 | { |
| 925 | struct el3_private *lp = netdev_priv(dev); | 932 | struct el3_private *lp = netdev_priv(dev); |
diff --git a/drivers/net/pcnet32.c b/drivers/net/pcnet32.c index 28368157dac4..23e1a0750fe0 100644 --- a/drivers/net/pcnet32.c +++ b/drivers/net/pcnet32.c | |||
| @@ -1611,8 +1611,11 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev) | |||
| 1611 | if (pcnet32_dwio_read_csr(ioaddr, 0) == 4 | 1611 | if (pcnet32_dwio_read_csr(ioaddr, 0) == 4 |
| 1612 | && pcnet32_dwio_check(ioaddr)) { | 1612 | && pcnet32_dwio_check(ioaddr)) { |
| 1613 | a = &pcnet32_dwio; | 1613 | a = &pcnet32_dwio; |
| 1614 | } else | 1614 | } else { |
| 1615 | if (pcnet32_debug & NETIF_MSG_PROBE) | ||
| 1616 | printk(KERN_ERR PFX "No access methods\n"); | ||
| 1615 | goto err_release_region; | 1617 | goto err_release_region; |
| 1618 | } | ||
| 1616 | } | 1619 | } |
| 1617 | 1620 | ||
| 1618 | chip_version = | 1621 | chip_version = |
| @@ -1719,7 +1722,9 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev) | |||
| 1719 | ret = -ENOMEM; | 1722 | ret = -ENOMEM; |
| 1720 | goto err_release_region; | 1723 | goto err_release_region; |
| 1721 | } | 1724 | } |
| 1722 | SET_NETDEV_DEV(dev, &pdev->dev); | 1725 | |
| 1726 | if (pdev) | ||
| 1727 | SET_NETDEV_DEV(dev, &pdev->dev); | ||
| 1723 | 1728 | ||
| 1724 | if (pcnet32_debug & NETIF_MSG_PROBE) | 1729 | if (pcnet32_debug & NETIF_MSG_PROBE) |
| 1725 | printk(KERN_INFO PFX "%s at %#3lx,", chipname, ioaddr); | 1730 | printk(KERN_INFO PFX "%s at %#3lx,", chipname, ioaddr); |
| @@ -1818,7 +1823,6 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev) | |||
| 1818 | 1823 | ||
| 1819 | spin_lock_init(&lp->lock); | 1824 | spin_lock_init(&lp->lock); |
| 1820 | 1825 | ||
| 1821 | SET_NETDEV_DEV(dev, &pdev->dev); | ||
| 1822 | lp->name = chipname; | 1826 | lp->name = chipname; |
| 1823 | lp->shared_irq = shared; | 1827 | lp->shared_irq = shared; |
| 1824 | lp->tx_ring_size = TX_RING_SIZE; /* default tx ring size */ | 1828 | lp->tx_ring_size = TX_RING_SIZE; /* default tx ring size */ |
| @@ -1835,7 +1839,7 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev) | |||
| 1835 | lp->chip_version = chip_version; | 1839 | lp->chip_version = chip_version; |
| 1836 | lp->msg_enable = pcnet32_debug; | 1840 | lp->msg_enable = pcnet32_debug; |
| 1837 | if ((cards_found >= MAX_UNITS) | 1841 | if ((cards_found >= MAX_UNITS) |
| 1838 | || (options[cards_found] > sizeof(options_mapping))) | 1842 | || (options[cards_found] >= sizeof(options_mapping))) |
| 1839 | lp->options = PCNET32_PORT_ASEL; | 1843 | lp->options = PCNET32_PORT_ASEL; |
| 1840 | else | 1844 | else |
| 1841 | lp->options = options_mapping[options[cards_found]]; | 1845 | lp->options = options_mapping[options[cards_found]]; |
| @@ -1852,12 +1856,6 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev) | |||
| 1852 | ((cards_found >= MAX_UNITS) || full_duplex[cards_found])) | 1856 | ((cards_found >= MAX_UNITS) || full_duplex[cards_found])) |
| 1853 | lp->options |= PCNET32_PORT_FD; | 1857 | lp->options |= PCNET32_PORT_FD; |
| 1854 | 1858 | ||
| 1855 | if (!a) { | ||
| 1856 | if (pcnet32_debug & NETIF_MSG_PROBE) | ||
| 1857 | printk(KERN_ERR PFX "No access methods\n"); | ||
| 1858 | ret = -ENODEV; | ||
| 1859 | goto err_free_consistent; | ||
| 1860 | } | ||
| 1861 | lp->a = *a; | 1859 | lp->a = *a; |
| 1862 | 1860 | ||
| 1863 | /* prior to register_netdev, dev->name is not yet correct */ | 1861 | /* prior to register_netdev, dev->name is not yet correct */ |
| @@ -1973,14 +1971,13 @@ pcnet32_probe1(unsigned long ioaddr, int shared, struct pci_dev *pdev) | |||
| 1973 | 1971 | ||
| 1974 | return 0; | 1972 | return 0; |
| 1975 | 1973 | ||
| 1976 | err_free_ring: | 1974 | err_free_ring: |
| 1977 | pcnet32_free_ring(dev); | 1975 | pcnet32_free_ring(dev); |
| 1978 | err_free_consistent: | ||
| 1979 | pci_free_consistent(lp->pci_dev, sizeof(*lp->init_block), | 1976 | pci_free_consistent(lp->pci_dev, sizeof(*lp->init_block), |
| 1980 | lp->init_block, lp->init_dma_addr); | 1977 | lp->init_block, lp->init_dma_addr); |
| 1981 | err_free_netdev: | 1978 | err_free_netdev: |
| 1982 | free_netdev(dev); | 1979 | free_netdev(dev); |
| 1983 | err_release_region: | 1980 | err_release_region: |
| 1984 | release_region(ioaddr, PCNET32_TOTAL_SIZE); | 1981 | release_region(ioaddr, PCNET32_TOTAL_SIZE); |
| 1985 | return ret; | 1982 | return ret; |
| 1986 | } | 1983 | } |
| @@ -2089,6 +2086,7 @@ static void pcnet32_free_ring(struct net_device *dev) | |||
| 2089 | static int pcnet32_open(struct net_device *dev) | 2086 | static int pcnet32_open(struct net_device *dev) |
| 2090 | { | 2087 | { |
| 2091 | struct pcnet32_private *lp = netdev_priv(dev); | 2088 | struct pcnet32_private *lp = netdev_priv(dev); |
| 2089 | struct pci_dev *pdev = lp->pci_dev; | ||
| 2092 | unsigned long ioaddr = dev->base_addr; | 2090 | unsigned long ioaddr = dev->base_addr; |
| 2093 | u16 val; | 2091 | u16 val; |
| 2094 | int i; | 2092 | int i; |
| @@ -2149,9 +2147,9 @@ static int pcnet32_open(struct net_device *dev) | |||
| 2149 | lp->a.write_csr(ioaddr, 124, val); | 2147 | lp->a.write_csr(ioaddr, 124, val); |
| 2150 | 2148 | ||
| 2151 | /* Allied Telesyn AT 2700/2701 FX are 100Mbit only and do not negotiate */ | 2149 | /* Allied Telesyn AT 2700/2701 FX are 100Mbit only and do not negotiate */ |
| 2152 | if (lp->pci_dev->subsystem_vendor == PCI_VENDOR_ID_AT && | 2150 | if (pdev && pdev->subsystem_vendor == PCI_VENDOR_ID_AT && |
| 2153 | (lp->pci_dev->subsystem_device == PCI_SUBDEVICE_ID_AT_2700FX || | 2151 | (pdev->subsystem_device == PCI_SUBDEVICE_ID_AT_2700FX || |
| 2154 | lp->pci_dev->subsystem_device == PCI_SUBDEVICE_ID_AT_2701FX)) { | 2152 | pdev->subsystem_device == PCI_SUBDEVICE_ID_AT_2701FX)) { |
| 2155 | if (lp->options & PCNET32_PORT_ASEL) { | 2153 | if (lp->options & PCNET32_PORT_ASEL) { |
| 2156 | lp->options = PCNET32_PORT_FD | PCNET32_PORT_100; | 2154 | lp->options = PCNET32_PORT_FD | PCNET32_PORT_100; |
| 2157 | if (netif_msg_link(lp)) | 2155 | if (netif_msg_link(lp)) |
diff --git a/drivers/net/phy/mdio-gpio.c b/drivers/net/phy/mdio-gpio.c index 33984b737233..22cdd451fb82 100644 --- a/drivers/net/phy/mdio-gpio.c +++ b/drivers/net/phy/mdio-gpio.c | |||
| @@ -30,6 +30,7 @@ | |||
| 30 | 30 | ||
| 31 | #ifdef CONFIG_OF_GPIO | 31 | #ifdef CONFIG_OF_GPIO |
| 32 | #include <linux/of_gpio.h> | 32 | #include <linux/of_gpio.h> |
| 33 | #include <linux/of_mdio.h> | ||
| 33 | #include <linux/of_platform.h> | 34 | #include <linux/of_platform.h> |
| 34 | #endif | 35 | #endif |
| 35 | 36 | ||
| @@ -81,13 +82,12 @@ static struct mdiobb_ops mdio_gpio_ops = { | |||
| 81 | .get_mdio_data = mdio_get, | 82 | .get_mdio_data = mdio_get, |
| 82 | }; | 83 | }; |
| 83 | 84 | ||
| 84 | static int __devinit mdio_gpio_bus_init(struct device *dev, | 85 | static struct mii_bus * __devinit mdio_gpio_bus_init(struct device *dev, |
| 85 | struct mdio_gpio_platform_data *pdata, | 86 | struct mdio_gpio_platform_data *pdata, |
| 86 | int bus_id) | 87 | int bus_id) |
| 87 | { | 88 | { |
| 88 | struct mii_bus *new_bus; | 89 | struct mii_bus *new_bus; |
| 89 | struct mdio_gpio_info *bitbang; | 90 | struct mdio_gpio_info *bitbang; |
| 90 | int ret = -ENOMEM; | ||
| 91 | int i; | 91 | int i; |
| 92 | 92 | ||
| 93 | bitbang = kzalloc(sizeof(*bitbang), GFP_KERNEL); | 93 | bitbang = kzalloc(sizeof(*bitbang), GFP_KERNEL); |
| @@ -104,8 +104,6 @@ static int __devinit mdio_gpio_bus_init(struct device *dev, | |||
| 104 | 104 | ||
| 105 | new_bus->name = "GPIO Bitbanged MDIO", | 105 | new_bus->name = "GPIO Bitbanged MDIO", |
| 106 | 106 | ||
| 107 | ret = -ENODEV; | ||
| 108 | |||
| 109 | new_bus->phy_mask = pdata->phy_mask; | 107 | new_bus->phy_mask = pdata->phy_mask; |
| 110 | new_bus->irq = pdata->irqs; | 108 | new_bus->irq = pdata->irqs; |
| 111 | new_bus->parent = dev; | 109 | new_bus->parent = dev; |
| @@ -129,15 +127,8 @@ static int __devinit mdio_gpio_bus_init(struct device *dev, | |||
| 129 | 127 | ||
| 130 | dev_set_drvdata(dev, new_bus); | 128 | dev_set_drvdata(dev, new_bus); |
| 131 | 129 | ||
| 132 | ret = mdiobus_register(new_bus); | 130 | return new_bus; |
| 133 | if (ret) | ||
| 134 | goto out_free_all; | ||
| 135 | |||
| 136 | return 0; | ||
| 137 | 131 | ||
| 138 | out_free_all: | ||
| 139 | dev_set_drvdata(dev, NULL); | ||
| 140 | gpio_free(bitbang->mdio); | ||
| 141 | out_free_mdc: | 132 | out_free_mdc: |
| 142 | gpio_free(bitbang->mdc); | 133 | gpio_free(bitbang->mdc); |
| 143 | out_free_bus: | 134 | out_free_bus: |
| @@ -145,30 +136,47 @@ out_free_bus: | |||
| 145 | out_free_bitbang: | 136 | out_free_bitbang: |
| 146 | kfree(bitbang); | 137 | kfree(bitbang); |
| 147 | out: | 138 | out: |
| 148 | return ret; | 139 | return NULL; |
| 149 | } | 140 | } |
| 150 | 141 | ||
| 151 | static void __devexit mdio_gpio_bus_destroy(struct device *dev) | 142 | static void __devinit mdio_gpio_bus_deinit(struct device *dev) |
| 152 | { | 143 | { |
| 153 | struct mii_bus *bus = dev_get_drvdata(dev); | 144 | struct mii_bus *bus = dev_get_drvdata(dev); |
| 154 | struct mdio_gpio_info *bitbang = bus->priv; | 145 | struct mdio_gpio_info *bitbang = bus->priv; |
| 155 | 146 | ||
| 156 | mdiobus_unregister(bus); | ||
| 157 | free_mdio_bitbang(bus); | ||
| 158 | dev_set_drvdata(dev, NULL); | 147 | dev_set_drvdata(dev, NULL); |
| 159 | gpio_free(bitbang->mdc); | ||
| 160 | gpio_free(bitbang->mdio); | 148 | gpio_free(bitbang->mdio); |
| 149 | gpio_free(bitbang->mdc); | ||
| 150 | free_mdio_bitbang(bus); | ||
| 161 | kfree(bitbang); | 151 | kfree(bitbang); |
| 162 | } | 152 | } |
| 163 | 153 | ||
| 154 | static void __devexit mdio_gpio_bus_destroy(struct device *dev) | ||
| 155 | { | ||
| 156 | struct mii_bus *bus = dev_get_drvdata(dev); | ||
| 157 | |||
| 158 | mdiobus_unregister(bus); | ||
| 159 | mdio_gpio_bus_deinit(dev); | ||
| 160 | } | ||
| 161 | |||
| 164 | static int __devinit mdio_gpio_probe(struct platform_device *pdev) | 162 | static int __devinit mdio_gpio_probe(struct platform_device *pdev) |
| 165 | { | 163 | { |
| 166 | struct mdio_gpio_platform_data *pdata = pdev->dev.platform_data; | 164 | struct mdio_gpio_platform_data *pdata = pdev->dev.platform_data; |
| 165 | struct mii_bus *new_bus; | ||
| 166 | int ret; | ||
| 167 | 167 | ||
| 168 | if (!pdata) | 168 | if (!pdata) |
| 169 | return -ENODEV; | 169 | return -ENODEV; |
| 170 | 170 | ||
| 171 | return mdio_gpio_bus_init(&pdev->dev, pdata, pdev->id); | 171 | new_bus = mdio_gpio_bus_init(&pdev->dev, pdata, pdev->id); |
| 172 | if (!new_bus) | ||
| 173 | return -ENODEV; | ||
| 174 | |||
| 175 | ret = mdiobus_register(new_bus); | ||
| 176 | if (ret) | ||
| 177 | mdio_gpio_bus_deinit(&pdev->dev); | ||
| 178 | |||
| 179 | return ret; | ||
| 172 | } | 180 | } |
| 173 | 181 | ||
| 174 | static int __devexit mdio_gpio_remove(struct platform_device *pdev) | 182 | static int __devexit mdio_gpio_remove(struct platform_device *pdev) |
| @@ -179,29 +187,12 @@ static int __devexit mdio_gpio_remove(struct platform_device *pdev) | |||
| 179 | } | 187 | } |
| 180 | 188 | ||
| 181 | #ifdef CONFIG_OF_GPIO | 189 | #ifdef CONFIG_OF_GPIO |
| 182 | static void __devinit add_phy(struct mdio_gpio_platform_data *pdata, | ||
| 183 | struct device_node *np) | ||
| 184 | { | ||
| 185 | const u32 *data; | ||
| 186 | int len, id, irq; | ||
| 187 | |||
| 188 | data = of_get_property(np, "reg", &len); | ||
| 189 | if (!data || len != 4) | ||
| 190 | return; | ||
| 191 | |||
| 192 | id = *data; | ||
| 193 | pdata->phy_mask &= ~(1 << id); | ||
| 194 | |||
| 195 | irq = of_irq_to_resource(np, 0, NULL); | ||
| 196 | if (irq) | ||
| 197 | pdata->irqs[id] = irq; | ||
| 198 | } | ||
| 199 | 190 | ||
| 200 | static int __devinit mdio_ofgpio_probe(struct of_device *ofdev, | 191 | static int __devinit mdio_ofgpio_probe(struct of_device *ofdev, |
| 201 | const struct of_device_id *match) | 192 | const struct of_device_id *match) |
| 202 | { | 193 | { |
| 203 | struct device_node *np = NULL; | ||
| 204 | struct mdio_gpio_platform_data *pdata; | 194 | struct mdio_gpio_platform_data *pdata; |
| 195 | struct mii_bus *new_bus; | ||
| 205 | int ret; | 196 | int ret; |
| 206 | 197 | ||
| 207 | pdata = kzalloc(sizeof(*pdata), GFP_KERNEL); | 198 | pdata = kzalloc(sizeof(*pdata), GFP_KERNEL); |
| @@ -215,14 +206,18 @@ static int __devinit mdio_ofgpio_probe(struct of_device *ofdev, | |||
| 215 | 206 | ||
| 216 | ret = of_get_gpio(ofdev->node, 1); | 207 | ret = of_get_gpio(ofdev->node, 1); |
| 217 | if (ret < 0) | 208 | if (ret < 0) |
| 218 | goto out_free; | 209 | goto out_free; |
| 219 | pdata->mdio = ret; | 210 | pdata->mdio = ret; |
| 220 | 211 | ||
| 221 | while ((np = of_get_next_child(ofdev->node, np))) | 212 | new_bus = mdio_gpio_bus_init(&ofdev->dev, pdata, pdata->mdc); |
| 222 | if (!strcmp(np->type, "ethernet-phy")) | 213 | if (!new_bus) |
| 223 | add_phy(pdata, np); | 214 | return -ENODEV; |
| 224 | 215 | ||
| 225 | return mdio_gpio_bus_init(&ofdev->dev, pdata, pdata->mdc); | 216 | ret = of_mdiobus_register(new_bus, ofdev->node); |
| 217 | if (ret) | ||
| 218 | mdio_gpio_bus_deinit(&ofdev->dev); | ||
| 219 | |||
| 220 | return ret; | ||
| 226 | 221 | ||
| 227 | out_free: | 222 | out_free: |
| 228 | kfree(pdata); | 223 | kfree(pdata); |
diff --git a/drivers/net/ppp_generic.c b/drivers/net/ppp_generic.c index 639d11bc444e..cd37d739ac74 100644 --- a/drivers/net/ppp_generic.c +++ b/drivers/net/ppp_generic.c | |||
| @@ -1384,7 +1384,7 @@ static int ppp_mp_explode(struct ppp *ppp, struct sk_buff *skb) | |||
| 1384 | 1384 | ||
| 1385 | /* create a fragment for each channel */ | 1385 | /* create a fragment for each channel */ |
| 1386 | bits = B; | 1386 | bits = B; |
| 1387 | while (nfree > 0 && len > 0) { | 1387 | while (len > 0) { |
| 1388 | list = list->next; | 1388 | list = list->next; |
| 1389 | if (list == &ppp->channels) { | 1389 | if (list == &ppp->channels) { |
| 1390 | i = 0; | 1390 | i = 0; |
| @@ -1431,29 +1431,31 @@ static int ppp_mp_explode(struct ppp *ppp, struct sk_buff *skb) | |||
| 1431 | *otherwise divide it according to the speed | 1431 | *otherwise divide it according to the speed |
| 1432 | *of the channel we are going to transmit on | 1432 | *of the channel we are going to transmit on |
| 1433 | */ | 1433 | */ |
| 1434 | if (pch->speed == 0) { | 1434 | if (nfree > 0) { |
| 1435 | flen = totlen/nfree ; | 1435 | if (pch->speed == 0) { |
| 1436 | if (nbigger > 0) { | 1436 | flen = totlen/nfree ; |
| 1437 | flen++; | 1437 | if (nbigger > 0) { |
| 1438 | nbigger--; | 1438 | flen++; |
| 1439 | } | 1439 | nbigger--; |
| 1440 | } else { | 1440 | } |
| 1441 | flen = (((totfree - nzero)*(totlen + hdrlen*totfree)) / | 1441 | } else { |
| 1442 | ((totspeed*totfree)/pch->speed)) - hdrlen; | 1442 | flen = (((totfree - nzero)*(totlen + hdrlen*totfree)) / |
| 1443 | if (nbigger > 0) { | 1443 | ((totspeed*totfree)/pch->speed)) - hdrlen; |
| 1444 | flen += ((totfree - nzero)*pch->speed)/totspeed; | 1444 | if (nbigger > 0) { |
| 1445 | nbigger -= ((totfree - nzero)*pch->speed)/ | 1445 | flen += ((totfree - nzero)*pch->speed)/totspeed; |
| 1446 | nbigger -= ((totfree - nzero)*pch->speed)/ | ||
| 1446 | totspeed; | 1447 | totspeed; |
| 1448 | } | ||
| 1447 | } | 1449 | } |
| 1450 | nfree--; | ||
| 1448 | } | 1451 | } |
| 1449 | nfree--; | ||
| 1450 | 1452 | ||
| 1451 | /* | 1453 | /* |
| 1452 | *check if we are on the last channel or | 1454 | *check if we are on the last channel or |
| 1453 | *we exceded the lenght of the data to | 1455 | *we exceded the lenght of the data to |
| 1454 | *fragment | 1456 | *fragment |
| 1455 | */ | 1457 | */ |
| 1456 | if ((nfree == 0) || (flen > len)) | 1458 | if ((nfree <= 0) || (flen > len)) |
| 1457 | flen = len; | 1459 | flen = len; |
| 1458 | /* | 1460 | /* |
| 1459 | *it is not worth to tx on slow channels: | 1461 | *it is not worth to tx on slow channels: |
| @@ -1467,7 +1469,7 @@ static int ppp_mp_explode(struct ppp *ppp, struct sk_buff *skb) | |||
| 1467 | continue; | 1469 | continue; |
| 1468 | } | 1470 | } |
| 1469 | 1471 | ||
| 1470 | mtu = pch->chan->mtu + 2 - hdrlen; | 1472 | mtu = pch->chan->mtu - hdrlen; |
| 1471 | if (mtu < 4) | 1473 | if (mtu < 4) |
| 1472 | mtu = 4; | 1474 | mtu = 4; |
| 1473 | if (flen > mtu) | 1475 | if (flen > mtu) |
diff --git a/drivers/net/pppoe.c b/drivers/net/pppoe.c index f0031f1f97e5..5f2090233d7b 100644 --- a/drivers/net/pppoe.c +++ b/drivers/net/pppoe.c | |||
| @@ -1063,6 +1063,7 @@ static void *pppoe_seq_next(struct seq_file *seq, void *v, loff_t *pos) | |||
| 1063 | else { | 1063 | else { |
| 1064 | int hash = hash_item(po->pppoe_pa.sid, po->pppoe_pa.remote); | 1064 | int hash = hash_item(po->pppoe_pa.sid, po->pppoe_pa.remote); |
| 1065 | 1065 | ||
| 1066 | po = NULL; | ||
| 1066 | while (++hash < PPPOE_HASH_SIZE) { | 1067 | while (++hash < PPPOE_HASH_SIZE) { |
| 1067 | po = pn->hash_table[hash]; | 1068 | po = pn->hash_table[hash]; |
| 1068 | if (po) | 1069 | if (po) |
diff --git a/drivers/net/pppol2tp.c b/drivers/net/pppol2tp.c index e7935d09c896..e0f9219a0aea 100644 --- a/drivers/net/pppol2tp.c +++ b/drivers/net/pppol2tp.c | |||
| @@ -2680,6 +2680,7 @@ out_unregister_pppol2tp_proto: | |||
| 2680 | static void __exit pppol2tp_exit(void) | 2680 | static void __exit pppol2tp_exit(void) |
| 2681 | { | 2681 | { |
| 2682 | unregister_pppox_proto(PX_PROTO_OL2TP); | 2682 | unregister_pppox_proto(PX_PROTO_OL2TP); |
| 2683 | unregister_pernet_gen_device(pppol2tp_net_id, &pppol2tp_net_ops); | ||
| 2683 | proto_unregister(&pppol2tp_sk_proto); | 2684 | proto_unregister(&pppol2tp_sk_proto); |
| 2684 | } | 2685 | } |
| 2685 | 2686 | ||
diff --git a/drivers/net/r8169.c b/drivers/net/r8169.c index 4b53b58d75fc..b82780d805f5 100644 --- a/drivers/net/r8169.c +++ b/drivers/net/r8169.c | |||
| @@ -2060,8 +2060,6 @@ rtl8169_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 2060 | } | 2060 | } |
| 2061 | } | 2061 | } |
| 2062 | 2062 | ||
| 2063 | pci_set_master(pdev); | ||
| 2064 | |||
| 2065 | /* ioremap MMIO region */ | 2063 | /* ioremap MMIO region */ |
| 2066 | ioaddr = ioremap(pci_resource_start(pdev, region), R8169_REGS_SIZE); | 2064 | ioaddr = ioremap(pci_resource_start(pdev, region), R8169_REGS_SIZE); |
| 2067 | if (!ioaddr) { | 2065 | if (!ioaddr) { |
| @@ -2089,6 +2087,8 @@ rtl8169_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 2089 | 2087 | ||
| 2090 | RTL_W16(IntrStatus, 0xffff); | 2088 | RTL_W16(IntrStatus, 0xffff); |
| 2091 | 2089 | ||
| 2090 | pci_set_master(pdev); | ||
| 2091 | |||
| 2092 | /* Identify chip attached to board */ | 2092 | /* Identify chip attached to board */ |
| 2093 | rtl8169_get_mac_version(tp, ioaddr); | 2093 | rtl8169_get_mac_version(tp, ioaddr); |
| 2094 | 2094 | ||
| @@ -3874,6 +3874,15 @@ static void rtl_shutdown(struct pci_dev *pdev) | |||
| 3874 | spin_unlock_irq(&tp->lock); | 3874 | spin_unlock_irq(&tp->lock); |
| 3875 | 3875 | ||
| 3876 | if (system_state == SYSTEM_POWER_OFF) { | 3876 | if (system_state == SYSTEM_POWER_OFF) { |
| 3877 | /* WoL fails with some 8168 when the receiver is disabled. */ | ||
| 3878 | if (tp->features & RTL_FEATURE_WOL) { | ||
| 3879 | pci_clear_master(pdev); | ||
| 3880 | |||
| 3881 | RTL_W8(ChipCmd, CmdRxEnb); | ||
| 3882 | /* PCI commit */ | ||
| 3883 | RTL_R8(ChipCmd); | ||
| 3884 | } | ||
| 3885 | |||
| 3877 | pci_wake_from_d3(pdev, true); | 3886 | pci_wake_from_d3(pdev, true); |
| 3878 | pci_set_power_state(pdev, PCI_D3hot); | 3887 | pci_set_power_state(pdev, PCI_D3hot); |
| 3879 | } | 3888 | } |
diff --git a/drivers/net/s6gmac.c b/drivers/net/s6gmac.c index 5345e47b35ac..4525cbe8dd69 100644 --- a/drivers/net/s6gmac.c +++ b/drivers/net/s6gmac.c | |||
| @@ -793,7 +793,7 @@ static inline int s6gmac_phy_start(struct net_device *dev) | |||
| 793 | struct s6gmac *pd = netdev_priv(dev); | 793 | struct s6gmac *pd = netdev_priv(dev); |
| 794 | int i = 0; | 794 | int i = 0; |
| 795 | struct phy_device *p = NULL; | 795 | struct phy_device *p = NULL; |
| 796 | while ((!(p = pd->mii.bus->phy_map[i])) && (i < PHY_MAX_ADDR)) | 796 | while ((i < PHY_MAX_ADDR) && (!(p = pd->mii.bus->phy_map[i]))) |
| 797 | i++; | 797 | i++; |
| 798 | p = phy_connect(dev, dev_name(&p->dev), &s6gmac_adjust_link, 0, | 798 | p = phy_connect(dev, dev_name(&p->dev), &s6gmac_adjust_link, 0, |
| 799 | PHY_INTERFACE_MODE_RGMII); | 799 | PHY_INTERFACE_MODE_RGMII); |
diff --git a/drivers/net/sc92031.c b/drivers/net/sc92031.c index 18821f217e19..e3156c97bb58 100644 --- a/drivers/net/sc92031.c +++ b/drivers/net/sc92031.c | |||
| @@ -1593,6 +1593,7 @@ out: | |||
| 1593 | static struct pci_device_id sc92031_pci_device_id_table[] __devinitdata = { | 1593 | static struct pci_device_id sc92031_pci_device_id_table[] __devinitdata = { |
| 1594 | { PCI_DEVICE(PCI_VENDOR_ID_SILAN, 0x2031) }, | 1594 | { PCI_DEVICE(PCI_VENDOR_ID_SILAN, 0x2031) }, |
| 1595 | { PCI_DEVICE(PCI_VENDOR_ID_SILAN, 0x8139) }, | 1595 | { PCI_DEVICE(PCI_VENDOR_ID_SILAN, 0x8139) }, |
| 1596 | { PCI_DEVICE(0x1088, 0x2031) }, | ||
| 1596 | { 0, } | 1597 | { 0, } |
| 1597 | }; | 1598 | }; |
| 1598 | MODULE_DEVICE_TABLE(pci, sc92031_pci_device_id_table); | 1599 | MODULE_DEVICE_TABLE(pci, sc92031_pci_device_id_table); |
diff --git a/drivers/net/skge.c b/drivers/net/skge.c index 60d502eef4fc..543af2044f40 100644 --- a/drivers/net/skge.c +++ b/drivers/net/skge.c | |||
| @@ -3854,8 +3854,10 @@ static struct net_device *skge_devinit(struct skge_hw *hw, int port, | |||
| 3854 | skge->speed = -1; | 3854 | skge->speed = -1; |
| 3855 | skge->advertising = skge_supported_modes(hw); | 3855 | skge->advertising = skge_supported_modes(hw); |
| 3856 | 3856 | ||
| 3857 | if (device_may_wakeup(&hw->pdev->dev)) | 3857 | if (device_can_wakeup(&hw->pdev->dev)) { |
| 3858 | skge->wol = wol_supported(hw) & WAKE_MAGIC; | 3858 | skge->wol = wol_supported(hw) & WAKE_MAGIC; |
| 3859 | device_set_wakeup_enable(&hw->pdev->dev, skge->wol); | ||
| 3860 | } | ||
| 3859 | 3861 | ||
| 3860 | hw->dev[port] = dev; | 3862 | hw->dev[port] = dev; |
| 3861 | 3863 | ||
diff --git a/drivers/net/sky2.c b/drivers/net/sky2.c index daf961ab68bc..0a551d8f5d95 100644 --- a/drivers/net/sky2.c +++ b/drivers/net/sky2.c | |||
| @@ -1151,14 +1151,7 @@ stopped: | |||
| 1151 | 1151 | ||
| 1152 | /* reset the Rx prefetch unit */ | 1152 | /* reset the Rx prefetch unit */ |
| 1153 | sky2_write32(hw, Y2_QADDR(rxq, PREF_UNIT_CTRL), PREF_UNIT_RST_SET); | 1153 | sky2_write32(hw, Y2_QADDR(rxq, PREF_UNIT_CTRL), PREF_UNIT_RST_SET); |
| 1154 | 1154 | mmiowb(); | |
| 1155 | /* Reset the RAM Buffer receive queue */ | ||
| 1156 | sky2_write8(hw, RB_ADDR(rxq, RB_CTRL), RB_RST_SET); | ||
| 1157 | |||
| 1158 | /* Reset Rx MAC FIFO */ | ||
| 1159 | sky2_write8(hw, SK_REG(sky2->port, RX_GMF_CTRL_T), GMF_RST_SET); | ||
| 1160 | |||
| 1161 | sky2_read8(hw, B0_CTST); | ||
| 1162 | } | 1155 | } |
| 1163 | 1156 | ||
| 1164 | /* Clean out receive buffer area, assumes receiver hardware stopped */ | 1157 | /* Clean out receive buffer area, assumes receiver hardware stopped */ |
| @@ -1495,6 +1488,8 @@ static int sky2_up(struct net_device *dev) | |||
| 1495 | sky2_set_vlan_mode(hw, port, sky2->vlgrp != NULL); | 1488 | sky2_set_vlan_mode(hw, port, sky2->vlgrp != NULL); |
| 1496 | #endif | 1489 | #endif |
| 1497 | 1490 | ||
| 1491 | sky2->restarting = 0; | ||
| 1492 | |||
| 1498 | err = sky2_rx_start(sky2); | 1493 | err = sky2_rx_start(sky2); |
| 1499 | if (err) | 1494 | if (err) |
| 1500 | goto err_out; | 1495 | goto err_out; |
| @@ -1507,6 +1502,9 @@ static int sky2_up(struct net_device *dev) | |||
| 1507 | 1502 | ||
| 1508 | sky2_set_multicast(dev); | 1503 | sky2_set_multicast(dev); |
| 1509 | 1504 | ||
| 1505 | /* wake queue incase we are restarting */ | ||
| 1506 | netif_wake_queue(dev); | ||
| 1507 | |||
| 1510 | if (netif_msg_ifup(sky2)) | 1508 | if (netif_msg_ifup(sky2)) |
| 1511 | printk(KERN_INFO PFX "%s: enabling interface\n", dev->name); | 1509 | printk(KERN_INFO PFX "%s: enabling interface\n", dev->name); |
| 1512 | return 0; | 1510 | return 0; |
| @@ -1540,6 +1538,8 @@ static inline int tx_dist(unsigned tail, unsigned head) | |||
| 1540 | /* Number of list elements available for next tx */ | 1538 | /* Number of list elements available for next tx */ |
| 1541 | static inline int tx_avail(const struct sky2_port *sky2) | 1539 | static inline int tx_avail(const struct sky2_port *sky2) |
| 1542 | { | 1540 | { |
| 1541 | if (unlikely(sky2->restarting)) | ||
| 1542 | return 0; | ||
| 1543 | return sky2->tx_pending - tx_dist(sky2->tx_cons, sky2->tx_prod); | 1543 | return sky2->tx_pending - tx_dist(sky2->tx_cons, sky2->tx_prod); |
| 1544 | } | 1544 | } |
| 1545 | 1545 | ||
| @@ -1825,11 +1825,9 @@ static int sky2_down(struct net_device *dev) | |||
| 1825 | if (netif_msg_ifdown(sky2)) | 1825 | if (netif_msg_ifdown(sky2)) |
| 1826 | printk(KERN_INFO PFX "%s: disabling interface\n", dev->name); | 1826 | printk(KERN_INFO PFX "%s: disabling interface\n", dev->name); |
| 1827 | 1827 | ||
| 1828 | /* Disable port IRQ */ | 1828 | /* explicitly shut off tx incase we're restarting */ |
| 1829 | imask = sky2_read32(hw, B0_IMSK); | 1829 | sky2->restarting = 1; |
| 1830 | imask &= ~portirq_msk[port]; | 1830 | netif_tx_disable(dev); |
| 1831 | sky2_write32(hw, B0_IMSK, imask); | ||
| 1832 | sky2_read32(hw, B0_IMSK); | ||
| 1833 | 1831 | ||
| 1834 | /* Force flow control off */ | 1832 | /* Force flow control off */ |
| 1835 | sky2_write8(hw, SK_REG(port, GMAC_CTRL), GMC_PAUSE_OFF); | 1833 | sky2_write8(hw, SK_REG(port, GMAC_CTRL), GMC_PAUSE_OFF); |
| @@ -1870,8 +1868,6 @@ static int sky2_down(struct net_device *dev) | |||
| 1870 | 1868 | ||
| 1871 | sky2_write32(hw, RB_ADDR(txqaddr[port], RB_CTRL), RB_RST_SET); | 1869 | sky2_write32(hw, RB_ADDR(txqaddr[port], RB_CTRL), RB_RST_SET); |
| 1872 | 1870 | ||
| 1873 | sky2_rx_stop(sky2); | ||
| 1874 | |||
| 1875 | sky2_write8(hw, SK_REG(port, RX_GMF_CTRL_T), GMF_RST_SET); | 1871 | sky2_write8(hw, SK_REG(port, RX_GMF_CTRL_T), GMF_RST_SET); |
| 1876 | sky2_write8(hw, SK_REG(port, TX_GMF_CTRL_T), GMF_RST_SET); | 1872 | sky2_write8(hw, SK_REG(port, TX_GMF_CTRL_T), GMF_RST_SET); |
| 1877 | 1873 | ||
| @@ -1881,6 +1877,14 @@ static int sky2_down(struct net_device *dev) | |||
| 1881 | sky2_write32(hw, STAT_ISR_TIMER_CNT, 0); | 1877 | sky2_write32(hw, STAT_ISR_TIMER_CNT, 0); |
| 1882 | sky2_read8(hw, STAT_ISR_TIMER_CTRL); | 1878 | sky2_read8(hw, STAT_ISR_TIMER_CTRL); |
| 1883 | 1879 | ||
| 1880 | sky2_rx_stop(sky2); | ||
| 1881 | |||
| 1882 | /* Disable port IRQ */ | ||
| 1883 | imask = sky2_read32(hw, B0_IMSK); | ||
| 1884 | imask &= ~portirq_msk[port]; | ||
| 1885 | sky2_write32(hw, B0_IMSK, imask); | ||
| 1886 | sky2_read32(hw, B0_IMSK); | ||
| 1887 | |||
| 1884 | synchronize_irq(hw->pdev->irq); | 1888 | synchronize_irq(hw->pdev->irq); |
| 1885 | napi_synchronize(&hw->napi); | 1889 | napi_synchronize(&hw->napi); |
| 1886 | 1890 | ||
| @@ -2366,7 +2370,7 @@ static inline void sky2_tx_done(struct net_device *dev, u16 last) | |||
| 2366 | { | 2370 | { |
| 2367 | struct sky2_port *sky2 = netdev_priv(dev); | 2371 | struct sky2_port *sky2 = netdev_priv(dev); |
| 2368 | 2372 | ||
| 2369 | if (netif_running(dev)) { | 2373 | if (likely(netif_running(dev) && !sky2->restarting)) { |
| 2370 | netif_tx_lock(dev); | 2374 | netif_tx_lock(dev); |
| 2371 | sky2_tx_complete(sky2, last); | 2375 | sky2_tx_complete(sky2, last); |
| 2372 | netif_tx_unlock(dev); | 2376 | netif_tx_unlock(dev); |
| @@ -4290,6 +4294,7 @@ static __devinit struct net_device *sky2_init_netdev(struct sky2_hw *hw, | |||
| 4290 | spin_lock_init(&sky2->phy_lock); | 4294 | spin_lock_init(&sky2->phy_lock); |
| 4291 | sky2->tx_pending = TX_DEF_PENDING; | 4295 | sky2->tx_pending = TX_DEF_PENDING; |
| 4292 | sky2->rx_pending = RX_DEF_PENDING; | 4296 | sky2->rx_pending = RX_DEF_PENDING; |
| 4297 | sky2->restarting = 0; | ||
| 4293 | 4298 | ||
| 4294 | hw->dev[port] = dev; | 4299 | hw->dev[port] = dev; |
| 4295 | 4300 | ||
diff --git a/drivers/net/sky2.h b/drivers/net/sky2.h index b5549c9e5107..4486b066b43f 100644 --- a/drivers/net/sky2.h +++ b/drivers/net/sky2.h | |||
| @@ -2051,6 +2051,7 @@ struct sky2_port { | |||
| 2051 | u8 duplex; /* DUPLEX_HALF, DUPLEX_FULL */ | 2051 | u8 duplex; /* DUPLEX_HALF, DUPLEX_FULL */ |
| 2052 | u8 rx_csum; | 2052 | u8 rx_csum; |
| 2053 | u8 wol; | 2053 | u8 wol; |
| 2054 | u8 restarting; | ||
| 2054 | enum flow_control flow_mode; | 2055 | enum flow_control flow_mode; |
| 2055 | enum flow_control flow_status; | 2056 | enum flow_control flow_status; |
| 2056 | 2057 | ||
diff --git a/drivers/net/smc91x.c b/drivers/net/smc91x.c index 1c70e999cc50..7567f510eff5 100644 --- a/drivers/net/smc91x.c +++ b/drivers/net/smc91x.c | |||
| @@ -196,21 +196,23 @@ static void PRINT_PKT(u_char *buf, int length) | |||
| 196 | /* this enables an interrupt in the interrupt mask register */ | 196 | /* this enables an interrupt in the interrupt mask register */ |
| 197 | #define SMC_ENABLE_INT(lp, x) do { \ | 197 | #define SMC_ENABLE_INT(lp, x) do { \ |
| 198 | unsigned char mask; \ | 198 | unsigned char mask; \ |
| 199 | spin_lock_irq(&lp->lock); \ | 199 | unsigned long smc_enable_flags; \ |
| 200 | spin_lock_irqsave(&lp->lock, smc_enable_flags); \ | ||
| 200 | mask = SMC_GET_INT_MASK(lp); \ | 201 | mask = SMC_GET_INT_MASK(lp); \ |
| 201 | mask |= (x); \ | 202 | mask |= (x); \ |
| 202 | SMC_SET_INT_MASK(lp, mask); \ | 203 | SMC_SET_INT_MASK(lp, mask); \ |
| 203 | spin_unlock_irq(&lp->lock); \ | 204 | spin_unlock_irqrestore(&lp->lock, smc_enable_flags); \ |
| 204 | } while (0) | 205 | } while (0) |
| 205 | 206 | ||
| 206 | /* this disables an interrupt from the interrupt mask register */ | 207 | /* this disables an interrupt from the interrupt mask register */ |
| 207 | #define SMC_DISABLE_INT(lp, x) do { \ | 208 | #define SMC_DISABLE_INT(lp, x) do { \ |
| 208 | unsigned char mask; \ | 209 | unsigned char mask; \ |
| 209 | spin_lock_irq(&lp->lock); \ | 210 | unsigned long smc_disable_flags; \ |
| 211 | spin_lock_irqsave(&lp->lock, smc_disable_flags); \ | ||
| 210 | mask = SMC_GET_INT_MASK(lp); \ | 212 | mask = SMC_GET_INT_MASK(lp); \ |
| 211 | mask &= ~(x); \ | 213 | mask &= ~(x); \ |
| 212 | SMC_SET_INT_MASK(lp, mask); \ | 214 | SMC_SET_INT_MASK(lp, mask); \ |
| 213 | spin_unlock_irq(&lp->lock); \ | 215 | spin_unlock_irqrestore(&lp->lock, smc_disable_flags); \ |
| 214 | } while (0) | 216 | } while (0) |
| 215 | 217 | ||
| 216 | /* | 218 | /* |
| @@ -520,21 +522,21 @@ static inline void smc_rcv(struct net_device *dev) | |||
| 520 | * any other concurrent access and C would always interrupt B. But life | 522 | * any other concurrent access and C would always interrupt B. But life |
| 521 | * isn't that easy in a SMP world... | 523 | * isn't that easy in a SMP world... |
| 522 | */ | 524 | */ |
| 523 | #define smc_special_trylock(lock) \ | 525 | #define smc_special_trylock(lock, flags) \ |
| 524 | ({ \ | 526 | ({ \ |
| 525 | int __ret; \ | 527 | int __ret; \ |
| 526 | local_irq_disable(); \ | 528 | local_irq_save(flags); \ |
| 527 | __ret = spin_trylock(lock); \ | 529 | __ret = spin_trylock(lock); \ |
| 528 | if (!__ret) \ | 530 | if (!__ret) \ |
| 529 | local_irq_enable(); \ | 531 | local_irq_restore(flags); \ |
| 530 | __ret; \ | 532 | __ret; \ |
| 531 | }) | 533 | }) |
| 532 | #define smc_special_lock(lock) spin_lock_irq(lock) | 534 | #define smc_special_lock(lock, flags) spin_lock_irqsave(lock, flags) |
| 533 | #define smc_special_unlock(lock) spin_unlock_irq(lock) | 535 | #define smc_special_unlock(lock, flags) spin_unlock_irqrestore(lock, flags) |
| 534 | #else | 536 | #else |
| 535 | #define smc_special_trylock(lock) (1) | 537 | #define smc_special_trylock(lock, flags) (1) |
| 536 | #define smc_special_lock(lock) do { } while (0) | 538 | #define smc_special_lock(lock, flags) do { } while (0) |
| 537 | #define smc_special_unlock(lock) do { } while (0) | 539 | #define smc_special_unlock(lock, flags) do { } while (0) |
| 538 | #endif | 540 | #endif |
| 539 | 541 | ||
| 540 | /* | 542 | /* |
| @@ -548,10 +550,11 @@ static void smc_hardware_send_pkt(unsigned long data) | |||
| 548 | struct sk_buff *skb; | 550 | struct sk_buff *skb; |
| 549 | unsigned int packet_no, len; | 551 | unsigned int packet_no, len; |
| 550 | unsigned char *buf; | 552 | unsigned char *buf; |
| 553 | unsigned long flags; | ||
| 551 | 554 | ||
| 552 | DBG(3, "%s: %s\n", dev->name, __func__); | 555 | DBG(3, "%s: %s\n", dev->name, __func__); |
| 553 | 556 | ||
| 554 | if (!smc_special_trylock(&lp->lock)) { | 557 | if (!smc_special_trylock(&lp->lock, flags)) { |
| 555 | netif_stop_queue(dev); | 558 | netif_stop_queue(dev); |
| 556 | tasklet_schedule(&lp->tx_task); | 559 | tasklet_schedule(&lp->tx_task); |
| 557 | return; | 560 | return; |
| @@ -559,7 +562,7 @@ static void smc_hardware_send_pkt(unsigned long data) | |||
| 559 | 562 | ||
| 560 | skb = lp->pending_tx_skb; | 563 | skb = lp->pending_tx_skb; |
| 561 | if (unlikely(!skb)) { | 564 | if (unlikely(!skb)) { |
| 562 | smc_special_unlock(&lp->lock); | 565 | smc_special_unlock(&lp->lock, flags); |
| 563 | return; | 566 | return; |
| 564 | } | 567 | } |
| 565 | lp->pending_tx_skb = NULL; | 568 | lp->pending_tx_skb = NULL; |
| @@ -569,7 +572,7 @@ static void smc_hardware_send_pkt(unsigned long data) | |||
| 569 | printk("%s: Memory allocation failed.\n", dev->name); | 572 | printk("%s: Memory allocation failed.\n", dev->name); |
| 570 | dev->stats.tx_errors++; | 573 | dev->stats.tx_errors++; |
| 571 | dev->stats.tx_fifo_errors++; | 574 | dev->stats.tx_fifo_errors++; |
| 572 | smc_special_unlock(&lp->lock); | 575 | smc_special_unlock(&lp->lock, flags); |
| 573 | goto done; | 576 | goto done; |
| 574 | } | 577 | } |
| 575 | 578 | ||
| @@ -608,7 +611,7 @@ static void smc_hardware_send_pkt(unsigned long data) | |||
| 608 | 611 | ||
| 609 | /* queue the packet for TX */ | 612 | /* queue the packet for TX */ |
| 610 | SMC_SET_MMU_CMD(lp, MC_ENQUEUE); | 613 | SMC_SET_MMU_CMD(lp, MC_ENQUEUE); |
| 611 | smc_special_unlock(&lp->lock); | 614 | smc_special_unlock(&lp->lock, flags); |
| 612 | 615 | ||
| 613 | dev->trans_start = jiffies; | 616 | dev->trans_start = jiffies; |
| 614 | dev->stats.tx_packets++; | 617 | dev->stats.tx_packets++; |
| @@ -633,6 +636,7 @@ static int smc_hard_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 633 | struct smc_local *lp = netdev_priv(dev); | 636 | struct smc_local *lp = netdev_priv(dev); |
| 634 | void __iomem *ioaddr = lp->base; | 637 | void __iomem *ioaddr = lp->base; |
| 635 | unsigned int numPages, poll_count, status; | 638 | unsigned int numPages, poll_count, status; |
| 639 | unsigned long flags; | ||
| 636 | 640 | ||
| 637 | DBG(3, "%s: %s\n", dev->name, __func__); | 641 | DBG(3, "%s: %s\n", dev->name, __func__); |
| 638 | 642 | ||
| @@ -658,7 +662,7 @@ static int smc_hard_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 658 | return 0; | 662 | return 0; |
| 659 | } | 663 | } |
| 660 | 664 | ||
| 661 | smc_special_lock(&lp->lock); | 665 | smc_special_lock(&lp->lock, flags); |
| 662 | 666 | ||
| 663 | /* now, try to allocate the memory */ | 667 | /* now, try to allocate the memory */ |
| 664 | SMC_SET_MMU_CMD(lp, MC_ALLOC | numPages); | 668 | SMC_SET_MMU_CMD(lp, MC_ALLOC | numPages); |
| @@ -676,7 +680,7 @@ static int smc_hard_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 676 | } | 680 | } |
| 677 | } while (--poll_count); | 681 | } while (--poll_count); |
| 678 | 682 | ||
| 679 | smc_special_unlock(&lp->lock); | 683 | smc_special_unlock(&lp->lock, flags); |
| 680 | 684 | ||
| 681 | lp->pending_tx_skb = skb; | 685 | lp->pending_tx_skb = skb; |
| 682 | if (!poll_count) { | 686 | if (!poll_count) { |
diff --git a/drivers/net/smc91x.h b/drivers/net/smc91x.h index f1f773b17fe1..57a159fac99f 100644 --- a/drivers/net/smc91x.h +++ b/drivers/net/smc91x.h | |||
| @@ -186,7 +186,8 @@ static inline void SMC_outw(u16 val, void __iomem *ioaddr, int reg) | |||
| 186 | #define SMC_outsb(a, r, p, l) writesb((a) + (r), p, (l)) | 186 | #define SMC_outsb(a, r, p, l) writesb((a) + (r), p, (l)) |
| 187 | #define SMC_IRQ_FLAGS (-1) /* from resource */ | 187 | #define SMC_IRQ_FLAGS (-1) /* from resource */ |
| 188 | 188 | ||
| 189 | #elif defined(CONFIG_MACH_LOGICPD_PXA270) | 189 | #elif defined(CONFIG_MACH_LOGICPD_PXA270) \ |
| 190 | || defined(CONFIG_MACH_NOMADIK_8815NHK) | ||
| 190 | 191 | ||
| 191 | #define SMC_CAN_USE_8BIT 0 | 192 | #define SMC_CAN_USE_8BIT 0 |
| 192 | #define SMC_CAN_USE_16BIT 1 | 193 | #define SMC_CAN_USE_16BIT 1 |
diff --git a/drivers/net/tokenring/ibmtr.c b/drivers/net/tokenring/ibmtr.c index 9d896116cf76..08a6c41c1599 100644 --- a/drivers/net/tokenring/ibmtr.c +++ b/drivers/net/tokenring/ibmtr.c | |||
| @@ -1912,7 +1912,7 @@ static int __init ibmtr_init(void) | |||
| 1912 | 1912 | ||
| 1913 | find_turbo_adapters(io); | 1913 | find_turbo_adapters(io); |
| 1914 | 1914 | ||
| 1915 | for (i = 0; io[i] && (i < IBMTR_MAX_ADAPTERS); i++) { | 1915 | for (i = 0; i < IBMTR_MAX_ADAPTERS && io[i]; i++) { |
| 1916 | struct net_device *dev; | 1916 | struct net_device *dev; |
| 1917 | irq[i] = 0; | 1917 | irq[i] = 0; |
| 1918 | mem[i] = 0; | 1918 | mem[i] = 0; |
diff --git a/drivers/net/tulip/de4x5.c b/drivers/net/tulip/de4x5.c index eb72d2e9ab3d..acfdccd44567 100644 --- a/drivers/net/tulip/de4x5.c +++ b/drivers/net/tulip/de4x5.c | |||
| @@ -5059,7 +5059,7 @@ mii_get_phy(struct net_device *dev) | |||
| 5059 | if ((id == 0) || (id == 65535)) continue; /* Valid ID? */ | 5059 | if ((id == 0) || (id == 65535)) continue; /* Valid ID? */ |
| 5060 | for (j=0; j<limit; j++) { /* Search PHY table */ | 5060 | for (j=0; j<limit; j++) { /* Search PHY table */ |
| 5061 | if (id != phy_info[j].id) continue; /* ID match? */ | 5061 | if (id != phy_info[j].id) continue; /* ID match? */ |
| 5062 | for (k=0; lp->phy[k].id && (k < DE4X5_MAX_PHY); k++); | 5062 | for (k=0; k < DE4X5_MAX_PHY && lp->phy[k].id; k++); |
| 5063 | if (k < DE4X5_MAX_PHY) { | 5063 | if (k < DE4X5_MAX_PHY) { |
| 5064 | memcpy((char *)&lp->phy[k], | 5064 | memcpy((char *)&lp->phy[k], |
| 5065 | (char *)&phy_info[j], sizeof(struct phy_table)); | 5065 | (char *)&phy_info[j], sizeof(struct phy_table)); |
| @@ -5072,7 +5072,7 @@ mii_get_phy(struct net_device *dev) | |||
| 5072 | break; | 5072 | break; |
| 5073 | } | 5073 | } |
| 5074 | if ((j == limit) && (i < DE4X5_MAX_MII)) { | 5074 | if ((j == limit) && (i < DE4X5_MAX_MII)) { |
| 5075 | for (k=0; lp->phy[k].id && (k < DE4X5_MAX_PHY); k++); | 5075 | for (k=0; k < DE4X5_MAX_PHY && lp->phy[k].id; k++); |
| 5076 | lp->phy[k].addr = i; | 5076 | lp->phy[k].addr = i; |
| 5077 | lp->phy[k].id = id; | 5077 | lp->phy[k].id = id; |
| 5078 | lp->phy[k].spd.reg = GENERIC_REG; /* ANLPA register */ | 5078 | lp->phy[k].spd.reg = GENERIC_REG; /* ANLPA register */ |
| @@ -5091,7 +5091,7 @@ mii_get_phy(struct net_device *dev) | |||
| 5091 | purgatory: | 5091 | purgatory: |
| 5092 | lp->active = 0; | 5092 | lp->active = 0; |
| 5093 | if (lp->phy[0].id) { /* Reset the PHY devices */ | 5093 | if (lp->phy[0].id) { /* Reset the PHY devices */ |
| 5094 | for (k=0; lp->phy[k].id && (k < DE4X5_MAX_PHY); k++) { /*For each PHY*/ | 5094 | for (k=0; k < DE4X5_MAX_PHY && lp->phy[k].id; k++) { /*For each PHY*/ |
| 5095 | mii_wr(MII_CR_RST, MII_CR, lp->phy[k].addr, DE4X5_MII); | 5095 | mii_wr(MII_CR_RST, MII_CR, lp->phy[k].addr, DE4X5_MII); |
| 5096 | while (mii_rd(MII_CR, lp->phy[k].addr, DE4X5_MII) & MII_CR_RST); | 5096 | while (mii_rd(MII_CR, lp->phy[k].addr, DE4X5_MII) & MII_CR_RST); |
| 5097 | 5097 | ||
diff --git a/drivers/net/tulip/tulip_core.c b/drivers/net/tulip/tulip_core.c index 99a63649f4fc..4cf9a6588751 100644 --- a/drivers/net/tulip/tulip_core.c +++ b/drivers/net/tulip/tulip_core.c | |||
| @@ -652,8 +652,9 @@ tulip_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 652 | int entry; | 652 | int entry; |
| 653 | u32 flag; | 653 | u32 flag; |
| 654 | dma_addr_t mapping; | 654 | dma_addr_t mapping; |
| 655 | unsigned long flags; | ||
| 655 | 656 | ||
| 656 | spin_lock_irq(&tp->lock); | 657 | spin_lock_irqsave(&tp->lock, flags); |
| 657 | 658 | ||
| 658 | /* Calculate the next Tx descriptor entry. */ | 659 | /* Calculate the next Tx descriptor entry. */ |
| 659 | entry = tp->cur_tx % TX_RING_SIZE; | 660 | entry = tp->cur_tx % TX_RING_SIZE; |
| @@ -688,7 +689,7 @@ tulip_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 688 | /* Trigger an immediate transmit demand. */ | 689 | /* Trigger an immediate transmit demand. */ |
| 689 | iowrite32(0, tp->base_addr + CSR1); | 690 | iowrite32(0, tp->base_addr + CSR1); |
| 690 | 691 | ||
| 691 | spin_unlock_irq(&tp->lock); | 692 | spin_unlock_irqrestore(&tp->lock, flags); |
| 692 | 693 | ||
| 693 | dev->trans_start = jiffies; | 694 | dev->trans_start = jiffies; |
| 694 | 695 | ||
diff --git a/drivers/net/tun.c b/drivers/net/tun.c index 027f7aba26af..42b6c6319bc2 100644 --- a/drivers/net/tun.c +++ b/drivers/net/tun.c | |||
| @@ -1048,20 +1048,15 @@ static int tun_set_iff(struct net *net, struct file *file, struct ifreq *ifr) | |||
| 1048 | return err; | 1048 | return err; |
| 1049 | } | 1049 | } |
| 1050 | 1050 | ||
| 1051 | static int tun_get_iff(struct net *net, struct file *file, struct ifreq *ifr) | 1051 | static int tun_get_iff(struct net *net, struct tun_struct *tun, |
| 1052 | struct ifreq *ifr) | ||
| 1052 | { | 1053 | { |
| 1053 | struct tun_struct *tun = tun_get(file); | ||
| 1054 | |||
| 1055 | if (!tun) | ||
| 1056 | return -EBADFD; | ||
| 1057 | |||
| 1058 | DBG(KERN_INFO "%s: tun_get_iff\n", tun->dev->name); | 1054 | DBG(KERN_INFO "%s: tun_get_iff\n", tun->dev->name); |
| 1059 | 1055 | ||
| 1060 | strcpy(ifr->ifr_name, tun->dev->name); | 1056 | strcpy(ifr->ifr_name, tun->dev->name); |
| 1061 | 1057 | ||
| 1062 | ifr->ifr_flags = tun_flags(tun); | 1058 | ifr->ifr_flags = tun_flags(tun); |
| 1063 | 1059 | ||
| 1064 | tun_put(tun); | ||
| 1065 | return 0; | 1060 | return 0; |
| 1066 | } | 1061 | } |
| 1067 | 1062 | ||
| @@ -1105,8 +1100,8 @@ static int set_offload(struct net_device *dev, unsigned long arg) | |||
| 1105 | return 0; | 1100 | return 0; |
| 1106 | } | 1101 | } |
| 1107 | 1102 | ||
| 1108 | static int tun_chr_ioctl(struct inode *inode, struct file *file, | 1103 | static long tun_chr_ioctl(struct file *file, unsigned int cmd, |
| 1109 | unsigned int cmd, unsigned long arg) | 1104 | unsigned long arg) |
| 1110 | { | 1105 | { |
| 1111 | struct tun_file *tfile = file->private_data; | 1106 | struct tun_file *tfile = file->private_data; |
| 1112 | struct tun_struct *tun; | 1107 | struct tun_struct *tun; |
| @@ -1128,34 +1123,32 @@ static int tun_chr_ioctl(struct inode *inode, struct file *file, | |||
| 1128 | (unsigned int __user*)argp); | 1123 | (unsigned int __user*)argp); |
| 1129 | } | 1124 | } |
| 1130 | 1125 | ||
| 1126 | rtnl_lock(); | ||
| 1127 | |||
| 1131 | tun = __tun_get(tfile); | 1128 | tun = __tun_get(tfile); |
| 1132 | if (cmd == TUNSETIFF && !tun) { | 1129 | if (cmd == TUNSETIFF && !tun) { |
| 1133 | int err; | ||
| 1134 | |||
| 1135 | ifr.ifr_name[IFNAMSIZ-1] = '\0'; | 1130 | ifr.ifr_name[IFNAMSIZ-1] = '\0'; |
| 1136 | 1131 | ||
| 1137 | rtnl_lock(); | 1132 | ret = tun_set_iff(tfile->net, file, &ifr); |
| 1138 | err = tun_set_iff(tfile->net, file, &ifr); | ||
| 1139 | rtnl_unlock(); | ||
| 1140 | 1133 | ||
| 1141 | if (err) | 1134 | if (ret) |
| 1142 | return err; | 1135 | goto unlock; |
| 1143 | 1136 | ||
| 1144 | if (copy_to_user(argp, &ifr, sizeof(ifr))) | 1137 | if (copy_to_user(argp, &ifr, sizeof(ifr))) |
| 1145 | return -EFAULT; | 1138 | ret = -EFAULT; |
| 1146 | return 0; | 1139 | goto unlock; |
| 1147 | } | 1140 | } |
| 1148 | 1141 | ||
| 1149 | 1142 | ret = -EBADFD; | |
| 1150 | if (!tun) | 1143 | if (!tun) |
| 1151 | return -EBADFD; | 1144 | goto unlock; |
| 1152 | 1145 | ||
| 1153 | DBG(KERN_INFO "%s: tun_chr_ioctl cmd %d\n", tun->dev->name, cmd); | 1146 | DBG(KERN_INFO "%s: tun_chr_ioctl cmd %d\n", tun->dev->name, cmd); |
| 1154 | 1147 | ||
| 1155 | ret = 0; | 1148 | ret = 0; |
| 1156 | switch (cmd) { | 1149 | switch (cmd) { |
| 1157 | case TUNGETIFF: | 1150 | case TUNGETIFF: |
| 1158 | ret = tun_get_iff(current->nsproxy->net_ns, file, &ifr); | 1151 | ret = tun_get_iff(current->nsproxy->net_ns, tun, &ifr); |
| 1159 | if (ret) | 1152 | if (ret) |
| 1160 | break; | 1153 | break; |
| 1161 | 1154 | ||
| @@ -1201,7 +1194,6 @@ static int tun_chr_ioctl(struct inode *inode, struct file *file, | |||
| 1201 | 1194 | ||
| 1202 | case TUNSETLINK: | 1195 | case TUNSETLINK: |
| 1203 | /* Only allow setting the type when the interface is down */ | 1196 | /* Only allow setting the type when the interface is down */ |
| 1204 | rtnl_lock(); | ||
| 1205 | if (tun->dev->flags & IFF_UP) { | 1197 | if (tun->dev->flags & IFF_UP) { |
| 1206 | DBG(KERN_INFO "%s: Linktype set failed because interface is up\n", | 1198 | DBG(KERN_INFO "%s: Linktype set failed because interface is up\n", |
| 1207 | tun->dev->name); | 1199 | tun->dev->name); |
| @@ -1211,7 +1203,6 @@ static int tun_chr_ioctl(struct inode *inode, struct file *file, | |||
| 1211 | DBG(KERN_INFO "%s: linktype set to %d\n", tun->dev->name, tun->dev->type); | 1203 | DBG(KERN_INFO "%s: linktype set to %d\n", tun->dev->name, tun->dev->type); |
| 1212 | ret = 0; | 1204 | ret = 0; |
| 1213 | } | 1205 | } |
| 1214 | rtnl_unlock(); | ||
| 1215 | break; | 1206 | break; |
| 1216 | 1207 | ||
| 1217 | #ifdef TUN_DEBUG | 1208 | #ifdef TUN_DEBUG |
| @@ -1220,9 +1211,7 @@ static int tun_chr_ioctl(struct inode *inode, struct file *file, | |||
| 1220 | break; | 1211 | break; |
| 1221 | #endif | 1212 | #endif |
| 1222 | case TUNSETOFFLOAD: | 1213 | case TUNSETOFFLOAD: |
| 1223 | rtnl_lock(); | ||
| 1224 | ret = set_offload(tun->dev, arg); | 1214 | ret = set_offload(tun->dev, arg); |
| 1225 | rtnl_unlock(); | ||
| 1226 | break; | 1215 | break; |
| 1227 | 1216 | ||
| 1228 | case TUNSETTXFILTER: | 1217 | case TUNSETTXFILTER: |
| @@ -1230,9 +1219,7 @@ static int tun_chr_ioctl(struct inode *inode, struct file *file, | |||
| 1230 | ret = -EINVAL; | 1219 | ret = -EINVAL; |
| 1231 | if ((tun->flags & TUN_TYPE_MASK) != TUN_TAP_DEV) | 1220 | if ((tun->flags & TUN_TYPE_MASK) != TUN_TAP_DEV) |
| 1232 | break; | 1221 | break; |
| 1233 | rtnl_lock(); | ||
| 1234 | ret = update_filter(&tun->txflt, (void __user *)arg); | 1222 | ret = update_filter(&tun->txflt, (void __user *)arg); |
| 1235 | rtnl_unlock(); | ||
| 1236 | break; | 1223 | break; |
| 1237 | 1224 | ||
| 1238 | case SIOCGIFHWADDR: | 1225 | case SIOCGIFHWADDR: |
| @@ -1248,9 +1235,7 @@ static int tun_chr_ioctl(struct inode *inode, struct file *file, | |||
| 1248 | DBG(KERN_DEBUG "%s: set hw address: %pM\n", | 1235 | DBG(KERN_DEBUG "%s: set hw address: %pM\n", |
| 1249 | tun->dev->name, ifr.ifr_hwaddr.sa_data); | 1236 | tun->dev->name, ifr.ifr_hwaddr.sa_data); |
| 1250 | 1237 | ||
| 1251 | rtnl_lock(); | ||
| 1252 | ret = dev_set_mac_address(tun->dev, &ifr.ifr_hwaddr); | 1238 | ret = dev_set_mac_address(tun->dev, &ifr.ifr_hwaddr); |
| 1253 | rtnl_unlock(); | ||
| 1254 | break; | 1239 | break; |
| 1255 | 1240 | ||
| 1256 | case TUNGETSNDBUF: | 1241 | case TUNGETSNDBUF: |
| @@ -1273,7 +1258,10 @@ static int tun_chr_ioctl(struct inode *inode, struct file *file, | |||
| 1273 | break; | 1258 | break; |
| 1274 | }; | 1259 | }; |
| 1275 | 1260 | ||
| 1276 | tun_put(tun); | 1261 | unlock: |
| 1262 | rtnl_unlock(); | ||
| 1263 | if (tun) | ||
| 1264 | tun_put(tun); | ||
| 1277 | return ret; | 1265 | return ret; |
| 1278 | } | 1266 | } |
| 1279 | 1267 | ||
| @@ -1361,7 +1349,7 @@ static const struct file_operations tun_fops = { | |||
| 1361 | .write = do_sync_write, | 1349 | .write = do_sync_write, |
| 1362 | .aio_write = tun_chr_aio_write, | 1350 | .aio_write = tun_chr_aio_write, |
| 1363 | .poll = tun_chr_poll, | 1351 | .poll = tun_chr_poll, |
| 1364 | .ioctl = tun_chr_ioctl, | 1352 | .unlocked_ioctl = tun_chr_ioctl, |
| 1365 | .open = tun_chr_open, | 1353 | .open = tun_chr_open, |
| 1366 | .release = tun_chr_close, | 1354 | .release = tun_chr_close, |
| 1367 | .fasync = tun_chr_fasync | 1355 | .fasync = tun_chr_fasync |
diff --git a/drivers/net/ucc_geth.c b/drivers/net/ucc_geth.c index 40c6eba775ce..8a7b8c7bd781 100644 --- a/drivers/net/ucc_geth.c +++ b/drivers/net/ucc_geth.c | |||
| @@ -1590,13 +1590,13 @@ static int init_phy(struct net_device *dev) | |||
| 1590 | priv->oldspeed = 0; | 1590 | priv->oldspeed = 0; |
| 1591 | priv->oldduplex = -1; | 1591 | priv->oldduplex = -1; |
| 1592 | 1592 | ||
| 1593 | if (!ug_info->phy_node) | ||
| 1594 | return 0; | ||
| 1595 | |||
| 1596 | phydev = of_phy_connect(dev, ug_info->phy_node, &adjust_link, 0, | 1593 | phydev = of_phy_connect(dev, ug_info->phy_node, &adjust_link, 0, |
| 1597 | priv->phy_interface); | 1594 | priv->phy_interface); |
| 1595 | if (!phydev) | ||
| 1596 | phydev = of_phy_connect_fixed_link(dev, &adjust_link, | ||
| 1597 | priv->phy_interface); | ||
| 1598 | if (!phydev) { | 1598 | if (!phydev) { |
| 1599 | printk("%s: Could not attach to PHY\n", dev->name); | 1599 | dev_err(&dev->dev, "Could not attach to PHY\n"); |
| 1600 | return -ENODEV; | 1600 | return -ENODEV; |
| 1601 | } | 1601 | } |
| 1602 | 1602 | ||
| @@ -3111,10 +3111,11 @@ static int ucc_geth_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 3111 | u8 __iomem *bd; /* BD pointer */ | 3111 | u8 __iomem *bd; /* BD pointer */ |
| 3112 | u32 bd_status; | 3112 | u32 bd_status; |
| 3113 | u8 txQ = 0; | 3113 | u8 txQ = 0; |
| 3114 | unsigned long flags; | ||
| 3114 | 3115 | ||
| 3115 | ugeth_vdbg("%s: IN", __func__); | 3116 | ugeth_vdbg("%s: IN", __func__); |
| 3116 | 3117 | ||
| 3117 | spin_lock_irq(&ugeth->lock); | 3118 | spin_lock_irqsave(&ugeth->lock, flags); |
| 3118 | 3119 | ||
| 3119 | dev->stats.tx_bytes += skb->len; | 3120 | dev->stats.tx_bytes += skb->len; |
| 3120 | 3121 | ||
| @@ -3171,7 +3172,7 @@ static int ucc_geth_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 3171 | uccf = ugeth->uccf; | 3172 | uccf = ugeth->uccf; |
| 3172 | out_be16(uccf->p_utodr, UCC_FAST_TOD); | 3173 | out_be16(uccf->p_utodr, UCC_FAST_TOD); |
| 3173 | #endif | 3174 | #endif |
| 3174 | spin_unlock_irq(&ugeth->lock); | 3175 | spin_unlock_irqrestore(&ugeth->lock, flags); |
| 3175 | 3176 | ||
| 3176 | return 0; | 3177 | return 0; |
| 3177 | } | 3178 | } |
| @@ -3608,9 +3609,7 @@ static int ucc_geth_probe(struct of_device* ofdev, const struct of_device_id *ma | |||
| 3608 | struct ucc_geth_private *ugeth = NULL; | 3609 | struct ucc_geth_private *ugeth = NULL; |
| 3609 | struct ucc_geth_info *ug_info; | 3610 | struct ucc_geth_info *ug_info; |
| 3610 | struct resource res; | 3611 | struct resource res; |
| 3611 | struct device_node *phy; | ||
| 3612 | int err, ucc_num, max_speed = 0; | 3612 | int err, ucc_num, max_speed = 0; |
| 3613 | const u32 *fixed_link; | ||
| 3614 | const unsigned int *prop; | 3613 | const unsigned int *prop; |
| 3615 | const char *sprop; | 3614 | const char *sprop; |
| 3616 | const void *mac_addr; | 3615 | const void *mac_addr; |
| @@ -3708,15 +3707,8 @@ static int ucc_geth_probe(struct of_device* ofdev, const struct of_device_id *ma | |||
| 3708 | 3707 | ||
| 3709 | ug_info->uf_info.regs = res.start; | 3708 | ug_info->uf_info.regs = res.start; |
| 3710 | ug_info->uf_info.irq = irq_of_parse_and_map(np, 0); | 3709 | ug_info->uf_info.irq = irq_of_parse_and_map(np, 0); |
| 3711 | fixed_link = of_get_property(np, "fixed-link", NULL); | 3710 | |
| 3712 | if (fixed_link) { | 3711 | ug_info->phy_node = of_parse_phandle(np, "phy-handle", 0); |
| 3713 | phy = NULL; | ||
| 3714 | } else { | ||
| 3715 | phy = of_parse_phandle(np, "phy-handle", 0); | ||
| 3716 | if (phy == NULL) | ||
| 3717 | return -ENODEV; | ||
| 3718 | } | ||
| 3719 | ug_info->phy_node = phy; | ||
| 3720 | 3712 | ||
| 3721 | /* Find the TBI PHY node. If it's not there, we don't support SGMII */ | 3713 | /* Find the TBI PHY node. If it's not there, we don't support SGMII */ |
| 3722 | ug_info->tbi_node = of_parse_phandle(np, "tbi-handle", 0); | 3714 | ug_info->tbi_node = of_parse_phandle(np, "tbi-handle", 0); |
| @@ -3725,7 +3717,7 @@ static int ucc_geth_probe(struct of_device* ofdev, const struct of_device_id *ma | |||
| 3725 | prop = of_get_property(np, "phy-connection-type", NULL); | 3717 | prop = of_get_property(np, "phy-connection-type", NULL); |
| 3726 | if (!prop) { | 3718 | if (!prop) { |
| 3727 | /* handle interface property present in old trees */ | 3719 | /* handle interface property present in old trees */ |
| 3728 | prop = of_get_property(phy, "interface", NULL); | 3720 | prop = of_get_property(ug_info->phy_node, "interface", NULL); |
| 3729 | if (prop != NULL) { | 3721 | if (prop != NULL) { |
| 3730 | phy_interface = enet_to_phy_interface[*prop]; | 3722 | phy_interface = enet_to_phy_interface[*prop]; |
| 3731 | max_speed = enet_to_speed[*prop]; | 3723 | max_speed = enet_to_speed[*prop]; |
diff --git a/drivers/net/usb/Kconfig b/drivers/net/usb/Kconfig index a906d3998131..c47237c2d638 100644 --- a/drivers/net/usb/Kconfig +++ b/drivers/net/usb/Kconfig | |||
| @@ -369,4 +369,12 @@ config USB_NET_INT51X1 | |||
| 369 | (Powerline Communications) solution with an Intellon | 369 | (Powerline Communications) solution with an Intellon |
| 370 | INT51x1/INT5200 chip, like the "devolo dLan duo". | 370 | INT51x1/INT5200 chip, like the "devolo dLan duo". |
| 371 | 371 | ||
| 372 | config USB_CDC_PHONET | ||
| 373 | tristate "CDC Phonet support" | ||
| 374 | depends on PHONET | ||
| 375 | help | ||
| 376 | Choose this option to support the Phonet interface to a Nokia | ||
| 377 | cellular modem, as found on most Nokia handsets with the | ||
| 378 | "PC suite" USB profile. | ||
| 379 | |||
| 372 | endmenu | 380 | endmenu |
diff --git a/drivers/net/usb/Makefile b/drivers/net/usb/Makefile index b870b0b1cbe0..e17afb78f372 100644 --- a/drivers/net/usb/Makefile +++ b/drivers/net/usb/Makefile | |||
| @@ -21,4 +21,5 @@ obj-$(CONFIG_USB_NET_ZAURUS) += zaurus.o | |||
| 21 | obj-$(CONFIG_USB_NET_MCS7830) += mcs7830.o | 21 | obj-$(CONFIG_USB_NET_MCS7830) += mcs7830.o |
| 22 | obj-$(CONFIG_USB_USBNET) += usbnet.o | 22 | obj-$(CONFIG_USB_USBNET) += usbnet.o |
| 23 | obj-$(CONFIG_USB_NET_INT51X1) += int51x1.o | 23 | obj-$(CONFIG_USB_NET_INT51X1) += int51x1.o |
| 24 | obj-$(CONFIG_USB_CDC_PHONET) += cdc-phonet.o | ||
| 24 | 25 | ||
diff --git a/drivers/net/usb/cdc-phonet.c b/drivers/net/usb/cdc-phonet.c new file mode 100644 index 000000000000..792af72da8ac --- /dev/null +++ b/drivers/net/usb/cdc-phonet.c | |||
| @@ -0,0 +1,461 @@ | |||
| 1 | /* | ||
| 2 | * phonet.c -- USB CDC Phonet host driver | ||
| 3 | * | ||
| 4 | * Copyright (C) 2008-2009 Nokia Corporation. All rights reserved. | ||
| 5 | * | ||
| 6 | * Author: Rémi Denis-Courmont | ||
| 7 | * | ||
| 8 | * This program is free software; you can redistribute it and/or | ||
| 9 | * modify it under the terms of the GNU General Public License | ||
| 10 | * version 2 as published by the Free Software Foundation. | ||
| 11 | * | ||
| 12 | * This program is distributed in the hope that it will be useful, but | ||
| 13 | * WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. Â See the GNU | ||
| 15 | * General Public License for more details. | ||
| 16 | * | ||
| 17 | * You should have received a copy of the GNU General Public License | ||
| 18 | * along with this program; if not, write to the Free Software | ||
| 19 | * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA | ||
| 20 | * 02110-1301 USA | ||
| 21 | */ | ||
| 22 | |||
| 23 | #include <linux/kernel.h> | ||
| 24 | #include <linux/module.h> | ||
| 25 | #include <linux/usb.h> | ||
| 26 | #include <linux/usb/cdc.h> | ||
| 27 | #include <linux/netdevice.h> | ||
| 28 | #include <linux/if_arp.h> | ||
| 29 | #include <linux/if_phonet.h> | ||
| 30 | |||
| 31 | #define PN_MEDIA_USB 0x1B | ||
| 32 | |||
| 33 | static const unsigned rxq_size = 17; | ||
| 34 | |||
| 35 | struct usbpn_dev { | ||
| 36 | struct net_device *dev; | ||
| 37 | |||
| 38 | struct usb_interface *intf, *data_intf; | ||
| 39 | struct usb_device *usb; | ||
| 40 | unsigned int tx_pipe, rx_pipe; | ||
| 41 | u8 active_setting; | ||
| 42 | u8 disconnected; | ||
| 43 | |||
| 44 | unsigned tx_queue; | ||
| 45 | spinlock_t tx_lock; | ||
| 46 | |||
| 47 | spinlock_t rx_lock; | ||
| 48 | struct sk_buff *rx_skb; | ||
| 49 | struct urb *urbs[0]; | ||
| 50 | }; | ||
| 51 | |||
| 52 | static void tx_complete(struct urb *req); | ||
| 53 | static void rx_complete(struct urb *req); | ||
| 54 | |||
| 55 | /* | ||
| 56 | * Network device callbacks | ||
| 57 | */ | ||
| 58 | static int usbpn_xmit(struct sk_buff *skb, struct net_device *dev) | ||
| 59 | { | ||
| 60 | struct usbpn_dev *pnd = netdev_priv(dev); | ||
| 61 | struct urb *req = NULL; | ||
| 62 | unsigned long flags; | ||
| 63 | int err; | ||
| 64 | |||
| 65 | if (skb->protocol != htons(ETH_P_PHONET)) | ||
| 66 | goto drop; | ||
| 67 | |||
| 68 | req = usb_alloc_urb(0, GFP_ATOMIC); | ||
| 69 | if (!req) | ||
| 70 | goto drop; | ||
| 71 | usb_fill_bulk_urb(req, pnd->usb, pnd->tx_pipe, skb->data, skb->len, | ||
| 72 | tx_complete, skb); | ||
| 73 | req->transfer_flags = URB_ZERO_PACKET; | ||
| 74 | err = usb_submit_urb(req, GFP_ATOMIC); | ||
| 75 | if (err) { | ||
| 76 | usb_free_urb(req); | ||
| 77 | goto drop; | ||
| 78 | } | ||
| 79 | |||
| 80 | spin_lock_irqsave(&pnd->tx_lock, flags); | ||
| 81 | pnd->tx_queue++; | ||
| 82 | if (pnd->tx_queue >= dev->tx_queue_len) | ||
| 83 | netif_stop_queue(dev); | ||
| 84 | spin_unlock_irqrestore(&pnd->tx_lock, flags); | ||
| 85 | return 0; | ||
| 86 | |||
| 87 | drop: | ||
| 88 | dev_kfree_skb(skb); | ||
| 89 | dev->stats.tx_dropped++; | ||
| 90 | return 0; | ||
| 91 | } | ||
| 92 | |||
| 93 | static void tx_complete(struct urb *req) | ||
| 94 | { | ||
| 95 | struct sk_buff *skb = req->context; | ||
| 96 | struct net_device *dev = skb->dev; | ||
| 97 | struct usbpn_dev *pnd = netdev_priv(dev); | ||
| 98 | |||
| 99 | switch (req->status) { | ||
| 100 | case 0: | ||
| 101 | dev->stats.tx_bytes += skb->len; | ||
| 102 | break; | ||
| 103 | |||
| 104 | case -ENOENT: | ||
| 105 | case -ECONNRESET: | ||
| 106 | case -ESHUTDOWN: | ||
| 107 | dev->stats.tx_aborted_errors++; | ||
| 108 | default: | ||
| 109 | dev->stats.tx_errors++; | ||
| 110 | dev_dbg(&dev->dev, "TX error (%d)\n", req->status); | ||
| 111 | } | ||
| 112 | dev->stats.tx_packets++; | ||
| 113 | |||
| 114 | spin_lock(&pnd->tx_lock); | ||
| 115 | pnd->tx_queue--; | ||
| 116 | netif_wake_queue(dev); | ||
| 117 | spin_unlock(&pnd->tx_lock); | ||
| 118 | |||
| 119 | dev_kfree_skb_any(skb); | ||
| 120 | usb_free_urb(req); | ||
| 121 | } | ||
| 122 | |||
| 123 | static int rx_submit(struct usbpn_dev *pnd, struct urb *req, gfp_t gfp_flags) | ||
| 124 | { | ||
| 125 | struct net_device *dev = pnd->dev; | ||
| 126 | struct page *page; | ||
| 127 | int err; | ||
| 128 | |||
| 129 | page = __netdev_alloc_page(dev, gfp_flags); | ||
| 130 | if (!page) | ||
| 131 | return -ENOMEM; | ||
| 132 | |||
| 133 | usb_fill_bulk_urb(req, pnd->usb, pnd->rx_pipe, page_address(page), | ||
| 134 | PAGE_SIZE, rx_complete, dev); | ||
| 135 | req->transfer_flags = 0; | ||
| 136 | err = usb_submit_urb(req, gfp_flags); | ||
| 137 | if (unlikely(err)) { | ||
| 138 | dev_dbg(&dev->dev, "RX submit error (%d)\n", err); | ||
| 139 | netdev_free_page(dev, page); | ||
| 140 | } | ||
| 141 | return err; | ||
| 142 | } | ||
| 143 | |||
| 144 | static void rx_complete(struct urb *req) | ||
| 145 | { | ||
| 146 | struct net_device *dev = req->context; | ||
| 147 | struct usbpn_dev *pnd = netdev_priv(dev); | ||
| 148 | struct page *page = virt_to_page(req->transfer_buffer); | ||
| 149 | struct sk_buff *skb; | ||
| 150 | unsigned long flags; | ||
| 151 | |||
| 152 | switch (req->status) { | ||
| 153 | case 0: | ||
| 154 | spin_lock_irqsave(&pnd->rx_lock, flags); | ||
| 155 | skb = pnd->rx_skb; | ||
| 156 | if (!skb) { | ||
| 157 | skb = pnd->rx_skb = netdev_alloc_skb(dev, 12); | ||
| 158 | if (likely(skb)) { | ||
| 159 | /* Can't use pskb_pull() on page in IRQ */ | ||
| 160 | memcpy(skb_put(skb, 1), page_address(page), 1); | ||
| 161 | skb_add_rx_frag(skb, skb_shinfo(skb)->nr_frags, | ||
| 162 | page, 1, req->actual_length); | ||
| 163 | page = NULL; | ||
| 164 | } | ||
| 165 | } else { | ||
| 166 | skb_add_rx_frag(skb, skb_shinfo(skb)->nr_frags, | ||
| 167 | page, 0, req->actual_length); | ||
| 168 | page = NULL; | ||
| 169 | } | ||
| 170 | if (req->actual_length < PAGE_SIZE) | ||
| 171 | pnd->rx_skb = NULL; /* Last fragment */ | ||
| 172 | else | ||
| 173 | skb = NULL; | ||
| 174 | spin_unlock_irqrestore(&pnd->rx_lock, flags); | ||
| 175 | if (skb) { | ||
| 176 | skb->protocol = htons(ETH_P_PHONET); | ||
| 177 | skb_reset_mac_header(skb); | ||
| 178 | __skb_pull(skb, 1); | ||
| 179 | skb->dev = dev; | ||
| 180 | dev->stats.rx_packets++; | ||
| 181 | dev->stats.rx_bytes += skb->len; | ||
| 182 | |||
| 183 | netif_rx(skb); | ||
| 184 | } | ||
| 185 | goto resubmit; | ||
| 186 | |||
| 187 | case -ENOENT: | ||
| 188 | case -ECONNRESET: | ||
| 189 | case -ESHUTDOWN: | ||
| 190 | req = NULL; | ||
| 191 | break; | ||
| 192 | |||
| 193 | case -EOVERFLOW: | ||
| 194 | dev->stats.rx_over_errors++; | ||
| 195 | dev_dbg(&dev->dev, "RX overflow\n"); | ||
| 196 | break; | ||
| 197 | |||
| 198 | case -EILSEQ: | ||
| 199 | dev->stats.rx_crc_errors++; | ||
| 200 | break; | ||
| 201 | } | ||
| 202 | |||
| 203 | dev->stats.rx_errors++; | ||
| 204 | resubmit: | ||
| 205 | if (page) | ||
| 206 | netdev_free_page(dev, page); | ||
| 207 | if (req) | ||
| 208 | rx_submit(pnd, req, GFP_ATOMIC); | ||
| 209 | } | ||
| 210 | |||
| 211 | static int usbpn_close(struct net_device *dev); | ||
| 212 | |||
| 213 | static int usbpn_open(struct net_device *dev) | ||
| 214 | { | ||
| 215 | struct usbpn_dev *pnd = netdev_priv(dev); | ||
| 216 | int err; | ||
| 217 | unsigned i; | ||
| 218 | unsigned num = pnd->data_intf->cur_altsetting->desc.bInterfaceNumber; | ||
| 219 | |||
| 220 | err = usb_set_interface(pnd->usb, num, pnd->active_setting); | ||
| 221 | if (err) | ||
| 222 | return err; | ||
| 223 | |||
| 224 | for (i = 0; i < rxq_size; i++) { | ||
| 225 | struct urb *req = usb_alloc_urb(0, GFP_KERNEL); | ||
| 226 | |||
| 227 | if (!req || rx_submit(pnd, req, GFP_KERNEL)) { | ||
| 228 | usbpn_close(dev); | ||
| 229 | return -ENOMEM; | ||
| 230 | } | ||
| 231 | pnd->urbs[i] = req; | ||
| 232 | } | ||
| 233 | |||
| 234 | netif_wake_queue(dev); | ||
| 235 | return 0; | ||
| 236 | } | ||
| 237 | |||
| 238 | static int usbpn_close(struct net_device *dev) | ||
| 239 | { | ||
| 240 | struct usbpn_dev *pnd = netdev_priv(dev); | ||
| 241 | unsigned i; | ||
| 242 | unsigned num = pnd->data_intf->cur_altsetting->desc.bInterfaceNumber; | ||
| 243 | |||
| 244 | netif_stop_queue(dev); | ||
| 245 | |||
| 246 | for (i = 0; i < rxq_size; i++) { | ||
| 247 | struct urb *req = pnd->urbs[i]; | ||
| 248 | |||
| 249 | if (!req) | ||
| 250 | continue; | ||
| 251 | usb_kill_urb(req); | ||
| 252 | usb_free_urb(req); | ||
| 253 | pnd->urbs[i] = NULL; | ||
| 254 | } | ||
| 255 | |||
| 256 | return usb_set_interface(pnd->usb, num, !pnd->active_setting); | ||
| 257 | } | ||
| 258 | |||
| 259 | static int usbpn_set_mtu(struct net_device *dev, int new_mtu) | ||
| 260 | { | ||
| 261 | if ((new_mtu < PHONET_MIN_MTU) || (new_mtu > PHONET_MAX_MTU)) | ||
| 262 | return -EINVAL; | ||
| 263 | |||
| 264 | dev->mtu = new_mtu; | ||
| 265 | return 0; | ||
| 266 | } | ||
| 267 | |||
| 268 | static const struct net_device_ops usbpn_ops = { | ||
| 269 | .ndo_open = usbpn_open, | ||
| 270 | .ndo_stop = usbpn_close, | ||
| 271 | .ndo_start_xmit = usbpn_xmit, | ||
| 272 | .ndo_change_mtu = usbpn_set_mtu, | ||
| 273 | }; | ||
| 274 | |||
| 275 | static void usbpn_setup(struct net_device *dev) | ||
| 276 | { | ||
| 277 | dev->features = 0; | ||
| 278 | dev->netdev_ops = &usbpn_ops, | ||
| 279 | dev->header_ops = &phonet_header_ops; | ||
| 280 | dev->type = ARPHRD_PHONET; | ||
| 281 | dev->flags = IFF_POINTOPOINT | IFF_NOARP; | ||
| 282 | dev->mtu = PHONET_MAX_MTU; | ||
| 283 | dev->hard_header_len = 1; | ||
| 284 | dev->dev_addr[0] = PN_MEDIA_USB; | ||
| 285 | dev->addr_len = 1; | ||
| 286 | dev->tx_queue_len = 3; | ||
| 287 | |||
| 288 | dev->destructor = free_netdev; | ||
| 289 | } | ||
| 290 | |||
| 291 | /* | ||
| 292 | * USB driver callbacks | ||
| 293 | */ | ||
| 294 | static struct usb_device_id usbpn_ids[] = { | ||
| 295 | { | ||
| 296 | .match_flags = USB_DEVICE_ID_MATCH_VENDOR | ||
| 297 | | USB_DEVICE_ID_MATCH_INT_CLASS | ||
| 298 | | USB_DEVICE_ID_MATCH_INT_SUBCLASS, | ||
| 299 | .idVendor = 0x0421, /* Nokia */ | ||
| 300 | .bInterfaceClass = USB_CLASS_COMM, | ||
| 301 | .bInterfaceSubClass = 0xFE, | ||
| 302 | }, | ||
| 303 | { }, | ||
| 304 | }; | ||
| 305 | |||
| 306 | MODULE_DEVICE_TABLE(usb, usbpn_ids); | ||
| 307 | |||
| 308 | static struct usb_driver usbpn_driver; | ||
| 309 | |||
| 310 | int usbpn_probe(struct usb_interface *intf, const struct usb_device_id *id) | ||
| 311 | { | ||
| 312 | static const char ifname[] = "usbpn%d"; | ||
| 313 | const struct usb_cdc_union_desc *union_header = NULL; | ||
| 314 | const struct usb_cdc_header_desc *phonet_header = NULL; | ||
| 315 | const struct usb_host_interface *data_desc; | ||
| 316 | struct usb_interface *data_intf; | ||
| 317 | struct usb_device *usbdev = interface_to_usbdev(intf); | ||
| 318 | struct net_device *dev; | ||
| 319 | struct usbpn_dev *pnd; | ||
| 320 | u8 *data; | ||
| 321 | int len, err; | ||
| 322 | |||
| 323 | data = intf->altsetting->extra; | ||
| 324 | len = intf->altsetting->extralen; | ||
| 325 | while (len >= 3) { | ||
| 326 | u8 dlen = data[0]; | ||
| 327 | if (dlen < 3) | ||
| 328 | return -EINVAL; | ||
| 329 | |||
| 330 | /* bDescriptorType */ | ||
| 331 | if (data[1] == USB_DT_CS_INTERFACE) { | ||
| 332 | /* bDescriptorSubType */ | ||
| 333 | switch (data[2]) { | ||
| 334 | case USB_CDC_UNION_TYPE: | ||
| 335 | if (union_header || dlen < 5) | ||
| 336 | break; | ||
| 337 | union_header = | ||
| 338 | (struct usb_cdc_union_desc *)data; | ||
| 339 | break; | ||
| 340 | case 0xAB: | ||
| 341 | if (phonet_header || dlen < 5) | ||
| 342 | break; | ||
| 343 | phonet_header = | ||
| 344 | (struct usb_cdc_header_desc *)data; | ||
| 345 | break; | ||
| 346 | } | ||
| 347 | } | ||
| 348 | data += dlen; | ||
| 349 | len -= dlen; | ||
| 350 | } | ||
| 351 | |||
| 352 | if (!union_header || !phonet_header) | ||
| 353 | return -EINVAL; | ||
| 354 | |||
| 355 | data_intf = usb_ifnum_to_if(usbdev, union_header->bSlaveInterface0); | ||
| 356 | if (data_intf == NULL) | ||
| 357 | return -ENODEV; | ||
| 358 | /* Data interface has one inactive and one active setting */ | ||
| 359 | if (data_intf->num_altsetting != 2) | ||
| 360 | return -EINVAL; | ||
| 361 | if (data_intf->altsetting[0].desc.bNumEndpoints == 0 | ||
| 362 | && data_intf->altsetting[1].desc.bNumEndpoints == 2) | ||
| 363 | data_desc = data_intf->altsetting + 1; | ||
| 364 | else | ||
| 365 | if (data_intf->altsetting[0].desc.bNumEndpoints == 2 | ||
| 366 | && data_intf->altsetting[1].desc.bNumEndpoints == 0) | ||
| 367 | data_desc = data_intf->altsetting; | ||
| 368 | else | ||
| 369 | return -EINVAL; | ||
| 370 | |||
| 371 | dev = alloc_netdev(sizeof(*pnd) + sizeof(pnd->urbs[0]) * rxq_size, | ||
| 372 | ifname, usbpn_setup); | ||
| 373 | if (!dev) | ||
| 374 | return -ENOMEM; | ||
| 375 | |||
| 376 | pnd = netdev_priv(dev); | ||
| 377 | SET_NETDEV_DEV(dev, &intf->dev); | ||
| 378 | netif_stop_queue(dev); | ||
| 379 | |||
| 380 | pnd->dev = dev; | ||
| 381 | pnd->usb = usb_get_dev(usbdev); | ||
| 382 | pnd->intf = intf; | ||
| 383 | pnd->data_intf = data_intf; | ||
| 384 | spin_lock_init(&pnd->tx_lock); | ||
| 385 | spin_lock_init(&pnd->rx_lock); | ||
| 386 | /* Endpoints */ | ||
| 387 | if (usb_pipein(data_desc->endpoint[0].desc.bEndpointAddress)) { | ||
| 388 | pnd->rx_pipe = usb_rcvbulkpipe(usbdev, | ||
| 389 | data_desc->endpoint[0].desc.bEndpointAddress); | ||
| 390 | pnd->tx_pipe = usb_sndbulkpipe(usbdev, | ||
| 391 | data_desc->endpoint[1].desc.bEndpointAddress); | ||
| 392 | } else { | ||
| 393 | pnd->rx_pipe = usb_rcvbulkpipe(usbdev, | ||
| 394 | data_desc->endpoint[1].desc.bEndpointAddress); | ||
| 395 | pnd->tx_pipe = usb_sndbulkpipe(usbdev, | ||
| 396 | data_desc->endpoint[0].desc.bEndpointAddress); | ||
| 397 | } | ||
| 398 | pnd->active_setting = data_desc - data_intf->altsetting; | ||
| 399 | |||
| 400 | err = usb_driver_claim_interface(&usbpn_driver, data_intf, pnd); | ||
| 401 | if (err) | ||
| 402 | goto out; | ||
| 403 | |||
| 404 | /* Force inactive mode until the network device is brought UP */ | ||
| 405 | usb_set_interface(usbdev, union_header->bSlaveInterface0, | ||
| 406 | !pnd->active_setting); | ||
| 407 | usb_set_intfdata(intf, pnd); | ||
| 408 | |||
| 409 | err = register_netdev(dev); | ||
| 410 | if (err) { | ||
| 411 | usb_driver_release_interface(&usbpn_driver, data_intf); | ||
| 412 | goto out; | ||
| 413 | } | ||
| 414 | |||
| 415 | dev_dbg(&dev->dev, "USB CDC Phonet device found\n"); | ||
| 416 | return 0; | ||
| 417 | |||
| 418 | out: | ||
| 419 | usb_set_intfdata(intf, NULL); | ||
| 420 | free_netdev(dev); | ||
| 421 | return err; | ||
| 422 | } | ||
| 423 | |||
| 424 | static void usbpn_disconnect(struct usb_interface *intf) | ||
| 425 | { | ||
| 426 | struct usbpn_dev *pnd = usb_get_intfdata(intf); | ||
| 427 | struct usb_device *usb = pnd->usb; | ||
| 428 | |||
| 429 | if (pnd->disconnected) | ||
| 430 | return; | ||
| 431 | |||
| 432 | pnd->disconnected = 1; | ||
| 433 | usb_driver_release_interface(&usbpn_driver, | ||
| 434 | (pnd->intf == intf) ? pnd->data_intf : pnd->intf); | ||
| 435 | unregister_netdev(pnd->dev); | ||
| 436 | usb_put_dev(usb); | ||
| 437 | } | ||
| 438 | |||
| 439 | static struct usb_driver usbpn_driver = { | ||
| 440 | .name = "cdc_phonet", | ||
| 441 | .probe = usbpn_probe, | ||
| 442 | .disconnect = usbpn_disconnect, | ||
| 443 | .id_table = usbpn_ids, | ||
| 444 | }; | ||
| 445 | |||
| 446 | static int __init usbpn_init(void) | ||
| 447 | { | ||
| 448 | return usb_register(&usbpn_driver); | ||
| 449 | } | ||
| 450 | |||
| 451 | static void __exit usbpn_exit(void) | ||
| 452 | { | ||
| 453 | usb_deregister(&usbpn_driver); | ||
| 454 | } | ||
| 455 | |||
| 456 | module_init(usbpn_init); | ||
| 457 | module_exit(usbpn_exit); | ||
| 458 | |||
| 459 | MODULE_AUTHOR("Remi Denis-Courmont"); | ||
| 460 | MODULE_DESCRIPTION("USB CDC Phonet host interface"); | ||
| 461 | MODULE_LICENSE("GPL"); | ||
diff --git a/drivers/net/usb/cdc_eem.c b/drivers/net/usb/cdc_eem.c index cd35d50e46d4..45cebfb302cf 100644 --- a/drivers/net/usb/cdc_eem.c +++ b/drivers/net/usb/cdc_eem.c | |||
| @@ -311,7 +311,7 @@ static int eem_rx_fixup(struct usbnet *dev, struct sk_buff *skb) | |||
| 311 | * bmCRC = 0 : CRC = 0xDEADBEEF | 311 | * bmCRC = 0 : CRC = 0xDEADBEEF |
| 312 | */ | 312 | */ |
| 313 | if (header & BIT(14)) | 313 | if (header & BIT(14)) |
| 314 | crc2 = ~crc32_le(~0, skb2->data, len); | 314 | crc2 = ~crc32_le(~0, skb2->data, skb2->len); |
| 315 | else | 315 | else |
| 316 | crc2 = 0xdeadbeef; | 316 | crc2 = 0xdeadbeef; |
| 317 | 317 | ||
diff --git a/drivers/net/usb/pegasus.h b/drivers/net/usb/pegasus.h index c7467823cd1c..f968c834ff63 100644 --- a/drivers/net/usb/pegasus.h +++ b/drivers/net/usb/pegasus.h | |||
| @@ -250,6 +250,8 @@ PEGASUS_DEV( "IO DATA USB ET/TX", VENDOR_IODATA, 0x0904, | |||
| 250 | DEFAULT_GPIO_RESET ) | 250 | DEFAULT_GPIO_RESET ) |
| 251 | PEGASUS_DEV( "IO DATA USB ET/TX-S", VENDOR_IODATA, 0x0913, | 251 | PEGASUS_DEV( "IO DATA USB ET/TX-S", VENDOR_IODATA, 0x0913, |
| 252 | DEFAULT_GPIO_RESET | PEGASUS_II ) | 252 | DEFAULT_GPIO_RESET | PEGASUS_II ) |
| 253 | PEGASUS_DEV( "IO DATA USB ETX-US2", VENDOR_IODATA, 0x092a, | ||
| 254 | DEFAULT_GPIO_RESET | PEGASUS_II ) | ||
| 253 | PEGASUS_DEV( "Kingston KNU101TX Ethernet", VENDOR_KINGSTON, 0x000a, | 255 | PEGASUS_DEV( "Kingston KNU101TX Ethernet", VENDOR_KINGSTON, 0x000a, |
| 254 | DEFAULT_GPIO_RESET) | 256 | DEFAULT_GPIO_RESET) |
| 255 | PEGASUS_DEV( "LANEED USB Ethernet LD-USB/TX", VENDOR_LANEED, 0x4002, | 257 | PEGASUS_DEV( "LANEED USB Ethernet LD-USB/TX", VENDOR_LANEED, 0x4002, |
diff --git a/drivers/net/via-rhine.c b/drivers/net/via-rhine.c index 88c30a58b4bd..934f7671650a 100644 --- a/drivers/net/via-rhine.c +++ b/drivers/net/via-rhine.c | |||
| @@ -1218,6 +1218,7 @@ static int rhine_start_tx(struct sk_buff *skb, struct net_device *dev) | |||
| 1218 | struct rhine_private *rp = netdev_priv(dev); | 1218 | struct rhine_private *rp = netdev_priv(dev); |
| 1219 | void __iomem *ioaddr = rp->base; | 1219 | void __iomem *ioaddr = rp->base; |
| 1220 | unsigned entry; | 1220 | unsigned entry; |
| 1221 | unsigned long flags; | ||
| 1221 | 1222 | ||
| 1222 | /* Caution: the write order is important here, set the field | 1223 | /* Caution: the write order is important here, set the field |
| 1223 | with the "ownership" bits last. */ | 1224 | with the "ownership" bits last. */ |
| @@ -1261,7 +1262,7 @@ static int rhine_start_tx(struct sk_buff *skb, struct net_device *dev) | |||
| 1261 | cpu_to_le32(TXDESC | (skb->len >= ETH_ZLEN ? skb->len : ETH_ZLEN)); | 1262 | cpu_to_le32(TXDESC | (skb->len >= ETH_ZLEN ? skb->len : ETH_ZLEN)); |
| 1262 | 1263 | ||
| 1263 | /* lock eth irq */ | 1264 | /* lock eth irq */ |
| 1264 | spin_lock_irq(&rp->lock); | 1265 | spin_lock_irqsave(&rp->lock, flags); |
| 1265 | wmb(); | 1266 | wmb(); |
| 1266 | rp->tx_ring[entry].tx_status = cpu_to_le32(DescOwn); | 1267 | rp->tx_ring[entry].tx_status = cpu_to_le32(DescOwn); |
| 1267 | wmb(); | 1268 | wmb(); |
| @@ -1280,7 +1281,7 @@ static int rhine_start_tx(struct sk_buff *skb, struct net_device *dev) | |||
| 1280 | 1281 | ||
| 1281 | dev->trans_start = jiffies; | 1282 | dev->trans_start = jiffies; |
| 1282 | 1283 | ||
| 1283 | spin_unlock_irq(&rp->lock); | 1284 | spin_unlock_irqrestore(&rp->lock, flags); |
| 1284 | 1285 | ||
| 1285 | if (debug > 4) { | 1286 | if (debug > 4) { |
| 1286 | printk(KERN_DEBUG "%s: Transmit frame #%d queued in slot %d.\n", | 1287 | printk(KERN_DEBUG "%s: Transmit frame #%d queued in slot %d.\n", |
diff --git a/drivers/net/via-velocity.c b/drivers/net/via-velocity.c index 3ba35956327a..cee08a1e497a 100644 --- a/drivers/net/via-velocity.c +++ b/drivers/net/via-velocity.c | |||
| @@ -1778,7 +1778,7 @@ static void velocity_error(struct velocity_info *vptr, int status) | |||
| 1778 | * mode | 1778 | * mode |
| 1779 | */ | 1779 | */ |
| 1780 | if (vptr->rev_id < REV_ID_VT3216_A0) { | 1780 | if (vptr->rev_id < REV_ID_VT3216_A0) { |
| 1781 | if (vptr->mii_status | VELOCITY_DUPLEX_FULL) | 1781 | if (vptr->mii_status & VELOCITY_DUPLEX_FULL) |
| 1782 | BYTE_REG_BITS_ON(TCR_TB2BDIS, ®s->TCR); | 1782 | BYTE_REG_BITS_ON(TCR_TB2BDIS, ®s->TCR); |
| 1783 | else | 1783 | else |
| 1784 | BYTE_REG_BITS_OFF(TCR_TB2BDIS, ®s->TCR); | 1784 | BYTE_REG_BITS_OFF(TCR_TB2BDIS, ®s->TCR); |
diff --git a/drivers/net/virtio_net.c b/drivers/net/virtio_net.c index 2a6e81d5b579..bbedf03a2124 100644 --- a/drivers/net/virtio_net.c +++ b/drivers/net/virtio_net.c | |||
| @@ -70,6 +70,9 @@ struct virtnet_info | |||
| 70 | struct sk_buff_head recv; | 70 | struct sk_buff_head recv; |
| 71 | struct sk_buff_head send; | 71 | struct sk_buff_head send; |
| 72 | 72 | ||
| 73 | /* Work struct for refilling if we run low on memory. */ | ||
| 74 | struct delayed_work refill; | ||
| 75 | |||
| 73 | /* Chain pages by the private ptr. */ | 76 | /* Chain pages by the private ptr. */ |
| 74 | struct page *pages; | 77 | struct page *pages; |
| 75 | }; | 78 | }; |
| @@ -273,19 +276,22 @@ drop: | |||
| 273 | dev_kfree_skb(skb); | 276 | dev_kfree_skb(skb); |
| 274 | } | 277 | } |
| 275 | 278 | ||
| 276 | static void try_fill_recv_maxbufs(struct virtnet_info *vi) | 279 | static bool try_fill_recv_maxbufs(struct virtnet_info *vi, gfp_t gfp) |
| 277 | { | 280 | { |
| 278 | struct sk_buff *skb; | 281 | struct sk_buff *skb; |
| 279 | struct scatterlist sg[2+MAX_SKB_FRAGS]; | 282 | struct scatterlist sg[2+MAX_SKB_FRAGS]; |
| 280 | int num, err, i; | 283 | int num, err, i; |
| 284 | bool oom = false; | ||
| 281 | 285 | ||
| 282 | sg_init_table(sg, 2+MAX_SKB_FRAGS); | 286 | sg_init_table(sg, 2+MAX_SKB_FRAGS); |
| 283 | for (;;) { | 287 | for (;;) { |
| 284 | struct virtio_net_hdr *hdr; | 288 | struct virtio_net_hdr *hdr; |
| 285 | 289 | ||
| 286 | skb = netdev_alloc_skb(vi->dev, MAX_PACKET_LEN + NET_IP_ALIGN); | 290 | skb = netdev_alloc_skb(vi->dev, MAX_PACKET_LEN + NET_IP_ALIGN); |
| 287 | if (unlikely(!skb)) | 291 | if (unlikely(!skb)) { |
| 292 | oom = true; | ||
| 288 | break; | 293 | break; |
| 294 | } | ||
| 289 | 295 | ||
| 290 | skb_reserve(skb, NET_IP_ALIGN); | 296 | skb_reserve(skb, NET_IP_ALIGN); |
| 291 | skb_put(skb, MAX_PACKET_LEN); | 297 | skb_put(skb, MAX_PACKET_LEN); |
| @@ -296,7 +302,7 @@ static void try_fill_recv_maxbufs(struct virtnet_info *vi) | |||
| 296 | if (vi->big_packets) { | 302 | if (vi->big_packets) { |
| 297 | for (i = 0; i < MAX_SKB_FRAGS; i++) { | 303 | for (i = 0; i < MAX_SKB_FRAGS; i++) { |
| 298 | skb_frag_t *f = &skb_shinfo(skb)->frags[i]; | 304 | skb_frag_t *f = &skb_shinfo(skb)->frags[i]; |
| 299 | f->page = get_a_page(vi, GFP_ATOMIC); | 305 | f->page = get_a_page(vi, gfp); |
| 300 | if (!f->page) | 306 | if (!f->page) |
| 301 | break; | 307 | break; |
| 302 | 308 | ||
| @@ -325,31 +331,35 @@ static void try_fill_recv_maxbufs(struct virtnet_info *vi) | |||
| 325 | if (unlikely(vi->num > vi->max)) | 331 | if (unlikely(vi->num > vi->max)) |
| 326 | vi->max = vi->num; | 332 | vi->max = vi->num; |
| 327 | vi->rvq->vq_ops->kick(vi->rvq); | 333 | vi->rvq->vq_ops->kick(vi->rvq); |
| 334 | return !oom; | ||
| 328 | } | 335 | } |
| 329 | 336 | ||
| 330 | static void try_fill_recv(struct virtnet_info *vi) | 337 | /* Returns false if we couldn't fill entirely (OOM). */ |
| 338 | static bool try_fill_recv(struct virtnet_info *vi, gfp_t gfp) | ||
| 331 | { | 339 | { |
| 332 | struct sk_buff *skb; | 340 | struct sk_buff *skb; |
| 333 | struct scatterlist sg[1]; | 341 | struct scatterlist sg[1]; |
| 334 | int err; | 342 | int err; |
| 343 | bool oom = false; | ||
| 335 | 344 | ||
| 336 | if (!vi->mergeable_rx_bufs) { | 345 | if (!vi->mergeable_rx_bufs) |
| 337 | try_fill_recv_maxbufs(vi); | 346 | return try_fill_recv_maxbufs(vi, gfp); |
| 338 | return; | ||
| 339 | } | ||
| 340 | 347 | ||
| 341 | for (;;) { | 348 | for (;;) { |
| 342 | skb_frag_t *f; | 349 | skb_frag_t *f; |
| 343 | 350 | ||
| 344 | skb = netdev_alloc_skb(vi->dev, GOOD_COPY_LEN + NET_IP_ALIGN); | 351 | skb = netdev_alloc_skb(vi->dev, GOOD_COPY_LEN + NET_IP_ALIGN); |
| 345 | if (unlikely(!skb)) | 352 | if (unlikely(!skb)) { |
| 353 | oom = true; | ||
| 346 | break; | 354 | break; |
| 355 | } | ||
| 347 | 356 | ||
| 348 | skb_reserve(skb, NET_IP_ALIGN); | 357 | skb_reserve(skb, NET_IP_ALIGN); |
| 349 | 358 | ||
| 350 | f = &skb_shinfo(skb)->frags[0]; | 359 | f = &skb_shinfo(skb)->frags[0]; |
| 351 | f->page = get_a_page(vi, GFP_ATOMIC); | 360 | f->page = get_a_page(vi, gfp); |
| 352 | if (!f->page) { | 361 | if (!f->page) { |
| 362 | oom = true; | ||
| 353 | kfree_skb(skb); | 363 | kfree_skb(skb); |
| 354 | break; | 364 | break; |
| 355 | } | 365 | } |
| @@ -373,6 +383,7 @@ static void try_fill_recv(struct virtnet_info *vi) | |||
| 373 | if (unlikely(vi->num > vi->max)) | 383 | if (unlikely(vi->num > vi->max)) |
| 374 | vi->max = vi->num; | 384 | vi->max = vi->num; |
| 375 | vi->rvq->vq_ops->kick(vi->rvq); | 385 | vi->rvq->vq_ops->kick(vi->rvq); |
| 386 | return !oom; | ||
| 376 | } | 387 | } |
| 377 | 388 | ||
| 378 | static void skb_recv_done(struct virtqueue *rvq) | 389 | static void skb_recv_done(struct virtqueue *rvq) |
| @@ -385,6 +396,23 @@ static void skb_recv_done(struct virtqueue *rvq) | |||
| 385 | } | 396 | } |
| 386 | } | 397 | } |
| 387 | 398 | ||
| 399 | static void refill_work(struct work_struct *work) | ||
| 400 | { | ||
| 401 | struct virtnet_info *vi; | ||
| 402 | bool still_empty; | ||
| 403 | |||
| 404 | vi = container_of(work, struct virtnet_info, refill.work); | ||
| 405 | napi_disable(&vi->napi); | ||
| 406 | try_fill_recv(vi, GFP_KERNEL); | ||
| 407 | still_empty = (vi->num == 0); | ||
| 408 | napi_enable(&vi->napi); | ||
| 409 | |||
| 410 | /* In theory, this can happen: if we don't get any buffers in | ||
| 411 | * we will *never* try to fill again. */ | ||
| 412 | if (still_empty) | ||
| 413 | schedule_delayed_work(&vi->refill, HZ/2); | ||
| 414 | } | ||
| 415 | |||
| 388 | static int virtnet_poll(struct napi_struct *napi, int budget) | 416 | static int virtnet_poll(struct napi_struct *napi, int budget) |
| 389 | { | 417 | { |
| 390 | struct virtnet_info *vi = container_of(napi, struct virtnet_info, napi); | 418 | struct virtnet_info *vi = container_of(napi, struct virtnet_info, napi); |
| @@ -400,10 +428,10 @@ again: | |||
| 400 | received++; | 428 | received++; |
| 401 | } | 429 | } |
| 402 | 430 | ||
| 403 | /* FIXME: If we oom and completely run out of inbufs, we need | 431 | if (vi->num < vi->max / 2) { |
| 404 | * to start a timer trying to fill more. */ | 432 | if (!try_fill_recv(vi, GFP_ATOMIC)) |
| 405 | if (vi->num < vi->max / 2) | 433 | schedule_delayed_work(&vi->refill, 0); |
| 406 | try_fill_recv(vi); | 434 | } |
| 407 | 435 | ||
| 408 | /* Out of packets? */ | 436 | /* Out of packets? */ |
| 409 | if (received < budget) { | 437 | if (received < budget) { |
| @@ -893,6 +921,7 @@ static int virtnet_probe(struct virtio_device *vdev) | |||
| 893 | vi->vdev = vdev; | 921 | vi->vdev = vdev; |
| 894 | vdev->priv = vi; | 922 | vdev->priv = vi; |
| 895 | vi->pages = NULL; | 923 | vi->pages = NULL; |
| 924 | INIT_DELAYED_WORK(&vi->refill, refill_work); | ||
| 896 | 925 | ||
| 897 | /* If they give us a callback when all buffers are done, we don't need | 926 | /* If they give us a callback when all buffers are done, we don't need |
| 898 | * the timer. */ | 927 | * the timer. */ |
| @@ -941,7 +970,7 @@ static int virtnet_probe(struct virtio_device *vdev) | |||
| 941 | } | 970 | } |
| 942 | 971 | ||
| 943 | /* Last of all, set up some receive buffers. */ | 972 | /* Last of all, set up some receive buffers. */ |
| 944 | try_fill_recv(vi); | 973 | try_fill_recv(vi, GFP_KERNEL); |
| 945 | 974 | ||
| 946 | /* If we didn't even get one input buffer, we're useless. */ | 975 | /* If we didn't even get one input buffer, we're useless. */ |
| 947 | if (vi->num == 0) { | 976 | if (vi->num == 0) { |
| @@ -958,6 +987,7 @@ static int virtnet_probe(struct virtio_device *vdev) | |||
| 958 | 987 | ||
| 959 | unregister: | 988 | unregister: |
| 960 | unregister_netdev(dev); | 989 | unregister_netdev(dev); |
| 990 | cancel_delayed_work_sync(&vi->refill); | ||
| 961 | free_vqs: | 991 | free_vqs: |
| 962 | vdev->config->del_vqs(vdev); | 992 | vdev->config->del_vqs(vdev); |
| 963 | free: | 993 | free: |
| @@ -986,6 +1016,7 @@ static void virtnet_remove(struct virtio_device *vdev) | |||
| 986 | BUG_ON(vi->num != 0); | 1016 | BUG_ON(vi->num != 0); |
| 987 | 1017 | ||
| 988 | unregister_netdev(vi->dev); | 1018 | unregister_netdev(vi->dev); |
| 1019 | cancel_delayed_work_sync(&vi->refill); | ||
| 989 | 1020 | ||
| 990 | vdev->config->del_vqs(vi->vdev); | 1021 | vdev->config->del_vqs(vi->vdev); |
| 991 | 1022 | ||
diff --git a/drivers/net/wireless/airo.c b/drivers/net/wireless/airo.c index c70604f0329e..8ce5e4cee168 100644 --- a/drivers/net/wireless/airo.c +++ b/drivers/net/wireless/airo.c | |||
| @@ -5918,20 +5918,19 @@ static int airo_set_essid(struct net_device *dev, | |||
| 5918 | readSsidRid(local, &SSID_rid); | 5918 | readSsidRid(local, &SSID_rid); |
| 5919 | 5919 | ||
| 5920 | /* Check if we asked for `any' */ | 5920 | /* Check if we asked for `any' */ |
| 5921 | if(dwrq->flags == 0) { | 5921 | if (dwrq->flags == 0) { |
| 5922 | /* Just send an empty SSID list */ | 5922 | /* Just send an empty SSID list */ |
| 5923 | memset(&SSID_rid, 0, sizeof(SSID_rid)); | 5923 | memset(&SSID_rid, 0, sizeof(SSID_rid)); |
| 5924 | } else { | 5924 | } else { |
| 5925 | int index = (dwrq->flags & IW_ENCODE_INDEX) - 1; | 5925 | unsigned index = (dwrq->flags & IW_ENCODE_INDEX) - 1; |
| 5926 | 5926 | ||
| 5927 | /* Check the size of the string */ | 5927 | /* Check the size of the string */ |
| 5928 | if(dwrq->length > IW_ESSID_MAX_SIZE) { | 5928 | if (dwrq->length > IW_ESSID_MAX_SIZE) |
| 5929 | return -E2BIG ; | 5929 | return -E2BIG ; |
| 5930 | } | 5930 | |
| 5931 | /* Check if index is valid */ | 5931 | /* Check if index is valid */ |
| 5932 | if((index < 0) || (index >= 4)) { | 5932 | if (index >= ARRAY_SIZE(SSID_rid.ssids)) |
| 5933 | return -EINVAL; | 5933 | return -EINVAL; |
| 5934 | } | ||
| 5935 | 5934 | ||
| 5936 | /* Set the SSID */ | 5935 | /* Set the SSID */ |
| 5937 | memset(SSID_rid.ssids[index].ssid, 0, | 5936 | memset(SSID_rid.ssids[index].ssid, 0, |
| @@ -6819,7 +6818,7 @@ static int airo_set_txpow(struct net_device *dev, | |||
| 6819 | return -EINVAL; | 6818 | return -EINVAL; |
| 6820 | } | 6819 | } |
| 6821 | clear_bit (FLAG_RADIO_OFF, &local->flags); | 6820 | clear_bit (FLAG_RADIO_OFF, &local->flags); |
| 6822 | for (i = 0; cap_rid.txPowerLevels[i] && (i < 8); i++) | 6821 | for (i = 0; i < 8 && cap_rid.txPowerLevels[i]; i++) |
| 6823 | if (v == cap_rid.txPowerLevels[i]) { | 6822 | if (v == cap_rid.txPowerLevels[i]) { |
| 6824 | readConfigRid(local, 1); | 6823 | readConfigRid(local, 1); |
| 6825 | local->config.txPower = v; | 6824 | local->config.txPower = v; |
diff --git a/drivers/net/wireless/ath/ar9170/main.c b/drivers/net/wireless/ath/ar9170/main.c index 9d38cf60a0db..88c3d8573869 100644 --- a/drivers/net/wireless/ath/ar9170/main.c +++ b/drivers/net/wireless/ath/ar9170/main.c | |||
| @@ -1967,13 +1967,14 @@ static int ar9170_conf_tx(struct ieee80211_hw *hw, u16 queue, | |||
| 1967 | int ret; | 1967 | int ret; |
| 1968 | 1968 | ||
| 1969 | mutex_lock(&ar->mutex); | 1969 | mutex_lock(&ar->mutex); |
| 1970 | if ((param) && !(queue > __AR9170_NUM_TXQ)) { | 1970 | if (queue < __AR9170_NUM_TXQ) { |
| 1971 | memcpy(&ar->edcf[ar9170_qos_hwmap[queue]], | 1971 | memcpy(&ar->edcf[ar9170_qos_hwmap[queue]], |
| 1972 | param, sizeof(*param)); | 1972 | param, sizeof(*param)); |
| 1973 | 1973 | ||
| 1974 | ret = ar9170_set_qos(ar); | 1974 | ret = ar9170_set_qos(ar); |
| 1975 | } else | 1975 | } else { |
| 1976 | ret = -EINVAL; | 1976 | ret = -EINVAL; |
| 1977 | } | ||
| 1977 | 1978 | ||
| 1978 | mutex_unlock(&ar->mutex); | 1979 | mutex_unlock(&ar->mutex); |
| 1979 | return ret; | 1980 | return ret; |
diff --git a/drivers/net/wireless/ath/ar9170/usb.c b/drivers/net/wireless/ath/ar9170/usb.c index 754b1f8d8da9..007eb85fc67e 100644 --- a/drivers/net/wireless/ath/ar9170/usb.c +++ b/drivers/net/wireless/ath/ar9170/usb.c | |||
| @@ -598,11 +598,15 @@ static int ar9170_usb_request_firmware(struct ar9170_usb *aru) | |||
| 598 | 598 | ||
| 599 | err = request_firmware(&aru->init_values, "ar9170-1.fw", | 599 | err = request_firmware(&aru->init_values, "ar9170-1.fw", |
| 600 | &aru->udev->dev); | 600 | &aru->udev->dev); |
| 601 | if (err) { | ||
| 602 | dev_err(&aru->udev->dev, "file with init values not found.\n"); | ||
| 603 | return err; | ||
| 604 | } | ||
| 601 | 605 | ||
| 602 | err = request_firmware(&aru->firmware, "ar9170-2.fw", &aru->udev->dev); | 606 | err = request_firmware(&aru->firmware, "ar9170-2.fw", &aru->udev->dev); |
| 603 | if (err) { | 607 | if (err) { |
| 604 | release_firmware(aru->init_values); | 608 | release_firmware(aru->init_values); |
| 605 | dev_err(&aru->udev->dev, "file with init values not found.\n"); | 609 | dev_err(&aru->udev->dev, "firmware file not found.\n"); |
| 606 | return err; | 610 | return err; |
| 607 | } | 611 | } |
| 608 | 612 | ||
diff --git a/drivers/net/wireless/ath/ath5k/base.c b/drivers/net/wireless/ath/ath5k/base.c index ea045151f953..029c1bc7468f 100644 --- a/drivers/net/wireless/ath/ath5k/base.c +++ b/drivers/net/wireless/ath/ath5k/base.c | |||
| @@ -2970,6 +2970,9 @@ ath5k_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd, | |||
| 2970 | if (modparam_nohwcrypt) | 2970 | if (modparam_nohwcrypt) |
| 2971 | return -EOPNOTSUPP; | 2971 | return -EOPNOTSUPP; |
| 2972 | 2972 | ||
| 2973 | if (sc->opmode == NL80211_IFTYPE_AP) | ||
| 2974 | return -EOPNOTSUPP; | ||
| 2975 | |||
| 2973 | switch (key->alg) { | 2976 | switch (key->alg) { |
| 2974 | case ALG_WEP: | 2977 | case ALG_WEP: |
| 2975 | case ALG_TKIP: | 2978 | case ALG_TKIP: |
diff --git a/drivers/net/wireless/ath/ath9k/ani.c b/drivers/net/wireless/ath/ath9k/ani.c index 1aeafb511ddd..aad259b4c197 100644 --- a/drivers/net/wireless/ath/ath9k/ani.c +++ b/drivers/net/wireless/ath/ath9k/ani.c | |||
| @@ -478,6 +478,18 @@ void ath9k_ani_reset(struct ath_hw *ah) | |||
| 478 | "Reset ANI state opmode %u\n", ah->opmode); | 478 | "Reset ANI state opmode %u\n", ah->opmode); |
| 479 | ah->stats.ast_ani_reset++; | 479 | ah->stats.ast_ani_reset++; |
| 480 | 480 | ||
| 481 | if (ah->opmode == NL80211_IFTYPE_AP) { | ||
| 482 | /* | ||
| 483 | * ath9k_hw_ani_control() will only process items set on | ||
| 484 | * ah->ani_function | ||
| 485 | */ | ||
| 486 | if (IS_CHAN_2GHZ(chan)) | ||
| 487 | ah->ani_function = (ATH9K_ANI_SPUR_IMMUNITY_LEVEL | | ||
| 488 | ATH9K_ANI_FIRSTEP_LEVEL); | ||
| 489 | else | ||
| 490 | ah->ani_function = 0; | ||
| 491 | } | ||
| 492 | |||
| 481 | ath9k_hw_ani_control(ah, ATH9K_ANI_NOISE_IMMUNITY_LEVEL, 0); | 493 | ath9k_hw_ani_control(ah, ATH9K_ANI_NOISE_IMMUNITY_LEVEL, 0); |
| 482 | ath9k_hw_ani_control(ah, ATH9K_ANI_SPUR_IMMUNITY_LEVEL, 0); | 494 | ath9k_hw_ani_control(ah, ATH9K_ANI_SPUR_IMMUNITY_LEVEL, 0); |
| 483 | ath9k_hw_ani_control(ah, ATH9K_ANI_FIRSTEP_LEVEL, 0); | 495 | ath9k_hw_ani_control(ah, ATH9K_ANI_FIRSTEP_LEVEL, 0); |
diff --git a/drivers/net/wireless/ath/ath9k/eeprom.c b/drivers/net/wireless/ath/ath9k/eeprom.c index a2fda702b620..ce0e86c36a82 100644 --- a/drivers/net/wireless/ath/ath9k/eeprom.c +++ b/drivers/net/wireless/ath/ath9k/eeprom.c | |||
| @@ -460,7 +460,7 @@ static int ath9k_hw_4k_check_eeprom(struct ath_hw *ah) | |||
| 460 | integer = swab32(eep->modalHeader.antCtrlCommon); | 460 | integer = swab32(eep->modalHeader.antCtrlCommon); |
| 461 | eep->modalHeader.antCtrlCommon = integer; | 461 | eep->modalHeader.antCtrlCommon = integer; |
| 462 | 462 | ||
| 463 | for (i = 0; i < AR5416_MAX_CHAINS; i++) { | 463 | for (i = 0; i < AR5416_EEP4K_MAX_CHAINS; i++) { |
| 464 | integer = swab32(eep->modalHeader.antCtrlChain[i]); | 464 | integer = swab32(eep->modalHeader.antCtrlChain[i]); |
| 465 | eep->modalHeader.antCtrlChain[i] = integer; | 465 | eep->modalHeader.antCtrlChain[i] = integer; |
| 466 | } | 466 | } |
| @@ -914,7 +914,7 @@ static void ath9k_hw_set_4k_power_per_rate_table(struct ath_hw *ah, | |||
| 914 | ctlMode, numCtlModes, isHt40CtlMode, | 914 | ctlMode, numCtlModes, isHt40CtlMode, |
| 915 | (pCtlMode[ctlMode] & EXT_ADDITIVE)); | 915 | (pCtlMode[ctlMode] & EXT_ADDITIVE)); |
| 916 | 916 | ||
| 917 | for (i = 0; (i < AR5416_NUM_CTLS) && | 917 | for (i = 0; (i < AR5416_EEP4K_NUM_CTLS) && |
| 918 | pEepData->ctlIndex[i]; i++) { | 918 | pEepData->ctlIndex[i]; i++) { |
| 919 | DPRINTF(ah->ah_sc, ATH_DBG_EEPROM, | 919 | DPRINTF(ah->ah_sc, ATH_DBG_EEPROM, |
| 920 | " LOOP-Ctlidx %d: cfgCtl 0x%2.2x " | 920 | " LOOP-Ctlidx %d: cfgCtl 0x%2.2x " |
diff --git a/drivers/net/wireless/ath/regd.c b/drivers/net/wireless/ath/regd.c index eef370bd1211..bf3d25ba7be1 100644 --- a/drivers/net/wireless/ath/regd.c +++ b/drivers/net/wireless/ath/regd.c | |||
| @@ -474,6 +474,21 @@ ath_regd_init_wiphy(struct ath_regulatory *reg, | |||
| 474 | return 0; | 474 | return 0; |
| 475 | } | 475 | } |
| 476 | 476 | ||
| 477 | /* | ||
| 478 | * Some users have reported their EEPROM programmed with | ||
| 479 | * 0x8000 set, this is not a supported regulatory domain | ||
| 480 | * but since we have more than one user with it we need | ||
| 481 | * a solution for them. We default to 0x64, which is the | ||
| 482 | * default Atheros world regulatory domain. | ||
| 483 | */ | ||
| 484 | static void ath_regd_sanitize(struct ath_regulatory *reg) | ||
| 485 | { | ||
| 486 | if (reg->current_rd != COUNTRY_ERD_FLAG) | ||
| 487 | return; | ||
| 488 | printk(KERN_DEBUG "ath: EEPROM regdomain sanitized\n"); | ||
| 489 | reg->current_rd = 0x64; | ||
| 490 | } | ||
| 491 | |||
| 477 | int | 492 | int |
| 478 | ath_regd_init(struct ath_regulatory *reg, | 493 | ath_regd_init(struct ath_regulatory *reg, |
| 479 | struct wiphy *wiphy, | 494 | struct wiphy *wiphy, |
| @@ -486,6 +501,8 @@ ath_regd_init(struct ath_regulatory *reg, | |||
| 486 | if (!reg) | 501 | if (!reg) |
| 487 | return -EINVAL; | 502 | return -EINVAL; |
| 488 | 503 | ||
| 504 | ath_regd_sanitize(reg); | ||
| 505 | |||
| 489 | printk(KERN_DEBUG "ath: EEPROM regdomain: 0x%0x\n", reg->current_rd); | 506 | printk(KERN_DEBUG "ath: EEPROM regdomain: 0x%0x\n", reg->current_rd); |
| 490 | 507 | ||
| 491 | if (!ath_regd_is_eeprom_valid(reg)) { | 508 | if (!ath_regd_is_eeprom_valid(reg)) { |
diff --git a/drivers/net/wireless/ipw2x00/ipw2200.c b/drivers/net/wireless/ipw2x00/ipw2200.c index 44c29b3f6728..6dcac73b4d29 100644 --- a/drivers/net/wireless/ipw2x00/ipw2200.c +++ b/drivers/net/wireless/ipw2x00/ipw2200.c | |||
| @@ -6226,7 +6226,7 @@ static void ipw_add_scan_channels(struct ipw_priv *priv, | |||
| 6226 | }; | 6226 | }; |
| 6227 | 6227 | ||
| 6228 | u8 channel; | 6228 | u8 channel; |
| 6229 | while (channel_index < IPW_SCAN_CHANNELS) { | 6229 | while (channel_index < IPW_SCAN_CHANNELS - 1) { |
| 6230 | channel = | 6230 | channel = |
| 6231 | priv->speed_scan[priv->speed_scan_pos]; | 6231 | priv->speed_scan[priv->speed_scan_pos]; |
| 6232 | if (channel == 0) { | 6232 | if (channel == 0) { |
diff --git a/drivers/net/wireless/iwlwifi/iwl-3945.h b/drivers/net/wireless/iwlwifi/iwl-3945.h index fbb3a573463e..2de6471d4be9 100644 --- a/drivers/net/wireless/iwlwifi/iwl-3945.h +++ b/drivers/net/wireless/iwlwifi/iwl-3945.h | |||
| @@ -112,7 +112,7 @@ enum iwl3945_antenna { | |||
| 112 | #define IWL_TX_FIFO_NONE 7 | 112 | #define IWL_TX_FIFO_NONE 7 |
| 113 | 113 | ||
| 114 | /* Minimum number of queues. MAX_NUM is defined in hw specific files */ | 114 | /* Minimum number of queues. MAX_NUM is defined in hw specific files */ |
| 115 | #define IWL_MIN_NUM_QUEUES 4 | 115 | #define IWL39_MIN_NUM_QUEUES 4 |
| 116 | 116 | ||
| 117 | #define IEEE80211_DATA_LEN 2304 | 117 | #define IEEE80211_DATA_LEN 2304 |
| 118 | #define IEEE80211_4ADDR_LEN 30 | 118 | #define IEEE80211_4ADDR_LEN 30 |
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn.c b/drivers/net/wireless/iwlwifi/iwl-agn.c index 6d1519e1f011..355f50ea7fef 100644 --- a/drivers/net/wireless/iwlwifi/iwl-agn.c +++ b/drivers/net/wireless/iwlwifi/iwl-agn.c | |||
| @@ -2675,12 +2675,10 @@ static ssize_t show_power_level(struct device *d, | |||
| 2675 | struct device_attribute *attr, char *buf) | 2675 | struct device_attribute *attr, char *buf) |
| 2676 | { | 2676 | { |
| 2677 | struct iwl_priv *priv = dev_get_drvdata(d); | 2677 | struct iwl_priv *priv = dev_get_drvdata(d); |
| 2678 | int mode = priv->power_data.user_power_setting; | ||
| 2679 | int level = priv->power_data.power_mode; | 2678 | int level = priv->power_data.power_mode; |
| 2680 | char *p = buf; | 2679 | char *p = buf; |
| 2681 | 2680 | ||
| 2682 | p += sprintf(p, "INDEX:%d\t", level); | 2681 | p += sprintf(p, "%d\n", level); |
| 2683 | p += sprintf(p, "USER:%d\n", mode); | ||
| 2684 | return p - buf + 1; | 2682 | return p - buf + 1; |
| 2685 | } | 2683 | } |
| 2686 | 2684 | ||
diff --git a/drivers/net/wireless/iwlwifi/iwl-core.c b/drivers/net/wireless/iwlwifi/iwl-core.c index 6ab07165ea28..18b135f510e5 100644 --- a/drivers/net/wireless/iwlwifi/iwl-core.c +++ b/drivers/net/wireless/iwlwifi/iwl-core.c | |||
| @@ -1332,6 +1332,9 @@ int iwl_setup_mac(struct iwl_priv *priv) | |||
| 1332 | 1332 | ||
| 1333 | hw->wiphy->custom_regulatory = true; | 1333 | hw->wiphy->custom_regulatory = true; |
| 1334 | 1334 | ||
| 1335 | /* Firmware does not support this */ | ||
| 1336 | hw->wiphy->disable_beacon_hints = true; | ||
| 1337 | |||
| 1335 | hw->wiphy->max_scan_ssids = PROBE_OPTION_MAX; | 1338 | hw->wiphy->max_scan_ssids = PROBE_OPTION_MAX; |
| 1336 | /* we create the 802.11 header and a zero-length SSID element */ | 1339 | /* we create the 802.11 header and a zero-length SSID element */ |
| 1337 | hw->wiphy->max_scan_ie_len = IWL_MAX_PROBE_REQUEST - 24 - 2; | 1340 | hw->wiphy->max_scan_ie_len = IWL_MAX_PROBE_REQUEST - 24 - 2; |
diff --git a/drivers/net/wireless/iwlwifi/iwl-debugfs.c b/drivers/net/wireless/iwlwifi/iwl-debugfs.c index 11e08c068917..ca00cc8ad4c7 100644 --- a/drivers/net/wireless/iwlwifi/iwl-debugfs.c +++ b/drivers/net/wireless/iwlwifi/iwl-debugfs.c | |||
| @@ -308,18 +308,18 @@ static ssize_t iwl_dbgfs_nvm_read(struct file *file, | |||
| 308 | return -ENODATA; | 308 | return -ENODATA; |
| 309 | } | 309 | } |
| 310 | 310 | ||
| 311 | ptr = priv->eeprom; | ||
| 312 | if (!ptr) { | ||
| 313 | IWL_ERR(priv, "Invalid EEPROM/OTP memory\n"); | ||
| 314 | return -ENOMEM; | ||
| 315 | } | ||
| 316 | |||
| 311 | /* 4 characters for byte 0xYY */ | 317 | /* 4 characters for byte 0xYY */ |
| 312 | buf = kzalloc(buf_size, GFP_KERNEL); | 318 | buf = kzalloc(buf_size, GFP_KERNEL); |
| 313 | if (!buf) { | 319 | if (!buf) { |
| 314 | IWL_ERR(priv, "Can not allocate Buffer\n"); | 320 | IWL_ERR(priv, "Can not allocate Buffer\n"); |
| 315 | return -ENOMEM; | 321 | return -ENOMEM; |
| 316 | } | 322 | } |
| 317 | |||
| 318 | ptr = priv->eeprom; | ||
| 319 | if (!ptr) { | ||
| 320 | IWL_ERR(priv, "Invalid EEPROM/OTP memory\n"); | ||
| 321 | return -ENOMEM; | ||
| 322 | } | ||
| 323 | pos += scnprintf(buf + pos, buf_size - pos, "NVM Type: %s\n", | 323 | pos += scnprintf(buf + pos, buf_size - pos, "NVM Type: %s\n", |
| 324 | (priv->nvm_device_type == NVM_DEVICE_TYPE_OTP) | 324 | (priv->nvm_device_type == NVM_DEVICE_TYPE_OTP) |
| 325 | ? "OTP" : "EEPROM"); | 325 | ? "OTP" : "EEPROM"); |
diff --git a/drivers/net/wireless/iwlwifi/iwl-dev.h b/drivers/net/wireless/iwlwifi/iwl-dev.h index e2d620f0b6e8..650e20af20fa 100644 --- a/drivers/net/wireless/iwlwifi/iwl-dev.h +++ b/drivers/net/wireless/iwlwifi/iwl-dev.h | |||
| @@ -258,8 +258,10 @@ struct iwl_channel_info { | |||
| 258 | #define IWL_TX_FIFO_HCCA_2 6 | 258 | #define IWL_TX_FIFO_HCCA_2 6 |
| 259 | #define IWL_TX_FIFO_NONE 7 | 259 | #define IWL_TX_FIFO_NONE 7 |
| 260 | 260 | ||
| 261 | /* Minimum number of queues. MAX_NUM is defined in hw specific files */ | 261 | /* Minimum number of queues. MAX_NUM is defined in hw specific files. |
| 262 | #define IWL_MIN_NUM_QUEUES 4 | 262 | * Set the minimum to accommodate the 4 standard TX queues, 1 command |
| 263 | * queue, 2 (unused) HCCA queues, and 4 HT queues (one for each AC) */ | ||
| 264 | #define IWL_MIN_NUM_QUEUES 10 | ||
| 263 | 265 | ||
| 264 | /* Power management (not Tx power) structures */ | 266 | /* Power management (not Tx power) structures */ |
| 265 | 267 | ||
diff --git a/drivers/net/wireless/iwlwifi/iwl-sta.c b/drivers/net/wireless/iwlwifi/iwl-sta.c index 2addf735b193..ffd5c61a7553 100644 --- a/drivers/net/wireless/iwlwifi/iwl-sta.c +++ b/drivers/net/wireless/iwlwifi/iwl-sta.c | |||
| @@ -566,6 +566,8 @@ int iwl_remove_default_wep_key(struct iwl_priv *priv, | |||
| 566 | unsigned long flags; | 566 | unsigned long flags; |
| 567 | 567 | ||
| 568 | spin_lock_irqsave(&priv->sta_lock, flags); | 568 | spin_lock_irqsave(&priv->sta_lock, flags); |
| 569 | IWL_DEBUG_WEP(priv, "Removing default WEP key: idx=%d\n", | ||
| 570 | keyconf->keyidx); | ||
| 569 | 571 | ||
| 570 | if (!test_and_clear_bit(keyconf->keyidx, &priv->ucode_key_table)) | 572 | if (!test_and_clear_bit(keyconf->keyidx, &priv->ucode_key_table)) |
| 571 | IWL_ERR(priv, "index %d not used in uCode key table.\n", | 573 | IWL_ERR(priv, "index %d not used in uCode key table.\n", |
| @@ -573,6 +575,11 @@ int iwl_remove_default_wep_key(struct iwl_priv *priv, | |||
| 573 | 575 | ||
| 574 | priv->default_wep_key--; | 576 | priv->default_wep_key--; |
| 575 | memset(&priv->wep_keys[keyconf->keyidx], 0, sizeof(priv->wep_keys[0])); | 577 | memset(&priv->wep_keys[keyconf->keyidx], 0, sizeof(priv->wep_keys[0])); |
| 578 | if (iwl_is_rfkill(priv)) { | ||
| 579 | IWL_DEBUG_WEP(priv, "Not sending REPLY_WEPKEY command due to RFKILL.\n"); | ||
| 580 | spin_unlock_irqrestore(&priv->sta_lock, flags); | ||
| 581 | return 0; | ||
| 582 | } | ||
| 576 | ret = iwl_send_static_wepkey_cmd(priv, 1); | 583 | ret = iwl_send_static_wepkey_cmd(priv, 1); |
| 577 | IWL_DEBUG_WEP(priv, "Remove default WEP key: idx=%d ret=%d\n", | 584 | IWL_DEBUG_WEP(priv, "Remove default WEP key: idx=%d ret=%d\n", |
| 578 | keyconf->keyidx, ret); | 585 | keyconf->keyidx, ret); |
| @@ -853,6 +860,11 @@ int iwl_remove_dynamic_key(struct iwl_priv *priv, | |||
| 853 | priv->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_KEY_MASK; | 860 | priv->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_KEY_MASK; |
| 854 | priv->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK; | 861 | priv->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK; |
| 855 | 862 | ||
| 863 | if (iwl_is_rfkill(priv)) { | ||
| 864 | IWL_DEBUG_WEP(priv, "Not sending REPLY_ADD_STA command because RFKILL enabled. \n"); | ||
| 865 | spin_unlock_irqrestore(&priv->sta_lock, flags); | ||
| 866 | return 0; | ||
| 867 | } | ||
| 856 | ret = iwl_send_add_sta(priv, &priv->stations[sta_id].sta, CMD_ASYNC); | 868 | ret = iwl_send_add_sta(priv, &priv->stations[sta_id].sta, CMD_ASYNC); |
| 857 | spin_unlock_irqrestore(&priv->sta_lock, flags); | 869 | spin_unlock_irqrestore(&priv->sta_lock, flags); |
| 858 | return ret; | 870 | return ret; |
diff --git a/drivers/net/wireless/iwlwifi/iwl-tx.c b/drivers/net/wireless/iwlwifi/iwl-tx.c index 85ae7a62109c..2e89040e63be 100644 --- a/drivers/net/wireless/iwlwifi/iwl-tx.c +++ b/drivers/net/wireless/iwlwifi/iwl-tx.c | |||
| @@ -720,8 +720,6 @@ int iwl_tx_skb(struct iwl_priv *priv, struct sk_buff *skb) | |||
| 720 | goto drop_unlock; | 720 | goto drop_unlock; |
| 721 | } | 721 | } |
| 722 | 722 | ||
| 723 | spin_unlock_irqrestore(&priv->lock, flags); | ||
| 724 | |||
| 725 | hdr_len = ieee80211_hdrlen(fc); | 723 | hdr_len = ieee80211_hdrlen(fc); |
| 726 | 724 | ||
| 727 | /* Find (or create) index into station table for destination station */ | 725 | /* Find (or create) index into station table for destination station */ |
| @@ -729,7 +727,7 @@ int iwl_tx_skb(struct iwl_priv *priv, struct sk_buff *skb) | |||
| 729 | if (sta_id == IWL_INVALID_STATION) { | 727 | if (sta_id == IWL_INVALID_STATION) { |
| 730 | IWL_DEBUG_DROP(priv, "Dropping - INVALID STATION: %pM\n", | 728 | IWL_DEBUG_DROP(priv, "Dropping - INVALID STATION: %pM\n", |
| 731 | hdr->addr1); | 729 | hdr->addr1); |
| 732 | goto drop; | 730 | goto drop_unlock; |
| 733 | } | 731 | } |
| 734 | 732 | ||
| 735 | IWL_DEBUG_TX(priv, "station Id %d\n", sta_id); | 733 | IWL_DEBUG_TX(priv, "station Id %d\n", sta_id); |
| @@ -750,14 +748,17 @@ int iwl_tx_skb(struct iwl_priv *priv, struct sk_buff *skb) | |||
| 750 | txq_id = priv->stations[sta_id].tid[tid].agg.txq_id; | 748 | txq_id = priv->stations[sta_id].tid[tid].agg.txq_id; |
| 751 | swq_id = iwl_virtual_agg_queue_num(swq_id, txq_id); | 749 | swq_id = iwl_virtual_agg_queue_num(swq_id, txq_id); |
| 752 | } | 750 | } |
| 753 | priv->stations[sta_id].tid[tid].tfds_in_queue++; | ||
| 754 | } | 751 | } |
| 755 | 752 | ||
| 756 | txq = &priv->txq[txq_id]; | 753 | txq = &priv->txq[txq_id]; |
| 757 | q = &txq->q; | 754 | q = &txq->q; |
| 758 | txq->swq_id = swq_id; | 755 | txq->swq_id = swq_id; |
| 759 | 756 | ||
| 760 | spin_lock_irqsave(&priv->lock, flags); | 757 | if (unlikely(iwl_queue_space(q) < q->high_mark)) |
| 758 | goto drop_unlock; | ||
| 759 | |||
| 760 | if (ieee80211_is_data_qos(fc)) | ||
| 761 | priv->stations[sta_id].tid[tid].tfds_in_queue++; | ||
| 761 | 762 | ||
| 762 | /* Set up driver data for this TFD */ | 763 | /* Set up driver data for this TFD */ |
| 763 | memset(&(txq->txb[q->write_ptr]), 0, sizeof(struct iwl_tx_info)); | 764 | memset(&(txq->txb[q->write_ptr]), 0, sizeof(struct iwl_tx_info)); |
| @@ -872,7 +873,8 @@ int iwl_tx_skb(struct iwl_priv *priv, struct sk_buff *skb) | |||
| 872 | iwl_print_hex_dump(priv, IWL_DL_TX, (u8 *)tx_cmd->hdr, hdr_len); | 873 | iwl_print_hex_dump(priv, IWL_DL_TX, (u8 *)tx_cmd->hdr, hdr_len); |
| 873 | 874 | ||
| 874 | /* Set up entry for this TFD in Tx byte-count array */ | 875 | /* Set up entry for this TFD in Tx byte-count array */ |
| 875 | priv->cfg->ops->lib->txq_update_byte_cnt_tbl(priv, txq, | 876 | if (info->flags & IEEE80211_TX_CTL_AMPDU) |
| 877 | priv->cfg->ops->lib->txq_update_byte_cnt_tbl(priv, txq, | ||
| 876 | le16_to_cpu(tx_cmd->len)); | 878 | le16_to_cpu(tx_cmd->len)); |
| 877 | 879 | ||
| 878 | pci_dma_sync_single_for_device(priv->pci_dev, txcmd_phys, | 880 | pci_dma_sync_single_for_device(priv->pci_dev, txcmd_phys, |
| @@ -901,7 +903,6 @@ int iwl_tx_skb(struct iwl_priv *priv, struct sk_buff *skb) | |||
| 901 | 903 | ||
| 902 | drop_unlock: | 904 | drop_unlock: |
| 903 | spin_unlock_irqrestore(&priv->lock, flags); | 905 | spin_unlock_irqrestore(&priv->lock, flags); |
| 904 | drop: | ||
| 905 | return -1; | 906 | return -1; |
| 906 | } | 907 | } |
| 907 | EXPORT_SYMBOL(iwl_tx_skb); | 908 | EXPORT_SYMBOL(iwl_tx_skb); |
| @@ -1170,6 +1171,8 @@ int iwl_tx_agg_start(struct iwl_priv *priv, const u8 *ra, u16 tid, u16 *ssn) | |||
| 1170 | IWL_ERR(priv, "Start AGG on invalid station\n"); | 1171 | IWL_ERR(priv, "Start AGG on invalid station\n"); |
| 1171 | return -ENXIO; | 1172 | return -ENXIO; |
| 1172 | } | 1173 | } |
| 1174 | if (unlikely(tid >= MAX_TID_COUNT)) | ||
| 1175 | return -EINVAL; | ||
| 1173 | 1176 | ||
| 1174 | if (priv->stations[sta_id].tid[tid].agg.state != IWL_AGG_OFF) { | 1177 | if (priv->stations[sta_id].tid[tid].agg.state != IWL_AGG_OFF) { |
| 1175 | IWL_ERR(priv, "Start AGG when state is not IWL_AGG_OFF !\n"); | 1178 | IWL_ERR(priv, "Start AGG when state is not IWL_AGG_OFF !\n"); |
diff --git a/drivers/net/wireless/iwlwifi/iwl3945-base.c b/drivers/net/wireless/iwlwifi/iwl3945-base.c index cb9bd4c8f25e..523843369ca2 100644 --- a/drivers/net/wireless/iwlwifi/iwl3945-base.c +++ b/drivers/net/wireless/iwlwifi/iwl3945-base.c | |||
| @@ -3643,12 +3643,10 @@ static ssize_t show_power_level(struct device *d, | |||
| 3643 | struct device_attribute *attr, char *buf) | 3643 | struct device_attribute *attr, char *buf) |
| 3644 | { | 3644 | { |
| 3645 | struct iwl_priv *priv = dev_get_drvdata(d); | 3645 | struct iwl_priv *priv = dev_get_drvdata(d); |
| 3646 | int mode = priv->power_data.user_power_setting; | ||
| 3647 | int level = priv->power_data.power_mode; | 3646 | int level = priv->power_data.power_mode; |
| 3648 | char *p = buf; | 3647 | char *p = buf; |
| 3649 | 3648 | ||
| 3650 | p += sprintf(p, "INDEX:%d\t", level); | 3649 | p += sprintf(p, "%d\n", level); |
| 3651 | p += sprintf(p, "USER:%d\n", mode); | ||
| 3652 | return p - buf + 1; | 3650 | return p - buf + 1; |
| 3653 | } | 3651 | } |
| 3654 | 3652 | ||
| @@ -3970,6 +3968,9 @@ static int iwl3945_setup_mac(struct iwl_priv *priv) | |||
| 3970 | 3968 | ||
| 3971 | hw->wiphy->custom_regulatory = true; | 3969 | hw->wiphy->custom_regulatory = true; |
| 3972 | 3970 | ||
| 3971 | /* Firmware does not support this */ | ||
| 3972 | hw->wiphy->disable_beacon_hints = true; | ||
| 3973 | |||
| 3973 | hw->wiphy->max_scan_ssids = PROBE_OPTION_MAX_3945; | 3974 | hw->wiphy->max_scan_ssids = PROBE_OPTION_MAX_3945; |
| 3974 | /* we create the 802.11 header and a zero-length SSID element */ | 3975 | /* we create the 802.11 header and a zero-length SSID element */ |
| 3975 | hw->wiphy->max_scan_ie_len = IWL_MAX_PROBE_REQUEST - 24 - 2; | 3976 | hw->wiphy->max_scan_ie_len = IWL_MAX_PROBE_REQUEST - 24 - 2; |
| @@ -4020,10 +4021,10 @@ static int iwl3945_pci_probe(struct pci_dev *pdev, const struct pci_device_id *e | |||
| 4020 | SET_IEEE80211_DEV(hw, &pdev->dev); | 4021 | SET_IEEE80211_DEV(hw, &pdev->dev); |
| 4021 | 4022 | ||
| 4022 | if ((iwl3945_mod_params.num_of_queues > IWL39_MAX_NUM_QUEUES) || | 4023 | if ((iwl3945_mod_params.num_of_queues > IWL39_MAX_NUM_QUEUES) || |
| 4023 | (iwl3945_mod_params.num_of_queues < IWL_MIN_NUM_QUEUES)) { | 4024 | (iwl3945_mod_params.num_of_queues < IWL39_MIN_NUM_QUEUES)) { |
| 4024 | IWL_ERR(priv, | 4025 | IWL_ERR(priv, |
| 4025 | "invalid queues_num, should be between %d and %d\n", | 4026 | "invalid queues_num, should be between %d and %d\n", |
| 4026 | IWL_MIN_NUM_QUEUES, IWL39_MAX_NUM_QUEUES); | 4027 | IWL39_MIN_NUM_QUEUES, IWL39_MAX_NUM_QUEUES); |
| 4027 | err = -EINVAL; | 4028 | err = -EINVAL; |
| 4028 | goto out_ieee80211_free_hw; | 4029 | goto out_ieee80211_free_hw; |
| 4029 | } | 4030 | } |
diff --git a/drivers/net/wireless/iwmc3200wifi/commands.c b/drivers/net/wireless/iwmc3200wifi/commands.c index 834a7f544e5d..e2334d123599 100644 --- a/drivers/net/wireless/iwmc3200wifi/commands.c +++ b/drivers/net/wireless/iwmc3200wifi/commands.c | |||
| @@ -220,6 +220,7 @@ int iwm_store_rxiq_calib_result(struct iwm_priv *iwm) | |||
| 220 | eeprom_rxiq = iwm_eeprom_access(iwm, IWM_EEPROM_CALIB_RXIQ); | 220 | eeprom_rxiq = iwm_eeprom_access(iwm, IWM_EEPROM_CALIB_RXIQ); |
| 221 | if (IS_ERR(eeprom_rxiq)) { | 221 | if (IS_ERR(eeprom_rxiq)) { |
| 222 | IWM_ERR(iwm, "Couldn't access EEPROM RX IQ entry\n"); | 222 | IWM_ERR(iwm, "Couldn't access EEPROM RX IQ entry\n"); |
| 223 | kfree(rxiq); | ||
| 223 | return PTR_ERR(eeprom_rxiq); | 224 | return PTR_ERR(eeprom_rxiq); |
| 224 | } | 225 | } |
| 225 | 226 | ||
diff --git a/drivers/net/wireless/iwmc3200wifi/netdev.c b/drivers/net/wireless/iwmc3200wifi/netdev.c index aaa20c6885c8..bf294e41753b 100644 --- a/drivers/net/wireless/iwmc3200wifi/netdev.c +++ b/drivers/net/wireless/iwmc3200wifi/netdev.c | |||
| @@ -106,10 +106,8 @@ void *iwm_if_alloc(int sizeof_bus, struct device *dev, | |||
| 106 | int ret = 0; | 106 | int ret = 0; |
| 107 | 107 | ||
| 108 | wdev = iwm_wdev_alloc(sizeof_bus, dev); | 108 | wdev = iwm_wdev_alloc(sizeof_bus, dev); |
| 109 | if (!wdev) { | 109 | if (IS_ERR(wdev)) |
| 110 | dev_err(dev, "no memory for wireless device instance\n"); | 110 | return wdev; |
| 111 | return ERR_PTR(-ENOMEM); | ||
| 112 | } | ||
| 113 | 111 | ||
| 114 | iwm = wdev_to_iwm(wdev); | 112 | iwm = wdev_to_iwm(wdev); |
| 115 | iwm->bus_ops = if_ops; | 113 | iwm->bus_ops = if_ops; |
| @@ -151,8 +149,8 @@ void iwm_if_free(struct iwm_priv *iwm) | |||
| 151 | return; | 149 | return; |
| 152 | 150 | ||
| 153 | free_netdev(iwm_to_ndev(iwm)); | 151 | free_netdev(iwm_to_ndev(iwm)); |
| 154 | iwm_wdev_free(iwm); | ||
| 155 | iwm_priv_deinit(iwm); | 152 | iwm_priv_deinit(iwm); |
| 153 | iwm_wdev_free(iwm); | ||
| 156 | } | 154 | } |
| 157 | 155 | ||
| 158 | int iwm_if_add(struct iwm_priv *iwm) | 156 | int iwm_if_add(struct iwm_priv *iwm) |
diff --git a/drivers/net/wireless/libertas/11d.c b/drivers/net/wireless/libertas/11d.c index 9a5408e7d94a..5c6968101f0d 100644 --- a/drivers/net/wireless/libertas/11d.c +++ b/drivers/net/wireless/libertas/11d.c | |||
| @@ -47,7 +47,7 @@ static u8 lbs_region_2_code(u8 *region) | |||
| 47 | { | 47 | { |
| 48 | u8 i; | 48 | u8 i; |
| 49 | 49 | ||
| 50 | for (i = 0; region[i] && i < COUNTRY_CODE_LEN; i++) | 50 | for (i = 0; i < COUNTRY_CODE_LEN && region[i]; i++) |
| 51 | region[i] = toupper(region[i]); | 51 | region[i] = toupper(region[i]); |
| 52 | 52 | ||
| 53 | for (i = 0; i < ARRAY_SIZE(region_code_mapping); i++) { | 53 | for (i = 0; i < ARRAY_SIZE(region_code_mapping); i++) { |
diff --git a/drivers/net/wireless/libertas/cmd.c b/drivers/net/wireless/libertas/cmd.c index 01db705a38ec..685098148e10 100644 --- a/drivers/net/wireless/libertas/cmd.c +++ b/drivers/net/wireless/libertas/cmd.c | |||
| @@ -135,8 +135,14 @@ int lbs_update_hw_spec(struct lbs_private *priv) | |||
| 135 | /* Clamp region code to 8-bit since FW spec indicates that it should | 135 | /* Clamp region code to 8-bit since FW spec indicates that it should |
| 136 | * only ever be 8-bit, even though the field size is 16-bit. Some firmware | 136 | * only ever be 8-bit, even though the field size is 16-bit. Some firmware |
| 137 | * returns non-zero high 8 bits here. | 137 | * returns non-zero high 8 bits here. |
| 138 | * | ||
| 139 | * Firmware version 4.0.102 used in CF8381 has region code shifted. We | ||
| 140 | * need to check for this problem and handle it properly. | ||
| 138 | */ | 141 | */ |
| 139 | priv->regioncode = le16_to_cpu(cmd.regioncode) & 0xFF; | 142 | if (MRVL_FW_MAJOR_REV(priv->fwrelease) == MRVL_FW_V4) |
| 143 | priv->regioncode = (le16_to_cpu(cmd.regioncode) >> 8) & 0xFF; | ||
| 144 | else | ||
| 145 | priv->regioncode = le16_to_cpu(cmd.regioncode) & 0xFF; | ||
| 140 | 146 | ||
| 141 | for (i = 0; i < MRVDRV_MAX_REGION_CODE; i++) { | 147 | for (i = 0; i < MRVDRV_MAX_REGION_CODE; i++) { |
| 142 | /* use the region code to search for the index */ | 148 | /* use the region code to search for the index */ |
diff --git a/drivers/net/wireless/libertas/defs.h b/drivers/net/wireless/libertas/defs.h index 48da157d6cda..72f3479a4d70 100644 --- a/drivers/net/wireless/libertas/defs.h +++ b/drivers/net/wireless/libertas/defs.h | |||
| @@ -234,6 +234,8 @@ static inline void lbs_deb_hex(unsigned int grp, const char *prompt, u8 *buf, in | |||
| 234 | /** Mesh enable bit in FW capability */ | 234 | /** Mesh enable bit in FW capability */ |
| 235 | #define MESH_CAPINFO_ENABLE_MASK (1<<16) | 235 | #define MESH_CAPINFO_ENABLE_MASK (1<<16) |
| 236 | 236 | ||
| 237 | /** FW definition from Marvell v4 */ | ||
| 238 | #define MRVL_FW_V4 (0x04) | ||
| 237 | /** FW definition from Marvell v5 */ | 239 | /** FW definition from Marvell v5 */ |
| 238 | #define MRVL_FW_V5 (0x05) | 240 | #define MRVL_FW_V5 (0x05) |
| 239 | /** FW definition from Marvell v10 */ | 241 | /** FW definition from Marvell v10 */ |
diff --git a/drivers/net/wireless/libertas/hostcmd.h b/drivers/net/wireless/libertas/hostcmd.h index 0a2e29140add..c8a1998d4744 100644 --- a/drivers/net/wireless/libertas/hostcmd.h +++ b/drivers/net/wireless/libertas/hostcmd.h | |||
| @@ -56,8 +56,8 @@ struct rxpd { | |||
| 56 | u8 bss_type; | 56 | u8 bss_type; |
| 57 | /* BSS number */ | 57 | /* BSS number */ |
| 58 | u8 bss_num; | 58 | u8 bss_num; |
| 59 | } bss; | 59 | } __attribute__ ((packed)) bss; |
| 60 | } u; | 60 | } __attribute__ ((packed)) u; |
| 61 | 61 | ||
| 62 | /* SNR */ | 62 | /* SNR */ |
| 63 | u8 snr; | 63 | u8 snr; |
diff --git a/drivers/net/wireless/libertas/scan.c b/drivers/net/wireless/libertas/scan.c index 601b54249677..6c95af3023cc 100644 --- a/drivers/net/wireless/libertas/scan.c +++ b/drivers/net/wireless/libertas/scan.c | |||
| @@ -5,6 +5,7 @@ | |||
| 5 | * for sending scan commands to the firmware. | 5 | * for sending scan commands to the firmware. |
| 6 | */ | 6 | */ |
| 7 | #include <linux/types.h> | 7 | #include <linux/types.h> |
| 8 | #include <linux/kernel.h> | ||
| 8 | #include <linux/etherdevice.h> | 9 | #include <linux/etherdevice.h> |
| 9 | #include <linux/if_arp.h> | 10 | #include <linux/if_arp.h> |
| 10 | #include <asm/unaligned.h> | 11 | #include <asm/unaligned.h> |
| @@ -876,7 +877,7 @@ static inline char *lbs_translate_scan(struct lbs_private *priv, | |||
| 876 | iwe.u.bitrate.disabled = 0; | 877 | iwe.u.bitrate.disabled = 0; |
| 877 | iwe.u.bitrate.value = 0; | 878 | iwe.u.bitrate.value = 0; |
| 878 | 879 | ||
| 879 | for (j = 0; bss->rates[j] && (j < sizeof(bss->rates)); j++) { | 880 | for (j = 0; j < ARRAY_SIZE(bss->rates) && bss->rates[j]; j++) { |
| 880 | /* Bit rate given in 500 kb/s units */ | 881 | /* Bit rate given in 500 kb/s units */ |
| 881 | iwe.u.bitrate.value = bss->rates[j] * 500000; | 882 | iwe.u.bitrate.value = bss->rates[j] * 500000; |
| 882 | current_val = iwe_stream_add_value(info, start, current_val, | 883 | current_val = iwe_stream_add_value(info, start, current_val, |
diff --git a/drivers/net/wireless/mac80211_hwsim.c b/drivers/net/wireless/mac80211_hwsim.c index a111bda392e2..7916ca3f84c8 100644 --- a/drivers/net/wireless/mac80211_hwsim.c +++ b/drivers/net/wireless/mac80211_hwsim.c | |||
| @@ -709,7 +709,7 @@ static const struct ieee80211_ops mac80211_hwsim_ops = | |||
| 709 | static void mac80211_hwsim_free(void) | 709 | static void mac80211_hwsim_free(void) |
| 710 | { | 710 | { |
| 711 | struct list_head tmplist, *i, *tmp; | 711 | struct list_head tmplist, *i, *tmp; |
| 712 | struct mac80211_hwsim_data *data; | 712 | struct mac80211_hwsim_data *data, *tmpdata; |
| 713 | 713 | ||
| 714 | INIT_LIST_HEAD(&tmplist); | 714 | INIT_LIST_HEAD(&tmplist); |
| 715 | 715 | ||
| @@ -718,7 +718,7 @@ static void mac80211_hwsim_free(void) | |||
| 718 | list_move(i, &tmplist); | 718 | list_move(i, &tmplist); |
| 719 | spin_unlock_bh(&hwsim_radio_lock); | 719 | spin_unlock_bh(&hwsim_radio_lock); |
| 720 | 720 | ||
| 721 | list_for_each_entry(data, &tmplist, list) { | 721 | list_for_each_entry_safe(data, tmpdata, &tmplist, list) { |
| 722 | debugfs_remove(data->debugfs_group); | 722 | debugfs_remove(data->debugfs_group); |
| 723 | debugfs_remove(data->debugfs_ps); | 723 | debugfs_remove(data->debugfs_ps); |
| 724 | debugfs_remove(data->debugfs); | 724 | debugfs_remove(data->debugfs); |
| @@ -1167,8 +1167,8 @@ static void __exit exit_mac80211_hwsim(void) | |||
| 1167 | { | 1167 | { |
| 1168 | printk(KERN_DEBUG "mac80211_hwsim: unregister radios\n"); | 1168 | printk(KERN_DEBUG "mac80211_hwsim: unregister radios\n"); |
| 1169 | 1169 | ||
| 1170 | unregister_netdev(hwsim_mon); | ||
| 1171 | mac80211_hwsim_free(); | 1170 | mac80211_hwsim_free(); |
| 1171 | unregister_netdev(hwsim_mon); | ||
| 1172 | } | 1172 | } |
| 1173 | 1173 | ||
| 1174 | 1174 | ||
diff --git a/drivers/net/wireless/mwl8k.c b/drivers/net/wireless/mwl8k.c index a263d5c84c08..83967afe0821 100644 --- a/drivers/net/wireless/mwl8k.c +++ b/drivers/net/wireless/mwl8k.c | |||
| @@ -261,7 +261,7 @@ struct mwl8k_vif { | |||
| 261 | */ | 261 | */ |
| 262 | }; | 262 | }; |
| 263 | 263 | ||
| 264 | #define MWL8K_VIF(_vif) (struct mwl8k_vif *)(&((_vif)->drv_priv)) | 264 | #define MWL8K_VIF(_vif) ((struct mwl8k_vif *)&((_vif)->drv_priv)) |
| 265 | 265 | ||
| 266 | static const struct ieee80211_channel mwl8k_channels[] = { | 266 | static const struct ieee80211_channel mwl8k_channels[] = { |
| 267 | { .center_freq = 2412, .hw_value = 1, }, | 267 | { .center_freq = 2412, .hw_value = 1, }, |
| @@ -1012,6 +1012,8 @@ static int rxq_process(struct ieee80211_hw *hw, int index, int limit) | |||
| 1012 | rmb(); | 1012 | rmb(); |
| 1013 | 1013 | ||
| 1014 | skb = rxq->rx_skb[rxq->rx_head]; | 1014 | skb = rxq->rx_skb[rxq->rx_head]; |
| 1015 | if (skb == NULL) | ||
| 1016 | break; | ||
| 1015 | rxq->rx_skb[rxq->rx_head] = NULL; | 1017 | rxq->rx_skb[rxq->rx_head] = NULL; |
| 1016 | 1018 | ||
| 1017 | rxq->rx_head = (rxq->rx_head + 1) % MWL8K_RX_DESCS; | 1019 | rxq->rx_head = (rxq->rx_head + 1) % MWL8K_RX_DESCS; |
| @@ -1591,6 +1593,9 @@ static int mwl8k_post_cmd(struct ieee80211_hw *hw, struct mwl8k_cmd_pkt *cmd) | |||
| 1591 | timeout = wait_for_completion_timeout(&cmd_wait, | 1593 | timeout = wait_for_completion_timeout(&cmd_wait, |
| 1592 | msecs_to_jiffies(MWL8K_CMD_TIMEOUT_MS)); | 1594 | msecs_to_jiffies(MWL8K_CMD_TIMEOUT_MS)); |
| 1593 | 1595 | ||
| 1596 | pci_unmap_single(priv->pdev, dma_addr, dma_size, | ||
| 1597 | PCI_DMA_BIDIRECTIONAL); | ||
| 1598 | |||
| 1594 | result = &cmd->result; | 1599 | result = &cmd->result; |
| 1595 | if (!timeout) { | 1600 | if (!timeout) { |
| 1596 | spin_lock_irq(&priv->fw_lock); | 1601 | spin_lock_irq(&priv->fw_lock); |
| @@ -1610,8 +1615,6 @@ static int mwl8k_post_cmd(struct ieee80211_hw *hw, struct mwl8k_cmd_pkt *cmd) | |||
| 1610 | *result); | 1615 | *result); |
| 1611 | } | 1616 | } |
| 1612 | 1617 | ||
| 1613 | pci_unmap_single(priv->pdev, dma_addr, dma_size, | ||
| 1614 | PCI_DMA_BIDIRECTIONAL); | ||
| 1615 | return rc; | 1618 | return rc; |
| 1616 | } | 1619 | } |
| 1617 | 1620 | ||
| @@ -1654,18 +1657,18 @@ static int mwl8k_cmd_get_hw_spec(struct ieee80211_hw *hw) | |||
| 1654 | memset(cmd->perm_addr, 0xff, sizeof(cmd->perm_addr)); | 1657 | memset(cmd->perm_addr, 0xff, sizeof(cmd->perm_addr)); |
| 1655 | cmd->ps_cookie = cpu_to_le32(priv->cookie_dma); | 1658 | cmd->ps_cookie = cpu_to_le32(priv->cookie_dma); |
| 1656 | cmd->rx_queue_ptr = cpu_to_le32(priv->rxq[0].rx_desc_dma); | 1659 | cmd->rx_queue_ptr = cpu_to_le32(priv->rxq[0].rx_desc_dma); |
| 1657 | cmd->num_tx_queues = MWL8K_TX_QUEUES; | 1660 | cmd->num_tx_queues = cpu_to_le32(MWL8K_TX_QUEUES); |
| 1658 | for (i = 0; i < MWL8K_TX_QUEUES; i++) | 1661 | for (i = 0; i < MWL8K_TX_QUEUES; i++) |
| 1659 | cmd->tx_queue_ptrs[i] = cpu_to_le32(priv->txq[i].tx_desc_dma); | 1662 | cmd->tx_queue_ptrs[i] = cpu_to_le32(priv->txq[i].tx_desc_dma); |
| 1660 | cmd->num_tx_desc_per_queue = MWL8K_TX_DESCS; | 1663 | cmd->num_tx_desc_per_queue = cpu_to_le32(MWL8K_TX_DESCS); |
| 1661 | cmd->total_rx_desc = MWL8K_RX_DESCS; | 1664 | cmd->total_rx_desc = cpu_to_le32(MWL8K_RX_DESCS); |
| 1662 | 1665 | ||
| 1663 | rc = mwl8k_post_cmd(hw, &cmd->header); | 1666 | rc = mwl8k_post_cmd(hw, &cmd->header); |
| 1664 | 1667 | ||
| 1665 | if (!rc) { | 1668 | if (!rc) { |
| 1666 | SET_IEEE80211_PERM_ADDR(hw, cmd->perm_addr); | 1669 | SET_IEEE80211_PERM_ADDR(hw, cmd->perm_addr); |
| 1667 | priv->num_mcaddrs = le16_to_cpu(cmd->num_mcaddrs); | 1670 | priv->num_mcaddrs = le16_to_cpu(cmd->num_mcaddrs); |
| 1668 | priv->fw_rev = cmd->fw_rev; | 1671 | priv->fw_rev = le32_to_cpu(cmd->fw_rev); |
| 1669 | priv->hw_rev = cmd->hw_rev; | 1672 | priv->hw_rev = cmd->hw_rev; |
| 1670 | priv->region_code = le16_to_cpu(cmd->region_code); | 1673 | priv->region_code = le16_to_cpu(cmd->region_code); |
| 1671 | } | 1674 | } |
| @@ -3216,15 +3219,19 @@ static int mwl8k_configure_filter_wt(struct work_struct *wt) | |||
| 3216 | struct dev_addr_list *mclist = worker->mclist; | 3219 | struct dev_addr_list *mclist = worker->mclist; |
| 3217 | 3220 | ||
| 3218 | struct mwl8k_priv *priv = hw->priv; | 3221 | struct mwl8k_priv *priv = hw->priv; |
| 3219 | struct mwl8k_vif *mv_vif; | ||
| 3220 | int rc = 0; | 3222 | int rc = 0; |
| 3221 | 3223 | ||
| 3222 | if (changed_flags & FIF_BCN_PRBRESP_PROMISC) { | 3224 | if (changed_flags & FIF_BCN_PRBRESP_PROMISC) { |
| 3223 | if (*total_flags & FIF_BCN_PRBRESP_PROMISC) | 3225 | if (*total_flags & FIF_BCN_PRBRESP_PROMISC) |
| 3224 | rc = mwl8k_cmd_set_pre_scan(hw); | 3226 | rc = mwl8k_cmd_set_pre_scan(hw); |
| 3225 | else { | 3227 | else { |
| 3226 | mv_vif = MWL8K_VIF(priv->vif); | 3228 | u8 *bssid; |
| 3227 | rc = mwl8k_cmd_set_post_scan(hw, mv_vif->bssid); | 3229 | |
| 3230 | bssid = "\x00\x00\x00\x00\x00\x00"; | ||
| 3231 | if (priv->vif != NULL) | ||
| 3232 | bssid = MWL8K_VIF(priv->vif)->bssid; | ||
| 3233 | |||
| 3234 | rc = mwl8k_cmd_set_post_scan(hw, bssid); | ||
| 3228 | } | 3235 | } |
| 3229 | } | 3236 | } |
| 3230 | 3237 | ||
| @@ -3726,6 +3733,8 @@ static void __devexit mwl8k_remove(struct pci_dev *pdev) | |||
| 3726 | 3733 | ||
| 3727 | ieee80211_stop_queues(hw); | 3734 | ieee80211_stop_queues(hw); |
| 3728 | 3735 | ||
| 3736 | ieee80211_unregister_hw(hw); | ||
| 3737 | |||
| 3729 | /* Remove tx reclaim tasklet */ | 3738 | /* Remove tx reclaim tasklet */ |
| 3730 | tasklet_kill(&priv->tx_reclaim_task); | 3739 | tasklet_kill(&priv->tx_reclaim_task); |
| 3731 | 3740 | ||
| @@ -3739,8 +3748,6 @@ static void __devexit mwl8k_remove(struct pci_dev *pdev) | |||
| 3739 | for (i = 0; i < MWL8K_TX_QUEUES; i++) | 3748 | for (i = 0; i < MWL8K_TX_QUEUES; i++) |
| 3740 | mwl8k_txq_reclaim(hw, i, 1); | 3749 | mwl8k_txq_reclaim(hw, i, 1); |
| 3741 | 3750 | ||
| 3742 | ieee80211_unregister_hw(hw); | ||
| 3743 | |||
| 3744 | for (i = 0; i < MWL8K_TX_QUEUES; i++) | 3751 | for (i = 0; i < MWL8K_TX_QUEUES; i++) |
| 3745 | mwl8k_txq_deinit(hw, i); | 3752 | mwl8k_txq_deinit(hw, i); |
| 3746 | 3753 | ||
diff --git a/drivers/net/wireless/orinoco/hw.c b/drivers/net/wireless/orinoco/hw.c index 632fac86a308..b3946272c72e 100644 --- a/drivers/net/wireless/orinoco/hw.c +++ b/drivers/net/wireless/orinoco/hw.c | |||
| @@ -70,7 +70,7 @@ int orinoco_hw_get_tkip_iv(struct orinoco_private *priv, int key, u8 *tsc) | |||
| 70 | int err = 0; | 70 | int err = 0; |
| 71 | u8 tsc_arr[4][IW_ENCODE_SEQ_MAX_SIZE]; | 71 | u8 tsc_arr[4][IW_ENCODE_SEQ_MAX_SIZE]; |
| 72 | 72 | ||
| 73 | if ((key < 0) || (key > 4)) | 73 | if ((key < 0) || (key >= 4)) |
| 74 | return -EINVAL; | 74 | return -EINVAL; |
| 75 | 75 | ||
| 76 | err = hermes_read_ltv(hw, USER_BAP, HERMES_RID_CURRENT_TKIP_IV, | 76 | err = hermes_read_ltv(hw, USER_BAP, HERMES_RID_CURRENT_TKIP_IV, |
diff --git a/drivers/net/wireless/p54/p54spi.c b/drivers/net/wireless/p54/p54spi.c index 83116baeb110..72c7dbd39d0a 100644 --- a/drivers/net/wireless/p54/p54spi.c +++ b/drivers/net/wireless/p54/p54spi.c | |||
| @@ -635,7 +635,7 @@ static int __devinit p54spi_probe(struct spi_device *spi) | |||
| 635 | 635 | ||
| 636 | hw = p54_init_common(sizeof(*priv)); | 636 | hw = p54_init_common(sizeof(*priv)); |
| 637 | if (!hw) { | 637 | if (!hw) { |
| 638 | dev_err(&priv->spi->dev, "could not alloc ieee80211_hw"); | 638 | dev_err(&spi->dev, "could not alloc ieee80211_hw"); |
| 639 | return -ENOMEM; | 639 | return -ENOMEM; |
| 640 | } | 640 | } |
| 641 | 641 | ||
diff --git a/drivers/net/wireless/rt2x00/rt2500usb.c b/drivers/net/wireless/rt2x00/rt2500usb.c index 66daf68ff0ee..ce75426764a1 100644 --- a/drivers/net/wireless/rt2x00/rt2500usb.c +++ b/drivers/net/wireless/rt2x00/rt2500usb.c | |||
| @@ -1550,7 +1550,9 @@ static int rt2500usb_init_eeprom(struct rt2x00_dev *rt2x00dev) | |||
| 1550 | rt2500usb_register_read(rt2x00dev, MAC_CSR0, ®); | 1550 | rt2500usb_register_read(rt2x00dev, MAC_CSR0, ®); |
| 1551 | rt2x00_set_chip(rt2x00dev, RT2570, value, reg); | 1551 | rt2x00_set_chip(rt2x00dev, RT2570, value, reg); |
| 1552 | 1552 | ||
| 1553 | if (!rt2x00_check_rev(&rt2x00dev->chip, 0x000ffff0, 0)) { | 1553 | if (!rt2x00_check_rev(&rt2x00dev->chip, 0x000ffff0, 0) || |
| 1554 | rt2x00_check_rev(&rt2x00dev->chip, 0x0000000f, 0)) { | ||
| 1555 | |||
| 1554 | ERROR(rt2x00dev, "Invalid RT chipset detected.\n"); | 1556 | ERROR(rt2x00dev, "Invalid RT chipset detected.\n"); |
| 1555 | return -ENODEV; | 1557 | return -ENODEV; |
| 1556 | } | 1558 | } |
diff --git a/drivers/net/wireless/rt2x00/rt2x00.h b/drivers/net/wireless/rt2x00/rt2x00.h index a498dde024e1..49c9e2c1433d 100644 --- a/drivers/net/wireless/rt2x00/rt2x00.h +++ b/drivers/net/wireless/rt2x00/rt2x00.h | |||
| @@ -849,13 +849,15 @@ struct rt2x00_dev { | |||
| 849 | static inline void rt2x00_rf_read(struct rt2x00_dev *rt2x00dev, | 849 | static inline void rt2x00_rf_read(struct rt2x00_dev *rt2x00dev, |
| 850 | const unsigned int word, u32 *data) | 850 | const unsigned int word, u32 *data) |
| 851 | { | 851 | { |
| 852 | *data = rt2x00dev->rf[word]; | 852 | BUG_ON(word < 1 || word > rt2x00dev->ops->rf_size / sizeof(u32)); |
| 853 | *data = rt2x00dev->rf[word - 1]; | ||
| 853 | } | 854 | } |
| 854 | 855 | ||
| 855 | static inline void rt2x00_rf_write(struct rt2x00_dev *rt2x00dev, | 856 | static inline void rt2x00_rf_write(struct rt2x00_dev *rt2x00dev, |
| 856 | const unsigned int word, u32 data) | 857 | const unsigned int word, u32 data) |
| 857 | { | 858 | { |
| 858 | rt2x00dev->rf[word] = data; | 859 | BUG_ON(word < 1 || word > rt2x00dev->ops->rf_size / sizeof(u32)); |
| 860 | rt2x00dev->rf[word - 1] = data; | ||
| 859 | } | 861 | } |
| 860 | 862 | ||
| 861 | /* | 863 | /* |
diff --git a/drivers/net/wireless/rtl818x/rtl8187_dev.c b/drivers/net/wireless/rtl818x/rtl8187_dev.c index 294250e294dd..87a95588a8e3 100644 --- a/drivers/net/wireless/rtl818x/rtl8187_dev.c +++ b/drivers/net/wireless/rtl818x/rtl8187_dev.c | |||
| @@ -869,6 +869,9 @@ static int rtl8187b_init_hw(struct ieee80211_hw *dev) | |||
| 869 | priv->aifsn[3] = 3; /* AIFSN[AC_BE] */ | 869 | priv->aifsn[3] = 3; /* AIFSN[AC_BE] */ |
| 870 | rtl818x_iowrite8(priv, &priv->map->ACM_CONTROL, 0); | 870 | rtl818x_iowrite8(priv, &priv->map->ACM_CONTROL, 0); |
| 871 | 871 | ||
| 872 | /* ENEDCA flag must always be set, transmit issues? */ | ||
| 873 | rtl818x_iowrite8(priv, &priv->map->MSR, RTL818X_MSR_ENEDCA); | ||
| 874 | |||
| 872 | return 0; | 875 | return 0; |
| 873 | } | 876 | } |
| 874 | 877 | ||
| @@ -1173,13 +1176,16 @@ static void rtl8187_bss_info_changed(struct ieee80211_hw *dev, | |||
| 1173 | rtl818x_iowrite8(priv, &priv->map->BSSID[i], | 1176 | rtl818x_iowrite8(priv, &priv->map->BSSID[i], |
| 1174 | info->bssid[i]); | 1177 | info->bssid[i]); |
| 1175 | 1178 | ||
| 1179 | if (priv->is_rtl8187b) | ||
| 1180 | reg = RTL818X_MSR_ENEDCA; | ||
| 1181 | else | ||
| 1182 | reg = 0; | ||
| 1183 | |||
| 1176 | if (is_valid_ether_addr(info->bssid)) { | 1184 | if (is_valid_ether_addr(info->bssid)) { |
| 1177 | reg = RTL818X_MSR_INFRA; | 1185 | reg |= RTL818X_MSR_INFRA; |
| 1178 | if (priv->is_rtl8187b) | ||
| 1179 | reg |= RTL818X_MSR_ENEDCA; | ||
| 1180 | rtl818x_iowrite8(priv, &priv->map->MSR, reg); | 1186 | rtl818x_iowrite8(priv, &priv->map->MSR, reg); |
| 1181 | } else { | 1187 | } else { |
| 1182 | reg = RTL818X_MSR_NO_LINK; | 1188 | reg |= RTL818X_MSR_NO_LINK; |
| 1183 | rtl818x_iowrite8(priv, &priv->map->MSR, reg); | 1189 | rtl818x_iowrite8(priv, &priv->map->MSR, reg); |
| 1184 | } | 1190 | } |
| 1185 | 1191 | ||
diff --git a/drivers/net/wireless/rtl818x/rtl8187_leds.c b/drivers/net/wireless/rtl818x/rtl8187_leds.c index b44253592243..cf9f899fe0e6 100644 --- a/drivers/net/wireless/rtl818x/rtl8187_leds.c +++ b/drivers/net/wireless/rtl818x/rtl8187_leds.c | |||
| @@ -208,11 +208,12 @@ void rtl8187_leds_exit(struct ieee80211_hw *dev) | |||
| 208 | { | 208 | { |
| 209 | struct rtl8187_priv *priv = dev->priv; | 209 | struct rtl8187_priv *priv = dev->priv; |
| 210 | 210 | ||
| 211 | rtl8187_unregister_led(&priv->led_tx); | ||
| 212 | /* turn the LED off before exiting */ | 211 | /* turn the LED off before exiting */ |
| 213 | queue_delayed_work(dev->workqueue, &priv->led_off, 0); | 212 | queue_delayed_work(dev->workqueue, &priv->led_off, 0); |
| 214 | cancel_delayed_work_sync(&priv->led_off); | 213 | cancel_delayed_work_sync(&priv->led_off); |
| 214 | cancel_delayed_work_sync(&priv->led_on); | ||
| 215 | rtl8187_unregister_led(&priv->led_rx); | 215 | rtl8187_unregister_led(&priv->led_rx); |
| 216 | rtl8187_unregister_led(&priv->led_tx); | ||
| 216 | } | 217 | } |
| 217 | #endif /* def CONFIG_RTL8187_LED */ | 218 | #endif /* def CONFIG_RTL8187_LED */ |
| 218 | 219 | ||
diff --git a/drivers/net/wireless/zd1211rw/zd_mac.c b/drivers/net/wireless/zd1211rw/zd_mac.c index 40b07b988224..3bd3c779fff3 100644 --- a/drivers/net/wireless/zd1211rw/zd_mac.c +++ b/drivers/net/wireless/zd1211rw/zd_mac.c | |||
| @@ -698,7 +698,7 @@ int zd_mac_rx(struct ieee80211_hw *hw, const u8 *buffer, unsigned int length) | |||
| 698 | && !mac->pass_ctrl) | 698 | && !mac->pass_ctrl) |
| 699 | return 0; | 699 | return 0; |
| 700 | 700 | ||
| 701 | fc = *(__le16 *)buffer; | 701 | fc = get_unaligned((__le16*)buffer); |
| 702 | need_padding = ieee80211_is_data_qos(fc) ^ ieee80211_has_a4(fc); | 702 | need_padding = ieee80211_is_data_qos(fc) ^ ieee80211_has_a4(fc); |
| 703 | 703 | ||
| 704 | skb = dev_alloc_skb(length + (need_padding ? 2 : 0)); | 704 | skb = dev_alloc_skb(length + (need_padding ? 2 : 0)); |
diff --git a/drivers/net/yellowfin.c b/drivers/net/yellowfin.c index a07580138e81..c2fd6187773f 100644 --- a/drivers/net/yellowfin.c +++ b/drivers/net/yellowfin.c | |||
| @@ -346,7 +346,7 @@ static int netdev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd); | |||
| 346 | static int yellowfin_open(struct net_device *dev); | 346 | static int yellowfin_open(struct net_device *dev); |
| 347 | static void yellowfin_timer(unsigned long data); | 347 | static void yellowfin_timer(unsigned long data); |
| 348 | static void yellowfin_tx_timeout(struct net_device *dev); | 348 | static void yellowfin_tx_timeout(struct net_device *dev); |
| 349 | static void yellowfin_init_ring(struct net_device *dev); | 349 | static int yellowfin_init_ring(struct net_device *dev); |
| 350 | static int yellowfin_start_xmit(struct sk_buff *skb, struct net_device *dev); | 350 | static int yellowfin_start_xmit(struct sk_buff *skb, struct net_device *dev); |
| 351 | static irqreturn_t yellowfin_interrupt(int irq, void *dev_instance); | 351 | static irqreturn_t yellowfin_interrupt(int irq, void *dev_instance); |
| 352 | static int yellowfin_rx(struct net_device *dev); | 352 | static int yellowfin_rx(struct net_device *dev); |
| @@ -573,19 +573,24 @@ static int yellowfin_open(struct net_device *dev) | |||
| 573 | { | 573 | { |
| 574 | struct yellowfin_private *yp = netdev_priv(dev); | 574 | struct yellowfin_private *yp = netdev_priv(dev); |
| 575 | void __iomem *ioaddr = yp->base; | 575 | void __iomem *ioaddr = yp->base; |
| 576 | int i; | 576 | int i, ret; |
| 577 | 577 | ||
| 578 | /* Reset the chip. */ | 578 | /* Reset the chip. */ |
| 579 | iowrite32(0x80000000, ioaddr + DMACtrl); | 579 | iowrite32(0x80000000, ioaddr + DMACtrl); |
| 580 | 580 | ||
| 581 | i = request_irq(dev->irq, &yellowfin_interrupt, IRQF_SHARED, dev->name, dev); | 581 | ret = request_irq(dev->irq, &yellowfin_interrupt, IRQF_SHARED, dev->name, dev); |
| 582 | if (i) return i; | 582 | if (ret) |
| 583 | return ret; | ||
| 583 | 584 | ||
| 584 | if (yellowfin_debug > 1) | 585 | if (yellowfin_debug > 1) |
| 585 | printk(KERN_DEBUG "%s: yellowfin_open() irq %d.\n", | 586 | printk(KERN_DEBUG "%s: yellowfin_open() irq %d.\n", |
| 586 | dev->name, dev->irq); | 587 | dev->name, dev->irq); |
| 587 | 588 | ||
| 588 | yellowfin_init_ring(dev); | 589 | ret = yellowfin_init_ring(dev); |
| 590 | if (ret) { | ||
| 591 | free_irq(dev->irq, dev); | ||
| 592 | return ret; | ||
| 593 | } | ||
| 589 | 594 | ||
| 590 | iowrite32(yp->rx_ring_dma, ioaddr + RxPtr); | 595 | iowrite32(yp->rx_ring_dma, ioaddr + RxPtr); |
| 591 | iowrite32(yp->tx_ring_dma, ioaddr + TxPtr); | 596 | iowrite32(yp->tx_ring_dma, ioaddr + TxPtr); |
| @@ -725,10 +730,10 @@ static void yellowfin_tx_timeout(struct net_device *dev) | |||
| 725 | } | 730 | } |
| 726 | 731 | ||
| 727 | /* Initialize the Rx and Tx rings, along with various 'dev' bits. */ | 732 | /* Initialize the Rx and Tx rings, along with various 'dev' bits. */ |
| 728 | static void yellowfin_init_ring(struct net_device *dev) | 733 | static int yellowfin_init_ring(struct net_device *dev) |
| 729 | { | 734 | { |
| 730 | struct yellowfin_private *yp = netdev_priv(dev); | 735 | struct yellowfin_private *yp = netdev_priv(dev); |
| 731 | int i; | 736 | int i, j; |
| 732 | 737 | ||
| 733 | yp->tx_full = 0; | 738 | yp->tx_full = 0; |
| 734 | yp->cur_rx = yp->cur_tx = 0; | 739 | yp->cur_rx = yp->cur_tx = 0; |
| @@ -753,6 +758,11 @@ static void yellowfin_init_ring(struct net_device *dev) | |||
| 753 | yp->rx_ring[i].addr = cpu_to_le32(pci_map_single(yp->pci_dev, | 758 | yp->rx_ring[i].addr = cpu_to_le32(pci_map_single(yp->pci_dev, |
| 754 | skb->data, yp->rx_buf_sz, PCI_DMA_FROMDEVICE)); | 759 | skb->data, yp->rx_buf_sz, PCI_DMA_FROMDEVICE)); |
| 755 | } | 760 | } |
| 761 | if (i != RX_RING_SIZE) { | ||
| 762 | for (j = 0; j < i; j++) | ||
| 763 | dev_kfree_skb(yp->rx_skbuff[j]); | ||
| 764 | return -ENOMEM; | ||
| 765 | } | ||
| 756 | yp->rx_ring[i-1].dbdma_cmd = cpu_to_le32(CMD_STOP); | 766 | yp->rx_ring[i-1].dbdma_cmd = cpu_to_le32(CMD_STOP); |
| 757 | yp->dirty_rx = (unsigned int)(i - RX_RING_SIZE); | 767 | yp->dirty_rx = (unsigned int)(i - RX_RING_SIZE); |
| 758 | 768 | ||
| @@ -769,8 +779,6 @@ static void yellowfin_init_ring(struct net_device *dev) | |||
| 769 | yp->tx_ring[--i].dbdma_cmd = cpu_to_le32(CMD_STOP | BRANCH_ALWAYS); | 779 | yp->tx_ring[--i].dbdma_cmd = cpu_to_le32(CMD_STOP | BRANCH_ALWAYS); |
| 770 | #else | 780 | #else |
| 771 | { | 781 | { |
| 772 | int j; | ||
| 773 | |||
| 774 | /* Tx ring needs a pair of descriptors, the second for the status. */ | 782 | /* Tx ring needs a pair of descriptors, the second for the status. */ |
| 775 | for (i = 0; i < TX_RING_SIZE; i++) { | 783 | for (i = 0; i < TX_RING_SIZE; i++) { |
| 776 | j = 2*i; | 784 | j = 2*i; |
| @@ -805,7 +813,7 @@ static void yellowfin_init_ring(struct net_device *dev) | |||
| 805 | } | 813 | } |
| 806 | #endif | 814 | #endif |
| 807 | yp->tx_tail_desc = &yp->tx_status[0]; | 815 | yp->tx_tail_desc = &yp->tx_status[0]; |
| 808 | return; | 816 | return 0; |
| 809 | } | 817 | } |
| 810 | 818 | ||
| 811 | static int yellowfin_start_xmit(struct sk_buff *skb, struct net_device *dev) | 819 | static int yellowfin_start_xmit(struct sk_buff *skb, struct net_device *dev) |
diff --git a/drivers/net/zorro8390.c b/drivers/net/zorro8390.c index 37c84e3b8be0..81c753a617ab 100644 --- a/drivers/net/zorro8390.c +++ b/drivers/net/zorro8390.c | |||
| @@ -120,6 +120,9 @@ static int __devinit zorro8390_init_one(struct zorro_dev *z, | |||
| 120 | for (i = ARRAY_SIZE(cards)-1; i >= 0; i--) | 120 | for (i = ARRAY_SIZE(cards)-1; i >= 0; i--) |
| 121 | if (z->id == cards[i].id) | 121 | if (z->id == cards[i].id) |
| 122 | break; | 122 | break; |
| 123 | if (i < 0) | ||
| 124 | return -ENODEV; | ||
| 125 | |||
| 123 | board = z->resource.start; | 126 | board = z->resource.start; |
| 124 | ioaddr = board+cards[i].offset; | 127 | ioaddr = board+cards[i].offset; |
| 125 | dev = alloc_ei_netdev(); | 128 | dev = alloc_ei_netdev(); |
diff --git a/drivers/of/of_mdio.c b/drivers/of/of_mdio.c index aee967d7f760..bacaa536fd51 100644 --- a/drivers/of/of_mdio.c +++ b/drivers/of/of_mdio.c | |||
| @@ -9,6 +9,10 @@ | |||
| 9 | * out of the OpenFirmware device tree and using it to populate an mii_bus. | 9 | * out of the OpenFirmware device tree and using it to populate an mii_bus. |
| 10 | */ | 10 | */ |
| 11 | 11 | ||
| 12 | #include <linux/kernel.h> | ||
| 13 | #include <linux/device.h> | ||
| 14 | #include <linux/netdevice.h> | ||
| 15 | #include <linux/err.h> | ||
| 12 | #include <linux/phy.h> | 16 | #include <linux/phy.h> |
| 13 | #include <linux/of.h> | 17 | #include <linux/of.h> |
| 14 | #include <linux/of_mdio.h> | 18 | #include <linux/of_mdio.h> |
| @@ -137,3 +141,41 @@ struct phy_device *of_phy_connect(struct net_device *dev, | |||
| 137 | return phy_connect_direct(dev, phy, hndlr, flags, iface) ? NULL : phy; | 141 | return phy_connect_direct(dev, phy, hndlr, flags, iface) ? NULL : phy; |
| 138 | } | 142 | } |
| 139 | EXPORT_SYMBOL(of_phy_connect); | 143 | EXPORT_SYMBOL(of_phy_connect); |
| 144 | |||
| 145 | /** | ||
| 146 | * of_phy_connect_fixed_link - Parse fixed-link property and return a dummy phy | ||
| 147 | * @dev: pointer to net_device claiming the phy | ||
| 148 | * @hndlr: Link state callback for the network device | ||
| 149 | * @iface: PHY data interface type | ||
| 150 | * | ||
| 151 | * This function is a temporary stop-gap and will be removed soon. It is | ||
| 152 | * only to support the fs_enet, ucc_geth and gianfar Ethernet drivers. Do | ||
| 153 | * not call this function from new drivers. | ||
| 154 | */ | ||
| 155 | struct phy_device *of_phy_connect_fixed_link(struct net_device *dev, | ||
| 156 | void (*hndlr)(struct net_device *), | ||
| 157 | phy_interface_t iface) | ||
| 158 | { | ||
| 159 | struct device_node *net_np; | ||
| 160 | char bus_id[MII_BUS_ID_SIZE + 3]; | ||
| 161 | struct phy_device *phy; | ||
| 162 | const u32 *phy_id; | ||
| 163 | int sz; | ||
| 164 | |||
| 165 | if (!dev->dev.parent) | ||
| 166 | return NULL; | ||
| 167 | |||
| 168 | net_np = dev_archdata_get_node(&dev->dev.parent->archdata); | ||
| 169 | if (!net_np) | ||
| 170 | return NULL; | ||
| 171 | |||
| 172 | phy_id = of_get_property(net_np, "fixed-link", &sz); | ||
| 173 | if (!phy_id || sz < sizeof(*phy_id)) | ||
| 174 | return NULL; | ||
| 175 | |||
| 176 | sprintf(bus_id, PHY_ID_FMT, "0", phy_id[0]); | ||
| 177 | |||
| 178 | phy = phy_connect(dev, bus_id, hndlr, 0, iface); | ||
| 179 | return IS_ERR(phy) ? NULL : phy; | ||
| 180 | } | ||
| 181 | EXPORT_SYMBOL(of_phy_connect_fixed_link); | ||
diff --git a/drivers/parisc/ccio-dma.c b/drivers/parisc/ccio-dma.c index 0f0e0b919ef4..a45b0c0d574e 100644 --- a/drivers/parisc/ccio-dma.c +++ b/drivers/parisc/ccio-dma.c | |||
| @@ -70,7 +70,6 @@ | |||
| 70 | #undef CCIO_COLLECT_STATS | 70 | #undef CCIO_COLLECT_STATS |
| 71 | #endif | 71 | #endif |
| 72 | 72 | ||
| 73 | #include <linux/proc_fs.h> | ||
| 74 | #include <asm/runway.h> /* for proc_runway_root */ | 73 | #include <asm/runway.h> /* for proc_runway_root */ |
| 75 | 74 | ||
| 76 | #ifdef DEBUG_CCIO_INIT | 75 | #ifdef DEBUG_CCIO_INIT |
diff --git a/drivers/parisc/dino.c b/drivers/parisc/dino.c index c590974e9815..d69bde6a2343 100644 --- a/drivers/parisc/dino.c +++ b/drivers/parisc/dino.c | |||
| @@ -614,7 +614,7 @@ dino_fixup_bus(struct pci_bus *bus) | |||
| 614 | dev_name(&bus->self->dev), i, | 614 | dev_name(&bus->self->dev), i, |
| 615 | bus->self->resource[i].start, | 615 | bus->self->resource[i].start, |
| 616 | bus->self->resource[i].end); | 616 | bus->self->resource[i].end); |
| 617 | pci_assign_resource(bus->self, i); | 617 | WARN_ON(pci_assign_resource(bus->self, i)); |
| 618 | DBG("DEBUG %s after assign %d [0x%lx,0x%lx]\n", | 618 | DBG("DEBUG %s after assign %d [0x%lx,0x%lx]\n", |
| 619 | dev_name(&bus->self->dev), i, | 619 | dev_name(&bus->self->dev), i, |
| 620 | bus->self->resource[i].start, | 620 | bus->self->resource[i].start, |
diff --git a/drivers/parisc/eisa_eeprom.c b/drivers/parisc/eisa_eeprom.c index 685d94e69d44..8c0b26e9b98a 100644 --- a/drivers/parisc/eisa_eeprom.c +++ b/drivers/parisc/eisa_eeprom.c | |||
| @@ -55,7 +55,7 @@ static ssize_t eisa_eeprom_read(struct file * file, | |||
| 55 | ssize_t ret; | 55 | ssize_t ret; |
| 56 | int i; | 56 | int i; |
| 57 | 57 | ||
| 58 | if (*ppos >= HPEE_MAX_LENGTH) | 58 | if (*ppos < 0 || *ppos >= HPEE_MAX_LENGTH) |
| 59 | return 0; | 59 | return 0; |
| 60 | 60 | ||
| 61 | count = *ppos + count < HPEE_MAX_LENGTH ? count : HPEE_MAX_LENGTH - *ppos; | 61 | count = *ppos + count < HPEE_MAX_LENGTH ? count : HPEE_MAX_LENGTH - *ppos; |
diff --git a/drivers/parisc/hppb.c b/drivers/parisc/hppb.c index 13856415b432..815db175d427 100644 --- a/drivers/parisc/hppb.c +++ b/drivers/parisc/hppb.c | |||
| @@ -62,7 +62,8 @@ static int hppb_probe(struct parisc_device *dev) | |||
| 62 | } | 62 | } |
| 63 | card = card->next; | 63 | card = card->next; |
| 64 | } | 64 | } |
| 65 | printk(KERN_INFO "Found GeckoBoa at 0x%x\n", dev->hpa.start); | 65 | printk(KERN_INFO "Found GeckoBoa at 0x%llx\n", |
| 66 | (unsigned long long) dev->hpa.start); | ||
| 66 | 67 | ||
| 67 | card->hpa = dev->hpa.start; | 68 | card->hpa = dev->hpa.start; |
| 68 | card->mmio_region.name = "HP-PB Bus"; | 69 | card->mmio_region.name = "HP-PB Bus"; |
| @@ -73,8 +74,10 @@ static int hppb_probe(struct parisc_device *dev) | |||
| 73 | 74 | ||
| 74 | status = ccio_request_resource(dev, &card->mmio_region); | 75 | status = ccio_request_resource(dev, &card->mmio_region); |
| 75 | if(status < 0) { | 76 | if(status < 0) { |
| 76 | printk(KERN_ERR "%s: failed to claim HP-PB bus space (%08x, %08x)\n", | 77 | printk(KERN_ERR "%s: failed to claim HP-PB " |
| 77 | __FILE__, card->mmio_region.start, card->mmio_region.end); | 78 | "bus space (0x%08llx, 0x%08llx)\n", |
| 79 | __FILE__, (unsigned long long) card->mmio_region.start, | ||
| 80 | (unsigned long long) card->mmio_region.end); | ||
| 78 | } | 81 | } |
| 79 | 82 | ||
| 80 | return 0; | 83 | return 0; |
diff --git a/drivers/parisc/lba_pci.c b/drivers/parisc/lba_pci.c index ede614616f8e..3aeb3279c92a 100644 --- a/drivers/parisc/lba_pci.c +++ b/drivers/parisc/lba_pci.c | |||
| @@ -992,7 +992,7 @@ lba_pat_resources(struct parisc_device *pa_dev, struct lba_device *lba_dev) | |||
| 992 | return; | 992 | return; |
| 993 | 993 | ||
| 994 | io_pdc_cell = kzalloc(sizeof(pdc_pat_cell_mod_maddr_block_t), GFP_KERNEL); | 994 | io_pdc_cell = kzalloc(sizeof(pdc_pat_cell_mod_maddr_block_t), GFP_KERNEL); |
| 995 | if (!pa_pdc_cell) { | 995 | if (!io_pdc_cell) { |
| 996 | kfree(pa_pdc_cell); | 996 | kfree(pa_pdc_cell); |
| 997 | return; | 997 | return; |
| 998 | } | 998 | } |
diff --git a/drivers/parisc/pdc_stable.c b/drivers/parisc/pdc_stable.c index f9f9a5f1bbd0..13a64bc081b6 100644 --- a/drivers/parisc/pdc_stable.c +++ b/drivers/parisc/pdc_stable.c | |||
| @@ -370,7 +370,7 @@ pdcspath_layer_read(struct pdcspath_entry *entry, char *buf) | |||
| 370 | if (!i) /* entry is not ready */ | 370 | if (!i) /* entry is not ready */ |
| 371 | return -ENODATA; | 371 | return -ENODATA; |
| 372 | 372 | ||
| 373 | for (i = 0; devpath->layers[i] && (likely(i < 6)); i++) | 373 | for (i = 0; i < 6 && devpath->layers[i]; i++) |
| 374 | out += sprintf(out, "%u ", devpath->layers[i]); | 374 | out += sprintf(out, "%u ", devpath->layers[i]); |
| 375 | 375 | ||
| 376 | out += sprintf(out, "\n"); | 376 | out += sprintf(out, "\n"); |
diff --git a/drivers/pci/hotplug/sgi_hotplug.c b/drivers/pci/hotplug/sgi_hotplug.c index a4494d78e7c2..8aebe1e9d3d6 100644 --- a/drivers/pci/hotplug/sgi_hotplug.c +++ b/drivers/pci/hotplug/sgi_hotplug.c | |||
| @@ -90,11 +90,10 @@ static struct hotplug_slot_ops sn_hotplug_slot_ops = { | |||
| 90 | 90 | ||
| 91 | static DEFINE_MUTEX(sn_hotplug_mutex); | 91 | static DEFINE_MUTEX(sn_hotplug_mutex); |
| 92 | 92 | ||
| 93 | static ssize_t path_show (struct hotplug_slot *bss_hotplug_slot, | 93 | static ssize_t path_show(struct pci_slot *pci_slot, char *buf) |
| 94 | char *buf) | ||
| 95 | { | 94 | { |
| 96 | int retval = -ENOENT; | 95 | int retval = -ENOENT; |
| 97 | struct slot *slot = bss_hotplug_slot->private; | 96 | struct slot *slot = pci_slot->hotplug->private; |
| 98 | 97 | ||
| 99 | if (!slot) | 98 | if (!slot) |
| 100 | return retval; | 99 | return retval; |
| @@ -103,7 +102,7 @@ static ssize_t path_show (struct hotplug_slot *bss_hotplug_slot, | |||
| 103 | return retval; | 102 | return retval; |
| 104 | } | 103 | } |
| 105 | 104 | ||
| 106 | static struct hotplug_slot_attribute sn_slot_path_attr = __ATTR_RO(path); | 105 | static struct pci_slot_attribute sn_slot_path_attr = __ATTR_RO(path); |
| 107 | 106 | ||
| 108 | static int sn_pci_slot_valid(struct pci_bus *pci_bus, int device) | 107 | static int sn_pci_slot_valid(struct pci_bus *pci_bus, int device) |
| 109 | { | 108 | { |
diff --git a/drivers/pci/intel-iommu.c b/drivers/pci/intel-iommu.c index 833509b53527..562221e11917 100644 --- a/drivers/pci/intel-iommu.c +++ b/drivers/pci/intel-iommu.c | |||
| @@ -1506,7 +1506,6 @@ static int domain_context_mapping_one(struct dmar_domain *domain, int segment, | |||
| 1506 | } | 1506 | } |
| 1507 | 1507 | ||
| 1508 | set_bit(num, iommu->domain_ids); | 1508 | set_bit(num, iommu->domain_ids); |
| 1509 | set_bit(iommu->seq_id, &domain->iommu_bmp); | ||
| 1510 | iommu->domains[num] = domain; | 1509 | iommu->domains[num] = domain; |
| 1511 | id = num; | 1510 | id = num; |
| 1512 | } | 1511 | } |
| @@ -1649,6 +1648,14 @@ static int domain_context_mapped(struct pci_dev *pdev) | |||
| 1649 | tmp->devfn); | 1648 | tmp->devfn); |
| 1650 | } | 1649 | } |
| 1651 | 1650 | ||
| 1651 | /* Returns a number of VTD pages, but aligned to MM page size */ | ||
| 1652 | static inline unsigned long aligned_nrpages(unsigned long host_addr, | ||
| 1653 | size_t size) | ||
| 1654 | { | ||
| 1655 | host_addr &= ~PAGE_MASK; | ||
| 1656 | return PAGE_ALIGN(host_addr + size) >> VTD_PAGE_SHIFT; | ||
| 1657 | } | ||
| 1658 | |||
| 1652 | static int __domain_mapping(struct dmar_domain *domain, unsigned long iov_pfn, | 1659 | static int __domain_mapping(struct dmar_domain *domain, unsigned long iov_pfn, |
| 1653 | struct scatterlist *sg, unsigned long phys_pfn, | 1660 | struct scatterlist *sg, unsigned long phys_pfn, |
| 1654 | unsigned long nr_pages, int prot) | 1661 | unsigned long nr_pages, int prot) |
| @@ -1676,7 +1683,7 @@ static int __domain_mapping(struct dmar_domain *domain, unsigned long iov_pfn, | |||
| 1676 | uint64_t tmp; | 1683 | uint64_t tmp; |
| 1677 | 1684 | ||
| 1678 | if (!sg_res) { | 1685 | if (!sg_res) { |
| 1679 | sg_res = (sg->offset + sg->length + VTD_PAGE_SIZE - 1) >> VTD_PAGE_SHIFT; | 1686 | sg_res = aligned_nrpages(sg->offset, sg->length); |
| 1680 | sg->dma_address = ((dma_addr_t)iov_pfn << VTD_PAGE_SHIFT) + sg->offset; | 1687 | sg->dma_address = ((dma_addr_t)iov_pfn << VTD_PAGE_SHIFT) + sg->offset; |
| 1681 | sg->dma_length = sg->length; | 1688 | sg->dma_length = sg->length; |
| 1682 | pteval = page_to_phys(sg_page(sg)) | prot; | 1689 | pteval = page_to_phys(sg_page(sg)) | prot; |
| @@ -2416,14 +2423,6 @@ error: | |||
| 2416 | return ret; | 2423 | return ret; |
| 2417 | } | 2424 | } |
| 2418 | 2425 | ||
| 2419 | /* Returns a number of VTD pages, but aligned to MM page size */ | ||
| 2420 | static inline unsigned long aligned_nrpages(unsigned long host_addr, | ||
| 2421 | size_t size) | ||
| 2422 | { | ||
| 2423 | host_addr &= ~PAGE_MASK; | ||
| 2424 | return PAGE_ALIGN(host_addr + size) >> VTD_PAGE_SHIFT; | ||
| 2425 | } | ||
| 2426 | |||
| 2427 | /* This takes a number of _MM_ pages, not VTD pages */ | 2426 | /* This takes a number of _MM_ pages, not VTD pages */ |
| 2428 | static struct iova *intel_alloc_iova(struct device *dev, | 2427 | static struct iova *intel_alloc_iova(struct device *dev, |
| 2429 | struct dmar_domain *domain, | 2428 | struct dmar_domain *domain, |
| @@ -2552,6 +2551,7 @@ static dma_addr_t __intel_map_single(struct device *hwdev, phys_addr_t paddr, | |||
| 2552 | int prot = 0; | 2551 | int prot = 0; |
| 2553 | int ret; | 2552 | int ret; |
| 2554 | struct intel_iommu *iommu; | 2553 | struct intel_iommu *iommu; |
| 2554 | unsigned long paddr_pfn = paddr >> PAGE_SHIFT; | ||
| 2555 | 2555 | ||
| 2556 | BUG_ON(dir == DMA_NONE); | 2556 | BUG_ON(dir == DMA_NONE); |
| 2557 | 2557 | ||
| @@ -2586,7 +2586,7 @@ static dma_addr_t __intel_map_single(struct device *hwdev, phys_addr_t paddr, | |||
| 2586 | * is not a big problem | 2586 | * is not a big problem |
| 2587 | */ | 2587 | */ |
| 2588 | ret = domain_pfn_mapping(domain, mm_to_dma_pfn(iova->pfn_lo), | 2588 | ret = domain_pfn_mapping(domain, mm_to_dma_pfn(iova->pfn_lo), |
| 2589 | paddr >> VTD_PAGE_SHIFT, size, prot); | 2589 | mm_to_dma_pfn(paddr_pfn), size, prot); |
| 2590 | if (ret) | 2590 | if (ret) |
| 2591 | goto error; | 2591 | goto error; |
| 2592 | 2592 | ||
| @@ -2876,7 +2876,7 @@ static int intel_map_sg(struct device *hwdev, struct scatterlist *sglist, int ne | |||
| 2876 | 2876 | ||
| 2877 | start_vpfn = mm_to_dma_pfn(iova->pfn_lo); | 2877 | start_vpfn = mm_to_dma_pfn(iova->pfn_lo); |
| 2878 | 2878 | ||
| 2879 | ret = domain_sg_mapping(domain, start_vpfn, sglist, mm_to_dma_pfn(size), prot); | 2879 | ret = domain_sg_mapping(domain, start_vpfn, sglist, size, prot); |
| 2880 | if (unlikely(ret)) { | 2880 | if (unlikely(ret)) { |
| 2881 | /* clear the page */ | 2881 | /* clear the page */ |
| 2882 | dma_pte_clear_range(domain, start_vpfn, | 2882 | dma_pte_clear_range(domain, start_vpfn, |
| @@ -3421,6 +3421,7 @@ static int md_domain_init(struct dmar_domain *domain, int guest_width) | |||
| 3421 | 3421 | ||
| 3422 | domain->iommu_count = 0; | 3422 | domain->iommu_count = 0; |
| 3423 | domain->iommu_coherency = 0; | 3423 | domain->iommu_coherency = 0; |
| 3424 | domain->iommu_snooping = 0; | ||
| 3424 | domain->max_addr = 0; | 3425 | domain->max_addr = 0; |
| 3425 | 3426 | ||
| 3426 | /* always allocate the top pgd */ | 3427 | /* always allocate the top pgd */ |
diff --git a/drivers/pci/pci-driver.c b/drivers/pci/pci-driver.c index d76c4c85367e..f99bc7f089f1 100644 --- a/drivers/pci/pci-driver.c +++ b/drivers/pci/pci-driver.c | |||
| @@ -508,7 +508,7 @@ static int pci_restore_standard_config(struct pci_dev *pci_dev) | |||
| 508 | return error; | 508 | return error; |
| 509 | } | 509 | } |
| 510 | 510 | ||
| 511 | return pci_dev->state_saved ? pci_restore_state(pci_dev) : 0; | 511 | return pci_restore_state(pci_dev); |
| 512 | } | 512 | } |
| 513 | 513 | ||
| 514 | static void pci_pm_default_resume_noirq(struct pci_dev *pci_dev) | 514 | static void pci_pm_default_resume_noirq(struct pci_dev *pci_dev) |
diff --git a/drivers/pci/pci.c b/drivers/pci/pci.c index dbd0f947f497..7b70312181d7 100644 --- a/drivers/pci/pci.c +++ b/drivers/pci/pci.c | |||
| @@ -846,6 +846,8 @@ pci_restore_state(struct pci_dev *dev) | |||
| 846 | int i; | 846 | int i; |
| 847 | u32 val; | 847 | u32 val; |
| 848 | 848 | ||
| 849 | if (!dev->state_saved) | ||
| 850 | return 0; | ||
| 849 | /* PCI Express register must be restored first */ | 851 | /* PCI Express register must be restored first */ |
| 850 | pci_restore_pcie_state(dev); | 852 | pci_restore_pcie_state(dev); |
| 851 | 853 | ||
diff --git a/drivers/pci/setup-res.c b/drivers/pci/setup-res.c index b711fb7181e2..1898c7b47907 100644 --- a/drivers/pci/setup-res.c +++ b/drivers/pci/setup-res.c | |||
| @@ -100,16 +100,16 @@ int pci_claim_resource(struct pci_dev *dev, int resource) | |||
| 100 | { | 100 | { |
| 101 | struct resource *res = &dev->resource[resource]; | 101 | struct resource *res = &dev->resource[resource]; |
| 102 | struct resource *root; | 102 | struct resource *root; |
| 103 | char *dtype = resource < PCI_BRIDGE_RESOURCES ? "device" : "bridge"; | ||
| 104 | int err; | 103 | int err; |
| 105 | 104 | ||
| 106 | root = pci_find_parent_resource(dev, res); | 105 | root = pci_find_parent_resource(dev, res); |
| 107 | 106 | ||
| 108 | err = -EINVAL; | 107 | err = -EINVAL; |
| 109 | if (root != NULL) | 108 | if (root != NULL) |
| 110 | err = insert_resource(root, res); | 109 | err = request_resource(root, res); |
| 111 | 110 | ||
| 112 | if (err) { | 111 | if (err) { |
| 112 | const char *dtype = resource < PCI_BRIDGE_RESOURCES ? "device" : "bridge"; | ||
| 113 | dev_err(&dev->dev, "BAR %d: %s of %s %pR\n", | 113 | dev_err(&dev->dev, "BAR %d: %s of %s %pR\n", |
| 114 | resource, | 114 | resource, |
| 115 | root ? "address space collision on" : | 115 | root ? "address space collision on" : |
diff --git a/drivers/platform/x86/Kconfig b/drivers/platform/x86/Kconfig index 46dad12f952f..77c6097ced80 100644 --- a/drivers/platform/x86/Kconfig +++ b/drivers/platform/x86/Kconfig | |||
| @@ -277,31 +277,6 @@ config THINKPAD_ACPI_UNSAFE_LEDS | |||
| 277 | Say N here, unless you are building a kernel for your own | 277 | Say N here, unless you are building a kernel for your own |
| 278 | use, and need to control the important firmware LEDs. | 278 | use, and need to control the important firmware LEDs. |
| 279 | 279 | ||
| 280 | config THINKPAD_ACPI_DOCK | ||
| 281 | bool "Legacy Docking Station Support" | ||
| 282 | depends on THINKPAD_ACPI | ||
| 283 | depends on ACPI_DOCK=n | ||
| 284 | default n | ||
| 285 | ---help--- | ||
| 286 | Allows the thinkpad_acpi driver to handle docking station events. | ||
| 287 | This support was made obsolete by the generic ACPI docking station | ||
| 288 | support (CONFIG_ACPI_DOCK). It will allow locking and removing the | ||
| 289 | laptop from the docking station, but will not properly connect PCI | ||
| 290 | devices. | ||
| 291 | |||
| 292 | If you are not sure, say N here. | ||
| 293 | |||
| 294 | config THINKPAD_ACPI_BAY | ||
| 295 | bool "Legacy Removable Bay Support" | ||
| 296 | depends on THINKPAD_ACPI | ||
| 297 | default y | ||
| 298 | ---help--- | ||
| 299 | Allows the thinkpad_acpi driver to handle removable bays. It will | ||
| 300 | electrically disable the device in the bay, and also generate | ||
| 301 | notifications when the bay lever is ejected or inserted. | ||
| 302 | |||
| 303 | If you are not sure, say Y here. | ||
| 304 | |||
| 305 | config THINKPAD_ACPI_VIDEO | 280 | config THINKPAD_ACPI_VIDEO |
| 306 | bool "Video output control support" | 281 | bool "Video output control support" |
| 307 | depends on THINKPAD_ACPI | 282 | depends on THINKPAD_ACPI |
diff --git a/drivers/platform/x86/acer-wmi.c b/drivers/platform/x86/acer-wmi.c index be2fd6f91639..fb45f5ee8df1 100644 --- a/drivers/platform/x86/acer-wmi.c +++ b/drivers/platform/x86/acer-wmi.c | |||
| @@ -973,7 +973,7 @@ static int acer_rfkill_set(void *data, bool blocked) | |||
| 973 | { | 973 | { |
| 974 | acpi_status status; | 974 | acpi_status status; |
| 975 | u32 cap = (unsigned long)data; | 975 | u32 cap = (unsigned long)data; |
| 976 | status = set_u32(!!blocked, cap); | 976 | status = set_u32(!blocked, cap); |
| 977 | if (ACPI_FAILURE(status)) | 977 | if (ACPI_FAILURE(status)) |
| 978 | return -ENODEV; | 978 | return -ENODEV; |
| 979 | return 0; | 979 | return 0; |
diff --git a/drivers/platform/x86/eeepc-laptop.c b/drivers/platform/x86/eeepc-laptop.c index ec560f16d720..222ffb892f22 100644 --- a/drivers/platform/x86/eeepc-laptop.c +++ b/drivers/platform/x86/eeepc-laptop.c | |||
| @@ -143,6 +143,7 @@ struct eeepc_hotk { | |||
| 143 | struct rfkill *bluetooth_rfkill; | 143 | struct rfkill *bluetooth_rfkill; |
| 144 | struct rfkill *wwan3g_rfkill; | 144 | struct rfkill *wwan3g_rfkill; |
| 145 | struct hotplug_slot *hotplug_slot; | 145 | struct hotplug_slot *hotplug_slot; |
| 146 | struct work_struct hotplug_work; | ||
| 146 | }; | 147 | }; |
| 147 | 148 | ||
| 148 | /* The actual device the driver binds to */ | 149 | /* The actual device the driver binds to */ |
| @@ -660,7 +661,7 @@ static int eeepc_get_adapter_status(struct hotplug_slot *hotplug_slot, | |||
| 660 | return 0; | 661 | return 0; |
| 661 | } | 662 | } |
| 662 | 663 | ||
| 663 | static void eeepc_rfkill_hotplug(void) | 664 | static void eeepc_hotplug_work(struct work_struct *work) |
| 664 | { | 665 | { |
| 665 | struct pci_dev *dev; | 666 | struct pci_dev *dev; |
| 666 | struct pci_bus *bus = pci_find_bus(0, 1); | 667 | struct pci_bus *bus = pci_find_bus(0, 1); |
| @@ -701,7 +702,7 @@ static void eeepc_rfkill_notify(acpi_handle handle, u32 event, void *data) | |||
| 701 | if (event != ACPI_NOTIFY_BUS_CHECK) | 702 | if (event != ACPI_NOTIFY_BUS_CHECK) |
| 702 | return; | 703 | return; |
| 703 | 704 | ||
| 704 | eeepc_rfkill_hotplug(); | 705 | schedule_work(&ehotk->hotplug_work); |
| 705 | } | 706 | } |
| 706 | 707 | ||
| 707 | static void eeepc_hotk_notify(struct acpi_device *device, u32 event) | 708 | static void eeepc_hotk_notify(struct acpi_device *device, u32 event) |
| @@ -892,7 +893,7 @@ static int eeepc_hotk_resume(struct acpi_device *device) | |||
| 892 | 893 | ||
| 893 | rfkill_set_sw_state(ehotk->wlan_rfkill, wlan != 1); | 894 | rfkill_set_sw_state(ehotk->wlan_rfkill, wlan != 1); |
| 894 | 895 | ||
| 895 | eeepc_rfkill_hotplug(); | 896 | schedule_work(&ehotk->hotplug_work); |
| 896 | } | 897 | } |
| 897 | 898 | ||
| 898 | if (ehotk->bluetooth_rfkill) | 899 | if (ehotk->bluetooth_rfkill) |
| @@ -1093,6 +1094,8 @@ static int eeepc_rfkill_init(struct device *dev) | |||
| 1093 | { | 1094 | { |
| 1094 | int result = 0; | 1095 | int result = 0; |
| 1095 | 1096 | ||
| 1097 | INIT_WORK(&ehotk->hotplug_work, eeepc_hotplug_work); | ||
| 1098 | |||
| 1096 | eeepc_register_rfkill_notifier("\\_SB.PCI0.P0P6"); | 1099 | eeepc_register_rfkill_notifier("\\_SB.PCI0.P0P6"); |
| 1097 | eeepc_register_rfkill_notifier("\\_SB.PCI0.P0P7"); | 1100 | eeepc_register_rfkill_notifier("\\_SB.PCI0.P0P7"); |
| 1098 | 1101 | ||
diff --git a/drivers/platform/x86/hp-wmi.c b/drivers/platform/x86/hp-wmi.c index ca508564a181..a2ad53e15874 100644 --- a/drivers/platform/x86/hp-wmi.c +++ b/drivers/platform/x86/hp-wmi.c | |||
| @@ -520,11 +520,13 @@ static int hp_wmi_resume_handler(struct platform_device *device) | |||
| 520 | * the input layer will only actually pass it on if the state | 520 | * the input layer will only actually pass it on if the state |
| 521 | * changed. | 521 | * changed. |
| 522 | */ | 522 | */ |
| 523 | 523 | if (hp_wmi_input_dev) { | |
| 524 | input_report_switch(hp_wmi_input_dev, SW_DOCK, hp_wmi_dock_state()); | 524 | input_report_switch(hp_wmi_input_dev, SW_DOCK, |
| 525 | input_report_switch(hp_wmi_input_dev, SW_TABLET_MODE, | 525 | hp_wmi_dock_state()); |
| 526 | hp_wmi_tablet_state()); | 526 | input_report_switch(hp_wmi_input_dev, SW_TABLET_MODE, |
| 527 | input_sync(hp_wmi_input_dev); | 527 | hp_wmi_tablet_state()); |
| 528 | input_sync(hp_wmi_input_dev); | ||
| 529 | } | ||
| 528 | 530 | ||
| 529 | return 0; | 531 | return 0; |
| 530 | } | 532 | } |
diff --git a/drivers/platform/x86/thinkpad_acpi.c b/drivers/platform/x86/thinkpad_acpi.c index a463fd72c495..e85600852502 100644 --- a/drivers/platform/x86/thinkpad_acpi.c +++ b/drivers/platform/x86/thinkpad_acpi.c | |||
| @@ -239,12 +239,6 @@ struct ibm_init_struct { | |||
| 239 | }; | 239 | }; |
| 240 | 240 | ||
| 241 | static struct { | 241 | static struct { |
| 242 | #ifdef CONFIG_THINKPAD_ACPI_BAY | ||
| 243 | u32 bay_status:1; | ||
| 244 | u32 bay_eject:1; | ||
| 245 | u32 bay_status2:1; | ||
| 246 | u32 bay_eject2:1; | ||
| 247 | #endif | ||
| 248 | u32 bluetooth:1; | 242 | u32 bluetooth:1; |
| 249 | u32 hotkey:1; | 243 | u32 hotkey:1; |
| 250 | u32 hotkey_mask:1; | 244 | u32 hotkey_mask:1; |
| @@ -589,18 +583,6 @@ static int acpi_ec_write(int i, u8 v) | |||
| 589 | return 1; | 583 | return 1; |
| 590 | } | 584 | } |
| 591 | 585 | ||
| 592 | #if defined(CONFIG_THINKPAD_ACPI_DOCK) || defined(CONFIG_THINKPAD_ACPI_BAY) | ||
| 593 | static int _sta(acpi_handle handle) | ||
| 594 | { | ||
| 595 | int status; | ||
| 596 | |||
| 597 | if (!handle || !acpi_evalf(handle, &status, "_STA", "d")) | ||
| 598 | status = 0; | ||
| 599 | |||
| 600 | return status; | ||
| 601 | } | ||
| 602 | #endif | ||
| 603 | |||
| 604 | static int issue_thinkpad_cmos_command(int cmos_cmd) | 586 | static int issue_thinkpad_cmos_command(int cmos_cmd) |
| 605 | { | 587 | { |
| 606 | if (!cmos_handle) | 588 | if (!cmos_handle) |
| @@ -784,6 +766,8 @@ static int dispatch_procfs_write(struct file *file, | |||
| 784 | 766 | ||
| 785 | if (!ibm || !ibm->write) | 767 | if (!ibm || !ibm->write) |
| 786 | return -EINVAL; | 768 | return -EINVAL; |
| 769 | if (count > PAGE_SIZE - 2) | ||
| 770 | return -EINVAL; | ||
| 787 | 771 | ||
| 788 | kernbuf = kmalloc(count + 2, GFP_KERNEL); | 772 | kernbuf = kmalloc(count + 2, GFP_KERNEL); |
| 789 | if (!kernbuf) | 773 | if (!kernbuf) |
| @@ -4442,293 +4426,6 @@ static struct ibm_struct light_driver_data = { | |||
| 4442 | }; | 4426 | }; |
| 4443 | 4427 | ||
| 4444 | /************************************************************************* | 4428 | /************************************************************************* |
| 4445 | * Dock subdriver | ||
| 4446 | */ | ||
| 4447 | |||
| 4448 | #ifdef CONFIG_THINKPAD_ACPI_DOCK | ||
| 4449 | |||
| 4450 | static void dock_notify(struct ibm_struct *ibm, u32 event); | ||
| 4451 | static int dock_read(char *p); | ||
| 4452 | static int dock_write(char *buf); | ||
| 4453 | |||
| 4454 | TPACPI_HANDLE(dock, root, "\\_SB.GDCK", /* X30, X31, X40 */ | ||
| 4455 | "\\_SB.PCI0.DOCK", /* 600e/x,770e,770x,A2xm/p,T20-22,X20-21 */ | ||
| 4456 | "\\_SB.PCI0.PCI1.DOCK", /* all others */ | ||
| 4457 | "\\_SB.PCI.ISA.SLCE", /* 570 */ | ||
| 4458 | ); /* A21e,G4x,R30,R31,R32,R40,R40e,R50e */ | ||
| 4459 | |||
| 4460 | /* don't list other alternatives as we install a notify handler on the 570 */ | ||
| 4461 | TPACPI_HANDLE(pci, root, "\\_SB.PCI"); /* 570 */ | ||
| 4462 | |||
| 4463 | static const struct acpi_device_id ibm_pci_device_ids[] = { | ||
| 4464 | {PCI_ROOT_HID_STRING, 0}, | ||
| 4465 | {"", 0}, | ||
| 4466 | }; | ||
| 4467 | |||
| 4468 | static struct tp_acpi_drv_struct ibm_dock_acpidriver[2] = { | ||
| 4469 | { | ||
| 4470 | .notify = dock_notify, | ||
| 4471 | .handle = &dock_handle, | ||
| 4472 | .type = ACPI_SYSTEM_NOTIFY, | ||
| 4473 | }, | ||
| 4474 | { | ||
| 4475 | /* THIS ONE MUST NEVER BE USED FOR DRIVER AUTOLOADING. | ||
| 4476 | * We just use it to get notifications of dock hotplug | ||
| 4477 | * in very old thinkpads */ | ||
| 4478 | .hid = ibm_pci_device_ids, | ||
| 4479 | .notify = dock_notify, | ||
| 4480 | .handle = &pci_handle, | ||
| 4481 | .type = ACPI_SYSTEM_NOTIFY, | ||
| 4482 | }, | ||
| 4483 | }; | ||
| 4484 | |||
| 4485 | static struct ibm_struct dock_driver_data[2] = { | ||
| 4486 | { | ||
| 4487 | .name = "dock", | ||
| 4488 | .read = dock_read, | ||
| 4489 | .write = dock_write, | ||
| 4490 | .acpi = &ibm_dock_acpidriver[0], | ||
| 4491 | }, | ||
| 4492 | { | ||
| 4493 | .name = "dock", | ||
| 4494 | .acpi = &ibm_dock_acpidriver[1], | ||
| 4495 | }, | ||
| 4496 | }; | ||
| 4497 | |||
| 4498 | #define dock_docked() (_sta(dock_handle) & 1) | ||
| 4499 | |||
| 4500 | static int __init dock_init(struct ibm_init_struct *iibm) | ||
| 4501 | { | ||
| 4502 | vdbg_printk(TPACPI_DBG_INIT, "initializing dock subdriver\n"); | ||
| 4503 | |||
| 4504 | TPACPI_ACPIHANDLE_INIT(dock); | ||
| 4505 | |||
| 4506 | vdbg_printk(TPACPI_DBG_INIT, "dock is %s\n", | ||
| 4507 | str_supported(dock_handle != NULL)); | ||
| 4508 | |||
| 4509 | return (dock_handle)? 0 : 1; | ||
| 4510 | } | ||
| 4511 | |||
| 4512 | static int __init dock_init2(struct ibm_init_struct *iibm) | ||
| 4513 | { | ||
| 4514 | int dock2_needed; | ||
| 4515 | |||
| 4516 | vdbg_printk(TPACPI_DBG_INIT, "initializing dock subdriver part 2\n"); | ||
| 4517 | |||
| 4518 | if (dock_driver_data[0].flags.acpi_driver_registered && | ||
| 4519 | dock_driver_data[0].flags.acpi_notify_installed) { | ||
| 4520 | TPACPI_ACPIHANDLE_INIT(pci); | ||
| 4521 | dock2_needed = (pci_handle != NULL); | ||
| 4522 | vdbg_printk(TPACPI_DBG_INIT, | ||
| 4523 | "dock PCI handler for the TP 570 is %s\n", | ||
| 4524 | str_supported(dock2_needed)); | ||
| 4525 | } else { | ||
| 4526 | vdbg_printk(TPACPI_DBG_INIT, | ||
| 4527 | "dock subdriver part 2 not required\n"); | ||
| 4528 | dock2_needed = 0; | ||
| 4529 | } | ||
| 4530 | |||
| 4531 | return (dock2_needed)? 0 : 1; | ||
| 4532 | } | ||
| 4533 | |||
| 4534 | static void dock_notify(struct ibm_struct *ibm, u32 event) | ||
| 4535 | { | ||
| 4536 | int docked = dock_docked(); | ||
| 4537 | int pci = ibm->acpi->hid && ibm->acpi->device && | ||
| 4538 | acpi_match_device_ids(ibm->acpi->device, ibm_pci_device_ids); | ||
| 4539 | int data; | ||
| 4540 | |||
| 4541 | if (event == 1 && !pci) /* 570 */ | ||
| 4542 | data = 1; /* button */ | ||
| 4543 | else if (event == 1 && pci) /* 570 */ | ||
| 4544 | data = 3; /* dock */ | ||
| 4545 | else if (event == 3 && docked) | ||
| 4546 | data = 1; /* button */ | ||
| 4547 | else if (event == 3 && !docked) | ||
| 4548 | data = 2; /* undock */ | ||
| 4549 | else if (event == 0 && docked) | ||
| 4550 | data = 3; /* dock */ | ||
| 4551 | else { | ||
| 4552 | printk(TPACPI_ERR "unknown dock event %d, status %d\n", | ||
| 4553 | event, _sta(dock_handle)); | ||
| 4554 | data = 0; /* unknown */ | ||
| 4555 | } | ||
| 4556 | acpi_bus_generate_proc_event(ibm->acpi->device, event, data); | ||
| 4557 | acpi_bus_generate_netlink_event(ibm->acpi->device->pnp.device_class, | ||
| 4558 | dev_name(&ibm->acpi->device->dev), | ||
| 4559 | event, data); | ||
| 4560 | } | ||
| 4561 | |||
| 4562 | static int dock_read(char *p) | ||
| 4563 | { | ||
| 4564 | int len = 0; | ||
| 4565 | int docked = dock_docked(); | ||
| 4566 | |||
| 4567 | if (!dock_handle) | ||
| 4568 | len += sprintf(p + len, "status:\t\tnot supported\n"); | ||
| 4569 | else if (!docked) | ||
| 4570 | len += sprintf(p + len, "status:\t\tundocked\n"); | ||
| 4571 | else { | ||
| 4572 | len += sprintf(p + len, "status:\t\tdocked\n"); | ||
| 4573 | len += sprintf(p + len, "commands:\tdock, undock\n"); | ||
| 4574 | } | ||
| 4575 | |||
| 4576 | return len; | ||
| 4577 | } | ||
| 4578 | |||
| 4579 | static int dock_write(char *buf) | ||
| 4580 | { | ||
| 4581 | char *cmd; | ||
| 4582 | |||
| 4583 | if (!dock_docked()) | ||
| 4584 | return -ENODEV; | ||
| 4585 | |||
| 4586 | while ((cmd = next_cmd(&buf))) { | ||
| 4587 | if (strlencmp(cmd, "undock") == 0) { | ||
| 4588 | if (!acpi_evalf(dock_handle, NULL, "_DCK", "vd", 0) || | ||
| 4589 | !acpi_evalf(dock_handle, NULL, "_EJ0", "vd", 1)) | ||
| 4590 | return -EIO; | ||
| 4591 | } else if (strlencmp(cmd, "dock") == 0) { | ||
| 4592 | if (!acpi_evalf(dock_handle, NULL, "_DCK", "vd", 1)) | ||
| 4593 | return -EIO; | ||
| 4594 | } else | ||
| 4595 | return -EINVAL; | ||
| 4596 | } | ||
| 4597 | |||
| 4598 | return 0; | ||
| 4599 | } | ||
| 4600 | |||
| 4601 | #endif /* CONFIG_THINKPAD_ACPI_DOCK */ | ||
| 4602 | |||
| 4603 | /************************************************************************* | ||
| 4604 | * Bay subdriver | ||
| 4605 | */ | ||
| 4606 | |||
| 4607 | #ifdef CONFIG_THINKPAD_ACPI_BAY | ||
| 4608 | |||
| 4609 | TPACPI_HANDLE(bay, root, "\\_SB.PCI.IDE.SECN.MAST", /* 570 */ | ||
| 4610 | "\\_SB.PCI0.IDE0.IDES.IDSM", /* 600e/x, 770e, 770x */ | ||
| 4611 | "\\_SB.PCI0.SATA.SCND.MSTR", /* T60, X60, Z60 */ | ||
| 4612 | "\\_SB.PCI0.IDE0.SCND.MSTR", /* all others */ | ||
| 4613 | ); /* A21e, R30, R31 */ | ||
| 4614 | TPACPI_HANDLE(bay_ej, bay, "_EJ3", /* 600e/x, A2xm/p, A3x */ | ||
| 4615 | "_EJ0", /* all others */ | ||
| 4616 | ); /* 570,A21e,G4x,R30,R31,R32,R40e,R50e */ | ||
| 4617 | TPACPI_HANDLE(bay2, root, "\\_SB.PCI0.IDE0.PRIM.SLAV", /* A3x, R32 */ | ||
| 4618 | "\\_SB.PCI0.IDE0.IDEP.IDPS", /* 600e/x, 770e, 770x */ | ||
| 4619 | ); /* all others */ | ||
| 4620 | TPACPI_HANDLE(bay2_ej, bay2, "_EJ3", /* 600e/x, 770e, A3x */ | ||
| 4621 | "_EJ0", /* 770x */ | ||
| 4622 | ); /* all others */ | ||
| 4623 | |||
| 4624 | static int __init bay_init(struct ibm_init_struct *iibm) | ||
| 4625 | { | ||
| 4626 | vdbg_printk(TPACPI_DBG_INIT, "initializing bay subdriver\n"); | ||
| 4627 | |||
| 4628 | TPACPI_ACPIHANDLE_INIT(bay); | ||
| 4629 | if (bay_handle) | ||
| 4630 | TPACPI_ACPIHANDLE_INIT(bay_ej); | ||
| 4631 | TPACPI_ACPIHANDLE_INIT(bay2); | ||
| 4632 | if (bay2_handle) | ||
| 4633 | TPACPI_ACPIHANDLE_INIT(bay2_ej); | ||
| 4634 | |||
| 4635 | tp_features.bay_status = bay_handle && | ||
| 4636 | acpi_evalf(bay_handle, NULL, "_STA", "qv"); | ||
| 4637 | tp_features.bay_status2 = bay2_handle && | ||
| 4638 | acpi_evalf(bay2_handle, NULL, "_STA", "qv"); | ||
| 4639 | |||
| 4640 | tp_features.bay_eject = bay_handle && bay_ej_handle && | ||
| 4641 | (strlencmp(bay_ej_path, "_EJ0") == 0 || experimental); | ||
| 4642 | tp_features.bay_eject2 = bay2_handle && bay2_ej_handle && | ||
| 4643 | (strlencmp(bay2_ej_path, "_EJ0") == 0 || experimental); | ||
| 4644 | |||
| 4645 | vdbg_printk(TPACPI_DBG_INIT, | ||
| 4646 | "bay 1: status %s, eject %s; bay 2: status %s, eject %s\n", | ||
| 4647 | str_supported(tp_features.bay_status), | ||
| 4648 | str_supported(tp_features.bay_eject), | ||
| 4649 | str_supported(tp_features.bay_status2), | ||
| 4650 | str_supported(tp_features.bay_eject2)); | ||
| 4651 | |||
| 4652 | return (tp_features.bay_status || tp_features.bay_eject || | ||
| 4653 | tp_features.bay_status2 || tp_features.bay_eject2)? 0 : 1; | ||
| 4654 | } | ||
| 4655 | |||
| 4656 | static void bay_notify(struct ibm_struct *ibm, u32 event) | ||
| 4657 | { | ||
| 4658 | acpi_bus_generate_proc_event(ibm->acpi->device, event, 0); | ||
| 4659 | acpi_bus_generate_netlink_event(ibm->acpi->device->pnp.device_class, | ||
| 4660 | dev_name(&ibm->acpi->device->dev), | ||
| 4661 | event, 0); | ||
| 4662 | } | ||
| 4663 | |||
| 4664 | #define bay_occupied(b) (_sta(b##_handle) & 1) | ||
| 4665 | |||
| 4666 | static int bay_read(char *p) | ||
| 4667 | { | ||
| 4668 | int len = 0; | ||
| 4669 | int occupied = bay_occupied(bay); | ||
| 4670 | int occupied2 = bay_occupied(bay2); | ||
| 4671 | int eject, eject2; | ||
| 4672 | |||
| 4673 | len += sprintf(p + len, "status:\t\t%s\n", | ||
| 4674 | tp_features.bay_status ? | ||
| 4675 | (occupied ? "occupied" : "unoccupied") : | ||
| 4676 | "not supported"); | ||
| 4677 | if (tp_features.bay_status2) | ||
| 4678 | len += sprintf(p + len, "status2:\t%s\n", occupied2 ? | ||
| 4679 | "occupied" : "unoccupied"); | ||
| 4680 | |||
| 4681 | eject = tp_features.bay_eject && occupied; | ||
| 4682 | eject2 = tp_features.bay_eject2 && occupied2; | ||
| 4683 | |||
| 4684 | if (eject && eject2) | ||
| 4685 | len += sprintf(p + len, "commands:\teject, eject2\n"); | ||
| 4686 | else if (eject) | ||
| 4687 | len += sprintf(p + len, "commands:\teject\n"); | ||
| 4688 | else if (eject2) | ||
| 4689 | len += sprintf(p + len, "commands:\teject2\n"); | ||
| 4690 | |||
| 4691 | return len; | ||
| 4692 | } | ||
| 4693 | |||
| 4694 | static int bay_write(char *buf) | ||
| 4695 | { | ||
| 4696 | char *cmd; | ||
| 4697 | |||
| 4698 | if (!tp_features.bay_eject && !tp_features.bay_eject2) | ||
| 4699 | return -ENODEV; | ||
| 4700 | |||
| 4701 | while ((cmd = next_cmd(&buf))) { | ||
| 4702 | if (tp_features.bay_eject && strlencmp(cmd, "eject") == 0) { | ||
| 4703 | if (!acpi_evalf(bay_ej_handle, NULL, NULL, "vd", 1)) | ||
| 4704 | return -EIO; | ||
| 4705 | } else if (tp_features.bay_eject2 && | ||
| 4706 | strlencmp(cmd, "eject2") == 0) { | ||
| 4707 | if (!acpi_evalf(bay2_ej_handle, NULL, NULL, "vd", 1)) | ||
| 4708 | return -EIO; | ||
| 4709 | } else | ||
| 4710 | return -EINVAL; | ||
| 4711 | } | ||
| 4712 | |||
| 4713 | return 0; | ||
| 4714 | } | ||
| 4715 | |||
| 4716 | static struct tp_acpi_drv_struct ibm_bay_acpidriver = { | ||
| 4717 | .notify = bay_notify, | ||
| 4718 | .handle = &bay_handle, | ||
| 4719 | .type = ACPI_SYSTEM_NOTIFY, | ||
| 4720 | }; | ||
| 4721 | |||
| 4722 | static struct ibm_struct bay_driver_data = { | ||
| 4723 | .name = "bay", | ||
| 4724 | .read = bay_read, | ||
| 4725 | .write = bay_write, | ||
| 4726 | .acpi = &ibm_bay_acpidriver, | ||
| 4727 | }; | ||
| 4728 | |||
| 4729 | #endif /* CONFIG_THINKPAD_ACPI_BAY */ | ||
| 4730 | |||
| 4731 | /************************************************************************* | ||
| 4732 | * CMOS subdriver | 4429 | * CMOS subdriver |
| 4733 | */ | 4430 | */ |
| 4734 | 4431 | ||
| @@ -5945,14 +5642,48 @@ static struct backlight_ops ibm_backlight_data = { | |||
| 5945 | 5642 | ||
| 5946 | /* --------------------------------------------------------------------- */ | 5643 | /* --------------------------------------------------------------------- */ |
| 5947 | 5644 | ||
| 5645 | /* | ||
| 5646 | * These are only useful for models that have only one possibility | ||
| 5647 | * of GPU. If the BIOS model handles both ATI and Intel, don't use | ||
| 5648 | * these quirks. | ||
| 5649 | */ | ||
| 5650 | #define TPACPI_BRGHT_Q_NOEC 0x0001 /* Must NOT use EC HBRV */ | ||
| 5651 | #define TPACPI_BRGHT_Q_EC 0x0002 /* Should or must use EC HBRV */ | ||
| 5652 | #define TPACPI_BRGHT_Q_ASK 0x8000 /* Ask for user report */ | ||
| 5653 | |||
| 5654 | static const struct tpacpi_quirk brightness_quirk_table[] __initconst = { | ||
| 5655 | /* Models with ATI GPUs known to require ECNVRAM mode */ | ||
| 5656 | TPACPI_Q_IBM('1', 'Y', TPACPI_BRGHT_Q_EC), /* T43/p ATI */ | ||
| 5657 | |||
| 5658 | /* Models with ATI GPUs (waiting confirmation) */ | ||
| 5659 | TPACPI_Q_IBM('1', 'R', TPACPI_BRGHT_Q_ASK|TPACPI_BRGHT_Q_EC), | ||
| 5660 | TPACPI_Q_IBM('1', 'Q', TPACPI_BRGHT_Q_ASK|TPACPI_BRGHT_Q_EC), | ||
| 5661 | TPACPI_Q_IBM('7', '6', TPACPI_BRGHT_Q_ASK|TPACPI_BRGHT_Q_EC), | ||
| 5662 | TPACPI_Q_IBM('7', '8', TPACPI_BRGHT_Q_ASK|TPACPI_BRGHT_Q_EC), | ||
| 5663 | |||
| 5664 | /* Models with Intel Extreme Graphics 2 (waiting confirmation) */ | ||
| 5665 | TPACPI_Q_IBM('1', 'V', TPACPI_BRGHT_Q_ASK|TPACPI_BRGHT_Q_NOEC), | ||
| 5666 | TPACPI_Q_IBM('1', 'W', TPACPI_BRGHT_Q_ASK|TPACPI_BRGHT_Q_NOEC), | ||
| 5667 | TPACPI_Q_IBM('1', 'U', TPACPI_BRGHT_Q_ASK|TPACPI_BRGHT_Q_NOEC), | ||
| 5668 | |||
| 5669 | /* Models with Intel GMA900 */ | ||
| 5670 | TPACPI_Q_IBM('7', '0', TPACPI_BRGHT_Q_NOEC), /* T43, R52 */ | ||
| 5671 | TPACPI_Q_IBM('7', '4', TPACPI_BRGHT_Q_NOEC), /* X41 */ | ||
| 5672 | TPACPI_Q_IBM('7', '5', TPACPI_BRGHT_Q_NOEC), /* X41 Tablet */ | ||
| 5673 | }; | ||
| 5674 | |||
| 5948 | static int __init brightness_init(struct ibm_init_struct *iibm) | 5675 | static int __init brightness_init(struct ibm_init_struct *iibm) |
| 5949 | { | 5676 | { |
| 5950 | int b; | 5677 | int b; |
| 5678 | unsigned long quirks; | ||
| 5951 | 5679 | ||
| 5952 | vdbg_printk(TPACPI_DBG_INIT, "initializing brightness subdriver\n"); | 5680 | vdbg_printk(TPACPI_DBG_INIT, "initializing brightness subdriver\n"); |
| 5953 | 5681 | ||
| 5954 | mutex_init(&brightness_mutex); | 5682 | mutex_init(&brightness_mutex); |
| 5955 | 5683 | ||
| 5684 | quirks = tpacpi_check_quirks(brightness_quirk_table, | ||
| 5685 | ARRAY_SIZE(brightness_quirk_table)); | ||
| 5686 | |||
| 5956 | /* | 5687 | /* |
| 5957 | * We always attempt to detect acpi support, so as to switch | 5688 | * We always attempt to detect acpi support, so as to switch |
| 5958 | * Lenovo Vista BIOS to ACPI brightness mode even if we are not | 5689 | * Lenovo Vista BIOS to ACPI brightness mode even if we are not |
| @@ -6009,23 +5740,13 @@ static int __init brightness_init(struct ibm_init_struct *iibm) | |||
| 6009 | /* TPACPI_BRGHT_MODE_AUTO not implemented yet, just use default */ | 5740 | /* TPACPI_BRGHT_MODE_AUTO not implemented yet, just use default */ |
| 6010 | if (brightness_mode == TPACPI_BRGHT_MODE_AUTO || | 5741 | if (brightness_mode == TPACPI_BRGHT_MODE_AUTO || |
| 6011 | brightness_mode == TPACPI_BRGHT_MODE_MAX) { | 5742 | brightness_mode == TPACPI_BRGHT_MODE_MAX) { |
| 6012 | if (thinkpad_id.vendor == PCI_VENDOR_ID_IBM) { | 5743 | if (quirks & TPACPI_BRGHT_Q_EC) |
| 6013 | /* | 5744 | brightness_mode = TPACPI_BRGHT_MODE_ECNVRAM; |
| 6014 | * IBM models that define HBRV probably have | 5745 | else |
| 6015 | * EC-based backlight level control | ||
| 6016 | */ | ||
| 6017 | if (acpi_evalf(ec_handle, NULL, "HBRV", "qd")) | ||
| 6018 | /* T40-T43, R50-R52, R50e, R51e, X31-X41 */ | ||
| 6019 | brightness_mode = TPACPI_BRGHT_MODE_ECNVRAM; | ||
| 6020 | else | ||
| 6021 | /* all other IBM ThinkPads */ | ||
| 6022 | brightness_mode = TPACPI_BRGHT_MODE_UCMS_STEP; | ||
| 6023 | } else | ||
| 6024 | /* All Lenovo ThinkPads */ | ||
| 6025 | brightness_mode = TPACPI_BRGHT_MODE_UCMS_STEP; | 5746 | brightness_mode = TPACPI_BRGHT_MODE_UCMS_STEP; |
| 6026 | 5747 | ||
| 6027 | dbg_printk(TPACPI_DBG_BRGHT, | 5748 | dbg_printk(TPACPI_DBG_BRGHT, |
| 6028 | "selected brightness_mode=%d\n", | 5749 | "driver auto-selected brightness_mode=%d\n", |
| 6029 | brightness_mode); | 5750 | brightness_mode); |
| 6030 | } | 5751 | } |
| 6031 | 5752 | ||
| @@ -6052,6 +5773,15 @@ static int __init brightness_init(struct ibm_init_struct *iibm) | |||
| 6052 | vdbg_printk(TPACPI_DBG_INIT | TPACPI_DBG_BRGHT, | 5773 | vdbg_printk(TPACPI_DBG_INIT | TPACPI_DBG_BRGHT, |
| 6053 | "brightness is supported\n"); | 5774 | "brightness is supported\n"); |
| 6054 | 5775 | ||
| 5776 | if (quirks & TPACPI_BRGHT_Q_ASK) { | ||
| 5777 | printk(TPACPI_NOTICE | ||
| 5778 | "brightness: will use unverified default: " | ||
| 5779 | "brightness_mode=%d\n", brightness_mode); | ||
| 5780 | printk(TPACPI_NOTICE | ||
| 5781 | "brightness: please report to %s whether it works well " | ||
| 5782 | "or not on your ThinkPad\n", TPACPI_MAIL); | ||
| 5783 | } | ||
| 5784 | |||
| 6055 | ibm_backlight_device->props.max_brightness = | 5785 | ibm_backlight_device->props.max_brightness = |
| 6056 | (tp_features.bright_16levels)? 15 : 7; | 5786 | (tp_features.bright_16levels)? 15 : 7; |
| 6057 | ibm_backlight_device->props.brightness = b & TP_EC_BACKLIGHT_LVLMSK; | 5787 | ibm_backlight_device->props.brightness = b & TP_EC_BACKLIGHT_LVLMSK; |
| @@ -7854,22 +7584,6 @@ static struct ibm_init_struct ibms_init[] __initdata = { | |||
| 7854 | .init = light_init, | 7584 | .init = light_init, |
| 7855 | .data = &light_driver_data, | 7585 | .data = &light_driver_data, |
| 7856 | }, | 7586 | }, |
| 7857 | #ifdef CONFIG_THINKPAD_ACPI_DOCK | ||
| 7858 | { | ||
| 7859 | .init = dock_init, | ||
| 7860 | .data = &dock_driver_data[0], | ||
| 7861 | }, | ||
| 7862 | { | ||
| 7863 | .init = dock_init2, | ||
| 7864 | .data = &dock_driver_data[1], | ||
| 7865 | }, | ||
| 7866 | #endif | ||
| 7867 | #ifdef CONFIG_THINKPAD_ACPI_BAY | ||
| 7868 | { | ||
| 7869 | .init = bay_init, | ||
| 7870 | .data = &bay_driver_data, | ||
| 7871 | }, | ||
| 7872 | #endif | ||
| 7873 | { | 7587 | { |
| 7874 | .init = cmos_init, | 7588 | .init = cmos_init, |
| 7875 | .data = &cmos_driver_data, | 7589 | .data = &cmos_driver_data, |
| @@ -7968,12 +7682,6 @@ TPACPI_PARAM(hotkey); | |||
| 7968 | TPACPI_PARAM(bluetooth); | 7682 | TPACPI_PARAM(bluetooth); |
| 7969 | TPACPI_PARAM(video); | 7683 | TPACPI_PARAM(video); |
| 7970 | TPACPI_PARAM(light); | 7684 | TPACPI_PARAM(light); |
| 7971 | #ifdef CONFIG_THINKPAD_ACPI_DOCK | ||
| 7972 | TPACPI_PARAM(dock); | ||
| 7973 | #endif | ||
| 7974 | #ifdef CONFIG_THINKPAD_ACPI_BAY | ||
| 7975 | TPACPI_PARAM(bay); | ||
| 7976 | #endif /* CONFIG_THINKPAD_ACPI_BAY */ | ||
| 7977 | TPACPI_PARAM(cmos); | 7685 | TPACPI_PARAM(cmos); |
| 7978 | TPACPI_PARAM(led); | 7686 | TPACPI_PARAM(led); |
| 7979 | TPACPI_PARAM(beep); | 7687 | TPACPI_PARAM(beep); |
diff --git a/drivers/platform/x86/wmi.c b/drivers/platform/x86/wmi.c index 043b208d971d..f215a5919192 100644 --- a/drivers/platform/x86/wmi.c +++ b/drivers/platform/x86/wmi.c | |||
| @@ -270,7 +270,7 @@ u32 method_id, const struct acpi_buffer *in, struct acpi_buffer *out) | |||
| 270 | acpi_status status; | 270 | acpi_status status; |
| 271 | struct acpi_object_list input; | 271 | struct acpi_object_list input; |
| 272 | union acpi_object params[3]; | 272 | union acpi_object params[3]; |
| 273 | char method[4] = "WM"; | 273 | char method[5] = "WM"; |
| 274 | 274 | ||
| 275 | if (!find_guid(guid_string, &wblock)) | 275 | if (!find_guid(guid_string, &wblock)) |
| 276 | return AE_ERROR; | 276 | return AE_ERROR; |
| @@ -328,8 +328,8 @@ struct acpi_buffer *out) | |||
| 328 | acpi_status status, wc_status = AE_ERROR; | 328 | acpi_status status, wc_status = AE_ERROR; |
| 329 | struct acpi_object_list input, wc_input; | 329 | struct acpi_object_list input, wc_input; |
| 330 | union acpi_object wc_params[1], wq_params[1]; | 330 | union acpi_object wc_params[1], wq_params[1]; |
| 331 | char method[4]; | 331 | char method[5]; |
| 332 | char wc_method[4] = "WC"; | 332 | char wc_method[5] = "WC"; |
| 333 | 333 | ||
| 334 | if (!guid_string || !out) | 334 | if (!guid_string || !out) |
| 335 | return AE_BAD_PARAMETER; | 335 | return AE_BAD_PARAMETER; |
| @@ -410,7 +410,7 @@ const struct acpi_buffer *in) | |||
| 410 | acpi_handle handle; | 410 | acpi_handle handle; |
| 411 | struct acpi_object_list input; | 411 | struct acpi_object_list input; |
| 412 | union acpi_object params[2]; | 412 | union acpi_object params[2]; |
| 413 | char method[4] = "WS"; | 413 | char method[5] = "WS"; |
| 414 | 414 | ||
| 415 | if (!guid_string || !in) | 415 | if (!guid_string || !in) |
| 416 | return AE_BAD_DATA; | 416 | return AE_BAD_DATA; |
diff --git a/drivers/power/Kconfig b/drivers/power/Kconfig index 7eda34838bfe..bdbc4f73fcdc 100644 --- a/drivers/power/Kconfig +++ b/drivers/power/Kconfig | |||
| @@ -43,6 +43,13 @@ config BATTERY_DS2760 | |||
| 43 | help | 43 | help |
| 44 | Say Y here to enable support for batteries with ds2760 chip. | 44 | Say Y here to enable support for batteries with ds2760 chip. |
| 45 | 45 | ||
| 46 | config BATTERY_DS2782 | ||
| 47 | tristate "DS2782 standalone gas-gauge" | ||
| 48 | depends on I2C | ||
| 49 | help | ||
| 50 | Say Y here to enable support for the DS2782 standalone battery | ||
| 51 | gas-gauge. | ||
| 52 | |||
| 46 | config BATTERY_PMU | 53 | config BATTERY_PMU |
| 47 | tristate "Apple PMU battery" | 54 | tristate "Apple PMU battery" |
| 48 | depends on PPC32 && ADB_PMU | 55 | depends on PPC32 && ADB_PMU |
diff --git a/drivers/power/Makefile b/drivers/power/Makefile index daf3179689aa..380d17c9ae29 100644 --- a/drivers/power/Makefile +++ b/drivers/power/Makefile | |||
| @@ -19,6 +19,7 @@ obj-$(CONFIG_APM_POWER) += apm_power.o | |||
| 19 | obj-$(CONFIG_WM8350_POWER) += wm8350_power.o | 19 | obj-$(CONFIG_WM8350_POWER) += wm8350_power.o |
| 20 | 20 | ||
| 21 | obj-$(CONFIG_BATTERY_DS2760) += ds2760_battery.o | 21 | obj-$(CONFIG_BATTERY_DS2760) += ds2760_battery.o |
| 22 | obj-$(CONFIG_BATTERY_DS2782) += ds2782_battery.o | ||
| 22 | obj-$(CONFIG_BATTERY_PMU) += pmu_battery.o | 23 | obj-$(CONFIG_BATTERY_PMU) += pmu_battery.o |
| 23 | obj-$(CONFIG_BATTERY_OLPC) += olpc_battery.o | 24 | obj-$(CONFIG_BATTERY_OLPC) += olpc_battery.o |
| 24 | obj-$(CONFIG_BATTERY_TOSA) += tosa_battery.o | 25 | obj-$(CONFIG_BATTERY_TOSA) += tosa_battery.o |
diff --git a/drivers/power/ds2782_battery.c b/drivers/power/ds2782_battery.c new file mode 100644 index 000000000000..da14f374cb60 --- /dev/null +++ b/drivers/power/ds2782_battery.c | |||
| @@ -0,0 +1,330 @@ | |||
| 1 | /* | ||
| 2 | * I2C client/driver for the Maxim/Dallas DS2782 Stand-Alone Fuel Gauge IC | ||
| 3 | * | ||
| 4 | * Copyright (C) 2009 Bluewater Systems Ltd | ||
| 5 | * | ||
| 6 | * Author: Ryan Mallon <ryan@bluewatersys.com> | ||
| 7 | * | ||
| 8 | * This program is free software; you can redistribute it and/or modify | ||
| 9 | * it under the terms of the GNU General Public License version 2 as | ||
| 10 | * published by the Free Software Foundation. | ||
| 11 | * | ||
| 12 | */ | ||
| 13 | |||
| 14 | #include <linux/kernel.h> | ||
| 15 | #include <linux/module.h> | ||
| 16 | #include <linux/types.h> | ||
| 17 | #include <linux/errno.h> | ||
| 18 | #include <linux/swab.h> | ||
| 19 | #include <linux/i2c.h> | ||
| 20 | #include <linux/idr.h> | ||
| 21 | #include <linux/power_supply.h> | ||
| 22 | |||
| 23 | #define DS2782_REG_RARC 0x06 /* Remaining active relative capacity */ | ||
| 24 | |||
| 25 | #define DS2782_REG_VOLT_MSB 0x0c | ||
| 26 | #define DS2782_REG_TEMP_MSB 0x0a | ||
| 27 | #define DS2782_REG_CURRENT_MSB 0x0e | ||
| 28 | |||
| 29 | /* EEPROM Block */ | ||
| 30 | #define DS2782_REG_RSNSP 0x69 /* Sense resistor value */ | ||
| 31 | |||
| 32 | /* Current unit measurement in uA for a 1 milli-ohm sense resistor */ | ||
| 33 | #define DS2782_CURRENT_UNITS 1563 | ||
| 34 | |||
| 35 | #define to_ds2782_info(x) container_of(x, struct ds2782_info, battery) | ||
| 36 | |||
| 37 | struct ds2782_info { | ||
| 38 | struct i2c_client *client; | ||
| 39 | struct power_supply battery; | ||
| 40 | int id; | ||
| 41 | }; | ||
| 42 | |||
| 43 | static DEFINE_IDR(battery_id); | ||
| 44 | static DEFINE_MUTEX(battery_lock); | ||
| 45 | |||
| 46 | static inline int ds2782_read_reg(struct ds2782_info *info, int reg, u8 *val) | ||
| 47 | { | ||
| 48 | int ret; | ||
| 49 | |||
| 50 | ret = i2c_smbus_read_byte_data(info->client, reg); | ||
| 51 | if (ret < 0) { | ||
| 52 | dev_err(&info->client->dev, "register read failed\n"); | ||
| 53 | return ret; | ||
| 54 | } | ||
| 55 | |||
| 56 | *val = ret; | ||
| 57 | return 0; | ||
| 58 | } | ||
| 59 | |||
| 60 | static inline int ds2782_read_reg16(struct ds2782_info *info, int reg_msb, | ||
| 61 | s16 *val) | ||
| 62 | { | ||
| 63 | int ret; | ||
| 64 | |||
| 65 | ret = swab16(i2c_smbus_read_word_data(info->client, reg_msb)); | ||
| 66 | if (ret < 0) { | ||
| 67 | dev_err(&info->client->dev, "register read failed\n"); | ||
| 68 | return ret; | ||
| 69 | } | ||
| 70 | |||
| 71 | *val = ret; | ||
| 72 | return 0; | ||
| 73 | } | ||
| 74 | |||
| 75 | static int ds2782_get_temp(struct ds2782_info *info, int *temp) | ||
| 76 | { | ||
| 77 | s16 raw; | ||
| 78 | int err; | ||
| 79 | |||
| 80 | /* | ||
| 81 | * Temperature is measured in units of 0.125 degrees celcius, the | ||
| 82 | * power_supply class measures temperature in tenths of degrees | ||
| 83 | * celsius. The temperature value is stored as a 10 bit number, plus | ||
| 84 | * sign in the upper bits of a 16 bit register. | ||
| 85 | */ | ||
| 86 | err = ds2782_read_reg16(info, DS2782_REG_TEMP_MSB, &raw); | ||
| 87 | if (err) | ||
| 88 | return err; | ||
| 89 | *temp = ((raw / 32) * 125) / 100; | ||
| 90 | return 0; | ||
| 91 | } | ||
| 92 | |||
| 93 | static int ds2782_get_current(struct ds2782_info *info, int *current_uA) | ||
| 94 | { | ||
| 95 | int sense_res; | ||
| 96 | int err; | ||
| 97 | u8 sense_res_raw; | ||
| 98 | s16 raw; | ||
| 99 | |||
| 100 | /* | ||
| 101 | * The units of measurement for current are dependent on the value of | ||
| 102 | * the sense resistor. | ||
| 103 | */ | ||
| 104 | err = ds2782_read_reg(info, DS2782_REG_RSNSP, &sense_res_raw); | ||
| 105 | if (err) | ||
| 106 | return err; | ||
| 107 | if (sense_res_raw == 0) { | ||
| 108 | dev_err(&info->client->dev, "sense resistor value is 0\n"); | ||
| 109 | return -ENXIO; | ||
| 110 | } | ||
| 111 | sense_res = 1000 / sense_res_raw; | ||
| 112 | |||
| 113 | dev_dbg(&info->client->dev, "sense resistor = %d milli-ohms\n", | ||
| 114 | sense_res); | ||
| 115 | err = ds2782_read_reg16(info, DS2782_REG_CURRENT_MSB, &raw); | ||
| 116 | if (err) | ||
| 117 | return err; | ||
| 118 | *current_uA = raw * (DS2782_CURRENT_UNITS / sense_res); | ||
| 119 | return 0; | ||
| 120 | } | ||
| 121 | |||
| 122 | static int ds2782_get_voltage(struct ds2782_info *info, int *voltage_uA) | ||
| 123 | { | ||
| 124 | s16 raw; | ||
| 125 | int err; | ||
| 126 | |||
| 127 | /* | ||
| 128 | * Voltage is measured in units of 4.88mV. The voltage is stored as | ||
| 129 | * a 10-bit number plus sign, in the upper bits of a 16-bit register | ||
| 130 | */ | ||
| 131 | err = ds2782_read_reg16(info, DS2782_REG_VOLT_MSB, &raw); | ||
| 132 | if (err) | ||
| 133 | return err; | ||
| 134 | *voltage_uA = (raw / 32) * 4800; | ||
| 135 | return 0; | ||
| 136 | } | ||
| 137 | |||
| 138 | static int ds2782_get_capacity(struct ds2782_info *info, int *capacity) | ||
| 139 | { | ||
| 140 | int err; | ||
| 141 | u8 raw; | ||
| 142 | |||
| 143 | err = ds2782_read_reg(info, DS2782_REG_RARC, &raw); | ||
| 144 | if (err) | ||
| 145 | return err; | ||
| 146 | *capacity = raw; | ||
| 147 | return raw; | ||
| 148 | } | ||
| 149 | |||
| 150 | static int ds2782_get_status(struct ds2782_info *info, int *status) | ||
| 151 | { | ||
| 152 | int err; | ||
| 153 | int current_uA; | ||
| 154 | int capacity; | ||
| 155 | |||
| 156 | err = ds2782_get_current(info, ¤t_uA); | ||
| 157 | if (err) | ||
| 158 | return err; | ||
| 159 | |||
| 160 | err = ds2782_get_capacity(info, &capacity); | ||
| 161 | if (err) | ||
| 162 | return err; | ||
| 163 | |||
| 164 | if (capacity == 100) | ||
| 165 | *status = POWER_SUPPLY_STATUS_FULL; | ||
| 166 | else if (current_uA == 0) | ||
| 167 | *status = POWER_SUPPLY_STATUS_NOT_CHARGING; | ||
| 168 | else if (current_uA < 0) | ||
| 169 | *status = POWER_SUPPLY_STATUS_DISCHARGING; | ||
| 170 | else | ||
| 171 | *status = POWER_SUPPLY_STATUS_CHARGING; | ||
| 172 | |||
| 173 | return 0; | ||
| 174 | } | ||
| 175 | |||
| 176 | static int ds2782_battery_get_property(struct power_supply *psy, | ||
| 177 | enum power_supply_property prop, | ||
| 178 | union power_supply_propval *val) | ||
| 179 | { | ||
| 180 | struct ds2782_info *info = to_ds2782_info(psy); | ||
| 181 | int ret; | ||
| 182 | |||
| 183 | switch (prop) { | ||
| 184 | case POWER_SUPPLY_PROP_STATUS: | ||
| 185 | ret = ds2782_get_status(info, &val->intval); | ||
| 186 | break; | ||
| 187 | |||
| 188 | case POWER_SUPPLY_PROP_CAPACITY: | ||
| 189 | ret = ds2782_get_capacity(info, &val->intval); | ||
| 190 | break; | ||
| 191 | |||
| 192 | case POWER_SUPPLY_PROP_VOLTAGE_NOW: | ||
| 193 | ret = ds2782_get_voltage(info, &val->intval); | ||
| 194 | break; | ||
| 195 | |||
| 196 | case POWER_SUPPLY_PROP_CURRENT_NOW: | ||
| 197 | ret = ds2782_get_current(info, &val->intval); | ||
| 198 | break; | ||
| 199 | |||
| 200 | case POWER_SUPPLY_PROP_TEMP: | ||
| 201 | ret = ds2782_get_temp(info, &val->intval); | ||
| 202 | break; | ||
| 203 | |||
| 204 | default: | ||
| 205 | ret = -EINVAL; | ||
| 206 | } | ||
| 207 | |||
| 208 | return ret; | ||
| 209 | } | ||
| 210 | |||
| 211 | static enum power_supply_property ds2782_battery_props[] = { | ||
| 212 | POWER_SUPPLY_PROP_STATUS, | ||
| 213 | POWER_SUPPLY_PROP_CAPACITY, | ||
| 214 | POWER_SUPPLY_PROP_VOLTAGE_NOW, | ||
| 215 | POWER_SUPPLY_PROP_CURRENT_NOW, | ||
| 216 | POWER_SUPPLY_PROP_TEMP, | ||
| 217 | }; | ||
| 218 | |||
| 219 | static void ds2782_power_supply_init(struct power_supply *battery) | ||
| 220 | { | ||
| 221 | battery->type = POWER_SUPPLY_TYPE_BATTERY; | ||
| 222 | battery->properties = ds2782_battery_props; | ||
| 223 | battery->num_properties = ARRAY_SIZE(ds2782_battery_props); | ||
| 224 | battery->get_property = ds2782_battery_get_property; | ||
| 225 | battery->external_power_changed = NULL; | ||
| 226 | } | ||
| 227 | |||
| 228 | static int ds2782_battery_remove(struct i2c_client *client) | ||
| 229 | { | ||
| 230 | struct ds2782_info *info = i2c_get_clientdata(client); | ||
| 231 | |||
| 232 | power_supply_unregister(&info->battery); | ||
| 233 | kfree(info->battery.name); | ||
| 234 | |||
| 235 | mutex_lock(&battery_lock); | ||
| 236 | idr_remove(&battery_id, info->id); | ||
| 237 | mutex_unlock(&battery_lock); | ||
| 238 | |||
| 239 | i2c_set_clientdata(client, info); | ||
| 240 | |||
| 241 | kfree(info); | ||
| 242 | return 0; | ||
| 243 | } | ||
| 244 | |||
| 245 | static int ds2782_battery_probe(struct i2c_client *client, | ||
| 246 | const struct i2c_device_id *id) | ||
| 247 | { | ||
| 248 | struct ds2782_info *info; | ||
| 249 | int ret; | ||
| 250 | int num; | ||
| 251 | |||
| 252 | /* Get an ID for this battery */ | ||
| 253 | ret = idr_pre_get(&battery_id, GFP_KERNEL); | ||
| 254 | if (ret == 0) { | ||
| 255 | ret = -ENOMEM; | ||
| 256 | goto fail_id; | ||
| 257 | } | ||
| 258 | |||
| 259 | mutex_lock(&battery_lock); | ||
| 260 | ret = idr_get_new(&battery_id, client, &num); | ||
| 261 | mutex_unlock(&battery_lock); | ||
| 262 | if (ret < 0) | ||
| 263 | goto fail_id; | ||
| 264 | |||
| 265 | info = kzalloc(sizeof(*info), GFP_KERNEL); | ||
| 266 | if (!info) { | ||
| 267 | ret = -ENOMEM; | ||
| 268 | goto fail_info; | ||
| 269 | } | ||
| 270 | |||
| 271 | info->battery.name = kasprintf(GFP_KERNEL, "ds2782-%d", num); | ||
| 272 | if (!info->battery.name) { | ||
| 273 | ret = -ENOMEM; | ||
| 274 | goto fail_name; | ||
| 275 | } | ||
| 276 | |||
| 277 | i2c_set_clientdata(client, info); | ||
| 278 | info->client = client; | ||
| 279 | ds2782_power_supply_init(&info->battery); | ||
| 280 | |||
| 281 | ret = power_supply_register(&client->dev, &info->battery); | ||
| 282 | if (ret) { | ||
| 283 | dev_err(&client->dev, "failed to register battery\n"); | ||
| 284 | goto fail_register; | ||
| 285 | } | ||
| 286 | |||
| 287 | return 0; | ||
| 288 | |||
| 289 | fail_register: | ||
| 290 | kfree(info->battery.name); | ||
| 291 | fail_name: | ||
| 292 | i2c_set_clientdata(client, info); | ||
| 293 | kfree(info); | ||
| 294 | fail_info: | ||
| 295 | mutex_lock(&battery_lock); | ||
| 296 | idr_remove(&battery_id, num); | ||
| 297 | mutex_unlock(&battery_lock); | ||
| 298 | fail_id: | ||
| 299 | return ret; | ||
| 300 | } | ||
| 301 | |||
| 302 | static const struct i2c_device_id ds2782_id[] = { | ||
| 303 | {"ds2782", 0}, | ||
| 304 | {}, | ||
| 305 | }; | ||
| 306 | |||
| 307 | static struct i2c_driver ds2782_battery_driver = { | ||
| 308 | .driver = { | ||
| 309 | .name = "ds2782-battery", | ||
| 310 | }, | ||
| 311 | .probe = ds2782_battery_probe, | ||
| 312 | .remove = ds2782_battery_remove, | ||
| 313 | .id_table = ds2782_id, | ||
| 314 | }; | ||
| 315 | |||
| 316 | static int __init ds2782_init(void) | ||
| 317 | { | ||
| 318 | return i2c_add_driver(&ds2782_battery_driver); | ||
| 319 | } | ||
| 320 | module_init(ds2782_init); | ||
| 321 | |||
| 322 | static void __exit ds2782_exit(void) | ||
| 323 | { | ||
| 324 | i2c_del_driver(&ds2782_battery_driver); | ||
| 325 | } | ||
| 326 | module_exit(ds2782_exit); | ||
| 327 | |||
| 328 | MODULE_AUTHOR("Ryan Mallon <ryan@bluewatersys.com>"); | ||
| 329 | MODULE_DESCRIPTION("Maxim/Dallas DS2782 Stand-Alone Fuel Gauage IC driver"); | ||
| 330 | MODULE_LICENSE("GPL"); | ||
diff --git a/drivers/power/olpc_battery.c b/drivers/power/olpc_battery.c index 5fbca2681baa..58e419299cd6 100644 --- a/drivers/power/olpc_battery.c +++ b/drivers/power/olpc_battery.c | |||
| @@ -8,6 +8,7 @@ | |||
| 8 | * published by the Free Software Foundation. | 8 | * published by the Free Software Foundation. |
| 9 | */ | 9 | */ |
| 10 | 10 | ||
| 11 | #include <linux/kernel.h> | ||
| 11 | #include <linux/module.h> | 12 | #include <linux/module.h> |
| 12 | #include <linux/err.h> | 13 | #include <linux/err.h> |
| 13 | #include <linux/platform_device.h> | 14 | #include <linux/platform_device.h> |
| @@ -35,6 +36,7 @@ | |||
| 35 | #define BAT_STAT_AC 0x10 | 36 | #define BAT_STAT_AC 0x10 |
| 36 | #define BAT_STAT_CHARGING 0x20 | 37 | #define BAT_STAT_CHARGING 0x20 |
| 37 | #define BAT_STAT_DISCHARGING 0x40 | 38 | #define BAT_STAT_DISCHARGING 0x40 |
| 39 | #define BAT_STAT_TRICKLE 0x80 | ||
| 38 | 40 | ||
| 39 | #define BAT_ERR_INFOFAIL 0x02 | 41 | #define BAT_ERR_INFOFAIL 0x02 |
| 40 | #define BAT_ERR_OVERVOLTAGE 0x04 | 42 | #define BAT_ERR_OVERVOLTAGE 0x04 |
| @@ -89,7 +91,7 @@ static char bat_serial[17]; /* Ick */ | |||
| 89 | static int olpc_bat_get_status(union power_supply_propval *val, uint8_t ec_byte) | 91 | static int olpc_bat_get_status(union power_supply_propval *val, uint8_t ec_byte) |
| 90 | { | 92 | { |
| 91 | if (olpc_platform_info.ecver > 0x44) { | 93 | if (olpc_platform_info.ecver > 0x44) { |
| 92 | if (ec_byte & BAT_STAT_CHARGING) | 94 | if (ec_byte & (BAT_STAT_CHARGING | BAT_STAT_TRICKLE)) |
| 93 | val->intval = POWER_SUPPLY_STATUS_CHARGING; | 95 | val->intval = POWER_SUPPLY_STATUS_CHARGING; |
| 94 | else if (ec_byte & BAT_STAT_DISCHARGING) | 96 | else if (ec_byte & BAT_STAT_DISCHARGING) |
| 95 | val->intval = POWER_SUPPLY_STATUS_DISCHARGING; | 97 | val->intval = POWER_SUPPLY_STATUS_DISCHARGING; |
| @@ -219,7 +221,8 @@ static int olpc_bat_get_property(struct power_supply *psy, | |||
| 219 | It doesn't matter though -- the EC will return the last-known | 221 | It doesn't matter though -- the EC will return the last-known |
| 220 | information, and it's as if we just ran that _little_ bit faster | 222 | information, and it's as if we just ran that _little_ bit faster |
| 221 | and managed to read it out before the battery went away. */ | 223 | and managed to read it out before the battery went away. */ |
| 222 | if (!(ec_byte & BAT_STAT_PRESENT) && psp != POWER_SUPPLY_PROP_PRESENT) | 224 | if (!(ec_byte & (BAT_STAT_PRESENT | BAT_STAT_TRICKLE)) && |
| 225 | psp != POWER_SUPPLY_PROP_PRESENT) | ||
| 223 | return -ENODEV; | 226 | return -ENODEV; |
| 224 | 227 | ||
| 225 | switch (psp) { | 228 | switch (psp) { |
| @@ -229,7 +232,8 @@ static int olpc_bat_get_property(struct power_supply *psy, | |||
| 229 | return ret; | 232 | return ret; |
| 230 | break; | 233 | break; |
| 231 | case POWER_SUPPLY_PROP_PRESENT: | 234 | case POWER_SUPPLY_PROP_PRESENT: |
| 232 | val->intval = !!(ec_byte & BAT_STAT_PRESENT); | 235 | val->intval = !!(ec_byte & (BAT_STAT_PRESENT | |
| 236 | BAT_STAT_TRICKLE)); | ||
| 233 | break; | 237 | break; |
| 234 | 238 | ||
| 235 | case POWER_SUPPLY_PROP_HEALTH: | 239 | case POWER_SUPPLY_PROP_HEALTH: |
| @@ -334,21 +338,21 @@ static ssize_t olpc_bat_eeprom_read(struct kobject *kobj, | |||
| 334 | struct bin_attribute *attr, char *buf, loff_t off, size_t count) | 338 | struct bin_attribute *attr, char *buf, loff_t off, size_t count) |
| 335 | { | 339 | { |
| 336 | uint8_t ec_byte; | 340 | uint8_t ec_byte; |
| 337 | int ret, end; | 341 | int ret; |
| 342 | int i; | ||
| 338 | 343 | ||
| 339 | if (off >= EEPROM_SIZE) | 344 | if (off >= EEPROM_SIZE) |
| 340 | return 0; | 345 | return 0; |
| 341 | if (off + count > EEPROM_SIZE) | 346 | if (off + count > EEPROM_SIZE) |
| 342 | count = EEPROM_SIZE - off; | 347 | count = EEPROM_SIZE - off; |
| 343 | 348 | ||
| 344 | end = EEPROM_START + off + count; | 349 | for (i = 0; i < count; i++) { |
| 345 | for (ec_byte = EEPROM_START + off; ec_byte < end; ec_byte++) { | 350 | ec_byte = EEPROM_START + off + i; |
| 346 | ret = olpc_ec_cmd(EC_BAT_EEPROM, &ec_byte, 1, | 351 | ret = olpc_ec_cmd(EC_BAT_EEPROM, &ec_byte, 1, &buf[i], 1); |
| 347 | &buf[ec_byte - EEPROM_START], 1); | ||
| 348 | if (ret) { | 352 | if (ret) { |
| 349 | printk(KERN_ERR "olpc-battery: EC command " | 353 | pr_err("olpc-battery: " |
| 350 | "EC_BAT_EEPROM @ 0x%x failed -" | 354 | "EC_BAT_EEPROM cmd @ 0x%x failed - %d!\n", |
| 351 | " %d!\n", ec_byte, ret); | 355 | ec_byte, ret); |
| 352 | return -EIO; | 356 | return -EIO; |
| 353 | } | 357 | } |
| 354 | } | 358 | } |
diff --git a/drivers/pps/pps.c b/drivers/pps/pps.c index ac8cc8cea1e3..fea17e7805e9 100644 --- a/drivers/pps/pps.c +++ b/drivers/pps/pps.c | |||
| @@ -244,7 +244,7 @@ int pps_register_cdev(struct pps_device *pps) | |||
| 244 | } | 244 | } |
| 245 | pps->dev = device_create(pps_class, pps->info.dev, pps->devno, NULL, | 245 | pps->dev = device_create(pps_class, pps->info.dev, pps->devno, NULL, |
| 246 | "pps%d", pps->id); | 246 | "pps%d", pps->id); |
| 247 | if (err) | 247 | if (IS_ERR(pps->dev)) |
| 248 | goto del_cdev; | 248 | goto del_cdev; |
| 249 | dev_set_drvdata(pps->dev, pps); | 249 | dev_set_drvdata(pps->dev, pps); |
| 250 | 250 | ||
diff --git a/drivers/rtc/rtc-cmos.c b/drivers/rtc/rtc-cmos.c index 23e10b6263d6..f7a4701bf863 100644 --- a/drivers/rtc/rtc-cmos.c +++ b/drivers/rtc/rtc-cmos.c | |||
| @@ -1174,23 +1174,34 @@ static struct platform_driver cmos_platform_driver = { | |||
| 1174 | } | 1174 | } |
| 1175 | }; | 1175 | }; |
| 1176 | 1176 | ||
| 1177 | #ifdef CONFIG_PNP | ||
| 1178 | static bool pnp_driver_registered; | ||
| 1179 | #endif | ||
| 1180 | static bool platform_driver_registered; | ||
| 1181 | |||
| 1177 | static int __init cmos_init(void) | 1182 | static int __init cmos_init(void) |
| 1178 | { | 1183 | { |
| 1179 | int retval = 0; | 1184 | int retval = 0; |
| 1180 | 1185 | ||
| 1181 | #ifdef CONFIG_PNP | 1186 | #ifdef CONFIG_PNP |
| 1182 | pnp_register_driver(&cmos_pnp_driver); | 1187 | retval = pnp_register_driver(&cmos_pnp_driver); |
| 1188 | if (retval == 0) | ||
| 1189 | pnp_driver_registered = true; | ||
| 1183 | #endif | 1190 | #endif |
| 1184 | 1191 | ||
| 1185 | if (!cmos_rtc.dev) | 1192 | if (!cmos_rtc.dev) { |
| 1186 | retval = platform_driver_probe(&cmos_platform_driver, | 1193 | retval = platform_driver_probe(&cmos_platform_driver, |
| 1187 | cmos_platform_probe); | 1194 | cmos_platform_probe); |
| 1195 | if (retval == 0) | ||
| 1196 | platform_driver_registered = true; | ||
| 1197 | } | ||
| 1188 | 1198 | ||
| 1189 | if (retval == 0) | 1199 | if (retval == 0) |
| 1190 | return 0; | 1200 | return 0; |
| 1191 | 1201 | ||
| 1192 | #ifdef CONFIG_PNP | 1202 | #ifdef CONFIG_PNP |
| 1193 | pnp_unregister_driver(&cmos_pnp_driver); | 1203 | if (pnp_driver_registered) |
| 1204 | pnp_unregister_driver(&cmos_pnp_driver); | ||
| 1194 | #endif | 1205 | #endif |
| 1195 | return retval; | 1206 | return retval; |
| 1196 | } | 1207 | } |
| @@ -1199,9 +1210,11 @@ module_init(cmos_init); | |||
| 1199 | static void __exit cmos_exit(void) | 1210 | static void __exit cmos_exit(void) |
| 1200 | { | 1211 | { |
| 1201 | #ifdef CONFIG_PNP | 1212 | #ifdef CONFIG_PNP |
| 1202 | pnp_unregister_driver(&cmos_pnp_driver); | 1213 | if (pnp_driver_registered) |
| 1214 | pnp_unregister_driver(&cmos_pnp_driver); | ||
| 1203 | #endif | 1215 | #endif |
| 1204 | platform_driver_unregister(&cmos_platform_driver); | 1216 | if (platform_driver_registered) |
| 1217 | platform_driver_unregister(&cmos_platform_driver); | ||
| 1205 | } | 1218 | } |
| 1206 | module_exit(cmos_exit); | 1219 | module_exit(cmos_exit); |
| 1207 | 1220 | ||
diff --git a/drivers/s390/block/dasd.c b/drivers/s390/block/dasd.c index 749836668655..3f62dd50bbbe 100644 --- a/drivers/s390/block/dasd.c +++ b/drivers/s390/block/dasd.c | |||
| @@ -2135,9 +2135,9 @@ static int dasd_getgeo(struct block_device *bdev, struct hd_geometry *geo) | |||
| 2135 | struct dasd_device *base; | 2135 | struct dasd_device *base; |
| 2136 | 2136 | ||
| 2137 | block = bdev->bd_disk->private_data; | 2137 | block = bdev->bd_disk->private_data; |
| 2138 | base = block->base; | ||
| 2139 | if (!block) | 2138 | if (!block) |
| 2140 | return -ENODEV; | 2139 | return -ENODEV; |
| 2140 | base = block->base; | ||
| 2141 | 2141 | ||
| 2142 | if (!base->discipline || | 2142 | if (!base->discipline || |
| 2143 | !base->discipline->fill_geometry) | 2143 | !base->discipline->fill_geometry) |
diff --git a/drivers/s390/cio/device.c b/drivers/s390/cio/device.c index 3c57c1a18bb8..d593bc76afe3 100644 --- a/drivers/s390/cio/device.c +++ b/drivers/s390/cio/device.c | |||
| @@ -772,10 +772,8 @@ static struct ccw_device * io_subchannel_create_ccwdev(struct subchannel *sch) | |||
| 772 | cdev = io_subchannel_allocate_dev(sch); | 772 | cdev = io_subchannel_allocate_dev(sch); |
| 773 | if (!IS_ERR(cdev)) { | 773 | if (!IS_ERR(cdev)) { |
| 774 | ret = io_subchannel_initialize_dev(sch, cdev); | 774 | ret = io_subchannel_initialize_dev(sch, cdev); |
| 775 | if (ret) { | 775 | if (ret) |
| 776 | kfree(cdev); | ||
| 777 | cdev = ERR_PTR(ret); | 776 | cdev = ERR_PTR(ret); |
| 778 | } | ||
| 779 | } | 777 | } |
| 780 | return cdev; | 778 | return cdev; |
| 781 | } | 779 | } |
diff --git a/drivers/s390/crypto/ap_bus.c b/drivers/s390/crypto/ap_bus.c index 727a809636d8..ed3dcdea7fe1 100644 --- a/drivers/s390/crypto/ap_bus.c +++ b/drivers/s390/crypto/ap_bus.c | |||
| @@ -1145,12 +1145,17 @@ ap_config_timeout(unsigned long ptr) | |||
| 1145 | */ | 1145 | */ |
| 1146 | static inline void ap_schedule_poll_timer(void) | 1146 | static inline void ap_schedule_poll_timer(void) |
| 1147 | { | 1147 | { |
| 1148 | ktime_t hr_time; | ||
| 1148 | if (ap_using_interrupts() || ap_suspend_flag) | 1149 | if (ap_using_interrupts() || ap_suspend_flag) |
| 1149 | return; | 1150 | return; |
| 1150 | if (hrtimer_is_queued(&ap_poll_timer)) | 1151 | if (hrtimer_is_queued(&ap_poll_timer)) |
| 1151 | return; | 1152 | return; |
| 1152 | hrtimer_start(&ap_poll_timer, ktime_set(0, poll_timeout), | 1153 | if (ktime_to_ns(hrtimer_expires_remaining(&ap_poll_timer)) <= 0) { |
| 1153 | HRTIMER_MODE_ABS); | 1154 | hr_time = ktime_set(0, poll_timeout); |
| 1155 | hrtimer_forward_now(&ap_poll_timer, hr_time); | ||
| 1156 | hrtimer_restart(&ap_poll_timer); | ||
| 1157 | } | ||
| 1158 | return; | ||
| 1154 | } | 1159 | } |
| 1155 | 1160 | ||
| 1156 | /** | 1161 | /** |
diff --git a/drivers/s390/scsi/zfcp_erp.c b/drivers/s390/scsi/zfcp_erp.c index 8030e25152fb..c75d6f35cb5f 100644 --- a/drivers/s390/scsi/zfcp_erp.c +++ b/drivers/s390/scsi/zfcp_erp.c | |||
| @@ -553,40 +553,35 @@ static void _zfcp_erp_unit_reopen_all(struct zfcp_port *port, int clear, | |||
| 553 | _zfcp_erp_unit_reopen(unit, clear, id, ref); | 553 | _zfcp_erp_unit_reopen(unit, clear, id, ref); |
| 554 | } | 554 | } |
| 555 | 555 | ||
| 556 | static void zfcp_erp_strategy_followup_actions(struct zfcp_erp_action *act) | 556 | static void zfcp_erp_strategy_followup_failed(struct zfcp_erp_action *act) |
| 557 | { | 557 | { |
| 558 | struct zfcp_adapter *adapter = act->adapter; | ||
| 559 | struct zfcp_port *port = act->port; | ||
| 560 | struct zfcp_unit *unit = act->unit; | ||
| 561 | u32 status = act->status; | ||
| 562 | |||
| 563 | /* initiate follow-up actions depending on success of finished action */ | ||
| 564 | switch (act->action) { | 558 | switch (act->action) { |
| 565 | |||
| 566 | case ZFCP_ERP_ACTION_REOPEN_ADAPTER: | 559 | case ZFCP_ERP_ACTION_REOPEN_ADAPTER: |
| 567 | if (status == ZFCP_ERP_SUCCEEDED) | 560 | _zfcp_erp_adapter_reopen(act->adapter, 0, "ersff_1", NULL); |
| 568 | _zfcp_erp_port_reopen_all(adapter, 0, "ersfa_1", NULL); | ||
| 569 | else | ||
| 570 | _zfcp_erp_adapter_reopen(adapter, 0, "ersfa_2", NULL); | ||
| 571 | break; | 561 | break; |
| 572 | |||
| 573 | case ZFCP_ERP_ACTION_REOPEN_PORT_FORCED: | 562 | case ZFCP_ERP_ACTION_REOPEN_PORT_FORCED: |
| 574 | if (status == ZFCP_ERP_SUCCEEDED) | 563 | _zfcp_erp_port_forced_reopen(act->port, 0, "ersff_2", NULL); |
| 575 | _zfcp_erp_port_reopen(port, 0, "ersfa_3", NULL); | ||
| 576 | else | ||
| 577 | _zfcp_erp_adapter_reopen(adapter, 0, "ersfa_4", NULL); | ||
| 578 | break; | 564 | break; |
| 579 | |||
| 580 | case ZFCP_ERP_ACTION_REOPEN_PORT: | 565 | case ZFCP_ERP_ACTION_REOPEN_PORT: |
| 581 | if (status == ZFCP_ERP_SUCCEEDED) | 566 | _zfcp_erp_port_reopen(act->port, 0, "ersff_3", NULL); |
| 582 | _zfcp_erp_unit_reopen_all(port, 0, "ersfa_5", NULL); | ||
| 583 | else | ||
| 584 | _zfcp_erp_port_forced_reopen(port, 0, "ersfa_6", NULL); | ||
| 585 | break; | 567 | break; |
| 586 | |||
| 587 | case ZFCP_ERP_ACTION_REOPEN_UNIT: | 568 | case ZFCP_ERP_ACTION_REOPEN_UNIT: |
| 588 | if (status != ZFCP_ERP_SUCCEEDED) | 569 | _zfcp_erp_unit_reopen(act->unit, 0, "ersff_4", NULL); |
| 589 | _zfcp_erp_port_reopen(unit->port, 0, "ersfa_7", NULL); | 570 | break; |
| 571 | } | ||
| 572 | } | ||
| 573 | |||
| 574 | static void zfcp_erp_strategy_followup_success(struct zfcp_erp_action *act) | ||
| 575 | { | ||
| 576 | switch (act->action) { | ||
| 577 | case ZFCP_ERP_ACTION_REOPEN_ADAPTER: | ||
| 578 | _zfcp_erp_port_reopen_all(act->adapter, 0, "ersfs_1", NULL); | ||
| 579 | break; | ||
| 580 | case ZFCP_ERP_ACTION_REOPEN_PORT_FORCED: | ||
| 581 | _zfcp_erp_port_reopen(act->port, 0, "ersfs_2", NULL); | ||
| 582 | break; | ||
| 583 | case ZFCP_ERP_ACTION_REOPEN_PORT: | ||
| 584 | _zfcp_erp_unit_reopen_all(act->port, 0, "ersfs_3", NULL); | ||
| 590 | break; | 585 | break; |
| 591 | } | 586 | } |
| 592 | } | 587 | } |
| @@ -801,7 +796,7 @@ static int zfcp_erp_port_forced_strategy(struct zfcp_erp_action *erp_action) | |||
| 801 | return ZFCP_ERP_FAILED; | 796 | return ZFCP_ERP_FAILED; |
| 802 | 797 | ||
| 803 | case ZFCP_ERP_STEP_PHYS_PORT_CLOSING: | 798 | case ZFCP_ERP_STEP_PHYS_PORT_CLOSING: |
| 804 | if (status & ZFCP_STATUS_PORT_PHYS_OPEN) | 799 | if (!(status & ZFCP_STATUS_PORT_PHYS_OPEN)) |
| 805 | return ZFCP_ERP_SUCCEEDED; | 800 | return ZFCP_ERP_SUCCEEDED; |
| 806 | } | 801 | } |
| 807 | return ZFCP_ERP_FAILED; | 802 | return ZFCP_ERP_FAILED; |
| @@ -853,11 +848,17 @@ void zfcp_erp_port_strategy_open_lookup(struct work_struct *work) | |||
| 853 | gid_pn_work); | 848 | gid_pn_work); |
| 854 | 849 | ||
| 855 | retval = zfcp_fc_ns_gid_pn(&port->erp_action); | 850 | retval = zfcp_fc_ns_gid_pn(&port->erp_action); |
| 856 | if (retval == -ENOMEM) | 851 | if (!retval) { |
| 857 | zfcp_erp_notify(&port->erp_action, ZFCP_ERP_NOMEM); | 852 | port->erp_action.step = ZFCP_ERP_STEP_NAMESERVER_LOOKUP; |
| 858 | port->erp_action.step = ZFCP_ERP_STEP_NAMESERVER_LOOKUP; | 853 | goto out; |
| 859 | if (retval) | 854 | } |
| 860 | zfcp_erp_notify(&port->erp_action, ZFCP_ERP_FAILED); | 855 | if (retval == -ENOMEM) { |
| 856 | zfcp_erp_notify(&port->erp_action, ZFCP_STATUS_ERP_LOWMEM); | ||
| 857 | goto out; | ||
| 858 | } | ||
| 859 | /* all other error condtions */ | ||
| 860 | zfcp_erp_notify(&port->erp_action, 0); | ||
| 861 | out: | ||
| 861 | zfcp_port_put(port); | 862 | zfcp_port_put(port); |
| 862 | } | 863 | } |
| 863 | 864 | ||
| @@ -1289,7 +1290,10 @@ static int zfcp_erp_strategy(struct zfcp_erp_action *erp_action) | |||
| 1289 | retval = zfcp_erp_strategy_statechange(erp_action, retval); | 1290 | retval = zfcp_erp_strategy_statechange(erp_action, retval); |
| 1290 | if (retval == ZFCP_ERP_EXIT) | 1291 | if (retval == ZFCP_ERP_EXIT) |
| 1291 | goto unlock; | 1292 | goto unlock; |
| 1292 | zfcp_erp_strategy_followup_actions(erp_action); | 1293 | if (retval == ZFCP_ERP_SUCCEEDED) |
| 1294 | zfcp_erp_strategy_followup_success(erp_action); | ||
| 1295 | if (retval == ZFCP_ERP_FAILED) | ||
| 1296 | zfcp_erp_strategy_followup_failed(erp_action); | ||
| 1293 | 1297 | ||
| 1294 | unlock: | 1298 | unlock: |
| 1295 | write_unlock(&adapter->erp_lock); | 1299 | write_unlock(&adapter->erp_lock); |
diff --git a/drivers/s390/scsi/zfcp_fc.c b/drivers/s390/scsi/zfcp_fc.c index 2f0705d76b72..47daebfa7e59 100644 --- a/drivers/s390/scsi/zfcp_fc.c +++ b/drivers/s390/scsi/zfcp_fc.c | |||
| @@ -79,11 +79,9 @@ static int zfcp_wka_port_get(struct zfcp_wka_port *wka_port) | |||
| 79 | 79 | ||
| 80 | mutex_unlock(&wka_port->mutex); | 80 | mutex_unlock(&wka_port->mutex); |
| 81 | 81 | ||
| 82 | wait_event_timeout( | 82 | wait_event(wka_port->completion_wq, |
| 83 | wka_port->completion_wq, | 83 | wka_port->status == ZFCP_WKA_PORT_ONLINE || |
| 84 | wka_port->status == ZFCP_WKA_PORT_ONLINE || | 84 | wka_port->status == ZFCP_WKA_PORT_OFFLINE); |
| 85 | wka_port->status == ZFCP_WKA_PORT_OFFLINE, | ||
| 86 | HZ >> 1); | ||
| 87 | 85 | ||
| 88 | if (wka_port->status == ZFCP_WKA_PORT_ONLINE) { | 86 | if (wka_port->status == ZFCP_WKA_PORT_ONLINE) { |
| 89 | atomic_inc(&wka_port->refcount); | 87 | atomic_inc(&wka_port->refcount); |
diff --git a/drivers/s390/scsi/zfcp_fsf.c b/drivers/s390/scsi/zfcp_fsf.c index c57658f3d34f..47795fbf081f 100644 --- a/drivers/s390/scsi/zfcp_fsf.c +++ b/drivers/s390/scsi/zfcp_fsf.c | |||
| @@ -670,8 +670,11 @@ static int zfcp_fsf_req_sbal_get(struct zfcp_adapter *adapter) | |||
| 670 | zfcp_fsf_sbal_check(adapter), 5 * HZ); | 670 | zfcp_fsf_sbal_check(adapter), 5 * HZ); |
| 671 | if (ret > 0) | 671 | if (ret > 0) |
| 672 | return 0; | 672 | return 0; |
| 673 | if (!ret) | 673 | if (!ret) { |
| 674 | atomic_inc(&adapter->qdio_outb_full); | 674 | atomic_inc(&adapter->qdio_outb_full); |
| 675 | /* assume hanging outbound queue, try queue recovery */ | ||
| 676 | zfcp_erp_adapter_reopen(adapter, 0, "fsrsg_1", NULL); | ||
| 677 | } | ||
| 675 | 678 | ||
| 676 | spin_lock_bh(&adapter->req_q_lock); | 679 | spin_lock_bh(&adapter->req_q_lock); |
| 677 | return -EIO; | 680 | return -EIO; |
| @@ -722,7 +725,7 @@ static struct zfcp_fsf_req *zfcp_fsf_req_create(struct zfcp_adapter *adapter, | |||
| 722 | req = zfcp_fsf_alloc_qtcb(pool); | 725 | req = zfcp_fsf_alloc_qtcb(pool); |
| 723 | 726 | ||
| 724 | if (unlikely(!req)) | 727 | if (unlikely(!req)) |
| 725 | return ERR_PTR(-EIO); | 728 | return ERR_PTR(-ENOMEM); |
| 726 | 729 | ||
| 727 | if (adapter->req_no == 0) | 730 | if (adapter->req_no == 0) |
| 728 | adapter->req_no++; | 731 | adapter->req_no++; |
| @@ -1010,6 +1013,23 @@ skip_fsfstatus: | |||
| 1010 | send_ct->handler(send_ct->handler_data); | 1013 | send_ct->handler(send_ct->handler_data); |
| 1011 | } | 1014 | } |
| 1012 | 1015 | ||
| 1016 | static void zfcp_fsf_setup_ct_els_unchained(struct qdio_buffer_element *sbale, | ||
| 1017 | struct scatterlist *sg_req, | ||
| 1018 | struct scatterlist *sg_resp) | ||
| 1019 | { | ||
| 1020 | sbale[0].flags |= SBAL_FLAGS0_TYPE_WRITE_READ; | ||
| 1021 | sbale[2].addr = sg_virt(sg_req); | ||
| 1022 | sbale[2].length = sg_req->length; | ||
| 1023 | sbale[3].addr = sg_virt(sg_resp); | ||
| 1024 | sbale[3].length = sg_resp->length; | ||
| 1025 | sbale[3].flags |= SBAL_FLAGS_LAST_ENTRY; | ||
| 1026 | } | ||
| 1027 | |||
| 1028 | static int zfcp_fsf_one_sbal(struct scatterlist *sg) | ||
| 1029 | { | ||
| 1030 | return sg_is_last(sg) && sg->length <= PAGE_SIZE; | ||
| 1031 | } | ||
| 1032 | |||
| 1013 | static int zfcp_fsf_setup_ct_els_sbals(struct zfcp_fsf_req *req, | 1033 | static int zfcp_fsf_setup_ct_els_sbals(struct zfcp_fsf_req *req, |
| 1014 | struct scatterlist *sg_req, | 1034 | struct scatterlist *sg_req, |
| 1015 | struct scatterlist *sg_resp, | 1035 | struct scatterlist *sg_resp, |
| @@ -1020,30 +1040,30 @@ static int zfcp_fsf_setup_ct_els_sbals(struct zfcp_fsf_req *req, | |||
| 1020 | int bytes; | 1040 | int bytes; |
| 1021 | 1041 | ||
| 1022 | if (!(feat & FSF_FEATURE_ELS_CT_CHAINED_SBALS)) { | 1042 | if (!(feat & FSF_FEATURE_ELS_CT_CHAINED_SBALS)) { |
| 1023 | if (sg_req->length > PAGE_SIZE || sg_resp->length > PAGE_SIZE || | 1043 | if (!zfcp_fsf_one_sbal(sg_req) || !zfcp_fsf_one_sbal(sg_resp)) |
| 1024 | !sg_is_last(sg_req) || !sg_is_last(sg_resp)) | ||
| 1025 | return -EOPNOTSUPP; | 1044 | return -EOPNOTSUPP; |
| 1026 | 1045 | ||
| 1027 | sbale[0].flags |= SBAL_FLAGS0_TYPE_WRITE_READ; | 1046 | zfcp_fsf_setup_ct_els_unchained(sbale, sg_req, sg_resp); |
| 1028 | sbale[2].addr = sg_virt(sg_req); | 1047 | return 0; |
| 1029 | sbale[2].length = sg_req->length; | 1048 | } |
| 1030 | sbale[3].addr = sg_virt(sg_resp); | 1049 | |
| 1031 | sbale[3].length = sg_resp->length; | 1050 | /* use single, unchained SBAL if it can hold the request */ |
| 1032 | sbale[3].flags |= SBAL_FLAGS_LAST_ENTRY; | 1051 | if (zfcp_fsf_one_sbal(sg_req) && zfcp_fsf_one_sbal(sg_resp)) { |
| 1052 | zfcp_fsf_setup_ct_els_unchained(sbale, sg_req, sg_resp); | ||
| 1033 | return 0; | 1053 | return 0; |
| 1034 | } | 1054 | } |
| 1035 | 1055 | ||
| 1036 | bytes = zfcp_qdio_sbals_from_sg(req, SBAL_FLAGS0_TYPE_WRITE_READ, | 1056 | bytes = zfcp_qdio_sbals_from_sg(req, SBAL_FLAGS0_TYPE_WRITE_READ, |
| 1037 | sg_req, max_sbals); | 1057 | sg_req, max_sbals); |
| 1038 | if (bytes <= 0) | 1058 | if (bytes <= 0) |
| 1039 | return -ENOMEM; | 1059 | return -EIO; |
| 1040 | req->qtcb->bottom.support.req_buf_length = bytes; | 1060 | req->qtcb->bottom.support.req_buf_length = bytes; |
| 1041 | req->sbale_curr = ZFCP_LAST_SBALE_PER_SBAL; | 1061 | req->sbale_curr = ZFCP_LAST_SBALE_PER_SBAL; |
| 1042 | 1062 | ||
| 1043 | bytes = zfcp_qdio_sbals_from_sg(req, SBAL_FLAGS0_TYPE_WRITE_READ, | 1063 | bytes = zfcp_qdio_sbals_from_sg(req, SBAL_FLAGS0_TYPE_WRITE_READ, |
| 1044 | sg_resp, max_sbals); | 1064 | sg_resp, max_sbals); |
| 1045 | if (bytes <= 0) | 1065 | if (bytes <= 0) |
| 1046 | return -ENOMEM; | 1066 | return -EIO; |
| 1047 | req->qtcb->bottom.support.resp_buf_length = bytes; | 1067 | req->qtcb->bottom.support.resp_buf_length = bytes; |
| 1048 | 1068 | ||
| 1049 | return 0; | 1069 | return 0; |
| @@ -1607,10 +1627,10 @@ static void zfcp_fsf_open_wka_port_handler(struct zfcp_fsf_req *req) | |||
| 1607 | case FSF_ACCESS_DENIED: | 1627 | case FSF_ACCESS_DENIED: |
| 1608 | wka_port->status = ZFCP_WKA_PORT_OFFLINE; | 1628 | wka_port->status = ZFCP_WKA_PORT_OFFLINE; |
| 1609 | break; | 1629 | break; |
| 1610 | case FSF_PORT_ALREADY_OPEN: | ||
| 1611 | break; | ||
| 1612 | case FSF_GOOD: | 1630 | case FSF_GOOD: |
| 1613 | wka_port->handle = header->port_handle; | 1631 | wka_port->handle = header->port_handle; |
| 1632 | /* fall through */ | ||
| 1633 | case FSF_PORT_ALREADY_OPEN: | ||
| 1614 | wka_port->status = ZFCP_WKA_PORT_ONLINE; | 1634 | wka_port->status = ZFCP_WKA_PORT_ONLINE; |
| 1615 | } | 1635 | } |
| 1616 | out: | 1636 | out: |
| @@ -1731,15 +1751,16 @@ static void zfcp_fsf_close_physical_port_handler(struct zfcp_fsf_req *req) | |||
| 1731 | zfcp_fsf_access_denied_port(req, port); | 1751 | zfcp_fsf_access_denied_port(req, port); |
| 1732 | break; | 1752 | break; |
| 1733 | case FSF_PORT_BOXED: | 1753 | case FSF_PORT_BOXED: |
| 1734 | zfcp_erp_port_boxed(port, "fscpph2", req); | ||
| 1735 | req->status |= ZFCP_STATUS_FSFREQ_ERROR | | ||
| 1736 | ZFCP_STATUS_FSFREQ_RETRY; | ||
| 1737 | /* can't use generic zfcp_erp_modify_port_status because | 1754 | /* can't use generic zfcp_erp_modify_port_status because |
| 1738 | * ZFCP_STATUS_COMMON_OPEN must not be reset for the port */ | 1755 | * ZFCP_STATUS_COMMON_OPEN must not be reset for the port */ |
| 1739 | atomic_clear_mask(ZFCP_STATUS_PORT_PHYS_OPEN, &port->status); | 1756 | atomic_clear_mask(ZFCP_STATUS_PORT_PHYS_OPEN, &port->status); |
| 1740 | list_for_each_entry(unit, &port->unit_list_head, list) | 1757 | list_for_each_entry(unit, &port->unit_list_head, list) |
| 1741 | atomic_clear_mask(ZFCP_STATUS_COMMON_OPEN, | 1758 | atomic_clear_mask(ZFCP_STATUS_COMMON_OPEN, |
| 1742 | &unit->status); | 1759 | &unit->status); |
| 1760 | zfcp_erp_port_boxed(port, "fscpph2", req); | ||
| 1761 | req->status |= ZFCP_STATUS_FSFREQ_ERROR | | ||
| 1762 | ZFCP_STATUS_FSFREQ_RETRY; | ||
| 1763 | |||
| 1743 | break; | 1764 | break; |
| 1744 | case FSF_ADAPTER_STATUS_AVAILABLE: | 1765 | case FSF_ADAPTER_STATUS_AVAILABLE: |
| 1745 | switch (header->fsf_status_qual.word[0]) { | 1766 | switch (header->fsf_status_qual.word[0]) { |
| @@ -2541,7 +2562,6 @@ struct zfcp_fsf_req *zfcp_fsf_control_file(struct zfcp_adapter *adapter, | |||
| 2541 | bytes = zfcp_qdio_sbals_from_sg(req, direction, fsf_cfdc->sg, | 2562 | bytes = zfcp_qdio_sbals_from_sg(req, direction, fsf_cfdc->sg, |
| 2542 | FSF_MAX_SBALS_PER_REQ); | 2563 | FSF_MAX_SBALS_PER_REQ); |
| 2543 | if (bytes != ZFCP_CFDC_MAX_SIZE) { | 2564 | if (bytes != ZFCP_CFDC_MAX_SIZE) { |
| 2544 | retval = -ENOMEM; | ||
| 2545 | zfcp_fsf_req_free(req); | 2565 | zfcp_fsf_req_free(req); |
| 2546 | goto out; | 2566 | goto out; |
| 2547 | } | 2567 | } |
diff --git a/drivers/s390/scsi/zfcp_scsi.c b/drivers/s390/scsi/zfcp_scsi.c index 967ede73f4c5..6925a1784682 100644 --- a/drivers/s390/scsi/zfcp_scsi.c +++ b/drivers/s390/scsi/zfcp_scsi.c | |||
| @@ -167,20 +167,21 @@ static int zfcp_scsi_eh_abort_handler(struct scsi_cmnd *scpnt) | |||
| 167 | struct zfcp_unit *unit = scpnt->device->hostdata; | 167 | struct zfcp_unit *unit = scpnt->device->hostdata; |
| 168 | struct zfcp_fsf_req *old_req, *abrt_req; | 168 | struct zfcp_fsf_req *old_req, *abrt_req; |
| 169 | unsigned long flags; | 169 | unsigned long flags; |
| 170 | unsigned long old_req_id = (unsigned long) scpnt->host_scribble; | 170 | unsigned long old_reqid = (unsigned long) scpnt->host_scribble; |
| 171 | int retval = SUCCESS; | 171 | int retval = SUCCESS; |
| 172 | int retry = 3; | 172 | int retry = 3; |
| 173 | char *dbf_tag; | ||
| 173 | 174 | ||
| 174 | /* avoid race condition between late normal completion and abort */ | 175 | /* avoid race condition between late normal completion and abort */ |
| 175 | write_lock_irqsave(&adapter->abort_lock, flags); | 176 | write_lock_irqsave(&adapter->abort_lock, flags); |
| 176 | 177 | ||
| 177 | spin_lock(&adapter->req_list_lock); | 178 | spin_lock(&adapter->req_list_lock); |
| 178 | old_req = zfcp_reqlist_find(adapter, old_req_id); | 179 | old_req = zfcp_reqlist_find(adapter, old_reqid); |
| 179 | spin_unlock(&adapter->req_list_lock); | 180 | spin_unlock(&adapter->req_list_lock); |
| 180 | if (!old_req) { | 181 | if (!old_req) { |
| 181 | write_unlock_irqrestore(&adapter->abort_lock, flags); | 182 | write_unlock_irqrestore(&adapter->abort_lock, flags); |
| 182 | zfcp_scsi_dbf_event_abort("lte1", adapter, scpnt, NULL, | 183 | zfcp_scsi_dbf_event_abort("lte1", adapter, scpnt, NULL, |
| 183 | old_req_id); | 184 | old_reqid); |
| 184 | return FAILED; /* completion could be in progress */ | 185 | return FAILED; /* completion could be in progress */ |
| 185 | } | 186 | } |
| 186 | old_req->data = NULL; | 187 | old_req->data = NULL; |
| @@ -189,7 +190,7 @@ static int zfcp_scsi_eh_abort_handler(struct scsi_cmnd *scpnt) | |||
| 189 | write_unlock_irqrestore(&adapter->abort_lock, flags); | 190 | write_unlock_irqrestore(&adapter->abort_lock, flags); |
| 190 | 191 | ||
| 191 | while (retry--) { | 192 | while (retry--) { |
| 192 | abrt_req = zfcp_fsf_abort_fcp_command(old_req_id, unit); | 193 | abrt_req = zfcp_fsf_abort_fcp_command(old_reqid, unit); |
| 193 | if (abrt_req) | 194 | if (abrt_req) |
| 194 | break; | 195 | break; |
| 195 | 196 | ||
| @@ -197,7 +198,7 @@ static int zfcp_scsi_eh_abort_handler(struct scsi_cmnd *scpnt) | |||
| 197 | if (!(atomic_read(&adapter->status) & | 198 | if (!(atomic_read(&adapter->status) & |
| 198 | ZFCP_STATUS_COMMON_RUNNING)) { | 199 | ZFCP_STATUS_COMMON_RUNNING)) { |
| 199 | zfcp_scsi_dbf_event_abort("nres", adapter, scpnt, NULL, | 200 | zfcp_scsi_dbf_event_abort("nres", adapter, scpnt, NULL, |
| 200 | old_req_id); | 201 | old_reqid); |
| 201 | return SUCCESS; | 202 | return SUCCESS; |
| 202 | } | 203 | } |
| 203 | } | 204 | } |
| @@ -208,13 +209,14 @@ static int zfcp_scsi_eh_abort_handler(struct scsi_cmnd *scpnt) | |||
| 208 | abrt_req->status & ZFCP_STATUS_FSFREQ_COMPLETED); | 209 | abrt_req->status & ZFCP_STATUS_FSFREQ_COMPLETED); |
| 209 | 210 | ||
| 210 | if (abrt_req->status & ZFCP_STATUS_FSFREQ_ABORTSUCCEEDED) | 211 | if (abrt_req->status & ZFCP_STATUS_FSFREQ_ABORTSUCCEEDED) |
| 211 | zfcp_scsi_dbf_event_abort("okay", adapter, scpnt, abrt_req, 0); | 212 | dbf_tag = "okay"; |
| 212 | else if (abrt_req->status & ZFCP_STATUS_FSFREQ_ABORTNOTNEEDED) | 213 | else if (abrt_req->status & ZFCP_STATUS_FSFREQ_ABORTNOTNEEDED) |
| 213 | zfcp_scsi_dbf_event_abort("lte2", adapter, scpnt, abrt_req, 0); | 214 | dbf_tag = "lte2"; |
| 214 | else { | 215 | else { |
| 215 | zfcp_scsi_dbf_event_abort("fail", adapter, scpnt, abrt_req, 0); | 216 | dbf_tag = "fail"; |
| 216 | retval = FAILED; | 217 | retval = FAILED; |
| 217 | } | 218 | } |
| 219 | zfcp_scsi_dbf_event_abort(dbf_tag, adapter, scpnt, abrt_req, old_reqid); | ||
| 218 | zfcp_fsf_req_free(abrt_req); | 220 | zfcp_fsf_req_free(abrt_req); |
| 219 | return retval; | 221 | return retval; |
| 220 | } | 222 | } |
| @@ -534,6 +536,9 @@ static void zfcp_scsi_rport_register(struct zfcp_port *port) | |||
| 534 | struct fc_rport_identifiers ids; | 536 | struct fc_rport_identifiers ids; |
| 535 | struct fc_rport *rport; | 537 | struct fc_rport *rport; |
| 536 | 538 | ||
| 539 | if (port->rport) | ||
| 540 | return; | ||
| 541 | |||
| 537 | ids.node_name = port->wwnn; | 542 | ids.node_name = port->wwnn; |
| 538 | ids.port_name = port->wwpn; | 543 | ids.port_name = port->wwpn; |
| 539 | ids.port_id = port->d_id; | 544 | ids.port_id = port->d_id; |
| @@ -557,8 +562,10 @@ static void zfcp_scsi_rport_block(struct zfcp_port *port) | |||
| 557 | { | 562 | { |
| 558 | struct fc_rport *rport = port->rport; | 563 | struct fc_rport *rport = port->rport; |
| 559 | 564 | ||
| 560 | if (rport) | 565 | if (rport) { |
| 561 | fc_remote_port_delete(rport); | 566 | fc_remote_port_delete(rport); |
| 567 | port->rport = NULL; | ||
| 568 | } | ||
| 562 | } | 569 | } |
| 563 | 570 | ||
| 564 | void zfcp_scsi_schedule_rport_register(struct zfcp_port *port) | 571 | void zfcp_scsi_schedule_rport_register(struct zfcp_port *port) |
diff --git a/drivers/s390/scsi/zfcp_sysfs.c b/drivers/s390/scsi/zfcp_sysfs.c index 3e51e64d1108..0fe5cce818cb 100644 --- a/drivers/s390/scsi/zfcp_sysfs.c +++ b/drivers/s390/scsi/zfcp_sysfs.c | |||
| @@ -494,9 +494,14 @@ static ssize_t zfcp_sysfs_adapter_q_full_show(struct device *dev, | |||
| 494 | struct Scsi_Host *scsi_host = class_to_shost(dev); | 494 | struct Scsi_Host *scsi_host = class_to_shost(dev); |
| 495 | struct zfcp_adapter *adapter = | 495 | struct zfcp_adapter *adapter = |
| 496 | (struct zfcp_adapter *) scsi_host->hostdata[0]; | 496 | (struct zfcp_adapter *) scsi_host->hostdata[0]; |
| 497 | u64 util; | ||
| 498 | |||
| 499 | spin_lock_bh(&adapter->qdio_stat_lock); | ||
| 500 | util = adapter->req_q_util; | ||
| 501 | spin_unlock_bh(&adapter->qdio_stat_lock); | ||
| 497 | 502 | ||
| 498 | return sprintf(buf, "%d %llu\n", atomic_read(&adapter->qdio_outb_full), | 503 | return sprintf(buf, "%d %llu\n", atomic_read(&adapter->qdio_outb_full), |
| 499 | (unsigned long long)adapter->req_q_util); | 504 | (unsigned long long)util); |
| 500 | } | 505 | } |
| 501 | static DEVICE_ATTR(queue_full, S_IRUGO, zfcp_sysfs_adapter_q_full_show, NULL); | 506 | static DEVICE_ATTR(queue_full, S_IRUGO, zfcp_sysfs_adapter_q_full_show, NULL); |
| 502 | 507 | ||
diff --git a/drivers/sbus/char/bbc_envctrl.c b/drivers/sbus/char/bbc_envctrl.c index 15dab96d05e3..7c815d3327f7 100644 --- a/drivers/sbus/char/bbc_envctrl.c +++ b/drivers/sbus/char/bbc_envctrl.c | |||
| @@ -537,8 +537,12 @@ int bbc_envctrl_init(struct bbc_i2c_bus *bp) | |||
| 537 | } | 537 | } |
| 538 | if (temp_index != 0 && fan_index != 0) { | 538 | if (temp_index != 0 && fan_index != 0) { |
| 539 | kenvctrld_task = kthread_run(kenvctrld, NULL, "kenvctrld"); | 539 | kenvctrld_task = kthread_run(kenvctrld, NULL, "kenvctrld"); |
| 540 | if (IS_ERR(kenvctrld_task)) | 540 | if (IS_ERR(kenvctrld_task)) { |
| 541 | return PTR_ERR(kenvctrld_task); | 541 | int err = PTR_ERR(kenvctrld_task); |
| 542 | |||
| 543 | kenvctrld_task = NULL; | ||
| 544 | return err; | ||
| 545 | } | ||
| 542 | } | 546 | } |
| 543 | 547 | ||
| 544 | return 0; | 548 | return 0; |
| @@ -561,7 +565,8 @@ void bbc_envctrl_cleanup(struct bbc_i2c_bus *bp) | |||
| 561 | struct bbc_cpu_temperature *tp, *tpos; | 565 | struct bbc_cpu_temperature *tp, *tpos; |
| 562 | struct bbc_fan_control *fp, *fpos; | 566 | struct bbc_fan_control *fp, *fpos; |
| 563 | 567 | ||
| 564 | kthread_stop(kenvctrld_task); | 568 | if (kenvctrld_task) |
| 569 | kthread_stop(kenvctrld_task); | ||
| 565 | 570 | ||
| 566 | list_for_each_entry_safe(tp, tpos, &bp->temps, bp_list) { | 571 | list_for_each_entry_safe(tp, tpos, &bp->temps, bp_list) { |
| 567 | list_del(&tp->bp_list); | 572 | list_del(&tp->bp_list); |
diff --git a/drivers/scsi/libfc/fc_exch.c b/drivers/scsi/libfc/fc_exch.c index 2bc22be5f849..145ab9ba55ea 100644 --- a/drivers/scsi/libfc/fc_exch.c +++ b/drivers/scsi/libfc/fc_exch.c | |||
| @@ -415,9 +415,9 @@ static void fc_exch_timeout(struct work_struct *work) | |||
| 415 | e_stat = ep->esb_stat; | 415 | e_stat = ep->esb_stat; |
| 416 | if (e_stat & ESB_ST_COMPLETE) { | 416 | if (e_stat & ESB_ST_COMPLETE) { |
| 417 | ep->esb_stat = e_stat & ~ESB_ST_REC_QUAL; | 417 | ep->esb_stat = e_stat & ~ESB_ST_REC_QUAL; |
| 418 | spin_unlock_bh(&ep->ex_lock); | ||
| 418 | if (e_stat & ESB_ST_REC_QUAL) | 419 | if (e_stat & ESB_ST_REC_QUAL) |
| 419 | fc_exch_rrq(ep); | 420 | fc_exch_rrq(ep); |
| 420 | spin_unlock_bh(&ep->ex_lock); | ||
| 421 | goto done; | 421 | goto done; |
| 422 | } else { | 422 | } else { |
| 423 | resp = ep->resp; | 423 | resp = ep->resp; |
| @@ -1624,14 +1624,14 @@ static void fc_exch_rrq(struct fc_exch *ep) | |||
| 1624 | struct fc_lport *lp; | 1624 | struct fc_lport *lp; |
| 1625 | struct fc_els_rrq *rrq; | 1625 | struct fc_els_rrq *rrq; |
| 1626 | struct fc_frame *fp; | 1626 | struct fc_frame *fp; |
| 1627 | struct fc_seq *rrq_sp; | ||
| 1628 | u32 did; | 1627 | u32 did; |
| 1629 | 1628 | ||
| 1630 | lp = ep->lp; | 1629 | lp = ep->lp; |
| 1631 | 1630 | ||
| 1632 | fp = fc_frame_alloc(lp, sizeof(*rrq)); | 1631 | fp = fc_frame_alloc(lp, sizeof(*rrq)); |
| 1633 | if (!fp) | 1632 | if (!fp) |
| 1634 | return; | 1633 | goto retry; |
| 1634 | |||
| 1635 | rrq = fc_frame_payload_get(fp, sizeof(*rrq)); | 1635 | rrq = fc_frame_payload_get(fp, sizeof(*rrq)); |
| 1636 | memset(rrq, 0, sizeof(*rrq)); | 1636 | memset(rrq, 0, sizeof(*rrq)); |
| 1637 | rrq->rrq_cmd = ELS_RRQ; | 1637 | rrq->rrq_cmd = ELS_RRQ; |
| @@ -1647,13 +1647,20 @@ static void fc_exch_rrq(struct fc_exch *ep) | |||
| 1647 | fc_host_port_id(lp->host), FC_TYPE_ELS, | 1647 | fc_host_port_id(lp->host), FC_TYPE_ELS, |
| 1648 | FC_FC_FIRST_SEQ | FC_FC_END_SEQ | FC_FC_SEQ_INIT, 0); | 1648 | FC_FC_FIRST_SEQ | FC_FC_END_SEQ | FC_FC_SEQ_INIT, 0); |
| 1649 | 1649 | ||
| 1650 | rrq_sp = fc_exch_seq_send(lp, fp, fc_exch_rrq_resp, NULL, ep, | 1650 | if (fc_exch_seq_send(lp, fp, fc_exch_rrq_resp, NULL, ep, lp->e_d_tov)) |
| 1651 | lp->e_d_tov); | 1651 | return; |
| 1652 | if (!rrq_sp) { | 1652 | |
| 1653 | ep->esb_stat |= ESB_ST_REC_QUAL; | 1653 | retry: |
| 1654 | fc_exch_timer_set_locked(ep, ep->r_a_tov); | 1654 | spin_lock_bh(&ep->ex_lock); |
| 1655 | if (ep->state & (FC_EX_RST_CLEANUP | FC_EX_DONE)) { | ||
| 1656 | spin_unlock_bh(&ep->ex_lock); | ||
| 1657 | /* drop hold for rec qual */ | ||
| 1658 | fc_exch_release(ep); | ||
| 1655 | return; | 1659 | return; |
| 1656 | } | 1660 | } |
| 1661 | ep->esb_stat |= ESB_ST_REC_QUAL; | ||
| 1662 | fc_exch_timer_set_locked(ep, ep->r_a_tov); | ||
| 1663 | spin_unlock_bh(&ep->ex_lock); | ||
| 1657 | } | 1664 | } |
| 1658 | 1665 | ||
| 1659 | 1666 | ||
diff --git a/drivers/scsi/libiscsi.c b/drivers/scsi/libiscsi.c index 716cc344c5df..a751f6230c22 100644 --- a/drivers/scsi/libiscsi.c +++ b/drivers/scsi/libiscsi.c | |||
| @@ -1974,10 +1974,10 @@ int iscsi_eh_abort(struct scsi_cmnd *sc) | |||
| 1974 | * good and have never sent us a successful tmf response | 1974 | * good and have never sent us a successful tmf response |
| 1975 | * then sent more data for the cmd. | 1975 | * then sent more data for the cmd. |
| 1976 | */ | 1976 | */ |
| 1977 | spin_lock(&session->lock); | 1977 | spin_lock_bh(&session->lock); |
| 1978 | fail_scsi_task(task, DID_ABORT); | 1978 | fail_scsi_task(task, DID_ABORT); |
| 1979 | conn->tmf_state = TMF_INITIAL; | 1979 | conn->tmf_state = TMF_INITIAL; |
| 1980 | spin_unlock(&session->lock); | 1980 | spin_unlock_bh(&session->lock); |
| 1981 | iscsi_start_tx(conn); | 1981 | iscsi_start_tx(conn); |
| 1982 | goto success_unlocked; | 1982 | goto success_unlocked; |
| 1983 | case TMF_TIMEDOUT: | 1983 | case TMF_TIMEDOUT: |
diff --git a/drivers/scsi/libsas/sas_expander.c b/drivers/scsi/libsas/sas_expander.c index 54fa1e42dc4d..b3381959acce 100644 --- a/drivers/scsi/libsas/sas_expander.c +++ b/drivers/scsi/libsas/sas_expander.c | |||
| @@ -766,6 +766,7 @@ static int sas_ex_join_wide_port(struct domain_device *parent, int phy_id) | |||
| 766 | if (!memcmp(phy->attached_sas_addr, ephy->attached_sas_addr, | 766 | if (!memcmp(phy->attached_sas_addr, ephy->attached_sas_addr, |
| 767 | SAS_ADDR_SIZE) && ephy->port) { | 767 | SAS_ADDR_SIZE) && ephy->port) { |
| 768 | sas_port_add_phy(ephy->port, phy->phy); | 768 | sas_port_add_phy(ephy->port, phy->phy); |
| 769 | phy->port = ephy->port; | ||
| 769 | phy->phy_state = PHY_DEVICE_DISCOVERED; | 770 | phy->phy_state = PHY_DEVICE_DISCOVERED; |
| 770 | return 0; | 771 | return 0; |
| 771 | } | 772 | } |
| @@ -945,11 +946,21 @@ static int sas_ex_discover_dev(struct domain_device *dev, int phy_id) | |||
| 945 | if (ex->ex_phy[i].phy_state == PHY_VACANT || | 946 | if (ex->ex_phy[i].phy_state == PHY_VACANT || |
| 946 | ex->ex_phy[i].phy_state == PHY_NOT_PRESENT) | 947 | ex->ex_phy[i].phy_state == PHY_NOT_PRESENT) |
| 947 | continue; | 948 | continue; |
| 948 | 949 | /* | |
| 950 | * Due to races, the phy might not get added to the | ||
| 951 | * wide port, so we add the phy to the wide port here. | ||
| 952 | */ | ||
| 949 | if (SAS_ADDR(ex->ex_phy[i].attached_sas_addr) == | 953 | if (SAS_ADDR(ex->ex_phy[i].attached_sas_addr) == |
| 950 | SAS_ADDR(child->sas_addr)) | 954 | SAS_ADDR(child->sas_addr)) { |
| 951 | ex->ex_phy[i].phy_state= PHY_DEVICE_DISCOVERED; | 955 | ex->ex_phy[i].phy_state= PHY_DEVICE_DISCOVERED; |
| 956 | res = sas_ex_join_wide_port(dev, i); | ||
| 957 | if (!res) | ||
| 958 | SAS_DPRINTK("Attaching ex phy%d to wide port %016llx\n", | ||
| 959 | i, SAS_ADDR(ex->ex_phy[i].attached_sas_addr)); | ||
| 960 | |||
| 961 | } | ||
| 952 | } | 962 | } |
| 963 | res = 0; | ||
| 953 | } | 964 | } |
| 954 | 965 | ||
| 955 | return res; | 966 | return res; |
| @@ -1598,7 +1609,7 @@ static int sas_get_phy_attached_sas_addr(struct domain_device *dev, | |||
| 1598 | } | 1609 | } |
| 1599 | 1610 | ||
| 1600 | static int sas_find_bcast_phy(struct domain_device *dev, int *phy_id, | 1611 | static int sas_find_bcast_phy(struct domain_device *dev, int *phy_id, |
| 1601 | int from_phy) | 1612 | int from_phy, bool update) |
| 1602 | { | 1613 | { |
| 1603 | struct expander_device *ex = &dev->ex_dev; | 1614 | struct expander_device *ex = &dev->ex_dev; |
| 1604 | int res = 0; | 1615 | int res = 0; |
| @@ -1611,7 +1622,9 @@ static int sas_find_bcast_phy(struct domain_device *dev, int *phy_id, | |||
| 1611 | if (res) | 1622 | if (res) |
| 1612 | goto out; | 1623 | goto out; |
| 1613 | else if (phy_change_count != ex->ex_phy[i].phy_change_count) { | 1624 | else if (phy_change_count != ex->ex_phy[i].phy_change_count) { |
| 1614 | ex->ex_phy[i].phy_change_count = phy_change_count; | 1625 | if (update) |
| 1626 | ex->ex_phy[i].phy_change_count = | ||
| 1627 | phy_change_count; | ||
| 1615 | *phy_id = i; | 1628 | *phy_id = i; |
| 1616 | return 0; | 1629 | return 0; |
| 1617 | } | 1630 | } |
| @@ -1653,31 +1666,52 @@ out: | |||
| 1653 | kfree(rg_req); | 1666 | kfree(rg_req); |
| 1654 | return res; | 1667 | return res; |
| 1655 | } | 1668 | } |
| 1669 | /** | ||
| 1670 | * sas_find_bcast_dev - find the device issue BROADCAST(CHANGE). | ||
| 1671 | * @dev:domain device to be detect. | ||
| 1672 | * @src_dev: the device which originated BROADCAST(CHANGE). | ||
| 1673 | * | ||
| 1674 | * Add self-configuration expander suport. Suppose two expander cascading, | ||
| 1675 | * when the first level expander is self-configuring, hotplug the disks in | ||
| 1676 | * second level expander, BROADCAST(CHANGE) will not only be originated | ||
| 1677 | * in the second level expander, but also be originated in the first level | ||
| 1678 | * expander (see SAS protocol SAS 2r-14, 7.11 for detail), it is to say, | ||
| 1679 | * expander changed count in two level expanders will all increment at least | ||
| 1680 | * once, but the phy which chang count has changed is the source device which | ||
| 1681 | * we concerned. | ||
| 1682 | */ | ||
| 1656 | 1683 | ||
| 1657 | static int sas_find_bcast_dev(struct domain_device *dev, | 1684 | static int sas_find_bcast_dev(struct domain_device *dev, |
| 1658 | struct domain_device **src_dev) | 1685 | struct domain_device **src_dev) |
| 1659 | { | 1686 | { |
| 1660 | struct expander_device *ex = &dev->ex_dev; | 1687 | struct expander_device *ex = &dev->ex_dev; |
| 1661 | int ex_change_count = -1; | 1688 | int ex_change_count = -1; |
| 1689 | int phy_id = -1; | ||
| 1662 | int res; | 1690 | int res; |
| 1691 | struct domain_device *ch; | ||
| 1663 | 1692 | ||
| 1664 | res = sas_get_ex_change_count(dev, &ex_change_count); | 1693 | res = sas_get_ex_change_count(dev, &ex_change_count); |
| 1665 | if (res) | 1694 | if (res) |
| 1666 | goto out; | 1695 | goto out; |
| 1667 | if (ex_change_count != -1 && | 1696 | if (ex_change_count != -1 && ex_change_count != ex->ex_change_count) { |
| 1668 | ex_change_count != ex->ex_change_count) { | 1697 | /* Just detect if this expander phys phy change count changed, |
| 1669 | *src_dev = dev; | 1698 | * in order to determine if this expander originate BROADCAST, |
| 1670 | ex->ex_change_count = ex_change_count; | 1699 | * and do not update phy change count field in our structure. |
| 1671 | } else { | 1700 | */ |
| 1672 | struct domain_device *ch; | 1701 | res = sas_find_bcast_phy(dev, &phy_id, 0, false); |
| 1673 | 1702 | if (phy_id != -1) { | |
| 1674 | list_for_each_entry(ch, &ex->children, siblings) { | 1703 | *src_dev = dev; |
| 1675 | if (ch->dev_type == EDGE_DEV || | 1704 | ex->ex_change_count = ex_change_count; |
| 1676 | ch->dev_type == FANOUT_DEV) { | 1705 | SAS_DPRINTK("Expander phy change count has changed\n"); |
| 1677 | res = sas_find_bcast_dev(ch, src_dev); | 1706 | return res; |
| 1678 | if (src_dev) | 1707 | } else |
| 1679 | return res; | 1708 | SAS_DPRINTK("Expander phys DID NOT change\n"); |
| 1680 | } | 1709 | } |
| 1710 | list_for_each_entry(ch, &ex->children, siblings) { | ||
| 1711 | if (ch->dev_type == EDGE_DEV || ch->dev_type == FANOUT_DEV) { | ||
| 1712 | res = sas_find_bcast_dev(ch, src_dev); | ||
| 1713 | if (src_dev) | ||
| 1714 | return res; | ||
| 1681 | } | 1715 | } |
| 1682 | } | 1716 | } |
| 1683 | out: | 1717 | out: |
| @@ -1700,24 +1734,26 @@ static void sas_unregister_ex_tree(struct domain_device *dev) | |||
| 1700 | } | 1734 | } |
| 1701 | 1735 | ||
| 1702 | static void sas_unregister_devs_sas_addr(struct domain_device *parent, | 1736 | static void sas_unregister_devs_sas_addr(struct domain_device *parent, |
| 1703 | int phy_id) | 1737 | int phy_id, bool last) |
| 1704 | { | 1738 | { |
| 1705 | struct expander_device *ex_dev = &parent->ex_dev; | 1739 | struct expander_device *ex_dev = &parent->ex_dev; |
| 1706 | struct ex_phy *phy = &ex_dev->ex_phy[phy_id]; | 1740 | struct ex_phy *phy = &ex_dev->ex_phy[phy_id]; |
| 1707 | struct domain_device *child, *n; | 1741 | struct domain_device *child, *n; |
| 1708 | 1742 | if (last) { | |
| 1709 | list_for_each_entry_safe(child, n, &ex_dev->children, siblings) { | 1743 | list_for_each_entry_safe(child, n, |
| 1710 | if (SAS_ADDR(child->sas_addr) == | 1744 | &ex_dev->children, siblings) { |
| 1711 | SAS_ADDR(phy->attached_sas_addr)) { | 1745 | if (SAS_ADDR(child->sas_addr) == |
| 1712 | if (child->dev_type == EDGE_DEV || | 1746 | SAS_ADDR(phy->attached_sas_addr)) { |
| 1713 | child->dev_type == FANOUT_DEV) | 1747 | if (child->dev_type == EDGE_DEV || |
| 1714 | sas_unregister_ex_tree(child); | 1748 | child->dev_type == FANOUT_DEV) |
| 1715 | else | 1749 | sas_unregister_ex_tree(child); |
| 1716 | sas_unregister_dev(child); | 1750 | else |
| 1717 | break; | 1751 | sas_unregister_dev(child); |
| 1752 | break; | ||
| 1753 | } | ||
| 1718 | } | 1754 | } |
| 1755 | sas_disable_routing(parent, phy->attached_sas_addr); | ||
| 1719 | } | 1756 | } |
| 1720 | sas_disable_routing(parent, phy->attached_sas_addr); | ||
| 1721 | memset(phy->attached_sas_addr, 0, SAS_ADDR_SIZE); | 1757 | memset(phy->attached_sas_addr, 0, SAS_ADDR_SIZE); |
| 1722 | sas_port_delete_phy(phy->port, phy->phy); | 1758 | sas_port_delete_phy(phy->port, phy->phy); |
| 1723 | if (phy->port->num_phys == 0) | 1759 | if (phy->port->num_phys == 0) |
| @@ -1770,15 +1806,31 @@ static int sas_discover_new(struct domain_device *dev, int phy_id) | |||
| 1770 | { | 1806 | { |
| 1771 | struct ex_phy *ex_phy = &dev->ex_dev.ex_phy[phy_id]; | 1807 | struct ex_phy *ex_phy = &dev->ex_dev.ex_phy[phy_id]; |
| 1772 | struct domain_device *child; | 1808 | struct domain_device *child; |
| 1773 | int res; | 1809 | bool found = false; |
| 1810 | int res, i; | ||
| 1774 | 1811 | ||
| 1775 | SAS_DPRINTK("ex %016llx phy%d new device attached\n", | 1812 | SAS_DPRINTK("ex %016llx phy%d new device attached\n", |
| 1776 | SAS_ADDR(dev->sas_addr), phy_id); | 1813 | SAS_ADDR(dev->sas_addr), phy_id); |
| 1777 | res = sas_ex_phy_discover(dev, phy_id); | 1814 | res = sas_ex_phy_discover(dev, phy_id); |
| 1778 | if (res) | 1815 | if (res) |
| 1779 | goto out; | 1816 | goto out; |
| 1817 | /* to support the wide port inserted */ | ||
| 1818 | for (i = 0; i < dev->ex_dev.num_phys; i++) { | ||
| 1819 | struct ex_phy *ex_phy_temp = &dev->ex_dev.ex_phy[i]; | ||
| 1820 | if (i == phy_id) | ||
| 1821 | continue; | ||
| 1822 | if (SAS_ADDR(ex_phy_temp->attached_sas_addr) == | ||
| 1823 | SAS_ADDR(ex_phy->attached_sas_addr)) { | ||
| 1824 | found = true; | ||
| 1825 | break; | ||
| 1826 | } | ||
| 1827 | } | ||
| 1828 | if (found) { | ||
| 1829 | sas_ex_join_wide_port(dev, phy_id); | ||
| 1830 | return 0; | ||
| 1831 | } | ||
| 1780 | res = sas_ex_discover_devices(dev, phy_id); | 1832 | res = sas_ex_discover_devices(dev, phy_id); |
| 1781 | if (res) | 1833 | if (!res) |
| 1782 | goto out; | 1834 | goto out; |
| 1783 | list_for_each_entry(child, &dev->ex_dev.children, siblings) { | 1835 | list_for_each_entry(child, &dev->ex_dev.children, siblings) { |
| 1784 | if (SAS_ADDR(child->sas_addr) == | 1836 | if (SAS_ADDR(child->sas_addr) == |
| @@ -1793,7 +1845,7 @@ out: | |||
| 1793 | return res; | 1845 | return res; |
| 1794 | } | 1846 | } |
| 1795 | 1847 | ||
| 1796 | static int sas_rediscover_dev(struct domain_device *dev, int phy_id) | 1848 | static int sas_rediscover_dev(struct domain_device *dev, int phy_id, bool last) |
| 1797 | { | 1849 | { |
| 1798 | struct expander_device *ex = &dev->ex_dev; | 1850 | struct expander_device *ex = &dev->ex_dev; |
| 1799 | struct ex_phy *phy = &ex->ex_phy[phy_id]; | 1851 | struct ex_phy *phy = &ex->ex_phy[phy_id]; |
| @@ -1804,11 +1856,11 @@ static int sas_rediscover_dev(struct domain_device *dev, int phy_id) | |||
| 1804 | switch (res) { | 1856 | switch (res) { |
| 1805 | case SMP_RESP_NO_PHY: | 1857 | case SMP_RESP_NO_PHY: |
| 1806 | phy->phy_state = PHY_NOT_PRESENT; | 1858 | phy->phy_state = PHY_NOT_PRESENT; |
| 1807 | sas_unregister_devs_sas_addr(dev, phy_id); | 1859 | sas_unregister_devs_sas_addr(dev, phy_id, last); |
| 1808 | goto out; break; | 1860 | goto out; break; |
| 1809 | case SMP_RESP_PHY_VACANT: | 1861 | case SMP_RESP_PHY_VACANT: |
| 1810 | phy->phy_state = PHY_VACANT; | 1862 | phy->phy_state = PHY_VACANT; |
| 1811 | sas_unregister_devs_sas_addr(dev, phy_id); | 1863 | sas_unregister_devs_sas_addr(dev, phy_id, last); |
| 1812 | goto out; break; | 1864 | goto out; break; |
| 1813 | case SMP_RESP_FUNC_ACC: | 1865 | case SMP_RESP_FUNC_ACC: |
| 1814 | break; | 1866 | break; |
| @@ -1816,7 +1868,7 @@ static int sas_rediscover_dev(struct domain_device *dev, int phy_id) | |||
| 1816 | 1868 | ||
| 1817 | if (SAS_ADDR(attached_sas_addr) == 0) { | 1869 | if (SAS_ADDR(attached_sas_addr) == 0) { |
| 1818 | phy->phy_state = PHY_EMPTY; | 1870 | phy->phy_state = PHY_EMPTY; |
| 1819 | sas_unregister_devs_sas_addr(dev, phy_id); | 1871 | sas_unregister_devs_sas_addr(dev, phy_id, last); |
| 1820 | } else if (SAS_ADDR(attached_sas_addr) == | 1872 | } else if (SAS_ADDR(attached_sas_addr) == |
| 1821 | SAS_ADDR(phy->attached_sas_addr)) { | 1873 | SAS_ADDR(phy->attached_sas_addr)) { |
| 1822 | SAS_DPRINTK("ex %016llx phy 0x%x broadcast flutter\n", | 1874 | SAS_DPRINTK("ex %016llx phy 0x%x broadcast flutter\n", |
| @@ -1828,12 +1880,27 @@ out: | |||
| 1828 | return res; | 1880 | return res; |
| 1829 | } | 1881 | } |
| 1830 | 1882 | ||
| 1883 | /** | ||
| 1884 | * sas_rediscover - revalidate the domain. | ||
| 1885 | * @dev:domain device to be detect. | ||
| 1886 | * @phy_id: the phy id will be detected. | ||
| 1887 | * | ||
| 1888 | * NOTE: this process _must_ quit (return) as soon as any connection | ||
| 1889 | * errors are encountered. Connection recovery is done elsewhere. | ||
| 1890 | * Discover process only interrogates devices in order to discover the | ||
| 1891 | * domain.For plugging out, we un-register the device only when it is | ||
| 1892 | * the last phy in the port, for other phys in this port, we just delete it | ||
| 1893 | * from the port.For inserting, we do discovery when it is the | ||
| 1894 | * first phy,for other phys in this port, we add it to the port to | ||
| 1895 | * forming the wide-port. | ||
| 1896 | */ | ||
| 1831 | static int sas_rediscover(struct domain_device *dev, const int phy_id) | 1897 | static int sas_rediscover(struct domain_device *dev, const int phy_id) |
| 1832 | { | 1898 | { |
| 1833 | struct expander_device *ex = &dev->ex_dev; | 1899 | struct expander_device *ex = &dev->ex_dev; |
| 1834 | struct ex_phy *changed_phy = &ex->ex_phy[phy_id]; | 1900 | struct ex_phy *changed_phy = &ex->ex_phy[phy_id]; |
| 1835 | int res = 0; | 1901 | int res = 0; |
| 1836 | int i; | 1902 | int i; |
| 1903 | bool last = true; /* is this the last phy of the port */ | ||
| 1837 | 1904 | ||
| 1838 | SAS_DPRINTK("ex %016llx phy%d originated BROADCAST(CHANGE)\n", | 1905 | SAS_DPRINTK("ex %016llx phy%d originated BROADCAST(CHANGE)\n", |
| 1839 | SAS_ADDR(dev->sas_addr), phy_id); | 1906 | SAS_ADDR(dev->sas_addr), phy_id); |
| @@ -1848,13 +1915,13 @@ static int sas_rediscover(struct domain_device *dev, const int phy_id) | |||
| 1848 | SAS_ADDR(changed_phy->attached_sas_addr)) { | 1915 | SAS_ADDR(changed_phy->attached_sas_addr)) { |
| 1849 | SAS_DPRINTK("phy%d part of wide port with " | 1916 | SAS_DPRINTK("phy%d part of wide port with " |
| 1850 | "phy%d\n", phy_id, i); | 1917 | "phy%d\n", phy_id, i); |
| 1851 | goto out; | 1918 | last = false; |
| 1919 | break; | ||
| 1852 | } | 1920 | } |
| 1853 | } | 1921 | } |
| 1854 | res = sas_rediscover_dev(dev, phy_id); | 1922 | res = sas_rediscover_dev(dev, phy_id, last); |
| 1855 | } else | 1923 | } else |
| 1856 | res = sas_discover_new(dev, phy_id); | 1924 | res = sas_discover_new(dev, phy_id); |
| 1857 | out: | ||
| 1858 | return res; | 1925 | return res; |
| 1859 | } | 1926 | } |
| 1860 | 1927 | ||
| @@ -1881,7 +1948,7 @@ int sas_ex_revalidate_domain(struct domain_device *port_dev) | |||
| 1881 | 1948 | ||
| 1882 | do { | 1949 | do { |
| 1883 | phy_id = -1; | 1950 | phy_id = -1; |
| 1884 | res = sas_find_bcast_phy(dev, &phy_id, i); | 1951 | res = sas_find_bcast_phy(dev, &phy_id, i, true); |
| 1885 | if (phy_id == -1) | 1952 | if (phy_id == -1) |
| 1886 | break; | 1953 | break; |
| 1887 | res = sas_rediscover(dev, phy_id); | 1954 | res = sas_rediscover(dev, phy_id); |
diff --git a/drivers/scsi/libsas/sas_port.c b/drivers/scsi/libsas/sas_port.c index e6ac59c023f1..fe8b74c706d2 100644 --- a/drivers/scsi/libsas/sas_port.c +++ b/drivers/scsi/libsas/sas_port.c | |||
| @@ -56,7 +56,7 @@ static void sas_form_port(struct asd_sas_phy *phy) | |||
| 56 | } | 56 | } |
| 57 | } | 57 | } |
| 58 | 58 | ||
| 59 | /* find a port */ | 59 | /* see if the phy should be part of a wide port */ |
| 60 | spin_lock_irqsave(&sas_ha->phy_port_lock, flags); | 60 | spin_lock_irqsave(&sas_ha->phy_port_lock, flags); |
| 61 | for (i = 0; i < sas_ha->num_phys; i++) { | 61 | for (i = 0; i < sas_ha->num_phys; i++) { |
| 62 | port = sas_ha->sas_port[i]; | 62 | port = sas_ha->sas_port[i]; |
| @@ -69,12 +69,23 @@ static void sas_form_port(struct asd_sas_phy *phy) | |||
| 69 | SAS_DPRINTK("phy%d matched wide port%d\n", phy->id, | 69 | SAS_DPRINTK("phy%d matched wide port%d\n", phy->id, |
| 70 | port->id); | 70 | port->id); |
| 71 | break; | 71 | break; |
| 72 | } else if (*(u64 *) port->sas_addr == 0 && port->num_phys==0) { | ||
| 73 | memcpy(port->sas_addr, phy->sas_addr, SAS_ADDR_SIZE); | ||
| 74 | break; | ||
| 75 | } | 72 | } |
| 76 | spin_unlock(&port->phy_list_lock); | 73 | spin_unlock(&port->phy_list_lock); |
| 77 | } | 74 | } |
| 75 | /* The phy does not match any existing port, create a new one */ | ||
| 76 | if (i == sas_ha->num_phys) { | ||
| 77 | for (i = 0; i < sas_ha->num_phys; i++) { | ||
| 78 | port = sas_ha->sas_port[i]; | ||
| 79 | spin_lock(&port->phy_list_lock); | ||
| 80 | if (*(u64 *)port->sas_addr == 0 | ||
| 81 | && port->num_phys == 0) { | ||
| 82 | memcpy(port->sas_addr, phy->sas_addr, | ||
| 83 | SAS_ADDR_SIZE); | ||
| 84 | break; | ||
| 85 | } | ||
| 86 | spin_unlock(&port->phy_list_lock); | ||
| 87 | } | ||
| 88 | } | ||
| 78 | 89 | ||
| 79 | if (i >= sas_ha->num_phys) { | 90 | if (i >= sas_ha->num_phys) { |
| 80 | printk(KERN_NOTICE "%s: couldn't find a free port, bug?\n", | 91 | printk(KERN_NOTICE "%s: couldn't find a free port, bug?\n", |
diff --git a/drivers/scsi/mpt2sas/mpt2sas_base.c b/drivers/scsi/mpt2sas/mpt2sas_base.c index f3da592f7bcc..35a13867495e 100644 --- a/drivers/scsi/mpt2sas/mpt2sas_base.c +++ b/drivers/scsi/mpt2sas/mpt2sas_base.c | |||
| @@ -119,6 +119,64 @@ _base_fault_reset_work(struct work_struct *work) | |||
| 119 | spin_unlock_irqrestore(&ioc->ioc_reset_in_progress_lock, flags); | 119 | spin_unlock_irqrestore(&ioc->ioc_reset_in_progress_lock, flags); |
| 120 | } | 120 | } |
| 121 | 121 | ||
| 122 | /** | ||
| 123 | * mpt2sas_base_start_watchdog - start the fault_reset_work_q | ||
| 124 | * @ioc: pointer to scsi command object | ||
| 125 | * Context: sleep. | ||
| 126 | * | ||
| 127 | * Return nothing. | ||
| 128 | */ | ||
| 129 | void | ||
| 130 | mpt2sas_base_start_watchdog(struct MPT2SAS_ADAPTER *ioc) | ||
| 131 | { | ||
| 132 | unsigned long flags; | ||
| 133 | |||
| 134 | if (ioc->fault_reset_work_q) | ||
| 135 | return; | ||
| 136 | |||
| 137 | /* initialize fault polling */ | ||
| 138 | INIT_DELAYED_WORK(&ioc->fault_reset_work, _base_fault_reset_work); | ||
| 139 | snprintf(ioc->fault_reset_work_q_name, | ||
| 140 | sizeof(ioc->fault_reset_work_q_name), "poll_%d_status", ioc->id); | ||
| 141 | ioc->fault_reset_work_q = | ||
| 142 | create_singlethread_workqueue(ioc->fault_reset_work_q_name); | ||
| 143 | if (!ioc->fault_reset_work_q) { | ||
| 144 | printk(MPT2SAS_ERR_FMT "%s: failed (line=%d)\n", | ||
| 145 | ioc->name, __func__, __LINE__); | ||
| 146 | return; | ||
| 147 | } | ||
| 148 | spin_lock_irqsave(&ioc->ioc_reset_in_progress_lock, flags); | ||
| 149 | if (ioc->fault_reset_work_q) | ||
| 150 | queue_delayed_work(ioc->fault_reset_work_q, | ||
| 151 | &ioc->fault_reset_work, | ||
| 152 | msecs_to_jiffies(FAULT_POLLING_INTERVAL)); | ||
| 153 | spin_unlock_irqrestore(&ioc->ioc_reset_in_progress_lock, flags); | ||
| 154 | } | ||
| 155 | |||
| 156 | /** | ||
| 157 | * mpt2sas_base_stop_watchdog - stop the fault_reset_work_q | ||
| 158 | * @ioc: pointer to scsi command object | ||
| 159 | * Context: sleep. | ||
| 160 | * | ||
| 161 | * Return nothing. | ||
| 162 | */ | ||
| 163 | void | ||
| 164 | mpt2sas_base_stop_watchdog(struct MPT2SAS_ADAPTER *ioc) | ||
| 165 | { | ||
| 166 | unsigned long flags; | ||
| 167 | struct workqueue_struct *wq; | ||
| 168 | |||
| 169 | spin_lock_irqsave(&ioc->ioc_reset_in_progress_lock, flags); | ||
| 170 | wq = ioc->fault_reset_work_q; | ||
| 171 | ioc->fault_reset_work_q = NULL; | ||
| 172 | spin_unlock_irqrestore(&ioc->ioc_reset_in_progress_lock, flags); | ||
| 173 | if (wq) { | ||
| 174 | if (!cancel_delayed_work(&ioc->fault_reset_work)) | ||
| 175 | flush_workqueue(wq); | ||
| 176 | destroy_workqueue(wq); | ||
| 177 | } | ||
| 178 | } | ||
| 179 | |||
| 122 | #ifdef CONFIG_SCSI_MPT2SAS_LOGGING | 180 | #ifdef CONFIG_SCSI_MPT2SAS_LOGGING |
| 123 | /** | 181 | /** |
| 124 | * _base_sas_ioc_info - verbose translation of the ioc status | 182 | * _base_sas_ioc_info - verbose translation of the ioc status |
| @@ -440,6 +498,10 @@ _base_sas_log_info(struct MPT2SAS_ADAPTER *ioc , u32 log_info) | |||
| 440 | if (sas_loginfo.dw.bus_type != 3 /*SAS*/) | 498 | if (sas_loginfo.dw.bus_type != 3 /*SAS*/) |
| 441 | return; | 499 | return; |
| 442 | 500 | ||
| 501 | /* each nexus loss loginfo */ | ||
| 502 | if (log_info == 0x31170000) | ||
| 503 | return; | ||
| 504 | |||
| 443 | /* eat the loginfos associated with task aborts */ | 505 | /* eat the loginfos associated with task aborts */ |
| 444 | if (ioc->ignore_loginfos && (log_info == 30050000 || log_info == | 506 | if (ioc->ignore_loginfos && (log_info == 30050000 || log_info == |
| 445 | 0x31140000 || log_info == 0x31130000)) | 507 | 0x31140000 || log_info == 0x31130000)) |
| @@ -1109,7 +1171,6 @@ mpt2sas_base_map_resources(struct MPT2SAS_ADAPTER *ioc) | |||
| 1109 | } | 1171 | } |
| 1110 | } | 1172 | } |
| 1111 | 1173 | ||
| 1112 | pci_set_drvdata(pdev, ioc->shost); | ||
| 1113 | _base_mask_interrupts(ioc); | 1174 | _base_mask_interrupts(ioc); |
| 1114 | r = _base_enable_msix(ioc); | 1175 | r = _base_enable_msix(ioc); |
| 1115 | if (r) | 1176 | if (r) |
| @@ -1132,7 +1193,6 @@ mpt2sas_base_map_resources(struct MPT2SAS_ADAPTER *ioc) | |||
| 1132 | ioc->pci_irq = -1; | 1193 | ioc->pci_irq = -1; |
| 1133 | pci_release_selected_regions(ioc->pdev, ioc->bars); | 1194 | pci_release_selected_regions(ioc->pdev, ioc->bars); |
| 1134 | pci_disable_device(pdev); | 1195 | pci_disable_device(pdev); |
| 1135 | pci_set_drvdata(pdev, NULL); | ||
| 1136 | return r; | 1196 | return r; |
| 1137 | } | 1197 | } |
| 1138 | 1198 | ||
| @@ -3191,7 +3251,6 @@ mpt2sas_base_free_resources(struct MPT2SAS_ADAPTER *ioc) | |||
| 3191 | ioc->chip_phys = 0; | 3251 | ioc->chip_phys = 0; |
| 3192 | pci_release_selected_regions(ioc->pdev, ioc->bars); | 3252 | pci_release_selected_regions(ioc->pdev, ioc->bars); |
| 3193 | pci_disable_device(pdev); | 3253 | pci_disable_device(pdev); |
| 3194 | pci_set_drvdata(pdev, NULL); | ||
| 3195 | return; | 3254 | return; |
| 3196 | } | 3255 | } |
| 3197 | 3256 | ||
| @@ -3205,7 +3264,6 @@ int | |||
| 3205 | mpt2sas_base_attach(struct MPT2SAS_ADAPTER *ioc) | 3264 | mpt2sas_base_attach(struct MPT2SAS_ADAPTER *ioc) |
| 3206 | { | 3265 | { |
| 3207 | int r, i; | 3266 | int r, i; |
| 3208 | unsigned long flags; | ||
| 3209 | 3267 | ||
| 3210 | dinitprintk(ioc, printk(MPT2SAS_DEBUG_FMT "%s\n", ioc->name, | 3268 | dinitprintk(ioc, printk(MPT2SAS_DEBUG_FMT "%s\n", ioc->name, |
| 3211 | __func__)); | 3269 | __func__)); |
| @@ -3214,6 +3272,7 @@ mpt2sas_base_attach(struct MPT2SAS_ADAPTER *ioc) | |||
| 3214 | if (r) | 3272 | if (r) |
| 3215 | return r; | 3273 | return r; |
| 3216 | 3274 | ||
| 3275 | pci_set_drvdata(ioc->pdev, ioc->shost); | ||
| 3217 | r = _base_make_ioc_ready(ioc, CAN_SLEEP, SOFT_RESET); | 3276 | r = _base_make_ioc_ready(ioc, CAN_SLEEP, SOFT_RESET); |
| 3218 | if (r) | 3277 | if (r) |
| 3219 | goto out_free_resources; | 3278 | goto out_free_resources; |
| @@ -3288,23 +3347,7 @@ mpt2sas_base_attach(struct MPT2SAS_ADAPTER *ioc) | |||
| 3288 | if (r) | 3347 | if (r) |
| 3289 | goto out_free_resources; | 3348 | goto out_free_resources; |
| 3290 | 3349 | ||
| 3291 | /* initialize fault polling */ | 3350 | mpt2sas_base_start_watchdog(ioc); |
| 3292 | INIT_DELAYED_WORK(&ioc->fault_reset_work, _base_fault_reset_work); | ||
| 3293 | snprintf(ioc->fault_reset_work_q_name, | ||
| 3294 | sizeof(ioc->fault_reset_work_q_name), "poll_%d_status", ioc->id); | ||
| 3295 | ioc->fault_reset_work_q = | ||
| 3296 | create_singlethread_workqueue(ioc->fault_reset_work_q_name); | ||
| 3297 | if (!ioc->fault_reset_work_q) { | ||
| 3298 | printk(MPT2SAS_ERR_FMT "%s: failed (line=%d)\n", | ||
| 3299 | ioc->name, __func__, __LINE__); | ||
| 3300 | goto out_free_resources; | ||
| 3301 | } | ||
| 3302 | spin_lock_irqsave(&ioc->ioc_reset_in_progress_lock, flags); | ||
| 3303 | if (ioc->fault_reset_work_q) | ||
| 3304 | queue_delayed_work(ioc->fault_reset_work_q, | ||
| 3305 | &ioc->fault_reset_work, | ||
| 3306 | msecs_to_jiffies(FAULT_POLLING_INTERVAL)); | ||
| 3307 | spin_unlock_irqrestore(&ioc->ioc_reset_in_progress_lock, flags); | ||
| 3308 | return 0; | 3351 | return 0; |
| 3309 | 3352 | ||
| 3310 | out_free_resources: | 3353 | out_free_resources: |
| @@ -3312,6 +3355,7 @@ mpt2sas_base_attach(struct MPT2SAS_ADAPTER *ioc) | |||
| 3312 | ioc->remove_host = 1; | 3355 | ioc->remove_host = 1; |
| 3313 | mpt2sas_base_free_resources(ioc); | 3356 | mpt2sas_base_free_resources(ioc); |
| 3314 | _base_release_memory_pools(ioc); | 3357 | _base_release_memory_pools(ioc); |
| 3358 | pci_set_drvdata(ioc->pdev, NULL); | ||
| 3315 | kfree(ioc->tm_cmds.reply); | 3359 | kfree(ioc->tm_cmds.reply); |
| 3316 | kfree(ioc->transport_cmds.reply); | 3360 | kfree(ioc->transport_cmds.reply); |
| 3317 | kfree(ioc->config_cmds.reply); | 3361 | kfree(ioc->config_cmds.reply); |
| @@ -3337,22 +3381,14 @@ mpt2sas_base_attach(struct MPT2SAS_ADAPTER *ioc) | |||
| 3337 | void | 3381 | void |
| 3338 | mpt2sas_base_detach(struct MPT2SAS_ADAPTER *ioc) | 3382 | mpt2sas_base_detach(struct MPT2SAS_ADAPTER *ioc) |
| 3339 | { | 3383 | { |
| 3340 | unsigned long flags; | ||
| 3341 | struct workqueue_struct *wq; | ||
| 3342 | 3384 | ||
| 3343 | dexitprintk(ioc, printk(MPT2SAS_DEBUG_FMT "%s\n", ioc->name, | 3385 | dexitprintk(ioc, printk(MPT2SAS_DEBUG_FMT "%s\n", ioc->name, |
| 3344 | __func__)); | 3386 | __func__)); |
| 3345 | 3387 | ||
| 3346 | spin_lock_irqsave(&ioc->ioc_reset_in_progress_lock, flags); | 3388 | mpt2sas_base_stop_watchdog(ioc); |
| 3347 | wq = ioc->fault_reset_work_q; | ||
| 3348 | ioc->fault_reset_work_q = NULL; | ||
| 3349 | spin_unlock_irqrestore(&ioc->ioc_reset_in_progress_lock, flags); | ||
| 3350 | if (!cancel_delayed_work(&ioc->fault_reset_work)) | ||
| 3351 | flush_workqueue(wq); | ||
| 3352 | destroy_workqueue(wq); | ||
| 3353 | |||
| 3354 | mpt2sas_base_free_resources(ioc); | 3389 | mpt2sas_base_free_resources(ioc); |
| 3355 | _base_release_memory_pools(ioc); | 3390 | _base_release_memory_pools(ioc); |
| 3391 | pci_set_drvdata(ioc->pdev, NULL); | ||
| 3356 | kfree(ioc->pfacts); | 3392 | kfree(ioc->pfacts); |
| 3357 | kfree(ioc->ctl_cmds.reply); | 3393 | kfree(ioc->ctl_cmds.reply); |
| 3358 | kfree(ioc->base_cmds.reply); | 3394 | kfree(ioc->base_cmds.reply); |
diff --git a/drivers/scsi/mpt2sas/mpt2sas_base.h b/drivers/scsi/mpt2sas/mpt2sas_base.h index 286c185fa9e4..acdcff150a35 100644 --- a/drivers/scsi/mpt2sas/mpt2sas_base.h +++ b/drivers/scsi/mpt2sas/mpt2sas_base.h | |||
| @@ -69,10 +69,10 @@ | |||
| 69 | #define MPT2SAS_DRIVER_NAME "mpt2sas" | 69 | #define MPT2SAS_DRIVER_NAME "mpt2sas" |
| 70 | #define MPT2SAS_AUTHOR "LSI Corporation <DL-MPTFusionLinux@lsi.com>" | 70 | #define MPT2SAS_AUTHOR "LSI Corporation <DL-MPTFusionLinux@lsi.com>" |
| 71 | #define MPT2SAS_DESCRIPTION "LSI MPT Fusion SAS 2.0 Device Driver" | 71 | #define MPT2SAS_DESCRIPTION "LSI MPT Fusion SAS 2.0 Device Driver" |
| 72 | #define MPT2SAS_DRIVER_VERSION "01.100.03.00" | 72 | #define MPT2SAS_DRIVER_VERSION "01.100.04.00" |
| 73 | #define MPT2SAS_MAJOR_VERSION 01 | 73 | #define MPT2SAS_MAJOR_VERSION 01 |
| 74 | #define MPT2SAS_MINOR_VERSION 100 | 74 | #define MPT2SAS_MINOR_VERSION 100 |
| 75 | #define MPT2SAS_BUILD_VERSION 03 | 75 | #define MPT2SAS_BUILD_VERSION 04 |
| 76 | #define MPT2SAS_RELEASE_VERSION 00 | 76 | #define MPT2SAS_RELEASE_VERSION 00 |
| 77 | 77 | ||
| 78 | /* | 78 | /* |
| @@ -673,6 +673,8 @@ typedef void (*MPT_CALLBACK)(struct MPT2SAS_ADAPTER *ioc, u16 smid, u8 VF_ID, | |||
| 673 | 673 | ||
| 674 | /* base shared API */ | 674 | /* base shared API */ |
| 675 | extern struct list_head mpt2sas_ioc_list; | 675 | extern struct list_head mpt2sas_ioc_list; |
| 676 | void mpt2sas_base_start_watchdog(struct MPT2SAS_ADAPTER *ioc); | ||
| 677 | void mpt2sas_base_stop_watchdog(struct MPT2SAS_ADAPTER *ioc); | ||
| 676 | 678 | ||
| 677 | int mpt2sas_base_attach(struct MPT2SAS_ADAPTER *ioc); | 679 | int mpt2sas_base_attach(struct MPT2SAS_ADAPTER *ioc); |
| 678 | void mpt2sas_base_detach(struct MPT2SAS_ADAPTER *ioc); | 680 | void mpt2sas_base_detach(struct MPT2SAS_ADAPTER *ioc); |
diff --git a/drivers/scsi/mpt2sas/mpt2sas_config.c b/drivers/scsi/mpt2sas/mpt2sas_config.c index 58cfb97846f7..6ddee161beb3 100644 --- a/drivers/scsi/mpt2sas/mpt2sas_config.c +++ b/drivers/scsi/mpt2sas/mpt2sas_config.c | |||
| @@ -236,17 +236,25 @@ _config_request(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigRequest_t | |||
| 236 | Mpi2ConfigRequest_t *config_request; | 236 | Mpi2ConfigRequest_t *config_request; |
| 237 | int r; | 237 | int r; |
| 238 | u8 retry_count; | 238 | u8 retry_count; |
| 239 | u8 issue_reset; | 239 | u8 issue_host_reset = 0; |
| 240 | u16 wait_state_count; | 240 | u16 wait_state_count; |
| 241 | 241 | ||
| 242 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 242 | if (ioc->config_cmds.status != MPT2_CMD_NOT_USED) { | 243 | if (ioc->config_cmds.status != MPT2_CMD_NOT_USED) { |
| 243 | printk(MPT2SAS_ERR_FMT "%s: config_cmd in use\n", | 244 | printk(MPT2SAS_ERR_FMT "%s: config_cmd in use\n", |
| 244 | ioc->name, __func__); | 245 | ioc->name, __func__); |
| 246 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 245 | return -EAGAIN; | 247 | return -EAGAIN; |
| 246 | } | 248 | } |
| 247 | retry_count = 0; | 249 | retry_count = 0; |
| 248 | 250 | ||
| 249 | retry_config: | 251 | retry_config: |
| 252 | if (retry_count) { | ||
| 253 | if (retry_count > 2) /* attempt only 2 retries */ | ||
| 254 | return -EFAULT; | ||
| 255 | printk(MPT2SAS_INFO_FMT "%s: attempting retry (%d)\n", | ||
| 256 | ioc->name, __func__, retry_count); | ||
| 257 | } | ||
| 250 | wait_state_count = 0; | 258 | wait_state_count = 0; |
| 251 | ioc_state = mpt2sas_base_get_iocstate(ioc, 1); | 259 | ioc_state = mpt2sas_base_get_iocstate(ioc, 1); |
| 252 | while (ioc_state != MPI2_IOC_STATE_OPERATIONAL) { | 260 | while (ioc_state != MPI2_IOC_STATE_OPERATIONAL) { |
| @@ -254,8 +262,8 @@ _config_request(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigRequest_t | |||
| 254 | printk(MPT2SAS_ERR_FMT | 262 | printk(MPT2SAS_ERR_FMT |
| 255 | "%s: failed due to ioc not operational\n", | 263 | "%s: failed due to ioc not operational\n", |
| 256 | ioc->name, __func__); | 264 | ioc->name, __func__); |
| 257 | ioc->config_cmds.status = MPT2_CMD_NOT_USED; | 265 | r = -EFAULT; |
| 258 | return -EFAULT; | 266 | goto out; |
| 259 | } | 267 | } |
| 260 | ssleep(1); | 268 | ssleep(1); |
| 261 | ioc_state = mpt2sas_base_get_iocstate(ioc, 1); | 269 | ioc_state = mpt2sas_base_get_iocstate(ioc, 1); |
| @@ -271,8 +279,8 @@ _config_request(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigRequest_t | |||
| 271 | if (!smid) { | 279 | if (!smid) { |
| 272 | printk(MPT2SAS_ERR_FMT "%s: failed obtaining a smid\n", | 280 | printk(MPT2SAS_ERR_FMT "%s: failed obtaining a smid\n", |
| 273 | ioc->name, __func__); | 281 | ioc->name, __func__); |
| 274 | ioc->config_cmds.status = MPT2_CMD_NOT_USED; | 282 | r = -EAGAIN; |
| 275 | return -EAGAIN; | 283 | goto out; |
| 276 | } | 284 | } |
| 277 | 285 | ||
| 278 | r = 0; | 286 | r = 0; |
| @@ -292,9 +300,15 @@ _config_request(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigRequest_t | |||
| 292 | ioc->name, __func__); | 300 | ioc->name, __func__); |
| 293 | _debug_dump_mf(mpi_request, | 301 | _debug_dump_mf(mpi_request, |
| 294 | sizeof(Mpi2ConfigRequest_t)/4); | 302 | sizeof(Mpi2ConfigRequest_t)/4); |
| 295 | if (!(ioc->config_cmds.status & MPT2_CMD_RESET)) | 303 | retry_count++; |
| 296 | issue_reset = 1; | 304 | if (ioc->config_cmds.smid == smid) |
| 297 | goto issue_host_reset; | 305 | mpt2sas_base_free_smid(ioc, smid); |
| 306 | if ((ioc->shost_recovery) || | ||
| 307 | (ioc->config_cmds.status & MPT2_CMD_RESET)) | ||
| 308 | goto retry_config; | ||
| 309 | issue_host_reset = 1; | ||
| 310 | r = -EFAULT; | ||
| 311 | goto out; | ||
| 298 | } | 312 | } |
| 299 | if (ioc->config_cmds.status & MPT2_CMD_REPLY_VALID) | 313 | if (ioc->config_cmds.status & MPT2_CMD_REPLY_VALID) |
| 300 | memcpy(mpi_reply, ioc->config_cmds.reply, | 314 | memcpy(mpi_reply, ioc->config_cmds.reply, |
| @@ -302,21 +316,13 @@ _config_request(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigRequest_t | |||
| 302 | if (retry_count) | 316 | if (retry_count) |
| 303 | printk(MPT2SAS_INFO_FMT "%s: retry completed!!\n", | 317 | printk(MPT2SAS_INFO_FMT "%s: retry completed!!\n", |
| 304 | ioc->name, __func__); | 318 | ioc->name, __func__); |
| 319 | out: | ||
| 305 | ioc->config_cmds.status = MPT2_CMD_NOT_USED; | 320 | ioc->config_cmds.status = MPT2_CMD_NOT_USED; |
| 306 | return r; | 321 | mutex_unlock(&ioc->config_cmds.mutex); |
| 307 | 322 | if (issue_host_reset) | |
| 308 | issue_host_reset: | ||
| 309 | if (issue_reset) | ||
| 310 | mpt2sas_base_hard_reset_handler(ioc, CAN_SLEEP, | 323 | mpt2sas_base_hard_reset_handler(ioc, CAN_SLEEP, |
| 311 | FORCE_BIG_HAMMER); | 324 | FORCE_BIG_HAMMER); |
| 312 | ioc->config_cmds.status = MPT2_CMD_NOT_USED; | 325 | return r; |
| 313 | if (!retry_count) { | ||
| 314 | printk(MPT2SAS_INFO_FMT "%s: attempting retry\n", | ||
| 315 | ioc->name, __func__); | ||
| 316 | retry_count++; | ||
| 317 | goto retry_config; | ||
| 318 | } | ||
| 319 | return -EFAULT; | ||
| 320 | } | 326 | } |
| 321 | 327 | ||
| 322 | /** | 328 | /** |
| @@ -375,7 +381,6 @@ mpt2sas_config_get_manufacturing_pg0(struct MPT2SAS_ADAPTER *ioc, | |||
| 375 | int r; | 381 | int r; |
| 376 | struct config_request mem; | 382 | struct config_request mem; |
| 377 | 383 | ||
| 378 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 379 | memset(config_page, 0, sizeof(Mpi2ManufacturingPage0_t)); | 384 | memset(config_page, 0, sizeof(Mpi2ManufacturingPage0_t)); |
| 380 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 385 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 381 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 386 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -417,7 +422,6 @@ mpt2sas_config_get_manufacturing_pg0(struct MPT2SAS_ADAPTER *ioc, | |||
| 417 | _config_free_config_dma_memory(ioc, &mem); | 422 | _config_free_config_dma_memory(ioc, &mem); |
| 418 | 423 | ||
| 419 | out: | 424 | out: |
| 420 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 421 | return r; | 425 | return r; |
| 422 | } | 426 | } |
| 423 | 427 | ||
| @@ -438,7 +442,6 @@ mpt2sas_config_get_bios_pg2(struct MPT2SAS_ADAPTER *ioc, | |||
| 438 | int r; | 442 | int r; |
| 439 | struct config_request mem; | 443 | struct config_request mem; |
| 440 | 444 | ||
| 441 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 442 | memset(config_page, 0, sizeof(Mpi2BiosPage2_t)); | 445 | memset(config_page, 0, sizeof(Mpi2BiosPage2_t)); |
| 443 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 446 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 444 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 447 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -480,7 +483,6 @@ mpt2sas_config_get_bios_pg2(struct MPT2SAS_ADAPTER *ioc, | |||
| 480 | _config_free_config_dma_memory(ioc, &mem); | 483 | _config_free_config_dma_memory(ioc, &mem); |
| 481 | 484 | ||
| 482 | out: | 485 | out: |
| 483 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 484 | return r; | 486 | return r; |
| 485 | } | 487 | } |
| 486 | 488 | ||
| @@ -501,7 +503,6 @@ mpt2sas_config_get_bios_pg3(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 501 | int r; | 503 | int r; |
| 502 | struct config_request mem; | 504 | struct config_request mem; |
| 503 | 505 | ||
| 504 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 505 | memset(config_page, 0, sizeof(Mpi2BiosPage3_t)); | 506 | memset(config_page, 0, sizeof(Mpi2BiosPage3_t)); |
| 506 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 507 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 507 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 508 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -543,7 +544,6 @@ mpt2sas_config_get_bios_pg3(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 543 | _config_free_config_dma_memory(ioc, &mem); | 544 | _config_free_config_dma_memory(ioc, &mem); |
| 544 | 545 | ||
| 545 | out: | 546 | out: |
| 546 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 547 | return r; | 547 | return r; |
| 548 | } | 548 | } |
| 549 | 549 | ||
| @@ -564,7 +564,6 @@ mpt2sas_config_get_iounit_pg0(struct MPT2SAS_ADAPTER *ioc, | |||
| 564 | int r; | 564 | int r; |
| 565 | struct config_request mem; | 565 | struct config_request mem; |
| 566 | 566 | ||
| 567 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 568 | memset(config_page, 0, sizeof(Mpi2IOUnitPage0_t)); | 567 | memset(config_page, 0, sizeof(Mpi2IOUnitPage0_t)); |
| 569 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 568 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 570 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 569 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -606,7 +605,6 @@ mpt2sas_config_get_iounit_pg0(struct MPT2SAS_ADAPTER *ioc, | |||
| 606 | _config_free_config_dma_memory(ioc, &mem); | 605 | _config_free_config_dma_memory(ioc, &mem); |
| 607 | 606 | ||
| 608 | out: | 607 | out: |
| 609 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 610 | return r; | 608 | return r; |
| 611 | } | 609 | } |
| 612 | 610 | ||
| @@ -627,7 +625,6 @@ mpt2sas_config_get_iounit_pg1(struct MPT2SAS_ADAPTER *ioc, | |||
| 627 | int r; | 625 | int r; |
| 628 | struct config_request mem; | 626 | struct config_request mem; |
| 629 | 627 | ||
| 630 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 631 | memset(config_page, 0, sizeof(Mpi2IOUnitPage1_t)); | 628 | memset(config_page, 0, sizeof(Mpi2IOUnitPage1_t)); |
| 632 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 629 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 633 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 630 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -669,7 +666,6 @@ mpt2sas_config_get_iounit_pg1(struct MPT2SAS_ADAPTER *ioc, | |||
| 669 | _config_free_config_dma_memory(ioc, &mem); | 666 | _config_free_config_dma_memory(ioc, &mem); |
| 670 | 667 | ||
| 671 | out: | 668 | out: |
| 672 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 673 | return r; | 669 | return r; |
| 674 | } | 670 | } |
| 675 | 671 | ||
| @@ -690,7 +686,6 @@ mpt2sas_config_set_iounit_pg1(struct MPT2SAS_ADAPTER *ioc, | |||
| 690 | int r; | 686 | int r; |
| 691 | struct config_request mem; | 687 | struct config_request mem; |
| 692 | 688 | ||
| 693 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 694 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 689 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 695 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 690 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| 696 | mpi_request.Action = MPI2_CONFIG_ACTION_PAGE_HEADER; | 691 | mpi_request.Action = MPI2_CONFIG_ACTION_PAGE_HEADER; |
| @@ -732,7 +727,6 @@ mpt2sas_config_set_iounit_pg1(struct MPT2SAS_ADAPTER *ioc, | |||
| 732 | _config_free_config_dma_memory(ioc, &mem); | 727 | _config_free_config_dma_memory(ioc, &mem); |
| 733 | 728 | ||
| 734 | out: | 729 | out: |
| 735 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 736 | return r; | 730 | return r; |
| 737 | } | 731 | } |
| 738 | 732 | ||
| @@ -753,7 +747,6 @@ mpt2sas_config_get_ioc_pg8(struct MPT2SAS_ADAPTER *ioc, | |||
| 753 | int r; | 747 | int r; |
| 754 | struct config_request mem; | 748 | struct config_request mem; |
| 755 | 749 | ||
| 756 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 757 | memset(config_page, 0, sizeof(Mpi2IOCPage8_t)); | 750 | memset(config_page, 0, sizeof(Mpi2IOCPage8_t)); |
| 758 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 751 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 759 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 752 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -795,7 +788,6 @@ mpt2sas_config_get_ioc_pg8(struct MPT2SAS_ADAPTER *ioc, | |||
| 795 | _config_free_config_dma_memory(ioc, &mem); | 788 | _config_free_config_dma_memory(ioc, &mem); |
| 796 | 789 | ||
| 797 | out: | 790 | out: |
| 798 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 799 | return r; | 791 | return r; |
| 800 | } | 792 | } |
| 801 | 793 | ||
| @@ -818,7 +810,6 @@ mpt2sas_config_get_sas_device_pg0(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 818 | int r; | 810 | int r; |
| 819 | struct config_request mem; | 811 | struct config_request mem; |
| 820 | 812 | ||
| 821 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 822 | memset(config_page, 0, sizeof(Mpi2SasDevicePage0_t)); | 813 | memset(config_page, 0, sizeof(Mpi2SasDevicePage0_t)); |
| 823 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 814 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 824 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 815 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -863,7 +854,6 @@ mpt2sas_config_get_sas_device_pg0(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 863 | _config_free_config_dma_memory(ioc, &mem); | 854 | _config_free_config_dma_memory(ioc, &mem); |
| 864 | 855 | ||
| 865 | out: | 856 | out: |
| 866 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 867 | return r; | 857 | return r; |
| 868 | } | 858 | } |
| 869 | 859 | ||
| @@ -886,7 +876,6 @@ mpt2sas_config_get_sas_device_pg1(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 886 | int r; | 876 | int r; |
| 887 | struct config_request mem; | 877 | struct config_request mem; |
| 888 | 878 | ||
| 889 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 890 | memset(config_page, 0, sizeof(Mpi2SasDevicePage1_t)); | 879 | memset(config_page, 0, sizeof(Mpi2SasDevicePage1_t)); |
| 891 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 880 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 892 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 881 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -931,7 +920,6 @@ mpt2sas_config_get_sas_device_pg1(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 931 | _config_free_config_dma_memory(ioc, &mem); | 920 | _config_free_config_dma_memory(ioc, &mem); |
| 932 | 921 | ||
| 933 | out: | 922 | out: |
| 934 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 935 | return r; | 923 | return r; |
| 936 | } | 924 | } |
| 937 | 925 | ||
| @@ -953,7 +941,6 @@ mpt2sas_config_get_number_hba_phys(struct MPT2SAS_ADAPTER *ioc, u8 *num_phys) | |||
| 953 | Mpi2ConfigReply_t mpi_reply; | 941 | Mpi2ConfigReply_t mpi_reply; |
| 954 | Mpi2SasIOUnitPage0_t config_page; | 942 | Mpi2SasIOUnitPage0_t config_page; |
| 955 | 943 | ||
| 956 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 957 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 944 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 958 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 945 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| 959 | mpi_request.Action = MPI2_CONFIG_ACTION_PAGE_HEADER; | 946 | mpi_request.Action = MPI2_CONFIG_ACTION_PAGE_HEADER; |
| @@ -1002,7 +989,6 @@ mpt2sas_config_get_number_hba_phys(struct MPT2SAS_ADAPTER *ioc, u8 *num_phys) | |||
| 1002 | _config_free_config_dma_memory(ioc, &mem); | 989 | _config_free_config_dma_memory(ioc, &mem); |
| 1003 | 990 | ||
| 1004 | out: | 991 | out: |
| 1005 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 1006 | return r; | 992 | return r; |
| 1007 | } | 993 | } |
| 1008 | 994 | ||
| @@ -1026,8 +1012,6 @@ mpt2sas_config_get_sas_iounit_pg0(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1026 | Mpi2ConfigRequest_t mpi_request; | 1012 | Mpi2ConfigRequest_t mpi_request; |
| 1027 | int r; | 1013 | int r; |
| 1028 | struct config_request mem; | 1014 | struct config_request mem; |
| 1029 | |||
| 1030 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 1031 | memset(config_page, 0, sz); | 1015 | memset(config_page, 0, sz); |
| 1032 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 1016 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 1033 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 1017 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -1070,7 +1054,6 @@ mpt2sas_config_get_sas_iounit_pg0(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1070 | _config_free_config_dma_memory(ioc, &mem); | 1054 | _config_free_config_dma_memory(ioc, &mem); |
| 1071 | 1055 | ||
| 1072 | out: | 1056 | out: |
| 1073 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 1074 | return r; | 1057 | return r; |
| 1075 | } | 1058 | } |
| 1076 | 1059 | ||
| @@ -1095,7 +1078,6 @@ mpt2sas_config_get_sas_iounit_pg1(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1095 | int r; | 1078 | int r; |
| 1096 | struct config_request mem; | 1079 | struct config_request mem; |
| 1097 | 1080 | ||
| 1098 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 1099 | memset(config_page, 0, sz); | 1081 | memset(config_page, 0, sz); |
| 1100 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 1082 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 1101 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 1083 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -1138,7 +1120,6 @@ mpt2sas_config_get_sas_iounit_pg1(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1138 | _config_free_config_dma_memory(ioc, &mem); | 1120 | _config_free_config_dma_memory(ioc, &mem); |
| 1139 | 1121 | ||
| 1140 | out: | 1122 | out: |
| 1141 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 1142 | return r; | 1123 | return r; |
| 1143 | } | 1124 | } |
| 1144 | 1125 | ||
| @@ -1161,7 +1142,6 @@ mpt2sas_config_get_expander_pg0(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1161 | int r; | 1142 | int r; |
| 1162 | struct config_request mem; | 1143 | struct config_request mem; |
| 1163 | 1144 | ||
| 1164 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 1165 | memset(config_page, 0, sizeof(Mpi2ExpanderPage0_t)); | 1145 | memset(config_page, 0, sizeof(Mpi2ExpanderPage0_t)); |
| 1166 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 1146 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 1167 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 1147 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -1206,7 +1186,6 @@ mpt2sas_config_get_expander_pg0(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1206 | _config_free_config_dma_memory(ioc, &mem); | 1186 | _config_free_config_dma_memory(ioc, &mem); |
| 1207 | 1187 | ||
| 1208 | out: | 1188 | out: |
| 1209 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 1210 | return r; | 1189 | return r; |
| 1211 | } | 1190 | } |
| 1212 | 1191 | ||
| @@ -1230,7 +1209,6 @@ mpt2sas_config_get_expander_pg1(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1230 | int r; | 1209 | int r; |
| 1231 | struct config_request mem; | 1210 | struct config_request mem; |
| 1232 | 1211 | ||
| 1233 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 1234 | memset(config_page, 0, sizeof(Mpi2ExpanderPage1_t)); | 1212 | memset(config_page, 0, sizeof(Mpi2ExpanderPage1_t)); |
| 1235 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 1213 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 1236 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 1214 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -1277,7 +1255,6 @@ mpt2sas_config_get_expander_pg1(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1277 | _config_free_config_dma_memory(ioc, &mem); | 1255 | _config_free_config_dma_memory(ioc, &mem); |
| 1278 | 1256 | ||
| 1279 | out: | 1257 | out: |
| 1280 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 1281 | return r; | 1258 | return r; |
| 1282 | } | 1259 | } |
| 1283 | 1260 | ||
| @@ -1300,7 +1277,6 @@ mpt2sas_config_get_enclosure_pg0(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1300 | int r; | 1277 | int r; |
| 1301 | struct config_request mem; | 1278 | struct config_request mem; |
| 1302 | 1279 | ||
| 1303 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 1304 | memset(config_page, 0, sizeof(Mpi2SasEnclosurePage0_t)); | 1280 | memset(config_page, 0, sizeof(Mpi2SasEnclosurePage0_t)); |
| 1305 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 1281 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 1306 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 1282 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -1345,7 +1321,6 @@ mpt2sas_config_get_enclosure_pg0(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1345 | _config_free_config_dma_memory(ioc, &mem); | 1321 | _config_free_config_dma_memory(ioc, &mem); |
| 1346 | 1322 | ||
| 1347 | out: | 1323 | out: |
| 1348 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 1349 | return r; | 1324 | return r; |
| 1350 | } | 1325 | } |
| 1351 | 1326 | ||
| @@ -1367,7 +1342,6 @@ mpt2sas_config_get_phy_pg0(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1367 | int r; | 1342 | int r; |
| 1368 | struct config_request mem; | 1343 | struct config_request mem; |
| 1369 | 1344 | ||
| 1370 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 1371 | memset(config_page, 0, sizeof(Mpi2SasPhyPage0_t)); | 1345 | memset(config_page, 0, sizeof(Mpi2SasPhyPage0_t)); |
| 1372 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 1346 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 1373 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 1347 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -1413,7 +1387,6 @@ mpt2sas_config_get_phy_pg0(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1413 | _config_free_config_dma_memory(ioc, &mem); | 1387 | _config_free_config_dma_memory(ioc, &mem); |
| 1414 | 1388 | ||
| 1415 | out: | 1389 | out: |
| 1416 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 1417 | return r; | 1390 | return r; |
| 1418 | } | 1391 | } |
| 1419 | 1392 | ||
| @@ -1435,7 +1408,6 @@ mpt2sas_config_get_phy_pg1(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1435 | int r; | 1408 | int r; |
| 1436 | struct config_request mem; | 1409 | struct config_request mem; |
| 1437 | 1410 | ||
| 1438 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 1439 | memset(config_page, 0, sizeof(Mpi2SasPhyPage1_t)); | 1411 | memset(config_page, 0, sizeof(Mpi2SasPhyPage1_t)); |
| 1440 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 1412 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 1441 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 1413 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -1481,7 +1453,6 @@ mpt2sas_config_get_phy_pg1(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1481 | _config_free_config_dma_memory(ioc, &mem); | 1453 | _config_free_config_dma_memory(ioc, &mem); |
| 1482 | 1454 | ||
| 1483 | out: | 1455 | out: |
| 1484 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 1485 | return r; | 1456 | return r; |
| 1486 | } | 1457 | } |
| 1487 | 1458 | ||
| @@ -1505,7 +1476,6 @@ mpt2sas_config_get_raid_volume_pg1(struct MPT2SAS_ADAPTER *ioc, | |||
| 1505 | int r; | 1476 | int r; |
| 1506 | struct config_request mem; | 1477 | struct config_request mem; |
| 1507 | 1478 | ||
| 1508 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 1509 | memset(config_page, 0, sizeof(Mpi2RaidVolPage1_t)); | 1479 | memset(config_page, 0, sizeof(Mpi2RaidVolPage1_t)); |
| 1510 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 1480 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 1511 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 1481 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -1548,7 +1518,6 @@ mpt2sas_config_get_raid_volume_pg1(struct MPT2SAS_ADAPTER *ioc, | |||
| 1548 | _config_free_config_dma_memory(ioc, &mem); | 1518 | _config_free_config_dma_memory(ioc, &mem); |
| 1549 | 1519 | ||
| 1550 | out: | 1520 | out: |
| 1551 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 1552 | return r; | 1521 | return r; |
| 1553 | } | 1522 | } |
| 1554 | 1523 | ||
| @@ -1572,7 +1541,6 @@ mpt2sas_config_get_number_pds(struct MPT2SAS_ADAPTER *ioc, u16 handle, | |||
| 1572 | struct config_request mem; | 1541 | struct config_request mem; |
| 1573 | u16 ioc_status; | 1542 | u16 ioc_status; |
| 1574 | 1543 | ||
| 1575 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 1576 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 1544 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 1577 | *num_pds = 0; | 1545 | *num_pds = 0; |
| 1578 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 1546 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -1620,7 +1588,6 @@ mpt2sas_config_get_number_pds(struct MPT2SAS_ADAPTER *ioc, u16 handle, | |||
| 1620 | _config_free_config_dma_memory(ioc, &mem); | 1588 | _config_free_config_dma_memory(ioc, &mem); |
| 1621 | 1589 | ||
| 1622 | out: | 1590 | out: |
| 1623 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 1624 | return r; | 1591 | return r; |
| 1625 | } | 1592 | } |
| 1626 | 1593 | ||
| @@ -1645,7 +1612,6 @@ mpt2sas_config_get_raid_volume_pg0(struct MPT2SAS_ADAPTER *ioc, | |||
| 1645 | int r; | 1612 | int r; |
| 1646 | struct config_request mem; | 1613 | struct config_request mem; |
| 1647 | 1614 | ||
| 1648 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 1649 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 1615 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 1650 | memset(config_page, 0, sz); | 1616 | memset(config_page, 0, sz); |
| 1651 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 1617 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -1687,7 +1653,6 @@ mpt2sas_config_get_raid_volume_pg0(struct MPT2SAS_ADAPTER *ioc, | |||
| 1687 | _config_free_config_dma_memory(ioc, &mem); | 1653 | _config_free_config_dma_memory(ioc, &mem); |
| 1688 | 1654 | ||
| 1689 | out: | 1655 | out: |
| 1690 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 1691 | return r; | 1656 | return r; |
| 1692 | } | 1657 | } |
| 1693 | 1658 | ||
| @@ -1711,7 +1676,6 @@ mpt2sas_config_get_phys_disk_pg0(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1711 | int r; | 1676 | int r; |
| 1712 | struct config_request mem; | 1677 | struct config_request mem; |
| 1713 | 1678 | ||
| 1714 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 1715 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 1679 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 1716 | memset(config_page, 0, sizeof(Mpi2RaidPhysDiskPage0_t)); | 1680 | memset(config_page, 0, sizeof(Mpi2RaidPhysDiskPage0_t)); |
| 1717 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 1681 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -1754,7 +1718,6 @@ mpt2sas_config_get_phys_disk_pg0(struct MPT2SAS_ADAPTER *ioc, Mpi2ConfigReply_t | |||
| 1754 | _config_free_config_dma_memory(ioc, &mem); | 1718 | _config_free_config_dma_memory(ioc, &mem); |
| 1755 | 1719 | ||
| 1756 | out: | 1720 | out: |
| 1757 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 1758 | return r; | 1721 | return r; |
| 1759 | } | 1722 | } |
| 1760 | 1723 | ||
| @@ -1778,7 +1741,6 @@ mpt2sas_config_get_volume_handle(struct MPT2SAS_ADAPTER *ioc, u16 pd_handle, | |||
| 1778 | struct config_request mem; | 1741 | struct config_request mem; |
| 1779 | u16 ioc_status; | 1742 | u16 ioc_status; |
| 1780 | 1743 | ||
| 1781 | mutex_lock(&ioc->config_cmds.mutex); | ||
| 1782 | *volume_handle = 0; | 1744 | *volume_handle = 0; |
| 1783 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); | 1745 | memset(&mpi_request, 0, sizeof(Mpi2ConfigRequest_t)); |
| 1784 | mpi_request.Function = MPI2_FUNCTION_CONFIG; | 1746 | mpi_request.Function = MPI2_FUNCTION_CONFIG; |
| @@ -1842,7 +1804,6 @@ mpt2sas_config_get_volume_handle(struct MPT2SAS_ADAPTER *ioc, u16 pd_handle, | |||
| 1842 | _config_free_config_dma_memory(ioc, &mem); | 1804 | _config_free_config_dma_memory(ioc, &mem); |
| 1843 | 1805 | ||
| 1844 | out: | 1806 | out: |
| 1845 | mutex_unlock(&ioc->config_cmds.mutex); | ||
| 1846 | return r; | 1807 | return r; |
| 1847 | } | 1808 | } |
| 1848 | 1809 | ||
diff --git a/drivers/scsi/mpt2sas/mpt2sas_scsih.c b/drivers/scsi/mpt2sas/mpt2sas_scsih.c index 2a01a5f2a84d..2e9a4445596f 100644 --- a/drivers/scsi/mpt2sas/mpt2sas_scsih.c +++ b/drivers/scsi/mpt2sas/mpt2sas_scsih.c | |||
| @@ -2767,6 +2767,10 @@ _scsih_scsi_ioc_info(struct MPT2SAS_ADAPTER *ioc, struct scsi_cmnd *scmd, | |||
| 2767 | char *desc_ioc_state = NULL; | 2767 | char *desc_ioc_state = NULL; |
| 2768 | char *desc_scsi_status = NULL; | 2768 | char *desc_scsi_status = NULL; |
| 2769 | char *desc_scsi_state = ioc->tmp_string; | 2769 | char *desc_scsi_state = ioc->tmp_string; |
| 2770 | u32 log_info = le32_to_cpu(mpi_reply->IOCLogInfo); | ||
| 2771 | |||
| 2772 | if (log_info == 0x31170000) | ||
| 2773 | return; | ||
| 2770 | 2774 | ||
| 2771 | switch (ioc_status) { | 2775 | switch (ioc_status) { |
| 2772 | case MPI2_IOCSTATUS_SUCCESS: | 2776 | case MPI2_IOCSTATUS_SUCCESS: |
| @@ -3426,7 +3430,7 @@ _scsih_expander_add(struct MPT2SAS_ADAPTER *ioc, u16 handle) | |||
| 3426 | __le64 sas_address; | 3430 | __le64 sas_address; |
| 3427 | int i; | 3431 | int i; |
| 3428 | unsigned long flags; | 3432 | unsigned long flags; |
| 3429 | struct _sas_port *mpt2sas_port; | 3433 | struct _sas_port *mpt2sas_port = NULL; |
| 3430 | int rc = 0; | 3434 | int rc = 0; |
| 3431 | 3435 | ||
| 3432 | if (!handle) | 3436 | if (!handle) |
| @@ -3518,12 +3522,20 @@ _scsih_expander_add(struct MPT2SAS_ADAPTER *ioc, u16 handle) | |||
| 3518 | &expander_pg1, i, handle))) { | 3522 | &expander_pg1, i, handle))) { |
| 3519 | printk(MPT2SAS_ERR_FMT "failure at %s:%d/%s()!\n", | 3523 | printk(MPT2SAS_ERR_FMT "failure at %s:%d/%s()!\n", |
| 3520 | ioc->name, __FILE__, __LINE__, __func__); | 3524 | ioc->name, __FILE__, __LINE__, __func__); |
| 3521 | continue; | 3525 | rc = -1; |
| 3526 | goto out_fail; | ||
| 3522 | } | 3527 | } |
| 3523 | sas_expander->phy[i].handle = handle; | 3528 | sas_expander->phy[i].handle = handle; |
| 3524 | sas_expander->phy[i].phy_id = i; | 3529 | sas_expander->phy[i].phy_id = i; |
| 3525 | mpt2sas_transport_add_expander_phy(ioc, &sas_expander->phy[i], | 3530 | |
| 3526 | expander_pg1, sas_expander->parent_dev); | 3531 | if ((mpt2sas_transport_add_expander_phy(ioc, |
| 3532 | &sas_expander->phy[i], expander_pg1, | ||
| 3533 | sas_expander->parent_dev))) { | ||
| 3534 | printk(MPT2SAS_ERR_FMT "failure at %s:%d/%s()!\n", | ||
| 3535 | ioc->name, __FILE__, __LINE__, __func__); | ||
| 3536 | rc = -1; | ||
| 3537 | goto out_fail; | ||
| 3538 | } | ||
| 3527 | } | 3539 | } |
| 3528 | 3540 | ||
| 3529 | if (sas_expander->enclosure_handle) { | 3541 | if (sas_expander->enclosure_handle) { |
| @@ -3540,8 +3552,9 @@ _scsih_expander_add(struct MPT2SAS_ADAPTER *ioc, u16 handle) | |||
| 3540 | 3552 | ||
| 3541 | out_fail: | 3553 | out_fail: |
| 3542 | 3554 | ||
| 3543 | if (sas_expander) | 3555 | if (mpt2sas_port) |
| 3544 | kfree(sas_expander->phy); | 3556 | mpt2sas_transport_port_remove(ioc, sas_expander->sas_address, |
| 3557 | sas_expander->parent_handle); | ||
| 3545 | kfree(sas_expander); | 3558 | kfree(sas_expander); |
| 3546 | return rc; | 3559 | return rc; |
| 3547 | } | 3560 | } |
| @@ -3663,12 +3676,11 @@ _scsih_add_device(struct MPT2SAS_ADAPTER *ioc, u16 handle, u8 phy_num, u8 is_pd) | |||
| 3663 | sas_device->hidden_raid_component = is_pd; | 3676 | sas_device->hidden_raid_component = is_pd; |
| 3664 | 3677 | ||
| 3665 | /* get enclosure_logical_id */ | 3678 | /* get enclosure_logical_id */ |
| 3666 | if (!(mpt2sas_config_get_enclosure_pg0(ioc, &mpi_reply, &enclosure_pg0, | 3679 | if (sas_device->enclosure_handle && !(mpt2sas_config_get_enclosure_pg0( |
| 3667 | MPI2_SAS_ENCLOS_PGAD_FORM_HANDLE, | 3680 | ioc, &mpi_reply, &enclosure_pg0, MPI2_SAS_ENCLOS_PGAD_FORM_HANDLE, |
| 3668 | sas_device->enclosure_handle))) { | 3681 | sas_device->enclosure_handle))) |
| 3669 | sas_device->enclosure_logical_id = | 3682 | sas_device->enclosure_logical_id = |
| 3670 | le64_to_cpu(enclosure_pg0.EnclosureLogicalID); | 3683 | le64_to_cpu(enclosure_pg0.EnclosureLogicalID); |
| 3671 | } | ||
| 3672 | 3684 | ||
| 3673 | /* get device name */ | 3685 | /* get device name */ |
| 3674 | sas_device->device_name = le64_to_cpu(sas_device_pg0.DeviceName); | 3686 | sas_device->device_name = le64_to_cpu(sas_device_pg0.DeviceName); |
| @@ -4250,12 +4262,6 @@ _scsih_sas_volume_add(struct MPT2SAS_ADAPTER *ioc, | |||
| 4250 | u16 handle = le16_to_cpu(element->VolDevHandle); | 4262 | u16 handle = le16_to_cpu(element->VolDevHandle); |
| 4251 | int rc; | 4263 | int rc; |
| 4252 | 4264 | ||
| 4253 | #if 0 /* RAID_HACKS */ | ||
| 4254 | if (le32_to_cpu(event_data->Flags) & | ||
| 4255 | MPI2_EVENT_IR_CHANGE_FLAGS_FOREIGN_CONFIG) | ||
| 4256 | return; | ||
| 4257 | #endif | ||
| 4258 | |||
| 4259 | mpt2sas_config_get_volume_wwid(ioc, handle, &wwid); | 4265 | mpt2sas_config_get_volume_wwid(ioc, handle, &wwid); |
| 4260 | if (!wwid) { | 4266 | if (!wwid) { |
| 4261 | printk(MPT2SAS_ERR_FMT | 4267 | printk(MPT2SAS_ERR_FMT |
| @@ -4310,12 +4316,6 @@ _scsih_sas_volume_delete(struct MPT2SAS_ADAPTER *ioc, | |||
| 4310 | unsigned long flags; | 4316 | unsigned long flags; |
| 4311 | struct MPT2SAS_TARGET *sas_target_priv_data; | 4317 | struct MPT2SAS_TARGET *sas_target_priv_data; |
| 4312 | 4318 | ||
| 4313 | #if 0 /* RAID_HACKS */ | ||
| 4314 | if (le32_to_cpu(event_data->Flags) & | ||
| 4315 | MPI2_EVENT_IR_CHANGE_FLAGS_FOREIGN_CONFIG) | ||
| 4316 | return; | ||
| 4317 | #endif | ||
| 4318 | |||
| 4319 | spin_lock_irqsave(&ioc->raid_device_lock, flags); | 4319 | spin_lock_irqsave(&ioc->raid_device_lock, flags); |
| 4320 | raid_device = _scsih_raid_device_find_by_handle(ioc, handle); | 4320 | raid_device = _scsih_raid_device_find_by_handle(ioc, handle); |
| 4321 | spin_unlock_irqrestore(&ioc->raid_device_lock, flags); | 4321 | spin_unlock_irqrestore(&ioc->raid_device_lock, flags); |
| @@ -4428,14 +4428,38 @@ _scsih_sas_pd_add(struct MPT2SAS_ADAPTER *ioc, | |||
| 4428 | struct _sas_device *sas_device; | 4428 | struct _sas_device *sas_device; |
| 4429 | unsigned long flags; | 4429 | unsigned long flags; |
| 4430 | u16 handle = le16_to_cpu(element->PhysDiskDevHandle); | 4430 | u16 handle = le16_to_cpu(element->PhysDiskDevHandle); |
| 4431 | Mpi2ConfigReply_t mpi_reply; | ||
| 4432 | Mpi2SasDevicePage0_t sas_device_pg0; | ||
| 4433 | u32 ioc_status; | ||
| 4431 | 4434 | ||
| 4432 | spin_lock_irqsave(&ioc->sas_device_lock, flags); | 4435 | spin_lock_irqsave(&ioc->sas_device_lock, flags); |
| 4433 | sas_device = _scsih_sas_device_find_by_handle(ioc, handle); | 4436 | sas_device = _scsih_sas_device_find_by_handle(ioc, handle); |
| 4434 | spin_unlock_irqrestore(&ioc->sas_device_lock, flags); | 4437 | spin_unlock_irqrestore(&ioc->sas_device_lock, flags); |
| 4435 | if (sas_device) | 4438 | if (sas_device) { |
| 4436 | sas_device->hidden_raid_component = 1; | 4439 | sas_device->hidden_raid_component = 1; |
| 4437 | else | 4440 | return; |
| 4438 | _scsih_add_device(ioc, handle, 0, 1); | 4441 | } |
| 4442 | |||
| 4443 | if ((mpt2sas_config_get_sas_device_pg0(ioc, &mpi_reply, &sas_device_pg0, | ||
| 4444 | MPI2_SAS_DEVICE_PGAD_FORM_HANDLE, handle))) { | ||
| 4445 | printk(MPT2SAS_ERR_FMT "failure at %s:%d/%s()!\n", | ||
| 4446 | ioc->name, __FILE__, __LINE__, __func__); | ||
| 4447 | return; | ||
| 4448 | } | ||
| 4449 | |||
| 4450 | ioc_status = le16_to_cpu(mpi_reply.IOCStatus) & | ||
| 4451 | MPI2_IOCSTATUS_MASK; | ||
| 4452 | if (ioc_status != MPI2_IOCSTATUS_SUCCESS) { | ||
| 4453 | printk(MPT2SAS_ERR_FMT "failure at %s:%d/%s()!\n", | ||
| 4454 | ioc->name, __FILE__, __LINE__, __func__); | ||
| 4455 | return; | ||
| 4456 | } | ||
| 4457 | |||
| 4458 | _scsih_link_change(ioc, | ||
| 4459 | le16_to_cpu(sas_device_pg0.ParentDevHandle), | ||
| 4460 | handle, sas_device_pg0.PhyNum, MPI2_SAS_NEG_LINK_RATE_1_5); | ||
| 4461 | |||
| 4462 | _scsih_add_device(ioc, handle, 0, 1); | ||
| 4439 | } | 4463 | } |
| 4440 | 4464 | ||
| 4441 | #ifdef CONFIG_SCSI_MPT2SAS_LOGGING | 4465 | #ifdef CONFIG_SCSI_MPT2SAS_LOGGING |
| @@ -4535,12 +4559,15 @@ _scsih_sas_ir_config_change_event(struct MPT2SAS_ADAPTER *ioc, u8 VF_ID, | |||
| 4535 | { | 4559 | { |
| 4536 | Mpi2EventIrConfigElement_t *element; | 4560 | Mpi2EventIrConfigElement_t *element; |
| 4537 | int i; | 4561 | int i; |
| 4562 | u8 foreign_config; | ||
| 4538 | 4563 | ||
| 4539 | #ifdef CONFIG_SCSI_MPT2SAS_LOGGING | 4564 | #ifdef CONFIG_SCSI_MPT2SAS_LOGGING |
| 4540 | if (ioc->logging_level & MPT_DEBUG_EVENT_WORK_TASK) | 4565 | if (ioc->logging_level & MPT_DEBUG_EVENT_WORK_TASK) |
| 4541 | _scsih_sas_ir_config_change_event_debug(ioc, event_data); | 4566 | _scsih_sas_ir_config_change_event_debug(ioc, event_data); |
| 4542 | 4567 | ||
| 4543 | #endif | 4568 | #endif |
| 4569 | foreign_config = (le32_to_cpu(event_data->Flags) & | ||
| 4570 | MPI2_EVENT_IR_CHANGE_FLAGS_FOREIGN_CONFIG) ? 1 : 0; | ||
| 4544 | 4571 | ||
| 4545 | element = (Mpi2EventIrConfigElement_t *)&event_data->ConfigElement[0]; | 4572 | element = (Mpi2EventIrConfigElement_t *)&event_data->ConfigElement[0]; |
| 4546 | for (i = 0; i < event_data->NumElements; i++, element++) { | 4573 | for (i = 0; i < event_data->NumElements; i++, element++) { |
| @@ -4548,11 +4575,13 @@ _scsih_sas_ir_config_change_event(struct MPT2SAS_ADAPTER *ioc, u8 VF_ID, | |||
| 4548 | switch (element->ReasonCode) { | 4575 | switch (element->ReasonCode) { |
| 4549 | case MPI2_EVENT_IR_CHANGE_RC_VOLUME_CREATED: | 4576 | case MPI2_EVENT_IR_CHANGE_RC_VOLUME_CREATED: |
| 4550 | case MPI2_EVENT_IR_CHANGE_RC_ADDED: | 4577 | case MPI2_EVENT_IR_CHANGE_RC_ADDED: |
| 4551 | _scsih_sas_volume_add(ioc, element); | 4578 | if (!foreign_config) |
| 4579 | _scsih_sas_volume_add(ioc, element); | ||
| 4552 | break; | 4580 | break; |
| 4553 | case MPI2_EVENT_IR_CHANGE_RC_VOLUME_DELETED: | 4581 | case MPI2_EVENT_IR_CHANGE_RC_VOLUME_DELETED: |
| 4554 | case MPI2_EVENT_IR_CHANGE_RC_REMOVED: | 4582 | case MPI2_EVENT_IR_CHANGE_RC_REMOVED: |
| 4555 | _scsih_sas_volume_delete(ioc, element); | 4583 | if (!foreign_config) |
| 4584 | _scsih_sas_volume_delete(ioc, element); | ||
| 4556 | break; | 4585 | break; |
| 4557 | case MPI2_EVENT_IR_CHANGE_RC_PD_CREATED: | 4586 | case MPI2_EVENT_IR_CHANGE_RC_PD_CREATED: |
| 4558 | _scsih_sas_pd_hide(ioc, element); | 4587 | _scsih_sas_pd_hide(ioc, element); |
| @@ -4671,6 +4700,9 @@ _scsih_sas_ir_physical_disk_event(struct MPT2SAS_ADAPTER *ioc, u8 VF_ID, | |||
| 4671 | u32 state; | 4700 | u32 state; |
| 4672 | struct _sas_device *sas_device; | 4701 | struct _sas_device *sas_device; |
| 4673 | unsigned long flags; | 4702 | unsigned long flags; |
| 4703 | Mpi2ConfigReply_t mpi_reply; | ||
| 4704 | Mpi2SasDevicePage0_t sas_device_pg0; | ||
| 4705 | u32 ioc_status; | ||
| 4674 | 4706 | ||
| 4675 | if (event_data->ReasonCode != MPI2_EVENT_IR_PHYSDISK_RC_STATE_CHANGED) | 4707 | if (event_data->ReasonCode != MPI2_EVENT_IR_PHYSDISK_RC_STATE_CHANGED) |
| 4676 | return; | 4708 | return; |
| @@ -4687,22 +4719,40 @@ _scsih_sas_ir_physical_disk_event(struct MPT2SAS_ADAPTER *ioc, u8 VF_ID, | |||
| 4687 | spin_unlock_irqrestore(&ioc->sas_device_lock, flags); | 4719 | spin_unlock_irqrestore(&ioc->sas_device_lock, flags); |
| 4688 | 4720 | ||
| 4689 | switch (state) { | 4721 | switch (state) { |
| 4690 | #if 0 | ||
| 4691 | case MPI2_RAID_PD_STATE_OFFLINE: | ||
| 4692 | if (sas_device) | ||
| 4693 | _scsih_remove_device(ioc, handle); | ||
| 4694 | break; | ||
| 4695 | #endif | ||
| 4696 | case MPI2_RAID_PD_STATE_ONLINE: | 4722 | case MPI2_RAID_PD_STATE_ONLINE: |
| 4697 | case MPI2_RAID_PD_STATE_DEGRADED: | 4723 | case MPI2_RAID_PD_STATE_DEGRADED: |
| 4698 | case MPI2_RAID_PD_STATE_REBUILDING: | 4724 | case MPI2_RAID_PD_STATE_REBUILDING: |
| 4699 | case MPI2_RAID_PD_STATE_OPTIMAL: | 4725 | case MPI2_RAID_PD_STATE_OPTIMAL: |
| 4700 | if (sas_device) | 4726 | if (sas_device) { |
| 4701 | sas_device->hidden_raid_component = 1; | 4727 | sas_device->hidden_raid_component = 1; |
| 4702 | else | 4728 | return; |
| 4703 | _scsih_add_device(ioc, handle, 0, 1); | 4729 | } |
| 4730 | |||
| 4731 | if ((mpt2sas_config_get_sas_device_pg0(ioc, &mpi_reply, | ||
| 4732 | &sas_device_pg0, MPI2_SAS_DEVICE_PGAD_FORM_HANDLE, | ||
| 4733 | handle))) { | ||
| 4734 | printk(MPT2SAS_ERR_FMT "failure at %s:%d/%s()!\n", | ||
| 4735 | ioc->name, __FILE__, __LINE__, __func__); | ||
| 4736 | return; | ||
| 4737 | } | ||
| 4738 | |||
| 4739 | ioc_status = le16_to_cpu(mpi_reply.IOCStatus) & | ||
| 4740 | MPI2_IOCSTATUS_MASK; | ||
| 4741 | if (ioc_status != MPI2_IOCSTATUS_SUCCESS) { | ||
| 4742 | printk(MPT2SAS_ERR_FMT "failure at %s:%d/%s()!\n", | ||
| 4743 | ioc->name, __FILE__, __LINE__, __func__); | ||
| 4744 | return; | ||
| 4745 | } | ||
| 4746 | |||
| 4747 | _scsih_link_change(ioc, | ||
| 4748 | le16_to_cpu(sas_device_pg0.ParentDevHandle), | ||
| 4749 | handle, sas_device_pg0.PhyNum, MPI2_SAS_NEG_LINK_RATE_1_5); | ||
| 4750 | |||
| 4751 | _scsih_add_device(ioc, handle, 0, 1); | ||
| 4752 | |||
| 4704 | break; | 4753 | break; |
| 4705 | 4754 | ||
| 4755 | case MPI2_RAID_PD_STATE_OFFLINE: | ||
| 4706 | case MPI2_RAID_PD_STATE_NOT_CONFIGURED: | 4756 | case MPI2_RAID_PD_STATE_NOT_CONFIGURED: |
| 4707 | case MPI2_RAID_PD_STATE_NOT_COMPATIBLE: | 4757 | case MPI2_RAID_PD_STATE_NOT_COMPATIBLE: |
| 4708 | case MPI2_RAID_PD_STATE_HOT_SPARE: | 4758 | case MPI2_RAID_PD_STATE_HOT_SPARE: |
| @@ -5774,6 +5824,7 @@ _scsih_suspend(struct pci_dev *pdev, pm_message_t state) | |||
| 5774 | struct MPT2SAS_ADAPTER *ioc = shost_priv(shost); | 5824 | struct MPT2SAS_ADAPTER *ioc = shost_priv(shost); |
| 5775 | u32 device_state; | 5825 | u32 device_state; |
| 5776 | 5826 | ||
| 5827 | mpt2sas_base_stop_watchdog(ioc); | ||
| 5777 | flush_scheduled_work(); | 5828 | flush_scheduled_work(); |
| 5778 | scsi_block_requests(shost); | 5829 | scsi_block_requests(shost); |
| 5779 | device_state = pci_choose_state(pdev, state); | 5830 | device_state = pci_choose_state(pdev, state); |
| @@ -5816,6 +5867,7 @@ _scsih_resume(struct pci_dev *pdev) | |||
| 5816 | 5867 | ||
| 5817 | mpt2sas_base_hard_reset_handler(ioc, CAN_SLEEP, SOFT_RESET); | 5868 | mpt2sas_base_hard_reset_handler(ioc, CAN_SLEEP, SOFT_RESET); |
| 5818 | scsi_unblock_requests(shost); | 5869 | scsi_unblock_requests(shost); |
| 5870 | mpt2sas_base_start_watchdog(ioc); | ||
| 5819 | return 0; | 5871 | return 0; |
| 5820 | } | 5872 | } |
| 5821 | #endif /* CONFIG_PM */ | 5873 | #endif /* CONFIG_PM */ |
diff --git a/drivers/scsi/qla4xxx/ql4_dbg.c b/drivers/scsi/qla4xxx/ql4_dbg.c index fcc184cd066d..cbceb0ebabf7 100644 --- a/drivers/scsi/qla4xxx/ql4_dbg.c +++ b/drivers/scsi/qla4xxx/ql4_dbg.c | |||
| @@ -15,19 +15,18 @@ void qla4xxx_dump_buffer(void *b, uint32_t size) | |||
| 15 | uint32_t cnt; | 15 | uint32_t cnt; |
| 16 | uint8_t *c = b; | 16 | uint8_t *c = b; |
| 17 | 17 | ||
| 18 | printk(" 0 1 2 3 4 5 6 7 8 9 Ah Bh Ch Dh Eh " | 18 | printk(" 0 1 2 3 4 5 6 7 8 9 Ah Bh Ch Dh Eh " |
| 19 | "Fh\n"); | 19 | "Fh\n"); |
| 20 | printk("------------------------------------------------------------" | 20 | printk("------------------------------------------------------------" |
| 21 | "--\n"); | 21 | "--\n"); |
| 22 | for (cnt = 0; cnt < size; cnt++, c++) { | 22 | for (cnt = 0; cnt < size; c++) { |
| 23 | printk(KERN_DEBUG "%02x", *c); | 23 | printk(KERN_INFO "%02x", *c); |
| 24 | if (!(cnt % 16)) | 24 | if (!(++cnt % 16)) |
| 25 | printk(KERN_DEBUG "\n"); | 25 | printk(KERN_INFO "\n"); |
| 26 | 26 | ||
| 27 | else | 27 | else |
| 28 | printk(KERN_DEBUG " "); | 28 | printk(KERN_INFO " "); |
| 29 | } | 29 | } |
| 30 | if (cnt % 16) | 30 | printk(KERN_INFO "\n"); |
| 31 | printk(KERN_DEBUG "\n"); | ||
| 32 | } | 31 | } |
| 33 | 32 | ||
diff --git a/drivers/scsi/qla4xxx/ql4_def.h b/drivers/scsi/qla4xxx/ql4_def.h index b586f27c3bd4..81b5f29254e2 100644 --- a/drivers/scsi/qla4xxx/ql4_def.h +++ b/drivers/scsi/qla4xxx/ql4_def.h | |||
| @@ -100,7 +100,6 @@ | |||
| 100 | #define MAX_SRBS MAX_CMDS_TO_RISC | 100 | #define MAX_SRBS MAX_CMDS_TO_RISC |
| 101 | #define MBOX_AEN_REG_COUNT 5 | 101 | #define MBOX_AEN_REG_COUNT 5 |
| 102 | #define MAX_INIT_RETRIES 5 | 102 | #define MAX_INIT_RETRIES 5 |
| 103 | #define IOCB_HIWAT_CUSHION 16 | ||
| 104 | 103 | ||
| 105 | /* | 104 | /* |
| 106 | * Buffer sizes | 105 | * Buffer sizes |
| @@ -184,6 +183,11 @@ struct srb { | |||
| 184 | uint16_t cc_stat; | 183 | uint16_t cc_stat; |
| 185 | u_long r_start; /* Time we recieve a cmd from OS */ | 184 | u_long r_start; /* Time we recieve a cmd from OS */ |
| 186 | u_long u_start; /* Time when we handed the cmd to F/W */ | 185 | u_long u_start; /* Time when we handed the cmd to F/W */ |
| 186 | |||
| 187 | /* Used for extended sense / status continuation */ | ||
| 188 | uint8_t *req_sense_ptr; | ||
| 189 | uint16_t req_sense_len; | ||
| 190 | uint16_t reserved2; | ||
| 187 | }; | 191 | }; |
| 188 | 192 | ||
| 189 | /* | 193 | /* |
| @@ -302,7 +306,6 @@ struct scsi_qla_host { | |||
| 302 | uint32_t tot_ddbs; | 306 | uint32_t tot_ddbs; |
| 303 | 307 | ||
| 304 | uint16_t iocb_cnt; | 308 | uint16_t iocb_cnt; |
| 305 | uint16_t iocb_hiwat; | ||
| 306 | 309 | ||
| 307 | /* SRB cache. */ | 310 | /* SRB cache. */ |
| 308 | #define SRB_MIN_REQ 128 | 311 | #define SRB_MIN_REQ 128 |
| @@ -436,6 +439,8 @@ struct scsi_qla_host { | |||
| 436 | /* Map ddb_list entry by FW ddb index */ | 439 | /* Map ddb_list entry by FW ddb index */ |
| 437 | struct ddb_entry *fw_ddb_index_map[MAX_DDB_ENTRIES]; | 440 | struct ddb_entry *fw_ddb_index_map[MAX_DDB_ENTRIES]; |
| 438 | 441 | ||
| 442 | /* Saved srb for status continuation entry processing */ | ||
| 443 | struct srb *status_srb; | ||
| 439 | }; | 444 | }; |
| 440 | 445 | ||
| 441 | static inline int is_qla4010(struct scsi_qla_host *ha) | 446 | static inline int is_qla4010(struct scsi_qla_host *ha) |
diff --git a/drivers/scsi/qla4xxx/ql4_fw.h b/drivers/scsi/qla4xxx/ql4_fw.h index 1b667a70cffa..9cd7a608df38 100644 --- a/drivers/scsi/qla4xxx/ql4_fw.h +++ b/drivers/scsi/qla4xxx/ql4_fw.h | |||
| @@ -572,6 +572,7 @@ struct conn_event_log_entry { | |||
| 572 | *************************************************************************/ | 572 | *************************************************************************/ |
| 573 | #define IOCB_MAX_CDB_LEN 16 /* Bytes in a CBD */ | 573 | #define IOCB_MAX_CDB_LEN 16 /* Bytes in a CBD */ |
| 574 | #define IOCB_MAX_SENSEDATA_LEN 32 /* Bytes of sense data */ | 574 | #define IOCB_MAX_SENSEDATA_LEN 32 /* Bytes of sense data */ |
| 575 | #define IOCB_MAX_EXT_SENSEDATA_LEN 60 /* Bytes of extended sense data */ | ||
| 575 | 576 | ||
| 576 | /* IOCB header structure */ | 577 | /* IOCB header structure */ |
| 577 | struct qla4_header { | 578 | struct qla4_header { |
| @@ -733,6 +734,12 @@ struct status_entry { | |||
| 733 | 734 | ||
| 734 | }; | 735 | }; |
| 735 | 736 | ||
| 737 | /* Status Continuation entry */ | ||
| 738 | struct status_cont_entry { | ||
| 739 | struct qla4_header hdr; /* 00-03 */ | ||
| 740 | uint8_t ext_sense_data[IOCB_MAX_EXT_SENSEDATA_LEN]; /* 04-63 */ | ||
| 741 | }; | ||
| 742 | |||
| 736 | struct passthru0 { | 743 | struct passthru0 { |
| 737 | struct qla4_header hdr; /* 00-03 */ | 744 | struct qla4_header hdr; /* 00-03 */ |
| 738 | uint32_t handle; /* 04-07 */ | 745 | uint32_t handle; /* 04-07 */ |
diff --git a/drivers/scsi/qla4xxx/ql4_iocb.c b/drivers/scsi/qla4xxx/ql4_iocb.c index 912a67494adf..e0c32159749c 100644 --- a/drivers/scsi/qla4xxx/ql4_iocb.c +++ b/drivers/scsi/qla4xxx/ql4_iocb.c | |||
| @@ -10,9 +10,42 @@ | |||
| 10 | #include "ql4_dbg.h" | 10 | #include "ql4_dbg.h" |
| 11 | #include "ql4_inline.h" | 11 | #include "ql4_inline.h" |
| 12 | 12 | ||
| 13 | |||
| 14 | #include <scsi/scsi_tcq.h> | 13 | #include <scsi/scsi_tcq.h> |
| 15 | 14 | ||
| 15 | static int | ||
| 16 | qla4xxx_space_in_req_ring(struct scsi_qla_host *ha, uint16_t req_cnt) | ||
| 17 | { | ||
| 18 | uint16_t cnt; | ||
| 19 | |||
| 20 | /* Calculate number of free request entries. */ | ||
| 21 | if ((req_cnt + 2) >= ha->req_q_count) { | ||
| 22 | cnt = (uint16_t) le32_to_cpu(ha->shadow_regs->req_q_out); | ||
| 23 | if (ha->request_in < cnt) | ||
| 24 | ha->req_q_count = cnt - ha->request_in; | ||
| 25 | else | ||
| 26 | ha->req_q_count = REQUEST_QUEUE_DEPTH - | ||
| 27 | (ha->request_in - cnt); | ||
| 28 | } | ||
| 29 | |||
| 30 | /* Check if room for request in request ring. */ | ||
| 31 | if ((req_cnt + 2) < ha->req_q_count) | ||
| 32 | return 1; | ||
| 33 | else | ||
| 34 | return 0; | ||
| 35 | } | ||
| 36 | |||
| 37 | static void qla4xxx_advance_req_ring_ptr(struct scsi_qla_host *ha) | ||
| 38 | { | ||
| 39 | /* Advance request queue pointer */ | ||
| 40 | if (ha->request_in == (REQUEST_QUEUE_DEPTH - 1)) { | ||
| 41 | ha->request_in = 0; | ||
| 42 | ha->request_ptr = ha->request_ring; | ||
| 43 | } else { | ||
| 44 | ha->request_in++; | ||
| 45 | ha->request_ptr++; | ||
| 46 | } | ||
| 47 | } | ||
| 48 | |||
| 16 | /** | 49 | /** |
| 17 | * qla4xxx_get_req_pkt - returns a valid entry in request queue. | 50 | * qla4xxx_get_req_pkt - returns a valid entry in request queue. |
| 18 | * @ha: Pointer to host adapter structure. | 51 | * @ha: Pointer to host adapter structure. |
| @@ -26,35 +59,18 @@ | |||
| 26 | static int qla4xxx_get_req_pkt(struct scsi_qla_host *ha, | 59 | static int qla4xxx_get_req_pkt(struct scsi_qla_host *ha, |
| 27 | struct queue_entry **queue_entry) | 60 | struct queue_entry **queue_entry) |
| 28 | { | 61 | { |
| 29 | uint16_t request_in; | 62 | uint16_t req_cnt = 1; |
| 30 | uint8_t status = QLA_SUCCESS; | ||
| 31 | |||
| 32 | *queue_entry = ha->request_ptr; | ||
| 33 | 63 | ||
| 34 | /* get the latest request_in and request_out index */ | 64 | if (qla4xxx_space_in_req_ring(ha, req_cnt)) { |
| 35 | request_in = ha->request_in; | 65 | *queue_entry = ha->request_ptr; |
| 36 | ha->request_out = (uint16_t) le32_to_cpu(ha->shadow_regs->req_q_out); | ||
| 37 | |||
| 38 | /* Advance request queue pointer and check for queue full */ | ||
| 39 | if (request_in == (REQUEST_QUEUE_DEPTH - 1)) { | ||
| 40 | request_in = 0; | ||
| 41 | ha->request_ptr = ha->request_ring; | ||
| 42 | } else { | ||
| 43 | request_in++; | ||
| 44 | ha->request_ptr++; | ||
| 45 | } | ||
| 46 | |||
| 47 | /* request queue is full, try again later */ | ||
| 48 | if ((ha->iocb_cnt + 1) >= ha->iocb_hiwat) { | ||
| 49 | /* restore request pointer */ | ||
| 50 | ha->request_ptr = *queue_entry; | ||
| 51 | status = QLA_ERROR; | ||
| 52 | } else { | ||
| 53 | ha->request_in = request_in; | ||
| 54 | memset(*queue_entry, 0, sizeof(**queue_entry)); | 66 | memset(*queue_entry, 0, sizeof(**queue_entry)); |
| 67 | |||
| 68 | qla4xxx_advance_req_ring_ptr(ha); | ||
| 69 | ha->req_q_count -= req_cnt; | ||
| 70 | return QLA_SUCCESS; | ||
| 55 | } | 71 | } |
| 56 | 72 | ||
| 57 | return status; | 73 | return QLA_ERROR; |
| 58 | } | 74 | } |
| 59 | 75 | ||
| 60 | /** | 76 | /** |
| @@ -100,21 +116,14 @@ exit_send_marker: | |||
| 100 | return status; | 116 | return status; |
| 101 | } | 117 | } |
| 102 | 118 | ||
| 103 | static struct continuation_t1_entry* qla4xxx_alloc_cont_entry( | 119 | static struct continuation_t1_entry * |
| 104 | struct scsi_qla_host *ha) | 120 | qla4xxx_alloc_cont_entry(struct scsi_qla_host *ha) |
| 105 | { | 121 | { |
| 106 | struct continuation_t1_entry *cont_entry; | 122 | struct continuation_t1_entry *cont_entry; |
| 107 | 123 | ||
| 108 | cont_entry = (struct continuation_t1_entry *)ha->request_ptr; | 124 | cont_entry = (struct continuation_t1_entry *)ha->request_ptr; |
| 109 | 125 | ||
| 110 | /* Advance request queue pointer */ | 126 | qla4xxx_advance_req_ring_ptr(ha); |
| 111 | if (ha->request_in == (REQUEST_QUEUE_DEPTH - 1)) { | ||
| 112 | ha->request_in = 0; | ||
| 113 | ha->request_ptr = ha->request_ring; | ||
| 114 | } else { | ||
| 115 | ha->request_in++; | ||
| 116 | ha->request_ptr++; | ||
| 117 | } | ||
| 118 | 127 | ||
| 119 | /* Load packet defaults */ | 128 | /* Load packet defaults */ |
| 120 | cont_entry->hdr.entryType = ET_CONTINUE; | 129 | cont_entry->hdr.entryType = ET_CONTINUE; |
| @@ -197,13 +206,10 @@ int qla4xxx_send_command_to_isp(struct scsi_qla_host *ha, struct srb * srb) | |||
| 197 | struct scsi_cmnd *cmd = srb->cmd; | 206 | struct scsi_cmnd *cmd = srb->cmd; |
| 198 | struct ddb_entry *ddb_entry; | 207 | struct ddb_entry *ddb_entry; |
| 199 | struct command_t3_entry *cmd_entry; | 208 | struct command_t3_entry *cmd_entry; |
| 200 | |||
| 201 | int nseg; | 209 | int nseg; |
| 202 | uint16_t tot_dsds; | 210 | uint16_t tot_dsds; |
| 203 | uint16_t req_cnt; | 211 | uint16_t req_cnt; |
| 204 | |||
| 205 | unsigned long flags; | 212 | unsigned long flags; |
| 206 | uint16_t cnt; | ||
| 207 | uint32_t index; | 213 | uint32_t index; |
| 208 | char tag[2]; | 214 | char tag[2]; |
| 209 | 215 | ||
| @@ -217,6 +223,19 @@ int qla4xxx_send_command_to_isp(struct scsi_qla_host *ha, struct srb * srb) | |||
| 217 | 223 | ||
| 218 | index = (uint32_t)cmd->request->tag; | 224 | index = (uint32_t)cmd->request->tag; |
| 219 | 225 | ||
| 226 | /* | ||
| 227 | * Check to see if adapter is online before placing request on | ||
| 228 | * request queue. If a reset occurs and a request is in the queue, | ||
| 229 | * the firmware will still attempt to process the request, retrieving | ||
| 230 | * garbage for pointers. | ||
| 231 | */ | ||
| 232 | if (!test_bit(AF_ONLINE, &ha->flags)) { | ||
| 233 | DEBUG2(printk("scsi%ld: %s: Adapter OFFLINE! " | ||
| 234 | "Do not issue command.\n", | ||
| 235 | ha->host_no, __func__)); | ||
| 236 | goto queuing_error; | ||
| 237 | } | ||
| 238 | |||
| 220 | /* Calculate the number of request entries needed. */ | 239 | /* Calculate the number of request entries needed. */ |
| 221 | nseg = scsi_dma_map(cmd); | 240 | nseg = scsi_dma_map(cmd); |
| 222 | if (nseg < 0) | 241 | if (nseg < 0) |
| @@ -224,17 +243,7 @@ int qla4xxx_send_command_to_isp(struct scsi_qla_host *ha, struct srb * srb) | |||
| 224 | tot_dsds = nseg; | 243 | tot_dsds = nseg; |
| 225 | 244 | ||
| 226 | req_cnt = qla4xxx_calc_request_entries(tot_dsds); | 245 | req_cnt = qla4xxx_calc_request_entries(tot_dsds); |
| 227 | 246 | if (!qla4xxx_space_in_req_ring(ha, req_cnt)) | |
| 228 | if (ha->req_q_count < (req_cnt + 2)) { | ||
| 229 | cnt = (uint16_t) le32_to_cpu(ha->shadow_regs->req_q_out); | ||
| 230 | if (ha->request_in < cnt) | ||
| 231 | ha->req_q_count = cnt - ha->request_in; | ||
| 232 | else | ||
| 233 | ha->req_q_count = REQUEST_QUEUE_DEPTH - | ||
| 234 | (ha->request_in - cnt); | ||
| 235 | } | ||
| 236 | |||
| 237 | if (ha->req_q_count < (req_cnt + 2)) | ||
| 238 | goto queuing_error; | 247 | goto queuing_error; |
| 239 | 248 | ||
| 240 | /* total iocbs active */ | 249 | /* total iocbs active */ |
| @@ -286,32 +295,10 @@ int qla4xxx_send_command_to_isp(struct scsi_qla_host *ha, struct srb * srb) | |||
| 286 | break; | 295 | break; |
| 287 | } | 296 | } |
| 288 | 297 | ||
| 289 | 298 | qla4xxx_advance_req_ring_ptr(ha); | |
| 290 | /* Advance request queue pointer */ | ||
| 291 | ha->request_in++; | ||
| 292 | if (ha->request_in == REQUEST_QUEUE_DEPTH) { | ||
| 293 | ha->request_in = 0; | ||
| 294 | ha->request_ptr = ha->request_ring; | ||
| 295 | } else | ||
| 296 | ha->request_ptr++; | ||
| 297 | |||
| 298 | |||
| 299 | qla4xxx_build_scsi_iocbs(srb, cmd_entry, tot_dsds); | 299 | qla4xxx_build_scsi_iocbs(srb, cmd_entry, tot_dsds); |
| 300 | wmb(); | 300 | wmb(); |
| 301 | 301 | ||
| 302 | /* | ||
| 303 | * Check to see if adapter is online before placing request on | ||
| 304 | * request queue. If a reset occurs and a request is in the queue, | ||
| 305 | * the firmware will still attempt to process the request, retrieving | ||
| 306 | * garbage for pointers. | ||
| 307 | */ | ||
| 308 | if (!test_bit(AF_ONLINE, &ha->flags)) { | ||
| 309 | DEBUG2(printk("scsi%ld: %s: Adapter OFFLINE! " | ||
| 310 | "Do not issue command.\n", | ||
| 311 | ha->host_no, __func__)); | ||
| 312 | goto queuing_error; | ||
| 313 | } | ||
| 314 | |||
| 315 | srb->cmd->host_scribble = (unsigned char *)srb; | 302 | srb->cmd->host_scribble = (unsigned char *)srb; |
| 316 | 303 | ||
| 317 | /* update counters */ | 304 | /* update counters */ |
diff --git a/drivers/scsi/qla4xxx/ql4_isr.c b/drivers/scsi/qla4xxx/ql4_isr.c index 799120fcb9be..8025ee16588e 100644 --- a/drivers/scsi/qla4xxx/ql4_isr.c +++ b/drivers/scsi/qla4xxx/ql4_isr.c | |||
| @@ -11,6 +11,98 @@ | |||
| 11 | #include "ql4_inline.h" | 11 | #include "ql4_inline.h" |
| 12 | 12 | ||
| 13 | /** | 13 | /** |
| 14 | * qla4xxx_copy_sense - copy sense data into cmd sense buffer | ||
| 15 | * @ha: Pointer to host adapter structure. | ||
| 16 | * @sts_entry: Pointer to status entry structure. | ||
| 17 | * @srb: Pointer to srb structure. | ||
| 18 | **/ | ||
| 19 | static void qla4xxx_copy_sense(struct scsi_qla_host *ha, | ||
| 20 | struct status_entry *sts_entry, | ||
| 21 | struct srb *srb) | ||
| 22 | { | ||
| 23 | struct scsi_cmnd *cmd = srb->cmd; | ||
| 24 | uint16_t sense_len; | ||
| 25 | |||
| 26 | memset(cmd->sense_buffer, 0, SCSI_SENSE_BUFFERSIZE); | ||
| 27 | sense_len = le16_to_cpu(sts_entry->senseDataByteCnt); | ||
| 28 | if (sense_len == 0) | ||
| 29 | return; | ||
| 30 | |||
| 31 | /* Save total available sense length, | ||
| 32 | * not to exceed cmd's sense buffer size */ | ||
| 33 | sense_len = min_t(uint16_t, sense_len, SCSI_SENSE_BUFFERSIZE); | ||
| 34 | srb->req_sense_ptr = cmd->sense_buffer; | ||
| 35 | srb->req_sense_len = sense_len; | ||
| 36 | |||
| 37 | /* Copy sense from sts_entry pkt */ | ||
| 38 | sense_len = min_t(uint16_t, sense_len, IOCB_MAX_SENSEDATA_LEN); | ||
| 39 | memcpy(cmd->sense_buffer, sts_entry->senseData, sense_len); | ||
| 40 | |||
| 41 | DEBUG2(printk(KERN_INFO "scsi%ld:%d:%d:%d: %s: sense key = %x, " | ||
| 42 | "ASL= %02x, ASC/ASCQ = %02x/%02x\n", ha->host_no, | ||
| 43 | cmd->device->channel, cmd->device->id, | ||
| 44 | cmd->device->lun, __func__, | ||
| 45 | sts_entry->senseData[2] & 0x0f, | ||
| 46 | sts_entry->senseData[7], | ||
| 47 | sts_entry->senseData[12], | ||
| 48 | sts_entry->senseData[13])); | ||
| 49 | |||
| 50 | DEBUG5(qla4xxx_dump_buffer(cmd->sense_buffer, sense_len)); | ||
| 51 | srb->flags |= SRB_GOT_SENSE; | ||
| 52 | |||
| 53 | /* Update srb, in case a sts_cont pkt follows */ | ||
| 54 | srb->req_sense_ptr += sense_len; | ||
| 55 | srb->req_sense_len -= sense_len; | ||
| 56 | if (srb->req_sense_len != 0) | ||
| 57 | ha->status_srb = srb; | ||
| 58 | else | ||
| 59 | ha->status_srb = NULL; | ||
| 60 | } | ||
| 61 | |||
| 62 | /** | ||
| 63 | * qla4xxx_status_cont_entry - Process a Status Continuations entry. | ||
| 64 | * @ha: SCSI driver HA context | ||
| 65 | * @sts_cont: Entry pointer | ||
| 66 | * | ||
| 67 | * Extended sense data. | ||
| 68 | */ | ||
| 69 | static void | ||
| 70 | qla4xxx_status_cont_entry(struct scsi_qla_host *ha, | ||
| 71 | struct status_cont_entry *sts_cont) | ||
| 72 | { | ||
| 73 | struct srb *srb = ha->status_srb; | ||
| 74 | struct scsi_cmnd *cmd; | ||
| 75 | uint8_t sense_len; | ||
| 76 | |||
| 77 | if (srb == NULL) | ||
| 78 | return; | ||
| 79 | |||
| 80 | cmd = srb->cmd; | ||
| 81 | if (cmd == NULL) { | ||
| 82 | DEBUG2(printk(KERN_INFO "scsi%ld: %s: Cmd already returned " | ||
| 83 | "back to OS srb=%p srb->state:%d\n", ha->host_no, | ||
| 84 | __func__, srb, srb->state)); | ||
| 85 | ha->status_srb = NULL; | ||
| 86 | return; | ||
| 87 | } | ||
| 88 | |||
| 89 | /* Copy sense data. */ | ||
| 90 | sense_len = min_t(uint16_t, srb->req_sense_len, | ||
| 91 | IOCB_MAX_EXT_SENSEDATA_LEN); | ||
| 92 | memcpy(srb->req_sense_ptr, sts_cont->ext_sense_data, sense_len); | ||
| 93 | DEBUG5(qla4xxx_dump_buffer(srb->req_sense_ptr, sense_len)); | ||
| 94 | |||
| 95 | srb->req_sense_ptr += sense_len; | ||
| 96 | srb->req_sense_len -= sense_len; | ||
| 97 | |||
| 98 | /* Place command on done queue. */ | ||
| 99 | if (srb->req_sense_len == 0) { | ||
| 100 | qla4xxx_srb_compl(ha, srb); | ||
| 101 | ha->status_srb = NULL; | ||
| 102 | } | ||
| 103 | } | ||
| 104 | |||
| 105 | /** | ||
| 14 | * qla4xxx_status_entry - processes status IOCBs | 106 | * qla4xxx_status_entry - processes status IOCBs |
| 15 | * @ha: Pointer to host adapter structure. | 107 | * @ha: Pointer to host adapter structure. |
| 16 | * @sts_entry: Pointer to status entry structure. | 108 | * @sts_entry: Pointer to status entry structure. |
| @@ -23,7 +115,6 @@ static void qla4xxx_status_entry(struct scsi_qla_host *ha, | |||
| 23 | struct srb *srb; | 115 | struct srb *srb; |
| 24 | struct ddb_entry *ddb_entry; | 116 | struct ddb_entry *ddb_entry; |
| 25 | uint32_t residual; | 117 | uint32_t residual; |
| 26 | uint16_t sensebytecnt; | ||
| 27 | 118 | ||
| 28 | srb = qla4xxx_del_from_active_array(ha, le32_to_cpu(sts_entry->handle)); | 119 | srb = qla4xxx_del_from_active_array(ha, le32_to_cpu(sts_entry->handle)); |
| 29 | if (!srb) { | 120 | if (!srb) { |
| @@ -92,24 +183,7 @@ static void qla4xxx_status_entry(struct scsi_qla_host *ha, | |||
| 92 | break; | 183 | break; |
| 93 | 184 | ||
| 94 | /* Copy Sense Data into sense buffer. */ | 185 | /* Copy Sense Data into sense buffer. */ |
| 95 | memset(cmd->sense_buffer, 0, SCSI_SENSE_BUFFERSIZE); | 186 | qla4xxx_copy_sense(ha, sts_entry, srb); |
| 96 | |||
| 97 | sensebytecnt = le16_to_cpu(sts_entry->senseDataByteCnt); | ||
| 98 | if (sensebytecnt == 0) | ||
| 99 | break; | ||
| 100 | |||
| 101 | memcpy(cmd->sense_buffer, sts_entry->senseData, | ||
| 102 | min_t(uint16_t, sensebytecnt, SCSI_SENSE_BUFFERSIZE)); | ||
| 103 | |||
| 104 | DEBUG2(printk("scsi%ld:%d:%d:%d: %s: sense key = %x, " | ||
| 105 | "ASC/ASCQ = %02x/%02x\n", ha->host_no, | ||
| 106 | cmd->device->channel, cmd->device->id, | ||
| 107 | cmd->device->lun, __func__, | ||
| 108 | sts_entry->senseData[2] & 0x0f, | ||
| 109 | sts_entry->senseData[12], | ||
| 110 | sts_entry->senseData[13])); | ||
| 111 | |||
| 112 | srb->flags |= SRB_GOT_SENSE; | ||
| 113 | break; | 187 | break; |
| 114 | 188 | ||
| 115 | case SCS_INCOMPLETE: | 189 | case SCS_INCOMPLETE: |
| @@ -176,23 +250,7 @@ static void qla4xxx_status_entry(struct scsi_qla_host *ha, | |||
| 176 | break; | 250 | break; |
| 177 | 251 | ||
| 178 | /* Copy Sense Data into sense buffer. */ | 252 | /* Copy Sense Data into sense buffer. */ |
| 179 | memset(cmd->sense_buffer, 0, SCSI_SENSE_BUFFERSIZE); | 253 | qla4xxx_copy_sense(ha, sts_entry, srb); |
| 180 | |||
| 181 | sensebytecnt = | ||
| 182 | le16_to_cpu(sts_entry->senseDataByteCnt); | ||
| 183 | if (sensebytecnt == 0) | ||
| 184 | break; | ||
| 185 | |||
| 186 | memcpy(cmd->sense_buffer, sts_entry->senseData, | ||
| 187 | min_t(uint16_t, sensebytecnt, SCSI_SENSE_BUFFERSIZE)); | ||
| 188 | |||
| 189 | DEBUG2(printk("scsi%ld:%d:%d:%d: %s: sense key = %x, " | ||
| 190 | "ASC/ASCQ = %02x/%02x\n", ha->host_no, | ||
| 191 | cmd->device->channel, cmd->device->id, | ||
| 192 | cmd->device->lun, __func__, | ||
| 193 | sts_entry->senseData[2] & 0x0f, | ||
| 194 | sts_entry->senseData[12], | ||
| 195 | sts_entry->senseData[13])); | ||
| 196 | } else { | 254 | } else { |
| 197 | /* | 255 | /* |
| 198 | * If RISC reports underrun and target does not | 256 | * If RISC reports underrun and target does not |
| @@ -268,9 +326,10 @@ static void qla4xxx_status_entry(struct scsi_qla_host *ha, | |||
| 268 | 326 | ||
| 269 | status_entry_exit: | 327 | status_entry_exit: |
| 270 | 328 | ||
| 271 | /* complete the request */ | 329 | /* complete the request, if not waiting for status_continuation pkt */ |
| 272 | srb->cc_stat = sts_entry->completionStatus; | 330 | srb->cc_stat = sts_entry->completionStatus; |
| 273 | qla4xxx_srb_compl(ha, srb); | 331 | if (ha->status_srb == NULL) |
| 332 | qla4xxx_srb_compl(ha, srb); | ||
| 274 | } | 333 | } |
| 275 | 334 | ||
| 276 | /** | 335 | /** |
| @@ -305,10 +364,7 @@ static void qla4xxx_process_response_queue(struct scsi_qla_host * ha) | |||
| 305 | /* process entry */ | 364 | /* process entry */ |
| 306 | switch (sts_entry->hdr.entryType) { | 365 | switch (sts_entry->hdr.entryType) { |
| 307 | case ET_STATUS: | 366 | case ET_STATUS: |
| 308 | /* | 367 | /* Common status */ |
| 309 | * Common status - Single completion posted in single | ||
| 310 | * IOSB. | ||
| 311 | */ | ||
| 312 | qla4xxx_status_entry(ha, sts_entry); | 368 | qla4xxx_status_entry(ha, sts_entry); |
| 313 | break; | 369 | break; |
| 314 | 370 | ||
| @@ -316,9 +372,8 @@ static void qla4xxx_process_response_queue(struct scsi_qla_host * ha) | |||
| 316 | break; | 372 | break; |
| 317 | 373 | ||
| 318 | case ET_STATUS_CONTINUATION: | 374 | case ET_STATUS_CONTINUATION: |
| 319 | /* Just throw away the status continuation entries */ | 375 | qla4xxx_status_cont_entry(ha, |
| 320 | DEBUG2(printk("scsi%ld: %s: Status Continuation entry " | 376 | (struct status_cont_entry *) sts_entry); |
| 321 | "- ignoring\n", ha->host_no, __func__)); | ||
| 322 | break; | 377 | break; |
| 323 | 378 | ||
| 324 | case ET_COMMAND: | 379 | case ET_COMMAND: |
diff --git a/drivers/scsi/qla4xxx/ql4_mbx.c b/drivers/scsi/qla4xxx/ql4_mbx.c index 051b0f5e8c8e..09d6d4b76f39 100644 --- a/drivers/scsi/qla4xxx/ql4_mbx.c +++ b/drivers/scsi/qla4xxx/ql4_mbx.c | |||
| @@ -385,16 +385,6 @@ int qla4xxx_get_firmware_status(struct scsi_qla_host * ha) | |||
| 385 | mbox_sts[0])); | 385 | mbox_sts[0])); |
| 386 | return QLA_ERROR; | 386 | return QLA_ERROR; |
| 387 | } | 387 | } |
| 388 | |||
| 389 | /* High-water mark of IOCBs */ | ||
| 390 | ha->iocb_hiwat = mbox_sts[2]; | ||
| 391 | if (ha->iocb_hiwat > IOCB_HIWAT_CUSHION) | ||
| 392 | ha->iocb_hiwat -= IOCB_HIWAT_CUSHION; | ||
| 393 | else | ||
| 394 | dev_info(&ha->pdev->dev, "WARNING!!! You have less than %d " | ||
| 395 | "firmware IOCBs available (%d).\n", | ||
| 396 | IOCB_HIWAT_CUSHION, ha->iocb_hiwat); | ||
| 397 | |||
| 398 | return QLA_SUCCESS; | 388 | return QLA_SUCCESS; |
| 399 | } | 389 | } |
| 400 | 390 | ||
diff --git a/drivers/scsi/qla4xxx/ql4_os.c b/drivers/scsi/qla4xxx/ql4_os.c index ec9da6ce8489..40e3cafb3a9c 100644 --- a/drivers/scsi/qla4xxx/ql4_os.c +++ b/drivers/scsi/qla4xxx/ql4_os.c | |||
| @@ -66,6 +66,7 @@ static int qla4xxx_sess_get_param(struct iscsi_cls_session *sess, | |||
| 66 | static int qla4xxx_host_get_param(struct Scsi_Host *shost, | 66 | static int qla4xxx_host_get_param(struct Scsi_Host *shost, |
| 67 | enum iscsi_host_param param, char *buf); | 67 | enum iscsi_host_param param, char *buf); |
| 68 | static void qla4xxx_recovery_timedout(struct iscsi_cls_session *session); | 68 | static void qla4xxx_recovery_timedout(struct iscsi_cls_session *session); |
| 69 | static enum blk_eh_timer_return qla4xxx_eh_cmd_timed_out(struct scsi_cmnd *sc); | ||
| 69 | 70 | ||
| 70 | /* | 71 | /* |
| 71 | * SCSI host template entry points | 72 | * SCSI host template entry points |
| @@ -89,6 +90,7 @@ static struct scsi_host_template qla4xxx_driver_template = { | |||
| 89 | .eh_device_reset_handler = qla4xxx_eh_device_reset, | 90 | .eh_device_reset_handler = qla4xxx_eh_device_reset, |
| 90 | .eh_target_reset_handler = qla4xxx_eh_target_reset, | 91 | .eh_target_reset_handler = qla4xxx_eh_target_reset, |
| 91 | .eh_host_reset_handler = qla4xxx_eh_host_reset, | 92 | .eh_host_reset_handler = qla4xxx_eh_host_reset, |
| 93 | .eh_timed_out = qla4xxx_eh_cmd_timed_out, | ||
| 92 | 94 | ||
| 93 | .slave_configure = qla4xxx_slave_configure, | 95 | .slave_configure = qla4xxx_slave_configure, |
| 94 | .slave_alloc = qla4xxx_slave_alloc, | 96 | .slave_alloc = qla4xxx_slave_alloc, |
| @@ -124,6 +126,21 @@ static struct iscsi_transport qla4xxx_iscsi_transport = { | |||
| 124 | 126 | ||
| 125 | static struct scsi_transport_template *qla4xxx_scsi_transport; | 127 | static struct scsi_transport_template *qla4xxx_scsi_transport; |
| 126 | 128 | ||
| 129 | static enum blk_eh_timer_return qla4xxx_eh_cmd_timed_out(struct scsi_cmnd *sc) | ||
| 130 | { | ||
| 131 | struct iscsi_cls_session *session; | ||
| 132 | struct ddb_entry *ddb_entry; | ||
| 133 | |||
| 134 | session = starget_to_session(scsi_target(sc->device)); | ||
| 135 | ddb_entry = session->dd_data; | ||
| 136 | |||
| 137 | /* if we are not logged in then the LLD is going to clean up the cmd */ | ||
| 138 | if (atomic_read(&ddb_entry->state) != DDB_STATE_ONLINE) | ||
| 139 | return BLK_EH_RESET_TIMER; | ||
| 140 | else | ||
| 141 | return BLK_EH_NOT_HANDLED; | ||
| 142 | } | ||
| 143 | |||
| 127 | static void qla4xxx_recovery_timedout(struct iscsi_cls_session *session) | 144 | static void qla4xxx_recovery_timedout(struct iscsi_cls_session *session) |
| 128 | { | 145 | { |
| 129 | struct ddb_entry *ddb_entry = session->dd_data; | 146 | struct ddb_entry *ddb_entry = session->dd_data; |
| @@ -904,18 +921,17 @@ static int qla4xxx_recover_adapter(struct scsi_qla_host *ha, | |||
| 904 | /* Flush any pending ddb changed AENs */ | 921 | /* Flush any pending ddb changed AENs */ |
| 905 | qla4xxx_process_aen(ha, FLUSH_DDB_CHANGED_AENS); | 922 | qla4xxx_process_aen(ha, FLUSH_DDB_CHANGED_AENS); |
| 906 | 923 | ||
| 924 | qla4xxx_flush_active_srbs(ha); | ||
| 925 | |||
| 907 | /* Reset the firmware. If successful, function | 926 | /* Reset the firmware. If successful, function |
| 908 | * returns with ISP interrupts enabled. | 927 | * returns with ISP interrupts enabled. |
| 909 | */ | 928 | */ |
| 910 | if (status == QLA_SUCCESS) { | 929 | DEBUG2(printk("scsi%ld: %s - Performing soft reset..\n", |
| 911 | DEBUG2(printk("scsi%ld: %s - Performing soft reset..\n", | 930 | ha->host_no, __func__)); |
| 912 | ha->host_no, __func__)); | 931 | if (ql4xxx_lock_drvr_wait(ha) == QLA_SUCCESS) |
| 913 | qla4xxx_flush_active_srbs(ha); | 932 | status = qla4xxx_soft_reset(ha); |
| 914 | if (ql4xxx_lock_drvr_wait(ha) == QLA_SUCCESS) | 933 | else |
| 915 | status = qla4xxx_soft_reset(ha); | 934 | status = QLA_ERROR; |
| 916 | else | ||
| 917 | status = QLA_ERROR; | ||
| 918 | } | ||
| 919 | 935 | ||
| 920 | /* Flush any pending ddb changed AENs */ | 936 | /* Flush any pending ddb changed AENs */ |
| 921 | qla4xxx_process_aen(ha, FLUSH_DDB_CHANGED_AENS); | 937 | qla4xxx_process_aen(ha, FLUSH_DDB_CHANGED_AENS); |
| @@ -1527,11 +1543,9 @@ static int qla4xxx_eh_device_reset(struct scsi_cmnd *cmd) | |||
| 1527 | { | 1543 | { |
| 1528 | struct scsi_qla_host *ha = to_qla_host(cmd->device->host); | 1544 | struct scsi_qla_host *ha = to_qla_host(cmd->device->host); |
| 1529 | struct ddb_entry *ddb_entry = cmd->device->hostdata; | 1545 | struct ddb_entry *ddb_entry = cmd->device->hostdata; |
| 1530 | struct srb *sp; | ||
| 1531 | int ret = FAILED, stat; | 1546 | int ret = FAILED, stat; |
| 1532 | 1547 | ||
| 1533 | sp = (struct srb *) cmd->SCp.ptr; | 1548 | if (!ddb_entry) |
| 1534 | if (!sp || !ddb_entry) | ||
| 1535 | return ret; | 1549 | return ret; |
| 1536 | 1550 | ||
| 1537 | dev_info(&ha->pdev->dev, | 1551 | dev_info(&ha->pdev->dev, |
| @@ -1644,7 +1658,7 @@ static int qla4xxx_eh_host_reset(struct scsi_cmnd *cmd) | |||
| 1644 | ha = (struct scsi_qla_host *) cmd->device->host->hostdata; | 1658 | ha = (struct scsi_qla_host *) cmd->device->host->hostdata; |
| 1645 | 1659 | ||
| 1646 | dev_info(&ha->pdev->dev, | 1660 | dev_info(&ha->pdev->dev, |
| 1647 | "scsi(%ld:%d:%d:%d): ADAPTER RESET ISSUED.\n", ha->host_no, | 1661 | "scsi(%ld:%d:%d:%d): HOST RESET ISSUED.\n", ha->host_no, |
| 1648 | cmd->device->channel, cmd->device->id, cmd->device->lun); | 1662 | cmd->device->channel, cmd->device->id, cmd->device->lun); |
| 1649 | 1663 | ||
| 1650 | if (qla4xxx_wait_for_hba_online(ha) != QLA_SUCCESS) { | 1664 | if (qla4xxx_wait_for_hba_online(ha) != QLA_SUCCESS) { |
diff --git a/drivers/scsi/qla4xxx/ql4_version.h b/drivers/scsi/qla4xxx/ql4_version.h index ab984cb89cea..6980cb279c81 100644 --- a/drivers/scsi/qla4xxx/ql4_version.h +++ b/drivers/scsi/qla4xxx/ql4_version.h | |||
| @@ -5,5 +5,5 @@ | |||
| 5 | * See LICENSE.qla4xxx for copyright and licensing details. | 5 | * See LICENSE.qla4xxx for copyright and licensing details. |
| 6 | */ | 6 | */ |
| 7 | 7 | ||
| 8 | #define QLA4XXX_DRIVER_VERSION "5.01.00-k8" | 8 | #define QLA4XXX_DRIVER_VERSION "5.01.00-k9" |
| 9 | 9 | ||
diff --git a/drivers/scsi/scsi_transport_iscsi.c b/drivers/scsi/scsi_transport_iscsi.c index 783e33c65eb7..b47240ca4b19 100644 --- a/drivers/scsi/scsi_transport_iscsi.c +++ b/drivers/scsi/scsi_transport_iscsi.c | |||
| @@ -990,7 +990,7 @@ int iscsi_offload_mesg(struct Scsi_Host *shost, | |||
| 990 | struct iscsi_uevent *ev; | 990 | struct iscsi_uevent *ev; |
| 991 | int len = NLMSG_SPACE(sizeof(*ev) + data_size); | 991 | int len = NLMSG_SPACE(sizeof(*ev) + data_size); |
| 992 | 992 | ||
| 993 | skb = alloc_skb(len, GFP_NOIO); | 993 | skb = alloc_skb(len, GFP_ATOMIC); |
| 994 | if (!skb) { | 994 | if (!skb) { |
| 995 | printk(KERN_ERR "can not deliver iscsi offload message:OOM\n"); | 995 | printk(KERN_ERR "can not deliver iscsi offload message:OOM\n"); |
| 996 | return -ENOMEM; | 996 | return -ENOMEM; |
| @@ -1012,7 +1012,7 @@ int iscsi_offload_mesg(struct Scsi_Host *shost, | |||
| 1012 | 1012 | ||
| 1013 | memcpy((char *)ev + sizeof(*ev), data, data_size); | 1013 | memcpy((char *)ev + sizeof(*ev), data, data_size); |
| 1014 | 1014 | ||
| 1015 | return iscsi_multicast_skb(skb, ISCSI_NL_GRP_UIP, GFP_NOIO); | 1015 | return iscsi_multicast_skb(skb, ISCSI_NL_GRP_UIP, GFP_ATOMIC); |
| 1016 | } | 1016 | } |
| 1017 | EXPORT_SYMBOL_GPL(iscsi_offload_mesg); | 1017 | EXPORT_SYMBOL_GPL(iscsi_offload_mesg); |
| 1018 | 1018 | ||
diff --git a/drivers/scsi/sd.c b/drivers/scsi/sd.c index 5616cd780ff3..b7b9fec67a98 100644 --- a/drivers/scsi/sd.c +++ b/drivers/scsi/sd.c | |||
| @@ -1840,6 +1840,18 @@ static void sd_read_block_characteristics(struct scsi_disk *sdkp) | |||
| 1840 | kfree(buffer); | 1840 | kfree(buffer); |
| 1841 | } | 1841 | } |
| 1842 | 1842 | ||
| 1843 | static int sd_try_extended_inquiry(struct scsi_device *sdp) | ||
| 1844 | { | ||
| 1845 | /* | ||
| 1846 | * Although VPD inquiries can go to SCSI-2 type devices, | ||
| 1847 | * some USB ones crash on receiving them, and the pages | ||
| 1848 | * we currently ask for are for SPC-3 and beyond | ||
| 1849 | */ | ||
| 1850 | if (sdp->scsi_level > SCSI_SPC_2) | ||
| 1851 | return 1; | ||
| 1852 | return 0; | ||
| 1853 | } | ||
| 1854 | |||
| 1843 | /** | 1855 | /** |
| 1844 | * sd_revalidate_disk - called the first time a new disk is seen, | 1856 | * sd_revalidate_disk - called the first time a new disk is seen, |
| 1845 | * performs disk spin up, read_capacity, etc. | 1857 | * performs disk spin up, read_capacity, etc. |
| @@ -1877,8 +1889,12 @@ static int sd_revalidate_disk(struct gendisk *disk) | |||
| 1877 | */ | 1889 | */ |
| 1878 | if (sdkp->media_present) { | 1890 | if (sdkp->media_present) { |
| 1879 | sd_read_capacity(sdkp, buffer); | 1891 | sd_read_capacity(sdkp, buffer); |
| 1880 | sd_read_block_limits(sdkp); | 1892 | |
| 1881 | sd_read_block_characteristics(sdkp); | 1893 | if (sd_try_extended_inquiry(sdp)) { |
| 1894 | sd_read_block_limits(sdkp); | ||
| 1895 | sd_read_block_characteristics(sdkp); | ||
| 1896 | } | ||
| 1897 | |||
| 1882 | sd_read_write_protect_flag(sdkp, buffer); | 1898 | sd_read_write_protect_flag(sdkp, buffer); |
| 1883 | sd_read_cache_type(sdkp, buffer); | 1899 | sd_read_cache_type(sdkp, buffer); |
| 1884 | sd_read_app_tag_own(sdkp, buffer); | 1900 | sd_read_app_tag_own(sdkp, buffer); |
diff --git a/drivers/serial/Kconfig b/drivers/serial/Kconfig index 037c1e0b7c4c..6553833c12db 100644 --- a/drivers/serial/Kconfig +++ b/drivers/serial/Kconfig | |||
| @@ -527,7 +527,7 @@ config SERIAL_S3C24A0 | |||
| 527 | 527 | ||
| 528 | config SERIAL_S3C6400 | 528 | config SERIAL_S3C6400 |
| 529 | tristate "Samsung S3C6400/S3C6410 Serial port support" | 529 | tristate "Samsung S3C6400/S3C6410 Serial port support" |
| 530 | depends on SERIAL_SAMSUNG && (CPU_S3C600 || CPU_S3C6410) | 530 | depends on SERIAL_SAMSUNG && (CPU_S3C6400 || CPU_S3C6410) |
| 531 | default y | 531 | default y |
| 532 | help | 532 | help |
| 533 | Serial port support for the Samsung S3C6400 and S3C6410 | 533 | Serial port support for the Samsung S3C6400 and S3C6410 |
diff --git a/drivers/serial/atmel_serial.c b/drivers/serial/atmel_serial.c index 338b15c0a548..607d43a31048 100644 --- a/drivers/serial/atmel_serial.c +++ b/drivers/serial/atmel_serial.c | |||
| @@ -1551,6 +1551,7 @@ static int __devinit atmel_serial_probe(struct platform_device *pdev) | |||
| 1551 | if (ret) | 1551 | if (ret) |
| 1552 | goto err_add_port; | 1552 | goto err_add_port; |
| 1553 | 1553 | ||
| 1554 | #ifdef CONFIG_SERIAL_ATMEL_CONSOLE | ||
| 1554 | if (atmel_is_console_port(&port->uart) | 1555 | if (atmel_is_console_port(&port->uart) |
| 1555 | && ATMEL_CONSOLE_DEVICE->flags & CON_ENABLED) { | 1556 | && ATMEL_CONSOLE_DEVICE->flags & CON_ENABLED) { |
| 1556 | /* | 1557 | /* |
| @@ -1559,6 +1560,7 @@ static int __devinit atmel_serial_probe(struct platform_device *pdev) | |||
| 1559 | */ | 1560 | */ |
| 1560 | clk_disable(port->clk); | 1561 | clk_disable(port->clk); |
| 1561 | } | 1562 | } |
| 1563 | #endif | ||
| 1562 | 1564 | ||
| 1563 | device_init_wakeup(&pdev->dev, 1); | 1565 | device_init_wakeup(&pdev->dev, 1); |
| 1564 | platform_set_drvdata(pdev, port); | 1566 | platform_set_drvdata(pdev, port); |
diff --git a/drivers/serial/cpm_uart/cpm_uart_cpm2.c b/drivers/serial/cpm_uart/cpm_uart_cpm2.c index 141c0a3333ad..a9802e76b5fa 100644 --- a/drivers/serial/cpm_uart/cpm_uart_cpm2.c +++ b/drivers/serial/cpm_uart/cpm_uart_cpm2.c | |||
| @@ -132,7 +132,7 @@ int cpm_uart_allocbuf(struct uart_cpm_port *pinfo, unsigned int is_con) | |||
| 132 | memsz = L1_CACHE_ALIGN(pinfo->rx_nrfifos * pinfo->rx_fifosize) + | 132 | memsz = L1_CACHE_ALIGN(pinfo->rx_nrfifos * pinfo->rx_fifosize) + |
| 133 | L1_CACHE_ALIGN(pinfo->tx_nrfifos * pinfo->tx_fifosize); | 133 | L1_CACHE_ALIGN(pinfo->tx_nrfifos * pinfo->tx_fifosize); |
| 134 | if (is_con) { | 134 | if (is_con) { |
| 135 | mem_addr = alloc_bootmem(memsz); | 135 | mem_addr = kzalloc(memsz, GFP_NOWAIT); |
| 136 | dma_addr = virt_to_bus(mem_addr); | 136 | dma_addr = virt_to_bus(mem_addr); |
| 137 | } | 137 | } |
| 138 | else | 138 | else |
diff --git a/drivers/serial/s3c2400.c b/drivers/serial/s3c2400.c index fb00ed5296e6..fed1a9a1ffb4 100644 --- a/drivers/serial/s3c2400.c +++ b/drivers/serial/s3c2400.c | |||
| @@ -76,7 +76,7 @@ static int s3c2400_serial_probe(struct platform_device *dev) | |||
| 76 | return s3c24xx_serial_probe(dev, &s3c2400_uart_inf); | 76 | return s3c24xx_serial_probe(dev, &s3c2400_uart_inf); |
| 77 | } | 77 | } |
| 78 | 78 | ||
| 79 | static struct platform_driver s3c2400_serial_drv = { | 79 | static struct platform_driver s3c2400_serial_driver = { |
| 80 | .probe = s3c2400_serial_probe, | 80 | .probe = s3c2400_serial_probe, |
| 81 | .remove = __devexit_p(s3c24xx_serial_remove), | 81 | .remove = __devexit_p(s3c24xx_serial_remove), |
| 82 | .driver = { | 82 | .driver = { |
| @@ -85,16 +85,16 @@ static struct platform_driver s3c2400_serial_drv = { | |||
| 85 | }, | 85 | }, |
| 86 | }; | 86 | }; |
| 87 | 87 | ||
| 88 | s3c24xx_console_init(&s3c2400_serial_drv, &s3c2400_uart_inf); | 88 | s3c24xx_console_init(&s3c2400_serial_driver, &s3c2400_uart_inf); |
| 89 | 89 | ||
| 90 | static inline int s3c2400_serial_init(void) | 90 | static inline int s3c2400_serial_init(void) |
| 91 | { | 91 | { |
| 92 | return s3c24xx_serial_init(&s3c2400_serial_drv, &s3c2400_uart_inf); | 92 | return s3c24xx_serial_init(&s3c2400_serial_driver, &s3c2400_uart_inf); |
| 93 | } | 93 | } |
| 94 | 94 | ||
| 95 | static inline void s3c2400_serial_exit(void) | 95 | static inline void s3c2400_serial_exit(void) |
| 96 | { | 96 | { |
| 97 | platform_driver_unregister(&s3c2400_serial_drv); | 97 | platform_driver_unregister(&s3c2400_serial_driver); |
| 98 | } | 98 | } |
| 99 | 99 | ||
| 100 | module_init(s3c2400_serial_init); | 100 | module_init(s3c2400_serial_init); |
diff --git a/drivers/serial/s3c2410.c b/drivers/serial/s3c2410.c index b5d7cbcba2ae..c99f0821cae3 100644 --- a/drivers/serial/s3c2410.c +++ b/drivers/serial/s3c2410.c | |||
| @@ -88,7 +88,7 @@ static int s3c2410_serial_probe(struct platform_device *dev) | |||
| 88 | return s3c24xx_serial_probe(dev, &s3c2410_uart_inf); | 88 | return s3c24xx_serial_probe(dev, &s3c2410_uart_inf); |
| 89 | } | 89 | } |
| 90 | 90 | ||
| 91 | static struct platform_driver s3c2410_serial_drv = { | 91 | static struct platform_driver s3c2410_serial_driver = { |
| 92 | .probe = s3c2410_serial_probe, | 92 | .probe = s3c2410_serial_probe, |
| 93 | .remove = __devexit_p(s3c24xx_serial_remove), | 93 | .remove = __devexit_p(s3c24xx_serial_remove), |
| 94 | .driver = { | 94 | .driver = { |
| @@ -97,16 +97,16 @@ static struct platform_driver s3c2410_serial_drv = { | |||
| 97 | }, | 97 | }, |
| 98 | }; | 98 | }; |
| 99 | 99 | ||
| 100 | s3c24xx_console_init(&s3c2410_serial_drv, &s3c2410_uart_inf); | 100 | s3c24xx_console_init(&s3c2410_serial_driver, &s3c2410_uart_inf); |
| 101 | 101 | ||
| 102 | static int __init s3c2410_serial_init(void) | 102 | static int __init s3c2410_serial_init(void) |
| 103 | { | 103 | { |
| 104 | return s3c24xx_serial_init(&s3c2410_serial_drv, &s3c2410_uart_inf); | 104 | return s3c24xx_serial_init(&s3c2410_serial_driver, &s3c2410_uart_inf); |
| 105 | } | 105 | } |
| 106 | 106 | ||
| 107 | static void __exit s3c2410_serial_exit(void) | 107 | static void __exit s3c2410_serial_exit(void) |
| 108 | { | 108 | { |
| 109 | platform_driver_unregister(&s3c2410_serial_drv); | 109 | platform_driver_unregister(&s3c2410_serial_driver); |
| 110 | } | 110 | } |
| 111 | 111 | ||
| 112 | module_init(s3c2410_serial_init); | 112 | module_init(s3c2410_serial_init); |
diff --git a/drivers/serial/s3c2412.c b/drivers/serial/s3c2412.c index 11dcb90bdfef..6e057d8809d3 100644 --- a/drivers/serial/s3c2412.c +++ b/drivers/serial/s3c2412.c | |||
| @@ -121,7 +121,7 @@ static int s3c2412_serial_probe(struct platform_device *dev) | |||
| 121 | return s3c24xx_serial_probe(dev, &s3c2412_uart_inf); | 121 | return s3c24xx_serial_probe(dev, &s3c2412_uart_inf); |
| 122 | } | 122 | } |
| 123 | 123 | ||
| 124 | static struct platform_driver s3c2412_serial_drv = { | 124 | static struct platform_driver s3c2412_serial_driver = { |
| 125 | .probe = s3c2412_serial_probe, | 125 | .probe = s3c2412_serial_probe, |
| 126 | .remove = __devexit_p(s3c24xx_serial_remove), | 126 | .remove = __devexit_p(s3c24xx_serial_remove), |
| 127 | .driver = { | 127 | .driver = { |
| @@ -130,16 +130,16 @@ static struct platform_driver s3c2412_serial_drv = { | |||
| 130 | }, | 130 | }, |
| 131 | }; | 131 | }; |
| 132 | 132 | ||
| 133 | s3c24xx_console_init(&s3c2412_serial_drv, &s3c2412_uart_inf); | 133 | s3c24xx_console_init(&s3c2412_serial_driver, &s3c2412_uart_inf); |
| 134 | 134 | ||
| 135 | static inline int s3c2412_serial_init(void) | 135 | static inline int s3c2412_serial_init(void) |
| 136 | { | 136 | { |
| 137 | return s3c24xx_serial_init(&s3c2412_serial_drv, &s3c2412_uart_inf); | 137 | return s3c24xx_serial_init(&s3c2412_serial_driver, &s3c2412_uart_inf); |
| 138 | } | 138 | } |
| 139 | 139 | ||
| 140 | static inline void s3c2412_serial_exit(void) | 140 | static inline void s3c2412_serial_exit(void) |
| 141 | { | 141 | { |
| 142 | platform_driver_unregister(&s3c2412_serial_drv); | 142 | platform_driver_unregister(&s3c2412_serial_driver); |
| 143 | } | 143 | } |
| 144 | 144 | ||
| 145 | module_init(s3c2412_serial_init); | 145 | module_init(s3c2412_serial_init); |
diff --git a/drivers/serial/s3c2440.c b/drivers/serial/s3c2440.c index 06c5b0cc47a3..69ff5d340f04 100644 --- a/drivers/serial/s3c2440.c +++ b/drivers/serial/s3c2440.c | |||
| @@ -151,7 +151,7 @@ static int s3c2440_serial_probe(struct platform_device *dev) | |||
| 151 | return s3c24xx_serial_probe(dev, &s3c2440_uart_inf); | 151 | return s3c24xx_serial_probe(dev, &s3c2440_uart_inf); |
| 152 | } | 152 | } |
| 153 | 153 | ||
| 154 | static struct platform_driver s3c2440_serial_drv = { | 154 | static struct platform_driver s3c2440_serial_driver = { |
| 155 | .probe = s3c2440_serial_probe, | 155 | .probe = s3c2440_serial_probe, |
| 156 | .remove = __devexit_p(s3c24xx_serial_remove), | 156 | .remove = __devexit_p(s3c24xx_serial_remove), |
| 157 | .driver = { | 157 | .driver = { |
| @@ -160,16 +160,16 @@ static struct platform_driver s3c2440_serial_drv = { | |||
| 160 | }, | 160 | }, |
| 161 | }; | 161 | }; |
| 162 | 162 | ||
| 163 | s3c24xx_console_init(&s3c2440_serial_drv, &s3c2440_uart_inf); | 163 | s3c24xx_console_init(&s3c2440_serial_driver, &s3c2440_uart_inf); |
| 164 | 164 | ||
| 165 | static int __init s3c2440_serial_init(void) | 165 | static int __init s3c2440_serial_init(void) |
| 166 | { | 166 | { |
| 167 | return s3c24xx_serial_init(&s3c2440_serial_drv, &s3c2440_uart_inf); | 167 | return s3c24xx_serial_init(&s3c2440_serial_driver, &s3c2440_uart_inf); |
| 168 | } | 168 | } |
| 169 | 169 | ||
| 170 | static void __exit s3c2440_serial_exit(void) | 170 | static void __exit s3c2440_serial_exit(void) |
| 171 | { | 171 | { |
| 172 | platform_driver_unregister(&s3c2440_serial_drv); | 172 | platform_driver_unregister(&s3c2440_serial_driver); |
| 173 | } | 173 | } |
| 174 | 174 | ||
| 175 | module_init(s3c2440_serial_init); | 175 | module_init(s3c2440_serial_init); |
diff --git a/drivers/serial/s3c24a0.c b/drivers/serial/s3c24a0.c index 786a067d62ac..26c49e18bdd1 100644 --- a/drivers/serial/s3c24a0.c +++ b/drivers/serial/s3c24a0.c | |||
| @@ -92,7 +92,7 @@ static int s3c24a0_serial_probe(struct platform_device *dev) | |||
| 92 | return s3c24xx_serial_probe(dev, &s3c24a0_uart_inf); | 92 | return s3c24xx_serial_probe(dev, &s3c24a0_uart_inf); |
| 93 | } | 93 | } |
| 94 | 94 | ||
| 95 | static struct platform_driver s3c24a0_serial_drv = { | 95 | static struct platform_driver s3c24a0_serial_driver = { |
| 96 | .probe = s3c24a0_serial_probe, | 96 | .probe = s3c24a0_serial_probe, |
| 97 | .remove = __devexit_p(s3c24xx_serial_remove), | 97 | .remove = __devexit_p(s3c24xx_serial_remove), |
| 98 | .driver = { | 98 | .driver = { |
| @@ -101,16 +101,16 @@ static struct platform_driver s3c24a0_serial_drv = { | |||
| 101 | }, | 101 | }, |
| 102 | }; | 102 | }; |
| 103 | 103 | ||
| 104 | s3c24xx_console_init(&s3c24a0_serial_drv, &s3c24a0_uart_inf); | 104 | s3c24xx_console_init(&s3c24a0_serial_driver, &s3c24a0_uart_inf); |
| 105 | 105 | ||
| 106 | static int __init s3c24a0_serial_init(void) | 106 | static int __init s3c24a0_serial_init(void) |
| 107 | { | 107 | { |
| 108 | return s3c24xx_serial_init(&s3c24a0_serial_drv, &s3c24a0_uart_inf); | 108 | return s3c24xx_serial_init(&s3c24a0_serial_driver, &s3c24a0_uart_inf); |
| 109 | } | 109 | } |
| 110 | 110 | ||
| 111 | static void __exit s3c24a0_serial_exit(void) | 111 | static void __exit s3c24a0_serial_exit(void) |
| 112 | { | 112 | { |
| 113 | platform_driver_unregister(&s3c24a0_serial_drv); | 113 | platform_driver_unregister(&s3c24a0_serial_driver); |
| 114 | } | 114 | } |
| 115 | 115 | ||
| 116 | module_init(s3c24a0_serial_init); | 116 | module_init(s3c24a0_serial_init); |
diff --git a/drivers/serial/s3c6400.c b/drivers/serial/s3c6400.c index 48f1a3781f0d..4be92ab50058 100644 --- a/drivers/serial/s3c6400.c +++ b/drivers/serial/s3c6400.c | |||
| @@ -122,7 +122,7 @@ static int s3c6400_serial_probe(struct platform_device *dev) | |||
| 122 | return s3c24xx_serial_probe(dev, &s3c6400_uart_inf); | 122 | return s3c24xx_serial_probe(dev, &s3c6400_uart_inf); |
| 123 | } | 123 | } |
| 124 | 124 | ||
| 125 | static struct platform_driver s3c6400_serial_drv = { | 125 | static struct platform_driver s3c6400_serial_driver = { |
| 126 | .probe = s3c6400_serial_probe, | 126 | .probe = s3c6400_serial_probe, |
| 127 | .remove = __devexit_p(s3c24xx_serial_remove), | 127 | .remove = __devexit_p(s3c24xx_serial_remove), |
| 128 | .driver = { | 128 | .driver = { |
| @@ -131,16 +131,16 @@ static struct platform_driver s3c6400_serial_drv = { | |||
| 131 | }, | 131 | }, |
| 132 | }; | 132 | }; |
| 133 | 133 | ||
| 134 | s3c24xx_console_init(&s3c6400_serial_drv, &s3c6400_uart_inf); | 134 | s3c24xx_console_init(&s3c6400_serial_driver, &s3c6400_uart_inf); |
| 135 | 135 | ||
| 136 | static int __init s3c6400_serial_init(void) | 136 | static int __init s3c6400_serial_init(void) |
| 137 | { | 137 | { |
| 138 | return s3c24xx_serial_init(&s3c6400_serial_drv, &s3c6400_uart_inf); | 138 | return s3c24xx_serial_init(&s3c6400_serial_driver, &s3c6400_uart_inf); |
| 139 | } | 139 | } |
| 140 | 140 | ||
| 141 | static void __exit s3c6400_serial_exit(void) | 141 | static void __exit s3c6400_serial_exit(void) |
| 142 | { | 142 | { |
| 143 | platform_driver_unregister(&s3c6400_serial_drv); | 143 | platform_driver_unregister(&s3c6400_serial_driver); |
| 144 | } | 144 | } |
| 145 | 145 | ||
| 146 | module_init(s3c6400_serial_init); | 146 | module_init(s3c6400_serial_init); |
diff --git a/drivers/serial/serial_ks8695.c b/drivers/serial/serial_ks8695.c index 998e89dc5aaf..e0665630e4da 100644 --- a/drivers/serial/serial_ks8695.c +++ b/drivers/serial/serial_ks8695.c | |||
| @@ -549,7 +549,7 @@ static struct uart_port ks8695uart_ports[SERIAL_KS8695_NR] = { | |||
| 549 | .mapbase = KS8695_UART_VA, | 549 | .mapbase = KS8695_UART_VA, |
| 550 | .iotype = SERIAL_IO_MEM, | 550 | .iotype = SERIAL_IO_MEM, |
| 551 | .irq = KS8695_IRQ_UART_TX, | 551 | .irq = KS8695_IRQ_UART_TX, |
| 552 | .uartclk = CLOCK_TICK_RATE * 16, | 552 | .uartclk = KS8695_CLOCK_RATE * 16, |
| 553 | .fifosize = 16, | 553 | .fifosize = 16, |
| 554 | .ops = &ks8695uart_pops, | 554 | .ops = &ks8695uart_pops, |
| 555 | .flags = ASYNC_BOOT_AUTOCONF, | 555 | .flags = ASYNC_BOOT_AUTOCONF, |
diff --git a/drivers/spi/omap2_mcspi.c b/drivers/spi/omap2_mcspi.c index eee4b6e0af2c..9b80ad36dbba 100644 --- a/drivers/spi/omap2_mcspi.c +++ b/drivers/spi/omap2_mcspi.c | |||
| @@ -59,6 +59,8 @@ | |||
| 59 | 59 | ||
| 60 | /* per-register bitmasks: */ | 60 | /* per-register bitmasks: */ |
| 61 | 61 | ||
| 62 | #define OMAP2_MCSPI_SYSCONFIG_SMARTIDLE (2 << 3) | ||
| 63 | #define OMAP2_MCSPI_SYSCONFIG_ENAWAKEUP (1 << 2) | ||
| 62 | #define OMAP2_MCSPI_SYSCONFIG_AUTOIDLE (1 << 0) | 64 | #define OMAP2_MCSPI_SYSCONFIG_AUTOIDLE (1 << 0) |
| 63 | #define OMAP2_MCSPI_SYSCONFIG_SOFTRESET (1 << 1) | 65 | #define OMAP2_MCSPI_SYSCONFIG_SOFTRESET (1 << 1) |
| 64 | 66 | ||
| @@ -90,6 +92,7 @@ | |||
| 90 | 92 | ||
| 91 | #define OMAP2_MCSPI_CHCTRL_EN (1 << 0) | 93 | #define OMAP2_MCSPI_CHCTRL_EN (1 << 0) |
| 92 | 94 | ||
| 95 | #define OMAP2_MCSPI_WAKEUPENABLE_WKEN (1 << 0) | ||
| 93 | 96 | ||
| 94 | /* We have 2 DMA channels per CS, one for RX and one for TX */ | 97 | /* We have 2 DMA channels per CS, one for RX and one for TX */ |
| 95 | struct omap2_mcspi_dma { | 98 | struct omap2_mcspi_dma { |
| @@ -269,7 +272,7 @@ omap2_mcspi_txrx_dma(struct spi_device *spi, struct spi_transfer *xfer) | |||
| 269 | 272 | ||
| 270 | if (rx != NULL) { | 273 | if (rx != NULL) { |
| 271 | omap_set_dma_transfer_params(mcspi_dma->dma_rx_channel, | 274 | omap_set_dma_transfer_params(mcspi_dma->dma_rx_channel, |
| 272 | data_type, element_count, 1, | 275 | data_type, element_count - 1, 1, |
| 273 | OMAP_DMA_SYNC_ELEMENT, | 276 | OMAP_DMA_SYNC_ELEMENT, |
| 274 | mcspi_dma->dma_rx_sync_dev, 1); | 277 | mcspi_dma->dma_rx_sync_dev, 1); |
| 275 | 278 | ||
| @@ -300,6 +303,25 @@ omap2_mcspi_txrx_dma(struct spi_device *spi, struct spi_transfer *xfer) | |||
| 300 | if (rx != NULL) { | 303 | if (rx != NULL) { |
| 301 | wait_for_completion(&mcspi_dma->dma_rx_completion); | 304 | wait_for_completion(&mcspi_dma->dma_rx_completion); |
| 302 | dma_unmap_single(NULL, xfer->rx_dma, count, DMA_FROM_DEVICE); | 305 | dma_unmap_single(NULL, xfer->rx_dma, count, DMA_FROM_DEVICE); |
| 306 | omap2_mcspi_set_enable(spi, 0); | ||
| 307 | if (likely(mcspi_read_cs_reg(spi, OMAP2_MCSPI_CHSTAT0) | ||
| 308 | & OMAP2_MCSPI_CHSTAT_RXS)) { | ||
| 309 | u32 w; | ||
| 310 | |||
| 311 | w = mcspi_read_cs_reg(spi, OMAP2_MCSPI_RX0); | ||
| 312 | if (word_len <= 8) | ||
| 313 | ((u8 *)xfer->rx_buf)[element_count - 1] = w; | ||
| 314 | else if (word_len <= 16) | ||
| 315 | ((u16 *)xfer->rx_buf)[element_count - 1] = w; | ||
| 316 | else /* word_len <= 32 */ | ||
| 317 | ((u32 *)xfer->rx_buf)[element_count - 1] = w; | ||
| 318 | } else { | ||
| 319 | dev_err(&spi->dev, "DMA RX last word empty"); | ||
| 320 | count -= (word_len <= 8) ? 1 : | ||
| 321 | (word_len <= 16) ? 2 : | ||
| 322 | /* word_len <= 32 */ 4; | ||
| 323 | } | ||
| 324 | omap2_mcspi_set_enable(spi, 1); | ||
| 303 | } | 325 | } |
| 304 | return count; | 326 | return count; |
| 305 | } | 327 | } |
| @@ -873,8 +895,12 @@ static int __init omap2_mcspi_reset(struct omap2_mcspi *mcspi) | |||
| 873 | } while (!(tmp & OMAP2_MCSPI_SYSSTATUS_RESETDONE)); | 895 | } while (!(tmp & OMAP2_MCSPI_SYSSTATUS_RESETDONE)); |
| 874 | 896 | ||
| 875 | mcspi_write_reg(master, OMAP2_MCSPI_SYSCONFIG, | 897 | mcspi_write_reg(master, OMAP2_MCSPI_SYSCONFIG, |
| 876 | /* (3 << 8) | (2 << 3) | */ | 898 | OMAP2_MCSPI_SYSCONFIG_AUTOIDLE | |
| 877 | OMAP2_MCSPI_SYSCONFIG_AUTOIDLE); | 899 | OMAP2_MCSPI_SYSCONFIG_ENAWAKEUP | |
| 900 | OMAP2_MCSPI_SYSCONFIG_SMARTIDLE); | ||
| 901 | |||
| 902 | mcspi_write_reg(master, OMAP2_MCSPI_WAKEUPENABLE, | ||
| 903 | OMAP2_MCSPI_WAKEUPENABLE_WKEN); | ||
| 878 | 904 | ||
| 879 | omap2_mcspi_set_master_mode(master); | 905 | omap2_mcspi_set_master_mode(master); |
| 880 | 906 | ||
diff --git a/drivers/spi/spi_s3c24xx.c b/drivers/spi/spi_s3c24xx.c index e0d44af4745a..3f3119d760db 100644 --- a/drivers/spi/spi_s3c24xx.c +++ b/drivers/spi/spi_s3c24xx.c | |||
| @@ -111,29 +111,32 @@ static int s3c24xx_spi_setupxfer(struct spi_device *spi, | |||
| 111 | unsigned int bpw; | 111 | unsigned int bpw; |
| 112 | unsigned int hz; | 112 | unsigned int hz; |
| 113 | unsigned int div; | 113 | unsigned int div; |
| 114 | unsigned long clk; | ||
| 114 | 115 | ||
| 115 | bpw = t ? t->bits_per_word : spi->bits_per_word; | 116 | bpw = t ? t->bits_per_word : spi->bits_per_word; |
| 116 | hz = t ? t->speed_hz : spi->max_speed_hz; | 117 | hz = t ? t->speed_hz : spi->max_speed_hz; |
| 117 | 118 | ||
| 119 | if (!bpw) | ||
| 120 | bpw = 8; | ||
| 121 | |||
| 122 | if (!hz) | ||
| 123 | hz = spi->max_speed_hz; | ||
| 124 | |||
| 118 | if (bpw != 8) { | 125 | if (bpw != 8) { |
| 119 | dev_err(&spi->dev, "invalid bits-per-word (%d)\n", bpw); | 126 | dev_err(&spi->dev, "invalid bits-per-word (%d)\n", bpw); |
| 120 | return -EINVAL; | 127 | return -EINVAL; |
| 121 | } | 128 | } |
| 122 | 129 | ||
| 123 | div = clk_get_rate(hw->clk) / hz; | 130 | clk = clk_get_rate(hw->clk); |
| 124 | 131 | div = DIV_ROUND_UP(clk, hz * 2) - 1; | |
| 125 | /* is clk = pclk / (2 * (pre+1)), or is it | ||
| 126 | * clk = (pclk * 2) / ( pre + 1) */ | ||
| 127 | |||
| 128 | div /= 2; | ||
| 129 | |||
| 130 | if (div > 0) | ||
| 131 | div -= 1; | ||
| 132 | 132 | ||
| 133 | if (div > 255) | 133 | if (div > 255) |
| 134 | div = 255; | 134 | div = 255; |
| 135 | 135 | ||
| 136 | dev_dbg(&spi->dev, "setting pre-scaler to %d (hz %d)\n", div, hz); | 136 | dev_dbg(&spi->dev, "setting pre-scaler to %d (wanted %d, got %ld)\n", |
| 137 | div, hz, clk / (2 * (div + 1))); | ||
| 138 | |||
| 139 | |||
| 137 | writeb(div, hw->regs + S3C2410_SPPRE); | 140 | writeb(div, hw->regs + S3C2410_SPPRE); |
| 138 | 141 | ||
| 139 | spin_lock(&hw->bitbang.lock); | 142 | spin_lock(&hw->bitbang.lock); |
diff --git a/drivers/staging/Kconfig b/drivers/staging/Kconfig index 348bf61a8fec..975ecddbce30 100644 --- a/drivers/staging/Kconfig +++ b/drivers/staging/Kconfig | |||
| @@ -103,8 +103,6 @@ source "drivers/staging/pohmelfs/Kconfig" | |||
| 103 | 103 | ||
| 104 | source "drivers/staging/stlc45xx/Kconfig" | 104 | source "drivers/staging/stlc45xx/Kconfig" |
| 105 | 105 | ||
| 106 | source "drivers/staging/uc2322/Kconfig" | ||
| 107 | |||
| 108 | source "drivers/staging/b3dfg/Kconfig" | 106 | source "drivers/staging/b3dfg/Kconfig" |
| 109 | 107 | ||
| 110 | source "drivers/staging/phison/Kconfig" | 108 | source "drivers/staging/phison/Kconfig" |
diff --git a/drivers/staging/Makefile b/drivers/staging/Makefile index 8d61d7b4debf..2241ae1b21ee 100644 --- a/drivers/staging/Makefile +++ b/drivers/staging/Makefile | |||
| @@ -34,7 +34,6 @@ obj-$(CONFIG_ANDROID) += android/ | |||
| 34 | obj-$(CONFIG_DST) += dst/ | 34 | obj-$(CONFIG_DST) += dst/ |
| 35 | obj-$(CONFIG_POHMELFS) += pohmelfs/ | 35 | obj-$(CONFIG_POHMELFS) += pohmelfs/ |
| 36 | obj-$(CONFIG_STLC45XX) += stlc45xx/ | 36 | obj-$(CONFIG_STLC45XX) += stlc45xx/ |
| 37 | obj-$(CONFIG_USB_SERIAL_ATEN2011) += uc2322/ | ||
| 38 | obj-$(CONFIG_B3DFG) += b3dfg/ | 37 | obj-$(CONFIG_B3DFG) += b3dfg/ |
| 39 | obj-$(CONFIG_IDE_PHISON) += phison/ | 38 | obj-$(CONFIG_IDE_PHISON) += phison/ |
| 40 | obj-$(CONFIG_PLAN9AUTH) += p9auth/ | 39 | obj-$(CONFIG_PLAN9AUTH) += p9auth/ |
diff --git a/drivers/staging/android/lowmemorykiller.c b/drivers/staging/android/lowmemorykiller.c index fe72240f5a9e..f934393f3959 100644 --- a/drivers/staging/android/lowmemorykiller.c +++ b/drivers/staging/android/lowmemorykiller.c | |||
| @@ -96,19 +96,21 @@ static int lowmem_shrink(int nr_to_scan, gfp_t gfp_mask) | |||
| 96 | 96 | ||
| 97 | read_lock(&tasklist_lock); | 97 | read_lock(&tasklist_lock); |
| 98 | for_each_process(p) { | 98 | for_each_process(p) { |
| 99 | struct mm_struct *mm; | ||
| 99 | int oom_adj; | 100 | int oom_adj; |
| 100 | 101 | ||
| 101 | task_lock(p); | 102 | task_lock(p); |
| 102 | if (!p->mm) { | 103 | mm = p->mm; |
| 104 | if (!mm) { | ||
| 103 | task_unlock(p); | 105 | task_unlock(p); |
| 104 | continue; | 106 | continue; |
| 105 | } | 107 | } |
| 106 | oom_adj = p->oomkilladj; | 108 | oom_adj = mm->oom_adj; |
| 107 | if (oom_adj < min_adj) { | 109 | if (oom_adj < min_adj) { |
| 108 | task_unlock(p); | 110 | task_unlock(p); |
| 109 | continue; | 111 | continue; |
| 110 | } | 112 | } |
| 111 | tasksize = get_mm_rss(p->mm); | 113 | tasksize = get_mm_rss(mm); |
| 112 | task_unlock(p); | 114 | task_unlock(p); |
| 113 | if (tasksize <= 0) | 115 | if (tasksize <= 0) |
| 114 | continue; | 116 | continue; |
diff --git a/drivers/staging/b3dfg/Kconfig b/drivers/staging/b3dfg/Kconfig index 524231047de5..9e6573cf97d3 100644 --- a/drivers/staging/b3dfg/Kconfig +++ b/drivers/staging/b3dfg/Kconfig | |||
| @@ -1,5 +1,6 @@ | |||
| 1 | config B3DFG | 1 | config B3DFG |
| 2 | tristate "Brontes 3d Frame Framegrabber" | 2 | tristate "Brontes 3d Frame Framegrabber" |
| 3 | depends on PCI | ||
| 3 | default n | 4 | default n |
| 4 | ---help--- | 5 | ---help--- |
| 5 | This driver provides support for the Brontes 3d Framegrabber | 6 | This driver provides support for the Brontes 3d Framegrabber |
diff --git a/drivers/staging/heci/Kconfig b/drivers/staging/heci/Kconfig index ae8d588d3a27..c7206f8bcd93 100644 --- a/drivers/staging/heci/Kconfig +++ b/drivers/staging/heci/Kconfig | |||
| @@ -1,5 +1,6 @@ | |||
| 1 | config HECI | 1 | config HECI |
| 2 | tristate "Intel Management Engine Interface (MEI) Support" | 2 | tristate "Intel Management Engine Interface (MEI) Support" |
| 3 | depends on PCI | ||
| 3 | ---help--- | 4 | ---help--- |
| 4 | The Intel Management Engine Interface (Intel MEI) driver allows | 5 | The Intel Management Engine Interface (Intel MEI) driver allows |
| 5 | applications to access the Active Management Technology | 6 | applications to access the Active Management Technology |
diff --git a/drivers/staging/rspiusb/rspiusb.c b/drivers/staging/rspiusb/rspiusb.c index 2f8155c1968b..04e2f92c0f62 100644 --- a/drivers/staging/rspiusb/rspiusb.c +++ b/drivers/staging/rspiusb/rspiusb.c | |||
| @@ -716,6 +716,8 @@ static int MapUserBuffer(struct ioctl_struct *io, struct device_extension *pdx) | |||
| 716 | pdx->PixelUrb[frameInfo][i]->transfer_flags = | 716 | pdx->PixelUrb[frameInfo][i]->transfer_flags = |
| 717 | URB_NO_TRANSFER_DMA_MAP | URB_NO_INTERRUPT; | 717 | URB_NO_TRANSFER_DMA_MAP | URB_NO_INTERRUPT; |
| 718 | } | 718 | } |
| 719 | if (i == 0) | ||
| 720 | return -EINVAL; | ||
| 719 | /* only interrupt when last URB completes */ | 721 | /* only interrupt when last URB completes */ |
| 720 | pdx->PixelUrb[frameInfo][--i]->transfer_flags &= ~URB_NO_INTERRUPT; | 722 | pdx->PixelUrb[frameInfo][--i]->transfer_flags &= ~URB_NO_INTERRUPT; |
| 721 | pdx->pendedPixelUrbs[frameInfo] = | 723 | pdx->pendedPixelUrbs[frameInfo] = |
diff --git a/drivers/staging/rt2860/rt_linux.h b/drivers/staging/rt2860/rt_linux.h index 85175c182432..25b53ac3f820 100644 --- a/drivers/staging/rt2860/rt_linux.h +++ b/drivers/staging/rt2860/rt_linux.h | |||
| @@ -43,9 +43,6 @@ | |||
| 43 | #include "rtmp_type.h" | 43 | #include "rtmp_type.h" |
| 44 | #include <linux/module.h> | 44 | #include <linux/module.h> |
| 45 | #include <linux/kernel.h> | 45 | #include <linux/kernel.h> |
| 46 | #if !defined(RT2860) && !defined(RT30xx) | ||
| 47 | #include <linux/kthread.h> | ||
| 48 | #endif | ||
| 49 | 46 | ||
| 50 | #include <linux/spinlock.h> | 47 | #include <linux/spinlock.h> |
| 51 | #include <linux/init.h> | 48 | #include <linux/init.h> |
| @@ -166,9 +163,7 @@ typedef int (*HARD_START_XMIT_FUNC)(struct sk_buff *skb, struct net_device *net_ | |||
| 166 | 163 | ||
| 167 | #ifndef RT30xx | 164 | #ifndef RT30xx |
| 168 | typedef struct pid * THREAD_PID; | 165 | typedef struct pid * THREAD_PID; |
| 169 | #ifdef RT2860 | ||
| 170 | #define THREAD_PID_INIT_VALUE NULL | 166 | #define THREAD_PID_INIT_VALUE NULL |
| 171 | #endif | ||
| 172 | #define GET_PID(_v) find_get_pid(_v) | 167 | #define GET_PID(_v) find_get_pid(_v) |
| 173 | #define GET_PID_NUMBER(_v) pid_nr(_v) | 168 | #define GET_PID_NUMBER(_v) pid_nr(_v) |
| 174 | #define CHECK_PID_LEGALITY(_pid) if (pid_nr(_pid) >= 0) | 169 | #define CHECK_PID_LEGALITY(_pid) if (pid_nr(_pid) >= 0) |
| @@ -188,12 +183,12 @@ struct os_cookie { | |||
| 188 | dma_addr_t pAd_pa; | 183 | dma_addr_t pAd_pa; |
| 189 | #endif | 184 | #endif |
| 190 | #ifdef RT2870 | 185 | #ifdef RT2870 |
| 191 | struct usb_device *pUsb_Dev; | 186 | struct usb_device *pUsb_Dev; |
| 192 | 187 | ||
| 193 | #ifndef RT30xx | 188 | #ifndef RT30xx |
| 194 | struct task_struct *MLMEThr_task; | 189 | THREAD_PID MLMEThr_pid; |
| 195 | struct task_struct *RTUSBCmdThr_task; | 190 | THREAD_PID RTUSBCmdThr_pid; |
| 196 | struct task_struct *TimerQThr_task; | 191 | THREAD_PID TimerQThr_pid; |
| 197 | #endif | 192 | #endif |
| 198 | #ifdef RT30xx | 193 | #ifdef RT30xx |
| 199 | struct pid *MLMEThr_pid; | 194 | struct pid *MLMEThr_pid; |
diff --git a/drivers/staging/rt2870/2870_main_dev.c b/drivers/staging/rt2870/2870_main_dev.c index dd01c64fbf61..a4e8696ca39c 100644 --- a/drivers/staging/rt2870/2870_main_dev.c +++ b/drivers/staging/rt2870/2870_main_dev.c | |||
| @@ -235,7 +235,7 @@ INT MlmeThread( | |||
| 235 | DBGPRINT(RT_DEBUG_TRACE,( "<---%s\n",__func__)); | 235 | DBGPRINT(RT_DEBUG_TRACE,( "<---%s\n",__func__)); |
| 236 | 236 | ||
| 237 | #ifndef RT30xx | 237 | #ifndef RT30xx |
| 238 | pObj->MLMEThr_task = NULL; | 238 | pObj->MLMEThr_pid = THREAD_PID_INIT_VALUE; |
| 239 | #endif | 239 | #endif |
| 240 | #ifdef RT30xx | 240 | #ifdef RT30xx |
| 241 | pObj->MLMEThr_pid = NULL; | 241 | pObj->MLMEThr_pid = NULL; |
| @@ -348,7 +348,7 @@ INT RTUSBCmdThread( | |||
| 348 | DBGPRINT(RT_DEBUG_TRACE,( "<---RTUSBCmdThread\n")); | 348 | DBGPRINT(RT_DEBUG_TRACE,( "<---RTUSBCmdThread\n")); |
| 349 | 349 | ||
| 350 | #ifndef RT30xx | 350 | #ifndef RT30xx |
| 351 | pObj->RTUSBCmdThr_task = NULL; | 351 | pObj->RTUSBCmdThr_pid = THREAD_PID_INIT_VALUE; |
| 352 | #endif | 352 | #endif |
| 353 | #ifdef RT30xx | 353 | #ifdef RT30xx |
| 354 | pObj->RTUSBCmdThr_pid = NULL; | 354 | pObj->RTUSBCmdThr_pid = NULL; |
| @@ -447,7 +447,7 @@ INT TimerQThread( | |||
| 447 | DBGPRINT(RT_DEBUG_TRACE,( "<---%s\n",__func__)); | 447 | DBGPRINT(RT_DEBUG_TRACE,( "<---%s\n",__func__)); |
| 448 | 448 | ||
| 449 | #ifndef RT30xx | 449 | #ifndef RT30xx |
| 450 | pObj->TimerQThr_task = NULL; | 450 | pObj->TimerQThr_pid = THREAD_PID_INIT_VALUE; |
| 451 | #endif | 451 | #endif |
| 452 | #ifdef RT30xx | 452 | #ifdef RT30xx |
| 453 | pObj->TimerQThr_pid = NULL; | 453 | pObj->TimerQThr_pid = NULL; |
| @@ -883,46 +883,69 @@ VOID RT28xxThreadTerminate( | |||
| 883 | 883 | ||
| 884 | // Terminate Threads | 884 | // Terminate Threads |
| 885 | #ifndef RT30xx | 885 | #ifndef RT30xx |
| 886 | BUG_ON(pObj->TimerQThr_task == NULL); | 886 | CHECK_PID_LEGALITY(pObj->TimerQThr_pid) |
| 887 | CHECK_PID_LEGALITY(task_pid(pObj->TimerQThr_task)) | ||
| 888 | { | 887 | { |
| 889 | POS_COOKIE pObj = (POS_COOKIE)pAd->OS_Cookie; | 888 | POS_COOKIE pObj = (POS_COOKIE)pAd->OS_Cookie; |
| 890 | 889 | ||
| 891 | printk(KERN_DEBUG "Terminate the TimerQThr pid=%d!\n", | 890 | printk("Terminate the TimerQThr_pid=%d!\n", GET_PID_NUMBER(pObj->TimerQThr_pid)); |
| 892 | pid_nr(task_pid(pObj->TimerQThr_task))); | ||
| 893 | mb(); | 891 | mb(); |
| 894 | pAd->TimerFunc_kill = 1; | 892 | pAd->TimerFunc_kill = 1; |
| 895 | mb(); | 893 | mb(); |
| 896 | kthread_stop(pObj->TimerQThr_task); | 894 | ret = KILL_THREAD_PID(pObj->TimerQThr_pid, SIGTERM, 1); |
| 897 | pObj->TimerQThr_task = NULL; | 895 | if (ret) |
| 896 | { | ||
| 897 | printk(KERN_WARNING "%s: unable to stop TimerQThread, pid=%d, ret=%d!\n", | ||
| 898 | pAd->net_dev->name, GET_PID_NUMBER(pObj->TimerQThr_pid), ret); | ||
| 899 | } | ||
| 900 | else | ||
| 901 | { | ||
| 902 | wait_for_completion(&pAd->TimerQComplete); | ||
| 903 | pObj->TimerQThr_pid = THREAD_PID_INIT_VALUE; | ||
| 904 | } | ||
| 898 | } | 905 | } |
| 899 | 906 | ||
| 900 | BUG_ON(pObj->MLMEThr_task == NULL); | 907 | CHECK_PID_LEGALITY(pObj->MLMEThr_pid) |
| 901 | CHECK_PID_LEGALITY(task_pid(pObj->MLMEThr_task)) | ||
| 902 | { | 908 | { |
| 903 | printk(KERN_DEBUG "Terminate the MLMEThr pid=%d!\n", | 909 | printk("Terminate the MLMEThr_pid=%d!\n", GET_PID_NUMBER(pObj->MLMEThr_pid)); |
| 904 | pid_nr(task_pid(pObj->MLMEThr_task))); | ||
| 905 | mb(); | 910 | mb(); |
| 906 | pAd->mlme_kill = 1; | 911 | pAd->mlme_kill = 1; |
| 907 | //RT28XX_MLME_HANDLER(pAd); | 912 | //RT28XX_MLME_HANDLER(pAd); |
| 908 | mb(); | 913 | mb(); |
| 909 | kthread_stop(pObj->MLMEThr_task); | 914 | ret = KILL_THREAD_PID(pObj->MLMEThr_pid, SIGTERM, 1); |
| 910 | pObj->MLMEThr_task = NULL; | 915 | if (ret) |
| 916 | { | ||
| 917 | printk (KERN_WARNING "%s: unable to Mlme thread, pid=%d, ret=%d!\n", | ||
| 918 | pAd->net_dev->name, GET_PID_NUMBER(pObj->MLMEThr_pid), ret); | ||
| 919 | } | ||
| 920 | else | ||
| 921 | { | ||
| 922 | //wait_for_completion (&pAd->notify); | ||
| 923 | wait_for_completion (&pAd->mlmeComplete); | ||
| 924 | pObj->MLMEThr_pid = THREAD_PID_INIT_VALUE; | ||
| 925 | } | ||
| 911 | } | 926 | } |
| 912 | 927 | ||
| 913 | BUG_ON(pObj->RTUSBCmdThr_task == NULL); | 928 | CHECK_PID_LEGALITY(pObj->RTUSBCmdThr_pid) |
| 914 | CHECK_PID_LEGALITY(task_pid(pObj->RTUSBCmdThr_task)) | ||
| 915 | { | 929 | { |
| 916 | printk(KERN_DEBUG "Terminate the RTUSBCmdThr pid=%d!\n", | 930 | printk("Terminate the RTUSBCmdThr_pid=%d!\n", GET_PID_NUMBER(pObj->RTUSBCmdThr_pid)); |
| 917 | pid_nr(task_pid(pObj->RTUSBCmdThr_task))); | ||
| 918 | mb(); | 931 | mb(); |
| 919 | NdisAcquireSpinLock(&pAd->CmdQLock); | 932 | NdisAcquireSpinLock(&pAd->CmdQLock); |
| 920 | pAd->CmdQ.CmdQState = RT2870_THREAD_STOPED; | 933 | pAd->CmdQ.CmdQState = RT2870_THREAD_STOPED; |
| 921 | NdisReleaseSpinLock(&pAd->CmdQLock); | 934 | NdisReleaseSpinLock(&pAd->CmdQLock); |
| 922 | mb(); | 935 | mb(); |
| 923 | //RTUSBCMDUp(pAd); | 936 | //RTUSBCMDUp(pAd); |
| 924 | kthread_stop(pObj->RTUSBCmdThr_task); | 937 | ret = KILL_THREAD_PID(pObj->RTUSBCmdThr_pid, SIGTERM, 1); |
| 925 | pObj->RTUSBCmdThr_task = NULL; | 938 | if (ret) |
| 939 | { | ||
| 940 | printk(KERN_WARNING "%s: unable to RTUSBCmd thread, pid=%d, ret=%d!\n", | ||
| 941 | pAd->net_dev->name, GET_PID_NUMBER(pObj->RTUSBCmdThr_pid), ret); | ||
| 942 | } | ||
| 943 | else | ||
| 944 | { | ||
| 945 | //wait_for_completion (&pAd->notify); | ||
| 946 | wait_for_completion (&pAd->CmdQComplete); | ||
| 947 | pObj->RTUSBCmdThr_pid = THREAD_PID_INIT_VALUE; | ||
| 948 | } | ||
| 926 | } | 949 | } |
| 927 | #endif | 950 | #endif |
| 928 | #ifdef RT30xx | 951 | #ifdef RT30xx |
| @@ -1045,7 +1068,7 @@ BOOLEAN RT28XXChipsetCheck( | |||
| 1045 | dev_p->descriptor.idProduct == rtusb_usb_id[i].idProduct) | 1068 | dev_p->descriptor.idProduct == rtusb_usb_id[i].idProduct) |
| 1046 | { | 1069 | { |
| 1047 | #ifndef RT30xx | 1070 | #ifndef RT30xx |
| 1048 | printk(KERN_DEBUG "rt2870: idVendor = 0x%x, idProduct = 0x%x\n", | 1071 | printk("rt2870: idVendor = 0x%x, idProduct = 0x%x\n", |
| 1049 | #endif | 1072 | #endif |
| 1050 | #ifdef RT30xx | 1073 | #ifdef RT30xx |
| 1051 | printk("rt2870: idVendor = 0x%x, idProduct = 0x%x\n", | 1074 | printk("rt2870: idVendor = 0x%x, idProduct = 0x%x\n", |
diff --git a/drivers/staging/rt2870/common/2870_rtmp_init.c b/drivers/staging/rt2870/common/2870_rtmp_init.c index 0f4c8af97e47..80909e9ab5ae 100644 --- a/drivers/staging/rt2870/common/2870_rtmp_init.c +++ b/drivers/staging/rt2870/common/2870_rtmp_init.c | |||
| @@ -700,8 +700,8 @@ NDIS_STATUS AdapterBlockAllocateMemory( | |||
| 700 | usb_dev = pObj->pUsb_Dev; | 700 | usb_dev = pObj->pUsb_Dev; |
| 701 | 701 | ||
| 702 | #ifndef RT30xx | 702 | #ifndef RT30xx |
| 703 | pObj->MLMEThr_task = NULL; | 703 | pObj->MLMEThr_pid = THREAD_PID_INIT_VALUE; |
| 704 | pObj->RTUSBCmdThr_task = NULL; | 704 | pObj->RTUSBCmdThr_pid = THREAD_PID_INIT_VALUE; |
| 705 | #endif | 705 | #endif |
| 706 | #ifdef RT30xx | 706 | #ifdef RT30xx |
| 707 | pObj->MLMEThr_pid = NULL; | 707 | pObj->MLMEThr_pid = NULL; |
| @@ -743,7 +743,7 @@ NDIS_STATUS CreateThreads( | |||
| 743 | PRTMP_ADAPTER pAd = net_dev->ml_priv; | 743 | PRTMP_ADAPTER pAd = net_dev->ml_priv; |
| 744 | POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie; | 744 | POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie; |
| 745 | #ifndef RT30xx | 745 | #ifndef RT30xx |
| 746 | struct task_struct *tsk; | 746 | pid_t pid_number = -1; |
| 747 | #endif | 747 | #endif |
| 748 | #ifdef RT30xx | 748 | #ifdef RT30xx |
| 749 | pid_t pid_number; | 749 | pid_t pid_number; |
| @@ -762,10 +762,10 @@ NDIS_STATUS CreateThreads( | |||
| 762 | 762 | ||
| 763 | // Creat MLME Thread | 763 | // Creat MLME Thread |
| 764 | #ifndef RT30xx | 764 | #ifndef RT30xx |
| 765 | pObj->MLMEThr_task = NULL; | 765 | pObj->MLMEThr_pid= THREAD_PID_INIT_VALUE; |
| 766 | tsk = kthread_run(MlmeThread, pAd, "%s", pAd->net_dev->name); | 766 | pid_number = kernel_thread(MlmeThread, pAd, CLONE_VM); |
| 767 | 767 | if (pid_number < 0) | |
| 768 | if (IS_ERR(tsk)) { | 768 | { |
| 769 | #endif | 769 | #endif |
| 770 | #ifdef RT30xx | 770 | #ifdef RT30xx |
| 771 | pObj->MLMEThr_pid = NULL; | 771 | pObj->MLMEThr_pid = NULL; |
| @@ -778,7 +778,7 @@ NDIS_STATUS CreateThreads( | |||
| 778 | } | 778 | } |
| 779 | 779 | ||
| 780 | #ifndef RT30xx | 780 | #ifndef RT30xx |
| 781 | pObj->MLMEThr_task = tsk; | 781 | pObj->MLMEThr_pid = GET_PID(pid_number); |
| 782 | #endif | 782 | #endif |
| 783 | #ifdef RT30xx | 783 | #ifdef RT30xx |
| 784 | pObj->MLMEThr_pid = find_get_pid(pid_number); | 784 | pObj->MLMEThr_pid = find_get_pid(pid_number); |
| @@ -788,10 +788,9 @@ NDIS_STATUS CreateThreads( | |||
| 788 | 788 | ||
| 789 | // Creat Command Thread | 789 | // Creat Command Thread |
| 790 | #ifndef RT30xx | 790 | #ifndef RT30xx |
| 791 | pObj->RTUSBCmdThr_task = NULL; | 791 | pObj->RTUSBCmdThr_pid= THREAD_PID_INIT_VALUE; |
| 792 | tsk = kthread_run(RTUSBCmdThread, pAd, "%s", pAd->net_dev->name); | 792 | pid_number = kernel_thread(RTUSBCmdThread, pAd, CLONE_VM); |
| 793 | 793 | if (pid_number < 0) | |
| 794 | if (IS_ERR(tsk) < 0) | ||
| 795 | #endif | 794 | #endif |
| 796 | #ifdef RT30xx | 795 | #ifdef RT30xx |
| 797 | pObj->RTUSBCmdThr_pid = NULL; | 796 | pObj->RTUSBCmdThr_pid = NULL; |
| @@ -804,7 +803,7 @@ NDIS_STATUS CreateThreads( | |||
| 804 | } | 803 | } |
| 805 | 804 | ||
| 806 | #ifndef RT30xx | 805 | #ifndef RT30xx |
| 807 | pObj->RTUSBCmdThr_task = tsk; | 806 | pObj->RTUSBCmdThr_pid = GET_PID(pid_number); |
| 808 | #endif | 807 | #endif |
| 809 | #ifdef RT30xx | 808 | #ifdef RT30xx |
| 810 | pObj->RTUSBCmdThr_pid = find_get_pid(pid_number); | 809 | pObj->RTUSBCmdThr_pid = find_get_pid(pid_number); |
| @@ -812,9 +811,9 @@ NDIS_STATUS CreateThreads( | |||
| 812 | wait_for_completion(&(pAd->CmdQComplete)); | 811 | wait_for_completion(&(pAd->CmdQComplete)); |
| 813 | 812 | ||
| 814 | #ifndef RT30xx | 813 | #ifndef RT30xx |
| 815 | pObj->TimerQThr_task = NULL; | 814 | pObj->TimerQThr_pid= THREAD_PID_INIT_VALUE; |
| 816 | tsk = kthread_run(TimerQThread, pAd, "%s", pAd->net_dev->name); | 815 | pid_number = kernel_thread(TimerQThread, pAd, CLONE_VM); |
| 817 | if (IS_ERR(tsk) < 0) | 816 | if (pid_number < 0) |
| 818 | #endif | 817 | #endif |
| 819 | #ifdef RT30xx | 818 | #ifdef RT30xx |
| 820 | pObj->TimerQThr_pid = NULL; | 819 | pObj->TimerQThr_pid = NULL; |
| @@ -826,7 +825,7 @@ NDIS_STATUS CreateThreads( | |||
| 826 | return NDIS_STATUS_FAILURE; | 825 | return NDIS_STATUS_FAILURE; |
| 827 | } | 826 | } |
| 828 | #ifndef RT30xx | 827 | #ifndef RT30xx |
| 829 | pObj->TimerQThr_task = tsk; | 828 | pObj->TimerQThr_pid = GET_PID(pid_number); |
| 830 | #endif | 829 | #endif |
| 831 | #ifdef RT30xx | 830 | #ifdef RT30xx |
| 832 | pObj->TimerQThr_pid = find_get_pid(pid_number); | 831 | pObj->TimerQThr_pid = find_get_pid(pid_number); |
diff --git a/drivers/staging/rt2870/common/rtusb_io.c b/drivers/staging/rt2870/common/rtusb_io.c index fd1b0c18f2a0..704b5c2d5091 100644 --- a/drivers/staging/rt2870/common/rtusb_io.c +++ b/drivers/staging/rt2870/common/rtusb_io.c | |||
| @@ -984,8 +984,7 @@ NDIS_STATUS RTUSBEnqueueCmdFromNdis( | |||
| 984 | POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie; | 984 | POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie; |
| 985 | 985 | ||
| 986 | #ifndef RT30xx | 986 | #ifndef RT30xx |
| 987 | BUG_ON(pObj->RTUSBCmdThr_task == NULL); | 987 | CHECK_PID_LEGALITY(pObj->RTUSBCmdThr_pid) |
| 988 | CHECK_PID_LEGALITY(task_pid(pObj->RTUSBCmdThr_task)) | ||
| 989 | #endif | 988 | #endif |
| 990 | #ifdef RT30xx | 989 | #ifdef RT30xx |
| 991 | if (pObj->RTUSBCmdThr_pid < 0) | 990 | if (pObj->RTUSBCmdThr_pid < 0) |
diff --git a/drivers/staging/rt2870/rt2870.h b/drivers/staging/rt2870/rt2870.h index 29e3b53e52a1..2b8872b2fd9d 100644 --- a/drivers/staging/rt2870/rt2870.h +++ b/drivers/staging/rt2870/rt2870.h | |||
| @@ -79,6 +79,7 @@ | |||
| 79 | { \ | 79 | { \ |
| 80 | {USB_DEVICE(0x148F,0x2770)}, /* Ralink */ \ | 80 | {USB_DEVICE(0x148F,0x2770)}, /* Ralink */ \ |
| 81 | {USB_DEVICE(0x1737,0x0071)}, /* Linksys WUSB600N */ \ | 81 | {USB_DEVICE(0x1737,0x0071)}, /* Linksys WUSB600N */ \ |
| 82 | {USB_DEVICE(0x1737,0x0070)}, /* Linksys */ \ | ||
| 82 | {USB_DEVICE(0x148F,0x2870)}, /* Ralink */ \ | 83 | {USB_DEVICE(0x148F,0x2870)}, /* Ralink */ \ |
| 83 | {USB_DEVICE(0x148F,0x3070)}, /* Ralink */ \ | 84 | {USB_DEVICE(0x148F,0x3070)}, /* Ralink */ \ |
| 84 | {USB_DEVICE(0x0B05,0x1731)}, /* Asus */ \ | 85 | {USB_DEVICE(0x0B05,0x1731)}, /* Asus */ \ |
| @@ -93,12 +94,14 @@ | |||
| 93 | {USB_DEVICE(0x14B2,0x3C06)}, /* Conceptronic */ \ | 94 | {USB_DEVICE(0x14B2,0x3C06)}, /* Conceptronic */ \ |
| 94 | {USB_DEVICE(0x14B2,0x3C28)}, /* Conceptronic */ \ | 95 | {USB_DEVICE(0x14B2,0x3C28)}, /* Conceptronic */ \ |
| 95 | {USB_DEVICE(0x2019,0xED06)}, /* Planex Communications, Inc. */ \ | 96 | {USB_DEVICE(0x2019,0xED06)}, /* Planex Communications, Inc. */ \ |
| 97 | {USB_DEVICE(0x2019,0xED14)}, /* Planex Communications, Inc. */ \ | ||
| 96 | {USB_DEVICE(0x2019,0xAB25)}, /* Planex Communications, Inc. RT3070 */ \ | 98 | {USB_DEVICE(0x2019,0xAB25)}, /* Planex Communications, Inc. RT3070 */ \ |
| 97 | {USB_DEVICE(0x07D1,0x3C09)}, /* D-Link */ \ | 99 | {USB_DEVICE(0x07D1,0x3C09)}, /* D-Link */ \ |
| 98 | {USB_DEVICE(0x07D1,0x3C11)}, /* D-Link */ \ | 100 | {USB_DEVICE(0x07D1,0x3C11)}, /* D-Link */ \ |
| 99 | {USB_DEVICE(0x14B2,0x3C07)}, /* AL */ \ | 101 | {USB_DEVICE(0x14B2,0x3C07)}, /* AL */ \ |
| 100 | {USB_DEVICE(0x14B2,0x3C12)}, /* AL */ \ | 102 | {USB_DEVICE(0x14B2,0x3C12)}, /* AL */ \ |
| 101 | {USB_DEVICE(0x050D,0x8053)}, /* Belkin */ \ | 103 | {USB_DEVICE(0x050D,0x8053)}, /* Belkin */ \ |
| 104 | {USB_DEVICE(0x050D,0x815C)}, /* Belkin */ \ | ||
| 102 | {USB_DEVICE(0x14B2,0x3C23)}, /* Airlink */ \ | 105 | {USB_DEVICE(0x14B2,0x3C23)}, /* Airlink */ \ |
| 103 | {USB_DEVICE(0x14B2,0x3C27)}, /* Airlink */ \ | 106 | {USB_DEVICE(0x14B2,0x3C27)}, /* Airlink */ \ |
| 104 | {USB_DEVICE(0x07AA,0x002F)}, /* Corega */ \ | 107 | {USB_DEVICE(0x07AA,0x002F)}, /* Corega */ \ |
| @@ -587,16 +590,14 @@ VOID RTUSBBulkRxComplete(purbb_t pUrb, struct pt_regs *pt_regs); | |||
| 587 | #define RTUSBMlmeUp(pAd) \ | 590 | #define RTUSBMlmeUp(pAd) \ |
| 588 | { \ | 591 | { \ |
| 589 | POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie; \ | 592 | POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie; \ |
| 590 | BUG_ON(pObj->MLMEThr_task == NULL); \ | 593 | CHECK_PID_LEGALITY(pObj->MLMEThr_pid) \ |
| 591 | CHECK_PID_LEGALITY(task_pid(pObj->MLMEThr_task)) \ | ||
| 592 | up(&(pAd->mlme_semaphore)); \ | 594 | up(&(pAd->mlme_semaphore)); \ |
| 593 | } | 595 | } |
| 594 | 596 | ||
| 595 | #define RTUSBCMDUp(pAd) \ | 597 | #define RTUSBCMDUp(pAd) \ |
| 596 | { \ | 598 | { \ |
| 597 | POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie; \ | 599 | POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie; \ |
| 598 | BUG_ON(pObj->RTUSBCmdThr_task == NULL); \ | 600 | CHECK_PID_LEGALITY(pObj->RTUSBCmdThr_pid) \ |
| 599 | CHECK_PID_LEGALITY(task_pid(pObj->RTUSBCmdThr_task)) \ | ||
| 600 | up(&(pAd->RTUSBCmd_semaphore)); \ | 601 | up(&(pAd->RTUSBCmd_semaphore)); \ |
| 601 | } | 602 | } |
| 602 | #endif | 603 | #endif |
diff --git a/drivers/staging/rtl8192su/ieee80211.h b/drivers/staging/rtl8192su/ieee80211.h index 0edb09a536f9..ea9739318037 100644 --- a/drivers/staging/rtl8192su/ieee80211.h +++ b/drivers/staging/rtl8192su/ieee80211.h | |||
| @@ -2645,7 +2645,7 @@ extern int ieee80211_encrypt_fragment( | |||
| 2645 | struct sk_buff *frag, | 2645 | struct sk_buff *frag, |
| 2646 | int hdr_len); | 2646 | int hdr_len); |
| 2647 | 2647 | ||
| 2648 | extern int ieee80211_xmit(struct sk_buff *skb, | 2648 | extern int rtl8192_ieee80211_xmit(struct sk_buff *skb, |
| 2649 | struct net_device *dev); | 2649 | struct net_device *dev); |
| 2650 | extern void ieee80211_txb_free(struct ieee80211_txb *); | 2650 | extern void ieee80211_txb_free(struct ieee80211_txb *); |
| 2651 | 2651 | ||
diff --git a/drivers/staging/rtl8192su/ieee80211/ieee80211.h b/drivers/staging/rtl8192su/ieee80211/ieee80211.h index 720bfcbfadc1..5e3a2cbed2b1 100644 --- a/drivers/staging/rtl8192su/ieee80211/ieee80211.h +++ b/drivers/staging/rtl8192su/ieee80211/ieee80211.h | |||
| @@ -2645,7 +2645,7 @@ extern int ieee80211_encrypt_fragment( | |||
| 2645 | struct sk_buff *frag, | 2645 | struct sk_buff *frag, |
| 2646 | int hdr_len); | 2646 | int hdr_len); |
| 2647 | 2647 | ||
| 2648 | extern int ieee80211_xmit(struct sk_buff *skb, | 2648 | extern int rtl8192_ieee80211_xmit(struct sk_buff *skb, |
| 2649 | struct net_device *dev); | 2649 | struct net_device *dev); |
| 2650 | extern void ieee80211_txb_free(struct ieee80211_txb *); | 2650 | extern void ieee80211_txb_free(struct ieee80211_txb *); |
| 2651 | 2651 | ||
diff --git a/drivers/staging/rtl8192su/ieee80211/ieee80211_tx.c b/drivers/staging/rtl8192su/ieee80211/ieee80211_tx.c index 7294572b990f..cba12b84be5c 100644 --- a/drivers/staging/rtl8192su/ieee80211/ieee80211_tx.c +++ b/drivers/staging/rtl8192su/ieee80211/ieee80211_tx.c | |||
| @@ -618,7 +618,7 @@ void ieee80211_query_seqnum(struct ieee80211_device*ieee, struct sk_buff* skb, u | |||
| 618 | } | 618 | } |
| 619 | } | 619 | } |
| 620 | 620 | ||
| 621 | int ieee80211_xmit(struct sk_buff *skb, struct net_device *dev) | 621 | int rtl8192_ieee80211_xmit(struct sk_buff *skb, struct net_device *dev) |
| 622 | { | 622 | { |
| 623 | #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0)) | 623 | #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0)) |
| 624 | struct ieee80211_device *ieee = netdev_priv(dev); | 624 | struct ieee80211_device *ieee = netdev_priv(dev); |
| @@ -943,5 +943,6 @@ int ieee80211_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 943 | return 1; | 943 | return 1; |
| 944 | 944 | ||
| 945 | } | 945 | } |
| 946 | EXPORT_SYMBOL(rtl8192_ieee80211_xmit); | ||
| 946 | 947 | ||
| 947 | EXPORT_SYMBOL(ieee80211_txb_free); | 948 | EXPORT_SYMBOL(ieee80211_txb_free); |
diff --git a/drivers/staging/rtl8192su/r8192U_core.c b/drivers/staging/rtl8192su/r8192U_core.c index 4ab250743e81..70f81a8f1291 100644 --- a/drivers/staging/rtl8192su/r8192U_core.c +++ b/drivers/staging/rtl8192su/r8192U_core.c | |||
| @@ -12142,7 +12142,7 @@ static const struct net_device_ops rtl8192_netdev_ops = { | |||
| 12142 | .ndo_set_mac_address = r8192_set_mac_adr, | 12142 | .ndo_set_mac_address = r8192_set_mac_adr, |
| 12143 | .ndo_validate_addr = eth_validate_addr, | 12143 | .ndo_validate_addr = eth_validate_addr, |
| 12144 | .ndo_change_mtu = eth_change_mtu, | 12144 | .ndo_change_mtu = eth_change_mtu, |
| 12145 | .ndo_start_xmit = ieee80211_xmit, | 12145 | .ndo_start_xmit = rtl8192_ieee80211_xmit, |
| 12146 | }; | 12146 | }; |
| 12147 | 12147 | ||
| 12148 | #if LINUX_VERSION_CODE > KERNEL_VERSION(2,5,0) | 12148 | #if LINUX_VERSION_CODE > KERNEL_VERSION(2,5,0) |
diff --git a/drivers/staging/serqt_usb2/serqt_usb2.c b/drivers/staging/serqt_usb2/serqt_usb2.c index a9bd4106beb7..0fdf8c6dc648 100644 --- a/drivers/staging/serqt_usb2/serqt_usb2.c +++ b/drivers/staging/serqt_usb2/serqt_usb2.c | |||
| @@ -360,18 +360,18 @@ static void qt_read_bulk_callback(struct urb *urb) | |||
| 360 | if (port_paranoia_check(port, __func__) != 0) { | 360 | if (port_paranoia_check(port, __func__) != 0) { |
| 361 | dbg("%s - port_paranoia_check, exiting\n", __func__); | 361 | dbg("%s - port_paranoia_check, exiting\n", __func__); |
| 362 | qt_port->ReadBulkStopped = 1; | 362 | qt_port->ReadBulkStopped = 1; |
| 363 | return; | 363 | goto exit; |
| 364 | } | 364 | } |
| 365 | 365 | ||
| 366 | if (!serial) { | 366 | if (!serial) { |
| 367 | dbg("%s - bad serial pointer, exiting\n", __func__); | 367 | dbg("%s - bad serial pointer, exiting\n", __func__); |
| 368 | return; | 368 | goto exit; |
| 369 | } | 369 | } |
| 370 | if (qt_port->closePending == 1) { | 370 | if (qt_port->closePending == 1) { |
| 371 | /* Were closing , stop reading */ | 371 | /* Were closing , stop reading */ |
| 372 | dbg("%s - (qt_port->closepending == 1\n", __func__); | 372 | dbg("%s - (qt_port->closepending == 1\n", __func__); |
| 373 | qt_port->ReadBulkStopped = 1; | 373 | qt_port->ReadBulkStopped = 1; |
| 374 | return; | 374 | goto exit; |
| 375 | } | 375 | } |
| 376 | 376 | ||
| 377 | /* | 377 | /* |
| @@ -381,7 +381,7 @@ static void qt_read_bulk_callback(struct urb *urb) | |||
| 381 | */ | 381 | */ |
| 382 | if (qt_port->RxHolding == 1) { | 382 | if (qt_port->RxHolding == 1) { |
| 383 | qt_port->ReadBulkStopped = 1; | 383 | qt_port->ReadBulkStopped = 1; |
| 384 | return; | 384 | goto exit; |
| 385 | } | 385 | } |
| 386 | 386 | ||
| 387 | if (urb->status) { | 387 | if (urb->status) { |
| @@ -389,7 +389,7 @@ static void qt_read_bulk_callback(struct urb *urb) | |||
| 389 | 389 | ||
| 390 | dbg("%s - nonzero read bulk status received: %d\n", | 390 | dbg("%s - nonzero read bulk status received: %d\n", |
| 391 | __func__, urb->status); | 391 | __func__, urb->status); |
| 392 | return; | 392 | goto exit; |
| 393 | } | 393 | } |
| 394 | 394 | ||
| 395 | if (tty && RxCount) { | 395 | if (tty && RxCount) { |
| @@ -463,6 +463,8 @@ static void qt_read_bulk_callback(struct urb *urb) | |||
| 463 | } | 463 | } |
| 464 | 464 | ||
| 465 | schedule_work(&port->work); | 465 | schedule_work(&port->work); |
| 466 | exit: | ||
| 467 | tty_kref_put(tty); | ||
| 466 | } | 468 | } |
| 467 | 469 | ||
| 468 | /* | 470 | /* |
| @@ -736,6 +738,11 @@ static int qt_startup(struct usb_serial *serial) | |||
| 736 | if (!qt_port) { | 738 | if (!qt_port) { |
| 737 | dbg("%s: kmalloc for quatech_port (%d) failed!.", | 739 | dbg("%s: kmalloc for quatech_port (%d) failed!.", |
| 738 | __func__, i); | 740 | __func__, i); |
| 741 | for(--i; i >= 0; i--) { | ||
| 742 | port = serial->port[i]; | ||
| 743 | kfree(usb_get_serial_port_data(port)); | ||
| 744 | usb_set_serial_port_data(port, NULL); | ||
| 745 | } | ||
| 739 | return -ENOMEM; | 746 | return -ENOMEM; |
| 740 | } | 747 | } |
| 741 | spin_lock_init(&qt_port->lock); | 748 | spin_lock_init(&qt_port->lock); |
| @@ -1041,7 +1048,7 @@ static void qt_block_until_empty(struct tty_struct *tty, | |||
| 1041 | } | 1048 | } |
| 1042 | } | 1049 | } |
| 1043 | 1050 | ||
| 1044 | static void qt_close( struct usb_serial_port *port) | 1051 | static void qt_close(struct usb_serial_port *port) |
| 1045 | { | 1052 | { |
| 1046 | struct usb_serial *serial = port->serial; | 1053 | struct usb_serial *serial = port->serial; |
| 1047 | struct quatech_port *qt_port; | 1054 | struct quatech_port *qt_port; |
| @@ -1068,6 +1075,7 @@ static void qt_close( struct usb_serial_port *port) | |||
| 1068 | /* wait up to for transmitter to empty */ | 1075 | /* wait up to for transmitter to empty */ |
| 1069 | if (serial->dev) | 1076 | if (serial->dev) |
| 1070 | qt_block_until_empty(tty, qt_port); | 1077 | qt_block_until_empty(tty, qt_port); |
| 1078 | tty_kref_put(tty); | ||
| 1071 | 1079 | ||
| 1072 | /* Close uart channel */ | 1080 | /* Close uart channel */ |
| 1073 | status = qt_close_channel(serial, index); | 1081 | status = qt_close_channel(serial, index); |
diff --git a/drivers/staging/uc2322/Kconfig b/drivers/staging/uc2322/Kconfig deleted file mode 100644 index 2e0c6e79df2b..000000000000 --- a/drivers/staging/uc2322/Kconfig +++ /dev/null | |||
| @@ -1,10 +0,0 @@ | |||
| 1 | config USB_SERIAL_ATEN2011 | ||
| 2 | tristate "ATEN 2011 USB to serial device support" | ||
| 3 | depends on USB_SERIAL | ||
| 4 | default N | ||
| 5 | ---help--- | ||
| 6 | Say Y here if you want to use a ATEN 2011 dual port USB to serial | ||
| 7 | adapter. | ||
| 8 | |||
| 9 | To compile this driver as a module, choose M here: the module will be | ||
| 10 | called aten2011. | ||
diff --git a/drivers/staging/uc2322/Makefile b/drivers/staging/uc2322/Makefile deleted file mode 100644 index 49c18d6e579f..000000000000 --- a/drivers/staging/uc2322/Makefile +++ /dev/null | |||
| @@ -1 +0,0 @@ | |||
| 1 | obj-$(CONFIG_USB_SERIAL_ATEN2011) += aten2011.o | ||
diff --git a/drivers/staging/uc2322/TODO b/drivers/staging/uc2322/TODO deleted file mode 100644 index c189a64c4185..000000000000 --- a/drivers/staging/uc2322/TODO +++ /dev/null | |||
| @@ -1,7 +0,0 @@ | |||
| 1 | TODO: | ||
| 2 | - checkpatch.pl cleanups | ||
| 3 | - remove dead and useless code (auditing the tty ioctls to | ||
| 4 | verify that they really are correct and needed.) | ||
| 5 | |||
| 6 | Please send any patches to Greg Kroah-Hartman <greg@kroah.com> and | ||
| 7 | Russell Lang <gsview@ghostgum.com.au>. | ||
diff --git a/drivers/staging/uc2322/aten2011.c b/drivers/staging/uc2322/aten2011.c deleted file mode 100644 index 39d0926d1a90..000000000000 --- a/drivers/staging/uc2322/aten2011.c +++ /dev/null | |||
| @@ -1,2430 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * Aten 2011 USB serial driver for 4 port devices | ||
| 3 | * | ||
| 4 | * Copyright (C) 2000 Inside Out Networks | ||
| 5 | * Copyright (C) 2001-2002, 2009 Greg Kroah-Hartman <greg@kroah.com> | ||
| 6 | * Copyright (C) 2009 Novell Inc. | ||
| 7 | * | ||
| 8 | * This program is free software; you can redistribute it and/or modify | ||
| 9 | * it under the terms of the GNU General Public License as published by | ||
| 10 | * the Free Software Foundation; either version 2 of the License, or | ||
| 11 | * (at your option) any later version. | ||
| 12 | * | ||
| 13 | */ | ||
| 14 | |||
| 15 | #include <linux/kernel.h> | ||
| 16 | #include <linux/errno.h> | ||
| 17 | #include <linux/init.h> | ||
| 18 | #include <linux/slab.h> | ||
| 19 | #include <linux/tty.h> | ||
| 20 | #include <linux/tty_driver.h> | ||
| 21 | #include <linux/tty_flip.h> | ||
| 22 | #include <linux/module.h> | ||
| 23 | #include <linux/serial.h> | ||
| 24 | #include <linux/uaccess.h> | ||
| 25 | #include <linux/usb.h> | ||
| 26 | #include <linux/usb/serial.h> | ||
| 27 | |||
| 28 | |||
| 29 | #define ZLP_REG1 0x3A /* Zero_Flag_Reg1 58 */ | ||
| 30 | #define ZLP_REG2 0x3B /* Zero_Flag_Reg2 59 */ | ||
| 31 | #define ZLP_REG3 0x3C /* Zero_Flag_Reg3 60 */ | ||
| 32 | #define ZLP_REG4 0x3D /* Zero_Flag_Reg4 61 */ | ||
| 33 | #define ZLP_REG5 0x3E /* Zero_Flag_Reg5 62 */ | ||
| 34 | |||
| 35 | /* Interrupt Rotinue Defines */ | ||
| 36 | #define SERIAL_IIR_RLS 0x06 | ||
| 37 | #define SERIAL_IIR_RDA 0x04 | ||
| 38 | #define SERIAL_IIR_CTI 0x0c | ||
| 39 | #define SERIAL_IIR_THR 0x02 | ||
| 40 | #define SERIAL_IIR_MS 0x00 | ||
| 41 | |||
| 42 | /* Emulation of the bit mask on the LINE STATUS REGISTER. */ | ||
| 43 | #define SERIAL_LSR_DR 0x0001 | ||
| 44 | #define SERIAL_LSR_OE 0x0002 | ||
| 45 | #define SERIAL_LSR_PE 0x0004 | ||
| 46 | #define SERIAL_LSR_FE 0x0008 | ||
| 47 | #define SERIAL_LSR_BI 0x0010 | ||
| 48 | #define SERIAL_LSR_THRE 0x0020 | ||
| 49 | #define SERIAL_LSR_TEMT 0x0040 | ||
| 50 | #define SERIAL_LSR_FIFOERR 0x0080 | ||
| 51 | |||
| 52 | /* MSR bit defines(place holders) */ | ||
| 53 | #define ATEN_MSR_DELTA_CTS 0x10 | ||
| 54 | #define ATEN_MSR_DELTA_DSR 0x20 | ||
| 55 | #define ATEN_MSR_DELTA_RI 0x40 | ||
| 56 | #define ATEN_MSR_DELTA_CD 0x80 | ||
| 57 | |||
| 58 | /* Serial Port register Address */ | ||
| 59 | #define RECEIVE_BUFFER_REGISTER ((__u16)(0x00)) | ||
| 60 | #define TRANSMIT_HOLDING_REGISTER ((__u16)(0x00)) | ||
| 61 | #define INTERRUPT_ENABLE_REGISTER ((__u16)(0x01)) | ||
| 62 | #define INTERRUPT_IDENT_REGISTER ((__u16)(0x02)) | ||
| 63 | #define FIFO_CONTROL_REGISTER ((__u16)(0x02)) | ||
| 64 | #define LINE_CONTROL_REGISTER ((__u16)(0x03)) | ||
| 65 | #define MODEM_CONTROL_REGISTER ((__u16)(0x04)) | ||
| 66 | #define LINE_STATUS_REGISTER ((__u16)(0x05)) | ||
| 67 | #define MODEM_STATUS_REGISTER ((__u16)(0x06)) | ||
| 68 | #define SCRATCH_PAD_REGISTER ((__u16)(0x07)) | ||
| 69 | #define DIVISOR_LATCH_LSB ((__u16)(0x00)) | ||
| 70 | #define DIVISOR_LATCH_MSB ((__u16)(0x01)) | ||
| 71 | |||
| 72 | #define SP1_REGISTER ((__u16)(0x00)) | ||
| 73 | #define CONTROL1_REGISTER ((__u16)(0x01)) | ||
| 74 | #define CLK_MULTI_REGISTER ((__u16)(0x02)) | ||
| 75 | #define CLK_START_VALUE_REGISTER ((__u16)(0x03)) | ||
| 76 | #define DCR1_REGISTER ((__u16)(0x04)) | ||
| 77 | #define GPIO_REGISTER ((__u16)(0x07)) | ||
| 78 | |||
| 79 | #define SERIAL_LCR_DLAB ((__u16)(0x0080)) | ||
| 80 | |||
| 81 | /* | ||
| 82 | * URB POOL related defines | ||
| 83 | */ | ||
| 84 | #define NUM_URBS 16 /* URB Count */ | ||
| 85 | #define URB_TRANSFER_BUFFER_SIZE 32 /* URB Size */ | ||
| 86 | |||
| 87 | #define USB_VENDOR_ID_ATENINTL 0x0557 | ||
| 88 | #define ATENINTL_DEVICE_ID_2011 0x2011 | ||
| 89 | #define ATENINTL_DEVICE_ID_7820 0x7820 | ||
| 90 | |||
| 91 | static struct usb_device_id id_table[] = { | ||
| 92 | { USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_2011) }, | ||
| 93 | { USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_7820) }, | ||
| 94 | { } /* terminating entry */ | ||
| 95 | }; | ||
| 96 | MODULE_DEVICE_TABLE(usb, id_table); | ||
| 97 | |||
| 98 | /* This structure holds all of the local port information */ | ||
| 99 | struct ATENINTL_port { | ||
| 100 | int port_num; /*Actual port number in the device(1,2,etc)*/ | ||
| 101 | __u8 bulk_out_endpoint; /* the bulk out endpoint handle */ | ||
| 102 | unsigned char *bulk_out_buffer; /* buffer used for the bulk out endpoint */ | ||
| 103 | struct urb *write_urb; /* write URB for this port */ | ||
| 104 | __u8 bulk_in_endpoint; /* the bulk in endpoint handle */ | ||
| 105 | unsigned char *bulk_in_buffer; /* the buffer we use for the bulk in endpoint */ | ||
| 106 | struct urb *read_urb; /* read URB for this port */ | ||
| 107 | __u8 shadowLCR; /* last LCR value received */ | ||
| 108 | __u8 shadowMCR; /* last MCR value received */ | ||
| 109 | char open; | ||
| 110 | char chaseResponsePending; | ||
| 111 | wait_queue_head_t wait_chase; /* for handling sleeping while waiting for chase to finish */ | ||
| 112 | wait_queue_head_t wait_command; /* for handling sleeping while waiting for command to finish */ | ||
| 113 | struct async_icount icount; | ||
| 114 | struct usb_serial_port *port; /* loop back to the owner of this object */ | ||
| 115 | /*Offsets*/ | ||
| 116 | __u8 SpRegOffset; | ||
| 117 | __u8 ControlRegOffset; | ||
| 118 | __u8 DcrRegOffset; | ||
| 119 | /* for processing control URBS in interrupt context */ | ||
| 120 | struct urb *control_urb; | ||
| 121 | char *ctrl_buf; | ||
| 122 | int MsrLsr; | ||
| 123 | |||
| 124 | struct urb *write_urb_pool[NUM_URBS]; | ||
| 125 | /* we pass a pointer to this as the arguement sent to cypress_set_termios old_termios */ | ||
| 126 | struct ktermios tmp_termios; /* stores the old termios settings */ | ||
| 127 | spinlock_t lock; /* private lock */ | ||
| 128 | }; | ||
| 129 | |||
| 130 | /* This structure holds all of the individual serial device information */ | ||
| 131 | struct ATENINTL_serial { | ||
| 132 | __u8 interrupt_in_endpoint; /* the interrupt endpoint handle */ | ||
| 133 | unsigned char *interrupt_in_buffer; /* the buffer we use for the interrupt endpoint */ | ||
| 134 | struct urb *interrupt_read_urb; /* our interrupt urb */ | ||
| 135 | __u8 bulk_in_endpoint; /* the bulk in endpoint handle */ | ||
| 136 | unsigned char *bulk_in_buffer; /* the buffer we use for the bulk in endpoint */ | ||
| 137 | struct urb *read_urb; /* our bulk read urb */ | ||
| 138 | __u8 bulk_out_endpoint; /* the bulk out endpoint handle */ | ||
| 139 | struct usb_serial *serial; /* loop back to the owner of this object */ | ||
| 140 | int ATEN2011_spectrum_2or4ports; /* this says the number of ports in the device */ | ||
| 141 | /* Indicates about the no.of opened ports of an individual USB-serial adapater. */ | ||
| 142 | unsigned int NoOfOpenPorts; | ||
| 143 | /* a flag for Status endpoint polling */ | ||
| 144 | unsigned char status_polling_started; | ||
| 145 | }; | ||
| 146 | |||
| 147 | static void ATEN2011_set_termios(struct tty_struct *tty, | ||
| 148 | struct usb_serial_port *port, | ||
| 149 | struct ktermios *old_termios); | ||
| 150 | static void ATEN2011_change_port_settings(struct tty_struct *tty, | ||
| 151 | struct ATENINTL_port *ATEN2011_port, | ||
| 152 | struct ktermios *old_termios); | ||
| 153 | |||
| 154 | /************************************* | ||
| 155 | * Bit definitions for each register * | ||
| 156 | *************************************/ | ||
| 157 | #define LCR_BITS_5 0x00 /* 5 bits/char */ | ||
| 158 | #define LCR_BITS_6 0x01 /* 6 bits/char */ | ||
| 159 | #define LCR_BITS_7 0x02 /* 7 bits/char */ | ||
| 160 | #define LCR_BITS_8 0x03 /* 8 bits/char */ | ||
| 161 | #define LCR_BITS_MASK 0x03 /* Mask for bits/char field */ | ||
| 162 | |||
| 163 | #define LCR_STOP_1 0x00 /* 1 stop bit */ | ||
| 164 | #define LCR_STOP_1_5 0x04 /* 1.5 stop bits (if 5 bits/char) */ | ||
| 165 | #define LCR_STOP_2 0x04 /* 2 stop bits (if 6-8 bits/char) */ | ||
| 166 | #define LCR_STOP_MASK 0x04 /* Mask for stop bits field */ | ||
| 167 | |||
| 168 | #define LCR_PAR_NONE 0x00 /* No parity */ | ||
| 169 | #define LCR_PAR_ODD 0x08 /* Odd parity */ | ||
| 170 | #define LCR_PAR_EVEN 0x18 /* Even parity */ | ||
| 171 | #define LCR_PAR_MARK 0x28 /* Force parity bit to 1 */ | ||
| 172 | #define LCR_PAR_SPACE 0x38 /* Force parity bit to 0 */ | ||
| 173 | #define LCR_PAR_MASK 0x38 /* Mask for parity field */ | ||
| 174 | |||
| 175 | #define LCR_SET_BREAK 0x40 /* Set Break condition */ | ||
| 176 | #define LCR_DL_ENABLE 0x80 /* Enable access to divisor latch */ | ||
| 177 | |||
| 178 | #define MCR_DTR 0x01 /* Assert DTR */ | ||
| 179 | #define MCR_RTS 0x02 /* Assert RTS */ | ||
| 180 | #define MCR_OUT1 0x04 /* Loopback only: Sets state of RI */ | ||
| 181 | #define MCR_MASTER_IE 0x08 /* Enable interrupt outputs */ | ||
| 182 | #define MCR_LOOPBACK 0x10 /* Set internal (digital) loopback mode */ | ||
| 183 | #define MCR_XON_ANY 0x20 /* Enable any char to exit XOFF mode */ | ||
| 184 | |||
| 185 | #define ATEN2011_MSR_CTS 0x10 /* Current state of CTS */ | ||
| 186 | #define ATEN2011_MSR_DSR 0x20 /* Current state of DSR */ | ||
| 187 | #define ATEN2011_MSR_RI 0x40 /* Current state of RI */ | ||
| 188 | #define ATEN2011_MSR_CD 0x80 /* Current state of CD */ | ||
| 189 | |||
| 190 | |||
| 191 | static int debug; | ||
| 192 | |||
| 193 | /* | ||
| 194 | * Version Information | ||
| 195 | */ | ||
| 196 | #define DRIVER_VERSION "2.0" | ||
| 197 | #define DRIVER_DESC "ATENINTL 2011 USB Serial Adapter" | ||
| 198 | |||
| 199 | /* | ||
| 200 | * Defines used for sending commands to port | ||
| 201 | */ | ||
| 202 | |||
| 203 | #define ATEN_WDR_TIMEOUT (50) /* default urb timeout */ | ||
| 204 | |||
| 205 | /* Requests */ | ||
| 206 | #define ATEN_RD_RTYPE 0xC0 | ||
| 207 | #define ATEN_WR_RTYPE 0x40 | ||
| 208 | #define ATEN_RDREQ 0x0D | ||
| 209 | #define ATEN_WRREQ 0x0E | ||
| 210 | #define ATEN_CTRL_TIMEOUT 500 | ||
| 211 | #define VENDOR_READ_LENGTH (0x01) | ||
| 212 | |||
| 213 | /* set to 1 for RS485 mode and 0 for RS232 mode */ | ||
| 214 | /* FIXME make this somehow dynamic and not build time specific */ | ||
| 215 | static int RS485mode; | ||
| 216 | |||
| 217 | static int set_reg_sync(struct usb_serial_port *port, __u16 reg, __u16 val) | ||
| 218 | { | ||
| 219 | struct usb_device *dev = port->serial->dev; | ||
| 220 | val = val & 0x00ff; | ||
| 221 | |||
| 222 | dbg("%s: is %x, value %x", __func__, reg, val); | ||
| 223 | |||
| 224 | return usb_control_msg(dev, usb_sndctrlpipe(dev, 0), ATEN_WRREQ, | ||
| 225 | ATEN_WR_RTYPE, val, reg, NULL, 0, | ||
| 226 | ATEN_WDR_TIMEOUT); | ||
| 227 | } | ||
| 228 | |||
| 229 | static int get_reg_sync(struct usb_serial_port *port, __u16 reg, __u16 *val) | ||
| 230 | { | ||
| 231 | struct usb_device *dev = port->serial->dev; | ||
| 232 | int ret; | ||
| 233 | |||
| 234 | ret = usb_control_msg(dev, usb_rcvctrlpipe(dev, 0), ATEN_RDREQ, | ||
| 235 | ATEN_RD_RTYPE, 0, reg, val, VENDOR_READ_LENGTH, | ||
| 236 | ATEN_WDR_TIMEOUT); | ||
| 237 | dbg("%s: offset is %x, return val %x", __func__, reg, *val); | ||
| 238 | *val = (*val) & 0x00ff; | ||
| 239 | return ret; | ||
| 240 | } | ||
| 241 | |||
| 242 | static int set_uart_reg(struct usb_serial_port *port, __u16 reg, __u16 val) | ||
| 243 | { | ||
| 244 | struct usb_device *dev = port->serial->dev; | ||
| 245 | struct ATENINTL_serial *a_serial; | ||
| 246 | __u16 minor; | ||
| 247 | |||
| 248 | a_serial = usb_get_serial_data(port->serial); | ||
| 249 | minor = port->serial->minor; | ||
| 250 | if (minor == SERIAL_TTY_NO_MINOR) | ||
| 251 | minor = 0; | ||
| 252 | val = val & 0x00ff; | ||
| 253 | |||
| 254 | /* | ||
| 255 | * For the UART control registers, | ||
| 256 | * the application number need to be Or'ed | ||
| 257 | */ | ||
| 258 | if (a_serial->ATEN2011_spectrum_2or4ports == 4) | ||
| 259 | val |= (((__u16)port->number - minor) + 1) << 8; | ||
| 260 | else { | ||
| 261 | if (((__u16) port->number - minor) == 0) | ||
| 262 | val |= (((__u16)port->number - minor) + 1) << 8; | ||
| 263 | else | ||
| 264 | val |= (((__u16)port->number - minor) + 2) << 8; | ||
| 265 | } | ||
| 266 | dbg("%s: application number is %x", __func__, val); | ||
| 267 | |||
| 268 | return usb_control_msg(dev, usb_sndctrlpipe(dev, 0), ATEN_WRREQ, | ||
| 269 | ATEN_WR_RTYPE, val, reg, NULL, 0, | ||
| 270 | ATEN_WDR_TIMEOUT); | ||
| 271 | } | ||
| 272 | |||
| 273 | static int get_uart_reg(struct usb_serial_port *port, __u16 reg, __u16 *val) | ||
| 274 | { | ||
| 275 | struct usb_device *dev = port->serial->dev; | ||
| 276 | int ret = 0; | ||
| 277 | __u16 wval; | ||
| 278 | struct ATENINTL_serial *a_serial; | ||
| 279 | __u16 minor = port->serial->minor; | ||
| 280 | |||
| 281 | a_serial = usb_get_serial_data(port->serial); | ||
| 282 | if (minor == SERIAL_TTY_NO_MINOR) | ||
| 283 | minor = 0; | ||
| 284 | |||
| 285 | /* wval is same as application number */ | ||
| 286 | if (a_serial->ATEN2011_spectrum_2or4ports == 4) | ||
| 287 | wval = (((__u16)port->number - minor) + 1) << 8; | ||
| 288 | else { | ||
| 289 | if (((__u16) port->number - minor) == 0) | ||
| 290 | wval = (((__u16) port->number - minor) + 1) << 8; | ||
| 291 | else | ||
| 292 | wval = (((__u16) port->number - minor) + 2) << 8; | ||
| 293 | } | ||
| 294 | dbg("%s: application number is %x", __func__, wval); | ||
| 295 | ret = usb_control_msg(dev, usb_rcvctrlpipe(dev, 0), ATEN_RDREQ, | ||
| 296 | ATEN_RD_RTYPE, wval, reg, val, VENDOR_READ_LENGTH, | ||
| 297 | ATEN_WDR_TIMEOUT); | ||
| 298 | *val = (*val) & 0x00ff; | ||
| 299 | return ret; | ||
| 300 | } | ||
| 301 | |||
| 302 | static int handle_newMsr(struct ATENINTL_port *port, __u8 newMsr) | ||
| 303 | { | ||
| 304 | struct ATENINTL_port *ATEN2011_port; | ||
| 305 | struct async_icount *icount; | ||
| 306 | ATEN2011_port = port; | ||
| 307 | icount = &ATEN2011_port->icount; | ||
| 308 | if (newMsr & | ||
| 309 | (ATEN_MSR_DELTA_CTS | ATEN_MSR_DELTA_DSR | ATEN_MSR_DELTA_RI | | ||
| 310 | ATEN_MSR_DELTA_CD)) { | ||
| 311 | icount = &ATEN2011_port->icount; | ||
| 312 | |||
| 313 | /* update input line counters */ | ||
| 314 | if (newMsr & ATEN_MSR_DELTA_CTS) | ||
| 315 | icount->cts++; | ||
| 316 | if (newMsr & ATEN_MSR_DELTA_DSR) | ||
| 317 | icount->dsr++; | ||
| 318 | if (newMsr & ATEN_MSR_DELTA_CD) | ||
| 319 | icount->dcd++; | ||
| 320 | if (newMsr & ATEN_MSR_DELTA_RI) | ||
| 321 | icount->rng++; | ||
| 322 | } | ||
| 323 | |||
| 324 | return 0; | ||
| 325 | } | ||
| 326 | |||
| 327 | static int handle_newLsr(struct ATENINTL_port *port, __u8 newLsr) | ||
| 328 | { | ||
| 329 | struct async_icount *icount; | ||
| 330 | |||
| 331 | dbg("%s - %02x", __func__, newLsr); | ||
| 332 | |||
| 333 | if (newLsr & SERIAL_LSR_BI) { | ||
| 334 | /* | ||
| 335 | * Parity and Framing errors only count if they occur exclusive | ||
| 336 | * of a break being received. | ||
| 337 | */ | ||
| 338 | newLsr &= (__u8) (SERIAL_LSR_OE | SERIAL_LSR_BI); | ||
| 339 | } | ||
| 340 | |||
| 341 | /* update input line counters */ | ||
| 342 | icount = &port->icount; | ||
| 343 | if (newLsr & SERIAL_LSR_BI) | ||
| 344 | icount->brk++; | ||
| 345 | if (newLsr & SERIAL_LSR_OE) | ||
| 346 | icount->overrun++; | ||
| 347 | if (newLsr & SERIAL_LSR_PE) | ||
| 348 | icount->parity++; | ||
| 349 | if (newLsr & SERIAL_LSR_FE) | ||
| 350 | icount->frame++; | ||
| 351 | |||
| 352 | return 0; | ||
| 353 | } | ||
| 354 | |||
| 355 | static void ATEN2011_control_callback(struct urb *urb) | ||
| 356 | { | ||
| 357 | unsigned char *data; | ||
| 358 | struct ATENINTL_port *ATEN2011_port; | ||
| 359 | __u8 regval = 0x0; | ||
| 360 | |||
| 361 | switch (urb->status) { | ||
| 362 | case 0: | ||
| 363 | /* success */ | ||
| 364 | break; | ||
| 365 | case -ECONNRESET: | ||
| 366 | case -ENOENT: | ||
| 367 | case -ESHUTDOWN: | ||
| 368 | /* this urb is terminated, clean up */ | ||
| 369 | dbg("%s - urb shutting down with status: %d", __func__, | ||
| 370 | urb->status); | ||
| 371 | return; | ||
| 372 | default: | ||
| 373 | dbg("%s - nonzero urb status received: %d", __func__, | ||
| 374 | urb->status); | ||
| 375 | goto exit; | ||
| 376 | } | ||
| 377 | |||
| 378 | ATEN2011_port = (struct ATENINTL_port *)urb->context; | ||
| 379 | |||
| 380 | dbg("%s urb buffer size is %d", __func__, urb->actual_length); | ||
| 381 | dbg("%s ATEN2011_port->MsrLsr is %d port %d", __func__, | ||
| 382 | ATEN2011_port->MsrLsr, ATEN2011_port->port_num); | ||
| 383 | data = urb->transfer_buffer; | ||
| 384 | regval = (__u8) data[0]; | ||
| 385 | dbg("%s data is %x", __func__, regval); | ||
| 386 | if (ATEN2011_port->MsrLsr == 0) | ||
| 387 | handle_newMsr(ATEN2011_port, regval); | ||
| 388 | else if (ATEN2011_port->MsrLsr == 1) | ||
| 389 | handle_newLsr(ATEN2011_port, regval); | ||
| 390 | |||
| 391 | exit: | ||
| 392 | return; | ||
| 393 | } | ||
| 394 | |||
| 395 | static int ATEN2011_get_reg(struct ATENINTL_port *ATEN, __u16 Wval, __u16 reg, | ||
| 396 | __u16 *val) | ||
| 397 | { | ||
| 398 | struct usb_device *dev = ATEN->port->serial->dev; | ||
| 399 | struct usb_ctrlrequest *dr = NULL; | ||
| 400 | unsigned char *buffer = NULL; | ||
| 401 | int ret = 0; | ||
| 402 | buffer = (__u8 *) ATEN->ctrl_buf; | ||
| 403 | |||
| 404 | dr = (void *)(buffer + 2); | ||
| 405 | dr->bRequestType = ATEN_RD_RTYPE; | ||
| 406 | dr->bRequest = ATEN_RDREQ; | ||
| 407 | dr->wValue = cpu_to_le16(Wval); | ||
| 408 | dr->wIndex = cpu_to_le16(reg); | ||
| 409 | dr->wLength = cpu_to_le16(2); | ||
| 410 | |||
| 411 | usb_fill_control_urb(ATEN->control_urb, dev, usb_rcvctrlpipe(dev, 0), | ||
| 412 | (unsigned char *)dr, buffer, 2, | ||
| 413 | ATEN2011_control_callback, ATEN); | ||
| 414 | ATEN->control_urb->transfer_buffer_length = 2; | ||
| 415 | ret = usb_submit_urb(ATEN->control_urb, GFP_ATOMIC); | ||
| 416 | return ret; | ||
| 417 | } | ||
| 418 | |||
| 419 | static void ATEN2011_interrupt_callback(struct urb *urb) | ||
| 420 | { | ||
| 421 | int result; | ||
| 422 | int length; | ||
| 423 | struct ATENINTL_port *ATEN2011_port; | ||
| 424 | struct ATENINTL_serial *ATEN2011_serial; | ||
| 425 | struct usb_serial *serial; | ||
| 426 | __u16 Data; | ||
| 427 | unsigned char *data; | ||
| 428 | __u8 sp[5], st; | ||
| 429 | int i; | ||
| 430 | __u16 wval; | ||
| 431 | int minor; | ||
| 432 | |||
| 433 | dbg("%s", " : Entering"); | ||
| 434 | |||
| 435 | ATEN2011_serial = (struct ATENINTL_serial *)urb->context; | ||
| 436 | |||
| 437 | switch (urb->status) { | ||
| 438 | case 0: | ||
| 439 | /* success */ | ||
| 440 | break; | ||
| 441 | case -ECONNRESET: | ||
| 442 | case -ENOENT: | ||
| 443 | case -ESHUTDOWN: | ||
| 444 | /* this urb is terminated, clean up */ | ||
| 445 | dbg("%s - urb shutting down with status: %d", __func__, | ||
| 446 | urb->status); | ||
| 447 | return; | ||
| 448 | default: | ||
| 449 | dbg("%s - nonzero urb status received: %d", __func__, | ||
| 450 | urb->status); | ||
| 451 | goto exit; | ||
| 452 | } | ||
| 453 | length = urb->actual_length; | ||
| 454 | data = urb->transfer_buffer; | ||
| 455 | |||
| 456 | serial = ATEN2011_serial->serial; | ||
| 457 | |||
| 458 | /* ATENINTL get 5 bytes | ||
| 459 | * Byte 1 IIR Port 1 (port.number is 0) | ||
| 460 | * Byte 2 IIR Port 2 (port.number is 1) | ||
| 461 | * Byte 3 IIR Port 3 (port.number is 2) | ||
| 462 | * Byte 4 IIR Port 4 (port.number is 3) | ||
| 463 | * Byte 5 FIFO status for both */ | ||
| 464 | |||
| 465 | if (length && length > 5) { | ||
| 466 | dbg("%s", "Wrong data !!!"); | ||
| 467 | return; | ||
| 468 | } | ||
| 469 | |||
| 470 | /* MATRIX */ | ||
| 471 | if (ATEN2011_serial->ATEN2011_spectrum_2or4ports == 4) { | ||
| 472 | sp[0] = (__u8) data[0]; | ||
| 473 | sp[1] = (__u8) data[1]; | ||
| 474 | sp[2] = (__u8) data[2]; | ||
| 475 | sp[3] = (__u8) data[3]; | ||
| 476 | st = (__u8) data[4]; | ||
| 477 | } else { | ||
| 478 | sp[0] = (__u8) data[0]; | ||
| 479 | sp[1] = (__u8) data[2]; | ||
| 480 | /* sp[2]=(__u8)data[2]; */ | ||
| 481 | /* sp[3]=(__u8)data[3]; */ | ||
| 482 | st = (__u8) data[4]; | ||
| 483 | |||
| 484 | } | ||
| 485 | for (i = 0; i < serial->num_ports; i++) { | ||
| 486 | ATEN2011_port = usb_get_serial_port_data(serial->port[i]); | ||
| 487 | minor = serial->minor; | ||
| 488 | if (minor == SERIAL_TTY_NO_MINOR) | ||
| 489 | minor = 0; | ||
| 490 | if ((ATEN2011_serial->ATEN2011_spectrum_2or4ports == 2) | ||
| 491 | && (i != 0)) | ||
| 492 | wval = | ||
| 493 | (((__u16) serial->port[i]->number - | ||
| 494 | (__u16) (minor)) + 2) << 8; | ||
| 495 | else | ||
| 496 | wval = | ||
| 497 | (((__u16) serial->port[i]->number - | ||
| 498 | (__u16) (minor)) + 1) << 8; | ||
| 499 | if (ATEN2011_port->open != 0) { | ||
| 500 | if (sp[i] & 0x01) { | ||
| 501 | dbg("SP%d No Interrupt !!!", i); | ||
| 502 | } else { | ||
| 503 | switch (sp[i] & 0x0f) { | ||
| 504 | case SERIAL_IIR_RLS: | ||
| 505 | dbg("Serial Port %d: Receiver status error or address bit detected in 9-bit mode", i); | ||
| 506 | ATEN2011_port->MsrLsr = 1; | ||
| 507 | ATEN2011_get_reg(ATEN2011_port, wval, | ||
| 508 | LINE_STATUS_REGISTER, | ||
| 509 | &Data); | ||
| 510 | break; | ||
| 511 | case SERIAL_IIR_MS: | ||
| 512 | dbg("Serial Port %d: Modem status change", i); | ||
| 513 | ATEN2011_port->MsrLsr = 0; | ||
| 514 | ATEN2011_get_reg(ATEN2011_port, wval, | ||
| 515 | MODEM_STATUS_REGISTER, | ||
| 516 | &Data); | ||
| 517 | break; | ||
| 518 | } | ||
| 519 | } | ||
| 520 | } | ||
| 521 | |||
| 522 | } | ||
| 523 | exit: | ||
| 524 | if (ATEN2011_serial->status_polling_started == 0) | ||
| 525 | return; | ||
| 526 | |||
| 527 | result = usb_submit_urb(urb, GFP_ATOMIC); | ||
| 528 | if (result) { | ||
| 529 | dev_err(&urb->dev->dev, | ||
| 530 | "%s - Error %d submitting interrupt urb\n", | ||
| 531 | __func__, result); | ||
| 532 | } | ||
| 533 | |||
| 534 | return; | ||
| 535 | } | ||
| 536 | |||
| 537 | static void ATEN2011_bulk_in_callback(struct urb *urb) | ||
| 538 | { | ||
| 539 | int status; | ||
| 540 | unsigned char *data; | ||
| 541 | struct usb_serial *serial; | ||
| 542 | struct usb_serial_port *port; | ||
| 543 | struct ATENINTL_serial *ATEN2011_serial; | ||
| 544 | struct ATENINTL_port *ATEN2011_port; | ||
| 545 | struct tty_struct *tty; | ||
| 546 | |||
| 547 | if (urb->status) { | ||
| 548 | dbg("nonzero read bulk status received: %d", urb->status); | ||
| 549 | return; | ||
| 550 | } | ||
| 551 | |||
| 552 | ATEN2011_port = (struct ATENINTL_port *)urb->context; | ||
| 553 | |||
| 554 | port = (struct usb_serial_port *)ATEN2011_port->port; | ||
| 555 | serial = port->serial; | ||
| 556 | |||
| 557 | dbg("%s", "Entering..."); | ||
| 558 | |||
| 559 | data = urb->transfer_buffer; | ||
| 560 | ATEN2011_serial = usb_get_serial_data(serial); | ||
| 561 | |||
| 562 | if (urb->actual_length) { | ||
| 563 | tty = tty_port_tty_get(&ATEN2011_port->port->port); | ||
| 564 | if (tty) { | ||
| 565 | tty_buffer_request_room(tty, urb->actual_length); | ||
| 566 | tty_insert_flip_string(tty, data, urb->actual_length); | ||
| 567 | tty_flip_buffer_push(tty); | ||
| 568 | tty_kref_put(tty); | ||
| 569 | } | ||
| 570 | |||
| 571 | ATEN2011_port->icount.rx += urb->actual_length; | ||
| 572 | dbg("ATEN2011_port->icount.rx is %d:", | ||
| 573 | ATEN2011_port->icount.rx); | ||
| 574 | } | ||
| 575 | |||
| 576 | if (!ATEN2011_port->read_urb) { | ||
| 577 | dbg("%s", "URB KILLED !!!"); | ||
| 578 | return; | ||
| 579 | } | ||
| 580 | |||
| 581 | if (ATEN2011_port->read_urb->status != -EINPROGRESS) { | ||
| 582 | ATEN2011_port->read_urb->dev = serial->dev; | ||
| 583 | |||
| 584 | status = usb_submit_urb(ATEN2011_port->read_urb, GFP_ATOMIC); | ||
| 585 | if (status) | ||
| 586 | dbg("usb_submit_urb(read bulk) failed, status = %d", status); | ||
| 587 | } | ||
| 588 | } | ||
| 589 | |||
| 590 | static void ATEN2011_bulk_out_data_callback(struct urb *urb) | ||
| 591 | { | ||
| 592 | struct ATENINTL_port *ATEN2011_port; | ||
| 593 | struct tty_struct *tty; | ||
| 594 | |||
| 595 | if (urb->status) { | ||
| 596 | dbg("nonzero write bulk status received:%d", urb->status); | ||
| 597 | return; | ||
| 598 | } | ||
| 599 | |||
| 600 | ATEN2011_port = (struct ATENINTL_port *)urb->context; | ||
| 601 | |||
| 602 | dbg("%s", "Entering ........."); | ||
| 603 | |||
| 604 | tty = tty_port_tty_get(&ATEN2011_port->port->port); | ||
| 605 | |||
| 606 | if (tty && ATEN2011_port->open) | ||
| 607 | /* tell the tty driver that something has changed */ | ||
| 608 | tty_wakeup(tty); | ||
| 609 | |||
| 610 | /* schedule_work(&ATEN2011_port->port->work); */ | ||
| 611 | tty_kref_put(tty); | ||
| 612 | |||
| 613 | } | ||
| 614 | |||
| 615 | #ifdef ATENSerialProbe | ||
| 616 | static int ATEN2011_serial_probe(struct usb_serial *serial, | ||
| 617 | const struct usb_device_id *id) | ||
| 618 | { | ||
| 619 | |||
| 620 | /*need to implement the mode_reg reading and updating\ | ||
| 621 | structures usb_serial_ device_type\ | ||
| 622 | (i.e num_ports, num_bulkin,bulkout etc) */ | ||
| 623 | /* Also we can update the changes attach */ | ||
| 624 | return 1; | ||
| 625 | } | ||
| 626 | #endif | ||
| 627 | |||
| 628 | static int ATEN2011_open(struct tty_struct *tty, struct usb_serial_port *port, | ||
| 629 | struct file *filp) | ||
| 630 | { | ||
| 631 | int response; | ||
| 632 | int j; | ||
| 633 | struct usb_serial *serial; | ||
| 634 | struct urb *urb; | ||
| 635 | __u16 Data; | ||
| 636 | int status; | ||
| 637 | struct ATENINTL_serial *ATEN2011_serial; | ||
| 638 | struct ATENINTL_port *ATEN2011_port; | ||
| 639 | struct ktermios tmp_termios; | ||
| 640 | int minor; | ||
| 641 | |||
| 642 | serial = port->serial; | ||
| 643 | |||
| 644 | ATEN2011_port = usb_get_serial_port_data(port); | ||
| 645 | |||
| 646 | if (ATEN2011_port == NULL) | ||
| 647 | return -ENODEV; | ||
| 648 | |||
| 649 | ATEN2011_serial = usb_get_serial_data(serial); | ||
| 650 | if (ATEN2011_serial == NULL) | ||
| 651 | return -ENODEV; | ||
| 652 | |||
| 653 | /* increment the number of opened ports counter here */ | ||
| 654 | ATEN2011_serial->NoOfOpenPorts++; | ||
| 655 | |||
| 656 | usb_clear_halt(serial->dev, port->write_urb->pipe); | ||
| 657 | usb_clear_halt(serial->dev, port->read_urb->pipe); | ||
| 658 | |||
| 659 | /* Initialising the write urb pool */ | ||
| 660 | for (j = 0; j < NUM_URBS; ++j) { | ||
| 661 | urb = usb_alloc_urb(0, GFP_ATOMIC); | ||
| 662 | ATEN2011_port->write_urb_pool[j] = urb; | ||
| 663 | |||
| 664 | if (urb == NULL) { | ||
| 665 | err("No more urbs???"); | ||
| 666 | continue; | ||
| 667 | } | ||
| 668 | |||
| 669 | urb->transfer_buffer = NULL; | ||
| 670 | urb->transfer_buffer = | ||
| 671 | kmalloc(URB_TRANSFER_BUFFER_SIZE, GFP_KERNEL); | ||
| 672 | if (!urb->transfer_buffer) { | ||
| 673 | err("%s-out of memory for urb buffers.", __func__); | ||
| 674 | continue; | ||
| 675 | } | ||
| 676 | } | ||
| 677 | |||
| 678 | /***************************************************************************** | ||
| 679 | * Initialize ATEN2011 -- Write Init values to corresponding Registers | ||
| 680 | * | ||
| 681 | * Register Index | ||
| 682 | * 1 : IER | ||
| 683 | * 2 : FCR | ||
| 684 | * 3 : LCR | ||
| 685 | * 4 : MCR | ||
| 686 | * | ||
| 687 | * 0x08 : SP1/2 Control Reg | ||
| 688 | *****************************************************************************/ | ||
| 689 | |||
| 690 | /* NEED to check the fallowing Block */ | ||
| 691 | |||
| 692 | Data = 0x0; | ||
| 693 | status = get_reg_sync(port, ATEN2011_port->SpRegOffset, &Data); | ||
| 694 | if (status < 0) { | ||
| 695 | dbg("Reading Spreg failed"); | ||
| 696 | return -1; | ||
| 697 | } | ||
| 698 | Data |= 0x80; | ||
| 699 | status = set_reg_sync(port, ATEN2011_port->SpRegOffset, Data); | ||
| 700 | if (status < 0) { | ||
| 701 | dbg("writing Spreg failed"); | ||
| 702 | return -1; | ||
| 703 | } | ||
| 704 | |||
| 705 | Data &= ~0x80; | ||
| 706 | status = set_reg_sync(port, ATEN2011_port->SpRegOffset, Data); | ||
| 707 | if (status < 0) { | ||
| 708 | dbg("writing Spreg failed"); | ||
| 709 | return -1; | ||
| 710 | } | ||
| 711 | |||
| 712 | /* End of block to be checked */ | ||
| 713 | /**************************CHECK***************************/ | ||
| 714 | |||
| 715 | if (RS485mode == 0) | ||
| 716 | Data = 0xC0; | ||
| 717 | else | ||
| 718 | Data = 0x00; | ||
| 719 | status = set_uart_reg(port, SCRATCH_PAD_REGISTER, Data); | ||
| 720 | if (status < 0) { | ||
| 721 | dbg("Writing SCRATCH_PAD_REGISTER failed status-0x%x", status); | ||
| 722 | return -1; | ||
| 723 | } else | ||
| 724 | dbg("SCRATCH_PAD_REGISTER Writing success status%d", status); | ||
| 725 | |||
| 726 | /**************************CHECK***************************/ | ||
| 727 | |||
| 728 | Data = 0x0; | ||
| 729 | status = get_reg_sync(port, ATEN2011_port->ControlRegOffset, &Data); | ||
| 730 | if (status < 0) { | ||
| 731 | dbg("Reading Controlreg failed"); | ||
| 732 | return -1; | ||
| 733 | } | ||
| 734 | Data |= 0x08; /* Driver done bit */ | ||
| 735 | Data |= 0x20; /* rx_disable */ | ||
| 736 | status = 0; | ||
| 737 | status = | ||
| 738 | set_reg_sync(port, ATEN2011_port->ControlRegOffset, Data); | ||
| 739 | if (status < 0) { | ||
| 740 | dbg("writing Controlreg failed"); | ||
| 741 | return -1; | ||
| 742 | } | ||
| 743 | /* | ||
| 744 | * do register settings here | ||
| 745 | * Set all regs to the device default values. | ||
| 746 | * First Disable all interrupts. | ||
| 747 | */ | ||
| 748 | |||
| 749 | Data = 0x00; | ||
| 750 | status = set_uart_reg(port, INTERRUPT_ENABLE_REGISTER, Data); | ||
| 751 | if (status < 0) { | ||
| 752 | dbg("disableing interrupts failed"); | ||
| 753 | return -1; | ||
| 754 | } | ||
| 755 | /* Set FIFO_CONTROL_REGISTER to the default value */ | ||
| 756 | Data = 0x00; | ||
| 757 | status = set_uart_reg(port, FIFO_CONTROL_REGISTER, Data); | ||
| 758 | if (status < 0) { | ||
| 759 | dbg("Writing FIFO_CONTROL_REGISTER failed"); | ||
| 760 | return -1; | ||
| 761 | } | ||
| 762 | |||
| 763 | Data = 0xcf; /* chk */ | ||
| 764 | status = set_uart_reg(port, FIFO_CONTROL_REGISTER, Data); | ||
| 765 | if (status < 0) { | ||
| 766 | dbg("Writing FIFO_CONTROL_REGISTER failed"); | ||
| 767 | return -1; | ||
| 768 | } | ||
| 769 | |||
| 770 | Data = 0x03; /* LCR_BITS_8 */ | ||
| 771 | status = set_uart_reg(port, LINE_CONTROL_REGISTER, Data); | ||
| 772 | ATEN2011_port->shadowLCR = Data; | ||
| 773 | |||
| 774 | Data = 0x0b; /* MCR_DTR|MCR_RTS|MCR_MASTER_IE */ | ||
| 775 | status = set_uart_reg(port, MODEM_CONTROL_REGISTER, Data); | ||
| 776 | ATEN2011_port->shadowMCR = Data; | ||
| 777 | |||
| 778 | #ifdef Check | ||
| 779 | Data = 0x00; | ||
| 780 | status = get_uart_reg(port, LINE_CONTROL_REGISTER, &Data); | ||
| 781 | ATEN2011_port->shadowLCR = Data; | ||
| 782 | |||
| 783 | Data |= SERIAL_LCR_DLAB; /* data latch enable in LCR 0x80 */ | ||
| 784 | status = set_uart_reg(port, LINE_CONTROL_REGISTER, Data); | ||
| 785 | |||
| 786 | Data = 0x0c; | ||
| 787 | status = set_uart_reg(port, DIVISOR_LATCH_LSB, Data); | ||
| 788 | |||
| 789 | Data = 0x0; | ||
| 790 | status = set_uart_reg(port, DIVISOR_LATCH_MSB, Data); | ||
| 791 | |||
| 792 | Data = 0x00; | ||
| 793 | status = get_uart_reg(port, LINE_CONTROL_REGISTER, &Data); | ||
| 794 | |||
| 795 | /* Data = ATEN2011_port->shadowLCR; */ /* data latch disable */ | ||
| 796 | Data = Data & ~SERIAL_LCR_DLAB; | ||
| 797 | status = set_uart_reg(port, LINE_CONTROL_REGISTER, Data); | ||
| 798 | ATEN2011_port->shadowLCR = Data; | ||
| 799 | #endif | ||
| 800 | /* clearing Bulkin and Bulkout Fifo */ | ||
| 801 | Data = 0x0; | ||
| 802 | status = get_reg_sync(port, ATEN2011_port->SpRegOffset, &Data); | ||
| 803 | |||
| 804 | Data = Data | 0x0c; | ||
| 805 | status = set_reg_sync(port, ATEN2011_port->SpRegOffset, Data); | ||
| 806 | |||
| 807 | Data = Data & ~0x0c; | ||
| 808 | status = set_reg_sync(port, ATEN2011_port->SpRegOffset, Data); | ||
| 809 | /* Finally enable all interrupts */ | ||
| 810 | Data = 0x0; | ||
| 811 | Data = 0x0c; | ||
| 812 | status = set_uart_reg(port, INTERRUPT_ENABLE_REGISTER, Data); | ||
| 813 | |||
| 814 | /* clearing rx_disable */ | ||
| 815 | Data = 0x0; | ||
| 816 | status = get_reg_sync(port, ATEN2011_port->ControlRegOffset, &Data); | ||
| 817 | Data = Data & ~0x20; | ||
| 818 | status = set_reg_sync(port, ATEN2011_port->ControlRegOffset, Data); | ||
| 819 | |||
| 820 | /* rx_negate */ | ||
| 821 | Data = 0x0; | ||
| 822 | status = get_reg_sync(port, ATEN2011_port->ControlRegOffset, &Data); | ||
| 823 | Data = Data | 0x10; | ||
| 824 | status = 0; | ||
| 825 | status = set_reg_sync(port, ATEN2011_port->ControlRegOffset, Data); | ||
| 826 | |||
| 827 | /* | ||
| 828 | * Check to see if we've set up our endpoint info yet | ||
| 829 | * (can't set it up in ATEN2011_startup as the structures | ||
| 830 | * were not set up at that time.) | ||
| 831 | */ | ||
| 832 | if (ATEN2011_serial->NoOfOpenPorts == 1) { | ||
| 833 | /* start the status polling here */ | ||
| 834 | ATEN2011_serial->status_polling_started = 1; | ||
| 835 | /* If not yet set, Set here */ | ||
| 836 | ATEN2011_serial->interrupt_in_buffer = | ||
| 837 | serial->port[0]->interrupt_in_buffer; | ||
| 838 | ATEN2011_serial->interrupt_in_endpoint = | ||
| 839 | serial->port[0]->interrupt_in_endpointAddress; | ||
| 840 | ATEN2011_serial->interrupt_read_urb = | ||
| 841 | serial->port[0]->interrupt_in_urb; | ||
| 842 | |||
| 843 | /* set up interrupt urb */ | ||
| 844 | usb_fill_int_urb(ATEN2011_serial->interrupt_read_urb, | ||
| 845 | serial->dev, | ||
| 846 | usb_rcvintpipe(serial->dev, | ||
| 847 | ATEN2011_serial-> | ||
| 848 | interrupt_in_endpoint), | ||
| 849 | ATEN2011_serial->interrupt_in_buffer, | ||
| 850 | ATEN2011_serial->interrupt_read_urb-> | ||
| 851 | transfer_buffer_length, | ||
| 852 | ATEN2011_interrupt_callback, ATEN2011_serial, | ||
| 853 | ATEN2011_serial->interrupt_read_urb->interval); | ||
| 854 | |||
| 855 | /* start interrupt read for ATEN2011 * | ||
| 856 | * will continue as long as ATEN2011 is connected */ | ||
| 857 | |||
| 858 | response = | ||
| 859 | usb_submit_urb(ATEN2011_serial->interrupt_read_urb, | ||
| 860 | GFP_KERNEL); | ||
| 861 | if (response) { | ||
| 862 | dbg("%s - Error %d submitting interrupt urb", | ||
| 863 | __func__, response); | ||
| 864 | } | ||
| 865 | |||
| 866 | } | ||
| 867 | |||
| 868 | /* | ||
| 869 | * See if we've set up our endpoint info yet | ||
| 870 | * (can't set it up in ATEN2011_startup as the | ||
| 871 | * structures were not set up at that time.) | ||
| 872 | */ | ||
| 873 | |||
| 874 | dbg("port number is %d", port->number); | ||
| 875 | dbg("serial number is %d", port->serial->minor); | ||
| 876 | dbg("Bulkin endpoint is %d", port->bulk_in_endpointAddress); | ||
| 877 | dbg("BulkOut endpoint is %d", port->bulk_out_endpointAddress); | ||
| 878 | dbg("Interrupt endpoint is %d", | ||
| 879 | port->interrupt_in_endpointAddress); | ||
| 880 | dbg("port's number in the device is %d", ATEN2011_port->port_num); | ||
| 881 | ATEN2011_port->bulk_in_buffer = port->bulk_in_buffer; | ||
| 882 | ATEN2011_port->bulk_in_endpoint = port->bulk_in_endpointAddress; | ||
| 883 | ATEN2011_port->read_urb = port->read_urb; | ||
| 884 | ATEN2011_port->bulk_out_endpoint = port->bulk_out_endpointAddress; | ||
| 885 | |||
| 886 | minor = port->serial->minor; | ||
| 887 | if (minor == SERIAL_TTY_NO_MINOR) | ||
| 888 | minor = 0; | ||
| 889 | |||
| 890 | /* set up our bulk in urb */ | ||
| 891 | if ((ATEN2011_serial->ATEN2011_spectrum_2or4ports == 2) | ||
| 892 | && (((__u16) port->number - (__u16) (minor)) != 0)) { | ||
| 893 | usb_fill_bulk_urb(ATEN2011_port->read_urb, serial->dev, | ||
| 894 | usb_rcvbulkpipe(serial->dev, | ||
| 895 | (port-> | ||
| 896 | bulk_in_endpointAddress + | ||
| 897 | 2)), port->bulk_in_buffer, | ||
| 898 | ATEN2011_port->read_urb-> | ||
| 899 | transfer_buffer_length, | ||
| 900 | ATEN2011_bulk_in_callback, ATEN2011_port); | ||
| 901 | } else | ||
| 902 | usb_fill_bulk_urb(ATEN2011_port->read_urb, | ||
| 903 | serial->dev, | ||
| 904 | usb_rcvbulkpipe(serial->dev, | ||
| 905 | port-> | ||
| 906 | bulk_in_endpointAddress), | ||
| 907 | port->bulk_in_buffer, | ||
| 908 | ATEN2011_port->read_urb-> | ||
| 909 | transfer_buffer_length, | ||
| 910 | ATEN2011_bulk_in_callback, ATEN2011_port); | ||
| 911 | |||
| 912 | dbg("ATEN2011_open: bulkin endpoint is %d", | ||
| 913 | port->bulk_in_endpointAddress); | ||
| 914 | response = usb_submit_urb(ATEN2011_port->read_urb, GFP_KERNEL); | ||
| 915 | if (response) { | ||
| 916 | err("%s - Error %d submitting control urb", __func__, | ||
| 917 | response); | ||
| 918 | } | ||
| 919 | |||
| 920 | /* initialize our wait queues */ | ||
| 921 | init_waitqueue_head(&ATEN2011_port->wait_chase); | ||
| 922 | init_waitqueue_head(&ATEN2011_port->wait_command); | ||
| 923 | |||
| 924 | /* initialize our icount structure */ | ||
| 925 | memset(&(ATEN2011_port->icount), 0x00, sizeof(ATEN2011_port->icount)); | ||
| 926 | |||
| 927 | /* initialize our port settings */ | ||
| 928 | ATEN2011_port->shadowMCR = MCR_MASTER_IE; /* Must set to enable ints! */ | ||
| 929 | ATEN2011_port->chaseResponsePending = 0; | ||
| 930 | /* send a open port command */ | ||
| 931 | ATEN2011_port->open = 1; | ||
| 932 | /* ATEN2011_change_port_settings(ATEN2011_port,old_termios); */ | ||
| 933 | /* Setup termios */ | ||
| 934 | ATEN2011_set_termios(tty, port, &tmp_termios); | ||
| 935 | ATEN2011_port->icount.tx = 0; | ||
| 936 | ATEN2011_port->icount.rx = 0; | ||
| 937 | |||
| 938 | dbg("usb_serial serial:%x ATEN2011_port:%x\nATEN2011_serial:%x usb_serial_port port:%x", | ||
| 939 | (unsigned int)serial, (unsigned int)ATEN2011_port, | ||
| 940 | (unsigned int)ATEN2011_serial, (unsigned int)port); | ||
| 941 | |||
| 942 | return 0; | ||
| 943 | |||
| 944 | } | ||
| 945 | |||
| 946 | static int ATEN2011_chars_in_buffer(struct tty_struct *tty) | ||
| 947 | { | ||
| 948 | struct usb_serial_port *port = tty->driver_data; | ||
| 949 | int i; | ||
| 950 | int chars = 0; | ||
| 951 | struct ATENINTL_port *ATEN2011_port; | ||
| 952 | |||
| 953 | /* dbg("%s"," ATEN2011_chars_in_buffer:entering ..........."); */ | ||
| 954 | |||
| 955 | ATEN2011_port = usb_get_serial_port_data(port); | ||
| 956 | if (ATEN2011_port == NULL) { | ||
| 957 | dbg("%s", "ATEN2011_break:leaving ..........."); | ||
| 958 | return -1; | ||
| 959 | } | ||
| 960 | |||
| 961 | for (i = 0; i < NUM_URBS; ++i) | ||
| 962 | if (ATEN2011_port->write_urb_pool[i]->status == -EINPROGRESS) | ||
| 963 | chars += URB_TRANSFER_BUFFER_SIZE; | ||
| 964 | |||
| 965 | dbg("%s - returns %d", __func__, chars); | ||
| 966 | return chars; | ||
| 967 | |||
| 968 | } | ||
| 969 | |||
| 970 | static void ATEN2011_block_until_tx_empty(struct tty_struct *tty, | ||
| 971 | struct ATENINTL_port *ATEN2011_port) | ||
| 972 | { | ||
| 973 | int timeout = HZ / 10; | ||
| 974 | int wait = 30; | ||
| 975 | int count; | ||
| 976 | |||
| 977 | while (1) { | ||
| 978 | count = ATEN2011_chars_in_buffer(tty); | ||
| 979 | |||
| 980 | /* Check for Buffer status */ | ||
| 981 | if (count <= 0) | ||
| 982 | return; | ||
| 983 | |||
| 984 | /* Block the thread for a while */ | ||
| 985 | interruptible_sleep_on_timeout(&ATEN2011_port->wait_chase, | ||
| 986 | timeout); | ||
| 987 | |||
| 988 | /* No activity.. count down section */ | ||
| 989 | wait--; | ||
| 990 | if (wait == 0) { | ||
| 991 | dbg("%s - TIMEOUT", __func__); | ||
| 992 | return; | ||
| 993 | } else { | ||
| 994 | /* Reset timout value back to seconds */ | ||
| 995 | wait = 30; | ||
| 996 | } | ||
| 997 | } | ||
| 998 | } | ||
| 999 | |||
| 1000 | static void ATEN2011_close(struct tty_struct *tty, struct usb_serial_port *port, | ||
| 1001 | struct file *filp) | ||
| 1002 | { | ||
| 1003 | struct usb_serial *serial; | ||
| 1004 | struct ATENINTL_serial *ATEN2011_serial; | ||
| 1005 | struct ATENINTL_port *ATEN2011_port; | ||
| 1006 | int no_urbs; | ||
| 1007 | __u16 Data; | ||
| 1008 | |||
| 1009 | dbg("%s", "ATEN2011_close:entering..."); | ||
| 1010 | serial = port->serial; | ||
| 1011 | |||
| 1012 | /* take the Adpater and port's private data */ | ||
| 1013 | ATEN2011_serial = usb_get_serial_data(serial); | ||
| 1014 | ATEN2011_port = usb_get_serial_port_data(port); | ||
| 1015 | if ((ATEN2011_serial == NULL) || (ATEN2011_port == NULL)) | ||
| 1016 | return; | ||
| 1017 | |||
| 1018 | if (serial->dev) { | ||
| 1019 | /* flush and block(wait) until tx is empty */ | ||
| 1020 | ATEN2011_block_until_tx_empty(tty, ATEN2011_port); | ||
| 1021 | } | ||
| 1022 | /* kill the ports URB's */ | ||
| 1023 | for (no_urbs = 0; no_urbs < NUM_URBS; no_urbs++) | ||
| 1024 | usb_kill_urb(ATEN2011_port->write_urb_pool[no_urbs]); | ||
| 1025 | /* Freeing Write URBs */ | ||
| 1026 | for (no_urbs = 0; no_urbs < NUM_URBS; ++no_urbs) { | ||
| 1027 | kfree(ATEN2011_port->write_urb_pool[no_urbs]->transfer_buffer); | ||
| 1028 | usb_free_urb(ATEN2011_port->write_urb_pool[no_urbs]); | ||
| 1029 | } | ||
| 1030 | /* While closing port, shutdown all bulk read, write * | ||
| 1031 | * and interrupt read if they exists */ | ||
| 1032 | if (serial->dev) { | ||
| 1033 | if (ATEN2011_port->write_urb) { | ||
| 1034 | dbg("%s", "Shutdown bulk write"); | ||
| 1035 | usb_kill_urb(ATEN2011_port->write_urb); | ||
| 1036 | } | ||
| 1037 | if (ATEN2011_port->read_urb) { | ||
| 1038 | dbg("%s", "Shutdown bulk read"); | ||
| 1039 | usb_kill_urb(ATEN2011_port->read_urb); | ||
| 1040 | } | ||
| 1041 | if ((&ATEN2011_port->control_urb)) { | ||
| 1042 | dbg("%s", "Shutdown control read"); | ||
| 1043 | /* usb_kill_urb (ATEN2011_port->control_urb); */ | ||
| 1044 | |||
| 1045 | } | ||
| 1046 | } | ||
| 1047 | /* if(ATEN2011_port->ctrl_buf != NULL) */ | ||
| 1048 | /* kfree(ATEN2011_port->ctrl_buf); */ | ||
| 1049 | /* decrement the no.of open ports counter of an individual USB-serial adapter. */ | ||
| 1050 | ATEN2011_serial->NoOfOpenPorts--; | ||
| 1051 | dbg("NoOfOpenPorts in close%d:in port%d", | ||
| 1052 | ATEN2011_serial->NoOfOpenPorts, port->number); | ||
| 1053 | if (ATEN2011_serial->NoOfOpenPorts == 0) { | ||
| 1054 | /* stop the stus polling here */ | ||
| 1055 | ATEN2011_serial->status_polling_started = 0; | ||
| 1056 | if (ATEN2011_serial->interrupt_read_urb) { | ||
| 1057 | dbg("%s", "Shutdown interrupt_read_urb"); | ||
| 1058 | /* ATEN2011_serial->interrupt_in_buffer=NULL; */ | ||
| 1059 | /* usb_kill_urb (ATEN2011_serial->interrupt_read_urb); */ | ||
| 1060 | } | ||
| 1061 | } | ||
| 1062 | if (ATEN2011_port->write_urb) { | ||
| 1063 | /* if this urb had a transfer buffer already (old tx) free it */ | ||
| 1064 | kfree(ATEN2011_port->write_urb->transfer_buffer); | ||
| 1065 | usb_free_urb(ATEN2011_port->write_urb); | ||
| 1066 | } | ||
| 1067 | |||
| 1068 | /* clear the MCR & IER */ | ||
| 1069 | Data = 0x00; | ||
| 1070 | set_uart_reg(port, MODEM_CONTROL_REGISTER, Data); | ||
| 1071 | Data = 0x00; | ||
| 1072 | set_uart_reg(port, INTERRUPT_ENABLE_REGISTER, Data); | ||
| 1073 | |||
| 1074 | ATEN2011_port->open = 0; | ||
| 1075 | dbg("%s", "Leaving ............"); | ||
| 1076 | |||
| 1077 | } | ||
| 1078 | |||
| 1079 | static void ATEN2011_block_until_chase_response(struct tty_struct *tty, | ||
| 1080 | struct ATENINTL_port | ||
| 1081 | *ATEN2011_port) | ||
| 1082 | { | ||
| 1083 | int timeout = 1 * HZ; | ||
| 1084 | int wait = 10; | ||
| 1085 | int count; | ||
| 1086 | |||
| 1087 | while (1) { | ||
| 1088 | count = ATEN2011_chars_in_buffer(tty); | ||
| 1089 | |||
| 1090 | /* Check for Buffer status */ | ||
| 1091 | if (count <= 0) { | ||
| 1092 | ATEN2011_port->chaseResponsePending = 0; | ||
| 1093 | return; | ||
| 1094 | } | ||
| 1095 | |||
| 1096 | /* Block the thread for a while */ | ||
| 1097 | interruptible_sleep_on_timeout(&ATEN2011_port->wait_chase, | ||
| 1098 | timeout); | ||
| 1099 | /* No activity.. count down section */ | ||
| 1100 | wait--; | ||
| 1101 | if (wait == 0) { | ||
| 1102 | dbg("%s - TIMEOUT", __func__); | ||
| 1103 | return; | ||
| 1104 | } else { | ||
| 1105 | /* Reset timout value back to seconds */ | ||
| 1106 | wait = 10; | ||
| 1107 | } | ||
| 1108 | } | ||
| 1109 | |||
| 1110 | } | ||
| 1111 | |||
| 1112 | static void ATEN2011_break(struct tty_struct *tty, int break_state) | ||
| 1113 | { | ||
| 1114 | struct usb_serial_port *port = tty->driver_data; | ||
| 1115 | unsigned char data; | ||
| 1116 | struct usb_serial *serial; | ||
| 1117 | struct ATENINTL_serial *ATEN2011_serial; | ||
| 1118 | struct ATENINTL_port *ATEN2011_port; | ||
| 1119 | |||
| 1120 | dbg("%s", "Entering ..........."); | ||
| 1121 | dbg("ATEN2011_break: Start"); | ||
| 1122 | |||
| 1123 | serial = port->serial; | ||
| 1124 | |||
| 1125 | ATEN2011_serial = usb_get_serial_data(serial); | ||
| 1126 | ATEN2011_port = usb_get_serial_port_data(port); | ||
| 1127 | |||
| 1128 | if ((ATEN2011_serial == NULL) || (ATEN2011_port == NULL)) | ||
| 1129 | return; | ||
| 1130 | |||
| 1131 | /* flush and chase */ | ||
| 1132 | ATEN2011_port->chaseResponsePending = 1; | ||
| 1133 | |||
| 1134 | if (serial->dev) { | ||
| 1135 | /* flush and block until tx is empty */ | ||
| 1136 | ATEN2011_block_until_chase_response(tty, ATEN2011_port); | ||
| 1137 | } | ||
| 1138 | |||
| 1139 | if (break_state == -1) | ||
| 1140 | data = ATEN2011_port->shadowLCR | LCR_SET_BREAK; | ||
| 1141 | else | ||
| 1142 | data = ATEN2011_port->shadowLCR & ~LCR_SET_BREAK; | ||
| 1143 | |||
| 1144 | ATEN2011_port->shadowLCR = data; | ||
| 1145 | dbg("ATEN2011_break ATEN2011_port->shadowLCR is %x", | ||
| 1146 | ATEN2011_port->shadowLCR); | ||
| 1147 | set_uart_reg(port, LINE_CONTROL_REGISTER, ATEN2011_port->shadowLCR); | ||
| 1148 | |||
| 1149 | return; | ||
| 1150 | } | ||
| 1151 | |||
| 1152 | static int ATEN2011_write_room(struct tty_struct *tty) | ||
| 1153 | { | ||
| 1154 | struct usb_serial_port *port = tty->driver_data; | ||
| 1155 | int i; | ||
| 1156 | int room = 0; | ||
| 1157 | struct ATENINTL_port *ATEN2011_port; | ||
| 1158 | |||
| 1159 | ATEN2011_port = usb_get_serial_port_data(port); | ||
| 1160 | if (ATEN2011_port == NULL) { | ||
| 1161 | dbg("%s", "ATEN2011_break:leaving ..........."); | ||
| 1162 | return -1; | ||
| 1163 | } | ||
| 1164 | |||
| 1165 | for (i = 0; i < NUM_URBS; ++i) | ||
| 1166 | if (ATEN2011_port->write_urb_pool[i]->status != -EINPROGRESS) | ||
| 1167 | room += URB_TRANSFER_BUFFER_SIZE; | ||
| 1168 | |||
| 1169 | dbg("%s - returns %d", __func__, room); | ||
| 1170 | return room; | ||
| 1171 | |||
| 1172 | } | ||
| 1173 | |||
| 1174 | static int ATEN2011_write(struct tty_struct *tty, struct usb_serial_port *port, | ||
| 1175 | const unsigned char *data, int count) | ||
| 1176 | { | ||
| 1177 | int status; | ||
| 1178 | int i; | ||
| 1179 | int bytes_sent = 0; | ||
| 1180 | int transfer_size; | ||
| 1181 | int minor; | ||
| 1182 | |||
| 1183 | struct ATENINTL_port *ATEN2011_port; | ||
| 1184 | struct usb_serial *serial; | ||
| 1185 | struct ATENINTL_serial *ATEN2011_serial; | ||
| 1186 | struct urb *urb; | ||
| 1187 | const unsigned char *current_position = data; | ||
| 1188 | unsigned char *data1; | ||
| 1189 | dbg("%s", "entering ..........."); | ||
| 1190 | |||
| 1191 | serial = port->serial; | ||
| 1192 | |||
| 1193 | ATEN2011_port = usb_get_serial_port_data(port); | ||
| 1194 | if (ATEN2011_port == NULL) { | ||
| 1195 | dbg("%s", "ATEN2011_port is NULL"); | ||
| 1196 | return -1; | ||
| 1197 | } | ||
| 1198 | |||
| 1199 | ATEN2011_serial = usb_get_serial_data(serial); | ||
| 1200 | if (ATEN2011_serial == NULL) { | ||
| 1201 | dbg("%s", "ATEN2011_serial is NULL"); | ||
| 1202 | return -1; | ||
| 1203 | } | ||
| 1204 | |||
| 1205 | /* try to find a free urb in the list */ | ||
| 1206 | urb = NULL; | ||
| 1207 | |||
| 1208 | for (i = 0; i < NUM_URBS; ++i) { | ||
| 1209 | if (ATEN2011_port->write_urb_pool[i]->status != -EINPROGRESS) { | ||
| 1210 | urb = ATEN2011_port->write_urb_pool[i]; | ||
| 1211 | dbg("URB:%d", i); | ||
| 1212 | break; | ||
| 1213 | } | ||
| 1214 | } | ||
| 1215 | |||
| 1216 | if (urb == NULL) { | ||
| 1217 | dbg("%s - no more free urbs", __func__); | ||
| 1218 | goto exit; | ||
| 1219 | } | ||
| 1220 | |||
| 1221 | if (urb->transfer_buffer == NULL) { | ||
| 1222 | urb->transfer_buffer = | ||
| 1223 | kmalloc(URB_TRANSFER_BUFFER_SIZE, GFP_KERNEL); | ||
| 1224 | |||
| 1225 | if (urb->transfer_buffer == NULL) { | ||
| 1226 | err("%s no more kernel memory...", __func__); | ||
| 1227 | goto exit; | ||
| 1228 | } | ||
| 1229 | } | ||
| 1230 | transfer_size = min(count, URB_TRANSFER_BUFFER_SIZE); | ||
| 1231 | |||
| 1232 | memcpy(urb->transfer_buffer, current_position, transfer_size); | ||
| 1233 | /* usb_serial_debug_data (__FILE__, __func__, transfer_size, urb->transfer_buffer); */ | ||
| 1234 | |||
| 1235 | /* fill urb with data and submit */ | ||
| 1236 | minor = port->serial->minor; | ||
| 1237 | if (minor == SERIAL_TTY_NO_MINOR) | ||
| 1238 | minor = 0; | ||
| 1239 | if ((ATEN2011_serial->ATEN2011_spectrum_2or4ports == 2) | ||
| 1240 | && (((__u16) port->number - (__u16) (minor)) != 0)) { | ||
| 1241 | usb_fill_bulk_urb(urb, ATEN2011_serial->serial->dev, | ||
| 1242 | usb_sndbulkpipe(ATEN2011_serial->serial->dev, | ||
| 1243 | (port-> | ||
| 1244 | bulk_out_endpointAddress) + | ||
| 1245 | 2), urb->transfer_buffer, | ||
| 1246 | transfer_size, | ||
| 1247 | ATEN2011_bulk_out_data_callback, | ||
| 1248 | ATEN2011_port); | ||
| 1249 | } else | ||
| 1250 | |||
| 1251 | usb_fill_bulk_urb(urb, | ||
| 1252 | ATEN2011_serial->serial->dev, | ||
| 1253 | usb_sndbulkpipe(ATEN2011_serial->serial->dev, | ||
| 1254 | port-> | ||
| 1255 | bulk_out_endpointAddress), | ||
| 1256 | urb->transfer_buffer, transfer_size, | ||
| 1257 | ATEN2011_bulk_out_data_callback, | ||
| 1258 | ATEN2011_port); | ||
| 1259 | |||
| 1260 | data1 = urb->transfer_buffer; | ||
| 1261 | dbg("bulkout endpoint is %d", port->bulk_out_endpointAddress); | ||
| 1262 | /* for(i=0;i < urb->actual_length;i++) */ | ||
| 1263 | /* dbg("Data is %c ",data1[i]); */ | ||
| 1264 | |||
| 1265 | /* send it down the pipe */ | ||
| 1266 | status = usb_submit_urb(urb, GFP_ATOMIC); | ||
| 1267 | |||
| 1268 | if (status) { | ||
| 1269 | err("%s - usb_submit_urb(write bulk) failed with status = %d", | ||
| 1270 | __func__, status); | ||
| 1271 | bytes_sent = status; | ||
| 1272 | goto exit; | ||
| 1273 | } | ||
| 1274 | bytes_sent = transfer_size; | ||
| 1275 | ATEN2011_port->icount.tx += transfer_size; | ||
| 1276 | dbg("ATEN2011_port->icount.tx is %d:", ATEN2011_port->icount.tx); | ||
| 1277 | |||
| 1278 | exit: | ||
| 1279 | return bytes_sent; | ||
| 1280 | } | ||
| 1281 | |||
| 1282 | static void ATEN2011_throttle(struct tty_struct *tty) | ||
| 1283 | { | ||
| 1284 | struct usb_serial_port *port = tty->driver_data; | ||
| 1285 | struct ATENINTL_port *ATEN2011_port; | ||
| 1286 | int status; | ||
| 1287 | |||
| 1288 | dbg("- port %d", port->number); | ||
| 1289 | |||
| 1290 | ATEN2011_port = usb_get_serial_port_data(port); | ||
| 1291 | |||
| 1292 | if (ATEN2011_port == NULL) | ||
| 1293 | return; | ||
| 1294 | |||
| 1295 | if (!ATEN2011_port->open) { | ||
| 1296 | dbg("%s", "port not opened"); | ||
| 1297 | return; | ||
| 1298 | } | ||
| 1299 | |||
| 1300 | dbg("%s", "Entering .......... "); | ||
| 1301 | |||
| 1302 | if (!tty) { | ||
| 1303 | dbg("%s - no tty available", __func__); | ||
| 1304 | return; | ||
| 1305 | } | ||
| 1306 | |||
| 1307 | /* if we are implementing XON/XOFF, send the stop character */ | ||
| 1308 | if (I_IXOFF(tty)) { | ||
| 1309 | unsigned char stop_char = STOP_CHAR(tty); | ||
| 1310 | status = ATEN2011_write(tty, port, &stop_char, 1); | ||
| 1311 | if (status <= 0) | ||
| 1312 | return; | ||
| 1313 | } | ||
| 1314 | |||
| 1315 | /* if we are implementing RTS/CTS, toggle that line */ | ||
| 1316 | if (tty->termios->c_cflag & CRTSCTS) { | ||
| 1317 | ATEN2011_port->shadowMCR &= ~MCR_RTS; | ||
| 1318 | status = set_uart_reg(port, MODEM_CONTROL_REGISTER, | ||
| 1319 | ATEN2011_port->shadowMCR); | ||
| 1320 | if (status < 0) | ||
| 1321 | return; | ||
| 1322 | } | ||
| 1323 | |||
| 1324 | return; | ||
| 1325 | } | ||
| 1326 | |||
| 1327 | static void ATEN2011_unthrottle(struct tty_struct *tty) | ||
| 1328 | { | ||
| 1329 | struct usb_serial_port *port = tty->driver_data; | ||
| 1330 | int status; | ||
| 1331 | struct ATENINTL_port *ATEN2011_port = usb_get_serial_port_data(port); | ||
| 1332 | |||
| 1333 | if (ATEN2011_port == NULL) | ||
| 1334 | return; | ||
| 1335 | |||
| 1336 | if (!ATEN2011_port->open) { | ||
| 1337 | dbg("%s - port not opened", __func__); | ||
| 1338 | return; | ||
| 1339 | } | ||
| 1340 | |||
| 1341 | dbg("%s", "Entering .......... "); | ||
| 1342 | |||
| 1343 | if (!tty) { | ||
| 1344 | dbg("%s - no tty available", __func__); | ||
| 1345 | return; | ||
| 1346 | } | ||
| 1347 | |||
| 1348 | /* if we are implementing XON/XOFF, send the start character */ | ||
| 1349 | if (I_IXOFF(tty)) { | ||
| 1350 | unsigned char start_char = START_CHAR(tty); | ||
| 1351 | status = ATEN2011_write(tty, port, &start_char, 1); | ||
| 1352 | if (status <= 0) | ||
| 1353 | return; | ||
| 1354 | } | ||
| 1355 | |||
| 1356 | /* if we are implementing RTS/CTS, toggle that line */ | ||
| 1357 | if (tty->termios->c_cflag & CRTSCTS) { | ||
| 1358 | ATEN2011_port->shadowMCR |= MCR_RTS; | ||
| 1359 | status = set_uart_reg(port, MODEM_CONTROL_REGISTER, | ||
| 1360 | ATEN2011_port->shadowMCR); | ||
| 1361 | if (status < 0) | ||
| 1362 | return; | ||
| 1363 | } | ||
| 1364 | |||
| 1365 | return; | ||
| 1366 | } | ||
| 1367 | |||
| 1368 | static int ATEN2011_tiocmget(struct tty_struct *tty, struct file *file) | ||
| 1369 | { | ||
| 1370 | struct usb_serial_port *port = tty->driver_data; | ||
| 1371 | struct ATENINTL_port *ATEN2011_port; | ||
| 1372 | unsigned int result; | ||
| 1373 | __u16 msr; | ||
| 1374 | __u16 mcr; | ||
| 1375 | /* unsigned int mcr; */ | ||
| 1376 | int status = 0; | ||
| 1377 | ATEN2011_port = usb_get_serial_port_data(port); | ||
| 1378 | |||
| 1379 | dbg("%s - port %d", __func__, port->number); | ||
| 1380 | |||
| 1381 | if (ATEN2011_port == NULL) | ||
| 1382 | return -ENODEV; | ||
| 1383 | |||
| 1384 | status = get_uart_reg(port, MODEM_STATUS_REGISTER, &msr); | ||
| 1385 | status = get_uart_reg(port, MODEM_CONTROL_REGISTER, &mcr); | ||
| 1386 | /* mcr = ATEN2011_port->shadowMCR; */ | ||
| 1387 | /* COMMENT2: the Fallowing three line are commented for updating only MSR values */ | ||
| 1388 | result = ((mcr & MCR_DTR) ? TIOCM_DTR : 0) | ||
| 1389 | | ((mcr & MCR_RTS) ? TIOCM_RTS : 0) | ||
| 1390 | | ((mcr & MCR_LOOPBACK) ? TIOCM_LOOP : 0) | ||
| 1391 | | ((msr & ATEN2011_MSR_CTS) ? TIOCM_CTS : 0) | ||
| 1392 | | ((msr & ATEN2011_MSR_CD) ? TIOCM_CAR : 0) | ||
| 1393 | | ((msr & ATEN2011_MSR_RI) ? TIOCM_RI : 0) | ||
| 1394 | | ((msr & ATEN2011_MSR_DSR) ? TIOCM_DSR : 0); | ||
| 1395 | |||
| 1396 | dbg("%s - 0x%04X", __func__, result); | ||
| 1397 | |||
| 1398 | return result; | ||
| 1399 | } | ||
| 1400 | |||
| 1401 | static int ATEN2011_tiocmset(struct tty_struct *tty, struct file *file, | ||
| 1402 | unsigned int set, unsigned int clear) | ||
| 1403 | { | ||
| 1404 | struct usb_serial_port *port = tty->driver_data; | ||
| 1405 | struct ATENINTL_port *ATEN2011_port; | ||
| 1406 | unsigned int mcr; | ||
| 1407 | unsigned int status; | ||
| 1408 | |||
| 1409 | dbg("%s - port %d", __func__, port->number); | ||
| 1410 | |||
| 1411 | ATEN2011_port = usb_get_serial_port_data(port); | ||
| 1412 | |||
| 1413 | if (ATEN2011_port == NULL) | ||
| 1414 | return -ENODEV; | ||
| 1415 | |||
| 1416 | mcr = ATEN2011_port->shadowMCR; | ||
| 1417 | if (clear & TIOCM_RTS) | ||
| 1418 | mcr &= ~MCR_RTS; | ||
| 1419 | if (clear & TIOCM_DTR) | ||
| 1420 | mcr &= ~MCR_DTR; | ||
| 1421 | if (clear & TIOCM_LOOP) | ||
| 1422 | mcr &= ~MCR_LOOPBACK; | ||
| 1423 | |||
| 1424 | if (set & TIOCM_RTS) | ||
| 1425 | mcr |= MCR_RTS; | ||
| 1426 | if (set & TIOCM_DTR) | ||
| 1427 | mcr |= MCR_DTR; | ||
| 1428 | if (set & TIOCM_LOOP) | ||
| 1429 | mcr |= MCR_LOOPBACK; | ||
| 1430 | |||
| 1431 | ATEN2011_port->shadowMCR = mcr; | ||
| 1432 | |||
| 1433 | status = set_uart_reg(port, MODEM_CONTROL_REGISTER, mcr); | ||
| 1434 | if (status < 0) { | ||
| 1435 | dbg("setting MODEM_CONTROL_REGISTER Failed"); | ||
| 1436 | return -1; | ||
| 1437 | } | ||
| 1438 | |||
| 1439 | return 0; | ||
| 1440 | } | ||
| 1441 | |||
| 1442 | static void ATEN2011_set_termios(struct tty_struct *tty, | ||
| 1443 | struct usb_serial_port *port, | ||
| 1444 | struct ktermios *old_termios) | ||
| 1445 | { | ||
| 1446 | int status; | ||
| 1447 | unsigned int cflag; | ||
| 1448 | struct usb_serial *serial; | ||
| 1449 | struct ATENINTL_port *ATEN2011_port; | ||
| 1450 | |||
| 1451 | dbg("ATEN2011_set_termios: START"); | ||
| 1452 | |||
| 1453 | serial = port->serial; | ||
| 1454 | |||
| 1455 | ATEN2011_port = usb_get_serial_port_data(port); | ||
| 1456 | |||
| 1457 | if (ATEN2011_port == NULL) | ||
| 1458 | return; | ||
| 1459 | |||
| 1460 | if (!ATEN2011_port->open) { | ||
| 1461 | dbg("%s - port not opened", __func__); | ||
| 1462 | return; | ||
| 1463 | } | ||
| 1464 | |||
| 1465 | dbg("%s", "setting termios - "); | ||
| 1466 | |||
| 1467 | cflag = tty->termios->c_cflag; | ||
| 1468 | |||
| 1469 | dbg("%s - cflag %08x iflag %08x", __func__, | ||
| 1470 | tty->termios->c_cflag, RELEVANT_IFLAG(tty->termios->c_iflag)); | ||
| 1471 | |||
| 1472 | if (old_termios) { | ||
| 1473 | dbg("%s - old clfag %08x old iflag %08x", __func__, | ||
| 1474 | old_termios->c_cflag, RELEVANT_IFLAG(old_termios->c_iflag)); | ||
| 1475 | } | ||
| 1476 | |||
| 1477 | dbg("%s - port %d", __func__, port->number); | ||
| 1478 | |||
| 1479 | /* change the port settings to the new ones specified */ | ||
| 1480 | |||
| 1481 | ATEN2011_change_port_settings(tty, ATEN2011_port, old_termios); | ||
| 1482 | |||
| 1483 | if (!ATEN2011_port->read_urb) { | ||
| 1484 | dbg("%s", "URB KILLED !!!!!"); | ||
| 1485 | return; | ||
| 1486 | } | ||
| 1487 | |||
| 1488 | if (ATEN2011_port->read_urb->status != -EINPROGRESS) { | ||
| 1489 | ATEN2011_port->read_urb->dev = serial->dev; | ||
| 1490 | status = usb_submit_urb(ATEN2011_port->read_urb, GFP_ATOMIC); | ||
| 1491 | if (status) { | ||
| 1492 | dbg | ||
| 1493 | (" usb_submit_urb(read bulk) failed, status = %d", | ||
| 1494 | status); | ||
| 1495 | } | ||
| 1496 | } | ||
| 1497 | return; | ||
| 1498 | } | ||
| 1499 | |||
| 1500 | static int get_lsr_info(struct tty_struct *tty, | ||
| 1501 | struct ATENINTL_port *ATEN2011_port, | ||
| 1502 | unsigned int __user *value) | ||
| 1503 | { | ||
| 1504 | int count; | ||
| 1505 | unsigned int result = 0; | ||
| 1506 | |||
| 1507 | count = ATEN2011_chars_in_buffer(tty); | ||
| 1508 | if (count == 0) { | ||
| 1509 | dbg("%s -- Empty", __func__); | ||
| 1510 | result = TIOCSER_TEMT; | ||
| 1511 | } | ||
| 1512 | |||
| 1513 | if (copy_to_user(value, &result, sizeof(int))) | ||
| 1514 | return -EFAULT; | ||
| 1515 | return 0; | ||
| 1516 | } | ||
| 1517 | |||
| 1518 | static int get_number_bytes_avail(struct tty_struct *tty, | ||
| 1519 | struct ATENINTL_port *ATEN2011_port, | ||
| 1520 | unsigned int __user *value) | ||
| 1521 | { | ||
| 1522 | unsigned int result = 0; | ||
| 1523 | |||
| 1524 | if (!tty) | ||
| 1525 | return -ENOIOCTLCMD; | ||
| 1526 | |||
| 1527 | result = tty->read_cnt; | ||
| 1528 | |||
| 1529 | dbg("%s(%d) = %d", __func__, ATEN2011_port->port->number, result); | ||
| 1530 | if (copy_to_user(value, &result, sizeof(int))) | ||
| 1531 | return -EFAULT; | ||
| 1532 | |||
| 1533 | return -ENOIOCTLCMD; | ||
| 1534 | } | ||
| 1535 | |||
| 1536 | static int set_modem_info(struct ATENINTL_port *ATEN2011_port, unsigned int cmd, | ||
| 1537 | unsigned int __user *value) | ||
| 1538 | { | ||
| 1539 | unsigned int mcr; | ||
| 1540 | unsigned int arg; | ||
| 1541 | __u16 Data; | ||
| 1542 | int status; | ||
| 1543 | struct usb_serial_port *port; | ||
| 1544 | |||
| 1545 | if (ATEN2011_port == NULL) | ||
| 1546 | return -1; | ||
| 1547 | |||
| 1548 | port = (struct usb_serial_port *)ATEN2011_port->port; | ||
| 1549 | |||
| 1550 | mcr = ATEN2011_port->shadowMCR; | ||
| 1551 | |||
| 1552 | if (copy_from_user(&arg, value, sizeof(int))) | ||
| 1553 | return -EFAULT; | ||
| 1554 | |||
| 1555 | switch (cmd) { | ||
| 1556 | case TIOCMBIS: | ||
| 1557 | if (arg & TIOCM_RTS) | ||
| 1558 | mcr |= MCR_RTS; | ||
| 1559 | if (arg & TIOCM_DTR) | ||
| 1560 | mcr |= MCR_RTS; | ||
| 1561 | if (arg & TIOCM_LOOP) | ||
| 1562 | mcr |= MCR_LOOPBACK; | ||
| 1563 | break; | ||
| 1564 | |||
| 1565 | case TIOCMBIC: | ||
| 1566 | if (arg & TIOCM_RTS) | ||
| 1567 | mcr &= ~MCR_RTS; | ||
| 1568 | if (arg & TIOCM_DTR) | ||
| 1569 | mcr &= ~MCR_RTS; | ||
| 1570 | if (arg & TIOCM_LOOP) | ||
| 1571 | mcr &= ~MCR_LOOPBACK; | ||
| 1572 | break; | ||
| 1573 | |||
| 1574 | case TIOCMSET: | ||
| 1575 | /* turn off the RTS and DTR and LOOPBACK | ||
| 1576 | * and then only turn on what was asked to */ | ||
| 1577 | mcr &= ~(MCR_RTS | MCR_DTR | MCR_LOOPBACK); | ||
| 1578 | mcr |= ((arg & TIOCM_RTS) ? MCR_RTS : 0); | ||
| 1579 | mcr |= ((arg & TIOCM_DTR) ? MCR_DTR : 0); | ||
| 1580 | mcr |= ((arg & TIOCM_LOOP) ? MCR_LOOPBACK : 0); | ||
| 1581 | break; | ||
| 1582 | } | ||
| 1583 | |||
| 1584 | ATEN2011_port->shadowMCR = mcr; | ||
| 1585 | |||
| 1586 | Data = ATEN2011_port->shadowMCR; | ||
| 1587 | status = set_uart_reg(port, MODEM_CONTROL_REGISTER, Data); | ||
| 1588 | if (status < 0) { | ||
| 1589 | dbg("setting MODEM_CONTROL_REGISTER Failed"); | ||
| 1590 | return -1; | ||
| 1591 | } | ||
| 1592 | |||
| 1593 | return 0; | ||
| 1594 | } | ||
| 1595 | |||
| 1596 | static int get_modem_info(struct ATENINTL_port *ATEN2011_port, | ||
| 1597 | unsigned int __user *value) | ||
| 1598 | { | ||
| 1599 | unsigned int result = 0; | ||
| 1600 | __u16 msr; | ||
| 1601 | unsigned int mcr = ATEN2011_port->shadowMCR; | ||
| 1602 | int status; | ||
| 1603 | |||
| 1604 | status = get_uart_reg(ATEN2011_port->port, MODEM_STATUS_REGISTER, &msr); | ||
| 1605 | result = ((mcr & MCR_DTR) ? TIOCM_DTR : 0) /* 0x002 */ | ||
| 1606 | |((mcr & MCR_RTS) ? TIOCM_RTS : 0) /* 0x004 */ | ||
| 1607 | |((msr & ATEN2011_MSR_CTS) ? TIOCM_CTS : 0) /* 0x020 */ | ||
| 1608 | |((msr & ATEN2011_MSR_CD) ? TIOCM_CAR : 0) /* 0x040 */ | ||
| 1609 | |((msr & ATEN2011_MSR_RI) ? TIOCM_RI : 0) /* 0x080 */ | ||
| 1610 | |((msr & ATEN2011_MSR_DSR) ? TIOCM_DSR : 0); /* 0x100 */ | ||
| 1611 | |||
| 1612 | dbg("%s -- %x", __func__, result); | ||
| 1613 | |||
| 1614 | if (copy_to_user(value, &result, sizeof(int))) | ||
| 1615 | return -EFAULT; | ||
| 1616 | return 0; | ||
| 1617 | } | ||
| 1618 | |||
| 1619 | static int get_serial_info(struct ATENINTL_port *ATEN2011_port, | ||
| 1620 | struct serial_struct __user *retinfo) | ||
| 1621 | { | ||
| 1622 | struct serial_struct tmp; | ||
| 1623 | |||
| 1624 | if (ATEN2011_port == NULL) | ||
| 1625 | return -1; | ||
| 1626 | |||
| 1627 | if (!retinfo) | ||
| 1628 | return -EFAULT; | ||
| 1629 | |||
| 1630 | memset(&tmp, 0, sizeof(tmp)); | ||
| 1631 | |||
| 1632 | tmp.type = PORT_16550A; | ||
| 1633 | tmp.line = ATEN2011_port->port->serial->minor; | ||
| 1634 | if (tmp.line == SERIAL_TTY_NO_MINOR) | ||
| 1635 | tmp.line = 0; | ||
| 1636 | tmp.port = ATEN2011_port->port->number; | ||
| 1637 | tmp.irq = 0; | ||
| 1638 | tmp.flags = ASYNC_SKIP_TEST | ASYNC_AUTO_IRQ; | ||
| 1639 | tmp.xmit_fifo_size = NUM_URBS * URB_TRANSFER_BUFFER_SIZE; | ||
| 1640 | tmp.baud_base = 9600; | ||
| 1641 | tmp.close_delay = 5 * HZ; | ||
| 1642 | tmp.closing_wait = 30 * HZ; | ||
| 1643 | |||
| 1644 | if (copy_to_user(retinfo, &tmp, sizeof(*retinfo))) | ||
| 1645 | return -EFAULT; | ||
| 1646 | return 0; | ||
| 1647 | } | ||
| 1648 | |||
| 1649 | static int ATEN2011_ioctl(struct tty_struct *tty, struct file *file, | ||
| 1650 | unsigned int cmd, unsigned long arg) | ||
| 1651 | { | ||
| 1652 | struct usb_serial_port *port = tty->driver_data; | ||
| 1653 | struct ATENINTL_port *ATEN2011_port; | ||
| 1654 | struct async_icount cnow; | ||
| 1655 | struct async_icount cprev; | ||
| 1656 | struct serial_icounter_struct icount; | ||
| 1657 | int ATENret = 0; | ||
| 1658 | unsigned int __user *user_arg = (unsigned int __user *)arg; | ||
| 1659 | |||
| 1660 | ATEN2011_port = usb_get_serial_port_data(port); | ||
| 1661 | |||
| 1662 | if (ATEN2011_port == NULL) | ||
| 1663 | return -1; | ||
| 1664 | |||
| 1665 | dbg("%s - port %d, cmd = 0x%x", __func__, port->number, cmd); | ||
| 1666 | |||
| 1667 | switch (cmd) { | ||
| 1668 | /* return number of bytes available */ | ||
| 1669 | |||
| 1670 | case TIOCINQ: | ||
| 1671 | dbg("%s (%d) TIOCINQ", __func__, port->number); | ||
| 1672 | return get_number_bytes_avail(tty, ATEN2011_port, user_arg); | ||
| 1673 | break; | ||
| 1674 | |||
| 1675 | case TIOCOUTQ: | ||
| 1676 | dbg("%s (%d) TIOCOUTQ", __func__, port->number); | ||
| 1677 | return put_user(ATEN2011_chars_in_buffer(tty), user_arg); | ||
| 1678 | break; | ||
| 1679 | |||
| 1680 | case TIOCSERGETLSR: | ||
| 1681 | dbg("%s (%d) TIOCSERGETLSR", __func__, port->number); | ||
| 1682 | return get_lsr_info(tty, ATEN2011_port, user_arg); | ||
| 1683 | return 0; | ||
| 1684 | |||
| 1685 | case TIOCMBIS: | ||
| 1686 | case TIOCMBIC: | ||
| 1687 | case TIOCMSET: | ||
| 1688 | dbg("%s (%d) TIOCMSET/TIOCMBIC/TIOCMSET", __func__, | ||
| 1689 | port->number); | ||
| 1690 | ATENret = set_modem_info(ATEN2011_port, cmd, user_arg); | ||
| 1691 | return ATENret; | ||
| 1692 | |||
| 1693 | case TIOCMGET: | ||
| 1694 | dbg("%s (%d) TIOCMGET", __func__, port->number); | ||
| 1695 | return get_modem_info(ATEN2011_port, user_arg); | ||
| 1696 | |||
| 1697 | case TIOCGSERIAL: | ||
| 1698 | dbg("%s (%d) TIOCGSERIAL", __func__, port->number); | ||
| 1699 | return get_serial_info(ATEN2011_port, | ||
| 1700 | (struct serial_struct __user *)arg); | ||
| 1701 | |||
| 1702 | case TIOCSSERIAL: | ||
| 1703 | dbg("%s (%d) TIOCSSERIAL", __func__, port->number); | ||
| 1704 | break; | ||
| 1705 | |||
| 1706 | case TIOCMIWAIT: | ||
| 1707 | dbg("%s (%d) TIOCMIWAIT", __func__, port->number); | ||
| 1708 | cprev = ATEN2011_port->icount; | ||
| 1709 | while (1) { | ||
| 1710 | /* see if a signal did it */ | ||
| 1711 | if (signal_pending(current)) | ||
| 1712 | return -ERESTARTSYS; | ||
| 1713 | cnow = ATEN2011_port->icount; | ||
| 1714 | if (cnow.rng == cprev.rng && cnow.dsr == cprev.dsr && | ||
| 1715 | cnow.dcd == cprev.dcd && cnow.cts == cprev.cts) | ||
| 1716 | return -EIO; /* no change => error */ | ||
| 1717 | if (((arg & TIOCM_RNG) && (cnow.rng != cprev.rng)) || | ||
| 1718 | ((arg & TIOCM_DSR) && (cnow.dsr != cprev.dsr)) || | ||
| 1719 | ((arg & TIOCM_CD) && (cnow.dcd != cprev.dcd)) || | ||
| 1720 | ((arg & TIOCM_CTS) && (cnow.cts != cprev.cts))) { | ||
| 1721 | return 0; | ||
| 1722 | } | ||
| 1723 | cprev = cnow; | ||
| 1724 | } | ||
| 1725 | /* NOTREACHED */ | ||
| 1726 | break; | ||
| 1727 | |||
| 1728 | case TIOCGICOUNT: | ||
| 1729 | cnow = ATEN2011_port->icount; | ||
| 1730 | icount.cts = cnow.cts; | ||
| 1731 | icount.dsr = cnow.dsr; | ||
| 1732 | icount.rng = cnow.rng; | ||
| 1733 | icount.dcd = cnow.dcd; | ||
| 1734 | icount.rx = cnow.rx; | ||
| 1735 | icount.tx = cnow.tx; | ||
| 1736 | icount.frame = cnow.frame; | ||
| 1737 | icount.overrun = cnow.overrun; | ||
| 1738 | icount.parity = cnow.parity; | ||
| 1739 | icount.brk = cnow.brk; | ||
| 1740 | icount.buf_overrun = cnow.buf_overrun; | ||
| 1741 | |||
| 1742 | dbg("%s (%d) TIOCGICOUNT RX=%d, TX=%d", __func__, | ||
| 1743 | port->number, icount.rx, icount.tx); | ||
| 1744 | if (copy_to_user((void __user *)arg, &icount, sizeof(icount))) | ||
| 1745 | return -EFAULT; | ||
| 1746 | return 0; | ||
| 1747 | |||
| 1748 | default: | ||
| 1749 | break; | ||
| 1750 | } | ||
| 1751 | |||
| 1752 | return -ENOIOCTLCMD; | ||
| 1753 | } | ||
| 1754 | |||
| 1755 | static int ATEN2011_calc_baud_rate_divisor(int baudRate, int *divisor, | ||
| 1756 | __u16 *clk_sel_val) | ||
| 1757 | { | ||
| 1758 | dbg("%s - %d", __func__, baudRate); | ||
| 1759 | |||
| 1760 | if (baudRate <= 115200) { | ||
| 1761 | *divisor = 115200 / baudRate; | ||
| 1762 | *clk_sel_val = 0x0; | ||
| 1763 | } | ||
| 1764 | if ((baudRate > 115200) && (baudRate <= 230400)) { | ||
| 1765 | *divisor = 230400 / baudRate; | ||
| 1766 | *clk_sel_val = 0x10; | ||
| 1767 | } else if ((baudRate > 230400) && (baudRate <= 403200)) { | ||
| 1768 | *divisor = 403200 / baudRate; | ||
| 1769 | *clk_sel_val = 0x20; | ||
| 1770 | } else if ((baudRate > 403200) && (baudRate <= 460800)) { | ||
| 1771 | *divisor = 460800 / baudRate; | ||
| 1772 | *clk_sel_val = 0x30; | ||
| 1773 | } else if ((baudRate > 460800) && (baudRate <= 806400)) { | ||
| 1774 | *divisor = 806400 / baudRate; | ||
| 1775 | *clk_sel_val = 0x40; | ||
| 1776 | } else if ((baudRate > 806400) && (baudRate <= 921600)) { | ||
| 1777 | *divisor = 921600 / baudRate; | ||
| 1778 | *clk_sel_val = 0x50; | ||
| 1779 | } else if ((baudRate > 921600) && (baudRate <= 1572864)) { | ||
| 1780 | *divisor = 1572864 / baudRate; | ||
| 1781 | *clk_sel_val = 0x60; | ||
| 1782 | } else if ((baudRate > 1572864) && (baudRate <= 3145728)) { | ||
| 1783 | *divisor = 3145728 / baudRate; | ||
| 1784 | *clk_sel_val = 0x70; | ||
| 1785 | } | ||
| 1786 | return 0; | ||
| 1787 | } | ||
| 1788 | |||
| 1789 | static int ATEN2011_send_cmd_write_baud_rate(struct ATENINTL_port | ||
| 1790 | *ATEN2011_port, int baudRate) | ||
| 1791 | { | ||
| 1792 | int divisor = 0; | ||
| 1793 | int status; | ||
| 1794 | __u16 Data; | ||
| 1795 | unsigned char number; | ||
| 1796 | __u16 clk_sel_val; | ||
| 1797 | struct usb_serial_port *port; | ||
| 1798 | int minor; | ||
| 1799 | |||
| 1800 | if (ATEN2011_port == NULL) | ||
| 1801 | return -1; | ||
| 1802 | |||
| 1803 | port = (struct usb_serial_port *)ATEN2011_port->port; | ||
| 1804 | |||
| 1805 | dbg("%s", "Entering .......... "); | ||
| 1806 | |||
| 1807 | minor = ATEN2011_port->port->serial->minor; | ||
| 1808 | if (minor == SERIAL_TTY_NO_MINOR) | ||
| 1809 | minor = 0; | ||
| 1810 | number = ATEN2011_port->port->number - minor; | ||
| 1811 | |||
| 1812 | dbg("%s - port = %d, baud = %d", __func__, | ||
| 1813 | ATEN2011_port->port->number, baudRate); | ||
| 1814 | /* reset clk_uart_sel in spregOffset */ | ||
| 1815 | if (baudRate > 115200) { | ||
| 1816 | #ifdef HW_flow_control | ||
| 1817 | /* | ||
| 1818 | * NOTE: need to see the pther register to modify | ||
| 1819 | * setting h/w flow control bit to 1; | ||
| 1820 | */ | ||
| 1821 | /* Data = ATEN2011_port->shadowMCR; */ | ||
| 1822 | Data = 0x2b; | ||
| 1823 | ATEN2011_port->shadowMCR = Data; | ||
| 1824 | status = set_uart_reg(port, MODEM_CONTROL_REGISTER, Data); | ||
| 1825 | if (status < 0) { | ||
| 1826 | dbg("Writing spreg failed in set_serial_baud"); | ||
| 1827 | return -1; | ||
| 1828 | } | ||
| 1829 | #endif | ||
| 1830 | |||
| 1831 | } else { | ||
| 1832 | #ifdef HW_flow_control | ||
| 1833 | /* setting h/w flow control bit to 0; */ | ||
| 1834 | /* Data = ATEN2011_port->shadowMCR; */ | ||
| 1835 | Data = 0xb; | ||
| 1836 | ATEN2011_port->shadowMCR = Data; | ||
| 1837 | status = set_uart_reg(port, MODEM_CONTROL_REGISTER, Data); | ||
| 1838 | if (status < 0) { | ||
| 1839 | dbg("Writing spreg failed in set_serial_baud"); | ||
| 1840 | return -1; | ||
| 1841 | } | ||
| 1842 | #endif | ||
| 1843 | |||
| 1844 | } | ||
| 1845 | |||
| 1846 | if (1) /* baudRate <= 115200) */ { | ||
| 1847 | clk_sel_val = 0x0; | ||
| 1848 | Data = 0x0; | ||
| 1849 | status = | ||
| 1850 | ATEN2011_calc_baud_rate_divisor(baudRate, &divisor, | ||
| 1851 | &clk_sel_val); | ||
| 1852 | status = get_reg_sync(port, ATEN2011_port->SpRegOffset, &Data); | ||
| 1853 | if (status < 0) { | ||
| 1854 | dbg("reading spreg failed in set_serial_baud"); | ||
| 1855 | return -1; | ||
| 1856 | } | ||
| 1857 | Data = (Data & 0x8f) | clk_sel_val; | ||
| 1858 | status = set_reg_sync(port, ATEN2011_port->SpRegOffset, Data); | ||
| 1859 | if (status < 0) { | ||
| 1860 | dbg("Writing spreg failed in set_serial_baud"); | ||
| 1861 | return -1; | ||
| 1862 | } | ||
| 1863 | /* Calculate the Divisor */ | ||
| 1864 | |||
| 1865 | if (status) { | ||
| 1866 | err("%s - bad baud rate", __func__); | ||
| 1867 | dbg("%s", "bad baud rate"); | ||
| 1868 | return status; | ||
| 1869 | } | ||
| 1870 | /* Enable access to divisor latch */ | ||
| 1871 | Data = ATEN2011_port->shadowLCR | SERIAL_LCR_DLAB; | ||
| 1872 | ATEN2011_port->shadowLCR = Data; | ||
| 1873 | set_uart_reg(port, LINE_CONTROL_REGISTER, Data); | ||
| 1874 | |||
| 1875 | /* Write the divisor */ | ||
| 1876 | Data = (unsigned char)(divisor & 0xff); | ||
| 1877 | dbg("set_serial_baud Value to write DLL is %x", Data); | ||
| 1878 | set_uart_reg(port, DIVISOR_LATCH_LSB, Data); | ||
| 1879 | |||
| 1880 | Data = (unsigned char)((divisor & 0xff00) >> 8); | ||
| 1881 | dbg("set_serial_baud Value to write DLM is %x", Data); | ||
| 1882 | set_uart_reg(port, DIVISOR_LATCH_MSB, Data); | ||
| 1883 | |||
| 1884 | /* Disable access to divisor latch */ | ||
| 1885 | Data = ATEN2011_port->shadowLCR & ~SERIAL_LCR_DLAB; | ||
| 1886 | ATEN2011_port->shadowLCR = Data; | ||
| 1887 | set_uart_reg(port, LINE_CONTROL_REGISTER, Data); | ||
| 1888 | |||
| 1889 | } | ||
| 1890 | |||
| 1891 | return status; | ||
| 1892 | } | ||
| 1893 | |||
| 1894 | static void ATEN2011_change_port_settings(struct tty_struct *tty, | ||
| 1895 | struct ATENINTL_port *ATEN2011_port, | ||
| 1896 | struct ktermios *old_termios) | ||
| 1897 | { | ||
| 1898 | int baud; | ||
| 1899 | unsigned cflag; | ||
| 1900 | unsigned iflag; | ||
| 1901 | __u8 lData; | ||
| 1902 | __u8 lParity; | ||
| 1903 | __u8 lStop; | ||
| 1904 | int status; | ||
| 1905 | __u16 Data; | ||
| 1906 | struct usb_serial_port *port; | ||
| 1907 | struct usb_serial *serial; | ||
| 1908 | |||
| 1909 | if (ATEN2011_port == NULL) | ||
| 1910 | return; | ||
| 1911 | |||
| 1912 | port = (struct usb_serial_port *)ATEN2011_port->port; | ||
| 1913 | |||
| 1914 | serial = port->serial; | ||
| 1915 | |||
| 1916 | dbg("%s - port %d", __func__, ATEN2011_port->port->number); | ||
| 1917 | |||
| 1918 | if (!ATEN2011_port->open) { | ||
| 1919 | dbg("%s - port not opened", __func__); | ||
| 1920 | return; | ||
| 1921 | } | ||
| 1922 | |||
| 1923 | if ((!tty) || (!tty->termios)) { | ||
| 1924 | dbg("%s - no tty structures", __func__); | ||
| 1925 | return; | ||
| 1926 | } | ||
| 1927 | |||
| 1928 | dbg("%s", "Entering .......... "); | ||
| 1929 | |||
| 1930 | lData = LCR_BITS_8; | ||
| 1931 | lStop = LCR_STOP_1; | ||
| 1932 | lParity = LCR_PAR_NONE; | ||
| 1933 | |||
| 1934 | cflag = tty->termios->c_cflag; | ||
| 1935 | iflag = tty->termios->c_iflag; | ||
| 1936 | |||
| 1937 | /* Change the number of bits */ | ||
| 1938 | |||
| 1939 | /* COMMENT1: the below Line"if(cflag & CSIZE)" is added for the errors we get for serial loop data test i.e serial_loopback.pl -v */ | ||
| 1940 | /* if(cflag & CSIZE) */ | ||
| 1941 | { | ||
| 1942 | switch (cflag & CSIZE) { | ||
| 1943 | case CS5: | ||
| 1944 | lData = LCR_BITS_5; | ||
| 1945 | break; | ||
| 1946 | |||
| 1947 | case CS6: | ||
| 1948 | lData = LCR_BITS_6; | ||
| 1949 | break; | ||
| 1950 | |||
| 1951 | case CS7: | ||
| 1952 | lData = LCR_BITS_7; | ||
| 1953 | break; | ||
| 1954 | default: | ||
| 1955 | case CS8: | ||
| 1956 | lData = LCR_BITS_8; | ||
| 1957 | break; | ||
| 1958 | } | ||
| 1959 | } | ||
| 1960 | /* Change the Parity bit */ | ||
| 1961 | if (cflag & PARENB) { | ||
| 1962 | if (cflag & PARODD) { | ||
| 1963 | lParity = LCR_PAR_ODD; | ||
| 1964 | dbg("%s - parity = odd", __func__); | ||
| 1965 | } else { | ||
| 1966 | lParity = LCR_PAR_EVEN; | ||
| 1967 | dbg("%s - parity = even", __func__); | ||
| 1968 | } | ||
| 1969 | |||
| 1970 | } else { | ||
| 1971 | dbg("%s - parity = none", __func__); | ||
| 1972 | } | ||
| 1973 | |||
| 1974 | if (cflag & CMSPAR) | ||
| 1975 | lParity = lParity | 0x20; | ||
| 1976 | |||
| 1977 | /* Change the Stop bit */ | ||
| 1978 | if (cflag & CSTOPB) { | ||
| 1979 | lStop = LCR_STOP_2; | ||
| 1980 | dbg("%s - stop bits = 2", __func__); | ||
| 1981 | } else { | ||
| 1982 | lStop = LCR_STOP_1; | ||
| 1983 | dbg("%s - stop bits = 1", __func__); | ||
| 1984 | } | ||
| 1985 | |||
| 1986 | /* Update the LCR with the correct value */ | ||
| 1987 | ATEN2011_port->shadowLCR &= | ||
| 1988 | ~(LCR_BITS_MASK | LCR_STOP_MASK | LCR_PAR_MASK); | ||
| 1989 | ATEN2011_port->shadowLCR |= (lData | lParity | lStop); | ||
| 1990 | |||
| 1991 | dbg | ||
| 1992 | ("ATEN2011_change_port_settings ATEN2011_port->shadowLCR is %x", | ||
| 1993 | ATEN2011_port->shadowLCR); | ||
| 1994 | /* Disable Interrupts */ | ||
| 1995 | Data = 0x00; | ||
| 1996 | set_uart_reg(port, INTERRUPT_ENABLE_REGISTER, Data); | ||
| 1997 | |||
| 1998 | Data = 0x00; | ||
| 1999 | set_uart_reg(port, FIFO_CONTROL_REGISTER, Data); | ||
| 2000 | |||
| 2001 | Data = 0xcf; | ||
| 2002 | set_uart_reg(port, FIFO_CONTROL_REGISTER, Data); | ||
| 2003 | |||
| 2004 | /* Send the updated LCR value to the ATEN2011 */ | ||
| 2005 | Data = ATEN2011_port->shadowLCR; | ||
| 2006 | |||
| 2007 | set_uart_reg(port, LINE_CONTROL_REGISTER, Data); | ||
| 2008 | |||
| 2009 | Data = 0x00b; | ||
| 2010 | ATEN2011_port->shadowMCR = Data; | ||
| 2011 | set_uart_reg(port, MODEM_CONTROL_REGISTER, Data); | ||
| 2012 | Data = 0x00b; | ||
| 2013 | set_uart_reg(port, MODEM_CONTROL_REGISTER, Data); | ||
| 2014 | |||
| 2015 | /* set up the MCR register and send it to the ATEN2011 */ | ||
| 2016 | |||
| 2017 | ATEN2011_port->shadowMCR = MCR_MASTER_IE; | ||
| 2018 | if (cflag & CBAUD) | ||
| 2019 | ATEN2011_port->shadowMCR |= (MCR_DTR | MCR_RTS); | ||
| 2020 | |||
| 2021 | if (cflag & CRTSCTS) | ||
| 2022 | ATEN2011_port->shadowMCR |= (MCR_XON_ANY); | ||
| 2023 | else | ||
| 2024 | ATEN2011_port->shadowMCR &= ~(MCR_XON_ANY); | ||
| 2025 | |||
| 2026 | Data = ATEN2011_port->shadowMCR; | ||
| 2027 | set_uart_reg(port, MODEM_CONTROL_REGISTER, Data); | ||
| 2028 | |||
| 2029 | /* Determine divisor based on baud rate */ | ||
| 2030 | baud = tty_get_baud_rate(tty); | ||
| 2031 | |||
| 2032 | if (!baud) { | ||
| 2033 | /* pick a default, any default... */ | ||
| 2034 | dbg("%s", "Picked default baud..."); | ||
| 2035 | baud = 9600; | ||
| 2036 | } | ||
| 2037 | |||
| 2038 | dbg("%s - baud rate = %d", __func__, baud); | ||
| 2039 | status = ATEN2011_send_cmd_write_baud_rate(ATEN2011_port, baud); | ||
| 2040 | |||
| 2041 | /* Enable Interrupts */ | ||
| 2042 | Data = 0x0c; | ||
| 2043 | set_uart_reg(port, INTERRUPT_ENABLE_REGISTER, Data); | ||
| 2044 | |||
| 2045 | if (ATEN2011_port->read_urb->status != -EINPROGRESS) { | ||
| 2046 | ATEN2011_port->read_urb->dev = serial->dev; | ||
| 2047 | |||
| 2048 | status = usb_submit_urb(ATEN2011_port->read_urb, GFP_ATOMIC); | ||
| 2049 | |||
| 2050 | if (status) { | ||
| 2051 | dbg | ||
| 2052 | (" usb_submit_urb(read bulk) failed, status = %d", | ||
| 2053 | status); | ||
| 2054 | } | ||
| 2055 | } | ||
| 2056 | dbg | ||
| 2057 | ("ATEN2011_change_port_settings ATEN2011_port->shadowLCR is End %x", | ||
| 2058 | ATEN2011_port->shadowLCR); | ||
| 2059 | |||
| 2060 | return; | ||
| 2061 | } | ||
| 2062 | |||
| 2063 | static int ATEN2011_calc_num_ports(struct usb_serial *serial) | ||
| 2064 | { | ||
| 2065 | |||
| 2066 | __u16 Data = 0x00; | ||
| 2067 | int ret = 0; | ||
| 2068 | int ATEN2011_2or4ports; | ||
| 2069 | ret = usb_control_msg(serial->dev, usb_rcvctrlpipe(serial->dev, 0), | ||
| 2070 | ATEN_RDREQ, ATEN_RD_RTYPE, 0, GPIO_REGISTER, | ||
| 2071 | &Data, VENDOR_READ_LENGTH, ATEN_WDR_TIMEOUT); | ||
| 2072 | |||
| 2073 | /* ghostgum: here is where the problem appears to bet */ | ||
| 2074 | /* Which of the following are needed? */ | ||
| 2075 | /* Greg used the serial->type->num_ports=2 */ | ||
| 2076 | /* But the code in the ATEN2011_open relies on serial->num_ports=2 */ | ||
| 2077 | if ((Data & 0x01) == 0) { | ||
| 2078 | ATEN2011_2or4ports = 2; | ||
| 2079 | serial->type->num_ports = 2; | ||
| 2080 | serial->num_ports = 2; | ||
| 2081 | } | ||
| 2082 | /* else if(serial->interface->cur_altsetting->desc.bNumEndpoints == 9) */ | ||
| 2083 | else { | ||
| 2084 | ATEN2011_2or4ports = 4; | ||
| 2085 | serial->type->num_ports = 4; | ||
| 2086 | serial->num_ports = 4; | ||
| 2087 | |||
| 2088 | } | ||
| 2089 | |||
| 2090 | return ATEN2011_2or4ports; | ||
| 2091 | } | ||
| 2092 | |||
| 2093 | static int ATEN2011_startup(struct usb_serial *serial) | ||
| 2094 | { | ||
| 2095 | struct ATENINTL_serial *ATEN2011_serial; | ||
| 2096 | struct ATENINTL_port *ATEN2011_port; | ||
| 2097 | struct usb_device *dev; | ||
| 2098 | int i, status; | ||
| 2099 | int minor; | ||
| 2100 | |||
| 2101 | __u16 Data; | ||
| 2102 | dbg("%s", " ATEN2011_startup :entering.........."); | ||
| 2103 | |||
| 2104 | if (!serial) { | ||
| 2105 | dbg("%s", "Invalid Handler"); | ||
| 2106 | return -1; | ||
| 2107 | } | ||
| 2108 | |||
| 2109 | dev = serial->dev; | ||
| 2110 | |||
| 2111 | dbg("%s", "Entering..."); | ||
| 2112 | |||
| 2113 | /* create our private serial structure */ | ||
| 2114 | ATEN2011_serial = kzalloc(sizeof(struct ATENINTL_serial), GFP_KERNEL); | ||
| 2115 | if (ATEN2011_serial == NULL) { | ||
| 2116 | err("%s - Out of memory", __func__); | ||
| 2117 | return -ENOMEM; | ||
| 2118 | } | ||
| 2119 | |||
| 2120 | /* resetting the private structure field values to zero */ | ||
| 2121 | memset(ATEN2011_serial, 0, sizeof(struct ATENINTL_serial)); | ||
| 2122 | |||
| 2123 | ATEN2011_serial->serial = serial; | ||
| 2124 | /* initilize status polling flag to 0 */ | ||
| 2125 | ATEN2011_serial->status_polling_started = 0; | ||
| 2126 | |||
| 2127 | usb_set_serial_data(serial, ATEN2011_serial); | ||
| 2128 | ATEN2011_serial->ATEN2011_spectrum_2or4ports = | ||
| 2129 | ATEN2011_calc_num_ports(serial); | ||
| 2130 | /* we set up the pointers to the endpoints in the ATEN2011_open * | ||
| 2131 | * function, as the structures aren't created yet. */ | ||
| 2132 | |||
| 2133 | /* set up port private structures */ | ||
| 2134 | for (i = 0; i < serial->num_ports; ++i) { | ||
| 2135 | ATEN2011_port = | ||
| 2136 | kmalloc(sizeof(struct ATENINTL_port), GFP_KERNEL); | ||
| 2137 | if (ATEN2011_port == NULL) { | ||
| 2138 | err("%s - Out of memory", __func__); | ||
| 2139 | usb_set_serial_data(serial, NULL); | ||
| 2140 | kfree(ATEN2011_serial); | ||
| 2141 | return -ENOMEM; | ||
| 2142 | } | ||
| 2143 | memset(ATEN2011_port, 0, sizeof(struct ATENINTL_port)); | ||
| 2144 | |||
| 2145 | /* | ||
| 2146 | * Initialize all port interrupt end point to port 0 | ||
| 2147 | * int endpoint. Our device has only one interrupt end point | ||
| 2148 | * comman to all port | ||
| 2149 | */ | ||
| 2150 | /* serial->port[i]->interrupt_in_endpointAddress = serial->port[0]->interrupt_in_endpointAddress; */ | ||
| 2151 | |||
| 2152 | ATEN2011_port->port = serial->port[i]; | ||
| 2153 | usb_set_serial_port_data(serial->port[i], ATEN2011_port); | ||
| 2154 | |||
| 2155 | minor = serial->port[i]->serial->minor; | ||
| 2156 | if (minor == SERIAL_TTY_NO_MINOR) | ||
| 2157 | minor = 0; | ||
| 2158 | ATEN2011_port->port_num = | ||
| 2159 | ((serial->port[i]->number - minor) + 1); | ||
| 2160 | |||
| 2161 | if (ATEN2011_port->port_num == 1) { | ||
| 2162 | ATEN2011_port->SpRegOffset = 0x0; | ||
| 2163 | ATEN2011_port->ControlRegOffset = 0x1; | ||
| 2164 | ATEN2011_port->DcrRegOffset = 0x4; | ||
| 2165 | } else if ((ATEN2011_port->port_num == 2) | ||
| 2166 | && (ATEN2011_serial->ATEN2011_spectrum_2or4ports == | ||
| 2167 | 4)) { | ||
| 2168 | ATEN2011_port->SpRegOffset = 0x8; | ||
| 2169 | ATEN2011_port->ControlRegOffset = 0x9; | ||
| 2170 | ATEN2011_port->DcrRegOffset = 0x16; | ||
| 2171 | } else if ((ATEN2011_port->port_num == 2) | ||
| 2172 | && (ATEN2011_serial->ATEN2011_spectrum_2or4ports == | ||
| 2173 | 2)) { | ||
| 2174 | ATEN2011_port->SpRegOffset = 0xa; | ||
| 2175 | ATEN2011_port->ControlRegOffset = 0xb; | ||
| 2176 | ATEN2011_port->DcrRegOffset = 0x19; | ||
| 2177 | } else if ((ATEN2011_port->port_num == 3) | ||
| 2178 | && (ATEN2011_serial->ATEN2011_spectrum_2or4ports == | ||
| 2179 | 4)) { | ||
| 2180 | ATEN2011_port->SpRegOffset = 0xa; | ||
| 2181 | ATEN2011_port->ControlRegOffset = 0xb; | ||
| 2182 | ATEN2011_port->DcrRegOffset = 0x19; | ||
| 2183 | } else if ((ATEN2011_port->port_num == 4) | ||
| 2184 | && (ATEN2011_serial->ATEN2011_spectrum_2or4ports == | ||
| 2185 | 4)) { | ||
| 2186 | ATEN2011_port->SpRegOffset = 0xc; | ||
| 2187 | ATEN2011_port->ControlRegOffset = 0xd; | ||
| 2188 | ATEN2011_port->DcrRegOffset = 0x1c; | ||
| 2189 | } | ||
| 2190 | |||
| 2191 | usb_set_serial_port_data(serial->port[i], ATEN2011_port); | ||
| 2192 | |||
| 2193 | /* enable rx_disable bit in control register */ | ||
| 2194 | |||
| 2195 | status = get_reg_sync(serial->port[i], | ||
| 2196 | ATEN2011_port->ControlRegOffset, &Data); | ||
| 2197 | if (status < 0) { | ||
| 2198 | dbg("Reading ControlReg failed status-0x%x", | ||
| 2199 | status); | ||
| 2200 | break; | ||
| 2201 | } else | ||
| 2202 | dbg | ||
| 2203 | ("ControlReg Reading success val is %x, status%d", | ||
| 2204 | Data, status); | ||
| 2205 | Data |= 0x08; /* setting driver done bit */ | ||
| 2206 | Data |= 0x04; /* sp1_bit to have cts change reflect in modem status reg */ | ||
| 2207 | |||
| 2208 | /* Data |= 0x20; */ /* rx_disable bit */ | ||
| 2209 | status = set_reg_sync(serial->port[i], | ||
| 2210 | ATEN2011_port->ControlRegOffset, Data); | ||
| 2211 | if (status < 0) { | ||
| 2212 | dbg | ||
| 2213 | ("Writing ControlReg failed(rx_disable) status-0x%x", | ||
| 2214 | status); | ||
| 2215 | break; | ||
| 2216 | } else | ||
| 2217 | dbg | ||
| 2218 | ("ControlReg Writing success(rx_disable) status%d", | ||
| 2219 | status); | ||
| 2220 | |||
| 2221 | /* | ||
| 2222 | * Write default values in DCR (i.e 0x01 in DCR0, 0x05 in DCR2 | ||
| 2223 | * and 0x24 in DCR3 | ||
| 2224 | */ | ||
| 2225 | Data = 0x01; | ||
| 2226 | status = set_reg_sync(serial->port[i], | ||
| 2227 | (__u16)(ATEN2011_port->DcrRegOffset + 0), | ||
| 2228 | Data); | ||
| 2229 | if (status < 0) { | ||
| 2230 | dbg("Writing DCR0 failed status-0x%x", status); | ||
| 2231 | break; | ||
| 2232 | } else | ||
| 2233 | dbg("DCR0 Writing success status%d", status); | ||
| 2234 | |||
| 2235 | Data = 0x05; | ||
| 2236 | status = set_reg_sync(serial->port[i], | ||
| 2237 | (__u16)(ATEN2011_port->DcrRegOffset + 1), | ||
| 2238 | Data); | ||
| 2239 | if (status < 0) { | ||
| 2240 | dbg("Writing DCR1 failed status-0x%x", status); | ||
| 2241 | break; | ||
| 2242 | } else | ||
| 2243 | dbg("DCR1 Writing success status%d", status); | ||
| 2244 | |||
| 2245 | Data = 0x24; | ||
| 2246 | status = set_reg_sync(serial->port[i], | ||
| 2247 | (__u16)(ATEN2011_port->DcrRegOffset + 2), | ||
| 2248 | Data); | ||
| 2249 | if (status < 0) { | ||
| 2250 | dbg("Writing DCR2 failed status-0x%x", status); | ||
| 2251 | break; | ||
| 2252 | } else | ||
| 2253 | dbg("DCR2 Writing success status%d", status); | ||
| 2254 | |||
| 2255 | /* write values in clkstart0x0 and clkmulti 0x20 */ | ||
| 2256 | Data = 0x0; | ||
| 2257 | status = set_reg_sync(serial->port[i], CLK_START_VALUE_REGISTER, | ||
| 2258 | Data); | ||
| 2259 | if (status < 0) { | ||
| 2260 | dbg | ||
| 2261 | ("Writing CLK_START_VALUE_REGISTER failed status-0x%x", | ||
| 2262 | status); | ||
| 2263 | break; | ||
| 2264 | } else | ||
| 2265 | dbg | ||
| 2266 | ("CLK_START_VALUE_REGISTER Writing success status%d", | ||
| 2267 | status); | ||
| 2268 | |||
| 2269 | Data = 0x20; | ||
| 2270 | status = set_reg_sync(serial->port[i], CLK_MULTI_REGISTER, | ||
| 2271 | Data); | ||
| 2272 | if (status < 0) { | ||
| 2273 | dbg | ||
| 2274 | ("Writing CLK_MULTI_REGISTER failed status-0x%x", | ||
| 2275 | status); | ||
| 2276 | break; | ||
| 2277 | } else | ||
| 2278 | dbg("CLK_MULTI_REGISTER Writing success status%d", | ||
| 2279 | status); | ||
| 2280 | |||
| 2281 | /* Zero Length flag register */ | ||
| 2282 | if ((ATEN2011_port->port_num != 1) | ||
| 2283 | && (ATEN2011_serial->ATEN2011_spectrum_2or4ports == 2)) { | ||
| 2284 | |||
| 2285 | Data = 0xff; | ||
| 2286 | status = set_reg_sync(serial->port[i], | ||
| 2287 | (__u16)(ZLP_REG1 + ((__u16)ATEN2011_port->port_num)), | ||
| 2288 | Data); | ||
| 2289 | dbg("ZLIP offset%x", | ||
| 2290 | (__u16) (ZLP_REG1 + | ||
| 2291 | ((__u16) ATEN2011_port->port_num))); | ||
| 2292 | if (status < 0) { | ||
| 2293 | dbg | ||
| 2294 | ("Writing ZLP_REG%d failed status-0x%x", | ||
| 2295 | i + 2, status); | ||
| 2296 | break; | ||
| 2297 | } else | ||
| 2298 | dbg("ZLP_REG%d Writing success status%d", | ||
| 2299 | i + 2, status); | ||
| 2300 | } else { | ||
| 2301 | Data = 0xff; | ||
| 2302 | status = set_reg_sync(serial->port[i], | ||
| 2303 | (__u16)(ZLP_REG1 + ((__u16)ATEN2011_port->port_num) - 0x1), | ||
| 2304 | Data); | ||
| 2305 | dbg("ZLIP offset%x", | ||
| 2306 | (__u16) (ZLP_REG1 + | ||
| 2307 | ((__u16) ATEN2011_port->port_num) - | ||
| 2308 | 0x1)); | ||
| 2309 | if (status < 0) { | ||
| 2310 | dbg | ||
| 2311 | ("Writing ZLP_REG%d failed status-0x%x", | ||
| 2312 | i + 1, status); | ||
| 2313 | break; | ||
| 2314 | } else | ||
| 2315 | dbg("ZLP_REG%d Writing success status%d", | ||
| 2316 | i + 1, status); | ||
| 2317 | |||
| 2318 | } | ||
| 2319 | ATEN2011_port->control_urb = usb_alloc_urb(0, GFP_ATOMIC); | ||
| 2320 | ATEN2011_port->ctrl_buf = kmalloc(16, GFP_KERNEL); | ||
| 2321 | |||
| 2322 | } | ||
| 2323 | |||
| 2324 | /* Zero Length flag enable */ | ||
| 2325 | Data = 0x0f; | ||
| 2326 | status = set_reg_sync(serial->port[0], ZLP_REG5, Data); | ||
| 2327 | if (status < 0) { | ||
| 2328 | dbg("Writing ZLP_REG5 failed status-0x%x", status); | ||
| 2329 | return -1; | ||
| 2330 | } else | ||
| 2331 | dbg("ZLP_REG5 Writing success status%d", status); | ||
| 2332 | |||
| 2333 | /* setting configuration feature to one */ | ||
| 2334 | usb_control_msg(serial->dev, usb_sndctrlpipe(serial->dev, 0), | ||
| 2335 | (__u8) 0x03, 0x00, 0x01, 0x00, NULL, 0x00, 5 * HZ); | ||
| 2336 | return 0; | ||
| 2337 | } | ||
| 2338 | |||
| 2339 | static void ATEN2011_release(struct usb_serial *serial) | ||
| 2340 | { | ||
| 2341 | int i; | ||
| 2342 | struct ATENINTL_port *ATEN2011_port; | ||
| 2343 | |||
| 2344 | /* check for the ports to be closed,close the ports and disconnect */ | ||
| 2345 | |||
| 2346 | /* free private structure allocated for serial port * | ||
| 2347 | * stop reads and writes on all ports */ | ||
| 2348 | |||
| 2349 | for (i = 0; i < serial->num_ports; ++i) { | ||
| 2350 | ATEN2011_port = usb_get_serial_port_data(serial->port[i]); | ||
| 2351 | kfree(ATEN2011_port->ctrl_buf); | ||
| 2352 | usb_kill_urb(ATEN2011_port->control_urb); | ||
| 2353 | kfree(ATEN2011_port); | ||
| 2354 | usb_set_serial_port_data(serial->port[i], NULL); | ||
| 2355 | } | ||
| 2356 | |||
| 2357 | /* free private structure allocated for serial device */ | ||
| 2358 | |||
| 2359 | kfree(usb_get_serial_data(serial)); | ||
| 2360 | usb_set_serial_data(serial, NULL); | ||
| 2361 | } | ||
| 2362 | |||
| 2363 | static struct usb_serial_driver aten_serial_driver = { | ||
| 2364 | .driver = { | ||
| 2365 | .owner = THIS_MODULE, | ||
| 2366 | .name = "aten2011", | ||
| 2367 | }, | ||
| 2368 | .description = DRIVER_DESC, | ||
| 2369 | .id_table = id_table, | ||
| 2370 | .open = ATEN2011_open, | ||
| 2371 | .close = ATEN2011_close, | ||
| 2372 | .write = ATEN2011_write, | ||
| 2373 | .write_room = ATEN2011_write_room, | ||
| 2374 | .chars_in_buffer = ATEN2011_chars_in_buffer, | ||
| 2375 | .throttle = ATEN2011_throttle, | ||
| 2376 | .unthrottle = ATEN2011_unthrottle, | ||
| 2377 | .calc_num_ports = ATEN2011_calc_num_ports, | ||
| 2378 | |||
| 2379 | .ioctl = ATEN2011_ioctl, | ||
| 2380 | .set_termios = ATEN2011_set_termios, | ||
| 2381 | .break_ctl = ATEN2011_break, | ||
| 2382 | .tiocmget = ATEN2011_tiocmget, | ||
| 2383 | .tiocmset = ATEN2011_tiocmset, | ||
| 2384 | .attach = ATEN2011_startup, | ||
| 2385 | .release = ATEN2011_release, | ||
| 2386 | .read_bulk_callback = ATEN2011_bulk_in_callback, | ||
| 2387 | .read_int_callback = ATEN2011_interrupt_callback, | ||
| 2388 | }; | ||
| 2389 | |||
| 2390 | static struct usb_driver aten_driver = { | ||
| 2391 | .name = "aten2011", | ||
| 2392 | .probe = usb_serial_probe, | ||
| 2393 | .disconnect = usb_serial_disconnect, | ||
| 2394 | .id_table = id_table, | ||
| 2395 | }; | ||
| 2396 | |||
| 2397 | static int __init aten_init(void) | ||
| 2398 | { | ||
| 2399 | int retval; | ||
| 2400 | |||
| 2401 | /* Register with the usb serial */ | ||
| 2402 | retval = usb_serial_register(&aten_serial_driver); | ||
| 2403 | if (retval) | ||
| 2404 | return retval; | ||
| 2405 | |||
| 2406 | printk(KERN_INFO KBUILD_MODNAME ":" | ||
| 2407 | DRIVER_DESC " " DRIVER_VERSION "\n"); | ||
| 2408 | |||
| 2409 | /* Register with the usb */ | ||
| 2410 | retval = usb_register(&aten_driver); | ||
| 2411 | if (retval) | ||
| 2412 | usb_serial_deregister(&aten_serial_driver); | ||
| 2413 | |||
| 2414 | return retval; | ||
| 2415 | } | ||
| 2416 | |||
| 2417 | static void __exit aten_exit(void) | ||
| 2418 | { | ||
| 2419 | usb_deregister(&aten_driver); | ||
| 2420 | usb_serial_deregister(&aten_serial_driver); | ||
| 2421 | } | ||
| 2422 | |||
| 2423 | module_init(aten_init); | ||
| 2424 | module_exit(aten_exit); | ||
| 2425 | |||
| 2426 | /* Module information */ | ||
| 2427 | MODULE_DESCRIPTION(DRIVER_DESC); | ||
| 2428 | MODULE_LICENSE("GPL"); | ||
| 2429 | |||
| 2430 | MODULE_PARM_DESC(debug, "Debug enabled or not"); | ||
diff --git a/drivers/staging/udlfb/udlfb.c b/drivers/staging/udlfb/udlfb.c index 0ab9d15f3439..f5416af1e902 100644 --- a/drivers/staging/udlfb/udlfb.c +++ b/drivers/staging/udlfb/udlfb.c | |||
| @@ -21,6 +21,7 @@ | |||
| 21 | #include <linux/mm.h> | 21 | #include <linux/mm.h> |
| 22 | #include <linux/fb.h> | 22 | #include <linux/fb.h> |
| 23 | #include <linux/mutex.h> | 23 | #include <linux/mutex.h> |
| 24 | #include <linux/vmalloc.h> | ||
| 24 | 25 | ||
| 25 | #include "udlfb.h" | 26 | #include "udlfb.h" |
| 26 | 27 | ||
diff --git a/drivers/thermal/thermal_sys.c b/drivers/thermal/thermal_sys.c index 0a69672097a8..4e83c297ec9e 100644 --- a/drivers/thermal/thermal_sys.c +++ b/drivers/thermal/thermal_sys.c | |||
| @@ -953,7 +953,12 @@ void thermal_zone_device_update(struct thermal_zone_device *tz) | |||
| 953 | 953 | ||
| 954 | mutex_lock(&tz->lock); | 954 | mutex_lock(&tz->lock); |
| 955 | 955 | ||
| 956 | tz->ops->get_temp(tz, &temp); | 956 | if (tz->ops->get_temp(tz, &temp)) { |
| 957 | /* get_temp failed - retry it later */ | ||
| 958 | printk(KERN_WARNING PREFIX "failed to read out thermal zone " | ||
| 959 | "%d\n", tz->id); | ||
| 960 | goto leave; | ||
| 961 | } | ||
| 957 | 962 | ||
| 958 | for (count = 0; count < tz->trips; count++) { | 963 | for (count = 0; count < tz->trips; count++) { |
| 959 | tz->ops->get_trip_type(tz, count, &trip_type); | 964 | tz->ops->get_trip_type(tz, count, &trip_type); |
| @@ -1005,6 +1010,8 @@ void thermal_zone_device_update(struct thermal_zone_device *tz) | |||
| 1005 | THERMAL_TRIPS_NONE); | 1010 | THERMAL_TRIPS_NONE); |
| 1006 | 1011 | ||
| 1007 | tz->last_temperature = temp; | 1012 | tz->last_temperature = temp; |
| 1013 | |||
| 1014 | leave: | ||
| 1008 | if (tz->passive) | 1015 | if (tz->passive) |
| 1009 | thermal_zone_device_set_polling(tz, tz->passive_delay); | 1016 | thermal_zone_device_set_polling(tz, tz->passive_delay); |
| 1010 | else if (tz->polling_delay) | 1017 | else if (tz->polling_delay) |
diff --git a/drivers/usb/class/cdc-acm.c b/drivers/usb/class/cdc-acm.c index e1f89416ef8c..2bfc41ece0e1 100644 --- a/drivers/usb/class/cdc-acm.c +++ b/drivers/usb/class/cdc-acm.c | |||
| @@ -387,7 +387,6 @@ static void acm_rx_tasklet(unsigned long _acm) | |||
| 387 | struct acm_ru *rcv; | 387 | struct acm_ru *rcv; |
| 388 | unsigned long flags; | 388 | unsigned long flags; |
| 389 | unsigned char throttled; | 389 | unsigned char throttled; |
| 390 | struct usb_host_endpoint *ep; | ||
| 391 | 390 | ||
| 392 | dbg("Entering acm_rx_tasklet"); | 391 | dbg("Entering acm_rx_tasklet"); |
| 393 | 392 | ||
| @@ -463,14 +462,12 @@ urbs: | |||
| 463 | 462 | ||
| 464 | rcv->buffer = buf; | 463 | rcv->buffer = buf; |
| 465 | 464 | ||
| 466 | ep = (usb_pipein(acm->rx_endpoint) ? acm->dev->ep_in : acm->dev->ep_out) | 465 | if (acm->is_int_ep) |
| 467 | [usb_pipeendpoint(acm->rx_endpoint)]; | ||
| 468 | if (usb_endpoint_xfer_int(&ep->desc)) | ||
| 469 | usb_fill_int_urb(rcv->urb, acm->dev, | 466 | usb_fill_int_urb(rcv->urb, acm->dev, |
| 470 | acm->rx_endpoint, | 467 | acm->rx_endpoint, |
| 471 | buf->base, | 468 | buf->base, |
| 472 | acm->readsize, | 469 | acm->readsize, |
| 473 | acm_read_bulk, rcv, ep->desc.bInterval); | 470 | acm_read_bulk, rcv, acm->bInterval); |
| 474 | else | 471 | else |
| 475 | usb_fill_bulk_urb(rcv->urb, acm->dev, | 472 | usb_fill_bulk_urb(rcv->urb, acm->dev, |
| 476 | acm->rx_endpoint, | 473 | acm->rx_endpoint, |
| @@ -1183,6 +1180,9 @@ made_compressed_probe: | |||
| 1183 | spin_lock_init(&acm->read_lock); | 1180 | spin_lock_init(&acm->read_lock); |
| 1184 | mutex_init(&acm->mutex); | 1181 | mutex_init(&acm->mutex); |
| 1185 | acm->rx_endpoint = usb_rcvbulkpipe(usb_dev, epread->bEndpointAddress); | 1182 | acm->rx_endpoint = usb_rcvbulkpipe(usb_dev, epread->bEndpointAddress); |
| 1183 | acm->is_int_ep = usb_endpoint_xfer_int(epread); | ||
| 1184 | if (acm->is_int_ep) | ||
| 1185 | acm->bInterval = epread->bInterval; | ||
| 1186 | tty_port_init(&acm->port); | 1186 | tty_port_init(&acm->port); |
| 1187 | acm->port.ops = &acm_port_ops; | 1187 | acm->port.ops = &acm_port_ops; |
| 1188 | 1188 | ||
diff --git a/drivers/usb/class/cdc-acm.h b/drivers/usb/class/cdc-acm.h index 1602324808ba..c4a0ee8ffccf 100644 --- a/drivers/usb/class/cdc-acm.h +++ b/drivers/usb/class/cdc-acm.h | |||
| @@ -126,6 +126,8 @@ struct acm { | |||
| 126 | unsigned int ctrl_caps; /* control capabilities from the class specific header */ | 126 | unsigned int ctrl_caps; /* control capabilities from the class specific header */ |
| 127 | unsigned int susp_count; /* number of suspended interfaces */ | 127 | unsigned int susp_count; /* number of suspended interfaces */ |
| 128 | int combined_interfaces:1; /* control and data collapsed */ | 128 | int combined_interfaces:1; /* control and data collapsed */ |
| 129 | int is_int_ep:1; /* interrupt endpoints contrary to spec used */ | ||
| 130 | u8 bInterval; | ||
| 129 | struct acm_wb *delayed_wb; /* write queued for a device about to be woken */ | 131 | struct acm_wb *delayed_wb; /* write queued for a device about to be woken */ |
| 130 | }; | 132 | }; |
| 131 | 133 | ||
diff --git a/drivers/usb/core/config.c b/drivers/usb/core/config.c index 24dfb33f90cb..a16c538d0132 100644 --- a/drivers/usb/core/config.c +++ b/drivers/usb/core/config.c | |||
| @@ -80,38 +80,18 @@ static int usb_parse_ss_endpoint_companion(struct device *ddev, int cfgno, | |||
| 80 | int max_tx; | 80 | int max_tx; |
| 81 | int i; | 81 | int i; |
| 82 | 82 | ||
| 83 | /* Allocate space for the SS endpoint companion descriptor */ | ||
| 84 | ep->ss_ep_comp = kzalloc(sizeof(struct usb_host_ss_ep_comp), | ||
| 85 | GFP_KERNEL); | ||
| 86 | if (!ep->ss_ep_comp) | ||
| 87 | return -ENOMEM; | ||
| 88 | desc = (struct usb_ss_ep_comp_descriptor *) buffer; | 83 | desc = (struct usb_ss_ep_comp_descriptor *) buffer; |
| 89 | if (desc->bDescriptorType != USB_DT_SS_ENDPOINT_COMP) { | 84 | if (desc->bDescriptorType != USB_DT_SS_ENDPOINT_COMP) { |
| 90 | dev_warn(ddev, "No SuperSpeed endpoint companion for config %d " | 85 | dev_warn(ddev, "No SuperSpeed endpoint companion for config %d " |
| 91 | " interface %d altsetting %d ep %d: " | 86 | " interface %d altsetting %d ep %d: " |
| 92 | "using minimum values\n", | 87 | "using minimum values\n", |
| 93 | cfgno, inum, asnum, ep->desc.bEndpointAddress); | 88 | cfgno, inum, asnum, ep->desc.bEndpointAddress); |
| 94 | ep->ss_ep_comp->desc.bLength = USB_DT_SS_EP_COMP_SIZE; | ||
| 95 | ep->ss_ep_comp->desc.bDescriptorType = USB_DT_SS_ENDPOINT_COMP; | ||
| 96 | ep->ss_ep_comp->desc.bMaxBurst = 0; | ||
| 97 | /* | ||
| 98 | * Leave bmAttributes as zero, which will mean no streams for | ||
| 99 | * bulk, and isoc won't support multiple bursts of packets. | ||
| 100 | * With bursts of only one packet, and a Mult of 1, the max | ||
| 101 | * amount of data moved per endpoint service interval is one | ||
| 102 | * packet. | ||
| 103 | */ | ||
| 104 | if (usb_endpoint_xfer_isoc(&ep->desc) || | ||
| 105 | usb_endpoint_xfer_int(&ep->desc)) | ||
| 106 | ep->ss_ep_comp->desc.wBytesPerInterval = | ||
| 107 | ep->desc.wMaxPacketSize; | ||
| 108 | /* | 89 | /* |
| 109 | * The next descriptor is for an Endpoint or Interface, | 90 | * The next descriptor is for an Endpoint or Interface, |
| 110 | * no extra descriptors to copy into the companion structure, | 91 | * no extra descriptors to copy into the companion structure, |
| 111 | * and we didn't eat up any of the buffer. | 92 | * and we didn't eat up any of the buffer. |
| 112 | */ | 93 | */ |
| 113 | retval = 0; | 94 | return 0; |
| 114 | goto valid; | ||
| 115 | } | 95 | } |
| 116 | memcpy(&ep->ss_ep_comp->desc, desc, USB_DT_SS_EP_COMP_SIZE); | 96 | memcpy(&ep->ss_ep_comp->desc, desc, USB_DT_SS_EP_COMP_SIZE); |
| 117 | desc = &ep->ss_ep_comp->desc; | 97 | desc = &ep->ss_ep_comp->desc; |
| @@ -320,6 +300,28 @@ static int usb_parse_endpoint(struct device *ddev, int cfgno, int inum, | |||
| 320 | buffer += i; | 300 | buffer += i; |
| 321 | size -= i; | 301 | size -= i; |
| 322 | 302 | ||
| 303 | /* Allocate space for the SS endpoint companion descriptor */ | ||
| 304 | endpoint->ss_ep_comp = kzalloc(sizeof(struct usb_host_ss_ep_comp), | ||
| 305 | GFP_KERNEL); | ||
| 306 | if (!endpoint->ss_ep_comp) | ||
| 307 | return -ENOMEM; | ||
| 308 | |||
| 309 | /* Fill in some default values (may be overwritten later) */ | ||
| 310 | endpoint->ss_ep_comp->desc.bLength = USB_DT_SS_EP_COMP_SIZE; | ||
| 311 | endpoint->ss_ep_comp->desc.bDescriptorType = USB_DT_SS_ENDPOINT_COMP; | ||
| 312 | endpoint->ss_ep_comp->desc.bMaxBurst = 0; | ||
| 313 | /* | ||
| 314 | * Leave bmAttributes as zero, which will mean no streams for | ||
| 315 | * bulk, and isoc won't support multiple bursts of packets. | ||
| 316 | * With bursts of only one packet, and a Mult of 1, the max | ||
| 317 | * amount of data moved per endpoint service interval is one | ||
| 318 | * packet. | ||
| 319 | */ | ||
| 320 | if (usb_endpoint_xfer_isoc(&endpoint->desc) || | ||
| 321 | usb_endpoint_xfer_int(&endpoint->desc)) | ||
| 322 | endpoint->ss_ep_comp->desc.wBytesPerInterval = | ||
| 323 | endpoint->desc.wMaxPacketSize; | ||
| 324 | |||
| 323 | if (size > 0) { | 325 | if (size > 0) { |
| 324 | retval = usb_parse_ss_endpoint_companion(ddev, cfgno, | 326 | retval = usb_parse_ss_endpoint_companion(ddev, cfgno, |
| 325 | inum, asnum, endpoint, num_ep, buffer, | 327 | inum, asnum, endpoint, num_ep, buffer, |
| @@ -329,6 +331,10 @@ static int usb_parse_endpoint(struct device *ddev, int cfgno, int inum, | |||
| 329 | retval = buffer - buffer0; | 331 | retval = buffer - buffer0; |
| 330 | } | 332 | } |
| 331 | } else { | 333 | } else { |
| 334 | dev_warn(ddev, "config %d interface %d altsetting %d " | ||
| 335 | "endpoint 0x%X has no " | ||
| 336 | "SuperSpeed companion descriptor\n", | ||
| 337 | cfgno, inum, asnum, d->bEndpointAddress); | ||
| 332 | retval = buffer - buffer0; | 338 | retval = buffer - buffer0; |
| 333 | } | 339 | } |
| 334 | } else { | 340 | } else { |
diff --git a/drivers/usb/core/devio.c b/drivers/usb/core/devio.c index 38b8bce782d6..4247eccf858c 100644 --- a/drivers/usb/core/devio.c +++ b/drivers/usb/core/devio.c | |||
| @@ -595,7 +595,7 @@ static int usbdev_open(struct inode *inode, struct file *file) | |||
| 595 | if (!ps) | 595 | if (!ps) |
| 596 | goto out; | 596 | goto out; |
| 597 | 597 | ||
| 598 | ret = -ENOENT; | 598 | ret = -ENODEV; |
| 599 | 599 | ||
| 600 | /* usbdev device-node */ | 600 | /* usbdev device-node */ |
| 601 | if (imajor(inode) == USB_DEVICE_MAJOR) | 601 | if (imajor(inode) == USB_DEVICE_MAJOR) |
| @@ -1321,7 +1321,8 @@ static int get_urb32(struct usbdevfs_urb *kurb, | |||
| 1321 | struct usbdevfs_urb32 __user *uurb) | 1321 | struct usbdevfs_urb32 __user *uurb) |
| 1322 | { | 1322 | { |
| 1323 | __u32 uptr; | 1323 | __u32 uptr; |
| 1324 | if (get_user(kurb->type, &uurb->type) || | 1324 | if (!access_ok(VERIFY_READ, uurb, sizeof(*uurb)) || |
| 1325 | __get_user(kurb->type, &uurb->type) || | ||
| 1325 | __get_user(kurb->endpoint, &uurb->endpoint) || | 1326 | __get_user(kurb->endpoint, &uurb->endpoint) || |
| 1326 | __get_user(kurb->status, &uurb->status) || | 1327 | __get_user(kurb->status, &uurb->status) || |
| 1327 | __get_user(kurb->flags, &uurb->flags) || | 1328 | __get_user(kurb->flags, &uurb->flags) || |
| @@ -1536,8 +1537,9 @@ static int proc_ioctl_compat(struct dev_state *ps, compat_uptr_t arg) | |||
| 1536 | u32 udata; | 1537 | u32 udata; |
| 1537 | 1538 | ||
| 1538 | uioc = compat_ptr((long)arg); | 1539 | uioc = compat_ptr((long)arg); |
| 1539 | if (get_user(ctrl.ifno, &uioc->ifno) || | 1540 | if (!access_ok(VERIFY_READ, uioc, sizeof(*uioc)) || |
| 1540 | get_user(ctrl.ioctl_code, &uioc->ioctl_code) || | 1541 | __get_user(ctrl.ifno, &uioc->ifno) || |
| 1542 | __get_user(ctrl.ioctl_code, &uioc->ioctl_code) || | ||
| 1541 | __get_user(udata, &uioc->data)) | 1543 | __get_user(udata, &uioc->data)) |
| 1542 | return -EFAULT; | 1544 | return -EFAULT; |
| 1543 | ctrl.data = compat_ptr(udata); | 1545 | ctrl.data = compat_ptr(udata); |
diff --git a/drivers/usb/host/ehci-hcd.c b/drivers/usb/host/ehci-hcd.c index 7d03549c3339..11c627ce6022 100644 --- a/drivers/usb/host/ehci-hcd.c +++ b/drivers/usb/host/ehci-hcd.c | |||
| @@ -903,7 +903,8 @@ static int ehci_urb_dequeue(struct usb_hcd *hcd, struct urb *urb, int status) | |||
| 903 | /* already started */ | 903 | /* already started */ |
| 904 | break; | 904 | break; |
| 905 | case QH_STATE_IDLE: | 905 | case QH_STATE_IDLE: |
| 906 | WARN_ON(1); | 906 | /* QH might be waiting for a Clear-TT-Buffer */ |
| 907 | qh_completions(ehci, qh); | ||
| 907 | break; | 908 | break; |
| 908 | } | 909 | } |
| 909 | break; | 910 | break; |
diff --git a/drivers/usb/host/ehci-orion.c b/drivers/usb/host/ehci-orion.c index dc2ac613a9d1..1d283e1b2b8d 100644 --- a/drivers/usb/host/ehci-orion.c +++ b/drivers/usb/host/ehci-orion.c | |||
| @@ -105,6 +105,7 @@ static int ehci_orion_setup(struct usb_hcd *hcd) | |||
| 105 | struct ehci_hcd *ehci = hcd_to_ehci(hcd); | 105 | struct ehci_hcd *ehci = hcd_to_ehci(hcd); |
| 106 | int retval; | 106 | int retval; |
| 107 | 107 | ||
| 108 | ehci_reset(ehci); | ||
| 108 | retval = ehci_halt(ehci); | 109 | retval = ehci_halt(ehci); |
| 109 | if (retval) | 110 | if (retval) |
| 110 | return retval; | 111 | return retval; |
| @@ -118,7 +119,6 @@ static int ehci_orion_setup(struct usb_hcd *hcd) | |||
| 118 | 119 | ||
| 119 | hcd->has_tt = 1; | 120 | hcd->has_tt = 1; |
| 120 | 121 | ||
| 121 | ehci_reset(ehci); | ||
| 122 | ehci_port_power(ehci, 0); | 122 | ehci_port_power(ehci, 0); |
| 123 | 123 | ||
| 124 | return retval; | 124 | return retval; |
diff --git a/drivers/usb/host/ehci-q.c b/drivers/usb/host/ehci-q.c index 9a1384747f3b..7673554fa64d 100644 --- a/drivers/usb/host/ehci-q.c +++ b/drivers/usb/host/ehci-q.c | |||
| @@ -375,12 +375,11 @@ qh_completions (struct ehci_hcd *ehci, struct ehci_qh *qh) | |||
| 375 | */ | 375 | */ |
| 376 | if ((token & QTD_STS_XACT) && | 376 | if ((token & QTD_STS_XACT) && |
| 377 | QTD_CERR(token) == 0 && | 377 | QTD_CERR(token) == 0 && |
| 378 | --qh->xacterrs > 0 && | 378 | ++qh->xacterrs < QH_XACTERR_MAX && |
| 379 | !urb->unlinked) { | 379 | !urb->unlinked) { |
| 380 | ehci_dbg(ehci, | 380 | ehci_dbg(ehci, |
| 381 | "detected XactErr len %zu/%zu retry %d\n", | 381 | "detected XactErr len %zu/%zu retry %d\n", |
| 382 | qtd->length - QTD_LENGTH(token), qtd->length, | 382 | qtd->length - QTD_LENGTH(token), qtd->length, qh->xacterrs); |
| 383 | QH_XACTERR_MAX - qh->xacterrs); | ||
| 384 | 383 | ||
| 385 | /* reset the token in the qtd and the | 384 | /* reset the token in the qtd and the |
| 386 | * qh overlay (which still contains | 385 | * qh overlay (which still contains |
| @@ -494,7 +493,7 @@ halt: | |||
| 494 | last = qtd; | 493 | last = qtd; |
| 495 | 494 | ||
| 496 | /* reinit the xacterr counter for the next qtd */ | 495 | /* reinit the xacterr counter for the next qtd */ |
| 497 | qh->xacterrs = QH_XACTERR_MAX; | 496 | qh->xacterrs = 0; |
| 498 | } | 497 | } |
| 499 | 498 | ||
| 500 | /* last urb's completion might still need calling */ | 499 | /* last urb's completion might still need calling */ |
| @@ -940,7 +939,8 @@ static void qh_link_async (struct ehci_hcd *ehci, struct ehci_qh *qh) | |||
| 940 | head->qh_next.qh = qh; | 939 | head->qh_next.qh = qh; |
| 941 | head->hw_next = dma; | 940 | head->hw_next = dma; |
| 942 | 941 | ||
| 943 | qh->xacterrs = QH_XACTERR_MAX; | 942 | qh_get(qh); |
| 943 | qh->xacterrs = 0; | ||
| 944 | qh->qh_state = QH_STATE_LINKED; | 944 | qh->qh_state = QH_STATE_LINKED; |
| 945 | /* qtd completions reported later by interrupt */ | 945 | /* qtd completions reported later by interrupt */ |
| 946 | } | 946 | } |
| @@ -1080,7 +1080,7 @@ submit_async ( | |||
| 1080 | * the HC and TT handle it when the TT has a buffer ready. | 1080 | * the HC and TT handle it when the TT has a buffer ready. |
| 1081 | */ | 1081 | */ |
| 1082 | if (likely (qh->qh_state == QH_STATE_IDLE)) | 1082 | if (likely (qh->qh_state == QH_STATE_IDLE)) |
| 1083 | qh_link_async (ehci, qh_get (qh)); | 1083 | qh_link_async(ehci, qh); |
| 1084 | done: | 1084 | done: |
| 1085 | spin_unlock_irqrestore (&ehci->lock, flags); | 1085 | spin_unlock_irqrestore (&ehci->lock, flags); |
| 1086 | if (unlikely (qh == NULL)) | 1086 | if (unlikely (qh == NULL)) |
| @@ -1115,8 +1115,6 @@ static void end_unlink_async (struct ehci_hcd *ehci) | |||
| 1115 | && HC_IS_RUNNING (ehci_to_hcd(ehci)->state)) | 1115 | && HC_IS_RUNNING (ehci_to_hcd(ehci)->state)) |
| 1116 | qh_link_async (ehci, qh); | 1116 | qh_link_async (ehci, qh); |
| 1117 | else { | 1117 | else { |
| 1118 | qh_put (qh); // refcount from async list | ||
| 1119 | |||
| 1120 | /* it's not free to turn the async schedule on/off; leave it | 1118 | /* it's not free to turn the async schedule on/off; leave it |
| 1121 | * active but idle for a while once it empties. | 1119 | * active but idle for a while once it empties. |
| 1122 | */ | 1120 | */ |
| @@ -1124,6 +1122,7 @@ static void end_unlink_async (struct ehci_hcd *ehci) | |||
| 1124 | && ehci->async->qh_next.qh == NULL) | 1122 | && ehci->async->qh_next.qh == NULL) |
| 1125 | timer_action (ehci, TIMER_ASYNC_OFF); | 1123 | timer_action (ehci, TIMER_ASYNC_OFF); |
| 1126 | } | 1124 | } |
| 1125 | qh_put(qh); /* refcount from async list */ | ||
| 1127 | 1126 | ||
| 1128 | if (next) { | 1127 | if (next) { |
| 1129 | ehci->reclaim = NULL; | 1128 | ehci->reclaim = NULL; |
diff --git a/drivers/usb/host/ehci-sched.c b/drivers/usb/host/ehci-sched.c index 74f7f83b29ad..edd61ee90323 100644 --- a/drivers/usb/host/ehci-sched.c +++ b/drivers/usb/host/ehci-sched.c | |||
| @@ -542,6 +542,7 @@ static int qh_link_periodic (struct ehci_hcd *ehci, struct ehci_qh *qh) | |||
| 542 | } | 542 | } |
| 543 | } | 543 | } |
| 544 | qh->qh_state = QH_STATE_LINKED; | 544 | qh->qh_state = QH_STATE_LINKED; |
| 545 | qh->xacterrs = 0; | ||
| 545 | qh_get (qh); | 546 | qh_get (qh); |
| 546 | 547 | ||
| 547 | /* update per-qh bandwidth for usbfs */ | 548 | /* update per-qh bandwidth for usbfs */ |
diff --git a/drivers/usb/host/ohci-omap.c b/drivers/usb/host/ohci-omap.c index f3aaba35e912..83cbecd2a1ed 100644 --- a/drivers/usb/host/ohci-omap.c +++ b/drivers/usb/host/ohci-omap.c | |||
| @@ -282,6 +282,7 @@ static int ohci_omap_init(struct usb_hcd *hcd) | |||
| 282 | static void ohci_omap_stop(struct usb_hcd *hcd) | 282 | static void ohci_omap_stop(struct usb_hcd *hcd) |
| 283 | { | 283 | { |
| 284 | dev_dbg(hcd->self.controller, "stopping USB Controller\n"); | 284 | dev_dbg(hcd->self.controller, "stopping USB Controller\n"); |
| 285 | ohci_stop(hcd); | ||
| 285 | omap_ohci_clock_power(0); | 286 | omap_ohci_clock_power(0); |
| 286 | } | 287 | } |
| 287 | 288 | ||
diff --git a/drivers/usb/host/xhci-dbg.c b/drivers/usb/host/xhci-dbg.c index 2501c571f855..705e34324156 100644 --- a/drivers/usb/host/xhci-dbg.c +++ b/drivers/usb/host/xhci-dbg.c | |||
| @@ -173,6 +173,7 @@ void xhci_print_ir_set(struct xhci_hcd *xhci, struct xhci_intr_reg *ir_set, int | |||
| 173 | { | 173 | { |
| 174 | void *addr; | 174 | void *addr; |
| 175 | u32 temp; | 175 | u32 temp; |
| 176 | u64 temp_64; | ||
| 176 | 177 | ||
| 177 | addr = &ir_set->irq_pending; | 178 | addr = &ir_set->irq_pending; |
| 178 | temp = xhci_readl(xhci, addr); | 179 | temp = xhci_readl(xhci, addr); |
| @@ -200,25 +201,15 @@ void xhci_print_ir_set(struct xhci_hcd *xhci, struct xhci_intr_reg *ir_set, int | |||
| 200 | xhci_dbg(xhci, " WARN: %p: ir_set.rsvd = 0x%x\n", | 201 | xhci_dbg(xhci, " WARN: %p: ir_set.rsvd = 0x%x\n", |
| 201 | addr, (unsigned int)temp); | 202 | addr, (unsigned int)temp); |
| 202 | 203 | ||
| 203 | addr = &ir_set->erst_base[0]; | 204 | addr = &ir_set->erst_base; |
| 204 | temp = xhci_readl(xhci, addr); | 205 | temp_64 = xhci_read_64(xhci, addr); |
| 205 | xhci_dbg(xhci, " %p: ir_set.erst_base[0] = 0x%x\n", | 206 | xhci_dbg(xhci, " %p: ir_set.erst_base = @%08llx\n", |
| 206 | addr, (unsigned int) temp); | 207 | addr, temp_64); |
| 207 | |||
| 208 | addr = &ir_set->erst_base[1]; | ||
| 209 | temp = xhci_readl(xhci, addr); | ||
| 210 | xhci_dbg(xhci, " %p: ir_set.erst_base[1] = 0x%x\n", | ||
| 211 | addr, (unsigned int) temp); | ||
| 212 | 208 | ||
| 213 | addr = &ir_set->erst_dequeue[0]; | 209 | addr = &ir_set->erst_dequeue; |
| 214 | temp = xhci_readl(xhci, addr); | 210 | temp_64 = xhci_read_64(xhci, addr); |
| 215 | xhci_dbg(xhci, " %p: ir_set.erst_dequeue[0] = 0x%x\n", | 211 | xhci_dbg(xhci, " %p: ir_set.erst_dequeue = @%08llx\n", |
| 216 | addr, (unsigned int) temp); | 212 | addr, temp_64); |
| 217 | |||
| 218 | addr = &ir_set->erst_dequeue[1]; | ||
| 219 | temp = xhci_readl(xhci, addr); | ||
| 220 | xhci_dbg(xhci, " %p: ir_set.erst_dequeue[1] = 0x%x\n", | ||
| 221 | addr, (unsigned int) temp); | ||
| 222 | } | 213 | } |
| 223 | 214 | ||
| 224 | void xhci_print_run_regs(struct xhci_hcd *xhci) | 215 | void xhci_print_run_regs(struct xhci_hcd *xhci) |
| @@ -268,8 +259,7 @@ void xhci_debug_trb(struct xhci_hcd *xhci, union xhci_trb *trb) | |||
| 268 | xhci_dbg(xhci, "Link TRB:\n"); | 259 | xhci_dbg(xhci, "Link TRB:\n"); |
| 269 | xhci_print_trb_offsets(xhci, trb); | 260 | xhci_print_trb_offsets(xhci, trb); |
| 270 | 261 | ||
| 271 | address = trb->link.segment_ptr[0] + | 262 | address = trb->link.segment_ptr; |
| 272 | (((u64) trb->link.segment_ptr[1]) << 32); | ||
| 273 | xhci_dbg(xhci, "Next ring segment DMA address = 0x%llx\n", address); | 263 | xhci_dbg(xhci, "Next ring segment DMA address = 0x%llx\n", address); |
| 274 | 264 | ||
| 275 | xhci_dbg(xhci, "Interrupter target = 0x%x\n", | 265 | xhci_dbg(xhci, "Interrupter target = 0x%x\n", |
| @@ -282,8 +272,7 @@ void xhci_debug_trb(struct xhci_hcd *xhci, union xhci_trb *trb) | |||
| 282 | (unsigned int) (trb->link.control & TRB_NO_SNOOP)); | 272 | (unsigned int) (trb->link.control & TRB_NO_SNOOP)); |
| 283 | break; | 273 | break; |
| 284 | case TRB_TYPE(TRB_TRANSFER): | 274 | case TRB_TYPE(TRB_TRANSFER): |
| 285 | address = trb->trans_event.buffer[0] + | 275 | address = trb->trans_event.buffer; |
| 286 | (((u64) trb->trans_event.buffer[1]) << 32); | ||
| 287 | /* | 276 | /* |
| 288 | * FIXME: look at flags to figure out if it's an address or if | 277 | * FIXME: look at flags to figure out if it's an address or if |
| 289 | * the data is directly in the buffer field. | 278 | * the data is directly in the buffer field. |
| @@ -291,8 +280,7 @@ void xhci_debug_trb(struct xhci_hcd *xhci, union xhci_trb *trb) | |||
| 291 | xhci_dbg(xhci, "DMA address or buffer contents= %llu\n", address); | 280 | xhci_dbg(xhci, "DMA address or buffer contents= %llu\n", address); |
| 292 | break; | 281 | break; |
| 293 | case TRB_TYPE(TRB_COMPLETION): | 282 | case TRB_TYPE(TRB_COMPLETION): |
| 294 | address = trb->event_cmd.cmd_trb[0] + | 283 | address = trb->event_cmd.cmd_trb; |
| 295 | (((u64) trb->event_cmd.cmd_trb[1]) << 32); | ||
| 296 | xhci_dbg(xhci, "Command TRB pointer = %llu\n", address); | 284 | xhci_dbg(xhci, "Command TRB pointer = %llu\n", address); |
| 297 | xhci_dbg(xhci, "Completion status = %u\n", | 285 | xhci_dbg(xhci, "Completion status = %u\n", |
| 298 | (unsigned int) GET_COMP_CODE(trb->event_cmd.status)); | 286 | (unsigned int) GET_COMP_CODE(trb->event_cmd.status)); |
| @@ -328,8 +316,8 @@ void xhci_debug_segment(struct xhci_hcd *xhci, struct xhci_segment *seg) | |||
| 328 | for (i = 0; i < TRBS_PER_SEGMENT; ++i) { | 316 | for (i = 0; i < TRBS_PER_SEGMENT; ++i) { |
| 329 | trb = &seg->trbs[i]; | 317 | trb = &seg->trbs[i]; |
| 330 | xhci_dbg(xhci, "@%08x %08x %08x %08x %08x\n", addr, | 318 | xhci_dbg(xhci, "@%08x %08x %08x %08x %08x\n", addr, |
| 331 | (unsigned int) trb->link.segment_ptr[0], | 319 | lower_32_bits(trb->link.segment_ptr), |
| 332 | (unsigned int) trb->link.segment_ptr[1], | 320 | upper_32_bits(trb->link.segment_ptr), |
| 333 | (unsigned int) trb->link.intr_target, | 321 | (unsigned int) trb->link.intr_target, |
| 334 | (unsigned int) trb->link.control); | 322 | (unsigned int) trb->link.control); |
| 335 | addr += sizeof(*trb); | 323 | addr += sizeof(*trb); |
| @@ -386,8 +374,8 @@ void xhci_dbg_erst(struct xhci_hcd *xhci, struct xhci_erst *erst) | |||
| 386 | entry = &erst->entries[i]; | 374 | entry = &erst->entries[i]; |
| 387 | xhci_dbg(xhci, "@%08x %08x %08x %08x %08x\n", | 375 | xhci_dbg(xhci, "@%08x %08x %08x %08x %08x\n", |
| 388 | (unsigned int) addr, | 376 | (unsigned int) addr, |
| 389 | (unsigned int) entry->seg_addr[0], | 377 | lower_32_bits(entry->seg_addr), |
| 390 | (unsigned int) entry->seg_addr[1], | 378 | upper_32_bits(entry->seg_addr), |
| 391 | (unsigned int) entry->seg_size, | 379 | (unsigned int) entry->seg_size, |
| 392 | (unsigned int) entry->rsvd); | 380 | (unsigned int) entry->rsvd); |
| 393 | addr += sizeof(*entry); | 381 | addr += sizeof(*entry); |
| @@ -396,90 +384,147 @@ void xhci_dbg_erst(struct xhci_hcd *xhci, struct xhci_erst *erst) | |||
| 396 | 384 | ||
| 397 | void xhci_dbg_cmd_ptrs(struct xhci_hcd *xhci) | 385 | void xhci_dbg_cmd_ptrs(struct xhci_hcd *xhci) |
| 398 | { | 386 | { |
| 399 | u32 val; | 387 | u64 val; |
| 400 | 388 | ||
| 401 | val = xhci_readl(xhci, &xhci->op_regs->cmd_ring[0]); | 389 | val = xhci_read_64(xhci, &xhci->op_regs->cmd_ring); |
| 402 | xhci_dbg(xhci, "// xHC command ring deq ptr low bits + flags = 0x%x\n", val); | 390 | xhci_dbg(xhci, "// xHC command ring deq ptr low bits + flags = @%08x\n", |
| 403 | val = xhci_readl(xhci, &xhci->op_regs->cmd_ring[1]); | 391 | lower_32_bits(val)); |
| 404 | xhci_dbg(xhci, "// xHC command ring deq ptr high bits = 0x%x\n", val); | 392 | xhci_dbg(xhci, "// xHC command ring deq ptr high bits = @%08x\n", |
| 393 | upper_32_bits(val)); | ||
| 405 | } | 394 | } |
| 406 | 395 | ||
| 407 | void xhci_dbg_ctx(struct xhci_hcd *xhci, struct xhci_device_control *ctx, dma_addr_t dma, unsigned int last_ep) | 396 | /* Print the last 32 bytes for 64-byte contexts */ |
| 397 | static void dbg_rsvd64(struct xhci_hcd *xhci, u64 *ctx, dma_addr_t dma) | ||
| 398 | { | ||
| 399 | int i; | ||
| 400 | for (i = 0; i < 4; ++i) { | ||
| 401 | xhci_dbg(xhci, "@%p (virt) @%08llx " | ||
| 402 | "(dma) %#08llx - rsvd64[%d]\n", | ||
| 403 | &ctx[4 + i], (unsigned long long)dma, | ||
| 404 | ctx[4 + i], i); | ||
| 405 | dma += 8; | ||
| 406 | } | ||
| 407 | } | ||
| 408 | |||
| 409 | void xhci_dbg_slot_ctx(struct xhci_hcd *xhci, struct xhci_container_ctx *ctx) | ||
| 408 | { | 410 | { |
| 409 | int i, j; | ||
| 410 | int last_ep_ctx = 31; | ||
| 411 | /* Fields are 32 bits wide, DMA addresses are in bytes */ | 411 | /* Fields are 32 bits wide, DMA addresses are in bytes */ |
| 412 | int field_size = 32 / 8; | 412 | int field_size = 32 / 8; |
| 413 | int i; | ||
| 413 | 414 | ||
| 414 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - drop flags\n", | 415 | struct xhci_slot_ctx *slot_ctx = xhci_get_slot_ctx(xhci, ctx); |
| 415 | &ctx->drop_flags, (unsigned long long)dma, | 416 | dma_addr_t dma = ctx->dma + ((unsigned long)slot_ctx - (unsigned long)ctx); |
| 416 | ctx->drop_flags); | 417 | int csz = HCC_64BYTE_CONTEXT(xhci->hcc_params); |
| 417 | dma += field_size; | ||
| 418 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - add flags\n", | ||
| 419 | &ctx->add_flags, (unsigned long long)dma, | ||
| 420 | ctx->add_flags); | ||
| 421 | dma += field_size; | ||
| 422 | for (i = 0; i > 6; ++i) { | ||
| 423 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - rsvd[%d]\n", | ||
| 424 | &ctx->rsvd[i], (unsigned long long)dma, | ||
| 425 | ctx->rsvd[i], i); | ||
| 426 | dma += field_size; | ||
| 427 | } | ||
| 428 | 418 | ||
| 429 | xhci_dbg(xhci, "Slot Context:\n"); | 419 | xhci_dbg(xhci, "Slot Context:\n"); |
| 430 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - dev_info\n", | 420 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - dev_info\n", |
| 431 | &ctx->slot.dev_info, | 421 | &slot_ctx->dev_info, |
| 432 | (unsigned long long)dma, ctx->slot.dev_info); | 422 | (unsigned long long)dma, slot_ctx->dev_info); |
| 433 | dma += field_size; | 423 | dma += field_size; |
| 434 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - dev_info2\n", | 424 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - dev_info2\n", |
| 435 | &ctx->slot.dev_info2, | 425 | &slot_ctx->dev_info2, |
| 436 | (unsigned long long)dma, ctx->slot.dev_info2); | 426 | (unsigned long long)dma, slot_ctx->dev_info2); |
| 437 | dma += field_size; | 427 | dma += field_size; |
| 438 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - tt_info\n", | 428 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - tt_info\n", |
| 439 | &ctx->slot.tt_info, | 429 | &slot_ctx->tt_info, |
| 440 | (unsigned long long)dma, ctx->slot.tt_info); | 430 | (unsigned long long)dma, slot_ctx->tt_info); |
| 441 | dma += field_size; | 431 | dma += field_size; |
| 442 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - dev_state\n", | 432 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - dev_state\n", |
| 443 | &ctx->slot.dev_state, | 433 | &slot_ctx->dev_state, |
| 444 | (unsigned long long)dma, ctx->slot.dev_state); | 434 | (unsigned long long)dma, slot_ctx->dev_state); |
| 445 | dma += field_size; | 435 | dma += field_size; |
| 446 | for (i = 0; i > 4; ++i) { | 436 | for (i = 0; i < 4; ++i) { |
| 447 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - rsvd[%d]\n", | 437 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - rsvd[%d]\n", |
| 448 | &ctx->slot.reserved[i], (unsigned long long)dma, | 438 | &slot_ctx->reserved[i], (unsigned long long)dma, |
| 449 | ctx->slot.reserved[i], i); | 439 | slot_ctx->reserved[i], i); |
| 450 | dma += field_size; | 440 | dma += field_size; |
| 451 | } | 441 | } |
| 452 | 442 | ||
| 443 | if (csz) | ||
| 444 | dbg_rsvd64(xhci, (u64 *)slot_ctx, dma); | ||
| 445 | } | ||
| 446 | |||
| 447 | void xhci_dbg_ep_ctx(struct xhci_hcd *xhci, | ||
| 448 | struct xhci_container_ctx *ctx, | ||
| 449 | unsigned int last_ep) | ||
| 450 | { | ||
| 451 | int i, j; | ||
| 452 | int last_ep_ctx = 31; | ||
| 453 | /* Fields are 32 bits wide, DMA addresses are in bytes */ | ||
| 454 | int field_size = 32 / 8; | ||
| 455 | int csz = HCC_64BYTE_CONTEXT(xhci->hcc_params); | ||
| 456 | |||
| 453 | if (last_ep < 31) | 457 | if (last_ep < 31) |
| 454 | last_ep_ctx = last_ep + 1; | 458 | last_ep_ctx = last_ep + 1; |
| 455 | for (i = 0; i < last_ep_ctx; ++i) { | 459 | for (i = 0; i < last_ep_ctx; ++i) { |
| 460 | struct xhci_ep_ctx *ep_ctx = xhci_get_ep_ctx(xhci, ctx, i); | ||
| 461 | dma_addr_t dma = ctx->dma + | ||
| 462 | ((unsigned long)ep_ctx - (unsigned long)ctx); | ||
| 463 | |||
| 456 | xhci_dbg(xhci, "Endpoint %02d Context:\n", i); | 464 | xhci_dbg(xhci, "Endpoint %02d Context:\n", i); |
| 457 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - ep_info\n", | 465 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - ep_info\n", |
| 458 | &ctx->ep[i].ep_info, | 466 | &ep_ctx->ep_info, |
| 459 | (unsigned long long)dma, ctx->ep[i].ep_info); | 467 | (unsigned long long)dma, ep_ctx->ep_info); |
| 460 | dma += field_size; | 468 | dma += field_size; |
| 461 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - ep_info2\n", | 469 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - ep_info2\n", |
| 462 | &ctx->ep[i].ep_info2, | 470 | &ep_ctx->ep_info2, |
| 463 | (unsigned long long)dma, ctx->ep[i].ep_info2); | 471 | (unsigned long long)dma, ep_ctx->ep_info2); |
| 464 | dma += field_size; | ||
| 465 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - deq[0]\n", | ||
| 466 | &ctx->ep[i].deq[0], | ||
| 467 | (unsigned long long)dma, ctx->ep[i].deq[0]); | ||
| 468 | dma += field_size; | ||
| 469 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - deq[1]\n", | ||
| 470 | &ctx->ep[i].deq[1], | ||
| 471 | (unsigned long long)dma, ctx->ep[i].deq[1]); | ||
| 472 | dma += field_size; | 472 | dma += field_size; |
| 473 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08llx - deq\n", | ||
| 474 | &ep_ctx->deq, | ||
| 475 | (unsigned long long)dma, ep_ctx->deq); | ||
| 476 | dma += 2*field_size; | ||
| 473 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - tx_info\n", | 477 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - tx_info\n", |
| 474 | &ctx->ep[i].tx_info, | 478 | &ep_ctx->tx_info, |
| 475 | (unsigned long long)dma, ctx->ep[i].tx_info); | 479 | (unsigned long long)dma, ep_ctx->tx_info); |
| 476 | dma += field_size; | 480 | dma += field_size; |
| 477 | for (j = 0; j < 3; ++j) { | 481 | for (j = 0; j < 3; ++j) { |
| 478 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - rsvd[%d]\n", | 482 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - rsvd[%d]\n", |
| 479 | &ctx->ep[i].reserved[j], | 483 | &ep_ctx->reserved[j], |
| 480 | (unsigned long long)dma, | 484 | (unsigned long long)dma, |
| 481 | ctx->ep[i].reserved[j], j); | 485 | ep_ctx->reserved[j], j); |
| 486 | dma += field_size; | ||
| 487 | } | ||
| 488 | |||
| 489 | if (csz) | ||
| 490 | dbg_rsvd64(xhci, (u64 *)ep_ctx, dma); | ||
| 491 | } | ||
| 492 | } | ||
| 493 | |||
| 494 | void xhci_dbg_ctx(struct xhci_hcd *xhci, | ||
| 495 | struct xhci_container_ctx *ctx, | ||
| 496 | unsigned int last_ep) | ||
| 497 | { | ||
| 498 | int i; | ||
| 499 | /* Fields are 32 bits wide, DMA addresses are in bytes */ | ||
| 500 | int field_size = 32 / 8; | ||
| 501 | struct xhci_slot_ctx *slot_ctx; | ||
| 502 | dma_addr_t dma = ctx->dma; | ||
| 503 | int csz = HCC_64BYTE_CONTEXT(xhci->hcc_params); | ||
| 504 | |||
| 505 | if (ctx->type == XHCI_CTX_TYPE_INPUT) { | ||
| 506 | struct xhci_input_control_ctx *ctrl_ctx = | ||
| 507 | xhci_get_input_control_ctx(xhci, ctx); | ||
| 508 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - drop flags\n", | ||
| 509 | &ctrl_ctx->drop_flags, (unsigned long long)dma, | ||
| 510 | ctrl_ctx->drop_flags); | ||
| 511 | dma += field_size; | ||
| 512 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - add flags\n", | ||
| 513 | &ctrl_ctx->add_flags, (unsigned long long)dma, | ||
| 514 | ctrl_ctx->add_flags); | ||
| 515 | dma += field_size; | ||
| 516 | for (i = 0; i < 6; ++i) { | ||
| 517 | xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - rsvd2[%d]\n", | ||
| 518 | &ctrl_ctx->rsvd2[i], (unsigned long long)dma, | ||
| 519 | ctrl_ctx->rsvd2[i], i); | ||
| 482 | dma += field_size; | 520 | dma += field_size; |
| 483 | } | 521 | } |
| 522 | |||
| 523 | if (csz) | ||
| 524 | dbg_rsvd64(xhci, (u64 *)ctrl_ctx, dma); | ||
| 484 | } | 525 | } |
| 526 | |||
| 527 | slot_ctx = xhci_get_slot_ctx(xhci, ctx); | ||
| 528 | xhci_dbg_slot_ctx(xhci, ctx); | ||
| 529 | xhci_dbg_ep_ctx(xhci, ctx, last_ep); | ||
| 485 | } | 530 | } |
diff --git a/drivers/usb/host/xhci-hcd.c b/drivers/usb/host/xhci-hcd.c index dba3e07ccd09..816c39caca1c 100644 --- a/drivers/usb/host/xhci-hcd.c +++ b/drivers/usb/host/xhci-hcd.c | |||
| @@ -103,7 +103,10 @@ int xhci_reset(struct xhci_hcd *xhci) | |||
| 103 | u32 state; | 103 | u32 state; |
| 104 | 104 | ||
| 105 | state = xhci_readl(xhci, &xhci->op_regs->status); | 105 | state = xhci_readl(xhci, &xhci->op_regs->status); |
| 106 | BUG_ON((state & STS_HALT) == 0); | 106 | if ((state & STS_HALT) == 0) { |
| 107 | xhci_warn(xhci, "Host controller not halted, aborting reset.\n"); | ||
| 108 | return 0; | ||
| 109 | } | ||
| 107 | 110 | ||
| 108 | xhci_dbg(xhci, "// Reset the HC\n"); | 111 | xhci_dbg(xhci, "// Reset the HC\n"); |
| 109 | command = xhci_readl(xhci, &xhci->op_regs->command); | 112 | command = xhci_readl(xhci, &xhci->op_regs->command); |
| @@ -226,6 +229,7 @@ int xhci_init(struct usb_hcd *hcd) | |||
| 226 | static void xhci_work(struct xhci_hcd *xhci) | 229 | static void xhci_work(struct xhci_hcd *xhci) |
| 227 | { | 230 | { |
| 228 | u32 temp; | 231 | u32 temp; |
| 232 | u64 temp_64; | ||
| 229 | 233 | ||
| 230 | /* | 234 | /* |
| 231 | * Clear the op reg interrupt status first, | 235 | * Clear the op reg interrupt status first, |
| @@ -248,9 +252,9 @@ static void xhci_work(struct xhci_hcd *xhci) | |||
| 248 | /* FIXME this should be a delayed service routine that clears the EHB */ | 252 | /* FIXME this should be a delayed service routine that clears the EHB */ |
| 249 | xhci_handle_event(xhci); | 253 | xhci_handle_event(xhci); |
| 250 | 254 | ||
| 251 | /* Clear the event handler busy flag; the event ring should be empty. */ | 255 | /* Clear the event handler busy flag (RW1C); the event ring should be empty. */ |
| 252 | temp = xhci_readl(xhci, &xhci->ir_set->erst_dequeue[0]); | 256 | temp_64 = xhci_read_64(xhci, &xhci->ir_set->erst_dequeue); |
| 253 | xhci_writel(xhci, temp & ~ERST_EHB, &xhci->ir_set->erst_dequeue[0]); | 257 | xhci_write_64(xhci, temp_64 | ERST_EHB, &xhci->ir_set->erst_dequeue); |
| 254 | /* Flush posted writes -- FIXME is this necessary? */ | 258 | /* Flush posted writes -- FIXME is this necessary? */ |
| 255 | xhci_readl(xhci, &xhci->ir_set->irq_pending); | 259 | xhci_readl(xhci, &xhci->ir_set->irq_pending); |
| 256 | } | 260 | } |
| @@ -266,19 +270,34 @@ irqreturn_t xhci_irq(struct usb_hcd *hcd) | |||
| 266 | { | 270 | { |
| 267 | struct xhci_hcd *xhci = hcd_to_xhci(hcd); | 271 | struct xhci_hcd *xhci = hcd_to_xhci(hcd); |
| 268 | u32 temp, temp2; | 272 | u32 temp, temp2; |
| 273 | union xhci_trb *trb; | ||
| 269 | 274 | ||
| 270 | spin_lock(&xhci->lock); | 275 | spin_lock(&xhci->lock); |
| 276 | trb = xhci->event_ring->dequeue; | ||
| 271 | /* Check if the xHC generated the interrupt, or the irq is shared */ | 277 | /* Check if the xHC generated the interrupt, or the irq is shared */ |
| 272 | temp = xhci_readl(xhci, &xhci->op_regs->status); | 278 | temp = xhci_readl(xhci, &xhci->op_regs->status); |
| 273 | temp2 = xhci_readl(xhci, &xhci->ir_set->irq_pending); | 279 | temp2 = xhci_readl(xhci, &xhci->ir_set->irq_pending); |
| 280 | if (temp == 0xffffffff && temp2 == 0xffffffff) | ||
| 281 | goto hw_died; | ||
| 282 | |||
| 274 | if (!(temp & STS_EINT) && !ER_IRQ_PENDING(temp2)) { | 283 | if (!(temp & STS_EINT) && !ER_IRQ_PENDING(temp2)) { |
| 275 | spin_unlock(&xhci->lock); | 284 | spin_unlock(&xhci->lock); |
| 276 | return IRQ_NONE; | 285 | return IRQ_NONE; |
| 277 | } | 286 | } |
| 287 | xhci_dbg(xhci, "op reg status = %08x\n", temp); | ||
| 288 | xhci_dbg(xhci, "ir set irq_pending = %08x\n", temp2); | ||
| 289 | xhci_dbg(xhci, "Event ring dequeue ptr:\n"); | ||
| 290 | xhci_dbg(xhci, "@%llx %08x %08x %08x %08x\n", | ||
| 291 | (unsigned long long)xhci_trb_virt_to_dma(xhci->event_ring->deq_seg, trb), | ||
| 292 | lower_32_bits(trb->link.segment_ptr), | ||
| 293 | upper_32_bits(trb->link.segment_ptr), | ||
| 294 | (unsigned int) trb->link.intr_target, | ||
| 295 | (unsigned int) trb->link.control); | ||
| 278 | 296 | ||
| 279 | if (temp & STS_FATAL) { | 297 | if (temp & STS_FATAL) { |
| 280 | xhci_warn(xhci, "WARNING: Host System Error\n"); | 298 | xhci_warn(xhci, "WARNING: Host System Error\n"); |
| 281 | xhci_halt(xhci); | 299 | xhci_halt(xhci); |
| 300 | hw_died: | ||
| 282 | xhci_to_hcd(xhci)->state = HC_STATE_HALT; | 301 | xhci_to_hcd(xhci)->state = HC_STATE_HALT; |
| 283 | spin_unlock(&xhci->lock); | 302 | spin_unlock(&xhci->lock); |
| 284 | return -ESHUTDOWN; | 303 | return -ESHUTDOWN; |
| @@ -295,6 +314,7 @@ void xhci_event_ring_work(unsigned long arg) | |||
| 295 | { | 314 | { |
| 296 | unsigned long flags; | 315 | unsigned long flags; |
| 297 | int temp; | 316 | int temp; |
| 317 | u64 temp_64; | ||
| 298 | struct xhci_hcd *xhci = (struct xhci_hcd *) arg; | 318 | struct xhci_hcd *xhci = (struct xhci_hcd *) arg; |
| 299 | int i, j; | 319 | int i, j; |
| 300 | 320 | ||
| @@ -311,9 +331,9 @@ void xhci_event_ring_work(unsigned long arg) | |||
| 311 | xhci_dbg(xhci, "Event ring:\n"); | 331 | xhci_dbg(xhci, "Event ring:\n"); |
| 312 | xhci_debug_segment(xhci, xhci->event_ring->deq_seg); | 332 | xhci_debug_segment(xhci, xhci->event_ring->deq_seg); |
| 313 | xhci_dbg_ring_ptrs(xhci, xhci->event_ring); | 333 | xhci_dbg_ring_ptrs(xhci, xhci->event_ring); |
| 314 | temp = xhci_readl(xhci, &xhci->ir_set->erst_dequeue[0]); | 334 | temp_64 = xhci_read_64(xhci, &xhci->ir_set->erst_dequeue); |
| 315 | temp &= ERST_PTR_MASK; | 335 | temp_64 &= ~ERST_PTR_MASK; |
| 316 | xhci_dbg(xhci, "ERST deq = 0x%x\n", temp); | 336 | xhci_dbg(xhci, "ERST deq = 64'h%0lx\n", (long unsigned int) temp_64); |
| 317 | xhci_dbg(xhci, "Command ring:\n"); | 337 | xhci_dbg(xhci, "Command ring:\n"); |
| 318 | xhci_debug_segment(xhci, xhci->cmd_ring->deq_seg); | 338 | xhci_debug_segment(xhci, xhci->cmd_ring->deq_seg); |
| 319 | xhci_dbg_ring_ptrs(xhci, xhci->cmd_ring); | 339 | xhci_dbg_ring_ptrs(xhci, xhci->cmd_ring); |
| @@ -356,6 +376,7 @@ void xhci_event_ring_work(unsigned long arg) | |||
| 356 | int xhci_run(struct usb_hcd *hcd) | 376 | int xhci_run(struct usb_hcd *hcd) |
| 357 | { | 377 | { |
| 358 | u32 temp; | 378 | u32 temp; |
| 379 | u64 temp_64; | ||
| 359 | struct xhci_hcd *xhci = hcd_to_xhci(hcd); | 380 | struct xhci_hcd *xhci = hcd_to_xhci(hcd); |
| 360 | void (*doorbell)(struct xhci_hcd *) = NULL; | 381 | void (*doorbell)(struct xhci_hcd *) = NULL; |
| 361 | 382 | ||
| @@ -382,6 +403,20 @@ int xhci_run(struct usb_hcd *hcd) | |||
| 382 | add_timer(&xhci->event_ring_timer); | 403 | add_timer(&xhci->event_ring_timer); |
| 383 | #endif | 404 | #endif |
| 384 | 405 | ||
| 406 | xhci_dbg(xhci, "Command ring memory map follows:\n"); | ||
| 407 | xhci_debug_ring(xhci, xhci->cmd_ring); | ||
| 408 | xhci_dbg_ring_ptrs(xhci, xhci->cmd_ring); | ||
| 409 | xhci_dbg_cmd_ptrs(xhci); | ||
| 410 | |||
| 411 | xhci_dbg(xhci, "ERST memory map follows:\n"); | ||
| 412 | xhci_dbg_erst(xhci, &xhci->erst); | ||
| 413 | xhci_dbg(xhci, "Event ring:\n"); | ||
| 414 | xhci_debug_ring(xhci, xhci->event_ring); | ||
| 415 | xhci_dbg_ring_ptrs(xhci, xhci->event_ring); | ||
| 416 | temp_64 = xhci_read_64(xhci, &xhci->ir_set->erst_dequeue); | ||
| 417 | temp_64 &= ~ERST_PTR_MASK; | ||
| 418 | xhci_dbg(xhci, "ERST deq = 64'h%0lx\n", (long unsigned int) temp_64); | ||
| 419 | |||
| 385 | xhci_dbg(xhci, "// Set the interrupt modulation register\n"); | 420 | xhci_dbg(xhci, "// Set the interrupt modulation register\n"); |
| 386 | temp = xhci_readl(xhci, &xhci->ir_set->irq_control); | 421 | temp = xhci_readl(xhci, &xhci->ir_set->irq_control); |
| 387 | temp &= ~ER_IRQ_INTERVAL_MASK; | 422 | temp &= ~ER_IRQ_INTERVAL_MASK; |
| @@ -406,22 +441,6 @@ int xhci_run(struct usb_hcd *hcd) | |||
| 406 | if (NUM_TEST_NOOPS > 0) | 441 | if (NUM_TEST_NOOPS > 0) |
| 407 | doorbell = xhci_setup_one_noop(xhci); | 442 | doorbell = xhci_setup_one_noop(xhci); |
| 408 | 443 | ||
| 409 | xhci_dbg(xhci, "Command ring memory map follows:\n"); | ||
| 410 | xhci_debug_ring(xhci, xhci->cmd_ring); | ||
| 411 | xhci_dbg_ring_ptrs(xhci, xhci->cmd_ring); | ||
| 412 | xhci_dbg_cmd_ptrs(xhci); | ||
| 413 | |||
| 414 | xhci_dbg(xhci, "ERST memory map follows:\n"); | ||
| 415 | xhci_dbg_erst(xhci, &xhci->erst); | ||
| 416 | xhci_dbg(xhci, "Event ring:\n"); | ||
| 417 | xhci_debug_ring(xhci, xhci->event_ring); | ||
| 418 | xhci_dbg_ring_ptrs(xhci, xhci->event_ring); | ||
| 419 | temp = xhci_readl(xhci, &xhci->ir_set->erst_dequeue[0]); | ||
| 420 | temp &= ERST_PTR_MASK; | ||
| 421 | xhci_dbg(xhci, "ERST deq = 0x%x\n", temp); | ||
| 422 | temp = xhci_readl(xhci, &xhci->ir_set->erst_dequeue[1]); | ||
| 423 | xhci_dbg(xhci, "ERST deq upper = 0x%x\n", temp); | ||
| 424 | |||
| 425 | temp = xhci_readl(xhci, &xhci->op_regs->command); | 444 | temp = xhci_readl(xhci, &xhci->op_regs->command); |
| 426 | temp |= (CMD_RUN); | 445 | temp |= (CMD_RUN); |
| 427 | xhci_dbg(xhci, "// Turn on HC, cmd = 0x%x.\n", | 446 | xhci_dbg(xhci, "// Turn on HC, cmd = 0x%x.\n", |
| @@ -601,10 +620,13 @@ int xhci_urb_enqueue(struct usb_hcd *hcd, struct urb *urb, gfp_t mem_flags) | |||
| 601 | goto exit; | 620 | goto exit; |
| 602 | } | 621 | } |
| 603 | if (usb_endpoint_xfer_control(&urb->ep->desc)) | 622 | if (usb_endpoint_xfer_control(&urb->ep->desc)) |
| 604 | ret = xhci_queue_ctrl_tx(xhci, mem_flags, urb, | 623 | /* We have a spinlock and interrupts disabled, so we must pass |
| 624 | * atomic context to this function, which may allocate memory. | ||
| 625 | */ | ||
| 626 | ret = xhci_queue_ctrl_tx(xhci, GFP_ATOMIC, urb, | ||
| 605 | slot_id, ep_index); | 627 | slot_id, ep_index); |
| 606 | else if (usb_endpoint_xfer_bulk(&urb->ep->desc)) | 628 | else if (usb_endpoint_xfer_bulk(&urb->ep->desc)) |
| 607 | ret = xhci_queue_bulk_tx(xhci, mem_flags, urb, | 629 | ret = xhci_queue_bulk_tx(xhci, GFP_ATOMIC, urb, |
| 608 | slot_id, ep_index); | 630 | slot_id, ep_index); |
| 609 | else | 631 | else |
| 610 | ret = -EINVAL; | 632 | ret = -EINVAL; |
| @@ -661,8 +683,12 @@ int xhci_urb_dequeue(struct usb_hcd *hcd, struct urb *urb, int status) | |||
| 661 | goto done; | 683 | goto done; |
| 662 | 684 | ||
| 663 | xhci_dbg(xhci, "Cancel URB %p\n", urb); | 685 | xhci_dbg(xhci, "Cancel URB %p\n", urb); |
| 686 | xhci_dbg(xhci, "Event ring:\n"); | ||
| 687 | xhci_debug_ring(xhci, xhci->event_ring); | ||
| 664 | ep_index = xhci_get_endpoint_index(&urb->ep->desc); | 688 | ep_index = xhci_get_endpoint_index(&urb->ep->desc); |
| 665 | ep_ring = xhci->devs[urb->dev->slot_id]->ep_rings[ep_index]; | 689 | ep_ring = xhci->devs[urb->dev->slot_id]->ep_rings[ep_index]; |
| 690 | xhci_dbg(xhci, "Endpoint ring:\n"); | ||
| 691 | xhci_debug_ring(xhci, ep_ring); | ||
| 666 | td = (struct xhci_td *) urb->hcpriv; | 692 | td = (struct xhci_td *) urb->hcpriv; |
| 667 | 693 | ||
| 668 | ep_ring->cancels_pending++; | 694 | ep_ring->cancels_pending++; |
| @@ -696,7 +722,9 @@ int xhci_drop_endpoint(struct usb_hcd *hcd, struct usb_device *udev, | |||
| 696 | struct usb_host_endpoint *ep) | 722 | struct usb_host_endpoint *ep) |
| 697 | { | 723 | { |
| 698 | struct xhci_hcd *xhci; | 724 | struct xhci_hcd *xhci; |
| 699 | struct xhci_device_control *in_ctx; | 725 | struct xhci_container_ctx *in_ctx, *out_ctx; |
| 726 | struct xhci_input_control_ctx *ctrl_ctx; | ||
| 727 | struct xhci_slot_ctx *slot_ctx; | ||
| 700 | unsigned int last_ctx; | 728 | unsigned int last_ctx; |
| 701 | unsigned int ep_index; | 729 | unsigned int ep_index; |
| 702 | struct xhci_ep_ctx *ep_ctx; | 730 | struct xhci_ep_ctx *ep_ctx; |
| @@ -724,31 +752,34 @@ int xhci_drop_endpoint(struct usb_hcd *hcd, struct usb_device *udev, | |||
| 724 | } | 752 | } |
| 725 | 753 | ||
| 726 | in_ctx = xhci->devs[udev->slot_id]->in_ctx; | 754 | in_ctx = xhci->devs[udev->slot_id]->in_ctx; |
| 755 | out_ctx = xhci->devs[udev->slot_id]->out_ctx; | ||
| 756 | ctrl_ctx = xhci_get_input_control_ctx(xhci, in_ctx); | ||
| 727 | ep_index = xhci_get_endpoint_index(&ep->desc); | 757 | ep_index = xhci_get_endpoint_index(&ep->desc); |
| 728 | ep_ctx = &xhci->devs[udev->slot_id]->out_ctx->ep[ep_index]; | 758 | ep_ctx = xhci_get_ep_ctx(xhci, out_ctx, ep_index); |
| 729 | /* If the HC already knows the endpoint is disabled, | 759 | /* If the HC already knows the endpoint is disabled, |
| 730 | * or the HCD has noted it is disabled, ignore this request | 760 | * or the HCD has noted it is disabled, ignore this request |
| 731 | */ | 761 | */ |
| 732 | if ((ep_ctx->ep_info & EP_STATE_MASK) == EP_STATE_DISABLED || | 762 | if ((ep_ctx->ep_info & EP_STATE_MASK) == EP_STATE_DISABLED || |
| 733 | in_ctx->drop_flags & xhci_get_endpoint_flag(&ep->desc)) { | 763 | ctrl_ctx->drop_flags & xhci_get_endpoint_flag(&ep->desc)) { |
| 734 | xhci_warn(xhci, "xHCI %s called with disabled ep %p\n", | 764 | xhci_warn(xhci, "xHCI %s called with disabled ep %p\n", |
| 735 | __func__, ep); | 765 | __func__, ep); |
| 736 | return 0; | 766 | return 0; |
| 737 | } | 767 | } |
| 738 | 768 | ||
| 739 | in_ctx->drop_flags |= drop_flag; | 769 | ctrl_ctx->drop_flags |= drop_flag; |
| 740 | new_drop_flags = in_ctx->drop_flags; | 770 | new_drop_flags = ctrl_ctx->drop_flags; |
| 741 | 771 | ||
| 742 | in_ctx->add_flags = ~drop_flag; | 772 | ctrl_ctx->add_flags = ~drop_flag; |
| 743 | new_add_flags = in_ctx->add_flags; | 773 | new_add_flags = ctrl_ctx->add_flags; |
| 744 | 774 | ||
| 745 | last_ctx = xhci_last_valid_endpoint(in_ctx->add_flags); | 775 | last_ctx = xhci_last_valid_endpoint(ctrl_ctx->add_flags); |
| 776 | slot_ctx = xhci_get_slot_ctx(xhci, in_ctx); | ||
| 746 | /* Update the last valid endpoint context, if we deleted the last one */ | 777 | /* Update the last valid endpoint context, if we deleted the last one */ |
| 747 | if ((in_ctx->slot.dev_info & LAST_CTX_MASK) > LAST_CTX(last_ctx)) { | 778 | if ((slot_ctx->dev_info & LAST_CTX_MASK) > LAST_CTX(last_ctx)) { |
| 748 | in_ctx->slot.dev_info &= ~LAST_CTX_MASK; | 779 | slot_ctx->dev_info &= ~LAST_CTX_MASK; |
| 749 | in_ctx->slot.dev_info |= LAST_CTX(last_ctx); | 780 | slot_ctx->dev_info |= LAST_CTX(last_ctx); |
| 750 | } | 781 | } |
| 751 | new_slot_info = in_ctx->slot.dev_info; | 782 | new_slot_info = slot_ctx->dev_info; |
| 752 | 783 | ||
| 753 | xhci_endpoint_zero(xhci, xhci->devs[udev->slot_id], ep); | 784 | xhci_endpoint_zero(xhci, xhci->devs[udev->slot_id], ep); |
| 754 | 785 | ||
| @@ -778,17 +809,22 @@ int xhci_add_endpoint(struct usb_hcd *hcd, struct usb_device *udev, | |||
| 778 | struct usb_host_endpoint *ep) | 809 | struct usb_host_endpoint *ep) |
| 779 | { | 810 | { |
| 780 | struct xhci_hcd *xhci; | 811 | struct xhci_hcd *xhci; |
| 781 | struct xhci_device_control *in_ctx; | 812 | struct xhci_container_ctx *in_ctx, *out_ctx; |
| 782 | unsigned int ep_index; | 813 | unsigned int ep_index; |
| 783 | struct xhci_ep_ctx *ep_ctx; | 814 | struct xhci_ep_ctx *ep_ctx; |
| 815 | struct xhci_slot_ctx *slot_ctx; | ||
| 816 | struct xhci_input_control_ctx *ctrl_ctx; | ||
| 784 | u32 added_ctxs; | 817 | u32 added_ctxs; |
| 785 | unsigned int last_ctx; | 818 | unsigned int last_ctx; |
| 786 | u32 new_add_flags, new_drop_flags, new_slot_info; | 819 | u32 new_add_flags, new_drop_flags, new_slot_info; |
| 787 | int ret = 0; | 820 | int ret = 0; |
| 788 | 821 | ||
| 789 | ret = xhci_check_args(hcd, udev, ep, 1, __func__); | 822 | ret = xhci_check_args(hcd, udev, ep, 1, __func__); |
| 790 | if (ret <= 0) | 823 | if (ret <= 0) { |
| 824 | /* So we won't queue a reset ep command for a root hub */ | ||
| 825 | ep->hcpriv = NULL; | ||
| 791 | return ret; | 826 | return ret; |
| 827 | } | ||
| 792 | xhci = hcd_to_xhci(hcd); | 828 | xhci = hcd_to_xhci(hcd); |
| 793 | 829 | ||
| 794 | added_ctxs = xhci_get_endpoint_flag(&ep->desc); | 830 | added_ctxs = xhci_get_endpoint_flag(&ep->desc); |
| @@ -810,12 +846,14 @@ int xhci_add_endpoint(struct usb_hcd *hcd, struct usb_device *udev, | |||
| 810 | } | 846 | } |
| 811 | 847 | ||
| 812 | in_ctx = xhci->devs[udev->slot_id]->in_ctx; | 848 | in_ctx = xhci->devs[udev->slot_id]->in_ctx; |
| 849 | out_ctx = xhci->devs[udev->slot_id]->out_ctx; | ||
| 850 | ctrl_ctx = xhci_get_input_control_ctx(xhci, in_ctx); | ||
| 813 | ep_index = xhci_get_endpoint_index(&ep->desc); | 851 | ep_index = xhci_get_endpoint_index(&ep->desc); |
| 814 | ep_ctx = &xhci->devs[udev->slot_id]->out_ctx->ep[ep_index]; | 852 | ep_ctx = xhci_get_ep_ctx(xhci, out_ctx, ep_index); |
| 815 | /* If the HCD has already noted the endpoint is enabled, | 853 | /* If the HCD has already noted the endpoint is enabled, |
| 816 | * ignore this request. | 854 | * ignore this request. |
| 817 | */ | 855 | */ |
| 818 | if (in_ctx->add_flags & xhci_get_endpoint_flag(&ep->desc)) { | 856 | if (ctrl_ctx->add_flags & xhci_get_endpoint_flag(&ep->desc)) { |
| 819 | xhci_warn(xhci, "xHCI %s called with enabled ep %p\n", | 857 | xhci_warn(xhci, "xHCI %s called with enabled ep %p\n", |
| 820 | __func__, ep); | 858 | __func__, ep); |
| 821 | return 0; | 859 | return 0; |
| @@ -833,8 +871,8 @@ int xhci_add_endpoint(struct usb_hcd *hcd, struct usb_device *udev, | |||
| 833 | return -ENOMEM; | 871 | return -ENOMEM; |
| 834 | } | 872 | } |
| 835 | 873 | ||
| 836 | in_ctx->add_flags |= added_ctxs; | 874 | ctrl_ctx->add_flags |= added_ctxs; |
| 837 | new_add_flags = in_ctx->add_flags; | 875 | new_add_flags = ctrl_ctx->add_flags; |
| 838 | 876 | ||
| 839 | /* If xhci_endpoint_disable() was called for this endpoint, but the | 877 | /* If xhci_endpoint_disable() was called for this endpoint, but the |
| 840 | * xHC hasn't been notified yet through the check_bandwidth() call, | 878 | * xHC hasn't been notified yet through the check_bandwidth() call, |
| @@ -842,14 +880,18 @@ int xhci_add_endpoint(struct usb_hcd *hcd, struct usb_device *udev, | |||
| 842 | * descriptors. We must drop and re-add this endpoint, so we leave the | 880 | * descriptors. We must drop and re-add this endpoint, so we leave the |
| 843 | * drop flags alone. | 881 | * drop flags alone. |
| 844 | */ | 882 | */ |
| 845 | new_drop_flags = in_ctx->drop_flags; | 883 | new_drop_flags = ctrl_ctx->drop_flags; |
| 846 | 884 | ||
| 885 | slot_ctx = xhci_get_slot_ctx(xhci, in_ctx); | ||
| 847 | /* Update the last valid endpoint context, if we just added one past */ | 886 | /* Update the last valid endpoint context, if we just added one past */ |
| 848 | if ((in_ctx->slot.dev_info & LAST_CTX_MASK) < LAST_CTX(last_ctx)) { | 887 | if ((slot_ctx->dev_info & LAST_CTX_MASK) < LAST_CTX(last_ctx)) { |
| 849 | in_ctx->slot.dev_info &= ~LAST_CTX_MASK; | 888 | slot_ctx->dev_info &= ~LAST_CTX_MASK; |
| 850 | in_ctx->slot.dev_info |= LAST_CTX(last_ctx); | 889 | slot_ctx->dev_info |= LAST_CTX(last_ctx); |
| 851 | } | 890 | } |
| 852 | new_slot_info = in_ctx->slot.dev_info; | 891 | new_slot_info = slot_ctx->dev_info; |
| 892 | |||
| 893 | /* Store the usb_device pointer for later use */ | ||
| 894 | ep->hcpriv = udev; | ||
| 853 | 895 | ||
| 854 | xhci_dbg(xhci, "add ep 0x%x, slot id %d, new drop flags = %#x, new add flags = %#x, new slot info = %#x\n", | 896 | xhci_dbg(xhci, "add ep 0x%x, slot id %d, new drop flags = %#x, new add flags = %#x, new slot info = %#x\n", |
| 855 | (unsigned int) ep->desc.bEndpointAddress, | 897 | (unsigned int) ep->desc.bEndpointAddress, |
| @@ -860,9 +902,11 @@ int xhci_add_endpoint(struct usb_hcd *hcd, struct usb_device *udev, | |||
| 860 | return 0; | 902 | return 0; |
| 861 | } | 903 | } |
| 862 | 904 | ||
| 863 | static void xhci_zero_in_ctx(struct xhci_virt_device *virt_dev) | 905 | static void xhci_zero_in_ctx(struct xhci_hcd *xhci, struct xhci_virt_device *virt_dev) |
| 864 | { | 906 | { |
| 907 | struct xhci_input_control_ctx *ctrl_ctx; | ||
| 865 | struct xhci_ep_ctx *ep_ctx; | 908 | struct xhci_ep_ctx *ep_ctx; |
| 909 | struct xhci_slot_ctx *slot_ctx; | ||
| 866 | int i; | 910 | int i; |
| 867 | 911 | ||
| 868 | /* When a device's add flag and drop flag are zero, any subsequent | 912 | /* When a device's add flag and drop flag are zero, any subsequent |
| @@ -870,17 +914,18 @@ static void xhci_zero_in_ctx(struct xhci_virt_device *virt_dev) | |||
| 870 | * untouched. Make sure we don't leave any old state in the input | 914 | * untouched. Make sure we don't leave any old state in the input |
| 871 | * endpoint contexts. | 915 | * endpoint contexts. |
| 872 | */ | 916 | */ |
| 873 | virt_dev->in_ctx->drop_flags = 0; | 917 | ctrl_ctx = xhci_get_input_control_ctx(xhci, virt_dev->in_ctx); |
| 874 | virt_dev->in_ctx->add_flags = 0; | 918 | ctrl_ctx->drop_flags = 0; |
| 875 | virt_dev->in_ctx->slot.dev_info &= ~LAST_CTX_MASK; | 919 | ctrl_ctx->add_flags = 0; |
| 920 | slot_ctx = xhci_get_slot_ctx(xhci, virt_dev->in_ctx); | ||
| 921 | slot_ctx->dev_info &= ~LAST_CTX_MASK; | ||
| 876 | /* Endpoint 0 is always valid */ | 922 | /* Endpoint 0 is always valid */ |
| 877 | virt_dev->in_ctx->slot.dev_info |= LAST_CTX(1); | 923 | slot_ctx->dev_info |= LAST_CTX(1); |
| 878 | for (i = 1; i < 31; ++i) { | 924 | for (i = 1; i < 31; ++i) { |
| 879 | ep_ctx = &virt_dev->in_ctx->ep[i]; | 925 | ep_ctx = xhci_get_ep_ctx(xhci, virt_dev->in_ctx, i); |
| 880 | ep_ctx->ep_info = 0; | 926 | ep_ctx->ep_info = 0; |
| 881 | ep_ctx->ep_info2 = 0; | 927 | ep_ctx->ep_info2 = 0; |
| 882 | ep_ctx->deq[0] = 0; | 928 | ep_ctx->deq = 0; |
| 883 | ep_ctx->deq[1] = 0; | ||
| 884 | ep_ctx->tx_info = 0; | 929 | ep_ctx->tx_info = 0; |
| 885 | } | 930 | } |
| 886 | } | 931 | } |
| @@ -903,6 +948,8 @@ int xhci_check_bandwidth(struct usb_hcd *hcd, struct usb_device *udev) | |||
| 903 | unsigned long flags; | 948 | unsigned long flags; |
| 904 | struct xhci_hcd *xhci; | 949 | struct xhci_hcd *xhci; |
| 905 | struct xhci_virt_device *virt_dev; | 950 | struct xhci_virt_device *virt_dev; |
| 951 | struct xhci_input_control_ctx *ctrl_ctx; | ||
| 952 | struct xhci_slot_ctx *slot_ctx; | ||
| 906 | 953 | ||
| 907 | ret = xhci_check_args(hcd, udev, NULL, 0, __func__); | 954 | ret = xhci_check_args(hcd, udev, NULL, 0, __func__); |
| 908 | if (ret <= 0) | 955 | if (ret <= 0) |
| @@ -918,16 +965,18 @@ int xhci_check_bandwidth(struct usb_hcd *hcd, struct usb_device *udev) | |||
| 918 | virt_dev = xhci->devs[udev->slot_id]; | 965 | virt_dev = xhci->devs[udev->slot_id]; |
| 919 | 966 | ||
| 920 | /* See section 4.6.6 - A0 = 1; A1 = D0 = D1 = 0 */ | 967 | /* See section 4.6.6 - A0 = 1; A1 = D0 = D1 = 0 */ |
| 921 | virt_dev->in_ctx->add_flags |= SLOT_FLAG; | 968 | ctrl_ctx = xhci_get_input_control_ctx(xhci, virt_dev->in_ctx); |
| 922 | virt_dev->in_ctx->add_flags &= ~EP0_FLAG; | 969 | ctrl_ctx->add_flags |= SLOT_FLAG; |
| 923 | virt_dev->in_ctx->drop_flags &= ~SLOT_FLAG; | 970 | ctrl_ctx->add_flags &= ~EP0_FLAG; |
| 924 | virt_dev->in_ctx->drop_flags &= ~EP0_FLAG; | 971 | ctrl_ctx->drop_flags &= ~SLOT_FLAG; |
| 972 | ctrl_ctx->drop_flags &= ~EP0_FLAG; | ||
| 925 | xhci_dbg(xhci, "New Input Control Context:\n"); | 973 | xhci_dbg(xhci, "New Input Control Context:\n"); |
| 926 | xhci_dbg_ctx(xhci, virt_dev->in_ctx, virt_dev->in_ctx_dma, | 974 | slot_ctx = xhci_get_slot_ctx(xhci, virt_dev->in_ctx); |
| 927 | LAST_CTX_TO_EP_NUM(virt_dev->in_ctx->slot.dev_info)); | 975 | xhci_dbg_ctx(xhci, virt_dev->in_ctx, |
| 976 | LAST_CTX_TO_EP_NUM(slot_ctx->dev_info)); | ||
| 928 | 977 | ||
| 929 | spin_lock_irqsave(&xhci->lock, flags); | 978 | spin_lock_irqsave(&xhci->lock, flags); |
| 930 | ret = xhci_queue_configure_endpoint(xhci, virt_dev->in_ctx_dma, | 979 | ret = xhci_queue_configure_endpoint(xhci, virt_dev->in_ctx->dma, |
| 931 | udev->slot_id); | 980 | udev->slot_id); |
| 932 | if (ret < 0) { | 981 | if (ret < 0) { |
| 933 | spin_unlock_irqrestore(&xhci->lock, flags); | 982 | spin_unlock_irqrestore(&xhci->lock, flags); |
| @@ -982,10 +1031,10 @@ int xhci_check_bandwidth(struct usb_hcd *hcd, struct usb_device *udev) | |||
| 982 | } | 1031 | } |
| 983 | 1032 | ||
| 984 | xhci_dbg(xhci, "Output context after successful config ep cmd:\n"); | 1033 | xhci_dbg(xhci, "Output context after successful config ep cmd:\n"); |
| 985 | xhci_dbg_ctx(xhci, virt_dev->out_ctx, virt_dev->out_ctx_dma, | 1034 | xhci_dbg_ctx(xhci, virt_dev->out_ctx, |
| 986 | LAST_CTX_TO_EP_NUM(virt_dev->in_ctx->slot.dev_info)); | 1035 | LAST_CTX_TO_EP_NUM(slot_ctx->dev_info)); |
| 987 | 1036 | ||
| 988 | xhci_zero_in_ctx(virt_dev); | 1037 | xhci_zero_in_ctx(xhci, virt_dev); |
| 989 | /* Free any old rings */ | 1038 | /* Free any old rings */ |
| 990 | for (i = 1; i < 31; ++i) { | 1039 | for (i = 1; i < 31; ++i) { |
| 991 | if (virt_dev->new_ep_rings[i]) { | 1040 | if (virt_dev->new_ep_rings[i]) { |
| @@ -1023,7 +1072,67 @@ void xhci_reset_bandwidth(struct usb_hcd *hcd, struct usb_device *udev) | |||
| 1023 | virt_dev->new_ep_rings[i] = NULL; | 1072 | virt_dev->new_ep_rings[i] = NULL; |
| 1024 | } | 1073 | } |
| 1025 | } | 1074 | } |
| 1026 | xhci_zero_in_ctx(virt_dev); | 1075 | xhci_zero_in_ctx(xhci, virt_dev); |
| 1076 | } | ||
| 1077 | |||
| 1078 | /* Deal with stalled endpoints. The core should have sent the control message | ||
| 1079 | * to clear the halt condition. However, we need to make the xHCI hardware | ||
| 1080 | * reset its sequence number, since a device will expect a sequence number of | ||
| 1081 | * zero after the halt condition is cleared. | ||
| 1082 | * Context: in_interrupt | ||
| 1083 | */ | ||
| 1084 | void xhci_endpoint_reset(struct usb_hcd *hcd, | ||
| 1085 | struct usb_host_endpoint *ep) | ||
| 1086 | { | ||
| 1087 | struct xhci_hcd *xhci; | ||
| 1088 | struct usb_device *udev; | ||
| 1089 | unsigned int ep_index; | ||
| 1090 | unsigned long flags; | ||
| 1091 | int ret; | ||
| 1092 | struct xhci_dequeue_state deq_state; | ||
| 1093 | struct xhci_ring *ep_ring; | ||
| 1094 | |||
| 1095 | xhci = hcd_to_xhci(hcd); | ||
| 1096 | udev = (struct usb_device *) ep->hcpriv; | ||
| 1097 | /* Called with a root hub endpoint (or an endpoint that wasn't added | ||
| 1098 | * with xhci_add_endpoint() | ||
| 1099 | */ | ||
| 1100 | if (!ep->hcpriv) | ||
| 1101 | return; | ||
| 1102 | ep_index = xhci_get_endpoint_index(&ep->desc); | ||
| 1103 | ep_ring = xhci->devs[udev->slot_id]->ep_rings[ep_index]; | ||
| 1104 | if (!ep_ring->stopped_td) { | ||
| 1105 | xhci_dbg(xhci, "Endpoint 0x%x not halted, refusing to reset.\n", | ||
| 1106 | ep->desc.bEndpointAddress); | ||
| 1107 | return; | ||
| 1108 | } | ||
| 1109 | |||
| 1110 | xhci_dbg(xhci, "Queueing reset endpoint command\n"); | ||
| 1111 | spin_lock_irqsave(&xhci->lock, flags); | ||
| 1112 | ret = xhci_queue_reset_ep(xhci, udev->slot_id, ep_index); | ||
| 1113 | /* | ||
| 1114 | * Can't change the ring dequeue pointer until it's transitioned to the | ||
| 1115 | * stopped state, which is only upon a successful reset endpoint | ||
| 1116 | * command. Better hope that last command worked! | ||
| 1117 | */ | ||
| 1118 | if (!ret) { | ||
| 1119 | xhci_dbg(xhci, "Cleaning up stalled endpoint ring\n"); | ||
| 1120 | /* We need to move the HW's dequeue pointer past this TD, | ||
| 1121 | * or it will attempt to resend it on the next doorbell ring. | ||
| 1122 | */ | ||
| 1123 | xhci_find_new_dequeue_state(xhci, udev->slot_id, | ||
| 1124 | ep_index, ep_ring->stopped_td, &deq_state); | ||
| 1125 | xhci_dbg(xhci, "Queueing new dequeue state\n"); | ||
| 1126 | xhci_queue_new_dequeue_state(xhci, ep_ring, | ||
| 1127 | udev->slot_id, | ||
| 1128 | ep_index, &deq_state); | ||
| 1129 | kfree(ep_ring->stopped_td); | ||
| 1130 | xhci_ring_cmd_db(xhci); | ||
| 1131 | } | ||
| 1132 | spin_unlock_irqrestore(&xhci->lock, flags); | ||
| 1133 | |||
| 1134 | if (ret) | ||
| 1135 | xhci_warn(xhci, "FIXME allocate a new ring segment\n"); | ||
| 1027 | } | 1136 | } |
| 1028 | 1137 | ||
| 1029 | /* | 1138 | /* |
| @@ -1120,7 +1229,9 @@ int xhci_address_device(struct usb_hcd *hcd, struct usb_device *udev) | |||
| 1120 | struct xhci_virt_device *virt_dev; | 1229 | struct xhci_virt_device *virt_dev; |
| 1121 | int ret = 0; | 1230 | int ret = 0; |
| 1122 | struct xhci_hcd *xhci = hcd_to_xhci(hcd); | 1231 | struct xhci_hcd *xhci = hcd_to_xhci(hcd); |
| 1123 | u32 temp; | 1232 | struct xhci_slot_ctx *slot_ctx; |
| 1233 | struct xhci_input_control_ctx *ctrl_ctx; | ||
| 1234 | u64 temp_64; | ||
| 1124 | 1235 | ||
| 1125 | if (!udev->slot_id) { | 1236 | if (!udev->slot_id) { |
| 1126 | xhci_dbg(xhci, "Bad Slot ID %d\n", udev->slot_id); | 1237 | xhci_dbg(xhci, "Bad Slot ID %d\n", udev->slot_id); |
| @@ -1133,10 +1244,12 @@ int xhci_address_device(struct usb_hcd *hcd, struct usb_device *udev) | |||
| 1133 | if (!udev->config) | 1244 | if (!udev->config) |
| 1134 | xhci_setup_addressable_virt_dev(xhci, udev); | 1245 | xhci_setup_addressable_virt_dev(xhci, udev); |
| 1135 | /* Otherwise, assume the core has the device configured how it wants */ | 1246 | /* Otherwise, assume the core has the device configured how it wants */ |
| 1247 | xhci_dbg(xhci, "Slot ID %d Input Context:\n", udev->slot_id); | ||
| 1248 | xhci_dbg_ctx(xhci, virt_dev->in_ctx, 2); | ||
| 1136 | 1249 | ||
| 1137 | spin_lock_irqsave(&xhci->lock, flags); | 1250 | spin_lock_irqsave(&xhci->lock, flags); |
| 1138 | ret = xhci_queue_address_device(xhci, virt_dev->in_ctx_dma, | 1251 | ret = xhci_queue_address_device(xhci, virt_dev->in_ctx->dma, |
| 1139 | udev->slot_id); | 1252 | udev->slot_id); |
| 1140 | if (ret) { | 1253 | if (ret) { |
| 1141 | spin_unlock_irqrestore(&xhci->lock, flags); | 1254 | spin_unlock_irqrestore(&xhci->lock, flags); |
| 1142 | xhci_dbg(xhci, "FIXME: allocate a command ring segment\n"); | 1255 | xhci_dbg(xhci, "FIXME: allocate a command ring segment\n"); |
| @@ -1176,41 +1289,37 @@ int xhci_address_device(struct usb_hcd *hcd, struct usb_device *udev) | |||
| 1176 | default: | 1289 | default: |
| 1177 | xhci_err(xhci, "ERROR: unexpected command completion " | 1290 | xhci_err(xhci, "ERROR: unexpected command completion " |
| 1178 | "code 0x%x.\n", virt_dev->cmd_status); | 1291 | "code 0x%x.\n", virt_dev->cmd_status); |
| 1292 | xhci_dbg(xhci, "Slot ID %d Output Context:\n", udev->slot_id); | ||
| 1293 | xhci_dbg_ctx(xhci, virt_dev->out_ctx, 2); | ||
| 1179 | ret = -EINVAL; | 1294 | ret = -EINVAL; |
| 1180 | break; | 1295 | break; |
| 1181 | } | 1296 | } |
| 1182 | if (ret) { | 1297 | if (ret) { |
| 1183 | return ret; | 1298 | return ret; |
| 1184 | } | 1299 | } |
| 1185 | temp = xhci_readl(xhci, &xhci->op_regs->dcbaa_ptr[0]); | 1300 | temp_64 = xhci_read_64(xhci, &xhci->op_regs->dcbaa_ptr); |
| 1186 | xhci_dbg(xhci, "Op regs DCBAA ptr[0] = %#08x\n", temp); | 1301 | xhci_dbg(xhci, "Op regs DCBAA ptr = %#016llx\n", temp_64); |
| 1187 | temp = xhci_readl(xhci, &xhci->op_regs->dcbaa_ptr[1]); | 1302 | xhci_dbg(xhci, "Slot ID %d dcbaa entry @%p = %#016llx\n", |
| 1188 | xhci_dbg(xhci, "Op regs DCBAA ptr[1] = %#08x\n", temp); | ||
| 1189 | xhci_dbg(xhci, "Slot ID %d dcbaa entry[0] @%p = %#08x\n", | ||
| 1190 | udev->slot_id, | ||
| 1191 | &xhci->dcbaa->dev_context_ptrs[2*udev->slot_id], | ||
| 1192 | xhci->dcbaa->dev_context_ptrs[2*udev->slot_id]); | ||
| 1193 | xhci_dbg(xhci, "Slot ID %d dcbaa entry[1] @%p = %#08x\n", | ||
| 1194 | udev->slot_id, | 1303 | udev->slot_id, |
| 1195 | &xhci->dcbaa->dev_context_ptrs[2*udev->slot_id+1], | 1304 | &xhci->dcbaa->dev_context_ptrs[udev->slot_id], |
| 1196 | xhci->dcbaa->dev_context_ptrs[2*udev->slot_id+1]); | 1305 | (unsigned long long) |
| 1306 | xhci->dcbaa->dev_context_ptrs[udev->slot_id]); | ||
| 1197 | xhci_dbg(xhci, "Output Context DMA address = %#08llx\n", | 1307 | xhci_dbg(xhci, "Output Context DMA address = %#08llx\n", |
| 1198 | (unsigned long long)virt_dev->out_ctx_dma); | 1308 | (unsigned long long)virt_dev->out_ctx->dma); |
| 1199 | xhci_dbg(xhci, "Slot ID %d Input Context:\n", udev->slot_id); | 1309 | xhci_dbg(xhci, "Slot ID %d Input Context:\n", udev->slot_id); |
| 1200 | xhci_dbg_ctx(xhci, virt_dev->in_ctx, virt_dev->in_ctx_dma, 2); | 1310 | xhci_dbg_ctx(xhci, virt_dev->in_ctx, 2); |
| 1201 | xhci_dbg(xhci, "Slot ID %d Output Context:\n", udev->slot_id); | 1311 | xhci_dbg(xhci, "Slot ID %d Output Context:\n", udev->slot_id); |
| 1202 | xhci_dbg_ctx(xhci, virt_dev->out_ctx, virt_dev->out_ctx_dma, 2); | 1312 | xhci_dbg_ctx(xhci, virt_dev->out_ctx, 2); |
| 1203 | /* | 1313 | /* |
| 1204 | * USB core uses address 1 for the roothubs, so we add one to the | 1314 | * USB core uses address 1 for the roothubs, so we add one to the |
| 1205 | * address given back to us by the HC. | 1315 | * address given back to us by the HC. |
| 1206 | */ | 1316 | */ |
| 1207 | udev->devnum = (virt_dev->out_ctx->slot.dev_state & DEV_ADDR_MASK) + 1; | 1317 | slot_ctx = xhci_get_slot_ctx(xhci, virt_dev->out_ctx); |
| 1318 | udev->devnum = (slot_ctx->dev_state & DEV_ADDR_MASK) + 1; | ||
| 1208 | /* Zero the input context control for later use */ | 1319 | /* Zero the input context control for later use */ |
| 1209 | virt_dev->in_ctx->add_flags = 0; | 1320 | ctrl_ctx = xhci_get_input_control_ctx(xhci, virt_dev->in_ctx); |
| 1210 | virt_dev->in_ctx->drop_flags = 0; | 1321 | ctrl_ctx->add_flags = 0; |
| 1211 | /* Mirror flags in the output context for future ep enable/disable */ | 1322 | ctrl_ctx->drop_flags = 0; |
| 1212 | virt_dev->out_ctx->add_flags = SLOT_FLAG | EP0_FLAG; | ||
| 1213 | virt_dev->out_ctx->drop_flags = 0; | ||
| 1214 | 1323 | ||
| 1215 | xhci_dbg(xhci, "Device address = %d\n", udev->devnum); | 1324 | xhci_dbg(xhci, "Device address = %d\n", udev->devnum); |
| 1216 | /* XXX Meh, not sure if anyone else but choose_address uses this. */ | 1325 | /* XXX Meh, not sure if anyone else but choose_address uses this. */ |
| @@ -1252,7 +1361,6 @@ static int __init xhci_hcd_init(void) | |||
| 1252 | /* xhci_device_control has eight fields, and also | 1361 | /* xhci_device_control has eight fields, and also |
| 1253 | * embeds one xhci_slot_ctx and 31 xhci_ep_ctx | 1362 | * embeds one xhci_slot_ctx and 31 xhci_ep_ctx |
| 1254 | */ | 1363 | */ |
| 1255 | BUILD_BUG_ON(sizeof(struct xhci_device_control) != (8+8+8*31)*32/8); | ||
| 1256 | BUILD_BUG_ON(sizeof(struct xhci_stream_ctx) != 4*32/8); | 1364 | BUILD_BUG_ON(sizeof(struct xhci_stream_ctx) != 4*32/8); |
| 1257 | BUILD_BUG_ON(sizeof(union xhci_trb) != 4*32/8); | 1365 | BUILD_BUG_ON(sizeof(union xhci_trb) != 4*32/8); |
| 1258 | BUILD_BUG_ON(sizeof(struct xhci_erst_entry) != 4*32/8); | 1366 | BUILD_BUG_ON(sizeof(struct xhci_erst_entry) != 4*32/8); |
diff --git a/drivers/usb/host/xhci-mem.c b/drivers/usb/host/xhci-mem.c index c8a72de1c508..e6b9a1c6002d 100644 --- a/drivers/usb/host/xhci-mem.c +++ b/drivers/usb/host/xhci-mem.c | |||
| @@ -88,7 +88,7 @@ static void xhci_link_segments(struct xhci_hcd *xhci, struct xhci_segment *prev, | |||
| 88 | return; | 88 | return; |
| 89 | prev->next = next; | 89 | prev->next = next; |
| 90 | if (link_trbs) { | 90 | if (link_trbs) { |
| 91 | prev->trbs[TRBS_PER_SEGMENT-1].link.segment_ptr[0] = next->dma; | 91 | prev->trbs[TRBS_PER_SEGMENT-1].link.segment_ptr = next->dma; |
| 92 | 92 | ||
| 93 | /* Set the last TRB in the segment to have a TRB type ID of Link TRB */ | 93 | /* Set the last TRB in the segment to have a TRB type ID of Link TRB */ |
| 94 | val = prev->trbs[TRBS_PER_SEGMENT-1].link.control; | 94 | val = prev->trbs[TRBS_PER_SEGMENT-1].link.control; |
| @@ -189,6 +189,63 @@ fail: | |||
| 189 | return 0; | 189 | return 0; |
| 190 | } | 190 | } |
| 191 | 191 | ||
| 192 | #define CTX_SIZE(_hcc) (HCC_64BYTE_CONTEXT(_hcc) ? 64 : 32) | ||
| 193 | |||
| 194 | struct xhci_container_ctx *xhci_alloc_container_ctx(struct xhci_hcd *xhci, | ||
| 195 | int type, gfp_t flags) | ||
| 196 | { | ||
| 197 | struct xhci_container_ctx *ctx = kzalloc(sizeof(*ctx), flags); | ||
| 198 | if (!ctx) | ||
| 199 | return NULL; | ||
| 200 | |||
| 201 | BUG_ON((type != XHCI_CTX_TYPE_DEVICE) && (type != XHCI_CTX_TYPE_INPUT)); | ||
| 202 | ctx->type = type; | ||
| 203 | ctx->size = HCC_64BYTE_CONTEXT(xhci->hcc_params) ? 2048 : 1024; | ||
| 204 | if (type == XHCI_CTX_TYPE_INPUT) | ||
| 205 | ctx->size += CTX_SIZE(xhci->hcc_params); | ||
| 206 | |||
| 207 | ctx->bytes = dma_pool_alloc(xhci->device_pool, flags, &ctx->dma); | ||
| 208 | memset(ctx->bytes, 0, ctx->size); | ||
| 209 | return ctx; | ||
| 210 | } | ||
| 211 | |||
| 212 | void xhci_free_container_ctx(struct xhci_hcd *xhci, | ||
| 213 | struct xhci_container_ctx *ctx) | ||
| 214 | { | ||
| 215 | dma_pool_free(xhci->device_pool, ctx->bytes, ctx->dma); | ||
| 216 | kfree(ctx); | ||
| 217 | } | ||
| 218 | |||
| 219 | struct xhci_input_control_ctx *xhci_get_input_control_ctx(struct xhci_hcd *xhci, | ||
| 220 | struct xhci_container_ctx *ctx) | ||
| 221 | { | ||
| 222 | BUG_ON(ctx->type != XHCI_CTX_TYPE_INPUT); | ||
| 223 | return (struct xhci_input_control_ctx *)ctx->bytes; | ||
| 224 | } | ||
| 225 | |||
| 226 | struct xhci_slot_ctx *xhci_get_slot_ctx(struct xhci_hcd *xhci, | ||
| 227 | struct xhci_container_ctx *ctx) | ||
| 228 | { | ||
| 229 | if (ctx->type == XHCI_CTX_TYPE_DEVICE) | ||
| 230 | return (struct xhci_slot_ctx *)ctx->bytes; | ||
| 231 | |||
| 232 | return (struct xhci_slot_ctx *) | ||
| 233 | (ctx->bytes + CTX_SIZE(xhci->hcc_params)); | ||
| 234 | } | ||
| 235 | |||
| 236 | struct xhci_ep_ctx *xhci_get_ep_ctx(struct xhci_hcd *xhci, | ||
| 237 | struct xhci_container_ctx *ctx, | ||
| 238 | unsigned int ep_index) | ||
| 239 | { | ||
| 240 | /* increment ep index by offset of start of ep ctx array */ | ||
| 241 | ep_index++; | ||
| 242 | if (ctx->type == XHCI_CTX_TYPE_INPUT) | ||
| 243 | ep_index++; | ||
| 244 | |||
| 245 | return (struct xhci_ep_ctx *) | ||
| 246 | (ctx->bytes + (ep_index * CTX_SIZE(xhci->hcc_params))); | ||
| 247 | } | ||
| 248 | |||
| 192 | /* All the xhci_tds in the ring's TD list should be freed at this point */ | 249 | /* All the xhci_tds in the ring's TD list should be freed at this point */ |
| 193 | void xhci_free_virt_device(struct xhci_hcd *xhci, int slot_id) | 250 | void xhci_free_virt_device(struct xhci_hcd *xhci, int slot_id) |
| 194 | { | 251 | { |
| @@ -200,8 +257,7 @@ void xhci_free_virt_device(struct xhci_hcd *xhci, int slot_id) | |||
| 200 | return; | 257 | return; |
| 201 | 258 | ||
| 202 | dev = xhci->devs[slot_id]; | 259 | dev = xhci->devs[slot_id]; |
| 203 | xhci->dcbaa->dev_context_ptrs[2*slot_id] = 0; | 260 | xhci->dcbaa->dev_context_ptrs[slot_id] = 0; |
| 204 | xhci->dcbaa->dev_context_ptrs[2*slot_id + 1] = 0; | ||
| 205 | if (!dev) | 261 | if (!dev) |
| 206 | return; | 262 | return; |
| 207 | 263 | ||
| @@ -210,11 +266,10 @@ void xhci_free_virt_device(struct xhci_hcd *xhci, int slot_id) | |||
| 210 | xhci_ring_free(xhci, dev->ep_rings[i]); | 266 | xhci_ring_free(xhci, dev->ep_rings[i]); |
| 211 | 267 | ||
| 212 | if (dev->in_ctx) | 268 | if (dev->in_ctx) |
| 213 | dma_pool_free(xhci->device_pool, | 269 | xhci_free_container_ctx(xhci, dev->in_ctx); |
| 214 | dev->in_ctx, dev->in_ctx_dma); | ||
| 215 | if (dev->out_ctx) | 270 | if (dev->out_ctx) |
| 216 | dma_pool_free(xhci->device_pool, | 271 | xhci_free_container_ctx(xhci, dev->out_ctx); |
| 217 | dev->out_ctx, dev->out_ctx_dma); | 272 | |
| 218 | kfree(xhci->devs[slot_id]); | 273 | kfree(xhci->devs[slot_id]); |
| 219 | xhci->devs[slot_id] = 0; | 274 | xhci->devs[slot_id] = 0; |
| 220 | } | 275 | } |
| @@ -222,7 +277,6 @@ void xhci_free_virt_device(struct xhci_hcd *xhci, int slot_id) | |||
| 222 | int xhci_alloc_virt_device(struct xhci_hcd *xhci, int slot_id, | 277 | int xhci_alloc_virt_device(struct xhci_hcd *xhci, int slot_id, |
| 223 | struct usb_device *udev, gfp_t flags) | 278 | struct usb_device *udev, gfp_t flags) |
| 224 | { | 279 | { |
| 225 | dma_addr_t dma; | ||
| 226 | struct xhci_virt_device *dev; | 280 | struct xhci_virt_device *dev; |
| 227 | 281 | ||
| 228 | /* Slot ID 0 is reserved */ | 282 | /* Slot ID 0 is reserved */ |
| @@ -236,23 +290,21 @@ int xhci_alloc_virt_device(struct xhci_hcd *xhci, int slot_id, | |||
| 236 | return 0; | 290 | return 0; |
| 237 | dev = xhci->devs[slot_id]; | 291 | dev = xhci->devs[slot_id]; |
| 238 | 292 | ||
| 239 | /* Allocate the (output) device context that will be used in the HC */ | 293 | /* Allocate the (output) device context that will be used in the HC. */ |
| 240 | dev->out_ctx = dma_pool_alloc(xhci->device_pool, flags, &dma); | 294 | dev->out_ctx = xhci_alloc_container_ctx(xhci, XHCI_CTX_TYPE_DEVICE, flags); |
| 241 | if (!dev->out_ctx) | 295 | if (!dev->out_ctx) |
| 242 | goto fail; | 296 | goto fail; |
| 243 | dev->out_ctx_dma = dma; | 297 | |
| 244 | xhci_dbg(xhci, "Slot %d output ctx = 0x%llx (dma)\n", slot_id, | 298 | xhci_dbg(xhci, "Slot %d output ctx = 0x%llx (dma)\n", slot_id, |
| 245 | (unsigned long long)dma); | 299 | (unsigned long long)dev->out_ctx->dma); |
| 246 | memset(dev->out_ctx, 0, sizeof(*dev->out_ctx)); | ||
| 247 | 300 | ||
| 248 | /* Allocate the (input) device context for address device command */ | 301 | /* Allocate the (input) device context for address device command */ |
| 249 | dev->in_ctx = dma_pool_alloc(xhci->device_pool, flags, &dma); | 302 | dev->in_ctx = xhci_alloc_container_ctx(xhci, XHCI_CTX_TYPE_INPUT, flags); |
| 250 | if (!dev->in_ctx) | 303 | if (!dev->in_ctx) |
| 251 | goto fail; | 304 | goto fail; |
| 252 | dev->in_ctx_dma = dma; | 305 | |
| 253 | xhci_dbg(xhci, "Slot %d input ctx = 0x%llx (dma)\n", slot_id, | 306 | xhci_dbg(xhci, "Slot %d input ctx = 0x%llx (dma)\n", slot_id, |
| 254 | (unsigned long long)dma); | 307 | (unsigned long long)dev->in_ctx->dma); |
| 255 | memset(dev->in_ctx, 0, sizeof(*dev->in_ctx)); | ||
| 256 | 308 | ||
| 257 | /* Allocate endpoint 0 ring */ | 309 | /* Allocate endpoint 0 ring */ |
| 258 | dev->ep_rings[0] = xhci_ring_alloc(xhci, 1, true, flags); | 310 | dev->ep_rings[0] = xhci_ring_alloc(xhci, 1, true, flags); |
| @@ -261,17 +313,12 @@ int xhci_alloc_virt_device(struct xhci_hcd *xhci, int slot_id, | |||
| 261 | 313 | ||
| 262 | init_completion(&dev->cmd_completion); | 314 | init_completion(&dev->cmd_completion); |
| 263 | 315 | ||
| 264 | /* | 316 | /* Point to output device context in dcbaa. */ |
| 265 | * Point to output device context in dcbaa; skip the output control | 317 | xhci->dcbaa->dev_context_ptrs[slot_id] = dev->out_ctx->dma; |
| 266 | * context, which is eight 32 bit fields (or 32 bytes long) | ||
| 267 | */ | ||
| 268 | xhci->dcbaa->dev_context_ptrs[2*slot_id] = | ||
| 269 | (u32) dev->out_ctx_dma + (32); | ||
| 270 | xhci_dbg(xhci, "Set slot id %d dcbaa entry %p to 0x%llx\n", | 318 | xhci_dbg(xhci, "Set slot id %d dcbaa entry %p to 0x%llx\n", |
| 271 | slot_id, | 319 | slot_id, |
| 272 | &xhci->dcbaa->dev_context_ptrs[2*slot_id], | 320 | &xhci->dcbaa->dev_context_ptrs[slot_id], |
| 273 | (unsigned long long)dev->out_ctx_dma); | 321 | (unsigned long long) xhci->dcbaa->dev_context_ptrs[slot_id]); |
| 274 | xhci->dcbaa->dev_context_ptrs[2*slot_id + 1] = 0; | ||
| 275 | 322 | ||
| 276 | return 1; | 323 | return 1; |
| 277 | fail: | 324 | fail: |
| @@ -285,6 +332,8 @@ int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *ud | |||
| 285 | struct xhci_virt_device *dev; | 332 | struct xhci_virt_device *dev; |
| 286 | struct xhci_ep_ctx *ep0_ctx; | 333 | struct xhci_ep_ctx *ep0_ctx; |
| 287 | struct usb_device *top_dev; | 334 | struct usb_device *top_dev; |
| 335 | struct xhci_slot_ctx *slot_ctx; | ||
| 336 | struct xhci_input_control_ctx *ctrl_ctx; | ||
| 288 | 337 | ||
| 289 | dev = xhci->devs[udev->slot_id]; | 338 | dev = xhci->devs[udev->slot_id]; |
| 290 | /* Slot ID 0 is reserved */ | 339 | /* Slot ID 0 is reserved */ |
| @@ -293,27 +342,29 @@ int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *ud | |||
| 293 | udev->slot_id); | 342 | udev->slot_id); |
| 294 | return -EINVAL; | 343 | return -EINVAL; |
| 295 | } | 344 | } |
| 296 | ep0_ctx = &dev->in_ctx->ep[0]; | 345 | ep0_ctx = xhci_get_ep_ctx(xhci, dev->in_ctx, 0); |
| 346 | ctrl_ctx = xhci_get_input_control_ctx(xhci, dev->in_ctx); | ||
| 347 | slot_ctx = xhci_get_slot_ctx(xhci, dev->in_ctx); | ||
| 297 | 348 | ||
| 298 | /* 2) New slot context and endpoint 0 context are valid*/ | 349 | /* 2) New slot context and endpoint 0 context are valid*/ |
| 299 | dev->in_ctx->add_flags = SLOT_FLAG | EP0_FLAG; | 350 | ctrl_ctx->add_flags = SLOT_FLAG | EP0_FLAG; |
| 300 | 351 | ||
| 301 | /* 3) Only the control endpoint is valid - one endpoint context */ | 352 | /* 3) Only the control endpoint is valid - one endpoint context */ |
| 302 | dev->in_ctx->slot.dev_info |= LAST_CTX(1); | 353 | slot_ctx->dev_info |= LAST_CTX(1); |
| 303 | 354 | ||
| 304 | switch (udev->speed) { | 355 | switch (udev->speed) { |
| 305 | case USB_SPEED_SUPER: | 356 | case USB_SPEED_SUPER: |
| 306 | dev->in_ctx->slot.dev_info |= (u32) udev->route; | 357 | slot_ctx->dev_info |= (u32) udev->route; |
| 307 | dev->in_ctx->slot.dev_info |= (u32) SLOT_SPEED_SS; | 358 | slot_ctx->dev_info |= (u32) SLOT_SPEED_SS; |
| 308 | break; | 359 | break; |
| 309 | case USB_SPEED_HIGH: | 360 | case USB_SPEED_HIGH: |
| 310 | dev->in_ctx->slot.dev_info |= (u32) SLOT_SPEED_HS; | 361 | slot_ctx->dev_info |= (u32) SLOT_SPEED_HS; |
| 311 | break; | 362 | break; |
| 312 | case USB_SPEED_FULL: | 363 | case USB_SPEED_FULL: |
| 313 | dev->in_ctx->slot.dev_info |= (u32) SLOT_SPEED_FS; | 364 | slot_ctx->dev_info |= (u32) SLOT_SPEED_FS; |
| 314 | break; | 365 | break; |
| 315 | case USB_SPEED_LOW: | 366 | case USB_SPEED_LOW: |
| 316 | dev->in_ctx->slot.dev_info |= (u32) SLOT_SPEED_LS; | 367 | slot_ctx->dev_info |= (u32) SLOT_SPEED_LS; |
| 317 | break; | 368 | break; |
| 318 | case USB_SPEED_VARIABLE: | 369 | case USB_SPEED_VARIABLE: |
| 319 | xhci_dbg(xhci, "FIXME xHCI doesn't support wireless speeds\n"); | 370 | xhci_dbg(xhci, "FIXME xHCI doesn't support wireless speeds\n"); |
| @@ -327,7 +378,7 @@ int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *ud | |||
| 327 | for (top_dev = udev; top_dev->parent && top_dev->parent->parent; | 378 | for (top_dev = udev; top_dev->parent && top_dev->parent->parent; |
| 328 | top_dev = top_dev->parent) | 379 | top_dev = top_dev->parent) |
| 329 | /* Found device below root hub */; | 380 | /* Found device below root hub */; |
| 330 | dev->in_ctx->slot.dev_info2 |= (u32) ROOT_HUB_PORT(top_dev->portnum); | 381 | slot_ctx->dev_info2 |= (u32) ROOT_HUB_PORT(top_dev->portnum); |
| 331 | xhci_dbg(xhci, "Set root hub portnum to %d\n", top_dev->portnum); | 382 | xhci_dbg(xhci, "Set root hub portnum to %d\n", top_dev->portnum); |
| 332 | 383 | ||
| 333 | /* Is this a LS/FS device under a HS hub? */ | 384 | /* Is this a LS/FS device under a HS hub? */ |
| @@ -337,8 +388,8 @@ int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *ud | |||
| 337 | */ | 388 | */ |
| 338 | if ((udev->speed == USB_SPEED_LOW || udev->speed == USB_SPEED_FULL) && | 389 | if ((udev->speed == USB_SPEED_LOW || udev->speed == USB_SPEED_FULL) && |
| 339 | udev->tt) { | 390 | udev->tt) { |
| 340 | dev->in_ctx->slot.tt_info = udev->tt->hub->slot_id; | 391 | slot_ctx->tt_info = udev->tt->hub->slot_id; |
| 341 | dev->in_ctx->slot.tt_info |= udev->ttport << 8; | 392 | slot_ctx->tt_info |= udev->ttport << 8; |
| 342 | } | 393 | } |
| 343 | xhci_dbg(xhci, "udev->tt = %p\n", udev->tt); | 394 | xhci_dbg(xhci, "udev->tt = %p\n", udev->tt); |
| 344 | xhci_dbg(xhci, "udev->ttport = 0x%x\n", udev->ttport); | 395 | xhci_dbg(xhci, "udev->ttport = 0x%x\n", udev->ttport); |
| @@ -360,10 +411,9 @@ int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *ud | |||
| 360 | ep0_ctx->ep_info2 |= MAX_BURST(0); | 411 | ep0_ctx->ep_info2 |= MAX_BURST(0); |
| 361 | ep0_ctx->ep_info2 |= ERROR_COUNT(3); | 412 | ep0_ctx->ep_info2 |= ERROR_COUNT(3); |
| 362 | 413 | ||
| 363 | ep0_ctx->deq[0] = | 414 | ep0_ctx->deq = |
| 364 | dev->ep_rings[0]->first_seg->dma; | 415 | dev->ep_rings[0]->first_seg->dma; |
| 365 | ep0_ctx->deq[0] |= dev->ep_rings[0]->cycle_state; | 416 | ep0_ctx->deq |= dev->ep_rings[0]->cycle_state; |
| 366 | ep0_ctx->deq[1] = 0; | ||
| 367 | 417 | ||
| 368 | /* Steps 7 and 8 were done in xhci_alloc_virt_device() */ | 418 | /* Steps 7 and 8 were done in xhci_alloc_virt_device() */ |
| 369 | 419 | ||
| @@ -470,25 +520,26 @@ int xhci_endpoint_init(struct xhci_hcd *xhci, | |||
| 470 | unsigned int max_burst; | 520 | unsigned int max_burst; |
| 471 | 521 | ||
| 472 | ep_index = xhci_get_endpoint_index(&ep->desc); | 522 | ep_index = xhci_get_endpoint_index(&ep->desc); |
| 473 | ep_ctx = &virt_dev->in_ctx->ep[ep_index]; | 523 | ep_ctx = xhci_get_ep_ctx(xhci, virt_dev->in_ctx, ep_index); |
| 474 | 524 | ||
| 475 | /* Set up the endpoint ring */ | 525 | /* Set up the endpoint ring */ |
| 476 | virt_dev->new_ep_rings[ep_index] = xhci_ring_alloc(xhci, 1, true, mem_flags); | 526 | virt_dev->new_ep_rings[ep_index] = xhci_ring_alloc(xhci, 1, true, mem_flags); |
| 477 | if (!virt_dev->new_ep_rings[ep_index]) | 527 | if (!virt_dev->new_ep_rings[ep_index]) |
| 478 | return -ENOMEM; | 528 | return -ENOMEM; |
| 479 | ep_ring = virt_dev->new_ep_rings[ep_index]; | 529 | ep_ring = virt_dev->new_ep_rings[ep_index]; |
| 480 | ep_ctx->deq[0] = ep_ring->first_seg->dma | ep_ring->cycle_state; | 530 | ep_ctx->deq = ep_ring->first_seg->dma | ep_ring->cycle_state; |
| 481 | ep_ctx->deq[1] = 0; | ||
| 482 | 531 | ||
| 483 | ep_ctx->ep_info = xhci_get_endpoint_interval(udev, ep); | 532 | ep_ctx->ep_info = xhci_get_endpoint_interval(udev, ep); |
| 484 | 533 | ||
| 485 | /* FIXME dig Mult and streams info out of ep companion desc */ | 534 | /* FIXME dig Mult and streams info out of ep companion desc */ |
| 486 | 535 | ||
| 487 | /* Allow 3 retries for everything but isoc */ | 536 | /* Allow 3 retries for everything but isoc; |
| 537 | * error count = 0 means infinite retries. | ||
| 538 | */ | ||
| 488 | if (!usb_endpoint_xfer_isoc(&ep->desc)) | 539 | if (!usb_endpoint_xfer_isoc(&ep->desc)) |
| 489 | ep_ctx->ep_info2 = ERROR_COUNT(3); | 540 | ep_ctx->ep_info2 = ERROR_COUNT(3); |
| 490 | else | 541 | else |
| 491 | ep_ctx->ep_info2 = ERROR_COUNT(0); | 542 | ep_ctx->ep_info2 = ERROR_COUNT(1); |
| 492 | 543 | ||
| 493 | ep_ctx->ep_info2 |= xhci_get_endpoint_type(udev, ep); | 544 | ep_ctx->ep_info2 |= xhci_get_endpoint_type(udev, ep); |
| 494 | 545 | ||
| @@ -498,7 +549,12 @@ int xhci_endpoint_init(struct xhci_hcd *xhci, | |||
| 498 | max_packet = ep->desc.wMaxPacketSize; | 549 | max_packet = ep->desc.wMaxPacketSize; |
| 499 | ep_ctx->ep_info2 |= MAX_PACKET(max_packet); | 550 | ep_ctx->ep_info2 |= MAX_PACKET(max_packet); |
| 500 | /* dig out max burst from ep companion desc */ | 551 | /* dig out max burst from ep companion desc */ |
| 501 | max_packet = ep->ss_ep_comp->desc.bMaxBurst; | 552 | if (!ep->ss_ep_comp) { |
| 553 | xhci_warn(xhci, "WARN no SS endpoint companion descriptor.\n"); | ||
| 554 | max_packet = 0; | ||
| 555 | } else { | ||
| 556 | max_packet = ep->ss_ep_comp->desc.bMaxBurst; | ||
| 557 | } | ||
| 502 | ep_ctx->ep_info2 |= MAX_BURST(max_packet); | 558 | ep_ctx->ep_info2 |= MAX_BURST(max_packet); |
| 503 | break; | 559 | break; |
| 504 | case USB_SPEED_HIGH: | 560 | case USB_SPEED_HIGH: |
| @@ -531,18 +587,114 @@ void xhci_endpoint_zero(struct xhci_hcd *xhci, | |||
| 531 | struct xhci_ep_ctx *ep_ctx; | 587 | struct xhci_ep_ctx *ep_ctx; |
| 532 | 588 | ||
| 533 | ep_index = xhci_get_endpoint_index(&ep->desc); | 589 | ep_index = xhci_get_endpoint_index(&ep->desc); |
| 534 | ep_ctx = &virt_dev->in_ctx->ep[ep_index]; | 590 | ep_ctx = xhci_get_ep_ctx(xhci, virt_dev->in_ctx, ep_index); |
| 535 | 591 | ||
| 536 | ep_ctx->ep_info = 0; | 592 | ep_ctx->ep_info = 0; |
| 537 | ep_ctx->ep_info2 = 0; | 593 | ep_ctx->ep_info2 = 0; |
| 538 | ep_ctx->deq[0] = 0; | 594 | ep_ctx->deq = 0; |
| 539 | ep_ctx->deq[1] = 0; | ||
| 540 | ep_ctx->tx_info = 0; | 595 | ep_ctx->tx_info = 0; |
| 541 | /* Don't free the endpoint ring until the set interface or configuration | 596 | /* Don't free the endpoint ring until the set interface or configuration |
| 542 | * request succeeds. | 597 | * request succeeds. |
| 543 | */ | 598 | */ |
| 544 | } | 599 | } |
| 545 | 600 | ||
| 601 | /* Set up the scratchpad buffer array and scratchpad buffers, if needed. */ | ||
| 602 | static int scratchpad_alloc(struct xhci_hcd *xhci, gfp_t flags) | ||
| 603 | { | ||
| 604 | int i; | ||
| 605 | struct device *dev = xhci_to_hcd(xhci)->self.controller; | ||
| 606 | int num_sp = HCS_MAX_SCRATCHPAD(xhci->hcs_params2); | ||
| 607 | |||
| 608 | xhci_dbg(xhci, "Allocating %d scratchpad buffers\n", num_sp); | ||
| 609 | |||
| 610 | if (!num_sp) | ||
| 611 | return 0; | ||
| 612 | |||
| 613 | xhci->scratchpad = kzalloc(sizeof(*xhci->scratchpad), flags); | ||
| 614 | if (!xhci->scratchpad) | ||
| 615 | goto fail_sp; | ||
| 616 | |||
| 617 | xhci->scratchpad->sp_array = | ||
| 618 | pci_alloc_consistent(to_pci_dev(dev), | ||
| 619 | num_sp * sizeof(u64), | ||
| 620 | &xhci->scratchpad->sp_dma); | ||
| 621 | if (!xhci->scratchpad->sp_array) | ||
| 622 | goto fail_sp2; | ||
| 623 | |||
| 624 | xhci->scratchpad->sp_buffers = kzalloc(sizeof(void *) * num_sp, flags); | ||
| 625 | if (!xhci->scratchpad->sp_buffers) | ||
| 626 | goto fail_sp3; | ||
| 627 | |||
| 628 | xhci->scratchpad->sp_dma_buffers = | ||
| 629 | kzalloc(sizeof(dma_addr_t) * num_sp, flags); | ||
| 630 | |||
| 631 | if (!xhci->scratchpad->sp_dma_buffers) | ||
| 632 | goto fail_sp4; | ||
| 633 | |||
| 634 | xhci->dcbaa->dev_context_ptrs[0] = xhci->scratchpad->sp_dma; | ||
| 635 | for (i = 0; i < num_sp; i++) { | ||
| 636 | dma_addr_t dma; | ||
| 637 | void *buf = pci_alloc_consistent(to_pci_dev(dev), | ||
| 638 | xhci->page_size, &dma); | ||
| 639 | if (!buf) | ||
| 640 | goto fail_sp5; | ||
| 641 | |||
| 642 | xhci->scratchpad->sp_array[i] = dma; | ||
| 643 | xhci->scratchpad->sp_buffers[i] = buf; | ||
| 644 | xhci->scratchpad->sp_dma_buffers[i] = dma; | ||
| 645 | } | ||
| 646 | |||
| 647 | return 0; | ||
| 648 | |||
| 649 | fail_sp5: | ||
| 650 | for (i = i - 1; i >= 0; i--) { | ||
| 651 | pci_free_consistent(to_pci_dev(dev), xhci->page_size, | ||
| 652 | xhci->scratchpad->sp_buffers[i], | ||
| 653 | xhci->scratchpad->sp_dma_buffers[i]); | ||
| 654 | } | ||
| 655 | kfree(xhci->scratchpad->sp_dma_buffers); | ||
| 656 | |||
| 657 | fail_sp4: | ||
| 658 | kfree(xhci->scratchpad->sp_buffers); | ||
| 659 | |||
| 660 | fail_sp3: | ||
| 661 | pci_free_consistent(to_pci_dev(dev), num_sp * sizeof(u64), | ||
| 662 | xhci->scratchpad->sp_array, | ||
| 663 | xhci->scratchpad->sp_dma); | ||
| 664 | |||
| 665 | fail_sp2: | ||
| 666 | kfree(xhci->scratchpad); | ||
| 667 | xhci->scratchpad = NULL; | ||
| 668 | |||
| 669 | fail_sp: | ||
| 670 | return -ENOMEM; | ||
| 671 | } | ||
| 672 | |||
| 673 | static void scratchpad_free(struct xhci_hcd *xhci) | ||
| 674 | { | ||
| 675 | int num_sp; | ||
| 676 | int i; | ||
| 677 | struct pci_dev *pdev = to_pci_dev(xhci_to_hcd(xhci)->self.controller); | ||
| 678 | |||
| 679 | if (!xhci->scratchpad) | ||
| 680 | return; | ||
| 681 | |||
| 682 | num_sp = HCS_MAX_SCRATCHPAD(xhci->hcs_params2); | ||
| 683 | |||
| 684 | for (i = 0; i < num_sp; i++) { | ||
| 685 | pci_free_consistent(pdev, xhci->page_size, | ||
| 686 | xhci->scratchpad->sp_buffers[i], | ||
| 687 | xhci->scratchpad->sp_dma_buffers[i]); | ||
| 688 | } | ||
| 689 | kfree(xhci->scratchpad->sp_dma_buffers); | ||
| 690 | kfree(xhci->scratchpad->sp_buffers); | ||
| 691 | pci_free_consistent(pdev, num_sp * sizeof(u64), | ||
| 692 | xhci->scratchpad->sp_array, | ||
| 693 | xhci->scratchpad->sp_dma); | ||
| 694 | kfree(xhci->scratchpad); | ||
| 695 | xhci->scratchpad = NULL; | ||
| 696 | } | ||
| 697 | |||
| 546 | void xhci_mem_cleanup(struct xhci_hcd *xhci) | 698 | void xhci_mem_cleanup(struct xhci_hcd *xhci) |
| 547 | { | 699 | { |
| 548 | struct pci_dev *pdev = to_pci_dev(xhci_to_hcd(xhci)->self.controller); | 700 | struct pci_dev *pdev = to_pci_dev(xhci_to_hcd(xhci)->self.controller); |
| @@ -551,10 +703,8 @@ void xhci_mem_cleanup(struct xhci_hcd *xhci) | |||
| 551 | 703 | ||
| 552 | /* Free the Event Ring Segment Table and the actual Event Ring */ | 704 | /* Free the Event Ring Segment Table and the actual Event Ring */ |
| 553 | xhci_writel(xhci, 0, &xhci->ir_set->erst_size); | 705 | xhci_writel(xhci, 0, &xhci->ir_set->erst_size); |
| 554 | xhci_writel(xhci, 0, &xhci->ir_set->erst_base[0]); | 706 | xhci_write_64(xhci, 0, &xhci->ir_set->erst_base); |
| 555 | xhci_writel(xhci, 0, &xhci->ir_set->erst_base[1]); | 707 | xhci_write_64(xhci, 0, &xhci->ir_set->erst_dequeue); |
| 556 | xhci_writel(xhci, 0, &xhci->ir_set->erst_dequeue[0]); | ||
| 557 | xhci_writel(xhci, 0, &xhci->ir_set->erst_dequeue[1]); | ||
| 558 | size = sizeof(struct xhci_erst_entry)*(xhci->erst.num_entries); | 708 | size = sizeof(struct xhci_erst_entry)*(xhci->erst.num_entries); |
| 559 | if (xhci->erst.entries) | 709 | if (xhci->erst.entries) |
| 560 | pci_free_consistent(pdev, size, | 710 | pci_free_consistent(pdev, size, |
| @@ -566,8 +716,7 @@ void xhci_mem_cleanup(struct xhci_hcd *xhci) | |||
| 566 | xhci->event_ring = NULL; | 716 | xhci->event_ring = NULL; |
| 567 | xhci_dbg(xhci, "Freed event ring\n"); | 717 | xhci_dbg(xhci, "Freed event ring\n"); |
| 568 | 718 | ||
| 569 | xhci_writel(xhci, 0, &xhci->op_regs->cmd_ring[0]); | 719 | xhci_write_64(xhci, 0, &xhci->op_regs->cmd_ring); |
| 570 | xhci_writel(xhci, 0, &xhci->op_regs->cmd_ring[1]); | ||
| 571 | if (xhci->cmd_ring) | 720 | if (xhci->cmd_ring) |
| 572 | xhci_ring_free(xhci, xhci->cmd_ring); | 721 | xhci_ring_free(xhci, xhci->cmd_ring); |
| 573 | xhci->cmd_ring = NULL; | 722 | xhci->cmd_ring = NULL; |
| @@ -586,8 +735,7 @@ void xhci_mem_cleanup(struct xhci_hcd *xhci) | |||
| 586 | xhci->device_pool = NULL; | 735 | xhci->device_pool = NULL; |
| 587 | xhci_dbg(xhci, "Freed device context pool\n"); | 736 | xhci_dbg(xhci, "Freed device context pool\n"); |
| 588 | 737 | ||
| 589 | xhci_writel(xhci, 0, &xhci->op_regs->dcbaa_ptr[0]); | 738 | xhci_write_64(xhci, 0, &xhci->op_regs->dcbaa_ptr); |
| 590 | xhci_writel(xhci, 0, &xhci->op_regs->dcbaa_ptr[1]); | ||
| 591 | if (xhci->dcbaa) | 739 | if (xhci->dcbaa) |
| 592 | pci_free_consistent(pdev, sizeof(*xhci->dcbaa), | 740 | pci_free_consistent(pdev, sizeof(*xhci->dcbaa), |
| 593 | xhci->dcbaa, xhci->dcbaa->dma); | 741 | xhci->dcbaa, xhci->dcbaa->dma); |
| @@ -595,6 +743,7 @@ void xhci_mem_cleanup(struct xhci_hcd *xhci) | |||
| 595 | 743 | ||
| 596 | xhci->page_size = 0; | 744 | xhci->page_size = 0; |
| 597 | xhci->page_shift = 0; | 745 | xhci->page_shift = 0; |
| 746 | scratchpad_free(xhci); | ||
| 598 | } | 747 | } |
| 599 | 748 | ||
| 600 | int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags) | 749 | int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags) |
| @@ -602,6 +751,7 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags) | |||
| 602 | dma_addr_t dma; | 751 | dma_addr_t dma; |
| 603 | struct device *dev = xhci_to_hcd(xhci)->self.controller; | 752 | struct device *dev = xhci_to_hcd(xhci)->self.controller; |
| 604 | unsigned int val, val2; | 753 | unsigned int val, val2; |
| 754 | u64 val_64; | ||
| 605 | struct xhci_segment *seg; | 755 | struct xhci_segment *seg; |
| 606 | u32 page_size; | 756 | u32 page_size; |
| 607 | int i; | 757 | int i; |
| @@ -647,8 +797,7 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags) | |||
| 647 | xhci->dcbaa->dma = dma; | 797 | xhci->dcbaa->dma = dma; |
| 648 | xhci_dbg(xhci, "// Device context base array address = 0x%llx (DMA), %p (virt)\n", | 798 | xhci_dbg(xhci, "// Device context base array address = 0x%llx (DMA), %p (virt)\n", |
| 649 | (unsigned long long)xhci->dcbaa->dma, xhci->dcbaa); | 799 | (unsigned long long)xhci->dcbaa->dma, xhci->dcbaa); |
| 650 | xhci_writel(xhci, dma, &xhci->op_regs->dcbaa_ptr[0]); | 800 | xhci_write_64(xhci, dma, &xhci->op_regs->dcbaa_ptr); |
| 651 | xhci_writel(xhci, (u32) 0, &xhci->op_regs->dcbaa_ptr[1]); | ||
| 652 | 801 | ||
| 653 | /* | 802 | /* |
| 654 | * Initialize the ring segment pool. The ring must be a contiguous | 803 | * Initialize the ring segment pool. The ring must be a contiguous |
| @@ -658,11 +807,10 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags) | |||
| 658 | */ | 807 | */ |
| 659 | xhci->segment_pool = dma_pool_create("xHCI ring segments", dev, | 808 | xhci->segment_pool = dma_pool_create("xHCI ring segments", dev, |
| 660 | SEGMENT_SIZE, 64, xhci->page_size); | 809 | SEGMENT_SIZE, 64, xhci->page_size); |
| 810 | |||
| 661 | /* See Table 46 and Note on Figure 55 */ | 811 | /* See Table 46 and Note on Figure 55 */ |
| 662 | /* FIXME support 64-byte contexts */ | ||
| 663 | xhci->device_pool = dma_pool_create("xHCI input/output contexts", dev, | 812 | xhci->device_pool = dma_pool_create("xHCI input/output contexts", dev, |
| 664 | sizeof(struct xhci_device_control), | 813 | 2112, 64, xhci->page_size); |
| 665 | 64, xhci->page_size); | ||
| 666 | if (!xhci->segment_pool || !xhci->device_pool) | 814 | if (!xhci->segment_pool || !xhci->device_pool) |
| 667 | goto fail; | 815 | goto fail; |
| 668 | 816 | ||
| @@ -675,14 +823,12 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags) | |||
| 675 | (unsigned long long)xhci->cmd_ring->first_seg->dma); | 823 | (unsigned long long)xhci->cmd_ring->first_seg->dma); |
| 676 | 824 | ||
| 677 | /* Set the address in the Command Ring Control register */ | 825 | /* Set the address in the Command Ring Control register */ |
| 678 | val = xhci_readl(xhci, &xhci->op_regs->cmd_ring[0]); | 826 | val_64 = xhci_read_64(xhci, &xhci->op_regs->cmd_ring); |
| 679 | val = (val & ~CMD_RING_ADDR_MASK) | | 827 | val_64 = (val_64 & (u64) CMD_RING_RSVD_BITS) | |
| 680 | (xhci->cmd_ring->first_seg->dma & CMD_RING_ADDR_MASK) | | 828 | (xhci->cmd_ring->first_seg->dma & (u64) ~CMD_RING_RSVD_BITS) | |
| 681 | xhci->cmd_ring->cycle_state; | 829 | xhci->cmd_ring->cycle_state; |
| 682 | xhci_dbg(xhci, "// Setting command ring address low bits to 0x%x\n", val); | 830 | xhci_dbg(xhci, "// Setting command ring address to 0x%x\n", val); |
| 683 | xhci_writel(xhci, val, &xhci->op_regs->cmd_ring[0]); | 831 | xhci_write_64(xhci, val_64, &xhci->op_regs->cmd_ring); |
| 684 | xhci_dbg(xhci, "// Setting command ring address high bits to 0x0\n"); | ||
| 685 | xhci_writel(xhci, (u32) 0, &xhci->op_regs->cmd_ring[1]); | ||
| 686 | xhci_dbg_cmd_ptrs(xhci); | 832 | xhci_dbg_cmd_ptrs(xhci); |
| 687 | 833 | ||
| 688 | val = xhci_readl(xhci, &xhci->cap_regs->db_off); | 834 | val = xhci_readl(xhci, &xhci->cap_regs->db_off); |
| @@ -722,8 +868,7 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags) | |||
| 722 | /* set ring base address and size for each segment table entry */ | 868 | /* set ring base address and size for each segment table entry */ |
| 723 | for (val = 0, seg = xhci->event_ring->first_seg; val < ERST_NUM_SEGS; val++) { | 869 | for (val = 0, seg = xhci->event_ring->first_seg; val < ERST_NUM_SEGS; val++) { |
| 724 | struct xhci_erst_entry *entry = &xhci->erst.entries[val]; | 870 | struct xhci_erst_entry *entry = &xhci->erst.entries[val]; |
| 725 | entry->seg_addr[0] = seg->dma; | 871 | entry->seg_addr = seg->dma; |
| 726 | entry->seg_addr[1] = 0; | ||
| 727 | entry->seg_size = TRBS_PER_SEGMENT; | 872 | entry->seg_size = TRBS_PER_SEGMENT; |
| 728 | entry->rsvd = 0; | 873 | entry->rsvd = 0; |
| 729 | seg = seg->next; | 874 | seg = seg->next; |
| @@ -741,11 +886,10 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags) | |||
| 741 | /* set the segment table base address */ | 886 | /* set the segment table base address */ |
| 742 | xhci_dbg(xhci, "// Set ERST base address for ir_set 0 = 0x%llx\n", | 887 | xhci_dbg(xhci, "// Set ERST base address for ir_set 0 = 0x%llx\n", |
| 743 | (unsigned long long)xhci->erst.erst_dma_addr); | 888 | (unsigned long long)xhci->erst.erst_dma_addr); |
| 744 | val = xhci_readl(xhci, &xhci->ir_set->erst_base[0]); | 889 | val_64 = xhci_read_64(xhci, &xhci->ir_set->erst_base); |
| 745 | val &= ERST_PTR_MASK; | 890 | val_64 &= ERST_PTR_MASK; |
| 746 | val |= (xhci->erst.erst_dma_addr & ~ERST_PTR_MASK); | 891 | val_64 |= (xhci->erst.erst_dma_addr & (u64) ~ERST_PTR_MASK); |
| 747 | xhci_writel(xhci, val, &xhci->ir_set->erst_base[0]); | 892 | xhci_write_64(xhci, val_64, &xhci->ir_set->erst_base); |
| 748 | xhci_writel(xhci, 0, &xhci->ir_set->erst_base[1]); | ||
| 749 | 893 | ||
| 750 | /* Set the event ring dequeue address */ | 894 | /* Set the event ring dequeue address */ |
| 751 | xhci_set_hc_event_deq(xhci); | 895 | xhci_set_hc_event_deq(xhci); |
| @@ -761,7 +905,11 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags) | |||
| 761 | for (i = 0; i < MAX_HC_SLOTS; ++i) | 905 | for (i = 0; i < MAX_HC_SLOTS; ++i) |
| 762 | xhci->devs[i] = 0; | 906 | xhci->devs[i] = 0; |
| 763 | 907 | ||
| 908 | if (scratchpad_alloc(xhci, flags)) | ||
| 909 | goto fail; | ||
| 910 | |||
| 764 | return 0; | 911 | return 0; |
| 912 | |||
| 765 | fail: | 913 | fail: |
| 766 | xhci_warn(xhci, "Couldn't initialize memory\n"); | 914 | xhci_warn(xhci, "Couldn't initialize memory\n"); |
| 767 | xhci_mem_cleanup(xhci); | 915 | xhci_mem_cleanup(xhci); |
diff --git a/drivers/usb/host/xhci-pci.c b/drivers/usb/host/xhci-pci.c index 1462709e26c0..592fe7e623f7 100644 --- a/drivers/usb/host/xhci-pci.c +++ b/drivers/usb/host/xhci-pci.c | |||
| @@ -117,6 +117,7 @@ static const struct hc_driver xhci_pci_hc_driver = { | |||
| 117 | .free_dev = xhci_free_dev, | 117 | .free_dev = xhci_free_dev, |
| 118 | .add_endpoint = xhci_add_endpoint, | 118 | .add_endpoint = xhci_add_endpoint, |
| 119 | .drop_endpoint = xhci_drop_endpoint, | 119 | .drop_endpoint = xhci_drop_endpoint, |
| 120 | .endpoint_reset = xhci_endpoint_reset, | ||
| 120 | .check_bandwidth = xhci_check_bandwidth, | 121 | .check_bandwidth = xhci_check_bandwidth, |
| 121 | .reset_bandwidth = xhci_reset_bandwidth, | 122 | .reset_bandwidth = xhci_reset_bandwidth, |
| 122 | .address_device = xhci_address_device, | 123 | .address_device = xhci_address_device, |
diff --git a/drivers/usb/host/xhci-ring.c b/drivers/usb/host/xhci-ring.c index 02d81985c454..aa88a067148b 100644 --- a/drivers/usb/host/xhci-ring.c +++ b/drivers/usb/host/xhci-ring.c | |||
| @@ -135,6 +135,7 @@ static void next_trb(struct xhci_hcd *xhci, | |||
| 135 | static void inc_deq(struct xhci_hcd *xhci, struct xhci_ring *ring, bool consumer) | 135 | static void inc_deq(struct xhci_hcd *xhci, struct xhci_ring *ring, bool consumer) |
| 136 | { | 136 | { |
| 137 | union xhci_trb *next = ++(ring->dequeue); | 137 | union xhci_trb *next = ++(ring->dequeue); |
| 138 | unsigned long long addr; | ||
| 138 | 139 | ||
| 139 | ring->deq_updates++; | 140 | ring->deq_updates++; |
| 140 | /* Update the dequeue pointer further if that was a link TRB or we're at | 141 | /* Update the dequeue pointer further if that was a link TRB or we're at |
| @@ -152,6 +153,13 @@ static void inc_deq(struct xhci_hcd *xhci, struct xhci_ring *ring, bool consumer | |||
| 152 | ring->dequeue = ring->deq_seg->trbs; | 153 | ring->dequeue = ring->deq_seg->trbs; |
| 153 | next = ring->dequeue; | 154 | next = ring->dequeue; |
| 154 | } | 155 | } |
| 156 | addr = (unsigned long long) xhci_trb_virt_to_dma(ring->deq_seg, ring->dequeue); | ||
| 157 | if (ring == xhci->event_ring) | ||
| 158 | xhci_dbg(xhci, "Event ring deq = 0x%llx (DMA)\n", addr); | ||
| 159 | else if (ring == xhci->cmd_ring) | ||
| 160 | xhci_dbg(xhci, "Command ring deq = 0x%llx (DMA)\n", addr); | ||
| 161 | else | ||
| 162 | xhci_dbg(xhci, "Ring deq = 0x%llx (DMA)\n", addr); | ||
| 155 | } | 163 | } |
| 156 | 164 | ||
| 157 | /* | 165 | /* |
| @@ -171,6 +179,7 @@ static void inc_enq(struct xhci_hcd *xhci, struct xhci_ring *ring, bool consumer | |||
| 171 | { | 179 | { |
| 172 | u32 chain; | 180 | u32 chain; |
| 173 | union xhci_trb *next; | 181 | union xhci_trb *next; |
| 182 | unsigned long long addr; | ||
| 174 | 183 | ||
| 175 | chain = ring->enqueue->generic.field[3] & TRB_CHAIN; | 184 | chain = ring->enqueue->generic.field[3] & TRB_CHAIN; |
| 176 | next = ++(ring->enqueue); | 185 | next = ++(ring->enqueue); |
| @@ -204,6 +213,13 @@ static void inc_enq(struct xhci_hcd *xhci, struct xhci_ring *ring, bool consumer | |||
| 204 | ring->enqueue = ring->enq_seg->trbs; | 213 | ring->enqueue = ring->enq_seg->trbs; |
| 205 | next = ring->enqueue; | 214 | next = ring->enqueue; |
| 206 | } | 215 | } |
| 216 | addr = (unsigned long long) xhci_trb_virt_to_dma(ring->enq_seg, ring->enqueue); | ||
| 217 | if (ring == xhci->event_ring) | ||
| 218 | xhci_dbg(xhci, "Event ring enq = 0x%llx (DMA)\n", addr); | ||
| 219 | else if (ring == xhci->cmd_ring) | ||
| 220 | xhci_dbg(xhci, "Command ring enq = 0x%llx (DMA)\n", addr); | ||
| 221 | else | ||
| 222 | xhci_dbg(xhci, "Ring enq = 0x%llx (DMA)\n", addr); | ||
| 207 | } | 223 | } |
| 208 | 224 | ||
| 209 | /* | 225 | /* |
| @@ -237,7 +253,7 @@ static int room_on_ring(struct xhci_hcd *xhci, struct xhci_ring *ring, | |||
| 237 | 253 | ||
| 238 | void xhci_set_hc_event_deq(struct xhci_hcd *xhci) | 254 | void xhci_set_hc_event_deq(struct xhci_hcd *xhci) |
| 239 | { | 255 | { |
| 240 | u32 temp; | 256 | u64 temp; |
| 241 | dma_addr_t deq; | 257 | dma_addr_t deq; |
| 242 | 258 | ||
| 243 | deq = xhci_trb_virt_to_dma(xhci->event_ring->deq_seg, | 259 | deq = xhci_trb_virt_to_dma(xhci->event_ring->deq_seg, |
| @@ -246,13 +262,15 @@ void xhci_set_hc_event_deq(struct xhci_hcd *xhci) | |||
| 246 | xhci_warn(xhci, "WARN something wrong with SW event ring " | 262 | xhci_warn(xhci, "WARN something wrong with SW event ring " |
| 247 | "dequeue ptr.\n"); | 263 | "dequeue ptr.\n"); |
| 248 | /* Update HC event ring dequeue pointer */ | 264 | /* Update HC event ring dequeue pointer */ |
| 249 | temp = xhci_readl(xhci, &xhci->ir_set->erst_dequeue[0]); | 265 | temp = xhci_read_64(xhci, &xhci->ir_set->erst_dequeue); |
| 250 | temp &= ERST_PTR_MASK; | 266 | temp &= ERST_PTR_MASK; |
| 251 | if (!in_interrupt()) | 267 | /* Don't clear the EHB bit (which is RW1C) because |
| 252 | xhci_dbg(xhci, "// Write event ring dequeue pointer\n"); | 268 | * there might be more events to service. |
| 253 | xhci_writel(xhci, 0, &xhci->ir_set->erst_dequeue[1]); | 269 | */ |
| 254 | xhci_writel(xhci, (deq & ~ERST_PTR_MASK) | temp, | 270 | temp &= ~ERST_EHB; |
| 255 | &xhci->ir_set->erst_dequeue[0]); | 271 | xhci_dbg(xhci, "// Write event ring dequeue pointer, preserving EHB bit\n"); |
| 272 | xhci_write_64(xhci, ((u64) deq & (u64) ~ERST_PTR_MASK) | temp, | ||
| 273 | &xhci->ir_set->erst_dequeue); | ||
| 256 | } | 274 | } |
| 257 | 275 | ||
| 258 | /* Ring the host controller doorbell after placing a command on the ring */ | 276 | /* Ring the host controller doorbell after placing a command on the ring */ |
| @@ -279,7 +297,8 @@ static void ring_ep_doorbell(struct xhci_hcd *xhci, | |||
| 279 | /* Don't ring the doorbell for this endpoint if there are pending | 297 | /* Don't ring the doorbell for this endpoint if there are pending |
| 280 | * cancellations because the we don't want to interrupt processing. | 298 | * cancellations because the we don't want to interrupt processing. |
| 281 | */ | 299 | */ |
| 282 | if (!ep_ring->cancels_pending && !(ep_ring->state & SET_DEQ_PENDING)) { | 300 | if (!ep_ring->cancels_pending && !(ep_ring->state & SET_DEQ_PENDING) |
| 301 | && !(ep_ring->state & EP_HALTED)) { | ||
| 283 | field = xhci_readl(xhci, db_addr) & DB_MASK; | 302 | field = xhci_readl(xhci, db_addr) & DB_MASK; |
| 284 | xhci_writel(xhci, field | EPI_TO_DB(ep_index), db_addr); | 303 | xhci_writel(xhci, field | EPI_TO_DB(ep_index), db_addr); |
| 285 | /* Flush PCI posted writes - FIXME Matthew Wilcox says this | 304 | /* Flush PCI posted writes - FIXME Matthew Wilcox says this |
| @@ -316,12 +335,6 @@ static struct xhci_segment *find_trb_seg( | |||
| 316 | return cur_seg; | 335 | return cur_seg; |
| 317 | } | 336 | } |
| 318 | 337 | ||
| 319 | struct dequeue_state { | ||
| 320 | struct xhci_segment *new_deq_seg; | ||
| 321 | union xhci_trb *new_deq_ptr; | ||
| 322 | int new_cycle_state; | ||
| 323 | }; | ||
| 324 | |||
| 325 | /* | 338 | /* |
| 326 | * Move the xHC's endpoint ring dequeue pointer past cur_td. | 339 | * Move the xHC's endpoint ring dequeue pointer past cur_td. |
| 327 | * Record the new state of the xHC's endpoint ring dequeue segment, | 340 | * Record the new state of the xHC's endpoint ring dequeue segment, |
| @@ -336,24 +349,30 @@ struct dequeue_state { | |||
| 336 | * - Finally we move the dequeue state one TRB further, toggling the cycle bit | 349 | * - Finally we move the dequeue state one TRB further, toggling the cycle bit |
| 337 | * if we've moved it past a link TRB with the toggle cycle bit set. | 350 | * if we've moved it past a link TRB with the toggle cycle bit set. |
| 338 | */ | 351 | */ |
| 339 | static void find_new_dequeue_state(struct xhci_hcd *xhci, | 352 | void xhci_find_new_dequeue_state(struct xhci_hcd *xhci, |
| 340 | unsigned int slot_id, unsigned int ep_index, | 353 | unsigned int slot_id, unsigned int ep_index, |
| 341 | struct xhci_td *cur_td, struct dequeue_state *state) | 354 | struct xhci_td *cur_td, struct xhci_dequeue_state *state) |
| 342 | { | 355 | { |
| 343 | struct xhci_virt_device *dev = xhci->devs[slot_id]; | 356 | struct xhci_virt_device *dev = xhci->devs[slot_id]; |
| 344 | struct xhci_ring *ep_ring = dev->ep_rings[ep_index]; | 357 | struct xhci_ring *ep_ring = dev->ep_rings[ep_index]; |
| 345 | struct xhci_generic_trb *trb; | 358 | struct xhci_generic_trb *trb; |
| 359 | struct xhci_ep_ctx *ep_ctx; | ||
| 360 | dma_addr_t addr; | ||
| 346 | 361 | ||
| 347 | state->new_cycle_state = 0; | 362 | state->new_cycle_state = 0; |
| 363 | xhci_dbg(xhci, "Finding segment containing stopped TRB.\n"); | ||
| 348 | state->new_deq_seg = find_trb_seg(cur_td->start_seg, | 364 | state->new_deq_seg = find_trb_seg(cur_td->start_seg, |
| 349 | ep_ring->stopped_trb, | 365 | ep_ring->stopped_trb, |
| 350 | &state->new_cycle_state); | 366 | &state->new_cycle_state); |
| 351 | if (!state->new_deq_seg) | 367 | if (!state->new_deq_seg) |
| 352 | BUG(); | 368 | BUG(); |
| 353 | /* Dig out the cycle state saved by the xHC during the stop ep cmd */ | 369 | /* Dig out the cycle state saved by the xHC during the stop ep cmd */ |
| 354 | state->new_cycle_state = 0x1 & dev->out_ctx->ep[ep_index].deq[0]; | 370 | xhci_dbg(xhci, "Finding endpoint context\n"); |
| 371 | ep_ctx = xhci_get_ep_ctx(xhci, dev->out_ctx, ep_index); | ||
| 372 | state->new_cycle_state = 0x1 & ep_ctx->deq; | ||
| 355 | 373 | ||
| 356 | state->new_deq_ptr = cur_td->last_trb; | 374 | state->new_deq_ptr = cur_td->last_trb; |
| 375 | xhci_dbg(xhci, "Finding segment containing last TRB in TD.\n"); | ||
| 357 | state->new_deq_seg = find_trb_seg(state->new_deq_seg, | 376 | state->new_deq_seg = find_trb_seg(state->new_deq_seg, |
| 358 | state->new_deq_ptr, | 377 | state->new_deq_ptr, |
| 359 | &state->new_cycle_state); | 378 | &state->new_cycle_state); |
| @@ -367,6 +386,12 @@ static void find_new_dequeue_state(struct xhci_hcd *xhci, | |||
| 367 | next_trb(xhci, ep_ring, &state->new_deq_seg, &state->new_deq_ptr); | 386 | next_trb(xhci, ep_ring, &state->new_deq_seg, &state->new_deq_ptr); |
| 368 | 387 | ||
| 369 | /* Don't update the ring cycle state for the producer (us). */ | 388 | /* Don't update the ring cycle state for the producer (us). */ |
| 389 | xhci_dbg(xhci, "New dequeue segment = %p (virtual)\n", | ||
| 390 | state->new_deq_seg); | ||
| 391 | addr = xhci_trb_virt_to_dma(state->new_deq_seg, state->new_deq_ptr); | ||
| 392 | xhci_dbg(xhci, "New dequeue pointer = 0x%llx (DMA)\n", | ||
| 393 | (unsigned long long) addr); | ||
| 394 | xhci_dbg(xhci, "Setting dequeue pointer in internal ring state.\n"); | ||
| 370 | ep_ring->dequeue = state->new_deq_ptr; | 395 | ep_ring->dequeue = state->new_deq_ptr; |
| 371 | ep_ring->deq_seg = state->new_deq_seg; | 396 | ep_ring->deq_seg = state->new_deq_seg; |
| 372 | } | 397 | } |
| @@ -416,6 +441,30 @@ static int queue_set_tr_deq(struct xhci_hcd *xhci, int slot_id, | |||
| 416 | unsigned int ep_index, struct xhci_segment *deq_seg, | 441 | unsigned int ep_index, struct xhci_segment *deq_seg, |
| 417 | union xhci_trb *deq_ptr, u32 cycle_state); | 442 | union xhci_trb *deq_ptr, u32 cycle_state); |
| 418 | 443 | ||
| 444 | void xhci_queue_new_dequeue_state(struct xhci_hcd *xhci, | ||
| 445 | struct xhci_ring *ep_ring, unsigned int slot_id, | ||
| 446 | unsigned int ep_index, struct xhci_dequeue_state *deq_state) | ||
| 447 | { | ||
| 448 | xhci_dbg(xhci, "Set TR Deq Ptr cmd, new deq seg = %p (0x%llx dma), " | ||
| 449 | "new deq ptr = %p (0x%llx dma), new cycle = %u\n", | ||
| 450 | deq_state->new_deq_seg, | ||
| 451 | (unsigned long long)deq_state->new_deq_seg->dma, | ||
| 452 | deq_state->new_deq_ptr, | ||
| 453 | (unsigned long long)xhci_trb_virt_to_dma(deq_state->new_deq_seg, deq_state->new_deq_ptr), | ||
| 454 | deq_state->new_cycle_state); | ||
| 455 | queue_set_tr_deq(xhci, slot_id, ep_index, | ||
| 456 | deq_state->new_deq_seg, | ||
| 457 | deq_state->new_deq_ptr, | ||
| 458 | (u32) deq_state->new_cycle_state); | ||
| 459 | /* Stop the TD queueing code from ringing the doorbell until | ||
| 460 | * this command completes. The HC won't set the dequeue pointer | ||
| 461 | * if the ring is running, and ringing the doorbell starts the | ||
| 462 | * ring running. | ||
| 463 | */ | ||
| 464 | ep_ring->state |= SET_DEQ_PENDING; | ||
| 465 | xhci_ring_cmd_db(xhci); | ||
| 466 | } | ||
| 467 | |||
| 419 | /* | 468 | /* |
| 420 | * When we get a command completion for a Stop Endpoint Command, we need to | 469 | * When we get a command completion for a Stop Endpoint Command, we need to |
| 421 | * unlink any cancelled TDs from the ring. There are two ways to do that: | 470 | * unlink any cancelled TDs from the ring. There are two ways to do that: |
| @@ -436,7 +485,7 @@ static void handle_stopped_endpoint(struct xhci_hcd *xhci, | |||
| 436 | struct xhci_td *cur_td = 0; | 485 | struct xhci_td *cur_td = 0; |
| 437 | struct xhci_td *last_unlinked_td; | 486 | struct xhci_td *last_unlinked_td; |
| 438 | 487 | ||
| 439 | struct dequeue_state deq_state; | 488 | struct xhci_dequeue_state deq_state; |
| 440 | #ifdef CONFIG_USB_HCD_STAT | 489 | #ifdef CONFIG_USB_HCD_STAT |
| 441 | ktime_t stop_time = ktime_get(); | 490 | ktime_t stop_time = ktime_get(); |
| 442 | #endif | 491 | #endif |
| @@ -464,7 +513,7 @@ static void handle_stopped_endpoint(struct xhci_hcd *xhci, | |||
| 464 | * move the xHC endpoint ring dequeue pointer past this TD. | 513 | * move the xHC endpoint ring dequeue pointer past this TD. |
| 465 | */ | 514 | */ |
| 466 | if (cur_td == ep_ring->stopped_td) | 515 | if (cur_td == ep_ring->stopped_td) |
| 467 | find_new_dequeue_state(xhci, slot_id, ep_index, cur_td, | 516 | xhci_find_new_dequeue_state(xhci, slot_id, ep_index, cur_td, |
| 468 | &deq_state); | 517 | &deq_state); |
| 469 | else | 518 | else |
| 470 | td_to_noop(xhci, ep_ring, cur_td); | 519 | td_to_noop(xhci, ep_ring, cur_td); |
| @@ -480,24 +529,8 @@ static void handle_stopped_endpoint(struct xhci_hcd *xhci, | |||
| 480 | 529 | ||
| 481 | /* If necessary, queue a Set Transfer Ring Dequeue Pointer command */ | 530 | /* If necessary, queue a Set Transfer Ring Dequeue Pointer command */ |
| 482 | if (deq_state.new_deq_ptr && deq_state.new_deq_seg) { | 531 | if (deq_state.new_deq_ptr && deq_state.new_deq_seg) { |
| 483 | xhci_dbg(xhci, "Set TR Deq Ptr cmd, new deq seg = %p (0x%llx dma), " | 532 | xhci_queue_new_dequeue_state(xhci, ep_ring, |
| 484 | "new deq ptr = %p (0x%llx dma), new cycle = %u\n", | 533 | slot_id, ep_index, &deq_state); |
| 485 | deq_state.new_deq_seg, | ||
| 486 | (unsigned long long)deq_state.new_deq_seg->dma, | ||
| 487 | deq_state.new_deq_ptr, | ||
| 488 | (unsigned long long)xhci_trb_virt_to_dma(deq_state.new_deq_seg, deq_state.new_deq_ptr), | ||
| 489 | deq_state.new_cycle_state); | ||
| 490 | queue_set_tr_deq(xhci, slot_id, ep_index, | ||
| 491 | deq_state.new_deq_seg, | ||
| 492 | deq_state.new_deq_ptr, | ||
| 493 | (u32) deq_state.new_cycle_state); | ||
| 494 | /* Stop the TD queueing code from ringing the doorbell until | ||
| 495 | * this command completes. The HC won't set the dequeue pointer | ||
| 496 | * if the ring is running, and ringing the doorbell starts the | ||
| 497 | * ring running. | ||
| 498 | */ | ||
| 499 | ep_ring->state |= SET_DEQ_PENDING; | ||
| 500 | xhci_ring_cmd_db(xhci); | ||
| 501 | } else { | 534 | } else { |
| 502 | /* Otherwise just ring the doorbell to restart the ring */ | 535 | /* Otherwise just ring the doorbell to restart the ring */ |
| 503 | ring_ep_doorbell(xhci, slot_id, ep_index); | 536 | ring_ep_doorbell(xhci, slot_id, ep_index); |
| @@ -551,11 +584,15 @@ static void handle_set_deq_completion(struct xhci_hcd *xhci, | |||
| 551 | unsigned int ep_index; | 584 | unsigned int ep_index; |
| 552 | struct xhci_ring *ep_ring; | 585 | struct xhci_ring *ep_ring; |
| 553 | struct xhci_virt_device *dev; | 586 | struct xhci_virt_device *dev; |
| 587 | struct xhci_ep_ctx *ep_ctx; | ||
| 588 | struct xhci_slot_ctx *slot_ctx; | ||
| 554 | 589 | ||
| 555 | slot_id = TRB_TO_SLOT_ID(trb->generic.field[3]); | 590 | slot_id = TRB_TO_SLOT_ID(trb->generic.field[3]); |
| 556 | ep_index = TRB_TO_EP_INDEX(trb->generic.field[3]); | 591 | ep_index = TRB_TO_EP_INDEX(trb->generic.field[3]); |
| 557 | dev = xhci->devs[slot_id]; | 592 | dev = xhci->devs[slot_id]; |
| 558 | ep_ring = dev->ep_rings[ep_index]; | 593 | ep_ring = dev->ep_rings[ep_index]; |
| 594 | ep_ctx = xhci_get_ep_ctx(xhci, dev->out_ctx, ep_index); | ||
| 595 | slot_ctx = xhci_get_slot_ctx(xhci, dev->out_ctx); | ||
| 559 | 596 | ||
| 560 | if (GET_COMP_CODE(event->status) != COMP_SUCCESS) { | 597 | if (GET_COMP_CODE(event->status) != COMP_SUCCESS) { |
| 561 | unsigned int ep_state; | 598 | unsigned int ep_state; |
| @@ -569,9 +606,9 @@ static void handle_set_deq_completion(struct xhci_hcd *xhci, | |||
| 569 | case COMP_CTX_STATE: | 606 | case COMP_CTX_STATE: |
| 570 | xhci_warn(xhci, "WARN Set TR Deq Ptr cmd failed due " | 607 | xhci_warn(xhci, "WARN Set TR Deq Ptr cmd failed due " |
| 571 | "to incorrect slot or ep state.\n"); | 608 | "to incorrect slot or ep state.\n"); |
| 572 | ep_state = dev->out_ctx->ep[ep_index].ep_info; | 609 | ep_state = ep_ctx->ep_info; |
| 573 | ep_state &= EP_STATE_MASK; | 610 | ep_state &= EP_STATE_MASK; |
| 574 | slot_state = dev->out_ctx->slot.dev_state; | 611 | slot_state = slot_ctx->dev_state; |
| 575 | slot_state = GET_SLOT_STATE(slot_state); | 612 | slot_state = GET_SLOT_STATE(slot_state); |
| 576 | xhci_dbg(xhci, "Slot state = %u, EP state = %u\n", | 613 | xhci_dbg(xhci, "Slot state = %u, EP state = %u\n", |
| 577 | slot_state, ep_state); | 614 | slot_state, ep_state); |
| @@ -593,16 +630,33 @@ static void handle_set_deq_completion(struct xhci_hcd *xhci, | |||
| 593 | * cancelling URBs, which might not be an error... | 630 | * cancelling URBs, which might not be an error... |
| 594 | */ | 631 | */ |
| 595 | } else { | 632 | } else { |
| 596 | xhci_dbg(xhci, "Successful Set TR Deq Ptr cmd, deq[0] = 0x%x, " | 633 | xhci_dbg(xhci, "Successful Set TR Deq Ptr cmd, deq = @%08llx\n", |
| 597 | "deq[1] = 0x%x.\n", | 634 | ep_ctx->deq); |
| 598 | dev->out_ctx->ep[ep_index].deq[0], | ||
| 599 | dev->out_ctx->ep[ep_index].deq[1]); | ||
| 600 | } | 635 | } |
| 601 | 636 | ||
| 602 | ep_ring->state &= ~SET_DEQ_PENDING; | 637 | ep_ring->state &= ~SET_DEQ_PENDING; |
| 603 | ring_ep_doorbell(xhci, slot_id, ep_index); | 638 | ring_ep_doorbell(xhci, slot_id, ep_index); |
| 604 | } | 639 | } |
| 605 | 640 | ||
| 641 | static void handle_reset_ep_completion(struct xhci_hcd *xhci, | ||
| 642 | struct xhci_event_cmd *event, | ||
| 643 | union xhci_trb *trb) | ||
| 644 | { | ||
| 645 | int slot_id; | ||
| 646 | unsigned int ep_index; | ||
| 647 | |||
| 648 | slot_id = TRB_TO_SLOT_ID(trb->generic.field[3]); | ||
| 649 | ep_index = TRB_TO_EP_INDEX(trb->generic.field[3]); | ||
| 650 | /* This command will only fail if the endpoint wasn't halted, | ||
| 651 | * but we don't care. | ||
| 652 | */ | ||
| 653 | xhci_dbg(xhci, "Ignoring reset ep completion code of %u\n", | ||
| 654 | (unsigned int) GET_COMP_CODE(event->status)); | ||
| 655 | |||
| 656 | /* Clear our internal halted state and restart the ring */ | ||
| 657 | xhci->devs[slot_id]->ep_rings[ep_index]->state &= ~EP_HALTED; | ||
| 658 | ring_ep_doorbell(xhci, slot_id, ep_index); | ||
| 659 | } | ||
| 606 | 660 | ||
| 607 | static void handle_cmd_completion(struct xhci_hcd *xhci, | 661 | static void handle_cmd_completion(struct xhci_hcd *xhci, |
| 608 | struct xhci_event_cmd *event) | 662 | struct xhci_event_cmd *event) |
| @@ -611,7 +665,7 @@ static void handle_cmd_completion(struct xhci_hcd *xhci, | |||
| 611 | u64 cmd_dma; | 665 | u64 cmd_dma; |
| 612 | dma_addr_t cmd_dequeue_dma; | 666 | dma_addr_t cmd_dequeue_dma; |
| 613 | 667 | ||
| 614 | cmd_dma = (((u64) event->cmd_trb[1]) << 32) + event->cmd_trb[0]; | 668 | cmd_dma = event->cmd_trb; |
| 615 | cmd_dequeue_dma = xhci_trb_virt_to_dma(xhci->cmd_ring->deq_seg, | 669 | cmd_dequeue_dma = xhci_trb_virt_to_dma(xhci->cmd_ring->deq_seg, |
| 616 | xhci->cmd_ring->dequeue); | 670 | xhci->cmd_ring->dequeue); |
| 617 | /* Is the command ring deq ptr out of sync with the deq seg ptr? */ | 671 | /* Is the command ring deq ptr out of sync with the deq seg ptr? */ |
| @@ -653,6 +707,9 @@ static void handle_cmd_completion(struct xhci_hcd *xhci, | |||
| 653 | case TRB_TYPE(TRB_CMD_NOOP): | 707 | case TRB_TYPE(TRB_CMD_NOOP): |
| 654 | ++xhci->noops_handled; | 708 | ++xhci->noops_handled; |
| 655 | break; | 709 | break; |
| 710 | case TRB_TYPE(TRB_RESET_EP): | ||
| 711 | handle_reset_ep_completion(xhci, event, xhci->cmd_ring->dequeue); | ||
| 712 | break; | ||
| 656 | default: | 713 | default: |
| 657 | /* Skip over unknown commands on the event ring */ | 714 | /* Skip over unknown commands on the event ring */ |
| 658 | xhci->error_bitmask |= 1 << 6; | 715 | xhci->error_bitmask |= 1 << 6; |
| @@ -756,7 +813,9 @@ static int handle_tx_event(struct xhci_hcd *xhci, | |||
| 756 | union xhci_trb *event_trb; | 813 | union xhci_trb *event_trb; |
| 757 | struct urb *urb = 0; | 814 | struct urb *urb = 0; |
| 758 | int status = -EINPROGRESS; | 815 | int status = -EINPROGRESS; |
| 816 | struct xhci_ep_ctx *ep_ctx; | ||
| 759 | 817 | ||
| 818 | xhci_dbg(xhci, "In %s\n", __func__); | ||
| 760 | xdev = xhci->devs[TRB_TO_SLOT_ID(event->flags)]; | 819 | xdev = xhci->devs[TRB_TO_SLOT_ID(event->flags)]; |
| 761 | if (!xdev) { | 820 | if (!xdev) { |
| 762 | xhci_err(xhci, "ERROR Transfer event pointed to bad slot\n"); | 821 | xhci_err(xhci, "ERROR Transfer event pointed to bad slot\n"); |
| @@ -765,17 +824,17 @@ static int handle_tx_event(struct xhci_hcd *xhci, | |||
| 765 | 824 | ||
| 766 | /* Endpoint ID is 1 based, our index is zero based */ | 825 | /* Endpoint ID is 1 based, our index is zero based */ |
| 767 | ep_index = TRB_TO_EP_ID(event->flags) - 1; | 826 | ep_index = TRB_TO_EP_ID(event->flags) - 1; |
| 827 | xhci_dbg(xhci, "%s - ep index = %d\n", __func__, ep_index); | ||
| 768 | ep_ring = xdev->ep_rings[ep_index]; | 828 | ep_ring = xdev->ep_rings[ep_index]; |
| 769 | if (!ep_ring || (xdev->out_ctx->ep[ep_index].ep_info & EP_STATE_MASK) == EP_STATE_DISABLED) { | 829 | ep_ctx = xhci_get_ep_ctx(xhci, xdev->out_ctx, ep_index); |
| 830 | if (!ep_ring || (ep_ctx->ep_info & EP_STATE_MASK) == EP_STATE_DISABLED) { | ||
| 770 | xhci_err(xhci, "ERROR Transfer event pointed to disabled endpoint\n"); | 831 | xhci_err(xhci, "ERROR Transfer event pointed to disabled endpoint\n"); |
| 771 | return -ENODEV; | 832 | return -ENODEV; |
| 772 | } | 833 | } |
| 773 | 834 | ||
| 774 | event_dma = event->buffer[0]; | 835 | event_dma = event->buffer; |
| 775 | if (event->buffer[1] != 0) | ||
| 776 | xhci_warn(xhci, "WARN ignoring upper 32-bits of 64-bit TRB dma address\n"); | ||
| 777 | |||
| 778 | /* This TRB should be in the TD at the head of this ring's TD list */ | 836 | /* This TRB should be in the TD at the head of this ring's TD list */ |
| 837 | xhci_dbg(xhci, "%s - checking for list empty\n", __func__); | ||
| 779 | if (list_empty(&ep_ring->td_list)) { | 838 | if (list_empty(&ep_ring->td_list)) { |
| 780 | xhci_warn(xhci, "WARN Event TRB for slot %d ep %d with no TDs queued?\n", | 839 | xhci_warn(xhci, "WARN Event TRB for slot %d ep %d with no TDs queued?\n", |
| 781 | TRB_TO_SLOT_ID(event->flags), ep_index); | 840 | TRB_TO_SLOT_ID(event->flags), ep_index); |
| @@ -785,11 +844,14 @@ static int handle_tx_event(struct xhci_hcd *xhci, | |||
| 785 | urb = NULL; | 844 | urb = NULL; |
| 786 | goto cleanup; | 845 | goto cleanup; |
| 787 | } | 846 | } |
| 847 | xhci_dbg(xhci, "%s - getting list entry\n", __func__); | ||
| 788 | td = list_entry(ep_ring->td_list.next, struct xhci_td, td_list); | 848 | td = list_entry(ep_ring->td_list.next, struct xhci_td, td_list); |
| 789 | 849 | ||
| 790 | /* Is this a TRB in the currently executing TD? */ | 850 | /* Is this a TRB in the currently executing TD? */ |
| 851 | xhci_dbg(xhci, "%s - looking for TD\n", __func__); | ||
| 791 | event_seg = trb_in_td(ep_ring->deq_seg, ep_ring->dequeue, | 852 | event_seg = trb_in_td(ep_ring->deq_seg, ep_ring->dequeue, |
| 792 | td->last_trb, event_dma); | 853 | td->last_trb, event_dma); |
| 854 | xhci_dbg(xhci, "%s - found event_seg = %p\n", __func__, event_seg); | ||
| 793 | if (!event_seg) { | 855 | if (!event_seg) { |
| 794 | /* HC is busted, give up! */ | 856 | /* HC is busted, give up! */ |
| 795 | xhci_err(xhci, "ERROR Transfer event TRB DMA ptr not part of current TD\n"); | 857 | xhci_err(xhci, "ERROR Transfer event TRB DMA ptr not part of current TD\n"); |
| @@ -798,10 +860,10 @@ static int handle_tx_event(struct xhci_hcd *xhci, | |||
| 798 | event_trb = &event_seg->trbs[(event_dma - event_seg->dma) / sizeof(*event_trb)]; | 860 | event_trb = &event_seg->trbs[(event_dma - event_seg->dma) / sizeof(*event_trb)]; |
| 799 | xhci_dbg(xhci, "Event TRB with TRB type ID %u\n", | 861 | xhci_dbg(xhci, "Event TRB with TRB type ID %u\n", |
| 800 | (unsigned int) (event->flags & TRB_TYPE_BITMASK)>>10); | 862 | (unsigned int) (event->flags & TRB_TYPE_BITMASK)>>10); |
| 801 | xhci_dbg(xhci, "Offset 0x00 (buffer[0]) = 0x%x\n", | 863 | xhci_dbg(xhci, "Offset 0x00 (buffer lo) = 0x%x\n", |
| 802 | (unsigned int) event->buffer[0]); | 864 | lower_32_bits(event->buffer)); |
| 803 | xhci_dbg(xhci, "Offset 0x04 (buffer[0]) = 0x%x\n", | 865 | xhci_dbg(xhci, "Offset 0x04 (buffer hi) = 0x%x\n", |
| 804 | (unsigned int) event->buffer[1]); | 866 | upper_32_bits(event->buffer)); |
| 805 | xhci_dbg(xhci, "Offset 0x08 (transfer length) = 0x%x\n", | 867 | xhci_dbg(xhci, "Offset 0x08 (transfer length) = 0x%x\n", |
| 806 | (unsigned int) event->transfer_len); | 868 | (unsigned int) event->transfer_len); |
| 807 | xhci_dbg(xhci, "Offset 0x0C (flags) = 0x%x\n", | 869 | xhci_dbg(xhci, "Offset 0x0C (flags) = 0x%x\n", |
| @@ -823,6 +885,7 @@ static int handle_tx_event(struct xhci_hcd *xhci, | |||
| 823 | break; | 885 | break; |
| 824 | case COMP_STALL: | 886 | case COMP_STALL: |
| 825 | xhci_warn(xhci, "WARN: Stalled endpoint\n"); | 887 | xhci_warn(xhci, "WARN: Stalled endpoint\n"); |
| 888 | ep_ring->state |= EP_HALTED; | ||
| 826 | status = -EPIPE; | 889 | status = -EPIPE; |
| 827 | break; | 890 | break; |
| 828 | case COMP_TRB_ERR: | 891 | case COMP_TRB_ERR: |
| @@ -833,6 +896,10 @@ static int handle_tx_event(struct xhci_hcd *xhci, | |||
| 833 | xhci_warn(xhci, "WARN: transfer error on endpoint\n"); | 896 | xhci_warn(xhci, "WARN: transfer error on endpoint\n"); |
| 834 | status = -EPROTO; | 897 | status = -EPROTO; |
| 835 | break; | 898 | break; |
| 899 | case COMP_BABBLE: | ||
| 900 | xhci_warn(xhci, "WARN: babble error on endpoint\n"); | ||
| 901 | status = -EOVERFLOW; | ||
| 902 | break; | ||
| 836 | case COMP_DB_ERR: | 903 | case COMP_DB_ERR: |
| 837 | xhci_warn(xhci, "WARN: HC couldn't access mem fast enough\n"); | 904 | xhci_warn(xhci, "WARN: HC couldn't access mem fast enough\n"); |
| 838 | status = -ENOSR; | 905 | status = -ENOSR; |
| @@ -874,15 +941,26 @@ static int handle_tx_event(struct xhci_hcd *xhci, | |||
| 874 | if (event_trb != ep_ring->dequeue) { | 941 | if (event_trb != ep_ring->dequeue) { |
| 875 | /* The event was for the status stage */ | 942 | /* The event was for the status stage */ |
| 876 | if (event_trb == td->last_trb) { | 943 | if (event_trb == td->last_trb) { |
| 877 | td->urb->actual_length = | 944 | if (td->urb->actual_length != 0) { |
| 878 | td->urb->transfer_buffer_length; | 945 | /* Don't overwrite a previously set error code */ |
| 946 | if (status == -EINPROGRESS || status == 0) | ||
| 947 | /* Did we already see a short data stage? */ | ||
| 948 | status = -EREMOTEIO; | ||
| 949 | } else { | ||
| 950 | td->urb->actual_length = | ||
| 951 | td->urb->transfer_buffer_length; | ||
| 952 | } | ||
| 879 | } else { | 953 | } else { |
| 880 | /* Maybe the event was for the data stage? */ | 954 | /* Maybe the event was for the data stage? */ |
| 881 | if (GET_COMP_CODE(event->transfer_len) != COMP_STOP_INVAL) | 955 | if (GET_COMP_CODE(event->transfer_len) != COMP_STOP_INVAL) { |
| 882 | /* We didn't stop on a link TRB in the middle */ | 956 | /* We didn't stop on a link TRB in the middle */ |
| 883 | td->urb->actual_length = | 957 | td->urb->actual_length = |
| 884 | td->urb->transfer_buffer_length - | 958 | td->urb->transfer_buffer_length - |
| 885 | TRB_LEN(event->transfer_len); | 959 | TRB_LEN(event->transfer_len); |
| 960 | xhci_dbg(xhci, "Waiting for status stage event\n"); | ||
| 961 | urb = NULL; | ||
| 962 | goto cleanup; | ||
| 963 | } | ||
| 886 | } | 964 | } |
| 887 | } | 965 | } |
| 888 | } else { | 966 | } else { |
| @@ -929,16 +1007,20 @@ static int handle_tx_event(struct xhci_hcd *xhci, | |||
| 929 | TRB_LEN(event->transfer_len)); | 1007 | TRB_LEN(event->transfer_len)); |
| 930 | td->urb->actual_length = 0; | 1008 | td->urb->actual_length = 0; |
| 931 | } | 1009 | } |
| 932 | if (td->urb->transfer_flags & URB_SHORT_NOT_OK) | 1010 | /* Don't overwrite a previously set error code */ |
| 933 | status = -EREMOTEIO; | 1011 | if (status == -EINPROGRESS) { |
| 934 | else | 1012 | if (td->urb->transfer_flags & URB_SHORT_NOT_OK) |
| 935 | status = 0; | 1013 | status = -EREMOTEIO; |
| 1014 | else | ||
| 1015 | status = 0; | ||
| 1016 | } | ||
| 936 | } else { | 1017 | } else { |
| 937 | td->urb->actual_length = td->urb->transfer_buffer_length; | 1018 | td->urb->actual_length = td->urb->transfer_buffer_length; |
| 938 | /* Ignore a short packet completion if the | 1019 | /* Ignore a short packet completion if the |
| 939 | * untransferred length was zero. | 1020 | * untransferred length was zero. |
| 940 | */ | 1021 | */ |
| 941 | status = 0; | 1022 | if (status == -EREMOTEIO) |
| 1023 | status = 0; | ||
| 942 | } | 1024 | } |
| 943 | } else { | 1025 | } else { |
| 944 | /* Slow path - walk the list, starting from the dequeue | 1026 | /* Slow path - walk the list, starting from the dequeue |
| @@ -965,19 +1047,30 @@ static int handle_tx_event(struct xhci_hcd *xhci, | |||
| 965 | TRB_LEN(event->transfer_len); | 1047 | TRB_LEN(event->transfer_len); |
| 966 | } | 1048 | } |
| 967 | } | 1049 | } |
| 968 | /* The Endpoint Stop Command completion will take care of | ||
| 969 | * any stopped TDs. A stopped TD may be restarted, so don't update the | ||
| 970 | * ring dequeue pointer or take this TD off any lists yet. | ||
| 971 | */ | ||
| 972 | if (GET_COMP_CODE(event->transfer_len) == COMP_STOP_INVAL || | 1050 | if (GET_COMP_CODE(event->transfer_len) == COMP_STOP_INVAL || |
| 973 | GET_COMP_CODE(event->transfer_len) == COMP_STOP) { | 1051 | GET_COMP_CODE(event->transfer_len) == COMP_STOP) { |
| 1052 | /* The Endpoint Stop Command completion will take care of any | ||
| 1053 | * stopped TDs. A stopped TD may be restarted, so don't update | ||
| 1054 | * the ring dequeue pointer or take this TD off any lists yet. | ||
| 1055 | */ | ||
| 974 | ep_ring->stopped_td = td; | 1056 | ep_ring->stopped_td = td; |
| 975 | ep_ring->stopped_trb = event_trb; | 1057 | ep_ring->stopped_trb = event_trb; |
| 976 | } else { | 1058 | } else { |
| 977 | /* Update ring dequeue pointer */ | 1059 | if (GET_COMP_CODE(event->transfer_len) == COMP_STALL) { |
| 978 | while (ep_ring->dequeue != td->last_trb) | 1060 | /* The transfer is completed from the driver's |
| 1061 | * perspective, but we need to issue a set dequeue | ||
| 1062 | * command for this stalled endpoint to move the dequeue | ||
| 1063 | * pointer past the TD. We can't do that here because | ||
| 1064 | * the halt condition must be cleared first. | ||
| 1065 | */ | ||
| 1066 | ep_ring->stopped_td = td; | ||
| 1067 | ep_ring->stopped_trb = event_trb; | ||
| 1068 | } else { | ||
| 1069 | /* Update ring dequeue pointer */ | ||
| 1070 | while (ep_ring->dequeue != td->last_trb) | ||
| 1071 | inc_deq(xhci, ep_ring, false); | ||
| 979 | inc_deq(xhci, ep_ring, false); | 1072 | inc_deq(xhci, ep_ring, false); |
| 980 | inc_deq(xhci, ep_ring, false); | 1073 | } |
| 981 | 1074 | ||
| 982 | /* Clean up the endpoint's TD list */ | 1075 | /* Clean up the endpoint's TD list */ |
| 983 | urb = td->urb; | 1076 | urb = td->urb; |
| @@ -987,7 +1080,10 @@ static int handle_tx_event(struct xhci_hcd *xhci, | |||
| 987 | list_del(&td->cancelled_td_list); | 1080 | list_del(&td->cancelled_td_list); |
| 988 | ep_ring->cancels_pending--; | 1081 | ep_ring->cancels_pending--; |
| 989 | } | 1082 | } |
| 990 | kfree(td); | 1083 | /* Leave the TD around for the reset endpoint function to use */ |
| 1084 | if (GET_COMP_CODE(event->transfer_len) != COMP_STALL) { | ||
| 1085 | kfree(td); | ||
| 1086 | } | ||
| 991 | urb->hcpriv = NULL; | 1087 | urb->hcpriv = NULL; |
| 992 | } | 1088 | } |
| 993 | cleanup: | 1089 | cleanup: |
| @@ -997,6 +1093,8 @@ cleanup: | |||
| 997 | /* FIXME for multi-TD URBs (who have buffers bigger than 64MB) */ | 1093 | /* FIXME for multi-TD URBs (who have buffers bigger than 64MB) */ |
| 998 | if (urb) { | 1094 | if (urb) { |
| 999 | usb_hcd_unlink_urb_from_ep(xhci_to_hcd(xhci), urb); | 1095 | usb_hcd_unlink_urb_from_ep(xhci_to_hcd(xhci), urb); |
| 1096 | xhci_dbg(xhci, "Giveback URB %p, len = %d, status = %d\n", | ||
| 1097 | urb, td->urb->actual_length, status); | ||
| 1000 | spin_unlock(&xhci->lock); | 1098 | spin_unlock(&xhci->lock); |
| 1001 | usb_hcd_giveback_urb(xhci_to_hcd(xhci), urb, status); | 1099 | usb_hcd_giveback_urb(xhci_to_hcd(xhci), urb, status); |
| 1002 | spin_lock(&xhci->lock); | 1100 | spin_lock(&xhci->lock); |
| @@ -1014,6 +1112,7 @@ void xhci_handle_event(struct xhci_hcd *xhci) | |||
| 1014 | int update_ptrs = 1; | 1112 | int update_ptrs = 1; |
| 1015 | int ret; | 1113 | int ret; |
| 1016 | 1114 | ||
| 1115 | xhci_dbg(xhci, "In %s\n", __func__); | ||
| 1017 | if (!xhci->event_ring || !xhci->event_ring->dequeue) { | 1116 | if (!xhci->event_ring || !xhci->event_ring->dequeue) { |
| 1018 | xhci->error_bitmask |= 1 << 1; | 1117 | xhci->error_bitmask |= 1 << 1; |
| 1019 | return; | 1118 | return; |
| @@ -1026,18 +1125,25 @@ void xhci_handle_event(struct xhci_hcd *xhci) | |||
| 1026 | xhci->error_bitmask |= 1 << 2; | 1125 | xhci->error_bitmask |= 1 << 2; |
| 1027 | return; | 1126 | return; |
| 1028 | } | 1127 | } |
| 1128 | xhci_dbg(xhci, "%s - OS owns TRB\n", __func__); | ||
| 1029 | 1129 | ||
| 1030 | /* FIXME: Handle more event types. */ | 1130 | /* FIXME: Handle more event types. */ |
| 1031 | switch ((event->event_cmd.flags & TRB_TYPE_BITMASK)) { | 1131 | switch ((event->event_cmd.flags & TRB_TYPE_BITMASK)) { |
| 1032 | case TRB_TYPE(TRB_COMPLETION): | 1132 | case TRB_TYPE(TRB_COMPLETION): |
| 1133 | xhci_dbg(xhci, "%s - calling handle_cmd_completion\n", __func__); | ||
| 1033 | handle_cmd_completion(xhci, &event->event_cmd); | 1134 | handle_cmd_completion(xhci, &event->event_cmd); |
| 1135 | xhci_dbg(xhci, "%s - returned from handle_cmd_completion\n", __func__); | ||
| 1034 | break; | 1136 | break; |
| 1035 | case TRB_TYPE(TRB_PORT_STATUS): | 1137 | case TRB_TYPE(TRB_PORT_STATUS): |
| 1138 | xhci_dbg(xhci, "%s - calling handle_port_status\n", __func__); | ||
| 1036 | handle_port_status(xhci, event); | 1139 | handle_port_status(xhci, event); |
| 1140 | xhci_dbg(xhci, "%s - returned from handle_port_status\n", __func__); | ||
| 1037 | update_ptrs = 0; | 1141 | update_ptrs = 0; |
| 1038 | break; | 1142 | break; |
| 1039 | case TRB_TYPE(TRB_TRANSFER): | 1143 | case TRB_TYPE(TRB_TRANSFER): |
| 1144 | xhci_dbg(xhci, "%s - calling handle_tx_event\n", __func__); | ||
| 1040 | ret = handle_tx_event(xhci, &event->trans_event); | 1145 | ret = handle_tx_event(xhci, &event->trans_event); |
| 1146 | xhci_dbg(xhci, "%s - returned from handle_tx_event\n", __func__); | ||
| 1041 | if (ret < 0) | 1147 | if (ret < 0) |
| 1042 | xhci->error_bitmask |= 1 << 9; | 1148 | xhci->error_bitmask |= 1 << 9; |
| 1043 | else | 1149 | else |
| @@ -1093,13 +1199,13 @@ static int prepare_ring(struct xhci_hcd *xhci, struct xhci_ring *ep_ring, | |||
| 1093 | */ | 1199 | */ |
| 1094 | xhci_warn(xhci, "WARN urb submitted to disabled ep\n"); | 1200 | xhci_warn(xhci, "WARN urb submitted to disabled ep\n"); |
| 1095 | return -ENOENT; | 1201 | return -ENOENT; |
| 1096 | case EP_STATE_HALTED: | ||
| 1097 | case EP_STATE_ERROR: | 1202 | case EP_STATE_ERROR: |
| 1098 | xhci_warn(xhci, "WARN waiting for halt or error on ep " | 1203 | xhci_warn(xhci, "WARN waiting for error on ep to be cleared\n"); |
| 1099 | "to be cleared\n"); | ||
| 1100 | /* FIXME event handling code for error needs to clear it */ | 1204 | /* FIXME event handling code for error needs to clear it */ |
| 1101 | /* XXX not sure if this should be -ENOENT or not */ | 1205 | /* XXX not sure if this should be -ENOENT or not */ |
| 1102 | return -EINVAL; | 1206 | return -EINVAL; |
| 1207 | case EP_STATE_HALTED: | ||
| 1208 | xhci_dbg(xhci, "WARN halted endpoint, queueing URB anyway.\n"); | ||
| 1103 | case EP_STATE_STOPPED: | 1209 | case EP_STATE_STOPPED: |
| 1104 | case EP_STATE_RUNNING: | 1210 | case EP_STATE_RUNNING: |
| 1105 | break; | 1211 | break; |
| @@ -1128,9 +1234,9 @@ static int prepare_transfer(struct xhci_hcd *xhci, | |||
| 1128 | gfp_t mem_flags) | 1234 | gfp_t mem_flags) |
| 1129 | { | 1235 | { |
| 1130 | int ret; | 1236 | int ret; |
| 1131 | 1237 | struct xhci_ep_ctx *ep_ctx = xhci_get_ep_ctx(xhci, xdev->out_ctx, ep_index); | |
| 1132 | ret = prepare_ring(xhci, xdev->ep_rings[ep_index], | 1238 | ret = prepare_ring(xhci, xdev->ep_rings[ep_index], |
| 1133 | xdev->out_ctx->ep[ep_index].ep_info & EP_STATE_MASK, | 1239 | ep_ctx->ep_info & EP_STATE_MASK, |
| 1134 | num_trbs, mem_flags); | 1240 | num_trbs, mem_flags); |
| 1135 | if (ret) | 1241 | if (ret) |
| 1136 | return ret; | 1242 | return ret; |
| @@ -1285,6 +1391,7 @@ static int queue_bulk_sg_tx(struct xhci_hcd *xhci, gfp_t mem_flags, | |||
| 1285 | /* Queue the first TRB, even if it's zero-length */ | 1391 | /* Queue the first TRB, even if it's zero-length */ |
| 1286 | do { | 1392 | do { |
| 1287 | u32 field = 0; | 1393 | u32 field = 0; |
| 1394 | u32 length_field = 0; | ||
| 1288 | 1395 | ||
| 1289 | /* Don't change the cycle bit of the first TRB until later */ | 1396 | /* Don't change the cycle bit of the first TRB until later */ |
| 1290 | if (first_trb) | 1397 | if (first_trb) |
| @@ -1314,10 +1421,13 @@ static int queue_bulk_sg_tx(struct xhci_hcd *xhci, gfp_t mem_flags, | |||
| 1314 | (unsigned int) (addr + TRB_MAX_BUFF_SIZE) & ~(TRB_MAX_BUFF_SIZE - 1), | 1421 | (unsigned int) (addr + TRB_MAX_BUFF_SIZE) & ~(TRB_MAX_BUFF_SIZE - 1), |
| 1315 | (unsigned int) addr + trb_buff_len); | 1422 | (unsigned int) addr + trb_buff_len); |
| 1316 | } | 1423 | } |
| 1424 | length_field = TRB_LEN(trb_buff_len) | | ||
| 1425 | TD_REMAINDER(urb->transfer_buffer_length - running_total) | | ||
| 1426 | TRB_INTR_TARGET(0); | ||
| 1317 | queue_trb(xhci, ep_ring, false, | 1427 | queue_trb(xhci, ep_ring, false, |
| 1318 | (u32) addr, | 1428 | lower_32_bits(addr), |
| 1319 | (u32) ((u64) addr >> 32), | 1429 | upper_32_bits(addr), |
| 1320 | TRB_LEN(trb_buff_len) | TRB_INTR_TARGET(0), | 1430 | length_field, |
| 1321 | /* We always want to know if the TRB was short, | 1431 | /* We always want to know if the TRB was short, |
| 1322 | * or we won't get an event when it completes. | 1432 | * or we won't get an event when it completes. |
| 1323 | * (Unless we use event data TRBs, which are a | 1433 | * (Unless we use event data TRBs, which are a |
| @@ -1365,7 +1475,7 @@ int xhci_queue_bulk_tx(struct xhci_hcd *xhci, gfp_t mem_flags, | |||
| 1365 | struct xhci_generic_trb *start_trb; | 1475 | struct xhci_generic_trb *start_trb; |
| 1366 | bool first_trb; | 1476 | bool first_trb; |
| 1367 | int start_cycle; | 1477 | int start_cycle; |
| 1368 | u32 field; | 1478 | u32 field, length_field; |
| 1369 | 1479 | ||
| 1370 | int running_total, trb_buff_len, ret; | 1480 | int running_total, trb_buff_len, ret; |
| 1371 | u64 addr; | 1481 | u64 addr; |
| @@ -1443,10 +1553,13 @@ int xhci_queue_bulk_tx(struct xhci_hcd *xhci, gfp_t mem_flags, | |||
| 1443 | td->last_trb = ep_ring->enqueue; | 1553 | td->last_trb = ep_ring->enqueue; |
| 1444 | field |= TRB_IOC; | 1554 | field |= TRB_IOC; |
| 1445 | } | 1555 | } |
| 1556 | length_field = TRB_LEN(trb_buff_len) | | ||
| 1557 | TD_REMAINDER(urb->transfer_buffer_length - running_total) | | ||
| 1558 | TRB_INTR_TARGET(0); | ||
| 1446 | queue_trb(xhci, ep_ring, false, | 1559 | queue_trb(xhci, ep_ring, false, |
| 1447 | (u32) addr, | 1560 | lower_32_bits(addr), |
| 1448 | (u32) ((u64) addr >> 32), | 1561 | upper_32_bits(addr), |
| 1449 | TRB_LEN(trb_buff_len) | TRB_INTR_TARGET(0), | 1562 | length_field, |
| 1450 | /* We always want to know if the TRB was short, | 1563 | /* We always want to know if the TRB was short, |
| 1451 | * or we won't get an event when it completes. | 1564 | * or we won't get an event when it completes. |
| 1452 | * (Unless we use event data TRBs, which are a | 1565 | * (Unless we use event data TRBs, which are a |
| @@ -1478,7 +1591,7 @@ int xhci_queue_ctrl_tx(struct xhci_hcd *xhci, gfp_t mem_flags, | |||
| 1478 | struct usb_ctrlrequest *setup; | 1591 | struct usb_ctrlrequest *setup; |
| 1479 | struct xhci_generic_trb *start_trb; | 1592 | struct xhci_generic_trb *start_trb; |
| 1480 | int start_cycle; | 1593 | int start_cycle; |
| 1481 | u32 field; | 1594 | u32 field, length_field; |
| 1482 | struct xhci_td *td; | 1595 | struct xhci_td *td; |
| 1483 | 1596 | ||
| 1484 | ep_ring = xhci->devs[slot_id]->ep_rings[ep_index]; | 1597 | ep_ring = xhci->devs[slot_id]->ep_rings[ep_index]; |
| @@ -1528,13 +1641,16 @@ int xhci_queue_ctrl_tx(struct xhci_hcd *xhci, gfp_t mem_flags, | |||
| 1528 | 1641 | ||
| 1529 | /* If there's data, queue data TRBs */ | 1642 | /* If there's data, queue data TRBs */ |
| 1530 | field = 0; | 1643 | field = 0; |
| 1644 | length_field = TRB_LEN(urb->transfer_buffer_length) | | ||
| 1645 | TD_REMAINDER(urb->transfer_buffer_length) | | ||
| 1646 | TRB_INTR_TARGET(0); | ||
| 1531 | if (urb->transfer_buffer_length > 0) { | 1647 | if (urb->transfer_buffer_length > 0) { |
| 1532 | if (setup->bRequestType & USB_DIR_IN) | 1648 | if (setup->bRequestType & USB_DIR_IN) |
| 1533 | field |= TRB_DIR_IN; | 1649 | field |= TRB_DIR_IN; |
| 1534 | queue_trb(xhci, ep_ring, false, | 1650 | queue_trb(xhci, ep_ring, false, |
| 1535 | lower_32_bits(urb->transfer_dma), | 1651 | lower_32_bits(urb->transfer_dma), |
| 1536 | upper_32_bits(urb->transfer_dma), | 1652 | upper_32_bits(urb->transfer_dma), |
| 1537 | TRB_LEN(urb->transfer_buffer_length) | TRB_INTR_TARGET(0), | 1653 | length_field, |
| 1538 | /* Event on short tx */ | 1654 | /* Event on short tx */ |
| 1539 | field | TRB_ISP | TRB_TYPE(TRB_DATA) | ep_ring->cycle_state); | 1655 | field | TRB_ISP | TRB_TYPE(TRB_DATA) | ep_ring->cycle_state); |
| 1540 | } | 1656 | } |
| @@ -1603,7 +1719,8 @@ int xhci_queue_slot_control(struct xhci_hcd *xhci, u32 trb_type, u32 slot_id) | |||
| 1603 | int xhci_queue_address_device(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr, | 1719 | int xhci_queue_address_device(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr, |
| 1604 | u32 slot_id) | 1720 | u32 slot_id) |
| 1605 | { | 1721 | { |
| 1606 | return queue_command(xhci, in_ctx_ptr, 0, 0, | 1722 | return queue_command(xhci, lower_32_bits(in_ctx_ptr), |
| 1723 | upper_32_bits(in_ctx_ptr), 0, | ||
| 1607 | TRB_TYPE(TRB_ADDR_DEV) | SLOT_ID_FOR_TRB(slot_id)); | 1724 | TRB_TYPE(TRB_ADDR_DEV) | SLOT_ID_FOR_TRB(slot_id)); |
| 1608 | } | 1725 | } |
| 1609 | 1726 | ||
| @@ -1611,7 +1728,8 @@ int xhci_queue_address_device(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr, | |||
| 1611 | int xhci_queue_configure_endpoint(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr, | 1728 | int xhci_queue_configure_endpoint(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr, |
| 1612 | u32 slot_id) | 1729 | u32 slot_id) |
| 1613 | { | 1730 | { |
| 1614 | return queue_command(xhci, in_ctx_ptr, 0, 0, | 1731 | return queue_command(xhci, lower_32_bits(in_ctx_ptr), |
| 1732 | upper_32_bits(in_ctx_ptr), 0, | ||
| 1615 | TRB_TYPE(TRB_CONFIG_EP) | SLOT_ID_FOR_TRB(slot_id)); | 1733 | TRB_TYPE(TRB_CONFIG_EP) | SLOT_ID_FOR_TRB(slot_id)); |
| 1616 | } | 1734 | } |
| 1617 | 1735 | ||
| @@ -1639,10 +1757,23 @@ static int queue_set_tr_deq(struct xhci_hcd *xhci, int slot_id, | |||
| 1639 | u32 type = TRB_TYPE(TRB_SET_DEQ); | 1757 | u32 type = TRB_TYPE(TRB_SET_DEQ); |
| 1640 | 1758 | ||
| 1641 | addr = xhci_trb_virt_to_dma(deq_seg, deq_ptr); | 1759 | addr = xhci_trb_virt_to_dma(deq_seg, deq_ptr); |
| 1642 | if (addr == 0) | 1760 | if (addr == 0) { |
| 1643 | xhci_warn(xhci, "WARN Cannot submit Set TR Deq Ptr\n"); | 1761 | xhci_warn(xhci, "WARN Cannot submit Set TR Deq Ptr\n"); |
| 1644 | xhci_warn(xhci, "WARN deq seg = %p, deq pt = %p\n", | 1762 | xhci_warn(xhci, "WARN deq seg = %p, deq pt = %p\n", |
| 1645 | deq_seg, deq_ptr); | 1763 | deq_seg, deq_ptr); |
| 1646 | return queue_command(xhci, (u32) addr | cycle_state, 0, 0, | 1764 | return 0; |
| 1765 | } | ||
| 1766 | return queue_command(xhci, lower_32_bits(addr) | cycle_state, | ||
| 1767 | upper_32_bits(addr), 0, | ||
| 1647 | trb_slot_id | trb_ep_index | type); | 1768 | trb_slot_id | trb_ep_index | type); |
| 1648 | } | 1769 | } |
| 1770 | |||
| 1771 | int xhci_queue_reset_ep(struct xhci_hcd *xhci, int slot_id, | ||
| 1772 | unsigned int ep_index) | ||
| 1773 | { | ||
| 1774 | u32 trb_slot_id = SLOT_ID_FOR_TRB(slot_id); | ||
| 1775 | u32 trb_ep_index = EP_ID_FOR_TRB(ep_index); | ||
| 1776 | u32 type = TRB_TYPE(TRB_RESET_EP); | ||
| 1777 | |||
| 1778 | return queue_command(xhci, 0, 0, 0, trb_slot_id | trb_ep_index | type); | ||
| 1779 | } | ||
diff --git a/drivers/usb/host/xhci.h b/drivers/usb/host/xhci.h index 8936eeb5588b..d31d32206ba3 100644 --- a/drivers/usb/host/xhci.h +++ b/drivers/usb/host/xhci.h | |||
| @@ -25,6 +25,7 @@ | |||
| 25 | 25 | ||
| 26 | #include <linux/usb.h> | 26 | #include <linux/usb.h> |
| 27 | #include <linux/timer.h> | 27 | #include <linux/timer.h> |
| 28 | #include <linux/kernel.h> | ||
| 28 | 29 | ||
| 29 | #include "../core/hcd.h" | 30 | #include "../core/hcd.h" |
| 30 | /* Code sharing between pci-quirks and xhci hcd */ | 31 | /* Code sharing between pci-quirks and xhci hcd */ |
| @@ -42,14 +43,6 @@ | |||
| 42 | * xHCI register interface. | 43 | * xHCI register interface. |
| 43 | * This corresponds to the eXtensible Host Controller Interface (xHCI) | 44 | * This corresponds to the eXtensible Host Controller Interface (xHCI) |
| 44 | * Revision 0.95 specification | 45 | * Revision 0.95 specification |
| 45 | * | ||
| 46 | * Registers should always be accessed with double word or quad word accesses. | ||
| 47 | * | ||
| 48 | * Some xHCI implementations may support 64-bit address pointers. Registers | ||
| 49 | * with 64-bit address pointers should be written to with dword accesses by | ||
| 50 | * writing the low dword first (ptr[0]), then the high dword (ptr[1]) second. | ||
| 51 | * xHCI implementations that do not support 64-bit address pointers will ignore | ||
| 52 | * the high dword, and write order is irrelevant. | ||
| 53 | */ | 46 | */ |
| 54 | 47 | ||
| 55 | /** | 48 | /** |
| @@ -96,6 +89,7 @@ struct xhci_cap_regs { | |||
| 96 | #define HCS_ERST_MAX(p) (((p) >> 4) & 0xf) | 89 | #define HCS_ERST_MAX(p) (((p) >> 4) & 0xf) |
| 97 | /* bit 26 Scratchpad restore - for save/restore HW state - not used yet */ | 90 | /* bit 26 Scratchpad restore - for save/restore HW state - not used yet */ |
| 98 | /* bits 27:31 number of Scratchpad buffers SW must allocate for the HW */ | 91 | /* bits 27:31 number of Scratchpad buffers SW must allocate for the HW */ |
| 92 | #define HCS_MAX_SCRATCHPAD(p) (((p) >> 27) & 0x1f) | ||
| 99 | 93 | ||
| 100 | /* HCSPARAMS3 - hcs_params3 - bitmasks */ | 94 | /* HCSPARAMS3 - hcs_params3 - bitmasks */ |
| 101 | /* bits 0:7, Max U1 to U0 latency for the roothub ports */ | 95 | /* bits 0:7, Max U1 to U0 latency for the roothub ports */ |
| @@ -166,10 +160,10 @@ struct xhci_op_regs { | |||
| 166 | u32 reserved1; | 160 | u32 reserved1; |
| 167 | u32 reserved2; | 161 | u32 reserved2; |
| 168 | u32 dev_notification; | 162 | u32 dev_notification; |
| 169 | u32 cmd_ring[2]; | 163 | u64 cmd_ring; |
| 170 | /* rsvd: offset 0x20-2F */ | 164 | /* rsvd: offset 0x20-2F */ |
| 171 | u32 reserved3[4]; | 165 | u32 reserved3[4]; |
| 172 | u32 dcbaa_ptr[2]; | 166 | u64 dcbaa_ptr; |
| 173 | u32 config_reg; | 167 | u32 config_reg; |
| 174 | /* rsvd: offset 0x3C-3FF */ | 168 | /* rsvd: offset 0x3C-3FF */ |
| 175 | u32 reserved4[241]; | 169 | u32 reserved4[241]; |
| @@ -254,7 +248,7 @@ struct xhci_op_regs { | |||
| 254 | #define CMD_RING_RUNNING (1 << 3) | 248 | #define CMD_RING_RUNNING (1 << 3) |
| 255 | /* bits 4:5 reserved and should be preserved */ | 249 | /* bits 4:5 reserved and should be preserved */ |
| 256 | /* Command Ring pointer - bit mask for the lower 32 bits. */ | 250 | /* Command Ring pointer - bit mask for the lower 32 bits. */ |
| 257 | #define CMD_RING_ADDR_MASK (0xffffffc0) | 251 | #define CMD_RING_RSVD_BITS (0x3f) |
| 258 | 252 | ||
| 259 | /* CONFIG - Configure Register - config_reg bitmasks */ | 253 | /* CONFIG - Configure Register - config_reg bitmasks */ |
| 260 | /* bits 0:7 - maximum number of device slots enabled (NumSlotsEn) */ | 254 | /* bits 0:7 - maximum number of device slots enabled (NumSlotsEn) */ |
| @@ -382,8 +376,8 @@ struct xhci_intr_reg { | |||
| 382 | u32 irq_control; | 376 | u32 irq_control; |
| 383 | u32 erst_size; | 377 | u32 erst_size; |
| 384 | u32 rsvd; | 378 | u32 rsvd; |
| 385 | u32 erst_base[2]; | 379 | u64 erst_base; |
| 386 | u32 erst_dequeue[2]; | 380 | u64 erst_dequeue; |
| 387 | }; | 381 | }; |
| 388 | 382 | ||
| 389 | /* irq_pending bitmasks */ | 383 | /* irq_pending bitmasks */ |
| @@ -453,6 +447,27 @@ struct xhci_doorbell_array { | |||
| 453 | 447 | ||
| 454 | 448 | ||
| 455 | /** | 449 | /** |
| 450 | * struct xhci_container_ctx | ||
| 451 | * @type: Type of context. Used to calculated offsets to contained contexts. | ||
| 452 | * @size: Size of the context data | ||
| 453 | * @bytes: The raw context data given to HW | ||
| 454 | * @dma: dma address of the bytes | ||
| 455 | * | ||
| 456 | * Represents either a Device or Input context. Holds a pointer to the raw | ||
| 457 | * memory used for the context (bytes) and dma address of it (dma). | ||
| 458 | */ | ||
| 459 | struct xhci_container_ctx { | ||
| 460 | unsigned type; | ||
| 461 | #define XHCI_CTX_TYPE_DEVICE 0x1 | ||
| 462 | #define XHCI_CTX_TYPE_INPUT 0x2 | ||
| 463 | |||
| 464 | int size; | ||
| 465 | |||
| 466 | u8 *bytes; | ||
| 467 | dma_addr_t dma; | ||
| 468 | }; | ||
| 469 | |||
| 470 | /** | ||
| 456 | * struct xhci_slot_ctx | 471 | * struct xhci_slot_ctx |
| 457 | * @dev_info: Route string, device speed, hub info, and last valid endpoint | 472 | * @dev_info: Route string, device speed, hub info, and last valid endpoint |
| 458 | * @dev_info2: Max exit latency for device number, root hub port number | 473 | * @dev_info2: Max exit latency for device number, root hub port number |
| @@ -538,7 +553,7 @@ struct xhci_slot_ctx { | |||
| 538 | struct xhci_ep_ctx { | 553 | struct xhci_ep_ctx { |
| 539 | u32 ep_info; | 554 | u32 ep_info; |
| 540 | u32 ep_info2; | 555 | u32 ep_info2; |
| 541 | u32 deq[2]; | 556 | u64 deq; |
| 542 | u32 tx_info; | 557 | u32 tx_info; |
| 543 | /* offset 0x14 - 0x1f reserved for HC internal use */ | 558 | /* offset 0x14 - 0x1f reserved for HC internal use */ |
| 544 | u32 reserved[3]; | 559 | u32 reserved[3]; |
| @@ -589,18 +604,16 @@ struct xhci_ep_ctx { | |||
| 589 | 604 | ||
| 590 | 605 | ||
| 591 | /** | 606 | /** |
| 592 | * struct xhci_device_control | 607 | * struct xhci_input_control_context |
| 593 | * Input/Output context; see section 6.2.5. | 608 | * Input control context; see section 6.2.5. |
| 594 | * | 609 | * |
| 595 | * @drop_context: set the bit of the endpoint context you want to disable | 610 | * @drop_context: set the bit of the endpoint context you want to disable |
| 596 | * @add_context: set the bit of the endpoint context you want to enable | 611 | * @add_context: set the bit of the endpoint context you want to enable |
| 597 | */ | 612 | */ |
| 598 | struct xhci_device_control { | 613 | struct xhci_input_control_ctx { |
| 599 | u32 drop_flags; | 614 | u32 drop_flags; |
| 600 | u32 add_flags; | 615 | u32 add_flags; |
| 601 | u32 rsvd[6]; | 616 | u32 rsvd2[6]; |
| 602 | struct xhci_slot_ctx slot; | ||
| 603 | struct xhci_ep_ctx ep[31]; | ||
| 604 | }; | 617 | }; |
| 605 | 618 | ||
| 606 | /* drop context bitmasks */ | 619 | /* drop context bitmasks */ |
| @@ -608,7 +621,6 @@ struct xhci_device_control { | |||
| 608 | /* add context bitmasks */ | 621 | /* add context bitmasks */ |
| 609 | #define ADD_EP(x) (0x1 << x) | 622 | #define ADD_EP(x) (0x1 << x) |
| 610 | 623 | ||
| 611 | |||
| 612 | struct xhci_virt_device { | 624 | struct xhci_virt_device { |
| 613 | /* | 625 | /* |
| 614 | * Commands to the hardware are passed an "input context" that | 626 | * Commands to the hardware are passed an "input context" that |
| @@ -618,11 +630,10 @@ struct xhci_virt_device { | |||
| 618 | * track of input and output contexts separately because | 630 | * track of input and output contexts separately because |
| 619 | * these commands might fail and we don't trust the hardware. | 631 | * these commands might fail and we don't trust the hardware. |
| 620 | */ | 632 | */ |
| 621 | struct xhci_device_control *out_ctx; | 633 | struct xhci_container_ctx *out_ctx; |
| 622 | dma_addr_t out_ctx_dma; | ||
| 623 | /* Used for addressing devices and configuration changes */ | 634 | /* Used for addressing devices and configuration changes */ |
| 624 | struct xhci_device_control *in_ctx; | 635 | struct xhci_container_ctx *in_ctx; |
| 625 | dma_addr_t in_ctx_dma; | 636 | |
| 626 | /* FIXME when stream support is added */ | 637 | /* FIXME when stream support is added */ |
| 627 | struct xhci_ring *ep_rings[31]; | 638 | struct xhci_ring *ep_rings[31]; |
| 628 | /* Temporary storage in case the configure endpoint command fails and we | 639 | /* Temporary storage in case the configure endpoint command fails and we |
| @@ -641,7 +652,7 @@ struct xhci_virt_device { | |||
| 641 | */ | 652 | */ |
| 642 | struct xhci_device_context_array { | 653 | struct xhci_device_context_array { |
| 643 | /* 64-bit device addresses; we only write 32-bit addresses */ | 654 | /* 64-bit device addresses; we only write 32-bit addresses */ |
| 644 | u32 dev_context_ptrs[2*MAX_HC_SLOTS]; | 655 | u64 dev_context_ptrs[MAX_HC_SLOTS]; |
| 645 | /* private xHCD pointers */ | 656 | /* private xHCD pointers */ |
| 646 | dma_addr_t dma; | 657 | dma_addr_t dma; |
| 647 | }; | 658 | }; |
| @@ -654,7 +665,7 @@ struct xhci_device_context_array { | |||
| 654 | 665 | ||
| 655 | struct xhci_stream_ctx { | 666 | struct xhci_stream_ctx { |
| 656 | /* 64-bit stream ring address, cycle state, and stream type */ | 667 | /* 64-bit stream ring address, cycle state, and stream type */ |
| 657 | u32 stream_ring[2]; | 668 | u64 stream_ring; |
| 658 | /* offset 0x14 - 0x1f reserved for HC internal use */ | 669 | /* offset 0x14 - 0x1f reserved for HC internal use */ |
| 659 | u32 reserved[2]; | 670 | u32 reserved[2]; |
| 660 | }; | 671 | }; |
| @@ -662,7 +673,7 @@ struct xhci_stream_ctx { | |||
| 662 | 673 | ||
| 663 | struct xhci_transfer_event { | 674 | struct xhci_transfer_event { |
| 664 | /* 64-bit buffer address, or immediate data */ | 675 | /* 64-bit buffer address, or immediate data */ |
| 665 | u32 buffer[2]; | 676 | u64 buffer; |
| 666 | u32 transfer_len; | 677 | u32 transfer_len; |
| 667 | /* This field is interpreted differently based on the type of TRB */ | 678 | /* This field is interpreted differently based on the type of TRB */ |
| 668 | u32 flags; | 679 | u32 flags; |
| @@ -744,7 +755,7 @@ struct xhci_transfer_event { | |||
| 744 | 755 | ||
| 745 | struct xhci_link_trb { | 756 | struct xhci_link_trb { |
| 746 | /* 64-bit segment pointer*/ | 757 | /* 64-bit segment pointer*/ |
| 747 | u32 segment_ptr[2]; | 758 | u64 segment_ptr; |
| 748 | u32 intr_target; | 759 | u32 intr_target; |
| 749 | u32 control; | 760 | u32 control; |
| 750 | }; | 761 | }; |
| @@ -755,7 +766,7 @@ struct xhci_link_trb { | |||
| 755 | /* Command completion event TRB */ | 766 | /* Command completion event TRB */ |
| 756 | struct xhci_event_cmd { | 767 | struct xhci_event_cmd { |
| 757 | /* Pointer to command TRB, or the value passed by the event data trb */ | 768 | /* Pointer to command TRB, or the value passed by the event data trb */ |
| 758 | u32 cmd_trb[2]; | 769 | u64 cmd_trb; |
| 759 | u32 status; | 770 | u32 status; |
| 760 | u32 flags; | 771 | u32 flags; |
| 761 | }; | 772 | }; |
| @@ -848,8 +859,8 @@ union xhci_trb { | |||
| 848 | #define TRB_CONFIG_EP 12 | 859 | #define TRB_CONFIG_EP 12 |
| 849 | /* Evaluate Context Command */ | 860 | /* Evaluate Context Command */ |
| 850 | #define TRB_EVAL_CONTEXT 13 | 861 | #define TRB_EVAL_CONTEXT 13 |
| 851 | /* Reset Transfer Ring Command */ | 862 | /* Reset Endpoint Command */ |
| 852 | #define TRB_RESET_RING 14 | 863 | #define TRB_RESET_EP 14 |
| 853 | /* Stop Transfer Ring Command */ | 864 | /* Stop Transfer Ring Command */ |
| 854 | #define TRB_STOP_RING 15 | 865 | #define TRB_STOP_RING 15 |
| 855 | /* Set Transfer Ring Dequeue Pointer Command */ | 866 | /* Set Transfer Ring Dequeue Pointer Command */ |
| @@ -929,6 +940,7 @@ struct xhci_ring { | |||
| 929 | unsigned int cancels_pending; | 940 | unsigned int cancels_pending; |
| 930 | unsigned int state; | 941 | unsigned int state; |
| 931 | #define SET_DEQ_PENDING (1 << 0) | 942 | #define SET_DEQ_PENDING (1 << 0) |
| 943 | #define EP_HALTED (1 << 1) | ||
| 932 | /* The TRB that was last reported in a stopped endpoint ring */ | 944 | /* The TRB that was last reported in a stopped endpoint ring */ |
| 933 | union xhci_trb *stopped_trb; | 945 | union xhci_trb *stopped_trb; |
| 934 | struct xhci_td *stopped_td; | 946 | struct xhci_td *stopped_td; |
| @@ -940,9 +952,15 @@ struct xhci_ring { | |||
| 940 | u32 cycle_state; | 952 | u32 cycle_state; |
| 941 | }; | 953 | }; |
| 942 | 954 | ||
| 955 | struct xhci_dequeue_state { | ||
| 956 | struct xhci_segment *new_deq_seg; | ||
| 957 | union xhci_trb *new_deq_ptr; | ||
| 958 | int new_cycle_state; | ||
| 959 | }; | ||
| 960 | |||
| 943 | struct xhci_erst_entry { | 961 | struct xhci_erst_entry { |
| 944 | /* 64-bit event ring segment address */ | 962 | /* 64-bit event ring segment address */ |
| 945 | u32 seg_addr[2]; | 963 | u64 seg_addr; |
| 946 | u32 seg_size; | 964 | u32 seg_size; |
| 947 | /* Set to zero */ | 965 | /* Set to zero */ |
| 948 | u32 rsvd; | 966 | u32 rsvd; |
| @@ -957,6 +975,13 @@ struct xhci_erst { | |||
| 957 | unsigned int erst_size; | 975 | unsigned int erst_size; |
| 958 | }; | 976 | }; |
| 959 | 977 | ||
| 978 | struct xhci_scratchpad { | ||
| 979 | u64 *sp_array; | ||
| 980 | dma_addr_t sp_dma; | ||
| 981 | void **sp_buffers; | ||
| 982 | dma_addr_t *sp_dma_buffers; | ||
| 983 | }; | ||
| 984 | |||
| 960 | /* | 985 | /* |
| 961 | * Each segment table entry is 4*32bits long. 1K seems like an ok size: | 986 | * Each segment table entry is 4*32bits long. 1K seems like an ok size: |
| 962 | * (1K bytes * 8bytes/bit) / (4*32 bits) = 64 segment entries in the table, | 987 | * (1K bytes * 8bytes/bit) / (4*32 bits) = 64 segment entries in the table, |
| @@ -1011,6 +1036,9 @@ struct xhci_hcd { | |||
| 1011 | struct xhci_ring *cmd_ring; | 1036 | struct xhci_ring *cmd_ring; |
| 1012 | struct xhci_ring *event_ring; | 1037 | struct xhci_ring *event_ring; |
| 1013 | struct xhci_erst erst; | 1038 | struct xhci_erst erst; |
| 1039 | /* Scratchpad */ | ||
| 1040 | struct xhci_scratchpad *scratchpad; | ||
| 1041 | |||
| 1014 | /* slot enabling and address device helpers */ | 1042 | /* slot enabling and address device helpers */ |
| 1015 | struct completion addr_dev; | 1043 | struct completion addr_dev; |
| 1016 | int slot_id; | 1044 | int slot_id; |
| @@ -1071,13 +1099,43 @@ static inline unsigned int xhci_readl(const struct xhci_hcd *xhci, | |||
| 1071 | static inline void xhci_writel(struct xhci_hcd *xhci, | 1099 | static inline void xhci_writel(struct xhci_hcd *xhci, |
| 1072 | const unsigned int val, __u32 __iomem *regs) | 1100 | const unsigned int val, __u32 __iomem *regs) |
| 1073 | { | 1101 | { |
| 1074 | if (!in_interrupt()) | 1102 | xhci_dbg(xhci, |
| 1075 | xhci_dbg(xhci, | 1103 | "`MEM_WRITE_DWORD(3'b000, 32'h%p, 32'h%0x, 4'hf);\n", |
| 1076 | "`MEM_WRITE_DWORD(3'b000, 32'h%p, 32'h%0x, 4'hf);\n", | 1104 | regs, val); |
| 1077 | regs, val); | ||
| 1078 | writel(val, regs); | 1105 | writel(val, regs); |
| 1079 | } | 1106 | } |
| 1080 | 1107 | ||
| 1108 | /* | ||
| 1109 | * Registers should always be accessed with double word or quad word accesses. | ||
| 1110 | * | ||
| 1111 | * Some xHCI implementations may support 64-bit address pointers. Registers | ||
| 1112 | * with 64-bit address pointers should be written to with dword accesses by | ||
| 1113 | * writing the low dword first (ptr[0]), then the high dword (ptr[1]) second. | ||
| 1114 | * xHCI implementations that do not support 64-bit address pointers will ignore | ||
| 1115 | * the high dword, and write order is irrelevant. | ||
| 1116 | */ | ||
| 1117 | static inline u64 xhci_read_64(const struct xhci_hcd *xhci, | ||
| 1118 | __u64 __iomem *regs) | ||
| 1119 | { | ||
| 1120 | __u32 __iomem *ptr = (__u32 __iomem *) regs; | ||
| 1121 | u64 val_lo = readl(ptr); | ||
| 1122 | u64 val_hi = readl(ptr + 1); | ||
| 1123 | return val_lo + (val_hi << 32); | ||
| 1124 | } | ||
| 1125 | static inline void xhci_write_64(struct xhci_hcd *xhci, | ||
| 1126 | const u64 val, __u64 __iomem *regs) | ||
| 1127 | { | ||
| 1128 | __u32 __iomem *ptr = (__u32 __iomem *) regs; | ||
| 1129 | u32 val_lo = lower_32_bits(val); | ||
| 1130 | u32 val_hi = upper_32_bits(val); | ||
| 1131 | |||
| 1132 | xhci_dbg(xhci, | ||
| 1133 | "`MEM_WRITE_DWORD(3'b000, 64'h%p, 64'h%0lx, 4'hf);\n", | ||
| 1134 | regs, (long unsigned int) val); | ||
| 1135 | writel(val_lo, ptr); | ||
| 1136 | writel(val_hi, ptr + 1); | ||
| 1137 | } | ||
| 1138 | |||
| 1081 | /* xHCI debugging */ | 1139 | /* xHCI debugging */ |
| 1082 | void xhci_print_ir_set(struct xhci_hcd *xhci, struct xhci_intr_reg *ir_set, int set_num); | 1140 | void xhci_print_ir_set(struct xhci_hcd *xhci, struct xhci_intr_reg *ir_set, int set_num); |
| 1083 | void xhci_print_registers(struct xhci_hcd *xhci); | 1141 | void xhci_print_registers(struct xhci_hcd *xhci); |
| @@ -1090,7 +1148,7 @@ void xhci_debug_ring(struct xhci_hcd *xhci, struct xhci_ring *ring); | |||
| 1090 | void xhci_dbg_erst(struct xhci_hcd *xhci, struct xhci_erst *erst); | 1148 | void xhci_dbg_erst(struct xhci_hcd *xhci, struct xhci_erst *erst); |
| 1091 | void xhci_dbg_cmd_ptrs(struct xhci_hcd *xhci); | 1149 | void xhci_dbg_cmd_ptrs(struct xhci_hcd *xhci); |
| 1092 | void xhci_dbg_ring_ptrs(struct xhci_hcd *xhci, struct xhci_ring *ring); | 1150 | void xhci_dbg_ring_ptrs(struct xhci_hcd *xhci, struct xhci_ring *ring); |
| 1093 | void xhci_dbg_ctx(struct xhci_hcd *xhci, struct xhci_device_control *ctx, dma_addr_t dma, unsigned int last_ep); | 1151 | void xhci_dbg_ctx(struct xhci_hcd *xhci, struct xhci_container_ctx *ctx, unsigned int last_ep); |
| 1094 | 1152 | ||
| 1095 | /* xHCI memory managment */ | 1153 | /* xHCI memory managment */ |
| 1096 | void xhci_mem_cleanup(struct xhci_hcd *xhci); | 1154 | void xhci_mem_cleanup(struct xhci_hcd *xhci); |
| @@ -1128,6 +1186,7 @@ int xhci_urb_enqueue(struct usb_hcd *hcd, struct urb *urb, gfp_t mem_flags); | |||
| 1128 | int xhci_urb_dequeue(struct usb_hcd *hcd, struct urb *urb, int status); | 1186 | int xhci_urb_dequeue(struct usb_hcd *hcd, struct urb *urb, int status); |
| 1129 | int xhci_add_endpoint(struct usb_hcd *hcd, struct usb_device *udev, struct usb_host_endpoint *ep); | 1187 | int xhci_add_endpoint(struct usb_hcd *hcd, struct usb_device *udev, struct usb_host_endpoint *ep); |
| 1130 | int xhci_drop_endpoint(struct usb_hcd *hcd, struct usb_device *udev, struct usb_host_endpoint *ep); | 1188 | int xhci_drop_endpoint(struct usb_hcd *hcd, struct usb_device *udev, struct usb_host_endpoint *ep); |
| 1189 | void xhci_endpoint_reset(struct usb_hcd *hcd, struct usb_host_endpoint *ep); | ||
| 1131 | int xhci_check_bandwidth(struct usb_hcd *hcd, struct usb_device *udev); | 1190 | int xhci_check_bandwidth(struct usb_hcd *hcd, struct usb_device *udev); |
| 1132 | void xhci_reset_bandwidth(struct usb_hcd *hcd, struct usb_device *udev); | 1191 | void xhci_reset_bandwidth(struct usb_hcd *hcd, struct usb_device *udev); |
| 1133 | 1192 | ||
| @@ -1148,10 +1207,23 @@ int xhci_queue_bulk_tx(struct xhci_hcd *xhci, gfp_t mem_flags, struct urb *urb, | |||
| 1148 | int slot_id, unsigned int ep_index); | 1207 | int slot_id, unsigned int ep_index); |
| 1149 | int xhci_queue_configure_endpoint(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr, | 1208 | int xhci_queue_configure_endpoint(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr, |
| 1150 | u32 slot_id); | 1209 | u32 slot_id); |
| 1210 | int xhci_queue_reset_ep(struct xhci_hcd *xhci, int slot_id, | ||
| 1211 | unsigned int ep_index); | ||
| 1212 | void xhci_find_new_dequeue_state(struct xhci_hcd *xhci, | ||
| 1213 | unsigned int slot_id, unsigned int ep_index, | ||
| 1214 | struct xhci_td *cur_td, struct xhci_dequeue_state *state); | ||
| 1215 | void xhci_queue_new_dequeue_state(struct xhci_hcd *xhci, | ||
| 1216 | struct xhci_ring *ep_ring, unsigned int slot_id, | ||
| 1217 | unsigned int ep_index, struct xhci_dequeue_state *deq_state); | ||
| 1151 | 1218 | ||
| 1152 | /* xHCI roothub code */ | 1219 | /* xHCI roothub code */ |
| 1153 | int xhci_hub_control(struct usb_hcd *hcd, u16 typeReq, u16 wValue, u16 wIndex, | 1220 | int xhci_hub_control(struct usb_hcd *hcd, u16 typeReq, u16 wValue, u16 wIndex, |
| 1154 | char *buf, u16 wLength); | 1221 | char *buf, u16 wLength); |
| 1155 | int xhci_hub_status_data(struct usb_hcd *hcd, char *buf); | 1222 | int xhci_hub_status_data(struct usb_hcd *hcd, char *buf); |
| 1156 | 1223 | ||
| 1224 | /* xHCI contexts */ | ||
| 1225 | struct xhci_input_control_ctx *xhci_get_input_control_ctx(struct xhci_hcd *xhci, struct xhci_container_ctx *ctx); | ||
| 1226 | struct xhci_slot_ctx *xhci_get_slot_ctx(struct xhci_hcd *xhci, struct xhci_container_ctx *ctx); | ||
| 1227 | struct xhci_ep_ctx *xhci_get_ep_ctx(struct xhci_hcd *xhci, struct xhci_container_ctx *ctx, unsigned int ep_index); | ||
| 1228 | |||
| 1157 | #endif /* __LINUX_XHCI_HCD_H */ | 1229 | #endif /* __LINUX_XHCI_HCD_H */ |
diff --git a/drivers/usb/misc/Kconfig b/drivers/usb/misc/Kconfig index a68d91a11bee..abe3aa67ed00 100644 --- a/drivers/usb/misc/Kconfig +++ b/drivers/usb/misc/Kconfig | |||
| @@ -220,7 +220,7 @@ config USB_IOWARRIOR | |||
| 220 | 220 | ||
| 221 | config USB_TEST | 221 | config USB_TEST |
| 222 | tristate "USB testing driver" | 222 | tristate "USB testing driver" |
| 223 | depends on USB && USB_DEVICEFS | 223 | depends on USB |
| 224 | help | 224 | help |
| 225 | This driver is for testing host controller software. It is used | 225 | This driver is for testing host controller software. It is used |
| 226 | with specialized device firmware for regression and stress testing, | 226 | with specialized device firmware for regression and stress testing, |
diff --git a/drivers/usb/musb/Kconfig b/drivers/usb/musb/Kconfig index 70073b157f0a..803adcb5ac1d 100644 --- a/drivers/usb/musb/Kconfig +++ b/drivers/usb/musb/Kconfig | |||
| @@ -12,6 +12,7 @@ config USB_MUSB_HDRC | |||
| 12 | depends on !SUPERH | 12 | depends on !SUPERH |
| 13 | select NOP_USB_XCEIV if ARCH_DAVINCI | 13 | select NOP_USB_XCEIV if ARCH_DAVINCI |
| 14 | select TWL4030_USB if MACH_OMAP_3430SDP | 14 | select TWL4030_USB if MACH_OMAP_3430SDP |
| 15 | select NOP_USB_XCEIV if MACH_OMAP3EVM | ||
| 15 | select USB_OTG_UTILS | 16 | select USB_OTG_UTILS |
| 16 | tristate 'Inventra Highspeed Dual Role Controller (TI, ADI, ...)' | 17 | tristate 'Inventra Highspeed Dual Role Controller (TI, ADI, ...)' |
| 17 | help | 18 | help |
diff --git a/drivers/usb/musb/musb_core.c b/drivers/usb/musb/musb_core.c index 554a414f65d1..c7c1ca0494cd 100644 --- a/drivers/usb/musb/musb_core.c +++ b/drivers/usb/musb/musb_core.c | |||
| @@ -1326,7 +1326,6 @@ static int __init musb_core_init(u16 musb_type, struct musb *musb) | |||
| 1326 | int i; | 1326 | int i; |
| 1327 | 1327 | ||
| 1328 | /* log core options (read using indexed model) */ | 1328 | /* log core options (read using indexed model) */ |
| 1329 | musb_ep_select(mbase, 0); | ||
| 1330 | reg = musb_read_configdata(mbase); | 1329 | reg = musb_read_configdata(mbase); |
| 1331 | 1330 | ||
| 1332 | strcpy(aInfo, (reg & MUSB_CONFIGDATA_UTMIDW) ? "UTMI-16" : "UTMI-8"); | 1331 | strcpy(aInfo, (reg & MUSB_CONFIGDATA_UTMIDW) ? "UTMI-16" : "UTMI-8"); |
| @@ -1990,7 +1989,7 @@ bad_config: | |||
| 1990 | if (status < 0) | 1989 | if (status < 0) |
| 1991 | goto fail2; | 1990 | goto fail2; |
| 1992 | 1991 | ||
| 1993 | #ifdef CONFIG_USB_OTG | 1992 | #ifdef CONFIG_USB_MUSB_OTG |
| 1994 | setup_timer(&musb->otg_timer, musb_otg_timer_func, (unsigned long) musb); | 1993 | setup_timer(&musb->otg_timer, musb_otg_timer_func, (unsigned long) musb); |
| 1995 | #endif | 1994 | #endif |
| 1996 | 1995 | ||
diff --git a/drivers/usb/musb/musb_gadget_ep0.c b/drivers/usb/musb/musb_gadget_ep0.c index 40ed50ecedff..7a6778675ad3 100644 --- a/drivers/usb/musb/musb_gadget_ep0.c +++ b/drivers/usb/musb/musb_gadget_ep0.c | |||
| @@ -407,7 +407,7 @@ stall: | |||
| 407 | csr |= MUSB_RXCSR_P_SENDSTALL | 407 | csr |= MUSB_RXCSR_P_SENDSTALL |
| 408 | | MUSB_RXCSR_FLUSHFIFO | 408 | | MUSB_RXCSR_FLUSHFIFO |
| 409 | | MUSB_RXCSR_CLRDATATOG | 409 | | MUSB_RXCSR_CLRDATATOG |
| 410 | | MUSB_TXCSR_P_WZC_BITS; | 410 | | MUSB_RXCSR_P_WZC_BITS; |
| 411 | musb_writew(regs, MUSB_RXCSR, | 411 | musb_writew(regs, MUSB_RXCSR, |
| 412 | csr); | 412 | csr); |
| 413 | } | 413 | } |
diff --git a/drivers/usb/musb/musb_regs.h b/drivers/usb/musb/musb_regs.h index de3b2f18db44..fbfd3fd9ce1f 100644 --- a/drivers/usb/musb/musb_regs.h +++ b/drivers/usb/musb/musb_regs.h | |||
| @@ -323,6 +323,7 @@ static inline void musb_write_rxfifoadd(void __iomem *mbase, u16 c_off) | |||
| 323 | 323 | ||
| 324 | static inline u8 musb_read_configdata(void __iomem *mbase) | 324 | static inline u8 musb_read_configdata(void __iomem *mbase) |
| 325 | { | 325 | { |
| 326 | musb_writeb(mbase, MUSB_INDEX, 0); | ||
| 326 | return musb_readb(mbase, 0x10 + MUSB_CONFIGDATA); | 327 | return musb_readb(mbase, 0x10 + MUSB_CONFIGDATA); |
| 327 | } | 328 | } |
| 328 | 329 | ||
diff --git a/drivers/usb/serial/cp210x.c b/drivers/usb/serial/cp210x.c index e9a40b820fd4..985cbcf48bda 100644 --- a/drivers/usb/serial/cp210x.c +++ b/drivers/usb/serial/cp210x.c | |||
| @@ -80,6 +80,7 @@ static struct usb_device_id id_table [] = { | |||
| 80 | { USB_DEVICE(0x10C4, 0x80F6) }, /* Suunto sports instrument */ | 80 | { USB_DEVICE(0x10C4, 0x80F6) }, /* Suunto sports instrument */ |
| 81 | { USB_DEVICE(0x10C4, 0x8115) }, /* Arygon NFC/Mifare Reader */ | 81 | { USB_DEVICE(0x10C4, 0x8115) }, /* Arygon NFC/Mifare Reader */ |
| 82 | { USB_DEVICE(0x10C4, 0x813D) }, /* Burnside Telecom Deskmobile */ | 82 | { USB_DEVICE(0x10C4, 0x813D) }, /* Burnside Telecom Deskmobile */ |
| 83 | { USB_DEVICE(0x10C4, 0x813F) }, /* Tams Master Easy Control */ | ||
| 83 | { USB_DEVICE(0x10C4, 0x814A) }, /* West Mountain Radio RIGblaster P&P */ | 84 | { USB_DEVICE(0x10C4, 0x814A) }, /* West Mountain Radio RIGblaster P&P */ |
| 84 | { USB_DEVICE(0x10C4, 0x814B) }, /* West Mountain Radio RIGtalk */ | 85 | { USB_DEVICE(0x10C4, 0x814B) }, /* West Mountain Radio RIGtalk */ |
| 85 | { USB_DEVICE(0x10C4, 0x815E) }, /* Helicomm IP-Link 1220-DVM */ | 86 | { USB_DEVICE(0x10C4, 0x815E) }, /* Helicomm IP-Link 1220-DVM */ |
| @@ -96,7 +97,9 @@ static struct usb_device_id id_table [] = { | |||
| 96 | { USB_DEVICE(0x10c4, 0x8293) }, /* Telegesys ETRX2USB */ | 97 | { USB_DEVICE(0x10c4, 0x8293) }, /* Telegesys ETRX2USB */ |
| 97 | { USB_DEVICE(0x10C4, 0x82F9) }, /* Procyon AVS */ | 98 | { USB_DEVICE(0x10C4, 0x82F9) }, /* Procyon AVS */ |
| 98 | { USB_DEVICE(0x10C4, 0x8341) }, /* Siemens MC35PU GPRS Modem */ | 99 | { USB_DEVICE(0x10C4, 0x8341) }, /* Siemens MC35PU GPRS Modem */ |
| 100 | { USB_DEVICE(0x10C4, 0x8382) }, /* Cygnal Integrated Products, Inc. */ | ||
| 99 | { USB_DEVICE(0x10C4, 0x83A8) }, /* Amber Wireless AMB2560 */ | 101 | { USB_DEVICE(0x10C4, 0x83A8) }, /* Amber Wireless AMB2560 */ |
| 102 | { USB_DEVICE(0x10C4, 0x8411) }, /* Kyocera GPS Module */ | ||
| 100 | { USB_DEVICE(0x10C4, 0x846E) }, /* BEI USB Sensor Interface (VCP) */ | 103 | { USB_DEVICE(0x10C4, 0x846E) }, /* BEI USB Sensor Interface (VCP) */ |
| 101 | { USB_DEVICE(0x10C4, 0xEA60) }, /* Silicon Labs factory default */ | 104 | { USB_DEVICE(0x10C4, 0xEA60) }, /* Silicon Labs factory default */ |
| 102 | { USB_DEVICE(0x10C4, 0xEA61) }, /* Silicon Labs factory default */ | 105 | { USB_DEVICE(0x10C4, 0xEA61) }, /* Silicon Labs factory default */ |
diff --git a/drivers/usb/serial/ftdi_sio.c b/drivers/usb/serial/ftdi_sio.c index 60c64cc5be2a..8fec5d4455c9 100644 --- a/drivers/usb/serial/ftdi_sio.c +++ b/drivers/usb/serial/ftdi_sio.c | |||
| @@ -698,6 +698,10 @@ static struct usb_device_id id_table_combined [] = { | |||
| 698 | { USB_DEVICE(MARVELL_VID, MARVELL_SHEEVAPLUG_PID), | 698 | { USB_DEVICE(MARVELL_VID, MARVELL_SHEEVAPLUG_PID), |
| 699 | .driver_info = (kernel_ulong_t)&ftdi_jtag_quirk }, | 699 | .driver_info = (kernel_ulong_t)&ftdi_jtag_quirk }, |
| 700 | { USB_DEVICE(LARSENBRUSGAARD_VID, LB_ALTITRACK_PID) }, | 700 | { USB_DEVICE(LARSENBRUSGAARD_VID, LB_ALTITRACK_PID) }, |
| 701 | { USB_DEVICE(GN_OTOMETRICS_VID, AURICAL_USB_PID) }, | ||
| 702 | { USB_DEVICE(BAYER_VID, BAYER_CONTOUR_CABLE_PID) }, | ||
| 703 | { USB_DEVICE(FTDI_VID, MARVELL_OPENRD_PID), | ||
| 704 | .driver_info = (kernel_ulong_t)&ftdi_jtag_quirk }, | ||
| 701 | { }, /* Optional parameter entry */ | 705 | { }, /* Optional parameter entry */ |
| 702 | { } /* Terminating entry */ | 706 | { } /* Terminating entry */ |
| 703 | }; | 707 | }; |
diff --git a/drivers/usb/serial/ftdi_sio.h b/drivers/usb/serial/ftdi_sio.h index c9fbd7415092..8c92b88166ae 100644 --- a/drivers/usb/serial/ftdi_sio.h +++ b/drivers/usb/serial/ftdi_sio.h | |||
| @@ -947,6 +947,27 @@ | |||
| 947 | #define FTDI_TURTELIZER_PID 0xBDC8 /* JTAG/RS-232 adapter by egnite GmBH */ | 947 | #define FTDI_TURTELIZER_PID 0xBDC8 /* JTAG/RS-232 adapter by egnite GmBH */ |
| 948 | 948 | ||
| 949 | /* | 949 | /* |
| 950 | * GN Otometrics (http://www.otometrics.com) | ||
| 951 | * Submitted by Ville Sundberg. | ||
| 952 | */ | ||
| 953 | #define GN_OTOMETRICS_VID 0x0c33 /* Vendor ID */ | ||
| 954 | #define AURICAL_USB_PID 0x0010 /* Aurical USB Audiometer */ | ||
| 955 | |||
| 956 | /* | ||
| 957 | * Bayer Ascensia Contour blood glucose meter USB-converter cable. | ||
| 958 | * http://winglucofacts.com/cables/ | ||
| 959 | */ | ||
| 960 | #define BAYER_VID 0x1A79 | ||
| 961 | #define BAYER_CONTOUR_CABLE_PID 0x6001 | ||
| 962 | |||
| 963 | /* | ||
| 964 | * Marvell OpenRD Base, Client | ||
| 965 | * http://www.open-rd.org | ||
| 966 | * OpenRD Base, Client use VID 0x0403 | ||
| 967 | */ | ||
| 968 | #define MARVELL_OPENRD_PID 0x9e90 | ||
| 969 | |||
| 970 | /* | ||
| 950 | * BmRequestType: 1100 0000b | 971 | * BmRequestType: 1100 0000b |
| 951 | * bRequest: FTDI_E2_READ | 972 | * bRequest: FTDI_E2_READ |
| 952 | * wValue: 0 | 973 | * wValue: 0 |
diff --git a/drivers/usb/serial/mos7840.c b/drivers/usb/serial/mos7840.c index c31940a307f8..270009afdf77 100644 --- a/drivers/usb/serial/mos7840.c +++ b/drivers/usb/serial/mos7840.c | |||
| @@ -124,10 +124,13 @@ | |||
| 124 | #define BANDB_DEVICE_ID_USOPTL4_4 0xAC44 | 124 | #define BANDB_DEVICE_ID_USOPTL4_4 0xAC44 |
| 125 | #define BANDB_DEVICE_ID_USOPTL4_2 0xAC42 | 125 | #define BANDB_DEVICE_ID_USOPTL4_2 0xAC42 |
| 126 | 126 | ||
| 127 | /* This driver also supports the ATEN UC2324 device since it is mos7840 based | 127 | /* This driver also supports |
| 128 | * - if I knew the device id it would also support the ATEN UC2322 */ | 128 | * ATEN UC2324 device using Moschip MCS7840 |
| 129 | * ATEN UC2322 device using Moschip MCS7820 | ||
| 130 | */ | ||
| 129 | #define USB_VENDOR_ID_ATENINTL 0x0557 | 131 | #define USB_VENDOR_ID_ATENINTL 0x0557 |
| 130 | #define ATENINTL_DEVICE_ID_UC2324 0x2011 | 132 | #define ATENINTL_DEVICE_ID_UC2324 0x2011 |
| 133 | #define ATENINTL_DEVICE_ID_UC2322 0x7820 | ||
| 131 | 134 | ||
| 132 | /* Interrupt Routine Defines */ | 135 | /* Interrupt Routine Defines */ |
| 133 | 136 | ||
| @@ -177,6 +180,7 @@ static struct usb_device_id moschip_port_id_table[] = { | |||
| 177 | {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_4)}, | 180 | {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_4)}, |
| 178 | {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_2)}, | 181 | {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_2)}, |
| 179 | {USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_UC2324)}, | 182 | {USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_UC2324)}, |
| 183 | {USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_UC2322)}, | ||
| 180 | {} /* terminating entry */ | 184 | {} /* terminating entry */ |
| 181 | }; | 185 | }; |
| 182 | 186 | ||
| @@ -186,6 +190,7 @@ static __devinitdata struct usb_device_id moschip_id_table_combined[] = { | |||
| 186 | {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_4)}, | 190 | {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_4)}, |
| 187 | {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_2)}, | 191 | {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_2)}, |
| 188 | {USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_UC2324)}, | 192 | {USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_UC2324)}, |
| 193 | {USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_UC2322)}, | ||
| 189 | {} /* terminating entry */ | 194 | {} /* terminating entry */ |
| 190 | }; | 195 | }; |
| 191 | 196 | ||
diff --git a/drivers/usb/serial/option.c b/drivers/usb/serial/option.c index 98262dd552bb..c784ddbe7b61 100644 --- a/drivers/usb/serial/option.c +++ b/drivers/usb/serial/option.c | |||
| @@ -66,8 +66,10 @@ static int option_tiocmget(struct tty_struct *tty, struct file *file); | |||
| 66 | static int option_tiocmset(struct tty_struct *tty, struct file *file, | 66 | static int option_tiocmset(struct tty_struct *tty, struct file *file, |
| 67 | unsigned int set, unsigned int clear); | 67 | unsigned int set, unsigned int clear); |
| 68 | static int option_send_setup(struct usb_serial_port *port); | 68 | static int option_send_setup(struct usb_serial_port *port); |
| 69 | #ifdef CONFIG_PM | ||
| 69 | static int option_suspend(struct usb_serial *serial, pm_message_t message); | 70 | static int option_suspend(struct usb_serial *serial, pm_message_t message); |
| 70 | static int option_resume(struct usb_serial *serial); | 71 | static int option_resume(struct usb_serial *serial); |
| 72 | #endif | ||
| 71 | 73 | ||
| 72 | /* Vendor and product IDs */ | 74 | /* Vendor and product IDs */ |
| 73 | #define OPTION_VENDOR_ID 0x0AF0 | 75 | #define OPTION_VENDOR_ID 0x0AF0 |
| @@ -205,6 +207,7 @@ static int option_resume(struct usb_serial *serial); | |||
| 205 | #define NOVATELWIRELESS_PRODUCT_MC727 0x4100 | 207 | #define NOVATELWIRELESS_PRODUCT_MC727 0x4100 |
| 206 | #define NOVATELWIRELESS_PRODUCT_MC950D 0x4400 | 208 | #define NOVATELWIRELESS_PRODUCT_MC950D 0x4400 |
| 207 | #define NOVATELWIRELESS_PRODUCT_U727 0x5010 | 209 | #define NOVATELWIRELESS_PRODUCT_U727 0x5010 |
| 210 | #define NOVATELWIRELESS_PRODUCT_MC727_NEW 0x5100 | ||
| 208 | #define NOVATELWIRELESS_PRODUCT_MC760 0x6000 | 211 | #define NOVATELWIRELESS_PRODUCT_MC760 0x6000 |
| 209 | #define NOVATELWIRELESS_PRODUCT_OVMC760 0x6002 | 212 | #define NOVATELWIRELESS_PRODUCT_OVMC760 0x6002 |
| 210 | 213 | ||
| @@ -259,11 +262,6 @@ static int option_resume(struct usb_serial *serial); | |||
| 259 | #define AXESSTEL_VENDOR_ID 0x1726 | 262 | #define AXESSTEL_VENDOR_ID 0x1726 |
| 260 | #define AXESSTEL_PRODUCT_MV110H 0x1000 | 263 | #define AXESSTEL_PRODUCT_MV110H 0x1000 |
| 261 | 264 | ||
| 262 | #define ONDA_VENDOR_ID 0x19d2 | ||
| 263 | #define ONDA_PRODUCT_MSA501HS 0x0001 | ||
| 264 | #define ONDA_PRODUCT_ET502HS 0x0002 | ||
| 265 | #define ONDA_PRODUCT_MT503HS 0x2000 | ||
| 266 | |||
| 267 | #define BANDRICH_VENDOR_ID 0x1A8D | 265 | #define BANDRICH_VENDOR_ID 0x1A8D |
| 268 | #define BANDRICH_PRODUCT_C100_1 0x1002 | 266 | #define BANDRICH_PRODUCT_C100_1 0x1002 |
| 269 | #define BANDRICH_PRODUCT_C100_2 0x1003 | 267 | #define BANDRICH_PRODUCT_C100_2 0x1003 |
| @@ -301,6 +299,7 @@ static int option_resume(struct usb_serial *serial); | |||
| 301 | #define ZTE_PRODUCT_MF628 0x0015 | 299 | #define ZTE_PRODUCT_MF628 0x0015 |
| 302 | #define ZTE_PRODUCT_MF626 0x0031 | 300 | #define ZTE_PRODUCT_MF626 0x0031 |
| 303 | #define ZTE_PRODUCT_CDMA_TECH 0xfffe | 301 | #define ZTE_PRODUCT_CDMA_TECH 0xfffe |
| 302 | #define ZTE_PRODUCT_AC8710 0xfff1 | ||
| 304 | 303 | ||
| 305 | #define BENQ_VENDOR_ID 0x04a5 | 304 | #define BENQ_VENDOR_ID 0x04a5 |
| 306 | #define BENQ_PRODUCT_H10 0x4068 | 305 | #define BENQ_PRODUCT_H10 0x4068 |
| @@ -322,6 +321,11 @@ static int option_resume(struct usb_serial *serial); | |||
| 322 | #define ALINK_VENDOR_ID 0x1e0e | 321 | #define ALINK_VENDOR_ID 0x1e0e |
| 323 | #define ALINK_PRODUCT_3GU 0x9200 | 322 | #define ALINK_PRODUCT_3GU 0x9200 |
| 324 | 323 | ||
| 324 | /* ALCATEL PRODUCTS */ | ||
| 325 | #define ALCATEL_VENDOR_ID 0x1bbb | ||
| 326 | #define ALCATEL_PRODUCT_X060S 0x0000 | ||
| 327 | |||
| 328 | |||
| 325 | static struct usb_device_id option_ids[] = { | 329 | static struct usb_device_id option_ids[] = { |
| 326 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_COLT) }, | 330 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_COLT) }, |
| 327 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_RICOLA) }, | 331 | { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_RICOLA) }, |
| @@ -438,6 +442,7 @@ static struct usb_device_id option_ids[] = { | |||
| 438 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EU870D) }, /* Novatel EU850D/EU860D/EU870D */ | 442 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EU870D) }, /* Novatel EU850D/EU860D/EU870D */ |
| 439 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC950D) }, /* Novatel MC930D/MC950D */ | 443 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC950D) }, /* Novatel MC930D/MC950D */ |
| 440 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC727) }, /* Novatel MC727/U727/USB727 */ | 444 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC727) }, /* Novatel MC727/U727/USB727 */ |
| 445 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC727_NEW) }, /* Novatel MC727/U727/USB727 refresh */ | ||
| 441 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_U727) }, /* Novatel MC727/U727/USB727 */ | 446 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_U727) }, /* Novatel MC727/U727/USB727 */ |
| 442 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC760) }, /* Novatel MC760/U760/USB760 */ | 447 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC760) }, /* Novatel MC760/U760/USB760 */ |
| 443 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_OVMC760) }, /* Novatel Ovation MC760 */ | 448 | { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_OVMC760) }, /* Novatel Ovation MC760 */ |
| @@ -474,42 +479,6 @@ static struct usb_device_id option_ids[] = { | |||
| 474 | { USB_DEVICE(ANYDATA_VENDOR_ID, ANYDATA_PRODUCT_ADU_500A) }, | 479 | { USB_DEVICE(ANYDATA_VENDOR_ID, ANYDATA_PRODUCT_ADU_500A) }, |
| 475 | { USB_DEVICE(ANYDATA_VENDOR_ID, ANYDATA_PRODUCT_ADU_620UW) }, | 480 | { USB_DEVICE(ANYDATA_VENDOR_ID, ANYDATA_PRODUCT_ADU_620UW) }, |
| 476 | { USB_DEVICE(AXESSTEL_VENDOR_ID, AXESSTEL_PRODUCT_MV110H) }, | 481 | { USB_DEVICE(AXESSTEL_VENDOR_ID, AXESSTEL_PRODUCT_MV110H) }, |
| 477 | { USB_DEVICE(ONDA_VENDOR_ID, ONDA_PRODUCT_MSA501HS) }, | ||
| 478 | { USB_DEVICE(ONDA_VENDOR_ID, ONDA_PRODUCT_ET502HS) }, | ||
| 479 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0003) }, | ||
| 480 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0004) }, | ||
| 481 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0005) }, | ||
| 482 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0006) }, | ||
| 483 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0007) }, | ||
| 484 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0008) }, | ||
| 485 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0009) }, | ||
| 486 | { USB_DEVICE(ONDA_VENDOR_ID, 0x000a) }, | ||
| 487 | { USB_DEVICE(ONDA_VENDOR_ID, 0x000b) }, | ||
| 488 | { USB_DEVICE(ONDA_VENDOR_ID, 0x000c) }, | ||
| 489 | { USB_DEVICE(ONDA_VENDOR_ID, 0x000d) }, | ||
| 490 | { USB_DEVICE(ONDA_VENDOR_ID, 0x000e) }, | ||
| 491 | { USB_DEVICE(ONDA_VENDOR_ID, 0x000f) }, | ||
| 492 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0010) }, | ||
| 493 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0011) }, | ||
| 494 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0012) }, | ||
| 495 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0013) }, | ||
| 496 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0014) }, | ||
| 497 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0015) }, | ||
| 498 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0016) }, | ||
| 499 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0017) }, | ||
| 500 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0018) }, | ||
| 501 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0019) }, | ||
| 502 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0020) }, | ||
| 503 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0021) }, | ||
| 504 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0022) }, | ||
| 505 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0023) }, | ||
| 506 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0024) }, | ||
| 507 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0025) }, | ||
| 508 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0026) }, | ||
| 509 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0027) }, | ||
| 510 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0028) }, | ||
| 511 | { USB_DEVICE(ONDA_VENDOR_ID, 0x0029) }, | ||
| 512 | { USB_DEVICE(ONDA_VENDOR_ID, ONDA_PRODUCT_MT503HS) }, | ||
| 513 | { USB_DEVICE(YISO_VENDOR_ID, YISO_PRODUCT_U893) }, | 482 | { USB_DEVICE(YISO_VENDOR_ID, YISO_PRODUCT_U893) }, |
| 514 | { USB_DEVICE(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_C100_1) }, | 483 | { USB_DEVICE(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_C100_1) }, |
| 515 | { USB_DEVICE(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_C100_2) }, | 484 | { USB_DEVICE(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_C100_2) }, |
| @@ -534,10 +503,75 @@ static struct usb_device_id option_ids[] = { | |||
| 534 | { USB_DEVICE(QUALCOMM_VENDOR_ID, 0x6613)}, /* Onda H600/ZTE MF330 */ | 503 | { USB_DEVICE(QUALCOMM_VENDOR_ID, 0x6613)}, /* Onda H600/ZTE MF330 */ |
| 535 | { USB_DEVICE(MAXON_VENDOR_ID, 0x6280) }, /* BP3-USB & BP3-EXT HSDPA */ | 504 | { USB_DEVICE(MAXON_VENDOR_ID, 0x6280) }, /* BP3-USB & BP3-EXT HSDPA */ |
| 536 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_UC864E) }, | 505 | { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_UC864E) }, |
| 537 | { USB_DEVICE(ZTE_VENDOR_ID, ZTE_PRODUCT_MF622) }, | 506 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_MF622, 0xff, 0xff, 0xff) }, /* ZTE WCDMA products */ |
| 538 | { USB_DEVICE(ZTE_VENDOR_ID, ZTE_PRODUCT_MF626) }, | 507 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0002, 0xff, 0xff, 0xff) }, |
| 539 | { USB_DEVICE(ZTE_VENDOR_ID, ZTE_PRODUCT_MF628) }, | 508 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0003, 0xff, 0xff, 0xff) }, |
| 540 | { USB_DEVICE(ZTE_VENDOR_ID, ZTE_PRODUCT_CDMA_TECH) }, | 509 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0004, 0xff, 0xff, 0xff) }, |
| 510 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0005, 0xff, 0xff, 0xff) }, | ||
| 511 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0006, 0xff, 0xff, 0xff) }, | ||
| 512 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0007, 0xff, 0xff, 0xff) }, | ||
| 513 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0008, 0xff, 0xff, 0xff) }, | ||
| 514 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0009, 0xff, 0xff, 0xff) }, | ||
| 515 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000a, 0xff, 0xff, 0xff) }, | ||
| 516 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000b, 0xff, 0xff, 0xff) }, | ||
| 517 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000c, 0xff, 0xff, 0xff) }, | ||
| 518 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000d, 0xff, 0xff, 0xff) }, | ||
| 519 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000e, 0xff, 0xff, 0xff) }, | ||
| 520 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000f, 0xff, 0xff, 0xff) }, | ||
| 521 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0010, 0xff, 0xff, 0xff) }, | ||
| 522 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0011, 0xff, 0xff, 0xff) }, | ||
| 523 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0012, 0xff, 0xff, 0xff) }, | ||
| 524 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0013, 0xff, 0xff, 0xff) }, | ||
| 525 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_MF628, 0xff, 0xff, 0xff) }, | ||
| 526 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0016, 0xff, 0xff, 0xff) }, | ||
| 527 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0017, 0xff, 0xff, 0xff) }, | ||
| 528 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0018, 0xff, 0xff, 0xff) }, | ||
| 529 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0019, 0xff, 0xff, 0xff) }, | ||
| 530 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0020, 0xff, 0xff, 0xff) }, | ||
| 531 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0021, 0xff, 0xff, 0xff) }, | ||
| 532 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0022, 0xff, 0xff, 0xff) }, | ||
| 533 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0023, 0xff, 0xff, 0xff) }, | ||
| 534 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0024, 0xff, 0xff, 0xff) }, | ||
| 535 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0025, 0xff, 0xff, 0xff) }, | ||
| 536 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0026, 0xff, 0xff, 0xff) }, | ||
| 537 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0028, 0xff, 0xff, 0xff) }, | ||
| 538 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0029, 0xff, 0xff, 0xff) }, | ||
| 539 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0030, 0xff, 0xff, 0xff) }, | ||
| 540 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_MF626, 0xff, 0xff, 0xff) }, | ||
| 541 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0032, 0xff, 0xff, 0xff) }, | ||
| 542 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0033, 0xff, 0xff, 0xff) }, | ||
| 543 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0037, 0xff, 0xff, 0xff) }, | ||
| 544 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0039, 0xff, 0xff, 0xff) }, | ||
| 545 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0042, 0xff, 0xff, 0xff) }, | ||
| 546 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0043, 0xff, 0xff, 0xff) }, | ||
| 547 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0048, 0xff, 0xff, 0xff) }, | ||
| 548 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0049, 0xff, 0xff, 0xff) }, | ||
| 549 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0051, 0xff, 0xff, 0xff) }, | ||
| 550 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0052, 0xff, 0xff, 0xff) }, | ||
| 551 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0054, 0xff, 0xff, 0xff) }, | ||
| 552 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0055, 0xff, 0xff, 0xff) }, | ||
| 553 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0057, 0xff, 0xff, 0xff) }, | ||
| 554 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0058, 0xff, 0xff, 0xff) }, | ||
| 555 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0061, 0xff, 0xff, 0xff) }, | ||
| 556 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0062, 0xff, 0xff, 0xff) }, | ||
| 557 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0063, 0xff, 0xff, 0xff) }, | ||
| 558 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0064, 0xff, 0xff, 0xff) }, | ||
| 559 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0066, 0xff, 0xff, 0xff) }, | ||
| 560 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0069, 0xff, 0xff, 0xff) }, | ||
| 561 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0076, 0xff, 0xff, 0xff) }, | ||
| 562 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0078, 0xff, 0xff, 0xff) }, | ||
| 563 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0082, 0xff, 0xff, 0xff) }, | ||
| 564 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0086, 0xff, 0xff, 0xff) }, | ||
| 565 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x2002, 0xff, 0xff, 0xff) }, | ||
| 566 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x2003, 0xff, 0xff, 0xff) }, | ||
| 567 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0014, 0xff, 0xff, 0xff) }, /* ZTE CDMA products */ | ||
| 568 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0027, 0xff, 0xff, 0xff) }, | ||
| 569 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0059, 0xff, 0xff, 0xff) }, | ||
| 570 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0060, 0xff, 0xff, 0xff) }, | ||
| 571 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0070, 0xff, 0xff, 0xff) }, | ||
| 572 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0073, 0xff, 0xff, 0xff) }, | ||
| 573 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_CDMA_TECH, 0xff, 0xff, 0xff) }, | ||
| 574 | { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_AC8710, 0xff, 0xff, 0xff) }, | ||
| 541 | { USB_DEVICE(BENQ_VENDOR_ID, BENQ_PRODUCT_H10) }, | 575 | { USB_DEVICE(BENQ_VENDOR_ID, BENQ_PRODUCT_H10) }, |
| 542 | { USB_DEVICE(DLINK_VENDOR_ID, DLINK_PRODUCT_DWM_652) }, | 576 | { USB_DEVICE(DLINK_VENDOR_ID, DLINK_PRODUCT_DWM_652) }, |
| 543 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H21_4512) }, | 577 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H21_4512) }, |
| @@ -547,6 +581,7 @@ static struct usb_device_id option_ids[] = { | |||
| 547 | { USB_DEVICE(TOSHIBA_VENDOR_ID, TOSHIBA_PRODUCT_HSDPA_MINICARD ) }, /* Toshiba 3G HSDPA == Novatel Expedite EU870D MiniCard */ | 581 | { USB_DEVICE(TOSHIBA_VENDOR_ID, TOSHIBA_PRODUCT_HSDPA_MINICARD ) }, /* Toshiba 3G HSDPA == Novatel Expedite EU870D MiniCard */ |
| 548 | { USB_DEVICE(ALINK_VENDOR_ID, 0x9000) }, | 582 | { USB_DEVICE(ALINK_VENDOR_ID, 0x9000) }, |
| 549 | { USB_DEVICE_AND_INTERFACE_INFO(ALINK_VENDOR_ID, ALINK_PRODUCT_3GU, 0xff, 0xff, 0xff) }, | 583 | { USB_DEVICE_AND_INTERFACE_INFO(ALINK_VENDOR_ID, ALINK_PRODUCT_3GU, 0xff, 0xff, 0xff) }, |
| 584 | { USB_DEVICE(ALCATEL_VENDOR_ID, ALCATEL_PRODUCT_X060S) }, | ||
| 550 | { } /* Terminating entry */ | 585 | { } /* Terminating entry */ |
| 551 | }; | 586 | }; |
| 552 | MODULE_DEVICE_TABLE(usb, option_ids); | 587 | MODULE_DEVICE_TABLE(usb, option_ids); |
| @@ -555,8 +590,10 @@ static struct usb_driver option_driver = { | |||
| 555 | .name = "option", | 590 | .name = "option", |
| 556 | .probe = usb_serial_probe, | 591 | .probe = usb_serial_probe, |
| 557 | .disconnect = usb_serial_disconnect, | 592 | .disconnect = usb_serial_disconnect, |
| 593 | #ifdef CONFIG_PM | ||
| 558 | .suspend = usb_serial_suspend, | 594 | .suspend = usb_serial_suspend, |
| 559 | .resume = usb_serial_resume, | 595 | .resume = usb_serial_resume, |
| 596 | #endif | ||
| 560 | .id_table = option_ids, | 597 | .id_table = option_ids, |
| 561 | .no_dynamic_id = 1, | 598 | .no_dynamic_id = 1, |
| 562 | }; | 599 | }; |
| @@ -588,8 +625,10 @@ static struct usb_serial_driver option_1port_device = { | |||
| 588 | .disconnect = option_disconnect, | 625 | .disconnect = option_disconnect, |
| 589 | .release = option_release, | 626 | .release = option_release, |
| 590 | .read_int_callback = option_instat_callback, | 627 | .read_int_callback = option_instat_callback, |
| 628 | #ifdef CONFIG_PM | ||
| 591 | .suspend = option_suspend, | 629 | .suspend = option_suspend, |
| 592 | .resume = option_resume, | 630 | .resume = option_resume, |
| 631 | #endif | ||
| 593 | }; | 632 | }; |
| 594 | 633 | ||
| 595 | static int debug; | 634 | static int debug; |
| @@ -831,7 +870,6 @@ static void option_instat_callback(struct urb *urb) | |||
| 831 | int status = urb->status; | 870 | int status = urb->status; |
| 832 | struct usb_serial_port *port = urb->context; | 871 | struct usb_serial_port *port = urb->context; |
| 833 | struct option_port_private *portdata = usb_get_serial_port_data(port); | 872 | struct option_port_private *portdata = usb_get_serial_port_data(port); |
| 834 | struct usb_serial *serial = port->serial; | ||
| 835 | 873 | ||
| 836 | dbg("%s", __func__); | 874 | dbg("%s", __func__); |
| 837 | dbg("%s: urb %p port %p has data %p", __func__, urb, port, portdata); | 875 | dbg("%s: urb %p port %p has data %p", __func__, urb, port, portdata); |
| @@ -927,7 +965,6 @@ static int option_open(struct tty_struct *tty, | |||
| 927 | struct usb_serial_port *port, struct file *filp) | 965 | struct usb_serial_port *port, struct file *filp) |
| 928 | { | 966 | { |
| 929 | struct option_port_private *portdata; | 967 | struct option_port_private *portdata; |
| 930 | struct usb_serial *serial = port->serial; | ||
| 931 | int i, err; | 968 | int i, err; |
| 932 | struct urb *urb; | 969 | struct urb *urb; |
| 933 | 970 | ||
| @@ -1187,6 +1224,7 @@ static void option_release(struct usb_serial *serial) | |||
| 1187 | } | 1224 | } |
| 1188 | } | 1225 | } |
| 1189 | 1226 | ||
| 1227 | #ifdef CONFIG_PM | ||
| 1190 | static int option_suspend(struct usb_serial *serial, pm_message_t message) | 1228 | static int option_suspend(struct usb_serial *serial, pm_message_t message) |
| 1191 | { | 1229 | { |
| 1192 | dbg("%s entered", __func__); | 1230 | dbg("%s entered", __func__); |
| @@ -1245,6 +1283,7 @@ static int option_resume(struct usb_serial *serial) | |||
| 1245 | } | 1283 | } |
| 1246 | return 0; | 1284 | return 0; |
| 1247 | } | 1285 | } |
| 1286 | #endif | ||
| 1248 | 1287 | ||
| 1249 | MODULE_AUTHOR(DRIVER_AUTHOR); | 1288 | MODULE_AUTHOR(DRIVER_AUTHOR); |
| 1250 | MODULE_DESCRIPTION(DRIVER_DESC); | 1289 | MODULE_DESCRIPTION(DRIVER_DESC); |
diff --git a/drivers/usb/serial/pl2303.c b/drivers/usb/serial/pl2303.c index 7d15bfa7c2db..3e86815b2705 100644 --- a/drivers/usb/serial/pl2303.c +++ b/drivers/usb/serial/pl2303.c | |||
| @@ -95,6 +95,7 @@ static struct usb_device_id id_table [] = { | |||
| 95 | { USB_DEVICE(SUPERIAL_VENDOR_ID, SUPERIAL_PRODUCT_ID) }, | 95 | { USB_DEVICE(SUPERIAL_VENDOR_ID, SUPERIAL_PRODUCT_ID) }, |
| 96 | { USB_DEVICE(HP_VENDOR_ID, HP_LD220_PRODUCT_ID) }, | 96 | { USB_DEVICE(HP_VENDOR_ID, HP_LD220_PRODUCT_ID) }, |
| 97 | { USB_DEVICE(CRESSI_VENDOR_ID, CRESSI_EDY_PRODUCT_ID) }, | 97 | { USB_DEVICE(CRESSI_VENDOR_ID, CRESSI_EDY_PRODUCT_ID) }, |
| 98 | { USB_DEVICE(SONY_VENDOR_ID, SONY_QN3USB_PRODUCT_ID) }, | ||
| 98 | { } /* Terminating entry */ | 99 | { } /* Terminating entry */ |
| 99 | }; | 100 | }; |
| 100 | 101 | ||
diff --git a/drivers/usb/serial/pl2303.h b/drivers/usb/serial/pl2303.h index 12aac7d2462d..ee9505e1dd92 100644 --- a/drivers/usb/serial/pl2303.h +++ b/drivers/usb/serial/pl2303.h | |||
| @@ -126,3 +126,7 @@ | |||
| 126 | /* Cressi Edy (diving computer) PC interface */ | 126 | /* Cressi Edy (diving computer) PC interface */ |
| 127 | #define CRESSI_VENDOR_ID 0x04b8 | 127 | #define CRESSI_VENDOR_ID 0x04b8 |
| 128 | #define CRESSI_EDY_PRODUCT_ID 0x0521 | 128 | #define CRESSI_EDY_PRODUCT_ID 0x0521 |
| 129 | |||
| 130 | /* Sony, USB data cable for CMD-Jxx mobile phones */ | ||
| 131 | #define SONY_VENDOR_ID 0x054c | ||
| 132 | #define SONY_QN3USB_PRODUCT_ID 0x0437 | ||
diff --git a/drivers/usb/serial/usb-serial.c b/drivers/usb/serial/usb-serial.c index bd7581b3a48a..99188c92068b 100644 --- a/drivers/usb/serial/usb-serial.c +++ b/drivers/usb/serial/usb-serial.c | |||
| @@ -32,6 +32,7 @@ | |||
| 32 | #include <linux/mutex.h> | 32 | #include <linux/mutex.h> |
| 33 | #include <linux/list.h> | 33 | #include <linux/list.h> |
| 34 | #include <linux/uaccess.h> | 34 | #include <linux/uaccess.h> |
| 35 | #include <linux/serial.h> | ||
| 35 | #include <linux/usb.h> | 36 | #include <linux/usb.h> |
| 36 | #include <linux/usb/serial.h> | 37 | #include <linux/usb/serial.h> |
| 37 | #include "pl2303.h" | 38 | #include "pl2303.h" |
| @@ -184,6 +185,7 @@ static int serial_open (struct tty_struct *tty, struct file *filp) | |||
| 184 | struct usb_serial_port *port; | 185 | struct usb_serial_port *port; |
| 185 | unsigned int portNumber; | 186 | unsigned int portNumber; |
| 186 | int retval = 0; | 187 | int retval = 0; |
| 188 | int first = 0; | ||
| 187 | 189 | ||
| 188 | dbg("%s", __func__); | 190 | dbg("%s", __func__); |
| 189 | 191 | ||
| @@ -223,7 +225,7 @@ static int serial_open (struct tty_struct *tty, struct file *filp) | |||
| 223 | 225 | ||
| 224 | /* If the console is attached, the device is already open */ | 226 | /* If the console is attached, the device is already open */ |
| 225 | if (port->port.count == 1 && !port->console) { | 227 | if (port->port.count == 1 && !port->console) { |
| 226 | 228 | first = 1; | |
| 227 | /* lock this module before we call it | 229 | /* lock this module before we call it |
| 228 | * this may fail, which means we must bail out, | 230 | * this may fail, which means we must bail out, |
| 229 | * safe because we are called with BKL held */ | 231 | * safe because we are called with BKL held */ |
| @@ -246,13 +248,21 @@ static int serial_open (struct tty_struct *tty, struct file *filp) | |||
| 246 | if (retval) | 248 | if (retval) |
| 247 | goto bailout_interface_put; | 249 | goto bailout_interface_put; |
| 248 | mutex_unlock(&serial->disc_mutex); | 250 | mutex_unlock(&serial->disc_mutex); |
| 251 | set_bit(ASYNCB_INITIALIZED, &port->port.flags); | ||
| 249 | } | 252 | } |
| 250 | mutex_unlock(&port->mutex); | 253 | mutex_unlock(&port->mutex); |
| 251 | /* Now do the correct tty layer semantics */ | 254 | /* Now do the correct tty layer semantics */ |
| 252 | retval = tty_port_block_til_ready(&port->port, tty, filp); | 255 | retval = tty_port_block_til_ready(&port->port, tty, filp); |
| 253 | if (retval == 0) | 256 | if (retval == 0) { |
| 257 | if (!first) | ||
| 258 | usb_serial_put(serial); | ||
| 254 | return 0; | 259 | return 0; |
| 255 | 260 | } | |
| 261 | mutex_lock(&port->mutex); | ||
| 262 | if (first == 0) | ||
| 263 | goto bailout_mutex_unlock; | ||
| 264 | /* Undo the initial port actions */ | ||
| 265 | mutex_lock(&serial->disc_mutex); | ||
| 256 | bailout_interface_put: | 266 | bailout_interface_put: |
| 257 | usb_autopm_put_interface(serial->interface); | 267 | usb_autopm_put_interface(serial->interface); |
| 258 | bailout_module_put: | 268 | bailout_module_put: |
| @@ -340,6 +350,22 @@ static void serial_close(struct tty_struct *tty, struct file *filp) | |||
| 340 | 350 | ||
| 341 | dbg("%s - port %d", __func__, port->number); | 351 | dbg("%s - port %d", __func__, port->number); |
| 342 | 352 | ||
| 353 | /* FIXME: | ||
| 354 | This leaves a very narrow race. Really we should do the | ||
| 355 | serial_do_free() on tty->shutdown(), but tty->shutdown can | ||
| 356 | be called from IRQ context and serial_do_free can sleep. | ||
| 357 | |||
| 358 | The right fix is probably to make the tty free (which is rare) | ||
| 359 | and thus tty->shutdown() occur via a work queue and simplify all | ||
| 360 | the drivers that use it. | ||
| 361 | */ | ||
| 362 | if (tty_hung_up_p(filp)) { | ||
| 363 | /* serial_hangup already called serial_down at this point. | ||
| 364 | Another user may have already reopened the port but | ||
| 365 | serial_do_free is refcounted */ | ||
| 366 | serial_do_free(port); | ||
| 367 | return; | ||
| 368 | } | ||
| 343 | 369 | ||
| 344 | if (tty_port_close_start(&port->port, tty, filp) == 0) | 370 | if (tty_port_close_start(&port->port, tty, filp) == 0) |
| 345 | return; | 371 | return; |
| @@ -355,7 +381,8 @@ static void serial_hangup(struct tty_struct *tty) | |||
| 355 | struct usb_serial_port *port = tty->driver_data; | 381 | struct usb_serial_port *port = tty->driver_data; |
| 356 | serial_do_down(port); | 382 | serial_do_down(port); |
| 357 | tty_port_hangup(&port->port); | 383 | tty_port_hangup(&port->port); |
| 358 | serial_do_free(port); | 384 | /* We must not free port yet - the USB serial layer depends on it's |
| 385 | continued existence */ | ||
| 359 | } | 386 | } |
| 360 | 387 | ||
| 361 | static int serial_write(struct tty_struct *tty, const unsigned char *buf, | 388 | static int serial_write(struct tty_struct *tty, const unsigned char *buf, |
| @@ -394,7 +421,6 @@ static int serial_chars_in_buffer(struct tty_struct *tty) | |||
| 394 | struct usb_serial_port *port = tty->driver_data; | 421 | struct usb_serial_port *port = tty->driver_data; |
| 395 | dbg("%s = port %d", __func__, port->number); | 422 | dbg("%s = port %d", __func__, port->number); |
| 396 | 423 | ||
| 397 | WARN_ON(!port->port.count); | ||
| 398 | /* if the device was unplugged then any remaining characters | 424 | /* if the device was unplugged then any remaining characters |
| 399 | fell out of the connector ;) */ | 425 | fell out of the connector ;) */ |
| 400 | if (port->serial->disconnected) | 426 | if (port->serial->disconnected) |
diff --git a/drivers/usb/storage/transport.c b/drivers/usb/storage/transport.c index fcb320217218..e20dc525d177 100644 --- a/drivers/usb/storage/transport.c +++ b/drivers/usb/storage/transport.c | |||
| @@ -961,7 +961,7 @@ int usb_stor_Bulk_max_lun(struct us_data *us) | |||
| 961 | US_BULK_GET_MAX_LUN, | 961 | US_BULK_GET_MAX_LUN, |
| 962 | USB_DIR_IN | USB_TYPE_CLASS | | 962 | USB_DIR_IN | USB_TYPE_CLASS | |
| 963 | USB_RECIP_INTERFACE, | 963 | USB_RECIP_INTERFACE, |
| 964 | 0, us->ifnum, us->iobuf, 1, HZ); | 964 | 0, us->ifnum, us->iobuf, 1, 10*HZ); |
| 965 | 965 | ||
| 966 | US_DEBUGP("GetMaxLUN command result is %d, data is %d\n", | 966 | US_DEBUGP("GetMaxLUN command result is %d, data is %d\n", |
| 967 | result, us->iobuf[0]); | 967 | result, us->iobuf[0]); |
diff --git a/drivers/usb/storage/unusual_devs.h b/drivers/usb/storage/unusual_devs.h index 1b9c5dd0fb27..7477d411959f 100644 --- a/drivers/usb/storage/unusual_devs.h +++ b/drivers/usb/storage/unusual_devs.h | |||
| @@ -838,6 +838,13 @@ UNUSUAL_DEV( 0x066f, 0x8000, 0x0001, 0x0001, | |||
| 838 | US_SC_DEVICE, US_PR_DEVICE, NULL, | 838 | US_SC_DEVICE, US_PR_DEVICE, NULL, |
| 839 | US_FL_FIX_CAPACITY ), | 839 | US_FL_FIX_CAPACITY ), |
| 840 | 840 | ||
| 841 | /* Reported by Rogerio Brito <rbrito@ime.usp.br> */ | ||
| 842 | UNUSUAL_DEV( 0x067b, 0x2317, 0x0001, 0x001, | ||
| 843 | "Prolific Technology, Inc.", | ||
| 844 | "Mass Storage Device", | ||
| 845 | US_SC_DEVICE, US_PR_DEVICE, NULL, | ||
| 846 | US_FL_NOT_LOCKABLE ), | ||
| 847 | |||
| 841 | /* Reported by Richard -=[]=- <micro_flyer@hotmail.com> */ | 848 | /* Reported by Richard -=[]=- <micro_flyer@hotmail.com> */ |
| 842 | /* Change to bcdDeviceMin (0x0100 to 0x0001) reported by | 849 | /* Change to bcdDeviceMin (0x0100 to 0x0001) reported by |
| 843 | * Thomas Bartosik <tbartdev@gmx-topmail.de> */ | 850 | * Thomas Bartosik <tbartdev@gmx-topmail.de> */ |
diff --git a/drivers/video/backlight/jornada720_bl.c b/drivers/video/backlight/jornada720_bl.c index c3ebb6b41ce1..7aed2565c1bd 100644 --- a/drivers/video/backlight/jornada720_bl.c +++ b/drivers/video/backlight/jornada720_bl.c | |||
| @@ -72,7 +72,7 @@ static int jornada_bl_update_status(struct backlight_device *bd) | |||
| 72 | if (jornada_ssp_byte(SETBRIGHTNESS) != TXDUMMY) { | 72 | if (jornada_ssp_byte(SETBRIGHTNESS) != TXDUMMY) { |
| 73 | printk(KERN_INFO "bl : failed to set brightness\n"); | 73 | printk(KERN_INFO "bl : failed to set brightness\n"); |
| 74 | ret = -ETIMEDOUT; | 74 | ret = -ETIMEDOUT; |
| 75 | goto out | 75 | goto out; |
| 76 | } | 76 | } |
| 77 | 77 | ||
| 78 | /* at this point we expect that the mcu has accepted | 78 | /* at this point we expect that the mcu has accepted |
diff --git a/drivers/video/console/fbcon.c b/drivers/video/console/fbcon.c index 471a9a60376a..3a44695b9c09 100644 --- a/drivers/video/console/fbcon.c +++ b/drivers/video/console/fbcon.c | |||
| @@ -1082,7 +1082,6 @@ static void fbcon_init(struct vc_data *vc, int init) | |||
| 1082 | new_rows = FBCON_SWAP(ops->rotate, info->var.yres, info->var.xres); | 1082 | new_rows = FBCON_SWAP(ops->rotate, info->var.yres, info->var.xres); |
| 1083 | new_cols /= vc->vc_font.width; | 1083 | new_cols /= vc->vc_font.width; |
| 1084 | new_rows /= vc->vc_font.height; | 1084 | new_rows /= vc->vc_font.height; |
| 1085 | vc_resize(vc, new_cols, new_rows); | ||
| 1086 | 1085 | ||
| 1087 | /* | 1086 | /* |
| 1088 | * We must always set the mode. The mode of the previous console | 1087 | * We must always set the mode. The mode of the previous console |
| @@ -1111,10 +1110,11 @@ static void fbcon_init(struct vc_data *vc, int init) | |||
| 1111 | * vc_{cols,rows}, but we must not set those if we are only | 1110 | * vc_{cols,rows}, but we must not set those if we are only |
| 1112 | * resizing the console. | 1111 | * resizing the console. |
| 1113 | */ | 1112 | */ |
| 1114 | if (!init) { | 1113 | if (init) { |
| 1115 | vc->vc_cols = new_cols; | 1114 | vc->vc_cols = new_cols; |
| 1116 | vc->vc_rows = new_rows; | 1115 | vc->vc_rows = new_rows; |
| 1117 | } | 1116 | } else |
| 1117 | vc_resize(vc, new_cols, new_rows); | ||
| 1118 | 1118 | ||
| 1119 | if (logo) | 1119 | if (logo) |
| 1120 | fbcon_prepare_logo(vc, info, cols, rows, new_cols, new_rows); | 1120 | fbcon_prepare_logo(vc, info, cols, rows, new_cols, new_rows); |
diff --git a/drivers/video/console/fbcon_rotate.h b/drivers/video/console/fbcon_rotate.h index 75be5ce53dc5..e233444cda66 100644 --- a/drivers/video/console/fbcon_rotate.h +++ b/drivers/video/console/fbcon_rotate.h | |||
| @@ -45,7 +45,7 @@ static inline void rotate_ud(const char *in, char *out, u32 width, u32 height) | |||
| 45 | width = (width + 7) & ~7; | 45 | width = (width + 7) & ~7; |
| 46 | 46 | ||
| 47 | for (i = 0; i < height; i++) { | 47 | for (i = 0; i < height; i++) { |
| 48 | for (j = 0; j < width; j++) { | 48 | for (j = 0; j < width - shift; j++) { |
| 49 | if (pattern_test_bit(j, i, width, in)) | 49 | if (pattern_test_bit(j, i, width, in)) |
| 50 | pattern_set_bit(width - (1 + j + shift), | 50 | pattern_set_bit(width - (1 + j + shift), |
| 51 | height - (1 + i), | 51 | height - (1 + i), |
diff --git a/drivers/video/console/sticore.c b/drivers/video/console/sticore.c index ef7870f5ea08..857b3668b3ba 100644 --- a/drivers/video/console/sticore.c +++ b/drivers/video/console/sticore.c | |||
| @@ -957,9 +957,14 @@ static int __devinit sticore_pci_init(struct pci_dev *pd, | |||
| 957 | #ifdef CONFIG_PCI | 957 | #ifdef CONFIG_PCI |
| 958 | unsigned long fb_base, rom_base; | 958 | unsigned long fb_base, rom_base; |
| 959 | unsigned int fb_len, rom_len; | 959 | unsigned int fb_len, rom_len; |
| 960 | int err; | ||
| 960 | struct sti_struct *sti; | 961 | struct sti_struct *sti; |
| 961 | 962 | ||
| 962 | pci_enable_device(pd); | 963 | err = pci_enable_device(pd); |
| 964 | if (err < 0) { | ||
| 965 | dev_err(&pd->dev, "Cannot enable PCI device\n"); | ||
| 966 | return err; | ||
| 967 | } | ||
| 963 | 968 | ||
| 964 | fb_base = pci_resource_start(pd, 0); | 969 | fb_base = pci_resource_start(pd, 0); |
| 965 | fb_len = pci_resource_len(pd, 0); | 970 | fb_len = pci_resource_len(pd, 0); |
| @@ -1048,7 +1053,7 @@ static void __devinit sti_init_roms(void) | |||
| 1048 | 1053 | ||
| 1049 | /* Register drivers for native & PCI cards */ | 1054 | /* Register drivers for native & PCI cards */ |
| 1050 | register_parisc_driver(&pa_sti_driver); | 1055 | register_parisc_driver(&pa_sti_driver); |
| 1051 | pci_register_driver(&pci_sti_driver); | 1056 | WARN_ON(pci_register_driver(&pci_sti_driver)); |
| 1052 | 1057 | ||
| 1053 | /* if we didn't find the given default sti, take the first one */ | 1058 | /* if we didn't find the given default sti, take the first one */ |
| 1054 | if (!default_sti) | 1059 | if (!default_sti) |
diff --git a/drivers/video/fbmon.c b/drivers/video/fbmon.c index 5c1a2c01778f..9ae9cd32bd06 100644 --- a/drivers/video/fbmon.c +++ b/drivers/video/fbmon.c | |||
| @@ -256,8 +256,8 @@ static void fix_edid(unsigned char *edid, int fix) | |||
| 256 | 256 | ||
| 257 | static int edid_checksum(unsigned char *edid) | 257 | static int edid_checksum(unsigned char *edid) |
| 258 | { | 258 | { |
| 259 | unsigned char i, csum = 0, all_null = 0; | 259 | unsigned char csum = 0, all_null = 0; |
| 260 | int err = 0, fix = check_edid(edid); | 260 | int i, err = 0, fix = check_edid(edid); |
| 261 | 261 | ||
| 262 | if (fix) | 262 | if (fix) |
| 263 | fix_edid(edid, fix); | 263 | fix_edid(edid, fix); |
diff --git a/drivers/video/mx3fb.c b/drivers/video/mx3fb.c index f8778cde2183..054ef29be479 100644 --- a/drivers/video/mx3fb.c +++ b/drivers/video/mx3fb.c | |||
| @@ -669,7 +669,8 @@ static uint32_t bpp_to_pixfmt(int bpp) | |||
| 669 | } | 669 | } |
| 670 | 670 | ||
| 671 | static int mx3fb_blank(int blank, struct fb_info *fbi); | 671 | static int mx3fb_blank(int blank, struct fb_info *fbi); |
| 672 | static int mx3fb_map_video_memory(struct fb_info *fbi, unsigned int mem_len); | 672 | static int mx3fb_map_video_memory(struct fb_info *fbi, unsigned int mem_len, |
| 673 | bool lock); | ||
| 673 | static int mx3fb_unmap_video_memory(struct fb_info *fbi); | 674 | static int mx3fb_unmap_video_memory(struct fb_info *fbi); |
| 674 | 675 | ||
| 675 | /** | 676 | /** |
| @@ -711,12 +712,7 @@ static void mx3fb_dma_done(void *arg) | |||
| 711 | complete(&mx3_fbi->flip_cmpl); | 712 | complete(&mx3_fbi->flip_cmpl); |
| 712 | } | 713 | } |
| 713 | 714 | ||
| 714 | /** | 715 | static int __set_par(struct fb_info *fbi, bool lock) |
| 715 | * mx3fb_set_par() - set framebuffer parameters and change the operating mode. | ||
| 716 | * @fbi: framebuffer information pointer. | ||
| 717 | * @return: 0 on success or negative error code on failure. | ||
| 718 | */ | ||
| 719 | static int mx3fb_set_par(struct fb_info *fbi) | ||
| 720 | { | 716 | { |
| 721 | u32 mem_len; | 717 | u32 mem_len; |
| 722 | struct ipu_di_signal_cfg sig_cfg; | 718 | struct ipu_di_signal_cfg sig_cfg; |
| @@ -727,10 +723,6 @@ static int mx3fb_set_par(struct fb_info *fbi) | |||
| 727 | struct idmac_video_param *video = &ichan->params.video; | 723 | struct idmac_video_param *video = &ichan->params.video; |
| 728 | struct scatterlist *sg = mx3_fbi->sg; | 724 | struct scatterlist *sg = mx3_fbi->sg; |
| 729 | 725 | ||
| 730 | dev_dbg(mx3fb->dev, "%s [%c]\n", __func__, list_empty(&ichan->queue) ? '-' : '+'); | ||
| 731 | |||
| 732 | mutex_lock(&mx3_fbi->mutex); | ||
| 733 | |||
| 734 | /* Total cleanup */ | 726 | /* Total cleanup */ |
| 735 | if (mx3_fbi->txd) | 727 | if (mx3_fbi->txd) |
| 736 | sdc_disable_channel(mx3_fbi); | 728 | sdc_disable_channel(mx3_fbi); |
| @@ -742,10 +734,8 @@ static int mx3fb_set_par(struct fb_info *fbi) | |||
| 742 | if (fbi->fix.smem_start) | 734 | if (fbi->fix.smem_start) |
| 743 | mx3fb_unmap_video_memory(fbi); | 735 | mx3fb_unmap_video_memory(fbi); |
| 744 | 736 | ||
| 745 | if (mx3fb_map_video_memory(fbi, mem_len) < 0) { | 737 | if (mx3fb_map_video_memory(fbi, mem_len, lock) < 0) |
| 746 | mutex_unlock(&mx3_fbi->mutex); | ||
| 747 | return -ENOMEM; | 738 | return -ENOMEM; |
| 748 | } | ||
| 749 | } | 739 | } |
| 750 | 740 | ||
| 751 | sg_init_table(&sg[0], 1); | 741 | sg_init_table(&sg[0], 1); |
| @@ -791,7 +781,6 @@ static int mx3fb_set_par(struct fb_info *fbi) | |||
| 791 | fbi->var.vsync_len, | 781 | fbi->var.vsync_len, |
| 792 | fbi->var.lower_margin + | 782 | fbi->var.lower_margin + |
| 793 | fbi->var.vsync_len, sig_cfg) != 0) { | 783 | fbi->var.vsync_len, sig_cfg) != 0) { |
| 794 | mutex_unlock(&mx3_fbi->mutex); | ||
| 795 | dev_err(fbi->device, | 784 | dev_err(fbi->device, |
| 796 | "mx3fb: Error initializing panel.\n"); | 785 | "mx3fb: Error initializing panel.\n"); |
| 797 | return -EINVAL; | 786 | return -EINVAL; |
| @@ -810,9 +799,30 @@ static int mx3fb_set_par(struct fb_info *fbi) | |||
| 810 | if (mx3_fbi->blank == FB_BLANK_UNBLANK) | 799 | if (mx3_fbi->blank == FB_BLANK_UNBLANK) |
| 811 | sdc_enable_channel(mx3_fbi); | 800 | sdc_enable_channel(mx3_fbi); |
| 812 | 801 | ||
| 802 | return 0; | ||
| 803 | } | ||
| 804 | |||
| 805 | /** | ||
| 806 | * mx3fb_set_par() - set framebuffer parameters and change the operating mode. | ||
| 807 | * @fbi: framebuffer information pointer. | ||
| 808 | * @return: 0 on success or negative error code on failure. | ||
| 809 | */ | ||
| 810 | static int mx3fb_set_par(struct fb_info *fbi) | ||
| 811 | { | ||
| 812 | struct mx3fb_info *mx3_fbi = fbi->par; | ||
| 813 | struct mx3fb_data *mx3fb = mx3_fbi->mx3fb; | ||
| 814 | struct idmac_channel *ichan = mx3_fbi->idmac_channel; | ||
| 815 | int ret; | ||
| 816 | |||
| 817 | dev_dbg(mx3fb->dev, "%s [%c]\n", __func__, list_empty(&ichan->queue) ? '-' : '+'); | ||
| 818 | |||
| 819 | mutex_lock(&mx3_fbi->mutex); | ||
| 820 | |||
| 821 | ret = __set_par(fbi, true); | ||
| 822 | |||
| 813 | mutex_unlock(&mx3_fbi->mutex); | 823 | mutex_unlock(&mx3_fbi->mutex); |
| 814 | 824 | ||
| 815 | return 0; | 825 | return ret; |
| 816 | } | 826 | } |
| 817 | 827 | ||
| 818 | /** | 828 | /** |
| @@ -966,21 +976,11 @@ static int mx3fb_setcolreg(unsigned int regno, unsigned int red, | |||
| 966 | return ret; | 976 | return ret; |
| 967 | } | 977 | } |
| 968 | 978 | ||
| 969 | /** | 979 | static void __blank(int blank, struct fb_info *fbi) |
| 970 | * mx3fb_blank() - blank the display. | ||
| 971 | */ | ||
| 972 | static int mx3fb_blank(int blank, struct fb_info *fbi) | ||
| 973 | { | 980 | { |
| 974 | struct mx3fb_info *mx3_fbi = fbi->par; | 981 | struct mx3fb_info *mx3_fbi = fbi->par; |
| 975 | struct mx3fb_data *mx3fb = mx3_fbi->mx3fb; | 982 | struct mx3fb_data *mx3fb = mx3_fbi->mx3fb; |
| 976 | 983 | ||
| 977 | dev_dbg(fbi->device, "%s, blank = %d, base %p, len %u\n", __func__, | ||
| 978 | blank, fbi->screen_base, fbi->fix.smem_len); | ||
| 979 | |||
| 980 | if (mx3_fbi->blank == blank) | ||
| 981 | return 0; | ||
| 982 | |||
| 983 | mutex_lock(&mx3_fbi->mutex); | ||
| 984 | mx3_fbi->blank = blank; | 984 | mx3_fbi->blank = blank; |
| 985 | 985 | ||
| 986 | switch (blank) { | 986 | switch (blank) { |
| @@ -999,6 +999,23 @@ static int mx3fb_blank(int blank, struct fb_info *fbi) | |||
| 999 | sdc_set_brightness(mx3fb, mx3fb->backlight_level); | 999 | sdc_set_brightness(mx3fb, mx3fb->backlight_level); |
| 1000 | break; | 1000 | break; |
| 1001 | } | 1001 | } |
| 1002 | } | ||
| 1003 | |||
| 1004 | /** | ||
| 1005 | * mx3fb_blank() - blank the display. | ||
| 1006 | */ | ||
| 1007 | static int mx3fb_blank(int blank, struct fb_info *fbi) | ||
| 1008 | { | ||
| 1009 | struct mx3fb_info *mx3_fbi = fbi->par; | ||
| 1010 | |||
| 1011 | dev_dbg(fbi->device, "%s, blank = %d, base %p, len %u\n", __func__, | ||
| 1012 | blank, fbi->screen_base, fbi->fix.smem_len); | ||
| 1013 | |||
| 1014 | if (mx3_fbi->blank == blank) | ||
| 1015 | return 0; | ||
| 1016 | |||
| 1017 | mutex_lock(&mx3_fbi->mutex); | ||
| 1018 | __blank(blank, fbi); | ||
| 1002 | mutex_unlock(&mx3_fbi->mutex); | 1019 | mutex_unlock(&mx3_fbi->mutex); |
| 1003 | 1020 | ||
| 1004 | return 0; | 1021 | return 0; |
| @@ -1198,6 +1215,7 @@ static int mx3fb_resume(struct platform_device *pdev) | |||
| 1198 | * mx3fb_map_video_memory() - allocates the DRAM memory for the frame buffer. | 1215 | * mx3fb_map_video_memory() - allocates the DRAM memory for the frame buffer. |
| 1199 | * @fbi: framebuffer information pointer | 1216 | * @fbi: framebuffer information pointer |
| 1200 | * @mem_len: length of mapped memory | 1217 | * @mem_len: length of mapped memory |
| 1218 | * @lock: do not lock during initialisation | ||
| 1201 | * @return: Error code indicating success or failure | 1219 | * @return: Error code indicating success or failure |
| 1202 | * | 1220 | * |
| 1203 | * This buffer is remapped into a non-cached, non-buffered, memory region to | 1221 | * This buffer is remapped into a non-cached, non-buffered, memory region to |
| @@ -1205,7 +1223,8 @@ static int mx3fb_resume(struct platform_device *pdev) | |||
| 1205 | * area is remapped, all virtual memory access to the video memory should occur | 1223 | * area is remapped, all virtual memory access to the video memory should occur |
| 1206 | * at the new region. | 1224 | * at the new region. |
| 1207 | */ | 1225 | */ |
| 1208 | static int mx3fb_map_video_memory(struct fb_info *fbi, unsigned int mem_len) | 1226 | static int mx3fb_map_video_memory(struct fb_info *fbi, unsigned int mem_len, |
| 1227 | bool lock) | ||
| 1209 | { | 1228 | { |
| 1210 | int retval = 0; | 1229 | int retval = 0; |
| 1211 | dma_addr_t addr; | 1230 | dma_addr_t addr; |
| @@ -1221,10 +1240,12 @@ static int mx3fb_map_video_memory(struct fb_info *fbi, unsigned int mem_len) | |||
| 1221 | goto err0; | 1240 | goto err0; |
| 1222 | } | 1241 | } |
| 1223 | 1242 | ||
| 1224 | mutex_lock(&fbi->mm_lock); | 1243 | if (lock) |
| 1244 | mutex_lock(&fbi->mm_lock); | ||
| 1225 | fbi->fix.smem_start = addr; | 1245 | fbi->fix.smem_start = addr; |
| 1226 | fbi->fix.smem_len = mem_len; | 1246 | fbi->fix.smem_len = mem_len; |
| 1227 | mutex_unlock(&fbi->mm_lock); | 1247 | if (lock) |
| 1248 | mutex_unlock(&fbi->mm_lock); | ||
| 1228 | 1249 | ||
| 1229 | dev_dbg(fbi->device, "allocated fb @ p=0x%08x, v=0x%p, size=%d.\n", | 1250 | dev_dbg(fbi->device, "allocated fb @ p=0x%08x, v=0x%p, size=%d.\n", |
| 1230 | (uint32_t) fbi->fix.smem_start, fbi->screen_base, fbi->fix.smem_len); | 1251 | (uint32_t) fbi->fix.smem_start, fbi->screen_base, fbi->fix.smem_len); |
| @@ -1365,6 +1386,11 @@ static int init_fb_chan(struct mx3fb_data *mx3fb, struct idmac_channel *ichan) | |||
| 1365 | init_completion(&mx3fbi->flip_cmpl); | 1386 | init_completion(&mx3fbi->flip_cmpl); |
| 1366 | disable_irq(ichan->eof_irq); | 1387 | disable_irq(ichan->eof_irq); |
| 1367 | dev_dbg(mx3fb->dev, "disabling irq %d\n", ichan->eof_irq); | 1388 | dev_dbg(mx3fb->dev, "disabling irq %d\n", ichan->eof_irq); |
| 1389 | ret = __set_par(fbi, false); | ||
| 1390 | if (ret < 0) | ||
| 1391 | goto esetpar; | ||
| 1392 | |||
| 1393 | __blank(FB_BLANK_UNBLANK, fbi); | ||
| 1368 | 1394 | ||
| 1369 | dev_info(dev, "registered, using mode %s\n", fb_mode); | 1395 | dev_info(dev, "registered, using mode %s\n", fb_mode); |
| 1370 | 1396 | ||
diff --git a/drivers/video/s3c-fb.c b/drivers/video/s3c-fb.c index bb63c07e13de..5a72083dc67c 100644 --- a/drivers/video/s3c-fb.c +++ b/drivers/video/s3c-fb.c | |||
| @@ -964,7 +964,7 @@ static int __devexit s3c_fb_remove(struct platform_device *pdev) | |||
| 964 | struct s3c_fb *sfb = platform_get_drvdata(pdev); | 964 | struct s3c_fb *sfb = platform_get_drvdata(pdev); |
| 965 | int win; | 965 | int win; |
| 966 | 966 | ||
| 967 | for (win = 0; win <= S3C_FB_MAX_WIN; win++) | 967 | for (win = 0; win < S3C_FB_MAX_WIN; win++) |
| 968 | if (sfb->windows[win]) | 968 | if (sfb->windows[win]) |
| 969 | s3c_fb_release_win(sfb, sfb->windows[win]); | 969 | s3c_fb_release_win(sfb, sfb->windows[win]); |
| 970 | 970 | ||
| @@ -988,7 +988,7 @@ static int s3c_fb_suspend(struct platform_device *pdev, pm_message_t state) | |||
| 988 | struct s3c_fb_win *win; | 988 | struct s3c_fb_win *win; |
| 989 | int win_no; | 989 | int win_no; |
| 990 | 990 | ||
| 991 | for (win_no = S3C_FB_MAX_WIN; win_no >= 0; win_no--) { | 991 | for (win_no = S3C_FB_MAX_WIN - 1; win_no >= 0; win_no--) { |
| 992 | win = sfb->windows[win_no]; | 992 | win = sfb->windows[win_no]; |
| 993 | if (!win) | 993 | if (!win) |
| 994 | continue; | 994 | continue; |
diff --git a/drivers/video/sh_mobile_lcdcfb.c b/drivers/video/sh_mobile_lcdcfb.c index 8f24564f77b0..07f22b625632 100644 --- a/drivers/video/sh_mobile_lcdcfb.c +++ b/drivers/video/sh_mobile_lcdcfb.c | |||
| @@ -481,6 +481,9 @@ static int sh_mobile_lcdc_start(struct sh_mobile_lcdc_priv *priv) | |||
| 481 | /* tell the board code to enable the panel */ | 481 | /* tell the board code to enable the panel */ |
| 482 | for (k = 0; k < ARRAY_SIZE(priv->ch); k++) { | 482 | for (k = 0; k < ARRAY_SIZE(priv->ch); k++) { |
| 483 | ch = &priv->ch[k]; | 483 | ch = &priv->ch[k]; |
| 484 | if (!ch->enabled) | ||
| 485 | continue; | ||
| 486 | |||
| 484 | board_cfg = &ch->cfg.board_cfg; | 487 | board_cfg = &ch->cfg.board_cfg; |
| 485 | if (board_cfg->display_on) | 488 | if (board_cfg->display_on) |
| 486 | board_cfg->display_on(board_cfg->board_data); | 489 | board_cfg->display_on(board_cfg->board_data); |
| @@ -498,6 +501,8 @@ static void sh_mobile_lcdc_stop(struct sh_mobile_lcdc_priv *priv) | |||
| 498 | /* clean up deferred io and ask board code to disable panel */ | 501 | /* clean up deferred io and ask board code to disable panel */ |
| 499 | for (k = 0; k < ARRAY_SIZE(priv->ch); k++) { | 502 | for (k = 0; k < ARRAY_SIZE(priv->ch); k++) { |
| 500 | ch = &priv->ch[k]; | 503 | ch = &priv->ch[k]; |
| 504 | if (!ch->enabled) | ||
| 505 | continue; | ||
| 501 | 506 | ||
| 502 | /* deferred io mode: | 507 | /* deferred io mode: |
| 503 | * flush frame, and wait for frame end interrupt | 508 | * flush frame, and wait for frame end interrupt |
diff --git a/drivers/video/via/hw.c b/drivers/video/via/hw.c index fcd53ceb88fa..c8960003f47d 100644 --- a/drivers/video/via/hw.c +++ b/drivers/video/via/hw.c | |||
| @@ -2407,14 +2407,14 @@ int viafb_setmode(int vmode_index, int hor_res, int ver_res, int video_bpp, | |||
| 2407 | viafb_dvi_set_mode(viafb_get_mode_index | 2407 | viafb_dvi_set_mode(viafb_get_mode_index |
| 2408 | (viaparinfo->tmds_setting_info->h_active, | 2408 | (viaparinfo->tmds_setting_info->h_active, |
| 2409 | viaparinfo->tmds_setting_info-> | 2409 | viaparinfo->tmds_setting_info-> |
| 2410 | v_active, 1), | 2410 | v_active), |
| 2411 | video_bpp1, viaparinfo-> | 2411 | video_bpp1, viaparinfo-> |
| 2412 | tmds_setting_info->iga_path); | 2412 | tmds_setting_info->iga_path); |
| 2413 | } else { | 2413 | } else { |
| 2414 | viafb_dvi_set_mode(viafb_get_mode_index | 2414 | viafb_dvi_set_mode(viafb_get_mode_index |
| 2415 | (viaparinfo->tmds_setting_info->h_active, | 2415 | (viaparinfo->tmds_setting_info->h_active, |
| 2416 | viaparinfo-> | 2416 | viaparinfo-> |
| 2417 | tmds_setting_info->v_active, 0), | 2417 | tmds_setting_info->v_active), |
| 2418 | video_bpp, viaparinfo-> | 2418 | video_bpp, viaparinfo-> |
| 2419 | tmds_setting_info->iga_path); | 2419 | tmds_setting_info->iga_path); |
| 2420 | } | 2420 | } |
diff --git a/drivers/video/via/lcd.c b/drivers/video/via/lcd.c index 6c7290a6a447..78c6b3387947 100644 --- a/drivers/video/via/lcd.c +++ b/drivers/video/via/lcd.c | |||
| @@ -580,10 +580,7 @@ static void load_lcd_k400_patch_tbl(int set_hres, int set_vres, | |||
| 580 | int reg_num = 0; | 580 | int reg_num = 0; |
| 581 | struct io_reg *lcd_patch_reg = NULL; | 581 | struct io_reg *lcd_patch_reg = NULL; |
| 582 | 582 | ||
| 583 | if (viaparinfo->lvds_setting_info->iga_path == IGA2) | 583 | vmode_index = viafb_get_mode_index(set_hres, set_vres); |
| 584 | vmode_index = viafb_get_mode_index(set_hres, set_vres, 1); | ||
| 585 | else | ||
| 586 | vmode_index = viafb_get_mode_index(set_hres, set_vres, 0); | ||
| 587 | switch (panel_id) { | 584 | switch (panel_id) { |
| 588 | /* LCD 800x600 */ | 585 | /* LCD 800x600 */ |
| 589 | case LCD_PANEL_ID1_800X600: | 586 | case LCD_PANEL_ID1_800X600: |
| @@ -761,10 +758,7 @@ static void load_lcd_p880_patch_tbl(int set_hres, int set_vres, | |||
| 761 | int reg_num = 0; | 758 | int reg_num = 0; |
| 762 | struct io_reg *lcd_patch_reg = NULL; | 759 | struct io_reg *lcd_patch_reg = NULL; |
| 763 | 760 | ||
| 764 | if (viaparinfo->lvds_setting_info->iga_path == IGA2) | 761 | vmode_index = viafb_get_mode_index(set_hres, set_vres); |
| 765 | vmode_index = viafb_get_mode_index(set_hres, set_vres, 1); | ||
| 766 | else | ||
| 767 | vmode_index = viafb_get_mode_index(set_hres, set_vres, 0); | ||
| 768 | 762 | ||
| 769 | switch (panel_id) { | 763 | switch (panel_id) { |
| 770 | case LCD_PANEL_ID5_1400X1050: | 764 | case LCD_PANEL_ID5_1400X1050: |
| @@ -832,10 +826,7 @@ static void load_lcd_patch_regs(int set_hres, int set_vres, | |||
| 832 | { | 826 | { |
| 833 | int vmode_index; | 827 | int vmode_index; |
| 834 | 828 | ||
| 835 | if (viaparinfo->lvds_setting_info->iga_path == IGA2) | 829 | vmode_index = viafb_get_mode_index(set_hres, set_vres); |
| 836 | vmode_index = viafb_get_mode_index(set_hres, set_vres, 1); | ||
| 837 | else | ||
| 838 | vmode_index = viafb_get_mode_index(set_hres, set_vres, 0); | ||
| 839 | 830 | ||
| 840 | viafb_unlock_crt(); | 831 | viafb_unlock_crt(); |
| 841 | 832 | ||
diff --git a/drivers/video/via/viafbdev.c b/drivers/video/via/viafbdev.c index a0fec298216e..72833f3334b5 100644 --- a/drivers/video/via/viafbdev.c +++ b/drivers/video/via/viafbdev.c | |||
| @@ -32,7 +32,6 @@ static u32 pseudo_pal[17]; | |||
| 32 | /* video mode */ | 32 | /* video mode */ |
| 33 | static char *viafb_mode = "640x480"; | 33 | static char *viafb_mode = "640x480"; |
| 34 | static char *viafb_mode1 = "640x480"; | 34 | static char *viafb_mode1 = "640x480"; |
| 35 | static int viafb_resMode = VIA_RES_640X480; | ||
| 36 | 35 | ||
| 37 | /* Added for specifying active devices.*/ | 36 | /* Added for specifying active devices.*/ |
| 38 | char *viafb_active_dev = ""; | 37 | char *viafb_active_dev = ""; |
| @@ -56,47 +55,47 @@ static void viafb_get_video_device(u32 *video_dev_info); | |||
| 56 | 55 | ||
| 57 | /* Mode information */ | 56 | /* Mode information */ |
| 58 | static const struct viafb_modeinfo viafb_modentry[] = { | 57 | static const struct viafb_modeinfo viafb_modentry[] = { |
| 59 | {480, 640, VIA_RES_480X640, "480x640"}, | 58 | {480, 640, VIA_RES_480X640}, |
| 60 | {640, 480, VIA_RES_640X480, "640x480"}, | 59 | {640, 480, VIA_RES_640X480}, |
| 61 | {800, 480, VIA_RES_800X480, "800x480"}, | 60 | {800, 480, VIA_RES_800X480}, |
| 62 | {800, 600, VIA_RES_800X600, "800x600"}, | 61 | {800, 600, VIA_RES_800X600}, |
| 63 | {1024, 768, VIA_RES_1024X768, "1024x768"}, | 62 | {1024, 768, VIA_RES_1024X768}, |
| 64 | {1152, 864, VIA_RES_1152X864, "1152x864"}, | 63 | {1152, 864, VIA_RES_1152X864}, |
| 65 | {1280, 1024, VIA_RES_1280X1024, "1280x1024"}, | 64 | {1280, 1024, VIA_RES_1280X1024}, |
| 66 | {1600, 1200, VIA_RES_1600X1200, "1600x1200"}, | 65 | {1600, 1200, VIA_RES_1600X1200}, |
| 67 | {1440, 1050, VIA_RES_1440X1050, "1440x1050"}, | 66 | {1440, 1050, VIA_RES_1440X1050}, |
| 68 | {1280, 768, VIA_RES_1280X768, "1280x768"}, | 67 | {1280, 768, VIA_RES_1280X768,}, |
| 69 | {1280, 800, VIA_RES_1280X800, "1280x800"}, | 68 | {1280, 800, VIA_RES_1280X800}, |
| 70 | {1280, 960, VIA_RES_1280X960, "1280x960"}, | 69 | {1280, 960, VIA_RES_1280X960}, |
| 71 | {1920, 1440, VIA_RES_1920X1440, "1920x1440"}, | 70 | {1920, 1440, VIA_RES_1920X1440}, |
| 72 | {848, 480, VIA_RES_848X480, "848x480"}, | 71 | {848, 480, VIA_RES_848X480}, |
| 73 | {1400, 1050, VIA_RES_1400X1050, "1400x1050"}, | 72 | {1400, 1050, VIA_RES_1400X1050}, |
| 74 | {720, 480, VIA_RES_720X480, "720x480"}, | 73 | {720, 480, VIA_RES_720X480}, |
| 75 | {720, 576, VIA_RES_720X576, "720x576"}, | 74 | {720, 576, VIA_RES_720X576}, |
| 76 | {1024, 512, VIA_RES_1024X512, "1024x512"}, | 75 | {1024, 512, VIA_RES_1024X512}, |
| 77 | {1024, 576, VIA_RES_1024X576, "1024x576"}, | 76 | {1024, 576, VIA_RES_1024X576}, |
| 78 | {1024, 600, VIA_RES_1024X600, "1024x600"}, | 77 | {1024, 600, VIA_RES_1024X600}, |
| 79 | {1280, 720, VIA_RES_1280X720, "1280x720"}, | 78 | {1280, 720, VIA_RES_1280X720}, |
| 80 | {1920, 1080, VIA_RES_1920X1080, "1920x1080"}, | 79 | {1920, 1080, VIA_RES_1920X1080}, |
| 81 | {1366, 768, VIA_RES_1368X768, "1368x768"}, | 80 | {1366, 768, VIA_RES_1368X768}, |
| 82 | {1680, 1050, VIA_RES_1680X1050, "1680x1050"}, | 81 | {1680, 1050, VIA_RES_1680X1050}, |
| 83 | {960, 600, VIA_RES_960X600, "960x600"}, | 82 | {960, 600, VIA_RES_960X600}, |
| 84 | {1000, 600, VIA_RES_1000X600, "1000x600"}, | 83 | {1000, 600, VIA_RES_1000X600}, |
| 85 | {1024, 576, VIA_RES_1024X576, "1024x576"}, | 84 | {1024, 576, VIA_RES_1024X576}, |
| 86 | {1024, 600, VIA_RES_1024X600, "1024x600"}, | 85 | {1024, 600, VIA_RES_1024X600}, |
| 87 | {1088, 612, VIA_RES_1088X612, "1088x612"}, | 86 | {1088, 612, VIA_RES_1088X612}, |
| 88 | {1152, 720, VIA_RES_1152X720, "1152x720"}, | 87 | {1152, 720, VIA_RES_1152X720}, |
| 89 | {1200, 720, VIA_RES_1200X720, "1200x720"}, | 88 | {1200, 720, VIA_RES_1200X720}, |
| 90 | {1280, 600, VIA_RES_1280X600, "1280x600"}, | 89 | {1280, 600, VIA_RES_1280X600}, |
| 91 | {1360, 768, VIA_RES_1360X768, "1360x768"}, | 90 | {1360, 768, VIA_RES_1360X768}, |
| 92 | {1440, 900, VIA_RES_1440X900, "1440x900"}, | 91 | {1440, 900, VIA_RES_1440X900}, |
| 93 | {1600, 900, VIA_RES_1600X900, "1600x900"}, | 92 | {1600, 900, VIA_RES_1600X900}, |
| 94 | {1600, 1024, VIA_RES_1600X1024, "1600x1024"}, | 93 | {1600, 1024, VIA_RES_1600X1024}, |
| 95 | {1792, 1344, VIA_RES_1792X1344, "1792x1344"}, | 94 | {1792, 1344, VIA_RES_1792X1344}, |
| 96 | {1856, 1392, VIA_RES_1856X1392, "1856x1392"}, | 95 | {1856, 1392, VIA_RES_1856X1392}, |
| 97 | {1920, 1200, VIA_RES_1920X1200, "1920x1200"}, | 96 | {1920, 1200, VIA_RES_1920X1200}, |
| 98 | {2048, 1536, VIA_RES_2048X1536, "2048x1536"}, | 97 | {2048, 1536, VIA_RES_2048X1536}, |
| 99 | {0, 0, VIA_RES_INVALID, "640x480"} | 98 | {0, 0, VIA_RES_INVALID} |
| 100 | }; | 99 | }; |
| 101 | 100 | ||
| 102 | static struct fb_ops viafb_ops; | 101 | static struct fb_ops viafb_ops; |
| @@ -177,7 +176,7 @@ static int viafb_check_var(struct fb_var_screeninfo *var, | |||
| 177 | if (var->vmode & FB_VMODE_INTERLACED || var->vmode & FB_VMODE_DOUBLE) | 176 | if (var->vmode & FB_VMODE_INTERLACED || var->vmode & FB_VMODE_DOUBLE) |
| 178 | return -EINVAL; | 177 | return -EINVAL; |
| 179 | 178 | ||
| 180 | vmode_index = viafb_get_mode_index(var->xres, var->yres, 0); | 179 | vmode_index = viafb_get_mode_index(var->xres, var->yres); |
| 181 | if (vmode_index == VIA_RES_INVALID) { | 180 | if (vmode_index == VIA_RES_INVALID) { |
| 182 | DEBUG_MSG(KERN_INFO | 181 | DEBUG_MSG(KERN_INFO |
| 183 | "viafb: Mode %dx%dx%d not supported!!\n", | 182 | "viafb: Mode %dx%dx%d not supported!!\n", |
| @@ -233,14 +232,14 @@ static int viafb_set_par(struct fb_info *info) | |||
| 233 | viafb_update_device_setting(info->var.xres, info->var.yres, | 232 | viafb_update_device_setting(info->var.xres, info->var.yres, |
| 234 | info->var.bits_per_pixel, viafb_refresh, 0); | 233 | info->var.bits_per_pixel, viafb_refresh, 0); |
| 235 | 234 | ||
| 236 | vmode_index = viafb_get_mode_index(info->var.xres, info->var.yres, 0); | 235 | vmode_index = viafb_get_mode_index(info->var.xres, info->var.yres); |
| 237 | 236 | ||
| 238 | if (viafb_SAMM_ON == 1) { | 237 | if (viafb_SAMM_ON == 1) { |
| 239 | DEBUG_MSG(KERN_INFO | 238 | DEBUG_MSG(KERN_INFO |
| 240 | "viafb_second_xres = %d, viafb_second_yres = %d, bpp = %d\n", | 239 | "viafb_second_xres = %d, viafb_second_yres = %d, bpp = %d\n", |
| 241 | viafb_second_xres, viafb_second_yres, viafb_bpp1); | 240 | viafb_second_xres, viafb_second_yres, viafb_bpp1); |
| 242 | vmode_index1 = viafb_get_mode_index(viafb_second_xres, | 241 | vmode_index1 = viafb_get_mode_index(viafb_second_xres, |
| 243 | viafb_second_yres, 1); | 242 | viafb_second_yres); |
| 244 | DEBUG_MSG(KERN_INFO "->viafb_SAMM_ON: index=%d\n", | 243 | DEBUG_MSG(KERN_INFO "->viafb_SAMM_ON: index=%d\n", |
| 245 | vmode_index1); | 244 | vmode_index1); |
| 246 | 245 | ||
| @@ -1262,7 +1261,7 @@ static int viafb_sync(struct fb_info *info) | |||
| 1262 | return 0; | 1261 | return 0; |
| 1263 | } | 1262 | } |
| 1264 | 1263 | ||
| 1265 | int viafb_get_mode_index(int hres, int vres, int flag) | 1264 | int viafb_get_mode_index(int hres, int vres) |
| 1266 | { | 1265 | { |
| 1267 | u32 i; | 1266 | u32 i; |
| 1268 | DEBUG_MSG(KERN_INFO "viafb_get_mode_index!\n"); | 1267 | DEBUG_MSG(KERN_INFO "viafb_get_mode_index!\n"); |
| @@ -1272,13 +1271,7 @@ int viafb_get_mode_index(int hres, int vres, int flag) | |||
| 1272 | viafb_modentry[i].yres == vres) | 1271 | viafb_modentry[i].yres == vres) |
| 1273 | break; | 1272 | break; |
| 1274 | 1273 | ||
| 1275 | viafb_resMode = viafb_modentry[i].mode_index; | 1274 | return viafb_modentry[i].mode_index; |
| 1276 | if (flag) | ||
| 1277 | viafb_mode1 = viafb_modentry[i].mode_res; | ||
| 1278 | else | ||
| 1279 | viafb_mode = viafb_modentry[i].mode_res; | ||
| 1280 | |||
| 1281 | return viafb_resMode; | ||
| 1282 | } | 1275 | } |
| 1283 | 1276 | ||
| 1284 | static void check_available_device_to_enable(int device_id) | 1277 | static void check_available_device_to_enable(int device_id) |
| @@ -2199,7 +2192,7 @@ static int __devinit via_pci_probe(void) | |||
| 2199 | strict_strtoul(tmpc, 0, &default_xres); | 2192 | strict_strtoul(tmpc, 0, &default_xres); |
| 2200 | strict_strtoul(tmpm, 0, &default_yres); | 2193 | strict_strtoul(tmpm, 0, &default_yres); |
| 2201 | 2194 | ||
| 2202 | vmode_index = viafb_get_mode_index(default_xres, default_yres, 0); | 2195 | vmode_index = viafb_get_mode_index(default_xres, default_yres); |
| 2203 | DEBUG_MSG(KERN_INFO "0->index=%d\n", vmode_index); | 2196 | DEBUG_MSG(KERN_INFO "0->index=%d\n", vmode_index); |
| 2204 | 2197 | ||
| 2205 | if (viafb_SAMM_ON == 1) { | 2198 | if (viafb_SAMM_ON == 1) { |
diff --git a/drivers/video/via/viafbdev.h b/drivers/video/via/viafbdev.h index a4158e872878..227b000feb38 100644 --- a/drivers/video/via/viafbdev.h +++ b/drivers/video/via/viafbdev.h | |||
| @@ -81,7 +81,6 @@ struct viafb_modeinfo { | |||
| 81 | u32 xres; | 81 | u32 xres; |
| 82 | u32 yres; | 82 | u32 yres; |
| 83 | int mode_index; | 83 | int mode_index; |
| 84 | char *mode_res; | ||
| 85 | }; | 84 | }; |
| 86 | extern unsigned int viafb_second_virtual_yres; | 85 | extern unsigned int viafb_second_virtual_yres; |
| 87 | extern unsigned int viafb_second_virtual_xres; | 86 | extern unsigned int viafb_second_virtual_xres; |
| @@ -102,7 +101,7 @@ extern int strict_strtoul(const char *cp, unsigned int base, | |||
| 102 | void viafb_memory_pitch_patch(struct fb_info *info); | 101 | void viafb_memory_pitch_patch(struct fb_info *info); |
| 103 | void viafb_fill_var_timing_info(struct fb_var_screeninfo *var, int refresh, | 102 | void viafb_fill_var_timing_info(struct fb_var_screeninfo *var, int refresh, |
| 104 | int mode_index); | 103 | int mode_index); |
| 105 | int viafb_get_mode_index(int hres, int vres, int flag); | 104 | int viafb_get_mode_index(int hres, int vres); |
| 106 | u8 viafb_gpio_i2c_read_lvds(struct lvds_setting_information | 105 | u8 viafb_gpio_i2c_read_lvds(struct lvds_setting_information |
| 107 | *plvds_setting_info, struct lvds_chip_information | 106 | *plvds_setting_info, struct lvds_chip_information |
| 108 | *plvds_chip_info, u8 index); | 107 | *plvds_chip_info, u8 index); |
diff --git a/drivers/video/xen-fbfront.c b/drivers/video/xen-fbfront.c index 15502d5e3641..54cd91610174 100644 --- a/drivers/video/xen-fbfront.c +++ b/drivers/video/xen-fbfront.c | |||
| @@ -454,6 +454,10 @@ static int __devinit xenfb_probe(struct xenbus_device *dev, | |||
| 454 | 454 | ||
| 455 | xenfb_init_shared_page(info, fb_info); | 455 | xenfb_init_shared_page(info, fb_info); |
| 456 | 456 | ||
| 457 | ret = xenfb_connect_backend(dev, info); | ||
| 458 | if (ret < 0) | ||
| 459 | goto error; | ||
| 460 | |||
| 457 | ret = register_framebuffer(fb_info); | 461 | ret = register_framebuffer(fb_info); |
| 458 | if (ret) { | 462 | if (ret) { |
| 459 | fb_deferred_io_cleanup(fb_info); | 463 | fb_deferred_io_cleanup(fb_info); |
| @@ -464,10 +468,6 @@ static int __devinit xenfb_probe(struct xenbus_device *dev, | |||
| 464 | } | 468 | } |
| 465 | info->fb_info = fb_info; | 469 | info->fb_info = fb_info; |
| 466 | 470 | ||
| 467 | ret = xenfb_connect_backend(dev, info); | ||
| 468 | if (ret < 0) | ||
| 469 | goto error; | ||
| 470 | |||
| 471 | xenfb_make_preferred_console(); | 471 | xenfb_make_preferred_console(); |
| 472 | return 0; | 472 | return 0; |
| 473 | 473 | ||
diff --git a/drivers/virtio/virtio_pci.c b/drivers/virtio/virtio_pci.c index bcec78ffc765..248e00ec4dc1 100644 --- a/drivers/virtio/virtio_pci.c +++ b/drivers/virtio/virtio_pci.c | |||
| @@ -52,8 +52,10 @@ struct virtio_pci_device | |||
| 52 | char (*msix_names)[256]; | 52 | char (*msix_names)[256]; |
| 53 | /* Number of available vectors */ | 53 | /* Number of available vectors */ |
| 54 | unsigned msix_vectors; | 54 | unsigned msix_vectors; |
| 55 | /* Vectors allocated */ | 55 | /* Vectors allocated, excluding per-vq vectors if any */ |
| 56 | unsigned msix_used_vectors; | 56 | unsigned msix_used_vectors; |
| 57 | /* Whether we have vector per vq */ | ||
| 58 | bool per_vq_vectors; | ||
| 57 | }; | 59 | }; |
| 58 | 60 | ||
| 59 | /* Constants for MSI-X */ | 61 | /* Constants for MSI-X */ |
| @@ -258,7 +260,6 @@ static void vp_free_vectors(struct virtio_device *vdev) | |||
| 258 | 260 | ||
| 259 | for (i = 0; i < vp_dev->msix_used_vectors; ++i) | 261 | for (i = 0; i < vp_dev->msix_used_vectors; ++i) |
| 260 | free_irq(vp_dev->msix_entries[i].vector, vp_dev); | 262 | free_irq(vp_dev->msix_entries[i].vector, vp_dev); |
| 261 | vp_dev->msix_used_vectors = 0; | ||
| 262 | 263 | ||
| 263 | if (vp_dev->msix_enabled) { | 264 | if (vp_dev->msix_enabled) { |
| 264 | /* Disable the vector used for configuration */ | 265 | /* Disable the vector used for configuration */ |
| @@ -267,80 +268,77 @@ static void vp_free_vectors(struct virtio_device *vdev) | |||
| 267 | /* Flush the write out to device */ | 268 | /* Flush the write out to device */ |
| 268 | ioread16(vp_dev->ioaddr + VIRTIO_MSI_CONFIG_VECTOR); | 269 | ioread16(vp_dev->ioaddr + VIRTIO_MSI_CONFIG_VECTOR); |
| 269 | 270 | ||
| 270 | vp_dev->msix_enabled = 0; | ||
| 271 | pci_disable_msix(vp_dev->pci_dev); | 271 | pci_disable_msix(vp_dev->pci_dev); |
| 272 | vp_dev->msix_enabled = 0; | ||
| 273 | vp_dev->msix_vectors = 0; | ||
| 272 | } | 274 | } |
| 273 | } | ||
| 274 | 275 | ||
| 275 | static int vp_enable_msix(struct pci_dev *dev, struct msix_entry *entries, | 276 | vp_dev->msix_used_vectors = 0; |
| 276 | int *options, int noptions) | 277 | kfree(vp_dev->msix_names); |
| 277 | { | 278 | vp_dev->msix_names = NULL; |
| 278 | int i; | 279 | kfree(vp_dev->msix_entries); |
| 279 | for (i = 0; i < noptions; ++i) | 280 | vp_dev->msix_entries = NULL; |
| 280 | if (!pci_enable_msix(dev, entries, options[i])) | ||
| 281 | return options[i]; | ||
| 282 | return -EBUSY; | ||
| 283 | } | 281 | } |
| 284 | 282 | ||
| 285 | static int vp_request_vectors(struct virtio_device *vdev, unsigned max_vqs) | 283 | static int vp_request_vectors(struct virtio_device *vdev, int nvectors, |
| 284 | bool per_vq_vectors) | ||
| 286 | { | 285 | { |
| 287 | struct virtio_pci_device *vp_dev = to_vp_device(vdev); | 286 | struct virtio_pci_device *vp_dev = to_vp_device(vdev); |
| 288 | const char *name = dev_name(&vp_dev->vdev.dev); | 287 | const char *name = dev_name(&vp_dev->vdev.dev); |
| 289 | unsigned i, v; | 288 | unsigned i, v; |
| 290 | int err = -ENOMEM; | 289 | int err = -ENOMEM; |
| 291 | /* We want at most one vector per queue and one for config changes. | 290 | |
| 292 | * Fallback to separate vectors for config and a shared for queues. | 291 | if (!nvectors) { |
| 293 | * Finally fall back to regular interrupts. */ | 292 | /* Can't allocate MSI-X vectors, use regular interrupt */ |
| 294 | int options[] = { max_vqs + 1, 2 }; | 293 | vp_dev->msix_vectors = 0; |
| 295 | int nvectors = max(options[0], options[1]); | 294 | err = request_irq(vp_dev->pci_dev->irq, vp_interrupt, |
| 295 | IRQF_SHARED, name, vp_dev); | ||
| 296 | if (err) | ||
| 297 | return err; | ||
| 298 | vp_dev->intx_enabled = 1; | ||
| 299 | return 0; | ||
| 300 | } | ||
| 296 | 301 | ||
| 297 | vp_dev->msix_entries = kmalloc(nvectors * sizeof *vp_dev->msix_entries, | 302 | vp_dev->msix_entries = kmalloc(nvectors * sizeof *vp_dev->msix_entries, |
| 298 | GFP_KERNEL); | 303 | GFP_KERNEL); |
| 299 | if (!vp_dev->msix_entries) | 304 | if (!vp_dev->msix_entries) |
| 300 | goto error_entries; | 305 | goto error; |
| 301 | vp_dev->msix_names = kmalloc(nvectors * sizeof *vp_dev->msix_names, | 306 | vp_dev->msix_names = kmalloc(nvectors * sizeof *vp_dev->msix_names, |
| 302 | GFP_KERNEL); | 307 | GFP_KERNEL); |
| 303 | if (!vp_dev->msix_names) | 308 | if (!vp_dev->msix_names) |
| 304 | goto error_names; | 309 | goto error; |
| 305 | 310 | ||
| 306 | for (i = 0; i < nvectors; ++i) | 311 | for (i = 0; i < nvectors; ++i) |
| 307 | vp_dev->msix_entries[i].entry = i; | 312 | vp_dev->msix_entries[i].entry = i; |
| 308 | 313 | ||
| 309 | err = vp_enable_msix(vp_dev->pci_dev, vp_dev->msix_entries, | 314 | err = pci_enable_msix(vp_dev->pci_dev, vp_dev->msix_entries, nvectors); |
| 310 | options, ARRAY_SIZE(options)); | 315 | if (err > 0) |
| 311 | if (err < 0) { | 316 | err = -ENOSPC; |
| 312 | /* Can't allocate enough MSI-X vectors, use regular interrupt */ | 317 | if (err) |
| 313 | vp_dev->msix_vectors = 0; | 318 | goto error; |
| 314 | err = request_irq(vp_dev->pci_dev->irq, vp_interrupt, | 319 | vp_dev->msix_vectors = nvectors; |
| 315 | IRQF_SHARED, name, vp_dev); | 320 | vp_dev->msix_enabled = 1; |
| 316 | if (err) | 321 | |
| 317 | goto error_irq; | 322 | /* Set the vector used for configuration */ |
| 318 | vp_dev->intx_enabled = 1; | 323 | v = vp_dev->msix_used_vectors; |
| 319 | } else { | 324 | snprintf(vp_dev->msix_names[v], sizeof *vp_dev->msix_names, |
| 320 | vp_dev->msix_vectors = err; | 325 | "%s-config", name); |
| 321 | vp_dev->msix_enabled = 1; | 326 | err = request_irq(vp_dev->msix_entries[v].vector, |
| 322 | 327 | vp_config_changed, 0, vp_dev->msix_names[v], | |
| 323 | /* Set the vector used for configuration */ | 328 | vp_dev); |
| 324 | v = vp_dev->msix_used_vectors; | 329 | if (err) |
| 325 | snprintf(vp_dev->msix_names[v], sizeof *vp_dev->msix_names, | 330 | goto error; |
| 326 | "%s-config", name); | 331 | ++vp_dev->msix_used_vectors; |
| 327 | err = request_irq(vp_dev->msix_entries[v].vector, | 332 | |
| 328 | vp_config_changed, 0, vp_dev->msix_names[v], | 333 | iowrite16(v, vp_dev->ioaddr + VIRTIO_MSI_CONFIG_VECTOR); |
| 329 | vp_dev); | 334 | /* Verify we had enough resources to assign the vector */ |
| 330 | if (err) | 335 | v = ioread16(vp_dev->ioaddr + VIRTIO_MSI_CONFIG_VECTOR); |
| 331 | goto error_irq; | 336 | if (v == VIRTIO_MSI_NO_VECTOR) { |
| 332 | ++vp_dev->msix_used_vectors; | 337 | err = -EBUSY; |
| 333 | 338 | goto error; | |
| 334 | iowrite16(v, vp_dev->ioaddr + VIRTIO_MSI_CONFIG_VECTOR); | ||
| 335 | /* Verify we had enough resources to assign the vector */ | ||
| 336 | v = ioread16(vp_dev->ioaddr + VIRTIO_MSI_CONFIG_VECTOR); | ||
| 337 | if (v == VIRTIO_MSI_NO_VECTOR) { | ||
| 338 | err = -EBUSY; | ||
| 339 | goto error_irq; | ||
| 340 | } | ||
| 341 | } | 339 | } |
| 342 | 340 | ||
| 343 | if (vp_dev->msix_vectors && vp_dev->msix_vectors != max_vqs + 1) { | 341 | if (!per_vq_vectors) { |
| 344 | /* Shared vector for all VQs */ | 342 | /* Shared vector for all VQs */ |
| 345 | v = vp_dev->msix_used_vectors; | 343 | v = vp_dev->msix_used_vectors; |
| 346 | snprintf(vp_dev->msix_names[v], sizeof *vp_dev->msix_names, | 344 | snprintf(vp_dev->msix_names[v], sizeof *vp_dev->msix_names, |
| @@ -349,28 +347,25 @@ static int vp_request_vectors(struct virtio_device *vdev, unsigned max_vqs) | |||
| 349 | vp_vring_interrupt, 0, vp_dev->msix_names[v], | 347 | vp_vring_interrupt, 0, vp_dev->msix_names[v], |
| 350 | vp_dev); | 348 | vp_dev); |
| 351 | if (err) | 349 | if (err) |
| 352 | goto error_irq; | 350 | goto error; |
| 353 | ++vp_dev->msix_used_vectors; | 351 | ++vp_dev->msix_used_vectors; |
| 354 | } | 352 | } |
| 355 | return 0; | 353 | return 0; |
| 356 | error_irq: | 354 | error: |
| 357 | vp_free_vectors(vdev); | 355 | vp_free_vectors(vdev); |
| 358 | kfree(vp_dev->msix_names); | ||
| 359 | error_names: | ||
| 360 | kfree(vp_dev->msix_entries); | ||
| 361 | error_entries: | ||
| 362 | return err; | 356 | return err; |
| 363 | } | 357 | } |
| 364 | 358 | ||
| 365 | static struct virtqueue *vp_find_vq(struct virtio_device *vdev, unsigned index, | 359 | static struct virtqueue *vp_find_vq(struct virtio_device *vdev, unsigned index, |
| 366 | void (*callback)(struct virtqueue *vq), | 360 | void (*callback)(struct virtqueue *vq), |
| 367 | const char *name) | 361 | const char *name, |
| 362 | u16 vector) | ||
| 368 | { | 363 | { |
| 369 | struct virtio_pci_device *vp_dev = to_vp_device(vdev); | 364 | struct virtio_pci_device *vp_dev = to_vp_device(vdev); |
| 370 | struct virtio_pci_vq_info *info; | 365 | struct virtio_pci_vq_info *info; |
| 371 | struct virtqueue *vq; | 366 | struct virtqueue *vq; |
| 372 | unsigned long flags, size; | 367 | unsigned long flags, size; |
| 373 | u16 num, vector; | 368 | u16 num; |
| 374 | int err; | 369 | int err; |
| 375 | 370 | ||
| 376 | /* Select the queue we're interested in */ | 371 | /* Select the queue we're interested in */ |
| @@ -389,7 +384,7 @@ static struct virtqueue *vp_find_vq(struct virtio_device *vdev, unsigned index, | |||
| 389 | 384 | ||
| 390 | info->queue_index = index; | 385 | info->queue_index = index; |
| 391 | info->num = num; | 386 | info->num = num; |
| 392 | info->vector = VIRTIO_MSI_NO_VECTOR; | 387 | info->vector = vector; |
| 393 | 388 | ||
| 394 | size = PAGE_ALIGN(vring_size(num, VIRTIO_PCI_VRING_ALIGN)); | 389 | size = PAGE_ALIGN(vring_size(num, VIRTIO_PCI_VRING_ALIGN)); |
| 395 | info->queue = alloc_pages_exact(size, GFP_KERNEL|__GFP_ZERO); | 390 | info->queue = alloc_pages_exact(size, GFP_KERNEL|__GFP_ZERO); |
| @@ -413,22 +408,7 @@ static struct virtqueue *vp_find_vq(struct virtio_device *vdev, unsigned index, | |||
| 413 | vq->priv = info; | 408 | vq->priv = info; |
| 414 | info->vq = vq; | 409 | info->vq = vq; |
| 415 | 410 | ||
| 416 | /* allocate per-vq vector if available and necessary */ | 411 | if (vector != VIRTIO_MSI_NO_VECTOR) { |
| 417 | if (callback && vp_dev->msix_used_vectors < vp_dev->msix_vectors) { | ||
| 418 | vector = vp_dev->msix_used_vectors; | ||
| 419 | snprintf(vp_dev->msix_names[vector], sizeof *vp_dev->msix_names, | ||
| 420 | "%s-%s", dev_name(&vp_dev->vdev.dev), name); | ||
| 421 | err = request_irq(vp_dev->msix_entries[vector].vector, | ||
| 422 | vring_interrupt, 0, | ||
| 423 | vp_dev->msix_names[vector], vq); | ||
| 424 | if (err) | ||
| 425 | goto out_request_irq; | ||
| 426 | info->vector = vector; | ||
| 427 | ++vp_dev->msix_used_vectors; | ||
| 428 | } else | ||
| 429 | vector = VP_MSIX_VQ_VECTOR; | ||
| 430 | |||
| 431 | if (callback && vp_dev->msix_enabled) { | ||
| 432 | iowrite16(vector, vp_dev->ioaddr + VIRTIO_MSI_QUEUE_VECTOR); | 412 | iowrite16(vector, vp_dev->ioaddr + VIRTIO_MSI_QUEUE_VECTOR); |
| 433 | vector = ioread16(vp_dev->ioaddr + VIRTIO_MSI_QUEUE_VECTOR); | 413 | vector = ioread16(vp_dev->ioaddr + VIRTIO_MSI_QUEUE_VECTOR); |
| 434 | if (vector == VIRTIO_MSI_NO_VECTOR) { | 414 | if (vector == VIRTIO_MSI_NO_VECTOR) { |
| @@ -444,11 +424,6 @@ static struct virtqueue *vp_find_vq(struct virtio_device *vdev, unsigned index, | |||
| 444 | return vq; | 424 | return vq; |
| 445 | 425 | ||
| 446 | out_assign: | 426 | out_assign: |
| 447 | if (info->vector != VIRTIO_MSI_NO_VECTOR) { | ||
| 448 | free_irq(vp_dev->msix_entries[info->vector].vector, vq); | ||
| 449 | --vp_dev->msix_used_vectors; | ||
| 450 | } | ||
| 451 | out_request_irq: | ||
| 452 | vring_del_virtqueue(vq); | 427 | vring_del_virtqueue(vq); |
| 453 | out_activate_queue: | 428 | out_activate_queue: |
| 454 | iowrite32(0, vp_dev->ioaddr + VIRTIO_PCI_QUEUE_PFN); | 429 | iowrite32(0, vp_dev->ioaddr + VIRTIO_PCI_QUEUE_PFN); |
| @@ -462,12 +437,13 @@ static void vp_del_vq(struct virtqueue *vq) | |||
| 462 | { | 437 | { |
| 463 | struct virtio_pci_device *vp_dev = to_vp_device(vq->vdev); | 438 | struct virtio_pci_device *vp_dev = to_vp_device(vq->vdev); |
| 464 | struct virtio_pci_vq_info *info = vq->priv; | 439 | struct virtio_pci_vq_info *info = vq->priv; |
| 465 | unsigned long size; | 440 | unsigned long flags, size; |
| 466 | 441 | ||
| 467 | iowrite16(info->queue_index, vp_dev->ioaddr + VIRTIO_PCI_QUEUE_SEL); | 442 | spin_lock_irqsave(&vp_dev->lock, flags); |
| 443 | list_del(&info->node); | ||
| 444 | spin_unlock_irqrestore(&vp_dev->lock, flags); | ||
| 468 | 445 | ||
| 469 | if (info->vector != VIRTIO_MSI_NO_VECTOR) | 446 | iowrite16(info->queue_index, vp_dev->ioaddr + VIRTIO_PCI_QUEUE_SEL); |
| 470 | free_irq(vp_dev->msix_entries[info->vector].vector, vq); | ||
| 471 | 447 | ||
| 472 | if (vp_dev->msix_enabled) { | 448 | if (vp_dev->msix_enabled) { |
| 473 | iowrite16(VIRTIO_MSI_NO_VECTOR, | 449 | iowrite16(VIRTIO_MSI_NO_VECTOR, |
| @@ -489,36 +465,62 @@ static void vp_del_vq(struct virtqueue *vq) | |||
| 489 | /* the config->del_vqs() implementation */ | 465 | /* the config->del_vqs() implementation */ |
| 490 | static void vp_del_vqs(struct virtio_device *vdev) | 466 | static void vp_del_vqs(struct virtio_device *vdev) |
| 491 | { | 467 | { |
| 468 | struct virtio_pci_device *vp_dev = to_vp_device(vdev); | ||
| 492 | struct virtqueue *vq, *n; | 469 | struct virtqueue *vq, *n; |
| 470 | struct virtio_pci_vq_info *info; | ||
| 493 | 471 | ||
| 494 | list_for_each_entry_safe(vq, n, &vdev->vqs, list) | 472 | list_for_each_entry_safe(vq, n, &vdev->vqs, list) { |
| 473 | info = vq->priv; | ||
| 474 | if (vp_dev->per_vq_vectors) | ||
| 475 | free_irq(vp_dev->msix_entries[info->vector].vector, vq); | ||
| 495 | vp_del_vq(vq); | 476 | vp_del_vq(vq); |
| 477 | } | ||
| 478 | vp_dev->per_vq_vectors = false; | ||
| 496 | 479 | ||
| 497 | vp_free_vectors(vdev); | 480 | vp_free_vectors(vdev); |
| 498 | } | 481 | } |
| 499 | 482 | ||
| 500 | /* the config->find_vqs() implementation */ | 483 | static int vp_try_to_find_vqs(struct virtio_device *vdev, unsigned nvqs, |
| 501 | static int vp_find_vqs(struct virtio_device *vdev, unsigned nvqs, | 484 | struct virtqueue *vqs[], |
| 502 | struct virtqueue *vqs[], | 485 | vq_callback_t *callbacks[], |
| 503 | vq_callback_t *callbacks[], | 486 | const char *names[], |
| 504 | const char *names[]) | 487 | int nvectors, |
| 488 | bool per_vq_vectors) | ||
| 505 | { | 489 | { |
| 506 | int vectors = 0; | 490 | struct virtio_pci_device *vp_dev = to_vp_device(vdev); |
| 507 | int i, err; | 491 | u16 vector; |
| 508 | 492 | int i, err, allocated_vectors; | |
| 509 | /* How many vectors would we like? */ | ||
| 510 | for (i = 0; i < nvqs; ++i) | ||
| 511 | if (callbacks[i]) | ||
| 512 | ++vectors; | ||
| 513 | 493 | ||
| 514 | err = vp_request_vectors(vdev, vectors); | 494 | err = vp_request_vectors(vdev, nvectors, per_vq_vectors); |
| 515 | if (err) | 495 | if (err) |
| 516 | goto error_request; | 496 | goto error_request; |
| 517 | 497 | ||
| 498 | vp_dev->per_vq_vectors = per_vq_vectors; | ||
| 499 | allocated_vectors = vp_dev->msix_used_vectors; | ||
| 518 | for (i = 0; i < nvqs; ++i) { | 500 | for (i = 0; i < nvqs; ++i) { |
| 519 | vqs[i] = vp_find_vq(vdev, i, callbacks[i], names[i]); | 501 | if (!callbacks[i] || !vp_dev->msix_enabled) |
| 520 | if (IS_ERR(vqs[i])) | 502 | vector = VIRTIO_MSI_NO_VECTOR; |
| 503 | else if (vp_dev->per_vq_vectors) | ||
| 504 | vector = allocated_vectors++; | ||
| 505 | else | ||
| 506 | vector = VP_MSIX_VQ_VECTOR; | ||
| 507 | vqs[i] = vp_find_vq(vdev, i, callbacks[i], names[i], vector); | ||
| 508 | if (IS_ERR(vqs[i])) { | ||
| 509 | err = PTR_ERR(vqs[i]); | ||
| 521 | goto error_find; | 510 | goto error_find; |
| 511 | } | ||
| 512 | /* allocate per-vq irq if available and necessary */ | ||
| 513 | if (vp_dev->per_vq_vectors && vector != VIRTIO_MSI_NO_VECTOR) { | ||
| 514 | snprintf(vp_dev->msix_names[vector], sizeof *vp_dev->msix_names, | ||
| 515 | "%s-%s", dev_name(&vp_dev->vdev.dev), names[i]); | ||
| 516 | err = request_irq(vp_dev->msix_entries[vector].vector, | ||
| 517 | vring_interrupt, 0, | ||
| 518 | vp_dev->msix_names[vector], vqs[i]); | ||
| 519 | if (err) { | ||
| 520 | vp_del_vq(vqs[i]); | ||
| 521 | goto error_find; | ||
| 522 | } | ||
| 523 | } | ||
| 522 | } | 524 | } |
| 523 | return 0; | 525 | return 0; |
| 524 | 526 | ||
| @@ -526,7 +528,37 @@ error_find: | |||
| 526 | vp_del_vqs(vdev); | 528 | vp_del_vqs(vdev); |
| 527 | 529 | ||
| 528 | error_request: | 530 | error_request: |
| 529 | return PTR_ERR(vqs[i]); | 531 | return err; |
| 532 | } | ||
| 533 | |||
| 534 | /* the config->find_vqs() implementation */ | ||
| 535 | static int vp_find_vqs(struct virtio_device *vdev, unsigned nvqs, | ||
| 536 | struct virtqueue *vqs[], | ||
| 537 | vq_callback_t *callbacks[], | ||
| 538 | const char *names[]) | ||
| 539 | { | ||
| 540 | int vectors = 0; | ||
| 541 | int i, uninitialized_var(err); | ||
| 542 | |||
| 543 | /* How many vectors would we like? */ | ||
| 544 | for (i = 0; i < nvqs; ++i) | ||
| 545 | if (callbacks[i]) | ||
| 546 | ++vectors; | ||
| 547 | |||
| 548 | /* We want at most one vector per queue and one for config changes. */ | ||
| 549 | err = vp_try_to_find_vqs(vdev, nvqs, vqs, callbacks, names, | ||
| 550 | vectors + 1, true); | ||
| 551 | if (!err) | ||
| 552 | return 0; | ||
| 553 | /* Fallback to separate vectors for config and a shared for queues. */ | ||
| 554 | err = vp_try_to_find_vqs(vdev, nvqs, vqs, callbacks, names, | ||
| 555 | 2, false); | ||
| 556 | if (!err) | ||
| 557 | return 0; | ||
| 558 | /* Finally fall back to regular interrupts. */ | ||
| 559 | err = vp_try_to_find_vqs(vdev, nvqs, vqs, callbacks, names, | ||
| 560 | 0, false); | ||
| 561 | return err; | ||
| 530 | } | 562 | } |
| 531 | 563 | ||
| 532 | static struct virtio_config_ops virtio_pci_config_ops = { | 564 | static struct virtio_config_ops virtio_pci_config_ops = { |
diff --git a/drivers/w1/masters/omap_hdq.c b/drivers/w1/masters/omap_hdq.c index a7e3b706b9d3..0d92969404c3 100644 --- a/drivers/w1/masters/omap_hdq.c +++ b/drivers/w1/masters/omap_hdq.c | |||
| @@ -687,6 +687,7 @@ static int omap_hdq_remove(struct platform_device *pdev) | |||
| 687 | 687 | ||
| 688 | if (hdq_data->hdq_usecount) { | 688 | if (hdq_data->hdq_usecount) { |
| 689 | dev_dbg(&pdev->dev, "removed when use count is not zero\n"); | 689 | dev_dbg(&pdev->dev, "removed when use count is not zero\n"); |
| 690 | mutex_unlock(&hdq_data->hdq_mutex); | ||
| 690 | return -EBUSY; | 691 | return -EBUSY; |
| 691 | } | 692 | } |
| 692 | 693 | ||
diff --git a/drivers/watchdog/ar7_wdt.c b/drivers/watchdog/ar7_wdt.c index 3fe9742c23ca..2f8643efe92c 100644 --- a/drivers/watchdog/ar7_wdt.c +++ b/drivers/watchdog/ar7_wdt.c | |||
| @@ -37,7 +37,7 @@ | |||
| 37 | #include <linux/uaccess.h> | 37 | #include <linux/uaccess.h> |
| 38 | 38 | ||
| 39 | #include <asm/addrspace.h> | 39 | #include <asm/addrspace.h> |
| 40 | #include <asm/ar7/ar7.h> | 40 | #include <asm/mach-ar7/ar7.h> |
| 41 | 41 | ||
| 42 | #define DRVNAME "ar7_wdt" | 42 | #define DRVNAME "ar7_wdt" |
| 43 | #define LONGNAME "TI AR7 Watchdog Timer" | 43 | #define LONGNAME "TI AR7 Watchdog Timer" |
diff --git a/drivers/watchdog/coh901327_wdt.c b/drivers/watchdog/coh901327_wdt.c index fecb307d28e9..aec7cefdef21 100644 --- a/drivers/watchdog/coh901327_wdt.c +++ b/drivers/watchdog/coh901327_wdt.c | |||
| @@ -18,6 +18,7 @@ | |||
| 18 | #include <linux/bitops.h> | 18 | #include <linux/bitops.h> |
| 19 | #include <linux/uaccess.h> | 19 | #include <linux/uaccess.h> |
| 20 | #include <linux/clk.h> | 20 | #include <linux/clk.h> |
| 21 | #include <linux/delay.h> | ||
| 21 | 22 | ||
| 22 | #define DRV_NAME "WDOG COH 901 327" | 23 | #define DRV_NAME "WDOG COH 901 327" |
| 23 | 24 | ||
| @@ -92,6 +93,8 @@ static struct clk *clk; | |||
| 92 | static void coh901327_enable(u16 timeout) | 93 | static void coh901327_enable(u16 timeout) |
| 93 | { | 94 | { |
| 94 | u16 val; | 95 | u16 val; |
| 96 | unsigned long freq; | ||
| 97 | unsigned long delay_ns; | ||
| 95 | 98 | ||
| 96 | clk_enable(clk); | 99 | clk_enable(clk); |
| 97 | /* Restart timer if it is disabled */ | 100 | /* Restart timer if it is disabled */ |
| @@ -102,6 +105,14 @@ static void coh901327_enable(u16 timeout) | |||
| 102 | /* Acknowledge any pending interrupt so it doesn't just fire off */ | 105 | /* Acknowledge any pending interrupt so it doesn't just fire off */ |
| 103 | writew(U300_WDOG_IER_WILL_BARK_IRQ_ACK_ENABLE, | 106 | writew(U300_WDOG_IER_WILL_BARK_IRQ_ACK_ENABLE, |
| 104 | virtbase + U300_WDOG_IER); | 107 | virtbase + U300_WDOG_IER); |
| 108 | /* | ||
| 109 | * The interrupt is cleared in the 32 kHz clock domain. | ||
| 110 | * Wait 3 32 kHz cycles for it to take effect | ||
| 111 | */ | ||
| 112 | freq = clk_get_rate(clk); | ||
| 113 | delay_ns = (1000000000 + freq - 1) / freq; /* Freq to ns and round up */ | ||
| 114 | delay_ns = 3 * delay_ns; /* Wait 3 cycles */ | ||
| 115 | ndelay(delay_ns); | ||
| 105 | /* Enable the watchdog interrupt */ | 116 | /* Enable the watchdog interrupt */ |
| 106 | writew(U300_WDOG_IMR_WILL_BARK_IRQ_ENABLE, virtbase + U300_WDOG_IMR); | 117 | writew(U300_WDOG_IMR_WILL_BARK_IRQ_ENABLE, virtbase + U300_WDOG_IMR); |
| 107 | /* Activate the watchdog timer */ | 118 | /* Activate the watchdog timer */ |
diff --git a/drivers/watchdog/ks8695_wdt.c b/drivers/watchdog/ks8695_wdt.c index 00b03eb43bf0..e1c82769b08e 100644 --- a/drivers/watchdog/ks8695_wdt.c +++ b/drivers/watchdog/ks8695_wdt.c | |||
| @@ -66,7 +66,7 @@ static inline void ks8695_wdt_stop(void) | |||
| 66 | static inline void ks8695_wdt_start(void) | 66 | static inline void ks8695_wdt_start(void) |
| 67 | { | 67 | { |
| 68 | unsigned long tmcon; | 68 | unsigned long tmcon; |
| 69 | unsigned long tval = wdt_time * CLOCK_TICK_RATE; | 69 | unsigned long tval = wdt_time * KS8695_CLOCK_RATE; |
| 70 | 70 | ||
| 71 | spin_lock(&ks8695_lock); | 71 | spin_lock(&ks8695_lock); |
| 72 | /* disable timer0 */ | 72 | /* disable timer0 */ |
| @@ -103,7 +103,7 @@ static inline void ks8695_wdt_reload(void) | |||
| 103 | static int ks8695_wdt_settimeout(int new_time) | 103 | static int ks8695_wdt_settimeout(int new_time) |
| 104 | { | 104 | { |
| 105 | /* | 105 | /* |
| 106 | * All counting occurs at SLOW_CLOCK / 128 = 0.256 Hz | 106 | * All counting occurs at KS8695_CLOCK_RATE / 128 = 0.256 Hz |
| 107 | * | 107 | * |
| 108 | * Since WDV is a 16-bit counter, the maximum period is | 108 | * Since WDV is a 16-bit counter, the maximum period is |
| 109 | * 65536 / 0.256 = 256 seconds. | 109 | * 65536 / 0.256 = 256 seconds. |
diff --git a/fs/9p/v9fs.c b/fs/9p/v9fs.c index 332b5ff02fec..f7003cfac63d 100644 --- a/fs/9p/v9fs.c +++ b/fs/9p/v9fs.c | |||
| @@ -76,7 +76,7 @@ static const match_table_t tokens = { | |||
| 76 | * Return 0 upon success, -ERRNO upon failure. | 76 | * Return 0 upon success, -ERRNO upon failure. |
| 77 | */ | 77 | */ |
| 78 | 78 | ||
| 79 | static int v9fs_parse_options(struct v9fs_session_info *v9ses) | 79 | static int v9fs_parse_options(struct v9fs_session_info *v9ses, char *opts) |
| 80 | { | 80 | { |
| 81 | char *options; | 81 | char *options; |
| 82 | substring_t args[MAX_OPT_ARGS]; | 82 | substring_t args[MAX_OPT_ARGS]; |
| @@ -90,10 +90,10 @@ static int v9fs_parse_options(struct v9fs_session_info *v9ses) | |||
| 90 | v9ses->debug = 0; | 90 | v9ses->debug = 0; |
| 91 | v9ses->cache = 0; | 91 | v9ses->cache = 0; |
| 92 | 92 | ||
| 93 | if (!v9ses->options) | 93 | if (!opts) |
| 94 | return 0; | 94 | return 0; |
| 95 | 95 | ||
| 96 | options = kstrdup(v9ses->options, GFP_KERNEL); | 96 | options = kstrdup(opts, GFP_KERNEL); |
| 97 | if (!options) { | 97 | if (!options) { |
| 98 | P9_DPRINTK(P9_DEBUG_ERROR, | 98 | P9_DPRINTK(P9_DEBUG_ERROR, |
| 99 | "failed to allocate copy of option string\n"); | 99 | "failed to allocate copy of option string\n"); |
| @@ -206,24 +206,14 @@ struct p9_fid *v9fs_session_init(struct v9fs_session_info *v9ses, | |||
| 206 | v9ses->uid = ~0; | 206 | v9ses->uid = ~0; |
| 207 | v9ses->dfltuid = V9FS_DEFUID; | 207 | v9ses->dfltuid = V9FS_DEFUID; |
| 208 | v9ses->dfltgid = V9FS_DEFGID; | 208 | v9ses->dfltgid = V9FS_DEFGID; |
| 209 | if (data) { | ||
| 210 | v9ses->options = kstrdup(data, GFP_KERNEL); | ||
| 211 | if (!v9ses->options) { | ||
| 212 | P9_DPRINTK(P9_DEBUG_ERROR, | ||
| 213 | "failed to allocate copy of option string\n"); | ||
| 214 | retval = -ENOMEM; | ||
| 215 | goto error; | ||
| 216 | } | ||
| 217 | } | ||
| 218 | 209 | ||
| 219 | rc = v9fs_parse_options(v9ses); | 210 | rc = v9fs_parse_options(v9ses, data); |
| 220 | if (rc < 0) { | 211 | if (rc < 0) { |
| 221 | retval = rc; | 212 | retval = rc; |
| 222 | goto error; | 213 | goto error; |
| 223 | } | 214 | } |
| 224 | 215 | ||
| 225 | v9ses->clnt = p9_client_create(dev_name, v9ses->options); | 216 | v9ses->clnt = p9_client_create(dev_name, data); |
| 226 | |||
| 227 | if (IS_ERR(v9ses->clnt)) { | 217 | if (IS_ERR(v9ses->clnt)) { |
| 228 | retval = PTR_ERR(v9ses->clnt); | 218 | retval = PTR_ERR(v9ses->clnt); |
| 229 | v9ses->clnt = NULL; | 219 | v9ses->clnt = NULL; |
| @@ -280,7 +270,6 @@ void v9fs_session_close(struct v9fs_session_info *v9ses) | |||
| 280 | 270 | ||
| 281 | __putname(v9ses->uname); | 271 | __putname(v9ses->uname); |
| 282 | __putname(v9ses->aname); | 272 | __putname(v9ses->aname); |
| 283 | kfree(v9ses->options); | ||
| 284 | } | 273 | } |
| 285 | 274 | ||
| 286 | /** | 275 | /** |
diff --git a/fs/9p/v9fs.h b/fs/9p/v9fs.h index a7d567192998..38762bf102a9 100644 --- a/fs/9p/v9fs.h +++ b/fs/9p/v9fs.h | |||
| @@ -85,7 +85,6 @@ struct v9fs_session_info { | |||
| 85 | unsigned int afid; | 85 | unsigned int afid; |
| 86 | unsigned int cache; | 86 | unsigned int cache; |
| 87 | 87 | ||
| 88 | char *options; /* copy of mount options */ | ||
| 89 | char *uname; /* user name to mount as */ | 88 | char *uname; /* user name to mount as */ |
| 90 | char *aname; /* name of remote hierarchy being mounted */ | 89 | char *aname; /* name of remote hierarchy being mounted */ |
| 91 | unsigned int maxdata; /* max data for client interface */ | 90 | unsigned int maxdata; /* max data for client interface */ |
diff --git a/fs/9p/vfs_inode.c b/fs/9p/vfs_inode.c index 81f8bbf12f9f..06a223d50a81 100644 --- a/fs/9p/vfs_inode.c +++ b/fs/9p/vfs_inode.c | |||
| @@ -171,7 +171,6 @@ int v9fs_uflags2omode(int uflags, int extended) | |||
| 171 | 171 | ||
| 172 | /** | 172 | /** |
| 173 | * v9fs_blank_wstat - helper function to setup a 9P stat structure | 173 | * v9fs_blank_wstat - helper function to setup a 9P stat structure |
| 174 | * @v9ses: 9P session info (for determining extended mode) | ||
| 175 | * @wstat: structure to initialize | 174 | * @wstat: structure to initialize |
| 176 | * | 175 | * |
| 177 | */ | 176 | */ |
| @@ -207,65 +206,72 @@ v9fs_blank_wstat(struct p9_wstat *wstat) | |||
| 207 | 206 | ||
| 208 | struct inode *v9fs_get_inode(struct super_block *sb, int mode) | 207 | struct inode *v9fs_get_inode(struct super_block *sb, int mode) |
| 209 | { | 208 | { |
| 209 | int err; | ||
| 210 | struct inode *inode; | 210 | struct inode *inode; |
| 211 | struct v9fs_session_info *v9ses = sb->s_fs_info; | 211 | struct v9fs_session_info *v9ses = sb->s_fs_info; |
| 212 | 212 | ||
| 213 | P9_DPRINTK(P9_DEBUG_VFS, "super block: %p mode: %o\n", sb, mode); | 213 | P9_DPRINTK(P9_DEBUG_VFS, "super block: %p mode: %o\n", sb, mode); |
| 214 | 214 | ||
| 215 | inode = new_inode(sb); | 215 | inode = new_inode(sb); |
| 216 | if (inode) { | 216 | if (!inode) { |
| 217 | inode->i_mode = mode; | ||
| 218 | inode->i_uid = current_fsuid(); | ||
| 219 | inode->i_gid = current_fsgid(); | ||
| 220 | inode->i_blocks = 0; | ||
| 221 | inode->i_rdev = 0; | ||
| 222 | inode->i_atime = inode->i_mtime = inode->i_ctime = CURRENT_TIME; | ||
| 223 | inode->i_mapping->a_ops = &v9fs_addr_operations; | ||
| 224 | |||
| 225 | switch (mode & S_IFMT) { | ||
| 226 | case S_IFIFO: | ||
| 227 | case S_IFBLK: | ||
| 228 | case S_IFCHR: | ||
| 229 | case S_IFSOCK: | ||
| 230 | if (!v9fs_extended(v9ses)) { | ||
| 231 | P9_DPRINTK(P9_DEBUG_ERROR, | ||
| 232 | "special files without extended mode\n"); | ||
| 233 | return ERR_PTR(-EINVAL); | ||
| 234 | } | ||
| 235 | init_special_inode(inode, inode->i_mode, | ||
| 236 | inode->i_rdev); | ||
| 237 | break; | ||
| 238 | case S_IFREG: | ||
| 239 | inode->i_op = &v9fs_file_inode_operations; | ||
| 240 | inode->i_fop = &v9fs_file_operations; | ||
| 241 | break; | ||
| 242 | case S_IFLNK: | ||
| 243 | if (!v9fs_extended(v9ses)) { | ||
| 244 | P9_DPRINTK(P9_DEBUG_ERROR, | ||
| 245 | "extended modes used w/o 9P2000.u\n"); | ||
| 246 | return ERR_PTR(-EINVAL); | ||
| 247 | } | ||
| 248 | inode->i_op = &v9fs_symlink_inode_operations; | ||
| 249 | break; | ||
| 250 | case S_IFDIR: | ||
| 251 | inc_nlink(inode); | ||
| 252 | if (v9fs_extended(v9ses)) | ||
| 253 | inode->i_op = &v9fs_dir_inode_operations_ext; | ||
| 254 | else | ||
| 255 | inode->i_op = &v9fs_dir_inode_operations; | ||
| 256 | inode->i_fop = &v9fs_dir_operations; | ||
| 257 | break; | ||
| 258 | default: | ||
| 259 | P9_DPRINTK(P9_DEBUG_ERROR, | ||
| 260 | "BAD mode 0x%x S_IFMT 0x%x\n", | ||
| 261 | mode, mode & S_IFMT); | ||
| 262 | return ERR_PTR(-EINVAL); | ||
| 263 | } | ||
| 264 | } else { | ||
| 265 | P9_EPRINTK(KERN_WARNING, "Problem allocating inode\n"); | 217 | P9_EPRINTK(KERN_WARNING, "Problem allocating inode\n"); |
| 266 | return ERR_PTR(-ENOMEM); | 218 | return ERR_PTR(-ENOMEM); |
| 267 | } | 219 | } |
| 220 | |||
| 221 | inode->i_mode = mode; | ||
| 222 | inode->i_uid = current_fsuid(); | ||
| 223 | inode->i_gid = current_fsgid(); | ||
| 224 | inode->i_blocks = 0; | ||
| 225 | inode->i_rdev = 0; | ||
| 226 | inode->i_atime = inode->i_mtime = inode->i_ctime = CURRENT_TIME; | ||
| 227 | inode->i_mapping->a_ops = &v9fs_addr_operations; | ||
| 228 | |||
| 229 | switch (mode & S_IFMT) { | ||
| 230 | case S_IFIFO: | ||
| 231 | case S_IFBLK: | ||
| 232 | case S_IFCHR: | ||
| 233 | case S_IFSOCK: | ||
| 234 | if (!v9fs_extended(v9ses)) { | ||
| 235 | P9_DPRINTK(P9_DEBUG_ERROR, | ||
| 236 | "special files without extended mode\n"); | ||
| 237 | err = -EINVAL; | ||
| 238 | goto error; | ||
| 239 | } | ||
| 240 | init_special_inode(inode, inode->i_mode, inode->i_rdev); | ||
| 241 | break; | ||
| 242 | case S_IFREG: | ||
| 243 | inode->i_op = &v9fs_file_inode_operations; | ||
| 244 | inode->i_fop = &v9fs_file_operations; | ||
| 245 | break; | ||
| 246 | case S_IFLNK: | ||
| 247 | if (!v9fs_extended(v9ses)) { | ||
| 248 | P9_DPRINTK(P9_DEBUG_ERROR, | ||
| 249 | "extended modes used w/o 9P2000.u\n"); | ||
| 250 | err = -EINVAL; | ||
| 251 | goto error; | ||
| 252 | } | ||
| 253 | inode->i_op = &v9fs_symlink_inode_operations; | ||
| 254 | break; | ||
| 255 | case S_IFDIR: | ||
| 256 | inc_nlink(inode); | ||
| 257 | if (v9fs_extended(v9ses)) | ||
| 258 | inode->i_op = &v9fs_dir_inode_operations_ext; | ||
| 259 | else | ||
| 260 | inode->i_op = &v9fs_dir_inode_operations; | ||
| 261 | inode->i_fop = &v9fs_dir_operations; | ||
| 262 | break; | ||
| 263 | default: | ||
| 264 | P9_DPRINTK(P9_DEBUG_ERROR, "BAD mode 0x%x S_IFMT 0x%x\n", | ||
| 265 | mode, mode & S_IFMT); | ||
| 266 | err = -EINVAL; | ||
| 267 | goto error; | ||
| 268 | } | ||
| 269 | |||
| 268 | return inode; | 270 | return inode; |
| 271 | |||
| 272 | error: | ||
| 273 | iput(inode); | ||
| 274 | return ERR_PTR(err); | ||
| 269 | } | 275 | } |
| 270 | 276 | ||
| 271 | /* | 277 | /* |
| @@ -338,30 +344,25 @@ v9fs_inode_from_fid(struct v9fs_session_info *v9ses, struct p9_fid *fid, | |||
| 338 | 344 | ||
| 339 | ret = NULL; | 345 | ret = NULL; |
| 340 | st = p9_client_stat(fid); | 346 | st = p9_client_stat(fid); |
| 341 | if (IS_ERR(st)) { | 347 | if (IS_ERR(st)) |
| 342 | err = PTR_ERR(st); | 348 | return ERR_CAST(st); |
| 343 | st = NULL; | ||
| 344 | goto error; | ||
| 345 | } | ||
| 346 | 349 | ||
| 347 | umode = p9mode2unixmode(v9ses, st->mode); | 350 | umode = p9mode2unixmode(v9ses, st->mode); |
| 348 | ret = v9fs_get_inode(sb, umode); | 351 | ret = v9fs_get_inode(sb, umode); |
| 349 | if (IS_ERR(ret)) { | 352 | if (IS_ERR(ret)) { |
| 350 | err = PTR_ERR(ret); | 353 | err = PTR_ERR(ret); |
| 351 | ret = NULL; | ||
| 352 | goto error; | 354 | goto error; |
| 353 | } | 355 | } |
| 354 | 356 | ||
| 355 | v9fs_stat2inode(st, ret, sb); | 357 | v9fs_stat2inode(st, ret, sb); |
| 356 | ret->i_ino = v9fs_qid2ino(&st->qid); | 358 | ret->i_ino = v9fs_qid2ino(&st->qid); |
| 359 | p9stat_free(st); | ||
| 357 | kfree(st); | 360 | kfree(st); |
| 358 | return ret; | 361 | return ret; |
| 359 | 362 | ||
| 360 | error: | 363 | error: |
| 364 | p9stat_free(st); | ||
| 361 | kfree(st); | 365 | kfree(st); |
| 362 | if (ret) | ||
| 363 | iput(ret); | ||
| 364 | |||
| 365 | return ERR_PTR(err); | 366 | return ERR_PTR(err); |
| 366 | } | 367 | } |
| 367 | 368 | ||
| @@ -403,9 +404,9 @@ v9fs_open_created(struct inode *inode, struct file *file) | |||
| 403 | * @v9ses: session information | 404 | * @v9ses: session information |
| 404 | * @dir: directory that dentry is being created in | 405 | * @dir: directory that dentry is being created in |
| 405 | * @dentry: dentry that is being created | 406 | * @dentry: dentry that is being created |
| 407 | * @extension: 9p2000.u extension string to support devices, etc. | ||
| 406 | * @perm: create permissions | 408 | * @perm: create permissions |
| 407 | * @mode: open mode | 409 | * @mode: open mode |
| 408 | * @extension: 9p2000.u extension string to support devices, etc. | ||
| 409 | * | 410 | * |
| 410 | */ | 411 | */ |
| 411 | static struct p9_fid * | 412 | static struct p9_fid * |
| @@ -470,7 +471,10 @@ v9fs_create(struct v9fs_session_info *v9ses, struct inode *dir, | |||
| 470 | dentry->d_op = &v9fs_dentry_operations; | 471 | dentry->d_op = &v9fs_dentry_operations; |
| 471 | 472 | ||
| 472 | d_instantiate(dentry, inode); | 473 | d_instantiate(dentry, inode); |
| 473 | v9fs_fid_add(dentry, fid); | 474 | err = v9fs_fid_add(dentry, fid); |
| 475 | if (err < 0) | ||
| 476 | goto error; | ||
| 477 | |||
| 474 | return ofid; | 478 | return ofid; |
| 475 | 479 | ||
| 476 | error: | 480 | error: |
diff --git a/fs/9p/vfs_super.c b/fs/9p/vfs_super.c index 38d695d66a0b..8961f1a8f668 100644 --- a/fs/9p/vfs_super.c +++ b/fs/9p/vfs_super.c | |||
| @@ -81,7 +81,7 @@ static int v9fs_set_super(struct super_block *s, void *data) | |||
| 81 | 81 | ||
| 82 | static void | 82 | static void |
| 83 | v9fs_fill_super(struct super_block *sb, struct v9fs_session_info *v9ses, | 83 | v9fs_fill_super(struct super_block *sb, struct v9fs_session_info *v9ses, |
| 84 | int flags) | 84 | int flags, void *data) |
| 85 | { | 85 | { |
| 86 | sb->s_maxbytes = MAX_LFS_FILESIZE; | 86 | sb->s_maxbytes = MAX_LFS_FILESIZE; |
| 87 | sb->s_blocksize_bits = fls(v9ses->maxdata - 1); | 87 | sb->s_blocksize_bits = fls(v9ses->maxdata - 1); |
| @@ -91,6 +91,8 @@ v9fs_fill_super(struct super_block *sb, struct v9fs_session_info *v9ses, | |||
| 91 | 91 | ||
| 92 | sb->s_flags = flags | MS_ACTIVE | MS_SYNCHRONOUS | MS_DIRSYNC | | 92 | sb->s_flags = flags | MS_ACTIVE | MS_SYNCHRONOUS | MS_DIRSYNC | |
| 93 | MS_NOATIME; | 93 | MS_NOATIME; |
| 94 | |||
| 95 | save_mount_options(sb, data); | ||
| 94 | } | 96 | } |
| 95 | 97 | ||
| 96 | /** | 98 | /** |
| @@ -113,14 +115,11 @@ static int v9fs_get_sb(struct file_system_type *fs_type, int flags, | |||
| 113 | struct v9fs_session_info *v9ses = NULL; | 115 | struct v9fs_session_info *v9ses = NULL; |
| 114 | struct p9_wstat *st = NULL; | 116 | struct p9_wstat *st = NULL; |
| 115 | int mode = S_IRWXUGO | S_ISVTX; | 117 | int mode = S_IRWXUGO | S_ISVTX; |
| 116 | uid_t uid = current_fsuid(); | ||
| 117 | gid_t gid = current_fsgid(); | ||
| 118 | struct p9_fid *fid; | 118 | struct p9_fid *fid; |
| 119 | int retval = 0; | 119 | int retval = 0; |
| 120 | 120 | ||
| 121 | P9_DPRINTK(P9_DEBUG_VFS, " \n"); | 121 | P9_DPRINTK(P9_DEBUG_VFS, " \n"); |
| 122 | 122 | ||
| 123 | st = NULL; | ||
| 124 | v9ses = kzalloc(sizeof(struct v9fs_session_info), GFP_KERNEL); | 123 | v9ses = kzalloc(sizeof(struct v9fs_session_info), GFP_KERNEL); |
| 125 | if (!v9ses) | 124 | if (!v9ses) |
| 126 | return -ENOMEM; | 125 | return -ENOMEM; |
| @@ -142,7 +141,7 @@ static int v9fs_get_sb(struct file_system_type *fs_type, int flags, | |||
| 142 | retval = PTR_ERR(sb); | 141 | retval = PTR_ERR(sb); |
| 143 | goto free_stat; | 142 | goto free_stat; |
| 144 | } | 143 | } |
| 145 | v9fs_fill_super(sb, v9ses, flags); | 144 | v9fs_fill_super(sb, v9ses, flags, data); |
| 146 | 145 | ||
| 147 | inode = v9fs_get_inode(sb, S_IFDIR | mode); | 146 | inode = v9fs_get_inode(sb, S_IFDIR | mode); |
| 148 | if (IS_ERR(inode)) { | 147 | if (IS_ERR(inode)) { |
| @@ -150,9 +149,6 @@ static int v9fs_get_sb(struct file_system_type *fs_type, int flags, | |||
| 150 | goto release_sb; | 149 | goto release_sb; |
| 151 | } | 150 | } |
| 152 | 151 | ||
| 153 | inode->i_uid = uid; | ||
| 154 | inode->i_gid = gid; | ||
| 155 | |||
| 156 | root = d_alloc_root(inode); | 152 | root = d_alloc_root(inode); |
| 157 | if (!root) { | 153 | if (!root) { |
| 158 | iput(inode); | 154 | iput(inode); |
| @@ -173,10 +169,8 @@ P9_DPRINTK(P9_DEBUG_VFS, " simple set mount, return 0\n"); | |||
| 173 | simple_set_mnt(mnt, sb); | 169 | simple_set_mnt(mnt, sb); |
| 174 | return 0; | 170 | return 0; |
| 175 | 171 | ||
| 176 | release_sb: | ||
| 177 | deactivate_locked_super(sb); | ||
| 178 | |||
| 179 | free_stat: | 172 | free_stat: |
| 173 | p9stat_free(st); | ||
| 180 | kfree(st); | 174 | kfree(st); |
| 181 | 175 | ||
| 182 | clunk_fid: | 176 | clunk_fid: |
| @@ -185,7 +179,12 @@ clunk_fid: | |||
| 185 | close_session: | 179 | close_session: |
| 186 | v9fs_session_close(v9ses); | 180 | v9fs_session_close(v9ses); |
| 187 | kfree(v9ses); | 181 | kfree(v9ses); |
| 182 | return retval; | ||
| 188 | 183 | ||
| 184 | release_sb: | ||
| 185 | p9stat_free(st); | ||
| 186 | kfree(st); | ||
| 187 | deactivate_locked_super(sb); | ||
| 189 | return retval; | 188 | return retval; |
| 190 | } | 189 | } |
| 191 | 190 | ||
| @@ -207,24 +206,10 @@ static void v9fs_kill_super(struct super_block *s) | |||
| 207 | 206 | ||
| 208 | v9fs_session_close(v9ses); | 207 | v9fs_session_close(v9ses); |
| 209 | kfree(v9ses); | 208 | kfree(v9ses); |
| 209 | s->s_fs_info = NULL; | ||
| 210 | P9_DPRINTK(P9_DEBUG_VFS, "exiting kill_super\n"); | 210 | P9_DPRINTK(P9_DEBUG_VFS, "exiting kill_super\n"); |
| 211 | } | 211 | } |
| 212 | 212 | ||
| 213 | /** | ||
| 214 | * v9fs_show_options - Show mount options in /proc/mounts | ||
| 215 | * @m: seq_file to write to | ||
| 216 | * @mnt: mount descriptor | ||
| 217 | * | ||
| 218 | */ | ||
| 219 | |||
| 220 | static int v9fs_show_options(struct seq_file *m, struct vfsmount *mnt) | ||
| 221 | { | ||
| 222 | struct v9fs_session_info *v9ses = mnt->mnt_sb->s_fs_info; | ||
| 223 | |||
| 224 | seq_printf(m, "%s", v9ses->options); | ||
| 225 | return 0; | ||
| 226 | } | ||
| 227 | |||
| 228 | static void | 213 | static void |
| 229 | v9fs_umount_begin(struct super_block *sb) | 214 | v9fs_umount_begin(struct super_block *sb) |
| 230 | { | 215 | { |
| @@ -237,7 +222,7 @@ v9fs_umount_begin(struct super_block *sb) | |||
| 237 | static const struct super_operations v9fs_super_ops = { | 222 | static const struct super_operations v9fs_super_ops = { |
| 238 | .statfs = simple_statfs, | 223 | .statfs = simple_statfs, |
| 239 | .clear_inode = v9fs_clear_inode, | 224 | .clear_inode = v9fs_clear_inode, |
| 240 | .show_options = v9fs_show_options, | 225 | .show_options = generic_show_options, |
| 241 | .umount_begin = v9fs_umount_begin, | 226 | .umount_begin = v9fs_umount_begin, |
| 242 | }; | 227 | }; |
| 243 | 228 | ||
diff --git a/fs/Kconfig b/fs/Kconfig index a97263be6a91..0e7da7bb5d93 100644 --- a/fs/Kconfig +++ b/fs/Kconfig | |||
| @@ -186,32 +186,7 @@ source "fs/romfs/Kconfig" | |||
| 186 | source "fs/sysv/Kconfig" | 186 | source "fs/sysv/Kconfig" |
| 187 | source "fs/ufs/Kconfig" | 187 | source "fs/ufs/Kconfig" |
| 188 | source "fs/exofs/Kconfig" | 188 | source "fs/exofs/Kconfig" |
| 189 | 189 | source "fs/nilfs2/Kconfig" | |
| 190 | config NILFS2_FS | ||
| 191 | tristate "NILFS2 file system support (EXPERIMENTAL)" | ||
| 192 | depends on BLOCK && EXPERIMENTAL | ||
| 193 | select CRC32 | ||
| 194 | help | ||
| 195 | NILFS2 is a log-structured file system (LFS) supporting continuous | ||
| 196 | snapshotting. In addition to versioning capability of the entire | ||
| 197 | file system, users can even restore files mistakenly overwritten or | ||
| 198 | destroyed just a few seconds ago. Since this file system can keep | ||
| 199 | consistency like conventional LFS, it achieves quick recovery after | ||
| 200 | system crashes. | ||
| 201 | |||
| 202 | NILFS2 creates a number of checkpoints every few seconds or per | ||
| 203 | synchronous write basis (unless there is no change). Users can | ||
| 204 | select significant versions among continuously created checkpoints, | ||
| 205 | and can change them into snapshots which will be preserved for long | ||
| 206 | periods until they are changed back to checkpoints. Each | ||
| 207 | snapshot is mountable as a read-only file system concurrently with | ||
| 208 | its writable mount, and this feature is convenient for online backup. | ||
| 209 | |||
| 210 | Some features including atime, extended attributes, and POSIX ACLs, | ||
| 211 | are not supported yet. | ||
| 212 | |||
| 213 | To compile this file system support as a module, choose M here: the | ||
| 214 | module will be called nilfs2. If unsure, say N. | ||
| 215 | 190 | ||
| 216 | endif # MISC_FILESYSTEMS | 191 | endif # MISC_FILESYSTEMS |
| 217 | 192 | ||
diff --git a/fs/afs/file.c b/fs/afs/file.c index 0149dab365e7..681c2a7b013f 100644 --- a/fs/afs/file.c +++ b/fs/afs/file.c | |||
| @@ -134,9 +134,16 @@ static int afs_readpage(struct file *file, struct page *page) | |||
| 134 | 134 | ||
| 135 | inode = page->mapping->host; | 135 | inode = page->mapping->host; |
| 136 | 136 | ||
| 137 | ASSERT(file != NULL); | 137 | if (file) { |
| 138 | key = file->private_data; | 138 | key = file->private_data; |
| 139 | ASSERT(key != NULL); | 139 | ASSERT(key != NULL); |
| 140 | } else { | ||
| 141 | key = afs_request_key(AFS_FS_S(inode->i_sb)->volume->cell); | ||
| 142 | if (IS_ERR(key)) { | ||
| 143 | ret = PTR_ERR(key); | ||
| 144 | goto error_nokey; | ||
| 145 | } | ||
| 146 | } | ||
| 140 | 147 | ||
| 141 | _enter("{%x},{%lu},{%lu}", key_serial(key), inode->i_ino, page->index); | 148 | _enter("{%x},{%lu},{%lu}", key_serial(key), inode->i_ino, page->index); |
| 142 | 149 | ||
| @@ -207,12 +214,17 @@ static int afs_readpage(struct file *file, struct page *page) | |||
| 207 | unlock_page(page); | 214 | unlock_page(page); |
| 208 | } | 215 | } |
| 209 | 216 | ||
| 217 | if (!file) | ||
| 218 | key_put(key); | ||
| 210 | _leave(" = 0"); | 219 | _leave(" = 0"); |
| 211 | return 0; | 220 | return 0; |
| 212 | 221 | ||
| 213 | error: | 222 | error: |
| 214 | SetPageError(page); | 223 | SetPageError(page); |
| 215 | unlock_page(page); | 224 | unlock_page(page); |
| 225 | if (!file) | ||
| 226 | key_put(key); | ||
| 227 | error_nokey: | ||
| 216 | _leave(" = %d", ret); | 228 | _leave(" = %d", ret); |
| 217 | return ret; | 229 | return ret; |
| 218 | } | 230 | } |
diff --git a/fs/binfmt_flat.c b/fs/binfmt_flat.c index 697f6b5f1313..e92f229e3c6e 100644 --- a/fs/binfmt_flat.c +++ b/fs/binfmt_flat.c | |||
| @@ -828,15 +828,22 @@ static int load_flat_shared_library(int id, struct lib_info *libs) | |||
| 828 | if (IS_ERR(bprm.file)) | 828 | if (IS_ERR(bprm.file)) |
| 829 | return res; | 829 | return res; |
| 830 | 830 | ||
| 831 | bprm.cred = prepare_exec_creds(); | ||
| 832 | res = -ENOMEM; | ||
| 833 | if (!bprm.cred) | ||
| 834 | goto out; | ||
| 835 | |||
| 831 | res = prepare_binprm(&bprm); | 836 | res = prepare_binprm(&bprm); |
| 832 | 837 | ||
| 833 | if (res <= (unsigned long)-4096) | 838 | if (res <= (unsigned long)-4096) |
| 834 | res = load_flat_file(&bprm, libs, id, NULL); | 839 | res = load_flat_file(&bprm, libs, id, NULL); |
| 835 | if (bprm.file) { | 840 | |
| 836 | allow_write_access(bprm.file); | 841 | abort_creds(bprm.cred); |
| 837 | fput(bprm.file); | 842 | |
| 838 | bprm.file = NULL; | 843 | out: |
| 839 | } | 844 | allow_write_access(bprm.file); |
| 845 | fput(bprm.file); | ||
| 846 | |||
| 840 | return(res); | 847 | return(res); |
| 841 | } | 848 | } |
| 842 | 849 | ||
diff --git a/fs/block_dev.c b/fs/block_dev.c index 3a6d4fb2a329..94dfda24c06e 100644 --- a/fs/block_dev.c +++ b/fs/block_dev.c | |||
| @@ -564,6 +564,16 @@ struct block_device *bdget(dev_t dev) | |||
| 564 | 564 | ||
| 565 | EXPORT_SYMBOL(bdget); | 565 | EXPORT_SYMBOL(bdget); |
| 566 | 566 | ||
| 567 | /** | ||
| 568 | * bdgrab -- Grab a reference to an already referenced block device | ||
| 569 | * @bdev: Block device to grab a reference to. | ||
| 570 | */ | ||
| 571 | struct block_device *bdgrab(struct block_device *bdev) | ||
| 572 | { | ||
| 573 | atomic_inc(&bdev->bd_inode->i_count); | ||
| 574 | return bdev; | ||
| 575 | } | ||
| 576 | |||
| 567 | long nr_blockdev_pages(void) | 577 | long nr_blockdev_pages(void) |
| 568 | { | 578 | { |
| 569 | struct block_device *bdev; | 579 | struct block_device *bdev; |
diff --git a/fs/btrfs/async-thread.c b/fs/btrfs/async-thread.c index 6e4f6c50a120..019e8af449ab 100644 --- a/fs/btrfs/async-thread.c +++ b/fs/btrfs/async-thread.c | |||
| @@ -424,11 +424,11 @@ int btrfs_requeue_work(struct btrfs_work *work) | |||
| 424 | * list | 424 | * list |
| 425 | */ | 425 | */ |
| 426 | if (worker->idle) { | 426 | if (worker->idle) { |
| 427 | spin_lock_irqsave(&worker->workers->lock, flags); | 427 | spin_lock(&worker->workers->lock); |
| 428 | worker->idle = 0; | 428 | worker->idle = 0; |
| 429 | list_move_tail(&worker->worker_list, | 429 | list_move_tail(&worker->worker_list, |
| 430 | &worker->workers->worker_list); | 430 | &worker->workers->worker_list); |
| 431 | spin_unlock_irqrestore(&worker->workers->lock, flags); | 431 | spin_unlock(&worker->workers->lock); |
| 432 | } | 432 | } |
| 433 | if (!worker->working) { | 433 | if (!worker->working) { |
| 434 | wake = 1; | 434 | wake = 1; |
diff --git a/fs/btrfs/ctree.c b/fs/btrfs/ctree.c index 60a45f3a4e91..3fdcc0512d3a 100644 --- a/fs/btrfs/ctree.c +++ b/fs/btrfs/ctree.c | |||
| @@ -557,19 +557,7 @@ static int comp_keys(struct btrfs_disk_key *disk, struct btrfs_key *k2) | |||
| 557 | 557 | ||
| 558 | btrfs_disk_key_to_cpu(&k1, disk); | 558 | btrfs_disk_key_to_cpu(&k1, disk); |
| 559 | 559 | ||
| 560 | if (k1.objectid > k2->objectid) | 560 | return btrfs_comp_cpu_keys(&k1, k2); |
| 561 | return 1; | ||
| 562 | if (k1.objectid < k2->objectid) | ||
| 563 | return -1; | ||
| 564 | if (k1.type > k2->type) | ||
| 565 | return 1; | ||
| 566 | if (k1.type < k2->type) | ||
| 567 | return -1; | ||
| 568 | if (k1.offset > k2->offset) | ||
| 569 | return 1; | ||
| 570 | if (k1.offset < k2->offset) | ||
| 571 | return -1; | ||
| 572 | return 0; | ||
| 573 | } | 561 | } |
| 574 | 562 | ||
| 575 | /* | 563 | /* |
| @@ -1052,9 +1040,6 @@ static noinline int balance_level(struct btrfs_trans_handle *trans, | |||
| 1052 | BTRFS_NODEPTRS_PER_BLOCK(root) / 4) | 1040 | BTRFS_NODEPTRS_PER_BLOCK(root) / 4) |
| 1053 | return 0; | 1041 | return 0; |
| 1054 | 1042 | ||
| 1055 | if (btrfs_header_nritems(mid) > 2) | ||
| 1056 | return 0; | ||
| 1057 | |||
| 1058 | if (btrfs_header_nritems(mid) < 2) | 1043 | if (btrfs_header_nritems(mid) < 2) |
| 1059 | err_on_enospc = 1; | 1044 | err_on_enospc = 1; |
| 1060 | 1045 | ||
| @@ -1701,6 +1686,7 @@ int btrfs_search_slot(struct btrfs_trans_handle *trans, struct btrfs_root | |||
| 1701 | struct extent_buffer *b; | 1686 | struct extent_buffer *b; |
| 1702 | int slot; | 1687 | int slot; |
| 1703 | int ret; | 1688 | int ret; |
| 1689 | int err; | ||
| 1704 | int level; | 1690 | int level; |
| 1705 | int lowest_unlock = 1; | 1691 | int lowest_unlock = 1; |
| 1706 | u8 lowest_level = 0; | 1692 | u8 lowest_level = 0; |
| @@ -1737,8 +1723,6 @@ again: | |||
| 1737 | p->locks[level] = 1; | 1723 | p->locks[level] = 1; |
| 1738 | 1724 | ||
| 1739 | if (cow) { | 1725 | if (cow) { |
| 1740 | int wret; | ||
| 1741 | |||
| 1742 | /* | 1726 | /* |
| 1743 | * if we don't really need to cow this block | 1727 | * if we don't really need to cow this block |
| 1744 | * then we don't want to set the path blocking, | 1728 | * then we don't want to set the path blocking, |
| @@ -1749,12 +1733,12 @@ again: | |||
| 1749 | 1733 | ||
| 1750 | btrfs_set_path_blocking(p); | 1734 | btrfs_set_path_blocking(p); |
| 1751 | 1735 | ||
| 1752 | wret = btrfs_cow_block(trans, root, b, | 1736 | err = btrfs_cow_block(trans, root, b, |
| 1753 | p->nodes[level + 1], | 1737 | p->nodes[level + 1], |
| 1754 | p->slots[level + 1], &b); | 1738 | p->slots[level + 1], &b); |
| 1755 | if (wret) { | 1739 | if (err) { |
| 1756 | free_extent_buffer(b); | 1740 | free_extent_buffer(b); |
| 1757 | ret = wret; | 1741 | ret = err; |
| 1758 | goto done; | 1742 | goto done; |
| 1759 | } | 1743 | } |
| 1760 | } | 1744 | } |
| @@ -1793,41 +1777,45 @@ cow_done: | |||
| 1793 | ret = bin_search(b, key, level, &slot); | 1777 | ret = bin_search(b, key, level, &slot); |
| 1794 | 1778 | ||
| 1795 | if (level != 0) { | 1779 | if (level != 0) { |
| 1796 | if (ret && slot > 0) | 1780 | int dec = 0; |
| 1781 | if (ret && slot > 0) { | ||
| 1782 | dec = 1; | ||
| 1797 | slot -= 1; | 1783 | slot -= 1; |
| 1784 | } | ||
| 1798 | p->slots[level] = slot; | 1785 | p->slots[level] = slot; |
| 1799 | ret = setup_nodes_for_search(trans, root, p, b, level, | 1786 | err = setup_nodes_for_search(trans, root, p, b, level, |
| 1800 | ins_len); | 1787 | ins_len); |
| 1801 | if (ret == -EAGAIN) | 1788 | if (err == -EAGAIN) |
| 1802 | goto again; | 1789 | goto again; |
| 1803 | else if (ret) | 1790 | if (err) { |
| 1791 | ret = err; | ||
| 1804 | goto done; | 1792 | goto done; |
| 1793 | } | ||
| 1805 | b = p->nodes[level]; | 1794 | b = p->nodes[level]; |
| 1806 | slot = p->slots[level]; | 1795 | slot = p->slots[level]; |
| 1807 | 1796 | ||
| 1808 | unlock_up(p, level, lowest_unlock); | 1797 | unlock_up(p, level, lowest_unlock); |
| 1809 | 1798 | ||
| 1810 | /* this is only true while dropping a snapshot */ | ||
| 1811 | if (level == lowest_level) { | 1799 | if (level == lowest_level) { |
| 1812 | ret = 0; | 1800 | if (dec) |
| 1801 | p->slots[level]++; | ||
| 1813 | goto done; | 1802 | goto done; |
| 1814 | } | 1803 | } |
| 1815 | 1804 | ||
| 1816 | ret = read_block_for_search(trans, root, p, | 1805 | err = read_block_for_search(trans, root, p, |
| 1817 | &b, level, slot, key); | 1806 | &b, level, slot, key); |
| 1818 | if (ret == -EAGAIN) | 1807 | if (err == -EAGAIN) |
| 1819 | goto again; | 1808 | goto again; |
| 1820 | 1809 | if (err) { | |
| 1821 | if (ret == -EIO) | 1810 | ret = err; |
| 1822 | goto done; | 1811 | goto done; |
| 1812 | } | ||
| 1823 | 1813 | ||
| 1824 | if (!p->skip_locking) { | 1814 | if (!p->skip_locking) { |
| 1825 | int lret; | ||
| 1826 | |||
| 1827 | btrfs_clear_path_blocking(p, NULL); | 1815 | btrfs_clear_path_blocking(p, NULL); |
| 1828 | lret = btrfs_try_spin_lock(b); | 1816 | err = btrfs_try_spin_lock(b); |
| 1829 | 1817 | ||
| 1830 | if (!lret) { | 1818 | if (!err) { |
| 1831 | btrfs_set_path_blocking(p); | 1819 | btrfs_set_path_blocking(p); |
| 1832 | btrfs_tree_lock(b); | 1820 | btrfs_tree_lock(b); |
| 1833 | btrfs_clear_path_blocking(p, b); | 1821 | btrfs_clear_path_blocking(p, b); |
| @@ -1837,16 +1825,14 @@ cow_done: | |||
| 1837 | p->slots[level] = slot; | 1825 | p->slots[level] = slot; |
| 1838 | if (ins_len > 0 && | 1826 | if (ins_len > 0 && |
| 1839 | btrfs_leaf_free_space(root, b) < ins_len) { | 1827 | btrfs_leaf_free_space(root, b) < ins_len) { |
| 1840 | int sret; | ||
| 1841 | |||
| 1842 | btrfs_set_path_blocking(p); | 1828 | btrfs_set_path_blocking(p); |
| 1843 | sret = split_leaf(trans, root, key, | 1829 | err = split_leaf(trans, root, key, |
| 1844 | p, ins_len, ret == 0); | 1830 | p, ins_len, ret == 0); |
| 1845 | btrfs_clear_path_blocking(p, NULL); | 1831 | btrfs_clear_path_blocking(p, NULL); |
| 1846 | 1832 | ||
| 1847 | BUG_ON(sret > 0); | 1833 | BUG_ON(err > 0); |
| 1848 | if (sret) { | 1834 | if (err) { |
| 1849 | ret = sret; | 1835 | ret = err; |
| 1850 | goto done; | 1836 | goto done; |
| 1851 | } | 1837 | } |
| 1852 | } | 1838 | } |
| @@ -3807,7 +3793,7 @@ int btrfs_del_items(struct btrfs_trans_handle *trans, struct btrfs_root *root, | |||
| 3807 | } | 3793 | } |
| 3808 | 3794 | ||
| 3809 | /* delete the leaf if it is mostly empty */ | 3795 | /* delete the leaf if it is mostly empty */ |
| 3810 | if (used < BTRFS_LEAF_DATA_SIZE(root) / 2) { | 3796 | if (used < BTRFS_LEAF_DATA_SIZE(root) / 3) { |
| 3811 | /* push_leaf_left fixes the path. | 3797 | /* push_leaf_left fixes the path. |
| 3812 | * make sure the path still points to our leaf | 3798 | * make sure the path still points to our leaf |
| 3813 | * for possible call to del_ptr below | 3799 | * for possible call to del_ptr below |
| @@ -4042,10 +4028,9 @@ out: | |||
| 4042 | * calling this function. | 4028 | * calling this function. |
| 4043 | */ | 4029 | */ |
| 4044 | int btrfs_find_next_key(struct btrfs_root *root, struct btrfs_path *path, | 4030 | int btrfs_find_next_key(struct btrfs_root *root, struct btrfs_path *path, |
| 4045 | struct btrfs_key *key, int lowest_level, | 4031 | struct btrfs_key *key, int level, |
| 4046 | int cache_only, u64 min_trans) | 4032 | int cache_only, u64 min_trans) |
| 4047 | { | 4033 | { |
| 4048 | int level = lowest_level; | ||
| 4049 | int slot; | 4034 | int slot; |
| 4050 | struct extent_buffer *c; | 4035 | struct extent_buffer *c; |
| 4051 | 4036 | ||
| @@ -4058,11 +4043,40 @@ int btrfs_find_next_key(struct btrfs_root *root, struct btrfs_path *path, | |||
| 4058 | c = path->nodes[level]; | 4043 | c = path->nodes[level]; |
| 4059 | next: | 4044 | next: |
| 4060 | if (slot >= btrfs_header_nritems(c)) { | 4045 | if (slot >= btrfs_header_nritems(c)) { |
| 4061 | level++; | 4046 | int ret; |
| 4062 | if (level == BTRFS_MAX_LEVEL) | 4047 | int orig_lowest; |
| 4048 | struct btrfs_key cur_key; | ||
| 4049 | if (level + 1 >= BTRFS_MAX_LEVEL || | ||
| 4050 | !path->nodes[level + 1]) | ||
| 4063 | return 1; | 4051 | return 1; |
| 4064 | continue; | 4052 | |
| 4053 | if (path->locks[level + 1]) { | ||
| 4054 | level++; | ||
| 4055 | continue; | ||
| 4056 | } | ||
| 4057 | |||
| 4058 | slot = btrfs_header_nritems(c) - 1; | ||
| 4059 | if (level == 0) | ||
| 4060 | btrfs_item_key_to_cpu(c, &cur_key, slot); | ||
| 4061 | else | ||
| 4062 | btrfs_node_key_to_cpu(c, &cur_key, slot); | ||
| 4063 | |||
| 4064 | orig_lowest = path->lowest_level; | ||
| 4065 | btrfs_release_path(root, path); | ||
| 4066 | path->lowest_level = level; | ||
| 4067 | ret = btrfs_search_slot(NULL, root, &cur_key, path, | ||
| 4068 | 0, 0); | ||
| 4069 | path->lowest_level = orig_lowest; | ||
| 4070 | if (ret < 0) | ||
| 4071 | return ret; | ||
| 4072 | |||
| 4073 | c = path->nodes[level]; | ||
| 4074 | slot = path->slots[level]; | ||
| 4075 | if (ret == 0) | ||
| 4076 | slot++; | ||
| 4077 | goto next; | ||
| 4065 | } | 4078 | } |
| 4079 | |||
| 4066 | if (level == 0) | 4080 | if (level == 0) |
| 4067 | btrfs_item_key_to_cpu(c, key, slot); | 4081 | btrfs_item_key_to_cpu(c, key, slot); |
| 4068 | else { | 4082 | else { |
| @@ -4146,7 +4160,8 @@ again: | |||
| 4146 | * advance the path if there are now more items available. | 4160 | * advance the path if there are now more items available. |
| 4147 | */ | 4161 | */ |
| 4148 | if (nritems > 0 && path->slots[0] < nritems - 1) { | 4162 | if (nritems > 0 && path->slots[0] < nritems - 1) { |
| 4149 | path->slots[0]++; | 4163 | if (ret == 0) |
| 4164 | path->slots[0]++; | ||
| 4150 | ret = 0; | 4165 | ret = 0; |
| 4151 | goto done; | 4166 | goto done; |
| 4152 | } | 4167 | } |
| @@ -4278,10 +4293,10 @@ int btrfs_previous_item(struct btrfs_root *root, | |||
| 4278 | path->slots[0]--; | 4293 | path->slots[0]--; |
| 4279 | 4294 | ||
| 4280 | btrfs_item_key_to_cpu(leaf, &found_key, path->slots[0]); | 4295 | btrfs_item_key_to_cpu(leaf, &found_key, path->slots[0]); |
| 4281 | if (found_key.type == type) | ||
| 4282 | return 0; | ||
| 4283 | if (found_key.objectid < min_objectid) | 4296 | if (found_key.objectid < min_objectid) |
| 4284 | break; | 4297 | break; |
| 4298 | if (found_key.type == type) | ||
| 4299 | return 0; | ||
| 4285 | if (found_key.objectid == min_objectid && | 4300 | if (found_key.objectid == min_objectid && |
| 4286 | found_key.type < type) | 4301 | found_key.type < type) |
| 4287 | break; | 4302 | break; |
diff --git a/fs/btrfs/ctree.h b/fs/btrfs/ctree.h index 98a873838717..837435ce84ca 100644 --- a/fs/btrfs/ctree.h +++ b/fs/btrfs/ctree.h | |||
| @@ -481,7 +481,7 @@ struct btrfs_shared_data_ref { | |||
| 481 | 481 | ||
| 482 | struct btrfs_extent_inline_ref { | 482 | struct btrfs_extent_inline_ref { |
| 483 | u8 type; | 483 | u8 type; |
| 484 | u64 offset; | 484 | __le64 offset; |
| 485 | } __attribute__ ((__packed__)); | 485 | } __attribute__ ((__packed__)); |
| 486 | 486 | ||
| 487 | /* old style backrefs item */ | 487 | /* old style backrefs item */ |
| @@ -689,6 +689,7 @@ struct btrfs_space_info { | |||
| 689 | struct list_head block_groups; | 689 | struct list_head block_groups; |
| 690 | spinlock_t lock; | 690 | spinlock_t lock; |
| 691 | struct rw_semaphore groups_sem; | 691 | struct rw_semaphore groups_sem; |
| 692 | atomic_t caching_threads; | ||
| 692 | }; | 693 | }; |
| 693 | 694 | ||
| 694 | /* | 695 | /* |
| @@ -707,6 +708,9 @@ struct btrfs_free_cluster { | |||
| 707 | /* first extent starting offset */ | 708 | /* first extent starting offset */ |
| 708 | u64 window_start; | 709 | u64 window_start; |
| 709 | 710 | ||
| 711 | /* if this cluster simply points at a bitmap in the block group */ | ||
| 712 | bool points_to_bitmap; | ||
| 713 | |||
| 710 | struct btrfs_block_group_cache *block_group; | 714 | struct btrfs_block_group_cache *block_group; |
| 711 | /* | 715 | /* |
| 712 | * when a cluster is allocated from a block group, we put the | 716 | * when a cluster is allocated from a block group, we put the |
| @@ -716,24 +720,37 @@ struct btrfs_free_cluster { | |||
| 716 | struct list_head block_group_list; | 720 | struct list_head block_group_list; |
| 717 | }; | 721 | }; |
| 718 | 722 | ||
| 723 | enum btrfs_caching_type { | ||
| 724 | BTRFS_CACHE_NO = 0, | ||
| 725 | BTRFS_CACHE_STARTED = 1, | ||
| 726 | BTRFS_CACHE_FINISHED = 2, | ||
| 727 | }; | ||
| 728 | |||
| 719 | struct btrfs_block_group_cache { | 729 | struct btrfs_block_group_cache { |
| 720 | struct btrfs_key key; | 730 | struct btrfs_key key; |
| 721 | struct btrfs_block_group_item item; | 731 | struct btrfs_block_group_item item; |
| 732 | struct btrfs_fs_info *fs_info; | ||
| 722 | spinlock_t lock; | 733 | spinlock_t lock; |
| 723 | struct mutex cache_mutex; | ||
| 724 | u64 pinned; | 734 | u64 pinned; |
| 725 | u64 reserved; | 735 | u64 reserved; |
| 726 | u64 flags; | 736 | u64 flags; |
| 727 | int cached; | 737 | u64 sectorsize; |
| 738 | int extents_thresh; | ||
| 739 | int free_extents; | ||
| 740 | int total_bitmaps; | ||
| 728 | int ro; | 741 | int ro; |
| 729 | int dirty; | 742 | int dirty; |
| 730 | 743 | ||
| 744 | /* cache tracking stuff */ | ||
| 745 | wait_queue_head_t caching_q; | ||
| 746 | int cached; | ||
| 747 | |||
| 731 | struct btrfs_space_info *space_info; | 748 | struct btrfs_space_info *space_info; |
| 732 | 749 | ||
| 733 | /* free space cache stuff */ | 750 | /* free space cache stuff */ |
| 734 | spinlock_t tree_lock; | 751 | spinlock_t tree_lock; |
| 735 | struct rb_root free_space_bytes; | ||
| 736 | struct rb_root free_space_offset; | 752 | struct rb_root free_space_offset; |
| 753 | u64 free_space; | ||
| 737 | 754 | ||
| 738 | /* block group cache stuff */ | 755 | /* block group cache stuff */ |
| 739 | struct rb_node cache_node; | 756 | struct rb_node cache_node; |
| @@ -808,6 +825,7 @@ struct btrfs_fs_info { | |||
| 808 | struct mutex drop_mutex; | 825 | struct mutex drop_mutex; |
| 809 | struct mutex volume_mutex; | 826 | struct mutex volume_mutex; |
| 810 | struct mutex tree_reloc_mutex; | 827 | struct mutex tree_reloc_mutex; |
| 828 | struct rw_semaphore extent_commit_sem; | ||
| 811 | 829 | ||
| 812 | /* | 830 | /* |
| 813 | * this protects the ordered operations list only while we are | 831 | * this protects the ordered operations list only while we are |
| @@ -1988,6 +2006,7 @@ void btrfs_delalloc_reserve_space(struct btrfs_root *root, struct inode *inode, | |||
| 1988 | u64 bytes); | 2006 | u64 bytes); |
| 1989 | void btrfs_delalloc_free_space(struct btrfs_root *root, struct inode *inode, | 2007 | void btrfs_delalloc_free_space(struct btrfs_root *root, struct inode *inode, |
| 1990 | u64 bytes); | 2008 | u64 bytes); |
| 2009 | void btrfs_free_pinned_extents(struct btrfs_fs_info *info); | ||
| 1991 | /* ctree.c */ | 2010 | /* ctree.c */ |
| 1992 | int btrfs_bin_search(struct extent_buffer *eb, struct btrfs_key *key, | 2011 | int btrfs_bin_search(struct extent_buffer *eb, struct btrfs_key *key, |
| 1993 | int level, int *slot); | 2012 | int level, int *slot); |
diff --git a/fs/btrfs/disk-io.c b/fs/btrfs/disk-io.c index d28d29c95f7c..e83be2e4602c 100644 --- a/fs/btrfs/disk-io.c +++ b/fs/btrfs/disk-io.c | |||
| @@ -1639,6 +1639,7 @@ struct btrfs_root *open_ctree(struct super_block *sb, | |||
| 1639 | mutex_init(&fs_info->cleaner_mutex); | 1639 | mutex_init(&fs_info->cleaner_mutex); |
| 1640 | mutex_init(&fs_info->volume_mutex); | 1640 | mutex_init(&fs_info->volume_mutex); |
| 1641 | mutex_init(&fs_info->tree_reloc_mutex); | 1641 | mutex_init(&fs_info->tree_reloc_mutex); |
| 1642 | init_rwsem(&fs_info->extent_commit_sem); | ||
| 1642 | 1643 | ||
| 1643 | btrfs_init_free_cluster(&fs_info->meta_alloc_cluster); | 1644 | btrfs_init_free_cluster(&fs_info->meta_alloc_cluster); |
| 1644 | btrfs_init_free_cluster(&fs_info->data_alloc_cluster); | 1645 | btrfs_init_free_cluster(&fs_info->data_alloc_cluster); |
| @@ -1799,6 +1800,11 @@ struct btrfs_root *open_ctree(struct super_block *sb, | |||
| 1799 | btrfs_super_chunk_root(disk_super), | 1800 | btrfs_super_chunk_root(disk_super), |
| 1800 | blocksize, generation); | 1801 | blocksize, generation); |
| 1801 | BUG_ON(!chunk_root->node); | 1802 | BUG_ON(!chunk_root->node); |
| 1803 | if (!test_bit(EXTENT_BUFFER_UPTODATE, &chunk_root->node->bflags)) { | ||
| 1804 | printk(KERN_WARNING "btrfs: failed to read chunk root on %s\n", | ||
| 1805 | sb->s_id); | ||
| 1806 | goto fail_chunk_root; | ||
| 1807 | } | ||
| 1802 | btrfs_set_root_node(&chunk_root->root_item, chunk_root->node); | 1808 | btrfs_set_root_node(&chunk_root->root_item, chunk_root->node); |
| 1803 | chunk_root->commit_root = btrfs_root_node(chunk_root); | 1809 | chunk_root->commit_root = btrfs_root_node(chunk_root); |
| 1804 | 1810 | ||
| @@ -1826,6 +1832,11 @@ struct btrfs_root *open_ctree(struct super_block *sb, | |||
| 1826 | blocksize, generation); | 1832 | blocksize, generation); |
| 1827 | if (!tree_root->node) | 1833 | if (!tree_root->node) |
| 1828 | goto fail_chunk_root; | 1834 | goto fail_chunk_root; |
| 1835 | if (!test_bit(EXTENT_BUFFER_UPTODATE, &tree_root->node->bflags)) { | ||
| 1836 | printk(KERN_WARNING "btrfs: failed to read tree root on %s\n", | ||
| 1837 | sb->s_id); | ||
| 1838 | goto fail_tree_root; | ||
| 1839 | } | ||
| 1829 | btrfs_set_root_node(&tree_root->root_item, tree_root->node); | 1840 | btrfs_set_root_node(&tree_root->root_item, tree_root->node); |
| 1830 | tree_root->commit_root = btrfs_root_node(tree_root); | 1841 | tree_root->commit_root = btrfs_root_node(tree_root); |
| 1831 | 1842 | ||
| @@ -2322,6 +2333,9 @@ int close_ctree(struct btrfs_root *root) | |||
| 2322 | printk(KERN_ERR "btrfs: commit super ret %d\n", ret); | 2333 | printk(KERN_ERR "btrfs: commit super ret %d\n", ret); |
| 2323 | } | 2334 | } |
| 2324 | 2335 | ||
| 2336 | fs_info->closing = 2; | ||
| 2337 | smp_mb(); | ||
| 2338 | |||
| 2325 | if (fs_info->delalloc_bytes) { | 2339 | if (fs_info->delalloc_bytes) { |
| 2326 | printk(KERN_INFO "btrfs: at unmount delalloc count %llu\n", | 2340 | printk(KERN_INFO "btrfs: at unmount delalloc count %llu\n", |
| 2327 | (unsigned long long)fs_info->delalloc_bytes); | 2341 | (unsigned long long)fs_info->delalloc_bytes); |
| @@ -2343,6 +2357,7 @@ int close_ctree(struct btrfs_root *root) | |||
| 2343 | free_extent_buffer(root->fs_info->csum_root->commit_root); | 2357 | free_extent_buffer(root->fs_info->csum_root->commit_root); |
| 2344 | 2358 | ||
| 2345 | btrfs_free_block_groups(root->fs_info); | 2359 | btrfs_free_block_groups(root->fs_info); |
| 2360 | btrfs_free_pinned_extents(root->fs_info); | ||
| 2346 | 2361 | ||
| 2347 | del_fs_roots(fs_info); | 2362 | del_fs_roots(fs_info); |
| 2348 | 2363 | ||
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index a5aca3997d42..72a2b9c28e9f 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c | |||
| @@ -21,6 +21,7 @@ | |||
| 21 | #include <linux/blkdev.h> | 21 | #include <linux/blkdev.h> |
| 22 | #include <linux/sort.h> | 22 | #include <linux/sort.h> |
| 23 | #include <linux/rcupdate.h> | 23 | #include <linux/rcupdate.h> |
| 24 | #include <linux/kthread.h> | ||
| 24 | #include "compat.h" | 25 | #include "compat.h" |
| 25 | #include "hash.h" | 26 | #include "hash.h" |
| 26 | #include "ctree.h" | 27 | #include "ctree.h" |
| @@ -61,6 +62,13 @@ static int do_chunk_alloc(struct btrfs_trans_handle *trans, | |||
| 61 | struct btrfs_root *extent_root, u64 alloc_bytes, | 62 | struct btrfs_root *extent_root, u64 alloc_bytes, |
| 62 | u64 flags, int force); | 63 | u64 flags, int force); |
| 63 | 64 | ||
| 65 | static noinline int | ||
| 66 | block_group_cache_done(struct btrfs_block_group_cache *cache) | ||
| 67 | { | ||
| 68 | smp_mb(); | ||
| 69 | return cache->cached == BTRFS_CACHE_FINISHED; | ||
| 70 | } | ||
| 71 | |||
| 64 | static int block_group_bits(struct btrfs_block_group_cache *cache, u64 bits) | 72 | static int block_group_bits(struct btrfs_block_group_cache *cache, u64 bits) |
| 65 | { | 73 | { |
| 66 | return (cache->flags & bits) == bits; | 74 | return (cache->flags & bits) == bits; |
| @@ -146,20 +154,70 @@ block_group_cache_tree_search(struct btrfs_fs_info *info, u64 bytenr, | |||
| 146 | } | 154 | } |
| 147 | 155 | ||
| 148 | /* | 156 | /* |
| 157 | * We always set EXTENT_LOCKED for the super mirror extents so we don't | ||
| 158 | * overwrite them, so those bits need to be unset. Also, if we are unmounting | ||
| 159 | * with pinned extents still sitting there because we had a block group caching, | ||
| 160 | * we need to clear those now, since we are done. | ||
| 161 | */ | ||
| 162 | void btrfs_free_pinned_extents(struct btrfs_fs_info *info) | ||
| 163 | { | ||
| 164 | u64 start, end, last = 0; | ||
| 165 | int ret; | ||
| 166 | |||
| 167 | while (1) { | ||
| 168 | ret = find_first_extent_bit(&info->pinned_extents, last, | ||
| 169 | &start, &end, | ||
| 170 | EXTENT_LOCKED|EXTENT_DIRTY); | ||
| 171 | if (ret) | ||
| 172 | break; | ||
| 173 | |||
| 174 | clear_extent_bits(&info->pinned_extents, start, end, | ||
| 175 | EXTENT_LOCKED|EXTENT_DIRTY, GFP_NOFS); | ||
| 176 | last = end+1; | ||
| 177 | } | ||
| 178 | } | ||
| 179 | |||
| 180 | static int remove_sb_from_cache(struct btrfs_root *root, | ||
| 181 | struct btrfs_block_group_cache *cache) | ||
| 182 | { | ||
| 183 | struct btrfs_fs_info *fs_info = root->fs_info; | ||
| 184 | u64 bytenr; | ||
| 185 | u64 *logical; | ||
| 186 | int stripe_len; | ||
| 187 | int i, nr, ret; | ||
| 188 | |||
| 189 | for (i = 0; i < BTRFS_SUPER_MIRROR_MAX; i++) { | ||
| 190 | bytenr = btrfs_sb_offset(i); | ||
| 191 | ret = btrfs_rmap_block(&root->fs_info->mapping_tree, | ||
| 192 | cache->key.objectid, bytenr, | ||
| 193 | 0, &logical, &nr, &stripe_len); | ||
| 194 | BUG_ON(ret); | ||
| 195 | while (nr--) { | ||
| 196 | try_lock_extent(&fs_info->pinned_extents, | ||
| 197 | logical[nr], | ||
| 198 | logical[nr] + stripe_len - 1, GFP_NOFS); | ||
| 199 | } | ||
| 200 | kfree(logical); | ||
| 201 | } | ||
| 202 | |||
| 203 | return 0; | ||
| 204 | } | ||
| 205 | |||
| 206 | /* | ||
| 149 | * this is only called by cache_block_group, since we could have freed extents | 207 | * this is only called by cache_block_group, since we could have freed extents |
| 150 | * we need to check the pinned_extents for any extents that can't be used yet | 208 | * we need to check the pinned_extents for any extents that can't be used yet |
| 151 | * since their free space will be released as soon as the transaction commits. | 209 | * since their free space will be released as soon as the transaction commits. |
| 152 | */ | 210 | */ |
| 153 | static int add_new_free_space(struct btrfs_block_group_cache *block_group, | 211 | static u64 add_new_free_space(struct btrfs_block_group_cache *block_group, |
| 154 | struct btrfs_fs_info *info, u64 start, u64 end) | 212 | struct btrfs_fs_info *info, u64 start, u64 end) |
| 155 | { | 213 | { |
| 156 | u64 extent_start, extent_end, size; | 214 | u64 extent_start, extent_end, size, total_added = 0; |
| 157 | int ret; | 215 | int ret; |
| 158 | 216 | ||
| 159 | while (start < end) { | 217 | while (start < end) { |
| 160 | ret = find_first_extent_bit(&info->pinned_extents, start, | 218 | ret = find_first_extent_bit(&info->pinned_extents, start, |
| 161 | &extent_start, &extent_end, | 219 | &extent_start, &extent_end, |
| 162 | EXTENT_DIRTY); | 220 | EXTENT_DIRTY|EXTENT_LOCKED); |
| 163 | if (ret) | 221 | if (ret) |
| 164 | break; | 222 | break; |
| 165 | 223 | ||
| @@ -167,6 +225,7 @@ static int add_new_free_space(struct btrfs_block_group_cache *block_group, | |||
| 167 | start = extent_end + 1; | 225 | start = extent_end + 1; |
| 168 | } else if (extent_start > start && extent_start < end) { | 226 | } else if (extent_start > start && extent_start < end) { |
| 169 | size = extent_start - start; | 227 | size = extent_start - start; |
| 228 | total_added += size; | ||
| 170 | ret = btrfs_add_free_space(block_group, start, | 229 | ret = btrfs_add_free_space(block_group, start, |
| 171 | size); | 230 | size); |
| 172 | BUG_ON(ret); | 231 | BUG_ON(ret); |
| @@ -178,84 +237,93 @@ static int add_new_free_space(struct btrfs_block_group_cache *block_group, | |||
| 178 | 237 | ||
| 179 | if (start < end) { | 238 | if (start < end) { |
| 180 | size = end - start; | 239 | size = end - start; |
| 240 | total_added += size; | ||
| 181 | ret = btrfs_add_free_space(block_group, start, size); | 241 | ret = btrfs_add_free_space(block_group, start, size); |
| 182 | BUG_ON(ret); | 242 | BUG_ON(ret); |
| 183 | } | 243 | } |
| 184 | 244 | ||
| 185 | return 0; | 245 | return total_added; |
| 186 | } | ||
| 187 | |||
| 188 | static int remove_sb_from_cache(struct btrfs_root *root, | ||
| 189 | struct btrfs_block_group_cache *cache) | ||
| 190 | { | ||
| 191 | u64 bytenr; | ||
| 192 | u64 *logical; | ||
| 193 | int stripe_len; | ||
| 194 | int i, nr, ret; | ||
| 195 | |||
| 196 | for (i = 0; i < BTRFS_SUPER_MIRROR_MAX; i++) { | ||
| 197 | bytenr = btrfs_sb_offset(i); | ||
| 198 | ret = btrfs_rmap_block(&root->fs_info->mapping_tree, | ||
| 199 | cache->key.objectid, bytenr, 0, | ||
| 200 | &logical, &nr, &stripe_len); | ||
| 201 | BUG_ON(ret); | ||
| 202 | while (nr--) { | ||
| 203 | btrfs_remove_free_space(cache, logical[nr], | ||
| 204 | stripe_len); | ||
| 205 | } | ||
| 206 | kfree(logical); | ||
| 207 | } | ||
| 208 | return 0; | ||
| 209 | } | 246 | } |
| 210 | 247 | ||
| 211 | static int cache_block_group(struct btrfs_root *root, | 248 | static int caching_kthread(void *data) |
| 212 | struct btrfs_block_group_cache *block_group) | ||
| 213 | { | 249 | { |
| 250 | struct btrfs_block_group_cache *block_group = data; | ||
| 251 | struct btrfs_fs_info *fs_info = block_group->fs_info; | ||
| 252 | u64 last = 0; | ||
| 214 | struct btrfs_path *path; | 253 | struct btrfs_path *path; |
| 215 | int ret = 0; | 254 | int ret = 0; |
| 216 | struct btrfs_key key; | 255 | struct btrfs_key key; |
| 217 | struct extent_buffer *leaf; | 256 | struct extent_buffer *leaf; |
| 218 | int slot; | 257 | int slot; |
| 219 | u64 last; | 258 | u64 total_found = 0; |
| 220 | |||
| 221 | if (!block_group) | ||
| 222 | return 0; | ||
| 223 | |||
| 224 | root = root->fs_info->extent_root; | ||
| 225 | 259 | ||
| 226 | if (block_group->cached) | 260 | BUG_ON(!fs_info); |
| 227 | return 0; | ||
| 228 | 261 | ||
| 229 | path = btrfs_alloc_path(); | 262 | path = btrfs_alloc_path(); |
| 230 | if (!path) | 263 | if (!path) |
| 231 | return -ENOMEM; | 264 | return -ENOMEM; |
| 232 | 265 | ||
| 233 | path->reada = 2; | 266 | atomic_inc(&block_group->space_info->caching_threads); |
| 267 | last = max_t(u64, block_group->key.objectid, BTRFS_SUPER_INFO_OFFSET); | ||
| 234 | /* | 268 | /* |
| 235 | * we get into deadlocks with paths held by callers of this function. | 269 | * We don't want to deadlock with somebody trying to allocate a new |
| 236 | * since the alloc_mutex is protecting things right now, just | 270 | * extent for the extent root while also trying to search the extent |
| 237 | * skip the locking here | 271 | * root to add free space. So we skip locking and search the commit |
| 272 | * root, since its read-only | ||
| 238 | */ | 273 | */ |
| 239 | path->skip_locking = 1; | 274 | path->skip_locking = 1; |
| 240 | last = max_t(u64, block_group->key.objectid, BTRFS_SUPER_INFO_OFFSET); | 275 | path->search_commit_root = 1; |
| 276 | path->reada = 2; | ||
| 277 | |||
| 241 | key.objectid = last; | 278 | key.objectid = last; |
| 242 | key.offset = 0; | 279 | key.offset = 0; |
| 243 | btrfs_set_key_type(&key, BTRFS_EXTENT_ITEM_KEY); | 280 | btrfs_set_key_type(&key, BTRFS_EXTENT_ITEM_KEY); |
| 244 | ret = btrfs_search_slot(NULL, root, &key, path, 0, 0); | 281 | again: |
| 282 | /* need to make sure the commit_root doesn't disappear */ | ||
| 283 | down_read(&fs_info->extent_commit_sem); | ||
| 284 | |||
| 285 | ret = btrfs_search_slot(NULL, fs_info->extent_root, &key, path, 0, 0); | ||
| 245 | if (ret < 0) | 286 | if (ret < 0) |
| 246 | goto err; | 287 | goto err; |
| 247 | 288 | ||
| 248 | while (1) { | 289 | while (1) { |
| 290 | smp_mb(); | ||
| 291 | if (block_group->fs_info->closing > 1) { | ||
| 292 | last = (u64)-1; | ||
| 293 | break; | ||
| 294 | } | ||
| 295 | |||
| 249 | leaf = path->nodes[0]; | 296 | leaf = path->nodes[0]; |
| 250 | slot = path->slots[0]; | 297 | slot = path->slots[0]; |
| 251 | if (slot >= btrfs_header_nritems(leaf)) { | 298 | if (slot >= btrfs_header_nritems(leaf)) { |
| 252 | ret = btrfs_next_leaf(root, path); | 299 | ret = btrfs_next_leaf(fs_info->extent_root, path); |
| 253 | if (ret < 0) | 300 | if (ret < 0) |
| 254 | goto err; | 301 | goto err; |
| 255 | if (ret == 0) | 302 | else if (ret) |
| 256 | continue; | ||
| 257 | else | ||
| 258 | break; | 303 | break; |
| 304 | |||
| 305 | if (need_resched() || | ||
| 306 | btrfs_transaction_in_commit(fs_info)) { | ||
| 307 | leaf = path->nodes[0]; | ||
| 308 | |||
| 309 | /* this shouldn't happen, but if the | ||
| 310 | * leaf is empty just move on. | ||
| 311 | */ | ||
| 312 | if (btrfs_header_nritems(leaf) == 0) | ||
| 313 | break; | ||
| 314 | /* | ||
| 315 | * we need to copy the key out so that | ||
| 316 | * we are sure the next search advances | ||
| 317 | * us forward in the btree. | ||
| 318 | */ | ||
| 319 | btrfs_item_key_to_cpu(leaf, &key, 0); | ||
| 320 | btrfs_release_path(fs_info->extent_root, path); | ||
| 321 | up_read(&fs_info->extent_commit_sem); | ||
| 322 | schedule_timeout(1); | ||
| 323 | goto again; | ||
| 324 | } | ||
| 325 | |||
| 326 | continue; | ||
| 259 | } | 327 | } |
| 260 | btrfs_item_key_to_cpu(leaf, &key, slot); | 328 | btrfs_item_key_to_cpu(leaf, &key, slot); |
| 261 | if (key.objectid < block_group->key.objectid) | 329 | if (key.objectid < block_group->key.objectid) |
| @@ -266,24 +334,59 @@ static int cache_block_group(struct btrfs_root *root, | |||
| 266 | break; | 334 | break; |
| 267 | 335 | ||
| 268 | if (btrfs_key_type(&key) == BTRFS_EXTENT_ITEM_KEY) { | 336 | if (btrfs_key_type(&key) == BTRFS_EXTENT_ITEM_KEY) { |
| 269 | add_new_free_space(block_group, root->fs_info, last, | 337 | total_found += add_new_free_space(block_group, |
| 270 | key.objectid); | 338 | fs_info, last, |
| 271 | 339 | key.objectid); | |
| 272 | last = key.objectid + key.offset; | 340 | last = key.objectid + key.offset; |
| 273 | } | 341 | } |
| 342 | |||
| 343 | if (total_found > (1024 * 1024 * 2)) { | ||
| 344 | total_found = 0; | ||
| 345 | wake_up(&block_group->caching_q); | ||
| 346 | } | ||
| 274 | next: | 347 | next: |
| 275 | path->slots[0]++; | 348 | path->slots[0]++; |
| 276 | } | 349 | } |
| 350 | ret = 0; | ||
| 277 | 351 | ||
| 278 | add_new_free_space(block_group, root->fs_info, last, | 352 | total_found += add_new_free_space(block_group, fs_info, last, |
| 279 | block_group->key.objectid + | 353 | block_group->key.objectid + |
| 280 | block_group->key.offset); | 354 | block_group->key.offset); |
| 355 | |||
| 356 | spin_lock(&block_group->lock); | ||
| 357 | block_group->cached = BTRFS_CACHE_FINISHED; | ||
| 358 | spin_unlock(&block_group->lock); | ||
| 281 | 359 | ||
| 282 | block_group->cached = 1; | ||
| 283 | remove_sb_from_cache(root, block_group); | ||
| 284 | ret = 0; | ||
| 285 | err: | 360 | err: |
| 286 | btrfs_free_path(path); | 361 | btrfs_free_path(path); |
| 362 | up_read(&fs_info->extent_commit_sem); | ||
| 363 | atomic_dec(&block_group->space_info->caching_threads); | ||
| 364 | wake_up(&block_group->caching_q); | ||
| 365 | |||
| 366 | return 0; | ||
| 367 | } | ||
| 368 | |||
| 369 | static int cache_block_group(struct btrfs_block_group_cache *cache) | ||
| 370 | { | ||
| 371 | struct task_struct *tsk; | ||
| 372 | int ret = 0; | ||
| 373 | |||
| 374 | spin_lock(&cache->lock); | ||
| 375 | if (cache->cached != BTRFS_CACHE_NO) { | ||
| 376 | spin_unlock(&cache->lock); | ||
| 377 | return ret; | ||
| 378 | } | ||
| 379 | cache->cached = BTRFS_CACHE_STARTED; | ||
| 380 | spin_unlock(&cache->lock); | ||
| 381 | |||
| 382 | tsk = kthread_run(caching_kthread, cache, "btrfs-cache-%llu\n", | ||
| 383 | cache->key.objectid); | ||
| 384 | if (IS_ERR(tsk)) { | ||
| 385 | ret = PTR_ERR(tsk); | ||
| 386 | printk(KERN_ERR "error running thread %d\n", ret); | ||
| 387 | BUG(); | ||
| 388 | } | ||
| 389 | |||
| 287 | return ret; | 390 | return ret; |
| 288 | } | 391 | } |
| 289 | 392 | ||
| @@ -2387,13 +2490,29 @@ fail: | |||
| 2387 | 2490 | ||
| 2388 | } | 2491 | } |
| 2389 | 2492 | ||
| 2493 | static struct btrfs_block_group_cache * | ||
| 2494 | next_block_group(struct btrfs_root *root, | ||
| 2495 | struct btrfs_block_group_cache *cache) | ||
| 2496 | { | ||
| 2497 | struct rb_node *node; | ||
| 2498 | spin_lock(&root->fs_info->block_group_cache_lock); | ||
| 2499 | node = rb_next(&cache->cache_node); | ||
| 2500 | btrfs_put_block_group(cache); | ||
| 2501 | if (node) { | ||
| 2502 | cache = rb_entry(node, struct btrfs_block_group_cache, | ||
| 2503 | cache_node); | ||
| 2504 | atomic_inc(&cache->count); | ||
| 2505 | } else | ||
| 2506 | cache = NULL; | ||
| 2507 | spin_unlock(&root->fs_info->block_group_cache_lock); | ||
| 2508 | return cache; | ||
| 2509 | } | ||
| 2510 | |||
| 2390 | int btrfs_write_dirty_block_groups(struct btrfs_trans_handle *trans, | 2511 | int btrfs_write_dirty_block_groups(struct btrfs_trans_handle *trans, |
| 2391 | struct btrfs_root *root) | 2512 | struct btrfs_root *root) |
| 2392 | { | 2513 | { |
| 2393 | struct btrfs_block_group_cache *cache, *entry; | 2514 | struct btrfs_block_group_cache *cache; |
| 2394 | struct rb_node *n; | ||
| 2395 | int err = 0; | 2515 | int err = 0; |
| 2396 | int werr = 0; | ||
| 2397 | struct btrfs_path *path; | 2516 | struct btrfs_path *path; |
| 2398 | u64 last = 0; | 2517 | u64 last = 0; |
| 2399 | 2518 | ||
| @@ -2402,39 +2521,35 @@ int btrfs_write_dirty_block_groups(struct btrfs_trans_handle *trans, | |||
| 2402 | return -ENOMEM; | 2521 | return -ENOMEM; |
| 2403 | 2522 | ||
| 2404 | while (1) { | 2523 | while (1) { |
| 2405 | cache = NULL; | 2524 | if (last == 0) { |
| 2406 | spin_lock(&root->fs_info->block_group_cache_lock); | 2525 | err = btrfs_run_delayed_refs(trans, root, |
| 2407 | for (n = rb_first(&root->fs_info->block_group_cache_tree); | 2526 | (unsigned long)-1); |
| 2408 | n; n = rb_next(n)) { | 2527 | BUG_ON(err); |
| 2409 | entry = rb_entry(n, struct btrfs_block_group_cache, | ||
| 2410 | cache_node); | ||
| 2411 | if (entry->dirty) { | ||
| 2412 | cache = entry; | ||
| 2413 | break; | ||
| 2414 | } | ||
| 2415 | } | 2528 | } |
| 2416 | spin_unlock(&root->fs_info->block_group_cache_lock); | ||
| 2417 | 2529 | ||
| 2418 | if (!cache) | 2530 | cache = btrfs_lookup_first_block_group(root->fs_info, last); |
| 2419 | break; | 2531 | while (cache) { |
| 2532 | if (cache->dirty) | ||
| 2533 | break; | ||
| 2534 | cache = next_block_group(root, cache); | ||
| 2535 | } | ||
| 2536 | if (!cache) { | ||
| 2537 | if (last == 0) | ||
| 2538 | break; | ||
| 2539 | last = 0; | ||
| 2540 | continue; | ||
| 2541 | } | ||
| 2420 | 2542 | ||
| 2421 | cache->dirty = 0; | 2543 | cache->dirty = 0; |
| 2422 | last += cache->key.offset; | 2544 | last = cache->key.objectid + cache->key.offset; |
| 2423 | 2545 | ||
| 2424 | err = write_one_cache_group(trans, root, | 2546 | err = write_one_cache_group(trans, root, path, cache); |
| 2425 | path, cache); | 2547 | BUG_ON(err); |
| 2426 | /* | 2548 | btrfs_put_block_group(cache); |
| 2427 | * if we fail to write the cache group, we want | ||
| 2428 | * to keep it marked dirty in hopes that a later | ||
| 2429 | * write will work | ||
| 2430 | */ | ||
| 2431 | if (err) { | ||
| 2432 | werr = err; | ||
| 2433 | continue; | ||
| 2434 | } | ||
| 2435 | } | 2549 | } |
| 2550 | |||
| 2436 | btrfs_free_path(path); | 2551 | btrfs_free_path(path); |
| 2437 | return werr; | 2552 | return 0; |
| 2438 | } | 2553 | } |
| 2439 | 2554 | ||
| 2440 | int btrfs_extent_readonly(struct btrfs_root *root, u64 bytenr) | 2555 | int btrfs_extent_readonly(struct btrfs_root *root, u64 bytenr) |
| @@ -2484,6 +2599,7 @@ static int update_space_info(struct btrfs_fs_info *info, u64 flags, | |||
| 2484 | found->force_alloc = 0; | 2599 | found->force_alloc = 0; |
| 2485 | *space_info = found; | 2600 | *space_info = found; |
| 2486 | list_add_rcu(&found->list, &info->space_info); | 2601 | list_add_rcu(&found->list, &info->space_info); |
| 2602 | atomic_set(&found->caching_threads, 0); | ||
| 2487 | return 0; | 2603 | return 0; |
| 2488 | } | 2604 | } |
| 2489 | 2605 | ||
| @@ -2947,13 +3063,9 @@ int btrfs_update_pinned_extents(struct btrfs_root *root, | |||
| 2947 | struct btrfs_block_group_cache *cache; | 3063 | struct btrfs_block_group_cache *cache; |
| 2948 | struct btrfs_fs_info *fs_info = root->fs_info; | 3064 | struct btrfs_fs_info *fs_info = root->fs_info; |
| 2949 | 3065 | ||
| 2950 | if (pin) { | 3066 | if (pin) |
| 2951 | set_extent_dirty(&fs_info->pinned_extents, | 3067 | set_extent_dirty(&fs_info->pinned_extents, |
| 2952 | bytenr, bytenr + num - 1, GFP_NOFS); | 3068 | bytenr, bytenr + num - 1, GFP_NOFS); |
| 2953 | } else { | ||
| 2954 | clear_extent_dirty(&fs_info->pinned_extents, | ||
| 2955 | bytenr, bytenr + num - 1, GFP_NOFS); | ||
| 2956 | } | ||
| 2957 | 3069 | ||
| 2958 | while (num > 0) { | 3070 | while (num > 0) { |
| 2959 | cache = btrfs_lookup_block_group(fs_info, bytenr); | 3071 | cache = btrfs_lookup_block_group(fs_info, bytenr); |
| @@ -2969,14 +3081,34 @@ int btrfs_update_pinned_extents(struct btrfs_root *root, | |||
| 2969 | spin_unlock(&cache->space_info->lock); | 3081 | spin_unlock(&cache->space_info->lock); |
| 2970 | fs_info->total_pinned += len; | 3082 | fs_info->total_pinned += len; |
| 2971 | } else { | 3083 | } else { |
| 3084 | int unpin = 0; | ||
| 3085 | |||
| 3086 | /* | ||
| 3087 | * in order to not race with the block group caching, we | ||
| 3088 | * only want to unpin the extent if we are cached. If | ||
| 3089 | * we aren't cached, we want to start async caching this | ||
| 3090 | * block group so we can free the extent the next time | ||
| 3091 | * around. | ||
| 3092 | */ | ||
| 2972 | spin_lock(&cache->space_info->lock); | 3093 | spin_lock(&cache->space_info->lock); |
| 2973 | spin_lock(&cache->lock); | 3094 | spin_lock(&cache->lock); |
| 2974 | cache->pinned -= len; | 3095 | unpin = (cache->cached == BTRFS_CACHE_FINISHED); |
| 2975 | cache->space_info->bytes_pinned -= len; | 3096 | if (likely(unpin)) { |
| 3097 | cache->pinned -= len; | ||
| 3098 | cache->space_info->bytes_pinned -= len; | ||
| 3099 | fs_info->total_pinned -= len; | ||
| 3100 | } | ||
| 2976 | spin_unlock(&cache->lock); | 3101 | spin_unlock(&cache->lock); |
| 2977 | spin_unlock(&cache->space_info->lock); | 3102 | spin_unlock(&cache->space_info->lock); |
| 2978 | fs_info->total_pinned -= len; | 3103 | |
| 2979 | if (cache->cached) | 3104 | if (likely(unpin)) |
| 3105 | clear_extent_dirty(&fs_info->pinned_extents, | ||
| 3106 | bytenr, bytenr + len -1, | ||
| 3107 | GFP_NOFS); | ||
| 3108 | else | ||
| 3109 | cache_block_group(cache); | ||
| 3110 | |||
| 3111 | if (unpin) | ||
| 2980 | btrfs_add_free_space(cache, bytenr, len); | 3112 | btrfs_add_free_space(cache, bytenr, len); |
| 2981 | } | 3113 | } |
| 2982 | btrfs_put_block_group(cache); | 3114 | btrfs_put_block_group(cache); |
| @@ -3030,6 +3162,7 @@ int btrfs_copy_pinned(struct btrfs_root *root, struct extent_io_tree *copy) | |||
| 3030 | &start, &end, EXTENT_DIRTY); | 3162 | &start, &end, EXTENT_DIRTY); |
| 3031 | if (ret) | 3163 | if (ret) |
| 3032 | break; | 3164 | break; |
| 3165 | |||
| 3033 | set_extent_dirty(copy, start, end, GFP_NOFS); | 3166 | set_extent_dirty(copy, start, end, GFP_NOFS); |
| 3034 | last = end + 1; | 3167 | last = end + 1; |
| 3035 | } | 3168 | } |
| @@ -3058,6 +3191,7 @@ int btrfs_finish_extent_commit(struct btrfs_trans_handle *trans, | |||
| 3058 | 3191 | ||
| 3059 | cond_resched(); | 3192 | cond_resched(); |
| 3060 | } | 3193 | } |
| 3194 | |||
| 3061 | return ret; | 3195 | return ret; |
| 3062 | } | 3196 | } |
| 3063 | 3197 | ||
| @@ -3436,6 +3570,45 @@ static u64 stripe_align(struct btrfs_root *root, u64 val) | |||
| 3436 | } | 3570 | } |
| 3437 | 3571 | ||
| 3438 | /* | 3572 | /* |
| 3573 | * when we wait for progress in the block group caching, its because | ||
| 3574 | * our allocation attempt failed at least once. So, we must sleep | ||
| 3575 | * and let some progress happen before we try again. | ||
| 3576 | * | ||
| 3577 | * This function will sleep at least once waiting for new free space to | ||
| 3578 | * show up, and then it will check the block group free space numbers | ||
| 3579 | * for our min num_bytes. Another option is to have it go ahead | ||
| 3580 | * and look in the rbtree for a free extent of a given size, but this | ||
| 3581 | * is a good start. | ||
| 3582 | */ | ||
| 3583 | static noinline int | ||
| 3584 | wait_block_group_cache_progress(struct btrfs_block_group_cache *cache, | ||
| 3585 | u64 num_bytes) | ||
| 3586 | { | ||
| 3587 | DEFINE_WAIT(wait); | ||
| 3588 | |||
| 3589 | prepare_to_wait(&cache->caching_q, &wait, TASK_UNINTERRUPTIBLE); | ||
| 3590 | |||
| 3591 | if (block_group_cache_done(cache)) { | ||
| 3592 | finish_wait(&cache->caching_q, &wait); | ||
| 3593 | return 0; | ||
| 3594 | } | ||
| 3595 | schedule(); | ||
| 3596 | finish_wait(&cache->caching_q, &wait); | ||
| 3597 | |||
| 3598 | wait_event(cache->caching_q, block_group_cache_done(cache) || | ||
| 3599 | (cache->free_space >= num_bytes)); | ||
| 3600 | return 0; | ||
| 3601 | } | ||
| 3602 | |||
| 3603 | enum btrfs_loop_type { | ||
| 3604 | LOOP_CACHED_ONLY = 0, | ||
| 3605 | LOOP_CACHING_NOWAIT = 1, | ||
| 3606 | LOOP_CACHING_WAIT = 2, | ||
| 3607 | LOOP_ALLOC_CHUNK = 3, | ||
| 3608 | LOOP_NO_EMPTY_SIZE = 4, | ||
| 3609 | }; | ||
| 3610 | |||
| 3611 | /* | ||
| 3439 | * walks the btree of allocated extents and find a hole of a given size. | 3612 | * walks the btree of allocated extents and find a hole of a given size. |
| 3440 | * The key ins is changed to record the hole: | 3613 | * The key ins is changed to record the hole: |
| 3441 | * ins->objectid == block start | 3614 | * ins->objectid == block start |
| @@ -3460,6 +3633,7 @@ static noinline int find_free_extent(struct btrfs_trans_handle *trans, | |||
| 3460 | struct btrfs_space_info *space_info; | 3633 | struct btrfs_space_info *space_info; |
| 3461 | int last_ptr_loop = 0; | 3634 | int last_ptr_loop = 0; |
| 3462 | int loop = 0; | 3635 | int loop = 0; |
| 3636 | bool found_uncached_bg = false; | ||
| 3463 | 3637 | ||
| 3464 | WARN_ON(num_bytes < root->sectorsize); | 3638 | WARN_ON(num_bytes < root->sectorsize); |
| 3465 | btrfs_set_key_type(ins, BTRFS_EXTENT_ITEM_KEY); | 3639 | btrfs_set_key_type(ins, BTRFS_EXTENT_ITEM_KEY); |
| @@ -3491,15 +3665,18 @@ static noinline int find_free_extent(struct btrfs_trans_handle *trans, | |||
| 3491 | search_start = max(search_start, first_logical_byte(root, 0)); | 3665 | search_start = max(search_start, first_logical_byte(root, 0)); |
| 3492 | search_start = max(search_start, hint_byte); | 3666 | search_start = max(search_start, hint_byte); |
| 3493 | 3667 | ||
| 3494 | if (!last_ptr) { | 3668 | if (!last_ptr) |
| 3495 | empty_cluster = 0; | 3669 | empty_cluster = 0; |
| 3496 | loop = 1; | ||
| 3497 | } | ||
| 3498 | 3670 | ||
| 3499 | if (search_start == hint_byte) { | 3671 | if (search_start == hint_byte) { |
| 3500 | block_group = btrfs_lookup_block_group(root->fs_info, | 3672 | block_group = btrfs_lookup_block_group(root->fs_info, |
| 3501 | search_start); | 3673 | search_start); |
| 3502 | if (block_group && block_group_bits(block_group, data)) { | 3674 | /* |
| 3675 | * we don't want to use the block group if it doesn't match our | ||
| 3676 | * allocation bits, or if its not cached. | ||
| 3677 | */ | ||
| 3678 | if (block_group && block_group_bits(block_group, data) && | ||
| 3679 | block_group_cache_done(block_group)) { | ||
| 3503 | down_read(&space_info->groups_sem); | 3680 | down_read(&space_info->groups_sem); |
| 3504 | if (list_empty(&block_group->list) || | 3681 | if (list_empty(&block_group->list) || |
| 3505 | block_group->ro) { | 3682 | block_group->ro) { |
| @@ -3522,21 +3699,35 @@ search: | |||
| 3522 | down_read(&space_info->groups_sem); | 3699 | down_read(&space_info->groups_sem); |
| 3523 | list_for_each_entry(block_group, &space_info->block_groups, list) { | 3700 | list_for_each_entry(block_group, &space_info->block_groups, list) { |
| 3524 | u64 offset; | 3701 | u64 offset; |
| 3702 | int cached; | ||
| 3525 | 3703 | ||
| 3526 | atomic_inc(&block_group->count); | 3704 | atomic_inc(&block_group->count); |
| 3527 | search_start = block_group->key.objectid; | 3705 | search_start = block_group->key.objectid; |
| 3528 | 3706 | ||
| 3529 | have_block_group: | 3707 | have_block_group: |
| 3530 | if (unlikely(!block_group->cached)) { | 3708 | if (unlikely(block_group->cached == BTRFS_CACHE_NO)) { |
| 3531 | mutex_lock(&block_group->cache_mutex); | 3709 | /* |
| 3532 | ret = cache_block_group(root, block_group); | 3710 | * we want to start caching kthreads, but not too many |
| 3533 | mutex_unlock(&block_group->cache_mutex); | 3711 | * right off the bat so we don't overwhelm the system, |
| 3534 | if (ret) { | 3712 | * so only start them if there are less than 2 and we're |
| 3535 | btrfs_put_block_group(block_group); | 3713 | * in the initial allocation phase. |
| 3536 | break; | 3714 | */ |
| 3715 | if (loop > LOOP_CACHING_NOWAIT || | ||
| 3716 | atomic_read(&space_info->caching_threads) < 2) { | ||
| 3717 | ret = cache_block_group(block_group); | ||
| 3718 | BUG_ON(ret); | ||
| 3537 | } | 3719 | } |
| 3538 | } | 3720 | } |
| 3539 | 3721 | ||
| 3722 | cached = block_group_cache_done(block_group); | ||
| 3723 | if (unlikely(!cached)) { | ||
| 3724 | found_uncached_bg = true; | ||
| 3725 | |||
| 3726 | /* if we only want cached bgs, loop */ | ||
| 3727 | if (loop == LOOP_CACHED_ONLY) | ||
| 3728 | goto loop; | ||
| 3729 | } | ||
| 3730 | |||
| 3540 | if (unlikely(block_group->ro)) | 3731 | if (unlikely(block_group->ro)) |
| 3541 | goto loop; | 3732 | goto loop; |
| 3542 | 3733 | ||
| @@ -3615,14 +3806,21 @@ refill_cluster: | |||
| 3615 | spin_unlock(&last_ptr->refill_lock); | 3806 | spin_unlock(&last_ptr->refill_lock); |
| 3616 | goto checks; | 3807 | goto checks; |
| 3617 | } | 3808 | } |
| 3809 | } else if (!cached && loop > LOOP_CACHING_NOWAIT) { | ||
| 3810 | spin_unlock(&last_ptr->refill_lock); | ||
| 3811 | |||
| 3812 | wait_block_group_cache_progress(block_group, | ||
| 3813 | num_bytes + empty_cluster + empty_size); | ||
| 3814 | goto have_block_group; | ||
| 3618 | } | 3815 | } |
| 3816 | |||
| 3619 | /* | 3817 | /* |
| 3620 | * at this point we either didn't find a cluster | 3818 | * at this point we either didn't find a cluster |
| 3621 | * or we weren't able to allocate a block from our | 3819 | * or we weren't able to allocate a block from our |
| 3622 | * cluster. Free the cluster we've been trying | 3820 | * cluster. Free the cluster we've been trying |
| 3623 | * to use, and go to the next block group | 3821 | * to use, and go to the next block group |
| 3624 | */ | 3822 | */ |
| 3625 | if (loop < 2) { | 3823 | if (loop < LOOP_NO_EMPTY_SIZE) { |
| 3626 | btrfs_return_cluster_to_free_space(NULL, | 3824 | btrfs_return_cluster_to_free_space(NULL, |
| 3627 | last_ptr); | 3825 | last_ptr); |
| 3628 | spin_unlock(&last_ptr->refill_lock); | 3826 | spin_unlock(&last_ptr->refill_lock); |
| @@ -3633,11 +3831,17 @@ refill_cluster: | |||
| 3633 | 3831 | ||
| 3634 | offset = btrfs_find_space_for_alloc(block_group, search_start, | 3832 | offset = btrfs_find_space_for_alloc(block_group, search_start, |
| 3635 | num_bytes, empty_size); | 3833 | num_bytes, empty_size); |
| 3636 | if (!offset) | 3834 | if (!offset && (cached || (!cached && |
| 3835 | loop == LOOP_CACHING_NOWAIT))) { | ||
| 3637 | goto loop; | 3836 | goto loop; |
| 3837 | } else if (!offset && (!cached && | ||
| 3838 | loop > LOOP_CACHING_NOWAIT)) { | ||
| 3839 | wait_block_group_cache_progress(block_group, | ||
| 3840 | num_bytes + empty_size); | ||
| 3841 | goto have_block_group; | ||
| 3842 | } | ||
| 3638 | checks: | 3843 | checks: |
| 3639 | search_start = stripe_align(root, offset); | 3844 | search_start = stripe_align(root, offset); |
| 3640 | |||
| 3641 | /* move on to the next group */ | 3845 | /* move on to the next group */ |
| 3642 | if (search_start + num_bytes >= search_end) { | 3846 | if (search_start + num_bytes >= search_end) { |
| 3643 | btrfs_add_free_space(block_group, offset, num_bytes); | 3847 | btrfs_add_free_space(block_group, offset, num_bytes); |
| @@ -3683,13 +3887,26 @@ loop: | |||
| 3683 | } | 3887 | } |
| 3684 | up_read(&space_info->groups_sem); | 3888 | up_read(&space_info->groups_sem); |
| 3685 | 3889 | ||
| 3686 | /* loop == 0, try to find a clustered alloc in every block group | 3890 | /* LOOP_CACHED_ONLY, only search fully cached block groups |
| 3687 | * loop == 1, try again after forcing a chunk allocation | 3891 | * LOOP_CACHING_NOWAIT, search partially cached block groups, but |
| 3688 | * loop == 2, set empty_size and empty_cluster to 0 and try again | 3892 | * dont wait foR them to finish caching |
| 3893 | * LOOP_CACHING_WAIT, search everything, and wait if our bg is caching | ||
| 3894 | * LOOP_ALLOC_CHUNK, force a chunk allocation and try again | ||
| 3895 | * LOOP_NO_EMPTY_SIZE, set empty_size and empty_cluster to 0 and try | ||
| 3896 | * again | ||
| 3689 | */ | 3897 | */ |
| 3690 | if (!ins->objectid && loop < 3 && | 3898 | if (!ins->objectid && loop < LOOP_NO_EMPTY_SIZE && |
| 3691 | (empty_size || empty_cluster || allowed_chunk_alloc)) { | 3899 | (found_uncached_bg || empty_size || empty_cluster || |
| 3692 | if (loop >= 2) { | 3900 | allowed_chunk_alloc)) { |
| 3901 | if (found_uncached_bg) { | ||
| 3902 | found_uncached_bg = false; | ||
| 3903 | if (loop < LOOP_CACHING_WAIT) { | ||
| 3904 | loop++; | ||
| 3905 | goto search; | ||
| 3906 | } | ||
| 3907 | } | ||
| 3908 | |||
| 3909 | if (loop == LOOP_ALLOC_CHUNK) { | ||
| 3693 | empty_size = 0; | 3910 | empty_size = 0; |
| 3694 | empty_cluster = 0; | 3911 | empty_cluster = 0; |
| 3695 | } | 3912 | } |
| @@ -3702,7 +3919,7 @@ loop: | |||
| 3702 | space_info->force_alloc = 1; | 3919 | space_info->force_alloc = 1; |
| 3703 | } | 3920 | } |
| 3704 | 3921 | ||
| 3705 | if (loop < 3) { | 3922 | if (loop < LOOP_NO_EMPTY_SIZE) { |
| 3706 | loop++; | 3923 | loop++; |
| 3707 | goto search; | 3924 | goto search; |
| 3708 | } | 3925 | } |
| @@ -3798,7 +4015,7 @@ again: | |||
| 3798 | num_bytes, data, 1); | 4015 | num_bytes, data, 1); |
| 3799 | goto again; | 4016 | goto again; |
| 3800 | } | 4017 | } |
| 3801 | if (ret) { | 4018 | if (ret == -ENOSPC) { |
| 3802 | struct btrfs_space_info *sinfo; | 4019 | struct btrfs_space_info *sinfo; |
| 3803 | 4020 | ||
| 3804 | sinfo = __find_space_info(root->fs_info, data); | 4021 | sinfo = __find_space_info(root->fs_info, data); |
| @@ -3806,7 +4023,6 @@ again: | |||
| 3806 | "wanted %llu\n", (unsigned long long)data, | 4023 | "wanted %llu\n", (unsigned long long)data, |
| 3807 | (unsigned long long)num_bytes); | 4024 | (unsigned long long)num_bytes); |
| 3808 | dump_space_info(sinfo, num_bytes); | 4025 | dump_space_info(sinfo, num_bytes); |
| 3809 | BUG(); | ||
| 3810 | } | 4026 | } |
| 3811 | 4027 | ||
| 3812 | return ret; | 4028 | return ret; |
| @@ -3844,7 +4060,9 @@ int btrfs_reserve_extent(struct btrfs_trans_handle *trans, | |||
| 3844 | ret = __btrfs_reserve_extent(trans, root, num_bytes, min_alloc_size, | 4060 | ret = __btrfs_reserve_extent(trans, root, num_bytes, min_alloc_size, |
| 3845 | empty_size, hint_byte, search_end, ins, | 4061 | empty_size, hint_byte, search_end, ins, |
| 3846 | data); | 4062 | data); |
| 3847 | update_reserved_extents(root, ins->objectid, ins->offset, 1); | 4063 | if (!ret) |
| 4064 | update_reserved_extents(root, ins->objectid, ins->offset, 1); | ||
| 4065 | |||
| 3848 | return ret; | 4066 | return ret; |
| 3849 | } | 4067 | } |
| 3850 | 4068 | ||
| @@ -4006,9 +4224,9 @@ int btrfs_alloc_logged_file_extent(struct btrfs_trans_handle *trans, | |||
| 4006 | struct btrfs_block_group_cache *block_group; | 4224 | struct btrfs_block_group_cache *block_group; |
| 4007 | 4225 | ||
| 4008 | block_group = btrfs_lookup_block_group(root->fs_info, ins->objectid); | 4226 | block_group = btrfs_lookup_block_group(root->fs_info, ins->objectid); |
| 4009 | mutex_lock(&block_group->cache_mutex); | 4227 | cache_block_group(block_group); |
| 4010 | cache_block_group(root, block_group); | 4228 | wait_event(block_group->caching_q, |
| 4011 | mutex_unlock(&block_group->cache_mutex); | 4229 | block_group_cache_done(block_group)); |
| 4012 | 4230 | ||
| 4013 | ret = btrfs_remove_free_space(block_group, ins->objectid, | 4231 | ret = btrfs_remove_free_space(block_group, ins->objectid, |
| 4014 | ins->offset); | 4232 | ins->offset); |
| @@ -4039,7 +4257,8 @@ static int alloc_tree_block(struct btrfs_trans_handle *trans, | |||
| 4039 | ret = __btrfs_reserve_extent(trans, root, num_bytes, num_bytes, | 4257 | ret = __btrfs_reserve_extent(trans, root, num_bytes, num_bytes, |
| 4040 | empty_size, hint_byte, search_end, | 4258 | empty_size, hint_byte, search_end, |
| 4041 | ins, 0); | 4259 | ins, 0); |
| 4042 | BUG_ON(ret); | 4260 | if (ret) |
| 4261 | return ret; | ||
| 4043 | 4262 | ||
| 4044 | if (root_objectid == BTRFS_TREE_RELOC_OBJECTID) { | 4263 | if (root_objectid == BTRFS_TREE_RELOC_OBJECTID) { |
| 4045 | if (parent == 0) | 4264 | if (parent == 0) |
| @@ -6955,11 +7174,16 @@ int btrfs_free_block_groups(struct btrfs_fs_info *info) | |||
| 6955 | &info->block_group_cache_tree); | 7174 | &info->block_group_cache_tree); |
| 6956 | spin_unlock(&info->block_group_cache_lock); | 7175 | spin_unlock(&info->block_group_cache_lock); |
| 6957 | 7176 | ||
| 6958 | btrfs_remove_free_space_cache(block_group); | ||
| 6959 | down_write(&block_group->space_info->groups_sem); | 7177 | down_write(&block_group->space_info->groups_sem); |
| 6960 | list_del(&block_group->list); | 7178 | list_del(&block_group->list); |
| 6961 | up_write(&block_group->space_info->groups_sem); | 7179 | up_write(&block_group->space_info->groups_sem); |
| 6962 | 7180 | ||
| 7181 | if (block_group->cached == BTRFS_CACHE_STARTED) | ||
| 7182 | wait_event(block_group->caching_q, | ||
| 7183 | block_group_cache_done(block_group)); | ||
| 7184 | |||
| 7185 | btrfs_remove_free_space_cache(block_group); | ||
| 7186 | |||
| 6963 | WARN_ON(atomic_read(&block_group->count) != 1); | 7187 | WARN_ON(atomic_read(&block_group->count) != 1); |
| 6964 | kfree(block_group); | 7188 | kfree(block_group); |
| 6965 | 7189 | ||
| @@ -7025,9 +7249,19 @@ int btrfs_read_block_groups(struct btrfs_root *root) | |||
| 7025 | atomic_set(&cache->count, 1); | 7249 | atomic_set(&cache->count, 1); |
| 7026 | spin_lock_init(&cache->lock); | 7250 | spin_lock_init(&cache->lock); |
| 7027 | spin_lock_init(&cache->tree_lock); | 7251 | spin_lock_init(&cache->tree_lock); |
| 7028 | mutex_init(&cache->cache_mutex); | 7252 | cache->fs_info = info; |
| 7253 | init_waitqueue_head(&cache->caching_q); | ||
| 7029 | INIT_LIST_HEAD(&cache->list); | 7254 | INIT_LIST_HEAD(&cache->list); |
| 7030 | INIT_LIST_HEAD(&cache->cluster_list); | 7255 | INIT_LIST_HEAD(&cache->cluster_list); |
| 7256 | |||
| 7257 | /* | ||
| 7258 | * we only want to have 32k of ram per block group for keeping | ||
| 7259 | * track of free space, and if we pass 1/2 of that we want to | ||
| 7260 | * start converting things over to using bitmaps | ||
| 7261 | */ | ||
| 7262 | cache->extents_thresh = ((1024 * 32) / 2) / | ||
| 7263 | sizeof(struct btrfs_free_space); | ||
| 7264 | |||
| 7031 | read_extent_buffer(leaf, &cache->item, | 7265 | read_extent_buffer(leaf, &cache->item, |
| 7032 | btrfs_item_ptr_offset(leaf, path->slots[0]), | 7266 | btrfs_item_ptr_offset(leaf, path->slots[0]), |
| 7033 | sizeof(cache->item)); | 7267 | sizeof(cache->item)); |
| @@ -7036,6 +7270,26 @@ int btrfs_read_block_groups(struct btrfs_root *root) | |||
| 7036 | key.objectid = found_key.objectid + found_key.offset; | 7270 | key.objectid = found_key.objectid + found_key.offset; |
| 7037 | btrfs_release_path(root, path); | 7271 | btrfs_release_path(root, path); |
| 7038 | cache->flags = btrfs_block_group_flags(&cache->item); | 7272 | cache->flags = btrfs_block_group_flags(&cache->item); |
| 7273 | cache->sectorsize = root->sectorsize; | ||
| 7274 | |||
| 7275 | remove_sb_from_cache(root, cache); | ||
| 7276 | |||
| 7277 | /* | ||
| 7278 | * check for two cases, either we are full, and therefore | ||
| 7279 | * don't need to bother with the caching work since we won't | ||
| 7280 | * find any space, or we are empty, and we can just add all | ||
| 7281 | * the space in and be done with it. This saves us _alot_ of | ||
| 7282 | * time, particularly in the full case. | ||
| 7283 | */ | ||
| 7284 | if (found_key.offset == btrfs_block_group_used(&cache->item)) { | ||
| 7285 | cache->cached = BTRFS_CACHE_FINISHED; | ||
| 7286 | } else if (btrfs_block_group_used(&cache->item) == 0) { | ||
| 7287 | cache->cached = BTRFS_CACHE_FINISHED; | ||
| 7288 | add_new_free_space(cache, root->fs_info, | ||
| 7289 | found_key.objectid, | ||
| 7290 | found_key.objectid + | ||
| 7291 | found_key.offset); | ||
| 7292 | } | ||
| 7039 | 7293 | ||
| 7040 | ret = update_space_info(info, cache->flags, found_key.offset, | 7294 | ret = update_space_info(info, cache->flags, found_key.offset, |
| 7041 | btrfs_block_group_used(&cache->item), | 7295 | btrfs_block_group_used(&cache->item), |
| @@ -7079,10 +7333,19 @@ int btrfs_make_block_group(struct btrfs_trans_handle *trans, | |||
| 7079 | cache->key.objectid = chunk_offset; | 7333 | cache->key.objectid = chunk_offset; |
| 7080 | cache->key.offset = size; | 7334 | cache->key.offset = size; |
| 7081 | cache->key.type = BTRFS_BLOCK_GROUP_ITEM_KEY; | 7335 | cache->key.type = BTRFS_BLOCK_GROUP_ITEM_KEY; |
| 7336 | cache->sectorsize = root->sectorsize; | ||
| 7337 | |||
| 7338 | /* | ||
| 7339 | * we only want to have 32k of ram per block group for keeping track | ||
| 7340 | * of free space, and if we pass 1/2 of that we want to start | ||
| 7341 | * converting things over to using bitmaps | ||
| 7342 | */ | ||
| 7343 | cache->extents_thresh = ((1024 * 32) / 2) / | ||
| 7344 | sizeof(struct btrfs_free_space); | ||
| 7082 | atomic_set(&cache->count, 1); | 7345 | atomic_set(&cache->count, 1); |
| 7083 | spin_lock_init(&cache->lock); | 7346 | spin_lock_init(&cache->lock); |
| 7084 | spin_lock_init(&cache->tree_lock); | 7347 | spin_lock_init(&cache->tree_lock); |
| 7085 | mutex_init(&cache->cache_mutex); | 7348 | init_waitqueue_head(&cache->caching_q); |
| 7086 | INIT_LIST_HEAD(&cache->list); | 7349 | INIT_LIST_HEAD(&cache->list); |
| 7087 | INIT_LIST_HEAD(&cache->cluster_list); | 7350 | INIT_LIST_HEAD(&cache->cluster_list); |
| 7088 | 7351 | ||
| @@ -7091,6 +7354,12 @@ int btrfs_make_block_group(struct btrfs_trans_handle *trans, | |||
| 7091 | cache->flags = type; | 7354 | cache->flags = type; |
| 7092 | btrfs_set_block_group_flags(&cache->item, type); | 7355 | btrfs_set_block_group_flags(&cache->item, type); |
| 7093 | 7356 | ||
| 7357 | cache->cached = BTRFS_CACHE_FINISHED; | ||
| 7358 | remove_sb_from_cache(root, cache); | ||
| 7359 | |||
| 7360 | add_new_free_space(cache, root->fs_info, chunk_offset, | ||
| 7361 | chunk_offset + size); | ||
| 7362 | |||
| 7094 | ret = update_space_info(root->fs_info, cache->flags, size, bytes_used, | 7363 | ret = update_space_info(root->fs_info, cache->flags, size, bytes_used, |
| 7095 | &cache->space_info); | 7364 | &cache->space_info); |
| 7096 | BUG_ON(ret); | 7365 | BUG_ON(ret); |
| @@ -7149,7 +7418,7 @@ int btrfs_remove_block_group(struct btrfs_trans_handle *trans, | |||
| 7149 | rb_erase(&block_group->cache_node, | 7418 | rb_erase(&block_group->cache_node, |
| 7150 | &root->fs_info->block_group_cache_tree); | 7419 | &root->fs_info->block_group_cache_tree); |
| 7151 | spin_unlock(&root->fs_info->block_group_cache_lock); | 7420 | spin_unlock(&root->fs_info->block_group_cache_lock); |
| 7152 | btrfs_remove_free_space_cache(block_group); | 7421 | |
| 7153 | down_write(&block_group->space_info->groups_sem); | 7422 | down_write(&block_group->space_info->groups_sem); |
| 7154 | /* | 7423 | /* |
| 7155 | * we must use list_del_init so people can check to see if they | 7424 | * we must use list_del_init so people can check to see if they |
| @@ -7158,11 +7427,18 @@ int btrfs_remove_block_group(struct btrfs_trans_handle *trans, | |||
| 7158 | list_del_init(&block_group->list); | 7427 | list_del_init(&block_group->list); |
| 7159 | up_write(&block_group->space_info->groups_sem); | 7428 | up_write(&block_group->space_info->groups_sem); |
| 7160 | 7429 | ||
| 7430 | if (block_group->cached == BTRFS_CACHE_STARTED) | ||
| 7431 | wait_event(block_group->caching_q, | ||
| 7432 | block_group_cache_done(block_group)); | ||
| 7433 | |||
| 7434 | btrfs_remove_free_space_cache(block_group); | ||
| 7435 | |||
| 7161 | spin_lock(&block_group->space_info->lock); | 7436 | spin_lock(&block_group->space_info->lock); |
| 7162 | block_group->space_info->total_bytes -= block_group->key.offset; | 7437 | block_group->space_info->total_bytes -= block_group->key.offset; |
| 7163 | block_group->space_info->bytes_readonly -= block_group->key.offset; | 7438 | block_group->space_info->bytes_readonly -= block_group->key.offset; |
| 7164 | spin_unlock(&block_group->space_info->lock); | 7439 | spin_unlock(&block_group->space_info->lock); |
| 7165 | block_group->space_info->full = 0; | 7440 | |
| 7441 | btrfs_clear_space_info_full(root->fs_info); | ||
| 7166 | 7442 | ||
| 7167 | btrfs_put_block_group(block_group); | 7443 | btrfs_put_block_group(block_group); |
| 7168 | btrfs_put_block_group(block_group); | 7444 | btrfs_put_block_group(block_group); |
diff --git a/fs/btrfs/free-space-cache.c b/fs/btrfs/free-space-cache.c index 4538e48581a5..5edcee3a617f 100644 --- a/fs/btrfs/free-space-cache.c +++ b/fs/btrfs/free-space-cache.c | |||
| @@ -16,45 +16,46 @@ | |||
| 16 | * Boston, MA 021110-1307, USA. | 16 | * Boston, MA 021110-1307, USA. |
| 17 | */ | 17 | */ |
| 18 | 18 | ||
| 19 | #include <linux/pagemap.h> | ||
| 19 | #include <linux/sched.h> | 20 | #include <linux/sched.h> |
| 21 | #include <linux/math64.h> | ||
| 20 | #include "ctree.h" | 22 | #include "ctree.h" |
| 21 | #include "free-space-cache.h" | 23 | #include "free-space-cache.h" |
| 22 | #include "transaction.h" | 24 | #include "transaction.h" |
| 23 | 25 | ||
| 24 | struct btrfs_free_space { | 26 | #define BITS_PER_BITMAP (PAGE_CACHE_SIZE * 8) |
| 25 | struct rb_node bytes_index; | 27 | #define MAX_CACHE_BYTES_PER_GIG (32 * 1024) |
| 26 | struct rb_node offset_index; | ||
| 27 | u64 offset; | ||
| 28 | u64 bytes; | ||
| 29 | }; | ||
| 30 | 28 | ||
| 31 | static int tree_insert_offset(struct rb_root *root, u64 offset, | 29 | static inline unsigned long offset_to_bit(u64 bitmap_start, u64 sectorsize, |
| 32 | struct rb_node *node) | 30 | u64 offset) |
| 33 | { | 31 | { |
| 34 | struct rb_node **p = &root->rb_node; | 32 | BUG_ON(offset < bitmap_start); |
| 35 | struct rb_node *parent = NULL; | 33 | offset -= bitmap_start; |
| 36 | struct btrfs_free_space *info; | 34 | return (unsigned long)(div64_u64(offset, sectorsize)); |
| 35 | } | ||
| 37 | 36 | ||
| 38 | while (*p) { | 37 | static inline unsigned long bytes_to_bits(u64 bytes, u64 sectorsize) |
| 39 | parent = *p; | 38 | { |
| 40 | info = rb_entry(parent, struct btrfs_free_space, offset_index); | 39 | return (unsigned long)(div64_u64(bytes, sectorsize)); |
| 40 | } | ||
| 41 | 41 | ||
| 42 | if (offset < info->offset) | 42 | static inline u64 offset_to_bitmap(struct btrfs_block_group_cache *block_group, |
| 43 | p = &(*p)->rb_left; | 43 | u64 offset) |
| 44 | else if (offset > info->offset) | 44 | { |
| 45 | p = &(*p)->rb_right; | 45 | u64 bitmap_start; |
| 46 | else | 46 | u64 bytes_per_bitmap; |
| 47 | return -EEXIST; | ||
| 48 | } | ||
| 49 | 47 | ||
| 50 | rb_link_node(node, parent, p); | 48 | bytes_per_bitmap = BITS_PER_BITMAP * block_group->sectorsize; |
| 51 | rb_insert_color(node, root); | 49 | bitmap_start = offset - block_group->key.objectid; |
| 50 | bitmap_start = div64_u64(bitmap_start, bytes_per_bitmap); | ||
| 51 | bitmap_start *= bytes_per_bitmap; | ||
| 52 | bitmap_start += block_group->key.objectid; | ||
| 52 | 53 | ||
| 53 | return 0; | 54 | return bitmap_start; |
| 54 | } | 55 | } |
| 55 | 56 | ||
| 56 | static int tree_insert_bytes(struct rb_root *root, u64 bytes, | 57 | static int tree_insert_offset(struct rb_root *root, u64 offset, |
| 57 | struct rb_node *node) | 58 | struct rb_node *node, int bitmap) |
| 58 | { | 59 | { |
| 59 | struct rb_node **p = &root->rb_node; | 60 | struct rb_node **p = &root->rb_node; |
| 60 | struct rb_node *parent = NULL; | 61 | struct rb_node *parent = NULL; |
| @@ -62,12 +63,34 @@ static int tree_insert_bytes(struct rb_root *root, u64 bytes, | |||
| 62 | 63 | ||
| 63 | while (*p) { | 64 | while (*p) { |
| 64 | parent = *p; | 65 | parent = *p; |
| 65 | info = rb_entry(parent, struct btrfs_free_space, bytes_index); | 66 | info = rb_entry(parent, struct btrfs_free_space, offset_index); |
| 66 | 67 | ||
| 67 | if (bytes < info->bytes) | 68 | if (offset < info->offset) { |
| 68 | p = &(*p)->rb_left; | 69 | p = &(*p)->rb_left; |
| 69 | else | 70 | } else if (offset > info->offset) { |
| 70 | p = &(*p)->rb_right; | 71 | p = &(*p)->rb_right; |
| 72 | } else { | ||
| 73 | /* | ||
| 74 | * we could have a bitmap entry and an extent entry | ||
| 75 | * share the same offset. If this is the case, we want | ||
| 76 | * the extent entry to always be found first if we do a | ||
| 77 | * linear search through the tree, since we want to have | ||
| 78 | * the quickest allocation time, and allocating from an | ||
| 79 | * extent is faster than allocating from a bitmap. So | ||
| 80 | * if we're inserting a bitmap and we find an entry at | ||
| 81 | * this offset, we want to go right, or after this entry | ||
| 82 | * logically. If we are inserting an extent and we've | ||
| 83 | * found a bitmap, we want to go left, or before | ||
| 84 | * logically. | ||
| 85 | */ | ||
| 86 | if (bitmap) { | ||
| 87 | WARN_ON(info->bitmap); | ||
| 88 | p = &(*p)->rb_right; | ||
| 89 | } else { | ||
| 90 | WARN_ON(!info->bitmap); | ||
| 91 | p = &(*p)->rb_left; | ||
| 92 | } | ||
| 93 | } | ||
| 71 | } | 94 | } |
| 72 | 95 | ||
| 73 | rb_link_node(node, parent, p); | 96 | rb_link_node(node, parent, p); |
| @@ -79,110 +102,143 @@ static int tree_insert_bytes(struct rb_root *root, u64 bytes, | |||
| 79 | /* | 102 | /* |
| 80 | * searches the tree for the given offset. | 103 | * searches the tree for the given offset. |
| 81 | * | 104 | * |
| 82 | * fuzzy == 1: this is used for allocations where we are given a hint of where | 105 | * fuzzy - If this is set, then we are trying to make an allocation, and we just |
| 83 | * to look for free space. Because the hint may not be completely on an offset | 106 | * want a section that has at least bytes size and comes at or after the given |
| 84 | * mark, or the hint may no longer point to free space we need to fudge our | 107 | * offset. |
| 85 | * results a bit. So we look for free space starting at or after offset with at | ||
| 86 | * least bytes size. We prefer to find as close to the given offset as we can. | ||
| 87 | * Also if the offset is within a free space range, then we will return the free | ||
| 88 | * space that contains the given offset, which means we can return a free space | ||
| 89 | * chunk with an offset before the provided offset. | ||
| 90 | * | ||
| 91 | * fuzzy == 0: this is just a normal tree search. Give us the free space that | ||
| 92 | * starts at the given offset which is at least bytes size, and if its not there | ||
| 93 | * return NULL. | ||
| 94 | */ | 108 | */ |
| 95 | static struct btrfs_free_space *tree_search_offset(struct rb_root *root, | 109 | static struct btrfs_free_space * |
| 96 | u64 offset, u64 bytes, | 110 | tree_search_offset(struct btrfs_block_group_cache *block_group, |
| 97 | int fuzzy) | 111 | u64 offset, int bitmap_only, int fuzzy) |
| 98 | { | 112 | { |
| 99 | struct rb_node *n = root->rb_node; | 113 | struct rb_node *n = block_group->free_space_offset.rb_node; |
| 100 | struct btrfs_free_space *entry, *ret = NULL; | 114 | struct btrfs_free_space *entry, *prev = NULL; |
| 115 | |||
| 116 | /* find entry that is closest to the 'offset' */ | ||
| 117 | while (1) { | ||
| 118 | if (!n) { | ||
| 119 | entry = NULL; | ||
| 120 | break; | ||
| 121 | } | ||
| 101 | 122 | ||
| 102 | while (n) { | ||
| 103 | entry = rb_entry(n, struct btrfs_free_space, offset_index); | 123 | entry = rb_entry(n, struct btrfs_free_space, offset_index); |
| 124 | prev = entry; | ||
| 104 | 125 | ||
| 105 | if (offset < entry->offset) { | 126 | if (offset < entry->offset) |
| 106 | if (fuzzy && | ||
| 107 | (!ret || entry->offset < ret->offset) && | ||
| 108 | (bytes <= entry->bytes)) | ||
| 109 | ret = entry; | ||
| 110 | n = n->rb_left; | 127 | n = n->rb_left; |
| 111 | } else if (offset > entry->offset) { | 128 | else if (offset > entry->offset) |
| 112 | if (fuzzy && | ||
| 113 | (entry->offset + entry->bytes - 1) >= offset && | ||
| 114 | bytes <= entry->bytes) { | ||
| 115 | ret = entry; | ||
| 116 | break; | ||
| 117 | } | ||
| 118 | n = n->rb_right; | 129 | n = n->rb_right; |
| 119 | } else { | 130 | else |
| 120 | if (bytes > entry->bytes) { | ||
| 121 | n = n->rb_right; | ||
| 122 | continue; | ||
| 123 | } | ||
| 124 | ret = entry; | ||
| 125 | break; | 131 | break; |
| 126 | } | ||
| 127 | } | 132 | } |
| 128 | 133 | ||
| 129 | return ret; | 134 | if (bitmap_only) { |
| 130 | } | 135 | if (!entry) |
| 136 | return NULL; | ||
| 137 | if (entry->bitmap) | ||
| 138 | return entry; | ||
| 131 | 139 | ||
| 132 | /* | 140 | /* |
| 133 | * return a chunk at least bytes size, as close to offset that we can get. | 141 | * bitmap entry and extent entry may share same offset, |
| 134 | */ | 142 | * in that case, bitmap entry comes after extent entry. |
| 135 | static struct btrfs_free_space *tree_search_bytes(struct rb_root *root, | 143 | */ |
| 136 | u64 offset, u64 bytes) | 144 | n = rb_next(n); |
| 137 | { | 145 | if (!n) |
| 138 | struct rb_node *n = root->rb_node; | 146 | return NULL; |
| 139 | struct btrfs_free_space *entry, *ret = NULL; | 147 | entry = rb_entry(n, struct btrfs_free_space, offset_index); |
| 140 | 148 | if (entry->offset != offset) | |
| 141 | while (n) { | 149 | return NULL; |
| 142 | entry = rb_entry(n, struct btrfs_free_space, bytes_index); | ||
| 143 | 150 | ||
| 144 | if (bytes < entry->bytes) { | 151 | WARN_ON(!entry->bitmap); |
| 152 | return entry; | ||
| 153 | } else if (entry) { | ||
| 154 | if (entry->bitmap) { | ||
| 145 | /* | 155 | /* |
| 146 | * We prefer to get a hole size as close to the size we | 156 | * if previous extent entry covers the offset, |
| 147 | * are asking for so we don't take small slivers out of | 157 | * we should return it instead of the bitmap entry |
| 148 | * huge holes, but we also want to get as close to the | ||
| 149 | * offset as possible so we don't have a whole lot of | ||
| 150 | * fragmentation. | ||
| 151 | */ | 158 | */ |
| 152 | if (offset <= entry->offset) { | 159 | n = &entry->offset_index; |
| 153 | if (!ret) | 160 | while (1) { |
| 154 | ret = entry; | 161 | n = rb_prev(n); |
| 155 | else if (entry->bytes < ret->bytes) | 162 | if (!n) |
| 156 | ret = entry; | 163 | break; |
| 157 | else if (entry->offset < ret->offset) | 164 | prev = rb_entry(n, struct btrfs_free_space, |
| 158 | ret = entry; | 165 | offset_index); |
| 166 | if (!prev->bitmap) { | ||
| 167 | if (prev->offset + prev->bytes > offset) | ||
| 168 | entry = prev; | ||
| 169 | break; | ||
| 170 | } | ||
| 159 | } | 171 | } |
| 160 | n = n->rb_left; | 172 | } |
| 161 | } else if (bytes > entry->bytes) { | 173 | return entry; |
| 162 | n = n->rb_right; | 174 | } |
| 175 | |||
| 176 | if (!prev) | ||
| 177 | return NULL; | ||
| 178 | |||
| 179 | /* find last entry before the 'offset' */ | ||
| 180 | entry = prev; | ||
| 181 | if (entry->offset > offset) { | ||
| 182 | n = rb_prev(&entry->offset_index); | ||
| 183 | if (n) { | ||
| 184 | entry = rb_entry(n, struct btrfs_free_space, | ||
| 185 | offset_index); | ||
| 186 | BUG_ON(entry->offset > offset); | ||
| 163 | } else { | 187 | } else { |
| 164 | /* | 188 | if (fuzzy) |
| 165 | * Ok we may have multiple chunks of the wanted size, | 189 | return entry; |
| 166 | * so we don't want to take the first one we find, we | 190 | else |
| 167 | * want to take the one closest to our given offset, so | 191 | return NULL; |
| 168 | * keep searching just in case theres a better match. | ||
| 169 | */ | ||
| 170 | n = n->rb_right; | ||
| 171 | if (offset > entry->offset) | ||
| 172 | continue; | ||
| 173 | else if (!ret || entry->offset < ret->offset) | ||
| 174 | ret = entry; | ||
| 175 | } | 192 | } |
| 176 | } | 193 | } |
| 177 | 194 | ||
| 178 | return ret; | 195 | if (entry->bitmap) { |
| 196 | n = &entry->offset_index; | ||
| 197 | while (1) { | ||
| 198 | n = rb_prev(n); | ||
| 199 | if (!n) | ||
| 200 | break; | ||
| 201 | prev = rb_entry(n, struct btrfs_free_space, | ||
| 202 | offset_index); | ||
| 203 | if (!prev->bitmap) { | ||
| 204 | if (prev->offset + prev->bytes > offset) | ||
| 205 | return prev; | ||
| 206 | break; | ||
| 207 | } | ||
| 208 | } | ||
| 209 | if (entry->offset + BITS_PER_BITMAP * | ||
| 210 | block_group->sectorsize > offset) | ||
| 211 | return entry; | ||
| 212 | } else if (entry->offset + entry->bytes > offset) | ||
| 213 | return entry; | ||
| 214 | |||
| 215 | if (!fuzzy) | ||
| 216 | return NULL; | ||
| 217 | |||
| 218 | while (1) { | ||
| 219 | if (entry->bitmap) { | ||
| 220 | if (entry->offset + BITS_PER_BITMAP * | ||
| 221 | block_group->sectorsize > offset) | ||
| 222 | break; | ||
| 223 | } else { | ||
| 224 | if (entry->offset + entry->bytes > offset) | ||
| 225 | break; | ||
| 226 | } | ||
| 227 | |||
| 228 | n = rb_next(&entry->offset_index); | ||
| 229 | if (!n) | ||
| 230 | return NULL; | ||
| 231 | entry = rb_entry(n, struct btrfs_free_space, offset_index); | ||
| 232 | } | ||
| 233 | return entry; | ||
| 179 | } | 234 | } |
| 180 | 235 | ||
| 181 | static void unlink_free_space(struct btrfs_block_group_cache *block_group, | 236 | static void unlink_free_space(struct btrfs_block_group_cache *block_group, |
| 182 | struct btrfs_free_space *info) | 237 | struct btrfs_free_space *info) |
| 183 | { | 238 | { |
| 184 | rb_erase(&info->offset_index, &block_group->free_space_offset); | 239 | rb_erase(&info->offset_index, &block_group->free_space_offset); |
| 185 | rb_erase(&info->bytes_index, &block_group->free_space_bytes); | 240 | block_group->free_extents--; |
| 241 | block_group->free_space -= info->bytes; | ||
| 186 | } | 242 | } |
| 187 | 243 | ||
| 188 | static int link_free_space(struct btrfs_block_group_cache *block_group, | 244 | static int link_free_space(struct btrfs_block_group_cache *block_group, |
| @@ -190,17 +246,353 @@ static int link_free_space(struct btrfs_block_group_cache *block_group, | |||
| 190 | { | 246 | { |
| 191 | int ret = 0; | 247 | int ret = 0; |
| 192 | 248 | ||
| 193 | 249 | BUG_ON(!info->bitmap && !info->bytes); | |
| 194 | BUG_ON(!info->bytes); | ||
| 195 | ret = tree_insert_offset(&block_group->free_space_offset, info->offset, | 250 | ret = tree_insert_offset(&block_group->free_space_offset, info->offset, |
| 196 | &info->offset_index); | 251 | &info->offset_index, (info->bitmap != NULL)); |
| 197 | if (ret) | 252 | if (ret) |
| 198 | return ret; | 253 | return ret; |
| 199 | 254 | ||
| 200 | ret = tree_insert_bytes(&block_group->free_space_bytes, info->bytes, | 255 | block_group->free_space += info->bytes; |
| 201 | &info->bytes_index); | 256 | block_group->free_extents++; |
| 202 | if (ret) | 257 | return ret; |
| 203 | return ret; | 258 | } |
| 259 | |||
| 260 | static void recalculate_thresholds(struct btrfs_block_group_cache *block_group) | ||
| 261 | { | ||
| 262 | u64 max_bytes, possible_bytes; | ||
| 263 | |||
| 264 | /* | ||
| 265 | * The goal is to keep the total amount of memory used per 1gb of space | ||
| 266 | * at or below 32k, so we need to adjust how much memory we allow to be | ||
| 267 | * used by extent based free space tracking | ||
| 268 | */ | ||
| 269 | max_bytes = MAX_CACHE_BYTES_PER_GIG * | ||
| 270 | (div64_u64(block_group->key.offset, 1024 * 1024 * 1024)); | ||
| 271 | |||
| 272 | possible_bytes = (block_group->total_bitmaps * PAGE_CACHE_SIZE) + | ||
| 273 | (sizeof(struct btrfs_free_space) * | ||
| 274 | block_group->extents_thresh); | ||
| 275 | |||
| 276 | if (possible_bytes > max_bytes) { | ||
| 277 | int extent_bytes = max_bytes - | ||
| 278 | (block_group->total_bitmaps * PAGE_CACHE_SIZE); | ||
| 279 | |||
| 280 | if (extent_bytes <= 0) { | ||
| 281 | block_group->extents_thresh = 0; | ||
| 282 | return; | ||
| 283 | } | ||
| 284 | |||
| 285 | block_group->extents_thresh = extent_bytes / | ||
| 286 | (sizeof(struct btrfs_free_space)); | ||
| 287 | } | ||
| 288 | } | ||
| 289 | |||
| 290 | static void bitmap_clear_bits(struct btrfs_block_group_cache *block_group, | ||
| 291 | struct btrfs_free_space *info, u64 offset, | ||
| 292 | u64 bytes) | ||
| 293 | { | ||
| 294 | unsigned long start, end; | ||
| 295 | unsigned long i; | ||
| 296 | |||
| 297 | start = offset_to_bit(info->offset, block_group->sectorsize, offset); | ||
| 298 | end = start + bytes_to_bits(bytes, block_group->sectorsize); | ||
| 299 | BUG_ON(end > BITS_PER_BITMAP); | ||
| 300 | |||
| 301 | for (i = start; i < end; i++) | ||
| 302 | clear_bit(i, info->bitmap); | ||
| 303 | |||
| 304 | info->bytes -= bytes; | ||
| 305 | block_group->free_space -= bytes; | ||
| 306 | } | ||
| 307 | |||
| 308 | static void bitmap_set_bits(struct btrfs_block_group_cache *block_group, | ||
| 309 | struct btrfs_free_space *info, u64 offset, | ||
| 310 | u64 bytes) | ||
| 311 | { | ||
| 312 | unsigned long start, end; | ||
| 313 | unsigned long i; | ||
| 314 | |||
| 315 | start = offset_to_bit(info->offset, block_group->sectorsize, offset); | ||
| 316 | end = start + bytes_to_bits(bytes, block_group->sectorsize); | ||
| 317 | BUG_ON(end > BITS_PER_BITMAP); | ||
| 318 | |||
| 319 | for (i = start; i < end; i++) | ||
| 320 | set_bit(i, info->bitmap); | ||
| 321 | |||
| 322 | info->bytes += bytes; | ||
| 323 | block_group->free_space += bytes; | ||
| 324 | } | ||
| 325 | |||
| 326 | static int search_bitmap(struct btrfs_block_group_cache *block_group, | ||
| 327 | struct btrfs_free_space *bitmap_info, u64 *offset, | ||
| 328 | u64 *bytes) | ||
| 329 | { | ||
| 330 | unsigned long found_bits = 0; | ||
| 331 | unsigned long bits, i; | ||
| 332 | unsigned long next_zero; | ||
| 333 | |||
| 334 | i = offset_to_bit(bitmap_info->offset, block_group->sectorsize, | ||
| 335 | max_t(u64, *offset, bitmap_info->offset)); | ||
| 336 | bits = bytes_to_bits(*bytes, block_group->sectorsize); | ||
| 337 | |||
| 338 | for (i = find_next_bit(bitmap_info->bitmap, BITS_PER_BITMAP, i); | ||
| 339 | i < BITS_PER_BITMAP; | ||
| 340 | i = find_next_bit(bitmap_info->bitmap, BITS_PER_BITMAP, i + 1)) { | ||
| 341 | next_zero = find_next_zero_bit(bitmap_info->bitmap, | ||
| 342 | BITS_PER_BITMAP, i); | ||
| 343 | if ((next_zero - i) >= bits) { | ||
| 344 | found_bits = next_zero - i; | ||
| 345 | break; | ||
| 346 | } | ||
| 347 | i = next_zero; | ||
| 348 | } | ||
| 349 | |||
| 350 | if (found_bits) { | ||
| 351 | *offset = (u64)(i * block_group->sectorsize) + | ||
| 352 | bitmap_info->offset; | ||
| 353 | *bytes = (u64)(found_bits) * block_group->sectorsize; | ||
| 354 | return 0; | ||
| 355 | } | ||
| 356 | |||
| 357 | return -1; | ||
| 358 | } | ||
| 359 | |||
| 360 | static struct btrfs_free_space *find_free_space(struct btrfs_block_group_cache | ||
| 361 | *block_group, u64 *offset, | ||
| 362 | u64 *bytes, int debug) | ||
| 363 | { | ||
| 364 | struct btrfs_free_space *entry; | ||
| 365 | struct rb_node *node; | ||
| 366 | int ret; | ||
| 367 | |||
| 368 | if (!block_group->free_space_offset.rb_node) | ||
| 369 | return NULL; | ||
| 370 | |||
| 371 | entry = tree_search_offset(block_group, | ||
| 372 | offset_to_bitmap(block_group, *offset), | ||
| 373 | 0, 1); | ||
| 374 | if (!entry) | ||
| 375 | return NULL; | ||
| 376 | |||
| 377 | for (node = &entry->offset_index; node; node = rb_next(node)) { | ||
| 378 | entry = rb_entry(node, struct btrfs_free_space, offset_index); | ||
| 379 | if (entry->bytes < *bytes) | ||
| 380 | continue; | ||
| 381 | |||
| 382 | if (entry->bitmap) { | ||
| 383 | ret = search_bitmap(block_group, entry, offset, bytes); | ||
| 384 | if (!ret) | ||
| 385 | return entry; | ||
| 386 | continue; | ||
| 387 | } | ||
| 388 | |||
| 389 | *offset = entry->offset; | ||
| 390 | *bytes = entry->bytes; | ||
| 391 | return entry; | ||
| 392 | } | ||
| 393 | |||
| 394 | return NULL; | ||
| 395 | } | ||
| 396 | |||
| 397 | static void add_new_bitmap(struct btrfs_block_group_cache *block_group, | ||
| 398 | struct btrfs_free_space *info, u64 offset) | ||
| 399 | { | ||
| 400 | u64 bytes_per_bg = BITS_PER_BITMAP * block_group->sectorsize; | ||
| 401 | int max_bitmaps = (int)div64_u64(block_group->key.offset + | ||
| 402 | bytes_per_bg - 1, bytes_per_bg); | ||
| 403 | BUG_ON(block_group->total_bitmaps >= max_bitmaps); | ||
| 404 | |||
| 405 | info->offset = offset_to_bitmap(block_group, offset); | ||
| 406 | link_free_space(block_group, info); | ||
| 407 | block_group->total_bitmaps++; | ||
| 408 | |||
| 409 | recalculate_thresholds(block_group); | ||
| 410 | } | ||
| 411 | |||
| 412 | static noinline int remove_from_bitmap(struct btrfs_block_group_cache *block_group, | ||
| 413 | struct btrfs_free_space *bitmap_info, | ||
| 414 | u64 *offset, u64 *bytes) | ||
| 415 | { | ||
| 416 | u64 end; | ||
| 417 | u64 search_start, search_bytes; | ||
| 418 | int ret; | ||
| 419 | |||
| 420 | again: | ||
| 421 | end = bitmap_info->offset + | ||
| 422 | (u64)(BITS_PER_BITMAP * block_group->sectorsize) - 1; | ||
| 423 | |||
| 424 | /* | ||
| 425 | * XXX - this can go away after a few releases. | ||
| 426 | * | ||
| 427 | * since the only user of btrfs_remove_free_space is the tree logging | ||
| 428 | * stuff, and the only way to test that is under crash conditions, we | ||
| 429 | * want to have this debug stuff here just in case somethings not | ||
| 430 | * working. Search the bitmap for the space we are trying to use to | ||
| 431 | * make sure its actually there. If its not there then we need to stop | ||
| 432 | * because something has gone wrong. | ||
| 433 | */ | ||
| 434 | search_start = *offset; | ||
| 435 | search_bytes = *bytes; | ||
| 436 | ret = search_bitmap(block_group, bitmap_info, &search_start, | ||
| 437 | &search_bytes); | ||
| 438 | BUG_ON(ret < 0 || search_start != *offset); | ||
| 439 | |||
| 440 | if (*offset > bitmap_info->offset && *offset + *bytes > end) { | ||
| 441 | bitmap_clear_bits(block_group, bitmap_info, *offset, | ||
| 442 | end - *offset + 1); | ||
| 443 | *bytes -= end - *offset + 1; | ||
| 444 | *offset = end + 1; | ||
| 445 | } else if (*offset >= bitmap_info->offset && *offset + *bytes <= end) { | ||
| 446 | bitmap_clear_bits(block_group, bitmap_info, *offset, *bytes); | ||
| 447 | *bytes = 0; | ||
| 448 | } | ||
| 449 | |||
| 450 | if (*bytes) { | ||
| 451 | struct rb_node *next = rb_next(&bitmap_info->offset_index); | ||
| 452 | if (!bitmap_info->bytes) { | ||
| 453 | unlink_free_space(block_group, bitmap_info); | ||
| 454 | kfree(bitmap_info->bitmap); | ||
| 455 | kfree(bitmap_info); | ||
| 456 | block_group->total_bitmaps--; | ||
| 457 | recalculate_thresholds(block_group); | ||
| 458 | } | ||
| 459 | |||
| 460 | /* | ||
| 461 | * no entry after this bitmap, but we still have bytes to | ||
| 462 | * remove, so something has gone wrong. | ||
| 463 | */ | ||
| 464 | if (!next) | ||
| 465 | return -EINVAL; | ||
| 466 | |||
| 467 | bitmap_info = rb_entry(next, struct btrfs_free_space, | ||
| 468 | offset_index); | ||
| 469 | |||
| 470 | /* | ||
| 471 | * if the next entry isn't a bitmap we need to return to let the | ||
| 472 | * extent stuff do its work. | ||
| 473 | */ | ||
| 474 | if (!bitmap_info->bitmap) | ||
| 475 | return -EAGAIN; | ||
| 476 | |||
| 477 | /* | ||
| 478 | * Ok the next item is a bitmap, but it may not actually hold | ||
| 479 | * the information for the rest of this free space stuff, so | ||
| 480 | * look for it, and if we don't find it return so we can try | ||
| 481 | * everything over again. | ||
| 482 | */ | ||
| 483 | search_start = *offset; | ||
| 484 | search_bytes = *bytes; | ||
| 485 | ret = search_bitmap(block_group, bitmap_info, &search_start, | ||
| 486 | &search_bytes); | ||
| 487 | if (ret < 0 || search_start != *offset) | ||
| 488 | return -EAGAIN; | ||
| 489 | |||
| 490 | goto again; | ||
| 491 | } else if (!bitmap_info->bytes) { | ||
| 492 | unlink_free_space(block_group, bitmap_info); | ||
| 493 | kfree(bitmap_info->bitmap); | ||
| 494 | kfree(bitmap_info); | ||
| 495 | block_group->total_bitmaps--; | ||
| 496 | recalculate_thresholds(block_group); | ||
| 497 | } | ||
| 498 | |||
| 499 | return 0; | ||
| 500 | } | ||
| 501 | |||
| 502 | static int insert_into_bitmap(struct btrfs_block_group_cache *block_group, | ||
| 503 | struct btrfs_free_space *info) | ||
| 504 | { | ||
| 505 | struct btrfs_free_space *bitmap_info; | ||
| 506 | int added = 0; | ||
| 507 | u64 bytes, offset, end; | ||
| 508 | int ret; | ||
| 509 | |||
| 510 | /* | ||
| 511 | * If we are below the extents threshold then we can add this as an | ||
| 512 | * extent, and don't have to deal with the bitmap | ||
| 513 | */ | ||
| 514 | if (block_group->free_extents < block_group->extents_thresh && | ||
| 515 | info->bytes > block_group->sectorsize * 4) | ||
| 516 | return 0; | ||
| 517 | |||
| 518 | /* | ||
| 519 | * some block groups are so tiny they can't be enveloped by a bitmap, so | ||
| 520 | * don't even bother to create a bitmap for this | ||
| 521 | */ | ||
| 522 | if (BITS_PER_BITMAP * block_group->sectorsize > | ||
| 523 | block_group->key.offset) | ||
| 524 | return 0; | ||
| 525 | |||
| 526 | bytes = info->bytes; | ||
| 527 | offset = info->offset; | ||
| 528 | |||
| 529 | again: | ||
| 530 | bitmap_info = tree_search_offset(block_group, | ||
| 531 | offset_to_bitmap(block_group, offset), | ||
| 532 | 1, 0); | ||
| 533 | if (!bitmap_info) { | ||
| 534 | BUG_ON(added); | ||
| 535 | goto new_bitmap; | ||
| 536 | } | ||
| 537 | |||
| 538 | end = bitmap_info->offset + | ||
| 539 | (u64)(BITS_PER_BITMAP * block_group->sectorsize); | ||
| 540 | |||
| 541 | if (offset >= bitmap_info->offset && offset + bytes > end) { | ||
| 542 | bitmap_set_bits(block_group, bitmap_info, offset, | ||
| 543 | end - offset); | ||
| 544 | bytes -= end - offset; | ||
| 545 | offset = end; | ||
| 546 | added = 0; | ||
| 547 | } else if (offset >= bitmap_info->offset && offset + bytes <= end) { | ||
| 548 | bitmap_set_bits(block_group, bitmap_info, offset, bytes); | ||
| 549 | bytes = 0; | ||
| 550 | } else { | ||
| 551 | BUG(); | ||
| 552 | } | ||
| 553 | |||
| 554 | if (!bytes) { | ||
| 555 | ret = 1; | ||
| 556 | goto out; | ||
| 557 | } else | ||
| 558 | goto again; | ||
| 559 | |||
| 560 | new_bitmap: | ||
| 561 | if (info && info->bitmap) { | ||
| 562 | add_new_bitmap(block_group, info, offset); | ||
| 563 | added = 1; | ||
| 564 | info = NULL; | ||
| 565 | goto again; | ||
| 566 | } else { | ||
| 567 | spin_unlock(&block_group->tree_lock); | ||
| 568 | |||
| 569 | /* no pre-allocated info, allocate a new one */ | ||
| 570 | if (!info) { | ||
| 571 | info = kzalloc(sizeof(struct btrfs_free_space), | ||
| 572 | GFP_NOFS); | ||
| 573 | if (!info) { | ||
| 574 | spin_lock(&block_group->tree_lock); | ||
| 575 | ret = -ENOMEM; | ||
| 576 | goto out; | ||
| 577 | } | ||
| 578 | } | ||
| 579 | |||
| 580 | /* allocate the bitmap */ | ||
| 581 | info->bitmap = kzalloc(PAGE_CACHE_SIZE, GFP_NOFS); | ||
| 582 | spin_lock(&block_group->tree_lock); | ||
| 583 | if (!info->bitmap) { | ||
| 584 | ret = -ENOMEM; | ||
| 585 | goto out; | ||
| 586 | } | ||
| 587 | goto again; | ||
| 588 | } | ||
| 589 | |||
| 590 | out: | ||
| 591 | if (info) { | ||
| 592 | if (info->bitmap) | ||
| 593 | kfree(info->bitmap); | ||
| 594 | kfree(info); | ||
| 595 | } | ||
| 204 | 596 | ||
| 205 | return ret; | 597 | return ret; |
| 206 | } | 598 | } |
| @@ -208,8 +600,8 @@ static int link_free_space(struct btrfs_block_group_cache *block_group, | |||
| 208 | int btrfs_add_free_space(struct btrfs_block_group_cache *block_group, | 600 | int btrfs_add_free_space(struct btrfs_block_group_cache *block_group, |
| 209 | u64 offset, u64 bytes) | 601 | u64 offset, u64 bytes) |
| 210 | { | 602 | { |
| 211 | struct btrfs_free_space *right_info; | 603 | struct btrfs_free_space *right_info = NULL; |
| 212 | struct btrfs_free_space *left_info; | 604 | struct btrfs_free_space *left_info = NULL; |
| 213 | struct btrfs_free_space *info = NULL; | 605 | struct btrfs_free_space *info = NULL; |
| 214 | int ret = 0; | 606 | int ret = 0; |
| 215 | 607 | ||
| @@ -227,18 +619,38 @@ int btrfs_add_free_space(struct btrfs_block_group_cache *block_group, | |||
| 227 | * are adding, if there is remove that struct and add a new one to | 619 | * are adding, if there is remove that struct and add a new one to |
| 228 | * cover the entire range | 620 | * cover the entire range |
| 229 | */ | 621 | */ |
| 230 | right_info = tree_search_offset(&block_group->free_space_offset, | 622 | right_info = tree_search_offset(block_group, offset + bytes, 0, 0); |
| 231 | offset+bytes, 0, 0); | 623 | if (right_info && rb_prev(&right_info->offset_index)) |
| 232 | left_info = tree_search_offset(&block_group->free_space_offset, | 624 | left_info = rb_entry(rb_prev(&right_info->offset_index), |
| 233 | offset-1, 0, 1); | 625 | struct btrfs_free_space, offset_index); |
| 626 | else | ||
| 627 | left_info = tree_search_offset(block_group, offset - 1, 0, 0); | ||
| 628 | |||
| 629 | /* | ||
| 630 | * If there was no extent directly to the left or right of this new | ||
| 631 | * extent then we know we're going to have to allocate a new extent, so | ||
| 632 | * before we do that see if we need to drop this into a bitmap | ||
| 633 | */ | ||
| 634 | if ((!left_info || left_info->bitmap) && | ||
| 635 | (!right_info || right_info->bitmap)) { | ||
| 636 | ret = insert_into_bitmap(block_group, info); | ||
| 637 | |||
| 638 | if (ret < 0) { | ||
| 639 | goto out; | ||
| 640 | } else if (ret) { | ||
| 641 | ret = 0; | ||
| 642 | goto out; | ||
| 643 | } | ||
| 644 | } | ||
| 234 | 645 | ||
| 235 | if (right_info) { | 646 | if (right_info && !right_info->bitmap) { |
| 236 | unlink_free_space(block_group, right_info); | 647 | unlink_free_space(block_group, right_info); |
| 237 | info->bytes += right_info->bytes; | 648 | info->bytes += right_info->bytes; |
| 238 | kfree(right_info); | 649 | kfree(right_info); |
| 239 | } | 650 | } |
| 240 | 651 | ||
| 241 | if (left_info && left_info->offset + left_info->bytes == offset) { | 652 | if (left_info && !left_info->bitmap && |
| 653 | left_info->offset + left_info->bytes == offset) { | ||
| 242 | unlink_free_space(block_group, left_info); | 654 | unlink_free_space(block_group, left_info); |
| 243 | info->offset = left_info->offset; | 655 | info->offset = left_info->offset; |
| 244 | info->bytes += left_info->bytes; | 656 | info->bytes += left_info->bytes; |
| @@ -248,11 +660,11 @@ int btrfs_add_free_space(struct btrfs_block_group_cache *block_group, | |||
| 248 | ret = link_free_space(block_group, info); | 660 | ret = link_free_space(block_group, info); |
| 249 | if (ret) | 661 | if (ret) |
| 250 | kfree(info); | 662 | kfree(info); |
| 251 | 663 | out: | |
| 252 | spin_unlock(&block_group->tree_lock); | 664 | spin_unlock(&block_group->tree_lock); |
| 253 | 665 | ||
| 254 | if (ret) { | 666 | if (ret) { |
| 255 | printk(KERN_ERR "btrfs: unable to add free space :%d\n", ret); | 667 | printk(KERN_CRIT "btrfs: unable to add free space :%d\n", ret); |
| 256 | BUG_ON(ret == -EEXIST); | 668 | BUG_ON(ret == -EEXIST); |
| 257 | } | 669 | } |
| 258 | 670 | ||
| @@ -263,40 +675,74 @@ int btrfs_remove_free_space(struct btrfs_block_group_cache *block_group, | |||
| 263 | u64 offset, u64 bytes) | 675 | u64 offset, u64 bytes) |
| 264 | { | 676 | { |
| 265 | struct btrfs_free_space *info; | 677 | struct btrfs_free_space *info; |
| 678 | struct btrfs_free_space *next_info = NULL; | ||
| 266 | int ret = 0; | 679 | int ret = 0; |
| 267 | 680 | ||
| 268 | spin_lock(&block_group->tree_lock); | 681 | spin_lock(&block_group->tree_lock); |
| 269 | 682 | ||
| 270 | info = tree_search_offset(&block_group->free_space_offset, offset, 0, | 683 | again: |
| 271 | 1); | 684 | info = tree_search_offset(block_group, offset, 0, 0); |
| 272 | if (info && info->offset == offset) { | 685 | if (!info) { |
| 273 | if (info->bytes < bytes) { | 686 | /* |
| 274 | printk(KERN_ERR "Found free space at %llu, size %llu," | 687 | * oops didn't find an extent that matched the space we wanted |
| 275 | "trying to use %llu\n", | 688 | * to remove, look for a bitmap instead |
| 276 | (unsigned long long)info->offset, | 689 | */ |
| 277 | (unsigned long long)info->bytes, | 690 | info = tree_search_offset(block_group, |
| 278 | (unsigned long long)bytes); | 691 | offset_to_bitmap(block_group, offset), |
| 692 | 1, 0); | ||
| 693 | if (!info) { | ||
| 694 | WARN_ON(1); | ||
| 695 | goto out_lock; | ||
| 696 | } | ||
| 697 | } | ||
| 698 | |||
| 699 | if (info->bytes < bytes && rb_next(&info->offset_index)) { | ||
| 700 | u64 end; | ||
| 701 | next_info = rb_entry(rb_next(&info->offset_index), | ||
| 702 | struct btrfs_free_space, | ||
| 703 | offset_index); | ||
| 704 | |||
| 705 | if (next_info->bitmap) | ||
| 706 | end = next_info->offset + BITS_PER_BITMAP * | ||
| 707 | block_group->sectorsize - 1; | ||
| 708 | else | ||
| 709 | end = next_info->offset + next_info->bytes; | ||
| 710 | |||
| 711 | if (next_info->bytes < bytes || | ||
| 712 | next_info->offset > offset || offset > end) { | ||
| 713 | printk(KERN_CRIT "Found free space at %llu, size %llu," | ||
| 714 | " trying to use %llu\n", | ||
| 715 | (unsigned long long)info->offset, | ||
| 716 | (unsigned long long)info->bytes, | ||
| 717 | (unsigned long long)bytes); | ||
| 279 | WARN_ON(1); | 718 | WARN_ON(1); |
| 280 | ret = -EINVAL; | 719 | ret = -EINVAL; |
| 281 | spin_unlock(&block_group->tree_lock); | 720 | goto out_lock; |
| 282 | goto out; | ||
| 283 | } | 721 | } |
| 284 | unlink_free_space(block_group, info); | ||
| 285 | 722 | ||
| 286 | if (info->bytes == bytes) { | 723 | info = next_info; |
| 287 | kfree(info); | 724 | } |
| 288 | spin_unlock(&block_group->tree_lock); | 725 | |
| 289 | goto out; | 726 | if (info->bytes == bytes) { |
| 727 | unlink_free_space(block_group, info); | ||
| 728 | if (info->bitmap) { | ||
| 729 | kfree(info->bitmap); | ||
| 730 | block_group->total_bitmaps--; | ||
| 290 | } | 731 | } |
| 732 | kfree(info); | ||
| 733 | goto out_lock; | ||
| 734 | } | ||
| 291 | 735 | ||
| 736 | if (!info->bitmap && info->offset == offset) { | ||
| 737 | unlink_free_space(block_group, info); | ||
| 292 | info->offset += bytes; | 738 | info->offset += bytes; |
| 293 | info->bytes -= bytes; | 739 | info->bytes -= bytes; |
| 740 | link_free_space(block_group, info); | ||
| 741 | goto out_lock; | ||
| 742 | } | ||
| 294 | 743 | ||
| 295 | ret = link_free_space(block_group, info); | 744 | if (!info->bitmap && info->offset <= offset && |
| 296 | spin_unlock(&block_group->tree_lock); | 745 | info->offset + info->bytes >= offset + bytes) { |
| 297 | BUG_ON(ret); | ||
| 298 | } else if (info && info->offset < offset && | ||
| 299 | info->offset + info->bytes >= offset + bytes) { | ||
| 300 | u64 old_start = info->offset; | 746 | u64 old_start = info->offset; |
| 301 | /* | 747 | /* |
| 302 | * we're freeing space in the middle of the info, | 748 | * we're freeing space in the middle of the info, |
| @@ -312,7 +758,9 @@ int btrfs_remove_free_space(struct btrfs_block_group_cache *block_group, | |||
| 312 | info->offset = offset + bytes; | 758 | info->offset = offset + bytes; |
| 313 | info->bytes = old_end - info->offset; | 759 | info->bytes = old_end - info->offset; |
| 314 | ret = link_free_space(block_group, info); | 760 | ret = link_free_space(block_group, info); |
| 315 | BUG_ON(ret); | 761 | WARN_ON(ret); |
| 762 | if (ret) | ||
| 763 | goto out_lock; | ||
| 316 | } else { | 764 | } else { |
| 317 | /* the hole we're creating ends at the end | 765 | /* the hole we're creating ends at the end |
| 318 | * of the info struct, just free the info | 766 | * of the info struct, just free the info |
| @@ -320,32 +768,22 @@ int btrfs_remove_free_space(struct btrfs_block_group_cache *block_group, | |||
| 320 | kfree(info); | 768 | kfree(info); |
| 321 | } | 769 | } |
| 322 | spin_unlock(&block_group->tree_lock); | 770 | spin_unlock(&block_group->tree_lock); |
| 323 | /* step two, insert a new info struct to cover anything | 771 | |
| 324 | * before the hole | 772 | /* step two, insert a new info struct to cover |
| 773 | * anything before the hole | ||
| 325 | */ | 774 | */ |
| 326 | ret = btrfs_add_free_space(block_group, old_start, | 775 | ret = btrfs_add_free_space(block_group, old_start, |
| 327 | offset - old_start); | 776 | offset - old_start); |
| 328 | BUG_ON(ret); | 777 | WARN_ON(ret); |
| 329 | } else { | 778 | goto out; |
| 330 | spin_unlock(&block_group->tree_lock); | ||
| 331 | if (!info) { | ||
| 332 | printk(KERN_ERR "couldn't find space %llu to free\n", | ||
| 333 | (unsigned long long)offset); | ||
| 334 | printk(KERN_ERR "cached is %d, offset %llu bytes %llu\n", | ||
| 335 | block_group->cached, | ||
| 336 | (unsigned long long)block_group->key.objectid, | ||
| 337 | (unsigned long long)block_group->key.offset); | ||
| 338 | btrfs_dump_free_space(block_group, bytes); | ||
| 339 | } else if (info) { | ||
| 340 | printk(KERN_ERR "hmm, found offset=%llu bytes=%llu, " | ||
| 341 | "but wanted offset=%llu bytes=%llu\n", | ||
| 342 | (unsigned long long)info->offset, | ||
| 343 | (unsigned long long)info->bytes, | ||
| 344 | (unsigned long long)offset, | ||
| 345 | (unsigned long long)bytes); | ||
| 346 | } | ||
| 347 | WARN_ON(1); | ||
| 348 | } | 779 | } |
| 780 | |||
| 781 | ret = remove_from_bitmap(block_group, info, &offset, &bytes); | ||
| 782 | if (ret == -EAGAIN) | ||
| 783 | goto again; | ||
| 784 | BUG_ON(ret); | ||
| 785 | out_lock: | ||
| 786 | spin_unlock(&block_group->tree_lock); | ||
| 349 | out: | 787 | out: |
| 350 | return ret; | 788 | return ret; |
| 351 | } | 789 | } |
| @@ -361,10 +799,13 @@ void btrfs_dump_free_space(struct btrfs_block_group_cache *block_group, | |||
| 361 | info = rb_entry(n, struct btrfs_free_space, offset_index); | 799 | info = rb_entry(n, struct btrfs_free_space, offset_index); |
| 362 | if (info->bytes >= bytes) | 800 | if (info->bytes >= bytes) |
| 363 | count++; | 801 | count++; |
| 364 | printk(KERN_ERR "entry offset %llu, bytes %llu\n", | 802 | printk(KERN_CRIT "entry offset %llu, bytes %llu, bitmap %s\n", |
| 365 | (unsigned long long)info->offset, | 803 | (unsigned long long)info->offset, |
| 366 | (unsigned long long)info->bytes); | 804 | (unsigned long long)info->bytes, |
| 805 | (info->bitmap) ? "yes" : "no"); | ||
| 367 | } | 806 | } |
| 807 | printk(KERN_INFO "block group has cluster?: %s\n", | ||
| 808 | list_empty(&block_group->cluster_list) ? "no" : "yes"); | ||
| 368 | printk(KERN_INFO "%d blocks of free space at or bigger than bytes is" | 809 | printk(KERN_INFO "%d blocks of free space at or bigger than bytes is" |
| 369 | "\n", count); | 810 | "\n", count); |
| 370 | } | 811 | } |
| @@ -397,26 +838,35 @@ __btrfs_return_cluster_to_free_space( | |||
| 397 | { | 838 | { |
| 398 | struct btrfs_free_space *entry; | 839 | struct btrfs_free_space *entry; |
| 399 | struct rb_node *node; | 840 | struct rb_node *node; |
| 841 | bool bitmap; | ||
| 400 | 842 | ||
| 401 | spin_lock(&cluster->lock); | 843 | spin_lock(&cluster->lock); |
| 402 | if (cluster->block_group != block_group) | 844 | if (cluster->block_group != block_group) |
| 403 | goto out; | 845 | goto out; |
| 404 | 846 | ||
| 847 | bitmap = cluster->points_to_bitmap; | ||
| 848 | cluster->block_group = NULL; | ||
| 405 | cluster->window_start = 0; | 849 | cluster->window_start = 0; |
| 850 | list_del_init(&cluster->block_group_list); | ||
| 851 | cluster->points_to_bitmap = false; | ||
| 852 | |||
| 853 | if (bitmap) | ||
| 854 | goto out; | ||
| 855 | |||
| 406 | node = rb_first(&cluster->root); | 856 | node = rb_first(&cluster->root); |
| 407 | while(node) { | 857 | while (node) { |
| 408 | entry = rb_entry(node, struct btrfs_free_space, offset_index); | 858 | entry = rb_entry(node, struct btrfs_free_space, offset_index); |
| 409 | node = rb_next(&entry->offset_index); | 859 | node = rb_next(&entry->offset_index); |
| 410 | rb_erase(&entry->offset_index, &cluster->root); | 860 | rb_erase(&entry->offset_index, &cluster->root); |
| 411 | link_free_space(block_group, entry); | 861 | BUG_ON(entry->bitmap); |
| 862 | tree_insert_offset(&block_group->free_space_offset, | ||
| 863 | entry->offset, &entry->offset_index, 0); | ||
| 412 | } | 864 | } |
| 413 | list_del_init(&cluster->block_group_list); | ||
| 414 | |||
| 415 | btrfs_put_block_group(cluster->block_group); | ||
| 416 | cluster->block_group = NULL; | ||
| 417 | cluster->root.rb_node = NULL; | 865 | cluster->root.rb_node = NULL; |
| 866 | |||
| 418 | out: | 867 | out: |
| 419 | spin_unlock(&cluster->lock); | 868 | spin_unlock(&cluster->lock); |
| 869 | btrfs_put_block_group(block_group); | ||
| 420 | return 0; | 870 | return 0; |
| 421 | } | 871 | } |
| 422 | 872 | ||
| @@ -425,20 +875,28 @@ void btrfs_remove_free_space_cache(struct btrfs_block_group_cache *block_group) | |||
| 425 | struct btrfs_free_space *info; | 875 | struct btrfs_free_space *info; |
| 426 | struct rb_node *node; | 876 | struct rb_node *node; |
| 427 | struct btrfs_free_cluster *cluster; | 877 | struct btrfs_free_cluster *cluster; |
| 428 | struct btrfs_free_cluster *safe; | 878 | struct list_head *head; |
| 429 | 879 | ||
| 430 | spin_lock(&block_group->tree_lock); | 880 | spin_lock(&block_group->tree_lock); |
| 431 | 881 | while ((head = block_group->cluster_list.next) != | |
| 432 | list_for_each_entry_safe(cluster, safe, &block_group->cluster_list, | 882 | &block_group->cluster_list) { |
| 433 | block_group_list) { | 883 | cluster = list_entry(head, struct btrfs_free_cluster, |
| 884 | block_group_list); | ||
| 434 | 885 | ||
| 435 | WARN_ON(cluster->block_group != block_group); | 886 | WARN_ON(cluster->block_group != block_group); |
| 436 | __btrfs_return_cluster_to_free_space(block_group, cluster); | 887 | __btrfs_return_cluster_to_free_space(block_group, cluster); |
| 888 | if (need_resched()) { | ||
| 889 | spin_unlock(&block_group->tree_lock); | ||
| 890 | cond_resched(); | ||
| 891 | spin_lock(&block_group->tree_lock); | ||
| 892 | } | ||
| 437 | } | 893 | } |
| 438 | 894 | ||
| 439 | while ((node = rb_last(&block_group->free_space_bytes)) != NULL) { | 895 | while ((node = rb_last(&block_group->free_space_offset)) != NULL) { |
| 440 | info = rb_entry(node, struct btrfs_free_space, bytes_index); | 896 | info = rb_entry(node, struct btrfs_free_space, offset_index); |
| 441 | unlink_free_space(block_group, info); | 897 | unlink_free_space(block_group, info); |
| 898 | if (info->bitmap) | ||
| 899 | kfree(info->bitmap); | ||
| 442 | kfree(info); | 900 | kfree(info); |
| 443 | if (need_resched()) { | 901 | if (need_resched()) { |
| 444 | spin_unlock(&block_group->tree_lock); | 902 | spin_unlock(&block_group->tree_lock); |
| @@ -446,6 +904,7 @@ void btrfs_remove_free_space_cache(struct btrfs_block_group_cache *block_group) | |||
| 446 | spin_lock(&block_group->tree_lock); | 904 | spin_lock(&block_group->tree_lock); |
| 447 | } | 905 | } |
| 448 | } | 906 | } |
| 907 | |||
| 449 | spin_unlock(&block_group->tree_lock); | 908 | spin_unlock(&block_group->tree_lock); |
| 450 | } | 909 | } |
| 451 | 910 | ||
| @@ -453,25 +912,35 @@ u64 btrfs_find_space_for_alloc(struct btrfs_block_group_cache *block_group, | |||
| 453 | u64 offset, u64 bytes, u64 empty_size) | 912 | u64 offset, u64 bytes, u64 empty_size) |
| 454 | { | 913 | { |
| 455 | struct btrfs_free_space *entry = NULL; | 914 | struct btrfs_free_space *entry = NULL; |
| 915 | u64 bytes_search = bytes + empty_size; | ||
| 456 | u64 ret = 0; | 916 | u64 ret = 0; |
| 457 | 917 | ||
| 458 | spin_lock(&block_group->tree_lock); | 918 | spin_lock(&block_group->tree_lock); |
| 459 | entry = tree_search_offset(&block_group->free_space_offset, offset, | 919 | entry = find_free_space(block_group, &offset, &bytes_search, 0); |
| 460 | bytes + empty_size, 1); | ||
| 461 | if (!entry) | 920 | if (!entry) |
| 462 | entry = tree_search_bytes(&block_group->free_space_bytes, | 921 | goto out; |
| 463 | offset, bytes + empty_size); | 922 | |
| 464 | if (entry) { | 923 | ret = offset; |
| 924 | if (entry->bitmap) { | ||
| 925 | bitmap_clear_bits(block_group, entry, offset, bytes); | ||
| 926 | if (!entry->bytes) { | ||
| 927 | unlink_free_space(block_group, entry); | ||
| 928 | kfree(entry->bitmap); | ||
| 929 | kfree(entry); | ||
| 930 | block_group->total_bitmaps--; | ||
| 931 | recalculate_thresholds(block_group); | ||
| 932 | } | ||
| 933 | } else { | ||
| 465 | unlink_free_space(block_group, entry); | 934 | unlink_free_space(block_group, entry); |
| 466 | ret = entry->offset; | ||
| 467 | entry->offset += bytes; | 935 | entry->offset += bytes; |
| 468 | entry->bytes -= bytes; | 936 | entry->bytes -= bytes; |
| 469 | |||
| 470 | if (!entry->bytes) | 937 | if (!entry->bytes) |
| 471 | kfree(entry); | 938 | kfree(entry); |
| 472 | else | 939 | else |
| 473 | link_free_space(block_group, entry); | 940 | link_free_space(block_group, entry); |
| 474 | } | 941 | } |
| 942 | |||
| 943 | out: | ||
| 475 | spin_unlock(&block_group->tree_lock); | 944 | spin_unlock(&block_group->tree_lock); |
| 476 | 945 | ||
| 477 | return ret; | 946 | return ret; |
| @@ -517,6 +986,54 @@ int btrfs_return_cluster_to_free_space( | |||
| 517 | return ret; | 986 | return ret; |
| 518 | } | 987 | } |
| 519 | 988 | ||
| 989 | static u64 btrfs_alloc_from_bitmap(struct btrfs_block_group_cache *block_group, | ||
| 990 | struct btrfs_free_cluster *cluster, | ||
| 991 | u64 bytes, u64 min_start) | ||
| 992 | { | ||
| 993 | struct btrfs_free_space *entry; | ||
| 994 | int err; | ||
| 995 | u64 search_start = cluster->window_start; | ||
| 996 | u64 search_bytes = bytes; | ||
| 997 | u64 ret = 0; | ||
| 998 | |||
| 999 | spin_lock(&block_group->tree_lock); | ||
| 1000 | spin_lock(&cluster->lock); | ||
| 1001 | |||
| 1002 | if (!cluster->points_to_bitmap) | ||
| 1003 | goto out; | ||
| 1004 | |||
| 1005 | if (cluster->block_group != block_group) | ||
| 1006 | goto out; | ||
| 1007 | |||
| 1008 | /* | ||
| 1009 | * search_start is the beginning of the bitmap, but at some point it may | ||
| 1010 | * be a good idea to point to the actual start of the free area in the | ||
| 1011 | * bitmap, so do the offset_to_bitmap trick anyway, and set bitmap_only | ||
| 1012 | * to 1 to make sure we get the bitmap entry | ||
| 1013 | */ | ||
| 1014 | entry = tree_search_offset(block_group, | ||
| 1015 | offset_to_bitmap(block_group, search_start), | ||
| 1016 | 1, 0); | ||
| 1017 | if (!entry || !entry->bitmap) | ||
| 1018 | goto out; | ||
| 1019 | |||
| 1020 | search_start = min_start; | ||
| 1021 | search_bytes = bytes; | ||
| 1022 | |||
| 1023 | err = search_bitmap(block_group, entry, &search_start, | ||
| 1024 | &search_bytes); | ||
| 1025 | if (err) | ||
| 1026 | goto out; | ||
| 1027 | |||
| 1028 | ret = search_start; | ||
| 1029 | bitmap_clear_bits(block_group, entry, ret, bytes); | ||
| 1030 | out: | ||
| 1031 | spin_unlock(&cluster->lock); | ||
| 1032 | spin_unlock(&block_group->tree_lock); | ||
| 1033 | |||
| 1034 | return ret; | ||
| 1035 | } | ||
| 1036 | |||
| 520 | /* | 1037 | /* |
| 521 | * given a cluster, try to allocate 'bytes' from it, returns 0 | 1038 | * given a cluster, try to allocate 'bytes' from it, returns 0 |
| 522 | * if it couldn't find anything suitably large, or a logical disk offset | 1039 | * if it couldn't find anything suitably large, or a logical disk offset |
| @@ -530,6 +1047,10 @@ u64 btrfs_alloc_from_cluster(struct btrfs_block_group_cache *block_group, | |||
| 530 | struct rb_node *node; | 1047 | struct rb_node *node; |
| 531 | u64 ret = 0; | 1048 | u64 ret = 0; |
| 532 | 1049 | ||
| 1050 | if (cluster->points_to_bitmap) | ||
| 1051 | return btrfs_alloc_from_bitmap(block_group, cluster, bytes, | ||
| 1052 | min_start); | ||
| 1053 | |||
| 533 | spin_lock(&cluster->lock); | 1054 | spin_lock(&cluster->lock); |
| 534 | if (bytes > cluster->max_size) | 1055 | if (bytes > cluster->max_size) |
| 535 | goto out; | 1056 | goto out; |
| @@ -567,9 +1088,73 @@ u64 btrfs_alloc_from_cluster(struct btrfs_block_group_cache *block_group, | |||
| 567 | } | 1088 | } |
| 568 | out: | 1089 | out: |
| 569 | spin_unlock(&cluster->lock); | 1090 | spin_unlock(&cluster->lock); |
| 1091 | |||
| 570 | return ret; | 1092 | return ret; |
| 571 | } | 1093 | } |
| 572 | 1094 | ||
| 1095 | static int btrfs_bitmap_cluster(struct btrfs_block_group_cache *block_group, | ||
| 1096 | struct btrfs_free_space *entry, | ||
| 1097 | struct btrfs_free_cluster *cluster, | ||
| 1098 | u64 offset, u64 bytes, u64 min_bytes) | ||
| 1099 | { | ||
| 1100 | unsigned long next_zero; | ||
| 1101 | unsigned long i; | ||
| 1102 | unsigned long search_bits; | ||
| 1103 | unsigned long total_bits; | ||
| 1104 | unsigned long found_bits; | ||
| 1105 | unsigned long start = 0; | ||
| 1106 | unsigned long total_found = 0; | ||
| 1107 | bool found = false; | ||
| 1108 | |||
| 1109 | i = offset_to_bit(entry->offset, block_group->sectorsize, | ||
| 1110 | max_t(u64, offset, entry->offset)); | ||
| 1111 | search_bits = bytes_to_bits(min_bytes, block_group->sectorsize); | ||
| 1112 | total_bits = bytes_to_bits(bytes, block_group->sectorsize); | ||
| 1113 | |||
| 1114 | again: | ||
| 1115 | found_bits = 0; | ||
| 1116 | for (i = find_next_bit(entry->bitmap, BITS_PER_BITMAP, i); | ||
| 1117 | i < BITS_PER_BITMAP; | ||
| 1118 | i = find_next_bit(entry->bitmap, BITS_PER_BITMAP, i + 1)) { | ||
| 1119 | next_zero = find_next_zero_bit(entry->bitmap, | ||
| 1120 | BITS_PER_BITMAP, i); | ||
| 1121 | if (next_zero - i >= search_bits) { | ||
| 1122 | found_bits = next_zero - i; | ||
| 1123 | break; | ||
| 1124 | } | ||
| 1125 | i = next_zero; | ||
| 1126 | } | ||
| 1127 | |||
| 1128 | if (!found_bits) | ||
| 1129 | return -1; | ||
| 1130 | |||
| 1131 | if (!found) { | ||
| 1132 | start = i; | ||
| 1133 | found = true; | ||
| 1134 | } | ||
| 1135 | |||
| 1136 | total_found += found_bits; | ||
| 1137 | |||
| 1138 | if (cluster->max_size < found_bits * block_group->sectorsize) | ||
| 1139 | cluster->max_size = found_bits * block_group->sectorsize; | ||
| 1140 | |||
| 1141 | if (total_found < total_bits) { | ||
| 1142 | i = find_next_bit(entry->bitmap, BITS_PER_BITMAP, next_zero); | ||
| 1143 | if (i - start > total_bits * 2) { | ||
| 1144 | total_found = 0; | ||
| 1145 | cluster->max_size = 0; | ||
| 1146 | found = false; | ||
| 1147 | } | ||
| 1148 | goto again; | ||
| 1149 | } | ||
| 1150 | |||
| 1151 | cluster->window_start = start * block_group->sectorsize + | ||
| 1152 | entry->offset; | ||
| 1153 | cluster->points_to_bitmap = true; | ||
| 1154 | |||
| 1155 | return 0; | ||
| 1156 | } | ||
| 1157 | |||
| 573 | /* | 1158 | /* |
| 574 | * here we try to find a cluster of blocks in a block group. The goal | 1159 | * here we try to find a cluster of blocks in a block group. The goal |
| 575 | * is to find at least bytes free and up to empty_size + bytes free. | 1160 | * is to find at least bytes free and up to empty_size + bytes free. |
| @@ -587,12 +1172,12 @@ int btrfs_find_space_cluster(struct btrfs_trans_handle *trans, | |||
| 587 | struct btrfs_free_space *entry = NULL; | 1172 | struct btrfs_free_space *entry = NULL; |
| 588 | struct rb_node *node; | 1173 | struct rb_node *node; |
| 589 | struct btrfs_free_space *next; | 1174 | struct btrfs_free_space *next; |
| 590 | struct btrfs_free_space *last; | 1175 | struct btrfs_free_space *last = NULL; |
| 591 | u64 min_bytes; | 1176 | u64 min_bytes; |
| 592 | u64 window_start; | 1177 | u64 window_start; |
| 593 | u64 window_free; | 1178 | u64 window_free; |
| 594 | u64 max_extent = 0; | 1179 | u64 max_extent = 0; |
| 595 | int total_retries = 0; | 1180 | bool found_bitmap = false; |
| 596 | int ret; | 1181 | int ret; |
| 597 | 1182 | ||
| 598 | /* for metadata, allow allocates with more holes */ | 1183 | /* for metadata, allow allocates with more holes */ |
| @@ -620,31 +1205,80 @@ int btrfs_find_space_cluster(struct btrfs_trans_handle *trans, | |||
| 620 | goto out; | 1205 | goto out; |
| 621 | } | 1206 | } |
| 622 | again: | 1207 | again: |
| 623 | min_bytes = min(min_bytes, bytes + empty_size); | 1208 | entry = tree_search_offset(block_group, offset, found_bitmap, 1); |
| 624 | entry = tree_search_bytes(&block_group->free_space_bytes, | ||
| 625 | offset, min_bytes); | ||
| 626 | if (!entry) { | 1209 | if (!entry) { |
| 627 | ret = -ENOSPC; | 1210 | ret = -ENOSPC; |
| 628 | goto out; | 1211 | goto out; |
| 629 | } | 1212 | } |
| 1213 | |||
| 1214 | /* | ||
| 1215 | * If found_bitmap is true, we exhausted our search for extent entries, | ||
| 1216 | * and we just want to search all of the bitmaps that we can find, and | ||
| 1217 | * ignore any extent entries we find. | ||
| 1218 | */ | ||
| 1219 | while (entry->bitmap || found_bitmap || | ||
| 1220 | (!entry->bitmap && entry->bytes < min_bytes)) { | ||
| 1221 | struct rb_node *node = rb_next(&entry->offset_index); | ||
| 1222 | |||
| 1223 | if (entry->bitmap && entry->bytes > bytes + empty_size) { | ||
| 1224 | ret = btrfs_bitmap_cluster(block_group, entry, cluster, | ||
| 1225 | offset, bytes + empty_size, | ||
| 1226 | min_bytes); | ||
| 1227 | if (!ret) | ||
| 1228 | goto got_it; | ||
| 1229 | } | ||
| 1230 | |||
| 1231 | if (!node) { | ||
| 1232 | ret = -ENOSPC; | ||
| 1233 | goto out; | ||
| 1234 | } | ||
| 1235 | entry = rb_entry(node, struct btrfs_free_space, offset_index); | ||
| 1236 | } | ||
| 1237 | |||
| 1238 | /* | ||
| 1239 | * We already searched all the extent entries from the passed in offset | ||
| 1240 | * to the end and didn't find enough space for the cluster, and we also | ||
| 1241 | * didn't find any bitmaps that met our criteria, just go ahead and exit | ||
| 1242 | */ | ||
| 1243 | if (found_bitmap) { | ||
| 1244 | ret = -ENOSPC; | ||
| 1245 | goto out; | ||
| 1246 | } | ||
| 1247 | |||
| 1248 | cluster->points_to_bitmap = false; | ||
| 630 | window_start = entry->offset; | 1249 | window_start = entry->offset; |
| 631 | window_free = entry->bytes; | 1250 | window_free = entry->bytes; |
| 632 | last = entry; | 1251 | last = entry; |
| 633 | max_extent = entry->bytes; | 1252 | max_extent = entry->bytes; |
| 634 | 1253 | ||
| 635 | while(1) { | 1254 | while (1) { |
| 636 | /* out window is just right, lets fill it */ | 1255 | /* out window is just right, lets fill it */ |
| 637 | if (window_free >= bytes + empty_size) | 1256 | if (window_free >= bytes + empty_size) |
| 638 | break; | 1257 | break; |
| 639 | 1258 | ||
| 640 | node = rb_next(&last->offset_index); | 1259 | node = rb_next(&last->offset_index); |
| 641 | if (!node) { | 1260 | if (!node) { |
| 1261 | if (found_bitmap) | ||
| 1262 | goto again; | ||
| 642 | ret = -ENOSPC; | 1263 | ret = -ENOSPC; |
| 643 | goto out; | 1264 | goto out; |
| 644 | } | 1265 | } |
| 645 | next = rb_entry(node, struct btrfs_free_space, offset_index); | 1266 | next = rb_entry(node, struct btrfs_free_space, offset_index); |
| 646 | 1267 | ||
| 647 | /* | 1268 | /* |
| 1269 | * we found a bitmap, so if this search doesn't result in a | ||
| 1270 | * cluster, we know to go and search again for the bitmaps and | ||
| 1271 | * start looking for space there | ||
| 1272 | */ | ||
| 1273 | if (next->bitmap) { | ||
| 1274 | if (!found_bitmap) | ||
| 1275 | offset = next->offset; | ||
| 1276 | found_bitmap = true; | ||
| 1277 | last = next; | ||
| 1278 | continue; | ||
| 1279 | } | ||
| 1280 | |||
| 1281 | /* | ||
| 648 | * we haven't filled the empty size and the window is | 1282 | * we haven't filled the empty size and the window is |
| 649 | * very large. reset and try again | 1283 | * very large. reset and try again |
| 650 | */ | 1284 | */ |
| @@ -655,19 +1289,6 @@ again: | |||
| 655 | window_free = entry->bytes; | 1289 | window_free = entry->bytes; |
| 656 | last = entry; | 1290 | last = entry; |
| 657 | max_extent = 0; | 1291 | max_extent = 0; |
| 658 | total_retries++; | ||
| 659 | if (total_retries % 64 == 0) { | ||
| 660 | if (min_bytes >= (bytes + empty_size)) { | ||
| 661 | ret = -ENOSPC; | ||
| 662 | goto out; | ||
| 663 | } | ||
| 664 | /* | ||
| 665 | * grow our allocation a bit, we're not having | ||
| 666 | * much luck | ||
| 667 | */ | ||
| 668 | min_bytes *= 2; | ||
| 669 | goto again; | ||
| 670 | } | ||
| 671 | } else { | 1292 | } else { |
| 672 | last = next; | 1293 | last = next; |
| 673 | window_free += next->bytes; | 1294 | window_free += next->bytes; |
| @@ -685,11 +1306,19 @@ again: | |||
| 685 | * The cluster includes an rbtree, but only uses the offset index | 1306 | * The cluster includes an rbtree, but only uses the offset index |
| 686 | * of each free space cache entry. | 1307 | * of each free space cache entry. |
| 687 | */ | 1308 | */ |
| 688 | while(1) { | 1309 | while (1) { |
| 689 | node = rb_next(&entry->offset_index); | 1310 | node = rb_next(&entry->offset_index); |
| 690 | unlink_free_space(block_group, entry); | 1311 | if (entry->bitmap && node) { |
| 1312 | entry = rb_entry(node, struct btrfs_free_space, | ||
| 1313 | offset_index); | ||
| 1314 | continue; | ||
| 1315 | } else if (entry->bitmap && !node) { | ||
| 1316 | break; | ||
| 1317 | } | ||
| 1318 | |||
| 1319 | rb_erase(&entry->offset_index, &block_group->free_space_offset); | ||
| 691 | ret = tree_insert_offset(&cluster->root, entry->offset, | 1320 | ret = tree_insert_offset(&cluster->root, entry->offset, |
| 692 | &entry->offset_index); | 1321 | &entry->offset_index, 0); |
| 693 | BUG_ON(ret); | 1322 | BUG_ON(ret); |
| 694 | 1323 | ||
| 695 | if (!node || entry == last) | 1324 | if (!node || entry == last) |
| @@ -697,8 +1326,10 @@ again: | |||
| 697 | 1326 | ||
| 698 | entry = rb_entry(node, struct btrfs_free_space, offset_index); | 1327 | entry = rb_entry(node, struct btrfs_free_space, offset_index); |
| 699 | } | 1328 | } |
| 700 | ret = 0; | 1329 | |
| 701 | cluster->max_size = max_extent; | 1330 | cluster->max_size = max_extent; |
| 1331 | got_it: | ||
| 1332 | ret = 0; | ||
| 702 | atomic_inc(&block_group->count); | 1333 | atomic_inc(&block_group->count); |
| 703 | list_add_tail(&cluster->block_group_list, &block_group->cluster_list); | 1334 | list_add_tail(&cluster->block_group_list, &block_group->cluster_list); |
| 704 | cluster->block_group = block_group; | 1335 | cluster->block_group = block_group; |
| @@ -718,6 +1349,7 @@ void btrfs_init_free_cluster(struct btrfs_free_cluster *cluster) | |||
| 718 | spin_lock_init(&cluster->refill_lock); | 1349 | spin_lock_init(&cluster->refill_lock); |
| 719 | cluster->root.rb_node = NULL; | 1350 | cluster->root.rb_node = NULL; |
| 720 | cluster->max_size = 0; | 1351 | cluster->max_size = 0; |
| 1352 | cluster->points_to_bitmap = false; | ||
| 721 | INIT_LIST_HEAD(&cluster->block_group_list); | 1353 | INIT_LIST_HEAD(&cluster->block_group_list); |
| 722 | cluster->block_group = NULL; | 1354 | cluster->block_group = NULL; |
| 723 | } | 1355 | } |
diff --git a/fs/btrfs/free-space-cache.h b/fs/btrfs/free-space-cache.h index 266fb8764054..890a8e79011b 100644 --- a/fs/btrfs/free-space-cache.h +++ b/fs/btrfs/free-space-cache.h | |||
| @@ -19,6 +19,14 @@ | |||
| 19 | #ifndef __BTRFS_FREE_SPACE_CACHE | 19 | #ifndef __BTRFS_FREE_SPACE_CACHE |
| 20 | #define __BTRFS_FREE_SPACE_CACHE | 20 | #define __BTRFS_FREE_SPACE_CACHE |
| 21 | 21 | ||
| 22 | struct btrfs_free_space { | ||
| 23 | struct rb_node offset_index; | ||
| 24 | u64 offset; | ||
| 25 | u64 bytes; | ||
| 26 | unsigned long *bitmap; | ||
| 27 | struct list_head list; | ||
| 28 | }; | ||
| 29 | |||
| 22 | int btrfs_add_free_space(struct btrfs_block_group_cache *block_group, | 30 | int btrfs_add_free_space(struct btrfs_block_group_cache *block_group, |
| 23 | u64 bytenr, u64 size); | 31 | u64 bytenr, u64 size); |
| 24 | int btrfs_remove_free_space(struct btrfs_block_group_cache *block_group, | 32 | int btrfs_remove_free_space(struct btrfs_block_group_cache *block_group, |
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c index 791eab19e330..59cba180fe83 100644 --- a/fs/btrfs/inode.c +++ b/fs/btrfs/inode.c | |||
| @@ -2603,8 +2603,8 @@ noinline int btrfs_truncate_inode_items(struct btrfs_trans_handle *trans, | |||
| 2603 | if (root->ref_cows) | 2603 | if (root->ref_cows) |
| 2604 | btrfs_drop_extent_cache(inode, new_size & (~mask), (u64)-1, 0); | 2604 | btrfs_drop_extent_cache(inode, new_size & (~mask), (u64)-1, 0); |
| 2605 | path = btrfs_alloc_path(); | 2605 | path = btrfs_alloc_path(); |
| 2606 | path->reada = -1; | ||
| 2607 | BUG_ON(!path); | 2606 | BUG_ON(!path); |
| 2607 | path->reada = -1; | ||
| 2608 | 2608 | ||
| 2609 | /* FIXME, add redo link to tree so we don't leak on crash */ | 2609 | /* FIXME, add redo link to tree so we don't leak on crash */ |
| 2610 | key.objectid = inode->i_ino; | 2610 | key.objectid = inode->i_ino; |
| @@ -3099,8 +3099,12 @@ static void inode_tree_add(struct inode *inode) | |||
| 3099 | { | 3099 | { |
| 3100 | struct btrfs_root *root = BTRFS_I(inode)->root; | 3100 | struct btrfs_root *root = BTRFS_I(inode)->root; |
| 3101 | struct btrfs_inode *entry; | 3101 | struct btrfs_inode *entry; |
| 3102 | struct rb_node **p = &root->inode_tree.rb_node; | 3102 | struct rb_node **p; |
| 3103 | struct rb_node *parent = NULL; | 3103 | struct rb_node *parent; |
| 3104 | |||
| 3105 | again: | ||
| 3106 | p = &root->inode_tree.rb_node; | ||
| 3107 | parent = NULL; | ||
| 3104 | 3108 | ||
| 3105 | spin_lock(&root->inode_lock); | 3109 | spin_lock(&root->inode_lock); |
| 3106 | while (*p) { | 3110 | while (*p) { |
| @@ -3108,13 +3112,16 @@ static void inode_tree_add(struct inode *inode) | |||
| 3108 | entry = rb_entry(parent, struct btrfs_inode, rb_node); | 3112 | entry = rb_entry(parent, struct btrfs_inode, rb_node); |
| 3109 | 3113 | ||
| 3110 | if (inode->i_ino < entry->vfs_inode.i_ino) | 3114 | if (inode->i_ino < entry->vfs_inode.i_ino) |
| 3111 | p = &(*p)->rb_left; | 3115 | p = &parent->rb_left; |
| 3112 | else if (inode->i_ino > entry->vfs_inode.i_ino) | 3116 | else if (inode->i_ino > entry->vfs_inode.i_ino) |
| 3113 | p = &(*p)->rb_right; | 3117 | p = &parent->rb_right; |
| 3114 | else { | 3118 | else { |
| 3115 | WARN_ON(!(entry->vfs_inode.i_state & | 3119 | WARN_ON(!(entry->vfs_inode.i_state & |
| 3116 | (I_WILL_FREE | I_FREEING | I_CLEAR))); | 3120 | (I_WILL_FREE | I_FREEING | I_CLEAR))); |
| 3117 | break; | 3121 | rb_erase(parent, &root->inode_tree); |
| 3122 | RB_CLEAR_NODE(parent); | ||
| 3123 | spin_unlock(&root->inode_lock); | ||
| 3124 | goto again; | ||
| 3118 | } | 3125 | } |
| 3119 | } | 3126 | } |
| 3120 | rb_link_node(&BTRFS_I(inode)->rb_node, parent, p); | 3127 | rb_link_node(&BTRFS_I(inode)->rb_node, parent, p); |
| @@ -3126,12 +3133,12 @@ static void inode_tree_del(struct inode *inode) | |||
| 3126 | { | 3133 | { |
| 3127 | struct btrfs_root *root = BTRFS_I(inode)->root; | 3134 | struct btrfs_root *root = BTRFS_I(inode)->root; |
| 3128 | 3135 | ||
| 3136 | spin_lock(&root->inode_lock); | ||
| 3129 | if (!RB_EMPTY_NODE(&BTRFS_I(inode)->rb_node)) { | 3137 | if (!RB_EMPTY_NODE(&BTRFS_I(inode)->rb_node)) { |
| 3130 | spin_lock(&root->inode_lock); | ||
| 3131 | rb_erase(&BTRFS_I(inode)->rb_node, &root->inode_tree); | 3138 | rb_erase(&BTRFS_I(inode)->rb_node, &root->inode_tree); |
| 3132 | spin_unlock(&root->inode_lock); | ||
| 3133 | RB_CLEAR_NODE(&BTRFS_I(inode)->rb_node); | 3139 | RB_CLEAR_NODE(&BTRFS_I(inode)->rb_node); |
| 3134 | } | 3140 | } |
| 3141 | spin_unlock(&root->inode_lock); | ||
| 3135 | } | 3142 | } |
| 3136 | 3143 | ||
| 3137 | static noinline void init_btrfs_i(struct inode *inode) | 3144 | static noinline void init_btrfs_i(struct inode *inode) |
| @@ -4785,8 +4792,7 @@ static int btrfs_rename(struct inode *old_dir, struct dentry *old_dentry, | |||
| 4785 | * and the replacement file is large. Start IO on it now so | 4792 | * and the replacement file is large. Start IO on it now so |
| 4786 | * we don't add too much work to the end of the transaction | 4793 | * we don't add too much work to the end of the transaction |
| 4787 | */ | 4794 | */ |
| 4788 | if (new_inode && old_inode && S_ISREG(old_inode->i_mode) && | 4795 | if (new_inode && S_ISREG(old_inode->i_mode) && new_inode->i_size && |
| 4789 | new_inode->i_size && | ||
| 4790 | old_inode->i_size > BTRFS_ORDERED_OPERATIONS_FLUSH_LIMIT) | 4796 | old_inode->i_size > BTRFS_ORDERED_OPERATIONS_FLUSH_LIMIT) |
| 4791 | filemap_flush(old_inode->i_mapping); | 4797 | filemap_flush(old_inode->i_mapping); |
| 4792 | 4798 | ||
diff --git a/fs/btrfs/print-tree.c b/fs/btrfs/print-tree.c index 6d6523da0a30..0d126be22b63 100644 --- a/fs/btrfs/print-tree.c +++ b/fs/btrfs/print-tree.c | |||
| @@ -309,7 +309,7 @@ void btrfs_print_tree(struct btrfs_root *root, struct extent_buffer *c) | |||
| 309 | } | 309 | } |
| 310 | printk(KERN_INFO "node %llu level %d total ptrs %d free spc %u\n", | 310 | printk(KERN_INFO "node %llu level %d total ptrs %d free spc %u\n", |
| 311 | (unsigned long long)btrfs_header_bytenr(c), | 311 | (unsigned long long)btrfs_header_bytenr(c), |
| 312 | btrfs_header_level(c), nr, | 312 | level, nr, |
| 313 | (u32)BTRFS_NODEPTRS_PER_BLOCK(root) - nr); | 313 | (u32)BTRFS_NODEPTRS_PER_BLOCK(root) - nr); |
| 314 | for (i = 0; i < nr; i++) { | 314 | for (i = 0; i < nr; i++) { |
| 315 | btrfs_node_key_to_cpu(c, &key, i); | 315 | btrfs_node_key_to_cpu(c, &key, i); |
| @@ -326,10 +326,10 @@ void btrfs_print_tree(struct btrfs_root *root, struct extent_buffer *c) | |||
| 326 | btrfs_level_size(root, level - 1), | 326 | btrfs_level_size(root, level - 1), |
| 327 | btrfs_node_ptr_generation(c, i)); | 327 | btrfs_node_ptr_generation(c, i)); |
| 328 | if (btrfs_is_leaf(next) && | 328 | if (btrfs_is_leaf(next) && |
| 329 | btrfs_header_level(c) != 1) | 329 | level != 1) |
| 330 | BUG(); | 330 | BUG(); |
| 331 | if (btrfs_header_level(next) != | 331 | if (btrfs_header_level(next) != |
| 332 | btrfs_header_level(c) - 1) | 332 | level - 1) |
| 333 | BUG(); | 333 | BUG(); |
| 334 | btrfs_print_tree(root, next); | 334 | btrfs_print_tree(root, next); |
| 335 | free_extent_buffer(next); | 335 | free_extent_buffer(next); |
diff --git a/fs/btrfs/relocation.c b/fs/btrfs/relocation.c index 008397934778..c04f7f212602 100644 --- a/fs/btrfs/relocation.c +++ b/fs/btrfs/relocation.c | |||
| @@ -670,6 +670,8 @@ again: | |||
| 670 | err = ret; | 670 | err = ret; |
| 671 | goto out; | 671 | goto out; |
| 672 | } | 672 | } |
| 673 | if (ret > 0 && path2->slots[level] > 0) | ||
| 674 | path2->slots[level]--; | ||
| 673 | 675 | ||
| 674 | eb = path2->nodes[level]; | 676 | eb = path2->nodes[level]; |
| 675 | WARN_ON(btrfs_node_blockptr(eb, path2->slots[level]) != | 677 | WARN_ON(btrfs_node_blockptr(eb, path2->slots[level]) != |
| @@ -1609,6 +1611,7 @@ static noinline_for_stack int merge_reloc_root(struct reloc_control *rc, | |||
| 1609 | BUG_ON(level == 0); | 1611 | BUG_ON(level == 0); |
| 1610 | path->lowest_level = level; | 1612 | path->lowest_level = level; |
| 1611 | ret = btrfs_search_slot(NULL, reloc_root, &key, path, 0, 0); | 1613 | ret = btrfs_search_slot(NULL, reloc_root, &key, path, 0, 0); |
| 1614 | path->lowest_level = 0; | ||
| 1612 | if (ret < 0) { | 1615 | if (ret < 0) { |
| 1613 | btrfs_free_path(path); | 1616 | btrfs_free_path(path); |
| 1614 | return ret; | 1617 | return ret; |
| @@ -2550,8 +2553,13 @@ int relocate_inode_pages(struct inode *inode, u64 start, u64 len) | |||
| 2550 | last_index = (start + len - 1) >> PAGE_CACHE_SHIFT; | 2553 | last_index = (start + len - 1) >> PAGE_CACHE_SHIFT; |
| 2551 | 2554 | ||
| 2552 | /* make sure the dirty trick played by the caller work */ | 2555 | /* make sure the dirty trick played by the caller work */ |
| 2553 | ret = invalidate_inode_pages2_range(inode->i_mapping, | 2556 | while (1) { |
| 2554 | first_index, last_index); | 2557 | ret = invalidate_inode_pages2_range(inode->i_mapping, |
| 2558 | first_index, last_index); | ||
| 2559 | if (ret != -EBUSY) | ||
| 2560 | break; | ||
| 2561 | schedule_timeout(HZ/10); | ||
| 2562 | } | ||
| 2555 | if (ret) | 2563 | if (ret) |
| 2556 | goto out_unlock; | 2564 | goto out_unlock; |
| 2557 | 2565 | ||
diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c index 2dbf1c1f56ee..cdbb5022da52 100644 --- a/fs/btrfs/transaction.c +++ b/fs/btrfs/transaction.c | |||
| @@ -40,6 +40,12 @@ static noinline void put_transaction(struct btrfs_transaction *transaction) | |||
| 40 | } | 40 | } |
| 41 | } | 41 | } |
| 42 | 42 | ||
| 43 | static noinline void switch_commit_root(struct btrfs_root *root) | ||
| 44 | { | ||
| 45 | free_extent_buffer(root->commit_root); | ||
| 46 | root->commit_root = btrfs_root_node(root); | ||
| 47 | } | ||
| 48 | |||
| 43 | /* | 49 | /* |
| 44 | * either allocate a new transaction or hop into the existing one | 50 | * either allocate a new transaction or hop into the existing one |
| 45 | */ | 51 | */ |
| @@ -444,9 +450,6 @@ static int update_cowonly_root(struct btrfs_trans_handle *trans, | |||
| 444 | 450 | ||
| 445 | btrfs_write_dirty_block_groups(trans, root); | 451 | btrfs_write_dirty_block_groups(trans, root); |
| 446 | 452 | ||
| 447 | ret = btrfs_run_delayed_refs(trans, root, (unsigned long)-1); | ||
| 448 | BUG_ON(ret); | ||
| 449 | |||
| 450 | while (1) { | 453 | while (1) { |
| 451 | old_root_bytenr = btrfs_root_bytenr(&root->root_item); | 454 | old_root_bytenr = btrfs_root_bytenr(&root->root_item); |
| 452 | if (old_root_bytenr == root->node->start) | 455 | if (old_root_bytenr == root->node->start) |
| @@ -457,13 +460,14 @@ static int update_cowonly_root(struct btrfs_trans_handle *trans, | |||
| 457 | &root->root_key, | 460 | &root->root_key, |
| 458 | &root->root_item); | 461 | &root->root_item); |
| 459 | BUG_ON(ret); | 462 | BUG_ON(ret); |
| 460 | btrfs_write_dirty_block_groups(trans, root); | ||
| 461 | 463 | ||
| 462 | ret = btrfs_run_delayed_refs(trans, root, (unsigned long)-1); | 464 | ret = btrfs_write_dirty_block_groups(trans, root); |
| 463 | BUG_ON(ret); | 465 | BUG_ON(ret); |
| 464 | } | 466 | } |
| 465 | free_extent_buffer(root->commit_root); | 467 | |
| 466 | root->commit_root = btrfs_root_node(root); | 468 | if (root != root->fs_info->extent_root) |
| 469 | switch_commit_root(root); | ||
| 470 | |||
| 467 | return 0; | 471 | return 0; |
| 468 | } | 472 | } |
| 469 | 473 | ||
| @@ -495,10 +499,12 @@ static noinline int commit_cowonly_roots(struct btrfs_trans_handle *trans, | |||
| 495 | root = list_entry(next, struct btrfs_root, dirty_list); | 499 | root = list_entry(next, struct btrfs_root, dirty_list); |
| 496 | 500 | ||
| 497 | update_cowonly_root(trans, root); | 501 | update_cowonly_root(trans, root); |
| 498 | |||
| 499 | ret = btrfs_run_delayed_refs(trans, root, (unsigned long)-1); | ||
| 500 | BUG_ON(ret); | ||
| 501 | } | 502 | } |
| 503 | |||
| 504 | down_write(&fs_info->extent_commit_sem); | ||
| 505 | switch_commit_root(fs_info->extent_root); | ||
| 506 | up_write(&fs_info->extent_commit_sem); | ||
| 507 | |||
| 502 | return 0; | 508 | return 0; |
| 503 | } | 509 | } |
| 504 | 510 | ||
| @@ -544,8 +550,7 @@ static noinline int commit_fs_roots(struct btrfs_trans_handle *trans, | |||
| 544 | btrfs_update_reloc_root(trans, root); | 550 | btrfs_update_reloc_root(trans, root); |
| 545 | 551 | ||
| 546 | if (root->commit_root != root->node) { | 552 | if (root->commit_root != root->node) { |
| 547 | free_extent_buffer(root->commit_root); | 553 | switch_commit_root(root); |
| 548 | root->commit_root = btrfs_root_node(root); | ||
| 549 | btrfs_set_root_node(&root->root_item, | 554 | btrfs_set_root_node(&root->root_item, |
| 550 | root->node); | 555 | root->node); |
| 551 | } | 556 | } |
| @@ -852,6 +857,16 @@ static void update_super_roots(struct btrfs_root *root) | |||
| 852 | super->root_level = root_item->level; | 857 | super->root_level = root_item->level; |
| 853 | } | 858 | } |
| 854 | 859 | ||
| 860 | int btrfs_transaction_in_commit(struct btrfs_fs_info *info) | ||
| 861 | { | ||
| 862 | int ret = 0; | ||
| 863 | spin_lock(&info->new_trans_lock); | ||
| 864 | if (info->running_transaction) | ||
| 865 | ret = info->running_transaction->in_commit; | ||
| 866 | spin_unlock(&info->new_trans_lock); | ||
| 867 | return ret; | ||
| 868 | } | ||
| 869 | |||
| 855 | int btrfs_commit_transaction(struct btrfs_trans_handle *trans, | 870 | int btrfs_commit_transaction(struct btrfs_trans_handle *trans, |
| 856 | struct btrfs_root *root) | 871 | struct btrfs_root *root) |
| 857 | { | 872 | { |
| @@ -943,9 +958,11 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans, | |||
| 943 | 958 | ||
| 944 | mutex_unlock(&root->fs_info->trans_mutex); | 959 | mutex_unlock(&root->fs_info->trans_mutex); |
| 945 | 960 | ||
| 946 | if (flush_on_commit || snap_pending) { | 961 | if (flush_on_commit) { |
| 947 | if (flush_on_commit) | 962 | btrfs_start_delalloc_inodes(root); |
| 948 | btrfs_start_delalloc_inodes(root); | 963 | ret = btrfs_wait_ordered_extents(root, 0); |
| 964 | BUG_ON(ret); | ||
| 965 | } else if (snap_pending) { | ||
| 949 | ret = btrfs_wait_ordered_extents(root, 1); | 966 | ret = btrfs_wait_ordered_extents(root, 1); |
| 950 | BUG_ON(ret); | 967 | BUG_ON(ret); |
| 951 | } | 968 | } |
| @@ -1009,15 +1026,11 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans, | |||
| 1009 | 1026 | ||
| 1010 | btrfs_set_root_node(&root->fs_info->tree_root->root_item, | 1027 | btrfs_set_root_node(&root->fs_info->tree_root->root_item, |
| 1011 | root->fs_info->tree_root->node); | 1028 | root->fs_info->tree_root->node); |
| 1012 | free_extent_buffer(root->fs_info->tree_root->commit_root); | 1029 | switch_commit_root(root->fs_info->tree_root); |
| 1013 | root->fs_info->tree_root->commit_root = | ||
| 1014 | btrfs_root_node(root->fs_info->tree_root); | ||
| 1015 | 1030 | ||
| 1016 | btrfs_set_root_node(&root->fs_info->chunk_root->root_item, | 1031 | btrfs_set_root_node(&root->fs_info->chunk_root->root_item, |
| 1017 | root->fs_info->chunk_root->node); | 1032 | root->fs_info->chunk_root->node); |
| 1018 | free_extent_buffer(root->fs_info->chunk_root->commit_root); | 1033 | switch_commit_root(root->fs_info->chunk_root); |
| 1019 | root->fs_info->chunk_root->commit_root = | ||
| 1020 | btrfs_root_node(root->fs_info->chunk_root); | ||
| 1021 | 1034 | ||
| 1022 | update_super_roots(root); | 1035 | update_super_roots(root); |
| 1023 | 1036 | ||
| @@ -1057,6 +1070,7 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans, | |||
| 1057 | cur_trans->commit_done = 1; | 1070 | cur_trans->commit_done = 1; |
| 1058 | 1071 | ||
| 1059 | root->fs_info->last_trans_committed = cur_trans->transid; | 1072 | root->fs_info->last_trans_committed = cur_trans->transid; |
| 1073 | |||
| 1060 | wake_up(&cur_trans->commit_wait); | 1074 | wake_up(&cur_trans->commit_wait); |
| 1061 | 1075 | ||
| 1062 | put_transaction(cur_trans); | 1076 | put_transaction(cur_trans); |
diff --git a/fs/btrfs/transaction.h b/fs/btrfs/transaction.h index 961c3ee5a2e1..663c67404918 100644 --- a/fs/btrfs/transaction.h +++ b/fs/btrfs/transaction.h | |||
| @@ -107,4 +107,5 @@ int btrfs_record_root_in_trans(struct btrfs_trans_handle *trans, | |||
| 107 | struct btrfs_root *root); | 107 | struct btrfs_root *root); |
| 108 | int btrfs_write_and_wait_marked_extents(struct btrfs_root *root, | 108 | int btrfs_write_and_wait_marked_extents(struct btrfs_root *root, |
| 109 | struct extent_io_tree *dirty_pages); | 109 | struct extent_io_tree *dirty_pages); |
| 110 | int btrfs_transaction_in_commit(struct btrfs_fs_info *info); | ||
| 110 | #endif | 111 | #endif |
diff --git a/fs/btrfs/tree-log.c b/fs/btrfs/tree-log.c index c13922206d1b..d91b0de7c502 100644 --- a/fs/btrfs/tree-log.c +++ b/fs/btrfs/tree-log.c | |||
| @@ -797,7 +797,7 @@ static noinline int add_inode_ref(struct btrfs_trans_handle *trans, | |||
| 797 | return -ENOENT; | 797 | return -ENOENT; |
| 798 | 798 | ||
| 799 | inode = read_one_inode(root, key->objectid); | 799 | inode = read_one_inode(root, key->objectid); |
| 800 | BUG_ON(!dir); | 800 | BUG_ON(!inode); |
| 801 | 801 | ||
| 802 | ref_ptr = btrfs_item_ptr_offset(eb, slot); | 802 | ref_ptr = btrfs_item_ptr_offset(eb, slot); |
| 803 | ref_end = ref_ptr + btrfs_item_size_nr(eb, slot); | 803 | ref_end = ref_ptr + btrfs_item_size_nr(eb, slot); |
diff --git a/fs/btrfs/volumes.c b/fs/btrfs/volumes.c index 3ab80e9cd767..5dbefd11b4af 100644 --- a/fs/btrfs/volumes.c +++ b/fs/btrfs/volumes.c | |||
| @@ -721,7 +721,8 @@ error: | |||
| 721 | */ | 721 | */ |
| 722 | static noinline int find_free_dev_extent(struct btrfs_trans_handle *trans, | 722 | static noinline int find_free_dev_extent(struct btrfs_trans_handle *trans, |
| 723 | struct btrfs_device *device, | 723 | struct btrfs_device *device, |
| 724 | u64 num_bytes, u64 *start) | 724 | u64 num_bytes, u64 *start, |
| 725 | u64 *max_avail) | ||
| 725 | { | 726 | { |
| 726 | struct btrfs_key key; | 727 | struct btrfs_key key; |
| 727 | struct btrfs_root *root = device->dev_root; | 728 | struct btrfs_root *root = device->dev_root; |
| @@ -758,9 +759,13 @@ static noinline int find_free_dev_extent(struct btrfs_trans_handle *trans, | |||
| 758 | ret = btrfs_search_slot(trans, root, &key, path, 0, 0); | 759 | ret = btrfs_search_slot(trans, root, &key, path, 0, 0); |
| 759 | if (ret < 0) | 760 | if (ret < 0) |
| 760 | goto error; | 761 | goto error; |
| 761 | ret = btrfs_previous_item(root, path, 0, key.type); | 762 | if (ret > 0) { |
| 762 | if (ret < 0) | 763 | ret = btrfs_previous_item(root, path, key.objectid, key.type); |
| 763 | goto error; | 764 | if (ret < 0) |
| 765 | goto error; | ||
| 766 | if (ret > 0) | ||
| 767 | start_found = 1; | ||
| 768 | } | ||
| 764 | l = path->nodes[0]; | 769 | l = path->nodes[0]; |
| 765 | btrfs_item_key_to_cpu(l, &key, path->slots[0]); | 770 | btrfs_item_key_to_cpu(l, &key, path->slots[0]); |
| 766 | while (1) { | 771 | while (1) { |
| @@ -803,6 +808,10 @@ no_more_items: | |||
| 803 | if (last_byte < search_start) | 808 | if (last_byte < search_start) |
| 804 | last_byte = search_start; | 809 | last_byte = search_start; |
| 805 | hole_size = key.offset - last_byte; | 810 | hole_size = key.offset - last_byte; |
| 811 | |||
| 812 | if (hole_size > *max_avail) | ||
| 813 | *max_avail = hole_size; | ||
| 814 | |||
| 806 | if (key.offset > last_byte && | 815 | if (key.offset > last_byte && |
| 807 | hole_size >= num_bytes) { | 816 | hole_size >= num_bytes) { |
| 808 | *start = last_byte; | 817 | *start = last_byte; |
| @@ -1621,6 +1630,7 @@ static int __btrfs_grow_device(struct btrfs_trans_handle *trans, | |||
| 1621 | device->fs_devices->total_rw_bytes += diff; | 1630 | device->fs_devices->total_rw_bytes += diff; |
| 1622 | 1631 | ||
| 1623 | device->total_bytes = new_size; | 1632 | device->total_bytes = new_size; |
| 1633 | device->disk_total_bytes = new_size; | ||
| 1624 | btrfs_clear_space_info_full(device->dev_root->fs_info); | 1634 | btrfs_clear_space_info_full(device->dev_root->fs_info); |
| 1625 | 1635 | ||
| 1626 | return btrfs_update_device(trans, device); | 1636 | return btrfs_update_device(trans, device); |
| @@ -2007,7 +2017,7 @@ int btrfs_shrink_device(struct btrfs_device *device, u64 new_size) | |||
| 2007 | goto done; | 2017 | goto done; |
| 2008 | if (ret) { | 2018 | if (ret) { |
| 2009 | ret = 0; | 2019 | ret = 0; |
| 2010 | goto done; | 2020 | break; |
| 2011 | } | 2021 | } |
| 2012 | 2022 | ||
| 2013 | l = path->nodes[0]; | 2023 | l = path->nodes[0]; |
| @@ -2015,7 +2025,7 @@ int btrfs_shrink_device(struct btrfs_device *device, u64 new_size) | |||
| 2015 | btrfs_item_key_to_cpu(l, &key, path->slots[0]); | 2025 | btrfs_item_key_to_cpu(l, &key, path->slots[0]); |
| 2016 | 2026 | ||
| 2017 | if (key.objectid != device->devid) | 2027 | if (key.objectid != device->devid) |
| 2018 | goto done; | 2028 | break; |
| 2019 | 2029 | ||
| 2020 | dev_extent = btrfs_item_ptr(l, slot, struct btrfs_dev_extent); | 2030 | dev_extent = btrfs_item_ptr(l, slot, struct btrfs_dev_extent); |
| 2021 | length = btrfs_dev_extent_length(l, dev_extent); | 2031 | length = btrfs_dev_extent_length(l, dev_extent); |
| @@ -2171,6 +2181,7 @@ static int __btrfs_alloc_chunk(struct btrfs_trans_handle *trans, | |||
| 2171 | max_chunk_size); | 2181 | max_chunk_size); |
| 2172 | 2182 | ||
| 2173 | again: | 2183 | again: |
| 2184 | max_avail = 0; | ||
| 2174 | if (!map || map->num_stripes != num_stripes) { | 2185 | if (!map || map->num_stripes != num_stripes) { |
| 2175 | kfree(map); | 2186 | kfree(map); |
| 2176 | map = kmalloc(map_lookup_size(num_stripes), GFP_NOFS); | 2187 | map = kmalloc(map_lookup_size(num_stripes), GFP_NOFS); |
| @@ -2219,7 +2230,8 @@ again: | |||
| 2219 | 2230 | ||
| 2220 | if (device->in_fs_metadata && avail >= min_free) { | 2231 | if (device->in_fs_metadata && avail >= min_free) { |
| 2221 | ret = find_free_dev_extent(trans, device, | 2232 | ret = find_free_dev_extent(trans, device, |
| 2222 | min_free, &dev_offset); | 2233 | min_free, &dev_offset, |
| 2234 | &max_avail); | ||
| 2223 | if (ret == 0) { | 2235 | if (ret == 0) { |
| 2224 | list_move_tail(&device->dev_alloc_list, | 2236 | list_move_tail(&device->dev_alloc_list, |
| 2225 | &private_devs); | 2237 | &private_devs); |
| @@ -2795,26 +2807,6 @@ int btrfs_rmap_block(struct btrfs_mapping_tree *map_tree, | |||
| 2795 | } | 2807 | } |
| 2796 | } | 2808 | } |
| 2797 | 2809 | ||
| 2798 | for (i = 0; i > nr; i++) { | ||
| 2799 | struct btrfs_multi_bio *multi; | ||
| 2800 | struct btrfs_bio_stripe *stripe; | ||
| 2801 | int ret; | ||
| 2802 | |||
| 2803 | length = 1; | ||
| 2804 | ret = btrfs_map_block(map_tree, WRITE, buf[i], | ||
| 2805 | &length, &multi, 0); | ||
| 2806 | BUG_ON(ret); | ||
| 2807 | |||
| 2808 | stripe = multi->stripes; | ||
| 2809 | for (j = 0; j < multi->num_stripes; j++) { | ||
| 2810 | if (stripe->physical >= physical && | ||
| 2811 | physical < stripe->physical + length) | ||
| 2812 | break; | ||
| 2813 | } | ||
| 2814 | BUG_ON(j >= multi->num_stripes); | ||
| 2815 | kfree(multi); | ||
| 2816 | } | ||
| 2817 | |||
| 2818 | *logical = buf; | 2810 | *logical = buf; |
| 2819 | *naddrs = nr; | 2811 | *naddrs = nr; |
| 2820 | *stripe_len = map->stripe_len; | 2812 | *stripe_len = map->stripe_len; |
diff --git a/fs/btrfs/zlib.c b/fs/btrfs/zlib.c index ecfbce836d32..3e2b90eaa239 100644 --- a/fs/btrfs/zlib.c +++ b/fs/btrfs/zlib.c | |||
| @@ -208,7 +208,7 @@ int btrfs_zlib_compress_pages(struct address_space *mapping, | |||
| 208 | *total_in = 0; | 208 | *total_in = 0; |
| 209 | 209 | ||
| 210 | workspace = find_zlib_workspace(); | 210 | workspace = find_zlib_workspace(); |
| 211 | if (!workspace) | 211 | if (IS_ERR(workspace)) |
| 212 | return -1; | 212 | return -1; |
| 213 | 213 | ||
| 214 | if (Z_OK != zlib_deflateInit(&workspace->def_strm, 3)) { | 214 | if (Z_OK != zlib_deflateInit(&workspace->def_strm, 3)) { |
| @@ -366,7 +366,7 @@ int btrfs_zlib_decompress_biovec(struct page **pages_in, | |||
| 366 | char *kaddr; | 366 | char *kaddr; |
| 367 | 367 | ||
| 368 | workspace = find_zlib_workspace(); | 368 | workspace = find_zlib_workspace(); |
| 369 | if (!workspace) | 369 | if (IS_ERR(workspace)) |
| 370 | return -ENOMEM; | 370 | return -ENOMEM; |
| 371 | 371 | ||
| 372 | data_in = kmap(pages_in[page_in_index]); | 372 | data_in = kmap(pages_in[page_in_index]); |
| @@ -547,7 +547,7 @@ int btrfs_zlib_decompress(unsigned char *data_in, | |||
| 547 | return -ENOMEM; | 547 | return -ENOMEM; |
| 548 | 548 | ||
| 549 | workspace = find_zlib_workspace(); | 549 | workspace = find_zlib_workspace(); |
| 550 | if (!workspace) | 550 | if (IS_ERR(workspace)) |
| 551 | return -ENOMEM; | 551 | return -ENOMEM; |
| 552 | 552 | ||
| 553 | workspace->inf_strm.next_in = data_in; | 553 | workspace->inf_strm.next_in = data_in; |
diff --git a/fs/buffer.c b/fs/buffer.c index a3ef091a45bd..28f320fac4d4 100644 --- a/fs/buffer.c +++ b/fs/buffer.c | |||
| @@ -1165,8 +1165,11 @@ void mark_buffer_dirty(struct buffer_head *bh) | |||
| 1165 | 1165 | ||
| 1166 | if (!test_set_buffer_dirty(bh)) { | 1166 | if (!test_set_buffer_dirty(bh)) { |
| 1167 | struct page *page = bh->b_page; | 1167 | struct page *page = bh->b_page; |
| 1168 | if (!TestSetPageDirty(page)) | 1168 | if (!TestSetPageDirty(page)) { |
| 1169 | __set_page_dirty(page, page_mapping(page), 0); | 1169 | struct address_space *mapping = page_mapping(page); |
| 1170 | if (mapping) | ||
| 1171 | __set_page_dirty(page, mapping, 0); | ||
| 1172 | } | ||
| 1170 | } | 1173 | } |
| 1171 | } | 1174 | } |
| 1172 | 1175 | ||
diff --git a/fs/cifs/CHANGES b/fs/cifs/CHANGES index 92888aa90749..e85b1e4389e0 100644 --- a/fs/cifs/CHANGES +++ b/fs/cifs/CHANGES | |||
| @@ -1,3 +1,10 @@ | |||
| 1 | Version 1.60 | ||
| 2 | ------------- | ||
| 3 | Fix memory leak in reconnect. Fix oops in DFS mount error path. | ||
| 4 | Set s_maxbytes to smaller (the max that vfs can handle) so that | ||
| 5 | sendfile will now work over cifs mounts again. Add noforcegid | ||
| 6 | and noforceuid mount parameters. | ||
| 7 | |||
| 1 | Version 1.59 | 8 | Version 1.59 |
| 2 | ------------ | 9 | ------------ |
| 3 | Client uses server inode numbers (which are persistent) rather than | 10 | Client uses server inode numbers (which are persistent) rather than |
diff --git a/fs/cifs/README b/fs/cifs/README index ad92921dbde4..79c1a93400be 100644 --- a/fs/cifs/README +++ b/fs/cifs/README | |||
| @@ -262,11 +262,11 @@ A partial list of the supported mount options follows: | |||
| 262 | mount. | 262 | mount. |
| 263 | domain Set the SMB/CIFS workgroup name prepended to the | 263 | domain Set the SMB/CIFS workgroup name prepended to the |
| 264 | username during CIFS session establishment | 264 | username during CIFS session establishment |
| 265 | forceuid Set the default uid for inodes based on the uid | 265 | forceuid Set the default uid for inodes to the uid |
| 266 | passed in. For mounts to servers | 266 | passed in on mount. For mounts to servers |
| 267 | which do support the CIFS Unix extensions, such as a | 267 | which do support the CIFS Unix extensions, such as a |
| 268 | properly configured Samba server, the server provides | 268 | properly configured Samba server, the server provides |
| 269 | the uid, gid and mode so this parameter should not be | 269 | the uid, gid and mode so this parameter should not be |
| 270 | specified unless the server and clients uid and gid | 270 | specified unless the server and clients uid and gid |
| 271 | numbering differ. If the server and client are in the | 271 | numbering differ. If the server and client are in the |
| 272 | same domain (e.g. running winbind or nss_ldap) and | 272 | same domain (e.g. running winbind or nss_ldap) and |
| @@ -278,11 +278,7 @@ A partial list of the supported mount options follows: | |||
| 278 | of existing files will be the uid (gid) of the person | 278 | of existing files will be the uid (gid) of the person |
| 279 | who executed the mount (root, except when mount.cifs | 279 | who executed the mount (root, except when mount.cifs |
| 280 | is configured setuid for user mounts) unless the "uid=" | 280 | is configured setuid for user mounts) unless the "uid=" |
| 281 | (gid) mount option is specified. For the uid (gid) of newly | 281 | (gid) mount option is specified. Also note that permission |
| 282 | created files and directories, ie files created since | ||
| 283 | the last mount of the server share, the expected uid | ||
| 284 | (gid) is cached as long as the inode remains in | ||
| 285 | memory on the client. Also note that permission | ||
| 286 | checks (authorization checks) on accesses to a file occur | 282 | checks (authorization checks) on accesses to a file occur |
| 287 | at the server, but there are cases in which an administrator | 283 | at the server, but there are cases in which an administrator |
| 288 | may want to restrict at the client as well. For those | 284 | may want to restrict at the client as well. For those |
| @@ -290,12 +286,15 @@ A partial list of the supported mount options follows: | |||
| 290 | (such as Windows), permissions can also be checked at the | 286 | (such as Windows), permissions can also be checked at the |
| 291 | client, and a crude form of client side permission checking | 287 | client, and a crude form of client side permission checking |
| 292 | can be enabled by specifying file_mode and dir_mode on | 288 | can be enabled by specifying file_mode and dir_mode on |
| 293 | the client. Note that the mount.cifs helper must be | 289 | the client. (default) |
| 294 | at version 1.10 or higher to support specifying the uid | 290 | forcegid (similar to above but for the groupid instead of uid) (default) |
| 295 | (or gid) in non-numeric form. | 291 | noforceuid Fill in file owner information (uid) by requesting it from |
| 296 | forcegid (similar to above but for the groupid instead of uid) | 292 | the server if possible. With this option, the value given in |
| 293 | the uid= option (on mount) will only be used if the server | ||
| 294 | can not support returning uids on inodes. | ||
| 295 | noforcegid (similar to above but for the group owner, gid, instead of uid) | ||
| 297 | uid Set the default uid for inodes, and indicate to the | 296 | uid Set the default uid for inodes, and indicate to the |
| 298 | cifs kernel driver which local user mounted . If the server | 297 | cifs kernel driver which local user mounted. If the server |
| 299 | supports the unix extensions the default uid is | 298 | supports the unix extensions the default uid is |
| 300 | not used to fill in the owner fields of inodes (files) | 299 | not used to fill in the owner fields of inodes (files) |
| 301 | unless the "forceuid" parameter is specified. | 300 | unless the "forceuid" parameter is specified. |
diff --git a/fs/cifs/cifs_dfs_ref.c b/fs/cifs/cifs_dfs_ref.c index 3bb11be8b6a8..606912d8f2a8 100644 --- a/fs/cifs/cifs_dfs_ref.c +++ b/fs/cifs/cifs_dfs_ref.c | |||
| @@ -55,7 +55,7 @@ void cifs_dfs_release_automount_timer(void) | |||
| 55 | * i.e. strips from UNC trailing path that is not part of share | 55 | * i.e. strips from UNC trailing path that is not part of share |
| 56 | * name and fixup missing '\' in the begining of DFS node refferal | 56 | * name and fixup missing '\' in the begining of DFS node refferal |
| 57 | * if neccessary. | 57 | * if neccessary. |
| 58 | * Returns pointer to share name on success or NULL on error. | 58 | * Returns pointer to share name on success or ERR_PTR on error. |
| 59 | * Caller is responsible for freeing returned string. | 59 | * Caller is responsible for freeing returned string. |
| 60 | */ | 60 | */ |
| 61 | static char *cifs_get_share_name(const char *node_name) | 61 | static char *cifs_get_share_name(const char *node_name) |
| @@ -68,7 +68,7 @@ static char *cifs_get_share_name(const char *node_name) | |||
| 68 | UNC = kmalloc(len+2 /*for term null and additional \ if it's missed */, | 68 | UNC = kmalloc(len+2 /*for term null and additional \ if it's missed */, |
| 69 | GFP_KERNEL); | 69 | GFP_KERNEL); |
| 70 | if (!UNC) | 70 | if (!UNC) |
| 71 | return NULL; | 71 | return ERR_PTR(-ENOMEM); |
| 72 | 72 | ||
| 73 | /* get share name and server name */ | 73 | /* get share name and server name */ |
| 74 | if (node_name[1] != '\\') { | 74 | if (node_name[1] != '\\') { |
| @@ -87,7 +87,7 @@ static char *cifs_get_share_name(const char *node_name) | |||
| 87 | cERROR(1, ("%s: no server name end in node name: %s", | 87 | cERROR(1, ("%s: no server name end in node name: %s", |
| 88 | __func__, node_name)); | 88 | __func__, node_name)); |
| 89 | kfree(UNC); | 89 | kfree(UNC); |
| 90 | return NULL; | 90 | return ERR_PTR(-EINVAL); |
| 91 | } | 91 | } |
| 92 | 92 | ||
| 93 | /* find sharename end */ | 93 | /* find sharename end */ |
| @@ -133,6 +133,12 @@ char *cifs_compose_mount_options(const char *sb_mountdata, | |||
| 133 | return ERR_PTR(-EINVAL); | 133 | return ERR_PTR(-EINVAL); |
| 134 | 134 | ||
| 135 | *devname = cifs_get_share_name(ref->node_name); | 135 | *devname = cifs_get_share_name(ref->node_name); |
| 136 | if (IS_ERR(*devname)) { | ||
| 137 | rc = PTR_ERR(*devname); | ||
| 138 | *devname = NULL; | ||
| 139 | goto compose_mount_options_err; | ||
| 140 | } | ||
| 141 | |||
| 136 | rc = dns_resolve_server_name_to_ip(*devname, &srvIP); | 142 | rc = dns_resolve_server_name_to_ip(*devname, &srvIP); |
| 137 | if (rc != 0) { | 143 | if (rc != 0) { |
| 138 | cERROR(1, ("%s: Failed to resolve server part of %s to IP: %d", | 144 | cERROR(1, ("%s: Failed to resolve server part of %s to IP: %d", |
diff --git a/fs/cifs/cifs_unicode.c b/fs/cifs/cifs_unicode.c index 60e3c4253de0..714a542cbafc 100644 --- a/fs/cifs/cifs_unicode.c +++ b/fs/cifs/cifs_unicode.c | |||
| @@ -44,7 +44,7 @@ cifs_ucs2_bytes(const __le16 *from, int maxbytes, | |||
| 44 | int maxwords = maxbytes / 2; | 44 | int maxwords = maxbytes / 2; |
| 45 | char tmp[NLS_MAX_CHARSET_SIZE]; | 45 | char tmp[NLS_MAX_CHARSET_SIZE]; |
| 46 | 46 | ||
| 47 | for (i = 0; from[i] && i < maxwords; i++) { | 47 | for (i = 0; i < maxwords && from[i]; i++) { |
| 48 | charlen = codepage->uni2char(le16_to_cpu(from[i]), tmp, | 48 | charlen = codepage->uni2char(le16_to_cpu(from[i]), tmp, |
| 49 | NLS_MAX_CHARSET_SIZE); | 49 | NLS_MAX_CHARSET_SIZE); |
| 50 | if (charlen > 0) | 50 | if (charlen > 0) |
diff --git a/fs/cifs/cifsfs.c b/fs/cifs/cifsfs.c index 44f30504b82d..84b75253b05a 100644 --- a/fs/cifs/cifsfs.c +++ b/fs/cifs/cifsfs.c | |||
| @@ -376,10 +376,14 @@ cifs_show_options(struct seq_file *s, struct vfsmount *m) | |||
| 376 | seq_printf(s, ",uid=%d", cifs_sb->mnt_uid); | 376 | seq_printf(s, ",uid=%d", cifs_sb->mnt_uid); |
| 377 | if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_OVERR_UID) | 377 | if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_OVERR_UID) |
| 378 | seq_printf(s, ",forceuid"); | 378 | seq_printf(s, ",forceuid"); |
| 379 | else | ||
| 380 | seq_printf(s, ",noforceuid"); | ||
| 379 | 381 | ||
| 380 | seq_printf(s, ",gid=%d", cifs_sb->mnt_gid); | 382 | seq_printf(s, ",gid=%d", cifs_sb->mnt_gid); |
| 381 | if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_OVERR_GID) | 383 | if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_OVERR_GID) |
| 382 | seq_printf(s, ",forcegid"); | 384 | seq_printf(s, ",forcegid"); |
| 385 | else | ||
| 386 | seq_printf(s, ",noforcegid"); | ||
| 383 | 387 | ||
| 384 | cifs_show_address(s, tcon->ses->server); | 388 | cifs_show_address(s, tcon->ses->server); |
| 385 | 389 | ||
diff --git a/fs/cifs/connect.c b/fs/cifs/connect.c index 9bb5c8750736..1f3345d7fa79 100644 --- a/fs/cifs/connect.c +++ b/fs/cifs/connect.c | |||
| @@ -803,6 +803,10 @@ cifs_parse_mount_options(char *options, const char *devname, | |||
| 803 | char *data; | 803 | char *data; |
| 804 | unsigned int temp_len, i, j; | 804 | unsigned int temp_len, i, j; |
| 805 | char separator[2]; | 805 | char separator[2]; |
| 806 | short int override_uid = -1; | ||
| 807 | short int override_gid = -1; | ||
| 808 | bool uid_specified = false; | ||
| 809 | bool gid_specified = false; | ||
| 806 | 810 | ||
| 807 | separator[0] = ','; | 811 | separator[0] = ','; |
| 808 | separator[1] = 0; | 812 | separator[1] = 0; |
| @@ -1093,18 +1097,20 @@ cifs_parse_mount_options(char *options, const char *devname, | |||
| 1093 | "too long.\n"); | 1097 | "too long.\n"); |
| 1094 | return 1; | 1098 | return 1; |
| 1095 | } | 1099 | } |
| 1096 | } else if (strnicmp(data, "uid", 3) == 0) { | 1100 | } else if (!strnicmp(data, "uid", 3) && value && *value) { |
| 1097 | if (value && *value) | 1101 | vol->linux_uid = simple_strtoul(value, &value, 0); |
| 1098 | vol->linux_uid = | 1102 | uid_specified = true; |
| 1099 | simple_strtoul(value, &value, 0); | 1103 | } else if (!strnicmp(data, "forceuid", 8)) { |
| 1100 | } else if (strnicmp(data, "forceuid", 8) == 0) { | 1104 | override_uid = 1; |
| 1101 | vol->override_uid = 1; | 1105 | } else if (!strnicmp(data, "noforceuid", 10)) { |
| 1102 | } else if (strnicmp(data, "gid", 3) == 0) { | 1106 | override_uid = 0; |
| 1103 | if (value && *value) | 1107 | } else if (!strnicmp(data, "gid", 3) && value && *value) { |
| 1104 | vol->linux_gid = | 1108 | vol->linux_gid = simple_strtoul(value, &value, 0); |
| 1105 | simple_strtoul(value, &value, 0); | 1109 | gid_specified = true; |
| 1106 | } else if (strnicmp(data, "forcegid", 8) == 0) { | 1110 | } else if (!strnicmp(data, "forcegid", 8)) { |
| 1107 | vol->override_gid = 1; | 1111 | override_gid = 1; |
| 1112 | } else if (!strnicmp(data, "noforcegid", 10)) { | ||
| 1113 | override_gid = 0; | ||
| 1108 | } else if (strnicmp(data, "file_mode", 4) == 0) { | 1114 | } else if (strnicmp(data, "file_mode", 4) == 0) { |
| 1109 | if (value && *value) { | 1115 | if (value && *value) { |
| 1110 | vol->file_mode = | 1116 | vol->file_mode = |
| @@ -1355,6 +1361,18 @@ cifs_parse_mount_options(char *options, const char *devname, | |||
| 1355 | if (vol->UNCip == NULL) | 1361 | if (vol->UNCip == NULL) |
| 1356 | vol->UNCip = &vol->UNC[2]; | 1362 | vol->UNCip = &vol->UNC[2]; |
| 1357 | 1363 | ||
| 1364 | if (uid_specified) | ||
| 1365 | vol->override_uid = override_uid; | ||
| 1366 | else if (override_uid == 1) | ||
| 1367 | printk(KERN_NOTICE "CIFS: ignoring forceuid mount option " | ||
| 1368 | "specified with no uid= option.\n"); | ||
| 1369 | |||
| 1370 | if (gid_specified) | ||
| 1371 | vol->override_gid = override_gid; | ||
| 1372 | else if (override_gid == 1) | ||
| 1373 | printk(KERN_NOTICE "CIFS: ignoring forcegid mount option " | ||
| 1374 | "specified with no gid= option.\n"); | ||
| 1375 | |||
| 1358 | return 0; | 1376 | return 0; |
| 1359 | } | 1377 | } |
| 1360 | 1378 | ||
| @@ -2452,10 +2470,10 @@ try_mount_again: | |||
| 2452 | tcon->local_lease = volume_info->local_lease; | 2470 | tcon->local_lease = volume_info->local_lease; |
| 2453 | } | 2471 | } |
| 2454 | if (pSesInfo) { | 2472 | if (pSesInfo) { |
| 2455 | if (pSesInfo->capabilities & CAP_LARGE_FILES) { | 2473 | if (pSesInfo->capabilities & CAP_LARGE_FILES) |
| 2456 | sb->s_maxbytes = (u64) 1 << 63; | 2474 | sb->s_maxbytes = MAX_LFS_FILESIZE; |
| 2457 | } else | 2475 | else |
| 2458 | sb->s_maxbytes = (u64) 1 << 31; /* 2 GB */ | 2476 | sb->s_maxbytes = MAX_NON_LFS; |
| 2459 | } | 2477 | } |
| 2460 | 2478 | ||
| 2461 | /* BB FIXME fix time_gran to be larger for LANMAN sessions */ | 2479 | /* BB FIXME fix time_gran to be larger for LANMAN sessions */ |
| @@ -2544,11 +2562,20 @@ remote_path_check: | |||
| 2544 | 2562 | ||
| 2545 | if (mount_data != mount_data_global) | 2563 | if (mount_data != mount_data_global) |
| 2546 | kfree(mount_data); | 2564 | kfree(mount_data); |
| 2565 | |||
| 2547 | mount_data = cifs_compose_mount_options( | 2566 | mount_data = cifs_compose_mount_options( |
| 2548 | cifs_sb->mountdata, full_path + 1, | 2567 | cifs_sb->mountdata, full_path + 1, |
| 2549 | referrals, &fake_devname); | 2568 | referrals, &fake_devname); |
| 2550 | kfree(fake_devname); | 2569 | |
| 2551 | free_dfs_info_array(referrals, num_referrals); | 2570 | free_dfs_info_array(referrals, num_referrals); |
| 2571 | kfree(fake_devname); | ||
| 2572 | kfree(full_path); | ||
| 2573 | |||
| 2574 | if (IS_ERR(mount_data)) { | ||
| 2575 | rc = PTR_ERR(mount_data); | ||
| 2576 | mount_data = NULL; | ||
| 2577 | goto mount_fail_check; | ||
| 2578 | } | ||
| 2552 | 2579 | ||
| 2553 | if (tcon) | 2580 | if (tcon) |
| 2554 | cifs_put_tcon(tcon); | 2581 | cifs_put_tcon(tcon); |
| @@ -2556,8 +2583,6 @@ remote_path_check: | |||
| 2556 | cifs_put_smb_ses(pSesInfo); | 2583 | cifs_put_smb_ses(pSesInfo); |
| 2557 | 2584 | ||
| 2558 | cleanup_volume_info(&volume_info); | 2585 | cleanup_volume_info(&volume_info); |
| 2559 | FreeXid(xid); | ||
| 2560 | kfree(full_path); | ||
| 2561 | referral_walks_count++; | 2586 | referral_walks_count++; |
| 2562 | goto try_mount_again; | 2587 | goto try_mount_again; |
| 2563 | } | 2588 | } |
diff --git a/fs/cifs/inode.c b/fs/cifs/inode.c index 18afe57b2461..82d83839655e 100644 --- a/fs/cifs/inode.c +++ b/fs/cifs/inode.c | |||
| @@ -212,7 +212,7 @@ cifs_unix_basic_to_fattr(struct cifs_fattr *fattr, FILE_UNIX_BASIC_INFO *info, | |||
| 212 | * junction to the new submount (ie to setup the fake directory | 212 | * junction to the new submount (ie to setup the fake directory |
| 213 | * which represents a DFS referral). | 213 | * which represents a DFS referral). |
| 214 | */ | 214 | */ |
| 215 | void | 215 | static void |
| 216 | cifs_create_dfs_fattr(struct cifs_fattr *fattr, struct super_block *sb) | 216 | cifs_create_dfs_fattr(struct cifs_fattr *fattr, struct super_block *sb) |
| 217 | { | 217 | { |
| 218 | struct cifs_sb_info *cifs_sb = CIFS_SB(sb); | 218 | struct cifs_sb_info *cifs_sb = CIFS_SB(sb); |
| @@ -388,7 +388,7 @@ static int cifs_sfu_mode(struct cifs_fattr *fattr, const unsigned char *path, | |||
| 388 | } | 388 | } |
| 389 | 389 | ||
| 390 | /* Fill a cifs_fattr struct with info from FILE_ALL_INFO */ | 390 | /* Fill a cifs_fattr struct with info from FILE_ALL_INFO */ |
| 391 | void | 391 | static void |
| 392 | cifs_all_info_to_fattr(struct cifs_fattr *fattr, FILE_ALL_INFO *info, | 392 | cifs_all_info_to_fattr(struct cifs_fattr *fattr, FILE_ALL_INFO *info, |
| 393 | struct cifs_sb_info *cifs_sb, bool adjust_tz) | 393 | struct cifs_sb_info *cifs_sb, bool adjust_tz) |
| 394 | { | 394 | { |
| @@ -513,9 +513,12 @@ int cifs_get_inode_info(struct inode **pinode, | |||
| 513 | cifs_sb->mnt_cifs_flags & | 513 | cifs_sb->mnt_cifs_flags & |
| 514 | CIFS_MOUNT_MAP_SPECIAL_CHR); | 514 | CIFS_MOUNT_MAP_SPECIAL_CHR); |
| 515 | if (rc1) { | 515 | if (rc1) { |
| 516 | /* BB EOPNOSUPP disable SERVER_INUM? */ | ||
| 517 | cFYI(1, ("GetSrvInodeNum rc %d", rc1)); | 516 | cFYI(1, ("GetSrvInodeNum rc %d", rc1)); |
| 518 | fattr.cf_uniqueid = iunique(sb, ROOT_I); | 517 | fattr.cf_uniqueid = iunique(sb, ROOT_I); |
| 518 | /* disable serverino if call not supported */ | ||
| 519 | if (rc1 == -EINVAL) | ||
| 520 | cifs_sb->mnt_cifs_flags &= | ||
| 521 | ~CIFS_MOUNT_SERVER_INUM; | ||
| 519 | } | 522 | } |
| 520 | } else { | 523 | } else { |
| 521 | fattr.cf_uniqueid = iunique(sb, ROOT_I); | 524 | fattr.cf_uniqueid = iunique(sb, ROOT_I); |
diff --git a/fs/compat_ioctl.c b/fs/compat_ioctl.c index f28f070a60fc..f91fd51b32e3 100644 --- a/fs/compat_ioctl.c +++ b/fs/compat_ioctl.c | |||
| @@ -1905,6 +1905,7 @@ COMPATIBLE_IOCTL(FIONCLEX) | |||
| 1905 | COMPATIBLE_IOCTL(FIOASYNC) | 1905 | COMPATIBLE_IOCTL(FIOASYNC) |
| 1906 | COMPATIBLE_IOCTL(FIONBIO) | 1906 | COMPATIBLE_IOCTL(FIONBIO) |
| 1907 | COMPATIBLE_IOCTL(FIONREAD) /* This is also TIOCINQ */ | 1907 | COMPATIBLE_IOCTL(FIONREAD) /* This is also TIOCINQ */ |
| 1908 | COMPATIBLE_IOCTL(FS_IOC_FIEMAP) | ||
| 1908 | /* 0x00 */ | 1909 | /* 0x00 */ |
| 1909 | COMPATIBLE_IOCTL(FIBMAP) | 1910 | COMPATIBLE_IOCTL(FIBMAP) |
| 1910 | COMPATIBLE_IOCTL(FIGETBSZ) | 1911 | COMPATIBLE_IOCTL(FIGETBSZ) |
diff --git a/fs/ecryptfs/keystore.c b/fs/ecryptfs/keystore.c index af737bb56cb7..259525c9abb8 100644 --- a/fs/ecryptfs/keystore.c +++ b/fs/ecryptfs/keystore.c | |||
| @@ -1303,6 +1303,13 @@ parse_tag_3_packet(struct ecryptfs_crypt_stat *crypt_stat, | |||
| 1303 | } | 1303 | } |
| 1304 | (*new_auth_tok)->session_key.encrypted_key_size = | 1304 | (*new_auth_tok)->session_key.encrypted_key_size = |
| 1305 | (body_size - (ECRYPTFS_SALT_SIZE + 5)); | 1305 | (body_size - (ECRYPTFS_SALT_SIZE + 5)); |
| 1306 | if ((*new_auth_tok)->session_key.encrypted_key_size | ||
| 1307 | > ECRYPTFS_MAX_ENCRYPTED_KEY_BYTES) { | ||
| 1308 | printk(KERN_WARNING "Tag 3 packet contains key larger " | ||
| 1309 | "than ECRYPTFS_MAX_ENCRYPTED_KEY_BYTES\n"); | ||
| 1310 | rc = -EINVAL; | ||
| 1311 | goto out_free; | ||
| 1312 | } | ||
| 1306 | if (unlikely(data[(*packet_size)++] != 0x04)) { | 1313 | if (unlikely(data[(*packet_size)++] != 0x04)) { |
| 1307 | printk(KERN_WARNING "Unknown version number [%d]\n", | 1314 | printk(KERN_WARNING "Unknown version number [%d]\n", |
| 1308 | data[(*packet_size) - 1]); | 1315 | data[(*packet_size) - 1]); |
| @@ -1449,6 +1456,12 @@ parse_tag_11_packet(unsigned char *data, unsigned char *contents, | |||
| 1449 | rc = -EINVAL; | 1456 | rc = -EINVAL; |
| 1450 | goto out; | 1457 | goto out; |
| 1451 | } | 1458 | } |
| 1459 | if (unlikely((*tag_11_contents_size) > max_contents_bytes)) { | ||
| 1460 | printk(KERN_ERR "Literal data section in tag 11 packet exceeds " | ||
| 1461 | "expected size\n"); | ||
| 1462 | rc = -EINVAL; | ||
| 1463 | goto out; | ||
| 1464 | } | ||
| 1452 | if (data[(*packet_size)++] != 0x62) { | 1465 | if (data[(*packet_size)++] != 0x62) { |
| 1453 | printk(KERN_WARNING "Unrecognizable packet\n"); | 1466 | printk(KERN_WARNING "Unrecognizable packet\n"); |
| 1454 | rc = -EINVAL; | 1467 | rc = -EINVAL; |
| @@ -678,8 +678,8 @@ exit: | |||
| 678 | } | 678 | } |
| 679 | EXPORT_SYMBOL(open_exec); | 679 | EXPORT_SYMBOL(open_exec); |
| 680 | 680 | ||
| 681 | int kernel_read(struct file *file, unsigned long offset, | 681 | int kernel_read(struct file *file, loff_t offset, |
| 682 | char *addr, unsigned long count) | 682 | char *addr, unsigned long count) |
| 683 | { | 683 | { |
| 684 | mm_segment_t old_fs; | 684 | mm_segment_t old_fs; |
| 685 | loff_t pos = offset; | 685 | loff_t pos = offset; |
diff --git a/fs/ext3/Kconfig b/fs/ext3/Kconfig index fb3c1a21b135..522b15498f45 100644 --- a/fs/ext3/Kconfig +++ b/fs/ext3/Kconfig | |||
| @@ -29,23 +29,25 @@ config EXT3_FS | |||
| 29 | module will be called ext3. | 29 | module will be called ext3. |
| 30 | 30 | ||
| 31 | config EXT3_DEFAULTS_TO_ORDERED | 31 | config EXT3_DEFAULTS_TO_ORDERED |
| 32 | bool "Default to 'data=ordered' in ext3 (legacy option)" | 32 | bool "Default to 'data=ordered' in ext3" |
| 33 | depends on EXT3_FS | 33 | depends on EXT3_FS |
| 34 | help | 34 | help |
| 35 | If a filesystem does not explicitly specify a data ordering | 35 | The journal mode options for ext3 have different tradeoffs |
| 36 | mode, and the journal capability allowed it, ext3 used to | 36 | between when data is guaranteed to be on disk and |
| 37 | historically default to 'data=ordered'. | 37 | performance. The use of "data=writeback" can cause |
| 38 | 38 | unwritten data to appear in files after an system crash or | |
| 39 | That was a rather unfortunate choice, because it leads to all | 39 | power failure, which can be a security issue. However, |
| 40 | kinds of latency problems, and the 'data=writeback' mode is more | 40 | "data=ordered" mode can also result in major performance |
| 41 | appropriate these days. | 41 | problems, including seconds-long delays before an fsync() |
| 42 | 42 | call returns. For details, see: | |
| 43 | You should probably always answer 'n' here, and if you really | 43 | |
| 44 | want to use 'data=ordered' mode, set it in the filesystem itself | 44 | http://ext4.wiki.kernel.org/index.php/Ext3_data_mode_tradeoffs |
| 45 | with 'tune2fs -o journal_data_ordered'. | 45 | |
| 46 | 46 | If you have been historically happy with ext3's performance, | |
| 47 | But if you really want to enable the legacy default, you can do | 47 | data=ordered mode will be a safe choice and you should |
| 48 | so by answering 'y' to this question. | 48 | answer 'y' here. If you understand the reliability and data |
| 49 | privacy issues of data=writeback and are willing to make | ||
| 50 | that trade off, answer 'n'. | ||
| 49 | 51 | ||
| 50 | config EXT3_FS_XATTR | 52 | config EXT3_FS_XATTR |
| 51 | bool "Ext3 extended attributes" | 53 | bool "Ext3 extended attributes" |
diff --git a/fs/ext3/dir.c b/fs/ext3/dir.c index 3d724a95882f..373fa90c796a 100644 --- a/fs/ext3/dir.c +++ b/fs/ext3/dir.c | |||
| @@ -130,8 +130,7 @@ static int ext3_readdir(struct file * filp, | |||
| 130 | struct buffer_head *bh = NULL; | 130 | struct buffer_head *bh = NULL; |
| 131 | 131 | ||
| 132 | map_bh.b_state = 0; | 132 | map_bh.b_state = 0; |
| 133 | err = ext3_get_blocks_handle(NULL, inode, blk, 1, | 133 | err = ext3_get_blocks_handle(NULL, inode, blk, 1, &map_bh, 0); |
| 134 | &map_bh, 0, 0); | ||
| 135 | if (err > 0) { | 134 | if (err > 0) { |
| 136 | pgoff_t index = map_bh.b_blocknr >> | 135 | pgoff_t index = map_bh.b_blocknr >> |
| 137 | (PAGE_CACHE_SHIFT - inode->i_blkbits); | 136 | (PAGE_CACHE_SHIFT - inode->i_blkbits); |
diff --git a/fs/ext3/inode.c b/fs/ext3/inode.c index 5f51fed5c750..b49908a167ae 100644 --- a/fs/ext3/inode.c +++ b/fs/ext3/inode.c | |||
| @@ -788,7 +788,7 @@ err_out: | |||
| 788 | int ext3_get_blocks_handle(handle_t *handle, struct inode *inode, | 788 | int ext3_get_blocks_handle(handle_t *handle, struct inode *inode, |
| 789 | sector_t iblock, unsigned long maxblocks, | 789 | sector_t iblock, unsigned long maxblocks, |
| 790 | struct buffer_head *bh_result, | 790 | struct buffer_head *bh_result, |
| 791 | int create, int extend_disksize) | 791 | int create) |
| 792 | { | 792 | { |
| 793 | int err = -EIO; | 793 | int err = -EIO; |
| 794 | int offsets[4]; | 794 | int offsets[4]; |
| @@ -911,13 +911,6 @@ int ext3_get_blocks_handle(handle_t *handle, struct inode *inode, | |||
| 911 | if (!err) | 911 | if (!err) |
| 912 | err = ext3_splice_branch(handle, inode, iblock, | 912 | err = ext3_splice_branch(handle, inode, iblock, |
| 913 | partial, indirect_blks, count); | 913 | partial, indirect_blks, count); |
| 914 | /* | ||
| 915 | * i_disksize growing is protected by truncate_mutex. Don't forget to | ||
| 916 | * protect it if you're about to implement concurrent | ||
| 917 | * ext3_get_block() -bzzz | ||
| 918 | */ | ||
| 919 | if (!err && extend_disksize && inode->i_size > ei->i_disksize) | ||
| 920 | ei->i_disksize = inode->i_size; | ||
| 921 | mutex_unlock(&ei->truncate_mutex); | 914 | mutex_unlock(&ei->truncate_mutex); |
| 922 | if (err) | 915 | if (err) |
| 923 | goto cleanup; | 916 | goto cleanup; |
| @@ -972,7 +965,7 @@ static int ext3_get_block(struct inode *inode, sector_t iblock, | |||
| 972 | } | 965 | } |
| 973 | 966 | ||
| 974 | ret = ext3_get_blocks_handle(handle, inode, iblock, | 967 | ret = ext3_get_blocks_handle(handle, inode, iblock, |
| 975 | max_blocks, bh_result, create, 0); | 968 | max_blocks, bh_result, create); |
| 976 | if (ret > 0) { | 969 | if (ret > 0) { |
| 977 | bh_result->b_size = (ret << inode->i_blkbits); | 970 | bh_result->b_size = (ret << inode->i_blkbits); |
| 978 | ret = 0; | 971 | ret = 0; |
| @@ -1005,7 +998,7 @@ struct buffer_head *ext3_getblk(handle_t *handle, struct inode *inode, | |||
| 1005 | dummy.b_blocknr = -1000; | 998 | dummy.b_blocknr = -1000; |
| 1006 | buffer_trace_init(&dummy.b_history); | 999 | buffer_trace_init(&dummy.b_history); |
| 1007 | err = ext3_get_blocks_handle(handle, inode, block, 1, | 1000 | err = ext3_get_blocks_handle(handle, inode, block, 1, |
| 1008 | &dummy, create, 1); | 1001 | &dummy, create); |
| 1009 | /* | 1002 | /* |
| 1010 | * ext3_get_blocks_handle() returns number of blocks | 1003 | * ext3_get_blocks_handle() returns number of blocks |
| 1011 | * mapped. 0 in case of a HOLE. | 1004 | * mapped. 0 in case of a HOLE. |
| @@ -1193,15 +1186,16 @@ write_begin_failed: | |||
| 1193 | * i_size_read because we hold i_mutex. | 1186 | * i_size_read because we hold i_mutex. |
| 1194 | * | 1187 | * |
| 1195 | * Add inode to orphan list in case we crash before truncate | 1188 | * Add inode to orphan list in case we crash before truncate |
| 1196 | * finishes. | 1189 | * finishes. Do this only if ext3_can_truncate() agrees so |
| 1190 | * that orphan processing code is happy. | ||
| 1197 | */ | 1191 | */ |
| 1198 | if (pos + len > inode->i_size) | 1192 | if (pos + len > inode->i_size && ext3_can_truncate(inode)) |
| 1199 | ext3_orphan_add(handle, inode); | 1193 | ext3_orphan_add(handle, inode); |
| 1200 | ext3_journal_stop(handle); | 1194 | ext3_journal_stop(handle); |
| 1201 | unlock_page(page); | 1195 | unlock_page(page); |
| 1202 | page_cache_release(page); | 1196 | page_cache_release(page); |
| 1203 | if (pos + len > inode->i_size) | 1197 | if (pos + len > inode->i_size) |
| 1204 | vmtruncate(inode, inode->i_size); | 1198 | ext3_truncate(inode); |
| 1205 | } | 1199 | } |
| 1206 | if (ret == -ENOSPC && ext3_should_retry_alloc(inode->i_sb, &retries)) | 1200 | if (ret == -ENOSPC && ext3_should_retry_alloc(inode->i_sb, &retries)) |
| 1207 | goto retry; | 1201 | goto retry; |
| @@ -1287,7 +1281,7 @@ static int ext3_ordered_write_end(struct file *file, | |||
| 1287 | * There may be allocated blocks outside of i_size because | 1281 | * There may be allocated blocks outside of i_size because |
| 1288 | * we failed to copy some data. Prepare for truncate. | 1282 | * we failed to copy some data. Prepare for truncate. |
| 1289 | */ | 1283 | */ |
| 1290 | if (pos + len > inode->i_size) | 1284 | if (pos + len > inode->i_size && ext3_can_truncate(inode)) |
| 1291 | ext3_orphan_add(handle, inode); | 1285 | ext3_orphan_add(handle, inode); |
| 1292 | ret2 = ext3_journal_stop(handle); | 1286 | ret2 = ext3_journal_stop(handle); |
| 1293 | if (!ret) | 1287 | if (!ret) |
| @@ -1296,7 +1290,7 @@ static int ext3_ordered_write_end(struct file *file, | |||
| 1296 | page_cache_release(page); | 1290 | page_cache_release(page); |
| 1297 | 1291 | ||
| 1298 | if (pos + len > inode->i_size) | 1292 | if (pos + len > inode->i_size) |
| 1299 | vmtruncate(inode, inode->i_size); | 1293 | ext3_truncate(inode); |
| 1300 | return ret ? ret : copied; | 1294 | return ret ? ret : copied; |
| 1301 | } | 1295 | } |
| 1302 | 1296 | ||
| @@ -1315,14 +1309,14 @@ static int ext3_writeback_write_end(struct file *file, | |||
| 1315 | * There may be allocated blocks outside of i_size because | 1309 | * There may be allocated blocks outside of i_size because |
| 1316 | * we failed to copy some data. Prepare for truncate. | 1310 | * we failed to copy some data. Prepare for truncate. |
| 1317 | */ | 1311 | */ |
| 1318 | if (pos + len > inode->i_size) | 1312 | if (pos + len > inode->i_size && ext3_can_truncate(inode)) |
| 1319 | ext3_orphan_add(handle, inode); | 1313 | ext3_orphan_add(handle, inode); |
| 1320 | ret = ext3_journal_stop(handle); | 1314 | ret = ext3_journal_stop(handle); |
| 1321 | unlock_page(page); | 1315 | unlock_page(page); |
| 1322 | page_cache_release(page); | 1316 | page_cache_release(page); |
| 1323 | 1317 | ||
| 1324 | if (pos + len > inode->i_size) | 1318 | if (pos + len > inode->i_size) |
| 1325 | vmtruncate(inode, inode->i_size); | 1319 | ext3_truncate(inode); |
| 1326 | return ret ? ret : copied; | 1320 | return ret ? ret : copied; |
| 1327 | } | 1321 | } |
| 1328 | 1322 | ||
| @@ -1358,7 +1352,7 @@ static int ext3_journalled_write_end(struct file *file, | |||
| 1358 | * There may be allocated blocks outside of i_size because | 1352 | * There may be allocated blocks outside of i_size because |
| 1359 | * we failed to copy some data. Prepare for truncate. | 1353 | * we failed to copy some data. Prepare for truncate. |
| 1360 | */ | 1354 | */ |
| 1361 | if (pos + len > inode->i_size) | 1355 | if (pos + len > inode->i_size && ext3_can_truncate(inode)) |
| 1362 | ext3_orphan_add(handle, inode); | 1356 | ext3_orphan_add(handle, inode); |
| 1363 | EXT3_I(inode)->i_state |= EXT3_STATE_JDATA; | 1357 | EXT3_I(inode)->i_state |= EXT3_STATE_JDATA; |
| 1364 | if (inode->i_size > EXT3_I(inode)->i_disksize) { | 1358 | if (inode->i_size > EXT3_I(inode)->i_disksize) { |
| @@ -1375,7 +1369,7 @@ static int ext3_journalled_write_end(struct file *file, | |||
| 1375 | page_cache_release(page); | 1369 | page_cache_release(page); |
| 1376 | 1370 | ||
| 1377 | if (pos + len > inode->i_size) | 1371 | if (pos + len > inode->i_size) |
| 1378 | vmtruncate(inode, inode->i_size); | 1372 | ext3_truncate(inode); |
| 1379 | return ret ? ret : copied; | 1373 | return ret ? ret : copied; |
| 1380 | } | 1374 | } |
| 1381 | 1375 | ||
diff --git a/fs/ext3/super.c b/fs/ext3/super.c index 524b349c6299..a8d80a7f1105 100644 --- a/fs/ext3/super.c +++ b/fs/ext3/super.c | |||
| @@ -543,6 +543,19 @@ static inline void ext3_show_quota_options(struct seq_file *seq, struct super_bl | |||
| 543 | #endif | 543 | #endif |
| 544 | } | 544 | } |
| 545 | 545 | ||
| 546 | static char *data_mode_string(unsigned long mode) | ||
| 547 | { | ||
| 548 | switch (mode) { | ||
| 549 | case EXT3_MOUNT_JOURNAL_DATA: | ||
| 550 | return "journal"; | ||
| 551 | case EXT3_MOUNT_ORDERED_DATA: | ||
| 552 | return "ordered"; | ||
| 553 | case EXT3_MOUNT_WRITEBACK_DATA: | ||
| 554 | return "writeback"; | ||
| 555 | } | ||
| 556 | return "unknown"; | ||
| 557 | } | ||
| 558 | |||
| 546 | /* | 559 | /* |
| 547 | * Show an option if | 560 | * Show an option if |
| 548 | * - it's set to a non-default value OR | 561 | * - it's set to a non-default value OR |
| @@ -616,13 +629,8 @@ static int ext3_show_options(struct seq_file *seq, struct vfsmount *vfs) | |||
| 616 | if (test_opt(sb, NOBH)) | 629 | if (test_opt(sb, NOBH)) |
| 617 | seq_puts(seq, ",nobh"); | 630 | seq_puts(seq, ",nobh"); |
| 618 | 631 | ||
| 619 | if (test_opt(sb, DATA_FLAGS) == EXT3_MOUNT_JOURNAL_DATA) | 632 | seq_printf(seq, ",data=%s", data_mode_string(sbi->s_mount_opt & |
| 620 | seq_puts(seq, ",data=journal"); | 633 | EXT3_MOUNT_DATA_FLAGS)); |
| 621 | else if (test_opt(sb, DATA_FLAGS) == EXT3_MOUNT_ORDERED_DATA) | ||
| 622 | seq_puts(seq, ",data=ordered"); | ||
| 623 | else if (test_opt(sb, DATA_FLAGS) == EXT3_MOUNT_WRITEBACK_DATA) | ||
| 624 | seq_puts(seq, ",data=writeback"); | ||
| 625 | |||
| 626 | if (test_opt(sb, DATA_ERR_ABORT)) | 634 | if (test_opt(sb, DATA_ERR_ABORT)) |
| 627 | seq_puts(seq, ",data_err=abort"); | 635 | seq_puts(seq, ",data_err=abort"); |
| 628 | 636 | ||
| @@ -1024,12 +1032,18 @@ static int parse_options (char *options, struct super_block *sb, | |||
| 1024 | datacheck: | 1032 | datacheck: |
| 1025 | if (is_remount) { | 1033 | if (is_remount) { |
| 1026 | if ((sbi->s_mount_opt & EXT3_MOUNT_DATA_FLAGS) | 1034 | if ((sbi->s_mount_opt & EXT3_MOUNT_DATA_FLAGS) |
| 1027 | != data_opt) { | 1035 | == data_opt) |
| 1028 | printk(KERN_ERR | 1036 | break; |
| 1029 | "EXT3-fs: cannot change data " | 1037 | printk(KERN_ERR |
| 1030 | "mode on remount\n"); | 1038 | "EXT3-fs (device %s): Cannot change " |
| 1031 | return 0; | 1039 | "data mode on remount. The filesystem " |
| 1032 | } | 1040 | "is mounted in data=%s mode and you " |
| 1041 | "try to remount it in data=%s mode.\n", | ||
| 1042 | sb->s_id, | ||
| 1043 | data_mode_string(sbi->s_mount_opt & | ||
| 1044 | EXT3_MOUNT_DATA_FLAGS), | ||
| 1045 | data_mode_string(data_opt)); | ||
| 1046 | return 0; | ||
| 1033 | } else { | 1047 | } else { |
| 1034 | sbi->s_mount_opt &= ~EXT3_MOUNT_DATA_FLAGS; | 1048 | sbi->s_mount_opt &= ~EXT3_MOUNT_DATA_FLAGS; |
| 1035 | sbi->s_mount_opt |= data_opt; | 1049 | sbi->s_mount_opt |= data_opt; |
diff --git a/fs/gfs2/aops.c b/fs/gfs2/aops.c index 03ebb439ace0..7ebae9a4ecc0 100644 --- a/fs/gfs2/aops.c +++ b/fs/gfs2/aops.c | |||
| @@ -624,6 +624,7 @@ static int gfs2_write_begin(struct file *file, struct address_space *mapping, | |||
| 624 | { | 624 | { |
| 625 | struct gfs2_inode *ip = GFS2_I(mapping->host); | 625 | struct gfs2_inode *ip = GFS2_I(mapping->host); |
| 626 | struct gfs2_sbd *sdp = GFS2_SB(mapping->host); | 626 | struct gfs2_sbd *sdp = GFS2_SB(mapping->host); |
| 627 | struct gfs2_inode *m_ip = GFS2_I(sdp->sd_statfs_inode); | ||
| 627 | unsigned int data_blocks = 0, ind_blocks = 0, rblocks; | 628 | unsigned int data_blocks = 0, ind_blocks = 0, rblocks; |
| 628 | int alloc_required; | 629 | int alloc_required; |
| 629 | int error = 0; | 630 | int error = 0; |
| @@ -637,6 +638,14 @@ static int gfs2_write_begin(struct file *file, struct address_space *mapping, | |||
| 637 | error = gfs2_glock_nq(&ip->i_gh); | 638 | error = gfs2_glock_nq(&ip->i_gh); |
| 638 | if (unlikely(error)) | 639 | if (unlikely(error)) |
| 639 | goto out_uninit; | 640 | goto out_uninit; |
| 641 | if (&ip->i_inode == sdp->sd_rindex) { | ||
| 642 | error = gfs2_glock_nq_init(m_ip->i_gl, LM_ST_EXCLUSIVE, | ||
| 643 | GL_NOCACHE, &m_ip->i_gh); | ||
| 644 | if (unlikely(error)) { | ||
| 645 | gfs2_glock_dq(&ip->i_gh); | ||
| 646 | goto out_uninit; | ||
| 647 | } | ||
| 648 | } | ||
| 640 | 649 | ||
| 641 | error = gfs2_write_alloc_required(ip, pos, len, &alloc_required); | 650 | error = gfs2_write_alloc_required(ip, pos, len, &alloc_required); |
| 642 | if (error) | 651 | if (error) |
| @@ -667,6 +676,8 @@ static int gfs2_write_begin(struct file *file, struct address_space *mapping, | |||
| 667 | rblocks += data_blocks ? data_blocks : 1; | 676 | rblocks += data_blocks ? data_blocks : 1; |
| 668 | if (ind_blocks || data_blocks) | 677 | if (ind_blocks || data_blocks) |
| 669 | rblocks += RES_STATFS + RES_QUOTA; | 678 | rblocks += RES_STATFS + RES_QUOTA; |
| 679 | if (&ip->i_inode == sdp->sd_rindex) | ||
| 680 | rblocks += 2 * RES_STATFS; | ||
| 670 | 681 | ||
| 671 | error = gfs2_trans_begin(sdp, rblocks, | 682 | error = gfs2_trans_begin(sdp, rblocks, |
| 672 | PAGE_CACHE_SIZE/sdp->sd_sb.sb_bsize); | 683 | PAGE_CACHE_SIZE/sdp->sd_sb.sb_bsize); |
| @@ -712,6 +723,10 @@ out_alloc_put: | |||
| 712 | gfs2_alloc_put(ip); | 723 | gfs2_alloc_put(ip); |
| 713 | } | 724 | } |
| 714 | out_unlock: | 725 | out_unlock: |
| 726 | if (&ip->i_inode == sdp->sd_rindex) { | ||
| 727 | gfs2_glock_dq(&m_ip->i_gh); | ||
| 728 | gfs2_holder_uninit(&m_ip->i_gh); | ||
| 729 | } | ||
| 715 | gfs2_glock_dq(&ip->i_gh); | 730 | gfs2_glock_dq(&ip->i_gh); |
| 716 | out_uninit: | 731 | out_uninit: |
| 717 | gfs2_holder_uninit(&ip->i_gh); | 732 | gfs2_holder_uninit(&ip->i_gh); |
| @@ -725,14 +740,21 @@ out_uninit: | |||
| 725 | static void adjust_fs_space(struct inode *inode) | 740 | static void adjust_fs_space(struct inode *inode) |
| 726 | { | 741 | { |
| 727 | struct gfs2_sbd *sdp = inode->i_sb->s_fs_info; | 742 | struct gfs2_sbd *sdp = inode->i_sb->s_fs_info; |
| 743 | struct gfs2_inode *m_ip = GFS2_I(sdp->sd_statfs_inode); | ||
| 744 | struct gfs2_inode *l_ip = GFS2_I(sdp->sd_sc_inode); | ||
| 728 | struct gfs2_statfs_change_host *m_sc = &sdp->sd_statfs_master; | 745 | struct gfs2_statfs_change_host *m_sc = &sdp->sd_statfs_master; |
| 729 | struct gfs2_statfs_change_host *l_sc = &sdp->sd_statfs_local; | 746 | struct gfs2_statfs_change_host *l_sc = &sdp->sd_statfs_local; |
| 747 | struct buffer_head *m_bh, *l_bh; | ||
| 730 | u64 fs_total, new_free; | 748 | u64 fs_total, new_free; |
| 731 | 749 | ||
| 732 | /* Total up the file system space, according to the latest rindex. */ | 750 | /* Total up the file system space, according to the latest rindex. */ |
| 733 | fs_total = gfs2_ri_total(sdp); | 751 | fs_total = gfs2_ri_total(sdp); |
| 752 | if (gfs2_meta_inode_buffer(m_ip, &m_bh) != 0) | ||
| 753 | return; | ||
| 734 | 754 | ||
| 735 | spin_lock(&sdp->sd_statfs_spin); | 755 | spin_lock(&sdp->sd_statfs_spin); |
| 756 | gfs2_statfs_change_in(m_sc, m_bh->b_data + | ||
| 757 | sizeof(struct gfs2_dinode)); | ||
| 736 | if (fs_total > (m_sc->sc_total + l_sc->sc_total)) | 758 | if (fs_total > (m_sc->sc_total + l_sc->sc_total)) |
| 737 | new_free = fs_total - (m_sc->sc_total + l_sc->sc_total); | 759 | new_free = fs_total - (m_sc->sc_total + l_sc->sc_total); |
| 738 | else | 760 | else |
| @@ -741,6 +763,13 @@ static void adjust_fs_space(struct inode *inode) | |||
| 741 | fs_warn(sdp, "File system extended by %llu blocks.\n", | 763 | fs_warn(sdp, "File system extended by %llu blocks.\n", |
| 742 | (unsigned long long)new_free); | 764 | (unsigned long long)new_free); |
| 743 | gfs2_statfs_change(sdp, new_free, new_free, 0); | 765 | gfs2_statfs_change(sdp, new_free, new_free, 0); |
| 766 | |||
| 767 | if (gfs2_meta_inode_buffer(l_ip, &l_bh) != 0) | ||
| 768 | goto out; | ||
| 769 | update_statfs(sdp, m_bh, l_bh); | ||
| 770 | brelse(l_bh); | ||
| 771 | out: | ||
| 772 | brelse(m_bh); | ||
| 744 | } | 773 | } |
| 745 | 774 | ||
| 746 | /** | 775 | /** |
| @@ -763,6 +792,7 @@ static int gfs2_stuffed_write_end(struct inode *inode, struct buffer_head *dibh, | |||
| 763 | { | 792 | { |
| 764 | struct gfs2_inode *ip = GFS2_I(inode); | 793 | struct gfs2_inode *ip = GFS2_I(inode); |
| 765 | struct gfs2_sbd *sdp = GFS2_SB(inode); | 794 | struct gfs2_sbd *sdp = GFS2_SB(inode); |
| 795 | struct gfs2_inode *m_ip = GFS2_I(sdp->sd_statfs_inode); | ||
| 766 | u64 to = pos + copied; | 796 | u64 to = pos + copied; |
| 767 | void *kaddr; | 797 | void *kaddr; |
| 768 | unsigned char *buf = dibh->b_data + sizeof(struct gfs2_dinode); | 798 | unsigned char *buf = dibh->b_data + sizeof(struct gfs2_dinode); |
| @@ -794,6 +824,10 @@ static int gfs2_stuffed_write_end(struct inode *inode, struct buffer_head *dibh, | |||
| 794 | 824 | ||
| 795 | brelse(dibh); | 825 | brelse(dibh); |
| 796 | gfs2_trans_end(sdp); | 826 | gfs2_trans_end(sdp); |
| 827 | if (inode == sdp->sd_rindex) { | ||
| 828 | gfs2_glock_dq(&m_ip->i_gh); | ||
| 829 | gfs2_holder_uninit(&m_ip->i_gh); | ||
| 830 | } | ||
| 797 | gfs2_glock_dq(&ip->i_gh); | 831 | gfs2_glock_dq(&ip->i_gh); |
| 798 | gfs2_holder_uninit(&ip->i_gh); | 832 | gfs2_holder_uninit(&ip->i_gh); |
| 799 | return copied; | 833 | return copied; |
| @@ -823,6 +857,7 @@ static int gfs2_write_end(struct file *file, struct address_space *mapping, | |||
| 823 | struct inode *inode = page->mapping->host; | 857 | struct inode *inode = page->mapping->host; |
| 824 | struct gfs2_inode *ip = GFS2_I(inode); | 858 | struct gfs2_inode *ip = GFS2_I(inode); |
| 825 | struct gfs2_sbd *sdp = GFS2_SB(inode); | 859 | struct gfs2_sbd *sdp = GFS2_SB(inode); |
| 860 | struct gfs2_inode *m_ip = GFS2_I(sdp->sd_statfs_inode); | ||
| 826 | struct buffer_head *dibh; | 861 | struct buffer_head *dibh; |
| 827 | struct gfs2_alloc *al = ip->i_alloc; | 862 | struct gfs2_alloc *al = ip->i_alloc; |
| 828 | unsigned int from = pos & (PAGE_CACHE_SIZE - 1); | 863 | unsigned int from = pos & (PAGE_CACHE_SIZE - 1); |
| @@ -865,6 +900,10 @@ failed: | |||
| 865 | gfs2_quota_unlock(ip); | 900 | gfs2_quota_unlock(ip); |
| 866 | gfs2_alloc_put(ip); | 901 | gfs2_alloc_put(ip); |
| 867 | } | 902 | } |
| 903 | if (inode == sdp->sd_rindex) { | ||
| 904 | gfs2_glock_dq(&m_ip->i_gh); | ||
| 905 | gfs2_holder_uninit(&m_ip->i_gh); | ||
| 906 | } | ||
| 868 | gfs2_glock_dq(&ip->i_gh); | 907 | gfs2_glock_dq(&ip->i_gh); |
| 869 | gfs2_holder_uninit(&ip->i_gh); | 908 | gfs2_holder_uninit(&ip->i_gh); |
| 870 | return ret; | 909 | return ret; |
diff --git a/fs/gfs2/glock.c b/fs/gfs2/glock.c index 297421c0427a..8b674b1f3a55 100644 --- a/fs/gfs2/glock.c +++ b/fs/gfs2/glock.c | |||
| @@ -63,6 +63,7 @@ static void do_xmote(struct gfs2_glock *gl, struct gfs2_holder *gh, unsigned int | |||
| 63 | static DECLARE_RWSEM(gfs2_umount_flush_sem); | 63 | static DECLARE_RWSEM(gfs2_umount_flush_sem); |
| 64 | static struct dentry *gfs2_root; | 64 | static struct dentry *gfs2_root; |
| 65 | static struct workqueue_struct *glock_workqueue; | 65 | static struct workqueue_struct *glock_workqueue; |
| 66 | struct workqueue_struct *gfs2_delete_workqueue; | ||
| 66 | static LIST_HEAD(lru_list); | 67 | static LIST_HEAD(lru_list); |
| 67 | static atomic_t lru_count = ATOMIC_INIT(0); | 68 | static atomic_t lru_count = ATOMIC_INIT(0); |
| 68 | static DEFINE_SPINLOCK(lru_lock); | 69 | static DEFINE_SPINLOCK(lru_lock); |
| @@ -167,13 +168,33 @@ static void glock_free(struct gfs2_glock *gl) | |||
| 167 | * | 168 | * |
| 168 | */ | 169 | */ |
| 169 | 170 | ||
| 170 | static void gfs2_glock_hold(struct gfs2_glock *gl) | 171 | void gfs2_glock_hold(struct gfs2_glock *gl) |
| 171 | { | 172 | { |
| 172 | GLOCK_BUG_ON(gl, atomic_read(&gl->gl_ref) == 0); | 173 | GLOCK_BUG_ON(gl, atomic_read(&gl->gl_ref) == 0); |
| 173 | atomic_inc(&gl->gl_ref); | 174 | atomic_inc(&gl->gl_ref); |
| 174 | } | 175 | } |
| 175 | 176 | ||
| 176 | /** | 177 | /** |
| 178 | * demote_ok - Check to see if it's ok to unlock a glock | ||
| 179 | * @gl: the glock | ||
| 180 | * | ||
| 181 | * Returns: 1 if it's ok | ||
| 182 | */ | ||
| 183 | |||
| 184 | static int demote_ok(const struct gfs2_glock *gl) | ||
| 185 | { | ||
| 186 | const struct gfs2_glock_operations *glops = gl->gl_ops; | ||
| 187 | |||
| 188 | if (gl->gl_state == LM_ST_UNLOCKED) | ||
| 189 | return 0; | ||
| 190 | if (!list_empty(&gl->gl_holders)) | ||
| 191 | return 0; | ||
| 192 | if (glops->go_demote_ok) | ||
| 193 | return glops->go_demote_ok(gl); | ||
| 194 | return 1; | ||
| 195 | } | ||
| 196 | |||
| 197 | /** | ||
| 177 | * gfs2_glock_schedule_for_reclaim - Add a glock to the reclaim list | 198 | * gfs2_glock_schedule_for_reclaim - Add a glock to the reclaim list |
| 178 | * @gl: the glock | 199 | * @gl: the glock |
| 179 | * | 200 | * |
| @@ -181,8 +202,13 @@ static void gfs2_glock_hold(struct gfs2_glock *gl) | |||
| 181 | 202 | ||
| 182 | static void gfs2_glock_schedule_for_reclaim(struct gfs2_glock *gl) | 203 | static void gfs2_glock_schedule_for_reclaim(struct gfs2_glock *gl) |
| 183 | { | 204 | { |
| 205 | int may_reclaim; | ||
| 206 | may_reclaim = (demote_ok(gl) && | ||
| 207 | (atomic_read(&gl->gl_ref) == 1 || | ||
| 208 | (gl->gl_name.ln_type == LM_TYPE_INODE && | ||
| 209 | atomic_read(&gl->gl_ref) <= 2))); | ||
| 184 | spin_lock(&lru_lock); | 210 | spin_lock(&lru_lock); |
| 185 | if (list_empty(&gl->gl_lru) && gl->gl_state != LM_ST_UNLOCKED) { | 211 | if (list_empty(&gl->gl_lru) && may_reclaim) { |
| 186 | list_add_tail(&gl->gl_lru, &lru_list); | 212 | list_add_tail(&gl->gl_lru, &lru_list); |
| 187 | atomic_inc(&lru_count); | 213 | atomic_inc(&lru_count); |
| 188 | } | 214 | } |
| @@ -190,6 +216,21 @@ static void gfs2_glock_schedule_for_reclaim(struct gfs2_glock *gl) | |||
| 190 | } | 216 | } |
| 191 | 217 | ||
| 192 | /** | 218 | /** |
| 219 | * gfs2_glock_put_nolock() - Decrement reference count on glock | ||
| 220 | * @gl: The glock to put | ||
| 221 | * | ||
| 222 | * This function should only be used if the caller has its own reference | ||
| 223 | * to the glock, in addition to the one it is dropping. | ||
| 224 | */ | ||
| 225 | |||
| 226 | void gfs2_glock_put_nolock(struct gfs2_glock *gl) | ||
| 227 | { | ||
| 228 | if (atomic_dec_and_test(&gl->gl_ref)) | ||
| 229 | GLOCK_BUG_ON(gl, 1); | ||
| 230 | gfs2_glock_schedule_for_reclaim(gl); | ||
| 231 | } | ||
| 232 | |||
| 233 | /** | ||
| 193 | * gfs2_glock_put() - Decrement reference count on glock | 234 | * gfs2_glock_put() - Decrement reference count on glock |
| 194 | * @gl: The glock to put | 235 | * @gl: The glock to put |
| 195 | * | 236 | * |
| @@ -214,9 +255,9 @@ int gfs2_glock_put(struct gfs2_glock *gl) | |||
| 214 | rv = 1; | 255 | rv = 1; |
| 215 | goto out; | 256 | goto out; |
| 216 | } | 257 | } |
| 217 | /* 1 for being hashed, 1 for having state != LM_ST_UNLOCKED */ | 258 | spin_lock(&gl->gl_spin); |
| 218 | if (atomic_read(&gl->gl_ref) == 2) | 259 | gfs2_glock_schedule_for_reclaim(gl); |
| 219 | gfs2_glock_schedule_for_reclaim(gl); | 260 | spin_unlock(&gl->gl_spin); |
| 220 | write_unlock(gl_lock_addr(gl->gl_hash)); | 261 | write_unlock(gl_lock_addr(gl->gl_hash)); |
| 221 | out: | 262 | out: |
| 222 | return rv; | 263 | return rv; |
| @@ -398,7 +439,7 @@ static void state_change(struct gfs2_glock *gl, unsigned int new_state) | |||
| 398 | if (held2) | 439 | if (held2) |
| 399 | gfs2_glock_hold(gl); | 440 | gfs2_glock_hold(gl); |
| 400 | else | 441 | else |
| 401 | gfs2_glock_put(gl); | 442 | gfs2_glock_put_nolock(gl); |
| 402 | } | 443 | } |
| 403 | 444 | ||
| 404 | gl->gl_state = new_state; | 445 | gl->gl_state = new_state; |
| @@ -633,12 +674,35 @@ out: | |||
| 633 | out_sched: | 674 | out_sched: |
| 634 | gfs2_glock_hold(gl); | 675 | gfs2_glock_hold(gl); |
| 635 | if (queue_delayed_work(glock_workqueue, &gl->gl_work, 0) == 0) | 676 | if (queue_delayed_work(glock_workqueue, &gl->gl_work, 0) == 0) |
| 636 | gfs2_glock_put(gl); | 677 | gfs2_glock_put_nolock(gl); |
| 637 | out_unlock: | 678 | out_unlock: |
| 638 | clear_bit(GLF_LOCK, &gl->gl_flags); | 679 | clear_bit(GLF_LOCK, &gl->gl_flags); |
| 639 | goto out; | 680 | goto out; |
| 640 | } | 681 | } |
| 641 | 682 | ||
| 683 | static void delete_work_func(struct work_struct *work) | ||
| 684 | { | ||
| 685 | struct gfs2_glock *gl = container_of(work, struct gfs2_glock, gl_delete); | ||
| 686 | struct gfs2_sbd *sdp = gl->gl_sbd; | ||
| 687 | struct gfs2_inode *ip = NULL; | ||
| 688 | struct inode *inode; | ||
| 689 | u64 no_addr = 0; | ||
| 690 | |||
| 691 | spin_lock(&gl->gl_spin); | ||
| 692 | ip = (struct gfs2_inode *)gl->gl_object; | ||
| 693 | if (ip) | ||
| 694 | no_addr = ip->i_no_addr; | ||
| 695 | spin_unlock(&gl->gl_spin); | ||
| 696 | if (ip) { | ||
| 697 | inode = gfs2_ilookup(sdp->sd_vfs, no_addr); | ||
| 698 | if (inode) { | ||
| 699 | d_prune_aliases(inode); | ||
| 700 | iput(inode); | ||
| 701 | } | ||
| 702 | } | ||
| 703 | gfs2_glock_put(gl); | ||
| 704 | } | ||
| 705 | |||
| 642 | static void glock_work_func(struct work_struct *work) | 706 | static void glock_work_func(struct work_struct *work) |
| 643 | { | 707 | { |
| 644 | unsigned long delay = 0; | 708 | unsigned long delay = 0; |
| @@ -717,6 +781,7 @@ int gfs2_glock_get(struct gfs2_sbd *sdp, u64 number, | |||
| 717 | gl->gl_sbd = sdp; | 781 | gl->gl_sbd = sdp; |
| 718 | gl->gl_aspace = NULL; | 782 | gl->gl_aspace = NULL; |
| 719 | INIT_DELAYED_WORK(&gl->gl_work, glock_work_func); | 783 | INIT_DELAYED_WORK(&gl->gl_work, glock_work_func); |
| 784 | INIT_WORK(&gl->gl_delete, delete_work_func); | ||
| 720 | 785 | ||
| 721 | /* If this glock protects actual on-disk data or metadata blocks, | 786 | /* If this glock protects actual on-disk data or metadata blocks, |
| 722 | create a VFS inode to manage the pages/buffers holding them. */ | 787 | create a VFS inode to manage the pages/buffers holding them. */ |
| @@ -858,6 +923,8 @@ static void handle_callback(struct gfs2_glock *gl, unsigned int state, | |||
| 858 | gl->gl_demote_state != state) { | 923 | gl->gl_demote_state != state) { |
| 859 | gl->gl_demote_state = LM_ST_UNLOCKED; | 924 | gl->gl_demote_state = LM_ST_UNLOCKED; |
| 860 | } | 925 | } |
| 926 | if (gl->gl_ops->go_callback) | ||
| 927 | gl->gl_ops->go_callback(gl); | ||
| 861 | trace_gfs2_demote_rq(gl); | 928 | trace_gfs2_demote_rq(gl); |
| 862 | } | 929 | } |
| 863 | 930 | ||
| @@ -1274,33 +1341,12 @@ void gfs2_glock_complete(struct gfs2_glock *gl, int ret) | |||
| 1274 | gfs2_glock_put(gl); | 1341 | gfs2_glock_put(gl); |
| 1275 | } | 1342 | } |
| 1276 | 1343 | ||
| 1277 | /** | ||
| 1278 | * demote_ok - Check to see if it's ok to unlock a glock | ||
| 1279 | * @gl: the glock | ||
| 1280 | * | ||
| 1281 | * Returns: 1 if it's ok | ||
| 1282 | */ | ||
| 1283 | |||
| 1284 | static int demote_ok(const struct gfs2_glock *gl) | ||
| 1285 | { | ||
| 1286 | const struct gfs2_glock_operations *glops = gl->gl_ops; | ||
| 1287 | |||
| 1288 | if (gl->gl_state == LM_ST_UNLOCKED) | ||
| 1289 | return 0; | ||
| 1290 | if (!list_empty(&gl->gl_holders)) | ||
| 1291 | return 0; | ||
| 1292 | if (glops->go_demote_ok) | ||
| 1293 | return glops->go_demote_ok(gl); | ||
| 1294 | return 1; | ||
| 1295 | } | ||
| 1296 | |||
| 1297 | 1344 | ||
| 1298 | static int gfs2_shrink_glock_memory(int nr, gfp_t gfp_mask) | 1345 | static int gfs2_shrink_glock_memory(int nr, gfp_t gfp_mask) |
| 1299 | { | 1346 | { |
| 1300 | struct gfs2_glock *gl; | 1347 | struct gfs2_glock *gl; |
| 1301 | int may_demote; | 1348 | int may_demote; |
| 1302 | int nr_skipped = 0; | 1349 | int nr_skipped = 0; |
| 1303 | int got_ref = 0; | ||
| 1304 | LIST_HEAD(skipped); | 1350 | LIST_HEAD(skipped); |
| 1305 | 1351 | ||
| 1306 | if (nr == 0) | 1352 | if (nr == 0) |
| @@ -1315,37 +1361,29 @@ static int gfs2_shrink_glock_memory(int nr, gfp_t gfp_mask) | |||
| 1315 | list_del_init(&gl->gl_lru); | 1361 | list_del_init(&gl->gl_lru); |
| 1316 | atomic_dec(&lru_count); | 1362 | atomic_dec(&lru_count); |
| 1317 | 1363 | ||
| 1364 | /* Check if glock is about to be freed */ | ||
| 1365 | if (atomic_read(&gl->gl_ref) == 0) | ||
| 1366 | continue; | ||
| 1367 | |||
| 1318 | /* Test for being demotable */ | 1368 | /* Test for being demotable */ |
| 1319 | if (!test_and_set_bit(GLF_LOCK, &gl->gl_flags)) { | 1369 | if (!test_and_set_bit(GLF_LOCK, &gl->gl_flags)) { |
| 1320 | gfs2_glock_hold(gl); | 1370 | gfs2_glock_hold(gl); |
| 1321 | got_ref = 1; | ||
| 1322 | spin_unlock(&lru_lock); | 1371 | spin_unlock(&lru_lock); |
| 1323 | spin_lock(&gl->gl_spin); | 1372 | spin_lock(&gl->gl_spin); |
| 1324 | may_demote = demote_ok(gl); | 1373 | may_demote = demote_ok(gl); |
| 1325 | spin_unlock(&gl->gl_spin); | ||
| 1326 | clear_bit(GLF_LOCK, &gl->gl_flags); | ||
| 1327 | if (may_demote) { | 1374 | if (may_demote) { |
| 1328 | handle_callback(gl, LM_ST_UNLOCKED, 0); | 1375 | handle_callback(gl, LM_ST_UNLOCKED, 0); |
| 1329 | nr--; | 1376 | nr--; |
| 1330 | if (queue_delayed_work(glock_workqueue, &gl->gl_work, 0) == 0) | ||
| 1331 | gfs2_glock_put(gl); | ||
| 1332 | got_ref = 0; | ||
| 1333 | } | 1377 | } |
| 1378 | if (queue_delayed_work(glock_workqueue, &gl->gl_work, 0) == 0) | ||
| 1379 | gfs2_glock_put_nolock(gl); | ||
| 1380 | spin_unlock(&gl->gl_spin); | ||
| 1381 | clear_bit(GLF_LOCK, &gl->gl_flags); | ||
| 1334 | spin_lock(&lru_lock); | 1382 | spin_lock(&lru_lock); |
| 1335 | if (may_demote) | 1383 | continue; |
| 1336 | continue; | ||
| 1337 | } | ||
| 1338 | if (list_empty(&gl->gl_lru) && | ||
| 1339 | (atomic_read(&gl->gl_ref) <= (2 + got_ref))) { | ||
| 1340 | nr_skipped++; | ||
| 1341 | list_add(&gl->gl_lru, &skipped); | ||
| 1342 | } | ||
| 1343 | if (got_ref) { | ||
| 1344 | spin_unlock(&lru_lock); | ||
| 1345 | gfs2_glock_put(gl); | ||
| 1346 | spin_lock(&lru_lock); | ||
| 1347 | got_ref = 0; | ||
| 1348 | } | 1384 | } |
| 1385 | nr_skipped++; | ||
| 1386 | list_add(&gl->gl_lru, &skipped); | ||
| 1349 | } | 1387 | } |
| 1350 | list_splice(&skipped, &lru_list); | 1388 | list_splice(&skipped, &lru_list); |
| 1351 | atomic_add(nr_skipped, &lru_count); | 1389 | atomic_add(nr_skipped, &lru_count); |
| @@ -1727,6 +1765,11 @@ int __init gfs2_glock_init(void) | |||
| 1727 | glock_workqueue = create_workqueue("glock_workqueue"); | 1765 | glock_workqueue = create_workqueue("glock_workqueue"); |
| 1728 | if (IS_ERR(glock_workqueue)) | 1766 | if (IS_ERR(glock_workqueue)) |
| 1729 | return PTR_ERR(glock_workqueue); | 1767 | return PTR_ERR(glock_workqueue); |
| 1768 | gfs2_delete_workqueue = create_workqueue("delete_workqueue"); | ||
| 1769 | if (IS_ERR(gfs2_delete_workqueue)) { | ||
| 1770 | destroy_workqueue(glock_workqueue); | ||
| 1771 | return PTR_ERR(gfs2_delete_workqueue); | ||
| 1772 | } | ||
| 1730 | 1773 | ||
| 1731 | register_shrinker(&glock_shrinker); | 1774 | register_shrinker(&glock_shrinker); |
| 1732 | 1775 | ||
| @@ -1737,6 +1780,7 @@ void gfs2_glock_exit(void) | |||
| 1737 | { | 1780 | { |
| 1738 | unregister_shrinker(&glock_shrinker); | 1781 | unregister_shrinker(&glock_shrinker); |
| 1739 | destroy_workqueue(glock_workqueue); | 1782 | destroy_workqueue(glock_workqueue); |
| 1783 | destroy_workqueue(gfs2_delete_workqueue); | ||
| 1740 | } | 1784 | } |
| 1741 | 1785 | ||
| 1742 | static int gfs2_glock_iter_next(struct gfs2_glock_iter *gi) | 1786 | static int gfs2_glock_iter_next(struct gfs2_glock_iter *gi) |
diff --git a/fs/gfs2/glock.h b/fs/gfs2/glock.h index a602a28f6f08..c609894ec0d0 100644 --- a/fs/gfs2/glock.h +++ b/fs/gfs2/glock.h | |||
| @@ -143,6 +143,7 @@ struct lm_lockops { | |||
| 143 | 143 | ||
| 144 | #define GLR_TRYFAILED 13 | 144 | #define GLR_TRYFAILED 13 |
| 145 | 145 | ||
| 146 | extern struct workqueue_struct *gfs2_delete_workqueue; | ||
| 146 | static inline struct gfs2_holder *gfs2_glock_is_locked_by_me(struct gfs2_glock *gl) | 147 | static inline struct gfs2_holder *gfs2_glock_is_locked_by_me(struct gfs2_glock *gl) |
| 147 | { | 148 | { |
| 148 | struct gfs2_holder *gh; | 149 | struct gfs2_holder *gh; |
| @@ -191,6 +192,8 @@ static inline int gfs2_glock_is_blocking(struct gfs2_glock *gl) | |||
| 191 | int gfs2_glock_get(struct gfs2_sbd *sdp, | 192 | int gfs2_glock_get(struct gfs2_sbd *sdp, |
| 192 | u64 number, const struct gfs2_glock_operations *glops, | 193 | u64 number, const struct gfs2_glock_operations *glops, |
| 193 | int create, struct gfs2_glock **glp); | 194 | int create, struct gfs2_glock **glp); |
| 195 | void gfs2_glock_hold(struct gfs2_glock *gl); | ||
| 196 | void gfs2_glock_put_nolock(struct gfs2_glock *gl); | ||
| 194 | int gfs2_glock_put(struct gfs2_glock *gl); | 197 | int gfs2_glock_put(struct gfs2_glock *gl); |
| 195 | void gfs2_holder_init(struct gfs2_glock *gl, unsigned int state, unsigned flags, | 198 | void gfs2_holder_init(struct gfs2_glock *gl, unsigned int state, unsigned flags, |
| 196 | struct gfs2_holder *gh); | 199 | struct gfs2_holder *gh); |
diff --git a/fs/gfs2/glops.c b/fs/gfs2/glops.c index d5e4ab155ca0..6985eef06c39 100644 --- a/fs/gfs2/glops.c +++ b/fs/gfs2/glops.c | |||
| @@ -323,6 +323,7 @@ static void trans_go_sync(struct gfs2_glock *gl) | |||
| 323 | 323 | ||
| 324 | if (gl->gl_state != LM_ST_UNLOCKED && | 324 | if (gl->gl_state != LM_ST_UNLOCKED && |
| 325 | test_bit(SDF_JOURNAL_LIVE, &sdp->sd_flags)) { | 325 | test_bit(SDF_JOURNAL_LIVE, &sdp->sd_flags)) { |
| 326 | flush_workqueue(gfs2_delete_workqueue); | ||
| 326 | gfs2_meta_syncfs(sdp); | 327 | gfs2_meta_syncfs(sdp); |
| 327 | gfs2_log_shutdown(sdp); | 328 | gfs2_log_shutdown(sdp); |
| 328 | } | 329 | } |
| @@ -372,6 +373,25 @@ static int trans_go_demote_ok(const struct gfs2_glock *gl) | |||
| 372 | return 0; | 373 | return 0; |
| 373 | } | 374 | } |
| 374 | 375 | ||
| 376 | /** | ||
| 377 | * iopen_go_callback - schedule the dcache entry for the inode to be deleted | ||
| 378 | * @gl: the glock | ||
| 379 | * | ||
| 380 | * gl_spin lock is held while calling this | ||
| 381 | */ | ||
| 382 | static void iopen_go_callback(struct gfs2_glock *gl) | ||
| 383 | { | ||
| 384 | struct gfs2_inode *ip = (struct gfs2_inode *)gl->gl_object; | ||
| 385 | |||
| 386 | if (gl->gl_demote_state == LM_ST_UNLOCKED && | ||
| 387 | gl->gl_state == LM_ST_SHARED && | ||
| 388 | ip && test_bit(GIF_USER, &ip->i_flags)) { | ||
| 389 | gfs2_glock_hold(gl); | ||
| 390 | if (queue_work(gfs2_delete_workqueue, &gl->gl_delete) == 0) | ||
| 391 | gfs2_glock_put_nolock(gl); | ||
| 392 | } | ||
| 393 | } | ||
| 394 | |||
| 375 | const struct gfs2_glock_operations gfs2_meta_glops = { | 395 | const struct gfs2_glock_operations gfs2_meta_glops = { |
| 376 | .go_type = LM_TYPE_META, | 396 | .go_type = LM_TYPE_META, |
| 377 | }; | 397 | }; |
| @@ -406,6 +426,7 @@ const struct gfs2_glock_operations gfs2_trans_glops = { | |||
| 406 | 426 | ||
| 407 | const struct gfs2_glock_operations gfs2_iopen_glops = { | 427 | const struct gfs2_glock_operations gfs2_iopen_glops = { |
| 408 | .go_type = LM_TYPE_IOPEN, | 428 | .go_type = LM_TYPE_IOPEN, |
| 429 | .go_callback = iopen_go_callback, | ||
| 409 | }; | 430 | }; |
| 410 | 431 | ||
| 411 | const struct gfs2_glock_operations gfs2_flock_glops = { | 432 | const struct gfs2_glock_operations gfs2_flock_glops = { |
diff --git a/fs/gfs2/incore.h b/fs/gfs2/incore.h index 225347fbff3c..61801ada36f0 100644 --- a/fs/gfs2/incore.h +++ b/fs/gfs2/incore.h | |||
| @@ -159,6 +159,7 @@ struct gfs2_glock_operations { | |||
| 159 | int (*go_lock) (struct gfs2_holder *gh); | 159 | int (*go_lock) (struct gfs2_holder *gh); |
| 160 | void (*go_unlock) (struct gfs2_holder *gh); | 160 | void (*go_unlock) (struct gfs2_holder *gh); |
| 161 | int (*go_dump)(struct seq_file *seq, const struct gfs2_glock *gl); | 161 | int (*go_dump)(struct seq_file *seq, const struct gfs2_glock *gl); |
| 162 | void (*go_callback) (struct gfs2_glock *gl); | ||
| 162 | const int go_type; | 163 | const int go_type; |
| 163 | const unsigned long go_min_hold_time; | 164 | const unsigned long go_min_hold_time; |
| 164 | }; | 165 | }; |
| @@ -228,6 +229,7 @@ struct gfs2_glock { | |||
| 228 | struct list_head gl_ail_list; | 229 | struct list_head gl_ail_list; |
| 229 | atomic_t gl_ail_count; | 230 | atomic_t gl_ail_count; |
| 230 | struct delayed_work gl_work; | 231 | struct delayed_work gl_work; |
| 232 | struct work_struct gl_delete; | ||
| 231 | }; | 233 | }; |
| 232 | 234 | ||
| 233 | #define GFS2_MIN_LVB_SIZE 32 /* Min size of LVB that gfs2 supports */ | 235 | #define GFS2_MIN_LVB_SIZE 32 /* Min size of LVB that gfs2 supports */ |
diff --git a/fs/gfs2/rgrp.c b/fs/gfs2/rgrp.c index daa4ae341a29..fba795798d3a 100644 --- a/fs/gfs2/rgrp.c +++ b/fs/gfs2/rgrp.c | |||
| @@ -285,27 +285,19 @@ void gfs2_rgrp_verify(struct gfs2_rgrpd *rgd) | |||
| 285 | } | 285 | } |
| 286 | 286 | ||
| 287 | tmp = rgd->rd_data - rgd->rd_free - rgd->rd_dinodes; | 287 | tmp = rgd->rd_data - rgd->rd_free - rgd->rd_dinodes; |
| 288 | if (count[1] + count[2] != tmp) { | 288 | if (count[1] != tmp) { |
| 289 | if (gfs2_consist_rgrpd(rgd)) | 289 | if (gfs2_consist_rgrpd(rgd)) |
| 290 | fs_err(sdp, "used data mismatch: %u != %u\n", | 290 | fs_err(sdp, "used data mismatch: %u != %u\n", |
| 291 | count[1], tmp); | 291 | count[1], tmp); |
| 292 | return; | 292 | return; |
| 293 | } | 293 | } |
| 294 | 294 | ||
| 295 | if (count[3] != rgd->rd_dinodes) { | 295 | if (count[2] + count[3] != rgd->rd_dinodes) { |
| 296 | if (gfs2_consist_rgrpd(rgd)) | 296 | if (gfs2_consist_rgrpd(rgd)) |
| 297 | fs_err(sdp, "used metadata mismatch: %u != %u\n", | 297 | fs_err(sdp, "used metadata mismatch: %u != %u\n", |
| 298 | count[3], rgd->rd_dinodes); | 298 | count[2] + count[3], rgd->rd_dinodes); |
| 299 | return; | 299 | return; |
| 300 | } | 300 | } |
| 301 | |||
| 302 | if (count[2] > count[3]) { | ||
| 303 | if (gfs2_consist_rgrpd(rgd)) | ||
| 304 | fs_err(sdp, "unlinked inodes > inodes: %u\n", | ||
| 305 | count[2]); | ||
| 306 | return; | ||
| 307 | } | ||
| 308 | |||
| 309 | } | 301 | } |
| 310 | 302 | ||
| 311 | static inline int rgrp_contains_block(struct gfs2_rgrpd *rgd, u64 block) | 303 | static inline int rgrp_contains_block(struct gfs2_rgrpd *rgd, u64 block) |
| @@ -961,7 +953,8 @@ static int try_rgrp_fit(struct gfs2_rgrpd *rgd, struct gfs2_alloc *al) | |||
| 961 | * Returns: The inode, if one has been found | 953 | * Returns: The inode, if one has been found |
| 962 | */ | 954 | */ |
| 963 | 955 | ||
| 964 | static struct inode *try_rgrp_unlink(struct gfs2_rgrpd *rgd, u64 *last_unlinked) | 956 | static struct inode *try_rgrp_unlink(struct gfs2_rgrpd *rgd, u64 *last_unlinked, |
| 957 | u64 skip) | ||
| 965 | { | 958 | { |
| 966 | struct inode *inode; | 959 | struct inode *inode; |
| 967 | u32 goal = 0, block; | 960 | u32 goal = 0, block; |
| @@ -985,6 +978,8 @@ static struct inode *try_rgrp_unlink(struct gfs2_rgrpd *rgd, u64 *last_unlinked) | |||
| 985 | goal++; | 978 | goal++; |
| 986 | if (*last_unlinked != NO_BLOCK && no_addr <= *last_unlinked) | 979 | if (*last_unlinked != NO_BLOCK && no_addr <= *last_unlinked) |
| 987 | continue; | 980 | continue; |
| 981 | if (no_addr == skip) | ||
| 982 | continue; | ||
| 988 | *last_unlinked = no_addr; | 983 | *last_unlinked = no_addr; |
| 989 | inode = gfs2_inode_lookup(rgd->rd_sbd->sd_vfs, DT_UNKNOWN, | 984 | inode = gfs2_inode_lookup(rgd->rd_sbd->sd_vfs, DT_UNKNOWN, |
| 990 | no_addr, -1, 1); | 985 | no_addr, -1, 1); |
| @@ -1104,7 +1099,7 @@ static struct inode *get_local_rgrp(struct gfs2_inode *ip, u64 *last_unlinked) | |||
| 1104 | if (try_rgrp_fit(rgd, al)) | 1099 | if (try_rgrp_fit(rgd, al)) |
| 1105 | goto out; | 1100 | goto out; |
| 1106 | if (rgd->rd_flags & GFS2_RDF_CHECK) | 1101 | if (rgd->rd_flags & GFS2_RDF_CHECK) |
| 1107 | inode = try_rgrp_unlink(rgd, last_unlinked); | 1102 | inode = try_rgrp_unlink(rgd, last_unlinked, ip->i_no_addr); |
| 1108 | if (!rg_locked) | 1103 | if (!rg_locked) |
| 1109 | gfs2_glock_dq_uninit(&al->al_rgd_gh); | 1104 | gfs2_glock_dq_uninit(&al->al_rgd_gh); |
| 1110 | if (inode) | 1105 | if (inode) |
| @@ -1138,7 +1133,7 @@ static struct inode *get_local_rgrp(struct gfs2_inode *ip, u64 *last_unlinked) | |||
| 1138 | if (try_rgrp_fit(rgd, al)) | 1133 | if (try_rgrp_fit(rgd, al)) |
| 1139 | goto out; | 1134 | goto out; |
| 1140 | if (rgd->rd_flags & GFS2_RDF_CHECK) | 1135 | if (rgd->rd_flags & GFS2_RDF_CHECK) |
| 1141 | inode = try_rgrp_unlink(rgd, last_unlinked); | 1136 | inode = try_rgrp_unlink(rgd, last_unlinked, ip->i_no_addr); |
| 1142 | if (!rg_locked) | 1137 | if (!rg_locked) |
| 1143 | gfs2_glock_dq_uninit(&al->al_rgd_gh); | 1138 | gfs2_glock_dq_uninit(&al->al_rgd_gh); |
| 1144 | if (inode) | 1139 | if (inode) |
diff --git a/fs/gfs2/super.c b/fs/gfs2/super.c index 0a6801336470..f522bb017973 100644 --- a/fs/gfs2/super.c +++ b/fs/gfs2/super.c | |||
| @@ -353,7 +353,7 @@ fail: | |||
| 353 | return error; | 353 | return error; |
| 354 | } | 354 | } |
| 355 | 355 | ||
| 356 | static void gfs2_statfs_change_in(struct gfs2_statfs_change_host *sc, const void *buf) | 356 | void gfs2_statfs_change_in(struct gfs2_statfs_change_host *sc, const void *buf) |
| 357 | { | 357 | { |
| 358 | const struct gfs2_statfs_change *str = buf; | 358 | const struct gfs2_statfs_change *str = buf; |
| 359 | 359 | ||
| @@ -441,6 +441,29 @@ void gfs2_statfs_change(struct gfs2_sbd *sdp, s64 total, s64 free, | |||
| 441 | brelse(l_bh); | 441 | brelse(l_bh); |
| 442 | } | 442 | } |
| 443 | 443 | ||
| 444 | void update_statfs(struct gfs2_sbd *sdp, struct buffer_head *m_bh, | ||
| 445 | struct buffer_head *l_bh) | ||
| 446 | { | ||
| 447 | struct gfs2_inode *m_ip = GFS2_I(sdp->sd_statfs_inode); | ||
| 448 | struct gfs2_inode *l_ip = GFS2_I(sdp->sd_sc_inode); | ||
| 449 | struct gfs2_statfs_change_host *m_sc = &sdp->sd_statfs_master; | ||
| 450 | struct gfs2_statfs_change_host *l_sc = &sdp->sd_statfs_local; | ||
| 451 | |||
| 452 | gfs2_trans_add_bh(l_ip->i_gl, l_bh, 1); | ||
| 453 | |||
| 454 | spin_lock(&sdp->sd_statfs_spin); | ||
| 455 | m_sc->sc_total += l_sc->sc_total; | ||
| 456 | m_sc->sc_free += l_sc->sc_free; | ||
| 457 | m_sc->sc_dinodes += l_sc->sc_dinodes; | ||
| 458 | memset(l_sc, 0, sizeof(struct gfs2_statfs_change)); | ||
| 459 | memset(l_bh->b_data + sizeof(struct gfs2_dinode), | ||
| 460 | 0, sizeof(struct gfs2_statfs_change)); | ||
| 461 | spin_unlock(&sdp->sd_statfs_spin); | ||
| 462 | |||
| 463 | gfs2_trans_add_bh(m_ip->i_gl, m_bh, 1); | ||
| 464 | gfs2_statfs_change_out(m_sc, m_bh->b_data + sizeof(struct gfs2_dinode)); | ||
| 465 | } | ||
| 466 | |||
| 444 | int gfs2_statfs_sync(struct gfs2_sbd *sdp) | 467 | int gfs2_statfs_sync(struct gfs2_sbd *sdp) |
| 445 | { | 468 | { |
| 446 | struct gfs2_inode *m_ip = GFS2_I(sdp->sd_statfs_inode); | 469 | struct gfs2_inode *m_ip = GFS2_I(sdp->sd_statfs_inode); |
| @@ -477,19 +500,7 @@ int gfs2_statfs_sync(struct gfs2_sbd *sdp) | |||
| 477 | if (error) | 500 | if (error) |
| 478 | goto out_bh2; | 501 | goto out_bh2; |
| 479 | 502 | ||
| 480 | gfs2_trans_add_bh(l_ip->i_gl, l_bh, 1); | 503 | update_statfs(sdp, m_bh, l_bh); |
| 481 | |||
| 482 | spin_lock(&sdp->sd_statfs_spin); | ||
| 483 | m_sc->sc_total += l_sc->sc_total; | ||
| 484 | m_sc->sc_free += l_sc->sc_free; | ||
| 485 | m_sc->sc_dinodes += l_sc->sc_dinodes; | ||
| 486 | memset(l_sc, 0, sizeof(struct gfs2_statfs_change)); | ||
| 487 | memset(l_bh->b_data + sizeof(struct gfs2_dinode), | ||
| 488 | 0, sizeof(struct gfs2_statfs_change)); | ||
| 489 | spin_unlock(&sdp->sd_statfs_spin); | ||
| 490 | |||
| 491 | gfs2_trans_add_bh(m_ip->i_gl, m_bh, 1); | ||
| 492 | gfs2_statfs_change_out(m_sc, m_bh->b_data + sizeof(struct gfs2_dinode)); | ||
| 493 | 504 | ||
| 494 | gfs2_trans_end(sdp); | 505 | gfs2_trans_end(sdp); |
| 495 | 506 | ||
| @@ -680,6 +691,7 @@ static int gfs2_make_fs_ro(struct gfs2_sbd *sdp) | |||
| 680 | struct gfs2_holder t_gh; | 691 | struct gfs2_holder t_gh; |
| 681 | int error; | 692 | int error; |
| 682 | 693 | ||
| 694 | flush_workqueue(gfs2_delete_workqueue); | ||
| 683 | gfs2_quota_sync(sdp); | 695 | gfs2_quota_sync(sdp); |
| 684 | gfs2_statfs_sync(sdp); | 696 | gfs2_statfs_sync(sdp); |
| 685 | 697 | ||
diff --git a/fs/gfs2/super.h b/fs/gfs2/super.h index b56413e3e40d..22e0417ed996 100644 --- a/fs/gfs2/super.h +++ b/fs/gfs2/super.h | |||
| @@ -40,6 +40,10 @@ extern int gfs2_make_fs_rw(struct gfs2_sbd *sdp); | |||
| 40 | extern int gfs2_statfs_init(struct gfs2_sbd *sdp); | 40 | extern int gfs2_statfs_init(struct gfs2_sbd *sdp); |
| 41 | extern void gfs2_statfs_change(struct gfs2_sbd *sdp, s64 total, s64 free, | 41 | extern void gfs2_statfs_change(struct gfs2_sbd *sdp, s64 total, s64 free, |
| 42 | s64 dinodes); | 42 | s64 dinodes); |
| 43 | extern void gfs2_statfs_change_in(struct gfs2_statfs_change_host *sc, | ||
| 44 | const void *buf); | ||
| 45 | extern void update_statfs(struct gfs2_sbd *sdp, struct buffer_head *m_bh, | ||
| 46 | struct buffer_head *l_bh); | ||
| 43 | extern int gfs2_statfs_sync(struct gfs2_sbd *sdp); | 47 | extern int gfs2_statfs_sync(struct gfs2_sbd *sdp); |
| 44 | 48 | ||
| 45 | extern int gfs2_freeze_fs(struct gfs2_sbd *sdp); | 49 | extern int gfs2_freeze_fs(struct gfs2_sbd *sdp); |
diff --git a/fs/gfs2/sys.c b/fs/gfs2/sys.c index 23419dc3027b..a7cbfbd340c7 100644 --- a/fs/gfs2/sys.c +++ b/fs/gfs2/sys.c | |||
| @@ -386,16 +386,16 @@ static ssize_t jid_show(struct gfs2_sbd *sdp, char *buf) | |||
| 386 | #define GDLM_ATTR(_name,_mode,_show,_store) \ | 386 | #define GDLM_ATTR(_name,_mode,_show,_store) \ |
| 387 | static struct gfs2_attr gdlm_attr_##_name = __ATTR(_name,_mode,_show,_store) | 387 | static struct gfs2_attr gdlm_attr_##_name = __ATTR(_name,_mode,_show,_store) |
| 388 | 388 | ||
| 389 | GDLM_ATTR(proto_name, 0444, proto_name_show, NULL); | 389 | GDLM_ATTR(proto_name, 0444, proto_name_show, NULL); |
| 390 | GDLM_ATTR(block, 0644, block_show, block_store); | 390 | GDLM_ATTR(block, 0644, block_show, block_store); |
| 391 | GDLM_ATTR(withdraw, 0644, withdraw_show, withdraw_store); | 391 | GDLM_ATTR(withdraw, 0644, withdraw_show, withdraw_store); |
| 392 | GDLM_ATTR(id, 0444, lkid_show, NULL); | 392 | GDLM_ATTR(id, 0444, lkid_show, NULL); |
| 393 | GDLM_ATTR(jid, 0444, jid_show, NULL); | 393 | GDLM_ATTR(jid, 0444, jid_show, NULL); |
| 394 | GDLM_ATTR(first, 0444, lkfirst_show, NULL); | 394 | GDLM_ATTR(first, 0444, lkfirst_show, NULL); |
| 395 | GDLM_ATTR(first_done, 0444, first_done_show, NULL); | 395 | GDLM_ATTR(first_done, 0444, first_done_show, NULL); |
| 396 | GDLM_ATTR(recover, 0200, NULL, recover_store); | 396 | GDLM_ATTR(recover, 0600, NULL, recover_store); |
| 397 | GDLM_ATTR(recover_done, 0444, recover_done_show, NULL); | 397 | GDLM_ATTR(recover_done, 0444, recover_done_show, NULL); |
| 398 | GDLM_ATTR(recover_status, 0444, recover_status_show, NULL); | 398 | GDLM_ATTR(recover_status, 0444, recover_status_show, NULL); |
| 399 | 399 | ||
| 400 | static struct attribute *lock_module_attrs[] = { | 400 | static struct attribute *lock_module_attrs[] = { |
| 401 | &gdlm_attr_proto_name.attr, | 401 | &gdlm_attr_proto_name.attr, |
diff --git a/fs/hugetlbfs/inode.c b/fs/hugetlbfs/inode.c index 941c8425c10b..cb88dac8ccaa 100644 --- a/fs/hugetlbfs/inode.c +++ b/fs/hugetlbfs/inode.c | |||
| @@ -935,26 +935,28 @@ static int can_do_hugetlb_shm(void) | |||
| 935 | return capable(CAP_IPC_LOCK) || in_group_p(sysctl_hugetlb_shm_group); | 935 | return capable(CAP_IPC_LOCK) || in_group_p(sysctl_hugetlb_shm_group); |
| 936 | } | 936 | } |
| 937 | 937 | ||
| 938 | struct file *hugetlb_file_setup(const char *name, size_t size, int acctflag) | 938 | struct file *hugetlb_file_setup(const char *name, size_t size, int acctflag, |
| 939 | struct user_struct **user) | ||
| 939 | { | 940 | { |
| 940 | int error = -ENOMEM; | 941 | int error = -ENOMEM; |
| 941 | int unlock_shm = 0; | ||
| 942 | struct file *file; | 942 | struct file *file; |
| 943 | struct inode *inode; | 943 | struct inode *inode; |
| 944 | struct dentry *dentry, *root; | 944 | struct dentry *dentry, *root; |
| 945 | struct qstr quick_string; | 945 | struct qstr quick_string; |
| 946 | struct user_struct *user = current_user(); | ||
| 947 | 946 | ||
| 947 | *user = NULL; | ||
| 948 | if (!hugetlbfs_vfsmount) | 948 | if (!hugetlbfs_vfsmount) |
| 949 | return ERR_PTR(-ENOENT); | 949 | return ERR_PTR(-ENOENT); |
| 950 | 950 | ||
| 951 | if (!can_do_hugetlb_shm()) { | 951 | if (!can_do_hugetlb_shm()) { |
| 952 | if (user_shm_lock(size, user)) { | 952 | *user = current_user(); |
| 953 | unlock_shm = 1; | 953 | if (user_shm_lock(size, *user)) { |
| 954 | WARN_ONCE(1, | 954 | WARN_ONCE(1, |
| 955 | "Using mlock ulimits for SHM_HUGETLB deprecated\n"); | 955 | "Using mlock ulimits for SHM_HUGETLB deprecated\n"); |
| 956 | } else | 956 | } else { |
| 957 | *user = NULL; | ||
| 957 | return ERR_PTR(-EPERM); | 958 | return ERR_PTR(-EPERM); |
| 959 | } | ||
| 958 | } | 960 | } |
| 959 | 961 | ||
| 960 | root = hugetlbfs_vfsmount->mnt_root; | 962 | root = hugetlbfs_vfsmount->mnt_root; |
| @@ -996,8 +998,10 @@ out_inode: | |||
| 996 | out_dentry: | 998 | out_dentry: |
| 997 | dput(dentry); | 999 | dput(dentry); |
| 998 | out_shm_unlock: | 1000 | out_shm_unlock: |
| 999 | if (unlock_shm) | 1001 | if (*user) { |
| 1000 | user_shm_unlock(size, user); | 1002 | user_shm_unlock(size, *user); |
| 1003 | *user = NULL; | ||
| 1004 | } | ||
| 1001 | return ERR_PTR(error); | 1005 | return ERR_PTR(error); |
| 1002 | } | 1006 | } |
| 1003 | 1007 | ||
diff --git a/fs/inode.c b/fs/inode.c index 901bad1e5f12..ae7b67e48661 100644 --- a/fs/inode.c +++ b/fs/inode.c | |||
| @@ -120,12 +120,11 @@ static void wake_up_inode(struct inode *inode) | |||
| 120 | * These are initializations that need to be done on every inode | 120 | * These are initializations that need to be done on every inode |
| 121 | * allocation as the fields are not initialised by slab allocation. | 121 | * allocation as the fields are not initialised by slab allocation. |
| 122 | */ | 122 | */ |
| 123 | struct inode *inode_init_always(struct super_block *sb, struct inode *inode) | 123 | int inode_init_always(struct super_block *sb, struct inode *inode) |
| 124 | { | 124 | { |
| 125 | static const struct address_space_operations empty_aops; | 125 | static const struct address_space_operations empty_aops; |
| 126 | static struct inode_operations empty_iops; | 126 | static struct inode_operations empty_iops; |
| 127 | static const struct file_operations empty_fops; | 127 | static const struct file_operations empty_fops; |
| 128 | |||
| 129 | struct address_space *const mapping = &inode->i_data; | 128 | struct address_space *const mapping = &inode->i_data; |
| 130 | 129 | ||
| 131 | inode->i_sb = sb; | 130 | inode->i_sb = sb; |
| @@ -152,7 +151,7 @@ struct inode *inode_init_always(struct super_block *sb, struct inode *inode) | |||
| 152 | inode->dirtied_when = 0; | 151 | inode->dirtied_when = 0; |
| 153 | 152 | ||
| 154 | if (security_inode_alloc(inode)) | 153 | if (security_inode_alloc(inode)) |
| 155 | goto out_free_inode; | 154 | goto out; |
| 156 | 155 | ||
| 157 | /* allocate and initialize an i_integrity */ | 156 | /* allocate and initialize an i_integrity */ |
| 158 | if (ima_inode_alloc(inode)) | 157 | if (ima_inode_alloc(inode)) |
| @@ -198,16 +197,12 @@ struct inode *inode_init_always(struct super_block *sb, struct inode *inode) | |||
| 198 | inode->i_fsnotify_mask = 0; | 197 | inode->i_fsnotify_mask = 0; |
| 199 | #endif | 198 | #endif |
| 200 | 199 | ||
| 201 | return inode; | 200 | return 0; |
| 202 | 201 | ||
| 203 | out_free_security: | 202 | out_free_security: |
| 204 | security_inode_free(inode); | 203 | security_inode_free(inode); |
| 205 | out_free_inode: | 204 | out: |
| 206 | if (inode->i_sb->s_op->destroy_inode) | 205 | return -ENOMEM; |
| 207 | inode->i_sb->s_op->destroy_inode(inode); | ||
| 208 | else | ||
| 209 | kmem_cache_free(inode_cachep, (inode)); | ||
| 210 | return NULL; | ||
| 211 | } | 206 | } |
| 212 | EXPORT_SYMBOL(inode_init_always); | 207 | EXPORT_SYMBOL(inode_init_always); |
| 213 | 208 | ||
| @@ -220,12 +215,21 @@ static struct inode *alloc_inode(struct super_block *sb) | |||
| 220 | else | 215 | else |
| 221 | inode = kmem_cache_alloc(inode_cachep, GFP_KERNEL); | 216 | inode = kmem_cache_alloc(inode_cachep, GFP_KERNEL); |
| 222 | 217 | ||
| 223 | if (inode) | 218 | if (!inode) |
| 224 | return inode_init_always(sb, inode); | 219 | return NULL; |
| 225 | return NULL; | 220 | |
| 221 | if (unlikely(inode_init_always(sb, inode))) { | ||
| 222 | if (inode->i_sb->s_op->destroy_inode) | ||
| 223 | inode->i_sb->s_op->destroy_inode(inode); | ||
| 224 | else | ||
| 225 | kmem_cache_free(inode_cachep, inode); | ||
| 226 | return NULL; | ||
| 227 | } | ||
| 228 | |||
| 229 | return inode; | ||
| 226 | } | 230 | } |
| 227 | 231 | ||
| 228 | void destroy_inode(struct inode *inode) | 232 | void __destroy_inode(struct inode *inode) |
| 229 | { | 233 | { |
| 230 | BUG_ON(inode_has_buffers(inode)); | 234 | BUG_ON(inode_has_buffers(inode)); |
| 231 | ima_inode_free(inode); | 235 | ima_inode_free(inode); |
| @@ -237,13 +241,17 @@ void destroy_inode(struct inode *inode) | |||
| 237 | if (inode->i_default_acl && inode->i_default_acl != ACL_NOT_CACHED) | 241 | if (inode->i_default_acl && inode->i_default_acl != ACL_NOT_CACHED) |
| 238 | posix_acl_release(inode->i_default_acl); | 242 | posix_acl_release(inode->i_default_acl); |
| 239 | #endif | 243 | #endif |
| 244 | } | ||
| 245 | EXPORT_SYMBOL(__destroy_inode); | ||
| 246 | |||
| 247 | void destroy_inode(struct inode *inode) | ||
| 248 | { | ||
| 249 | __destroy_inode(inode); | ||
| 240 | if (inode->i_sb->s_op->destroy_inode) | 250 | if (inode->i_sb->s_op->destroy_inode) |
| 241 | inode->i_sb->s_op->destroy_inode(inode); | 251 | inode->i_sb->s_op->destroy_inode(inode); |
| 242 | else | 252 | else |
| 243 | kmem_cache_free(inode_cachep, (inode)); | 253 | kmem_cache_free(inode_cachep, (inode)); |
| 244 | } | 254 | } |
| 245 | EXPORT_SYMBOL(destroy_inode); | ||
| 246 | |||
| 247 | 255 | ||
| 248 | /* | 256 | /* |
| 249 | * These are initializations that only need to be done | 257 | * These are initializations that only need to be done |
diff --git a/fs/jbd/journal.c b/fs/jbd/journal.c index 737f7246a4b5..f96f85092d1c 100644 --- a/fs/jbd/journal.c +++ b/fs/jbd/journal.c | |||
| @@ -287,6 +287,7 @@ int journal_write_metadata_buffer(transaction_t *transaction, | |||
| 287 | struct page *new_page; | 287 | struct page *new_page; |
| 288 | unsigned int new_offset; | 288 | unsigned int new_offset; |
| 289 | struct buffer_head *bh_in = jh2bh(jh_in); | 289 | struct buffer_head *bh_in = jh2bh(jh_in); |
| 290 | journal_t *journal = transaction->t_journal; | ||
| 290 | 291 | ||
| 291 | /* | 292 | /* |
| 292 | * The buffer really shouldn't be locked: only the current committing | 293 | * The buffer really shouldn't be locked: only the current committing |
| @@ -300,6 +301,11 @@ int journal_write_metadata_buffer(transaction_t *transaction, | |||
| 300 | J_ASSERT_BH(bh_in, buffer_jbddirty(bh_in)); | 301 | J_ASSERT_BH(bh_in, buffer_jbddirty(bh_in)); |
| 301 | 302 | ||
| 302 | new_bh = alloc_buffer_head(GFP_NOFS|__GFP_NOFAIL); | 303 | new_bh = alloc_buffer_head(GFP_NOFS|__GFP_NOFAIL); |
| 304 | /* keep subsequent assertions sane */ | ||
| 305 | new_bh->b_state = 0; | ||
| 306 | init_buffer(new_bh, NULL, NULL); | ||
| 307 | atomic_set(&new_bh->b_count, 1); | ||
| 308 | new_jh = journal_add_journal_head(new_bh); /* This sleeps */ | ||
| 303 | 309 | ||
| 304 | /* | 310 | /* |
| 305 | * If a new transaction has already done a buffer copy-out, then | 311 | * If a new transaction has already done a buffer copy-out, then |
| @@ -361,14 +367,6 @@ repeat: | |||
| 361 | kunmap_atomic(mapped_data, KM_USER0); | 367 | kunmap_atomic(mapped_data, KM_USER0); |
| 362 | } | 368 | } |
| 363 | 369 | ||
| 364 | /* keep subsequent assertions sane */ | ||
| 365 | new_bh->b_state = 0; | ||
| 366 | init_buffer(new_bh, NULL, NULL); | ||
| 367 | atomic_set(&new_bh->b_count, 1); | ||
| 368 | jbd_unlock_bh_state(bh_in); | ||
| 369 | |||
| 370 | new_jh = journal_add_journal_head(new_bh); /* This sleeps */ | ||
| 371 | |||
| 372 | set_bh_page(new_bh, new_page, new_offset); | 370 | set_bh_page(new_bh, new_page, new_offset); |
| 373 | new_jh->b_transaction = NULL; | 371 | new_jh->b_transaction = NULL; |
| 374 | new_bh->b_size = jh2bh(jh_in)->b_size; | 372 | new_bh->b_size = jh2bh(jh_in)->b_size; |
| @@ -385,7 +383,11 @@ repeat: | |||
| 385 | * copying is moved to the transaction's shadow queue. | 383 | * copying is moved to the transaction's shadow queue. |
| 386 | */ | 384 | */ |
| 387 | JBUFFER_TRACE(jh_in, "file as BJ_Shadow"); | 385 | JBUFFER_TRACE(jh_in, "file as BJ_Shadow"); |
| 388 | journal_file_buffer(jh_in, transaction, BJ_Shadow); | 386 | spin_lock(&journal->j_list_lock); |
| 387 | __journal_file_buffer(jh_in, transaction, BJ_Shadow); | ||
| 388 | spin_unlock(&journal->j_list_lock); | ||
| 389 | jbd_unlock_bh_state(bh_in); | ||
| 390 | |||
| 389 | JBUFFER_TRACE(new_jh, "file as BJ_IO"); | 391 | JBUFFER_TRACE(new_jh, "file as BJ_IO"); |
| 390 | journal_file_buffer(new_jh, transaction, BJ_IO); | 392 | journal_file_buffer(new_jh, transaction, BJ_IO); |
| 391 | 393 | ||
| @@ -848,6 +850,12 @@ static int journal_reset(journal_t *journal) | |||
| 848 | 850 | ||
| 849 | first = be32_to_cpu(sb->s_first); | 851 | first = be32_to_cpu(sb->s_first); |
| 850 | last = be32_to_cpu(sb->s_maxlen); | 852 | last = be32_to_cpu(sb->s_maxlen); |
| 853 | if (first + JFS_MIN_JOURNAL_BLOCKS > last + 1) { | ||
| 854 | printk(KERN_ERR "JBD: Journal too short (blocks %lu-%lu).\n", | ||
| 855 | first, last); | ||
| 856 | journal_fail_superblock(journal); | ||
| 857 | return -EINVAL; | ||
| 858 | } | ||
| 851 | 859 | ||
| 852 | journal->j_first = first; | 860 | journal->j_first = first; |
| 853 | journal->j_last = last; | 861 | journal->j_last = last; |
diff --git a/fs/jbd/transaction.c b/fs/jbd/transaction.c index 73242ba7c7b1..c03ac11f74be 100644 --- a/fs/jbd/transaction.c +++ b/fs/jbd/transaction.c | |||
| @@ -489,34 +489,15 @@ void journal_unlock_updates (journal_t *journal) | |||
| 489 | wake_up(&journal->j_wait_transaction_locked); | 489 | wake_up(&journal->j_wait_transaction_locked); |
| 490 | } | 490 | } |
| 491 | 491 | ||
| 492 | /* | 492 | static void warn_dirty_buffer(struct buffer_head *bh) |
| 493 | * Report any unexpected dirty buffers which turn up. Normally those | ||
| 494 | * indicate an error, but they can occur if the user is running (say) | ||
| 495 | * tune2fs to modify the live filesystem, so we need the option of | ||
| 496 | * continuing as gracefully as possible. # | ||
| 497 | * | ||
| 498 | * The caller should already hold the journal lock and | ||
| 499 | * j_list_lock spinlock: most callers will need those anyway | ||
| 500 | * in order to probe the buffer's journaling state safely. | ||
| 501 | */ | ||
| 502 | static void jbd_unexpected_dirty_buffer(struct journal_head *jh) | ||
| 503 | { | 493 | { |
| 504 | int jlist; | 494 | char b[BDEVNAME_SIZE]; |
| 505 | |||
| 506 | /* If this buffer is one which might reasonably be dirty | ||
| 507 | * --- ie. data, or not part of this journal --- then | ||
| 508 | * we're OK to leave it alone, but otherwise we need to | ||
| 509 | * move the dirty bit to the journal's own internal | ||
| 510 | * JBDDirty bit. */ | ||
| 511 | jlist = jh->b_jlist; | ||
| 512 | 495 | ||
| 513 | if (jlist == BJ_Metadata || jlist == BJ_Reserved || | 496 | printk(KERN_WARNING |
| 514 | jlist == BJ_Shadow || jlist == BJ_Forget) { | 497 | "JBD: Spotted dirty metadata buffer (dev = %s, blocknr = %llu). " |
| 515 | struct buffer_head *bh = jh2bh(jh); | 498 | "There's a risk of filesystem corruption in case of system " |
| 516 | 499 | "crash.\n", | |
| 517 | if (test_clear_buffer_dirty(bh)) | 500 | bdevname(bh->b_bdev, b), (unsigned long long)bh->b_blocknr); |
| 518 | set_buffer_jbddirty(bh); | ||
| 519 | } | ||
| 520 | } | 501 | } |
| 521 | 502 | ||
| 522 | /* | 503 | /* |
| @@ -583,14 +564,16 @@ repeat: | |||
| 583 | if (jh->b_next_transaction) | 564 | if (jh->b_next_transaction) |
| 584 | J_ASSERT_JH(jh, jh->b_next_transaction == | 565 | J_ASSERT_JH(jh, jh->b_next_transaction == |
| 585 | transaction); | 566 | transaction); |
| 567 | warn_dirty_buffer(bh); | ||
| 586 | } | 568 | } |
| 587 | /* | 569 | /* |
| 588 | * In any case we need to clean the dirty flag and we must | 570 | * In any case we need to clean the dirty flag and we must |
| 589 | * do it under the buffer lock to be sure we don't race | 571 | * do it under the buffer lock to be sure we don't race |
| 590 | * with running write-out. | 572 | * with running write-out. |
| 591 | */ | 573 | */ |
| 592 | JBUFFER_TRACE(jh, "Unexpected dirty buffer"); | 574 | JBUFFER_TRACE(jh, "Journalling dirty buffer"); |
| 593 | jbd_unexpected_dirty_buffer(jh); | 575 | clear_buffer_dirty(bh); |
| 576 | set_buffer_jbddirty(bh); | ||
| 594 | } | 577 | } |
| 595 | 578 | ||
| 596 | unlock_buffer(bh); | 579 | unlock_buffer(bh); |
| @@ -826,6 +809,15 @@ int journal_get_create_access(handle_t *handle, struct buffer_head *bh) | |||
| 826 | J_ASSERT_JH(jh, buffer_locked(jh2bh(jh))); | 809 | J_ASSERT_JH(jh, buffer_locked(jh2bh(jh))); |
| 827 | 810 | ||
| 828 | if (jh->b_transaction == NULL) { | 811 | if (jh->b_transaction == NULL) { |
| 812 | /* | ||
| 813 | * Previous journal_forget() could have left the buffer | ||
| 814 | * with jbddirty bit set because it was being committed. When | ||
| 815 | * the commit finished, we've filed the buffer for | ||
| 816 | * checkpointing and marked it dirty. Now we are reallocating | ||
| 817 | * the buffer so the transaction freeing it must have | ||
| 818 | * committed and so it's safe to clear the dirty bit. | ||
| 819 | */ | ||
| 820 | clear_buffer_dirty(jh2bh(jh)); | ||
| 829 | jh->b_transaction = transaction; | 821 | jh->b_transaction = transaction; |
| 830 | 822 | ||
| 831 | /* first access by this transaction */ | 823 | /* first access by this transaction */ |
| @@ -1782,8 +1774,13 @@ static int __dispose_buffer(struct journal_head *jh, transaction_t *transaction) | |||
| 1782 | 1774 | ||
| 1783 | if (jh->b_cp_transaction) { | 1775 | if (jh->b_cp_transaction) { |
| 1784 | JBUFFER_TRACE(jh, "on running+cp transaction"); | 1776 | JBUFFER_TRACE(jh, "on running+cp transaction"); |
| 1777 | /* | ||
| 1778 | * We don't want to write the buffer anymore, clear the | ||
| 1779 | * bit so that we don't confuse checks in | ||
| 1780 | * __journal_file_buffer | ||
| 1781 | */ | ||
| 1782 | clear_buffer_dirty(bh); | ||
| 1785 | __journal_file_buffer(jh, transaction, BJ_Forget); | 1783 | __journal_file_buffer(jh, transaction, BJ_Forget); |
| 1786 | clear_buffer_jbddirty(bh); | ||
| 1787 | may_free = 0; | 1784 | may_free = 0; |
| 1788 | } else { | 1785 | } else { |
| 1789 | JBUFFER_TRACE(jh, "on running transaction"); | 1786 | JBUFFER_TRACE(jh, "on running transaction"); |
| @@ -2041,12 +2038,17 @@ void __journal_file_buffer(struct journal_head *jh, | |||
| 2041 | if (jh->b_transaction && jh->b_jlist == jlist) | 2038 | if (jh->b_transaction && jh->b_jlist == jlist) |
| 2042 | return; | 2039 | return; |
| 2043 | 2040 | ||
| 2044 | /* The following list of buffer states needs to be consistent | ||
| 2045 | * with __jbd_unexpected_dirty_buffer()'s handling of dirty | ||
| 2046 | * state. */ | ||
| 2047 | |||
| 2048 | if (jlist == BJ_Metadata || jlist == BJ_Reserved || | 2041 | if (jlist == BJ_Metadata || jlist == BJ_Reserved || |
| 2049 | jlist == BJ_Shadow || jlist == BJ_Forget) { | 2042 | jlist == BJ_Shadow || jlist == BJ_Forget) { |
| 2043 | /* | ||
| 2044 | * For metadata buffers, we track dirty bit in buffer_jbddirty | ||
| 2045 | * instead of buffer_dirty. We should not see a dirty bit set | ||
| 2046 | * here because we clear it in do_get_write_access but e.g. | ||
| 2047 | * tune2fs can modify the sb and set the dirty bit at any time | ||
| 2048 | * so we try to gracefully handle that. | ||
| 2049 | */ | ||
| 2050 | if (buffer_dirty(bh)) | ||
| 2051 | warn_dirty_buffer(bh); | ||
| 2050 | if (test_clear_buffer_dirty(bh) || | 2052 | if (test_clear_buffer_dirty(bh) || |
| 2051 | test_clear_buffer_jbddirty(bh)) | 2053 | test_clear_buffer_jbddirty(bh)) |
| 2052 | was_dirty = 1; | 2054 | was_dirty = 1; |
diff --git a/fs/jffs2/file.c b/fs/jffs2/file.c index 5edc2bf20581..23c947539864 100644 --- a/fs/jffs2/file.c +++ b/fs/jffs2/file.c | |||
| @@ -99,7 +99,7 @@ static int jffs2_do_readpage_nolock (struct inode *inode, struct page *pg) | |||
| 99 | kunmap(pg); | 99 | kunmap(pg); |
| 100 | 100 | ||
| 101 | D2(printk(KERN_DEBUG "readpage finished\n")); | 101 | D2(printk(KERN_DEBUG "readpage finished\n")); |
| 102 | return 0; | 102 | return ret; |
| 103 | } | 103 | } |
| 104 | 104 | ||
| 105 | int jffs2_do_readpage_unlock(struct inode *inode, struct page *pg) | 105 | int jffs2_do_readpage_unlock(struct inode *inode, struct page *pg) |
diff --git a/fs/jfs/acl.c b/fs/jfs/acl.c index 91fa3ad6e8c2..a29c7c3e3fb8 100644 --- a/fs/jfs/acl.c +++ b/fs/jfs/acl.c | |||
| @@ -67,10 +67,8 @@ static struct posix_acl *jfs_get_acl(struct inode *inode, int type) | |||
| 67 | acl = posix_acl_from_xattr(value, size); | 67 | acl = posix_acl_from_xattr(value, size); |
| 68 | } | 68 | } |
| 69 | kfree(value); | 69 | kfree(value); |
| 70 | if (!IS_ERR(acl)) { | 70 | if (!IS_ERR(acl)) |
| 71 | set_cached_acl(inode, type, acl); | 71 | set_cached_acl(inode, type, acl); |
| 72 | posix_acl_release(acl); | ||
| 73 | } | ||
| 74 | return acl; | 72 | return acl; |
| 75 | } | 73 | } |
| 76 | 74 | ||
diff --git a/fs/libfs.c b/fs/libfs.c index ddfa89948c3f..dcec3d3ea64f 100644 --- a/fs/libfs.c +++ b/fs/libfs.c | |||
| @@ -217,7 +217,7 @@ int get_sb_pseudo(struct file_system_type *fs_type, char *name, | |||
| 217 | return PTR_ERR(s); | 217 | return PTR_ERR(s); |
| 218 | 218 | ||
| 219 | s->s_flags = MS_NOUSER; | 219 | s->s_flags = MS_NOUSER; |
| 220 | s->s_maxbytes = ~0ULL; | 220 | s->s_maxbytes = MAX_LFS_FILESIZE; |
| 221 | s->s_blocksize = PAGE_SIZE; | 221 | s->s_blocksize = PAGE_SIZE; |
| 222 | s->s_blocksize_bits = PAGE_SHIFT; | 222 | s->s_blocksize_bits = PAGE_SHIFT; |
| 223 | s->s_magic = magic; | 223 | s->s_magic = magic; |
diff --git a/fs/namespace.c b/fs/namespace.c index 277c28a63ead..7230787d18b0 100644 --- a/fs/namespace.c +++ b/fs/namespace.c | |||
| @@ -316,7 +316,8 @@ EXPORT_SYMBOL_GPL(mnt_clone_write); | |||
| 316 | */ | 316 | */ |
| 317 | int mnt_want_write_file(struct file *file) | 317 | int mnt_want_write_file(struct file *file) |
| 318 | { | 318 | { |
| 319 | if (!(file->f_mode & FMODE_WRITE)) | 319 | struct inode *inode = file->f_dentry->d_inode; |
| 320 | if (!(file->f_mode & FMODE_WRITE) || special_file(inode->i_mode)) | ||
| 320 | return mnt_want_write(file->f_path.mnt); | 321 | return mnt_want_write(file->f_path.mnt); |
| 321 | else | 322 | else |
| 322 | return mnt_clone_write(file->f_path.mnt); | 323 | return mnt_clone_write(file->f_path.mnt); |
diff --git a/fs/nfs/client.c b/fs/nfs/client.c index c2d061675d80..8d25ccb2d51d 100644 --- a/fs/nfs/client.c +++ b/fs/nfs/client.c | |||
| @@ -1242,20 +1242,6 @@ error: | |||
| 1242 | return error; | 1242 | return error; |
| 1243 | } | 1243 | } |
| 1244 | 1244 | ||
| 1245 | /* | ||
| 1246 | * Initialize a session. | ||
| 1247 | * Note: save the mount rsize and wsize for create_server negotiation. | ||
| 1248 | */ | ||
| 1249 | static void nfs4_init_session(struct nfs_client *clp, | ||
| 1250 | unsigned int wsize, unsigned int rsize) | ||
| 1251 | { | ||
| 1252 | #if defined(CONFIG_NFS_V4_1) | ||
| 1253 | if (nfs4_has_session(clp)) { | ||
| 1254 | clp->cl_session->fc_attrs.max_rqst_sz = wsize; | ||
| 1255 | clp->cl_session->fc_attrs.max_resp_sz = rsize; | ||
| 1256 | } | ||
| 1257 | #endif /* CONFIG_NFS_V4_1 */ | ||
| 1258 | } | ||
| 1259 | 1245 | ||
| 1260 | /* | 1246 | /* |
| 1261 | * Session has been established, and the client marked ready. | 1247 | * Session has been established, and the client marked ready. |
| @@ -1350,7 +1336,9 @@ struct nfs_server *nfs4_create_server(const struct nfs_parsed_mount_data *data, | |||
| 1350 | BUG_ON(!server->nfs_client->rpc_ops); | 1336 | BUG_ON(!server->nfs_client->rpc_ops); |
| 1351 | BUG_ON(!server->nfs_client->rpc_ops->file_inode_ops); | 1337 | BUG_ON(!server->nfs_client->rpc_ops->file_inode_ops); |
| 1352 | 1338 | ||
| 1353 | nfs4_init_session(server->nfs_client, server->wsize, server->rsize); | 1339 | error = nfs4_init_session(server); |
| 1340 | if (error < 0) | ||
| 1341 | goto error; | ||
| 1354 | 1342 | ||
| 1355 | /* Probe the root fh to retrieve its FSID */ | 1343 | /* Probe the root fh to retrieve its FSID */ |
| 1356 | error = nfs4_path_walk(server, mntfh, data->nfs_server.export_path); | 1344 | error = nfs4_path_walk(server, mntfh, data->nfs_server.export_path); |
diff --git a/fs/nfs/dir.c b/fs/nfs/dir.c index 38d42c29fb92..32062c33c859 100644 --- a/fs/nfs/dir.c +++ b/fs/nfs/dir.c | |||
| @@ -1025,12 +1025,12 @@ static struct dentry *nfs_atomic_lookup(struct inode *dir, struct dentry *dentry | |||
| 1025 | res = NULL; | 1025 | res = NULL; |
| 1026 | goto out; | 1026 | goto out; |
| 1027 | /* This turned out not to be a regular file */ | 1027 | /* This turned out not to be a regular file */ |
| 1028 | case -EISDIR: | ||
| 1029 | case -ENOTDIR: | 1028 | case -ENOTDIR: |
| 1030 | goto no_open; | 1029 | goto no_open; |
| 1031 | case -ELOOP: | 1030 | case -ELOOP: |
| 1032 | if (!(nd->intent.open.flags & O_NOFOLLOW)) | 1031 | if (!(nd->intent.open.flags & O_NOFOLLOW)) |
| 1033 | goto no_open; | 1032 | goto no_open; |
| 1033 | /* case -EISDIR: */ | ||
| 1034 | /* case -EINVAL: */ | 1034 | /* case -EINVAL: */ |
| 1035 | default: | 1035 | default: |
| 1036 | goto out; | 1036 | goto out; |
diff --git a/fs/nfs/direct.c b/fs/nfs/direct.c index 489fc01a3204..e4e089a8f294 100644 --- a/fs/nfs/direct.c +++ b/fs/nfs/direct.c | |||
| @@ -255,7 +255,7 @@ static void nfs_direct_read_release(void *calldata) | |||
| 255 | 255 | ||
| 256 | if (put_dreq(dreq)) | 256 | if (put_dreq(dreq)) |
| 257 | nfs_direct_complete(dreq); | 257 | nfs_direct_complete(dreq); |
| 258 | nfs_readdata_release(calldata); | 258 | nfs_readdata_free(data); |
| 259 | } | 259 | } |
| 260 | 260 | ||
| 261 | static const struct rpc_call_ops nfs_read_direct_ops = { | 261 | static const struct rpc_call_ops nfs_read_direct_ops = { |
| @@ -314,14 +314,14 @@ static ssize_t nfs_direct_read_schedule_segment(struct nfs_direct_req *dreq, | |||
| 314 | data->npages, 1, 0, data->pagevec, NULL); | 314 | data->npages, 1, 0, data->pagevec, NULL); |
| 315 | up_read(¤t->mm->mmap_sem); | 315 | up_read(¤t->mm->mmap_sem); |
| 316 | if (result < 0) { | 316 | if (result < 0) { |
| 317 | nfs_readdata_release(data); | 317 | nfs_readdata_free(data); |
| 318 | break; | 318 | break; |
| 319 | } | 319 | } |
| 320 | if ((unsigned)result < data->npages) { | 320 | if ((unsigned)result < data->npages) { |
| 321 | bytes = result * PAGE_SIZE; | 321 | bytes = result * PAGE_SIZE; |
| 322 | if (bytes <= pgbase) { | 322 | if (bytes <= pgbase) { |
| 323 | nfs_direct_release_pages(data->pagevec, result); | 323 | nfs_direct_release_pages(data->pagevec, result); |
| 324 | nfs_readdata_release(data); | 324 | nfs_readdata_free(data); |
| 325 | break; | 325 | break; |
| 326 | } | 326 | } |
| 327 | bytes -= pgbase; | 327 | bytes -= pgbase; |
| @@ -334,7 +334,7 @@ static ssize_t nfs_direct_read_schedule_segment(struct nfs_direct_req *dreq, | |||
| 334 | data->inode = inode; | 334 | data->inode = inode; |
| 335 | data->cred = msg.rpc_cred; | 335 | data->cred = msg.rpc_cred; |
| 336 | data->args.fh = NFS_FH(inode); | 336 | data->args.fh = NFS_FH(inode); |
| 337 | data->args.context = get_nfs_open_context(ctx); | 337 | data->args.context = ctx; |
| 338 | data->args.offset = pos; | 338 | data->args.offset = pos; |
| 339 | data->args.pgbase = pgbase; | 339 | data->args.pgbase = pgbase; |
| 340 | data->args.pages = data->pagevec; | 340 | data->args.pages = data->pagevec; |
| @@ -441,7 +441,7 @@ static void nfs_direct_free_writedata(struct nfs_direct_req *dreq) | |||
| 441 | struct nfs_write_data *data = list_entry(dreq->rewrite_list.next, struct nfs_write_data, pages); | 441 | struct nfs_write_data *data = list_entry(dreq->rewrite_list.next, struct nfs_write_data, pages); |
| 442 | list_del(&data->pages); | 442 | list_del(&data->pages); |
| 443 | nfs_direct_release_pages(data->pagevec, data->npages); | 443 | nfs_direct_release_pages(data->pagevec, data->npages); |
| 444 | nfs_writedata_release(data); | 444 | nfs_writedata_free(data); |
| 445 | } | 445 | } |
| 446 | } | 446 | } |
| 447 | 447 | ||
| @@ -534,7 +534,7 @@ static void nfs_direct_commit_release(void *calldata) | |||
| 534 | 534 | ||
| 535 | dprintk("NFS: %5u commit returned %d\n", data->task.tk_pid, status); | 535 | dprintk("NFS: %5u commit returned %d\n", data->task.tk_pid, status); |
| 536 | nfs_direct_write_complete(dreq, data->inode); | 536 | nfs_direct_write_complete(dreq, data->inode); |
| 537 | nfs_commitdata_release(calldata); | 537 | nfs_commit_free(data); |
| 538 | } | 538 | } |
| 539 | 539 | ||
| 540 | static const struct rpc_call_ops nfs_commit_direct_ops = { | 540 | static const struct rpc_call_ops nfs_commit_direct_ops = { |
| @@ -570,7 +570,7 @@ static void nfs_direct_commit_schedule(struct nfs_direct_req *dreq) | |||
| 570 | data->args.fh = NFS_FH(data->inode); | 570 | data->args.fh = NFS_FH(data->inode); |
| 571 | data->args.offset = 0; | 571 | data->args.offset = 0; |
| 572 | data->args.count = 0; | 572 | data->args.count = 0; |
| 573 | data->args.context = get_nfs_open_context(dreq->ctx); | 573 | data->args.context = dreq->ctx; |
| 574 | data->res.count = 0; | 574 | data->res.count = 0; |
| 575 | data->res.fattr = &data->fattr; | 575 | data->res.fattr = &data->fattr; |
| 576 | data->res.verf = &data->verf; | 576 | data->res.verf = &data->verf; |
| @@ -734,14 +734,14 @@ static ssize_t nfs_direct_write_schedule_segment(struct nfs_direct_req *dreq, | |||
| 734 | data->npages, 0, 0, data->pagevec, NULL); | 734 | data->npages, 0, 0, data->pagevec, NULL); |
| 735 | up_read(¤t->mm->mmap_sem); | 735 | up_read(¤t->mm->mmap_sem); |
| 736 | if (result < 0) { | 736 | if (result < 0) { |
| 737 | nfs_writedata_release(data); | 737 | nfs_writedata_free(data); |
| 738 | break; | 738 | break; |
| 739 | } | 739 | } |
| 740 | if ((unsigned)result < data->npages) { | 740 | if ((unsigned)result < data->npages) { |
| 741 | bytes = result * PAGE_SIZE; | 741 | bytes = result * PAGE_SIZE; |
| 742 | if (bytes <= pgbase) { | 742 | if (bytes <= pgbase) { |
| 743 | nfs_direct_release_pages(data->pagevec, result); | 743 | nfs_direct_release_pages(data->pagevec, result); |
| 744 | nfs_writedata_release(data); | 744 | nfs_writedata_free(data); |
| 745 | break; | 745 | break; |
| 746 | } | 746 | } |
| 747 | bytes -= pgbase; | 747 | bytes -= pgbase; |
| @@ -756,7 +756,7 @@ static ssize_t nfs_direct_write_schedule_segment(struct nfs_direct_req *dreq, | |||
| 756 | data->inode = inode; | 756 | data->inode = inode; |
| 757 | data->cred = msg.rpc_cred; | 757 | data->cred = msg.rpc_cred; |
| 758 | data->args.fh = NFS_FH(inode); | 758 | data->args.fh = NFS_FH(inode); |
| 759 | data->args.context = get_nfs_open_context(ctx); | 759 | data->args.context = ctx; |
| 760 | data->args.offset = pos; | 760 | data->args.offset = pos; |
| 761 | data->args.pgbase = pgbase; | 761 | data->args.pgbase = pgbase; |
| 762 | data->args.pages = data->pagevec; | 762 | data->args.pages = data->pagevec; |
diff --git a/fs/nfs/nfs4_fs.h b/fs/nfs/nfs4_fs.h index 61bc3a32e1e2..6ea07a3c75d4 100644 --- a/fs/nfs/nfs4_fs.h +++ b/fs/nfs/nfs4_fs.h | |||
| @@ -220,6 +220,7 @@ extern void nfs4_destroy_session(struct nfs4_session *session); | |||
| 220 | extern struct nfs4_session *nfs4_alloc_session(struct nfs_client *clp); | 220 | extern struct nfs4_session *nfs4_alloc_session(struct nfs_client *clp); |
| 221 | extern int nfs4_proc_create_session(struct nfs_client *, int reset); | 221 | extern int nfs4_proc_create_session(struct nfs_client *, int reset); |
| 222 | extern int nfs4_proc_destroy_session(struct nfs4_session *); | 222 | extern int nfs4_proc_destroy_session(struct nfs4_session *); |
| 223 | extern int nfs4_init_session(struct nfs_server *server); | ||
| 223 | #else /* CONFIG_NFS_v4_1 */ | 224 | #else /* CONFIG_NFS_v4_1 */ |
| 224 | static inline int nfs4_setup_sequence(struct nfs_client *clp, | 225 | static inline int nfs4_setup_sequence(struct nfs_client *clp, |
| 225 | struct nfs4_sequence_args *args, struct nfs4_sequence_res *res, | 226 | struct nfs4_sequence_args *args, struct nfs4_sequence_res *res, |
| @@ -227,6 +228,11 @@ static inline int nfs4_setup_sequence(struct nfs_client *clp, | |||
| 227 | { | 228 | { |
| 228 | return 0; | 229 | return 0; |
| 229 | } | 230 | } |
| 231 | |||
| 232 | static inline int nfs4_init_session(struct nfs_server *server) | ||
| 233 | { | ||
| 234 | return 0; | ||
| 235 | } | ||
| 230 | #endif /* CONFIG_NFS_V4_1 */ | 236 | #endif /* CONFIG_NFS_V4_1 */ |
| 231 | 237 | ||
| 232 | extern struct nfs4_state_maintenance_ops *nfs4_state_renewal_ops[]; | 238 | extern struct nfs4_state_maintenance_ops *nfs4_state_renewal_ops[]; |
diff --git a/fs/nfs/nfs4proc.c b/fs/nfs/nfs4proc.c index ff0c080db59b..6917311f201c 100644 --- a/fs/nfs/nfs4proc.c +++ b/fs/nfs/nfs4proc.c | |||
| @@ -2040,15 +2040,9 @@ static int _nfs4_lookup_root(struct nfs_server *server, struct nfs_fh *fhandle, | |||
| 2040 | .rpc_argp = &args, | 2040 | .rpc_argp = &args, |
| 2041 | .rpc_resp = &res, | 2041 | .rpc_resp = &res, |
| 2042 | }; | 2042 | }; |
| 2043 | int status; | ||
| 2044 | 2043 | ||
| 2045 | nfs_fattr_init(info->fattr); | 2044 | nfs_fattr_init(info->fattr); |
| 2046 | status = nfs4_recover_expired_lease(server); | 2045 | return nfs4_call_sync(server, &msg, &args, &res, 0); |
| 2047 | if (!status) | ||
| 2048 | status = nfs4_check_client_ready(server->nfs_client); | ||
| 2049 | if (!status) | ||
| 2050 | status = nfs4_call_sync(server, &msg, &args, &res, 0); | ||
| 2051 | return status; | ||
| 2052 | } | 2046 | } |
| 2053 | 2047 | ||
| 2054 | static int nfs4_lookup_root(struct nfs_server *server, struct nfs_fh *fhandle, | 2048 | static int nfs4_lookup_root(struct nfs_server *server, struct nfs_fh *fhandle, |
| @@ -4099,15 +4093,23 @@ nfs4_proc_lock(struct file *filp, int cmd, struct file_lock *request) | |||
| 4099 | if (request->fl_start < 0 || request->fl_end < 0) | 4093 | if (request->fl_start < 0 || request->fl_end < 0) |
| 4100 | return -EINVAL; | 4094 | return -EINVAL; |
| 4101 | 4095 | ||
| 4102 | if (IS_GETLK(cmd)) | 4096 | if (IS_GETLK(cmd)) { |
| 4103 | return nfs4_proc_getlk(state, F_GETLK, request); | 4097 | if (state != NULL) |
| 4098 | return nfs4_proc_getlk(state, F_GETLK, request); | ||
| 4099 | return 0; | ||
| 4100 | } | ||
| 4104 | 4101 | ||
| 4105 | if (!(IS_SETLK(cmd) || IS_SETLKW(cmd))) | 4102 | if (!(IS_SETLK(cmd) || IS_SETLKW(cmd))) |
| 4106 | return -EINVAL; | 4103 | return -EINVAL; |
| 4107 | 4104 | ||
| 4108 | if (request->fl_type == F_UNLCK) | 4105 | if (request->fl_type == F_UNLCK) { |
| 4109 | return nfs4_proc_unlck(state, cmd, request); | 4106 | if (state != NULL) |
| 4107 | return nfs4_proc_unlck(state, cmd, request); | ||
| 4108 | return 0; | ||
| 4109 | } | ||
| 4110 | 4110 | ||
| 4111 | if (state == NULL) | ||
| 4112 | return -ENOLCK; | ||
| 4111 | do { | 4113 | do { |
| 4112 | status = nfs4_proc_setlk(state, cmd, request); | 4114 | status = nfs4_proc_setlk(state, cmd, request); |
| 4113 | if ((status != -EAGAIN) || IS_SETLK(cmd)) | 4115 | if ((status != -EAGAIN) || IS_SETLK(cmd)) |
| @@ -4793,6 +4795,22 @@ int nfs4_proc_destroy_session(struct nfs4_session *session) | |||
| 4793 | return status; | 4795 | return status; |
| 4794 | } | 4796 | } |
| 4795 | 4797 | ||
| 4798 | int nfs4_init_session(struct nfs_server *server) | ||
| 4799 | { | ||
| 4800 | struct nfs_client *clp = server->nfs_client; | ||
| 4801 | int ret; | ||
| 4802 | |||
| 4803 | if (!nfs4_has_session(clp)) | ||
| 4804 | return 0; | ||
| 4805 | |||
| 4806 | clp->cl_session->fc_attrs.max_rqst_sz = server->wsize; | ||
| 4807 | clp->cl_session->fc_attrs.max_resp_sz = server->rsize; | ||
| 4808 | ret = nfs4_recover_expired_lease(server); | ||
| 4809 | if (!ret) | ||
| 4810 | ret = nfs4_check_client_ready(clp); | ||
| 4811 | return ret; | ||
| 4812 | } | ||
| 4813 | |||
| 4796 | /* | 4814 | /* |
| 4797 | * Renew the cl_session lease. | 4815 | * Renew the cl_session lease. |
| 4798 | */ | 4816 | */ |
diff --git a/fs/nfs/nfs4state.c b/fs/nfs/nfs4state.c index b73c5a728655..1434080aefeb 100644 --- a/fs/nfs/nfs4state.c +++ b/fs/nfs/nfs4state.c | |||
| @@ -553,6 +553,7 @@ static struct nfs4_lock_state *nfs4_alloc_lock_state(struct nfs4_state *state, f | |||
| 553 | INIT_LIST_HEAD(&lsp->ls_sequence.list); | 553 | INIT_LIST_HEAD(&lsp->ls_sequence.list); |
| 554 | lsp->ls_seqid.sequence = &lsp->ls_sequence; | 554 | lsp->ls_seqid.sequence = &lsp->ls_sequence; |
| 555 | atomic_set(&lsp->ls_count, 1); | 555 | atomic_set(&lsp->ls_count, 1); |
| 556 | lsp->ls_state = state; | ||
| 556 | lsp->ls_owner = fl_owner; | 557 | lsp->ls_owner = fl_owner; |
| 557 | spin_lock(&clp->cl_lock); | 558 | spin_lock(&clp->cl_lock); |
| 558 | nfs_alloc_unique_id(&clp->cl_lockowner_id, &lsp->ls_id, 1, 64); | 559 | nfs_alloc_unique_id(&clp->cl_lockowner_id, &lsp->ls_id, 1, 64); |
| @@ -587,7 +588,6 @@ static struct nfs4_lock_state *nfs4_get_lock_state(struct nfs4_state *state, fl_ | |||
| 587 | if (lsp != NULL) | 588 | if (lsp != NULL) |
| 588 | break; | 589 | break; |
| 589 | if (new != NULL) { | 590 | if (new != NULL) { |
| 590 | new->ls_state = state; | ||
| 591 | list_add(&new->ls_locks, &state->lock_states); | 591 | list_add(&new->ls_locks, &state->lock_states); |
| 592 | set_bit(LK_STATE_IN_USE, &state->flags); | 592 | set_bit(LK_STATE_IN_USE, &state->flags); |
| 593 | lsp = new; | 593 | lsp = new; |
| @@ -1250,8 +1250,8 @@ static void nfs4_state_manager(struct nfs_client *clp) | |||
| 1250 | continue; | 1250 | continue; |
| 1251 | } | 1251 | } |
| 1252 | /* Initialize or reset the session */ | 1252 | /* Initialize or reset the session */ |
| 1253 | if (nfs4_has_session(clp) && | 1253 | if (test_and_clear_bit(NFS4CLNT_SESSION_SETUP, &clp->cl_state) |
| 1254 | test_and_clear_bit(NFS4CLNT_SESSION_SETUP, &clp->cl_state)) { | 1254 | && nfs4_has_session(clp)) { |
| 1255 | if (clp->cl_cons_state == NFS_CS_SESSION_INITING) | 1255 | if (clp->cl_cons_state == NFS_CS_SESSION_INITING) |
| 1256 | status = nfs4_initialize_session(clp); | 1256 | status = nfs4_initialize_session(clp); |
| 1257 | else | 1257 | else |
diff --git a/fs/nfs/read.c b/fs/nfs/read.c index 73ea5e8d66ce..12c9e66d3f1d 100644 --- a/fs/nfs/read.c +++ b/fs/nfs/read.c | |||
| @@ -60,17 +60,15 @@ struct nfs_read_data *nfs_readdata_alloc(unsigned int pagecount) | |||
| 60 | return p; | 60 | return p; |
| 61 | } | 61 | } |
| 62 | 62 | ||
| 63 | static void nfs_readdata_free(struct nfs_read_data *p) | 63 | void nfs_readdata_free(struct nfs_read_data *p) |
| 64 | { | 64 | { |
| 65 | if (p && (p->pagevec != &p->page_array[0])) | 65 | if (p && (p->pagevec != &p->page_array[0])) |
| 66 | kfree(p->pagevec); | 66 | kfree(p->pagevec); |
| 67 | mempool_free(p, nfs_rdata_mempool); | 67 | mempool_free(p, nfs_rdata_mempool); |
| 68 | } | 68 | } |
| 69 | 69 | ||
| 70 | void nfs_readdata_release(void *data) | 70 | static void nfs_readdata_release(struct nfs_read_data *rdata) |
| 71 | { | 71 | { |
| 72 | struct nfs_read_data *rdata = data; | ||
| 73 | |||
| 74 | put_nfs_open_context(rdata->args.context); | 72 | put_nfs_open_context(rdata->args.context); |
| 75 | nfs_readdata_free(rdata); | 73 | nfs_readdata_free(rdata); |
| 76 | } | 74 | } |
diff --git a/fs/nfs/write.c b/fs/nfs/write.c index 0a0a2ff767c3..a34fae21fe10 100644 --- a/fs/nfs/write.c +++ b/fs/nfs/write.c | |||
| @@ -87,17 +87,15 @@ struct nfs_write_data *nfs_writedata_alloc(unsigned int pagecount) | |||
| 87 | return p; | 87 | return p; |
| 88 | } | 88 | } |
| 89 | 89 | ||
| 90 | static void nfs_writedata_free(struct nfs_write_data *p) | 90 | void nfs_writedata_free(struct nfs_write_data *p) |
| 91 | { | 91 | { |
| 92 | if (p && (p->pagevec != &p->page_array[0])) | 92 | if (p && (p->pagevec != &p->page_array[0])) |
| 93 | kfree(p->pagevec); | 93 | kfree(p->pagevec); |
| 94 | mempool_free(p, nfs_wdata_mempool); | 94 | mempool_free(p, nfs_wdata_mempool); |
| 95 | } | 95 | } |
| 96 | 96 | ||
| 97 | void nfs_writedata_release(void *data) | 97 | static void nfs_writedata_release(struct nfs_write_data *wdata) |
| 98 | { | 98 | { |
| 99 | struct nfs_write_data *wdata = data; | ||
| 100 | |||
| 101 | put_nfs_open_context(wdata->args.context); | 99 | put_nfs_open_context(wdata->args.context); |
| 102 | nfs_writedata_free(wdata); | 100 | nfs_writedata_free(wdata); |
| 103 | } | 101 | } |
diff --git a/fs/nilfs2/Kconfig b/fs/nilfs2/Kconfig new file mode 100644 index 000000000000..72da095d4009 --- /dev/null +++ b/fs/nilfs2/Kconfig | |||
| @@ -0,0 +1,25 @@ | |||
| 1 | config NILFS2_FS | ||
| 2 | tristate "NILFS2 file system support (EXPERIMENTAL)" | ||
| 3 | depends on BLOCK && EXPERIMENTAL | ||
| 4 | select CRC32 | ||
| 5 | help | ||
| 6 | NILFS2 is a log-structured file system (LFS) supporting continuous | ||
| 7 | snapshotting. In addition to versioning capability of the entire | ||
| 8 | file system, users can even restore files mistakenly overwritten or | ||
| 9 | destroyed just a few seconds ago. Since this file system can keep | ||
| 10 | consistency like conventional LFS, it achieves quick recovery after | ||
| 11 | system crashes. | ||
| 12 | |||
| 13 | NILFS2 creates a number of checkpoints every few seconds or per | ||
| 14 | synchronous write basis (unless there is no change). Users can | ||
| 15 | select significant versions among continuously created checkpoints, | ||
| 16 | and can change them into snapshots which will be preserved for long | ||
| 17 | periods until they are changed back to checkpoints. Each | ||
| 18 | snapshot is mountable as a read-only file system concurrently with | ||
| 19 | its writable mount, and this feature is convenient for online backup. | ||
| 20 | |||
| 21 | Some features including atime, extended attributes, and POSIX ACLs, | ||
| 22 | are not supported yet. | ||
| 23 | |||
| 24 | To compile this file system support as a module, choose M here: the | ||
| 25 | module will be called nilfs2. If unsure, say N. | ||
diff --git a/fs/nilfs2/mdt.c b/fs/nilfs2/mdt.c index 3d3ddb3f5177..2dfd47714ae5 100644 --- a/fs/nilfs2/mdt.c +++ b/fs/nilfs2/mdt.c | |||
| @@ -412,8 +412,10 @@ nilfs_mdt_write_page(struct page *page, struct writeback_control *wbc) | |||
| 412 | return 0; /* Do not request flush for shadow page cache */ | 412 | return 0; /* Do not request flush for shadow page cache */ |
| 413 | if (!sb) { | 413 | if (!sb) { |
| 414 | writer = nilfs_get_writer(NILFS_MDT(inode)->mi_nilfs); | 414 | writer = nilfs_get_writer(NILFS_MDT(inode)->mi_nilfs); |
| 415 | if (!writer) | 415 | if (!writer) { |
| 416 | nilfs_put_writer(NILFS_MDT(inode)->mi_nilfs); | ||
| 416 | return -EROFS; | 417 | return -EROFS; |
| 418 | } | ||
| 417 | sb = writer->s_super; | 419 | sb = writer->s_super; |
| 418 | } | 420 | } |
| 419 | 421 | ||
diff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c index 8b5e4778cf28..51ff3d0a4ee2 100644 --- a/fs/nilfs2/segment.c +++ b/fs/nilfs2/segment.c | |||
| @@ -1859,12 +1859,26 @@ static void nilfs_end_page_io(struct page *page, int err) | |||
| 1859 | if (!page) | 1859 | if (!page) |
| 1860 | return; | 1860 | return; |
| 1861 | 1861 | ||
| 1862 | if (buffer_nilfs_node(page_buffers(page)) && !PageWriteback(page)) | 1862 | if (buffer_nilfs_node(page_buffers(page)) && !PageWriteback(page)) { |
| 1863 | /* | 1863 | /* |
| 1864 | * For b-tree node pages, this function may be called twice | 1864 | * For b-tree node pages, this function may be called twice |
| 1865 | * or more because they might be split in a segment. | 1865 | * or more because they might be split in a segment. |
| 1866 | */ | 1866 | */ |
| 1867 | if (PageDirty(page)) { | ||
| 1868 | /* | ||
| 1869 | * For pages holding split b-tree node buffers, dirty | ||
| 1870 | * flag on the buffers may be cleared discretely. | ||
| 1871 | * In that case, the page is once redirtied for | ||
| 1872 | * remaining buffers, and it must be cancelled if | ||
| 1873 | * all the buffers get cleaned later. | ||
| 1874 | */ | ||
| 1875 | lock_page(page); | ||
| 1876 | if (nilfs_page_buffers_clean(page)) | ||
| 1877 | __nilfs_clear_page_dirty(page); | ||
| 1878 | unlock_page(page); | ||
| 1879 | } | ||
| 1867 | return; | 1880 | return; |
| 1881 | } | ||
| 1868 | 1882 | ||
| 1869 | __nilfs_end_page_io(page, err); | 1883 | __nilfs_end_page_io(page, err); |
| 1870 | } | 1884 | } |
diff --git a/fs/nilfs2/super.c b/fs/nilfs2/super.c index 8e2ec43b18f4..151964f0de4c 100644 --- a/fs/nilfs2/super.c +++ b/fs/nilfs2/super.c | |||
| @@ -416,8 +416,10 @@ int nilfs_attach_checkpoint(struct nilfs_sb_info *sbi, __u64 cno) | |||
| 416 | if (unlikely(err)) | 416 | if (unlikely(err)) |
| 417 | goto failed; | 417 | goto failed; |
| 418 | 418 | ||
| 419 | down_read(&nilfs->ns_segctor_sem); | ||
| 419 | err = nilfs_cpfile_get_checkpoint(nilfs->ns_cpfile, cno, 0, &raw_cp, | 420 | err = nilfs_cpfile_get_checkpoint(nilfs->ns_cpfile, cno, 0, &raw_cp, |
| 420 | &bh_cp); | 421 | &bh_cp); |
| 422 | up_read(&nilfs->ns_segctor_sem); | ||
| 421 | if (unlikely(err)) { | 423 | if (unlikely(err)) { |
| 422 | if (err == -ENOENT || err == -EINVAL) { | 424 | if (err == -ENOENT || err == -EINVAL) { |
| 423 | printk(KERN_ERR | 425 | printk(KERN_ERR |
diff --git a/fs/nilfs2/the_nilfs.h b/fs/nilfs2/the_nilfs.h index e8adbffc626f..1b9caafb8662 100644 --- a/fs/nilfs2/the_nilfs.h +++ b/fs/nilfs2/the_nilfs.h | |||
| @@ -253,7 +253,7 @@ nilfs_detach_writer(struct the_nilfs *nilfs, struct nilfs_sb_info *sbi) | |||
| 253 | 253 | ||
| 254 | static inline void nilfs_put_sbinfo(struct nilfs_sb_info *sbi) | 254 | static inline void nilfs_put_sbinfo(struct nilfs_sb_info *sbi) |
| 255 | { | 255 | { |
| 256 | if (!atomic_dec_and_test(&sbi->s_count)) | 256 | if (atomic_dec_and_test(&sbi->s_count)) |
| 257 | kfree(sbi); | 257 | kfree(sbi); |
| 258 | } | 258 | } |
| 259 | 259 | ||
diff --git a/fs/notify/Kconfig b/fs/notify/Kconfig index 31dac7e3b0f1..dffbb0911d02 100644 --- a/fs/notify/Kconfig +++ b/fs/notify/Kconfig | |||
| @@ -1,15 +1,5 @@ | |||
| 1 | config FSNOTIFY | 1 | config FSNOTIFY |
| 2 | bool "Filesystem notification backend" | 2 | def_bool n |
| 3 | default y | ||
| 4 | ---help--- | ||
| 5 | fsnotify is a backend for filesystem notification. fsnotify does | ||
| 6 | not provide any userspace interface but does provide the basis | ||
| 7 | needed for other notification schemes such as dnotify, inotify, | ||
| 8 | and fanotify. | ||
| 9 | |||
| 10 | Say Y here to enable fsnotify suport. | ||
| 11 | |||
| 12 | If unsure, say Y. | ||
| 13 | 3 | ||
| 14 | source "fs/notify/dnotify/Kconfig" | 4 | source "fs/notify/dnotify/Kconfig" |
| 15 | source "fs/notify/inotify/Kconfig" | 5 | source "fs/notify/inotify/Kconfig" |
diff --git a/fs/notify/dnotify/Kconfig b/fs/notify/dnotify/Kconfig index 904ff8d5405a..f9c1ca139d8f 100644 --- a/fs/notify/dnotify/Kconfig +++ b/fs/notify/dnotify/Kconfig | |||
| @@ -1,6 +1,6 @@ | |||
| 1 | config DNOTIFY | 1 | config DNOTIFY |
| 2 | bool "Dnotify support" | 2 | bool "Dnotify support" |
| 3 | depends on FSNOTIFY | 3 | select FSNOTIFY |
| 4 | default y | 4 | default y |
| 5 | help | 5 | help |
| 6 | Dnotify is a directory-based per-fd file change notification system | 6 | Dnotify is a directory-based per-fd file change notification system |
diff --git a/fs/notify/fsnotify.c b/fs/notify/fsnotify.c index ec2f7bd76818..037e878e03fc 100644 --- a/fs/notify/fsnotify.c +++ b/fs/notify/fsnotify.c | |||
| @@ -159,7 +159,9 @@ void fsnotify(struct inode *to_tell, __u32 mask, void *data, int data_is, const | |||
| 159 | if (!group->ops->should_send_event(group, to_tell, mask)) | 159 | if (!group->ops->should_send_event(group, to_tell, mask)) |
| 160 | continue; | 160 | continue; |
| 161 | if (!event) { | 161 | if (!event) { |
| 162 | event = fsnotify_create_event(to_tell, mask, data, data_is, file_name, cookie); | 162 | event = fsnotify_create_event(to_tell, mask, data, |
| 163 | data_is, file_name, cookie, | ||
| 164 | GFP_KERNEL); | ||
| 163 | /* shit, we OOM'd and now we can't tell, maybe | 165 | /* shit, we OOM'd and now we can't tell, maybe |
| 164 | * someday someone else will want to do something | 166 | * someday someone else will want to do something |
| 165 | * here */ | 167 | * here */ |
diff --git a/fs/notify/inotify/Kconfig b/fs/notify/inotify/Kconfig index 5356884289a1..3e56dbffe729 100644 --- a/fs/notify/inotify/Kconfig +++ b/fs/notify/inotify/Kconfig | |||
| @@ -15,7 +15,7 @@ config INOTIFY | |||
| 15 | 15 | ||
| 16 | config INOTIFY_USER | 16 | config INOTIFY_USER |
| 17 | bool "Inotify support for userspace" | 17 | bool "Inotify support for userspace" |
| 18 | depends on FSNOTIFY | 18 | select FSNOTIFY |
| 19 | default y | 19 | default y |
| 20 | ---help--- | 20 | ---help--- |
| 21 | Say Y here to enable inotify support for userspace, including the | 21 | Say Y here to enable inotify support for userspace, including the |
diff --git a/fs/notify/inotify/inotify_fsnotify.c b/fs/notify/inotify/inotify_fsnotify.c index 47cd258fd24d..c9ee67b442e1 100644 --- a/fs/notify/inotify/inotify_fsnotify.c +++ b/fs/notify/inotify/inotify_fsnotify.c | |||
| @@ -62,13 +62,14 @@ static int inotify_handle_event(struct fsnotify_group *group, struct fsnotify_ev | |||
| 62 | event_priv->wd = wd; | 62 | event_priv->wd = wd; |
| 63 | 63 | ||
| 64 | ret = fsnotify_add_notify_event(group, event, fsn_event_priv); | 64 | ret = fsnotify_add_notify_event(group, event, fsn_event_priv); |
| 65 | /* EEXIST is not an error */ | 65 | if (ret) { |
| 66 | if (ret == -EEXIST) | ||
| 67 | ret = 0; | ||
| 68 | |||
| 69 | /* did event_priv get attached? */ | ||
| 70 | if (list_empty(&fsn_event_priv->event_list)) | ||
| 71 | inotify_free_event_priv(fsn_event_priv); | 66 | inotify_free_event_priv(fsn_event_priv); |
| 67 | /* EEXIST says we tail matched, EOVERFLOW isn't something | ||
| 68 | * to report up the stack. */ | ||
| 69 | if ((ret == -EEXIST) || | ||
| 70 | (ret == -EOVERFLOW)) | ||
| 71 | ret = 0; | ||
| 72 | } | ||
| 72 | 73 | ||
| 73 | /* | 74 | /* |
| 74 | * If we hold the entry until after the event is on the queue | 75 | * If we hold the entry until after the event is on the queue |
| @@ -104,16 +105,45 @@ static bool inotify_should_send_event(struct fsnotify_group *group, struct inode | |||
| 104 | return send; | 105 | return send; |
| 105 | } | 106 | } |
| 106 | 107 | ||
| 108 | /* | ||
| 109 | * This is NEVER supposed to be called. Inotify marks should either have been | ||
| 110 | * removed from the idr when the watch was removed or in the | ||
| 111 | * fsnotify_destroy_mark_by_group() call when the inotify instance was being | ||
| 112 | * torn down. This is only called if the idr is about to be freed but there | ||
| 113 | * are still marks in it. | ||
| 114 | */ | ||
| 107 | static int idr_callback(int id, void *p, void *data) | 115 | static int idr_callback(int id, void *p, void *data) |
| 108 | { | 116 | { |
| 109 | BUG(); | 117 | struct fsnotify_mark_entry *entry; |
| 118 | struct inotify_inode_mark_entry *ientry; | ||
| 119 | static bool warned = false; | ||
| 120 | |||
| 121 | if (warned) | ||
| 122 | return 0; | ||
| 123 | |||
| 124 | warned = false; | ||
| 125 | entry = p; | ||
| 126 | ientry = container_of(entry, struct inotify_inode_mark_entry, fsn_entry); | ||
| 127 | |||
| 128 | WARN(1, "inotify closing but id=%d for entry=%p in group=%p still in " | ||
| 129 | "idr. Probably leaking memory\n", id, p, data); | ||
| 130 | |||
| 131 | /* | ||
| 132 | * I'm taking the liberty of assuming that the mark in question is a | ||
| 133 | * valid address and I'm dereferencing it. This might help to figure | ||
| 134 | * out why we got here and the panic is no worse than the original | ||
| 135 | * BUG() that was here. | ||
| 136 | */ | ||
| 137 | if (entry) | ||
| 138 | printk(KERN_WARNING "entry->group=%p inode=%p wd=%d\n", | ||
| 139 | entry->group, entry->inode, ientry->wd); | ||
| 110 | return 0; | 140 | return 0; |
| 111 | } | 141 | } |
| 112 | 142 | ||
| 113 | static void inotify_free_group_priv(struct fsnotify_group *group) | 143 | static void inotify_free_group_priv(struct fsnotify_group *group) |
| 114 | { | 144 | { |
| 115 | /* ideally the idr is empty and we won't hit the BUG in teh callback */ | 145 | /* ideally the idr is empty and we won't hit the BUG in teh callback */ |
| 116 | idr_for_each(&group->inotify_data.idr, idr_callback, NULL); | 146 | idr_for_each(&group->inotify_data.idr, idr_callback, group); |
| 117 | idr_remove_all(&group->inotify_data.idr); | 147 | idr_remove_all(&group->inotify_data.idr); |
| 118 | idr_destroy(&group->inotify_data.idr); | 148 | idr_destroy(&group->inotify_data.idr); |
| 119 | } | 149 | } |
diff --git a/fs/notify/inotify/inotify_user.c b/fs/notify/inotify/inotify_user.c index ff27a2965844..0e781bc88d1e 100644 --- a/fs/notify/inotify/inotify_user.c +++ b/fs/notify/inotify/inotify_user.c | |||
| @@ -47,9 +47,6 @@ | |||
| 47 | 47 | ||
| 48 | static struct vfsmount *inotify_mnt __read_mostly; | 48 | static struct vfsmount *inotify_mnt __read_mostly; |
| 49 | 49 | ||
| 50 | /* this just sits here and wastes global memory. used to just pad userspace messages with zeros */ | ||
| 51 | static struct inotify_event nul_inotify_event; | ||
| 52 | |||
| 53 | /* these are configurable via /proc/sys/fs/inotify/ */ | 50 | /* these are configurable via /proc/sys/fs/inotify/ */ |
| 54 | static int inotify_max_user_instances __read_mostly; | 51 | static int inotify_max_user_instances __read_mostly; |
| 55 | static int inotify_max_queued_events __read_mostly; | 52 | static int inotify_max_queued_events __read_mostly; |
| @@ -57,7 +54,6 @@ int inotify_max_user_watches __read_mostly; | |||
| 57 | 54 | ||
| 58 | static struct kmem_cache *inotify_inode_mark_cachep __read_mostly; | 55 | static struct kmem_cache *inotify_inode_mark_cachep __read_mostly; |
| 59 | struct kmem_cache *event_priv_cachep __read_mostly; | 56 | struct kmem_cache *event_priv_cachep __read_mostly; |
| 60 | static struct fsnotify_event *inotify_ignored_event; | ||
| 61 | 57 | ||
| 62 | /* | 58 | /* |
| 63 | * When inotify registers a new group it increments this and uses that | 59 | * When inotify registers a new group it increments this and uses that |
| @@ -200,8 +196,10 @@ static ssize_t copy_event_to_user(struct fsnotify_group *group, | |||
| 200 | inotify_free_event_priv(fsn_priv); | 196 | inotify_free_event_priv(fsn_priv); |
| 201 | } | 197 | } |
| 202 | 198 | ||
| 203 | /* round up event->name_len so it is a multiple of event_size */ | 199 | /* round up event->name_len so it is a multiple of event_size |
| 204 | name_len = roundup(event->name_len, event_size); | 200 | * plus an extra byte for the terminating '\0'. |
| 201 | */ | ||
| 202 | name_len = roundup(event->name_len + 1, event_size); | ||
| 205 | inotify_event.len = name_len; | 203 | inotify_event.len = name_len; |
| 206 | 204 | ||
| 207 | inotify_event.mask = inotify_mask_to_arg(event->mask); | 205 | inotify_event.mask = inotify_mask_to_arg(event->mask); |
| @@ -225,8 +223,8 @@ static ssize_t copy_event_to_user(struct fsnotify_group *group, | |||
| 225 | return -EFAULT; | 223 | return -EFAULT; |
| 226 | buf += event->name_len; | 224 | buf += event->name_len; |
| 227 | 225 | ||
| 228 | /* fill userspace with 0's from nul_inotify_event */ | 226 | /* fill userspace with 0's */ |
| 229 | if (copy_to_user(buf, &nul_inotify_event, len_to_zero)) | 227 | if (clear_user(buf, len_to_zero)) |
| 230 | return -EFAULT; | 228 | return -EFAULT; |
| 231 | buf += len_to_zero; | 229 | buf += len_to_zero; |
| 232 | event_size += name_len; | 230 | event_size += name_len; |
| @@ -366,20 +364,71 @@ static int inotify_find_inode(const char __user *dirname, struct path *path, uns | |||
| 366 | } | 364 | } |
| 367 | 365 | ||
| 368 | /* | 366 | /* |
| 369 | * Send IN_IGNORED for this wd, remove this wd from the idr, and drop the | 367 | * Remove the mark from the idr (if present) and drop the reference |
| 370 | * internal reference help on the mark because it is in the idr. | 368 | * on the mark because it was in the idr. |
| 369 | */ | ||
| 370 | static void inotify_remove_from_idr(struct fsnotify_group *group, | ||
| 371 | struct inotify_inode_mark_entry *ientry) | ||
| 372 | { | ||
| 373 | struct idr *idr; | ||
| 374 | struct fsnotify_mark_entry *entry; | ||
| 375 | struct inotify_inode_mark_entry *found_ientry; | ||
| 376 | int wd; | ||
| 377 | |||
| 378 | spin_lock(&group->inotify_data.idr_lock); | ||
| 379 | idr = &group->inotify_data.idr; | ||
| 380 | wd = ientry->wd; | ||
| 381 | |||
| 382 | if (wd == -1) | ||
| 383 | goto out; | ||
| 384 | |||
| 385 | entry = idr_find(&group->inotify_data.idr, wd); | ||
| 386 | if (unlikely(!entry)) | ||
| 387 | goto out; | ||
| 388 | |||
| 389 | found_ientry = container_of(entry, struct inotify_inode_mark_entry, fsn_entry); | ||
| 390 | if (unlikely(found_ientry != ientry)) { | ||
| 391 | /* We found an entry in the idr with the right wd, but it's | ||
| 392 | * not the entry we were told to remove. eparis seriously | ||
| 393 | * fucked up somewhere. */ | ||
| 394 | WARN_ON(1); | ||
| 395 | ientry->wd = -1; | ||
| 396 | goto out; | ||
| 397 | } | ||
| 398 | |||
| 399 | /* One ref for being in the idr, one ref held by the caller */ | ||
| 400 | BUG_ON(atomic_read(&entry->refcnt) < 2); | ||
| 401 | |||
| 402 | idr_remove(idr, wd); | ||
| 403 | ientry->wd = -1; | ||
| 404 | |||
| 405 | /* removed from the idr, drop that ref */ | ||
| 406 | fsnotify_put_mark(entry); | ||
| 407 | out: | ||
| 408 | spin_unlock(&group->inotify_data.idr_lock); | ||
| 409 | } | ||
| 410 | |||
| 411 | /* | ||
| 412 | * Send IN_IGNORED for this wd, remove this wd from the idr. | ||
| 371 | */ | 413 | */ |
| 372 | void inotify_ignored_and_remove_idr(struct fsnotify_mark_entry *entry, | 414 | void inotify_ignored_and_remove_idr(struct fsnotify_mark_entry *entry, |
| 373 | struct fsnotify_group *group) | 415 | struct fsnotify_group *group) |
| 374 | { | 416 | { |
| 375 | struct inotify_inode_mark_entry *ientry; | 417 | struct inotify_inode_mark_entry *ientry; |
| 418 | struct fsnotify_event *ignored_event; | ||
| 376 | struct inotify_event_private_data *event_priv; | 419 | struct inotify_event_private_data *event_priv; |
| 377 | struct fsnotify_event_private_data *fsn_event_priv; | 420 | struct fsnotify_event_private_data *fsn_event_priv; |
| 378 | struct idr *idr; | 421 | int ret; |
| 422 | |||
| 423 | ignored_event = fsnotify_create_event(NULL, FS_IN_IGNORED, NULL, | ||
| 424 | FSNOTIFY_EVENT_NONE, NULL, 0, | ||
| 425 | GFP_NOFS); | ||
| 426 | if (!ignored_event) | ||
| 427 | return; | ||
| 379 | 428 | ||
| 380 | ientry = container_of(entry, struct inotify_inode_mark_entry, fsn_entry); | 429 | ientry = container_of(entry, struct inotify_inode_mark_entry, fsn_entry); |
| 381 | 430 | ||
| 382 | event_priv = kmem_cache_alloc(event_priv_cachep, GFP_KERNEL); | 431 | event_priv = kmem_cache_alloc(event_priv_cachep, GFP_NOFS); |
| 383 | if (unlikely(!event_priv)) | 432 | if (unlikely(!event_priv)) |
| 384 | goto skip_send_ignore; | 433 | goto skip_send_ignore; |
| 385 | 434 | ||
| @@ -388,22 +437,19 @@ void inotify_ignored_and_remove_idr(struct fsnotify_mark_entry *entry, | |||
| 388 | fsn_event_priv->group = group; | 437 | fsn_event_priv->group = group; |
| 389 | event_priv->wd = ientry->wd; | 438 | event_priv->wd = ientry->wd; |
| 390 | 439 | ||
| 391 | fsnotify_add_notify_event(group, inotify_ignored_event, fsn_event_priv); | 440 | ret = fsnotify_add_notify_event(group, ignored_event, fsn_event_priv); |
| 392 | 441 | if (ret) | |
| 393 | /* did the private data get added? */ | ||
| 394 | if (list_empty(&fsn_event_priv->event_list)) | ||
| 395 | inotify_free_event_priv(fsn_event_priv); | 442 | inotify_free_event_priv(fsn_event_priv); |
| 396 | 443 | ||
| 397 | skip_send_ignore: | 444 | skip_send_ignore: |
| 398 | 445 | ||
| 446 | /* matches the reference taken when the event was created */ | ||
| 447 | fsnotify_put_event(ignored_event); | ||
| 448 | |||
| 399 | /* remove this entry from the idr */ | 449 | /* remove this entry from the idr */ |
| 400 | spin_lock(&group->inotify_data.idr_lock); | 450 | inotify_remove_from_idr(group, ientry); |
| 401 | idr = &group->inotify_data.idr; | ||
| 402 | idr_remove(idr, ientry->wd); | ||
| 403 | spin_unlock(&group->inotify_data.idr_lock); | ||
| 404 | 451 | ||
| 405 | /* removed from idr, drop that reference */ | 452 | atomic_dec(&group->inotify_data.user->inotify_watches); |
| 406 | fsnotify_put_mark(entry); | ||
| 407 | } | 453 | } |
| 408 | 454 | ||
| 409 | /* ding dong the mark is dead */ | 455 | /* ding dong the mark is dead */ |
| @@ -414,67 +460,29 @@ static void inotify_free_mark(struct fsnotify_mark_entry *entry) | |||
| 414 | kmem_cache_free(inotify_inode_mark_cachep, ientry); | 460 | kmem_cache_free(inotify_inode_mark_cachep, ientry); |
| 415 | } | 461 | } |
| 416 | 462 | ||
| 417 | static int inotify_update_watch(struct fsnotify_group *group, struct inode *inode, u32 arg) | 463 | static int inotify_update_existing_watch(struct fsnotify_group *group, |
| 464 | struct inode *inode, | ||
| 465 | u32 arg) | ||
| 418 | { | 466 | { |
| 419 | struct fsnotify_mark_entry *entry = NULL; | 467 | struct fsnotify_mark_entry *entry; |
| 420 | struct inotify_inode_mark_entry *ientry; | 468 | struct inotify_inode_mark_entry *ientry; |
| 421 | int ret = 0; | ||
| 422 | int add = (arg & IN_MASK_ADD); | ||
| 423 | __u32 mask; | ||
| 424 | __u32 old_mask, new_mask; | 469 | __u32 old_mask, new_mask; |
| 470 | __u32 mask; | ||
| 471 | int add = (arg & IN_MASK_ADD); | ||
| 472 | int ret; | ||
| 425 | 473 | ||
| 426 | /* don't allow invalid bits: we don't want flags set */ | 474 | /* don't allow invalid bits: we don't want flags set */ |
| 427 | mask = inotify_arg_to_mask(arg); | 475 | mask = inotify_arg_to_mask(arg); |
| 428 | if (unlikely(!mask)) | 476 | if (unlikely(!mask)) |
| 429 | return -EINVAL; | 477 | return -EINVAL; |
| 430 | 478 | ||
| 431 | ientry = kmem_cache_alloc(inotify_inode_mark_cachep, GFP_KERNEL); | ||
| 432 | if (unlikely(!ientry)) | ||
| 433 | return -ENOMEM; | ||
| 434 | /* we set the mask at the end after attaching it */ | ||
| 435 | fsnotify_init_mark(&ientry->fsn_entry, inotify_free_mark); | ||
| 436 | ientry->wd = 0; | ||
| 437 | |||
| 438 | find_entry: | ||
| 439 | spin_lock(&inode->i_lock); | 479 | spin_lock(&inode->i_lock); |
| 440 | entry = fsnotify_find_mark_entry(group, inode); | 480 | entry = fsnotify_find_mark_entry(group, inode); |
| 441 | spin_unlock(&inode->i_lock); | 481 | spin_unlock(&inode->i_lock); |
| 442 | if (entry) { | 482 | if (!entry) |
| 443 | kmem_cache_free(inotify_inode_mark_cachep, ientry); | 483 | return -ENOENT; |
| 444 | ientry = container_of(entry, struct inotify_inode_mark_entry, fsn_entry); | ||
| 445 | } else { | ||
| 446 | if (atomic_read(&group->inotify_data.user->inotify_watches) >= inotify_max_user_watches) { | ||
| 447 | ret = -ENOSPC; | ||
| 448 | goto out_err; | ||
| 449 | } | ||
| 450 | |||
| 451 | ret = fsnotify_add_mark(&ientry->fsn_entry, group, inode); | ||
| 452 | if (ret == -EEXIST) | ||
| 453 | goto find_entry; | ||
| 454 | else if (ret) | ||
| 455 | goto out_err; | ||
| 456 | 484 | ||
| 457 | entry = &ientry->fsn_entry; | 485 | ientry = container_of(entry, struct inotify_inode_mark_entry, fsn_entry); |
| 458 | retry: | ||
| 459 | ret = -ENOMEM; | ||
| 460 | if (unlikely(!idr_pre_get(&group->inotify_data.idr, GFP_KERNEL))) | ||
| 461 | goto out_err; | ||
| 462 | |||
| 463 | spin_lock(&group->inotify_data.idr_lock); | ||
| 464 | /* if entry is added to the idr we keep the reference obtained | ||
| 465 | * through fsnotify_mark_add. remember to drop this reference | ||
| 466 | * when entry is removed from idr */ | ||
| 467 | ret = idr_get_new_above(&group->inotify_data.idr, entry, | ||
| 468 | ++group->inotify_data.last_wd, | ||
| 469 | &ientry->wd); | ||
| 470 | spin_unlock(&group->inotify_data.idr_lock); | ||
| 471 | if (ret) { | ||
| 472 | if (ret == -EAGAIN) | ||
| 473 | goto retry; | ||
| 474 | goto out_err; | ||
| 475 | } | ||
| 476 | atomic_inc(&group->inotify_data.user->inotify_watches); | ||
| 477 | } | ||
| 478 | 486 | ||
| 479 | spin_lock(&entry->lock); | 487 | spin_lock(&entry->lock); |
| 480 | 488 | ||
| @@ -506,14 +514,104 @@ retry: | |||
| 506 | fsnotify_recalc_group_mask(group); | 514 | fsnotify_recalc_group_mask(group); |
| 507 | } | 515 | } |
| 508 | 516 | ||
| 509 | return ientry->wd; | 517 | /* return the wd */ |
| 518 | ret = ientry->wd; | ||
| 510 | 519 | ||
| 511 | out_err: | 520 | /* match the get from fsnotify_find_mark_entry() */ |
| 512 | /* see this isn't supposed to happen, just kill the watch */ | 521 | fsnotify_put_mark(entry); |
| 513 | if (entry) { | 522 | |
| 514 | fsnotify_destroy_mark_by_entry(entry); | 523 | return ret; |
| 515 | fsnotify_put_mark(entry); | 524 | } |
| 525 | |||
| 526 | static int inotify_new_watch(struct fsnotify_group *group, | ||
| 527 | struct inode *inode, | ||
| 528 | u32 arg) | ||
| 529 | { | ||
| 530 | struct inotify_inode_mark_entry *tmp_ientry; | ||
| 531 | __u32 mask; | ||
| 532 | int ret; | ||
| 533 | |||
| 534 | /* don't allow invalid bits: we don't want flags set */ | ||
| 535 | mask = inotify_arg_to_mask(arg); | ||
| 536 | if (unlikely(!mask)) | ||
| 537 | return -EINVAL; | ||
| 538 | |||
| 539 | tmp_ientry = kmem_cache_alloc(inotify_inode_mark_cachep, GFP_KERNEL); | ||
| 540 | if (unlikely(!tmp_ientry)) | ||
| 541 | return -ENOMEM; | ||
| 542 | |||
| 543 | fsnotify_init_mark(&tmp_ientry->fsn_entry, inotify_free_mark); | ||
| 544 | tmp_ientry->fsn_entry.mask = mask; | ||
| 545 | tmp_ientry->wd = -1; | ||
| 546 | |||
| 547 | ret = -ENOSPC; | ||
| 548 | if (atomic_read(&group->inotify_data.user->inotify_watches) >= inotify_max_user_watches) | ||
| 549 | goto out_err; | ||
| 550 | retry: | ||
| 551 | ret = -ENOMEM; | ||
| 552 | if (unlikely(!idr_pre_get(&group->inotify_data.idr, GFP_KERNEL))) | ||
| 553 | goto out_err; | ||
| 554 | |||
| 555 | spin_lock(&group->inotify_data.idr_lock); | ||
| 556 | ret = idr_get_new_above(&group->inotify_data.idr, &tmp_ientry->fsn_entry, | ||
| 557 | group->inotify_data.last_wd, | ||
| 558 | &tmp_ientry->wd); | ||
| 559 | spin_unlock(&group->inotify_data.idr_lock); | ||
| 560 | if (ret) { | ||
| 561 | /* idr was out of memory allocate and try again */ | ||
| 562 | if (ret == -EAGAIN) | ||
| 563 | goto retry; | ||
| 564 | goto out_err; | ||
| 565 | } | ||
| 566 | |||
| 567 | /* we put the mark on the idr, take a reference */ | ||
| 568 | fsnotify_get_mark(&tmp_ientry->fsn_entry); | ||
| 569 | |||
| 570 | /* we are on the idr, now get on the inode */ | ||
| 571 | ret = fsnotify_add_mark(&tmp_ientry->fsn_entry, group, inode); | ||
| 572 | if (ret) { | ||
| 573 | /* we failed to get on the inode, get off the idr */ | ||
| 574 | inotify_remove_from_idr(group, tmp_ientry); | ||
| 575 | goto out_err; | ||
| 516 | } | 576 | } |
| 577 | |||
| 578 | /* update the idr hint, who cares about races, it's just a hint */ | ||
| 579 | group->inotify_data.last_wd = tmp_ientry->wd; | ||
| 580 | |||
| 581 | /* increment the number of watches the user has */ | ||
| 582 | atomic_inc(&group->inotify_data.user->inotify_watches); | ||
| 583 | |||
| 584 | /* return the watch descriptor for this new entry */ | ||
| 585 | ret = tmp_ientry->wd; | ||
| 586 | |||
| 587 | /* match the ref from fsnotify_init_markentry() */ | ||
| 588 | fsnotify_put_mark(&tmp_ientry->fsn_entry); | ||
| 589 | |||
| 590 | out_err: | ||
| 591 | if (ret < 0) | ||
| 592 | kmem_cache_free(inotify_inode_mark_cachep, tmp_ientry); | ||
| 593 | |||
| 594 | return ret; | ||
| 595 | } | ||
| 596 | |||
| 597 | static int inotify_update_watch(struct fsnotify_group *group, struct inode *inode, u32 arg) | ||
| 598 | { | ||
| 599 | int ret = 0; | ||
| 600 | |||
| 601 | retry: | ||
| 602 | /* try to update and existing watch with the new arg */ | ||
| 603 | ret = inotify_update_existing_watch(group, inode, arg); | ||
| 604 | /* no mark present, try to add a new one */ | ||
| 605 | if (ret == -ENOENT) | ||
| 606 | ret = inotify_new_watch(group, inode, arg); | ||
| 607 | /* | ||
| 608 | * inotify_new_watch could race with another thread which did an | ||
| 609 | * inotify_new_watch between the update_existing and the add watch | ||
| 610 | * here, go back and try to update an existing mark again. | ||
| 611 | */ | ||
| 612 | if (ret == -EEXIST) | ||
| 613 | goto retry; | ||
| 614 | |||
| 517 | return ret; | 615 | return ret; |
| 518 | } | 616 | } |
| 519 | 617 | ||
| @@ -532,7 +630,7 @@ static struct fsnotify_group *inotify_new_group(struct user_struct *user, unsign | |||
| 532 | 630 | ||
| 533 | spin_lock_init(&group->inotify_data.idr_lock); | 631 | spin_lock_init(&group->inotify_data.idr_lock); |
| 534 | idr_init(&group->inotify_data.idr); | 632 | idr_init(&group->inotify_data.idr); |
| 535 | group->inotify_data.last_wd = 0; | 633 | group->inotify_data.last_wd = 1; |
| 536 | group->inotify_data.user = user; | 634 | group->inotify_data.user = user; |
| 537 | group->inotify_data.fa = NULL; | 635 | group->inotify_data.fa = NULL; |
| 538 | 636 | ||
| @@ -721,9 +819,6 @@ static int __init inotify_user_setup(void) | |||
| 721 | 819 | ||
| 722 | inotify_inode_mark_cachep = KMEM_CACHE(inotify_inode_mark_entry, SLAB_PANIC); | 820 | inotify_inode_mark_cachep = KMEM_CACHE(inotify_inode_mark_entry, SLAB_PANIC); |
| 723 | event_priv_cachep = KMEM_CACHE(inotify_event_private_data, SLAB_PANIC); | 821 | event_priv_cachep = KMEM_CACHE(inotify_event_private_data, SLAB_PANIC); |
| 724 | inotify_ignored_event = fsnotify_create_event(NULL, FS_IN_IGNORED, NULL, FSNOTIFY_EVENT_NONE, NULL, 0); | ||
| 725 | if (!inotify_ignored_event) | ||
| 726 | panic("unable to allocate the inotify ignored event\n"); | ||
| 727 | 822 | ||
| 728 | inotify_max_queued_events = 16384; | 823 | inotify_max_queued_events = 16384; |
| 729 | inotify_max_user_instances = 128; | 824 | inotify_max_user_instances = 128; |
diff --git a/fs/notify/notification.c b/fs/notify/notification.c index 959b73e756fd..3816d5750dd5 100644 --- a/fs/notify/notification.c +++ b/fs/notify/notification.c | |||
| @@ -136,18 +136,28 @@ static bool event_compare(struct fsnotify_event *old, struct fsnotify_event *new | |||
| 136 | { | 136 | { |
| 137 | if ((old->mask == new->mask) && | 137 | if ((old->mask == new->mask) && |
| 138 | (old->to_tell == new->to_tell) && | 138 | (old->to_tell == new->to_tell) && |
| 139 | (old->data_type == new->data_type)) { | 139 | (old->data_type == new->data_type) && |
| 140 | (old->name_len == new->name_len)) { | ||
| 140 | switch (old->data_type) { | 141 | switch (old->data_type) { |
| 141 | case (FSNOTIFY_EVENT_INODE): | 142 | case (FSNOTIFY_EVENT_INODE): |
| 142 | if (old->inode == new->inode) | 143 | /* remember, after old was put on the wait_q we aren't |
| 144 | * allowed to look at the inode any more, only thing | ||
| 145 | * left to check was if the file_name is the same */ | ||
| 146 | if (old->name_len && | ||
| 147 | !strcmp(old->file_name, new->file_name)) | ||
| 143 | return true; | 148 | return true; |
| 144 | break; | 149 | break; |
| 145 | case (FSNOTIFY_EVENT_PATH): | 150 | case (FSNOTIFY_EVENT_PATH): |
| 146 | if ((old->path.mnt == new->path.mnt) && | 151 | if ((old->path.mnt == new->path.mnt) && |
| 147 | (old->path.dentry == new->path.dentry)) | 152 | (old->path.dentry == new->path.dentry)) |
| 148 | return true; | 153 | return true; |
| 154 | break; | ||
| 149 | case (FSNOTIFY_EVENT_NONE): | 155 | case (FSNOTIFY_EVENT_NONE): |
| 150 | return true; | 156 | if (old->mask & FS_Q_OVERFLOW) |
| 157 | return true; | ||
| 158 | else if (old->mask & FS_IN_IGNORED) | ||
| 159 | return false; | ||
| 160 | return false; | ||
| 151 | }; | 161 | }; |
| 152 | } | 162 | } |
| 153 | return false; | 163 | return false; |
| @@ -165,9 +175,7 @@ int fsnotify_add_notify_event(struct fsnotify_group *group, struct fsnotify_even | |||
| 165 | struct list_head *list = &group->notification_list; | 175 | struct list_head *list = &group->notification_list; |
| 166 | struct fsnotify_event_holder *last_holder; | 176 | struct fsnotify_event_holder *last_holder; |
| 167 | struct fsnotify_event *last_event; | 177 | struct fsnotify_event *last_event; |
| 168 | 178 | int ret = 0; | |
| 169 | /* easy to tell if priv was attached to the event */ | ||
| 170 | INIT_LIST_HEAD(&priv->event_list); | ||
| 171 | 179 | ||
| 172 | /* | 180 | /* |
| 173 | * There is one fsnotify_event_holder embedded inside each fsnotify_event. | 181 | * There is one fsnotify_event_holder embedded inside each fsnotify_event. |
| @@ -188,6 +196,7 @@ alloc_holder: | |||
| 188 | 196 | ||
| 189 | if (group->q_len >= group->max_events) { | 197 | if (group->q_len >= group->max_events) { |
| 190 | event = &q_overflow_event; | 198 | event = &q_overflow_event; |
| 199 | ret = -EOVERFLOW; | ||
| 191 | /* sorry, no private data on the overflow event */ | 200 | /* sorry, no private data on the overflow event */ |
| 192 | priv = NULL; | 201 | priv = NULL; |
| 193 | } | 202 | } |
| @@ -229,7 +238,7 @@ alloc_holder: | |||
| 229 | mutex_unlock(&group->notification_mutex); | 238 | mutex_unlock(&group->notification_mutex); |
| 230 | 239 | ||
| 231 | wake_up(&group->notification_waitq); | 240 | wake_up(&group->notification_waitq); |
| 232 | return 0; | 241 | return ret; |
| 233 | } | 242 | } |
| 234 | 243 | ||
| 235 | /* | 244 | /* |
| @@ -339,18 +348,19 @@ static void initialize_event(struct fsnotify_event *event) | |||
| 339 | * @name the filename, if available | 348 | * @name the filename, if available |
| 340 | */ | 349 | */ |
| 341 | struct fsnotify_event *fsnotify_create_event(struct inode *to_tell, __u32 mask, void *data, | 350 | struct fsnotify_event *fsnotify_create_event(struct inode *to_tell, __u32 mask, void *data, |
| 342 | int data_type, const char *name, u32 cookie) | 351 | int data_type, const char *name, u32 cookie, |
| 352 | gfp_t gfp) | ||
| 343 | { | 353 | { |
| 344 | struct fsnotify_event *event; | 354 | struct fsnotify_event *event; |
| 345 | 355 | ||
| 346 | event = kmem_cache_alloc(fsnotify_event_cachep, GFP_KERNEL); | 356 | event = kmem_cache_alloc(fsnotify_event_cachep, gfp); |
| 347 | if (!event) | 357 | if (!event) |
| 348 | return NULL; | 358 | return NULL; |
| 349 | 359 | ||
| 350 | initialize_event(event); | 360 | initialize_event(event); |
| 351 | 361 | ||
| 352 | if (name) { | 362 | if (name) { |
| 353 | event->file_name = kstrdup(name, GFP_KERNEL); | 363 | event->file_name = kstrdup(name, gfp); |
| 354 | if (!event->file_name) { | 364 | if (!event->file_name) { |
| 355 | kmem_cache_free(fsnotify_event_cachep, event); | 365 | kmem_cache_free(fsnotify_event_cachep, event); |
| 356 | return NULL; | 366 | return NULL; |
diff --git a/fs/ocfs2/alloc.c b/fs/ocfs2/alloc.c index 9edcde4974aa..ab513ddaeff2 100644 --- a/fs/ocfs2/alloc.c +++ b/fs/ocfs2/alloc.c | |||
| @@ -1914,7 +1914,8 @@ static void ocfs2_adjust_adjacent_records(struct ocfs2_extent_rec *left_rec, | |||
| 1914 | * immediately to their right. | 1914 | * immediately to their right. |
| 1915 | */ | 1915 | */ |
| 1916 | left_clusters = le32_to_cpu(right_child_el->l_recs[0].e_cpos); | 1916 | left_clusters = le32_to_cpu(right_child_el->l_recs[0].e_cpos); |
| 1917 | if (ocfs2_is_empty_extent(&right_child_el->l_recs[0])) { | 1917 | if (!ocfs2_rec_clusters(right_child_el, &right_child_el->l_recs[0])) { |
| 1918 | BUG_ON(right_child_el->l_tree_depth); | ||
| 1918 | BUG_ON(le16_to_cpu(right_child_el->l_next_free_rec) <= 1); | 1919 | BUG_ON(le16_to_cpu(right_child_el->l_next_free_rec) <= 1); |
| 1919 | left_clusters = le32_to_cpu(right_child_el->l_recs[1].e_cpos); | 1920 | left_clusters = le32_to_cpu(right_child_el->l_recs[1].e_cpos); |
| 1920 | } | 1921 | } |
| @@ -2476,15 +2477,37 @@ out_ret_path: | |||
| 2476 | return ret; | 2477 | return ret; |
| 2477 | } | 2478 | } |
| 2478 | 2479 | ||
| 2479 | static void ocfs2_update_edge_lengths(struct inode *inode, handle_t *handle, | 2480 | static int ocfs2_update_edge_lengths(struct inode *inode, handle_t *handle, |
| 2480 | struct ocfs2_path *path) | 2481 | int subtree_index, struct ocfs2_path *path) |
| 2481 | { | 2482 | { |
| 2482 | int i, idx; | 2483 | int i, idx, ret; |
| 2483 | struct ocfs2_extent_rec *rec; | 2484 | struct ocfs2_extent_rec *rec; |
| 2484 | struct ocfs2_extent_list *el; | 2485 | struct ocfs2_extent_list *el; |
| 2485 | struct ocfs2_extent_block *eb; | 2486 | struct ocfs2_extent_block *eb; |
| 2486 | u32 range; | 2487 | u32 range; |
| 2487 | 2488 | ||
| 2489 | /* | ||
| 2490 | * In normal tree rotation process, we will never touch the | ||
| 2491 | * tree branch above subtree_index and ocfs2_extend_rotate_transaction | ||
| 2492 | * doesn't reserve the credits for them either. | ||
| 2493 | * | ||
| 2494 | * But we do have a special case here which will update the rightmost | ||
| 2495 | * records for all the bh in the path. | ||
| 2496 | * So we have to allocate extra credits and access them. | ||
| 2497 | */ | ||
| 2498 | ret = ocfs2_extend_trans(handle, | ||
| 2499 | handle->h_buffer_credits + subtree_index); | ||
| 2500 | if (ret) { | ||
| 2501 | mlog_errno(ret); | ||
| 2502 | goto out; | ||
| 2503 | } | ||
| 2504 | |||
| 2505 | ret = ocfs2_journal_access_path(inode, handle, path); | ||
| 2506 | if (ret) { | ||
| 2507 | mlog_errno(ret); | ||
| 2508 | goto out; | ||
| 2509 | } | ||
| 2510 | |||
| 2488 | /* Path should always be rightmost. */ | 2511 | /* Path should always be rightmost. */ |
| 2489 | eb = (struct ocfs2_extent_block *)path_leaf_bh(path)->b_data; | 2512 | eb = (struct ocfs2_extent_block *)path_leaf_bh(path)->b_data; |
| 2490 | BUG_ON(eb->h_next_leaf_blk != 0ULL); | 2513 | BUG_ON(eb->h_next_leaf_blk != 0ULL); |
| @@ -2505,6 +2528,8 @@ static void ocfs2_update_edge_lengths(struct inode *inode, handle_t *handle, | |||
| 2505 | 2528 | ||
| 2506 | ocfs2_journal_dirty(handle, path->p_node[i].bh); | 2529 | ocfs2_journal_dirty(handle, path->p_node[i].bh); |
| 2507 | } | 2530 | } |
| 2531 | out: | ||
| 2532 | return ret; | ||
| 2508 | } | 2533 | } |
| 2509 | 2534 | ||
| 2510 | static void ocfs2_unlink_path(struct inode *inode, handle_t *handle, | 2535 | static void ocfs2_unlink_path(struct inode *inode, handle_t *handle, |
| @@ -2717,7 +2742,12 @@ static int ocfs2_rotate_subtree_left(struct inode *inode, handle_t *handle, | |||
| 2717 | if (del_right_subtree) { | 2742 | if (del_right_subtree) { |
| 2718 | ocfs2_unlink_subtree(inode, handle, left_path, right_path, | 2743 | ocfs2_unlink_subtree(inode, handle, left_path, right_path, |
| 2719 | subtree_index, dealloc); | 2744 | subtree_index, dealloc); |
| 2720 | ocfs2_update_edge_lengths(inode, handle, left_path); | 2745 | ret = ocfs2_update_edge_lengths(inode, handle, subtree_index, |
| 2746 | left_path); | ||
| 2747 | if (ret) { | ||
| 2748 | mlog_errno(ret); | ||
| 2749 | goto out; | ||
| 2750 | } | ||
| 2721 | 2751 | ||
| 2722 | eb = (struct ocfs2_extent_block *)path_leaf_bh(left_path)->b_data; | 2752 | eb = (struct ocfs2_extent_block *)path_leaf_bh(left_path)->b_data; |
| 2723 | ocfs2_et_set_last_eb_blk(et, le64_to_cpu(eb->h_blkno)); | 2753 | ocfs2_et_set_last_eb_blk(et, le64_to_cpu(eb->h_blkno)); |
| @@ -3034,7 +3064,12 @@ static int ocfs2_remove_rightmost_path(struct inode *inode, handle_t *handle, | |||
| 3034 | 3064 | ||
| 3035 | ocfs2_unlink_subtree(inode, handle, left_path, path, | 3065 | ocfs2_unlink_subtree(inode, handle, left_path, path, |
| 3036 | subtree_index, dealloc); | 3066 | subtree_index, dealloc); |
| 3037 | ocfs2_update_edge_lengths(inode, handle, left_path); | 3067 | ret = ocfs2_update_edge_lengths(inode, handle, subtree_index, |
| 3068 | left_path); | ||
| 3069 | if (ret) { | ||
| 3070 | mlog_errno(ret); | ||
| 3071 | goto out; | ||
| 3072 | } | ||
| 3038 | 3073 | ||
| 3039 | eb = (struct ocfs2_extent_block *)path_leaf_bh(left_path)->b_data; | 3074 | eb = (struct ocfs2_extent_block *)path_leaf_bh(left_path)->b_data; |
| 3040 | ocfs2_et_set_last_eb_blk(et, le64_to_cpu(eb->h_blkno)); | 3075 | ocfs2_et_set_last_eb_blk(et, le64_to_cpu(eb->h_blkno)); |
| @@ -6816,7 +6851,7 @@ static int ocfs2_do_truncate(struct ocfs2_super *osb, | |||
| 6816 | } | 6851 | } |
| 6817 | status = 0; | 6852 | status = 0; |
| 6818 | bail: | 6853 | bail: |
| 6819 | 6854 | brelse(last_eb_bh); | |
| 6820 | mlog_exit(status); | 6855 | mlog_exit(status); |
| 6821 | return status; | 6856 | return status; |
| 6822 | } | 6857 | } |
diff --git a/fs/ocfs2/aops.c b/fs/ocfs2/aops.c index b2c52b3a1484..b401654011a2 100644 --- a/fs/ocfs2/aops.c +++ b/fs/ocfs2/aops.c | |||
| @@ -193,6 +193,7 @@ static int ocfs2_get_block(struct inode *inode, sector_t iblock, | |||
| 193 | (unsigned long long)OCFS2_I(inode)->ip_blkno); | 193 | (unsigned long long)OCFS2_I(inode)->ip_blkno); |
| 194 | mlog(ML_ERROR, "Size %llu, clusters %u\n", (unsigned long long)i_size_read(inode), OCFS2_I(inode)->ip_clusters); | 194 | mlog(ML_ERROR, "Size %llu, clusters %u\n", (unsigned long long)i_size_read(inode), OCFS2_I(inode)->ip_clusters); |
| 195 | dump_stack(); | 195 | dump_stack(); |
| 196 | goto bail; | ||
| 196 | } | 197 | } |
| 197 | 198 | ||
| 198 | past_eof = ocfs2_blocks_for_bytes(inode->i_sb, i_size_read(inode)); | 199 | past_eof = ocfs2_blocks_for_bytes(inode->i_sb, i_size_read(inode)); |
| @@ -894,18 +895,17 @@ struct ocfs2_write_cluster_desc { | |||
| 894 | */ | 895 | */ |
| 895 | unsigned c_new; | 896 | unsigned c_new; |
| 896 | unsigned c_unwritten; | 897 | unsigned c_unwritten; |
| 898 | unsigned c_needs_zero; | ||
| 897 | }; | 899 | }; |
| 898 | 900 | ||
| 899 | static inline int ocfs2_should_zero_cluster(struct ocfs2_write_cluster_desc *d) | ||
| 900 | { | ||
| 901 | return d->c_new || d->c_unwritten; | ||
| 902 | } | ||
| 903 | |||
| 904 | struct ocfs2_write_ctxt { | 901 | struct ocfs2_write_ctxt { |
| 905 | /* Logical cluster position / len of write */ | 902 | /* Logical cluster position / len of write */ |
| 906 | u32 w_cpos; | 903 | u32 w_cpos; |
| 907 | u32 w_clen; | 904 | u32 w_clen; |
| 908 | 905 | ||
| 906 | /* First cluster allocated in a nonsparse extend */ | ||
| 907 | u32 w_first_new_cpos; | ||
| 908 | |||
| 909 | struct ocfs2_write_cluster_desc w_desc[OCFS2_MAX_CLUSTERS_PER_PAGE]; | 909 | struct ocfs2_write_cluster_desc w_desc[OCFS2_MAX_CLUSTERS_PER_PAGE]; |
| 910 | 910 | ||
| 911 | /* | 911 | /* |
| @@ -983,6 +983,7 @@ static int ocfs2_alloc_write_ctxt(struct ocfs2_write_ctxt **wcp, | |||
| 983 | return -ENOMEM; | 983 | return -ENOMEM; |
| 984 | 984 | ||
| 985 | wc->w_cpos = pos >> osb->s_clustersize_bits; | 985 | wc->w_cpos = pos >> osb->s_clustersize_bits; |
| 986 | wc->w_first_new_cpos = UINT_MAX; | ||
| 986 | cend = (pos + len - 1) >> osb->s_clustersize_bits; | 987 | cend = (pos + len - 1) >> osb->s_clustersize_bits; |
| 987 | wc->w_clen = cend - wc->w_cpos + 1; | 988 | wc->w_clen = cend - wc->w_cpos + 1; |
| 988 | get_bh(di_bh); | 989 | get_bh(di_bh); |
| @@ -1217,20 +1218,18 @@ out: | |||
| 1217 | */ | 1218 | */ |
| 1218 | static int ocfs2_write_cluster(struct address_space *mapping, | 1219 | static int ocfs2_write_cluster(struct address_space *mapping, |
| 1219 | u32 phys, unsigned int unwritten, | 1220 | u32 phys, unsigned int unwritten, |
| 1221 | unsigned int should_zero, | ||
| 1220 | struct ocfs2_alloc_context *data_ac, | 1222 | struct ocfs2_alloc_context *data_ac, |
| 1221 | struct ocfs2_alloc_context *meta_ac, | 1223 | struct ocfs2_alloc_context *meta_ac, |
| 1222 | struct ocfs2_write_ctxt *wc, u32 cpos, | 1224 | struct ocfs2_write_ctxt *wc, u32 cpos, |
| 1223 | loff_t user_pos, unsigned user_len) | 1225 | loff_t user_pos, unsigned user_len) |
| 1224 | { | 1226 | { |
| 1225 | int ret, i, new, should_zero = 0; | 1227 | int ret, i, new; |
| 1226 | u64 v_blkno, p_blkno; | 1228 | u64 v_blkno, p_blkno; |
| 1227 | struct inode *inode = mapping->host; | 1229 | struct inode *inode = mapping->host; |
| 1228 | struct ocfs2_extent_tree et; | 1230 | struct ocfs2_extent_tree et; |
| 1229 | 1231 | ||
| 1230 | new = phys == 0 ? 1 : 0; | 1232 | new = phys == 0 ? 1 : 0; |
| 1231 | if (new || unwritten) | ||
| 1232 | should_zero = 1; | ||
| 1233 | |||
| 1234 | if (new) { | 1233 | if (new) { |
| 1235 | u32 tmp_pos; | 1234 | u32 tmp_pos; |
| 1236 | 1235 | ||
| @@ -1301,7 +1300,7 @@ static int ocfs2_write_cluster(struct address_space *mapping, | |||
| 1301 | if (tmpret) { | 1300 | if (tmpret) { |
| 1302 | mlog_errno(tmpret); | 1301 | mlog_errno(tmpret); |
| 1303 | if (ret == 0) | 1302 | if (ret == 0) |
| 1304 | tmpret = ret; | 1303 | ret = tmpret; |
| 1305 | } | 1304 | } |
| 1306 | } | 1305 | } |
| 1307 | 1306 | ||
| @@ -1341,7 +1340,9 @@ static int ocfs2_write_cluster_by_desc(struct address_space *mapping, | |||
| 1341 | local_len = osb->s_clustersize - cluster_off; | 1340 | local_len = osb->s_clustersize - cluster_off; |
| 1342 | 1341 | ||
| 1343 | ret = ocfs2_write_cluster(mapping, desc->c_phys, | 1342 | ret = ocfs2_write_cluster(mapping, desc->c_phys, |
| 1344 | desc->c_unwritten, data_ac, meta_ac, | 1343 | desc->c_unwritten, |
| 1344 | desc->c_needs_zero, | ||
| 1345 | data_ac, meta_ac, | ||
| 1345 | wc, desc->c_cpos, pos, local_len); | 1346 | wc, desc->c_cpos, pos, local_len); |
| 1346 | if (ret) { | 1347 | if (ret) { |
| 1347 | mlog_errno(ret); | 1348 | mlog_errno(ret); |
| @@ -1391,14 +1392,14 @@ static void ocfs2_set_target_boundaries(struct ocfs2_super *osb, | |||
| 1391 | * newly allocated cluster. | 1392 | * newly allocated cluster. |
| 1392 | */ | 1393 | */ |
| 1393 | desc = &wc->w_desc[0]; | 1394 | desc = &wc->w_desc[0]; |
| 1394 | if (ocfs2_should_zero_cluster(desc)) | 1395 | if (desc->c_needs_zero) |
| 1395 | ocfs2_figure_cluster_boundaries(osb, | 1396 | ocfs2_figure_cluster_boundaries(osb, |
| 1396 | desc->c_cpos, | 1397 | desc->c_cpos, |
| 1397 | &wc->w_target_from, | 1398 | &wc->w_target_from, |
| 1398 | NULL); | 1399 | NULL); |
| 1399 | 1400 | ||
| 1400 | desc = &wc->w_desc[wc->w_clen - 1]; | 1401 | desc = &wc->w_desc[wc->w_clen - 1]; |
| 1401 | if (ocfs2_should_zero_cluster(desc)) | 1402 | if (desc->c_needs_zero) |
| 1402 | ocfs2_figure_cluster_boundaries(osb, | 1403 | ocfs2_figure_cluster_boundaries(osb, |
| 1403 | desc->c_cpos, | 1404 | desc->c_cpos, |
| 1404 | NULL, | 1405 | NULL, |
| @@ -1466,13 +1467,28 @@ static int ocfs2_populate_write_desc(struct inode *inode, | |||
| 1466 | phys++; | 1467 | phys++; |
| 1467 | } | 1468 | } |
| 1468 | 1469 | ||
| 1470 | /* | ||
| 1471 | * If w_first_new_cpos is < UINT_MAX, we have a non-sparse | ||
| 1472 | * file that got extended. w_first_new_cpos tells us | ||
| 1473 | * where the newly allocated clusters are so we can | ||
| 1474 | * zero them. | ||
| 1475 | */ | ||
| 1476 | if (desc->c_cpos >= wc->w_first_new_cpos) { | ||
| 1477 | BUG_ON(phys == 0); | ||
| 1478 | desc->c_needs_zero = 1; | ||
| 1479 | } | ||
| 1480 | |||
| 1469 | desc->c_phys = phys; | 1481 | desc->c_phys = phys; |
| 1470 | if (phys == 0) { | 1482 | if (phys == 0) { |
| 1471 | desc->c_new = 1; | 1483 | desc->c_new = 1; |
| 1484 | desc->c_needs_zero = 1; | ||
| 1472 | *clusters_to_alloc = *clusters_to_alloc + 1; | 1485 | *clusters_to_alloc = *clusters_to_alloc + 1; |
| 1473 | } | 1486 | } |
| 1474 | if (ext_flags & OCFS2_EXT_UNWRITTEN) | 1487 | |
| 1488 | if (ext_flags & OCFS2_EXT_UNWRITTEN) { | ||
| 1475 | desc->c_unwritten = 1; | 1489 | desc->c_unwritten = 1; |
| 1490 | desc->c_needs_zero = 1; | ||
| 1491 | } | ||
| 1476 | 1492 | ||
| 1477 | num_clusters--; | 1493 | num_clusters--; |
| 1478 | } | 1494 | } |
| @@ -1632,10 +1648,13 @@ static int ocfs2_expand_nonsparse_inode(struct inode *inode, loff_t pos, | |||
| 1632 | if (newsize <= i_size_read(inode)) | 1648 | if (newsize <= i_size_read(inode)) |
| 1633 | return 0; | 1649 | return 0; |
| 1634 | 1650 | ||
| 1635 | ret = ocfs2_extend_no_holes(inode, newsize, newsize - len); | 1651 | ret = ocfs2_extend_no_holes(inode, newsize, pos); |
| 1636 | if (ret) | 1652 | if (ret) |
| 1637 | mlog_errno(ret); | 1653 | mlog_errno(ret); |
| 1638 | 1654 | ||
| 1655 | wc->w_first_new_cpos = | ||
| 1656 | ocfs2_clusters_for_bytes(inode->i_sb, i_size_read(inode)); | ||
| 1657 | |||
| 1639 | return ret; | 1658 | return ret; |
| 1640 | } | 1659 | } |
| 1641 | 1660 | ||
| @@ -1644,7 +1663,7 @@ int ocfs2_write_begin_nolock(struct address_space *mapping, | |||
| 1644 | struct page **pagep, void **fsdata, | 1663 | struct page **pagep, void **fsdata, |
| 1645 | struct buffer_head *di_bh, struct page *mmap_page) | 1664 | struct buffer_head *di_bh, struct page *mmap_page) |
| 1646 | { | 1665 | { |
| 1647 | int ret, credits = OCFS2_INODE_UPDATE_CREDITS; | 1666 | int ret, cluster_of_pages, credits = OCFS2_INODE_UPDATE_CREDITS; |
| 1648 | unsigned int clusters_to_alloc, extents_to_split; | 1667 | unsigned int clusters_to_alloc, extents_to_split; |
| 1649 | struct ocfs2_write_ctxt *wc; | 1668 | struct ocfs2_write_ctxt *wc; |
| 1650 | struct inode *inode = mapping->host; | 1669 | struct inode *inode = mapping->host; |
| @@ -1722,8 +1741,19 @@ int ocfs2_write_begin_nolock(struct address_space *mapping, | |||
| 1722 | 1741 | ||
| 1723 | } | 1742 | } |
| 1724 | 1743 | ||
| 1725 | ocfs2_set_target_boundaries(osb, wc, pos, len, | 1744 | /* |
| 1726 | clusters_to_alloc + extents_to_split); | 1745 | * We have to zero sparse allocated clusters, unwritten extent clusters, |
| 1746 | * and non-sparse clusters we just extended. For non-sparse writes, | ||
| 1747 | * we know zeros will only be needed in the first and/or last cluster. | ||
| 1748 | */ | ||
| 1749 | if (clusters_to_alloc || extents_to_split || | ||
| 1750 | wc->w_desc[0].c_needs_zero || | ||
| 1751 | wc->w_desc[wc->w_clen - 1].c_needs_zero) | ||
| 1752 | cluster_of_pages = 1; | ||
| 1753 | else | ||
| 1754 | cluster_of_pages = 0; | ||
| 1755 | |||
| 1756 | ocfs2_set_target_boundaries(osb, wc, pos, len, cluster_of_pages); | ||
| 1727 | 1757 | ||
| 1728 | handle = ocfs2_start_trans(osb, credits); | 1758 | handle = ocfs2_start_trans(osb, credits); |
| 1729 | if (IS_ERR(handle)) { | 1759 | if (IS_ERR(handle)) { |
| @@ -1756,8 +1786,7 @@ int ocfs2_write_begin_nolock(struct address_space *mapping, | |||
| 1756 | * extent. | 1786 | * extent. |
| 1757 | */ | 1787 | */ |
| 1758 | ret = ocfs2_grab_pages_for_write(mapping, wc, wc->w_cpos, pos, | 1788 | ret = ocfs2_grab_pages_for_write(mapping, wc, wc->w_cpos, pos, |
| 1759 | clusters_to_alloc + extents_to_split, | 1789 | cluster_of_pages, mmap_page); |
| 1760 | mmap_page); | ||
| 1761 | if (ret) { | 1790 | if (ret) { |
| 1762 | mlog_errno(ret); | 1791 | mlog_errno(ret); |
| 1763 | goto out_quota; | 1792 | goto out_quota; |
diff --git a/fs/ocfs2/dcache.c b/fs/ocfs2/dcache.c index b574431a031d..2f28b7de2c8d 100644 --- a/fs/ocfs2/dcache.c +++ b/fs/ocfs2/dcache.c | |||
| @@ -310,22 +310,19 @@ out_attach: | |||
| 310 | return ret; | 310 | return ret; |
| 311 | } | 311 | } |
| 312 | 312 | ||
| 313 | static DEFINE_SPINLOCK(dentry_list_lock); | 313 | DEFINE_SPINLOCK(dentry_list_lock); |
| 314 | 314 | ||
| 315 | /* We limit the number of dentry locks to drop in one go. We have | 315 | /* We limit the number of dentry locks to drop in one go. We have |
| 316 | * this limit so that we don't starve other users of ocfs2_wq. */ | 316 | * this limit so that we don't starve other users of ocfs2_wq. */ |
| 317 | #define DL_INODE_DROP_COUNT 64 | 317 | #define DL_INODE_DROP_COUNT 64 |
| 318 | 318 | ||
| 319 | /* Drop inode references from dentry locks */ | 319 | /* Drop inode references from dentry locks */ |
| 320 | void ocfs2_drop_dl_inodes(struct work_struct *work) | 320 | static void __ocfs2_drop_dl_inodes(struct ocfs2_super *osb, int drop_count) |
| 321 | { | 321 | { |
| 322 | struct ocfs2_super *osb = container_of(work, struct ocfs2_super, | ||
| 323 | dentry_lock_work); | ||
| 324 | struct ocfs2_dentry_lock *dl; | 322 | struct ocfs2_dentry_lock *dl; |
| 325 | int drop_count = DL_INODE_DROP_COUNT; | ||
| 326 | 323 | ||
| 327 | spin_lock(&dentry_list_lock); | 324 | spin_lock(&dentry_list_lock); |
| 328 | while (osb->dentry_lock_list && drop_count--) { | 325 | while (osb->dentry_lock_list && (drop_count < 0 || drop_count--)) { |
| 329 | dl = osb->dentry_lock_list; | 326 | dl = osb->dentry_lock_list; |
| 330 | osb->dentry_lock_list = dl->dl_next; | 327 | osb->dentry_lock_list = dl->dl_next; |
| 331 | spin_unlock(&dentry_list_lock); | 328 | spin_unlock(&dentry_list_lock); |
| @@ -333,11 +330,32 @@ void ocfs2_drop_dl_inodes(struct work_struct *work) | |||
| 333 | kfree(dl); | 330 | kfree(dl); |
| 334 | spin_lock(&dentry_list_lock); | 331 | spin_lock(&dentry_list_lock); |
| 335 | } | 332 | } |
| 336 | if (osb->dentry_lock_list) | 333 | spin_unlock(&dentry_list_lock); |
| 334 | } | ||
| 335 | |||
| 336 | void ocfs2_drop_dl_inodes(struct work_struct *work) | ||
| 337 | { | ||
| 338 | struct ocfs2_super *osb = container_of(work, struct ocfs2_super, | ||
| 339 | dentry_lock_work); | ||
| 340 | |||
| 341 | __ocfs2_drop_dl_inodes(osb, DL_INODE_DROP_COUNT); | ||
| 342 | /* | ||
| 343 | * Don't queue dropping if umount is in progress. We flush the | ||
| 344 | * list in ocfs2_dismount_volume | ||
| 345 | */ | ||
| 346 | spin_lock(&dentry_list_lock); | ||
| 347 | if (osb->dentry_lock_list && | ||
| 348 | !ocfs2_test_osb_flag(osb, OCFS2_OSB_DROP_DENTRY_LOCK_IMMED)) | ||
| 337 | queue_work(ocfs2_wq, &osb->dentry_lock_work); | 349 | queue_work(ocfs2_wq, &osb->dentry_lock_work); |
| 338 | spin_unlock(&dentry_list_lock); | 350 | spin_unlock(&dentry_list_lock); |
| 339 | } | 351 | } |
| 340 | 352 | ||
| 353 | /* Flush the whole work queue */ | ||
| 354 | void ocfs2_drop_all_dl_inodes(struct ocfs2_super *osb) | ||
| 355 | { | ||
| 356 | __ocfs2_drop_dl_inodes(osb, -1); | ||
| 357 | } | ||
| 358 | |||
| 341 | /* | 359 | /* |
| 342 | * ocfs2_dentry_iput() and friends. | 360 | * ocfs2_dentry_iput() and friends. |
| 343 | * | 361 | * |
| @@ -368,7 +386,8 @@ static void ocfs2_drop_dentry_lock(struct ocfs2_super *osb, | |||
| 368 | /* We leave dropping of inode reference to ocfs2_wq as that can | 386 | /* We leave dropping of inode reference to ocfs2_wq as that can |
| 369 | * possibly lead to inode deletion which gets tricky */ | 387 | * possibly lead to inode deletion which gets tricky */ |
| 370 | spin_lock(&dentry_list_lock); | 388 | spin_lock(&dentry_list_lock); |
| 371 | if (!osb->dentry_lock_list) | 389 | if (!osb->dentry_lock_list && |
| 390 | !ocfs2_test_osb_flag(osb, OCFS2_OSB_DROP_DENTRY_LOCK_IMMED)) | ||
| 372 | queue_work(ocfs2_wq, &osb->dentry_lock_work); | 391 | queue_work(ocfs2_wq, &osb->dentry_lock_work); |
| 373 | dl->dl_next = osb->dentry_lock_list; | 392 | dl->dl_next = osb->dentry_lock_list; |
| 374 | osb->dentry_lock_list = dl; | 393 | osb->dentry_lock_list = dl; |
diff --git a/fs/ocfs2/dcache.h b/fs/ocfs2/dcache.h index faa12e75f98d..f5dd1789acf1 100644 --- a/fs/ocfs2/dcache.h +++ b/fs/ocfs2/dcache.h | |||
| @@ -49,10 +49,13 @@ struct ocfs2_dentry_lock { | |||
| 49 | int ocfs2_dentry_attach_lock(struct dentry *dentry, struct inode *inode, | 49 | int ocfs2_dentry_attach_lock(struct dentry *dentry, struct inode *inode, |
| 50 | u64 parent_blkno); | 50 | u64 parent_blkno); |
| 51 | 51 | ||
| 52 | extern spinlock_t dentry_list_lock; | ||
| 53 | |||
| 52 | void ocfs2_dentry_lock_put(struct ocfs2_super *osb, | 54 | void ocfs2_dentry_lock_put(struct ocfs2_super *osb, |
| 53 | struct ocfs2_dentry_lock *dl); | 55 | struct ocfs2_dentry_lock *dl); |
| 54 | 56 | ||
| 55 | void ocfs2_drop_dl_inodes(struct work_struct *work); | 57 | void ocfs2_drop_dl_inodes(struct work_struct *work); |
| 58 | void ocfs2_drop_all_dl_inodes(struct ocfs2_super *osb); | ||
| 56 | 59 | ||
| 57 | struct dentry *ocfs2_find_local_alias(struct inode *inode, u64 parent_blkno, | 60 | struct dentry *ocfs2_find_local_alias(struct inode *inode, u64 parent_blkno, |
| 58 | int skip_unhashed); | 61 | int skip_unhashed); |
diff --git a/fs/ocfs2/dlm/dlmast.c b/fs/ocfs2/dlm/dlmast.c index d07ddbe4b283..81eff8e58322 100644 --- a/fs/ocfs2/dlm/dlmast.c +++ b/fs/ocfs2/dlm/dlmast.c | |||
| @@ -103,7 +103,6 @@ static void __dlm_queue_ast(struct dlm_ctxt *dlm, struct dlm_lock *lock) | |||
| 103 | lock->ast_pending, lock->ml.type); | 103 | lock->ast_pending, lock->ml.type); |
| 104 | BUG(); | 104 | BUG(); |
| 105 | } | 105 | } |
| 106 | BUG_ON(!list_empty(&lock->ast_list)); | ||
| 107 | if (lock->ast_pending) | 106 | if (lock->ast_pending) |
| 108 | mlog(0, "lock has an ast getting flushed right now\n"); | 107 | mlog(0, "lock has an ast getting flushed right now\n"); |
| 109 | 108 | ||
diff --git a/fs/ocfs2/dlm/dlmrecovery.c b/fs/ocfs2/dlm/dlmrecovery.c index bcb9260c3735..43e6e3280569 100644 --- a/fs/ocfs2/dlm/dlmrecovery.c +++ b/fs/ocfs2/dlm/dlmrecovery.c | |||
| @@ -1118,7 +1118,7 @@ static int dlm_send_mig_lockres_msg(struct dlm_ctxt *dlm, | |||
| 1118 | 1118 | ||
| 1119 | mlog(0, "%s:%.*s: sending mig lockres (%s) to %u\n", | 1119 | mlog(0, "%s:%.*s: sending mig lockres (%s) to %u\n", |
| 1120 | dlm->name, res->lockname.len, res->lockname.name, | 1120 | dlm->name, res->lockname.len, res->lockname.name, |
| 1121 | orig_flags & DLM_MRES_MIGRATION ? "migrate" : "recovery", | 1121 | orig_flags & DLM_MRES_MIGRATION ? "migration" : "recovery", |
| 1122 | send_to); | 1122 | send_to); |
| 1123 | 1123 | ||
| 1124 | /* send it */ | 1124 | /* send it */ |
diff --git a/fs/ocfs2/dlm/dlmunlock.c b/fs/ocfs2/dlm/dlmunlock.c index fcf879ed6930..756f5b0998e0 100644 --- a/fs/ocfs2/dlm/dlmunlock.c +++ b/fs/ocfs2/dlm/dlmunlock.c | |||
| @@ -122,7 +122,7 @@ static enum dlm_status dlmunlock_common(struct dlm_ctxt *dlm, | |||
| 122 | * that still has AST's pending... */ | 122 | * that still has AST's pending... */ |
| 123 | in_use = !list_empty(&lock->ast_list); | 123 | in_use = !list_empty(&lock->ast_list); |
| 124 | spin_unlock(&dlm->ast_lock); | 124 | spin_unlock(&dlm->ast_lock); |
| 125 | if (in_use) { | 125 | if (in_use && !(flags & LKM_CANCEL)) { |
| 126 | mlog(ML_ERROR, "lockres %.*s: Someone is calling dlmunlock " | 126 | mlog(ML_ERROR, "lockres %.*s: Someone is calling dlmunlock " |
| 127 | "while waiting for an ast!", res->lockname.len, | 127 | "while waiting for an ast!", res->lockname.len, |
| 128 | res->lockname.name); | 128 | res->lockname.name); |
| @@ -131,7 +131,7 @@ static enum dlm_status dlmunlock_common(struct dlm_ctxt *dlm, | |||
| 131 | 131 | ||
| 132 | spin_lock(&res->spinlock); | 132 | spin_lock(&res->spinlock); |
| 133 | if (res->state & DLM_LOCK_RES_IN_PROGRESS) { | 133 | if (res->state & DLM_LOCK_RES_IN_PROGRESS) { |
| 134 | if (master_node) { | 134 | if (master_node && !(flags & LKM_CANCEL)) { |
| 135 | mlog(ML_ERROR, "lockres in progress!\n"); | 135 | mlog(ML_ERROR, "lockres in progress!\n"); |
| 136 | spin_unlock(&res->spinlock); | 136 | spin_unlock(&res->spinlock); |
| 137 | return DLM_FORWARD; | 137 | return DLM_FORWARD; |
diff --git a/fs/ocfs2/file.c b/fs/ocfs2/file.c index 62442e413a00..aa501d3f93f1 100644 --- a/fs/ocfs2/file.c +++ b/fs/ocfs2/file.c | |||
| @@ -1851,6 +1851,7 @@ relock: | |||
| 1851 | if (ret) | 1851 | if (ret) |
| 1852 | goto out_dio; | 1852 | goto out_dio; |
| 1853 | 1853 | ||
| 1854 | count = ocount; | ||
| 1854 | ret = generic_write_checks(file, ppos, &count, | 1855 | ret = generic_write_checks(file, ppos, &count, |
| 1855 | S_ISBLK(inode->i_mode)); | 1856 | S_ISBLK(inode->i_mode)); |
| 1856 | if (ret) | 1857 | if (ret) |
| @@ -1918,8 +1919,10 @@ out_sems: | |||
| 1918 | 1919 | ||
| 1919 | mutex_unlock(&inode->i_mutex); | 1920 | mutex_unlock(&inode->i_mutex); |
| 1920 | 1921 | ||
| 1922 | if (written) | ||
| 1923 | ret = written; | ||
| 1921 | mlog_exit(ret); | 1924 | mlog_exit(ret); |
| 1922 | return written ? written : ret; | 1925 | return ret; |
| 1923 | } | 1926 | } |
| 1924 | 1927 | ||
| 1925 | static int ocfs2_splice_to_file(struct pipe_inode_info *pipe, | 1928 | static int ocfs2_splice_to_file(struct pipe_inode_info *pipe, |
diff --git a/fs/ocfs2/journal.c b/fs/ocfs2/journal.c index f033760ecbea..c48b93ac6b65 100644 --- a/fs/ocfs2/journal.c +++ b/fs/ocfs2/journal.c | |||
| @@ -1954,10 +1954,16 @@ void ocfs2_orphan_scan_init(struct ocfs2_super *osb) | |||
| 1954 | os->os_osb = osb; | 1954 | os->os_osb = osb; |
| 1955 | os->os_count = 0; | 1955 | os->os_count = 0; |
| 1956 | os->os_seqno = 0; | 1956 | os->os_seqno = 0; |
| 1957 | os->os_scantime = CURRENT_TIME; | ||
| 1958 | mutex_init(&os->os_lock); | 1957 | mutex_init(&os->os_lock); |
| 1959 | INIT_DELAYED_WORK(&os->os_orphan_scan_work, ocfs2_orphan_scan_work); | 1958 | INIT_DELAYED_WORK(&os->os_orphan_scan_work, ocfs2_orphan_scan_work); |
| 1959 | } | ||
| 1960 | 1960 | ||
| 1961 | void ocfs2_orphan_scan_start(struct ocfs2_super *osb) | ||
| 1962 | { | ||
| 1963 | struct ocfs2_orphan_scan *os; | ||
| 1964 | |||
| 1965 | os = &osb->osb_orphan_scan; | ||
| 1966 | os->os_scantime = CURRENT_TIME; | ||
| 1961 | if (ocfs2_is_hard_readonly(osb) || ocfs2_mount_local(osb)) | 1967 | if (ocfs2_is_hard_readonly(osb) || ocfs2_mount_local(osb)) |
| 1962 | atomic_set(&os->os_state, ORPHAN_SCAN_INACTIVE); | 1968 | atomic_set(&os->os_state, ORPHAN_SCAN_INACTIVE); |
| 1963 | else { | 1969 | else { |
diff --git a/fs/ocfs2/journal.h b/fs/ocfs2/journal.h index 5432c7f79cc6..2c3222aec622 100644 --- a/fs/ocfs2/journal.h +++ b/fs/ocfs2/journal.h | |||
| @@ -145,6 +145,7 @@ static inline void ocfs2_inode_set_new(struct ocfs2_super *osb, | |||
| 145 | 145 | ||
| 146 | /* Exported only for the journal struct init code in super.c. Do not call. */ | 146 | /* Exported only for the journal struct init code in super.c. Do not call. */ |
| 147 | void ocfs2_orphan_scan_init(struct ocfs2_super *osb); | 147 | void ocfs2_orphan_scan_init(struct ocfs2_super *osb); |
| 148 | void ocfs2_orphan_scan_start(struct ocfs2_super *osb); | ||
| 148 | void ocfs2_orphan_scan_stop(struct ocfs2_super *osb); | 149 | void ocfs2_orphan_scan_stop(struct ocfs2_super *osb); |
| 149 | void ocfs2_orphan_scan_exit(struct ocfs2_super *osb); | 150 | void ocfs2_orphan_scan_exit(struct ocfs2_super *osb); |
| 150 | 151 | ||
| @@ -329,20 +330,27 @@ int ocfs2_journal_dirty(handle_t *handle, | |||
| 329 | /* extended attribute block update */ | 330 | /* extended attribute block update */ |
| 330 | #define OCFS2_XATTR_BLOCK_UPDATE_CREDITS 1 | 331 | #define OCFS2_XATTR_BLOCK_UPDATE_CREDITS 1 |
| 331 | 332 | ||
| 333 | /* Update of a single quota block */ | ||
| 334 | #define OCFS2_QUOTA_BLOCK_UPDATE_CREDITS 1 | ||
| 335 | |||
| 332 | /* global quotafile inode update, data block */ | 336 | /* global quotafile inode update, data block */ |
| 333 | #define OCFS2_QINFO_WRITE_CREDITS (OCFS2_INODE_UPDATE_CREDITS + 1) | 337 | #define OCFS2_QINFO_WRITE_CREDITS (OCFS2_INODE_UPDATE_CREDITS + \ |
| 338 | OCFS2_QUOTA_BLOCK_UPDATE_CREDITS) | ||
| 334 | 339 | ||
| 340 | #define OCFS2_LOCAL_QINFO_WRITE_CREDITS OCFS2_QUOTA_BLOCK_UPDATE_CREDITS | ||
| 335 | /* | 341 | /* |
| 336 | * The two writes below can accidentally see global info dirty due | 342 | * The two writes below can accidentally see global info dirty due |
| 337 | * to set_info() quotactl so make them prepared for the writes. | 343 | * to set_info() quotactl so make them prepared for the writes. |
| 338 | */ | 344 | */ |
| 339 | /* quota data block, global info */ | 345 | /* quota data block, global info */ |
| 340 | /* Write to local quota file */ | 346 | /* Write to local quota file */ |
| 341 | #define OCFS2_QWRITE_CREDITS (OCFS2_QINFO_WRITE_CREDITS + 1) | 347 | #define OCFS2_QWRITE_CREDITS (OCFS2_QINFO_WRITE_CREDITS + \ |
| 348 | OCFS2_QUOTA_BLOCK_UPDATE_CREDITS) | ||
| 342 | 349 | ||
| 343 | /* global quota data block, local quota data block, global quota inode, | 350 | /* global quota data block, local quota data block, global quota inode, |
| 344 | * global quota info */ | 351 | * global quota info */ |
| 345 | #define OCFS2_QSYNC_CREDITS (OCFS2_INODE_UPDATE_CREDITS + 3) | 352 | #define OCFS2_QSYNC_CREDITS (OCFS2_QINFO_WRITE_CREDITS + \ |
| 353 | 2 * OCFS2_QUOTA_BLOCK_UPDATE_CREDITS) | ||
| 346 | 354 | ||
| 347 | static inline int ocfs2_quota_trans_credits(struct super_block *sb) | 355 | static inline int ocfs2_quota_trans_credits(struct super_block *sb) |
| 348 | { | 356 | { |
| @@ -355,11 +363,6 @@ static inline int ocfs2_quota_trans_credits(struct super_block *sb) | |||
| 355 | return credits; | 363 | return credits; |
| 356 | } | 364 | } |
| 357 | 365 | ||
| 358 | /* Number of credits needed for removing quota structure from file */ | ||
| 359 | int ocfs2_calc_qdel_credits(struct super_block *sb, int type); | ||
| 360 | /* Number of credits needed for initialization of new quota structure */ | ||
| 361 | int ocfs2_calc_qinit_credits(struct super_block *sb, int type); | ||
| 362 | |||
| 363 | /* group extend. inode update and last group update. */ | 366 | /* group extend. inode update and last group update. */ |
| 364 | #define OCFS2_GROUP_EXTEND_CREDITS (OCFS2_INODE_UPDATE_CREDITS + 1) | 367 | #define OCFS2_GROUP_EXTEND_CREDITS (OCFS2_INODE_UPDATE_CREDITS + 1) |
| 365 | 368 | ||
diff --git a/fs/ocfs2/ocfs2.h b/fs/ocfs2/ocfs2.h index c9345ebb8493..39e1d5a39505 100644 --- a/fs/ocfs2/ocfs2.h +++ b/fs/ocfs2/ocfs2.h | |||
| @@ -224,10 +224,12 @@ enum ocfs2_mount_options | |||
| 224 | OCFS2_MOUNT_GRPQUOTA = 1 << 10, /* We support group quotas */ | 224 | OCFS2_MOUNT_GRPQUOTA = 1 << 10, /* We support group quotas */ |
| 225 | }; | 225 | }; |
| 226 | 226 | ||
| 227 | #define OCFS2_OSB_SOFT_RO 0x0001 | 227 | #define OCFS2_OSB_SOFT_RO 0x0001 |
| 228 | #define OCFS2_OSB_HARD_RO 0x0002 | 228 | #define OCFS2_OSB_HARD_RO 0x0002 |
| 229 | #define OCFS2_OSB_ERROR_FS 0x0004 | 229 | #define OCFS2_OSB_ERROR_FS 0x0004 |
| 230 | #define OCFS2_DEFAULT_ATIME_QUANTUM 60 | 230 | #define OCFS2_OSB_DROP_DENTRY_LOCK_IMMED 0x0008 |
| 231 | |||
| 232 | #define OCFS2_DEFAULT_ATIME_QUANTUM 60 | ||
| 231 | 233 | ||
| 232 | struct ocfs2_journal; | 234 | struct ocfs2_journal; |
| 233 | struct ocfs2_slot_info; | 235 | struct ocfs2_slot_info; |
| @@ -490,6 +492,18 @@ static inline void ocfs2_set_osb_flag(struct ocfs2_super *osb, | |||
| 490 | spin_unlock(&osb->osb_lock); | 492 | spin_unlock(&osb->osb_lock); |
| 491 | } | 493 | } |
| 492 | 494 | ||
| 495 | |||
| 496 | static inline unsigned long ocfs2_test_osb_flag(struct ocfs2_super *osb, | ||
| 497 | unsigned long flag) | ||
| 498 | { | ||
| 499 | unsigned long ret; | ||
| 500 | |||
| 501 | spin_lock(&osb->osb_lock); | ||
| 502 | ret = osb->osb_flags & flag; | ||
| 503 | spin_unlock(&osb->osb_lock); | ||
| 504 | return ret; | ||
| 505 | } | ||
| 506 | |||
| 493 | static inline void ocfs2_set_ro_flag(struct ocfs2_super *osb, | 507 | static inline void ocfs2_set_ro_flag(struct ocfs2_super *osb, |
| 494 | int hard) | 508 | int hard) |
| 495 | { | 509 | { |
diff --git a/fs/ocfs2/ocfs2_lockid.h b/fs/ocfs2/ocfs2_lockid.h index fcdba091af3d..c212cf5a2bdf 100644 --- a/fs/ocfs2/ocfs2_lockid.h +++ b/fs/ocfs2/ocfs2_lockid.h | |||
| @@ -108,6 +108,7 @@ static char *ocfs2_lock_type_strings[] = { | |||
| 108 | [OCFS2_LOCK_TYPE_OPEN] = "Open", | 108 | [OCFS2_LOCK_TYPE_OPEN] = "Open", |
| 109 | [OCFS2_LOCK_TYPE_FLOCK] = "Flock", | 109 | [OCFS2_LOCK_TYPE_FLOCK] = "Flock", |
| 110 | [OCFS2_LOCK_TYPE_QINFO] = "Quota", | 110 | [OCFS2_LOCK_TYPE_QINFO] = "Quota", |
| 111 | [OCFS2_LOCK_TYPE_NFS_SYNC] = "NFSSync", | ||
| 111 | [OCFS2_LOCK_TYPE_ORPHAN_SCAN] = "OrphanScan", | 112 | [OCFS2_LOCK_TYPE_ORPHAN_SCAN] = "OrphanScan", |
| 112 | }; | 113 | }; |
| 113 | 114 | ||
diff --git a/fs/ocfs2/quota.h b/fs/ocfs2/quota.h index 7365e2e08706..3fb96fcd4c81 100644 --- a/fs/ocfs2/quota.h +++ b/fs/ocfs2/quota.h | |||
| @@ -50,7 +50,6 @@ struct ocfs2_mem_dqinfo { | |||
| 50 | unsigned int dqi_chunks; /* Number of chunks in local quota file */ | 50 | unsigned int dqi_chunks; /* Number of chunks in local quota file */ |
| 51 | unsigned int dqi_blocks; /* Number of blocks allocated for local quota file */ | 51 | unsigned int dqi_blocks; /* Number of blocks allocated for local quota file */ |
| 52 | unsigned int dqi_syncms; /* How often should we sync with other nodes */ | 52 | unsigned int dqi_syncms; /* How often should we sync with other nodes */ |
| 53 | unsigned int dqi_syncjiff; /* Precomputed dqi_syncms in jiffies */ | ||
| 54 | struct list_head dqi_chunk; /* List of chunks */ | 53 | struct list_head dqi_chunk; /* List of chunks */ |
| 55 | struct inode *dqi_gqinode; /* Global quota file inode */ | 54 | struct inode *dqi_gqinode; /* Global quota file inode */ |
| 56 | struct ocfs2_lock_res dqi_gqlock; /* Lock protecting quota information structure */ | 55 | struct ocfs2_lock_res dqi_gqlock; /* Lock protecting quota information structure */ |
diff --git a/fs/ocfs2/quota_global.c b/fs/ocfs2/quota_global.c index edfa60cd155c..44f2a5e1d042 100644 --- a/fs/ocfs2/quota_global.c +++ b/fs/ocfs2/quota_global.c | |||
| @@ -23,6 +23,7 @@ | |||
| 23 | #include "sysfile.h" | 23 | #include "sysfile.h" |
| 24 | #include "dlmglue.h" | 24 | #include "dlmglue.h" |
| 25 | #include "uptodate.h" | 25 | #include "uptodate.h" |
| 26 | #include "super.h" | ||
| 26 | #include "quota.h" | 27 | #include "quota.h" |
| 27 | 28 | ||
| 28 | static struct workqueue_struct *ocfs2_quota_wq = NULL; | 29 | static struct workqueue_struct *ocfs2_quota_wq = NULL; |
| @@ -69,6 +70,7 @@ static void ocfs2_global_mem2diskdqb(void *dp, struct dquot *dquot) | |||
| 69 | d->dqb_curspace = cpu_to_le64(m->dqb_curspace); | 70 | d->dqb_curspace = cpu_to_le64(m->dqb_curspace); |
| 70 | d->dqb_btime = cpu_to_le64(m->dqb_btime); | 71 | d->dqb_btime = cpu_to_le64(m->dqb_btime); |
| 71 | d->dqb_itime = cpu_to_le64(m->dqb_itime); | 72 | d->dqb_itime = cpu_to_le64(m->dqb_itime); |
| 73 | d->dqb_pad1 = d->dqb_pad2 = 0; | ||
| 72 | } | 74 | } |
| 73 | 75 | ||
| 74 | static int ocfs2_global_is_id(void *dp, struct dquot *dquot) | 76 | static int ocfs2_global_is_id(void *dp, struct dquot *dquot) |
| @@ -113,6 +115,15 @@ int ocfs2_read_quota_block(struct inode *inode, u64 v_block, | |||
| 113 | int rc = 0; | 115 | int rc = 0; |
| 114 | struct buffer_head *tmp = *bh; | 116 | struct buffer_head *tmp = *bh; |
| 115 | 117 | ||
| 118 | if (i_size_read(inode) >> inode->i_sb->s_blocksize_bits <= v_block) { | ||
| 119 | ocfs2_error(inode->i_sb, | ||
| 120 | "Quota file %llu is probably corrupted! Requested " | ||
| 121 | "to read block %Lu but file has size only %Lu\n", | ||
| 122 | (unsigned long long)OCFS2_I(inode)->ip_blkno, | ||
| 123 | (unsigned long long)v_block, | ||
| 124 | (unsigned long long)i_size_read(inode)); | ||
| 125 | return -EIO; | ||
| 126 | } | ||
| 116 | rc = ocfs2_read_virt_blocks(inode, v_block, 1, &tmp, 0, | 127 | rc = ocfs2_read_virt_blocks(inode, v_block, 1, &tmp, 0, |
| 117 | ocfs2_validate_quota_block); | 128 | ocfs2_validate_quota_block); |
| 118 | if (rc) | 129 | if (rc) |
| @@ -211,14 +222,13 @@ ssize_t ocfs2_quota_write(struct super_block *sb, int type, | |||
| 211 | 222 | ||
| 212 | mutex_lock_nested(&gqinode->i_mutex, I_MUTEX_QUOTA); | 223 | mutex_lock_nested(&gqinode->i_mutex, I_MUTEX_QUOTA); |
| 213 | if (gqinode->i_size < off + len) { | 224 | if (gqinode->i_size < off + len) { |
| 214 | down_write(&OCFS2_I(gqinode)->ip_alloc_sem); | 225 | loff_t rounded_end = |
| 215 | err = ocfs2_extend_no_holes(gqinode, off + len, off); | 226 | ocfs2_align_bytes_to_blocks(sb, off + len); |
| 216 | up_write(&OCFS2_I(gqinode)->ip_alloc_sem); | 227 | |
| 217 | if (err < 0) | 228 | /* Space is already allocated in ocfs2_global_read_dquot() */ |
| 218 | goto out; | ||
| 219 | err = ocfs2_simple_size_update(gqinode, | 229 | err = ocfs2_simple_size_update(gqinode, |
| 220 | oinfo->dqi_gqi_bh, | 230 | oinfo->dqi_gqi_bh, |
| 221 | off + len); | 231 | rounded_end); |
| 222 | if (err < 0) | 232 | if (err < 0) |
| 223 | goto out; | 233 | goto out; |
| 224 | new = 1; | 234 | new = 1; |
| @@ -234,7 +244,7 @@ ssize_t ocfs2_quota_write(struct super_block *sb, int type, | |||
| 234 | } | 244 | } |
| 235 | if (err) { | 245 | if (err) { |
| 236 | mlog_errno(err); | 246 | mlog_errno(err); |
| 237 | return err; | 247 | goto out; |
| 238 | } | 248 | } |
| 239 | lock_buffer(bh); | 249 | lock_buffer(bh); |
| 240 | if (new) | 250 | if (new) |
| @@ -342,7 +352,6 @@ int ocfs2_global_read_info(struct super_block *sb, int type) | |||
| 342 | info->dqi_bgrace = le32_to_cpu(dinfo.dqi_bgrace); | 352 | info->dqi_bgrace = le32_to_cpu(dinfo.dqi_bgrace); |
| 343 | info->dqi_igrace = le32_to_cpu(dinfo.dqi_igrace); | 353 | info->dqi_igrace = le32_to_cpu(dinfo.dqi_igrace); |
| 344 | oinfo->dqi_syncms = le32_to_cpu(dinfo.dqi_syncms); | 354 | oinfo->dqi_syncms = le32_to_cpu(dinfo.dqi_syncms); |
| 345 | oinfo->dqi_syncjiff = msecs_to_jiffies(oinfo->dqi_syncms); | ||
| 346 | oinfo->dqi_gi.dqi_blocks = le32_to_cpu(dinfo.dqi_blocks); | 355 | oinfo->dqi_gi.dqi_blocks = le32_to_cpu(dinfo.dqi_blocks); |
| 347 | oinfo->dqi_gi.dqi_free_blk = le32_to_cpu(dinfo.dqi_free_blk); | 356 | oinfo->dqi_gi.dqi_free_blk = le32_to_cpu(dinfo.dqi_free_blk); |
| 348 | oinfo->dqi_gi.dqi_free_entry = le32_to_cpu(dinfo.dqi_free_entry); | 357 | oinfo->dqi_gi.dqi_free_entry = le32_to_cpu(dinfo.dqi_free_entry); |
| @@ -352,7 +361,7 @@ int ocfs2_global_read_info(struct super_block *sb, int type) | |||
| 352 | oinfo->dqi_gi.dqi_qtree_depth = qtree_depth(&oinfo->dqi_gi); | 361 | oinfo->dqi_gi.dqi_qtree_depth = qtree_depth(&oinfo->dqi_gi); |
| 353 | INIT_DELAYED_WORK(&oinfo->dqi_sync_work, qsync_work_fn); | 362 | INIT_DELAYED_WORK(&oinfo->dqi_sync_work, qsync_work_fn); |
| 354 | queue_delayed_work(ocfs2_quota_wq, &oinfo->dqi_sync_work, | 363 | queue_delayed_work(ocfs2_quota_wq, &oinfo->dqi_sync_work, |
| 355 | oinfo->dqi_syncjiff); | 364 | msecs_to_jiffies(oinfo->dqi_syncms)); |
| 356 | 365 | ||
| 357 | out_err: | 366 | out_err: |
| 358 | mlog_exit(status); | 367 | mlog_exit(status); |
| @@ -402,13 +411,36 @@ int ocfs2_global_write_info(struct super_block *sb, int type) | |||
| 402 | return err; | 411 | return err; |
| 403 | } | 412 | } |
| 404 | 413 | ||
| 414 | static int ocfs2_global_qinit_alloc(struct super_block *sb, int type) | ||
| 415 | { | ||
| 416 | struct ocfs2_mem_dqinfo *oinfo = sb_dqinfo(sb, type)->dqi_priv; | ||
| 417 | |||
| 418 | /* | ||
| 419 | * We may need to allocate tree blocks and a leaf block but not the | ||
| 420 | * root block | ||
| 421 | */ | ||
| 422 | return oinfo->dqi_gi.dqi_qtree_depth; | ||
| 423 | } | ||
| 424 | |||
| 425 | static int ocfs2_calc_global_qinit_credits(struct super_block *sb, int type) | ||
| 426 | { | ||
| 427 | /* We modify all the allocated blocks, tree root, and info block */ | ||
| 428 | return (ocfs2_global_qinit_alloc(sb, type) + 2) * | ||
| 429 | OCFS2_QUOTA_BLOCK_UPDATE_CREDITS; | ||
| 430 | } | ||
| 431 | |||
| 405 | /* Read in information from global quota file and acquire a reference to it. | 432 | /* Read in information from global quota file and acquire a reference to it. |
| 406 | * dquot_acquire() has already started the transaction and locked quota file */ | 433 | * dquot_acquire() has already started the transaction and locked quota file */ |
| 407 | int ocfs2_global_read_dquot(struct dquot *dquot) | 434 | int ocfs2_global_read_dquot(struct dquot *dquot) |
| 408 | { | 435 | { |
| 409 | int err, err2, ex = 0; | 436 | int err, err2, ex = 0; |
| 410 | struct ocfs2_mem_dqinfo *info = | 437 | struct super_block *sb = dquot->dq_sb; |
| 411 | sb_dqinfo(dquot->dq_sb, dquot->dq_type)->dqi_priv; | 438 | int type = dquot->dq_type; |
| 439 | struct ocfs2_mem_dqinfo *info = sb_dqinfo(sb, type)->dqi_priv; | ||
| 440 | struct ocfs2_super *osb = OCFS2_SB(sb); | ||
| 441 | struct inode *gqinode = info->dqi_gqinode; | ||
| 442 | int need_alloc = ocfs2_global_qinit_alloc(sb, type); | ||
| 443 | handle_t *handle = NULL; | ||
| 412 | 444 | ||
| 413 | err = ocfs2_qinfo_lock(info, 0); | 445 | err = ocfs2_qinfo_lock(info, 0); |
| 414 | if (err < 0) | 446 | if (err < 0) |
| @@ -419,14 +451,33 @@ int ocfs2_global_read_dquot(struct dquot *dquot) | |||
| 419 | OCFS2_DQUOT(dquot)->dq_use_count++; | 451 | OCFS2_DQUOT(dquot)->dq_use_count++; |
| 420 | OCFS2_DQUOT(dquot)->dq_origspace = dquot->dq_dqb.dqb_curspace; | 452 | OCFS2_DQUOT(dquot)->dq_origspace = dquot->dq_dqb.dqb_curspace; |
| 421 | OCFS2_DQUOT(dquot)->dq_originodes = dquot->dq_dqb.dqb_curinodes; | 453 | OCFS2_DQUOT(dquot)->dq_originodes = dquot->dq_dqb.dqb_curinodes; |
| 454 | ocfs2_qinfo_unlock(info, 0); | ||
| 455 | |||
| 422 | if (!dquot->dq_off) { /* No real quota entry? */ | 456 | if (!dquot->dq_off) { /* No real quota entry? */ |
| 423 | /* Upgrade to exclusive lock for allocation */ | ||
| 424 | ocfs2_qinfo_unlock(info, 0); | ||
| 425 | err = ocfs2_qinfo_lock(info, 1); | ||
| 426 | if (err < 0) | ||
| 427 | goto out_qlock; | ||
| 428 | ex = 1; | 457 | ex = 1; |
| 458 | /* | ||
| 459 | * Add blocks to quota file before we start a transaction since | ||
| 460 | * locking allocators ranks above a transaction start | ||
| 461 | */ | ||
| 462 | WARN_ON(journal_current_handle()); | ||
| 463 | down_write(&OCFS2_I(gqinode)->ip_alloc_sem); | ||
| 464 | err = ocfs2_extend_no_holes(gqinode, | ||
| 465 | gqinode->i_size + (need_alloc << sb->s_blocksize_bits), | ||
| 466 | gqinode->i_size); | ||
| 467 | up_write(&OCFS2_I(gqinode)->ip_alloc_sem); | ||
| 468 | if (err < 0) | ||
| 469 | goto out; | ||
| 429 | } | 470 | } |
| 471 | |||
| 472 | handle = ocfs2_start_trans(osb, | ||
| 473 | ocfs2_calc_global_qinit_credits(sb, type)); | ||
| 474 | if (IS_ERR(handle)) { | ||
| 475 | err = PTR_ERR(handle); | ||
| 476 | goto out; | ||
| 477 | } | ||
| 478 | err = ocfs2_qinfo_lock(info, ex); | ||
| 479 | if (err < 0) | ||
| 480 | goto out_trans; | ||
| 430 | err = qtree_write_dquot(&info->dqi_gi, dquot); | 481 | err = qtree_write_dquot(&info->dqi_gi, dquot); |
| 431 | if (ex && info_dirty(sb_dqinfo(dquot->dq_sb, dquot->dq_type))) { | 482 | if (ex && info_dirty(sb_dqinfo(dquot->dq_sb, dquot->dq_type))) { |
| 432 | err2 = __ocfs2_global_write_info(dquot->dq_sb, dquot->dq_type); | 483 | err2 = __ocfs2_global_write_info(dquot->dq_sb, dquot->dq_type); |
| @@ -438,6 +489,9 @@ out_qlock: | |||
| 438 | ocfs2_qinfo_unlock(info, 1); | 489 | ocfs2_qinfo_unlock(info, 1); |
| 439 | else | 490 | else |
| 440 | ocfs2_qinfo_unlock(info, 0); | 491 | ocfs2_qinfo_unlock(info, 0); |
| 492 | out_trans: | ||
| 493 | if (handle) | ||
| 494 | ocfs2_commit_trans(osb, handle); | ||
| 441 | out: | 495 | out: |
| 442 | if (err < 0) | 496 | if (err < 0) |
| 443 | mlog_errno(err); | 497 | mlog_errno(err); |
| @@ -607,7 +661,7 @@ static void qsync_work_fn(struct work_struct *work) | |||
| 607 | 661 | ||
| 608 | dquot_scan_active(sb, ocfs2_sync_dquot_helper, oinfo->dqi_type); | 662 | dquot_scan_active(sb, ocfs2_sync_dquot_helper, oinfo->dqi_type); |
| 609 | queue_delayed_work(ocfs2_quota_wq, &oinfo->dqi_sync_work, | 663 | queue_delayed_work(ocfs2_quota_wq, &oinfo->dqi_sync_work, |
| 610 | oinfo->dqi_syncjiff); | 664 | msecs_to_jiffies(oinfo->dqi_syncms)); |
| 611 | } | 665 | } |
| 612 | 666 | ||
| 613 | /* | 667 | /* |
| @@ -635,20 +689,18 @@ out: | |||
| 635 | return status; | 689 | return status; |
| 636 | } | 690 | } |
| 637 | 691 | ||
| 638 | int ocfs2_calc_qdel_credits(struct super_block *sb, int type) | 692 | static int ocfs2_calc_qdel_credits(struct super_block *sb, int type) |
| 639 | { | 693 | { |
| 640 | struct ocfs2_mem_dqinfo *oinfo; | 694 | struct ocfs2_mem_dqinfo *oinfo = sb_dqinfo(sb, type)->dqi_priv; |
| 641 | int features[MAXQUOTAS] = { OCFS2_FEATURE_RO_COMPAT_USRQUOTA, | 695 | /* |
| 642 | OCFS2_FEATURE_RO_COMPAT_GRPQUOTA }; | 696 | * We modify tree, leaf block, global info, local chunk header, |
| 643 | 697 | * global and local inode; OCFS2_QINFO_WRITE_CREDITS already | |
| 644 | if (!OCFS2_HAS_RO_COMPAT_FEATURE(sb, features[type])) | 698 | * accounts for inode update |
| 645 | return 0; | 699 | */ |
| 646 | 700 | return (oinfo->dqi_gi.dqi_qtree_depth + 2) * | |
| 647 | oinfo = sb_dqinfo(sb, type)->dqi_priv; | 701 | OCFS2_QUOTA_BLOCK_UPDATE_CREDITS + |
| 648 | /* We modify tree, leaf block, global info, local chunk header, | 702 | OCFS2_QINFO_WRITE_CREDITS + |
| 649 | * global and local inode */ | 703 | OCFS2_INODE_UPDATE_CREDITS; |
| 650 | return oinfo->dqi_gi.dqi_qtree_depth + 2 + 1 + | ||
| 651 | 2 * OCFS2_INODE_UPDATE_CREDITS; | ||
| 652 | } | 704 | } |
| 653 | 705 | ||
| 654 | static int ocfs2_release_dquot(struct dquot *dquot) | 706 | static int ocfs2_release_dquot(struct dquot *dquot) |
| @@ -680,33 +732,10 @@ out: | |||
| 680 | return status; | 732 | return status; |
| 681 | } | 733 | } |
| 682 | 734 | ||
| 683 | int ocfs2_calc_qinit_credits(struct super_block *sb, int type) | ||
| 684 | { | ||
| 685 | struct ocfs2_mem_dqinfo *oinfo; | ||
| 686 | int features[MAXQUOTAS] = { OCFS2_FEATURE_RO_COMPAT_USRQUOTA, | ||
| 687 | OCFS2_FEATURE_RO_COMPAT_GRPQUOTA }; | ||
| 688 | struct ocfs2_dinode *lfe, *gfe; | ||
| 689 | |||
| 690 | if (!OCFS2_HAS_RO_COMPAT_FEATURE(sb, features[type])) | ||
| 691 | return 0; | ||
| 692 | |||
| 693 | oinfo = sb_dqinfo(sb, type)->dqi_priv; | ||
| 694 | gfe = (struct ocfs2_dinode *)oinfo->dqi_gqi_bh->b_data; | ||
| 695 | lfe = (struct ocfs2_dinode *)oinfo->dqi_lqi_bh->b_data; | ||
| 696 | /* We can extend local file + global file. In local file we | ||
| 697 | * can modify info, chunk header block and dquot block. In | ||
| 698 | * global file we can modify info, tree and leaf block */ | ||
| 699 | return ocfs2_calc_extend_credits(sb, &lfe->id2.i_list, 0) + | ||
| 700 | ocfs2_calc_extend_credits(sb, &gfe->id2.i_list, 0) + | ||
| 701 | 3 + oinfo->dqi_gi.dqi_qtree_depth + 2; | ||
| 702 | } | ||
| 703 | |||
| 704 | static int ocfs2_acquire_dquot(struct dquot *dquot) | 735 | static int ocfs2_acquire_dquot(struct dquot *dquot) |
| 705 | { | 736 | { |
| 706 | handle_t *handle; | ||
| 707 | struct ocfs2_mem_dqinfo *oinfo = | 737 | struct ocfs2_mem_dqinfo *oinfo = |
| 708 | sb_dqinfo(dquot->dq_sb, dquot->dq_type)->dqi_priv; | 738 | sb_dqinfo(dquot->dq_sb, dquot->dq_type)->dqi_priv; |
| 709 | struct ocfs2_super *osb = OCFS2_SB(dquot->dq_sb); | ||
| 710 | int status = 0; | 739 | int status = 0; |
| 711 | 740 | ||
| 712 | mlog_entry("id=%u, type=%d", dquot->dq_id, dquot->dq_type); | 741 | mlog_entry("id=%u, type=%d", dquot->dq_id, dquot->dq_type); |
| @@ -715,16 +744,7 @@ static int ocfs2_acquire_dquot(struct dquot *dquot) | |||
| 715 | status = ocfs2_lock_global_qf(oinfo, 1); | 744 | status = ocfs2_lock_global_qf(oinfo, 1); |
| 716 | if (status < 0) | 745 | if (status < 0) |
| 717 | goto out; | 746 | goto out; |
| 718 | handle = ocfs2_start_trans(osb, | ||
| 719 | ocfs2_calc_qinit_credits(dquot->dq_sb, dquot->dq_type)); | ||
| 720 | if (IS_ERR(handle)) { | ||
| 721 | status = PTR_ERR(handle); | ||
| 722 | mlog_errno(status); | ||
| 723 | goto out_ilock; | ||
| 724 | } | ||
| 725 | status = dquot_acquire(dquot); | 747 | status = dquot_acquire(dquot); |
| 726 | ocfs2_commit_trans(osb, handle); | ||
| 727 | out_ilock: | ||
| 728 | ocfs2_unlock_global_qf(oinfo, 1); | 748 | ocfs2_unlock_global_qf(oinfo, 1); |
| 729 | out: | 749 | out: |
| 730 | mlog_exit(status); | 750 | mlog_exit(status); |
diff --git a/fs/ocfs2/quota_local.c b/fs/ocfs2/quota_local.c index 5a460fa82553..bdb09cb6e1fe 100644 --- a/fs/ocfs2/quota_local.c +++ b/fs/ocfs2/quota_local.c | |||
| @@ -20,6 +20,7 @@ | |||
| 20 | #include "sysfile.h" | 20 | #include "sysfile.h" |
| 21 | #include "dlmglue.h" | 21 | #include "dlmglue.h" |
| 22 | #include "quota.h" | 22 | #include "quota.h" |
| 23 | #include "uptodate.h" | ||
| 23 | 24 | ||
| 24 | /* Number of local quota structures per block */ | 25 | /* Number of local quota structures per block */ |
| 25 | static inline unsigned int ol_quota_entries_per_block(struct super_block *sb) | 26 | static inline unsigned int ol_quota_entries_per_block(struct super_block *sb) |
| @@ -100,7 +101,8 @@ static int ocfs2_modify_bh(struct inode *inode, struct buffer_head *bh, | |||
| 100 | handle_t *handle; | 101 | handle_t *handle; |
| 101 | int status; | 102 | int status; |
| 102 | 103 | ||
| 103 | handle = ocfs2_start_trans(OCFS2_SB(sb), 1); | 104 | handle = ocfs2_start_trans(OCFS2_SB(sb), |
| 105 | OCFS2_QUOTA_BLOCK_UPDATE_CREDITS); | ||
| 104 | if (IS_ERR(handle)) { | 106 | if (IS_ERR(handle)) { |
| 105 | status = PTR_ERR(handle); | 107 | status = PTR_ERR(handle); |
| 106 | mlog_errno(status); | 108 | mlog_errno(status); |
| @@ -610,7 +612,8 @@ int ocfs2_finish_quota_recovery(struct ocfs2_super *osb, | |||
| 610 | goto out_bh; | 612 | goto out_bh; |
| 611 | /* Mark quota file as clean if we are recovering quota file of | 613 | /* Mark quota file as clean if we are recovering quota file of |
| 612 | * some other node. */ | 614 | * some other node. */ |
| 613 | handle = ocfs2_start_trans(osb, 1); | 615 | handle = ocfs2_start_trans(osb, |
| 616 | OCFS2_LOCAL_QINFO_WRITE_CREDITS); | ||
| 614 | if (IS_ERR(handle)) { | 617 | if (IS_ERR(handle)) { |
| 615 | status = PTR_ERR(handle); | 618 | status = PTR_ERR(handle); |
| 616 | mlog_errno(status); | 619 | mlog_errno(status); |
| @@ -940,7 +943,7 @@ static struct ocfs2_quota_chunk *ocfs2_local_quota_add_chunk( | |||
| 940 | struct ocfs2_local_disk_chunk *dchunk; | 943 | struct ocfs2_local_disk_chunk *dchunk; |
| 941 | int status; | 944 | int status; |
| 942 | handle_t *handle; | 945 | handle_t *handle; |
| 943 | struct buffer_head *bh = NULL; | 946 | struct buffer_head *bh = NULL, *dbh = NULL; |
| 944 | u64 p_blkno; | 947 | u64 p_blkno; |
| 945 | 948 | ||
| 946 | /* We are protected by dqio_sem so no locking needed */ | 949 | /* We are protected by dqio_sem so no locking needed */ |
| @@ -964,32 +967,35 @@ static struct ocfs2_quota_chunk *ocfs2_local_quota_add_chunk( | |||
| 964 | mlog_errno(status); | 967 | mlog_errno(status); |
| 965 | goto out; | 968 | goto out; |
| 966 | } | 969 | } |
| 970 | /* Local quota info and two new blocks we initialize */ | ||
| 971 | handle = ocfs2_start_trans(OCFS2_SB(sb), | ||
| 972 | OCFS2_LOCAL_QINFO_WRITE_CREDITS + | ||
| 973 | 2 * OCFS2_QUOTA_BLOCK_UPDATE_CREDITS); | ||
| 974 | if (IS_ERR(handle)) { | ||
| 975 | status = PTR_ERR(handle); | ||
| 976 | mlog_errno(status); | ||
| 977 | goto out; | ||
| 978 | } | ||
| 967 | 979 | ||
| 980 | /* Initialize chunk header */ | ||
| 968 | down_read(&OCFS2_I(lqinode)->ip_alloc_sem); | 981 | down_read(&OCFS2_I(lqinode)->ip_alloc_sem); |
| 969 | status = ocfs2_extent_map_get_blocks(lqinode, oinfo->dqi_blocks, | 982 | status = ocfs2_extent_map_get_blocks(lqinode, oinfo->dqi_blocks, |
| 970 | &p_blkno, NULL, NULL); | 983 | &p_blkno, NULL, NULL); |
| 971 | up_read(&OCFS2_I(lqinode)->ip_alloc_sem); | 984 | up_read(&OCFS2_I(lqinode)->ip_alloc_sem); |
| 972 | if (status < 0) { | 985 | if (status < 0) { |
| 973 | mlog_errno(status); | 986 | mlog_errno(status); |
| 974 | goto out; | 987 | goto out_trans; |
| 975 | } | 988 | } |
| 976 | bh = sb_getblk(sb, p_blkno); | 989 | bh = sb_getblk(sb, p_blkno); |
| 977 | if (!bh) { | 990 | if (!bh) { |
| 978 | status = -ENOMEM; | 991 | status = -ENOMEM; |
| 979 | mlog_errno(status); | 992 | mlog_errno(status); |
| 980 | goto out; | 993 | goto out_trans; |
| 981 | } | 994 | } |
| 982 | dchunk = (struct ocfs2_local_disk_chunk *)bh->b_data; | 995 | dchunk = (struct ocfs2_local_disk_chunk *)bh->b_data; |
| 983 | 996 | ocfs2_set_new_buffer_uptodate(lqinode, bh); | |
| 984 | handle = ocfs2_start_trans(OCFS2_SB(sb), 2); | ||
| 985 | if (IS_ERR(handle)) { | ||
| 986 | status = PTR_ERR(handle); | ||
| 987 | mlog_errno(status); | ||
| 988 | goto out; | ||
| 989 | } | ||
| 990 | |||
| 991 | status = ocfs2_journal_access_dq(handle, lqinode, bh, | 997 | status = ocfs2_journal_access_dq(handle, lqinode, bh, |
| 992 | OCFS2_JOURNAL_ACCESS_WRITE); | 998 | OCFS2_JOURNAL_ACCESS_CREATE); |
| 993 | if (status < 0) { | 999 | if (status < 0) { |
| 994 | mlog_errno(status); | 1000 | mlog_errno(status); |
| 995 | goto out_trans; | 1001 | goto out_trans; |
| @@ -999,7 +1005,6 @@ static struct ocfs2_quota_chunk *ocfs2_local_quota_add_chunk( | |||
| 999 | memset(dchunk->dqc_bitmap, 0, | 1005 | memset(dchunk->dqc_bitmap, 0, |
| 1000 | sb->s_blocksize - sizeof(struct ocfs2_local_disk_chunk) - | 1006 | sb->s_blocksize - sizeof(struct ocfs2_local_disk_chunk) - |
| 1001 | OCFS2_QBLK_RESERVED_SPACE); | 1007 | OCFS2_QBLK_RESERVED_SPACE); |
| 1002 | set_buffer_uptodate(bh); | ||
| 1003 | unlock_buffer(bh); | 1008 | unlock_buffer(bh); |
| 1004 | status = ocfs2_journal_dirty(handle, bh); | 1009 | status = ocfs2_journal_dirty(handle, bh); |
| 1005 | if (status < 0) { | 1010 | if (status < 0) { |
| @@ -1007,6 +1012,38 @@ static struct ocfs2_quota_chunk *ocfs2_local_quota_add_chunk( | |||
| 1007 | goto out_trans; | 1012 | goto out_trans; |
| 1008 | } | 1013 | } |
| 1009 | 1014 | ||
| 1015 | /* Initialize new block with structures */ | ||
| 1016 | down_read(&OCFS2_I(lqinode)->ip_alloc_sem); | ||
| 1017 | status = ocfs2_extent_map_get_blocks(lqinode, oinfo->dqi_blocks + 1, | ||
| 1018 | &p_blkno, NULL, NULL); | ||
| 1019 | up_read(&OCFS2_I(lqinode)->ip_alloc_sem); | ||
| 1020 | if (status < 0) { | ||
| 1021 | mlog_errno(status); | ||
| 1022 | goto out_trans; | ||
| 1023 | } | ||
| 1024 | dbh = sb_getblk(sb, p_blkno); | ||
| 1025 | if (!dbh) { | ||
| 1026 | status = -ENOMEM; | ||
| 1027 | mlog_errno(status); | ||
| 1028 | goto out_trans; | ||
| 1029 | } | ||
| 1030 | ocfs2_set_new_buffer_uptodate(lqinode, dbh); | ||
| 1031 | status = ocfs2_journal_access_dq(handle, lqinode, dbh, | ||
| 1032 | OCFS2_JOURNAL_ACCESS_CREATE); | ||
| 1033 | if (status < 0) { | ||
| 1034 | mlog_errno(status); | ||
| 1035 | goto out_trans; | ||
| 1036 | } | ||
| 1037 | lock_buffer(dbh); | ||
| 1038 | memset(dbh->b_data, 0, sb->s_blocksize - OCFS2_QBLK_RESERVED_SPACE); | ||
| 1039 | unlock_buffer(dbh); | ||
| 1040 | status = ocfs2_journal_dirty(handle, dbh); | ||
| 1041 | if (status < 0) { | ||
| 1042 | mlog_errno(status); | ||
| 1043 | goto out_trans; | ||
| 1044 | } | ||
| 1045 | |||
| 1046 | /* Update local quotafile info */ | ||
| 1010 | oinfo->dqi_blocks += 2; | 1047 | oinfo->dqi_blocks += 2; |
| 1011 | oinfo->dqi_chunks++; | 1048 | oinfo->dqi_chunks++; |
| 1012 | status = ocfs2_local_write_info(sb, type); | 1049 | status = ocfs2_local_write_info(sb, type); |
| @@ -1031,6 +1068,7 @@ out_trans: | |||
| 1031 | ocfs2_commit_trans(OCFS2_SB(sb), handle); | 1068 | ocfs2_commit_trans(OCFS2_SB(sb), handle); |
| 1032 | out: | 1069 | out: |
| 1033 | brelse(bh); | 1070 | brelse(bh); |
| 1071 | brelse(dbh); | ||
| 1034 | kmem_cache_free(ocfs2_qf_chunk_cachep, chunk); | 1072 | kmem_cache_free(ocfs2_qf_chunk_cachep, chunk); |
| 1035 | return ERR_PTR(status); | 1073 | return ERR_PTR(status); |
| 1036 | } | 1074 | } |
| @@ -1048,6 +1086,8 @@ static struct ocfs2_quota_chunk *ocfs2_extend_local_quota_file( | |||
| 1048 | struct ocfs2_local_disk_chunk *dchunk; | 1086 | struct ocfs2_local_disk_chunk *dchunk; |
| 1049 | int epb = ol_quota_entries_per_block(sb); | 1087 | int epb = ol_quota_entries_per_block(sb); |
| 1050 | unsigned int chunk_blocks; | 1088 | unsigned int chunk_blocks; |
| 1089 | struct buffer_head *bh; | ||
| 1090 | u64 p_blkno; | ||
| 1051 | int status; | 1091 | int status; |
| 1052 | handle_t *handle; | 1092 | handle_t *handle; |
| 1053 | 1093 | ||
| @@ -1075,12 +1115,49 @@ static struct ocfs2_quota_chunk *ocfs2_extend_local_quota_file( | |||
| 1075 | mlog_errno(status); | 1115 | mlog_errno(status); |
| 1076 | goto out; | 1116 | goto out; |
| 1077 | } | 1117 | } |
| 1078 | handle = ocfs2_start_trans(OCFS2_SB(sb), 2); | 1118 | |
| 1119 | /* Get buffer from the just added block */ | ||
| 1120 | down_read(&OCFS2_I(lqinode)->ip_alloc_sem); | ||
| 1121 | status = ocfs2_extent_map_get_blocks(lqinode, oinfo->dqi_blocks, | ||
| 1122 | &p_blkno, NULL, NULL); | ||
| 1123 | up_read(&OCFS2_I(lqinode)->ip_alloc_sem); | ||
| 1124 | if (status < 0) { | ||
| 1125 | mlog_errno(status); | ||
| 1126 | goto out; | ||
| 1127 | } | ||
| 1128 | bh = sb_getblk(sb, p_blkno); | ||
| 1129 | if (!bh) { | ||
| 1130 | status = -ENOMEM; | ||
| 1131 | mlog_errno(status); | ||
| 1132 | goto out; | ||
| 1133 | } | ||
| 1134 | ocfs2_set_new_buffer_uptodate(lqinode, bh); | ||
| 1135 | |||
| 1136 | /* Local quota info, chunk header and the new block we initialize */ | ||
| 1137 | handle = ocfs2_start_trans(OCFS2_SB(sb), | ||
| 1138 | OCFS2_LOCAL_QINFO_WRITE_CREDITS + | ||
| 1139 | 2 * OCFS2_QUOTA_BLOCK_UPDATE_CREDITS); | ||
| 1079 | if (IS_ERR(handle)) { | 1140 | if (IS_ERR(handle)) { |
| 1080 | status = PTR_ERR(handle); | 1141 | status = PTR_ERR(handle); |
| 1081 | mlog_errno(status); | 1142 | mlog_errno(status); |
| 1082 | goto out; | 1143 | goto out; |
| 1083 | } | 1144 | } |
| 1145 | /* Zero created block */ | ||
| 1146 | status = ocfs2_journal_access_dq(handle, lqinode, bh, | ||
| 1147 | OCFS2_JOURNAL_ACCESS_CREATE); | ||
| 1148 | if (status < 0) { | ||
| 1149 | mlog_errno(status); | ||
| 1150 | goto out_trans; | ||
| 1151 | } | ||
| 1152 | lock_buffer(bh); | ||
| 1153 | memset(bh->b_data, 0, sb->s_blocksize); | ||
| 1154 | unlock_buffer(bh); | ||
| 1155 | status = ocfs2_journal_dirty(handle, bh); | ||
| 1156 | if (status < 0) { | ||
| 1157 | mlog_errno(status); | ||
| 1158 | goto out_trans; | ||
| 1159 | } | ||
| 1160 | /* Update chunk header */ | ||
| 1084 | status = ocfs2_journal_access_dq(handle, lqinode, chunk->qc_headerbh, | 1161 | status = ocfs2_journal_access_dq(handle, lqinode, chunk->qc_headerbh, |
| 1085 | OCFS2_JOURNAL_ACCESS_WRITE); | 1162 | OCFS2_JOURNAL_ACCESS_WRITE); |
| 1086 | if (status < 0) { | 1163 | if (status < 0) { |
| @@ -1097,6 +1174,7 @@ static struct ocfs2_quota_chunk *ocfs2_extend_local_quota_file( | |||
| 1097 | mlog_errno(status); | 1174 | mlog_errno(status); |
| 1098 | goto out_trans; | 1175 | goto out_trans; |
| 1099 | } | 1176 | } |
| 1177 | /* Update file header */ | ||
| 1100 | oinfo->dqi_blocks++; | 1178 | oinfo->dqi_blocks++; |
| 1101 | status = ocfs2_local_write_info(sb, type); | 1179 | status = ocfs2_local_write_info(sb, type); |
| 1102 | if (status < 0) { | 1180 | if (status < 0) { |
diff --git a/fs/ocfs2/stack_o2cb.c b/fs/ocfs2/stack_o2cb.c index 3f661376a2de..e49c41050264 100644 --- a/fs/ocfs2/stack_o2cb.c +++ b/fs/ocfs2/stack_o2cb.c | |||
| @@ -17,6 +17,7 @@ | |||
| 17 | * General Public License for more details. | 17 | * General Public License for more details. |
| 18 | */ | 18 | */ |
| 19 | 19 | ||
| 20 | #include <linux/kernel.h> | ||
| 20 | #include <linux/crc32.h> | 21 | #include <linux/crc32.h> |
| 21 | #include <linux/module.h> | 22 | #include <linux/module.h> |
| 22 | 23 | ||
| @@ -153,7 +154,7 @@ static int status_map[] = { | |||
| 153 | 154 | ||
| 154 | static int dlm_status_to_errno(enum dlm_status status) | 155 | static int dlm_status_to_errno(enum dlm_status status) |
| 155 | { | 156 | { |
| 156 | BUG_ON(status > (sizeof(status_map) / sizeof(status_map[0]))); | 157 | BUG_ON(status < 0 || status >= ARRAY_SIZE(status_map)); |
| 157 | 158 | ||
| 158 | return status_map[status]; | 159 | return status_map[status]; |
| 159 | } | 160 | } |
diff --git a/fs/ocfs2/super.c b/fs/ocfs2/super.c index 7efb349fb9bd..a3f8871d21fd 100644 --- a/fs/ocfs2/super.c +++ b/fs/ocfs2/super.c | |||
| @@ -777,6 +777,7 @@ static int ocfs2_sb_probe(struct super_block *sb, | |||
| 777 | } | 777 | } |
| 778 | di = (struct ocfs2_dinode *) (*bh)->b_data; | 778 | di = (struct ocfs2_dinode *) (*bh)->b_data; |
| 779 | memset(stats, 0, sizeof(struct ocfs2_blockcheck_stats)); | 779 | memset(stats, 0, sizeof(struct ocfs2_blockcheck_stats)); |
| 780 | spin_lock_init(&stats->b_lock); | ||
| 780 | status = ocfs2_verify_volume(di, *bh, blksize, stats); | 781 | status = ocfs2_verify_volume(di, *bh, blksize, stats); |
| 781 | if (status >= 0) | 782 | if (status >= 0) |
| 782 | goto bail; | 783 | goto bail; |
| @@ -1182,7 +1183,7 @@ static int ocfs2_fill_super(struct super_block *sb, void *data, int silent) | |||
| 1182 | wake_up(&osb->osb_mount_event); | 1183 | wake_up(&osb->osb_mount_event); |
| 1183 | 1184 | ||
| 1184 | /* Start this when the mount is almost sure of being successful */ | 1185 | /* Start this when the mount is almost sure of being successful */ |
| 1185 | ocfs2_orphan_scan_init(osb); | 1186 | ocfs2_orphan_scan_start(osb); |
| 1186 | 1187 | ||
| 1187 | mlog_exit(status); | 1188 | mlog_exit(status); |
| 1188 | return status; | 1189 | return status; |
| @@ -1213,14 +1214,31 @@ static int ocfs2_get_sb(struct file_system_type *fs_type, | |||
| 1213 | mnt); | 1214 | mnt); |
| 1214 | } | 1215 | } |
| 1215 | 1216 | ||
| 1217 | static void ocfs2_kill_sb(struct super_block *sb) | ||
| 1218 | { | ||
| 1219 | struct ocfs2_super *osb = OCFS2_SB(sb); | ||
| 1220 | |||
| 1221 | /* Failed mount? */ | ||
| 1222 | if (!osb || atomic_read(&osb->vol_state) == VOLUME_DISABLED) | ||
| 1223 | goto out; | ||
| 1224 | |||
| 1225 | /* Prevent further queueing of inode drop events */ | ||
| 1226 | spin_lock(&dentry_list_lock); | ||
| 1227 | ocfs2_set_osb_flag(osb, OCFS2_OSB_DROP_DENTRY_LOCK_IMMED); | ||
| 1228 | spin_unlock(&dentry_list_lock); | ||
| 1229 | /* Wait for work to finish and/or remove it */ | ||
| 1230 | cancel_work_sync(&osb->dentry_lock_work); | ||
| 1231 | out: | ||
| 1232 | kill_block_super(sb); | ||
| 1233 | } | ||
| 1234 | |||
| 1216 | static struct file_system_type ocfs2_fs_type = { | 1235 | static struct file_system_type ocfs2_fs_type = { |
| 1217 | .owner = THIS_MODULE, | 1236 | .owner = THIS_MODULE, |
| 1218 | .name = "ocfs2", | 1237 | .name = "ocfs2", |
| 1219 | .get_sb = ocfs2_get_sb, /* is this called when we mount | 1238 | .get_sb = ocfs2_get_sb, /* is this called when we mount |
| 1220 | * the fs? */ | 1239 | * the fs? */ |
| 1221 | .kill_sb = kill_block_super, /* set to the generic one | 1240 | .kill_sb = ocfs2_kill_sb, |
| 1222 | * right now, but do we | 1241 | |
| 1223 | * need to change that? */ | ||
| 1224 | .fs_flags = FS_REQUIRES_DEV|FS_RENAME_DOES_D_MOVE, | 1242 | .fs_flags = FS_REQUIRES_DEV|FS_RENAME_DOES_D_MOVE, |
| 1225 | .next = NULL | 1243 | .next = NULL |
| 1226 | }; | 1244 | }; |
| @@ -1819,6 +1837,12 @@ static void ocfs2_dismount_volume(struct super_block *sb, int mnt_err) | |||
| 1819 | 1837 | ||
| 1820 | debugfs_remove(osb->osb_ctxt); | 1838 | debugfs_remove(osb->osb_ctxt); |
| 1821 | 1839 | ||
| 1840 | /* | ||
| 1841 | * Flush inode dropping work queue so that deletes are | ||
| 1842 | * performed while the filesystem is still working | ||
| 1843 | */ | ||
| 1844 | ocfs2_drop_all_dl_inodes(osb); | ||
| 1845 | |||
| 1822 | /* Orphan scan should be stopped as early as possible */ | 1846 | /* Orphan scan should be stopped as early as possible */ |
| 1823 | ocfs2_orphan_scan_stop(osb); | 1847 | ocfs2_orphan_scan_stop(osb); |
| 1824 | 1848 | ||
| @@ -1981,6 +2005,8 @@ static int ocfs2_initialize_super(struct super_block *sb, | |||
| 1981 | snprintf(osb->dev_str, sizeof(osb->dev_str), "%u,%u", | 2005 | snprintf(osb->dev_str, sizeof(osb->dev_str), "%u,%u", |
| 1982 | MAJOR(osb->sb->s_dev), MINOR(osb->sb->s_dev)); | 2006 | MAJOR(osb->sb->s_dev), MINOR(osb->sb->s_dev)); |
| 1983 | 2007 | ||
| 2008 | ocfs2_orphan_scan_init(osb); | ||
| 2009 | |||
| 1984 | status = ocfs2_recovery_init(osb); | 2010 | status = ocfs2_recovery_init(osb); |
| 1985 | if (status) { | 2011 | if (status) { |
| 1986 | mlog(ML_ERROR, "Unable to initialize recovery state\n"); | 2012 | mlog(ML_ERROR, "Unable to initialize recovery state\n"); |
diff --git a/fs/ocfs2/xattr.c b/fs/ocfs2/xattr.c index ba320e250747..d1a27cda984f 100644 --- a/fs/ocfs2/xattr.c +++ b/fs/ocfs2/xattr.c | |||
| @@ -1052,7 +1052,8 @@ static int ocfs2_xattr_block_get(struct inode *inode, | |||
| 1052 | struct ocfs2_xattr_block *xb; | 1052 | struct ocfs2_xattr_block *xb; |
| 1053 | struct ocfs2_xattr_value_root *xv; | 1053 | struct ocfs2_xattr_value_root *xv; |
| 1054 | size_t size; | 1054 | size_t size; |
| 1055 | int ret = -ENODATA, name_offset, name_len, block_off, i; | 1055 | int ret = -ENODATA, name_offset, name_len, i; |
| 1056 | int uninitialized_var(block_off); | ||
| 1056 | 1057 | ||
| 1057 | xs->bucket = ocfs2_xattr_bucket_new(inode); | 1058 | xs->bucket = ocfs2_xattr_bucket_new(inode); |
| 1058 | if (!xs->bucket) { | 1059 | if (!xs->bucket) { |
| @@ -68,8 +68,8 @@ void pipe_double_lock(struct pipe_inode_info *pipe1, | |||
| 68 | pipe_lock_nested(pipe1, I_MUTEX_PARENT); | 68 | pipe_lock_nested(pipe1, I_MUTEX_PARENT); |
| 69 | pipe_lock_nested(pipe2, I_MUTEX_CHILD); | 69 | pipe_lock_nested(pipe2, I_MUTEX_CHILD); |
| 70 | } else { | 70 | } else { |
| 71 | pipe_lock_nested(pipe2, I_MUTEX_CHILD); | 71 | pipe_lock_nested(pipe2, I_MUTEX_PARENT); |
| 72 | pipe_lock_nested(pipe1, I_MUTEX_PARENT); | 72 | pipe_lock_nested(pipe1, I_MUTEX_CHILD); |
| 73 | } | 73 | } |
| 74 | } | 74 | } |
| 75 | 75 | ||
diff --git a/fs/proc/base.c b/fs/proc/base.c index 3ce5ae9e3d2d..6f742f6658a9 100644 --- a/fs/proc/base.c +++ b/fs/proc/base.c | |||
| @@ -234,23 +234,20 @@ static int check_mem_permission(struct task_struct *task) | |||
| 234 | 234 | ||
| 235 | struct mm_struct *mm_for_maps(struct task_struct *task) | 235 | struct mm_struct *mm_for_maps(struct task_struct *task) |
| 236 | { | 236 | { |
| 237 | struct mm_struct *mm = get_task_mm(task); | 237 | struct mm_struct *mm; |
| 238 | if (!mm) | 238 | |
| 239 | if (mutex_lock_killable(&task->cred_guard_mutex)) | ||
| 239 | return NULL; | 240 | return NULL; |
| 240 | down_read(&mm->mmap_sem); | 241 | |
| 241 | task_lock(task); | 242 | mm = get_task_mm(task); |
| 242 | if (task->mm != mm) | 243 | if (mm && mm != current->mm && |
| 243 | goto out; | 244 | !ptrace_may_access(task, PTRACE_MODE_READ)) { |
| 244 | if (task->mm != current->mm && | 245 | mmput(mm); |
| 245 | __ptrace_may_access(task, PTRACE_MODE_READ) < 0) | 246 | mm = NULL; |
| 246 | goto out; | 247 | } |
| 247 | task_unlock(task); | 248 | mutex_unlock(&task->cred_guard_mutex); |
| 249 | |||
| 248 | return mm; | 250 | return mm; |
| 249 | out: | ||
| 250 | task_unlock(task); | ||
| 251 | up_read(&mm->mmap_sem); | ||
| 252 | mmput(mm); | ||
| 253 | return NULL; | ||
| 254 | } | 251 | } |
| 255 | 252 | ||
| 256 | static int proc_pid_cmdline(struct task_struct *task, char * buffer) | 253 | static int proc_pid_cmdline(struct task_struct *task, char * buffer) |
| @@ -1006,12 +1003,7 @@ static ssize_t oom_adjust_read(struct file *file, char __user *buf, | |||
| 1006 | 1003 | ||
| 1007 | if (!task) | 1004 | if (!task) |
| 1008 | return -ESRCH; | 1005 | return -ESRCH; |
| 1009 | task_lock(task); | 1006 | oom_adjust = task->oomkilladj; |
| 1010 | if (task->mm) | ||
| 1011 | oom_adjust = task->mm->oom_adj; | ||
| 1012 | else | ||
| 1013 | oom_adjust = OOM_DISABLE; | ||
| 1014 | task_unlock(task); | ||
| 1015 | put_task_struct(task); | 1007 | put_task_struct(task); |
| 1016 | 1008 | ||
| 1017 | len = snprintf(buffer, sizeof(buffer), "%i\n", oom_adjust); | 1009 | len = snprintf(buffer, sizeof(buffer), "%i\n", oom_adjust); |
| @@ -1040,19 +1032,11 @@ static ssize_t oom_adjust_write(struct file *file, const char __user *buf, | |||
| 1040 | task = get_proc_task(file->f_path.dentry->d_inode); | 1032 | task = get_proc_task(file->f_path.dentry->d_inode); |
| 1041 | if (!task) | 1033 | if (!task) |
| 1042 | return -ESRCH; | 1034 | return -ESRCH; |
| 1043 | task_lock(task); | 1035 | if (oom_adjust < task->oomkilladj && !capable(CAP_SYS_RESOURCE)) { |
| 1044 | if (!task->mm) { | ||
| 1045 | task_unlock(task); | ||
| 1046 | put_task_struct(task); | ||
| 1047 | return -EINVAL; | ||
| 1048 | } | ||
| 1049 | if (oom_adjust < task->mm->oom_adj && !capable(CAP_SYS_RESOURCE)) { | ||
| 1050 | task_unlock(task); | ||
| 1051 | put_task_struct(task); | 1036 | put_task_struct(task); |
| 1052 | return -EACCES; | 1037 | return -EACCES; |
| 1053 | } | 1038 | } |
| 1054 | task->mm->oom_adj = oom_adjust; | 1039 | task->oomkilladj = oom_adjust; |
| 1055 | task_unlock(task); | ||
| 1056 | put_task_struct(task); | 1040 | put_task_struct(task); |
| 1057 | if (end - buffer == 0) | 1041 | if (end - buffer == 0) |
| 1058 | return -EIO; | 1042 | return -EIO; |
diff --git a/fs/proc/task_mmu.c b/fs/proc/task_mmu.c index 6f61b7cc32e0..9bd8be1d235c 100644 --- a/fs/proc/task_mmu.c +++ b/fs/proc/task_mmu.c | |||
| @@ -119,6 +119,7 @@ static void *m_start(struct seq_file *m, loff_t *pos) | |||
| 119 | mm = mm_for_maps(priv->task); | 119 | mm = mm_for_maps(priv->task); |
| 120 | if (!mm) | 120 | if (!mm) |
| 121 | return NULL; | 121 | return NULL; |
| 122 | down_read(&mm->mmap_sem); | ||
| 122 | 123 | ||
| 123 | tail_vma = get_gate_vma(priv->task); | 124 | tail_vma = get_gate_vma(priv->task); |
| 124 | priv->tail_vma = tail_vma; | 125 | priv->tail_vma = tail_vma; |
diff --git a/fs/proc/task_nommu.c b/fs/proc/task_nommu.c index 64a72e2e7650..8f5c05d3dbd3 100644 --- a/fs/proc/task_nommu.c +++ b/fs/proc/task_nommu.c | |||
| @@ -189,6 +189,7 @@ static void *m_start(struct seq_file *m, loff_t *pos) | |||
| 189 | priv->task = NULL; | 189 | priv->task = NULL; |
| 190 | return NULL; | 190 | return NULL; |
| 191 | } | 191 | } |
| 192 | down_read(&mm->mmap_sem); | ||
| 192 | 193 | ||
| 193 | /* start from the Nth VMA */ | 194 | /* start from the Nth VMA */ |
| 194 | for (p = rb_first(&mm->mm_rb); p; p = rb_next(p)) | 195 | for (p = rb_first(&mm->mm_rb); p; p = rb_next(p)) |
diff --git a/fs/quota/dquot.c b/fs/quota/dquot.c index 70f36c043d62..38f7bd559f35 100644 --- a/fs/quota/dquot.c +++ b/fs/quota/dquot.c | |||
| @@ -2043,7 +2043,6 @@ static int vfs_load_quota_inode(struct inode *inode, int type, int format_id, | |||
| 2043 | invalidate_bdev(sb->s_bdev); | 2043 | invalidate_bdev(sb->s_bdev); |
| 2044 | } | 2044 | } |
| 2045 | mutex_lock(&dqopt->dqonoff_mutex); | 2045 | mutex_lock(&dqopt->dqonoff_mutex); |
| 2046 | mutex_lock_nested(&inode->i_mutex, I_MUTEX_QUOTA); | ||
| 2047 | if (sb_has_quota_loaded(sb, type)) { | 2046 | if (sb_has_quota_loaded(sb, type)) { |
| 2048 | error = -EBUSY; | 2047 | error = -EBUSY; |
| 2049 | goto out_lock; | 2048 | goto out_lock; |
| @@ -2054,9 +2053,11 @@ static int vfs_load_quota_inode(struct inode *inode, int type, int format_id, | |||
| 2054 | * possible) Also nobody should write to the file - we use | 2053 | * possible) Also nobody should write to the file - we use |
| 2055 | * special IO operations which ignore the immutable bit. */ | 2054 | * special IO operations which ignore the immutable bit. */ |
| 2056 | down_write(&dqopt->dqptr_sem); | 2055 | down_write(&dqopt->dqptr_sem); |
| 2056 | mutex_lock_nested(&inode->i_mutex, I_MUTEX_QUOTA); | ||
| 2057 | oldflags = inode->i_flags & (S_NOATIME | S_IMMUTABLE | | 2057 | oldflags = inode->i_flags & (S_NOATIME | S_IMMUTABLE | |
| 2058 | S_NOQUOTA); | 2058 | S_NOQUOTA); |
| 2059 | inode->i_flags |= S_NOQUOTA | S_NOATIME | S_IMMUTABLE; | 2059 | inode->i_flags |= S_NOQUOTA | S_NOATIME | S_IMMUTABLE; |
| 2060 | mutex_unlock(&inode->i_mutex); | ||
| 2060 | up_write(&dqopt->dqptr_sem); | 2061 | up_write(&dqopt->dqptr_sem); |
| 2061 | sb->dq_op->drop(inode); | 2062 | sb->dq_op->drop(inode); |
| 2062 | } | 2063 | } |
| @@ -2080,7 +2081,6 @@ static int vfs_load_quota_inode(struct inode *inode, int type, int format_id, | |||
| 2080 | goto out_file_init; | 2081 | goto out_file_init; |
| 2081 | } | 2082 | } |
| 2082 | mutex_unlock(&dqopt->dqio_mutex); | 2083 | mutex_unlock(&dqopt->dqio_mutex); |
| 2083 | mutex_unlock(&inode->i_mutex); | ||
| 2084 | spin_lock(&dq_state_lock); | 2084 | spin_lock(&dq_state_lock); |
| 2085 | dqopt->flags |= dquot_state_flag(flags, type); | 2085 | dqopt->flags |= dquot_state_flag(flags, type); |
| 2086 | spin_unlock(&dq_state_lock); | 2086 | spin_unlock(&dq_state_lock); |
| @@ -2096,13 +2096,14 @@ out_file_init: | |||
| 2096 | out_lock: | 2096 | out_lock: |
| 2097 | if (oldflags != -1) { | 2097 | if (oldflags != -1) { |
| 2098 | down_write(&dqopt->dqptr_sem); | 2098 | down_write(&dqopt->dqptr_sem); |
| 2099 | mutex_lock_nested(&inode->i_mutex, I_MUTEX_QUOTA); | ||
| 2099 | /* Set the flags back (in the case of accidental quotaon() | 2100 | /* Set the flags back (in the case of accidental quotaon() |
| 2100 | * on a wrong file we don't want to mess up the flags) */ | 2101 | * on a wrong file we don't want to mess up the flags) */ |
| 2101 | inode->i_flags &= ~(S_NOATIME | S_NOQUOTA | S_IMMUTABLE); | 2102 | inode->i_flags &= ~(S_NOATIME | S_NOQUOTA | S_IMMUTABLE); |
| 2102 | inode->i_flags |= oldflags; | 2103 | inode->i_flags |= oldflags; |
| 2104 | mutex_unlock(&inode->i_mutex); | ||
| 2103 | up_write(&dqopt->dqptr_sem); | 2105 | up_write(&dqopt->dqptr_sem); |
| 2104 | } | 2106 | } |
| 2105 | mutex_unlock(&inode->i_mutex); | ||
| 2106 | mutex_unlock(&dqopt->dqonoff_mutex); | 2107 | mutex_unlock(&dqopt->dqonoff_mutex); |
| 2107 | out_fmt: | 2108 | out_fmt: |
| 2108 | put_quota_format(fmt); | 2109 | put_quota_format(fmt); |
diff --git a/fs/ramfs/file-nommu.c b/fs/ramfs/file-nommu.c index ebb2c417912c..11f0c06316de 100644 --- a/fs/ramfs/file-nommu.c +++ b/fs/ramfs/file-nommu.c | |||
| @@ -20,6 +20,7 @@ | |||
| 20 | #include <linux/ramfs.h> | 20 | #include <linux/ramfs.h> |
| 21 | #include <linux/pagevec.h> | 21 | #include <linux/pagevec.h> |
| 22 | #include <linux/mman.h> | 22 | #include <linux/mman.h> |
| 23 | #include <linux/sched.h> | ||
| 23 | 24 | ||
| 24 | #include <asm/uaccess.h> | 25 | #include <asm/uaccess.h> |
| 25 | #include "internal.h" | 26 | #include "internal.h" |
diff --git a/fs/select.c b/fs/select.c index d870237e42c7..8084834e123e 100644 --- a/fs/select.c +++ b/fs/select.c | |||
| @@ -110,6 +110,7 @@ void poll_initwait(struct poll_wqueues *pwq) | |||
| 110 | { | 110 | { |
| 111 | init_poll_funcptr(&pwq->pt, __pollwait); | 111 | init_poll_funcptr(&pwq->pt, __pollwait); |
| 112 | pwq->polling_task = current; | 112 | pwq->polling_task = current; |
| 113 | pwq->triggered = 0; | ||
| 113 | pwq->error = 0; | 114 | pwq->error = 0; |
| 114 | pwq->table = NULL; | 115 | pwq->table = NULL; |
| 115 | pwq->inline_index = 0; | 116 | pwq->inline_index = 0; |
diff --git a/fs/sysfs/dir.c b/fs/sysfs/dir.c index d88d0fac9fa5..14f2d71ea3ce 100644 --- a/fs/sysfs/dir.c +++ b/fs/sysfs/dir.c | |||
| @@ -939,8 +939,10 @@ again: | |||
| 939 | /* Remove from old parent's list and insert into new parent's list. */ | 939 | /* Remove from old parent's list and insert into new parent's list. */ |
| 940 | sysfs_unlink_sibling(sd); | 940 | sysfs_unlink_sibling(sd); |
| 941 | sysfs_get(new_parent_sd); | 941 | sysfs_get(new_parent_sd); |
| 942 | drop_nlink(old_parent->d_inode); | ||
| 942 | sysfs_put(sd->s_parent); | 943 | sysfs_put(sd->s_parent); |
| 943 | sd->s_parent = new_parent_sd; | 944 | sd->s_parent = new_parent_sd; |
| 945 | inc_nlink(new_parent->d_inode); | ||
| 944 | sysfs_link_sibling(sd); | 946 | sysfs_link_sibling(sd); |
| 945 | 947 | ||
| 946 | out_unlock: | 948 | out_unlock: |
diff --git a/fs/udf/super.c b/fs/udf/super.c index 6832135159b6..9d1b8c2e6c45 100644 --- a/fs/udf/super.c +++ b/fs/udf/super.c | |||
| @@ -1087,11 +1087,23 @@ static int udf_load_vat(struct super_block *sb, int p_index, int type1_index) | |||
| 1087 | struct udf_inode_info *vati; | 1087 | struct udf_inode_info *vati; |
| 1088 | uint32_t pos; | 1088 | uint32_t pos; |
| 1089 | struct virtualAllocationTable20 *vat20; | 1089 | struct virtualAllocationTable20 *vat20; |
| 1090 | sector_t blocks = sb->s_bdev->bd_inode->i_size >> sb->s_blocksize_bits; | ||
| 1090 | 1091 | ||
| 1091 | /* VAT file entry is in the last recorded block */ | 1092 | /* VAT file entry is in the last recorded block */ |
| 1092 | ino.partitionReferenceNum = type1_index; | 1093 | ino.partitionReferenceNum = type1_index; |
| 1093 | ino.logicalBlockNum = sbi->s_last_block - map->s_partition_root; | 1094 | ino.logicalBlockNum = sbi->s_last_block - map->s_partition_root; |
| 1094 | sbi->s_vat_inode = udf_iget(sb, &ino); | 1095 | sbi->s_vat_inode = udf_iget(sb, &ino); |
| 1096 | if (!sbi->s_vat_inode && | ||
| 1097 | sbi->s_last_block != blocks - 1) { | ||
| 1098 | printk(KERN_NOTICE "UDF-fs: Failed to read VAT inode from the" | ||
| 1099 | " last recorded block (%lu), retrying with the last " | ||
| 1100 | "block of the device (%lu).\n", | ||
| 1101 | (unsigned long)sbi->s_last_block, | ||
| 1102 | (unsigned long)blocks - 1); | ||
| 1103 | ino.partitionReferenceNum = type1_index; | ||
| 1104 | ino.logicalBlockNum = blocks - 1 - map->s_partition_root; | ||
| 1105 | sbi->s_vat_inode = udf_iget(sb, &ino); | ||
| 1106 | } | ||
| 1095 | if (!sbi->s_vat_inode) | 1107 | if (!sbi->s_vat_inode) |
| 1096 | return 1; | 1108 | return 1; |
| 1097 | 1109 | ||
diff --git a/fs/xfs/linux-2.6/xfs_aops.c b/fs/xfs/linux-2.6/xfs_aops.c index 7ec89fc05b2b..aecf2519db76 100644 --- a/fs/xfs/linux-2.6/xfs_aops.c +++ b/fs/xfs/linux-2.6/xfs_aops.c | |||
| @@ -1268,6 +1268,14 @@ xfs_vm_writepage( | |||
| 1268 | if (!page_has_buffers(page)) | 1268 | if (!page_has_buffers(page)) |
| 1269 | create_empty_buffers(page, 1 << inode->i_blkbits, 0); | 1269 | create_empty_buffers(page, 1 << inode->i_blkbits, 0); |
| 1270 | 1270 | ||
| 1271 | |||
| 1272 | /* | ||
| 1273 | * VM calculation for nr_to_write seems off. Bump it way | ||
| 1274 | * up, this gets simple streaming writes zippy again. | ||
| 1275 | * To be reviewed again after Jens' writeback changes. | ||
| 1276 | */ | ||
| 1277 | wbc->nr_to_write *= 4; | ||
| 1278 | |||
| 1271 | /* | 1279 | /* |
| 1272 | * Convert delayed allocate, unwritten or unmapped space | 1280 | * Convert delayed allocate, unwritten or unmapped space |
| 1273 | * to real space and flush out to disk. | 1281 | * to real space and flush out to disk. |
diff --git a/fs/xfs/linux-2.6/xfs_buf.c b/fs/xfs/linux-2.6/xfs_buf.c index 0c93c7ef3d18..965df1227d64 100644 --- a/fs/xfs/linux-2.6/xfs_buf.c +++ b/fs/xfs/linux-2.6/xfs_buf.c | |||
| @@ -770,7 +770,7 @@ xfs_buf_associate_memory( | |||
| 770 | bp->b_pages = NULL; | 770 | bp->b_pages = NULL; |
| 771 | bp->b_addr = mem; | 771 | bp->b_addr = mem; |
| 772 | 772 | ||
| 773 | rval = _xfs_buf_get_pages(bp, page_count, 0); | 773 | rval = _xfs_buf_get_pages(bp, page_count, XBF_DONT_BLOCK); |
| 774 | if (rval) | 774 | if (rval) |
| 775 | return rval; | 775 | return rval; |
| 776 | 776 | ||
diff --git a/fs/xfs/linux-2.6/xfs_iops.c b/fs/xfs/linux-2.6/xfs_iops.c index 58973bb46038..8070b34cc287 100644 --- a/fs/xfs/linux-2.6/xfs_iops.c +++ b/fs/xfs/linux-2.6/xfs_iops.c | |||
| @@ -680,8 +680,8 @@ xfs_vn_fiemap( | |||
| 680 | else | 680 | else |
| 681 | bm.bmv_length = BTOBB(length); | 681 | bm.bmv_length = BTOBB(length); |
| 682 | 682 | ||
| 683 | /* our formatter will tell xfs_getbmap when to stop. */ | 683 | /* We add one because in getbmap world count includes the header */ |
| 684 | bm.bmv_count = MAXEXTNUM; | 684 | bm.bmv_count = fieinfo->fi_extents_max + 1; |
| 685 | bm.bmv_iflags = BMV_IF_PREALLOC; | 685 | bm.bmv_iflags = BMV_IF_PREALLOC; |
| 686 | if (fieinfo->fi_flags & FIEMAP_FLAG_XATTR) | 686 | if (fieinfo->fi_flags & FIEMAP_FLAG_XATTR) |
| 687 | bm.bmv_iflags |= BMV_IF_ATTRFORK; | 687 | bm.bmv_iflags |= BMV_IF_ATTRFORK; |
diff --git a/fs/xfs/linux-2.6/xfs_sync.c b/fs/xfs/linux-2.6/xfs_sync.c index b619d6b8ca43..98ef624d9baf 100644 --- a/fs/xfs/linux-2.6/xfs_sync.c +++ b/fs/xfs/linux-2.6/xfs_sync.c | |||
| @@ -708,6 +708,16 @@ xfs_reclaim_inode( | |||
| 708 | return 0; | 708 | return 0; |
| 709 | } | 709 | } |
| 710 | 710 | ||
| 711 | void | ||
| 712 | __xfs_inode_set_reclaim_tag( | ||
| 713 | struct xfs_perag *pag, | ||
| 714 | struct xfs_inode *ip) | ||
| 715 | { | ||
| 716 | radix_tree_tag_set(&pag->pag_ici_root, | ||
| 717 | XFS_INO_TO_AGINO(ip->i_mount, ip->i_ino), | ||
| 718 | XFS_ICI_RECLAIM_TAG); | ||
| 719 | } | ||
| 720 | |||
| 711 | /* | 721 | /* |
| 712 | * We set the inode flag atomically with the radix tree tag. | 722 | * We set the inode flag atomically with the radix tree tag. |
| 713 | * Once we get tag lookups on the radix tree, this inode flag | 723 | * Once we get tag lookups on the radix tree, this inode flag |
| @@ -722,8 +732,7 @@ xfs_inode_set_reclaim_tag( | |||
| 722 | 732 | ||
| 723 | read_lock(&pag->pag_ici_lock); | 733 | read_lock(&pag->pag_ici_lock); |
| 724 | spin_lock(&ip->i_flags_lock); | 734 | spin_lock(&ip->i_flags_lock); |
| 725 | radix_tree_tag_set(&pag->pag_ici_root, | 735 | __xfs_inode_set_reclaim_tag(pag, ip); |
| 726 | XFS_INO_TO_AGINO(mp, ip->i_ino), XFS_ICI_RECLAIM_TAG); | ||
| 727 | __xfs_iflags_set(ip, XFS_IRECLAIMABLE); | 736 | __xfs_iflags_set(ip, XFS_IRECLAIMABLE); |
| 728 | spin_unlock(&ip->i_flags_lock); | 737 | spin_unlock(&ip->i_flags_lock); |
| 729 | read_unlock(&pag->pag_ici_lock); | 738 | read_unlock(&pag->pag_ici_lock); |
diff --git a/fs/xfs/linux-2.6/xfs_sync.h b/fs/xfs/linux-2.6/xfs_sync.h index 2a10301c99c7..59120602588a 100644 --- a/fs/xfs/linux-2.6/xfs_sync.h +++ b/fs/xfs/linux-2.6/xfs_sync.h | |||
| @@ -48,6 +48,7 @@ int xfs_reclaim_inode(struct xfs_inode *ip, int locked, int sync_mode); | |||
| 48 | int xfs_reclaim_inodes(struct xfs_mount *mp, int mode); | 48 | int xfs_reclaim_inodes(struct xfs_mount *mp, int mode); |
| 49 | 49 | ||
| 50 | void xfs_inode_set_reclaim_tag(struct xfs_inode *ip); | 50 | void xfs_inode_set_reclaim_tag(struct xfs_inode *ip); |
| 51 | void __xfs_inode_set_reclaim_tag(struct xfs_perag *pag, struct xfs_inode *ip); | ||
| 51 | void xfs_inode_clear_reclaim_tag(struct xfs_inode *ip); | 52 | void xfs_inode_clear_reclaim_tag(struct xfs_inode *ip); |
| 52 | void __xfs_inode_clear_reclaim_tag(struct xfs_mount *mp, struct xfs_perag *pag, | 53 | void __xfs_inode_clear_reclaim_tag(struct xfs_mount *mp, struct xfs_perag *pag, |
| 53 | struct xfs_inode *ip); | 54 | struct xfs_inode *ip); |
diff --git a/fs/xfs/xfs_attr.c b/fs/xfs/xfs_attr.c index db15feb906ff..4ece1906bd41 100644 --- a/fs/xfs/xfs_attr.c +++ b/fs/xfs/xfs_attr.c | |||
| @@ -2010,7 +2010,9 @@ xfs_attr_rmtval_get(xfs_da_args_t *args) | |||
| 2010 | dblkno = XFS_FSB_TO_DADDR(mp, map[i].br_startblock); | 2010 | dblkno = XFS_FSB_TO_DADDR(mp, map[i].br_startblock); |
| 2011 | blkcnt = XFS_FSB_TO_BB(mp, map[i].br_blockcount); | 2011 | blkcnt = XFS_FSB_TO_BB(mp, map[i].br_blockcount); |
| 2012 | error = xfs_read_buf(mp, mp->m_ddev_targp, dblkno, | 2012 | error = xfs_read_buf(mp, mp->m_ddev_targp, dblkno, |
| 2013 | blkcnt, XFS_BUF_LOCK, &bp); | 2013 | blkcnt, |
| 2014 | XFS_BUF_LOCK | XBF_DONT_BLOCK, | ||
| 2015 | &bp); | ||
| 2014 | if (error) | 2016 | if (error) |
| 2015 | return(error); | 2017 | return(error); |
| 2016 | 2018 | ||
| @@ -2141,8 +2143,8 @@ xfs_attr_rmtval_set(xfs_da_args_t *args) | |||
| 2141 | dblkno = XFS_FSB_TO_DADDR(mp, map.br_startblock), | 2143 | dblkno = XFS_FSB_TO_DADDR(mp, map.br_startblock), |
| 2142 | blkcnt = XFS_FSB_TO_BB(mp, map.br_blockcount); | 2144 | blkcnt = XFS_FSB_TO_BB(mp, map.br_blockcount); |
| 2143 | 2145 | ||
| 2144 | bp = xfs_buf_get_flags(mp->m_ddev_targp, dblkno, | 2146 | bp = xfs_buf_get_flags(mp->m_ddev_targp, dblkno, blkcnt, |
| 2145 | blkcnt, XFS_BUF_LOCK); | 2147 | XFS_BUF_LOCK | XBF_DONT_BLOCK); |
| 2146 | ASSERT(bp); | 2148 | ASSERT(bp); |
| 2147 | ASSERT(!XFS_BUF_GETERROR(bp)); | 2149 | ASSERT(!XFS_BUF_GETERROR(bp)); |
| 2148 | 2150 | ||
diff --git a/fs/xfs/xfs_bmap.c b/fs/xfs/xfs_bmap.c index 7928b9983c1d..8ee5b5a76a2a 100644 --- a/fs/xfs/xfs_bmap.c +++ b/fs/xfs/xfs_bmap.c | |||
| @@ -6009,7 +6009,7 @@ xfs_getbmap( | |||
| 6009 | */ | 6009 | */ |
| 6010 | error = ENOMEM; | 6010 | error = ENOMEM; |
| 6011 | subnex = 16; | 6011 | subnex = 16; |
| 6012 | map = kmem_alloc(subnex * sizeof(*map), KM_MAYFAIL); | 6012 | map = kmem_alloc(subnex * sizeof(*map), KM_MAYFAIL | KM_NOFS); |
| 6013 | if (!map) | 6013 | if (!map) |
| 6014 | goto out_unlock_ilock; | 6014 | goto out_unlock_ilock; |
| 6015 | 6015 | ||
diff --git a/fs/xfs/xfs_btree.c b/fs/xfs/xfs_btree.c index e9df99574829..26717388acf5 100644 --- a/fs/xfs/xfs_btree.c +++ b/fs/xfs/xfs_btree.c | |||
| @@ -120,8 +120,8 @@ xfs_btree_check_sblock( | |||
| 120 | XFS_RANDOM_BTREE_CHECK_SBLOCK))) { | 120 | XFS_RANDOM_BTREE_CHECK_SBLOCK))) { |
| 121 | if (bp) | 121 | if (bp) |
| 122 | xfs_buftrace("SBTREE ERROR", bp); | 122 | xfs_buftrace("SBTREE ERROR", bp); |
| 123 | XFS_ERROR_REPORT("xfs_btree_check_sblock", XFS_ERRLEVEL_LOW, | 123 | XFS_CORRUPTION_ERROR("xfs_btree_check_sblock", |
| 124 | cur->bc_mp); | 124 | XFS_ERRLEVEL_LOW, cur->bc_mp, block); |
| 125 | return XFS_ERROR(EFSCORRUPTED); | 125 | return XFS_ERROR(EFSCORRUPTED); |
| 126 | } | 126 | } |
| 127 | return 0; | 127 | return 0; |
diff --git a/fs/xfs/xfs_da_btree.c b/fs/xfs/xfs_da_btree.c index 9ff6e57a5075..2847bbc1c534 100644 --- a/fs/xfs/xfs_da_btree.c +++ b/fs/xfs/xfs_da_btree.c | |||
| @@ -2201,7 +2201,7 @@ kmem_zone_t *xfs_dabuf_zone; /* dabuf zone */ | |||
| 2201 | xfs_da_state_t * | 2201 | xfs_da_state_t * |
| 2202 | xfs_da_state_alloc(void) | 2202 | xfs_da_state_alloc(void) |
| 2203 | { | 2203 | { |
| 2204 | return kmem_zone_zalloc(xfs_da_state_zone, KM_SLEEP); | 2204 | return kmem_zone_zalloc(xfs_da_state_zone, KM_NOFS); |
| 2205 | } | 2205 | } |
| 2206 | 2206 | ||
| 2207 | /* | 2207 | /* |
| @@ -2261,9 +2261,9 @@ xfs_da_buf_make(int nbuf, xfs_buf_t **bps, inst_t *ra) | |||
| 2261 | int off; | 2261 | int off; |
| 2262 | 2262 | ||
| 2263 | if (nbuf == 1) | 2263 | if (nbuf == 1) |
| 2264 | dabuf = kmem_zone_alloc(xfs_dabuf_zone, KM_SLEEP); | 2264 | dabuf = kmem_zone_alloc(xfs_dabuf_zone, KM_NOFS); |
| 2265 | else | 2265 | else |
| 2266 | dabuf = kmem_alloc(XFS_DA_BUF_SIZE(nbuf), KM_SLEEP); | 2266 | dabuf = kmem_alloc(XFS_DA_BUF_SIZE(nbuf), KM_NOFS); |
| 2267 | dabuf->dirty = 0; | 2267 | dabuf->dirty = 0; |
| 2268 | #ifdef XFS_DABUF_DEBUG | 2268 | #ifdef XFS_DABUF_DEBUG |
| 2269 | dabuf->ra = ra; | 2269 | dabuf->ra = ra; |
diff --git a/fs/xfs/xfs_dir2.c b/fs/xfs/xfs_dir2.c index c657bec6d951..bb1d58eb3982 100644 --- a/fs/xfs/xfs_dir2.c +++ b/fs/xfs/xfs_dir2.c | |||
| @@ -256,7 +256,7 @@ xfs_dir_cilookup_result( | |||
| 256 | !(args->op_flags & XFS_DA_OP_CILOOKUP)) | 256 | !(args->op_flags & XFS_DA_OP_CILOOKUP)) |
| 257 | return EEXIST; | 257 | return EEXIST; |
| 258 | 258 | ||
| 259 | args->value = kmem_alloc(len, KM_MAYFAIL); | 259 | args->value = kmem_alloc(len, KM_NOFS | KM_MAYFAIL); |
| 260 | if (!args->value) | 260 | if (!args->value) |
| 261 | return ENOMEM; | 261 | return ENOMEM; |
| 262 | 262 | ||
diff --git a/fs/xfs/xfs_fsops.c b/fs/xfs/xfs_fsops.c index cbd451bb4848..2d0b3e1da9e6 100644 --- a/fs/xfs/xfs_fsops.c +++ b/fs/xfs/xfs_fsops.c | |||
| @@ -167,17 +167,25 @@ xfs_growfs_data_private( | |||
| 167 | new = nb - mp->m_sb.sb_dblocks; | 167 | new = nb - mp->m_sb.sb_dblocks; |
| 168 | oagcount = mp->m_sb.sb_agcount; | 168 | oagcount = mp->m_sb.sb_agcount; |
| 169 | if (nagcount > oagcount) { | 169 | if (nagcount > oagcount) { |
| 170 | void *new_perag, *old_perag; | ||
| 171 | |||
| 170 | xfs_filestream_flush(mp); | 172 | xfs_filestream_flush(mp); |
| 173 | |||
| 174 | new_perag = kmem_zalloc(sizeof(xfs_perag_t) * nagcount, | ||
| 175 | KM_MAYFAIL); | ||
| 176 | if (!new_perag) | ||
| 177 | return XFS_ERROR(ENOMEM); | ||
| 178 | |||
| 171 | down_write(&mp->m_peraglock); | 179 | down_write(&mp->m_peraglock); |
| 172 | mp->m_perag = kmem_realloc(mp->m_perag, | 180 | memcpy(new_perag, mp->m_perag, sizeof(xfs_perag_t) * oagcount); |
| 173 | sizeof(xfs_perag_t) * nagcount, | 181 | old_perag = mp->m_perag; |
| 174 | sizeof(xfs_perag_t) * oagcount, | 182 | mp->m_perag = new_perag; |
| 175 | KM_SLEEP); | 183 | |
| 176 | memset(&mp->m_perag[oagcount], 0, | ||
| 177 | (nagcount - oagcount) * sizeof(xfs_perag_t)); | ||
| 178 | mp->m_flags |= XFS_MOUNT_32BITINODES; | 184 | mp->m_flags |= XFS_MOUNT_32BITINODES; |
| 179 | nagimax = xfs_initialize_perag(mp, nagcount); | 185 | nagimax = xfs_initialize_perag(mp, nagcount); |
| 180 | up_write(&mp->m_peraglock); | 186 | up_write(&mp->m_peraglock); |
| 187 | |||
| 188 | kmem_free(old_perag); | ||
| 181 | } | 189 | } |
| 182 | tp = xfs_trans_alloc(mp, XFS_TRANS_GROWFS); | 190 | tp = xfs_trans_alloc(mp, XFS_TRANS_GROWFS); |
| 183 | tp->t_flags |= XFS_TRANS_RESERVE; | 191 | tp->t_flags |= XFS_TRANS_RESERVE; |
diff --git a/fs/xfs/xfs_iget.c b/fs/xfs/xfs_iget.c index 5fcec6f020a7..ecbf8b4d2e2e 100644 --- a/fs/xfs/xfs_iget.c +++ b/fs/xfs/xfs_iget.c | |||
| @@ -64,6 +64,10 @@ xfs_inode_alloc( | |||
| 64 | ip = kmem_zone_alloc(xfs_inode_zone, KM_SLEEP); | 64 | ip = kmem_zone_alloc(xfs_inode_zone, KM_SLEEP); |
| 65 | if (!ip) | 65 | if (!ip) |
| 66 | return NULL; | 66 | return NULL; |
| 67 | if (inode_init_always(mp->m_super, VFS_I(ip))) { | ||
| 68 | kmem_zone_free(xfs_inode_zone, ip); | ||
| 69 | return NULL; | ||
| 70 | } | ||
| 67 | 71 | ||
| 68 | ASSERT(atomic_read(&ip->i_iocount) == 0); | 72 | ASSERT(atomic_read(&ip->i_iocount) == 0); |
| 69 | ASSERT(atomic_read(&ip->i_pincount) == 0); | 73 | ASSERT(atomic_read(&ip->i_pincount) == 0); |
| @@ -105,17 +109,6 @@ xfs_inode_alloc( | |||
| 105 | #ifdef XFS_DIR2_TRACE | 109 | #ifdef XFS_DIR2_TRACE |
| 106 | ip->i_dir_trace = ktrace_alloc(XFS_DIR2_KTRACE_SIZE, KM_NOFS); | 110 | ip->i_dir_trace = ktrace_alloc(XFS_DIR2_KTRACE_SIZE, KM_NOFS); |
| 107 | #endif | 111 | #endif |
| 108 | /* | ||
| 109 | * Now initialise the VFS inode. We do this after the xfs_inode | ||
| 110 | * initialisation as internal failures will result in ->destroy_inode | ||
| 111 | * being called and that will pass down through the reclaim path and | ||
| 112 | * free the XFS inode. This path requires the XFS inode to already be | ||
| 113 | * initialised. Hence if this call fails, the xfs_inode has already | ||
| 114 | * been freed and we should not reference it at all in the error | ||
| 115 | * handling. | ||
| 116 | */ | ||
| 117 | if (!inode_init_always(mp->m_super, VFS_I(ip))) | ||
| 118 | return NULL; | ||
| 119 | 112 | ||
| 120 | /* prevent anyone from using this yet */ | 113 | /* prevent anyone from using this yet */ |
| 121 | VFS_I(ip)->i_state = I_NEW|I_LOCK; | 114 | VFS_I(ip)->i_state = I_NEW|I_LOCK; |
| @@ -123,6 +116,71 @@ xfs_inode_alloc( | |||
| 123 | return ip; | 116 | return ip; |
| 124 | } | 117 | } |
| 125 | 118 | ||
| 119 | STATIC void | ||
| 120 | xfs_inode_free( | ||
| 121 | struct xfs_inode *ip) | ||
| 122 | { | ||
| 123 | switch (ip->i_d.di_mode & S_IFMT) { | ||
| 124 | case S_IFREG: | ||
| 125 | case S_IFDIR: | ||
| 126 | case S_IFLNK: | ||
| 127 | xfs_idestroy_fork(ip, XFS_DATA_FORK); | ||
| 128 | break; | ||
| 129 | } | ||
| 130 | |||
| 131 | if (ip->i_afp) | ||
| 132 | xfs_idestroy_fork(ip, XFS_ATTR_FORK); | ||
| 133 | |||
| 134 | #ifdef XFS_INODE_TRACE | ||
| 135 | ktrace_free(ip->i_trace); | ||
| 136 | #endif | ||
| 137 | #ifdef XFS_BMAP_TRACE | ||
| 138 | ktrace_free(ip->i_xtrace); | ||
| 139 | #endif | ||
| 140 | #ifdef XFS_BTREE_TRACE | ||
| 141 | ktrace_free(ip->i_btrace); | ||
| 142 | #endif | ||
| 143 | #ifdef XFS_RW_TRACE | ||
| 144 | ktrace_free(ip->i_rwtrace); | ||
| 145 | #endif | ||
| 146 | #ifdef XFS_ILOCK_TRACE | ||
| 147 | ktrace_free(ip->i_lock_trace); | ||
| 148 | #endif | ||
| 149 | #ifdef XFS_DIR2_TRACE | ||
| 150 | ktrace_free(ip->i_dir_trace); | ||
| 151 | #endif | ||
| 152 | |||
| 153 | if (ip->i_itemp) { | ||
| 154 | /* | ||
| 155 | * Only if we are shutting down the fs will we see an | ||
| 156 | * inode still in the AIL. If it is there, we should remove | ||
| 157 | * it to prevent a use-after-free from occurring. | ||
| 158 | */ | ||
| 159 | xfs_log_item_t *lip = &ip->i_itemp->ili_item; | ||
| 160 | struct xfs_ail *ailp = lip->li_ailp; | ||
| 161 | |||
| 162 | ASSERT(((lip->li_flags & XFS_LI_IN_AIL) == 0) || | ||
| 163 | XFS_FORCED_SHUTDOWN(ip->i_mount)); | ||
| 164 | if (lip->li_flags & XFS_LI_IN_AIL) { | ||
| 165 | spin_lock(&ailp->xa_lock); | ||
| 166 | if (lip->li_flags & XFS_LI_IN_AIL) | ||
| 167 | xfs_trans_ail_delete(ailp, lip); | ||
| 168 | else | ||
| 169 | spin_unlock(&ailp->xa_lock); | ||
| 170 | } | ||
| 171 | xfs_inode_item_destroy(ip); | ||
| 172 | ip->i_itemp = NULL; | ||
| 173 | } | ||
| 174 | |||
| 175 | /* asserts to verify all state is correct here */ | ||
| 176 | ASSERT(atomic_read(&ip->i_iocount) == 0); | ||
| 177 | ASSERT(atomic_read(&ip->i_pincount) == 0); | ||
| 178 | ASSERT(!spin_is_locked(&ip->i_flags_lock)); | ||
| 179 | ASSERT(completion_done(&ip->i_flush)); | ||
| 180 | |||
| 181 | kmem_zone_free(xfs_inode_zone, ip); | ||
| 182 | } | ||
| 183 | |||
| 126 | /* | 184 | /* |
| 127 | * Check the validity of the inode we just found it the cache | 185 | * Check the validity of the inode we just found it the cache |
| 128 | */ | 186 | */ |
| @@ -133,80 +191,82 @@ xfs_iget_cache_hit( | |||
| 133 | int flags, | 191 | int flags, |
| 134 | int lock_flags) __releases(pag->pag_ici_lock) | 192 | int lock_flags) __releases(pag->pag_ici_lock) |
| 135 | { | 193 | { |
| 194 | struct inode *inode = VFS_I(ip); | ||
| 136 | struct xfs_mount *mp = ip->i_mount; | 195 | struct xfs_mount *mp = ip->i_mount; |
| 137 | int error = EAGAIN; | 196 | int error; |
| 197 | |||
| 198 | spin_lock(&ip->i_flags_lock); | ||
| 138 | 199 | ||
| 139 | /* | 200 | /* |
| 140 | * If INEW is set this inode is being set up | 201 | * If we are racing with another cache hit that is currently |
| 141 | * If IRECLAIM is set this inode is being torn down | 202 | * instantiating this inode or currently recycling it out of |
| 142 | * Pause and try again. | 203 | * reclaimabe state, wait for the initialisation to complete |
| 204 | * before continuing. | ||
| 205 | * | ||
| 206 | * XXX(hch): eventually we should do something equivalent to | ||
| 207 | * wait_on_inode to wait for these flags to be cleared | ||
| 208 | * instead of polling for it. | ||
| 143 | */ | 209 | */ |
| 144 | if (xfs_iflags_test(ip, (XFS_INEW|XFS_IRECLAIM))) { | 210 | if (ip->i_flags & (XFS_INEW|XFS_IRECLAIM)) { |
| 145 | XFS_STATS_INC(xs_ig_frecycle); | 211 | XFS_STATS_INC(xs_ig_frecycle); |
| 212 | error = EAGAIN; | ||
| 146 | goto out_error; | 213 | goto out_error; |
| 147 | } | 214 | } |
| 148 | 215 | ||
| 149 | /* If IRECLAIMABLE is set, we've torn down the vfs inode part */ | 216 | /* |
| 150 | if (xfs_iflags_test(ip, XFS_IRECLAIMABLE)) { | 217 | * If lookup is racing with unlink return an error immediately. |
| 151 | 218 | */ | |
| 152 | /* | 219 | if (ip->i_d.di_mode == 0 && !(flags & XFS_IGET_CREATE)) { |
| 153 | * If lookup is racing with unlink, then we should return an | 220 | error = ENOENT; |
| 154 | * error immediately so we don't remove it from the reclaim | 221 | goto out_error; |
| 155 | * list and potentially leak the inode. | 222 | } |
| 156 | */ | ||
| 157 | if ((ip->i_d.di_mode == 0) && !(flags & XFS_IGET_CREATE)) { | ||
| 158 | error = ENOENT; | ||
| 159 | goto out_error; | ||
| 160 | } | ||
| 161 | 223 | ||
| 224 | /* | ||
| 225 | * If IRECLAIMABLE is set, we've torn down the VFS inode already. | ||
| 226 | * Need to carefully get it back into useable state. | ||
| 227 | */ | ||
| 228 | if (ip->i_flags & XFS_IRECLAIMABLE) { | ||
| 162 | xfs_itrace_exit_tag(ip, "xfs_iget.alloc"); | 229 | xfs_itrace_exit_tag(ip, "xfs_iget.alloc"); |
| 163 | 230 | ||
| 164 | /* | 231 | /* |
| 165 | * We need to re-initialise the VFS inode as it has been | 232 | * We need to set XFS_INEW atomically with clearing the |
| 166 | * 'freed' by the VFS. Do this here so we can deal with | 233 | * reclaimable tag so that we do have an indicator of the |
| 167 | * errors cleanly, then tag it so it can be set up correctly | 234 | * inode still being initialized. |
| 168 | * later. | ||
| 169 | */ | 235 | */ |
| 170 | if (!inode_init_always(mp->m_super, VFS_I(ip))) { | 236 | ip->i_flags |= XFS_INEW; |
| 171 | error = ENOMEM; | 237 | ip->i_flags &= ~XFS_IRECLAIMABLE; |
| 172 | goto out_error; | 238 | __xfs_inode_clear_reclaim_tag(mp, pag, ip); |
| 173 | } | ||
| 174 | 239 | ||
| 175 | /* | 240 | spin_unlock(&ip->i_flags_lock); |
| 176 | * We must set the XFS_INEW flag before clearing the | 241 | read_unlock(&pag->pag_ici_lock); |
| 177 | * XFS_IRECLAIMABLE flag so that if a racing lookup does | ||
| 178 | * not find the XFS_IRECLAIMABLE above but has the igrab() | ||
| 179 | * below succeed we can safely check XFS_INEW to detect | ||
| 180 | * that this inode is still being initialised. | ||
| 181 | */ | ||
| 182 | xfs_iflags_set(ip, XFS_INEW); | ||
| 183 | xfs_iflags_clear(ip, XFS_IRECLAIMABLE); | ||
| 184 | 242 | ||
| 185 | /* clear the radix tree reclaim flag as well. */ | 243 | error = -inode_init_always(mp->m_super, inode); |
| 186 | __xfs_inode_clear_reclaim_tag(mp, pag, ip); | 244 | if (error) { |
| 187 | } else if (!igrab(VFS_I(ip))) { | 245 | /* |
| 246 | * Re-initializing the inode failed, and we are in deep | ||
| 247 | * trouble. Try to re-add it to the reclaim list. | ||
| 248 | */ | ||
| 249 | read_lock(&pag->pag_ici_lock); | ||
| 250 | spin_lock(&ip->i_flags_lock); | ||
| 251 | |||
| 252 | ip->i_flags &= ~XFS_INEW; | ||
| 253 | ip->i_flags |= XFS_IRECLAIMABLE; | ||
| 254 | __xfs_inode_set_reclaim_tag(pag, ip); | ||
| 255 | goto out_error; | ||
| 256 | } | ||
| 257 | inode->i_state = I_LOCK|I_NEW; | ||
| 258 | } else { | ||
| 188 | /* If the VFS inode is being torn down, pause and try again. */ | 259 | /* If the VFS inode is being torn down, pause and try again. */ |
| 189 | XFS_STATS_INC(xs_ig_frecycle); | 260 | if (!igrab(inode)) { |
| 190 | goto out_error; | 261 | error = EAGAIN; |
| 191 | } else if (xfs_iflags_test(ip, XFS_INEW)) { | 262 | goto out_error; |
| 192 | /* | 263 | } |
| 193 | * We are racing with another cache hit that is | ||
| 194 | * currently recycling this inode out of the XFS_IRECLAIMABLE | ||
| 195 | * state. Wait for the initialisation to complete before | ||
| 196 | * continuing. | ||
| 197 | */ | ||
| 198 | wait_on_inode(VFS_I(ip)); | ||
| 199 | } | ||
| 200 | 264 | ||
| 201 | if (ip->i_d.di_mode == 0 && !(flags & XFS_IGET_CREATE)) { | 265 | /* We've got a live one. */ |
| 202 | error = ENOENT; | 266 | spin_unlock(&ip->i_flags_lock); |
| 203 | iput(VFS_I(ip)); | 267 | read_unlock(&pag->pag_ici_lock); |
| 204 | goto out_error; | ||
| 205 | } | 268 | } |
| 206 | 269 | ||
| 207 | /* We've got a live one. */ | ||
| 208 | read_unlock(&pag->pag_ici_lock); | ||
| 209 | |||
| 210 | if (lock_flags != 0) | 270 | if (lock_flags != 0) |
| 211 | xfs_ilock(ip, lock_flags); | 271 | xfs_ilock(ip, lock_flags); |
| 212 | 272 | ||
| @@ -216,6 +276,7 @@ xfs_iget_cache_hit( | |||
| 216 | return 0; | 276 | return 0; |
| 217 | 277 | ||
| 218 | out_error: | 278 | out_error: |
| 279 | spin_unlock(&ip->i_flags_lock); | ||
| 219 | read_unlock(&pag->pag_ici_lock); | 280 | read_unlock(&pag->pag_ici_lock); |
| 220 | return error; | 281 | return error; |
| 221 | } | 282 | } |
| @@ -299,7 +360,8 @@ out_preload_end: | |||
| 299 | if (lock_flags) | 360 | if (lock_flags) |
| 300 | xfs_iunlock(ip, lock_flags); | 361 | xfs_iunlock(ip, lock_flags); |
| 301 | out_destroy: | 362 | out_destroy: |
| 302 | xfs_destroy_inode(ip); | 363 | __destroy_inode(VFS_I(ip)); |
| 364 | xfs_inode_free(ip); | ||
| 303 | return error; | 365 | return error; |
| 304 | } | 366 | } |
| 305 | 367 | ||
| @@ -504,62 +566,7 @@ xfs_ireclaim( | |||
| 504 | xfs_qm_dqdetach(ip); | 566 | xfs_qm_dqdetach(ip); |
| 505 | xfs_iunlock(ip, XFS_ILOCK_EXCL | XFS_IOLOCK_EXCL); | 567 | xfs_iunlock(ip, XFS_ILOCK_EXCL | XFS_IOLOCK_EXCL); |
| 506 | 568 | ||
| 507 | switch (ip->i_d.di_mode & S_IFMT) { | 569 | xfs_inode_free(ip); |
| 508 | case S_IFREG: | ||
| 509 | case S_IFDIR: | ||
| 510 | case S_IFLNK: | ||
| 511 | xfs_idestroy_fork(ip, XFS_DATA_FORK); | ||
| 512 | break; | ||
| 513 | } | ||
| 514 | |||
| 515 | if (ip->i_afp) | ||
| 516 | xfs_idestroy_fork(ip, XFS_ATTR_FORK); | ||
| 517 | |||
| 518 | #ifdef XFS_INODE_TRACE | ||
| 519 | ktrace_free(ip->i_trace); | ||
| 520 | #endif | ||
| 521 | #ifdef XFS_BMAP_TRACE | ||
| 522 | ktrace_free(ip->i_xtrace); | ||
| 523 | #endif | ||
| 524 | #ifdef XFS_BTREE_TRACE | ||
| 525 | ktrace_free(ip->i_btrace); | ||
| 526 | #endif | ||
| 527 | #ifdef XFS_RW_TRACE | ||
| 528 | ktrace_free(ip->i_rwtrace); | ||
| 529 | #endif | ||
| 530 | #ifdef XFS_ILOCK_TRACE | ||
| 531 | ktrace_free(ip->i_lock_trace); | ||
| 532 | #endif | ||
| 533 | #ifdef XFS_DIR2_TRACE | ||
| 534 | ktrace_free(ip->i_dir_trace); | ||
| 535 | #endif | ||
| 536 | if (ip->i_itemp) { | ||
| 537 | /* | ||
| 538 | * Only if we are shutting down the fs will we see an | ||
| 539 | * inode still in the AIL. If it is there, we should remove | ||
| 540 | * it to prevent a use-after-free from occurring. | ||
| 541 | */ | ||
| 542 | xfs_log_item_t *lip = &ip->i_itemp->ili_item; | ||
| 543 | struct xfs_ail *ailp = lip->li_ailp; | ||
| 544 | |||
| 545 | ASSERT(((lip->li_flags & XFS_LI_IN_AIL) == 0) || | ||
| 546 | XFS_FORCED_SHUTDOWN(ip->i_mount)); | ||
| 547 | if (lip->li_flags & XFS_LI_IN_AIL) { | ||
| 548 | spin_lock(&ailp->xa_lock); | ||
| 549 | if (lip->li_flags & XFS_LI_IN_AIL) | ||
| 550 | xfs_trans_ail_delete(ailp, lip); | ||
| 551 | else | ||
| 552 | spin_unlock(&ailp->xa_lock); | ||
| 553 | } | ||
| 554 | xfs_inode_item_destroy(ip); | ||
| 555 | ip->i_itemp = NULL; | ||
| 556 | } | ||
| 557 | /* asserts to verify all state is correct here */ | ||
| 558 | ASSERT(atomic_read(&ip->i_iocount) == 0); | ||
| 559 | ASSERT(atomic_read(&ip->i_pincount) == 0); | ||
| 560 | ASSERT(!spin_is_locked(&ip->i_flags_lock)); | ||
| 561 | ASSERT(completion_done(&ip->i_flush)); | ||
| 562 | kmem_zone_free(xfs_inode_zone, ip); | ||
| 563 | } | 570 | } |
| 564 | 571 | ||
| 565 | /* | 572 | /* |
diff --git a/fs/xfs/xfs_inode.c b/fs/xfs/xfs_inode.c index 1f22d65fed0a..da428b3fe0f5 100644 --- a/fs/xfs/xfs_inode.c +++ b/fs/xfs/xfs_inode.c | |||
| @@ -343,6 +343,16 @@ xfs_iformat( | |||
| 343 | return XFS_ERROR(EFSCORRUPTED); | 343 | return XFS_ERROR(EFSCORRUPTED); |
| 344 | } | 344 | } |
| 345 | 345 | ||
| 346 | if (unlikely((ip->i_d.di_flags & XFS_DIFLAG_REALTIME) && | ||
| 347 | !ip->i_mount->m_rtdev_targp)) { | ||
| 348 | xfs_fs_repair_cmn_err(CE_WARN, ip->i_mount, | ||
| 349 | "corrupt dinode %Lu, has realtime flag set.", | ||
| 350 | ip->i_ino); | ||
| 351 | XFS_CORRUPTION_ERROR("xfs_iformat(realtime)", | ||
| 352 | XFS_ERRLEVEL_LOW, ip->i_mount, dip); | ||
| 353 | return XFS_ERROR(EFSCORRUPTED); | ||
| 354 | } | ||
| 355 | |||
| 346 | switch (ip->i_d.di_mode & S_IFMT) { | 356 | switch (ip->i_d.di_mode & S_IFMT) { |
| 347 | case S_IFIFO: | 357 | case S_IFIFO: |
| 348 | case S_IFCHR: | 358 | case S_IFCHR: |
diff --git a/fs/xfs/xfs_inode.h b/fs/xfs/xfs_inode.h index 1804f866a71d..65f24a3cc992 100644 --- a/fs/xfs/xfs_inode.h +++ b/fs/xfs/xfs_inode.h | |||
| @@ -310,23 +310,6 @@ static inline struct inode *VFS_I(struct xfs_inode *ip) | |||
| 310 | } | 310 | } |
| 311 | 311 | ||
| 312 | /* | 312 | /* |
| 313 | * Get rid of a partially initialized inode. | ||
| 314 | * | ||
| 315 | * We have to go through destroy_inode to make sure allocations | ||
| 316 | * from init_inode_always like the security data are undone. | ||
| 317 | * | ||
| 318 | * We mark the inode bad so that it takes the short cut in | ||
| 319 | * the reclaim path instead of going through the flush path | ||
| 320 | * which doesn't make sense for an inode that has never seen the | ||
| 321 | * light of day. | ||
| 322 | */ | ||
| 323 | static inline void xfs_destroy_inode(struct xfs_inode *ip) | ||
| 324 | { | ||
| 325 | make_bad_inode(VFS_I(ip)); | ||
| 326 | return destroy_inode(VFS_I(ip)); | ||
| 327 | } | ||
| 328 | |||
| 329 | /* | ||
| 330 | * i_flags helper functions | 313 | * i_flags helper functions |
| 331 | */ | 314 | */ |
| 332 | static inline void | 315 | static inline void |
diff --git a/fs/xfs/xfs_log.c b/fs/xfs/xfs_log.c index 3750f04ede0b..9dbdff3ea484 100644 --- a/fs/xfs/xfs_log.c +++ b/fs/xfs/xfs_log.c | |||
| @@ -3180,7 +3180,7 @@ try_again: | |||
| 3180 | STATIC void | 3180 | STATIC void |
| 3181 | xlog_state_want_sync(xlog_t *log, xlog_in_core_t *iclog) | 3181 | xlog_state_want_sync(xlog_t *log, xlog_in_core_t *iclog) |
| 3182 | { | 3182 | { |
| 3183 | ASSERT(spin_is_locked(&log->l_icloglock)); | 3183 | assert_spin_locked(&log->l_icloglock); |
| 3184 | 3184 | ||
| 3185 | if (iclog->ic_state == XLOG_STATE_ACTIVE) { | 3185 | if (iclog->ic_state == XLOG_STATE_ACTIVE) { |
| 3186 | xlog_state_switch_iclogs(log, iclog, 0); | 3186 | xlog_state_switch_iclogs(log, iclog, 0); |
diff --git a/fs/xfs/xfs_vnodeops.c b/fs/xfs/xfs_vnodeops.c index c4eca5ed5dab..492d75bae2bf 100644 --- a/fs/xfs/xfs_vnodeops.c +++ b/fs/xfs/xfs_vnodeops.c | |||
| @@ -538,7 +538,9 @@ xfs_readlink_bmap( | |||
| 538 | d = XFS_FSB_TO_DADDR(mp, mval[n].br_startblock); | 538 | d = XFS_FSB_TO_DADDR(mp, mval[n].br_startblock); |
| 539 | byte_cnt = XFS_FSB_TO_B(mp, mval[n].br_blockcount); | 539 | byte_cnt = XFS_FSB_TO_B(mp, mval[n].br_blockcount); |
| 540 | 540 | ||
| 541 | bp = xfs_buf_read(mp->m_ddev_targp, d, BTOBB(byte_cnt), 0); | 541 | bp = xfs_buf_read_flags(mp->m_ddev_targp, d, BTOBB(byte_cnt), |
| 542 | XBF_LOCK | XBF_MAPPED | | ||
| 543 | XBF_DONT_BLOCK); | ||
| 542 | error = XFS_BUF_GETERROR(bp); | 544 | error = XFS_BUF_GETERROR(bp); |
| 543 | if (error) { | 545 | if (error) { |
| 544 | xfs_ioerror_alert("xfs_readlink", | 546 | xfs_ioerror_alert("xfs_readlink", |
diff --git a/include/acpi/acpiosxf.h b/include/acpi/acpiosxf.h index 3e798593b17b..ab0b85cf21f3 100644 --- a/include/acpi/acpiosxf.h +++ b/include/acpi/acpiosxf.h | |||
| @@ -242,6 +242,10 @@ acpi_os_derive_pci_id(acpi_handle rhandle, | |||
| 242 | acpi_status acpi_os_validate_interface(char *interface); | 242 | acpi_status acpi_os_validate_interface(char *interface); |
| 243 | acpi_status acpi_osi_invalidate(char* interface); | 243 | acpi_status acpi_osi_invalidate(char* interface); |
| 244 | 244 | ||
| 245 | acpi_status | ||
| 246 | acpi_os_validate_address(u8 space_id, acpi_physical_address address, | ||
| 247 | acpi_size length, char *name); | ||
| 248 | |||
| 245 | u64 acpi_os_get_timer(void); | 249 | u64 acpi_os_get_timer(void); |
| 246 | 250 | ||
| 247 | acpi_status acpi_os_signal(u32 function, void *info); | 251 | acpi_status acpi_os_signal(u32 function, void *info); |
diff --git a/include/acpi/processor.h b/include/acpi/processor.h index baf1e0a9a7ee..740ac3ad8fd0 100644 --- a/include/acpi/processor.h +++ b/include/acpi/processor.h | |||
| @@ -174,7 +174,7 @@ struct acpi_processor_throttling { | |||
| 174 | cpumask_var_t shared_cpu_map; | 174 | cpumask_var_t shared_cpu_map; |
| 175 | int (*acpi_processor_get_throttling) (struct acpi_processor * pr); | 175 | int (*acpi_processor_get_throttling) (struct acpi_processor * pr); |
| 176 | int (*acpi_processor_set_throttling) (struct acpi_processor * pr, | 176 | int (*acpi_processor_set_throttling) (struct acpi_processor * pr, |
| 177 | int state); | 177 | int state, bool force); |
| 178 | 178 | ||
| 179 | u32 address; | 179 | u32 address; |
| 180 | u8 duty_offset; | 180 | u8 duty_offset; |
| @@ -321,7 +321,8 @@ static inline int acpi_processor_ppc_has_changed(struct acpi_processor *pr) | |||
| 321 | /* in processor_throttling.c */ | 321 | /* in processor_throttling.c */ |
| 322 | int acpi_processor_tstate_has_changed(struct acpi_processor *pr); | 322 | int acpi_processor_tstate_has_changed(struct acpi_processor *pr); |
| 323 | int acpi_processor_get_throttling_info(struct acpi_processor *pr); | 323 | int acpi_processor_get_throttling_info(struct acpi_processor *pr); |
| 324 | extern int acpi_processor_set_throttling(struct acpi_processor *pr, int state); | 324 | extern int acpi_processor_set_throttling(struct acpi_processor *pr, |
| 325 | int state, bool force); | ||
| 325 | extern const struct file_operations acpi_processor_throttling_fops; | 326 | extern const struct file_operations acpi_processor_throttling_fops; |
| 326 | extern void acpi_processor_throttling_init(void); | 327 | extern void acpi_processor_throttling_init(void); |
| 327 | /* in processor_idle.c */ | 328 | /* in processor_idle.c */ |
diff --git a/include/asm-generic/4level-fixup.h b/include/asm-generic/4level-fixup.h index 9d40e879f99e..77ff547730af 100644 --- a/include/asm-generic/4level-fixup.h +++ b/include/asm-generic/4level-fixup.h | |||
| @@ -27,9 +27,9 @@ | |||
| 27 | #define pud_page_vaddr(pud) pgd_page_vaddr(pud) | 27 | #define pud_page_vaddr(pud) pgd_page_vaddr(pud) |
| 28 | 28 | ||
| 29 | #undef pud_free_tlb | 29 | #undef pud_free_tlb |
| 30 | #define pud_free_tlb(tlb, x) do { } while (0) | 30 | #define pud_free_tlb(tlb, x, addr) do { } while (0) |
| 31 | #define pud_free(mm, x) do { } while (0) | 31 | #define pud_free(mm, x) do { } while (0) |
| 32 | #define __pud_free_tlb(tlb, x) do { } while (0) | 32 | #define __pud_free_tlb(tlb, x, addr) do { } while (0) |
| 33 | 33 | ||
| 34 | #undef pud_addr_end | 34 | #undef pud_addr_end |
| 35 | #define pud_addr_end(addr, end) (end) | 35 | #define pud_addr_end(addr, end) (end) |
diff --git a/include/asm-generic/pgtable-nopmd.h b/include/asm-generic/pgtable-nopmd.h index a7cdc48e8b78..725612b793ce 100644 --- a/include/asm-generic/pgtable-nopmd.h +++ b/include/asm-generic/pgtable-nopmd.h | |||
| @@ -59,7 +59,7 @@ static inline pmd_t * pmd_offset(pud_t * pud, unsigned long address) | |||
| 59 | static inline void pmd_free(struct mm_struct *mm, pmd_t *pmd) | 59 | static inline void pmd_free(struct mm_struct *mm, pmd_t *pmd) |
| 60 | { | 60 | { |
| 61 | } | 61 | } |
| 62 | #define __pmd_free_tlb(tlb, x) do { } while (0) | 62 | #define __pmd_free_tlb(tlb, x, a) do { } while (0) |
| 63 | 63 | ||
| 64 | #undef pmd_addr_end | 64 | #undef pmd_addr_end |
| 65 | #define pmd_addr_end(addr, end) (end) | 65 | #define pmd_addr_end(addr, end) (end) |
diff --git a/include/asm-generic/pgtable-nopud.h b/include/asm-generic/pgtable-nopud.h index 87cf449a6df3..810431d8351b 100644 --- a/include/asm-generic/pgtable-nopud.h +++ b/include/asm-generic/pgtable-nopud.h | |||
| @@ -52,7 +52,7 @@ static inline pud_t * pud_offset(pgd_t * pgd, unsigned long address) | |||
| 52 | */ | 52 | */ |
| 53 | #define pud_alloc_one(mm, address) NULL | 53 | #define pud_alloc_one(mm, address) NULL |
| 54 | #define pud_free(mm, x) do { } while (0) | 54 | #define pud_free(mm, x) do { } while (0) |
| 55 | #define __pud_free_tlb(tlb, x) do { } while (0) | 55 | #define __pud_free_tlb(tlb, x, a) do { } while (0) |
| 56 | 56 | ||
| 57 | #undef pud_addr_end | 57 | #undef pud_addr_end |
| 58 | #define pud_addr_end(addr, end) (end) | 58 | #define pud_addr_end(addr, end) (end) |
diff --git a/include/asm-generic/tlb.h b/include/asm-generic/tlb.h index f490e43a90b9..e43f9766259f 100644 --- a/include/asm-generic/tlb.h +++ b/include/asm-generic/tlb.h | |||
| @@ -123,24 +123,24 @@ static inline void tlb_remove_page(struct mmu_gather *tlb, struct page *page) | |||
| 123 | __tlb_remove_tlb_entry(tlb, ptep, address); \ | 123 | __tlb_remove_tlb_entry(tlb, ptep, address); \ |
| 124 | } while (0) | 124 | } while (0) |
| 125 | 125 | ||
| 126 | #define pte_free_tlb(tlb, ptep) \ | 126 | #define pte_free_tlb(tlb, ptep, address) \ |
| 127 | do { \ | 127 | do { \ |
| 128 | tlb->need_flush = 1; \ | 128 | tlb->need_flush = 1; \ |
| 129 | __pte_free_tlb(tlb, ptep); \ | 129 | __pte_free_tlb(tlb, ptep, address); \ |
| 130 | } while (0) | 130 | } while (0) |
| 131 | 131 | ||
| 132 | #ifndef __ARCH_HAS_4LEVEL_HACK | 132 | #ifndef __ARCH_HAS_4LEVEL_HACK |
| 133 | #define pud_free_tlb(tlb, pudp) \ | 133 | #define pud_free_tlb(tlb, pudp, address) \ |
| 134 | do { \ | 134 | do { \ |
| 135 | tlb->need_flush = 1; \ | 135 | tlb->need_flush = 1; \ |
| 136 | __pud_free_tlb(tlb, pudp); \ | 136 | __pud_free_tlb(tlb, pudp, address); \ |
| 137 | } while (0) | 137 | } while (0) |
| 138 | #endif | 138 | #endif |
| 139 | 139 | ||
| 140 | #define pmd_free_tlb(tlb, pmdp) \ | 140 | #define pmd_free_tlb(tlb, pmdp, address) \ |
| 141 | do { \ | 141 | do { \ |
| 142 | tlb->need_flush = 1; \ | 142 | tlb->need_flush = 1; \ |
| 143 | __pmd_free_tlb(tlb, pmdp); \ | 143 | __pmd_free_tlb(tlb, pmdp, address); \ |
| 144 | } while (0) | 144 | } while (0) |
| 145 | 145 | ||
| 146 | #define tlb_migrate_finish(mm) do {} while (0) | 146 | #define tlb_migrate_finish(mm) do {} while (0) |
diff --git a/include/drm/drm_pciids.h b/include/drm/drm_pciids.h index 7174818c2c13..853508499d20 100644 --- a/include/drm/drm_pciids.h +++ b/include/drm/drm_pciids.h | |||
| @@ -257,9 +257,12 @@ | |||
| 257 | {0x1002, 0x940F, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_R600|RADEON_NEW_MEMMAP}, \ | 257 | {0x1002, 0x940F, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_R600|RADEON_NEW_MEMMAP}, \ |
| 258 | {0x1002, 0x94A0, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV740|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ | 258 | {0x1002, 0x94A0, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV740|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ |
| 259 | {0x1002, 0x94A1, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV740|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ | 259 | {0x1002, 0x94A1, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV740|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ |
| 260 | {0x1002, 0x94A3, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV740|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ | ||
| 260 | {0x1002, 0x94B1, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV740|RADEON_NEW_MEMMAP}, \ | 261 | {0x1002, 0x94B1, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV740|RADEON_NEW_MEMMAP}, \ |
| 261 | {0x1002, 0x94B3, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV740|RADEON_NEW_MEMMAP}, \ | 262 | {0x1002, 0x94B3, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV740|RADEON_NEW_MEMMAP}, \ |
| 263 | {0x1002, 0x94B4, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV740|RADEON_NEW_MEMMAP}, \ | ||
| 262 | {0x1002, 0x94B5, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV740|RADEON_NEW_MEMMAP}, \ | 264 | {0x1002, 0x94B5, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV740|RADEON_NEW_MEMMAP}, \ |
| 265 | {0x1002, 0x94B9, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV740|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ | ||
| 263 | {0x1002, 0x9440, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV770|RADEON_NEW_MEMMAP}, \ | 266 | {0x1002, 0x9440, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV770|RADEON_NEW_MEMMAP}, \ |
| 264 | {0x1002, 0x9441, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV770|RADEON_NEW_MEMMAP}, \ | 267 | {0x1002, 0x9441, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV770|RADEON_NEW_MEMMAP}, \ |
| 265 | {0x1002, 0x9442, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV770|RADEON_NEW_MEMMAP}, \ | 268 | {0x1002, 0x9442, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV770|RADEON_NEW_MEMMAP}, \ |
| @@ -288,6 +291,7 @@ | |||
| 288 | {0x1002, 0x948F, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV730|RADEON_NEW_MEMMAP}, \ | 291 | {0x1002, 0x948F, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV730|RADEON_NEW_MEMMAP}, \ |
| 289 | {0x1002, 0x9490, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV730|RADEON_NEW_MEMMAP}, \ | 292 | {0x1002, 0x9490, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV730|RADEON_NEW_MEMMAP}, \ |
| 290 | {0x1002, 0x9491, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV730|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ | 293 | {0x1002, 0x9491, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV730|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ |
| 294 | {0x1002, 0x9495, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV730|RADEON_NEW_MEMMAP}, \ | ||
| 291 | {0x1002, 0x9498, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV730|RADEON_NEW_MEMMAP}, \ | 295 | {0x1002, 0x9498, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV730|RADEON_NEW_MEMMAP}, \ |
| 292 | {0x1002, 0x949C, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV730|RADEON_NEW_MEMMAP}, \ | 296 | {0x1002, 0x949C, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV730|RADEON_NEW_MEMMAP}, \ |
| 293 | {0x1002, 0x949E, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV730|RADEON_NEW_MEMMAP}, \ | 297 | {0x1002, 0x949E, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV730|RADEON_NEW_MEMMAP}, \ |
| @@ -325,6 +329,7 @@ | |||
| 325 | {0x1002, 0x9552, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV710|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ | 329 | {0x1002, 0x9552, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV710|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ |
| 326 | {0x1002, 0x9553, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV710|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ | 330 | {0x1002, 0x9553, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV710|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ |
| 327 | {0x1002, 0x9555, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV710|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ | 331 | {0x1002, 0x9555, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV710|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ |
| 332 | {0x1002, 0x9557, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV710|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ | ||
| 328 | {0x1002, 0x9580, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV630|RADEON_NEW_MEMMAP}, \ | 333 | {0x1002, 0x9580, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV630|RADEON_NEW_MEMMAP}, \ |
| 329 | {0x1002, 0x9581, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV630|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ | 334 | {0x1002, 0x9581, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV630|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ |
| 330 | {0x1002, 0x9583, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV630|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ | 335 | {0x1002, 0x9583, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV630|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP}, \ |
| @@ -365,6 +370,11 @@ | |||
| 365 | {0x1002, 0x9614, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RS780|RADEON_NEW_MEMMAP|RADEON_IS_IGP}, \ | 370 | {0x1002, 0x9614, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RS780|RADEON_NEW_MEMMAP|RADEON_IS_IGP}, \ |
| 366 | {0x1002, 0x9615, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RS780|RADEON_NEW_MEMMAP|RADEON_IS_IGP}, \ | 371 | {0x1002, 0x9615, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RS780|RADEON_NEW_MEMMAP|RADEON_IS_IGP}, \ |
| 367 | {0x1002, 0x9616, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RS780|RADEON_NEW_MEMMAP|RADEON_IS_IGP}, \ | 372 | {0x1002, 0x9616, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RS780|RADEON_NEW_MEMMAP|RADEON_IS_IGP}, \ |
| 373 | {0x1002, 0x9710, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RS880|RADEON_NEW_MEMMAP|RADEON_IS_IGP}, \ | ||
| 374 | {0x1002, 0x9711, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RS880|RADEON_NEW_MEMMAP|RADEON_IS_IGP}, \ | ||
| 375 | {0x1002, 0x9712, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RS880|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP|RADEON_IS_IGP}, \ | ||
| 376 | {0x1002, 0x9713, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RS880|RADEON_IS_MOBILITY|RADEON_NEW_MEMMAP|RADEON_IS_IGP}, \ | ||
| 377 | {0x1002, 0x9714, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RS880|RADEON_NEW_MEMMAP|RADEON_IS_IGP}, \ | ||
| 368 | {0, 0, 0} | 378 | {0, 0, 0} |
| 369 | 379 | ||
| 370 | #define r128_PCI_IDS \ | 380 | #define r128_PCI_IDS \ |
diff --git a/include/drm/radeon_drm.h b/include/drm/radeon_drm.h index 41862e9a4c20..2ba61e18fc8b 100644 --- a/include/drm/radeon_drm.h +++ b/include/drm/radeon_drm.h | |||
| @@ -506,6 +506,9 @@ typedef struct { | |||
| 506 | #define DRM_RADEON_GEM_WAIT_IDLE 0x24 | 506 | #define DRM_RADEON_GEM_WAIT_IDLE 0x24 |
| 507 | #define DRM_RADEON_CS 0x26 | 507 | #define DRM_RADEON_CS 0x26 |
| 508 | #define DRM_RADEON_INFO 0x27 | 508 | #define DRM_RADEON_INFO 0x27 |
| 509 | #define DRM_RADEON_GEM_SET_TILING 0x28 | ||
| 510 | #define DRM_RADEON_GEM_GET_TILING 0x29 | ||
| 511 | #define DRM_RADEON_GEM_BUSY 0x2a | ||
| 509 | 512 | ||
| 510 | #define DRM_IOCTL_RADEON_CP_INIT DRM_IOW( DRM_COMMAND_BASE + DRM_RADEON_CP_INIT, drm_radeon_init_t) | 513 | #define DRM_IOCTL_RADEON_CP_INIT DRM_IOW( DRM_COMMAND_BASE + DRM_RADEON_CP_INIT, drm_radeon_init_t) |
| 511 | #define DRM_IOCTL_RADEON_CP_START DRM_IO( DRM_COMMAND_BASE + DRM_RADEON_CP_START) | 514 | #define DRM_IOCTL_RADEON_CP_START DRM_IO( DRM_COMMAND_BASE + DRM_RADEON_CP_START) |
| @@ -544,7 +547,9 @@ typedef struct { | |||
| 544 | #define DRM_IOCTL_RADEON_GEM_WAIT_IDLE DRM_IOW(DRM_COMMAND_BASE + DRM_RADEON_GEM_WAIT_IDLE, struct drm_radeon_gem_wait_idle) | 547 | #define DRM_IOCTL_RADEON_GEM_WAIT_IDLE DRM_IOW(DRM_COMMAND_BASE + DRM_RADEON_GEM_WAIT_IDLE, struct drm_radeon_gem_wait_idle) |
| 545 | #define DRM_IOCTL_RADEON_CS DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_CS, struct drm_radeon_cs) | 548 | #define DRM_IOCTL_RADEON_CS DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_CS, struct drm_radeon_cs) |
| 546 | #define DRM_IOCTL_RADEON_INFO DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_INFO, struct drm_radeon_info) | 549 | #define DRM_IOCTL_RADEON_INFO DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_INFO, struct drm_radeon_info) |
| 547 | 550 | #define DRM_IOCTL_RADEON_SET_TILING DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_GEM_SET_TILING, struct drm_radeon_gem_set_tiling) | |
| 551 | #define DRM_IOCTL_RADEON_GET_TILING DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_GEM_GET_TILING, struct drm_radeon_gem_get_tiling) | ||
| 552 | #define DRM_IOCTL_RADEON_GEM_BUSY DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_GEM_BUSY, struct drm_radeon_gem_busy) | ||
| 548 | 553 | ||
| 549 | typedef struct drm_radeon_init { | 554 | typedef struct drm_radeon_init { |
| 550 | enum { | 555 | enum { |
| @@ -704,6 +709,7 @@ typedef struct drm_radeon_indirect { | |||
| 704 | #define RADEON_PARAM_FB_LOCATION 14 /* FB location */ | 709 | #define RADEON_PARAM_FB_LOCATION 14 /* FB location */ |
| 705 | #define RADEON_PARAM_NUM_GB_PIPES 15 /* num GB pipes */ | 710 | #define RADEON_PARAM_NUM_GB_PIPES 15 /* num GB pipes */ |
| 706 | #define RADEON_PARAM_DEVICE_ID 16 | 711 | #define RADEON_PARAM_DEVICE_ID 16 |
| 712 | #define RADEON_PARAM_NUM_Z_PIPES 17 /* num Z pipes */ | ||
| 707 | 713 | ||
| 708 | typedef struct drm_radeon_getparam { | 714 | typedef struct drm_radeon_getparam { |
| 709 | int param; | 715 | int param; |
| @@ -796,6 +802,24 @@ struct drm_radeon_gem_create { | |||
| 796 | uint32_t flags; | 802 | uint32_t flags; |
| 797 | }; | 803 | }; |
| 798 | 804 | ||
| 805 | #define RADEON_TILING_MACRO 0x1 | ||
| 806 | #define RADEON_TILING_MICRO 0x2 | ||
| 807 | #define RADEON_TILING_SWAP 0x4 | ||
| 808 | #define RADEON_TILING_SURFACE 0x8 /* this object requires a surface | ||
| 809 | * when mapped - i.e. front buffer */ | ||
| 810 | |||
| 811 | struct drm_radeon_gem_set_tiling { | ||
| 812 | uint32_t handle; | ||
| 813 | uint32_t tiling_flags; | ||
| 814 | uint32_t pitch; | ||
| 815 | }; | ||
| 816 | |||
| 817 | struct drm_radeon_gem_get_tiling { | ||
| 818 | uint32_t handle; | ||
| 819 | uint32_t tiling_flags; | ||
| 820 | uint32_t pitch; | ||
| 821 | }; | ||
| 822 | |||
| 799 | struct drm_radeon_gem_mmap { | 823 | struct drm_radeon_gem_mmap { |
| 800 | uint32_t handle; | 824 | uint32_t handle; |
| 801 | uint32_t pad; | 825 | uint32_t pad; |
| @@ -817,7 +841,7 @@ struct drm_radeon_gem_wait_idle { | |||
| 817 | 841 | ||
| 818 | struct drm_radeon_gem_busy { | 842 | struct drm_radeon_gem_busy { |
| 819 | uint32_t handle; | 843 | uint32_t handle; |
| 820 | uint32_t busy; | 844 | uint32_t domain; |
| 821 | }; | 845 | }; |
| 822 | 846 | ||
| 823 | struct drm_radeon_gem_pread { | 847 | struct drm_radeon_gem_pread { |
| @@ -874,6 +898,7 @@ struct drm_radeon_cs { | |||
| 874 | 898 | ||
| 875 | #define RADEON_INFO_DEVICE_ID 0x00 | 899 | #define RADEON_INFO_DEVICE_ID 0x00 |
| 876 | #define RADEON_INFO_NUM_GB_PIPES 0x01 | 900 | #define RADEON_INFO_NUM_GB_PIPES 0x01 |
| 901 | #define RADEON_INFO_NUM_Z_PIPES 0x02 | ||
| 877 | 902 | ||
| 878 | struct drm_radeon_info { | 903 | struct drm_radeon_info { |
| 879 | uint32_t request; | 904 | uint32_t request; |
diff --git a/include/drm/ttm/ttm_bo_driver.h b/include/drm/ttm/ttm_bo_driver.h index 62ed733c52a2..a68829db381a 100644 --- a/include/drm/ttm/ttm_bo_driver.h +++ b/include/drm/ttm/ttm_bo_driver.h | |||
| @@ -121,6 +121,7 @@ struct ttm_backend { | |||
| 121 | #define TTM_PAGE_FLAG_SWAPPED (1 << 4) | 121 | #define TTM_PAGE_FLAG_SWAPPED (1 << 4) |
| 122 | #define TTM_PAGE_FLAG_PERSISTANT_SWAP (1 << 5) | 122 | #define TTM_PAGE_FLAG_PERSISTANT_SWAP (1 << 5) |
| 123 | #define TTM_PAGE_FLAG_ZERO_ALLOC (1 << 6) | 123 | #define TTM_PAGE_FLAG_ZERO_ALLOC (1 << 6) |
| 124 | #define TTM_PAGE_FLAG_DMA32 (1 << 7) | ||
| 124 | 125 | ||
| 125 | enum ttm_caching_state { | 126 | enum ttm_caching_state { |
| 126 | tt_uncached, | 127 | tt_uncached, |
| @@ -353,6 +354,14 @@ struct ttm_bo_driver { | |||
| 353 | int (*sync_obj_flush) (void *sync_obj, void *sync_arg); | 354 | int (*sync_obj_flush) (void *sync_obj, void *sync_arg); |
| 354 | void (*sync_obj_unref) (void **sync_obj); | 355 | void (*sync_obj_unref) (void **sync_obj); |
| 355 | void *(*sync_obj_ref) (void *sync_obj); | 356 | void *(*sync_obj_ref) (void *sync_obj); |
| 357 | |||
| 358 | /* hook to notify driver about a driver move so it | ||
| 359 | * can do tiling things */ | ||
| 360 | void (*move_notify)(struct ttm_buffer_object *bo, | ||
| 361 | struct ttm_mem_reg *new_mem); | ||
| 362 | /* notify the driver we are taking a fault on this BO | ||
| 363 | * and have reserved it */ | ||
| 364 | void (*fault_reserve_notify)(struct ttm_buffer_object *bo); | ||
| 356 | }; | 365 | }; |
| 357 | 366 | ||
| 358 | #define TTM_NUM_MEM_TYPES 8 | 367 | #define TTM_NUM_MEM_TYPES 8 |
| @@ -429,6 +438,8 @@ struct ttm_bo_device { | |||
| 429 | */ | 438 | */ |
| 430 | 439 | ||
| 431 | struct delayed_work wq; | 440 | struct delayed_work wq; |
| 441 | |||
| 442 | bool need_dma32; | ||
| 432 | }; | 443 | }; |
| 433 | 444 | ||
| 434 | /** | 445 | /** |
| @@ -648,7 +659,14 @@ extern int ttm_bo_device_release(struct ttm_bo_device *bdev); | |||
| 648 | extern int ttm_bo_device_init(struct ttm_bo_device *bdev, | 659 | extern int ttm_bo_device_init(struct ttm_bo_device *bdev, |
| 649 | struct ttm_mem_global *mem_glob, | 660 | struct ttm_mem_global *mem_glob, |
| 650 | struct ttm_bo_driver *driver, | 661 | struct ttm_bo_driver *driver, |
| 651 | uint64_t file_page_offset); | 662 | uint64_t file_page_offset, bool need_dma32); |
| 663 | |||
| 664 | /** | ||
| 665 | * ttm_bo_unmap_virtual | ||
| 666 | * | ||
| 667 | * @bo: tear down the virtual mappings for this BO | ||
| 668 | */ | ||
| 669 | extern void ttm_bo_unmap_virtual(struct ttm_buffer_object *bo); | ||
| 652 | 670 | ||
| 653 | /** | 671 | /** |
| 654 | * ttm_bo_reserve: | 672 | * ttm_bo_reserve: |
diff --git a/include/drm/ttm/ttm_module.h b/include/drm/ttm/ttm_module.h index 889a4c7958ae..d1d433834e4f 100644 --- a/include/drm/ttm/ttm_module.h +++ b/include/drm/ttm/ttm_module.h | |||
| @@ -33,7 +33,7 @@ | |||
| 33 | 33 | ||
| 34 | #include <linux/kernel.h> | 34 | #include <linux/kernel.h> |
| 35 | 35 | ||
| 36 | #define TTM_PFX "[TTM]" | 36 | #define TTM_PFX "[TTM] " |
| 37 | 37 | ||
| 38 | enum ttm_global_types { | 38 | enum ttm_global_types { |
| 39 | TTM_GLOBAL_TTM_MEM = 0, | 39 | TTM_GLOBAL_TTM_MEM = 0, |
diff --git a/include/linux/bitmap.h b/include/linux/bitmap.h index 2878811c6134..756d78b8c1c5 100644 --- a/include/linux/bitmap.h +++ b/include/linux/bitmap.h | |||
| @@ -94,13 +94,13 @@ extern void __bitmap_shift_right(unsigned long *dst, | |||
| 94 | const unsigned long *src, int shift, int bits); | 94 | const unsigned long *src, int shift, int bits); |
| 95 | extern void __bitmap_shift_left(unsigned long *dst, | 95 | extern void __bitmap_shift_left(unsigned long *dst, |
| 96 | const unsigned long *src, int shift, int bits); | 96 | const unsigned long *src, int shift, int bits); |
| 97 | extern void __bitmap_and(unsigned long *dst, const unsigned long *bitmap1, | 97 | extern int __bitmap_and(unsigned long *dst, const unsigned long *bitmap1, |
| 98 | const unsigned long *bitmap2, int bits); | 98 | const unsigned long *bitmap2, int bits); |
| 99 | extern void __bitmap_or(unsigned long *dst, const unsigned long *bitmap1, | 99 | extern void __bitmap_or(unsigned long *dst, const unsigned long *bitmap1, |
| 100 | const unsigned long *bitmap2, int bits); | 100 | const unsigned long *bitmap2, int bits); |
| 101 | extern void __bitmap_xor(unsigned long *dst, const unsigned long *bitmap1, | 101 | extern void __bitmap_xor(unsigned long *dst, const unsigned long *bitmap1, |
| 102 | const unsigned long *bitmap2, int bits); | 102 | const unsigned long *bitmap2, int bits); |
| 103 | extern void __bitmap_andnot(unsigned long *dst, const unsigned long *bitmap1, | 103 | extern int __bitmap_andnot(unsigned long *dst, const unsigned long *bitmap1, |
| 104 | const unsigned long *bitmap2, int bits); | 104 | const unsigned long *bitmap2, int bits); |
| 105 | extern int __bitmap_intersects(const unsigned long *bitmap1, | 105 | extern int __bitmap_intersects(const unsigned long *bitmap1, |
| 106 | const unsigned long *bitmap2, int bits); | 106 | const unsigned long *bitmap2, int bits); |
| @@ -171,13 +171,12 @@ static inline void bitmap_copy(unsigned long *dst, const unsigned long *src, | |||
| 171 | } | 171 | } |
| 172 | } | 172 | } |
| 173 | 173 | ||
| 174 | static inline void bitmap_and(unsigned long *dst, const unsigned long *src1, | 174 | static inline int bitmap_and(unsigned long *dst, const unsigned long *src1, |
| 175 | const unsigned long *src2, int nbits) | 175 | const unsigned long *src2, int nbits) |
| 176 | { | 176 | { |
| 177 | if (small_const_nbits(nbits)) | 177 | if (small_const_nbits(nbits)) |
| 178 | *dst = *src1 & *src2; | 178 | return (*dst = *src1 & *src2) != 0; |
| 179 | else | 179 | return __bitmap_and(dst, src1, src2, nbits); |
| 180 | __bitmap_and(dst, src1, src2, nbits); | ||
| 181 | } | 180 | } |
| 182 | 181 | ||
| 183 | static inline void bitmap_or(unsigned long *dst, const unsigned long *src1, | 182 | static inline void bitmap_or(unsigned long *dst, const unsigned long *src1, |
| @@ -198,13 +197,12 @@ static inline void bitmap_xor(unsigned long *dst, const unsigned long *src1, | |||
| 198 | __bitmap_xor(dst, src1, src2, nbits); | 197 | __bitmap_xor(dst, src1, src2, nbits); |
| 199 | } | 198 | } |
| 200 | 199 | ||
| 201 | static inline void bitmap_andnot(unsigned long *dst, const unsigned long *src1, | 200 | static inline int bitmap_andnot(unsigned long *dst, const unsigned long *src1, |
| 202 | const unsigned long *src2, int nbits) | 201 | const unsigned long *src2, int nbits) |
| 203 | { | 202 | { |
| 204 | if (small_const_nbits(nbits)) | 203 | if (small_const_nbits(nbits)) |
| 205 | *dst = *src1 & ~(*src2); | 204 | return (*dst = *src1 & ~(*src2)) != 0; |
| 206 | else | 205 | return __bitmap_andnot(dst, src1, src2, nbits); |
| 207 | __bitmap_andnot(dst, src1, src2, nbits); | ||
| 208 | } | 206 | } |
| 209 | 207 | ||
| 210 | static inline void bitmap_complement(unsigned long *dst, const unsigned long *src, | 208 | static inline void bitmap_complement(unsigned long *dst, const unsigned long *src, |
diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h index e7cb5dbf6c26..69103e053c92 100644 --- a/include/linux/blkdev.h +++ b/include/linux/blkdev.h | |||
| @@ -913,6 +913,7 @@ extern void blk_queue_logical_block_size(struct request_queue *, unsigned short) | |||
| 913 | extern void blk_queue_physical_block_size(struct request_queue *, unsigned short); | 913 | extern void blk_queue_physical_block_size(struct request_queue *, unsigned short); |
| 914 | extern void blk_queue_alignment_offset(struct request_queue *q, | 914 | extern void blk_queue_alignment_offset(struct request_queue *q, |
| 915 | unsigned int alignment); | 915 | unsigned int alignment); |
| 916 | extern void blk_limits_io_min(struct queue_limits *limits, unsigned int min); | ||
| 916 | extern void blk_queue_io_min(struct request_queue *q, unsigned int min); | 917 | extern void blk_queue_io_min(struct request_queue *q, unsigned int min); |
| 917 | extern void blk_queue_io_opt(struct request_queue *q, unsigned int opt); | 918 | extern void blk_queue_io_opt(struct request_queue *q, unsigned int opt); |
| 918 | extern void blk_set_default_limits(struct queue_limits *lim); | 919 | extern void blk_set_default_limits(struct queue_limits *lim); |
diff --git a/include/linux/cb710.h b/include/linux/cb710.h index 63bc9a4d2926..8cc10411bab2 100644 --- a/include/linux/cb710.h +++ b/include/linux/cb710.h | |||
| @@ -140,29 +140,6 @@ void cb710_dump_regs(struct cb710_chip *chip, unsigned dump); | |||
| 140 | #include <linux/highmem.h> | 140 | #include <linux/highmem.h> |
| 141 | #include <linux/scatterlist.h> | 141 | #include <linux/scatterlist.h> |
| 142 | 142 | ||
| 143 | /** | ||
| 144 | * cb710_sg_miter_stop_writing - stop mapping iteration after writing | ||
| 145 | * @miter: sg mapping iter to be stopped | ||
| 146 | * | ||
| 147 | * Description: | ||
| 148 | * Stops mapping iterator @miter. @miter should have been started | ||
| 149 | * started using sg_miter_start(). A stopped iteration can be | ||
| 150 | * resumed by calling sg_miter_next() on it. This is useful when | ||
| 151 | * resources (kmap) need to be released during iteration. | ||
| 152 | * | ||
| 153 | * This is a convenience wrapper that will be optimized out for arches | ||
| 154 | * that don't need flush_kernel_dcache_page(). | ||
| 155 | * | ||
| 156 | * Context: | ||
| 157 | * IRQ disabled if the SG_MITER_ATOMIC is set. Don't care otherwise. | ||
| 158 | */ | ||
| 159 | static inline void cb710_sg_miter_stop_writing(struct sg_mapping_iter *miter) | ||
| 160 | { | ||
| 161 | if (miter->page) | ||
| 162 | flush_kernel_dcache_page(miter->page); | ||
| 163 | sg_miter_stop(miter); | ||
| 164 | } | ||
| 165 | |||
| 166 | /* | 143 | /* |
| 167 | * 32-bit PIO mapping sg iterator | 144 | * 32-bit PIO mapping sg iterator |
| 168 | * | 145 | * |
| @@ -171,12 +148,12 @@ static inline void cb710_sg_miter_stop_writing(struct sg_mapping_iter *miter) | |||
| 171 | * without DMA support). | 148 | * without DMA support). |
| 172 | * | 149 | * |
| 173 | * Best-case reading (transfer from device): | 150 | * Best-case reading (transfer from device): |
| 174 | * sg_miter_start(); | 151 | * sg_miter_start(, SG_MITER_TO_SG); |
| 175 | * cb710_sg_dwiter_write_from_io(); | 152 | * cb710_sg_dwiter_write_from_io(); |
| 176 | * cb710_sg_miter_stop_writing(); | 153 | * sg_miter_stop(); |
| 177 | * | 154 | * |
| 178 | * Best-case writing (transfer to device): | 155 | * Best-case writing (transfer to device): |
| 179 | * sg_miter_start(); | 156 | * sg_miter_start(, SG_MITER_FROM_SG); |
| 180 | * cb710_sg_dwiter_read_to_io(); | 157 | * cb710_sg_dwiter_read_to_io(); |
| 181 | * sg_miter_stop(); | 158 | * sg_miter_stop(); |
| 182 | */ | 159 | */ |
diff --git a/include/linux/cgroup.h b/include/linux/cgroup.h index 665fa70e4094..90bba9e62286 100644 --- a/include/linux/cgroup.h +++ b/include/linux/cgroup.h | |||
| @@ -179,14 +179,11 @@ struct cgroup { | |||
| 179 | */ | 179 | */ |
| 180 | struct list_head release_list; | 180 | struct list_head release_list; |
| 181 | 181 | ||
| 182 | /* pids_mutex protects the fields below */ | 182 | /* pids_mutex protects pids_list and cached pid arrays. */ |
| 183 | struct rw_semaphore pids_mutex; | 183 | struct rw_semaphore pids_mutex; |
| 184 | /* Array of process ids in the cgroup */ | 184 | |
| 185 | pid_t *tasks_pids; | 185 | /* Linked list of struct cgroup_pids */ |
| 186 | /* How many files are using the current tasks_pids array */ | 186 | struct list_head pids_list; |
| 187 | int pids_use_count; | ||
| 188 | /* Length of the current tasks_pids array */ | ||
| 189 | int pids_length; | ||
| 190 | 187 | ||
| 191 | /* For RCU-protected deletion */ | 188 | /* For RCU-protected deletion */ |
| 192 | struct rcu_head rcu_head; | 189 | struct rcu_head rcu_head; |
| @@ -366,6 +363,23 @@ int cgroup_task_count(const struct cgroup *cgrp); | |||
| 366 | int cgroup_is_descendant(const struct cgroup *cgrp, struct task_struct *task); | 363 | int cgroup_is_descendant(const struct cgroup *cgrp, struct task_struct *task); |
| 367 | 364 | ||
| 368 | /* | 365 | /* |
| 366 | * When the subsys has to access css and may add permanent refcnt to css, | ||
| 367 | * it should take care of racy conditions with rmdir(). Following set of | ||
| 368 | * functions, is for stop/restart rmdir if necessary. | ||
| 369 | * Because these will call css_get/put, "css" should be alive css. | ||
| 370 | * | ||
| 371 | * cgroup_exclude_rmdir(); | ||
| 372 | * ...do some jobs which may access arbitrary empty cgroup | ||
| 373 | * cgroup_release_and_wakeup_rmdir(); | ||
| 374 | * | ||
| 375 | * When someone removes a cgroup while cgroup_exclude_rmdir() holds it, | ||
| 376 | * it sleeps and cgroup_release_and_wakeup_rmdir() will wake him up. | ||
| 377 | */ | ||
| 378 | |||
| 379 | void cgroup_exclude_rmdir(struct cgroup_subsys_state *css); | ||
| 380 | void cgroup_release_and_wakeup_rmdir(struct cgroup_subsys_state *css); | ||
| 381 | |||
| 382 | /* | ||
| 369 | * Control Group subsystem type. | 383 | * Control Group subsystem type. |
| 370 | * See Documentation/cgroups/cgroups.txt for details | 384 | * See Documentation/cgroups/cgroups.txt for details |
| 371 | */ | 385 | */ |
diff --git a/include/linux/clocksource.h b/include/linux/clocksource.h index c56457c8334e..1219be4fb42e 100644 --- a/include/linux/clocksource.h +++ b/include/linux/clocksource.h | |||
| @@ -293,7 +293,12 @@ static inline int clocksource_enable(struct clocksource *cs) | |||
| 293 | if (cs->enable) | 293 | if (cs->enable) |
| 294 | ret = cs->enable(cs); | 294 | ret = cs->enable(cs); |
| 295 | 295 | ||
| 296 | /* save mult_orig on enable */ | 296 | /* |
| 297 | * The frequency may have changed while the clocksource | ||
| 298 | * was disabled. If so the code in ->enable() must update | ||
| 299 | * the mult value to reflect the new frequency. Make sure | ||
| 300 | * mult_orig follows this change. | ||
| 301 | */ | ||
| 297 | cs->mult_orig = cs->mult; | 302 | cs->mult_orig = cs->mult; |
| 298 | 303 | ||
| 299 | return ret; | 304 | return ret; |
| @@ -309,6 +314,13 @@ static inline int clocksource_enable(struct clocksource *cs) | |||
| 309 | */ | 314 | */ |
| 310 | static inline void clocksource_disable(struct clocksource *cs) | 315 | static inline void clocksource_disable(struct clocksource *cs) |
| 311 | { | 316 | { |
| 317 | /* | ||
| 318 | * Save mult_orig in mult so clocksource_enable() can | ||
| 319 | * restore the value regardless if ->enable() updates | ||
| 320 | * the value of mult or not. | ||
| 321 | */ | ||
| 322 | cs->mult = cs->mult_orig; | ||
| 323 | |||
| 312 | if (cs->disable) | 324 | if (cs->disable) |
| 313 | cs->disable(cs); | 325 | cs->disable(cs); |
| 314 | } | 326 | } |
diff --git a/include/linux/cpumask.h b/include/linux/cpumask.h index c5ac87ca7bc6..796df12091b7 100644 --- a/include/linux/cpumask.h +++ b/include/linux/cpumask.h | |||
| @@ -43,10 +43,10 @@ | |||
| 43 | * int cpu_isset(cpu, mask) true iff bit 'cpu' set in mask | 43 | * int cpu_isset(cpu, mask) true iff bit 'cpu' set in mask |
| 44 | * int cpu_test_and_set(cpu, mask) test and set bit 'cpu' in mask | 44 | * int cpu_test_and_set(cpu, mask) test and set bit 'cpu' in mask |
| 45 | * | 45 | * |
| 46 | * void cpus_and(dst, src1, src2) dst = src1 & src2 [intersection] | 46 | * int cpus_and(dst, src1, src2) dst = src1 & src2 [intersection] |
| 47 | * void cpus_or(dst, src1, src2) dst = src1 | src2 [union] | 47 | * void cpus_or(dst, src1, src2) dst = src1 | src2 [union] |
| 48 | * void cpus_xor(dst, src1, src2) dst = src1 ^ src2 | 48 | * void cpus_xor(dst, src1, src2) dst = src1 ^ src2 |
| 49 | * void cpus_andnot(dst, src1, src2) dst = src1 & ~src2 | 49 | * int cpus_andnot(dst, src1, src2) dst = src1 & ~src2 |
| 50 | * void cpus_complement(dst, src) dst = ~src | 50 | * void cpus_complement(dst, src) dst = ~src |
| 51 | * | 51 | * |
| 52 | * int cpus_equal(mask1, mask2) Does mask1 == mask2? | 52 | * int cpus_equal(mask1, mask2) Does mask1 == mask2? |
| @@ -179,10 +179,10 @@ static inline int __cpu_test_and_set(int cpu, cpumask_t *addr) | |||
| 179 | } | 179 | } |
| 180 | 180 | ||
| 181 | #define cpus_and(dst, src1, src2) __cpus_and(&(dst), &(src1), &(src2), NR_CPUS) | 181 | #define cpus_and(dst, src1, src2) __cpus_and(&(dst), &(src1), &(src2), NR_CPUS) |
| 182 | static inline void __cpus_and(cpumask_t *dstp, const cpumask_t *src1p, | 182 | static inline int __cpus_and(cpumask_t *dstp, const cpumask_t *src1p, |
| 183 | const cpumask_t *src2p, int nbits) | 183 | const cpumask_t *src2p, int nbits) |
| 184 | { | 184 | { |
| 185 | bitmap_and(dstp->bits, src1p->bits, src2p->bits, nbits); | 185 | return bitmap_and(dstp->bits, src1p->bits, src2p->bits, nbits); |
| 186 | } | 186 | } |
| 187 | 187 | ||
| 188 | #define cpus_or(dst, src1, src2) __cpus_or(&(dst), &(src1), &(src2), NR_CPUS) | 188 | #define cpus_or(dst, src1, src2) __cpus_or(&(dst), &(src1), &(src2), NR_CPUS) |
| @@ -201,10 +201,10 @@ static inline void __cpus_xor(cpumask_t *dstp, const cpumask_t *src1p, | |||
| 201 | 201 | ||
| 202 | #define cpus_andnot(dst, src1, src2) \ | 202 | #define cpus_andnot(dst, src1, src2) \ |
| 203 | __cpus_andnot(&(dst), &(src1), &(src2), NR_CPUS) | 203 | __cpus_andnot(&(dst), &(src1), &(src2), NR_CPUS) |
| 204 | static inline void __cpus_andnot(cpumask_t *dstp, const cpumask_t *src1p, | 204 | static inline int __cpus_andnot(cpumask_t *dstp, const cpumask_t *src1p, |
| 205 | const cpumask_t *src2p, int nbits) | 205 | const cpumask_t *src2p, int nbits) |
| 206 | { | 206 | { |
| 207 | bitmap_andnot(dstp->bits, src1p->bits, src2p->bits, nbits); | 207 | return bitmap_andnot(dstp->bits, src1p->bits, src2p->bits, nbits); |
| 208 | } | 208 | } |
| 209 | 209 | ||
| 210 | #define cpus_complement(dst, src) __cpus_complement(&(dst), &(src), NR_CPUS) | 210 | #define cpus_complement(dst, src) __cpus_complement(&(dst), &(src), NR_CPUS) |
| @@ -738,11 +738,11 @@ static inline void cpumask_clear(struct cpumask *dstp) | |||
| 738 | * @src1p: the first input | 738 | * @src1p: the first input |
| 739 | * @src2p: the second input | 739 | * @src2p: the second input |
| 740 | */ | 740 | */ |
| 741 | static inline void cpumask_and(struct cpumask *dstp, | 741 | static inline int cpumask_and(struct cpumask *dstp, |
| 742 | const struct cpumask *src1p, | 742 | const struct cpumask *src1p, |
| 743 | const struct cpumask *src2p) | 743 | const struct cpumask *src2p) |
| 744 | { | 744 | { |
| 745 | bitmap_and(cpumask_bits(dstp), cpumask_bits(src1p), | 745 | return bitmap_and(cpumask_bits(dstp), cpumask_bits(src1p), |
| 746 | cpumask_bits(src2p), nr_cpumask_bits); | 746 | cpumask_bits(src2p), nr_cpumask_bits); |
| 747 | } | 747 | } |
| 748 | 748 | ||
| @@ -779,11 +779,11 @@ static inline void cpumask_xor(struct cpumask *dstp, | |||
| 779 | * @src1p: the first input | 779 | * @src1p: the first input |
| 780 | * @src2p: the second input | 780 | * @src2p: the second input |
| 781 | */ | 781 | */ |
| 782 | static inline void cpumask_andnot(struct cpumask *dstp, | 782 | static inline int cpumask_andnot(struct cpumask *dstp, |
| 783 | const struct cpumask *src1p, | 783 | const struct cpumask *src1p, |
| 784 | const struct cpumask *src2p) | 784 | const struct cpumask *src2p) |
| 785 | { | 785 | { |
| 786 | bitmap_andnot(cpumask_bits(dstp), cpumask_bits(src1p), | 786 | return bitmap_andnot(cpumask_bits(dstp), cpumask_bits(src1p), |
| 787 | cpumask_bits(src2p), nr_cpumask_bits); | 787 | cpumask_bits(src2p), nr_cpumask_bits); |
| 788 | } | 788 | } |
| 789 | 789 | ||
diff --git a/include/linux/decompress/generic.h b/include/linux/decompress/generic.h index 6dfb856327bb..0c7111a55a1a 100644 --- a/include/linux/decompress/generic.h +++ b/include/linux/decompress/generic.h | |||
| @@ -1,31 +1,37 @@ | |||
| 1 | #ifndef DECOMPRESS_GENERIC_H | 1 | #ifndef DECOMPRESS_GENERIC_H |
| 2 | #define DECOMPRESS_GENERIC_H | 2 | #define DECOMPRESS_GENERIC_H |
| 3 | 3 | ||
| 4 | /* Minimal chunksize to be read. | ||
| 5 | *Bzip2 prefers at least 4096 | ||
| 6 | *Lzma prefers 0x10000 */ | ||
| 7 | #define COMPR_IOBUF_SIZE 4096 | ||
| 8 | |||
| 9 | typedef int (*decompress_fn) (unsigned char *inbuf, int len, | 4 | typedef int (*decompress_fn) (unsigned char *inbuf, int len, |
| 10 | int(*fill)(void*, unsigned int), | 5 | int(*fill)(void*, unsigned int), |
| 11 | int(*writebb)(void*, unsigned int), | 6 | int(*flush)(void*, unsigned int), |
| 12 | unsigned char *output, | 7 | unsigned char *outbuf, |
| 13 | int *posp, | 8 | int *posp, |
| 14 | void(*error)(char *x)); | 9 | void(*error)(char *x)); |
| 15 | 10 | ||
| 16 | /* inbuf - input buffer | 11 | /* inbuf - input buffer |
| 17 | *len - len of pre-read data in inbuf | 12 | *len - len of pre-read data in inbuf |
| 18 | *fill - function to fill inbuf if empty | 13 | *fill - function to fill inbuf when empty |
| 19 | *writebb - function to write out outbug | 14 | *flush - function to write out outbuf |
| 15 | *outbuf - output buffer | ||
| 20 | *posp - if non-null, input position (number of bytes read) will be | 16 | *posp - if non-null, input position (number of bytes read) will be |
| 21 | * returned here | 17 | * returned here |
| 22 | * | 18 | * |
| 23 | *If len != 0, the inbuf is initialized (with as much data), and fill | 19 | *If len != 0, inbuf should contain all the necessary input data, and fill |
| 24 | *should not be called | 20 | *should be NULL |
| 25 | *If len = 0, the inbuf is allocated, but empty. Its size is IOBUF_SIZE | 21 | *If len = 0, inbuf can be NULL, in which case the decompressor will allocate |
| 26 | *fill should be called (repeatedly...) to read data, at most IOBUF_SIZE | 22 | *the input buffer. If inbuf != NULL it must be at least XXX_IOBUF_SIZE bytes. |
| 23 | *fill will be called (repeatedly...) to read data, at most XXX_IOBUF_SIZE | ||
| 24 | *bytes should be read per call. Replace XXX with the appropriate decompressor | ||
| 25 | *name, i.e. LZMA_IOBUF_SIZE. | ||
| 26 | * | ||
| 27 | *If flush = NULL, outbuf must be large enough to buffer all the expected | ||
| 28 | *output. If flush != NULL, the output buffer will be allocated by the | ||
| 29 | *decompressor (outbuf = NULL), and the flush function will be called to | ||
| 30 | *flush the output buffer at the appropriate time (decompressor and stream | ||
| 31 | *dependent). | ||
| 27 | */ | 32 | */ |
| 28 | 33 | ||
| 34 | |||
| 29 | /* Utility routine to detect the decompression method */ | 35 | /* Utility routine to detect the decompression method */ |
| 30 | decompress_fn decompress_method(const unsigned char *inbuf, int len, | 36 | decompress_fn decompress_method(const unsigned char *inbuf, int len, |
| 31 | const char **name); | 37 | const char **name); |
diff --git a/include/linux/device-mapper.h b/include/linux/device-mapper.h index 0d6310657f32..655e7721580a 100644 --- a/include/linux/device-mapper.h +++ b/include/linux/device-mapper.h | |||
| @@ -84,7 +84,7 @@ typedef int (*dm_merge_fn) (struct dm_target *ti, struct bvec_merge_data *bvm, | |||
| 84 | 84 | ||
| 85 | typedef int (*iterate_devices_callout_fn) (struct dm_target *ti, | 85 | typedef int (*iterate_devices_callout_fn) (struct dm_target *ti, |
| 86 | struct dm_dev *dev, | 86 | struct dm_dev *dev, |
| 87 | sector_t physical_start, | 87 | sector_t start, sector_t len, |
| 88 | void *data); | 88 | void *data); |
| 89 | 89 | ||
| 90 | typedef int (*dm_iterate_devices_fn) (struct dm_target *ti, | 90 | typedef int (*dm_iterate_devices_fn) (struct dm_target *ti, |
| @@ -104,7 +104,7 @@ void dm_error(const char *message); | |||
| 104 | * Combine device limits. | 104 | * Combine device limits. |
| 105 | */ | 105 | */ |
| 106 | int dm_set_device_limits(struct dm_target *ti, struct dm_dev *dev, | 106 | int dm_set_device_limits(struct dm_target *ti, struct dm_dev *dev, |
| 107 | sector_t start, void *data); | 107 | sector_t start, sector_t len, void *data); |
| 108 | 108 | ||
| 109 | struct dm_dev { | 109 | struct dm_dev { |
| 110 | struct block_device *bdev; | 110 | struct block_device *bdev; |
diff --git a/include/linux/ext3_fs.h b/include/linux/ext3_fs.h index 634a5e5aba3e..7499b3667798 100644 --- a/include/linux/ext3_fs.h +++ b/include/linux/ext3_fs.h | |||
| @@ -874,7 +874,7 @@ struct buffer_head * ext3_getblk (handle_t *, struct inode *, long, int, int *); | |||
| 874 | struct buffer_head * ext3_bread (handle_t *, struct inode *, int, int, int *); | 874 | struct buffer_head * ext3_bread (handle_t *, struct inode *, int, int, int *); |
| 875 | int ext3_get_blocks_handle(handle_t *handle, struct inode *inode, | 875 | int ext3_get_blocks_handle(handle_t *handle, struct inode *inode, |
| 876 | sector_t iblock, unsigned long maxblocks, struct buffer_head *bh_result, | 876 | sector_t iblock, unsigned long maxblocks, struct buffer_head *bh_result, |
| 877 | int create, int extend_disksize); | 877 | int create); |
| 878 | 878 | ||
| 879 | extern struct inode *ext3_iget(struct super_block *, unsigned long); | 879 | extern struct inode *ext3_iget(struct super_block *, unsigned long); |
| 880 | extern int ext3_write_inode (struct inode *, int); | 880 | extern int ext3_write_inode (struct inode *, int); |
diff --git a/include/linux/flex_array.h b/include/linux/flex_array.h new file mode 100644 index 000000000000..45ff18491514 --- /dev/null +++ b/include/linux/flex_array.h | |||
| @@ -0,0 +1,49 @@ | |||
| 1 | #ifndef _FLEX_ARRAY_H | ||
| 2 | #define _FLEX_ARRAY_H | ||
| 3 | |||
| 4 | #include <linux/types.h> | ||
| 5 | #include <asm/page.h> | ||
| 6 | |||
| 7 | #define FLEX_ARRAY_PART_SIZE PAGE_SIZE | ||
| 8 | #define FLEX_ARRAY_BASE_SIZE PAGE_SIZE | ||
| 9 | |||
| 10 | struct flex_array_part; | ||
| 11 | |||
| 12 | /* | ||
| 13 | * This is meant to replace cases where an array-like | ||
| 14 | * structure has gotten too big to fit into kmalloc() | ||
| 15 | * and the developer is getting tempted to use | ||
| 16 | * vmalloc(). | ||
| 17 | */ | ||
| 18 | |||
| 19 | struct flex_array { | ||
| 20 | union { | ||
| 21 | struct { | ||
| 22 | int element_size; | ||
| 23 | int total_nr_elements; | ||
| 24 | struct flex_array_part *parts[]; | ||
| 25 | }; | ||
| 26 | /* | ||
| 27 | * This little trick makes sure that | ||
| 28 | * sizeof(flex_array) == PAGE_SIZE | ||
| 29 | */ | ||
| 30 | char padding[FLEX_ARRAY_BASE_SIZE]; | ||
| 31 | }; | ||
| 32 | }; | ||
| 33 | |||
| 34 | #define FLEX_ARRAY_INIT(size, total) { { {\ | ||
| 35 | .element_size = (size), \ | ||
| 36 | .total_nr_elements = (total), \ | ||
| 37 | } } } | ||
| 38 | |||
| 39 | struct flex_array *flex_array_alloc(int element_size, unsigned int total, | ||
| 40 | gfp_t flags); | ||
| 41 | int flex_array_prealloc(struct flex_array *fa, unsigned int start, | ||
| 42 | unsigned int end, gfp_t flags); | ||
| 43 | void flex_array_free(struct flex_array *fa); | ||
| 44 | void flex_array_free_parts(struct flex_array *fa); | ||
| 45 | int flex_array_put(struct flex_array *fa, unsigned int element_nr, void *src, | ||
| 46 | gfp_t flags); | ||
| 47 | void *flex_array_get(struct flex_array *fa, unsigned int element_nr); | ||
| 48 | |||
| 49 | #endif /* _FLEX_ARRAY_H */ | ||
diff --git a/include/linux/fs.h b/include/linux/fs.h index 0872372184fe..73e9b643e455 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h | |||
| @@ -1946,6 +1946,7 @@ extern void putname(const char *name); | |||
| 1946 | extern int register_blkdev(unsigned int, const char *); | 1946 | extern int register_blkdev(unsigned int, const char *); |
| 1947 | extern void unregister_blkdev(unsigned int, const char *); | 1947 | extern void unregister_blkdev(unsigned int, const char *); |
| 1948 | extern struct block_device *bdget(dev_t); | 1948 | extern struct block_device *bdget(dev_t); |
| 1949 | extern struct block_device *bdgrab(struct block_device *bdev); | ||
| 1949 | extern void bd_set_size(struct block_device *, loff_t size); | 1950 | extern void bd_set_size(struct block_device *, loff_t size); |
| 1950 | extern void bd_forget(struct inode *inode); | 1951 | extern void bd_forget(struct inode *inode); |
| 1951 | extern void bdput(struct block_device *); | 1952 | extern void bdput(struct block_device *); |
| @@ -2122,7 +2123,7 @@ extern struct file *do_filp_open(int dfd, const char *pathname, | |||
| 2122 | int open_flag, int mode, int acc_mode); | 2123 | int open_flag, int mode, int acc_mode); |
| 2123 | extern int may_open(struct path *, int, int); | 2124 | extern int may_open(struct path *, int, int); |
| 2124 | 2125 | ||
| 2125 | extern int kernel_read(struct file *, unsigned long, char *, unsigned long); | 2126 | extern int kernel_read(struct file *, loff_t, char *, unsigned long); |
| 2126 | extern struct file * open_exec(const char *); | 2127 | extern struct file * open_exec(const char *); |
| 2127 | 2128 | ||
| 2128 | /* fs/dcache.c -- generic fs support functions */ | 2129 | /* fs/dcache.c -- generic fs support functions */ |
| @@ -2136,7 +2137,7 @@ extern loff_t default_llseek(struct file *file, loff_t offset, int origin); | |||
| 2136 | 2137 | ||
| 2137 | extern loff_t vfs_llseek(struct file *file, loff_t offset, int origin); | 2138 | extern loff_t vfs_llseek(struct file *file, loff_t offset, int origin); |
| 2138 | 2139 | ||
| 2139 | extern struct inode * inode_init_always(struct super_block *, struct inode *); | 2140 | extern int inode_init_always(struct super_block *, struct inode *); |
| 2140 | extern void inode_init_once(struct inode *); | 2141 | extern void inode_init_once(struct inode *); |
| 2141 | extern void inode_add_to_lists(struct super_block *, struct inode *); | 2142 | extern void inode_add_to_lists(struct super_block *, struct inode *); |
| 2142 | extern void iput(struct inode *); | 2143 | extern void iput(struct inode *); |
| @@ -2163,6 +2164,7 @@ extern void __iget(struct inode * inode); | |||
| 2163 | extern void iget_failed(struct inode *); | 2164 | extern void iget_failed(struct inode *); |
| 2164 | extern void clear_inode(struct inode *); | 2165 | extern void clear_inode(struct inode *); |
| 2165 | extern void destroy_inode(struct inode *); | 2166 | extern void destroy_inode(struct inode *); |
| 2167 | extern void __destroy_inode(struct inode *); | ||
| 2166 | extern struct inode *new_inode(struct super_block *); | 2168 | extern struct inode *new_inode(struct super_block *); |
| 2167 | extern int should_remove_suid(struct dentry *); | 2169 | extern int should_remove_suid(struct dentry *); |
| 2168 | extern int file_remove_suid(struct file *); | 2170 | extern int file_remove_suid(struct file *); |
diff --git a/include/linux/fsnotify_backend.h b/include/linux/fsnotify_backend.h index 6c3de999fb34..4d6f47b51189 100644 --- a/include/linux/fsnotify_backend.h +++ b/include/linux/fsnotify_backend.h | |||
| @@ -352,7 +352,7 @@ extern void fsnotify_unmount_inodes(struct list_head *list); | |||
| 352 | /* put here because inotify does some weird stuff when destroying watches */ | 352 | /* put here because inotify does some weird stuff when destroying watches */ |
| 353 | extern struct fsnotify_event *fsnotify_create_event(struct inode *to_tell, __u32 mask, | 353 | extern struct fsnotify_event *fsnotify_create_event(struct inode *to_tell, __u32 mask, |
| 354 | void *data, int data_is, const char *name, | 354 | void *data, int data_is, const char *name, |
| 355 | u32 cookie); | 355 | u32 cookie, gfp_t gfp); |
| 356 | 356 | ||
| 357 | #else | 357 | #else |
| 358 | 358 | ||
diff --git a/include/linux/ftrace_event.h b/include/linux/ftrace_event.h index 5c093ffc655b..a81170de7f6b 100644 --- a/include/linux/ftrace_event.h +++ b/include/linux/ftrace_event.h | |||
| @@ -89,7 +89,9 @@ enum print_line_t { | |||
| 89 | TRACE_TYPE_NO_CONSUME = 3 /* Handled but ask to not consume */ | 89 | TRACE_TYPE_NO_CONSUME = 3 /* Handled but ask to not consume */ |
| 90 | }; | 90 | }; |
| 91 | 91 | ||
| 92 | 92 | void tracing_generic_entry_update(struct trace_entry *entry, | |
| 93 | unsigned long flags, | ||
| 94 | int pc); | ||
| 93 | struct ring_buffer_event * | 95 | struct ring_buffer_event * |
| 94 | trace_current_buffer_lock_reserve(int type, unsigned long len, | 96 | trace_current_buffer_lock_reserve(int type, unsigned long len, |
| 95 | unsigned long flags, int pc); | 97 | unsigned long flags, int pc); |
| @@ -119,11 +121,9 @@ struct ftrace_event_call { | |||
| 119 | void *filter; | 121 | void *filter; |
| 120 | void *mod; | 122 | void *mod; |
| 121 | 123 | ||
| 122 | #ifdef CONFIG_EVENT_PROFILE | 124 | atomic_t profile_count; |
| 123 | atomic_t profile_count; | 125 | int (*profile_enable)(struct ftrace_event_call *); |
| 124 | int (*profile_enable)(struct ftrace_event_call *); | 126 | void (*profile_disable)(struct ftrace_event_call *); |
| 125 | void (*profile_disable)(struct ftrace_event_call *); | ||
| 126 | #endif | ||
| 127 | }; | 127 | }; |
| 128 | 128 | ||
| 129 | #define MAX_FILTER_PRED 32 | 129 | #define MAX_FILTER_PRED 32 |
diff --git a/include/linux/gen_stats.h b/include/linux/gen_stats.h index 0ffa41df0ee8..710e901085d0 100644 --- a/include/linux/gen_stats.h +++ b/include/linux/gen_stats.h | |||
| @@ -22,6 +22,11 @@ struct gnet_stats_basic | |||
| 22 | { | 22 | { |
| 23 | __u64 bytes; | 23 | __u64 bytes; |
| 24 | __u32 packets; | 24 | __u32 packets; |
| 25 | }; | ||
| 26 | struct gnet_stats_basic_packed | ||
| 27 | { | ||
| 28 | __u64 bytes; | ||
| 29 | __u32 packets; | ||
| 25 | } __attribute__ ((packed)); | 30 | } __attribute__ ((packed)); |
| 26 | 31 | ||
| 27 | /** | 32 | /** |
diff --git a/include/linux/hugetlb.h b/include/linux/hugetlb.h index 2723513a5651..5cbc620bdfe0 100644 --- a/include/linux/hugetlb.h +++ b/include/linux/hugetlb.h | |||
| @@ -10,6 +10,7 @@ | |||
| 10 | #include <asm/tlbflush.h> | 10 | #include <asm/tlbflush.h> |
| 11 | 11 | ||
| 12 | struct ctl_table; | 12 | struct ctl_table; |
| 13 | struct user_struct; | ||
| 13 | 14 | ||
| 14 | int PageHuge(struct page *page); | 15 | int PageHuge(struct page *page); |
| 15 | 16 | ||
| @@ -146,7 +147,8 @@ static inline struct hugetlbfs_sb_info *HUGETLBFS_SB(struct super_block *sb) | |||
| 146 | 147 | ||
| 147 | extern const struct file_operations hugetlbfs_file_operations; | 148 | extern const struct file_operations hugetlbfs_file_operations; |
| 148 | extern struct vm_operations_struct hugetlb_vm_ops; | 149 | extern struct vm_operations_struct hugetlb_vm_ops; |
| 149 | struct file *hugetlb_file_setup(const char *name, size_t, int); | 150 | struct file *hugetlb_file_setup(const char *name, size_t size, int acct, |
| 151 | struct user_struct **user); | ||
| 150 | int hugetlb_get_quota(struct address_space *mapping, long delta); | 152 | int hugetlb_get_quota(struct address_space *mapping, long delta); |
| 151 | void hugetlb_put_quota(struct address_space *mapping, long delta); | 153 | void hugetlb_put_quota(struct address_space *mapping, long delta); |
| 152 | 154 | ||
| @@ -168,7 +170,7 @@ static inline void set_file_hugepages(struct file *file) | |||
| 168 | 170 | ||
| 169 | #define is_file_hugepages(file) 0 | 171 | #define is_file_hugepages(file) 0 |
| 170 | #define set_file_hugepages(file) BUG() | 172 | #define set_file_hugepages(file) BUG() |
| 171 | #define hugetlb_file_setup(name,size,acctflag) ERR_PTR(-ENOSYS) | 173 | #define hugetlb_file_setup(name,size,acct,user) ERR_PTR(-ENOSYS) |
| 172 | 174 | ||
| 173 | #endif /* !CONFIG_HUGETLBFS */ | 175 | #endif /* !CONFIG_HUGETLBFS */ |
| 174 | 176 | ||
diff --git a/include/linux/inetdevice.h b/include/linux/inetdevice.h index acef2a770b6b..ad27c7da8798 100644 --- a/include/linux/inetdevice.h +++ b/include/linux/inetdevice.h | |||
| @@ -82,7 +82,7 @@ static inline void ipv4_devconf_setall(struct in_device *in_dev) | |||
| 82 | 82 | ||
| 83 | #define IN_DEV_FORWARD(in_dev) IN_DEV_CONF_GET((in_dev), FORWARDING) | 83 | #define IN_DEV_FORWARD(in_dev) IN_DEV_CONF_GET((in_dev), FORWARDING) |
| 84 | #define IN_DEV_MFORWARD(in_dev) IN_DEV_ANDCONF((in_dev), MC_FORWARDING) | 84 | #define IN_DEV_MFORWARD(in_dev) IN_DEV_ANDCONF((in_dev), MC_FORWARDING) |
| 85 | #define IN_DEV_RPFILTER(in_dev) IN_DEV_ANDCONF((in_dev), RP_FILTER) | 85 | #define IN_DEV_RPFILTER(in_dev) IN_DEV_MAXCONF((in_dev), RP_FILTER) |
| 86 | #define IN_DEV_SOURCE_ROUTE(in_dev) IN_DEV_ANDCONF((in_dev), \ | 86 | #define IN_DEV_SOURCE_ROUTE(in_dev) IN_DEV_ANDCONF((in_dev), \ |
| 87 | ACCEPT_SOURCE_ROUTE) | 87 | ACCEPT_SOURCE_ROUTE) |
| 88 | #define IN_DEV_BOOTP_RELAY(in_dev) IN_DEV_ANDCONF((in_dev), BOOTP_RELAY) | 88 | #define IN_DEV_BOOTP_RELAY(in_dev) IN_DEV_ANDCONF((in_dev), BOOTP_RELAY) |
diff --git a/include/linux/input/matrix_keypad.h b/include/linux/input/matrix_keypad.h index 7964516c6954..15d5903af2dd 100644 --- a/include/linux/input/matrix_keypad.h +++ b/include/linux/input/matrix_keypad.h | |||
| @@ -15,12 +15,13 @@ | |||
| 15 | #define KEY_COL(k) (((k) >> 16) & 0xff) | 15 | #define KEY_COL(k) (((k) >> 16) & 0xff) |
| 16 | #define KEY_VAL(k) ((k) & 0xffff) | 16 | #define KEY_VAL(k) ((k) & 0xffff) |
| 17 | 17 | ||
| 18 | #define MATRIX_SCAN_CODE(row, col, row_shift) (((row) << (row_shift)) + (col)) | ||
| 19 | |||
| 18 | /** | 20 | /** |
| 19 | * struct matrix_keymap_data - keymap for matrix keyboards | 21 | * struct matrix_keymap_data - keymap for matrix keyboards |
| 20 | * @keymap: pointer to array of uint32 values encoded with KEY() macro | 22 | * @keymap: pointer to array of uint32 values encoded with KEY() macro |
| 21 | * representing keymap | 23 | * representing keymap |
| 22 | * @keymap_size: number of entries (initialized) in this keymap | 24 | * @keymap_size: number of entries (initialized) in this keymap |
| 23 | * @max_keymap_size: maximum size of keymap supported by the device | ||
| 24 | * | 25 | * |
| 25 | * This structure is supposed to be used by platform code to supply | 26 | * This structure is supposed to be used by platform code to supply |
| 26 | * keymaps to drivers that implement matrix-like keypads/keyboards. | 27 | * keymaps to drivers that implement matrix-like keypads/keyboards. |
| @@ -28,14 +29,13 @@ | |||
| 28 | struct matrix_keymap_data { | 29 | struct matrix_keymap_data { |
| 29 | const uint32_t *keymap; | 30 | const uint32_t *keymap; |
| 30 | unsigned int keymap_size; | 31 | unsigned int keymap_size; |
| 31 | unsigned int max_keymap_size; | ||
| 32 | }; | 32 | }; |
| 33 | 33 | ||
| 34 | /** | 34 | /** |
| 35 | * struct matrix_keypad_platform_data - platform-dependent keypad data | 35 | * struct matrix_keypad_platform_data - platform-dependent keypad data |
| 36 | * @keymap_data: pointer to &matrix_keymap_data | 36 | * @keymap_data: pointer to &matrix_keymap_data |
| 37 | * @row_gpios: array of gpio numbers reporesenting rows | 37 | * @row_gpios: pointer to array of gpio numbers representing rows |
| 38 | * @col_gpios: array of gpio numbers reporesenting colums | 38 | * @col_gpios: pointer to array of gpio numbers reporesenting colums |
| 39 | * @num_row_gpios: actual number of row gpios used by device | 39 | * @num_row_gpios: actual number of row gpios used by device |
| 40 | * @num_col_gpios: actual number of col gpios used by device | 40 | * @num_col_gpios: actual number of col gpios used by device |
| 41 | * @col_scan_delay_us: delay, measured in microseconds, that is | 41 | * @col_scan_delay_us: delay, measured in microseconds, that is |
| @@ -48,8 +48,9 @@ struct matrix_keymap_data { | |||
| 48 | struct matrix_keypad_platform_data { | 48 | struct matrix_keypad_platform_data { |
| 49 | const struct matrix_keymap_data *keymap_data; | 49 | const struct matrix_keymap_data *keymap_data; |
| 50 | 50 | ||
| 51 | unsigned int row_gpios[MATRIX_MAX_ROWS]; | 51 | const unsigned int *row_gpios; |
| 52 | unsigned int col_gpios[MATRIX_MAX_COLS]; | 52 | const unsigned int *col_gpios; |
| 53 | |||
| 53 | unsigned int num_row_gpios; | 54 | unsigned int num_row_gpios; |
| 54 | unsigned int num_col_gpios; | 55 | unsigned int num_col_gpios; |
| 55 | 56 | ||
diff --git a/include/linux/interrupt.h b/include/linux/interrupt.h index 2721f07e9354..35e7df1e9f30 100644 --- a/include/linux/interrupt.h +++ b/include/linux/interrupt.h | |||
| @@ -14,6 +14,7 @@ | |||
| 14 | #include <linux/irqflags.h> | 14 | #include <linux/irqflags.h> |
| 15 | #include <linux/smp.h> | 15 | #include <linux/smp.h> |
| 16 | #include <linux/percpu.h> | 16 | #include <linux/percpu.h> |
| 17 | #include <linux/hrtimer.h> | ||
| 17 | 18 | ||
| 18 | #include <asm/atomic.h> | 19 | #include <asm/atomic.h> |
| 19 | #include <asm/ptrace.h> | 20 | #include <asm/ptrace.h> |
| @@ -64,11 +65,13 @@ | |||
| 64 | * IRQTF_RUNTHREAD - signals that the interrupt handler thread should run | 65 | * IRQTF_RUNTHREAD - signals that the interrupt handler thread should run |
| 65 | * IRQTF_DIED - handler thread died | 66 | * IRQTF_DIED - handler thread died |
| 66 | * IRQTF_WARNED - warning "IRQ_WAKE_THREAD w/o thread_fn" has been printed | 67 | * IRQTF_WARNED - warning "IRQ_WAKE_THREAD w/o thread_fn" has been printed |
| 68 | * IRQTF_AFFINITY - irq thread is requested to adjust affinity | ||
| 67 | */ | 69 | */ |
| 68 | enum { | 70 | enum { |
| 69 | IRQTF_RUNTHREAD, | 71 | IRQTF_RUNTHREAD, |
| 70 | IRQTF_DIED, | 72 | IRQTF_DIED, |
| 71 | IRQTF_WARNED, | 73 | IRQTF_WARNED, |
| 74 | IRQTF_AFFINITY, | ||
| 72 | }; | 75 | }; |
| 73 | 76 | ||
| 74 | typedef irqreturn_t (*irq_handler_t)(int, void *); | 77 | typedef irqreturn_t (*irq_handler_t)(int, void *); |
| @@ -517,6 +520,31 @@ extern void tasklet_kill_immediate(struct tasklet_struct *t, unsigned int cpu); | |||
| 517 | extern void tasklet_init(struct tasklet_struct *t, | 520 | extern void tasklet_init(struct tasklet_struct *t, |
| 518 | void (*func)(unsigned long), unsigned long data); | 521 | void (*func)(unsigned long), unsigned long data); |
| 519 | 522 | ||
| 523 | struct tasklet_hrtimer { | ||
| 524 | struct hrtimer timer; | ||
| 525 | struct tasklet_struct tasklet; | ||
| 526 | enum hrtimer_restart (*function)(struct hrtimer *); | ||
| 527 | }; | ||
| 528 | |||
| 529 | extern void | ||
| 530 | tasklet_hrtimer_init(struct tasklet_hrtimer *ttimer, | ||
| 531 | enum hrtimer_restart (*function)(struct hrtimer *), | ||
| 532 | clockid_t which_clock, enum hrtimer_mode mode); | ||
| 533 | |||
| 534 | static inline | ||
| 535 | int tasklet_hrtimer_start(struct tasklet_hrtimer *ttimer, ktime_t time, | ||
| 536 | const enum hrtimer_mode mode) | ||
| 537 | { | ||
| 538 | return hrtimer_start(&ttimer->timer, time, mode); | ||
| 539 | } | ||
| 540 | |||
| 541 | static inline | ||
| 542 | void tasklet_hrtimer_cancel(struct tasklet_hrtimer *ttimer) | ||
| 543 | { | ||
| 544 | hrtimer_cancel(&ttimer->timer); | ||
| 545 | tasklet_kill(&ttimer->tasklet); | ||
| 546 | } | ||
| 547 | |||
| 520 | /* | 548 | /* |
| 521 | * Autoprobing for irqs: | 549 | * Autoprobing for irqs: |
| 522 | * | 550 | * |
diff --git a/include/linux/iocontext.h b/include/linux/iocontext.h index dd05434fa45f..4da4a75c3f1e 100644 --- a/include/linux/iocontext.h +++ b/include/linux/iocontext.h | |||
| @@ -92,7 +92,7 @@ static inline struct io_context *ioc_task_link(struct io_context *ioc) | |||
| 92 | * a race). | 92 | * a race). |
| 93 | */ | 93 | */ |
| 94 | if (ioc && atomic_long_inc_not_zero(&ioc->refcount)) { | 94 | if (ioc && atomic_long_inc_not_zero(&ioc->refcount)) { |
| 95 | atomic_long_inc(&ioc->refcount); | 95 | atomic_inc(&ioc->nr_tasks); |
| 96 | return ioc; | 96 | return ioc; |
| 97 | } | 97 | } |
| 98 | 98 | ||
diff --git a/include/linux/kvm_host.h b/include/linux/kvm_host.h index 16713dc672e4..3060bdc35ffe 100644 --- a/include/linux/kvm_host.h +++ b/include/linux/kvm_host.h | |||
| @@ -110,6 +110,7 @@ struct kvm_memory_slot { | |||
| 110 | 110 | ||
| 111 | struct kvm_kernel_irq_routing_entry { | 111 | struct kvm_kernel_irq_routing_entry { |
| 112 | u32 gsi; | 112 | u32 gsi; |
| 113 | u32 type; | ||
| 113 | int (*set)(struct kvm_kernel_irq_routing_entry *e, | 114 | int (*set)(struct kvm_kernel_irq_routing_entry *e, |
| 114 | struct kvm *kvm, int level); | 115 | struct kvm *kvm, int level); |
| 115 | union { | 116 | union { |
diff --git a/include/linux/lguest.h b/include/linux/lguest.h index dbf2479e808e..2fb1dcbcb5aa 100644 --- a/include/linux/lguest.h +++ b/include/linux/lguest.h | |||
| @@ -1,5 +1,7 @@ | |||
| 1 | /* Things the lguest guest needs to know. Note: like all lguest interfaces, | 1 | /* |
| 2 | * this is subject to wild and random change between versions. */ | 2 | * Things the lguest guest needs to know. Note: like all lguest interfaces, |
| 3 | * this is subject to wild and random change between versions. | ||
| 4 | */ | ||
| 3 | #ifndef _LINUX_LGUEST_H | 5 | #ifndef _LINUX_LGUEST_H |
| 4 | #define _LINUX_LGUEST_H | 6 | #define _LINUX_LGUEST_H |
| 5 | 7 | ||
| @@ -11,32 +13,41 @@ | |||
| 11 | #define LG_CLOCK_MIN_DELTA 100UL | 13 | #define LG_CLOCK_MIN_DELTA 100UL |
| 12 | #define LG_CLOCK_MAX_DELTA ULONG_MAX | 14 | #define LG_CLOCK_MAX_DELTA ULONG_MAX |
| 13 | 15 | ||
| 14 | /*G:031 The second method of communicating with the Host is to via "struct | 16 | /*G:031 |
| 17 | * The second method of communicating with the Host is to via "struct | ||
| 15 | * lguest_data". Once the Guest's initialization hypercall tells the Host where | 18 | * lguest_data". Once the Guest's initialization hypercall tells the Host where |
| 16 | * this is, the Guest and Host both publish information in it. :*/ | 19 | * this is, the Guest and Host both publish information in it. |
| 17 | struct lguest_data | 20 | :*/ |
| 18 | { | 21 | struct lguest_data { |
| 19 | /* 512 == enabled (same as eflags in normal hardware). The Guest | 22 | /* |
| 20 | * changes interrupts so often that a hypercall is too slow. */ | 23 | * 512 == enabled (same as eflags in normal hardware). The Guest |
| 24 | * changes interrupts so often that a hypercall is too slow. | ||
| 25 | */ | ||
| 21 | unsigned int irq_enabled; | 26 | unsigned int irq_enabled; |
| 22 | /* Fine-grained interrupt disabling by the Guest */ | 27 | /* Fine-grained interrupt disabling by the Guest */ |
| 23 | DECLARE_BITMAP(blocked_interrupts, LGUEST_IRQS); | 28 | DECLARE_BITMAP(blocked_interrupts, LGUEST_IRQS); |
| 24 | 29 | ||
| 25 | /* The Host writes the virtual address of the last page fault here, | 30 | /* |
| 31 | * The Host writes the virtual address of the last page fault here, | ||
| 26 | * which saves the Guest a hypercall. CR2 is the native register where | 32 | * which saves the Guest a hypercall. CR2 is the native register where |
| 27 | * this address would normally be found. */ | 33 | * this address would normally be found. |
| 34 | */ | ||
| 28 | unsigned long cr2; | 35 | unsigned long cr2; |
| 29 | 36 | ||
| 30 | /* Wallclock time set by the Host. */ | 37 | /* Wallclock time set by the Host. */ |
| 31 | struct timespec time; | 38 | struct timespec time; |
| 32 | 39 | ||
| 33 | /* Interrupt pending set by the Host. The Guest should do a hypercall | 40 | /* |
| 34 | * if it re-enables interrupts and sees this set (to X86_EFLAGS_IF). */ | 41 | * Interrupt pending set by the Host. The Guest should do a hypercall |
| 42 | * if it re-enables interrupts and sees this set (to X86_EFLAGS_IF). | ||
| 43 | */ | ||
| 35 | int irq_pending; | 44 | int irq_pending; |
| 36 | 45 | ||
| 37 | /* Async hypercall ring. Instead of directly making hypercalls, we can | 46 | /* |
| 47 | * Async hypercall ring. Instead of directly making hypercalls, we can | ||
| 38 | * place them in here for processing the next time the Host wants. | 48 | * place them in here for processing the next time the Host wants. |
| 39 | * This batching can be quite efficient. */ | 49 | * This batching can be quite efficient. |
| 50 | */ | ||
| 40 | 51 | ||
| 41 | /* 0xFF == done (set by Host), 0 == pending (set by Guest). */ | 52 | /* 0xFF == done (set by Host), 0 == pending (set by Guest). */ |
| 42 | u8 hcall_status[LHCALL_RING_SIZE]; | 53 | u8 hcall_status[LHCALL_RING_SIZE]; |
diff --git a/include/linux/lguest_launcher.h b/include/linux/lguest_launcher.h index bfefbdf7498a..495203ff221c 100644 --- a/include/linux/lguest_launcher.h +++ b/include/linux/lguest_launcher.h | |||
| @@ -29,8 +29,10 @@ struct lguest_device_desc { | |||
| 29 | __u8 type; | 29 | __u8 type; |
| 30 | /* The number of virtqueues (first in config array) */ | 30 | /* The number of virtqueues (first in config array) */ |
| 31 | __u8 num_vq; | 31 | __u8 num_vq; |
| 32 | /* The number of bytes of feature bits. Multiply by 2: one for host | 32 | /* |
| 33 | * features and one for Guest acknowledgements. */ | 33 | * The number of bytes of feature bits. Multiply by 2: one for host |
| 34 | * features and one for Guest acknowledgements. | ||
| 35 | */ | ||
| 34 | __u8 feature_len; | 36 | __u8 feature_len; |
| 35 | /* The number of bytes of the config array after virtqueues. */ | 37 | /* The number of bytes of the config array after virtqueues. */ |
| 36 | __u8 config_len; | 38 | __u8 config_len; |
| @@ -39,8 +41,10 @@ struct lguest_device_desc { | |||
| 39 | __u8 config[0]; | 41 | __u8 config[0]; |
| 40 | }; | 42 | }; |
| 41 | 43 | ||
| 42 | /*D:135 This is how we expect the device configuration field for a virtqueue | 44 | /*D:135 |
| 43 | * to be laid out in config space. */ | 45 | * This is how we expect the device configuration field for a virtqueue |
| 46 | * to be laid out in config space. | ||
| 47 | */ | ||
| 44 | struct lguest_vqconfig { | 48 | struct lguest_vqconfig { |
| 45 | /* The number of entries in the virtio_ring */ | 49 | /* The number of entries in the virtio_ring */ |
| 46 | __u16 num; | 50 | __u16 num; |
| @@ -61,7 +65,9 @@ enum lguest_req | |||
| 61 | LHREQ_EVENTFD, /* + address, fd. */ | 65 | LHREQ_EVENTFD, /* + address, fd. */ |
| 62 | }; | 66 | }; |
| 63 | 67 | ||
| 64 | /* The alignment to use between consumer and producer parts of vring. | 68 | /* |
| 65 | * x86 pagesize for historical reasons. */ | 69 | * The alignment to use between consumer and producer parts of vring. |
| 70 | * x86 pagesize for historical reasons. | ||
| 71 | */ | ||
| 66 | #define LGUEST_VRING_ALIGN 4096 | 72 | #define LGUEST_VRING_ALIGN 4096 |
| 67 | #endif /* _LINUX_LGUEST_LAUNCHER */ | 73 | #endif /* _LINUX_LGUEST_LAUNCHER */ |
diff --git a/include/linux/libata.h b/include/linux/libata.h index 79b6d7fd4ac2..e5b6e33c6571 100644 --- a/include/linux/libata.h +++ b/include/linux/libata.h | |||
| @@ -589,6 +589,7 @@ struct ata_device { | |||
| 589 | #endif | 589 | #endif |
| 590 | /* n_sector is CLEAR_BEGIN, read comment above CLEAR_BEGIN */ | 590 | /* n_sector is CLEAR_BEGIN, read comment above CLEAR_BEGIN */ |
| 591 | u64 n_sectors; /* size of device, if ATA */ | 591 | u64 n_sectors; /* size of device, if ATA */ |
| 592 | u64 n_native_sectors; /* native size, if ATA */ | ||
| 592 | unsigned int class; /* ATA_DEV_xxx */ | 593 | unsigned int class; /* ATA_DEV_xxx */ |
| 593 | unsigned long unpark_deadline; | 594 | unsigned long unpark_deadline; |
| 594 | 595 | ||
diff --git a/include/linux/mm.h b/include/linux/mm.h index ba3a7cb1eaa0..9a72cc78e6b8 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h | |||
| @@ -34,8 +34,6 @@ extern int sysctl_legacy_va_layout; | |||
| 34 | #define sysctl_legacy_va_layout 0 | 34 | #define sysctl_legacy_va_layout 0 |
| 35 | #endif | 35 | #endif |
| 36 | 36 | ||
| 37 | extern unsigned long mmap_min_addr; | ||
| 38 | |||
| 39 | #include <asm/page.h> | 37 | #include <asm/page.h> |
| 40 | #include <asm/pgtable.h> | 38 | #include <asm/pgtable.h> |
| 41 | #include <asm/processor.h> | 39 | #include <asm/processor.h> |
| @@ -575,19 +573,6 @@ static inline void set_page_links(struct page *page, enum zone_type zone, | |||
| 575 | } | 573 | } |
| 576 | 574 | ||
| 577 | /* | 575 | /* |
| 578 | * If a hint addr is less than mmap_min_addr change hint to be as | ||
| 579 | * low as possible but still greater than mmap_min_addr | ||
| 580 | */ | ||
| 581 | static inline unsigned long round_hint_to_min(unsigned long hint) | ||
| 582 | { | ||
| 583 | hint &= PAGE_MASK; | ||
| 584 | if (((void *)hint != NULL) && | ||
| 585 | (hint < mmap_min_addr)) | ||
| 586 | return PAGE_ALIGN(mmap_min_addr); | ||
| 587 | return hint; | ||
| 588 | } | ||
| 589 | |||
| 590 | /* | ||
| 591 | * Some inline functions in vmstat.h depend on page_zone() | 576 | * Some inline functions in vmstat.h depend on page_zone() |
| 592 | */ | 577 | */ |
| 593 | #include <linux/vmstat.h> | 578 | #include <linux/vmstat.h> |
diff --git a/include/linux/mm_types.h b/include/linux/mm_types.h index 7acc8439d9b3..0042090a4d70 100644 --- a/include/linux/mm_types.h +++ b/include/linux/mm_types.h | |||
| @@ -240,8 +240,6 @@ struct mm_struct { | |||
| 240 | 240 | ||
| 241 | unsigned long saved_auxv[AT_VECTOR_SIZE]; /* for /proc/PID/auxv */ | 241 | unsigned long saved_auxv[AT_VECTOR_SIZE]; /* for /proc/PID/auxv */ |
| 242 | 242 | ||
| 243 | s8 oom_adj; /* OOM kill score adjustment (bit shift) */ | ||
| 244 | |||
| 245 | cpumask_t cpu_vm_mask; | 243 | cpumask_t cpu_vm_mask; |
| 246 | 244 | ||
| 247 | /* Architecture-specific MM context */ | 245 | /* Architecture-specific MM context */ |
diff --git a/include/linux/mtd/mtd.h b/include/linux/mtd/mtd.h index 5675b63a0631..0f32a9b6ff55 100644 --- a/include/linux/mtd/mtd.h +++ b/include/linux/mtd/mtd.h | |||
| @@ -251,7 +251,7 @@ struct mtd_info { | |||
| 251 | 251 | ||
| 252 | static inline struct mtd_info *dev_to_mtd(struct device *dev) | 252 | static inline struct mtd_info *dev_to_mtd(struct device *dev) |
| 253 | { | 253 | { |
| 254 | return dev ? container_of(dev, struct mtd_info, dev) : NULL; | 254 | return dev ? dev_get_drvdata(dev) : NULL; |
| 255 | } | 255 | } |
| 256 | 256 | ||
| 257 | static inline uint32_t mtd_div_by_eb(uint64_t sz, struct mtd_info *mtd) | 257 | static inline uint32_t mtd_div_by_eb(uint64_t sz, struct mtd_info *mtd) |
diff --git a/include/linux/mtd/partitions.h b/include/linux/mtd/partitions.h index af6dcb992bc3..b70313d33ff8 100644 --- a/include/linux/mtd/partitions.h +++ b/include/linux/mtd/partitions.h | |||
| @@ -47,6 +47,8 @@ struct mtd_partition { | |||
| 47 | #define MTDPART_SIZ_FULL (0) | 47 | #define MTDPART_SIZ_FULL (0) |
| 48 | 48 | ||
| 49 | 49 | ||
| 50 | struct mtd_info; | ||
| 51 | |||
| 50 | int add_mtd_partitions(struct mtd_info *, const struct mtd_partition *, int); | 52 | int add_mtd_partitions(struct mtd_info *, const struct mtd_partition *, int); |
| 51 | int del_mtd_partitions(struct mtd_info *); | 53 | int del_mtd_partitions(struct mtd_info *); |
| 52 | 54 | ||
diff --git a/include/linux/nfs_fs.h b/include/linux/nfs_fs.h index fdffb413b192..f6b90240dd41 100644 --- a/include/linux/nfs_fs.h +++ b/include/linux/nfs_fs.h | |||
| @@ -473,7 +473,6 @@ extern int nfs_writepages(struct address_space *, struct writeback_control *); | |||
| 473 | extern int nfs_flush_incompatible(struct file *file, struct page *page); | 473 | extern int nfs_flush_incompatible(struct file *file, struct page *page); |
| 474 | extern int nfs_updatepage(struct file *, struct page *, unsigned int, unsigned int); | 474 | extern int nfs_updatepage(struct file *, struct page *, unsigned int, unsigned int); |
| 475 | extern int nfs_writeback_done(struct rpc_task *, struct nfs_write_data *); | 475 | extern int nfs_writeback_done(struct rpc_task *, struct nfs_write_data *); |
| 476 | extern void nfs_writedata_release(void *); | ||
| 477 | 476 | ||
| 478 | /* | 477 | /* |
| 479 | * Try to write back everything synchronously (but check the | 478 | * Try to write back everything synchronously (but check the |
| @@ -488,7 +487,6 @@ extern int nfs_wb_page_cancel(struct inode *inode, struct page* page); | |||
| 488 | extern int nfs_commit_inode(struct inode *, int); | 487 | extern int nfs_commit_inode(struct inode *, int); |
| 489 | extern struct nfs_write_data *nfs_commitdata_alloc(void); | 488 | extern struct nfs_write_data *nfs_commitdata_alloc(void); |
| 490 | extern void nfs_commit_free(struct nfs_write_data *wdata); | 489 | extern void nfs_commit_free(struct nfs_write_data *wdata); |
| 491 | extern void nfs_commitdata_release(void *wdata); | ||
| 492 | #else | 490 | #else |
| 493 | static inline int | 491 | static inline int |
| 494 | nfs_commit_inode(struct inode *inode, int how) | 492 | nfs_commit_inode(struct inode *inode, int how) |
| @@ -507,6 +505,7 @@ nfs_have_writebacks(struct inode *inode) | |||
| 507 | * Allocate nfs_write_data structures | 505 | * Allocate nfs_write_data structures |
| 508 | */ | 506 | */ |
| 509 | extern struct nfs_write_data *nfs_writedata_alloc(unsigned int npages); | 507 | extern struct nfs_write_data *nfs_writedata_alloc(unsigned int npages); |
| 508 | extern void nfs_writedata_free(struct nfs_write_data *); | ||
| 510 | 509 | ||
| 511 | /* | 510 | /* |
| 512 | * linux/fs/nfs/read.c | 511 | * linux/fs/nfs/read.c |
| @@ -515,7 +514,6 @@ extern int nfs_readpage(struct file *, struct page *); | |||
| 515 | extern int nfs_readpages(struct file *, struct address_space *, | 514 | extern int nfs_readpages(struct file *, struct address_space *, |
| 516 | struct list_head *, unsigned); | 515 | struct list_head *, unsigned); |
| 517 | extern int nfs_readpage_result(struct rpc_task *, struct nfs_read_data *); | 516 | extern int nfs_readpage_result(struct rpc_task *, struct nfs_read_data *); |
| 518 | extern void nfs_readdata_release(void *data); | ||
| 519 | extern int nfs_readpage_async(struct nfs_open_context *, struct inode *, | 517 | extern int nfs_readpage_async(struct nfs_open_context *, struct inode *, |
| 520 | struct page *); | 518 | struct page *); |
| 521 | 519 | ||
| @@ -523,6 +521,7 @@ extern int nfs_readpage_async(struct nfs_open_context *, struct inode *, | |||
| 523 | * Allocate nfs_read_data structures | 521 | * Allocate nfs_read_data structures |
| 524 | */ | 522 | */ |
| 525 | extern struct nfs_read_data *nfs_readdata_alloc(unsigned int npages); | 523 | extern struct nfs_read_data *nfs_readdata_alloc(unsigned int npages); |
| 524 | extern void nfs_readdata_free(struct nfs_read_data *); | ||
| 526 | 525 | ||
| 527 | /* | 526 | /* |
| 528 | * linux/fs/nfs3proc.c | 527 | * linux/fs/nfs3proc.c |
diff --git a/include/linux/nodemask.h b/include/linux/nodemask.h index 829b94b156f2..b359c4a9ec9e 100644 --- a/include/linux/nodemask.h +++ b/include/linux/nodemask.h | |||
| @@ -82,6 +82,12 @@ | |||
| 82 | * to generate slightly worse code. So use a simple one-line #define | 82 | * to generate slightly worse code. So use a simple one-line #define |
| 83 | * for node_isset(), instead of wrapping an inline inside a macro, the | 83 | * for node_isset(), instead of wrapping an inline inside a macro, the |
| 84 | * way we do the other calls. | 84 | * way we do the other calls. |
| 85 | * | ||
| 86 | * NODEMASK_SCRATCH | ||
| 87 | * When doing above logical AND, OR, XOR, Remap operations the callers tend to | ||
| 88 | * need temporary nodemask_t's on the stack. But if NODES_SHIFT is large, | ||
| 89 | * nodemask_t's consume too much stack space. NODEMASK_SCRATCH is a helper | ||
| 90 | * for such situations. See below and CPUMASK_ALLOC also. | ||
| 85 | */ | 91 | */ |
| 86 | 92 | ||
| 87 | #include <linux/kernel.h> | 93 | #include <linux/kernel.h> |
| @@ -473,4 +479,26 @@ static inline int num_node_state(enum node_states state) | |||
| 473 | #define for_each_node(node) for_each_node_state(node, N_POSSIBLE) | 479 | #define for_each_node(node) for_each_node_state(node, N_POSSIBLE) |
| 474 | #define for_each_online_node(node) for_each_node_state(node, N_ONLINE) | 480 | #define for_each_online_node(node) for_each_node_state(node, N_ONLINE) |
| 475 | 481 | ||
| 482 | /* | ||
| 483 | * For nodemask scrach area.(See CPUMASK_ALLOC() in cpumask.h) | ||
| 484 | */ | ||
| 485 | |||
| 486 | #if NODES_SHIFT > 8 /* nodemask_t > 64 bytes */ | ||
| 487 | #define NODEMASK_ALLOC(x, m) struct x *m = kmalloc(sizeof(*m), GFP_KERNEL) | ||
| 488 | #define NODEMASK_FREE(m) kfree(m) | ||
| 489 | #else | ||
| 490 | #define NODEMASK_ALLOC(x, m) struct x _m, *m = &_m | ||
| 491 | #define NODEMASK_FREE(m) | ||
| 492 | #endif | ||
| 493 | |||
| 494 | /* A example struture for using NODEMASK_ALLOC, used in mempolicy. */ | ||
| 495 | struct nodemask_scratch { | ||
| 496 | nodemask_t mask1; | ||
| 497 | nodemask_t mask2; | ||
| 498 | }; | ||
| 499 | |||
| 500 | #define NODEMASK_SCRATCH(x) NODEMASK_ALLOC(nodemask_scratch, x) | ||
| 501 | #define NODEMASK_SCRATCH_FREE(x) NODEMASK_FREE(x) | ||
| 502 | |||
| 503 | |||
| 476 | #endif /* __LINUX_NODEMASK_H */ | 504 | #endif /* __LINUX_NODEMASK_H */ |
diff --git a/include/linux/of_mdio.h b/include/linux/of_mdio.h index c9663c690303..53b94e025c7c 100644 --- a/include/linux/of_mdio.h +++ b/include/linux/of_mdio.h | |||
| @@ -18,5 +18,8 @@ extern struct phy_device *of_phy_connect(struct net_device *dev, | |||
| 18 | struct device_node *phy_np, | 18 | struct device_node *phy_np, |
| 19 | void (*hndlr)(struct net_device *), | 19 | void (*hndlr)(struct net_device *), |
| 20 | u32 flags, phy_interface_t iface); | 20 | u32 flags, phy_interface_t iface); |
| 21 | extern struct phy_device *of_phy_connect_fixed_link(struct net_device *dev, | ||
| 22 | void (*hndlr)(struct net_device *), | ||
| 23 | phy_interface_t iface); | ||
| 21 | 24 | ||
| 22 | #endif /* __LINUX_OF_MDIO_H */ | 25 | #endif /* __LINUX_OF_MDIO_H */ |
diff --git a/include/linux/perf_counter.h b/include/linux/perf_counter.h index 5e970c7d3fd5..b53f7006cc4e 100644 --- a/include/linux/perf_counter.h +++ b/include/linux/perf_counter.h | |||
| @@ -115,26 +115,44 @@ enum perf_counter_sample_format { | |||
| 115 | PERF_SAMPLE_TID = 1U << 1, | 115 | PERF_SAMPLE_TID = 1U << 1, |
| 116 | PERF_SAMPLE_TIME = 1U << 2, | 116 | PERF_SAMPLE_TIME = 1U << 2, |
| 117 | PERF_SAMPLE_ADDR = 1U << 3, | 117 | PERF_SAMPLE_ADDR = 1U << 3, |
| 118 | PERF_SAMPLE_GROUP = 1U << 4, | 118 | PERF_SAMPLE_READ = 1U << 4, |
| 119 | PERF_SAMPLE_CALLCHAIN = 1U << 5, | 119 | PERF_SAMPLE_CALLCHAIN = 1U << 5, |
| 120 | PERF_SAMPLE_ID = 1U << 6, | 120 | PERF_SAMPLE_ID = 1U << 6, |
| 121 | PERF_SAMPLE_CPU = 1U << 7, | 121 | PERF_SAMPLE_CPU = 1U << 7, |
| 122 | PERF_SAMPLE_PERIOD = 1U << 8, | 122 | PERF_SAMPLE_PERIOD = 1U << 8, |
| 123 | PERF_SAMPLE_STREAM_ID = 1U << 9, | ||
| 124 | PERF_SAMPLE_RAW = 1U << 10, | ||
| 123 | 125 | ||
| 124 | PERF_SAMPLE_MAX = 1U << 9, /* non-ABI */ | 126 | PERF_SAMPLE_MAX = 1U << 11, /* non-ABI */ |
| 125 | }; | 127 | }; |
| 126 | 128 | ||
| 127 | /* | 129 | /* |
| 128 | * Bits that can be set in attr.read_format to request that | 130 | * The format of the data returned by read() on a perf counter fd, |
| 129 | * reads on the counter should return the indicated quantities, | 131 | * as specified by attr.read_format: |
| 130 | * in increasing order of bit value, after the counter value. | 132 | * |
| 133 | * struct read_format { | ||
| 134 | * { u64 value; | ||
| 135 | * { u64 time_enabled; } && PERF_FORMAT_ENABLED | ||
| 136 | * { u64 time_running; } && PERF_FORMAT_RUNNING | ||
| 137 | * { u64 id; } && PERF_FORMAT_ID | ||
| 138 | * } && !PERF_FORMAT_GROUP | ||
| 139 | * | ||
| 140 | * { u64 nr; | ||
| 141 | * { u64 time_enabled; } && PERF_FORMAT_ENABLED | ||
| 142 | * { u64 time_running; } && PERF_FORMAT_RUNNING | ||
| 143 | * { u64 value; | ||
| 144 | * { u64 id; } && PERF_FORMAT_ID | ||
| 145 | * } cntr[nr]; | ||
| 146 | * } && PERF_FORMAT_GROUP | ||
| 147 | * }; | ||
| 131 | */ | 148 | */ |
| 132 | enum perf_counter_read_format { | 149 | enum perf_counter_read_format { |
| 133 | PERF_FORMAT_TOTAL_TIME_ENABLED = 1U << 0, | 150 | PERF_FORMAT_TOTAL_TIME_ENABLED = 1U << 0, |
| 134 | PERF_FORMAT_TOTAL_TIME_RUNNING = 1U << 1, | 151 | PERF_FORMAT_TOTAL_TIME_RUNNING = 1U << 1, |
| 135 | PERF_FORMAT_ID = 1U << 2, | 152 | PERF_FORMAT_ID = 1U << 2, |
| 153 | PERF_FORMAT_GROUP = 1U << 3, | ||
| 136 | 154 | ||
| 137 | PERF_FORMAT_MAX = 1U << 3, /* non-ABI */ | 155 | PERF_FORMAT_MAX = 1U << 4, /* non-ABI */ |
| 138 | }; | 156 | }; |
| 139 | 157 | ||
| 140 | #define PERF_ATTR_SIZE_VER0 64 /* sizeof first published struct */ | 158 | #define PERF_ATTR_SIZE_VER0 64 /* sizeof first published struct */ |
| @@ -180,8 +198,9 @@ struct perf_counter_attr { | |||
| 180 | freq : 1, /* use freq, not period */ | 198 | freq : 1, /* use freq, not period */ |
| 181 | inherit_stat : 1, /* per task counts */ | 199 | inherit_stat : 1, /* per task counts */ |
| 182 | enable_on_exec : 1, /* next exec enables */ | 200 | enable_on_exec : 1, /* next exec enables */ |
| 201 | task : 1, /* trace fork/exit */ | ||
| 183 | 202 | ||
| 184 | __reserved_1 : 51; | 203 | __reserved_1 : 50; |
| 185 | 204 | ||
| 186 | __u32 wakeup_events; /* wakeup every n events */ | 205 | __u32 wakeup_events; /* wakeup every n events */ |
| 187 | __u32 __reserved_2; | 206 | __u32 __reserved_2; |
| @@ -310,18 +329,18 @@ enum perf_event_type { | |||
| 310 | /* | 329 | /* |
| 311 | * struct { | 330 | * struct { |
| 312 | * struct perf_event_header header; | 331 | * struct perf_event_header header; |
| 313 | * u64 time; | 332 | * u32 pid, ppid; |
| 314 | * u64 id; | 333 | * u32 tid, ptid; |
| 315 | * u64 sample_period; | ||
| 316 | * }; | 334 | * }; |
| 317 | */ | 335 | */ |
| 318 | PERF_EVENT_PERIOD = 4, | 336 | PERF_EVENT_EXIT = 4, |
| 319 | 337 | ||
| 320 | /* | 338 | /* |
| 321 | * struct { | 339 | * struct { |
| 322 | * struct perf_event_header header; | 340 | * struct perf_event_header header; |
| 323 | * u64 time; | 341 | * u64 time; |
| 324 | * u64 id; | 342 | * u64 id; |
| 343 | * u64 stream_id; | ||
| 325 | * }; | 344 | * }; |
| 326 | */ | 345 | */ |
| 327 | PERF_EVENT_THROTTLE = 5, | 346 | PERF_EVENT_THROTTLE = 5, |
| @@ -331,6 +350,7 @@ enum perf_event_type { | |||
| 331 | * struct { | 350 | * struct { |
| 332 | * struct perf_event_header header; | 351 | * struct perf_event_header header; |
| 333 | * u32 pid, ppid; | 352 | * u32 pid, ppid; |
| 353 | * u32 tid, ptid; | ||
| 334 | * }; | 354 | * }; |
| 335 | */ | 355 | */ |
| 336 | PERF_EVENT_FORK = 7, | 356 | PERF_EVENT_FORK = 7, |
| @@ -339,10 +359,8 @@ enum perf_event_type { | |||
| 339 | * struct { | 359 | * struct { |
| 340 | * struct perf_event_header header; | 360 | * struct perf_event_header header; |
| 341 | * u32 pid, tid; | 361 | * u32 pid, tid; |
| 342 | * u64 value; | 362 | * |
| 343 | * { u64 time_enabled; } && PERF_FORMAT_ENABLED | 363 | * struct read_format values; |
| 344 | * { u64 time_running; } && PERF_FORMAT_RUNNING | ||
| 345 | * { u64 parent_id; } && PERF_FORMAT_ID | ||
| 346 | * }; | 364 | * }; |
| 347 | */ | 365 | */ |
| 348 | PERF_EVENT_READ = 8, | 366 | PERF_EVENT_READ = 8, |
| @@ -356,14 +374,28 @@ enum perf_event_type { | |||
| 356 | * { u64 time; } && PERF_SAMPLE_TIME | 374 | * { u64 time; } && PERF_SAMPLE_TIME |
| 357 | * { u64 addr; } && PERF_SAMPLE_ADDR | 375 | * { u64 addr; } && PERF_SAMPLE_ADDR |
| 358 | * { u64 id; } && PERF_SAMPLE_ID | 376 | * { u64 id; } && PERF_SAMPLE_ID |
| 377 | * { u64 stream_id;} && PERF_SAMPLE_STREAM_ID | ||
| 359 | * { u32 cpu, res; } && PERF_SAMPLE_CPU | 378 | * { u32 cpu, res; } && PERF_SAMPLE_CPU |
| 360 | * { u64 period; } && PERF_SAMPLE_PERIOD | 379 | * { u64 period; } && PERF_SAMPLE_PERIOD |
| 361 | * | 380 | * |
| 362 | * { u64 nr; | 381 | * { struct read_format values; } && PERF_SAMPLE_READ |
| 363 | * { u64 id, val; } cnt[nr]; } && PERF_SAMPLE_GROUP | ||
| 364 | * | 382 | * |
| 365 | * { u64 nr, | 383 | * { u64 nr, |
| 366 | * u64 ips[nr]; } && PERF_SAMPLE_CALLCHAIN | 384 | * u64 ips[nr]; } && PERF_SAMPLE_CALLCHAIN |
| 385 | * | ||
| 386 | * # | ||
| 387 | * # The RAW record below is opaque data wrt the ABI | ||
| 388 | * # | ||
| 389 | * # That is, the ABI doesn't make any promises wrt to | ||
| 390 | * # the stability of its content, it may vary depending | ||
| 391 | * # on event, hardware, kernel version and phase of | ||
| 392 | * # the moon. | ||
| 393 | * # | ||
| 394 | * # In other words, PERF_SAMPLE_RAW contents are not an ABI. | ||
| 395 | * # | ||
| 396 | * | ||
| 397 | * { u32 size; | ||
| 398 | * char data[size];}&& PERF_SAMPLE_RAW | ||
| 367 | * }; | 399 | * }; |
| 368 | */ | 400 | */ |
| 369 | PERF_EVENT_SAMPLE = 9, | 401 | PERF_EVENT_SAMPLE = 9, |
| @@ -409,6 +441,11 @@ struct perf_callchain_entry { | |||
| 409 | __u64 ip[PERF_MAX_STACK_DEPTH]; | 441 | __u64 ip[PERF_MAX_STACK_DEPTH]; |
| 410 | }; | 442 | }; |
| 411 | 443 | ||
| 444 | struct perf_raw_record { | ||
| 445 | u32 size; | ||
| 446 | void *data; | ||
| 447 | }; | ||
| 448 | |||
| 412 | struct task_struct; | 449 | struct task_struct; |
| 413 | 450 | ||
| 414 | /** | 451 | /** |
| @@ -677,10 +714,13 @@ struct perf_sample_data { | |||
| 677 | struct pt_regs *regs; | 714 | struct pt_regs *regs; |
| 678 | u64 addr; | 715 | u64 addr; |
| 679 | u64 period; | 716 | u64 period; |
| 717 | struct perf_raw_record *raw; | ||
| 680 | }; | 718 | }; |
| 681 | 719 | ||
| 682 | extern int perf_counter_overflow(struct perf_counter *counter, int nmi, | 720 | extern int perf_counter_overflow(struct perf_counter *counter, int nmi, |
| 683 | struct perf_sample_data *data); | 721 | struct perf_sample_data *data); |
| 722 | extern void perf_counter_output(struct perf_counter *counter, int nmi, | ||
| 723 | struct perf_sample_data *data); | ||
| 684 | 724 | ||
| 685 | /* | 725 | /* |
| 686 | * Return 1 for a software counter, 0 for a hardware counter | 726 | * Return 1 for a software counter, 0 for a hardware counter |
diff --git a/include/linux/pps.h b/include/linux/pps.h index cfe5c7214ec6..0194ab06177b 100644 --- a/include/linux/pps.h +++ b/include/linux/pps.h | |||
| @@ -22,6 +22,8 @@ | |||
| 22 | #ifndef _PPS_H_ | 22 | #ifndef _PPS_H_ |
| 23 | #define _PPS_H_ | 23 | #define _PPS_H_ |
| 24 | 24 | ||
| 25 | #include <linux/types.h> | ||
| 26 | |||
| 25 | #define PPS_VERSION "5.3.6" | 27 | #define PPS_VERSION "5.3.6" |
| 26 | #define PPS_MAX_SOURCES 16 /* should be enough... */ | 28 | #define PPS_MAX_SOURCES 16 /* should be enough... */ |
| 27 | 29 | ||
diff --git a/include/linux/rfkill.h b/include/linux/rfkill.h index 2ce29831feb6..278777fa8a3a 100644 --- a/include/linux/rfkill.h +++ b/include/linux/rfkill.h | |||
| @@ -224,7 +224,7 @@ void rfkill_destroy(struct rfkill *rfkill); | |||
| 224 | * should be blocked) so that drivers need not keep track of the soft | 224 | * should be blocked) so that drivers need not keep track of the soft |
| 225 | * block state -- which they might not be able to. | 225 | * block state -- which they might not be able to. |
| 226 | */ | 226 | */ |
| 227 | bool __must_check rfkill_set_hw_state(struct rfkill *rfkill, bool blocked); | 227 | bool rfkill_set_hw_state(struct rfkill *rfkill, bool blocked); |
| 228 | 228 | ||
| 229 | /** | 229 | /** |
| 230 | * rfkill_set_sw_state - Set the internal rfkill software block state | 230 | * rfkill_set_sw_state - Set the internal rfkill software block state |
diff --git a/include/linux/scatterlist.h b/include/linux/scatterlist.h index e5996984ddd0..9aaf5bfdad1a 100644 --- a/include/linux/scatterlist.h +++ b/include/linux/scatterlist.h | |||
| @@ -242,6 +242,8 @@ size_t sg_copy_to_buffer(struct scatterlist *sgl, unsigned int nents, | |||
| 242 | */ | 242 | */ |
| 243 | 243 | ||
| 244 | #define SG_MITER_ATOMIC (1 << 0) /* use kmap_atomic */ | 244 | #define SG_MITER_ATOMIC (1 << 0) /* use kmap_atomic */ |
| 245 | #define SG_MITER_TO_SG (1 << 1) /* flush back to phys on unmap */ | ||
| 246 | #define SG_MITER_FROM_SG (1 << 2) /* nop */ | ||
| 245 | 247 | ||
| 246 | struct sg_mapping_iter { | 248 | struct sg_mapping_iter { |
| 247 | /* the following three fields can be accessed directly */ | 249 | /* the following three fields can be accessed directly */ |
diff --git a/include/linux/sched.h b/include/linux/sched.h index 16a982e389fb..0f1ea4a66957 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h | |||
| @@ -209,7 +209,7 @@ extern unsigned long long time_sync_thresh; | |||
| 209 | ((task->state & (__TASK_STOPPED | __TASK_TRACED)) != 0) | 209 | ((task->state & (__TASK_STOPPED | __TASK_TRACED)) != 0) |
| 210 | #define task_contributes_to_load(task) \ | 210 | #define task_contributes_to_load(task) \ |
| 211 | ((task->state & TASK_UNINTERRUPTIBLE) != 0 && \ | 211 | ((task->state & TASK_UNINTERRUPTIBLE) != 0 && \ |
| 212 | (task->flags & PF_FROZEN) == 0) | 212 | (task->flags & PF_FREEZING) == 0) |
| 213 | 213 | ||
| 214 | #define __set_task_state(tsk, state_value) \ | 214 | #define __set_task_state(tsk, state_value) \ |
| 215 | do { (tsk)->state = (state_value); } while (0) | 215 | do { (tsk)->state = (state_value); } while (0) |
| @@ -1198,6 +1198,7 @@ struct task_struct { | |||
| 1198 | * a short time | 1198 | * a short time |
| 1199 | */ | 1199 | */ |
| 1200 | unsigned char fpu_counter; | 1200 | unsigned char fpu_counter; |
| 1201 | s8 oomkilladj; /* OOM kill score adjustment (bit shift). */ | ||
| 1201 | #ifdef CONFIG_BLK_DEV_IO_TRACE | 1202 | #ifdef CONFIG_BLK_DEV_IO_TRACE |
| 1202 | unsigned int btrace_seq; | 1203 | unsigned int btrace_seq; |
| 1203 | #endif | 1204 | #endif |
| @@ -1680,6 +1681,7 @@ extern cputime_t task_gtime(struct task_struct *p); | |||
| 1680 | #define PF_MEMALLOC 0x00000800 /* Allocating memory */ | 1681 | #define PF_MEMALLOC 0x00000800 /* Allocating memory */ |
| 1681 | #define PF_FLUSHER 0x00001000 /* responsible for disk writeback */ | 1682 | #define PF_FLUSHER 0x00001000 /* responsible for disk writeback */ |
| 1682 | #define PF_USED_MATH 0x00002000 /* if unset the fpu must be initialized before use */ | 1683 | #define PF_USED_MATH 0x00002000 /* if unset the fpu must be initialized before use */ |
| 1684 | #define PF_FREEZING 0x00004000 /* freeze in progress. do not account to load */ | ||
| 1683 | #define PF_NOFREEZE 0x00008000 /* this thread should not be frozen */ | 1685 | #define PF_NOFREEZE 0x00008000 /* this thread should not be frozen */ |
| 1684 | #define PF_FROZEN 0x00010000 /* frozen for system suspend */ | 1686 | #define PF_FROZEN 0x00010000 /* frozen for system suspend */ |
| 1685 | #define PF_FSTRANS 0x00020000 /* inside a filesystem transaction */ | 1687 | #define PF_FSTRANS 0x00020000 /* inside a filesystem transaction */ |
diff --git a/include/linux/security.h b/include/linux/security.h index 5eff459b3833..1f16eea2017b 100644 --- a/include/linux/security.h +++ b/include/linux/security.h | |||
| @@ -28,6 +28,7 @@ | |||
| 28 | #include <linux/resource.h> | 28 | #include <linux/resource.h> |
| 29 | #include <linux/sem.h> | 29 | #include <linux/sem.h> |
| 30 | #include <linux/shm.h> | 30 | #include <linux/shm.h> |
| 31 | #include <linux/mm.h> /* PAGE_ALIGN */ | ||
| 31 | #include <linux/msg.h> | 32 | #include <linux/msg.h> |
| 32 | #include <linux/sched.h> | 33 | #include <linux/sched.h> |
| 33 | #include <linux/key.h> | 34 | #include <linux/key.h> |
| @@ -66,6 +67,9 @@ extern int cap_inode_setxattr(struct dentry *dentry, const char *name, | |||
| 66 | extern int cap_inode_removexattr(struct dentry *dentry, const char *name); | 67 | extern int cap_inode_removexattr(struct dentry *dentry, const char *name); |
| 67 | extern int cap_inode_need_killpriv(struct dentry *dentry); | 68 | extern int cap_inode_need_killpriv(struct dentry *dentry); |
| 68 | extern int cap_inode_killpriv(struct dentry *dentry); | 69 | extern int cap_inode_killpriv(struct dentry *dentry); |
| 70 | extern int cap_file_mmap(struct file *file, unsigned long reqprot, | ||
| 71 | unsigned long prot, unsigned long flags, | ||
| 72 | unsigned long addr, unsigned long addr_only); | ||
| 69 | extern int cap_task_fix_setuid(struct cred *new, const struct cred *old, int flags); | 73 | extern int cap_task_fix_setuid(struct cred *new, const struct cred *old, int flags); |
| 70 | extern int cap_task_prctl(int option, unsigned long arg2, unsigned long arg3, | 74 | extern int cap_task_prctl(int option, unsigned long arg2, unsigned long arg3, |
| 71 | unsigned long arg4, unsigned long arg5); | 75 | unsigned long arg4, unsigned long arg5); |
| @@ -92,6 +96,7 @@ extern int cap_netlink_send(struct sock *sk, struct sk_buff *skb); | |||
| 92 | extern int cap_netlink_recv(struct sk_buff *skb, int cap); | 96 | extern int cap_netlink_recv(struct sk_buff *skb, int cap); |
| 93 | 97 | ||
| 94 | extern unsigned long mmap_min_addr; | 98 | extern unsigned long mmap_min_addr; |
| 99 | extern unsigned long dac_mmap_min_addr; | ||
| 95 | /* | 100 | /* |
| 96 | * Values used in the task_security_ops calls | 101 | * Values used in the task_security_ops calls |
| 97 | */ | 102 | */ |
| @@ -116,6 +121,21 @@ struct request_sock; | |||
| 116 | #define LSM_UNSAFE_PTRACE 2 | 121 | #define LSM_UNSAFE_PTRACE 2 |
| 117 | #define LSM_UNSAFE_PTRACE_CAP 4 | 122 | #define LSM_UNSAFE_PTRACE_CAP 4 |
| 118 | 123 | ||
| 124 | /* | ||
| 125 | * If a hint addr is less than mmap_min_addr change hint to be as | ||
| 126 | * low as possible but still greater than mmap_min_addr | ||
| 127 | */ | ||
| 128 | static inline unsigned long round_hint_to_min(unsigned long hint) | ||
| 129 | { | ||
| 130 | hint &= PAGE_MASK; | ||
| 131 | if (((void *)hint != NULL) && | ||
| 132 | (hint < mmap_min_addr)) | ||
| 133 | return PAGE_ALIGN(mmap_min_addr); | ||
| 134 | return hint; | ||
| 135 | } | ||
| 136 | extern int mmap_min_addr_handler(struct ctl_table *table, int write, struct file *filp, | ||
| 137 | void __user *buffer, size_t *lenp, loff_t *ppos); | ||
| 138 | |||
| 119 | #ifdef CONFIG_SECURITY | 139 | #ifdef CONFIG_SECURITY |
| 120 | 140 | ||
| 121 | struct security_mnt_opts { | 141 | struct security_mnt_opts { |
| @@ -2197,9 +2217,7 @@ static inline int security_file_mmap(struct file *file, unsigned long reqprot, | |||
| 2197 | unsigned long addr, | 2217 | unsigned long addr, |
| 2198 | unsigned long addr_only) | 2218 | unsigned long addr_only) |
| 2199 | { | 2219 | { |
| 2200 | if ((addr < mmap_min_addr) && !capable(CAP_SYS_RAWIO)) | 2220 | return cap_file_mmap(file, reqprot, prot, flags, addr, addr_only); |
| 2201 | return -EACCES; | ||
| 2202 | return 0; | ||
| 2203 | } | 2221 | } |
| 2204 | 2222 | ||
| 2205 | static inline int security_file_mprotect(struct vm_area_struct *vma, | 2223 | static inline int security_file_mprotect(struct vm_area_struct *vma, |
diff --git a/include/linux/tty.h b/include/linux/tty.h index 1488d8c81aac..e8c6c9136c97 100644 --- a/include/linux/tty.h +++ b/include/linux/tty.h | |||
| @@ -394,6 +394,7 @@ extern void __do_SAK(struct tty_struct *tty); | |||
| 394 | extern void disassociate_ctty(int priv); | 394 | extern void disassociate_ctty(int priv); |
| 395 | extern void no_tty(void); | 395 | extern void no_tty(void); |
| 396 | extern void tty_flip_buffer_push(struct tty_struct *tty); | 396 | extern void tty_flip_buffer_push(struct tty_struct *tty); |
| 397 | extern void tty_flush_to_ldisc(struct tty_struct *tty); | ||
| 397 | extern void tty_buffer_free_all(struct tty_struct *tty); | 398 | extern void tty_buffer_free_all(struct tty_struct *tty); |
| 398 | extern void tty_buffer_flush(struct tty_struct *tty); | 399 | extern void tty_buffer_flush(struct tty_struct *tty); |
| 399 | extern void tty_buffer_init(struct tty_struct *tty); | 400 | extern void tty_buffer_init(struct tty_struct *tty); |
diff --git a/include/linux/tty_ldisc.h b/include/linux/tty_ldisc.h index 40f38d896777..0c4ee9b88f85 100644 --- a/include/linux/tty_ldisc.h +++ b/include/linux/tty_ldisc.h | |||
| @@ -144,7 +144,7 @@ struct tty_ldisc_ops { | |||
| 144 | 144 | ||
| 145 | struct tty_ldisc { | 145 | struct tty_ldisc { |
| 146 | struct tty_ldisc_ops *ops; | 146 | struct tty_ldisc_ops *ops; |
| 147 | int refcount; | 147 | atomic_t users; |
| 148 | }; | 148 | }; |
| 149 | 149 | ||
| 150 | #define TTY_LDISC_MAGIC 0x5403 | 150 | #define TTY_LDISC_MAGIC 0x5403 |
diff --git a/include/linux/ucb1400.h b/include/linux/ucb1400.h index ed889f4168f3..ae779bb8cc0f 100644 --- a/include/linux/ucb1400.h +++ b/include/linux/ucb1400.h | |||
| @@ -73,6 +73,10 @@ | |||
| 73 | 73 | ||
| 74 | #define UCB_ADC_DATA 0x68 | 74 | #define UCB_ADC_DATA 0x68 |
| 75 | #define UCB_ADC_DAT_VALID (1 << 15) | 75 | #define UCB_ADC_DAT_VALID (1 << 15) |
| 76 | |||
| 77 | #define UCB_FCSR 0x6c | ||
| 78 | #define UCB_FCSR_AVE (1 << 12) | ||
| 79 | |||
| 76 | #define UCB_ADC_DAT_MASK 0x3ff | 80 | #define UCB_ADC_DAT_MASK 0x3ff |
| 77 | 81 | ||
| 78 | #define UCB_ID 0x7e | 82 | #define UCB_ID 0x7e |
diff --git a/include/linux/uio.h b/include/linux/uio.h index b7fe13883bdb..98c114323a8b 100644 --- a/include/linux/uio.h +++ b/include/linux/uio.h | |||
| @@ -19,15 +19,6 @@ struct iovec | |||
| 19 | __kernel_size_t iov_len; /* Must be size_t (1003.1g) */ | 19 | __kernel_size_t iov_len; /* Must be size_t (1003.1g) */ |
| 20 | }; | 20 | }; |
| 21 | 21 | ||
| 22 | #ifdef __KERNEL__ | ||
| 23 | |||
| 24 | struct kvec { | ||
| 25 | void *iov_base; /* and that should *never* hold a userland pointer */ | ||
| 26 | size_t iov_len; | ||
| 27 | }; | ||
| 28 | |||
| 29 | #endif | ||
| 30 | |||
| 31 | /* | 22 | /* |
| 32 | * UIO_MAXIOV shall be at least 16 1003.1g (5.4.1.1) | 23 | * UIO_MAXIOV shall be at least 16 1003.1g (5.4.1.1) |
| 33 | */ | 24 | */ |
| @@ -35,6 +26,13 @@ struct kvec { | |||
| 35 | #define UIO_FASTIOV 8 | 26 | #define UIO_FASTIOV 8 |
| 36 | #define UIO_MAXIOV 1024 | 27 | #define UIO_MAXIOV 1024 |
| 37 | 28 | ||
| 29 | #ifdef __KERNEL__ | ||
| 30 | |||
| 31 | struct kvec { | ||
| 32 | void *iov_base; /* and that should *never* hold a userland pointer */ | ||
| 33 | size_t iov_len; | ||
| 34 | }; | ||
| 35 | |||
| 38 | /* | 36 | /* |
| 39 | * Total number of bytes covered by an iovec. | 37 | * Total number of bytes covered by an iovec. |
| 40 | * | 38 | * |
| @@ -53,5 +51,6 @@ static inline size_t iov_length(const struct iovec *iov, unsigned long nr_segs) | |||
| 53 | } | 51 | } |
| 54 | 52 | ||
| 55 | unsigned long iov_shorten(struct iovec *iov, unsigned long nr_segs, size_t to); | 53 | unsigned long iov_shorten(struct iovec *iov, unsigned long nr_segs, size_t to); |
| 54 | #endif | ||
| 56 | 55 | ||
| 57 | #endif | 56 | #endif |
diff --git a/include/linux/videodev2.h b/include/linux/videodev2.h index 95846d988011..74f16876f38d 100644 --- a/include/linux/videodev2.h +++ b/include/linux/videodev2.h | |||
| @@ -338,6 +338,7 @@ struct v4l2_pix_format { | |||
| 338 | /* Vendor-specific formats */ | 338 | /* Vendor-specific formats */ |
| 339 | #define V4L2_PIX_FMT_WNVA v4l2_fourcc('W', 'N', 'V', 'A') /* Winnov hw compress */ | 339 | #define V4L2_PIX_FMT_WNVA v4l2_fourcc('W', 'N', 'V', 'A') /* Winnov hw compress */ |
| 340 | #define V4L2_PIX_FMT_SN9C10X v4l2_fourcc('S', '9', '1', '0') /* SN9C10x compression */ | 340 | #define V4L2_PIX_FMT_SN9C10X v4l2_fourcc('S', '9', '1', '0') /* SN9C10x compression */ |
| 341 | #define V4L2_PIX_FMT_SN9C20X_I420 v4l2_fourcc('S', '9', '2', '0') /* SN9C20x YUV 4:2:0 */ | ||
| 341 | #define V4L2_PIX_FMT_PWC1 v4l2_fourcc('P', 'W', 'C', '1') /* pwc older webcam */ | 342 | #define V4L2_PIX_FMT_PWC1 v4l2_fourcc('P', 'W', 'C', '1') /* pwc older webcam */ |
| 342 | #define V4L2_PIX_FMT_PWC2 v4l2_fourcc('P', 'W', 'C', '2') /* pwc newer webcam */ | 343 | #define V4L2_PIX_FMT_PWC2 v4l2_fourcc('P', 'W', 'C', '2') /* pwc newer webcam */ |
| 343 | #define V4L2_PIX_FMT_ET61X251 v4l2_fourcc('E', '6', '2', '5') /* ET61X251 compression */ | 344 | #define V4L2_PIX_FMT_ET61X251 v4l2_fourcc('E', '6', '2', '5') /* ET61X251 compression */ |
diff --git a/include/linux/virtio_blk.h b/include/linux/virtio_blk.h index be7d255fc7cf..8dab9f2b8832 100644 --- a/include/linux/virtio_blk.h +++ b/include/linux/virtio_blk.h | |||
| @@ -20,8 +20,7 @@ | |||
| 20 | 20 | ||
| 21 | #define VIRTIO_BLK_ID_BYTES (sizeof(__u16[256])) /* IDENTIFY DATA */ | 21 | #define VIRTIO_BLK_ID_BYTES (sizeof(__u16[256])) /* IDENTIFY DATA */ |
| 22 | 22 | ||
| 23 | struct virtio_blk_config | 23 | struct virtio_blk_config { |
| 24 | { | ||
| 25 | /* The capacity (in 512-byte sectors). */ | 24 | /* The capacity (in 512-byte sectors). */ |
| 26 | __u64 capacity; | 25 | __u64 capacity; |
| 27 | /* The maximum segment size (if VIRTIO_BLK_F_SIZE_MAX) */ | 26 | /* The maximum segment size (if VIRTIO_BLK_F_SIZE_MAX) */ |
| @@ -50,8 +49,7 @@ struct virtio_blk_config | |||
| 50 | #define VIRTIO_BLK_T_BARRIER 0x80000000 | 49 | #define VIRTIO_BLK_T_BARRIER 0x80000000 |
| 51 | 50 | ||
| 52 | /* This is the first element of the read scatter-gather list. */ | 51 | /* This is the first element of the read scatter-gather list. */ |
| 53 | struct virtio_blk_outhdr | 52 | struct virtio_blk_outhdr { |
| 54 | { | ||
| 55 | /* VIRTIO_BLK_T* */ | 53 | /* VIRTIO_BLK_T* */ |
| 56 | __u32 type; | 54 | __u32 type; |
| 57 | /* io priority. */ | 55 | /* io priority. */ |
diff --git a/include/linux/virtio_config.h b/include/linux/virtio_config.h index 99f514575f6a..e547e3c8ee9a 100644 --- a/include/linux/virtio_config.h +++ b/include/linux/virtio_config.h | |||
| @@ -79,8 +79,7 @@ | |||
| 79 | * the dev->feature bits if it wants. | 79 | * the dev->feature bits if it wants. |
| 80 | */ | 80 | */ |
| 81 | typedef void vq_callback_t(struct virtqueue *); | 81 | typedef void vq_callback_t(struct virtqueue *); |
| 82 | struct virtio_config_ops | 82 | struct virtio_config_ops { |
| 83 | { | ||
| 84 | void (*get)(struct virtio_device *vdev, unsigned offset, | 83 | void (*get)(struct virtio_device *vdev, unsigned offset, |
| 85 | void *buf, unsigned len); | 84 | void *buf, unsigned len); |
| 86 | void (*set)(struct virtio_device *vdev, unsigned offset, | 85 | void (*set)(struct virtio_device *vdev, unsigned offset, |
diff --git a/include/linux/virtio_net.h b/include/linux/virtio_net.h index 9c543d6ac535..d8dd539c9f48 100644 --- a/include/linux/virtio_net.h +++ b/include/linux/virtio_net.h | |||
| @@ -31,8 +31,7 @@ | |||
| 31 | 31 | ||
| 32 | #define VIRTIO_NET_S_LINK_UP 1 /* Link is up */ | 32 | #define VIRTIO_NET_S_LINK_UP 1 /* Link is up */ |
| 33 | 33 | ||
| 34 | struct virtio_net_config | 34 | struct virtio_net_config { |
| 35 | { | ||
| 36 | /* The config defining mac address (if VIRTIO_NET_F_MAC) */ | 35 | /* The config defining mac address (if VIRTIO_NET_F_MAC) */ |
| 37 | __u8 mac[6]; | 36 | __u8 mac[6]; |
| 38 | /* See VIRTIO_NET_F_STATUS and VIRTIO_NET_S_* above */ | 37 | /* See VIRTIO_NET_F_STATUS and VIRTIO_NET_S_* above */ |
| @@ -41,8 +40,7 @@ struct virtio_net_config | |||
| 41 | 40 | ||
| 42 | /* This is the first element of the scatter-gather list. If you don't | 41 | /* This is the first element of the scatter-gather list. If you don't |
| 43 | * specify GSO or CSUM features, you can simply ignore the header. */ | 42 | * specify GSO or CSUM features, you can simply ignore the header. */ |
| 44 | struct virtio_net_hdr | 43 | struct virtio_net_hdr { |
| 45 | { | ||
| 46 | #define VIRTIO_NET_HDR_F_NEEDS_CSUM 1 // Use csum_start, csum_offset | 44 | #define VIRTIO_NET_HDR_F_NEEDS_CSUM 1 // Use csum_start, csum_offset |
| 47 | __u8 flags; | 45 | __u8 flags; |
| 48 | #define VIRTIO_NET_HDR_GSO_NONE 0 // Not a GSO frame | 46 | #define VIRTIO_NET_HDR_GSO_NONE 0 // Not a GSO frame |
diff --git a/include/linux/virtio_ring.h b/include/linux/virtio_ring.h index 693e0ec5afa6..e4d144b132b5 100644 --- a/include/linux/virtio_ring.h +++ b/include/linux/virtio_ring.h | |||
| @@ -30,8 +30,7 @@ | |||
| 30 | #define VIRTIO_RING_F_INDIRECT_DESC 28 | 30 | #define VIRTIO_RING_F_INDIRECT_DESC 28 |
| 31 | 31 | ||
| 32 | /* Virtio ring descriptors: 16 bytes. These can chain together via "next". */ | 32 | /* Virtio ring descriptors: 16 bytes. These can chain together via "next". */ |
| 33 | struct vring_desc | 33 | struct vring_desc { |
| 34 | { | ||
| 35 | /* Address (guest-physical). */ | 34 | /* Address (guest-physical). */ |
| 36 | __u64 addr; | 35 | __u64 addr; |
| 37 | /* Length. */ | 36 | /* Length. */ |
| @@ -42,24 +41,21 @@ struct vring_desc | |||
| 42 | __u16 next; | 41 | __u16 next; |
| 43 | }; | 42 | }; |
| 44 | 43 | ||
| 45 | struct vring_avail | 44 | struct vring_avail { |
| 46 | { | ||
| 47 | __u16 flags; | 45 | __u16 flags; |
| 48 | __u16 idx; | 46 | __u16 idx; |
| 49 | __u16 ring[]; | 47 | __u16 ring[]; |
| 50 | }; | 48 | }; |
| 51 | 49 | ||
| 52 | /* u32 is used here for ids for padding reasons. */ | 50 | /* u32 is used here for ids for padding reasons. */ |
| 53 | struct vring_used_elem | 51 | struct vring_used_elem { |
| 54 | { | ||
| 55 | /* Index of start of used descriptor chain. */ | 52 | /* Index of start of used descriptor chain. */ |
| 56 | __u32 id; | 53 | __u32 id; |
| 57 | /* Total length of the descriptor chain which was used (written to) */ | 54 | /* Total length of the descriptor chain which was used (written to) */ |
| 58 | __u32 len; | 55 | __u32 len; |
| 59 | }; | 56 | }; |
| 60 | 57 | ||
| 61 | struct vring_used | 58 | struct vring_used { |
| 62 | { | ||
| 63 | __u16 flags; | 59 | __u16 flags; |
| 64 | __u16 idx; | 60 | __u16 idx; |
| 65 | struct vring_used_elem ring[]; | 61 | struct vring_used_elem ring[]; |
diff --git a/include/linux/wait.h b/include/linux/wait.h index 6788e1a4d4ca..cf3c2f5dba51 100644 --- a/include/linux/wait.h +++ b/include/linux/wait.h | |||
| @@ -77,7 +77,14 @@ struct task_struct; | |||
| 77 | #define __WAIT_BIT_KEY_INITIALIZER(word, bit) \ | 77 | #define __WAIT_BIT_KEY_INITIALIZER(word, bit) \ |
| 78 | { .flags = word, .bit_nr = bit, } | 78 | { .flags = word, .bit_nr = bit, } |
| 79 | 79 | ||
| 80 | extern void init_waitqueue_head(wait_queue_head_t *q); | 80 | extern void __init_waitqueue_head(wait_queue_head_t *q, struct lock_class_key *); |
| 81 | |||
| 82 | #define init_waitqueue_head(q) \ | ||
| 83 | do { \ | ||
| 84 | static struct lock_class_key __key; \ | ||
| 85 | \ | ||
| 86 | __init_waitqueue_head((q), &__key); \ | ||
| 87 | } while (0) | ||
| 81 | 88 | ||
| 82 | #ifdef CONFIG_LOCKDEP | 89 | #ifdef CONFIG_LOCKDEP |
| 83 | # define __WAIT_QUEUE_HEAD_INIT_ONSTACK(name) \ | 90 | # define __WAIT_QUEUE_HEAD_INIT_ONSTACK(name) \ |
diff --git a/include/media/v4l2-chip-ident.h b/include/media/v4l2-chip-ident.h index 11a4a2d3e364..94e908c0d7a0 100644 --- a/include/media/v4l2-chip-ident.h +++ b/include/media/v4l2-chip-ident.h | |||
| @@ -60,6 +60,10 @@ enum { | |||
| 60 | V4L2_IDENT_OV7670 = 250, | 60 | V4L2_IDENT_OV7670 = 250, |
| 61 | V4L2_IDENT_OV7720 = 251, | 61 | V4L2_IDENT_OV7720 = 251, |
| 62 | V4L2_IDENT_OV7725 = 252, | 62 | V4L2_IDENT_OV7725 = 252, |
| 63 | V4L2_IDENT_OV7660 = 253, | ||
| 64 | V4L2_IDENT_OV9650 = 254, | ||
| 65 | V4L2_IDENT_OV9655 = 255, | ||
| 66 | V4L2_IDENT_SOI968 = 256, | ||
| 63 | 67 | ||
| 64 | /* module saa7146: reserved range 300-309 */ | 68 | /* module saa7146: reserved range 300-309 */ |
| 65 | V4L2_IDENT_SAA7146 = 300, | 69 | V4L2_IDENT_SAA7146 = 300, |
| @@ -161,6 +165,9 @@ enum { | |||
| 161 | /* module tw9910: just ident 9910 */ | 165 | /* module tw9910: just ident 9910 */ |
| 162 | V4L2_IDENT_TW9910 = 9910, | 166 | V4L2_IDENT_TW9910 = 9910, |
| 163 | 167 | ||
| 168 | /* module sn9c20x: just ident 10000 */ | ||
| 169 | V4L2_IDENT_SN9C20X = 10000, | ||
| 170 | |||
| 164 | /* module msp3400: reserved range 34000-34999 and 44000-44999 */ | 171 | /* module msp3400: reserved range 34000-34999 and 44000-44999 */ |
| 165 | V4L2_IDENT_MSPX4XX = 34000, /* generic MSPX4XX identifier, only | 172 | V4L2_IDENT_MSPX4XX = 34000, /* generic MSPX4XX identifier, only |
| 166 | use internally (tveeprom.c). */ | 173 | use internally (tveeprom.c). */ |
| @@ -237,6 +244,11 @@ enum { | |||
| 237 | V4L2_IDENT_MT9V022IX7ATC = 45010, /* No way to detect "normal" I77ATx */ | 244 | V4L2_IDENT_MT9V022IX7ATC = 45010, /* No way to detect "normal" I77ATx */ |
| 238 | V4L2_IDENT_MT9V022IX7ATM = 45015, /* and "lead free" IA7ATx chips */ | 245 | V4L2_IDENT_MT9V022IX7ATM = 45015, /* and "lead free" IA7ATx chips */ |
| 239 | V4L2_IDENT_MT9T031 = 45020, | 246 | V4L2_IDENT_MT9T031 = 45020, |
| 247 | V4L2_IDENT_MT9V111 = 45031, | ||
| 248 | V4L2_IDENT_MT9V112 = 45032, | ||
| 249 | |||
| 250 | /* HV7131R CMOS sensor: just ident 46000 */ | ||
| 251 | V4L2_IDENT_HV7131R = 46000, | ||
| 240 | 252 | ||
| 241 | /* module cs53132a: just ident 53132 */ | 253 | /* module cs53132a: just ident 53132 */ |
| 242 | V4L2_IDENT_CS53l32A = 53132, | 254 | V4L2_IDENT_CS53l32A = 53132, |
diff --git a/include/net/act_api.h b/include/net/act_api.h index 565eed8fe496..c05fd717c588 100644 --- a/include/net/act_api.h +++ b/include/net/act_api.h | |||
| @@ -16,7 +16,7 @@ struct tcf_common { | |||
| 16 | u32 tcfc_capab; | 16 | u32 tcfc_capab; |
| 17 | int tcfc_action; | 17 | int tcfc_action; |
| 18 | struct tcf_t tcfc_tm; | 18 | struct tcf_t tcfc_tm; |
| 19 | struct gnet_stats_basic tcfc_bstats; | 19 | struct gnet_stats_basic_packed tcfc_bstats; |
| 20 | struct gnet_stats_queue tcfc_qstats; | 20 | struct gnet_stats_queue tcfc_qstats; |
| 21 | struct gnet_stats_rate_est tcfc_rate_est; | 21 | struct gnet_stats_rate_est tcfc_rate_est; |
| 22 | spinlock_t tcfc_lock; | 22 | spinlock_t tcfc_lock; |
diff --git a/include/net/bluetooth/rfcomm.h b/include/net/bluetooth/rfcomm.h index 80072611d26a..c274993234e3 100644 --- a/include/net/bluetooth/rfcomm.h +++ b/include/net/bluetooth/rfcomm.h | |||
| @@ -355,7 +355,17 @@ struct rfcomm_dev_list_req { | |||
| 355 | }; | 355 | }; |
| 356 | 356 | ||
| 357 | int rfcomm_dev_ioctl(struct sock *sk, unsigned int cmd, void __user *arg); | 357 | int rfcomm_dev_ioctl(struct sock *sk, unsigned int cmd, void __user *arg); |
| 358 | |||
| 359 | #ifdef CONFIG_BT_RFCOMM_TTY | ||
| 358 | int rfcomm_init_ttys(void); | 360 | int rfcomm_init_ttys(void); |
| 359 | void rfcomm_cleanup_ttys(void); | 361 | void rfcomm_cleanup_ttys(void); |
| 360 | 362 | #else | |
| 363 | static inline int rfcomm_init_ttys(void) | ||
| 364 | { | ||
| 365 | return 0; | ||
| 366 | } | ||
| 367 | static inline void rfcomm_cleanup_ttys(void) | ||
| 368 | { | ||
| 369 | } | ||
| 370 | #endif | ||
| 361 | #endif /* __RFCOMM_H */ | 371 | #endif /* __RFCOMM_H */ |
diff --git a/include/net/cfg80211.h b/include/net/cfg80211.h index 1a21895b732b..d1892d66701a 100644 --- a/include/net/cfg80211.h +++ b/include/net/cfg80211.h | |||
| @@ -979,6 +979,10 @@ struct cfg80211_ops { | |||
| 979 | * channels at a later time. This can be used for devices which do not | 979 | * channels at a later time. This can be used for devices which do not |
| 980 | * have calibration information gauranteed for frequencies or settings | 980 | * have calibration information gauranteed for frequencies or settings |
| 981 | * outside of its regulatory domain. | 981 | * outside of its regulatory domain. |
| 982 | * @disable_beacon_hints: enable this if your driver needs to ensure that | ||
| 983 | * passive scan flags and beaconing flags may not be lifted by cfg80211 | ||
| 984 | * due to regulatory beacon hints. For more information on beacon | ||
| 985 | * hints read the documenation for regulatory_hint_found_beacon() | ||
| 982 | * @reg_notifier: the driver's regulatory notification callback | 986 | * @reg_notifier: the driver's regulatory notification callback |
| 983 | * @regd: the driver's regulatory domain, if one was requested via | 987 | * @regd: the driver's regulatory domain, if one was requested via |
| 984 | * the regulatory_hint() API. This can be used by the driver | 988 | * the regulatory_hint() API. This can be used by the driver |
| @@ -1004,6 +1008,7 @@ struct wiphy { | |||
| 1004 | 1008 | ||
| 1005 | bool custom_regulatory; | 1009 | bool custom_regulatory; |
| 1006 | bool strict_regulatory; | 1010 | bool strict_regulatory; |
| 1011 | bool disable_beacon_hints; | ||
| 1007 | 1012 | ||
| 1008 | enum cfg80211_signal_type signal_type; | 1013 | enum cfg80211_signal_type signal_type; |
| 1009 | 1014 | ||
diff --git a/include/net/gen_stats.h b/include/net/gen_stats.h index d136b5240ef2..c1488553e349 100644 --- a/include/net/gen_stats.h +++ b/include/net/gen_stats.h | |||
| @@ -28,7 +28,7 @@ extern int gnet_stats_start_copy_compat(struct sk_buff *skb, int type, | |||
| 28 | spinlock_t *lock, struct gnet_dump *d); | 28 | spinlock_t *lock, struct gnet_dump *d); |
| 29 | 29 | ||
| 30 | extern int gnet_stats_copy_basic(struct gnet_dump *d, | 30 | extern int gnet_stats_copy_basic(struct gnet_dump *d, |
| 31 | struct gnet_stats_basic *b); | 31 | struct gnet_stats_basic_packed *b); |
| 32 | extern int gnet_stats_copy_rate_est(struct gnet_dump *d, | 32 | extern int gnet_stats_copy_rate_est(struct gnet_dump *d, |
| 33 | struct gnet_stats_rate_est *r); | 33 | struct gnet_stats_rate_est *r); |
| 34 | extern int gnet_stats_copy_queue(struct gnet_dump *d, | 34 | extern int gnet_stats_copy_queue(struct gnet_dump *d, |
| @@ -37,14 +37,14 @@ extern int gnet_stats_copy_app(struct gnet_dump *d, void *st, int len); | |||
| 37 | 37 | ||
| 38 | extern int gnet_stats_finish_copy(struct gnet_dump *d); | 38 | extern int gnet_stats_finish_copy(struct gnet_dump *d); |
| 39 | 39 | ||
| 40 | extern int gen_new_estimator(struct gnet_stats_basic *bstats, | 40 | extern int gen_new_estimator(struct gnet_stats_basic_packed *bstats, |
| 41 | struct gnet_stats_rate_est *rate_est, | 41 | struct gnet_stats_rate_est *rate_est, |
| 42 | spinlock_t *stats_lock, struct nlattr *opt); | 42 | spinlock_t *stats_lock, struct nlattr *opt); |
| 43 | extern void gen_kill_estimator(struct gnet_stats_basic *bstats, | 43 | extern void gen_kill_estimator(struct gnet_stats_basic_packed *bstats, |
| 44 | struct gnet_stats_rate_est *rate_est); | 44 | struct gnet_stats_rate_est *rate_est); |
| 45 | extern int gen_replace_estimator(struct gnet_stats_basic *bstats, | 45 | extern int gen_replace_estimator(struct gnet_stats_basic_packed *bstats, |
| 46 | struct gnet_stats_rate_est *rate_est, | 46 | struct gnet_stats_rate_est *rate_est, |
| 47 | spinlock_t *stats_lock, struct nlattr *opt); | 47 | spinlock_t *stats_lock, struct nlattr *opt); |
| 48 | extern bool gen_estimator_active(const struct gnet_stats_basic *bstats, | 48 | extern bool gen_estimator_active(const struct gnet_stats_basic_packed *bstats, |
| 49 | const struct gnet_stats_rate_est *rate_est); | 49 | const struct gnet_stats_rate_est *rate_est); |
| 50 | #endif | 50 | #endif |
diff --git a/include/net/netfilter/xt_rateest.h b/include/net/netfilter/xt_rateest.h index 65d594dffbff..ddbf37e19616 100644 --- a/include/net/netfilter/xt_rateest.h +++ b/include/net/netfilter/xt_rateest.h | |||
| @@ -8,7 +8,7 @@ struct xt_rateest { | |||
| 8 | spinlock_t lock; | 8 | spinlock_t lock; |
| 9 | struct gnet_estimator params; | 9 | struct gnet_estimator params; |
| 10 | struct gnet_stats_rate_est rstats; | 10 | struct gnet_stats_rate_est rstats; |
| 11 | struct gnet_stats_basic bstats; | 11 | struct gnet_stats_basic_packed bstats; |
| 12 | }; | 12 | }; |
| 13 | 13 | ||
| 14 | extern struct xt_rateest *xt_rateest_lookup(const char *name); | 14 | extern struct xt_rateest *xt_rateest_lookup(const char *name); |
diff --git a/include/net/pkt_sched.h b/include/net/pkt_sched.h index 82a3191375f5..7eafb8d54470 100644 --- a/include/net/pkt_sched.h +++ b/include/net/pkt_sched.h | |||
| @@ -61,8 +61,8 @@ psched_tdiff_bounded(psched_time_t tv1, psched_time_t tv2, psched_time_t bound) | |||
| 61 | } | 61 | } |
| 62 | 62 | ||
| 63 | struct qdisc_watchdog { | 63 | struct qdisc_watchdog { |
| 64 | struct hrtimer timer; | 64 | struct tasklet_hrtimer timer; |
| 65 | struct Qdisc *qdisc; | 65 | struct Qdisc *qdisc; |
| 66 | }; | 66 | }; |
| 67 | 67 | ||
| 68 | extern void qdisc_watchdog_init(struct qdisc_watchdog *wd, struct Qdisc *qdisc); | 68 | extern void qdisc_watchdog_init(struct qdisc_watchdog *wd, struct Qdisc *qdisc); |
diff --git a/include/net/rose.h b/include/net/rose.h index cbd5364b2c8a..5ba9f02731eb 100644 --- a/include/net/rose.h +++ b/include/net/rose.h | |||
| @@ -156,7 +156,7 @@ extern int sysctl_rose_maximum_vcs; | |||
| 156 | extern int sysctl_rose_window_size; | 156 | extern int sysctl_rose_window_size; |
| 157 | extern int rosecmp(rose_address *, rose_address *); | 157 | extern int rosecmp(rose_address *, rose_address *); |
| 158 | extern int rosecmpm(rose_address *, rose_address *, unsigned short); | 158 | extern int rosecmpm(rose_address *, rose_address *, unsigned short); |
| 159 | extern const char *rose2asc(const rose_address *); | 159 | extern char *rose2asc(char *buf, const rose_address *); |
| 160 | extern struct sock *rose_find_socket(unsigned int, struct rose_neigh *); | 160 | extern struct sock *rose_find_socket(unsigned int, struct rose_neigh *); |
| 161 | extern void rose_kill_by_neigh(struct rose_neigh *); | 161 | extern void rose_kill_by_neigh(struct rose_neigh *); |
| 162 | extern unsigned int rose_new_lci(struct rose_neigh *); | 162 | extern unsigned int rose_new_lci(struct rose_neigh *); |
diff --git a/include/net/sch_generic.h b/include/net/sch_generic.h index 964ffa0d8815..5482e9582f55 100644 --- a/include/net/sch_generic.h +++ b/include/net/sch_generic.h | |||
| @@ -72,7 +72,7 @@ struct Qdisc | |||
| 72 | */ | 72 | */ |
| 73 | unsigned long state; | 73 | unsigned long state; |
| 74 | struct sk_buff_head q; | 74 | struct sk_buff_head q; |
| 75 | struct gnet_stats_basic bstats; | 75 | struct gnet_stats_basic_packed bstats; |
| 76 | struct gnet_stats_queue qstats; | 76 | struct gnet_stats_queue qstats; |
| 77 | }; | 77 | }; |
| 78 | 78 | ||
diff --git a/include/net/sock.h b/include/net/sock.h index 2c0da9239b95..950409dcec3d 100644 --- a/include/net/sock.h +++ b/include/net/sock.h | |||
| @@ -104,15 +104,15 @@ struct net; | |||
| 104 | 104 | ||
| 105 | /** | 105 | /** |
| 106 | * struct sock_common - minimal network layer representation of sockets | 106 | * struct sock_common - minimal network layer representation of sockets |
| 107 | * @skc_node: main hash linkage for various protocol lookup tables | ||
| 108 | * @skc_nulls_node: main hash linkage for UDP/UDP-Lite protocol | ||
| 109 | * @skc_refcnt: reference count | ||
| 110 | * @skc_hash: hash value used with various protocol lookup tables | ||
| 107 | * @skc_family: network address family | 111 | * @skc_family: network address family |
| 108 | * @skc_state: Connection state | 112 | * @skc_state: Connection state |
| 109 | * @skc_reuse: %SO_REUSEADDR setting | 113 | * @skc_reuse: %SO_REUSEADDR setting |
| 110 | * @skc_bound_dev_if: bound device index if != 0 | 114 | * @skc_bound_dev_if: bound device index if != 0 |
| 111 | * @skc_node: main hash linkage for various protocol lookup tables | ||
| 112 | * @skc_nulls_node: main hash linkage for UDP/UDP-Lite protocol | ||
| 113 | * @skc_bind_node: bind hash linkage for various protocol lookup tables | 115 | * @skc_bind_node: bind hash linkage for various protocol lookup tables |
| 114 | * @skc_refcnt: reference count | ||
| 115 | * @skc_hash: hash value used with various protocol lookup tables | ||
| 116 | * @skc_prot: protocol handlers inside a network family | 116 | * @skc_prot: protocol handlers inside a network family |
| 117 | * @skc_net: reference to the network namespace of this socket | 117 | * @skc_net: reference to the network namespace of this socket |
| 118 | * | 118 | * |
| @@ -120,17 +120,21 @@ struct net; | |||
| 120 | * for struct sock and struct inet_timewait_sock. | 120 | * for struct sock and struct inet_timewait_sock. |
| 121 | */ | 121 | */ |
| 122 | struct sock_common { | 122 | struct sock_common { |
| 123 | unsigned short skc_family; | 123 | /* |
| 124 | volatile unsigned char skc_state; | 124 | * first fields are not copied in sock_copy() |
| 125 | unsigned char skc_reuse; | 125 | */ |
| 126 | int skc_bound_dev_if; | ||
| 127 | union { | 126 | union { |
| 128 | struct hlist_node skc_node; | 127 | struct hlist_node skc_node; |
| 129 | struct hlist_nulls_node skc_nulls_node; | 128 | struct hlist_nulls_node skc_nulls_node; |
| 130 | }; | 129 | }; |
| 131 | struct hlist_node skc_bind_node; | ||
| 132 | atomic_t skc_refcnt; | 130 | atomic_t skc_refcnt; |
| 131 | |||
| 133 | unsigned int skc_hash; | 132 | unsigned int skc_hash; |
| 133 | unsigned short skc_family; | ||
| 134 | volatile unsigned char skc_state; | ||
| 135 | unsigned char skc_reuse; | ||
| 136 | int skc_bound_dev_if; | ||
| 137 | struct hlist_node skc_bind_node; | ||
| 134 | struct proto *skc_prot; | 138 | struct proto *skc_prot; |
| 135 | #ifdef CONFIG_NET_NS | 139 | #ifdef CONFIG_NET_NS |
| 136 | struct net *skc_net; | 140 | struct net *skc_net; |
| @@ -208,15 +212,17 @@ struct sock { | |||
| 208 | * don't add nothing before this first member (__sk_common) --acme | 212 | * don't add nothing before this first member (__sk_common) --acme |
| 209 | */ | 213 | */ |
| 210 | struct sock_common __sk_common; | 214 | struct sock_common __sk_common; |
| 215 | #define sk_node __sk_common.skc_node | ||
| 216 | #define sk_nulls_node __sk_common.skc_nulls_node | ||
| 217 | #define sk_refcnt __sk_common.skc_refcnt | ||
| 218 | |||
| 219 | #define sk_copy_start __sk_common.skc_hash | ||
| 220 | #define sk_hash __sk_common.skc_hash | ||
| 211 | #define sk_family __sk_common.skc_family | 221 | #define sk_family __sk_common.skc_family |
| 212 | #define sk_state __sk_common.skc_state | 222 | #define sk_state __sk_common.skc_state |
| 213 | #define sk_reuse __sk_common.skc_reuse | 223 | #define sk_reuse __sk_common.skc_reuse |
| 214 | #define sk_bound_dev_if __sk_common.skc_bound_dev_if | 224 | #define sk_bound_dev_if __sk_common.skc_bound_dev_if |
| 215 | #define sk_node __sk_common.skc_node | ||
| 216 | #define sk_nulls_node __sk_common.skc_nulls_node | ||
| 217 | #define sk_bind_node __sk_common.skc_bind_node | 225 | #define sk_bind_node __sk_common.skc_bind_node |
| 218 | #define sk_refcnt __sk_common.skc_refcnt | ||
| 219 | #define sk_hash __sk_common.skc_hash | ||
| 220 | #define sk_prot __sk_common.skc_prot | 226 | #define sk_prot __sk_common.skc_prot |
| 221 | #define sk_net __sk_common.skc_net | 227 | #define sk_net __sk_common.skc_net |
| 222 | kmemcheck_bitfield_begin(flags); | 228 | kmemcheck_bitfield_begin(flags); |
diff --git a/include/net/tcp.h b/include/net/tcp.h index 19f4150f4d4d..88af84306471 100644 --- a/include/net/tcp.h +++ b/include/net/tcp.h | |||
| @@ -1425,6 +1425,11 @@ struct tcp_request_sock_ops { | |||
| 1425 | #ifdef CONFIG_TCP_MD5SIG | 1425 | #ifdef CONFIG_TCP_MD5SIG |
| 1426 | struct tcp_md5sig_key *(*md5_lookup) (struct sock *sk, | 1426 | struct tcp_md5sig_key *(*md5_lookup) (struct sock *sk, |
| 1427 | struct request_sock *req); | 1427 | struct request_sock *req); |
| 1428 | int (*calc_md5_hash) (char *location, | ||
| 1429 | struct tcp_md5sig_key *md5, | ||
| 1430 | struct sock *sk, | ||
| 1431 | struct request_sock *req, | ||
| 1432 | struct sk_buff *skb); | ||
| 1428 | #endif | 1433 | #endif |
| 1429 | }; | 1434 | }; |
| 1430 | 1435 | ||
diff --git a/include/trace/ftrace.h b/include/trace/ftrace.h index 1867553c61e5..f64fbaae781a 100644 --- a/include/trace/ftrace.h +++ b/include/trace/ftrace.h | |||
| @@ -144,6 +144,9 @@ | |||
| 144 | #undef TP_fast_assign | 144 | #undef TP_fast_assign |
| 145 | #define TP_fast_assign(args...) args | 145 | #define TP_fast_assign(args...) args |
| 146 | 146 | ||
| 147 | #undef TP_perf_assign | ||
| 148 | #define TP_perf_assign(args...) | ||
| 149 | |||
| 147 | #undef TRACE_EVENT | 150 | #undef TRACE_EVENT |
| 148 | #define TRACE_EVENT(call, proto, args, tstruct, func, print) \ | 151 | #define TRACE_EVENT(call, proto, args, tstruct, func, print) \ |
| 149 | static int \ | 152 | static int \ |
| @@ -345,6 +348,56 @@ static inline int ftrace_get_offsets_##call( \ | |||
| 345 | 348 | ||
| 346 | #include TRACE_INCLUDE(TRACE_INCLUDE_FILE) | 349 | #include TRACE_INCLUDE(TRACE_INCLUDE_FILE) |
| 347 | 350 | ||
| 351 | #ifdef CONFIG_EVENT_PROFILE | ||
| 352 | |||
| 353 | /* | ||
| 354 | * Generate the functions needed for tracepoint perf_counter support. | ||
| 355 | * | ||
| 356 | * NOTE: The insertion profile callback (ftrace_profile_<call>) is defined later | ||
| 357 | * | ||
| 358 | * static int ftrace_profile_enable_<call>(struct ftrace_event_call *event_call) | ||
| 359 | * { | ||
| 360 | * int ret = 0; | ||
| 361 | * | ||
| 362 | * if (!atomic_inc_return(&event_call->profile_count)) | ||
| 363 | * ret = register_trace_<call>(ftrace_profile_<call>); | ||
| 364 | * | ||
| 365 | * return ret; | ||
| 366 | * } | ||
| 367 | * | ||
| 368 | * static void ftrace_profile_disable_<call>(struct ftrace_event_call *event_call) | ||
| 369 | * { | ||
| 370 | * if (atomic_add_negative(-1, &event->call->profile_count)) | ||
| 371 | * unregister_trace_<call>(ftrace_profile_<call>); | ||
| 372 | * } | ||
| 373 | * | ||
| 374 | */ | ||
| 375 | |||
| 376 | #undef TRACE_EVENT | ||
| 377 | #define TRACE_EVENT(call, proto, args, tstruct, assign, print) \ | ||
| 378 | \ | ||
| 379 | static void ftrace_profile_##call(proto); \ | ||
| 380 | \ | ||
| 381 | static int ftrace_profile_enable_##call(struct ftrace_event_call *event_call) \ | ||
| 382 | { \ | ||
| 383 | int ret = 0; \ | ||
| 384 | \ | ||
| 385 | if (!atomic_inc_return(&event_call->profile_count)) \ | ||
| 386 | ret = register_trace_##call(ftrace_profile_##call); \ | ||
| 387 | \ | ||
| 388 | return ret; \ | ||
| 389 | } \ | ||
| 390 | \ | ||
| 391 | static void ftrace_profile_disable_##call(struct ftrace_event_call *event_call)\ | ||
| 392 | { \ | ||
| 393 | if (atomic_add_negative(-1, &event_call->profile_count)) \ | ||
| 394 | unregister_trace_##call(ftrace_profile_##call); \ | ||
| 395 | } | ||
| 396 | |||
| 397 | #include TRACE_INCLUDE(TRACE_INCLUDE_FILE) | ||
| 398 | |||
| 399 | #endif | ||
| 400 | |||
| 348 | /* | 401 | /* |
| 349 | * Stage 4 of the trace events. | 402 | * Stage 4 of the trace events. |
| 350 | * | 403 | * |
| @@ -447,28 +500,6 @@ static inline int ftrace_get_offsets_##call( \ | |||
| 447 | #define TP_FMT(fmt, args...) fmt "\n", ##args | 500 | #define TP_FMT(fmt, args...) fmt "\n", ##args |
| 448 | 501 | ||
| 449 | #ifdef CONFIG_EVENT_PROFILE | 502 | #ifdef CONFIG_EVENT_PROFILE |
| 450 | #define _TRACE_PROFILE(call, proto, args) \ | ||
| 451 | static void ftrace_profile_##call(proto) \ | ||
| 452 | { \ | ||
| 453 | extern void perf_tpcounter_event(int); \ | ||
| 454 | perf_tpcounter_event(event_##call.id); \ | ||
| 455 | } \ | ||
| 456 | \ | ||
| 457 | static int ftrace_profile_enable_##call(struct ftrace_event_call *event_call) \ | ||
| 458 | { \ | ||
| 459 | int ret = 0; \ | ||
| 460 | \ | ||
| 461 | if (!atomic_inc_return(&event_call->profile_count)) \ | ||
| 462 | ret = register_trace_##call(ftrace_profile_##call); \ | ||
| 463 | \ | ||
| 464 | return ret; \ | ||
| 465 | } \ | ||
| 466 | \ | ||
| 467 | static void ftrace_profile_disable_##call(struct ftrace_event_call *event_call)\ | ||
| 468 | { \ | ||
| 469 | if (atomic_add_negative(-1, &event_call->profile_count)) \ | ||
| 470 | unregister_trace_##call(ftrace_profile_##call); \ | ||
| 471 | } | ||
| 472 | 503 | ||
| 473 | #define _TRACE_PROFILE_INIT(call) \ | 504 | #define _TRACE_PROFILE_INIT(call) \ |
| 474 | .profile_count = ATOMIC_INIT(-1), \ | 505 | .profile_count = ATOMIC_INIT(-1), \ |
| @@ -476,7 +507,6 @@ static void ftrace_profile_disable_##call(struct ftrace_event_call *event_call)\ | |||
| 476 | .profile_disable = ftrace_profile_disable_##call, | 507 | .profile_disable = ftrace_profile_disable_##call, |
| 477 | 508 | ||
| 478 | #else | 509 | #else |
| 479 | #define _TRACE_PROFILE(call, proto, args) | ||
| 480 | #define _TRACE_PROFILE_INIT(call) | 510 | #define _TRACE_PROFILE_INIT(call) |
| 481 | #endif | 511 | #endif |
| 482 | 512 | ||
| @@ -502,7 +532,6 @@ static void ftrace_profile_disable_##call(struct ftrace_event_call *event_call)\ | |||
| 502 | 532 | ||
| 503 | #undef TRACE_EVENT | 533 | #undef TRACE_EVENT |
| 504 | #define TRACE_EVENT(call, proto, args, tstruct, assign, print) \ | 534 | #define TRACE_EVENT(call, proto, args, tstruct, assign, print) \ |
| 505 | _TRACE_PROFILE(call, PARAMS(proto), PARAMS(args)) \ | ||
| 506 | \ | 535 | \ |
| 507 | static struct ftrace_event_call event_##call; \ | 536 | static struct ftrace_event_call event_##call; \ |
| 508 | \ | 537 | \ |
| @@ -586,6 +615,110 @@ __attribute__((section("_ftrace_events"))) event_##call = { \ | |||
| 586 | 615 | ||
| 587 | #include TRACE_INCLUDE(TRACE_INCLUDE_FILE) | 616 | #include TRACE_INCLUDE(TRACE_INCLUDE_FILE) |
| 588 | 617 | ||
| 589 | #undef _TRACE_PROFILE | 618 | /* |
| 619 | * Define the insertion callback to profile events | ||
| 620 | * | ||
| 621 | * The job is very similar to ftrace_raw_event_<call> except that we don't | ||
| 622 | * insert in the ring buffer but in a perf counter. | ||
| 623 | * | ||
| 624 | * static void ftrace_profile_<call>(proto) | ||
| 625 | * { | ||
| 626 | * struct ftrace_data_offsets_<call> __maybe_unused __data_offsets; | ||
| 627 | * struct ftrace_event_call *event_call = &event_<call>; | ||
| 628 | * extern void perf_tpcounter_event(int, u64, u64, void *, int); | ||
| 629 | * struct ftrace_raw_##call *entry; | ||
| 630 | * u64 __addr = 0, __count = 1; | ||
| 631 | * unsigned long irq_flags; | ||
| 632 | * int __entry_size; | ||
| 633 | * int __data_size; | ||
| 634 | * int pc; | ||
| 635 | * | ||
| 636 | * local_save_flags(irq_flags); | ||
| 637 | * pc = preempt_count(); | ||
| 638 | * | ||
| 639 | * __data_size = ftrace_get_offsets_<call>(&__data_offsets, args); | ||
| 640 | * | ||
| 641 | * // Below we want to get the aligned size by taking into account | ||
| 642 | * // the u32 field that will later store the buffer size | ||
| 643 | * __entry_size = ALIGN(__data_size + sizeof(*entry) + sizeof(u32), | ||
| 644 | * sizeof(u64)); | ||
| 645 | * __entry_size -= sizeof(u32); | ||
| 646 | * | ||
| 647 | * do { | ||
| 648 | * char raw_data[__entry_size]; <- allocate our sample in the stack | ||
| 649 | * struct trace_entry *ent; | ||
| 650 | * | ||
| 651 | * zero dead bytes from alignment to avoid stack leak to userspace: | ||
| 652 | * | ||
| 653 | * *(u64 *)(&raw_data[__entry_size - sizeof(u64)]) = 0ULL; | ||
| 654 | * entry = (struct ftrace_raw_<call> *)raw_data; | ||
| 655 | * ent = &entry->ent; | ||
| 656 | * tracing_generic_entry_update(ent, irq_flags, pc); | ||
| 657 | * ent->type = event_call->id; | ||
| 658 | * | ||
| 659 | * <tstruct> <- do some jobs with dynamic arrays | ||
| 660 | * | ||
| 661 | * <assign> <- affect our values | ||
| 662 | * | ||
| 663 | * perf_tpcounter_event(event_call->id, __addr, __count, entry, | ||
| 664 | * __entry_size); <- submit them to perf counter | ||
| 665 | * } while (0); | ||
| 666 | * | ||
| 667 | * } | ||
| 668 | */ | ||
| 669 | |||
| 670 | #ifdef CONFIG_EVENT_PROFILE | ||
| 671 | |||
| 672 | #undef __perf_addr | ||
| 673 | #define __perf_addr(a) __addr = (a) | ||
| 674 | |||
| 675 | #undef __perf_count | ||
| 676 | #define __perf_count(c) __count = (c) | ||
| 677 | |||
| 678 | #undef TRACE_EVENT | ||
| 679 | #define TRACE_EVENT(call, proto, args, tstruct, assign, print) \ | ||
| 680 | static void ftrace_profile_##call(proto) \ | ||
| 681 | { \ | ||
| 682 | struct ftrace_data_offsets_##call __maybe_unused __data_offsets;\ | ||
| 683 | struct ftrace_event_call *event_call = &event_##call; \ | ||
| 684 | extern void perf_tpcounter_event(int, u64, u64, void *, int); \ | ||
| 685 | struct ftrace_raw_##call *entry; \ | ||
| 686 | u64 __addr = 0, __count = 1; \ | ||
| 687 | unsigned long irq_flags; \ | ||
| 688 | int __entry_size; \ | ||
| 689 | int __data_size; \ | ||
| 690 | int pc; \ | ||
| 691 | \ | ||
| 692 | local_save_flags(irq_flags); \ | ||
| 693 | pc = preempt_count(); \ | ||
| 694 | \ | ||
| 695 | __data_size = ftrace_get_offsets_##call(&__data_offsets, args); \ | ||
| 696 | __entry_size = ALIGN(__data_size + sizeof(*entry) + sizeof(u32),\ | ||
| 697 | sizeof(u64)); \ | ||
| 698 | __entry_size -= sizeof(u32); \ | ||
| 699 | \ | ||
| 700 | do { \ | ||
| 701 | char raw_data[__entry_size]; \ | ||
| 702 | struct trace_entry *ent; \ | ||
| 703 | \ | ||
| 704 | *(u64 *)(&raw_data[__entry_size - sizeof(u64)]) = 0ULL; \ | ||
| 705 | entry = (struct ftrace_raw_##call *)raw_data; \ | ||
| 706 | ent = &entry->ent; \ | ||
| 707 | tracing_generic_entry_update(ent, irq_flags, pc); \ | ||
| 708 | ent->type = event_call->id; \ | ||
| 709 | \ | ||
| 710 | tstruct \ | ||
| 711 | \ | ||
| 712 | { assign; } \ | ||
| 713 | \ | ||
| 714 | perf_tpcounter_event(event_call->id, __addr, __count, entry,\ | ||
| 715 | __entry_size); \ | ||
| 716 | } while (0); \ | ||
| 717 | \ | ||
| 718 | } | ||
| 719 | |||
| 720 | #include TRACE_INCLUDE(TRACE_INCLUDE_FILE) | ||
| 721 | #endif /* CONFIG_EVENT_PROFILE */ | ||
| 722 | |||
| 590 | #undef _TRACE_PROFILE_INIT | 723 | #undef _TRACE_PROFILE_INIT |
| 591 | 724 | ||
diff --git a/init/Kconfig b/init/Kconfig index 1ce05a4cb5f6..3f7e60995c80 100644 --- a/init/Kconfig +++ b/init/Kconfig | |||
| @@ -940,6 +940,7 @@ menu "Performance Counters" | |||
| 940 | 940 | ||
| 941 | config PERF_COUNTERS | 941 | config PERF_COUNTERS |
| 942 | bool "Kernel Performance Counters" | 942 | bool "Kernel Performance Counters" |
| 943 | default y if PROFILING | ||
| 943 | depends on HAVE_PERF_COUNTERS | 944 | depends on HAVE_PERF_COUNTERS |
| 944 | select ANON_INODES | 945 | select ANON_INODES |
| 945 | help | 946 | help |
| @@ -961,9 +962,17 @@ config PERF_COUNTERS | |||
| 961 | Say Y if unsure. | 962 | Say Y if unsure. |
| 962 | 963 | ||
| 963 | config EVENT_PROFILE | 964 | config EVENT_PROFILE |
| 964 | bool "Tracepoint profile sources" | 965 | bool "Tracepoint profiling sources" |
| 965 | depends on PERF_COUNTERS && EVENT_TRACER | 966 | depends on PERF_COUNTERS && EVENT_TRACING |
| 966 | default y | 967 | default y |
| 968 | help | ||
| 969 | Allow the use of tracepoints as software performance counters. | ||
| 970 | |||
| 971 | When this is enabled, you can create perf counters based on | ||
| 972 | tracepoints using PERF_TYPE_TRACEPOINT and the tracepoint ID | ||
| 973 | found in debugfs://tracing/events/*/*/id. (The -e/--events | ||
| 974 | option to the perf tool can parse and interpret symbolic | ||
| 975 | tracepoints, in the subsystem:tracepoint_name format.) | ||
| 967 | 976 | ||
| 968 | endmenu | 977 | endmenu |
| 969 | 978 | ||
diff --git a/init/main.c b/init/main.c index 2c5ade79eb81..11f4f145be3f 100644 --- a/init/main.c +++ b/init/main.c | |||
| @@ -584,8 +584,8 @@ asmlinkage void __init start_kernel(void) | |||
| 584 | setup_arch(&command_line); | 584 | setup_arch(&command_line); |
| 585 | mm_init_owner(&init_mm, &init_task); | 585 | mm_init_owner(&init_mm, &init_task); |
| 586 | setup_command_line(command_line); | 586 | setup_command_line(command_line); |
| 587 | setup_per_cpu_areas(); | ||
| 588 | setup_nr_cpu_ids(); | 587 | setup_nr_cpu_ids(); |
| 588 | setup_per_cpu_areas(); | ||
| 589 | smp_prepare_boot_cpu(); /* arch-specific boot-cpu hooks */ | 589 | smp_prepare_boot_cpu(); /* arch-specific boot-cpu hooks */ |
| 590 | 590 | ||
| 591 | build_all_zonelists(); | 591 | build_all_zonelists(); |
| @@ -733,13 +733,14 @@ static void __init do_ctors(void) | |||
| 733 | int initcall_debug; | 733 | int initcall_debug; |
| 734 | core_param(initcall_debug, initcall_debug, bool, 0644); | 734 | core_param(initcall_debug, initcall_debug, bool, 0644); |
| 735 | 735 | ||
| 736 | static char msgbuf[64]; | ||
| 737 | static struct boot_trace_call call; | ||
| 738 | static struct boot_trace_ret ret; | ||
| 739 | |||
| 736 | int do_one_initcall(initcall_t fn) | 740 | int do_one_initcall(initcall_t fn) |
| 737 | { | 741 | { |
| 738 | int count = preempt_count(); | 742 | int count = preempt_count(); |
| 739 | ktime_t calltime, delta, rettime; | 743 | ktime_t calltime, delta, rettime; |
| 740 | char msgbuf[64]; | ||
| 741 | struct boot_trace_call call; | ||
| 742 | struct boot_trace_ret ret; | ||
| 743 | 744 | ||
| 744 | if (initcall_debug) { | 745 | if (initcall_debug) { |
| 745 | call.caller = task_pid_nr(current); | 746 | call.caller = task_pid_nr(current); |
| @@ -174,7 +174,7 @@ static void shm_destroy(struct ipc_namespace *ns, struct shmid_kernel *shp) | |||
| 174 | shm_unlock(shp); | 174 | shm_unlock(shp); |
| 175 | if (!is_file_hugepages(shp->shm_file)) | 175 | if (!is_file_hugepages(shp->shm_file)) |
| 176 | shmem_lock(shp->shm_file, 0, shp->mlock_user); | 176 | shmem_lock(shp->shm_file, 0, shp->mlock_user); |
| 177 | else | 177 | else if (shp->mlock_user) |
| 178 | user_shm_unlock(shp->shm_file->f_path.dentry->d_inode->i_size, | 178 | user_shm_unlock(shp->shm_file->f_path.dentry->d_inode->i_size, |
| 179 | shp->mlock_user); | 179 | shp->mlock_user); |
| 180 | fput (shp->shm_file); | 180 | fput (shp->shm_file); |
| @@ -369,8 +369,8 @@ static int newseg(struct ipc_namespace *ns, struct ipc_params *params) | |||
| 369 | /* hugetlb_file_setup applies strict accounting */ | 369 | /* hugetlb_file_setup applies strict accounting */ |
| 370 | if (shmflg & SHM_NORESERVE) | 370 | if (shmflg & SHM_NORESERVE) |
| 371 | acctflag = VM_NORESERVE; | 371 | acctflag = VM_NORESERVE; |
| 372 | file = hugetlb_file_setup(name, size, acctflag); | 372 | file = hugetlb_file_setup(name, size, acctflag, |
| 373 | shp->mlock_user = current_user(); | 373 | &shp->mlock_user); |
| 374 | } else { | 374 | } else { |
| 375 | /* | 375 | /* |
| 376 | * Do not allow no accounting for OVERCOMMIT_NEVER, even | 376 | * Do not allow no accounting for OVERCOMMIT_NEVER, even |
| @@ -410,6 +410,8 @@ static int newseg(struct ipc_namespace *ns, struct ipc_params *params) | |||
| 410 | return error; | 410 | return error; |
| 411 | 411 | ||
| 412 | no_id: | 412 | no_id: |
| 413 | if (shp->mlock_user) /* shmflg & SHM_HUGETLB case */ | ||
| 414 | user_shm_unlock(size, shp->mlock_user); | ||
| 413 | fput(file); | 415 | fput(file); |
| 414 | no_file: | 416 | no_file: |
| 415 | security_shm_free(shp); | 417 | security_shm_free(shp); |
diff --git a/kernel/cgroup.c b/kernel/cgroup.c index 3737a682cdf5..b6eadfe30e7b 100644 --- a/kernel/cgroup.c +++ b/kernel/cgroup.c | |||
| @@ -47,6 +47,7 @@ | |||
| 47 | #include <linux/hash.h> | 47 | #include <linux/hash.h> |
| 48 | #include <linux/namei.h> | 48 | #include <linux/namei.h> |
| 49 | #include <linux/smp_lock.h> | 49 | #include <linux/smp_lock.h> |
| 50 | #include <linux/pid_namespace.h> | ||
| 50 | 51 | ||
| 51 | #include <asm/atomic.h> | 52 | #include <asm/atomic.h> |
| 52 | 53 | ||
| @@ -734,16 +735,28 @@ static void cgroup_d_remove_dir(struct dentry *dentry) | |||
| 734 | * reference to css->refcnt. In general, this refcnt is expected to goes down | 735 | * reference to css->refcnt. In general, this refcnt is expected to goes down |
| 735 | * to zero, soon. | 736 | * to zero, soon. |
| 736 | * | 737 | * |
| 737 | * CGRP_WAIT_ON_RMDIR flag is modified under cgroup's inode->i_mutex; | 738 | * CGRP_WAIT_ON_RMDIR flag is set under cgroup's inode->i_mutex; |
| 738 | */ | 739 | */ |
| 739 | DECLARE_WAIT_QUEUE_HEAD(cgroup_rmdir_waitq); | 740 | DECLARE_WAIT_QUEUE_HEAD(cgroup_rmdir_waitq); |
| 740 | 741 | ||
| 741 | static void cgroup_wakeup_rmdir_waiters(const struct cgroup *cgrp) | 742 | static void cgroup_wakeup_rmdir_waiter(struct cgroup *cgrp) |
| 742 | { | 743 | { |
| 743 | if (unlikely(test_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags))) | 744 | if (unlikely(test_and_clear_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags))) |
| 744 | wake_up_all(&cgroup_rmdir_waitq); | 745 | wake_up_all(&cgroup_rmdir_waitq); |
| 745 | } | 746 | } |
| 746 | 747 | ||
| 748 | void cgroup_exclude_rmdir(struct cgroup_subsys_state *css) | ||
| 749 | { | ||
| 750 | css_get(css); | ||
| 751 | } | ||
| 752 | |||
| 753 | void cgroup_release_and_wakeup_rmdir(struct cgroup_subsys_state *css) | ||
| 754 | { | ||
| 755 | cgroup_wakeup_rmdir_waiter(css->cgroup); | ||
| 756 | css_put(css); | ||
| 757 | } | ||
| 758 | |||
| 759 | |||
| 747 | static int rebind_subsystems(struct cgroupfs_root *root, | 760 | static int rebind_subsystems(struct cgroupfs_root *root, |
| 748 | unsigned long final_bits) | 761 | unsigned long final_bits) |
| 749 | { | 762 | { |
| @@ -960,6 +973,7 @@ static void init_cgroup_housekeeping(struct cgroup *cgrp) | |||
| 960 | INIT_LIST_HEAD(&cgrp->children); | 973 | INIT_LIST_HEAD(&cgrp->children); |
| 961 | INIT_LIST_HEAD(&cgrp->css_sets); | 974 | INIT_LIST_HEAD(&cgrp->css_sets); |
| 962 | INIT_LIST_HEAD(&cgrp->release_list); | 975 | INIT_LIST_HEAD(&cgrp->release_list); |
| 976 | INIT_LIST_HEAD(&cgrp->pids_list); | ||
| 963 | init_rwsem(&cgrp->pids_mutex); | 977 | init_rwsem(&cgrp->pids_mutex); |
| 964 | } | 978 | } |
| 965 | static void init_cgroup_root(struct cgroupfs_root *root) | 979 | static void init_cgroup_root(struct cgroupfs_root *root) |
| @@ -1357,7 +1371,7 @@ int cgroup_attach_task(struct cgroup *cgrp, struct task_struct *tsk) | |||
| 1357 | * wake up rmdir() waiter. the rmdir should fail since the cgroup | 1371 | * wake up rmdir() waiter. the rmdir should fail since the cgroup |
| 1358 | * is no longer empty. | 1372 | * is no longer empty. |
| 1359 | */ | 1373 | */ |
| 1360 | cgroup_wakeup_rmdir_waiters(cgrp); | 1374 | cgroup_wakeup_rmdir_waiter(cgrp); |
| 1361 | return 0; | 1375 | return 0; |
| 1362 | } | 1376 | } |
| 1363 | 1377 | ||
| @@ -2201,12 +2215,30 @@ err: | |||
| 2201 | return ret; | 2215 | return ret; |
| 2202 | } | 2216 | } |
| 2203 | 2217 | ||
| 2218 | /* | ||
| 2219 | * Cache pids for all threads in the same pid namespace that are | ||
| 2220 | * opening the same "tasks" file. | ||
| 2221 | */ | ||
| 2222 | struct cgroup_pids { | ||
| 2223 | /* The node in cgrp->pids_list */ | ||
| 2224 | struct list_head list; | ||
| 2225 | /* The cgroup those pids belong to */ | ||
| 2226 | struct cgroup *cgrp; | ||
| 2227 | /* The namepsace those pids belong to */ | ||
| 2228 | struct pid_namespace *ns; | ||
| 2229 | /* Array of process ids in the cgroup */ | ||
| 2230 | pid_t *tasks_pids; | ||
| 2231 | /* How many files are using the this tasks_pids array */ | ||
| 2232 | int use_count; | ||
| 2233 | /* Length of the current tasks_pids array */ | ||
| 2234 | int length; | ||
| 2235 | }; | ||
| 2236 | |||
| 2204 | static int cmppid(const void *a, const void *b) | 2237 | static int cmppid(const void *a, const void *b) |
| 2205 | { | 2238 | { |
| 2206 | return *(pid_t *)a - *(pid_t *)b; | 2239 | return *(pid_t *)a - *(pid_t *)b; |
| 2207 | } | 2240 | } |
| 2208 | 2241 | ||
| 2209 | |||
| 2210 | /* | 2242 | /* |
| 2211 | * seq_file methods for the "tasks" file. The seq_file position is the | 2243 | * seq_file methods for the "tasks" file. The seq_file position is the |
| 2212 | * next pid to display; the seq_file iterator is a pointer to the pid | 2244 | * next pid to display; the seq_file iterator is a pointer to the pid |
| @@ -2221,45 +2253,47 @@ static void *cgroup_tasks_start(struct seq_file *s, loff_t *pos) | |||
| 2221 | * after a seek to the start). Use a binary-search to find the | 2253 | * after a seek to the start). Use a binary-search to find the |
| 2222 | * next pid to display, if any | 2254 | * next pid to display, if any |
| 2223 | */ | 2255 | */ |
| 2224 | struct cgroup *cgrp = s->private; | 2256 | struct cgroup_pids *cp = s->private; |
| 2257 | struct cgroup *cgrp = cp->cgrp; | ||
| 2225 | int index = 0, pid = *pos; | 2258 | int index = 0, pid = *pos; |
| 2226 | int *iter; | 2259 | int *iter; |
| 2227 | 2260 | ||
| 2228 | down_read(&cgrp->pids_mutex); | 2261 | down_read(&cgrp->pids_mutex); |
| 2229 | if (pid) { | 2262 | if (pid) { |
| 2230 | int end = cgrp->pids_length; | 2263 | int end = cp->length; |
| 2231 | 2264 | ||
| 2232 | while (index < end) { | 2265 | while (index < end) { |
| 2233 | int mid = (index + end) / 2; | 2266 | int mid = (index + end) / 2; |
| 2234 | if (cgrp->tasks_pids[mid] == pid) { | 2267 | if (cp->tasks_pids[mid] == pid) { |
| 2235 | index = mid; | 2268 | index = mid; |
| 2236 | break; | 2269 | break; |
| 2237 | } else if (cgrp->tasks_pids[mid] <= pid) | 2270 | } else if (cp->tasks_pids[mid] <= pid) |
| 2238 | index = mid + 1; | 2271 | index = mid + 1; |
| 2239 | else | 2272 | else |
| 2240 | end = mid; | 2273 | end = mid; |
| 2241 | } | 2274 | } |
| 2242 | } | 2275 | } |
| 2243 | /* If we're off the end of the array, we're done */ | 2276 | /* If we're off the end of the array, we're done */ |
| 2244 | if (index >= cgrp->pids_length) | 2277 | if (index >= cp->length) |
| 2245 | return NULL; | 2278 | return NULL; |
| 2246 | /* Update the abstract position to be the actual pid that we found */ | 2279 | /* Update the abstract position to be the actual pid that we found */ |
| 2247 | iter = cgrp->tasks_pids + index; | 2280 | iter = cp->tasks_pids + index; |
| 2248 | *pos = *iter; | 2281 | *pos = *iter; |
| 2249 | return iter; | 2282 | return iter; |
| 2250 | } | 2283 | } |
| 2251 | 2284 | ||
| 2252 | static void cgroup_tasks_stop(struct seq_file *s, void *v) | 2285 | static void cgroup_tasks_stop(struct seq_file *s, void *v) |
| 2253 | { | 2286 | { |
| 2254 | struct cgroup *cgrp = s->private; | 2287 | struct cgroup_pids *cp = s->private; |
| 2288 | struct cgroup *cgrp = cp->cgrp; | ||
| 2255 | up_read(&cgrp->pids_mutex); | 2289 | up_read(&cgrp->pids_mutex); |
| 2256 | } | 2290 | } |
| 2257 | 2291 | ||
| 2258 | static void *cgroup_tasks_next(struct seq_file *s, void *v, loff_t *pos) | 2292 | static void *cgroup_tasks_next(struct seq_file *s, void *v, loff_t *pos) |
| 2259 | { | 2293 | { |
| 2260 | struct cgroup *cgrp = s->private; | 2294 | struct cgroup_pids *cp = s->private; |
| 2261 | int *p = v; | 2295 | int *p = v; |
| 2262 | int *end = cgrp->tasks_pids + cgrp->pids_length; | 2296 | int *end = cp->tasks_pids + cp->length; |
| 2263 | 2297 | ||
| 2264 | /* | 2298 | /* |
| 2265 | * Advance to the next pid in the array. If this goes off the | 2299 | * Advance to the next pid in the array. If this goes off the |
| @@ -2286,26 +2320,33 @@ static struct seq_operations cgroup_tasks_seq_operations = { | |||
| 2286 | .show = cgroup_tasks_show, | 2320 | .show = cgroup_tasks_show, |
| 2287 | }; | 2321 | }; |
| 2288 | 2322 | ||
| 2289 | static void release_cgroup_pid_array(struct cgroup *cgrp) | 2323 | static void release_cgroup_pid_array(struct cgroup_pids *cp) |
| 2290 | { | 2324 | { |
| 2325 | struct cgroup *cgrp = cp->cgrp; | ||
| 2326 | |||
| 2291 | down_write(&cgrp->pids_mutex); | 2327 | down_write(&cgrp->pids_mutex); |
| 2292 | BUG_ON(!cgrp->pids_use_count); | 2328 | BUG_ON(!cp->use_count); |
| 2293 | if (!--cgrp->pids_use_count) { | 2329 | if (!--cp->use_count) { |
| 2294 | kfree(cgrp->tasks_pids); | 2330 | list_del(&cp->list); |
| 2295 | cgrp->tasks_pids = NULL; | 2331 | put_pid_ns(cp->ns); |
| 2296 | cgrp->pids_length = 0; | 2332 | kfree(cp->tasks_pids); |
| 2333 | kfree(cp); | ||
| 2297 | } | 2334 | } |
| 2298 | up_write(&cgrp->pids_mutex); | 2335 | up_write(&cgrp->pids_mutex); |
| 2299 | } | 2336 | } |
| 2300 | 2337 | ||
| 2301 | static int cgroup_tasks_release(struct inode *inode, struct file *file) | 2338 | static int cgroup_tasks_release(struct inode *inode, struct file *file) |
| 2302 | { | 2339 | { |
| 2303 | struct cgroup *cgrp = __d_cgrp(file->f_dentry->d_parent); | 2340 | struct seq_file *seq; |
| 2341 | struct cgroup_pids *cp; | ||
| 2304 | 2342 | ||
| 2305 | if (!(file->f_mode & FMODE_READ)) | 2343 | if (!(file->f_mode & FMODE_READ)) |
| 2306 | return 0; | 2344 | return 0; |
| 2307 | 2345 | ||
| 2308 | release_cgroup_pid_array(cgrp); | 2346 | seq = file->private_data; |
| 2347 | cp = seq->private; | ||
| 2348 | |||
| 2349 | release_cgroup_pid_array(cp); | ||
| 2309 | return seq_release(inode, file); | 2350 | return seq_release(inode, file); |
| 2310 | } | 2351 | } |
| 2311 | 2352 | ||
| @@ -2324,6 +2365,8 @@ static struct file_operations cgroup_tasks_operations = { | |||
| 2324 | static int cgroup_tasks_open(struct inode *unused, struct file *file) | 2365 | static int cgroup_tasks_open(struct inode *unused, struct file *file) |
| 2325 | { | 2366 | { |
| 2326 | struct cgroup *cgrp = __d_cgrp(file->f_dentry->d_parent); | 2367 | struct cgroup *cgrp = __d_cgrp(file->f_dentry->d_parent); |
| 2368 | struct pid_namespace *ns = current->nsproxy->pid_ns; | ||
| 2369 | struct cgroup_pids *cp; | ||
| 2327 | pid_t *pidarray; | 2370 | pid_t *pidarray; |
| 2328 | int npids; | 2371 | int npids; |
| 2329 | int retval; | 2372 | int retval; |
| @@ -2350,20 +2393,37 @@ static int cgroup_tasks_open(struct inode *unused, struct file *file) | |||
| 2350 | * array if necessary | 2393 | * array if necessary |
| 2351 | */ | 2394 | */ |
| 2352 | down_write(&cgrp->pids_mutex); | 2395 | down_write(&cgrp->pids_mutex); |
| 2353 | kfree(cgrp->tasks_pids); | 2396 | |
| 2354 | cgrp->tasks_pids = pidarray; | 2397 | list_for_each_entry(cp, &cgrp->pids_list, list) { |
| 2355 | cgrp->pids_length = npids; | 2398 | if (ns == cp->ns) |
| 2356 | cgrp->pids_use_count++; | 2399 | goto found; |
| 2400 | } | ||
| 2401 | |||
| 2402 | cp = kzalloc(sizeof(*cp), GFP_KERNEL); | ||
| 2403 | if (!cp) { | ||
| 2404 | up_write(&cgrp->pids_mutex); | ||
| 2405 | kfree(pidarray); | ||
| 2406 | return -ENOMEM; | ||
| 2407 | } | ||
| 2408 | cp->cgrp = cgrp; | ||
| 2409 | cp->ns = ns; | ||
| 2410 | get_pid_ns(ns); | ||
| 2411 | list_add(&cp->list, &cgrp->pids_list); | ||
| 2412 | found: | ||
| 2413 | kfree(cp->tasks_pids); | ||
| 2414 | cp->tasks_pids = pidarray; | ||
| 2415 | cp->length = npids; | ||
| 2416 | cp->use_count++; | ||
| 2357 | up_write(&cgrp->pids_mutex); | 2417 | up_write(&cgrp->pids_mutex); |
| 2358 | 2418 | ||
| 2359 | file->f_op = &cgroup_tasks_operations; | 2419 | file->f_op = &cgroup_tasks_operations; |
| 2360 | 2420 | ||
| 2361 | retval = seq_open(file, &cgroup_tasks_seq_operations); | 2421 | retval = seq_open(file, &cgroup_tasks_seq_operations); |
| 2362 | if (retval) { | 2422 | if (retval) { |
| 2363 | release_cgroup_pid_array(cgrp); | 2423 | release_cgroup_pid_array(cp); |
| 2364 | return retval; | 2424 | return retval; |
| 2365 | } | 2425 | } |
| 2366 | ((struct seq_file *)file->private_data)->private = cgrp; | 2426 | ((struct seq_file *)file->private_data)->private = cp; |
| 2367 | return 0; | 2427 | return 0; |
| 2368 | } | 2428 | } |
| 2369 | 2429 | ||
| @@ -2696,33 +2756,42 @@ again: | |||
| 2696 | mutex_unlock(&cgroup_mutex); | 2756 | mutex_unlock(&cgroup_mutex); |
| 2697 | 2757 | ||
| 2698 | /* | 2758 | /* |
| 2759 | * In general, subsystem has no css->refcnt after pre_destroy(). But | ||
| 2760 | * in racy cases, subsystem may have to get css->refcnt after | ||
| 2761 | * pre_destroy() and it makes rmdir return with -EBUSY. This sometimes | ||
| 2762 | * make rmdir return -EBUSY too often. To avoid that, we use waitqueue | ||
| 2763 | * for cgroup's rmdir. CGRP_WAIT_ON_RMDIR is for synchronizing rmdir | ||
| 2764 | * and subsystem's reference count handling. Please see css_get/put | ||
| 2765 | * and css_tryget() and cgroup_wakeup_rmdir_waiter() implementation. | ||
| 2766 | */ | ||
| 2767 | set_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags); | ||
| 2768 | |||
| 2769 | /* | ||
| 2699 | * Call pre_destroy handlers of subsys. Notify subsystems | 2770 | * Call pre_destroy handlers of subsys. Notify subsystems |
| 2700 | * that rmdir() request comes. | 2771 | * that rmdir() request comes. |
| 2701 | */ | 2772 | */ |
| 2702 | ret = cgroup_call_pre_destroy(cgrp); | 2773 | ret = cgroup_call_pre_destroy(cgrp); |
| 2703 | if (ret) | 2774 | if (ret) { |
| 2775 | clear_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags); | ||
| 2704 | return ret; | 2776 | return ret; |
| 2777 | } | ||
| 2705 | 2778 | ||
| 2706 | mutex_lock(&cgroup_mutex); | 2779 | mutex_lock(&cgroup_mutex); |
| 2707 | parent = cgrp->parent; | 2780 | parent = cgrp->parent; |
| 2708 | if (atomic_read(&cgrp->count) || !list_empty(&cgrp->children)) { | 2781 | if (atomic_read(&cgrp->count) || !list_empty(&cgrp->children)) { |
| 2782 | clear_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags); | ||
| 2709 | mutex_unlock(&cgroup_mutex); | 2783 | mutex_unlock(&cgroup_mutex); |
| 2710 | return -EBUSY; | 2784 | return -EBUSY; |
| 2711 | } | 2785 | } |
| 2712 | /* | ||
| 2713 | * css_put/get is provided for subsys to grab refcnt to css. In typical | ||
| 2714 | * case, subsystem has no reference after pre_destroy(). But, under | ||
| 2715 | * hierarchy management, some *temporal* refcnt can be hold. | ||
| 2716 | * To avoid returning -EBUSY to a user, waitqueue is used. If subsys | ||
| 2717 | * is really busy, it should return -EBUSY at pre_destroy(). wake_up | ||
| 2718 | * is called when css_put() is called and refcnt goes down to 0. | ||
| 2719 | */ | ||
| 2720 | set_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags); | ||
| 2721 | prepare_to_wait(&cgroup_rmdir_waitq, &wait, TASK_INTERRUPTIBLE); | 2786 | prepare_to_wait(&cgroup_rmdir_waitq, &wait, TASK_INTERRUPTIBLE); |
| 2722 | |||
| 2723 | if (!cgroup_clear_css_refs(cgrp)) { | 2787 | if (!cgroup_clear_css_refs(cgrp)) { |
| 2724 | mutex_unlock(&cgroup_mutex); | 2788 | mutex_unlock(&cgroup_mutex); |
| 2725 | schedule(); | 2789 | /* |
| 2790 | * Because someone may call cgroup_wakeup_rmdir_waiter() before | ||
| 2791 | * prepare_to_wait(), we need to check this flag. | ||
| 2792 | */ | ||
| 2793 | if (test_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags)) | ||
| 2794 | schedule(); | ||
| 2726 | finish_wait(&cgroup_rmdir_waitq, &wait); | 2795 | finish_wait(&cgroup_rmdir_waitq, &wait); |
| 2727 | clear_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags); | 2796 | clear_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags); |
| 2728 | if (signal_pending(current)) | 2797 | if (signal_pending(current)) |
| @@ -3294,7 +3363,7 @@ void __css_put(struct cgroup_subsys_state *css) | |||
| 3294 | set_bit(CGRP_RELEASABLE, &cgrp->flags); | 3363 | set_bit(CGRP_RELEASABLE, &cgrp->flags); |
| 3295 | check_for_release(cgrp); | 3364 | check_for_release(cgrp); |
| 3296 | } | 3365 | } |
| 3297 | cgroup_wakeup_rmdir_waiters(cgrp); | 3366 | cgroup_wakeup_rmdir_waiter(cgrp); |
| 3298 | } | 3367 | } |
| 3299 | rcu_read_unlock(); | 3368 | rcu_read_unlock(); |
| 3300 | } | 3369 | } |
diff --git a/kernel/fork.c b/kernel/fork.c index bd2959228871..e6c04d462ab2 100644 --- a/kernel/fork.c +++ b/kernel/fork.c | |||
| @@ -567,18 +567,18 @@ void mm_release(struct task_struct *tsk, struct mm_struct *mm) | |||
| 567 | * the value intact in a core dump, and to save the unnecessary | 567 | * the value intact in a core dump, and to save the unnecessary |
| 568 | * trouble otherwise. Userland only wants this done for a sys_exit. | 568 | * trouble otherwise. Userland only wants this done for a sys_exit. |
| 569 | */ | 569 | */ |
| 570 | if (tsk->clear_child_tid | 570 | if (tsk->clear_child_tid) { |
| 571 | && !(tsk->flags & PF_SIGNALED) | 571 | if (!(tsk->flags & PF_SIGNALED) && |
| 572 | && atomic_read(&mm->mm_users) > 1) { | 572 | atomic_read(&mm->mm_users) > 1) { |
| 573 | u32 __user * tidptr = tsk->clear_child_tid; | 573 | /* |
| 574 | * We don't check the error code - if userspace has | ||
| 575 | * not set up a proper pointer then tough luck. | ||
| 576 | */ | ||
| 577 | put_user(0, tsk->clear_child_tid); | ||
| 578 | sys_futex(tsk->clear_child_tid, FUTEX_WAKE, | ||
| 579 | 1, NULL, NULL, 0); | ||
| 580 | } | ||
| 574 | tsk->clear_child_tid = NULL; | 581 | tsk->clear_child_tid = NULL; |
| 575 | |||
| 576 | /* | ||
| 577 | * We don't check the error code - if userspace has | ||
| 578 | * not set up a proper pointer then tough luck. | ||
| 579 | */ | ||
| 580 | put_user(0, tidptr); | ||
| 581 | sys_futex(tidptr, FUTEX_WAKE, 1, NULL, NULL, 0); | ||
| 582 | } | 582 | } |
| 583 | } | 583 | } |
| 584 | 584 | ||
| @@ -815,11 +815,8 @@ static int copy_signal(unsigned long clone_flags, struct task_struct *tsk) | |||
| 815 | { | 815 | { |
| 816 | struct signal_struct *sig; | 816 | struct signal_struct *sig; |
| 817 | 817 | ||
| 818 | if (clone_flags & CLONE_THREAD) { | 818 | if (clone_flags & CLONE_THREAD) |
| 819 | atomic_inc(¤t->signal->count); | ||
| 820 | atomic_inc(¤t->signal->live); | ||
| 821 | return 0; | 819 | return 0; |
| 822 | } | ||
| 823 | 820 | ||
| 824 | sig = kmem_cache_alloc(signal_cachep, GFP_KERNEL); | 821 | sig = kmem_cache_alloc(signal_cachep, GFP_KERNEL); |
| 825 | tsk->signal = sig; | 822 | tsk->signal = sig; |
| @@ -877,16 +874,6 @@ void __cleanup_signal(struct signal_struct *sig) | |||
| 877 | kmem_cache_free(signal_cachep, sig); | 874 | kmem_cache_free(signal_cachep, sig); |
| 878 | } | 875 | } |
| 879 | 876 | ||
| 880 | static void cleanup_signal(struct task_struct *tsk) | ||
| 881 | { | ||
| 882 | struct signal_struct *sig = tsk->signal; | ||
| 883 | |||
| 884 | atomic_dec(&sig->live); | ||
| 885 | |||
| 886 | if (atomic_dec_and_test(&sig->count)) | ||
| 887 | __cleanup_signal(sig); | ||
| 888 | } | ||
| 889 | |||
| 890 | static void copy_flags(unsigned long clone_flags, struct task_struct *p) | 877 | static void copy_flags(unsigned long clone_flags, struct task_struct *p) |
| 891 | { | 878 | { |
| 892 | unsigned long new_flags = p->flags; | 879 | unsigned long new_flags = p->flags; |
| @@ -1239,6 +1226,8 @@ static struct task_struct *copy_process(unsigned long clone_flags, | |||
| 1239 | } | 1226 | } |
| 1240 | 1227 | ||
| 1241 | if (clone_flags & CLONE_THREAD) { | 1228 | if (clone_flags & CLONE_THREAD) { |
| 1229 | atomic_inc(¤t->signal->count); | ||
| 1230 | atomic_inc(¤t->signal->live); | ||
| 1242 | p->group_leader = current->group_leader; | 1231 | p->group_leader = current->group_leader; |
| 1243 | list_add_tail_rcu(&p->thread_group, &p->group_leader->thread_group); | 1232 | list_add_tail_rcu(&p->thread_group, &p->group_leader->thread_group); |
| 1244 | } | 1233 | } |
| @@ -1268,6 +1257,7 @@ static struct task_struct *copy_process(unsigned long clone_flags, | |||
| 1268 | write_unlock_irq(&tasklist_lock); | 1257 | write_unlock_irq(&tasklist_lock); |
| 1269 | proc_fork_connector(p); | 1258 | proc_fork_connector(p); |
| 1270 | cgroup_post_fork(p); | 1259 | cgroup_post_fork(p); |
| 1260 | perf_counter_fork(p); | ||
| 1271 | return p; | 1261 | return p; |
| 1272 | 1262 | ||
| 1273 | bad_fork_free_pid: | 1263 | bad_fork_free_pid: |
| @@ -1281,7 +1271,8 @@ bad_fork_cleanup_mm: | |||
| 1281 | if (p->mm) | 1271 | if (p->mm) |
| 1282 | mmput(p->mm); | 1272 | mmput(p->mm); |
| 1283 | bad_fork_cleanup_signal: | 1273 | bad_fork_cleanup_signal: |
| 1284 | cleanup_signal(p); | 1274 | if (!(clone_flags & CLONE_THREAD)) |
| 1275 | __cleanup_signal(p->signal); | ||
| 1285 | bad_fork_cleanup_sighand: | 1276 | bad_fork_cleanup_sighand: |
| 1286 | __cleanup_sighand(p->sighand); | 1277 | __cleanup_sighand(p->sighand); |
| 1287 | bad_fork_cleanup_fs: | 1278 | bad_fork_cleanup_fs: |
| @@ -1407,12 +1398,6 @@ long do_fork(unsigned long clone_flags, | |||
| 1407 | if (clone_flags & CLONE_VFORK) { | 1398 | if (clone_flags & CLONE_VFORK) { |
| 1408 | p->vfork_done = &vfork; | 1399 | p->vfork_done = &vfork; |
| 1409 | init_completion(&vfork); | 1400 | init_completion(&vfork); |
| 1410 | } else if (!(clone_flags & CLONE_VM)) { | ||
| 1411 | /* | ||
| 1412 | * vfork will do an exec which will call | ||
| 1413 | * set_task_comm() | ||
| 1414 | */ | ||
| 1415 | perf_counter_fork(p); | ||
| 1416 | } | 1401 | } |
| 1417 | 1402 | ||
| 1418 | audit_finish_fork(p); | 1403 | audit_finish_fork(p); |
diff --git a/kernel/freezer.c b/kernel/freezer.c index 2f4936cf7083..bd1d42b17cb2 100644 --- a/kernel/freezer.c +++ b/kernel/freezer.c | |||
| @@ -44,12 +44,19 @@ void refrigerator(void) | |||
| 44 | recalc_sigpending(); /* We sent fake signal, clean it up */ | 44 | recalc_sigpending(); /* We sent fake signal, clean it up */ |
| 45 | spin_unlock_irq(¤t->sighand->siglock); | 45 | spin_unlock_irq(¤t->sighand->siglock); |
| 46 | 46 | ||
| 47 | /* prevent accounting of that task to load */ | ||
| 48 | current->flags |= PF_FREEZING; | ||
| 49 | |||
| 47 | for (;;) { | 50 | for (;;) { |
| 48 | set_current_state(TASK_UNINTERRUPTIBLE); | 51 | set_current_state(TASK_UNINTERRUPTIBLE); |
| 49 | if (!frozen(current)) | 52 | if (!frozen(current)) |
| 50 | break; | 53 | break; |
| 51 | schedule(); | 54 | schedule(); |
| 52 | } | 55 | } |
| 56 | |||
| 57 | /* Remove the accounting blocker */ | ||
| 58 | current->flags &= ~PF_FREEZING; | ||
| 59 | |||
| 53 | pr_debug("%s left refrigerator\n", current->comm); | 60 | pr_debug("%s left refrigerator\n", current->comm); |
| 54 | __set_current_state(save); | 61 | __set_current_state(save); |
| 55 | } | 62 | } |
diff --git a/kernel/futex.c b/kernel/futex.c index 0672ff88f159..e18cfbdc7190 100644 --- a/kernel/futex.c +++ b/kernel/futex.c | |||
| @@ -1010,15 +1010,19 @@ void requeue_futex(struct futex_q *q, struct futex_hash_bucket *hb1, | |||
| 1010 | * requeue_pi_wake_futex() - Wake a task that acquired the lock during requeue | 1010 | * requeue_pi_wake_futex() - Wake a task that acquired the lock during requeue |
| 1011 | * q: the futex_q | 1011 | * q: the futex_q |
| 1012 | * key: the key of the requeue target futex | 1012 | * key: the key of the requeue target futex |
| 1013 | * hb: the hash_bucket of the requeue target futex | ||
| 1013 | * | 1014 | * |
| 1014 | * During futex_requeue, with requeue_pi=1, it is possible to acquire the | 1015 | * During futex_requeue, with requeue_pi=1, it is possible to acquire the |
| 1015 | * target futex if it is uncontended or via a lock steal. Set the futex_q key | 1016 | * target futex if it is uncontended or via a lock steal. Set the futex_q key |
| 1016 | * to the requeue target futex so the waiter can detect the wakeup on the right | 1017 | * to the requeue target futex so the waiter can detect the wakeup on the right |
| 1017 | * futex, but remove it from the hb and NULL the rt_waiter so it can detect | 1018 | * futex, but remove it from the hb and NULL the rt_waiter so it can detect |
| 1018 | * atomic lock acquisition. Must be called with the q->lock_ptr held. | 1019 | * atomic lock acquisition. Set the q->lock_ptr to the requeue target hb->lock |
| 1020 | * to protect access to the pi_state to fixup the owner later. Must be called | ||
| 1021 | * with both q->lock_ptr and hb->lock held. | ||
| 1019 | */ | 1022 | */ |
| 1020 | static inline | 1023 | static inline |
| 1021 | void requeue_pi_wake_futex(struct futex_q *q, union futex_key *key) | 1024 | void requeue_pi_wake_futex(struct futex_q *q, union futex_key *key, |
| 1025 | struct futex_hash_bucket *hb) | ||
| 1022 | { | 1026 | { |
| 1023 | drop_futex_key_refs(&q->key); | 1027 | drop_futex_key_refs(&q->key); |
| 1024 | get_futex_key_refs(key); | 1028 | get_futex_key_refs(key); |
| @@ -1030,6 +1034,11 @@ void requeue_pi_wake_futex(struct futex_q *q, union futex_key *key) | |||
| 1030 | WARN_ON(!q->rt_waiter); | 1034 | WARN_ON(!q->rt_waiter); |
| 1031 | q->rt_waiter = NULL; | 1035 | q->rt_waiter = NULL; |
| 1032 | 1036 | ||
| 1037 | q->lock_ptr = &hb->lock; | ||
| 1038 | #ifdef CONFIG_DEBUG_PI_LIST | ||
| 1039 | q->list.plist.lock = &hb->lock; | ||
| 1040 | #endif | ||
| 1041 | |||
| 1033 | wake_up_state(q->task, TASK_NORMAL); | 1042 | wake_up_state(q->task, TASK_NORMAL); |
| 1034 | } | 1043 | } |
| 1035 | 1044 | ||
| @@ -1088,7 +1097,7 @@ static int futex_proxy_trylock_atomic(u32 __user *pifutex, | |||
| 1088 | ret = futex_lock_pi_atomic(pifutex, hb2, key2, ps, top_waiter->task, | 1097 | ret = futex_lock_pi_atomic(pifutex, hb2, key2, ps, top_waiter->task, |
| 1089 | set_waiters); | 1098 | set_waiters); |
| 1090 | if (ret == 1) | 1099 | if (ret == 1) |
| 1091 | requeue_pi_wake_futex(top_waiter, key2); | 1100 | requeue_pi_wake_futex(top_waiter, key2, hb2); |
| 1092 | 1101 | ||
| 1093 | return ret; | 1102 | return ret; |
| 1094 | } | 1103 | } |
| @@ -1247,8 +1256,15 @@ retry_private: | |||
| 1247 | if (!match_futex(&this->key, &key1)) | 1256 | if (!match_futex(&this->key, &key1)) |
| 1248 | continue; | 1257 | continue; |
| 1249 | 1258 | ||
| 1250 | WARN_ON(!requeue_pi && this->rt_waiter); | 1259 | /* |
| 1251 | WARN_ON(requeue_pi && !this->rt_waiter); | 1260 | * FUTEX_WAIT_REQEUE_PI and FUTEX_CMP_REQUEUE_PI should always |
| 1261 | * be paired with each other and no other futex ops. | ||
| 1262 | */ | ||
| 1263 | if ((requeue_pi && !this->rt_waiter) || | ||
| 1264 | (!requeue_pi && this->rt_waiter)) { | ||
| 1265 | ret = -EINVAL; | ||
| 1266 | break; | ||
| 1267 | } | ||
| 1252 | 1268 | ||
| 1253 | /* | 1269 | /* |
| 1254 | * Wake nr_wake waiters. For requeue_pi, if we acquired the | 1270 | * Wake nr_wake waiters. For requeue_pi, if we acquired the |
| @@ -1273,7 +1289,7 @@ retry_private: | |||
| 1273 | this->task, 1); | 1289 | this->task, 1); |
| 1274 | if (ret == 1) { | 1290 | if (ret == 1) { |
| 1275 | /* We got the lock. */ | 1291 | /* We got the lock. */ |
| 1276 | requeue_pi_wake_futex(this, &key2); | 1292 | requeue_pi_wake_futex(this, &key2, hb2); |
| 1277 | continue; | 1293 | continue; |
| 1278 | } else if (ret) { | 1294 | } else if (ret) { |
| 1279 | /* -EDEADLK */ | 1295 | /* -EDEADLK */ |
diff --git a/kernel/futex_compat.c b/kernel/futex_compat.c index d607a5b9ee29..235716556bf1 100644 --- a/kernel/futex_compat.c +++ b/kernel/futex_compat.c | |||
| @@ -180,7 +180,8 @@ asmlinkage long compat_sys_futex(u32 __user *uaddr, int op, u32 val, | |||
| 180 | int cmd = op & FUTEX_CMD_MASK; | 180 | int cmd = op & FUTEX_CMD_MASK; |
| 181 | 181 | ||
| 182 | if (utime && (cmd == FUTEX_WAIT || cmd == FUTEX_LOCK_PI || | 182 | if (utime && (cmd == FUTEX_WAIT || cmd == FUTEX_LOCK_PI || |
| 183 | cmd == FUTEX_WAIT_BITSET)) { | 183 | cmd == FUTEX_WAIT_BITSET || |
| 184 | cmd == FUTEX_WAIT_REQUEUE_PI)) { | ||
| 184 | if (get_compat_timespec(&ts, utime)) | 185 | if (get_compat_timespec(&ts, utime)) |
| 185 | return -EFAULT; | 186 | return -EFAULT; |
| 186 | if (!timespec_valid(&ts)) | 187 | if (!timespec_valid(&ts)) |
| @@ -191,7 +192,8 @@ asmlinkage long compat_sys_futex(u32 __user *uaddr, int op, u32 val, | |||
| 191 | t = ktime_add_safe(ktime_get(), t); | 192 | t = ktime_add_safe(ktime_get(), t); |
| 192 | tp = &t; | 193 | tp = &t; |
| 193 | } | 194 | } |
| 194 | if (cmd == FUTEX_REQUEUE || cmd == FUTEX_CMP_REQUEUE) | 195 | if (cmd == FUTEX_REQUEUE || cmd == FUTEX_CMP_REQUEUE || |
| 196 | cmd == FUTEX_CMP_REQUEUE_PI || cmd == FUTEX_WAKE_OP) | ||
| 195 | val2 = (int) (unsigned long) utime; | 197 | val2 = (int) (unsigned long) utime; |
| 196 | 198 | ||
| 197 | return do_futex(uaddr, op, val, tp, uaddr2, val2, val3); | 199 | return do_futex(uaddr, op, val, tp, uaddr2, val2, val3); |
diff --git a/kernel/irq/internals.h b/kernel/irq/internals.h index 73468253143b..e70ed5592eb9 100644 --- a/kernel/irq/internals.h +++ b/kernel/irq/internals.h | |||
| @@ -42,8 +42,7 @@ static inline void unregister_handler_proc(unsigned int irq, | |||
| 42 | 42 | ||
| 43 | extern int irq_select_affinity_usr(unsigned int irq); | 43 | extern int irq_select_affinity_usr(unsigned int irq); |
| 44 | 44 | ||
| 45 | extern void | 45 | extern void irq_set_thread_affinity(struct irq_desc *desc); |
| 46 | irq_set_thread_affinity(struct irq_desc *desc, const struct cpumask *cpumask); | ||
| 47 | 46 | ||
| 48 | /* | 47 | /* |
| 49 | * Debugging printout: | 48 | * Debugging printout: |
diff --git a/kernel/irq/manage.c b/kernel/irq/manage.c index 50da67672901..0ec9ed831737 100644 --- a/kernel/irq/manage.c +++ b/kernel/irq/manage.c | |||
| @@ -80,14 +80,22 @@ int irq_can_set_affinity(unsigned int irq) | |||
| 80 | return 1; | 80 | return 1; |
| 81 | } | 81 | } |
| 82 | 82 | ||
| 83 | void | 83 | /** |
| 84 | irq_set_thread_affinity(struct irq_desc *desc, const struct cpumask *cpumask) | 84 | * irq_set_thread_affinity - Notify irq threads to adjust affinity |
| 85 | * @desc: irq descriptor which has affitnity changed | ||
| 86 | * | ||
| 87 | * We just set IRQTF_AFFINITY and delegate the affinity setting | ||
| 88 | * to the interrupt thread itself. We can not call | ||
| 89 | * set_cpus_allowed_ptr() here as we hold desc->lock and this | ||
| 90 | * code can be called from hard interrupt context. | ||
| 91 | */ | ||
| 92 | void irq_set_thread_affinity(struct irq_desc *desc) | ||
| 85 | { | 93 | { |
| 86 | struct irqaction *action = desc->action; | 94 | struct irqaction *action = desc->action; |
| 87 | 95 | ||
| 88 | while (action) { | 96 | while (action) { |
| 89 | if (action->thread) | 97 | if (action->thread) |
| 90 | set_cpus_allowed_ptr(action->thread, cpumask); | 98 | set_bit(IRQTF_AFFINITY, &action->thread_flags); |
| 91 | action = action->next; | 99 | action = action->next; |
| 92 | } | 100 | } |
| 93 | } | 101 | } |
| @@ -112,7 +120,7 @@ int irq_set_affinity(unsigned int irq, const struct cpumask *cpumask) | |||
| 112 | if (desc->status & IRQ_MOVE_PCNTXT) { | 120 | if (desc->status & IRQ_MOVE_PCNTXT) { |
| 113 | if (!desc->chip->set_affinity(irq, cpumask)) { | 121 | if (!desc->chip->set_affinity(irq, cpumask)) { |
| 114 | cpumask_copy(desc->affinity, cpumask); | 122 | cpumask_copy(desc->affinity, cpumask); |
| 115 | irq_set_thread_affinity(desc, cpumask); | 123 | irq_set_thread_affinity(desc); |
| 116 | } | 124 | } |
| 117 | } | 125 | } |
| 118 | else { | 126 | else { |
| @@ -122,7 +130,7 @@ int irq_set_affinity(unsigned int irq, const struct cpumask *cpumask) | |||
| 122 | #else | 130 | #else |
| 123 | if (!desc->chip->set_affinity(irq, cpumask)) { | 131 | if (!desc->chip->set_affinity(irq, cpumask)) { |
| 124 | cpumask_copy(desc->affinity, cpumask); | 132 | cpumask_copy(desc->affinity, cpumask); |
| 125 | irq_set_thread_affinity(desc, cpumask); | 133 | irq_set_thread_affinity(desc); |
| 126 | } | 134 | } |
| 127 | #endif | 135 | #endif |
| 128 | desc->status |= IRQ_AFFINITY_SET; | 136 | desc->status |= IRQ_AFFINITY_SET; |
| @@ -176,7 +184,7 @@ int irq_select_affinity_usr(unsigned int irq) | |||
| 176 | spin_lock_irqsave(&desc->lock, flags); | 184 | spin_lock_irqsave(&desc->lock, flags); |
| 177 | ret = setup_affinity(irq, desc); | 185 | ret = setup_affinity(irq, desc); |
| 178 | if (!ret) | 186 | if (!ret) |
| 179 | irq_set_thread_affinity(desc, desc->affinity); | 187 | irq_set_thread_affinity(desc); |
| 180 | spin_unlock_irqrestore(&desc->lock, flags); | 188 | spin_unlock_irqrestore(&desc->lock, flags); |
| 181 | 189 | ||
| 182 | return ret; | 190 | return ret; |
| @@ -443,6 +451,39 @@ static int irq_wait_for_interrupt(struct irqaction *action) | |||
| 443 | return -1; | 451 | return -1; |
| 444 | } | 452 | } |
| 445 | 453 | ||
| 454 | #ifdef CONFIG_SMP | ||
| 455 | /* | ||
| 456 | * Check whether we need to change the affinity of the interrupt thread. | ||
| 457 | */ | ||
| 458 | static void | ||
| 459 | irq_thread_check_affinity(struct irq_desc *desc, struct irqaction *action) | ||
| 460 | { | ||
| 461 | cpumask_var_t mask; | ||
| 462 | |||
| 463 | if (!test_and_clear_bit(IRQTF_AFFINITY, &action->thread_flags)) | ||
| 464 | return; | ||
| 465 | |||
| 466 | /* | ||
| 467 | * In case we are out of memory we set IRQTF_AFFINITY again and | ||
| 468 | * try again next time | ||
| 469 | */ | ||
| 470 | if (!alloc_cpumask_var(&mask, GFP_KERNEL)) { | ||
| 471 | set_bit(IRQTF_AFFINITY, &action->thread_flags); | ||
| 472 | return; | ||
| 473 | } | ||
| 474 | |||
| 475 | spin_lock_irq(&desc->lock); | ||
| 476 | cpumask_copy(mask, desc->affinity); | ||
| 477 | spin_unlock_irq(&desc->lock); | ||
| 478 | |||
| 479 | set_cpus_allowed_ptr(current, mask); | ||
| 480 | free_cpumask_var(mask); | ||
| 481 | } | ||
| 482 | #else | ||
| 483 | static inline void | ||
| 484 | irq_thread_check_affinity(struct irq_desc *desc, struct irqaction *action) { } | ||
| 485 | #endif | ||
| 486 | |||
| 446 | /* | 487 | /* |
| 447 | * Interrupt handler thread | 488 | * Interrupt handler thread |
| 448 | */ | 489 | */ |
| @@ -458,6 +499,8 @@ static int irq_thread(void *data) | |||
| 458 | 499 | ||
| 459 | while (!irq_wait_for_interrupt(action)) { | 500 | while (!irq_wait_for_interrupt(action)) { |
| 460 | 501 | ||
| 502 | irq_thread_check_affinity(desc, action); | ||
| 503 | |||
| 461 | atomic_inc(&desc->threads_active); | 504 | atomic_inc(&desc->threads_active); |
| 462 | 505 | ||
| 463 | spin_lock_irq(&desc->lock); | 506 | spin_lock_irq(&desc->lock); |
| @@ -564,7 +607,6 @@ __setup_irq(unsigned int irq, struct irq_desc *desc, struct irqaction *new) | |||
| 564 | */ | 607 | */ |
| 565 | get_task_struct(t); | 608 | get_task_struct(t); |
| 566 | new->thread = t; | 609 | new->thread = t; |
| 567 | wake_up_process(t); | ||
| 568 | } | 610 | } |
| 569 | 611 | ||
| 570 | /* | 612 | /* |
| @@ -647,6 +689,7 @@ __setup_irq(unsigned int irq, struct irq_desc *desc, struct irqaction *new) | |||
| 647 | (int)(new->flags & IRQF_TRIGGER_MASK)); | 689 | (int)(new->flags & IRQF_TRIGGER_MASK)); |
| 648 | } | 690 | } |
| 649 | 691 | ||
| 692 | new->irq = irq; | ||
| 650 | *old_ptr = new; | 693 | *old_ptr = new; |
| 651 | 694 | ||
| 652 | /* Reset broken irq detection when installing new handler */ | 695 | /* Reset broken irq detection when installing new handler */ |
| @@ -664,7 +707,13 @@ __setup_irq(unsigned int irq, struct irq_desc *desc, struct irqaction *new) | |||
| 664 | 707 | ||
| 665 | spin_unlock_irqrestore(&desc->lock, flags); | 708 | spin_unlock_irqrestore(&desc->lock, flags); |
| 666 | 709 | ||
| 667 | new->irq = irq; | 710 | /* |
| 711 | * Strictly no need to wake it up, but hung_task complains | ||
| 712 | * when no hard interrupt wakes the thread up. | ||
| 713 | */ | ||
| 714 | if (new->thread) | ||
| 715 | wake_up_process(new->thread); | ||
| 716 | |||
| 668 | register_irq_proc(irq, desc); | 717 | register_irq_proc(irq, desc); |
| 669 | new->dir = NULL; | 718 | new->dir = NULL; |
| 670 | register_handler_proc(irq, new); | 719 | register_handler_proc(irq, new); |
| @@ -718,7 +767,6 @@ static struct irqaction *__free_irq(unsigned int irq, void *dev_id) | |||
| 718 | { | 767 | { |
| 719 | struct irq_desc *desc = irq_to_desc(irq); | 768 | struct irq_desc *desc = irq_to_desc(irq); |
| 720 | struct irqaction *action, **action_ptr; | 769 | struct irqaction *action, **action_ptr; |
| 721 | struct task_struct *irqthread; | ||
| 722 | unsigned long flags; | 770 | unsigned long flags; |
| 723 | 771 | ||
| 724 | WARN(in_interrupt(), "Trying to free IRQ %d from IRQ context!\n", irq); | 772 | WARN(in_interrupt(), "Trying to free IRQ %d from IRQ context!\n", irq); |
| @@ -766,9 +814,6 @@ static struct irqaction *__free_irq(unsigned int irq, void *dev_id) | |||
| 766 | desc->chip->disable(irq); | 814 | desc->chip->disable(irq); |
| 767 | } | 815 | } |
| 768 | 816 | ||
| 769 | irqthread = action->thread; | ||
| 770 | action->thread = NULL; | ||
| 771 | |||
| 772 | spin_unlock_irqrestore(&desc->lock, flags); | 817 | spin_unlock_irqrestore(&desc->lock, flags); |
| 773 | 818 | ||
| 774 | unregister_handler_proc(irq, action); | 819 | unregister_handler_proc(irq, action); |
| @@ -776,12 +821,6 @@ static struct irqaction *__free_irq(unsigned int irq, void *dev_id) | |||
| 776 | /* Make sure it's not being used on another CPU: */ | 821 | /* Make sure it's not being used on another CPU: */ |
| 777 | synchronize_irq(irq); | 822 | synchronize_irq(irq); |
| 778 | 823 | ||
| 779 | if (irqthread) { | ||
| 780 | if (!test_bit(IRQTF_DIED, &action->thread_flags)) | ||
| 781 | kthread_stop(irqthread); | ||
| 782 | put_task_struct(irqthread); | ||
| 783 | } | ||
| 784 | |||
| 785 | #ifdef CONFIG_DEBUG_SHIRQ | 824 | #ifdef CONFIG_DEBUG_SHIRQ |
| 786 | /* | 825 | /* |
| 787 | * It's a shared IRQ -- the driver ought to be prepared for an IRQ | 826 | * It's a shared IRQ -- the driver ought to be prepared for an IRQ |
| @@ -797,6 +836,13 @@ static struct irqaction *__free_irq(unsigned int irq, void *dev_id) | |||
| 797 | local_irq_restore(flags); | 836 | local_irq_restore(flags); |
| 798 | } | 837 | } |
| 799 | #endif | 838 | #endif |
| 839 | |||
| 840 | if (action->thread) { | ||
| 841 | if (!test_bit(IRQTF_DIED, &action->thread_flags)) | ||
| 842 | kthread_stop(action->thread); | ||
| 843 | put_task_struct(action->thread); | ||
| 844 | } | ||
| 845 | |||
| 800 | return action; | 846 | return action; |
| 801 | } | 847 | } |
| 802 | 848 | ||
diff --git a/kernel/irq/migration.c b/kernel/irq/migration.c index cfe767ca1545..fcb6c96f2627 100644 --- a/kernel/irq/migration.c +++ b/kernel/irq/migration.c | |||
| @@ -45,7 +45,7 @@ void move_masked_irq(int irq) | |||
| 45 | < nr_cpu_ids)) | 45 | < nr_cpu_ids)) |
| 46 | if (!desc->chip->set_affinity(irq, desc->pending_mask)) { | 46 | if (!desc->chip->set_affinity(irq, desc->pending_mask)) { |
| 47 | cpumask_copy(desc->affinity, desc->pending_mask); | 47 | cpumask_copy(desc->affinity, desc->pending_mask); |
| 48 | irq_set_thread_affinity(desc, desc->pending_mask); | 48 | irq_set_thread_affinity(desc); |
| 49 | } | 49 | } |
| 50 | 50 | ||
| 51 | cpumask_clear(desc->pending_mask); | 51 | cpumask_clear(desc->pending_mask); |
diff --git a/kernel/irq/numa_migrate.c b/kernel/irq/numa_migrate.c index 2f69bee57bf2..3fd30197da2e 100644 --- a/kernel/irq/numa_migrate.c +++ b/kernel/irq/numa_migrate.c | |||
| @@ -107,8 +107,8 @@ out_unlock: | |||
| 107 | 107 | ||
| 108 | struct irq_desc *move_irq_desc(struct irq_desc *desc, int node) | 108 | struct irq_desc *move_irq_desc(struct irq_desc *desc, int node) |
| 109 | { | 109 | { |
| 110 | /* those all static, do move them */ | 110 | /* those static or target node is -1, do not move them */ |
| 111 | if (desc->irq < NR_IRQS_LEGACY) | 111 | if (desc->irq < NR_IRQS_LEGACY || node == -1) |
| 112 | return desc; | 112 | return desc; |
| 113 | 113 | ||
| 114 | if (desc->node != node) | 114 | if (desc->node != node) |
diff --git a/kernel/kexec.c b/kernel/kexec.c index ae1c35201cc8..f336e2107f98 100644 --- a/kernel/kexec.c +++ b/kernel/kexec.c | |||
| @@ -1228,7 +1228,7 @@ static int __init parse_crashkernel_mem(char *cmdline, | |||
| 1228 | } while (*cur++ == ','); | 1228 | } while (*cur++ == ','); |
| 1229 | 1229 | ||
| 1230 | if (*crash_size > 0) { | 1230 | if (*crash_size > 0) { |
| 1231 | while (*cur != ' ' && *cur != '@') | 1231 | while (*cur && *cur != ' ' && *cur != '@') |
| 1232 | cur++; | 1232 | cur++; |
| 1233 | if (*cur == '@') { | 1233 | if (*cur == '@') { |
| 1234 | cur++; | 1234 | cur++; |
diff --git a/kernel/kprobes.c b/kernel/kprobes.c index 16b5739c516a..0540948e29ab 100644 --- a/kernel/kprobes.c +++ b/kernel/kprobes.c | |||
| @@ -694,7 +694,7 @@ int __kprobes register_kprobe(struct kprobe *p) | |||
| 694 | p->addr = addr; | 694 | p->addr = addr; |
| 695 | 695 | ||
| 696 | preempt_disable(); | 696 | preempt_disable(); |
| 697 | if (!__kernel_text_address((unsigned long) p->addr) || | 697 | if (!kernel_text_address((unsigned long) p->addr) || |
| 698 | in_kprobes_functions((unsigned long) p->addr)) { | 698 | in_kprobes_functions((unsigned long) p->addr)) { |
| 699 | preempt_enable(); | 699 | preempt_enable(); |
| 700 | return -EINVAL; | 700 | return -EINVAL; |
diff --git a/kernel/kthread.c b/kernel/kthread.c index 9b1a7de26979..eb8751aa0418 100644 --- a/kernel/kthread.c +++ b/kernel/kthread.c | |||
| @@ -180,10 +180,12 @@ EXPORT_SYMBOL(kthread_bind); | |||
| 180 | * @k: thread created by kthread_create(). | 180 | * @k: thread created by kthread_create(). |
| 181 | * | 181 | * |
| 182 | * Sets kthread_should_stop() for @k to return true, wakes it, and | 182 | * Sets kthread_should_stop() for @k to return true, wakes it, and |
| 183 | * waits for it to exit. Your threadfn() must not call do_exit() | 183 | * waits for it to exit. This can also be called after kthread_create() |
| 184 | * itself if you use this function! This can also be called after | 184 | * instead of calling wake_up_process(): the thread will exit without |
| 185 | * kthread_create() instead of calling wake_up_process(): the thread | 185 | * calling threadfn(). |
| 186 | * will exit without calling threadfn(). | 186 | * |
| 187 | * If threadfn() may call do_exit() itself, the caller must ensure | ||
| 188 | * task_struct can't go away. | ||
| 187 | * | 189 | * |
| 188 | * Returns the result of threadfn(), or %-EINTR if wake_up_process() | 190 | * Returns the result of threadfn(), or %-EINTR if wake_up_process() |
| 189 | * was never called. | 191 | * was never called. |
diff --git a/kernel/lockdep_proc.c b/kernel/lockdep_proc.c index d7135aa2d2c4..e94caa666dba 100644 --- a/kernel/lockdep_proc.c +++ b/kernel/lockdep_proc.c | |||
| @@ -758,7 +758,8 @@ static int __init lockdep_proc_init(void) | |||
| 758 | &proc_lockdep_stats_operations); | 758 | &proc_lockdep_stats_operations); |
| 759 | 759 | ||
| 760 | #ifdef CONFIG_LOCK_STAT | 760 | #ifdef CONFIG_LOCK_STAT |
| 761 | proc_create("lock_stat", S_IRUSR, NULL, &proc_lock_stat_operations); | 761 | proc_create("lock_stat", S_IRUSR | S_IWUSR, NULL, |
| 762 | &proc_lock_stat_operations); | ||
| 762 | #endif | 763 | #endif |
| 763 | 764 | ||
| 764 | return 0; | 765 | return 0; |
diff --git a/kernel/module.c b/kernel/module.c index 0a049837008e..eccb561dd8a3 100644 --- a/kernel/module.c +++ b/kernel/module.c | |||
| @@ -909,16 +909,18 @@ void __symbol_put(const char *symbol) | |||
| 909 | } | 909 | } |
| 910 | EXPORT_SYMBOL(__symbol_put); | 910 | EXPORT_SYMBOL(__symbol_put); |
| 911 | 911 | ||
| 912 | /* Note this assumes addr is a function, which it currently always is. */ | ||
| 912 | void symbol_put_addr(void *addr) | 913 | void symbol_put_addr(void *addr) |
| 913 | { | 914 | { |
| 914 | struct module *modaddr; | 915 | struct module *modaddr; |
| 916 | unsigned long a = (unsigned long)dereference_function_descriptor(addr); | ||
| 915 | 917 | ||
| 916 | if (core_kernel_text((unsigned long)addr)) | 918 | if (core_kernel_text(a)) |
| 917 | return; | 919 | return; |
| 918 | 920 | ||
| 919 | /* module_text_address is safe here: we're supposed to have reference | 921 | /* module_text_address is safe here: we're supposed to have reference |
| 920 | * to module from symbol_get, so it can't go away. */ | 922 | * to module from symbol_get, so it can't go away. */ |
| 921 | modaddr = __module_text_address((unsigned long)addr); | 923 | modaddr = __module_text_address(a); |
| 922 | BUG_ON(!modaddr); | 924 | BUG_ON(!modaddr); |
| 923 | module_put(modaddr); | 925 | module_put(modaddr); |
| 924 | } | 926 | } |
| @@ -1068,7 +1070,8 @@ static inline int check_modstruct_version(Elf_Shdr *sechdrs, | |||
| 1068 | { | 1070 | { |
| 1069 | const unsigned long *crc; | 1071 | const unsigned long *crc; |
| 1070 | 1072 | ||
| 1071 | if (!find_symbol("module_layout", NULL, &crc, true, false)) | 1073 | if (!find_symbol(MODULE_SYMBOL_PREFIX "module_layout", NULL, |
| 1074 | &crc, true, false)) | ||
| 1072 | BUG(); | 1075 | BUG(); |
| 1073 | return check_version(sechdrs, versindex, "module_layout", mod, crc); | 1076 | return check_version(sechdrs, versindex, "module_layout", mod, crc); |
| 1074 | } | 1077 | } |
| @@ -2352,7 +2355,8 @@ static noinline struct module *load_module(void __user *umod, | |||
| 2352 | if (err < 0) | 2355 | if (err < 0) |
| 2353 | goto unlink; | 2356 | goto unlink; |
| 2354 | add_sect_attrs(mod, hdr->e_shnum, secstrings, sechdrs); | 2357 | add_sect_attrs(mod, hdr->e_shnum, secstrings, sechdrs); |
| 2355 | add_notes_attrs(mod, hdr->e_shnum, secstrings, sechdrs); | 2358 | if (mod->sect_attrs) |
| 2359 | add_notes_attrs(mod, hdr->e_shnum, secstrings, sechdrs); | ||
| 2356 | 2360 | ||
| 2357 | /* Get rid of temporary copy */ | 2361 | /* Get rid of temporary copy */ |
| 2358 | vfree(hdr); | 2362 | vfree(hdr); |
diff --git a/kernel/panic.c b/kernel/panic.c index 984b3ecbd72c..512ab73b0ca3 100644 --- a/kernel/panic.c +++ b/kernel/panic.c | |||
| @@ -301,6 +301,7 @@ int oops_may_print(void) | |||
| 301 | */ | 301 | */ |
| 302 | void oops_enter(void) | 302 | void oops_enter(void) |
| 303 | { | 303 | { |
| 304 | tracing_off(); | ||
| 304 | /* can't trust the integrity of the kernel anymore: */ | 305 | /* can't trust the integrity of the kernel anymore: */ |
| 305 | debug_locks_off(); | 306 | debug_locks_off(); |
| 306 | do_oops_enter_exit(); | 307 | do_oops_enter_exit(); |
diff --git a/kernel/perf_counter.c b/kernel/perf_counter.c index a641eb753b8c..f274e1959885 100644 --- a/kernel/perf_counter.c +++ b/kernel/perf_counter.c | |||
| @@ -42,6 +42,7 @@ static int perf_overcommit __read_mostly = 1; | |||
| 42 | static atomic_t nr_counters __read_mostly; | 42 | static atomic_t nr_counters __read_mostly; |
| 43 | static atomic_t nr_mmap_counters __read_mostly; | 43 | static atomic_t nr_mmap_counters __read_mostly; |
| 44 | static atomic_t nr_comm_counters __read_mostly; | 44 | static atomic_t nr_comm_counters __read_mostly; |
| 45 | static atomic_t nr_task_counters __read_mostly; | ||
| 45 | 46 | ||
| 46 | /* | 47 | /* |
| 47 | * perf counter paranoia level: | 48 | * perf counter paranoia level: |
| @@ -87,6 +88,7 @@ void __weak hw_perf_disable(void) { barrier(); } | |||
| 87 | void __weak hw_perf_enable(void) { barrier(); } | 88 | void __weak hw_perf_enable(void) { barrier(); } |
| 88 | 89 | ||
| 89 | void __weak hw_perf_counter_setup(int cpu) { barrier(); } | 90 | void __weak hw_perf_counter_setup(int cpu) { barrier(); } |
| 91 | void __weak hw_perf_counter_setup_online(int cpu) { barrier(); } | ||
| 90 | 92 | ||
| 91 | int __weak | 93 | int __weak |
| 92 | hw_perf_group_sched_in(struct perf_counter *group_leader, | 94 | hw_perf_group_sched_in(struct perf_counter *group_leader, |
| @@ -146,6 +148,28 @@ static void put_ctx(struct perf_counter_context *ctx) | |||
| 146 | } | 148 | } |
| 147 | } | 149 | } |
| 148 | 150 | ||
| 151 | static void unclone_ctx(struct perf_counter_context *ctx) | ||
| 152 | { | ||
| 153 | if (ctx->parent_ctx) { | ||
| 154 | put_ctx(ctx->parent_ctx); | ||
| 155 | ctx->parent_ctx = NULL; | ||
| 156 | } | ||
| 157 | } | ||
| 158 | |||
| 159 | /* | ||
| 160 | * If we inherit counters we want to return the parent counter id | ||
| 161 | * to userspace. | ||
| 162 | */ | ||
| 163 | static u64 primary_counter_id(struct perf_counter *counter) | ||
| 164 | { | ||
| 165 | u64 id = counter->id; | ||
| 166 | |||
| 167 | if (counter->parent) | ||
| 168 | id = counter->parent->id; | ||
| 169 | |||
| 170 | return id; | ||
| 171 | } | ||
| 172 | |||
| 149 | /* | 173 | /* |
| 150 | * Get the perf_counter_context for a task and lock it. | 174 | * Get the perf_counter_context for a task and lock it. |
| 151 | * This has to cope with with the fact that until it is locked, | 175 | * This has to cope with with the fact that until it is locked, |
| @@ -283,6 +307,10 @@ counter_sched_out(struct perf_counter *counter, | |||
| 283 | return; | 307 | return; |
| 284 | 308 | ||
| 285 | counter->state = PERF_COUNTER_STATE_INACTIVE; | 309 | counter->state = PERF_COUNTER_STATE_INACTIVE; |
| 310 | if (counter->pending_disable) { | ||
| 311 | counter->pending_disable = 0; | ||
| 312 | counter->state = PERF_COUNTER_STATE_OFF; | ||
| 313 | } | ||
| 286 | counter->tstamp_stopped = ctx->time; | 314 | counter->tstamp_stopped = ctx->time; |
| 287 | counter->pmu->disable(counter); | 315 | counter->pmu->disable(counter); |
| 288 | counter->oncpu = -1; | 316 | counter->oncpu = -1; |
| @@ -1081,7 +1109,7 @@ static void perf_counter_sync_stat(struct perf_counter_context *ctx, | |||
| 1081 | __perf_counter_sync_stat(counter, next_counter); | 1109 | __perf_counter_sync_stat(counter, next_counter); |
| 1082 | 1110 | ||
| 1083 | counter = list_next_entry(counter, event_entry); | 1111 | counter = list_next_entry(counter, event_entry); |
| 1084 | next_counter = list_next_entry(counter, event_entry); | 1112 | next_counter = list_next_entry(next_counter, event_entry); |
| 1085 | } | 1113 | } |
| 1086 | } | 1114 | } |
| 1087 | 1115 | ||
| @@ -1288,7 +1316,6 @@ static void perf_counter_cpu_sched_in(struct perf_cpu_context *cpuctx, int cpu) | |||
| 1288 | #define MAX_INTERRUPTS (~0ULL) | 1316 | #define MAX_INTERRUPTS (~0ULL) |
| 1289 | 1317 | ||
| 1290 | static void perf_log_throttle(struct perf_counter *counter, int enable); | 1318 | static void perf_log_throttle(struct perf_counter *counter, int enable); |
| 1291 | static void perf_log_period(struct perf_counter *counter, u64 period); | ||
| 1292 | 1319 | ||
| 1293 | static void perf_adjust_period(struct perf_counter *counter, u64 events) | 1320 | static void perf_adjust_period(struct perf_counter *counter, u64 events) |
| 1294 | { | 1321 | { |
| @@ -1307,8 +1334,6 @@ static void perf_adjust_period(struct perf_counter *counter, u64 events) | |||
| 1307 | if (!sample_period) | 1334 | if (!sample_period) |
| 1308 | sample_period = 1; | 1335 | sample_period = 1; |
| 1309 | 1336 | ||
| 1310 | perf_log_period(counter, sample_period); | ||
| 1311 | |||
| 1312 | hwc->sample_period = sample_period; | 1337 | hwc->sample_period = sample_period; |
| 1313 | } | 1338 | } |
| 1314 | 1339 | ||
| @@ -1463,10 +1488,8 @@ static void perf_counter_enable_on_exec(struct task_struct *task) | |||
| 1463 | /* | 1488 | /* |
| 1464 | * Unclone this context if we enabled any counter. | 1489 | * Unclone this context if we enabled any counter. |
| 1465 | */ | 1490 | */ |
| 1466 | if (enabled && ctx->parent_ctx) { | 1491 | if (enabled) |
| 1467 | put_ctx(ctx->parent_ctx); | 1492 | unclone_ctx(ctx); |
| 1468 | ctx->parent_ctx = NULL; | ||
| 1469 | } | ||
| 1470 | 1493 | ||
| 1471 | spin_unlock(&ctx->lock); | 1494 | spin_unlock(&ctx->lock); |
| 1472 | 1495 | ||
| @@ -1480,10 +1503,21 @@ static void perf_counter_enable_on_exec(struct task_struct *task) | |||
| 1480 | */ | 1503 | */ |
| 1481 | static void __perf_counter_read(void *info) | 1504 | static void __perf_counter_read(void *info) |
| 1482 | { | 1505 | { |
| 1506 | struct perf_cpu_context *cpuctx = &__get_cpu_var(perf_cpu_context); | ||
| 1483 | struct perf_counter *counter = info; | 1507 | struct perf_counter *counter = info; |
| 1484 | struct perf_counter_context *ctx = counter->ctx; | 1508 | struct perf_counter_context *ctx = counter->ctx; |
| 1485 | unsigned long flags; | 1509 | unsigned long flags; |
| 1486 | 1510 | ||
| 1511 | /* | ||
| 1512 | * If this is a task context, we need to check whether it is | ||
| 1513 | * the current task context of this cpu. If not it has been | ||
| 1514 | * scheduled out before the smp call arrived. In that case | ||
| 1515 | * counter->count would have been updated to a recent sample | ||
| 1516 | * when the counter was scheduled out. | ||
| 1517 | */ | ||
| 1518 | if (ctx->task && cpuctx->task_ctx != ctx) | ||
| 1519 | return; | ||
| 1520 | |||
| 1487 | local_irq_save(flags); | 1521 | local_irq_save(flags); |
| 1488 | if (ctx->is_active) | 1522 | if (ctx->is_active) |
| 1489 | update_context_time(ctx); | 1523 | update_context_time(ctx); |
| @@ -1526,7 +1560,6 @@ __perf_counter_init_context(struct perf_counter_context *ctx, | |||
| 1526 | 1560 | ||
| 1527 | static struct perf_counter_context *find_get_context(pid_t pid, int cpu) | 1561 | static struct perf_counter_context *find_get_context(pid_t pid, int cpu) |
| 1528 | { | 1562 | { |
| 1529 | struct perf_counter_context *parent_ctx; | ||
| 1530 | struct perf_counter_context *ctx; | 1563 | struct perf_counter_context *ctx; |
| 1531 | struct perf_cpu_context *cpuctx; | 1564 | struct perf_cpu_context *cpuctx; |
| 1532 | struct task_struct *task; | 1565 | struct task_struct *task; |
| @@ -1586,11 +1619,7 @@ static struct perf_counter_context *find_get_context(pid_t pid, int cpu) | |||
| 1586 | retry: | 1619 | retry: |
| 1587 | ctx = perf_lock_task_context(task, &flags); | 1620 | ctx = perf_lock_task_context(task, &flags); |
| 1588 | if (ctx) { | 1621 | if (ctx) { |
| 1589 | parent_ctx = ctx->parent_ctx; | 1622 | unclone_ctx(ctx); |
| 1590 | if (parent_ctx) { | ||
| 1591 | put_ctx(parent_ctx); | ||
| 1592 | ctx->parent_ctx = NULL; /* no longer a clone */ | ||
| 1593 | } | ||
| 1594 | spin_unlock_irqrestore(&ctx->lock, flags); | 1623 | spin_unlock_irqrestore(&ctx->lock, flags); |
| 1595 | } | 1624 | } |
| 1596 | 1625 | ||
| @@ -1642,6 +1671,8 @@ static void free_counter(struct perf_counter *counter) | |||
| 1642 | atomic_dec(&nr_mmap_counters); | 1671 | atomic_dec(&nr_mmap_counters); |
| 1643 | if (counter->attr.comm) | 1672 | if (counter->attr.comm) |
| 1644 | atomic_dec(&nr_comm_counters); | 1673 | atomic_dec(&nr_comm_counters); |
| 1674 | if (counter->attr.task) | ||
| 1675 | atomic_dec(&nr_task_counters); | ||
| 1645 | } | 1676 | } |
| 1646 | 1677 | ||
| 1647 | if (counter->destroy) | 1678 | if (counter->destroy) |
| @@ -1676,14 +1707,133 @@ static int perf_release(struct inode *inode, struct file *file) | |||
| 1676 | return 0; | 1707 | return 0; |
| 1677 | } | 1708 | } |
| 1678 | 1709 | ||
| 1710 | static int perf_counter_read_size(struct perf_counter *counter) | ||
| 1711 | { | ||
| 1712 | int entry = sizeof(u64); /* value */ | ||
| 1713 | int size = 0; | ||
| 1714 | int nr = 1; | ||
| 1715 | |||
| 1716 | if (counter->attr.read_format & PERF_FORMAT_TOTAL_TIME_ENABLED) | ||
| 1717 | size += sizeof(u64); | ||
| 1718 | |||
| 1719 | if (counter->attr.read_format & PERF_FORMAT_TOTAL_TIME_RUNNING) | ||
| 1720 | size += sizeof(u64); | ||
| 1721 | |||
| 1722 | if (counter->attr.read_format & PERF_FORMAT_ID) | ||
| 1723 | entry += sizeof(u64); | ||
| 1724 | |||
| 1725 | if (counter->attr.read_format & PERF_FORMAT_GROUP) { | ||
| 1726 | nr += counter->group_leader->nr_siblings; | ||
| 1727 | size += sizeof(u64); | ||
| 1728 | } | ||
| 1729 | |||
| 1730 | size += entry * nr; | ||
| 1731 | |||
| 1732 | return size; | ||
| 1733 | } | ||
| 1734 | |||
| 1735 | static u64 perf_counter_read_value(struct perf_counter *counter) | ||
| 1736 | { | ||
| 1737 | struct perf_counter *child; | ||
| 1738 | u64 total = 0; | ||
| 1739 | |||
| 1740 | total += perf_counter_read(counter); | ||
| 1741 | list_for_each_entry(child, &counter->child_list, child_list) | ||
| 1742 | total += perf_counter_read(child); | ||
| 1743 | |||
| 1744 | return total; | ||
| 1745 | } | ||
| 1746 | |||
| 1747 | static int perf_counter_read_entry(struct perf_counter *counter, | ||
| 1748 | u64 read_format, char __user *buf) | ||
| 1749 | { | ||
| 1750 | int n = 0, count = 0; | ||
| 1751 | u64 values[2]; | ||
| 1752 | |||
| 1753 | values[n++] = perf_counter_read_value(counter); | ||
| 1754 | if (read_format & PERF_FORMAT_ID) | ||
| 1755 | values[n++] = primary_counter_id(counter); | ||
| 1756 | |||
| 1757 | count = n * sizeof(u64); | ||
| 1758 | |||
| 1759 | if (copy_to_user(buf, values, count)) | ||
| 1760 | return -EFAULT; | ||
| 1761 | |||
| 1762 | return count; | ||
| 1763 | } | ||
| 1764 | |||
| 1765 | static int perf_counter_read_group(struct perf_counter *counter, | ||
| 1766 | u64 read_format, char __user *buf) | ||
| 1767 | { | ||
| 1768 | struct perf_counter *leader = counter->group_leader, *sub; | ||
| 1769 | int n = 0, size = 0, err = -EFAULT; | ||
| 1770 | u64 values[3]; | ||
| 1771 | |||
| 1772 | values[n++] = 1 + leader->nr_siblings; | ||
| 1773 | if (read_format & PERF_FORMAT_TOTAL_TIME_ENABLED) { | ||
| 1774 | values[n++] = leader->total_time_enabled + | ||
| 1775 | atomic64_read(&leader->child_total_time_enabled); | ||
| 1776 | } | ||
| 1777 | if (read_format & PERF_FORMAT_TOTAL_TIME_RUNNING) { | ||
| 1778 | values[n++] = leader->total_time_running + | ||
| 1779 | atomic64_read(&leader->child_total_time_running); | ||
| 1780 | } | ||
| 1781 | |||
| 1782 | size = n * sizeof(u64); | ||
| 1783 | |||
| 1784 | if (copy_to_user(buf, values, size)) | ||
| 1785 | return -EFAULT; | ||
| 1786 | |||
| 1787 | err = perf_counter_read_entry(leader, read_format, buf + size); | ||
| 1788 | if (err < 0) | ||
| 1789 | return err; | ||
| 1790 | |||
| 1791 | size += err; | ||
| 1792 | |||
| 1793 | list_for_each_entry(sub, &leader->sibling_list, list_entry) { | ||
| 1794 | err = perf_counter_read_entry(sub, read_format, | ||
| 1795 | buf + size); | ||
| 1796 | if (err < 0) | ||
| 1797 | return err; | ||
| 1798 | |||
| 1799 | size += err; | ||
| 1800 | } | ||
| 1801 | |||
| 1802 | return size; | ||
| 1803 | } | ||
| 1804 | |||
| 1805 | static int perf_counter_read_one(struct perf_counter *counter, | ||
| 1806 | u64 read_format, char __user *buf) | ||
| 1807 | { | ||
| 1808 | u64 values[4]; | ||
| 1809 | int n = 0; | ||
| 1810 | |||
| 1811 | values[n++] = perf_counter_read_value(counter); | ||
| 1812 | if (read_format & PERF_FORMAT_TOTAL_TIME_ENABLED) { | ||
| 1813 | values[n++] = counter->total_time_enabled + | ||
| 1814 | atomic64_read(&counter->child_total_time_enabled); | ||
| 1815 | } | ||
| 1816 | if (read_format & PERF_FORMAT_TOTAL_TIME_RUNNING) { | ||
| 1817 | values[n++] = counter->total_time_running + | ||
| 1818 | atomic64_read(&counter->child_total_time_running); | ||
| 1819 | } | ||
| 1820 | if (read_format & PERF_FORMAT_ID) | ||
| 1821 | values[n++] = primary_counter_id(counter); | ||
| 1822 | |||
| 1823 | if (copy_to_user(buf, values, n * sizeof(u64))) | ||
| 1824 | return -EFAULT; | ||
| 1825 | |||
| 1826 | return n * sizeof(u64); | ||
| 1827 | } | ||
| 1828 | |||
| 1679 | /* | 1829 | /* |
| 1680 | * Read the performance counter - simple non blocking version for now | 1830 | * Read the performance counter - simple non blocking version for now |
| 1681 | */ | 1831 | */ |
| 1682 | static ssize_t | 1832 | static ssize_t |
| 1683 | perf_read_hw(struct perf_counter *counter, char __user *buf, size_t count) | 1833 | perf_read_hw(struct perf_counter *counter, char __user *buf, size_t count) |
| 1684 | { | 1834 | { |
| 1685 | u64 values[4]; | 1835 | u64 read_format = counter->attr.read_format; |
| 1686 | int n; | 1836 | int ret; |
| 1687 | 1837 | ||
| 1688 | /* | 1838 | /* |
| 1689 | * Return end-of-file for a read on a counter that is in | 1839 | * Return end-of-file for a read on a counter that is in |
| @@ -1693,28 +1843,18 @@ perf_read_hw(struct perf_counter *counter, char __user *buf, size_t count) | |||
| 1693 | if (counter->state == PERF_COUNTER_STATE_ERROR) | 1843 | if (counter->state == PERF_COUNTER_STATE_ERROR) |
| 1694 | return 0; | 1844 | return 0; |
| 1695 | 1845 | ||
| 1846 | if (count < perf_counter_read_size(counter)) | ||
| 1847 | return -ENOSPC; | ||
| 1848 | |||
| 1696 | WARN_ON_ONCE(counter->ctx->parent_ctx); | 1849 | WARN_ON_ONCE(counter->ctx->parent_ctx); |
| 1697 | mutex_lock(&counter->child_mutex); | 1850 | mutex_lock(&counter->child_mutex); |
| 1698 | values[0] = perf_counter_read(counter); | 1851 | if (read_format & PERF_FORMAT_GROUP) |
| 1699 | n = 1; | 1852 | ret = perf_counter_read_group(counter, read_format, buf); |
| 1700 | if (counter->attr.read_format & PERF_FORMAT_TOTAL_TIME_ENABLED) | 1853 | else |
| 1701 | values[n++] = counter->total_time_enabled + | 1854 | ret = perf_counter_read_one(counter, read_format, buf); |
| 1702 | atomic64_read(&counter->child_total_time_enabled); | ||
| 1703 | if (counter->attr.read_format & PERF_FORMAT_TOTAL_TIME_RUNNING) | ||
| 1704 | values[n++] = counter->total_time_running + | ||
| 1705 | atomic64_read(&counter->child_total_time_running); | ||
| 1706 | if (counter->attr.read_format & PERF_FORMAT_ID) | ||
| 1707 | values[n++] = counter->id; | ||
| 1708 | mutex_unlock(&counter->child_mutex); | 1855 | mutex_unlock(&counter->child_mutex); |
| 1709 | 1856 | ||
| 1710 | if (count < n * sizeof(u64)) | 1857 | return ret; |
| 1711 | return -EINVAL; | ||
| 1712 | count = n * sizeof(u64); | ||
| 1713 | |||
| 1714 | if (copy_to_user(buf, values, count)) | ||
| 1715 | return -EFAULT; | ||
| 1716 | |||
| 1717 | return count; | ||
| 1718 | } | 1858 | } |
| 1719 | 1859 | ||
| 1720 | static ssize_t | 1860 | static ssize_t |
| @@ -1811,8 +1951,6 @@ static int perf_counter_period(struct perf_counter *counter, u64 __user *arg) | |||
| 1811 | 1951 | ||
| 1812 | counter->attr.sample_freq = value; | 1952 | counter->attr.sample_freq = value; |
| 1813 | } else { | 1953 | } else { |
| 1814 | perf_log_period(counter, value); | ||
| 1815 | |||
| 1816 | counter->attr.sample_period = value; | 1954 | counter->attr.sample_period = value; |
| 1817 | counter->hw.sample_period = value; | 1955 | counter->hw.sample_period = value; |
| 1818 | } | 1956 | } |
| @@ -1881,6 +2019,10 @@ int perf_counter_task_disable(void) | |||
| 1881 | return 0; | 2019 | return 0; |
| 1882 | } | 2020 | } |
| 1883 | 2021 | ||
| 2022 | #ifndef PERF_COUNTER_INDEX_OFFSET | ||
| 2023 | # define PERF_COUNTER_INDEX_OFFSET 0 | ||
| 2024 | #endif | ||
| 2025 | |||
| 1884 | static int perf_counter_index(struct perf_counter *counter) | 2026 | static int perf_counter_index(struct perf_counter *counter) |
| 1885 | { | 2027 | { |
| 1886 | if (counter->state != PERF_COUNTER_STATE_ACTIVE) | 2028 | if (counter->state != PERF_COUNTER_STATE_ACTIVE) |
| @@ -2220,7 +2362,7 @@ static void perf_pending_counter(struct perf_pending_entry *entry) | |||
| 2220 | 2362 | ||
| 2221 | if (counter->pending_disable) { | 2363 | if (counter->pending_disable) { |
| 2222 | counter->pending_disable = 0; | 2364 | counter->pending_disable = 0; |
| 2223 | perf_counter_disable(counter); | 2365 | __perf_counter_disable(counter); |
| 2224 | } | 2366 | } |
| 2225 | 2367 | ||
| 2226 | if (counter->pending_wakeup) { | 2368 | if (counter->pending_wakeup) { |
| @@ -2605,7 +2747,80 @@ static u32 perf_counter_tid(struct perf_counter *counter, struct task_struct *p) | |||
| 2605 | return task_pid_nr_ns(p, counter->ns); | 2747 | return task_pid_nr_ns(p, counter->ns); |
| 2606 | } | 2748 | } |
| 2607 | 2749 | ||
| 2608 | static void perf_counter_output(struct perf_counter *counter, int nmi, | 2750 | static void perf_output_read_one(struct perf_output_handle *handle, |
| 2751 | struct perf_counter *counter) | ||
| 2752 | { | ||
| 2753 | u64 read_format = counter->attr.read_format; | ||
| 2754 | u64 values[4]; | ||
| 2755 | int n = 0; | ||
| 2756 | |||
| 2757 | values[n++] = atomic64_read(&counter->count); | ||
| 2758 | if (read_format & PERF_FORMAT_TOTAL_TIME_ENABLED) { | ||
| 2759 | values[n++] = counter->total_time_enabled + | ||
| 2760 | atomic64_read(&counter->child_total_time_enabled); | ||
| 2761 | } | ||
| 2762 | if (read_format & PERF_FORMAT_TOTAL_TIME_RUNNING) { | ||
| 2763 | values[n++] = counter->total_time_running + | ||
| 2764 | atomic64_read(&counter->child_total_time_running); | ||
| 2765 | } | ||
| 2766 | if (read_format & PERF_FORMAT_ID) | ||
| 2767 | values[n++] = primary_counter_id(counter); | ||
| 2768 | |||
| 2769 | perf_output_copy(handle, values, n * sizeof(u64)); | ||
| 2770 | } | ||
| 2771 | |||
| 2772 | /* | ||
| 2773 | * XXX PERF_FORMAT_GROUP vs inherited counters seems difficult. | ||
| 2774 | */ | ||
| 2775 | static void perf_output_read_group(struct perf_output_handle *handle, | ||
| 2776 | struct perf_counter *counter) | ||
| 2777 | { | ||
| 2778 | struct perf_counter *leader = counter->group_leader, *sub; | ||
| 2779 | u64 read_format = counter->attr.read_format; | ||
| 2780 | u64 values[5]; | ||
| 2781 | int n = 0; | ||
| 2782 | |||
| 2783 | values[n++] = 1 + leader->nr_siblings; | ||
| 2784 | |||
| 2785 | if (read_format & PERF_FORMAT_TOTAL_TIME_ENABLED) | ||
| 2786 | values[n++] = leader->total_time_enabled; | ||
| 2787 | |||
| 2788 | if (read_format & PERF_FORMAT_TOTAL_TIME_RUNNING) | ||
| 2789 | values[n++] = leader->total_time_running; | ||
| 2790 | |||
| 2791 | if (leader != counter) | ||
| 2792 | leader->pmu->read(leader); | ||
| 2793 | |||
| 2794 | values[n++] = atomic64_read(&leader->count); | ||
| 2795 | if (read_format & PERF_FORMAT_ID) | ||
| 2796 | values[n++] = primary_counter_id(leader); | ||
| 2797 | |||
| 2798 | perf_output_copy(handle, values, n * sizeof(u64)); | ||
| 2799 | |||
| 2800 | list_for_each_entry(sub, &leader->sibling_list, list_entry) { | ||
| 2801 | n = 0; | ||
| 2802 | |||
| 2803 | if (sub != counter) | ||
| 2804 | sub->pmu->read(sub); | ||
| 2805 | |||
| 2806 | values[n++] = atomic64_read(&sub->count); | ||
| 2807 | if (read_format & PERF_FORMAT_ID) | ||
| 2808 | values[n++] = primary_counter_id(sub); | ||
| 2809 | |||
| 2810 | perf_output_copy(handle, values, n * sizeof(u64)); | ||
| 2811 | } | ||
| 2812 | } | ||
| 2813 | |||
| 2814 | static void perf_output_read(struct perf_output_handle *handle, | ||
| 2815 | struct perf_counter *counter) | ||
| 2816 | { | ||
| 2817 | if (counter->attr.read_format & PERF_FORMAT_GROUP) | ||
| 2818 | perf_output_read_group(handle, counter); | ||
| 2819 | else | ||
| 2820 | perf_output_read_one(handle, counter); | ||
| 2821 | } | ||
| 2822 | |||
| 2823 | void perf_counter_output(struct perf_counter *counter, int nmi, | ||
| 2609 | struct perf_sample_data *data) | 2824 | struct perf_sample_data *data) |
| 2610 | { | 2825 | { |
| 2611 | int ret; | 2826 | int ret; |
| @@ -2616,10 +2831,6 @@ static void perf_counter_output(struct perf_counter *counter, int nmi, | |||
| 2616 | struct { | 2831 | struct { |
| 2617 | u32 pid, tid; | 2832 | u32 pid, tid; |
| 2618 | } tid_entry; | 2833 | } tid_entry; |
| 2619 | struct { | ||
| 2620 | u64 id; | ||
| 2621 | u64 counter; | ||
| 2622 | } group_entry; | ||
| 2623 | struct perf_callchain_entry *callchain = NULL; | 2834 | struct perf_callchain_entry *callchain = NULL; |
| 2624 | int callchain_size = 0; | 2835 | int callchain_size = 0; |
| 2625 | u64 time; | 2836 | u64 time; |
| @@ -2661,19 +2872,21 @@ static void perf_counter_output(struct perf_counter *counter, int nmi, | |||
| 2661 | if (sample_type & PERF_SAMPLE_ID) | 2872 | if (sample_type & PERF_SAMPLE_ID) |
| 2662 | header.size += sizeof(u64); | 2873 | header.size += sizeof(u64); |
| 2663 | 2874 | ||
| 2875 | if (sample_type & PERF_SAMPLE_STREAM_ID) | ||
| 2876 | header.size += sizeof(u64); | ||
| 2877 | |||
| 2664 | if (sample_type & PERF_SAMPLE_CPU) { | 2878 | if (sample_type & PERF_SAMPLE_CPU) { |
| 2665 | header.size += sizeof(cpu_entry); | 2879 | header.size += sizeof(cpu_entry); |
| 2666 | 2880 | ||
| 2667 | cpu_entry.cpu = raw_smp_processor_id(); | 2881 | cpu_entry.cpu = raw_smp_processor_id(); |
| 2882 | cpu_entry.reserved = 0; | ||
| 2668 | } | 2883 | } |
| 2669 | 2884 | ||
| 2670 | if (sample_type & PERF_SAMPLE_PERIOD) | 2885 | if (sample_type & PERF_SAMPLE_PERIOD) |
| 2671 | header.size += sizeof(u64); | 2886 | header.size += sizeof(u64); |
| 2672 | 2887 | ||
| 2673 | if (sample_type & PERF_SAMPLE_GROUP) { | 2888 | if (sample_type & PERF_SAMPLE_READ) |
| 2674 | header.size += sizeof(u64) + | 2889 | header.size += perf_counter_read_size(counter); |
| 2675 | counter->nr_siblings * sizeof(group_entry); | ||
| 2676 | } | ||
| 2677 | 2890 | ||
| 2678 | if (sample_type & PERF_SAMPLE_CALLCHAIN) { | 2891 | if (sample_type & PERF_SAMPLE_CALLCHAIN) { |
| 2679 | callchain = perf_callchain(data->regs); | 2892 | callchain = perf_callchain(data->regs); |
| @@ -2685,6 +2898,18 @@ static void perf_counter_output(struct perf_counter *counter, int nmi, | |||
| 2685 | header.size += sizeof(u64); | 2898 | header.size += sizeof(u64); |
| 2686 | } | 2899 | } |
| 2687 | 2900 | ||
| 2901 | if (sample_type & PERF_SAMPLE_RAW) { | ||
| 2902 | int size = sizeof(u32); | ||
| 2903 | |||
| 2904 | if (data->raw) | ||
| 2905 | size += data->raw->size; | ||
| 2906 | else | ||
| 2907 | size += sizeof(u32); | ||
| 2908 | |||
| 2909 | WARN_ON_ONCE(size & (sizeof(u64)-1)); | ||
| 2910 | header.size += size; | ||
| 2911 | } | ||
| 2912 | |||
| 2688 | ret = perf_output_begin(&handle, counter, header.size, nmi, 1); | 2913 | ret = perf_output_begin(&handle, counter, header.size, nmi, 1); |
| 2689 | if (ret) | 2914 | if (ret) |
| 2690 | return; | 2915 | return; |
| @@ -2703,7 +2928,13 @@ static void perf_counter_output(struct perf_counter *counter, int nmi, | |||
| 2703 | if (sample_type & PERF_SAMPLE_ADDR) | 2928 | if (sample_type & PERF_SAMPLE_ADDR) |
| 2704 | perf_output_put(&handle, data->addr); | 2929 | perf_output_put(&handle, data->addr); |
| 2705 | 2930 | ||
| 2706 | if (sample_type & PERF_SAMPLE_ID) | 2931 | if (sample_type & PERF_SAMPLE_ID) { |
| 2932 | u64 id = primary_counter_id(counter); | ||
| 2933 | |||
| 2934 | perf_output_put(&handle, id); | ||
| 2935 | } | ||
| 2936 | |||
| 2937 | if (sample_type & PERF_SAMPLE_STREAM_ID) | ||
| 2707 | perf_output_put(&handle, counter->id); | 2938 | perf_output_put(&handle, counter->id); |
| 2708 | 2939 | ||
| 2709 | if (sample_type & PERF_SAMPLE_CPU) | 2940 | if (sample_type & PERF_SAMPLE_CPU) |
| @@ -2712,26 +2943,8 @@ static void perf_counter_output(struct perf_counter *counter, int nmi, | |||
| 2712 | if (sample_type & PERF_SAMPLE_PERIOD) | 2943 | if (sample_type & PERF_SAMPLE_PERIOD) |
| 2713 | perf_output_put(&handle, data->period); | 2944 | perf_output_put(&handle, data->period); |
| 2714 | 2945 | ||
| 2715 | /* | 2946 | if (sample_type & PERF_SAMPLE_READ) |
| 2716 | * XXX PERF_SAMPLE_GROUP vs inherited counters seems difficult. | 2947 | perf_output_read(&handle, counter); |
| 2717 | */ | ||
| 2718 | if (sample_type & PERF_SAMPLE_GROUP) { | ||
| 2719 | struct perf_counter *leader, *sub; | ||
| 2720 | u64 nr = counter->nr_siblings; | ||
| 2721 | |||
| 2722 | perf_output_put(&handle, nr); | ||
| 2723 | |||
| 2724 | leader = counter->group_leader; | ||
| 2725 | list_for_each_entry(sub, &leader->sibling_list, list_entry) { | ||
| 2726 | if (sub != counter) | ||
| 2727 | sub->pmu->read(sub); | ||
| 2728 | |||
| 2729 | group_entry.id = sub->id; | ||
| 2730 | group_entry.counter = atomic64_read(&sub->count); | ||
| 2731 | |||
| 2732 | perf_output_put(&handle, group_entry); | ||
| 2733 | } | ||
| 2734 | } | ||
| 2735 | 2948 | ||
| 2736 | if (sample_type & PERF_SAMPLE_CALLCHAIN) { | 2949 | if (sample_type & PERF_SAMPLE_CALLCHAIN) { |
| 2737 | if (callchain) | 2950 | if (callchain) |
| @@ -2742,6 +2955,22 @@ static void perf_counter_output(struct perf_counter *counter, int nmi, | |||
| 2742 | } | 2955 | } |
| 2743 | } | 2956 | } |
| 2744 | 2957 | ||
| 2958 | if (sample_type & PERF_SAMPLE_RAW) { | ||
| 2959 | if (data->raw) { | ||
| 2960 | perf_output_put(&handle, data->raw->size); | ||
| 2961 | perf_output_copy(&handle, data->raw->data, data->raw->size); | ||
| 2962 | } else { | ||
| 2963 | struct { | ||
| 2964 | u32 size; | ||
| 2965 | u32 data; | ||
| 2966 | } raw = { | ||
| 2967 | .size = sizeof(u32), | ||
| 2968 | .data = 0, | ||
| 2969 | }; | ||
| 2970 | perf_output_put(&handle, raw); | ||
| 2971 | } | ||
| 2972 | } | ||
| 2973 | |||
| 2745 | perf_output_end(&handle); | 2974 | perf_output_end(&handle); |
| 2746 | } | 2975 | } |
| 2747 | 2976 | ||
| @@ -2754,8 +2983,6 @@ struct perf_read_event { | |||
| 2754 | 2983 | ||
| 2755 | u32 pid; | 2984 | u32 pid; |
| 2756 | u32 tid; | 2985 | u32 tid; |
| 2757 | u64 value; | ||
| 2758 | u64 format[3]; | ||
| 2759 | }; | 2986 | }; |
| 2760 | 2987 | ||
| 2761 | static void | 2988 | static void |
| @@ -2767,87 +2994,74 @@ perf_counter_read_event(struct perf_counter *counter, | |||
| 2767 | .header = { | 2994 | .header = { |
| 2768 | .type = PERF_EVENT_READ, | 2995 | .type = PERF_EVENT_READ, |
| 2769 | .misc = 0, | 2996 | .misc = 0, |
| 2770 | .size = sizeof(event) - sizeof(event.format), | 2997 | .size = sizeof(event) + perf_counter_read_size(counter), |
| 2771 | }, | 2998 | }, |
| 2772 | .pid = perf_counter_pid(counter, task), | 2999 | .pid = perf_counter_pid(counter, task), |
| 2773 | .tid = perf_counter_tid(counter, task), | 3000 | .tid = perf_counter_tid(counter, task), |
| 2774 | .value = atomic64_read(&counter->count), | ||
| 2775 | }; | 3001 | }; |
| 2776 | int ret, i = 0; | 3002 | int ret; |
| 2777 | |||
| 2778 | if (counter->attr.read_format & PERF_FORMAT_TOTAL_TIME_ENABLED) { | ||
| 2779 | event.header.size += sizeof(u64); | ||
| 2780 | event.format[i++] = counter->total_time_enabled; | ||
| 2781 | } | ||
| 2782 | |||
| 2783 | if (counter->attr.read_format & PERF_FORMAT_TOTAL_TIME_RUNNING) { | ||
| 2784 | event.header.size += sizeof(u64); | ||
| 2785 | event.format[i++] = counter->total_time_running; | ||
| 2786 | } | ||
| 2787 | |||
| 2788 | if (counter->attr.read_format & PERF_FORMAT_ID) { | ||
| 2789 | u64 id; | ||
| 2790 | |||
| 2791 | event.header.size += sizeof(u64); | ||
| 2792 | if (counter->parent) | ||
| 2793 | id = counter->parent->id; | ||
| 2794 | else | ||
| 2795 | id = counter->id; | ||
| 2796 | |||
| 2797 | event.format[i++] = id; | ||
| 2798 | } | ||
| 2799 | 3003 | ||
| 2800 | ret = perf_output_begin(&handle, counter, event.header.size, 0, 0); | 3004 | ret = perf_output_begin(&handle, counter, event.header.size, 0, 0); |
| 2801 | if (ret) | 3005 | if (ret) |
| 2802 | return; | 3006 | return; |
| 2803 | 3007 | ||
| 2804 | perf_output_copy(&handle, &event, event.header.size); | 3008 | perf_output_put(&handle, event); |
| 3009 | perf_output_read(&handle, counter); | ||
| 3010 | |||
| 2805 | perf_output_end(&handle); | 3011 | perf_output_end(&handle); |
| 2806 | } | 3012 | } |
| 2807 | 3013 | ||
| 2808 | /* | 3014 | /* |
| 2809 | * fork tracking | 3015 | * task tracking -- fork/exit |
| 3016 | * | ||
| 3017 | * enabled by: attr.comm | attr.mmap | attr.task | ||
| 2810 | */ | 3018 | */ |
| 2811 | 3019 | ||
| 2812 | struct perf_fork_event { | 3020 | struct perf_task_event { |
| 2813 | struct task_struct *task; | 3021 | struct task_struct *task; |
| 3022 | struct perf_counter_context *task_ctx; | ||
| 2814 | 3023 | ||
| 2815 | struct { | 3024 | struct { |
| 2816 | struct perf_event_header header; | 3025 | struct perf_event_header header; |
| 2817 | 3026 | ||
| 2818 | u32 pid; | 3027 | u32 pid; |
| 2819 | u32 ppid; | 3028 | u32 ppid; |
| 3029 | u32 tid; | ||
| 3030 | u32 ptid; | ||
| 2820 | } event; | 3031 | } event; |
| 2821 | }; | 3032 | }; |
| 2822 | 3033 | ||
| 2823 | static void perf_counter_fork_output(struct perf_counter *counter, | 3034 | static void perf_counter_task_output(struct perf_counter *counter, |
| 2824 | struct perf_fork_event *fork_event) | 3035 | struct perf_task_event *task_event) |
| 2825 | { | 3036 | { |
| 2826 | struct perf_output_handle handle; | 3037 | struct perf_output_handle handle; |
| 2827 | int size = fork_event->event.header.size; | 3038 | int size = task_event->event.header.size; |
| 2828 | struct task_struct *task = fork_event->task; | 3039 | struct task_struct *task = task_event->task; |
| 2829 | int ret = perf_output_begin(&handle, counter, size, 0, 0); | 3040 | int ret = perf_output_begin(&handle, counter, size, 0, 0); |
| 2830 | 3041 | ||
| 2831 | if (ret) | 3042 | if (ret) |
| 2832 | return; | 3043 | return; |
| 2833 | 3044 | ||
| 2834 | fork_event->event.pid = perf_counter_pid(counter, task); | 3045 | task_event->event.pid = perf_counter_pid(counter, task); |
| 2835 | fork_event->event.ppid = perf_counter_pid(counter, task->real_parent); | 3046 | task_event->event.ppid = perf_counter_pid(counter, current); |
| 2836 | 3047 | ||
| 2837 | perf_output_put(&handle, fork_event->event); | 3048 | task_event->event.tid = perf_counter_tid(counter, task); |
| 3049 | task_event->event.ptid = perf_counter_tid(counter, current); | ||
| 3050 | |||
| 3051 | perf_output_put(&handle, task_event->event); | ||
| 2838 | perf_output_end(&handle); | 3052 | perf_output_end(&handle); |
| 2839 | } | 3053 | } |
| 2840 | 3054 | ||
| 2841 | static int perf_counter_fork_match(struct perf_counter *counter) | 3055 | static int perf_counter_task_match(struct perf_counter *counter) |
| 2842 | { | 3056 | { |
| 2843 | if (counter->attr.comm || counter->attr.mmap) | 3057 | if (counter->attr.comm || counter->attr.mmap || counter->attr.task) |
| 2844 | return 1; | 3058 | return 1; |
| 2845 | 3059 | ||
| 2846 | return 0; | 3060 | return 0; |
| 2847 | } | 3061 | } |
| 2848 | 3062 | ||
| 2849 | static void perf_counter_fork_ctx(struct perf_counter_context *ctx, | 3063 | static void perf_counter_task_ctx(struct perf_counter_context *ctx, |
| 2850 | struct perf_fork_event *fork_event) | 3064 | struct perf_task_event *task_event) |
| 2851 | { | 3065 | { |
| 2852 | struct perf_counter *counter; | 3066 | struct perf_counter *counter; |
| 2853 | 3067 | ||
| @@ -2856,51 +3070,62 @@ static void perf_counter_fork_ctx(struct perf_counter_context *ctx, | |||
| 2856 | 3070 | ||
| 2857 | rcu_read_lock(); | 3071 | rcu_read_lock(); |
| 2858 | list_for_each_entry_rcu(counter, &ctx->event_list, event_entry) { | 3072 | list_for_each_entry_rcu(counter, &ctx->event_list, event_entry) { |
| 2859 | if (perf_counter_fork_match(counter)) | 3073 | if (perf_counter_task_match(counter)) |
| 2860 | perf_counter_fork_output(counter, fork_event); | 3074 | perf_counter_task_output(counter, task_event); |
| 2861 | } | 3075 | } |
| 2862 | rcu_read_unlock(); | 3076 | rcu_read_unlock(); |
| 2863 | } | 3077 | } |
| 2864 | 3078 | ||
| 2865 | static void perf_counter_fork_event(struct perf_fork_event *fork_event) | 3079 | static void perf_counter_task_event(struct perf_task_event *task_event) |
| 2866 | { | 3080 | { |
| 2867 | struct perf_cpu_context *cpuctx; | 3081 | struct perf_cpu_context *cpuctx; |
| 2868 | struct perf_counter_context *ctx; | 3082 | struct perf_counter_context *ctx = task_event->task_ctx; |
| 2869 | 3083 | ||
| 2870 | cpuctx = &get_cpu_var(perf_cpu_context); | 3084 | cpuctx = &get_cpu_var(perf_cpu_context); |
| 2871 | perf_counter_fork_ctx(&cpuctx->ctx, fork_event); | 3085 | perf_counter_task_ctx(&cpuctx->ctx, task_event); |
| 2872 | put_cpu_var(perf_cpu_context); | 3086 | put_cpu_var(perf_cpu_context); |
| 2873 | 3087 | ||
| 2874 | rcu_read_lock(); | 3088 | rcu_read_lock(); |
| 2875 | /* | 3089 | if (!ctx) |
| 2876 | * doesn't really matter which of the child contexts the | 3090 | ctx = rcu_dereference(task_event->task->perf_counter_ctxp); |
| 2877 | * events ends up in. | ||
| 2878 | */ | ||
| 2879 | ctx = rcu_dereference(current->perf_counter_ctxp); | ||
| 2880 | if (ctx) | 3091 | if (ctx) |
| 2881 | perf_counter_fork_ctx(ctx, fork_event); | 3092 | perf_counter_task_ctx(ctx, task_event); |
| 2882 | rcu_read_unlock(); | 3093 | rcu_read_unlock(); |
| 2883 | } | 3094 | } |
| 2884 | 3095 | ||
| 2885 | void perf_counter_fork(struct task_struct *task) | 3096 | static void perf_counter_task(struct task_struct *task, |
| 3097 | struct perf_counter_context *task_ctx, | ||
| 3098 | int new) | ||
| 2886 | { | 3099 | { |
| 2887 | struct perf_fork_event fork_event; | 3100 | struct perf_task_event task_event; |
| 2888 | 3101 | ||
| 2889 | if (!atomic_read(&nr_comm_counters) && | 3102 | if (!atomic_read(&nr_comm_counters) && |
| 2890 | !atomic_read(&nr_mmap_counters)) | 3103 | !atomic_read(&nr_mmap_counters) && |
| 3104 | !atomic_read(&nr_task_counters)) | ||
| 2891 | return; | 3105 | return; |
| 2892 | 3106 | ||
| 2893 | fork_event = (struct perf_fork_event){ | 3107 | task_event = (struct perf_task_event){ |
| 2894 | .task = task, | 3108 | .task = task, |
| 2895 | .event = { | 3109 | .task_ctx = task_ctx, |
| 3110 | .event = { | ||
| 2896 | .header = { | 3111 | .header = { |
| 2897 | .type = PERF_EVENT_FORK, | 3112 | .type = new ? PERF_EVENT_FORK : PERF_EVENT_EXIT, |
| 2898 | .size = sizeof(fork_event.event), | 3113 | .misc = 0, |
| 3114 | .size = sizeof(task_event.event), | ||
| 2899 | }, | 3115 | }, |
| 3116 | /* .pid */ | ||
| 3117 | /* .ppid */ | ||
| 3118 | /* .tid */ | ||
| 3119 | /* .ptid */ | ||
| 2900 | }, | 3120 | }, |
| 2901 | }; | 3121 | }; |
| 2902 | 3122 | ||
| 2903 | perf_counter_fork_event(&fork_event); | 3123 | perf_counter_task_event(&task_event); |
| 3124 | } | ||
| 3125 | |||
| 3126 | void perf_counter_fork(struct task_struct *task) | ||
| 3127 | { | ||
| 3128 | perf_counter_task(task, NULL, 1); | ||
| 2904 | } | 3129 | } |
| 2905 | 3130 | ||
| 2906 | /* | 3131 | /* |
| @@ -2968,8 +3193,10 @@ static void perf_counter_comm_event(struct perf_comm_event *comm_event) | |||
| 2968 | struct perf_cpu_context *cpuctx; | 3193 | struct perf_cpu_context *cpuctx; |
| 2969 | struct perf_counter_context *ctx; | 3194 | struct perf_counter_context *ctx; |
| 2970 | unsigned int size; | 3195 | unsigned int size; |
| 2971 | char *comm = comm_event->task->comm; | 3196 | char comm[TASK_COMM_LEN]; |
| 2972 | 3197 | ||
| 3198 | memset(comm, 0, sizeof(comm)); | ||
| 3199 | strncpy(comm, comm_event->task->comm, sizeof(comm)); | ||
| 2973 | size = ALIGN(strlen(comm)+1, sizeof(u64)); | 3200 | size = ALIGN(strlen(comm)+1, sizeof(u64)); |
| 2974 | 3201 | ||
| 2975 | comm_event->comm = comm; | 3202 | comm_event->comm = comm; |
| @@ -3004,8 +3231,16 @@ void perf_counter_comm(struct task_struct *task) | |||
| 3004 | 3231 | ||
| 3005 | comm_event = (struct perf_comm_event){ | 3232 | comm_event = (struct perf_comm_event){ |
| 3006 | .task = task, | 3233 | .task = task, |
| 3234 | /* .comm */ | ||
| 3235 | /* .comm_size */ | ||
| 3007 | .event = { | 3236 | .event = { |
| 3008 | .header = { .type = PERF_EVENT_COMM, }, | 3237 | .header = { |
| 3238 | .type = PERF_EVENT_COMM, | ||
| 3239 | .misc = 0, | ||
| 3240 | /* .size */ | ||
| 3241 | }, | ||
| 3242 | /* .pid */ | ||
| 3243 | /* .tid */ | ||
| 3009 | }, | 3244 | }, |
| 3010 | }; | 3245 | }; |
| 3011 | 3246 | ||
| @@ -3088,8 +3323,15 @@ static void perf_counter_mmap_event(struct perf_mmap_event *mmap_event) | |||
| 3088 | char *buf = NULL; | 3323 | char *buf = NULL; |
| 3089 | const char *name; | 3324 | const char *name; |
| 3090 | 3325 | ||
| 3326 | memset(tmp, 0, sizeof(tmp)); | ||
| 3327 | |||
| 3091 | if (file) { | 3328 | if (file) { |
| 3092 | buf = kzalloc(PATH_MAX, GFP_KERNEL); | 3329 | /* |
| 3330 | * d_path works from the end of the buffer backwards, so we | ||
| 3331 | * need to add enough zero bytes after the string to handle | ||
| 3332 | * the 64bit alignment we do later. | ||
| 3333 | */ | ||
| 3334 | buf = kzalloc(PATH_MAX + sizeof(u64), GFP_KERNEL); | ||
| 3093 | if (!buf) { | 3335 | if (!buf) { |
| 3094 | name = strncpy(tmp, "//enomem", sizeof(tmp)); | 3336 | name = strncpy(tmp, "//enomem", sizeof(tmp)); |
| 3095 | goto got_name; | 3337 | goto got_name; |
| @@ -3100,9 +3342,11 @@ static void perf_counter_mmap_event(struct perf_mmap_event *mmap_event) | |||
| 3100 | goto got_name; | 3342 | goto got_name; |
| 3101 | } | 3343 | } |
| 3102 | } else { | 3344 | } else { |
| 3103 | name = arch_vma_name(mmap_event->vma); | 3345 | if (arch_vma_name(mmap_event->vma)) { |
| 3104 | if (name) | 3346 | name = strncpy(tmp, arch_vma_name(mmap_event->vma), |
| 3347 | sizeof(tmp)); | ||
| 3105 | goto got_name; | 3348 | goto got_name; |
| 3349 | } | ||
| 3106 | 3350 | ||
| 3107 | if (!vma->vm_mm) { | 3351 | if (!vma->vm_mm) { |
| 3108 | name = strncpy(tmp, "[vdso]", sizeof(tmp)); | 3352 | name = strncpy(tmp, "[vdso]", sizeof(tmp)); |
| @@ -3147,8 +3391,16 @@ void __perf_counter_mmap(struct vm_area_struct *vma) | |||
| 3147 | 3391 | ||
| 3148 | mmap_event = (struct perf_mmap_event){ | 3392 | mmap_event = (struct perf_mmap_event){ |
| 3149 | .vma = vma, | 3393 | .vma = vma, |
| 3394 | /* .file_name */ | ||
| 3395 | /* .file_size */ | ||
| 3150 | .event = { | 3396 | .event = { |
| 3151 | .header = { .type = PERF_EVENT_MMAP, }, | 3397 | .header = { |
| 3398 | .type = PERF_EVENT_MMAP, | ||
| 3399 | .misc = 0, | ||
| 3400 | /* .size */ | ||
| 3401 | }, | ||
| 3402 | /* .pid */ | ||
| 3403 | /* .tid */ | ||
| 3152 | .start = vma->vm_start, | 3404 | .start = vma->vm_start, |
| 3153 | .len = vma->vm_end - vma->vm_start, | 3405 | .len = vma->vm_end - vma->vm_start, |
| 3154 | .pgoff = vma->vm_pgoff, | 3406 | .pgoff = vma->vm_pgoff, |
| @@ -3159,49 +3411,6 @@ void __perf_counter_mmap(struct vm_area_struct *vma) | |||
| 3159 | } | 3411 | } |
| 3160 | 3412 | ||
| 3161 | /* | 3413 | /* |
| 3162 | * Log sample_period changes so that analyzing tools can re-normalize the | ||
| 3163 | * event flow. | ||
| 3164 | */ | ||
| 3165 | |||
| 3166 | struct freq_event { | ||
| 3167 | struct perf_event_header header; | ||
| 3168 | u64 time; | ||
| 3169 | u64 id; | ||
| 3170 | u64 period; | ||
| 3171 | }; | ||
| 3172 | |||
| 3173 | static void perf_log_period(struct perf_counter *counter, u64 period) | ||
| 3174 | { | ||
| 3175 | struct perf_output_handle handle; | ||
| 3176 | struct freq_event event; | ||
| 3177 | int ret; | ||
| 3178 | |||
| 3179 | if (counter->hw.sample_period == period) | ||
| 3180 | return; | ||
| 3181 | |||
| 3182 | if (counter->attr.sample_type & PERF_SAMPLE_PERIOD) | ||
| 3183 | return; | ||
| 3184 | |||
| 3185 | event = (struct freq_event) { | ||
| 3186 | .header = { | ||
| 3187 | .type = PERF_EVENT_PERIOD, | ||
| 3188 | .misc = 0, | ||
| 3189 | .size = sizeof(event), | ||
| 3190 | }, | ||
| 3191 | .time = sched_clock(), | ||
| 3192 | .id = counter->id, | ||
| 3193 | .period = period, | ||
| 3194 | }; | ||
| 3195 | |||
| 3196 | ret = perf_output_begin(&handle, counter, sizeof(event), 1, 0); | ||
| 3197 | if (ret) | ||
| 3198 | return; | ||
| 3199 | |||
| 3200 | perf_output_put(&handle, event); | ||
| 3201 | perf_output_end(&handle); | ||
| 3202 | } | ||
| 3203 | |||
| 3204 | /* | ||
| 3205 | * IRQ throttle logging | 3414 | * IRQ throttle logging |
| 3206 | */ | 3415 | */ |
| 3207 | 3416 | ||
| @@ -3214,16 +3423,21 @@ static void perf_log_throttle(struct perf_counter *counter, int enable) | |||
| 3214 | struct perf_event_header header; | 3423 | struct perf_event_header header; |
| 3215 | u64 time; | 3424 | u64 time; |
| 3216 | u64 id; | 3425 | u64 id; |
| 3426 | u64 stream_id; | ||
| 3217 | } throttle_event = { | 3427 | } throttle_event = { |
| 3218 | .header = { | 3428 | .header = { |
| 3219 | .type = PERF_EVENT_THROTTLE + 1, | 3429 | .type = PERF_EVENT_THROTTLE, |
| 3220 | .misc = 0, | 3430 | .misc = 0, |
| 3221 | .size = sizeof(throttle_event), | 3431 | .size = sizeof(throttle_event), |
| 3222 | }, | 3432 | }, |
| 3223 | .time = sched_clock(), | 3433 | .time = sched_clock(), |
| 3224 | .id = counter->id, | 3434 | .id = primary_counter_id(counter), |
| 3435 | .stream_id = counter->id, | ||
| 3225 | }; | 3436 | }; |
| 3226 | 3437 | ||
| 3438 | if (enable) | ||
| 3439 | throttle_event.header.type = PERF_EVENT_UNTHROTTLE; | ||
| 3440 | |||
| 3227 | ret = perf_output_begin(&handle, counter, sizeof(throttle_event), 1, 0); | 3441 | ret = perf_output_begin(&handle, counter, sizeof(throttle_event), 1, 0); |
| 3228 | if (ret) | 3442 | if (ret) |
| 3229 | return; | 3443 | return; |
| @@ -3300,125 +3514,111 @@ int perf_counter_overflow(struct perf_counter *counter, int nmi, | |||
| 3300 | * Generic software counter infrastructure | 3514 | * Generic software counter infrastructure |
| 3301 | */ | 3515 | */ |
| 3302 | 3516 | ||
| 3303 | static void perf_swcounter_update(struct perf_counter *counter) | 3517 | /* |
| 3518 | * We directly increment counter->count and keep a second value in | ||
| 3519 | * counter->hw.period_left to count intervals. This period counter | ||
| 3520 | * is kept in the range [-sample_period, 0] so that we can use the | ||
| 3521 | * sign as trigger. | ||
| 3522 | */ | ||
| 3523 | |||
| 3524 | static u64 perf_swcounter_set_period(struct perf_counter *counter) | ||
| 3304 | { | 3525 | { |
| 3305 | struct hw_perf_counter *hwc = &counter->hw; | 3526 | struct hw_perf_counter *hwc = &counter->hw; |
| 3306 | u64 prev, now; | 3527 | u64 period = hwc->last_period; |
| 3307 | s64 delta; | 3528 | u64 nr, offset; |
| 3529 | s64 old, val; | ||
| 3530 | |||
| 3531 | hwc->last_period = hwc->sample_period; | ||
| 3308 | 3532 | ||
| 3309 | again: | 3533 | again: |
| 3310 | prev = atomic64_read(&hwc->prev_count); | 3534 | old = val = atomic64_read(&hwc->period_left); |
| 3311 | now = atomic64_read(&hwc->count); | 3535 | if (val < 0) |
| 3312 | if (atomic64_cmpxchg(&hwc->prev_count, prev, now) != prev) | 3536 | return 0; |
| 3313 | goto again; | ||
| 3314 | 3537 | ||
| 3315 | delta = now - prev; | 3538 | nr = div64_u64(period + val, period); |
| 3539 | offset = nr * period; | ||
| 3540 | val -= offset; | ||
| 3541 | if (atomic64_cmpxchg(&hwc->period_left, old, val) != old) | ||
| 3542 | goto again; | ||
| 3316 | 3543 | ||
| 3317 | atomic64_add(delta, &counter->count); | 3544 | return nr; |
| 3318 | atomic64_sub(delta, &hwc->period_left); | ||
| 3319 | } | 3545 | } |
| 3320 | 3546 | ||
| 3321 | static void perf_swcounter_set_period(struct perf_counter *counter) | 3547 | static void perf_swcounter_overflow(struct perf_counter *counter, |
| 3548 | int nmi, struct perf_sample_data *data) | ||
| 3322 | { | 3549 | { |
| 3323 | struct hw_perf_counter *hwc = &counter->hw; | 3550 | struct hw_perf_counter *hwc = &counter->hw; |
| 3324 | s64 left = atomic64_read(&hwc->period_left); | 3551 | u64 overflow; |
| 3325 | s64 period = hwc->sample_period; | ||
| 3326 | 3552 | ||
| 3327 | if (unlikely(left <= -period)) { | 3553 | data->period = counter->hw.last_period; |
| 3328 | left = period; | 3554 | overflow = perf_swcounter_set_period(counter); |
| 3329 | atomic64_set(&hwc->period_left, left); | ||
| 3330 | hwc->last_period = period; | ||
| 3331 | } | ||
| 3332 | 3555 | ||
| 3333 | if (unlikely(left <= 0)) { | 3556 | if (hwc->interrupts == MAX_INTERRUPTS) |
| 3334 | left += period; | 3557 | return; |
| 3335 | atomic64_add(period, &hwc->period_left); | ||
| 3336 | hwc->last_period = period; | ||
| 3337 | } | ||
| 3338 | 3558 | ||
| 3339 | atomic64_set(&hwc->prev_count, -left); | 3559 | for (; overflow; overflow--) { |
| 3340 | atomic64_set(&hwc->count, -left); | 3560 | if (perf_counter_overflow(counter, nmi, data)) { |
| 3561 | /* | ||
| 3562 | * We inhibit the overflow from happening when | ||
| 3563 | * hwc->interrupts == MAX_INTERRUPTS. | ||
| 3564 | */ | ||
| 3565 | break; | ||
| 3566 | } | ||
| 3567 | } | ||
| 3341 | } | 3568 | } |
| 3342 | 3569 | ||
| 3343 | static enum hrtimer_restart perf_swcounter_hrtimer(struct hrtimer *hrtimer) | 3570 | static void perf_swcounter_unthrottle(struct perf_counter *counter) |
| 3344 | { | 3571 | { |
| 3345 | enum hrtimer_restart ret = HRTIMER_RESTART; | ||
| 3346 | struct perf_sample_data data; | ||
| 3347 | struct perf_counter *counter; | ||
| 3348 | u64 period; | ||
| 3349 | |||
| 3350 | counter = container_of(hrtimer, struct perf_counter, hw.hrtimer); | ||
| 3351 | counter->pmu->read(counter); | ||
| 3352 | |||
| 3353 | data.addr = 0; | ||
| 3354 | data.regs = get_irq_regs(); | ||
| 3355 | /* | 3572 | /* |
| 3356 | * In case we exclude kernel IPs or are somehow not in interrupt | 3573 | * Nothing to do, we already reset hwc->interrupts. |
| 3357 | * context, provide the next best thing, the user IP. | ||
| 3358 | */ | 3574 | */ |
| 3359 | if ((counter->attr.exclude_kernel || !data.regs) && | 3575 | } |
| 3360 | !counter->attr.exclude_user) | ||
| 3361 | data.regs = task_pt_regs(current); | ||
| 3362 | 3576 | ||
| 3363 | if (data.regs) { | 3577 | static void perf_swcounter_add(struct perf_counter *counter, u64 nr, |
| 3364 | if (perf_counter_overflow(counter, 0, &data)) | 3578 | int nmi, struct perf_sample_data *data) |
| 3365 | ret = HRTIMER_NORESTART; | 3579 | { |
| 3366 | } | 3580 | struct hw_perf_counter *hwc = &counter->hw; |
| 3367 | 3581 | ||
| 3368 | period = max_t(u64, 10000, counter->hw.sample_period); | 3582 | atomic64_add(nr, &counter->count); |
| 3369 | hrtimer_forward_now(hrtimer, ns_to_ktime(period)); | ||
| 3370 | 3583 | ||
| 3371 | return ret; | 3584 | if (!hwc->sample_period) |
| 3372 | } | 3585 | return; |
| 3373 | 3586 | ||
| 3374 | static void perf_swcounter_overflow(struct perf_counter *counter, | 3587 | if (!data->regs) |
| 3375 | int nmi, struct perf_sample_data *data) | 3588 | return; |
| 3376 | { | ||
| 3377 | data->period = counter->hw.last_period; | ||
| 3378 | 3589 | ||
| 3379 | perf_swcounter_update(counter); | 3590 | if (!atomic64_add_negative(nr, &hwc->period_left)) |
| 3380 | perf_swcounter_set_period(counter); | 3591 | perf_swcounter_overflow(counter, nmi, data); |
| 3381 | if (perf_counter_overflow(counter, nmi, data)) | ||
| 3382 | /* soft-disable the counter */ | ||
| 3383 | ; | ||
| 3384 | } | 3592 | } |
| 3385 | 3593 | ||
| 3386 | static int perf_swcounter_is_counting(struct perf_counter *counter) | 3594 | static int perf_swcounter_is_counting(struct perf_counter *counter) |
| 3387 | { | 3595 | { |
| 3388 | struct perf_counter_context *ctx; | 3596 | /* |
| 3389 | unsigned long flags; | 3597 | * The counter is active, we're good! |
| 3390 | int count; | 3598 | */ |
| 3391 | |||
| 3392 | if (counter->state == PERF_COUNTER_STATE_ACTIVE) | 3599 | if (counter->state == PERF_COUNTER_STATE_ACTIVE) |
| 3393 | return 1; | 3600 | return 1; |
| 3394 | 3601 | ||
| 3602 | /* | ||
| 3603 | * The counter is off/error, not counting. | ||
| 3604 | */ | ||
| 3395 | if (counter->state != PERF_COUNTER_STATE_INACTIVE) | 3605 | if (counter->state != PERF_COUNTER_STATE_INACTIVE) |
| 3396 | return 0; | 3606 | return 0; |
| 3397 | 3607 | ||
| 3398 | /* | 3608 | /* |
| 3399 | * If the counter is inactive, it could be just because | 3609 | * The counter is inactive, if the context is active |
| 3400 | * its task is scheduled out, or because it's in a group | 3610 | * we're part of a group that didn't make it on the 'pmu', |
| 3401 | * which could not go on the PMU. We want to count in | 3611 | * not counting. |
| 3402 | * the first case but not the second. If the context is | ||
| 3403 | * currently active then an inactive software counter must | ||
| 3404 | * be the second case. If it's not currently active then | ||
| 3405 | * we need to know whether the counter was active when the | ||
| 3406 | * context was last active, which we can determine by | ||
| 3407 | * comparing counter->tstamp_stopped with ctx->time. | ||
| 3408 | * | ||
| 3409 | * We are within an RCU read-side critical section, | ||
| 3410 | * which protects the existence of *ctx. | ||
| 3411 | */ | 3612 | */ |
| 3412 | ctx = counter->ctx; | 3613 | if (counter->ctx->is_active) |
| 3413 | spin_lock_irqsave(&ctx->lock, flags); | 3614 | return 0; |
| 3414 | count = 1; | 3615 | |
| 3415 | /* Re-check state now we have the lock */ | 3616 | /* |
| 3416 | if (counter->state < PERF_COUNTER_STATE_INACTIVE || | 3617 | * We're inactive and the context is too, this means the |
| 3417 | counter->ctx->is_active || | 3618 | * task is scheduled out, we're counting events that happen |
| 3418 | counter->tstamp_stopped < ctx->time) | 3619 | * to us, like migration events. |
| 3419 | count = 0; | 3620 | */ |
| 3420 | spin_unlock_irqrestore(&ctx->lock, flags); | 3621 | return 1; |
| 3421 | return count; | ||
| 3422 | } | 3622 | } |
| 3423 | 3623 | ||
| 3424 | static int perf_swcounter_match(struct perf_counter *counter, | 3624 | static int perf_swcounter_match(struct perf_counter *counter, |
| @@ -3444,15 +3644,6 @@ static int perf_swcounter_match(struct perf_counter *counter, | |||
| 3444 | return 1; | 3644 | return 1; |
| 3445 | } | 3645 | } |
| 3446 | 3646 | ||
| 3447 | static void perf_swcounter_add(struct perf_counter *counter, u64 nr, | ||
| 3448 | int nmi, struct perf_sample_data *data) | ||
| 3449 | { | ||
| 3450 | int neg = atomic64_add_negative(nr, &counter->hw.count); | ||
| 3451 | |||
| 3452 | if (counter->hw.sample_period && !neg && data->regs) | ||
| 3453 | perf_swcounter_overflow(counter, nmi, data); | ||
| 3454 | } | ||
| 3455 | |||
| 3456 | static void perf_swcounter_ctx_event(struct perf_counter_context *ctx, | 3647 | static void perf_swcounter_ctx_event(struct perf_counter_context *ctx, |
| 3457 | enum perf_type_id type, | 3648 | enum perf_type_id type, |
| 3458 | u32 event, u64 nr, int nmi, | 3649 | u32 event, u64 nr, int nmi, |
| @@ -3531,27 +3722,66 @@ void __perf_swcounter_event(u32 event, u64 nr, int nmi, | |||
| 3531 | 3722 | ||
| 3532 | static void perf_swcounter_read(struct perf_counter *counter) | 3723 | static void perf_swcounter_read(struct perf_counter *counter) |
| 3533 | { | 3724 | { |
| 3534 | perf_swcounter_update(counter); | ||
| 3535 | } | 3725 | } |
| 3536 | 3726 | ||
| 3537 | static int perf_swcounter_enable(struct perf_counter *counter) | 3727 | static int perf_swcounter_enable(struct perf_counter *counter) |
| 3538 | { | 3728 | { |
| 3539 | perf_swcounter_set_period(counter); | 3729 | struct hw_perf_counter *hwc = &counter->hw; |
| 3730 | |||
| 3731 | if (hwc->sample_period) { | ||
| 3732 | hwc->last_period = hwc->sample_period; | ||
| 3733 | perf_swcounter_set_period(counter); | ||
| 3734 | } | ||
| 3540 | return 0; | 3735 | return 0; |
| 3541 | } | 3736 | } |
| 3542 | 3737 | ||
| 3543 | static void perf_swcounter_disable(struct perf_counter *counter) | 3738 | static void perf_swcounter_disable(struct perf_counter *counter) |
| 3544 | { | 3739 | { |
| 3545 | perf_swcounter_update(counter); | ||
| 3546 | } | 3740 | } |
| 3547 | 3741 | ||
| 3548 | static const struct pmu perf_ops_generic = { | 3742 | static const struct pmu perf_ops_generic = { |
| 3549 | .enable = perf_swcounter_enable, | 3743 | .enable = perf_swcounter_enable, |
| 3550 | .disable = perf_swcounter_disable, | 3744 | .disable = perf_swcounter_disable, |
| 3551 | .read = perf_swcounter_read, | 3745 | .read = perf_swcounter_read, |
| 3746 | .unthrottle = perf_swcounter_unthrottle, | ||
| 3552 | }; | 3747 | }; |
| 3553 | 3748 | ||
| 3554 | /* | 3749 | /* |
| 3750 | * hrtimer based swcounter callback | ||
| 3751 | */ | ||
| 3752 | |||
| 3753 | static enum hrtimer_restart perf_swcounter_hrtimer(struct hrtimer *hrtimer) | ||
| 3754 | { | ||
| 3755 | enum hrtimer_restart ret = HRTIMER_RESTART; | ||
| 3756 | struct perf_sample_data data; | ||
| 3757 | struct perf_counter *counter; | ||
| 3758 | u64 period; | ||
| 3759 | |||
| 3760 | counter = container_of(hrtimer, struct perf_counter, hw.hrtimer); | ||
| 3761 | counter->pmu->read(counter); | ||
| 3762 | |||
| 3763 | data.addr = 0; | ||
| 3764 | data.regs = get_irq_regs(); | ||
| 3765 | /* | ||
| 3766 | * In case we exclude kernel IPs or are somehow not in interrupt | ||
| 3767 | * context, provide the next best thing, the user IP. | ||
| 3768 | */ | ||
| 3769 | if ((counter->attr.exclude_kernel || !data.regs) && | ||
| 3770 | !counter->attr.exclude_user) | ||
| 3771 | data.regs = task_pt_regs(current); | ||
| 3772 | |||
| 3773 | if (data.regs) { | ||
| 3774 | if (perf_counter_overflow(counter, 0, &data)) | ||
| 3775 | ret = HRTIMER_NORESTART; | ||
| 3776 | } | ||
| 3777 | |||
| 3778 | period = max_t(u64, 10000, counter->hw.sample_period); | ||
| 3779 | hrtimer_forward_now(hrtimer, ns_to_ktime(period)); | ||
| 3780 | |||
| 3781 | return ret; | ||
| 3782 | } | ||
| 3783 | |||
| 3784 | /* | ||
| 3555 | * Software counter: cpu wall time clock | 3785 | * Software counter: cpu wall time clock |
| 3556 | */ | 3786 | */ |
| 3557 | 3787 | ||
| @@ -3668,17 +3898,24 @@ static const struct pmu perf_ops_task_clock = { | |||
| 3668 | }; | 3898 | }; |
| 3669 | 3899 | ||
| 3670 | #ifdef CONFIG_EVENT_PROFILE | 3900 | #ifdef CONFIG_EVENT_PROFILE |
| 3671 | void perf_tpcounter_event(int event_id) | 3901 | void perf_tpcounter_event(int event_id, u64 addr, u64 count, void *record, |
| 3902 | int entry_size) | ||
| 3672 | { | 3903 | { |
| 3904 | struct perf_raw_record raw = { | ||
| 3905 | .size = entry_size, | ||
| 3906 | .data = record, | ||
| 3907 | }; | ||
| 3908 | |||
| 3673 | struct perf_sample_data data = { | 3909 | struct perf_sample_data data = { |
| 3674 | .regs = get_irq_regs(); | 3910 | .regs = get_irq_regs(), |
| 3675 | .addr = 0, | 3911 | .addr = addr, |
| 3912 | .raw = &raw, | ||
| 3676 | }; | 3913 | }; |
| 3677 | 3914 | ||
| 3678 | if (!data.regs) | 3915 | if (!data.regs) |
| 3679 | data.regs = task_pt_regs(current); | 3916 | data.regs = task_pt_regs(current); |
| 3680 | 3917 | ||
| 3681 | do_perf_swcounter_event(PERF_TYPE_TRACEPOINT, event_id, 1, 1, &data); | 3918 | do_perf_swcounter_event(PERF_TYPE_TRACEPOINT, event_id, count, 1, &data); |
| 3682 | } | 3919 | } |
| 3683 | EXPORT_SYMBOL_GPL(perf_tpcounter_event); | 3920 | EXPORT_SYMBOL_GPL(perf_tpcounter_event); |
| 3684 | 3921 | ||
| @@ -3687,16 +3924,20 @@ extern void ftrace_profile_disable(int); | |||
| 3687 | 3924 | ||
| 3688 | static void tp_perf_counter_destroy(struct perf_counter *counter) | 3925 | static void tp_perf_counter_destroy(struct perf_counter *counter) |
| 3689 | { | 3926 | { |
| 3690 | ftrace_profile_disable(perf_event_id(&counter->attr)); | 3927 | ftrace_profile_disable(counter->attr.config); |
| 3691 | } | 3928 | } |
| 3692 | 3929 | ||
| 3693 | static const struct pmu *tp_perf_counter_init(struct perf_counter *counter) | 3930 | static const struct pmu *tp_perf_counter_init(struct perf_counter *counter) |
| 3694 | { | 3931 | { |
| 3695 | int event_id = perf_event_id(&counter->attr); | 3932 | /* |
| 3696 | int ret; | 3933 | * Raw tracepoint data is a severe data leak, only allow root to |
| 3934 | * have these. | ||
| 3935 | */ | ||
| 3936 | if ((counter->attr.sample_type & PERF_SAMPLE_RAW) && | ||
| 3937 | !capable(CAP_SYS_ADMIN)) | ||
| 3938 | return ERR_PTR(-EPERM); | ||
| 3697 | 3939 | ||
| 3698 | ret = ftrace_profile_enable(event_id); | 3940 | if (ftrace_profile_enable(counter->attr.config)) |
| 3699 | if (ret) | ||
| 3700 | return NULL; | 3941 | return NULL; |
| 3701 | 3942 | ||
| 3702 | counter->destroy = tp_perf_counter_destroy; | 3943 | counter->destroy = tp_perf_counter_destroy; |
| @@ -3829,9 +4070,9 @@ perf_counter_alloc(struct perf_counter_attr *attr, | |||
| 3829 | atomic64_set(&hwc->period_left, hwc->sample_period); | 4070 | atomic64_set(&hwc->period_left, hwc->sample_period); |
| 3830 | 4071 | ||
| 3831 | /* | 4072 | /* |
| 3832 | * we currently do not support PERF_SAMPLE_GROUP on inherited counters | 4073 | * we currently do not support PERF_FORMAT_GROUP on inherited counters |
| 3833 | */ | 4074 | */ |
| 3834 | if (attr->inherit && (attr->sample_type & PERF_SAMPLE_GROUP)) | 4075 | if (attr->inherit && (attr->read_format & PERF_FORMAT_GROUP)) |
| 3835 | goto done; | 4076 | goto done; |
| 3836 | 4077 | ||
| 3837 | switch (attr->type) { | 4078 | switch (attr->type) { |
| @@ -3874,6 +4115,8 @@ done: | |||
| 3874 | atomic_inc(&nr_mmap_counters); | 4115 | atomic_inc(&nr_mmap_counters); |
| 3875 | if (counter->attr.comm) | 4116 | if (counter->attr.comm) |
| 3876 | atomic_inc(&nr_comm_counters); | 4117 | atomic_inc(&nr_comm_counters); |
| 4118 | if (counter->attr.task) | ||
| 4119 | atomic_inc(&nr_task_counters); | ||
| 3877 | } | 4120 | } |
| 3878 | 4121 | ||
| 3879 | return counter; | 4122 | return counter; |
| @@ -4235,8 +4478,10 @@ void perf_counter_exit_task(struct task_struct *child) | |||
| 4235 | struct perf_counter_context *child_ctx; | 4478 | struct perf_counter_context *child_ctx; |
| 4236 | unsigned long flags; | 4479 | unsigned long flags; |
| 4237 | 4480 | ||
| 4238 | if (likely(!child->perf_counter_ctxp)) | 4481 | if (likely(!child->perf_counter_ctxp)) { |
| 4482 | perf_counter_task(child, NULL, 0); | ||
| 4239 | return; | 4483 | return; |
| 4484 | } | ||
| 4240 | 4485 | ||
| 4241 | local_irq_save(flags); | 4486 | local_irq_save(flags); |
| 4242 | /* | 4487 | /* |
| @@ -4255,17 +4500,20 @@ void perf_counter_exit_task(struct task_struct *child) | |||
| 4255 | */ | 4500 | */ |
| 4256 | spin_lock(&child_ctx->lock); | 4501 | spin_lock(&child_ctx->lock); |
| 4257 | child->perf_counter_ctxp = NULL; | 4502 | child->perf_counter_ctxp = NULL; |
| 4258 | if (child_ctx->parent_ctx) { | 4503 | /* |
| 4259 | /* | 4504 | * If this context is a clone; unclone it so it can't get |
| 4260 | * This context is a clone; unclone it so it can't get | 4505 | * swapped to another process while we're removing all |
| 4261 | * swapped to another process while we're removing all | 4506 | * the counters from it. |
| 4262 | * the counters from it. | 4507 | */ |
| 4263 | */ | 4508 | unclone_ctx(child_ctx); |
| 4264 | put_ctx(child_ctx->parent_ctx); | 4509 | spin_unlock_irqrestore(&child_ctx->lock, flags); |
| 4265 | child_ctx->parent_ctx = NULL; | 4510 | |
| 4266 | } | 4511 | /* |
| 4267 | spin_unlock(&child_ctx->lock); | 4512 | * Report the task dead after unscheduling the counters so that we |
| 4268 | local_irq_restore(flags); | 4513 | * won't get any samples after PERF_EVENT_EXIT. We can however still |
| 4514 | * get a few PERF_EVENT_READ events. | ||
| 4515 | */ | ||
| 4516 | perf_counter_task(child, child_ctx, 0); | ||
| 4269 | 4517 | ||
| 4270 | /* | 4518 | /* |
| 4271 | * We can recurse on the same lock type through: | 4519 | * We can recurse on the same lock type through: |
| @@ -4486,6 +4734,11 @@ perf_cpu_notify(struct notifier_block *self, unsigned long action, void *hcpu) | |||
| 4486 | perf_counter_init_cpu(cpu); | 4734 | perf_counter_init_cpu(cpu); |
| 4487 | break; | 4735 | break; |
| 4488 | 4736 | ||
| 4737 | case CPU_ONLINE: | ||
| 4738 | case CPU_ONLINE_FROZEN: | ||
| 4739 | hw_perf_counter_setup_online(cpu); | ||
| 4740 | break; | ||
| 4741 | |||
| 4489 | case CPU_DOWN_PREPARE: | 4742 | case CPU_DOWN_PREPARE: |
| 4490 | case CPU_DOWN_PREPARE_FROZEN: | 4743 | case CPU_DOWN_PREPARE_FROZEN: |
| 4491 | perf_counter_exit_cpu(cpu); | 4744 | perf_counter_exit_cpu(cpu); |
| @@ -4510,6 +4763,8 @@ void __init perf_counter_init(void) | |||
| 4510 | { | 4763 | { |
| 4511 | perf_cpu_notify(&perf_cpu_nb, (unsigned long)CPU_UP_PREPARE, | 4764 | perf_cpu_notify(&perf_cpu_nb, (unsigned long)CPU_UP_PREPARE, |
| 4512 | (void *)(long)smp_processor_id()); | 4765 | (void *)(long)smp_processor_id()); |
| 4766 | perf_cpu_notify(&perf_cpu_nb, (unsigned long)CPU_ONLINE, | ||
| 4767 | (void *)(long)smp_processor_id()); | ||
| 4513 | register_cpu_notifier(&perf_cpu_nb); | 4768 | register_cpu_notifier(&perf_cpu_nb); |
| 4514 | } | 4769 | } |
| 4515 | 4770 | ||
diff --git a/kernel/posix-cpu-timers.c b/kernel/posix-cpu-timers.c index bece7c0b67b2..e33a21cb9407 100644 --- a/kernel/posix-cpu-timers.c +++ b/kernel/posix-cpu-timers.c | |||
| @@ -521,11 +521,12 @@ void posix_cpu_timers_exit(struct task_struct *tsk) | |||
| 521 | } | 521 | } |
| 522 | void posix_cpu_timers_exit_group(struct task_struct *tsk) | 522 | void posix_cpu_timers_exit_group(struct task_struct *tsk) |
| 523 | { | 523 | { |
| 524 | struct task_cputime cputime; | 524 | struct signal_struct *const sig = tsk->signal; |
| 525 | 525 | ||
| 526 | thread_group_cputimer(tsk, &cputime); | ||
| 527 | cleanup_timers(tsk->signal->cpu_timers, | 526 | cleanup_timers(tsk->signal->cpu_timers, |
| 528 | cputime.utime, cputime.stime, cputime.sum_exec_runtime); | 527 | cputime_add(tsk->utime, sig->utime), |
| 528 | cputime_add(tsk->stime, sig->stime), | ||
| 529 | tsk->se.sum_exec_runtime + sig->sum_sched_runtime); | ||
| 529 | } | 530 | } |
| 530 | 531 | ||
| 531 | static void clear_dead_task(struct k_itimer *timer, union cpu_time_count now) | 532 | static void clear_dead_task(struct k_itimer *timer, union cpu_time_count now) |
diff --git a/kernel/posix-timers.c b/kernel/posix-timers.c index 052ec4d195c7..d089d052c4a9 100644 --- a/kernel/posix-timers.c +++ b/kernel/posix-timers.c | |||
| @@ -202,6 +202,12 @@ static int no_timer_create(struct k_itimer *new_timer) | |||
| 202 | return -EOPNOTSUPP; | 202 | return -EOPNOTSUPP; |
| 203 | } | 203 | } |
| 204 | 204 | ||
| 205 | static int no_nsleep(const clockid_t which_clock, int flags, | ||
| 206 | struct timespec *tsave, struct timespec __user *rmtp) | ||
| 207 | { | ||
| 208 | return -EOPNOTSUPP; | ||
| 209 | } | ||
| 210 | |||
| 205 | /* | 211 | /* |
| 206 | * Return nonzero if we know a priori this clockid_t value is bogus. | 212 | * Return nonzero if we know a priori this clockid_t value is bogus. |
| 207 | */ | 213 | */ |
| @@ -254,6 +260,7 @@ static __init int init_posix_timers(void) | |||
| 254 | .clock_get = posix_get_monotonic_raw, | 260 | .clock_get = posix_get_monotonic_raw, |
| 255 | .clock_set = do_posix_clock_nosettime, | 261 | .clock_set = do_posix_clock_nosettime, |
| 256 | .timer_create = no_timer_create, | 262 | .timer_create = no_timer_create, |
| 263 | .nsleep = no_nsleep, | ||
| 257 | }; | 264 | }; |
| 258 | 265 | ||
| 259 | register_posix_clock(CLOCK_REALTIME, &clock_realtime); | 266 | register_posix_clock(CLOCK_REALTIME, &clock_realtime); |
diff --git a/kernel/profile.c b/kernel/profile.c index 69911b5745eb..419250ebec4d 100644 --- a/kernel/profile.c +++ b/kernel/profile.c | |||
| @@ -117,11 +117,12 @@ int __ref profile_init(void) | |||
| 117 | 117 | ||
| 118 | cpumask_copy(prof_cpu_mask, cpu_possible_mask); | 118 | cpumask_copy(prof_cpu_mask, cpu_possible_mask); |
| 119 | 119 | ||
| 120 | prof_buffer = kzalloc(buffer_bytes, GFP_KERNEL); | 120 | prof_buffer = kzalloc(buffer_bytes, GFP_KERNEL|__GFP_NOWARN); |
| 121 | if (prof_buffer) | 121 | if (prof_buffer) |
| 122 | return 0; | 122 | return 0; |
| 123 | 123 | ||
| 124 | prof_buffer = alloc_pages_exact(buffer_bytes, GFP_KERNEL|__GFP_ZERO); | 124 | prof_buffer = alloc_pages_exact(buffer_bytes, |
| 125 | GFP_KERNEL|__GFP_ZERO|__GFP_NOWARN); | ||
| 125 | if (prof_buffer) | 126 | if (prof_buffer) |
| 126 | return 0; | 127 | return 0; |
| 127 | 128 | ||
diff --git a/kernel/rtmutex.c b/kernel/rtmutex.c index fcd107a78c5a..29bd4baf9e75 100644 --- a/kernel/rtmutex.c +++ b/kernel/rtmutex.c | |||
| @@ -1039,16 +1039,14 @@ int rt_mutex_start_proxy_lock(struct rt_mutex *lock, | |||
| 1039 | if (!rt_mutex_owner(lock) || try_to_steal_lock(lock, task)) { | 1039 | if (!rt_mutex_owner(lock) || try_to_steal_lock(lock, task)) { |
| 1040 | /* We got the lock for task. */ | 1040 | /* We got the lock for task. */ |
| 1041 | debug_rt_mutex_lock(lock); | 1041 | debug_rt_mutex_lock(lock); |
| 1042 | |||
| 1043 | rt_mutex_set_owner(lock, task, 0); | 1042 | rt_mutex_set_owner(lock, task, 0); |
| 1044 | 1043 | spin_unlock(&lock->wait_lock); | |
| 1045 | rt_mutex_deadlock_account_lock(lock, task); | 1044 | rt_mutex_deadlock_account_lock(lock, task); |
| 1046 | return 1; | 1045 | return 1; |
| 1047 | } | 1046 | } |
| 1048 | 1047 | ||
| 1049 | ret = task_blocks_on_rt_mutex(lock, waiter, task, detect_deadlock); | 1048 | ret = task_blocks_on_rt_mutex(lock, waiter, task, detect_deadlock); |
| 1050 | 1049 | ||
| 1051 | |||
| 1052 | if (ret && !waiter->task) { | 1050 | if (ret && !waiter->task) { |
| 1053 | /* | 1051 | /* |
| 1054 | * Reset the return value. We might have | 1052 | * Reset the return value. We might have |
diff --git a/kernel/sched.c b/kernel/sched.c index 98972d366fdc..1b59e265273b 100644 --- a/kernel/sched.c +++ b/kernel/sched.c | |||
| @@ -7289,6 +7289,7 @@ static void migrate_dead_tasks(unsigned int dead_cpu) | |||
| 7289 | static void calc_global_load_remove(struct rq *rq) | 7289 | static void calc_global_load_remove(struct rq *rq) |
| 7290 | { | 7290 | { |
| 7291 | atomic_long_sub(rq->calc_load_active, &calc_load_tasks); | 7291 | atomic_long_sub(rq->calc_load_active, &calc_load_tasks); |
| 7292 | rq->calc_load_active = 0; | ||
| 7292 | } | 7293 | } |
| 7293 | #endif /* CONFIG_HOTPLUG_CPU */ | 7294 | #endif /* CONFIG_HOTPLUG_CPU */ |
| 7294 | 7295 | ||
| @@ -7515,6 +7516,7 @@ migration_call(struct notifier_block *nfb, unsigned long action, void *hcpu) | |||
| 7515 | task_rq_unlock(rq, &flags); | 7516 | task_rq_unlock(rq, &flags); |
| 7516 | get_task_struct(p); | 7517 | get_task_struct(p); |
| 7517 | cpu_rq(cpu)->migration_thread = p; | 7518 | cpu_rq(cpu)->migration_thread = p; |
| 7519 | rq->calc_load_update = calc_load_update; | ||
| 7518 | break; | 7520 | break; |
| 7519 | 7521 | ||
| 7520 | case CPU_ONLINE: | 7522 | case CPU_ONLINE: |
| @@ -7525,8 +7527,6 @@ migration_call(struct notifier_block *nfb, unsigned long action, void *hcpu) | |||
| 7525 | /* Update our root-domain */ | 7527 | /* Update our root-domain */ |
| 7526 | rq = cpu_rq(cpu); | 7528 | rq = cpu_rq(cpu); |
| 7527 | spin_lock_irqsave(&rq->lock, flags); | 7529 | spin_lock_irqsave(&rq->lock, flags); |
| 7528 | rq->calc_load_update = calc_load_update; | ||
| 7529 | rq->calc_load_active = 0; | ||
| 7530 | if (rq->rd) { | 7530 | if (rq->rd) { |
| 7531 | BUG_ON(!cpumask_test_cpu(cpu, rq->rd->span)); | 7531 | BUG_ON(!cpumask_test_cpu(cpu, rq->rd->span)); |
| 7532 | 7532 | ||
diff --git a/kernel/sched_cpupri.c b/kernel/sched_cpupri.c index e6c251790dde..d014efbf947a 100644 --- a/kernel/sched_cpupri.c +++ b/kernel/sched_cpupri.c | |||
| @@ -81,8 +81,21 @@ int cpupri_find(struct cpupri *cp, struct task_struct *p, | |||
| 81 | if (cpumask_any_and(&p->cpus_allowed, vec->mask) >= nr_cpu_ids) | 81 | if (cpumask_any_and(&p->cpus_allowed, vec->mask) >= nr_cpu_ids) |
| 82 | continue; | 82 | continue; |
| 83 | 83 | ||
| 84 | if (lowest_mask) | 84 | if (lowest_mask) { |
| 85 | cpumask_and(lowest_mask, &p->cpus_allowed, vec->mask); | 85 | cpumask_and(lowest_mask, &p->cpus_allowed, vec->mask); |
| 86 | |||
| 87 | /* | ||
| 88 | * We have to ensure that we have at least one bit | ||
| 89 | * still set in the array, since the map could have | ||
| 90 | * been concurrently emptied between the first and | ||
| 91 | * second reads of vec->mask. If we hit this | ||
| 92 | * condition, simply act as though we never hit this | ||
| 93 | * priority level and continue on. | ||
| 94 | */ | ||
| 95 | if (cpumask_any(lowest_mask) >= nr_cpu_ids) | ||
| 96 | continue; | ||
| 97 | } | ||
| 98 | |||
| 86 | return 1; | 99 | return 1; |
| 87 | } | 100 | } |
| 88 | 101 | ||
diff --git a/kernel/sched_fair.c b/kernel/sched_fair.c index 7c248dc30f41..652e8bdef9aa 100644 --- a/kernel/sched_fair.c +++ b/kernel/sched_fair.c | |||
| @@ -266,6 +266,12 @@ static inline u64 min_vruntime(u64 min_vruntime, u64 vruntime) | |||
| 266 | return min_vruntime; | 266 | return min_vruntime; |
| 267 | } | 267 | } |
| 268 | 268 | ||
| 269 | static inline int entity_before(struct sched_entity *a, | ||
| 270 | struct sched_entity *b) | ||
| 271 | { | ||
| 272 | return (s64)(a->vruntime - b->vruntime) < 0; | ||
| 273 | } | ||
| 274 | |||
| 269 | static inline s64 entity_key(struct cfs_rq *cfs_rq, struct sched_entity *se) | 275 | static inline s64 entity_key(struct cfs_rq *cfs_rq, struct sched_entity *se) |
| 270 | { | 276 | { |
| 271 | return se->vruntime - cfs_rq->min_vruntime; | 277 | return se->vruntime - cfs_rq->min_vruntime; |
| @@ -605,9 +611,13 @@ account_entity_dequeue(struct cfs_rq *cfs_rq, struct sched_entity *se) | |||
| 605 | static void enqueue_sleeper(struct cfs_rq *cfs_rq, struct sched_entity *se) | 611 | static void enqueue_sleeper(struct cfs_rq *cfs_rq, struct sched_entity *se) |
| 606 | { | 612 | { |
| 607 | #ifdef CONFIG_SCHEDSTATS | 613 | #ifdef CONFIG_SCHEDSTATS |
| 614 | struct task_struct *tsk = NULL; | ||
| 615 | |||
| 616 | if (entity_is_task(se)) | ||
| 617 | tsk = task_of(se); | ||
| 618 | |||
| 608 | if (se->sleep_start) { | 619 | if (se->sleep_start) { |
| 609 | u64 delta = rq_of(cfs_rq)->clock - se->sleep_start; | 620 | u64 delta = rq_of(cfs_rq)->clock - se->sleep_start; |
| 610 | struct task_struct *tsk = task_of(se); | ||
| 611 | 621 | ||
| 612 | if ((s64)delta < 0) | 622 | if ((s64)delta < 0) |
| 613 | delta = 0; | 623 | delta = 0; |
| @@ -618,11 +628,11 @@ static void enqueue_sleeper(struct cfs_rq *cfs_rq, struct sched_entity *se) | |||
| 618 | se->sleep_start = 0; | 628 | se->sleep_start = 0; |
| 619 | se->sum_sleep_runtime += delta; | 629 | se->sum_sleep_runtime += delta; |
| 620 | 630 | ||
| 621 | account_scheduler_latency(tsk, delta >> 10, 1); | 631 | if (tsk) |
| 632 | account_scheduler_latency(tsk, delta >> 10, 1); | ||
| 622 | } | 633 | } |
| 623 | if (se->block_start) { | 634 | if (se->block_start) { |
| 624 | u64 delta = rq_of(cfs_rq)->clock - se->block_start; | 635 | u64 delta = rq_of(cfs_rq)->clock - se->block_start; |
| 625 | struct task_struct *tsk = task_of(se); | ||
| 626 | 636 | ||
| 627 | if ((s64)delta < 0) | 637 | if ((s64)delta < 0) |
| 628 | delta = 0; | 638 | delta = 0; |
| @@ -633,17 +643,19 @@ static void enqueue_sleeper(struct cfs_rq *cfs_rq, struct sched_entity *se) | |||
| 633 | se->block_start = 0; | 643 | se->block_start = 0; |
| 634 | se->sum_sleep_runtime += delta; | 644 | se->sum_sleep_runtime += delta; |
| 635 | 645 | ||
| 636 | /* | 646 | if (tsk) { |
| 637 | * Blocking time is in units of nanosecs, so shift by 20 to | 647 | /* |
| 638 | * get a milliseconds-range estimation of the amount of | 648 | * Blocking time is in units of nanosecs, so shift by |
| 639 | * time that the task spent sleeping: | 649 | * 20 to get a milliseconds-range estimation of the |
| 640 | */ | 650 | * amount of time that the task spent sleeping: |
| 641 | if (unlikely(prof_on == SLEEP_PROFILING)) { | 651 | */ |
| 642 | 652 | if (unlikely(prof_on == SLEEP_PROFILING)) { | |
| 643 | profile_hits(SLEEP_PROFILING, (void *)get_wchan(tsk), | 653 | profile_hits(SLEEP_PROFILING, |
| 644 | delta >> 20); | 654 | (void *)get_wchan(tsk), |
| 655 | delta >> 20); | ||
| 656 | } | ||
| 657 | account_scheduler_latency(tsk, delta >> 10, 0); | ||
| 645 | } | 658 | } |
| 646 | account_scheduler_latency(tsk, delta >> 10, 0); | ||
| 647 | } | 659 | } |
| 648 | #endif | 660 | #endif |
| 649 | } | 661 | } |
| @@ -1017,7 +1029,7 @@ static void yield_task_fair(struct rq *rq) | |||
| 1017 | /* | 1029 | /* |
| 1018 | * Already in the rightmost position? | 1030 | * Already in the rightmost position? |
| 1019 | */ | 1031 | */ |
| 1020 | if (unlikely(!rightmost || rightmost->vruntime < se->vruntime)) | 1032 | if (unlikely(!rightmost || entity_before(rightmost, se))) |
| 1021 | return; | 1033 | return; |
| 1022 | 1034 | ||
| 1023 | /* | 1035 | /* |
| @@ -1713,7 +1725,7 @@ static void task_new_fair(struct rq *rq, struct task_struct *p) | |||
| 1713 | 1725 | ||
| 1714 | /* 'curr' will be NULL if the child belongs to a different group */ | 1726 | /* 'curr' will be NULL if the child belongs to a different group */ |
| 1715 | if (sysctl_sched_child_runs_first && this_cpu == task_cpu(p) && | 1727 | if (sysctl_sched_child_runs_first && this_cpu == task_cpu(p) && |
| 1716 | curr && curr->vruntime < se->vruntime) { | 1728 | curr && entity_before(curr, se)) { |
| 1717 | /* | 1729 | /* |
| 1718 | * Upon rescheduling, sched_class::put_prev_task() will place | 1730 | * Upon rescheduling, sched_class::put_prev_task() will place |
| 1719 | * 'current' within the tree based on its new key value. | 1731 | * 'current' within the tree based on its new key value. |
diff --git a/kernel/signal.c b/kernel/signal.c index ccf1ceedaebe..64c5deeaca5d 100644 --- a/kernel/signal.c +++ b/kernel/signal.c | |||
| @@ -2454,11 +2454,9 @@ do_sigaltstack (const stack_t __user *uss, stack_t __user *uoss, unsigned long s | |||
| 2454 | stack_t oss; | 2454 | stack_t oss; |
| 2455 | int error; | 2455 | int error; |
| 2456 | 2456 | ||
| 2457 | if (uoss) { | 2457 | oss.ss_sp = (void __user *) current->sas_ss_sp; |
| 2458 | oss.ss_sp = (void __user *) current->sas_ss_sp; | 2458 | oss.ss_size = current->sas_ss_size; |
| 2459 | oss.ss_size = current->sas_ss_size; | 2459 | oss.ss_flags = sas_ss_flags(sp); |
| 2460 | oss.ss_flags = sas_ss_flags(sp); | ||
| 2461 | } | ||
| 2462 | 2460 | ||
| 2463 | if (uss) { | 2461 | if (uss) { |
| 2464 | void __user *ss_sp; | 2462 | void __user *ss_sp; |
| @@ -2466,10 +2464,12 @@ do_sigaltstack (const stack_t __user *uss, stack_t __user *uoss, unsigned long s | |||
| 2466 | int ss_flags; | 2464 | int ss_flags; |
| 2467 | 2465 | ||
| 2468 | error = -EFAULT; | 2466 | error = -EFAULT; |
| 2469 | if (!access_ok(VERIFY_READ, uss, sizeof(*uss)) | 2467 | if (!access_ok(VERIFY_READ, uss, sizeof(*uss))) |
| 2470 | || __get_user(ss_sp, &uss->ss_sp) | 2468 | goto out; |
| 2471 | || __get_user(ss_flags, &uss->ss_flags) | 2469 | error = __get_user(ss_sp, &uss->ss_sp) | |
| 2472 | || __get_user(ss_size, &uss->ss_size)) | 2470 | __get_user(ss_flags, &uss->ss_flags) | |
| 2471 | __get_user(ss_size, &uss->ss_size); | ||
| 2472 | if (error) | ||
| 2473 | goto out; | 2473 | goto out; |
| 2474 | 2474 | ||
| 2475 | error = -EPERM; | 2475 | error = -EPERM; |
| @@ -2501,13 +2501,16 @@ do_sigaltstack (const stack_t __user *uss, stack_t __user *uoss, unsigned long s | |||
| 2501 | current->sas_ss_size = ss_size; | 2501 | current->sas_ss_size = ss_size; |
| 2502 | } | 2502 | } |
| 2503 | 2503 | ||
| 2504 | error = 0; | ||
| 2504 | if (uoss) { | 2505 | if (uoss) { |
| 2505 | error = -EFAULT; | 2506 | error = -EFAULT; |
| 2506 | if (copy_to_user(uoss, &oss, sizeof(oss))) | 2507 | if (!access_ok(VERIFY_WRITE, uoss, sizeof(*uoss))) |
| 2507 | goto out; | 2508 | goto out; |
| 2509 | error = __put_user(oss.ss_sp, &uoss->ss_sp) | | ||
| 2510 | __put_user(oss.ss_size, &uoss->ss_size) | | ||
| 2511 | __put_user(oss.ss_flags, &uoss->ss_flags); | ||
| 2508 | } | 2512 | } |
| 2509 | 2513 | ||
| 2510 | error = 0; | ||
| 2511 | out: | 2514 | out: |
| 2512 | return error; | 2515 | return error; |
| 2513 | } | 2516 | } |
diff --git a/kernel/smp.c b/kernel/smp.c index ad63d8501207..94188b8ecc33 100644 --- a/kernel/smp.c +++ b/kernel/smp.c | |||
| @@ -57,7 +57,7 @@ hotplug_cfd(struct notifier_block *nfb, unsigned long action, void *hcpu) | |||
| 57 | return NOTIFY_BAD; | 57 | return NOTIFY_BAD; |
| 58 | break; | 58 | break; |
| 59 | 59 | ||
| 60 | #ifdef CONFIG_CPU_HOTPLUG | 60 | #ifdef CONFIG_HOTPLUG_CPU |
| 61 | case CPU_UP_CANCELED: | 61 | case CPU_UP_CANCELED: |
| 62 | case CPU_UP_CANCELED_FROZEN: | 62 | case CPU_UP_CANCELED_FROZEN: |
| 63 | 63 | ||
diff --git a/kernel/softirq.c b/kernel/softirq.c index 3a94905fa5d2..eb5e131a0485 100644 --- a/kernel/softirq.c +++ b/kernel/softirq.c | |||
| @@ -345,7 +345,9 @@ void open_softirq(int nr, void (*action)(struct softirq_action *)) | |||
| 345 | softirq_vec[nr].action = action; | 345 | softirq_vec[nr].action = action; |
| 346 | } | 346 | } |
| 347 | 347 | ||
| 348 | /* Tasklets */ | 348 | /* |
| 349 | * Tasklets | ||
| 350 | */ | ||
| 349 | struct tasklet_head | 351 | struct tasklet_head |
| 350 | { | 352 | { |
| 351 | struct tasklet_struct *head; | 353 | struct tasklet_struct *head; |
| @@ -493,6 +495,66 @@ void tasklet_kill(struct tasklet_struct *t) | |||
| 493 | 495 | ||
| 494 | EXPORT_SYMBOL(tasklet_kill); | 496 | EXPORT_SYMBOL(tasklet_kill); |
| 495 | 497 | ||
| 498 | /* | ||
| 499 | * tasklet_hrtimer | ||
| 500 | */ | ||
| 501 | |||
| 502 | /* | ||
| 503 | * The trampoline is called when the hrtimer expires. If this is | ||
| 504 | * called from the hrtimer interrupt then we schedule the tasklet as | ||
| 505 | * the timer callback function expects to run in softirq context. If | ||
| 506 | * it's called in softirq context anyway (i.e. high resolution timers | ||
| 507 | * disabled) then the hrtimer callback is called right away. | ||
| 508 | */ | ||
| 509 | static enum hrtimer_restart __hrtimer_tasklet_trampoline(struct hrtimer *timer) | ||
| 510 | { | ||
| 511 | struct tasklet_hrtimer *ttimer = | ||
| 512 | container_of(timer, struct tasklet_hrtimer, timer); | ||
| 513 | |||
| 514 | if (hrtimer_is_hres_active(timer)) { | ||
| 515 | tasklet_hi_schedule(&ttimer->tasklet); | ||
| 516 | return HRTIMER_NORESTART; | ||
| 517 | } | ||
| 518 | return ttimer->function(timer); | ||
| 519 | } | ||
| 520 | |||
| 521 | /* | ||
| 522 | * Helper function which calls the hrtimer callback from | ||
| 523 | * tasklet/softirq context | ||
| 524 | */ | ||
| 525 | static void __tasklet_hrtimer_trampoline(unsigned long data) | ||
| 526 | { | ||
| 527 | struct tasklet_hrtimer *ttimer = (void *)data; | ||
| 528 | enum hrtimer_restart restart; | ||
| 529 | |||
| 530 | restart = ttimer->function(&ttimer->timer); | ||
| 531 | if (restart != HRTIMER_NORESTART) | ||
| 532 | hrtimer_restart(&ttimer->timer); | ||
| 533 | } | ||
| 534 | |||
| 535 | /** | ||
| 536 | * tasklet_hrtimer_init - Init a tasklet/hrtimer combo for softirq callbacks | ||
| 537 | * @ttimer: tasklet_hrtimer which is initialized | ||
| 538 | * @function: hrtimer callback funtion which gets called from softirq context | ||
| 539 | * @which_clock: clock id (CLOCK_MONOTONIC/CLOCK_REALTIME) | ||
| 540 | * @mode: hrtimer mode (HRTIMER_MODE_ABS/HRTIMER_MODE_REL) | ||
| 541 | */ | ||
| 542 | void tasklet_hrtimer_init(struct tasklet_hrtimer *ttimer, | ||
| 543 | enum hrtimer_restart (*function)(struct hrtimer *), | ||
| 544 | clockid_t which_clock, enum hrtimer_mode mode) | ||
| 545 | { | ||
| 546 | hrtimer_init(&ttimer->timer, which_clock, mode); | ||
| 547 | ttimer->timer.function = __hrtimer_tasklet_trampoline; | ||
| 548 | tasklet_init(&ttimer->tasklet, __tasklet_hrtimer_trampoline, | ||
| 549 | (unsigned long)ttimer); | ||
| 550 | ttimer->function = function; | ||
| 551 | } | ||
| 552 | EXPORT_SYMBOL_GPL(tasklet_hrtimer_init); | ||
| 553 | |||
| 554 | /* | ||
| 555 | * Remote softirq bits | ||
| 556 | */ | ||
| 557 | |||
| 496 | DEFINE_PER_CPU(struct list_head [NR_SOFTIRQS], softirq_work_list); | 558 | DEFINE_PER_CPU(struct list_head [NR_SOFTIRQS], softirq_work_list); |
| 497 | EXPORT_PER_CPU_SYMBOL(softirq_work_list); | 559 | EXPORT_PER_CPU_SYMBOL(softirq_work_list); |
| 498 | 560 | ||
diff --git a/kernel/sysctl.c b/kernel/sysctl.c index 98e02328c67d..58be76017fd0 100644 --- a/kernel/sysctl.c +++ b/kernel/sysctl.c | |||
| @@ -49,6 +49,7 @@ | |||
| 49 | #include <linux/acpi.h> | 49 | #include <linux/acpi.h> |
| 50 | #include <linux/reboot.h> | 50 | #include <linux/reboot.h> |
| 51 | #include <linux/ftrace.h> | 51 | #include <linux/ftrace.h> |
| 52 | #include <linux/security.h> | ||
| 52 | #include <linux/slow-work.h> | 53 | #include <linux/slow-work.h> |
| 53 | #include <linux/perf_counter.h> | 54 | #include <linux/perf_counter.h> |
| 54 | 55 | ||
| @@ -1306,10 +1307,10 @@ static struct ctl_table vm_table[] = { | |||
| 1306 | { | 1307 | { |
| 1307 | .ctl_name = CTL_UNNUMBERED, | 1308 | .ctl_name = CTL_UNNUMBERED, |
| 1308 | .procname = "mmap_min_addr", | 1309 | .procname = "mmap_min_addr", |
| 1309 | .data = &mmap_min_addr, | 1310 | .data = &dac_mmap_min_addr, |
| 1310 | .maxlen = sizeof(unsigned long), | 1311 | .maxlen = sizeof(unsigned long), |
| 1311 | .mode = 0644, | 1312 | .mode = 0644, |
| 1312 | .proc_handler = &proc_doulongvec_minmax, | 1313 | .proc_handler = &mmap_min_addr_handler, |
| 1313 | }, | 1314 | }, |
| 1314 | #ifdef CONFIG_NUMA | 1315 | #ifdef CONFIG_NUMA |
| 1315 | { | 1316 | { |
diff --git a/kernel/time/clockevents.c b/kernel/time/clockevents.c index a6dcd67b041d..620b58abdc32 100644 --- a/kernel/time/clockevents.c +++ b/kernel/time/clockevents.c | |||
| @@ -137,11 +137,12 @@ int clockevents_program_event(struct clock_event_device *dev, ktime_t expires, | |||
| 137 | */ | 137 | */ |
| 138 | int clockevents_register_notifier(struct notifier_block *nb) | 138 | int clockevents_register_notifier(struct notifier_block *nb) |
| 139 | { | 139 | { |
| 140 | unsigned long flags; | ||
| 140 | int ret; | 141 | int ret; |
| 141 | 142 | ||
| 142 | spin_lock(&clockevents_lock); | 143 | spin_lock_irqsave(&clockevents_lock, flags); |
| 143 | ret = raw_notifier_chain_register(&clockevents_chain, nb); | 144 | ret = raw_notifier_chain_register(&clockevents_chain, nb); |
| 144 | spin_unlock(&clockevents_lock); | 145 | spin_unlock_irqrestore(&clockevents_lock, flags); |
| 145 | 146 | ||
| 146 | return ret; | 147 | return ret; |
| 147 | } | 148 | } |
| @@ -178,16 +179,18 @@ static void clockevents_notify_released(void) | |||
| 178 | */ | 179 | */ |
| 179 | void clockevents_register_device(struct clock_event_device *dev) | 180 | void clockevents_register_device(struct clock_event_device *dev) |
| 180 | { | 181 | { |
| 182 | unsigned long flags; | ||
| 183 | |||
| 181 | BUG_ON(dev->mode != CLOCK_EVT_MODE_UNUSED); | 184 | BUG_ON(dev->mode != CLOCK_EVT_MODE_UNUSED); |
| 182 | BUG_ON(!dev->cpumask); | 185 | BUG_ON(!dev->cpumask); |
| 183 | 186 | ||
| 184 | spin_lock(&clockevents_lock); | 187 | spin_lock_irqsave(&clockevents_lock, flags); |
| 185 | 188 | ||
| 186 | list_add(&dev->list, &clockevent_devices); | 189 | list_add(&dev->list, &clockevent_devices); |
| 187 | clockevents_do_notify(CLOCK_EVT_NOTIFY_ADD, dev); | 190 | clockevents_do_notify(CLOCK_EVT_NOTIFY_ADD, dev); |
| 188 | clockevents_notify_released(); | 191 | clockevents_notify_released(); |
| 189 | 192 | ||
| 190 | spin_unlock(&clockevents_lock); | 193 | spin_unlock_irqrestore(&clockevents_lock, flags); |
| 191 | } | 194 | } |
| 192 | EXPORT_SYMBOL_GPL(clockevents_register_device); | 195 | EXPORT_SYMBOL_GPL(clockevents_register_device); |
| 193 | 196 | ||
| @@ -235,8 +238,9 @@ void clockevents_exchange_device(struct clock_event_device *old, | |||
| 235 | void clockevents_notify(unsigned long reason, void *arg) | 238 | void clockevents_notify(unsigned long reason, void *arg) |
| 236 | { | 239 | { |
| 237 | struct list_head *node, *tmp; | 240 | struct list_head *node, *tmp; |
| 241 | unsigned long flags; | ||
| 238 | 242 | ||
| 239 | spin_lock(&clockevents_lock); | 243 | spin_lock_irqsave(&clockevents_lock, flags); |
| 240 | clockevents_do_notify(reason, arg); | 244 | clockevents_do_notify(reason, arg); |
| 241 | 245 | ||
| 242 | switch (reason) { | 246 | switch (reason) { |
| @@ -251,7 +255,7 @@ void clockevents_notify(unsigned long reason, void *arg) | |||
| 251 | default: | 255 | default: |
| 252 | break; | 256 | break; |
| 253 | } | 257 | } |
| 254 | spin_unlock(&clockevents_lock); | 258 | spin_unlock_irqrestore(&clockevents_lock, flags); |
| 255 | } | 259 | } |
| 256 | EXPORT_SYMBOL_GPL(clockevents_notify); | 260 | EXPORT_SYMBOL_GPL(clockevents_notify); |
| 257 | #endif | 261 | #endif |
diff --git a/kernel/time/clocksource.c b/kernel/time/clocksource.c index 592bf584d1d2..7466cb811251 100644 --- a/kernel/time/clocksource.c +++ b/kernel/time/clocksource.c | |||
| @@ -513,7 +513,7 @@ static ssize_t sysfs_override_clocksource(struct sys_device *dev, | |||
| 513 | * Check to make sure we don't switch to a non-highres capable | 513 | * Check to make sure we don't switch to a non-highres capable |
| 514 | * clocksource if the tick code is in oneshot mode (highres or nohz) | 514 | * clocksource if the tick code is in oneshot mode (highres or nohz) |
| 515 | */ | 515 | */ |
| 516 | if (tick_oneshot_mode_active() && | 516 | if (tick_oneshot_mode_active() && ovr && |
| 517 | !(ovr->flags & CLOCK_SOURCE_VALID_FOR_HRES)) { | 517 | !(ovr->flags & CLOCK_SOURCE_VALID_FOR_HRES)) { |
| 518 | printk(KERN_WARNING "%s clocksource is not HRT compatible. " | 518 | printk(KERN_WARNING "%s clocksource is not HRT compatible. " |
| 519 | "Cannot switch while in HRT/NOHZ mode\n", ovr->name); | 519 | "Cannot switch while in HRT/NOHZ mode\n", ovr->name); |
diff --git a/kernel/time/tick-broadcast.c b/kernel/time/tick-broadcast.c index 877dbedc3118..c2ec25087a35 100644 --- a/kernel/time/tick-broadcast.c +++ b/kernel/time/tick-broadcast.c | |||
| @@ -205,11 +205,11 @@ static void tick_handle_periodic_broadcast(struct clock_event_device *dev) | |||
| 205 | * Powerstate information: The system enters/leaves a state, where | 205 | * Powerstate information: The system enters/leaves a state, where |
| 206 | * affected devices might stop | 206 | * affected devices might stop |
| 207 | */ | 207 | */ |
| 208 | static void tick_do_broadcast_on_off(void *why) | 208 | static void tick_do_broadcast_on_off(unsigned long *reason) |
| 209 | { | 209 | { |
| 210 | struct clock_event_device *bc, *dev; | 210 | struct clock_event_device *bc, *dev; |
| 211 | struct tick_device *td; | 211 | struct tick_device *td; |
| 212 | unsigned long flags, *reason = why; | 212 | unsigned long flags; |
| 213 | int cpu, bc_stopped; | 213 | int cpu, bc_stopped; |
| 214 | 214 | ||
| 215 | spin_lock_irqsave(&tick_broadcast_lock, flags); | 215 | spin_lock_irqsave(&tick_broadcast_lock, flags); |
| @@ -276,8 +276,7 @@ void tick_broadcast_on_off(unsigned long reason, int *oncpu) | |||
| 276 | printk(KERN_ERR "tick-broadcast: ignoring broadcast for " | 276 | printk(KERN_ERR "tick-broadcast: ignoring broadcast for " |
| 277 | "offline CPU #%d\n", *oncpu); | 277 | "offline CPU #%d\n", *oncpu); |
| 278 | else | 278 | else |
| 279 | smp_call_function_single(*oncpu, tick_do_broadcast_on_off, | 279 | tick_do_broadcast_on_off(&reason); |
| 280 | &reason, 1); | ||
| 281 | } | 280 | } |
| 282 | 281 | ||
| 283 | /* | 282 | /* |
diff --git a/kernel/time/timer_list.c b/kernel/time/timer_list.c index a999b92a1277..fddd69d16e03 100644 --- a/kernel/time/timer_list.c +++ b/kernel/time/timer_list.c | |||
| @@ -286,7 +286,7 @@ static int __init init_timer_list_procfs(void) | |||
| 286 | { | 286 | { |
| 287 | struct proc_dir_entry *pe; | 287 | struct proc_dir_entry *pe; |
| 288 | 288 | ||
| 289 | pe = proc_create("timer_list", 0644, NULL, &timer_list_fops); | 289 | pe = proc_create("timer_list", 0444, NULL, &timer_list_fops); |
| 290 | if (!pe) | 290 | if (!pe) |
| 291 | return -ENOMEM; | 291 | return -ENOMEM; |
| 292 | return 0; | 292 | return 0; |
diff --git a/kernel/timer.c b/kernel/timer.c index 0b36b9e5cc8b..a7f07d5a6241 100644 --- a/kernel/timer.c +++ b/kernel/timer.c | |||
| @@ -714,7 +714,7 @@ int mod_timer(struct timer_list *timer, unsigned long expires) | |||
| 714 | * networking code - if the timer is re-modified | 714 | * networking code - if the timer is re-modified |
| 715 | * to be the same thing then just return: | 715 | * to be the same thing then just return: |
| 716 | */ | 716 | */ |
| 717 | if (timer->expires == expires && timer_pending(timer)) | 717 | if (timer_pending(timer) && timer->expires == expires) |
| 718 | return 1; | 718 | return 1; |
| 719 | 719 | ||
| 720 | return __mod_timer(timer, expires, false, TIMER_NOT_PINNED); | 720 | return __mod_timer(timer, expires, false, TIMER_NOT_PINNED); |
diff --git a/kernel/trace/blktrace.c b/kernel/trace/blktrace.c index 1090b0aed9ba..7a34cb563fec 100644 --- a/kernel/trace/blktrace.c +++ b/kernel/trace/blktrace.c | |||
| @@ -267,8 +267,8 @@ static void blk_trace_free(struct blk_trace *bt) | |||
| 267 | { | 267 | { |
| 268 | debugfs_remove(bt->msg_file); | 268 | debugfs_remove(bt->msg_file); |
| 269 | debugfs_remove(bt->dropped_file); | 269 | debugfs_remove(bt->dropped_file); |
| 270 | debugfs_remove(bt->dir); | ||
| 271 | relay_close(bt->rchan); | 270 | relay_close(bt->rchan); |
| 271 | debugfs_remove(bt->dir); | ||
| 272 | free_percpu(bt->sequence); | 272 | free_percpu(bt->sequence); |
| 273 | free_percpu(bt->msg_data); | 273 | free_percpu(bt->msg_data); |
| 274 | kfree(bt); | 274 | kfree(bt); |
| @@ -378,18 +378,8 @@ static int blk_subbuf_start_callback(struct rchan_buf *buf, void *subbuf, | |||
| 378 | 378 | ||
| 379 | static int blk_remove_buf_file_callback(struct dentry *dentry) | 379 | static int blk_remove_buf_file_callback(struct dentry *dentry) |
| 380 | { | 380 | { |
| 381 | struct dentry *parent = dentry->d_parent; | ||
| 382 | debugfs_remove(dentry); | 381 | debugfs_remove(dentry); |
| 383 | 382 | ||
| 384 | /* | ||
| 385 | * this will fail for all but the last file, but that is ok. what we | ||
| 386 | * care about is the top level buts->name directory going away, when | ||
| 387 | * the last trace file is gone. Then we don't have to rmdir() that | ||
| 388 | * manually on trace stop, so it nicely solves the issue with | ||
| 389 | * force killing of running traces. | ||
| 390 | */ | ||
| 391 | |||
| 392 | debugfs_remove(parent); | ||
| 393 | return 0; | 383 | return 0; |
| 394 | } | 384 | } |
| 395 | 385 | ||
diff --git a/kernel/trace/ftrace.c b/kernel/trace/ftrace.c index 4521c77d1a1a..25edd5cc5935 100644 --- a/kernel/trace/ftrace.c +++ b/kernel/trace/ftrace.c | |||
| @@ -1662,7 +1662,7 @@ ftrace_regex_open(struct inode *inode, struct file *file, int enable) | |||
| 1662 | 1662 | ||
| 1663 | mutex_lock(&ftrace_regex_lock); | 1663 | mutex_lock(&ftrace_regex_lock); |
| 1664 | if ((file->f_mode & FMODE_WRITE) && | 1664 | if ((file->f_mode & FMODE_WRITE) && |
| 1665 | !(file->f_flags & O_APPEND)) | 1665 | (file->f_flags & O_TRUNC)) |
| 1666 | ftrace_filter_reset(enable); | 1666 | ftrace_filter_reset(enable); |
| 1667 | 1667 | ||
| 1668 | if (file->f_mode & FMODE_READ) { | 1668 | if (file->f_mode & FMODE_READ) { |
| @@ -2278,7 +2278,11 @@ ftrace_regex_write(struct file *file, const char __user *ubuf, | |||
| 2278 | read++; | 2278 | read++; |
| 2279 | cnt--; | 2279 | cnt--; |
| 2280 | 2280 | ||
| 2281 | if (!(iter->flags & ~FTRACE_ITER_CONT)) { | 2281 | /* |
| 2282 | * If the parser haven't finished with the last write, | ||
| 2283 | * continue reading the user input without skipping spaces. | ||
| 2284 | */ | ||
| 2285 | if (!(iter->flags & FTRACE_ITER_CONT)) { | ||
| 2282 | /* skip white space */ | 2286 | /* skip white space */ |
| 2283 | while (cnt && isspace(ch)) { | 2287 | while (cnt && isspace(ch)) { |
| 2284 | ret = get_user(ch, ubuf++); | 2288 | ret = get_user(ch, ubuf++); |
| @@ -2288,8 +2292,9 @@ ftrace_regex_write(struct file *file, const char __user *ubuf, | |||
| 2288 | cnt--; | 2292 | cnt--; |
| 2289 | } | 2293 | } |
| 2290 | 2294 | ||
| 2295 | /* only spaces were written */ | ||
| 2291 | if (isspace(ch)) { | 2296 | if (isspace(ch)) { |
| 2292 | file->f_pos += read; | 2297 | *ppos += read; |
| 2293 | ret = read; | 2298 | ret = read; |
| 2294 | goto out; | 2299 | goto out; |
| 2295 | } | 2300 | } |
| @@ -2319,12 +2324,12 @@ ftrace_regex_write(struct file *file, const char __user *ubuf, | |||
| 2319 | if (ret) | 2324 | if (ret) |
| 2320 | goto out; | 2325 | goto out; |
| 2321 | iter->buffer_idx = 0; | 2326 | iter->buffer_idx = 0; |
| 2322 | } else | 2327 | } else { |
| 2323 | iter->flags |= FTRACE_ITER_CONT; | 2328 | iter->flags |= FTRACE_ITER_CONT; |
| 2329 | iter->buffer[iter->buffer_idx++] = ch; | ||
| 2330 | } | ||
| 2324 | 2331 | ||
| 2325 | 2332 | *ppos += read; | |
| 2326 | file->f_pos += read; | ||
| 2327 | |||
| 2328 | ret = read; | 2333 | ret = read; |
| 2329 | out: | 2334 | out: |
| 2330 | mutex_unlock(&ftrace_regex_lock); | 2335 | mutex_unlock(&ftrace_regex_lock); |
| @@ -2577,7 +2582,7 @@ ftrace_graph_open(struct inode *inode, struct file *file) | |||
| 2577 | 2582 | ||
| 2578 | mutex_lock(&graph_lock); | 2583 | mutex_lock(&graph_lock); |
| 2579 | if ((file->f_mode & FMODE_WRITE) && | 2584 | if ((file->f_mode & FMODE_WRITE) && |
| 2580 | !(file->f_flags & O_APPEND)) { | 2585 | (file->f_flags & O_TRUNC)) { |
| 2581 | ftrace_graph_count = 0; | 2586 | ftrace_graph_count = 0; |
| 2582 | memset(ftrace_graph_funcs, 0, sizeof(ftrace_graph_funcs)); | 2587 | memset(ftrace_graph_funcs, 0, sizeof(ftrace_graph_funcs)); |
| 2583 | } | 2588 | } |
| @@ -2596,6 +2601,14 @@ ftrace_graph_open(struct inode *inode, struct file *file) | |||
| 2596 | } | 2601 | } |
| 2597 | 2602 | ||
| 2598 | static int | 2603 | static int |
| 2604 | ftrace_graph_release(struct inode *inode, struct file *file) | ||
| 2605 | { | ||
| 2606 | if (file->f_mode & FMODE_READ) | ||
| 2607 | seq_release(inode, file); | ||
| 2608 | return 0; | ||
| 2609 | } | ||
| 2610 | |||
| 2611 | static int | ||
| 2599 | ftrace_set_func(unsigned long *array, int *idx, char *buffer) | 2612 | ftrace_set_func(unsigned long *array, int *idx, char *buffer) |
| 2600 | { | 2613 | { |
| 2601 | struct dyn_ftrace *rec; | 2614 | struct dyn_ftrace *rec; |
| @@ -2724,9 +2737,10 @@ ftrace_graph_write(struct file *file, const char __user *ubuf, | |||
| 2724 | } | 2737 | } |
| 2725 | 2738 | ||
| 2726 | static const struct file_operations ftrace_graph_fops = { | 2739 | static const struct file_operations ftrace_graph_fops = { |
| 2727 | .open = ftrace_graph_open, | 2740 | .open = ftrace_graph_open, |
| 2728 | .read = seq_read, | 2741 | .read = seq_read, |
| 2729 | .write = ftrace_graph_write, | 2742 | .write = ftrace_graph_write, |
| 2743 | .release = ftrace_graph_release, | ||
| 2730 | }; | 2744 | }; |
| 2731 | #endif /* CONFIG_FUNCTION_GRAPH_TRACER */ | 2745 | #endif /* CONFIG_FUNCTION_GRAPH_TRACER */ |
| 2732 | 2746 | ||
diff --git a/kernel/trace/ring_buffer.c b/kernel/trace/ring_buffer.c index bf27bb7a63e2..a330513d96ce 100644 --- a/kernel/trace/ring_buffer.c +++ b/kernel/trace/ring_buffer.c | |||
| @@ -735,6 +735,7 @@ ring_buffer_free(struct ring_buffer *buffer) | |||
| 735 | 735 | ||
| 736 | put_online_cpus(); | 736 | put_online_cpus(); |
| 737 | 737 | ||
| 738 | kfree(buffer->buffers); | ||
| 738 | free_cpumask_var(buffer->cpumask); | 739 | free_cpumask_var(buffer->cpumask); |
| 739 | 740 | ||
| 740 | kfree(buffer); | 741 | kfree(buffer); |
| @@ -1785,7 +1786,7 @@ void ring_buffer_discard_commit(struct ring_buffer *buffer, | |||
| 1785 | */ | 1786 | */ |
| 1786 | RB_WARN_ON(buffer, !local_read(&cpu_buffer->committing)); | 1787 | RB_WARN_ON(buffer, !local_read(&cpu_buffer->committing)); |
| 1787 | 1788 | ||
| 1788 | if (!rb_try_to_discard(cpu_buffer, event)) | 1789 | if (rb_try_to_discard(cpu_buffer, event)) |
| 1789 | goto out; | 1790 | goto out; |
| 1790 | 1791 | ||
| 1791 | /* | 1792 | /* |
| @@ -2383,7 +2384,6 @@ rb_buffer_peek(struct ring_buffer *buffer, int cpu, u64 *ts) | |||
| 2383 | * the box. Return the padding, and we will release | 2384 | * the box. Return the padding, and we will release |
| 2384 | * the current locks, and try again. | 2385 | * the current locks, and try again. |
| 2385 | */ | 2386 | */ |
| 2386 | rb_advance_reader(cpu_buffer); | ||
| 2387 | return event; | 2387 | return event; |
| 2388 | 2388 | ||
| 2389 | case RINGBUF_TYPE_TIME_EXTEND: | 2389 | case RINGBUF_TYPE_TIME_EXTEND: |
| @@ -2486,7 +2486,7 @@ static inline int rb_ok_to_lock(void) | |||
| 2486 | * buffer too. A one time deal is all you get from reading | 2486 | * buffer too. A one time deal is all you get from reading |
| 2487 | * the ring buffer from an NMI. | 2487 | * the ring buffer from an NMI. |
| 2488 | */ | 2488 | */ |
| 2489 | if (likely(!in_nmi() && !oops_in_progress)) | 2489 | if (likely(!in_nmi())) |
| 2490 | return 1; | 2490 | return 1; |
| 2491 | 2491 | ||
| 2492 | tracing_off_permanent(); | 2492 | tracing_off_permanent(); |
| @@ -2519,6 +2519,8 @@ ring_buffer_peek(struct ring_buffer *buffer, int cpu, u64 *ts) | |||
| 2519 | if (dolock) | 2519 | if (dolock) |
| 2520 | spin_lock(&cpu_buffer->reader_lock); | 2520 | spin_lock(&cpu_buffer->reader_lock); |
| 2521 | event = rb_buffer_peek(buffer, cpu, ts); | 2521 | event = rb_buffer_peek(buffer, cpu, ts); |
| 2522 | if (event && event->type_len == RINGBUF_TYPE_PADDING) | ||
| 2523 | rb_advance_reader(cpu_buffer); | ||
| 2522 | if (dolock) | 2524 | if (dolock) |
| 2523 | spin_unlock(&cpu_buffer->reader_lock); | 2525 | spin_unlock(&cpu_buffer->reader_lock); |
| 2524 | local_irq_restore(flags); | 2526 | local_irq_restore(flags); |
| @@ -2590,12 +2592,9 @@ ring_buffer_consume(struct ring_buffer *buffer, int cpu, u64 *ts) | |||
| 2590 | spin_lock(&cpu_buffer->reader_lock); | 2592 | spin_lock(&cpu_buffer->reader_lock); |
| 2591 | 2593 | ||
| 2592 | event = rb_buffer_peek(buffer, cpu, ts); | 2594 | event = rb_buffer_peek(buffer, cpu, ts); |
| 2593 | if (!event) | 2595 | if (event) |
| 2594 | goto out_unlock; | 2596 | rb_advance_reader(cpu_buffer); |
| 2595 | |||
| 2596 | rb_advance_reader(cpu_buffer); | ||
| 2597 | 2597 | ||
| 2598 | out_unlock: | ||
| 2599 | if (dolock) | 2598 | if (dolock) |
| 2600 | spin_unlock(&cpu_buffer->reader_lock); | 2599 | spin_unlock(&cpu_buffer->reader_lock); |
| 2601 | local_irq_restore(flags); | 2600 | local_irq_restore(flags); |
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c index 8bc8d8afea6a..8c358395d338 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c | |||
| @@ -848,6 +848,7 @@ tracing_generic_entry_update(struct trace_entry *entry, unsigned long flags, | |||
| 848 | ((pc & SOFTIRQ_MASK) ? TRACE_FLAG_SOFTIRQ : 0) | | 848 | ((pc & SOFTIRQ_MASK) ? TRACE_FLAG_SOFTIRQ : 0) | |
| 849 | (need_resched() ? TRACE_FLAG_NEED_RESCHED : 0); | 849 | (need_resched() ? TRACE_FLAG_NEED_RESCHED : 0); |
| 850 | } | 850 | } |
| 851 | EXPORT_SYMBOL_GPL(tracing_generic_entry_update); | ||
| 851 | 852 | ||
| 852 | struct ring_buffer_event *trace_buffer_lock_reserve(struct trace_array *tr, | 853 | struct ring_buffer_event *trace_buffer_lock_reserve(struct trace_array *tr, |
| 853 | int type, | 854 | int type, |
| @@ -2031,7 +2032,7 @@ static int tracing_open(struct inode *inode, struct file *file) | |||
| 2031 | 2032 | ||
| 2032 | /* If this file was open for write, then erase contents */ | 2033 | /* If this file was open for write, then erase contents */ |
| 2033 | if ((file->f_mode & FMODE_WRITE) && | 2034 | if ((file->f_mode & FMODE_WRITE) && |
| 2034 | !(file->f_flags & O_APPEND)) { | 2035 | (file->f_flags & O_TRUNC)) { |
| 2035 | long cpu = (long) inode->i_private; | 2036 | long cpu = (long) inode->i_private; |
| 2036 | 2037 | ||
| 2037 | if (cpu == TRACE_PIPE_ALL_CPU) | 2038 | if (cpu == TRACE_PIPE_ALL_CPU) |
| @@ -3085,7 +3086,8 @@ tracing_fill_pipe_page(size_t rem, struct trace_iterator *iter) | |||
| 3085 | break; | 3086 | break; |
| 3086 | } | 3087 | } |
| 3087 | 3088 | ||
| 3088 | trace_consume(iter); | 3089 | if (ret != TRACE_TYPE_NO_CONSUME) |
| 3090 | trace_consume(iter); | ||
| 3089 | rem -= count; | 3091 | rem -= count; |
| 3090 | if (!find_next_entry_inc(iter)) { | 3092 | if (!find_next_entry_inc(iter)) { |
| 3091 | rem = 0; | 3093 | rem = 0; |
| @@ -3894,17 +3896,9 @@ trace_options_core_write(struct file *filp, const char __user *ubuf, size_t cnt, | |||
| 3894 | if (ret < 0) | 3896 | if (ret < 0) |
| 3895 | return ret; | 3897 | return ret; |
| 3896 | 3898 | ||
| 3897 | switch (val) { | 3899 | if (val != 0 && val != 1) |
| 3898 | case 0: | ||
| 3899 | trace_flags &= ~(1 << index); | ||
| 3900 | break; | ||
| 3901 | case 1: | ||
| 3902 | trace_flags |= 1 << index; | ||
| 3903 | break; | ||
| 3904 | |||
| 3905 | default: | ||
| 3906 | return -EINVAL; | 3900 | return -EINVAL; |
| 3907 | } | 3901 | set_tracer_flags(1 << index, val); |
| 3908 | 3902 | ||
| 3909 | *ppos += cnt; | 3903 | *ppos += cnt; |
| 3910 | 3904 | ||
| @@ -4233,8 +4227,11 @@ static void __ftrace_dump(bool disable_tracing) | |||
| 4233 | iter.pos = -1; | 4227 | iter.pos = -1; |
| 4234 | 4228 | ||
| 4235 | if (find_next_entry_inc(&iter) != NULL) { | 4229 | if (find_next_entry_inc(&iter) != NULL) { |
| 4236 | print_trace_line(&iter); | 4230 | int ret; |
| 4237 | trace_consume(&iter); | 4231 | |
| 4232 | ret = print_trace_line(&iter); | ||
| 4233 | if (ret != TRACE_TYPE_NO_CONSUME) | ||
| 4234 | trace_consume(&iter); | ||
| 4238 | } | 4235 | } |
| 4239 | 4236 | ||
| 4240 | trace_printk_seq(&iter.seq); | 4237 | trace_printk_seq(&iter.seq); |
diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h index 3548ae5cc780..8b9f4f6e9559 100644 --- a/kernel/trace/trace.h +++ b/kernel/trace/trace.h | |||
| @@ -438,10 +438,6 @@ struct trace_entry *tracing_get_trace_entry(struct trace_array *tr, | |||
| 438 | struct trace_entry *trace_find_next_entry(struct trace_iterator *iter, | 438 | struct trace_entry *trace_find_next_entry(struct trace_iterator *iter, |
| 439 | int *ent_cpu, u64 *ent_ts); | 439 | int *ent_cpu, u64 *ent_ts); |
| 440 | 440 | ||
| 441 | void tracing_generic_entry_update(struct trace_entry *entry, | ||
| 442 | unsigned long flags, | ||
| 443 | int pc); | ||
| 444 | |||
| 445 | void default_wait_pipe(struct trace_iterator *iter); | 441 | void default_wait_pipe(struct trace_iterator *iter); |
| 446 | void poll_wait_pipe(struct trace_iterator *iter); | 442 | void poll_wait_pipe(struct trace_iterator *iter); |
| 447 | 443 | ||
diff --git a/kernel/trace/trace_event_profile.c b/kernel/trace/trace_event_profile.c index 5b5895afecfe..11ba5bb4ed0a 100644 --- a/kernel/trace/trace_event_profile.c +++ b/kernel/trace/trace_event_profile.c | |||
| @@ -14,7 +14,7 @@ int ftrace_profile_enable(int event_id) | |||
| 14 | 14 | ||
| 15 | mutex_lock(&event_mutex); | 15 | mutex_lock(&event_mutex); |
| 16 | list_for_each_entry(event, &ftrace_events, list) { | 16 | list_for_each_entry(event, &ftrace_events, list) { |
| 17 | if (event->id == event_id) { | 17 | if (event->id == event_id && event->profile_enable) { |
| 18 | ret = event->profile_enable(event); | 18 | ret = event->profile_enable(event); |
| 19 | break; | 19 | break; |
| 20 | } | 20 | } |
diff --git a/kernel/trace/trace_events.c b/kernel/trace/trace_events.c index 53c8fd376a88..e75276a49cf5 100644 --- a/kernel/trace/trace_events.c +++ b/kernel/trace/trace_events.c | |||
| @@ -376,7 +376,7 @@ ftrace_event_seq_open(struct inode *inode, struct file *file) | |||
| 376 | const struct seq_operations *seq_ops; | 376 | const struct seq_operations *seq_ops; |
| 377 | 377 | ||
| 378 | if ((file->f_mode & FMODE_WRITE) && | 378 | if ((file->f_mode & FMODE_WRITE) && |
| 379 | !(file->f_flags & O_APPEND)) | 379 | (file->f_flags & O_TRUNC)) |
| 380 | ftrace_clear_events(); | 380 | ftrace_clear_events(); |
| 381 | 381 | ||
| 382 | seq_ops = inode->i_private; | 382 | seq_ops = inode->i_private; |
| @@ -940,7 +940,7 @@ event_create_dir(struct ftrace_event_call *call, struct dentry *d_events, | |||
| 940 | entry = trace_create_file("enable", 0644, call->dir, call, | 940 | entry = trace_create_file("enable", 0644, call->dir, call, |
| 941 | enable); | 941 | enable); |
| 942 | 942 | ||
| 943 | if (call->id) | 943 | if (call->id && call->profile_enable) |
| 944 | entry = trace_create_file("id", 0444, call->dir, call, | 944 | entry = trace_create_file("id", 0444, call->dir, call, |
| 945 | id); | 945 | id); |
| 946 | 946 | ||
diff --git a/kernel/trace/trace_events_filter.c b/kernel/trace/trace_events_filter.c index 936c621bbf46..f32dc9d1ea7b 100644 --- a/kernel/trace/trace_events_filter.c +++ b/kernel/trace/trace_events_filter.c | |||
| @@ -624,9 +624,6 @@ static int filter_add_subsystem_pred(struct filter_parse_state *ps, | |||
| 624 | return -ENOSPC; | 624 | return -ENOSPC; |
| 625 | } | 625 | } |
| 626 | 626 | ||
| 627 | filter->preds[filter->n_preds] = pred; | ||
| 628 | filter->n_preds++; | ||
| 629 | |||
| 630 | list_for_each_entry(call, &ftrace_events, list) { | 627 | list_for_each_entry(call, &ftrace_events, list) { |
| 631 | 628 | ||
| 632 | if (!call->define_fields) | 629 | if (!call->define_fields) |
| @@ -643,6 +640,9 @@ static int filter_add_subsystem_pred(struct filter_parse_state *ps, | |||
| 643 | } | 640 | } |
| 644 | replace_filter_string(call->filter, filter_string); | 641 | replace_filter_string(call->filter, filter_string); |
| 645 | } | 642 | } |
| 643 | |||
| 644 | filter->preds[filter->n_preds] = pred; | ||
| 645 | filter->n_preds++; | ||
| 646 | out: | 646 | out: |
| 647 | return err; | 647 | return err; |
| 648 | } | 648 | } |
| @@ -1029,12 +1029,17 @@ static int replace_preds(struct event_subsystem *system, | |||
| 1029 | 1029 | ||
| 1030 | if (elt->op == OP_AND || elt->op == OP_OR) { | 1030 | if (elt->op == OP_AND || elt->op == OP_OR) { |
| 1031 | pred = create_logical_pred(elt->op); | 1031 | pred = create_logical_pred(elt->op); |
| 1032 | if (!pred) | ||
| 1033 | return -ENOMEM; | ||
| 1032 | if (call) { | 1034 | if (call) { |
| 1033 | err = filter_add_pred(ps, call, pred); | 1035 | err = filter_add_pred(ps, call, pred); |
| 1034 | filter_free_pred(pred); | 1036 | filter_free_pred(pred); |
| 1035 | } else | 1037 | } else { |
| 1036 | err = filter_add_subsystem_pred(ps, system, | 1038 | err = filter_add_subsystem_pred(ps, system, |
| 1037 | pred, filter_string); | 1039 | pred, filter_string); |
| 1040 | if (err) | ||
| 1041 | filter_free_pred(pred); | ||
| 1042 | } | ||
| 1038 | if (err) | 1043 | if (err) |
| 1039 | return err; | 1044 | return err; |
| 1040 | 1045 | ||
| @@ -1048,12 +1053,17 @@ static int replace_preds(struct event_subsystem *system, | |||
| 1048 | } | 1053 | } |
| 1049 | 1054 | ||
| 1050 | pred = create_pred(elt->op, operand1, operand2); | 1055 | pred = create_pred(elt->op, operand1, operand2); |
| 1056 | if (!pred) | ||
| 1057 | return -ENOMEM; | ||
| 1051 | if (call) { | 1058 | if (call) { |
| 1052 | err = filter_add_pred(ps, call, pred); | 1059 | err = filter_add_pred(ps, call, pred); |
| 1053 | filter_free_pred(pred); | 1060 | filter_free_pred(pred); |
| 1054 | } else | 1061 | } else { |
| 1055 | err = filter_add_subsystem_pred(ps, system, pred, | 1062 | err = filter_add_subsystem_pred(ps, system, pred, |
| 1056 | filter_string); | 1063 | filter_string); |
| 1064 | if (err) | ||
| 1065 | filter_free_pred(pred); | ||
| 1066 | } | ||
| 1057 | if (err) | 1067 | if (err) |
| 1058 | return err; | 1068 | return err; |
| 1059 | 1069 | ||
diff --git a/kernel/trace/trace_functions_graph.c b/kernel/trace/trace_functions_graph.c index d2249abafb53..420ec3487579 100644 --- a/kernel/trace/trace_functions_graph.c +++ b/kernel/trace/trace_functions_graph.c | |||
| @@ -843,9 +843,16 @@ print_graph_function(struct trace_iterator *iter) | |||
| 843 | 843 | ||
| 844 | switch (entry->type) { | 844 | switch (entry->type) { |
| 845 | case TRACE_GRAPH_ENT: { | 845 | case TRACE_GRAPH_ENT: { |
| 846 | struct ftrace_graph_ent_entry *field; | 846 | /* |
| 847 | * print_graph_entry() may consume the current event, | ||
| 848 | * thus @field may become invalid, so we need to save it. | ||
| 849 | * sizeof(struct ftrace_graph_ent_entry) is very small, | ||
| 850 | * it can be safely saved at the stack. | ||
| 851 | */ | ||
| 852 | struct ftrace_graph_ent_entry *field, saved; | ||
| 847 | trace_assign_type(field, entry); | 853 | trace_assign_type(field, entry); |
| 848 | return print_graph_entry(field, s, iter); | 854 | saved = *field; |
| 855 | return print_graph_entry(&saved, s, iter); | ||
| 849 | } | 856 | } |
| 850 | case TRACE_GRAPH_RET: { | 857 | case TRACE_GRAPH_RET: { |
| 851 | struct ftrace_graph_ret_entry *field; | 858 | struct ftrace_graph_ret_entry *field; |
diff --git a/kernel/trace/trace_printk.c b/kernel/trace/trace_printk.c index 7b6278110827..687699d365ae 100644 --- a/kernel/trace/trace_printk.c +++ b/kernel/trace/trace_printk.c | |||
| @@ -176,7 +176,7 @@ static int t_show(struct seq_file *m, void *v) | |||
| 176 | const char *str = *fmt; | 176 | const char *str = *fmt; |
| 177 | int i; | 177 | int i; |
| 178 | 178 | ||
| 179 | seq_printf(m, "0x%lx : \"", (unsigned long)fmt); | 179 | seq_printf(m, "0x%lx : \"", *(unsigned long *)fmt); |
| 180 | 180 | ||
| 181 | /* | 181 | /* |
| 182 | * Tabs and new lines need to be converted. | 182 | * Tabs and new lines need to be converted. |
diff --git a/kernel/trace/trace_stack.c b/kernel/trace/trace_stack.c index e644af910124..6a2a9d484cd6 100644 --- a/kernel/trace/trace_stack.c +++ b/kernel/trace/trace_stack.c | |||
| @@ -301,17 +301,14 @@ static const struct seq_operations stack_trace_seq_ops = { | |||
| 301 | 301 | ||
| 302 | static int stack_trace_open(struct inode *inode, struct file *file) | 302 | static int stack_trace_open(struct inode *inode, struct file *file) |
| 303 | { | 303 | { |
| 304 | int ret; | 304 | return seq_open(file, &stack_trace_seq_ops); |
| 305 | |||
| 306 | ret = seq_open(file, &stack_trace_seq_ops); | ||
| 307 | |||
| 308 | return ret; | ||
| 309 | } | 305 | } |
| 310 | 306 | ||
| 311 | static const struct file_operations stack_trace_fops = { | 307 | static const struct file_operations stack_trace_fops = { |
| 312 | .open = stack_trace_open, | 308 | .open = stack_trace_open, |
| 313 | .read = seq_read, | 309 | .read = seq_read, |
| 314 | .llseek = seq_lseek, | 310 | .llseek = seq_lseek, |
| 311 | .release = seq_release, | ||
| 315 | }; | 312 | }; |
| 316 | 313 | ||
| 317 | int | 314 | int |
diff --git a/kernel/trace/trace_stat.c b/kernel/trace/trace_stat.c index e66f5e493342..aea321c82fa0 100644 --- a/kernel/trace/trace_stat.c +++ b/kernel/trace/trace_stat.c | |||
| @@ -73,7 +73,7 @@ static struct rb_node *release_next(struct rb_node *node) | |||
| 73 | } | 73 | } |
| 74 | } | 74 | } |
| 75 | 75 | ||
| 76 | static void reset_stat_session(struct stat_session *session) | 76 | static void __reset_stat_session(struct stat_session *session) |
| 77 | { | 77 | { |
| 78 | struct rb_node *node = session->stat_root.rb_node; | 78 | struct rb_node *node = session->stat_root.rb_node; |
| 79 | 79 | ||
| @@ -83,10 +83,17 @@ static void reset_stat_session(struct stat_session *session) | |||
| 83 | session->stat_root = RB_ROOT; | 83 | session->stat_root = RB_ROOT; |
| 84 | } | 84 | } |
| 85 | 85 | ||
| 86 | static void reset_stat_session(struct stat_session *session) | ||
| 87 | { | ||
| 88 | mutex_lock(&session->stat_mutex); | ||
| 89 | __reset_stat_session(session); | ||
| 90 | mutex_unlock(&session->stat_mutex); | ||
| 91 | } | ||
| 92 | |||
| 86 | static void destroy_session(struct stat_session *session) | 93 | static void destroy_session(struct stat_session *session) |
| 87 | { | 94 | { |
| 88 | debugfs_remove(session->file); | 95 | debugfs_remove(session->file); |
| 89 | reset_stat_session(session); | 96 | __reset_stat_session(session); |
| 90 | mutex_destroy(&session->stat_mutex); | 97 | mutex_destroy(&session->stat_mutex); |
| 91 | kfree(session); | 98 | kfree(session); |
| 92 | } | 99 | } |
| @@ -150,7 +157,7 @@ static int stat_seq_init(struct stat_session *session) | |||
| 150 | int i; | 157 | int i; |
| 151 | 158 | ||
| 152 | mutex_lock(&session->stat_mutex); | 159 | mutex_lock(&session->stat_mutex); |
| 153 | reset_stat_session(session); | 160 | __reset_stat_session(session); |
| 154 | 161 | ||
| 155 | if (!ts->stat_cmp) | 162 | if (!ts->stat_cmp) |
| 156 | ts->stat_cmp = dummy_cmp; | 163 | ts->stat_cmp = dummy_cmp; |
| @@ -183,7 +190,7 @@ exit: | |||
| 183 | return ret; | 190 | return ret; |
| 184 | 191 | ||
| 185 | exit_free_rbtree: | 192 | exit_free_rbtree: |
| 186 | reset_stat_session(session); | 193 | __reset_stat_session(session); |
| 187 | mutex_unlock(&session->stat_mutex); | 194 | mutex_unlock(&session->stat_mutex); |
| 188 | return ret; | 195 | return ret; |
| 189 | } | 196 | } |
| @@ -250,16 +257,21 @@ static const struct seq_operations trace_stat_seq_ops = { | |||
| 250 | static int tracing_stat_open(struct inode *inode, struct file *file) | 257 | static int tracing_stat_open(struct inode *inode, struct file *file) |
| 251 | { | 258 | { |
| 252 | int ret; | 259 | int ret; |
| 253 | 260 | struct seq_file *m; | |
| 254 | struct stat_session *session = inode->i_private; | 261 | struct stat_session *session = inode->i_private; |
| 255 | 262 | ||
| 263 | ret = stat_seq_init(session); | ||
| 264 | if (ret) | ||
| 265 | return ret; | ||
| 266 | |||
| 256 | ret = seq_open(file, &trace_stat_seq_ops); | 267 | ret = seq_open(file, &trace_stat_seq_ops); |
| 257 | if (!ret) { | 268 | if (ret) { |
| 258 | struct seq_file *m = file->private_data; | 269 | reset_stat_session(session); |
| 259 | m->private = session; | 270 | return ret; |
| 260 | ret = stat_seq_init(session); | ||
| 261 | } | 271 | } |
| 262 | 272 | ||
| 273 | m = file->private_data; | ||
| 274 | m->private = session; | ||
| 263 | return ret; | 275 | return ret; |
| 264 | } | 276 | } |
| 265 | 277 | ||
| @@ -270,11 +282,9 @@ static int tracing_stat_release(struct inode *i, struct file *f) | |||
| 270 | { | 282 | { |
| 271 | struct stat_session *session = i->i_private; | 283 | struct stat_session *session = i->i_private; |
| 272 | 284 | ||
| 273 | mutex_lock(&session->stat_mutex); | ||
| 274 | reset_stat_session(session); | 285 | reset_stat_session(session); |
| 275 | mutex_unlock(&session->stat_mutex); | ||
| 276 | 286 | ||
| 277 | return 0; | 287 | return seq_release(i, f); |
| 278 | } | 288 | } |
| 279 | 289 | ||
| 280 | static const struct file_operations tracing_stat_fops = { | 290 | static const struct file_operations tracing_stat_fops = { |
diff --git a/kernel/wait.c b/kernel/wait.c index ea7c3b4275cf..c4bd3d825f35 100644 --- a/kernel/wait.c +++ b/kernel/wait.c | |||
| @@ -10,13 +10,14 @@ | |||
| 10 | #include <linux/wait.h> | 10 | #include <linux/wait.h> |
| 11 | #include <linux/hash.h> | 11 | #include <linux/hash.h> |
| 12 | 12 | ||
| 13 | void init_waitqueue_head(wait_queue_head_t *q) | 13 | void __init_waitqueue_head(wait_queue_head_t *q, struct lock_class_key *key) |
| 14 | { | 14 | { |
| 15 | spin_lock_init(&q->lock); | 15 | spin_lock_init(&q->lock); |
| 16 | lockdep_set_class(&q->lock, key); | ||
| 16 | INIT_LIST_HEAD(&q->task_list); | 17 | INIT_LIST_HEAD(&q->task_list); |
| 17 | } | 18 | } |
| 18 | 19 | ||
| 19 | EXPORT_SYMBOL(init_waitqueue_head); | 20 | EXPORT_SYMBOL(__init_waitqueue_head); |
| 20 | 21 | ||
| 21 | void add_wait_queue(wait_queue_head_t *q, wait_queue_t *wait) | 22 | void add_wait_queue(wait_queue_head_t *q, wait_queue_t *wait) |
| 22 | { | 23 | { |
diff --git a/lib/Makefile b/lib/Makefile index b6d1857bbf08..2e78277eff9d 100644 --- a/lib/Makefile +++ b/lib/Makefile | |||
| @@ -12,7 +12,7 @@ lib-y := ctype.o string.o vsprintf.o cmdline.o \ | |||
| 12 | idr.o int_sqrt.o extable.o prio_tree.o \ | 12 | idr.o int_sqrt.o extable.o prio_tree.o \ |
| 13 | sha1.o irq_regs.o reciprocal_div.o argv_split.o \ | 13 | sha1.o irq_regs.o reciprocal_div.o argv_split.o \ |
| 14 | proportions.o prio_heap.o ratelimit.o show_mem.o \ | 14 | proportions.o prio_heap.o ratelimit.o show_mem.o \ |
| 15 | is_single_threaded.o plist.o decompress.o | 15 | is_single_threaded.o plist.o decompress.o flex_array.o |
| 16 | 16 | ||
| 17 | lib-$(CONFIG_MMU) += ioremap.o | 17 | lib-$(CONFIG_MMU) += ioremap.o |
| 18 | lib-$(CONFIG_SMP) += cpumask.o | 18 | lib-$(CONFIG_SMP) += cpumask.o |
diff --git a/lib/atomic64.c b/lib/atomic64.c index c5e725562416..8bee16ec7524 100644 --- a/lib/atomic64.c +++ b/lib/atomic64.c | |||
| @@ -13,6 +13,7 @@ | |||
| 13 | #include <linux/cache.h> | 13 | #include <linux/cache.h> |
| 14 | #include <linux/spinlock.h> | 14 | #include <linux/spinlock.h> |
| 15 | #include <linux/init.h> | 15 | #include <linux/init.h> |
| 16 | #include <linux/module.h> | ||
| 16 | #include <asm/atomic.h> | 17 | #include <asm/atomic.h> |
| 17 | 18 | ||
| 18 | /* | 19 | /* |
| @@ -52,6 +53,7 @@ long long atomic64_read(const atomic64_t *v) | |||
| 52 | spin_unlock_irqrestore(lock, flags); | 53 | spin_unlock_irqrestore(lock, flags); |
| 53 | return val; | 54 | return val; |
| 54 | } | 55 | } |
| 56 | EXPORT_SYMBOL(atomic64_read); | ||
| 55 | 57 | ||
| 56 | void atomic64_set(atomic64_t *v, long long i) | 58 | void atomic64_set(atomic64_t *v, long long i) |
| 57 | { | 59 | { |
| @@ -62,6 +64,7 @@ void atomic64_set(atomic64_t *v, long long i) | |||
| 62 | v->counter = i; | 64 | v->counter = i; |
| 63 | spin_unlock_irqrestore(lock, flags); | 65 | spin_unlock_irqrestore(lock, flags); |
| 64 | } | 66 | } |
| 67 | EXPORT_SYMBOL(atomic64_set); | ||
| 65 | 68 | ||
| 66 | void atomic64_add(long long a, atomic64_t *v) | 69 | void atomic64_add(long long a, atomic64_t *v) |
| 67 | { | 70 | { |
| @@ -72,6 +75,7 @@ void atomic64_add(long long a, atomic64_t *v) | |||
| 72 | v->counter += a; | 75 | v->counter += a; |
| 73 | spin_unlock_irqrestore(lock, flags); | 76 | spin_unlock_irqrestore(lock, flags); |
| 74 | } | 77 | } |
| 78 | EXPORT_SYMBOL(atomic64_add); | ||
| 75 | 79 | ||
| 76 | long long atomic64_add_return(long long a, atomic64_t *v) | 80 | long long atomic64_add_return(long long a, atomic64_t *v) |
| 77 | { | 81 | { |
| @@ -84,6 +88,7 @@ long long atomic64_add_return(long long a, atomic64_t *v) | |||
| 84 | spin_unlock_irqrestore(lock, flags); | 88 | spin_unlock_irqrestore(lock, flags); |
| 85 | return val; | 89 | return val; |
| 86 | } | 90 | } |
| 91 | EXPORT_SYMBOL(atomic64_add_return); | ||
| 87 | 92 | ||
| 88 | void atomic64_sub(long long a, atomic64_t *v) | 93 | void atomic64_sub(long long a, atomic64_t *v) |
| 89 | { | 94 | { |
| @@ -94,6 +99,7 @@ void atomic64_sub(long long a, atomic64_t *v) | |||
| 94 | v->counter -= a; | 99 | v->counter -= a; |
| 95 | spin_unlock_irqrestore(lock, flags); | 100 | spin_unlock_irqrestore(lock, flags); |
| 96 | } | 101 | } |
| 102 | EXPORT_SYMBOL(atomic64_sub); | ||
| 97 | 103 | ||
| 98 | long long atomic64_sub_return(long long a, atomic64_t *v) | 104 | long long atomic64_sub_return(long long a, atomic64_t *v) |
| 99 | { | 105 | { |
| @@ -106,6 +112,7 @@ long long atomic64_sub_return(long long a, atomic64_t *v) | |||
| 106 | spin_unlock_irqrestore(lock, flags); | 112 | spin_unlock_irqrestore(lock, flags); |
| 107 | return val; | 113 | return val; |
| 108 | } | 114 | } |
| 115 | EXPORT_SYMBOL(atomic64_sub_return); | ||
| 109 | 116 | ||
| 110 | long long atomic64_dec_if_positive(atomic64_t *v) | 117 | long long atomic64_dec_if_positive(atomic64_t *v) |
| 111 | { | 118 | { |
| @@ -120,6 +127,7 @@ long long atomic64_dec_if_positive(atomic64_t *v) | |||
| 120 | spin_unlock_irqrestore(lock, flags); | 127 | spin_unlock_irqrestore(lock, flags); |
| 121 | return val; | 128 | return val; |
| 122 | } | 129 | } |
| 130 | EXPORT_SYMBOL(atomic64_dec_if_positive); | ||
| 123 | 131 | ||
| 124 | long long atomic64_cmpxchg(atomic64_t *v, long long o, long long n) | 132 | long long atomic64_cmpxchg(atomic64_t *v, long long o, long long n) |
| 125 | { | 133 | { |
| @@ -134,6 +142,7 @@ long long atomic64_cmpxchg(atomic64_t *v, long long o, long long n) | |||
| 134 | spin_unlock_irqrestore(lock, flags); | 142 | spin_unlock_irqrestore(lock, flags); |
| 135 | return val; | 143 | return val; |
| 136 | } | 144 | } |
| 145 | EXPORT_SYMBOL(atomic64_cmpxchg); | ||
| 137 | 146 | ||
| 138 | long long atomic64_xchg(atomic64_t *v, long long new) | 147 | long long atomic64_xchg(atomic64_t *v, long long new) |
| 139 | { | 148 | { |
| @@ -147,6 +156,7 @@ long long atomic64_xchg(atomic64_t *v, long long new) | |||
| 147 | spin_unlock_irqrestore(lock, flags); | 156 | spin_unlock_irqrestore(lock, flags); |
| 148 | return val; | 157 | return val; |
| 149 | } | 158 | } |
| 159 | EXPORT_SYMBOL(atomic64_xchg); | ||
| 150 | 160 | ||
| 151 | int atomic64_add_unless(atomic64_t *v, long long a, long long u) | 161 | int atomic64_add_unless(atomic64_t *v, long long a, long long u) |
| 152 | { | 162 | { |
| @@ -162,6 +172,7 @@ int atomic64_add_unless(atomic64_t *v, long long a, long long u) | |||
| 162 | spin_unlock_irqrestore(lock, flags); | 172 | spin_unlock_irqrestore(lock, flags); |
| 163 | return ret; | 173 | return ret; |
| 164 | } | 174 | } |
| 175 | EXPORT_SYMBOL(atomic64_add_unless); | ||
| 165 | 176 | ||
| 166 | static int init_atomic64_lock(void) | 177 | static int init_atomic64_lock(void) |
| 167 | { | 178 | { |
diff --git a/lib/bitmap.c b/lib/bitmap.c index 35a1f7ff4149..702565821c99 100644 --- a/lib/bitmap.c +++ b/lib/bitmap.c | |||
| @@ -179,14 +179,16 @@ void __bitmap_shift_left(unsigned long *dst, | |||
| 179 | } | 179 | } |
| 180 | EXPORT_SYMBOL(__bitmap_shift_left); | 180 | EXPORT_SYMBOL(__bitmap_shift_left); |
| 181 | 181 | ||
| 182 | void __bitmap_and(unsigned long *dst, const unsigned long *bitmap1, | 182 | int __bitmap_and(unsigned long *dst, const unsigned long *bitmap1, |
| 183 | const unsigned long *bitmap2, int bits) | 183 | const unsigned long *bitmap2, int bits) |
| 184 | { | 184 | { |
| 185 | int k; | 185 | int k; |
| 186 | int nr = BITS_TO_LONGS(bits); | 186 | int nr = BITS_TO_LONGS(bits); |
| 187 | unsigned long result = 0; | ||
| 187 | 188 | ||
| 188 | for (k = 0; k < nr; k++) | 189 | for (k = 0; k < nr; k++) |
| 189 | dst[k] = bitmap1[k] & bitmap2[k]; | 190 | result |= (dst[k] = bitmap1[k] & bitmap2[k]); |
| 191 | return result != 0; | ||
| 190 | } | 192 | } |
| 191 | EXPORT_SYMBOL(__bitmap_and); | 193 | EXPORT_SYMBOL(__bitmap_and); |
| 192 | 194 | ||
| @@ -212,14 +214,16 @@ void __bitmap_xor(unsigned long *dst, const unsigned long *bitmap1, | |||
| 212 | } | 214 | } |
| 213 | EXPORT_SYMBOL(__bitmap_xor); | 215 | EXPORT_SYMBOL(__bitmap_xor); |
| 214 | 216 | ||
| 215 | void __bitmap_andnot(unsigned long *dst, const unsigned long *bitmap1, | 217 | int __bitmap_andnot(unsigned long *dst, const unsigned long *bitmap1, |
| 216 | const unsigned long *bitmap2, int bits) | 218 | const unsigned long *bitmap2, int bits) |
| 217 | { | 219 | { |
| 218 | int k; | 220 | int k; |
| 219 | int nr = BITS_TO_LONGS(bits); | 221 | int nr = BITS_TO_LONGS(bits); |
| 222 | unsigned long result = 0; | ||
| 220 | 223 | ||
| 221 | for (k = 0; k < nr; k++) | 224 | for (k = 0; k < nr; k++) |
| 222 | dst[k] = bitmap1[k] & ~bitmap2[k]; | 225 | result |= (dst[k] = bitmap1[k] & ~bitmap2[k]); |
| 226 | return result != 0; | ||
| 223 | } | 227 | } |
| 224 | EXPORT_SYMBOL(__bitmap_andnot); | 228 | EXPORT_SYMBOL(__bitmap_andnot); |
| 225 | 229 | ||
diff --git a/lib/decompress_bunzip2.c b/lib/decompress_bunzip2.c index 708e2a86d87b..600f473a5610 100644 --- a/lib/decompress_bunzip2.c +++ b/lib/decompress_bunzip2.c | |||
| @@ -45,12 +45,14 @@ | |||
| 45 | */ | 45 | */ |
| 46 | 46 | ||
| 47 | 47 | ||
| 48 | #ifndef STATIC | 48 | #ifdef STATIC |
| 49 | #define PREBOOT | ||
| 50 | #else | ||
| 49 | #include <linux/decompress/bunzip2.h> | 51 | #include <linux/decompress/bunzip2.h> |
| 50 | #endif /* !STATIC */ | 52 | #include <linux/slab.h> |
| 53 | #endif /* STATIC */ | ||
| 51 | 54 | ||
| 52 | #include <linux/decompress/mm.h> | 55 | #include <linux/decompress/mm.h> |
| 53 | #include <linux/slab.h> | ||
| 54 | 56 | ||
| 55 | #ifndef INT_MAX | 57 | #ifndef INT_MAX |
| 56 | #define INT_MAX 0x7fffffff | 58 | #define INT_MAX 0x7fffffff |
| @@ -681,9 +683,7 @@ STATIC int INIT bunzip2(unsigned char *buf, int len, | |||
| 681 | set_error_fn(error_fn); | 683 | set_error_fn(error_fn); |
| 682 | if (flush) | 684 | if (flush) |
| 683 | outbuf = malloc(BZIP2_IOBUF_SIZE); | 685 | outbuf = malloc(BZIP2_IOBUF_SIZE); |
| 684 | else | 686 | |
| 685 | len -= 4; /* Uncompressed size hack active in pre-boot | ||
| 686 | environment */ | ||
| 687 | if (!outbuf) { | 687 | if (!outbuf) { |
| 688 | error("Could not allocate output bufer"); | 688 | error("Could not allocate output bufer"); |
| 689 | return -1; | 689 | return -1; |
| @@ -733,4 +733,14 @@ exit_0: | |||
| 733 | return i; | 733 | return i; |
| 734 | } | 734 | } |
| 735 | 735 | ||
| 736 | #define decompress bunzip2 | 736 | #ifdef PREBOOT |
| 737 | STATIC int INIT decompress(unsigned char *buf, int len, | ||
| 738 | int(*fill)(void*, unsigned int), | ||
| 739 | int(*flush)(void*, unsigned int), | ||
| 740 | unsigned char *outbuf, | ||
| 741 | int *pos, | ||
| 742 | void(*error_fn)(char *x)) | ||
| 743 | { | ||
| 744 | return bunzip2(buf, len - 4, fill, flush, outbuf, pos, error_fn); | ||
| 745 | } | ||
| 746 | #endif | ||
diff --git a/lib/decompress_inflate.c b/lib/decompress_inflate.c index e36b296fc9f8..68dfce59c1b8 100644 --- a/lib/decompress_inflate.c +++ b/lib/decompress_inflate.c | |||
| @@ -19,13 +19,13 @@ | |||
| 19 | #include "zlib_inflate/inflate.h" | 19 | #include "zlib_inflate/inflate.h" |
| 20 | 20 | ||
| 21 | #include "zlib_inflate/infutil.h" | 21 | #include "zlib_inflate/infutil.h" |
| 22 | #include <linux/slab.h> | ||
| 22 | 23 | ||
| 23 | #endif /* STATIC */ | 24 | #endif /* STATIC */ |
| 24 | 25 | ||
| 25 | #include <linux/decompress/mm.h> | 26 | #include <linux/decompress/mm.h> |
| 26 | #include <linux/slab.h> | ||
| 27 | 27 | ||
| 28 | #define INBUF_LEN (16*1024) | 28 | #define GZIP_IOBUF_SIZE (16*1024) |
| 29 | 29 | ||
| 30 | /* Included from initramfs et al code */ | 30 | /* Included from initramfs et al code */ |
| 31 | STATIC int INIT gunzip(unsigned char *buf, int len, | 31 | STATIC int INIT gunzip(unsigned char *buf, int len, |
| @@ -55,7 +55,7 @@ STATIC int INIT gunzip(unsigned char *buf, int len, | |||
| 55 | if (buf) | 55 | if (buf) |
| 56 | zbuf = buf; | 56 | zbuf = buf; |
| 57 | else { | 57 | else { |
| 58 | zbuf = malloc(INBUF_LEN); | 58 | zbuf = malloc(GZIP_IOBUF_SIZE); |
| 59 | len = 0; | 59 | len = 0; |
| 60 | } | 60 | } |
| 61 | if (!zbuf) { | 61 | if (!zbuf) { |
| @@ -77,7 +77,7 @@ STATIC int INIT gunzip(unsigned char *buf, int len, | |||
| 77 | } | 77 | } |
| 78 | 78 | ||
| 79 | if (len == 0) | 79 | if (len == 0) |
| 80 | len = fill(zbuf, INBUF_LEN); | 80 | len = fill(zbuf, GZIP_IOBUF_SIZE); |
| 81 | 81 | ||
| 82 | /* verify the gzip header */ | 82 | /* verify the gzip header */ |
| 83 | if (len < 10 || | 83 | if (len < 10 || |
| @@ -113,7 +113,7 @@ STATIC int INIT gunzip(unsigned char *buf, int len, | |||
| 113 | while (rc == Z_OK) { | 113 | while (rc == Z_OK) { |
| 114 | if (strm->avail_in == 0) { | 114 | if (strm->avail_in == 0) { |
| 115 | /* TODO: handle case where both pos and fill are set */ | 115 | /* TODO: handle case where both pos and fill are set */ |
| 116 | len = fill(zbuf, INBUF_LEN); | 116 | len = fill(zbuf, GZIP_IOBUF_SIZE); |
| 117 | if (len < 0) { | 117 | if (len < 0) { |
| 118 | rc = -1; | 118 | rc = -1; |
| 119 | error("read error"); | 119 | error("read error"); |
diff --git a/lib/decompress_unlzma.c b/lib/decompress_unlzma.c index 32123a1340e6..0b954e04bd30 100644 --- a/lib/decompress_unlzma.c +++ b/lib/decompress_unlzma.c | |||
| @@ -29,12 +29,14 @@ | |||
| 29 | *Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA | 29 | *Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
| 30 | */ | 30 | */ |
| 31 | 31 | ||
| 32 | #ifndef STATIC | 32 | #ifdef STATIC |
| 33 | #define PREBOOT | ||
| 34 | #else | ||
| 33 | #include <linux/decompress/unlzma.h> | 35 | #include <linux/decompress/unlzma.h> |
| 36 | #include <linux/slab.h> | ||
| 34 | #endif /* STATIC */ | 37 | #endif /* STATIC */ |
| 35 | 38 | ||
| 36 | #include <linux/decompress/mm.h> | 39 | #include <linux/decompress/mm.h> |
| 37 | #include <linux/slab.h> | ||
| 38 | 40 | ||
| 39 | #define MIN(a, b) (((a) < (b)) ? (a) : (b)) | 41 | #define MIN(a, b) (((a) < (b)) ? (a) : (b)) |
| 40 | 42 | ||
| @@ -543,9 +545,7 @@ STATIC inline int INIT unlzma(unsigned char *buf, int in_len, | |||
| 543 | int ret = -1; | 545 | int ret = -1; |
| 544 | 546 | ||
| 545 | set_error_fn(error_fn); | 547 | set_error_fn(error_fn); |
| 546 | if (!flush) | 548 | |
| 547 | in_len -= 4; /* Uncompressed size hack active in pre-boot | ||
| 548 | environment */ | ||
| 549 | if (buf) | 549 | if (buf) |
| 550 | inbuf = buf; | 550 | inbuf = buf; |
| 551 | else | 551 | else |
| @@ -645,4 +645,15 @@ exit_0: | |||
| 645 | return ret; | 645 | return ret; |
| 646 | } | 646 | } |
| 647 | 647 | ||
| 648 | #define decompress unlzma | 648 | #ifdef PREBOOT |
| 649 | STATIC int INIT decompress(unsigned char *buf, int in_len, | ||
| 650 | int(*fill)(void*, unsigned int), | ||
| 651 | int(*flush)(void*, unsigned int), | ||
| 652 | unsigned char *output, | ||
| 653 | int *posp, | ||
| 654 | void(*error_fn)(char *x) | ||
| 655 | ) | ||
| 656 | { | ||
| 657 | return unlzma(buf, in_len - 4, fill, flush, output, posp, error_fn); | ||
| 658 | } | ||
| 659 | #endif | ||
diff --git a/lib/dma-debug.c b/lib/dma-debug.c index 65b0d99b6d0a..58a9f9fc609a 100644 --- a/lib/dma-debug.c +++ b/lib/dma-debug.c | |||
| @@ -156,9 +156,13 @@ static bool driver_filter(struct device *dev) | |||
| 156 | return true; | 156 | return true; |
| 157 | 157 | ||
| 158 | /* driver filter on and initialized */ | 158 | /* driver filter on and initialized */ |
| 159 | if (current_driver && dev->driver == current_driver) | 159 | if (current_driver && dev && dev->driver == current_driver) |
| 160 | return true; | 160 | return true; |
| 161 | 161 | ||
| 162 | /* driver filter on, but we can't filter on a NULL device... */ | ||
| 163 | if (!dev) | ||
| 164 | return false; | ||
| 165 | |||
| 162 | if (current_driver || !current_driver_name[0]) | 166 | if (current_driver || !current_driver_name[0]) |
| 163 | return false; | 167 | return false; |
| 164 | 168 | ||
| @@ -183,17 +187,17 @@ static bool driver_filter(struct device *dev) | |||
| 183 | return ret; | 187 | return ret; |
| 184 | } | 188 | } |
| 185 | 189 | ||
| 186 | #define err_printk(dev, entry, format, arg...) do { \ | 190 | #define err_printk(dev, entry, format, arg...) do { \ |
| 187 | error_count += 1; \ | 191 | error_count += 1; \ |
| 188 | if (driver_filter(dev) && \ | 192 | if (driver_filter(dev) && \ |
| 189 | (show_all_errors || show_num_errors > 0)) { \ | 193 | (show_all_errors || show_num_errors > 0)) { \ |
| 190 | WARN(1, "%s %s: " format, \ | 194 | WARN(1, "%s %s: " format, \ |
| 191 | dev_driver_string(dev), \ | 195 | dev ? dev_driver_string(dev) : "NULL", \ |
| 192 | dev_name(dev) , ## arg); \ | 196 | dev ? dev_name(dev) : "NULL", ## arg); \ |
| 193 | dump_entry_trace(entry); \ | 197 | dump_entry_trace(entry); \ |
| 194 | } \ | 198 | } \ |
| 195 | if (!show_all_errors && show_num_errors > 0) \ | 199 | if (!show_all_errors && show_num_errors > 0) \ |
| 196 | show_num_errors -= 1; \ | 200 | show_num_errors -= 1; \ |
| 197 | } while (0); | 201 | } while (0); |
| 198 | 202 | ||
| 199 | /* | 203 | /* |
diff --git a/lib/dynamic_debug.c b/lib/dynamic_debug.c index 833139ce1e22..e22c148e4b7f 100644 --- a/lib/dynamic_debug.c +++ b/lib/dynamic_debug.c | |||
| @@ -164,7 +164,7 @@ static void ddebug_change(const struct ddebug_query *query, | |||
| 164 | 164 | ||
| 165 | if (!newflags) | 165 | if (!newflags) |
| 166 | dt->num_enabled--; | 166 | dt->num_enabled--; |
| 167 | else if (!dp-flags) | 167 | else if (!dp->flags) |
| 168 | dt->num_enabled++; | 168 | dt->num_enabled++; |
| 169 | dp->flags = newflags; | 169 | dp->flags = newflags; |
| 170 | if (newflags) { | 170 | if (newflags) { |
diff --git a/lib/flex_array.c b/lib/flex_array.c new file mode 100644 index 000000000000..7baed2fc3bc8 --- /dev/null +++ b/lib/flex_array.c | |||
| @@ -0,0 +1,268 @@ | |||
| 1 | /* | ||
| 2 | * Flexible array managed in PAGE_SIZE parts | ||
| 3 | * | ||
| 4 | * This program is free software; you can redistribute it and/or modify | ||
| 5 | * it under the terms of the GNU General Public License as published by | ||
| 6 | * the Free Software Foundation; either version 2 of the License, or | ||
| 7 | * (at your option) any later version. | ||
| 8 | * | ||
| 9 | * This program is distributed in the hope that it will be useful, | ||
| 10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 12 | * GNU General Public License for more details. | ||
| 13 | * | ||
| 14 | * You should have received a copy of the GNU General Public License | ||
| 15 | * along with this program; if not, write to the Free Software | ||
| 16 | * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | ||
| 17 | * | ||
| 18 | * Copyright IBM Corporation, 2009 | ||
| 19 | * | ||
| 20 | * Author: Dave Hansen <dave@linux.vnet.ibm.com> | ||
| 21 | */ | ||
| 22 | |||
| 23 | #include <linux/flex_array.h> | ||
| 24 | #include <linux/slab.h> | ||
| 25 | #include <linux/stddef.h> | ||
| 26 | |||
| 27 | struct flex_array_part { | ||
| 28 | char elements[FLEX_ARRAY_PART_SIZE]; | ||
| 29 | }; | ||
| 30 | |||
| 31 | static inline int __elements_per_part(int element_size) | ||
| 32 | { | ||
| 33 | return FLEX_ARRAY_PART_SIZE / element_size; | ||
| 34 | } | ||
| 35 | |||
| 36 | static inline int bytes_left_in_base(void) | ||
| 37 | { | ||
| 38 | int element_offset = offsetof(struct flex_array, parts); | ||
| 39 | int bytes_left = FLEX_ARRAY_BASE_SIZE - element_offset; | ||
| 40 | return bytes_left; | ||
| 41 | } | ||
| 42 | |||
| 43 | static inline int nr_base_part_ptrs(void) | ||
| 44 | { | ||
| 45 | return bytes_left_in_base() / sizeof(struct flex_array_part *); | ||
| 46 | } | ||
| 47 | |||
| 48 | /* | ||
| 49 | * If a user requests an allocation which is small | ||
| 50 | * enough, we may simply use the space in the | ||
| 51 | * flex_array->parts[] array to store the user | ||
| 52 | * data. | ||
| 53 | */ | ||
| 54 | static inline int elements_fit_in_base(struct flex_array *fa) | ||
| 55 | { | ||
| 56 | int data_size = fa->element_size * fa->total_nr_elements; | ||
| 57 | if (data_size <= bytes_left_in_base()) | ||
| 58 | return 1; | ||
| 59 | return 0; | ||
| 60 | } | ||
| 61 | |||
| 62 | /** | ||
| 63 | * flex_array_alloc - allocate a new flexible array | ||
| 64 | * @element_size: the size of individual elements in the array | ||
| 65 | * @total: total number of elements that this should hold | ||
| 66 | * | ||
| 67 | * Note: all locking must be provided by the caller. | ||
| 68 | * | ||
| 69 | * @total is used to size internal structures. If the user ever | ||
| 70 | * accesses any array indexes >=@total, it will produce errors. | ||
| 71 | * | ||
| 72 | * The maximum number of elements is defined as: the number of | ||
| 73 | * elements that can be stored in a page times the number of | ||
| 74 | * page pointers that we can fit in the base structure or (using | ||
| 75 | * integer math): | ||
| 76 | * | ||
| 77 | * (PAGE_SIZE/element_size) * (PAGE_SIZE-8)/sizeof(void *) | ||
| 78 | * | ||
| 79 | * Here's a table showing example capacities. Note that the maximum | ||
| 80 | * index that the get/put() functions is just nr_objects-1. This | ||
| 81 | * basically means that you get 4MB of storage on 32-bit and 2MB on | ||
| 82 | * 64-bit. | ||
| 83 | * | ||
| 84 | * | ||
| 85 | * Element size | Objects | Objects | | ||
| 86 | * PAGE_SIZE=4k | 32-bit | 64-bit | | ||
| 87 | * ---------------------------------| | ||
| 88 | * 1 bytes | 4186112 | 2093056 | | ||
| 89 | * 2 bytes | 2093056 | 1046528 | | ||
| 90 | * 3 bytes | 1395030 | 697515 | | ||
| 91 | * 4 bytes | 1046528 | 523264 | | ||
| 92 | * 32 bytes | 130816 | 65408 | | ||
| 93 | * 33 bytes | 126728 | 63364 | | ||
| 94 | * 2048 bytes | 2044 | 1022 | | ||
| 95 | * 2049 bytes | 1022 | 511 | | ||
| 96 | * void * | 1046528 | 261632 | | ||
| 97 | * | ||
| 98 | * Since 64-bit pointers are twice the size, we lose half the | ||
| 99 | * capacity in the base structure. Also note that no effort is made | ||
| 100 | * to efficiently pack objects across page boundaries. | ||
| 101 | */ | ||
| 102 | struct flex_array *flex_array_alloc(int element_size, unsigned int total, | ||
| 103 | gfp_t flags) | ||
| 104 | { | ||
| 105 | struct flex_array *ret; | ||
| 106 | int max_size = nr_base_part_ptrs() * __elements_per_part(element_size); | ||
| 107 | |||
| 108 | /* max_size will end up 0 if element_size > PAGE_SIZE */ | ||
| 109 | if (total > max_size) | ||
| 110 | return NULL; | ||
| 111 | ret = kzalloc(sizeof(struct flex_array), flags); | ||
| 112 | if (!ret) | ||
| 113 | return NULL; | ||
| 114 | ret->element_size = element_size; | ||
| 115 | ret->total_nr_elements = total; | ||
| 116 | return ret; | ||
| 117 | } | ||
| 118 | |||
| 119 | static int fa_element_to_part_nr(struct flex_array *fa, | ||
| 120 | unsigned int element_nr) | ||
| 121 | { | ||
| 122 | return element_nr / __elements_per_part(fa->element_size); | ||
| 123 | } | ||
| 124 | |||
| 125 | /** | ||
| 126 | * flex_array_free_parts - just free the second-level pages | ||
| 127 | * | ||
| 128 | * This is to be used in cases where the base 'struct flex_array' | ||
| 129 | * has been statically allocated and should not be free. | ||
| 130 | */ | ||
| 131 | void flex_array_free_parts(struct flex_array *fa) | ||
| 132 | { | ||
| 133 | int part_nr; | ||
| 134 | int max_part = nr_base_part_ptrs(); | ||
| 135 | |||
| 136 | if (elements_fit_in_base(fa)) | ||
| 137 | return; | ||
| 138 | for (part_nr = 0; part_nr < max_part; part_nr++) | ||
| 139 | kfree(fa->parts[part_nr]); | ||
| 140 | } | ||
| 141 | |||
| 142 | void flex_array_free(struct flex_array *fa) | ||
| 143 | { | ||
| 144 | flex_array_free_parts(fa); | ||
| 145 | kfree(fa); | ||
| 146 | } | ||
| 147 | |||
| 148 | static unsigned int index_inside_part(struct flex_array *fa, | ||
| 149 | unsigned int element_nr) | ||
| 150 | { | ||
| 151 | unsigned int part_offset; | ||
| 152 | |||
| 153 | part_offset = element_nr % __elements_per_part(fa->element_size); | ||
| 154 | return part_offset * fa->element_size; | ||
| 155 | } | ||
| 156 | |||
| 157 | static struct flex_array_part * | ||
| 158 | __fa_get_part(struct flex_array *fa, int part_nr, gfp_t flags) | ||
| 159 | { | ||
| 160 | struct flex_array_part *part = fa->parts[part_nr]; | ||
| 161 | if (!part) { | ||
| 162 | /* | ||
| 163 | * This leaves the part pages uninitialized | ||
| 164 | * and with potentially random data, just | ||
| 165 | * as if the user had kmalloc()'d the whole. | ||
| 166 | * __GFP_ZERO can be used to zero it. | ||
| 167 | */ | ||
| 168 | part = kmalloc(FLEX_ARRAY_PART_SIZE, flags); | ||
| 169 | if (!part) | ||
| 170 | return NULL; | ||
| 171 | fa->parts[part_nr] = part; | ||
| 172 | } | ||
| 173 | return part; | ||
| 174 | } | ||
| 175 | |||
| 176 | /** | ||
| 177 | * flex_array_put - copy data into the array at @element_nr | ||
| 178 | * @src: address of data to copy into the array | ||
| 179 | * @element_nr: index of the position in which to insert | ||
| 180 | * the new element. | ||
| 181 | * | ||
| 182 | * Note that this *copies* the contents of @src into | ||
| 183 | * the array. If you are trying to store an array of | ||
| 184 | * pointers, make sure to pass in &ptr instead of ptr. | ||
| 185 | * | ||
| 186 | * Locking must be provided by the caller. | ||
| 187 | */ | ||
| 188 | int flex_array_put(struct flex_array *fa, unsigned int element_nr, void *src, | ||
| 189 | gfp_t flags) | ||
| 190 | { | ||
| 191 | int part_nr = fa_element_to_part_nr(fa, element_nr); | ||
| 192 | struct flex_array_part *part; | ||
| 193 | void *dst; | ||
| 194 | |||
| 195 | if (element_nr >= fa->total_nr_elements) | ||
| 196 | return -ENOSPC; | ||
| 197 | if (elements_fit_in_base(fa)) | ||
| 198 | part = (struct flex_array_part *)&fa->parts[0]; | ||
| 199 | else { | ||
| 200 | part = __fa_get_part(fa, part_nr, flags); | ||
| 201 | if (!part) | ||
| 202 | return -ENOMEM; | ||
| 203 | } | ||
| 204 | dst = &part->elements[index_inside_part(fa, element_nr)]; | ||
| 205 | memcpy(dst, src, fa->element_size); | ||
| 206 | return 0; | ||
| 207 | } | ||
| 208 | |||
| 209 | /** | ||
| 210 | * flex_array_prealloc - guarantee that array space exists | ||
| 211 | * @start: index of first array element for which space is allocated | ||
| 212 | * @end: index of last (inclusive) element for which space is allocated | ||
| 213 | * | ||
| 214 | * This will guarantee that no future calls to flex_array_put() | ||
| 215 | * will allocate memory. It can be used if you are expecting to | ||
| 216 | * be holding a lock or in some atomic context while writing | ||
| 217 | * data into the array. | ||
| 218 | * | ||
| 219 | * Locking must be provided by the caller. | ||
| 220 | */ | ||
| 221 | int flex_array_prealloc(struct flex_array *fa, unsigned int start, | ||
| 222 | unsigned int end, gfp_t flags) | ||
| 223 | { | ||
| 224 | int start_part; | ||
| 225 | int end_part; | ||
| 226 | int part_nr; | ||
| 227 | struct flex_array_part *part; | ||
| 228 | |||
| 229 | if (start >= fa->total_nr_elements || end >= fa->total_nr_elements) | ||
| 230 | return -ENOSPC; | ||
| 231 | if (elements_fit_in_base(fa)) | ||
| 232 | return 0; | ||
| 233 | start_part = fa_element_to_part_nr(fa, start); | ||
| 234 | end_part = fa_element_to_part_nr(fa, end); | ||
| 235 | for (part_nr = start_part; part_nr <= end_part; part_nr++) { | ||
| 236 | part = __fa_get_part(fa, part_nr, flags); | ||
| 237 | if (!part) | ||
| 238 | return -ENOMEM; | ||
| 239 | } | ||
| 240 | return 0; | ||
| 241 | } | ||
| 242 | |||
| 243 | /** | ||
| 244 | * flex_array_get - pull data back out of the array | ||
| 245 | * @element_nr: index of the element to fetch from the array | ||
| 246 | * | ||
| 247 | * Returns a pointer to the data at index @element_nr. Note | ||
| 248 | * that this is a copy of the data that was passed in. If you | ||
| 249 | * are using this to store pointers, you'll get back &ptr. | ||
| 250 | * | ||
| 251 | * Locking must be provided by the caller. | ||
| 252 | */ | ||
| 253 | void *flex_array_get(struct flex_array *fa, unsigned int element_nr) | ||
| 254 | { | ||
| 255 | int part_nr = fa_element_to_part_nr(fa, element_nr); | ||
| 256 | struct flex_array_part *part; | ||
| 257 | |||
| 258 | if (element_nr >= fa->total_nr_elements) | ||
| 259 | return NULL; | ||
| 260 | if (elements_fit_in_base(fa)) | ||
| 261 | part = (struct flex_array_part *)&fa->parts[0]; | ||
| 262 | else { | ||
| 263 | part = fa->parts[part_nr]; | ||
| 264 | if (!part) | ||
| 265 | return NULL; | ||
| 266 | } | ||
| 267 | return &part->elements[index_inside_part(fa, element_nr)]; | ||
| 268 | } | ||
| @@ -429,7 +429,7 @@ u64 __init lmb_phys_mem_size(void) | |||
| 429 | return lmb.memory.size; | 429 | return lmb.memory.size; |
| 430 | } | 430 | } |
| 431 | 431 | ||
| 432 | u64 __init lmb_end_of_DRAM(void) | 432 | u64 lmb_end_of_DRAM(void) |
| 433 | { | 433 | { |
| 434 | int idx = lmb.memory.cnt - 1; | 434 | int idx = lmb.memory.cnt - 1; |
| 435 | 435 | ||
diff --git a/lib/scatterlist.c b/lib/scatterlist.c index a295e404e908..0d475d8167bf 100644 --- a/lib/scatterlist.c +++ b/lib/scatterlist.c | |||
| @@ -314,6 +314,7 @@ void sg_miter_start(struct sg_mapping_iter *miter, struct scatterlist *sgl, | |||
| 314 | miter->__sg = sgl; | 314 | miter->__sg = sgl; |
| 315 | miter->__nents = nents; | 315 | miter->__nents = nents; |
| 316 | miter->__offset = 0; | 316 | miter->__offset = 0; |
| 317 | WARN_ON(!(flags & (SG_MITER_TO_SG | SG_MITER_FROM_SG))); | ||
| 317 | miter->__flags = flags; | 318 | miter->__flags = flags; |
| 318 | } | 319 | } |
| 319 | EXPORT_SYMBOL(sg_miter_start); | 320 | EXPORT_SYMBOL(sg_miter_start); |
| @@ -394,6 +395,9 @@ void sg_miter_stop(struct sg_mapping_iter *miter) | |||
| 394 | if (miter->addr) { | 395 | if (miter->addr) { |
| 395 | miter->__offset += miter->consumed; | 396 | miter->__offset += miter->consumed; |
| 396 | 397 | ||
| 398 | if (miter->__flags & SG_MITER_TO_SG) | ||
| 399 | flush_kernel_dcache_page(miter->page); | ||
| 400 | |||
| 397 | if (miter->__flags & SG_MITER_ATOMIC) { | 401 | if (miter->__flags & SG_MITER_ATOMIC) { |
| 398 | WARN_ON(!irqs_disabled()); | 402 | WARN_ON(!irqs_disabled()); |
| 399 | kunmap_atomic(miter->addr, KM_BIO_SRC_IRQ); | 403 | kunmap_atomic(miter->addr, KM_BIO_SRC_IRQ); |
| @@ -426,8 +430,14 @@ static size_t sg_copy_buffer(struct scatterlist *sgl, unsigned int nents, | |||
| 426 | unsigned int offset = 0; | 430 | unsigned int offset = 0; |
| 427 | struct sg_mapping_iter miter; | 431 | struct sg_mapping_iter miter; |
| 428 | unsigned long flags; | 432 | unsigned long flags; |
| 433 | unsigned int sg_flags = SG_MITER_ATOMIC; | ||
| 434 | |||
| 435 | if (to_buffer) | ||
| 436 | sg_flags |= SG_MITER_FROM_SG; | ||
| 437 | else | ||
| 438 | sg_flags |= SG_MITER_TO_SG; | ||
| 429 | 439 | ||
| 430 | sg_miter_start(&miter, sgl, nents, SG_MITER_ATOMIC); | 440 | sg_miter_start(&miter, sgl, nents, sg_flags); |
| 431 | 441 | ||
| 432 | local_irq_save(flags); | 442 | local_irq_save(flags); |
| 433 | 443 | ||
| @@ -438,10 +448,8 @@ static size_t sg_copy_buffer(struct scatterlist *sgl, unsigned int nents, | |||
| 438 | 448 | ||
| 439 | if (to_buffer) | 449 | if (to_buffer) |
| 440 | memcpy(buf + offset, miter.addr, len); | 450 | memcpy(buf + offset, miter.addr, len); |
| 441 | else { | 451 | else |
| 442 | memcpy(miter.addr, buf + offset, len); | 452 | memcpy(miter.addr, buf + offset, len); |
| 443 | flush_kernel_dcache_page(miter.page); | ||
| 444 | } | ||
| 445 | 453 | ||
| 446 | offset += len; | 454 | offset += len; |
| 447 | } | 455 | } |
diff --git a/mm/Kconfig b/mm/Kconfig index c948d4ca8bde..fe5f674d7a7d 100644 --- a/mm/Kconfig +++ b/mm/Kconfig | |||
| @@ -225,9 +225,9 @@ config DEFAULT_MMAP_MIN_ADDR | |||
| 225 | For most ia64, ppc64 and x86 users with lots of address space | 225 | For most ia64, ppc64 and x86 users with lots of address space |
| 226 | a value of 65536 is reasonable and should cause no problems. | 226 | a value of 65536 is reasonable and should cause no problems. |
| 227 | On arm and other archs it should not be higher than 32768. | 227 | On arm and other archs it should not be higher than 32768. |
| 228 | Programs which use vm86 functionality would either need additional | 228 | Programs which use vm86 functionality or have some need to map |
| 229 | permissions from either the LSM or the capabilities module or have | 229 | this low address space will need CAP_SYS_RAWIO or disable this |
| 230 | this protection disabled. | 230 | protection by setting the value to 0. |
| 231 | 231 | ||
| 232 | This value can be changed after boot using the | 232 | This value can be changed after boot using the |
| 233 | /proc/sys/vm/mmap_min_addr tunable. | 233 | /proc/sys/vm/mmap_min_addr tunable. |
diff --git a/mm/hugetlb.c b/mm/hugetlb.c index d0351e31f474..cafdcee154e8 100644 --- a/mm/hugetlb.c +++ b/mm/hugetlb.c | |||
| @@ -2370,7 +2370,7 @@ void hugetlb_unreserve_pages(struct inode *inode, long offset, long freed) | |||
| 2370 | long chg = region_truncate(&inode->i_mapping->private_list, offset); | 2370 | long chg = region_truncate(&inode->i_mapping->private_list, offset); |
| 2371 | 2371 | ||
| 2372 | spin_lock(&inode->i_lock); | 2372 | spin_lock(&inode->i_lock); |
| 2373 | inode->i_blocks -= blocks_per_huge_page(h); | 2373 | inode->i_blocks -= (blocks_per_huge_page(h) * freed); |
| 2374 | spin_unlock(&inode->i_lock); | 2374 | spin_unlock(&inode->i_lock); |
| 2375 | 2375 | ||
| 2376 | hugetlb_put_quota(inode->i_mapping, (chg - freed)); | 2376 | hugetlb_put_quota(inode->i_mapping, (chg - freed)); |
diff --git a/mm/kmemleak.c b/mm/kmemleak.c index 5aabd41ffb8f..487267310a84 100644 --- a/mm/kmemleak.c +++ b/mm/kmemleak.c | |||
| @@ -1217,7 +1217,6 @@ static void *kmemleak_seq_start(struct seq_file *seq, loff_t *pos) | |||
| 1217 | } | 1217 | } |
| 1218 | object = NULL; | 1218 | object = NULL; |
| 1219 | out: | 1219 | out: |
| 1220 | rcu_read_unlock(); | ||
| 1221 | return object; | 1220 | return object; |
| 1222 | } | 1221 | } |
| 1223 | 1222 | ||
| @@ -1233,13 +1232,11 @@ static void *kmemleak_seq_next(struct seq_file *seq, void *v, loff_t *pos) | |||
| 1233 | 1232 | ||
| 1234 | ++(*pos); | 1233 | ++(*pos); |
| 1235 | 1234 | ||
| 1236 | rcu_read_lock(); | ||
| 1237 | list_for_each_continue_rcu(n, &object_list) { | 1235 | list_for_each_continue_rcu(n, &object_list) { |
| 1238 | next_obj = list_entry(n, struct kmemleak_object, object_list); | 1236 | next_obj = list_entry(n, struct kmemleak_object, object_list); |
| 1239 | if (get_object(next_obj)) | 1237 | if (get_object(next_obj)) |
| 1240 | break; | 1238 | break; |
| 1241 | } | 1239 | } |
| 1242 | rcu_read_unlock(); | ||
| 1243 | 1240 | ||
| 1244 | put_object(prev_obj); | 1241 | put_object(prev_obj); |
| 1245 | return next_obj; | 1242 | return next_obj; |
| @@ -1255,6 +1252,7 @@ static void kmemleak_seq_stop(struct seq_file *seq, void *v) | |||
| 1255 | * kmemleak_seq_start may return ERR_PTR if the scan_mutex | 1252 | * kmemleak_seq_start may return ERR_PTR if the scan_mutex |
| 1256 | * waiting was interrupted, so only release it if !IS_ERR. | 1253 | * waiting was interrupted, so only release it if !IS_ERR. |
| 1257 | */ | 1254 | */ |
| 1255 | rcu_read_unlock(); | ||
| 1258 | mutex_unlock(&scan_mutex); | 1256 | mutex_unlock(&scan_mutex); |
| 1259 | if (v) | 1257 | if (v) |
| 1260 | put_object(v); | 1258 | put_object(v); |
diff --git a/mm/memcontrol.c b/mm/memcontrol.c index e717964cb5a0..fd4529d86de5 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c | |||
| @@ -1207,6 +1207,12 @@ static int mem_cgroup_move_account(struct page_cgroup *pc, | |||
| 1207 | ret = 0; | 1207 | ret = 0; |
| 1208 | out: | 1208 | out: |
| 1209 | unlock_page_cgroup(pc); | 1209 | unlock_page_cgroup(pc); |
| 1210 | /* | ||
| 1211 | * We charges against "to" which may not have any tasks. Then, "to" | ||
| 1212 | * can be under rmdir(). But in current implementation, caller of | ||
| 1213 | * this function is just force_empty() and it's garanteed that | ||
| 1214 | * "to" is never removed. So, we don't check rmdir status here. | ||
| 1215 | */ | ||
| 1210 | return ret; | 1216 | return ret; |
| 1211 | } | 1217 | } |
| 1212 | 1218 | ||
| @@ -1428,6 +1434,7 @@ __mem_cgroup_commit_charge_swapin(struct page *page, struct mem_cgroup *ptr, | |||
| 1428 | return; | 1434 | return; |
| 1429 | if (!ptr) | 1435 | if (!ptr) |
| 1430 | return; | 1436 | return; |
| 1437 | cgroup_exclude_rmdir(&ptr->css); | ||
| 1431 | pc = lookup_page_cgroup(page); | 1438 | pc = lookup_page_cgroup(page); |
| 1432 | mem_cgroup_lru_del_before_commit_swapcache(page); | 1439 | mem_cgroup_lru_del_before_commit_swapcache(page); |
| 1433 | __mem_cgroup_commit_charge(ptr, pc, ctype); | 1440 | __mem_cgroup_commit_charge(ptr, pc, ctype); |
| @@ -1457,8 +1464,12 @@ __mem_cgroup_commit_charge_swapin(struct page *page, struct mem_cgroup *ptr, | |||
| 1457 | } | 1464 | } |
| 1458 | rcu_read_unlock(); | 1465 | rcu_read_unlock(); |
| 1459 | } | 1466 | } |
| 1460 | /* add this page(page_cgroup) to the LRU we want. */ | 1467 | /* |
| 1461 | 1468 | * At swapin, we may charge account against cgroup which has no tasks. | |
| 1469 | * So, rmdir()->pre_destroy() can be called while we do this charge. | ||
| 1470 | * In that case, we need to call pre_destroy() again. check it here. | ||
| 1471 | */ | ||
| 1472 | cgroup_release_and_wakeup_rmdir(&ptr->css); | ||
| 1462 | } | 1473 | } |
| 1463 | 1474 | ||
| 1464 | void mem_cgroup_commit_charge_swapin(struct page *page, struct mem_cgroup *ptr) | 1475 | void mem_cgroup_commit_charge_swapin(struct page *page, struct mem_cgroup *ptr) |
| @@ -1664,7 +1675,7 @@ void mem_cgroup_end_migration(struct mem_cgroup *mem, | |||
| 1664 | 1675 | ||
| 1665 | if (!mem) | 1676 | if (!mem) |
| 1666 | return; | 1677 | return; |
| 1667 | 1678 | cgroup_exclude_rmdir(&mem->css); | |
| 1668 | /* at migration success, oldpage->mapping is NULL. */ | 1679 | /* at migration success, oldpage->mapping is NULL. */ |
| 1669 | if (oldpage->mapping) { | 1680 | if (oldpage->mapping) { |
| 1670 | target = oldpage; | 1681 | target = oldpage; |
| @@ -1704,6 +1715,12 @@ void mem_cgroup_end_migration(struct mem_cgroup *mem, | |||
| 1704 | */ | 1715 | */ |
| 1705 | if (ctype == MEM_CGROUP_CHARGE_TYPE_MAPPED) | 1716 | if (ctype == MEM_CGROUP_CHARGE_TYPE_MAPPED) |
| 1706 | mem_cgroup_uncharge_page(target); | 1717 | mem_cgroup_uncharge_page(target); |
| 1718 | /* | ||
| 1719 | * At migration, we may charge account against cgroup which has no tasks | ||
| 1720 | * So, rmdir()->pre_destroy() can be called while we do this charge. | ||
| 1721 | * In that case, we need to call pre_destroy() again. check it here. | ||
| 1722 | */ | ||
| 1723 | cgroup_release_and_wakeup_rmdir(&mem->css); | ||
| 1707 | } | 1724 | } |
| 1708 | 1725 | ||
| 1709 | /* | 1726 | /* |
diff --git a/mm/memory.c b/mm/memory.c index 65216194eb8d..aede2ce3aba4 100644 --- a/mm/memory.c +++ b/mm/memory.c | |||
| @@ -135,11 +135,12 @@ void pmd_clear_bad(pmd_t *pmd) | |||
| 135 | * Note: this doesn't free the actual pages themselves. That | 135 | * Note: this doesn't free the actual pages themselves. That |
| 136 | * has been handled earlier when unmapping all the memory regions. | 136 | * has been handled earlier when unmapping all the memory regions. |
| 137 | */ | 137 | */ |
| 138 | static void free_pte_range(struct mmu_gather *tlb, pmd_t *pmd) | 138 | static void free_pte_range(struct mmu_gather *tlb, pmd_t *pmd, |
| 139 | unsigned long addr) | ||
| 139 | { | 140 | { |
| 140 | pgtable_t token = pmd_pgtable(*pmd); | 141 | pgtable_t token = pmd_pgtable(*pmd); |
| 141 | pmd_clear(pmd); | 142 | pmd_clear(pmd); |
| 142 | pte_free_tlb(tlb, token); | 143 | pte_free_tlb(tlb, token, addr); |
| 143 | tlb->mm->nr_ptes--; | 144 | tlb->mm->nr_ptes--; |
| 144 | } | 145 | } |
| 145 | 146 | ||
| @@ -157,7 +158,7 @@ static inline void free_pmd_range(struct mmu_gather *tlb, pud_t *pud, | |||
| 157 | next = pmd_addr_end(addr, end); | 158 | next = pmd_addr_end(addr, end); |
| 158 | if (pmd_none_or_clear_bad(pmd)) | 159 | if (pmd_none_or_clear_bad(pmd)) |
| 159 | continue; | 160 | continue; |
| 160 | free_pte_range(tlb, pmd); | 161 | free_pte_range(tlb, pmd, addr); |
| 161 | } while (pmd++, addr = next, addr != end); | 162 | } while (pmd++, addr = next, addr != end); |
| 162 | 163 | ||
| 163 | start &= PUD_MASK; | 164 | start &= PUD_MASK; |
| @@ -173,7 +174,7 @@ static inline void free_pmd_range(struct mmu_gather *tlb, pud_t *pud, | |||
| 173 | 174 | ||
| 174 | pmd = pmd_offset(pud, start); | 175 | pmd = pmd_offset(pud, start); |
| 175 | pud_clear(pud); | 176 | pud_clear(pud); |
| 176 | pmd_free_tlb(tlb, pmd); | 177 | pmd_free_tlb(tlb, pmd, start); |
| 177 | } | 178 | } |
| 178 | 179 | ||
| 179 | static inline void free_pud_range(struct mmu_gather *tlb, pgd_t *pgd, | 180 | static inline void free_pud_range(struct mmu_gather *tlb, pgd_t *pgd, |
| @@ -206,7 +207,7 @@ static inline void free_pud_range(struct mmu_gather *tlb, pgd_t *pgd, | |||
| 206 | 207 | ||
| 207 | pud = pud_offset(pgd, start); | 208 | pud = pud_offset(pgd, start); |
| 208 | pgd_clear(pgd); | 209 | pgd_clear(pgd); |
| 209 | pud_free_tlb(tlb, pud); | 210 | pud_free_tlb(tlb, pud, start); |
| 210 | } | 211 | } |
| 211 | 212 | ||
| 212 | /* | 213 | /* |
diff --git a/mm/mempolicy.c b/mm/mempolicy.c index e08e2c4da63a..7dd9d9f80694 100644 --- a/mm/mempolicy.c +++ b/mm/mempolicy.c | |||
| @@ -191,25 +191,27 @@ static int mpol_new_bind(struct mempolicy *pol, const nodemask_t *nodes) | |||
| 191 | * Must be called holding task's alloc_lock to protect task's mems_allowed | 191 | * Must be called holding task's alloc_lock to protect task's mems_allowed |
| 192 | * and mempolicy. May also be called holding the mmap_semaphore for write. | 192 | * and mempolicy. May also be called holding the mmap_semaphore for write. |
| 193 | */ | 193 | */ |
| 194 | static int mpol_set_nodemask(struct mempolicy *pol, const nodemask_t *nodes) | 194 | static int mpol_set_nodemask(struct mempolicy *pol, |
| 195 | const nodemask_t *nodes, struct nodemask_scratch *nsc) | ||
| 195 | { | 196 | { |
| 196 | nodemask_t cpuset_context_nmask; | ||
| 197 | int ret; | 197 | int ret; |
| 198 | 198 | ||
| 199 | /* if mode is MPOL_DEFAULT, pol is NULL. This is right. */ | 199 | /* if mode is MPOL_DEFAULT, pol is NULL. This is right. */ |
| 200 | if (pol == NULL) | 200 | if (pol == NULL) |
| 201 | return 0; | 201 | return 0; |
| 202 | /* Check N_HIGH_MEMORY */ | ||
| 203 | nodes_and(nsc->mask1, | ||
| 204 | cpuset_current_mems_allowed, node_states[N_HIGH_MEMORY]); | ||
| 202 | 205 | ||
| 203 | VM_BUG_ON(!nodes); | 206 | VM_BUG_ON(!nodes); |
| 204 | if (pol->mode == MPOL_PREFERRED && nodes_empty(*nodes)) | 207 | if (pol->mode == MPOL_PREFERRED && nodes_empty(*nodes)) |
| 205 | nodes = NULL; /* explicit local allocation */ | 208 | nodes = NULL; /* explicit local allocation */ |
| 206 | else { | 209 | else { |
| 207 | if (pol->flags & MPOL_F_RELATIVE_NODES) | 210 | if (pol->flags & MPOL_F_RELATIVE_NODES) |
| 208 | mpol_relative_nodemask(&cpuset_context_nmask, nodes, | 211 | mpol_relative_nodemask(&nsc->mask2, nodes,&nsc->mask1); |
| 209 | &cpuset_current_mems_allowed); | ||
| 210 | else | 212 | else |
| 211 | nodes_and(cpuset_context_nmask, *nodes, | 213 | nodes_and(nsc->mask2, *nodes, nsc->mask1); |
| 212 | cpuset_current_mems_allowed); | 214 | |
| 213 | if (mpol_store_user_nodemask(pol)) | 215 | if (mpol_store_user_nodemask(pol)) |
| 214 | pol->w.user_nodemask = *nodes; | 216 | pol->w.user_nodemask = *nodes; |
| 215 | else | 217 | else |
| @@ -217,8 +219,10 @@ static int mpol_set_nodemask(struct mempolicy *pol, const nodemask_t *nodes) | |||
| 217 | cpuset_current_mems_allowed; | 219 | cpuset_current_mems_allowed; |
| 218 | } | 220 | } |
| 219 | 221 | ||
| 220 | ret = mpol_ops[pol->mode].create(pol, | 222 | if (nodes) |
| 221 | nodes ? &cpuset_context_nmask : NULL); | 223 | ret = mpol_ops[pol->mode].create(pol, &nsc->mask2); |
| 224 | else | ||
| 225 | ret = mpol_ops[pol->mode].create(pol, NULL); | ||
| 222 | return ret; | 226 | return ret; |
| 223 | } | 227 | } |
| 224 | 228 | ||
| @@ -620,12 +624,17 @@ static long do_set_mempolicy(unsigned short mode, unsigned short flags, | |||
| 620 | { | 624 | { |
| 621 | struct mempolicy *new, *old; | 625 | struct mempolicy *new, *old; |
| 622 | struct mm_struct *mm = current->mm; | 626 | struct mm_struct *mm = current->mm; |
| 627 | NODEMASK_SCRATCH(scratch); | ||
| 623 | int ret; | 628 | int ret; |
| 624 | 629 | ||
| 625 | new = mpol_new(mode, flags, nodes); | 630 | if (!scratch) |
| 626 | if (IS_ERR(new)) | 631 | return -ENOMEM; |
| 627 | return PTR_ERR(new); | ||
| 628 | 632 | ||
| 633 | new = mpol_new(mode, flags, nodes); | ||
| 634 | if (IS_ERR(new)) { | ||
| 635 | ret = PTR_ERR(new); | ||
| 636 | goto out; | ||
| 637 | } | ||
| 629 | /* | 638 | /* |
| 630 | * prevent changing our mempolicy while show_numa_maps() | 639 | * prevent changing our mempolicy while show_numa_maps() |
| 631 | * is using it. | 640 | * is using it. |
| @@ -635,13 +644,13 @@ static long do_set_mempolicy(unsigned short mode, unsigned short flags, | |||
| 635 | if (mm) | 644 | if (mm) |
| 636 | down_write(&mm->mmap_sem); | 645 | down_write(&mm->mmap_sem); |
| 637 | task_lock(current); | 646 | task_lock(current); |
| 638 | ret = mpol_set_nodemask(new, nodes); | 647 | ret = mpol_set_nodemask(new, nodes, scratch); |
| 639 | if (ret) { | 648 | if (ret) { |
| 640 | task_unlock(current); | 649 | task_unlock(current); |
| 641 | if (mm) | 650 | if (mm) |
| 642 | up_write(&mm->mmap_sem); | 651 | up_write(&mm->mmap_sem); |
| 643 | mpol_put(new); | 652 | mpol_put(new); |
| 644 | return ret; | 653 | goto out; |
| 645 | } | 654 | } |
| 646 | old = current->mempolicy; | 655 | old = current->mempolicy; |
| 647 | current->mempolicy = new; | 656 | current->mempolicy = new; |
| @@ -654,7 +663,10 @@ static long do_set_mempolicy(unsigned short mode, unsigned short flags, | |||
| 654 | up_write(&mm->mmap_sem); | 663 | up_write(&mm->mmap_sem); |
| 655 | 664 | ||
| 656 | mpol_put(old); | 665 | mpol_put(old); |
| 657 | return 0; | 666 | ret = 0; |
| 667 | out: | ||
| 668 | NODEMASK_SCRATCH_FREE(scratch); | ||
| 669 | return ret; | ||
| 658 | } | 670 | } |
| 659 | 671 | ||
| 660 | /* | 672 | /* |
| @@ -1014,12 +1026,20 @@ static long do_mbind(unsigned long start, unsigned long len, | |||
| 1014 | if (err) | 1026 | if (err) |
| 1015 | return err; | 1027 | return err; |
| 1016 | } | 1028 | } |
| 1017 | down_write(&mm->mmap_sem); | 1029 | { |
| 1018 | task_lock(current); | 1030 | NODEMASK_SCRATCH(scratch); |
| 1019 | err = mpol_set_nodemask(new, nmask); | 1031 | if (scratch) { |
| 1020 | task_unlock(current); | 1032 | down_write(&mm->mmap_sem); |
| 1033 | task_lock(current); | ||
| 1034 | err = mpol_set_nodemask(new, nmask, scratch); | ||
| 1035 | task_unlock(current); | ||
| 1036 | if (err) | ||
| 1037 | up_write(&mm->mmap_sem); | ||
| 1038 | } else | ||
| 1039 | err = -ENOMEM; | ||
| 1040 | NODEMASK_SCRATCH_FREE(scratch); | ||
| 1041 | } | ||
| 1021 | if (err) { | 1042 | if (err) { |
| 1022 | up_write(&mm->mmap_sem); | ||
| 1023 | mpol_put(new); | 1043 | mpol_put(new); |
| 1024 | return err; | 1044 | return err; |
| 1025 | } | 1045 | } |
| @@ -1891,6 +1911,7 @@ restart: | |||
| 1891 | * Install non-NULL @mpol in inode's shared policy rb-tree. | 1911 | * Install non-NULL @mpol in inode's shared policy rb-tree. |
| 1892 | * On entry, the current task has a reference on a non-NULL @mpol. | 1912 | * On entry, the current task has a reference on a non-NULL @mpol. |
| 1893 | * This must be released on exit. | 1913 | * This must be released on exit. |
| 1914 | * This is called at get_inode() calls and we can use GFP_KERNEL. | ||
| 1894 | */ | 1915 | */ |
| 1895 | void mpol_shared_policy_init(struct shared_policy *sp, struct mempolicy *mpol) | 1916 | void mpol_shared_policy_init(struct shared_policy *sp, struct mempolicy *mpol) |
| 1896 | { | 1917 | { |
| @@ -1902,19 +1923,24 @@ void mpol_shared_policy_init(struct shared_policy *sp, struct mempolicy *mpol) | |||
| 1902 | if (mpol) { | 1923 | if (mpol) { |
| 1903 | struct vm_area_struct pvma; | 1924 | struct vm_area_struct pvma; |
| 1904 | struct mempolicy *new; | 1925 | struct mempolicy *new; |
| 1926 | NODEMASK_SCRATCH(scratch); | ||
| 1905 | 1927 | ||
| 1928 | if (!scratch) | ||
| 1929 | return; | ||
| 1906 | /* contextualize the tmpfs mount point mempolicy */ | 1930 | /* contextualize the tmpfs mount point mempolicy */ |
| 1907 | new = mpol_new(mpol->mode, mpol->flags, &mpol->w.user_nodemask); | 1931 | new = mpol_new(mpol->mode, mpol->flags, &mpol->w.user_nodemask); |
| 1908 | if (IS_ERR(new)) { | 1932 | if (IS_ERR(new)) { |
| 1909 | mpol_put(mpol); /* drop our ref on sb mpol */ | 1933 | mpol_put(mpol); /* drop our ref on sb mpol */ |
| 1934 | NODEMASK_SCRATCH_FREE(scratch); | ||
| 1910 | return; /* no valid nodemask intersection */ | 1935 | return; /* no valid nodemask intersection */ |
| 1911 | } | 1936 | } |
| 1912 | 1937 | ||
| 1913 | task_lock(current); | 1938 | task_lock(current); |
| 1914 | ret = mpol_set_nodemask(new, &mpol->w.user_nodemask); | 1939 | ret = mpol_set_nodemask(new, &mpol->w.user_nodemask, scratch); |
| 1915 | task_unlock(current); | 1940 | task_unlock(current); |
| 1916 | mpol_put(mpol); /* drop our ref on sb mpol */ | 1941 | mpol_put(mpol); /* drop our ref on sb mpol */ |
| 1917 | if (ret) { | 1942 | if (ret) { |
| 1943 | NODEMASK_SCRATCH_FREE(scratch); | ||
| 1918 | mpol_put(new); | 1944 | mpol_put(new); |
| 1919 | return; | 1945 | return; |
| 1920 | } | 1946 | } |
| @@ -1924,6 +1950,7 @@ void mpol_shared_policy_init(struct shared_policy *sp, struct mempolicy *mpol) | |||
| 1924 | pvma.vm_end = TASK_SIZE; /* policy covers entire file */ | 1950 | pvma.vm_end = TASK_SIZE; /* policy covers entire file */ |
| 1925 | mpol_set_shared_policy(sp, &pvma, new); /* adds ref */ | 1951 | mpol_set_shared_policy(sp, &pvma, new); /* adds ref */ |
| 1926 | mpol_put(new); /* drop initial ref */ | 1952 | mpol_put(new); /* drop initial ref */ |
| 1953 | NODEMASK_SCRATCH_FREE(scratch); | ||
| 1927 | } | 1954 | } |
| 1928 | } | 1955 | } |
| 1929 | 1956 | ||
| @@ -2140,13 +2167,18 @@ int mpol_parse_str(char *str, struct mempolicy **mpol, int no_context) | |||
| 2140 | err = 1; | 2167 | err = 1; |
| 2141 | else { | 2168 | else { |
| 2142 | int ret; | 2169 | int ret; |
| 2143 | 2170 | NODEMASK_SCRATCH(scratch); | |
| 2144 | task_lock(current); | 2171 | if (scratch) { |
| 2145 | ret = mpol_set_nodemask(new, &nodes); | 2172 | task_lock(current); |
| 2146 | task_unlock(current); | 2173 | ret = mpol_set_nodemask(new, &nodes, scratch); |
| 2147 | if (ret) | 2174 | task_unlock(current); |
| 2175 | } else | ||
| 2176 | ret = -ENOMEM; | ||
| 2177 | NODEMASK_SCRATCH_FREE(scratch); | ||
| 2178 | if (ret) { | ||
| 2148 | err = 1; | 2179 | err = 1; |
| 2149 | else if (no_context) { | 2180 | mpol_put(new); |
| 2181 | } else if (no_context) { | ||
| 2150 | /* save for contextualization */ | 2182 | /* save for contextualization */ |
| 2151 | new->w.user_nodemask = nodes; | 2183 | new->w.user_nodemask = nodes; |
| 2152 | } | 2184 | } |
diff --git a/mm/mempool.c b/mm/mempool.c index a46eb1b4bb66..32e75d400503 100644 --- a/mm/mempool.c +++ b/mm/mempool.c | |||
| @@ -303,14 +303,14 @@ EXPORT_SYMBOL(mempool_free_slab); | |||
| 303 | */ | 303 | */ |
| 304 | void *mempool_kmalloc(gfp_t gfp_mask, void *pool_data) | 304 | void *mempool_kmalloc(gfp_t gfp_mask, void *pool_data) |
| 305 | { | 305 | { |
| 306 | size_t size = (size_t)(long)pool_data; | 306 | size_t size = (size_t)pool_data; |
| 307 | return kmalloc(size, gfp_mask); | 307 | return kmalloc(size, gfp_mask); |
| 308 | } | 308 | } |
| 309 | EXPORT_SYMBOL(mempool_kmalloc); | 309 | EXPORT_SYMBOL(mempool_kmalloc); |
| 310 | 310 | ||
| 311 | void *mempool_kzalloc(gfp_t gfp_mask, void *pool_data) | 311 | void *mempool_kzalloc(gfp_t gfp_mask, void *pool_data) |
| 312 | { | 312 | { |
| 313 | size_t size = (size_t) pool_data; | 313 | size_t size = (size_t)pool_data; |
| 314 | return kzalloc(size, gfp_mask); | 314 | return kzalloc(size, gfp_mask); |
| 315 | } | 315 | } |
| 316 | EXPORT_SYMBOL(mempool_kzalloc); | 316 | EXPORT_SYMBOL(mempool_kzalloc); |
| @@ -88,9 +88,6 @@ int sysctl_overcommit_ratio = 50; /* default is 50% */ | |||
| 88 | int sysctl_max_map_count __read_mostly = DEFAULT_MAX_MAP_COUNT; | 88 | int sysctl_max_map_count __read_mostly = DEFAULT_MAX_MAP_COUNT; |
| 89 | struct percpu_counter vm_committed_as; | 89 | struct percpu_counter vm_committed_as; |
| 90 | 90 | ||
| 91 | /* amount of vm to protect from userspace access */ | ||
| 92 | unsigned long mmap_min_addr = CONFIG_DEFAULT_MMAP_MIN_ADDR; | ||
| 93 | |||
| 94 | /* | 91 | /* |
| 95 | * Check that a process has enough memory to allocate a new virtual | 92 | * Check that a process has enough memory to allocate a new virtual |
| 96 | * mapping. 0 means there is enough memory for the allocation to | 93 | * mapping. 0 means there is enough memory for the allocation to |
diff --git a/mm/nommu.c b/mm/nommu.c index 53cab10fece4..4bde489ec431 100644 --- a/mm/nommu.c +++ b/mm/nommu.c | |||
| @@ -69,9 +69,6 @@ int sysctl_max_map_count = DEFAULT_MAX_MAP_COUNT; | |||
| 69 | int sysctl_nr_trim_pages = CONFIG_NOMMU_INITIAL_TRIM_EXCESS; | 69 | int sysctl_nr_trim_pages = CONFIG_NOMMU_INITIAL_TRIM_EXCESS; |
| 70 | int heap_stack_gap = 0; | 70 | int heap_stack_gap = 0; |
| 71 | 71 | ||
| 72 | /* amount of vm to protect from userspace access */ | ||
| 73 | unsigned long mmap_min_addr = CONFIG_DEFAULT_MMAP_MIN_ADDR; | ||
| 74 | |||
| 75 | atomic_long_t mmap_pages_allocated; | 72 | atomic_long_t mmap_pages_allocated; |
| 76 | 73 | ||
| 77 | EXPORT_SYMBOL(mem_map); | 74 | EXPORT_SYMBOL(mem_map); |
| @@ -922,6 +919,10 @@ static int validate_mmap_request(struct file *file, | |||
| 922 | if (!file->f_op->read) | 919 | if (!file->f_op->read) |
| 923 | capabilities &= ~BDI_CAP_MAP_COPY; | 920 | capabilities &= ~BDI_CAP_MAP_COPY; |
| 924 | 921 | ||
| 922 | /* The file shall have been opened with read permission. */ | ||
| 923 | if (!(file->f_mode & FMODE_READ)) | ||
| 924 | return -EACCES; | ||
| 925 | |||
| 925 | if (flags & MAP_SHARED) { | 926 | if (flags & MAP_SHARED) { |
| 926 | /* do checks for writing, appending and locking */ | 927 | /* do checks for writing, appending and locking */ |
| 927 | if ((prot & PROT_WRITE) && | 928 | if ((prot & PROT_WRITE) && |
diff --git a/mm/oom_kill.c b/mm/oom_kill.c index 175a67a78a99..a7b2460e922b 100644 --- a/mm/oom_kill.c +++ b/mm/oom_kill.c | |||
| @@ -58,7 +58,6 @@ unsigned long badness(struct task_struct *p, unsigned long uptime) | |||
| 58 | unsigned long points, cpu_time, run_time; | 58 | unsigned long points, cpu_time, run_time; |
| 59 | struct mm_struct *mm; | 59 | struct mm_struct *mm; |
| 60 | struct task_struct *child; | 60 | struct task_struct *child; |
| 61 | int oom_adj; | ||
| 62 | 61 | ||
| 63 | task_lock(p); | 62 | task_lock(p); |
| 64 | mm = p->mm; | 63 | mm = p->mm; |
| @@ -66,11 +65,6 @@ unsigned long badness(struct task_struct *p, unsigned long uptime) | |||
| 66 | task_unlock(p); | 65 | task_unlock(p); |
| 67 | return 0; | 66 | return 0; |
| 68 | } | 67 | } |
| 69 | oom_adj = mm->oom_adj; | ||
| 70 | if (oom_adj == OOM_DISABLE) { | ||
| 71 | task_unlock(p); | ||
| 72 | return 0; | ||
| 73 | } | ||
| 74 | 68 | ||
| 75 | /* | 69 | /* |
| 76 | * The memory size of the process is the basis for the badness. | 70 | * The memory size of the process is the basis for the badness. |
| @@ -154,15 +148,15 @@ unsigned long badness(struct task_struct *p, unsigned long uptime) | |||
| 154 | points /= 8; | 148 | points /= 8; |
| 155 | 149 | ||
| 156 | /* | 150 | /* |
| 157 | * Adjust the score by oom_adj. | 151 | * Adjust the score by oomkilladj. |
| 158 | */ | 152 | */ |
| 159 | if (oom_adj) { | 153 | if (p->oomkilladj) { |
| 160 | if (oom_adj > 0) { | 154 | if (p->oomkilladj > 0) { |
| 161 | if (!points) | 155 | if (!points) |
| 162 | points = 1; | 156 | points = 1; |
| 163 | points <<= oom_adj; | 157 | points <<= p->oomkilladj; |
| 164 | } else | 158 | } else |
| 165 | points >>= -(oom_adj); | 159 | points >>= -(p->oomkilladj); |
| 166 | } | 160 | } |
| 167 | 161 | ||
| 168 | #ifdef DEBUG | 162 | #ifdef DEBUG |
| @@ -257,8 +251,11 @@ static struct task_struct *select_bad_process(unsigned long *ppoints, | |||
| 257 | *ppoints = ULONG_MAX; | 251 | *ppoints = ULONG_MAX; |
| 258 | } | 252 | } |
| 259 | 253 | ||
| 254 | if (p->oomkilladj == OOM_DISABLE) | ||
| 255 | continue; | ||
| 256 | |||
| 260 | points = badness(p, uptime.tv_sec); | 257 | points = badness(p, uptime.tv_sec); |
| 261 | if (points > *ppoints) { | 258 | if (points > *ppoints || !chosen) { |
| 262 | chosen = p; | 259 | chosen = p; |
| 263 | *ppoints = points; | 260 | *ppoints = points; |
| 264 | } | 261 | } |
| @@ -307,7 +304,8 @@ static void dump_tasks(const struct mem_cgroup *mem) | |||
| 307 | } | 304 | } |
| 308 | printk(KERN_INFO "[%5d] %5d %5d %8lu %8lu %3d %3d %s\n", | 305 | printk(KERN_INFO "[%5d] %5d %5d %8lu %8lu %3d %3d %s\n", |
| 309 | p->pid, __task_cred(p)->uid, p->tgid, mm->total_vm, | 306 | p->pid, __task_cred(p)->uid, p->tgid, mm->total_vm, |
| 310 | get_mm_rss(mm), (int)task_cpu(p), mm->oom_adj, p->comm); | 307 | get_mm_rss(mm), (int)task_cpu(p), p->oomkilladj, |
| 308 | p->comm); | ||
| 311 | task_unlock(p); | 309 | task_unlock(p); |
| 312 | } while_each_thread(g, p); | 310 | } while_each_thread(g, p); |
| 313 | } | 311 | } |
| @@ -325,8 +323,11 @@ static void __oom_kill_task(struct task_struct *p, int verbose) | |||
| 325 | return; | 323 | return; |
| 326 | } | 324 | } |
| 327 | 325 | ||
| 328 | if (!p->mm) | 326 | if (!p->mm) { |
| 327 | WARN_ON(1); | ||
| 328 | printk(KERN_WARNING "tried to kill an mm-less task!\n"); | ||
| 329 | return; | 329 | return; |
| 330 | } | ||
| 330 | 331 | ||
| 331 | if (verbose) | 332 | if (verbose) |
| 332 | printk(KERN_ERR "Killed process %d (%s)\n", | 333 | printk(KERN_ERR "Killed process %d (%s)\n", |
| @@ -348,13 +349,28 @@ static int oom_kill_task(struct task_struct *p) | |||
| 348 | struct mm_struct *mm; | 349 | struct mm_struct *mm; |
| 349 | struct task_struct *g, *q; | 350 | struct task_struct *g, *q; |
| 350 | 351 | ||
| 351 | task_lock(p); | ||
| 352 | mm = p->mm; | 352 | mm = p->mm; |
| 353 | if (!mm || mm->oom_adj == OOM_DISABLE) { | 353 | |
| 354 | task_unlock(p); | 354 | /* WARNING: mm may not be dereferenced since we did not obtain its |
| 355 | * value from get_task_mm(p). This is OK since all we need to do is | ||
| 356 | * compare mm to q->mm below. | ||
| 357 | * | ||
| 358 | * Furthermore, even if mm contains a non-NULL value, p->mm may | ||
| 359 | * change to NULL at any time since we do not hold task_lock(p). | ||
| 360 | * However, this is of no concern to us. | ||
| 361 | */ | ||
| 362 | |||
| 363 | if (mm == NULL) | ||
| 355 | return 1; | 364 | return 1; |
| 356 | } | 365 | |
| 357 | task_unlock(p); | 366 | /* |
| 367 | * Don't kill the process if any threads are set to OOM_DISABLE | ||
| 368 | */ | ||
| 369 | do_each_thread(g, q) { | ||
| 370 | if (q->mm == mm && q->oomkilladj == OOM_DISABLE) | ||
| 371 | return 1; | ||
| 372 | } while_each_thread(g, q); | ||
| 373 | |||
| 358 | __oom_kill_task(p, 1); | 374 | __oom_kill_task(p, 1); |
| 359 | 375 | ||
| 360 | /* | 376 | /* |
| @@ -377,11 +393,10 @@ static int oom_kill_process(struct task_struct *p, gfp_t gfp_mask, int order, | |||
| 377 | struct task_struct *c; | 393 | struct task_struct *c; |
| 378 | 394 | ||
| 379 | if (printk_ratelimit()) { | 395 | if (printk_ratelimit()) { |
| 380 | task_lock(current); | ||
| 381 | printk(KERN_WARNING "%s invoked oom-killer: " | 396 | printk(KERN_WARNING "%s invoked oom-killer: " |
| 382 | "gfp_mask=0x%x, order=%d, oom_adj=%d\n", | 397 | "gfp_mask=0x%x, order=%d, oomkilladj=%d\n", |
| 383 | current->comm, gfp_mask, order, | 398 | current->comm, gfp_mask, order, current->oomkilladj); |
| 384 | current->mm ? current->mm->oom_adj : OOM_DISABLE); | 399 | task_lock(current); |
| 385 | cpuset_print_task_mems_allowed(current); | 400 | cpuset_print_task_mems_allowed(current); |
| 386 | task_unlock(current); | 401 | task_unlock(current); |
| 387 | dump_stack(); | 402 | dump_stack(); |
| @@ -394,9 +409,8 @@ static int oom_kill_process(struct task_struct *p, gfp_t gfp_mask, int order, | |||
| 394 | /* | 409 | /* |
| 395 | * If the task is already exiting, don't alarm the sysadmin or kill | 410 | * If the task is already exiting, don't alarm the sysadmin or kill |
| 396 | * its children or threads, just set TIF_MEMDIE so it can die quickly | 411 | * its children or threads, just set TIF_MEMDIE so it can die quickly |
| 397 | * if its mm is still attached. | ||
| 398 | */ | 412 | */ |
| 399 | if (p->mm && (p->flags & PF_EXITING)) { | 413 | if (p->flags & PF_EXITING) { |
| 400 | __oom_kill_task(p, 0); | 414 | __oom_kill_task(p, 0); |
| 401 | return 0; | 415 | return 0; |
| 402 | } | 416 | } |
diff --git a/mm/page_alloc.c b/mm/page_alloc.c index caa92689aac9..5cc986eb9f6f 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c | |||
| @@ -882,7 +882,7 @@ retry_reserve: | |||
| 882 | */ | 882 | */ |
| 883 | static int rmqueue_bulk(struct zone *zone, unsigned int order, | 883 | static int rmqueue_bulk(struct zone *zone, unsigned int order, |
| 884 | unsigned long count, struct list_head *list, | 884 | unsigned long count, struct list_head *list, |
| 885 | int migratetype) | 885 | int migratetype, int cold) |
| 886 | { | 886 | { |
| 887 | int i; | 887 | int i; |
| 888 | 888 | ||
| @@ -901,7 +901,10 @@ static int rmqueue_bulk(struct zone *zone, unsigned int order, | |||
| 901 | * merge IO requests if the physical pages are ordered | 901 | * merge IO requests if the physical pages are ordered |
| 902 | * properly. | 902 | * properly. |
| 903 | */ | 903 | */ |
| 904 | list_add(&page->lru, list); | 904 | if (likely(cold == 0)) |
| 905 | list_add(&page->lru, list); | ||
| 906 | else | ||
| 907 | list_add_tail(&page->lru, list); | ||
| 905 | set_page_private(page, migratetype); | 908 | set_page_private(page, migratetype); |
| 906 | list = &page->lru; | 909 | list = &page->lru; |
| 907 | } | 910 | } |
| @@ -1119,7 +1122,8 @@ again: | |||
| 1119 | local_irq_save(flags); | 1122 | local_irq_save(flags); |
| 1120 | if (!pcp->count) { | 1123 | if (!pcp->count) { |
| 1121 | pcp->count = rmqueue_bulk(zone, 0, | 1124 | pcp->count = rmqueue_bulk(zone, 0, |
| 1122 | pcp->batch, &pcp->list, migratetype); | 1125 | pcp->batch, &pcp->list, |
| 1126 | migratetype, cold); | ||
| 1123 | if (unlikely(!pcp->count)) | 1127 | if (unlikely(!pcp->count)) |
| 1124 | goto failed; | 1128 | goto failed; |
| 1125 | } | 1129 | } |
| @@ -1138,7 +1142,8 @@ again: | |||
| 1138 | /* Allocate more to the pcp list if necessary */ | 1142 | /* Allocate more to the pcp list if necessary */ |
| 1139 | if (unlikely(&page->lru == &pcp->list)) { | 1143 | if (unlikely(&page->lru == &pcp->list)) { |
| 1140 | pcp->count += rmqueue_bulk(zone, 0, | 1144 | pcp->count += rmqueue_bulk(zone, 0, |
| 1141 | pcp->batch, &pcp->list, migratetype); | 1145 | pcp->batch, &pcp->list, |
| 1146 | migratetype, cold); | ||
| 1142 | page = list_entry(pcp->list.next, struct page, lru); | 1147 | page = list_entry(pcp->list.next, struct page, lru); |
| 1143 | } | 1148 | } |
| 1144 | 1149 | ||
| @@ -1740,8 +1745,10 @@ __alloc_pages_slowpath(gfp_t gfp_mask, unsigned int order, | |||
| 1740 | * be using allocators in order of preference for an area that is | 1745 | * be using allocators in order of preference for an area that is |
| 1741 | * too large. | 1746 | * too large. |
| 1742 | */ | 1747 | */ |
| 1743 | if (WARN_ON_ONCE(order >= MAX_ORDER)) | 1748 | if (order >= MAX_ORDER) { |
| 1749 | WARN_ON_ONCE(!(gfp_mask & __GFP_NOWARN)); | ||
| 1744 | return NULL; | 1750 | return NULL; |
| 1751 | } | ||
| 1745 | 1752 | ||
| 1746 | /* | 1753 | /* |
| 1747 | * GFP_THISNODE (meaning __GFP_THISNODE, __GFP_NORETRY and | 1754 | * GFP_THISNODE (meaning __GFP_THISNODE, __GFP_NORETRY and |
| @@ -1789,6 +1796,10 @@ rebalance: | |||
| 1789 | if (p->flags & PF_MEMALLOC) | 1796 | if (p->flags & PF_MEMALLOC) |
| 1790 | goto nopage; | 1797 | goto nopage; |
| 1791 | 1798 | ||
| 1799 | /* Avoid allocations with no watermarks from looping endlessly */ | ||
| 1800 | if (test_thread_flag(TIF_MEMDIE) && !(gfp_mask & __GFP_NOFAIL)) | ||
| 1801 | goto nopage; | ||
| 1802 | |||
| 1792 | /* Try direct reclaim and then allocating */ | 1803 | /* Try direct reclaim and then allocating */ |
| 1793 | page = __alloc_pages_direct_reclaim(gfp_mask, order, | 1804 | page = __alloc_pages_direct_reclaim(gfp_mask, order, |
| 1794 | zonelist, high_zoneidx, | 1805 | zonelist, high_zoneidx, |
| @@ -2533,7 +2544,6 @@ static void build_zonelists(pg_data_t *pgdat) | |||
| 2533 | prev_node = local_node; | 2544 | prev_node = local_node; |
| 2534 | nodes_clear(used_mask); | 2545 | nodes_clear(used_mask); |
| 2535 | 2546 | ||
| 2536 | memset(node_load, 0, sizeof(node_load)); | ||
| 2537 | memset(node_order, 0, sizeof(node_order)); | 2547 | memset(node_order, 0, sizeof(node_order)); |
| 2538 | j = 0; | 2548 | j = 0; |
| 2539 | 2549 | ||
| @@ -2642,6 +2652,9 @@ static int __build_all_zonelists(void *dummy) | |||
| 2642 | { | 2652 | { |
| 2643 | int nid; | 2653 | int nid; |
| 2644 | 2654 | ||
| 2655 | #ifdef CONFIG_NUMA | ||
| 2656 | memset(node_load, 0, sizeof(node_load)); | ||
| 2657 | #endif | ||
| 2645 | for_each_online_node(nid) { | 2658 | for_each_online_node(nid) { |
| 2646 | pg_data_t *pgdat = NODE_DATA(nid); | 2659 | pg_data_t *pgdat = NODE_DATA(nid); |
| 2647 | 2660 | ||
diff --git a/mm/percpu.c b/mm/percpu.c index b70f2acd8853..5fe37842e0ea 100644 --- a/mm/percpu.c +++ b/mm/percpu.c | |||
| @@ -8,12 +8,12 @@ | |||
| 8 | * | 8 | * |
| 9 | * This is percpu allocator which can handle both static and dynamic | 9 | * This is percpu allocator which can handle both static and dynamic |
| 10 | * areas. Percpu areas are allocated in chunks in vmalloc area. Each | 10 | * areas. Percpu areas are allocated in chunks in vmalloc area. Each |
| 11 | * chunk is consisted of num_possible_cpus() units and the first chunk | 11 | * chunk is consisted of nr_cpu_ids units and the first chunk is used |
| 12 | * is used for static percpu variables in the kernel image (special | 12 | * for static percpu variables in the kernel image (special boot time |
| 13 | * boot time alloc/init handling necessary as these areas need to be | 13 | * alloc/init handling necessary as these areas need to be brought up |
| 14 | * brought up before allocation services are running). Unit grows as | 14 | * before allocation services are running). Unit grows as necessary |
| 15 | * necessary and all units grow or shrink in unison. When a chunk is | 15 | * and all units grow or shrink in unison. When a chunk is filled up, |
| 16 | * filled up, another chunk is allocated. ie. in vmalloc area | 16 | * another chunk is allocated. ie. in vmalloc area |
| 17 | * | 17 | * |
| 18 | * c0 c1 c2 | 18 | * c0 c1 c2 |
| 19 | * ------------------- ------------------- ------------ | 19 | * ------------------- ------------------- ------------ |
| @@ -558,7 +558,7 @@ static void pcpu_free_area(struct pcpu_chunk *chunk, int freeme) | |||
| 558 | static void pcpu_unmap(struct pcpu_chunk *chunk, int page_start, int page_end, | 558 | static void pcpu_unmap(struct pcpu_chunk *chunk, int page_start, int page_end, |
| 559 | bool flush_tlb) | 559 | bool flush_tlb) |
| 560 | { | 560 | { |
| 561 | unsigned int last = num_possible_cpus() - 1; | 561 | unsigned int last = nr_cpu_ids - 1; |
| 562 | unsigned int cpu; | 562 | unsigned int cpu; |
| 563 | 563 | ||
| 564 | /* unmap must not be done on immutable chunk */ | 564 | /* unmap must not be done on immutable chunk */ |
| @@ -643,7 +643,7 @@ static void pcpu_depopulate_chunk(struct pcpu_chunk *chunk, int off, int size, | |||
| 643 | */ | 643 | */ |
| 644 | static int pcpu_map(struct pcpu_chunk *chunk, int page_start, int page_end) | 644 | static int pcpu_map(struct pcpu_chunk *chunk, int page_start, int page_end) |
| 645 | { | 645 | { |
| 646 | unsigned int last = num_possible_cpus() - 1; | 646 | unsigned int last = nr_cpu_ids - 1; |
| 647 | unsigned int cpu; | 647 | unsigned int cpu; |
| 648 | int err; | 648 | int err; |
| 649 | 649 | ||
| @@ -749,7 +749,7 @@ static struct pcpu_chunk *alloc_pcpu_chunk(void) | |||
| 749 | chunk->map[chunk->map_used++] = pcpu_unit_size; | 749 | chunk->map[chunk->map_used++] = pcpu_unit_size; |
| 750 | chunk->page = chunk->page_ar; | 750 | chunk->page = chunk->page_ar; |
| 751 | 751 | ||
| 752 | chunk->vm = get_vm_area(pcpu_chunk_size, GFP_KERNEL); | 752 | chunk->vm = get_vm_area(pcpu_chunk_size, VM_ALLOC); |
| 753 | if (!chunk->vm) { | 753 | if (!chunk->vm) { |
| 754 | free_pcpu_chunk(chunk); | 754 | free_pcpu_chunk(chunk); |
| 755 | return NULL; | 755 | return NULL; |
| @@ -1067,9 +1067,9 @@ size_t __init pcpu_setup_first_chunk(pcpu_get_page_fn_t get_page_fn, | |||
| 1067 | PFN_UP(size_sum)); | 1067 | PFN_UP(size_sum)); |
| 1068 | 1068 | ||
| 1069 | pcpu_unit_size = pcpu_unit_pages << PAGE_SHIFT; | 1069 | pcpu_unit_size = pcpu_unit_pages << PAGE_SHIFT; |
| 1070 | pcpu_chunk_size = num_possible_cpus() * pcpu_unit_size; | 1070 | pcpu_chunk_size = nr_cpu_ids * pcpu_unit_size; |
| 1071 | pcpu_chunk_struct_size = sizeof(struct pcpu_chunk) | 1071 | pcpu_chunk_struct_size = sizeof(struct pcpu_chunk) |
| 1072 | + num_possible_cpus() * pcpu_unit_pages * sizeof(struct page *); | 1072 | + nr_cpu_ids * pcpu_unit_pages * sizeof(struct page *); |
| 1073 | 1073 | ||
| 1074 | if (dyn_size < 0) | 1074 | if (dyn_size < 0) |
| 1075 | dyn_size = pcpu_unit_size - static_size - reserved_size; | 1075 | dyn_size = pcpu_unit_size - static_size - reserved_size; |
| @@ -1248,7 +1248,7 @@ ssize_t __init pcpu_embed_first_chunk(size_t static_size, size_t reserved_size, | |||
| 1248 | } else | 1248 | } else |
| 1249 | pcpue_unit_size = max_t(size_t, pcpue_size, PCPU_MIN_UNIT_SIZE); | 1249 | pcpue_unit_size = max_t(size_t, pcpue_size, PCPU_MIN_UNIT_SIZE); |
| 1250 | 1250 | ||
| 1251 | chunk_size = pcpue_unit_size * num_possible_cpus(); | 1251 | chunk_size = pcpue_unit_size * nr_cpu_ids; |
| 1252 | 1252 | ||
| 1253 | pcpue_ptr = __alloc_bootmem_nopanic(chunk_size, PAGE_SIZE, | 1253 | pcpue_ptr = __alloc_bootmem_nopanic(chunk_size, PAGE_SIZE, |
| 1254 | __pa(MAX_DMA_ADDRESS)); | 1254 | __pa(MAX_DMA_ADDRESS)); |
| @@ -1259,12 +1259,15 @@ ssize_t __init pcpu_embed_first_chunk(size_t static_size, size_t reserved_size, | |||
| 1259 | } | 1259 | } |
| 1260 | 1260 | ||
| 1261 | /* return the leftover and copy */ | 1261 | /* return the leftover and copy */ |
| 1262 | for_each_possible_cpu(cpu) { | 1262 | for (cpu = 0; cpu < nr_cpu_ids; cpu++) { |
| 1263 | void *ptr = pcpue_ptr + cpu * pcpue_unit_size; | 1263 | void *ptr = pcpue_ptr + cpu * pcpue_unit_size; |
| 1264 | 1264 | ||
| 1265 | free_bootmem(__pa(ptr + pcpue_size), | 1265 | if (cpu_possible(cpu)) { |
| 1266 | pcpue_unit_size - pcpue_size); | 1266 | free_bootmem(__pa(ptr + pcpue_size), |
| 1267 | memcpy(ptr, __per_cpu_load, static_size); | 1267 | pcpue_unit_size - pcpue_size); |
| 1268 | memcpy(ptr, __per_cpu_load, static_size); | ||
| 1269 | } else | ||
| 1270 | free_bootmem(__pa(ptr), pcpue_unit_size); | ||
| 1268 | } | 1271 | } |
| 1269 | 1272 | ||
| 1270 | /* we're ready, commit */ | 1273 | /* we're ready, commit */ |
| @@ -358,6 +358,7 @@ static int page_referenced_one(struct page *page, | |||
| 358 | */ | 358 | */ |
| 359 | if (vma->vm_flags & VM_LOCKED) { | 359 | if (vma->vm_flags & VM_LOCKED) { |
| 360 | *mapcount = 1; /* break early from loop */ | 360 | *mapcount = 1; /* break early from loop */ |
| 361 | *vm_flags |= VM_LOCKED; | ||
| 361 | goto out_unmap; | 362 | goto out_unmap; |
| 362 | } | 363 | } |
| 363 | 364 | ||
diff --git a/mm/swapfile.c b/mm/swapfile.c index d1ade1a48ee7..8ffdc0d23c53 100644 --- a/mm/swapfile.c +++ b/mm/swapfile.c | |||
| @@ -753,7 +753,7 @@ int swap_type_of(dev_t device, sector_t offset, struct block_device **bdev_p) | |||
| 753 | 753 | ||
| 754 | if (!bdev) { | 754 | if (!bdev) { |
| 755 | if (bdev_p) | 755 | if (bdev_p) |
| 756 | *bdev_p = bdget(sis->bdev->bd_dev); | 756 | *bdev_p = bdgrab(sis->bdev); |
| 757 | 757 | ||
| 758 | spin_unlock(&swap_lock); | 758 | spin_unlock(&swap_lock); |
| 759 | return i; | 759 | return i; |
| @@ -765,7 +765,7 @@ int swap_type_of(dev_t device, sector_t offset, struct block_device **bdev_p) | |||
| 765 | struct swap_extent, list); | 765 | struct swap_extent, list); |
| 766 | if (se->start_block == offset) { | 766 | if (se->start_block == offset) { |
| 767 | if (bdev_p) | 767 | if (bdev_p) |
| 768 | *bdev_p = bdget(sis->bdev->bd_dev); | 768 | *bdev_p = bdgrab(sis->bdev); |
| 769 | 769 | ||
| 770 | spin_unlock(&swap_lock); | 770 | spin_unlock(&swap_lock); |
| 771 | bdput(bdev); | 771 | bdput(bdev); |
diff --git a/mm/vmscan.c b/mm/vmscan.c index dea7abd31098..94e86dd6954c 100644 --- a/mm/vmscan.c +++ b/mm/vmscan.c | |||
| @@ -630,9 +630,14 @@ static unsigned long shrink_page_list(struct list_head *page_list, | |||
| 630 | 630 | ||
| 631 | referenced = page_referenced(page, 1, | 631 | referenced = page_referenced(page, 1, |
| 632 | sc->mem_cgroup, &vm_flags); | 632 | sc->mem_cgroup, &vm_flags); |
| 633 | /* In active use or really unfreeable? Activate it. */ | 633 | /* |
| 634 | * In active use or really unfreeable? Activate it. | ||
| 635 | * If page which have PG_mlocked lost isoltation race, | ||
| 636 | * try_to_unmap moves it to unevictable list | ||
| 637 | */ | ||
| 634 | if (sc->order <= PAGE_ALLOC_COSTLY_ORDER && | 638 | if (sc->order <= PAGE_ALLOC_COSTLY_ORDER && |
| 635 | referenced && page_mapping_inuse(page)) | 639 | referenced && page_mapping_inuse(page) |
| 640 | && !(vm_flags & VM_LOCKED)) | ||
| 636 | goto activate_locked; | 641 | goto activate_locked; |
| 637 | 642 | ||
| 638 | /* | 643 | /* |
diff --git a/net/9p/client.c b/net/9p/client.c index 787ccddb85ea..5bf5f227dbe0 100644 --- a/net/9p/client.c +++ b/net/9p/client.c | |||
| @@ -60,9 +60,9 @@ static struct p9_req_t * | |||
| 60 | p9_client_rpc(struct p9_client *c, int8_t type, const char *fmt, ...); | 60 | p9_client_rpc(struct p9_client *c, int8_t type, const char *fmt, ...); |
| 61 | 61 | ||
| 62 | /** | 62 | /** |
| 63 | * v9fs_parse_options - parse mount options into session structure | 63 | * parse_options - parse mount options into client structure |
| 64 | * @options: options string passed from mount | 64 | * @opts: options string passed from mount |
| 65 | * @v9ses: existing v9fs session information | 65 | * @clnt: existing v9fs client information |
| 66 | * | 66 | * |
| 67 | * Return 0 upon success, -ERRNO upon failure | 67 | * Return 0 upon success, -ERRNO upon failure |
| 68 | */ | 68 | */ |
| @@ -232,7 +232,7 @@ EXPORT_SYMBOL(p9_tag_lookup); | |||
| 232 | 232 | ||
| 233 | /** | 233 | /** |
| 234 | * p9_tag_init - setup tags structure and contents | 234 | * p9_tag_init - setup tags structure and contents |
| 235 | * @tags: tags structure from the client struct | 235 | * @c: v9fs client struct |
| 236 | * | 236 | * |
| 237 | * This initializes the tags structure for each client instance. | 237 | * This initializes the tags structure for each client instance. |
| 238 | * | 238 | * |
| @@ -258,7 +258,7 @@ error: | |||
| 258 | 258 | ||
| 259 | /** | 259 | /** |
| 260 | * p9_tag_cleanup - cleans up tags structure and reclaims resources | 260 | * p9_tag_cleanup - cleans up tags structure and reclaims resources |
| 261 | * @tags: tags structure from the client struct | 261 | * @c: v9fs client struct |
| 262 | * | 262 | * |
| 263 | * This frees resources associated with the tags structure | 263 | * This frees resources associated with the tags structure |
| 264 | * | 264 | * |
| @@ -411,14 +411,9 @@ static int p9_check_errors(struct p9_client *c, struct p9_req_t *req) | |||
| 411 | if (c->dotu) | 411 | if (c->dotu) |
| 412 | err = -ecode; | 412 | err = -ecode; |
| 413 | 413 | ||
| 414 | if (!err) { | 414 | if (!err || !IS_ERR_VALUE(err)) |
| 415 | err = p9_errstr2errno(ename, strlen(ename)); | 415 | err = p9_errstr2errno(ename, strlen(ename)); |
| 416 | 416 | ||
| 417 | /* string match failed */ | ||
| 418 | if (!err) | ||
| 419 | err = -ESERVERFAULT; | ||
| 420 | } | ||
| 421 | |||
| 422 | P9_DPRINTK(P9_DEBUG_9P, "<<< RERROR (%d) %s\n", -ecode, ename); | 417 | P9_DPRINTK(P9_DEBUG_9P, "<<< RERROR (%d) %s\n", -ecode, ename); |
| 423 | 418 | ||
| 424 | kfree(ename); | 419 | kfree(ename); |
| @@ -430,8 +425,8 @@ static int p9_check_errors(struct p9_client *c, struct p9_req_t *req) | |||
| 430 | 425 | ||
| 431 | /** | 426 | /** |
| 432 | * p9_client_flush - flush (cancel) a request | 427 | * p9_client_flush - flush (cancel) a request |
| 433 | * c: client state | 428 | * @c: client state |
| 434 | * req: request to cancel | 429 | * @oldreq: request to cancel |
| 435 | * | 430 | * |
| 436 | * This sents a flush for a particular requests and links | 431 | * This sents a flush for a particular requests and links |
| 437 | * the flush request to the original request. The current | 432 | * the flush request to the original request. The current |
diff --git a/net/9p/error.c b/net/9p/error.c index fdebe4314062..52518512a93e 100644 --- a/net/9p/error.c +++ b/net/9p/error.c | |||
| @@ -239,7 +239,7 @@ int p9_errstr2errno(char *errstr, int len) | |||
| 239 | errstr[len] = 0; | 239 | errstr[len] = 0; |
| 240 | printk(KERN_ERR "%s: server reported unknown error %s\n", | 240 | printk(KERN_ERR "%s: server reported unknown error %s\n", |
| 241 | __func__, errstr); | 241 | __func__, errstr); |
| 242 | errno = 1; | 242 | errno = ESERVERFAULT; |
| 243 | } | 243 | } |
| 244 | 244 | ||
| 245 | return -errno; | 245 | return -errno; |
diff --git a/net/9p/trans_fd.c b/net/9p/trans_fd.c index 8c2588e4edc0..8d934dd7fd54 100644 --- a/net/9p/trans_fd.c +++ b/net/9p/trans_fd.c | |||
| @@ -119,8 +119,8 @@ struct p9_poll_wait { | |||
| 119 | * @wpos: write position for current frame | 119 | * @wpos: write position for current frame |
| 120 | * @wsize: amount of data to write for current frame | 120 | * @wsize: amount of data to write for current frame |
| 121 | * @wbuf: current write buffer | 121 | * @wbuf: current write buffer |
| 122 | * @poll_pending_link: pending links to be polled per conn | ||
| 122 | * @poll_wait: array of wait_q's for various worker threads | 123 | * @poll_wait: array of wait_q's for various worker threads |
| 123 | * @poll_waddr: ???? | ||
| 124 | * @pt: poll state | 124 | * @pt: poll state |
| 125 | * @rq: current read work | 125 | * @rq: current read work |
| 126 | * @wq: current write work | 126 | * @wq: current write work |
| @@ -700,9 +700,9 @@ static int p9_fd_cancel(struct p9_client *client, struct p9_req_t *req) | |||
| 700 | } | 700 | } |
| 701 | 701 | ||
| 702 | /** | 702 | /** |
| 703 | * parse_options - parse mount options into session structure | 703 | * parse_opts - parse mount options into p9_fd_opts structure |
| 704 | * @options: options string passed from mount | 704 | * @params: options string passed from mount |
| 705 | * @opts: transport-specific structure to parse options into | 705 | * @opts: fd transport-specific structure to parse options into |
| 706 | * | 706 | * |
| 707 | * Returns 0 upon success, -ERRNO upon failure | 707 | * Returns 0 upon success, -ERRNO upon failure |
| 708 | */ | 708 | */ |
diff --git a/net/9p/trans_rdma.c b/net/9p/trans_rdma.c index ac4990041ebb..65cb29db03f8 100644 --- a/net/9p/trans_rdma.c +++ b/net/9p/trans_rdma.c | |||
| @@ -67,14 +67,15 @@ | |||
| 67 | * @pd: Protection Domain pointer | 67 | * @pd: Protection Domain pointer |
| 68 | * @qp: Queue Pair pointer | 68 | * @qp: Queue Pair pointer |
| 69 | * @cq: Completion Queue pointer | 69 | * @cq: Completion Queue pointer |
| 70 | * @dm_mr: DMA Memory Region pointer | ||
| 70 | * @lkey: The local access only memory region key | 71 | * @lkey: The local access only memory region key |
| 71 | * @timeout: Number of uSecs to wait for connection management events | 72 | * @timeout: Number of uSecs to wait for connection management events |
| 72 | * @sq_depth: The depth of the Send Queue | 73 | * @sq_depth: The depth of the Send Queue |
| 73 | * @sq_sem: Semaphore for the SQ | 74 | * @sq_sem: Semaphore for the SQ |
| 74 | * @rq_depth: The depth of the Receive Queue. | 75 | * @rq_depth: The depth of the Receive Queue. |
| 76 | * @rq_count: Count of requests in the Receive Queue. | ||
| 75 | * @addr: The remote peer's address | 77 | * @addr: The remote peer's address |
| 76 | * @req_lock: Protects the active request list | 78 | * @req_lock: Protects the active request list |
| 77 | * @send_wait: Wait list when the SQ fills up | ||
| 78 | * @cm_done: Completion event for connection management tracking | 79 | * @cm_done: Completion event for connection management tracking |
| 79 | */ | 80 | */ |
| 80 | struct p9_trans_rdma { | 81 | struct p9_trans_rdma { |
| @@ -154,9 +155,9 @@ static match_table_t tokens = { | |||
| 154 | }; | 155 | }; |
| 155 | 156 | ||
| 156 | /** | 157 | /** |
| 157 | * parse_options - parse mount options into session structure | 158 | * parse_opts - parse mount options into rdma options structure |
| 158 | * @options: options string passed from mount | 159 | * @params: options string passed from mount |
| 159 | * @opts: transport-specific structure to parse options into | 160 | * @opts: rdma transport-specific structure to parse options into |
| 160 | * | 161 | * |
| 161 | * Returns 0 upon success, -ERRNO upon failure | 162 | * Returns 0 upon success, -ERRNO upon failure |
| 162 | */ | 163 | */ |
diff --git a/net/9p/trans_virtio.c b/net/9p/trans_virtio.c index a49484e67e1d..9bf0b737aa51 100644 --- a/net/9p/trans_virtio.c +++ b/net/9p/trans_virtio.c | |||
| @@ -57,11 +57,9 @@ static int chan_index; | |||
| 57 | * @initialized: whether the channel is initialized | 57 | * @initialized: whether the channel is initialized |
| 58 | * @inuse: whether the channel is in use | 58 | * @inuse: whether the channel is in use |
| 59 | * @lock: protects multiple elements within this structure | 59 | * @lock: protects multiple elements within this structure |
| 60 | * @client: client instance | ||
| 60 | * @vdev: virtio dev associated with this channel | 61 | * @vdev: virtio dev associated with this channel |
| 61 | * @vq: virtio queue associated with this channel | 62 | * @vq: virtio queue associated with this channel |
| 62 | * @tagpool: accounting for tag ids (and request slots) | ||
| 63 | * @reqs: array of request slots | ||
| 64 | * @max_tag: current number of request_slots allocated | ||
| 65 | * @sg: scatter gather list which is used to pack a request (protected?) | 63 | * @sg: scatter gather list which is used to pack a request (protected?) |
| 66 | * | 64 | * |
| 67 | * We keep all per-channel information in a structure. | 65 | * We keep all per-channel information in a structure. |
| @@ -92,7 +90,7 @@ static unsigned int rest_of_page(void *data) | |||
| 92 | 90 | ||
| 93 | /** | 91 | /** |
| 94 | * p9_virtio_close - reclaim resources of a channel | 92 | * p9_virtio_close - reclaim resources of a channel |
| 95 | * @trans: transport state | 93 | * @client: client instance |
| 96 | * | 94 | * |
| 97 | * This reclaims a channel by freeing its resources and | 95 | * This reclaims a channel by freeing its resources and |
| 98 | * reseting its inuse flag. | 96 | * reseting its inuse flag. |
| @@ -181,9 +179,8 @@ static int p9_virtio_cancel(struct p9_client *client, struct p9_req_t *req) | |||
| 181 | 179 | ||
| 182 | /** | 180 | /** |
| 183 | * p9_virtio_request - issue a request | 181 | * p9_virtio_request - issue a request |
| 184 | * @t: transport state | 182 | * @client: client instance issuing the request |
| 185 | * @tc: &p9_fcall request to transmit | 183 | * @req: request to be issued |
| 186 | * @rc: &p9_fcall to put reponse into | ||
| 187 | * | 184 | * |
| 188 | */ | 185 | */ |
| 189 | 186 | ||
diff --git a/net/appletalk/ddp.c b/net/appletalk/ddp.c index bfbe13786bb4..875eda5dbad7 100644 --- a/net/appletalk/ddp.c +++ b/net/appletalk/ddp.c | |||
| @@ -1238,6 +1238,7 @@ static int atalk_getname(struct socket *sock, struct sockaddr *uaddr, | |||
| 1238 | return -ENOBUFS; | 1238 | return -ENOBUFS; |
| 1239 | 1239 | ||
| 1240 | *uaddr_len = sizeof(struct sockaddr_at); | 1240 | *uaddr_len = sizeof(struct sockaddr_at); |
| 1241 | memset(&sat.sat_zero, 0, sizeof(sat.sat_zero)); | ||
| 1241 | 1242 | ||
| 1242 | if (peer) { | 1243 | if (peer) { |
| 1243 | if (sk->sk_state != TCP_ESTABLISHED) | 1244 | if (sk->sk_state != TCP_ESTABLISHED) |
diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c index e50566ebf9f9..94b3388c188b 100644 --- a/net/bluetooth/rfcomm/core.c +++ b/net/bluetooth/rfcomm/core.c | |||
| @@ -2080,28 +2080,41 @@ static CLASS_ATTR(rfcomm_dlc, S_IRUGO, rfcomm_dlc_sysfs_show, NULL); | |||
| 2080 | /* ---- Initialization ---- */ | 2080 | /* ---- Initialization ---- */ |
| 2081 | static int __init rfcomm_init(void) | 2081 | static int __init rfcomm_init(void) |
| 2082 | { | 2082 | { |
| 2083 | int ret; | ||
| 2084 | |||
| 2083 | l2cap_load(); | 2085 | l2cap_load(); |
| 2084 | 2086 | ||
| 2085 | hci_register_cb(&rfcomm_cb); | 2087 | hci_register_cb(&rfcomm_cb); |
| 2086 | 2088 | ||
| 2087 | rfcomm_thread = kthread_run(rfcomm_run, NULL, "krfcommd"); | 2089 | rfcomm_thread = kthread_run(rfcomm_run, NULL, "krfcommd"); |
| 2088 | if (IS_ERR(rfcomm_thread)) { | 2090 | if (IS_ERR(rfcomm_thread)) { |
| 2089 | hci_unregister_cb(&rfcomm_cb); | 2091 | ret = PTR_ERR(rfcomm_thread); |
| 2090 | return PTR_ERR(rfcomm_thread); | 2092 | goto out_thread; |
| 2091 | } | 2093 | } |
| 2092 | 2094 | ||
| 2093 | if (class_create_file(bt_class, &class_attr_rfcomm_dlc) < 0) | 2095 | if (class_create_file(bt_class, &class_attr_rfcomm_dlc) < 0) |
| 2094 | BT_ERR("Failed to create RFCOMM info file"); | 2096 | BT_ERR("Failed to create RFCOMM info file"); |
| 2095 | 2097 | ||
| 2096 | rfcomm_init_sockets(); | 2098 | ret = rfcomm_init_ttys(); |
| 2099 | if (ret) | ||
| 2100 | goto out_tty; | ||
| 2097 | 2101 | ||
| 2098 | #ifdef CONFIG_BT_RFCOMM_TTY | 2102 | ret = rfcomm_init_sockets(); |
| 2099 | rfcomm_init_ttys(); | 2103 | if (ret) |
| 2100 | #endif | 2104 | goto out_sock; |
| 2101 | 2105 | ||
| 2102 | BT_INFO("RFCOMM ver %s", VERSION); | 2106 | BT_INFO("RFCOMM ver %s", VERSION); |
| 2103 | 2107 | ||
| 2104 | return 0; | 2108 | return 0; |
| 2109 | |||
| 2110 | out_sock: | ||
| 2111 | rfcomm_cleanup_ttys(); | ||
| 2112 | out_tty: | ||
| 2113 | kthread_stop(rfcomm_thread); | ||
| 2114 | out_thread: | ||
| 2115 | hci_unregister_cb(&rfcomm_cb); | ||
| 2116 | |||
| 2117 | return ret; | ||
| 2105 | } | 2118 | } |
| 2106 | 2119 | ||
| 2107 | static void __exit rfcomm_exit(void) | 2120 | static void __exit rfcomm_exit(void) |
| @@ -2112,9 +2125,7 @@ static void __exit rfcomm_exit(void) | |||
| 2112 | 2125 | ||
| 2113 | kthread_stop(rfcomm_thread); | 2126 | kthread_stop(rfcomm_thread); |
| 2114 | 2127 | ||
| 2115 | #ifdef CONFIG_BT_RFCOMM_TTY | ||
| 2116 | rfcomm_cleanup_ttys(); | 2128 | rfcomm_cleanup_ttys(); |
| 2117 | #endif | ||
| 2118 | 2129 | ||
| 2119 | rfcomm_cleanup_sockets(); | 2130 | rfcomm_cleanup_sockets(); |
| 2120 | } | 2131 | } |
diff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c index 7f482784e9f7..0b85e8116859 100644 --- a/net/bluetooth/rfcomm/sock.c +++ b/net/bluetooth/rfcomm/sock.c | |||
| @@ -1132,7 +1132,7 @@ error: | |||
| 1132 | return err; | 1132 | return err; |
| 1133 | } | 1133 | } |
| 1134 | 1134 | ||
| 1135 | void __exit rfcomm_cleanup_sockets(void) | 1135 | void rfcomm_cleanup_sockets(void) |
| 1136 | { | 1136 | { |
| 1137 | class_remove_file(bt_class, &class_attr_rfcomm); | 1137 | class_remove_file(bt_class, &class_attr_rfcomm); |
| 1138 | 1138 | ||
diff --git a/net/bridge/br_if.c b/net/bridge/br_if.c index 8a96672e2c5c..eb404dc3ed6e 100644 --- a/net/bridge/br_if.c +++ b/net/bridge/br_if.c | |||
| @@ -424,7 +424,7 @@ int br_add_if(struct net_bridge *br, struct net_device *dev) | |||
| 424 | err2: | 424 | err2: |
| 425 | br_fdb_delete_by_port(br, p, 1); | 425 | br_fdb_delete_by_port(br, p, 1); |
| 426 | err1: | 426 | err1: |
| 427 | kobject_del(&p->kobj); | 427 | kobject_put(&p->kobj); |
| 428 | err0: | 428 | err0: |
| 429 | dev_set_promiscuity(dev, -1); | 429 | dev_set_promiscuity(dev, -1); |
| 430 | put_back: | 430 | put_back: |
diff --git a/net/can/bcm.c b/net/can/bcm.c index 95d7f32643ae..72720c710351 100644 --- a/net/can/bcm.c +++ b/net/can/bcm.c | |||
| @@ -75,6 +75,7 @@ static __initdata const char banner[] = KERN_INFO | |||
| 75 | MODULE_DESCRIPTION("PF_CAN broadcast manager protocol"); | 75 | MODULE_DESCRIPTION("PF_CAN broadcast manager protocol"); |
| 76 | MODULE_LICENSE("Dual BSD/GPL"); | 76 | MODULE_LICENSE("Dual BSD/GPL"); |
| 77 | MODULE_AUTHOR("Oliver Hartkopp <oliver.hartkopp@volkswagen.de>"); | 77 | MODULE_AUTHOR("Oliver Hartkopp <oliver.hartkopp@volkswagen.de>"); |
| 78 | MODULE_ALIAS("can-proto-2"); | ||
| 78 | 79 | ||
| 79 | /* easy access to can_frame payload */ | 80 | /* easy access to can_frame payload */ |
| 80 | static inline u64 GET_U64(const struct can_frame *cp) | 81 | static inline u64 GET_U64(const struct can_frame *cp) |
| @@ -1469,6 +1470,9 @@ static int bcm_release(struct socket *sock) | |||
| 1469 | bo->ifindex = 0; | 1470 | bo->ifindex = 0; |
| 1470 | } | 1471 | } |
| 1471 | 1472 | ||
| 1473 | sock_orphan(sk); | ||
| 1474 | sock->sk = NULL; | ||
| 1475 | |||
| 1472 | release_sock(sk); | 1476 | release_sock(sk); |
| 1473 | sock_put(sk); | 1477 | sock_put(sk); |
| 1474 | 1478 | ||
diff --git a/net/can/raw.c b/net/can/raw.c index 6aa154e806ae..db3152df7d2b 100644 --- a/net/can/raw.c +++ b/net/can/raw.c | |||
| @@ -62,6 +62,7 @@ static __initdata const char banner[] = | |||
| 62 | MODULE_DESCRIPTION("PF_CAN raw protocol"); | 62 | MODULE_DESCRIPTION("PF_CAN raw protocol"); |
| 63 | MODULE_LICENSE("Dual BSD/GPL"); | 63 | MODULE_LICENSE("Dual BSD/GPL"); |
| 64 | MODULE_AUTHOR("Urs Thuermann <urs.thuermann@volkswagen.de>"); | 64 | MODULE_AUTHOR("Urs Thuermann <urs.thuermann@volkswagen.de>"); |
| 65 | MODULE_ALIAS("can-proto-1"); | ||
| 65 | 66 | ||
| 66 | #define MASK_ALL 0 | 67 | #define MASK_ALL 0 |
| 67 | 68 | ||
| @@ -306,6 +307,9 @@ static int raw_release(struct socket *sock) | |||
| 306 | ro->bound = 0; | 307 | ro->bound = 0; |
| 307 | ro->count = 0; | 308 | ro->count = 0; |
| 308 | 309 | ||
| 310 | sock_orphan(sk); | ||
| 311 | sock->sk = NULL; | ||
| 312 | |||
| 309 | release_sock(sk); | 313 | release_sock(sk); |
| 310 | sock_put(sk); | 314 | sock_put(sk); |
| 311 | 315 | ||
| @@ -397,6 +401,7 @@ static int raw_getname(struct socket *sock, struct sockaddr *uaddr, | |||
| 397 | if (peer) | 401 | if (peer) |
| 398 | return -EOPNOTSUPP; | 402 | return -EOPNOTSUPP; |
| 399 | 403 | ||
| 404 | memset(addr, 0, sizeof(*addr)); | ||
| 400 | addr->can_family = AF_CAN; | 405 | addr->can_family = AF_CAN; |
| 401 | addr->can_ifindex = ro->ifindex; | 406 | addr->can_ifindex = ro->ifindex; |
| 402 | 407 | ||
diff --git a/net/core/dev.c b/net/core/dev.c index 70c27e0c7c32..6a94475aee85 100644 --- a/net/core/dev.c +++ b/net/core/dev.c | |||
| @@ -3865,10 +3865,12 @@ int dev_unicast_delete(struct net_device *dev, void *addr) | |||
| 3865 | 3865 | ||
| 3866 | ASSERT_RTNL(); | 3866 | ASSERT_RTNL(); |
| 3867 | 3867 | ||
| 3868 | netif_addr_lock_bh(dev); | ||
| 3868 | err = __hw_addr_del(&dev->uc, addr, dev->addr_len, | 3869 | err = __hw_addr_del(&dev->uc, addr, dev->addr_len, |
| 3869 | NETDEV_HW_ADDR_T_UNICAST); | 3870 | NETDEV_HW_ADDR_T_UNICAST); |
| 3870 | if (!err) | 3871 | if (!err) |
| 3871 | __dev_set_rx_mode(dev); | 3872 | __dev_set_rx_mode(dev); |
| 3873 | netif_addr_unlock_bh(dev); | ||
| 3872 | return err; | 3874 | return err; |
| 3873 | } | 3875 | } |
| 3874 | EXPORT_SYMBOL(dev_unicast_delete); | 3876 | EXPORT_SYMBOL(dev_unicast_delete); |
| @@ -3889,10 +3891,12 @@ int dev_unicast_add(struct net_device *dev, void *addr) | |||
| 3889 | 3891 | ||
| 3890 | ASSERT_RTNL(); | 3892 | ASSERT_RTNL(); |
| 3891 | 3893 | ||
| 3894 | netif_addr_lock_bh(dev); | ||
| 3892 | err = __hw_addr_add(&dev->uc, addr, dev->addr_len, | 3895 | err = __hw_addr_add(&dev->uc, addr, dev->addr_len, |
| 3893 | NETDEV_HW_ADDR_T_UNICAST); | 3896 | NETDEV_HW_ADDR_T_UNICAST); |
| 3894 | if (!err) | 3897 | if (!err) |
| 3895 | __dev_set_rx_mode(dev); | 3898 | __dev_set_rx_mode(dev); |
| 3899 | netif_addr_unlock_bh(dev); | ||
| 3896 | return err; | 3900 | return err; |
| 3897 | } | 3901 | } |
| 3898 | EXPORT_SYMBOL(dev_unicast_add); | 3902 | EXPORT_SYMBOL(dev_unicast_add); |
| @@ -3949,7 +3953,8 @@ void __dev_addr_unsync(struct dev_addr_list **to, int *to_count, | |||
| 3949 | * @from: source device | 3953 | * @from: source device |
| 3950 | * | 3954 | * |
| 3951 | * Add newly added addresses to the destination device and release | 3955 | * Add newly added addresses to the destination device and release |
| 3952 | * addresses that have no users left. | 3956 | * addresses that have no users left. The source device must be |
| 3957 | * locked by netif_tx_lock_bh. | ||
| 3953 | * | 3958 | * |
| 3954 | * This function is intended to be called from the dev->set_rx_mode | 3959 | * This function is intended to be called from the dev->set_rx_mode |
| 3955 | * function of layered software devices. | 3960 | * function of layered software devices. |
| @@ -3958,14 +3963,14 @@ int dev_unicast_sync(struct net_device *to, struct net_device *from) | |||
| 3958 | { | 3963 | { |
| 3959 | int err = 0; | 3964 | int err = 0; |
| 3960 | 3965 | ||
| 3961 | ASSERT_RTNL(); | ||
| 3962 | |||
| 3963 | if (to->addr_len != from->addr_len) | 3966 | if (to->addr_len != from->addr_len) |
| 3964 | return -EINVAL; | 3967 | return -EINVAL; |
| 3965 | 3968 | ||
| 3969 | netif_addr_lock_bh(to); | ||
| 3966 | err = __hw_addr_sync(&to->uc, &from->uc, to->addr_len); | 3970 | err = __hw_addr_sync(&to->uc, &from->uc, to->addr_len); |
| 3967 | if (!err) | 3971 | if (!err) |
| 3968 | __dev_set_rx_mode(to); | 3972 | __dev_set_rx_mode(to); |
| 3973 | netif_addr_unlock_bh(to); | ||
| 3969 | return err; | 3974 | return err; |
| 3970 | } | 3975 | } |
| 3971 | EXPORT_SYMBOL(dev_unicast_sync); | 3976 | EXPORT_SYMBOL(dev_unicast_sync); |
| @@ -3981,27 +3986,27 @@ EXPORT_SYMBOL(dev_unicast_sync); | |||
| 3981 | */ | 3986 | */ |
| 3982 | void dev_unicast_unsync(struct net_device *to, struct net_device *from) | 3987 | void dev_unicast_unsync(struct net_device *to, struct net_device *from) |
| 3983 | { | 3988 | { |
| 3984 | ASSERT_RTNL(); | ||
| 3985 | |||
| 3986 | if (to->addr_len != from->addr_len) | 3989 | if (to->addr_len != from->addr_len) |
| 3987 | return; | 3990 | return; |
| 3988 | 3991 | ||
| 3992 | netif_addr_lock_bh(from); | ||
| 3993 | netif_addr_lock(to); | ||
| 3989 | __hw_addr_unsync(&to->uc, &from->uc, to->addr_len); | 3994 | __hw_addr_unsync(&to->uc, &from->uc, to->addr_len); |
| 3990 | __dev_set_rx_mode(to); | 3995 | __dev_set_rx_mode(to); |
| 3996 | netif_addr_unlock(to); | ||
| 3997 | netif_addr_unlock_bh(from); | ||
| 3991 | } | 3998 | } |
| 3992 | EXPORT_SYMBOL(dev_unicast_unsync); | 3999 | EXPORT_SYMBOL(dev_unicast_unsync); |
| 3993 | 4000 | ||
| 3994 | static void dev_unicast_flush(struct net_device *dev) | 4001 | static void dev_unicast_flush(struct net_device *dev) |
| 3995 | { | 4002 | { |
| 3996 | /* rtnl_mutex must be held here */ | 4003 | netif_addr_lock_bh(dev); |
| 3997 | |||
| 3998 | __hw_addr_flush(&dev->uc); | 4004 | __hw_addr_flush(&dev->uc); |
| 4005 | netif_addr_unlock_bh(dev); | ||
| 3999 | } | 4006 | } |
| 4000 | 4007 | ||
| 4001 | static void dev_unicast_init(struct net_device *dev) | 4008 | static void dev_unicast_init(struct net_device *dev) |
| 4002 | { | 4009 | { |
| 4003 | /* rtnl_mutex must be held here */ | ||
| 4004 | |||
| 4005 | __hw_addr_init(&dev->uc); | 4010 | __hw_addr_init(&dev->uc); |
| 4006 | } | 4011 | } |
| 4007 | 4012 | ||
diff --git a/net/core/gen_estimator.c b/net/core/gen_estimator.c index 78e5bfc454ae..493775f4f2f1 100644 --- a/net/core/gen_estimator.c +++ b/net/core/gen_estimator.c | |||
| @@ -81,7 +81,7 @@ | |||
| 81 | struct gen_estimator | 81 | struct gen_estimator |
| 82 | { | 82 | { |
| 83 | struct list_head list; | 83 | struct list_head list; |
| 84 | struct gnet_stats_basic *bstats; | 84 | struct gnet_stats_basic_packed *bstats; |
| 85 | struct gnet_stats_rate_est *rate_est; | 85 | struct gnet_stats_rate_est *rate_est; |
| 86 | spinlock_t *stats_lock; | 86 | spinlock_t *stats_lock; |
| 87 | int ewma_log; | 87 | int ewma_log; |
| @@ -165,7 +165,7 @@ static void gen_add_node(struct gen_estimator *est) | |||
| 165 | } | 165 | } |
| 166 | 166 | ||
| 167 | static | 167 | static |
| 168 | struct gen_estimator *gen_find_node(const struct gnet_stats_basic *bstats, | 168 | struct gen_estimator *gen_find_node(const struct gnet_stats_basic_packed *bstats, |
| 169 | const struct gnet_stats_rate_est *rate_est) | 169 | const struct gnet_stats_rate_est *rate_est) |
| 170 | { | 170 | { |
| 171 | struct rb_node *p = est_root.rb_node; | 171 | struct rb_node *p = est_root.rb_node; |
| @@ -202,7 +202,7 @@ struct gen_estimator *gen_find_node(const struct gnet_stats_basic *bstats, | |||
| 202 | * | 202 | * |
| 203 | * NOTE: Called under rtnl_mutex | 203 | * NOTE: Called under rtnl_mutex |
| 204 | */ | 204 | */ |
| 205 | int gen_new_estimator(struct gnet_stats_basic *bstats, | 205 | int gen_new_estimator(struct gnet_stats_basic_packed *bstats, |
| 206 | struct gnet_stats_rate_est *rate_est, | 206 | struct gnet_stats_rate_est *rate_est, |
| 207 | spinlock_t *stats_lock, | 207 | spinlock_t *stats_lock, |
| 208 | struct nlattr *opt) | 208 | struct nlattr *opt) |
| @@ -262,7 +262,7 @@ static void __gen_kill_estimator(struct rcu_head *head) | |||
| 262 | * | 262 | * |
| 263 | * NOTE: Called under rtnl_mutex | 263 | * NOTE: Called under rtnl_mutex |
| 264 | */ | 264 | */ |
| 265 | void gen_kill_estimator(struct gnet_stats_basic *bstats, | 265 | void gen_kill_estimator(struct gnet_stats_basic_packed *bstats, |
| 266 | struct gnet_stats_rate_est *rate_est) | 266 | struct gnet_stats_rate_est *rate_est) |
| 267 | { | 267 | { |
| 268 | struct gen_estimator *e; | 268 | struct gen_estimator *e; |
| @@ -292,7 +292,7 @@ EXPORT_SYMBOL(gen_kill_estimator); | |||
| 292 | * | 292 | * |
| 293 | * Returns 0 on success or a negative error code. | 293 | * Returns 0 on success or a negative error code. |
| 294 | */ | 294 | */ |
| 295 | int gen_replace_estimator(struct gnet_stats_basic *bstats, | 295 | int gen_replace_estimator(struct gnet_stats_basic_packed *bstats, |
| 296 | struct gnet_stats_rate_est *rate_est, | 296 | struct gnet_stats_rate_est *rate_est, |
| 297 | spinlock_t *stats_lock, struct nlattr *opt) | 297 | spinlock_t *stats_lock, struct nlattr *opt) |
| 298 | { | 298 | { |
| @@ -308,7 +308,7 @@ EXPORT_SYMBOL(gen_replace_estimator); | |||
| 308 | * | 308 | * |
| 309 | * Returns true if estimator is active, and false if not. | 309 | * Returns true if estimator is active, and false if not. |
| 310 | */ | 310 | */ |
| 311 | bool gen_estimator_active(const struct gnet_stats_basic *bstats, | 311 | bool gen_estimator_active(const struct gnet_stats_basic_packed *bstats, |
| 312 | const struct gnet_stats_rate_est *rate_est) | 312 | const struct gnet_stats_rate_est *rate_est) |
| 313 | { | 313 | { |
| 314 | ASSERT_RTNL(); | 314 | ASSERT_RTNL(); |
diff --git a/net/core/gen_stats.c b/net/core/gen_stats.c index c3d0ffeac243..8569310268ab 100644 --- a/net/core/gen_stats.c +++ b/net/core/gen_stats.c | |||
| @@ -106,16 +106,21 @@ gnet_stats_start_copy(struct sk_buff *skb, int type, spinlock_t *lock, | |||
| 106 | * if the room in the socket buffer was not sufficient. | 106 | * if the room in the socket buffer was not sufficient. |
| 107 | */ | 107 | */ |
| 108 | int | 108 | int |
| 109 | gnet_stats_copy_basic(struct gnet_dump *d, struct gnet_stats_basic *b) | 109 | gnet_stats_copy_basic(struct gnet_dump *d, struct gnet_stats_basic_packed *b) |
| 110 | { | 110 | { |
| 111 | if (d->compat_tc_stats) { | 111 | if (d->compat_tc_stats) { |
| 112 | d->tc_stats.bytes = b->bytes; | 112 | d->tc_stats.bytes = b->bytes; |
| 113 | d->tc_stats.packets = b->packets; | 113 | d->tc_stats.packets = b->packets; |
| 114 | } | 114 | } |
| 115 | 115 | ||
| 116 | if (d->tail) | 116 | if (d->tail) { |
| 117 | return gnet_stats_copy(d, TCA_STATS_BASIC, b, sizeof(*b)); | 117 | struct gnet_stats_basic sb; |
| 118 | 118 | ||
| 119 | memset(&sb, 0, sizeof(sb)); | ||
| 120 | sb.bytes = b->bytes; | ||
| 121 | sb.packets = b->packets; | ||
| 122 | return gnet_stats_copy(d, TCA_STATS_BASIC, &sb, sizeof(sb)); | ||
| 123 | } | ||
| 119 | return 0; | 124 | return 0; |
| 120 | } | 125 | } |
| 121 | 126 | ||
diff --git a/net/core/net_namespace.c b/net/core/net_namespace.c index b7292a2719dc..197283072cc8 100644 --- a/net/core/net_namespace.c +++ b/net/core/net_namespace.c | |||
| @@ -488,7 +488,7 @@ int net_assign_generic(struct net *net, int id, void *data) | |||
| 488 | */ | 488 | */ |
| 489 | 489 | ||
| 490 | ng->len = id; | 490 | ng->len = id; |
| 491 | memcpy(&ng->ptr, &old_ng->ptr, old_ng->len); | 491 | memcpy(&ng->ptr, &old_ng->ptr, old_ng->len * sizeof(void*)); |
| 492 | 492 | ||
| 493 | rcu_assign_pointer(net->gen, ng); | 493 | rcu_assign_pointer(net->gen, ng); |
| 494 | call_rcu(&old_ng->rcu, net_generic_release); | 494 | call_rcu(&old_ng->rcu, net_generic_release); |
diff --git a/net/core/netpoll.c b/net/core/netpoll.c index df30feb2fc72..1b76eb11deb4 100644 --- a/net/core/netpoll.c +++ b/net/core/netpoll.c | |||
| @@ -319,6 +319,11 @@ static void netpoll_send_skb(struct netpoll *np, struct sk_buff *skb) | |||
| 319 | 319 | ||
| 320 | udelay(USEC_PER_POLL); | 320 | udelay(USEC_PER_POLL); |
| 321 | } | 321 | } |
| 322 | |||
| 323 | WARN_ONCE(!irqs_disabled(), | ||
| 324 | "netpoll_send_skb(): %s enabled interrupts in poll (%pF)\n", | ||
| 325 | dev->name, ops->ndo_start_xmit); | ||
| 326 | |||
| 322 | local_irq_restore(flags); | 327 | local_irq_restore(flags); |
| 323 | } | 328 | } |
| 324 | 329 | ||
diff --git a/net/core/sock.c b/net/core/sock.c index ba5d2116aea1..bbb25be7ddfe 100644 --- a/net/core/sock.c +++ b/net/core/sock.c | |||
| @@ -631,7 +631,7 @@ set_rcvbuf: | |||
| 631 | 631 | ||
| 632 | case SO_TIMESTAMPING: | 632 | case SO_TIMESTAMPING: |
| 633 | if (val & ~SOF_TIMESTAMPING_MASK) { | 633 | if (val & ~SOF_TIMESTAMPING_MASK) { |
| 634 | ret = EINVAL; | 634 | ret = -EINVAL; |
| 635 | break; | 635 | break; |
| 636 | } | 636 | } |
| 637 | sock_valbool_flag(sk, SOCK_TIMESTAMPING_TX_HARDWARE, | 637 | sock_valbool_flag(sk, SOCK_TIMESTAMPING_TX_HARDWARE, |
| @@ -919,13 +919,19 @@ static inline void sock_lock_init(struct sock *sk) | |||
| 919 | af_family_keys + sk->sk_family); | 919 | af_family_keys + sk->sk_family); |
| 920 | } | 920 | } |
| 921 | 921 | ||
| 922 | /* | ||
| 923 | * Copy all fields from osk to nsk but nsk->sk_refcnt must not change yet, | ||
| 924 | * even temporarly, because of RCU lookups. sk_node should also be left as is. | ||
| 925 | */ | ||
| 922 | static void sock_copy(struct sock *nsk, const struct sock *osk) | 926 | static void sock_copy(struct sock *nsk, const struct sock *osk) |
| 923 | { | 927 | { |
| 924 | #ifdef CONFIG_SECURITY_NETWORK | 928 | #ifdef CONFIG_SECURITY_NETWORK |
| 925 | void *sptr = nsk->sk_security; | 929 | void *sptr = nsk->sk_security; |
| 926 | #endif | 930 | #endif |
| 927 | 931 | BUILD_BUG_ON(offsetof(struct sock, sk_copy_start) != | |
| 928 | memcpy(nsk, osk, osk->sk_prot->obj_size); | 932 | sizeof(osk->sk_node) + sizeof(osk->sk_refcnt)); |
| 933 | memcpy(&nsk->sk_copy_start, &osk->sk_copy_start, | ||
| 934 | osk->sk_prot->obj_size - offsetof(struct sock, sk_copy_start)); | ||
| 929 | #ifdef CONFIG_SECURITY_NETWORK | 935 | #ifdef CONFIG_SECURITY_NETWORK |
| 930 | nsk->sk_security = sptr; | 936 | nsk->sk_security = sptr; |
| 931 | security_sk_clone(osk, nsk); | 937 | security_sk_clone(osk, nsk); |
| @@ -1140,6 +1146,11 @@ struct sock *sk_clone(const struct sock *sk, const gfp_t priority) | |||
| 1140 | 1146 | ||
| 1141 | newsk->sk_err = 0; | 1147 | newsk->sk_err = 0; |
| 1142 | newsk->sk_priority = 0; | 1148 | newsk->sk_priority = 0; |
| 1149 | /* | ||
| 1150 | * Before updating sk_refcnt, we must commit prior changes to memory | ||
| 1151 | * (Documentation/RCU/rculist_nulls.txt for details) | ||
| 1152 | */ | ||
| 1153 | smp_wmb(); | ||
| 1143 | atomic_set(&newsk->sk_refcnt, 2); | 1154 | atomic_set(&newsk->sk_refcnt, 2); |
| 1144 | 1155 | ||
| 1145 | /* | 1156 | /* |
| @@ -1855,6 +1866,11 @@ void sock_init_data(struct socket *sock, struct sock *sk) | |||
| 1855 | 1866 | ||
| 1856 | sk->sk_stamp = ktime_set(-1L, 0); | 1867 | sk->sk_stamp = ktime_set(-1L, 0); |
| 1857 | 1868 | ||
| 1869 | /* | ||
| 1870 | * Before updating sk_refcnt, we must commit prior changes to memory | ||
| 1871 | * (Documentation/RCU/rculist_nulls.txt for details) | ||
| 1872 | */ | ||
| 1873 | smp_wmb(); | ||
| 1858 | atomic_set(&sk->sk_refcnt, 1); | 1874 | atomic_set(&sk->sk_refcnt, 1); |
| 1859 | atomic_set(&sk->sk_wmem_alloc, 1); | 1875 | atomic_set(&sk->sk_wmem_alloc, 1); |
| 1860 | atomic_set(&sk->sk_drops, 0); | 1876 | atomic_set(&sk->sk_drops, 0); |
diff --git a/net/dccp/proto.c b/net/dccp/proto.c index 94ca8eaace7d..1bca9205104e 100644 --- a/net/dccp/proto.c +++ b/net/dccp/proto.c | |||
| @@ -1066,7 +1066,7 @@ static int __init dccp_init(void) | |||
| 1066 | (dccp_hashinfo.ehash_size - 1)) | 1066 | (dccp_hashinfo.ehash_size - 1)) |
| 1067 | dccp_hashinfo.ehash_size--; | 1067 | dccp_hashinfo.ehash_size--; |
| 1068 | dccp_hashinfo.ehash = (struct inet_ehash_bucket *) | 1068 | dccp_hashinfo.ehash = (struct inet_ehash_bucket *) |
| 1069 | __get_free_pages(GFP_ATOMIC, ehash_order); | 1069 | __get_free_pages(GFP_ATOMIC|__GFP_NOWARN, ehash_order); |
| 1070 | } while (!dccp_hashinfo.ehash && --ehash_order > 0); | 1070 | } while (!dccp_hashinfo.ehash && --ehash_order > 0); |
| 1071 | 1071 | ||
| 1072 | if (!dccp_hashinfo.ehash) { | 1072 | if (!dccp_hashinfo.ehash) { |
| @@ -1091,7 +1091,7 @@ static int __init dccp_init(void) | |||
| 1091 | bhash_order > 0) | 1091 | bhash_order > 0) |
| 1092 | continue; | 1092 | continue; |
| 1093 | dccp_hashinfo.bhash = (struct inet_bind_hashbucket *) | 1093 | dccp_hashinfo.bhash = (struct inet_bind_hashbucket *) |
| 1094 | __get_free_pages(GFP_ATOMIC, bhash_order); | 1094 | __get_free_pages(GFP_ATOMIC|__GFP_NOWARN, bhash_order); |
| 1095 | } while (!dccp_hashinfo.bhash && --bhash_order >= 0); | 1095 | } while (!dccp_hashinfo.bhash && --bhash_order >= 0); |
| 1096 | 1096 | ||
| 1097 | if (!dccp_hashinfo.bhash) { | 1097 | if (!dccp_hashinfo.bhash) { |
| @@ -1159,6 +1159,7 @@ static void __exit dccp_fini(void) | |||
| 1159 | kmem_cache_destroy(dccp_hashinfo.bind_bucket_cachep); | 1159 | kmem_cache_destroy(dccp_hashinfo.bind_bucket_cachep); |
| 1160 | dccp_ackvec_exit(); | 1160 | dccp_ackvec_exit(); |
| 1161 | dccp_sysctl_exit(); | 1161 | dccp_sysctl_exit(); |
| 1162 | percpu_counter_destroy(&dccp_orphan_count); | ||
| 1162 | } | 1163 | } |
| 1163 | 1164 | ||
| 1164 | module_init(dccp_init); | 1165 | module_init(dccp_init); |
diff --git a/net/econet/af_econet.c b/net/econet/af_econet.c index 2e1f836d4240..f0bbc57926cd 100644 --- a/net/econet/af_econet.c +++ b/net/econet/af_econet.c | |||
| @@ -520,6 +520,7 @@ static int econet_getname(struct socket *sock, struct sockaddr *uaddr, | |||
| 520 | if (peer) | 520 | if (peer) |
| 521 | return -EOPNOTSUPP; | 521 | return -EOPNOTSUPP; |
| 522 | 522 | ||
| 523 | memset(sec, 0, sizeof(*sec)); | ||
| 523 | mutex_lock(&econet_mutex); | 524 | mutex_lock(&econet_mutex); |
| 524 | 525 | ||
| 525 | sk = sock->sk; | 526 | sk = sock->sk; |
diff --git a/net/ieee802154/af_ieee802154.c b/net/ieee802154/af_ieee802154.c index 3bb6bdb1dac1..af661805b9fa 100644 --- a/net/ieee802154/af_ieee802154.c +++ b/net/ieee802154/af_ieee802154.c | |||
| @@ -136,7 +136,7 @@ static int ieee802154_dev_ioctl(struct sock *sk, struct ifreq __user *arg, | |||
| 136 | unsigned int cmd) | 136 | unsigned int cmd) |
| 137 | { | 137 | { |
| 138 | struct ifreq ifr; | 138 | struct ifreq ifr; |
| 139 | int ret = -EINVAL; | 139 | int ret = -ENOIOCTLCMD; |
| 140 | struct net_device *dev; | 140 | struct net_device *dev; |
| 141 | 141 | ||
| 142 | if (copy_from_user(&ifr, arg, sizeof(struct ifreq))) | 142 | if (copy_from_user(&ifr, arg, sizeof(struct ifreq))) |
| @@ -146,8 +146,10 @@ static int ieee802154_dev_ioctl(struct sock *sk, struct ifreq __user *arg, | |||
| 146 | 146 | ||
| 147 | dev_load(sock_net(sk), ifr.ifr_name); | 147 | dev_load(sock_net(sk), ifr.ifr_name); |
| 148 | dev = dev_get_by_name(sock_net(sk), ifr.ifr_name); | 148 | dev = dev_get_by_name(sock_net(sk), ifr.ifr_name); |
| 149 | if (dev->type == ARPHRD_IEEE802154 || | 149 | |
| 150 | dev->type == ARPHRD_IEEE802154_PHY) | 150 | if ((dev->type == ARPHRD_IEEE802154 || |
| 151 | dev->type == ARPHRD_IEEE802154_PHY) && | ||
| 152 | dev->netdev_ops->ndo_do_ioctl) | ||
| 151 | ret = dev->netdev_ops->ndo_do_ioctl(dev, &ifr, cmd); | 153 | ret = dev->netdev_ops->ndo_do_ioctl(dev, &ifr, cmd); |
| 152 | 154 | ||
| 153 | if (!ret && copy_to_user(arg, &ifr, sizeof(struct ifreq))) | 155 | if (!ret && copy_to_user(arg, &ifr, sizeof(struct ifreq))) |
diff --git a/net/ieee802154/dgram.c b/net/ieee802154/dgram.c index 14d39840dd62..ba8b214dda8f 100644 --- a/net/ieee802154/dgram.c +++ b/net/ieee802154/dgram.c | |||
| @@ -377,6 +377,18 @@ int ieee802154_dgram_deliver(struct net_device *dev, struct sk_buff *skb) | |||
| 377 | return ret; | 377 | return ret; |
| 378 | } | 378 | } |
| 379 | 379 | ||
| 380 | static int dgram_getsockopt(struct sock *sk, int level, int optname, | ||
| 381 | char __user *optval, int __user *optlen) | ||
| 382 | { | ||
| 383 | return -EOPNOTSUPP; | ||
| 384 | } | ||
| 385 | |||
| 386 | static int dgram_setsockopt(struct sock *sk, int level, int optname, | ||
| 387 | char __user *optval, int __user optlen) | ||
| 388 | { | ||
| 389 | return -EOPNOTSUPP; | ||
| 390 | } | ||
| 391 | |||
| 380 | struct proto ieee802154_dgram_prot = { | 392 | struct proto ieee802154_dgram_prot = { |
| 381 | .name = "IEEE-802.15.4-MAC", | 393 | .name = "IEEE-802.15.4-MAC", |
| 382 | .owner = THIS_MODULE, | 394 | .owner = THIS_MODULE, |
| @@ -391,5 +403,7 @@ struct proto ieee802154_dgram_prot = { | |||
| 391 | .connect = dgram_connect, | 403 | .connect = dgram_connect, |
| 392 | .disconnect = dgram_disconnect, | 404 | .disconnect = dgram_disconnect, |
| 393 | .ioctl = dgram_ioctl, | 405 | .ioctl = dgram_ioctl, |
| 406 | .getsockopt = dgram_getsockopt, | ||
| 407 | .setsockopt = dgram_setsockopt, | ||
| 394 | }; | 408 | }; |
| 395 | 409 | ||
diff --git a/net/ieee802154/raw.c b/net/ieee802154/raw.c index fca44d59f97e..9315977c4c61 100644 --- a/net/ieee802154/raw.c +++ b/net/ieee802154/raw.c | |||
| @@ -238,6 +238,18 @@ void ieee802154_raw_deliver(struct net_device *dev, struct sk_buff *skb) | |||
| 238 | read_unlock(&raw_lock); | 238 | read_unlock(&raw_lock); |
| 239 | } | 239 | } |
| 240 | 240 | ||
| 241 | static int raw_getsockopt(struct sock *sk, int level, int optname, | ||
| 242 | char __user *optval, int __user *optlen) | ||
| 243 | { | ||
| 244 | return -EOPNOTSUPP; | ||
| 245 | } | ||
| 246 | |||
| 247 | static int raw_setsockopt(struct sock *sk, int level, int optname, | ||
| 248 | char __user *optval, int __user optlen) | ||
| 249 | { | ||
| 250 | return -EOPNOTSUPP; | ||
| 251 | } | ||
| 252 | |||
| 241 | struct proto ieee802154_raw_prot = { | 253 | struct proto ieee802154_raw_prot = { |
| 242 | .name = "IEEE-802.15.4-RAW", | 254 | .name = "IEEE-802.15.4-RAW", |
| 243 | .owner = THIS_MODULE, | 255 | .owner = THIS_MODULE, |
| @@ -250,5 +262,7 @@ struct proto ieee802154_raw_prot = { | |||
| 250 | .unhash = raw_unhash, | 262 | .unhash = raw_unhash, |
| 251 | .connect = raw_connect, | 263 | .connect = raw_connect, |
| 252 | .disconnect = raw_disconnect, | 264 | .disconnect = raw_disconnect, |
| 265 | .getsockopt = raw_getsockopt, | ||
| 266 | .setsockopt = raw_setsockopt, | ||
| 253 | }; | 267 | }; |
| 254 | 268 | ||
diff --git a/net/ipv4/arp.c b/net/ipv4/arp.c index c29d75d8f1b1..090e9991ac2a 100644 --- a/net/ipv4/arp.c +++ b/net/ipv4/arp.c | |||
| @@ -1304,7 +1304,9 @@ static void arp_format_neigh_entry(struct seq_file *seq, | |||
| 1304 | hbuffer[k++] = hex_asc_lo(n->ha[j]); | 1304 | hbuffer[k++] = hex_asc_lo(n->ha[j]); |
| 1305 | hbuffer[k++] = ':'; | 1305 | hbuffer[k++] = ':'; |
| 1306 | } | 1306 | } |
| 1307 | hbuffer[--k] = 0; | 1307 | if (k != 0) |
| 1308 | --k; | ||
| 1309 | hbuffer[k] = 0; | ||
| 1308 | #if defined(CONFIG_AX25) || defined(CONFIG_AX25_MODULE) | 1310 | #if defined(CONFIG_AX25) || defined(CONFIG_AX25_MODULE) |
| 1309 | } | 1311 | } |
| 1310 | #endif | 1312 | #endif |
diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c index cb4a0f4bd5e5..82c11dd10a62 100644 --- a/net/ipv4/ip_gre.c +++ b/net/ipv4/ip_gre.c | |||
| @@ -951,7 +951,7 @@ static int ipgre_tunnel_bind_dev(struct net_device *dev) | |||
| 951 | addend += 4; | 951 | addend += 4; |
| 952 | } | 952 | } |
| 953 | dev->needed_headroom = addend + hlen; | 953 | dev->needed_headroom = addend + hlen; |
| 954 | mtu -= dev->hard_header_len - addend; | 954 | mtu -= dev->hard_header_len + addend; |
| 955 | 955 | ||
| 956 | if (mtu < 68) | 956 | if (mtu < 68) |
| 957 | mtu = 68; | 957 | mtu = 68; |
diff --git a/net/ipv4/ip_output.c b/net/ipv4/ip_output.c index 7d0821054729..7ffcd96fe591 100644 --- a/net/ipv4/ip_output.c +++ b/net/ipv4/ip_output.c | |||
| @@ -813,6 +813,8 @@ int ip_append_data(struct sock *sk, | |||
| 813 | inet->cork.addr = ipc->addr; | 813 | inet->cork.addr = ipc->addr; |
| 814 | } | 814 | } |
| 815 | rt = *rtp; | 815 | rt = *rtp; |
| 816 | if (unlikely(!rt)) | ||
| 817 | return -EFAULT; | ||
| 816 | /* | 818 | /* |
| 817 | * We steal reference to this route, caller should not release it | 819 | * We steal reference to this route, caller should not release it |
| 818 | */ | 820 | */ |
diff --git a/net/ipv4/tcp_ipv4.c b/net/ipv4/tcp_ipv4.c index 5a1ca2698c88..6d88219c5e22 100644 --- a/net/ipv4/tcp_ipv4.c +++ b/net/ipv4/tcp_ipv4.c | |||
| @@ -1160,6 +1160,7 @@ struct request_sock_ops tcp_request_sock_ops __read_mostly = { | |||
| 1160 | #ifdef CONFIG_TCP_MD5SIG | 1160 | #ifdef CONFIG_TCP_MD5SIG |
| 1161 | static struct tcp_request_sock_ops tcp_request_sock_ipv4_ops = { | 1161 | static struct tcp_request_sock_ops tcp_request_sock_ipv4_ops = { |
| 1162 | .md5_lookup = tcp_v4_reqsk_md5_lookup, | 1162 | .md5_lookup = tcp_v4_reqsk_md5_lookup, |
| 1163 | .calc_md5_hash = tcp_v4_md5_hash_skb, | ||
| 1163 | }; | 1164 | }; |
| 1164 | #endif | 1165 | #endif |
| 1165 | 1166 | ||
| @@ -1373,7 +1374,7 @@ struct sock *tcp_v4_syn_recv_sock(struct sock *sk, struct sk_buff *skb, | |||
| 1373 | */ | 1374 | */ |
| 1374 | char *newkey = kmemdup(key->key, key->keylen, GFP_ATOMIC); | 1375 | char *newkey = kmemdup(key->key, key->keylen, GFP_ATOMIC); |
| 1375 | if (newkey != NULL) | 1376 | if (newkey != NULL) |
| 1376 | tcp_v4_md5_do_add(newsk, inet_sk(sk)->daddr, | 1377 | tcp_v4_md5_do_add(newsk, newinet->daddr, |
| 1377 | newkey, key->keylen); | 1378 | newkey, key->keylen); |
| 1378 | newsk->sk_route_caps &= ~NETIF_F_GSO_MASK; | 1379 | newsk->sk_route_caps &= ~NETIF_F_GSO_MASK; |
| 1379 | } | 1380 | } |
diff --git a/net/ipv4/tcp_output.c b/net/ipv4/tcp_output.c index 5bdf08d312d9..bd62712848fa 100644 --- a/net/ipv4/tcp_output.c +++ b/net/ipv4/tcp_output.c | |||
| @@ -2261,7 +2261,7 @@ struct sk_buff *tcp_make_synack(struct sock *sk, struct dst_entry *dst, | |||
| 2261 | #ifdef CONFIG_TCP_MD5SIG | 2261 | #ifdef CONFIG_TCP_MD5SIG |
| 2262 | /* Okay, we have all we need - do the md5 hash if needed */ | 2262 | /* Okay, we have all we need - do the md5 hash if needed */ |
| 2263 | if (md5) { | 2263 | if (md5) { |
| 2264 | tp->af_specific->calc_md5_hash(md5_hash_location, | 2264 | tcp_rsk(req)->af_specific->calc_md5_hash(md5_hash_location, |
| 2265 | md5, NULL, req, skb); | 2265 | md5, NULL, req, skb); |
| 2266 | } | 2266 | } |
| 2267 | #endif | 2267 | #endif |
diff --git a/net/ipv6/af_inet6.c b/net/ipv6/af_inet6.c index caa0278d30a9..45f9a2a42d56 100644 --- a/net/ipv6/af_inet6.c +++ b/net/ipv6/af_inet6.c | |||
| @@ -306,8 +306,10 @@ int inet6_bind(struct socket *sock, struct sockaddr *uaddr, int addr_len) | |||
| 306 | v4addr != htonl(INADDR_ANY) && | 306 | v4addr != htonl(INADDR_ANY) && |
| 307 | chk_addr_ret != RTN_LOCAL && | 307 | chk_addr_ret != RTN_LOCAL && |
| 308 | chk_addr_ret != RTN_MULTICAST && | 308 | chk_addr_ret != RTN_MULTICAST && |
| 309 | chk_addr_ret != RTN_BROADCAST) | 309 | chk_addr_ret != RTN_BROADCAST) { |
| 310 | err = -EADDRNOTAVAIL; | ||
| 310 | goto out; | 311 | goto out; |
| 312 | } | ||
| 311 | } else { | 313 | } else { |
| 312 | if (addr_type != IPV6_ADDR_ANY) { | 314 | if (addr_type != IPV6_ADDR_ANY) { |
| 313 | struct net_device *dev = NULL; | 315 | struct net_device *dev = NULL; |
diff --git a/net/ipv6/tcp_ipv6.c b/net/ipv6/tcp_ipv6.c index 58810c65b635..d849dd53b788 100644 --- a/net/ipv6/tcp_ipv6.c +++ b/net/ipv6/tcp_ipv6.c | |||
| @@ -896,6 +896,7 @@ struct request_sock_ops tcp6_request_sock_ops __read_mostly = { | |||
| 896 | #ifdef CONFIG_TCP_MD5SIG | 896 | #ifdef CONFIG_TCP_MD5SIG |
| 897 | static struct tcp_request_sock_ops tcp_request_sock_ipv6_ops = { | 897 | static struct tcp_request_sock_ops tcp_request_sock_ipv6_ops = { |
| 898 | .md5_lookup = tcp_v6_reqsk_md5_lookup, | 898 | .md5_lookup = tcp_v6_reqsk_md5_lookup, |
| 899 | .calc_md5_hash = tcp_v6_md5_hash_skb, | ||
| 899 | }; | 900 | }; |
| 900 | #endif | 901 | #endif |
| 901 | 902 | ||
| @@ -1441,7 +1442,7 @@ static struct sock * tcp_v6_syn_recv_sock(struct sock *sk, struct sk_buff *skb, | |||
| 1441 | */ | 1442 | */ |
| 1442 | char *newkey = kmemdup(key->key, key->keylen, GFP_ATOMIC); | 1443 | char *newkey = kmemdup(key->key, key->keylen, GFP_ATOMIC); |
| 1443 | if (newkey != NULL) | 1444 | if (newkey != NULL) |
| 1444 | tcp_v6_md5_do_add(newsk, &inet6_sk(sk)->daddr, | 1445 | tcp_v6_md5_do_add(newsk, &newnp->daddr, |
| 1445 | newkey, key->keylen); | 1446 | newkey, key->keylen); |
| 1446 | } | 1447 | } |
| 1447 | #endif | 1448 | #endif |
diff --git a/net/irda/af_irda.c b/net/irda/af_irda.c index 80cf29aae096..50b43c57d5d8 100644 --- a/net/irda/af_irda.c +++ b/net/irda/af_irda.c | |||
| @@ -715,6 +715,7 @@ static int irda_getname(struct socket *sock, struct sockaddr *uaddr, | |||
| 715 | struct sock *sk = sock->sk; | 715 | struct sock *sk = sock->sk; |
| 716 | struct irda_sock *self = irda_sk(sk); | 716 | struct irda_sock *self = irda_sk(sk); |
| 717 | 717 | ||
| 718 | memset(&saddr, 0, sizeof(saddr)); | ||
| 718 | if (peer) { | 719 | if (peer) { |
| 719 | if (sk->sk_state != TCP_ESTABLISHED) | 720 | if (sk->sk_state != TCP_ESTABLISHED) |
| 720 | return -ENOTCONN; | 721 | return -ENOTCONN; |
diff --git a/net/irda/irttp.c b/net/irda/irttp.c index ecf4eb2717cb..9cb79f95bf63 100644 --- a/net/irda/irttp.c +++ b/net/irda/irttp.c | |||
| @@ -1453,6 +1453,7 @@ struct tsap_cb *irttp_dup(struct tsap_cb *orig, void *instance) | |||
| 1453 | } | 1453 | } |
| 1454 | /* Dup */ | 1454 | /* Dup */ |
| 1455 | memcpy(new, orig, sizeof(struct tsap_cb)); | 1455 | memcpy(new, orig, sizeof(struct tsap_cb)); |
| 1456 | spin_lock_init(&new->lock); | ||
| 1456 | 1457 | ||
| 1457 | /* We don't need the old instance any more */ | 1458 | /* We don't need the old instance any more */ |
| 1458 | spin_unlock_irqrestore(&irttp->tsaps->hb_spinlock, flags); | 1459 | spin_unlock_irqrestore(&irttp->tsaps->hb_spinlock, flags); |
diff --git a/net/llc/af_llc.c b/net/llc/af_llc.c index 9208cf5f2bd5..c45eee1c0e8d 100644 --- a/net/llc/af_llc.c +++ b/net/llc/af_llc.c | |||
| @@ -914,6 +914,7 @@ static int llc_ui_getname(struct socket *sock, struct sockaddr *uaddr, | |||
| 914 | struct llc_sock *llc = llc_sk(sk); | 914 | struct llc_sock *llc = llc_sk(sk); |
| 915 | int rc = 0; | 915 | int rc = 0; |
| 916 | 916 | ||
| 917 | memset(&sllc, 0, sizeof(sllc)); | ||
| 917 | lock_sock(sk); | 918 | lock_sock(sk); |
| 918 | if (sock_flag(sk, SOCK_ZAPPED)) | 919 | if (sock_flag(sk, SOCK_ZAPPED)) |
| 919 | goto out; | 920 | goto out; |
diff --git a/net/mac80211/Kconfig b/net/mac80211/Kconfig index ba2643a43c73..7836ee928983 100644 --- a/net/mac80211/Kconfig +++ b/net/mac80211/Kconfig | |||
| @@ -83,6 +83,7 @@ endmenu | |||
| 83 | config MAC80211_MESH | 83 | config MAC80211_MESH |
| 84 | bool "Enable mac80211 mesh networking (pre-802.11s) support" | 84 | bool "Enable mac80211 mesh networking (pre-802.11s) support" |
| 85 | depends on MAC80211 && EXPERIMENTAL | 85 | depends on MAC80211 && EXPERIMENTAL |
| 86 | depends on BROKEN | ||
| 86 | ---help--- | 87 | ---help--- |
| 87 | This options enables support of Draft 802.11s mesh networking. | 88 | This options enables support of Draft 802.11s mesh networking. |
| 88 | The implementation is based on Draft 1.08 of the Mesh Networking | 89 | The implementation is based on Draft 1.08 of the Mesh Networking |
diff --git a/net/mac80211/agg-tx.c b/net/mac80211/agg-tx.c index 9e5762ad307d..a24e59816b93 100644 --- a/net/mac80211/agg-tx.c +++ b/net/mac80211/agg-tx.c | |||
| @@ -381,6 +381,14 @@ static void ieee80211_agg_splice_packets(struct ieee80211_local *local, | |||
| 381 | &local->hw, queue, | 381 | &local->hw, queue, |
| 382 | IEEE80211_QUEUE_STOP_REASON_AGGREGATION); | 382 | IEEE80211_QUEUE_STOP_REASON_AGGREGATION); |
| 383 | 383 | ||
| 384 | if (!(sta->ampdu_mlme.tid_state_tx[tid] & HT_ADDBA_REQUESTED_MSK)) | ||
| 385 | return; | ||
| 386 | |||
| 387 | if (WARN(!sta->ampdu_mlme.tid_tx[tid], | ||
| 388 | "TID %d gone but expected when splicing aggregates from" | ||
| 389 | "the pending queue\n", tid)) | ||
| 390 | return; | ||
| 391 | |||
| 384 | if (!skb_queue_empty(&sta->ampdu_mlme.tid_tx[tid]->pending)) { | 392 | if (!skb_queue_empty(&sta->ampdu_mlme.tid_tx[tid]->pending)) { |
| 385 | spin_lock_irqsave(&local->queue_stop_reason_lock, flags); | 393 | spin_lock_irqsave(&local->queue_stop_reason_lock, flags); |
| 386 | /* mark queue as pending, it is stopped already */ | 394 | /* mark queue as pending, it is stopped already */ |
diff --git a/net/mac80211/key.c b/net/mac80211/key.c index ce267565e180..659a42d529e3 100644 --- a/net/mac80211/key.c +++ b/net/mac80211/key.c | |||
| @@ -67,6 +67,8 @@ static DECLARE_WORK(todo_work, key_todo); | |||
| 67 | * | 67 | * |
| 68 | * @key: key to add to do item for | 68 | * @key: key to add to do item for |
| 69 | * @flag: todo flag(s) | 69 | * @flag: todo flag(s) |
| 70 | * | ||
| 71 | * Must be called with IRQs or softirqs disabled. | ||
| 70 | */ | 72 | */ |
| 71 | static void add_todo(struct ieee80211_key *key, u32 flag) | 73 | static void add_todo(struct ieee80211_key *key, u32 flag) |
| 72 | { | 74 | { |
| @@ -140,9 +142,9 @@ static void ieee80211_key_enable_hw_accel(struct ieee80211_key *key) | |||
| 140 | ret = drv_set_key(key->local, SET_KEY, &sdata->vif, sta, &key->conf); | 142 | ret = drv_set_key(key->local, SET_KEY, &sdata->vif, sta, &key->conf); |
| 141 | 143 | ||
| 142 | if (!ret) { | 144 | if (!ret) { |
| 143 | spin_lock(&todo_lock); | 145 | spin_lock_bh(&todo_lock); |
| 144 | key->flags |= KEY_FLAG_UPLOADED_TO_HARDWARE; | 146 | key->flags |= KEY_FLAG_UPLOADED_TO_HARDWARE; |
| 145 | spin_unlock(&todo_lock); | 147 | spin_unlock_bh(&todo_lock); |
| 146 | } | 148 | } |
| 147 | 149 | ||
| 148 | if (ret && ret != -ENOSPC && ret != -EOPNOTSUPP) | 150 | if (ret && ret != -ENOSPC && ret != -EOPNOTSUPP) |
| @@ -164,12 +166,12 @@ static void ieee80211_key_disable_hw_accel(struct ieee80211_key *key) | |||
| 164 | if (!key || !key->local->ops->set_key) | 166 | if (!key || !key->local->ops->set_key) |
| 165 | return; | 167 | return; |
| 166 | 168 | ||
| 167 | spin_lock(&todo_lock); | 169 | spin_lock_bh(&todo_lock); |
| 168 | if (!(key->flags & KEY_FLAG_UPLOADED_TO_HARDWARE)) { | 170 | if (!(key->flags & KEY_FLAG_UPLOADED_TO_HARDWARE)) { |
| 169 | spin_unlock(&todo_lock); | 171 | spin_unlock_bh(&todo_lock); |
| 170 | return; | 172 | return; |
| 171 | } | 173 | } |
| 172 | spin_unlock(&todo_lock); | 174 | spin_unlock_bh(&todo_lock); |
| 173 | 175 | ||
| 174 | sta = get_sta_for_key(key); | 176 | sta = get_sta_for_key(key); |
| 175 | sdata = key->sdata; | 177 | sdata = key->sdata; |
| @@ -188,9 +190,9 @@ static void ieee80211_key_disable_hw_accel(struct ieee80211_key *key) | |||
| 188 | wiphy_name(key->local->hw.wiphy), | 190 | wiphy_name(key->local->hw.wiphy), |
| 189 | key->conf.keyidx, sta ? sta->addr : bcast_addr, ret); | 191 | key->conf.keyidx, sta ? sta->addr : bcast_addr, ret); |
| 190 | 192 | ||
| 191 | spin_lock(&todo_lock); | 193 | spin_lock_bh(&todo_lock); |
| 192 | key->flags &= ~KEY_FLAG_UPLOADED_TO_HARDWARE; | 194 | key->flags &= ~KEY_FLAG_UPLOADED_TO_HARDWARE; |
| 193 | spin_unlock(&todo_lock); | 195 | spin_unlock_bh(&todo_lock); |
| 194 | } | 196 | } |
| 195 | 197 | ||
| 196 | static void __ieee80211_set_default_key(struct ieee80211_sub_if_data *sdata, | 198 | static void __ieee80211_set_default_key(struct ieee80211_sub_if_data *sdata, |
| @@ -437,14 +439,14 @@ void ieee80211_key_link(struct ieee80211_key *key, | |||
| 437 | 439 | ||
| 438 | __ieee80211_key_replace(sdata, sta, old_key, key); | 440 | __ieee80211_key_replace(sdata, sta, old_key, key); |
| 439 | 441 | ||
| 440 | spin_unlock_irqrestore(&sdata->local->key_lock, flags); | ||
| 441 | |||
| 442 | /* free old key later */ | 442 | /* free old key later */ |
| 443 | add_todo(old_key, KEY_FLAG_TODO_DELETE); | 443 | add_todo(old_key, KEY_FLAG_TODO_DELETE); |
| 444 | 444 | ||
| 445 | add_todo(key, KEY_FLAG_TODO_ADD_DEBUGFS); | 445 | add_todo(key, KEY_FLAG_TODO_ADD_DEBUGFS); |
| 446 | if (netif_running(sdata->dev)) | 446 | if (netif_running(sdata->dev)) |
| 447 | add_todo(key, KEY_FLAG_TODO_HWACCEL_ADD); | 447 | add_todo(key, KEY_FLAG_TODO_HWACCEL_ADD); |
| 448 | |||
| 449 | spin_unlock_irqrestore(&sdata->local->key_lock, flags); | ||
| 448 | } | 450 | } |
| 449 | 451 | ||
| 450 | static void __ieee80211_key_free(struct ieee80211_key *key) | 452 | static void __ieee80211_key_free(struct ieee80211_key *key) |
| @@ -547,7 +549,7 @@ static void __ieee80211_key_todo(void) | |||
| 547 | */ | 549 | */ |
| 548 | synchronize_rcu(); | 550 | synchronize_rcu(); |
| 549 | 551 | ||
| 550 | spin_lock(&todo_lock); | 552 | spin_lock_bh(&todo_lock); |
| 551 | while (!list_empty(&todo_list)) { | 553 | while (!list_empty(&todo_list)) { |
| 552 | key = list_first_entry(&todo_list, struct ieee80211_key, todo); | 554 | key = list_first_entry(&todo_list, struct ieee80211_key, todo); |
| 553 | list_del_init(&key->todo); | 555 | list_del_init(&key->todo); |
| @@ -558,7 +560,7 @@ static void __ieee80211_key_todo(void) | |||
| 558 | KEY_FLAG_TODO_HWACCEL_REMOVE | | 560 | KEY_FLAG_TODO_HWACCEL_REMOVE | |
| 559 | KEY_FLAG_TODO_DELETE); | 561 | KEY_FLAG_TODO_DELETE); |
| 560 | key->flags &= ~todoflags; | 562 | key->flags &= ~todoflags; |
| 561 | spin_unlock(&todo_lock); | 563 | spin_unlock_bh(&todo_lock); |
| 562 | 564 | ||
| 563 | work_done = false; | 565 | work_done = false; |
| 564 | 566 | ||
| @@ -591,9 +593,9 @@ static void __ieee80211_key_todo(void) | |||
| 591 | 593 | ||
| 592 | WARN_ON(!work_done); | 594 | WARN_ON(!work_done); |
| 593 | 595 | ||
| 594 | spin_lock(&todo_lock); | 596 | spin_lock_bh(&todo_lock); |
| 595 | } | 597 | } |
| 596 | spin_unlock(&todo_lock); | 598 | spin_unlock_bh(&todo_lock); |
| 597 | } | 599 | } |
| 598 | 600 | ||
| 599 | void ieee80211_key_todo(void) | 601 | void ieee80211_key_todo(void) |
diff --git a/net/mac80211/mesh_pathtbl.c b/net/mac80211/mesh_pathtbl.c index 3c72557df45a..479597e88583 100644 --- a/net/mac80211/mesh_pathtbl.c +++ b/net/mac80211/mesh_pathtbl.c | |||
| @@ -175,6 +175,8 @@ int mesh_path_add(u8 *dst, struct ieee80211_sub_if_data *sdata) | |||
| 175 | int err = 0; | 175 | int err = 0; |
| 176 | u32 hash_idx; | 176 | u32 hash_idx; |
| 177 | 177 | ||
| 178 | might_sleep(); | ||
| 179 | |||
| 178 | if (memcmp(dst, sdata->dev->dev_addr, ETH_ALEN) == 0) | 180 | if (memcmp(dst, sdata->dev->dev_addr, ETH_ALEN) == 0) |
| 179 | /* never add ourselves as neighbours */ | 181 | /* never add ourselves as neighbours */ |
| 180 | return -ENOTSUPP; | 182 | return -ENOTSUPP; |
| @@ -265,6 +267,7 @@ int mpp_path_add(u8 *dst, u8 *mpp, struct ieee80211_sub_if_data *sdata) | |||
| 265 | int err = 0; | 267 | int err = 0; |
| 266 | u32 hash_idx; | 268 | u32 hash_idx; |
| 267 | 269 | ||
| 270 | might_sleep(); | ||
| 268 | 271 | ||
| 269 | if (memcmp(dst, sdata->dev->dev_addr, ETH_ALEN) == 0) | 272 | if (memcmp(dst, sdata->dev->dev_addr, ETH_ALEN) == 0) |
| 270 | /* never add ourselves as neighbours */ | 273 | /* never add ourselves as neighbours */ |
| @@ -491,8 +494,10 @@ void mesh_path_tx_pending(struct mesh_path *mpath) | |||
| 491 | * @skb: frame to discard | 494 | * @skb: frame to discard |
| 492 | * @sdata: network subif the frame was to be sent through | 495 | * @sdata: network subif the frame was to be sent through |
| 493 | * | 496 | * |
| 494 | * If the frame was beign forwarded from another MP, a PERR frame will be sent | 497 | * If the frame was being forwarded from another MP, a PERR frame will be sent |
| 495 | * to the precursor. | 498 | * to the precursor. The precursor's address (i.e. the previous hop) was saved |
| 499 | * in addr1 of the frame-to-be-forwarded, and would only be overwritten once | ||
| 500 | * the destination is successfully resolved. | ||
| 496 | * | 501 | * |
| 497 | * Locking: the function must me called within a rcu_read_lock region | 502 | * Locking: the function must me called within a rcu_read_lock region |
| 498 | */ | 503 | */ |
| @@ -507,7 +512,7 @@ void mesh_path_discard_frame(struct sk_buff *skb, | |||
| 507 | u8 *ra, *da; | 512 | u8 *ra, *da; |
| 508 | 513 | ||
| 509 | da = hdr->addr3; | 514 | da = hdr->addr3; |
| 510 | ra = hdr->addr2; | 515 | ra = hdr->addr1; |
| 511 | mpath = mesh_path_lookup(da, sdata); | 516 | mpath = mesh_path_lookup(da, sdata); |
| 512 | if (mpath) | 517 | if (mpath) |
| 513 | dsn = ++mpath->dsn; | 518 | dsn = ++mpath->dsn; |
diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c index aca22b00b6a3..07e7e41816be 100644 --- a/net/mac80211/mlme.c +++ b/net/mac80211/mlme.c | |||
| @@ -721,7 +721,7 @@ void ieee80211_dynamic_ps_timer(unsigned long data) | |||
| 721 | { | 721 | { |
| 722 | struct ieee80211_local *local = (void *) data; | 722 | struct ieee80211_local *local = (void *) data; |
| 723 | 723 | ||
| 724 | if (local->quiescing) | 724 | if (local->quiescing || local->suspended) |
| 725 | return; | 725 | return; |
| 726 | 726 | ||
| 727 | queue_work(local->hw.workqueue, &local->dynamic_ps_enable_work); | 727 | queue_work(local->hw.workqueue, &local->dynamic_ps_enable_work); |
diff --git a/net/mac80211/pm.c b/net/mac80211/pm.c index 7a549f9deb96..5e3d476972f9 100644 --- a/net/mac80211/pm.c +++ b/net/mac80211/pm.c | |||
| @@ -55,15 +55,6 @@ int __ieee80211_suspend(struct ieee80211_hw *hw) | |||
| 55 | 55 | ||
| 56 | rcu_read_unlock(); | 56 | rcu_read_unlock(); |
| 57 | 57 | ||
| 58 | /* flush again, in case driver queued work */ | ||
| 59 | flush_workqueue(local->hw.workqueue); | ||
| 60 | |||
| 61 | /* stop hardware - this must stop RX */ | ||
| 62 | if (local->open_count) { | ||
| 63 | ieee80211_led_radio(local, false); | ||
| 64 | drv_stop(local); | ||
| 65 | } | ||
| 66 | |||
| 67 | /* remove STAs */ | 58 | /* remove STAs */ |
| 68 | spin_lock_irqsave(&local->sta_lock, flags); | 59 | spin_lock_irqsave(&local->sta_lock, flags); |
| 69 | list_for_each_entry(sta, &local->sta_list, list) { | 60 | list_for_each_entry(sta, &local->sta_list, list) { |
| @@ -111,7 +102,22 @@ int __ieee80211_suspend(struct ieee80211_hw *hw) | |||
| 111 | drv_remove_interface(local, &conf); | 102 | drv_remove_interface(local, &conf); |
| 112 | } | 103 | } |
| 113 | 104 | ||
| 105 | /* stop hardware - this must stop RX */ | ||
| 106 | if (local->open_count) { | ||
| 107 | ieee80211_led_radio(local, false); | ||
| 108 | drv_stop(local); | ||
| 109 | } | ||
| 110 | |||
| 111 | /* | ||
| 112 | * flush again, in case driver queued work -- it | ||
| 113 | * shouldn't be doing (or cancel everything in the | ||
| 114 | * stop callback) that but better safe than sorry. | ||
| 115 | */ | ||
| 116 | flush_workqueue(local->hw.workqueue); | ||
| 117 | |||
| 114 | local->suspended = true; | 118 | local->suspended = true; |
| 119 | /* need suspended to be visible before quiescing is false */ | ||
| 120 | barrier(); | ||
| 115 | local->quiescing = false; | 121 | local->quiescing = false; |
| 116 | 122 | ||
| 117 | return 0; | 123 | return 0; |
diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c index de5bba7f910a..0936fc24942d 100644 --- a/net/mac80211/rx.c +++ b/net/mac80211/rx.c | |||
| @@ -2453,6 +2453,18 @@ void __ieee80211_rx(struct ieee80211_hw *hw, struct sk_buff *skb, | |||
| 2453 | return; | 2453 | return; |
| 2454 | } | 2454 | } |
| 2455 | 2455 | ||
| 2456 | /* | ||
| 2457 | * If we're suspending, it is possible although not too likely | ||
| 2458 | * that we'd be receiving frames after having already partially | ||
| 2459 | * quiesced the stack. We can't process such frames then since | ||
| 2460 | * that might, for example, cause stations to be added or other | ||
| 2461 | * driver callbacks be invoked. | ||
| 2462 | */ | ||
| 2463 | if (unlikely(local->quiescing || local->suspended)) { | ||
| 2464 | kfree_skb(skb); | ||
| 2465 | return; | ||
| 2466 | } | ||
| 2467 | |||
| 2456 | if (status->flag & RX_FLAG_HT) { | 2468 | if (status->flag & RX_FLAG_HT) { |
| 2457 | /* rate_idx is MCS index */ | 2469 | /* rate_idx is MCS index */ |
| 2458 | if (WARN_ON(status->rate_idx < 0 || | 2470 | if (WARN_ON(status->rate_idx < 0 || |
diff --git a/net/mac80211/tx.c b/net/mac80211/tx.c index d238a8939a09..3a8922cd1038 100644 --- a/net/mac80211/tx.c +++ b/net/mac80211/tx.c | |||
| @@ -1455,7 +1455,7 @@ int ieee80211_master_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 1455 | monitor_iface = UNKNOWN_ADDRESS; | 1455 | monitor_iface = UNKNOWN_ADDRESS; |
| 1456 | 1456 | ||
| 1457 | len_rthdr = ieee80211_get_radiotap_len(skb->data); | 1457 | len_rthdr = ieee80211_get_radiotap_len(skb->data); |
| 1458 | hdr = (struct ieee80211_hdr *)skb->data + len_rthdr; | 1458 | hdr = (struct ieee80211_hdr *)(skb->data + len_rthdr); |
| 1459 | hdrlen = ieee80211_hdrlen(hdr->frame_control); | 1459 | hdrlen = ieee80211_hdrlen(hdr->frame_control); |
| 1460 | 1460 | ||
| 1461 | /* check the header is complete in the frame */ | 1461 | /* check the header is complete in the frame */ |
diff --git a/net/netfilter/nf_conntrack_core.c b/net/netfilter/nf_conntrack_core.c index 7508f11c5b39..b5869b9574b0 100644 --- a/net/netfilter/nf_conntrack_core.c +++ b/net/netfilter/nf_conntrack_core.c | |||
| @@ -561,23 +561,38 @@ struct nf_conn *nf_conntrack_alloc(struct net *net, | |||
| 561 | } | 561 | } |
| 562 | } | 562 | } |
| 563 | 563 | ||
| 564 | ct = kmem_cache_zalloc(nf_conntrack_cachep, gfp); | 564 | /* |
| 565 | * Do not use kmem_cache_zalloc(), as this cache uses | ||
| 566 | * SLAB_DESTROY_BY_RCU. | ||
| 567 | */ | ||
| 568 | ct = kmem_cache_alloc(nf_conntrack_cachep, gfp); | ||
| 565 | if (ct == NULL) { | 569 | if (ct == NULL) { |
| 566 | pr_debug("nf_conntrack_alloc: Can't alloc conntrack.\n"); | 570 | pr_debug("nf_conntrack_alloc: Can't alloc conntrack.\n"); |
| 567 | atomic_dec(&net->ct.count); | 571 | atomic_dec(&net->ct.count); |
| 568 | return ERR_PTR(-ENOMEM); | 572 | return ERR_PTR(-ENOMEM); |
| 569 | } | 573 | } |
| 570 | 574 | /* | |
| 575 | * Let ct->tuplehash[IP_CT_DIR_ORIGINAL].hnnode.next | ||
| 576 | * and ct->tuplehash[IP_CT_DIR_REPLY].hnnode.next unchanged. | ||
| 577 | */ | ||
| 578 | memset(&ct->tuplehash[IP_CT_DIR_MAX], 0, | ||
| 579 | sizeof(*ct) - offsetof(struct nf_conn, tuplehash[IP_CT_DIR_MAX])); | ||
| 571 | spin_lock_init(&ct->lock); | 580 | spin_lock_init(&ct->lock); |
| 572 | atomic_set(&ct->ct_general.use, 1); | ||
| 573 | ct->tuplehash[IP_CT_DIR_ORIGINAL].tuple = *orig; | 581 | ct->tuplehash[IP_CT_DIR_ORIGINAL].tuple = *orig; |
| 582 | ct->tuplehash[IP_CT_DIR_ORIGINAL].hnnode.pprev = NULL; | ||
| 574 | ct->tuplehash[IP_CT_DIR_REPLY].tuple = *repl; | 583 | ct->tuplehash[IP_CT_DIR_REPLY].tuple = *repl; |
| 584 | ct->tuplehash[IP_CT_DIR_REPLY].hnnode.pprev = NULL; | ||
| 575 | /* Don't set timer yet: wait for confirmation */ | 585 | /* Don't set timer yet: wait for confirmation */ |
| 576 | setup_timer(&ct->timeout, death_by_timeout, (unsigned long)ct); | 586 | setup_timer(&ct->timeout, death_by_timeout, (unsigned long)ct); |
| 577 | #ifdef CONFIG_NET_NS | 587 | #ifdef CONFIG_NET_NS |
| 578 | ct->ct_net = net; | 588 | ct->ct_net = net; |
| 579 | #endif | 589 | #endif |
| 580 | 590 | ||
| 591 | /* | ||
| 592 | * changes to lookup keys must be done before setting refcnt to 1 | ||
| 593 | */ | ||
| 594 | smp_wmb(); | ||
| 595 | atomic_set(&ct->ct_general.use, 1); | ||
| 581 | return ct; | 596 | return ct; |
| 582 | } | 597 | } |
| 583 | EXPORT_SYMBOL_GPL(nf_conntrack_alloc); | 598 | EXPORT_SYMBOL_GPL(nf_conntrack_alloc); |
diff --git a/net/netfilter/xt_RATEEST.c b/net/netfilter/xt_RATEEST.c index 43f5676b1af4..d80b8192e0d4 100644 --- a/net/netfilter/xt_RATEEST.c +++ b/net/netfilter/xt_RATEEST.c | |||
| @@ -74,7 +74,7 @@ static unsigned int | |||
| 74 | xt_rateest_tg(struct sk_buff *skb, const struct xt_target_param *par) | 74 | xt_rateest_tg(struct sk_buff *skb, const struct xt_target_param *par) |
| 75 | { | 75 | { |
| 76 | const struct xt_rateest_target_info *info = par->targinfo; | 76 | const struct xt_rateest_target_info *info = par->targinfo; |
| 77 | struct gnet_stats_basic *stats = &info->est->bstats; | 77 | struct gnet_stats_basic_packed *stats = &info->est->bstats; |
| 78 | 78 | ||
| 79 | spin_lock_bh(&info->est->lock); | 79 | spin_lock_bh(&info->est->lock); |
| 80 | stats->bytes += skb->len; | 80 | stats->bytes += skb->len; |
diff --git a/net/netfilter/xt_osf.c b/net/netfilter/xt_osf.c index 863e40977a4d..0f482e2440b4 100644 --- a/net/netfilter/xt_osf.c +++ b/net/netfilter/xt_osf.c | |||
| @@ -330,7 +330,8 @@ static bool xt_osf_match_packet(const struct sk_buff *skb, | |||
| 330 | fcount++; | 330 | fcount++; |
| 331 | 331 | ||
| 332 | if (info->flags & XT_OSF_LOG) | 332 | if (info->flags & XT_OSF_LOG) |
| 333 | nf_log_packet(p->hooknum, 0, skb, p->in, p->out, NULL, | 333 | nf_log_packet(p->family, p->hooknum, skb, |
| 334 | p->in, p->out, NULL, | ||
| 334 | "%s [%s:%s] : %pi4:%d -> %pi4:%d hops=%d\n", | 335 | "%s [%s:%s] : %pi4:%d -> %pi4:%d hops=%d\n", |
| 335 | f->genre, f->version, f->subtype, | 336 | f->genre, f->version, f->subtype, |
| 336 | &ip->saddr, ntohs(tcp->source), | 337 | &ip->saddr, ntohs(tcp->source), |
| @@ -345,7 +346,7 @@ static bool xt_osf_match_packet(const struct sk_buff *skb, | |||
| 345 | rcu_read_unlock(); | 346 | rcu_read_unlock(); |
| 346 | 347 | ||
| 347 | if (!fcount && (info->flags & XT_OSF_LOG)) | 348 | if (!fcount && (info->flags & XT_OSF_LOG)) |
| 348 | nf_log_packet(p->hooknum, 0, skb, p->in, p->out, NULL, | 349 | nf_log_packet(p->family, p->hooknum, skb, p->in, p->out, NULL, |
| 349 | "Remote OS is not known: %pi4:%u -> %pi4:%u\n", | 350 | "Remote OS is not known: %pi4:%u -> %pi4:%u\n", |
| 350 | &ip->saddr, ntohs(tcp->source), | 351 | &ip->saddr, ntohs(tcp->source), |
| 351 | &ip->daddr, ntohs(tcp->dest)); | 352 | &ip->daddr, ntohs(tcp->dest)); |
diff --git a/net/netfilter/xt_quota.c b/net/netfilter/xt_quota.c index 98fc190e8f0e..390b7d09fe51 100644 --- a/net/netfilter/xt_quota.c +++ b/net/netfilter/xt_quota.c | |||
| @@ -52,7 +52,7 @@ static bool quota_mt_check(const struct xt_mtchk_param *par) | |||
| 52 | 52 | ||
| 53 | q->master = kmalloc(sizeof(*q->master), GFP_KERNEL); | 53 | q->master = kmalloc(sizeof(*q->master), GFP_KERNEL); |
| 54 | if (q->master == NULL) | 54 | if (q->master == NULL) |
| 55 | return -ENOMEM; | 55 | return false; |
| 56 | 56 | ||
| 57 | q->master->quota = q->quota; | 57 | q->master->quota = q->quota; |
| 58 | return true; | 58 | return true; |
diff --git a/net/netlabel/netlabel_kapi.c b/net/netlabel/netlabel_kapi.c index b0e582f2d37a..16e6c4378ff1 100644 --- a/net/netlabel/netlabel_kapi.c +++ b/net/netlabel/netlabel_kapi.c | |||
| @@ -151,7 +151,7 @@ int netlbl_cfg_unlbl_map_add(const char *domain, | |||
| 151 | addr6 = addr; | 151 | addr6 = addr; |
| 152 | mask6 = mask; | 152 | mask6 = mask; |
| 153 | map6 = kzalloc(sizeof(*map6), GFP_ATOMIC); | 153 | map6 = kzalloc(sizeof(*map6), GFP_ATOMIC); |
| 154 | if (map4 == NULL) | 154 | if (map6 == NULL) |
| 155 | goto cfg_unlbl_map_add_failure; | 155 | goto cfg_unlbl_map_add_failure; |
| 156 | map6->type = NETLBL_NLTYPE_UNLABELED; | 156 | map6->type = NETLBL_NLTYPE_UNLABELED; |
| 157 | ipv6_addr_copy(&map6->list.addr, addr6); | 157 | ipv6_addr_copy(&map6->list.addr, addr6); |
diff --git a/net/netrom/af_netrom.c b/net/netrom/af_netrom.c index ce51ce012cda..ce1a34b99c23 100644 --- a/net/netrom/af_netrom.c +++ b/net/netrom/af_netrom.c | |||
| @@ -847,6 +847,7 @@ static int nr_getname(struct socket *sock, struct sockaddr *uaddr, | |||
| 847 | sax->fsa_ax25.sax25_family = AF_NETROM; | 847 | sax->fsa_ax25.sax25_family = AF_NETROM; |
| 848 | sax->fsa_ax25.sax25_ndigis = 1; | 848 | sax->fsa_ax25.sax25_ndigis = 1; |
| 849 | sax->fsa_ax25.sax25_call = nr->user_addr; | 849 | sax->fsa_ax25.sax25_call = nr->user_addr; |
| 850 | memset(sax->fsa_digipeater, 0, sizeof(sax->fsa_digipeater)); | ||
| 850 | sax->fsa_digipeater[0] = nr->dest_addr; | 851 | sax->fsa_digipeater[0] = nr->dest_addr; |
| 851 | *uaddr_len = sizeof(struct full_sockaddr_ax25); | 852 | *uaddr_len = sizeof(struct full_sockaddr_ax25); |
| 852 | } else { | 853 | } else { |
diff --git a/net/netrom/nr_route.c b/net/netrom/nr_route.c index e943c16552a2..4eb1ac9a7679 100644 --- a/net/netrom/nr_route.c +++ b/net/netrom/nr_route.c | |||
| @@ -630,23 +630,23 @@ out: | |||
| 630 | return dev; | 630 | return dev; |
| 631 | } | 631 | } |
| 632 | 632 | ||
| 633 | static ax25_digi *nr_call_to_digi(int ndigis, ax25_address *digipeaters) | 633 | static ax25_digi *nr_call_to_digi(ax25_digi *digi, int ndigis, |
| 634 | ax25_address *digipeaters) | ||
| 634 | { | 635 | { |
| 635 | static ax25_digi ax25_digi; | ||
| 636 | int i; | 636 | int i; |
| 637 | 637 | ||
| 638 | if (ndigis == 0) | 638 | if (ndigis == 0) |
| 639 | return NULL; | 639 | return NULL; |
| 640 | 640 | ||
| 641 | for (i = 0; i < ndigis; i++) { | 641 | for (i = 0; i < ndigis; i++) { |
| 642 | ax25_digi.calls[i] = digipeaters[i]; | 642 | digi->calls[i] = digipeaters[i]; |
| 643 | ax25_digi.repeated[i] = 0; | 643 | digi->repeated[i] = 0; |
| 644 | } | 644 | } |
| 645 | 645 | ||
| 646 | ax25_digi.ndigi = ndigis; | 646 | digi->ndigi = ndigis; |
| 647 | ax25_digi.lastrepeat = -1; | 647 | digi->lastrepeat = -1; |
| 648 | 648 | ||
| 649 | return &ax25_digi; | 649 | return digi; |
| 650 | } | 650 | } |
| 651 | 651 | ||
| 652 | /* | 652 | /* |
| @@ -656,6 +656,7 @@ int nr_rt_ioctl(unsigned int cmd, void __user *arg) | |||
| 656 | { | 656 | { |
| 657 | struct nr_route_struct nr_route; | 657 | struct nr_route_struct nr_route; |
| 658 | struct net_device *dev; | 658 | struct net_device *dev; |
| 659 | ax25_digi digi; | ||
| 659 | int ret; | 660 | int ret; |
| 660 | 661 | ||
| 661 | switch (cmd) { | 662 | switch (cmd) { |
| @@ -673,13 +674,15 @@ int nr_rt_ioctl(unsigned int cmd, void __user *arg) | |||
| 673 | ret = nr_add_node(&nr_route.callsign, | 674 | ret = nr_add_node(&nr_route.callsign, |
| 674 | nr_route.mnemonic, | 675 | nr_route.mnemonic, |
| 675 | &nr_route.neighbour, | 676 | &nr_route.neighbour, |
| 676 | nr_call_to_digi(nr_route.ndigis, nr_route.digipeaters), | 677 | nr_call_to_digi(&digi, nr_route.ndigis, |
| 678 | nr_route.digipeaters), | ||
| 677 | dev, nr_route.quality, | 679 | dev, nr_route.quality, |
| 678 | nr_route.obs_count); | 680 | nr_route.obs_count); |
| 679 | break; | 681 | break; |
| 680 | case NETROM_NEIGH: | 682 | case NETROM_NEIGH: |
| 681 | ret = nr_add_neigh(&nr_route.callsign, | 683 | ret = nr_add_neigh(&nr_route.callsign, |
| 682 | nr_call_to_digi(nr_route.ndigis, nr_route.digipeaters), | 684 | nr_call_to_digi(&digi, nr_route.ndigis, |
| 685 | nr_route.digipeaters), | ||
| 683 | dev, nr_route.quality); | 686 | dev, nr_route.quality); |
| 684 | break; | 687 | break; |
| 685 | default: | 688 | default: |
diff --git a/net/phonet/pn_dev.c b/net/phonet/pn_dev.c index b0d6ddd82a9d..c2b77a698695 100644 --- a/net/phonet/pn_dev.c +++ b/net/phonet/pn_dev.c | |||
| @@ -96,7 +96,7 @@ struct net_device *phonet_device_get(struct net *net) | |||
| 96 | { | 96 | { |
| 97 | struct phonet_device_list *pndevs = phonet_device_list(net); | 97 | struct phonet_device_list *pndevs = phonet_device_list(net); |
| 98 | struct phonet_device *pnd; | 98 | struct phonet_device *pnd; |
| 99 | struct net_device *dev; | 99 | struct net_device *dev = NULL; |
| 100 | 100 | ||
| 101 | spin_lock_bh(&pndevs->lock); | 101 | spin_lock_bh(&pndevs->lock); |
| 102 | list_for_each_entry(pnd, &pndevs->list, list) { | 102 | list_for_each_entry(pnd, &pndevs->list, list) { |
diff --git a/net/rfkill/core.c b/net/rfkill/core.c index 79693fe2001e..2fc4a1724eb8 100644 --- a/net/rfkill/core.c +++ b/net/rfkill/core.c | |||
| @@ -549,6 +549,10 @@ void rfkill_set_states(struct rfkill *rfkill, bool sw, bool hw) | |||
| 549 | swprev = !!(rfkill->state & RFKILL_BLOCK_SW); | 549 | swprev = !!(rfkill->state & RFKILL_BLOCK_SW); |
| 550 | hwprev = !!(rfkill->state & RFKILL_BLOCK_HW); | 550 | hwprev = !!(rfkill->state & RFKILL_BLOCK_HW); |
| 551 | __rfkill_set_sw_state(rfkill, sw); | 551 | __rfkill_set_sw_state(rfkill, sw); |
| 552 | if (hw) | ||
| 553 | rfkill->state |= RFKILL_BLOCK_HW; | ||
| 554 | else | ||
| 555 | rfkill->state &= ~RFKILL_BLOCK_HW; | ||
| 552 | 556 | ||
| 553 | spin_unlock_irqrestore(&rfkill->lock, flags); | 557 | spin_unlock_irqrestore(&rfkill->lock, flags); |
| 554 | 558 | ||
| @@ -648,15 +652,26 @@ static ssize_t rfkill_state_store(struct device *dev, | |||
| 648 | struct device_attribute *attr, | 652 | struct device_attribute *attr, |
| 649 | const char *buf, size_t count) | 653 | const char *buf, size_t count) |
| 650 | { | 654 | { |
| 651 | /* | 655 | struct rfkill *rfkill = to_rfkill(dev); |
| 652 | * The intention was that userspace can only take control over | 656 | unsigned long state; |
| 653 | * a given device when/if rfkill-input doesn't control it due | 657 | int err; |
| 654 | * to user_claim. Since user_claim is currently unsupported, | 658 | |
| 655 | * we never support changing the state from userspace -- this | 659 | if (!capable(CAP_NET_ADMIN)) |
| 656 | * can be implemented again later. | 660 | return -EPERM; |
| 657 | */ | 661 | |
| 662 | err = strict_strtoul(buf, 0, &state); | ||
| 663 | if (err) | ||
| 664 | return err; | ||
| 665 | |||
| 666 | if (state != RFKILL_USER_STATE_SOFT_BLOCKED && | ||
| 667 | state != RFKILL_USER_STATE_UNBLOCKED) | ||
| 668 | return -EINVAL; | ||
| 669 | |||
| 670 | mutex_lock(&rfkill_global_mutex); | ||
| 671 | rfkill_set_block(rfkill, state == RFKILL_USER_STATE_SOFT_BLOCKED); | ||
| 672 | mutex_unlock(&rfkill_global_mutex); | ||
| 658 | 673 | ||
| 659 | return -EPERM; | 674 | return err ?: count; |
| 660 | } | 675 | } |
| 661 | 676 | ||
| 662 | static ssize_t rfkill_claim_show(struct device *dev, | 677 | static ssize_t rfkill_claim_show(struct device *dev, |
diff --git a/net/rose/af_rose.c b/net/rose/af_rose.c index 6bd8e93869ed..e5f478ca3d61 100644 --- a/net/rose/af_rose.c +++ b/net/rose/af_rose.c | |||
| @@ -92,23 +92,21 @@ static void rose_set_lockdep_key(struct net_device *dev) | |||
| 92 | /* | 92 | /* |
| 93 | * Convert a ROSE address into text. | 93 | * Convert a ROSE address into text. |
| 94 | */ | 94 | */ |
| 95 | const char *rose2asc(const rose_address *addr) | 95 | char *rose2asc(char *buf, const rose_address *addr) |
| 96 | { | 96 | { |
| 97 | static char buffer[11]; | ||
| 98 | |||
| 99 | if (addr->rose_addr[0] == 0x00 && addr->rose_addr[1] == 0x00 && | 97 | if (addr->rose_addr[0] == 0x00 && addr->rose_addr[1] == 0x00 && |
| 100 | addr->rose_addr[2] == 0x00 && addr->rose_addr[3] == 0x00 && | 98 | addr->rose_addr[2] == 0x00 && addr->rose_addr[3] == 0x00 && |
| 101 | addr->rose_addr[4] == 0x00) { | 99 | addr->rose_addr[4] == 0x00) { |
| 102 | strcpy(buffer, "*"); | 100 | strcpy(buf, "*"); |
| 103 | } else { | 101 | } else { |
| 104 | sprintf(buffer, "%02X%02X%02X%02X%02X", addr->rose_addr[0] & 0xFF, | 102 | sprintf(buf, "%02X%02X%02X%02X%02X", addr->rose_addr[0] & 0xFF, |
| 105 | addr->rose_addr[1] & 0xFF, | 103 | addr->rose_addr[1] & 0xFF, |
| 106 | addr->rose_addr[2] & 0xFF, | 104 | addr->rose_addr[2] & 0xFF, |
| 107 | addr->rose_addr[3] & 0xFF, | 105 | addr->rose_addr[3] & 0xFF, |
| 108 | addr->rose_addr[4] & 0xFF); | 106 | addr->rose_addr[4] & 0xFF); |
| 109 | } | 107 | } |
| 110 | 108 | ||
| 111 | return buffer; | 109 | return buf; |
| 112 | } | 110 | } |
| 113 | 111 | ||
| 114 | /* | 112 | /* |
| @@ -956,6 +954,7 @@ static int rose_getname(struct socket *sock, struct sockaddr *uaddr, | |||
| 956 | struct rose_sock *rose = rose_sk(sk); | 954 | struct rose_sock *rose = rose_sk(sk); |
| 957 | int n; | 955 | int n; |
| 958 | 956 | ||
| 957 | memset(srose, 0, sizeof(*srose)); | ||
| 959 | if (peer != 0) { | 958 | if (peer != 0) { |
| 960 | if (sk->sk_state != TCP_ESTABLISHED) | 959 | if (sk->sk_state != TCP_ESTABLISHED) |
| 961 | return -ENOTCONN; | 960 | return -ENOTCONN; |
| @@ -1437,7 +1436,7 @@ static void rose_info_stop(struct seq_file *seq, void *v) | |||
| 1437 | 1436 | ||
| 1438 | static int rose_info_show(struct seq_file *seq, void *v) | 1437 | static int rose_info_show(struct seq_file *seq, void *v) |
| 1439 | { | 1438 | { |
| 1440 | char buf[11]; | 1439 | char buf[11], rsbuf[11]; |
| 1441 | 1440 | ||
| 1442 | if (v == SEQ_START_TOKEN) | 1441 | if (v == SEQ_START_TOKEN) |
| 1443 | seq_puts(seq, | 1442 | seq_puts(seq, |
| @@ -1455,8 +1454,8 @@ static int rose_info_show(struct seq_file *seq, void *v) | |||
| 1455 | devname = dev->name; | 1454 | devname = dev->name; |
| 1456 | 1455 | ||
| 1457 | seq_printf(seq, "%-10s %-9s ", | 1456 | seq_printf(seq, "%-10s %-9s ", |
| 1458 | rose2asc(&rose->dest_addr), | 1457 | rose2asc(rsbuf, &rose->dest_addr), |
| 1459 | ax2asc(buf, &rose->dest_call)); | 1458 | ax2asc(buf, &rose->dest_call)); |
| 1460 | 1459 | ||
| 1461 | if (ax25cmp(&rose->source_call, &null_ax25_address) == 0) | 1460 | if (ax25cmp(&rose->source_call, &null_ax25_address) == 0) |
| 1462 | callsign = "??????-?"; | 1461 | callsign = "??????-?"; |
| @@ -1465,7 +1464,7 @@ static int rose_info_show(struct seq_file *seq, void *v) | |||
| 1465 | 1464 | ||
| 1466 | seq_printf(seq, | 1465 | seq_printf(seq, |
| 1467 | "%-10s %-9s %-5s %3.3X %05d %d %d %d %d %3lu %3lu %3lu %3lu %3lu %3lu/%03lu %5d %5d %ld\n", | 1466 | "%-10s %-9s %-5s %3.3X %05d %d %d %d %d %3lu %3lu %3lu %3lu %3lu %3lu/%03lu %5d %5d %ld\n", |
| 1468 | rose2asc(&rose->source_addr), | 1467 | rose2asc(rsbuf, &rose->source_addr), |
| 1469 | callsign, | 1468 | callsign, |
| 1470 | devname, | 1469 | devname, |
| 1471 | rose->lci & 0x0FFF, | 1470 | rose->lci & 0x0FFF, |
diff --git a/net/rose/rose_route.c b/net/rose/rose_route.c index a81066a1010a..9478d9b3d977 100644 --- a/net/rose/rose_route.c +++ b/net/rose/rose_route.c | |||
| @@ -1104,6 +1104,7 @@ static void rose_node_stop(struct seq_file *seq, void *v) | |||
| 1104 | 1104 | ||
| 1105 | static int rose_node_show(struct seq_file *seq, void *v) | 1105 | static int rose_node_show(struct seq_file *seq, void *v) |
| 1106 | { | 1106 | { |
| 1107 | char rsbuf[11]; | ||
| 1107 | int i; | 1108 | int i; |
| 1108 | 1109 | ||
| 1109 | if (v == SEQ_START_TOKEN) | 1110 | if (v == SEQ_START_TOKEN) |
| @@ -1112,13 +1113,13 @@ static int rose_node_show(struct seq_file *seq, void *v) | |||
| 1112 | const struct rose_node *rose_node = v; | 1113 | const struct rose_node *rose_node = v; |
| 1113 | /* if (rose_node->loopback) { | 1114 | /* if (rose_node->loopback) { |
| 1114 | seq_printf(seq, "%-10s %04d 1 loopback\n", | 1115 | seq_printf(seq, "%-10s %04d 1 loopback\n", |
| 1115 | rose2asc(&rose_node->address), | 1116 | rose2asc(rsbuf, &rose_node->address), |
| 1116 | rose_node->mask); | 1117 | rose_node->mask); |
| 1117 | } else { */ | 1118 | } else { */ |
| 1118 | seq_printf(seq, "%-10s %04d %d", | 1119 | seq_printf(seq, "%-10s %04d %d", |
| 1119 | rose2asc(&rose_node->address), | 1120 | rose2asc(rsbuf, &rose_node->address), |
| 1120 | rose_node->mask, | 1121 | rose_node->mask, |
| 1121 | rose_node->count); | 1122 | rose_node->count); |
| 1122 | 1123 | ||
| 1123 | for (i = 0; i < rose_node->count; i++) | 1124 | for (i = 0; i < rose_node->count; i++) |
| 1124 | seq_printf(seq, " %05d", | 1125 | seq_printf(seq, " %05d", |
| @@ -1267,7 +1268,7 @@ static void rose_route_stop(struct seq_file *seq, void *v) | |||
| 1267 | 1268 | ||
| 1268 | static int rose_route_show(struct seq_file *seq, void *v) | 1269 | static int rose_route_show(struct seq_file *seq, void *v) |
| 1269 | { | 1270 | { |
| 1270 | char buf[11]; | 1271 | char buf[11], rsbuf[11]; |
| 1271 | 1272 | ||
| 1272 | if (v == SEQ_START_TOKEN) | 1273 | if (v == SEQ_START_TOKEN) |
| 1273 | seq_puts(seq, | 1274 | seq_puts(seq, |
| @@ -1279,7 +1280,7 @@ static int rose_route_show(struct seq_file *seq, void *v) | |||
| 1279 | seq_printf(seq, | 1280 | seq_printf(seq, |
| 1280 | "%3.3X %-10s %-9s %05d ", | 1281 | "%3.3X %-10s %-9s %05d ", |
| 1281 | rose_route->lci1, | 1282 | rose_route->lci1, |
| 1282 | rose2asc(&rose_route->src_addr), | 1283 | rose2asc(rsbuf, &rose_route->src_addr), |
| 1283 | ax2asc(buf, &rose_route->src_call), | 1284 | ax2asc(buf, &rose_route->src_call), |
| 1284 | rose_route->neigh1->number); | 1285 | rose_route->neigh1->number); |
| 1285 | else | 1286 | else |
| @@ -1289,10 +1290,10 @@ static int rose_route_show(struct seq_file *seq, void *v) | |||
| 1289 | if (rose_route->neigh2) | 1290 | if (rose_route->neigh2) |
| 1290 | seq_printf(seq, | 1291 | seq_printf(seq, |
| 1291 | "%3.3X %-10s %-9s %05d\n", | 1292 | "%3.3X %-10s %-9s %05d\n", |
| 1292 | rose_route->lci2, | 1293 | rose_route->lci2, |
| 1293 | rose2asc(&rose_route->dest_addr), | 1294 | rose2asc(rsbuf, &rose_route->dest_addr), |
| 1294 | ax2asc(buf, &rose_route->dest_call), | 1295 | ax2asc(buf, &rose_route->dest_call), |
| 1295 | rose_route->neigh2->number); | 1296 | rose_route->neigh2->number); |
| 1296 | else | 1297 | else |
| 1297 | seq_puts(seq, | 1298 | seq_puts(seq, |
| 1298 | "000 * * 00000\n"); | 1299 | "000 * * 00000\n"); |
diff --git a/net/sched/sch_api.c b/net/sched/sch_api.c index 24d17ce9c294..92e6f3a52c13 100644 --- a/net/sched/sch_api.c +++ b/net/sched/sch_api.c | |||
| @@ -458,7 +458,7 @@ EXPORT_SYMBOL(qdisc_warn_nonwc); | |||
| 458 | static enum hrtimer_restart qdisc_watchdog(struct hrtimer *timer) | 458 | static enum hrtimer_restart qdisc_watchdog(struct hrtimer *timer) |
| 459 | { | 459 | { |
| 460 | struct qdisc_watchdog *wd = container_of(timer, struct qdisc_watchdog, | 460 | struct qdisc_watchdog *wd = container_of(timer, struct qdisc_watchdog, |
| 461 | timer); | 461 | timer.timer); |
| 462 | 462 | ||
| 463 | wd->qdisc->flags &= ~TCQ_F_THROTTLED; | 463 | wd->qdisc->flags &= ~TCQ_F_THROTTLED; |
| 464 | __netif_schedule(qdisc_root(wd->qdisc)); | 464 | __netif_schedule(qdisc_root(wd->qdisc)); |
| @@ -468,8 +468,8 @@ static enum hrtimer_restart qdisc_watchdog(struct hrtimer *timer) | |||
| 468 | 468 | ||
| 469 | void qdisc_watchdog_init(struct qdisc_watchdog *wd, struct Qdisc *qdisc) | 469 | void qdisc_watchdog_init(struct qdisc_watchdog *wd, struct Qdisc *qdisc) |
| 470 | { | 470 | { |
| 471 | hrtimer_init(&wd->timer, CLOCK_MONOTONIC, HRTIMER_MODE_ABS); | 471 | tasklet_hrtimer_init(&wd->timer, qdisc_watchdog, |
| 472 | wd->timer.function = qdisc_watchdog; | 472 | CLOCK_MONOTONIC, HRTIMER_MODE_ABS); |
| 473 | wd->qdisc = qdisc; | 473 | wd->qdisc = qdisc; |
| 474 | } | 474 | } |
| 475 | EXPORT_SYMBOL(qdisc_watchdog_init); | 475 | EXPORT_SYMBOL(qdisc_watchdog_init); |
| @@ -485,13 +485,13 @@ void qdisc_watchdog_schedule(struct qdisc_watchdog *wd, psched_time_t expires) | |||
| 485 | wd->qdisc->flags |= TCQ_F_THROTTLED; | 485 | wd->qdisc->flags |= TCQ_F_THROTTLED; |
| 486 | time = ktime_set(0, 0); | 486 | time = ktime_set(0, 0); |
| 487 | time = ktime_add_ns(time, PSCHED_TICKS2NS(expires)); | 487 | time = ktime_add_ns(time, PSCHED_TICKS2NS(expires)); |
| 488 | hrtimer_start(&wd->timer, time, HRTIMER_MODE_ABS); | 488 | tasklet_hrtimer_start(&wd->timer, time, HRTIMER_MODE_ABS); |
| 489 | } | 489 | } |
| 490 | EXPORT_SYMBOL(qdisc_watchdog_schedule); | 490 | EXPORT_SYMBOL(qdisc_watchdog_schedule); |
| 491 | 491 | ||
| 492 | void qdisc_watchdog_cancel(struct qdisc_watchdog *wd) | 492 | void qdisc_watchdog_cancel(struct qdisc_watchdog *wd) |
| 493 | { | 493 | { |
| 494 | hrtimer_cancel(&wd->timer); | 494 | tasklet_hrtimer_cancel(&wd->timer); |
| 495 | wd->qdisc->flags &= ~TCQ_F_THROTTLED; | 495 | wd->qdisc->flags &= ~TCQ_F_THROTTLED; |
| 496 | } | 496 | } |
| 497 | EXPORT_SYMBOL(qdisc_watchdog_cancel); | 497 | EXPORT_SYMBOL(qdisc_watchdog_cancel); |
diff --git a/net/sched/sch_atm.c b/net/sched/sch_atm.c index 2a8b83af7c47..ab82f145f689 100644 --- a/net/sched/sch_atm.c +++ b/net/sched/sch_atm.c | |||
| @@ -49,7 +49,7 @@ struct atm_flow_data { | |||
| 49 | struct socket *sock; /* for closing */ | 49 | struct socket *sock; /* for closing */ |
| 50 | u32 classid; /* x:y type ID */ | 50 | u32 classid; /* x:y type ID */ |
| 51 | int ref; /* reference count */ | 51 | int ref; /* reference count */ |
| 52 | struct gnet_stats_basic bstats; | 52 | struct gnet_stats_basic_packed bstats; |
| 53 | struct gnet_stats_queue qstats; | 53 | struct gnet_stats_queue qstats; |
| 54 | struct atm_flow_data *next; | 54 | struct atm_flow_data *next; |
| 55 | struct atm_flow_data *excess; /* flow for excess traffic; | 55 | struct atm_flow_data *excess; /* flow for excess traffic; |
diff --git a/net/sched/sch_cbq.c b/net/sched/sch_cbq.c index 23a167670fd5..149b0405c5ec 100644 --- a/net/sched/sch_cbq.c +++ b/net/sched/sch_cbq.c | |||
| @@ -128,7 +128,7 @@ struct cbq_class | |||
| 128 | long avgidle; | 128 | long avgidle; |
| 129 | long deficit; /* Saved deficit for WRR */ | 129 | long deficit; /* Saved deficit for WRR */ |
| 130 | psched_time_t penalized; | 130 | psched_time_t penalized; |
| 131 | struct gnet_stats_basic bstats; | 131 | struct gnet_stats_basic_packed bstats; |
| 132 | struct gnet_stats_queue qstats; | 132 | struct gnet_stats_queue qstats; |
| 133 | struct gnet_stats_rate_est rate_est; | 133 | struct gnet_stats_rate_est rate_est; |
| 134 | struct tc_cbq_xstats xstats; | 134 | struct tc_cbq_xstats xstats; |
| @@ -163,7 +163,7 @@ struct cbq_sched_data | |||
| 163 | psched_time_t now_rt; /* Cached real time */ | 163 | psched_time_t now_rt; /* Cached real time */ |
| 164 | unsigned pmask; | 164 | unsigned pmask; |
| 165 | 165 | ||
| 166 | struct hrtimer delay_timer; | 166 | struct tasklet_hrtimer delay_timer; |
| 167 | struct qdisc_watchdog watchdog; /* Watchdog timer, | 167 | struct qdisc_watchdog watchdog; /* Watchdog timer, |
| 168 | started when CBQ has | 168 | started when CBQ has |
| 169 | backlog, but cannot | 169 | backlog, but cannot |
| @@ -503,6 +503,8 @@ static void cbq_ovl_delay(struct cbq_class *cl) | |||
| 503 | cl->undertime = q->now + delay; | 503 | cl->undertime = q->now + delay; |
| 504 | 504 | ||
| 505 | if (delay > 0) { | 505 | if (delay > 0) { |
| 506 | struct hrtimer *ht; | ||
| 507 | |||
| 506 | sched += delay + cl->penalty; | 508 | sched += delay + cl->penalty; |
| 507 | cl->penalized = sched; | 509 | cl->penalized = sched; |
| 508 | cl->cpriority = TC_CBQ_MAXPRIO; | 510 | cl->cpriority = TC_CBQ_MAXPRIO; |
| @@ -510,12 +512,12 @@ static void cbq_ovl_delay(struct cbq_class *cl) | |||
| 510 | 512 | ||
| 511 | expires = ktime_set(0, 0); | 513 | expires = ktime_set(0, 0); |
| 512 | expires = ktime_add_ns(expires, PSCHED_TICKS2NS(sched)); | 514 | expires = ktime_add_ns(expires, PSCHED_TICKS2NS(sched)); |
| 513 | if (hrtimer_try_to_cancel(&q->delay_timer) && | 515 | ht = &q->delay_timer.timer; |
| 514 | ktime_to_ns(ktime_sub( | 516 | if (hrtimer_try_to_cancel(ht) && |
| 515 | hrtimer_get_expires(&q->delay_timer), | 517 | ktime_to_ns(ktime_sub(hrtimer_get_expires(ht), |
| 516 | expires)) > 0) | 518 | expires)) > 0) |
| 517 | hrtimer_set_expires(&q->delay_timer, expires); | 519 | hrtimer_set_expires(ht, expires); |
| 518 | hrtimer_restart(&q->delay_timer); | 520 | hrtimer_restart(ht); |
| 519 | cl->delayed = 1; | 521 | cl->delayed = 1; |
| 520 | cl->xstats.overactions++; | 522 | cl->xstats.overactions++; |
| 521 | return; | 523 | return; |
| @@ -591,7 +593,7 @@ static psched_tdiff_t cbq_undelay_prio(struct cbq_sched_data *q, int prio, | |||
| 591 | static enum hrtimer_restart cbq_undelay(struct hrtimer *timer) | 593 | static enum hrtimer_restart cbq_undelay(struct hrtimer *timer) |
| 592 | { | 594 | { |
| 593 | struct cbq_sched_data *q = container_of(timer, struct cbq_sched_data, | 595 | struct cbq_sched_data *q = container_of(timer, struct cbq_sched_data, |
| 594 | delay_timer); | 596 | delay_timer.timer); |
| 595 | struct Qdisc *sch = q->watchdog.qdisc; | 597 | struct Qdisc *sch = q->watchdog.qdisc; |
| 596 | psched_time_t now; | 598 | psched_time_t now; |
| 597 | psched_tdiff_t delay = 0; | 599 | psched_tdiff_t delay = 0; |
| @@ -621,7 +623,7 @@ static enum hrtimer_restart cbq_undelay(struct hrtimer *timer) | |||
| 621 | 623 | ||
| 622 | time = ktime_set(0, 0); | 624 | time = ktime_set(0, 0); |
| 623 | time = ktime_add_ns(time, PSCHED_TICKS2NS(now + delay)); | 625 | time = ktime_add_ns(time, PSCHED_TICKS2NS(now + delay)); |
| 624 | hrtimer_start(&q->delay_timer, time, HRTIMER_MODE_ABS); | 626 | tasklet_hrtimer_start(&q->delay_timer, time, HRTIMER_MODE_ABS); |
| 625 | } | 627 | } |
| 626 | 628 | ||
| 627 | sch->flags &= ~TCQ_F_THROTTLED; | 629 | sch->flags &= ~TCQ_F_THROTTLED; |
| @@ -1214,7 +1216,7 @@ cbq_reset(struct Qdisc* sch) | |||
| 1214 | q->tx_class = NULL; | 1216 | q->tx_class = NULL; |
| 1215 | q->tx_borrowed = NULL; | 1217 | q->tx_borrowed = NULL; |
| 1216 | qdisc_watchdog_cancel(&q->watchdog); | 1218 | qdisc_watchdog_cancel(&q->watchdog); |
| 1217 | hrtimer_cancel(&q->delay_timer); | 1219 | tasklet_hrtimer_cancel(&q->delay_timer); |
| 1218 | q->toplevel = TC_CBQ_MAXLEVEL; | 1220 | q->toplevel = TC_CBQ_MAXLEVEL; |
| 1219 | q->now = psched_get_time(); | 1221 | q->now = psched_get_time(); |
| 1220 | q->now_rt = q->now; | 1222 | q->now_rt = q->now; |
| @@ -1397,7 +1399,8 @@ static int cbq_init(struct Qdisc *sch, struct nlattr *opt) | |||
| 1397 | q->link.minidle = -0x7FFFFFFF; | 1399 | q->link.minidle = -0x7FFFFFFF; |
| 1398 | 1400 | ||
| 1399 | qdisc_watchdog_init(&q->watchdog, sch); | 1401 | qdisc_watchdog_init(&q->watchdog, sch); |
| 1400 | hrtimer_init(&q->delay_timer, CLOCK_MONOTONIC, HRTIMER_MODE_ABS); | 1402 | tasklet_hrtimer_init(&q->delay_timer, cbq_undelay, |
| 1403 | CLOCK_MONOTONIC, HRTIMER_MODE_ABS); | ||
| 1401 | q->delay_timer.function = cbq_undelay; | 1404 | q->delay_timer.function = cbq_undelay; |
| 1402 | q->toplevel = TC_CBQ_MAXLEVEL; | 1405 | q->toplevel = TC_CBQ_MAXLEVEL; |
| 1403 | q->now = psched_get_time(); | 1406 | q->now = psched_get_time(); |
diff --git a/net/sched/sch_drr.c b/net/sched/sch_drr.c index 7597fe146866..12b2fb04b29b 100644 --- a/net/sched/sch_drr.c +++ b/net/sched/sch_drr.c | |||
| @@ -22,7 +22,7 @@ struct drr_class { | |||
| 22 | unsigned int refcnt; | 22 | unsigned int refcnt; |
| 23 | unsigned int filter_cnt; | 23 | unsigned int filter_cnt; |
| 24 | 24 | ||
| 25 | struct gnet_stats_basic bstats; | 25 | struct gnet_stats_basic_packed bstats; |
| 26 | struct gnet_stats_queue qstats; | 26 | struct gnet_stats_queue qstats; |
| 27 | struct gnet_stats_rate_est rate_est; | 27 | struct gnet_stats_rate_est rate_est; |
| 28 | struct list_head alist; | 28 | struct list_head alist; |
diff --git a/net/sched/sch_hfsc.c b/net/sched/sch_hfsc.c index 362c2811b2df..dad0144423da 100644 --- a/net/sched/sch_hfsc.c +++ b/net/sched/sch_hfsc.c | |||
| @@ -116,7 +116,7 @@ struct hfsc_class | |||
| 116 | struct Qdisc_class_common cl_common; | 116 | struct Qdisc_class_common cl_common; |
| 117 | unsigned int refcnt; /* usage count */ | 117 | unsigned int refcnt; /* usage count */ |
| 118 | 118 | ||
| 119 | struct gnet_stats_basic bstats; | 119 | struct gnet_stats_basic_packed bstats; |
| 120 | struct gnet_stats_queue qstats; | 120 | struct gnet_stats_queue qstats; |
| 121 | struct gnet_stats_rate_est rate_est; | 121 | struct gnet_stats_rate_est rate_est; |
| 122 | unsigned int level; /* class level in hierarchy */ | 122 | unsigned int level; /* class level in hierarchy */ |
diff --git a/net/sched/sch_htb.c b/net/sched/sch_htb.c index 88cd02626621..ec4d46399d59 100644 --- a/net/sched/sch_htb.c +++ b/net/sched/sch_htb.c | |||
| @@ -74,7 +74,7 @@ enum htb_cmode { | |||
| 74 | struct htb_class { | 74 | struct htb_class { |
| 75 | struct Qdisc_class_common common; | 75 | struct Qdisc_class_common common; |
| 76 | /* general class parameters */ | 76 | /* general class parameters */ |
| 77 | struct gnet_stats_basic bstats; | 77 | struct gnet_stats_basic_packed bstats; |
| 78 | struct gnet_stats_queue qstats; | 78 | struct gnet_stats_queue qstats; |
| 79 | struct gnet_stats_rate_est rate_est; | 79 | struct gnet_stats_rate_est rate_est; |
| 80 | struct tc_htb_xstats xstats; /* our special stats */ | 80 | struct tc_htb_xstats xstats; /* our special stats */ |
diff --git a/net/sctp/protocol.c b/net/sctp/protocol.c index 79cbd47f4df7..a76da657244a 100644 --- a/net/sctp/protocol.c +++ b/net/sctp/protocol.c | |||
| @@ -160,6 +160,7 @@ static void sctp_proc_exit(void) | |||
| 160 | remove_proc_entry("sctp", init_net.proc_net); | 160 | remove_proc_entry("sctp", init_net.proc_net); |
| 161 | } | 161 | } |
| 162 | #endif | 162 | #endif |
| 163 | percpu_counter_destroy(&sctp_sockets_allocated); | ||
| 163 | } | 164 | } |
| 164 | 165 | ||
| 165 | /* Private helper to extract ipv4 address and stash them in | 166 | /* Private helper to extract ipv4 address and stash them in |
diff --git a/net/socket.c b/net/socket.c index 791d71a36a93..6d4716559047 100644 --- a/net/socket.c +++ b/net/socket.c | |||
| @@ -736,7 +736,7 @@ static ssize_t sock_sendpage(struct file *file, struct page *page, | |||
| 736 | if (more) | 736 | if (more) |
| 737 | flags |= MSG_MORE; | 737 | flags |= MSG_MORE; |
| 738 | 738 | ||
| 739 | return sock->ops->sendpage(sock, page, offset, size, flags); | 739 | return kernel_sendpage(sock, page, offset, size, flags); |
| 740 | } | 740 | } |
| 741 | 741 | ||
| 742 | static ssize_t sock_splice_read(struct file *file, loff_t *ppos, | 742 | static ssize_t sock_splice_read(struct file *file, loff_t *ppos, |
diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c index 43bdb1372cae..634496b3ed77 100644 --- a/net/wireless/nl80211.c +++ b/net/wireless/nl80211.c | |||
| @@ -997,7 +997,7 @@ static int nl80211_get_key(struct sk_buff *skb, struct genl_info *info) | |||
| 997 | 997 | ||
| 998 | if (IS_ERR(hdr)) { | 998 | if (IS_ERR(hdr)) { |
| 999 | err = PTR_ERR(hdr); | 999 | err = PTR_ERR(hdr); |
| 1000 | goto out; | 1000 | goto free_msg; |
| 1001 | } | 1001 | } |
| 1002 | 1002 | ||
| 1003 | cookie.msg = msg; | 1003 | cookie.msg = msg; |
| @@ -1011,7 +1011,7 @@ static int nl80211_get_key(struct sk_buff *skb, struct genl_info *info) | |||
| 1011 | &cookie, get_key_callback); | 1011 | &cookie, get_key_callback); |
| 1012 | 1012 | ||
| 1013 | if (err) | 1013 | if (err) |
| 1014 | goto out; | 1014 | goto free_msg; |
| 1015 | 1015 | ||
| 1016 | if (cookie.error) | 1016 | if (cookie.error) |
| 1017 | goto nla_put_failure; | 1017 | goto nla_put_failure; |
| @@ -1022,6 +1022,7 @@ static int nl80211_get_key(struct sk_buff *skb, struct genl_info *info) | |||
| 1022 | 1022 | ||
| 1023 | nla_put_failure: | 1023 | nla_put_failure: |
| 1024 | err = -ENOBUFS; | 1024 | err = -ENOBUFS; |
| 1025 | free_msg: | ||
| 1025 | nlmsg_free(msg); | 1026 | nlmsg_free(msg); |
| 1026 | out: | 1027 | out: |
| 1027 | cfg80211_put_dev(drv); | 1028 | cfg80211_put_dev(drv); |
diff --git a/net/wireless/reg.c b/net/wireless/reg.c index 5e14371cda70..75a406d33619 100644 --- a/net/wireless/reg.c +++ b/net/wireless/reg.c | |||
| @@ -1089,17 +1089,18 @@ static void handle_reg_beacon(struct wiphy *wiphy, | |||
| 1089 | 1089 | ||
| 1090 | chan->beacon_found = true; | 1090 | chan->beacon_found = true; |
| 1091 | 1091 | ||
| 1092 | if (wiphy->disable_beacon_hints) | ||
| 1093 | return; | ||
| 1094 | |||
| 1092 | chan_before.center_freq = chan->center_freq; | 1095 | chan_before.center_freq = chan->center_freq; |
| 1093 | chan_before.flags = chan->flags; | 1096 | chan_before.flags = chan->flags; |
| 1094 | 1097 | ||
| 1095 | if ((chan->flags & IEEE80211_CHAN_PASSIVE_SCAN) && | 1098 | if (chan->flags & IEEE80211_CHAN_PASSIVE_SCAN) { |
| 1096 | !(chan->orig_flags & IEEE80211_CHAN_PASSIVE_SCAN)) { | ||
| 1097 | chan->flags &= ~IEEE80211_CHAN_PASSIVE_SCAN; | 1099 | chan->flags &= ~IEEE80211_CHAN_PASSIVE_SCAN; |
| 1098 | channel_changed = true; | 1100 | channel_changed = true; |
| 1099 | } | 1101 | } |
| 1100 | 1102 | ||
| 1101 | if ((chan->flags & IEEE80211_CHAN_NO_IBSS) && | 1103 | if (chan->flags & IEEE80211_CHAN_NO_IBSS) { |
| 1102 | !(chan->orig_flags & IEEE80211_CHAN_NO_IBSS)) { | ||
| 1103 | chan->flags &= ~IEEE80211_CHAN_NO_IBSS; | 1104 | chan->flags &= ~IEEE80211_CHAN_NO_IBSS; |
| 1104 | channel_changed = true; | 1105 | channel_changed = true; |
| 1105 | } | 1106 | } |
diff --git a/net/wireless/reg.h b/net/wireless/reg.h index e37829a49dc4..4e167a8e11be 100644 --- a/net/wireless/reg.h +++ b/net/wireless/reg.h | |||
| @@ -30,7 +30,8 @@ int set_regdom(const struct ieee80211_regdomain *rd); | |||
| 30 | * non-radar 5 GHz channels. | 30 | * non-radar 5 GHz channels. |
| 31 | * | 31 | * |
| 32 | * Drivers do not need to call this, cfg80211 will do it for after a scan | 32 | * Drivers do not need to call this, cfg80211 will do it for after a scan |
| 33 | * on a newly found BSS. | 33 | * on a newly found BSS. If you cannot make use of this feature you can |
| 34 | * set the wiphy->disable_beacon_hints to true. | ||
| 34 | */ | 35 | */ |
| 35 | int regulatory_hint_found_beacon(struct wiphy *wiphy, | 36 | int regulatory_hint_found_beacon(struct wiphy *wiphy, |
| 36 | struct ieee80211_channel *beacon_chan, | 37 | struct ieee80211_channel *beacon_chan, |
diff --git a/net/wireless/scan.c b/net/wireless/scan.c index f8e71b300001..7e595ce24eeb 100644 --- a/net/wireless/scan.c +++ b/net/wireless/scan.c | |||
| @@ -35,8 +35,6 @@ void cfg80211_scan_done(struct cfg80211_scan_request *request, bool aborted) | |||
| 35 | else | 35 | else |
| 36 | nl80211_send_scan_done(wiphy_to_dev(request->wiphy), dev); | 36 | nl80211_send_scan_done(wiphy_to_dev(request->wiphy), dev); |
| 37 | 37 | ||
| 38 | wiphy_to_dev(request->wiphy)->scan_req = NULL; | ||
| 39 | |||
| 40 | #ifdef CONFIG_WIRELESS_EXT | 38 | #ifdef CONFIG_WIRELESS_EXT |
| 41 | if (!aborted) { | 39 | if (!aborted) { |
| 42 | memset(&wrqu, 0, sizeof(wrqu)); | 40 | memset(&wrqu, 0, sizeof(wrqu)); |
| @@ -48,6 +46,7 @@ void cfg80211_scan_done(struct cfg80211_scan_request *request, bool aborted) | |||
| 48 | dev_put(dev); | 46 | dev_put(dev); |
| 49 | 47 | ||
| 50 | out: | 48 | out: |
| 49 | wiphy_to_dev(request->wiphy)->scan_req = NULL; | ||
| 51 | kfree(request); | 50 | kfree(request); |
| 52 | } | 51 | } |
| 53 | EXPORT_SYMBOL(cfg80211_scan_done); | 52 | EXPORT_SYMBOL(cfg80211_scan_done); |
| @@ -119,7 +118,7 @@ static int cmp_ies(u8 num, u8 *ies1, size_t len1, u8 *ies2, size_t len2) | |||
| 119 | 118 | ||
| 120 | if (!ie1 && !ie2) | 119 | if (!ie1 && !ie2) |
| 121 | return 0; | 120 | return 0; |
| 122 | if (!ie1) | 121 | if (!ie1 || !ie2) |
| 123 | return -1; | 122 | return -1; |
| 124 | 123 | ||
| 125 | r = memcmp(ie1 + 2, ie2 + 2, min(ie1[1], ie2[1])); | 124 | r = memcmp(ie1 + 2, ie2 + 2, min(ie1[1], ie2[1])); |
| @@ -172,6 +171,8 @@ static bool is_mesh(struct cfg80211_bss *a, | |||
| 172 | ie = find_ie(WLAN_EID_MESH_CONFIG, | 171 | ie = find_ie(WLAN_EID_MESH_CONFIG, |
| 173 | a->information_elements, | 172 | a->information_elements, |
| 174 | a->len_information_elements); | 173 | a->len_information_elements); |
| 174 | if (!ie) | ||
| 175 | return false; | ||
| 175 | if (ie[1] != IEEE80211_MESH_CONFIG_LEN) | 176 | if (ie[1] != IEEE80211_MESH_CONFIG_LEN) |
| 176 | return false; | 177 | return false; |
| 177 | 178 | ||
diff --git a/net/xfrm/xfrm_hash.h b/net/xfrm/xfrm_hash.h index d401dc8f05ed..e5195c99f71e 100644 --- a/net/xfrm/xfrm_hash.h +++ b/net/xfrm/xfrm_hash.h | |||
| @@ -16,7 +16,7 @@ static inline unsigned int __xfrm6_addr_hash(xfrm_address_t *addr) | |||
| 16 | 16 | ||
| 17 | static inline unsigned int __xfrm4_daddr_saddr_hash(xfrm_address_t *daddr, xfrm_address_t *saddr) | 17 | static inline unsigned int __xfrm4_daddr_saddr_hash(xfrm_address_t *daddr, xfrm_address_t *saddr) |
| 18 | { | 18 | { |
| 19 | return ntohl(daddr->a4 ^ saddr->a4); | 19 | return ntohl(daddr->a4 + saddr->a4); |
| 20 | } | 20 | } |
| 21 | 21 | ||
| 22 | static inline unsigned int __xfrm6_daddr_saddr_hash(xfrm_address_t *daddr, xfrm_address_t *saddr) | 22 | static inline unsigned int __xfrm6_daddr_saddr_hash(xfrm_address_t *daddr, xfrm_address_t *saddr) |
diff --git a/scripts/get_maintainer.pl b/scripts/get_maintainer.pl index 3e733146cd51..278a45bd45a5 100755 --- a/scripts/get_maintainer.pl +++ b/scripts/get_maintainer.pl | |||
| @@ -13,7 +13,7 @@ | |||
| 13 | use strict; | 13 | use strict; |
| 14 | 14 | ||
| 15 | my $P = $0; | 15 | my $P = $0; |
| 16 | my $V = '0.16'; | 16 | my $V = '0.17'; |
| 17 | 17 | ||
| 18 | use Getopt::Long qw(:config no_auto_abbrev); | 18 | use Getopt::Long qw(:config no_auto_abbrev); |
| 19 | 19 | ||
| @@ -27,6 +27,7 @@ my $email_git = 1; | |||
| 27 | my $email_git_penguin_chiefs = 0; | 27 | my $email_git_penguin_chiefs = 0; |
| 28 | my $email_git_min_signatures = 1; | 28 | my $email_git_min_signatures = 1; |
| 29 | my $email_git_max_maintainers = 5; | 29 | my $email_git_max_maintainers = 5; |
| 30 | my $email_git_min_percent = 5; | ||
| 30 | my $email_git_since = "1-year-ago"; | 31 | my $email_git_since = "1-year-ago"; |
| 31 | my $output_multiline = 1; | 32 | my $output_multiline = 1; |
| 32 | my $output_separator = ", "; | 33 | my $output_separator = ", "; |
| @@ -65,6 +66,7 @@ if (!GetOptions( | |||
| 65 | 'git-chief-penguins!' => \$email_git_penguin_chiefs, | 66 | 'git-chief-penguins!' => \$email_git_penguin_chiefs, |
| 66 | 'git-min-signatures=i' => \$email_git_min_signatures, | 67 | 'git-min-signatures=i' => \$email_git_min_signatures, |
| 67 | 'git-max-maintainers=i' => \$email_git_max_maintainers, | 68 | 'git-max-maintainers=i' => \$email_git_max_maintainers, |
| 69 | 'git-min-percent=i' => \$email_git_min_percent, | ||
| 68 | 'git-since=s' => \$email_git_since, | 70 | 'git-since=s' => \$email_git_since, |
| 69 | 'm!' => \$email_maintainer, | 71 | 'm!' => \$email_maintainer, |
| 70 | 'n!' => \$email_usename, | 72 | 'n!' => \$email_usename, |
| @@ -132,6 +134,10 @@ while (<MAINT>) { | |||
| 132 | $value =~ s@\.@\\\.@g; ##Convert . to \. | 134 | $value =~ s@\.@\\\.@g; ##Convert . to \. |
| 133 | $value =~ s/\*/\.\*/g; ##Convert * to .* | 135 | $value =~ s/\*/\.\*/g; ##Convert * to .* |
| 134 | $value =~ s/\?/\./g; ##Convert ? to . | 136 | $value =~ s/\?/\./g; ##Convert ? to . |
| 137 | ##if pattern is a directory and it lacks a trailing slash, add one | ||
| 138 | if ((-d $value)) { | ||
| 139 | $value =~ s@([^/])$@$1/@; | ||
| 140 | } | ||
| 135 | } | 141 | } |
| 136 | push(@typevalue, "$type:$value"); | 142 | push(@typevalue, "$type:$value"); |
| 137 | } elsif (!/^(\s)*$/) { | 143 | } elsif (!/^(\s)*$/) { |
| @@ -146,8 +152,10 @@ close(MAINT); | |||
| 146 | my @files = (); | 152 | my @files = (); |
| 147 | 153 | ||
| 148 | foreach my $file (@ARGV) { | 154 | foreach my $file (@ARGV) { |
| 149 | next if ((-d $file)); | 155 | ##if $file is a directory and it lacks a trailing slash, add one |
| 150 | if (!(-f $file)) { | 156 | if ((-d $file)) { |
| 157 | $file =~ s@([^/])$@$1/@; | ||
| 158 | } elsif (!(-f $file)) { | ||
| 151 | die "$P: file '${file}' not found\n"; | 159 | die "$P: file '${file}' not found\n"; |
| 152 | } | 160 | } |
| 153 | if ($from_filename) { | 161 | if ($from_filename) { |
| @@ -292,7 +300,7 @@ sub file_match_pattern { | |||
| 292 | sub usage { | 300 | sub usage { |
| 293 | print <<EOT; | 301 | print <<EOT; |
| 294 | usage: $P [options] patchfile | 302 | usage: $P [options] patchfile |
| 295 | $P [options] -f file | 303 | $P [options] -f file|directory |
| 296 | version: $V | 304 | version: $V |
| 297 | 305 | ||
| 298 | MAINTAINER field selection options: | 306 | MAINTAINER field selection options: |
| @@ -301,6 +309,7 @@ MAINTAINER field selection options: | |||
| 301 | --git-chief-penguins => include ${penguin_chiefs} | 309 | --git-chief-penguins => include ${penguin_chiefs} |
| 302 | --git-min-signatures => number of signatures required (default: 1) | 310 | --git-min-signatures => number of signatures required (default: 1) |
| 303 | --git-max-maintainers => maximum maintainers to add (default: 5) | 311 | --git-max-maintainers => maximum maintainers to add (default: 5) |
| 312 | --git-min-percent => minimum percentage of commits required (default: 5) | ||
| 304 | --git-since => git history to use (default: 1-year-ago) | 313 | --git-since => git history to use (default: 1-year-ago) |
| 305 | --m => include maintainer(s) if any | 314 | --m => include maintainer(s) if any |
| 306 | --n => include name 'Full Name <addr\@domain.tld>' | 315 | --n => include name 'Full Name <addr\@domain.tld>' |
| @@ -322,6 +331,15 @@ Other options: | |||
| 322 | --version => show version | 331 | --version => show version |
| 323 | --help => show this help information | 332 | --help => show this help information |
| 324 | 333 | ||
| 334 | Notes: | ||
| 335 | Using "-f directory" may give unexpected results: | ||
| 336 | |||
| 337 | Used with "--git", git signators for _all_ files in and below | ||
| 338 | directory are examined as git recurses directories. | ||
| 339 | Any specified X: (exclude) pattern matches are _not_ ignored. | ||
| 340 | Used with "--nogit", directory is used as a pattern match, | ||
| 341 | no individual file within the directory or subdirectory | ||
| 342 | is matched. | ||
| 325 | EOT | 343 | EOT |
| 326 | } | 344 | } |
| 327 | 345 | ||
| @@ -482,6 +500,7 @@ sub recent_git_signoffs { | |||
| 482 | my $output = ""; | 500 | my $output = ""; |
| 483 | my $count = 0; | 501 | my $count = 0; |
| 484 | my @lines = (); | 502 | my @lines = (); |
| 503 | my $total_sign_offs; | ||
| 485 | 504 | ||
| 486 | if (which("git") eq "") { | 505 | if (which("git") eq "") { |
| 487 | warn("$P: git not found. Add --nogit to options?\n"); | 506 | warn("$P: git not found. Add --nogit to options?\n"); |
| @@ -505,17 +524,26 @@ sub recent_git_signoffs { | |||
| 505 | $output =~ s/^\s*//gm; | 524 | $output =~ s/^\s*//gm; |
| 506 | 525 | ||
| 507 | @lines = split("\n", $output); | 526 | @lines = split("\n", $output); |
| 527 | |||
| 528 | $total_sign_offs = 0; | ||
| 529 | foreach my $line (@lines) { | ||
| 530 | if ($line =~ m/([0-9]+)\s+(.*)/) { | ||
| 531 | $total_sign_offs += $1; | ||
| 532 | } else { | ||
| 533 | die("$P: Unexpected git output: ${line}\n"); | ||
| 534 | } | ||
| 535 | } | ||
| 536 | |||
| 508 | foreach my $line (@lines) { | 537 | foreach my $line (@lines) { |
| 509 | if ($line =~ m/([0-9]+)\s+(.*)/) { | 538 | if ($line =~ m/([0-9]+)\s+(.*)/) { |
| 510 | my $sign_offs = $1; | 539 | my $sign_offs = $1; |
| 511 | $line = $2; | 540 | $line = $2; |
| 512 | $count++; | 541 | $count++; |
| 513 | if ($sign_offs < $email_git_min_signatures || | 542 | if ($sign_offs < $email_git_min_signatures || |
| 514 | $count > $email_git_max_maintainers) { | 543 | $count > $email_git_max_maintainers || |
| 544 | $sign_offs * 100 / $total_sign_offs < $email_git_min_percent) { | ||
| 515 | last; | 545 | last; |
| 516 | } | 546 | } |
| 517 | } else { | ||
| 518 | die("$P: Unexpected git output: ${line}\n"); | ||
| 519 | } | 547 | } |
| 520 | if ($line =~ m/(.+)<(.+)>/) { | 548 | if ($line =~ m/(.+)<(.+)>/) { |
| 521 | my $git_name = $1; | 549 | my $git_name = $1; |
diff --git a/scripts/markup_oops.pl b/scripts/markup_oops.pl index 528492bcba5b..89774011965d 100644 --- a/scripts/markup_oops.pl +++ b/scripts/markup_oops.pl | |||
| @@ -1,6 +1,7 @@ | |||
| 1 | #!/usr/bin/perl | 1 | #!/usr/bin/perl |
| 2 | 2 | ||
| 3 | use File::Basename; | 3 | use File::Basename; |
| 4 | use Math::BigInt; | ||
| 4 | 5 | ||
| 5 | # Copyright 2008, Intel Corporation | 6 | # Copyright 2008, Intel Corporation |
| 6 | # | 7 | # |
| @@ -172,8 +173,8 @@ while (<STDIN>) { | |||
| 172 | parse_x86_regs($line); | 173 | parse_x86_regs($line); |
| 173 | } | 174 | } |
| 174 | 175 | ||
| 175 | my $decodestart = hex($target) - hex($func_offset); | 176 | my $decodestart = Math::BigInt->from_hex("0x$target") - Math::BigInt->from_hex("0x$func_offset"); |
| 176 | my $decodestop = hex($target) + 8192; | 177 | my $decodestop = Math::BigInt->from_hex("0x$target") + 8192; |
| 177 | if ($target eq "0") { | 178 | if ($target eq "0") { |
| 178 | print "No oops found!\n"; | 179 | print "No oops found!\n"; |
| 179 | print "Usage: \n"; | 180 | print "Usage: \n"; |
diff --git a/scripts/recordmcount.pl b/scripts/recordmcount.pl index 7109e2b5bc0a..911ba7ffab84 100755 --- a/scripts/recordmcount.pl +++ b/scripts/recordmcount.pl | |||
| @@ -393,7 +393,7 @@ while (<IN>) { | |||
| 393 | $read_function = 0; | 393 | $read_function = 0; |
| 394 | } | 394 | } |
| 395 | # print out any recorded offsets | 395 | # print out any recorded offsets |
| 396 | update_funcs() if ($text_found); | 396 | update_funcs() if (defined($ref_func)); |
| 397 | 397 | ||
| 398 | # reset all markers and arrays | 398 | # reset all markers and arrays |
| 399 | $text_found = 0; | 399 | $text_found = 0; |
| @@ -403,7 +403,6 @@ while (<IN>) { | |||
| 403 | # section found, now is this a start of a function? | 403 | # section found, now is this a start of a function? |
| 404 | } elsif ($read_function && /$function_regex/) { | 404 | } elsif ($read_function && /$function_regex/) { |
| 405 | $text_found = 1; | 405 | $text_found = 1; |
| 406 | $offset = hex $1; | ||
| 407 | $text = $2; | 406 | $text = $2; |
| 408 | 407 | ||
| 409 | # if this is either a local function or a weak function | 408 | # if this is either a local function or a weak function |
| @@ -412,10 +411,15 @@ while (<IN>) { | |||
| 412 | if (!defined($locals{$text}) && !defined($weak{$text})) { | 411 | if (!defined($locals{$text}) && !defined($weak{$text})) { |
| 413 | $ref_func = $text; | 412 | $ref_func = $text; |
| 414 | $read_function = 0; | 413 | $read_function = 0; |
| 414 | $offset = hex $1; | ||
| 415 | } else { | 415 | } else { |
| 416 | # if we already have a function, and this is weak, skip it | 416 | # if we already have a function, and this is weak, skip it |
| 417 | if (!defined($ref_func) || !defined($weak{$text})) { | 417 | if (!defined($ref_func) && !defined($weak{$text}) && |
| 418 | # PPC64 can have symbols that start with .L and | ||
| 419 | # gcc considers these special. Don't use them! | ||
| 420 | $text !~ /^\.L/) { | ||
| 418 | $ref_func = $text; | 421 | $ref_func = $text; |
| 422 | $offset = hex $1; | ||
| 419 | } | 423 | } |
| 420 | } | 424 | } |
| 421 | } elsif ($read_headers && /$mcount_section/) { | 425 | } elsif ($read_headers && /$mcount_section/) { |
| @@ -440,7 +444,7 @@ while (<IN>) { | |||
| 440 | } | 444 | } |
| 441 | 445 | ||
| 442 | # dump out anymore offsets that may have been found | 446 | # dump out anymore offsets that may have been found |
| 443 | update_funcs() if ($text_found); | 447 | update_funcs() if (defined($ref_func)); |
| 444 | 448 | ||
| 445 | # If we did not find any mcount callers, we are done (do nothing). | 449 | # If we did not find any mcount callers, we are done (do nothing). |
| 446 | if (!$opened) { | 450 | if (!$opened) { |
diff --git a/security/Kconfig b/security/Kconfig index 5721847a7a62..fb363cd81cf6 100644 --- a/security/Kconfig +++ b/security/Kconfig | |||
| @@ -143,6 +143,22 @@ config INTEL_TXT | |||
| 143 | 143 | ||
| 144 | If you are unsure as to whether this is required, answer N. | 144 | If you are unsure as to whether this is required, answer N. |
| 145 | 145 | ||
| 146 | config LSM_MMAP_MIN_ADDR | ||
| 147 | int "Low address space for LSM to protect from user allocation" | ||
| 148 | depends on SECURITY && SECURITY_SELINUX | ||
| 149 | default 65536 | ||
| 150 | help | ||
| 151 | This is the portion of low virtual memory which should be protected | ||
| 152 | from userspace allocation. Keeping a user from writing to low pages | ||
| 153 | can help reduce the impact of kernel NULL pointer bugs. | ||
| 154 | |||
| 155 | For most ia64, ppc64 and x86 users with lots of address space | ||
| 156 | a value of 65536 is reasonable and should cause no problems. | ||
| 157 | On arm and other archs it should not be higher than 32768. | ||
| 158 | Programs which use vm86 functionality or have some need to map | ||
| 159 | this low address space will need the permission specific to the | ||
| 160 | systems running LSM. | ||
| 161 | |||
| 146 | source security/selinux/Kconfig | 162 | source security/selinux/Kconfig |
| 147 | source security/smack/Kconfig | 163 | source security/smack/Kconfig |
| 148 | source security/tomoyo/Kconfig | 164 | source security/tomoyo/Kconfig |
diff --git a/security/Makefile b/security/Makefile index c67557cdaa85..b56e7f9ecbc2 100644 --- a/security/Makefile +++ b/security/Makefile | |||
| @@ -8,7 +8,7 @@ subdir-$(CONFIG_SECURITY_SMACK) += smack | |||
| 8 | subdir-$(CONFIG_SECURITY_TOMOYO) += tomoyo | 8 | subdir-$(CONFIG_SECURITY_TOMOYO) += tomoyo |
| 9 | 9 | ||
| 10 | # always enable default capabilities | 10 | # always enable default capabilities |
| 11 | obj-y += commoncap.o | 11 | obj-y += commoncap.o min_addr.o |
| 12 | 12 | ||
| 13 | # Object file lists | 13 | # Object file lists |
| 14 | obj-$(CONFIG_SECURITY) += security.o capability.o | 14 | obj-$(CONFIG_SECURITY) += security.o capability.o |
diff --git a/security/capability.c b/security/capability.c index 21b6cead6a8e..88f752e8152c 100644 --- a/security/capability.c +++ b/security/capability.c | |||
| @@ -330,15 +330,6 @@ static int cap_file_ioctl(struct file *file, unsigned int command, | |||
| 330 | return 0; | 330 | return 0; |
| 331 | } | 331 | } |
| 332 | 332 | ||
| 333 | static int cap_file_mmap(struct file *file, unsigned long reqprot, | ||
| 334 | unsigned long prot, unsigned long flags, | ||
| 335 | unsigned long addr, unsigned long addr_only) | ||
| 336 | { | ||
| 337 | if ((addr < mmap_min_addr) && !capable(CAP_SYS_RAWIO)) | ||
| 338 | return -EACCES; | ||
| 339 | return 0; | ||
| 340 | } | ||
| 341 | |||
| 342 | static int cap_file_mprotect(struct vm_area_struct *vma, unsigned long reqprot, | 333 | static int cap_file_mprotect(struct vm_area_struct *vma, unsigned long reqprot, |
| 343 | unsigned long prot) | 334 | unsigned long prot) |
| 344 | { | 335 | { |
diff --git a/security/commoncap.c b/security/commoncap.c index 48b7e0228fa3..e3097c0a1311 100644 --- a/security/commoncap.c +++ b/security/commoncap.c | |||
| @@ -984,3 +984,33 @@ int cap_vm_enough_memory(struct mm_struct *mm, long pages) | |||
| 984 | cap_sys_admin = 1; | 984 | cap_sys_admin = 1; |
| 985 | return __vm_enough_memory(mm, pages, cap_sys_admin); | 985 | return __vm_enough_memory(mm, pages, cap_sys_admin); |
| 986 | } | 986 | } |
| 987 | |||
| 988 | /* | ||
| 989 | * cap_file_mmap - check if able to map given addr | ||
| 990 | * @file: unused | ||
| 991 | * @reqprot: unused | ||
| 992 | * @prot: unused | ||
| 993 | * @flags: unused | ||
| 994 | * @addr: address attempting to be mapped | ||
| 995 | * @addr_only: unused | ||
| 996 | * | ||
| 997 | * If the process is attempting to map memory below mmap_min_addr they need | ||
| 998 | * CAP_SYS_RAWIO. The other parameters to this function are unused by the | ||
| 999 | * capability security module. Returns 0 if this mapping should be allowed | ||
| 1000 | * -EPERM if not. | ||
| 1001 | */ | ||
| 1002 | int cap_file_mmap(struct file *file, unsigned long reqprot, | ||
| 1003 | unsigned long prot, unsigned long flags, | ||
| 1004 | unsigned long addr, unsigned long addr_only) | ||
| 1005 | { | ||
| 1006 | int ret = 0; | ||
| 1007 | |||
| 1008 | if (addr < dac_mmap_min_addr) { | ||
| 1009 | ret = cap_capable(current, current_cred(), CAP_SYS_RAWIO, | ||
| 1010 | SECURITY_CAP_AUDIT); | ||
| 1011 | /* set PF_SUPERPRIV if it turns out we allow the low mmap */ | ||
| 1012 | if (ret == 0) | ||
| 1013 | current->flags |= PF_SUPERPRIV; | ||
| 1014 | } | ||
| 1015 | return ret; | ||
| 1016 | } | ||
diff --git a/security/integrity/ima/ima_crypto.c b/security/integrity/ima/ima_crypto.c index 63003a63aaee..46642a19bc78 100644 --- a/security/integrity/ima/ima_crypto.c +++ b/security/integrity/ima/ima_crypto.c | |||
| @@ -45,9 +45,9 @@ int ima_calc_hash(struct file *file, char *digest) | |||
| 45 | { | 45 | { |
| 46 | struct hash_desc desc; | 46 | struct hash_desc desc; |
| 47 | struct scatterlist sg[1]; | 47 | struct scatterlist sg[1]; |
| 48 | loff_t i_size; | 48 | loff_t i_size, offset = 0; |
| 49 | char *rbuf; | 49 | char *rbuf; |
| 50 | int rc, offset = 0; | 50 | int rc; |
| 51 | 51 | ||
| 52 | rc = init_desc(&desc); | 52 | rc = init_desc(&desc); |
| 53 | if (rc != 0) | 53 | if (rc != 0) |
| @@ -67,6 +67,8 @@ int ima_calc_hash(struct file *file, char *digest) | |||
| 67 | rc = rbuf_len; | 67 | rc = rbuf_len; |
| 68 | break; | 68 | break; |
| 69 | } | 69 | } |
| 70 | if (rbuf_len == 0) | ||
| 71 | break; | ||
| 70 | offset += rbuf_len; | 72 | offset += rbuf_len; |
| 71 | sg_init_one(sg, rbuf, rbuf_len); | 73 | sg_init_one(sg, rbuf, rbuf_len); |
| 72 | 74 | ||
diff --git a/security/integrity/ima/ima_main.c b/security/integrity/ima/ima_main.c index 101c512564ec..4732f5e5d127 100644 --- a/security/integrity/ima/ima_main.c +++ b/security/integrity/ima/ima_main.c | |||
| @@ -262,6 +262,8 @@ void ima_counts_put(struct path *path, int mask) | |||
| 262 | else if (mask & (MAY_READ | MAY_EXEC)) | 262 | else if (mask & (MAY_READ | MAY_EXEC)) |
| 263 | iint->readcount--; | 263 | iint->readcount--; |
| 264 | mutex_unlock(&iint->mutex); | 264 | mutex_unlock(&iint->mutex); |
| 265 | |||
| 266 | kref_put(&iint->refcount, iint_free); | ||
| 265 | } | 267 | } |
| 266 | 268 | ||
| 267 | /* | 269 | /* |
| @@ -291,6 +293,8 @@ void ima_counts_get(struct file *file) | |||
| 291 | if (file->f_mode & FMODE_WRITE) | 293 | if (file->f_mode & FMODE_WRITE) |
| 292 | iint->writecount++; | 294 | iint->writecount++; |
| 293 | mutex_unlock(&iint->mutex); | 295 | mutex_unlock(&iint->mutex); |
| 296 | |||
| 297 | kref_put(&iint->refcount, iint_free); | ||
| 294 | } | 298 | } |
| 295 | EXPORT_SYMBOL_GPL(ima_counts_get); | 299 | EXPORT_SYMBOL_GPL(ima_counts_get); |
| 296 | 300 | ||
diff --git a/security/min_addr.c b/security/min_addr.c new file mode 100644 index 000000000000..14cc7b3b8d03 --- /dev/null +++ b/security/min_addr.c | |||
| @@ -0,0 +1,49 @@ | |||
| 1 | #include <linux/init.h> | ||
| 2 | #include <linux/mm.h> | ||
| 3 | #include <linux/security.h> | ||
| 4 | #include <linux/sysctl.h> | ||
| 5 | |||
| 6 | /* amount of vm to protect from userspace access by both DAC and the LSM*/ | ||
| 7 | unsigned long mmap_min_addr; | ||
| 8 | /* amount of vm to protect from userspace using CAP_SYS_RAWIO (DAC) */ | ||
| 9 | unsigned long dac_mmap_min_addr = CONFIG_DEFAULT_MMAP_MIN_ADDR; | ||
| 10 | /* amount of vm to protect from userspace using the LSM = CONFIG_LSM_MMAP_MIN_ADDR */ | ||
| 11 | |||
| 12 | /* | ||
| 13 | * Update mmap_min_addr = max(dac_mmap_min_addr, CONFIG_LSM_MMAP_MIN_ADDR) | ||
| 14 | */ | ||
| 15 | static void update_mmap_min_addr(void) | ||
| 16 | { | ||
| 17 | #ifdef CONFIG_LSM_MMAP_MIN_ADDR | ||
| 18 | if (dac_mmap_min_addr > CONFIG_LSM_MMAP_MIN_ADDR) | ||
| 19 | mmap_min_addr = dac_mmap_min_addr; | ||
| 20 | else | ||
| 21 | mmap_min_addr = CONFIG_LSM_MMAP_MIN_ADDR; | ||
| 22 | #else | ||
| 23 | mmap_min_addr = dac_mmap_min_addr; | ||
| 24 | #endif | ||
| 25 | } | ||
| 26 | |||
| 27 | /* | ||
| 28 | * sysctl handler which just sets dac_mmap_min_addr = the new value and then | ||
| 29 | * calls update_mmap_min_addr() so non MAP_FIXED hints get rounded properly | ||
| 30 | */ | ||
| 31 | int mmap_min_addr_handler(struct ctl_table *table, int write, struct file *filp, | ||
| 32 | void __user *buffer, size_t *lenp, loff_t *ppos) | ||
| 33 | { | ||
| 34 | int ret; | ||
| 35 | |||
| 36 | ret = proc_doulongvec_minmax(table, write, filp, buffer, lenp, ppos); | ||
| 37 | |||
| 38 | update_mmap_min_addr(); | ||
| 39 | |||
| 40 | return ret; | ||
| 41 | } | ||
| 42 | |||
| 43 | int __init init_mmap_min_addr(void) | ||
| 44 | { | ||
| 45 | update_mmap_min_addr(); | ||
| 46 | |||
| 47 | return 0; | ||
| 48 | } | ||
| 49 | pure_initcall(init_mmap_min_addr); | ||
diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c index 15c2a08a66f1..8d8b69c5664e 100644 --- a/security/selinux/hooks.c +++ b/security/selinux/hooks.c | |||
| @@ -1285,6 +1285,8 @@ static int inode_doinit_with_dentry(struct inode *inode, struct dentry *opt_dent | |||
| 1285 | rc = inode->i_op->getxattr(dentry, XATTR_NAME_SELINUX, | 1285 | rc = inode->i_op->getxattr(dentry, XATTR_NAME_SELINUX, |
| 1286 | context, len); | 1286 | context, len); |
| 1287 | if (rc == -ERANGE) { | 1287 | if (rc == -ERANGE) { |
| 1288 | kfree(context); | ||
| 1289 | |||
| 1288 | /* Need a larger buffer. Query for the right size. */ | 1290 | /* Need a larger buffer. Query for the right size. */ |
| 1289 | rc = inode->i_op->getxattr(dentry, XATTR_NAME_SELINUX, | 1291 | rc = inode->i_op->getxattr(dentry, XATTR_NAME_SELINUX, |
| 1290 | NULL, 0); | 1292 | NULL, 0); |
| @@ -1292,7 +1294,6 @@ static int inode_doinit_with_dentry(struct inode *inode, struct dentry *opt_dent | |||
| 1292 | dput(dentry); | 1294 | dput(dentry); |
| 1293 | goto out_unlock; | 1295 | goto out_unlock; |
| 1294 | } | 1296 | } |
| 1295 | kfree(context); | ||
| 1296 | len = rc; | 1297 | len = rc; |
| 1297 | context = kmalloc(len+1, GFP_NOFS); | 1298 | context = kmalloc(len+1, GFP_NOFS); |
| 1298 | if (!context) { | 1299 | if (!context) { |
| @@ -3029,9 +3030,21 @@ static int selinux_file_mmap(struct file *file, unsigned long reqprot, | |||
| 3029 | int rc = 0; | 3030 | int rc = 0; |
| 3030 | u32 sid = current_sid(); | 3031 | u32 sid = current_sid(); |
| 3031 | 3032 | ||
| 3032 | if (addr < mmap_min_addr) | 3033 | /* |
| 3034 | * notice that we are intentionally putting the SELinux check before | ||
| 3035 | * the secondary cap_file_mmap check. This is such a likely attempt | ||
| 3036 | * at bad behaviour/exploit that we always want to get the AVC, even | ||
| 3037 | * if DAC would have also denied the operation. | ||
| 3038 | */ | ||
| 3039 | if (addr < CONFIG_LSM_MMAP_MIN_ADDR) { | ||
| 3033 | rc = avc_has_perm(sid, sid, SECCLASS_MEMPROTECT, | 3040 | rc = avc_has_perm(sid, sid, SECCLASS_MEMPROTECT, |
| 3034 | MEMPROTECT__MMAP_ZERO, NULL); | 3041 | MEMPROTECT__MMAP_ZERO, NULL); |
| 3042 | if (rc) | ||
| 3043 | return rc; | ||
| 3044 | } | ||
| 3045 | |||
| 3046 | /* do DAC check on address space usage */ | ||
| 3047 | rc = cap_file_mmap(file, reqprot, prot, flags, addr, addr_only); | ||
| 3035 | if (rc || addr_only) | 3048 | if (rc || addr_only) |
| 3036 | return rc; | 3049 | return rc; |
| 3037 | 3050 | ||
diff --git a/sound/aoa/core/gpio-pmf.c b/sound/aoa/core/gpio-pmf.c index 5ca2220eac7d..1dd0c28d1fb7 100644 --- a/sound/aoa/core/gpio-pmf.c +++ b/sound/aoa/core/gpio-pmf.c | |||
| @@ -182,6 +182,10 @@ static int pmf_set_notify(struct gpio_runtime *rt, | |||
| 182 | if (!old && notify) { | 182 | if (!old && notify) { |
| 183 | irq_client = kzalloc(sizeof(struct pmf_irq_client), | 183 | irq_client = kzalloc(sizeof(struct pmf_irq_client), |
| 184 | GFP_KERNEL); | 184 | GFP_KERNEL); |
| 185 | if (!irq_client) { | ||
| 186 | err = -ENOMEM; | ||
| 187 | goto out_unlock; | ||
| 188 | } | ||
| 185 | irq_client->data = notif; | 189 | irq_client->data = notif; |
| 186 | irq_client->handler = pmf_handle_notify_irq; | 190 | irq_client->handler = pmf_handle_notify_irq; |
| 187 | irq_client->owner = THIS_MODULE; | 191 | irq_client->owner = THIS_MODULE; |
diff --git a/sound/core/pcm_lib.c b/sound/core/pcm_lib.c index 333e4dd29450..9db60d831bb2 100644 --- a/sound/core/pcm_lib.c +++ b/sound/core/pcm_lib.c | |||
| @@ -233,6 +233,18 @@ static int snd_pcm_update_hw_ptr_interrupt(struct snd_pcm_substream *substream) | |||
| 233 | xrun(substream); | 233 | xrun(substream); |
| 234 | return -EPIPE; | 234 | return -EPIPE; |
| 235 | } | 235 | } |
| 236 | if (xrun_debug(substream, 8)) { | ||
| 237 | char name[16]; | ||
| 238 | pcm_debug_name(substream, name, sizeof(name)); | ||
| 239 | snd_printd("period_update: %s: pos=0x%x/0x%x/0x%x, " | ||
| 240 | "hwptr=0x%lx, hw_base=0x%lx, hw_intr=0x%lx\n", | ||
| 241 | name, (unsigned int)pos, | ||
| 242 | (unsigned int)runtime->period_size, | ||
| 243 | (unsigned int)runtime->buffer_size, | ||
| 244 | (unsigned long)old_hw_ptr, | ||
| 245 | (unsigned long)runtime->hw_ptr_base, | ||
| 246 | (unsigned long)runtime->hw_ptr_interrupt); | ||
| 247 | } | ||
| 236 | hw_base = runtime->hw_ptr_base; | 248 | hw_base = runtime->hw_ptr_base; |
| 237 | new_hw_ptr = hw_base + pos; | 249 | new_hw_ptr = hw_base + pos; |
| 238 | hw_ptr_interrupt = runtime->hw_ptr_interrupt + runtime->period_size; | 250 | hw_ptr_interrupt = runtime->hw_ptr_interrupt + runtime->period_size; |
| @@ -244,18 +256,27 @@ static int snd_pcm_update_hw_ptr_interrupt(struct snd_pcm_substream *substream) | |||
| 244 | delta = new_hw_ptr - hw_ptr_interrupt; | 256 | delta = new_hw_ptr - hw_ptr_interrupt; |
| 245 | } | 257 | } |
| 246 | if (delta < 0) { | 258 | if (delta < 0) { |
| 247 | delta += runtime->buffer_size; | 259 | if (runtime->periods == 1 || new_hw_ptr < old_hw_ptr) |
| 260 | delta += runtime->buffer_size; | ||
| 248 | if (delta < 0) { | 261 | if (delta < 0) { |
| 249 | hw_ptr_error(substream, | 262 | hw_ptr_error(substream, |
| 250 | "Unexpected hw_pointer value " | 263 | "Unexpected hw_pointer value " |
| 251 | "(stream=%i, pos=%ld, intr_ptr=%ld)\n", | 264 | "(stream=%i, pos=%ld, intr_ptr=%ld)\n", |
| 252 | substream->stream, (long)pos, | 265 | substream->stream, (long)pos, |
| 253 | (long)hw_ptr_interrupt); | 266 | (long)hw_ptr_interrupt); |
| 267 | #if 1 | ||
| 268 | /* simply skipping the hwptr update seems more | ||
| 269 | * robust in some cases, e.g. on VMware with | ||
| 270 | * inaccurate timer source | ||
| 271 | */ | ||
| 272 | return 0; /* skip this update */ | ||
| 273 | #else | ||
| 254 | /* rebase to interrupt position */ | 274 | /* rebase to interrupt position */ |
| 255 | hw_base = new_hw_ptr = hw_ptr_interrupt; | 275 | hw_base = new_hw_ptr = hw_ptr_interrupt; |
| 256 | /* align hw_base to buffer_size */ | 276 | /* align hw_base to buffer_size */ |
| 257 | hw_base -= hw_base % runtime->buffer_size; | 277 | hw_base -= hw_base % runtime->buffer_size; |
| 258 | delta = 0; | 278 | delta = 0; |
| 279 | #endif | ||
| 259 | } else { | 280 | } else { |
| 260 | hw_base += runtime->buffer_size; | 281 | hw_base += runtime->buffer_size; |
| 261 | if (hw_base >= runtime->boundary) | 282 | if (hw_base >= runtime->boundary) |
| @@ -344,6 +365,19 @@ int snd_pcm_update_hw_ptr(struct snd_pcm_substream *substream) | |||
| 344 | xrun(substream); | 365 | xrun(substream); |
| 345 | return -EPIPE; | 366 | return -EPIPE; |
| 346 | } | 367 | } |
| 368 | if (xrun_debug(substream, 16)) { | ||
| 369 | char name[16]; | ||
| 370 | pcm_debug_name(substream, name, sizeof(name)); | ||
| 371 | snd_printd("hw_update: %s: pos=0x%x/0x%x/0x%x, " | ||
| 372 | "hwptr=0x%lx, hw_base=0x%lx, hw_intr=0x%lx\n", | ||
| 373 | name, (unsigned int)pos, | ||
| 374 | (unsigned int)runtime->period_size, | ||
| 375 | (unsigned int)runtime->buffer_size, | ||
| 376 | (unsigned long)old_hw_ptr, | ||
| 377 | (unsigned long)runtime->hw_ptr_base, | ||
| 378 | (unsigned long)runtime->hw_ptr_interrupt); | ||
| 379 | } | ||
| 380 | |||
| 347 | hw_base = runtime->hw_ptr_base; | 381 | hw_base = runtime->hw_ptr_base; |
| 348 | new_hw_ptr = hw_base + pos; | 382 | new_hw_ptr = hw_base + pos; |
| 349 | 383 | ||
| @@ -909,47 +943,24 @@ static int snd_interval_ratden(struct snd_interval *i, | |||
| 909 | int snd_interval_list(struct snd_interval *i, unsigned int count, unsigned int *list, unsigned int mask) | 943 | int snd_interval_list(struct snd_interval *i, unsigned int count, unsigned int *list, unsigned int mask) |
| 910 | { | 944 | { |
| 911 | unsigned int k; | 945 | unsigned int k; |
| 912 | int changed = 0; | 946 | struct snd_interval list_range; |
| 913 | 947 | ||
| 914 | if (!count) { | 948 | if (!count) { |
| 915 | i->empty = 1; | 949 | i->empty = 1; |
| 916 | return -EINVAL; | 950 | return -EINVAL; |
| 917 | } | 951 | } |
| 952 | snd_interval_any(&list_range); | ||
| 953 | list_range.min = UINT_MAX; | ||
| 954 | list_range.max = 0; | ||
| 918 | for (k = 0; k < count; k++) { | 955 | for (k = 0; k < count; k++) { |
| 919 | if (mask && !(mask & (1 << k))) | 956 | if (mask && !(mask & (1 << k))) |
| 920 | continue; | 957 | continue; |
| 921 | if (i->min == list[k] && !i->openmin) | 958 | if (!snd_interval_test(i, list[k])) |
| 922 | goto _l1; | ||
| 923 | if (i->min < list[k]) { | ||
| 924 | i->min = list[k]; | ||
| 925 | i->openmin = 0; | ||
| 926 | changed = 1; | ||
| 927 | goto _l1; | ||
| 928 | } | ||
| 929 | } | ||
| 930 | i->empty = 1; | ||
| 931 | return -EINVAL; | ||
| 932 | _l1: | ||
| 933 | for (k = count; k-- > 0;) { | ||
| 934 | if (mask && !(mask & (1 << k))) | ||
| 935 | continue; | 959 | continue; |
| 936 | if (i->max == list[k] && !i->openmax) | 960 | list_range.min = min(list_range.min, list[k]); |
| 937 | goto _l2; | 961 | list_range.max = max(list_range.max, list[k]); |
| 938 | if (i->max > list[k]) { | ||
| 939 | i->max = list[k]; | ||
| 940 | i->openmax = 0; | ||
| 941 | changed = 1; | ||
| 942 | goto _l2; | ||
| 943 | } | ||
| 944 | } | 962 | } |
| 945 | i->empty = 1; | 963 | return snd_interval_refine(i, &list_range); |
| 946 | return -EINVAL; | ||
| 947 | _l2: | ||
| 948 | if (snd_interval_checkempty(i)) { | ||
| 949 | i->empty = 1; | ||
| 950 | return -EINVAL; | ||
| 951 | } | ||
| 952 | return changed; | ||
| 953 | } | 964 | } |
| 954 | 965 | ||
| 955 | EXPORT_SYMBOL(snd_interval_list); | 966 | EXPORT_SYMBOL(snd_interval_list); |
diff --git a/sound/core/seq/Makefile b/sound/core/seq/Makefile index 1bcb360330e5..941f64a853eb 100644 --- a/sound/core/seq/Makefile +++ b/sound/core/seq/Makefile | |||
| @@ -3,10 +3,6 @@ | |||
| 3 | # Copyright (c) 1999 by Jaroslav Kysela <perex@perex.cz> | 3 | # Copyright (c) 1999 by Jaroslav Kysela <perex@perex.cz> |
| 4 | # | 4 | # |
| 5 | 5 | ||
| 6 | ifeq ($(CONFIG_SND_SEQUENCER_OSS),y) | ||
| 7 | obj-$(CONFIG_SND_SEQUENCER) += oss/ | ||
| 8 | endif | ||
| 9 | |||
| 10 | snd-seq-device-objs := seq_device.o | 6 | snd-seq-device-objs := seq_device.o |
| 11 | snd-seq-objs := seq.o seq_lock.o seq_clientmgr.o seq_memory.o seq_queue.o \ | 7 | snd-seq-objs := seq.o seq_lock.o seq_clientmgr.o seq_memory.o seq_queue.o \ |
| 12 | seq_fifo.o seq_prioq.o seq_timer.o \ | 8 | seq_fifo.o seq_prioq.o seq_timer.o \ |
| @@ -19,7 +15,8 @@ snd-seq-virmidi-objs := seq_virmidi.o | |||
| 19 | 15 | ||
| 20 | obj-$(CONFIG_SND_SEQUENCER) += snd-seq.o snd-seq-device.o | 16 | obj-$(CONFIG_SND_SEQUENCER) += snd-seq.o snd-seq-device.o |
| 21 | ifeq ($(CONFIG_SND_SEQUENCER_OSS),y) | 17 | ifeq ($(CONFIG_SND_SEQUENCER_OSS),y) |
| 22 | obj-$(CONFIG_SND_SEQUENCER) += snd-seq-midi-event.o | 18 | obj-$(CONFIG_SND_SEQUENCER) += snd-seq-midi-event.o |
| 19 | obj-$(CONFIG_SND_SEQUENCER) += oss/ | ||
| 23 | endif | 20 | endif |
| 24 | obj-$(CONFIG_SND_SEQ_DUMMY) += snd-seq-dummy.o | 21 | obj-$(CONFIG_SND_SEQ_DUMMY) += snd-seq-dummy.o |
| 25 | 22 | ||
diff --git a/sound/isa/gus/gus_pcm.c b/sound/isa/gus/gus_pcm.c index edb11eefdfe3..2dcf45bf7293 100644 --- a/sound/isa/gus/gus_pcm.c +++ b/sound/isa/gus/gus_pcm.c | |||
| @@ -795,13 +795,13 @@ static int snd_gf1_pcm_volume_put(struct snd_kcontrol *kcontrol, struct snd_ctl_ | |||
| 795 | if (!(pcmp->flags & SNDRV_GF1_PCM_PFLG_ACTIVE)) | 795 | if (!(pcmp->flags & SNDRV_GF1_PCM_PFLG_ACTIVE)) |
| 796 | continue; | 796 | continue; |
| 797 | /* load real volume - better precision */ | 797 | /* load real volume - better precision */ |
| 798 | spin_lock_irqsave(&gus->reg_lock, flags); | 798 | spin_lock(&gus->reg_lock); |
| 799 | snd_gf1_select_voice(gus, pvoice->number); | 799 | snd_gf1_select_voice(gus, pvoice->number); |
| 800 | snd_gf1_ctrl_stop(gus, SNDRV_GF1_VB_VOLUME_CONTROL); | 800 | snd_gf1_ctrl_stop(gus, SNDRV_GF1_VB_VOLUME_CONTROL); |
| 801 | vol = pvoice == pcmp->pvoices[0] ? gus->gf1.pcm_volume_level_left : gus->gf1.pcm_volume_level_right; | 801 | vol = pvoice == pcmp->pvoices[0] ? gus->gf1.pcm_volume_level_left : gus->gf1.pcm_volume_level_right; |
| 802 | snd_gf1_write16(gus, SNDRV_GF1_VW_VOLUME, vol); | 802 | snd_gf1_write16(gus, SNDRV_GF1_VW_VOLUME, vol); |
| 803 | pcmp->final_volume = 1; | 803 | pcmp->final_volume = 1; |
| 804 | spin_unlock_irqrestore(&gus->reg_lock, flags); | 804 | spin_unlock(&gus->reg_lock); |
| 805 | } | 805 | } |
| 806 | spin_unlock_irqrestore(&gus->voice_alloc, flags); | 806 | spin_unlock_irqrestore(&gus->voice_alloc, flags); |
| 807 | return change; | 807 | return change; |
diff --git a/sound/oss/aedsp16.c b/sound/oss/aedsp16.c index 3ee9900ffd7b..35b5912cf3f8 100644 --- a/sound/oss/aedsp16.c +++ b/sound/oss/aedsp16.c | |||
| @@ -325,8 +325,9 @@ | |||
| 325 | /* | 325 | /* |
| 326 | * Size of character arrays that store name and version of sound card | 326 | * Size of character arrays that store name and version of sound card |
| 327 | */ | 327 | */ |
| 328 | #define CARDNAMELEN 15 /* Size of the card's name in chars */ | 328 | #define CARDNAMELEN 15 /* Size of the card's name in chars */ |
| 329 | #define CARDVERLEN 2 /* Size of the card's version in chars */ | 329 | #define CARDVERLEN 10 /* Size of the card's version in chars */ |
| 330 | #define CARDVERDIGITS 2 /* Number of digits in the version */ | ||
| 330 | 331 | ||
| 331 | #if defined(CONFIG_SC6600) | 332 | #if defined(CONFIG_SC6600) |
| 332 | /* | 333 | /* |
| @@ -410,7 +411,7 @@ | |||
| 410 | 411 | ||
| 411 | static int soft_cfg __initdata = 0; /* bitmapped config */ | 412 | static int soft_cfg __initdata = 0; /* bitmapped config */ |
| 412 | static int soft_cfg_mss __initdata = 0; /* bitmapped mss config */ | 413 | static int soft_cfg_mss __initdata = 0; /* bitmapped mss config */ |
| 413 | static int ver[CARDVERLEN] __initdata = {0, 0}; /* DSP Ver: | 414 | static int ver[CARDVERDIGITS] __initdata = {0, 0}; /* DSP Ver: |
| 414 | hi->ver[0] lo->ver[1] */ | 415 | hi->ver[0] lo->ver[1] */ |
| 415 | 416 | ||
| 416 | #if defined(CONFIG_SC6600) | 417 | #if defined(CONFIG_SC6600) |
| @@ -957,7 +958,7 @@ static int __init aedsp16_dsp_version(int port) | |||
| 957 | * string is finished. | 958 | * string is finished. |
| 958 | */ | 959 | */ |
| 959 | ver[len++] = ret; | 960 | ver[len++] = ret; |
| 960 | } while (len < CARDVERLEN); | 961 | } while (len < CARDVERDIGITS); |
| 961 | sprintf(DSPVersion, "%d.%d", ver[0], ver[1]); | 962 | sprintf(DSPVersion, "%d.%d", ver[0], ver[1]); |
| 962 | 963 | ||
| 963 | DBG(("success.\n")); | 964 | DBG(("success.\n")); |
diff --git a/sound/oss/mpu401.c b/sound/oss/mpu401.c index 1b2316f35b1f..734b8f9e2f78 100644 --- a/sound/oss/mpu401.c +++ b/sound/oss/mpu401.c | |||
| @@ -1074,7 +1074,7 @@ int attach_mpu401(struct address_info *hw_config, struct module *owner) | |||
| 1074 | sprintf(mpu_synth_info[m].name, "%s (MPU401)", hw_config->name); | 1074 | sprintf(mpu_synth_info[m].name, "%s (MPU401)", hw_config->name); |
| 1075 | else | 1075 | else |
| 1076 | sprintf(mpu_synth_info[m].name, | 1076 | sprintf(mpu_synth_info[m].name, |
| 1077 | "MPU-401 %d.%d%c Midi interface #%d", | 1077 | "MPU-401 %d.%d%c MIDI #%d", |
| 1078 | (int) (devc->version & 0xf0) >> 4, | 1078 | (int) (devc->version & 0xf0) >> 4, |
| 1079 | devc->version & 0x0f, | 1079 | devc->version & 0x0f, |
| 1080 | revision_char, | 1080 | revision_char, |
diff --git a/sound/pci/ali5451/ali5451.c b/sound/pci/ali5451/ali5451.c index c551006e2920..76d76c08339b 100644 --- a/sound/pci/ali5451/ali5451.c +++ b/sound/pci/ali5451/ali5451.c | |||
| @@ -310,12 +310,16 @@ static int snd_ali_codec_ready(struct snd_ali *codec, | |||
| 310 | unsigned int res; | 310 | unsigned int res; |
| 311 | 311 | ||
| 312 | end_time = jiffies + msecs_to_jiffies(250); | 312 | end_time = jiffies + msecs_to_jiffies(250); |
| 313 | do { | 313 | |
| 314 | for (;;) { | ||
| 314 | res = snd_ali_5451_peek(codec,port); | 315 | res = snd_ali_5451_peek(codec,port); |
| 315 | if (!(res & 0x8000)) | 316 | if (!(res & 0x8000)) |
| 316 | return 0; | 317 | return 0; |
| 318 | if (!time_after_eq(end_time, jiffies)) | ||
| 319 | break; | ||
| 317 | schedule_timeout_uninterruptible(1); | 320 | schedule_timeout_uninterruptible(1); |
| 318 | } while (time_after_eq(end_time, jiffies)); | 321 | } |
| 322 | |||
| 319 | snd_ali_5451_poke(codec, port, res & ~0x8000); | 323 | snd_ali_5451_poke(codec, port, res & ~0x8000); |
| 320 | snd_printdd("ali_codec_ready: codec is not ready.\n "); | 324 | snd_printdd("ali_codec_ready: codec is not ready.\n "); |
| 321 | return -EIO; | 325 | return -EIO; |
| @@ -327,15 +331,17 @@ static int snd_ali_stimer_ready(struct snd_ali *codec) | |||
| 327 | unsigned long dwChk1,dwChk2; | 331 | unsigned long dwChk1,dwChk2; |
| 328 | 332 | ||
| 329 | dwChk1 = snd_ali_5451_peek(codec, ALI_STIMER); | 333 | dwChk1 = snd_ali_5451_peek(codec, ALI_STIMER); |
| 330 | dwChk2 = snd_ali_5451_peek(codec, ALI_STIMER); | ||
| 331 | |||
| 332 | end_time = jiffies + msecs_to_jiffies(250); | 334 | end_time = jiffies + msecs_to_jiffies(250); |
| 333 | do { | 335 | |
| 336 | for (;;) { | ||
| 334 | dwChk2 = snd_ali_5451_peek(codec, ALI_STIMER); | 337 | dwChk2 = snd_ali_5451_peek(codec, ALI_STIMER); |
| 335 | if (dwChk2 != dwChk1) | 338 | if (dwChk2 != dwChk1) |
| 336 | return 0; | 339 | return 0; |
| 340 | if (!time_after_eq(end_time, jiffies)) | ||
| 341 | break; | ||
| 337 | schedule_timeout_uninterruptible(1); | 342 | schedule_timeout_uninterruptible(1); |
| 338 | } while (time_after_eq(end_time, jiffies)); | 343 | } |
| 344 | |||
| 339 | snd_printk(KERN_ERR "ali_stimer_read: stimer is not ready.\n"); | 345 | snd_printk(KERN_ERR "ali_stimer_read: stimer is not ready.\n"); |
| 340 | return -EIO; | 346 | return -EIO; |
| 341 | } | 347 | } |
diff --git a/sound/pci/ca0106/ca0106_main.c b/sound/pci/ca0106/ca0106_main.c index f24bf1ecb36d..15e4138bce17 100644 --- a/sound/pci/ca0106/ca0106_main.c +++ b/sound/pci/ca0106/ca0106_main.c | |||
| @@ -325,9 +325,9 @@ static struct snd_pcm_hardware snd_ca0106_capture_hw = { | |||
| 325 | .rate_max = 192000, | 325 | .rate_max = 192000, |
| 326 | .channels_min = 2, | 326 | .channels_min = 2, |
| 327 | .channels_max = 2, | 327 | .channels_max = 2, |
| 328 | .buffer_bytes_max = ((65536 - 64) * 8), | 328 | .buffer_bytes_max = 65536 - 128, |
| 329 | .period_bytes_min = 64, | 329 | .period_bytes_min = 64, |
| 330 | .period_bytes_max = (65536 - 64), | 330 | .period_bytes_max = 32768 - 64, |
| 331 | .periods_min = 2, | 331 | .periods_min = 2, |
| 332 | .periods_max = 2, | 332 | .periods_max = 2, |
| 333 | .fifo_size = 0, | 333 | .fifo_size = 0, |
diff --git a/sound/pci/ctxfi/ctamixer.c b/sound/pci/ctxfi/ctamixer.c index a1db51b3ead8..a7f4a671f7b7 100644 --- a/sound/pci/ctxfi/ctamixer.c +++ b/sound/pci/ctxfi/ctamixer.c | |||
| @@ -242,13 +242,12 @@ static int get_amixer_rsc(struct amixer_mgr *mgr, | |||
| 242 | 242 | ||
| 243 | /* Allocate mem for amixer resource */ | 243 | /* Allocate mem for amixer resource */ |
| 244 | amixer = kzalloc(sizeof(*amixer), GFP_KERNEL); | 244 | amixer = kzalloc(sizeof(*amixer), GFP_KERNEL); |
| 245 | if (NULL == amixer) { | 245 | if (!amixer) |
| 246 | err = -ENOMEM; | 246 | return -ENOMEM; |
| 247 | return err; | ||
| 248 | } | ||
| 249 | 247 | ||
| 250 | /* Check whether there are sufficient | 248 | /* Check whether there are sufficient |
| 251 | * amixer resources to meet request. */ | 249 | * amixer resources to meet request. */ |
| 250 | err = 0; | ||
| 252 | spin_lock_irqsave(&mgr->mgr_lock, flags); | 251 | spin_lock_irqsave(&mgr->mgr_lock, flags); |
| 253 | for (i = 0; i < desc->msr; i++) { | 252 | for (i = 0; i < desc->msr; i++) { |
| 254 | err = mgr_get_resource(&mgr->mgr, 1, &idx); | 253 | err = mgr_get_resource(&mgr->mgr, 1, &idx); |
| @@ -397,12 +396,11 @@ static int get_sum_rsc(struct sum_mgr *mgr, | |||
| 397 | 396 | ||
| 398 | /* Allocate mem for sum resource */ | 397 | /* Allocate mem for sum resource */ |
| 399 | sum = kzalloc(sizeof(*sum), GFP_KERNEL); | 398 | sum = kzalloc(sizeof(*sum), GFP_KERNEL); |
| 400 | if (NULL == sum) { | 399 | if (!sum) |
| 401 | err = -ENOMEM; | 400 | return -ENOMEM; |
| 402 | return err; | ||
| 403 | } | ||
| 404 | 401 | ||
| 405 | /* Check whether there are sufficient sum resources to meet request. */ | 402 | /* Check whether there are sufficient sum resources to meet request. */ |
| 403 | err = 0; | ||
| 406 | spin_lock_irqsave(&mgr->mgr_lock, flags); | 404 | spin_lock_irqsave(&mgr->mgr_lock, flags); |
| 407 | for (i = 0; i < desc->msr; i++) { | 405 | for (i = 0; i < desc->msr; i++) { |
| 408 | err = mgr_get_resource(&mgr->mgr, 1, &idx); | 406 | err = mgr_get_resource(&mgr->mgr, 1, &idx); |
diff --git a/sound/pci/ctxfi/ctdaio.c b/sound/pci/ctxfi/ctdaio.c index 082e35c08c02..deb6cfa73600 100644 --- a/sound/pci/ctxfi/ctdaio.c +++ b/sound/pci/ctxfi/ctdaio.c | |||
| @@ -57,9 +57,9 @@ struct daio_rsc_idx idx_20k1[NUM_DAIOTYP] = { | |||
| 57 | 57 | ||
| 58 | struct daio_rsc_idx idx_20k2[NUM_DAIOTYP] = { | 58 | struct daio_rsc_idx idx_20k2[NUM_DAIOTYP] = { |
| 59 | [LINEO1] = {.left = 0x40, .right = 0x41}, | 59 | [LINEO1] = {.left = 0x40, .right = 0x41}, |
| 60 | [LINEO2] = {.left = 0x70, .right = 0x71}, | 60 | [LINEO2] = {.left = 0x60, .right = 0x61}, |
| 61 | [LINEO3] = {.left = 0x50, .right = 0x51}, | 61 | [LINEO3] = {.left = 0x50, .right = 0x51}, |
| 62 | [LINEO4] = {.left = 0x60, .right = 0x61}, | 62 | [LINEO4] = {.left = 0x70, .right = 0x71}, |
| 63 | [LINEIM] = {.left = 0x45, .right = 0xc5}, | 63 | [LINEIM] = {.left = 0x45, .right = 0xc5}, |
| 64 | [SPDIFOO] = {.left = 0x00, .right = 0x01}, | 64 | [SPDIFOO] = {.left = 0x00, .right = 0x01}, |
| 65 | [SPDIFIO] = {.left = 0x05, .right = 0x85}, | 65 | [SPDIFIO] = {.left = 0x05, .right = 0x85}, |
diff --git a/sound/pci/ctxfi/ctsrc.c b/sound/pci/ctxfi/ctsrc.c index e1c145d8b702..df43a5cd3938 100644 --- a/sound/pci/ctxfi/ctsrc.c +++ b/sound/pci/ctxfi/ctsrc.c | |||
| @@ -724,12 +724,11 @@ static int get_srcimp_rsc(struct srcimp_mgr *mgr, | |||
| 724 | 724 | ||
| 725 | /* Allocate mem for SRCIMP resource */ | 725 | /* Allocate mem for SRCIMP resource */ |
| 726 | srcimp = kzalloc(sizeof(*srcimp), GFP_KERNEL); | 726 | srcimp = kzalloc(sizeof(*srcimp), GFP_KERNEL); |
| 727 | if (NULL == srcimp) { | 727 | if (!srcimp) |
| 728 | err = -ENOMEM; | 728 | return -ENOMEM; |
| 729 | return err; | ||
| 730 | } | ||
| 731 | 729 | ||
| 732 | /* Check whether there are sufficient SRCIMP resources. */ | 730 | /* Check whether there are sufficient SRCIMP resources. */ |
| 731 | err = 0; | ||
| 733 | spin_lock_irqsave(&mgr->mgr_lock, flags); | 732 | spin_lock_irqsave(&mgr->mgr_lock, flags); |
| 734 | for (i = 0; i < desc->msr; i++) { | 733 | for (i = 0; i < desc->msr; i++) { |
| 735 | err = mgr_get_resource(&mgr->mgr, 1, &idx); | 734 | err = mgr_get_resource(&mgr->mgr, 1, &idx); |
diff --git a/sound/pci/hda/hda_codec.c b/sound/pci/hda/hda_codec.c index 26d255de6beb..c7df01b72cac 100644 --- a/sound/pci/hda/hda_codec.c +++ b/sound/pci/hda/hda_codec.c | |||
| @@ -174,7 +174,7 @@ static int codec_exec_verb(struct hda_codec *codec, unsigned int cmd, | |||
| 174 | mutex_lock(&bus->cmd_mutex); | 174 | mutex_lock(&bus->cmd_mutex); |
| 175 | err = bus->ops.command(bus, cmd); | 175 | err = bus->ops.command(bus, cmd); |
| 176 | if (!err && res) | 176 | if (!err && res) |
| 177 | *res = bus->ops.get_response(bus); | 177 | *res = bus->ops.get_response(bus, codec->addr); |
| 178 | mutex_unlock(&bus->cmd_mutex); | 178 | mutex_unlock(&bus->cmd_mutex); |
| 179 | snd_hda_power_down(codec); | 179 | snd_hda_power_down(codec); |
| 180 | if (res && *res == -1 && bus->rirb_error) { | 180 | if (res && *res == -1 && bus->rirb_error) { |
| @@ -332,6 +332,12 @@ int snd_hda_get_connections(struct hda_codec *codec, hda_nid_t nid, | |||
| 332 | AC_VERB_GET_CONNECT_LIST, i); | 332 | AC_VERB_GET_CONNECT_LIST, i); |
| 333 | range_val = !!(parm & (1 << (shift-1))); /* ranges */ | 333 | range_val = !!(parm & (1 << (shift-1))); /* ranges */ |
| 334 | val = parm & mask; | 334 | val = parm & mask; |
| 335 | if (val == 0) { | ||
| 336 | snd_printk(KERN_WARNING "hda_codec: " | ||
| 337 | "invalid CONNECT_LIST verb %x[%i]:%x\n", | ||
| 338 | nid, i, parm); | ||
| 339 | return 0; | ||
| 340 | } | ||
| 335 | parm >>= shift; | 341 | parm >>= shift; |
| 336 | if (range_val) { | 342 | if (range_val) { |
| 337 | /* ranges between the previous and this one */ | 343 | /* ranges between the previous and this one */ |
diff --git a/sound/pci/hda/hda_codec.h b/sound/pci/hda/hda_codec.h index cad79efaabc9..1b75f28ed092 100644 --- a/sound/pci/hda/hda_codec.h +++ b/sound/pci/hda/hda_codec.h | |||
| @@ -568,7 +568,7 @@ struct hda_bus_ops { | |||
| 568 | /* send a single command */ | 568 | /* send a single command */ |
| 569 | int (*command)(struct hda_bus *bus, unsigned int cmd); | 569 | int (*command)(struct hda_bus *bus, unsigned int cmd); |
| 570 | /* get a response from the last command */ | 570 | /* get a response from the last command */ |
| 571 | unsigned int (*get_response)(struct hda_bus *bus); | 571 | unsigned int (*get_response)(struct hda_bus *bus, unsigned int addr); |
| 572 | /* free the private data */ | 572 | /* free the private data */ |
| 573 | void (*private_free)(struct hda_bus *); | 573 | void (*private_free)(struct hda_bus *); |
| 574 | /* attach a PCM stream */ | 574 | /* attach a PCM stream */ |
diff --git a/sound/pci/hda/hda_eld.c b/sound/pci/hda/hda_eld.c index fcad5ec31773..9446a5abea13 100644 --- a/sound/pci/hda/hda_eld.c +++ b/sound/pci/hda/hda_eld.c | |||
| @@ -508,7 +508,7 @@ static void hdmi_write_eld_info(struct snd_info_entry *entry, | |||
| 508 | char name[64]; | 508 | char name[64]; |
| 509 | char *sname; | 509 | char *sname; |
| 510 | long long val; | 510 | long long val; |
| 511 | int n; | 511 | unsigned int n; |
| 512 | 512 | ||
| 513 | while (!snd_info_get_line(buffer, line, sizeof(line))) { | 513 | while (!snd_info_get_line(buffer, line, sizeof(line))) { |
| 514 | if (sscanf(line, "%s %llx", name, &val) != 2) | 514 | if (sscanf(line, "%s %llx", name, &val) != 2) |
| @@ -539,7 +539,7 @@ static void hdmi_write_eld_info(struct snd_info_entry *entry, | |||
| 539 | sname++; | 539 | sname++; |
| 540 | n = 10 * n + name[4] - '0'; | 540 | n = 10 * n + name[4] - '0'; |
| 541 | } | 541 | } |
| 542 | if (n < 0 || n > 31) /* double the CEA limit */ | 542 | if (n >= ELD_MAX_SAD) |
| 543 | continue; | 543 | continue; |
| 544 | if (!strcmp(sname, "_coding_type")) | 544 | if (!strcmp(sname, "_coding_type")) |
| 545 | e->sad[n].format = val; | 545 | e->sad[n].format = val; |
diff --git a/sound/pci/hda/hda_intel.c b/sound/pci/hda/hda_intel.c index 77c1b840ca8b..175f07a381ba 100644 --- a/sound/pci/hda/hda_intel.c +++ b/sound/pci/hda/hda_intel.c | |||
| @@ -253,7 +253,7 @@ enum { SDI0, SDI1, SDI2, SDI3, SDO0, SDO1, SDO2, SDO3 }; | |||
| 253 | 253 | ||
| 254 | /* STATESTS int mask: S3,SD2,SD1,SD0 */ | 254 | /* STATESTS int mask: S3,SD2,SD1,SD0 */ |
| 255 | #define AZX_MAX_CODECS 4 | 255 | #define AZX_MAX_CODECS 4 |
| 256 | #define STATESTS_INT_MASK 0x0f | 256 | #define STATESTS_INT_MASK ((1 << AZX_MAX_CODECS) - 1) |
| 257 | 257 | ||
| 258 | /* SD_CTL bits */ | 258 | /* SD_CTL bits */ |
| 259 | #define SD_CTL_STREAM_RESET 0x01 /* stream reset bit */ | 259 | #define SD_CTL_STREAM_RESET 0x01 /* stream reset bit */ |
| @@ -361,8 +361,8 @@ struct azx_rb { | |||
| 361 | dma_addr_t addr; /* physical address of CORB/RIRB buffer */ | 361 | dma_addr_t addr; /* physical address of CORB/RIRB buffer */ |
| 362 | /* for RIRB */ | 362 | /* for RIRB */ |
| 363 | unsigned short rp, wp; /* read/write pointers */ | 363 | unsigned short rp, wp; /* read/write pointers */ |
| 364 | int cmds; /* number of pending requests */ | 364 | int cmds[AZX_MAX_CODECS]; /* number of pending requests */ |
| 365 | u32 res; /* last read value */ | 365 | u32 res[AZX_MAX_CODECS]; /* last read value */ |
| 366 | }; | 366 | }; |
| 367 | 367 | ||
| 368 | struct azx { | 368 | struct azx { |
| @@ -418,7 +418,7 @@ struct azx { | |||
| 418 | unsigned int probing :1; /* codec probing phase */ | 418 | unsigned int probing :1; /* codec probing phase */ |
| 419 | 419 | ||
| 420 | /* for debugging */ | 420 | /* for debugging */ |
| 421 | unsigned int last_cmd; /* last issued command (to sync) */ | 421 | unsigned int last_cmd[AZX_MAX_CODECS]; |
| 422 | 422 | ||
| 423 | /* for pending irqs */ | 423 | /* for pending irqs */ |
| 424 | struct work_struct irq_pending_work; | 424 | struct work_struct irq_pending_work; |
| @@ -513,6 +513,7 @@ static int azx_alloc_cmd_io(struct azx *chip) | |||
| 513 | 513 | ||
| 514 | static void azx_init_cmd_io(struct azx *chip) | 514 | static void azx_init_cmd_io(struct azx *chip) |
| 515 | { | 515 | { |
| 516 | spin_lock_irq(&chip->reg_lock); | ||
| 516 | /* CORB set up */ | 517 | /* CORB set up */ |
| 517 | chip->corb.addr = chip->rb.addr; | 518 | chip->corb.addr = chip->rb.addr; |
| 518 | chip->corb.buf = (u32 *)chip->rb.area; | 519 | chip->corb.buf = (u32 *)chip->rb.area; |
| @@ -531,7 +532,8 @@ static void azx_init_cmd_io(struct azx *chip) | |||
| 531 | /* RIRB set up */ | 532 | /* RIRB set up */ |
| 532 | chip->rirb.addr = chip->rb.addr + 2048; | 533 | chip->rirb.addr = chip->rb.addr + 2048; |
| 533 | chip->rirb.buf = (u32 *)(chip->rb.area + 2048); | 534 | chip->rirb.buf = (u32 *)(chip->rb.area + 2048); |
| 534 | chip->rirb.wp = chip->rirb.rp = chip->rirb.cmds = 0; | 535 | chip->rirb.wp = chip->rirb.rp = 0; |
| 536 | memset(chip->rirb.cmds, 0, sizeof(chip->rirb.cmds)); | ||
| 535 | azx_writel(chip, RIRBLBASE, (u32)chip->rirb.addr); | 537 | azx_writel(chip, RIRBLBASE, (u32)chip->rirb.addr); |
| 536 | azx_writel(chip, RIRBUBASE, upper_32_bits(chip->rirb.addr)); | 538 | azx_writel(chip, RIRBUBASE, upper_32_bits(chip->rirb.addr)); |
| 537 | 539 | ||
| @@ -543,30 +545,60 @@ static void azx_init_cmd_io(struct azx *chip) | |||
| 543 | azx_writew(chip, RINTCNT, 1); | 545 | azx_writew(chip, RINTCNT, 1); |
| 544 | /* enable rirb dma and response irq */ | 546 | /* enable rirb dma and response irq */ |
| 545 | azx_writeb(chip, RIRBCTL, ICH6_RBCTL_DMA_EN | ICH6_RBCTL_IRQ_EN); | 547 | azx_writeb(chip, RIRBCTL, ICH6_RBCTL_DMA_EN | ICH6_RBCTL_IRQ_EN); |
| 548 | spin_unlock_irq(&chip->reg_lock); | ||
| 546 | } | 549 | } |
| 547 | 550 | ||
| 548 | static void azx_free_cmd_io(struct azx *chip) | 551 | static void azx_free_cmd_io(struct azx *chip) |
| 549 | { | 552 | { |
| 553 | spin_lock_irq(&chip->reg_lock); | ||
| 550 | /* disable ringbuffer DMAs */ | 554 | /* disable ringbuffer DMAs */ |
| 551 | azx_writeb(chip, RIRBCTL, 0); | 555 | azx_writeb(chip, RIRBCTL, 0); |
| 552 | azx_writeb(chip, CORBCTL, 0); | 556 | azx_writeb(chip, CORBCTL, 0); |
| 557 | spin_unlock_irq(&chip->reg_lock); | ||
| 558 | } | ||
| 559 | |||
| 560 | static unsigned int azx_command_addr(u32 cmd) | ||
| 561 | { | ||
| 562 | unsigned int addr = cmd >> 28; | ||
| 563 | |||
| 564 | if (addr >= AZX_MAX_CODECS) { | ||
| 565 | snd_BUG(); | ||
| 566 | addr = 0; | ||
| 567 | } | ||
| 568 | |||
| 569 | return addr; | ||
| 570 | } | ||
| 571 | |||
| 572 | static unsigned int azx_response_addr(u32 res) | ||
| 573 | { | ||
| 574 | unsigned int addr = res & 0xf; | ||
| 575 | |||
| 576 | if (addr >= AZX_MAX_CODECS) { | ||
| 577 | snd_BUG(); | ||
| 578 | addr = 0; | ||
| 579 | } | ||
| 580 | |||
| 581 | return addr; | ||
| 553 | } | 582 | } |
| 554 | 583 | ||
| 555 | /* send a command */ | 584 | /* send a command */ |
| 556 | static int azx_corb_send_cmd(struct hda_bus *bus, u32 val) | 585 | static int azx_corb_send_cmd(struct hda_bus *bus, u32 val) |
| 557 | { | 586 | { |
| 558 | struct azx *chip = bus->private_data; | 587 | struct azx *chip = bus->private_data; |
| 588 | unsigned int addr = azx_command_addr(val); | ||
| 559 | unsigned int wp; | 589 | unsigned int wp; |
| 560 | 590 | ||
| 591 | spin_lock_irq(&chip->reg_lock); | ||
| 592 | |||
| 561 | /* add command to corb */ | 593 | /* add command to corb */ |
| 562 | wp = azx_readb(chip, CORBWP); | 594 | wp = azx_readb(chip, CORBWP); |
| 563 | wp++; | 595 | wp++; |
| 564 | wp %= ICH6_MAX_CORB_ENTRIES; | 596 | wp %= ICH6_MAX_CORB_ENTRIES; |
| 565 | 597 | ||
| 566 | spin_lock_irq(&chip->reg_lock); | 598 | chip->rirb.cmds[addr]++; |
| 567 | chip->rirb.cmds++; | ||
| 568 | chip->corb.buf[wp] = cpu_to_le32(val); | 599 | chip->corb.buf[wp] = cpu_to_le32(val); |
| 569 | azx_writel(chip, CORBWP, wp); | 600 | azx_writel(chip, CORBWP, wp); |
| 601 | |||
| 570 | spin_unlock_irq(&chip->reg_lock); | 602 | spin_unlock_irq(&chip->reg_lock); |
| 571 | 603 | ||
| 572 | return 0; | 604 | return 0; |
| @@ -578,13 +610,14 @@ static int azx_corb_send_cmd(struct hda_bus *bus, u32 val) | |||
| 578 | static void azx_update_rirb(struct azx *chip) | 610 | static void azx_update_rirb(struct azx *chip) |
| 579 | { | 611 | { |
| 580 | unsigned int rp, wp; | 612 | unsigned int rp, wp; |
| 613 | unsigned int addr; | ||
| 581 | u32 res, res_ex; | 614 | u32 res, res_ex; |
| 582 | 615 | ||
| 583 | wp = azx_readb(chip, RIRBWP); | 616 | wp = azx_readb(chip, RIRBWP); |
| 584 | if (wp == chip->rirb.wp) | 617 | if (wp == chip->rirb.wp) |
| 585 | return; | 618 | return; |
| 586 | chip->rirb.wp = wp; | 619 | chip->rirb.wp = wp; |
| 587 | 620 | ||
| 588 | while (chip->rirb.rp != wp) { | 621 | while (chip->rirb.rp != wp) { |
| 589 | chip->rirb.rp++; | 622 | chip->rirb.rp++; |
| 590 | chip->rirb.rp %= ICH6_MAX_RIRB_ENTRIES; | 623 | chip->rirb.rp %= ICH6_MAX_RIRB_ENTRIES; |
| @@ -592,18 +625,24 @@ static void azx_update_rirb(struct azx *chip) | |||
| 592 | rp = chip->rirb.rp << 1; /* an RIRB entry is 8-bytes */ | 625 | rp = chip->rirb.rp << 1; /* an RIRB entry is 8-bytes */ |
| 593 | res_ex = le32_to_cpu(chip->rirb.buf[rp + 1]); | 626 | res_ex = le32_to_cpu(chip->rirb.buf[rp + 1]); |
| 594 | res = le32_to_cpu(chip->rirb.buf[rp]); | 627 | res = le32_to_cpu(chip->rirb.buf[rp]); |
| 628 | addr = azx_response_addr(res_ex); | ||
| 595 | if (res_ex & ICH6_RIRB_EX_UNSOL_EV) | 629 | if (res_ex & ICH6_RIRB_EX_UNSOL_EV) |
| 596 | snd_hda_queue_unsol_event(chip->bus, res, res_ex); | 630 | snd_hda_queue_unsol_event(chip->bus, res, res_ex); |
| 597 | else if (chip->rirb.cmds) { | 631 | else if (chip->rirb.cmds[addr]) { |
| 598 | chip->rirb.res = res; | 632 | chip->rirb.res[addr] = res; |
| 599 | smp_wmb(); | 633 | smp_wmb(); |
| 600 | chip->rirb.cmds--; | 634 | chip->rirb.cmds[addr]--; |
| 601 | } | 635 | } else |
| 636 | snd_printk(KERN_ERR SFX "spurious response %#x:%#x, " | ||
| 637 | "last cmd=%#08x\n", | ||
| 638 | res, res_ex, | ||
| 639 | chip->last_cmd[addr]); | ||
| 602 | } | 640 | } |
| 603 | } | 641 | } |
| 604 | 642 | ||
| 605 | /* receive a response */ | 643 | /* receive a response */ |
| 606 | static unsigned int azx_rirb_get_response(struct hda_bus *bus) | 644 | static unsigned int azx_rirb_get_response(struct hda_bus *bus, |
| 645 | unsigned int addr) | ||
| 607 | { | 646 | { |
| 608 | struct azx *chip = bus->private_data; | 647 | struct azx *chip = bus->private_data; |
| 609 | unsigned long timeout; | 648 | unsigned long timeout; |
| @@ -616,10 +655,10 @@ static unsigned int azx_rirb_get_response(struct hda_bus *bus) | |||
| 616 | azx_update_rirb(chip); | 655 | azx_update_rirb(chip); |
| 617 | spin_unlock_irq(&chip->reg_lock); | 656 | spin_unlock_irq(&chip->reg_lock); |
| 618 | } | 657 | } |
| 619 | if (!chip->rirb.cmds) { | 658 | if (!chip->rirb.cmds[addr]) { |
| 620 | smp_rmb(); | 659 | smp_rmb(); |
| 621 | bus->rirb_error = 0; | 660 | bus->rirb_error = 0; |
| 622 | return chip->rirb.res; /* the last value */ | 661 | return chip->rirb.res[addr]; /* the last value */ |
| 623 | } | 662 | } |
| 624 | if (time_after(jiffies, timeout)) | 663 | if (time_after(jiffies, timeout)) |
| 625 | break; | 664 | break; |
| @@ -633,7 +672,8 @@ static unsigned int azx_rirb_get_response(struct hda_bus *bus) | |||
| 633 | 672 | ||
| 634 | if (chip->msi) { | 673 | if (chip->msi) { |
| 635 | snd_printk(KERN_WARNING SFX "No response from codec, " | 674 | snd_printk(KERN_WARNING SFX "No response from codec, " |
| 636 | "disabling MSI: last cmd=0x%08x\n", chip->last_cmd); | 675 | "disabling MSI: last cmd=0x%08x\n", |
| 676 | chip->last_cmd[addr]); | ||
| 637 | free_irq(chip->irq, chip); | 677 | free_irq(chip->irq, chip); |
| 638 | chip->irq = -1; | 678 | chip->irq = -1; |
| 639 | pci_disable_msi(chip->pci); | 679 | pci_disable_msi(chip->pci); |
| @@ -648,7 +688,7 @@ static unsigned int azx_rirb_get_response(struct hda_bus *bus) | |||
| 648 | if (!chip->polling_mode) { | 688 | if (!chip->polling_mode) { |
| 649 | snd_printk(KERN_WARNING SFX "azx_get_response timeout, " | 689 | snd_printk(KERN_WARNING SFX "azx_get_response timeout, " |
| 650 | "switching to polling mode: last cmd=0x%08x\n", | 690 | "switching to polling mode: last cmd=0x%08x\n", |
| 651 | chip->last_cmd); | 691 | chip->last_cmd[addr]); |
| 652 | chip->polling_mode = 1; | 692 | chip->polling_mode = 1; |
| 653 | goto again; | 693 | goto again; |
| 654 | } | 694 | } |
| @@ -672,7 +712,7 @@ static unsigned int azx_rirb_get_response(struct hda_bus *bus) | |||
| 672 | 712 | ||
| 673 | snd_printk(KERN_ERR "hda_intel: azx_get_response timeout, " | 713 | snd_printk(KERN_ERR "hda_intel: azx_get_response timeout, " |
| 674 | "switching to single_cmd mode: last cmd=0x%08x\n", | 714 | "switching to single_cmd mode: last cmd=0x%08x\n", |
| 675 | chip->last_cmd); | 715 | chip->last_cmd[addr]); |
| 676 | chip->single_cmd = 1; | 716 | chip->single_cmd = 1; |
| 677 | bus->response_reset = 0; | 717 | bus->response_reset = 0; |
| 678 | /* re-initialize CORB/RIRB */ | 718 | /* re-initialize CORB/RIRB */ |
| @@ -692,7 +732,7 @@ static unsigned int azx_rirb_get_response(struct hda_bus *bus) | |||
| 692 | */ | 732 | */ |
| 693 | 733 | ||
| 694 | /* receive a response */ | 734 | /* receive a response */ |
| 695 | static int azx_single_wait_for_response(struct azx *chip) | 735 | static int azx_single_wait_for_response(struct azx *chip, unsigned int addr) |
| 696 | { | 736 | { |
| 697 | int timeout = 50; | 737 | int timeout = 50; |
| 698 | 738 | ||
| @@ -700,7 +740,7 @@ static int azx_single_wait_for_response(struct azx *chip) | |||
| 700 | /* check IRV busy bit */ | 740 | /* check IRV busy bit */ |
| 701 | if (azx_readw(chip, IRS) & ICH6_IRS_VALID) { | 741 | if (azx_readw(chip, IRS) & ICH6_IRS_VALID) { |
| 702 | /* reuse rirb.res as the response return value */ | 742 | /* reuse rirb.res as the response return value */ |
| 703 | chip->rirb.res = azx_readl(chip, IR); | 743 | chip->rirb.res[addr] = azx_readl(chip, IR); |
| 704 | return 0; | 744 | return 0; |
| 705 | } | 745 | } |
| 706 | udelay(1); | 746 | udelay(1); |
| @@ -708,7 +748,7 @@ static int azx_single_wait_for_response(struct azx *chip) | |||
| 708 | if (printk_ratelimit()) | 748 | if (printk_ratelimit()) |
| 709 | snd_printd(SFX "get_response timeout: IRS=0x%x\n", | 749 | snd_printd(SFX "get_response timeout: IRS=0x%x\n", |
| 710 | azx_readw(chip, IRS)); | 750 | azx_readw(chip, IRS)); |
| 711 | chip->rirb.res = -1; | 751 | chip->rirb.res[addr] = -1; |
| 712 | return -EIO; | 752 | return -EIO; |
| 713 | } | 753 | } |
| 714 | 754 | ||
| @@ -716,6 +756,7 @@ static int azx_single_wait_for_response(struct azx *chip) | |||
| 716 | static int azx_single_send_cmd(struct hda_bus *bus, u32 val) | 756 | static int azx_single_send_cmd(struct hda_bus *bus, u32 val) |
| 717 | { | 757 | { |
| 718 | struct azx *chip = bus->private_data; | 758 | struct azx *chip = bus->private_data; |
| 759 | unsigned int addr = azx_command_addr(val); | ||
| 719 | int timeout = 50; | 760 | int timeout = 50; |
| 720 | 761 | ||
| 721 | bus->rirb_error = 0; | 762 | bus->rirb_error = 0; |
| @@ -728,7 +769,7 @@ static int azx_single_send_cmd(struct hda_bus *bus, u32 val) | |||
| 728 | azx_writel(chip, IC, val); | 769 | azx_writel(chip, IC, val); |
| 729 | azx_writew(chip, IRS, azx_readw(chip, IRS) | | 770 | azx_writew(chip, IRS, azx_readw(chip, IRS) | |
| 730 | ICH6_IRS_BUSY); | 771 | ICH6_IRS_BUSY); |
| 731 | return azx_single_wait_for_response(chip); | 772 | return azx_single_wait_for_response(chip, addr); |
| 732 | } | 773 | } |
| 733 | udelay(1); | 774 | udelay(1); |
| 734 | } | 775 | } |
| @@ -739,10 +780,11 @@ static int azx_single_send_cmd(struct hda_bus *bus, u32 val) | |||
| 739 | } | 780 | } |
| 740 | 781 | ||
| 741 | /* receive a response */ | 782 | /* receive a response */ |
| 742 | static unsigned int azx_single_get_response(struct hda_bus *bus) | 783 | static unsigned int azx_single_get_response(struct hda_bus *bus, |
| 784 | unsigned int addr) | ||
| 743 | { | 785 | { |
| 744 | struct azx *chip = bus->private_data; | 786 | struct azx *chip = bus->private_data; |
| 745 | return chip->rirb.res; | 787 | return chip->rirb.res[addr]; |
| 746 | } | 788 | } |
| 747 | 789 | ||
| 748 | /* | 790 | /* |
| @@ -757,7 +799,7 @@ static int azx_send_cmd(struct hda_bus *bus, unsigned int val) | |||
| 757 | { | 799 | { |
| 758 | struct azx *chip = bus->private_data; | 800 | struct azx *chip = bus->private_data; |
| 759 | 801 | ||
| 760 | chip->last_cmd = val; | 802 | chip->last_cmd[azx_command_addr(val)] = val; |
| 761 | if (chip->single_cmd) | 803 | if (chip->single_cmd) |
| 762 | return azx_single_send_cmd(bus, val); | 804 | return azx_single_send_cmd(bus, val); |
| 763 | else | 805 | else |
| @@ -765,13 +807,14 @@ static int azx_send_cmd(struct hda_bus *bus, unsigned int val) | |||
| 765 | } | 807 | } |
| 766 | 808 | ||
| 767 | /* get a response */ | 809 | /* get a response */ |
| 768 | static unsigned int azx_get_response(struct hda_bus *bus) | 810 | static unsigned int azx_get_response(struct hda_bus *bus, |
| 811 | unsigned int addr) | ||
| 769 | { | 812 | { |
| 770 | struct azx *chip = bus->private_data; | 813 | struct azx *chip = bus->private_data; |
| 771 | if (chip->single_cmd) | 814 | if (chip->single_cmd) |
| 772 | return azx_single_get_response(bus); | 815 | return azx_single_get_response(bus, addr); |
| 773 | else | 816 | else |
| 774 | return azx_rirb_get_response(bus); | 817 | return azx_rirb_get_response(bus, addr); |
| 775 | } | 818 | } |
| 776 | 819 | ||
| 777 | #ifdef CONFIG_SND_HDA_POWER_SAVE | 820 | #ifdef CONFIG_SND_HDA_POWER_SAVE |
| @@ -1243,10 +1286,12 @@ static int probe_codec(struct azx *chip, int addr) | |||
| 1243 | (AC_VERB_PARAMETERS << 8) | AC_PAR_VENDOR_ID; | 1286 | (AC_VERB_PARAMETERS << 8) | AC_PAR_VENDOR_ID; |
| 1244 | unsigned int res; | 1287 | unsigned int res; |
| 1245 | 1288 | ||
| 1289 | mutex_lock(&chip->bus->cmd_mutex); | ||
| 1246 | chip->probing = 1; | 1290 | chip->probing = 1; |
| 1247 | azx_send_cmd(chip->bus, cmd); | 1291 | azx_send_cmd(chip->bus, cmd); |
| 1248 | res = azx_get_response(chip->bus); | 1292 | res = azx_get_response(chip->bus, addr); |
| 1249 | chip->probing = 0; | 1293 | chip->probing = 0; |
| 1294 | mutex_unlock(&chip->bus->cmd_mutex); | ||
| 1250 | if (res == -1) | 1295 | if (res == -1) |
| 1251 | return -EIO; | 1296 | return -EIO; |
| 1252 | snd_printdd(SFX "codec #%d probed OK\n", addr); | 1297 | snd_printdd(SFX "codec #%d probed OK\n", addr); |
diff --git a/sound/pci/hda/patch_analog.c b/sound/pci/hda/patch_analog.c index be7d25fa7f35..403588c6e3f6 100644 --- a/sound/pci/hda/patch_analog.c +++ b/sound/pci/hda/patch_analog.c | |||
| @@ -3754,7 +3754,7 @@ static int ad1884a_mobile_master_sw_put(struct snd_kcontrol *kcontrol, | |||
| 3754 | int mute = (!ucontrol->value.integer.value[0] && | 3754 | int mute = (!ucontrol->value.integer.value[0] && |
| 3755 | !ucontrol->value.integer.value[1]); | 3755 | !ucontrol->value.integer.value[1]); |
| 3756 | /* toggle GPIO1 according to the mute state */ | 3756 | /* toggle GPIO1 according to the mute state */ |
| 3757 | snd_hda_codec_write(codec, 0x01, 0, AC_VERB_SET_GPIO_DATA, | 3757 | snd_hda_codec_write_cache(codec, 0x01, 0, AC_VERB_SET_GPIO_DATA, |
| 3758 | mute ? 0x02 : 0x0); | 3758 | mute ? 0x02 : 0x0); |
| 3759 | return ret; | 3759 | return ret; |
| 3760 | } | 3760 | } |
| @@ -3835,9 +3835,11 @@ static struct hda_verb ad1884a_laptop_verbs[] = { | |||
| 3835 | /* Port-F (int speaker) mixer - route only from analog mixer */ | 3835 | /* Port-F (int speaker) mixer - route only from analog mixer */ |
| 3836 | {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, | 3836 | {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, |
| 3837 | {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 3837 | {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
| 3838 | /* Port-F pin */ | 3838 | /* Port-F (int speaker) pin */ |
| 3839 | {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP}, | 3839 | {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT}, |
| 3840 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, | 3840 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, |
| 3841 | /* required for compaq 6530s/6531s speaker output */ | ||
| 3842 | {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT}, | ||
| 3841 | /* Port-C pin - internal mic-in */ | 3843 | /* Port-C pin - internal mic-in */ |
| 3842 | {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80}, | 3844 | {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80}, |
| 3843 | {0x14, AC_VERB_SET_AMP_GAIN_MUTE, 0x7002}, /* raise mic as default */ | 3845 | {0x14, AC_VERB_SET_AMP_GAIN_MUTE, 0x7002}, /* raise mic as default */ |
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index 7e99763ca527..6f683e451f2b 100644 --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c | |||
| @@ -275,13 +275,13 @@ struct alc_spec { | |||
| 275 | */ | 275 | */ |
| 276 | unsigned int num_init_verbs; | 276 | unsigned int num_init_verbs; |
| 277 | 277 | ||
| 278 | char stream_name_analog[16]; /* analog PCM stream */ | 278 | char stream_name_analog[32]; /* analog PCM stream */ |
| 279 | struct hda_pcm_stream *stream_analog_playback; | 279 | struct hda_pcm_stream *stream_analog_playback; |
| 280 | struct hda_pcm_stream *stream_analog_capture; | 280 | struct hda_pcm_stream *stream_analog_capture; |
| 281 | struct hda_pcm_stream *stream_analog_alt_playback; | 281 | struct hda_pcm_stream *stream_analog_alt_playback; |
| 282 | struct hda_pcm_stream *stream_analog_alt_capture; | 282 | struct hda_pcm_stream *stream_analog_alt_capture; |
| 283 | 283 | ||
| 284 | char stream_name_digital[16]; /* digital PCM stream */ | 284 | char stream_name_digital[32]; /* digital PCM stream */ |
| 285 | struct hda_pcm_stream *stream_digital_playback; | 285 | struct hda_pcm_stream *stream_digital_playback; |
| 286 | struct hda_pcm_stream *stream_digital_capture; | 286 | struct hda_pcm_stream *stream_digital_capture; |
| 287 | 287 | ||
| @@ -559,7 +559,7 @@ static int alc_pin_mode_get(struct snd_kcontrol *kcontrol, | |||
| 559 | 559 | ||
| 560 | /* Find enumerated value for current pinctl setting */ | 560 | /* Find enumerated value for current pinctl setting */ |
| 561 | i = alc_pin_mode_min(dir); | 561 | i = alc_pin_mode_min(dir); |
| 562 | while (alc_pin_mode_values[i] != pinctl && i <= alc_pin_mode_max(dir)) | 562 | while (i <= alc_pin_mode_max(dir) && alc_pin_mode_values[i] != pinctl) |
| 563 | i++; | 563 | i++; |
| 564 | *valp = i <= alc_pin_mode_max(dir) ? i: alc_pin_mode_min(dir); | 564 | *valp = i <= alc_pin_mode_max(dir) ? i: alc_pin_mode_min(dir); |
| 565 | return 0; | 565 | return 0; |
| @@ -10631,6 +10631,18 @@ static void alc262_lenovo_3000_unsol_event(struct hda_codec *codec, | |||
| 10631 | alc262_lenovo_3000_automute(codec, 1); | 10631 | alc262_lenovo_3000_automute(codec, 1); |
| 10632 | } | 10632 | } |
| 10633 | 10633 | ||
| 10634 | static int amp_stereo_mute_update(struct hda_codec *codec, hda_nid_t nid, | ||
| 10635 | int dir, int idx, long *valp) | ||
| 10636 | { | ||
| 10637 | int i, change = 0; | ||
| 10638 | |||
| 10639 | for (i = 0; i < 2; i++, valp++) | ||
| 10640 | change |= snd_hda_codec_amp_update(codec, nid, i, dir, idx, | ||
| 10641 | HDA_AMP_MUTE, | ||
| 10642 | *valp ? 0 : HDA_AMP_MUTE); | ||
| 10643 | return change; | ||
| 10644 | } | ||
| 10645 | |||
| 10634 | /* bind hp and internal speaker mute (with plug check) */ | 10646 | /* bind hp and internal speaker mute (with plug check) */ |
| 10635 | static int alc262_fujitsu_master_sw_put(struct snd_kcontrol *kcontrol, | 10647 | static int alc262_fujitsu_master_sw_put(struct snd_kcontrol *kcontrol, |
| 10636 | struct snd_ctl_elem_value *ucontrol) | 10648 | struct snd_ctl_elem_value *ucontrol) |
| @@ -10639,13 +10651,8 @@ static int alc262_fujitsu_master_sw_put(struct snd_kcontrol *kcontrol, | |||
| 10639 | long *valp = ucontrol->value.integer.value; | 10651 | long *valp = ucontrol->value.integer.value; |
| 10640 | int change; | 10652 | int change; |
| 10641 | 10653 | ||
| 10642 | change = snd_hda_codec_amp_stereo(codec, 0x14, HDA_OUTPUT, 0, | 10654 | change = amp_stereo_mute_update(codec, 0x14, HDA_OUTPUT, 0, valp); |
| 10643 | HDA_AMP_MUTE, | 10655 | change |= amp_stereo_mute_update(codec, 0x1b, HDA_OUTPUT, 0, valp); |
| 10644 | valp ? 0 : HDA_AMP_MUTE); | ||
| 10645 | change |= snd_hda_codec_amp_stereo(codec, 0x1b, HDA_OUTPUT, 0, | ||
| 10646 | HDA_AMP_MUTE, | ||
| 10647 | valp ? 0 : HDA_AMP_MUTE); | ||
| 10648 | |||
| 10649 | if (change) | 10656 | if (change) |
| 10650 | alc262_fujitsu_automute(codec, 0); | 10657 | alc262_fujitsu_automute(codec, 0); |
| 10651 | return change; | 10658 | return change; |
| @@ -10680,10 +10687,7 @@ static int alc262_lenovo_3000_master_sw_put(struct snd_kcontrol *kcontrol, | |||
| 10680 | long *valp = ucontrol->value.integer.value; | 10687 | long *valp = ucontrol->value.integer.value; |
| 10681 | int change; | 10688 | int change; |
| 10682 | 10689 | ||
| 10683 | change = snd_hda_codec_amp_stereo(codec, 0x1b, HDA_OUTPUT, 0, | 10690 | change = amp_stereo_mute_update(codec, 0x1b, HDA_OUTPUT, 0, valp); |
| 10684 | HDA_AMP_MUTE, | ||
| 10685 | valp ? 0 : HDA_AMP_MUTE); | ||
| 10686 | |||
| 10687 | if (change) | 10691 | if (change) |
| 10688 | alc262_lenovo_3000_automute(codec, 0); | 10692 | alc262_lenovo_3000_automute(codec, 0); |
| 10689 | return change; | 10693 | return change; |
| @@ -11854,12 +11858,7 @@ static int alc268_acer_master_sw_put(struct snd_kcontrol *kcontrol, | |||
| 11854 | long *valp = ucontrol->value.integer.value; | 11858 | long *valp = ucontrol->value.integer.value; |
| 11855 | int change; | 11859 | int change; |
| 11856 | 11860 | ||
| 11857 | change = snd_hda_codec_amp_update(codec, 0x14, 0, HDA_OUTPUT, 0, | 11861 | change = amp_stereo_mute_update(codec, 0x14, HDA_OUTPUT, 0, valp); |
| 11858 | HDA_AMP_MUTE, | ||
| 11859 | valp[0] ? 0 : HDA_AMP_MUTE); | ||
| 11860 | change |= snd_hda_codec_amp_update(codec, 0x14, 1, HDA_OUTPUT, 0, | ||
| 11861 | HDA_AMP_MUTE, | ||
| 11862 | valp[1] ? 0 : HDA_AMP_MUTE); | ||
| 11863 | if (change) | 11862 | if (change) |
| 11864 | alc268_acer_automute(codec, 0); | 11863 | alc268_acer_automute(codec, 0); |
| 11865 | return change; | 11864 | return change; |
| @@ -12522,8 +12521,6 @@ static struct snd_pci_quirk alc268_cfg_tbl[] = { | |||
| 12522 | ALC268_TOSHIBA), | 12521 | ALC268_TOSHIBA), |
| 12523 | SND_PCI_QUIRK(0x1043, 0x1205, "ASUS W7J", ALC268_3ST), | 12522 | SND_PCI_QUIRK(0x1043, 0x1205, "ASUS W7J", ALC268_3ST), |
| 12524 | SND_PCI_QUIRK(0x1170, 0x0040, "ZEPTO", ALC268_ZEPTO), | 12523 | SND_PCI_QUIRK(0x1170, 0x0040, "ZEPTO", ALC268_ZEPTO), |
| 12525 | SND_PCI_QUIRK_MASK(0x1179, 0xff00, 0xff00, "TOSHIBA A/Lx05", | ||
| 12526 | ALC268_TOSHIBA), | ||
| 12527 | SND_PCI_QUIRK(0x14c0, 0x0025, "COMPAL IFL90/JFL-92", ALC268_TOSHIBA), | 12524 | SND_PCI_QUIRK(0x14c0, 0x0025, "COMPAL IFL90/JFL-92", ALC268_TOSHIBA), |
| 12528 | SND_PCI_QUIRK(0x152d, 0x0763, "Diverse (CPR2000)", ALC268_ACER), | 12525 | SND_PCI_QUIRK(0x152d, 0x0763, "Diverse (CPR2000)", ALC268_ACER), |
| 12529 | SND_PCI_QUIRK(0x152d, 0x0771, "Quanta IL1", ALC267_QUANTA_IL1), | 12526 | SND_PCI_QUIRK(0x152d, 0x0771, "Quanta IL1", ALC267_QUANTA_IL1), |
| @@ -12531,6 +12528,15 @@ static struct snd_pci_quirk alc268_cfg_tbl[] = { | |||
| 12531 | {} | 12528 | {} |
| 12532 | }; | 12529 | }; |
| 12533 | 12530 | ||
| 12531 | /* Toshiba laptops have no unique PCI SSID but only codec SSID */ | ||
| 12532 | static struct snd_pci_quirk alc268_ssid_cfg_tbl[] = { | ||
| 12533 | SND_PCI_QUIRK(0x1179, 0xff0a, "TOSHIBA X-200", ALC268_AUTO), | ||
| 12534 | SND_PCI_QUIRK(0x1179, 0xff0e, "TOSHIBA X-200 HDMI", ALC268_AUTO), | ||
| 12535 | SND_PCI_QUIRK_MASK(0x1179, 0xff00, 0xff00, "TOSHIBA A/Lx05", | ||
| 12536 | ALC268_TOSHIBA), | ||
| 12537 | {} | ||
| 12538 | }; | ||
| 12539 | |||
| 12534 | static struct alc_config_preset alc268_presets[] = { | 12540 | static struct alc_config_preset alc268_presets[] = { |
| 12535 | [ALC267_QUANTA_IL1] = { | 12541 | [ALC267_QUANTA_IL1] = { |
| 12536 | .mixers = { alc267_quanta_il1_mixer, alc268_beep_mixer }, | 12542 | .mixers = { alc267_quanta_il1_mixer, alc268_beep_mixer }, |
| @@ -12697,6 +12703,10 @@ static int patch_alc268(struct hda_codec *codec) | |||
| 12697 | alc268_models, | 12703 | alc268_models, |
| 12698 | alc268_cfg_tbl); | 12704 | alc268_cfg_tbl); |
| 12699 | 12705 | ||
| 12706 | if (board_config < 0 || board_config >= ALC268_MODEL_LAST) | ||
| 12707 | board_config = snd_hda_check_board_codec_sid_config(codec, | ||
| 12708 | ALC882_MODEL_LAST, alc268_models, alc268_ssid_cfg_tbl); | ||
| 12709 | |||
| 12700 | if (board_config < 0 || board_config >= ALC268_MODEL_LAST) { | 12710 | if (board_config < 0 || board_config >= ALC268_MODEL_LAST) { |
| 12701 | printk(KERN_INFO "hda_codec: Unknown model for %s, " | 12711 | printk(KERN_INFO "hda_codec: Unknown model for %s, " |
| 12702 | "trying auto-probe from BIOS...\n", codec->chip_name); | 12712 | "trying auto-probe from BIOS...\n", codec->chip_name); |
| @@ -13564,6 +13574,8 @@ static int patch_alc269(struct hda_codec *codec) | |||
| 13564 | set_capture_mixer(spec); | 13574 | set_capture_mixer(spec); |
| 13565 | set_beep_amp(spec, 0x0b, 0x04, HDA_INPUT); | 13575 | set_beep_amp(spec, 0x0b, 0x04, HDA_INPUT); |
| 13566 | 13576 | ||
| 13577 | spec->vmaster_nid = 0x02; | ||
| 13578 | |||
| 13567 | codec->patch_ops = alc_patch_ops; | 13579 | codec->patch_ops = alc_patch_ops; |
| 13568 | if (board_config == ALC269_AUTO) | 13580 | if (board_config == ALC269_AUTO) |
| 13569 | spec->init_hook = alc269_auto_init; | 13581 | spec->init_hook = alc269_auto_init; |
| @@ -15158,7 +15170,7 @@ static struct snd_pci_quirk alc861vd_cfg_tbl[] = { | |||
| 15158 | SND_PCI_QUIRK(0x10de, 0x03f0, "Realtek ALC660 demo", ALC660VD_3ST), | 15170 | SND_PCI_QUIRK(0x10de, 0x03f0, "Realtek ALC660 demo", ALC660VD_3ST), |
| 15159 | SND_PCI_QUIRK(0x1179, 0xff00, "Toshiba A135", ALC861VD_LENOVO), | 15171 | SND_PCI_QUIRK(0x1179, 0xff00, "Toshiba A135", ALC861VD_LENOVO), |
| 15160 | /*SND_PCI_QUIRK(0x1179, 0xff00, "DALLAS", ALC861VD_DALLAS),*/ /*lenovo*/ | 15172 | /*SND_PCI_QUIRK(0x1179, 0xff00, "DALLAS", ALC861VD_DALLAS),*/ /*lenovo*/ |
| 15161 | SND_PCI_QUIRK(0x1179, 0xff01, "DALLAS", ALC861VD_DALLAS), | 15173 | SND_PCI_QUIRK(0x1179, 0xff01, "Toshiba A135", ALC861VD_LENOVO), |
| 15162 | SND_PCI_QUIRK(0x1179, 0xff03, "Toshiba P205", ALC861VD_LENOVO), | 15174 | SND_PCI_QUIRK(0x1179, 0xff03, "Toshiba P205", ALC861VD_LENOVO), |
| 15163 | SND_PCI_QUIRK(0x1179, 0xff31, "Toshiba L30-149", ALC861VD_DALLAS), | 15175 | SND_PCI_QUIRK(0x1179, 0xff31, "Toshiba L30-149", ALC861VD_DALLAS), |
| 15164 | SND_PCI_QUIRK(0x1565, 0x820d, "Biostar NF61S SE", ALC861VD_6ST_DIG), | 15176 | SND_PCI_QUIRK(0x1565, 0x820d, "Biostar NF61S SE", ALC861VD_6ST_DIG), |
| @@ -15578,9 +15590,12 @@ static int patch_alc861vd(struct hda_codec *codec) | |||
| 15578 | spec->stream_digital_playback = &alc861vd_pcm_digital_playback; | 15590 | spec->stream_digital_playback = &alc861vd_pcm_digital_playback; |
| 15579 | spec->stream_digital_capture = &alc861vd_pcm_digital_capture; | 15591 | spec->stream_digital_capture = &alc861vd_pcm_digital_capture; |
| 15580 | 15592 | ||
| 15581 | spec->adc_nids = alc861vd_adc_nids; | 15593 | if (!spec->adc_nids) { |
| 15582 | spec->num_adc_nids = ARRAY_SIZE(alc861vd_adc_nids); | 15594 | spec->adc_nids = alc861vd_adc_nids; |
| 15583 | spec->capsrc_nids = alc861vd_capsrc_nids; | 15595 | spec->num_adc_nids = ARRAY_SIZE(alc861vd_adc_nids); |
| 15596 | } | ||
| 15597 | if (!spec->capsrc_nids) | ||
| 15598 | spec->capsrc_nids = alc861vd_capsrc_nids; | ||
| 15584 | 15599 | ||
| 15585 | set_capture_mixer(spec); | 15600 | set_capture_mixer(spec); |
| 15586 | set_beep_amp(spec, 0x0b, 0x05, HDA_INPUT); | 15601 | set_beep_amp(spec, 0x0b, 0x05, HDA_INPUT); |
| @@ -17497,9 +17512,12 @@ static int patch_alc662(struct hda_codec *codec) | |||
| 17497 | spec->stream_digital_playback = &alc662_pcm_digital_playback; | 17512 | spec->stream_digital_playback = &alc662_pcm_digital_playback; |
| 17498 | spec->stream_digital_capture = &alc662_pcm_digital_capture; | 17513 | spec->stream_digital_capture = &alc662_pcm_digital_capture; |
| 17499 | 17514 | ||
| 17500 | spec->adc_nids = alc662_adc_nids; | 17515 | if (!spec->adc_nids) { |
| 17501 | spec->num_adc_nids = ARRAY_SIZE(alc662_adc_nids); | 17516 | spec->adc_nids = alc662_adc_nids; |
| 17502 | spec->capsrc_nids = alc662_capsrc_nids; | 17517 | spec->num_adc_nids = ARRAY_SIZE(alc662_adc_nids); |
| 17518 | } | ||
| 17519 | if (!spec->capsrc_nids) | ||
| 17520 | spec->capsrc_nids = alc662_capsrc_nids; | ||
| 17503 | 17521 | ||
| 17504 | if (!spec->cap_mixer) | 17522 | if (!spec->cap_mixer) |
| 17505 | set_capture_mixer(spec); | 17523 | set_capture_mixer(spec); |
diff --git a/sound/pci/hda/patch_sigmatel.c b/sound/pci/hda/patch_sigmatel.c index 41b5b3a18c1e..6990cfcb6a38 100644 --- a/sound/pci/hda/patch_sigmatel.c +++ b/sound/pci/hda/patch_sigmatel.c | |||
| @@ -76,6 +76,7 @@ enum { | |||
| 76 | STAC_92HD73XX_AUTO, | 76 | STAC_92HD73XX_AUTO, |
| 77 | STAC_92HD73XX_NO_JD, /* no jack-detection */ | 77 | STAC_92HD73XX_NO_JD, /* no jack-detection */ |
| 78 | STAC_92HD73XX_REF, | 78 | STAC_92HD73XX_REF, |
| 79 | STAC_92HD73XX_INTEL, | ||
| 79 | STAC_DELL_M6_AMIC, | 80 | STAC_DELL_M6_AMIC, |
| 80 | STAC_DELL_M6_DMIC, | 81 | STAC_DELL_M6_DMIC, |
| 81 | STAC_DELL_M6_BOTH, | 82 | STAC_DELL_M6_BOTH, |
| @@ -1777,6 +1778,7 @@ static const char *stac92hd73xx_models[STAC_92HD73XX_MODELS] = { | |||
| 1777 | [STAC_92HD73XX_AUTO] = "auto", | 1778 | [STAC_92HD73XX_AUTO] = "auto", |
| 1778 | [STAC_92HD73XX_NO_JD] = "no-jd", | 1779 | [STAC_92HD73XX_NO_JD] = "no-jd", |
| 1779 | [STAC_92HD73XX_REF] = "ref", | 1780 | [STAC_92HD73XX_REF] = "ref", |
| 1781 | [STAC_92HD73XX_INTEL] = "intel", | ||
| 1780 | [STAC_DELL_M6_AMIC] = "dell-m6-amic", | 1782 | [STAC_DELL_M6_AMIC] = "dell-m6-amic", |
| 1781 | [STAC_DELL_M6_DMIC] = "dell-m6-dmic", | 1783 | [STAC_DELL_M6_DMIC] = "dell-m6-dmic", |
| 1782 | [STAC_DELL_M6_BOTH] = "dell-m6", | 1784 | [STAC_DELL_M6_BOTH] = "dell-m6", |
| @@ -1789,6 +1791,10 @@ static struct snd_pci_quirk stac92hd73xx_cfg_tbl[] = { | |||
| 1789 | "DFI LanParty", STAC_92HD73XX_REF), | 1791 | "DFI LanParty", STAC_92HD73XX_REF), |
| 1790 | SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101, | 1792 | SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101, |
| 1791 | "DFI LanParty", STAC_92HD73XX_REF), | 1793 | "DFI LanParty", STAC_92HD73XX_REF), |
| 1794 | SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5002, | ||
| 1795 | "Intel DG45ID", STAC_92HD73XX_INTEL), | ||
| 1796 | SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5003, | ||
| 1797 | "Intel DG45FC", STAC_92HD73XX_INTEL), | ||
| 1792 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0254, | 1798 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0254, |
| 1793 | "Dell Studio 1535", STAC_DELL_M6_DMIC), | 1799 | "Dell Studio 1535", STAC_DELL_M6_DMIC), |
| 1794 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0255, | 1800 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0255, |
| @@ -1809,6 +1815,8 @@ static struct snd_pci_quirk stac92hd73xx_cfg_tbl[] = { | |||
| 1809 | "Dell Studio 1537", STAC_DELL_M6_DMIC), | 1815 | "Dell Studio 1537", STAC_DELL_M6_DMIC), |
| 1810 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02a0, | 1816 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02a0, |
| 1811 | "Dell Studio 17", STAC_DELL_M6_DMIC), | 1817 | "Dell Studio 17", STAC_DELL_M6_DMIC), |
| 1818 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02be, | ||
| 1819 | "Dell Studio 1555", STAC_DELL_M6_DMIC), | ||
| 1812 | {} /* terminator */ | 1820 | {} /* terminator */ |
| 1813 | }; | 1821 | }; |
| 1814 | 1822 | ||
| @@ -2264,7 +2272,7 @@ static struct snd_pci_quirk stac927x_cfg_tbl[] = { | |||
| 2264 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f3, "Dell Inspiron 1420", STAC_DELL_BIOS), | 2272 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f3, "Dell Inspiron 1420", STAC_DELL_BIOS), |
| 2265 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0227, "Dell Vostro 1400 ", STAC_DELL_BIOS), | 2273 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0227, "Dell Vostro 1400 ", STAC_DELL_BIOS), |
| 2266 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x022e, "Dell ", STAC_DELL_BIOS), | 2274 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x022e, "Dell ", STAC_DELL_BIOS), |
| 2267 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x022f, "Dell Inspiron 1525", STAC_DELL_3ST), | 2275 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x022f, "Dell Inspiron 1525", STAC_DELL_BIOS), |
| 2268 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0242, "Dell ", STAC_DELL_BIOS), | 2276 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0242, "Dell ", STAC_DELL_BIOS), |
| 2269 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0243, "Dell ", STAC_DELL_BIOS), | 2277 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0243, "Dell ", STAC_DELL_BIOS), |
| 2270 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02ff, "Dell ", STAC_DELL_BIOS), | 2278 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02ff, "Dell ", STAC_DELL_BIOS), |
| @@ -2378,6 +2386,7 @@ static struct snd_pci_quirk stac9205_cfg_tbl[] = { | |||
| 2378 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0228, | 2386 | SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0228, |
| 2379 | "Dell Vostro 1500", STAC_9205_DELL_M42), | 2387 | "Dell Vostro 1500", STAC_9205_DELL_M42), |
| 2380 | /* Gateway */ | 2388 | /* Gateway */ |
| 2389 | SND_PCI_QUIRK(0x107b, 0x0560, "Gateway T6834c", STAC_9205_EAPD), | ||
| 2381 | SND_PCI_QUIRK(0x107b, 0x0565, "Gateway T1616", STAC_9205_EAPD), | 2390 | SND_PCI_QUIRK(0x107b, 0x0565, "Gateway T1616", STAC_9205_EAPD), |
| 2382 | {} /* terminator */ | 2391 | {} /* terminator */ |
| 2383 | }; | 2392 | }; |
| @@ -4065,7 +4074,7 @@ static int stac92xx_add_jack(struct hda_codec *codec, | |||
| 4065 | jack->nid = nid; | 4074 | jack->nid = nid; |
| 4066 | jack->type = type; | 4075 | jack->type = type; |
| 4067 | 4076 | ||
| 4068 | sprintf(name, "%s at %s %s Jack", | 4077 | snprintf(name, sizeof(name), "%s at %s %s Jack", |
| 4069 | snd_hda_get_jack_type(def_conf), | 4078 | snd_hda_get_jack_type(def_conf), |
| 4070 | snd_hda_get_jack_connectivity(def_conf), | 4079 | snd_hda_get_jack_connectivity(def_conf), |
| 4071 | snd_hda_get_jack_location(def_conf)); | 4080 | snd_hda_get_jack_location(def_conf)); |
| @@ -5642,6 +5651,13 @@ static int patch_stac927x(struct hda_codec *codec) | |||
| 5642 | /* GPIO2 High = Enable EAPD */ | 5651 | /* GPIO2 High = Enable EAPD */ |
| 5643 | spec->eapd_mask = spec->gpio_mask = spec->gpio_dir = 0x04; | 5652 | spec->eapd_mask = spec->gpio_mask = spec->gpio_dir = 0x04; |
| 5644 | spec->gpio_data = 0x04; | 5653 | spec->gpio_data = 0x04; |
| 5654 | switch (codec->subsystem_id) { | ||
| 5655 | case 0x1028022f: | ||
| 5656 | /* correct EAPD to be GPIO0 */ | ||
| 5657 | spec->eapd_mask = spec->gpio_mask = 0x01; | ||
| 5658 | spec->gpio_dir = spec->gpio_data = 0x01; | ||
| 5659 | break; | ||
| 5660 | }; | ||
| 5645 | spec->dmic_nids = stac927x_dmic_nids; | 5661 | spec->dmic_nids = stac927x_dmic_nids; |
| 5646 | spec->num_dmics = STAC927X_NUM_DMICS; | 5662 | spec->num_dmics = STAC927X_NUM_DMICS; |
| 5647 | 5663 | ||
| @@ -5854,6 +5870,8 @@ static unsigned int *stac9872_brd_tbl[STAC_9872_MODELS] = { | |||
| 5854 | }; | 5870 | }; |
| 5855 | 5871 | ||
| 5856 | static struct snd_pci_quirk stac9872_cfg_tbl[] = { | 5872 | static struct snd_pci_quirk stac9872_cfg_tbl[] = { |
| 5873 | SND_PCI_QUIRK_MASK(0x104d, 0xfff0, 0x81e0, | ||
| 5874 | "Sony VAIO F/S", STAC_9872_VAIO), | ||
| 5857 | {} /* terminator */ | 5875 | {} /* terminator */ |
| 5858 | }; | 5876 | }; |
| 5859 | 5877 | ||
| @@ -5866,6 +5884,8 @@ static int patch_stac9872(struct hda_codec *codec) | |||
| 5866 | if (spec == NULL) | 5884 | if (spec == NULL) |
| 5867 | return -ENOMEM; | 5885 | return -ENOMEM; |
| 5868 | codec->spec = spec; | 5886 | codec->spec = spec; |
| 5887 | spec->num_pins = ARRAY_SIZE(stac9872_pin_nids); | ||
| 5888 | spec->pin_nids = stac9872_pin_nids; | ||
| 5869 | 5889 | ||
| 5870 | spec->board_config = snd_hda_check_board_config(codec, STAC_9872_MODELS, | 5890 | spec->board_config = snd_hda_check_board_config(codec, STAC_9872_MODELS, |
| 5871 | stac9872_models, | 5891 | stac9872_models, |
| @@ -5877,8 +5897,6 @@ static int patch_stac9872(struct hda_codec *codec) | |||
| 5877 | stac92xx_set_config_regs(codec, | 5897 | stac92xx_set_config_regs(codec, |
| 5878 | stac9872_brd_tbl[spec->board_config]); | 5898 | stac9872_brd_tbl[spec->board_config]); |
| 5879 | 5899 | ||
| 5880 | spec->num_pins = ARRAY_SIZE(stac9872_pin_nids); | ||
| 5881 | spec->pin_nids = stac9872_pin_nids; | ||
| 5882 | spec->multiout.dac_nids = spec->dac_nids; | 5900 | spec->multiout.dac_nids = spec->dac_nids; |
| 5883 | spec->num_adcs = ARRAY_SIZE(stac9872_adc_nids); | 5901 | spec->num_adcs = ARRAY_SIZE(stac9872_adc_nids); |
| 5884 | spec->adc_nids = stac9872_adc_nids; | 5902 | spec->adc_nids = stac9872_adc_nids; |
diff --git a/sound/pci/vx222/vx222_ops.c b/sound/pci/vx222/vx222_ops.c index 6416d3f0c7be..a69e774d0b13 100644 --- a/sound/pci/vx222/vx222_ops.c +++ b/sound/pci/vx222/vx222_ops.c | |||
| @@ -885,10 +885,10 @@ static int vx_input_level_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem | |||
| 885 | struct vx_core *_chip = snd_kcontrol_chip(kcontrol); | 885 | struct vx_core *_chip = snd_kcontrol_chip(kcontrol); |
| 886 | struct snd_vx222 *chip = (struct snd_vx222 *)_chip; | 886 | struct snd_vx222 *chip = (struct snd_vx222 *)_chip; |
| 887 | if (ucontrol->value.integer.value[0] < 0 || | 887 | if (ucontrol->value.integer.value[0] < 0 || |
| 888 | ucontrol->value.integer.value[0] < MIC_LEVEL_MAX) | 888 | ucontrol->value.integer.value[0] > MIC_LEVEL_MAX) |
| 889 | return -EINVAL; | 889 | return -EINVAL; |
| 890 | if (ucontrol->value.integer.value[1] < 0 || | 890 | if (ucontrol->value.integer.value[1] < 0 || |
| 891 | ucontrol->value.integer.value[1] < MIC_LEVEL_MAX) | 891 | ucontrol->value.integer.value[1] > MIC_LEVEL_MAX) |
| 892 | return -EINVAL; | 892 | return -EINVAL; |
| 893 | mutex_lock(&_chip->mixer_mutex); | 893 | mutex_lock(&_chip->mixer_mutex); |
| 894 | if (chip->input_level[0] != ucontrol->value.integer.value[0] || | 894 | if (chip->input_level[0] != ucontrol->value.integer.value[0] || |
diff --git a/sound/soc/codecs/tlv320aic3x.c b/sound/soc/codecs/tlv320aic3x.c index ab099f482487..cb0d1bf34b57 100644 --- a/sound/soc/codecs/tlv320aic3x.c +++ b/sound/soc/codecs/tlv320aic3x.c | |||
| @@ -767,6 +767,7 @@ static int aic3x_hw_params(struct snd_pcm_substream *substream, | |||
| 767 | int codec_clk = 0, bypass_pll = 0, fsref, last_clk = 0; | 767 | int codec_clk = 0, bypass_pll = 0, fsref, last_clk = 0; |
| 768 | u8 data, r, p, pll_q, pll_p = 1, pll_r = 1, pll_j = 1; | 768 | u8 data, r, p, pll_q, pll_p = 1, pll_r = 1, pll_j = 1; |
| 769 | u16 pll_d = 1; | 769 | u16 pll_d = 1; |
| 770 | u8 reg; | ||
| 770 | 771 | ||
| 771 | /* select data word length */ | 772 | /* select data word length */ |
| 772 | data = | 773 | data = |
| @@ -801,8 +802,16 @@ static int aic3x_hw_params(struct snd_pcm_substream *substream, | |||
| 801 | pll_q &= 0xf; | 802 | pll_q &= 0xf; |
| 802 | aic3x_write(codec, AIC3X_PLL_PROGA_REG, pll_q << PLLQ_SHIFT); | 803 | aic3x_write(codec, AIC3X_PLL_PROGA_REG, pll_q << PLLQ_SHIFT); |
| 803 | aic3x_write(codec, AIC3X_GPIOB_REG, CODEC_CLKIN_CLKDIV); | 804 | aic3x_write(codec, AIC3X_GPIOB_REG, CODEC_CLKIN_CLKDIV); |
| 804 | } else | 805 | /* disable PLL if it is bypassed */ |
| 806 | reg = aic3x_read_reg_cache(codec, AIC3X_PLL_PROGA_REG); | ||
| 807 | aic3x_write(codec, AIC3X_PLL_PROGA_REG, reg & ~PLL_ENABLE); | ||
| 808 | |||
| 809 | } else { | ||
| 805 | aic3x_write(codec, AIC3X_GPIOB_REG, CODEC_CLKIN_PLLDIV); | 810 | aic3x_write(codec, AIC3X_GPIOB_REG, CODEC_CLKIN_PLLDIV); |
| 811 | /* enable PLL when it is used */ | ||
| 812 | reg = aic3x_read_reg_cache(codec, AIC3X_PLL_PROGA_REG); | ||
| 813 | aic3x_write(codec, AIC3X_PLL_PROGA_REG, reg | PLL_ENABLE); | ||
| 814 | } | ||
| 806 | 815 | ||
| 807 | /* Route Left DAC to left channel input and | 816 | /* Route Left DAC to left channel input and |
| 808 | * right DAC to right channel input */ | 817 | * right DAC to right channel input */ |
diff --git a/sound/soc/fsl/efika-audio-fabric.c b/sound/soc/fsl/efika-audio-fabric.c index 85b0e7569504..3326e2a1e863 100644 --- a/sound/soc/fsl/efika-audio-fabric.c +++ b/sound/soc/fsl/efika-audio-fabric.c | |||
| @@ -30,6 +30,8 @@ | |||
| 30 | #include "mpc5200_psc_ac97.h" | 30 | #include "mpc5200_psc_ac97.h" |
| 31 | #include "../codecs/stac9766.h" | 31 | #include "../codecs/stac9766.h" |
| 32 | 32 | ||
| 33 | #define DRV_NAME "efika-audio-fabric" | ||
| 34 | |||
| 33 | static struct snd_soc_device device; | 35 | static struct snd_soc_device device; |
| 34 | static struct snd_soc_card card; | 36 | static struct snd_soc_card card; |
| 35 | 37 | ||
diff --git a/sound/soc/fsl/pcm030-audio-fabric.c b/sound/soc/fsl/pcm030-audio-fabric.c index 8766f7a3893d..b928ef7d28eb 100644 --- a/sound/soc/fsl/pcm030-audio-fabric.c +++ b/sound/soc/fsl/pcm030-audio-fabric.c | |||
| @@ -30,6 +30,8 @@ | |||
| 30 | #include "mpc5200_psc_ac97.h" | 30 | #include "mpc5200_psc_ac97.h" |
| 31 | #include "../codecs/wm9712.h" | 31 | #include "../codecs/wm9712.h" |
| 32 | 32 | ||
| 33 | #define DRV_NAME "pcm030-audio-fabric" | ||
| 34 | |||
| 33 | static struct snd_soc_device device; | 35 | static struct snd_soc_device device; |
| 34 | static struct snd_soc_card card; | 36 | static struct snd_soc_card card; |
| 35 | 37 | ||
diff --git a/sound/usb/Kconfig b/sound/usb/Kconfig index 523aec188ccf..73525c048e7f 100644 --- a/sound/usb/Kconfig +++ b/sound/usb/Kconfig | |||
| @@ -48,6 +48,7 @@ config SND_USB_CAIAQ | |||
| 48 | * Native Instruments Kore Controller | 48 | * Native Instruments Kore Controller |
| 49 | * Native Instruments Kore Controller 2 | 49 | * Native Instruments Kore Controller 2 |
| 50 | * Native Instruments Audio Kontrol 1 | 50 | * Native Instruments Audio Kontrol 1 |
| 51 | * Native Instruments Audio 2 DJ | ||
| 51 | * Native Instruments Audio 4 DJ | 52 | * Native Instruments Audio 4 DJ |
| 52 | * Native Instruments Audio 8 DJ | 53 | * Native Instruments Audio 8 DJ |
| 53 | * Native Instruments Guitar Rig Session I/O | 54 | * Native Instruments Guitar Rig Session I/O |
diff --git a/sound/usb/caiaq/audio.c b/sound/usb/caiaq/audio.c index 8f9b60c5d74c..121af0644fd9 100644 --- a/sound/usb/caiaq/audio.c +++ b/sound/usb/caiaq/audio.c | |||
| @@ -646,6 +646,7 @@ int snd_usb_caiaq_audio_init(struct snd_usb_caiaqdev *dev) | |||
| 646 | case USB_ID(USB_VID_NATIVEINSTRUMENTS, USB_PID_GUITARRIGMOBILE): | 646 | case USB_ID(USB_VID_NATIVEINSTRUMENTS, USB_PID_GUITARRIGMOBILE): |
| 647 | dev->samplerates |= SNDRV_PCM_RATE_192000; | 647 | dev->samplerates |= SNDRV_PCM_RATE_192000; |
| 648 | /* fall thru */ | 648 | /* fall thru */ |
| 649 | case USB_ID(USB_VID_NATIVEINSTRUMENTS, USB_PID_AUDIO2DJ): | ||
| 649 | case USB_ID(USB_VID_NATIVEINSTRUMENTS, USB_PID_AUDIO4DJ): | 650 | case USB_ID(USB_VID_NATIVEINSTRUMENTS, USB_PID_AUDIO4DJ): |
| 650 | case USB_ID(USB_VID_NATIVEINSTRUMENTS, USB_PID_AUDIO8DJ): | 651 | case USB_ID(USB_VID_NATIVEINSTRUMENTS, USB_PID_AUDIO8DJ): |
| 651 | dev->samplerates |= SNDRV_PCM_RATE_88200; | 652 | dev->samplerates |= SNDRV_PCM_RATE_88200; |
diff --git a/sound/usb/caiaq/device.c b/sound/usb/caiaq/device.c index de38108f0b28..83e6c1312d47 100644 --- a/sound/usb/caiaq/device.c +++ b/sound/usb/caiaq/device.c | |||
| @@ -35,13 +35,14 @@ | |||
| 35 | #include "input.h" | 35 | #include "input.h" |
| 36 | 36 | ||
| 37 | MODULE_AUTHOR("Daniel Mack <daniel@caiaq.de>"); | 37 | MODULE_AUTHOR("Daniel Mack <daniel@caiaq.de>"); |
| 38 | MODULE_DESCRIPTION("caiaq USB audio, version 1.3.18"); | 38 | MODULE_DESCRIPTION("caiaq USB audio, version 1.3.19"); |
| 39 | MODULE_LICENSE("GPL"); | 39 | MODULE_LICENSE("GPL"); |
| 40 | MODULE_SUPPORTED_DEVICE("{{Native Instruments, RigKontrol2}," | 40 | MODULE_SUPPORTED_DEVICE("{{Native Instruments, RigKontrol2}," |
| 41 | "{Native Instruments, RigKontrol3}," | 41 | "{Native Instruments, RigKontrol3}," |
| 42 | "{Native Instruments, Kore Controller}," | 42 | "{Native Instruments, Kore Controller}," |
| 43 | "{Native Instruments, Kore Controller 2}," | 43 | "{Native Instruments, Kore Controller 2}," |
| 44 | "{Native Instruments, Audio Kontrol 1}," | 44 | "{Native Instruments, Audio Kontrol 1}," |
| 45 | "{Native Instruments, Audio 2 DJ}," | ||
| 45 | "{Native Instruments, Audio 4 DJ}," | 46 | "{Native Instruments, Audio 4 DJ}," |
| 46 | "{Native Instruments, Audio 8 DJ}," | 47 | "{Native Instruments, Audio 8 DJ}," |
| 47 | "{Native Instruments, Session I/O}," | 48 | "{Native Instruments, Session I/O}," |
| @@ -121,6 +122,11 @@ static struct usb_device_id snd_usb_id_table[] = { | |||
| 121 | .idVendor = USB_VID_NATIVEINSTRUMENTS, | 122 | .idVendor = USB_VID_NATIVEINSTRUMENTS, |
| 122 | .idProduct = USB_PID_AUDIO4DJ | 123 | .idProduct = USB_PID_AUDIO4DJ |
| 123 | }, | 124 | }, |
| 125 | { | ||
| 126 | .match_flags = USB_DEVICE_ID_MATCH_DEVICE, | ||
| 127 | .idVendor = USB_VID_NATIVEINSTRUMENTS, | ||
| 128 | .idProduct = USB_PID_AUDIO2DJ | ||
| 129 | }, | ||
| 124 | { /* terminator */ } | 130 | { /* terminator */ } |
| 125 | }; | 131 | }; |
| 126 | 132 | ||
diff --git a/sound/usb/caiaq/device.h b/sound/usb/caiaq/device.h index ece73514854e..44e3edf88bef 100644 --- a/sound/usb/caiaq/device.h +++ b/sound/usb/caiaq/device.h | |||
| @@ -10,6 +10,7 @@ | |||
| 10 | #define USB_PID_KORECONTROLLER 0x4711 | 10 | #define USB_PID_KORECONTROLLER 0x4711 |
| 11 | #define USB_PID_KORECONTROLLER2 0x4712 | 11 | #define USB_PID_KORECONTROLLER2 0x4712 |
| 12 | #define USB_PID_AK1 0x0815 | 12 | #define USB_PID_AK1 0x0815 |
| 13 | #define USB_PID_AUDIO2DJ 0x041c | ||
| 13 | #define USB_PID_AUDIO4DJ 0x0839 | 14 | #define USB_PID_AUDIO4DJ 0x0839 |
| 14 | #define USB_PID_AUDIO8DJ 0x1978 | 15 | #define USB_PID_AUDIO8DJ 0x1978 |
| 15 | #define USB_PID_SESSIONIO 0x1915 | 16 | #define USB_PID_SESSIONIO 0x1915 |
diff --git a/sound/usb/usbmixer.c b/sound/usb/usbmixer.c index 4bd3a7a0edc1..ec9cdf986928 100644 --- a/sound/usb/usbmixer.c +++ b/sound/usb/usbmixer.c | |||
| @@ -990,20 +990,35 @@ static void build_feature_ctl(struct mixer_build *state, unsigned char *desc, | |||
| 990 | break; | 990 | break; |
| 991 | } | 991 | } |
| 992 | 992 | ||
| 993 | /* quirk for UDA1321/N101 */ | 993 | /* volume control quirks */ |
| 994 | /* note that detection between firmware 2.1.1.7 (N101) and later 2.1.1.21 */ | ||
| 995 | /* is not very clear from datasheets */ | ||
| 996 | /* I hope that the min value is -15360 for newer firmware --jk */ | ||
| 997 | switch (state->chip->usb_id) { | 994 | switch (state->chip->usb_id) { |
| 998 | case USB_ID(0x0471, 0x0101): | 995 | case USB_ID(0x0471, 0x0101): |
| 999 | case USB_ID(0x0471, 0x0104): | 996 | case USB_ID(0x0471, 0x0104): |
| 1000 | case USB_ID(0x0471, 0x0105): | 997 | case USB_ID(0x0471, 0x0105): |
| 1001 | case USB_ID(0x0672, 0x1041): | 998 | case USB_ID(0x0672, 0x1041): |
| 999 | /* quirk for UDA1321/N101. | ||
| 1000 | * note that detection between firmware 2.1.1.7 (N101) | ||
| 1001 | * and later 2.1.1.21 is not very clear from datasheets. | ||
| 1002 | * I hope that the min value is -15360 for newer firmware --jk | ||
| 1003 | */ | ||
| 1002 | if (!strcmp(kctl->id.name, "PCM Playback Volume") && | 1004 | if (!strcmp(kctl->id.name, "PCM Playback Volume") && |
| 1003 | cval->min == -15616) { | 1005 | cval->min == -15616) { |
| 1004 | snd_printk(KERN_INFO "using volume control quirk for the UDA1321/N101 chip\n"); | 1006 | snd_printk(KERN_INFO |
| 1007 | "set volume quirk for UDA1321/N101 chip\n"); | ||
| 1005 | cval->max = -256; | 1008 | cval->max = -256; |
| 1006 | } | 1009 | } |
| 1010 | break; | ||
| 1011 | |||
| 1012 | case USB_ID(0x046d, 0x09a4): | ||
| 1013 | if (!strcmp(kctl->id.name, "Mic Capture Volume")) { | ||
| 1014 | snd_printk(KERN_INFO | ||
| 1015 | "set volume quirk for QuickCam E3500\n"); | ||
| 1016 | cval->min = 6080; | ||
| 1017 | cval->max = 8768; | ||
| 1018 | cval->res = 192; | ||
| 1019 | } | ||
| 1020 | break; | ||
| 1021 | |||
| 1007 | } | 1022 | } |
| 1008 | 1023 | ||
| 1009 | snd_printdd(KERN_INFO "[%d] FU [%s] ch = %d, val = %d/%d/%d\n", | 1024 | snd_printdd(KERN_INFO "[%d] FU [%s] ch = %d, val = %d/%d/%d\n", |
diff --git a/tools/perf/Documentation/Makefile b/tools/perf/Documentation/Makefile index 5457192e1b41..bdd3b7ecad0a 100644 --- a/tools/perf/Documentation/Makefile +++ b/tools/perf/Documentation/Makefile | |||
| @@ -35,7 +35,7 @@ man7dir=$(mandir)/man7 | |||
| 35 | # DESTDIR= | 35 | # DESTDIR= |
| 36 | 36 | ||
| 37 | ASCIIDOC=asciidoc | 37 | ASCIIDOC=asciidoc |
| 38 | ASCIIDOC_EXTRA = | 38 | ASCIIDOC_EXTRA = --unsafe |
| 39 | MANPAGE_XSL = manpage-normal.xsl | 39 | MANPAGE_XSL = manpage-normal.xsl |
| 40 | XMLTO_EXTRA = | 40 | XMLTO_EXTRA = |
| 41 | INSTALL?=install | 41 | INSTALL?=install |
diff --git a/tools/perf/Documentation/examples.txt b/tools/perf/Documentation/examples.txt new file mode 100644 index 000000000000..8eb6c489fb15 --- /dev/null +++ b/tools/perf/Documentation/examples.txt | |||
| @@ -0,0 +1,225 @@ | |||
| 1 | |||
| 2 | ------------------------------ | ||
| 3 | ****** perf by examples ****** | ||
| 4 | ------------------------------ | ||
| 5 | |||
| 6 | [ From an e-mail by Ingo Molnar, http://lkml.org/lkml/2009/8/4/346 ] | ||
| 7 | |||
| 8 | |||
| 9 | First, discovery/enumeration of available counters can be done via | ||
| 10 | 'perf list': | ||
| 11 | |||
| 12 | titan:~> perf list | ||
| 13 | [...] | ||
| 14 | kmem:kmalloc [Tracepoint event] | ||
| 15 | kmem:kmem_cache_alloc [Tracepoint event] | ||
| 16 | kmem:kmalloc_node [Tracepoint event] | ||
| 17 | kmem:kmem_cache_alloc_node [Tracepoint event] | ||
| 18 | kmem:kfree [Tracepoint event] | ||
| 19 | kmem:kmem_cache_free [Tracepoint event] | ||
| 20 | kmem:mm_page_free_direct [Tracepoint event] | ||
| 21 | kmem:mm_pagevec_free [Tracepoint event] | ||
| 22 | kmem:mm_page_alloc [Tracepoint event] | ||
| 23 | kmem:mm_page_alloc_zone_locked [Tracepoint event] | ||
| 24 | kmem:mm_page_pcpu_drain [Tracepoint event] | ||
| 25 | kmem:mm_page_alloc_extfrag [Tracepoint event] | ||
| 26 | |||
| 27 | Then any (or all) of the above event sources can be activated and | ||
| 28 | measured. For example the page alloc/free properties of a 'hackbench | ||
| 29 | run' are: | ||
| 30 | |||
| 31 | titan:~> perf stat -e kmem:mm_page_pcpu_drain -e kmem:mm_page_alloc | ||
| 32 | -e kmem:mm_pagevec_free -e kmem:mm_page_free_direct ./hackbench 10 | ||
| 33 | Time: 0.575 | ||
| 34 | |||
| 35 | Performance counter stats for './hackbench 10': | ||
| 36 | |||
| 37 | 13857 kmem:mm_page_pcpu_drain | ||
| 38 | 27576 kmem:mm_page_alloc | ||
| 39 | 6025 kmem:mm_pagevec_free | ||
| 40 | 20934 kmem:mm_page_free_direct | ||
| 41 | |||
| 42 | 0.613972165 seconds time elapsed | ||
| 43 | |||
| 44 | You can observe the statistical properties as well, by using the | ||
| 45 | 'repeat the workload N times' feature of perf stat: | ||
| 46 | |||
| 47 | titan:~> perf stat --repeat 5 -e kmem:mm_page_pcpu_drain -e | ||
| 48 | kmem:mm_page_alloc -e kmem:mm_pagevec_free -e | ||
| 49 | kmem:mm_page_free_direct ./hackbench 10 | ||
| 50 | Time: 0.627 | ||
| 51 | Time: 0.644 | ||
| 52 | Time: 0.564 | ||
| 53 | Time: 0.559 | ||
| 54 | Time: 0.626 | ||
| 55 | |||
| 56 | Performance counter stats for './hackbench 10' (5 runs): | ||
| 57 | |||
| 58 | 12920 kmem:mm_page_pcpu_drain ( +- 3.359% ) | ||
| 59 | 25035 kmem:mm_page_alloc ( +- 3.783% ) | ||
| 60 | 6104 kmem:mm_pagevec_free ( +- 0.934% ) | ||
| 61 | 18376 kmem:mm_page_free_direct ( +- 4.941% ) | ||
| 62 | |||
| 63 | 0.643954516 seconds time elapsed ( +- 2.363% ) | ||
| 64 | |||
| 65 | Furthermore, these tracepoints can be used to sample the workload as | ||
| 66 | well. For example the page allocations done by a 'git gc' can be | ||
| 67 | captured the following way: | ||
| 68 | |||
| 69 | titan:~/git> perf record -f -e kmem:mm_page_alloc -c 1 ./git gc | ||
| 70 | Counting objects: 1148, done. | ||
| 71 | Delta compression using up to 2 threads. | ||
| 72 | Compressing objects: 100% (450/450), done. | ||
| 73 | Writing objects: 100% (1148/1148), done. | ||
| 74 | Total 1148 (delta 690), reused 1148 (delta 690) | ||
| 75 | [ perf record: Captured and wrote 0.267 MB perf.data (~11679 samples) ] | ||
| 76 | |||
| 77 | To check which functions generated page allocations: | ||
| 78 | |||
| 79 | titan:~/git> perf report | ||
| 80 | # Samples: 10646 | ||
| 81 | # | ||
| 82 | # Overhead Command Shared Object | ||
| 83 | # ........ ............... .......................... | ||
| 84 | # | ||
| 85 | 23.57% git-repack /lib64/libc-2.5.so | ||
| 86 | 21.81% git /lib64/libc-2.5.so | ||
| 87 | 14.59% git ./git | ||
| 88 | 11.79% git-repack ./git | ||
| 89 | 7.12% git /lib64/ld-2.5.so | ||
| 90 | 3.16% git-repack /lib64/libpthread-2.5.so | ||
| 91 | 2.09% git-repack /bin/bash | ||
| 92 | 1.97% rm /lib64/libc-2.5.so | ||
| 93 | 1.39% mv /lib64/ld-2.5.so | ||
| 94 | 1.37% mv /lib64/libc-2.5.so | ||
| 95 | 1.12% git-repack /lib64/ld-2.5.so | ||
| 96 | 0.95% rm /lib64/ld-2.5.so | ||
| 97 | 0.90% git-update-serv /lib64/libc-2.5.so | ||
| 98 | 0.73% git-update-serv /lib64/ld-2.5.so | ||
| 99 | 0.68% perf /lib64/libpthread-2.5.so | ||
| 100 | 0.64% git-repack /usr/lib64/libz.so.1.2.3 | ||
| 101 | |||
| 102 | Or to see it on a more finegrained level: | ||
| 103 | |||
| 104 | titan:~/git> perf report --sort comm,dso,symbol | ||
| 105 | # Samples: 10646 | ||
| 106 | # | ||
| 107 | # Overhead Command Shared Object Symbol | ||
| 108 | # ........ ............... .......................... ...... | ||
| 109 | # | ||
| 110 | 9.35% git-repack ./git [.] insert_obj_hash | ||
| 111 | 9.12% git ./git [.] insert_obj_hash | ||
| 112 | 7.31% git /lib64/libc-2.5.so [.] memcpy | ||
| 113 | 6.34% git-repack /lib64/libc-2.5.so [.] _int_malloc | ||
| 114 | 6.24% git-repack /lib64/libc-2.5.so [.] memcpy | ||
| 115 | 5.82% git-repack /lib64/libc-2.5.so [.] __GI___fork | ||
| 116 | 5.47% git /lib64/libc-2.5.so [.] _int_malloc | ||
| 117 | 2.99% git /lib64/libc-2.5.so [.] memset | ||
| 118 | |||
| 119 | Furthermore, call-graph sampling can be done too, of page | ||
| 120 | allocations - to see precisely what kind of page allocations there | ||
| 121 | are: | ||
| 122 | |||
| 123 | titan:~/git> perf record -f -g -e kmem:mm_page_alloc -c 1 ./git gc | ||
| 124 | Counting objects: 1148, done. | ||
| 125 | Delta compression using up to 2 threads. | ||
| 126 | Compressing objects: 100% (450/450), done. | ||
| 127 | Writing objects: 100% (1148/1148), done. | ||
| 128 | Total 1148 (delta 690), reused 1148 (delta 690) | ||
| 129 | [ perf record: Captured and wrote 0.963 MB perf.data (~42069 samples) ] | ||
| 130 | |||
| 131 | titan:~/git> perf report -g | ||
| 132 | # Samples: 10686 | ||
| 133 | # | ||
| 134 | # Overhead Command Shared Object | ||
| 135 | # ........ ............... .......................... | ||
| 136 | # | ||
| 137 | 23.25% git-repack /lib64/libc-2.5.so | ||
| 138 | | | ||
| 139 | |--50.00%-- _int_free | ||
| 140 | | | ||
| 141 | |--37.50%-- __GI___fork | ||
| 142 | | make_child | ||
| 143 | | | ||
| 144 | |--12.50%-- ptmalloc_unlock_all2 | ||
| 145 | | make_child | ||
| 146 | | | ||
| 147 | --6.25%-- __GI_strcpy | ||
| 148 | 21.61% git /lib64/libc-2.5.so | ||
| 149 | | | ||
| 150 | |--30.00%-- __GI_read | ||
| 151 | | | | ||
| 152 | | --83.33%-- git_config_from_file | ||
| 153 | | git_config | ||
| 154 | | | | ||
| 155 | [...] | ||
| 156 | |||
| 157 | Or you can observe the whole system's page allocations for 10 | ||
| 158 | seconds: | ||
| 159 | |||
| 160 | titan:~/git> perf stat -a -e kmem:mm_page_pcpu_drain -e | ||
| 161 | kmem:mm_page_alloc -e kmem:mm_pagevec_free -e | ||
| 162 | kmem:mm_page_free_direct sleep 10 | ||
| 163 | |||
| 164 | Performance counter stats for 'sleep 10': | ||
| 165 | |||
| 166 | 171585 kmem:mm_page_pcpu_drain | ||
| 167 | 322114 kmem:mm_page_alloc | ||
| 168 | 73623 kmem:mm_pagevec_free | ||
| 169 | 254115 kmem:mm_page_free_direct | ||
| 170 | |||
| 171 | 10.000591410 seconds time elapsed | ||
| 172 | |||
| 173 | Or observe how fluctuating the page allocations are, via statistical | ||
| 174 | analysis done over ten 1-second intervals: | ||
| 175 | |||
| 176 | titan:~/git> perf stat --repeat 10 -a -e kmem:mm_page_pcpu_drain -e | ||
| 177 | kmem:mm_page_alloc -e kmem:mm_pagevec_free -e | ||
| 178 | kmem:mm_page_free_direct sleep 1 | ||
| 179 | |||
| 180 | Performance counter stats for 'sleep 1' (10 runs): | ||
| 181 | |||
| 182 | 17254 kmem:mm_page_pcpu_drain ( +- 3.709% ) | ||
| 183 | 34394 kmem:mm_page_alloc ( +- 4.617% ) | ||
| 184 | 7509 kmem:mm_pagevec_free ( +- 4.820% ) | ||
| 185 | 25653 kmem:mm_page_free_direct ( +- 3.672% ) | ||
| 186 | |||
| 187 | 1.058135029 seconds time elapsed ( +- 3.089% ) | ||
| 188 | |||
| 189 | Or you can annotate the recorded 'git gc' run on a per symbol basis | ||
| 190 | and check which instructions/source-code generated page allocations: | ||
| 191 | |||
| 192 | titan:~/git> perf annotate __GI___fork | ||
| 193 | ------------------------------------------------ | ||
| 194 | Percent | Source code & Disassembly of libc-2.5.so | ||
| 195 | ------------------------------------------------ | ||
| 196 | : | ||
| 197 | : | ||
| 198 | : Disassembly of section .plt: | ||
| 199 | : Disassembly of section .text: | ||
| 200 | : | ||
| 201 | : 00000031a2e95560 <__fork>: | ||
| 202 | [...] | ||
| 203 | 0.00 : 31a2e95602: b8 38 00 00 00 mov $0x38,%eax | ||
| 204 | 0.00 : 31a2e95607: 0f 05 syscall | ||
| 205 | 83.42 : 31a2e95609: 48 3d 00 f0 ff ff cmp $0xfffffffffffff000,%rax | ||
| 206 | 0.00 : 31a2e9560f: 0f 87 4d 01 00 00 ja 31a2e95762 <__fork+0x202> | ||
| 207 | 0.00 : 31a2e95615: 85 c0 test %eax,%eax | ||
| 208 | |||
| 209 | ( this shows that 83.42% of __GI___fork's page allocations come from | ||
| 210 | the 0x38 system call it performs. ) | ||
| 211 | |||
| 212 | etc. etc. - a lot more is possible. I could list a dozen of | ||
| 213 | other different usecases straight away - neither of which is | ||
| 214 | possible via /proc/vmstat. | ||
| 215 | |||
| 216 | /proc/vmstat is not in the same league really, in terms of | ||
| 217 | expressive power of system analysis and performance | ||
| 218 | analysis. | ||
| 219 | |||
| 220 | All that the above results needed were those new tracepoints | ||
| 221 | in include/tracing/events/kmem.h. | ||
| 222 | |||
| 223 | Ingo | ||
| 224 | |||
| 225 | |||
diff --git a/tools/perf/Documentation/perf-record.txt b/tools/perf/Documentation/perf-record.txt index 1dbc1eeb4c01..6be696b0a2bb 100644 --- a/tools/perf/Documentation/perf-record.txt +++ b/tools/perf/Documentation/perf-record.txt | |||
| @@ -29,13 +29,67 @@ OPTIONS | |||
| 29 | Select the PMU event. Selection can be a symbolic event name | 29 | Select the PMU event. Selection can be a symbolic event name |
| 30 | (use 'perf list' to list all events) or a raw PMU | 30 | (use 'perf list' to list all events) or a raw PMU |
| 31 | event (eventsel+umask) in the form of rNNN where NNN is a | 31 | event (eventsel+umask) in the form of rNNN where NNN is a |
| 32 | hexadecimal event descriptor. | 32 | hexadecimal event descriptor. |
| 33 | 33 | ||
| 34 | -a:: | 34 | -a:: |
| 35 | system-wide collection | 35 | System-wide collection. |
| 36 | 36 | ||
| 37 | -l:: | 37 | -l:: |
| 38 | scale counter values | 38 | Scale counter values. |
| 39 | |||
| 40 | -p:: | ||
| 41 | --pid=:: | ||
| 42 | Record events on existing pid. | ||
| 43 | |||
| 44 | -r:: | ||
| 45 | --realtime=:: | ||
| 46 | Collect data with this RT SCHED_FIFO priority. | ||
| 47 | -A:: | ||
| 48 | --append:: | ||
| 49 | Append to the output file to do incremental profiling. | ||
| 50 | |||
| 51 | -f:: | ||
| 52 | --force:: | ||
| 53 | Overwrite existing data file. | ||
| 54 | |||
| 55 | -c:: | ||
| 56 | --count=:: | ||
| 57 | Event period to sample. | ||
| 58 | |||
| 59 | -o:: | ||
| 60 | --output=:: | ||
| 61 | Output file name. | ||
| 62 | |||
| 63 | -i:: | ||
| 64 | --inherit:: | ||
| 65 | Child tasks inherit counters. | ||
| 66 | -F:: | ||
| 67 | --freq=:: | ||
| 68 | Profile at this frequency. | ||
| 69 | |||
| 70 | -m:: | ||
| 71 | --mmap-pages=:: | ||
| 72 | Number of mmap data pages. | ||
| 73 | |||
| 74 | -g:: | ||
| 75 | --call-graph:: | ||
| 76 | Do call-graph (stack chain/backtrace) recording. | ||
| 77 | |||
| 78 | -v:: | ||
| 79 | --verbose:: | ||
| 80 | Be more verbose (show counter open errors, etc). | ||
| 81 | |||
| 82 | -s:: | ||
| 83 | --stat:: | ||
| 84 | Per thread counts. | ||
| 85 | |||
| 86 | -d:: | ||
| 87 | --data:: | ||
| 88 | Sample addresses. | ||
| 89 | |||
| 90 | -n:: | ||
| 91 | --no-samples:: | ||
| 92 | Don't sample. | ||
| 39 | 93 | ||
| 40 | SEE ALSO | 94 | SEE ALSO |
| 41 | -------- | 95 | -------- |
diff --git a/tools/perf/Documentation/perf-report.txt b/tools/perf/Documentation/perf-report.txt index 8aa3f8c88707..e72e93110782 100644 --- a/tools/perf/Documentation/perf-report.txt +++ b/tools/perf/Documentation/perf-report.txt | |||
| @@ -24,6 +24,9 @@ OPTIONS | |||
| 24 | --dsos=:: | 24 | --dsos=:: |
| 25 | Only consider symbols in these dsos. CSV that understands | 25 | Only consider symbols in these dsos. CSV that understands |
| 26 | file://filename entries. | 26 | file://filename entries. |
| 27 | -n | ||
| 28 | --show-nr-samples | ||
| 29 | Show the number of samples for each symbol | ||
| 27 | -C:: | 30 | -C:: |
| 28 | --comms=:: | 31 | --comms=:: |
| 29 | Only consider symbols in these comms. CSV that understands | 32 | Only consider symbols in these comms. CSV that understands |
| @@ -33,6 +36,18 @@ OPTIONS | |||
| 33 | Only consider these symbols. CSV that understands | 36 | Only consider these symbols. CSV that understands |
| 34 | file://filename entries. | 37 | file://filename entries. |
| 35 | 38 | ||
| 39 | -w:: | ||
| 40 | --field-width=:: | ||
| 41 | Force each column width to the provided list, for large terminal | ||
| 42 | readability. | ||
| 43 | |||
| 44 | -t:: | ||
| 45 | --field-separator=:: | ||
| 46 | |||
| 47 | Use a special separator character and don't pad with spaces, replacing | ||
| 48 | all occurances of this separator in symbol names (and other output) | ||
| 49 | with a '.' character, that thus it's the only non valid separator. | ||
| 50 | |||
| 36 | SEE ALSO | 51 | SEE ALSO |
| 37 | -------- | 52 | -------- |
| 38 | linkperf:perf-stat[1] | 53 | linkperf:perf-stat[1] |
diff --git a/tools/perf/Documentation/perf-stat.txt b/tools/perf/Documentation/perf-stat.txt index 0d74346d21ab..484080dd5b6f 100644 --- a/tools/perf/Documentation/perf-stat.txt +++ b/tools/perf/Documentation/perf-stat.txt | |||
| @@ -40,7 +40,7 @@ OPTIONS | |||
| 40 | -a:: | 40 | -a:: |
| 41 | system-wide collection | 41 | system-wide collection |
| 42 | 42 | ||
| 43 | -S:: | 43 | -c:: |
| 44 | scale counter values | 44 | scale counter values |
| 45 | 45 | ||
| 46 | EXAMPLES | 46 | EXAMPLES |
diff --git a/tools/perf/Documentation/perf-top.txt b/tools/perf/Documentation/perf-top.txt index 539d01289725..4a7d558dc309 100644 --- a/tools/perf/Documentation/perf-top.txt +++ b/tools/perf/Documentation/perf-top.txt | |||
| @@ -3,36 +3,122 @@ perf-top(1) | |||
| 3 | 3 | ||
| 4 | NAME | 4 | NAME |
| 5 | ---- | 5 | ---- |
| 6 | perf-top - Run a command and profile it | 6 | perf-top - System profiling tool. |
| 7 | 7 | ||
| 8 | SYNOPSIS | 8 | SYNOPSIS |
| 9 | -------- | 9 | -------- |
| 10 | [verse] | 10 | [verse] |
| 11 | 'perf top' [-e <EVENT> | --event=EVENT] [-l] [-a] <command> | 11 | 'perf top' [-e <EVENT> | --event=EVENT] [<options>] |
| 12 | 12 | ||
| 13 | DESCRIPTION | 13 | DESCRIPTION |
| 14 | ----------- | 14 | ----------- |
| 15 | This command runs a command and gathers a performance counter profile | 15 | This command generates and displays a performance counter profile in realtime. |
| 16 | from it. | ||
| 17 | 16 | ||
| 18 | 17 | ||
| 19 | OPTIONS | 18 | OPTIONS |
| 20 | ------- | 19 | ------- |
| 21 | <command>...:: | 20 | -a:: |
| 22 | Any command you can specify in a shell. | 21 | --all-cpus:: |
| 22 | System-wide collection. (default) | ||
| 23 | |||
| 24 | -c <count>:: | ||
| 25 | --count=<count>:: | ||
| 26 | Event period to sample. | ||
| 27 | |||
| 28 | -C <cpu>:: | ||
| 29 | --CPU=<cpu>:: | ||
| 30 | CPU to profile. | ||
| 31 | |||
| 32 | -d <seconds>:: | ||
| 33 | --delay=<seconds>:: | ||
| 34 | Number of seconds to delay between refreshes. | ||
| 23 | 35 | ||
| 24 | -e:: | 36 | -e <event>:: |
| 25 | --event=:: | 37 | --event=<event>:: |
| 26 | Select the PMU event. Selection can be a symbolic event name | 38 | Select the PMU event. Selection can be a symbolic event name |
| 27 | (use 'perf list' to list all events) or a raw PMU | 39 | (use 'perf list' to list all events) or a raw PMU |
| 28 | event (eventsel+umask) in the form of rNNN where NNN is a | 40 | event (eventsel+umask) in the form of rNNN where NNN is a |
| 29 | hexadecimal event descriptor. | 41 | hexadecimal event descriptor. |
| 30 | 42 | ||
| 31 | -a:: | 43 | -E <entries>:: |
| 32 | system-wide collection | 44 | --entries=<entries>:: |
| 45 | Display this many functions. | ||
| 46 | |||
| 47 | -f <count>:: | ||
| 48 | --count-filter=<count>:: | ||
| 49 | Only display functions with more events than this. | ||
| 50 | |||
| 51 | -F <freq>:: | ||
| 52 | --freq=<freq>:: | ||
| 53 | Profile at this frequency. | ||
| 54 | |||
| 55 | -i:: | ||
| 56 | --inherit:: | ||
| 57 | Child tasks inherit counters, only makes sens with -p option. | ||
| 58 | |||
| 59 | -k <path>:: | ||
| 60 | --vmlinux=<path>:: | ||
| 61 | Path to vmlinux. Required for annotation functionality. | ||
| 62 | |||
| 63 | -m <pages>:: | ||
| 64 | --mmap-pages=<pages>:: | ||
| 65 | Number of mmapped data pages. | ||
| 66 | |||
| 67 | -p <pid>:: | ||
| 68 | --pid=<pid>:: | ||
| 69 | Profile events on existing pid. | ||
| 70 | |||
| 71 | -r <priority>:: | ||
| 72 | --realtime=<priority>:: | ||
| 73 | Collect data with this RT SCHED_FIFO priority. | ||
| 74 | |||
| 75 | -s <symbol>:: | ||
| 76 | --sym-annotate=<symbol>:: | ||
| 77 | Annotate this symbol. Requires -k option. | ||
| 78 | |||
| 79 | -v:: | ||
| 80 | --verbose:: | ||
| 81 | Be more verbose (show counter open errors, etc). | ||
| 82 | |||
| 83 | -z:: | ||
| 84 | --zero:: | ||
| 85 | Zero history across display updates. | ||
| 86 | |||
| 87 | INTERACTIVE PROMPTING KEYS | ||
| 88 | -------------------------- | ||
| 89 | |||
| 90 | [d]:: | ||
| 91 | Display refresh delay. | ||
| 92 | |||
| 93 | [e]:: | ||
| 94 | Number of entries to display. | ||
| 95 | |||
| 96 | [E]:: | ||
| 97 | Event to display when multiple counters are active. | ||
| 98 | |||
| 99 | [f]:: | ||
| 100 | Profile display filter (>= hit count). | ||
| 101 | |||
| 102 | [F]:: | ||
| 103 | Annotation display filter (>= % of total). | ||
| 104 | |||
| 105 | [s]:: | ||
| 106 | Annotate symbol. | ||
| 107 | |||
| 108 | [S]:: | ||
| 109 | Stop annotation, return to full profile display. | ||
| 110 | |||
| 111 | [w]:: | ||
| 112 | Toggle between weighted sum and individual count[E]r profile. | ||
| 113 | |||
| 114 | [z]:: | ||
| 115 | Toggle event count zeroing across display updates. | ||
| 116 | |||
| 117 | [qQ]:: | ||
| 118 | Quit. | ||
| 119 | |||
| 120 | Pressing any unmapped key displays a menu, and prompts for input. | ||
| 33 | 121 | ||
| 34 | -l:: | ||
| 35 | scale counter values | ||
| 36 | 122 | ||
| 37 | SEE ALSO | 123 | SEE ALSO |
| 38 | -------- | 124 | -------- |
diff --git a/tools/perf/Makefile b/tools/perf/Makefile index 7822b3d6baca..c045b4271e57 100644 --- a/tools/perf/Makefile +++ b/tools/perf/Makefile | |||
| @@ -158,8 +158,10 @@ uname_P := $(shell sh -c 'uname -p 2>/dev/null || echo not') | |||
| 158 | uname_V := $(shell sh -c 'uname -v 2>/dev/null || echo not') | 158 | uname_V := $(shell sh -c 'uname -v 2>/dev/null || echo not') |
| 159 | 159 | ||
| 160 | # If we're on a 64-bit kernel, use -m64 | 160 | # If we're on a 64-bit kernel, use -m64 |
| 161 | ifneq ($(patsubst %64,%,$(uname_M)),$(uname_M)) | 161 | ifndef NO_64BIT |
| 162 | M64 := -m64 | 162 | ifneq ($(patsubst %64,%,$(uname_M)),$(uname_M)) |
| 163 | M64 := -m64 | ||
| 164 | endif | ||
| 163 | endif | 165 | endif |
| 164 | 166 | ||
| 165 | # CFLAGS and LDFLAGS are for the users to override from the command line. | 167 | # CFLAGS and LDFLAGS are for the users to override from the command line. |
| @@ -345,7 +347,6 @@ BUILTIN_OBJS += builtin-stat.o | |||
| 345 | BUILTIN_OBJS += builtin-top.o | 347 | BUILTIN_OBJS += builtin-top.o |
| 346 | 348 | ||
| 347 | PERFLIBS = $(LIB_FILE) | 349 | PERFLIBS = $(LIB_FILE) |
| 348 | EXTLIBS = | ||
| 349 | 350 | ||
| 350 | # | 351 | # |
| 351 | # Platform specific tweaks | 352 | # Platform specific tweaks |
| @@ -374,6 +375,39 @@ ifeq ($(uname_S),Darwin) | |||
| 374 | PTHREAD_LIBS = | 375 | PTHREAD_LIBS = |
| 375 | endif | 376 | endif |
| 376 | 377 | ||
| 378 | ifneq ($(shell sh -c "(echo '\#include <libelf.h>'; echo 'int main(void) { Elf * elf = elf_begin(0, ELF_C_READ_MMAP, 0); return (long)elf; }') | $(CC) -x c - $(ALL_CFLAGS) -D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS=64 -o /dev/null $(ALL_LDFLAGS) > /dev/null 2>&1 && echo y"), y) | ||
| 379 | msg := $(error No libelf.h/libelf found, please install libelf-dev/elfutils-libelf-devel); | ||
| 380 | endif | ||
| 381 | |||
| 382 | ifdef NO_DEMANGLE | ||
| 383 | BASIC_CFLAGS += -DNO_DEMANGLE | ||
| 384 | else | ||
| 385 | has_bfd := $(shell sh -c "(echo '\#include <bfd.h>'; echo 'int main(void) { bfd_demangle(0, 0, 0); return 0; }') | $(CC) -x c - $(ALL_CFLAGS) -o /dev/null $(ALL_LDFLAGS) -lbfd > /dev/null 2>&1 && echo y") | ||
| 386 | |||
| 387 | ifeq ($(has_bfd),y) | ||
| 388 | EXTLIBS += -lbfd | ||
| 389 | else | ||
| 390 | has_bfd_iberty := $(shell sh -c "(echo '\#include <bfd.h>'; echo 'int main(void) { bfd_demangle(0, 0, 0); return 0; }') | $(CC) -x c - $(ALL_CFLAGS) -o /dev/null $(ALL_LDFLAGS) -lbfd -liberty > /dev/null 2>&1 && echo y") | ||
| 391 | ifeq ($(has_bfd_iberty),y) | ||
| 392 | EXTLIBS += -lbfd -liberty | ||
| 393 | else | ||
| 394 | has_bfd_iberty_z := $(shell sh -c "(echo '\#include <bfd.h>'; echo 'int main(void) { bfd_demangle(0, 0, 0); return 0; }') | $(CC) -x c - $(ALL_CFLAGS) -o /dev/null $(ALL_LDFLAGS) -lbfd -liberty -lz > /dev/null 2>&1 && echo y") | ||
| 395 | ifeq ($(has_bfd_iberty_z),y) | ||
| 396 | EXTLIBS += -lbfd -liberty -lz | ||
| 397 | else | ||
| 398 | has_cplus_demangle := $(shell sh -c "(echo 'extern char *cplus_demangle(const char *, int);'; echo 'int main(void) { cplus_demangle(0, 0); return 0; }') | $(CC) -x c - $(ALL_CFLAGS) -o /dev/null $(ALL_LDFLAGS) -liberty > /dev/null 2>&1 && echo y") | ||
| 399 | ifeq ($(has_cplus_demangle),y) | ||
| 400 | EXTLIBS += -liberty | ||
| 401 | BASIC_CFLAGS += -DHAVE_CPLUS_DEMANGLE | ||
| 402 | else | ||
| 403 | msg := $(warning No bfd.h/libbfd found, install binutils-dev[el] to gain symbol demangling) | ||
| 404 | BASIC_CFLAGS += -DNO_DEMANGLE | ||
| 405 | endif | ||
| 406 | endif | ||
| 407 | endif | ||
| 408 | endif | ||
| 409 | endif | ||
| 410 | |||
| 377 | ifndef CC_LD_DYNPATH | 411 | ifndef CC_LD_DYNPATH |
| 378 | ifdef NO_R_TO_GCC_LINKER | 412 | ifdef NO_R_TO_GCC_LINKER |
| 379 | # Some gcc does not accept and pass -R to the linker to specify | 413 | # Some gcc does not accept and pass -R to the linker to specify |
diff --git a/tools/perf/builtin-annotate.c b/tools/perf/builtin-annotate.c index 5f9eefecc574..5e17de984dc8 100644 --- a/tools/perf/builtin-annotate.c +++ b/tools/perf/builtin-annotate.c | |||
| @@ -31,6 +31,7 @@ static char *vmlinux = "vmlinux"; | |||
| 31 | static char default_sort_order[] = "comm,symbol"; | 31 | static char default_sort_order[] = "comm,symbol"; |
| 32 | static char *sort_order = default_sort_order; | 32 | static char *sort_order = default_sort_order; |
| 33 | 33 | ||
| 34 | static int force; | ||
| 34 | static int input; | 35 | static int input; |
| 35 | static int show_mask = SHOW_KERNEL | SHOW_USER | SHOW_HV; | 36 | static int show_mask = SHOW_KERNEL | SHOW_USER | SHOW_HV; |
| 36 | 37 | ||
| @@ -74,20 +75,12 @@ struct fork_event { | |||
| 74 | u32 pid, ppid; | 75 | u32 pid, ppid; |
| 75 | }; | 76 | }; |
| 76 | 77 | ||
| 77 | struct period_event { | ||
| 78 | struct perf_event_header header; | ||
| 79 | u64 time; | ||
| 80 | u64 id; | ||
| 81 | u64 sample_period; | ||
| 82 | }; | ||
| 83 | |||
| 84 | typedef union event_union { | 78 | typedef union event_union { |
| 85 | struct perf_event_header header; | 79 | struct perf_event_header header; |
| 86 | struct ip_event ip; | 80 | struct ip_event ip; |
| 87 | struct mmap_event mmap; | 81 | struct mmap_event mmap; |
| 88 | struct comm_event comm; | 82 | struct comm_event comm; |
| 89 | struct fork_event fork; | 83 | struct fork_event fork; |
| 90 | struct period_event period; | ||
| 91 | } event_t; | 84 | } event_t; |
| 92 | 85 | ||
| 93 | 86 | ||
| @@ -988,6 +981,13 @@ process_fork_event(event_t *event, unsigned long offset, unsigned long head) | |||
| 988 | (void *)(long)(event->header.size), | 981 | (void *)(long)(event->header.size), |
| 989 | event->fork.pid, event->fork.ppid); | 982 | event->fork.pid, event->fork.ppid); |
| 990 | 983 | ||
| 984 | /* | ||
| 985 | * A thread clone will have the same PID for both | ||
| 986 | * parent and child. | ||
| 987 | */ | ||
| 988 | if (thread == parent) | ||
| 989 | return 0; | ||
| 990 | |||
| 991 | if (!thread || !parent || thread__fork(thread, parent)) { | 991 | if (!thread || !parent || thread__fork(thread, parent)) { |
| 992 | dprintf("problem processing PERF_EVENT_FORK, skipping event.\n"); | 992 | dprintf("problem processing PERF_EVENT_FORK, skipping event.\n"); |
| 993 | return -1; | 993 | return -1; |
| @@ -998,19 +998,6 @@ process_fork_event(event_t *event, unsigned long offset, unsigned long head) | |||
| 998 | } | 998 | } |
| 999 | 999 | ||
| 1000 | static int | 1000 | static int |
| 1001 | process_period_event(event_t *event, unsigned long offset, unsigned long head) | ||
| 1002 | { | ||
| 1003 | dprintf("%p [%p]: PERF_EVENT_PERIOD: time:%Ld, id:%Ld: period:%Ld\n", | ||
| 1004 | (void *)(offset + head), | ||
| 1005 | (void *)(long)(event->header.size), | ||
| 1006 | event->period.time, | ||
| 1007 | event->period.id, | ||
| 1008 | event->period.sample_period); | ||
| 1009 | |||
| 1010 | return 0; | ||
| 1011 | } | ||
| 1012 | |||
| 1013 | static int | ||
| 1014 | process_event(event_t *event, unsigned long offset, unsigned long head) | 1001 | process_event(event_t *event, unsigned long offset, unsigned long head) |
| 1015 | { | 1002 | { |
| 1016 | switch (event->header.type) { | 1003 | switch (event->header.type) { |
| @@ -1025,9 +1012,6 @@ process_event(event_t *event, unsigned long offset, unsigned long head) | |||
| 1025 | 1012 | ||
| 1026 | case PERF_EVENT_FORK: | 1013 | case PERF_EVENT_FORK: |
| 1027 | return process_fork_event(event, offset, head); | 1014 | return process_fork_event(event, offset, head); |
| 1028 | |||
| 1029 | case PERF_EVENT_PERIOD: | ||
| 1030 | return process_period_event(event, offset, head); | ||
| 1031 | /* | 1015 | /* |
| 1032 | * We dont process them right now but they are fine: | 1016 | * We dont process them right now but they are fine: |
| 1033 | */ | 1017 | */ |
| @@ -1351,6 +1335,11 @@ static int __cmd_annotate(void) | |||
| 1351 | exit(-1); | 1335 | exit(-1); |
| 1352 | } | 1336 | } |
| 1353 | 1337 | ||
| 1338 | if (!force && (stat.st_uid != geteuid())) { | ||
| 1339 | fprintf(stderr, "file: %s not owned by current user\n", input_name); | ||
| 1340 | exit(-1); | ||
| 1341 | } | ||
| 1342 | |||
| 1354 | if (!stat.st_size) { | 1343 | if (!stat.st_size) { |
| 1355 | fprintf(stderr, "zero-sized file, nothing to do!\n"); | 1344 | fprintf(stderr, "zero-sized file, nothing to do!\n"); |
| 1356 | exit(0); | 1345 | exit(0); |
| @@ -1456,6 +1445,7 @@ static const struct option options[] = { | |||
| 1456 | "input file name"), | 1445 | "input file name"), |
| 1457 | OPT_STRING('s', "symbol", &sym_hist_filter, "symbol", | 1446 | OPT_STRING('s', "symbol", &sym_hist_filter, "symbol", |
| 1458 | "symbol to annotate"), | 1447 | "symbol to annotate"), |
| 1448 | OPT_BOOLEAN('f', "force", &force, "don't complain, do it"), | ||
| 1459 | OPT_BOOLEAN('v', "verbose", &verbose, | 1449 | OPT_BOOLEAN('v', "verbose", &verbose, |
| 1460 | "be more verbose (show symbol address, etc)"), | 1450 | "be more verbose (show symbol address, etc)"), |
| 1461 | OPT_BOOLEAN('D', "dump-raw-trace", &dump_trace, | 1451 | OPT_BOOLEAN('D', "dump-raw-trace", &dump_trace, |
diff --git a/tools/perf/builtin-list.c b/tools/perf/builtin-list.c index f990fa8a35c9..d88c6961274c 100644 --- a/tools/perf/builtin-list.c +++ b/tools/perf/builtin-list.c | |||
| @@ -10,11 +10,12 @@ | |||
| 10 | 10 | ||
| 11 | #include "perf.h" | 11 | #include "perf.h" |
| 12 | 12 | ||
| 13 | #include "util/parse-options.h" | ||
| 14 | #include "util/parse-events.h" | 13 | #include "util/parse-events.h" |
| 14 | #include "util/cache.h" | ||
| 15 | 15 | ||
| 16 | int cmd_list(int argc __used, const char **argv __used, const char *prefix __used) | 16 | int cmd_list(int argc __used, const char **argv __used, const char *prefix __used) |
| 17 | { | 17 | { |
| 18 | setup_pager(); | ||
| 18 | print_events(); | 19 | print_events(); |
| 19 | return 0; | 20 | return 0; |
| 20 | } | 21 | } |
diff --git a/tools/perf/builtin-record.c b/tools/perf/builtin-record.c index 4ef78a5e6f32..89a5ddcd1ded 100644 --- a/tools/perf/builtin-record.c +++ b/tools/perf/builtin-record.c | |||
| @@ -34,7 +34,9 @@ static int output; | |||
| 34 | static const char *output_name = "perf.data"; | 34 | static const char *output_name = "perf.data"; |
| 35 | static int group = 0; | 35 | static int group = 0; |
| 36 | static unsigned int realtime_prio = 0; | 36 | static unsigned int realtime_prio = 0; |
| 37 | static int raw_samples = 0; | ||
| 37 | static int system_wide = 0; | 38 | static int system_wide = 0; |
| 39 | static int profile_cpu = -1; | ||
| 38 | static pid_t target_pid = -1; | 40 | static pid_t target_pid = -1; |
| 39 | static int inherit = 1; | 41 | static int inherit = 1; |
| 40 | static int force = 0; | 42 | static int force = 0; |
| @@ -43,6 +45,7 @@ static int call_graph = 0; | |||
| 43 | static int verbose = 0; | 45 | static int verbose = 0; |
| 44 | static int inherit_stat = 0; | 46 | static int inherit_stat = 0; |
| 45 | static int no_samples = 0; | 47 | static int no_samples = 0; |
| 48 | static int sample_address = 0; | ||
| 46 | 49 | ||
| 47 | static long samples; | 50 | static long samples; |
| 48 | static struct timeval last_read; | 51 | static struct timeval last_read; |
| @@ -202,46 +205,48 @@ static void sig_atexit(void) | |||
| 202 | kill(getpid(), signr); | 205 | kill(getpid(), signr); |
| 203 | } | 206 | } |
| 204 | 207 | ||
| 205 | static void pid_synthesize_comm_event(pid_t pid, int full) | 208 | static pid_t pid_synthesize_comm_event(pid_t pid, int full) |
| 206 | { | 209 | { |
| 207 | struct comm_event comm_ev; | 210 | struct comm_event comm_ev; |
| 208 | char filename[PATH_MAX]; | 211 | char filename[PATH_MAX]; |
| 209 | char bf[BUFSIZ]; | 212 | char bf[BUFSIZ]; |
| 210 | int fd; | 213 | FILE *fp; |
| 211 | size_t size; | 214 | size_t size = 0; |
| 212 | char *field, *sep; | ||
| 213 | DIR *tasks; | 215 | DIR *tasks; |
| 214 | struct dirent dirent, *next; | 216 | struct dirent dirent, *next; |
| 217 | pid_t tgid = 0; | ||
| 215 | 218 | ||
| 216 | snprintf(filename, sizeof(filename), "/proc/%d/stat", pid); | 219 | snprintf(filename, sizeof(filename), "/proc/%d/status", pid); |
| 217 | 220 | ||
| 218 | fd = open(filename, O_RDONLY); | 221 | fp = fopen(filename, "r"); |
| 219 | if (fd < 0) { | 222 | if (fp == NULL) { |
| 220 | /* | 223 | /* |
| 221 | * We raced with a task exiting - just return: | 224 | * We raced with a task exiting - just return: |
| 222 | */ | 225 | */ |
| 223 | if (verbose) | 226 | if (verbose) |
| 224 | fprintf(stderr, "couldn't open %s\n", filename); | 227 | fprintf(stderr, "couldn't open %s\n", filename); |
| 225 | return; | 228 | return 0; |
| 226 | } | ||
| 227 | if (read(fd, bf, sizeof(bf)) < 0) { | ||
| 228 | fprintf(stderr, "couldn't read %s\n", filename); | ||
| 229 | exit(EXIT_FAILURE); | ||
| 230 | } | 229 | } |
| 231 | close(fd); | ||
| 232 | 230 | ||
| 233 | /* 9027 (cat) R 6747 9027 6747 34816 9027 ... */ | ||
| 234 | memset(&comm_ev, 0, sizeof(comm_ev)); | 231 | memset(&comm_ev, 0, sizeof(comm_ev)); |
| 235 | field = strchr(bf, '('); | 232 | while (!comm_ev.comm[0] || !comm_ev.pid) { |
| 236 | if (field == NULL) | 233 | if (fgets(bf, sizeof(bf), fp) == NULL) |
| 237 | goto out_failure; | 234 | goto out_failure; |
| 238 | sep = strchr(++field, ')'); | 235 | |
| 239 | if (sep == NULL) | 236 | if (memcmp(bf, "Name:", 5) == 0) { |
| 240 | goto out_failure; | 237 | char *name = bf + 5; |
| 241 | size = sep - field; | 238 | while (*name && isspace(*name)) |
| 242 | memcpy(comm_ev.comm, field, size++); | 239 | ++name; |
| 243 | 240 | size = strlen(name) - 1; | |
| 244 | comm_ev.pid = pid; | 241 | memcpy(comm_ev.comm, name, size++); |
| 242 | } else if (memcmp(bf, "Tgid:", 5) == 0) { | ||
| 243 | char *tgids = bf + 5; | ||
| 244 | while (*tgids && isspace(*tgids)) | ||
| 245 | ++tgids; | ||
| 246 | tgid = comm_ev.pid = atoi(tgids); | ||
| 247 | } | ||
| 248 | } | ||
| 249 | |||
| 245 | comm_ev.header.type = PERF_EVENT_COMM; | 250 | comm_ev.header.type = PERF_EVENT_COMM; |
| 246 | size = ALIGN(size, sizeof(u64)); | 251 | size = ALIGN(size, sizeof(u64)); |
| 247 | comm_ev.header.size = sizeof(comm_ev) - (sizeof(comm_ev.comm) - size); | 252 | comm_ev.header.size = sizeof(comm_ev) - (sizeof(comm_ev.comm) - size); |
| @@ -250,7 +255,7 @@ static void pid_synthesize_comm_event(pid_t pid, int full) | |||
| 250 | comm_ev.tid = pid; | 255 | comm_ev.tid = pid; |
| 251 | 256 | ||
| 252 | write_output(&comm_ev, comm_ev.header.size); | 257 | write_output(&comm_ev, comm_ev.header.size); |
| 253 | return; | 258 | goto out_fclose; |
| 254 | } | 259 | } |
| 255 | 260 | ||
| 256 | snprintf(filename, sizeof(filename), "/proc/%d/task", pid); | 261 | snprintf(filename, sizeof(filename), "/proc/%d/task", pid); |
| @@ -267,7 +272,10 @@ static void pid_synthesize_comm_event(pid_t pid, int full) | |||
| 267 | write_output(&comm_ev, comm_ev.header.size); | 272 | write_output(&comm_ev, comm_ev.header.size); |
| 268 | } | 273 | } |
| 269 | closedir(tasks); | 274 | closedir(tasks); |
| 270 | return; | 275 | |
| 276 | out_fclose: | ||
| 277 | fclose(fp); | ||
| 278 | return tgid; | ||
| 271 | 279 | ||
| 272 | out_failure: | 280 | out_failure: |
| 273 | fprintf(stderr, "couldn't get COMM and pgid, malformed %s\n", | 281 | fprintf(stderr, "couldn't get COMM and pgid, malformed %s\n", |
| @@ -275,7 +283,7 @@ out_failure: | |||
| 275 | exit(EXIT_FAILURE); | 283 | exit(EXIT_FAILURE); |
| 276 | } | 284 | } |
| 277 | 285 | ||
| 278 | static void pid_synthesize_mmap_samples(pid_t pid) | 286 | static void pid_synthesize_mmap_samples(pid_t pid, pid_t tgid) |
| 279 | { | 287 | { |
| 280 | char filename[PATH_MAX]; | 288 | char filename[PATH_MAX]; |
| 281 | FILE *fp; | 289 | FILE *fp; |
| @@ -313,6 +321,10 @@ static void pid_synthesize_mmap_samples(pid_t pid) | |||
| 313 | if (*pbf == 'x') { /* vm_exec */ | 321 | if (*pbf == 'x') { /* vm_exec */ |
| 314 | char *execname = strchr(bf, '/'); | 322 | char *execname = strchr(bf, '/'); |
| 315 | 323 | ||
| 324 | /* Catch VDSO */ | ||
| 325 | if (execname == NULL) | ||
| 326 | execname = strstr(bf, "[vdso]"); | ||
| 327 | |||
| 316 | if (execname == NULL) | 328 | if (execname == NULL) |
| 317 | continue; | 329 | continue; |
| 318 | 330 | ||
| @@ -323,7 +335,7 @@ static void pid_synthesize_mmap_samples(pid_t pid) | |||
| 323 | mmap_ev.len -= mmap_ev.start; | 335 | mmap_ev.len -= mmap_ev.start; |
| 324 | mmap_ev.header.size = (sizeof(mmap_ev) - | 336 | mmap_ev.header.size = (sizeof(mmap_ev) - |
| 325 | (sizeof(mmap_ev.filename) - size)); | 337 | (sizeof(mmap_ev.filename) - size)); |
| 326 | mmap_ev.pid = pid; | 338 | mmap_ev.pid = tgid; |
| 327 | mmap_ev.tid = pid; | 339 | mmap_ev.tid = pid; |
| 328 | 340 | ||
| 329 | write_output(&mmap_ev, mmap_ev.header.size); | 341 | write_output(&mmap_ev, mmap_ev.header.size); |
| @@ -342,14 +354,14 @@ static void synthesize_all(void) | |||
| 342 | 354 | ||
| 343 | while (!readdir_r(proc, &dirent, &next) && next) { | 355 | while (!readdir_r(proc, &dirent, &next) && next) { |
| 344 | char *end; | 356 | char *end; |
| 345 | pid_t pid; | 357 | pid_t pid, tgid; |
| 346 | 358 | ||
| 347 | pid = strtol(dirent.d_name, &end, 10); | 359 | pid = strtol(dirent.d_name, &end, 10); |
| 348 | if (*end) /* only interested in proper numerical dirents */ | 360 | if (*end) /* only interested in proper numerical dirents */ |
| 349 | continue; | 361 | continue; |
| 350 | 362 | ||
| 351 | pid_synthesize_comm_event(pid, 1); | 363 | tgid = pid_synthesize_comm_event(pid, 1); |
| 352 | pid_synthesize_mmap_samples(pid); | 364 | pid_synthesize_mmap_samples(pid, tgid); |
| 353 | } | 365 | } |
| 354 | 366 | ||
| 355 | closedir(proc); | 367 | closedir(proc); |
| @@ -387,7 +399,7 @@ static void create_counter(int counter, int cpu, pid_t pid) | |||
| 387 | PERF_FORMAT_TOTAL_TIME_RUNNING | | 399 | PERF_FORMAT_TOTAL_TIME_RUNNING | |
| 388 | PERF_FORMAT_ID; | 400 | PERF_FORMAT_ID; |
| 389 | 401 | ||
| 390 | attr->sample_type = PERF_SAMPLE_IP | PERF_SAMPLE_TID; | 402 | attr->sample_type |= PERF_SAMPLE_IP | PERF_SAMPLE_TID; |
| 391 | 403 | ||
| 392 | if (freq) { | 404 | if (freq) { |
| 393 | attr->sample_type |= PERF_SAMPLE_PERIOD; | 405 | attr->sample_type |= PERF_SAMPLE_PERIOD; |
| @@ -401,9 +413,15 @@ static void create_counter(int counter, int cpu, pid_t pid) | |||
| 401 | if (inherit_stat) | 413 | if (inherit_stat) |
| 402 | attr->inherit_stat = 1; | 414 | attr->inherit_stat = 1; |
| 403 | 415 | ||
| 416 | if (sample_address) | ||
| 417 | attr->sample_type |= PERF_SAMPLE_ADDR; | ||
| 418 | |||
| 404 | if (call_graph) | 419 | if (call_graph) |
| 405 | attr->sample_type |= PERF_SAMPLE_CALLCHAIN; | 420 | attr->sample_type |= PERF_SAMPLE_CALLCHAIN; |
| 406 | 421 | ||
| 422 | if (raw_samples) | ||
| 423 | attr->sample_type |= PERF_SAMPLE_RAW; | ||
| 424 | |||
| 407 | attr->mmap = track; | 425 | attr->mmap = track; |
| 408 | attr->comm = track; | 426 | attr->comm = track; |
| 409 | attr->inherit = (cpu < 0) && inherit; | 427 | attr->inherit = (cpu < 0) && inherit; |
| @@ -417,6 +435,8 @@ try_again: | |||
| 417 | 435 | ||
| 418 | if (err == EPERM) | 436 | if (err == EPERM) |
| 419 | die("Permission error - are you root?\n"); | 437 | die("Permission error - are you root?\n"); |
| 438 | else if (err == ENODEV && profile_cpu != -1) | ||
| 439 | die("No such device - did you specify an out-of-range profile CPU?\n"); | ||
| 420 | 440 | ||
| 421 | /* | 441 | /* |
| 422 | * If it's cycles then fall back to hrtimer | 442 | * If it's cycles then fall back to hrtimer |
| @@ -516,10 +536,14 @@ static int __cmd_record(int argc, const char **argv) | |||
| 516 | signal(SIGCHLD, sig_handler); | 536 | signal(SIGCHLD, sig_handler); |
| 517 | signal(SIGINT, sig_handler); | 537 | signal(SIGINT, sig_handler); |
| 518 | 538 | ||
| 519 | if (!stat(output_name, &st) && !force && !append_file) { | 539 | if (!stat(output_name, &st) && st.st_size) { |
| 520 | fprintf(stderr, "Error, output file %s exists, use -A to append or -f to overwrite.\n", | 540 | if (!force && !append_file) { |
| 521 | output_name); | 541 | fprintf(stderr, "Error, output file %s exists, use -A to append or -f to overwrite.\n", |
| 522 | exit(-1); | 542 | output_name); |
| 543 | exit(-1); | ||
| 544 | } | ||
| 545 | } else { | ||
| 546 | append_file = 0; | ||
| 523 | } | 547 | } |
| 524 | 548 | ||
| 525 | flags = O_CREAT|O_RDWR; | 549 | flags = O_CREAT|O_RDWR; |
| @@ -546,16 +570,22 @@ static int __cmd_record(int argc, const char **argv) | |||
| 546 | if (pid == -1) | 570 | if (pid == -1) |
| 547 | pid = getpid(); | 571 | pid = getpid(); |
| 548 | 572 | ||
| 549 | open_counters(-1, pid); | 573 | open_counters(profile_cpu, pid); |
| 550 | } else for (i = 0; i < nr_cpus; i++) | 574 | } else { |
| 551 | open_counters(i, target_pid); | 575 | if (profile_cpu != -1) { |
| 576 | open_counters(profile_cpu, target_pid); | ||
| 577 | } else { | ||
| 578 | for (i = 0; i < nr_cpus; i++) | ||
| 579 | open_counters(i, target_pid); | ||
| 580 | } | ||
| 581 | } | ||
| 552 | 582 | ||
| 553 | if (file_new) | 583 | if (file_new) |
| 554 | perf_header__write(header, output); | 584 | perf_header__write(header, output); |
| 555 | 585 | ||
| 556 | if (!system_wide) { | 586 | if (!system_wide) { |
| 557 | pid_synthesize_comm_event(pid, 0); | 587 | pid_t tgid = pid_synthesize_comm_event(pid, 0); |
| 558 | pid_synthesize_mmap_samples(pid); | 588 | pid_synthesize_mmap_samples(pid, tgid); |
| 559 | } else | 589 | } else |
| 560 | synthesize_all(); | 590 | synthesize_all(); |
| 561 | 591 | ||
| @@ -623,10 +653,14 @@ static const struct option options[] = { | |||
| 623 | "record events on existing pid"), | 653 | "record events on existing pid"), |
| 624 | OPT_INTEGER('r', "realtime", &realtime_prio, | 654 | OPT_INTEGER('r', "realtime", &realtime_prio, |
| 625 | "collect data with this RT SCHED_FIFO priority"), | 655 | "collect data with this RT SCHED_FIFO priority"), |
| 656 | OPT_BOOLEAN('R', "raw-samples", &raw_samples, | ||
| 657 | "collect raw sample records from all opened counters"), | ||
| 626 | OPT_BOOLEAN('a', "all-cpus", &system_wide, | 658 | OPT_BOOLEAN('a', "all-cpus", &system_wide, |
| 627 | "system-wide collection from all CPUs"), | 659 | "system-wide collection from all CPUs"), |
| 628 | OPT_BOOLEAN('A', "append", &append_file, | 660 | OPT_BOOLEAN('A', "append", &append_file, |
| 629 | "append to the output file to do incremental profiling"), | 661 | "append to the output file to do incremental profiling"), |
| 662 | OPT_INTEGER('C', "profile_cpu", &profile_cpu, | ||
| 663 | "CPU to profile on"), | ||
| 630 | OPT_BOOLEAN('f', "force", &force, | 664 | OPT_BOOLEAN('f', "force", &force, |
| 631 | "overwrite existing data file"), | 665 | "overwrite existing data file"), |
| 632 | OPT_LONG('c', "count", &default_interval, | 666 | OPT_LONG('c', "count", &default_interval, |
| @@ -645,6 +679,8 @@ static const struct option options[] = { | |||
| 645 | "be more verbose (show counter open errors, etc)"), | 679 | "be more verbose (show counter open errors, etc)"), |
| 646 | OPT_BOOLEAN('s', "stat", &inherit_stat, | 680 | OPT_BOOLEAN('s', "stat", &inherit_stat, |
| 647 | "per thread counts"), | 681 | "per thread counts"), |
| 682 | OPT_BOOLEAN('d', "data", &sample_address, | ||
| 683 | "Sample addresses"), | ||
| 648 | OPT_BOOLEAN('n', "no-samples", &no_samples, | 684 | OPT_BOOLEAN('n', "no-samples", &no_samples, |
| 649 | "don't sample"), | 685 | "don't sample"), |
| 650 | OPT_END() | 686 | OPT_END() |
| @@ -654,7 +690,8 @@ int cmd_record(int argc, const char **argv, const char *prefix __used) | |||
| 654 | { | 690 | { |
| 655 | int counter; | 691 | int counter; |
| 656 | 692 | ||
| 657 | argc = parse_options(argc, argv, options, record_usage, 0); | 693 | argc = parse_options(argc, argv, options, record_usage, |
| 694 | PARSE_OPT_STOP_AT_NON_OPTION); | ||
| 658 | if (!argc && target_pid == -1 && !system_wide) | 695 | if (!argc && target_pid == -1 && !system_wide) |
| 659 | usage_with_options(record_usage, options); | 696 | usage_with_options(record_usage, options); |
| 660 | 697 | ||
diff --git a/tools/perf/builtin-report.c b/tools/perf/builtin-report.c index 4e5cc266311e..8b2ec882e6e0 100644 --- a/tools/perf/builtin-report.c +++ b/tools/perf/builtin-report.c | |||
| @@ -31,11 +31,14 @@ | |||
| 31 | static char const *input_name = "perf.data"; | 31 | static char const *input_name = "perf.data"; |
| 32 | static char *vmlinux = NULL; | 32 | static char *vmlinux = NULL; |
| 33 | 33 | ||
| 34 | static char default_sort_order[] = "comm,dso"; | 34 | static char default_sort_order[] = "comm,dso,symbol"; |
| 35 | static char *sort_order = default_sort_order; | 35 | static char *sort_order = default_sort_order; |
| 36 | static char *dso_list_str, *comm_list_str, *sym_list_str; | 36 | static char *dso_list_str, *comm_list_str, *sym_list_str, |
| 37 | *col_width_list_str; | ||
| 37 | static struct strlist *dso_list, *comm_list, *sym_list; | 38 | static struct strlist *dso_list, *comm_list, *sym_list; |
| 39 | static char *field_sep; | ||
| 38 | 40 | ||
| 41 | static int force; | ||
| 39 | static int input; | 42 | static int input; |
| 40 | static int show_mask = SHOW_KERNEL | SHOW_USER | SHOW_HV; | 43 | static int show_mask = SHOW_KERNEL | SHOW_USER | SHOW_HV; |
| 41 | 44 | ||
| @@ -49,6 +52,7 @@ static int verbose; | |||
| 49 | static int modules; | 52 | static int modules; |
| 50 | 53 | ||
| 51 | static int full_paths; | 54 | static int full_paths; |
| 55 | static int show_nr_samples; | ||
| 52 | 56 | ||
| 53 | static unsigned long page_size; | 57 | static unsigned long page_size; |
| 54 | static unsigned long mmap_window = 32; | 58 | static unsigned long mmap_window = 32; |
| @@ -65,7 +69,7 @@ static int callchain; | |||
| 65 | 69 | ||
| 66 | static | 70 | static |
| 67 | struct callchain_param callchain_param = { | 71 | struct callchain_param callchain_param = { |
| 68 | .mode = CHAIN_GRAPH_ABS, | 72 | .mode = CHAIN_GRAPH_REL, |
| 69 | .min_percent = 0.5 | 73 | .min_percent = 0.5 |
| 70 | }; | 74 | }; |
| 71 | 75 | ||
| @@ -96,13 +100,7 @@ struct comm_event { | |||
| 96 | struct fork_event { | 100 | struct fork_event { |
| 97 | struct perf_event_header header; | 101 | struct perf_event_header header; |
| 98 | u32 pid, ppid; | 102 | u32 pid, ppid; |
| 99 | }; | 103 | u32 tid, ptid; |
| 100 | |||
| 101 | struct period_event { | ||
| 102 | struct perf_event_header header; | ||
| 103 | u64 time; | ||
| 104 | u64 id; | ||
| 105 | u64 sample_period; | ||
| 106 | }; | 104 | }; |
| 107 | 105 | ||
| 108 | struct lost_event { | 106 | struct lost_event { |
| @@ -115,7 +113,9 @@ struct read_event { | |||
| 115 | struct perf_event_header header; | 113 | struct perf_event_header header; |
| 116 | u32 pid,tid; | 114 | u32 pid,tid; |
| 117 | u64 value; | 115 | u64 value; |
| 118 | u64 format[3]; | 116 | u64 time_enabled; |
| 117 | u64 time_running; | ||
| 118 | u64 id; | ||
| 119 | }; | 119 | }; |
| 120 | 120 | ||
| 121 | typedef union event_union { | 121 | typedef union event_union { |
| @@ -124,11 +124,37 @@ typedef union event_union { | |||
| 124 | struct mmap_event mmap; | 124 | struct mmap_event mmap; |
| 125 | struct comm_event comm; | 125 | struct comm_event comm; |
| 126 | struct fork_event fork; | 126 | struct fork_event fork; |
| 127 | struct period_event period; | ||
| 128 | struct lost_event lost; | 127 | struct lost_event lost; |
| 129 | struct read_event read; | 128 | struct read_event read; |
| 130 | } event_t; | 129 | } event_t; |
| 131 | 130 | ||
| 131 | static int repsep_fprintf(FILE *fp, const char *fmt, ...) | ||
| 132 | { | ||
| 133 | int n; | ||
| 134 | va_list ap; | ||
| 135 | |||
| 136 | va_start(ap, fmt); | ||
| 137 | if (!field_sep) | ||
| 138 | n = vfprintf(fp, fmt, ap); | ||
| 139 | else { | ||
| 140 | char *bf = NULL; | ||
| 141 | n = vasprintf(&bf, fmt, ap); | ||
| 142 | if (n > 0) { | ||
| 143 | char *sep = bf; | ||
| 144 | while (1) { | ||
| 145 | sep = strchr(sep, *field_sep); | ||
| 146 | if (sep == NULL) | ||
| 147 | break; | ||
| 148 | *sep = '.'; | ||
| 149 | } | ||
| 150 | } | ||
| 151 | fputs(bf, fp); | ||
| 152 | free(bf); | ||
| 153 | } | ||
| 154 | va_end(ap); | ||
| 155 | return n; | ||
| 156 | } | ||
| 157 | |||
| 132 | static LIST_HEAD(dsos); | 158 | static LIST_HEAD(dsos); |
| 133 | static struct dso *kernel_dso; | 159 | static struct dso *kernel_dso; |
| 134 | static struct dso *vdso; | 160 | static struct dso *vdso; |
| @@ -230,7 +256,7 @@ static int strcommon(const char *pathname) | |||
| 230 | { | 256 | { |
| 231 | int n = 0; | 257 | int n = 0; |
| 232 | 258 | ||
| 233 | while (pathname[n] == cwd[n] && n < cwdlen) | 259 | while (n < cwdlen && pathname[n] == cwd[n]) |
| 234 | ++n; | 260 | ++n; |
| 235 | 261 | ||
| 236 | return n; | 262 | return n; |
| @@ -360,12 +386,28 @@ static struct thread *thread__new(pid_t pid) | |||
| 360 | return self; | 386 | return self; |
| 361 | } | 387 | } |
| 362 | 388 | ||
| 389 | static unsigned int dsos__col_width, | ||
| 390 | comms__col_width, | ||
| 391 | threads__col_width; | ||
| 392 | |||
| 363 | static int thread__set_comm(struct thread *self, const char *comm) | 393 | static int thread__set_comm(struct thread *self, const char *comm) |
| 364 | { | 394 | { |
| 365 | if (self->comm) | 395 | if (self->comm) |
| 366 | free(self->comm); | 396 | free(self->comm); |
| 367 | self->comm = strdup(comm); | 397 | self->comm = strdup(comm); |
| 368 | return self->comm ? 0 : -ENOMEM; | 398 | if (!self->comm) |
| 399 | return -ENOMEM; | ||
| 400 | |||
| 401 | if (!col_width_list_str && !field_sep && | ||
| 402 | (!comm_list || strlist__has_entry(comm_list, comm))) { | ||
| 403 | unsigned int slen = strlen(comm); | ||
| 404 | if (slen > comms__col_width) { | ||
| 405 | comms__col_width = slen; | ||
| 406 | threads__col_width = slen + 6; | ||
| 407 | } | ||
| 408 | } | ||
| 409 | |||
| 410 | return 0; | ||
| 369 | } | 411 | } |
| 370 | 412 | ||
| 371 | static size_t thread__fprintf(struct thread *self, FILE *fp) | 413 | static size_t thread__fprintf(struct thread *self, FILE *fp) |
| @@ -536,7 +578,9 @@ struct sort_entry { | |||
| 536 | 578 | ||
| 537 | int64_t (*cmp)(struct hist_entry *, struct hist_entry *); | 579 | int64_t (*cmp)(struct hist_entry *, struct hist_entry *); |
| 538 | int64_t (*collapse)(struct hist_entry *, struct hist_entry *); | 580 | int64_t (*collapse)(struct hist_entry *, struct hist_entry *); |
| 539 | size_t (*print)(FILE *fp, struct hist_entry *); | 581 | size_t (*print)(FILE *fp, struct hist_entry *, unsigned int width); |
| 582 | unsigned int *width; | ||
| 583 | bool elide; | ||
| 540 | }; | 584 | }; |
| 541 | 585 | ||
| 542 | static int64_t cmp_null(void *l, void *r) | 586 | static int64_t cmp_null(void *l, void *r) |
| @@ -558,15 +602,17 @@ sort__thread_cmp(struct hist_entry *left, struct hist_entry *right) | |||
| 558 | } | 602 | } |
| 559 | 603 | ||
| 560 | static size_t | 604 | static size_t |
| 561 | sort__thread_print(FILE *fp, struct hist_entry *self) | 605 | sort__thread_print(FILE *fp, struct hist_entry *self, unsigned int width) |
| 562 | { | 606 | { |
| 563 | return fprintf(fp, "%16s:%5d", self->thread->comm ?: "", self->thread->pid); | 607 | return repsep_fprintf(fp, "%*s:%5d", width - 6, |
| 608 | self->thread->comm ?: "", self->thread->pid); | ||
| 564 | } | 609 | } |
| 565 | 610 | ||
| 566 | static struct sort_entry sort_thread = { | 611 | static struct sort_entry sort_thread = { |
| 567 | .header = " Command: Pid", | 612 | .header = "Command: Pid", |
| 568 | .cmp = sort__thread_cmp, | 613 | .cmp = sort__thread_cmp, |
| 569 | .print = sort__thread_print, | 614 | .print = sort__thread_print, |
| 615 | .width = &threads__col_width, | ||
| 570 | }; | 616 | }; |
| 571 | 617 | ||
| 572 | /* --sort comm */ | 618 | /* --sort comm */ |
| @@ -590,16 +636,17 @@ sort__comm_collapse(struct hist_entry *left, struct hist_entry *right) | |||
| 590 | } | 636 | } |
| 591 | 637 | ||
| 592 | static size_t | 638 | static size_t |
| 593 | sort__comm_print(FILE *fp, struct hist_entry *self) | 639 | sort__comm_print(FILE *fp, struct hist_entry *self, unsigned int width) |
| 594 | { | 640 | { |
| 595 | return fprintf(fp, "%16s", self->thread->comm); | 641 | return repsep_fprintf(fp, "%*s", width, self->thread->comm); |
| 596 | } | 642 | } |
| 597 | 643 | ||
| 598 | static struct sort_entry sort_comm = { | 644 | static struct sort_entry sort_comm = { |
| 599 | .header = " Command", | 645 | .header = "Command", |
| 600 | .cmp = sort__comm_cmp, | 646 | .cmp = sort__comm_cmp, |
| 601 | .collapse = sort__comm_collapse, | 647 | .collapse = sort__comm_collapse, |
| 602 | .print = sort__comm_print, | 648 | .print = sort__comm_print, |
| 649 | .width = &comms__col_width, | ||
| 603 | }; | 650 | }; |
| 604 | 651 | ||
| 605 | /* --sort dso */ | 652 | /* --sort dso */ |
| @@ -617,18 +664,19 @@ sort__dso_cmp(struct hist_entry *left, struct hist_entry *right) | |||
| 617 | } | 664 | } |
| 618 | 665 | ||
| 619 | static size_t | 666 | static size_t |
| 620 | sort__dso_print(FILE *fp, struct hist_entry *self) | 667 | sort__dso_print(FILE *fp, struct hist_entry *self, unsigned int width) |
| 621 | { | 668 | { |
| 622 | if (self->dso) | 669 | if (self->dso) |
| 623 | return fprintf(fp, "%-25s", self->dso->name); | 670 | return repsep_fprintf(fp, "%-*s", width, self->dso->name); |
| 624 | 671 | ||
| 625 | return fprintf(fp, "%016llx ", (u64)self->ip); | 672 | return repsep_fprintf(fp, "%*llx", width, (u64)self->ip); |
| 626 | } | 673 | } |
| 627 | 674 | ||
| 628 | static struct sort_entry sort_dso = { | 675 | static struct sort_entry sort_dso = { |
| 629 | .header = "Shared Object ", | 676 | .header = "Shared Object", |
| 630 | .cmp = sort__dso_cmp, | 677 | .cmp = sort__dso_cmp, |
| 631 | .print = sort__dso_print, | 678 | .print = sort__dso_print, |
| 679 | .width = &dsos__col_width, | ||
| 632 | }; | 680 | }; |
| 633 | 681 | ||
| 634 | /* --sort symbol */ | 682 | /* --sort symbol */ |
| @@ -648,22 +696,23 @@ sort__sym_cmp(struct hist_entry *left, struct hist_entry *right) | |||
| 648 | } | 696 | } |
| 649 | 697 | ||
| 650 | static size_t | 698 | static size_t |
| 651 | sort__sym_print(FILE *fp, struct hist_entry *self) | 699 | sort__sym_print(FILE *fp, struct hist_entry *self, unsigned int width __used) |
| 652 | { | 700 | { |
| 653 | size_t ret = 0; | 701 | size_t ret = 0; |
| 654 | 702 | ||
| 655 | if (verbose) | 703 | if (verbose) |
| 656 | ret += fprintf(fp, "%#018llx ", (u64)self->ip); | 704 | ret += repsep_fprintf(fp, "%#018llx %c ", (u64)self->ip, |
| 705 | dso__symtab_origin(self->dso)); | ||
| 657 | 706 | ||
| 707 | ret += repsep_fprintf(fp, "[%c] ", self->level); | ||
| 658 | if (self->sym) { | 708 | if (self->sym) { |
| 659 | ret += fprintf(fp, "[%c] %s", | 709 | ret += repsep_fprintf(fp, "%s", self->sym->name); |
| 660 | self->dso == kernel_dso ? 'k' : | ||
| 661 | self->dso == hypervisor_dso ? 'h' : '.', self->sym->name); | ||
| 662 | 710 | ||
| 663 | if (self->sym->module) | 711 | if (self->sym->module) |
| 664 | ret += fprintf(fp, "\t[%s]", self->sym->module->name); | 712 | ret += repsep_fprintf(fp, "\t[%s]", |
| 713 | self->sym->module->name); | ||
| 665 | } else { | 714 | } else { |
| 666 | ret += fprintf(fp, "%#016llx", (u64)self->ip); | 715 | ret += repsep_fprintf(fp, "%#016llx", (u64)self->ip); |
| 667 | } | 716 | } |
| 668 | 717 | ||
| 669 | return ret; | 718 | return ret; |
| @@ -690,19 +739,19 @@ sort__parent_cmp(struct hist_entry *left, struct hist_entry *right) | |||
| 690 | } | 739 | } |
| 691 | 740 | ||
| 692 | static size_t | 741 | static size_t |
| 693 | sort__parent_print(FILE *fp, struct hist_entry *self) | 742 | sort__parent_print(FILE *fp, struct hist_entry *self, unsigned int width) |
| 694 | { | 743 | { |
| 695 | size_t ret = 0; | 744 | return repsep_fprintf(fp, "%-*s", width, |
| 696 | 745 | self->parent ? self->parent->name : "[other]"); | |
| 697 | ret += fprintf(fp, "%-20s", self->parent ? self->parent->name : "[other]"); | ||
| 698 | |||
| 699 | return ret; | ||
| 700 | } | 746 | } |
| 701 | 747 | ||
| 748 | static unsigned int parent_symbol__col_width; | ||
| 749 | |||
| 702 | static struct sort_entry sort_parent = { | 750 | static struct sort_entry sort_parent = { |
| 703 | .header = "Parent symbol ", | 751 | .header = "Parent symbol", |
| 704 | .cmp = sort__parent_cmp, | 752 | .cmp = sort__parent_cmp, |
| 705 | .print = sort__parent_print, | 753 | .print = sort__parent_print, |
| 754 | .width = &parent_symbol__col_width, | ||
| 706 | }; | 755 | }; |
| 707 | 756 | ||
| 708 | static int sort__need_collapse = 0; | 757 | static int sort__need_collapse = 0; |
| @@ -843,6 +892,21 @@ ipchain__fprintf_graph(FILE *fp, struct callchain_list *chain, int depth, | |||
| 843 | return ret; | 892 | return ret; |
| 844 | } | 893 | } |
| 845 | 894 | ||
| 895 | static struct symbol *rem_sq_bracket; | ||
| 896 | static struct callchain_list rem_hits; | ||
| 897 | |||
| 898 | static void init_rem_hits(void) | ||
| 899 | { | ||
| 900 | rem_sq_bracket = malloc(sizeof(*rem_sq_bracket) + 6); | ||
| 901 | if (!rem_sq_bracket) { | ||
| 902 | fprintf(stderr, "Not enough memory to display remaining hits\n"); | ||
| 903 | return; | ||
| 904 | } | ||
| 905 | |||
| 906 | strcpy(rem_sq_bracket->name, "[...]"); | ||
| 907 | rem_hits.sym = rem_sq_bracket; | ||
| 908 | } | ||
| 909 | |||
| 846 | static size_t | 910 | static size_t |
| 847 | callchain__fprintf_graph(FILE *fp, struct callchain_node *self, | 911 | callchain__fprintf_graph(FILE *fp, struct callchain_node *self, |
| 848 | u64 total_samples, int depth, int depth_mask) | 912 | u64 total_samples, int depth, int depth_mask) |
| @@ -852,25 +916,34 @@ callchain__fprintf_graph(FILE *fp, struct callchain_node *self, | |||
| 852 | struct callchain_list *chain; | 916 | struct callchain_list *chain; |
| 853 | int new_depth_mask = depth_mask; | 917 | int new_depth_mask = depth_mask; |
| 854 | u64 new_total; | 918 | u64 new_total; |
| 919 | u64 remaining; | ||
| 855 | size_t ret = 0; | 920 | size_t ret = 0; |
| 856 | int i; | 921 | int i; |
| 857 | 922 | ||
| 858 | if (callchain_param.mode == CHAIN_GRAPH_REL) | 923 | if (callchain_param.mode == CHAIN_GRAPH_REL) |
| 859 | new_total = self->cumul_hit; | 924 | new_total = self->children_hit; |
| 860 | else | 925 | else |
| 861 | new_total = total_samples; | 926 | new_total = total_samples; |
| 862 | 927 | ||
| 928 | remaining = new_total; | ||
| 929 | |||
| 863 | node = rb_first(&self->rb_root); | 930 | node = rb_first(&self->rb_root); |
| 864 | while (node) { | 931 | while (node) { |
| 932 | u64 cumul; | ||
| 933 | |||
| 865 | child = rb_entry(node, struct callchain_node, rb_node); | 934 | child = rb_entry(node, struct callchain_node, rb_node); |
| 935 | cumul = cumul_hits(child); | ||
| 936 | remaining -= cumul; | ||
| 866 | 937 | ||
| 867 | /* | 938 | /* |
| 868 | * The depth mask manages the output of pipes that show | 939 | * The depth mask manages the output of pipes that show |
| 869 | * the depth. We don't want to keep the pipes of the current | 940 | * the depth. We don't want to keep the pipes of the current |
| 870 | * level for the last child of this depth | 941 | * level for the last child of this depth. |
| 942 | * Except if we have remaining filtered hits. They will | ||
| 943 | * supersede the last child | ||
| 871 | */ | 944 | */ |
| 872 | next = rb_next(node); | 945 | next = rb_next(node); |
| 873 | if (!next) | 946 | if (!next && (callchain_param.mode != CHAIN_GRAPH_REL || !remaining)) |
| 874 | new_depth_mask &= ~(1 << (depth - 1)); | 947 | new_depth_mask &= ~(1 << (depth - 1)); |
| 875 | 948 | ||
| 876 | /* | 949 | /* |
| @@ -885,7 +958,7 @@ callchain__fprintf_graph(FILE *fp, struct callchain_node *self, | |||
| 885 | ret += ipchain__fprintf_graph(fp, chain, depth, | 958 | ret += ipchain__fprintf_graph(fp, chain, depth, |
| 886 | new_depth_mask, i++, | 959 | new_depth_mask, i++, |
| 887 | new_total, | 960 | new_total, |
| 888 | child->cumul_hit); | 961 | cumul); |
| 889 | } | 962 | } |
| 890 | ret += callchain__fprintf_graph(fp, child, new_total, | 963 | ret += callchain__fprintf_graph(fp, child, new_total, |
| 891 | depth + 1, | 964 | depth + 1, |
| @@ -893,6 +966,19 @@ callchain__fprintf_graph(FILE *fp, struct callchain_node *self, | |||
| 893 | node = next; | 966 | node = next; |
| 894 | } | 967 | } |
| 895 | 968 | ||
| 969 | if (callchain_param.mode == CHAIN_GRAPH_REL && | ||
| 970 | remaining && remaining != new_total) { | ||
| 971 | |||
| 972 | if (!rem_sq_bracket) | ||
| 973 | return ret; | ||
| 974 | |||
| 975 | new_depth_mask &= ~(1 << (depth - 1)); | ||
| 976 | |||
| 977 | ret += ipchain__fprintf_graph(fp, &rem_hits, depth, | ||
| 978 | new_depth_mask, 0, new_total, | ||
| 979 | remaining); | ||
| 980 | } | ||
| 981 | |||
| 896 | return ret; | 982 | return ret; |
| 897 | } | 983 | } |
| 898 | 984 | ||
| @@ -967,17 +1053,25 @@ hist_entry__fprintf(FILE *fp, struct hist_entry *self, u64 total_samples) | |||
| 967 | return 0; | 1053 | return 0; |
| 968 | 1054 | ||
| 969 | if (total_samples) | 1055 | if (total_samples) |
| 970 | ret = percent_color_fprintf(fp, " %6.2f%%", | 1056 | ret = percent_color_fprintf(fp, |
| 971 | (self->count * 100.0) / total_samples); | 1057 | field_sep ? "%.2f" : " %6.2f%%", |
| 1058 | (self->count * 100.0) / total_samples); | ||
| 972 | else | 1059 | else |
| 973 | ret = fprintf(fp, "%12Ld ", self->count); | 1060 | ret = fprintf(fp, field_sep ? "%lld" : "%12lld ", self->count); |
| 1061 | |||
| 1062 | if (show_nr_samples) { | ||
| 1063 | if (field_sep) | ||
| 1064 | fprintf(fp, "%c%lld", *field_sep, self->count); | ||
| 1065 | else | ||
| 1066 | fprintf(fp, "%11lld", self->count); | ||
| 1067 | } | ||
| 974 | 1068 | ||
| 975 | list_for_each_entry(se, &hist_entry__sort_list, list) { | 1069 | list_for_each_entry(se, &hist_entry__sort_list, list) { |
| 976 | if (exclude_other && (se == &sort_parent)) | 1070 | if (se->elide) |
| 977 | continue; | 1071 | continue; |
| 978 | 1072 | ||
| 979 | fprintf(fp, " "); | 1073 | fprintf(fp, "%s", field_sep ?: " "); |
| 980 | ret += se->print(fp, self); | 1074 | ret += se->print(fp, self, se->width ? *se->width : 0); |
| 981 | } | 1075 | } |
| 982 | 1076 | ||
| 983 | ret += fprintf(fp, "\n"); | 1077 | ret += fprintf(fp, "\n"); |
| @@ -992,6 +1086,18 @@ hist_entry__fprintf(FILE *fp, struct hist_entry *self, u64 total_samples) | |||
| 992 | * | 1086 | * |
| 993 | */ | 1087 | */ |
| 994 | 1088 | ||
| 1089 | static void dso__calc_col_width(struct dso *self) | ||
| 1090 | { | ||
| 1091 | if (!col_width_list_str && !field_sep && | ||
| 1092 | (!dso_list || strlist__has_entry(dso_list, self->name))) { | ||
| 1093 | unsigned int slen = strlen(self->name); | ||
| 1094 | if (slen > dsos__col_width) | ||
| 1095 | dsos__col_width = slen; | ||
| 1096 | } | ||
| 1097 | |||
| 1098 | self->slen_calculated = 1; | ||
| 1099 | } | ||
| 1100 | |||
| 995 | static struct symbol * | 1101 | static struct symbol * |
| 996 | resolve_symbol(struct thread *thread, struct map **mapp, | 1102 | resolve_symbol(struct thread *thread, struct map **mapp, |
| 997 | struct dso **dsop, u64 *ipp) | 1103 | struct dso **dsop, u64 *ipp) |
| @@ -1011,6 +1117,14 @@ resolve_symbol(struct thread *thread, struct map **mapp, | |||
| 1011 | 1117 | ||
| 1012 | map = thread__find_map(thread, ip); | 1118 | map = thread__find_map(thread, ip); |
| 1013 | if (map != NULL) { | 1119 | if (map != NULL) { |
| 1120 | /* | ||
| 1121 | * We have to do this here as we may have a dso | ||
| 1122 | * with no symbol hit that has a name longer than | ||
| 1123 | * the ones with symbols sampled. | ||
| 1124 | */ | ||
| 1125 | if (!sort_dso.elide && !map->dso->slen_calculated) | ||
| 1126 | dso__calc_col_width(map->dso); | ||
| 1127 | |||
| 1014 | if (mapp) | 1128 | if (mapp) |
| 1015 | *mapp = map; | 1129 | *mapp = map; |
| 1016 | got_map: | 1130 | got_map: |
| @@ -1282,35 +1396,69 @@ static size_t output__fprintf(FILE *fp, u64 total_samples) | |||
| 1282 | struct sort_entry *se; | 1396 | struct sort_entry *se; |
| 1283 | struct rb_node *nd; | 1397 | struct rb_node *nd; |
| 1284 | size_t ret = 0; | 1398 | size_t ret = 0; |
| 1399 | unsigned int width; | ||
| 1400 | char *col_width = col_width_list_str; | ||
| 1285 | 1401 | ||
| 1286 | fprintf(fp, "\n"); | 1402 | init_rem_hits(); |
| 1287 | fprintf(fp, "#\n"); | 1403 | |
| 1288 | fprintf(fp, "# (%Ld samples)\n", (u64)total_samples); | 1404 | fprintf(fp, "# Samples: %Ld\n", (u64)total_samples); |
| 1289 | fprintf(fp, "#\n"); | 1405 | fprintf(fp, "#\n"); |
| 1290 | 1406 | ||
| 1291 | fprintf(fp, "# Overhead"); | 1407 | fprintf(fp, "# Overhead"); |
| 1408 | if (show_nr_samples) { | ||
| 1409 | if (field_sep) | ||
| 1410 | fprintf(fp, "%cSamples", *field_sep); | ||
| 1411 | else | ||
| 1412 | fputs(" Samples ", fp); | ||
| 1413 | } | ||
| 1292 | list_for_each_entry(se, &hist_entry__sort_list, list) { | 1414 | list_for_each_entry(se, &hist_entry__sort_list, list) { |
| 1293 | if (exclude_other && (se == &sort_parent)) | 1415 | if (se->elide) |
| 1294 | continue; | 1416 | continue; |
| 1295 | fprintf(fp, " %s", se->header); | 1417 | if (field_sep) { |
| 1418 | fprintf(fp, "%c%s", *field_sep, se->header); | ||
| 1419 | continue; | ||
| 1420 | } | ||
| 1421 | width = strlen(se->header); | ||
| 1422 | if (se->width) { | ||
| 1423 | if (col_width_list_str) { | ||
| 1424 | if (col_width) { | ||
| 1425 | *se->width = atoi(col_width); | ||
| 1426 | col_width = strchr(col_width, ','); | ||
| 1427 | if (col_width) | ||
| 1428 | ++col_width; | ||
| 1429 | } | ||
| 1430 | } | ||
| 1431 | width = *se->width = max(*se->width, width); | ||
| 1432 | } | ||
| 1433 | fprintf(fp, " %*s", width, se->header); | ||
| 1296 | } | 1434 | } |
| 1297 | fprintf(fp, "\n"); | 1435 | fprintf(fp, "\n"); |
| 1298 | 1436 | ||
| 1437 | if (field_sep) | ||
| 1438 | goto print_entries; | ||
| 1439 | |||
| 1299 | fprintf(fp, "# ........"); | 1440 | fprintf(fp, "# ........"); |
| 1441 | if (show_nr_samples) | ||
| 1442 | fprintf(fp, " .........."); | ||
| 1300 | list_for_each_entry(se, &hist_entry__sort_list, list) { | 1443 | list_for_each_entry(se, &hist_entry__sort_list, list) { |
| 1301 | unsigned int i; | 1444 | unsigned int i; |
| 1302 | 1445 | ||
| 1303 | if (exclude_other && (se == &sort_parent)) | 1446 | if (se->elide) |
| 1304 | continue; | 1447 | continue; |
| 1305 | 1448 | ||
| 1306 | fprintf(fp, " "); | 1449 | fprintf(fp, " "); |
| 1307 | for (i = 0; i < strlen(se->header); i++) | 1450 | if (se->width) |
| 1451 | width = *se->width; | ||
| 1452 | else | ||
| 1453 | width = strlen(se->header); | ||
| 1454 | for (i = 0; i < width; i++) | ||
| 1308 | fprintf(fp, "."); | 1455 | fprintf(fp, "."); |
| 1309 | } | 1456 | } |
| 1310 | fprintf(fp, "\n"); | 1457 | fprintf(fp, "\n"); |
| 1311 | 1458 | ||
| 1312 | fprintf(fp, "#\n"); | 1459 | fprintf(fp, "#\n"); |
| 1313 | 1460 | ||
| 1461 | print_entries: | ||
| 1314 | for (nd = rb_first(&output_hists); nd; nd = rb_next(nd)) { | 1462 | for (nd = rb_first(&output_hists); nd; nd = rb_next(nd)) { |
| 1315 | pos = rb_entry(nd, struct hist_entry, rb_node); | 1463 | pos = rb_entry(nd, struct hist_entry, rb_node); |
| 1316 | ret += hist_entry__fprintf(fp, pos, total_samples); | 1464 | ret += hist_entry__fprintf(fp, pos, total_samples); |
| @@ -1319,11 +1467,13 @@ static size_t output__fprintf(FILE *fp, u64 total_samples) | |||
| 1319 | if (sort_order == default_sort_order && | 1467 | if (sort_order == default_sort_order && |
| 1320 | parent_pattern == default_parent_pattern) { | 1468 | parent_pattern == default_parent_pattern) { |
| 1321 | fprintf(fp, "#\n"); | 1469 | fprintf(fp, "#\n"); |
| 1322 | fprintf(fp, "# (For more details, try: perf report --sort comm,dso,symbol)\n"); | 1470 | fprintf(fp, "# (For a higher level overview, try: perf report --sort comm,dso)\n"); |
| 1323 | fprintf(fp, "#\n"); | 1471 | fprintf(fp, "#\n"); |
| 1324 | } | 1472 | } |
| 1325 | fprintf(fp, "\n"); | 1473 | fprintf(fp, "\n"); |
| 1326 | 1474 | ||
| 1475 | free(rem_sq_bracket); | ||
| 1476 | |||
| 1327 | return ret; | 1477 | return ret; |
| 1328 | } | 1478 | } |
| 1329 | 1479 | ||
| @@ -1377,11 +1527,11 @@ process_sample_event(event_t *event, unsigned long offset, unsigned long head) | |||
| 1377 | more_data += sizeof(u64); | 1527 | more_data += sizeof(u64); |
| 1378 | } | 1528 | } |
| 1379 | 1529 | ||
| 1380 | dprintf("%p [%p]: PERF_EVENT_SAMPLE (IP, %d): %d: %p period: %Ld\n", | 1530 | dprintf("%p [%p]: PERF_EVENT_SAMPLE (IP, %d): %d/%d: %p period: %Ld\n", |
| 1381 | (void *)(offset + head), | 1531 | (void *)(offset + head), |
| 1382 | (void *)(long)(event->header.size), | 1532 | (void *)(long)(event->header.size), |
| 1383 | event->header.misc, | 1533 | event->header.misc, |
| 1384 | event->ip.pid, | 1534 | event->ip.pid, event->ip.tid, |
| 1385 | (void *)(long)ip, | 1535 | (void *)(long)ip, |
| 1386 | (long long)period); | 1536 | (long long)period); |
| 1387 | 1537 | ||
| @@ -1441,10 +1591,11 @@ process_sample_event(event_t *event, unsigned long offset, unsigned long head) | |||
| 1441 | if (show & show_mask) { | 1591 | if (show & show_mask) { |
| 1442 | struct symbol *sym = resolve_symbol(thread, &map, &dso, &ip); | 1592 | struct symbol *sym = resolve_symbol(thread, &map, &dso, &ip); |
| 1443 | 1593 | ||
| 1444 | if (dso_list && dso && dso->name && !strlist__has_entry(dso_list, dso->name)) | 1594 | if (dso_list && (!dso || !dso->name || |
| 1595 | !strlist__has_entry(dso_list, dso->name))) | ||
| 1445 | return 0; | 1596 | return 0; |
| 1446 | 1597 | ||
| 1447 | if (sym_list && sym && !strlist__has_entry(sym_list, sym->name)) | 1598 | if (sym_list && (!sym || !strlist__has_entry(sym_list, sym->name))) |
| 1448 | return 0; | 1599 | return 0; |
| 1449 | 1600 | ||
| 1450 | if (hist_entry__add(thread, map, dso, sym, ip, chain, level, period)) { | 1601 | if (hist_entry__add(thread, map, dso, sym, ip, chain, level, period)) { |
| @@ -1463,10 +1614,11 @@ process_mmap_event(event_t *event, unsigned long offset, unsigned long head) | |||
| 1463 | struct thread *thread = threads__findnew(event->mmap.pid); | 1614 | struct thread *thread = threads__findnew(event->mmap.pid); |
| 1464 | struct map *map = map__new(&event->mmap); | 1615 | struct map *map = map__new(&event->mmap); |
| 1465 | 1616 | ||
| 1466 | dprintf("%p [%p]: PERF_EVENT_MMAP %d: [%p(%p) @ %p]: %s\n", | 1617 | dprintf("%p [%p]: PERF_EVENT_MMAP %d/%d: [%p(%p) @ %p]: %s\n", |
| 1467 | (void *)(offset + head), | 1618 | (void *)(offset + head), |
| 1468 | (void *)(long)(event->header.size), | 1619 | (void *)(long)(event->header.size), |
| 1469 | event->mmap.pid, | 1620 | event->mmap.pid, |
| 1621 | event->mmap.tid, | ||
| 1470 | (void *)(long)event->mmap.start, | 1622 | (void *)(long)event->mmap.start, |
| 1471 | (void *)(long)event->mmap.len, | 1623 | (void *)(long)event->mmap.len, |
| 1472 | (void *)(long)event->mmap.pgoff, | 1624 | (void *)(long)event->mmap.pgoff, |
| @@ -1504,15 +1656,27 @@ process_comm_event(event_t *event, unsigned long offset, unsigned long head) | |||
| 1504 | } | 1656 | } |
| 1505 | 1657 | ||
| 1506 | static int | 1658 | static int |
| 1507 | process_fork_event(event_t *event, unsigned long offset, unsigned long head) | 1659 | process_task_event(event_t *event, unsigned long offset, unsigned long head) |
| 1508 | { | 1660 | { |
| 1509 | struct thread *thread = threads__findnew(event->fork.pid); | 1661 | struct thread *thread = threads__findnew(event->fork.pid); |
| 1510 | struct thread *parent = threads__findnew(event->fork.ppid); | 1662 | struct thread *parent = threads__findnew(event->fork.ppid); |
| 1511 | 1663 | ||
| 1512 | dprintf("%p [%p]: PERF_EVENT_FORK: %d:%d\n", | 1664 | dprintf("%p [%p]: PERF_EVENT_%s: (%d:%d):(%d:%d)\n", |
| 1513 | (void *)(offset + head), | 1665 | (void *)(offset + head), |
| 1514 | (void *)(long)(event->header.size), | 1666 | (void *)(long)(event->header.size), |
| 1515 | event->fork.pid, event->fork.ppid); | 1667 | event->header.type == PERF_EVENT_FORK ? "FORK" : "EXIT", |
| 1668 | event->fork.pid, event->fork.tid, | ||
| 1669 | event->fork.ppid, event->fork.ptid); | ||
| 1670 | |||
| 1671 | /* | ||
| 1672 | * A thread clone will have the same PID for both | ||
| 1673 | * parent and child. | ||
| 1674 | */ | ||
| 1675 | if (thread == parent) | ||
| 1676 | return 0; | ||
| 1677 | |||
| 1678 | if (event->header.type == PERF_EVENT_EXIT) | ||
| 1679 | return 0; | ||
| 1516 | 1680 | ||
| 1517 | if (!thread || !parent || thread__fork(thread, parent)) { | 1681 | if (!thread || !parent || thread__fork(thread, parent)) { |
| 1518 | dprintf("problem processing PERF_EVENT_FORK, skipping event.\n"); | 1682 | dprintf("problem processing PERF_EVENT_FORK, skipping event.\n"); |
| @@ -1524,19 +1688,6 @@ process_fork_event(event_t *event, unsigned long offset, unsigned long head) | |||
| 1524 | } | 1688 | } |
| 1525 | 1689 | ||
| 1526 | static int | 1690 | static int |
| 1527 | process_period_event(event_t *event, unsigned long offset, unsigned long head) | ||
| 1528 | { | ||
| 1529 | dprintf("%p [%p]: PERF_EVENT_PERIOD: time:%Ld, id:%Ld: period:%Ld\n", | ||
| 1530 | (void *)(offset + head), | ||
| 1531 | (void *)(long)(event->header.size), | ||
| 1532 | event->period.time, | ||
| 1533 | event->period.id, | ||
| 1534 | event->period.sample_period); | ||
| 1535 | |||
| 1536 | return 0; | ||
| 1537 | } | ||
| 1538 | |||
| 1539 | static int | ||
| 1540 | process_lost_event(event_t *event, unsigned long offset, unsigned long head) | 1691 | process_lost_event(event_t *event, unsigned long offset, unsigned long head) |
| 1541 | { | 1692 | { |
| 1542 | dprintf("%p [%p]: PERF_EVENT_LOST: id:%Ld: lost:%Ld\n", | 1693 | dprintf("%p [%p]: PERF_EVENT_LOST: id:%Ld: lost:%Ld\n", |
| @@ -1586,14 +1737,37 @@ static void trace_event(event_t *event) | |||
| 1586 | dprintf(".\n"); | 1737 | dprintf(".\n"); |
| 1587 | } | 1738 | } |
| 1588 | 1739 | ||
| 1740 | static struct perf_header *header; | ||
| 1741 | |||
| 1742 | static struct perf_counter_attr *perf_header__find_attr(u64 id) | ||
| 1743 | { | ||
| 1744 | int i; | ||
| 1745 | |||
| 1746 | for (i = 0; i < header->attrs; i++) { | ||
| 1747 | struct perf_header_attr *attr = header->attr[i]; | ||
| 1748 | int j; | ||
| 1749 | |||
| 1750 | for (j = 0; j < attr->ids; j++) { | ||
| 1751 | if (attr->id[j] == id) | ||
| 1752 | return &attr->attr; | ||
| 1753 | } | ||
| 1754 | } | ||
| 1755 | |||
| 1756 | return NULL; | ||
| 1757 | } | ||
| 1758 | |||
| 1589 | static int | 1759 | static int |
| 1590 | process_read_event(event_t *event, unsigned long offset, unsigned long head) | 1760 | process_read_event(event_t *event, unsigned long offset, unsigned long head) |
| 1591 | { | 1761 | { |
| 1592 | dprintf("%p [%p]: PERF_EVENT_READ: %d %d %Lu\n", | 1762 | struct perf_counter_attr *attr = perf_header__find_attr(event->read.id); |
| 1763 | |||
| 1764 | dprintf("%p [%p]: PERF_EVENT_READ: %d %d %s %Lu\n", | ||
| 1593 | (void *)(offset + head), | 1765 | (void *)(offset + head), |
| 1594 | (void *)(long)(event->header.size), | 1766 | (void *)(long)(event->header.size), |
| 1595 | event->read.pid, | 1767 | event->read.pid, |
| 1596 | event->read.tid, | 1768 | event->read.tid, |
| 1769 | attr ? __event_name(attr->type, attr->config) | ||
| 1770 | : "FAIL", | ||
| 1597 | event->read.value); | 1771 | event->read.value); |
| 1598 | 1772 | ||
| 1599 | return 0; | 1773 | return 0; |
| @@ -1615,10 +1789,8 @@ process_event(event_t *event, unsigned long offset, unsigned long head) | |||
| 1615 | return process_comm_event(event, offset, head); | 1789 | return process_comm_event(event, offset, head); |
| 1616 | 1790 | ||
| 1617 | case PERF_EVENT_FORK: | 1791 | case PERF_EVENT_FORK: |
| 1618 | return process_fork_event(event, offset, head); | 1792 | case PERF_EVENT_EXIT: |
| 1619 | 1793 | return process_task_event(event, offset, head); | |
| 1620 | case PERF_EVENT_PERIOD: | ||
| 1621 | return process_period_event(event, offset, head); | ||
| 1622 | 1794 | ||
| 1623 | case PERF_EVENT_LOST: | 1795 | case PERF_EVENT_LOST: |
| 1624 | return process_lost_event(event, offset, head); | 1796 | return process_lost_event(event, offset, head); |
| @@ -1641,8 +1813,6 @@ process_event(event_t *event, unsigned long offset, unsigned long head) | |||
| 1641 | return 0; | 1813 | return 0; |
| 1642 | } | 1814 | } |
| 1643 | 1815 | ||
| 1644 | static struct perf_header *header; | ||
| 1645 | |||
| 1646 | static u64 perf_header__sample_type(void) | 1816 | static u64 perf_header__sample_type(void) |
| 1647 | { | 1817 | { |
| 1648 | u64 sample_type = 0; | 1818 | u64 sample_type = 0; |
| @@ -1687,6 +1857,11 @@ static int __cmd_report(void) | |||
| 1687 | exit(-1); | 1857 | exit(-1); |
| 1688 | } | 1858 | } |
| 1689 | 1859 | ||
| 1860 | if (!force && (stat.st_uid != geteuid())) { | ||
| 1861 | fprintf(stderr, "file: %s not owned by current user\n", input_name); | ||
| 1862 | exit(-1); | ||
| 1863 | } | ||
| 1864 | |||
| 1690 | if (!stat.st_size) { | 1865 | if (!stat.st_size) { |
| 1691 | fprintf(stderr, "zero-sized file, nothing to do!\n"); | 1866 | fprintf(stderr, "zero-sized file, nothing to do!\n"); |
| 1692 | exit(0); | 1867 | exit(0); |
| @@ -1710,6 +1885,13 @@ static int __cmd_report(void) | |||
| 1710 | " -g?\n"); | 1885 | " -g?\n"); |
| 1711 | exit(-1); | 1886 | exit(-1); |
| 1712 | } | 1887 | } |
| 1888 | } else if (callchain_param.mode != CHAIN_NONE && !callchain) { | ||
| 1889 | callchain = 1; | ||
| 1890 | if (register_callchain_param(&callchain_param) < 0) { | ||
| 1891 | fprintf(stderr, "Can't register callchain" | ||
| 1892 | " params\n"); | ||
| 1893 | exit(-1); | ||
| 1894 | } | ||
| 1713 | } | 1895 | } |
| 1714 | 1896 | ||
| 1715 | if (load_kernel() < 0) { | 1897 | if (load_kernel() < 0) { |
| @@ -1848,6 +2030,13 @@ parse_callchain_opt(const struct option *opt __used, const char *arg, | |||
| 1848 | else if (!strncmp(tok, "fractal", strlen(arg))) | 2030 | else if (!strncmp(tok, "fractal", strlen(arg))) |
| 1849 | callchain_param.mode = CHAIN_GRAPH_REL; | 2031 | callchain_param.mode = CHAIN_GRAPH_REL; |
| 1850 | 2032 | ||
| 2033 | else if (!strncmp(tok, "none", strlen(arg))) { | ||
| 2034 | callchain_param.mode = CHAIN_NONE; | ||
| 2035 | callchain = 0; | ||
| 2036 | |||
| 2037 | return 0; | ||
| 2038 | } | ||
| 2039 | |||
| 1851 | else | 2040 | else |
| 1852 | return -1; | 2041 | return -1; |
| 1853 | 2042 | ||
| @@ -1881,8 +2070,11 @@ static const struct option options[] = { | |||
| 1881 | OPT_BOOLEAN('D', "dump-raw-trace", &dump_trace, | 2070 | OPT_BOOLEAN('D', "dump-raw-trace", &dump_trace, |
| 1882 | "dump raw trace in ASCII"), | 2071 | "dump raw trace in ASCII"), |
| 1883 | OPT_STRING('k', "vmlinux", &vmlinux, "file", "vmlinux pathname"), | 2072 | OPT_STRING('k', "vmlinux", &vmlinux, "file", "vmlinux pathname"), |
| 2073 | OPT_BOOLEAN('f', "force", &force, "don't complain, do it"), | ||
| 1884 | OPT_BOOLEAN('m', "modules", &modules, | 2074 | OPT_BOOLEAN('m', "modules", &modules, |
| 1885 | "load module symbols - WARNING: use only with -k and LIVE kernel"), | 2075 | "load module symbols - WARNING: use only with -k and LIVE kernel"), |
| 2076 | OPT_BOOLEAN('n', "show-nr-samples", &show_nr_samples, | ||
| 2077 | "Show a column with the number of samples"), | ||
| 1886 | OPT_STRING('s', "sort", &sort_order, "key[,key2...]", | 2078 | OPT_STRING('s', "sort", &sort_order, "key[,key2...]", |
| 1887 | "sort by key(s): pid, comm, dso, symbol, parent"), | 2079 | "sort by key(s): pid, comm, dso, symbol, parent"), |
| 1888 | OPT_BOOLEAN('P', "full-paths", &full_paths, | 2080 | OPT_BOOLEAN('P', "full-paths", &full_paths, |
| @@ -1891,15 +2083,21 @@ static const struct option options[] = { | |||
| 1891 | "regex filter to identify parent, see: '--sort parent'"), | 2083 | "regex filter to identify parent, see: '--sort parent'"), |
| 1892 | OPT_BOOLEAN('x', "exclude-other", &exclude_other, | 2084 | OPT_BOOLEAN('x', "exclude-other", &exclude_other, |
| 1893 | "Only display entries with parent-match"), | 2085 | "Only display entries with parent-match"), |
| 1894 | OPT_CALLBACK_DEFAULT('c', "callchain", NULL, "output_type,min_percent", | 2086 | OPT_CALLBACK_DEFAULT('g', "call-graph", NULL, "output_type,min_percent", |
| 1895 | "Display callchains using output_type and min percent threshold. " | 2087 | "Display callchains using output_type and min percent threshold. " |
| 1896 | "Default: flat,0", &parse_callchain_opt, callchain_default_opt), | 2088 | "Default: fractal,0.5", &parse_callchain_opt, callchain_default_opt), |
| 1897 | OPT_STRING('d', "dsos", &dso_list_str, "dso[,dso...]", | 2089 | OPT_STRING('d', "dsos", &dso_list_str, "dso[,dso...]", |
| 1898 | "only consider symbols in these dsos"), | 2090 | "only consider symbols in these dsos"), |
| 1899 | OPT_STRING('C', "comms", &comm_list_str, "comm[,comm...]", | 2091 | OPT_STRING('C', "comms", &comm_list_str, "comm[,comm...]", |
| 1900 | "only consider symbols in these comms"), | 2092 | "only consider symbols in these comms"), |
| 1901 | OPT_STRING('S', "symbols", &sym_list_str, "symbol[,symbol...]", | 2093 | OPT_STRING('S', "symbols", &sym_list_str, "symbol[,symbol...]", |
| 1902 | "only consider these symbols"), | 2094 | "only consider these symbols"), |
| 2095 | OPT_STRING('w', "column-widths", &col_width_list_str, | ||
| 2096 | "width[,width...]", | ||
| 2097 | "don't try to adjust column width, use these fixed values"), | ||
| 2098 | OPT_STRING('t', "field-separator", &field_sep, "separator", | ||
| 2099 | "separator for columns, no spaces will be added between " | ||
| 2100 | "columns '.' is reserved."), | ||
| 1903 | OPT_END() | 2101 | OPT_END() |
| 1904 | }; | 2102 | }; |
| 1905 | 2103 | ||
| @@ -1919,7 +2117,8 @@ static void setup_sorting(void) | |||
| 1919 | } | 2117 | } |
| 1920 | 2118 | ||
| 1921 | static void setup_list(struct strlist **list, const char *list_str, | 2119 | static void setup_list(struct strlist **list, const char *list_str, |
| 1922 | const char *list_name) | 2120 | struct sort_entry *se, const char *list_name, |
| 2121 | FILE *fp) | ||
| 1923 | { | 2122 | { |
| 1924 | if (list_str) { | 2123 | if (list_str) { |
| 1925 | *list = strlist__new(true, list_str); | 2124 | *list = strlist__new(true, list_str); |
| @@ -1928,6 +2127,11 @@ static void setup_list(struct strlist **list, const char *list_str, | |||
| 1928 | list_name); | 2127 | list_name); |
| 1929 | exit(129); | 2128 | exit(129); |
| 1930 | } | 2129 | } |
| 2130 | if (strlist__nr_entries(*list) == 1) { | ||
| 2131 | fprintf(fp, "# %s: %s\n", list_name, | ||
| 2132 | strlist__entry(*list, 0)->s); | ||
| 2133 | se->elide = true; | ||
| 2134 | } | ||
| 1931 | } | 2135 | } |
| 1932 | } | 2136 | } |
| 1933 | 2137 | ||
| @@ -1941,9 +2145,10 @@ int cmd_report(int argc, const char **argv, const char *prefix __used) | |||
| 1941 | 2145 | ||
| 1942 | setup_sorting(); | 2146 | setup_sorting(); |
| 1943 | 2147 | ||
| 1944 | if (parent_pattern != default_parent_pattern) | 2148 | if (parent_pattern != default_parent_pattern) { |
| 1945 | sort_dimension__add("parent"); | 2149 | sort_dimension__add("parent"); |
| 1946 | else | 2150 | sort_parent.elide = 1; |
| 2151 | } else | ||
| 1947 | exclude_other = 0; | 2152 | exclude_other = 0; |
| 1948 | 2153 | ||
| 1949 | /* | 2154 | /* |
| @@ -1952,11 +2157,17 @@ int cmd_report(int argc, const char **argv, const char *prefix __used) | |||
| 1952 | if (argc) | 2157 | if (argc) |
| 1953 | usage_with_options(report_usage, options); | 2158 | usage_with_options(report_usage, options); |
| 1954 | 2159 | ||
| 1955 | setup_list(&dso_list, dso_list_str, "dso"); | ||
| 1956 | setup_list(&comm_list, comm_list_str, "comm"); | ||
| 1957 | setup_list(&sym_list, sym_list_str, "symbol"); | ||
| 1958 | |||
| 1959 | setup_pager(); | 2160 | setup_pager(); |
| 1960 | 2161 | ||
| 2162 | setup_list(&dso_list, dso_list_str, &sort_dso, "dso", stdout); | ||
| 2163 | setup_list(&comm_list, comm_list_str, &sort_comm, "comm", stdout); | ||
| 2164 | setup_list(&sym_list, sym_list_str, &sort_sym, "symbol", stdout); | ||
| 2165 | |||
| 2166 | if (field_sep && *field_sep == '.') { | ||
| 2167 | fputs("'.' is the only non valid --field-separator argument\n", | ||
| 2168 | stderr); | ||
| 2169 | exit(129); | ||
| 2170 | } | ||
| 2171 | |||
| 1961 | return __cmd_report(); | 2172 | return __cmd_report(); |
| 1962 | } | 2173 | } |
diff --git a/tools/perf/builtin-stat.c b/tools/perf/builtin-stat.c index 27921a8ce1a9..b4b06c7903e1 100644 --- a/tools/perf/builtin-stat.c +++ b/tools/perf/builtin-stat.c | |||
| @@ -496,7 +496,7 @@ static const struct option options[] = { | |||
| 496 | "stat events on existing pid"), | 496 | "stat events on existing pid"), |
| 497 | OPT_BOOLEAN('a', "all-cpus", &system_wide, | 497 | OPT_BOOLEAN('a', "all-cpus", &system_wide, |
| 498 | "system-wide collection from all CPUs"), | 498 | "system-wide collection from all CPUs"), |
| 499 | OPT_BOOLEAN('S', "scale", &scale, | 499 | OPT_BOOLEAN('c', "scale", &scale, |
| 500 | "scale/normalize counters"), | 500 | "scale/normalize counters"), |
| 501 | OPT_BOOLEAN('v', "verbose", &verbose, | 501 | OPT_BOOLEAN('v', "verbose", &verbose, |
| 502 | "be more verbose (show counter open errors, etc)"), | 502 | "be more verbose (show counter open errors, etc)"), |
| @@ -511,7 +511,8 @@ int cmd_stat(int argc, const char **argv, const char *prefix __used) | |||
| 511 | { | 511 | { |
| 512 | int status; | 512 | int status; |
| 513 | 513 | ||
| 514 | argc = parse_options(argc, argv, options, stat_usage, 0); | 514 | argc = parse_options(argc, argv, options, stat_usage, |
| 515 | PARSE_OPT_STOP_AT_NON_OPTION); | ||
| 515 | if (!argc) | 516 | if (!argc) |
| 516 | usage_with_options(stat_usage, options); | 517 | usage_with_options(stat_usage, options); |
| 517 | if (run_count <= 0 || run_count > MAX_RUN) | 518 | if (run_count <= 0 || run_count > MAX_RUN) |
diff --git a/tools/perf/builtin-top.c b/tools/perf/builtin-top.c index 95d5c0ae375a..7de28ce9ca26 100644 --- a/tools/perf/builtin-top.c +++ b/tools/perf/builtin-top.c | |||
| @@ -31,6 +31,8 @@ | |||
| 31 | #include <fcntl.h> | 31 | #include <fcntl.h> |
| 32 | 32 | ||
| 33 | #include <stdio.h> | 33 | #include <stdio.h> |
| 34 | #include <termios.h> | ||
| 35 | #include <unistd.h> | ||
| 34 | 36 | ||
| 35 | #include <errno.h> | 37 | #include <errno.h> |
| 36 | #include <time.h> | 38 | #include <time.h> |
| @@ -54,10 +56,11 @@ static int system_wide = 0; | |||
| 54 | 56 | ||
| 55 | static int default_interval = 100000; | 57 | static int default_interval = 100000; |
| 56 | 58 | ||
| 57 | static u64 count_filter = 5; | 59 | static int count_filter = 5; |
| 58 | static int print_entries = 15; | 60 | static int print_entries = 15; |
| 59 | 61 | ||
| 60 | static int target_pid = -1; | 62 | static int target_pid = -1; |
| 63 | static int inherit = 0; | ||
| 61 | static int profile_cpu = -1; | 64 | static int profile_cpu = -1; |
| 62 | static int nr_cpus = 0; | 65 | static int nr_cpus = 0; |
| 63 | static unsigned int realtime_prio = 0; | 66 | static unsigned int realtime_prio = 0; |
| @@ -68,15 +71,28 @@ static int freq = 0; | |||
| 68 | static int verbose = 0; | 71 | static int verbose = 0; |
| 69 | static char *vmlinux = NULL; | 72 | static char *vmlinux = NULL; |
| 70 | 73 | ||
| 71 | static char *sym_filter; | ||
| 72 | static unsigned long filter_start; | ||
| 73 | static unsigned long filter_end; | ||
| 74 | |||
| 75 | static int delay_secs = 2; | 74 | static int delay_secs = 2; |
| 76 | static int zero; | 75 | static int zero; |
| 77 | static int dump_symtab; | 76 | static int dump_symtab; |
| 78 | 77 | ||
| 79 | /* | 78 | /* |
| 79 | * Source | ||
| 80 | */ | ||
| 81 | |||
| 82 | struct source_line { | ||
| 83 | u64 eip; | ||
| 84 | unsigned long count[MAX_COUNTERS]; | ||
| 85 | char *line; | ||
| 86 | struct source_line *next; | ||
| 87 | }; | ||
| 88 | |||
| 89 | static char *sym_filter = NULL; | ||
| 90 | struct sym_entry *sym_filter_entry = NULL; | ||
| 91 | static int sym_pcnt_filter = 5; | ||
| 92 | static int sym_counter = 0; | ||
| 93 | static int display_weighted = -1; | ||
| 94 | |||
| 95 | /* | ||
| 80 | * Symbols | 96 | * Symbols |
| 81 | */ | 97 | */ |
| 82 | 98 | ||
| @@ -90,9 +106,237 @@ struct sym_entry { | |||
| 90 | unsigned long snap_count; | 106 | unsigned long snap_count; |
| 91 | double weight; | 107 | double weight; |
| 92 | int skip; | 108 | int skip; |
| 109 | struct source_line *source; | ||
| 110 | struct source_line *lines; | ||
| 111 | struct source_line **lines_tail; | ||
| 112 | pthread_mutex_t source_lock; | ||
| 93 | }; | 113 | }; |
| 94 | 114 | ||
| 95 | struct sym_entry *sym_filter_entry; | 115 | /* |
| 116 | * Source functions | ||
| 117 | */ | ||
| 118 | |||
| 119 | static void parse_source(struct sym_entry *syme) | ||
| 120 | { | ||
| 121 | struct symbol *sym; | ||
| 122 | struct module *module; | ||
| 123 | struct section *section = NULL; | ||
| 124 | FILE *file; | ||
| 125 | char command[PATH_MAX*2], *path = vmlinux; | ||
| 126 | u64 start, end, len; | ||
| 127 | |||
| 128 | if (!syme) | ||
| 129 | return; | ||
| 130 | |||
| 131 | if (syme->lines) { | ||
| 132 | pthread_mutex_lock(&syme->source_lock); | ||
| 133 | goto out_assign; | ||
| 134 | } | ||
| 135 | |||
| 136 | sym = (struct symbol *)(syme + 1); | ||
| 137 | module = sym->module; | ||
| 138 | |||
| 139 | if (module) | ||
| 140 | path = module->path; | ||
| 141 | if (!path) | ||
| 142 | return; | ||
| 143 | |||
| 144 | start = sym->obj_start; | ||
| 145 | if (!start) | ||
| 146 | start = sym->start; | ||
| 147 | |||
| 148 | if (module) { | ||
| 149 | section = module->sections->find_section(module->sections, ".text"); | ||
| 150 | if (section) | ||
| 151 | start -= section->vma; | ||
| 152 | } | ||
| 153 | |||
| 154 | end = start + sym->end - sym->start + 1; | ||
| 155 | len = sym->end - sym->start; | ||
| 156 | |||
| 157 | sprintf(command, "objdump --start-address=0x%016Lx --stop-address=0x%016Lx -dS %s", start, end, path); | ||
| 158 | |||
| 159 | file = popen(command, "r"); | ||
| 160 | if (!file) | ||
| 161 | return; | ||
| 162 | |||
| 163 | pthread_mutex_lock(&syme->source_lock); | ||
| 164 | syme->lines_tail = &syme->lines; | ||
| 165 | while (!feof(file)) { | ||
| 166 | struct source_line *src; | ||
| 167 | size_t dummy = 0; | ||
| 168 | char *c; | ||
| 169 | |||
| 170 | src = malloc(sizeof(struct source_line)); | ||
| 171 | assert(src != NULL); | ||
| 172 | memset(src, 0, sizeof(struct source_line)); | ||
| 173 | |||
| 174 | if (getline(&src->line, &dummy, file) < 0) | ||
| 175 | break; | ||
| 176 | if (!src->line) | ||
| 177 | break; | ||
| 178 | |||
| 179 | c = strchr(src->line, '\n'); | ||
| 180 | if (c) | ||
| 181 | *c = 0; | ||
| 182 | |||
| 183 | src->next = NULL; | ||
| 184 | *syme->lines_tail = src; | ||
| 185 | syme->lines_tail = &src->next; | ||
| 186 | |||
| 187 | if (strlen(src->line)>8 && src->line[8] == ':') { | ||
| 188 | src->eip = strtoull(src->line, NULL, 16); | ||
| 189 | if (section) | ||
| 190 | src->eip += section->vma; | ||
| 191 | } | ||
| 192 | if (strlen(src->line)>8 && src->line[16] == ':') { | ||
| 193 | src->eip = strtoull(src->line, NULL, 16); | ||
| 194 | if (section) | ||
| 195 | src->eip += section->vma; | ||
| 196 | } | ||
| 197 | } | ||
| 198 | pclose(file); | ||
| 199 | out_assign: | ||
| 200 | sym_filter_entry = syme; | ||
| 201 | pthread_mutex_unlock(&syme->source_lock); | ||
| 202 | } | ||
| 203 | |||
| 204 | static void __zero_source_counters(struct sym_entry *syme) | ||
| 205 | { | ||
| 206 | int i; | ||
| 207 | struct source_line *line; | ||
| 208 | |||
| 209 | line = syme->lines; | ||
| 210 | while (line) { | ||
| 211 | for (i = 0; i < nr_counters; i++) | ||
| 212 | line->count[i] = 0; | ||
| 213 | line = line->next; | ||
| 214 | } | ||
| 215 | } | ||
| 216 | |||
| 217 | static void record_precise_ip(struct sym_entry *syme, int counter, u64 ip) | ||
| 218 | { | ||
| 219 | struct source_line *line; | ||
| 220 | |||
| 221 | if (syme != sym_filter_entry) | ||
| 222 | return; | ||
| 223 | |||
| 224 | if (pthread_mutex_trylock(&syme->source_lock)) | ||
| 225 | return; | ||
| 226 | |||
| 227 | if (!syme->source) | ||
| 228 | goto out_unlock; | ||
| 229 | |||
| 230 | for (line = syme->lines; line; line = line->next) { | ||
| 231 | if (line->eip == ip) { | ||
| 232 | line->count[counter]++; | ||
| 233 | break; | ||
| 234 | } | ||
| 235 | if (line->eip > ip) | ||
| 236 | break; | ||
| 237 | } | ||
| 238 | out_unlock: | ||
| 239 | pthread_mutex_unlock(&syme->source_lock); | ||
| 240 | } | ||
| 241 | |||
| 242 | static void lookup_sym_source(struct sym_entry *syme) | ||
| 243 | { | ||
| 244 | struct symbol *symbol = (struct symbol *)(syme + 1); | ||
| 245 | struct source_line *line; | ||
| 246 | char pattern[PATH_MAX]; | ||
| 247 | char *idx; | ||
| 248 | |||
| 249 | sprintf(pattern, "<%s>:", symbol->name); | ||
| 250 | |||
| 251 | if (symbol->module) { | ||
| 252 | idx = strstr(pattern, "\t"); | ||
| 253 | if (idx) | ||
| 254 | *idx = 0; | ||
| 255 | } | ||
| 256 | |||
| 257 | pthread_mutex_lock(&syme->source_lock); | ||
| 258 | for (line = syme->lines; line; line = line->next) { | ||
| 259 | if (strstr(line->line, pattern)) { | ||
| 260 | syme->source = line; | ||
| 261 | break; | ||
| 262 | } | ||
| 263 | } | ||
| 264 | pthread_mutex_unlock(&syme->source_lock); | ||
| 265 | } | ||
| 266 | |||
| 267 | static void show_lines(struct source_line *queue, int count, int total) | ||
| 268 | { | ||
| 269 | int i; | ||
| 270 | struct source_line *line; | ||
| 271 | |||
| 272 | line = queue; | ||
| 273 | for (i = 0; i < count; i++) { | ||
| 274 | float pcnt = 100.0*(float)line->count[sym_counter]/(float)total; | ||
| 275 | |||
| 276 | printf("%8li %4.1f%%\t%s\n", line->count[sym_counter], pcnt, line->line); | ||
| 277 | line = line->next; | ||
| 278 | } | ||
| 279 | } | ||
| 280 | |||
| 281 | #define TRACE_COUNT 3 | ||
| 282 | |||
| 283 | static void show_details(struct sym_entry *syme) | ||
| 284 | { | ||
| 285 | struct symbol *symbol; | ||
| 286 | struct source_line *line; | ||
| 287 | struct source_line *line_queue = NULL; | ||
| 288 | int displayed = 0; | ||
| 289 | int line_queue_count = 0, total = 0, more = 0; | ||
| 290 | |||
| 291 | if (!syme) | ||
| 292 | return; | ||
| 293 | |||
| 294 | if (!syme->source) | ||
| 295 | lookup_sym_source(syme); | ||
| 296 | |||
| 297 | if (!syme->source) | ||
| 298 | return; | ||
| 299 | |||
| 300 | symbol = (struct symbol *)(syme + 1); | ||
| 301 | printf("Showing %s for %s\n", event_name(sym_counter), symbol->name); | ||
| 302 | printf(" Events Pcnt (>=%d%%)\n", sym_pcnt_filter); | ||
| 303 | |||
| 304 | pthread_mutex_lock(&syme->source_lock); | ||
| 305 | line = syme->source; | ||
| 306 | while (line) { | ||
| 307 | total += line->count[sym_counter]; | ||
| 308 | line = line->next; | ||
| 309 | } | ||
| 310 | |||
| 311 | line = syme->source; | ||
| 312 | while (line) { | ||
| 313 | float pcnt = 0.0; | ||
| 314 | |||
| 315 | if (!line_queue_count) | ||
| 316 | line_queue = line; | ||
| 317 | line_queue_count++; | ||
| 318 | |||
| 319 | if (line->count[sym_counter]) | ||
| 320 | pcnt = 100.0 * line->count[sym_counter] / (float)total; | ||
| 321 | if (pcnt >= (float)sym_pcnt_filter) { | ||
| 322 | if (displayed <= print_entries) | ||
| 323 | show_lines(line_queue, line_queue_count, total); | ||
| 324 | else more++; | ||
| 325 | displayed += line_queue_count; | ||
| 326 | line_queue_count = 0; | ||
| 327 | line_queue = NULL; | ||
| 328 | } else if (line_queue_count > TRACE_COUNT) { | ||
| 329 | line_queue = line_queue->next; | ||
| 330 | line_queue_count--; | ||
| 331 | } | ||
| 332 | |||
| 333 | line->count[sym_counter] = zero ? 0 : line->count[sym_counter] * 7 / 8; | ||
| 334 | line = line->next; | ||
| 335 | } | ||
| 336 | pthread_mutex_unlock(&syme->source_lock); | ||
| 337 | if (more) | ||
| 338 | printf("%d lines not displayed, maybe increase display entries [e]\n", more); | ||
| 339 | } | ||
| 96 | 340 | ||
| 97 | struct dso *kernel_dso; | 341 | struct dso *kernel_dso; |
| 98 | 342 | ||
| @@ -111,6 +355,9 @@ static double sym_weight(const struct sym_entry *sym) | |||
| 111 | double weight = sym->snap_count; | 355 | double weight = sym->snap_count; |
| 112 | int counter; | 356 | int counter; |
| 113 | 357 | ||
| 358 | if (!display_weighted) | ||
| 359 | return weight; | ||
| 360 | |||
| 114 | for (counter = 1; counter < nr_counters-1; counter++) | 361 | for (counter = 1; counter < nr_counters-1; counter++) |
| 115 | weight *= sym->count[counter]; | 362 | weight *= sym->count[counter]; |
| 116 | 363 | ||
| @@ -158,7 +405,7 @@ static void rb_insert_active_sym(struct rb_root *tree, struct sym_entry *se) | |||
| 158 | static void print_sym_table(void) | 405 | static void print_sym_table(void) |
| 159 | { | 406 | { |
| 160 | int printed = 0, j; | 407 | int printed = 0, j; |
| 161 | int counter; | 408 | int counter, snap = !display_weighted ? sym_counter : 0; |
| 162 | float samples_per_sec = samples/delay_secs; | 409 | float samples_per_sec = samples/delay_secs; |
| 163 | float ksamples_per_sec = (samples-userspace_samples)/delay_secs; | 410 | float ksamples_per_sec = (samples-userspace_samples)/delay_secs; |
| 164 | float sum_ksamples = 0.0; | 411 | float sum_ksamples = 0.0; |
| @@ -174,7 +421,7 @@ static void print_sym_table(void) | |||
| 174 | pthread_mutex_unlock(&active_symbols_lock); | 421 | pthread_mutex_unlock(&active_symbols_lock); |
| 175 | 422 | ||
| 176 | list_for_each_entry_safe_from(syme, n, &active_symbols, node) { | 423 | list_for_each_entry_safe_from(syme, n, &active_symbols, node) { |
| 177 | syme->snap_count = syme->count[0]; | 424 | syme->snap_count = syme->count[snap]; |
| 178 | if (syme->snap_count != 0) { | 425 | if (syme->snap_count != 0) { |
| 179 | syme->weight = sym_weight(syme); | 426 | syme->weight = sym_weight(syme); |
| 180 | rb_insert_active_sym(&tmp, syme); | 427 | rb_insert_active_sym(&tmp, syme); |
| @@ -194,7 +441,7 @@ static void print_sym_table(void) | |||
| 194 | samples_per_sec, | 441 | samples_per_sec, |
| 195 | 100.0 - (100.0*((samples_per_sec-ksamples_per_sec)/samples_per_sec))); | 442 | 100.0 - (100.0*((samples_per_sec-ksamples_per_sec)/samples_per_sec))); |
| 196 | 443 | ||
| 197 | if (nr_counters == 1) { | 444 | if (nr_counters == 1 || !display_weighted) { |
| 198 | printf("%Ld", (u64)attrs[0].sample_period); | 445 | printf("%Ld", (u64)attrs[0].sample_period); |
| 199 | if (freq) | 446 | if (freq) |
| 200 | printf("Hz "); | 447 | printf("Hz "); |
| @@ -202,7 +449,9 @@ static void print_sym_table(void) | |||
| 202 | printf(" "); | 449 | printf(" "); |
| 203 | } | 450 | } |
| 204 | 451 | ||
| 205 | for (counter = 0; counter < nr_counters; counter++) { | 452 | if (!display_weighted) |
| 453 | printf("%s", event_name(sym_counter)); | ||
| 454 | else for (counter = 0; counter < nr_counters; counter++) { | ||
| 206 | if (counter) | 455 | if (counter) |
| 207 | printf("/"); | 456 | printf("/"); |
| 208 | 457 | ||
| @@ -227,6 +476,11 @@ static void print_sym_table(void) | |||
| 227 | 476 | ||
| 228 | printf("------------------------------------------------------------------------------\n\n"); | 477 | printf("------------------------------------------------------------------------------\n\n"); |
| 229 | 478 | ||
| 479 | if (sym_filter_entry) { | ||
| 480 | show_details(sym_filter_entry); | ||
| 481 | return; | ||
| 482 | } | ||
| 483 | |||
| 230 | if (nr_counters == 1) | 484 | if (nr_counters == 1) |
| 231 | printf(" samples pcnt"); | 485 | printf(" samples pcnt"); |
| 232 | else | 486 | else |
| @@ -241,13 +495,13 @@ static void print_sym_table(void) | |||
| 241 | struct symbol *sym = (struct symbol *)(syme + 1); | 495 | struct symbol *sym = (struct symbol *)(syme + 1); |
| 242 | double pcnt; | 496 | double pcnt; |
| 243 | 497 | ||
| 244 | if (++printed > print_entries || syme->snap_count < count_filter) | 498 | if (++printed > print_entries || (int)syme->snap_count < count_filter) |
| 245 | continue; | 499 | continue; |
| 246 | 500 | ||
| 247 | pcnt = 100.0 - (100.0 * ((sum_ksamples - syme->snap_count) / | 501 | pcnt = 100.0 - (100.0 * ((sum_ksamples - syme->snap_count) / |
| 248 | sum_ksamples)); | 502 | sum_ksamples)); |
| 249 | 503 | ||
| 250 | if (nr_counters == 1) | 504 | if (nr_counters == 1 || !display_weighted) |
| 251 | printf("%20.2f - ", syme->weight); | 505 | printf("%20.2f - ", syme->weight); |
| 252 | else | 506 | else |
| 253 | printf("%9.1f %10ld - ", syme->weight, syme->snap_count); | 507 | printf("%9.1f %10ld - ", syme->weight, syme->snap_count); |
| @@ -260,19 +514,250 @@ static void print_sym_table(void) | |||
| 260 | } | 514 | } |
| 261 | } | 515 | } |
| 262 | 516 | ||
| 517 | static void prompt_integer(int *target, const char *msg) | ||
| 518 | { | ||
| 519 | char *buf = malloc(0), *p; | ||
| 520 | size_t dummy = 0; | ||
| 521 | int tmp; | ||
| 522 | |||
| 523 | fprintf(stdout, "\n%s: ", msg); | ||
| 524 | if (getline(&buf, &dummy, stdin) < 0) | ||
| 525 | return; | ||
| 526 | |||
| 527 | p = strchr(buf, '\n'); | ||
| 528 | if (p) | ||
| 529 | *p = 0; | ||
| 530 | |||
| 531 | p = buf; | ||
| 532 | while(*p) { | ||
| 533 | if (!isdigit(*p)) | ||
| 534 | goto out_free; | ||
| 535 | p++; | ||
| 536 | } | ||
| 537 | tmp = strtoul(buf, NULL, 10); | ||
| 538 | *target = tmp; | ||
| 539 | out_free: | ||
| 540 | free(buf); | ||
| 541 | } | ||
| 542 | |||
| 543 | static void prompt_percent(int *target, const char *msg) | ||
| 544 | { | ||
| 545 | int tmp = 0; | ||
| 546 | |||
| 547 | prompt_integer(&tmp, msg); | ||
| 548 | if (tmp >= 0 && tmp <= 100) | ||
| 549 | *target = tmp; | ||
| 550 | } | ||
| 551 | |||
| 552 | static void prompt_symbol(struct sym_entry **target, const char *msg) | ||
| 553 | { | ||
| 554 | char *buf = malloc(0), *p; | ||
| 555 | struct sym_entry *syme = *target, *n, *found = NULL; | ||
| 556 | size_t dummy = 0; | ||
| 557 | |||
| 558 | /* zero counters of active symbol */ | ||
| 559 | if (syme) { | ||
| 560 | pthread_mutex_lock(&syme->source_lock); | ||
| 561 | __zero_source_counters(syme); | ||
| 562 | *target = NULL; | ||
| 563 | pthread_mutex_unlock(&syme->source_lock); | ||
| 564 | } | ||
| 565 | |||
| 566 | fprintf(stdout, "\n%s: ", msg); | ||
| 567 | if (getline(&buf, &dummy, stdin) < 0) | ||
| 568 | goto out_free; | ||
| 569 | |||
| 570 | p = strchr(buf, '\n'); | ||
| 571 | if (p) | ||
| 572 | *p = 0; | ||
| 573 | |||
| 574 | pthread_mutex_lock(&active_symbols_lock); | ||
| 575 | syme = list_entry(active_symbols.next, struct sym_entry, node); | ||
| 576 | pthread_mutex_unlock(&active_symbols_lock); | ||
| 577 | |||
| 578 | list_for_each_entry_safe_from(syme, n, &active_symbols, node) { | ||
| 579 | struct symbol *sym = (struct symbol *)(syme + 1); | ||
| 580 | |||
| 581 | if (!strcmp(buf, sym->name)) { | ||
| 582 | found = syme; | ||
| 583 | break; | ||
| 584 | } | ||
| 585 | } | ||
| 586 | |||
| 587 | if (!found) { | ||
| 588 | fprintf(stderr, "Sorry, %s is not active.\n", sym_filter); | ||
| 589 | sleep(1); | ||
| 590 | return; | ||
| 591 | } else | ||
| 592 | parse_source(found); | ||
| 593 | |||
| 594 | out_free: | ||
| 595 | free(buf); | ||
| 596 | } | ||
| 597 | |||
| 598 | static void print_mapped_keys(void) | ||
| 599 | { | ||
| 600 | char *name = NULL; | ||
| 601 | |||
| 602 | if (sym_filter_entry) { | ||
| 603 | struct symbol *sym = (struct symbol *)(sym_filter_entry+1); | ||
| 604 | name = sym->name; | ||
| 605 | } | ||
| 606 | |||
| 607 | fprintf(stdout, "\nMapped keys:\n"); | ||
| 608 | fprintf(stdout, "\t[d] display refresh delay. \t(%d)\n", delay_secs); | ||
| 609 | fprintf(stdout, "\t[e] display entries (lines). \t(%d)\n", print_entries); | ||
| 610 | |||
| 611 | if (nr_counters > 1) | ||
| 612 | fprintf(stdout, "\t[E] active event counter. \t(%s)\n", event_name(sym_counter)); | ||
| 613 | |||
| 614 | fprintf(stdout, "\t[f] profile display filter (count). \t(%d)\n", count_filter); | ||
| 615 | |||
| 616 | if (vmlinux) { | ||
| 617 | fprintf(stdout, "\t[F] annotate display filter (percent). \t(%d%%)\n", sym_pcnt_filter); | ||
| 618 | fprintf(stdout, "\t[s] annotate symbol. \t(%s)\n", name?: "NULL"); | ||
| 619 | fprintf(stdout, "\t[S] stop annotation.\n"); | ||
| 620 | } | ||
| 621 | |||
| 622 | if (nr_counters > 1) | ||
| 623 | fprintf(stdout, "\t[w] toggle display weighted/count[E]r. \t(%d)\n", display_weighted ? 1 : 0); | ||
| 624 | |||
| 625 | fprintf(stdout, "\t[z] toggle sample zeroing. \t(%d)\n", zero ? 1 : 0); | ||
| 626 | fprintf(stdout, "\t[qQ] quit.\n"); | ||
| 627 | } | ||
| 628 | |||
| 629 | static int key_mapped(int c) | ||
| 630 | { | ||
| 631 | switch (c) { | ||
| 632 | case 'd': | ||
| 633 | case 'e': | ||
| 634 | case 'f': | ||
| 635 | case 'z': | ||
| 636 | case 'q': | ||
| 637 | case 'Q': | ||
| 638 | return 1; | ||
| 639 | case 'E': | ||
| 640 | case 'w': | ||
| 641 | return nr_counters > 1 ? 1 : 0; | ||
| 642 | case 'F': | ||
| 643 | case 's': | ||
| 644 | case 'S': | ||
| 645 | return vmlinux ? 1 : 0; | ||
| 646 | } | ||
| 647 | |||
| 648 | return 0; | ||
| 649 | } | ||
| 650 | |||
| 651 | static void handle_keypress(int c) | ||
| 652 | { | ||
| 653 | if (!key_mapped(c)) { | ||
| 654 | struct pollfd stdin_poll = { .fd = 0, .events = POLLIN }; | ||
| 655 | struct termios tc, save; | ||
| 656 | |||
| 657 | print_mapped_keys(); | ||
| 658 | fprintf(stdout, "\nEnter selection, or unmapped key to continue: "); | ||
| 659 | fflush(stdout); | ||
| 660 | |||
| 661 | tcgetattr(0, &save); | ||
| 662 | tc = save; | ||
| 663 | tc.c_lflag &= ~(ICANON | ECHO); | ||
| 664 | tc.c_cc[VMIN] = 0; | ||
| 665 | tc.c_cc[VTIME] = 0; | ||
| 666 | tcsetattr(0, TCSANOW, &tc); | ||
| 667 | |||
| 668 | poll(&stdin_poll, 1, -1); | ||
| 669 | c = getc(stdin); | ||
| 670 | |||
| 671 | tcsetattr(0, TCSAFLUSH, &save); | ||
| 672 | if (!key_mapped(c)) | ||
| 673 | return; | ||
| 674 | } | ||
| 675 | |||
| 676 | switch (c) { | ||
| 677 | case 'd': | ||
| 678 | prompt_integer(&delay_secs, "Enter display delay"); | ||
| 679 | break; | ||
| 680 | case 'e': | ||
| 681 | prompt_integer(&print_entries, "Enter display entries (lines)"); | ||
| 682 | break; | ||
| 683 | case 'E': | ||
| 684 | if (nr_counters > 1) { | ||
| 685 | int i; | ||
| 686 | |||
| 687 | fprintf(stderr, "\nAvailable events:"); | ||
| 688 | for (i = 0; i < nr_counters; i++) | ||
| 689 | fprintf(stderr, "\n\t%d %s", i, event_name(i)); | ||
| 690 | |||
| 691 | prompt_integer(&sym_counter, "Enter details event counter"); | ||
| 692 | |||
| 693 | if (sym_counter >= nr_counters) { | ||
| 694 | fprintf(stderr, "Sorry, no such event, using %s.\n", event_name(0)); | ||
| 695 | sym_counter = 0; | ||
| 696 | sleep(1); | ||
| 697 | } | ||
| 698 | } else sym_counter = 0; | ||
| 699 | break; | ||
| 700 | case 'f': | ||
| 701 | prompt_integer(&count_filter, "Enter display event count filter"); | ||
| 702 | break; | ||
| 703 | case 'F': | ||
| 704 | prompt_percent(&sym_pcnt_filter, "Enter details display event filter (percent)"); | ||
| 705 | break; | ||
| 706 | case 'q': | ||
| 707 | case 'Q': | ||
| 708 | printf("exiting.\n"); | ||
| 709 | exit(0); | ||
| 710 | case 's': | ||
| 711 | prompt_symbol(&sym_filter_entry, "Enter details symbol"); | ||
| 712 | break; | ||
| 713 | case 'S': | ||
| 714 | if (!sym_filter_entry) | ||
| 715 | break; | ||
| 716 | else { | ||
| 717 | struct sym_entry *syme = sym_filter_entry; | ||
| 718 | |||
| 719 | pthread_mutex_lock(&syme->source_lock); | ||
| 720 | sym_filter_entry = NULL; | ||
| 721 | __zero_source_counters(syme); | ||
| 722 | pthread_mutex_unlock(&syme->source_lock); | ||
| 723 | } | ||
| 724 | break; | ||
| 725 | case 'w': | ||
| 726 | display_weighted = ~display_weighted; | ||
| 727 | break; | ||
| 728 | case 'z': | ||
| 729 | zero = ~zero; | ||
| 730 | break; | ||
| 731 | } | ||
| 732 | } | ||
| 733 | |||
| 263 | static void *display_thread(void *arg __used) | 734 | static void *display_thread(void *arg __used) |
| 264 | { | 735 | { |
| 265 | struct pollfd stdin_poll = { .fd = 0, .events = POLLIN }; | 736 | struct pollfd stdin_poll = { .fd = 0, .events = POLLIN }; |
| 266 | int delay_msecs = delay_secs * 1000; | 737 | struct termios tc, save; |
| 738 | int delay_msecs, c; | ||
| 739 | |||
| 740 | tcgetattr(0, &save); | ||
| 741 | tc = save; | ||
| 742 | tc.c_lflag &= ~(ICANON | ECHO); | ||
| 743 | tc.c_cc[VMIN] = 0; | ||
| 744 | tc.c_cc[VTIME] = 0; | ||
| 267 | 745 | ||
| 268 | printf("PerfTop refresh period: %d seconds\n", delay_secs); | 746 | repeat: |
| 747 | delay_msecs = delay_secs * 1000; | ||
| 748 | tcsetattr(0, TCSANOW, &tc); | ||
| 749 | /* trash return*/ | ||
| 750 | getc(stdin); | ||
| 269 | 751 | ||
| 270 | do { | 752 | do { |
| 271 | print_sym_table(); | 753 | print_sym_table(); |
| 272 | } while (!poll(&stdin_poll, 1, delay_msecs) == 1); | 754 | } while (!poll(&stdin_poll, 1, delay_msecs) == 1); |
| 273 | 755 | ||
| 274 | printf("key pressed - exiting.\n"); | 756 | c = getc(stdin); |
| 275 | exit(0); | 757 | tcsetattr(0, TCSAFLUSH, &save); |
| 758 | |||
| 759 | handle_keypress(c); | ||
| 760 | goto repeat; | ||
| 276 | 761 | ||
| 277 | return NULL; | 762 | return NULL; |
| 278 | } | 763 | } |
| @@ -284,6 +769,7 @@ static const char *skip_symbols[] = { | |||
| 284 | "enter_idle", | 769 | "enter_idle", |
| 285 | "exit_idle", | 770 | "exit_idle", |
| 286 | "mwait_idle", | 771 | "mwait_idle", |
| 772 | "mwait_idle_with_hints", | ||
| 287 | "ppc64_runlatch_off", | 773 | "ppc64_runlatch_off", |
| 288 | "pseries_dedicated_idle_sleep", | 774 | "pseries_dedicated_idle_sleep", |
| 289 | NULL | 775 | NULL |
| @@ -291,7 +777,6 @@ static const char *skip_symbols[] = { | |||
| 291 | 777 | ||
| 292 | static int symbol_filter(struct dso *self, struct symbol *sym) | 778 | static int symbol_filter(struct dso *self, struct symbol *sym) |
| 293 | { | 779 | { |
| 294 | static int filter_match; | ||
| 295 | struct sym_entry *syme; | 780 | struct sym_entry *syme; |
| 296 | const char *name = sym->name; | 781 | const char *name = sym->name; |
| 297 | int i; | 782 | int i; |
| @@ -313,6 +798,10 @@ static int symbol_filter(struct dso *self, struct symbol *sym) | |||
| 313 | return 1; | 798 | return 1; |
| 314 | 799 | ||
| 315 | syme = dso__sym_priv(self, sym); | 800 | syme = dso__sym_priv(self, sym); |
| 801 | pthread_mutex_init(&syme->source_lock, NULL); | ||
| 802 | if (!sym_filter_entry && sym_filter && !strcmp(name, sym_filter)) | ||
| 803 | sym_filter_entry = syme; | ||
| 804 | |||
| 316 | for (i = 0; skip_symbols[i]; i++) { | 805 | for (i = 0; skip_symbols[i]; i++) { |
| 317 | if (!strcmp(skip_symbols[i], name)) { | 806 | if (!strcmp(skip_symbols[i], name)) { |
| 318 | syme->skip = 1; | 807 | syme->skip = 1; |
| @@ -320,29 +809,6 @@ static int symbol_filter(struct dso *self, struct symbol *sym) | |||
| 320 | } | 809 | } |
| 321 | } | 810 | } |
| 322 | 811 | ||
| 323 | if (filter_match == 1) { | ||
| 324 | filter_end = sym->start; | ||
| 325 | filter_match = -1; | ||
| 326 | if (filter_end - filter_start > 10000) { | ||
| 327 | fprintf(stderr, | ||
| 328 | "hm, too large filter symbol <%s> - skipping.\n", | ||
| 329 | sym_filter); | ||
| 330 | fprintf(stderr, "symbol filter start: %016lx\n", | ||
| 331 | filter_start); | ||
| 332 | fprintf(stderr, " end: %016lx\n", | ||
| 333 | filter_end); | ||
| 334 | filter_end = filter_start = 0; | ||
| 335 | sym_filter = NULL; | ||
| 336 | sleep(1); | ||
| 337 | } | ||
| 338 | } | ||
| 339 | |||
| 340 | if (filter_match == 0 && sym_filter && !strcmp(name, sym_filter)) { | ||
| 341 | filter_match = 1; | ||
| 342 | filter_start = sym->start; | ||
| 343 | } | ||
| 344 | |||
| 345 | |||
| 346 | return 0; | 812 | return 0; |
| 347 | } | 813 | } |
| 348 | 814 | ||
| @@ -378,8 +844,6 @@ out_delete_dso: | |||
| 378 | return -1; | 844 | return -1; |
| 379 | } | 845 | } |
| 380 | 846 | ||
| 381 | #define TRACE_COUNT 3 | ||
| 382 | |||
| 383 | /* | 847 | /* |
| 384 | * Binary search in the histogram table and record the hit: | 848 | * Binary search in the histogram table and record the hit: |
| 385 | */ | 849 | */ |
| @@ -392,6 +856,7 @@ static void record_ip(u64 ip, int counter) | |||
| 392 | 856 | ||
| 393 | if (!syme->skip) { | 857 | if (!syme->skip) { |
| 394 | syme->count[counter]++; | 858 | syme->count[counter]++; |
| 859 | record_precise_ip(syme, counter, ip); | ||
| 395 | pthread_mutex_lock(&active_symbols_lock); | 860 | pthread_mutex_lock(&active_symbols_lock); |
| 396 | if (list_empty(&syme->node) || !syme->node.next) | 861 | if (list_empty(&syme->node) || !syme->node.next) |
| 397 | __list_insert_active_sym(syme); | 862 | __list_insert_active_sym(syme); |
| @@ -549,7 +1014,7 @@ int group_fd; | |||
| 549 | static void start_counter(int i, int counter) | 1014 | static void start_counter(int i, int counter) |
| 550 | { | 1015 | { |
| 551 | struct perf_counter_attr *attr; | 1016 | struct perf_counter_attr *attr; |
| 552 | unsigned int cpu; | 1017 | int cpu; |
| 553 | 1018 | ||
| 554 | cpu = profile_cpu; | 1019 | cpu = profile_cpu; |
| 555 | if (target_pid == -1 && profile_cpu == -1) | 1020 | if (target_pid == -1 && profile_cpu == -1) |
| @@ -559,6 +1024,7 @@ static void start_counter(int i, int counter) | |||
| 559 | 1024 | ||
| 560 | attr->sample_type = PERF_SAMPLE_IP | PERF_SAMPLE_TID; | 1025 | attr->sample_type = PERF_SAMPLE_IP | PERF_SAMPLE_TID; |
| 561 | attr->freq = freq; | 1026 | attr->freq = freq; |
| 1027 | attr->inherit = (cpu < 0) && inherit; | ||
| 562 | 1028 | ||
| 563 | try_again: | 1029 | try_again: |
| 564 | fd[i][counter] = sys_perf_counter_open(attr, target_pid, cpu, group_fd, 0); | 1030 | fd[i][counter] = sys_perf_counter_open(attr, target_pid, cpu, group_fd, 0); |
| @@ -685,8 +1151,10 @@ static const struct option options[] = { | |||
| 685 | "only display functions with more events than this"), | 1151 | "only display functions with more events than this"), |
| 686 | OPT_BOOLEAN('g', "group", &group, | 1152 | OPT_BOOLEAN('g', "group", &group, |
| 687 | "put the counters into a counter group"), | 1153 | "put the counters into a counter group"), |
| 688 | OPT_STRING('s', "sym-filter", &sym_filter, "pattern", | 1154 | OPT_BOOLEAN('i', "inherit", &inherit, |
| 689 | "only display symbols matchig this pattern"), | 1155 | "child tasks inherit counters"), |
| 1156 | OPT_STRING('s', "sym-annotate", &sym_filter, "symbol name", | ||
| 1157 | "symbol to annotate - requires -k option"), | ||
| 690 | OPT_BOOLEAN('z', "zero", &zero, | 1158 | OPT_BOOLEAN('z', "zero", &zero, |
| 691 | "zero history across updates"), | 1159 | "zero history across updates"), |
| 692 | OPT_INTEGER('F', "freq", &freq, | 1160 | OPT_INTEGER('F', "freq", &freq, |
| @@ -729,6 +1197,7 @@ int cmd_top(int argc, const char **argv, const char *prefix __used) | |||
| 729 | delay_secs = 1; | 1197 | delay_secs = 1; |
| 730 | 1198 | ||
| 731 | parse_symbols(); | 1199 | parse_symbols(); |
| 1200 | parse_source(sym_filter_entry); | ||
| 732 | 1201 | ||
| 733 | /* | 1202 | /* |
| 734 | * Fill in the ones not specifically initialized via -c: | 1203 | * Fill in the ones not specifically initialized via -c: |
diff --git a/tools/perf/perf.c b/tools/perf/perf.c index c5656784c61d..31982ad064b4 100644 --- a/tools/perf/perf.c +++ b/tools/perf/perf.c | |||
| @@ -12,6 +12,8 @@ | |||
| 12 | #include "util/cache.h" | 12 | #include "util/cache.h" |
| 13 | #include "util/quote.h" | 13 | #include "util/quote.h" |
| 14 | #include "util/run-command.h" | 14 | #include "util/run-command.h" |
| 15 | #include "util/parse-events.h" | ||
| 16 | #include "util/string.h" | ||
| 15 | 17 | ||
| 16 | const char perf_usage_string[] = | 18 | const char perf_usage_string[] = |
| 17 | "perf [--version] [--help] COMMAND [ARGS]"; | 19 | "perf [--version] [--help] COMMAND [ARGS]"; |
| @@ -25,6 +27,8 @@ struct pager_config { | |||
| 25 | int val; | 27 | int val; |
| 26 | }; | 28 | }; |
| 27 | 29 | ||
| 30 | static char debugfs_mntpt[MAXPATHLEN]; | ||
| 31 | |||
| 28 | static int pager_command_config(const char *var, const char *value, void *data) | 32 | static int pager_command_config(const char *var, const char *value, void *data) |
| 29 | { | 33 | { |
| 30 | struct pager_config *c = data; | 34 | struct pager_config *c = data; |
| @@ -56,6 +60,15 @@ static void commit_pager_choice(void) { | |||
| 56 | } | 60 | } |
| 57 | } | 61 | } |
| 58 | 62 | ||
| 63 | static void set_debugfs_path(void) | ||
| 64 | { | ||
| 65 | char *path; | ||
| 66 | |||
| 67 | path = getenv(PERF_DEBUGFS_ENVIRONMENT); | ||
| 68 | snprintf(debugfs_path, MAXPATHLEN, "%s/%s", path ?: debugfs_mntpt, | ||
| 69 | "tracing/events"); | ||
| 70 | } | ||
| 71 | |||
| 59 | static int handle_options(const char*** argv, int* argc, int* envchanged) | 72 | static int handle_options(const char*** argv, int* argc, int* envchanged) |
| 60 | { | 73 | { |
| 61 | int handled = 0; | 74 | int handled = 0; |
| @@ -122,6 +135,22 @@ static int handle_options(const char*** argv, int* argc, int* envchanged) | |||
| 122 | setenv(PERF_WORK_TREE_ENVIRONMENT, cmd + 12, 1); | 135 | setenv(PERF_WORK_TREE_ENVIRONMENT, cmd + 12, 1); |
| 123 | if (envchanged) | 136 | if (envchanged) |
| 124 | *envchanged = 1; | 137 | *envchanged = 1; |
| 138 | } else if (!strcmp(cmd, "--debugfs-dir")) { | ||
| 139 | if (*argc < 2) { | ||
| 140 | fprintf(stderr, "No directory given for --debugfs-dir.\n"); | ||
| 141 | usage(perf_usage_string); | ||
| 142 | } | ||
| 143 | strncpy(debugfs_mntpt, (*argv)[1], MAXPATHLEN); | ||
| 144 | debugfs_mntpt[MAXPATHLEN - 1] = '\0'; | ||
| 145 | if (envchanged) | ||
| 146 | *envchanged = 1; | ||
| 147 | (*argv)++; | ||
| 148 | (*argc)--; | ||
| 149 | } else if (!prefixcmp(cmd, "--debugfs-dir=")) { | ||
| 150 | strncpy(debugfs_mntpt, cmd + 14, MAXPATHLEN); | ||
| 151 | debugfs_mntpt[MAXPATHLEN - 1] = '\0'; | ||
| 152 | if (envchanged) | ||
| 153 | *envchanged = 1; | ||
| 125 | } else { | 154 | } else { |
| 126 | fprintf(stderr, "Unknown option: %s\n", cmd); | 155 | fprintf(stderr, "Unknown option: %s\n", cmd); |
| 127 | usage(perf_usage_string); | 156 | usage(perf_usage_string); |
| @@ -228,6 +257,7 @@ static int run_builtin(struct cmd_struct *p, int argc, const char **argv) | |||
| 228 | if (use_pager == -1 && p->option & USE_PAGER) | 257 | if (use_pager == -1 && p->option & USE_PAGER) |
| 229 | use_pager = 1; | 258 | use_pager = 1; |
| 230 | commit_pager_choice(); | 259 | commit_pager_choice(); |
| 260 | set_debugfs_path(); | ||
| 231 | 261 | ||
| 232 | status = p->fn(argc, argv, prefix); | 262 | status = p->fn(argc, argv, prefix); |
| 233 | if (status) | 263 | if (status) |
| @@ -346,6 +376,49 @@ static int run_argv(int *argcp, const char ***argv) | |||
| 346 | return done_alias; | 376 | return done_alias; |
| 347 | } | 377 | } |
| 348 | 378 | ||
| 379 | /* mini /proc/mounts parser: searching for "^blah /mount/point debugfs" */ | ||
| 380 | static void get_debugfs_mntpt(void) | ||
| 381 | { | ||
| 382 | FILE *file; | ||
| 383 | char fs_type[100]; | ||
| 384 | char debugfs[MAXPATHLEN]; | ||
| 385 | |||
| 386 | /* | ||
| 387 | * try the standard location | ||
| 388 | */ | ||
| 389 | if (valid_debugfs_mount("/sys/kernel/debug/") == 0) { | ||
| 390 | strcpy(debugfs_mntpt, "/sys/kernel/debug/"); | ||
| 391 | return; | ||
| 392 | } | ||
| 393 | |||
| 394 | /* | ||
| 395 | * try the sane location | ||
| 396 | */ | ||
| 397 | if (valid_debugfs_mount("/debug/") == 0) { | ||
| 398 | strcpy(debugfs_mntpt, "/debug/"); | ||
| 399 | return; | ||
| 400 | } | ||
| 401 | |||
| 402 | /* | ||
| 403 | * give up and parse /proc/mounts | ||
| 404 | */ | ||
| 405 | file = fopen("/proc/mounts", "r"); | ||
| 406 | if (file == NULL) | ||
| 407 | return; | ||
| 408 | |||
| 409 | while (fscanf(file, "%*s %" | ||
| 410 | STR(MAXPATHLEN) | ||
| 411 | "s %99s %*s %*d %*d\n", | ||
| 412 | debugfs, fs_type) == 2) { | ||
| 413 | if (strcmp(fs_type, "debugfs") == 0) | ||
| 414 | break; | ||
| 415 | } | ||
| 416 | fclose(file); | ||
| 417 | if (strcmp(fs_type, "debugfs") == 0) { | ||
| 418 | strncpy(debugfs_mntpt, debugfs, MAXPATHLEN); | ||
| 419 | debugfs_mntpt[MAXPATHLEN - 1] = '\0'; | ||
| 420 | } | ||
| 421 | } | ||
| 349 | 422 | ||
| 350 | int main(int argc, const char **argv) | 423 | int main(int argc, const char **argv) |
| 351 | { | 424 | { |
| @@ -354,7 +427,8 @@ int main(int argc, const char **argv) | |||
| 354 | cmd = perf_extract_argv0_path(argv[0]); | 427 | cmd = perf_extract_argv0_path(argv[0]); |
| 355 | if (!cmd) | 428 | if (!cmd) |
| 356 | cmd = "perf-help"; | 429 | cmd = "perf-help"; |
| 357 | 430 | /* get debugfs mount point from /proc/mounts */ | |
| 431 | get_debugfs_mntpt(); | ||
| 358 | /* | 432 | /* |
| 359 | * "perf-xxxx" is the same as "perf xxxx", but we obviously: | 433 | * "perf-xxxx" is the same as "perf xxxx", but we obviously: |
| 360 | * | 434 | * |
| @@ -377,6 +451,7 @@ int main(int argc, const char **argv) | |||
| 377 | argc--; | 451 | argc--; |
| 378 | handle_options(&argv, &argc, NULL); | 452 | handle_options(&argv, &argc, NULL); |
| 379 | commit_pager_choice(); | 453 | commit_pager_choice(); |
| 454 | set_debugfs_path(); | ||
| 380 | if (argc > 0) { | 455 | if (argc > 0) { |
| 381 | if (!prefixcmp(argv[0], "--")) | 456 | if (!prefixcmp(argv[0], "--")) |
| 382 | argv[0] += 2; | 457 | argv[0] += 2; |
diff --git a/tools/perf/perf.h b/tools/perf/perf.h index 63e67cc5487b..e5148e2b6134 100644 --- a/tools/perf/perf.h +++ b/tools/perf/perf.h | |||
| @@ -1,7 +1,13 @@ | |||
| 1 | #ifndef _PERF_PERF_H | 1 | #ifndef _PERF_PERF_H |
| 2 | #define _PERF_PERF_H | 2 | #define _PERF_PERF_H |
| 3 | 3 | ||
| 4 | #if defined(__x86_64__) || defined(__i386__) | 4 | #if defined(__i386__) |
| 5 | #include "../../arch/x86/include/asm/unistd.h" | ||
| 6 | #define rmb() asm volatile("lock; addl $0,0(%%esp)" ::: "memory") | ||
| 7 | #define cpu_relax() asm volatile("rep; nop" ::: "memory"); | ||
| 8 | #endif | ||
| 9 | |||
| 10 | #if defined(__x86_64__) | ||
| 5 | #include "../../arch/x86/include/asm/unistd.h" | 11 | #include "../../arch/x86/include/asm/unistd.h" |
| 6 | #define rmb() asm volatile("lfence" ::: "memory") | 12 | #define rmb() asm volatile("lfence" ::: "memory") |
| 7 | #define cpu_relax() asm volatile("rep; nop" ::: "memory"); | 13 | #define cpu_relax() asm volatile("rep; nop" ::: "memory"); |
diff --git a/tools/perf/util/cache.h b/tools/perf/util/cache.h index 161d5f413e28..4b50c412b9c5 100644 --- a/tools/perf/util/cache.h +++ b/tools/perf/util/cache.h | |||
| @@ -18,6 +18,7 @@ | |||
| 18 | #define PERFATTRIBUTES_FILE ".perfattributes" | 18 | #define PERFATTRIBUTES_FILE ".perfattributes" |
| 19 | #define INFOATTRIBUTES_FILE "info/attributes" | 19 | #define INFOATTRIBUTES_FILE "info/attributes" |
| 20 | #define ATTRIBUTE_MACRO_PREFIX "[attr]" | 20 | #define ATTRIBUTE_MACRO_PREFIX "[attr]" |
| 21 | #define PERF_DEBUGFS_ENVIRONMENT "PERF_DEBUGFS_DIR" | ||
| 21 | 22 | ||
| 22 | typedef int (*config_fn_t)(const char *, const char *, void *); | 23 | typedef int (*config_fn_t)(const char *, const char *, void *); |
| 23 | extern int perf_default_config(const char *, const char *, void *); | 24 | extern int perf_default_config(const char *, const char *, void *); |
diff --git a/tools/perf/util/callchain.c b/tools/perf/util/callchain.c index 9d3c8141b8c1..011473411642 100644 --- a/tools/perf/util/callchain.c +++ b/tools/perf/util/callchain.c | |||
| @@ -13,6 +13,7 @@ | |||
| 13 | #include <stdio.h> | 13 | #include <stdio.h> |
| 14 | #include <stdbool.h> | 14 | #include <stdbool.h> |
| 15 | #include <errno.h> | 15 | #include <errno.h> |
| 16 | #include <math.h> | ||
| 16 | 17 | ||
| 17 | #include "callchain.h" | 18 | #include "callchain.h" |
| 18 | 19 | ||
| @@ -26,10 +27,14 @@ rb_insert_callchain(struct rb_root *root, struct callchain_node *chain, | |||
| 26 | struct rb_node **p = &root->rb_node; | 27 | struct rb_node **p = &root->rb_node; |
| 27 | struct rb_node *parent = NULL; | 28 | struct rb_node *parent = NULL; |
| 28 | struct callchain_node *rnode; | 29 | struct callchain_node *rnode; |
| 30 | u64 chain_cumul = cumul_hits(chain); | ||
| 29 | 31 | ||
| 30 | while (*p) { | 32 | while (*p) { |
| 33 | u64 rnode_cumul; | ||
| 34 | |||
| 31 | parent = *p; | 35 | parent = *p; |
| 32 | rnode = rb_entry(parent, struct callchain_node, rb_node); | 36 | rnode = rb_entry(parent, struct callchain_node, rb_node); |
| 37 | rnode_cumul = cumul_hits(rnode); | ||
| 33 | 38 | ||
| 34 | switch (mode) { | 39 | switch (mode) { |
| 35 | case CHAIN_FLAT: | 40 | case CHAIN_FLAT: |
| @@ -40,7 +45,7 @@ rb_insert_callchain(struct rb_root *root, struct callchain_node *chain, | |||
| 40 | break; | 45 | break; |
| 41 | case CHAIN_GRAPH_ABS: /* Falldown */ | 46 | case CHAIN_GRAPH_ABS: /* Falldown */ |
| 42 | case CHAIN_GRAPH_REL: | 47 | case CHAIN_GRAPH_REL: |
| 43 | if (rnode->cumul_hit < chain->cumul_hit) | 48 | if (rnode_cumul < chain_cumul) |
| 44 | p = &(*p)->rb_left; | 49 | p = &(*p)->rb_left; |
| 45 | else | 50 | else |
| 46 | p = &(*p)->rb_right; | 51 | p = &(*p)->rb_right; |
| @@ -87,7 +92,7 @@ static void __sort_chain_graph_abs(struct callchain_node *node, | |||
| 87 | 92 | ||
| 88 | chain_for_each_child(child, node) { | 93 | chain_for_each_child(child, node) { |
| 89 | __sort_chain_graph_abs(child, min_hit); | 94 | __sort_chain_graph_abs(child, min_hit); |
| 90 | if (child->cumul_hit >= min_hit) | 95 | if (cumul_hits(child) >= min_hit) |
| 91 | rb_insert_callchain(&node->rb_root, child, | 96 | rb_insert_callchain(&node->rb_root, child, |
| 92 | CHAIN_GRAPH_ABS); | 97 | CHAIN_GRAPH_ABS); |
| 93 | } | 98 | } |
| @@ -108,11 +113,11 @@ static void __sort_chain_graph_rel(struct callchain_node *node, | |||
| 108 | u64 min_hit; | 113 | u64 min_hit; |
| 109 | 114 | ||
| 110 | node->rb_root = RB_ROOT; | 115 | node->rb_root = RB_ROOT; |
| 111 | min_hit = node->cumul_hit * min_percent / 100.0; | 116 | min_hit = ceil(node->children_hit * min_percent); |
| 112 | 117 | ||
| 113 | chain_for_each_child(child, node) { | 118 | chain_for_each_child(child, node) { |
| 114 | __sort_chain_graph_rel(child, min_percent); | 119 | __sort_chain_graph_rel(child, min_percent); |
| 115 | if (child->cumul_hit >= min_hit) | 120 | if (cumul_hits(child) >= min_hit) |
| 116 | rb_insert_callchain(&node->rb_root, child, | 121 | rb_insert_callchain(&node->rb_root, child, |
| 117 | CHAIN_GRAPH_REL); | 122 | CHAIN_GRAPH_REL); |
| 118 | } | 123 | } |
| @@ -122,7 +127,7 @@ static void | |||
| 122 | sort_chain_graph_rel(struct rb_root *rb_root, struct callchain_node *chain_root, | 127 | sort_chain_graph_rel(struct rb_root *rb_root, struct callchain_node *chain_root, |
| 123 | u64 min_hit __used, struct callchain_param *param) | 128 | u64 min_hit __used, struct callchain_param *param) |
| 124 | { | 129 | { |
| 125 | __sort_chain_graph_rel(chain_root, param->min_percent); | 130 | __sort_chain_graph_rel(chain_root, param->min_percent / 100.0); |
| 126 | rb_root->rb_node = chain_root->rb_root.rb_node; | 131 | rb_root->rb_node = chain_root->rb_root.rb_node; |
| 127 | } | 132 | } |
| 128 | 133 | ||
| @@ -211,7 +216,8 @@ add_child(struct callchain_node *parent, struct ip_callchain *chain, | |||
| 211 | new = create_child(parent, false); | 216 | new = create_child(parent, false); |
| 212 | fill_node(new, chain, start, syms); | 217 | fill_node(new, chain, start, syms); |
| 213 | 218 | ||
| 214 | new->cumul_hit = new->hit = 1; | 219 | new->children_hit = 0; |
| 220 | new->hit = 1; | ||
| 215 | } | 221 | } |
| 216 | 222 | ||
| 217 | /* | 223 | /* |
| @@ -241,7 +247,8 @@ split_add_child(struct callchain_node *parent, struct ip_callchain *chain, | |||
| 241 | 247 | ||
| 242 | /* split the hits */ | 248 | /* split the hits */ |
| 243 | new->hit = parent->hit; | 249 | new->hit = parent->hit; |
| 244 | new->cumul_hit = parent->cumul_hit; | 250 | new->children_hit = parent->children_hit; |
| 251 | parent->children_hit = cumul_hits(new); | ||
| 245 | new->val_nr = parent->val_nr - idx_local; | 252 | new->val_nr = parent->val_nr - idx_local; |
| 246 | parent->val_nr = idx_local; | 253 | parent->val_nr = idx_local; |
| 247 | 254 | ||
| @@ -249,6 +256,7 @@ split_add_child(struct callchain_node *parent, struct ip_callchain *chain, | |||
| 249 | if (idx_total < chain->nr) { | 256 | if (idx_total < chain->nr) { |
| 250 | parent->hit = 0; | 257 | parent->hit = 0; |
| 251 | add_child(parent, chain, idx_total, syms); | 258 | add_child(parent, chain, idx_total, syms); |
| 259 | parent->children_hit++; | ||
| 252 | } else { | 260 | } else { |
| 253 | parent->hit = 1; | 261 | parent->hit = 1; |
| 254 | } | 262 | } |
| @@ -269,13 +277,13 @@ __append_chain_children(struct callchain_node *root, struct ip_callchain *chain, | |||
| 269 | unsigned int ret = __append_chain(rnode, chain, start, syms); | 277 | unsigned int ret = __append_chain(rnode, chain, start, syms); |
| 270 | 278 | ||
| 271 | if (!ret) | 279 | if (!ret) |
| 272 | goto cumul; | 280 | goto inc_children_hit; |
| 273 | } | 281 | } |
| 274 | /* nothing in children, add to the current node */ | 282 | /* nothing in children, add to the current node */ |
| 275 | add_child(root, chain, start, syms); | 283 | add_child(root, chain, start, syms); |
| 276 | 284 | ||
| 277 | cumul: | 285 | inc_children_hit: |
| 278 | root->cumul_hit++; | 286 | root->children_hit++; |
| 279 | } | 287 | } |
| 280 | 288 | ||
| 281 | static int | 289 | static int |
| @@ -317,8 +325,6 @@ __append_chain(struct callchain_node *root, struct ip_callchain *chain, | |||
| 317 | /* we match 100% of the path, increment the hit */ | 325 | /* we match 100% of the path, increment the hit */ |
| 318 | if (i - start == root->val_nr && i == chain->nr) { | 326 | if (i - start == root->val_nr && i == chain->nr) { |
| 319 | root->hit++; | 327 | root->hit++; |
| 320 | root->cumul_hit++; | ||
| 321 | |||
| 322 | return 0; | 328 | return 0; |
| 323 | } | 329 | } |
| 324 | 330 | ||
| @@ -331,5 +337,7 @@ __append_chain(struct callchain_node *root, struct ip_callchain *chain, | |||
| 331 | void append_chain(struct callchain_node *root, struct ip_callchain *chain, | 337 | void append_chain(struct callchain_node *root, struct ip_callchain *chain, |
| 332 | struct symbol **syms) | 338 | struct symbol **syms) |
| 333 | { | 339 | { |
| 340 | if (!chain->nr) | ||
| 341 | return; | ||
| 334 | __append_chain_children(root, chain, syms, 0); | 342 | __append_chain_children(root, chain, syms, 0); |
| 335 | } | 343 | } |
diff --git a/tools/perf/util/callchain.h b/tools/perf/util/callchain.h index 7812122bea1d..a926ae4f5a16 100644 --- a/tools/perf/util/callchain.h +++ b/tools/perf/util/callchain.h | |||
| @@ -7,6 +7,7 @@ | |||
| 7 | #include "symbol.h" | 7 | #include "symbol.h" |
| 8 | 8 | ||
| 9 | enum chain_mode { | 9 | enum chain_mode { |
| 10 | CHAIN_NONE, | ||
| 10 | CHAIN_FLAT, | 11 | CHAIN_FLAT, |
| 11 | CHAIN_GRAPH_ABS, | 12 | CHAIN_GRAPH_ABS, |
| 12 | CHAIN_GRAPH_REL | 13 | CHAIN_GRAPH_REL |
| @@ -21,7 +22,7 @@ struct callchain_node { | |||
| 21 | struct rb_root rb_root; /* sorted tree of children */ | 22 | struct rb_root rb_root; /* sorted tree of children */ |
| 22 | unsigned int val_nr; | 23 | unsigned int val_nr; |
| 23 | u64 hit; | 24 | u64 hit; |
| 24 | u64 cumul_hit; /* hit + hits of children */ | 25 | u64 children_hit; |
| 25 | }; | 26 | }; |
| 26 | 27 | ||
| 27 | struct callchain_param; | 28 | struct callchain_param; |
| @@ -48,6 +49,11 @@ static inline void callchain_init(struct callchain_node *node) | |||
| 48 | INIT_LIST_HEAD(&node->val); | 49 | INIT_LIST_HEAD(&node->val); |
| 49 | } | 50 | } |
| 50 | 51 | ||
| 52 | static inline u64 cumul_hits(struct callchain_node *node) | ||
| 53 | { | ||
| 54 | return node->hit + node->children_hit; | ||
| 55 | } | ||
| 56 | |||
| 51 | int register_callchain_param(struct callchain_param *param); | 57 | int register_callchain_param(struct callchain_param *param); |
| 52 | void append_chain(struct callchain_node *root, struct ip_callchain *chain, | 58 | void append_chain(struct callchain_node *root, struct ip_callchain *chain, |
| 53 | struct symbol **syms); | 59 | struct symbol **syms); |
diff --git a/tools/perf/util/header.c b/tools/perf/util/header.c index 450384b3bbe5..b92a457ca32e 100644 --- a/tools/perf/util/header.c +++ b/tools/perf/util/header.c | |||
| @@ -185,6 +185,8 @@ static void do_read(int fd, void *buf, size_t size) | |||
| 185 | 185 | ||
| 186 | if (ret < 0) | 186 | if (ret < 0) |
| 187 | die("failed to read"); | 187 | die("failed to read"); |
| 188 | if (ret == 0) | ||
| 189 | die("failed to read: missing data"); | ||
| 188 | 190 | ||
| 189 | size -= ret; | 191 | size -= ret; |
| 190 | buf += ret; | 192 | buf += ret; |
| @@ -213,9 +215,10 @@ struct perf_header *perf_header__read(int fd) | |||
| 213 | 215 | ||
| 214 | for (i = 0; i < nr_attrs; i++) { | 216 | for (i = 0; i < nr_attrs; i++) { |
| 215 | struct perf_header_attr *attr; | 217 | struct perf_header_attr *attr; |
| 216 | off_t tmp = lseek(fd, 0, SEEK_CUR); | 218 | off_t tmp; |
| 217 | 219 | ||
| 218 | do_read(fd, &f_attr, sizeof(f_attr)); | 220 | do_read(fd, &f_attr, sizeof(f_attr)); |
| 221 | tmp = lseek(fd, 0, SEEK_CUR); | ||
| 219 | 222 | ||
| 220 | attr = perf_header_attr__new(&f_attr.attr); | 223 | attr = perf_header_attr__new(&f_attr.attr); |
| 221 | 224 | ||
diff --git a/tools/perf/util/header.h b/tools/perf/util/header.h index b5ef53ad4c7a..bf280449fcfd 100644 --- a/tools/perf/util/header.h +++ b/tools/perf/util/header.h | |||
| @@ -16,7 +16,7 @@ struct perf_header { | |||
| 16 | int frozen; | 16 | int frozen; |
| 17 | int attrs, size; | 17 | int attrs, size; |
| 18 | struct perf_header_attr **attr; | 18 | struct perf_header_attr **attr; |
| 19 | off_t attr_offset; | 19 | s64 attr_offset; |
| 20 | u64 data_offset; | 20 | u64 data_offset; |
| 21 | u64 data_size; | 21 | u64 data_size; |
| 22 | }; | 22 | }; |
diff --git a/tools/perf/util/include/linux/kernel.h b/tools/perf/util/include/linux/kernel.h index 99c1b3d1edd9..a6b87390cb52 100644 --- a/tools/perf/util/include/linux/kernel.h +++ b/tools/perf/util/include/linux/kernel.h | |||
| @@ -18,4 +18,12 @@ | |||
| 18 | (type *)((char *)__mptr - offsetof(type, member)); }) | 18 | (type *)((char *)__mptr - offsetof(type, member)); }) |
| 19 | #endif | 19 | #endif |
| 20 | 20 | ||
| 21 | #ifndef max | ||
| 22 | #define max(x, y) ({ \ | ||
| 23 | typeof(x) _max1 = (x); \ | ||
| 24 | typeof(y) _max2 = (y); \ | ||
| 25 | (void) (&_max1 == &_max2); \ | ||
| 26 | _max1 > _max2 ? _max1 : _max2; }) | ||
| 27 | #endif | ||
| 28 | |||
| 21 | #endif | 29 | #endif |
diff --git a/tools/perf/util/parse-events.c b/tools/perf/util/parse-events.c index 5184959e0615..044178408783 100644 --- a/tools/perf/util/parse-events.c +++ b/tools/perf/util/parse-events.c | |||
| @@ -5,6 +5,7 @@ | |||
| 5 | #include "parse-events.h" | 5 | #include "parse-events.h" |
| 6 | #include "exec_cmd.h" | 6 | #include "exec_cmd.h" |
| 7 | #include "string.h" | 7 | #include "string.h" |
| 8 | #include "cache.h" | ||
| 8 | 9 | ||
| 9 | extern char *strcasestr(const char *haystack, const char *needle); | 10 | extern char *strcasestr(const char *haystack, const char *needle); |
| 10 | 11 | ||
| @@ -19,6 +20,8 @@ struct event_symbol { | |||
| 19 | char *alias; | 20 | char *alias; |
| 20 | }; | 21 | }; |
| 21 | 22 | ||
| 23 | char debugfs_path[MAXPATHLEN]; | ||
| 24 | |||
| 22 | #define CHW(x) .type = PERF_TYPE_HARDWARE, .config = PERF_COUNT_HW_##x | 25 | #define CHW(x) .type = PERF_TYPE_HARDWARE, .config = PERF_COUNT_HW_##x |
| 23 | #define CSW(x) .type = PERF_TYPE_SOFTWARE, .config = PERF_COUNT_SW_##x | 26 | #define CSW(x) .type = PERF_TYPE_SOFTWARE, .config = PERF_COUNT_SW_##x |
| 24 | 27 | ||
| @@ -71,8 +74,8 @@ static char *sw_event_names[] = { | |||
| 71 | #define MAX_ALIASES 8 | 74 | #define MAX_ALIASES 8 |
| 72 | 75 | ||
| 73 | static char *hw_cache[][MAX_ALIASES] = { | 76 | static char *hw_cache[][MAX_ALIASES] = { |
| 74 | { "L1-d$", "l1-d", "l1d", "L1-data", }, | 77 | { "L1-dcache", "l1-d", "l1d", "L1-data", }, |
| 75 | { "L1-i$", "l1-i", "l1i", "L1-instruction", }, | 78 | { "L1-icache", "l1-i", "l1i", "L1-instruction", }, |
| 76 | { "LLC", "L2" }, | 79 | { "LLC", "L2" }, |
| 77 | { "dTLB", "d-tlb", "Data-TLB", }, | 80 | { "dTLB", "d-tlb", "Data-TLB", }, |
| 78 | { "iTLB", "i-tlb", "Instruction-TLB", }, | 81 | { "iTLB", "i-tlb", "Instruction-TLB", }, |
| @@ -110,6 +113,104 @@ static unsigned long hw_cache_stat[C(MAX)] = { | |||
| 110 | [C(BPU)] = (CACHE_READ), | 113 | [C(BPU)] = (CACHE_READ), |
| 111 | }; | 114 | }; |
| 112 | 115 | ||
| 116 | #define for_each_subsystem(sys_dir, sys_dirent, sys_next, file, st) \ | ||
| 117 | while (!readdir_r(sys_dir, &sys_dirent, &sys_next) && sys_next) \ | ||
| 118 | if (snprintf(file, MAXPATHLEN, "%s/%s", debugfs_path, \ | ||
| 119 | sys_dirent.d_name) && \ | ||
| 120 | (!stat(file, &st)) && (S_ISDIR(st.st_mode)) && \ | ||
| 121 | (strcmp(sys_dirent.d_name, ".")) && \ | ||
| 122 | (strcmp(sys_dirent.d_name, ".."))) | ||
| 123 | |||
| 124 | static int tp_event_has_id(struct dirent *sys_dir, struct dirent *evt_dir) | ||
| 125 | { | ||
| 126 | char evt_path[MAXPATHLEN]; | ||
| 127 | int fd; | ||
| 128 | |||
| 129 | snprintf(evt_path, MAXPATHLEN, "%s/%s/%s/id", debugfs_path, | ||
| 130 | sys_dir->d_name, evt_dir->d_name); | ||
| 131 | fd = open(evt_path, O_RDONLY); | ||
| 132 | if (fd < 0) | ||
| 133 | return -EINVAL; | ||
| 134 | close(fd); | ||
| 135 | |||
| 136 | return 0; | ||
| 137 | } | ||
| 138 | |||
| 139 | #define for_each_event(sys_dirent, evt_dir, evt_dirent, evt_next, file, st) \ | ||
| 140 | while (!readdir_r(evt_dir, &evt_dirent, &evt_next) && evt_next) \ | ||
| 141 | if (snprintf(file, MAXPATHLEN, "%s/%s/%s", debugfs_path, \ | ||
| 142 | sys_dirent.d_name, evt_dirent.d_name) && \ | ||
| 143 | (!stat(file, &st)) && (S_ISDIR(st.st_mode)) && \ | ||
| 144 | (strcmp(evt_dirent.d_name, ".")) && \ | ||
| 145 | (strcmp(evt_dirent.d_name, "..")) && \ | ||
| 146 | (!tp_event_has_id(&sys_dirent, &evt_dirent))) | ||
| 147 | |||
| 148 | #define MAX_EVENT_LENGTH 30 | ||
| 149 | |||
| 150 | int valid_debugfs_mount(const char *debugfs) | ||
| 151 | { | ||
| 152 | struct statfs st_fs; | ||
| 153 | |||
| 154 | if (statfs(debugfs, &st_fs) < 0) | ||
| 155 | return -ENOENT; | ||
| 156 | else if (st_fs.f_type != (long) DEBUGFS_MAGIC) | ||
| 157 | return -ENOENT; | ||
| 158 | return 0; | ||
| 159 | } | ||
| 160 | |||
| 161 | static char *tracepoint_id_to_name(u64 config) | ||
| 162 | { | ||
| 163 | static char tracepoint_name[2 * MAX_EVENT_LENGTH]; | ||
| 164 | DIR *sys_dir, *evt_dir; | ||
| 165 | struct dirent *sys_next, *evt_next, sys_dirent, evt_dirent; | ||
| 166 | struct stat st; | ||
| 167 | char id_buf[4]; | ||
| 168 | int fd; | ||
| 169 | u64 id; | ||
| 170 | char evt_path[MAXPATHLEN]; | ||
| 171 | |||
| 172 | if (valid_debugfs_mount(debugfs_path)) | ||
| 173 | return "unkown"; | ||
| 174 | |||
| 175 | sys_dir = opendir(debugfs_path); | ||
| 176 | if (!sys_dir) | ||
| 177 | goto cleanup; | ||
| 178 | |||
| 179 | for_each_subsystem(sys_dir, sys_dirent, sys_next, evt_path, st) { | ||
| 180 | evt_dir = opendir(evt_path); | ||
| 181 | if (!evt_dir) | ||
| 182 | goto cleanup; | ||
| 183 | for_each_event(sys_dirent, evt_dir, evt_dirent, evt_next, | ||
| 184 | evt_path, st) { | ||
| 185 | snprintf(evt_path, MAXPATHLEN, "%s/%s/%s/id", | ||
| 186 | debugfs_path, sys_dirent.d_name, | ||
| 187 | evt_dirent.d_name); | ||
| 188 | fd = open(evt_path, O_RDONLY); | ||
| 189 | if (fd < 0) | ||
| 190 | continue; | ||
| 191 | if (read(fd, id_buf, sizeof(id_buf)) < 0) { | ||
| 192 | close(fd); | ||
| 193 | continue; | ||
| 194 | } | ||
| 195 | close(fd); | ||
| 196 | id = atoll(id_buf); | ||
| 197 | if (id == config) { | ||
| 198 | closedir(evt_dir); | ||
| 199 | closedir(sys_dir); | ||
| 200 | snprintf(tracepoint_name, 2 * MAX_EVENT_LENGTH, | ||
| 201 | "%s:%s", sys_dirent.d_name, | ||
| 202 | evt_dirent.d_name); | ||
| 203 | return tracepoint_name; | ||
| 204 | } | ||
| 205 | } | ||
| 206 | closedir(evt_dir); | ||
| 207 | } | ||
| 208 | |||
| 209 | cleanup: | ||
| 210 | closedir(sys_dir); | ||
| 211 | return "unkown"; | ||
| 212 | } | ||
| 213 | |||
| 113 | static int is_cache_op_valid(u8 cache_type, u8 cache_op) | 214 | static int is_cache_op_valid(u8 cache_type, u8 cache_op) |
| 114 | { | 215 | { |
| 115 | if (hw_cache_stat[cache_type] & COP(cache_op)) | 216 | if (hw_cache_stat[cache_type] & COP(cache_op)) |
| @@ -138,9 +239,15 @@ char *event_name(int counter) | |||
| 138 | { | 239 | { |
| 139 | u64 config = attrs[counter].config; | 240 | u64 config = attrs[counter].config; |
| 140 | int type = attrs[counter].type; | 241 | int type = attrs[counter].type; |
| 242 | |||
| 243 | return __event_name(type, config); | ||
| 244 | } | ||
| 245 | |||
| 246 | char *__event_name(int type, u64 config) | ||
| 247 | { | ||
| 141 | static char buf[32]; | 248 | static char buf[32]; |
| 142 | 249 | ||
| 143 | if (attrs[counter].type == PERF_TYPE_RAW) { | 250 | if (type == PERF_TYPE_RAW) { |
| 144 | sprintf(buf, "raw 0x%llx", config); | 251 | sprintf(buf, "raw 0x%llx", config); |
| 145 | return buf; | 252 | return buf; |
| 146 | } | 253 | } |
| @@ -177,6 +284,9 @@ char *event_name(int counter) | |||
| 177 | return sw_event_names[config]; | 284 | return sw_event_names[config]; |
| 178 | return "unknown-software"; | 285 | return "unknown-software"; |
| 179 | 286 | ||
| 287 | case PERF_TYPE_TRACEPOINT: | ||
| 288 | return tracepoint_id_to_name(config); | ||
| 289 | |||
| 180 | default: | 290 | default: |
| 181 | break; | 291 | break; |
| 182 | } | 292 | } |
| @@ -265,6 +375,63 @@ parse_generic_hw_event(const char **str, struct perf_counter_attr *attr) | |||
| 265 | return 1; | 375 | return 1; |
| 266 | } | 376 | } |
| 267 | 377 | ||
| 378 | static int parse_tracepoint_event(const char **strp, | ||
| 379 | struct perf_counter_attr *attr) | ||
| 380 | { | ||
| 381 | const char *evt_name; | ||
| 382 | char *flags; | ||
| 383 | char sys_name[MAX_EVENT_LENGTH]; | ||
| 384 | char id_buf[4]; | ||
| 385 | int fd; | ||
| 386 | unsigned int sys_length, evt_length; | ||
| 387 | u64 id; | ||
| 388 | char evt_path[MAXPATHLEN]; | ||
| 389 | |||
| 390 | if (valid_debugfs_mount(debugfs_path)) | ||
| 391 | return 0; | ||
| 392 | |||
| 393 | evt_name = strchr(*strp, ':'); | ||
| 394 | if (!evt_name) | ||
| 395 | return 0; | ||
| 396 | |||
| 397 | sys_length = evt_name - *strp; | ||
| 398 | if (sys_length >= MAX_EVENT_LENGTH) | ||
| 399 | return 0; | ||
| 400 | |||
| 401 | strncpy(sys_name, *strp, sys_length); | ||
| 402 | sys_name[sys_length] = '\0'; | ||
| 403 | evt_name = evt_name + 1; | ||
| 404 | |||
| 405 | flags = strchr(evt_name, ':'); | ||
| 406 | if (flags) { | ||
| 407 | *flags = '\0'; | ||
| 408 | flags++; | ||
| 409 | if (!strncmp(flags, "record", strlen(flags))) | ||
| 410 | attr->sample_type |= PERF_SAMPLE_RAW; | ||
| 411 | } | ||
| 412 | |||
| 413 | evt_length = strlen(evt_name); | ||
| 414 | if (evt_length >= MAX_EVENT_LENGTH) | ||
| 415 | return 0; | ||
| 416 | |||
| 417 | snprintf(evt_path, MAXPATHLEN, "%s/%s/%s/id", debugfs_path, | ||
| 418 | sys_name, evt_name); | ||
| 419 | fd = open(evt_path, O_RDONLY); | ||
| 420 | if (fd < 0) | ||
| 421 | return 0; | ||
| 422 | |||
| 423 | if (read(fd, id_buf, sizeof(id_buf)) < 0) { | ||
| 424 | close(fd); | ||
| 425 | return 0; | ||
| 426 | } | ||
| 427 | close(fd); | ||
| 428 | id = atoll(id_buf); | ||
| 429 | attr->config = id; | ||
| 430 | attr->type = PERF_TYPE_TRACEPOINT; | ||
| 431 | *strp = evt_name + evt_length; | ||
| 432 | return 1; | ||
| 433 | } | ||
| 434 | |||
| 268 | static int check_events(const char *str, unsigned int i) | 435 | static int check_events(const char *str, unsigned int i) |
| 269 | { | 436 | { |
| 270 | int n; | 437 | int n; |
| @@ -374,7 +541,8 @@ parse_event_modifier(const char **strp, struct perf_counter_attr *attr) | |||
| 374 | */ | 541 | */ |
| 375 | static int parse_event_symbols(const char **str, struct perf_counter_attr *attr) | 542 | static int parse_event_symbols(const char **str, struct perf_counter_attr *attr) |
| 376 | { | 543 | { |
| 377 | if (!(parse_raw_event(str, attr) || | 544 | if (!(parse_tracepoint_event(str, attr) || |
| 545 | parse_raw_event(str, attr) || | ||
| 378 | parse_numeric_event(str, attr) || | 546 | parse_numeric_event(str, attr) || |
| 379 | parse_symbolic_event(str, attr) || | 547 | parse_symbolic_event(str, attr) || |
| 380 | parse_generic_hw_event(str, attr))) | 548 | parse_generic_hw_event(str, attr))) |
| @@ -423,6 +591,42 @@ static const char * const event_type_descriptors[] = { | |||
| 423 | }; | 591 | }; |
| 424 | 592 | ||
| 425 | /* | 593 | /* |
| 594 | * Print the events from <debugfs_mount_point>/tracing/events | ||
| 595 | */ | ||
| 596 | |||
| 597 | static void print_tracepoint_events(void) | ||
| 598 | { | ||
| 599 | DIR *sys_dir, *evt_dir; | ||
| 600 | struct dirent *sys_next, *evt_next, sys_dirent, evt_dirent; | ||
| 601 | struct stat st; | ||
| 602 | char evt_path[MAXPATHLEN]; | ||
| 603 | |||
| 604 | if (valid_debugfs_mount(debugfs_path)) | ||
| 605 | return; | ||
| 606 | |||
| 607 | sys_dir = opendir(debugfs_path); | ||
| 608 | if (!sys_dir) | ||
| 609 | goto cleanup; | ||
| 610 | |||
| 611 | for_each_subsystem(sys_dir, sys_dirent, sys_next, evt_path, st) { | ||
| 612 | evt_dir = opendir(evt_path); | ||
| 613 | if (!evt_dir) | ||
| 614 | goto cleanup; | ||
| 615 | for_each_event(sys_dirent, evt_dir, evt_dirent, evt_next, | ||
| 616 | evt_path, st) { | ||
| 617 | snprintf(evt_path, MAXPATHLEN, "%s:%s", | ||
| 618 | sys_dirent.d_name, evt_dirent.d_name); | ||
| 619 | fprintf(stderr, " %-40s [%s]\n", evt_path, | ||
| 620 | event_type_descriptors[PERF_TYPE_TRACEPOINT+1]); | ||
| 621 | } | ||
| 622 | closedir(evt_dir); | ||
| 623 | } | ||
| 624 | |||
| 625 | cleanup: | ||
| 626 | closedir(sys_dir); | ||
| 627 | } | ||
| 628 | |||
| 629 | /* | ||
| 426 | * Print the help text for the event symbols: | 630 | * Print the help text for the event symbols: |
| 427 | */ | 631 | */ |
| 428 | void print_events(void) | 632 | void print_events(void) |
| @@ -436,7 +640,7 @@ void print_events(void) | |||
| 436 | 640 | ||
| 437 | for (i = 0; i < ARRAY_SIZE(event_symbols); i++, syms++) { | 641 | for (i = 0; i < ARRAY_SIZE(event_symbols); i++, syms++) { |
| 438 | type = syms->type + 1; | 642 | type = syms->type + 1; |
| 439 | if (type > ARRAY_SIZE(event_type_descriptors)) | 643 | if (type >= ARRAY_SIZE(event_type_descriptors)) |
| 440 | type = 0; | 644 | type = 0; |
| 441 | 645 | ||
| 442 | if (type != prev_type) | 646 | if (type != prev_type) |
| @@ -472,5 +676,7 @@ void print_events(void) | |||
| 472 | "rNNN"); | 676 | "rNNN"); |
| 473 | fprintf(stderr, "\n"); | 677 | fprintf(stderr, "\n"); |
| 474 | 678 | ||
| 679 | print_tracepoint_events(); | ||
| 680 | |||
| 475 | exit(129); | 681 | exit(129); |
| 476 | } | 682 | } |
diff --git a/tools/perf/util/parse-events.h b/tools/perf/util/parse-events.h index e3d552908e60..192a962e3a0f 100644 --- a/tools/perf/util/parse-events.h +++ b/tools/perf/util/parse-events.h | |||
| @@ -3,11 +3,14 @@ | |||
| 3 | * Parse symbolic events/counts passed in as options: | 3 | * Parse symbolic events/counts passed in as options: |
| 4 | */ | 4 | */ |
| 5 | 5 | ||
| 6 | struct option; | ||
| 7 | |||
| 6 | extern int nr_counters; | 8 | extern int nr_counters; |
| 7 | 9 | ||
| 8 | extern struct perf_counter_attr attrs[MAX_COUNTERS]; | 10 | extern struct perf_counter_attr attrs[MAX_COUNTERS]; |
| 9 | 11 | ||
| 10 | extern char *event_name(int ctr); | 12 | extern char *event_name(int ctr); |
| 13 | extern char *__event_name(int type, u64 config); | ||
| 11 | 14 | ||
| 12 | extern int parse_events(const struct option *opt, const char *str, int unset); | 15 | extern int parse_events(const struct option *opt, const char *str, int unset); |
| 13 | 16 | ||
| @@ -15,3 +18,6 @@ extern int parse_events(const struct option *opt, const char *str, int unset); | |||
| 15 | 18 | ||
| 16 | extern void print_events(void); | 19 | extern void print_events(void); |
| 17 | 20 | ||
| 21 | extern char debugfs_path[]; | ||
| 22 | extern int valid_debugfs_mount(const char *debugfs); | ||
| 23 | |||
diff --git a/tools/perf/util/quote.c b/tools/perf/util/quote.c index c6e5dc0dc82f..2726fe40eb5d 100644 --- a/tools/perf/util/quote.c +++ b/tools/perf/util/quote.c | |||
| @@ -318,7 +318,7 @@ char *quote_path_relative(const char *in, int len, | |||
| 318 | strbuf_addch(out, '"'); | 318 | strbuf_addch(out, '"'); |
| 319 | if (prefix) { | 319 | if (prefix) { |
| 320 | int off = 0; | 320 | int off = 0; |
| 321 | while (prefix[off] && off < len && prefix[off] == in[off]) | 321 | while (off < len && prefix[off] && prefix[off] == in[off]) |
| 322 | if (prefix[off] == '/') { | 322 | if (prefix[off] == '/') { |
| 323 | prefix += off + 1; | 323 | prefix += off + 1; |
| 324 | in += off + 1; | 324 | in += off + 1; |
diff --git a/tools/perf/util/string.h b/tools/perf/util/string.h index 3dca2f654cd0..bf39dfadfd24 100644 --- a/tools/perf/util/string.h +++ b/tools/perf/util/string.h | |||
| @@ -5,4 +5,7 @@ | |||
| 5 | 5 | ||
| 6 | int hex2u64(const char *ptr, u64 *val); | 6 | int hex2u64(const char *ptr, u64 *val); |
| 7 | 7 | ||
| 8 | #define _STR(x) #x | ||
| 9 | #define STR(x) _STR(x) | ||
| 10 | |||
| 8 | #endif | 11 | #endif |
diff --git a/tools/perf/util/strlist.c b/tools/perf/util/strlist.c index 025a78edfffe..7ad38171dc2b 100644 --- a/tools/perf/util/strlist.c +++ b/tools/perf/util/strlist.c | |||
| @@ -64,6 +64,7 @@ int strlist__add(struct strlist *self, const char *new_entry) | |||
| 64 | 64 | ||
| 65 | rb_link_node(&sn->rb_node, parent, p); | 65 | rb_link_node(&sn->rb_node, parent, p); |
| 66 | rb_insert_color(&sn->rb_node, &self->entries); | 66 | rb_insert_color(&sn->rb_node, &self->entries); |
| 67 | ++self->nr_entries; | ||
| 67 | 68 | ||
| 68 | return 0; | 69 | return 0; |
| 69 | } | 70 | } |
| @@ -155,8 +156,9 @@ struct strlist *strlist__new(bool dupstr, const char *slist) | |||
| 155 | struct strlist *self = malloc(sizeof(*self)); | 156 | struct strlist *self = malloc(sizeof(*self)); |
| 156 | 157 | ||
| 157 | if (self != NULL) { | 158 | if (self != NULL) { |
| 158 | self->entries = RB_ROOT; | 159 | self->entries = RB_ROOT; |
| 159 | self->dupstr = dupstr; | 160 | self->dupstr = dupstr; |
| 161 | self->nr_entries = 0; | ||
| 160 | if (slist && strlist__parse_list(self, slist) != 0) | 162 | if (slist && strlist__parse_list(self, slist) != 0) |
| 161 | goto out_error; | 163 | goto out_error; |
| 162 | } | 164 | } |
| @@ -182,3 +184,17 @@ void strlist__delete(struct strlist *self) | |||
| 182 | free(self); | 184 | free(self); |
| 183 | } | 185 | } |
| 184 | } | 186 | } |
| 187 | |||
| 188 | struct str_node *strlist__entry(const struct strlist *self, unsigned int idx) | ||
| 189 | { | ||
| 190 | struct rb_node *nd; | ||
| 191 | |||
| 192 | for (nd = rb_first(&self->entries); nd; nd = rb_next(nd)) { | ||
| 193 | struct str_node *pos = rb_entry(nd, struct str_node, rb_node); | ||
| 194 | |||
| 195 | if (!idx--) | ||
| 196 | return pos; | ||
| 197 | } | ||
| 198 | |||
| 199 | return NULL; | ||
| 200 | } | ||
diff --git a/tools/perf/util/strlist.h b/tools/perf/util/strlist.h index 2fdcfee87586..921818e44a54 100644 --- a/tools/perf/util/strlist.h +++ b/tools/perf/util/strlist.h | |||
| @@ -11,7 +11,8 @@ struct str_node { | |||
| 11 | 11 | ||
| 12 | struct strlist { | 12 | struct strlist { |
| 13 | struct rb_root entries; | 13 | struct rb_root entries; |
| 14 | bool dupstr; | 14 | unsigned int nr_entries; |
| 15 | bool dupstr; | ||
| 15 | }; | 16 | }; |
| 16 | 17 | ||
| 17 | struct strlist *strlist__new(bool dupstr, const char *slist); | 18 | struct strlist *strlist__new(bool dupstr, const char *slist); |
| @@ -21,11 +22,17 @@ void strlist__remove(struct strlist *self, struct str_node *sn); | |||
| 21 | int strlist__load(struct strlist *self, const char *filename); | 22 | int strlist__load(struct strlist *self, const char *filename); |
| 22 | int strlist__add(struct strlist *self, const char *str); | 23 | int strlist__add(struct strlist *self, const char *str); |
| 23 | 24 | ||
| 25 | struct str_node *strlist__entry(const struct strlist *self, unsigned int idx); | ||
| 24 | bool strlist__has_entry(struct strlist *self, const char *entry); | 26 | bool strlist__has_entry(struct strlist *self, const char *entry); |
| 25 | 27 | ||
| 26 | static inline bool strlist__empty(const struct strlist *self) | 28 | static inline bool strlist__empty(const struct strlist *self) |
| 27 | { | 29 | { |
| 28 | return rb_first(&self->entries) == NULL; | 30 | return self->nr_entries == 0; |
| 31 | } | ||
| 32 | |||
| 33 | static inline unsigned int strlist__nr_entries(const struct strlist *self) | ||
| 34 | { | ||
| 35 | return self->nr_entries; | ||
| 29 | } | 36 | } |
| 30 | 37 | ||
| 31 | int strlist__parse_list(struct strlist *self, const char *s); | 38 | int strlist__parse_list(struct strlist *self, const char *s); |
diff --git a/tools/perf/util/symbol.c b/tools/perf/util/symbol.c index 4683b67b5ee4..5c0f42e6b33b 100644 --- a/tools/perf/util/symbol.c +++ b/tools/perf/util/symbol.c | |||
| @@ -9,6 +9,16 @@ | |||
| 9 | 9 | ||
| 10 | const char *sym_hist_filter; | 10 | const char *sym_hist_filter; |
| 11 | 11 | ||
| 12 | enum dso_origin { | ||
| 13 | DSO__ORIG_KERNEL = 0, | ||
| 14 | DSO__ORIG_JAVA_JIT, | ||
| 15 | DSO__ORIG_FEDORA, | ||
| 16 | DSO__ORIG_UBUNTU, | ||
| 17 | DSO__ORIG_BUILDID, | ||
| 18 | DSO__ORIG_DSO, | ||
| 19 | DSO__ORIG_NOT_FOUND, | ||
| 20 | }; | ||
| 21 | |||
| 12 | static struct symbol *symbol__new(u64 start, u64 len, | 22 | static struct symbol *symbol__new(u64 start, u64 len, |
| 13 | const char *name, unsigned int priv_size, | 23 | const char *name, unsigned int priv_size, |
| 14 | u64 obj_start, int verbose) | 24 | u64 obj_start, int verbose) |
| @@ -65,6 +75,8 @@ struct dso *dso__new(const char *name, unsigned int sym_priv_size) | |||
| 65 | self->syms = RB_ROOT; | 75 | self->syms = RB_ROOT; |
| 66 | self->sym_priv_size = sym_priv_size; | 76 | self->sym_priv_size = sym_priv_size; |
| 67 | self->find_symbol = dso__find_symbol; | 77 | self->find_symbol = dso__find_symbol; |
| 78 | self->slen_calculated = 0; | ||
| 79 | self->origin = DSO__ORIG_NOT_FOUND; | ||
| 68 | } | 80 | } |
| 69 | 81 | ||
| 70 | return self; | 82 | return self; |
| @@ -373,36 +385,61 @@ static Elf_Scn *elf_section_by_name(Elf *elf, GElf_Ehdr *ep, | |||
| 373 | idx < nr_entries; \ | 385 | idx < nr_entries; \ |
| 374 | ++idx, pos = gelf_getrela(reldata, idx, &pos_mem)) | 386 | ++idx, pos = gelf_getrela(reldata, idx, &pos_mem)) |
| 375 | 387 | ||
| 376 | static int dso__synthesize_plt_symbols(struct dso *self, Elf *elf, | 388 | /* |
| 377 | GElf_Ehdr *ehdr, Elf_Scn *scn_dynsym, | 389 | * We need to check if we have a .dynsym, so that we can handle the |
| 378 | GElf_Shdr *shdr_dynsym, | 390 | * .plt, synthesizing its symbols, that aren't on the symtabs (be it |
| 379 | size_t dynsym_idx, int verbose) | 391 | * .dynsym or .symtab). |
| 392 | * And always look at the original dso, not at debuginfo packages, that | ||
| 393 | * have the PLT data stripped out (shdr_rel_plt.sh_type == SHT_NOBITS). | ||
| 394 | */ | ||
| 395 | static int dso__synthesize_plt_symbols(struct dso *self, int verbose) | ||
| 380 | { | 396 | { |
| 381 | uint32_t nr_rel_entries, idx; | 397 | uint32_t nr_rel_entries, idx; |
| 382 | GElf_Sym sym; | 398 | GElf_Sym sym; |
| 383 | u64 plt_offset; | 399 | u64 plt_offset; |
| 384 | GElf_Shdr shdr_plt; | 400 | GElf_Shdr shdr_plt; |
| 385 | struct symbol *f; | 401 | struct symbol *f; |
| 386 | GElf_Shdr shdr_rel_plt; | 402 | GElf_Shdr shdr_rel_plt, shdr_dynsym; |
| 387 | Elf_Data *reldata, *syms, *symstrs; | 403 | Elf_Data *reldata, *syms, *symstrs; |
| 388 | Elf_Scn *scn_plt_rel, *scn_symstrs; | 404 | Elf_Scn *scn_plt_rel, *scn_symstrs, *scn_dynsym; |
| 405 | size_t dynsym_idx; | ||
| 406 | GElf_Ehdr ehdr; | ||
| 389 | char sympltname[1024]; | 407 | char sympltname[1024]; |
| 390 | int nr = 0, symidx; | 408 | Elf *elf; |
| 409 | int nr = 0, symidx, fd, err = 0; | ||
| 410 | |||
| 411 | fd = open(self->name, O_RDONLY); | ||
| 412 | if (fd < 0) | ||
| 413 | goto out; | ||
| 391 | 414 | ||
| 392 | scn_plt_rel = elf_section_by_name(elf, ehdr, &shdr_rel_plt, | 415 | elf = elf_begin(fd, ELF_C_READ_MMAP, NULL); |
| 416 | if (elf == NULL) | ||
| 417 | goto out_close; | ||
| 418 | |||
| 419 | if (gelf_getehdr(elf, &ehdr) == NULL) | ||
| 420 | goto out_elf_end; | ||
| 421 | |||
| 422 | scn_dynsym = elf_section_by_name(elf, &ehdr, &shdr_dynsym, | ||
| 423 | ".dynsym", &dynsym_idx); | ||
| 424 | if (scn_dynsym == NULL) | ||
| 425 | goto out_elf_end; | ||
| 426 | |||
| 427 | scn_plt_rel = elf_section_by_name(elf, &ehdr, &shdr_rel_plt, | ||
| 393 | ".rela.plt", NULL); | 428 | ".rela.plt", NULL); |
| 394 | if (scn_plt_rel == NULL) { | 429 | if (scn_plt_rel == NULL) { |
| 395 | scn_plt_rel = elf_section_by_name(elf, ehdr, &shdr_rel_plt, | 430 | scn_plt_rel = elf_section_by_name(elf, &ehdr, &shdr_rel_plt, |
| 396 | ".rel.plt", NULL); | 431 | ".rel.plt", NULL); |
| 397 | if (scn_plt_rel == NULL) | 432 | if (scn_plt_rel == NULL) |
| 398 | return 0; | 433 | goto out_elf_end; |
| 399 | } | 434 | } |
| 400 | 435 | ||
| 436 | err = -1; | ||
| 437 | |||
| 401 | if (shdr_rel_plt.sh_link != dynsym_idx) | 438 | if (shdr_rel_plt.sh_link != dynsym_idx) |
| 402 | return 0; | 439 | goto out_elf_end; |
| 403 | 440 | ||
| 404 | if (elf_section_by_name(elf, ehdr, &shdr_plt, ".plt", NULL) == NULL) | 441 | if (elf_section_by_name(elf, &ehdr, &shdr_plt, ".plt", NULL) == NULL) |
| 405 | return 0; | 442 | goto out_elf_end; |
| 406 | 443 | ||
| 407 | /* | 444 | /* |
| 408 | * Fetch the relocation section to find the indexes to the GOT | 445 | * Fetch the relocation section to find the indexes to the GOT |
| @@ -410,19 +447,19 @@ static int dso__synthesize_plt_symbols(struct dso *self, Elf *elf, | |||
| 410 | */ | 447 | */ |
| 411 | reldata = elf_getdata(scn_plt_rel, NULL); | 448 | reldata = elf_getdata(scn_plt_rel, NULL); |
| 412 | if (reldata == NULL) | 449 | if (reldata == NULL) |
| 413 | return -1; | 450 | goto out_elf_end; |
| 414 | 451 | ||
| 415 | syms = elf_getdata(scn_dynsym, NULL); | 452 | syms = elf_getdata(scn_dynsym, NULL); |
| 416 | if (syms == NULL) | 453 | if (syms == NULL) |
| 417 | return -1; | 454 | goto out_elf_end; |
| 418 | 455 | ||
| 419 | scn_symstrs = elf_getscn(elf, shdr_dynsym->sh_link); | 456 | scn_symstrs = elf_getscn(elf, shdr_dynsym.sh_link); |
| 420 | if (scn_symstrs == NULL) | 457 | if (scn_symstrs == NULL) |
| 421 | return -1; | 458 | goto out_elf_end; |
| 422 | 459 | ||
| 423 | symstrs = elf_getdata(scn_symstrs, NULL); | 460 | symstrs = elf_getdata(scn_symstrs, NULL); |
| 424 | if (symstrs == NULL) | 461 | if (symstrs == NULL) |
| 425 | return -1; | 462 | goto out_elf_end; |
| 426 | 463 | ||
| 427 | nr_rel_entries = shdr_rel_plt.sh_size / shdr_rel_plt.sh_entsize; | 464 | nr_rel_entries = shdr_rel_plt.sh_size / shdr_rel_plt.sh_entsize; |
| 428 | plt_offset = shdr_plt.sh_offset; | 465 | plt_offset = shdr_plt.sh_offset; |
| @@ -441,7 +478,7 @@ static int dso__synthesize_plt_symbols(struct dso *self, Elf *elf, | |||
| 441 | f = symbol__new(plt_offset, shdr_plt.sh_entsize, | 478 | f = symbol__new(plt_offset, shdr_plt.sh_entsize, |
| 442 | sympltname, self->sym_priv_size, 0, verbose); | 479 | sympltname, self->sym_priv_size, 0, verbose); |
| 443 | if (!f) | 480 | if (!f) |
| 444 | return -1; | 481 | goto out_elf_end; |
| 445 | 482 | ||
| 446 | dso__insert_symbol(self, f); | 483 | dso__insert_symbol(self, f); |
| 447 | ++nr; | 484 | ++nr; |
| @@ -459,19 +496,25 @@ static int dso__synthesize_plt_symbols(struct dso *self, Elf *elf, | |||
| 459 | f = symbol__new(plt_offset, shdr_plt.sh_entsize, | 496 | f = symbol__new(plt_offset, shdr_plt.sh_entsize, |
| 460 | sympltname, self->sym_priv_size, 0, verbose); | 497 | sympltname, self->sym_priv_size, 0, verbose); |
| 461 | if (!f) | 498 | if (!f) |
| 462 | return -1; | 499 | goto out_elf_end; |
| 463 | 500 | ||
| 464 | dso__insert_symbol(self, f); | 501 | dso__insert_symbol(self, f); |
| 465 | ++nr; | 502 | ++nr; |
| 466 | } | 503 | } |
| 467 | } else { | ||
| 468 | /* | ||
| 469 | * TODO: There are still one more shdr_rel_plt.sh_type | ||
| 470 | * I have to investigate, but probably should be ignored. | ||
| 471 | */ | ||
| 472 | } | 504 | } |
| 473 | 505 | ||
| 474 | return nr; | 506 | err = 0; |
| 507 | out_elf_end: | ||
| 508 | elf_end(elf); | ||
| 509 | out_close: | ||
| 510 | close(fd); | ||
| 511 | |||
| 512 | if (err == 0) | ||
| 513 | return nr; | ||
| 514 | out: | ||
| 515 | fprintf(stderr, "%s: problems reading %s PLT info.\n", | ||
| 516 | __func__, self->name); | ||
| 517 | return 0; | ||
| 475 | } | 518 | } |
| 476 | 519 | ||
| 477 | static int dso__load_sym(struct dso *self, int fd, const char *name, | 520 | static int dso__load_sym(struct dso *self, int fd, const char *name, |
| @@ -485,10 +528,9 @@ static int dso__load_sym(struct dso *self, int fd, const char *name, | |||
| 485 | GElf_Shdr shdr; | 528 | GElf_Shdr shdr; |
| 486 | Elf_Data *syms; | 529 | Elf_Data *syms; |
| 487 | GElf_Sym sym; | 530 | GElf_Sym sym; |
| 488 | Elf_Scn *sec, *sec_dynsym, *sec_strndx; | 531 | Elf_Scn *sec, *sec_strndx; |
| 489 | Elf *elf; | 532 | Elf *elf; |
| 490 | size_t dynsym_idx; | 533 | int nr = 0, kernel = !strcmp("[kernel]", self->name); |
| 491 | int nr = 0; | ||
| 492 | 534 | ||
| 493 | elf = elf_begin(fd, ELF_C_READ_MMAP, NULL); | 535 | elf = elf_begin(fd, ELF_C_READ_MMAP, NULL); |
| 494 | if (elf == NULL) { | 536 | if (elf == NULL) { |
| @@ -504,32 +546,11 @@ static int dso__load_sym(struct dso *self, int fd, const char *name, | |||
| 504 | goto out_elf_end; | 546 | goto out_elf_end; |
| 505 | } | 547 | } |
| 506 | 548 | ||
| 507 | /* | ||
| 508 | * We need to check if we have a .dynsym, so that we can handle the | ||
| 509 | * .plt, synthesizing its symbols, that aren't on the symtabs (be it | ||
| 510 | * .dynsym or .symtab) | ||
| 511 | */ | ||
| 512 | sec_dynsym = elf_section_by_name(elf, &ehdr, &shdr, | ||
| 513 | ".dynsym", &dynsym_idx); | ||
| 514 | if (sec_dynsym != NULL) { | ||
| 515 | nr = dso__synthesize_plt_symbols(self, elf, &ehdr, | ||
| 516 | sec_dynsym, &shdr, | ||
| 517 | dynsym_idx, verbose); | ||
| 518 | if (nr < 0) | ||
| 519 | goto out_elf_end; | ||
| 520 | } | ||
| 521 | |||
| 522 | /* | ||
| 523 | * But if we have a full .symtab (that is a superset of .dynsym) we | ||
| 524 | * should add the symbols not in the .dynsyn | ||
| 525 | */ | ||
| 526 | sec = elf_section_by_name(elf, &ehdr, &shdr, ".symtab", NULL); | 549 | sec = elf_section_by_name(elf, &ehdr, &shdr, ".symtab", NULL); |
| 527 | if (sec == NULL) { | 550 | if (sec == NULL) { |
| 528 | if (sec_dynsym == NULL) | 551 | sec = elf_section_by_name(elf, &ehdr, &shdr, ".dynsym", NULL); |
| 552 | if (sec == NULL) | ||
| 529 | goto out_elf_end; | 553 | goto out_elf_end; |
| 530 | |||
| 531 | sec = sec_dynsym; | ||
| 532 | gelf_getshdr(sec, &shdr); | ||
| 533 | } | 554 | } |
| 534 | 555 | ||
| 535 | syms = elf_getdata(sec, NULL); | 556 | syms = elf_getdata(sec, NULL); |
| @@ -549,18 +570,23 @@ static int dso__load_sym(struct dso *self, int fd, const char *name, | |||
| 549 | goto out_elf_end; | 570 | goto out_elf_end; |
| 550 | 571 | ||
| 551 | secstrs = elf_getdata(sec_strndx, NULL); | 572 | secstrs = elf_getdata(sec_strndx, NULL); |
| 552 | if (symstrs == NULL) | 573 | if (secstrs == NULL) |
| 553 | goto out_elf_end; | 574 | goto out_elf_end; |
| 554 | 575 | ||
| 555 | nr_syms = shdr.sh_size / shdr.sh_entsize; | 576 | nr_syms = shdr.sh_size / shdr.sh_entsize; |
| 556 | 577 | ||
| 557 | memset(&sym, 0, sizeof(sym)); | 578 | memset(&sym, 0, sizeof(sym)); |
| 558 | self->adjust_symbols = (ehdr.e_type == ET_EXEC || | 579 | if (!kernel) { |
| 580 | self->adjust_symbols = (ehdr.e_type == ET_EXEC || | ||
| 559 | elf_section_by_name(elf, &ehdr, &shdr, | 581 | elf_section_by_name(elf, &ehdr, &shdr, |
| 560 | ".gnu.prelink_undo", | 582 | ".gnu.prelink_undo", |
| 561 | NULL) != NULL); | 583 | NULL) != NULL); |
| 584 | } else self->adjust_symbols = 0; | ||
| 585 | |||
| 562 | elf_symtab__for_each_symbol(syms, nr_syms, index, sym) { | 586 | elf_symtab__for_each_symbol(syms, nr_syms, index, sym) { |
| 563 | struct symbol *f; | 587 | struct symbol *f; |
| 588 | const char *name; | ||
| 589 | char *demangled; | ||
| 564 | u64 obj_start; | 590 | u64 obj_start; |
| 565 | struct section *section = NULL; | 591 | struct section *section = NULL; |
| 566 | int is_label = elf_sym__is_label(&sym); | 592 | int is_label = elf_sym__is_label(&sym); |
| @@ -599,10 +625,19 @@ static int dso__load_sym(struct dso *self, int fd, const char *name, | |||
| 599 | goto out_elf_end; | 625 | goto out_elf_end; |
| 600 | } | 626 | } |
| 601 | } | 627 | } |
| 628 | /* | ||
| 629 | * We need to figure out if the object was created from C++ sources | ||
| 630 | * DWARF DW_compile_unit has this, but we don't always have access | ||
| 631 | * to it... | ||
| 632 | */ | ||
| 633 | name = elf_sym__name(&sym, symstrs); | ||
| 634 | demangled = bfd_demangle(NULL, name, DMGL_PARAMS | DMGL_ANSI); | ||
| 635 | if (demangled != NULL) | ||
| 636 | name = demangled; | ||
| 602 | 637 | ||
| 603 | f = symbol__new(sym.st_value, sym.st_size, | 638 | f = symbol__new(sym.st_value, sym.st_size, name, |
| 604 | elf_sym__name(&sym, symstrs), | ||
| 605 | self->sym_priv_size, obj_start, verbose); | 639 | self->sym_priv_size, obj_start, verbose); |
| 640 | free(demangled); | ||
| 606 | if (!f) | 641 | if (!f) |
| 607 | goto out_elf_end; | 642 | goto out_elf_end; |
| 608 | 643 | ||
| @@ -622,11 +657,85 @@ out_close: | |||
| 622 | return err; | 657 | return err; |
| 623 | } | 658 | } |
| 624 | 659 | ||
| 660 | #define BUILD_ID_SIZE 128 | ||
| 661 | |||
| 662 | static char *dso__read_build_id(struct dso *self, int verbose) | ||
| 663 | { | ||
| 664 | int i; | ||
| 665 | GElf_Ehdr ehdr; | ||
| 666 | GElf_Shdr shdr; | ||
| 667 | Elf_Data *build_id_data; | ||
| 668 | Elf_Scn *sec; | ||
| 669 | char *build_id = NULL, *bid; | ||
| 670 | unsigned char *raw; | ||
| 671 | Elf *elf; | ||
| 672 | int fd = open(self->name, O_RDONLY); | ||
| 673 | |||
| 674 | if (fd < 0) | ||
| 675 | goto out; | ||
| 676 | |||
| 677 | elf = elf_begin(fd, ELF_C_READ_MMAP, NULL); | ||
| 678 | if (elf == NULL) { | ||
| 679 | if (verbose) | ||
| 680 | fprintf(stderr, "%s: cannot read %s ELF file.\n", | ||
| 681 | __func__, self->name); | ||
| 682 | goto out_close; | ||
| 683 | } | ||
| 684 | |||
| 685 | if (gelf_getehdr(elf, &ehdr) == NULL) { | ||
| 686 | if (verbose) | ||
| 687 | fprintf(stderr, "%s: cannot get elf header.\n", __func__); | ||
| 688 | goto out_elf_end; | ||
| 689 | } | ||
| 690 | |||
| 691 | sec = elf_section_by_name(elf, &ehdr, &shdr, ".note.gnu.build-id", NULL); | ||
| 692 | if (sec == NULL) | ||
| 693 | goto out_elf_end; | ||
| 694 | |||
| 695 | build_id_data = elf_getdata(sec, NULL); | ||
| 696 | if (build_id_data == NULL) | ||
| 697 | goto out_elf_end; | ||
| 698 | build_id = malloc(BUILD_ID_SIZE); | ||
| 699 | if (build_id == NULL) | ||
| 700 | goto out_elf_end; | ||
| 701 | raw = build_id_data->d_buf + 16; | ||
| 702 | bid = build_id; | ||
| 703 | |||
| 704 | for (i = 0; i < 20; ++i) { | ||
| 705 | sprintf(bid, "%02x", *raw); | ||
| 706 | ++raw; | ||
| 707 | bid += 2; | ||
| 708 | } | ||
| 709 | if (verbose >= 2) | ||
| 710 | printf("%s(%s): %s\n", __func__, self->name, build_id); | ||
| 711 | out_elf_end: | ||
| 712 | elf_end(elf); | ||
| 713 | out_close: | ||
| 714 | close(fd); | ||
| 715 | out: | ||
| 716 | return build_id; | ||
| 717 | } | ||
| 718 | |||
| 719 | char dso__symtab_origin(const struct dso *self) | ||
| 720 | { | ||
| 721 | static const char origin[] = { | ||
| 722 | [DSO__ORIG_KERNEL] = 'k', | ||
| 723 | [DSO__ORIG_JAVA_JIT] = 'j', | ||
| 724 | [DSO__ORIG_FEDORA] = 'f', | ||
| 725 | [DSO__ORIG_UBUNTU] = 'u', | ||
| 726 | [DSO__ORIG_BUILDID] = 'b', | ||
| 727 | [DSO__ORIG_DSO] = 'd', | ||
| 728 | }; | ||
| 729 | |||
| 730 | if (self == NULL || self->origin == DSO__ORIG_NOT_FOUND) | ||
| 731 | return '!'; | ||
| 732 | return origin[self->origin]; | ||
| 733 | } | ||
| 734 | |||
| 625 | int dso__load(struct dso *self, symbol_filter_t filter, int verbose) | 735 | int dso__load(struct dso *self, symbol_filter_t filter, int verbose) |
| 626 | { | 736 | { |
| 627 | int size = strlen(self->name) + sizeof("/usr/lib/debug%s.debug"); | 737 | int size = PATH_MAX; |
| 628 | char *name = malloc(size); | 738 | char *name = malloc(size), *build_id = NULL; |
| 629 | int variant = 0; | ||
| 630 | int ret = -1; | 739 | int ret = -1; |
| 631 | int fd; | 740 | int fd; |
| 632 | 741 | ||
| @@ -635,26 +744,43 @@ int dso__load(struct dso *self, symbol_filter_t filter, int verbose) | |||
| 635 | 744 | ||
| 636 | self->adjust_symbols = 0; | 745 | self->adjust_symbols = 0; |
| 637 | 746 | ||
| 638 | if (strncmp(self->name, "/tmp/perf-", 10) == 0) | 747 | if (strncmp(self->name, "/tmp/perf-", 10) == 0) { |
| 639 | return dso__load_perf_map(self, filter, verbose); | 748 | ret = dso__load_perf_map(self, filter, verbose); |
| 749 | self->origin = ret > 0 ? DSO__ORIG_JAVA_JIT : | ||
| 750 | DSO__ORIG_NOT_FOUND; | ||
| 751 | return ret; | ||
| 752 | } | ||
| 753 | |||
| 754 | self->origin = DSO__ORIG_FEDORA - 1; | ||
| 640 | 755 | ||
| 641 | more: | 756 | more: |
| 642 | do { | 757 | do { |
| 643 | switch (variant) { | 758 | self->origin++; |
| 644 | case 0: /* Fedora */ | 759 | switch (self->origin) { |
| 760 | case DSO__ORIG_FEDORA: | ||
| 645 | snprintf(name, size, "/usr/lib/debug%s.debug", self->name); | 761 | snprintf(name, size, "/usr/lib/debug%s.debug", self->name); |
| 646 | break; | 762 | break; |
| 647 | case 1: /* Ubuntu */ | 763 | case DSO__ORIG_UBUNTU: |
| 648 | snprintf(name, size, "/usr/lib/debug%s", self->name); | 764 | snprintf(name, size, "/usr/lib/debug%s", self->name); |
| 649 | break; | 765 | break; |
| 650 | case 2: /* Sane people */ | 766 | case DSO__ORIG_BUILDID: |
| 767 | build_id = dso__read_build_id(self, verbose); | ||
| 768 | if (build_id != NULL) { | ||
| 769 | snprintf(name, size, | ||
| 770 | "/usr/lib/debug/.build-id/%.2s/%s.debug", | ||
| 771 | build_id, build_id + 2); | ||
| 772 | free(build_id); | ||
| 773 | break; | ||
| 774 | } | ||
| 775 | self->origin++; | ||
| 776 | /* Fall thru */ | ||
| 777 | case DSO__ORIG_DSO: | ||
| 651 | snprintf(name, size, "%s", self->name); | 778 | snprintf(name, size, "%s", self->name); |
| 652 | break; | 779 | break; |
| 653 | 780 | ||
| 654 | default: | 781 | default: |
| 655 | goto out; | 782 | goto out; |
| 656 | } | 783 | } |
| 657 | variant++; | ||
| 658 | 784 | ||
| 659 | fd = open(name, O_RDONLY); | 785 | fd = open(name, O_RDONLY); |
| 660 | } while (fd < 0); | 786 | } while (fd < 0); |
| @@ -668,8 +794,15 @@ more: | |||
| 668 | if (!ret) | 794 | if (!ret) |
| 669 | goto more; | 795 | goto more; |
| 670 | 796 | ||
| 797 | if (ret > 0) { | ||
| 798 | int nr_plt = dso__synthesize_plt_symbols(self, verbose); | ||
| 799 | if (nr_plt > 0) | ||
| 800 | ret += nr_plt; | ||
| 801 | } | ||
| 671 | out: | 802 | out: |
| 672 | free(name); | 803 | free(name); |
| 804 | if (ret < 0 && strstr(self->name, " (deleted)") != NULL) | ||
| 805 | return 0; | ||
| 673 | return ret; | 806 | return ret; |
| 674 | } | 807 | } |
| 675 | 808 | ||
| @@ -785,6 +918,9 @@ int dso__load_kernel(struct dso *self, const char *vmlinux, | |||
| 785 | if (err <= 0) | 918 | if (err <= 0) |
| 786 | err = dso__load_kallsyms(self, filter, verbose); | 919 | err = dso__load_kallsyms(self, filter, verbose); |
| 787 | 920 | ||
| 921 | if (err > 0) | ||
| 922 | self->origin = DSO__ORIG_KERNEL; | ||
| 923 | |||
| 788 | return err; | 924 | return err; |
| 789 | } | 925 | } |
| 790 | 926 | ||
diff --git a/tools/perf/util/symbol.h b/tools/perf/util/symbol.h index 7918cffb23cd..b53bf0125c1b 100644 --- a/tools/perf/util/symbol.h +++ b/tools/perf/util/symbol.h | |||
| @@ -7,6 +7,30 @@ | |||
| 7 | #include <linux/rbtree.h> | 7 | #include <linux/rbtree.h> |
| 8 | #include "module.h" | 8 | #include "module.h" |
| 9 | 9 | ||
| 10 | #ifdef HAVE_CPLUS_DEMANGLE | ||
| 11 | extern char *cplus_demangle(const char *, int); | ||
| 12 | |||
| 13 | static inline char *bfd_demangle(void __used *v, const char *c, int i) | ||
| 14 | { | ||
| 15 | return cplus_demangle(c, i); | ||
| 16 | } | ||
| 17 | #else | ||
| 18 | #ifdef NO_DEMANGLE | ||
| 19 | static inline char *bfd_demangle(void __used *v, const char __used *c, | ||
| 20 | int __used i) | ||
| 21 | { | ||
| 22 | return NULL; | ||
| 23 | } | ||
| 24 | #else | ||
| 25 | #include <bfd.h> | ||
| 26 | #endif | ||
| 27 | #endif | ||
| 28 | |||
| 29 | #ifndef DMGL_PARAMS | ||
| 30 | #define DMGL_PARAMS (1 << 0) /* Include function args */ | ||
| 31 | #define DMGL_ANSI (1 << 1) /* Include const, volatile, etc */ | ||
| 32 | #endif | ||
| 33 | |||
| 10 | struct symbol { | 34 | struct symbol { |
| 11 | struct rb_node rb_node; | 35 | struct rb_node rb_node; |
| 12 | u64 start; | 36 | u64 start; |
| @@ -25,6 +49,8 @@ struct dso { | |||
| 25 | struct symbol *(*find_symbol)(struct dso *, u64 ip); | 49 | struct symbol *(*find_symbol)(struct dso *, u64 ip); |
| 26 | unsigned int sym_priv_size; | 50 | unsigned int sym_priv_size; |
| 27 | unsigned char adjust_symbols; | 51 | unsigned char adjust_symbols; |
| 52 | unsigned char slen_calculated; | ||
| 53 | unsigned char origin; | ||
| 28 | char name[0]; | 54 | char name[0]; |
| 29 | }; | 55 | }; |
| 30 | 56 | ||
| @@ -48,6 +74,7 @@ int dso__load_modules(struct dso *self, symbol_filter_t filter, int verbose); | |||
| 48 | int dso__load(struct dso *self, symbol_filter_t filter, int verbose); | 74 | int dso__load(struct dso *self, symbol_filter_t filter, int verbose); |
| 49 | 75 | ||
| 50 | size_t dso__fprintf(struct dso *self, FILE *fp); | 76 | size_t dso__fprintf(struct dso *self, FILE *fp); |
| 77 | char dso__symtab_origin(const struct dso *self); | ||
| 51 | 78 | ||
| 52 | void symbol__init(void); | 79 | void symbol__init(void); |
| 53 | #endif /* _PERF_SYMBOL_ */ | 80 | #endif /* _PERF_SYMBOL_ */ |
diff --git a/tools/perf/util/util.h b/tools/perf/util/util.h index b4be6071c105..68fe157d72fb 100644 --- a/tools/perf/util/util.h +++ b/tools/perf/util/util.h | |||
| @@ -50,6 +50,7 @@ | |||
| 50 | #include <unistd.h> | 50 | #include <unistd.h> |
| 51 | #include <stdio.h> | 51 | #include <stdio.h> |
| 52 | #include <sys/stat.h> | 52 | #include <sys/stat.h> |
| 53 | #include <sys/statfs.h> | ||
| 53 | #include <fcntl.h> | 54 | #include <fcntl.h> |
| 54 | #include <stddef.h> | 55 | #include <stddef.h> |
| 55 | #include <stdlib.h> | 56 | #include <stdlib.h> |
| @@ -80,6 +81,7 @@ | |||
| 80 | #include <netdb.h> | 81 | #include <netdb.h> |
| 81 | #include <pwd.h> | 82 | #include <pwd.h> |
| 82 | #include <inttypes.h> | 83 | #include <inttypes.h> |
| 84 | #include "../../../include/linux/magic.h" | ||
| 83 | 85 | ||
| 84 | #ifndef NO_ICONV | 86 | #ifndef NO_ICONV |
| 85 | #include <iconv.h> | 87 | #include <iconv.h> |
diff --git a/virt/kvm/ioapic.c b/virt/kvm/ioapic.c index 1eddae94bab3..1150c6d5c7b8 100644 --- a/virt/kvm/ioapic.c +++ b/virt/kvm/ioapic.c | |||
| @@ -95,8 +95,6 @@ static int ioapic_service(struct kvm_ioapic *ioapic, unsigned int idx) | |||
| 95 | if (injected && pent->fields.trig_mode == IOAPIC_LEVEL_TRIG) | 95 | if (injected && pent->fields.trig_mode == IOAPIC_LEVEL_TRIG) |
| 96 | pent->fields.remote_irr = 1; | 96 | pent->fields.remote_irr = 1; |
| 97 | } | 97 | } |
| 98 | if (!pent->fields.trig_mode) | ||
| 99 | ioapic->irr &= ~(1 << idx); | ||
| 100 | 98 | ||
| 101 | return injected; | 99 | return injected; |
| 102 | } | 100 | } |
| @@ -136,7 +134,8 @@ static void ioapic_write_indirect(struct kvm_ioapic *ioapic, u32 val) | |||
| 136 | mask_after = ioapic->redirtbl[index].fields.mask; | 134 | mask_after = ioapic->redirtbl[index].fields.mask; |
| 137 | if (mask_before != mask_after) | 135 | if (mask_before != mask_after) |
| 138 | kvm_fire_mask_notifiers(ioapic->kvm, index, mask_after); | 136 | kvm_fire_mask_notifiers(ioapic->kvm, index, mask_after); |
| 139 | if (ioapic->irr & (1 << index)) | 137 | if (ioapic->redirtbl[index].fields.trig_mode == IOAPIC_LEVEL_TRIG |
| 138 | && ioapic->irr & (1 << index)) | ||
| 140 | ioapic_service(ioapic, index); | 139 | ioapic_service(ioapic, index); |
| 141 | break; | 140 | break; |
| 142 | } | 141 | } |
| @@ -184,9 +183,10 @@ int kvm_ioapic_set_irq(struct kvm_ioapic *ioapic, int irq, int level) | |||
| 184 | if (!level) | 183 | if (!level) |
| 185 | ioapic->irr &= ~mask; | 184 | ioapic->irr &= ~mask; |
| 186 | else { | 185 | else { |
| 186 | int edge = (entry.fields.trig_mode == IOAPIC_EDGE_TRIG); | ||
| 187 | ioapic->irr |= mask; | 187 | ioapic->irr |= mask; |
| 188 | if ((!entry.fields.trig_mode && old_irr != ioapic->irr) | 188 | if ((edge && old_irr != ioapic->irr) || |
| 189 | || !entry.fields.remote_irr) | 189 | (!edge && !entry.fields.remote_irr)) |
| 190 | ret = ioapic_service(ioapic, irq); | 190 | ret = ioapic_service(ioapic, irq); |
| 191 | } | 191 | } |
| 192 | } | 192 | } |
diff --git a/virt/kvm/irq_comm.c b/virt/kvm/irq_comm.c index a8bd466d00cc..ddc17f0e2f35 100644 --- a/virt/kvm/irq_comm.c +++ b/virt/kvm/irq_comm.c | |||
| @@ -160,7 +160,8 @@ void kvm_notify_acked_irq(struct kvm *kvm, unsigned irqchip, unsigned pin) | |||
| 160 | unsigned gsi = pin; | 160 | unsigned gsi = pin; |
| 161 | 161 | ||
| 162 | list_for_each_entry(e, &kvm->irq_routing, link) | 162 | list_for_each_entry(e, &kvm->irq_routing, link) |
| 163 | if (e->irqchip.irqchip == irqchip && | 163 | if (e->type == KVM_IRQ_ROUTING_IRQCHIP && |
| 164 | e->irqchip.irqchip == irqchip && | ||
| 164 | e->irqchip.pin == pin) { | 165 | e->irqchip.pin == pin) { |
| 165 | gsi = e->gsi; | 166 | gsi = e->gsi; |
| 166 | break; | 167 | break; |
| @@ -259,6 +260,7 @@ static int setup_routing_entry(struct kvm_kernel_irq_routing_entry *e, | |||
| 259 | int delta; | 260 | int delta; |
| 260 | 261 | ||
| 261 | e->gsi = ue->gsi; | 262 | e->gsi = ue->gsi; |
| 263 | e->type = ue->type; | ||
| 262 | switch (ue->type) { | 264 | switch (ue->type) { |
| 263 | case KVM_IRQ_ROUTING_IRQCHIP: | 265 | case KVM_IRQ_ROUTING_IRQCHIP: |
| 264 | delta = 0; | 266 | delta = 0; |
