You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I was able to get go-dsl working with my ALLNET ALL-BM300 modem after applying some quirks. I don't have a straight up patch because some of the quirks go beyond what go-dsl does right now, and others conflict with some of its assumptions. Here is what I had to do:
Once accessed by telnet (192.168.16.254, user admin, password admin), the command prompt ends in $, not # (lantiq/telnet.go line 37).
The command is found at /opt/opt/intel/bin/dsl_pipe, but it's owned by dsl:dslgrp with permissions 110, so user admin cannot run it. Fortunately, sudo is available. I didn't want to mess with the original binary via overlayfs and simply copied it to /tmp/dsl_pipe_ (there was an unrelated file called /tmp/dsl_pipe there already), then changed its permissions to 755.
When run as user admin, the command fails because it has no write access to /tmp/pipe/dms_0_cmd. I changed this file's permissions to 777 and go-dsl was finally able to read data.
The modem reports API version 5.5.21 and did not understand most commands sent by go-dsl. Treating it as legacy (lantiq/data.go, line 137) helped and made more data appear.
I was able to add the following commandLegacy entries in lantiq/data.go to get more data:
Finally, for the line state, lantiq/status.go checks for a 0x prefix on the state code in line 235, but only to strip it, not to distinguish between hex and decimal numbers. This is wrong for my modem. The code has no 0x prefix and it isn't hex, but decimal. Decoding it as such in line 239 gave me the correct line state.
The text was updated successfully, but these errors were encountered:
Thank you for the report and sorry for the late response.
Adding proper support for the newer API version should be possible, but I need more data. If you can find out the working commands and send them to me including the full output, I'll look into it.
About the first three points: Allowing the $ prompt should not be an issue. If I understand correctly, the other two steps can be done manually by the user, right?
I was able to get go-dsl working with my ALLNET ALL-BM300 modem after applying some quirks. I don't have a straight up patch because some of the quirks go beyond what go-dsl does right now, and others conflict with some of its assumptions. Here is what I had to do:
$
, not#
(lantiq/telnet.go line 37).commandLegacy
entries in lantiq/data.go to get more data:commandLegacy
entries for my modem:0x
prefix on the state code in line 235, but only to strip it, not to distinguish between hex and decimal numbers. This is wrong for my modem. The code has no0x
prefix and it isn't hex, but decimal. Decoding it as such in line 239 gave me the correct line state.The text was updated successfully, but these errors were encountered: