草庐IT

CAP_SYS_RAWIO

全部标签

c - 为什么 glibc 的 fork 实现没有使用 sys_fork?

在eglibc的nptl/sysdeps/unix/sysv/linux/i386/fork.c中有一个定义:#defineARCH_FORK()\INLINE_SYSCALL(clone,5,\CLONE_CHILD_SETTID|CLONE_CHILD_CLEARTID|SIGCHLD,0,\NULL,NULL,&THREAD_SELF->tid)在实际的__libc_fork()中用作实现的核心。但是例如在Linux的arch/x86/entry/syscalls/syscall_32.tbl中存在一个sys_fork条目,在syscalls_64.tbl中也是如此。所以显然Li

linux -/sys/device/和 dmidecode 报告的不同 CPU 缓存大小

我正在尝试获取系统中不同缓存级别的大小。我尝试了两种技术。a)使用来自/sys/device的信息。这是输出。$cat/sys/devices/system/cpu/cpu0/cache/index1/size32K$cat/sys/devices/system/cpu/cpu0/cache/index2/size256K$cat/sys/devices/system/cpu/cpu0/cache/index3/size8192Kb)使用来自dmidecode的信息$sudodmidecode-tcacheCacheInformationSocketDesignation:CPUInt

linux - 为什么 time.h 中的 time() 没有对 sys_time 的系统调用?

我编写了一个非常简单的程序,调用了time()来说明strace的用法,但是我遇到了问题;time()调用似乎实际上并没有产生系统调用!我最终进入了GDB中的time()函数,现在我比以往任何时候都更加困惑。来自time()函数的反汇编:0x7ffff7ffad90:pushrbp0x7ffff7ffad91:testrdi,rdi0x7ffff7ffad94:movrax,QWORDPTR[rip+0xffffffffffffd30d]#0x7ffff7ff80a80x7ffff7ffad9b:movrbp,rsp0x7ffff7ffad9e:je0x7ffff7ffada30x7f

c++ - 在 linux/sys/class/gpio 中写入文件的错误

我现在遇到了我在Linux系统上见过的最奇怪的错误,似乎只有两种可能的解释-要么附加sudo使文件立即写入或者附加sudo会在执行语句时产生短暂的延迟或者我不知道我的程序发生了什么好吧,让我给你一些背景知识。我目前正在编写一个用于raspberrypigpio操作的c++程序。据我所知,程序中没有明显的错误,因为它成功地与sudo一起工作并且也成功地延迟了。所以这里是rpi的gpio是如何工作的-Firstyou'vetoexportone,toreserveitformanipulation,itwillcreateanewdirectoryasgpio+numberwithseve

linux - 如何为 Linux 用户设置 CAP_SYS_NICE 能力?

我的程序正在使用Linux系统调用setpriority()来更改它创建的线程的优先级。它需要设置负优先级(-10),但如文档中所述,以普通用户身份运行时会失败。用户需要CAP_SYS_NICE能力来设置他想要的优先级,但我不知道如何给用户这样的能力。所以我的问题是:如何为Linux用户设置CAP_SYS_NICE功能? 最佳答案 有一个非常方便的实用程序可用于设置二进制文件的功能:setcap。这需要在您的应用程序二进制文件上以root身份运行,但一旦设置,就可以作为普通用户运行。示例:$sudosetcap'cap_sys_ni

c - __NR_gettid 和 SYS_gettid 之间的区别

我只是在寻找在Linux中获取唯一线程ID的方法。我发现的方法是使用以下两个参数之一作为参数执行系统调用:__NR_gettid或SYS_gettid。谁能解释一下它们之间有何不同? 最佳答案 没有在有这个:#defineSYS_gettid__NR_gettid 关于c-__NR_gettid和SYS_gettid之间的区别,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/223

linux - 原始捕获功能(CAP_NET_RAW、CAP_NET_ADMIN)在/usr/bin 和使用 libpcap 的数据包捕获程序之外不起作用

TL;DR:为什么cap_net_raw、cap_net_admin功能只能在/usr/bin(或/usr/sbin),但不是其他地方?这可以在某个地方配置吗?我在Ubuntu14.04中使用libpcap为我的C程序分配功能时遇到问题。即使在使用setcap(8)分配功能并使用getcap(8)检查它之后,我仍然遇到权限错误。似乎功能仅适用于\usr\bin和friend中的可执行文件。我的程序test.c如下所示:#include#includeintmain(intargc,char**argv){if(argc!=2){printf("Specifyinterface\n");

c - 在保留 CAP_SYS_NICE 的同时删除根 UID

我正在尝试编写一个守护进程,它将使用setuid位以root身份启动,然后快速恢复到运行该进程的用户。然而,守护进程需要保留将新线程设置为“实时”优先级的能力。我用来设置优先级的代码如下(一旦创建就在线程中运行):structsched_paramsched_param;memset(&sched_param,0,sizeof(sched_param));sched_param.sched_priority=90;if(-1==sched_setscheduler(0,SCHED_FIFO,&sched_param)){//Ifwegethere,wehaveanerror,forex

linux - 为什么sys_read系统调用检测到换行就结束?

我是汇编的初学者(使用nasm)。我正在通过大学类(class)学习汇编。我试图了解sys_readlinux系统调用在被调用时的行为。具体来说,sys_read在读取新行或换行符时停止。根据我所受的教导,这是真的。这onlinetutorialarticle也证实了事实/主张。Whensys_readdetectsalinefeed,controlreturnstotheprogramandtheusersinputislocatedatthememoryaddressyoupassedinECX.我检查了linux程序员手册中的sys_read调用(通过“man2read”)。它没

php - 共享主机环境中的 sys_get_temp_dir

注意:这也适合super用户。我正在使用apache2mpmitk和open_basedir在共享主机上设置PHP5.3.10,每个用户可能看不到或更改其他用户的文件。在apache2vhost设置中,我添加了相应的条目来限制用户:AssignUserIduserAuserAphp_admin_valueopen_basedir/home/userA/www/php_admin_valueupload_tmp_dir/home/userA/www/tmp/php_admin_valuesession.save_path/home/userA/www/tmp/SetEnvTMPDIR/h