Open file list is currently created as statically allocated array (64 items).
Once this array is filled up, loader will not be able to operate with files.
In most cases, this mechanism is good enough, but the problem appears, when
we have many disks with zfs pool(s). In current loader implementation, all
discovered zfs pool configurations are kept in memory and disk devices open -
consuming the open file array. Rewrite the open file mechanism to use
dynamically allocated list.
Details
Diff Detail
- Repository
- rS FreeBSD src repository - subversion
- Lint
Lint Passed - Unit
No Test Coverage - Build Status
Buildable 40822 Build 37711: arc lint + arc unit
Event Timeline
stand/libsa/close.c | ||
---|---|---|
74–75 | This should be a function fd2open_file(fd) or something. It's repeated a lot. | |
stand/libsa/closeall.c | ||
44 | nit: casts like this usually don't have a space. | |
stand/libsa/lseek.c | ||
34–35 | This file has a lot of white space changes that makes it a little harder to review.... If possible, can you split the changes between functional and whitespace? | |
stand/libsa/netif.c | ||
306 | same comment for the socket list as I had for the file list: this lookup code is repeated 3 times, which is my usual threshold... |
this is coming along nicely. I have only a couple of questions around closing files.
stand/libsa/close.c | ||
---|---|---|
95 | why do you free them only from the tail? | |
stand/libsa/closeall.c | ||
47 | This is a total re-write of this function / file. Whomever wrote it (you or your client) should likely remove the old licenses and put a standard BSD-2-Clause license in its place. | |
stand/libsa/netif.c | ||
374 | Same question as I had for the other close routine: Why only free from the end? | |
stand/libsa/open.c | ||
125 | I think this is my answer to the questions. But you should document the requirement that the list be ordered by fd,. |
stand/libsa/close.c | ||
---|---|---|
95 | The reason is actually pretty simple. We do need unique ID for files (and sockets). If we switch to use list, we have three alternates:
I did pick first option because in most cases, the fd is really short lived and with one exception, we practically do not keep multiple files open. This one exception is zfs pools - pools are discovered, and "imported", with disk devices kept open and practically never closed... |
stand/libsa/close.c | ||
---|---|---|
95 | comment added to open.c | |
stand/libsa/netif.c | ||
374 | comment added (next to list declaration). | |
stand/libsa/open.c | ||
125 | Yea, we can use different strategies to handle ID. But it is not just about how we manage ID, but also combination with entry search for lookup/remove/add... anyhow, since both open file and sockets lists do have special properties there, I think this approach is reasonably good... :) |
I'll note that we could remove from the middle of the list and maintain the current preconditions for the code. However, there's so few files open that this optimization is optional and likely not worth making.