Можно ли использовать камеру мобильного

Запускаем камеру от телефона, или что делать, когда ничего не получается?

Лет восемь назад работал я в одном… а в прочем, не важно где. Делали мы там всякие разные интересные вещи. В том числе занимались системами технического зрения для роботов. Роботы были немного маленькие. И если привод для них маленький сделать не было для нас особой проблемой, то вот сделать миниатюрную цифровую камеру, которая не была бы размером с половину робота, было трудно (когда же мы наконец похороним PAL в таких разработках и везде будет цифра?). Если вам любопытно узнать, чем же всё закончилось, прошу под кат!

Небольшой дисклеймер. С описываемых событий прошло уже достаточно лет, результаты работы не представляют никакого коммерческого интереса (ведь так, товарищ майор?), поскольку повторить полностью сейчас всё это невозможно из-за устаревания элементной базы, теперь можно рассказать, как молодой инженер искал решение проблемы и к чему всё это привело.

Изначально у нас был микропроцессор PXA300, в который втыкался SoC, от тогда еще Aptina, типа MT9D131 (JPEG сразу на параллельном выходе), но всё это потребляло много, а смысла в таком монстре было мало.

Проблема звучала просто — робот привязан к компьютеру проводом на 100 мегабит. Оператор должен видеть цветную картинку хотя бы 640х480 в целых 15 FPS. Ставить в него камеру, которая гонит параллельный поток в XScale, в котором потом происходит тупое складывание картинки в буфер и передача кадра по сети, показалось слишком расточительным (ну серьезно, целый линукс на борту только чтобы перекладывать байты из одного интерфейса в другой?). Особенно учитывая целевое разрешение камеры. Нужно было решение проще. Плюс существенные ограничения по габаритам не позволяли поставить даже самый маленький объектив типа М12, он был просто конских размеров вместе с держателем.

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

В результате творческого поиска меня заинтересовали камеры мобильных телефонов, которые были модульными, стоили как блохи (это выяснилось уже позднее) и теоретически закрывали все наши хотелки. Вопрос был только в том, как такую камеру подключить и получить с неё картинку. Я начал с изучения доступных на рынке мобильных телефонов и конкретно того, какие параметры обеспечивают камеры в них. Сразу стало понятно, что принципиально есть два типа таких камер — модули с линзами с гибко-жесткой частью, которые заточены под конкретный конструктив телефона:

,

и модули, вставляющиеся в так называемые кроватки, которые выглядели наиболее перспективно:

реальный модуль,

кроватки на любой вкус.

Также удалось узнать, что есть такая штука как SMIA. Довольно быстро я нашел всю утекшую в сеть документацию на стандарт и стал его изучать. Оказалось, что есть три типоразмера модулей:

и по конструктиву нам подходит самый маленький — SMIA65.

Поиск нормальных брендовых камер ни к чему адекватному не привел. Искать такую дичь у китайцев я еще не умел, а нормальные европейцы типа ST хоть и заявляли о том, что производят подобные модули (и даже документацию на которые можно было скачать без регистрации и смс), продавать свободно заинтересованной публике не желали. Обращение в наше представительство ST не помогло, и пришлось продолжать копать.

Слава ремонтникам мобильников! Схемы, платы, фотки! У них есть всё. После изучения документации и сопоставления доступных для покупки телефонов и запчастей выбор пал на камеру от Nokia 5250.

Сферическая нокия в вакууме.

Симбиан, все дела. Я даже качал торрентом какие-то дикие исходники этой чудесной операционки, в попытке найти готовый драйвер для камеры. Но, увы, тогда моих способностей на это не хватило. Опять пришлось копать глубже.

Читайте также:  Можно ли использовать соевый соус для жарки

