Драйвер для работы с lpt портом. Порты (COM и LPT)

Компания Cooltek вывела на рынок очередную новинку – mid-tower корпус под названием GT-04. Модель объединяет в себе исключительные характеристики, такие как функциональность, эргономика, стильный дизайн и привлекательная цена (59.99 евро). Шасси выполнено в полностью черном цвете с яркими оранжевыми/зелеными вставками на передней панели. Сюда же выведена и пара корзин для оптических накопителей формата 5.25 дюйма, а также отсек для накопителя 3.5 дюйма.

Корпус Cooltek GT-04 (Orange/Green) оснащен боковым окошком, открывающим вид на системные компоненты. …

Kingston Technology, ведущий производитель памяти для ПК с многолетней историей успеха на рынке, в честь десятилетия продуктовой линейки HyperX объявила о выпуске новых модулей памяти. Примечательной особенностью новинок является черная печатная плата, используемая в семействе HyperX и HyperX Beast, а также наличие уникального теплораспределителя, который значительно улучшает теплоотвод.

Серия HyperX Beast с черной PCB, входящая в состав линейки Predator, характеризуется огромной вместительностью и максимальными рабочими частотами. В розничной торговле модули …

Исключительно для фанатов смонтировать систему из комплектующих белоснежного окраса, организация CORSAIR добавила в известную серию блоков питания CORSAIR RMx механизмы в данном цветовом выполнении. Кроме корпуса самого источника, белый цвет получили полностью модульные кабели, а присутствие небольшого числа компонентов черного окраса придает модный вид новым механизмам, делая акцент на контрасте.

