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

Update CRC module to SSE4_CRC32 v3.1.0 #488

Merged
merged 1 commit into from
Apr 28, 2015

Conversation

anandsuresh
Copy link
Contributor

- v3.1.0 fixes issues with hardware CRC detection and provides software fallbalck
for platforms lacking hardware CRC support.
- Reduces the number of layers between core code and the CRC functions
@googlebot googlebot added the cla: yes This human has signed the Contributor License Agreement. label Apr 9, 2015
Google Inc.
Anand Suresh

This comment was marked as spam.

This comment was marked as spam.

This comment was marked as spam.

@ryanseys
Copy link
Contributor

ryanseys commented Apr 9, 2015

It seems that under Node v0.12.0 the package cannot be installed.

@anandsuresh
Copy link
Contributor Author

Strange. The sse4_crc32 module passed all tests on node v0.10, 0.11 and 0.12. Is there something different about the environment that the CI system is running in?

I just built the module on my macbook running node v0.12.0.

anandsuresh@AnandSuresh-23981 sse4_crc32 (master) $ nvm install v0.12.0
######################################################################## 100.0%
Now using node v0.12.0
anandsuresh@AnandSuresh-23981 sse4_crc32 (master) $ node -v
v0.12.0
anandsuresh@AnandSuresh-23981 sse4_crc32 (master) $ make clean
./node_modules/.bin/node-gyp clean
gyp info it worked if it ends with ok
gyp info using [email protected]
gyp info using [email protected] | darwin | x64
gyp info ok
anandsuresh@AnandSuresh-23981 sse4_crc32 (master) $ make
./node_modules/.bin/node-gyp clean
gyp info it worked if it ends with ok
gyp info using [email protected]
gyp info using [email protected] | darwin | x64
gyp info ok
npm install .

> [email protected] install /Users/anandsuresh/voxer-inc/sse4_crc32
> node-gyp rebuild

child_process: customFds option is deprecated, use stdio instead.
  CXX(target) Release/obj.target/sse4_crc32/src/sse4_crc32.o
  SOLINK_MODULE(target) Release/sse4_crc32.node
  SOLINK_MODULE(target) Release/sse4_crc32.node: Finished
