From: smcg@cs.hw.ac.uk (Stephen McGowan)
Subject: Re: Beer - it's no joke!



			--------------------------------------
			BUGS.         DON'T LIVE IN IGNORANCE.
			--------------------------------------


-------------------------------------------------------------------------------
1.  Why Are You Being Sent This Message?
-------------------------------------------------------------------------------

This message is being sent to every software house in the country. It is about
BUGS. And everyone needs to know the facts. It explains what BUGS are, how they
spread, how serious the threat may be, and how they can be avoided.
Because it has to deal with matters of software and hardware, you may find
some of the information disturbing. But please make sure that everyone who
needs this advice reads this message. The more people who know about BUGS the
less likely they are to spread.

So, if you employ programmers, think carefully about what they need to know.
Whether or not you approve, many programmers do write programs, and some may
experiment with assembler.

Even if you think your programmer's don't act in this way, they will still need
advice because they may have friends who encourage them to.


-------------------------------------------------------------------------------
2.  Why Should You Be Concerned About BUGS?
-------------------------------------------------------------------------------

Any computer user can suffer from BUGS, depending on their behaviour. It is
not just a hacker's problem. There is no cure and they can cause crashes. By
the time you have read this, probably 3000 computers will have crashed in this
country. It is believed that a further 400,000 carry BUGS. This number is
rising and will continue to rise unless we all take precautions.

-------------------------------------------------------------------------------
3.  What Are BUGS?
-------------------------------------------------------------------------------

BUGS are caused by logical errors. These can attack a program's validation
routines which normally help fight off bad input and corruption. And if this
happens then programs can develop BUGS. They become unreliable and crash from
errors that cannot be detected.


-------------------------------------------------------------------------------
4.   How Do Programs Become Infected?
-------------------------------------------------------------------------------

Because errors can be present in specifications and designs, this means that
for most programmers the only danger comes through using a faulty design. This
applies to both top-down and bottom-up design. (It is believed that other forms
of design are also risky, such as SSADM, particularly if specifications are
taken at face value.)

So the errors can be passed from design to design, design to program, and back
again from program to design. For those who use assembler there is an added
risk from sharing software interrupts or device printers on a time-sharing
basis. Furthermore, sub-tasks spawned from infected programs have a high risk
of inheriting BUGS.

-------------------------------------------------------------------------------
5.   How Can You Protect Yourself From BUGS?
-------------------------------------------------------------------------------

(a)  Most programs which have errors don't even show it. They may look and
behave completely normally. So you cannot tell which ones are infected and
which ones are not. To protect yourself, follow these simple guidelines;

(i) The more programs you write, particularly assembler programs, the more
chance you have of encountering one which is infected. It is safest to stick
to one program.

			FEWER PROGRAMS, LESS RISK

(ii) Unless you are sure of a program, always use a debugger. This will
reduce the risk of encountering BUGS.

			USE DEBUGGERS FOR SAFER PROGRAMMING.

(iii) It is always best to use a source-level debugger. Low-level debuggers
can reduce this protection. Ask your team-leader for advice. Anyone who uses
assembler programs should not use software interrupts. If you do, never share
interrupts (or device handlers, floppies, etc) as you could be introducing
BUGS directly into your program.

			DON'T USE SOFTWARE INTERRUPTS. NEVER SHARE.


-------------------------------------------------------------------------------
6.   What Should You Do If You Think Your Program Has Been Infected?
-------------------------------------------------------------------------------

If you think your program has been infected, go to your course leader for 
advice about having a test. Or go directly to your personal tutor for private
and confidential advice and a test if you wish. If your program does have 
errors, they'll let you know and give you help and support.


-------------------------------------------------------------------------------
7.   What About The Resident Software?
-------------------------------------------------------------------------------

It is not safe to use comms packages, Armstrad applications or on-line
dictionaries unless you know they are bug free and have been rigorously 
tested. Nor is it safe to share a routine or include a file in a program
which has been infected.

-------------------------------------------------------------------------------
8.   What Can't You Get BUGS From?
-------------------------------------------------------------------------------

The government's clear advice for the software industry is that you CANNOT
get BUGS from normal use of an infected program. Neither can you get them
>from reading listings. Nor is there any record of a program becoming infected
through sharing comments. There is no danger in sharing floppies or micro-
drives. Nor can anyone become infected through using network drives or line
printers.

When integrating software, standard precautions should be taken to protect
programmers, users and applications. Exporting routines are safe: all the
declarations are used only once. All routines used for library builds should
be thoroughly checked.

-------------------------------------------------------------------------------
9.   How Safe Is It In Other Countries?
-------------------------------------------------------------------------------

BUGS exist throughout the world and throughout the computer industry. In
certain companies a large number of programs are believed to have BUGS. So it
is even more essential to follow the advice given in this message, particularly
if you should visit another company. Otherwise, if you do some work on an
unfamiliar program, you may inadvertantly affect your regular work when you
return.

Furthermore, in some companies, public routines are not checked for BUGS. In
those places where errors are widespread you should not, if you can possibly
avoid it, use routines from a contract programmer.

In certain start-up companies, routines may not be properly debugged. If you
can, avoid using interrupt repairs or patches. If you are in any doubt about
these points then discuss them with your course leader.


-------------------------------------------------------------------------------
10.   Do You Need More Information?
-------------------------------------------------------------------------------

The true picture about BUGS is that, at the moment, relatively few programs
are infected with proper full-blown BUGS. Those most at risk are assembler
programs which have common code with other assembler programs, programs
which share software interrupts, and users of these programs.

But BUGS is spreading. And as it does, so the risk of sharing an infected
routine also increases.

Ultimately, defence against BUGS depends on us all taking responsibility for
our own logical and programming actions.