You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					1036 lines
				
				30 KiB
			
		
		
			
		
	
	
					1036 lines
				
				30 KiB
			| 
											5 days ago
										 | # type: ignore
 | ||
|  | # -*- coding: utf-8 -*-
 | ||
|  | #
 | ||
|  | # TARGET arch is: []
 | ||
|  | # WORD_SIZE is: 8
 | ||
|  | # POINTER_SIZE is: 8
 | ||
|  | # LONGDOUBLE_SIZE is: 16
 | ||
|  | #
 | ||
|  | import ctypes
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class AsDictMixin:
 | ||
|  |     @classmethod
 | ||
|  |     def as_dict(cls, self):
 | ||
|  |         result = {}
 | ||
|  |         if not isinstance(self, AsDictMixin):
 | ||
|  |             # not a structure, assume it's already a python object
 | ||
|  |             return self
 | ||
|  |         if not hasattr(cls, "_fields_"):
 | ||
|  |             return result
 | ||
|  |         # sys.version_info >= (3, 5)
 | ||
|  |         # for (field, *_) in cls._fields_:  # noqa
 | ||
|  |         for field_tuple in cls._fields_:  # noqa
 | ||
|  |             field = field_tuple[0]
 | ||
|  |             if field.startswith('PADDING_'):
 | ||
|  |                 continue
 | ||
|  |             value = getattr(self, field)
 | ||
|  |             type_ = type(value)
 | ||
|  |             if hasattr(value, "_length_") and hasattr(value, "_type_"):
 | ||
|  |                 # array
 | ||
|  |                 if not hasattr(type_, "as_dict"):
 | ||
|  |                     value = [v for v in value]
 | ||
|  |                 else:
 | ||
|  |                     type_ = type_._type_
 | ||
|  |                     value = [type_.as_dict(v) for v in value]
 | ||
|  |             elif hasattr(value, "contents") and hasattr(value, "_type_"):
 | ||
|  |                 # pointer
 | ||
|  |                 try:
 | ||
|  |                     if not hasattr(type_, "as_dict"):
 | ||
|  |                         value = value.contents
 | ||
|  |                     else:
 | ||
|  |                         type_ = type_._type_
 | ||
|  |                         value = type_.as_dict(value.contents)
 | ||
|  |                 except ValueError:
 | ||
|  |                     # nullptr
 | ||
|  |                     value = None
 | ||
|  |             elif isinstance(value, AsDictMixin):
 | ||
|  |                 # other structure
 | ||
|  |                 value = type_.as_dict(value)
 | ||
|  |             result[field] = value
 | ||
|  |         return result
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class Structure(ctypes.Structure, AsDictMixin):
 | ||
|  | 
 | ||
|  |     def __init__(self, *args, **kwds):
 | ||
|  |         # We don't want to use positional arguments fill PADDING_* fields
 | ||
|  | 
 | ||
|  |         args = dict(zip(self.__class__._field_names_(), args))
 | ||
|  |         args.update(kwds)
 | ||
|  |         super(Structure, self).__init__(**args)
 | ||
|  | 
 | ||
|  |     @classmethod
 | ||
|  |     def _field_names_(cls):
 | ||
|  |         if hasattr(cls, '_fields_'):
 | ||
|  |             return (f[0] for f in cls._fields_ if not f[0].startswith('PADDING'))
 | ||
|  |         else:
 | ||
|  |             return ()
 | ||
|  | 
 | ||
|  |     @classmethod
 | ||
|  |     def get_type(cls, field):
 | ||
|  |         for f in cls._fields_:
 | ||
|  |             if f[0] == field:
 | ||
|  |                 return f[1]
 | ||
|  |         return None
 | ||
|  | 
 | ||
|  |     @classmethod
 | ||
|  |     def bind(cls, bound_fields):
 | ||
|  |         fields = {}
 | ||
|  |         for name, type_ in cls._fields_:
 | ||
|  |             if hasattr(type_, "restype"):
 | ||
|  |                 if name in bound_fields:
 | ||
|  |                     if bound_fields[name] is None:
 | ||
|  |                         fields[name] = type_()
 | ||
|  |                     else:
 | ||
|  |                         # use a closure to capture the callback from the loop scope
 | ||
|  |                         fields[name] = (
 | ||
|  |                             type_((lambda callback: lambda *args: callback(*args))(
 | ||
|  |                                 bound_fields[name]))
 | ||
|  |                         )
 | ||
|  |                     del bound_fields[name]
 | ||
|  |                 else:
 | ||
|  |                     # default callback implementation (does nothing)
 | ||
|  |                     try:
 | ||
|  |                         default_ = type_(0).restype().value
 | ||
|  |                     except TypeError:
 | ||
|  |                         default_ = None
 | ||
|  |                     fields[name] = type_((
 | ||
|  |                         lambda default_: lambda *args: default_)(default_))
 | ||
|  |             else:
 | ||
