Перейти к содержанию

Не Синхронизируется Передатчик I2S


_Alex90_

Рекомендуемые сообщения

Приветствую участников форума!

Хочу отправлять данные с процессора на кодек по I2S. Взял за основу basic-at73c213-ssc-i2s-project для отладочной платы at91sam9260-ek. С исходными параметрами интерфейса (частота дискретизации 48 кГц, 16 бит на отсчёт, 2 канала) проект на моей плате запустился. Мне нужна частота дискретизации 8 кГц, 16 бит на отсчёт, 1 канал.

Попробовал следующие комбинации:

24 кГц, 16 бит на отсчёт, 2 канала - интерфейс запустился;

24 кГц, 32 бит на отсчёт, 1 канал - интерфейс запустился;

12 кГц, 16 бит на отсчёт, 2 канала - интерфейс запустился;

12 кГц, 32 бит на отсчёт, 1 канал - интерфейс запустился;

12 кГц, 8 бит на отсчёт, 2 канала - интерфейс запустился;

12 кГц, 16 бит на отсчёт, 1 канал - интерфейс не запустился.

8 кГц, 16 бит на отсчёт, 1 канал - интерфейс не запустился.

То есть я в два раза уменьшал битрейт (произведение частоты дискретизации, числа бит на отсчёт и количества каналов): сначала за счёт уменьшения частоты дискретизации, потом за счёт сокращения длины отсчёта или количества каналов. Остальные параметры не менял.

При неудачных попытках в регистре SSC0_SR бит TXSYN=0, то есть передатчик I2S не синхронизировался.

Попробовал в качестве исходной частоты для интерфейса использовать частоту на выводе TK. Для этого сделал кодек ведущим и сформировал у него на выходе TK нужную частоту ( 8000 * 16 * 1 = 128 кГц). Интерфейс тоже не запустился. Использую кодек tlv320aic3100.

В связи с этим три вопроса:

1) Что я делаю не так в исходном варианте (процессор - ведущий)? Исходная частота делится в нужное количество раз, интерфейс конфигурируется правильно, иначе бы вообще не запускался.

2) Когда ведущий - кодек, нужно ли мне кроме TK настраивать TF как выход?

3) Нужно ли мне в PIO настраивать TK (и, возможно, TF) как входы? В настройках интерфейса указал, что чаастоту передатчика беру с вывода TK.

У кого-нибудь был опыт работы с I2S? Помогите разобраться, пожалуйста.

Ссылка на комментарий
Поделиться на другие сайты

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

В исходном варианте (процессор - ведущий) I2S запустился в следующих конфигурациях:

8 кГц, 8 бит на отсчёт, 2 канала;

8 кГц, 16 бит на отсчёт, 2 канала;

8 кГц, 32 бит на отсчёт, 1 канал.

Видимо, дело в соотношении длины отсчёта, количества каналов и разрядности интерфейса.

Второй вариант мне подходит. Остался вопрос - данные левого и правого каналов идут отдельными отсчётами (2 по 16 бит) или одним длинным (32 бит), а кодек сам их разбирает?

Ссылка на комментарий
Поделиться на другие сайты

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

Присоединяйтесь к обсуждению

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

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

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

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
×
×
  • Создать...