From nobody Wed May 24 21:15:08 2023 X-Original-To: freebsd-arch@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 4QRP8x6NFkz4V29y for ; Wed, 24 May 2023 21:15:13 +0000 (UTC) (envelope-from hps@selasky.org) Received: from mail.turbocat.net (turbocat.net [IPv6:2a01:4f8:c17:6c4b::2]) (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 mx1.freebsd.org (Postfix) with ESMTPS id 4QRP8x46bsz3FHw; Wed, 24 May 2023 21:15:13 +0000 (UTC) (envelope-from hps@selasky.org) Authentication-Results: mx1.freebsd.org; none Received: from [10.36.2.145] (unknown [46.212.121.255]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by mail.turbocat.net (Postfix) with ESMTPSA id B5542260C84; Wed, 24 May 2023 23:15:08 +0200 (CEST) Message-ID: <12525a96-04aa-56d7-c79b-a24a52165490@selasky.org> Date: Wed, 24 May 2023 23:15:08 +0200 List-Id: Discussion related to FreeBSD architecture List-Archive: https://lists.freebsd.org/archives/freebsd-arch List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-freebsd-arch@freebsd.org MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; FreeBSD amd64; rv:102.0) Gecko/20100101 Thunderbird/102.10.1 Subject: Re: [RFC] An idea for general kernel post-processing automation in FreeBSD To: Jessica Clarke Cc: Emmanuel Vadot , Kyle Evans , John Baldwin , Mark Johnston , Warner Losh , Konstantin Belousov , "freebsd-arch@freebsd.org" References: <394775eb-1000-60d9-2ddd-5c2aca6c99ea@selasky.org> <08ba506f-66c5-35eb-e992-ecf9dfeccf93@selasky.org> <20230524082850.ffc8793b6bb1b47325ae0139@bidouilliste.com> <39e6793a-33f9-8f48-30d3-eaa30d321452@selasky.org> <47B35276-B92A-49BC-A0FB-B71BA38ADA2A@freebsd.org> Content-Language: en-US From: Hans Petter Selasky In-Reply-To: <47B35276-B92A-49BC-A0FB-B71BA38ADA2A@freebsd.org> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Rspamd-Queue-Id: 4QRP8x46bsz3FHw X-Spamd-Bar: ---- X-Spamd-Result: default: False [-4.00 / 15.00]; REPLY(-4.00)[]; ASN(0.00)[asn:24940, ipnet:2a01:4f8::/32, country:DE] X-Rspamd-Pre-Result: action=no action; module=replies; Message is reply to one we originated X-ThisMailContainsUnwantedMimeParts: N On 5/24/23 17:20, Jessica Clarke wrote: >> 1.2) Compiletime sorting puts more requirements on the toolchain. Referring Jessica Clarke, this is a "gross hack". On the other hand, debugging and visibility makes this desirable. > I’ve been deliberately staying out of my thread, but this is blatantly false. I said that in response to*one specific part of your proposed implementation*, which is completely different to saying it about the general concept. The full quote is: > >>> If you are worried multiple DEFINE_MUTEX(lock) will result in multiple global symbols having the same "lock" name, all you need to do is pass through the ${.TARGET} variable from "make" as a define, stripping a few invalid characters, and macro-concat that to the locally generated global variable name, and you are all good. >> You could. But that’s a pretty gross hack IMO, and depending on how you do it may still not be unique. Not to mention it’s going to further bloat the symbol tables with these long names. > > So this is some pretty horrendous misquoting. Do not do that again. I am extremely unimpressed. This e-mail is a side track into the LinuxKPI regarding the DEFINE_MUTEX() Jess asked about. Hi Jess, In FreeBSD DEFINE_MUTEX() is both a SYSINIT() and a mutex. The "lock" name propagates to both the mutex and the SYSINIT(). The problem is not the mutex part, but the SYSINIT() part: #define DEFINE_MUTEX(lock) \ mutex_t lock; \ SX_SYSINIT_FLAGS(lock, &(lock).sx, mutex_name(#lock), SX_DUPOK) Your answer is according to how DEFINE_MUTEX() is implemented in Linux: #define DEFINE_MUTEX(mutexname) \ struct mutex mutexname = __MUTEX_INITIALIZER(mutexname) This is a FreeBSD list, and here we discuss how things are working in FreeBSD and not Linux. In FreeBSD we don't have any equivalent of __MUTEX_INITIALIZER() for SX locks, yet. The DEFINE_MUTEX() macro in FreeBSD is then currently not 100% compatible with the one in Linux. This is probably something to work on. Right now, putting a SX_SYSINIT_FLAGS() inside the DEFINE_MUTEX() macro just works. I have a feeling our background and experiences are somewhat different. We put different meaning behind the words in our e-mail changes, leading up to apparent frustration. I see why you are burning in your mind, because you think FreeBSD tries to emulate Linux, and at the same time they are not fully compatible with Linux, and you don't get how that makes sense. The LinuxKPI is mapping functionality in Linux to FreeBSD. Mapping means there is a transform. This sometimes leave FreeBSD in a corner, we need to patch Linux kernel code ported to FreeBSD, because the transforms being used, are not covering a particular case. This is the price FreeBSD has to pay, to use its kernel, internals and way of thinking. I have no clue how much operating system work you've done, and at what level and without going into further details and explanations, I kindly ask you to accept: Linux code on Linux is not the same like Linux code on FreeBSD. It may behave differently, have different timing, different synchronization, but not always. You can talk to me, manu@, emaste@, bz@ and several others about what is going on there and the history behind the LinuxKPI and why it ended up this "confusing" way. If you already know all of this, and feel I'm teaching you basics again, please disregard this e-mail. Thank you! --HPS