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

Программатор Pickit2-Помогите Разобраться.


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

Купил у китайцев http://ru.aliexpress.com/item/PIC-ICD2-PICKit-2-PICKIT-3-programming-adapter-PICKIT2-PICKIT3-universal-programmer-seat/32300343983.html?recommendVersion=1

При запуске ПРОГРАММАТОРА пишет -PICkit 2 connected ID=OIHoss? :unknw:

Пробовал читать и писать EEPROM не пишет и не читает . :angry:

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

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

а откуда программатор?

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

Потыкайте галку питания, тоже помогает

Изменено пользователем mail_robot

Нужно делать то, что нужно. А то, что не нужно, делать не нужно. (С) Винни Пух

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

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

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

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

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

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

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

..При запуске ПРОГРАММАТОРА пишет -PICkit 2 connected ID=OIHoss? :unknw:

Вы можете задать PicKit2 любое имя, это - не показатель, если это - полный клон, конечно ( по компонентам похоже, что полный ):

www.pickit2.ru/doku.php/разные.хитрости

А то, что он не пишет и не читает EEPROM, то это ещё ни о чём не говорит. Может чип мёртвый, может подключен неправильно, может этот чип не поддерживается. Попробуйте на гарантировано живом и поддерживаемом PIC-е.

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

Проверял EEPROM в другом простом всё пишет и читает.Пика пока не попробовать в пути.А на русском к нему программа есть?

Как на чип программируемый напряжение подаётся во время программирования и ли постоянно?

Так подключал

post-83917-0-87443300-1431696701_thumb.png

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

Прошьет без проблем ,только ПО установить правильное ,я долго мучался с программным ,где то нашел и установил ,не помню. За то сейчас проблем нет. Пики шьет практически все ,слышал что есть прошива и на епром для данного программатора ,но не стал вдаваться в подробности за ненадобностью. данной функции. На работе есть универсал.

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

...только ПО установить правильное...

Это как??? Фирменная оболочка для PicKit2 от Microchip чем не устроила? В ней есть всё. И для прошивки некоторых EEPROM в том числе. Или это слишком просто? Кто-нибудь мне объяснит, почему было-бы не взять хотя-бы это:

http://ru.aliexpress.com/item/Free-shipping-PICKIT2-Programmer-PIC-ICD2-PICKit-2-Programming-Adapter-Universal-Programmer-seat/1291727442.html

А не неизвестное поделие с ZIF-панелью?

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

Для начала надо настроить программу. Для этого выполни следующее;

- подключи программер шнуром к USB, вставь микроконтроллер и запусти программу

- в меню "Device Family" выбери "Midrange" и в вывалившемся меню - "Standard"

- в меню "Programmer" поставь галочки на "Verify on Write" и "Clear Memory Buffers on Erase"

- в меню "Tools" поставь галочку на "Fast Programmer", а в "Target VDD Source" выбери "Auto-Detect" и сдесь же выбери в

"Display Unimplemented Config Bits" "As read or imported"

- в меню "View" поставь галочку на "Single Window"

Теперь, в меню "File" выбери "Import HEX" и найди нужный файл прошивки. Его содержимое и настройки появятся в окнах программы.

Выставь при необходимости напряжение питания 5 V стрелочками в окне программы. Сдесь же должен появиться тип микроконтроллера (Device:)

Жмем "Write" и наслаждаемся процессом.

Я использую программу версии 2.61. Для нормальной работы программатора необходима программа dotnetfx версии не ниже 2.

Она стартует с диска к программатору.

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

...Для начала надо настроить программу...

Дополнительно стОит выставить галочку на пункте меню Use Vpp first. Нужно для того, если ранее чип был прошит с конфигурацией на внутренний осциллятор и настройкой MCLR I\O выводом.

...Я использую программу версии 2.61. Для нормальной работы программатора необходима программа dotnetfx версии не ниже 2.

Полная инсталляция оболочки PicKit2 v2.61 всё ставит сама.

P.S. При правильных настройках и подключении оболочка сама найдёт подсоединённый чип и без hex-файла. Для внутрисхемного программирования увидел стандартную майкрочиповскую SIL-гребёнку с торца ZIF-разъёма.

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

Как повезёт. :) "Семь раз отмерь" никто не отменял. :) Старые PIC-и выдерживали выдерживали многое: переполюсовку, некоторые даже от 12В запитывали и всё, как-будто, работало. Современные, говорят нежнее, не знаю.

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

Всё есть в документации на PicKit. Подключить EEPROM можно к гребёнке, о которой я выше упоминал, или отследить связи до ZIF-разъёма.

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

