Showing error 672

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--uio--uio_pci_generic.ko-ldv_main0_sequence_infinite_withcheck_stateful.cil.out.c
Line in file: 3295
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 19 "include/asm-generic/int-ll64.h"
   5typedef signed char __s8;
   6#line 22 "include/asm-generic/int-ll64.h"
   7typedef short __s16;
   8#line 23 "include/asm-generic/int-ll64.h"
   9typedef unsigned short __u16;
  10#line 25 "include/asm-generic/int-ll64.h"
  11typedef int __s32;
  12#line 26 "include/asm-generic/int-ll64.h"
  13typedef unsigned int __u32;
  14#line 30 "include/asm-generic/int-ll64.h"
  15typedef unsigned long long __u64;
  16#line 43 "include/asm-generic/int-ll64.h"
  17typedef unsigned char u8;
  18#line 45 "include/asm-generic/int-ll64.h"
  19typedef short s16;
  20#line 46 "include/asm-generic/int-ll64.h"
  21typedef unsigned short u16;
  22#line 48 "include/asm-generic/int-ll64.h"
  23typedef int s32;
  24#line 49 "include/asm-generic/int-ll64.h"
  25typedef unsigned int u32;
  26#line 51 "include/asm-generic/int-ll64.h"
  27typedef long long s64;
  28#line 52 "include/asm-generic/int-ll64.h"
  29typedef unsigned long long u64;
  30#line 14 "include/asm-generic/posix_types.h"
  31typedef long __kernel_long_t;
  32#line 15 "include/asm-generic/posix_types.h"
  33typedef unsigned long __kernel_ulong_t;
  34#line 52 "include/asm-generic/posix_types.h"
  35typedef unsigned int __kernel_uid32_t;
  36#line 53 "include/asm-generic/posix_types.h"
  37typedef unsigned int __kernel_gid32_t;
  38#line 75 "include/asm-generic/posix_types.h"
  39typedef __kernel_ulong_t __kernel_size_t;
  40#line 76 "include/asm-generic/posix_types.h"
  41typedef __kernel_long_t __kernel_ssize_t;
  42#line 91 "include/asm-generic/posix_types.h"
  43typedef long long __kernel_loff_t;
  44#line 92 "include/asm-generic/posix_types.h"
  45typedef __kernel_long_t __kernel_time_t;
  46#line 21 "include/linux/types.h"
  47typedef __u32 __kernel_dev_t;
  48#line 24 "include/linux/types.h"
  49typedef __kernel_dev_t dev_t;
  50#line 27 "include/linux/types.h"
  51typedef unsigned short umode_t;
  52#line 38 "include/linux/types.h"
  53typedef _Bool bool;
  54#line 40 "include/linux/types.h"
  55typedef __kernel_uid32_t uid_t;
  56#line 41 "include/linux/types.h"
  57typedef __kernel_gid32_t gid_t;
  58#line 54 "include/linux/types.h"
  59typedef __kernel_loff_t loff_t;
  60#line 63 "include/linux/types.h"
  61typedef __kernel_size_t size_t;
  62#line 68 "include/linux/types.h"
  63typedef __kernel_ssize_t ssize_t;
  64#line 78 "include/linux/types.h"
  65typedef __kernel_time_t time_t;
  66#line 142 "include/linux/types.h"
  67typedef unsigned long sector_t;
  68#line 143 "include/linux/types.h"
  69typedef unsigned long blkcnt_t;
  70#line 155 "include/linux/types.h"
  71typedef u64 dma_addr_t;
  72#line 202 "include/linux/types.h"
  73typedef unsigned int gfp_t;
  74#line 203 "include/linux/types.h"
  75typedef unsigned int fmode_t;
  76#line 206 "include/linux/types.h"
  77typedef u64 phys_addr_t;
  78#line 211 "include/linux/types.h"
  79typedef phys_addr_t resource_size_t;
  80#line 219 "include/linux/types.h"
  81struct __anonstruct_atomic_t_7 {
  82   int counter ;
  83};
  84#line 219 "include/linux/types.h"
  85typedef struct __anonstruct_atomic_t_7 atomic_t;
  86#line 224 "include/linux/types.h"
  87struct __anonstruct_atomic64_t_8 {
  88   long counter ;
  89};
  90#line 224 "include/linux/types.h"
  91typedef struct __anonstruct_atomic64_t_8 atomic64_t;
  92#line 229 "include/linux/types.h"
  93struct list_head {
  94   struct list_head *next ;
  95   struct list_head *prev ;
  96};
  97#line 233
  98struct hlist_node;
  99#line 233 "include/linux/types.h"
 100struct hlist_head {
 101   struct hlist_node *first ;
 102};
 103#line 237 "include/linux/types.h"
 104struct hlist_node {
 105   struct hlist_node *next ;
 106   struct hlist_node **pprev ;
 107};
 108#line 253 "include/linux/types.h"
 109struct rcu_head {
 110   struct rcu_head *next ;
 111   void (*func)(struct rcu_head *head ) ;
 112};
 113#line 18 "include/linux/ioport.h"
 114struct resource {
 115   resource_size_t start ;
 116   resource_size_t end ;
 117   char const   *name ;
 118   unsigned long flags ;
 119   struct resource *parent ;
 120   struct resource *sibling ;
 121   struct resource *child ;
 122};
 123#line 202
 124struct device;
 125#line 202
 126struct device;
 127#line 12 "include/linux/lockdep.h"
 128struct task_struct;
 129#line 12
 130struct task_struct;
 131#line 391 "include/linux/lockdep.h"
 132struct lock_class_key {
 133
 134};
 135#line 20 "include/linux/kobject_ns.h"
 136struct sock;
 137#line 20
 138struct sock;
 139#line 21
 140struct kobject;
 141#line 21
 142struct kobject;
 143#line 27
 144enum kobj_ns_type {
 145    KOBJ_NS_TYPE_NONE = 0,
 146    KOBJ_NS_TYPE_NET = 1,
 147    KOBJ_NS_TYPES = 2
 148} ;
 149#line 40 "include/linux/kobject_ns.h"
 150struct kobj_ns_type_operations {
 151   enum kobj_ns_type type ;
 152   void *(*grab_current_ns)(void) ;
 153   void const   *(*netlink_ns)(struct sock *sk ) ;
 154   void const   *(*initial_ns)(void) ;
 155   void (*drop_ns)(void * ) ;
 156};
 157#line 7 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/processor.h"
 158struct task_struct;
 159#line 8
 160struct mm_struct;
 161#line 8
 162struct mm_struct;
 163#line 146 "include/linux/init.h"
 164typedef void (*ctor_fn_t)(void);
 165#line 13 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/pgtable_64_types.h"
 166typedef unsigned long pgdval_t;
 167#line 14 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/pgtable_64_types.h"
 168typedef unsigned long pgprotval_t;
 169#line 192 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/pgtable_types.h"
 170struct pgprot {
 171   pgprotval_t pgprot ;
 172};
 173#line 192 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/pgtable_types.h"
 174typedef struct pgprot pgprot_t;
 175#line 194 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/pgtable_types.h"
 176struct __anonstruct_pgd_t_15 {
 177   pgdval_t pgd ;
 178};
 179#line 194 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/pgtable_types.h"
 180typedef struct __anonstruct_pgd_t_15 pgd_t;
 181#line 282
 182struct page;
 183#line 282 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/pgtable_types.h"
 184typedef struct page *pgtable_t;
 185#line 295
 186struct file;
 187#line 295
 188struct file;
 189#line 313
 190struct seq_file;
 191#line 313
 192struct seq_file;
 193#line 46 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/paravirt_types.h"
 194struct page;
 195#line 50
 196struct mm_struct;
 197#line 52
 198struct task_struct;
 199#line 53
 200struct cpumask;
 201#line 53
 202struct cpumask;
 203#line 329
 204struct arch_spinlock;
 205#line 329
 206struct arch_spinlock;
 207#line 139 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/ptrace.h"
 208struct task_struct;
 209#line 56 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/alternative.h"
 210struct module;
 211#line 56
 212struct module;
 213#line 47 "include/linux/dynamic_debug.h"
 214struct device;
 215#line 135 "include/linux/kernel.h"
 216struct completion;
 217#line 135
 218struct completion;
 219#line 349
 220struct pid;
 221#line 349
 222struct pid;
 223#line 8 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/current.h"
 224struct task_struct;
 225#line 18 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/page.h"
 226struct page;
 227#line 10 "include/asm-generic/bug.h"
 228struct bug_entry {
 229   int bug_addr_disp ;
 230   int file_disp ;
 231   unsigned short line ;
 232   unsigned short flags ;
 233};
 234#line 14 "include/linux/cpumask.h"
 235struct cpumask {
 236   unsigned long bits[((4096UL + 8UL * sizeof(long )) - 1UL) / (8UL * sizeof(long ))] ;
 237};
 238#line 637 "include/linux/cpumask.h"
 239typedef struct cpumask *cpumask_var_t;
 240#line 234 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/paravirt.h"
 241struct static_key;
 242#line 234
 243struct static_key;
 244#line 433 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/processor.h"
 245struct kmem_cache;
 246#line 23 "include/asm-generic/atomic-long.h"
 247typedef atomic64_t atomic_long_t;
 248#line 22 "include/linux/sysfs.h"
 249struct kobject;
 250#line 23
 251struct module;
 252#line 24
 253enum kobj_ns_type;
 254#line 26 "include/linux/sysfs.h"
 255struct attribute {
 256   char const   *name ;
 257   umode_t mode ;
 258};
 259#line 56 "include/linux/sysfs.h"
 260struct attribute_group {
 261   char const   *name ;
 262   umode_t (*is_visible)(struct kobject * , struct attribute * , int  ) ;
 263   struct attribute **attrs ;
 264};
 265#line 85
 266struct file;
 267#line 86
 268struct vm_area_struct;
 269#line 86
 270struct vm_area_struct;
 271#line 88 "include/linux/sysfs.h"
 272struct bin_attribute {
 273   struct attribute attr ;
 274   size_t size ;
 275   void *private ;
 276   ssize_t (*read)(struct file * , struct kobject * , struct bin_attribute * , char * ,
 277                   loff_t  , size_t  ) ;
 278   ssize_t (*write)(struct file * , struct kobject * , struct bin_attribute * , char * ,
 279                    loff_t  , size_t  ) ;
 280   int (*mmap)(struct file * , struct kobject * , struct bin_attribute *attr , struct vm_area_struct *vma ) ;
 281};
 282#line 112 "include/linux/sysfs.h"
 283struct sysfs_ops {
 284   ssize_t (*show)(struct kobject * , struct attribute * , char * ) ;
 285   ssize_t (*store)(struct kobject * , struct attribute * , char const   * , size_t  ) ;
 286   void const   *(*namespace)(struct kobject * , struct attribute  const  * ) ;
 287};
 288#line 118
 289struct sysfs_dirent;
 290#line 118
 291struct sysfs_dirent;
 292#line 12 "include/linux/thread_info.h"
 293struct timespec;
 294#line 12
 295struct timespec;
 296#line 20 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/thread_info.h"
 297struct task_struct;
 298#line 14 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/spinlock_types.h"
 299typedef u16 __ticket_t;
 300#line 15 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/spinlock_types.h"
 301typedef u32 __ticketpair_t;
 302#line 20 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/spinlock_types.h"
 303struct __raw_tickets {
 304   __ticket_t head ;
 305   __ticket_t tail ;
 306};
 307#line 20 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/spinlock_types.h"
 308union __anonunion____missing_field_name_36 {
 309   __ticketpair_t head_tail ;
 310   struct __raw_tickets tickets ;
 311};
 312#line 20 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/spinlock_types.h"
 313struct arch_spinlock {
 314   union __anonunion____missing_field_name_36 __annonCompField17 ;
 315};
 316#line 20 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/spinlock_types.h"
 317typedef struct arch_spinlock arch_spinlock_t;
 318#line 27 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/rwlock.h"
 319struct __anonstruct____missing_field_name_38 {
 320   u32 read ;
 321   s32 write ;
 322};
 323#line 27 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/rwlock.h"
 324union __anonunion_arch_rwlock_t_37 {
 325   s64 lock ;
 326   struct __anonstruct____missing_field_name_38 __annonCompField18 ;
 327};
 328#line 27 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/rwlock.h"
 329typedef union __anonunion_arch_rwlock_t_37 arch_rwlock_t;
 330#line 20 "include/linux/spinlock_types.h"
 331struct raw_spinlock {
 332   arch_spinlock_t raw_lock ;
 333   unsigned int magic ;
 334   unsigned int owner_cpu ;
 335   void *owner ;
 336};
 337#line 20 "include/linux/spinlock_types.h"
 338typedef struct raw_spinlock raw_spinlock_t;
 339#line 64 "include/linux/spinlock_types.h"
 340union __anonunion____missing_field_name_39 {
 341   struct raw_spinlock rlock ;
 342};
 343#line 64 "include/linux/spinlock_types.h"
 344struct spinlock {
 345   union __anonunion____missing_field_name_39 __annonCompField19 ;
 346};
 347#line 64 "include/linux/spinlock_types.h"
 348typedef struct spinlock spinlock_t;
 349#line 11 "include/linux/rwlock_types.h"
 350struct __anonstruct_rwlock_t_40 {
 351   arch_rwlock_t raw_lock ;
 352   unsigned int magic ;
 353   unsigned int owner_cpu ;
 354   void *owner ;
 355};
 356#line 11 "include/linux/rwlock_types.h"
 357typedef struct __anonstruct_rwlock_t_40 rwlock_t;
 358#line 22 "include/linux/kref.h"
 359struct kref {
 360   atomic_t refcount ;
 361};
 362#line 49 "include/linux/wait.h"
 363struct __wait_queue_head {
 364   spinlock_t lock ;
 365   struct list_head task_list ;
 366};
 367#line 53 "include/linux/wait.h"
 368typedef struct __wait_queue_head wait_queue_head_t;
 369#line 55
 370struct task_struct;
 371#line 60 "include/linux/kobject.h"
 372struct kset;
 373#line 60
 374struct kobj_type;
 375#line 60 "include/linux/kobject.h"
 376struct kobject {
 377   char const   *name ;
 378   struct list_head entry ;
 379   struct kobject *parent ;
 380   struct kset *kset ;
 381   struct kobj_type *ktype ;
 382   struct sysfs_dirent *sd ;
 383   struct kref kref ;
 384   unsigned int state_initialized : 1 ;
 385   unsigned int state_in_sysfs : 1 ;
 386   unsigned int state_add_uevent_sent : 1 ;
 387   unsigned int state_remove_uevent_sent : 1 ;
 388   unsigned int uevent_suppress : 1 ;
 389};
 390#line 108 "include/linux/kobject.h"
 391struct kobj_type {
 392   void (*release)(struct kobject *kobj ) ;
 393   struct sysfs_ops  const  *sysfs_ops ;
 394   struct attribute **default_attrs ;
 395   struct kobj_ns_type_operations  const  *(*child_ns_type)(struct kobject *kobj ) ;
 396   void const   *(*namespace)(struct kobject *kobj ) ;
 397};
 398#line 116 "include/linux/kobject.h"
 399struct kobj_uevent_env {
 400   char *envp[32] ;
 401   int envp_idx ;
 402   char buf[2048] ;
 403   int buflen ;
 404};
 405#line 123 "include/linux/kobject.h"
 406struct kset_uevent_ops {
 407   int (* const  filter)(struct kset *kset , struct kobject *kobj ) ;
 408   char const   *(* const  name)(struct kset *kset , struct kobject *kobj ) ;
 409   int (* const  uevent)(struct kset *kset , struct kobject *kobj , struct kobj_uevent_env *env ) ;
 410};
 411#line 140
 412struct sock;
 413#line 159 "include/linux/kobject.h"
 414struct kset {
 415   struct list_head list ;
 416   spinlock_t list_lock ;
 417   struct kobject kobj ;
 418   struct kset_uevent_ops  const  *uevent_ops ;
 419};
 420#line 19 "include/linux/klist.h"
 421struct klist_node;
 422#line 19
 423struct klist_node;
 424#line 39 "include/linux/klist.h"
 425struct klist_node {
 426   void *n_klist ;
 427   struct list_head n_node ;
 428   struct kref n_ref ;
 429};
 430#line 48 "include/linux/mutex.h"
 431struct mutex {
 432   atomic_t count ;
 433   spinlock_t wait_lock ;
 434   struct list_head wait_list ;
 435   struct task_struct *owner ;
 436   char const   *name ;
 437   void *magic ;
 438};
 439#line 119 "include/linux/seqlock.h"
 440struct seqcount {
 441   unsigned int sequence ;
 442};
 443#line 119 "include/linux/seqlock.h"
 444typedef struct seqcount seqcount_t;
 445#line 14 "include/linux/time.h"
 446struct timespec {
 447   __kernel_time_t tv_sec ;
 448   long tv_nsec ;
 449};
 450#line 46 "include/linux/ktime.h"
 451union ktime {
 452   s64 tv64 ;
 453};
 454#line 59 "include/linux/ktime.h"
 455typedef union ktime ktime_t;
 456#line 10 "include/linux/timer.h"
 457struct tvec_base;
 458#line 10
 459struct tvec_base;
 460#line 12 "include/linux/timer.h"
 461struct timer_list {
 462   struct list_head entry ;
 463   unsigned long expires ;
 464   struct tvec_base *base ;
 465   void (*function)(unsigned long  ) ;
 466   unsigned long data ;
 467   int slack ;
 468   int start_pid ;
 469   void *start_site ;
 470   char start_comm[16] ;
 471};
 472#line 17 "include/linux/workqueue.h"
 473struct work_struct;
 474#line 17
 475struct work_struct;
 476#line 79 "include/linux/workqueue.h"
 477struct work_struct {
 478   atomic_long_t data ;
 479   struct list_head entry ;
 480   void (*func)(struct work_struct *work ) ;
 481};
 482#line 25 "include/linux/completion.h"
 483struct completion {
 484   unsigned int done ;
 485   wait_queue_head_t wait ;
 486};
 487#line 42 "include/linux/pm.h"
 488struct device;
 489#line 50 "include/linux/pm.h"
 490struct pm_message {
 491   int event ;
 492};
 493#line 50 "include/linux/pm.h"
 494typedef struct pm_message pm_message_t;
 495#line 264 "include/linux/pm.h"
 496struct dev_pm_ops {
 497   int (*prepare)(struct device *dev ) ;
 498   void (*complete)(struct device *dev ) ;
 499   int (*suspend)(struct device *dev ) ;
 500   int (*resume)(struct device *dev ) ;
 501   int (*freeze)(struct device *dev ) ;
 502   int (*thaw)(struct device *dev ) ;
 503   int (*poweroff)(struct device *dev ) ;
 504   int (*restore)(struct device *dev ) ;
 505   int (*suspend_late)(struct device *dev ) ;
 506   int (*resume_early)(struct device *dev ) ;
 507   int (*freeze_late)(struct device *dev ) ;
 508   int (*thaw_early)(struct device *dev ) ;
 509   int (*poweroff_late)(struct device *dev ) ;
 510   int (*restore_early)(struct device *dev ) ;
 511   int (*suspend_noirq)(struct device *dev ) ;
 512   int (*resume_noirq)(struct device *dev ) ;
 513   int (*freeze_noirq)(struct device *dev ) ;
 514   int (*thaw_noirq)(struct device *dev ) ;
 515   int (*poweroff_noirq)(struct device *dev ) ;
 516   int (*restore_noirq)(struct device *dev ) ;
 517   int (*runtime_suspend)(struct device *dev ) ;
 518   int (*runtime_resume)(struct device *dev ) ;
 519   int (*runtime_idle)(struct device *dev ) ;
 520};
 521#line 458
 522enum rpm_status {
 523    RPM_ACTIVE = 0,
 524    RPM_RESUMING = 1,
 525    RPM_SUSPENDED = 2,
 526    RPM_SUSPENDING = 3
 527} ;
 528#line 480
 529enum rpm_request {
 530    RPM_REQ_NONE = 0,
 531    RPM_REQ_IDLE = 1,
 532    RPM_REQ_SUSPEND = 2,
 533    RPM_REQ_AUTOSUSPEND = 3,
 534    RPM_REQ_RESUME = 4
 535} ;
 536#line 488
 537struct wakeup_source;
 538#line 488
 539struct wakeup_source;
 540#line 495 "include/linux/pm.h"
 541struct pm_subsys_data {
 542   spinlock_t lock ;
 543   unsigned int refcount ;
 544};
 545#line 506
 546struct dev_pm_qos_request;
 547#line 506
 548struct pm_qos_constraints;
 549#line 506 "include/linux/pm.h"
 550struct dev_pm_info {
 551   pm_message_t power_state ;
 552   unsigned int can_wakeup : 1 ;
 553   unsigned int async_suspend : 1 ;
 554   bool is_prepared : 1 ;
 555   bool is_suspended : 1 ;
 556   bool ignore_children : 1 ;
 557   spinlock_t lock ;
 558   struct list_head entry ;
 559   struct completion completion ;
 560   struct wakeup_source *wakeup ;
 561   bool wakeup_path : 1 ;
 562   struct timer_list suspend_timer ;
 563   unsigned long timer_expires ;
 564   struct work_struct work ;
 565   wait_queue_head_t wait_queue ;
 566   atomic_t usage_count ;
 567   atomic_t child_count ;
 568   unsigned int disable_depth : 3 ;
 569   unsigned int idle_notification : 1 ;
 570   unsigned int request_pending : 1 ;
 571   unsigned int deferred_resume : 1 ;
 572   unsigned int run_wake : 1 ;
 573   unsigned int runtime_auto : 1 ;
 574   unsigned int no_callbacks : 1 ;
 575   unsigned int irq_safe : 1 ;
 576   unsigned int use_autosuspend : 1 ;
 577   unsigned int timer_autosuspends : 1 ;
 578   enum rpm_request request ;
 579   enum rpm_status runtime_status ;
 580   int runtime_error ;
 581   int autosuspend_delay ;
 582   unsigned long last_busy ;
 583   unsigned long active_jiffies ;
 584   unsigned long suspended_jiffies ;
 585   unsigned long accounting_timestamp ;
 586   ktime_t suspend_time ;
 587   s64 max_time_suspended_ns ;
 588   struct dev_pm_qos_request *pq_req ;
 589   struct pm_subsys_data *subsys_data ;
 590   struct pm_qos_constraints *constraints ;
 591};
 592#line 564 "include/linux/pm.h"
 593struct dev_pm_domain {
 594   struct dev_pm_ops ops ;
 595};
 596#line 4 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/device.h"
 597struct dma_map_ops;
 598#line 4 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/device.h"
 599struct dev_archdata {
 600   void *acpi_handle ;
 601   struct dma_map_ops *dma_ops ;
 602   void *iommu ;
 603};
 604#line 28 "include/linux/device.h"
 605struct device;
 606#line 29
 607struct device_private;
 608#line 29
 609struct device_private;
 610#line 30
 611struct device_driver;
 612#line 30
 613struct device_driver;
 614#line 31
 615struct driver_private;
 616#line 31
 617struct driver_private;
 618#line 32
 619struct module;
 620#line 33
 621struct class;
 622#line 33
 623struct class;
 624#line 34
 625struct subsys_private;
 626#line 34
 627struct subsys_private;
 628#line 35
 629struct bus_type;
 630#line 35
 631struct bus_type;
 632#line 36
 633struct device_node;
 634#line 36
 635struct device_node;
 636#line 37
 637struct iommu_ops;
 638#line 37
 639struct iommu_ops;
 640#line 39 "include/linux/device.h"
 641struct bus_attribute {
 642   struct attribute attr ;
 643   ssize_t (*show)(struct bus_type *bus , char *buf ) ;
 644   ssize_t (*store)(struct bus_type *bus , char const   *buf , size_t count ) ;
 645};
 646#line 89
 647struct device_attribute;
 648#line 89
 649struct driver_attribute;
 650#line 89 "include/linux/device.h"
 651struct bus_type {
 652   char const   *name ;
 653   char const   *dev_name ;
 654   struct device *dev_root ;
 655   struct bus_attribute *bus_attrs ;
 656   struct device_attribute *dev_attrs ;
 657   struct driver_attribute *drv_attrs ;
 658   int (*match)(struct device *dev , struct device_driver *drv ) ;
 659   int (*uevent)(struct device *dev , struct kobj_uevent_env *env ) ;
 660   int (*probe)(struct device *dev ) ;
 661   int (*remove)(struct device *dev ) ;
 662   void (*shutdown)(struct device *dev ) ;
 663   int (*suspend)(struct device *dev , pm_message_t state ) ;
 664   int (*resume)(struct device *dev ) ;
 665   struct dev_pm_ops  const  *pm ;
 666   struct iommu_ops *iommu_ops ;
 667   struct subsys_private *p ;
 668};
 669#line 127
 670struct device_type;
 671#line 214
 672struct of_device_id;
 673#line 214 "include/linux/device.h"
 674struct device_driver {
 675   char const   *name ;
 676   struct bus_type *bus ;
 677   struct module *owner ;
 678   char const   *mod_name ;
 679   bool suppress_bind_attrs ;
 680   struct of_device_id  const  *of_match_table ;
 681   int (*probe)(struct device *dev ) ;
 682   int (*remove)(struct device *dev ) ;
 683   void (*shutdown)(struct device *dev ) ;
 684   int (*suspend)(struct device *dev , pm_message_t state ) ;
 685   int (*resume)(struct device *dev ) ;
 686   struct attribute_group  const  **groups ;
 687   struct dev_pm_ops  const  *pm ;
 688   struct driver_private *p ;
 689};
 690#line 249 "include/linux/device.h"
 691struct driver_attribute {
 692   struct attribute attr ;
 693   ssize_t (*show)(struct device_driver *driver , char *buf ) ;
 694   ssize_t (*store)(struct device_driver *driver , char const   *buf , size_t count ) ;
 695};
 696#line 330
 697struct class_attribute;
 698#line 330 "include/linux/device.h"
 699struct class {
 700   char const   *name ;
 701   struct module *owner ;
 702   struct class_attribute *class_attrs ;
 703   struct device_attribute *dev_attrs ;
 704   struct bin_attribute *dev_bin_attrs ;
 705   struct kobject *dev_kobj ;
 706   int (*dev_uevent)(struct device *dev , struct kobj_uevent_env *env ) ;
 707   char *(*devnode)(struct device *dev , umode_t *mode ) ;
 708   void (*class_release)(struct class *class ) ;
 709   void (*dev_release)(struct device *dev ) ;
 710   int (*suspend)(struct device *dev , pm_message_t state ) ;
 711   int (*resume)(struct device *dev ) ;
 712   struct kobj_ns_type_operations  const  *ns_type ;
 713   void const   *(*namespace)(struct device *dev ) ;
 714   struct dev_pm_ops  const  *pm ;
 715   struct subsys_private *p ;
 716};
 717#line 397 "include/linux/device.h"
 718struct class_attribute {
 719   struct attribute attr ;
 720   ssize_t (*show)(struct class *class , struct class_attribute *attr , char *buf ) ;
 721   ssize_t (*store)(struct class *class , struct class_attribute *attr , char const   *buf ,
 722                    size_t count ) ;
 723   void const   *(*namespace)(struct class *class , struct class_attribute  const  *attr ) ;
 724};
 725#line 465 "include/linux/device.h"
 726struct device_type {
 727   char const   *name ;
 728   struct attribute_group  const  **groups ;
 729   int (*uevent)(struct device *dev , struct kobj_uevent_env *env ) ;
 730   char *(*devnode)(struct device *dev , umode_t *mode ) ;
 731   void (*release)(struct device *dev ) ;
 732   struct dev_pm_ops  const  *pm ;
 733};
 734#line 476 "include/linux/device.h"
 735struct device_attribute {
 736   struct attribute attr ;
 737   ssize_t (*show)(struct device *dev , struct device_attribute *attr , char *buf ) ;
 738   ssize_t (*store)(struct device *dev , struct device_attribute *attr , char const   *buf ,
 739                    size_t count ) ;
 740};
 741#line 559 "include/linux/device.h"
 742struct device_dma_parameters {
 743   unsigned int max_segment_size ;
 744   unsigned long segment_boundary_mask ;
 745};
 746#line 627
 747struct dma_coherent_mem;
 748#line 627 "include/linux/device.h"
 749struct device {
 750   struct device *parent ;
 751   struct device_private *p ;
 752   struct kobject kobj ;
 753   char const   *init_name ;
 754   struct device_type  const  *type ;
 755   struct mutex mutex ;
 756   struct bus_type *bus ;
 757   struct device_driver *driver ;
 758   void *platform_data ;
 759   struct dev_pm_info power ;
 760   struct dev_pm_domain *pm_domain ;
 761   int numa_node ;
 762   u64 *dma_mask ;
 763   u64 coherent_dma_mask ;
 764   struct device_dma_parameters *dma_parms ;
 765   struct list_head dma_pools ;
 766   struct dma_coherent_mem *dma_mem ;
 767   struct dev_archdata archdata ;
 768   struct device_node *of_node ;
 769   dev_t devt ;
 770   u32 id ;
 771   spinlock_t devres_lock ;
 772   struct list_head devres_head ;
 773   struct klist_node knode_class ;
 774   struct class *class ;
 775   struct attribute_group  const  **groups ;
 776   void (*release)(struct device *dev ) ;
 777};
 778#line 43 "include/linux/pm_wakeup.h"
 779struct wakeup_source {
 780   char const   *name ;
 781   struct list_head entry ;
 782   spinlock_t lock ;
 783   struct timer_list timer ;
 784   unsigned long timer_expires ;
 785   ktime_t total_time ;
 786   ktime_t max_time ;
 787   ktime_t last_time ;
 788   unsigned long event_count ;
 789   unsigned long active_count ;
 790   unsigned long relax_count ;
 791   unsigned long hit_count ;
 792   unsigned int active : 1 ;
 793};
 794#line 62 "include/linux/stat.h"
 795struct kstat {
 796   u64 ino ;
 797   dev_t dev ;
 798   umode_t mode ;
 799   unsigned int nlink ;
 800   uid_t uid ;
 801   gid_t gid ;
 802   dev_t rdev ;
 803   loff_t size ;
 804   struct timespec atime ;
 805   struct timespec mtime ;
 806   struct timespec ctime ;
 807   unsigned long blksize ;
 808   unsigned long long blocks ;
 809};
 810#line 98 "include/linux/nodemask.h"
 811struct __anonstruct_nodemask_t_44 {
 812   unsigned long bits[(((unsigned long )(1 << 10) + 8UL * sizeof(long )) - 1UL) / (8UL * sizeof(long ))] ;
 813};
 814#line 98 "include/linux/nodemask.h"
 815typedef struct __anonstruct_nodemask_t_44 nodemask_t;
 816#line 60 "include/linux/pageblock-flags.h"
 817struct page;
 818#line 19 "include/linux/rwsem.h"
 819struct rw_semaphore;
 820#line 19
 821struct rw_semaphore;
 822#line 25 "include/linux/rwsem.h"
 823struct rw_semaphore {
 824   long count ;
 825   raw_spinlock_t wait_lock ;
 826   struct list_head wait_list ;
 827};
 828#line 9 "include/linux/memory_hotplug.h"
 829struct page;
 830#line 182 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/x86_init.h"
 831struct pci_dev;
 832#line 182
 833struct pci_dev;
 834#line 103 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/mpspec.h"
 835struct device;
 836#line 174 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/topology.h"
 837struct pci_bus;
 838#line 174
 839struct pci_bus;
 840#line 11 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/mmu.h"
 841struct __anonstruct_mm_context_t_112 {
 842   void *ldt ;
 843   int size ;
 844   unsigned short ia32_compat ;
 845   struct mutex lock ;
 846   void *vdso ;
 847};
 848#line 11 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/mmu.h"
 849typedef struct __anonstruct_mm_context_t_112 mm_context_t;
 850#line 71 "include/asm-generic/iomap.h"
 851struct pci_dev;
 852#line 14 "include/asm-generic/pci_iomap.h"
 853struct pci_dev;
 854#line 8 "include/linux/vmalloc.h"
 855struct vm_area_struct;
 856#line 994 "include/linux/mmzone.h"
 857struct page;
 858#line 10 "include/linux/gfp.h"
 859struct vm_area_struct;
 860#line 29 "include/linux/sysctl.h"
 861struct completion;
 862#line 100 "include/linux/rbtree.h"
 863struct rb_node {
 864   unsigned long rb_parent_color ;
 865   struct rb_node *rb_right ;
 866   struct rb_node *rb_left ;
 867} __attribute__((__aligned__(sizeof(long )))) ;
 868#line 110 "include/linux/rbtree.h"
 869struct rb_root {
 870   struct rb_node *rb_node ;
 871};
 872#line 48 "include/linux/kmod.h"
 873struct cred;
 874#line 48
 875struct cred;
 876#line 49
 877struct file;
 878#line 270 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/elf.h"
 879struct task_struct;
 880#line 18 "include/linux/elf.h"
 881typedef __u64 Elf64_Addr;
 882#line 19 "include/linux/elf.h"
 883typedef __u16 Elf64_Half;
 884#line 23 "include/linux/elf.h"
 885typedef __u32 Elf64_Word;
 886#line 24 "include/linux/elf.h"
 887typedef __u64 Elf64_Xword;
 888#line 194 "include/linux/elf.h"
 889struct elf64_sym {
 890   Elf64_Word st_name ;
 891   unsigned char st_info ;
 892   unsigned char st_other ;
 893   Elf64_Half st_shndx ;
 894   Elf64_Addr st_value ;
 895   Elf64_Xword st_size ;
 896};
 897#line 194 "include/linux/elf.h"
 898typedef struct elf64_sym Elf64_Sym;
 899#line 438
 900struct file;
 901#line 39 "include/linux/moduleparam.h"
 902struct kernel_param;
 903#line 39
 904struct kernel_param;
 905#line 41 "include/linux/moduleparam.h"
 906struct kernel_param_ops {
 907   int (*set)(char const   *val , struct kernel_param  const  *kp ) ;
 908   int (*get)(char *buffer , struct kernel_param  const  *kp ) ;
 909   void (*free)(void *arg ) ;
 910};
 911#line 50
 912struct kparam_string;
 913#line 50
 914struct kparam_array;
 915#line 50 "include/linux/moduleparam.h"
 916union __anonunion____missing_field_name_199 {
 917   void *arg ;
 918   struct kparam_string  const  *str ;
 919   struct kparam_array  const  *arr ;
 920};
 921#line 50 "include/linux/moduleparam.h"
 922struct kernel_param {
 923   char const   *name ;
 924   struct kernel_param_ops  const  *ops ;
 925   u16 perm ;
 926   s16 level ;
 927   union __anonunion____missing_field_name_199 __annonCompField32 ;
 928};
 929#line 63 "include/linux/moduleparam.h"
 930struct kparam_string {
 931   unsigned int maxlen ;
 932   char *string ;
 933};
 934#line 69 "include/linux/moduleparam.h"
 935struct kparam_array {
 936   unsigned int max ;
 937   unsigned int elemsize ;
 938   unsigned int *num ;
 939   struct kernel_param_ops  const  *ops ;
 940   void *elem ;
 941};
 942#line 445
 943struct module;
 944#line 80 "include/linux/jump_label.h"
 945struct module;
 946#line 143 "include/linux/jump_label.h"
 947struct static_key {
 948   atomic_t enabled ;
 949};
 950#line 22 "include/linux/tracepoint.h"
 951struct module;
 952#line 23
 953struct tracepoint;
 954#line 23
 955struct tracepoint;
 956#line 25 "include/linux/tracepoint.h"
 957struct tracepoint_func {
 958   void *func ;
 959   void *data ;
 960};
 961#line 30 "include/linux/tracepoint.h"
 962struct tracepoint {
 963   char const   *name ;
 964   struct static_key key ;
 965   void (*regfunc)(void) ;
 966   void (*unregfunc)(void) ;
 967   struct tracepoint_func *funcs ;
 968};
 969#line 19 "include/linux/export.h"
 970struct kernel_symbol {
 971   unsigned long value ;
 972   char const   *name ;
 973};
 974#line 8 "include/asm-generic/module.h"
 975struct mod_arch_specific {
 976
 977};
 978#line 35 "include/linux/module.h"
 979struct module;
 980#line 37
 981struct module_param_attrs;
 982#line 37 "include/linux/module.h"
 983struct module_kobject {
 984   struct kobject kobj ;
 985   struct module *mod ;
 986   struct kobject *drivers_dir ;
 987   struct module_param_attrs *mp ;
 988};
 989#line 44 "include/linux/module.h"
 990struct module_attribute {
 991   struct attribute attr ;
 992   ssize_t (*show)(struct module_attribute * , struct module_kobject * , char * ) ;
 993   ssize_t (*store)(struct module_attribute * , struct module_kobject * , char const   * ,
 994                    size_t count ) ;
 995   void (*setup)(struct module * , char const   * ) ;
 996   int (*test)(struct module * ) ;
 997   void (*free)(struct module * ) ;
 998};
 999#line 71
