Asterisk - The Open Source Telephony Project
18.5.0
|
Codec API. More...
Go to the source code of this file.
Data Structures | |
struct | ast_codec |
Represents a media codec within Asterisk. More... | |
Macros | |
#define | ast_codec_register(codec) __ast_codec_register(codec, AST_MODULE_SELF) |
This function is used to register a codec with the Asterisk core. Registering allows it to be passed through in frames and configured in channel drivers. More... | |
Enumerations | |
enum | ast_media_type { AST_MEDIA_TYPE_UNKNOWN = 0, AST_MEDIA_TYPE_AUDIO, AST_MEDIA_TYPE_VIDEO, AST_MEDIA_TYPE_IMAGE, AST_MEDIA_TYPE_TEXT, AST_MEDIA_TYPE_END } |
Types of media. More... | |
Functions | |
int | __ast_codec_register (struct ast_codec *codec, struct ast_module *mod) |
This function is used to register a codec with the Asterisk core. Registering allows it to be passed through in frames and configured in channel drivers. More... | |
int | ast_codec_builtin_init (void) |
Initialize built-in codecs within the core. More... | |
unsigned int | ast_codec_determine_length (const struct ast_codec *codec, unsigned int samples) |
Get the length of media (in milliseconds) given a number of samples. More... | |
struct ast_codec * | ast_codec_get (const char *name, enum ast_media_type type, unsigned int sample_rate) |
Retrieve a codec given a name, type, and sample rate. More... | |
struct ast_codec * | ast_codec_get_by_id (int id) |
Retrieve a codec given the unique identifier. More... | |
int | ast_codec_get_max (void) |
Retrieve the current maximum identifier for codec iteration. More... | |
int | ast_codec_init (void) |
Initialize codec support within the core. More... | |
const char * | ast_codec_media_type2str (enum ast_media_type type) |
Conversion function to take a media type and turn it into a string. More... | |
unsigned int | ast_codec_samples_count (struct ast_frame *frame) |
Get the number of samples contained within a frame. More... | |
enum ast_media_type | ast_media_type_from_str (const char *media_type_str) |
Conversion function to take a media string and convert it to a media type. More... | |
Codec API.
Definition in file codec.h.
#define ast_codec_register | ( | codec | ) | __ast_codec_register(codec, AST_MODULE_SELF) |
This function is used to register a codec with the Asterisk core. Registering allows it to be passed through in frames and configured in channel drivers.
codec | to register |
0 | success |
-1 | failure |
Definition at line 122 of file codec.h.
Referenced by AST_TEST_DEFINE(), and load_module().
enum ast_media_type |
Types of media.
Enumerator | |
---|---|
AST_MEDIA_TYPE_UNKNOWN | |
AST_MEDIA_TYPE_AUDIO | |
AST_MEDIA_TYPE_VIDEO | |
AST_MEDIA_TYPE_IMAGE | |
AST_MEDIA_TYPE_TEXT | |
AST_MEDIA_TYPE_END |
Definition at line 30 of file codec.h.
int __ast_codec_register | ( | struct ast_codec * | codec, |
struct ast_module * | mod | ||
) |
This function is used to register a codec with the Asterisk core. Registering allows it to be passed through in frames and configured in channel drivers.
codec | to register |
mod | the module this codec is provided by |
0 | success |
-1 | failure |
Definition at line 272 of file codec.c.
References __ast_codec_register_with_format(), and NULL.
int ast_codec_builtin_init | ( | void | ) |
Initialize built-in codecs within the core.
0 | success |
-1 | failure |
Definition at line 942 of file codec_builtin.c.
References CODEC_REGISTER_AND_CACHE, and CODEC_REGISTER_AND_CACHE_NAMED.
Referenced by asterisk_daemon().
unsigned int ast_codec_determine_length | ( | const struct ast_codec * | codec, |
unsigned int | samples | ||
) |
Get the length of media (in milliseconds) given a number of samples.
codec | The codec itself |
samples | The number of samples |
length | of media (in milliseconds) |
Definition at line 407 of file codec.c.
References ast_codec::get_length.
Referenced by ast_format_determine_length().
struct ast_codec* ast_codec_get | ( | const char * | name, |
enum ast_media_type | type, | ||
unsigned int | sample_rate | ||
) |
Retrieve a codec given a name, type, and sample rate.
name | The name of the codec |
type | The type of the codec |
sample_rate | Optional sample rate, may not be applicable for some types |
non-NULL | success |
NULL | failure |
Definition at line 326 of file codec.c.
References ao2_find, ast_codec::name, name, OBJ_SEARCH_OBJECT, ast_codec::sample_rate, and type.
Referenced by __ast_register_translator(), AST_TEST_DEFINE(), handle_show_translation_path(), and newpvt().
struct ast_codec* ast_codec_get_by_id | ( | int | id | ) |
Retrieve a codec given the unique identifier.
id | The unique identifier |
non-NULL | success |
NULL | failure |
Definition at line 337 of file codec.c.
References ao2_callback, and codec_id_cmp().
Referenced by ast_format_cap_append_by_type(), AST_TEST_DEFINE(), complete_trans_path_choice(), handle_show_translation_path(), handle_show_translation_table(), and index2codec().
int ast_codec_get_max | ( | void | ) |
Retrieve the current maximum identifier for codec iteration.
Definition at line 342 of file codec.c.
References codec_id.
Referenced by ast_format_cap_append_by_type(), and AST_TEST_DEFINE().
int ast_codec_init | ( | void | ) |
Initialize codec support within the core.
0 | success |
-1 | failure |
Definition at line 249 of file codec.c.
References AO2_ALLOC_OPT_LOCK_RWLOCK, ao2_container_alloc_hash, ARRAY_LEN, ast_cli_register_multiple, ast_register_cleanup(), CODEC_BUCKETS, codec_cmp(), codec_shutdown(), and NULL.
Referenced by asterisk_daemon().
const char* ast_codec_media_type2str | ( | enum ast_media_type | type | ) |
Conversion function to take a media type and turn it into a string.
type | The media type |
string | representation of the media type |
Definition at line 347 of file codec.c.
References AST_MEDIA_TYPE_AUDIO, AST_MEDIA_TYPE_IMAGE, AST_MEDIA_TYPE_TEXT, and AST_MEDIA_TYPE_VIDEO.
Referenced by __ast_codec_register_with_format(), add_msid_to_stream(), add_sdp_streams(), ast_rtp_engine_load_format(), ast_rtp_interpret(), ast_rtp_read(), ast_sip_create_joint_call_cap(), ast_sip_session_media_state_add(), ast_stream_create_resolved(), ast_stream_to_str(), ast_stream_topology_append_stream(), ast_stream_topology_create_from_format_cap(), ast_stream_topology_set_stream(), AST_TEST_DEFINE(), chan_pjsip_write_stream(), check_stream_positions(), create_outgoing_sdp_stream(), handle_incoming_sdp(), handle_negotiated_sdp_session_media(), handle_showchan(), is_media_state_valid(), log_caps(), negotiate_incoming_sdp_stream(), rtp_check_timeout(), sdp_requires_deferral(), set_caps(), set_incoming_call_offer_cap(), show_codecs(), stream_echo_exec(), stream_echo_write_error(), and validate_stream().
unsigned int ast_codec_samples_count | ( | struct ast_frame * | frame | ) |
Get the number of samples contained within a frame.
frame | The frame itself |
number | of samples in the frame |
Definition at line 378 of file codec.c.
References ao2_ref, ast_format_get_codec(), ast_format_get_name(), AST_FRAME_IMAGE, AST_FRAME_VIDEO, AST_FRAME_VOICE, ast_log, ast_frame_subclass::format, ast_frame::frametype, LOG_WARNING, ast_codec::samples_count, and ast_frame::subclass.
Referenced by ast_rtp_interpret(), dahdi_encoder_frameout(), isAnsweringMachine(), moh_generate(), ogg_speex_read(), schedule_delivery(), socket_process_helper(), and socket_process_meta().
enum ast_media_type ast_media_type_from_str | ( | const char * | media_type_str | ) |
Conversion function to take a media string and convert it to a media type.
media_type_str | The media type string |
The | ast_media_type that corresponds to the string |
Definition at line 363 of file codec.c.
References AST_MEDIA_TYPE_AUDIO, AST_MEDIA_TYPE_IMAGE, AST_MEDIA_TYPE_TEXT, AST_MEDIA_TYPE_UNKNOWN, and AST_MEDIA_TYPE_VIDEO.
Referenced by handle_incoming_sdp(), sdp_requires_deferral(), and stream_echo_exec().