1
0
mirror of https://github.com/myhdl/myhdl.git synced 2024-12-14 07:44:38 +08:00

32 lines
702 B
Python
Raw Normal View History

2003-02-19 22:35:10 +00:00
from myhdl import intbv
concat = intbv.concat # shorthand
COSET = 0x55
def calculateHec(header):
2003-02-19 23:38:08 +00:00
""" Return hec for an ATM header, represented as an intbv.
2003-02-20 11:26:05 +00:00
The hec polynomial is 1 + x + x**2 + x**8.
2003-02-19 22:35:10 +00:00
"""
hec = intbv(0)
for bit in header[32:]:
hec[8:] = concat(hec[7:2],
bit ^ hec[1] ^ hec[7],
bit ^ hec[0] ^ hec[7],
bit ^ hec[7]
)
return hec ^ COSET
headers = ( 0x00000000,
0x01234567,
0xbac6f4ca
)
2003-06-30 14:24:23 +00:00
def main():
2003-02-19 22:35:10 +00:00
for header in headers:
print hex(calculateHec(intbv(header)))
2003-06-30 14:24:23 +00:00
if __name__ == '__main__':
main()