Skip to content

Commit

Permalink
Try to set stronger controls on arguments
Browse files Browse the repository at this point in the history
  • Loading branch information
jcpunk committed Jul 24, 2024
1 parent ff71817 commit 0ffeb45
Show file tree
Hide file tree
Showing 3 changed files with 5 additions and 5 deletions.
4 changes: 2 additions & 2 deletions src/C/kcron_caps.h
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ static void print_cap_error(const char *mode, const cap_value_t expected_cap[],
}
}

int enable_capabilities(const cap_value_t expected_cap[], const int num_caps) __attribute__((nonnull(1))) __attribute__((warn_unused_result)) __attribute__((flatten)) __attribute__((hot));
int enable_capabilities(const cap_value_t expected_cap[], const int num_caps) __attribute__((nonnull(1))) __attribute__((warn_unused_result)) __attribute__((flatten)) __attribute__((hot)) __attribute__((access(read_only, 1))) __attribute__((access(read_only, 2)));
int enable_capabilities(const cap_value_t expected_cap[], const int num_caps) {
cap_t capabilities = cap_get_proc();

Expand Down Expand Up @@ -124,7 +124,7 @@ int disable_capabilities(void) {
return 0;
}

int enable_capabilities(const cap_value_t expected_cap[], const int num_caps) __attribute__((nonnull(1))) __attribute__((warn_unused_result)) __attribute__((flatten));
int enable_capabilities(const cap_value_t expected_cap[], const int num_caps) __attribute__((nonnull(1))) __attribute__((warn_unused_result)) __attribute__((flatten)) __attribute__((access(read_only, 1))) __attribute__((access(read_only, 2)));
int enable_capabilities(const cap_value_t expected_cap[], const int num_caps) {
DTRACE_PROBE1(__PROGRAM_NAME, "cap-set-flag-permitted", 2);
DTRACE_PROBE1(__PROGRAM_NAME, "cap-set-flag-effective", 2);
Expand Down
2 changes: 1 addition & 1 deletion src/C/kcron_empty_keytab_file.h
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@
#include <stdio.h>
#include <stdlib.h>

int write_empty_keytab(int filedescriptor) __attribute__((warn_unused_result));
int write_empty_keytab(int filedescriptor) __attribute__((warn_unused_result)) __attribute__((fd_arg_write));
int write_empty_keytab(int filedescriptor) {

if (filedescriptor == 0) {
Expand Down
4 changes: 2 additions & 2 deletions src/C/kcron_filename.h
Original file line number Diff line number Diff line change
Expand Up @@ -60,8 +60,8 @@ int get_client_dirname(char *keytab_dir) {
return 0;
}

int get_filenames(char *keytab_dir, char *keytab_filename, char *keytab) __attribute__((nonnull(1, 2, 3))) __attribute__((access(read_write, 1)))
__attribute((access(read_write, 2))) __attribute((access(read_write, 3))) __attribute__((warn_unused_result)) __attribute__((flatten));
int get_filenames(char *keytab_dir, char *keytab_filename, char *keytab) __attribute__((nonnull(1, 2, 3))) __attribute__((access(read_only, 1)))
__attribute((access(read_only, 2))) __attribute((access(read_write, 3))) __attribute__((warn_unused_result)) __attribute__((flatten));
int get_filenames(char *keytab_dir, char *keytab_filename, char *keytab) {

const uid_t uid = getuid();
Expand Down

0 comments on commit 0ffeb45

Please sign in to comment.