|
LVDS протокол для передачи на 50-100 МБ/с, Можно ли использовать SPI через LVDS на скорости 50-100 МБ/с |
|
|
|
Dec 27 2017, 20:32
|

Частый гость
 
Группа: Свой
Сообщений: 81
Регистрация: 31-10-14
Из: Воронеж
Пользователь №: 83 452

|
Цитата(Олег Гаврильченко @ Dec 27 2017, 18:00)  Можно Вас попросить подробнее описать, как Вы это делали? да там ничего особо хитрого, клок 2x, работа по обоим фронтам клока. вот и вся хитрость. получаем 4 семпла на бит. нарисовать это на бумаге и всё очевидно станет. можно и проще сделать, как посоветовал Цитата(a123-flex @ Dec 27 2017, 23:08)  xapp224 - это дорого ? там тоже 4x, для относительно небольших скоростей вполне подходит вариант. но увеличение скорости требует увеличения точности смежных фаз клоков. плюс еще вместо одного домена используется 2. мелочь, но жаба душит. поэтому мой вариант с одним доменом 2x, но с DDR мне больше понравился. Тем более, что 2x уже и в других модулях используется. Ну и если требуется повышенная надёжность -- не забывайте про защиту от метастабильности.
|
|
|
|
|
Dec 27 2017, 20:36
|
Профессионал
    
Группа: Свой
Сообщений: 1 687
Регистрация: 11-01-05
Из: Москва
Пользователь №: 1 884

|
Цитата(FakeDevice @ Dec 28 2017, 00:32)  работа по обоим фронтам клока, да там ничего особо хитрого ) Цитата(FakeDevice @ Dec 28 2017, 00:32)  там тоже 4x, для относительно небольших скоростей вполне подходит вариант. но увеличение скорости требует увеличения точности смежных фаз клоков. плюс еще вместо одного домена используется 2. мелочь, но жаба душит. поэтому мой вариант с одним доменом 2x, но с DDR мне больше понравился. Ну и если требуется повышенная надёжность -- не забывайте про защиту от метастабильности. В оригинальном xapp rloc. Поэтому метастабильности там нет - проверено десятками тысяч часов и сотнями девайсов. Доменов действительно 2. Частота там 1x. Очень полезно такое бывает, когда линию подразогнать нужно.
--------------------
Если хочешь узнать, что ждет тебя на дороге впереди, спроси у тех, кто возвращается по ней.
|
|
|
|
|
Dec 27 2017, 20:42
|
Гуру
     
Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713

|
Цитата(FakeDevice @ Dec 27 2017, 22:08)  Грубо говоря, oversampling получается 4. Это если тактовая - строго меандр. Но даже если меандр, всё равно - точность определения точки стробирования в 4 раза ниже стандарта UART. Ну и соответственно - помехоустойчивость. Можно ли это назвать полноценным UART? Вопрос.... Я бы делал по-другому: Разбил поток на блоки некоей длины, с маркерами начала и конца блока, добавил в блок информацию для контроля целостности. В передатчике выдвигал биты как в UART, только без стартового и стоповых битов - синхронизируемся в начале блока, макс.длина блока выбирается такой, чтобы точка стробирования не ушла за пределы бита при максимальных отношениях частот приёмника/передатчика. В приёмнике сделать oversampling любой насколько позволяет макс.тактовая, но не менее 3. Завести N приёмников (где: N - величина oversampling-а) с точками стробирования в каждом такте. Все приёмники работают независимо принимая параллельно один и тот же блок. В конце блока проверяем его валидность (по контрольной информации). Если блок валиден - передаём его на выход. Ну и сделать между приёмниками необходимую синхронизацию для удаления лишних копий блоков. Делал когда-то давно подобное только на DSP - работало стабильно. Да и сейчас ещё работает - устройство уже десяток лет в коммерческой эксплуатации.
|
|
|
|
|
Dec 27 2017, 20:59
|

Частый гость
 
Группа: Свой
Сообщений: 81
Регистрация: 31-10-14
Из: Воронеж
Пользователь №: 83 452

|
Цитата(a123-flex @ Dec 27 2017, 23:36)  В оригинальном xapp rloc. Поэтому метастабильности там нет - проверено десятками тысяч часов и сотнями девайсов. Доменов действительно 2. Частота там 1x. Очень полезно бывает, когда линию подразогнать нужно. домена 2 -- это минус. частота 1x -- это плюс. ну и наглядность, простота реализации в xapp мне тоже понравилась. тут, видимо, исходя из реальных обстоятельств лучше принимать решение. Просто, повторюсь, у меня к тому моменту уже были задействованы dcm и с 2x, и с 3x. Лишнего уже не терял по потреблению и ресурсам. Вот и реализовал именно так не задумываясь. обеспечение точности разницы фаз, конечно, на совести трассировщика... Я никого не стремлюсь убедить/переубедить, но лично мне спокойнее, когда работаю на 1 домене. Цитата(jcxz @ Dec 27 2017, 23:42)  Это если тактовая - строго меандр. Но даже если меандр, всё равно - точность определения точки стробирования в 4 раза ниже стандарта UART. Ну и соответственно - помехоустойчивость. Можно ли это назвать полноценным UART? Вопрос.... не будет она строго меандром, конечно, но ~40% внутри кристалла вполне достижимо ведь? помехоустойчивость... а что мы сможем тут сделать в разумных пределах кроме попыток защиты от метастабильности? не фильтровать же в самом деле на 16x сигнал? да и от помехи зависит. даже если фильтровать -- далеко не всегда спасёт. если нужна надёжность -- только дублирование. всего. засылок, устройств и т.д. и то не факт, что метеорит не упадёт.
|
|
|
|
|
Dec 27 2017, 21:06
|
Профессионал
    
