This file is indexed.

/usr/include/freehdl/kernel-resolver-descriptor.hh is in libfreehdl0-dev 0.0.7-1.1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#ifndef KERNEL_RESOLVER_DESCRIPTOR_H
#define KERNEL_RESOLVER_DESCRIPTOR_H

#include <freehdl/kernel-driver-info.hh>
#include <freehdl/std-vhdl-types.hh>

/* *************************************************************
 *  Further definitions required for signal resolution
 * ************************************************************* */

// The following template function is used to generate a wrapper
// function for the actual user defined resolution function. This
// mechanism is necessary because the kernel does not know anything
// about user defines types. Hence, he cannot call the user defined
// reolution function directly. Instead, each time a resolved type is
// created an appropriate pointer to a "resolver handle" function is
// generated (which uses only simple parameter types and no return
// type; hence, it can be called by the kernel) and passed over to the
// kernel. The kernel uses this handler to execute the resolver
// function indirectly. T is the type to be resolved while F points to
// the user defined resolution function.
template<class T, T (*F)(const array_type<T >&, array_info&) >
void resolver_handler(void *result, driver_info *driver, array_base *array, array_info *unc_ainfo)
{
  *(T*)result = (*F)(*(array_type<T >*)array, *unc_ainfo);
  driver->transport_assign(*(T*)result, zero_time);
}

// Similar to the previous template but the actual resolution function
// takes only a single argument. Both templates are required as some
// resolution function will actually take one and some other two
// arguments (the second arguments is actually an internal parameter
// to the function which is not specified in the VHDL source).
template<class T, T (*F)(const array_type<T >&) >
void resolver_handler(void *result, driver_info *driver, array_base *array, array_info *unc_ainfo)
{
  *(T*)result = (*F)(*(array_type<T >*)array);
  driver->transport_assign(*(T*)result, zero_time);
}




#ifdef KERNEL
/* ****************************************************************
 * These definitions are required by the kernel only
 * **************************************************************** */

#include <map>
#include <freehdl/kernel-db.hh>

struct resolver_descriptor {
  // Points to the wrapper function used by the kernel to call the
  // resolver.
  resolver_handler_p handler;
  // Points to the array_info instance describing the driver array
  type_info_interface *ainfo;
  // States whether the resolver function must be called for a single
  // driver. When ideal = true then it must be used only if more than
  // one driver is present.
  bool ideal;
 
  resolver_descriptor() : handler(NULL), ainfo(NULL) {};
 
  resolver_descriptor(resolver_handler_p h, type_info_interface *a, bool id) :
    handler(h), ainfo(a), ideal(id) { 
    // Increase reference counter so that the type_info insstance is
    // not removed.
    if (a != NULL)
      a->add_ref(); 
  };
 
  resolver_descriptor(const resolver_descriptor &d) : 
    handler(d.handler), ainfo(d.ainfo), ideal(d.ideal) {
    // Increase reference counter so that the type_info insstance is
    // not removed.
    if (ainfo != NULL)
      ainfo->add_ref();
  }

  ~resolver_descriptor() {
    // Decrease reference counter to enable type_info removing (if not
    // used somewhere else)
    if (ainfo != NULL)
      ainfo->remove_ref();
  }
};


// Generate an entry type for the kernel database. The entries are
// associated with type_info_interface pointers.
define_db_entry_type (resolver_descriptor, resolver_map);


#endif
#endif