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

Bug: Luban does not finish loading STL on MacOS Sequoia 15.0.1 with Apple Silicon M3 #2513

Open
ITmaze opened this issue Oct 28, 2024 · 6 comments

Comments

@ITmaze
Copy link

ITmaze commented Oct 28, 2024

🐞 bug report

When attempting to load an STL file, even the standard included ones, the loading starts and stops at different locations, depending on the mode and the model. It appears that you cannot complete the loading of any STL.

  • On 3D printing, the vase loads 75% and stops
  • On CNC, the chess pieces do not load, a standard benchy loads 12.5%, the cube.stl in the /Applications/Snapmaker Luban.app/Resources/app/resources/engine-test/cube.stl also loads 12.5%
  • I can see the laser giftbox, but the preview is empty.
  • I can see the CNC phone holder, but the preview is empty.

Affected Version(s)

  • Version 4.13.0 (4.13.0)

To Reproduce

  • Install Luban
  • Launch Luban
  • Configure machine
  • Attempt to open a supplied model
  • See failure

I also attempted to use "Help" -> "Reset Configurations" with the same results.

🌍 Your Environment

  • MacBook Air, 13-inch, M3, 2024, 8GB RAM
  • MacOS: Sequoia 15.0.1 (24A348)
  • Printer: Snapmaker A350 with enclosure and 4th axis.
@ITmaze
Copy link
Author

ITmaze commented Nov 14, 2024

I raised this issue directly with Snapmaker Support who asked for the log file.

I've also attached the index.js file (though to send it, I've had to add a .txt extension) that the log refers to, since there's nothing quite like having the actual file to debug an issue.

  errno: -86,
  code: 'Unknown system error -86',
  syscall: 'spawn'

I note that this appears to be a known issue with node.js, indicating a mismatch between the binary architecture (of the file being spawned) and the system CPU architecture of the computer on which it's running.

It appears that the Electron development environment Snapmaker is using is not configured correctly to deal with the M3 CPU in my Machine.

Snapmaker Support indicated that the "workaround" was to install Rosetta, which is not a viable option in my system for reasons outside of the scope of this ticket, suffice to say, there is no "undo" from installing Rosetta, as far as I know, you cannot remove it after installing it.

The reason that installing Rosetta works, is that the bug caused by this mismatch is hidden because the binary will run fine on an emulated x86 machine which is what Rosetta does - unfortunately it doesn't actually fix the issue.

I suspect that this github issue is related:

The files:

@ITmaze
Copy link
Author

ITmaze commented Dec 6, 2024

In response to a (for some reason not visible here) direct email from "@xiwai2" which stated:

Sorry, we are unable to analyze the problem based on the information you have provided. We hope you can contact our after-sales service to help you solve the problem.

I'd like to point out that I have been in touch with the Snapmaker support team (Ticket: 180620) throughout the past month. I have also provided the same logs to them as I have here. I have also confirmed that the bug persists with version 4.14.0 of Snapmaker Luban and version 15.1.1 of MacOS.

It occurred to me that if the person testing this bug is unable to reproduce it, they have Rosetta installed, which I do not. Snapmaker support appears to confirm this:

Our developers found that there is indeed a problem with the system after analysis.

It appears that the bug occurs because the electron-builder in use has not been properly configured to generate actual ARM binaries, which I've also pointed out to the Snapmaker support team.

Shy of me installing electron-builder on my own infrastructure, cloning the repository, I'm not sure what else is required to fix this bug.

@ITmaze
Copy link
Author

ITmaze commented Jan 15, 2025

This issue persists with the versions of Luban released since I lodged this bug:

  • 4.13.0
  • 4.14.0
  • 4.15.0

@ITmaze
Copy link
Author

ITmaze commented Jan 17, 2025

Consider the following directory in the MacOS arm64 application:

  • /Applications/Snapmaker Luban.app/Contents/Resources/app/node_modules/@snapmaker/snapmaker-lunar/engine/MacOS

Note that there are three files there, none are arm64 compatible:

  • LunarMP: Mach-O 64-bit executable x86_64
  • LunarSlicer: Mach-O 64-bit executable x86_64
  • LunarTPP: Mach-O 64-bit executable x86_64

Attempting to run these on an Apple Silicon machine results in this error:

  • zsh: bad CPU type in executable: ./LunarMP
  • zsh: bad CPU type in executable: ./LunarSlicer
  • zsh: bad CPU type in executable: ./LunarTPP

I strongly suspect that this is the cause of the issue and I continue to suspect that an incorrectly configured electron build process is the root cause.

@ITmaze
Copy link
Author

ITmaze commented Jan 18, 2025

Just grepped for 'arm' and 'arm64' through the source of LunarSlicer which I presume is the origin of that code, and there is no reference whatsoever in relation to arm64.

I don't think this has ever worked and it looks like it's never been tested without Rosetta installed.

@ITmaze
Copy link
Author

ITmaze commented Jan 19, 2025

This bug appears to be a duplicate of #2460.

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

No branches or pull requests

1 participant