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

libcaliptra: add SHA accelerator API #1637

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

MDr164
Copy link

@MDr164 MDr164 commented Aug 14, 2024

Resolves #1361 by providing an abstraction above the caliptra_write_u32 and caliptra_read_u32 function calls according to the info at https://chipsalliance.github.io/caliptra-rtl/main/external-regs/?p=caliptra_top_reg.sha512_acc_csr

Copy link

linux-foundation-easycla bot commented Sep 11, 2024

CLA Signed

The committers listed above are authorized under a signed CLA.

  • ✅ login: MDr164 / name: Marvin Drees (c9f6499)

Copy link
Contributor

@nquarton nquarton left a comment

Choose a reason for hiding this comment

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

I think there are some issues when it comes to obtaining and releasing the lock. It think there should also be a test that performs these operations with a known answer to ensure this is working.


if (mode == CALIPTRA_SHA_ACCELERATOR_MODE_MBOX_384 || mode == CALIPTRA_SHA_ACCELERATOR_MODE_MBOX_512) {
// Writing 1 will clear the lock
caliptra_write_u32(CALIPTRA_SHA_ACCELERATOR_LOCK_ADDR, 0x1);
Copy link
Contributor

Choose a reason for hiding this comment

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

Don't we need to obtain the lock before interacting with it? I think we'll also want to return a busy error if it's not available as we do for the mailbox.

Copy link
Author

Choose a reason for hiding this comment

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

I manually ran a test on the FPGA for that back when I wrote it but I might have just been lucky that nothing interfered. But I agree, I'll add a tests around locking and unlocking the accelerator and check if that handling needs to be revised.

Copy link
Author

Choose a reason for hiding this comment

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

I'm somewhat confused about the locking behavior. Writing 1 will clear the lock and "reading 0" will set the lock but how does "reading 0" even work? That documentation looks odd to me now that I went over it again and it also seems like the emulator is not really doing what is written in the documentation.

Copy link
Collaborator

Choose a reason for hiding this comment

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

So my understanding is that when you read the lock register, if the read returns 0, it means the lock was available and now you have the lock. Every subsequent read should return 1 (that the lock is held).

Then writing 1 will clear the lock, so that the next read will return 0.

That documentation looks odd to me now that I went over it again and it also seems like the emulator is not really doing what is written in the documentation.

I would need to double check, but it's possible there's a mismatch. What unexpected behavior are you seeing?

Copy link
Author

Choose a reason for hiding this comment

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

iirc the lock was also set when writing 0 instead of just reading from it but your explanation that the read itself should cause the lock to be held and whether that worked is explained by the response.

Copy link
Author

Choose a reason for hiding this comment

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

I updated the code so that for the streaming variant we hold the lock with start and only release it again with finish. I'm unsure if that is the best way to do it but I also don't really see how holding and releasing between each call improves the situation given that they need to be called in this order anyways to produce a valid result.

@MDr164 MDr164 force-pushed the sha-accel branch 3 times, most recently from 3eef2a0 to c1d16d7 Compare December 11, 2024 18:02
@MDr164 MDr164 force-pushed the sha-accel branch 3 times, most recently from c613fe0 to 505ae38 Compare January 15, 2025 16:18
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.

Libcaliptra support needed for SHA accelerator engine
3 participants