-
Notifications
You must be signed in to change notification settings - Fork 5
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: fix issue#8 #11
base: master
Are you sure you want to change the base?
fix: fix issue#8 #11
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -1090,6 +1090,7 @@ static int rdcp_test_client(struct rdcp_cb *cb) | |
struct ibv_send_wr *bad_wr; | ||
int size; | ||
long total_size = 0; | ||
struct stat filebuf; | ||
|
||
if (!cb->use_null) { | ||
cb->fd = open(cb->metadata.src_path, O_RDONLY); | ||
|
@@ -1098,14 +1099,17 @@ static int rdcp_test_client(struct rdcp_cb *cb) | |
perror("Couldn't open file"); | ||
goto out; | ||
} | ||
cb->fp = fdopen(cb->fd, "rb"); | ||
fseek(cb->fp, 0, SEEK_END); | ||
cb->metadata.size = ftell(cb->fp); | ||
// cb->fp = fdopen(cb->fd, "rb"); | ||
// fseek(cb->fp, 0, SEEK_END); | ||
// cb->metadata.size = ftell(cb->fp); | ||
stat(cb->metadata.src_path, &filebuf); | ||
cb->metadata.size = filebuf.st_size; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. how is using stat() instead of fseek() helps here? stat() is great and has better performance but beside that i dont see how it fix an issue. if you can change your commit to explain to use stat() instead of fseek() its fine by me to accept the commit anyway. but it is requiring some explanation why/how it fixes the issue with small files. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm inspired by issue#8. After read the issue, I searched the Internet for the difference between stat() and fseek(). I believed that it might have some conflicts between a file pointer(cb->fp) and a file descriptor(cb->fd), so it'd better use just a file pointer or just a file descriptor rather than hybird, and using stat() can simply and easily get the whole file's length without moving position(which I thought the bug happened), but actually I didn't know exactly why this happened, sorry. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ok and it is fine by me but need to refactor the patch to have a meaningful title and description. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ok and it is fine by me but need to refactor the patch to have a meaningful title and description. |
||
|
||
if (cb->metadata.size <= 0) { | ||
perror("size error"); | ||
goto out; | ||
} | ||
fseek(cb->fp, 0, SEEK_SET); | ||
// fseek(cb->fp, 0, SEEK_SET); | ||
} else { | ||
cb->metadata.size = 0; | ||
} | ||
|
@@ -1175,7 +1179,7 @@ static int rdcp_test_client(struct rdcp_cb *cb) | |
VERBOSE_LOG(1, "done\n"); | ||
|
||
out: | ||
fclose(cb->fp); | ||
// fclose(cb->fp); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. dont leave commented out code. also how does it fix anything? why do skip closing the file pointer? |
||
cb->fd = -1; | ||
|
||
return (cb->state == DISCONNECTED) ? 0 : ret; | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
dont leave commented out code.