mirror of
				https://github.com/ossrs/srs.git
				synced 2025-03-09 15:49:59 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			58 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			58 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
 | |
| }
 |