Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix filedelta type in fd_seek #319

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

kulcsaradam
Copy link
Contributor

No description provided.

@@ -263,7 +263,7 @@ void WASI::fd_prestat_dir_name(ExecutionState& state, Value* argv, Value* result
void WASI::fd_seek(ExecutionState& state, Value* argv, Value* result, Instance* instance)
{
uint32_t fd = argv[0].asI32();
uint64_t fileDelta = argv[1].asI32();
uint64_t fileDelta = argv[1].asI64();
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This patch looks so simple, is this done?
If so, could you add a TC to verify this?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's just a typo fix, thats why it is simple, but I will add a test to verify it then.

Also according to the wasi specs it should be signed 64 bit, so I also missedtyped it. I will be correcting that.
fd_seek documentation

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@clover2123 I have been thinking about how I should write a proper test case for this. Filedelta describes the amount of bytes fd_seek should jump from the location that depends on whence.

To properly test it we would need a signed int32 maximum + 1 amount of bytes in a file, which is quite large, around 2.2 gigabytes and I am concerned about the size. (Please tell me if my math is wrong, it may be I just misscalculated.)

Fd_seek is based on the posix lseek which also uses a signed 64 bit value so I think its safe to say that a test is not that necessary I belive, though I could make a tests that generates a file that big, but I dont think it should be part of the CI.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does this do a type check? I think WebAssembly is strongly typed, so it should enforce a 64 bit value if the argument description of the function is correct.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@zherczeg asI64() checks the type in a debug mode only as far as I know. The argument description is correct in WASI.h but I dont think it actually enforces it to be a 64 bit value and as I have seen uvwasi does not actually check if it is the right type.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

When we find the wasi functions, we should also validate that the interface is the same as expected. This could be a follow-up work.

Signed-off-by: Ádám Kulcsár <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants