Skip to content

Commit

Permalink
pkg/snet: ignore decoding/parsing reading errors on SCIONPacketConn (#…
Browse files Browse the repository at this point in the history
…4670)

So far, the `snet/SCIONPacketConn` was bubbling up decoding/parsing
errors to the calling applications. In principle, these errors are not
recoverable by the application. The current solution simulates that the
network stack simply discards incorrect/malformated packets.
Otherwise,some libraries/applications would misbehave (similar to what
would happen if were to receive SCMP errors). If we believe that
SCION-aware applications using the low-level `SCIONPacketConn` should
receive the error, we can move this up to `Conn`.
  • Loading branch information
JordiSubira authored Dec 23, 2024
1 parent 105ab1b commit 0b42cbc
Showing 1 changed file with 19 additions and 2 deletions.
21 changes: 19 additions & 2 deletions pkg/snet/packet_conn.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import (
"time"

"github.com/scionproto/scion/pkg/addr"
"github.com/scionproto/scion/pkg/log"
"github.com/scionproto/scion/pkg/metrics/v2"
"github.com/scionproto/scion/pkg/private/common"
"github.com/scionproto/scion/pkg/private/serrors"
Expand Down Expand Up @@ -168,6 +169,14 @@ func (c *SCIONPacketConn) ReadFrom(pkt *Packet, ov *net.UDPAddr) error {
if err != nil {
return err
}
if remoteAddr == nil {
// XXX(JordiSubira): The remote address of the underlay next host
// will not be nil unless there was an error while reading the
// SCION packet. If the err is nil, it means that it was a
// non-recoverable error (e.g., decoding the header) and we
// discard the packet and keep
continue
}
*ov = *remoteAddr
if scmp, ok := pkt.Payload.(SCMPPayload); ok {
if c.SCMPHandler == nil {
Expand Down Expand Up @@ -206,7 +215,11 @@ func (c *SCIONPacketConn) readFrom(pkt *Packet) (*net.UDPAddr, error) {
pkt.Bytes = pkt.Bytes[:n]
if err := pkt.Decode(); err != nil {
metrics.CounterInc(c.Metrics.ParseErrors)
return nil, serrors.Wrap("decoding packet", err)
// XXX(JordiSubira): We avoid bubbling up parsing errors to the
// caller application to avoid problems with applications
// that don't expect this type of errors.
log.Debug("decoding packet", "error", err)
return nil, nil
}

udpRemoteAddr := remoteAddr.(*net.UDPAddr)
Expand All @@ -218,7 +231,11 @@ func (c *SCIONPacketConn) readFrom(pkt *Packet) (*net.UDPAddr, error) {
// *loopback:30041* `SCIONPacketConn.lastHop()` should yield the right next hop address.
lastHop, err = c.lastHop(pkt)
if err != nil {
return nil, serrors.Wrap("extracting last hop based on packet path", err)
// XXX(JordiSubira): We avoid bubbling up parsing errors to the
// caller application to avoid problems with applications
// that don't expect this type of errors.
log.Debug("extracting last hop based on packet path", "error", err)
return nil, nil
}
}
return lastHop, nil
Expand Down

0 comments on commit 0b42cbc

Please sign in to comment.