Вот здесь: http://www.pickit2.ru много чего полезного по PicKit. Цитата оттуда: "Для получения подробной информации по подключению конкретной микросхемы обратитесь к файлу «PICkit 2 Programmer Readme» (меню Help→Readme)."

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

Перевёл коряво -мне бы схематично посмотреть

Соединения для устройств 11LC --------------------------------------- PICkit 2 Pin 11LC Устройство контактов ( DIP) (2) Vdd! 8 Vcc (3) Земля 4 В пост (6) AUX 5 SCIO! Устройства 11LC может не программировать правильно ниже 3,6 VDD. Это ограничение PICkit 2 AUX IO булавки. Соединения для устройств 24LC --------------------------------------- PICkit 2 Pin 24LC Устройство контактов ( DIP) (2) Vdd! 8 Vcc (3) Земля 4 В пост (5) PGC 6 SCL (приводится в двухтактной) (6) AUX 5 ПДД (требуется подтяжки) 7 WP - инвалидов (GND) 1, 2, 3 вывода Ax Подключение к Vdd или GND за технического описания и установить адрес! Устройства 24LC может не программировать правильно ниже 3,6 VDD. Это ограничение PICkit 2 AUX IO булавки. Соединения для устройств 25LC --------------------------------------- PICkit 2 Pin 25LC Устройство контактов ( DIP) (1) VPP 1 NCS (2) Vdd Vcc 8 (3) Земля 4 В пост (4) 2 SO ПГД (5) PGC 6 СХК (6) AUX 5 С.И. 7 nHOLD - инвалидов (Vdd) 3 ЧПП - инвалидов ( Vdd) Соединения для 93LC устройств --------------------------------------- PICkit 2 Pin 93LC устройств PIN-код (DIP) (1) VPP 1 CS (2) Vdd Vcc 8 (3) GND 5 В пост (4) ПГД 4 DO (5) PGC 2 CLK (6) AUX 3 DI 7 PE - включен (Vdd) 6 'С

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

А зачем там что-то переводить? У PicKit-а функционал ног на разъёме не меняется, а куда подцеплять к памяти на рисунке тоже подробно разжёвано.

1 - Vpp не трогаем, высокое напряжение программирования только для PIC

2 - Vdd - напряжение питания, без комментариев

3 - GND земля, без комментариев

4 - PGD - выход данных для последовательного программирования

5 - PGC - выход тактовой частоты

