Does anyone can help me how to interface Qt with parallel port? I'm developing a software that sends some commands to the parallel. Wich class may I use? Thanks
Does anyone can help me how to interface Qt with parallel port? I'm developing a software that sends some commands to the parallel. Wich class may I use? Thanks
i'm not sure but i think that qt cant help you with it, you must use standart api approachOriginally Posted by r00tz
![]()
a life without programming is like an empty bottle![]()
For which platform?
I implemented a basic Qt wrapped for parapin (the paraport driver for linux) if you want it I can post it.
I guess you should create a subclass of QIODevice and implement all the platform-specific issues by yourselfSomething like this:
A quote from TT's docs:Qt Code:
//ParalellPort.h #include <QIODevice> Q_OBJECT public: virtual ~ParalellPort(); virtual bool isSequential () const { return true; } virtual bool open(OpenMode); virtual void close (); //.. protected: virtual qint64 readData ( char * data, qint64 maxSize ); virtual qint64 writeData ( const char * data, qint64 maxSize ); private: #ifdef Q_OS_UNIX QFile deviceFile; #endif }; //ParalellPort.cpp #include "ParalellPort.cpp" #ifdef Q_OS_UNIX , deviceFile(port) #endif { } bool ParalellPort::open(OpenMode mode) { #ifdef Q_OS_UNIX return deviceFile.open(mode); #endif #ifdef Q_OS_MACX //... #endif #ifdef Q_OS_WIN32 //... #endif } //...To copy to clipboard, switch view to plain text mode
Subclasses of QIODevice are only required to implement the protected readData() and writeData() functions.
Well, yes and no.I guess you should create a subclass of QIODevice
The 'problem' with the parallel port is that you can (and usually want to) manipulate individual pins. not just (or nesseseraly) transmit data.
Originally Posted by high_flyer
Qt Code:
void ParalellPort::setPin(int pin, int value) { int oldValue = getChar(pin); if (value != 0) { putChar(oldValue | 1 << pin); } else { putChar(oldValue & (~ (1 << pin)) ); } } int ParalellPort::getPin(int pin) { return (getChar() & (1 << pin)) ? 1 ? 0; }To copy to clipboard, switch view to plain text mode
Ok, here is my implementation, at the moment the fact its Qt has no advantage.
One could build in a polling mechanism that will send signals on pin state changes.
This clas works, it is being used in a program that controlls harware through the paraport.
You should install parapin and read the docs there.
wallyqt (13th November 2007)
Well... I'd just like to thank both of you. This helped very very much, I got some tutorial about parallel port interfacing. With all code and tips you passed to me, I will implement it. Thanks a lot.
I tried the parapin drivers and it works good as root.
When using the parapin-kernel-driver i can access the port from user-space.
Do anybody know how to implement the kerneldriver with qt.
I am looking for something very similar "QParaport.zip" from "high_flyer".
I able to open the parapindriver with:
(set pins is also possible:
int kparappWidget::pushButtonOpen_clicked()
{
pardevice = open("/dev/ppdrv_device", 0);
if (pardevice < 0) {
fprintf(stderr, "pardevice open failed\n");
exit(-1);
}
return 0;
}
but when i call the close function, all widgets on the application mainWin
disappear and i only can close (kill) the app.
int kparappWidget::pushButtonClose_clicked()
{
close(pardevice);
return 0;
}
here is the code for setting pins:
void kparappWidget::pushButtonSetPins_clicked()
{
ioctl(pardevice, PPDRV_IOC_PINMODE_OUT, LP_PIN02);
ioctl(pardevice, PPDRV_IOC_PINSET, LP_PIN02 | LP_PIN03 | LP_PIN04 | LP_PIN05 | LP_PIN06 | LP_PIN07 | LP_PIN08 | LP_PIN09);
}
cheers wally
Last edited by wallyqt; 13th November 2007 at 12:03. Reason: tried to removed disturbing smiles
I am not sure you mean what your text says. i.e:I tried the parapin drivers and it works good as root.
When using the parapin-kernel-driver i can access the port from user-space.
Do you mean you want to use the kernel module from user space, or, do you want to use the user space module with a user that is not root?
It could be that you have problem with read write right for non root users, you can fix that with chmod.
You can't use the kernel module from user space (and you shouldn't)
And if you don't need PIN10, (and from your code it seams that way) you don't need to - the user space module should be used - and you can the QParaport class for what you described here.
==========================signature=============== ==================
S.O.L.I.D principles (use them!):
https://en.wikipedia.org/wiki/SOLID_...iented_design)
Do you write clean code? - if you are TDD'ing then maybe, if not, your not writing clean code.
high_flyer,
you are right, its confusing because i didn't understand it myself not entirely.
I want to use the kernel-driver of parapin which i load during boot.
After the driver is once loaded i do not want to use root anymore.
In command-line apps it works perfect, but i have problems to close the
device properly in a kde-qt-app.
i think i should use Qiodevice.h and not mixing old and new stuff together,
but i am not a good programmer. So i ask in this forum.
As far as i understand you code sample - it needs root previleges.
But i want to use the parapin stuff also in a larger application which not should run as root.
Maybe i do some fundamnetal error
cheers wally
No, you want to use the user space moduleI want to use the kernel-driver of parapin which i load during boot.
Only the system is allowed to access the kernel space module.
Read the parapin documentation.
The problem with QParaport is that it is written for Qt3.
And I haven't had a look at this code for a very long time, so I don't know how easy it should be to port it to Qt4. (I forgot about this during the last post)
But I think it should be just a matter of changing the header deceleration.
The *code* doesn't require root privileges.As far as i understand you code sample - it needs root privileges.
Under linux, you can set access privileges using the chmod command.
read the chmod command man pages for usage. (its simple)
QIOdevice could be good if you'd want to implement the driver your self.i think i should use Qiodevice.h and not mixing old and new stuff together,
But if you use the ready made parapin driver, all you can do is either wrap it (as I did with QParaport) or use it directly.
It has nothing to do with mixing new and old.
==========================signature=============== ==================
S.O.L.I.D principles (use them!):
https://en.wikipedia.org/wiki/SOLID_...iented_design)
Do you write clean code? - if you are TDD'ing then maybe, if not, your not writing clean code.
high_flyer
Thanks for your patience and explanation.
Any concrete idea what i could do to find the problem
with close(device) function in the code above.
Gnu debugger and system messages do not have
any interesting outputs on this problem.
cheers wally
yes - use the user space module.
You should not access kernel space from user space.
==========================signature=============== ==================
S.O.L.I.D principles (use them!):
https://en.wikipedia.org/wiki/SOLID_...iented_design)
Do you write clean code? - if you are TDD'ing then maybe, if not, your not writing clean code.
read the parapin user documentation in the link I posted before on this thread.
Specifically look for the section:
"Parapin Basics
Userspace version and kernel version "
==========================signature=============== ==================
S.O.L.I.D principles (use them!):
https://en.wikipedia.org/wiki/SOLID_...iented_design)
Do you write clean code? - if you are TDD'ing then maybe, if not, your not writing clean code.
high_flyer
for me the parapin documentation sounds as follows:
There is a C library version and a Kernel Module version with a device driver.
Quotes from parapin documentation:
C library version:
Programs using Parapin must be running as root when they are initialized.
Kernel-Module version:
Before the parapindriver device interface may be used, an entry in /dev must be created that corresponds to the device driver module loaded in to the kernel
Once parapindriver is successfully loaded, and a corresponding /dev entry is in place, initialization and shutdown of the parallel port are easy. To initialize the parapin system, just call open(2) on the /dev entry as you would any other device file:
int device;
device = open("/dev/<device-name>", 0);
if (device < 0) {
fprintf(stderr, "device open failed\n");
exit(-1);
}
To shutdown the parapin system you simply have to call close(2):
close(device);
I want to use the last one and excepting the "close(device) everything is ok.
cheers wally
Ok, I see what you mean.
It has been quite long since I used this, so I guess I need to read the docs again
Did you do what is says in the docs about initializing the driver?
int pin_init_kernel(int lpt, void (*irq_func)(int, void *, struct pt_regs *));
AND :
void pin_release();
==========================signature=============== ==================
S.O.L.I.D principles (use them!):
https://en.wikipedia.org/wiki/SOLID_...iented_design)
Do you write clean code? - if you are TDD'ing then maybe, if not, your not writing clean code.
high_flyer
No, because afaik this is the initialization for the C-library version.
During boot my system do the following (of course as root) :
DEVNAME="ppdrv_device"
depmod
modprobe kparapin
modprobe parapindriver devname=${DEVNAME}
mknod /dev/${DEVNAME} u `grep $DEVNAME /proc/devices | cut -d " " -f 1` 0
# Change mode and ownership here if necessary
chmod 777 /dev/${DEVNAME}
chown root /dev/${DEVNAME}
chgrp root /dev/${DEVNAME}
After this is done i acces the parapellport (as user) by opening the device:
pardevice = open("/dev/ppdrv_device", 0);
if (pardevice < 0) {
fprintf(stderr, "pardevice open failed\n");
exit(-1);
from this point on i can simply acces the parallelport with the ioctl command, e.g.:
ioctl(pardevice, PPDRV_IOC_PINMODE_OUT, LP_PIN02);
ioctl(pardevice, PPDRV_IOC_PINSET, LP_PIN02 | LP_PIN03)
I preferred this because i added some parts to the KSIMUS Application.
Its a Electronics simulator by Rasmus Diekenbrock.
I want to avoid the need of root access during the simulator is accessing
the parallelport. It works perfect in KSIMUS (also the close(device) command
which is the reason i wrote here.
In a simple new Kdevelop project, just for open the device,
setting some pins and close the device, this mini application
doesn't work as expected.
When i call "close(device" all of the widgets ( 3 pushbuttons for open/set/close)
disappear and thats it. I have to kill the process.
I wrote here in QT-Centre because i think its not a problem of parapin.
Parapin works perfect e.g. in the ksimus enveronment.
I am sure i am making some coding or logical errors in my code.
( maybe the close(device) command from unistd.h is not welcome.
Also some hint is desireable how to trace what is going on in the app
after calling close(device) and the "crash"
"gdb" and the system messages do not contain strange infos on this.
cheers wally
read again:No, because afaik this is the initialization for the C-library version.
The Kernel Module Version
Initialization and shutdown in the kernel flavor of Parapin is done using the following two functions:
int pin_init_kernel(int lpt,
void (*irq_func)(int, void *, struct pt_regs *));
void pin_release();
The first function is not as intimidating as it looks. Its first argument, lpt, is the parallel port number that you want to control. The number references the kernel's table of detected parallel ports; 0 is the first parallel port and is a safe guess as a default.
The second argument, irq_func, is a pointer to a callback function to be used for servicing interrupts generated by the parallel port. This argument may be NULL if the driver does not need to handle interrupts. Details about interrupt handling are discussed in Section 9.
pin_init_kernel will return 0 on success, or a number less than 0 on error. The return value will be a standard errno value such as -ENODEV, suitable for passing up to higher layers. If Parapin initialization fails, the driver must not call Parapin's other functions. As described earlier, this requirement is not enforced for efficiency reasons.
When a driver is finished controlling the parallel port using Parapin, it must call pin_release. The state of the parallel port's interrupt-enable bit will be restored to the state it was in at the time pin_init_kernel was originally called.
Parapin's pin_init_kernel and pin_release functions work with the Linux kernel's standard parport facility; as noted above, the parport module must be loaded along with any module that uses Parapin. When initialized, Parapin will register itself as a user of the parallel port, and claim exclusive access to that port. This means no other processes will be allowed to use the parallel port until pin_release is called.
==========================signature=============== ==================
S.O.L.I.D principles (use them!):
https://en.wikipedia.org/wiki/SOLID_...iented_design)
Do you write clean code? - if you are TDD'ing then maybe, if not, your not writing clean code.
Bookmarks