> > Sorry to bug the list with yet another programming problem but ... > > What permissions on the file do I need to change to allow an ordinary user > to run a setuid-root programme ? The programme below compiles and runs if > I compile & run as root but does not work if run by a user regardless of > who compiles it. What am I doing wrong ?
[ ... skipped source code ...] If a program is setuid root depends on the file permissions. If you could just become root like you tried by changing the uid in a C-program, then any user could do this and there would be no security in the system. To make a program run as root, do the following: If it is not owned by root yet: $ chown root myprog Then $ chmod +s myprog Now the program will run with uid 0 regardless of who runs it. The setuid function is normally used to drop the root permissions in parts of the program where they are not really needed. This is then done as a security measure. This topic is discussed clearly and at length in the libc documentation: if you installed the docs, just type info libc and check out the `Users and Groups' section. HTH, Eric -- E.L. Meijer ([EMAIL PROTECTED]) | tel. office +31 40 2472189 Eindhoven Univ. of Technology | tel. lab. +31 40 2475032 Lab. for Catalysis and Inorg. Chem. (TAK) | tel. fax +31 40 2455054