Merge pull request #36 from Lobaro/v1

Windows: Set DTS via setCommState
This commit is contained in:
Cristian Maglie
2017-07-28 10:12:30 +02:00
committed by GitHub

View File

@@ -266,6 +266,15 @@ func (port *windowsPort) SetMode(mode *Mode) error {
} }
func (port *windowsPort) SetDTR(dtr bool) error { func (port *windowsPort) SetDTR(dtr bool) error {
// Like for RTS there are problems with the escapeCommFunction
// observed behaviour was that DTR is set from false -> true
// when setting RTS from true -> false
// 1) Connect -> RTS = true (low) DTR = true (low) OKAY
// 2) SetDTR(false) -> RTS = true (low) DTR = false (heigh) OKAY
// 3) SetRTS(false) -> RTS = false (heigh) DTR = true (low) ERROR: DTR toggled
//
// In addition this way the CommState Flags are not updated
/*
var res bool var res bool
if dtr { if dtr {
res = escapeCommFunction(port.handle, commFunctionSetDTR) res = escapeCommFunction(port.handle, commFunctionSetDTR)
@@ -275,6 +284,23 @@ func (port *windowsPort) SetDTR(dtr bool) error {
if !res { if !res {
return &PortError{} return &PortError{}
} }
return nil
*/
// The following seems a more reliable way to do it
params := &dcb{}
if err := getCommState(port.handle, params); err != nil {
return &PortError{causedBy: err}
}
params.Flags &= dcbDTRControlDisableMask
if dtr {
params.Flags |= dcbDTRControlEnable
}
if err := setCommState(port.handle, params); err != nil {
return &PortError{causedBy: err}
}
return nil return nil
} }
@@ -283,6 +309,8 @@ func (port *windowsPort) SetRTS(rts bool) error {
// it doesn't send USB control message when the RTS bit is // it doesn't send USB control message when the RTS bit is
// changed, so the following code not always works with // changed, so the following code not always works with
// USB-to-serial adapters. // USB-to-serial adapters.
//
// In addition this way the CommState Flags are not updated
/* /*
var res bool var res bool