Skip to content
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

Remove reset_gop_hash and update_gop_hash APIs #265

Merged
merged 2 commits into from
Dec 6, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions lib/src/signed_video_h26x_auth.c
Original file line number Diff line number Diff line change
Expand Up @@ -29,9 +29,9 @@
#include "legacy_validation.h"
#include "signed_video_authenticity.h" // create_local_authenticity_report_if_needed()
#include "signed_video_defines.h" // svrc_t
#include "signed_video_h26x_internal.h" // gop_state_*(), update_gop_hash(), update_validation_flags()
#include "signed_video_h26x_internal.h" // gop_state_*(), update_validation_flags()
#include "signed_video_h26x_nalu_list.h" // h26x_nalu_list_append()
#include "signed_video_internal.h" // gop_info_t, gop_state_t, reset_gop_hash()
#include "signed_video_internal.h" // gop_info_t, gop_state_t
#include "signed_video_openssl_internal.h" // openssl_{verify_hash, public_key_malloc}()
#include "signed_video_tlv.h" // tlv_find_tag()

Expand Down
35 changes: 2 additions & 33 deletions lib/src/signed_video_h26x_common.c
Original file line number Diff line number Diff line change
Expand Up @@ -271,18 +271,6 @@ set_hash_list_size(gop_info_t *gop_info, size_t hash_list_size)
return SV_OK;
}

svrc_t
reset_gop_hash(signed_video_t *self)
{
if (!self) return SV_INVALID_PARAMETER;

gop_info_t *gop_info = self->gop_info;
assert(gop_info);

gop_info->num_nalus_in_gop_hash = 0;
return openssl_hash_data(self->crypto_handle, &gop_info->gop_hash_init, 1, gop_info->gop_hash);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We should write a ticket to init the new gop hash computation with gop_hash_init.

}

/**
* Checks a pointer to member in struct if it's allocated, and correct size, then copies over the
* data to that member.
Expand Down Expand Up @@ -837,23 +825,6 @@ update_num_nalus_in_gop_hash(signed_video_t *self, const h26x_nalu_t *nalu)
}
}

svrc_t
update_gop_hash(void *crypto_handle, gop_info_t *gop_info)
{
if (!gop_info) return SV_INVALID_PARAMETER;

size_t hash_size = openssl_get_hash_size(crypto_handle);
svrc_t status = SV_UNKNOWN_FAILURE;
SV_TRY()
// Update the gop_hash, that is, hash the memory (both hashes) in hashes = [gop_hash, latest
// nalu_hash] and replace the gop_hash part with the new hash.
SV_THROW(openssl_hash_data(crypto_handle, gop_info->hashes, 2 * hash_size, gop_info->gop_hash));
SV_CATCH()
SV_DONE(status)

return status;
}

/* Initializes and updates the GOP hash regardless of available space. If there is enough
* room, copies the |hash| and updates |list_idx|. Otherwise, sets |list_idx| to -1.
*/
Expand Down Expand Up @@ -1070,7 +1041,6 @@ hash_and_add(signed_video_t *self, const h26x_nalu_t *nalu)
if (nalu->is_last_nalu_part) {
// The end of the NALU has been reached. Update hash list and GOP hash.
check_and_copy_hash_to_hash_list(self, nalu_hash, hash_size);
SV_THROW(update_gop_hash(self->crypto_handle, gop_info));
update_num_nalus_in_gop_hash(self, nalu);
}
SV_CATCH()
Expand Down Expand Up @@ -1171,8 +1141,7 @@ signed_video_create(SignedVideoCodec codec)

self->gop_info = gop_info_create();
SV_THROW_IF_WITH_MSG(!self->gop_info, SV_MEMORY, "Could not allocate gop_info");
SV_THROW_WITH_MSG(reset_gop_hash(self), "Could not reset gop_hash");

self->gop_info->num_nalus_in_gop_hash = 0;
// Setup vendor handle.
#ifdef SV_VENDOR_AXIS_COMMUNICATIONS
self->vendor_handle = sv_vendor_axis_communications_setup();
Expand Down Expand Up @@ -1250,7 +1219,7 @@ signed_video_reset(signed_video_t *self)
self->last_nalu->is_last_nalu_part = true;
SV_THROW(openssl_init_hash(self->crypto_handle, false));

SV_THROW(reset_gop_hash(self));
self->gop_info->num_nalus_in_gop_hash = 0;
SV_CATCH()
SV_DONE(status)

Expand Down
3 changes: 0 additions & 3 deletions lib/src/signed_video_h26x_internal.h
Original file line number Diff line number Diff line change
Expand Up @@ -171,9 +171,6 @@ gop_state_reset(gop_state_t *gop_state);
void
update_num_nalus_in_gop_hash(signed_video_t *signed_video, const h26x_nalu_t *nalu);

svrc_t
update_gop_hash(void *crypto_handle, gop_info_t *gop_info);

void
check_and_copy_hash_to_hash_list(signed_video_t *signed_video,
const uint8_t *hash,
Expand Down
6 changes: 3 additions & 3 deletions lib/src/signed_video_h26x_sign.c
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@
#include "signed_video_authenticity.h" // allocate_memory_and_copy_string
#include "signed_video_defines.h" // svrc_t, sv_tlv_tag_t
#include "signed_video_h26x_internal.h" // parse_nalu_info()
#include "signed_video_internal.h" // gop_info_t, reset_gop_hash()
#include "signed_video_internal.h" // gop_info_t
#include "signed_video_openssl_internal.h"
#include "signed_video_tlv.h" // tlv_list_encode_or_get_size()

Expand Down Expand Up @@ -354,8 +354,8 @@ generate_sei_nalu(signed_video_t *self, uint8_t **payload, uint8_t **payload_sig
memcpy(sign_data->hash, gop_info->gop_hash, hash_size);
}

// Reset the gop_hash since we start a new GOP.
SV_THROW(reset_gop_hash(self));
// Reset the |num_nalus_in_gop_hash| since we start a new GOP.
gop_info->num_nalus_in_gop_hash = 0;
// Reset the |hash_list| by rewinding the |list_idx| since we start a new GOP.
gop_info->list_idx = 0;

Expand Down
4 changes: 0 additions & 4 deletions lib/src/signed_video_internal.h
Original file line number Diff line number Diff line change
Expand Up @@ -269,10 +269,6 @@ struct_member_memory_allocated_and_copy(void **member_ptr,
svrc_t
set_hash_list_size(gop_info_t *gop_info, size_t hash_list_size);

/* Resets the gop_hash. */
svrc_t
reset_gop_hash(signed_video_t *signed_video);

void
product_info_free_members(signed_video_product_info_t *product_info);

Expand Down
Loading