mirror of
https://gitlab.freedesktop.org/pulseaudio/pulseaudio.git
synced 2025-11-02 09:01:46 -05:00
Add seq and rtptime params to record/flush with a view to using these for timing and device suspension
git-svn-id: file:///home/lennart/svn/public/pulseaudio/branches/coling@2500 fefdeb5f-60dc-0310-8127-8f9354f1896f
This commit is contained in:
parent
651da7d095
commit
5f527dc479
3 changed files with 21 additions and 9 deletions
|
|
@ -90,6 +90,9 @@ struct pa_raop_client {
|
|||
pa_socket_client *sc;
|
||||
int fd;
|
||||
|
||||
uint16_t seq;
|
||||
uint32_t rtptime;
|
||||
|
||||
pa_raop_client_cb_t callback;
|
||||
void* userdata;
|
||||
pa_raop_client_closed_cb_t closed_callback;
|
||||
|
|
@ -317,7 +320,7 @@ static void rtsp_cb(pa_rtsp_client *rtsp, pa_rtsp_state state, pa_headerlist* he
|
|||
} else {
|
||||
pa_log_warn("Audio Jack Status missing");
|
||||
}
|
||||
pa_rtsp_record(c->rtsp);
|
||||
pa_rtsp_record(c->rtsp, &c->seq, &c->rtptime);
|
||||
break;
|
||||
}
|
||||
|
||||
|
|
@ -403,8 +406,6 @@ void pa_raop_client_free(pa_raop_client* c)
|
|||
}
|
||||
|
||||
|
||||
static void noop(PA_GCC_UNUSED void* p) {}
|
||||
|
||||
int pa_raop_client_encode_sample(pa_raop_client* c, pa_memchunk* raw, pa_memchunk* encoded)
|
||||
{
|
||||
uint16_t len;
|
||||
|
|
|
|||
|
|
@ -47,6 +47,8 @@
|
|||
#include <pulsecore/strbuf.h>
|
||||
#include <pulsecore/poll.h>
|
||||
#include <pulsecore/ioline.h>
|
||||
#include <pulsecore/time-smoother.h>
|
||||
#include <pulsecore/rtclock.h>
|
||||
|
||||
#include "rtsp_client.h"
|
||||
|
||||
|
|
@ -467,9 +469,10 @@ int pa_rtsp_setup(pa_rtsp_client* c) {
|
|||
}
|
||||
|
||||
|
||||
int pa_rtsp_record(pa_rtsp_client* c) {
|
||||
int pa_rtsp_record(pa_rtsp_client* c, uint16_t* seq, uint32_t* rtptime) {
|
||||
pa_headerlist* headers;
|
||||
int rv;
|
||||
char *info;
|
||||
|
||||
pa_assert(c);
|
||||
if (!c->session) {
|
||||
|
|
@ -477,9 +480,14 @@ int pa_rtsp_record(pa_rtsp_client* c) {
|
|||
return -1;
|
||||
}
|
||||
|
||||
/* Todo: Generate these values randomly as per spec */
|
||||
*seq = *rtptime = 0;
|
||||
|
||||
headers = pa_headerlist_new();
|
||||
pa_headerlist_puts(headers, "Range", "npt=0-");
|
||||
pa_headerlist_puts(headers, "RTP-Info", "seq=0;rtptime=0");
|
||||
info = pa_sprintf_malloc("seq=%u;rtptime=%u", *seq, *rtptime);
|
||||
pa_headerlist_puts(headers, "RTP-Info", info);
|
||||
pa_xfree(info);
|
||||
|
||||
c->state = STATE_RECORD;
|
||||
rv = rtsp_exec(c, "RECORD", NULL, NULL, 1, headers);
|
||||
|
|
@ -506,14 +514,17 @@ int pa_rtsp_setparameter(pa_rtsp_client *c, const char* param) {
|
|||
}
|
||||
|
||||
|
||||
int pa_rtsp_flush(pa_rtsp_client *c) {
|
||||
int pa_rtsp_flush(pa_rtsp_client *c, uint16_t seq, uint32_t rtptime) {
|
||||
pa_headerlist* headers;
|
||||
int rv;
|
||||
char *info;
|
||||
|
||||
pa_assert(c);
|
||||
|
||||
headers = pa_headerlist_new();
|
||||
pa_headerlist_puts(headers, "RTP-Info", "seq=0;rtptime=0");
|
||||
info = pa_sprintf_malloc("seq=%u;rtptime=%u", seq, rtptime);
|
||||
pa_headerlist_puts(headers, "RTP-Info", info);
|
||||
pa_xfree(info);
|
||||
|
||||
c->state = STATE_FLUSH;
|
||||
rv = rtsp_exec(c, "FLUSH", NULL, NULL, 1, headers);
|
||||
|
|
|
|||
|
|
@ -66,10 +66,10 @@ void pa_rtsp_remove_header(pa_rtsp_client *c, const char* key);
|
|||
int pa_rtsp_announce(pa_rtsp_client* c, const char* sdp);
|
||||
|
||||
int pa_rtsp_setup(pa_rtsp_client* c);
|
||||
int pa_rtsp_record(pa_rtsp_client* c);
|
||||
int pa_rtsp_record(pa_rtsp_client* c, uint16_t* seq, uint32_t* rtptime);
|
||||
int pa_rtsp_teardown(pa_rtsp_client* c);
|
||||
|
||||
int pa_rtsp_setparameter(pa_rtsp_client* c, const char* param);
|
||||
int pa_rtsp_flush(pa_rtsp_client* c);
|
||||
int pa_rtsp_flush(pa_rtsp_client* c, uint16_t seq, uint32_t rtptime);
|
||||
|
||||
#endif
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue