[identity profile] vkorehovisback.livejournal.com posting in [community profile] engineering_ru
Оригинал взят у [livejournal.com profile] vkorehovisback в Как сделать PCI карту своими руками, Часть 1 (введение)
Мне понадобился качественный интерфейс для CNC станка.
Сразу скажу что параллельный порт меня не устраивает. потому как качество его реализации сомнительное, контактов мало (всего 16 I/O, не помню сколько I и сколько O) и максимальная частота работы до 50 кгЦ, с сомнительными показателями по интерференции, крутизне фронтов, задержек, и т.д.
Для интерфейса с 6-осным станком, понадобится 24 дифференциальные пары контактов (6 диффпар на сигналы DIR, 6 диффпар на сигналы PULSE).
Кроме того я предусмотрел 12 цифровых TTL выхода (до 50ма) и 12 опто-изолированных цифровых входа общего назначения.
И того все это добро еле уместилось в SCSI коннектор 50 pin, который мне очень нравится.


Дальше самое главное, какой вариант реализации PCI карты выбрать, существует два пути:
1) Использовать готовый PCI чип какого-либо производителя.
2) Использовать FPGA.


Первый вариант я отбросил, потому что тогда реализация будет целиком зависеть от этого чипа, его глюков или их отсутствия.
т.е. мы будем всецело полагаться на кого-то учить их спецификацию, разбирать какой драйвер нужен, как его написать и т.д.

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

Начнем с самого сложного, с шины PCI. Осложняется все тем, что спецификация закрытая, в интернете информации не много, но есть способ обойти буржуев.
Многие производители FPGA имеют и комплект стандартных реализаций различных интерфейсов за доп. плату (которую вменяемые люди конечно-же платить не будут), называется это все IP Core (Xilinx у других может отличаться, но идея таже)
что это такое? ну это вроде библиотеки для линковки кода.
IP Core может поставляться в виде непосредственно кода (Verilog ili VHDL) либо в виде специального закрытого нэтлиста (что-то вроде EDIF, но зашифрован, у каждого вендора свой формат и позволяет линковать их только используя их средства разработки)
Спасибо умельцам, которые четко взломали пакет Xilinx ISE 10.1, что позволяет получить доступ ко всем IP Core абсолютно бесплатно и на уровне исходного кода (что самое полезное для обучения)
Раздачу каждый может найти сам на известном торрент трекере.

Далее, есть сайт fpga4fun.com где рассказывается максимально сжато о всех особенностях FPGA и нет смысля дублировать эту информацию тут. Сайт рассказывает о FPGA двух лидеров на рынке: Xylinx и Altera.
Также вам потребуется изучить Verilog, но если вы уже программировали на каком-то языке, то это не составит большего труда.

Какой чип выбрать??
Я остановился на Xylinx Spartan xxx
Тут есть несколько подводных камней.
1) Совместимость с шиной PCI32 5V
2) Количество выходов которые можно коммутировать одновременно (называется SSO simultaneously switching outputs)
3) Тип корпуса: BGA или PQ (BGA сложнее паять, потребуется печь, либо хороший фен и удача)
4) Встроенный flash либо вынесенный в отдельный чип?
5) Максимальное время загрузки до получения первых сигналов с PCI

Совместимость с шиной PCI32 5V


Это наверное самое ответственное из всего. Вам предстоит сделать выбор, использовать ли вам чипы конвертации уровней сигналов всех I/O шины (около 50) и использовать современный FPGA (1.25V, 2.5V, 3.3V no 5V tolerant).
Либо использовать старый FPGA.
Для своего проекта я сделал выбор в пользу старого FPGA (Spartan II) и пока еще не пожалел.
Следует отметить, что использование чипов конвертации уровней вносит дополнительные сложности в проблему с SSO, потому как
такие чипы генерируют Overshotы и Undershotы напряжения и могут приводить к ошибкам.
Проблема SSO, питания и максимального времени загрузки FPGA для PCI32 3.3V:
http://www.xilinx.com/support/documentation/application_notes/xapp457.pdf
Наилучшее подключение Bus Switch для совместимости с 5V PCI (что является стандартом для домашних ПК):
http://www.xilinx.com/support/documentation/application_notes/xapp646.pdf
Проблему с overshot и undershot тут решают сместив уровень земли для чипов конвертера уровней.
Следует отметить особенно, что для увеличения числа SSO (также называется Ground bounce) применяют шунтирующий резистор в цели питания чипа, задавая ток "холостого хода" 50mA (резистор 34 ом, для питания 3.3V)
Такой резистор, либо низкоомную обратную связь для LDO я видел во ВСЕХ pci платах схемы которых мне удалось достать.

Количество выходов которые можно коммутировать одновременно (называется SSO: simultaneously switching outputs)


У каждого чипа и типа корпуса этот параметр разный и приводится в даташите.
Например в моем случае с типом корпуса PQ208 и моделью Spartan II для стандарта PCI разрешается использовать до 4х SSO на группу питания, которых всего 16 в устройстве (по две на банк, которых 8-мь)

Далее я взял константы которые поставлялись с IP Core PCI (версия 3.199) (*.ucf файл User Constants file)
И оказалось что они распределили все сигналы PCI на 4 банка (получается 32 SSO сигнала разрешено, в то время как для шины pci требуется порядка 40 сигналов у которых крутые фронты):
http://www.xilinx.com/support/documentation/application_notes/xapp457.pdf
• AD[31:0]
• CBE[3:0]
• PAR
• IRDY#, FRAME#
• REQ#

Кроме того банки заполнены неравномерно, что так-же нарушает Допустимый SSО.
С другой стороны IP Core прошла тестирование в такой конфигурации и я побоялся менять тут что-то.
рискуя не вложиться в тайминги PCI шины, из за особенностей внутренней архитектуры FPGA.
Поэтому я предпринял дополнительные усилия для увеличения SSO. Я поставил шунт (120 ом) нa выход каждого регулятора напряжения питания, хорошие байпас конденсаторы, многослойную печатную плату с отдельным слоем для земли и т.д.
Также следует думать тут об удобном расположении выводов для трассировки печатной платы!

Тип корпуса: BGA или PQ


Я выбрал PQ208, BGA имеет большее преимущество (вдвое выше SSO), но есть риск не запаять в домашних условиях, еще может быть закорочен какой-либо контакт из за смещения чипа, что опасно для вашей материнской платы!.

Встроенный flash либо вынесенный в отдельный чип? и Максимальное время загрузки до получения первых сигналов с PCI



Тут я первый раз пожалел что связался со старой линейкой чипов а не выбрал новую Spartan 3AN (со встроены флешем)
Оказалось что для каждой модели Spartan II есть свой чип программируемый через JTAG.
Он оказался довольно дорогим, и чувствуется что его скоро перестанут продавать.
XC18V01 (1 мегабайт флеша в моем случае)
Как его подключить к FPGA Spartan II, есть в даташите.
Возможно либо серийный интерфейс либо параллельный, под управлением внутреннего такта FPGA либо внешнего!, я выбрал серийный под управлением FPGA, т.е. сигнал кола генерирует сам FPGA и после окончания загрузки переходит в рабочий режим.
Частота загрузки конфигурации 66Мгц, для PCI32 5V это достаточно чтобы уложиться в 1.1 секунду (PCI32 5V 32Mhz) для загрузки полной конфигурации. однако в моем проекте будет использоваться лишь небольшая часть конфигурационного пространства.

Ну вот вроде и все, скоро выложу печатную плату и схему, в следующей части.
Потом будет софт и наша PCI карта готова.

Date: 2014-05-01 08:43 pm (UTC)
From: [identity profile] dimorlus.livejournal.com
А микроконтроллер с USB не проще?

Date: 2014-05-01 09:10 pm (UTC)
From: [identity profile] dimorlus.livejournal.com
если только USB3, нужно минимизировать задержку.

Думаю, с CNC (особенно самодельным) и USB1 справится, и даже UART (только их уже часто нет), если собственно приводами будет сам контроллер управлять, генерируя PWM, или импульсы для шаговых моторов, а комп будет сообщать что, собственно, делать. Реальное время, особенно быстрое и не буферизируемое на контроллере куда сподручнее, чем на РС с любой общего применения ОС делать. И надежнее.

опыт с FPGA намного ценнее чем с любым микроконтроллером.

Сильно зависит от того, что делать. Задачи привода обычно решаются именно контроллерами.

если скорость CNC быстрая то он должен управляться 160кГц, бывает и выше, крутизна фронтов определяет точность также, лучше чтобы запас был по частоте.

Какой-то бессмысленный набор слов. Что именно нужно делать на частоте 160кГц? Вообще, для обычных сегодня 32хразрядных контроллеров с 50МГц тактовой за пару долларов это несколько сот команд. Крутизна каких именно фронтов, и причем тут вообще частота и контроллер или не контроллер?

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

