AS12637 - SEEWEB SEEWEB s.r.lPI/PARFC 4890 ✓RPKI ✓ 10/10ASPA ✓

← back to summary

All countriesHomeState of IPv6TopologyIXPsAboutipv6.si ↗ Sparky

AS overview

Test target: 2001:4b78::22 · dns2.seeweb.it · address space: mixed · prefixes announced: 10

prefix(es): 2a05:b6c1::/32, 2a02:e9::/32, 2a02:ea::/32, 2a0d:b000::/29, 2a04:2700::/29, 2a05:b6c0::/32, 2a0b:fd40::/29, 2001:4b78::/29 (+2 more)

Targets & per-vantage-point probe results (10 target(s) across 3 vantage point(s))

Source codes (hover any badge for full description): CUR=curated · NS/SOA/MX=DNS records · SPF=SPF TXT · DRV=holder-derived (www, ns1, mail, gw, …) · ATL=RIPE Atlas · PDB=PeeringDB · WHOIS=RIPE whois · RDAP=RIPE RDAP · HIT=IPv6 Hitlist · RTR=in-prefix path hop (router) · PRB=static prefix probe · SYN=synthetic prefix::1 fallback

Target IP / hostnameSourceNL host (go6lab)ITA host (Karsolink)SLO host (6connect)
ping1500B:80:443reachedping1500B:80:443reachedping1500B:80:443reached
2001:4b78:1:20::28
smtp-avas.seeweb.it
MX??refusedrefusedrefusedrefused
2001:4b78:1:3::140
dns1.seeweb.it
drv??refusedrefusedrefusedrefused
2001:4b78:1:3::143
ns3.seeweb.it
drv??refusedrefusedrefusedrefused
2001:4b78:1:3::4
ns2.seeweb.it
drv??refusedrefusedrefusedrefused
2001:4b78:1:a::75
anubi.seeweb.it
SPFopenopenopenopenopenopen
2001:4b78:1:f:25::138
rah-b.seeweb.it
MX??-??-??-
2001:4b78:1:f::132
git.seeweb.it
drv??-??-??-
2001:4b78::22
dns2.seeweb.it
NS??refusedrefusedrefusedrefused
2001:4b78::5666
monitor.seeweb.it
drv?open-?open-?open-
2001:4b7a:100:1::1
ns3.freedns.si
NS??refusedrefusedrefusedrefused

MIX-IT / NAMEX / MINAP / TOP-IX / VSIX / EQUINIX-MILAN / BGPX-ROME / NAMEX-BARI / PCIX / DECIX-PALERMO peering

MIX-IT / NAMEX / MINAP / TOP-IX / VSIX / EQUINIX-MILAN / BGPX-ROME / NAMEX-BARI / PCIX / DECIX-PALERMO member - Open peering, peering member, since 2011-07-01. IPv6 LAN: 2001:7f8:b:100:1d1:a5d1:2637:86. Locations: -.

RPKI & ASPA

10 of 10 prefix(es) covered by a valid ROA.

PrefixRPKI stateReasonCovering VRP(s)
2a05:b6c1::/32✓ validmatched VRP (correct origin, length within maxLength)AS12637 /29 maxLen 48 (ripe)
2a02:e9::/32✓ validmatched VRP (correct origin, length within maxLength)AS12637 /32 maxLen 32 (ripe)
2a02:ea::/32✓ validmatched VRP (correct origin, length within maxLength)AS12637 /32 maxLen 48 (ripe)
2a0d:b000::/29✓ validmatched VRP (correct origin, length within maxLength)AS12637 /29 maxLen 48 (ripe)
2a04:2700::/29✓ validmatched VRP (correct origin, length within maxLength)AS12637 /29 maxLen 48 (ripe)
2a05:b6c0::/32✓ validmatched VRP (correct origin, length within maxLength)AS12637 /29 maxLen 48 (ripe)
2a0b:fd40::/29✓ validmatched VRP (correct origin, length within maxLength)AS12637 /29 maxLen 48 (ripe)
2001:4b78::/29✓ validmatched VRP (correct origin, length within maxLength)AS12637 /29 maxLen 48 (ripe)
2001:4b78::/32✓ validmatched VRP (correct origin, length within maxLength)AS12637 /32 maxLen 48 (ripe); AS12637 /29 maxLen 48 (ripe)
2a05:be80::/29✓ validmatched VRP (correct origin, length within maxLength)AS12637 /29 maxLen 48 (ripe)

