Инструменты пользователя

Инструменты сайта


doc:1201:643.mgul.12013-01_12_01

Различия

Здесь показаны различия между двумя версиями данной страницы.

Ссылка на это сравнение

Предыдущая версия справа и слева Предыдущая версия
Следующая версия
Предыдущая версия
doc:1201:643.mgul.12013-01_12_01 [2017/02/22 21:40]
gotrum
doc:1201:643.mgul.12013-01_12_01 [2018/04/28 23:47] (текущий)
Строка 26: Строка 26:
 ====Текст программы telemetry_rev1-1.asm==== ====Текст программы telemetry_rev1-1.asm====
  
-<​hidden ​telemetry_rev1-1.asm>;-------------------------------------------------------------------------------------------------------------- +<​hidden ​развернуть>​ 
-; Program ​ : telemetry_rev1-1 +<​code ​asm> 
-; Compiler ​ : AVRA +  ​;​---------------------------------------------------- 
-; Chip type : ATmega328P +  ; Program ​ : telemetry_rev1-1 
-; System Clock : 16 MHz +  ; Compiler ​ : AVRA 
-; Date   : 18.01.2017 +  ; Chip type : ATmega328P 
-;​-------------------------------------------------------------------------------------------------------------- +  ; System Clock : 16 MHz 
- +  ; Date   : 18.01.2017 
-;​Подключение библиотек и резервация места под данные +  ;​-------------------------------------------------------------------------------------------------------------- 
-.include "​m328Pdef.inc " +   
- +  ;​Подключение библиотек и резервация места под данные 
-.dseg +  .include "​m328Pdef.inc " 
-adc_data: +   
-.byte8 +  .dseg 
-Trm:; Ячейки ОЗУ под показания датчиков DS18B20 +  adc_data: 
-.byte14 +  .byte8 
-bmp_temp:; Ячейки ОЗУ под показания темп. датчика BMP180 +  Trm:; Ячейки ОЗУ под показания датчиков DS18B20 
-.byte2 +  .byte14 
-bmp_pres:; Ячейки ОЗУ под показания давления датчика BMP180 ​+  bmp_temp:; Ячейки ОЗУ под показания темп. датчика BMP180 
 +  .byte2 
 +  bmp_pres:; Ячейки ОЗУ под показания давления датчика BMP180 ​ 
 +  .byte2 
 +  bh_lux:
   .byte2   .byte2
