Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

outpw/outport

Posted on 1997-01-28
1
Medium Priority
?
732 Views
Last Modified: 2008-03-10
I am attempting to access a card on the ISA bus using Borland C++ 3.1's outpw() and outport() commands, but in both cases the I/O write line goes low (active low) twice while the address is still valid causing the wrong values to be latched because the data is no longer valid on the second strobe. However, that only happens when I attempt to do 16 bit transfers, eight bit transfers work like a charm. Am I doing something wrong or is this simply how the two byte transfer works and I simply have to design around it. Please reply by email.
0
Comment
Question by:robertsb110896
1 Comment
 

Accepted Solution

by:
michaelf earned 100 total points
ID: 1162204
Hi.
Actually it is not about C++ or borland, but
just about ISA bus. ISA bus designed to work
with old style 8-bit devices as well as 16-bit
devices. And I/O device (slave) must tell
CPU (master) wether it is capable to accept /
transmit 16 bit data or just 8 bit.
If it is 8-bit device and program is using
16-bit I/O instructions (using Borland
outpw(), for example) CPU will transfer
data byte by byte: first low order byte
to the specified port, then high order
byte to the port with address greater by
one. I believe it is your case.

If you want to receve 16 bit of data
at once, you have to assert special
signal that tells that it is 16-bit
slave device. I do not have ISA bus
description with me, but according
to the brief table I do have it is
"I/O 16 chip select : D2". You have to
check it using complete ISA bus
description.
  Regards,
      MichaelF

0

Featured Post

Keep up with what's happening at Experts Exchange!

Sign up to receive Decoded, a new monthly digest with product updates, feature release info, continuing education opportunities, and more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Unlike C#, C++ doesn't have native support for sealing classes (so they cannot be sub-classed). At the cost of a virtual base class pointer it is possible to implement a pseudo sealing mechanism The trick is to virtually inherit from a base class…
Introduction This article is the first in a series of articles about the C/C++ Visual Studio Express debugger.  It provides a quick start guide in using the debugger. Part 2 focuses on additional topics in breakpoints.  Lastly, Part 3 focuses on th…
The viewer will learn additional member functions of the vector class. Specifically, the capacity and swap member functions will be introduced.
The viewer will be introduced to the technique of using vectors in C++. The video will cover how to define a vector, store values in the vector and retrieve data from the values stored in the vector.
Suggested Courses

772 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question