ASPA: this AS has published an ASPA record listing 5 upstream provider(s) that are authorized to propagate routes from it: AS174, AS1299, AS2914, AS3303, AS50673. Routes from this AS that arrive via any other upstream are considered ASPA-invalid by validators that enforce ASPA.

Random-IP probe (yarrp) into the AS' prefixes

At least one router inside AS12637's announced prefix replied during the random-target probe. Hop(s): 2001:4b7a:0:f000::2. These are candidate targets for direct testing.

ICMPv6 Type 2 (Packet Too Big) acceptance - active test

Vantage points disagree about Type 2 acceptance - transit ASes on one path may be filtering Type 2 even though the destination's stack accepts it on another path:

Why they disagree - path-asymmetric Type 2 filtering: Both vantages used the ICMPv6 Echo + forged-PTB method on the same destination IP, but reached different verdicts. The destination's stack is the same in both cases - so the difference is in the path: a transit AS on one route filters our forged Type 2 (or its return ICMPv6 carrying the embedded packet) while the other route delivers it intact. The vantage that says honored shows what the destination's stack actually does; the one that says not honored shows that the path between us and them drops Type 2.

Failure detail — what to grep in your logs
vantageour sourceyour targetmethodresulttested (UTC)
go6lab2a00:8642:42::752001:4b78::22icmp6-echonot_honored2026-05-30T12:41:46Z
karsolink2a12:d8c0:105a:9001::a1542001:4b78::22icmp6-echono_echo2026-05-30T12:42:56Z
odin2607:fae0:a000::422001:4b78::22icmp6-echohonored2026-05-30T12:41:39Z

Attempt log (go6lab):

  1. icmp6-echonot_honored (size_before=1360, size_after=1360)
  2. dns-tcpno_tcp: no DNS response data
  3. tlsno_tcp: TLS connect failed
  4. httpno_tcp: tcp/80 not open

Attempt log (karsolink):

  1. icmp6-echono_echo: no Echo Reply to 1300-byte probe
  2. dns-tcpinconclusive (size_before=156, size_after=None): max DNS-over-TCP segment 156B; not big enough to test PMTU shrink
  3. tlsno_tcp: TLS connect failed
  4. httpno_tcp: tcp/80 not open

Attempt log (odin):

  1. icmp6-echohonored (size_before=1460, size_after=None)
  2. dns-tcpinconclusive (size_before=156, size_after=None): max DNS-over-TCP segment 156B; not big enough to test PMTU shrink
  3. tlsno_tcp: TLS connect failed
  4. httpno_tcp: tcp/80 not open

To match the corresponding ICMPv6 packet on your side (host firewall, AS edge, or transit tap), look for our PTBs around the timestamps above:

sudo tcpdump -i any -n -e 'icmp6 and ip6[40] = 2 and (src host 2607:fae0:a000::42 or src host 2a00:8642:42::75 or src host 2a12:d8c0:105a:9001::a154)'

If you see our PTBs arriving but the destination's TCP/Echo flow does not shrink, the drop is in the destination kernel (cause 3 below). If you don't see them at all, drop is upstream of you (cause 2). If you only see them from one of our two source IPs, the drop is path-asymmetric — one transit on the asymmetric route is filtering, the other is not.

What does "Type 2 not honored" actually mean? — click to expand

What this test does

Using the icmp6-echo method, we send a 1500-byte ICMPv6 Echo Request, then a forged ICMPv6 Type 2 (Packet Too Big) declaring path MTU=1280, and observe whether the next Echo Reply arrives split into IPv6 fragments. RFC 4890 requires hosts and intermediate networks not to filter ICMPv6 Type 2; the destination's TCP/UDP stack must act on a received PTB by lowering its Path MTU cache for that destination, which makes subsequent segments smaller.

What we measured

The TCP segment size your server emitted before our forged Type 2 was 1360 B; after, it was 1360 B. No change. RFC 4890 ("Type 2 messages MUST NOT be filtered") expects subsequent segments to shrink to fit a Path MTU of 1280 B.

