From mboxrd@z Thu Jan 1 00:00:00 1970 From: Arnd Bergmann Subject: Re: [PATCH v06 33/36] uapi linux/fsmap.h: use __kernel_size_t instead of size_t Date: Mon, 7 Aug 2017 18:01:43 +0200 Message-ID: References: <20170806164428.2273-1-mikko.rapeli@iki.fi> <20170806164428.2273-34-mikko.rapeli@iki.fi> <20170807155445.GA4074@magnolia> Mime-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable Return-path: In-Reply-To: <20170807155445.GA4074@magnolia> Sender: linux-api-owner-u79uwXL29TY76Z2rM5mHXA@public.gmane.org To: "Darrick J. Wong" Cc: Mikko Rapeli , Linux Kernel Mailing List , Linux API , Theodore Ts'o List-Id: linux-api@vger.kernel.org On Mon, Aug 7, 2017 at 5:54 PM, Darrick J. Wong w= rote: > On Sun, Aug 06, 2017 at 06:44:24PM +0200, Mikko Rapeli wrote: >> Fixes user space compilation error: >> >> linux/fsmap.h:71:19: error: unknown type name =E2=80=98size_t=E2=80=99 >> static __inline__ size_t >> ^~~~~~ >> >> Signed-off-by: Mikko Rapeli >> Cc: Darrick J. Wong >> --- >> include/uapi/linux/fsmap.h | 2 +- >> 1 file changed, 1 insertion(+), 1 deletion(-) >> >> diff --git a/include/uapi/linux/fsmap.h b/include/uapi/linux/fsmap.h >> index 7e8e5f0bd6d2..99600bbed6b6 100644 >> --- a/include/uapi/linux/fsmap.h >> +++ b/include/uapi/linux/fsmap.h >> @@ -68,7 +68,7 @@ struct fsmap_head { >> }; >> >> /* Size of an fsmap_head with room for nr records. */ >> -static inline size_t >> +static inline __kernel_size_t > > This is a static inline helper to assist in malloc calls. We don't pass > size_t to the kernel, so why is this necessary over, say, > > #include > Either way works, but including a system header from a kernel header requires an additional "#ifndef __KERNEL__" check, so I think Miko's variant is a little nicer. Generally speaking, you also want to avoid including system headers indirectly from kernel headers, as POSIX requires that including one system header should not indirectly make symbols from other system headers visible. I think this is not a problem here though, as no system header should include linux/fsmap.h. Arnd