[net.unix-wizards] sdb poser solved -- 5.0 sdb users read this

rcj@burl.UUCP (R. Curtis Jackson) (05/18/84)

Many thanks to John Haller (ihldt!jhh) for telling me the solution to
this one; here was the problem:  on a Vax-11/780 running Release (USG)
5.0, I suddenly could not set any breakpoints in a program I was
developing.  The problem lies in the fact that the -n (shared text)
option of the loader write-protects the part of the program that sdb
needs to write into to set breakpoints.  To avoid a rash of denials,
I must note here that this does not always happen; it apparently depends
on where the program is loaded or some other variable.

The reason for the write-protect is a possibility that someone who
*really* knew what they were doing might cause a security problem by
being able to write into the text segment of a system program loaded
with the -n option.  The way to get around the problem is to use the
'-Wl,-N' option of cc, or the '-N' option of f77; these tell the compiler
 to pass the argument '-N' (no shared text) to the loader (l) pass of the
compiler.  Works like a charm.

So, if you can't set breakpoints in your program, try this option and
see if it fixes it.  Also, (I don't know if this has come up on the
net yet) if you are using sdb with f77 programs and are having problems,
do NOT compile your labeled commons with -g, it screws things up.  This
one courtesy of Rich Whitelaw (burl!rlw), who discovered this while
trying to debug a microsimulator he is developing here.
-- 

He gave the novice a long, icy stare and quietly growled, "RTFM".

The MAD Programmer -- 919-228-3313 (Cornet 291)
alias: Curtis Jackson	...![ ihnp4 ulysses cbosgd we13 ]!burl!rcj
			...![ ihnp4 cbosgd akgua masscomp ]!clyde!rcj

ed@mtxinu.UUCP (05/22/84)

The kernel (this was true in V7, and I presume is still true in
5.0) does write-protect the text segment of shared-text
programs.  There is a hook in the kernel to prevent two people
from using the same copy of a shared program when one of them
wants to debug it.

If someone executes a shared program and then tries to write
on the text with a debugger, the kernel un-write protects the
text segment and "loses" the memory that this program is
sharable.  If someone else tries to execute it, they'll get
their own copy.  If, however, there are two people using the
program when one of them tries to write on the text, the
kernel won't let it happen because it can't break the
interdependancy on the same text any more.

I haven't looked at the 4.2 kernel for this yet, but I suspect that
it does the same thing as well.

-- 
Ed Gould
ucbvax!mtxinu!ed