Showing error 381

User: Jiri Slaby
Error type: Reachable Error Location
Error type description: A specified error location is reachable in some program path
File location: ldv-linux-3.4/32_1_cilled_safe_ok_nondet_linux-3.4-32_1-drivers--media--rc--keymaps--rc-ati-tv-wonder-hd-600.ko-ldv_main0_sequence_infinite_withcheck_stateful.cil.out.c
Line in file: 332
Project: SV-COMP 2013
Project version: 2.6.28
Tools: Manual Work
Entered: 2013-01-17 16:57:54 UTC


Source:

  1/* Generated by CIL v. 1.3.7 */
  2/* print_CIL_Input is true */
  3
  4#line 46 "include/asm-generic/int-ll64.h"
  5typedef unsigned short u16;
  6#line 49 "include/asm-generic/int-ll64.h"
  7typedef unsigned int u32;
  8#line 52 "include/asm-generic/int-ll64.h"
  9typedef unsigned long long u64;
 10#line 219 "include/linux/types.h"
 11struct __anonstruct_atomic_t_7 {
 12   int counter ;
 13};
 14#line 219 "include/linux/types.h"
 15typedef struct __anonstruct_atomic_t_7 atomic_t;
 16#line 229 "include/linux/types.h"
 17struct list_head {
 18   struct list_head *next ;
 19   struct list_head *prev ;
 20};
 21#line 20 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/thread_info.h"
 22struct task_struct;
 23#line 20
 24struct task_struct;
 25#line 7 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/processor.h"
 26struct task_struct;
 27#line 52 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/paravirt_types.h"
 28struct task_struct;
 29#line 329
 30struct arch_spinlock;
 31#line 329
 32struct arch_spinlock;
 33#line 139 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/ptrace.h"
 34struct task_struct;
 35#line 8 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/current.h"
 36struct task_struct;
 37#line 14 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/spinlock_types.h"
 38typedef u16 __ticket_t;
 39#line 15 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/spinlock_types.h"
 40typedef u32 __ticketpair_t;
 41#line 20 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/spinlock_types.h"
 42struct __raw_tickets {
 43   __ticket_t head ;
 44   __ticket_t tail ;
 45};
 46#line 20 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/spinlock_types.h"
 47union __anonunion____missing_field_name_36 {
 48   __ticketpair_t head_tail ;
 49   struct __raw_tickets tickets ;
 50};
 51#line 20 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/spinlock_types.h"
 52struct arch_spinlock {
 53   union __anonunion____missing_field_name_36 __annonCompField17 ;
 54};
 55#line 20 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/spinlock_types.h"
 56typedef struct arch_spinlock arch_spinlock_t;
 57#line 12 "include/linux/lockdep.h"
 58struct task_struct;
 59#line 20 "include/linux/spinlock_types.h"
 60struct raw_spinlock {
 61   arch_spinlock_t raw_lock ;
 62   unsigned int magic ;
 63   unsigned int owner_cpu ;
 64   void *owner ;
 65};
 66#line 64 "include/linux/spinlock_types.h"
 67union __anonunion____missing_field_name_39 {
 68   struct raw_spinlock rlock ;
 69};
 70#line 64 "include/linux/spinlock_types.h"
 71struct spinlock {
 72   union __anonunion____missing_field_name_39 __annonCompField19 ;
 73};
 74#line 64 "include/linux/spinlock_types.h"
 75typedef struct spinlock spinlock_t;
 76#line 55 "include/linux/wait.h"
 77struct task_struct;
 78#line 48 "include/linux/mutex.h"
 79struct mutex {
 80   atomic_t count ;
 81   spinlock_t wait_lock ;
 82   struct list_head wait_list ;
 83   struct task_struct *owner ;
 84   char const   *name ;
 85   void *magic ;
 86};
 87#line 18 "include/linux/capability.h"
 88struct task_struct;
 89#line 31 "include/media/rc-map.h"
 90struct rc_map_table {
 91   u32 scancode ;
 92   u32 keycode ;
 93};
 94#line 36 "include/media/rc-map.h"
 95struct rc_map {
 96   struct rc_map_table *scan ;
 97   unsigned int size ;
 98   unsigned int len ;
 99   unsigned int alloc ;
100   u64 rc_type ;
101   char const   *name ;
102   spinlock_t lock ;
103};
104#line 46 "include/media/rc-map.h"
105struct rc_map_list {
106   struct list_head list ;
107   struct rc_map map ;
108};
109#line 270 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/elf.h"
110struct task_struct;
111#line 48 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/drivers/media/rc/keymaps/rc-ati-tv-wonder-hd-600.c.common.c"
112struct __anonstruct_220 {
113   int  : 0 ;
114};
115#line 1 "<compiler builtins>"
116long __builtin_expect(long val , long res ) ;
117#line 152 "include/linux/mutex.h"
118void mutex_lock(struct mutex *lock ) ;
119#line 153
120int __attribute__((__warn_unused_result__))  mutex_lock_interruptible(struct mutex *lock ) ;
121#line 154
122int __attribute__((__warn_unused_result__))  mutex_lock_killable(struct mutex *lock ) ;
123#line 168
124int mutex_trylock(struct mutex *lock ) ;
125#line 169
126void mutex_unlock(struct mutex *lock ) ;
127#line 170
128int atomic_dec_and_mutex_lock(atomic_t *cnt , struct mutex *lock ) ;
129#line 53 "include/media/rc-map.h"
130extern int rc_map_register(struct rc_map_list *map ) ;
131#line 54
132extern void rc_map_unregister(struct rc_map_list *map ) ;
133#line 67 "include/linux/module.h"
134int init_module(void) ;
135#line 68
136void cleanup_module(void) ;
137#line 21 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/drivers/media/rc/keymaps/rc-ati-tv-wonder-hd-600.c.common.c"
138static struct rc_map_table ati_tv_wonder_hd_600[24]  = 
139#line 21 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/drivers/media/rc/keymaps/rc-ati-tv-wonder-hd-600.c.common.c"
140  {      {(u32 )0, (u32 )167}, 
141        {(u32 )1, (u32 )164}, 
142        {(u32 )2, (u32 )128}, 
143        {(u32 )3, (u32 )116}, 
144        {(u32 )4, (u32 )412}, 
145        {(u32 )5, (u32 )168}, 
146        {(u32 )6, (u32 )159}, 
147        {(u32 )7, (u32 )407}, 
148        {(u32 )8, (u32 )365}, 
149        {(u32 )9, (u32 )102}, 
150        {(u32 )10, (u32 )139}, 
151        {(u32 )11, (u32 )402}, 
152        {(u32 )12, (u32 )158}, 
153        {(u32 )13, (u32 )103}, 
154        {(u32 )14, (u32 )358}, 
155        {(u32 )15, (u32 )403}, 
156        {(u32 )16, (u32 )105}, 
157        {(u32 )17, (u32 )353}, 
158        {(u32 )18, (u32 )106}, 
159        {(u32 )19, (u32 )115}, 
160        {(u32 )20, (u32 )405}, 
161        {(u32 )21, (u32 )108}, 
162        {(u32 )22, (u32 )113}, 
163        {(u32 )23, (u32 )114}};
164#line 48 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/drivers/media/rc/keymaps/rc-ati-tv-wonder-hd-600.c.common.c"
165static struct rc_map_list ati_tv_wonder_hd_600_map  =    {{(struct list_head *)0, (struct list_head *)0}, {ati_tv_wonder_hd_600, (unsigned int )(sizeof(ati_tv_wonder_hd_600) / sizeof(ati_tv_wonder_hd_600[0]) + sizeof(struct __anonstruct_220 )),
166                                                     0U, 0U, (u64 )0, "rc-ati-tv-wonder-hd-600",
167                                                     {{{{{0U}}, 0U, 0U, (void *)0}}}}};
168#line 57
169static int init_rc_map_ati_tv_wonder_hd_600(void)  __attribute__((__section__(".init.text"),
170__no_instrument_function__)) ;
171#line 57 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/drivers/media/rc/keymaps/rc-ati-tv-wonder-hd-600.c.common.c"
172static int init_rc_map_ati_tv_wonder_hd_600(void) 
173{ int tmp ;
174
175  {
176  {
177#line 59
178  tmp = rc_map_register(& ati_tv_wonder_hd_600_map);
179  }
180#line 59
181  return (tmp);
182}
183}
184#line 62
185static void exit_rc_map_ati_tv_wonder_hd_600(void)  __attribute__((__section__(".exit.text"),
186__no_instrument_function__)) ;
187#line 62 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/drivers/media/rc/keymaps/rc-ati-tv-wonder-hd-600.c.common.c"
188static void exit_rc_map_ati_tv_wonder_hd_600(void) 
189{ 
190
191  {
192  {
193#line 64
194  rc_map_unregister(& ati_tv_wonder_hd_600_map);
195  }
196#line 65
197  return;
198}
199}
200#line 67 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/drivers/media/rc/keymaps/rc-ati-tv-wonder-hd-600.c.common.c"
201int init_module(void) 
202{ int tmp ;
203
204  {
205  {
206#line 67
207  tmp = init_rc_map_ati_tv_wonder_hd_600();
208  }
209#line 67
210  return (tmp);
211}
212}
213#line 68 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/drivers/media/rc/keymaps/rc-ati-tv-wonder-hd-600.c.common.c"
214void cleanup_module(void) 
215{ 
216
217  {
218  {
219#line 68
220  exit_rc_map_ati_tv_wonder_hd_600();
221  }
222#line 68
223  return;
224}
225}
226#line 70 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/drivers/media/rc/keymaps/rc-ati-tv-wonder-hd-600.c.common.c"
227static char const   __mod_license70[12]  __attribute__((__used__, __unused__, __section__(".modinfo"),
228__aligned__(1)))  = 
229#line 70
230  {      (char const   )'l',      (char const   )'i',      (char const   )'c',      (char const   )'e', 
231        (char const   )'n',      (char const   )'s',      (char const   )'e',      (char const   )'=', 
232        (char const   )'G',      (char const   )'P',      (char const   )'L',      (char const   )'\000'};
233#line 71 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/drivers/media/rc/keymaps/rc-ati-tv-wonder-hd-600.c.common.c"
234static char const   __mod_author71[50]  __attribute__((__used__, __unused__, __section__(".modinfo"),
235__aligned__(1)))  = 
236#line 71
237  {      (char const   )'a',      (char const   )'u',      (char const   )'t',      (char const   )'h', 
238        (char const   )'o',      (char const   )'r',      (char const   )'=',      (char const   )'M', 
239        (char const   )'a',      (char const   )'u',      (char const   )'r',      (char const   )'o', 
240        (char const   )' ',      (char const   )'C',      (char const   )'a',      (char const   )'r', 
241        (char const   )'v',      (char const   )'a',      (char const   )'l',      (char const   )'h', 
242        (char const   )'o',      (char const   )' ',      (char const   )'C',      (char const   )'h', 
243        (char const   )'e',      (char const   )'h',      (char const   )'a',      (char const   )'b', 
244        (char const   )' ',      (char const   )'<',      (char const   )'m',      (char const   )'c', 
245        (char const   )'h',      (char const   )'e',      (char const   )'h',      (char const   )'a', 
246        (char const   )'b',      (char const   )'@',      (char const   )'r',      (char const   )'e', 
247        (char const   )'d',      (char const   )'h',      (char const   )'a',      (char const   )'t', 
248        (char const   )'.',      (char const   )'c',      (char const   )'o',      (char const   )'m', 
249        (char const   )'>',      (char const   )'\000'};
250#line 89
251void ldv_check_final_state(void) ;
252#line 95
253extern void ldv_initialize(void) ;
254#line 98
255extern int __VERIFIER_nondet_int(void) ;
256#line 101 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/drivers/media/rc/keymaps/rc-ati-tv-wonder-hd-600.c.common.c"
257int LDV_IN_INTERRUPT  ;
258#line 104 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/drivers/media/rc/keymaps/rc-ati-tv-wonder-hd-600.c.common.c"
259void main(void) 
260{ int tmp ;
261  int tmp___0 ;
262  int tmp___1 ;
263
264  {
265  {
266#line 116
267  LDV_IN_INTERRUPT = 1;
268#line 125
269  ldv_initialize();
270#line 131
271  tmp = init_rc_map_ati_tv_wonder_hd_600();
272  }
273#line 131
274  if (tmp) {
275#line 132
276    goto ldv_final;
277  } else {
278
279  }
280  {
281#line 134
282  while (1) {
283    while_continue: /* CIL Label */ ;
284    {
285#line 134
286    tmp___1 = __VERIFIER_nondet_int();
287    }
288#line 134
289    if (tmp___1) {
290
291    } else {
292#line 134
293      goto while_break;
294    }
295    {
296#line 137
297    tmp___0 = __VERIFIER_nondet_int();
298    }
299    {
300#line 139
301    goto switch_default;
302#line 137
303    if (0) {
304      switch_default: /* CIL Label */ 
305#line 139
306      goto switch_break;
307    } else {
308      switch_break: /* CIL Label */ ;
309    }
310    }
311  }
312  while_break: /* CIL Label */ ;
313  }
314  {
315#line 151
316  exit_rc_map_ati_tv_wonder_hd_600();
317  }
318  ldv_final: 
319  {
320#line 154
321  ldv_check_final_state();
322  }
323#line 157
324  return;
325}
326}
327#line 5 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/engine-blast-assert.h"
328void ldv_blast_assert(void) 
329{ 
330
331  {
332  ERROR: 
333#line 6
334  goto ERROR;
335}
336}
337#line 6 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/engine-blast.h"
338extern int __VERIFIER_nondet_int(void) ;
339#line 19 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
340int ldv_mutex  =    1;
341#line 22 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
342int __attribute__((__warn_unused_result__))  mutex_lock_interruptible(struct mutex *lock ) 
343{ int nondetermined ;
344
345  {
346#line 29
347  if (ldv_mutex == 1) {
348
349  } else {
350    {
351#line 29
352    ldv_blast_assert();
353    }
354  }
355  {
356#line 32
357  nondetermined = __VERIFIER_nondet_int();
358  }
359#line 35
360  if (nondetermined) {
361#line 38
362    ldv_mutex = 2;
363#line 40
364    return (0);
365  } else {
366#line 45
367    return (-4);
368  }
369}
370}
371#line 50 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
372int __attribute__((__warn_unused_result__))  mutex_lock_killable(struct mutex *lock ) 
373{ int nondetermined ;
374
375  {
376#line 57
377  if (ldv_mutex == 1) {
378
379  } else {
380    {
381#line 57
382    ldv_blast_assert();
383    }
384  }
385  {
386#line 60
387  nondetermined = __VERIFIER_nondet_int();
388  }
389#line 63
390  if (nondetermined) {
391#line 66
392    ldv_mutex = 2;
393#line 68
394    return (0);
395  } else {
396#line 73
397    return (-4);
398  }
399}
400}
401#line 78 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
402int atomic_dec_and_mutex_lock(atomic_t *cnt , struct mutex *lock ) 
403{ int atomic_value_after_dec ;
404
405  {
406#line 83
407  if (ldv_mutex == 1) {
408
409  } else {
410    {
411#line 83
412    ldv_blast_assert();
413    }
414  }
415  {
416#line 86
417  atomic_value_after_dec = __VERIFIER_nondet_int();
418  }
419#line 89
420  if (atomic_value_after_dec == 0) {
421#line 92
422    ldv_mutex = 2;
423#line 94
424    return (1);
425  } else {
426
427  }
428#line 98
429  return (0);
430}
431}
432#line 103 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
433void mutex_lock(struct mutex *lock ) 
434{ 
435
436  {
437#line 108
438  if (ldv_mutex == 1) {
439
440  } else {
441    {
442#line 108
443    ldv_blast_assert();
444    }
445  }
446#line 110
447  ldv_mutex = 2;
448#line 111
449  return;
450}
451}
452#line 114 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
453int mutex_trylock(struct mutex *lock ) 
454{ int nondetermined ;
455
456  {
457#line 121
458  if (ldv_mutex == 1) {
459
460  } else {
461    {
462#line 121
463    ldv_blast_assert();
464    }
465  }
466  {
467#line 124
468  nondetermined = __VERIFIER_nondet_int();
469  }
470#line 127
471  if (nondetermined) {
472#line 130
473    ldv_mutex = 2;
474#line 132
475    return (1);
476  } else {
477#line 137
478    return (0);
479  }
480}
481}
482#line 142 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
483void mutex_unlock(struct mutex *lock ) 
484{ 
485
486  {
487#line 147
488  if (ldv_mutex == 2) {
489
490  } else {
491    {
492#line 147
493    ldv_blast_assert();
494    }
495  }
496#line 149
497  ldv_mutex = 1;
498#line 150
499  return;
500}
501}
502#line 153 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
503void ldv_check_final_state(void) 
504{ 
505
506  {
507#line 156
508  if (ldv_mutex == 1) {
509
510  } else {
511    {
512#line 156
513    ldv_blast_assert();
514    }
515  }
516#line 157
517  return;
518}
519}
520#line 166 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12864/dscv_tempdir/dscv/ri/32_1/drivers/media/rc/keymaps/rc-ati-tv-wonder-hd-600.c.common.c"
521long s__builtin_expect(long val , long res ) 
522{ 
523
524  {
525#line 167
526  return (val);
527}
528}