Группа: Свой
Сообщений: 1 687
Регистрация: 11-01-05
Из: Москва
Пользователь №: 1 884

|
Цитата(FakeDevice @ Dec 28 2017, 00:59)  не будет она строго меандром, конечно, но ~40% внутри кристалла вполне достижимо ведь? помехоустойчивость... а что мы сможем тут сделать в разумных пределах кроме попыток защиты от метастабильности? не фильтровать же в самом деле на 16x сигнал? да и от помехи зависит. даже если фильтровать -- далеко не всегда спасёт. если нужна надёжность -- только дублирование. всего. засылок, устройств и т.д. и то не факт, что метеорит не упадёт. В каналах на базе xapp контролировалась целостность потока. Частота была 96 Мгц, кристаллы - spartan3, virtex2. Генераторы с обоих сторон 50 ppm. Разъемы мр, провода и разводка в модулях жуть. Длина 2-6 метров. Температура была -20 +85. За несколько лет на многих устройствах сбоя не было ни разу. Цитата(jcxz @ Dec 28 2017, 00:42)  Завести N приёмников (где: N - величина oversampling-а) с точками стробирования в каждом такте. расходненько будет.
--------------------
Если хочешь узнать, что ждет тебя на дороге впереди, спроси у тех, кто возвращается по ней.
|
|
|
|
|
Dec 27 2017, 21:12
|

Частый гость
 
Группа: Свой
Сообщений: 81
Регистрация: 31-10-14
Из: Воронеж
Пользователь №: 83 452

|
Цитата(a123-flex @ Dec 28 2017, 00:06)  В каналах на базе xapp контролировалась целостность потока. Частота была 96 Мгц, кристаллы - spartan3, virtex2. За несколько лет на многих устройствах сбоя не было ни разу. у меня тоже контролируется. года за 3-4 тоже сбоя не было ни разу.
|
|
|
|
|
Dec 27 2017, 21:14
|
Гуру
     
Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713

|
Цитата(FakeDevice @ Dec 27 2017, 22:59)  помехоустойчивость... а что мы сможем тут сделать в разумных пределах кроме попыток защиты от метастабильности? Сам oversampling как раз и нужен для повышения помехоустойчивости. Чем он выше, тем точнее определение точки стробирования. Т.е. - самая минимальная помеха, которая чуть-чуть сдвинет фронт стартового бита, при оверсэмплинге==16 внесёт ошибку равную всего лишь 1/16 baudrate в определение точки стробирования. А вот при 4x, промахнёмся аж на четверть бита и точка стробирования на стартовом бите уже может находится на расстоянии 0.25 битового периода от края бита (это без учёта отличия скважности от меандра). Цитата(a123-flex @ Dec 27 2017, 23:06)  расходненько будет. Зато макс.битовая скорость может быть всего лишь в 3 раза ниже макс.тактовой частоты.
|
|
|
|
|
Dec 27 2017, 21:29
|

Частый гость
 
Группа: Свой
Сообщений: 81
Регистрация: 31-10-14
Из: Воронеж
Пользователь №: 83 452

|
Цитата(jcxz @ Dec 28 2017, 00:14)  Сам oversampling как раз и нужен для повышения помехоустойчивости. Чем он выше, тем точнее определение точки стробирования. Т.е. - самая минимальная помеха, которая чуть-чуть сдвинет фронт стартового бита, при оверсэмплинге==16 внесёт ошибку равную всего лишь 1/16 baudrate в определение точки стробирования. (+/-) 1/16 = |1/8|, если быть точнее. Цитата(jcxz @ Dec 28 2017, 00:14)  А вот при 4x, промахнёмся аж на четверть бита и точка стробирования на стартовом бите уже может находится на расстоянии 0.25 битового периода от края бита (это без учёта отличия скважности от меандра). надо исходить из размера пакетов, скорости обмена, девиации. тут каждый сам выбирает, что ему ближе. палка о двух концах: либо частота не подойдёт, либо точности не хватит.
|
|
|
|
|
Dec 27 2017, 21:42
|
Профессионал
    
Группа: Свой
Сообщений: 1 687
Регистрация: 11-01-05
Из: Москва
Пользователь №: 1 884

|
Цитата(jcxz @ Dec 28 2017, 01:40)  Очень узкие у вас представления о модемах. Ну простите Беспроводным каналом я раз в жизни занимался - мне не понравилось. Может быть это потому было, что мы систему за 2 месяца под ключ сдали. Это было ужасно. Поэтому беспроводные я подсознательно исключил)
--------------------
Если хочешь узнать, что ждет тебя на дороге впереди, спроси у тех, кто возвращается по ней.
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|