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.
125 lines
3.7 KiB
125 lines
3.7 KiB
7 years ago
|
/* Copyright (c) 2012-2018, The Linux Foundation. All rights reserved.
|
||
|
*
|
||
|
* This program is free software; you can redistribute it and/or modify
|
||
|
* it under the terms of the GNU General Public License version 2 and
|
||
|
* only version 2 as published by the Free Software Foundation.
|
||
|
*
|
||
|
* This program is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
* GNU General Public License for more details.
|
||
|
*/
|
||
|
|
||
|
#ifndef _MSM_TSPP_H_
|
||
|
#define _MSM_TSPP_H_
|
||
|
|
||
|
struct tspp_data_descriptor {
|
||
|
void *virt_base; /* logical address of the actual data */
|
||
|
phys_addr_t phys_base; /* physical address of the actual data */
|
||
|
dma_addr_t dma_base; /* DMA address of the actual data */
|
||
|
u32 size; /* size of buffer in bytes */
|
||
|
int id; /* unique identifier */
|
||
|
void *user; /* user-defined data */
|
||
|
};
|
||
|
|
||
|
enum tspp_key_parity {
|
||
|
TSPP_KEY_PARITY_EVEN,
|
||
|
TSPP_KEY_PARITY_ODD
|
||
|
};
|
||
|
|
||
|
struct tspp_key {
|
||
|
enum tspp_key_parity parity;
|
||
|
int lsb;
|
||
|
int msb;
|
||
|
};
|
||
|
|
||
|
enum tspp_source {
|
||
|
TSPP_SOURCE_TSIF0,
|
||
|
TSPP_SOURCE_TSIF1,
|
||
|
TSPP_SOURCE_MEM,
|
||
|
TSPP_SOURCE_NONE = -1
|
||
|
};
|
||
|
|
||
|
enum tspp_mode {
|
||
|
TSPP_MODE_DISABLED,
|
||
|
TSPP_MODE_PES,
|
||
|
TSPP_MODE_RAW,
|
||
|
TSPP_MODE_RAW_NO_SUFFIX
|
||
|
};
|
||
|
|
||
|
enum tspp_tsif_mode {
|
||
|
TSPP_TSIF_MODE_LOOPBACK, /* loopback mode */
|
||
|
TSPP_TSIF_MODE_1, /* without sync */
|
||
|
TSPP_TSIF_MODE_2 /* with sync signal */
|
||
|
};
|
||
|
|
||
|
struct tspp_filter {
|
||
|
int pid;
|
||
|
int mask;
|
||
|
enum tspp_mode mode;
|
||
|
unsigned int priority; /* 0 - 15 */
|
||
|
int decrypt;
|
||
|
enum tspp_source source;
|
||
|
};
|
||
|
|
||
|
struct tspp_select_source {
|
||
|
enum tspp_source source;
|
||
|
enum tspp_tsif_mode mode;
|
||
|
int clk_inverse;
|
||
|
int data_inverse;
|
||
|
int sync_inverse;
|
||
|
int enable_inverse;
|
||
|
};
|
||
|
|
||
|
enum tsif_tts_source {
|
||
|
TSIF_TTS_TCR = 0, /* Time stamps from TCR counter */
|
||
|
TSIF_TTS_LPASS_TIMER /* Time stamps from AV/Qtimer Timer */
|
||
|
};
|
||
|
|
||
|
struct tspp_ion_dma_buf_info {
|
||
|
struct dma_buf *dbuf;
|
||
|
struct dma_buf_attachment *attach;
|
||
|
struct sg_table *table;
|
||
|
bool smmu_map;
|
||
|
void *va;
|
||
|
};
|
||
|
|
||
|
typedef void (tspp_notifier)(int channel_id, void *user);
|
||
|
typedef void* (tspp_allocator)(int channel_id, u32 size,
|
||
|
phys_addr_t *phys_base, dma_addr_t *dma_base, void *user);
|
||
|
typedef void (tspp_memfree)(int channel_id, u32 size,
|
||
|
void *virt_base, phys_addr_t phys_base, void *user);
|
||
|
|
||
|
/* Kernel API functions */
|
||
|
int tspp_open_stream(u32 dev, u32 channel_id,
|
||
|
struct tspp_select_source *source);
|
||
|
int tspp_close_stream(u32 dev, u32 channel_id);
|
||
|
int tspp_open_channel(u32 dev, u32 channel_id);
|
||
|
int tspp_close_channel(u32 dev, u32 channel_id);
|
||
|
int tspp_get_ref_clk_counter(u32 dev,
|
||
|
enum tspp_source source, u32 *tcr_counter);
|
||
|
int tspp_add_filter(u32 dev, u32 channel_id, struct tspp_filter *filter);
|
||
|
int tspp_remove_filter(u32 dev, u32 channel_id, struct tspp_filter *filter);
|
||
|
int tspp_set_key(u32 dev, u32 channel_id, struct tspp_key *key);
|
||
|
int tspp_register_notification(u32 dev, u32 channel_id, tspp_notifier *notify,
|
||
|
void *data, u32 timer_ms);
|
||
|
int tspp_unregister_notification(u32 dev, u32 channel_id);
|
||
|
const struct tspp_data_descriptor *tspp_get_buffer(u32 dev, u32 channel_id);
|
||
|
int tspp_release_buffer(u32 dev, u32 channel_id, u32 descriptor_id);
|
||
|
int tspp_allocate_buffers(u32 dev, u32 channel_id, u32 count,
|
||
|
u32 size, u32 int_freq, tspp_allocator *alloc,
|
||
|
tspp_memfree *memfree, void *user);
|
||
|
|
||
|
int tspp_get_tts_source(u32 dev, int *tts_source);
|
||
|
int tspp_get_lpass_time_counter(u32 dev, enum tspp_source source,
|
||
|
u64 *lpass_time_counter);
|
||
|
|
||
|
int tspp_attach_ion_dma_buff(u32 dev,
|
||
|
struct tspp_ion_dma_buf_info *ion_dma_buf);
|
||
|
|
||
|
int tspp_detach_ion_dma_buff(u32 dev,
|
||
|
struct tspp_ion_dma_buf_info *ion_dma_buf);
|
||
|
void *tspp_allocate_dma_buffer(u32 dev, int size, phys_addr_t *paddr);
|
||
|
int tspp_free_dma_buffer(u32 dev, int size, void *vaddr, dma_addr_t paddr);
|
||
|
#endif /* _MSM_TSPP_H_ */
|