[oe] postinst problem: module vs. update-rc.d

Martin Jansa martin.jansa at gmail.com
Fri Oct 14 14:08:10 UTC 2011


On Fri, Oct 14, 2011 at 04:00:04PM +0200, Steffen Sledz wrote:
> We have a problem with a package that needs to install a kernel module and an initscript.
> 
> The recipe contains
> 
>   inherit module update-rc.d
> 
> The generated postinst script is
> 
>   #!/bin/sh
>   if [ -n "$D" ]; then
>         exit 1
>   else
>         depmod -a 2.6.24.7
>         update-modules || true
>   fi
>   if test "x$D" != "x"; then
>         OPT="-r $D"
>   else
>         OPT="-s"
>   fi
>   update-rc.d $OPT somescript start 90 S . stop 10 0 1 6 .
> 
> The 'exit 1' leads to an error if $D contains a nonzero length string (what is the case in the OE image creation step at the build host) and suppresses the execution of the second (update-rc.d) part.
> 
> Because of this error the postinst is run a second time when the target device boots the first time ("opkg-cl configure" from /etc/rcS.d/S40configure).
> 
> The problem is that the update-rc.d execution (and therefor the creation of the new symlink into rcS.d) is done from within rcS itself. So the rcS.d/S90somescript will *not* be executed at this boot. :(
> 
> We see two possible solutions.
> 
> A) Don't use "inherit module update-rc.d" but write the pkg_postint ourselfs.
> 
> B) Create two packages (one for the module, one for the initscript) with a runtime dependency.
> 
> I don't like both of them. Any other ideas? Is it possible to force the order of postinst fragments (update-rc.d code before module code)?
> 
> Regards,
> Steffen

BTW: there is another problem with update-modules:

SHR root at gjama ~ $ opkg files syslog-ng | grep modules.conf
/etc/modules.conf
SHR root at gjama ~ $ update-modules
Error: the current /etc/modules.conf is not automatically generated.
Use "update-modules force" to force (re)generation.

so if someone is using syslog-ng, than kernel-module-* or any "inherit
module" package won't update ie autoloads properly..

-- 
Martin 'JaMa' Jansa     jabber: Martin.Jansa at gmail.com
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 198 bytes
Desc: Digital signature
URL: <http://lists.openembedded.org/pipermail/openembedded-devel/attachments/20111014/172408e3/attachment-0002.sig>


More information about the Openembedded-devel mailing list