Skip to content

Commit

Permalink
introduce xxx2 api
Browse files Browse the repository at this point in the history
  • Loading branch information
pabuhler committed Dec 1, 2023
1 parent 8d24f9c commit deb4c84
Show file tree
Hide file tree
Showing 4 changed files with 282 additions and 124 deletions.
1 change: 1 addition & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -345,6 +345,7 @@ if(LIBSRTP_TEST_APPS)
test/util.c test/getopt_s.c)
target_link_libraries(srtp_driver srtp2)
add_test(srtp_driver srtp_driver -v)
add_test(srtp_driver_x2 srtp_driver -v -n)

if(NOT (BUILD_SHARED_LIBS AND WIN32))
add_executable(test_srtp test/test_srtp.c)
Expand Down
30 changes: 30 additions & 0 deletions include/srtp.h
Original file line number Diff line number Diff line change
Expand Up @@ -478,6 +478,14 @@ srtp_err_status_t srtp_protect_mki(srtp_ctx_t *ctx,
unsigned int use_mki,
unsigned int mki_index);

srtp_err_status_t srtp_protect2(srtp_t ctx,
const void *rtp,
int rtp_len,
void *srtp,
int *srtp_len,
unsigned int use_mki,
unsigned int mki_index);

/**
* @brief srtp_unprotect() is the Secure RTP receiver-side packet
* processing function.
Expand Down Expand Up @@ -571,6 +579,13 @@ srtp_err_status_t srtp_unprotect_mki(srtp_t ctx,
int *len_ptr,
unsigned int use_mki);

srtp_err_status_t srtp_unprotect2(srtp_t ctx,
const void *srtp,
int srtp_len,
void *rtp,
int *rtp_len,
unsigned int use_mki);

/**
* @brief srtp_create() allocates and initializes an SRTP session.
Expand Down Expand Up @@ -1382,6 +1397,14 @@ srtp_err_status_t srtp_protect_rtcp_mki(srtp_t ctx,
unsigned int use_mki,
unsigned int mki_index);

srtp_err_status_t srtp_protect_rtcp2(srtp_t ctx,
const void *rtcp,
int rtcp_len,
void *srtcp,
int *srtcp_len,
unsigned int use_mki,
unsigned int mki_index);

/**
* @brief srtp_unprotect_rtcp() is the Secure RTCP receiver-side packet
* processing function.
Expand Down Expand Up @@ -1474,6 +1497,13 @@ srtp_err_status_t srtp_unprotect_rtcp_mki(srtp_t ctx,
int *pkt_octet_len,
unsigned int use_mki);

srtp_err_status_t srtp_unprotect_rtcp2(srtp_t ctx,
const void *srtcp,
int srtcp_len,
void *rtcp,
int *rtcp_len,
unsigned int use_mki);

/**
* @}
*/
Expand Down
64 changes: 64 additions & 0 deletions srtp/srtp.c
Original file line number Diff line number Diff line change
Expand Up @@ -2142,6 +2142,22 @@ srtp_err_status_t srtp_protect(srtp_ctx_t *ctx,
return srtp_protect_mki(ctx, rtp_hdr, pkt_octet_len, 0, 0);
}

srtp_err_status_t srtp_protect2(srtp_t ctx,
const void *rtp,
int rtp_len,
void *srtp,
int *srtp_len,
unsigned int use_mki,
unsigned int mki_index)
{
if (*srtp_len < rtp_len) {
return srtp_err_status_bad_param;
}
memcpy(srtp, rtp, rtp_len);
*srtp_len = rtp_len;
return srtp_protect_mki(ctx, srtp, srtp_len, use_mki, mki_index);
}

srtp_err_status_t srtp_protect_mki(srtp_ctx_t *ctx,
void *rtp_hdr,
int *pkt_octet_len,
Expand Down Expand Up @@ -2470,6 +2486,22 @@ srtp_err_status_t srtp_unprotect(srtp_ctx_t *ctx,
return srtp_unprotect_mki(ctx, srtp_hdr, pkt_octet_len, 0);
}

srtp_err_status_t srtp_unprotect2(srtp_t ctx,
const void *srtp,
int srtp_len,
void *rtp,
int *rtp_len,
unsigned int use_mki)
{
if (*rtp_len < srtp_len) {
// this is actually expected but for the tests this should not happen
return srtp_err_status_bad_param;
}
memcpy(rtp, srtp, srtp_len);
*rtp_len = srtp_len;
return srtp_unprotect_mki(ctx, rtp, rtp_len, use_mki);
}

srtp_err_status_t srtp_unprotect_mki(srtp_ctx_t *ctx,
void *srtp_hdr,
int *pkt_octet_len,
Expand Down Expand Up @@ -3987,6 +4019,22 @@ srtp_err_status_t srtp_protect_rtcp(srtp_t ctx,
return srtp_protect_rtcp_mki(ctx, rtcp_hdr, pkt_octet_len, 0, 0);
}

srtp_err_status_t srtp_protect_rtcp2(srtp_t ctx,
const void *rtcp,
int rtcp_len,
void *srtcp,
int *srtcp_len,
unsigned int use_mki,
unsigned int mki_index)
{
if (*srtcp_len < rtcp_len) {
return srtp_err_status_bad_param;
}
memcpy(srtcp, rtcp, rtcp_len);
*srtcp_len = rtcp_len;
return srtp_protect_rtcp_mki(ctx, srtcp, srtcp_len, use_mki, mki_index);
}

srtp_err_status_t srtp_protect_rtcp_mki(srtp_t ctx,
void *rtcp_hdr,
int *pkt_octet_len,
Expand Down Expand Up @@ -4219,6 +4267,22 @@ srtp_err_status_t srtp_unprotect_rtcp(srtp_t ctx,
return srtp_unprotect_rtcp_mki(ctx, srtcp_hdr, pkt_octet_len, 0);
}

srtp_err_status_t srtp_unprotect_rtcp2(srtp_t ctx,
const void *srtcp,
int srtcp_len,
void *rtcp,
int *rtcp_len,
unsigned int use_mki)
{
if (*rtcp_len < srtcp_len) {
// this is actually expected but for the tests this should not happen
return srtp_err_status_bad_param;
}
memcpy(rtcp, srtcp, srtcp_len);
*rtcp_len = srtcp_len;
return srtp_unprotect_rtcp_mki(ctx, rtcp, rtcp_len, use_mki);
}

srtp_err_status_t srtp_unprotect_rtcp_mki(srtp_t ctx,
void *srtcp_hdr,
int *pkt_octet_len,
Expand Down
Loading

0 comments on commit deb4c84

Please sign in to comment.