-bh_lux: +  ​ 
-.byte2 +  .cseg 
- +  .include "​iterrupts.asm";​ Библиотека векторов прерываний 
-.cseg +  .include "​macr.asm";​ Библиотека макросов 
-.include "​iterrupts.asm";​ Библиотека векторов прерываний +  .include "​twi_lib.asm";​ Библиотека работы шины TWI 
-.include "​macr.asm";​ Библиотека макросов +  .include "​hextobcd.asm";​ Библиотека перевода чисел в неупакованный 2-10 код 
-.include "​twi_lib.asm";​ Библиотека работы шины TWI +  .include "​1wire.asm";​ Библиотека 1-wire устройств 
-.include "​hextobcd.asm";​ Библиотека перевода чисел в неупакованный 2-10 код +  ;​-------------------------------------------------------------------------------------------------------------- 
-.include "​1wire.asm";​ Библиотека 1-wire устройств +   
-;​-------------------------------------------------------------------------------------------------------------- +  RESET: 
- +   
-RESET: +  ;​Начальная_инициализация 
- +  ;​-------------------------------------------------------------------------------------------------------------- 
-;​Начальная_инициализация +   
-;​-------------------------------------------------------------------------------------------------------------- +  ldi R16, Low(RAMEND);​ Инициализация стека 
- +  out SPL, R16 
-ldi R16, Low(RAMEND);​ Инициализация стека +  ldi R16, High(RAMEND) 
-out SPL, R16 +  out SPH, R16 
-ldi R16, High(RAMEND) +   
-out SPH, R16 +  .def try = r21 
- +  .def temp = r16 
-.def try = r21 +  .def razr1 = r17 
-.def temp = r16 +  .def razr2 = r18 
-.def razr1 = r17 +  .def razr3 = r19 
-.def razr2 = r18 +   
-.def razr3 = r19 +   
- +  .equ W1_DDR = DDRB ; Присваиваем псевдоним регистрам порта датчиков DS18B20 
- +  .equ W1_PORT = PORTB  
-.equ W1_DDR = DDRB ; Присваиваем псевдоним регистрам порта датчиков DS18B20 +  .equ W1_PIN = PINB  
-.equ W1_PORT = PORTB  +  .equ W1_BIT = 0 ; Бит порта на котором датчики (8 цифровой контакт на плате Ардуино) 
-.equ W1_PIN = PINB  +   
-.equ W1_BIT = 0 ; Бит порта на котором датчики (8 цифровой контакт на плате Ардуино) +  .equ FREQ = 16000000 ; Частота процессора  
- +  .equ baudrate = 38400; Рассчитываем делитель бодрейта для UART 
-.equ FREQ = 16000000 ; Частота процессора  +  .equ bauddivider = FREQ/​(16*baudrate)-1 
-.equ baudrate = 38400; Рассчитываем делитель бодрейта для UART +  .equ FreqSCL = 200000; Рассчитываем частоту работы шины TWI 
-.equ bauddivider = FREQ/​(16*baudrate)-1 +  .equ FreqTWBR = ((FREQ/​FreqSCL)-16)/​2 
-.equ FreqSCL = 200000; Рассчитываем частоту работы шины TWI +   
-.equ FreqTWBR = ((FREQ/​FreqSCL)-16)/​2 +  ldi R16, low(bauddivider);​ Инициализация UART 
- +  sts UBRR0L,​R16 
-ldi R16, low(bauddivider);​ Инициализация UART +  ldi R16, high(bauddivider) 
-sts UBRR0L,​R16 +  sts UBRR0H,​R16 
-ldi R16, high(bauddivider) +   
-sts UBRR0H,​R16 +  ldi R16,0 
- +  sts UCSR0A, R16 
-ldi R16,0 +  sts UCSR0B, R16 
-sts UCSR0A, R16 +  sts UCSR0C, R16 
-sts UCSR0B, R16 +   
-sts UCSR0C, R16 +  LDI R16, (1<<​RXEN0)|(1<<​TXEN0)|(0<<​RXCIE0)|(0<<​TXCIE0)|(0<<​UDRIE0) 
- +  sts UCSR0B, R16 
-LDI R16, (1<<​RXEN0)|(1<<​TXEN0)|(0<<​RXCIE0)|(0<<​TXCIE0)|(0<<​UDRIE0) +  ldi r16,0 
-sts UCSR0B, R16 +   
-ldi r16,0 +  LDI R16, (0<<​USBS0)|(0<<​UMSEL0)|(0<<​UMSEL1)|(1<<​UCSZ00)|(1<<​UCSZ01) 
- +  sts UCSR0C, R16 
-LDI R16, (0<<​USBS0)|(0<<​UMSEL0)|(0<<​UMSEL1)|(1<<​UCSZ00)|(1<<​UCSZ01) +   
-sts UCSR0C, R16 +   
- +  ldi r16,​0b01000000;​ Инициализация АЦП 
- +  sts ADMUX,r16 
-ldi r16,​0b01000000;​ Инициализация АЦП +  ldi r16,​0b11011111 
-sts ADMUX,r16 +  sts ADCSRA,​r16 
-ldi r16,​0b11011111 +  ldi r25,0 
-sts ADCSRA,​r16 +   
-ldi r25,0 +  rcall W1_Sbros; Сбрасываем шину 1-Wire 
- +  rcall W1_Init_12bit;​ Перестраиваем конфигурационный байт на 12 битную схему работы 
-rcall W1_Sbros; Сбрасываем шину 1-Wire +  rcall W1_Sbros; Вновь сбрасываем 
-rcall W1_Init_12bit;​ Перестраиваем конфигурационный байт на 12 битную схему работы +   
-rcall W1_Sbros; Вновь сбрасываем +  ldi r16,​0b00000101;​ Инициализация работы прерывания по таймеру для отправки показаний 
- +  sts TCCR2B,r16; датчиков DS18B20 по шине 1-Wire 
-ldi r16,​0b00000101;​ Инициализация работы прерывания по таймеру для отправки показаний +  ldi r16,​0b00000001 
-sts TCCR2B,r16; датчиков DS18B20 по шине 1-Wire +  sts TIMSK2,​r16 
-ldi r16,​0b00000001 +  sts TIFR2,r16 
-sts TIMSK2,​r16 +  ldi r16,0xF0 
-sts TIFR2,r16 +  sts TCNT2,r16 
-ldi r16,0xF0 +   
-sts TCNT2,r16 +  ldi r16,​0b00000101;​ Инициализация работы прерывания по таймеру для отправки показаний 
- +  sts TCCR1B,r16; датчиков DS18B20 по шине 1-Wire 
-ldi r16,​0b00000101;​ Инициализация работы прерывания по таймеру для отправки показаний +  ldi r16,​0b00000001 
-sts TCCR1B,r16; датчиков DS18B20 по шине 1-Wire +  sts TIMSK1,​r16 
-ldi r16,​0b00000001 +  sts TIFR1,r16 
-sts TIMSK1,​r16 +  ldi r16,0xA0 
-sts TIFR1,r16 +  sts TCNT1H,​temp 
-ldi r16,0xA0 +  sts TCNT1L,​temp 
-sts TCNT1H,​temp +   
-sts TCNT1L,​temp +  ldi R16, 0b00110000; Инициализация шины TWI 
- +  out PORTC, R16 
-ldi R16, 0b00110000; Инициализация шины TWI +  ldi r16,​FreqTWBR 
-out PORTC, R16 +  sts TWBR,r16 
-ldi r16,​FreqTWBR +  ldi r16,0x00 
-sts TWBR,r16 +  sts TWSR,r16 
-ldi r16,0x00 +   
-sts TWSR,r16 +  clr try 
- +  clr r2 
-clr try +  clr r3 
-clr r2 +  clr r4 
-clr r3 +  clr r5 
-clr r4 +  ldi r24,0x00 
-clr r5 +  ldi R16, 0b00000000 
-ldi r24,0x00 +  out PORTD, R16 
-ldi R16, 0b00000000 +   
-out PORTD, R16 +  ldi R16, 0b00000100 
- +  out DDRD, R16 
-ldi R16, 0b00000100 +   
-out DDRD, R16 +  rcall i2c_start 
- +  ldi r16,0x46; Если нет, то остаемся этой процедуре 
-rcall i2c_start +  rcall i2c_send 
-ldi r16,0x46; Если нет, то остаемся этой процедуре +  ldi r16,0x11 
-rcall i2c_send +  rcall i2c_send 
-ldi r16,0x11 +  rcall i2c_stop 
-rcall i2c_send +  sei; Разрешаем прерывания 
-rcall i2c_stop +  rjmp main 
-sei; Разрешаем прерывания +  ;​-------------------------------------------------------------------------------------------------------------- 
-rjmp main +  ;​Конец_начальной_инициализации 
-;​-------------------------------------------------------------------------------------------------------------- +   
-;​Конец_начальной_инициализации +   
- +   
- +   
- +  ;​Основная_подпрограмма 
- +  ;​-------------------------------------------------------------------------------------------------------------- 
-;​Основная_подпрограмма +   
-;​-------------------------------------------------------------------------------------------------------------- +   
- +  main: 
- +  cli; Запрещаем прерывания в основном цикле 
-main: +  push r 
-cli; Запрещаем прерывания в основном цикле +  mov r17,r5 
-push r +  mov r16,r4 
-mov r17,r5 +  rcall bin2ASCII15 
-mov r16,r4 +  mov r17,r3 
-rcall bin2ASCII15 +  mov r16,r2 
-mov r17,r3 +  rcall bin2ASCII15 
-mov r16,r2 +  popr 
-rcall bin2ASCII15 +  tabulate 
-popr +   
-tabulate +  rcall W1_ConvTemp;​ Говорим датчикам конвертировать температуры 
- +   
-rcall W1_ConvTemp;​ Говорим датчикам конвертировать температуры +  push r16 
- +  lds r16,​bh_lux+1 
-push r16 +  cpi r16,0x82 
-lds r16,​bh_lux+1 +  brlo light 
-cpi r16,0x82 +  brsh no_light 
-brlo light +  light: 
-brsh no_light +  lds r16,​bh_lux 
-light: +  cpi r16,0x01 
-lds r16,​bh_lux +  brsh light_exit 
-cpi r16,0x01 +  ldi r16,​0b00000100 
-brsh light_exit +  out PORTD,r16 
-ldi r16,​0b00000100 +  jmp light_exit 
-out PORTD,r16 +  no_light: 
-jmp light_exit +  ldi r16,​0b00000000 
-no_light: +  out PORTD,r16 
-ldi r16,​0b00000000 +  jmp light_exit 
-out PORTD,r16 +  light_exit:​ 
-jmp light_exit +   
-light_exit:​ +  pop r16 
- +  ldi ZL, LOW(adc_data);​ Производим косвенную адресацию на показания АЦП, чтобы потом их 
-pop r16 +  ldi ZH, HIGH(adc_data);​ последовательно отправить по UART 
-ldi ZL, LOW(adc_data);​ Производим косвенную адресацию на показания АЦП, чтобы потом их +  clr r20 
-ldi ZH, HIGH(adc_data);​ последовательно отправить по UART +  print_adc:; Цикл отправки показаний АЦП 
-clr r20 +  inc r20 
-print_adc:; Цикл отправки показаний АЦП +  push r 
-inc r20 +  ld r17,Z 
-push r +  adiw ZH:ZL,1 
-ld r17,Z +  ld r16,Z 
-adiw ZH:ZL,1 +  adiw ZH:ZL,1 
-ld r16,Z +  rcall bin2ASCII15 
-adiw ZH:ZL,1 +  popr 
-rcall bin2ASCII15 +  tabulate 
-popr +  cpi r20,4 
-tabulate +  brne print_adc; Закончили цикл 
-cpi r20,4 +  tabulate 
-brne print_adc; Закончили цикл +   
-tabulate +  push r 
- +  lds r17,​bmp_temp;​ Выводим показания датчика BMP180 
-push r +  lds r16,​bmp_temp+1 
-lds r17,​bmp_temp;​ Выводим показания датчика BMP180 +  rcall bin2ASCII15 
-lds r16,​bmp_temp+1 +  tabulate 
-rcall bin2ASCII15 +  lds r17,​bmp_pres 
-tabulate +  lds r16,​bmp_pres+1 
-lds r17,​bmp_pres +  rcall bin2ASCII15 
-lds r16,​bmp_pres+1 +  tabulate 
-rcall bin2ASCII15 +  lds r17,​bh_lux 
-tabulate +  lds r16,​bh_lux+1 
-lds r17,​bh_lux +  rcall bin2ASCII15 
-lds r16,​bh_lux+1 +  popr 
-rcall bin2ASCII15 +   
-popr +  inc r24; Увеличили счетчик кадров и отправили его значение по UART 
- +  newline 
-inc r24; Увеличили счетчик кадров и отправили его значение по UART +   
-newline +  rcall i2c_start 
- +  ldi r16,0x47 
-rcall i2c_start +  rcall i2c_send 
-ldi r16,0x47 +  rcall i2c_receive 
-rcall i2c_send +  sts bh_lux,​r16 
-rcall i2c_receive +  rcall i2c_receive_last 
-sts bh_lux,​r16 +  sts bh_lux+1,​r16 
-rcall i2c_receive_last +  rcall i2c_stop 
-sts bh_lux+1,​r16 +  sei; Разрешили прерывания,​ чтобы микроконтроллер смог обработать 
-rcall i2c_stop +  ; новые показания АПЦ, термометров и датчика BMP180 
-sei; Разрешили прерывания,​ чтобы микроконтроллер смог обработать +  rcall i2c_start 
-; новые показания АПЦ, термометров и датчика BMP180 +  rjmp main 
-rcall i2c_start +   
-rjmp main +  ;​-------------------------------------------------------------------------------------------------------------- 
- +  ;​Конец_основной_подпрограммы 
-;​-------------------------------------------------------------------------------------------------------------- +   
-;​Конец_основной_подпрограммы +  ;​Прерывание_АЦП 
- +  ;​-------------------------------------------------------------------------------------------------------------- 
-;​Прерывание_АЦП +  adc_conv: 
-;​-------------------------------------------------------------------------------------------------------------- +  cli; Запрещаем прерывания 
-adc_conv: +   
-cli; Запрещаем прерывания +  lds r17,ADCL; Снимаем показания сделанные во время нашего отсутствия в прерывании 
- +  lds r18,ADCH 
-lds r17,ADCL; Снимаем показания сделанные во время нашего отсутствия в прерывании +  cpi r25,0; Смотрим,​ какое число содержится в r25 
-lds r18,ADCH +  breq adc0; Переходим по метке для этого числа 
-cpi r25,0; Смотрим,​ какое число содержится в r25 +  cpi r25,1 
-breq adc0; Переходим по метке для этого числа +  breq adc1 
-cpi r25,1 +  cpi r25,2 
-breq adc1 +  breq adc2 
-cpi r25,2 +  cpi r25,3 
-breq adc2 +  breq adc3 
-cpi r25,3 +  cpi r25,4 
-breq adc3 +  breq adc4 
-cpi r25,4 +   
-breq adc4 +  adc0: 
- +  sts adc_data+6,​r18;​ Записываем снятые в начале показания АЦП 
-adc0: +  sts adc_data+7,​r17 
-sts adc_data+6,​r18;​ Записываем снятые в начале показания АЦП +  ldi r16,​0b01000000;​ Запускаем новое преобразования в зависимости от пина АЦП 
-sts adc_data+7,​r17 +  sts ADMUX,r16 
-ldi r16,​0b01000000;​ Запускаем новое преобразования в зависимости от пина АЦП +  rjmp adc_ex; Переходим на выход 
-sts ADMUX,r16 +   
-rjmp adc_ex; Переходим на выход +  adc1: 
- +  sts adc_data,​r18 
-adc1: +  sts adc_data+1,​r17 
-sts adc_data,​r18 +  ldi r16,​0b01000001 
-sts adc_data+1,​r17 +  sts ADMUX,r16 
-ldi r16,​0b01000001 +  rjmp adc_ex 
-sts ADMUX,r16 +   
-rjmp adc_ex +  adc2: 
- +  sts adc_data+2,​r18 
-adc2: +  sts adc_data+3,​r17 
-sts adc_data+2,​r18 +  ldi r16,​0b01000010 
-sts adc_data+3,​r17 +  sts ADMUX,r16 
-ldi r16,​0b01000010 +  rjmp adc_ex 
-sts ADMUX,r16 +   
-rjmp adc_ex +  adc3: 
- +  sts adc_data+4,​r18 
-adc3: +  sts adc_data+5,​r17 
-sts adc_data+4,​r18 +  ldi r16,​0b01000011 
-sts adc_data+5,​r17 +  sts ADMUX,r16 
-ldi r16,​0b01000011 +  rjmp adc_ex 
-sts ADMUX,r16 +   
-rjmp adc_ex +  adc4: 
- +  clr r25; Если r25 = 4, очищаем его и прыгаем на adc0 
-adc4: +  rjmp adc0 
-clr r25; Если r25 = 4, очищаем его и прыгаем на adc0 +   
-rjmp adc0 +  adc_ex:ldi r16,​0b11011111;​ Каждый раз повторно инициализируем АЦП 
- +  sts ADCSRA,​r16 
-adc_ex:ldi r16,​0b11011111;​ Каждый раз повторно инициализируем АЦП +  inc r25 
-sts ADCSRA,​r16 +  sei 
-inc r25 +  reti 
-sei +  ;​-------------------------------------------------------------------------------------------------------------- 
-reti +  ;​Конец_прерывания_АЦП 
-;​-------------------------------------------------------------------------------------------------------------- +   
-;​Конец_прерывания_АЦП +   
- +  ;​Прерывание_таймера1 
- +  ;​-------------------------------------------------------------------------------------------------------------- 
-;​Прерывание_таймера1 +  W1_timer: 
-;​-------------------------------------------------------------------------------------------------------------- +  cli 
-W1_timer: +   
-cli +  ldi r16,0x54 
- +  check1 r16 
-ldi r16,0x54 +  tabulate 
-check1 r16 +  rcall W1_Sbros; Сбрасываем шину и проверяем есть ли датчик 
-tabulate +  ldi YL, LOW(Trm) 
-rcall W1_Sbros; Сбрасываем шину и проверяем есть ли датчик +  ldi YH, HIGH(Trm) 
-ldi YL, LOW(Trm) +  ldi ZL,​LOW(Addr1*2) 
-ldi YH, HIGH(Trm) +  ldi ZH,​HIGH(Addr1*2) 
-ldi ZL,​LOW(Addr1*2) +  rcall W1_ReadMem; Читаем в ОЗУ текущую температуру 
-ldi ZH,​HIGH(Addr1*2) +  ldi ZL,​LOW(Addr2*2) 
-rcall W1_ReadMem; Читаем в ОЗУ текущую температуру +  ldi ZH,​HIGH(Addr2*2) 
-ldi ZL,​LOW(Addr2*2) +  rcall W1_ReadMem 
-ldi ZH,​HIGH(Addr2*2) +  ldi ZL,​LOW(Addr3*2) 
-rcall W1_ReadMem +  ldi ZH,​HIGH(Addr3*2) 
-ldi ZL,​LOW(Addr3*2) +  rcall W1_ReadMem 
-ldi ZH,​HIGH(Addr3*2) +  ldi ZL,​LOW(Addr4*2) 
-rcall W1_ReadMem +  ldi ZH,​HIGH(Addr4*2) 
-ldi ZL,​LOW(Addr4*2) +  rcall W1_ReadMem 
-ldi ZH,​HIGH(Addr4*2) +  ldi ZL,​LOW(Addr5*2) 
-rcall W1_ReadMem +  ldi ZH,​HIGH(Addr5*2) 
-ldi ZL,​LOW(Addr5*2) +  rcall W1_ReadMem 
-ldi ZH,​HIGH(Addr5*2) +  ldi ZL,​LOW(Addr6*2) 
-rcall W1_ReadMem +  ldi ZH,​HIGH(Addr6*2) 
-ldi ZL,​LOW(Addr6*2) +  rcall W1_ReadMem 
-ldi ZH,​HIGH(Addr6*2) +  ldi ZL,​LOW(Addr7*2) 
-rcall W1_ReadMem +  ldi ZH,​HIGH(Addr7*2) 
-ldi ZL,​LOW(Addr7*2) +  rcall W1_ReadMem 
-ldi ZH,​HIGH(Addr7*2) +  push f; На всякий случай отправляем в стек SREG 
-rcall W1_ReadMem +  ldi ZL, LOW(Trm); Делаем косвенную адресацию на массив данных температуры датчиков DS18B20 
-push f; На всякий случай отправляем в стек SREG +  ldi ZH, HIGH(Trm) 
-ldi ZL, LOW(Trm); Делаем косвенную адресацию на массив данных температуры датчиков DS18B20 +  clr r20 
-ldi ZH, HIGH(Trm) +  print1:; Цикл печати данных 
-clr r20 +  inc r20 
-print1:; Цикл печати данных +  push r 
-inc r20 +  ld r16,Z 
-push r +  adiwZH:​ZL,​1 
-ld r16,Z +  ld r17,Z 
-adiwZH:​ZL,​1 +  adiwZH:​ZL,​1 
-ld r17,Z +  rcall bin2ASCII15 
-adiwZH:​ZL,​1 +  tabulate 
-rcall bin2ASCII15 +  popr 
-tabulate +  cpi r20,7 
-popr +   
-cpi r20,7 +  brne print1 
- +  newline 
-brne print1 +  ; Задаем число с которого таймер начнет считать до следующего прерывания 
-newline +  ldi r22,0xA0 
-; Задаем число с которого таймер начнет считать до следующего прерывания +  sts TCNT1H,​r22 
-ldi r22,0xA0 +  sts TCNT1L,​r22 
-sts TCNT1H,​r22 +  popf; Возвращаем SREG из стека 
-sts TCNT1L,​r22 +  sei; Разрешаем прерывания 
-popf; Возвращаем SREG из стека +  reti 
-sei; Разрешаем прерывания +   
-reti +  ;​-------------------------------------------------------------------------------------------------------------- 
- +  ;​Конец_прерывания_таймера1 
-;​-------------------------------------------------------------------------------------------------------------- +   
-;​Конец_прерывания_таймера1 +  ;​Прерывание_таймера0 
- +  ;​-------------------------------------------------------------------------------------------------------------- 
-;​Прерывание_таймера0 +  Board_timer:​ 
-;​-------------------------------------------------------------------------------------------------------------- +  cli 
-Board_timer:​ +   
-cli +  push f 
- +  mov r16,r2 
-push f +   
-mov r16,r2 +  cpi r16,0xFF 
- +  breq r2cap 
-cpi r16,0xFF +  inc r2 
-breq r2cap +  jmp btim_exit 
-inc r2 +  r2cap: 
-jmp btim_exit +  clr r2 
-r2cap: +  mov r16,r3 
-clr r2 +  cpi r16,0xFF 
-mov r16,r3 +  breq r3cap 
-cpi r16,0xFF +  inc r3 
-breq r3cap +  jmp btim_exit 
-inc r3 +  r3cap: 
-jmp btim_exit +  clr r3 
-r3cap: +  mov r16,r4 
-clr r3 +  cpi r16,0xFF 
-mov r16,r4 +  breq r4cap 
-cpi r16,0xFF +  inc r4 
-breq r4cap +  jmp btim_exit 
-inc r4 +  r4cap: 
-jmp btim_exit +  clr r4 
-r4cap: +  mov r16,r5 
-clr r4 +  cpi r16,0xFF 
-mov r16,r5 +  breq r5cap 
-cpi r16,0xFF +  jmp btim_exit 
-breq r5cap +  inc r5 
-jmp btim_exit +  r5cap: 
-inc r5 +  clr r5 
-r5cap: +  jmp btim_exit 
-clr r5 +   
-jmp btim_exit +  btim_exit:​ 
- +  ldi r22,0xE9 
-btim_exit:​ +  sts TCNT2,r22 
-ldi r22,0xE9 +  popf 
-sts TCNT2,r22 +  sei 
-popf +  reti 
-sei +   
-reti +  ;​-------------------------------------------------------------------------------------------------------------- 
- +  ;​Конец_прерывания_таймера0 
-;​-------------------------------------------------------------------------------------------------------------- +   
-;​Конец_прерывания_таймера0 +   
- +   
- +   
- +   
- +  ;​Прерывание_TWI 
- +  ;​-------------------------------------------------------------------------------------------------------------- 
-;​Прерывание_TWI +  TWI_int: 
-;​-------------------------------------------------------------------------------------------------------------- +  cli; Запрещаем прерывания 
-TWI_int: +  push r16; Отправляем в стек r16 
-cli; Запрещаем прерывания +  lds r16,TWSR; Сравниваем Статус-регистр TWI  
-push r16; Отправляем в стек r16 +  andi r16,0xF8 
-lds r16,TWSR; Сравниваем Статус-регистр TWI  +  cpi r16,0x08; Если он равен 0x08, то нам надо запустить вычисление  
-andi r16,0xF8 +  breq TWI_start_samples_1 
-cpi r16,0x08; Если он равен 0x08, то нам надо запустить вычисление  +  cpi r16,0x10; Если он равен 0х10, то нам надо считывать показания 
-breq TWI_start_samples_1 +  breq TWI_read_samples_1 
-cpi r16,0x10; Если он равен 0х10, то нам надо считывать показания +  TWI_exit:​popr16;​ Возвращаем r16 из стека 
-breq TWI_read_samples_1 +  sei; Разрешаем прерывания 
-TWI_exit:​popr16;​ Возвращаем r16 из стека +  reti 
-sei; Разрешаем прерывания +   
-reti +  TWI_start_samples_1:;​ Запускаем вычисление некомпенсированной температуры 
- +  ; Проверяем содержимое переменной try 
-TWI_start_samples_1:;​ Запускаем вычисление некомпенсированной температуры +  cpi try,1; Если 1, то прыгаем на запуск вычисления давления 
-; Проверяем содержимое переменной try +  breq TWI_start_samples_2 
-cpi try,1; Если 1, то прыгаем на запуск вычисления давления +  ldi r16,0xEE; Если нет, то остаемся этой процедуре 
-breq TWI_start_samples_2 +  rcall i2c_send 
-ldi r16,0xEE; Если нет, то остаемся этой процедуре +   
-rcall i2c_send +  ldi r16,0xF4 
- +  rcall i2c_send 
-ldi r16,0xF4 +   
-rcall i2c_send +  ldi r16,0x2E 
- +  rcall i2c_send 
-ldi r16,0x2E +  rcall i2c_start 
-rcall i2c_send +  rjmp TWI_exit 
-rcall i2c_start +   
-rjmp TWI_exit +  TWI_start_samples_2:;​ Запускаем вычисление некомпенсированного давления 
- +  ldi r16,0xEE 
-TWI_start_samples_2:;​ Запускаем вычисление некомпенсированного давления +  rcall i2c_send 
-ldi r16,0xEE +   
-rcall i2c_send +  ldi r16,0xF4 
- +  rcall i2c_send 
-ldi r16,0xF4 +   
-rcall i2c_send +  ldi r16,0x34 
- +  rcall i2c_send 
-ldi r16,0x34 +  rcall i2c_start 
-rcall i2c_send +  rjmp TWI_exit 
-rcall i2c_start +  TWI_read_samples_1:;​ Считываем показания некомпенсированной температуры 
-rjmp TWI_exit +  ; Снова проверяем try 
-TWI_read_samples_1:;​ Считываем показания некомпенсированной температуры +  cpi try,1 
-; Снова проверяем try +  breq TWI_read_samples_2 
-cpi try,1 +  ldi r16,0xEE 
-breq TWI_read_samples_2 +  rcall i2c_send 
-ldi r16,0xEE +   
-rcall i2c_send +  ldi r16,0xF6 
- +  rcall i2c_send 
-ldi r16,0xF6 +   
-rcall i2c_send +  rcall i2c_start 
- +   
-rcall i2c_start +  ldi r16,0xEF 
- +  rcall i2c_send 
-ldi r16,0xEF +   
-rcall i2c_send +  rcall i2c_receive 
- +  sts bmp_temp,​r16 
-rcall i2c_receive +  rcall i2c_receive_last 
-sts bmp_temp,​r16 +  sts bmp_temp+1,​r16 
-rcall i2c_receive_last +  ldi try,​0b00000001 
-sts bmp_temp+1,​r16 +  rcall i2c_stop 
-ldi try,​0b00000001 +  rjmp TWI_exit 
-rcall i2c_stop +  TWI_read_samples_2:​ 
-rjmp TWI_exit +  ldi r16,0xEE 
-TWI_read_samples_2:​ +  rcall i2c_send 
-ldi r16,0xEE +   
-rcall i2c_send +  ldi r16,0xF6 
- +  rcall i2c_send 
-ldi r16,0xF6 +   
-rcall i2c_send +  rcall i2c_start 
- +   
-rcall i2c_start +  ldi r16,0xEF 
- +  rcall i2c_send 
-ldi r16,0xEF +   
-rcall i2c_send +  rcall i2c_receive 
- +  sts bmp_pres,​r16 
-rcall i2c_receive +  rcall i2c_receive_last 
-sts bmp_pres,​r16 +  sts bmp_pres+1,​r16 
-rcall i2c_receive_last +  ldi try,​0b00000000;​ Уменьшаем try до 0 
-sts bmp_pres+1,​r16 +  rcall i2c_stop 
-ldi try,​0b00000000;​ Уменьшаем try до 0 +  rjmp TWI_exit 
-rcall i2c_stop +  ;​-------------------------------------------------------------------------------------------------------------- 
-rjmp TWI_exit +  ;​Конец_прерывания_TWI 
-;​-------------------------------------------------------------------------------------------------------------- +   
-;​Конец_прерывания_TWI +   
- +  Addr1:​.db0x28,​0xFF,​0x41,​0x3,​0xA3,​0x15,​0x1,​0xBB;​ Адреса датчиков DS18B20 
- +  Addr2:​.db0x28,​0xFF,​0xE2,​0x1A,​0xA2,​0x15,​0x4,​0xF9 
-Addr1:​.db0x28,​0xFF,​0x41,​0x3,​0xA3,​0x15,​0x1,​0xBB;​ Адреса датчиков DS18B20 +  Addr3:​.db0x28,​0xFF,​0x91,​0xF,​0xA3,​0x15,​0x4,​0xC8 
-Addr2:​.db0x28,​0xFF,​0xE2,​0x1A,​0xA2,​0x15,​0x4,​0xF9 +  Addr4:​.db0x28,​0xFF,​0x90,​0x82,​0xA3,​0x15,​0x4,​0x41 
-Addr3:​.db0x28,​0xFF,​0x91,​0xF,​0xA3,​0x15,​0x4,​0xC8 +  Addr5:​.db0x28,​0xFF,​0xC6,​0xB,​0xA3,​0x15,​0x4,​0x2 
-Addr4:​.db0x28,​0xFF,​0x90,​0x82,​0xA3,​0x15,​0x4,​0x41 +  Addr6:​.db0x28,​0xFF,​0x9,​0x5D,​0xA3,​0x15,​0x4,​0x9E 
-Addr5:​.db0x28,​0xFF,​0xC6,​0xB,​0xA3,​0x15,​0x4,​0x2 +  Addr7:​.db0x28,​0xFF,​0x7F,​0x83,​0xA3,​0x15,​0x4,​0x7B 
-Addr6:​.db0x28,​0xFF,​0x9,​0x5D,​0xA3,​0x15,​0x4,​0x9E +   
-Addr7:​.db0x28,​0xFF,​0x7F,​0x83,​0xA3,​0x15,​0x4,​0x7B +   
- +   
- +  Delay: ; Стандартная задержка 
- +  push f 
-Delay: ; Стандартная задержка +  ldi razr1, 50 
-push f +  ldi razr2, 10 
-ldi razr1, 50 +  Pdelay: 
-ldi razr2, 10 +  dec razr1 
-Pdelay: +  brne Pdelay 
-dec razr1 +  dec razr2 
-brne Pdelay +  brne Pdelay 
-dec razr2 +  popf 
-brne Pdelay +  ret 
-popf +  Delay1: ; Стандартная задержка 1 
-ret +  push f 
-Delay1: ; Стандартная задержка 1 +  ldi razr1, 50 
-push f +  ldi razr2, 50 
-ldi razr1, 50 +  ldi razr3, 1 
-ldi razr2, 50 +  Pdelay1: 
-ldi razr3, 1 +  dec razr1 
-Pdelay1: +  brne Pdelay1 
-dec razr1 +  dec razr2 
-brne Pdelay1 +  brne Pdelay1 
-dec razr2 +  dec razr3 
-brne Pdelay1 +  brne Pdelay1 
-dec razr3 +  popf 
-brne Pdelay1 +  ret 
-popf +  </​code>​
-ret+
 </​hidden>​ </​hidden>​
  
 +\\
 ====Текст модуля 1wire.asm==== ====Текст модуля 1wire.asm====
-<file asm 1wire.asm> +<hidden развернуть>​ 
-;​1-wire_подпрограммы +<​code ​asm> 
-;​-------------------------------------------------------------------------------------------------------------- +  ;​1-wire_подпрограммы 
- +  ;​-------------------------------------------------------------------------------------------------------------- 
- +   
-W1_Sbros: ​    ; Сброс шины и проверка датчик на месте ли +   
-lds r16, W1_BIT ; Записываем в r16 ножку где датчик +  W1_Sbros: ​    ; Сброс шины и проверка датчик на месте ли 
-sbi W1_DDR, W1_BIT ; Ногу на выход +  lds r16, W1_BIT ; Записываем в r16 ножку где датчик 
-cbi W1_PORT, W1_BIT ; Опрокидываем вывод на землю +  sbi W1_DDR, W1_BIT ; Ногу на выход 
-rcall W1_DelayH ; Задержка 480 мкс, для сброса +  cbi W1_PORT, W1_BIT ; Опрокидываем вывод на землю 
-cbi W1_DDR, W1_BIT ; Ногу на вход +  rcall W1_DelayH ; Задержка 480 мкс, для сброса 
-rcall W1_DelayI ; Ждем тайм слот 70 мкс +  cbi W1_DDR, W1_BIT ; Ногу на вход 
-sbis W1_PIN, W1_BIT ; Пропускаем следующую строку,​ если бит порта в 1 +  rcall W1_DelayI ; Ждем тайм слот 70 мкс 
-ldi r17, 1  ; И установим сигнальный регистр в 1 +  sbis W1_PIN, W1_BIT ; Пропускаем следующую строку,​ если бит порта в 1 
-sbic W1_PIN, W1_BIT ; Пропускаем следующую строку,​ если бит порта в 0 +  ldi r17, 1  ; И установим сигнальный регистр в 1 
-ldi r17, 0  ; И установим сигнальный регистр в 0 +  sbic W1_PIN, W1_BIT ; Пропускаем следующую строку,​ если бит порта в 0 
-rcall W1_DelayJ ; Ждем тайм слот 410 мкс +  ldi r17, 0  ; И установим сигнальный регистр в 0 
-ret    ; Если датчик на месте, в r17 по выходу отсюда будет 1, в противном случае 0 +  rcall W1_DelayJ ; Ждем тайм слот 410 мкс 
- +  ret    ; Если датчик на месте, в r17 по выходу отсюда будет 1, в противном случае 0 
-W1_Address:​ +   
-clr r20 +  W1_Address:​ 
-read: +  clr r20 
-inc r20  ; Процедура считывания адреса датчиков DS18B20 +  read: 
-in r10,SREG +  inc r20  ; Процедура считывания адреса датчиков DS18B20 
-push r10 +  in r10,SREG 
-lpm r16,Z +  push r10 
-rcall ds_byte_wr +  lpm r16,Z 
-pop r10 +  rcall ds_byte_wr 
-out SREG,r10 +  pop r10 
-adiw ZH:ZL,1 +  out SREG,r10 
-cpi r20,8 +  adiw ZH:ZL,1 
-brne read +  cpi r20,8 
-ret +  brne read 
- +  ret 
-W1_ReadMem: ​    ; Чтение памяти регистров температуры +   
-ldi  r16, 0x55  ; Пошлем команду 0x55, это сравнить уникальный номер датчика +  W1_ReadMem: ​    ; Чтение памяти регистров температуры 
-rcall  ds_byte_wr ​ ; Так как он у нас один на проводе +  ldi  r16, 0x55  ; Пошлем команду 0x55, это сравнить уникальный номер датчика 
-rcall  W1_Address ; Отправляем адрес датчика +  rcall  ds_byte_wr ​ ; Так как он у нас один на проводе 
-ldi  r16, 0xBE  ; Говорим датчику,​ что мы сейчас будем читать +  rcall  W1_Address ; Отправляем адрес датчика 
-rcall  ds_byte_wr ​ ; Запуливаем байт +  ldi  r16, 0xBE  ; Говорим датчику,​ что мы сейчас будем читать 
-rcall ds_byte_rd ​ ; А тут уже начинаем читать,​ прочитали первый +  rcall  ds_byte_wr ​ ; Запуливаем байт 
-st Y, r16  ; И запулили его в память,​ по метке Trm +  rcall ds_byte_rd ​ ; А тут уже начинаем читать,​ прочитали первый 
-adiw YH:YL,1 +  st Y, r16  ; И запулили его в память,​ по метке Trm 
-rcall ds_byte_rd ​ ; Читаем второй +  adiw YH:YL,1 
-st Y, r16  ; И запулили его в память,​ по метке Trm+1 +  rcall ds_byte_rd ​ ; Читаем второй 
-adiw YH:YL,1 +  st Y, r16  ; И запулили его в память,​ по метке Trm+1 
-rcall W1_Sbros ​ ; Сбрасываем шину и проверяем есть ли датчик +  adiw YH:YL,1 
-;ldi ZL,​LOW(Addr2*2) +  rcall W1_Sbros ​ ; Сбрасываем шину и проверяем есть ли датчик 
-;ldi ZH,​HIGH(Addr2*2) +  ;ldi ZL,​LOW(Addr2*2) 
-;clr r20 +  ;ldi ZH,​HIGH(Addr2*2) 
-ret +  ;clr r20 
- +  ret 
-W1_ConvTemp: ​    ; Подпрограмма конвертирования температуры +   
-ldi r16, 0xCC  ; Пропускаем уникальный номер датчика +  W1_ConvTemp: ​    ; Подпрограмма конвертирования температуры 
-rcall ds_byte_wr +  ldi r16, 0xCC  ; Пропускаем уникальный номер датчика 
-ldi r16, 0x44  ; Говорим что надо бы сконвертировать температуру,​ этот процесс занимает 750 +  rcall ds_byte_wr 
-rcall ds_byte_wr ​ ; миллисекунд,​ поэтому идем что-то делать,​ или ленится +  ldi r16, 0x44  ; Говорим что надо бы сконвертировать температуру,​ этот процесс занимает 750 
-ret +  rcall ds_byte_wr ​ ; миллисекунд,​ поэтому идем что-то делать,​ или ленится 
- +  ret 
-W1_Init_12bit: ​    ; Подпрограмма перестройки на 12 бит температуры +   
-ldi r16, 0xCC   ; Пропускаем уникальный номер датчика +  W1_Init_12bit: ​    ; Подпрограмма перестройки на 12 бит температуры 
-rcall ds_byte_wr ​ ; Спуливаем в датчик +  ldi r16, 0xCC   ; Пропускаем уникальный номер датчика 
-ldi r16, 0x4E  ; Говорим что сейчас будем писать в RAM регистры датчика +  rcall ds_byte_wr ​ ; Спуливаем в датчик 
-rcall ds_byte_wr ; Спуливаем в датчик +  ldi r16, 0x4E  ; Говорим что сейчас будем писать в RAM регистры датчика 
-ldi r16, 0xFF ; 0xFF записываем в первые 2 регистра,​ это регистры температуры,​ он нам не  +  rcall ds_byte_wr ; Спуливаем в датчик 
-rcall ds_byte_wr ; нужен, поэтому их оставляем в стандартном состоянии +  ldi r16, 0xFF ; 0xFF записываем в первые 2 регистра,​ это регистры температуры,​ он нам не  
-ldi r16, 0xFF ; 0xFF второй байт температуры +  rcall ds_byte_wr ; нужен, поэтому их оставляем в стандартном состоянии 
-rcall ds_byte_wr ; Спуливаем на порт +  ldi r16, 0xFF ; 0xFF второй байт температуры 
-ldi r16, 0x7F ; А вот тут говорим что 12 бит - 7F, или 1F  - 9бит, 3F - 10 бит, 5F - 11 бит  +  rcall ds_byte_wr ; Спуливаем на порт 
-rcall ds_byte_wr ; Спуливаем на порт +  ldi r16, 0x7F ; А вот тут говорим что 12 бит - 7F, или 1F  - 9бит, 3F - 10 бит, 5F - 11 бит  
-ret +  rcall ds_byte_wr ; Спуливаем на порт 
- +  ret 
-ds_byte_rd: ​    ; Подпрограмма чтения данных в регистр r16 с 1 Wire +   
-ldi r17, 8   ; Пишем в r17 - 8, т.к. у нас в бит в регистре +  ds_byte_rd: ​    ; Подпрограмма чтения данных в регистр r16 с 1 Wire 
-clr r16   ;​Чистим r16, сюда будем читать данные +  ldi r17, 8   ; Пишем в r17 - 8, т.к. у нас в бит в регистре 
-ds_byte_rd_0:​ +  clr r16   ;​Чистим r16, сюда будем читать данные 
-sbi W1_DDR, W1_BIT ; Вывод на выход +  ds_byte_rd_0:​ 
-cbi W1_PORT, W1_BIT ; Опрокидываем вывод на землю +  sbi W1_DDR, W1_BIT ; Вывод на выход 
-rcall W1_DelayA ; Ждем 6 микросекунд +  cbi W1_PORT, W1_BIT ; Опрокидываем вывод на землю 
-cbi W1_DDR, W1_BIT ; Вывод на вход +  rcall W1_DelayA ; Ждем 6 микросекунд 
-rcall W1_DelayE ; Ждем 9 микросекунд +  cbi W1_DDR, W1_BIT ; Вывод на вход 
-sbis W1_PIN, W1_BIT +  rcall W1_DelayE ; Ждем 9 микросекунд 
-clc   ; Очищаем бит C = 0 +  sbis W1_PIN, W1_BIT 
-sbic W1_PIN, W1_BIT +  clc   ; Очищаем бит C = 0 
-sec   ; Очищаем бит C = 1 +  sbic W1_PIN, W1_BIT 
-ror r16  ; Производим циклический сдвиг вправо через С +  sec   ; Очищаем бит C = 1 
-rcall W1_DelayF ; Ждем 55 микросекунд +  ror r16  ; Производим циклический сдвиг вправо через С 
-dec r17  ;​Понижаем на 1 регистр r17 +  rcall W1_DelayF ; Ждем 55 микросекунд 
-brne ds_byte_rd_0 ; если не равен 0 вращаемся в цикле +  dec r17  ;​Понижаем на 1 регистр r17 
-ret +  brne ds_byte_rd_0 ; если не равен 0 вращаемся в цикле 
- +  ret 
-ds_byte_wr: ​    ; Подпрограмма записи данных из регистра r16 в датчик  +   
-ldi r17, 8  ; Пишем в r17 - 8, т.к. у нас в бит в регистре +  ds_byte_wr: ​    ; Подпрограмма записи данных из регистра r16 в датчик  
-ds_byte_wr0:​  +  ldi r17, 8  ; Пишем в r17 - 8, т.к. у нас в бит в регистре 
-sbi W1_DDR, W1_BIT ; Вывод на выход +  ds_byte_wr0:​  
-cbi W1_PORT, W1_BIT ; Опрокидываем вывод на землю +  sbi W1_DDR, W1_BIT ; Вывод на выход 
-sbrc r16, 0  ; Проверим,​ в r16 бит 0 очищен или установлен  +  cbi W1_PORT, W1_BIT ; Опрокидываем вывод на землю 
-rjmp ds_byte_write_1 ; Если установлен перейдем по этой метке +  sbrc r16, 0  ; Проверим,​ в r16 бит 0 очищен или установлен  
-rjmp ds_byte_write_0 ; Если очищен перейдем по этой метке +  rjmp ds_byte_write_1 ; Если установлен перейдем по этой метке 
-ds_byte_wr1:​ +  rjmp ds_byte_write_0 ; Если очищен перейдем по этой метке 
-lsr r16  ; Логический сдвиг вправо +  ds_byte_wr1:​ 
-dec r17  ; Понижаем r17 на 1  +  lsr r16  ; Логический сдвиг вправо 
-brne ds_byte_wr0 ; Если не равен 0, вращаемся в цикле +  dec r17  ; Понижаем r17 на 1  
-ret   ; Выход из подпрограммы +  brne ds_byte_wr0 ; Если не равен 0, вращаемся в цикле 
- +  ret   ; Выход из подпрограммы 
-ds_byte_write_0: ​   ; Запись 0 +   
-rcall W1_DelayC ; Ждем 60 микросекунд +  ds_byte_write_0: ​   ; Запись 0 
-cbi W1_DDR, W1_BIT ; Вывод на вход +  rcall W1_DelayC ; Ждем 60 микросекунд 
-rcall W1_DelayD ; Ждем 10 микросекунд +  cbi W1_DDR, W1_BIT ; Вывод на вход 
-rjmp ds_byte_wr1 +  rcall W1_DelayD ; Ждем 10 микросекунд 
- +  rjmp ds_byte_wr1 
-ds_byte_write_1: ​  ; Запись 1 +   
-rcall W1_DelayA ; Ждем 6 микросекунд +  ds_byte_write_1: ​  ; Запись 1 
-cbi W1_DDR, W1_BIT ; Вывод на вход +  rcall W1_DelayA ; Ждем 6 микросекунд 
-rcall W1_DelayB ; Ждем 64 микросекунд +  cbi W1_DDR, W1_BIT ; Вывод на вход 
-rjmp ds_byte_wr1 +  rcall W1_DelayB ; Ждем 64 микросекунд 
- +  rjmp ds_byte_wr1 
-W1_DelayA: ​    ; Задержка 6 mcs +   
-ldi XH, high(FREQ/​2000000) +  W1_DelayA: ​    ; Задержка 6 mcs 
-ldi XL, low(FREQ/​2000000) +  ldi XH, high(FREQ/​2000000) 
-rcall W1_Delay +  ldi XL, low(FREQ/​2000000) 
-ret +  rcall W1_Delay 
-W1_DelayB: ​    ; Задержка 64 mcs +  ret 
-ldi XH, high(FREQ/​130000) +  W1_DelayB: ​    ; Задержка 64 mcs 
-ldi XL, low(FREQ/​130000) +  ldi XH, high(FREQ/​130000) 
-rcall W1_Delay +  ldi XL, low(FREQ/​130000) 
-ret +  rcall W1_Delay 
-W1_DelayC: ​    ; Задержка 60 mcs +  ret 
-ldi XH, high(FREQ/​136000) +  W1_DelayC: ​    ; Задержка 60 mcs 
-ldi XL, low(FREQ/​136000) +  ldi XH, high(FREQ/​136000) 
-rcall W1_Delay +  ldi XL, low(FREQ/​136000) 
-ret +  rcall W1_Delay 
-W1_DelayD: ​    ; Задержка 10 mcs +  ret 
-ldi XH, high(FREQ/​1000000) +  W1_DelayD: ​    ; Задержка 10 mcs 
-ldi XL, low(FREQ/​1000000) +  ldi XH, high(FREQ/​1000000) 
-rcall W1_Delay +  ldi XL, low(FREQ/​1000000) 
-ret +  rcall W1_Delay 
-W1_DelayE: ​    ; Задержка 9 mcs +  ret 
-ldi XH, high(FREQ/​1200000) +  W1_DelayE: ​    ; Задержка 9 mcs 
-ldi XL, low(FREQ/​1200000) +  ldi XH, high(FREQ/​1200000) 
-rcall W1_Delay +  ldi XL, low(FREQ/​1200000) 
-ret +  rcall W1_Delay 
-W1_DelayF: ​    ; Задержка 55 mcs +  ret 
-ldi XH, high(FREQ/​150000) +  W1_DelayF: ​    ; Задержка 55 mcs 
-ldi XL, low(FREQ/​150000) +  ldi XH, high(FREQ/​150000) 
-rcall W1_Delay +  ldi XL, low(FREQ/​150000) 
-ret +  rcall W1_Delay 
-W1_DelayH: ​    ; Задержка 480 mcs +  ret 
-ldi XH, high(FREQ/​16664) +  W1_DelayH: ​    ; Задержка 480 mcs 
-ldi XL, low(FREQ/​16664) +  ldi XH, high(FREQ/​16664) 
-rcall W1_Delay +  ldi XL, low(FREQ/​16664) 
-ret +  rcall W1_Delay 
-W1_DelayI: ​    ; Задержка 70 mcs +  ret 
-ldi XH, high(FREQ/​116000) +  W1_DelayI: ​    ; Задержка 70 mcs 
-ldi XL, low(FREQ/​116000) +  ldi XH, high(FREQ/​116000) 
-rcall W1_Delay +  ldi XL, low(FREQ/​116000) 
-ret +  rcall W1_Delay 
-W1_DelayJ: ​    ; Задержка 410 mcs +  ret 
-ldi XH, high(FREQ/​19512) +  W1_DelayJ: ​    ; Задержка 410 mcs 
-ldi XL, low(FREQ/​19512) +  ldi XH, high(FREQ/​19512) 
-rcall W1_Delay +  ldi XL, low(FREQ/​19512) 
-ret +  rcall W1_Delay 
-W1_Delay: ​    ; Подпрограмма воспроизведения задержки +  ret 
-sbiw XH:XL, 1 ; Вычитаем единицу из регистровой пары +  W1_Delay: ​    ; Подпрограмма воспроизведения задержки 
-brne W1_Delay ; Если не равно 0 крутимся в цикле +  sbiw XH:XL, 1 ; Вычитаем единицу из регистровой пары 
-ret   ; Выход из подпрограммы +  brne W1_Delay ; Если не равно 0 крутимся в цикле 
-;​-------------------------------------------------------------------------------------------------------------- +  ret   ; Выход из подпрограммы 
-;​Конец_1-wire_подпрограмм +  ;​-------------------------------------------------------------------------------------------------------------- 
-</file+  ;​Конец_1-wire_подпрограмм 
 +</code> 
 +</hidden
 +\\
 ====Текст модуля hextobcd.asm==== ====Текст модуля hextobcd.asm====