Three plausible causes

  1. Your host firewall is dropping ICMPv6 Type 2 inbound. Many default firewall rule sets only allow Echo Request/Reply and Neighbor Discovery, silently dropping all other ICMPv6 types - including Packet Too Big.
  2. An upstream / transit network is dropping ICMPv6 Type 2 before it reaches you. Some transit ASes filter ICMPv6 messages other than Echo at the edge. The forged PTB never arrives, so your stack never has a chance to act on it.
  3. Your kernel is ignoring the PTB. Linux / BSD stacks normally accept ICMPv6 PTB and update the route cache, but a few sysctls (or a hardened kernel) can be configured to ignore PMTU updates - typically as part of an over-aggressive anti-spoofing or uRPF policy.

How to check & fix (Linux examples)

1. Confirm Type 2 is not blocked at the host firewall:

sudo ip6tables -L INPUT -nv | grep -iE 'icmpv6|packet-too-big'
sudo nft list ruleset 2>/dev/null | grep -A1 'icmpv6'

If you see rules dropping ICMPv6 unconditionally, change them to permit at least icmpv6 type packet-too-big (and destination-unreachable, time-exceeded, parameter-problem per RFC 4890).

2. Confirm the kernel accepts incoming PTB:

sudo sysctl net.ipv6.conf.all.accept_redirects net.ipv4.ip_no_pmtu_disc net.ipv6.route.mtu_expires

The defaults (accept_redirects=1, ip_no_pmtu_disc=0) are the right values for honoring PTB.

3. Live trace: while we have an open TCP flow with a small MSS (we run our test from 2607:fae0:a000::42 on odin, 2a00:8642:42::75 on go6lab and 2a12:d8c0:105a:9001::a154 on karsolink), watch for our forged Type 2 arriving on your interface:

sudo tcpdump -i any -n -e 'icmp6 and ip6[40] = 2 and (src host 2607:fae0:a000::42 or src host 2a00:8642:42::75 or src host 2a12:d8c0:105a:9001::a154)'

If you see our PTBs arriving but TCP segments still stay big, the drop is in your kernel or NIC offload (cause 3). If you don't see them at all, the drop is upstream of you (cause 2) - ask your upstream(s) to permit ICMPv6 Type 2.

4. If your test target above (2026-05-30T12:41:46Z) is a host that you don't own (e.g. a third-party DNS / TLS server you happen to operate prefixes for), the verdict reflects that specific host's behaviour - try the test against a server you do own and we'll happily re-run.

RFC 4890 references: §4.3.1 (Packet Too Big - MUST NOT be dropped), and RFC 8201 for the broader PMTUD requirement.

Where the path divergence is

Per-vantage probe + verdict (headline):

Full per-method matrix (all four methods run at each vantage):

vantageicmp6-echodns-tcptlshttp
go6labnot_honoredno_tcpno_tcpno_tcp
karsolinkno_echoinconclusiveno_tcpno_tcp
odinhonoredinconclusiveno_tcpno_tcp

These vantage-level disagreements are rooted somewhere in the forward paths. Joining each per-vantage traceroute against the IP→AS lookup from our global yarrp mesh, the first hop where the paths land in different ASes is the most likely site of the offending filter / unreachable AS / Type 2 drop.

Suspect transit AS (ranked by how often they appear at the divergence point on the path of the worse-classifying vantage): AS12637.

Diagnosis is path-level, not packet-level: it tells you which transit AS is the prime suspect, not exactly which firewall rule is to blame. Use the tracepath6 output below (when available) for per-hop PMTU evidence on the same path.

Diagnostic interpretation

An operator-targeted diagnostic interpretation can be generated for this AS on demand. The pipeline holds the raw verdicts and the per-hop walk; an AI pass synthesises where to start looking. Click the button below to run it.

Per-hop PTB acceptance walk

From the local vantage, we walk the forward path hop-by-hop, sending each hop a 1500-byte ICMPv6 Echo, then a forged PTB (MTU=1280) sourced from us, then another 1500-byte Echo. If the second reply arrives fragmented or smaller, that hop honoured the PTB. If unchanged, it didn't. The first ✗ in an otherwise-✓ path is the most likely filter location. Cross-country aggregation: see the global PTB filter atlas for transit ASes ranked by filter rate across all measurements.

