SpeedTouch 516 DSL metrics

network

Like many folks my internet connection is connected to a router/gateway.  The router acts as the hub of my internal network providing both access to other machines on my local network as well as the internet.  In my case I have a SpeedTouch 516 DSL modem, plugged into a Linksys WRT54GL router/gateway, and an assortment of PCs plugged into the router.

If you have a single PC, then it makes sense to plug your DSL modem directly into your computer.  This has the advantage of making it easy to talk directly to your DSL modem for configuration (usually via a web interface on the modem itself).  Some modems provide various statistics about your connection.  There is also a tool called DMT which gives you a nice graphical interface to the data.

Now if your network is at all configured like mine, you can’t easily talk to the DSL modem since the router is in the way.  Assuming you are running the alternate router firmware DD-WRT, there is a solution that will expose your DSL modem to your network.

You need to gather two bits of information about your DSL modem, and the easiest manner to do this is to plug it directly into a PC via an ethernet cable.  The modem should act as a DHCP server and hand out an address to your PC.  You want to collect both the IP (cilent) address that your PC was assigned, and the gateway address (the IP of the DSL modem).

In my case I had:
client IP address 192.168.1.64
gateway IP address 192.168.1.254

Then we telnet to the DD-WRT enabled Linksys box (yup, telnet is always enabled for the local network).  You log in using user root (even if you have changed the web interface user name) and the password you use for the web interface.

We are going to temporarily modify the routers configuration with the following two commands:
/sbin/ifconfig vlan1:1 192.168.1.64 \
netmask 255.255.255.0

/usr/sbin/iptables -I POSTROUTING -t nat -o vlan1 \
-d 192.168.1.0/24 -j MASQUERADE

If you want to make this more permanent, the DD-WRT wiki has some instructions on how to do this along with a few more details as to what we’re doing in the commands above.  Assuming all went well, we can now visit the DSL modem’s web interface at http://192.168.1.254 – do this to validate that you’ve got things working ok.

Now we go grab a copy of DMT (this is a windows only program).  For the SpeedTouch 516 you want version 7.35.  By running this on a windows PC connected to your network, you should get some data out of your DSL modem in a nice graphical form.

dmt20091111_2249

So neat-o, we’ve got some nice data here.  What does it mean?  A good reference can be found here – let’s look at my results using that reference.  The downstream attenuation of 48.0dB falls into the ‘good’ category, a lower value is better and much higher than 50 is not so good.  The Signal to Noise Ratio Margin (SNRM) of 10.0dB rates as fair, with this value bigger is better – a result of 6dB or less would be very bad.  The last area I’ll talk about is the upper right yellow box showing errors – ideally you want no errors, any  increase in CRC errors after your initial connection is established is a problem and usually points to a physical issue somewhere between the modem and the telephone companies equipment.

What if you don’t like Windows?  You’re in luck – all of this data can be gathered via telnet.  Simply telnet 192.168.1.254 and log into the modem:

$telnet 192.168.1.254
Trying 192.168.1.254...
Connected to 192.168.1.254.
Escape character is '^]'.
Username : Administrator
Password :

{Administrator}=>adsl info
Modemstate            :  up
Operation Mode        :  G.992.1 Annex A
Channel Mode          :  fast
Number of resets      :  1

Vendor                              Local           Remote
Country             :               0f               0f
Vendor              :             TMMB             ALCB
VendorSpecific      :             3c61             0000
StandardRevisionNr  :               00               01

Downstream        Upstream
Margin       [dB]     :             10.0              8.0
Attenuation  [dB]     :             48.0             29.0
OutputPower  [dBm]    :             19.5             11.5

Intrinsic/Actual  Bandwidth          %
Upstream            :             82
Downstream          :             78

Available Bandwidth                 Cells/s           Kbit/s
Downstream          :            11924             5056
Upstream            :             1886              800

Transfer statistics
Errors
Received FEC    :                0
Received CRC    :              117
Received HEC    :               22
Transmitted FEC :                0
Transmitted CRC :                0
Transmitted HEC :                0

Near end failures since reset
Loss of frame:          0 failures
Loss of signal:         0 failures
Loss of power:          0 failures
Errored seconds:       47 seconds
Near end failures last 15 minutes
Loss of frame:          0 seconds
Loss of signal:         0 seconds
Loss of power:          0 seconds
Errored seconds:        0 seconds
Near end failures current day
Errored seconds:       47 seconds
Near end failures previous day
Errored seconds:        0 seconds
{Administrator}=>