6 - Aux дополнительный выход, вход данных для последовательного программирования, у некоторых чипов на вход CS.

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

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

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

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

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

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

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

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

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

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

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

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

    • Повторюсь - НЕТ, так как у вас там крутилки, что приведет к искажениям при работе в мостовой схеме.
    • Все верно, вы почти все что нужно сделали.  Только не нужно было добавлять это b=UDR; Сразу после старта сбросить флаг flags = 0; А в основном цикле ждать установки флага FLAG_END_RX. И если он установлен, проверять на совпадение строки в буфере (rx_buf) с вашей строкой (AT+QM \ r \ n .....   .....  AT+MP \ r \ n) При совпадении вызывать выполнение нужного алгоритма.
    • У меня до саба ещё дело не дошло, только сейчас думаю купить амп на полкиловатта, но так можно, при условии, что на входе будет моно, и будет срез частот
    • Про флаг Т: если он не используется в основной программе, а у меня он постоянно в деле. для меня меня отложенная обработка прерывания обычное дело, нужно лишь правильно расставить приоритеты частей программы. И обычное дело: выставляешь частоту задающего генератора побольше, делишь его до получения частоты 1000 Гц каким либо таймером, загоняешь в прерывание с флагом. затем закольцовываешь основную программу с проверкой флага прерывания от таймера 1000Гц. загоняешь программу в Sleep. Получаешь кольцо обработки с образцовым интервалом в 1 мс. После любого прерывания проверяешь флаг от таймера, если он, то сбрасываешь флаг и начинаешь перебирать подпрограммы обработки индикаторов, клавиатуры, и тд. и тп, подпрограммы обработки флагов и др. После окончания обработки всех подпрограмм возвращаешься к Sleep. И так по кольцу. Если происходит прерывание не от таймера, программа выходит из Sleep, проверяется флаг от таймера, если не он (а это не он) обратно к Sleep. В большенстве программ использую этот алгоритм.   GPIOR1 и GPIOR2 в 88 условно можно использовать как флаги, но их адреса больше 0х1Е, на них не распространяются команды cbi, sbi, sbic, sbis, и их сначала нужно загрузить в общий регистр, промодифицировать, и заново сохранить. Эта последовательность длинная, и модифицирует SREG, что сводит на нет работу по сравнению с  классическим GPIOR.
    • @korsaj Сегодня попробовал сделать как ты посоветовал. Получился следующий код. #define F_CPU 7372800UL #define BAUND 9600L #define UBRRL_value (F_CPU/(BAUND*16))-1 #include <avr/io.h> #include <util/delay.h> #include <avr/interrupt.h> #include <stdlib.h> void init_pin(void); #define C_PC0 (~PINC&(1<<PC0)) #define C_PC1 (~PINC&(1<<PC1)) #define LED_1_ON() PORTD|=(1<<PD2) #define LED_1_OFF() PORTD&=~(1<<PD2) #define LED_2_ON() PORTD|=(1<<PD3) #define LED_2_OFF() PORTD&=~(1<<PD3) #define FLAG_END_RX (1<<3) #define FLAG_ERR_RX (1<<4) #define BUF_SIZE 20 char rx_buf[BUF_SIZE]; char buf_index = 0; volatile start=1, flags; char b; ISR(USART_RXC_vect) { b=UDR; if(!(flags & FLAG_END_RX)) { rx_buf[buf_index]=UDR; if(rx_buf[buf_index] == 0x0D) { flags |= FLAG_END_RX; return; } buf_index++; if(buf_index >= BUF_SIZE) { buf_index = 0; flags |= FLAG_ERR_RX; } } } void init_UART() { UBRRL = UBRRL_value; UBRRH = UBRRL_value>>8; UCSRB|=(1<<TXEN); UCSRB|=(1<<RXEN); UCSRC|=((1<<URSEL)|(1<<UCSZ0)|(1<<UCSZ1)); UCSRB|=(1<<RXCIE); sei(); flags = 0; } void send_UART(char value) { while(!(UCSRA&(1<<UDRE))); UDR=value; } int main(void) { init_pin(); init_UART(); while(1) { if (start==1) { _delay_ms(500); send_UART('O'); send_UART('K'); send_UART('!'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); start=0; } if (b == '0') { LED_1_ON(); LED_2_OFF(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('0'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '1') { LED_1_OFF(); LED_2_ON(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('1'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '2') { LED_1_ON(); LED_2_ON(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('2'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '3') { LED_1_OFF(); LED_2_OFF(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('3'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (C_PC0) { send_UART('P'); send_UART('C'); send_UART('0'); send_UART(0x0D); send_UART(0x0A); _delay_ms(250); } if (C_PC1) { send_UART('P'); send_UART('C'); send_UART('1'); send_UART(0x0D); send_UART(0x0A); _delay_ms(250); } } } void init_pin(void) { DDRC = 0b00000000; PORTC = 0b11111111; DDRD |= ((1<<2)|(1<<3)); PORTD &=~ ((1<<2)|(1<<3)); } Ну как сказать всё работает, но вот меня очень интересует приём команд на саму ATMEGA16. Он так и работает только с цифрами. Более ничего корректно принять не получается даже используя таблицу ascii. А мне нужно будет принимать команды и посложней чем просто буквенно - цифровые. Потому как возвращаясь к командам самого плеера там в этих командах хранятся различные данные. Вот примерно так это всё выглядит. AT+QM \ r \ n Запрос режима работы [0: Bluetooth], [1: MP3] AT+M1 \ r \ n Номер текущего файла AT+M2 \ r \ n Общее количество звуковых файлов AT+MD \ r \ n Источник музыки USB или SD Card AT+MT \ r \ n Общее время воспроизведения текущего файла AT+MK \ r \ n Время воспроизведения текущего файла AT+MP \ r \ n Текущее состояние плеера [0]Стоп, [1]Воспроизведение, [2]Пауза К примеру при отправке команды AT+M1 \ r \ n в ответ мы получим M1 + 000002 \ r \ n при этом здесь может быть любое число в hex формате. Мне же нужно каким то образом принять эти данные и обработать их соответствующим образом. Но при этом и нужно учитывать так же что плеер может сам отправить эти данные по началу воспроизведения трека. Вот в этом сейчас и стоит основная задача. Чего я и пытаюсь получить в итоге.
    • Ну тогда дорога к сименсу в гости - они вам какой-нибудь Desigo CC или даже Siematic предложат, тыщ за 10 долларов. Ну и ещё тыщ 5 надо будет отдать за контроллеры и их конфигурирование.   А если попроще - то можно к отечественным MasterSCADA обратиться, либо к WiredBoard - у них не совсем SCADA система, но нормальные контроллеры, довольно просто настраиваются и можно графическую оболочку рисовать.
  • Похожий контент

×
×
  • Создать...