PipeWire
0.3.29
|
The device interface can be used to monitor all kinds of devices and create objects as a result. More...
Data Structures | |
struct | spa_device |
struct | spa_device_info |
Information about the device and parameters it supports. More... | |
struct | spa_device_object_info |
Information about a device object. More... | |
struct | spa_result_device_params |
struct | spa_device_events |
spa_device_events: More... | |
struct | spa_device_methods |
spa_device_methods: More... | |
Macros | |
#define | SPA_TYPE_INTERFACE_Device SPA_TYPE_INFO_INTERFACE_BASE "Device" |
#define | SPA_VERSION_DEVICE 0 |
#define | SPA_DEVICE_INFO_INIT() (struct spa_device_info){ SPA_VERSION_DEVICE_INFO, } |
#define | SPA_DEVICE_OBJECT_INFO_INIT() (struct spa_device_object_info){ SPA_VERSION_DEVICE_OBJECT_INFO, } |
#define | SPA_RESULT_TYPE_DEVICE_PARAMS 1 |
the result of spa_device_enum_params() More... | |
#define | SPA_DEVICE_EVENT_INFO 0 |
#define | SPA_DEVICE_EVENT_RESULT 1 |
#define | SPA_DEVICE_EVENT_EVENT 2 |
#define | SPA_DEVICE_EVENT_OBJECT_INFO 3 |
#define | SPA_DEVICE_EVENT_NUM 4 |
#define | SPA_DEVICE_METHOD_ADD_LISTENER 0 |
#define | SPA_DEVICE_METHOD_SYNC 1 |
#define | SPA_DEVICE_METHOD_ENUM_PARAMS 2 |
#define | SPA_DEVICE_METHOD_SET_PARAM 3 |
#define | SPA_DEVICE_METHOD_NUM 4 |
#define | spa_device_method(o, method, version, ...) |
#define | spa_device_add_listener(d, ...) spa_device_method(d, add_listener, 0, __VA_ARGS__) |
#define | spa_device_sync(d, ...) spa_device_method(d, sync, 0, __VA_ARGS__) |
#define | spa_device_enum_params(d, ...) spa_device_method(d, enum_params, 0, __VA_ARGS__) |
#define | spa_device_set_param(d, ...) spa_device_method(d, set_param, 0, __VA_ARGS__) |
#define | SPA_KEY_DEVICE_ENUM_API "device.enum.api" |
the api used to discover this device More... | |
#define | SPA_KEY_DEVICE_API "device.api" |
the api used by the device Ex. More... | |
#define | SPA_KEY_DEVICE_NAME "device.name" |
the name of the device More... | |
#define | SPA_KEY_DEVICE_ALIAS "device.alias" |
alternative name of the device More... | |
#define | SPA_KEY_DEVICE_NICK "device.nick" |
the device short name More... | |
#define | SPA_KEY_DEVICE_DESCRIPTION "device.description" |
a device description More... | |
#define | SPA_KEY_DEVICE_ICON "device.icon" |
icon for the device. More... | |
#define | SPA_KEY_DEVICE_ICON_NAME "device.icon-name" |
an XDG icon name for the device. More... | |
#define | SPA_KEY_DEVICE_PLUGGED_USEC "device.plugged.usec" |
when the device was plugged More... | |
#define | SPA_KEY_DEVICE_BUS_ID "device.bus-id" |
the device bus-id More... | |
#define | SPA_KEY_DEVICE_BUS_PATH "device.bus-path" |
bus path to the device in the OS' format. More... | |
#define | SPA_KEY_DEVICE_BUS "device.bus" |
bus of the device if applicable. More... | |
#define | SPA_KEY_DEVICE_SUBSYSTEM "device.subsystem" |
device subsystem More... | |
#define | SPA_KEY_DEVICE_SYSFS_PATH "device.sysfs.path" |
device sysfs path More... | |
#define | SPA_KEY_DEVICE_VENDOR_ID "device.vendor.id" |
vendor ID if applicable More... | |
#define | SPA_KEY_DEVICE_VENDOR_NAME "device.vendor.name" |
vendor name if applicable More... | |
#define | SPA_KEY_DEVICE_PRODUCT_ID "device.product.id" |
product ID if applicable More... | |
#define | SPA_KEY_DEVICE_PRODUCT_NAME "device.product.name" |
product name if applicable More... | |
#define | SPA_KEY_DEVICE_SERIAL "device.serial" |
Serial number if applicable. More... | |
#define | SPA_KEY_DEVICE_CLASS "device.class" |
device class More... | |
#define | SPA_KEY_DEVICE_CAPABILITIES "device.capabilities" |
api specific device capabilities More... | |
#define | SPA_KEY_DEVICE_FORM_FACTOR "device.form-factor" |
form factor if applicable. More... | |
#define | SPA_KEY_DEVICE_PROFILE "device.profile " |
profile for the device More... | |
#define | SPA_KEY_DEVICE_PROFILE_SET "device.profile-set" |
profile set for the device More... | |
#define | SPA_KEY_DEVICE_STRING "device.string" |
device string in the underlying layer's format. More... | |
The device interface can be used to monitor all kinds of devices and create objects as a result.
Objects a typically other Devices or Nodes.
#define spa_device_add_listener | ( | d, | |
... | |||
) | spa_device_method(d, add_listener, 0, __VA_ARGS__) |
Referenced by pw_impl_device_set_implementation().
#define spa_device_enum_params | ( | d, | |
... | |||
) | spa_device_method(d, enum_params, 0, __VA_ARGS__) |
#define SPA_DEVICE_EVENT_EVENT 2 |
#define SPA_DEVICE_EVENT_INFO 0 |
#define SPA_DEVICE_EVENT_NUM 4 |
#define SPA_DEVICE_EVENT_OBJECT_INFO 3 |
#define SPA_DEVICE_EVENT_RESULT 1 |
#define SPA_DEVICE_INFO_INIT | ( | ) | (struct spa_device_info){ SPA_VERSION_DEVICE_INFO, } |
#define spa_device_method | ( | o, | |
method, | |||
version, | |||
... | |||
) |
#define SPA_DEVICE_METHOD_ADD_LISTENER 0 |
#define SPA_DEVICE_METHOD_ENUM_PARAMS 2 |
#define SPA_DEVICE_METHOD_NUM 4 |
#define SPA_DEVICE_METHOD_SET_PARAM 3 |
#define SPA_DEVICE_METHOD_SYNC 1 |
#define SPA_DEVICE_OBJECT_INFO_INIT | ( | ) | (struct spa_device_object_info){ SPA_VERSION_DEVICE_OBJECT_INFO, } |
#define spa_device_set_param | ( | d, | |
... | |||
) | spa_device_method(d, set_param, 0, __VA_ARGS__) |
#define spa_device_sync | ( | d, | |
... | |||
) | spa_device_method(d, sync, 0, __VA_ARGS__) |
#define SPA_KEY_DEVICE_ALIAS "device.alias" |
alternative name of the device
#define SPA_KEY_DEVICE_API "device.api" |
the api used by the device Ex.
"udev", "alsa", "v4l2".
#define SPA_KEY_DEVICE_BUS "device.bus" |
bus of the device if applicable.
One of "isa", "pci", "usb", "firewire", "bluetooth"
#define SPA_KEY_DEVICE_BUS_ID "device.bus-id" |
the device bus-id
#define SPA_KEY_DEVICE_BUS_PATH "device.bus-path" |
bus path to the device in the OS' format.
Ex. "pci-0000:00:14.0-usb-0:3.2:1.0"
#define SPA_KEY_DEVICE_CAPABILITIES "device.capabilities" |
api specific device capabilities
#define SPA_KEY_DEVICE_CLASS "device.class" |
device class
#define SPA_KEY_DEVICE_DESCRIPTION "device.description" |
a device description
#define SPA_KEY_DEVICE_ENUM_API "device.enum.api" |
the api used to discover this device
#define SPA_KEY_DEVICE_FORM_FACTOR "device.form-factor" |
form factor if applicable.
One of "internal", "speaker", "handset", "tv", "webcam", "microphone", "headset", "headphone", "hands-free", "car", "hifi", "computer", "portable"
#define SPA_KEY_DEVICE_ICON "device.icon" |
icon for the device.
A base64 blob containing PNG image data
#define SPA_KEY_DEVICE_ICON_NAME "device.icon-name" |
an XDG icon name for the device.
Ex. "sound-card-speakers-usb"
#define SPA_KEY_DEVICE_NAME "device.name" |
the name of the device
#define SPA_KEY_DEVICE_NICK "device.nick" |
the device short name
#define SPA_KEY_DEVICE_PLUGGED_USEC "device.plugged.usec" |
when the device was plugged
#define SPA_KEY_DEVICE_PRODUCT_ID "device.product.id" |
product ID if applicable
#define SPA_KEY_DEVICE_PRODUCT_NAME "device.product.name" |
product name if applicable
#define SPA_KEY_DEVICE_PROFILE "device.profile " |
profile for the device
#define SPA_KEY_DEVICE_PROFILE_SET "device.profile-set" |
profile set for the device
#define SPA_KEY_DEVICE_SERIAL "device.serial" |
Serial number if applicable.
#define SPA_KEY_DEVICE_STRING "device.string" |
device string in the underlying layer's format.
E.g. "surround51:0"
#define SPA_KEY_DEVICE_SUBSYSTEM "device.subsystem" |
device subsystem
#define SPA_KEY_DEVICE_SYSFS_PATH "device.sysfs.path" |
device sysfs path
#define SPA_KEY_DEVICE_VENDOR_ID "device.vendor.id" |
vendor ID if applicable
#define SPA_KEY_DEVICE_VENDOR_NAME "device.vendor.name" |
vendor name if applicable
#define SPA_RESULT_TYPE_DEVICE_PARAMS 1 |
the result of spa_device_enum_params()
#define SPA_TYPE_INTERFACE_Device SPA_TYPE_INFO_INTERFACE_BASE "Device" |
#define SPA_VERSION_DEVICE 0 |