From: Leo Yan <leo.yan@arm.com>
To: James Clark <james.clark@linaro.org>
Cc: Arnd Bergmann <arnd@arndb.de>,
linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org,
Arnaldo Carvalho de Melo <acme@kernel.org>,
Namhyung Kim <namhyung@kernel.org>, Jiri Olsa <jolsa@kernel.org>,
Ian Rogers <irogers@google.com>,
Adrian Hunter <adrian.hunter@intel.com>
Subject: Re: [PATCH v3 1/3] tools headers: Go back to include asm-generic/unistd.h for arm64
Date: Wed, 7 Jan 2026 14:48:06 +0000 [thread overview]
Message-ID: <20260107144806.GC336318@e132581.arm.com> (raw)
In-Reply-To: <58e432e4-5825-4f2e-9aba-29be63eac56f@linaro.org>
On Wed, Dec 24, 2025 at 01:47:51PM +0000, James Clark wrote:
[...]
> > To fix the issue, it restores to include asm-generic/unistd.h. This is
>
> Would this prevent us from using any Arm64 specific syscalls in the future?
I hope the perf code can be general enough so don't call arch specific
syscalls.
> I think that's a downside of this approach vs copying the generated output
> that should be noted here.
From pragmatic view, I don't see any issue with using the
asm-generic/unistd.h on Arm64 at current stage.
If later we need to support new syscalls, I assume it is very likely not
an issue for Arm64 specific, we need to resolve common issue either
updating asm-generic/unistd.h or change to use dynamic generated headers.
> > consistent with other architectures and ensures the header is available
>
> 'Consistent' isn't accurate is it? x86 already has static copies of syscalls
> in tools/arch/x86/include/uapi/asm/unistd_32.h and
> tools/arch/x86/include/uapi/asm/unistd_64.h.
I went through a bit x86's unistd_32.h/unistd_64.h, it defines some
special syscall numbers. Seems removing them will break on x86.
I'd leave this to x86 maintainers.
To avoid confusion, I will update the commit log:
Restore to include asm-generic/unistd.h for fixing the issue. This
aligns with most architectures (x86 is a special case that keeps
unistd_32.h/unistd_64.h for its particular syscall numbers) and
ensures the header is available from the start.
> Maybe something more like "eventual consistency" is intended, if we plan to
> remove those x86 headers too?
Yes.
> I'm still a bit lost about why Arm64 copying
> the generated header is considered a special case when we already have these
> x86 ones.
If arm64 maintains its own unistd.h, there is a concern that other
architectures will do the same, and we will end up maintaining
fragmented headers for each architecture.
Later, if we need to support architecture specific syscalls, we should
explore better approaches, such as using generated headers (e.g.,
make headers) to provide UAPI headers instead.
IMO, in this case, x86 is not a good example to follow.
Thanks,
Leo
next prev parent reply other threads:[~2026-01-07 14:48 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-12-22 18:06 [PATCH v3 0/3] tools build: Fix arm64 unistd.h dependency Leo Yan
2025-12-22 18:06 ` [PATCH v3 1/3] tools headers: Go back to include asm-generic/unistd.h for arm64 Leo Yan
2025-12-24 13:47 ` James Clark
2026-01-07 14:48 ` Leo Yan [this message]
2026-01-07 15:21 ` Arnd Bergmann
2026-01-07 17:14 ` Leo Yan
2025-12-22 18:06 ` [PATCH v3 2/3] Revert "perf tools: Fix arm64 build by generating unistd_64.h" Leo Yan
2025-12-22 18:06 ` [PATCH v3 3/3] tools headers: Don't check arm64's unistd.h Leo Yan
2025-12-24 13:51 ` James Clark
2026-01-07 15:05 ` Leo Yan
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20260107144806.GC336318@e132581.arm.com \
--to=leo.yan@arm.com \
--cc=acme@kernel.org \
--cc=adrian.hunter@intel.com \
--cc=arnd@arndb.de \
--cc=irogers@google.com \
--cc=james.clark@linaro.org \
--cc=jolsa@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-perf-users@vger.kernel.org \
--cc=namhyung@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox