Skip to content

Commit

Permalink
Improved the capabilities feature detection.
Browse files Browse the repository at this point in the history
Previously included file sys/capability.h mentioned in capset(2) man page,
belongs to the libcap-dev package, which may not be installed on some Linux
systems when compiling nginx.  This prevented the capabilities feature from
being detected and compiled on that systems.

Now linux/capability.h system header is included instead.  Since capset()
declaration is located in sys/capability.h, now capset() syscall is defined
explicitly in code using the SYS_capset constant, similarly to other
Linux-specific features in nginx.
  • Loading branch information
arut committed Dec 18, 2017
1 parent 752f66b commit 0e92c21
Show file tree
Hide file tree
Showing 3 changed files with 5 additions and 4 deletions.
5 changes: 3 additions & 2 deletions auto/os/linux
Original file line number Diff line number Diff line change
Expand Up @@ -174,7 +174,8 @@ ngx_feature_test="if (prctl(PR_SET_KEEPCAPS, 1, 0, 0, 0) == -1) return 1"
ngx_feature="capabilities"
ngx_feature_name="NGX_HAVE_CAPABILITIES"
ngx_feature_run=no
ngx_feature_incs="#include <sys/capability.h>"
ngx_feature_incs="#include <linux/capability.h>
#include <sys/syscall.h>"
ngx_feature_path=
ngx_feature_libs=
ngx_feature_test="struct __user_cap_data_struct data;
Expand All @@ -184,7 +185,7 @@ ngx_feature_test="struct __user_cap_data_struct data;
data.effective = CAP_TO_MASK(CAP_NET_RAW);
data.permitted = 0;

(void) capset(&header, &data)"
(void) SYS_capset"
. auto/feature


Expand Down
2 changes: 1 addition & 1 deletion src/os/unix/ngx_linux_config.h
Original file line number Diff line number Diff line change
Expand Up @@ -100,7 +100,7 @@ typedef struct iocb ngx_aiocb_t;


#if (NGX_HAVE_CAPABILITIES)
#include <sys/capability.h>
#include <linux/capability.h>
#endif


Expand Down
2 changes: 1 addition & 1 deletion src/os/unix/ngx_process_cycle.c
Original file line number Diff line number Diff line change
Expand Up @@ -869,7 +869,7 @@ ngx_worker_process_init(ngx_cycle_t *cycle, ngx_int_t worker)
data.effective = CAP_TO_MASK(CAP_NET_RAW);
data.permitted = data.effective;

if (capset(&header, &data) == -1) {
if (syscall(SYS_capset, &header, &data) == -1) {
ngx_log_error(NGX_LOG_EMERG, cycle->log, ngx_errno,
"capset() failed");
/* fatal */
Expand Down

0 comments on commit 0e92c21

Please sign in to comment.