./node_modules/.bin/node-gyp configure
gyp info it worked if it ends with ok
gyp info using [email protected]
gyp info using [email protected] | darwin | x64
gyp info spawn python
gyp info spawn args [ '/Users/anandsuresh/voxer-inc/sse4_crc32/node_modules/node-gyp/gyp/gyp_main.py',
gyp info spawn args   'binding.gyp',
gyp info spawn args   '-f',
gyp info spawn args   'make',
gyp info spawn args   '-I',
gyp info spawn args   '/Users/anandsuresh/voxer-inc/sse4_crc32/build/config.gypi',
gyp info spawn args   '-I',
gyp info spawn args   '/Users/anandsuresh/voxer-inc/sse4_crc32/common.gypi',
gyp info spawn args   '-I',
gyp info spawn args   '/Users/anandsuresh/voxer-inc/sse4_crc32/node_modules/node-gyp/addon.gypi',
gyp info spawn args   '-I',
gyp info spawn args   '/Users/anandsuresh/.node-gyp/0.12.0/common.gypi',
gyp info spawn args   '-Dlibrary=shared_library',
gyp info spawn args   '-Dvisibility=default',
gyp info spawn args   '-Dnode_root_dir=/Users/anandsuresh/.node-gyp/0.12.0',
gyp info spawn args   '-Dmodule_root_dir=/Users/anandsuresh/voxer-inc/sse4_crc32',
gyp info spawn args   '--depth=.',
gyp info spawn args   '--no-parallel',
gyp info spawn args   '--generator-output',
gyp info spawn args   'build',
gyp info spawn args   '-Goutput_dir=.' ]
gyp info ok
./node_modules/.bin/node-gyp build
gyp info it worked if it ends with ok
gyp info using [email protected]
gyp info using [email protected] | darwin | x64
gyp info spawn make
gyp info spawn args [ 'BUILDTYPE=Release', '-C', 'build' ]
make[1]: Nothing to be done for `all'.
gyp info ok
./node_modules/.bin/tap test/*.test.js
ok test/basic.test.js ................................... 4/4
total ................................................... 4/4

ok

@stephenplusplus
Copy link
Contributor

Thanks for sending this in, @anandsuresh! I'm a little out of my wheelhouse trying to investigate this issue, but the 0.12 Travis error is:

Error: Module did not self-register.

Googling took me to an explanation of what that means: sass/node-sass#655 - maybe from their solution, one of you can make sense of how to fix for sse4_crc32?

@anandsuresh
Copy link
Contributor Author

That's the result I landed up at as well. Have been trying to make sense of
it but no luck so far.

Might have to soon up a Linux VM and test it locally.
On Apr 20, 2015 7:20 AM, "Stephen Sawchuk" [email protected] wrote:

Thanks for sending this in, @anandsuresh https://github.com/anandsuresh!
I'm a little out of my wheelhouse trying to investigate this issue, but the 0.12
Travis error
https://travis-ci.org/GoogleCloudPlatform/gcloud-node/builds/57841134#L963
is:

Error: Module did not self-register.

Googling took me to an explanation of what that means: sass/node-sass#655
sass/node-sass#655 - maybe from their
solution, one of you can make sense of how to fix for sse4_crc32?


Reply to this email directly or view it on GitHub
#488 (comment)
.

@ryanseys
Copy link
Contributor

I emailed the folks at Travis describing our issue here and they replied with the following:

Thanks for the email. We are sorry to hear about the problem you are having. What sort of machine are you using for your development? Is it an Ubuntu machine running 64-bit kernel, or are there significant differences? Also, does the problem occur if you run the build on the standard infrastructure with sudo: required?

It appears that their boxes run on Ubuntu 64-bit. Perhaps we could try switching to the old infrastructure by setting sudo: required in our travis.yml

@ryanseys
Copy link
Contributor

Update: https://travis-ci.org/ryanseys/gcloud-node/builds/60161412

No, sudo: required didn't help. I believe it's an issue with the module being incompatible with node 0.12.0 on certain machines. :(

@anandsuresh
Copy link
Contributor Author

Will try building the module manually in an Ubuntu 12.x 64-bit VM and report back.

@ryanseys
Copy link
Contributor

I booted into a Docker with Ubuntu 64-bit and installed Node 0.12.2, attempted to install sse4_crc32, giving me the following error:

root@bfe40e612555:/# npm install sse4_crc32
-
> [email protected] install /node_modules/sse4_crc32
> node-gyp rebuild

gyp ERR! configure error
gyp ERR! stack Error: Can't find Python executable "python", you can set the PYTHON env variable.
gyp ERR! stack     at failNoPython (/usr/lib/node_modules/npm/node_modules/node-gyp/lib/configure.js:103:14)
gyp ERR! stack     at /usr/lib/node_modules/npm/node_modules/node-gyp/lib/configure.js:42:11
gyp ERR! stack     at F (/usr/lib/node_modules/npm/node_modules/which/which.js:40:25)
gyp ERR! stack     at E (/usr/lib/node_modules/npm/node_modules/which/which.js:43:29)
gyp ERR! stack     at /usr/lib/node_modules/npm/node_modules/which/which.js:54:16
gyp ERR! stack     at FSReqWrap.oncomplete (fs.js:95:15)
gyp ERR! System Linux 3.18.11-tinycore64
gyp ERR! command "node" "/usr/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "rebuild"
gyp ERR! cwd /node_modules/sse4_crc32
gyp ERR! node -v v0.12.2
gyp ERR! node-gyp -v v1.0.3
gyp ERR! not ok

So it seems at the very least we need Python installed to build this thing.

Edit: And make and g++. Then it finally built without errors. Never got the Error: Module did not self-register. error.

@anandsuresh
Copy link
Contributor Author

Aah! Python is a node-gyp dependency. Maybe someday we can build node-addons without node-gyp and python. But until then...

So it seems more like a test environment issue.

@ryanseys
Copy link
Contributor

Hmm, I actually don't think that's an issue really. It seems to have nothing to do with the Module did not self register. error. I'm curious if pre-built binaries were provided for the test environment it would get rid of the issue. I'd imagine that's difficult to do though.

@anandsuresh
Copy link
Contributor Author

Oh. I see what you mean. Having taken a peek at the Travis logs, it seems that the module builds correctly when the npm install step is executed. So I'm not sure why that error pops up. I have had no luck reproducing that error at my end.

Googling the issue brings up some other modules that faced similar problems, but those were resolved by deleting the node_modules directory and reinstalling the module. Doesn't seem like that solution would help in this case.

Yet another analysis mentioned that this might be caused due to inconsistencies in node-gyp and/or npm due to a botched install that did not complete successfully, and/or failed to clean up files from older versions. Perhaps the image being used by the Travis CI system suffers from that issue. No real way to verify that though.

The SSE4_CRC32 module itself uses Travis CI, without any problems on node versions 0.10, 0.11 and 0.12.

@anandsuresh
Copy link
Contributor Author

Also, if it helps, here are the environments where I've tested the SSE4_CC32 module to be working:

  • MacOS 10.9.5
  • SmartOS 5.11
  • CentOS 6.6
  • FreeBSD 10.0

@ryanseys
Copy link
Contributor

Yes I'm looking further and it appears it might be an issue with the way we are using mockery, one of the test libraries we are using.

@ryanseys ryanseys merged commit 4a0e81e into googleapis:master Apr 28, 2015
@dickfickling
Copy link

@ryanseys Could you push a new release to npm with this fix?

@anandsuresh anandsuresh deleted the crc-update branch May 4, 2015 18:44
@ryanseys
Copy link
Contributor

ryanseys commented May 4, 2015

@richardfickling I'll do my best to get 0.14.0 pushed to npm in the near future.

@ryanseys
Copy link
Contributor

ryanseys commented May 7, 2015

@richardfickling A new version has been pushed if you didn't realize :)

@dickfickling
Copy link

Thanks @ryanseys 👍

chingor13 pushed a commit that referenced this pull request Aug 22, 2022
gcr.io/repo-automation-bots/owlbot-nodejs:latest@sha256:f4734af778c3d0eb58a6db0078907a87f2e53f3c7a6422363fc37ee52e02b25a
chingor13 pushed a commit that referenced this pull request Aug 22, 2022
gcr.io/repo-automation-bots/owlbot-nodejs:latest@sha256:f4734af778c3d0eb58a6db0078907a87f2e53f3c7a6422363fc37ee52e02b25a
chingor13 pushed a commit that referenced this pull request Aug 22, 2022
gcr.io/repo-automation-bots/owlbot-nodejs:latest@sha256:f4734af778c3d0eb58a6db0078907a87f2e53f3c7a6422363fc37ee52e02b25a
sofisl pushed a commit that referenced this pull request Jan 24, 2023
sofisl pushed a commit that referenced this pull request Jan 25, 2023
sofisl pushed a commit that referenced this pull request Sep 13, 2023
[![WhiteSource Renovate](https://app.renovatebot.com/images/banner.svg)](https://renovatebot.com)

This PR contains the following updates:

| Package | Change | Age | Adoption | Passing | Confidence |
|---|---|---|---|---|---|
| [sinon](https://sinonjs.org/) ([source](https://togithub.com/sinonjs/sinon)) | [`^9.0.1` -> `^10.0.0`](https://renovatebot.com/diffs/npm/sinon/9.2.4/10.0.0) | [![age](https://badges.renovateapi.com/packages/npm/sinon/10.0.0/age-slim)](https://docs.renovatebot.com/merge-confidence/) | [![adoption](https://badges.renovateapi.com/packages/npm/sinon/10.0.0/adoption-slim)](https://docs.renovatebot.com/merge-confidence/) | [![passing](https://badges.renovateapi.com/packages/npm/sinon/10.0.0/compatibility-slim/9.2.4)](https://docs.renovatebot.com/merge-confidence/) | [![confidence](https://badges.renovateapi.com/packages/npm/sinon/10.0.0/confidence-slim/9.2.4)](https://docs.renovatebot.com/merge-confidence/) |

---

### Release Notes

<details>
<summary>sinonjs/sinon</summary>

### [`v10.0.0`](https://togithub.com/sinonjs/sinon/blob/master/CHANGELOG.md#&#8203;1000--2021-03-22)

[Compare Source](https://togithub.com/sinonjs/sinon/compare/v9.2.4...v10.0.0)

==================

-   Upgrade nise to 4.1.0
-   Use [@&#8203;sinonjs/eslint-config](https://togithub.com/sinonjs/eslint-config)[@&#8203;4](https://togithub.com/4) => Adopts ES2017 => Drops support for IE 11, Legacy Edge and legacy Safari

</details>

---

### Renovate configuration

:date: **Schedule**: "after 9am and before 3pm" (UTC).

:vertical_traffic_light: **Automerge**: Disabled by config. Please merge this manually once you are satisfied.

:recycle: **Rebasing**: Whenever PR is behind base branch, or you tick the rebase/retry checkbox.

:no_bell: **Ignore**: Close this PR and you won't be reminded about this update again.

---

 - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box

---

This PR has been generated by [WhiteSource Renovate](https://renovate.whitesourcesoftware.com). View repository job log [here](https://app.renovatebot.com/dashboard#github/googleapis/nodejs-automl).
sofisl pushed a commit that referenced this pull request Sep 14, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
cla: yes This human has signed the Contributor License Agreement.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

illegal hardware instruction (core dumped) on importing gcloud
6 participants