Ну не каждый, конечно, их же тысячи разных от десятков производителей. Про параллельную обработку - опять какая-то бессмыслица. Обработка или успевает за реальным временем, или нет. А параллельно или последовательно обрабатываются сигналы - какая разница? Ну и для даже самого изощренного сервопривода например TI делает кучу контроллеров, например семейство Piccolo (http://www.ti.com/lsds/ti/microcontroller/32-bit_c2000/c28x_piccolo/overview.page)

Date: 2014-05-06 07:10 am (UTC)
From: [identity profile] ikaktys.livejournal.com
c CNC сложность в том что все команды G code не так то просто реализовать в контроллере, но основная сложность в том что бы с основного управляющего компа можно было управлять произвольно, т.е. "отмотать" на любую команду в списке G code, и нАчать/продолжить в с нее, это требует полноценный интрефейс с контроллером, так никто не делает, у всех сделан обработчик/компилятор G code в самой управляющец программе, которая при перемотке его перекомпилирует, а сам контроллер получает уже полупереваренные команды и только выдает realtime такт на наговики/сервомоторы, скорости USB1 тут не хватит, такт при 1/16 шаге нужет приличный, при 200 шагов/оборот и 10об/сек, нужен такт на фазу не ниже 32KHz, общий c учетом сдвига фаз - разрешение должно быть в 4 раза выше.

Но таки да, PCI для этого не нужно, делают USB2 или ethernet 10/100 интерфейсы, причем ethernet все распространеннее, бо есть везде, дубовый, изолированый (само то для индустрии) "бьет" далеко и не капризный.
Realtime общениф с компом при том не нужно, у меня есть CNC Smoothstepper контроллер, в нем буфер для полупереваренных команд на 1-2 секунды, хвататет в 99.999% случаев.

Date: 2014-05-02 05:27 am (UTC)
From: [identity profile] vasiapetechkin.livejournal.com
о, Боже, как все сложно...

ну вот сколько точек с какой точностью должен делать ваш станок?

АРМ-контроллер на каком-нибудь кортексе-м3 по USB все это переварит и даже не чхнет

и еще, 160кГц - это у вас ШИМ или частота шагов (во что я не верю)?

если всего-навсего ШИМ, то городить с PCI трудозатратнее раз в 20

Date: 2014-05-02 03:16 pm (UTC)
From: [identity profile] vasiapetechkin.livejournal.com
1) ну так вот, возваращемся в школу, 3ий, примерно, класс:
9м/мин при шаге 0.016мм это всего 9375 шагов в секунду
даже если 6 координат, то всеравно это не более 60тыс шагов в секунду
но далеко не 160 заявленых в посте

2) дальше больше - никто не режет металлы со скоростью 9м/минуту, тем более, если нужна точность в сотых миллиметра, для высоких точностей режут гораздо медленнее

3) если вы попробуете резать хотя бы алюминий с такой скоростью, то либо фреза сломается либо привод фрезы просто не потянет ее вращать

4) посчитайте, кстати, с какой частотой должен вращаться шпиндель, чтоб при толщине реза 0.1 мм срезать 150мм металла за секунду - допустим у фрезы 6 режущих кромок - это минимум 15тыс оборотов/мин

5) может быть, вам задали максимальную линейную скорость головы, то это исключительно для холостых перемещений, там и DIR существенно реже приходит

6) нормальный инженер разделит задачи пакетирования DIR, конвертации в шаги и, собственно, привод шаговиков - последнее будет реализовано в МК, который подключен к ПК по USB

7) если есть 60тыс шагов в секунду, то это приблизительно скорость в битах, если реализовывать систему по 4)
даже, если допустить, что на каждый шаг вы будете передавать 10байт информации, то это всего лишь 4,8МБит/сек; некоторые UART работают уже до 1.5Мбит. я не говорю уже об USB

ну, собственно, вам в комментариях расписали то же
ясное дело, что решать вам - ехать или шашечки

потому что если для спортивного интереса, то можно, если для коммерц, то это лишняя трата времени где-то раз в 10-20

Profile

engineering_ru: (Default)
Инженерия

December 2025

S M T W T F S
 123456
78910111213
14151617181920
2122232425 2627
28293031   

Most Popular Tags

Style Credit

Expand Cut Tags

No cut tags
Page generated Mar. 8th, 2026 09:40 am
Powered by Dreamwidth Studios