So in my case, I’ve got CRC errors happening at a low rate indicating there is possibly some physical problem (ie: wiring).  This is probably what led to a rash of recent DSL disconnect problems that prompted me to investigate this far in terms of self diagnosing the problem (because who wants to sit on hold with your ISP all day?).

So this is what the phone line connected to my DSL modem looks like:

img_3076Look suspicious?  Ok, so I’ve been meaning to fix that for a while.

I also started searching on potential firmware upgrades, and came across some data that indicates that my current 6.1.9.6.0 revision may not be all that stable.  I’ll have to tinker with that soon too.

I need to share one more goof with you.  Jenn told me today that her email wasn’t working.  I looked on the server and all appeared to be well, and it turns out it was her Mac acting up – it couldn’t see the mail server anymore.  I checked with nslookup and the name was resolving fine, but ping to the same machine failed to map the name.  Strange, I thought it was specific to the Mac until I later tried my linux box and it failed too… Huh?  Turns out that I had reboot my router last night to clear some of the settings, since the router acts as my local DNS server/cache it had forgotten the email servers IP address.  Renewing the IP address on the email server cause the DNS entry on the router to refresh and all was well again.  The lesson?  Remember your network topology.

TED 5000 – Installation

I’ve had my eye on the TED device for quite some time.  It allows you to monitor your power consumption at the whole house level.  I’ve used in the past a Kill-A-Watt which is handy to monitor energy usage by a single device.

The TED 1000 had a closed software package, but showed promise.  The TED 5000 provides a web based API to both view your data – and provides a manner to export it.  The TED 5000 is one of the few devices supported by Google Powermeter, while I don’t plan to make use of the Google service I do hope they figure out how to collaborate with the community better.

Ontario has a Smart Meter plan on the way, but the roll out is taking a while and I really don’t trust them to get the web tools right in the near term.  The TED 5000 is available now, and the data is easy to get to if I want to re-graph it in some way.

I ordered the basic package (TED 5000-G) – there are two basic parts that come with it.  The MTU (Measuring Transmitting Unit) and the Gateway, each packaged in their own little box.  The first (and scary part) is installing the MTU as it it attached to your electrical panel.  The MTU communicates over the power lines to the Gateway (no need to run wires from one to the other).  The Gateway needs to be plugged into your router/network and will aquire an IP address via DHCP.  You interact with the Gateway with a web browser to view/configure the data.

The rest of this posting is about the install procedure, read on for gory details.

Continue reading “TED 5000 – Installation”

Review: Zipit Wireless Messenger 2

IMG_3034-2

So I must thank my good friend Andrew C for picking one of these up for me at his local Target store and shipping it up to me in Canada.   The device itself is about the size and form factor of the Gameboy Advance SP, however there is a lot more under the hood.  The Zipit2 boasts a 320×240 colour display, 312MHz XScale (ARM), 32MB RAM, 8MB flash, Mini-SD expansion, backlit querty thumb keyboard, D_Pad and music controls, 802.11 B/G, and a 1000Mah LiOn battery. IMG_3034-1 The retail price is $49.99, but as you can see it was marked down to under $25!

For the casual consumer, this device allows for IM with AIM, Yahoo, and MSN.  It appears they also have a gateway to a wide range of US cell phone providers (and one Canadian – Fido) allowing for SMS messages to be sent / received.  It will play music and display photos from the Mini-SD card.  There is also support for internet radio.  While you need to use your own WiFi to connect to the internet, you are reliant on the zipitwireless.com site for the IM connectivity to the device.  The 1st year of service is free and after that its $29.95 a year.  If you’ve got teenagers and not enough computers, this is a great solution.  Another benefit is a side-effect of the limitations of the device – no malware or virus issues, constrained functionality results in a limited amount of mischief they can get into.

Oh yeah, and it runs Linux.  So of course the hacking community has has its way with this device and you can now get an “open” Linux build for it.  There is also a fairly dated wiki hosted by zipitwireless, however the irc logs seem to be fairly current.  I was particulary excited to see that the ScummVM was able to run Full Throttle – something I plan to setup as I actually own the original game.

I’ll update with another post once I’ve got the firmware modified – you knew that was coming right?