Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Specify default DTR and RTS output states #177

Open
codembed opened this issue Jan 25, 2023 · 1 comment
Open

Specify default DTR and RTS output states #177

codembed opened this issue Jan 25, 2023 · 1 comment

Comments

@codembed
Copy link

codembed commented Jan 25, 2023

What is the default state for these pins after a call to open ?

On Windows, it seems that DTR and RTS assert on open. In some cases, automatically asserting these is not desirable.

In my experience, some serial port drivers leave these pins in the state set by a previous OS handle. Perhaps other drivers or APIs always set a default state (which is not always asserted)?

If possible, it would be nice to have consistency over all platforms.

My preference would be for DTR and RTS to be unmodified by open. However, this can be problematic as there is currently no function to get the existing state of these outputs. In addition, setSignals is not permitted before the port is opened.

Please discuss one the following enhancements:

  1. open will not modify signals states, and
    setSignals will return the existing/modified signal states in its Promise, and will support no parameter, so that setSignals({}) or setSignals() will return the current states - unmodified.

or,

  1. Add optional signals parameters to the SerialOptions dictionary to allow these signals to be set synchronously when the port is opened. In some cases, this would prevent glitches in the signals between calls to open and setSignals.

I prefer 1, but I suppose this is considered a 'breaking' change. Having a way to retrieve the current output states would be good!

If neither implementation is practical, it would be good to at least have the default states specified in the standard.

It seems that close will leave DTR and RTS in their current state. I'm okay with that.

@reillyeon
Copy link
Collaborator

In this message I'm referring to the Windows APIs but I think similar issues exist on POSIX systems.

I don't think (1) is possible because the underlying OS APIs don't allow us to observe the state of the output signals. For example, there doesn't appear to be an equivalent to EscapeCommFunction() which returns the state of these signals rather than setting them. There also isn't an option which could be passed to CreateFile() when opening the port which prevents the driver from automatically setting the signal state.

Given that, the best we could achieve with (2) is to add the signal parameters to SerialOptions so that we can immediately call EscapeCommFunction() after CreateFile() so that, at best, signals like DTR are only asserted for a short time.

Am I missing something? Are there other serial APIs which enable the behavior you're looking for?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants