mirror of
https://github.com/fumiama/WireGold.git
synced 2026-06-12 12:50:28 +08:00
fix: mtu
This commit is contained in:
@@ -28,7 +28,7 @@ func (m *Me) AddPeer(cfg *PeerConfig) (l *Link) {
|
|||||||
if ok {
|
if ok {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if cfg.MTU == 0 || cfg.MTU == 65535 || (m.mtu != 0 && cfg.MTU > m.mtu) {
|
if cfg.MTU == 0 || cfg.MTU == 65535 || cfg.MTU%8 != 0 || (m.mtu != 0 && cfg.MTU > m.mtu) {
|
||||||
panic("invalid mtu for peer " + cfg.PeerIP)
|
panic("invalid mtu for peer " + cfg.PeerIP)
|
||||||
}
|
}
|
||||||
l = &Link{
|
l = &Link{
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ func (l *Link) WriteAndPut(p *head.Packet, istransfer bool) (n int, err error) {
|
|||||||
for ; int(totl)-i > int(l.mtu); i += int(l.mtu) {
|
for ; int(totl)-i > int(l.mtu); i += int(l.mtu) {
|
||||||
logrus.Debugln("[link] split frag", i, ":", i+int(l.mtu), ", remain:", int(totl)-i-int(l.mtu))
|
logrus.Debugln("[link] split frag", i, ":", i+int(l.mtu), ", remain:", int(totl)-i-int(l.mtu))
|
||||||
packet.Data = data[:int(l.mtu)]
|
packet.Data = data[:int(l.mtu)]
|
||||||
cnt, err := l.write(packet, teatype, totl, uint16(uint(i)>>3), istransfer, true)
|
cnt, err := l.write(packet, teatype, totl, uint16(i>>3), istransfer, true)
|
||||||
n += cnt
|
n += cnt
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return n, err
|
return n, err
|
||||||
@@ -43,7 +43,7 @@ func (l *Link) WriteAndPut(p *head.Packet, istransfer bool) (n int, err error) {
|
|||||||
}
|
}
|
||||||
packet.Put()
|
packet.Put()
|
||||||
p.Data = data
|
p.Data = data
|
||||||
cnt, err := l.write(p, teatype, totl, uint16(uint(i)>>3), istransfer, false)
|
cnt, err := l.write(p, teatype, totl, uint16(i>>3), istransfer, false)
|
||||||
p.Put()
|
p.Put()
|
||||||
n += cnt
|
n += cnt
|
||||||
return n, err
|
return n, err
|
||||||
|
|||||||
Reference in New Issue
Block a user