1 /* SPDX-License-Identifier: (GPL-2.0 OR BSD-3-Clause) */
3 * This file is provided under a dual BSD/GPLv2 license. When using or
4 * redistributing this file, you may do so under either license.
6 * Copyright(c) 2019 Intel Corporation. All rights reserved.
9 #ifndef __IPC_CHANNEL_MAP_H__
10 #define __IPC_CHANNEL_MAP_H__
12 #include <uapi/sound/sof/header.h>
13 #include <sound/sof/header.h>
16 * \brief Channel map, specifies transformation of one-to-many or many-to-one.
18 * In case of one-to-many specifies how the output channels are computed out of
19 * a single source channel,
20 * in case of many-to-one specifies how a single target channel is computed
21 * from a multichannel input stream.
23 * Channel index specifies position of the channel in the stream on the 'one'
26 * Ext ID is the identifier of external part of the transformation. Depending
27 * on the context, it may be pipeline ID, dai ID, ...
29 * Channel mask describes which channels are taken into account on the "many"
30 * side. Bit[i] set to 1 means that i-th channel is used for computation
31 * (either as source or as a target).
33 * Channel mask is followed by array of coefficients in Q2.30 format,
34 * one per each channel set in the mask (left to right, LS bit set in the
35 * mask corresponds to ch_coeffs[0]).
37 struct sof_ipc_channel_map
{
46 * \brief Complete map for each channel of a multichannel stream.
48 * num_ch_map Specifies number of items in the ch_map.
49 * More than one transformation per a single channel is allowed (in case
50 * multiple external entities are transformed).
51 * A channel may be skipped in the transformation list, then it is filled
52 * with 0's by the transformation function.
54 struct sof_ipc_stream_map
{
55 struct sof_ipc_cmd_hdr hdr
;
58 struct sof_ipc_channel_map ch_map
[0];
61 #endif /* __IPC_CHANNEL_MAP_H__ */