Jump to content
Вячеслав_НС

какую библиотеку использовать для i2c в atmel studio 7

Recommended Posts

Здравствуйте ! подскажите , какую лучше библиотеку использовать (и где ее взять) для управления i2c atmega8 в atmel studio 7  .  задача - управлять atmega8 по i2c ,  цап  PCF8591T .

понимаю , в интернете много примеров и библиотек , но хотелось бы пример максимально простой и точно рабочий . т.к. пока что все мои попытки не привели к успеху ... то Atmel Studio 7 при компиляции ругается на несуществующий файл ( к примеру - "stream.h") при использовании библиотеки i2c , то еще какие то грабли .

Share this post


Link to post
Share on other sites

Всегда применял библиотечку http://homepage.hispeed.ch/peterfleury/doxygen/avr-gcc-libraries/group__pfleury__ic2master.html от Peter Fleury, и ни разу не был разочарован.

Кстати, и его библиотека поддержки символьных ЖКИ тоже не подводила ни разу.

Share this post


Link to post
Share on other sites

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

#define F_CPU 1000000 
#include <stdlib.h>
#include <avr/io.h>
#include <util/delay.h>
                                                                                     //#define PCF8591 0x48  // адр 000
//*** ИНИЦИАЛИЗАЦИЯ ШИНЫ TWI ***/
void TWI_Init(void)
{
    // Установка тактовой частоты F_scl  
     //F_scl = F_cpu/(16 + 2* TWBR* 4^TWPS) = 1000000/(16+2*2*4^3) = 1000000/272 = 3,7кГц
    TWBR = 2;
    TWSR = (1 << TWPS1)|(1 << TWPS0);
    //TWSR = ((0 << TWPS0)|(0 << TWPS1));
    TWCR |= (1 << TWEN);            // Разрешение работы TWI-модуля
}


/*** ЗАПУСК TWI ***/
void TWI_Start(void)
{
    TWCR = (1<<TWINT) | (1<<TWSTA) | (1<<TWEN);
    while(!(TWCR & (1<<TWINT)));    
}

/*** ОСТАНОВКА TWI ***/
void TWI_Stop(void)
{
    TWCR = (1<<TWINT) | (1<<TWEN) | (1<<TWSTO);
    while(TWCR & (1<<TWSTO));        // Ожидание завершения передачи условия СТОП
}

uint8_t TWI_WriteByte(uint8_t data)
{
    TWDR = data;                    // Загрузка адресов или данных в TWDR
    TWCR =   (1 << TWEN)            // Включение TWI
    |(1 << TWINT);            // Сброс флага TWINT (!!!)
    while(!(TWCR & (1 << TWINT)));    // Ожидание завершения передачи данных
}
/*** ПЕРЕДАТЬ ЗНАЧЕНИЕ НА ЦАП ***/
void PCF8591_get(void)
{
    TWI_Start();                    // Запуск TWI
    TWI_WriteByte(0x48);        // Передача адреса устройства
    TWI_WriteByte(0x40);            //включаем цап
    TWI_WriteByte(0xA);            // Записать в цап - "10"
    TWI_Stop();                        // Остановить TWI
    _delay_ms(50);        
    }            

    int main(void)
{
    TWI_Init();    
    while (1)
{
        PCF8591_get;
        _delay_ms(50);
  }
}
 

 

Share this post


Link to post
Share on other sites

Литиевые батарейки Fanso для систем телеметрии и дистанционного контроля

Системы телеметрии находят все более широкое применение во многих отраслях на промышленных и коммунальных объектах. Требования, предъявляемые к условиям эксплуатации приборов телеметрии и, как следствие, источников питания для них, могут быть довольно жесткими. Fanso предоставляет широкую линейку продукции, рассчитанной на различные условия эксплуатации, что позволяет подобрать батарейку для каждого конкретного применения, в том числе и для устройств телеметрии.

Подробнее

#define F_CPU 8000000UL 
#include <stdlib.h>
#include <avr/io.h>
#include <util/delay.h>