Ох, какой же наивный я был. Это сейчас, пройдя весь путь от и до, я понимаю, что можно было существенно сократить время разработки, заказывая нормальные платы на нормальном производстве (правда, с оплатой тогда потенциально были некоторые проблемы, а ручки чесались сделать здесь и сейчас). Когда там появился JLCPCB или PCBWay? А тогда только ЛУТ на фольге, хлорное железо и два дня на всё про всё.

al Integrity? Вы делали гигабитные дифпары на двустороннем миллиметровом текстолите из платана лутом? А я делал. Даже импеданс считал.

0.5.2.

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

Экспериментировал с паяльной маской, даже сделал несколько плат. Одну успешно запорол, пропаяв её при помощи флюса ТАГС (ха-ха, какая ирония. Сейчас на сайте чипдипа написано про остаточное сопротивление. Эх, эту бы надпись тогда). На той плате ничего нормально не работало, даже источники питания. Между дорожками, которые ну никак не могли быть связаны, всегда присутствовало от десятков до сотен килоом.

Причем плату после пайки мыл в семи водах. Поначалу я думал, что что-то успешно спалил. Начал отпаивать источники питания и всякую обвязку. Замыкания не проходили. Кончилось всё тем, что отпаял с платы вообще всё. Замыкания остались. Сделал вывод, что дело во флюсе, который затёк под маску и не вымылся вообще ничем. После этого я перестал делать платы с маской сам и паять их с флюсом ТАГС.

Но камера — это еще полбеды. Надо же было чем-то принимать последовательный сигнал и разворачивать его в параллельный, чтобы запихнуть в STM32F217 (BlackFin? Не, не слышали. К моменту описываемых событий я прочно состоял в секте стм-оводов и конфигурил клоки через только появившийся экселевский файлик (кубоводы, привет!)). Да-да, четырехсотых стм-ок тогда еще не было (хорошо, хорошо, они только появились), и я успешно использовал кит от стартеркита на двухсотой серии. Опять же в результате длительного поиска и изучения рынка оказалось, что пути ровно два. Либо брать лэттисовскую плисину, для которой был апноут по преобразованию CSI в PCAM (так и не нашел его из 2012 года у себя в архиве, но точно помню, что был такой), либо покупать STSMIA832 (забавно, ST выпилили свою доку на преобразователь с сайта. У них теперь можно только апноутом разжиться.) и учиться паять BGA. Поскольку пайка была мне ближе и знакомство с потрохами плисов не входило в планы, да и сроки откровенно поджимали, я обзавелся несколькими микросхемами и купил готовые переходники с TFBGA25 в DIP (и да, макет был собран на беспаечной макетке и даже как-то работал).

Собственно, схема десериализатора совершенно банальна (не переживайте, ГОСТом тут и не пахнет, с тех пор я научился рисовать схемы посимпатичнее).

Схема, да.

Видите красные площадки? Это площадки подключения переходника из TFBGA25 в DIP.

Плата.

Но вернемся к камере. Чем прекрасна SMIA? Да тем, что поначалу казалось, что всё просто.

Красота же?

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

Такие подробности да в каждый документ бы!

Пока я занимался всем этим, SMIA_al_specification_1.0.pdf стал моей настольной брошюркой, зачитанной до дыр.

Но, чу, колченогое подобие драйвера (ах, какое громкое слово для заголовочного файла с несколькими функциями записи-чтения регистров камеры) написано, а в память микроконтроллера почему-то никакие байтики не падают. Хотя модуль через I2C успешно читается и записывается. О, сколько раз я думал, что неправильно сконфигурировал клоки или пропустил какую-то команду. Результата не было. Тогда я подумал, что хватит биться головой об стенку, надо делать что-то адекватное тому тупику, в который я угодил. Откуда я взял камеру? Правильно, из телефона. Телефон умеет показывать видео и делать фотографии с модуля? Умеет. Значит нужно тело на опыты. Драматичная нет история покупки донора для опытов лежит здесь.

Читайте также:  Можно ли использовать фольгу в мультиварке поларис

Как бы там ни было, самым сложным было подпаяться к клоку и данным с модуля.

