From owner-freebsd-stable Mon Nov 25 10: 4:38 2002 Delivered-To: freebsd-stable@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 387F237B401 for ; Mon, 25 Nov 2002 10:04:36 -0800 (PST) Received: from sccmmhc02.mchsi.com (sccmmhc02.mchsi.com [204.127.203.184]) by mx1.FreeBSD.org (Postfix) with ESMTP id 4D31143EA9 for ; Mon, 25 Nov 2002 10:04:35 -0800 (PST) (envelope-from stephen@math.missouri.edu) Received: from math.missouri.edu ([12.216.242.20]) by sccmmhc02.mchsi.com (InterMail vM.4.01.03.27 201-229-121-127-20010626) with ESMTP id <20021125180429.JHVS5896.sccmmhc02.mchsi.com@math.missouri.edu> for ; Mon, 25 Nov 2002 18:04:29 +0000 Message-ID: <3DE2662D.3070404@math.missouri.edu> Date: Mon, 25 Nov 2002 12:04:29 -0600 From: Stephen Montgomery-Smith User-Agent: Mozilla/5.0 (X11; U; Linux i386; en-US; rv:1.2b) Gecko/20021016 X-Accept-Language: en-us, en MIME-Version: 1.0 To: freebsd-stable@FreeBSD.ORG Subject: Re: running many programs on multiprocessor system References: <3DE149C7.2030607@math.missouri.edu> <3DE14D21.8070905@math.missouri.edu> <3DE248AC.8C54C273@softweyr.com> In-Reply-To: <3DE149C7.2030607@math.missouri.edu> Content-Type: text/plain; charset=us-ascii; format=flowed Content-Transfer-Encoding: 7bit Sender: owner-freebsd-stable@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG Wes Peters wrote: > Stephen Montgomery-Smith wrote: > > >Stephen Montgomery-Smith wrote: > > > > > >>I have a dual Athlon MP 2100+. If I run three computationally intensive > >>programs, one program runs at 99% CPU usage, and the other two run at > >>50% CPU usage (this is according to top). > >> > >>It used to be that each of the three programs ran at 66% CPU. I liked > >>it better the old way. > >> > > > >I spent a couple of weeks thinking about this before posting. And then right > >after posting, I realise the difference between these programs and other > >programs I run - these programs were written in assembler. > > > >I have also noticed that threaded programs don't thread properly if one of the > >threads calls a subroutine that is written in assembler. > > > >Sorry about the noise - but if anyone can explain to me why this happens I would > >appreciate it. > OK, I started out thinking that this might be a bug in FreeBSD, now I think that it is a bug in my program. I wrote a very simple threaded program in which one of the threads is a very simple loop written in assembler (a single jmp instruction), and the other thread is something very easy also. The program threads properly. Furthermore, if I run 3 instances of this program (even the non-threaded version) each process takes 66% CPU time, as expected. The problem with the more compilated assembler code I was using (which is called from a C program) is that I didn't write it, and I barely understand assembler code. Anyway, I realise now that this is not a freebsd-stable question. Maybe sometime soon I will post the question afresh to freebsd-hackers. In the mean time, can anyone tell me or point to me documentation telling me any kind of rules that assembler functions called from C programs have to obey? (And maybe vice versa.) Thanks for all the offers of help. The programs are all running at the same nice level, so that is not the problem. Thanks, Stephen -- Stephen Montgomery-Smith stephen@math.missouri.edu http://www.math.missouri.edu/~stephen To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-stable" in the body of the message