|
dxd - dynax driver framework 2.6.0d172
cross platform open source driver development framework
|
generic kernel multichannel stream More...
#include <dxd_stream.h>
Inheritance diagram for dxd::multichannel::stream< channel_t >:
Collaboration diagram for dxd::multichannel::stream< channel_t >:Classes | |
| class | clock |
| class | in |
| kernel stream mapped client reference counted in channel buffers More... | |
| class | umap |
| stream user mapping More... | |
Public Member Functions | |
| os_result | attach (unsigned int iosize, channel_t **channel[2]) |
| attach user client owned out channels | |
| os_result | attach (unsigned int iosize, const uint64_t *channel_map) |
| create stream local in channels | |
| void | detach (channel_t **channel[2]) |
| void | detach (const uint64_t *channel_map) |
| template<typename return_t = os_result, typename exec_t > | |
| return_t | each (exec_t exec) |
| 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 | |
| item_t * | pop () |
| pop item from head | |
| item_t * | pop (item_t *item) |
| pop item | |
| list & | print () |
| item_t * | push (item_t *item) |
| push item to head | |
| template<typename reference_t > | |
| int | release (reference_t &reference) |
| void | retain () |
| void | rx (int64_t timestamp) |
| os_result | signal () |
| size_t | size () const |
| IOKit memory size. | |
| size_t | size () const |
| kernel mapping size | |
| virtual os_result | start (bool force=false)=0 |
| virtual os_result | stop (bool force=false)=0 |
| void | tx (int64_t timestamp) |
Public Attributes | ||
| struct { | ||
| uint64_t advance = 0 | ||
| dxd::buffer< dx::user > buffer {sizeof(dx::stream::channel::control)} | ||
| bool in | ||
| unsigned int iosize = 0 | ||
| dxd::map< dx::kernel, dx::stream::channel::control > map {buffer} | ||
| } | control | |
| atomic< int > | references {} | |
| os_result | status =not_initialized | |
| IOKit memory status. | ||
| os_result | status =not_initialized | |
| status of mapping object | ||
Protected Member Functions | |
| void | __lock () |
| void | __lock () |
| bool | __trylock () |
| void | __unlock () |
| void | __unlock () |
| operator const::KSPIN_LOCK & () const | |
| operator const::KSPIN_LOCK * () const | |
| operator::KSPIN_LOCK & () | |
| operator::KSPIN_LOCK * () | |
| ~stream () | |
Protected Attributes | ||
| vm_t * | _vm =nullptr | |
| kernel virtual address mapping | ||
| union { | ||
| channel_t ** in [2] | ||
| in channel array [switch] [channels] More... | ||
| channel_t *const *const *volatile out [2] | ||
| client out channel array [switch] [client] -> umap out channels [channels] More... | ||
| } | cache | |
| unsigned int | channels = 0 | |
| stream channels | ||
| dxd::multichannel::stream::in * | in [2] | |
| ::IOMemoryMap * | iokit_memory_map =nullptr | |
| atomic< int > | out = 0 | |
| client outs atached | ||
| os_result | status =not_initialized | |
generic kernel multichannel stream
|
inlineprotectedvirtual |
Reimplemented from dxd::stream.
|
inlineprotectedinherited |
|
inlineprotectedinherited |
|
inlineprotectedinherited |
|
inlineprotectedinherited |
|
inlineprotectedinherited |
|
inline |
attach user client owned out channels
|
inline |
create stream local in channels
Here is the caller graph for this function:
|
inline |
|
inline |
Here is the caller graph for this function:
|
inlineinherited |
|
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 |
|
inlineinherited |
|
inlineinherited |
IOKit physical address (only relevant for contigous memory)
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
operator to use mapping like pointer
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
pop item from head
Here is the caller graph for this function:
|
inlineinherited |
pop item
Here is the caller graph for this function:
|
inlineinherited |
Here is the call graph for this function:
|
inlineinherited |
push item to head
Here is the caller graph for this function:
|
inlineinherited |
|
inlineinherited |
Here is the caller graph for this function:
|
inline |
Here is the call graph for this function:
|
inlineinherited |
Here is the call graph for this function:
|
inlineinherited |
IOKit memory size.
|
inlineinherited |
kernel mapping size
|
pure virtualinherited |
|
pure virtualinherited |
|
inline |
Here is the call graph for this function:
|
protectedinherited |
kernel virtual address mapping
| uint64_t dxd::multichannel::stream< channel_t >::advance = 0 |
| dxd::buffer<dx::user> dxd::multichannel::stream< channel_t >::buffer {sizeof(dx::stream::channel::control)} |
| union { ... } dxd::multichannel::stream< channel_t >::cache |
|
protected |
stream channels
| struct { ... } dxd::multichannel::stream< channel_t >::control |
|
protected |
| channel_t** dxd::multichannel::stream< channel_t >::in[2] |
in channel array [switch] [channels]
| bool dxd::multichannel::stream< channel_t >::in |
|
protectedinherited |
| unsigned int dxd::multichannel::stream< channel_t >::iosize = 0 |
| dxd::map<dx::kernel, dx::stream::channel::control> dxd::multichannel::stream< channel_t >::map {buffer} |
|
protected |
client outs atached
| channel_t* const* const* volatile dxd::multichannel::stream< channel_t >::out[2] |
client out channel array [switch] [client] -> umap out channels [channels]
|
inherited |
IOKit memory status.
status of memory object
|
inherited |
status of mapping object
|
inherited |
| (c) copyright 2009 dynamic acoustics e.U. | generated on Mon Nov 3 2025 |