-
Notifications
You must be signed in to change notification settings - Fork 487
Allow overriding stream list implementation #612
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
Merged
Changes from all commits
Commits
Show all changes
15 commits
Select commit
Hold shift + click to select a range
6a8eea3
add stream list interface
mildsunrise b8734bb
1/2 use it
mildsunrise 8e31471
2/2 use it
mildsunrise feac4ce
use in update_template_streams()
mildsunrise 6653a86
use in get_protect_trailer_length
mildsunrise f161ac1
expose missing internal method
mildsunrise 6b0aa2d
update tests
mildsunrise 55f409f
allow insertions to fail
mildsunrise 0bc8b9b
(format)
mildsunrise b2932b3
Merge remote-tracking branch 'origin/main' into pr/mildsunrise/612
pabuhler 523c2a9
fix compile after merge
pabuhler 914cb55
alternative stream list api and unit tests for the api
pabuhler 8ef4084
use cmake to build and run test
pabuhler 07334b2
move stream list replace test to own CI work flow
pabuhler d1eb03a
address comments from review, no function change
pabuhler File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
name: Stream List CI | ||
|
||
on: | ||
push: | ||
branches: [ main ] | ||
pull_request: | ||
branches: [ main ] | ||
|
||
jobs: | ||
build: | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
os: [ubuntu-latest, macos-latest, windows-latest] | ||
|
||
runs-on: ${{ matrix.os }} | ||
|
||
env: | ||
CTEST_OUTPUT_ON_FAILURE: 1 | ||
|
||
steps: | ||
|
||
- uses: actions/checkout@v2 | ||
|
||
- name: Create Build Environment | ||
run: cmake -E make_directory ${{github.workspace}}/build | ||
|
||
- name: Configure CMake | ||
working-directory: ${{github.workspace}}/build | ||
shell: bash | ||
run: cmake $GITHUB_WORKSPACE -DBUILD_WITH_SANITIZERS=TRUE -DCMAKE_C_FLAGS:STRING="-DSRTP_NO_STREAM_LIST -DSRTP_USE_TEST_STREAM_LIST" | ||
|
||
- name: Build | ||
working-directory: ${{github.workspace}}/build | ||
shell: bash | ||
run: cmake --build . -t srtp_driver | ||
|
||
- name: Test | ||
working-directory: ${{github.workspace}}/build | ||
shell: bash | ||
run: ctest -R srtp_driver |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,122 @@ | ||
/* | ||
* stream_list_priv.h | ||
* | ||
* list of SRTP streams, keyed by SSRC | ||
* | ||
* Alba Mendez | ||
*/ | ||
/* | ||
* | ||
* Copyright (c) 2001-2017, Cisco Systems, Inc. | ||
* Copyright (c) 2022, Dolby Laboratories, Inc. | ||
* All rights reserved. | ||
* | ||
* Redistribution and use in source and binary forms, with or without | ||
* modification, are permitted provided that the following conditions | ||
* are met: | ||
* | ||
* Redistributions of source code must retain the above copyright | ||
* notice, this list of conditions and the following disclaimer. | ||
* | ||
* Redistributions in binary form must reproduce the above | ||
* copyright notice, this list of conditions and the following | ||
* disclaimer in the documentation and/or other materials provided | ||
* with the distribution. | ||
* | ||
* Neither the name of the Cisco Systems, Inc. nor the names of its | ||
* contributors may be used to endorse or promote products derived | ||
* from this software without specific prior written permission. | ||
* | ||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS | ||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE | ||
* COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, | ||
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | ||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, | ||
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | ||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED | ||
* OF THE POSSIBILITY OF SUCH DAMAGE. | ||
* | ||
*/ | ||
|
||
#ifndef SRTP_STREAM_LIST_PRIV_H | ||
#define SRTP_STREAM_LIST_PRIV_H | ||
|
||
#include <srtp_priv.h> | ||
|
||
#ifdef __cplusplus | ||
extern "C" { | ||
#endif | ||
|
||
/** | ||
* srtp_stream_list_t holds a list of srtp_stream_t, each identified | ||
* by their SSRC. | ||
* | ||
* the API was extracted to allow downstreams to override its | ||
* implementation by defining the `SRTP_NO_STREAM_LIST` preprocessor | ||
* directive, which removes the default implementation of these | ||
* functions. if this is done, the `next` & `prev` fields are free for | ||
* the implementation to use. | ||
pabuhler marked this conversation as resolved.
Show resolved
Hide resolved
|
||
* | ||
* this is still an internal interface; there is no stability | ||
* guarantee--downstreams should watch this file for changes in | ||
* signatures or semantics. | ||
*/ | ||
|
||
/** | ||
* allocate and initialize a stream list instance | ||
*/ | ||
srtp_err_status_t srtp_stream_list_alloc(srtp_stream_list_t *list_ptr); | ||
|
||
/** | ||
* deallocate a stream list instance | ||
* | ||
* the list must be empty or else an error is returned. | ||
*/ | ||
srtp_err_status_t srtp_stream_list_dealloc(srtp_stream_list_t list); | ||
|
||
/** | ||
* insert a stream into the list | ||
* | ||
* returns srtp_err_status_alloc_fail if insertion failed due to unavailable | ||
* capacity in the list. if operation succeeds, srtp_err_status_ok is returned | ||
* | ||
* if another stream with the same SSRC already exists in the list, | ||
* behavior is undefined. if the SSRC field is mutated while the | ||
* stream is inserted, further operations have undefined behavior | ||
bifurcation marked this conversation as resolved.
Show resolved
Hide resolved
|
||
*/ | ||
srtp_err_status_t srtp_stream_list_insert(srtp_stream_list_t list, | ||
srtp_stream_t stream); | ||
|
||
/* | ||
* look up the stream corresponding to the specified SSRC and return it. | ||
* if no such SSRC is found, NULL is returned. | ||
*/ | ||
srtp_stream_t srtp_stream_list_get(srtp_stream_list_t list, uint32_t ssrc); | ||
|
||
/** | ||
* remove the stream from the list. | ||
* | ||
* The stream to be removed is referenced "by value", i.e., by the pointer to be | ||
* removed from the list. This pointer is obtained using `srtp_stream_list_get` | ||
* or as callback parameter in `srtp_stream_list_for_each`. | ||
*/ | ||
void srtp_stream_list_remove(srtp_stream_list_t list, srtp_stream_t stream); | ||
pabuhler marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
/** | ||
* iterate through all stored streams. while iterating, it is allowed to delete | ||
* the current element; any other mutation to the list is undefined behavior. | ||
* returning non-zero from callback aborts the iteration. | ||
*/ | ||
void srtp_stream_list_for_each(srtp_stream_list_t list, | ||
int (*callback)(srtp_stream_t, void *), | ||
void *data); | ||
|
||
#ifdef __cplusplus | ||
} | ||
#endif | ||
|
||
#endif /* SRTP_STREAM_LIST_PRIV_H */ |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Uh oh!
There was an error while loading. Please reload this page.