Ножки у кроватки под стенками, понимаешь.

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

Вы тоже заметили строки с вопросиками, которыми я пометил запись непонятно чего непонятно куда (пакеты 45-50)? Эти странные регистры, не описанные в, казалось, незыблемой документации (кто ж знал, что в Manufacturer Specific Registers — [0x3000 — 0x3FFF] тоже надо что-то писать). Ну а дальше всё было очевидно. Пишем это непонятно что в непонятно куда и вуа-ля!

first_picture_ever.png

К сожалению не помню, есть ли тут дебайеризация (хм, J = demosaic(I,’grbg’); подсказывает, что есть) и если есть, то всё ли сделано правильно. Как и на втором кадре:

Камера лежала на боку.

Если повернуть голову набок, то можно прочитать 95% чего-то, рассмотреть рёбра какого-то радиатора, лежавшего на столе, и даже попытаться прочитать пароли на листочках с магнитной доски.

Почему всё такое зеленое? А пёс его знает. Этим вопросом уже занимался нормальный адекватный программист (Миша, привет!), который прикручивал эту систему к LwIP и проклинал меня за маленький объем SRAM и малую скорость 217-го (120МГц всего), который еле успевал перекладывать байты. По его словам, надо было просто правильно выставить усиление цветов каналов.

А дальше было дело техники. Нарисовать нормальную схему:

Ещё одна схема.

И сделать нормальную плату, которая показана на КДПВ.

Плата, да.

В производство, собственно, ушел вариант транслятора на отдельной платке (пришлось дорожки по 75мкм делать), чтобы не удорожать производство материнки, куда это всё напаивалось.

Времени было на всё угрохано больше года. Сейчас это кажется диким и ужасно непродуктивным. Наверняка, есть много людей, проделавших бы подобное за пару месяцев. Но я был один, в коллективе никто таким не занимался, интернеты упорно молчали, совета просить было не у кого. Но опыт есть опыт. Я ни сколько не жалею о потраченном времени. Полученные знания бесценны! Предполагаю, подобным образом можно раскурить многие другие модули, которые всё еще ставятся в телефоны, ведь, по сути, никакой особой магии в них нет. Знай себе записывай правильные байтики в правильные регистры да трассировку корректную делай.

А вы как думаете?

Источник

