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

ADIOS 2.8 Breaks Old BP4 Files (Compression) #3273

Closed
ax3l opened this issue Jul 1, 2022 · 7 comments
Closed

ADIOS 2.8 Breaks Old BP4 Files (Compression) #3273

ax3l opened this issue Jul 1, 2022 · 7 comments

Comments

@ax3l
Copy link
Contributor

ax3l commented Jul 1, 2022

The ADIOS 2.8 release series breaks reading of 2.7 (and ealier) BP4 files.

We use c-blosc compression with ADIOS2 in openPMD (WarpX, PIConGPU, etc al.). The ADIOS 2.8 series cannot read files written with earlier ADIOS2 releases anymore if we used compression.

Please see openPMD/openPMD-api#1293 for details.

@pnorbert et al., can you please add a backwards compatible read mode so we can continue to read our existing BP4 files?

@ax3l
Copy link
Contributor Author

ax3l commented Jul 1, 2022

@chuckatkins this will also affect our production usage of ParaView. if possible, please hold back on upgrading to ADIOS2 v2.8 in ParaView until this bug is fixed in ADIOS2.

@eisenhauer
Copy link
Member

@JasonRuonanWang, something you can do here?

@JasonRuonanWang
Copy link
Member

We have discussed this for a long time. This is because we added backward compatibility in the common compression headers in 2.8. Once we add the bytes in binary buffer to record the compressor version info, it will be always backward compatible. But there is no logically safe way to make a backward-compatible version and a non-backward-compatible version compatible. So @pnorbert and I thought, if we have to break it, then break it sooner than later. Break it when compression is still experimental, rather than break it when it's already production. If I were the original operator infrastructure designer, I would have added this from Day 1, so that it wouldn't break anything later on. But unfortunately I am not.

@eisenhauer
Copy link
Member

I understand that there's nothing code-local to the operator, but we do have file version info in the file headers that we could use as a conditional. Any hope there? Or was the resolution simply that we wouldn't read old files?

@JasonRuonanWang
Copy link
Member

I understand that there's nothing code-local to the operator, but we do have file version info in the file headers that we could use as a conditional. Any hope there? Or was the resolution simply that we wouldn't read old files?

What's in the file version info? Is it the ADIOS version or the BP format version? Maybe we can make it work for some specific cases, but I am not sure if it will work in general.

@pnorbert
Copy link
Contributor

pnorbert commented Jul 6, 2022

I am adding specific backward compatible hack for BP4 with BLOSC in #3275

@eisenhauer
Copy link
Member

Norbert's fix in #3275 is merged into 2.8 and master branches and the 2.8.2 release has been cut. Closing this as fixed.

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

4 participants