Subject: Context switch times for NetBSD 2x those of 386BSD 0.1?
To: None <port-i386@sun-lamp.cs.berkeley.edu, current-users@sun-lamp.cs.berkeley.edu>
From: Thor Lancelot Simon <tls@panix.com>
List: current-users
Date: 08/26/1994 18:05:41
A recent thread in comp.arch discusses context switch times for various
operating systems on modern hardware.  Someone who works at QNX just posted a
list of measurements he's taken; it shows context switch times of 210ms and
380ms for 386BSD 0.1 and NetBSD on the same hardware.

This seems potentially indicative of a disturbing trend.  Is any attempt
being made to keep the kernel in line so far as code bloat goes?

Is anyone profiling the kernel, or otherwise actively working on this issue?
I can go spend a few weeks taking measurements if someone's not already.

Thor

P.S. I've attached a comp.arch article below.

Newsgroups: comp.arch,comp.benchmarks,comp.sys.super
Path: panix!MathWorks.Com!europa.eng.gtefsd.com!howland.reston.ans.net!torn!nott!cunews!revcan!quantum!danh
From: danh@qnx.com (Dan Hildebrand)
Subject: Re: Overheads of Parallel Systems (Summary)
Message-ID: <lmh9=0k@qnx.com>
Date: Thu, 25 Aug 94 12:23:24 GMT
Organization: QNX Software Systems
References: <33gfr2$atr@monalisa.usc.edu>
Lines: 67
Xref: panix comp.arch:34185 comp.benchmarks:6377 comp.sys.super:3562

In article <33gfr2$atr@monalisa.usc.edu>,
Zhiwei Xu <zxu@monalisa.usc.edu> wrote:
>
>(3) Context-switching times in microseconds
>
>Platform,                Operating System		Context Switching Time
>Processor Speed (Mhz)
>
>HP-735, 99               HP-UX 9.01		     68
>486DX, 33                QNX 4.2                80
>DEC 4000/610, 160        OSF/1 v1.3             87
>486DX2, 66               Linux 0.99.10          98
>IBM RS6000/580, 62       AIX 3.2               102
>Sun SS10, 40             SunOS 4.1.3           128
>Sun SS10, 40             SunOS 5.2             225
>Sun SS2, 40              SunOS 5.2             454

Note that these times are the measured result of a pair of processes 
signalling each other, which includes the additional kernel call overhead 
for the signalling calls.  A benefit of this approach is that the source is 
portable to a wide range of UNIX systems, howver, a more correct result, 
but currently less portable, can be obtained by using the sched_yield() 
call in a POSIX 1003.1b (previously 1003.4) OS.  Since this approach 
executes only one kernel call per context switch, with no signal processing 
being done, it is a more accurate indication of the actual context switch 
time.  Without the signal processing, the intervals are also much shorter. 
For example, the Pentium/90 number for QNX drops from 23 usec to 2 usecs, 
the 486/66 number drops from 44 to 5 usecs.  Here's a more complete listing 
of numbers collected from various responses on the net:

Platform,                Operating System        Context Switching Time
Processor Speed (Mhz)                              in microseconds

  90 MHz PCI Pentium     QNX 4.21                  23
  60 MHz ALR Pentium     QNX 4.2                   28
 100 MHz HP-747x         HP-RT 1.1                 34
  66 MHz 486DX2          QNX 4.2                   44
 100 Mhz HP-735          HP-UX 9.01                68
  50 MHz HP-742          HP-RT 1.1                 71
  33 MHz 486DX           QNX 4.2                   80
 150 MHz 21064           DEC OSF/1 v1.3            93
  80 MHz HP-712/80       HP-UX 9.05                96
  40 MHz DEC 5000/240    Ultrix 4.2                98
  66 MHz 486DX2          Linux 0.99.10             98
 150 MHz DEC 3000/500    ?                        100
  62 MHz IBM-RS6000/580  AIX 3.2                  102
  66 Mhz Snake           HP-UX 9.x                106
 150 MHz DEC 3000/400    ?                        127
  40 Mhz Viking          SunOS 4.1.3              128
  25 MHz DEC 5000/200    ?                        154
  50 MHz R4000 SGI       ?                        158
  33 MHz Sparc           SunOS 4.1.1              198
  40 MHz MIPS R3000      Ultrix 4.3               198
  33 Mhz 486             386BSD 0.1               210
  85 MHz Sparcstation-5  SunOS 4.1.3_U1           210
  50 Mhz RIOS            AIX 3.2                  212
  20 MHz DEC 5000/120    ?                        281
  33 MHz R3000/3010 SGI  Irix 4.0.5               345
  33 MHz 486             NetBSD                   380
  50 MHz Sparcstation-LX Solaris 2.3              620
  50 MHz 486DX2          Solaris                  636
  16 MHz 386SX           NetBSD                  2603
-- 
Dan Hildebrand                     email: danh@qnx.com
QNX Software Systems, Ltd.         QUICS: danh  (613) 591-0934 (data)
(613) 591-0931 x204 (voice)        mail:  175 Terence Matthews          
(613) 591-3579      (fax)                 Kanata, Ontario, Canada K2M 1W8

------------------------------------------------------------------------------