Hello!

> You aren't opening it with O_NDELAY by any chance?

Hopefully not :)  Even plain cat exhibits the problem.

> Please look with strace.

| albireo:/home/mj# strace cat /dev/usb/lp0 
| execve("/bin/cat", ["cat", "/dev/usb/lp0"], [/* 34 vars */]) = 0
| uname({sys="Linux", node="albireo", ...}) = 0
| brk(0)                                  = 0x804d000
| access("/etc/ld.so.nohwcap", F_OK)      = -1 ENOENT (No such file or 
directory)
| mmap2(NULL, 8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 
0xb7fbb000
| access("/etc/ld.so.preload", R_OK)      = -1 ENOENT (No such file or 
directory)
| open("/etc/ld.so.cache", O_RDONLY)      = 3
| fstat64(3, {st_mode=S_IFREG|0644, st_size=97571, ...}) = 0
| mmap2(NULL, 97571, PROT_READ, MAP_PRIVATE, 3, 0) = 0xb7fa3000
| close(3)                                = 0
| access("/etc/ld.so.nohwcap", F_OK)      = -1 ENOENT (No such file or 
directory)
| open("/lib/tls/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\240O\1"..., 512) = 
512
| fstat64(3, {st_mode=S_IFREG|0644, st_size=1245488, ...}) = 0
| mmap2(NULL, 1251484, PROT_READ|PROT_EXEC, MAP_PRIVATE|MAP_DENYWRITE, 3, 0) = 
0xb7e71000
| mmap2(0xb7f99000, 28672, PROT_READ|PROT_WRITE, 
MAP_PRIVATE|MAP_FIXED|MAP_DENYWRITE, 3, 0x128) = 0xb7f99000
| mmap2(0xb7fa0000, 10396, PROT_READ|PROT_WRITE, 
MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0xb7fa0000
| close(3)                                = 0
| mmap2(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 
0xb7e70000
| mprotect(0xb7f99000, 20480, PROT_READ)  = 0
| set_thread_area({entry_number:-1 -> 6, base_addr:0xb7e708e0, limit:1048575, 
seg_32bit:1, contents:0, read_exec_only:0, limit_in_pages:1, seg_not_present:0, 
useable:1}) = 0
| munmap(0xb7fa3000, 97571)               = 0
| brk(0)                                  = 0x804d000
| brk(0x806e000)                          = 0x806e000
| open("/usr/lib/locale/locale-archive", O_RDONLY|O_LARGEFILE) = 3
| fstat64(3, {st_mode=S_IFREG|0644, st_size=1673120, ...}) = 0
| mmap2(NULL, 1673120, PROT_READ, MAP_PRIVATE, 3, 0) = 0xb7cd7000
| close(3)                                = 0
| fstat64(1, {st_mode=S_IFCHR|0620, st_rdev=makedev(136, 4), ...}) = 0
| open("/dev/usb/lp0", O_RDONLY|O_LARGEFILE) = 3
| fstat64(3, {st_mode=S_IFCHR|0660, st_rdev=makedev(180, 0), ...}) = 0
| read(3, "", 4096)                       = 0
| close(3)                                = 0
| close(1)                                = 0
| exit_group(0)                           = ?
| Process 4888 detached

> If that looks ok, a usbmon trace would be helpful.
> Please send me both traces.

albireo:/sys/kernel/debug/usbmon# cat 1u
# (ran cat for the first time)
ddbeb7c0 1940101507 S Bi:1:003:1 -115 1024 <
ddbeb7c0 1940101645 C Bi:1:003:1 0 0
ddbeb7c0 1940101675 S Bi:1:003:1 -115 1024 <
ddbeb7c0 1940101766 C Bi:1:003:1 -2 0
# (2nd time)
ddbebec0 1943391766 S Bi:1:003:1 -115 1024 <
ddbebec0 1943391838 C Bi:1:003:1 0 0
ddbebec0 1943391881 S Bi:1:003:1 -115 1024 <
ddbebec0 1943391959 C Bi:1:003:1 -2 0

                                Have a nice fortnight
-- 
Martin `MJ' Mares                          <[EMAIL PROTECTED]>   
http://mj.ucw.cz/
Faculty of Math and Physics, Charles University, Prague, Czech Rep., Earth
Maintenance-free:  When it breaks, it can't be fixed...
-
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to