On Tue, 2008-08-26 at 20:58 -0400, Parag Warudkar wrote: [...] > The savings part -financial ones- are not always realizable with the > way memory is priced/sized/fitted. > Savings in few Mb of Kernel stack are not necessarily going to allow > getting rid of a single memory chip of 64M or so. No, but you can put an additional service(s) on it and sales people have one (or two or ....) line more for their sales brochures. > Either that or embedded manufacturing/configurations are different > than the desktop world. They are different. Think of running the complete system acting as a bridge, router and/or firewall (Kernel early 2.4 though) from 4MB flash in 32MB RAM and - listing the outside visible services - having a command-line interface, web-GUI (implying a http server) and and a (net-)SNMP agent on it. Running a glibc without thread support is win there (implying that there is no thread support available on that device). > (If my device has 2 memory slots and my user space requires 100Mb > including kernel memory - I anyways have to put in 64Mx2 there to take > advantage of mass manufactured, general purpose memory - so no big > deal if I saved 1.2Mb in Kernel stack or not. And savings of 64Mb > Kernel memory are not feasible anyways to allow user space to work > with 64Mb.) As soon as product management realizes that there is space left on the device, they get new ideas and/or customer requirements to run more services on that device. > On the other hand reducing user space memory usage on those devices > (not counting savings from kernel stack size) is a way more attractive > option. There is no question if save space here or there. You save it - sooner or later - on all fronts. Period. > And although you said in your later reply that Linux x86 with 4K > stacks should be more than usable - my experiences running a untainted > desktop/file server with 4K stack have been always disastrous XFS or > not. It _might_ work for some well defined workloads but you would > not want to risk 4K stacks otherwise. The embedded world of really small devices usually doesn't run XFS (or ext? or reiser* of jfs or NFS or ...) or stacks block devices on files or ..... > I understand the having 4K stack option as a non-default for very > specific workloads is a good idea but apart from that I think no one > else seems to bother with reducing stack sizes (by no one I mean other > OSes.) They probably gave the idea pretty soon because you need to rework/improve large parts of the kernel + drivers (and that has two major problems - it consumes a lot of man power for "no new features and everything must be completely tested again"[0] and it adds new risks). And that is practically impossible if one sells "stable driver APIs" for 3rd party (commercial) drivers because these must be changed too. Bernd [0]: Let alone if you (or your customers) need certificates from some governmental agencys. -- Firmix Software GmbH http://www.firmix.at/ mobil: +43 664 4416156 fax: +43 1 7890849-55 Embedded Linux Development and Services -- To unsubscribe from this list: send the line "unsubscribe kernel-testers" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html