RE: Why is the kfree() argument const?
- From: "David Schwartz" <davids@xxxxxxxxxxxxx>
- Date: Fri, 18 Jan 2008 12:55:09 -0800
On Thu, 17 Jan 2008, David Schwartz wrote:
Nonsense. The 'kfree' function *destroys* the object pointer to by the
pointer. How can you describe that as not doing anything to the object?
Here's an idea. Think it through.
Why don't we need write permissions to a file to unlink it?
You cannot unlink a file. Given a file, if you were to attempt to unlink it,
what directory would you remove it from?
Unlinking a file is an operation on the directory the file is in, not on the
directory itself. We do need write permissions to the directory.
If you had only a const pointer to the data in the file, you should
definitely not be able to use that pointer to find a directory the file is
in and remove it without clearly indicating you know *exactly* what you're
doing. Given just that 'const' pointer, you're not supposed to be modifying
the data and certainly using that pointer to modify anything logically above
it.
Here's a hint: because unlinking doesn't *write* to it. In fact, it
doesn't read from it either. It doesn't do any access at all to that
object, it just *removes* it.
Right. It's an operation on the directory the file is in that might have
consequences for the file.
Is the file gone after you unlink it? Yes (modulo refcounting for
aliasing
"pointers" aka filenames, but that's the same for any memory manager -
malloc/free just doesn't have any, so you could think of it as a
non-hardlinking filesystem).
The file is gone if and only if the directory was the only thing that needed
the file to exist. A file that is only on one directory "belongs to" that
directory. So write permission to the directory is all that is needed.
What you are arguing is essentially that you should be able to remove a file
from any directory it is in just because you have write access to the file's
data.
So you're the one who are speaking nonsense. Making something "not exist"
is not at all the same thing as accessing it for a write (or a read). It
is a metadata operation that doesn't conceptually change the data in any
way, shape or form - it just makes it go away.
Making something "not exist" is a modification operation on that thing.
And btw, exactly as with kfree(), a unlink() may well do something like
"disk scrubbing" for security purposes, or cancel pending writes to the
backing store. But even though it may write (or, by undoing a pending
write, effectively "change the state") to the disk sectors that used to
contain the file data, ONLY AN IDIOT would call it "writing to the file".
Because "the file" is gone. Writing to the place where the file
used to be
is a different thing.
I agree with you about that part. I can't understand why you keep thinking
this is where our disagreement lies when I've stated at least three times
that I agree about this. The issue has nothing to do with whether or not
'kfree' modifies the particular bytes pointed to. It has to do with whether
or not 'kfree' is the kind of operation one would normally want to allow on
a 'const' object.
So give it up. You're wrong. Freeing a memory area is not "writing to it"
or accessing it in *any* manner, it's an operation on another level
entirely.
Nevertheless, it's a modification operation on an object that's not supposed
to be modified.
By the way, I did think of one argument that supports your position: Suppose
you have a reference counted object. You have a 'release reference and free
if zero' function. Should it be 'const'? If not, how can a 'lookup and
reference for read' function return a const pointer to the object?
However, on balance, I think a 'release reference and free if zero' function
that operates on a const pointer is sufficiently unusual that a cast to show
you know what you're doing is not a bad thing. In this case, you know it's
safe to destroy the object through a const pointer because you *know* nobody
gave you the 'const' pointer trusting you not to destroy the object. A cast
to show you have that special knowledge is, IMO, reasonable.
DS
--
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/
- References:
- RE: Why is the kfree() argument const?
- From: Linus Torvalds
- RE: Why is the kfree() argument const?
- Prev by Date: Re: [PATCH 4/5] x86: Add config variables for SMP_MAX
- Next by Date: Re: [patch 02/11] PAT x86: Map only usable memory in x86_64 identity map and kernel text
- Previous by thread: RE: Why is the kfree() argument const?
- Next by thread: Re: Why is the kfree() argument const?
- Index(es):
Relevant Pages
|
Loading