-<file asm hextobcd.asm> +<hidden развернуть>​ 
-.def fASCIIL =r16 +<​code ​asm> 
-.def tASCII0 =r16 +  .def fASCIIL =r16 
-.def fASCIIH =r17 +  .def tASCII0 =r16 
-.def tASCII2 =r25 +  .def fASCIIH =r17 
-.def tASCII3 =r19 +  .def tASCII2 =r25 
-.def tASCII4 =r20 +  .def tASCII3 =r19 
-.def tASCII1 =r21 +  .def tASCII4 =r20 
-.def cnt16a =r21 +  .def tASCII1 =r21 
-.def tmp16a =r22 +  .def cnt16a =r21 
-.def tmp16b =r23 +  .def tmp16a =r22 
- +  .def tmp16b =r23 
-;***** Код +   
-print_ascii:​ +  ;***** Код 
-check1 r20 +  print_ascii:​ 
-check1 r19 +  check1 r20 
-check1 r25 +  check1 r19 
-check1 r21 +  check1 r25 
-check1 r16 +  check1 r21 
-ret +  check1 r16 
-bin2ASCII15:​  +  ret 
-ldi tmp16a, low(10000) +  bin2ASCII15:​  
-ldi tmp16b, high(10000) +  ldi tmp16a, low(10000) 
-rcall bin2ASCII_digit +  ldi tmp16b, high(10000) 
-mov tASCII4, cnt16a +  rcall bin2ASCII_digit 
-ldi tmp16a, low(1000) +  mov tASCII4, cnt16a 
-ldi tmp16b, high(1000) +  ldi tmp16a, low(1000) 
-rcall bin2ASCII_digit +  ldi tmp16b, high(1000) 
-mov tASCII3, cnt16a +  rcall bin2ASCII_digit 
-ldi tmp16a, low(100) +  mov tASCII3, cnt16a 
-ldi tmp16b, high(100) +  ldi tmp16a, low(100) 
-rcall bin2ASCII_digit +  ldi tmp16b, high(100) 
-mov tASCII2, cnt16a +  rcall bin2ASCII_digit 
-ldi tmp16a, low(10) +  mov tASCII2, cnt16a 
-ldi tmp16b, high(10) +  ldi tmp16a, low(10) 
-rcall bin2ASCII_digit +  ldi tmp16b, high(10) 
-ldi r17,0x30 +  rcall bin2ASCII_digit 
-add r16,r17 +  ldi r17,0x30 
-add r21,r17 +  add r16,r17 
-add r25,r17 +  add r21,r17 
-add r19,r17 +  add r25,r17 
-add r20,r17 +  add r19,r17 
-rcall print_ascii +  add r20,r17 
-ret +  rcall print_ascii 
-bin2ASCII_digit:​  +  ret 
-ldi cnt16a, -1 +  bin2ASCII_digit:​  
-bin2ASCII_digit_loop:​  +  ldi cnt16a, -1 
-inc cnt16a +  bin2ASCII_digit_loop:​  
-sub fASCIIL, tmp16a +  inc cnt16a 
-sbc fASCIIH, tmp16b +  sub fASCIIL, tmp16a 
-brsh bin2ASCII_digit_loop +  sbc fASCIIH, tmp16b 
-add fASCIIL, tmp16a +  brsh bin2ASCII_digit_loop 
-adc fASCIIH, tmp16b +  add fASCIIL, tmp16a 
- +  adc fASCIIH, tmp16b 
-ret +   
- +  ret 
-</file+</​code>​ 
 +</hidden
 +\\
 ====Текст модуля iterrupts.asm==== ====Текст модуля iterrupts.asm====
