Re: [v4l-dvb-maintainer] bttv build error (CONFIG_NET=n)

From: Trent Piepho
Date: Wed Oct 31 2007 - 07:51:57 EST


On Tue, 30 Oct 2007, Randy Dunlap wrote:
> drivers/media/video/bt8xx/bttv-cards.c calls ip_compute_csum().
> However, when CONFIG_NET=n, that produces:
>
> ERROR: "ip_compute_csum" [drivers/media/video/bt8xx/bttv.ko] undefined!
>
> Config symbol VIDEO_BT848 can be made to depend on NET, or the
> osprey_eeprom() function can be built depending on some new config
> symbol, or bttv could have its own checksum function...

The real problem here is that ip_compute_csum is part of lib-y, but is also
exported for modules. This problem has come up before, for instance your
patch for csum_partial()
http://lkml.org/lkml/2007/4/3/209

Or the problem with kasprintf and the lg module:
http://lkml.org/lkml/2007/9/24/15

The general lib-y vs EXPORT_SYMBOL problem:
http://lkml.org/lkml/2007/9/25/17

The only reason the net stuff works, is because CONFIG_NET includes igmp.c,
which can't be compiled as a module. That means ip_compute_csum() will get
pulled out of the lib.a file for igmp, and thus be present for the net modules
that use it too. If igmp could be turned off, made a module, or stopped using
ip_compute_csum(), then the users of ip_compute_csum() that do depend on
CONFIG_NET would have the same problem as bttv does.

It seems a shame to create a new ip checksum function in the bttv driver when
a perfectly good one already exists and will already be present in just about
every kernel out there. Honestly, how common is NET=n and VIDEO_BT848=m
outside of randconfig?
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/