From nobody Wed Jun 22 11:41:13 2022 X-Original-To: dev-commits-src-all@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 33EB5872135; Wed, 22 Jun 2022 11:41:14 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R3" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4LShKk0Yqkz4sL0; Wed, 22 Jun 2022 11:41:13 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1655898074; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=HwqNBhwj6hI1J6LFajCNHSlDNrlSdLqdJ4gtbP1S3ho=; b=xyxgbgRZ1zapwxTcv7+nkOUXbCCK9NMh58DmIka2QrH1UnqYVDx4TNMohECq7V2V0JhPXo azgolkmf+CoHT922W22CFA9Iit0Cp9gzJH+DtAmC15Y/FCHg49AAq6tixxP5MIygU3wFuO vr3sINRrjeS5qCZ+zTqRrSL/KOJ7agh9K3Y699hExeDst8gJLhyYK/BYcC44vwWj20k3If XTKDJRz1sSBxPeTVdpp46ba5PvLOMgju3U+hwlRcQC5mKhQJLH3kH21E8e8cSsN3Ka2ylR xspXV/IHdhC9RwYQ1UDDJ/leMB3t6KU3kYTIgC1uq6lTEGtEfugxANlp0roRdA== Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 7B1E425533; Wed, 22 Jun 2022 11:41:13 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.16.1/8.16.1) with ESMTP id 25MBfDsB023962; Wed, 22 Jun 2022 11:41:13 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.16.1/8.16.1/Submit) id 25MBfDmF023961; Wed, 22 Jun 2022 11:41:13 GMT (envelope-from git) Date: Wed, 22 Jun 2022 11:41:13 GMT Message-Id: <202206221141.25MBfDmF023961@gitrepo.freebsd.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-main@FreeBSD.org From: Dmitry Chagin Subject: git: 4d496ab44a09 - main - kdump: Decode Linux *at() syscalls List-Id: Commit messages for all branches of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-all List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-dev-commits-src-all@freebsd.org X-BeenThere: dev-commits-src-all@freebsd.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: dchagin X-Git-Repository: src X-Git-Refname: refs/heads/main X-Git-Reftype: branch X-Git-Commit: 4d496ab44a09a3a20dbec8968d1b4ef837ab10bb Auto-Submitted: auto-generated ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1655898074; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=HwqNBhwj6hI1J6LFajCNHSlDNrlSdLqdJ4gtbP1S3ho=; b=Eun149FV4zKDIYACgOO2rSCPCc2jShKXabgzFR9fNRkgsJH/f8PgvSSoWara94s3bjGCfl RT3swt652Qz8z2oekdWDK4fAUE5ppi5DbB1wmSVayLQ7t8Tj751/kG/NR+pHM5uZtl1dT8 slC1cz2isbj3W2AZ0xZo/gtmMcWvoHQIg1U5IytzqnAnanNVctX/GmGQfWjAIBTCIOwmOy 7WWFDqIT4t9n8Txlzbi4MV+kRbZ16UwUP1MdR7m1tQI2WVkX0WgXaJgHWzN8mcAirzNOjG Qr7jfxpNBvh3fB0kNRCDc/crU4OxSwBLCt7Qpqi+dwurCESQb41dxVevy8MjYw== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1655898074; a=rsa-sha256; cv=none; b=HB2Z1AN2GUxrEk2isIvOrQjEW4pKoteowuHndx3e2/6B56RTpxw3hW5nP+zcLIWWceMpGz 4jGKQBBobMuxjLubVAuRgxVHQTDtWhvlyTjvk61F4BVOPGW83GYVcglCF/eKR7MsW//ucQ WDWqLA99c602z0/tCtwHOFZfYAKYjDgOE7R4ATxgHuMgB0WwZPwFRnIMin6iMriDZu6bEE 0v980S2xGRy4GVGrzIaPtr1FFvnhjbN1lGwz9+pjtxvx6Pm42efD+b9jfO9MgMNs1FqTXH uX0vOsrDdNbmG71/Z1V8SbzNmDu6gqyEwEjrH+b+7yUTbKxqrzYdfGzAV8evGA== ARC-Authentication-Results: i=1; mx1.freebsd.org; none X-ThisMailContainsUnwantedMimeParts: N The branch main has been updated by dchagin: URL: https://cgit.FreeBSD.org/src/commit/?id=4d496ab44a09a3a20dbec8968d1b4ef837ab10bb commit 4d496ab44a09a3a20dbec8968d1b4ef837ab10bb Author: Dmitry Chagin AuthorDate: 2022-06-22 11:29:38 +0000 Commit: Dmitry Chagin CommitDate: 2022-06-22 11:29:38 +0000 kdump: Decode Linux *at() syscalls MFC after: 2 weeks --- usr.bin/kdump/linux.c | 235 +++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 232 insertions(+), 3 deletions(-) diff --git a/usr.bin/kdump/linux.c b/usr.bin/kdump/linux.c index 1d9768fc302d..109f7b84e622 100644 --- a/usr.bin/kdump/linux.c +++ b/usr.bin/kdump/linux.c @@ -41,15 +41,16 @@ __FBSDID("$FreeBSD$"); #include "kdump.h" #ifdef __amd64__ -#include +#include #include #elif __aarch64__ -#include +#include #elif __i386__ -#include +#include #endif #include +#include static void print_linux_signal(int signo) @@ -77,6 +78,99 @@ ktrsyscall_linux(struct ktr_syscall *ktr, register_t **resip, quad_align = 0; quad_slots = 1; switch (ktr->ktr_code) { + case LINUX_SYS_linux_faccessat: + case LINUX_SYS_linux_fchmodat: + case LINUX_SYS_linux_fchownat: +#ifdef LINUX_SYS_linux_newfstatat + case LINUX_SYS_linux_newfstatat: +#endif +#ifdef LINUX_SYS_linux_fstatat64 + case LINUX_SYS_linux_fstatat64: +#endif +#ifdef LINUX_SYS_linux_futimesat + case LINUX_SYS_linux_futimesat: +#endif + case LINUX_SYS_linux_linkat: + case LINUX_SYS_linux_mkdirat: + case LINUX_SYS_linux_mknodat: + case LINUX_SYS_linux_openat: + case LINUX_SYS_linux_readlinkat: + case LINUX_SYS_linux_renameat: + case LINUX_SYS_linux_unlinkat: + case LINUX_SYS_linux_utimensat: + putchar('('); + print_integer_arg_valid(sysdecode_atfd, *ip); + c = ','; + ip++; + narg--; + break; + } + switch (ktr->ktr_code) { +#ifdef LINUX_SYS_linux_access + case LINUX_SYS_linux_access: +#endif + case LINUX_SYS_linux_faccessat: + print_number(ip, narg, c); + putchar(','); + print_mask_arg(sysdecode_access_mode, *ip); + ip++; + narg--; + break; +#ifdef LINUX_SYS_linux_chmod + case LINUX_SYS_linux_chmod: +#endif + case LINUX_SYS_linux_fchmodat: + print_number(ip, narg, c); + putchar(','); + decode_filemode(*ip); + ip++; + narg--; + break; + case LINUX_SYS_linux_mknodat: + print_number(ip, narg, c); + putchar(','); + decode_filemode(*ip); + ip++; + narg--; + break; +#ifdef LINUX_SYS_linux_mkdir + case LINUX_SYS_linux_mkdir: +#endif + case LINUX_SYS_linux_mkdirat: + print_number(ip, narg, c); + putchar(','); + decode_filemode(*ip); + ip++; + narg--; + break; + case LINUX_SYS_linux_linkat: + case LINUX_SYS_linux_renameat: + case LINUX_SYS_linux_symlinkat: + print_number(ip, narg, c); + putchar(','); + print_integer_arg_valid(sysdecode_atfd, *ip); + ip++; + narg--; + print_number(ip, narg, c); + break; + case LINUX_SYS_linux_fchownat: + print_number(ip, narg, c); + print_number(ip, narg, c); + print_number(ip, narg, c); + break; +#ifdef LINUX_SYS_linux_newfstatat + case LINUX_SYS_linux_newfstatat: +#endif +#ifdef LINUX_SYS_linux_fstatat64 + case LINUX_SYS_linux_fstatat64: +#endif + case LINUX_SYS_linux_utimensat: + print_number(ip, narg, c); + print_number(ip, narg, c); + break; + case LINUX_SYS_linux_unlinkat: + print_number(ip, narg, c); + break; case LINUX_SYS_linux_clock_gettime: case LINUX_SYS_linux_clock_settime: case LINUX_SYS_linux_clock_getres: @@ -116,6 +210,20 @@ ktrsyscall_linux(struct ktr_syscall *ktr, register_t **resip, ip++; narg--; break; +#ifdef LINUX_SYS_linux_open + case LINUX_SYS_linux_open: +#endif + case LINUX_SYS_linux_openat: + print_number(ip, narg, c); + putchar(','); + print_mask_arg(sysdecode_linux_open_flags, ip[0]); + if ((ip[0] & LINUX_O_CREAT) == LINUX_O_CREAT) { + putchar(','); + decode_filemode(ip[1]); + } + ip += 2; + narg -= 2; + break; case LINUX_SYS_linux_rt_sigaction: putchar('('); print_linux_signal(*ip); @@ -147,6 +255,25 @@ ktrsyscall_linux(struct ktr_syscall *ktr, register_t **resip, c = ','; break; } + switch (ktr->ktr_code) { + case LINUX_SYS_linux_fchownat: + case LINUX_SYS_linux_faccessat: + case LINUX_SYS_linux_fchmodat: +#ifdef LINUX_SYS_linux_newfstatat + case LINUX_SYS_linux_newfstatat: +#endif +#ifdef LINUX_SYS_linux_fstatat64 + case LINUX_SYS_linux_fstatat64: +#endif + case LINUX_SYS_linux_linkat: + case LINUX_SYS_linux_unlinkat: + case LINUX_SYS_linux_utimensat: + putchar(','); + print_mask_arg0(sysdecode_linux_atflags, *ip); + ip++; + narg--; + break; + } *resc = c; *resip = ip; *resnarg = narg; @@ -167,6 +294,82 @@ ktrsyscall_linux32(struct ktr_syscall *ktr, register_t **resip, quad_align = 0; quad_slots = 2; switch (ktr->ktr_code) { + case LINUX32_SYS_linux_faccessat: + case LINUX32_SYS_linux_fchmodat: + case LINUX32_SYS_linux_fchownat: + case LINUX32_SYS_linux_fstatat64: + case LINUX32_SYS_linux_futimesat: + case LINUX32_SYS_linux_linkat: + case LINUX32_SYS_linux_mkdirat: + case LINUX32_SYS_linux_mknodat: + case LINUX32_SYS_linux_openat: + case LINUX32_SYS_linux_readlinkat: + case LINUX32_SYS_linux_renameat: + case LINUX32_SYS_linux_unlinkat: + case LINUX32_SYS_linux_utimensat: + putchar('('); + print_integer_arg_valid(sysdecode_atfd, *ip); + c = ','; + ip++; + narg--; + break; + } + switch (ktr->ktr_code) { + case LINUX32_SYS_linux_access: + case LINUX32_SYS_linux_faccessat: + print_number(ip, narg, c); + putchar(','); + print_mask_arg(sysdecode_access_mode, *ip); + ip++; + narg--; + break; + case LINUX32_SYS_linux_chmod: + case LINUX32_SYS_fchmod: + case LINUX32_SYS_linux_fchmodat: + print_number(ip, narg, c); + putchar(','); + decode_filemode(*ip); + ip++; + narg--; + break; + case LINUX32_SYS_linux_mknodat: + print_number(ip, narg, c); + putchar(','); + decode_filemode(*ip); + ip++; + narg--; + break; + case LINUX32_SYS_linux_mkdir: + case LINUX32_SYS_linux_mkdirat: + print_number(ip, narg, c); + putchar(','); + decode_filemode(*ip); + ip++; + narg--; + break; + case LINUX32_SYS_linux_linkat: + case LINUX32_SYS_linux_renameat: + case LINUX32_SYS_linux_symlinkat: + print_number(ip, narg, c); + putchar(','); + print_integer_arg_valid(sysdecode_atfd, *ip); + ip++; + narg--; + print_number(ip, narg, c); + break; + case LINUX32_SYS_linux_fchownat: + print_number(ip, narg, c); + print_number(ip, narg, c); + print_number(ip, narg, c); + break; + case LINUX32_SYS_linux_fstatat64: + case LINUX32_SYS_linux_utimensat: + print_number(ip, narg, c); + print_number(ip, narg, c); + break; + case LINUX32_SYS_linux_unlinkat: + print_number(ip, narg, c); + break; case LINUX32_SYS_linux_clock_gettime: case LINUX32_SYS_linux_clock_settime: case LINUX32_SYS_linux_clock_getres: @@ -209,6 +412,18 @@ ktrsyscall_linux32(struct ktr_syscall *ktr, register_t **resip, ip++; narg--; break; + case LINUX32_SYS_linux_open: + case LINUX32_SYS_linux_openat: + print_number(ip, narg, c); + putchar(','); + print_mask_arg(sysdecode_linux_open_flags, ip[0]); + if ((ip[0] & LINUX_O_CREAT) == LINUX_O_CREAT) { + putchar(','); + decode_filemode(ip[1]); + } + ip += 2; + narg -= 2; + break; case LINUX32_SYS_linux_signal: case LINUX32_SYS_linux_sigaction: case LINUX32_SYS_linux_rt_sigaction: @@ -240,6 +455,20 @@ ktrsyscall_linux32(struct ktr_syscall *ktr, register_t **resip, c = ','; break; } + switch (ktr->ktr_code) { + case LINUX32_SYS_linux_fchownat: + case LINUX32_SYS_linux_faccessat: + case LINUX32_SYS_linux_fchmodat: + case LINUX32_SYS_linux_fstatat64: + case LINUX32_SYS_linux_linkat: + case LINUX32_SYS_linux_unlinkat: + case LINUX32_SYS_linux_utimensat: + putchar(','); + print_mask_arg0(sysdecode_linux_atflags, *ip); + ip++; + narg--; + break; + } *resc = c; *resip = ip; *resnarg = narg;