In its Supplemental Responses to IBM's Second Interrogatories and Second Requests for Documents, SCO gave this answer:
Insofar as this interrogatory seeks information as to whether plaintiff has ever distributed the code in question or otherwise made it available to the public, SCO has never authorized, approved or knowingly released any part of the subject code that contains or may contain its confidential and proprietary information and/or trade secrets for inclusion in any Linux kernel or as part of any Linux distribution.
Cross your heart and hope to die, SCO? Or cross your fingers behind your back? Let's see what the evidence shows.
SCO has specifically mentioned the following four as being code at issue in this case: JFS, NUMA, RCU, and SMP, and while it is conceivable that the "subject code" they are talking about in this response to IBM's interrogatory is referring to some other code, it seems reasonable to look at the code they have mentioned publicly. Actually, it's more than reasonable. It's our only choice, until they tell us exactly what code they are complaining about with specificity. Is it true that they never "authorized, approved or knowingly released" any of this code for inclusion in any Linux kernel or as part of any Linux distribution?
Let's start with JFS.
In the case of JFS, they not only distributed Linux with JFS, one of Caldera's employees, Christoph Hellwig, contributed code to JFS, as Groklaw reported on July 18. Here is a snip from that article:
Here is an email in which he tells an inquirer how to contribute to JFS, including this tidbit: "I've run native sysvfs tools under linux, but as now that I'm Linux sysvfs maintainer I'm looking into implementing free versions of it. . . . The JFS/Linux core team has setup a CVS commitinfo, but currently I'm the only one who receives it."
And he is listed on this page of JFS contributors. Here is IBM's page on Who Is Using JFS? and it lists United Linux. So they not only released a distro with JFS in it under the GPL, their employee helped make it happen. Here is a page listing the Skunkworks team, and you will note that the first entry is Ronald Joe Record, a SCO employee (firstname.lastname@example.org), and JFS is listed for him. But in case you aren't yet convinced, here is a handy list for you of some other pages that mention JFS, collected by Rand McNatt and nw:
And here he encourages someone to donate to the main JFS repository at IBM and talks about his role:
"I'm one of the main commiters to JFS outside IBM and I'm really happy to see more people involved :)
He also posts to the freebsd list as freebsd-fs at freebsd.org.
"First I'd like to encourage you to contribute your userspace changes to the main JFS repository at IBM. For the 1.0.11 release I have added autoconf/automake support to easify portability and a bunch of portablity patches (mostly getting rid of linuxisms) is under way to the Core team."
Here is the press release when SCO in 2002 released "SCO Linux Server 4.0 for the Itanium (R) Processor Family" and which mentions that the product is based on United Linux.
This SCO pagelists JFS as one of its features. . . .
They are complaining that IBM contributed JFS to Linux, but their own employee, from this evidence, was involved in helping out. On the day IBM announced JFS was being given to Linux, Hellwig is listed as making five contributions to the kernel.
http://uk.sco.com/events/Partner_Briefings/March_2003/sco_os_update.ppt (mentions NUMA also)
What about SMP?
http://www.caldera.com/unitedlinux/info/unitedlinuxwhitepaper.pdf (JFS chapter on page 15-16.)
http://www.caldera.com/images/pdf/scooffice/SettingUpSCOofficeMailServeronSCOLinux.pdf (P. 8: "SCO Linux gives you a choice of four journaling filesystems, EXT3, Reiser, XFS and JFS.")
http://www.caldera.com/images/pdf/scolinux/UnitedLinux_whitepaper.pdf(p. 13-15: "“The Journaled File System (JFS) is a full 64-bit file system. All of the appropriate file system structure fields are 64-bits in size. This allows JFS to support both large files and partitions. JFS was developed by IBM under the GPL license and is ported from its AIX systems. JFS provides a log-based, byte-level file system that was developed for transaction-oriented, high performance systems. Scalable and robust, its advantage over non-journaled file systems is its quick restart capability. JFS can restore a file system to a consistent state in a matter of seconds or minutes.”)
http://www.caldera.com/products/scolinuxserveripf/features.html ("Journaling file systems add a higher level of reliability and faster recovery time. JFS, ReiserFS, XFS and Ext3 journaling file systems are included with SCO Linux Server. Each of these file systems has been tested and optimised for the best performance and stability.")
Here is another one, which mentions both JFS and XFS:
SCO Linux Server 4.0 (Powered by UnitedLinux 1.0) . . . . The SCO Linux Server 4.0 has many advanced enterprise filesystems, including ext2, ext3, reiserfs, jfs, and xfs, which of these have support for ACLs on SCO Linux 4.0?
Hellwig worked on SMP also. Alex Roston has researched Hellwig and SMP and contributes this:
Christoph Hellwig is also a contributor to Linux's SMP systems. Here he proposes a patch that fixes the booting of an "SMP-compiled i386 kernel on a SMP-capable motherboard with" a CPU which is not SMP.
Linus replies to him with this note.
So Hellwig patches his patch.
Later, a SCO employee, Senior Programmer Torsten Duwe, (email@example.com) acknowledges Hellwig's code. He also discusses the issues around binding a process to a CPU. (Process affinity) This is obviously only an issue on machines with more than one CPU, otherwise the process is already bound to the single CPU on the system. Here he posts a piece of code by Nick Pollit from SGI which allows the 2.4 kernel to perform something called "process pinning." Later on in the same discussion he
discusses a Red Hat patch for the SMP code.
On another occasion he discusses SMP support for Pentium-3 chips and suggests that given the number of different architectures Linux supports that SMP should be either per-architecture or a configuration option. I've found several other references to SMP and Christoph Hellwig, but only one other seems significant. In this exchange he proposes a change to Linux's gendisk handling.
Red Hat's Arjan van de Ven notes that the patch is SMP unsafe and Hellwig
agrees that he will fix SMP problem if the patch is accepted, and if you follow the thread, it goes on a little longer with a discussion of whether Hellwig's code was inspired by someone else, and Hellwig acknowleges that he's rewriting another programmer's contribution.
In addition to his email address hch at ns.caldera.de, Christoph Hellwig also has another email address which he frequently uses for his Linux work. This address is hch at infradead.org. Here we see him making a reply to this post which discusses an SMP machine with problems, with a suggestion for either clearing up or diagnosing the problem.
In a thread called "Re: Longstanding networking / SMP issue?" Hellwig acknowledges some buggy code. In this post he makes a suggestion for someone having trouble with XFS on an SMP machine.
Looking at all this, we see that Hellwig didn't just post a patch because he was having a problem with SMP. He's performing a large number of programming tasks involving this issue. He's creating SMP code, forwarding SMP code written by others, rewriting code belonging to others that impinges on SMP, and acknowledging buggy SMP code. In addition, he's interacting with other people at SCO. Hellwig's own SMP patch is acknowleged by another SCO programmer and a former SCO employee, Tigran A. Aivazian, who is acknowleged as a contributor to the Linux SMP HOWTO, although whether Mr. Aivazian was involved in the HOWTO while employed by SCO is unknown.
Further, we also see Hellwig involving himself in technical discussions revolving around SMP, and he also makes diagnoses and suggests workarounds for SMP code. Lastly, he also shows an awareness that his code needs to take SMP issues into account. He's also listed as the active maintainer of two other file systems under Linux, the FREEVXFS and SYSV filesystems.
So it should come as no surprise that he's made many contributions to another important Linux filesystem, the XFS filesystem contributed the the Linux kernel by those nice folks at SGI. While he's not listed as the filesystem's maintainer, he's so important to this effort that SGI has given him two more email addresses, "hch at sgi dot com," and "hch at lab343.munich.sgi dot com." He also has the authority to merge code into this subsystem, as you can see here. The document at this URL is full of emails that read like this example:
Date: Tue Jan 14 07:19:17 PST 2003
Merged by: hch
Merged mods: 2.4.x-xfs:slinx:136126a
The following file(s) were checked into:
In other words, on January 14th of 2003, Christoph Hellwig merged an XFS patch by Russell Cattelan into the "lab343.munich.sgi.com:/home/hch/repo/slinx/2.5.x-xfs" work area. You'll also note that he's merging kernel 2.4 code into the 2.5 kernel.
Here's another document where he's working with the XFS code. Here he writes about checking files into "bonnie.engr.sgi.com:/isms/slinx/2.4.x-xfs" .
He also acts like a teacher/boss. Note his comments in the following documents. Here he replies to Andrew Morton with a suggestion for making his XFS patch better, and Mr. Morton replies.
Here are more URLs listing XFS commits. In the first URL he commits filesystem code from three different email addresses:
His work rates frequent mention in the 2.5.* kernel release notes. Once again, it happens under three different email addresses. Note how much of this work involves the XFS filesystem, here and here.
Here Hellwig deals with an XFS bug. And here he's listed in connection with several XFS bugs. See number 452, 835, 840, 861, and 870. In other words, he was deeply involved with porting the XFS file system from SGI into Linux, and he performed all of a chief programmer's usual functions - coding, debugging, merging patches and codebases, supervising, and instructing.
Worse for SCO, in addition to Hellwig's work on XFS and SMP, we also see from this post that Hellwig's supervisors, in this case Ralf Flaxa, (firstname.lastname@example.org) are aware that he is online and making changes to the Linux kernel:
Reading this thread and previous requests I see a need by ISVs and
applications to determine at runtime certain processor related features. They can roughly be grouped into:
You might also notice the kernel version numbers. Where SMP is concerned, he's not just talking about code in 2.2. He (or his code) discusses 2.4 (though I'm not sure which release he's discussing) and 2.4.10. Lastly, most of the posts are dated after the January 5th, 2001 release of the 2.4 kernel, so Hellwig not only contributed to SMP, his contributions involved 2.4. One of them is even dated July 13, 2003, long after SCO filed suit against IBM. The XFS code is much the same, though most of it deals with the 2.5 codebase.
1. number-crunching power in general
"I have asked Christoph to work on a proposal and present it
to this list. I think we agree that there is a need and demand
for a standard way to gather this info and that /proc/cpuinfo
was just a bad start - so I would like to give it another chance. This is Ralf speaking as director of Linux development at Caldera
and as technical lead for the LSB sample implementation."
2. features specific to a processor
number of CPUs
CPU family and type
BogoMips (per CPU and/or overall)
SMP capabilities (here kernel scalability could be an item)
for x86 e.g. the "flags" and *_bug fields
- info about FPU, MMU and the like
Mr. Hellwig has been at the heart of three important initiatives aimed at making Linux 'enterprise ready,' JFS, SMP, and XFS.
So not only was Hellwig making contributions while a Caldera employee, his supervisor is on the record that he was supposed to be doing so. Here Hellwig discusses RCU with a SuSE guy. Aside from Hellwig, there is a great deal of other proof of SCO's distributing SMP in their Linux distributions, again largely from Rand. Here is a SCO support page on OpenLinux, "How to enable SMP (multiple processor)support" with detailed instructions on how to do it.
Here is the support page for "What is patch 4924, the SCO Linux 4.0 SMP Kernel Oracle update?"
Here is the page for "What is patch 3364, the SCO Linux 4.0 SMP kernel security update?"
And here is the page that tells us that "By default our kernel is compiled for SMP support."
Well, there is so much, how about we just list all the references to SMP?
Another of their employees, Tigran Aivazian, is listed here and given credit because he "fixed '0.00 in /proc/uptime on SMP' bug."
workstation/datasheet.html ("Linux 2.4 Kernel – The new Linux 2.4 kernel is a key component of the OpenLinux Workstation product. The Linux 2.4 kernel provides significantly improved hardware support for new hardware devices, improved SMP scalability, greater memory support, faster I/O performance, and many other performance boosting enhancements.")
infrastructure/i01092003.htm("UnitedLinux is an attempt to create a standard business server Linux with common file directory conventions, command options, installation routines and high-end options like clustering and shared memory multiprocessing (SMP).")
BCLP_LinuxWhitepaper.pdf (P. 6.)
What about NUMA?
As it happens, SCO Linux 4 lists it as one of its features, along with JFS and SMP:
Features of SCO Linux 4 include: And this white paper lists NUMA on page 10. Caldera should have known about NUMA in Linux: here is a description of ccNUMA in Caldera's OpenLinux Documentation.
Linux 2.4.19 Kernel – The core of SCO Linux Server 4.0 is the 2.4.19 Linux kernel. New features include broadened USB support, Logical Volume Manager, improved journaling file system support, POSIX-ACLS, new O(1) scheduler (improves SMP support), Asynchronous I/O, Enterprise Volume Management System (EVMS), PCI Hot Plug Support on
supported hardware, NUMA support, and many other performance enhancing capabilities.
Well, that's three down and only one to go, RCU.
I had more trouble finding proof that SCO distributed a kernel with RCU. But, thanks to the Groklaw community, and especially nw, we got that one done eventually. Here's a guy who reports on downloading the 2.4.19 kernel from SCO's ftp site and finding RCU patches:
The SCO RPMs for the 2.4.19 kernels do not contain the generic 2.4.19 GPL kernel source code (linux-2.4.19.tar.bz2). These RPMs contain the SCO GPL patches (some are which RCU patches to the kernel) and "specfiles" to create the SCO 2.4.19 GPL kernels from the generic 2.4.19 kernel source code. The reason the SCO RPMs do not contain the generic 2.4.19 GPL kernel source code (linux-2.4.19.tar.bz2) can be found in an email from a UnitedLinux developer at: http://
marc.theaimsgroup.com/?l=linux-kernel&m=104218778023663&w=4 Then, I couldn't seem to find any more on RCU, so I put out the call for folks to try to find a bit more, knowing there could be some skeptics in the crowd. Dr. Stupid, as always, came through with skill and charm. Here is his email:
The generic 2.4.19 GPL kernel source code (linux-2.4.19.tar.bz2) can be found at: ftp://ftp.kernel.org/pub/linux/
kernel/v2.4/linux-2.4.19.tar.bz2 - Copy this file to the RPM source directory before building the SCO 2.4.19 GPL kernels.
Here's an article about SCO Linux 4, showing it's based
on UL and thus SuSE.
So, there we have it. All four. And just in time for December 5, too. I do hope Judge Wells enjoys detail. While no one can yet know for sure what SCO meant in its response to the interrogatory, I think we can safely say that they cannot claim that the were unaware that they had released, and even were contributing toward, these enterprise-enabling features of Linux.
Here's a SCO page talking about how to update SCO Linux 4, note that it gives the explicit kernel version - "k_deflt-2.4.19-246.i586.rpm" Date is Feb 2003.
Google cache of above just in case.
Note that SCO did distribute the kernel updates themselves. Allegedly it's rather harder to get the kernel from them these days. But they talk of the "United Linux SP1 CD" which SuSE could send
you if you ask them nicely. Here is a page which verifies that SCO was using the SuSE kernel (though he's referring to the pre-service pack 1 version)
And while this may have been posted before on Groklaw, it bears repeating in this context: Christoph Hellwig, nodding approvingly about RCU and helping out.
Also check here. That "k_deflt-2.4.19-246.i586.rpm" was made available on many sites, such as here. Search on google for "k_deflt-2.4.19-246.i586.rpm" for more)
Note that this mirror site has the kernel built for various processors (athlon, SMP etc) but they are all built from the same source RPM which is at the bottom... kernel-source-2.4.19.SuSE-152.i586.rpm . Yes folks, remember that all the United Linux chaps were shipping
the exact same kernel: SuSE's kernel. But that kernel isn't the plain 2.4.19 kernel, it's patched (with
152 patches to be exact!)
So, I downloaded the source RPM and unpacked it, to see just what
SCO was shipping, under the GPL, in its SCO Linux 4 product.
Well, well... in the "kernel" folder of the source package there is a file which isn't in the vanilla 2.4.19 kernel. That file is called rcupdate.c and I'll give you a short excerpt:
* Read-Copy Update mechanism for mutual exclusion
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
* Copyright (c) International Business Machines Corp., 2001
* Copyright (C) Andrea Arcangeli SuSE, 2001
* Author: Dipankar Sarma ,
* Andrea Arcangeli B^!
* Based on the original work by Paul McKenney
* and inputs from Andrea Arcangeli, Rusty Russell, Andi Kleen etc.
* For detailed explanation of Read-Copy Update mechanism see -
Leans back, lights cigar.... B^!
Oh, and btw, SCO could hardly have been ignorant about the
enterprise level features going into UnitedLinux, as they
crowed about them.
P.S. Moreover, the changelog for the kernel mentions rcu patches back in
the original kernel that SCO Linux 4 shipped with would have had RCU too.