-<file asm iterrupts.asm> +<hidden развернуть>​ 
-;​Векторы_прерываний +<​code ​asm> 
-;​----------------------------------------------------------------------- +  ;​Векторы_прерываний 
- +  ;​----------------------------------------------------------------------- 
-.org 0x0000 ​   ; Reset +   
-jmp RESET +  .org 0x0000 ​   ; Reset 
-.org 0x0002 ​   ; External Interrupt Request 0 +  jmp RESET 
-reti +  .org 0x0002 ​   ; External Interrupt Request 0 
-.org 0x0004 ​   ; External Interrupt Request 1 +  reti 
-reti +  .org 0x0004 ​   ; External Interrupt Request 1 
-.org 0x0006 ​   ; Pin Change Interrupt Request 0 +  reti 
-reti +  .org 0x0006 ​   ; Pin Change Interrupt Request 0 
-.org 0x0008 ​   ; Pin Change Interrupt Request 1 +  reti 
-reti +  .org 0x0008 ​   ; Pin Change Interrupt Request 1 
-.org 0x000A ​   ; Pin Change Interrupt Request 2 +  reti 
-reti +  .org 0x000A ​   ; Pin Change Interrupt Request 2 
-.org 0x000C ​   ; Watchdog Time-out Interrupt +  reti 
-reti +  .org 0x000C ​   ; Watchdog Time-out Interrupt 
-.org 0x000E ​   ; Timer/​Counter 2 Compare Match A +  reti 
-reti +  .org 0x000E ​   ; Timer/​Counter 2 Compare Match A 
-.org 0x0010 ​   ; Timer/​Counter 2 Compare Match B +  reti 
-reti +  .org 0x0010 ​   ; Timer/​Counter 2 Compare Match B 
-.org 0x0012 ​   ; Timer/​Counter 2 Overflow +  reti 
-jmp Board_timer +  .org 0x0012 ​   ; Timer/​Counter 2 Overflow 
-.org 0x0014 ​   ; Timer/​Counter 1 Capture Event +  jmp Board_timer 
-reti +  .org 0x0014 ​   ; Timer/​Counter 1 Capture Event 
-.org 0x0016 ​   ; Timer/​Counter 1 Compare Match A +  reti 
-reti +  .org 0x0016 ​   ; Timer/​Counter 1 Compare Match A 
-.org 0x0018 ​   ; Timer/​Counter 1 Compare Match B +  reti 
-reti +  .org 0x0018 ​   ; Timer/​Counter 1 Compare Match B 
-.org 0x001A ​   ; Timer/​Counter 1 Overflow +  reti 
-rjmp W1_timer +  .org 0x001A ​   ; Timer/​Counter 1 Overflow 
-;reti +  rjmp W1_timer 
-.org 0x001C ​   ; Timer/​Counter 0 Compare Match A +  ;reti 
-reti +  .org 0x001C ​   ; Timer/​Counter 0 Compare Match A 
-.org 0x001E ​   ; Timer/​Counter 0 Compare Match B +  reti 
-reti +  .org 0x001E ​   ; Timer/​Counter 0 Compare Match B 
-.org 0x0020 ​   ; Timer/​Counter 0 Overflow +  reti 
-reti +  .org 0x0020 ​   ; Timer/​Counter 0 Overflow 
-.org 0x0022 ​   ; SPI Serial Transfer Complete +  reti 
-reti +  .org 0x0022 ​   ; SPI Serial Transfer Complete 
-.org 0x0024 ​   ; USART, Rx Complete +  reti 
-reti +  .org 0x0024 ​   ; USART, Rx Complete 
-.org 0x0026 ​   ; USART, UDR Empty +  reti 
-reti +  .org 0x0026 ​   ; USART, UDR Empty 
-.org 0x0028 ​   ; USART, Tx Complete +  reti 
-reti +  .org 0x0028 ​   ; USART, Tx Complete 
-.org 0x002A ​   ; ADC Conversion Complete +  reti 
-jmp adc_conv +  .org 0x002A ​   ; ADC Conversion Complete 
-.org 0x002C ​   ; EEPROM Ready +  jmp adc_conv 
-reti +  .org 0x002C ​   ; EEPROM Ready 
-.org 0x002E ​   ; Analog Comparator +  reti 
-reti +  .org 0x002E ​   ; Analog Comparator 
-.org 0x0030 ​   ; Two-wire Serial Interface +  reti 
-jmp TWI_int +  .org 0x0030 ​   ; Two-wire Serial Interface 
-;reti +  jmp TWI_int 
-.org 0x0032 ​   ; Store Program Memory Read +  ;reti 
-reti +  .org 0x0032 ​   ; Store Program Memory Read 
- +  reti 
-.org INT_VECTORS_SIZE +   
-</file+  .org INT_VECTORS_SIZE 
- +</code
 +</​hidden>​ 
 +\\
 ====Текст модуля macr.asm==== ====Текст модуля macr.asm====
