* Re: /dev/port BUG and possible workaround
2002-05-22 8:41 /dev/port BUG and possible workaround Nick Kurshev
@ 2002-05-22 7:52 ` Martin Dalecki
2002-05-22 9:12 ` Nick Kurshev
2002-05-22 12:09 ` Padraig Brady
0 siblings, 2 replies; 4+ messages in thread
From: Martin Dalecki @ 2002-05-22 7:52 UTC (permalink / raw)
To: Nick Kurshev; +Cc: linux-kernel
Uz.ytkownik Nick Kurshev napisa?:
...
> 800=inl(CFC)
> 2. Wrong log with using of /dev/port:
...
> But it seems that nobody uses this device. Then what is goal
> of implementing of this device?
Basically the goal is that contrary to some silly /proc
stuff which is "en vouge" nowadays you have the ability to
controll port access by using normal user permission control
semantics of unix file access permissions, by giving /dev/port
a proper group and so on. This is legacy crap of course, since
the above goal can be reached by using a apache-suexec alike wrapper
as well... even with more fine grained resolution of access controll.
^ permalink raw reply [flat|nested] 4+ messages in thread
* /dev/port BUG and possible workaround
@ 2002-05-22 8:41 Nick Kurshev
2002-05-22 7:52 ` Martin Dalecki
0 siblings, 1 reply; 4+ messages in thread
From: Nick Kurshev @ 2002-05-22 8:41 UTC (permalink / raw)
To: linux-kernel
[-- Attachment #1: Type: text/plain, Size: 1579 bytes --]
Hello!
It seems that I've found out bug in subj
(sorry if this subj was already discussed here)
looking at sources of drivers/char/mem.c I found out:
static ssize_t read_port(struct file * file, char * buf,
size_t count, loff_t *ppos)
{
unsigned long i = *ppos;
[snip]
while (count-- > 0 && i < 65536) {
if (__put_user(inb(i),tmp) < 0)
return -EFAULT;
[snip]
}
static ssize_t write_port(struct file * file, const char * buf,
size_t count, loff_t *ppos)
{
unsigned long i = *ppos;
[snip]
while (count-- > 0 && i < 65536) {
char c;
if (__get_user(c, tmp))
return -EFAULT;
outb(c,i);
[snip]
}
Well, when I'm trying to use this device in the way:
lseek(port_fd,port_idx,SEEK_SET);
write(port_fd,&val32,4);
I get perfectly broken results due outl() != outb()*4
Please look at logs:
1. Correct log with using of inport/outport:
outb(CF8,0)
outb(CFA,0)
FF=inb(CF8)
FF=inb(CFA)
80FFFFFC=inl(CF8)
outl(CF8,80000000)
80000000=inl(CF8)
outl(CF8,80FFFFFC)
outl(CF8,80000000)
3051106=inl(CFC)
outl(CF8,80000004)
22100006=inl(CFC)
outl(CF8,80000008)
6000003=inl(CFC)
outl(CF8,8000000C)
800=inl(CFC)
2. Wrong log with using of /dev/port:
outb(CF8,0)
outb(CFA,0)
FF=inb(CF8)
FF=inb(CFA)
FFFFFFFF=inl(CF8)
outl(CF8,80000000)
FFFFFFFF=inl(CF8)
outl(CF8,FFFFFFFF)
As possible workaround it would be better to examine size of
buffer and use corresponded insn within of these functions:
switch(size)
{
case 4: outl
case 2: outw
default: outb
}
But it seems that nobody uses this device. Then what is goal
of implementing of this device?
Best regards! Nick
[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: /dev/port BUG and possible workaround
2002-05-22 7:52 ` Martin Dalecki
@ 2002-05-22 9:12 ` Nick Kurshev
2002-05-22 12:09 ` Padraig Brady
1 sibling, 0 replies; 4+ messages in thread
From: Nick Kurshev @ 2002-05-22 9:12 UTC (permalink / raw)
To: linux-kernel
[-- Attachment #1: Type: text/plain, Size: 1004 bytes --]
Hello, Martin!
On Wed, 22 May 2002 09:52:35 +0200 you wrote:
> Uz.ytkownik Nick Kurshev napisa?:
>
> ...
>
> > 800=inl(CFC)
> > 2. Wrong log with using of /dev/port:
>
> ...
>
> > But it seems that nobody uses this device. Then what is goal
> > of implementing of this device?
>
> Basically the goal is that contrary to some silly /proc
> stuff which is "en vouge" nowadays you have the ability to
> controll port access by using normal user permission control
> semantics of unix file access permissions, by giving /dev/port
> a proper group and so on. This is legacy crap of course, since
But this device is unworking in general. It simply unusable for
programs which require 4-byte operations with ports.
As I wrote: outl() != 4*outb() same as inl() != 4*inb()
> the above goal can be reached by using a apache-suexec alike wrapper
> as well... even with more fine grained resolution of access controll.
>
Maybe after fixing these flaws it will be usable but not for now.
Best regards! Nick
[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: /dev/port BUG and possible workaround
2002-05-22 7:52 ` Martin Dalecki
2002-05-22 9:12 ` Nick Kurshev
@ 2002-05-22 12:09 ` Padraig Brady
1 sibling, 0 replies; 4+ messages in thread
From: Padraig Brady @ 2002-05-22 12:09 UTC (permalink / raw)
To: Martin Dalecki; +Cc: Nick Kurshev, linux-kernel
Martin Dalecki wrote:
> Uz.ytkownik Nick Kurshev napisa?:
>
> ...
>
>> 800=inl(CFC)
>> 2. Wrong log with using of /dev/port:
>
> ...
>
>> But it seems that nobody uses this device. Then what is goal
>> of implementing of this device?
>
> Basically the goal is that contrary to some silly /proc
> stuff which is "en vouge" nowadays you have the ability to
> controll port access by using normal user permission control
> semantics of unix file access permissions, by giving /dev/port
> a proper group and so on. This is legacy crap of course, since
> the above goal can be reached by using a apache-suexec alike wrapper
> as well... even with more fine grained resolution of access controll.
It also allows you to write a watchdog driver in shell :-)
#!/bin/sh
# Padraig@antefacto.com
# This supports both the Ibase MB700 and Advantech PCM9576
usage() {
echo "Usage: `basename $0` [pat] [playdead]"
exit 1
}
if [ $# != 1 ]; then usage; fi;
if [ $1 != "pat" ]; then
if [ $1 != "playdead" ]; then
usage
fi
fi
HW_VERSION=`cat /var/run/HW_VERSION`
if [ "$HW_VERSION" == "IBASE MB700" ];
ENABLE_PORT=`printf %d 0x443`
DISABLE_PORT=`printf %d 0x441`
if [ $1 == "pat" ]; then
TIMEOUT='\x5' #20 seconds (0=30s, 1=28s, ..., F=0s)
printf "$TIMEOUT" | dd bs=1 seek=$ENABLE_PORT of=/dev/port
else
#write any value to port to disable
printf "\001" | dd bs=1 seek=$DISABLE_PORT of=/dev/port
fi
elif [ "$HW_VERSION" == "Advantech PCM9576" ]; then
DISENABLE_PORT=`printf %d 0x443`
if [ $1 == "pat" ]; then
TIMEOUT='\x14' #20 seconds (1=1s, 2=2s, ..., 3E=62s)
printf "$TIMEOUT" | dd bs=1 seek=$DISENABLE_PORT of=/dev/port
else
#read from port to disable
dd bs=1 count=1 skip=$DISENABLE_PORT if=/dev/port of=/dev/null
fi
fi
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2002-05-22 12:10 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2002-05-22 8:41 /dev/port BUG and possible workaround Nick Kurshev
2002-05-22 7:52 ` Martin Dalecki
2002-05-22 9:12 ` Nick Kurshev
2002-05-22 12:09 ` Padraig Brady
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.