|
dxd - dynax driver framework 2.6.0d166
cross platform open source driver development framework
|
kernel stream mapped client reference counted in channel buffers More...
#include <dxd_stream.h>
Inheritance diagram for dxd::multichannel::stream< channel_t >::in:
Collaboration diagram for dxd::multichannel::stream< channel_t >::in:Public Member Functions | |
| in () | |
Protected Member Functions | |
| void | free () |
| kernel map free | |
| void | free () |
| os_result | initialize (::IOMemoryDescriptor *iokit_memory_descriptor) |
| IOKit memory initializer. | |
| os_result | initialize (::IOMemoryDescriptor *iokit_memory_descriptor, size_t offset, size_t size) |
| IOKit memory initializer. | |
| os_result | initialize (::IOMemoryDescriptor *iokit_memory_descriptor, size_t offset=0) |
| IOKit kernel map initializer. | |
| os_result | initialize (const void *data, size_t size) |
| IOKit memory initializer. | |
| os_result | initialize (const::MDL *mdl) |
| os_result | initialize (const::MDL *mdl, size_t offset, size_t size) |
| os_result | initialize (size_t size, unsigned int limit=limit_t, unsigned int alignment=alignment_t, bool contigous=contigous_t) |
| IOKit buffer initializer. | |
| os_result | initialize (size_t size, unsigned int limit=limit_t, unsigned int alignment=alignment_t, bool contigous=contigous_t) |
| os_result | initialize (void *data, size_t size) |
| IOKit memory initializer. | |
| operator const vm_t * () const | |
| operator const::IOMemoryDescriptor * () const | |
| IOKit IOMemoryDescriptor* implicit cast. | |
| operator const::IOMemoryMap * () const | |
| operator uint64_t () const | |
| IOKit physical address (only relevant for contigous memory) | |
| operator vm_t * () const | |
| vm_t * | operator-> () |
| const vm_t * | operator-> () const |
| operator to use mapping like pointer | |
| operator::IOMemoryDescriptor * () | |
| operator::IOMemoryMap * () | |
| operator::MDL * () const | |
| size_t | size () const |
| IOKit memory size. | |
| size_t | size () const |
| kernel mapping size | |
Protected Attributes | |
| vm_t * | _vm =nullptr |
| kernel virtual address mapping | |
| ::IOMemoryMap * | iokit_memory_map =nullptr |
| os_result | status =not_initialized |
| IOKit memory status. | |
| os_result | status =not_initialized |
| status of mapping object | |
Friends | |
| class | stream |
kernel stream mapped client reference counted in channel buffers
|
inline |
|
inlineinherited |
kernel map free
Checks if kernel mapping already exists and
does not call unmap(): IOMemoryMap instances will unmap themselves upon free, ie. when the last client with a reference calls release. unmap() forces the IOMemoryMap to destroy the mapping it represents, regardless of the number of clients. releases the map object.
|
inlineinherited |
|
inlineinherited |
IOKit memory initializer.
Here is the call graph for this function:
|
inlineinherited |
IOKit memory initializer.
Here is the call graph for this function:
|
inlineinherited |
IOKit kernel map initializer.
map<kernel> maps an IOMemoryDescriptor (typically cast of a dxd::memory or buffer class) into the kernel address space.
https://developer.apple.com/library/content/qa/qa1197/_index.html
Allows re-initialization.
Checks buffer object,
maps the buffer into the kernel (will fail if offset is given)
and obtains a kernel virtual address (apply offset here instead).
| iokit_memory_descriptor | IOMemoryDescriptor to be mapped into the kernel address space |
| offset | offset into memory descriptor to create mapping |
Here is the call graph for this function:
|
inherited |
IOKit memory initializer.
| data | virtual base address of range to create memory descriptor from |
| size | size of range to create memory descriptor from |
|
inlineinherited |
in contrast to an IOKit MemoryDescriptor MDLs do not support reference counting. take care when creating a dxd::memory from a dxd::buffer: although the dxd::memory holds an MDL to the buffer the buffer itself is not retained after the dxd::buffer is released!
Here is the call graph for this function:
|
inlineinherited |
Here is the call graph for this function:
|
inlineinherited |
IOKit buffer initializer.
Allows re-initialization.
Creates a buffer and associated memory descriptor.
Wires down the backing store memory.
| size | size to be alloced by buffer object |
| limit | limit physical memory address space |
| alignment | enforce physical memory alignment |
| contigous | enforce contiguos physical memory |
Here is the call graph for this function:
|
inlineinherited |
Allows re-initialization
| size | size to be alloced by buffer object |
| limit | limit physical memory address space |
| alignment | enforce physical memory alignment |
| contigous | enforce contiguos physical memory |
Here is the call graph for this function:
|
inherited |
IOKit memory initializer.
| data | virtual base address of range to create memory descriptor from |
| size | size of range to create memory descriptor from |
|
inlineinherited |
|
inlineinherited |
IOKit IOMemoryDescriptor* implicit cast.
|
inlineinherited |
|
inlineinherited |
IOKit physical address (only relevant for contigous memory)
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
operator to use mapping like pointer
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
IOKit memory size.
|
inlineinherited |
kernel mapping size
|
protectedinherited |
kernel virtual address mapping
|
protectedinherited |
IOKit memory status.
status of memory object
|
inherited |
status of mapping object
| (c) copyright 2009 dynamic acoustics e.U. | generated on Mon Oct 27 2025 |