Все варианты линейки CORSAIR RMx White имеют качественную элементную базу (в том числе, применяются сугубо японские конденсаторы высокотемпературной …

Подключение контроллера с использованием переходника USB-LPT

1 Настройка для работы программы Mach3 с переходником USB-LPT

1.1 При использовании переходника USB-LPT, необходимо скопировать файл mach3usb.dll в папку c:\mach3\plugins.

1.2 Для работы устройства также понадобится установить драйвер.

Для этого подключаемадаптер к USB порту компьютера.

Ждем пока операционная система обнаружит подключенное устройство.

Отрываем «Панель управления»→ «Диспетчер устройств», находим в разделе «Другие устройства» - CNC controller, рисунок 1.

Рисунок 1.

Щелкнув правой кнопкой по нему, и выбрав " С войства", нажать кнопку "Обновить драйвер ы ".

В открывшимся окне выбираем пункт «Поиск драйверов на этом компьютере (Поиск и установка драйверов вручную)».

Указываем путь к папке с драйверами, рисунок 2.


Рисунок 2.

1.3 При запуске программы управления станком MACH3 потребуется выбрать из списка устройств, рисунок 3

Рисунок 3

1.4 Конфигурация плагина mach3usb для USB-LPT адаптера.

Нажимаем кнопку “Reset”, Mach3 устанавливает связь с адаптером. П роизводим настройку плагина. Для этого в ыбираем в меню “Config” пункт " Config pl u gins” , рисунок 4.


Рисунок 4.

Нажимаем кнопку “Config” напротив “mach3usb”, открывается окно конфигурации плагина , рисунок 5 .

Рисунок 5.

1.5 Настройка панели микрошага "Software microstep” (программная интерполяция шага ).

Программн ая интерполяция шага двигателя позволяет обеспечить более точный временной контроль , особенно при работе на малых скоростях. Д вижение будет более гладк им и с более низки м уровнем шума . При использовании программного мульт и пликатора шага двигателя в " Motion plugin”, M ach3 будет работать как будто параметр " StepPer" в настройках шаговых двигаталей выше, чем физически, без уменьшения максимальной скорости. При N = 1 параметры работы шаговых двигателей станка соответ с твуют установленным в п у нкте меню " Motor Tuning”.

Введите коэффициент мультипликации N> 1, и умножите на коэффициент N параметр " StepPer" в настройках двигателей(Motor Tuning) Mach3 , рисунок 6.

Рисунок 6.

После окончания установки параметров, закройте окно настройки плагина. Далее нажмите " EStop" (Reset) перейдите в режим "Стоп" и заново в режим "Пуск", для перезагрузки параметров адаптера.

2 Дополнительные настройки плагина переходника USB-LPT

2.1 Автоматическое отключение сигнала "Enable"

Автоматическое отключение сигнала "Enable", через установленный промежуток времени, в течении которого не производилось перемещений. Если в поле установлено значение 0, то используется параметр по умолчанию — 500мС. При отключении этой функции сигнал "Enable" отключается нажатием кнопки "E-Stop" (Reset).

2.2 Возврат от концевого выключателя базы (Home ).

Рисунок 7.

Устанавливает возврат портала от момента срабатывания концевого выключателя при автоматическом поиске баз по всем осям. (Для исключения ложных

срабатываний при поиске баз, если один входной сигнал используется для нескольких концевых выключателей).

2.3 Использование кнопок "Cycle Start" , "Feed Hold", "Stop".

Рисунок 8.

При работе плагина:

Нажатие кнопки "Stop" приводит к быстрой остановке выполнения программы, с потерей всего G- кода содержащегося в буфере данных

Нажатие кнопки "Feed Hold", исполнение программы будет продолжаться до исчерпания содержимого программного буфера.

После нажатия "Feed Hold ", для корректного продолжения работы нажмите кнопку " Regen toolpath " затем " Run", э то обеспечит корректное продолжение программы.

Рисунок 9.

2.4 Таймер.

Рисунок 10.

Activity: время пре-буферизации при старте

Inactivity : время детекции состояний Stop/Pause, а так же ресинхронизации индексных импульсов

Response : время передачи команд статуса. Используется для правильной реализации состояний остановка, движение, синхронизация.

При использовании значений по умолчанию, данные введённые в поля значений не используются. Используются значения 100/300/300.

Таймер не распространяется на команды переездов. Команды переездов всегда исполняются сразу.

2.5 Панель настройки индексного входа, рисунок 23.

Рисунок 11.

Адаптер имеет конфигурироемый индексный вход -вывод 12.
индексный вход поддерживает следующие функции:
- Измерение числа оборотов шпинделя в минуту и индикации в Mach3 - “RPM measurement”.

Синхронизация старта с паузы в G-коде по появлению синхроимпульса -“Sync pause/start on
pulse” (в том числе и по нажатию кнопок Pause/Start основного экрана Mach3.)
- Синхронизации скорости подачи инструмента с числом оборотов шпинделя- “Sync adapter
speed with RPM”.
Синхронизация скорости подачи с числом оборотов шпинделя производится средствами
адаптера и соответствует формуле:
А=(А1*В)/В1.
Где: А -подача в данный момент времени;
А1- нормальная подача заданная в G-коде;
В - измеренное значение числа оборотов в минуту шпинделя;
В1- число оборотов шпинделя при нормальной подаче;
Поле RPM - число оборотов при нормальной подаче, поле % -величина превышения числа
оборотов над заданными которая может быть отслежена. Если поле % равно нулю, то подача
всегда меньше или равна нормальной подаче заданной в G-коде.

2.6 Буфер.

Рисунок 12.

Иногда возможно временное рассогласование между строкой G-кода отображаемой, как выполняемая в Mach3, и фактически исполняемой строкой, а так же задержка исполнения команд Stop, Feed Hold. Это связано с наличием собственного командного буфера адаптера.
Буфер стабилизирует работу при кратковременных сбоях связи между адаптером и компьютером и при замедлении расчёта Mach3. С одной стороны,чем больше буфер тем стабильнее работа, но в связи с тем что объём буфера может достигать десятков килобайт, возможны задержки исполнения команд FeedHold, Stop до нескольких секунд. Вы можете повысить скорость реакции уменьшив значение буфера до 0, но повысится вероятность сбоя при работе.


Итак, рассмотрим следующий вариант работы с портами ввода/вывода в ОС Windows NT. Этим "вариантом" будет специальный драйвер GiveIO.sys , который позволяет приложению, запустившему его, свободно работать с любыми портами. Этот драйвер написал Dale Roberts черт знает когда, но актуальности от не потерял до сих пор.



В кратце расскажу как он работает: в начале работы нашей программы для общения с портами необходимо обратиться к драйверу GiveIO.sys . При этом он установит такие значения системного битового массива карты разрешения (I/O Permission Map) для нашего приложения, что для него будет разрешен прямой доступ к любым портам. I/O Permission Map - это составная часть системы защиты ввода-вывода Windows NT. Он представляет собой битовый массив, каждый бит которого соответствует порту ввода-вывода. Если бит = 1, то доступ к порту закрыт, если 0, то открыт. Для любого пользовательского приложения все биты установлены в 1, и соответственно мы не можем напрямую вмешаться в работу порта. GiveIO.sys внаглую "влезает" в этом массив и везде устанавливает 0 - т.е. мы получаем возможность обращаться к любому порту из приложения.



Для начала скачиваем архив с драйвером и файлом установки:


Теперь нам необходимо зарегистрировать и установить драйвер в системе. Для этого необходимо сделать ряд операций. Во-первых, копируем файл драйвера GIVEIO.sys в папку C:\Windows\system32\drivers\ если, конечно, система у Вас установлена на диск С:\ и вы не меняли пути установки Windows.

Нажимаем Да . При этом вы получите сообщение об успешном внесении информации в реестр. Можно убедиться в этом. В программе редактора реестра regedit.exe в ветви HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\giveio можно увидеть следующее:

Для того что бы сделанные нами изменения вступили в силу в обязательном порядке нужна ПЕРЕЗАГРУЗКА КОМПЬЮТЕРА.


Настало время взяться за программирование. В код нашей программы Port.exe (см. ) внесем некоторые изменения, которые позволят ей обращаться к портам не только в Windows 9x как было раньше, но и в Windows NT. Итоговый код примет вид:

#include "iostream.h" #include "conio.h" #include "stdlib.h" #include "windows.h" int main() { int Address = 888; cout<<"Test LPT port with GiveIO.sys"<

Все. Компилируем, запускаем. Щелкаем 1-0: все должно работать. Если выскочило сообщение Error! Can"t open driver! Press any key to exit... , значит установка драйвера прошла неудачно, и его надо переустановить заново.

Благодаря giveio.sys успешно отработают и такие ассемблерные письмена:

Asm { mov dx, 378h mov al, 1 out dx, al }

© Дмитрий Иванов
2005-2006

Лет 10-15 назад параллельный порт был довольно востребованным интерфейсом для связи между устройствами. Сегодня производители различных устройств отдают предпочтение последовательным интерфейсам. Тем не менее, и сегодня LPT порт всё ещё можно встретить. А некоторые разработчики ещё пишут под него программы (или поддерживают написанные во времена расцвета параллельных интерфейсов). Но в компьютерах сейчас LPT порт - достаточно большая редкость. Существуют, конечно, платы расширения для компьютера, которые реализуют интерфейс LPT. Они в основном представляют собой платы на шине PCI. К сожалению, далеко не весь софт, который был написан для интегрированных в материнскую плату LPT портов, будет работать с LPT-PCI-платами.

Предлагается решение этой проблемы: программный класс, написанный под.NET, и динамическую библиотеку, которая работает с LPT. Данная реализация проверена на 32- и 64-разрядных Windows XP, Windows 7, 8 и 10 как со встроенными LPT портами, так и реализованными в виде плат расширения на шине PCI или PCI-Express. Скачать драйвер для LPT порта можно по ссылке внизу после статьи.

1 Установка драйвера для работы с LPT портом

В приложенном архиве находятся две папки - для 32-разрядной и для 64-разрядной версий Windows. В одной из папок лежит файл InstallDriver.exe . Сначала запустите этот файл, он установит динамические библиотеки в систему. После этого компьютер следует перезагрузить.

Чтобы использовать предлагаемый драйвер, файлы inpout32.dll и inpoutx64.dll должны располагаться в одной директории с исполняемым файлом вашей программы.

2 Программный класс использования библиотек работы с LPT портом

Мной был написан класс для.NET, который использует динамические библиотеки inpout32.dll и inpoutx64.dll и позволяет считывать из параллельного порта и записывать в его регистры данные.

Упомянутые библиотеки написаны не мной. Я предлагаю удобный класс-оболочку, упрощающий работу с данными библиотеками. Кроме того, автор библиотек в файле readme.txt сообщает, что его драйвер не поддерживает PCI устройства. Мне удалось его запустить для работы как с интегрированным параллельным портом, так и LPT портом, реализованном в виде платы расширения на шине PCI-Express. Причём порт отлично работает и на современной Windows10 x64, и на более старых системах.

Вот код класса LPT на языке VB.NET:

Код класса LPT на языке VB.NET (разворачивается) Imports System.Runtime.InteropServices """ """ Работа с LPT портом. При создании определяет наличие драйвера и выбирает подходящую библиотеку. """ Public NotInheritable Class LPT #Region "CONST" Public Const DLL32 As String = "c:\temp\inpout32.dll" Public Const DLL64 As String = "c:\temp\inpoutx64.dll" Public Const DLL32DRV As String = "c:\temp\inpoutx32drv.dll" """ """ Регистры параллельного порта. """ Public Enum Register As Integer """ """ Регистр данных SPP/EPP. """ DATA = 0 """ """ Регистр состояния SPP/EPP. """ STATUS = DATA + 1 """ """ Регистр управления SPP/EPP. """ CONTROL = DATA + 2 """ """ Регистр адреса EPP. Чтение или запись в него генерирует свзяанный цикл чтения или записи адреса EPP. """ EPP_ADDRESS = DATA + 3 """ """ Регистр данных EPP. Чтение (запись) генерирует связанный цикл чтения (записи) данных EPP. """ EPP_DATA = DATA + 4 """ """ Регистр активации режима EPP. """ """ """ Если только смешанный "ECP+EPP" или "Extended" - скорее всего потребуется еще выполнить запись в порт ECR байта 0x80 """ (ECR - это регистр ECP-режима, ECR=BASE_ADDR+0x402, BASE_ADDR - базовый адрес LPT-порта """ ECR = DATA + &H402 "TEST End Enum #End Region "/CONST #Region "DllImport" Private Shared Function IsInpOutDriverOpen() As Byte End Function Private Shared Function IsInpOutDriverOpen_x64() As UInt64 End Function Private Shared Function Inp32(PortAddress As UInt32) As Byte End Function Private Shared Sub Out32(portAddress As UInt32, data As UInt32) End Sub Private Shared Function Inp64(PortAddress As UInt64) As Byte End Function Private Shared Sub Out64(PortAddress As UInt64, Data As UInt64) End Sub #End Region "/DllImport #Region "CTOR" """ """ Проверяет возможность использования x86 или x64 драйвера. В случае невозможности выбрасывает исключение "драйвер не установлен". """ Shared Sub New() Dim x86 As Boolean = CheckIsDriverX86() Dim x64 As Boolean = CheckIsDriverX64() If x64 Then _IsX64DriverUsed = True ElseIf x86 Then _IsX64DriverUsed = False Else Throw New SystemException("Драйвер для LPT порта не установлен.") End If End Sub """ """ Инициализация порта - выставление XXXX0100"b в регистре контроля. """ Private Shared Sub InitLpt(port As ULong) Write(port, Register.ECR, &H80) Write(port, Register.CONTROL, &H4) End Sub #End Region "/CTOR #Region "PROPS" """ """ Используется ли 64-разрядная версия драйвера. """ Если драйвер не установлен, возвращается NULL. """ Public Shared ReadOnly Property IsX64DriverUsed As Boolean? Get Return _IsX64DriverUsed End Get End Property Private Shared ReadOnly _IsX64DriverUsed As Boolean? = Nothing #End Region "/PROPS #Region "METHODS" """ """ Определяет, является ли драйвер 32-разрядным. """ Private Shared Function CheckIsDriverX86() As Boolean Try Dim res As Byte = IsInpOutDriverOpen() Return True Catch ex As Exception Return False End Try End Function """ """ Определяет, является ли драйвер 64-разрядным. """ Private Shared Function CheckIsDriverX64() As Boolean Try Dim nResult As ULong = IsInpOutDriverOpen_x64() Return (nResult <> 0) Catch ex As Exception Return False End Try End Function #End Region "/METHODS #Region "Read / Write LPT Port" """ """ Читает из заданного регистра LPT порта 1 байт данных. """ """ Номер порта. """ Регистр порта. Public Shared Function Read(port As ULong, Optional reg As Register = Register.DATA) As Byte Dim data As Byte = 0 If IsX64DriverUsed Then data = Inp64(CULng(port + reg)) Else data = Inp32(CUInt(port + reg)) End If Return data End Function """ """ Записывает в заданный регистр LPT порта число. """ """ Адрес порта. """ Регистр порта. """ Public Shared Sub Write(port As ULong, reg As Register, data As ULong) If IsX64DriverUsed Then Out64(port + CULng(reg), data) Else If (data <= UInteger.MaxValue) Then Out32(CUInt(port + reg), CUInt(data)) Else Throw New ArgumentException("В 32-разрядных системах аргумент должен быть 32-разрядным (тип UInt32).", "data") End If End If End Sub #End Region "/Read / Write LPT Port """ """ Тестирует наличие LPT порта по заданному адресу. """ """ Адрес параллельного порта. Public Shared Function CheckPortPresent(lptAddress As ULong) As Boolean Dim portPresent As Boolean = False Try InitLpt(lptAddress) Dim data As ULong = Read(lptAddress, Register.DATA) "сохраняем текущее значение регистра данных "Проверим: что записали, то и прочитали? Write(lptAddress, Register.DATA, &H0) portPresent = portPresent And (&H0 = Read(lptAddress, Register.DATA)) Write(lptAddress, Register.DATA, &H55) portPresent = portPresent And (&H55 = Read(lptAddress, Register.DATA)) Write(lptAddress, Register.DATA, &HAA) portPresent = portPresent And (&HAA = Read(lptAddress, Register.DATA)) Write(lptAddress, Register.DATA, data) "восстанавливаем прежнее значение регистра данных "Проверим наличие регистров управления и данных, если порт не обнаружен (в случае однонаправленного порта) If (Not portPresent) Then data = Read(lptAddress, Register.CONTROL) portPresent = ((data <> 0) AndAlso (data <> &HFF)) "Не пустое значение? => Порт присутствует. If (Not portPresent) Then data = Read(lptAddress, Register.STATUS) portPresent = ((data <> 0) AndAlso (data <> &HFF)) End If End If Catch ex As Exception Return False End Try Return portPresent End Function End Class "/LPT

Код класса LPT на языке C#:

Код класса LPT на языке C# (разворачивается) using System; using System.Diagnostics; using System.Runtime.InteropServices; namespace LPTIO { /// Класс для работы LPT портом. При создании определяет наличие драйвера и его разрядность. public sealed class LPT { private const string DLL32 = "inpout32.dll"; private const string DLL64 = "inpoutx64.dll"; private static bool _IsX64DriverUsed; /// Используется ли 64-разрядная версия драйвера. public static bool IsX64DriverUsed { get { return LPT._IsX64DriverUsed; } } static LPT() { if (LPT.getIsDriverX86()) { LPT._IsX64DriverUsed = false; } else { if (!LPT.getIsDriverX64()) throw new SystemException("Драйвер для LPT порта не установлен."); LPT._IsX64DriverUsed = true; } } public LPT() { } private static extern byte IsInpOutDriverOpen(); private static extern ulong IsInpOutDriverOpen_x64(); private static extern byte Inp32(uint PortAddress); private static extern void Out32(uint portAddress, uint data); private static extern byte Inp64(ulong PortAddress); private static extern void Out64(ulong PortAddress, ulong Data); /// Определяет, является ли драйвер для 32-разрядной версии Windows. private static bool getIsDriverX86() { bool flag; try { LPT.IsInpOutDriverOpen(); flag = true; } catch (Exception ex) { ProjectData.SetProjectError(ex); flag = false; ProjectData.ClearProjectError(); } return flag; } /// Определяет, является ли драйвер для 64-разрядной версии Windows. private static bool getIsDriverX64() { bool flag; try { flag = Decimal.Compare(new Decimal(LPT.IsInpOutDriverOpen_x64()), Decimal.Zero) != 0; } catch (Exception ex) { ProjectData.SetProjectError(ex); flag = false; ProjectData.ClearProjectError(); } return flag; } /// Читает из LPT порта 1 байт данных. /// Номер порта. /// Регистр порта. public static byte Read(ulong port, LPT.Register reg = LPT.Register.DATA) { return !LPT.IsX64DriverUsed ? LPT.Inp32(Convert.ToUInt32(Decimal.Add(new Decimal(port), new Decimal((int) reg)))) : LPT.Inp64(Convert.ToUInt64(Decimal.Add(new Decimal(port), new Decimal((int) reg)))); } /// Записывает в LPT порт число. /// Адрес порта. /// Регистр порта. /// Число для записи. В 32-разрядных системах аргумент должен быть не более, чем максимальное значение для типа UInt32. public static void Write(ulong port, LPT.Register reg, ulong data) { if (LPT.IsX64DriverUsed) { LPT.Out64(checked (port + (ulong) (uint) reg), data); } else { if (data > (ulong) uint.MaxValue) throw new ArgumentException("В 32-разрядных системах аргумент должен быть 32-разрядным (тип UInt32).", "data"); LPT.Out32(Convert.ToUInt32(Decimal.Add(new Decimal(port), new Decimal((int) reg))), checked ((uint) data)); } } /// Регистры порта LPT. public enum Register { DATA, STATUS, CONTROL, } } }

3 Применение класса.NET для работы с LPT портом

Если мы посмотрим на список экспортируемых функций библиотеки inpout32.dll с помощью замечательного инструмента DLL Export Viewer от NirSoft , то увидим следующую картину:

Это список функций, которые мы можем использовать. Фактически все они используются в классе LPT , но реализация скрыта, и из публичных методов пользователю доступны только два метода и одно свойство (они рассматриваются чуть далее).

При инстанцировании класс сам определит, библиотеку какой разрядности ему использовать - inpout32.dll или inpoutx64.dll . Поэтому от пользователя не требуется никаких действий по инициализации или определения разрядности используемой dll . Вы можете сразу записывать или читать из LPT порта. Одно «Но»: если драйвер не установлен, обращение к любому из методов динамической библиотеки вызовет исключение, поэтому рекомендую использовать блоки Try…Catch для перехвата и обработки исключений.

Несколько примеров использования класса LPT .

Для определения, используется ли 64-разрядная версия драйвера (inpoutx64.dll при True) или 32-разрядная (inpout32.dll при False) (на самом деле, это знать не обязательно, класс использует именно ту библиотеку, которая нужна, но вдруг вам для чего-то понадобится это узнать из своей программы):

Bool is64bitDriver = LPT.IsX64DriverUsed;

Для записи числа "123" в регистр контроля LPT порта вызовите из своего класса:

LPT.Write(currentPort, LPT.Register.CONTROL, 123);

Для чтения одного байта из регистра данных LPT порта и чтения регистра статуса:

Byte b = LPT.Read(currentPort, LPT.Register.DATA); byte s = LPT.Read(currentPort, LPT.Register.STATUS);

Здесь currentPort - адрес LPT порта . Причём, если у вас интегрированный LPT порт, то его адрес будет, скорее всего, 378h . А если у вас LPT порт на плате расширения, то адрес будет другой, например, D100h или C100h .

Чтобы узнать адрес LPT порта, зайдите в диспетчер устройств Windows, найдите раздел Порты COM и LPT , выберите используемый параллельный порт, и в окне свойств (щёлкнув по нему правой кнопкой мыши) посмотрите, какие ресурсы использует выбранный порт (необходимо брать первое значение из диапазона).


Например, в данном случае необходимо использовать номер порта C100 .

Скачать вложения:

  • Скачать драйвер для LPT порта (3281 Скачиваний)

Публикации по теме