1000struct exception_table_entry;
1001#line 71
1002struct exception_table_entry;
1003#line 199
1004enum module_state {
1005    MODULE_STATE_LIVE = 0,
1006    MODULE_STATE_COMING = 1,
1007    MODULE_STATE_GOING = 2
1008} ;
1009#line 215 "include/linux/module.h"
1010struct module_ref {
1011   unsigned long incs ;
1012   unsigned long decs ;
1013} __attribute__((__aligned__((2) *  (sizeof(unsigned long )) ))) ;
1014#line 220
1015struct module_sect_attrs;
1016#line 220
1017struct module_notes_attrs;
1018#line 220
1019struct ftrace_event_call;
1020#line 220 "include/linux/module.h"
1021struct module {
1022   enum module_state state ;
1023   struct list_head list ;
1024   char name[64UL - sizeof(unsigned long )] ;
1025   struct module_kobject mkobj ;
1026   struct module_attribute *modinfo_attrs ;
1027   char const   *version ;
1028   char const   *srcversion ;
1029   struct kobject *holders_dir ;
1030   struct kernel_symbol  const  *syms ;
1031   unsigned long const   *crcs ;
1032   unsigned int num_syms ;
1033   struct kernel_param *kp ;
1034   unsigned int num_kp ;
1035   unsigned int num_gpl_syms ;
1036   struct kernel_symbol  const  *gpl_syms ;
1037   unsigned long const   *gpl_crcs ;
1038   struct kernel_symbol  const  *unused_syms ;
1039   unsigned long const   *unused_crcs ;
1040   unsigned int num_unused_syms ;
1041   unsigned int num_unused_gpl_syms ;
1042   struct kernel_symbol  const  *unused_gpl_syms ;
1043   unsigned long const   *unused_gpl_crcs ;
1044   struct kernel_symbol  const  *gpl_future_syms ;
1045   unsigned long const   *gpl_future_crcs ;
1046   unsigned int num_gpl_future_syms ;
1047   unsigned int num_exentries ;
1048   struct exception_table_entry *extable ;
1049   int (*init)(void) ;
1050   void *module_init ;
1051   void *module_core ;
1052   unsigned int init_size ;
1053   unsigned int core_size ;
1054   unsigned int init_text_size ;
1055   unsigned int core_text_size ;
1056   unsigned int init_ro_size ;
1057   unsigned int core_ro_size ;
1058   struct mod_arch_specific arch ;
1059   unsigned int taints ;
1060   unsigned int num_bugs ;
1061   struct list_head bug_list ;
1062   struct bug_entry *bug_table ;
1063   Elf64_Sym *symtab ;
1064   Elf64_Sym *core_symtab ;
1065   unsigned int num_symtab ;
1066   unsigned int core_num_syms ;
1067   char *strtab ;
1068   char *core_strtab ;
1069   struct module_sect_attrs *sect_attrs ;
1070   struct module_notes_attrs *notes_attrs ;
1071   char *args ;
1072   void *percpu ;
1073   unsigned int percpu_size ;
1074   unsigned int num_tracepoints ;
1075   struct tracepoint * const  *tracepoints_ptrs ;
1076   unsigned int num_trace_bprintk_fmt ;
1077   char const   **trace_bprintk_fmt_start ;
1078   struct ftrace_event_call **trace_events ;
1079   unsigned int num_trace_events ;
1080   struct list_head source_list ;
1081   struct list_head target_list ;
1082   struct task_struct *waiter ;
1083   void (*exit)(void) ;
1084   struct module_ref *refptr ;
1085   ctor_fn_t *ctors ;
1086   unsigned int num_ctors ;
1087};
1088#line 12 "include/linux/mod_devicetable.h"
1089typedef unsigned long kernel_ulong_t;
1090#line 17 "include/linux/mod_devicetable.h"
1091struct pci_device_id {
1092   __u32 vendor ;
1093   __u32 device ;
1094   __u32 subvendor ;
1095   __u32 subdevice ;
1096   __u32 class ;
1097   __u32 class_mask ;
1098   kernel_ulong_t driver_data ;
1099};
1100#line 219 "include/linux/mod_devicetable.h"
1101struct of_device_id {
1102   char name[32] ;
1103   char type[32] ;
1104   char compatible[128] ;
1105   void *data ;
1106};
1107#line 25 "include/linux/io.h"
1108struct device;
1109#line 10 "include/linux/irqreturn.h"
1110enum irqreturn {
1111    IRQ_NONE = 0,
1112    IRQ_HANDLED = 1,
1113    IRQ_WAKE_THREAD = 2
1114} ;
1115#line 16 "include/linux/irqreturn.h"
1116typedef enum irqreturn irqreturn_t;
1117#line 61 "include/linux/pci.h"
1118struct hotplug_slot;
1119#line 61 "include/linux/pci.h"
1120struct pci_slot {
1121   struct pci_bus *bus ;
1122   struct list_head list ;
1123   struct hotplug_slot *hotplug ;
1124   unsigned char number ;
1125   struct kobject kobj ;
1126};
1127#line 117 "include/linux/pci.h"
1128typedef int pci_power_t;
1129#line 143 "include/linux/pci.h"
1130typedef unsigned int pci_channel_state_t;
1131#line 145
1132enum pci_channel_state {
1133    pci_channel_io_normal = 1,
1134    pci_channel_io_frozen = 2,
1135    pci_channel_io_perm_failure = 3
1136} ;
1137#line 169 "include/linux/pci.h"
1138typedef unsigned short pci_dev_flags_t;
1139#line 186 "include/linux/pci.h"
1140typedef unsigned short pci_bus_flags_t;
1141#line 230
1142struct pcie_link_state;
1143#line 230
1144struct pcie_link_state;
1145#line 231
1146struct pci_vpd;
1147#line 231
1148struct pci_vpd;
1149#line 232
1150struct pci_sriov;
1151#line 232
1152struct pci_sriov;
1153#line 233
1154struct pci_ats;
1155#line 233
1156struct pci_ats;
1157#line 238
1158struct proc_dir_entry;
1159#line 238
1160struct pci_driver;
1161#line 238 "include/linux/pci.h"
1162union __anonunion____missing_field_name_203 {
1163   struct pci_sriov *sriov ;
1164   struct pci_dev *physfn ;
1165};
1166#line 238 "include/linux/pci.h"
1167struct pci_dev {
1168   struct list_head bus_list ;
1169   struct pci_bus *bus ;
1170   struct pci_bus *subordinate ;
1171   void *sysdata ;
1172   struct proc_dir_entry *procent ;
1173   struct pci_slot *slot ;
1174   unsigned int devfn ;
1175   unsigned short vendor ;
1176   unsigned short device ;
1177   unsigned short subsystem_vendor ;
1178   unsigned short subsystem_device ;
1179   unsigned int class ;
1180   u8 revision ;
1181   u8 hdr_type ;
1182   u8 pcie_cap ;
1183   u8 pcie_type : 4 ;
1184   u8 pcie_mpss : 3 ;
1185   u8 rom_base_reg ;
1186   u8 pin ;
1187   struct pci_driver *driver ;
1188   u64 dma_mask ;
1189   struct device_dma_parameters dma_parms ;
1190   pci_power_t current_state ;
1191   int pm_cap ;
1192   unsigned int pme_support : 5 ;
1193   unsigned int pme_interrupt : 1 ;
1194   unsigned int pme_poll : 1 ;
1195   unsigned int d1_support : 1 ;
1196   unsigned int d2_support : 1 ;
1197   unsigned int no_d1d2 : 1 ;
1198   unsigned int mmio_always_on : 1 ;
1199   unsigned int wakeup_prepared : 1 ;
1200   unsigned int d3_delay ;
1201   struct pcie_link_state *link_state ;
1202   pci_channel_state_t error_state ;
1203   struct device dev ;
1204   int cfg_size ;
1205   unsigned int irq ;
1206   struct resource resource[17] ;
1207   unsigned int transparent : 1 ;
1208   unsigned int multifunction : 1 ;
1209   unsigned int is_added : 1 ;
1210   unsigned int is_busmaster : 1 ;
1211   unsigned int no_msi : 1 ;
1212   unsigned int block_cfg_access : 1 ;
1213   unsigned int broken_parity_status : 1 ;
1214   unsigned int irq_reroute_variant : 2 ;
1215   unsigned int msi_enabled : 1 ;
1216   unsigned int msix_enabled : 1 ;
1217   unsigned int ari_enabled : 1 ;
1218   unsigned int is_managed : 1 ;
1219   unsigned int is_pcie : 1 ;
1220   unsigned int needs_freset : 1 ;
1221   unsigned int state_saved : 1 ;
1222   unsigned int is_physfn : 1 ;
1223   unsigned int is_virtfn : 1 ;
1224   unsigned int reset_fn : 1 ;
1225   unsigned int is_hotplug_bridge : 1 ;
1226   unsigned int __aer_firmware_first_valid : 1 ;
1227   unsigned int __aer_firmware_first : 1 ;
1228   pci_dev_flags_t dev_flags ;
1229   atomic_t enable_cnt ;
1230   u32 saved_config_space[16] ;
1231   struct hlist_head saved_cap_space ;
1232   struct bin_attribute *rom_attr ;
1233   int rom_attr_enabled ;
1234   struct bin_attribute *res_attr[17] ;
1235   struct bin_attribute *res_attr_wc[17] ;
1236   struct list_head msi_list ;
1237   struct kset *msi_kset ;
1238   struct pci_vpd *vpd ;
1239   union __anonunion____missing_field_name_203 __annonCompField33 ;
1240   struct pci_ats *ats ;
1241};
1242#line 406
1243struct pci_ops;
1244#line 406 "include/linux/pci.h"
1245struct pci_bus {
1246   struct list_head node ;
1247   struct pci_bus *parent ;
1248   struct list_head children ;
1249   struct list_head devices ;
1250   struct pci_dev *self ;
1251   struct list_head slots ;
1252   struct resource *resource[4] ;
1253   struct list_head resources ;
1254   struct pci_ops *ops ;
1255   void *sysdata ;
1256   struct proc_dir_entry *procdir ;
1257   unsigned char number ;
1258   unsigned char primary ;
1259   unsigned char secondary ;
1260   unsigned char subordinate ;
1261   unsigned char max_bus_speed ;
1262   unsigned char cur_bus_speed ;
1263   char name[48] ;
1264   unsigned short bridge_ctl ;
1265   pci_bus_flags_t bus_flags ;
1266   struct device *bridge ;
1267   struct device dev ;
1268   struct bin_attribute *legacy_io ;
1269   struct bin_attribute *legacy_mem ;
1270   unsigned int is_added : 1 ;
1271};
1272#line 472 "include/linux/pci.h"
1273struct pci_ops {
1274   int (*read)(struct pci_bus *bus , unsigned int devfn , int where , int size , u32 *val ) ;
1275   int (*write)(struct pci_bus *bus , unsigned int devfn , int where , int size ,
1276                u32 val ) ;
1277};
1278#line 491 "include/linux/pci.h"
1279struct pci_dynids {
1280   spinlock_t lock ;
1281   struct list_head list ;
1282};
1283#line 503 "include/linux/pci.h"
1284typedef unsigned int pci_ers_result_t;
1285#line 523 "include/linux/pci.h"
1286struct pci_error_handlers {
1287   pci_ers_result_t (*error_detected)(struct pci_dev *dev , enum pci_channel_state error ) ;
1288   pci_ers_result_t (*mmio_enabled)(struct pci_dev *dev ) ;
1289   pci_ers_result_t (*link_reset)(struct pci_dev *dev ) ;
1290   pci_ers_result_t (*slot_reset)(struct pci_dev *dev ) ;
1291   void (*resume)(struct pci_dev *dev ) ;
1292};
1293#line 543
1294struct module;
1295#line 544 "include/linux/pci.h"
1296struct pci_driver {
1297   struct list_head node ;
1298   char const   *name ;
1299   struct pci_device_id  const  *id_table ;
1300   int (*probe)(struct pci_dev *dev , struct pci_device_id  const  *id ) ;
1301   void (*remove)(struct pci_dev *dev ) ;
1302   int (*suspend)(struct pci_dev *dev , pm_message_t state ) ;
1303   int (*suspend_late)(struct pci_dev *dev , pm_message_t state ) ;
1304   int (*resume_early)(struct pci_dev *dev ) ;
1305   int (*resume)(struct pci_dev *dev ) ;
1306   void (*shutdown)(struct pci_dev *dev ) ;
1307   struct pci_error_handlers *err_handler ;
1308   struct device_driver driver ;
1309   struct pci_dynids dynids ;
1310};
1311#line 6 "include/asm-generic/scatterlist.h"
1312struct scatterlist {
1313   unsigned long sg_magic ;
1314   unsigned long page_link ;
1315   unsigned int offset ;
1316   unsigned int length ;
1317   dma_addr_t dma_address ;
1318   unsigned int dma_length ;
1319};
1320#line 14 "include/linux/prio_tree.h"
1321struct prio_tree_node;
1322#line 14 "include/linux/prio_tree.h"
1323struct raw_prio_tree_node {
1324   struct prio_tree_node *left ;
1325   struct prio_tree_node *right ;
1326   struct prio_tree_node *parent ;
1327};
1328#line 20 "include/linux/prio_tree.h"
1329struct prio_tree_node {
1330   struct prio_tree_node *left ;
1331   struct prio_tree_node *right ;
1332   struct prio_tree_node *parent ;
1333   unsigned long start ;
1334   unsigned long last ;
1335};
1336#line 28 "include/linux/prio_tree.h"
1337struct prio_tree_root {
1338   struct prio_tree_node *prio_tree_node ;
1339   unsigned short index_bits ;
1340   unsigned short raw ;
1341};
1342#line 8 "include/linux/debug_locks.h"
1343struct task_struct;
1344#line 48
1345struct task_struct;
1346#line 23 "include/linux/mm_types.h"
1347struct address_space;
1348#line 23
1349struct address_space;
1350#line 40 "include/linux/mm_types.h"
1351union __anonunion____missing_field_name_205 {
1352   unsigned long index ;
1353   void *freelist ;
1354};
1355#line 40 "include/linux/mm_types.h"
1356struct __anonstruct____missing_field_name_209 {
1357   unsigned int inuse : 16 ;
1358   unsigned int objects : 15 ;
1359   unsigned int frozen : 1 ;
1360};
1361#line 40 "include/linux/mm_types.h"
1362union __anonunion____missing_field_name_208 {
1363   atomic_t _mapcount ;
1364   struct __anonstruct____missing_field_name_209 __annonCompField35 ;
1365};
1366#line 40 "include/linux/mm_types.h"
1367struct __anonstruct____missing_field_name_207 {
1368   union __anonunion____missing_field_name_208 __annonCompField36 ;
1369   atomic_t _count ;
1370};
1371#line 40 "include/linux/mm_types.h"
1372union __anonunion____missing_field_name_206 {
1373   unsigned long counters ;
1374   struct __anonstruct____missing_field_name_207 __annonCompField37 ;
1375};
1376#line 40 "include/linux/mm_types.h"
1377struct __anonstruct____missing_field_name_204 {
1378   union __anonunion____missing_field_name_205 __annonCompField34 ;
1379   union __anonunion____missing_field_name_206 __annonCompField38 ;
1380};
1381#line 40 "include/linux/mm_types.h"
1382struct __anonstruct____missing_field_name_211 {
1383   struct page *next ;
1384   int pages ;
1385   int pobjects ;
1386};
1387#line 40 "include/linux/mm_types.h"
1388union __anonunion____missing_field_name_210 {
1389   struct list_head lru ;
1390   struct __anonstruct____missing_field_name_211 __annonCompField40 ;
1391};
1392#line 40 "include/linux/mm_types.h"
1393union __anonunion____missing_field_name_212 {
1394   unsigned long private ;
1395   struct kmem_cache *slab ;
1396   struct page *first_page ;
1397};
1398#line 40 "include/linux/mm_types.h"
1399struct page {
1400   unsigned long flags ;
1401   struct address_space *mapping ;
1402   struct __anonstruct____missing_field_name_204 __annonCompField39 ;
1403   union __anonunion____missing_field_name_210 __annonCompField41 ;
1404   union __anonunion____missing_field_name_212 __annonCompField42 ;
1405   unsigned long debug_flags ;
1406} __attribute__((__aligned__((2) *  (sizeof(unsigned long )) ))) ;
1407#line 200 "include/linux/mm_types.h"
1408struct __anonstruct_vm_set_214 {
1409   struct list_head list ;
1410   void *parent ;
1411   struct vm_area_struct *head ;
1412};
1413#line 200 "include/linux/mm_types.h"
1414union __anonunion_shared_213 {
1415   struct __anonstruct_vm_set_214 vm_set ;
1416   struct raw_prio_tree_node prio_tree_node ;
1417};
1418#line 200
1419struct anon_vma;
1420#line 200
1421struct vm_operations_struct;
1422#line 200
1423struct mempolicy;
1424#line 200 "include/linux/mm_types.h"
1425struct vm_area_struct {
1426   struct mm_struct *vm_mm ;
1427   unsigned long vm_start ;
1428   unsigned long vm_end ;
1429   struct vm_area_struct *vm_next ;
1430   struct vm_area_struct *vm_prev ;
1431   pgprot_t vm_page_prot ;
1432   unsigned long vm_flags ;
1433   struct rb_node vm_rb ;
1434   union __anonunion_shared_213 shared ;
1435   struct list_head anon_vma_chain ;
1436   struct anon_vma *anon_vma ;
1437   struct vm_operations_struct  const  *vm_ops ;
1438   unsigned long vm_pgoff ;
1439   struct file *vm_file ;
1440   void *vm_private_data ;
1441   struct mempolicy *vm_policy ;
1442};
1443#line 257 "include/linux/mm_types.h"
1444struct core_thread {
1445   struct task_struct *task ;
1446   struct core_thread *next ;
1447};
1448#line 262 "include/linux/mm_types.h"
1449struct core_state {
1450   atomic_t nr_threads ;
1451   struct core_thread dumper ;
1452   struct completion startup ;
1453};
1454#line 284 "include/linux/mm_types.h"
1455struct mm_rss_stat {
1456   atomic_long_t count[3] ;
1457};
1458#line 288
1459struct linux_binfmt;
1460#line 288
1461struct mmu_notifier_mm;
1462#line 288 "include/linux/mm_types.h"
1463struct mm_struct {
1464   struct vm_area_struct *mmap ;
1465   struct rb_root mm_rb ;
1466   struct vm_area_struct *mmap_cache ;
1467   unsigned long (*get_unmapped_area)(struct file *filp , unsigned long addr , unsigned long len ,
1468                                      unsigned long pgoff , unsigned long flags ) ;
1469   void (*unmap_area)(struct mm_struct *mm , unsigned long addr ) ;
1470   unsigned long mmap_base ;
1471   unsigned long task_size ;
1472   unsigned long cached_hole_size ;
1473   unsigned long free_area_cache ;
1474   pgd_t *pgd ;
1475   atomic_t mm_users ;
1476   atomic_t mm_count ;
1477   int map_count ;
1478   spinlock_t page_table_lock ;
1479   struct rw_semaphore mmap_sem ;
1480   struct list_head mmlist ;
1481   unsigned long hiwater_rss ;
1482   unsigned long hiwater_vm ;
1483   unsigned long total_vm ;
1484   unsigned long locked_vm ;
1485   unsigned long pinned_vm ;
1486   unsigned long shared_vm ;
1487   unsigned long exec_vm ;
1488   unsigned long stack_vm ;
1489   unsigned long reserved_vm ;
1490   unsigned long def_flags ;
1491   unsigned long nr_ptes ;
1492   unsigned long start_code ;
1493   unsigned long end_code ;
1494   unsigned long start_data ;
1495   unsigned long end_data ;
1496   unsigned long start_brk ;
1497   unsigned long brk ;
1498   unsigned long start_stack ;
1499   unsigned long arg_start ;
1500   unsigned long arg_end ;
1501   unsigned long env_start ;
1502   unsigned long env_end ;
1503   unsigned long saved_auxv[44] ;
1504   struct mm_rss_stat rss_stat ;
1505   struct linux_binfmt *binfmt ;
1506   cpumask_var_t cpu_vm_mask_var ;
1507   mm_context_t context ;
1508   unsigned int faultstamp ;
1509   unsigned int token_priority ;
1510   unsigned int last_interval ;
1511   unsigned long flags ;
1512   struct core_state *core_state ;
1513   spinlock_t ioctx_lock ;
1514   struct hlist_head ioctx_list ;
1515   struct task_struct *owner ;
1516   struct file *exe_file ;
1517   unsigned long num_exe_file_vmas ;
1518   struct mmu_notifier_mm *mmu_notifier_mm ;
1519   pgtable_t pmd_huge_pte ;
1520   struct cpumask cpumask_allocation ;
1521};
1522#line 8 "include/linux/shrinker.h"
1523struct shrink_control {
1524   gfp_t gfp_mask ;
1525   unsigned long nr_to_scan ;
1526};
1527#line 31 "include/linux/shrinker.h"
1528struct shrinker {
1529   int (*shrink)(struct shrinker * , struct shrink_control *sc ) ;
1530   int seeks ;
1531   long batch ;
1532   struct list_head list ;
1533   atomic_long_t nr_in_batch ;
1534};
1535#line 22 "include/linux/mm.h"
1536struct mempolicy;
1537#line 23
1538struct anon_vma;
1539#line 24
1540struct file_ra_state;
1541#line 24
1542struct file_ra_state;
1543#line 26
1544struct writeback_control;
1545#line 26
1546struct writeback_control;
1547#line 41 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/pgtable_64.h"
1548struct mm_struct;
1549#line 656 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/pgtable.h"
1550struct vm_area_struct;
1551#line 188 "include/linux/mm.h"
1552struct vm_fault {
1553   unsigned int flags ;
1554   unsigned long pgoff ;
1555   void *virtual_address ;
1556   struct page *page ;
1557};
1558#line 205 "include/linux/mm.h"
1559struct vm_operations_struct {
1560   void (*open)(struct vm_area_struct *area ) ;
1561   void (*close)(struct vm_area_struct *area ) ;
1562   int (*fault)(struct vm_area_struct *vma , struct vm_fault *vmf ) ;
1563   int (*page_mkwrite)(struct vm_area_struct *vma , struct vm_fault *vmf ) ;
1564   int (*access)(struct vm_area_struct *vma , unsigned long addr , void *buf , int len ,
1565                 int write ) ;
1566   int (*set_policy)(struct vm_area_struct *vma , struct mempolicy *new ) ;
1567   struct mempolicy *(*get_policy)(struct vm_area_struct *vma , unsigned long addr ) ;
1568   int (*migrate)(struct vm_area_struct *vma , nodemask_t const   *from , nodemask_t const   *to ,
1569                  unsigned long flags ) ;
1570};
1571#line 247
1572struct inode;
1573#line 247
1574struct inode;
1575#line 195 "include/linux/page-flags.h"
1576struct page;
1577#line 46 "include/linux/slub_def.h"
1578struct kmem_cache_cpu {
1579   void **freelist ;
1580   unsigned long tid ;
1581   struct page *page ;
1582   struct page *partial ;
1583   int node ;
1584   unsigned int stat[26] ;
1585};
1586#line 57 "include/linux/slub_def.h"
1587struct kmem_cache_node {
1588   spinlock_t list_lock ;
1589   unsigned long nr_partial ;
1590   struct list_head partial ;
1591   atomic_long_t nr_slabs ;
1592   atomic_long_t total_objects ;
1593   struct list_head full ;
1594};
1595#line 73 "include/linux/slub_def.h"
1596struct kmem_cache_order_objects {
1597   unsigned long x ;
1598};
1599#line 80 "include/linux/slub_def.h"
1600struct kmem_cache {
1601   struct kmem_cache_cpu *cpu_slab ;
1602   unsigned long flags ;
1603   unsigned long min_partial ;
1604   int size ;
1605   int objsize ;
1606   int offset ;
1607   int cpu_partial ;
1608   struct kmem_cache_order_objects oo ;
1609   struct kmem_cache_order_objects max ;
1610   struct kmem_cache_order_objects min ;
1611   gfp_t allocflags ;
1612   int refcount ;
1613   void (*ctor)(void * ) ;
1614   int inuse ;
1615   int align ;
1616   int reserved ;
1617   char const   *name ;
1618   struct list_head list ;
1619   struct kobject kobj ;
1620   int remote_node_defrag_ratio ;
1621   struct kmem_cache_node *node[1 << 10] ;
1622};
1623#line 27 "include/linux/dma-attrs.h"
1624struct dma_attrs {
1625   unsigned long flags[((4UL + 8UL * sizeof(long )) - 1UL) / (8UL * sizeof(long ))] ;
1626};
1627#line 7 "include/linux/dma-direction.h"
1628enum dma_data_direction {
1629    DMA_BIDIRECTIONAL = 0,
1630    DMA_TO_DEVICE = 1,
1631    DMA_FROM_DEVICE = 2,
1632    DMA_NONE = 3
1633} ;
1634#line 11 "include/linux/dma-mapping.h"
1635struct dma_map_ops {
1636   void *(*alloc)(struct device *dev , size_t size , dma_addr_t *dma_handle , gfp_t gfp ,
1637                  struct dma_attrs *attrs ) ;
1638   void (*free)(struct device *dev , size_t size , void *vaddr , dma_addr_t dma_handle ,
1639                struct dma_attrs *attrs ) ;
1640   int (*mmap)(struct device * , struct vm_area_struct * , void * , dma_addr_t  ,
1641               size_t  , struct dma_attrs *attrs ) ;
1642   dma_addr_t (*map_page)(struct device *dev , struct page *page , unsigned long offset ,
1643                          size_t size , enum dma_data_direction dir , struct dma_attrs *attrs ) ;
1644   void (*unmap_page)(struct device *dev , dma_addr_t dma_handle , size_t size , enum dma_data_direction dir ,
1645                      struct dma_attrs *attrs ) ;
1646   int (*map_sg)(struct device *dev , struct scatterlist *sg , int nents , enum dma_data_direction dir ,
1647                 struct dma_attrs *attrs ) ;
1648   void (*unmap_sg)(struct device *dev , struct scatterlist *sg , int nents , enum dma_data_direction dir ,
1649                    struct dma_attrs *attrs ) ;
1650   void (*sync_single_for_cpu)(struct device *dev , dma_addr_t dma_handle , size_t size ,
1651                               enum dma_data_direction dir ) ;
1652   void (*sync_single_for_device)(struct device *dev , dma_addr_t dma_handle , size_t size ,
1653                                  enum dma_data_direction dir ) ;
1654   void (*sync_sg_for_cpu)(struct device *dev , struct scatterlist *sg , int nents ,
1655                           enum dma_data_direction dir ) ;
1656   void (*sync_sg_for_device)(struct device *dev , struct scatterlist *sg , int nents ,
1657                              enum dma_data_direction dir ) ;
1658   int (*mapping_error)(struct device *dev , dma_addr_t dma_addr ) ;
1659   int (*dma_supported)(struct device *dev , u64 mask ) ;
1660   int (*set_dma_mask)(struct device *dev , u64 mask ) ;
1661   int is_phys ;
1662};
1663#line 25 "include/linux/dma-debug.h"
1664struct device;
1665#line 26
1666struct scatterlist;
1667#line 27
1668struct bus_type;
1669#line 6 "include/linux/swiotlb.h"
1670struct device;
1671#line 7
1672struct dma_attrs;
1673#line 8
1674struct scatterlist;
1675#line 15 "include/linux/blk_types.h"
1676struct page;
1677#line 16
1678struct block_device;
1679#line 16
1680struct block_device;
1681#line 33 "include/linux/list_bl.h"
1682struct hlist_bl_node;
1683#line 33 "include/linux/list_bl.h"
1684struct hlist_bl_head {
1685   struct hlist_bl_node *first ;
1686};
1687#line 37 "include/linux/list_bl.h"
1688struct hlist_bl_node {
1689   struct hlist_bl_node *next ;
1690   struct hlist_bl_node **pprev ;
1691};
1692#line 13 "include/linux/dcache.h"
1693struct nameidata;
1694#line 13
1695struct nameidata;
1696#line 14
1697struct path;
1698#line 14
1699struct path;
1700#line 15
1701struct vfsmount;
1702#line 15
1703struct vfsmount;
1704#line 35 "include/linux/dcache.h"
1705struct qstr {
1706   unsigned int hash ;
1707   unsigned int len ;
1708   unsigned char const   *name ;
1709};
1710#line 88
1711struct dentry_operations;
1712#line 88
1713struct super_block;
1714#line 88 "include/linux/dcache.h"
1715union __anonunion_d_u_216 {
1716   struct list_head d_child ;
1717   struct rcu_head d_rcu ;
1718};
1719#line 88 "include/linux/dcache.h"
1720struct dentry {
1721   unsigned int d_flags ;
1722   seqcount_t d_seq ;
1723   struct hlist_bl_node d_hash ;
1724   struct dentry *d_parent ;
1725   struct qstr d_name ;
1726   struct inode *d_inode ;
1727   unsigned char d_iname[32] ;
1728   unsigned int d_count ;
1729   spinlock_t d_lock ;
1730   struct dentry_operations  const  *d_op ;
1731   struct super_block *d_sb ;
1732   unsigned long d_time ;
1733   void *d_fsdata ;
1734   struct list_head d_lru ;
1735   union __anonunion_d_u_216 d_u ;
1736   struct list_head d_subdirs ;
1737   struct list_head d_alias ;
1738};
1739#line 131 "include/linux/dcache.h"
1740struct dentry_operations {
1741   int (*d_revalidate)(struct dentry * , struct nameidata * ) ;
1742   int (*d_hash)(struct dentry  const  * , struct inode  const  * , struct qstr * ) ;
1743   int (*d_compare)(struct dentry  const  * , struct inode  const  * , struct dentry  const  * ,
1744                    struct inode  const  * , unsigned int  , char const   * , struct qstr  const  * ) ;
1745   int (*d_delete)(struct dentry  const  * ) ;
1746   void (*d_release)(struct dentry * ) ;
1747   void (*d_prune)(struct dentry * ) ;
1748   void (*d_iput)(struct dentry * , struct inode * ) ;
1749   char *(*d_dname)(struct dentry * , char * , int  ) ;
1750   struct vfsmount *(*d_automount)(struct path * ) ;
1751   int (*d_manage)(struct dentry * , bool  ) ;
1752} __attribute__((__aligned__((1) <<  (6) ))) ;
1753#line 4 "include/linux/path.h"
1754struct dentry;
1755#line 5
1756struct vfsmount;
1757#line 7 "include/linux/path.h"
1758struct path {
1759   struct vfsmount *mnt ;
1760   struct dentry *dentry ;
1761};
1762#line 64 "include/linux/radix-tree.h"
1763struct radix_tree_node;
1764#line 64 "include/linux/radix-tree.h"
1765struct radix_tree_root {
1766   unsigned int height ;
1767   gfp_t gfp_mask ;
1768   struct radix_tree_node *rnode ;
1769};
1770#line 6 "include/linux/pid.h"
1771enum pid_type {
1772    PIDTYPE_PID = 0,
1773    PIDTYPE_PGID = 1,
1774    PIDTYPE_SID = 2,
1775    PIDTYPE_MAX = 3
1776} ;
1777#line 50
1778struct pid_namespace;
1779#line 50 "include/linux/pid.h"
1780struct upid {
1781   int nr ;
1782   struct pid_namespace *ns ;
1783   struct hlist_node pid_chain ;
1784};
1785#line 57 "include/linux/pid.h"
1786struct pid {
1787   atomic_t count ;
1788   unsigned int level ;
1789   struct hlist_head tasks[3] ;
1790   struct rcu_head rcu ;
1791   struct upid numbers[1] ;
1792};
1793#line 100
1794struct pid_namespace;
1795#line 18 "include/linux/capability.h"
1796struct task_struct;
1797#line 377
1798struct dentry;
1799#line 16 "include/linux/fiemap.h"
1800struct fiemap_extent {
1801   __u64 fe_logical ;
1802   __u64 fe_physical ;
1803   __u64 fe_length ;
1804   __u64 fe_reserved64[2] ;
1805   __u32 fe_flags ;
1806   __u32 fe_reserved[3] ;
1807};
1808#line 10 "include/linux/migrate_mode.h"
1809enum migrate_mode {
1810    MIGRATE_ASYNC = 0,
1811    MIGRATE_SYNC_LIGHT = 1,
1812    MIGRATE_SYNC = 2
1813} ;
1814#line 408 "include/linux/fs.h"
1815struct export_operations;
1816#line 408
1817struct export_operations;
1818#line 410
1819struct iovec;
1820#line 410
1821struct iovec;
1822#line 411
1823struct nameidata;
1824#line 412
1825struct kiocb;
1826#line 412
1827struct kiocb;
1828#line 413
1829struct kobject;
1830#line 414
1831struct pipe_inode_info;
1832#line 414
1833struct pipe_inode_info;
1834#line 415
1835struct poll_table_struct;
1836#line 415
1837struct poll_table_struct;
1838#line 416
1839struct kstatfs;
1840#line 416
1841struct kstatfs;
1842#line 417
1843struct vm_area_struct;
1844#line 418
1845struct vfsmount;
1846#line 419
1847struct cred;
1848#line 469 "include/linux/fs.h"
1849struct iattr {
1850   unsigned int ia_valid ;
1851   umode_t ia_mode ;
1852   uid_t ia_uid ;
1853   gid_t ia_gid ;
1854   loff_t ia_size ;
1855   struct timespec ia_atime ;
1856   struct timespec ia_mtime ;
1857   struct timespec ia_ctime ;
1858   struct file *ia_file ;
1859};
1860#line 129 "include/linux/quota.h"
1861struct if_dqinfo {
1862   __u64 dqi_bgrace ;
1863   __u64 dqi_igrace ;
1864   __u32 dqi_flags ;
1865   __u32 dqi_valid ;
1866};
1867#line 50 "include/linux/dqblk_xfs.h"
1868struct fs_disk_quota {
1869   __s8 d_version ;
1870   __s8 d_flags ;
1871   __u16 d_fieldmask ;
1872   __u32 d_id ;
1873   __u64 d_blk_hardlimit ;
1874   __u64 d_blk_softlimit ;
1875   __u64 d_ino_hardlimit ;
1876   __u64 d_ino_softlimit ;
1877   __u64 d_bcount ;
1878   __u64 d_icount ;
1879   __s32 d_itimer ;
1880   __s32 d_btimer ;
1881   __u16 d_iwarns ;
1882   __u16 d_bwarns ;
1883   __s32 d_padding2 ;
1884   __u64 d_rtb_hardlimit ;
1885   __u64 d_rtb_softlimit ;
1886   __u64 d_rtbcount ;
1887   __s32 d_rtbtimer ;
1888   __u16 d_rtbwarns ;
1889   __s16 d_padding3 ;
1890   char d_padding4[8] ;
1891};
1892#line 146 "include/linux/dqblk_xfs.h"
1893struct fs_qfilestat {
1894   __u64 qfs_ino ;
1895   __u64 qfs_nblks ;
1896   __u32 qfs_nextents ;
1897};
1898#line 146 "include/linux/dqblk_xfs.h"
1899typedef struct fs_qfilestat fs_qfilestat_t;
1900#line 152 "include/linux/dqblk_xfs.h"
1901struct fs_quota_stat {
1902   __s8 qs_version ;
1903   __u16 qs_flags ;
1904   __s8 qs_pad ;
1905   fs_qfilestat_t qs_uquota ;
1906   fs_qfilestat_t qs_gquota ;
1907   __u32 qs_incoredqs ;
1908   __s32 qs_btimelimit ;
1909   __s32 qs_itimelimit ;
1910   __s32 qs_rtbtimelimit ;
1911   __u16 qs_bwarnlimit ;
1912   __u16 qs_iwarnlimit ;
1913};
1914#line 17 "include/linux/dqblk_qtree.h"
1915struct dquot;
1916#line 17
1917struct dquot;
1918#line 185 "include/linux/quota.h"
1919typedef __kernel_uid32_t qid_t;
1920#line 186 "include/linux/quota.h"
1921typedef long long qsize_t;
1922#line 200 "include/linux/quota.h"
1923struct mem_dqblk {
1924   qsize_t dqb_bhardlimit ;
1925   qsize_t dqb_bsoftlimit ;
1926   qsize_t dqb_curspace ;
1927   qsize_t dqb_rsvspace ;
1928   qsize_t dqb_ihardlimit ;
1929   qsize_t dqb_isoftlimit ;
1930   qsize_t dqb_curinodes ;
1931   time_t dqb_btime ;
1932   time_t dqb_itime ;
1933};
1934#line 215
1935struct quota_format_type;
1936#line 215
1937struct quota_format_type;
1938#line 217 "include/linux/quota.h"
1939struct mem_dqinfo {
1940   struct quota_format_type *dqi_format ;
1941   int dqi_fmt_id ;
1942   struct list_head dqi_dirty_list ;
1943   unsigned long dqi_flags ;
1944   unsigned int dqi_bgrace ;
1945   unsigned int dqi_igrace ;
1946   qsize_t dqi_maxblimit ;
1947   qsize_t dqi_maxilimit ;
1948   void *dqi_priv ;
1949};
1950#line 230
1951struct super_block;
1952#line 288 "include/linux/quota.h"
1953struct dquot {
1954   struct hlist_node dq_hash ;
1955   struct list_head dq_inuse ;
1956   struct list_head dq_free ;
1957   struct list_head dq_dirty ;
1958   struct mutex dq_lock ;
1959   atomic_t dq_count ;
1960   wait_queue_head_t dq_wait_unused ;
1961   struct super_block *dq_sb ;
1962   unsigned int dq_id ;
1963   loff_t dq_off ;
1964   unsigned long dq_flags ;
1965   short dq_type ;
1966   struct mem_dqblk dq_dqb ;
1967};
1968#line 305 "include/linux/quota.h"
1969struct quota_format_ops {
1970   int (*check_quota_file)(struct super_block *sb , int type ) ;
1971   int (*read_file_info)(struct super_block *sb , int type ) ;
1972   int (*write_file_info)(struct super_block *sb , int type ) ;
1973   int (*free_file_info)(struct super_block *sb , int type ) ;
1974   int (*read_dqblk)(struct dquot *dquot ) ;
1975   int (*commit_dqblk)(struct dquot *dquot ) ;
1976   int (*release_dqblk)(struct dquot *dquot ) ;
1977};
1978#line 316 "include/linux/quota.h"
1979struct dquot_operations {
1980   int (*write_dquot)(struct dquot * ) ;
1981   struct dquot *(*alloc_dquot)(struct super_block * , int  ) ;
1982   void (*destroy_dquot)(struct dquot * ) ;
1983   int (*acquire_dquot)(struct dquot * ) ;
1984   int (*release_dquot)(struct dquot * ) ;
1985   int (*mark_dirty)(struct dquot * ) ;
1986   int (*write_info)(struct super_block * , int  ) ;
1987   qsize_t *(*get_reserved_space)(struct inode * ) ;
1988};
1989#line 329
1990struct path;
1991#line 332 "include/linux/quota.h"
1992struct quotactl_ops {
1993   int (*quota_on)(struct super_block * , int  , int  , struct path * ) ;
1994   int (*quota_on_meta)(struct super_block * , int  , int  ) ;
1995   int (*quota_off)(struct super_block * , int  ) ;
1996   int (*quota_sync)(struct super_block * , int  , int  ) ;
1997   int (*get_info)(struct super_block * , int  , struct if_dqinfo * ) ;
1998   int (*set_info)(struct super_block * , int  , struct if_dqinfo * ) ;
1999   int (*get_dqblk)(struct super_block * , int  , qid_t  , struct fs_disk_quota * ) ;
2000   int (*set_dqblk)(struct super_block * , int  , qid_t  , struct fs_disk_quota * ) ;
2001   int (*get_xstate)(struct super_block * , struct fs_quota_stat * ) ;
2002   int (*set_xstate)(struct super_block * , unsigned int  , int  ) ;
2003};
2004#line 345 "include/linux/quota.h"
2005struct quota_format_type {
2006   int qf_fmt_id ;
2007   struct quota_format_ops  const  *qf_ops ;
2008   struct module *qf_owner ;
2009   struct quota_format_type *qf_next ;
2010};
2011#line 399 "include/linux/quota.h"
2012struct quota_info {
2013   unsigned int flags ;
2014   struct mutex dqio_mutex ;
2015   struct mutex dqonoff_mutex ;
2016   struct rw_semaphore dqptr_sem ;
2017   struct inode *files[2] ;
2018   struct mem_dqinfo info[2] ;
2019   struct quota_format_ops  const  *ops[2] ;
2020};
2021#line 532 "include/linux/fs.h"
2022struct page;
2023#line 533
2024struct address_space;
2025#line 534
2026struct writeback_control;
2027#line 577 "include/linux/fs.h"
2028union __anonunion_arg_224 {
2029   char *buf ;
2030   void *data ;
2031};
2032#line 577 "include/linux/fs.h"
2033struct __anonstruct_read_descriptor_t_223 {
2034   size_t written ;
2035   size_t count ;
2036   union __anonunion_arg_224 arg ;
2037   int error ;
2038};
2039#line 577 "include/linux/fs.h"
2040typedef struct __anonstruct_read_descriptor_t_223 read_descriptor_t;
2041#line 590 "include/linux/fs.h"
2042struct address_space_operations {
2043   int (*writepage)(struct page *page , struct writeback_control *wbc ) ;
2044   int (*readpage)(struct file * , struct page * ) ;
2045   int (*writepages)(struct address_space * , struct writeback_control * ) ;
2046   int (*set_page_dirty)(struct page *page ) ;
2047   int (*readpages)(struct file *filp , struct address_space *mapping , struct list_head *pages ,
2048                    unsigned int nr_pages ) ;
2049   int (*write_begin)(struct file * , struct address_space *mapping , loff_t pos ,
2050                      unsigned int len , unsigned int flags , struct page **pagep ,
2051                      void **fsdata ) ;
2052   int (*write_end)(struct file * , struct address_space *mapping , loff_t pos , unsigned int len ,
2053                    unsigned int copied , struct page *page , void *fsdata ) ;
2054   sector_t (*bmap)(struct address_space * , sector_t  ) ;
2055   void (*invalidatepage)(struct page * , unsigned long  ) ;
2056   int (*releasepage)(struct page * , gfp_t  ) ;
2057   void (*freepage)(struct page * ) ;
2058   ssize_t (*direct_IO)(int  , struct kiocb * , struct iovec  const  *iov , loff_t offset ,
2059                        unsigned long nr_segs ) ;
2060   int (*get_xip_mem)(struct address_space * , unsigned long  , int  , void ** , unsigned long * ) ;
2061   int (*migratepage)(struct address_space * , struct page * , struct page * , enum migrate_mode  ) ;
2062   int (*launder_page)(struct page * ) ;
2063   int (*is_partially_uptodate)(struct page * , read_descriptor_t * , unsigned long  ) ;
2064   int (*error_remove_page)(struct address_space * , struct page * ) ;
2065};
2066#line 645
2067struct backing_dev_info;
2068#line 645
2069struct backing_dev_info;
2070#line 646 "include/linux/fs.h"
2071struct address_space {
2072   struct inode *host ;
2073   struct radix_tree_root page_tree ;
2074   spinlock_t tree_lock ;
2075   unsigned int i_mmap_writable ;
2076   struct prio_tree_root i_mmap ;
2077   struct list_head i_mmap_nonlinear ;
2078   struct mutex i_mmap_mutex ;
2079   unsigned long nrpages ;
2080   unsigned long writeback_index ;
2081   struct address_space_operations  const  *a_ops ;
2082   unsigned long flags ;
2083   struct backing_dev_info *backing_dev_info ;
2084   spinlock_t private_lock ;
2085   struct list_head private_list ;
2086   struct address_space *assoc_mapping ;
2087} __attribute__((__aligned__(sizeof(long )))) ;
2088#line 669
2089struct request_queue;
2090#line 669
2091struct request_queue;
2092#line 671
2093struct hd_struct;
2094#line 671
2095struct gendisk;
2096#line 671 "include/linux/fs.h"
2097struct block_device {
2098   dev_t bd_dev ;
2099   int bd_openers ;
2100   struct inode *bd_inode ;
2101   struct super_block *bd_super ;
2102   struct mutex bd_mutex ;
2103   struct list_head bd_inodes ;
2104   void *bd_claiming ;
2105   void *bd_holder ;
2106   int bd_holders ;
2107   bool bd_write_holder ;
2108   struct list_head bd_holder_disks ;
2109   struct block_device *bd_contains ;
2110   unsigned int bd_block_size ;
2111   struct hd_struct *bd_part ;
2112   unsigned int bd_part_count ;
2113   int bd_invalidated ;
2114   struct gendisk *bd_disk ;
2115   struct request_queue *bd_queue ;
2116   struct list_head bd_list ;
2117   unsigned long bd_private ;
2118   int bd_fsfreeze_count ;
2119   struct mutex bd_fsfreeze_mutex ;
2120};
2121#line 749
2122struct posix_acl;
2123#line 749
2124struct posix_acl;
2125#line 761
2126struct inode_operations;
2127#line 761 "include/linux/fs.h"
2128union __anonunion____missing_field_name_225 {
2129   unsigned int const   i_nlink ;
2130   unsigned int __i_nlink ;
2131};
2132#line 761 "include/linux/fs.h"
2133union __anonunion____missing_field_name_226 {
2134   struct list_head i_dentry ;
2135   struct rcu_head i_rcu ;
2136};
2137#line 761
2138struct file_operations;
2139#line 761
2140struct file_lock;
2141#line 761
2142struct cdev;
2143#line 761 "include/linux/fs.h"
2144union __anonunion____missing_field_name_227 {
2145   struct pipe_inode_info *i_pipe ;
2146   struct block_device *i_bdev ;
2147   struct cdev *i_cdev ;
2148};
2149#line 761 "include/linux/fs.h"
2150struct inode {
2151   umode_t i_mode ;
2152   unsigned short i_opflags ;
2153   uid_t i_uid ;
2154   gid_t i_gid ;
2155   unsigned int i_flags ;
2156   struct posix_acl *i_acl ;
2157   struct posix_acl *i_default_acl ;
2158   struct inode_operations  const  *i_op ;
2159   struct super_block *i_sb ;
2160   struct address_space *i_mapping ;
2161   void *i_security ;
2162   unsigned long i_ino ;
2163   union __anonunion____missing_field_name_225 __annonCompField43 ;
2164   dev_t i_rdev ;
2165   struct timespec i_atime ;
2166   struct timespec i_mtime ;
2167   struct timespec i_ctime ;
2168   spinlock_t i_lock ;
2169   unsigned short i_bytes ;
2170   blkcnt_t i_blocks ;
2171   loff_t i_size ;
2172   unsigned long i_state ;
2173   struct mutex i_mutex ;
2174   unsigned long dirtied_when ;
2175   struct hlist_node i_hash ;
2176   struct list_head i_wb_list ;
2177   struct list_head i_lru ;
2178   struct list_head i_sb_list ;
2179   union __anonunion____missing_field_name_226 __annonCompField44 ;
2180   atomic_t i_count ;
2181   unsigned int i_blkbits ;
2182   u64 i_version ;
2183   atomic_t i_dio_count ;
2184   atomic_t i_writecount ;
2185   struct file_operations  const  *i_fop ;
2186   struct file_lock *i_flock ;
2187   struct address_space i_data ;
2188   struct dquot *i_dquot[2] ;
2189   struct list_head i_devices ;
2190   union __anonunion____missing_field_name_227 __annonCompField45 ;
2191   __u32 i_generation ;
2192   __u32 i_fsnotify_mask ;
2193   struct hlist_head i_fsnotify_marks ;
2194   atomic_t i_readcount ;
2195   void *i_private ;
2196};
2197#line 942 "include/linux/fs.h"
2198struct fown_struct {
2199   rwlock_t lock ;
2200   struct pid *pid ;
2201   enum pid_type pid_type ;
2202   uid_t uid ;
2203   uid_t euid ;
2204   int signum ;
2205};
2206#line 953 "include/linux/fs.h"
2207struct file_ra_state {
2208   unsigned long start ;
2209   unsigned int size ;
2210   unsigned int async_size ;
2211   unsigned int ra_pages ;
2212   unsigned int mmap_miss ;
2213   loff_t prev_pos ;
2214};
2215#line 976 "include/linux/fs.h"
2216union __anonunion_f_u_228 {
2217   struct list_head fu_list ;
2218   struct rcu_head fu_rcuhead ;
2219};
2220#line 976 "include/linux/fs.h"
2221struct file {
2222   union __anonunion_f_u_228 f_u ;
2223   struct path f_path ;
2224   struct file_operations  const  *f_op ;
2225   spinlock_t f_lock ;
2226   int f_sb_list_cpu ;
2227   atomic_long_t f_count ;
2228   unsigned int f_flags ;
2229   fmode_t f_mode ;
2230   loff_t f_pos ;
2231   struct fown_struct f_owner ;
2232   struct cred  const  *f_cred ;
2233   struct file_ra_state f_ra ;
2234   u64 f_version ;
2235   void *f_security ;
2236   void *private_data ;
2237   struct list_head f_ep_links ;
2238   struct list_head f_tfile_llink ;
2239   struct address_space *f_mapping ;
2240   unsigned long f_mnt_write_state ;
2241};
2242#line 1111
2243struct files_struct;
2244#line 1111 "include/linux/fs.h"
2245typedef struct files_struct *fl_owner_t;
2246#line 1113 "include/linux/fs.h"
2247struct file_lock_operations {
2248   void (*fl_copy_lock)(struct file_lock * , struct file_lock * ) ;
2249   void (*fl_release_private)(struct file_lock * ) ;
2250};
2251#line 1118 "include/linux/fs.h"
2252struct lock_manager_operations {
2253   int (*lm_compare_owner)(struct file_lock * , struct file_lock * ) ;
2254   void (*lm_notify)(struct file_lock * ) ;
2255   int (*lm_grant)(struct file_lock * , struct file_lock * , int  ) ;
2256   void (*lm_release_private)(struct file_lock * ) ;
2257   void (*lm_break)(struct file_lock * ) ;
2258   int (*lm_change)(struct file_lock ** , int  ) ;
2259};
2260#line 4 "include/linux/nfs_fs_i.h"
2261struct nlm_lockowner;
2262#line 4
2263struct nlm_lockowner;
2264#line 9 "include/linux/nfs_fs_i.h"
2265struct nfs_lock_info {
2266   u32 state ;
2267   struct nlm_lockowner *owner ;
2268   struct list_head list ;
2269};
2270#line 15
2271struct nfs4_lock_state;
2272#line 15
2273struct nfs4_lock_state;
2274#line 16 "include/linux/nfs_fs_i.h"
2275struct nfs4_lock_info {
2276   struct nfs4_lock_state *owner ;
2277};
2278#line 1138 "include/linux/fs.h"
2279struct fasync_struct;
2280#line 1138 "include/linux/fs.h"
2281struct __anonstruct_afs_230 {
2282   struct list_head link ;
2283   int state ;
2284};
2285#line 1138 "include/linux/fs.h"
2286union __anonunion_fl_u_229 {
2287   struct nfs_lock_info nfs_fl ;
2288   struct nfs4_lock_info nfs4_fl ;
2289   struct __anonstruct_afs_230 afs ;
2290};
2291#line 1138 "include/linux/fs.h"
2292struct file_lock {
2293   struct file_lock *fl_next ;
2294   struct list_head fl_link ;
2295   struct list_head fl_block ;
2296   fl_owner_t fl_owner ;
2297   unsigned int fl_flags ;
2298   unsigned char fl_type ;
2299   unsigned int fl_pid ;
2300   struct pid *fl_nspid ;
2301   wait_queue_head_t fl_wait ;
2302   struct file *fl_file ;
2303   loff_t fl_start ;
2304   loff_t fl_end ;
2305   struct fasync_struct *fl_fasync ;
2306   unsigned long fl_break_time ;
2307   unsigned long fl_downgrade_time ;
2308   struct file_lock_operations  const  *fl_ops ;
2309   struct lock_manager_operations  const  *fl_lmops ;
2310   union __anonunion_fl_u_229 fl_u ;
2311};
2312#line 1378 "include/linux/fs.h"
2313struct fasync_struct {
2314   spinlock_t fa_lock ;
2315   int magic ;
2316   int fa_fd ;
2317   struct fasync_struct *fa_next ;
2318   struct file *fa_file ;
2319   struct rcu_head fa_rcu ;
2320};
2321#line 1418
2322struct file_system_type;
2323#line 1418
2324struct super_operations;
2325#line 1418
2326struct xattr_handler;
2327#line 1418
2328struct mtd_info;
2329#line 1418 "include/linux/fs.h"
2330struct super_block {
2331   struct list_head s_list ;
2332   dev_t s_dev ;
2333   unsigned char s_dirt ;
2334   unsigned char s_blocksize_bits ;
2335   unsigned long s_blocksize ;
2336   loff_t s_maxbytes ;
2337   struct file_system_type *s_type ;
2338   struct super_operations  const  *s_op ;
2339   struct dquot_operations  const  *dq_op ;
2340   struct quotactl_ops  const  *s_qcop ;
2341   struct export_operations  const  *s_export_op ;
2342   unsigned long s_flags ;
2343   unsigned long s_magic ;
2344   struct dentry *s_root ;
2345   struct rw_semaphore s_umount ;
2346   struct mutex s_lock ;
2347   int s_count ;
2348   atomic_t s_active ;
2349   void *s_security ;
2350   struct xattr_handler  const  **s_xattr ;
2351   struct list_head s_inodes ;
2352   struct hlist_bl_head s_anon ;
2353   struct list_head *s_files ;
2354   struct list_head s_mounts ;
2355   struct list_head s_dentry_lru ;
2356   int s_nr_dentry_unused ;
2357   spinlock_t s_inode_lru_lock  __attribute__((__aligned__((1) <<  (6) ))) ;
2358   struct list_head s_inode_lru ;
2359   int s_nr_inodes_unused ;
2360   struct block_device *s_bdev ;
2361   struct backing_dev_info *s_bdi ;
2362   struct mtd_info *s_mtd ;
2363   struct hlist_node s_instances ;
2364   struct quota_info s_dquot ;
2365   int s_frozen ;
2366   wait_queue_head_t s_wait_unfrozen ;
2367   char s_id[32] ;
2368   u8 s_uuid[16] ;
2369   void *s_fs_info ;
2370   unsigned int s_max_links ;
2371   fmode_t s_mode ;
2372   u32 s_time_gran ;
2373   struct mutex s_vfs_rename_mutex ;
2374   char *s_subtype ;
2375   char *s_options ;
2376   struct dentry_operations  const  *s_d_op ;
2377   int cleancache_poolid ;
2378   struct shrinker s_shrink ;
2379   atomic_long_t s_remove_count ;
2380   int s_readonly_remount ;
2381};
2382#line 1567 "include/linux/fs.h"
2383struct fiemap_extent_info {
2384   unsigned int fi_flags ;
2385   unsigned int fi_extents_mapped ;
2386   unsigned int fi_extents_max ;
2387   struct fiemap_extent *fi_extents_start ;
2388};
2389#line 1609 "include/linux/fs.h"
2390struct file_operations {
2391   struct module *owner ;
2392   loff_t (*llseek)(struct file * , loff_t  , int  ) ;
2393   ssize_t (*read)(struct file * , char * , size_t  , loff_t * ) ;
2394   ssize_t (*write)(struct file * , char const   * , size_t  , loff_t * ) ;
2395   ssize_t (*aio_read)(struct kiocb * , struct iovec  const  * , unsigned long  ,
2396                       loff_t  ) ;
2397   ssize_t (*aio_write)(struct kiocb * , struct iovec  const  * , unsigned long  ,
2398                        loff_t  ) ;
2399   int (*readdir)(struct file * , void * , int (*)(void * , char const   * , int  ,
2400                                                   loff_t  , u64  , unsigned int  ) ) ;
2401   unsigned int (*poll)(struct file * , struct poll_table_struct * ) ;
2402   long (*unlocked_ioctl)(struct file * , unsigned int  , unsigned long  ) ;
2403   long (*compat_ioctl)(struct file * , unsigned int  , unsigned long  ) ;
2404   int (*mmap)(struct file * , struct vm_area_struct * ) ;
2405   int (*open)(struct inode * , struct file * ) ;
2406   int (*flush)(struct file * , fl_owner_t id ) ;
2407   int (*release)(struct inode * , struct file * ) ;
2408   int (*fsync)(struct file * , loff_t  , loff_t  , int datasync ) ;
2409   int (*aio_fsync)(struct kiocb * , int datasync ) ;
2410   int (*fasync)(int  , struct file * , int  ) ;
2411   int (*lock)(struct file * , int  , struct file_lock * ) ;
2412   ssize_t (*sendpage)(struct file * , struct page * , int  , size_t  , loff_t * ,
2413                       int  ) ;
2414   unsigned long (*get_unmapped_area)(struct file * , unsigned long  , unsigned long  ,
2415                                      unsigned long  , unsigned long  ) ;
2416   int (*check_flags)(int  ) ;
2417   int (*flock)(struct file * , int  , struct file_lock * ) ;
2418   ssize_t (*splice_write)(struct pipe_inode_info * , struct file * , loff_t * , size_t  ,
2419                           unsigned int  ) ;
2420   ssize_t (*splice_read)(struct file * , loff_t * , struct pipe_inode_info * , size_t  ,
2421                          unsigned int  ) ;
2422   int (*setlease)(struct file * , long  , struct file_lock ** ) ;
2423   long (*fallocate)(struct file *file , int mode , loff_t offset , loff_t len ) ;
2424};
2425#line 1639 "include/linux/fs.h"
2426struct inode_operations {
2427   struct dentry *(*lookup)(struct inode * , struct dentry * , struct nameidata * ) ;
2428   void *(*follow_link)(struct dentry * , struct nameidata * ) ;
2429   int (*permission)(struct inode * , int  ) ;
2430   struct posix_acl *(*get_acl)(struct inode * , int  ) ;
2431   int (*readlink)(struct dentry * , char * , int  ) ;
2432   void (*put_link)(struct dentry * , struct nameidata * , void * ) ;
2433   int (*create)(struct inode * , struct dentry * , umode_t  , struct nameidata * ) ;
2434   int (*link)(struct dentry * , struct inode * , struct dentry * ) ;
2435   int (*unlink)(struct inode * , struct dentry * ) ;
2436   int (*symlink)(struct inode * , struct dentry * , char const   * ) ;
2437   int (*mkdir)(struct inode * , struct dentry * , umode_t  ) ;
2438   int (*rmdir)(struct inode * , struct dentry * ) ;
2439   int (*mknod)(struct inode * , struct dentry * , umode_t  , dev_t  ) ;
2440   int (*rename)(struct inode * , struct dentry * , struct inode * , struct dentry * ) ;
2441   void (*truncate)(struct inode * ) ;
2442   int (*setattr)(struct dentry * , struct iattr * ) ;
2443   int (*getattr)(struct vfsmount *mnt , struct dentry * , struct kstat * ) ;
2444   int (*setxattr)(struct dentry * , char const   * , void const   * , size_t  , int  ) ;
2445   ssize_t (*getxattr)(struct dentry * , char const   * , void * , size_t  ) ;
2446   ssize_t (*listxattr)(struct dentry * , char * , size_t  ) ;
2447   int (*removexattr)(struct dentry * , char const   * ) ;
2448   void (*truncate_range)(struct inode * , loff_t  , loff_t  ) ;
2449   int (*fiemap)(struct inode * , struct fiemap_extent_info * , u64 start , u64 len ) ;
2450} __attribute__((__aligned__((1) <<  (6) ))) ;
2451#line 1669
2452struct seq_file;
2453#line 1684 "include/linux/fs.h"
2454struct super_operations {
2455   struct inode *(*alloc_inode)(struct super_block *sb ) ;
2456   void (*destroy_inode)(struct inode * ) ;
2457   void (*dirty_inode)(struct inode * , int flags ) ;
2458   int (*write_inode)(struct inode * , struct writeback_control *wbc ) ;
2459   int (*drop_inode)(struct inode * ) ;
2460   void (*evict_inode)(struct inode * ) ;
2461   void (*put_super)(struct super_block * ) ;
2462   void (*write_super)(struct super_block * ) ;
2463   int (*sync_fs)(struct super_block *sb , int wait ) ;
2464   int (*freeze_fs)(struct super_block * ) ;
2465   int (*unfreeze_fs)(struct super_block * ) ;
2466   int (*statfs)(struct dentry * , struct kstatfs * ) ;
2467   int (*remount_fs)(struct super_block * , int * , char * ) ;
2468   void (*umount_begin)(struct super_block * ) ;
2469   int (*show_options)(struct seq_file * , struct dentry * ) ;
2470   int (*show_devname)(struct seq_file * , struct dentry * ) ;
2471   int (*show_path)(struct seq_file * , struct dentry * ) ;
2472   int (*show_stats)(struct seq_file * , struct dentry * ) ;
2473   ssize_t (*quota_read)(struct super_block * , int  , char * , size_t  , loff_t  ) ;
2474   ssize_t (*quota_write)(struct super_block * , int  , char const   * , size_t  ,
2475                          loff_t  ) ;
2476   int (*bdev_try_to_free_page)(struct super_block * , struct page * , gfp_t  ) ;
2477   int (*nr_cached_objects)(struct super_block * ) ;
2478   void (*free_cached_objects)(struct super_block * , int  ) ;
2479};
2480#line 1835 "include/linux/fs.h"
2481struct file_system_type {
2482   char const   *name ;
2483   int fs_flags ;
2484   struct dentry *(*mount)(struct file_system_type * , int  , char const   * , void * ) ;
2485   void (*kill_sb)(struct super_block * ) ;
2486   struct module *owner ;
2487   struct file_system_type *next ;
2488   struct hlist_head fs_supers ;
2489   struct lock_class_key s_lock_key ;
2490   struct lock_class_key s_umount_key ;
2491   struct lock_class_key s_vfs_rename_key ;
2492   struct lock_class_key i_lock_key ;
2493   struct lock_class_key i_mutex_key ;
2494   struct lock_class_key i_mutex_dir_key ;
2495};
2496#line 31 "include/linux/irq.h"
2497struct seq_file;
2498#line 32
2499struct module;
2500#line 12 "include/linux/irqdesc.h"
2501struct proc_dir_entry;
2502#line 14
2503struct module;
2504#line 16 "include/linux/profile.h"
2505struct proc_dir_entry;
2506#line 65
2507struct task_struct;
2508#line 66
2509struct mm_struct;
2510#line 94 "/home/zakharov/launch/inst/current/envs/linux-3.4/linux-3.4/arch/x86/include/asm/uaccess.h"
2511struct exception_table_entry {
2512   unsigned long insn ;
2513   unsigned long fixup ;
2514};
2515#line 132 "include/linux/hardirq.h"
2516struct task_struct;
2517#line 187 "include/linux/interrupt.h"
2518struct device;
2519#line 695
2520struct seq_file;
2521#line 20 "include/linux/uio_driver.h"
2522struct module;
2523#line 21
2524struct uio_map;
2525#line 21
2526struct uio_map;
2527#line 35 "include/linux/uio_driver.h"
2528struct uio_mem {
2529   char const   *name ;
2530   phys_addr_t addr ;
2531   unsigned long size ;
2532   int memtype ;
2533   void *internal_addr ;
2534   struct uio_map *map ;
2535};
2536#line 46
2537struct uio_portio;
2538#line 46
2539struct uio_portio;
2540#line 56 "include/linux/uio_driver.h"
2541struct uio_port {
2542   char const   *name ;
2543   unsigned long start ;
2544   unsigned long size ;
2545   int porttype ;
2546   struct uio_portio *portio ;
2547};
2548#line 66
2549struct uio_device;
2550#line 66
2551struct uio_device;
2552#line 84 "include/linux/uio_driver.h"
2553struct uio_info {
2554   struct uio_device *uio_dev ;
2555   char const   *name ;
2556   char const   *version ;
2557   struct uio_mem mem[5] ;
2558   struct uio_port port[5] ;
2559   long irq ;
2560   unsigned long irq_flags ;
2561   void *priv ;
2562   irqreturn_t (*handler)(int irq , struct uio_info *dev_info ) ;
2563   int (*mmap)(struct uio_info *info , struct vm_area_struct *vma ) ;
2564   int (*open)(struct uio_info *info , struct inode *inode ) ;
2565   int (*release)(struct uio_info *info , struct inode *inode ) ;
2566   int (*irqcontrol)(struct uio_info *info , s32 irq_on ) ;
2567};
2568#line 33 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
2569struct uio_pci_generic_dev {
2570   struct uio_info info ;
2571   struct pci_dev *pdev ;
2572};
2573#line 1 "<compiler builtins>"
2574long __builtin_expect(long val , long res ) ;
2575#line 100 "include/linux/printk.h"
2576extern int ( /* format attribute */  printk)(char const   *fmt  , ...) ;
2577#line 152 "include/linux/mutex.h"
2578void mutex_lock(struct mutex *lock ) ;
2579#line 153
2580int __attribute__((__warn_unused_result__))  mutex_lock_interruptible(struct mutex *lock ) ;
2581#line 154
2582int __attribute__((__warn_unused_result__))  mutex_lock_killable(struct mutex *lock ) ;
2583#line 168
2584int mutex_trylock(struct mutex *lock ) ;
2585#line 169
2586void mutex_unlock(struct mutex *lock ) ;
2587#line 170
2588int atomic_dec_and_mutex_lock(atomic_t *cnt , struct mutex *lock ) ;
2589#line 792 "include/linux/device.h"
2590extern void *dev_get_drvdata(struct device  const  *dev ) ;
2591#line 793
2592extern int dev_set_drvdata(struct device *dev , void *data ) ;
2593#line 891
2594extern int ( /* format attribute */  dev_err)(struct device  const  *dev , char const   *fmt 
2595                                              , ...) ;
2596#line 893
2597extern int ( /* format attribute */  dev_warn)(struct device  const  *dev , char const   *fmt 
2598                                               , ...) ;
2599#line 26 "include/linux/export.h"
2600extern struct module __this_module ;
2601#line 67 "include/linux/module.h"
2602int init_module(void) ;
2603#line 68
2604void cleanup_module(void) ;
2605#line 773 "include/linux/pci.h"
2606extern int __attribute__((__warn_unused_result__))  pci_enable_device(struct pci_dev *dev ) ;
2607#line 790
2608extern void pci_disable_device(struct pci_dev *dev ) ;
2609#line 803
2610extern bool pci_intx_mask_supported(struct pci_dev *dev ) ;
2611#line 804
2612extern bool pci_check_and_mask_intx(struct pci_dev *dev ) ;
2613#line 940
2614extern int __attribute__((__warn_unused_result__))  __pci_register_driver(struct pci_driver * ,
2615                                                                          struct module * ,
2616                                                                          char const   *mod_name ) ;
2617#line 949
2618extern void pci_unregister_driver(struct pci_driver *dev ) ;
2619#line 161 "include/linux/slab.h"
2620extern void kfree(void const   * ) ;
2621#line 221 "include/linux/slub_def.h"
2622extern void *__kmalloc(size_t size , gfp_t flags ) ;
2623#line 268
2624__inline static void *( __attribute__((__always_inline__)) kmalloc)(size_t size ,
2625                                                                    gfp_t flags )  __attribute__((__no_instrument_function__)) ;
2626#line 268 "include/linux/slub_def.h"
2627__inline static void *( __attribute__((__always_inline__)) kmalloc)(size_t size ,
2628                                                                    gfp_t flags ) 
2629{ void *tmp___2 ;
2630
2631  {
2632  {
2633#line 283
2634  tmp___2 = __kmalloc(size, flags);
2635  }
2636#line 283
2637  return (tmp___2);
2638}
2639}
2640#line 349 "include/linux/slab.h"
2641__inline static void *kzalloc(size_t size , gfp_t flags )  __attribute__((__no_instrument_function__)) ;
2642#line 349 "include/linux/slab.h"
2643__inline static void *kzalloc(size_t size , gfp_t flags ) 
2644{ void *tmp ;
2645  unsigned int __cil_tmp4 ;
2646
2647  {
2648  {
2649#line 351
2650  __cil_tmp4 = flags | 32768U;
2651#line 351
2652  tmp = kmalloc(size, __cil_tmp4);
2653  }
2654#line 351
2655  return (tmp);
2656}
2657}
2658#line 1358 "include/linux/pci.h"
2659__inline static void *pci_get_drvdata(struct pci_dev *pdev )  __attribute__((__no_instrument_function__)) ;
2660#line 1358 "include/linux/pci.h"
2661__inline static void *pci_get_drvdata(struct pci_dev *pdev ) 
2662{ void *tmp ;
2663  unsigned long __cil_tmp3 ;
2664  unsigned long __cil_tmp4 ;
2665  struct device *__cil_tmp5 ;
2666  struct device  const  *__cil_tmp6 ;
2667
2668  {
2669  {
2670#line 1360
2671  __cil_tmp3 = (unsigned long )pdev;
2672#line 1360
2673  __cil_tmp4 = __cil_tmp3 + 144;
2674#line 1360
2675  __cil_tmp5 = (struct device *)__cil_tmp4;
2676#line 1360
2677  __cil_tmp6 = (struct device  const  *)__cil_tmp5;
2678#line 1360
2679  tmp = dev_get_drvdata(__cil_tmp6);
2680  }
2681#line 1360
2682  return (tmp);
2683}
2684}
2685#line 1363
2686__inline static void pci_set_drvdata(struct pci_dev *pdev , void *data )  __attribute__((__no_instrument_function__)) ;
2687#line 1363 "include/linux/pci.h"
2688__inline static void pci_set_drvdata(struct pci_dev *pdev , void *data ) 
2689{ unsigned long __cil_tmp3 ;
2690  unsigned long __cil_tmp4 ;
2691  struct device *__cil_tmp5 ;
2692
2693  {
2694  {
2695#line 1365
2696  __cil_tmp3 = (unsigned long )pdev;
2697#line 1365
2698  __cil_tmp4 = __cil_tmp3 + 144;
2699#line 1365
2700  __cil_tmp5 = (struct device *)__cil_tmp4;
2701#line 1365
2702  dev_set_drvdata(__cil_tmp5, data);
2703  }
2704#line 1366
2705  return;
2706}
2707}
2708#line 100 "include/linux/uio_driver.h"
2709extern int __attribute__((__warn_unused_result__))  __uio_register_device(struct module *owner ,
2710                                                                          struct device *parent ,
2711                                                                          struct uio_info *info ) ;
2712#line 109
2713extern void uio_unregister_device(struct uio_info *info ) ;
2714#line 38 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
2715__inline static struct uio_pci_generic_dev *to_uio_pci_generic_dev(struct uio_info *info )  __attribute__((__no_instrument_function__)) ;
2716#line 38 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
2717__inline static struct uio_pci_generic_dev *to_uio_pci_generic_dev(struct uio_info *info ) 
2718{ struct uio_info  const  *__mptr ;
2719  struct uio_pci_generic_dev *__cil_tmp3 ;
2720  struct uio_info *__cil_tmp4 ;
2721  unsigned int __cil_tmp5 ;
2722  char *__cil_tmp6 ;
2723  char *__cil_tmp7 ;
2724
2725  {
2726#line 41
2727  __mptr = (struct uio_info  const  *)info;
2728  {
2729#line 41
2730  __cil_tmp3 = (struct uio_pci_generic_dev *)0;
2731#line 41
2732  __cil_tmp4 = (struct uio_info *)__cil_tmp3;
2733#line 41
2734  __cil_tmp5 = (unsigned int )__cil_tmp4;
2735#line 41
2736  __cil_tmp6 = (char *)__mptr;
2737#line 41
2738  __cil_tmp7 = __cil_tmp6 - __cil_tmp5;
2739#line 41
2740  return ((struct uio_pci_generic_dev *)__cil_tmp7);
2741  }
2742}
2743}
2744#line 46 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
2745static irqreturn_t irqhandler(int irq , struct uio_info *info ) 
2746{ struct uio_pci_generic_dev *gdev ;
2747  struct uio_pci_generic_dev *tmp ;
2748  bool tmp___0 ;
2749  unsigned long __cil_tmp6 ;
2750  unsigned long __cil_tmp7 ;
2751  struct pci_dev *__cil_tmp8 ;
2752
2753  {
2754  {
2755#line 48
2756  tmp = to_uio_pci_generic_dev(info);
2757#line 48
2758  gdev = tmp;
2759#line 50
2760  __cil_tmp6 = (unsigned long )gdev;
2761#line 50
2762  __cil_tmp7 = __cil_tmp6 + 528;
2763#line 50
2764  __cil_tmp8 = *((struct pci_dev **)__cil_tmp7);
2765#line 50
2766  tmp___0 = pci_check_and_mask_intx(__cil_tmp8);
2767  }
2768#line 50
2769  if (tmp___0) {
2770
2771  } else {
2772#line 51
2773    return ((irqreturn_t )0);
2774  }
2775#line 54
2776  return ((irqreturn_t )1);
2777}
2778}
2779#line 57
2780static int probe(struct pci_dev *pdev , struct pci_device_id  const  *id )  __attribute__((__section__(".devinit.text"),
2781__no_instrument_function__)) ;
2782#line 57 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
2783static int probe(struct pci_dev *pdev , struct pci_device_id  const  *id ) 
2784{ struct uio_pci_generic_dev *gdev ;
2785  int err ;
2786  bool tmp ;
2787  void *tmp___0 ;
2788  int tmp___1 ;
2789  unsigned long __cil_tmp8 ;
2790  unsigned long __cil_tmp9 ;
2791  struct device *__cil_tmp10 ;
2792  struct device  const  *__cil_tmp11 ;
2793  unsigned long __cil_tmp12 ;
2794  unsigned long __cil_tmp13 ;
2795  unsigned int __cil_tmp14 ;
2796  unsigned long __cil_tmp15 ;
2797  unsigned long __cil_tmp16 ;
2798  struct device *__cil_tmp17 ;
2799  struct device  const  *__cil_tmp18 ;
2800  unsigned long __cil_tmp19 ;
2801  unsigned long __cil_tmp20 ;
2802  unsigned long __cil_tmp21 ;
2803  unsigned long __cil_tmp22 ;
2804  unsigned long __cil_tmp23 ;
2805  unsigned long __cil_tmp24 ;
2806  unsigned long __cil_tmp25 ;
2807  unsigned long __cil_tmp26 ;
2808  unsigned long __cil_tmp27 ;
2809  unsigned long __cil_tmp28 ;
2810  unsigned long __cil_tmp29 ;
2811  unsigned int __cil_tmp30 ;
2812  unsigned long __cil_tmp31 ;
2813  unsigned long __cil_tmp32 ;
2814  unsigned long __cil_tmp33 ;
2815  unsigned long __cil_tmp34 ;
2816  unsigned long __cil_tmp35 ;
2817  unsigned long __cil_tmp36 ;
2818  unsigned long __cil_tmp37 ;
2819  unsigned long __cil_tmp38 ;
2820  unsigned long __cil_tmp39 ;
2821  unsigned long __cil_tmp40 ;
2822  struct device *__cil_tmp41 ;
2823  struct uio_info *__cil_tmp42 ;
2824  void *__cil_tmp43 ;
2825  void const   *__cil_tmp44 ;
2826
2827  {
2828  {
2829#line 63
2830  err = (int )pci_enable_device(pdev);
2831  }
2832#line 64
2833  if (err) {
2834    {
2835#line 65
2836    __cil_tmp8 = (unsigned long )pdev;
2837#line 65
2838    __cil_tmp9 = __cil_tmp8 + 144;
2839#line 65
2840    __cil_tmp10 = (struct device *)__cil_tmp9;
2841#line 65
2842    __cil_tmp11 = (struct device  const  *)__cil_tmp10;
2843#line 65
2844    dev_err(__cil_tmp11, "%s: pci_enable_device failed: %d\n", "probe", err);
2845    }
2846#line 67
2847    return (err);
2848  } else {
2849
2850  }
2851  {
2852#line 70
2853  __cil_tmp12 = (unsigned long )pdev;
2854#line 70
2855  __cil_tmp13 = __cil_tmp12 + 916;
2856#line 70
2857  __cil_tmp14 = *((unsigned int *)__cil_tmp13);
2858#line 70
2859  if (! __cil_tmp14) {
2860    {
2861#line 71
2862    __cil_tmp15 = (unsigned long )pdev;
2863#line 71
2864    __cil_tmp16 = __cil_tmp15 + 144;
2865#line 71
2866    __cil_tmp17 = (struct device *)__cil_tmp16;
2867#line 71
2868    __cil_tmp18 = (struct device  const  *)__cil_tmp17;
2869#line 71
2870    dev_warn(__cil_tmp18, "No IRQ assigned to device: no support for interrupts?\n");
2871#line 73
2872    pci_disable_device(pdev);
2873    }
2874#line 74
2875    return (-19);
2876  } else {
2877
2878  }
2879  }
2880  {
2881#line 77
2882  tmp = pci_intx_mask_supported(pdev);
2883  }
2884#line 77
2885  if (tmp) {
2886
2887  } else {
2888#line 78
2889    err = -19;
2890#line 79
2891    goto err_alloc;
2892  }
2893  {
2894#line 82
2895  tmp___0 = kzalloc(536UL, 208U);
2896#line 82
2897  gdev = (struct uio_pci_generic_dev *)tmp___0;
2898  }
2899#line 83
2900  if (! gdev) {
2901#line 84
2902    err = -12;
2903#line 85
2904    goto err_alloc;
2905  } else {
2906
2907  }
2908  {
2909#line 88
2910  __cil_tmp19 = 0 + 8;
2911#line 88
2912  __cil_tmp20 = (unsigned long )gdev;
2913#line 88
2914  __cil_tmp21 = __cil_tmp20 + __cil_tmp19;
2915#line 88
2916  *((char const   **)__cil_tmp21) = "uio_pci_generic";
2917#line 89
2918  __cil_tmp22 = 0 + 16;
2919#line 89
2920  __cil_tmp23 = (unsigned long )gdev;
2921#line 89
2922  __cil_tmp24 = __cil_tmp23 + __cil_tmp22;
2923#line 89
2924  *((char const   **)__cil_tmp24) = "0.01.0";
2925#line 90
2926  __cil_tmp25 = 0 + 464;
2927#line 90
2928  __cil_tmp26 = (unsigned long )gdev;
2929#line 90
2930  __cil_tmp27 = __cil_tmp26 + __cil_tmp25;
2931#line 90
2932  __cil_tmp28 = (unsigned long )pdev;
2933#line 90
2934  __cil_tmp29 = __cil_tmp28 + 916;
2935#line 90
2936  __cil_tmp30 = *((unsigned int *)__cil_tmp29);
2937#line 90
2938  *((long *)__cil_tmp27) = (long )__cil_tmp30;
2939#line 91
2940  __cil_tmp31 = 0 + 472;
2941#line 91
2942  __cil_tmp32 = (unsigned long )gdev;
2943#line 91
2944  __cil_tmp33 = __cil_tmp32 + __cil_tmp31;
2945#line 91
2946  *((unsigned long *)__cil_tmp33) = 128UL;
2947#line 92
2948  __cil_tmp34 = 0 + 488;
2949#line 92
2950  __cil_tmp35 = (unsigned long )gdev;
2951#line 92
2952  __cil_tmp36 = __cil_tmp35 + __cil_tmp34;
2953#line 92
2954  *((irqreturn_t (**)(int irq , struct uio_info *dev_info ))__cil_tmp36) = & irqhandler;
2955#line 93
2956  __cil_tmp37 = (unsigned long )gdev;
2957#line 93
2958  __cil_tmp38 = __cil_tmp37 + 528;
2959#line 93
2960  *((struct pci_dev **)__cil_tmp38) = pdev;
2961#line 95
2962  __cil_tmp39 = (unsigned long )pdev;
2963#line 95
2964  __cil_tmp40 = __cil_tmp39 + 144;
2965#line 95
2966  __cil_tmp41 = (struct device *)__cil_tmp40;
2967#line 95
2968  __cil_tmp42 = (struct uio_info *)gdev;
2969#line 95
2970  tmp___1 = (int )__uio_register_device(& __this_module, __cil_tmp41, __cil_tmp42);
2971  }
2972#line 95
2973  if (tmp___1) {
2974#line 96
2975    goto err_register;
2976  } else {
2977
2978  }
2979  {
2980#line 97
2981  __cil_tmp43 = (void *)gdev;
2982#line 97
2983  pci_set_drvdata(pdev, __cil_tmp43);
2984  }
2985#line 99
2986  return (0);
2987  err_register: 
2988  {
2989#line 101
2990  __cil_tmp44 = (void const   *)gdev;
2991#line 101
2992  kfree(__cil_tmp44);
2993  }
2994  err_alloc: 
2995  {
2996#line 104
2997  pci_disable_device(pdev);
2998  }
2999#line 105
3000  return (err);
3001}
3002}
3003#line 108 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
3004static void remove(struct pci_dev *pdev ) 
3005{ struct uio_pci_generic_dev *gdev ;
3006  void *tmp ;
3007  struct uio_info *__cil_tmp4 ;
3008  void const   *__cil_tmp5 ;
3009
3010  {
3011  {
3012#line 110
3013  tmp = pci_get_drvdata(pdev);
3014#line 110
3015  gdev = (struct uio_pci_generic_dev *)tmp;
3016#line 112
3017  __cil_tmp4 = (struct uio_info *)gdev;
3018#line 112
3019  uio_unregister_device(__cil_tmp4);
3020#line 113
3021  pci_disable_device(pdev);
3022#line 114
3023  __cil_tmp5 = (void const   *)gdev;
3024#line 114
3025  kfree(__cil_tmp5);
3026  }
3027#line 115
3028  return;
3029}
3030}
3031#line 117 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
3032static struct pci_driver driver  = 
3033#line 117
3034     {{(struct list_head *)0, (struct list_head *)0}, "uio_pci_generic", (struct pci_device_id  const  *)((void *)0),
3035    & probe, & remove, (int (*)(struct pci_dev *dev , pm_message_t state ))0, (int (*)(struct pci_dev *dev ,
3036                                                                                       pm_message_t state ))0,
3037    (int (*)(struct pci_dev *dev ))0, (int (*)(struct pci_dev *dev ))0, (void (*)(struct pci_dev *dev ))0,
3038    (struct pci_error_handlers *)0, {(char const   *)0, (struct bus_type *)0, (struct module *)0,
3039                                     (char const   *)0, (_Bool)0, (struct of_device_id  const  *)0,
3040                                     (int (*)(struct device *dev ))0, (int (*)(struct device *dev ))0,
3041                                     (void (*)(struct device *dev ))0, (int (*)(struct device *dev ,
3042                                                                                pm_message_t state ))0,
3043                                     (int (*)(struct device *dev ))0, (struct attribute_group  const  **)0,
3044                                     (struct dev_pm_ops  const  *)0, (struct driver_private *)0},
3045    {{{{{{0U}}, 0U, 0U, (void *)0}}}, {(struct list_head *)0, (struct list_head *)0}}};
3046#line 124
3047static int init(void)  __attribute__((__section__(".init.text"), __no_instrument_function__)) ;
3048#line 124 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
3049static int init(void) 
3050{ int tmp ;
3051
3052  {
3053  {
3054#line 126
3055  printk("<6>Generic UIO driver for PCI 2.3 devices version: 0.01.0\n");
3056#line 127
3057  tmp = (int )__pci_register_driver(& driver, & __this_module, "uio_pci_generic");
3058  }
3059#line 127
3060  return (tmp);
3061}
3062}
3063#line 130
3064static void cleanup(void)  __attribute__((__section__(".exit.text"), __no_instrument_function__)) ;
3065#line 130 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
3066static void cleanup(void) 
3067{ 
3068
3069  {
3070  {
3071#line 132
3072  pci_unregister_driver(& driver);
3073  }
3074#line 133
3075  return;
3076}
3077}
3078#line 135 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
3079int init_module(void) 
3080{ int tmp ;
3081
3082  {
3083  {
3084#line 135
3085  tmp = init();
3086  }
3087#line 135
3088  return (tmp);
3089}
3090}
3091#line 136 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
3092void cleanup_module(void) 
3093{ 
3094
3095  {
3096  {
3097#line 136
3098  cleanup();
3099  }
3100#line 136
3101  return;
3102}
3103}
3104#line 138 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
3105static char const   __mod_version138[15]  __attribute__((__used__, __unused__, __section__(".modinfo"),
3106__aligned__(1)))  = 
3107#line 138
3108  {      (char const   )'v',      (char const   )'e',      (char const   )'r',      (char const   )'s', 
3109        (char const   )'i',      (char const   )'o',      (char const   )'n',      (char const   )'=', 
3110        (char const   )'0',      (char const   )'.',      (char const   )'0',      (char const   )'1', 
3111        (char const   )'.',      (char const   )'0',      (char const   )'\000'};
3112#line 139 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
3113static char const   __mod_license139[15]  __attribute__((__used__, __unused__, __section__(".modinfo"),
3114__aligned__(1)))  = 
3115#line 139
3116  {      (char const   )'l',      (char const   )'i',      (char const   )'c',      (char const   )'e', 
3117        (char const   )'n',      (char const   )'s',      (char const   )'e',      (char const   )'=', 
3118        (char const   )'G',      (char const   )'P',      (char const   )'L',      (char const   )' ', 
3119        (char const   )'v',      (char const   )'2',      (char const   )'\000'};
3120#line 140 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
3121static char const   __mod_author140[43]  __attribute__((__used__, __unused__, __section__(".modinfo"),
3122__aligned__(1)))  = 
3123#line 140
3124  {      (char const   )'a',      (char const   )'u',      (char const   )'t',      (char const   )'h', 
3125        (char const   )'o',      (char const   )'r',      (char const   )'=',      (char const   )'M', 
3126        (char const   )'i',      (char const   )'c',      (char const   )'h',      (char const   )'a', 
3127        (char const   )'e',      (char const   )'l',      (char const   )' ',      (char const   )'S', 
3128        (char const   )'.',      (char const   )' ',      (char const   )'T',      (char const   )'s', 
3129        (char const   )'i',      (char const   )'r',      (char const   )'k',      (char const   )'i', 
3130        (char const   )'n',      (char const   )' ',      (char const   )'<',      (char const   )'m', 
3131        (char const   )'s',      (char const   )'t',      (char const   )'@',      (char const   )'r', 
3132        (char const   )'e',      (char const   )'d',      (char const   )'h',      (char const   )'a', 
3133        (char const   )'t',      (char const   )'.',      (char const   )'c',      (char const   )'o', 
3134        (char const   )'m',      (char const   )'>',      (char const   )'\000'};
3135#line 141 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
3136static char const   __mod_description141[51]  __attribute__((__used__, __unused__,
3137__section__(".modinfo"), __aligned__(1)))  = 
3138#line 141
3139  {      (char const   )'d',      (char const   )'e',      (char const   )'s',      (char const   )'c', 
3140        (char const   )'r',      (char const   )'i',      (char const   )'p',      (char const   )'t', 
3141        (char const   )'i',      (char const   )'o',      (char const   )'n',      (char const   )'=', 
3142        (char const   )'G',      (char const   )'e',      (char const   )'n',      (char const   )'e', 
3143        (char const   )'r',      (char const   )'i',      (char const   )'c',      (char const   )' ', 
3144        (char const   )'U',      (char const   )'I',      (char const   )'O',      (char const   )' ', 
3145        (char const   )'d',      (char const   )'r',      (char const   )'i',      (char const   )'v', 
3146        (char const   )'e',      (char const   )'r',      (char const   )' ',      (char const   )'f', 
3147        (char const   )'o',      (char const   )'r',      (char const   )' ',      (char const   )'P', 
3148        (char const   )'C',      (char const   )'I',      (char const   )' ',      (char const   )'2', 
3149        (char const   )'.',      (char const   )'3',      (char const   )' ',      (char const   )'d', 
3150        (char const   )'e',      (char const   )'v',      (char const   )'i',      (char const   )'c', 
3151        (char const   )'e',      (char const   )'s',      (char const   )'\000'};
3152#line 159
3153void ldv_check_final_state(void) ;
3154#line 162
3155extern void ldv_check_return_value(int res ) ;
3156#line 165
3157extern void ldv_initialize(void) ;
3158#line 168
3159extern int __VERIFIER_nondet_int(void) ;
3160#line 171 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
3161int LDV_IN_INTERRUPT  ;
3162#line 192 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
3163static int res_probe_2  ;
3164#line 174 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
3165void main(void) 
3166{ struct pci_dev *var_group1 ;
3167  struct pci_device_id  const  *var_probe_2_p1 ;
3168  int tmp ;
3169  int ldv_s_driver_pci_driver ;
3170  int tmp___0 ;
3171  int tmp___1 ;
3172  int __cil_tmp7 ;
3173
3174  {
3175  {
3176#line 206
3177  LDV_IN_INTERRUPT = 1;
3178#line 215
3179  ldv_initialize();
3180#line 225
3181  tmp = init();
3182  }
3183#line 225
3184  if (tmp) {
3185#line 226
3186    goto ldv_final;
3187  } else {
3188
3189  }
3190#line 227
3191  ldv_s_driver_pci_driver = 0;
3192  {
3193#line 231
3194  while (1) {
3195    while_continue: /* CIL Label */ ;
3196    {
3197#line 231
3198    tmp___1 = __VERIFIER_nondet_int();
3199    }
3200#line 231
3201    if (tmp___1) {
3202
3203    } else {
3204      {
3205#line 231
3206      __cil_tmp7 = ldv_s_driver_pci_driver == 0;
3207#line 231
3208      if (! __cil_tmp7) {
3209
3210      } else {
3211#line 231
3212        goto while_break;
3213      }
3214      }
3215    }
3216    {
3217#line 235
3218    tmp___0 = __VERIFIER_nondet_int();
3219    }
3220#line 237
3221    if (tmp___0 == 0) {
3222#line 237
3223      goto case_0;
3224    } else
3225#line 260
3226    if (tmp___0 == 1) {
3227#line 260
3228      goto case_1;
3229    } else {
3230      {
3231#line 280
3232      goto switch_default;
3233#line 235
3234      if (0) {
3235        case_0: /* CIL Label */ 
3236#line 240
3237        if (ldv_s_driver_pci_driver == 0) {
3238          {
3239#line 249
3240          res_probe_2 = probe(var_group1, var_probe_2_p1);
3241#line 250
3242          ldv_check_return_value(res_probe_2);
3243          }
3244#line 251
3245          if (res_probe_2) {
3246#line 252
3247            goto ldv_module_exit;
3248          } else {
3249
3250          }
3251#line 253
3252          ldv_s_driver_pci_driver = 0;
3253        } else {
3254
3255        }
3256#line 259
3257        goto switch_break;
3258        case_1: /* CIL Label */ 
3259        {
3260#line 272
3261        remove(var_group1);
3262        }
3263#line 279
3264        goto switch_break;
3265        switch_default: /* CIL Label */ 
3266#line 280
3267        goto switch_break;
3268      } else {
3269        switch_break: /* CIL Label */ ;
3270      }
3271      }
3272    }
3273  }
3274  while_break: /* CIL Label */ ;
3275  }
3276  ldv_module_exit: 
3277  {
3278#line 296
3279  cleanup();
3280  }
3281  ldv_final: 
3282  {
3283#line 299
3284  ldv_check_final_state();
3285  }
3286#line 302
3287  return;
3288}
3289}
3290#line 5 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/engine-blast-assert.h"
3291void ldv_blast_assert(void) 
3292{ 
3293
3294  {
3295  ERROR: 
3296#line 6
3297  goto ERROR;
3298}
3299}
3300#line 6 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/engine-blast.h"
3301extern int __VERIFIER_nondet_int(void) ;
3302#line 19 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
3303int ldv_mutex  =    1;
3304#line 22 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
3305int __attribute__((__warn_unused_result__))  mutex_lock_interruptible(struct mutex *lock ) 
3306{ int nondetermined ;
3307
3308  {
3309#line 29
3310  if (ldv_mutex == 1) {
3311
3312  } else {
3313    {
3314#line 29
3315    ldv_blast_assert();
3316    }
3317  }
3318  {
3319#line 32
3320  nondetermined = __VERIFIER_nondet_int();
3321  }
3322#line 35
3323  if (nondetermined) {
3324#line 38
3325    ldv_mutex = 2;
3326#line 40
3327    return (0);
3328  } else {
3329#line 45
3330    return (-4);
3331  }
3332}
3333}
3334#line 50 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
3335int __attribute__((__warn_unused_result__))  mutex_lock_killable(struct mutex *lock ) 
3336{ int nondetermined ;
3337
3338  {
3339#line 57
3340  if (ldv_mutex == 1) {
3341
3342  } else {
3343    {
3344#line 57
3345    ldv_blast_assert();
3346    }
3347  }
3348  {
3349#line 60
3350  nondetermined = __VERIFIER_nondet_int();
3351  }
3352#line 63
3353  if (nondetermined) {
3354#line 66
3355    ldv_mutex = 2;
3356#line 68
3357    return (0);
3358  } else {
3359#line 73
3360    return (-4);
3361  }
3362}
3363}
3364#line 78 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
3365int atomic_dec_and_mutex_lock(atomic_t *cnt , struct mutex *lock ) 
3366{ int atomic_value_after_dec ;
3367
3368  {
3369#line 83
3370  if (ldv_mutex == 1) {
3371
3372  } else {
3373    {
3374#line 83
3375    ldv_blast_assert();
3376    }
3377  }
3378  {
3379#line 86
3380  atomic_value_after_dec = __VERIFIER_nondet_int();
3381  }
3382#line 89
3383  if (atomic_value_after_dec == 0) {
3384#line 92
3385    ldv_mutex = 2;
3386#line 94
3387    return (1);
3388  } else {
3389
3390  }
3391#line 98
3392  return (0);
3393}
3394}
3395#line 103 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
3396void mutex_lock(struct mutex *lock ) 
3397{ 
3398
3399  {
3400#line 108
3401  if (ldv_mutex == 1) {
3402
3403  } else {
3404    {
3405#line 108
3406    ldv_blast_assert();
3407    }
3408  }
3409#line 110
3410  ldv_mutex = 2;
3411#line 111
3412  return;
3413}
3414}
3415#line 114 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
3416int mutex_trylock(struct mutex *lock ) 
3417{ int nondetermined ;
3418
3419  {
3420#line 121
3421  if (ldv_mutex == 1) {
3422
3423  } else {
3424    {
3425#line 121
3426    ldv_blast_assert();
3427    }
3428  }
3429  {
3430#line 124
3431  nondetermined = __VERIFIER_nondet_int();
3432  }
3433#line 127
3434  if (nondetermined) {
3435#line 130
3436    ldv_mutex = 2;
3437#line 132
3438    return (1);
3439  } else {
3440#line 137
3441    return (0);
3442  }
3443}
3444}
3445#line 142 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
3446void mutex_unlock(struct mutex *lock ) 
3447{ 
3448
3449  {
3450#line 147
3451  if (ldv_mutex == 2) {
3452
3453  } else {
3454    {
3455#line 147
3456    ldv_blast_assert();
3457    }
3458  }
3459#line 149
3460  ldv_mutex = 1;
3461#line 150
3462  return;
3463}
3464}
3465#line 153 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/kernel-rules/files/model0032.c"
3466void ldv_check_final_state(void) 
3467{ 
3468
3469  {
3470#line 156
3471  if (ldv_mutex == 1) {
3472
3473  } else {
3474    {
3475#line 156
3476    ldv_blast_assert();
3477    }
3478  }
3479#line 157
3480  return;
3481}
3482}
3483#line 311 "/home/zakharov/launch/work/current--X--drivers/--X--defaultlinux-3.4--X--32_1--X--cpachecker/linux-3.4/csd_deg_dscv/12549/dscv_tempdir/dscv/ri/32_1/drivers/uio/uio_pci_generic.c.common.c"
3484long s__builtin_expect(long val , long res ) 
3485{ 
3486
3487  {
3488#line 312
3489  return (val);
3490}
3491}