Coder Social home page Coder Social logo

Comments (13)

solidpixel avatar solidpixel commented on August 14, 2024

Never tried Emscripten, so "will look" but fair warning that it might take a while before I get around to it.

from astc-encoder.

MarkCallow avatar MarkCallow commented on August 14, 2024

The only reason I opened the issue is because the warning says that on some native platforms unaligned accesses are very slow.

from astc-encoder.

solidpixel avatar solidpixel commented on August 14, 2024

I generally try to avoid unaligned access, as we've seen people try to run this on Arm systems with unaligned access disabled so it will fault if you try.

from astc-encoder.

solidpixel avatar solidpixel commented on August 14, 2024

Looks like UBSAN is flagging a few cases where we pass unaligned addresses into SIMD intrinsics. The intrinsics in question explicitly allow unaligned addresses, so this isn't necessarily a problem, but would be good to avoid if we can.

env UBSAN_OPTIONS=print_stacktrace=true ./bin/astcenc-avx2 -tl in.png out.png 6x6 -medium

from astc-encoder.

solidpixel avatar solidpixel commented on August 14, 2024

@MarkCallow I'm in two minds about this one, given that this only impacts SIMD intrinsics which explicitly allow unaligned access, but can you try this branch:

https://github.com/ARM-software/astc-encoder/tree/unaligned_ubsan

... which at least seems to make UBSAN happy for the SIMD builds.

There is no measurable impact on performance (at least on a single x86-64 machine I tested on), as this is not impacting loads we expect to hit a lot in core loops.

from astc-encoder.

solidpixel avatar solidpixel commented on August 14, 2024

Decided that a clean UBSAN was worth the cost, as it's a useful tool, so I've merged the branch into main. Can you let me know if this solves the problem - I think it should.

from astc-encoder.

MarkCallow avatar MarkCallow commented on August 14, 2024

Can you let me know if this solves the problem - I think it should.

Sorry for the delay. I'll test it as soon as I have time.

from astc-encoder.

solidpixel avatar solidpixel commented on August 14, 2024

No need to apologize - there is no hurry =)

from astc-encoder.

MarkCallow avatar MarkCallow commented on August 14, 2024

Can you let me know if this solves the problem - I think it should.

Yes. It solved the problem. I no longer get the exception when SAFE_HEAP is defined.

When do you expect to release 4.8.0?

from astc-encoder.

solidpixel avatar solidpixel commented on August 14, 2024

When do you expect to release 4.8.0?

I didn't really have a date in mind. If you need one to pull for KTX-Tools, I can do it this week.

from astc-encoder.

MarkCallow avatar MarkCallow commented on August 14, 2024

I didn't really have a date in mind. If you need one to pull for KTX-Tools, I can do it this week.

I have quite a bit more work before our next release so there is no huge rush but if you can do it this week I can pull it now while there is no danger of it being a critical path item.

from astc-encoder.

solidpixel avatar solidpixel commented on August 14, 2024

OK, I'll see what I can get done. Should be this week, but we're rolling out a new CI for this based on public GitHub Actions, so might be some teething issues =)

from astc-encoder.

MarkCallow avatar MarkCallow commented on August 14, 2024

OK, I'll see what I can get done. Should be this week.

Thanks Pete. I've subscribed to notifications of new releases.

from astc-encoder.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.