| Nicolas Palix | e105007 | 2010-08-24 17:38:58 +0200 | [diff] [blame] | 1 | /// Find functions that refer to GFP_KERNEL but are called with locks held. | 
|  | 2 | /// The proposed change of converting the GFP_KERNEL is not necessarily the | 
|  | 3 | /// correct one.  It may be desired to unlock the lock, or to not call the | 
|  | 4 | /// function under the lock in the first place. | 
|  | 5 | /// | 
|  | 6 | // Confidence: Moderate | 
|  | 7 | // Copyright: (C) 2010 Nicolas Palix, DIKU.  GPLv2. | 
|  | 8 | // Copyright: (C) 2010 Julia Lawall, DIKU.  GPLv2. | 
|  | 9 | // Copyright: (C) 2010 Gilles Muller, INRIA/LiP6.  GPLv2. | 
|  | 10 | // URL: http://coccinelle.lip6.fr/ | 
|  | 11 | // Comments: | 
|  | 12 | // Options: -no_includes -include_headers | 
|  | 13 |  | 
|  | 14 | virtual patch | 
|  | 15 |  | 
|  | 16 | @gfp exists@ | 
|  | 17 | identifier fn; | 
|  | 18 | position p; | 
|  | 19 | @@ | 
|  | 20 |  | 
|  | 21 | fn(...) { | 
|  | 22 | ... when != read_unlock_irq(...) | 
|  | 23 | when != write_unlock_irq(...) | 
|  | 24 | when != read_unlock_irqrestore(...) | 
|  | 25 | when != write_unlock_irqrestore(...) | 
|  | 26 | when != spin_unlock(...) | 
|  | 27 | when != spin_unlock_irq(...) | 
|  | 28 | when != spin_unlock_irqrestore(...) | 
|  | 29 | when != local_irq_enable(...) | 
|  | 30 | when any | 
|  | 31 | GFP_KERNEL@p | 
|  | 32 | ... when any | 
|  | 33 | } | 
|  | 34 |  | 
|  | 35 | @locked@ | 
|  | 36 | identifier gfp.fn; | 
|  | 37 | @@ | 
|  | 38 |  | 
|  | 39 | ( | 
|  | 40 | read_lock_irq | 
|  | 41 | | | 
|  | 42 | write_lock_irq | 
|  | 43 | | | 
|  | 44 | read_lock_irqsave | 
|  | 45 | | | 
|  | 46 | write_lock_irqsave | 
|  | 47 | | | 
|  | 48 | spin_lock | 
|  | 49 | | | 
|  | 50 | spin_trylock | 
|  | 51 | | | 
|  | 52 | spin_lock_irq | 
|  | 53 | | | 
|  | 54 | spin_lock_irqsave | 
|  | 55 | | | 
|  | 56 | local_irq_disable | 
|  | 57 | ) | 
|  | 58 | (...) | 
|  | 59 | ...  when != read_unlock_irq(...) | 
|  | 60 | when != write_unlock_irq(...) | 
|  | 61 | when != read_unlock_irqrestore(...) | 
|  | 62 | when != write_unlock_irqrestore(...) | 
|  | 63 | when != spin_unlock(...) | 
|  | 64 | when != spin_unlock_irq(...) | 
|  | 65 | when != spin_unlock_irqrestore(...) | 
|  | 66 | when != local_irq_enable(...) | 
|  | 67 | fn(...) | 
|  | 68 |  | 
|  | 69 | @depends on locked@ | 
|  | 70 | position gfp.p; | 
|  | 71 | @@ | 
|  | 72 |  | 
|  | 73 | - GFP_KERNEL@p | 
|  | 74 | + GFP_ATOMIC |