Hi,
I've been re-implementing my flexible vector hacks using isle, and I'm enjoying the DSL, but I'm wondering if there's any technical obstacle to organising the isle files by architecture features, so for aarch64: (1) scalar (2) Neon (3) SVE? I'm assuming it would be possible but would it be pretty? I'd like to have a logic separation but avoid duplicating much code.
AFAIK this would be quite easy to do, it'd basically just be an edit to cranelift's build script to add in one more *.isle
file and then you'd add contents as usual. I believe there's just one "namespace" right now so the division into files is purely for humans
Okay, thanks, I'll give it a go.
Yep, that worked nicely! Thanks again
@Sam Parker happy to hear things are working out for you with the DSL! We're working on documenting stuff now, so if there are any non-obvious or confusing bits, feedback is especially useful :-)
It seems fairly intuitive so far, especially with the existing work in the aarch64 and x64 backends to look at. I'm feeling much more productive than when I first used tablegen for sure :)
And my only gripe so far is that the DSL makes the encoding and register mapping process feel even more laborious and clumsy than before! I get to write some concise pattern matching and then have to revert to copy-paste some rust code in different places. Do you think there's a possible route to extend isle to handle some of the details of the instruction descriptions..?
@Sam Parker yes, the plan is to cover those with some automated codegen as well; @fitzgen (he/him) is planning on doing something with some yaml/toml-to-Rust magic so we can say "inst X with these fields, reads this reg, writes this reg"
not a full DSL but more like a schema description with metadata
Ah, wonderful!
Last updated: Jan 24 2025 at 00:11 UTC