|  |                 # not a callback function, use default initialization
 | ||
|  |                 if name in bound_fields:
 | ||
|  |                     fields[name] = bound_fields[name]
 | ||
|  |                     del bound_fields[name]
 | ||
|  |                 else:
 | ||
|  |                     fields[name] = type_()
 | ||
|  |         if len(bound_fields) != 0:
 | ||
|  |             raise ValueError(
 | ||
|  |                 "Cannot bind the following unknown callback(s) {}.{}".format(
 | ||
|  |                     cls.__name__, bound_fields.keys()
 | ||
|  |             ))
 | ||
|  |         return cls(**fields)
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class Union(ctypes.Union, AsDictMixin):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | c_int128 = ctypes.c_ubyte*16
 | ||
|  | c_uint128 = c_int128
 | ||
|  | void = None
 | ||
|  | if ctypes.sizeof(ctypes.c_longdouble) == 16:
 | ||
|  |     c_long_double_t = ctypes.c_longdouble
 | ||
|  | else:
 | ||
|  |     c_long_double_t = ctypes.c_ubyte*16
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | # values for enumeration 'kgsl_user_mem_type'
 | ||
|  | kgsl_user_mem_type__enumvalues = {
 | ||
|  |     0: 'KGSL_USER_MEM_TYPE_PMEM',
 | ||
|  |     1: 'KGSL_USER_MEM_TYPE_ASHMEM',
 | ||
|  |     2: 'KGSL_USER_MEM_TYPE_ADDR',
 | ||
|  |     3: 'KGSL_USER_MEM_TYPE_ION',
 | ||
|  |     3: 'KGSL_USER_MEM_TYPE_DMABUF',
 | ||
|  |     7: 'KGSL_USER_MEM_TYPE_MAX',
 | ||
|  | }
 | ||
|  | KGSL_USER_MEM_TYPE_PMEM = 0
 | ||
|  | KGSL_USER_MEM_TYPE_ASHMEM = 1
 | ||
|  | KGSL_USER_MEM_TYPE_ADDR = 2
 | ||
|  | KGSL_USER_MEM_TYPE_ION = 3
 | ||
|  | KGSL_USER_MEM_TYPE_DMABUF = 3
 | ||
|  | KGSL_USER_MEM_TYPE_MAX = 7
 | ||
|  | kgsl_user_mem_type = ctypes.c_uint32 # enum
 | ||
|  | 
 | ||
|  | # values for enumeration 'kgsl_ctx_reset_stat'
 | ||
|  | kgsl_ctx_reset_stat__enumvalues = {
 | ||
|  |     0: 'KGSL_CTX_STAT_NO_ERROR',
 | ||
|  |     1: 'KGSL_CTX_STAT_GUILTY_CONTEXT_RESET_EXT',
 | ||
|  |     2: 'KGSL_CTX_STAT_INNOCENT_CONTEXT_RESET_EXT',
 | ||
|  |     3: 'KGSL_CTX_STAT_UNKNOWN_CONTEXT_RESET_EXT',
 | ||
|  | }
 | ||
|  | KGSL_CTX_STAT_NO_ERROR = 0
 | ||
|  | KGSL_CTX_STAT_GUILTY_CONTEXT_RESET_EXT = 1
 | ||
|  | KGSL_CTX_STAT_INNOCENT_CONTEXT_RESET_EXT = 2
 | ||
|  | KGSL_CTX_STAT_UNKNOWN_CONTEXT_RESET_EXT = 3
 | ||
|  | kgsl_ctx_reset_stat = ctypes.c_uint32 # enum
 | ||
|  | 
 | ||
|  | # values for enumeration 'kgsl_deviceid'
 | ||
|  | kgsl_deviceid__enumvalues = {
 | ||
|  |     0: 'KGSL_DEVICE_3D0',
 | ||
|  |     1: 'KGSL_DEVICE_MAX',
 | ||
|  | }
 | ||
|  | KGSL_DEVICE_3D0 = 0
 | ||
|  | KGSL_DEVICE_MAX = 1
 | ||
|  | kgsl_deviceid = ctypes.c_uint32 # enum
 | ||