#hop IPASHolderPTB acceptance
12607:fae0:a000::2AS80386CONNECT - 6connect, Inc., US- skipped (CoPP)
22607:fae0:a000:2::2AS80386CONNECT - 6connect, Inc., US- skipped (CoPP)
3*-- (no IP)
4*-- (no IP)
5*-- (no IP)
6*-- (no IP)
7*-- (no IP)
82001:7f8:b:100:1d1:a5d1:2637:86-NA? no_response
92001:4b78:2:a::8AS12637SEEWEB - SEEWEB s.r.l., IT? no_response
102001:4b78::22AS12637SEEWEB - SEEWEB s.r.l., IT? no_response

Tests host-mode PTB acceptance (PTBs aimed at the hop itself). A router that honours PTBs to itself can still be filtering PTBs transiting through it; this is one indicator, not proof of full PTB transparency. Hops in CoPP-rate-limit ranges are skipped to avoid false signals.

tracepath6 per-hop PMTU drilldown

For each target where Type 2 verdicts disagreed across vantages, tracepath -6 ran from every vantage to capture per-hop PMTU evolution along that vantage's actual forward path. A pmtu change entry on a hop means that hop's router generated a PTB and we observed the shrink; absence of any change combined with a not_honored verdict suggests a router somewhere downstream is silently dropping >MTU packets (an RFC 4890 violation) rather than sending a PTB.

Target 2001:4b78::22

go6lab — verdict not_honored

verdict = not_honored; final pmtu = 1500

#hop IPpmtu change
1<span class='muted'>no reply</span>
22a00:8642:1000:f000::1
32a00:8642:dc1:2::b
42001:7f8:1::a501:2637:1
52001:4b78:2:a::8
62001:4b78::22
karsolink — verdict no_echo

verdict = no_echo; final pmtu = 1500

#hop IPpmtu change
1<span class='muted'>no reply</span>
22a12:d8c0:109f:121::a1
32a12:d8c0:101f:103::1
42001:7f8:b:100:1d1:a5d1:2637:86
52001:4b78:2:a::8
62001:4b78::22
odin — verdict honored

verdict = honored; final pmtu = 1500

#hop IPpmtu change
1<span class='muted'>no reply</span>
22607:fae0:a000:2::2
32a03:a100:0:201:1::1
42001:470:1:5be::1
5<span class='muted'>no reply</span>
62001:470:0:2ea::2
7<span class='muted'>no reply</span>
82001:7f8:b:100:1d1:a5d1:2637:86
92001:4b78:2:a::8
102001:4b78::22

Target 2001:4b78:1:a::75

go6lab — verdict honored

verdict = honored; final pmtu = 1500

#hop IPpmtu change
1<span class='muted'>no reply</span>
22a00:8642:1000:f000::1
32a00:8642:dc1:2::b
42001:7f8:1::a501:2637:1
52001:4b78:0:f010::2
62001:4b78:1:a::75
karsolink — verdict not_honored

verdict = not_honored; final pmtu = 1500

#hop IPpmtu change
1<span class='muted'>no reply</span>
22a12:d8c0:109f:121::a1
32a12:d8c0:101f:103::1
42001:7f8:b:100:1d1:a5d1:2637:86
52001:4b7a:0:f000::2
62001:4b78:0:f010::2
72001:4b78:1:a::75
odin — verdict honored

verdict = honored; final pmtu = 1500

#hop IPpmtu change
1<span class='muted'>no reply</span>
22607:fae0:a000:2::2
32a03:a100:0:201:1::1
42001:470:1:5be::1
5<span class='muted'>no reply</span>
62001:470:0:2ea::2
7<span class='muted'>no reply</span>
82001:7f8:b:100:1d1:a5d1:2637:86
92001:4b7a:0:f000::2
102001:4b78:0:f010::2
112001:4b78:1:a::75

Target 2001:4b78::5666

go6lab — verdict honored

verdict = honored; final pmtu = 1500