//*** ИНИЦИАЛИЗАЦИЯ ШИНЫ TWI ***/
void TWI_Init(void)
{
    // Установка тактовой частоты F_scl  = 100 кГц
    TWBR =32;
    TWSR &= (~((1<<TWPS1)|(1<<TWPS0)));
    TWCR |= (1 << TWEN);            // Разрешение работы TWI-модуля
}


/*** ЗАПУСК TWI ***/
void TWI_Start(void)
{
    TWCR = (1<<TWINT) | (1<<TWSTA) | (1<<TWEN);
    while(!(TWCR & (1<<TWINT)));
    TWDR = 1001000; // передача адреса модуля PCF8591 в шину TWI
    TWCR=(1<<TWINT)|(1<<TWEN);
    while(!(TWCR & (1<<TWINT)));
}

/*** ОСТАНОВКА TWI ***/
void TWI_Stop(void)
{
    TWCR = (1<<TWINT) | (1<<TWEN) | (1<<TWSTO);
    while(TWCR & (1<<TWSTO));        // Ожидание завершения передачи условия СТОП
}
/***ПЕРЕДАЧА ДАННЫХ В TWI***/
void TWI_WriteByte(uint8_t data)
{
    TWDR = data;                    // Загрузка данных в TWDR
    TWCR=(1<<TWINT)|(1<<TWEN);
    while(!(TWCR & (1 << TWINT)));    // Ожидание завершения передачи данных
}
/*** ПЕРЕДАТЬ ЗНАЧЕНИЕ В PCF8591 ***/
void PCF8591_get(void)
{
    TWI_Start();                // Запуск TWI
    TWI_WriteByte(0x40);        //включаем цап
    TWI_WriteByte(100);            // запись в ЦАП значения 100
    TWI_Stop();                    // Остановить TWI
}            

    int main(void)
{
    TWI_Init();    
    while (1)
{
        PCF8591_get;
       _delay_ms(50);
  }
}

Share this post


Link to post
Share on other sites

Join the conversation

