Pekka, I still do not see why you are opposed to assertions so much :-) Pekka Enberg wrote:Because we want to have a way to catch bugs and to quickly fix them. This is why we injected many assertions all over the place. Enabling them by default is inefficient and makes the code larger, which is not good especially for small embedded systems. If someone reports us an obscure oops, and we have no idea why it happened, and we cannot reproduce it on our setup, we ask the reporter to enable debugging and report us results. This helps us to figure out what was the reason and to quickly fix the bug. I do not see why you want to prevent us from doing this. We handle all errors. Errors are things like I/O failures, memory allocation failures, unexpected behavior. We do handle this. Assertion are about _debugging_, when you already know you have a problem. Indeed, bugs may be tricky. An oops may happen because half an hour ago a function craped out something. Assertions allow us to catch problems on _early_ stage, instead of dealing with consequences and scratching the head what was the reason. But I do agree we have too much of that. We will lessen the amount of course. I am not sure what you mean. I would not want to delve into a general discussion of the debugging stuff. I would better talk about specific things. I'll just point you examples of debugging stuff in the kernel in other subsystems which exists and does not hurt anyone. And I believe it is helpful. It is compiled out by default and is enable when it is needed to hunt a bug. fs/ext2: ea_idebug(), EXT2FS_DEBUG fs/xfs: #ifdef DEBUG, XFS_LOUD_RECOVERY and so on fs/ocfs2: OCFS2_DEBUG_FS fs/jfs: CONFIG_JFS_DEBUG, assert(), etc fs: DEBUG_EPOLL, #ifdef DEBUG fs/jbd2: assert_spin_locked(), CONFIG_JBD2_DEBUG, etc mm: CONFIG_SLUB_DEBUG, SLABDEBUG, CONFIG_DEBUG_VM, and so on Of course. People who are not familiar with the code send bug reports and we have to fix the problem quickly, and debugging stuff helps. It is OK to have few BUG_ON() checks, and we should probably turn few assertions into BUG_ON(). But only few. If something unexpected happens, UBIFS will just return -EINVAL in the most cases, because one of the function will find out that something is going wrong. Assertions have nothing to do with this. The help to _fix_ bugs which were hit in certain circumstances. We have heavy checks, right. They are expensive, so disabled by default. Why can't assertions be similar? -- Best Regards, Artem Bityutskiy (Артём Битюцкий) --
| Greg KH | Re: Dual-Licensing Linux Kernel with GPL V2 and GPL V3 |
| Ingo Molnar | [bug] mm/slab.c boot crash in -git, "kernel BUG at mm/slab.c:2103!" |
| Adrian Bunk | If you want me to quit I will quit |
| Matthew Garrett | [PATCH] Remove process freezer from suspend to RAM pathway |
git: | |
| Miles Bader | way to automatically add untracked files? |
| Linus Torvalds | People unaware of the importance of "git gc"? |
| Andy Whitcroft | Re: VCS comparison table |
| Alex Riesen | Re: gitattributes |
| Richard Stallman | Real men don't attack straw men |
| Falk Brockerhoff - smartTERRA GmbH | OpenBGPd won't receive prefix |
| no@spam@mgedv.net | Re: HUAWEI not recognized properly (3 modem) |
| Diana Eichert | bcw(4) is gone |
| James Carpenter | Re: SCSI Controller |
| Zane H. Healy | Linux BBS List #8 (Long) |
| Lars Wirzenius | Re: Parse Error |
| Ian Jackson | *** READ THIS BEFORE POSTING *** |
