Opened 5 years ago
Last modified 5 years ago
#16301 in-progress bug
lsindex Illegal Byte Sequence Error
Reported by: | AGMS | Owned by: | axeld |
---|---|---|---|
Priority: | normal | Milestone: | Unscheduled |
Component: | Applications/Command Line Tools | Version: | R1/beta2 |
Keywords: | lsindex | Cc: | agmsmith@…, ttcoder |
Blocked By: | Blocking: | ||
Platform: | All |
Description
When running "lsindex -l" it always prints an error message at the end, after listing all the indices:
lsindex: fs_read_index_dir: (-2147454938) Illegal byte sequence
Works okay if you just do "lsindex". I thought it may be a corrupted index directory (tried adding and removing indices), but this happens on a clean R1B2 installer boot too.
Change History (7)
comment:1 by , 5 years ago
Cc: | added |
---|
comment:2 by , 5 years ago
Behavior confirmed in beta2, using the exact same partitions to test ; now to actually test on beta1...
comment:3 by , 5 years ago
Turns out the bug/problem was already present in beta1:
Int-64 12/20/2018 04:48 PM 3410944 size lsindex: fs_read_index_dir: (-2147454938) Illegal byte sequence ~> uname -a Haiku shredder 1 hrev52295+132 Jan 26 2020 08:04 x86_64 x86_64 Haiku
So that "narrows" it down (in a manner of speaking...) to somewhere between 50465 and 52295+132.
comment:4 by , 5 years ago
When I grep for EILSEQ (that's the corresponding error code), I get very few hits. The ones I get pretty much all have to do with unicode conversion. The code in lsindex looks like this:
dirent *index = fs_read_index_dir(indices); if (index == NULL) { if (errno != B_ENTRY_NOT_FOUND && errno != B_OK) { printf("%s: fs_read_index_dir: (%d) %s\n", argv[0], errno, strerror(errno)); return errno; } break; }
This does look good, however, when we look at readdir() which is what fs_read_index_dir() uses internally, we find this code:
count = _kern_read_dir(dir->fd, &dir->first_entry, (char*)dir + DIR_BUFFER_SIZE - (char*)&dir->first_entry, USHRT_MAX); if (count <= 0) { if (count < 0) __set_errno(count); // end of directory return NULL; }
If count == 0, errno is not set, but NULL is returned. The error shown comes from another call.
comment:5 by , 5 years ago
Owner: | changed from | to
---|---|
Status: | new → in-progress |
comment:6 by , 5 years ago
The incorrect error message has been fixed in hrev54364. However, the underlying issue has not been investigated yet (I cannot reproduce it on my normal install).
Therefore I'll keep this one open, until someone has gotten to the root cause of it.
comment:7 by , 5 years ago
I'm able to recreate it by running R1B2 hrev54154_111 anyboot.iso in VirtualBox in 64 bit mode. Just pick boot to desktop, fire up a Terminal and type in lsindex -l.
FWIW, the error does not occur on an old pre-beta hrev (50465). Will try on beta1 too when I reboot.