#hop IPpmtu change
1<span class='muted'>no reply</span>
22a00:8642:1000:f000::1
32a00:8642:dc1:2::b
42001:7f8:1::a501:2637:1
52001:4b78:0:f010::2
62001:4b78:1::133
7<span class='muted'>no reply</span>
8<span class='muted'>no reply</span>
9<span class='muted'>no reply</span>
10<span class='muted'>no reply</span>
11<span class='muted'>no reply</span>
12<span class='muted'>no reply</span>
13<span class='muted'>no reply</span>
14<span class='muted'>no reply</span>
15<span class='muted'>no reply</span>
16<span class='muted'>no reply</span>
17<span class='muted'>no reply</span>
18<span class='muted'>no reply</span>
19<span class='muted'>no reply</span>
20<span class='muted'>no reply</span>
21<span class='muted'>no reply</span>
22<span class='muted'>no reply</span>
23<span class='muted'>no reply</span>
24<span class='muted'>no reply</span>
karsolink — verdict not_honored

verdict = not_honored; final pmtu = 1500

#hop IPpmtu change
1<span class='muted'>no reply</span>
22a12:d8c0:109f:121::a1
32a12:d8c0:101f:103::1
42001:7f8:b:100:1d1:a5d1:2637:86
52001:4b7a:0:f000::2
62001:4b78:0:f010::2
72001:4b78:1::133
8<span class='muted'>no reply</span>
9<span class='muted'>no reply</span>
10<span class='muted'>no reply</span>
11<span class='muted'>no reply</span>
12<span class='muted'>no reply</span>
13<span class='muted'>no reply</span>
14<span class='muted'>no reply</span>
15<span class='muted'>no reply</span>
16<span class='muted'>no reply</span>
17<span class='muted'>no reply</span>
18<span class='muted'>no reply</span>
19<span class='muted'>no reply</span>
20<span class='muted'>no reply</span>
21<span class='muted'>no reply</span>
22<span class='muted'>no reply</span>
23<span class='muted'>no reply</span>
24<span class='muted'>no reply</span>
odin — verdict honored

verdict = honored; final pmtu = 1500

#hop IPpmtu change
1<span class='muted'>no reply</span>
22607:fae0:a000:2::2
32a03:a100:0:201:1::1
42001:470:1:5be::1
5<span class='muted'>no reply</span>
62001:470:0:2ea::2
7<span class='muted'>no reply</span>
82001:7f8:b:100:1d1:a5d1:2637:86
92001:4b7a:0:f000::2
102001:4b78:0:f010::2
112001:4b78:1::133
12<span class='muted'>no reply</span>
13<span class='muted'>no reply</span>
14<span class='muted'>no reply</span>
15<span class='muted'>no reply</span>
16<span class='muted'>no reply</span>
17<span class='muted'>no reply</span>
18<span class='muted'>no reply</span>
19<span class='muted'>no reply</span>
20<span class='muted'>no reply</span>
21<span class='muted'>no reply</span>
22<span class='muted'>no reply</span>
23<span class='muted'>no reply</span>
24<span class='muted'>no reply</span>

From NL host (go6lab)   openRFC 4890 ✗

filter likely at: (none) · min PMTU on path: 1500

4/4
Echo small (56B) 19.0ms
4/4
Echo 1500B (DF) 18.8ms
yes
Type 1 dest-unreach
-
TCP responds on

Path (traceroute + mtr + PTR)

#IP / PTRRTTmtr lossASAS holder
12a00:8642:42::31.1ms0%AS203993STEFFANN-DC-AS - S.J.M. Steffann, NL
2*-0%*-
3ccr2-ccr1.dc1.nogalliance.org
2a00:8642:dc1:2::b
1.8ms0%AS203993STEFFANN-DC-AS - S.J.M. Steffann, NL
4ams-ix.mil.seeweb.it
2001:7f8:1::a501:2637:1
18.4ms0%-NA
5horus.seeweb.it
2001:4b78:2:a::8
18.0ms0%AS12637SEEWEB - SEEWEB s.r.l., IT
6dns2.seeweb.it
2001:4b78::22
18.8ms0%AS12637SEEWEB - SEEWEB s.r.l., IT