-<file asm macr.asm+<hidden развернуть
- +<code asm> 
-;​Макросы +  ;​Макросы 
-;​----------------------------------------------------------------------- +  ;​----------------------------------------------------------------------- 
-.macro pushf +  .macro pushf 
-push r10 +  push r10 
-in r10,SREG +  in r10,SREG 
-push r10 +  push r10 
-.endm +  .endm 
-.macro popf +  .macro popf 
-pop r10 +  pop r10 
-out SREG,r10 +  out SREG,r10 
-pop r10 +  pop r10 
-.endm +  .endm 
-.macro pushr +  .macro pushr 
-push r10 +  push r10 
-in r10,SREG +  in r10,SREG 
-push r10 +  push r10 
-push r16 +  push r16 
-push r17 +  push r17 
-push r18 +  push r18 
-push r19 +  push r19 
-push r20 +  push r20 
-push r21 +  push r21 
-push r22 +  push r22 
-push r23 +  push r23 
-push r25 +  push r25 
-push r26 +  push r26 
-push r27 +  push r27 
-push r28 +  push r28 
-push r29 +  push r29 
-.endm +  .endm 
-.macro popr +  .macro popr 
-pop r29 +  pop r29 
-pop r28 +  pop r28 
-pop r27 +  pop r27 
-pop r26 +  pop r26 
-pop r25 +  pop r25 
-pop r23  +  pop r23  
-pop r22 +  pop r22 
-pop r21 +  pop r21 
-pop r20 +  pop r20 
-pop r19 +  pop r19 
-pop r18 +  pop r18 
-pop r17 +  pop r17 
-pop r16 +  pop r16 
-pop r10 +  pop r10 
-out SREG,r10 +  out SREG,r10 
-pop r10 +  pop r10 
-.endm +  .endm 
-.macro check +  .macro check 
-push @0 +  push @0 
-lds @0,@1 +  lds @0,@1 
-sts UDR0,@0 +  sts UDR0,@0 
-check_loop: ldi @0,UCSR0A +  check_loop: ldi @0,UCSR0A 
-sbrs @0,TXC0 +  sbrs @0,TXC0 
-rjmp check_loop +  rjmp check_loop 
-pop @0 +  pop @0 
-rcall Delay +  rcall Delay 
-.endm +  .endm 
- +   
-.macro check_kosv +  .macro check_kosv 
-push @0 +  push @0 
-ld @0,@1 +  ld @0,@1 
-sts UDR0,@0 +  sts UDR0,@0 
-check_loop1:​ ldi @0,UCSR0A +  check_loop1:​ ldi @0,UCSR0A 
-sbrs @0,TXC0 +  sbrs @0,TXC0 
-rjmp check_loop1 +  rjmp check_loop1 
-pop @0 +  pop @0 
-rcall Delay +  rcall Delay 
-.endm +  .endm 
-.macro check1 +  .macro check1 
-sts UDR0,@0 +  sts UDR0,@0 
-check_loop1:​ ldi @0,UCSR0A +  check_loop1:​ ldi @0,UCSR0A 
-sbrs @0,TXC0 +  sbrs @0,TXC0 
-rjmp check_loop1 +  rjmp check_loop1 
-rcall Delay +  rcall Delay 
-.endm +  .endm 
- +   
-.macro tabulate +  .macro tabulate 
-push r16 +  push r16 
-ldi r16,0x09 +  ldi r16,0x09 
-check1 r16 +  check1 r16 
-pop r16 +  pop r16 
-.endm +  .endm 
-.macro newline +  .macro newline 
-push r16 +  push r16 
-ldi r16,0x0D +  ldi r16,0x0D 
-check1 r16 +  check1 r16 
-ldi r16,0x0A +  ldi r16,0x0A 
-check1 r16 +  check1 r16 
-pop r16 +  pop r16 
-.endm +  .endm 
-</file>+</code> 
 +</hidden>
  
 +\\
 ====Текст модуля twi_lib.asm==== ====Текст модуля twi_lib.asm====
