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

CDRIVER-5756 Coverity fixes #1867

Open
wants to merge 14 commits into
base: master
Choose a base branch
from

Conversation

rcsanchez97
Copy link
Collaborator

This PR fixes some small Coverity issues (w/ full Evergreen patch build).

@kevinAlbs I wasn't sure who would be available to review, so please feel free to adjust the reviewers as needed.

@rcsanchez97 rcsanchez97 changed the title Coverity fixes CDRIVER-5756 Coverity fixes Feb 15, 2025
Copy link
Collaborator

@vector-of-bool vector-of-bool left a comment

Choose a reason for hiding this comment

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

A few comments and questions.

Comment on lines +314 to +319
bson_mutex_lock (&topology->tpld_modification_mtx);
for (size_t i = 0u; i < n_rtt_monitors; i++) {
server_monitor = mongoc_set_get_item (topology->rtt_monitors, i);
mongoc_server_monitor_request_shutdown (server_monitor);
}
bson_mutex_unlock (&topology->tpld_modification_mtx);
Copy link
Collaborator

Choose a reason for hiding this comment

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

I'm not sure if this mutex is relevant here. Do you have a link to the Coverity warning related to these lines?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

I sent you the link in a DM.

Comment on lines 1151 to +1154
jsn->jprs = (jsonsl_jpr_t *)malloc(sizeof(jsonsl_jpr_t) * njprs);
if (!jsn->jprs) {
return;
}
Copy link
Collaborator

Choose a reason for hiding this comment

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

Suggested change
jsn->jprs = (jsonsl_jpr_t *)malloc(sizeof(jsonsl_jpr_t) * njprs);
if (!jsn->jprs) {
return;
}
jsn->jprs = (jsonsl_jpr_t *) bson_malloc (sizeof (jsonsl_jpr_t) * njprs);

Suggest using bson_malloc. bson_malloc already checks (and aborts) if allocation fails. I expect that will fix the Coverity warning. Using bson_malloc ensures allocators set with bson_mem_set_vtable are used.

Also replace free(jsn->jprs); with bson_free(jsn->jprs);

Comment on lines 1156 to +1160
jsn->jpr_root = (size_t*)calloc(1, sizeof(size_t) * njprs * jsn->levels_max);
if (!jsn->jpr_root) {
free(jsn->jprs);
return;
}
Copy link
Collaborator

Choose a reason for hiding this comment

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

Suggested change
jsn->jpr_root = (size_t*)calloc(1, sizeof(size_t) * njprs * jsn->levels_max);
if (!jsn->jpr_root) {
free(jsn->jprs);
return;
}
jsn->jpr_root = (size_t *) bson_malloc0 (sizeof (size_t) * njprs * jsn->levels_max);

Similarly, use bson_malloc0 in place of calloc. Suggest updating other malloc / free calls in this file.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

OK. That makes sense. Should I do that as a drive-by in this PR, or a separate PR?

Copy link
Collaborator

Choose a reason for hiding this comment

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

I think it is OK to include in this PR. Though the other malloc calls check their returns, I think it is a related enough change to include in this PR.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants