Unoffical empeg BBS

Quick Links: Empeg FAQ | RioCar.Org | Hijack | BigDisk Builder | jEmplode | emphatic
Repairs: Repairs

Topic Options
#63998 - 28/01/2002 15:41 upgrade can't find player.
danthep
enthusiast

Registered: 29/08/1999
Posts: 209
Loc: new zealand
Got my new Mk2 and i want to replace 1.02 as the player reports or 1.03 as the kernel reports with 2.0b7

I am pretty sure my connection to the empeg is OK, cause i can "cat /dev/tts/0" and then power cycle the empeg to see the boot messgeas.

But when i run emptool it just says
empeg-car Upgrade client.
empegupgrade: Using upgrade file '../car2-consumer-v2.00-beta7.upgrade' to device '/dev/tts/0' (115200 baud)
Checking upgrade file integrity [100%]
Pumping player software
Upgrade file checked [100%]
ERROR: 5 empeg unit not found

Upgrade failed :-(

Upgrade failed with error 0x8004004c
Note that it doesn't wait looking for the unit, it exits out with that error pretty much instantly.

Top
#63999 - 28/01/2002 16:08 Re: upgrade can't find player. [Re: danthep]
tfabris
carpal tunnel

Registered: 20/12/1999
Posts: 31565
Loc: Seattle, WA
1) Did you install the latest version of emplode, and are you sure the EmpegUpgrade.exe you're running is the correct one from that version?

2) Did you leave the player power unplugged until it asked you to apply power?

3) Did you get a fresh copy of the upgrade file using GetRight to be absolutely certain the file was not corrupted?

4) Are you sure the cable and COM port are good? Can you type things into hypterterminal and have the player respond? Just seeing the boot messages is not necessarily enough. The communication needs to work both ways.
_________________________
Tony Fabris

Top
#64000 - 28/01/2002 19:05 Re: upgrade can't find player. [Re: tfabris]
danthep
enthusiast

Registered: 29/08/1999
Posts: 209
Loc: new zealand
1)Indeed i was using beta3. I've upgraded to beta7 now, same results

2) it never gets to the point of asking me to apply power

3)The upgrade file passes the integrity check of the uploader. I don't
use GetRight but i've downloaded another copy with wget and it's
identical, and gives identical faliure results

4) I was using some serial cable i had used on the Mk1. Just tried the
cable that came with the Mk2 (looks identical on the outside) same
result. I'm pretty sure it is some problem with serial communication
though, i think i had this problem on my Mk1 when putting v2b3 on it and
i resorted to loading windows under vmware and using emplode to do the
upgrade, so it wasn't the serial cable or the com port.

Arggg and now the BBS has crashed again, or at least my route to it has
disappered again... yay, 2 hours later its back...

Top
#64001 - 28/01/2002 19:15 Re: upgrade can't find player. [Re: danthep]
danthep
enthusiast

Registered: 29/08/1999
Posts: 209
Loc: new zealand
OK, here's some more info

1) i can view the boot msgs when i cat /dev/tts/0

2)i can connect with emptool over usb (if i force usb buffering) and it tells me i need to upgrade the player software because emptool is using a newer protocol

3)i can't connect with emptool over serial. or with upgclient over serial. It just errors out straight away, it doesn't stop and wait for me to power on the empeg. Perhaps it is having trouble opening the com port rather than reading from it? But i'm running as root so it should be able to.

4) i've tried the 2nd com port /dev/tts/1 with the same results

[root@danski empeg-car]# head /proc/tty/driver/serial
serinfo:1.0 driver:5.05c revision:2001-07-08
0: uart:16550A port:3F8 irq:4 baud:115200 tx:2119 rx:9104 fe:76 brk:5
1: uart:16550A port:2F8 irq:3 baud:9600 tx:195 rx:0
2: uart:unknown port:3E8 irq:4
3: uart:unknown port:2E8 irq:3
4: uart:unknown port:1A0 irq:9
5: uart:unknown port:1A8 irq:9
6: uart:unknown port:1B0 irq:9
7: uart:unknown port:1B8 irq:9
8: uart:unknown port:2A0 irq:5
[root@danski empeg-car]# ./emptool /dev/tts/0
4001 Failed to open device /dev/tts/0, errno:2
[root@danski empeg-car]# ./emptool /dev/ttyS0
4001 Failed to open device /dev/ttyS0, errno:17
[root@danski empeg-car]# ./emptool /dev/ttyUSB0
Unknown device character 188,0 - assuming serial buffering
4001 Failed to open device /dev/ttyUSB0, errno:17
[root@danski empeg-car]# ./emptool --usb /dev/ttyUSB0
2000 Checking connection
[Done]Protocol version of your player (4) is too old for emptool (6)
Please obtain an upgrade for your player
[root@danski empeg-car]# ./emptool /dev/usb/tts/0
Unknown device character 188,0 - assuming serial buffering
4001 Failed to open device /dev/usb/tts/0, errno:2
[root@danski empeg-car]# ./emptool --usb /dev/usb/tts/0
2000 Checking connection
[Done]Protocol version of your player (4) is too old for emptool (6)
Please obtain an upgrade for your player
[root@danski empeg-car]# ./upgclient ../car2-consumer-v2.00-beta7.upgrade
empeg-car Upgrade client.
empegupgrade: Using upgrade file '../car2-consumer-v2.00-beta7.upgrade'
to device '/dev/ttyS0' (115200 baud)
Checking upgrade file integrity
[100%]
Pumping player software
Upgrade file checked
[100%]
ERROR: 5 empeg unit not found

