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

Support big endian #13

Merged
merged 5 commits into from
Oct 13, 2020
Merged

Support big endian #13

merged 5 commits into from
Oct 13, 2020

Conversation

guybedford
Copy link
Collaborator

This adds big endian support to the copy function.

I don't want to merge this until it has actually been tested on the right hardware, but don't have access to a test machine - any assitance testing would be really great.

src/lexer.js Outdated
let i = 0;
while (i < len) {
outBuf16[i] = src.charCodeAt(i * 2 + 1);
outBuf16[i + 1] = src.charCodeAt(i * 2);
Copy link
Member

Choose a reason for hiding this comment

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

This doesn't appear to work as

  • outBuf16[i + 1] gets overwritten the next time around the loop by outBuf16[i]
  • it swaps pairs of 16-bit values rather than the octets within the 16-bit value.

I've hacked something together that appears to work on AIX (tests pass). I'll need to tidy up a bit (I've almost certainly broken little endian in what I currently have) -- I'll try to get a PR in either later tonight or tomorrow.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Thanks @richardlau, I've pushed up some fixes here, running on nodejs/node#35634 to see if it works, but if it's still failing your PR would be a huge help.

@guybedford guybedford merged commit 88b711b into master Oct 13, 2020
@guybedford
Copy link
Collaborator Author

Finally got it working!

let i = 0;
while (i < len) {
const ch = src.charCodeAt(i);
outBuf16[i++] = (ch & 0xff) << 8 | (ch & 0xff0) >> 8;
Copy link
Contributor

@ExE-Boss ExE-Boss Oct 14, 2020

Choose a reason for hiding this comment

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

This is missing a 0, which causes the most significant nibble to be discared:

Suggested change
outBuf16[i++] = (ch & 0xff) << 8 | (ch & 0xff0) >> 8;
outBuf16[i++] = (ch & 0xff) << 8 | (ch & 0xff00) >> 8;

Copy link
Collaborator Author

@guybedford guybedford Oct 14, 2020

Choose a reason for hiding this comment

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

Thanks for spotting this, it wasn't causing an issue because the right shift drops these bits anyway, the version on master has the fix.

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