tracepath -6

 1?: [LOCALHOST]                        0.044ms pmtu 1500
 1:  2a00:8642:42::3                                       1.690ms 
 1:  2a00:8642:42::3                                       1.379ms 
 2:  gw.friends.steffann.nl                                2.021ms 
 3:  ccr2-ccr1.dc1.nogalliance.org                         2.334ms asymm  2 
 4:  ams-ix.mil.seeweb.it                                 19.108ms asymm  5 
 5:  horus.seeweb.it                                      19.152ms asymm  6 
 6:  dns2.seeweb.it                                       19.524ms reached
     Resume: pmtu 1500 hops 6 back 7 

From ITA host (Karsolink)   open

filter likely at: (none) · min PMTU on path: 1500

4/4
Echo small (56B) 9.5ms
4/4
Echo 1500B (DF) 9.5ms
yes
Type 1 dest-unreach
443,80
TCP responds on

Path (traceroute + mtr + PTR)

#IP / PTRRTTmtr lossASAS holder
1*---
2*---
3*-40%-
4seeweb-v6.mix-it.net @MIX-IT / NAMEX / MINAP / TOP-IX / VSIX / EQUINIX-MILAN / BGPX-ROME / NAMEX-BARI / PCIX / DECIX-PALERMO
2001:7f8:b:100:1d1:a5d1:2637:86
9.4ms0%-NA
5horus.seeweb.it
2001:4b78:2:a::8
9.2ms0%AS12637SEEWEB - SEEWEB s.r.l., IT
6dns2.seeweb.it
2001:4b78::22
9.3ms0%AS12637SEEWEB - SEEWEB s.r.l., IT

Rate-limited ICMPv6: hop 3 (loss between 5% and 95% across mtr cycles - the router replies but only sometimes).

tracepath -6

 1?: [LOCALHOST]                        0.031ms pmtu 1500
 1:  no reply
 2:  no reply
 3:  2a12:d8c0:101f:103::1                                 8.968ms 
 4:  seeweb-v6.mix-it.net                                  9.792ms asymm  5 
 5:  horus.seeweb.it                                       9.989ms 
 6:  dns2.seeweb.it                                        9.953ms reached
     Resume: pmtu 1500 hops 6 back 6 

From SLO host (6connect)   openRFC 4890 ✓

filter likely at: (none) · min PMTU on path: 1500

4/4
Echo small (56B) 12.3ms
3/4
Echo 1500B (DF) 12.1ms
yes
Type 1 dest-unreach
443,80
TCP responds on

Path (traceroute + mtr + PTR)

#IP / PTRRTTmtr lossASAS holder
1fw1-lju.6connect.com
2607:fae0:a000::2
0.2ms0%*AS80386CONNECT - 6connect, Inc., US
2ccr-to-fw-ccr1-gw-lju.6connect.com
2607:fae0:a000:2::2
0.8ms-AS80386CONNECT - 6connect, Inc., US
3*---
4*-70%-
5*---
6*---
7*---
8seeweb-v6.mix-it.net @MIX-IT / NAMEX / MINAP / TOP-IX / VSIX / EQUINIX-MILAN / BGPX-ROME / NAMEX-BARI / PCIX / DECIX-PALERMO
2001:7f8:b:100:1d1:a5d1:2637:86
17.5ms0%-NA
9horus.seeweb.it
2001:4b78:2:a::8
12.1ms0%AS12637SEEWEB - SEEWEB s.r.l., IT
10dns2.seeweb.it
2001:4b78::22
12.2ms0%AS12637SEEWEB - SEEWEB s.r.l., IT

Rate-limited ICMPv6: hop 4 (loss between 5% and 95% across mtr cycles - the router replies but only sometimes).

tracepath -6

 1?: [LOCALHOST]                        0.026ms pmtu 1500
 1:  fw1-lju.6connect.com                                  0.598ms 
 1:  fw1-lju.6connect.com                                  0.406ms 
 2:  no reply
 3:  no reply
 4:  e0-1.core1.lju1.he.net                                2.367ms 
 5:  no reply
 6:  port-channel1.core1.zag2.he.net                       3.650ms 
 7:  no reply
 8:  seeweb-v6.mix-it.net                                 12.382ms asymm  9 
 9:  horus.seeweb.it                                      13.223ms 
10:  dns2.seeweb.it                                       12.378ms reached
     Resume: pmtu 1500 hops 10 back 10