You are posting as a guest. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Loading...

  • Similar Content

    • By Максим123456789
      делаю диплом, в схеме у меня микроконтроллер PIC16F688 и мне нужно его заменить на ATmega. Не могу найти похожий
    • By Вячеслав_НС
      помогите разобраться с кодом .(послать значение по шине TWI на ЦАП PCF8591) не работает в протеусе ...
      #define F_CPU 8000000UL 
      #include <stdlib.h>
      #include <avr/io.h>
      #include <util/delay.h>
      //*** ИНИЦИАЛИЗАЦИЯ ШИНЫ TWI ***/
      void TWI_Init(void)
      {
          // Установка тактовой частоты F_scl  = 100 кГц
          TWBR =32;
          TWSR &= (~((1<<TWPS1)|(1<<TWPS0)));
          TWCR |= (1 << TWEN);            // Разрешение работы TWI-модуля
      }

      /*** ЗАПУСК TWI ***/
      void TWI_Start(void)
      {
          TWCR = (1<<TWINT) | (1<<TWSTA) | (1<<TWEN);
          while(!(TWCR & (1<<TWINT)));
          TWDR = 1001000; // передача адреса модуля PCF8591 в шину TWI
          TWCR=(1<<TWINT)|(1<<TWEN);
          while(!(TWCR & (1<<TWINT)));
      }
      /*** ОСТАНОВКА TWI ***/
      void TWI_Stop(void)
      {
          TWCR = (1<<TWINT) | (1<<TWEN) | (1<<TWSTO);
          while(TWCR & (1<<TWSTO));        // Ожидание завершения передачи условия СТОП
      }
      /***ПЕРЕДАЧА ДАННЫХ В TWI***/
      void TWI_WriteByte(uint8_t data)
      {
          TWDR = data;                    // Загрузка данных в TWDR
          TWCR=(1<<TWINT)|(1<<TWEN);
          while(!(TWCR & (1 << TWINT)));    // Ожидание завершения передачи данных
      }
      /*** ПЕРЕДАТЬ ЗНАЧЕНИЕ В PCF8591 ***/
      void PCF8591_get(void)
      {
          TWI_Start();                // Запуск TWI
          TWI_WriteByte(0x40);        //включаем цап
          TWI_WriteByte(100);            // запись в ЦАП значения 100
          TWI_Stop();                    // Остановить TWI
      }            
          int main(void)
      {
          TWI_Init();    
          while (1)
      {
              PCF8591_get;
             _delay_ms(50);
        }
      }
    • By Антон Плюшкин
      В общем есть небольшая тривиальная задача - сделать свитюльку. Контроллер управляет светодиодиками, цвета меняются, людишки довольны.
      Схема проста: Attiny44a -> 2n3904 x3 -> RGB-светодиод.
      Собрал, протестил, всё норм, но!
      Как только в коде я использую функцию задержки - _delay_ms (util/delay.h) - контроллер повисает!
      #define F_CPU 16000000UL #include <avr/io.h> #include <util/delay.h> int main(void) { // Input/Output Ports initialization // Port A initialization // Function: Bit7=Out Bit6=Out Bit5=In Bit4=In Bit3=In Bit2=In Bit1=In Bit0=In DDRA=(1<<DDA7) | (1<<DDA6) | (0<<DDA5) | (0<<DDA4) | (0<<DDA3) | (0<<DDA2) | (0<<DDA1) | (0<<DDA0); // State: Bit7=0 Bit6=0 Bit5=T Bit4=T Bit3=T Bit2=T Bit1=T Bit0=T PORTA=(0<<PORTA7) | (0<<PORTA6) | (0<<PORTA5) | (0<<PORTA4) | (0<<PORTA3) | (0<<PORTA2) | (0<<PORTA1) | (0<<PORTA0); // Port B initialization // Function: Bit3=In Bit2=Out Bit1=In Bit0=In DDRB=(0<<DDB3) | (1<<DDB2) | (0<<DDB1) | (0<<DDB0); // State: Bit3=T Bit2=0 Bit1=T Bit0=T PORTB=(0<<PORTB3) | (0<<PORTB2) | (0<<PORTB1) | (0<<PORTB0); // Timer/Counter 0 initialization // Clock source: System Clock // Clock value: 16000,000 kHz // Mode: Phase correct PWM top=0xFF // OC0A output: Non-Inverted PWM // OC0B output: Non-Inverted PWM // Timer Period: 0,031875 ms // Output Pulse(s): // OC0A Period: 0,031875 ms Width: 0 us // OC0B Period: 0,031875 ms Width: 0 us TCCR0A=(1<<COM0A1) | (0<<COM0A0) | (1<<COM0B1) | (0<<COM0B0) | (0<<WGM01) | (1<<WGM00); TCCR0B=(0<<WGM02) | (0<<CS02) | (0<<CS01) | (1<<CS00); TCNT0=0x00; OCR0A=0x00; OCR0B=0x00; // Timer/Counter 1 initialization // Clock source: System Clock // Clock value: 16000,000 kHz // Mode: Ph. correct PWM top=0x00FF // OC1A output: Non-Inverted PWM // OC1B output: Disconnected // Noise Canceler: Off // Input Capture on Falling Edge // Timer Period: 0,031875 ms // Output Pulse(s): // OC1A Period: 0,031875 ms Width: 0 us // Timer1 Overflow Interrupt: Off // Input Capture Interrupt: Off // Compare A Match Interrupt: Off // Compare B Match Interrupt: Off TCCR1A=(1<<COM1A1) | (0<<COM1A0) | (0<<COM1B1) | (0<<COM1B0) | (0<<WGM11) | (1<<WGM10); TCCR1B=(0<<ICNC1) | (0<<ICES1) | (0<<WGM13) | (0<<WGM12) | (0<<CS12) | (0<<CS11) | (1<<CS10); TCNT1H=0x00; TCNT1L=0x00; ICR1H=0x00; ICR1L=0x00; OCR1AH=0x00; OCR1AL=0x00; OCR1BH=0x00; OCR1BL=0x00; // Timer/Counter 0 Interrupt(s) initialization TIMSK0=(0<<OCIE0B) | (0<<OCIE0A) | (0<<TOIE0); // Timer/Counter 1 Interrupt(s) initialization TIMSK1=(0<<ICIE1) | (0<<OCIE1B) | (0<<OCIE1A) | (0<<TOIE1); // External Interrupt(s) initialization // INT0: Off // Interrupt on any change on pins PCINT0-7: Off // Interrupt on any change on pins PCINT8-11: Off MCUCR=(0<<ISC01) | (0<<ISC00); GIMSK=(0<<INT0) | (0<<PCIE1) | (0<<PCIE0); // USI initialization // Mode: Disabled // Clock source: Register & Counter=no clk. // USI Counter Overflow Interrupt: Off USICR=(0<<USISIE) | (0<<USIOIE) | (0<<USIWM1) | (0<<USIWM0) | (0<<USICS1) | (0<<USICS0) | (0<<USICLK) | (0<<USITC); // Analog Comparator initialization // Analog Comparator: Off // The Analog Comparator's positive input is // connected to the AIN0 pin // The Analog Comparator's negative input is // connected to the AIN1 pin ACSR=(1<<ACD) | (0<<ACBG) | (0<<ACO) | (0<<ACI) | (0<<ACIE) | (0<<ACIC) | (0<<ACIS1) | (0<<ACIS0); ADCSRB=(0<<ACME); // Digital input buffer on AIN0: On // Digital input buffer on AIN1: On DIDR0=(0<<ADC1D) | (0<<ADC2D); // ADC initialization // ADC disabled ADCSRA=(0<<ADEN) | (0<<ADSC) | (0<<ADATE) | (0<<ADIF) | (0<<ADIE) | (0<<ADPS2) | (0<<ADPS1) | (0<<ADPS0); unsigned char VL_OCR0A = 0, VL_OCR0B = 0, VL_OCR1A = 0; OCR0A = 0; OCR0B = 0; OCR1A = 0; while(1) { _delay_ms( 100 ); VL_OCR0A = VL_OCR0A + 1; VL_OCR0B = VL_OCR0B + 1; VL_OCR1A = VL_OCR1A + 1; if( VL_OCR0A >= 250 ){ VL_OCR0A = 0; } if( VL_OCR0B >= 250 ){ VL_OCR0B = 0; } if( VL_OCR1A >= 250 ){ VL_OCR1A = 0; } OCR0A = VL_OCR0A; OCR0B = VL_OCR0B; OCR1A = VL_OCR1A; } } Т.е. если указать задержку в начале цикла, то светодиод не светится вообще.
      Если задержку убрать - светодиод немного подсвечивает всеми цветами.
      while(1) { _delay_ms( 100 ); // <--- ЗАДЕРЖКА --- VL_OCR0A = VL_OCR0A + 1; VL_OCR0B = VL_OCR0B + 1; VL_OCR1A = VL_OCR1A + 1; if( VL_OCR0A >= 250 ){ VL_OCR0A = 0; } if( VL_OCR0B >= 250 ){ VL_OCR0B = 0; } if( VL_OCR1A >= 250 ){ VL_OCR1A = 0; } OCR0A = VL_OCR0A; OCR0B = VL_OCR0B; OCR1A = VL_OCR1A; } Где я накосячил?
      З.Ы.: Замечаний по поводу оптимизации кода, излишних переменных и п.р. прошу не писать - изощряюсь как могу ибо не пойму почему не работает
    • By LegionKC
      Добрый день.
      Экспериментирую с платой TP4056 и MK ATmega8, конкретнее - пытаюсь собрать простенькое зарядное устройство с выводом параметров при зарядке/разрядке на АЦП МК. Для измерения тока нашел ACS712. Думаю, что получится выводить ток при зарядке (т.е. когда идет питание на TP4056 и нагрузка отключена) и при разрядке (питание выключено, нагрузка подключена). Нагрузка - резистор. Возникла проблема с измерением напряжения на АКБ. Вернее, проблема с отсутствием идей как это сделать. Может какую-нибудь схему делителя напряжения нужно сделать? Прошу помочь советом. Схему из пэинта прилагаю.
      Спасибо.
       

    • By Cheshire Cat
      Здравствуйте, только начинаю изучать программирование мк. Я уже задавал этот вопрос в моих прошлых схемах мне отвечали что-то типа "любой стабилизрованый источник постоянного напряжения", или кидали схему такого источника. Можно назвать мне конкретное устройство? В общем то что я смогу забить в гугл и приписать купить. 

      Я уже больше двух месяцев жду пока мне придут с aliexpress детали для маленького лабараторного блока, но этот вариант может разбиться о кривизну моих рук.  Хочу просто купить такой источник и наконец заняться непосредственно МК. 
  • Сообщения

    • Абсолютный, полный аналог искать нет смысла, нужно смотреть, какой функционал используется в исходной схеме и подбирать замену исходя из этого. А в курсе, что под другой МК ещё и прошивку придётся писать с нуля?
    • Окончание попыток сборки "качественных" УНЧ у меня состоялось в тот день, когда стробоскопом осветил этот самый диффузор - полное совпадение с поверхностью воды, которую обдувают вентилятором. И это при синусоидальном токе в обмотке динамика! Теория и математическая модель работы диффузора в корне отличается от практически визуально наблюдаемой картинки. Уважаемые ПРОФИ в области конструирования высококачественных УНЧ, Ваши схемы и электроника создают, вероятно, только электрически качественный ток. А как же конечный результат или цель Ваших конструкций?  Некоторый положительный эффект улучшения качества звука возможен при ЭМОС (электромеханической обратной связи) по сигналу перемещения диффузора названного динамика.   Кроме критики могу добавить следующее, резкое улучшение качества звука у меня получилось при подключении к усилителю маленьких динамиков с диффузором из алюминия диаметром 40-50 мм. Для воспроизведения низких частот желательно соединить их параллельно-последовательно, что даёт возможность согласования по необходимому значению требуемого электрического сопротивления, несколько динамиков на одной плоскости.  
    • Самое интересное - каким боком тут может помочь ардуина?
    • А ссылка, что Бориска дал, действительно хорошая. Буквально каждый узел разобран по косточкам.
    • 5. Две одинокие ромашки на маковом поле. Их УЗД маскируется уровнем всего остального. Ведь фильтрация у шириков тю-тю а они тянут до 16кгц с выраженным пиком 5кгц. 6. При совокупности всех факторов пародия и есть...
    • Перемотал дроссель. литцендрат - провод 0,25мм - 13 жил  -- 21 виток. Всё равно греется.. Когда на выходе на динамики значение переменки превышает 20 вольт - дроссель начинает зудеть.. потиху. на 30 вольтах очень даже ощутимо зудит-пищит.. Максимум показал 34 вольта пока был холодный. Нагрелся - максимум стал 32 вольта с копейками. Когда вход зашунтирован  - на выходе 0,4 вольта постоянки (я так понимаю, что это и есть остаток несущей). Поднимаю громкость - вырастает до 0,6 в гдето, поднимаю до максимума - дроссель начинает зудеть  -  а постоянка резко уходит в минусовые показатели...
    • 1. Для чего снято и выложено подобные демо мы прекрасно понимает...  2. Не имеет значения. Вообще следует головке отдавать тот диапазон, где её ачх максимально линейна, отрезав лишнее. Вам бы справочник по акустике почитать а не форумы...  3. Сможете аргументировать, что групповой излучатель не может состоять из группы разнотипных излучателей/ас? 4. Сколько людей столько мнений. Но держу пари, большинство  категорически против подобных щитов, роликов и мнений их авторов.
  • Покупай!

×
×
  • Create New...