Upgrade failed :-(

Upgrade failed with error 0x8004004c
[root@danski empeg-car]#

Top
#64002 - 29/01/2002 02:24 Re: upgrade can't find player. [Re: danthep]
danthep
enthusiast

Registered: 29/08/1999
Posts: 209
Loc: new zealand
Well...
By running emplode under win95 under vmware under linux i was able to do the upgrade.
So i guess the cabling is fine, must be some problem with the setup of my com ports under linux and emptool.

However, during the upgrade process it complained about a bad response from pump. And now when it boot it says no hard disk found contact support It found it before the upgrade...

Top
#64003 - 29/01/2002 03:01 Re: upgrade can't find player. [Re: danthep]
tfabris
carpal tunnel

Registered: 20/12/1999
Posts: 31565
Loc: Seattle, WA
However, during the upgrade process it complained about a bad response from pump. And now when it boot it says no hard disk found contact support

Pump error is a FAQ Entry.

Have phun.
_________________________
Tony Fabris

Top
#64004 - 29/01/2002 04:18 Re: upgrade can't find player. [Re: tfabris]
danthep
enthusiast

Registered: 29/08/1999
Posts: 209
Loc: new zealand
It has also been reported that a bad pump error can be caused by a loose or faulty disk drive cable.

I'm guessing it's this one, seen as the kernel can't find my disc anymore.

I'd open it and check but i don't wanna void the warrenty so i'll wait to here back from them.

Top
#64005 - 30/01/2002 01:15 Re: Serial connection solved (weird though) [Re: danthep]
danthep
enthusiast

Registered: 29/08/1999
Posts: 209
Loc: new zealand
OK, so there i was writing a nice bug report to send to bugs@empeg, going through all the steps to demonstrate the problem when whadayaknow, it works!

I've figured it out, i can connect over serial no probs, with my normal user account. If i run emptool or upgclient as root then it won't connect. This makes no sense to me at all, becuase root should have full access to everything.

[dantheperson@danski empeg-car]$ ./emptool --serial /dev/tts/0
2000 Checking connection [Done] 2121 Downloading
[...snip...]

[root@danski empeg-car]# ./emptool --serial /dev/tts/0
4001 Failed to open device /dev/tts/0, errno:2

Top
#64006 - 30/01/2002 04:07 Re: Serial connection solved (weird though) [Re: danthep]
peter
carpal tunnel

Registered: 13/07/2000
Posts: 4172
Loc: Cambridge, England
[dantheperson@danski empeg-car]$ ./emptool --serial /dev/tts/0
2000 Checking connection [Done] 2121 Downloading
[...snip...]

[root@danski empeg-car]# ./emptool --serial /dev/tts/0
4001 Failed to open device /dev/tts/0, errno:2


2 is ENOENT, file not found. What exactly are the permissions on /dev/tts/0? Isn't that a devfs filename? in which case I expect you should be complaining to Mr Gooch on linux-kernel (it seems you might as well; everyone else on linux-kernel does).

Peter


Top
#64007 - 30/01/2002 04:23 Re: Serial connection solved (weird though) [Re: peter]
danthep
enthusiast

Registered: 29/08/1999
Posts: 209
Loc: new zealand
Yeah, mandrakes been running devfs for a while now.

[dantheperson@danski JEmplode_2.0]$ ls -l /dev/tts/0
crwxrwxrwx 1 danthepe tty 4, 64 Jan 31 00:16 /dev/tts/0

(yes i've been playing with the permissions.)
Everyone has read write but root can't see it... odd.

Top
#64008 - 30/01/2002 04:53 Re: Serial connection solved (weird though) [Re: danthep]
peter
carpal tunnel

Registered: 13/07/2000
Posts: 4172
Loc: Cambridge, England
Everyone has read write but root can't see it... odd.

# echo foo <>/dev/tts/0

# strace emptool --serial /dev/tts/0

Peter

Top
#64009 - 30/01/2002 05:06 Re: Serial connection solved (weird though) [Re: peter]
danthep
enthusiast

Registered: 29/08/1999
Posts: 209
Loc: new zealand
[root@danski empeg-car]# echo foo <>/dev/tts/0
foo
[root@danski empeg-car]# strace ./emptool --serial /dev/tts/0
execve("./emptool", ["./emptool", "--serial", "/dev/tts/0"], [/* 44 vars */]) = 0
uname({sys="Linux", node="danski", ...}) = 0
brk(0) = 0x80b3bb4
old_mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x40016000
open("/etc/ld.so.preload", O_RDONLY) = -1 ENOENT (No such file or directory) open("/etc/ld.so.cache", O_RDONLY) = 3
fstat64(3, {st_mode=S_IFREG|0644, st_size=59585, ...}) = 0
old_mmap(NULL, 59585, PROT_READ, MAP_PRIVATE, 3, 0) = 0x40017000
close(3) = 0
open("/lib/libz.so.1", O_RDONLY) = 3
read(3, "\177ELF\1\1\1\0\0\0\0\0\0\0\0\0\3\0\3\0\1\0\0\0\220\36"..., 1024) = 1024
fstat64(3, {st_mode=S_IFREG|0755, st_size=55576, ...}) = 0
old_mmap(NULL, 58480, PROT_READ|PROT_EXEC, MAP_PRIVATE, 3, 0) = 0x40026000
mprotect(0x40033000, 5232, PROT_NONE) = 0
old_mmap(0x40033000, 8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED, 3, 0xc000) = 0x40033000
close(3) = 0
open("/lib/libpthread.so.0", O_RDONLY) = 3
read(3, "\177ELF\1\1\1\0\0\0\0\0\0\0\0\0\3\0\3\0\1\0\0\0 P\0\000"..., 1024) = 1024
fstat64(3, {st_mode=S_IFREG|0755, st_size=554033, ...}) = 0
old_mmap(NULL, 91164, PROT_READ|PROT_EXEC, MAP_PRIVATE, 3, 0) = 0x40035000
mprotect(0x40044000, 29724, PROT_NONE) = 0
old_mmap(0x40044000, 32768, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED, 3, 0xe000) = 0x40044000
close(3) = 0
open("/lib/libm.so.6", O_RDONLY) = 3
read(3, "\177ELF\1\1\1\0\0\0\0\0\0\0\0\0\3\0\3\0\1\0\0\0\340H\0"..., 1024) = 1024
fstat64(3, {st_mode=S_IFREG|0755, st_size=139200, ...}) = 0
old_mmap(NULL, 141716, PROT_READ|PROT_EXEC, MAP_PRIVATE, 3, 0) = 0x4004c000
mprotect(0x4006e000, 2452, PROT_NONE) = 0
old_mmap(0x4006e000, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED, 3, 0x21000) = 0x4006e000
close(3) = 0
open("/lib/libc.so.6", O_RDONLY) = 3
read(3, "\177ELF\1\1\1\0\0\0\0\0\0\0\0\0\3\0\3\0\1\0\0\0\260\306"..., 1024) = 1024
fstat64(3, {st_mode=S_IFREG|0755, st_size=1285480, ...}) = 0
old_mmap(NULL, 1301800, PROT_READ|PROT_EXEC, MAP_PRIVATE, 3, 0) = 0x4006f000
mprotect(0x401a4000, 36136, PROT_NONE) = 0
old_mmap(0x401a4000, 20480, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED, 3, 0x134000) = 0x401a4000
old_mmap(0x401a9000, 15656, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0x401a9000
close(3) = 0
mprotect(0x40026000, 53248, PROT_READ|PROT_WRITE) = 0
mprotect(0x40026000, 53248, PROT_READ|PROT_EXEC) = 0
munmap(0x40017000, 59585) = 0
getrlimit(0x3, 0xbffff744) = 0
setrlimit(RLIMIT_STACK, {rlim_cur=2044*1024, rlim_max=RLIM_INFINITY}) = 0
getpid() = 23906
rt_sigaction(SIGRT_0, {0x4003ed70, [], 0x4000000}, NULL, 8) = 0
rt_sigaction(SIGRT_1, {0x4003e0c0, [], 0x4000000}, NULL, 8) = 0
rt_sigaction(SIGRT_2, {0x4003ee00, [], 0x4000000}, NULL, 8) = 0
rt_sigprocmask(SIG_BLOCK, [32], NULL, 8) = 0
_sysctl({{CTL_KERN, KERN_VERSION}, 2, 0xbffff4fc, 32, (nil), 0}) = 0
brk(0) = 0x80b3bb4
brk(0x80b3be4) = 0x80b3be4
brk(0x80b4000) = 0x80b4000
stat64("/dev/tts/0", {st_mode=S_IFCHR|0777, st_rdev=makedev(4, 64), ...}) = 0
brk(0x80c5000) = 0x80c5000
ioctl(-1, 0x5401, 0xbffff680) = -1 EBADF (Bad file descriptor)
nanosleep({0, 5000000}, NULL) = 0
ioctl(-1, 0x5404, {B115200 -opost -isig -icanon -echo ...}) = -1 EBADF (Bad file descriptor)
stat64("/var/lock", {st_mode=S_IFDIR|0775, st_size=1024, ...}) = 0
gettimeofday({1012392205, 695732}, NULL) = 0
getpid() = 23906
open("/var/lock/empeg-JwUC0X", O_RDWR|O_CREAT|O_EXCL, 0600) = 3
getpid() = 23906
write(3, " 23906 empeg\n", 17) = 17
close(3) = 0
link("/var/lock/empeg-JwUC0X", "/var/lock/LCK..tts/0") = -1 ENOENT (No such file or directory)
stat64("/var/lock/empeg-JwUC0X", {st_mode=S_IFREG|0600, st_size=17, ...}) = 0
unlink("/var/lock/empeg-JwUC0X") = 0
fstat64(1, {st_mode=S_IFCHR|0620, st_rdev=makedev(136, 4), ...}) = 0
old_mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x40017000
write(1, "4001 Failed to open device /dev/"..., 474001 Failed to open device /dev/tts/0, errno:2
) = 47
munmap(0x40017000, 4096) = 0
_exit(1) = ?
[root@danski empeg-car]#

Is that what you were asking for?

Top
#64010 - 30/01/2002 07:12 Re: Serial connection solved (weird though) [Re: danthep]
peter
carpal tunnel

Registered: 13/07/2000
Posts: 4172
Loc: Cambridge, England
Is that what you were asking for?

Yes. Aaaaah. Urrrrrgh. It's constructing a lockfile name from the device name, and it's not dealing with the device being in a subdirectory of /dev.

Does anyone know how one is supposed to generate lockfile names from devfs device names?

In the meantime, you should use the backwards-compatibility stuff in devfsd to make it appear as /dev/ttyS<n>.

Peter

Top
#64011 - 30/01/2002 09:21 Re: Serial connection solved (weird though) [Re: peter]
wfaulk
carpal tunnel

Registered: 25/12/2000
Posts: 16706
Loc: Raleigh, NC US
It would be interesting to know why it would work as a non-root user, though. It should have the same problem regardless of what the uid is.
_________________________
Bitt Faulk

Top
#64012 - 30/01/2002 09:31 Re: Serial connection solved (weird though) [Re: wfaulk]
peter
carpal tunnel

Registered: 13/07/2000
Posts: 4172
Loc: Cambridge, England
It would be interesting to know why it would work as a non-root user, though. It should have the same problem regardless of what the uid is.

The way you're meant to lock serial ports is quite elaborate (it was designed to cope with broken NFS locking implementations). First you create a file in /var/lock named after your program and its PID, then you (supposedly atomically) rename that to the name of the lock file you actually want. If the rename fails, someone's beaten you to it, so you report the failure. (In this case, though, the rename has failed for a different reason.)

A non-root user probably can't create the initial file in /var/lock in the first place; this is not a failure (distros probably shouldn't make /var/lock world-writable), it just means that access to your serial port isn't lockfile-locked properly.

NB. Modern Unixes probably don't require lockfile-locking to protect their serial ports, but, for portability, emptool does it anyway.

Peter

Top
#64013 - 30/01/2002 10:16 Re: Serial connection solved (weird though) [Re: peter]
wfaulk
carpal tunnel

Registered: 25/12/2000
Posts: 16706
Loc: Raleigh, NC US
    A non-root user probably can't create the initial file in /var/lock in the first place; this is not a failure
Duh. I knew that -- I'm just an idiot, I guess.
_________________________
Bitt Faulk

Top