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

Bit fiddling / slicing help #11

Open
kenkendk opened this issue Aug 11, 2017 · 0 comments
Open

Bit fiddling / slicing help #11

kenkendk opened this issue Aug 11, 2017 · 0 comments

Comments

@kenkendk
Copy link
Owner

kenkendk commented Aug 11, 2017

In low-level logic it is common that words are split into bits and bit regions.
In VHDL this is nicely supported with slice ranges, similar to how Python supports it.

To support this we should add two features to SME.

The first feature is with named fields, and could look like this:

public interface IBitSplitter<T> 
{
    T Value { get; set; }
}

public interface IMyCombi : IBitSplitter<byte>
{
    [BitOffset(0)]
    UInt3 Lead { get; set; }

    [BitOffset(0)]
    bool LeadSign { get; set; }

    [BitOffset(3)]
    UInt4 Control { get; set; }
}

The runtime will then create a struct that implements the interface correctly and allows the aliasing of the bits. The interface can then be used in a Bus definition as well.

To further help with bit fiddling, a number of support methods should be added:

public static UInt4 Slice4(this int value, uint offset, uint count = 4) { ... };
public static UInt8 Slice8(this int value, uint offset, uint count = 8) { ... };
...

The implementation in C# is simply a shift-n-mask, but the VHDL generator can emit slice expressions if the arguments are constant, and revert to shift-n-mask if the argument values cannot be determined statically.

A more general slice function could also be something like:

public static ulong Slice(this ulong value, uint offset, uint count) { ... };

This will return 64 bit values, but the VHDL vendor tools will usually optimize the unused bits away.


Want to back this issue? Post a bounty on it! We accept bounties via Bountysource.

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