-<file asm twi_lib.asm>+<hidden развернуть>​ 
 +<​code ​asm>
  
-;​Библиотека_TWI +  ​;​Библиотека_TWI 
-;​----------------------------------------------------------------------- +  ;​----------------------------------------------------------------------- 
- +   
-;======= Стартовая посылка по шине i2c ================================================= +  ;======= Стартовая посылка по шине i2c ================================================= 
-i2c_start:​ +  i2c_start:​ 
-push r16  +  push r16  
-ldi r16,​(1<<​TWINT)|(1<<​TWSTA)|(1<<​TWEN)|(1<<​TWIE) ; Выполняем посылку стартовой комбинации +  ldi r16,​(1<<​TWINT)|(1<<​TWSTA)|(1<<​TWEN)|(1<<​TWIE) ; Выполняем посылку стартовой комбинации 
-sts TWCR,r16 ; Посылаем полученный байт в TWCR +  sts TWCR,r16 ; Посылаем полученный байт в TWCR 
-rcall i2c_wait ; Ожидание формирования start в блоке TWI +  rcall i2c_wait ; Ожидание формирования start в блоке TWI 
-pop r16 ; Возвращаем данные в r16 из стека +  pop r16 ; Возвращаем данные в r16 из стека 
-ret +  ret 
-;======= Стоповая посылка по шине i2c ================================================== +  ;======= Стоповая посылка по шине i2c ================================================== 
-i2c_stop: +  i2c_stop: 
-push r16  +  push r16  
-ldi r16,​(1<<​TWINT)|(1<<​TWSTO)|(1<<​TWEN) ; Отправляем стоповую посылку +  ldi r16,​(1<<​TWINT)|(1<<​TWSTO)|(1<<​TWEN) ; Отправляем стоповую посылку 
-sts TWCR,r16 ; Посылаем полученный байт в TWCR +  sts TWCR,r16 ; Посылаем полученный байт в TWCR 
-pop r16 ; Возвращаем данные в r16 из стека +  pop r16 ; Возвращаем данные в r16 из стека 
-ret +  ret 
-;======= Посылка байта информации по шине i2c ========================================== +  ;======= Посылка байта информации по шине i2c ========================================== 
-i2c_send: +  i2c_send: 
-push r16 +  push r16 
-sts TWDR,r16 ; Записываем передаваемый байт в регистр TWDR +  sts TWDR,r16 ; Записываем передаваемый байт в регистр TWDR 
-ldi r16,​(1<<​TWINT)|(1<<​TWEN)|(1<<​TWIE) ; Формируем байт, отвечающий  +  ldi r16,​(1<<​TWINT)|(1<<​TWEN)|(1<<​TWIE) ; Формируем байт, отвечающий  
-; за пересылку информационного байта +  ; за пересылку информационного байта 
-sts TWCR,r16 ; Посылаем полученный байт в TWCR +  sts TWCR,r16 ; Посылаем полученный байт в TWCR 
-rcall i2c_wait ; Ожидание окончания пересылки байта +  rcall i2c_wait ; Ожидание окончания пересылки байта 
-pop r16 ; Возвращаем данные в r16 из стека +  pop r16 ; Возвращаем данные в r16 из стека 
-ret +  ret 
-;======= Приём информационного байта по шине i2c ======================================= +  ;======= Приём информационного байта по шине i2c ======================================= 
-i2c_receive:​ +  i2c_receive:​ 
-; Принятый байт помещается в регистр r16, поэтому рекомендуется  +  ; Принятый байт помещается в регистр r16, поэтому рекомендуется  
-; продумать программу так, чтобы в этот момент в нём не было  +  ; продумать программу так, чтобы в этот момент в нём не было  
-; важной информации,​ байт не сохраняется в стеке в коде данной  +  ; важной информации,​ байт не сохраняется в стеке в коде данной  
-; процедуры +  ; процедуры 
-ldi r16,​(1<<​TWINT)|(1<<​TWEN)|(1<<​TWEA)|(1<<​TWIE) ; Формируем байт, отвечающий за прием  +  ldi r16,​(1<<​TWINT)|(1<<​TWEN)|(1<<​TWEA)|(1<<​TWIE) ; Формируем байт, отвечающий за прием  
-sts TWCR,r16 ; Посылаем полученный байт в TWCR +  sts TWCR,r16 ; Посылаем полученный байт в TWCR 
-rcall i2c_wait ; Ожидание окончания приёма байта +  rcall i2c_wait ; Ожидание окончания приёма байта 
-lds r16,TWDR ; Считываем полученную информацию из TWDR +  lds r16,TWDR ; Считываем полученную информацию из TWDR 
-ret +  ret 
-;======= Приём последнего байта (NACK) ================================================= +  ;======= Приём последнего байта (NACK) ================================================= 
-i2c_receive_last:​ +  i2c_receive_last:​ 
-; Принятый байт помещается в регистр r16, поэтому рекомендуется  +  ; Принятый байт помещается в регистр r16, поэтому рекомендуется  
-; продумать программу так, чтобы в этот момент в нём не было  +  ; продумать программу так, чтобы в этот момент в нём не было  
-; важной информации,​ байт не сохраняется в стеке в коде данной  +  ; важной информации,​ байт не сохраняется в стеке в коде данной  
-; процедуры +  ; процедуры 
-ldi r16,​(1<<​TWINT)|(1<<​TWEN)|(1<<​TWIE) ; Формируем байт, отвечающий за прием информационного байта +  ldi r16,​(1<<​TWINT)|(1<<​TWEN)|(1<<​TWIE) ; Формируем байт, отвечающий за прием информационного байта 
-sts TWCR,r16 ; Посылаем полученный байт в TWCR +  sts TWCR,r16 ; Посылаем полученный байт в TWCR 
-rcall i2c_wait ; Ожидание окончания приёма байта +  rcall i2c_wait ; Ожидание окончания приёма байта 
-lds r16,TWDR ; Считываем полученную информацию из TWDR +  lds r16,TWDR ; Считываем полученную информацию из TWDR 
-ret +  ret 
-;======= Ожидание готовности TWI ======================================================= +  ;======= Ожидание готовности TWI ======================================================= 
-i2c_wait: +  i2c_wait: 
-lds r16,TWCR ; Загружаем значение из TWCR в r16 +  lds r16,TWCR ; Загружаем значение из TWCR в r16 
-sbrs r16,TWINT ; Функция ожидания выполняется до тех пор, пока поднят флаг  +  sbrs r16,TWINT ; Функция ожидания выполняется до тех пор, пока поднят флаг  
-; прерывания в 1 +  ; прерывания в 1 
-rjmp i2c_wait +  rjmp i2c_wait 
-ret +  ret 
-;​======================================================================================= +  ;​======================================================================================= 
-</file>+</code> 
 +</hidden>
doc/1201/643.mgul.12013-01_12_01.1487788859.txt.gz · Последние изменения: 2018/04/28 23:47 (внешнее изменение)