59 lines
1.1 KiB
Go
59 lines
1.1 KiB
Go
package sctp
|
|
|
|
const (
|
|
paddingMultiple = 4
|
|
)
|
|
|
|
func getPadding(len int) int {
|
|
return (paddingMultiple - (len % paddingMultiple)) % paddingMultiple
|
|
}
|
|
|
|
func padByte(in []byte, cnt int) []byte {
|
|
if cnt < 0 {
|
|
cnt = 0
|
|
}
|
|
padding := make([]byte, cnt)
|
|
return append(in, padding...)
|
|
}
|
|
|
|
// Serial Number Arithmetic (RFC 1982)
|
|
func sna32LT(i1, i2 uint32) bool {
|
|
return (i1 < i2 && i2-i1 < 1<<31) || (i1 > i2 && i1-i2 > 1<<31)
|
|
}
|
|
|
|
func sna32LTE(i1, i2 uint32) bool {
|
|
return i1 == i2 || sna32LT(i1, i2)
|
|
}
|
|
|
|
func sna32GT(i1, i2 uint32) bool {
|
|
return (i1 < i2 && (i2-i1) >= 1<<31) || (i1 > i2 && (i1-i2) <= 1<<31)
|
|
}
|
|
|
|
func sna32GTE(i1, i2 uint32) bool {
|
|
return i1 == i2 || sna32GT(i1, i2)
|
|
}
|
|
|
|
func sna32EQ(i1, i2 uint32) bool {
|
|
return i1 == i2
|
|
}
|
|
|
|
func sna16LT(i1, i2 uint16) bool {
|
|
return (i1 < i2 && (i2-i1) < 1<<15) || (i1 > i2 && (i1-i2) > 1<<15)
|
|
}
|
|
|
|
func sna16LTE(i1, i2 uint16) bool {
|
|
return i1 == i2 || sna16LT(i1, i2)
|
|
}
|
|
|
|
func sna16GT(i1, i2 uint16) bool {
|
|
return (i1 < i2 && (i2-i1) >= 1<<15) || (i1 > i2 && (i1-i2) <= 1<<15)
|
|
}
|
|
|
|
func sna16GTE(i1, i2 uint16) bool {
|
|
return i1 == i2 || sna16GT(i1, i2)
|
|
}
|
|
|
|
func sna16EQ(i1, i2 uint16) bool {
|
|
return i1 == i2
|
|
}
|