|  | class struct_kgsl_devinfo(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_devinfo._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_devinfo._fields_ = [
 | ||
|  |     ('device_id', ctypes.c_uint32),
 | ||
|  |     ('chip_id', ctypes.c_uint32),
 | ||
|  |     ('mmu_enabled', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  |     ('gmem_gpubaseaddr', ctypes.c_uint64),
 | ||
|  |     ('gpu_id', ctypes.c_uint32),
 | ||
|  |     ('PADDING_1', ctypes.c_ubyte * 4),
 | ||
|  |     ('gmem_sizebytes', ctypes.c_uint64),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_devmemstore(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_devmemstore._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_devmemstore._fields_ = [
 | ||
|  |     ('soptimestamp', ctypes.c_uint32),
 | ||
|  |     ('sbz', ctypes.c_uint32),
 | ||
|  |     ('eoptimestamp', ctypes.c_uint32),
 | ||
|  |     ('sbz2', ctypes.c_uint32),
 | ||
|  |     ('preempted', ctypes.c_uint32),
 | ||
|  |     ('sbz3', ctypes.c_uint32),
 | ||
|  |     ('ref_wait_ts', ctypes.c_uint32),
 | ||
|  |     ('sbz4', ctypes.c_uint32),
 | ||
|  |     ('current_context', ctypes.c_uint32),
 | ||
|  |     ('sbz5', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | 
 | ||
|  | # values for enumeration 'kgsl_timestamp_type'
 | ||
|  | kgsl_timestamp_type__enumvalues = {
 | ||
|  |     1: 'KGSL_TIMESTAMP_CONSUMED',
 | ||
|  |     2: 'KGSL_TIMESTAMP_RETIRED',
 | ||
|  |     3: 'KGSL_TIMESTAMP_QUEUED',
 | ||
|  | }
 | ||
|  | KGSL_TIMESTAMP_CONSUMED = 1
 | ||
|  | KGSL_TIMESTAMP_RETIRED = 2
 | ||
|  | KGSL_TIMESTAMP_QUEUED = 3
 | ||
|  | kgsl_timestamp_type = ctypes.c_uint32 # enum
 | ||
|  | class struct_kgsl_shadowprop(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_shadowprop._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_shadowprop._fields_ = [
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('size', ctypes.c_uint64),
 | ||
|  |     ('flags', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_version(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_version._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_version._fields_ = [
 | ||
|  |     ('drv_major', ctypes.c_uint32),
 | ||
|  |     ('drv_minor', ctypes.c_uint32),
 | ||
|  |     ('dev_major', ctypes.c_uint32),
 | ||
|  |     ('dev_minor', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_sp_generic_mem(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_sp_generic_mem._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_sp_generic_mem._fields_ = [
 | ||
|  |     ('local', ctypes.c_uint64),
 | ||
|  |     ('pvt', ctypes.c_uint64),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_ucode_version(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_ucode_version._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_ucode_version._fields_ = [
 | ||
|  |     ('pfp', ctypes.c_uint32),
 | ||
|  |     ('pm4', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpmu_version(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpmu_version._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpmu_version._fields_ = [
 | ||
|  |     ('major', ctypes.c_uint32),
 | ||
|  |     ('minor', ctypes.c_uint32),
 | ||
|  |     ('features', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_ibdesc(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_ibdesc._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_ibdesc._fields_ = [
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('__pad', ctypes.c_uint64),
 | ||
|  |     ('sizedwords', ctypes.c_uint64),
 | ||
|  |     ('ctrl', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_cmdbatch_profiling_buffer(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_cmdbatch_profiling_buffer._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_cmdbatch_profiling_buffer._fields_ = [
 | ||
|  |     ('wall_clock_s', ctypes.c_uint64),
 | ||
|  |     ('wall_clock_ns', ctypes.c_uint64),
 | ||
|  |     ('gpu_ticks_queued', ctypes.c_uint64),
 | ||
|  |     ('gpu_ticks_submitted', ctypes.c_uint64),
 | ||
|  |     ('gpu_ticks_retired', ctypes.c_uint64),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_device_getproperty(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_device_getproperty._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_device_getproperty._fields_ = [
 | ||
|  |     ('type', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  |     ('value', ctypes.POINTER(None)),
 | ||
|  |     ('sizebytes', ctypes.c_uint64),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_device_waittimestamp(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_device_waittimestamp._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_device_waittimestamp._fields_ = [
 | ||
|  |     ('timestamp', ctypes.c_uint32),
 | ||
|  |     ('timeout', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_device_waittimestamp_ctxtid(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_device_waittimestamp_ctxtid._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_device_waittimestamp_ctxtid._fields_ = [
 | ||
|  |     ('context_id', ctypes.c_uint32),
 | ||
|  |     ('timestamp', ctypes.c_uint32),
 | ||
|  |     ('timeout', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_ringbuffer_issueibcmds(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_ringbuffer_issueibcmds._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_ringbuffer_issueibcmds._fields_ = [
 | ||
|  |     ('drawctxt_id', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  |     ('ibdesc_addr', ctypes.c_uint64),
 | ||
|  |     ('numibs', ctypes.c_uint32),
 | ||
|  |     ('timestamp', ctypes.c_uint32),
 | ||
|  |     ('flags', ctypes.c_uint32),
 | ||
|  |     ('PADDING_1', ctypes.c_ubyte * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_cmdstream_readtimestamp(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_cmdstream_readtimestamp._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_cmdstream_readtimestamp._fields_ = [
 | ||
|  |     ('type', ctypes.c_uint32),
 | ||
|  |     ('timestamp', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_cmdstream_freememontimestamp(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_cmdstream_freememontimestamp._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_cmdstream_freememontimestamp._fields_ = [
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('type', ctypes.c_uint32),
 | ||
|  |     ('timestamp', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_drawctxt_create(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_drawctxt_create._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_drawctxt_create._fields_ = [
 | ||
|  |     ('flags', ctypes.c_uint32),
 | ||
|  |     ('drawctxt_id', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_drawctxt_destroy(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_drawctxt_destroy._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_drawctxt_destroy._fields_ = [
 | ||
|  |     ('drawctxt_id', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_map_user_mem(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_map_user_mem._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_map_user_mem._fields_ = [
 | ||
|  |     ('fd', ctypes.c_int32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('len', ctypes.c_uint64),
 | ||
|  |     ('offset', ctypes.c_uint64),
 | ||
|  |     ('hostptr', ctypes.c_uint64),
 | ||
|  |     ('memtype', kgsl_user_mem_type),
 | ||
|  |     ('flags', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_cmdstream_readtimestamp_ctxtid(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_cmdstream_readtimestamp_ctxtid._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_cmdstream_readtimestamp_ctxtid._fields_ = [
 | ||
|  |     ('context_id', ctypes.c_uint32),
 | ||
|  |     ('type', ctypes.c_uint32),
 | ||
|  |     ('timestamp', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_cmdstream_freememontimestamp_ctxtid(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_cmdstream_freememontimestamp_ctxtid._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_cmdstream_freememontimestamp_ctxtid._fields_ = [
 | ||
|  |     ('context_id', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('type', ctypes.c_uint32),
 | ||
|  |     ('timestamp', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_sharedmem_from_pmem(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_sharedmem_from_pmem._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_sharedmem_from_pmem._fields_ = [
 | ||
|  |     ('pmem_fd', ctypes.c_int32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('len', ctypes.c_uint32),
 | ||
|  |     ('offset', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_sharedmem_free(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_sharedmem_free._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_sharedmem_free._fields_ = [
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_cff_user_event(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_cff_user_event._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_cff_user_event._fields_ = [
 | ||
|  |     ('cff_opcode', ctypes.c_ubyte),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 3),
 | ||
|  |     ('op1', ctypes.c_uint32),
 | ||
|  |     ('op2', ctypes.c_uint32),
 | ||
|  |     ('op3', ctypes.c_uint32),
 | ||
|  |     ('op4', ctypes.c_uint32),
 | ||
|  |     ('op5', ctypes.c_uint32),
 | ||
|  |     ('__pad', ctypes.c_uint32 * 2),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gmem_desc(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gmem_desc._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gmem_desc._fields_ = [
 | ||
|  |     ('x', ctypes.c_uint32),
 | ||
|  |     ('y', ctypes.c_uint32),
 | ||
|  |     ('width', ctypes.c_uint32),
 | ||
|  |     ('height', ctypes.c_uint32),
 | ||
|  |     ('pitch', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_buffer_desc(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_buffer_desc._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_buffer_desc._fields_ = [
 | ||
|  |     ('hostptr', ctypes.POINTER(None)),
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('size', ctypes.c_int32),
 | ||
|  |     ('format', ctypes.c_uint32),
 | ||
|  |     ('pitch', ctypes.c_uint32),
 | ||
|  |     ('enabled', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_bind_gmem_shadow(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_bind_gmem_shadow._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_bind_gmem_shadow._fields_ = [
 | ||
|  |     ('drawctxt_id', ctypes.c_uint32),
 | ||
|  |     ('gmem_desc', struct_kgsl_gmem_desc),
 | ||
|  |     ('shadow_x', ctypes.c_uint32),
 | ||
|  |     ('shadow_y', ctypes.c_uint32),
 | ||
|  |     ('shadow_buffer', struct_kgsl_buffer_desc),
 | ||
|  |     ('buffer_id', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_sharedmem_from_vmalloc(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_sharedmem_from_vmalloc._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_sharedmem_from_vmalloc._fields_ = [
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('hostptr', ctypes.c_uint32),
 | ||
|  |     ('flags', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_drawctxt_set_bin_base_offset(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_drawctxt_set_bin_base_offset._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_drawctxt_set_bin_base_offset._fields_ = [
 | ||
|  |     ('drawctxt_id', ctypes.c_uint32),
 | ||
|  |     ('offset', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | 
 | ||
|  | # values for enumeration 'kgsl_cmdwindow_type'
 | ||
|  | kgsl_cmdwindow_type__enumvalues = {
 | ||
|  |     0: 'KGSL_CMDWINDOW_MIN',
 | ||
|  |     0: 'KGSL_CMDWINDOW_2D',
 | ||
|  |     1: 'KGSL_CMDWINDOW_3D',
 | ||
|  |     2: 'KGSL_CMDWINDOW_MMU',
 | ||
|  |     255: 'KGSL_CMDWINDOW_ARBITER',
 | ||
|  |     255: 'KGSL_CMDWINDOW_MAX',
 | ||
|  | }
 | ||
|  | KGSL_CMDWINDOW_MIN = 0
 | ||
|  | KGSL_CMDWINDOW_2D = 0
 | ||
|  | KGSL_CMDWINDOW_3D = 1
 | ||
|  | KGSL_CMDWINDOW_MMU = 2
 | ||
|  | KGSL_CMDWINDOW_ARBITER = 255
 | ||
|  | KGSL_CMDWINDOW_MAX = 255
 | ||
|  | kgsl_cmdwindow_type = ctypes.c_uint32 # enum
 | ||
|  | class struct_kgsl_cmdwindow_write(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_cmdwindow_write._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_cmdwindow_write._fields_ = [
 | ||
|  |     ('target', kgsl_cmdwindow_type),
 | ||
|  |     ('addr', ctypes.c_uint32),
 | ||
|  |     ('data', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpumem_alloc(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpumem_alloc._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpumem_alloc._fields_ = [
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('size', ctypes.c_uint64),
 | ||
|  |     ('flags', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_cff_syncmem(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_cff_syncmem._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_cff_syncmem._fields_ = [
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('len', ctypes.c_uint64),
 | ||
|  |     ('__pad', ctypes.c_uint32 * 2),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_timestamp_event(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_timestamp_event._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_timestamp_event._fields_ = [
 | ||
|  |     ('type', ctypes.c_int32),
 | ||
|  |     ('timestamp', ctypes.c_uint32),
 | ||
|  |     ('context_id', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  |     ('priv', ctypes.POINTER(None)),
 | ||
|  |     ('len', ctypes.c_uint64),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_timestamp_event_genlock(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_timestamp_event_genlock._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_timestamp_event_genlock._fields_ = [
 | ||
|  |     ('handle', ctypes.c_int32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_timestamp_event_fence(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_timestamp_event_fence._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_timestamp_event_fence._fields_ = [
 | ||
|  |     ('fence_fd', ctypes.c_int32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpumem_alloc_id(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpumem_alloc_id._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpumem_alloc_id._fields_ = [
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  |     ('flags', ctypes.c_uint32),
 | ||
|  |     ('size', ctypes.c_uint64),
 | ||
|  |     ('mmapsize', ctypes.c_uint64),
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('__pad', ctypes.c_uint64 * 2),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpumem_free_id(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpumem_free_id._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpumem_free_id._fields_ = [
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  |     ('__pad', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpumem_get_info(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpumem_get_info._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpumem_get_info._fields_ = [
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  |     ('flags', ctypes.c_uint32),
 | ||
|  |     ('size', ctypes.c_uint64),
 | ||
|  |     ('mmapsize', ctypes.c_uint64),
 | ||
|  |     ('useraddr', ctypes.c_uint64),
 | ||
|  |     ('__pad', ctypes.c_uint64 * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpumem_sync_cache(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpumem_sync_cache._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpumem_sync_cache._fields_ = [
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  |     ('op', ctypes.c_uint32),
 | ||
|  |     ('offset', ctypes.c_uint64),
 | ||
|  |     ('length', ctypes.c_uint64),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_perfcounter_get(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_perfcounter_get._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_perfcounter_get._fields_ = [
 | ||
|  |     ('groupid', ctypes.c_uint32),
 | ||
|  |     ('countable', ctypes.c_uint32),
 | ||
|  |     ('offset', ctypes.c_uint32),
 | ||
|  |     ('offset_hi', ctypes.c_uint32),
 | ||
|  |     ('__pad', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_perfcounter_put(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_perfcounter_put._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_perfcounter_put._fields_ = [
 | ||
|  |     ('groupid', ctypes.c_uint32),
 | ||
|  |     ('countable', ctypes.c_uint32),
 | ||
|  |     ('__pad', ctypes.c_uint32 * 2),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_perfcounter_query(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_perfcounter_query._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_perfcounter_query._fields_ = [
 | ||
|  |     ('groupid', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  |     ('countables', ctypes.POINTER(ctypes.c_uint32)),
 | ||
|  |     ('count', ctypes.c_uint32),
 | ||
|  |     ('max_counters', ctypes.c_uint32),
 | ||
|  |     ('__pad', ctypes.c_uint32 * 2),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_perfcounter_read_group(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_perfcounter_read_group._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_perfcounter_read_group._fields_ = [
 | ||
|  |     ('groupid', ctypes.c_uint32),
 | ||
|  |     ('countable', ctypes.c_uint32),
 | ||
|  |     ('value', ctypes.c_uint64),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_perfcounter_read(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_perfcounter_read._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_perfcounter_read._fields_ = [
 | ||
|  |     ('reads', ctypes.POINTER(struct_kgsl_perfcounter_read_group)),
 | ||
|  |     ('count', ctypes.c_uint32),
 | ||
|  |     ('__pad', ctypes.c_uint32 * 2),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpumem_sync_cache_bulk(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpumem_sync_cache_bulk._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpumem_sync_cache_bulk._fields_ = [
 | ||
|  |     ('id_list', ctypes.POINTER(ctypes.c_uint32)),
 | ||
|  |     ('count', ctypes.c_uint32),
 | ||
|  |     ('op', ctypes.c_uint32),
 | ||
|  |     ('__pad', ctypes.c_uint32 * 2),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_cmd_syncpoint_timestamp(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_cmd_syncpoint_timestamp._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_cmd_syncpoint_timestamp._fields_ = [
 | ||
|  |     ('context_id', ctypes.c_uint32),
 | ||
|  |     ('timestamp', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_cmd_syncpoint_fence(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_cmd_syncpoint_fence._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_cmd_syncpoint_fence._fields_ = [
 | ||
|  |     ('fd', ctypes.c_int32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_cmd_syncpoint(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_cmd_syncpoint._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_cmd_syncpoint._fields_ = [
 | ||
|  |     ('type', ctypes.c_int32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  |     ('priv', ctypes.POINTER(None)),
 | ||
|  |     ('size', ctypes.c_uint64),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_submit_commands(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_submit_commands._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_submit_commands._fields_ = [
 | ||
|  |     ('context_id', ctypes.c_uint32),
 | ||
|  |     ('flags', ctypes.c_uint32),
 | ||
|  |     ('cmdlist', ctypes.POINTER(struct_kgsl_ibdesc)),
 | ||
|  |     ('numcmds', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  |     ('synclist', ctypes.POINTER(struct_kgsl_cmd_syncpoint)),
 | ||
|  |     ('numsyncs', ctypes.c_uint32),
 | ||
|  |     ('timestamp', ctypes.c_uint32),
 | ||
|  |     ('__pad', ctypes.c_uint32 * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_device_constraint(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_device_constraint._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_device_constraint._fields_ = [
 | ||
|  |     ('type', ctypes.c_uint32),
 | ||
|  |     ('context_id', ctypes.c_uint32),
 | ||
|  |     ('data', ctypes.POINTER(None)),
 | ||
|  |     ('size', ctypes.c_uint64),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_device_constraint_pwrlevel(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_device_constraint_pwrlevel._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_device_constraint_pwrlevel._fields_ = [
 | ||
|  |     ('level', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_syncsource_create(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_syncsource_create._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_syncsource_create._fields_ = [
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  |     ('__pad', ctypes.c_uint32 * 3),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_syncsource_destroy(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_syncsource_destroy._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_syncsource_destroy._fields_ = [
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  |     ('__pad', ctypes.c_uint32 * 3),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_syncsource_create_fence(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_syncsource_create_fence._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_syncsource_create_fence._fields_ = [
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  |     ('fence_fd', ctypes.c_int32),
 | ||
|  |     ('__pad', ctypes.c_uint32 * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_syncsource_signal_fence(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_syncsource_signal_fence._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_syncsource_signal_fence._fields_ = [
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  |     ('fence_fd', ctypes.c_int32),
 | ||
|  |     ('__pad', ctypes.c_uint32 * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_cff_sync_gpuobj(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_cff_sync_gpuobj._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_cff_sync_gpuobj._fields_ = [
 | ||
|  |     ('offset', ctypes.c_uint64),
 | ||
|  |     ('length', ctypes.c_uint64),
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpuobj_alloc(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpuobj_alloc._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpuobj_alloc._fields_ = [
 | ||
|  |     ('size', ctypes.c_uint64),
 | ||
|  |     ('flags', ctypes.c_uint64),
 | ||
|  |     ('va_len', ctypes.c_uint64),
 | ||
|  |     ('mmapsize', ctypes.c_uint64),
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  |     ('metadata_len', ctypes.c_uint32),
 | ||
|  |     ('metadata', ctypes.c_uint64),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpuobj_free(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpuobj_free._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpuobj_free._fields_ = [
 | ||
|  |     ('flags', ctypes.c_uint64),
 | ||
|  |     ('priv', ctypes.c_uint64),
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  |     ('type', ctypes.c_uint32),
 | ||
|  |     ('len', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpu_event_timestamp(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpu_event_timestamp._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpu_event_timestamp._fields_ = [
 | ||
|  |     ('context_id', ctypes.c_uint32),
 | ||
|  |     ('timestamp', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpu_event_fence(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpu_event_fence._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpu_event_fence._fields_ = [
 | ||
|  |     ('fd', ctypes.c_int32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpuobj_info(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpuobj_info._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpuobj_info._fields_ = [
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('flags', ctypes.c_uint64),
 | ||
|  |     ('size', ctypes.c_uint64),
 | ||
|  |     ('va_len', ctypes.c_uint64),
 | ||
|  |     ('va_addr', ctypes.c_uint64),
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpuobj_import(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpuobj_import._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpuobj_import._fields_ = [
 | ||
|  |     ('priv', ctypes.c_uint64),
 | ||
|  |     ('priv_len', ctypes.c_uint64),
 | ||
|  |     ('flags', ctypes.c_uint64),
 | ||
|  |     ('type', ctypes.c_uint32),
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpuobj_import_dma_buf(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpuobj_import_dma_buf._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpuobj_import_dma_buf._fields_ = [
 | ||
|  |     ('fd', ctypes.c_int32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpuobj_import_useraddr(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpuobj_import_useraddr._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpuobj_import_useraddr._fields_ = [
 | ||
|  |     ('virtaddr', ctypes.c_uint64),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpuobj_sync_obj(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpuobj_sync_obj._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpuobj_sync_obj._fields_ = [
 | ||
|  |     ('offset', ctypes.c_uint64),
 | ||
|  |     ('length', ctypes.c_uint64),
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  |     ('op', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpuobj_sync(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpuobj_sync._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpuobj_sync._fields_ = [
 | ||
|  |     ('objs', ctypes.c_uint64),
 | ||
|  |     ('obj_len', ctypes.c_uint32),
 | ||
|  |     ('count', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_command_object(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_command_object._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_command_object._fields_ = [
 | ||
|  |     ('offset', ctypes.c_uint64),
 | ||
|  |     ('gpuaddr', ctypes.c_uint64),
 | ||
|  |     ('size', ctypes.c_uint64),
 | ||
|  |     ('flags', ctypes.c_uint32),
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_command_syncpoint(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_command_syncpoint._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_command_syncpoint._fields_ = [
 | ||
|  |     ('priv', ctypes.c_uint64),
 | ||
|  |     ('size', ctypes.c_uint64),
 | ||
|  |     ('type', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpu_command(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpu_command._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpu_command._fields_ = [
 | ||
|  |     ('flags', ctypes.c_uint64),
 | ||
|  |     ('cmdlist', ctypes.c_uint64),
 | ||
|  |     ('cmdsize', ctypes.c_uint32),
 | ||
|  |     ('numcmds', ctypes.c_uint32),
 | ||
|  |     ('objlist', ctypes.c_uint64),
 | ||
|  |     ('objsize', ctypes.c_uint32),
 | ||
|  |     ('numobjs', ctypes.c_uint32),
 | ||
|  |     ('synclist', ctypes.c_uint64),
 | ||
|  |     ('syncsize', ctypes.c_uint32),
 | ||
|  |     ('numsyncs', ctypes.c_uint32),
 | ||
|  |     ('context_id', ctypes.c_uint32),
 | ||
|  |     ('timestamp', ctypes.c_uint32),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_preemption_counters_query(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_preemption_counters_query._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_preemption_counters_query._fields_ = [
 | ||
|  |     ('counters', ctypes.c_uint64),
 | ||
|  |     ('size_user', ctypes.c_uint32),
 | ||
|  |     ('size_priority_level', ctypes.c_uint32),
 | ||
|  |     ('max_priority_level', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | class struct_kgsl_gpuobj_set_info(Structure):
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | struct_kgsl_gpuobj_set_info._pack_ = 1 # source:False
 | ||
|  | struct_kgsl_gpuobj_set_info._fields_ = [
 | ||
|  |     ('flags', ctypes.c_uint64),
 | ||
|  |     ('metadata', ctypes.c_uint64),
 | ||
|  |     ('id', ctypes.c_uint32),
 | ||
|  |     ('metadata_len', ctypes.c_uint32),
 | ||
|  |     ('type', ctypes.c_uint32),
 | ||
|  |     ('PADDING_0', ctypes.c_ubyte * 4),
 | ||
|  | ]
 | ||
|  | 
 | ||
|  | __all__ = \
 | ||
|  |     ['KGSL_CMDWINDOW_2D', 'KGSL_CMDWINDOW_3D',
 | ||
|  |     'KGSL_CMDWINDOW_ARBITER', 'KGSL_CMDWINDOW_MAX',
 | ||
|  |     'KGSL_CMDWINDOW_MIN', 'KGSL_CMDWINDOW_MMU',
 | ||
|  |     'KGSL_CTX_STAT_GUILTY_CONTEXT_RESET_EXT',
 | ||
|  |     'KGSL_CTX_STAT_INNOCENT_CONTEXT_RESET_EXT',
 | ||
|  |     'KGSL_CTX_STAT_NO_ERROR',
 | ||
|  |     'KGSL_CTX_STAT_UNKNOWN_CONTEXT_RESET_EXT', 'KGSL_DEVICE_3D0',
 | ||
|  |     'KGSL_DEVICE_MAX', 'KGSL_TIMESTAMP_CONSUMED',
 | ||
|  |     'KGSL_TIMESTAMP_QUEUED', 'KGSL_TIMESTAMP_RETIRED',
 | ||
|  |     'KGSL_USER_MEM_TYPE_ADDR', 'KGSL_USER_MEM_TYPE_ASHMEM',
 | ||
|  |     'KGSL_USER_MEM_TYPE_DMABUF', 'KGSL_USER_MEM_TYPE_ION',
 | ||
|  |     'KGSL_USER_MEM_TYPE_MAX', 'KGSL_USER_MEM_TYPE_PMEM',
 | ||
|  |     'kgsl_cmdwindow_type', 'kgsl_ctx_reset_stat', 'kgsl_deviceid',
 | ||
|  |     'kgsl_timestamp_type', 'kgsl_user_mem_type',
 | ||
|  |     'struct_kgsl_bind_gmem_shadow', 'struct_kgsl_buffer_desc',
 | ||
|  |     'struct_kgsl_cff_sync_gpuobj', 'struct_kgsl_cff_syncmem',
 | ||
|  |     'struct_kgsl_cff_user_event', 'struct_kgsl_cmd_syncpoint',
 | ||
|  |     'struct_kgsl_cmd_syncpoint_fence',
 | ||
|  |     'struct_kgsl_cmd_syncpoint_timestamp',
 | ||
|  |     'struct_kgsl_cmdbatch_profiling_buffer',
 | ||
|  |     'struct_kgsl_cmdstream_freememontimestamp',
 | ||
|  |     'struct_kgsl_cmdstream_freememontimestamp_ctxtid',
 | ||
|  |     'struct_kgsl_cmdstream_readtimestamp',
 | ||
|  |     'struct_kgsl_cmdstream_readtimestamp_ctxtid',
 | ||
|  |     'struct_kgsl_cmdwindow_write', 'struct_kgsl_command_object',
 | ||
|  |     'struct_kgsl_command_syncpoint', 'struct_kgsl_device_constraint',
 | ||
|  |     'struct_kgsl_device_constraint_pwrlevel',
 | ||
|  |     'struct_kgsl_device_getproperty',
 | ||
|  |     'struct_kgsl_device_waittimestamp',
 | ||
|  |     'struct_kgsl_device_waittimestamp_ctxtid', 'struct_kgsl_devinfo',
 | ||
|  |     'struct_kgsl_devmemstore', 'struct_kgsl_drawctxt_create',
 | ||
|  |     'struct_kgsl_drawctxt_destroy',
 | ||
|  |     'struct_kgsl_drawctxt_set_bin_base_offset',
 | ||
|  |     'struct_kgsl_gmem_desc', 'struct_kgsl_gpmu_version',
 | ||
|  |     'struct_kgsl_gpu_command', 'struct_kgsl_gpu_event_fence',
 | ||
|  |     'struct_kgsl_gpu_event_timestamp', 'struct_kgsl_gpumem_alloc',
 | ||
|  |     'struct_kgsl_gpumem_alloc_id', 'struct_kgsl_gpumem_free_id',
 | ||
|  |     'struct_kgsl_gpumem_get_info', 'struct_kgsl_gpumem_sync_cache',
 | ||
|  |     'struct_kgsl_gpumem_sync_cache_bulk', 'struct_kgsl_gpuobj_alloc',
 | ||
|  |     'struct_kgsl_gpuobj_free', 'struct_kgsl_gpuobj_import',
 | ||
|  |     'struct_kgsl_gpuobj_import_dma_buf',
 | ||
|  |     'struct_kgsl_gpuobj_import_useraddr', 'struct_kgsl_gpuobj_info',
 | ||
|  |     'struct_kgsl_gpuobj_set_info', 'struct_kgsl_gpuobj_sync',
 | ||
|  |     'struct_kgsl_gpuobj_sync_obj', 'struct_kgsl_ibdesc',
 | ||
|  |     'struct_kgsl_map_user_mem', 'struct_kgsl_perfcounter_get',
 | ||
|  |     'struct_kgsl_perfcounter_put', 'struct_kgsl_perfcounter_query',
 | ||
|  |     'struct_kgsl_perfcounter_read',
 | ||
|  |     'struct_kgsl_perfcounter_read_group',
 | ||
|  |     'struct_kgsl_preemption_counters_query',
 | ||
|  |     'struct_kgsl_ringbuffer_issueibcmds', 'struct_kgsl_shadowprop',
 | ||
|  |     'struct_kgsl_sharedmem_free', 'struct_kgsl_sharedmem_from_pmem',
 | ||
|  |     'struct_kgsl_sharedmem_from_vmalloc',
 | ||
|  |     'struct_kgsl_sp_generic_mem', 'struct_kgsl_submit_commands',
 | ||
|  |     'struct_kgsl_syncsource_create',
 | ||
|  |     'struct_kgsl_syncsource_create_fence',
 | ||
|  |     'struct_kgsl_syncsource_destroy',
 | ||
|  |     'struct_kgsl_syncsource_signal_fence',
 | ||
|  |     'struct_kgsl_timestamp_event',
 | ||
|  |     'struct_kgsl_timestamp_event_fence',
 | ||
|  |     'struct_kgsl_timestamp_event_genlock',
 | ||
|  |     'struct_kgsl_ucode_version', 'struct_kgsl_version']
 |