Тема: Вторичное использование камер мобильных телефонов

  1. 12.07.2008, 10:03 #1

    Без позывного

    Привет Всем,у моего товарища один гений использовал видео камеру 0.3мПс от моб.телефона в качестве камеры наблюдения.Как он это сделал естественно молчит,но может сделать это за деньги и мне,но я тоже мог бы это сделать — зная как именно.У меня есть телефон с убитым экраном(SE К300ї).Помогите разобраться,самому же хочется сделать.За рабочий совет с меня пиво!

  2. 12.07.2008, 11:33 #2

    гораздо проще купить нормальную камеру от профессионального видеонаблюдения.

    к примеру цветная стоит 3 тыщи рублей.

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

    это надо лазить по европейским сайтам — там есть такие умельцы, но как это все эти сайты найти мне неведомо(да и не нужно)

    или выдерни из какого нить разбитого ноута камеру — там usb — никаких проблем и дров не надо.

    у мнея такая к окну приклеена — она шириной с карандаш и длиноой 4 см

    я вот лет 5 назад балдел от экранчиков от сотиков — после месяця поисков наткнулся на сайт где чувак брал цветные экраны и через лпт выводил видео на них.

    Последний раз редактировалось RA3POD; 12.07.2008 в 11:38.

    73. Алексей (RA3POD)

  3. 01.11.2008, 09:25 #3

    Без позывного

    Сообщение от Sylver

    Привет Всем,у моего товарища один гений использовал видео камеру 0.3мПс от моб.телефона в качестве камеры наблюдения.Как он это сделал естественно молчит,но может сделать это за деньги и мне,но я тоже мог бы это сделать — зная как именно.У меня есть телефон с убитым экраном(SE К300ї).Помогите разобраться,самому же хочется сделать.За рабочий совет с меня пиво!

    Если самому хочется сделать, значит и самому надо разбираться. Так будет интереснее.

  4. 30.08.2009, 21:44 #4

    Без позывного

    Мне кажеться, что лучше обойтись без самопала и купить нормальную камеру

  5. 04.11.2009, 14:19 #5

    Без позывного

    ага))) поддерживаю)) а то кучу времени потратите- и в пустую))

  6. 10.07.2010, 17:48 #6

    Без позывного

    А как же жажда познания непознанного?

  7. 11.07.2010, 00:29 #7

    Сообщение от bukazavr

    А как же жажда познания непознанного?

    Жажда, это по стеллажам в библиотеке, а на форуме это халява.

  8. 11.07.2010, 00:40 #8

    Жа там на камерах ничего страшного нет, протоколы описаны.

    Сиди да реализуй.

    Вон на те же MTK-шные процессоры посмотрите, там даже в периферии для камер все сделано…

    Для человека с молотком любая проблема кажется гвоздем.

    Слава богу, теперь уже БЫВШИЙ член СРР, 73!

  9. 11.07.2010, 00:43 #9

    и где почитать? или ключевые слова хотя бы

  10. 11.07.2010, 10:14 #10

    Без позывного

    Сообщение от Afox

    Жажда, это по стеллажам в библиотеке, а на форуме это халява.

    С чего это вдруг халява??? И что за сравнение с библиотекой?

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

  11. 11.07.2010, 12:09 #11

    Сообщение от bukazavr

    С чего это вдруг халява???

    [skip]

    Сообщение от bukazavr

    это ж моск напрягать нуна

    Ну, и? Где я был неправ?

  12. 18.06.2011, 00:11 #12

    Без позывного

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

  13. 18.06.2011, 00:40 #13

    очнулся………..

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

    для элит програмеров — это на 80% игрушка для тренировки костей мозга.

    для коммерческих устройств имхо гораздо проще взять тупо IP камеру и на чипе линух поднять, а там уж гуляй рука и всё проще и доступнее.

    а камера от сотика гонит потоком с огромной скоростью (12 мегабайт, не путать с битами) сырые данные прямо с матрицы.

    даже арм7 или 9 с таким потоком без аппаратной обработки захлебнется — большинство кустарных проектов построенно на плисинах. и то они тупо перегоняют видео на экранчик.

    так что оно как бы не надо — убить кучу времени на программирование на вхдл, что делается в аналоговом виде за 5 минут двумя проводами = камера + телевизорик с аналоговой матрицей.

    Последний раз редактировалось RA3POD; 18.06.2011 в 00:44.

    73. Алексей (RA3POD)

  14. 18.06.2011, 00:51 #14

    Сергей (RN3DDW)

    Настоящий радиолюбитель, открыв спичечный коробок и обнаружив там спички, смотрит на них С УДИВЛЕНИЕМ

  15. 19.06.2011, 22:37 #15

    QRP

    https://o-d-v.nm.ru/tel_cam/index.htm Про камеру от сотового.

    Данная страница посвящена описанию принципа работы и применению камеры от сотового.

Похожие темы

  1. Ответов: 17

    Последнее сообщение: 22.05.2016, 11:03

  2. Ответов: 13

    Последнее сообщение: 16.04.2007, 17:58

  3. Ответов: 10

    Последнее сообщение: 07.10.2006, 18:36

  4. Ответов: 0

    Последнее сообщение: 08.09.2006, 10:50

Читайте также:  Можно ли ковролин использовать вместо паласа

Ваши права

  • Вы не можете создавать новые темы
  • Вы не можете отвечать в темах
  • Вы не можете прикреплять вложения
  • Вы не можете редактировать свои сообщения

Правила форума

Источник