From owner-freebsd-current Thu Sep 13 13:18:55 2001 Delivered-To: freebsd-current@freebsd.org Received: from InterJet.elischer.org (c421509-a.pinol1.sfba.home.com [24.7.86.9]) by hub.freebsd.org (Postfix) with ESMTP id A06B137B409; Thu, 13 Sep 2001 13:18:46 -0700 (PDT) Received: from localhost (localhost.elischer.org [127.0.0.1]) by InterJet.elischer.org (8.9.1a/8.9.1) with ESMTP id NAA65151; Thu, 13 Sep 2001 13:49:39 -0700 (PDT) Date: Thu, 13 Sep 2001 13:49:38 -0700 (PDT) From: Julian Elischer To: John Baldwin Cc: current@freebsd.org Subject: Re: cvs commit: src/sys/fs/msdosfs denode.h msdosfs_denode.c ms In-Reply-To: Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: owner-freebsd-current@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG Note CC list changed.. On Thu, 13 Sep 2001, John Baldwin wrote: > > On 13-Sep-01 Julian Elischer wrote: > > Why are you doing this? > > having pointers to threads that are calle proc is going to be REALLY > > confusing! > > > > All vop operations will have threads (do) > > so why are you puting proc structures on them? > > Because the code claims to be shared with NetBSD and they dont have struct > thread. However, as we talked on the phone, if portability with NetBSD is no > longer a concern, then this is moot. #define proc threadB is a REALLY bad choice of how to do this.. If You REALLY MUST do this.. #ifdef __FreeBSD__ #define OS_THREAD thread #else #define OS_THREAD proc #endif at least that way it will be obvious in the code that it's not a proc in FreeBSD. But as I said on the phone, NetBSD are making hteir own changes in these files without ifdeffing, so the minimal diff changes (easy to see and understand) you are removing simply massively obscure the code for FreeBSD. We have a struct proc, so to define proc to actually be a thread is not just obscure, it's possitively misleading. We could add general macros for compatibility but they should probably go in a central place so that they can be used in multiple places. If you really wanted to go overboard, we could #ifdef __FreeBSD__ typedef struct thread *vop_thread_arg; #define V_TD_PROC(dta) ((dta)->td_proc) #else typedef struct proc *vop_thread_arg; #define V_TD_PROC(dta) (dta) #endif or some similar set of macros but I'm uncomfortable about obfuscating the code and even more unhappy about making it plain misleading! > > -- > > John Baldwin -- http://www.FreeBSD.org/~jhb/ > PGP Key: http://www.baldwin.cx/~john/pgpkey.asc > "Power Users Use the Power to Serve!" - http://www.FreeBSD.org/ > To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-current" in the body of the message