КОРЗИНА
магазина
8 (499) 500-14-56 | ПН. - ПТ. 12:00-18:00
ЛЕСНОРЯДСКИЙ ПЕРЕУЛОК, 18С2, БЦ "ДМ-ПРЕСС"

Четырехразрядный индикатор LED, FLASH-I2C - Datasheet

Trema модуль - Четырехразрядный индикатор LED, FLASH-I2C.

Техническое описание: Данная страница содержит подробное техническое описание Trema модуля - Четырехразрядный индикатор LED, FLASH-I2C и раскрывает работу с модулем через его регистры.

Ознакомиться с пользовательским описанием модуля и примерами работы с библиотекой iarduino_I2C_4LED можно на странице Wiki - Четырехразрядный индикатор LED, FLASH-I2C.

Назначение:

Trema модуль - Четырехразрядный индикатор LED, FLASH-I2C - является устройством вывода информации получаемой по шине I2С.

К одной шине I2C можно подключить более 100 модулей. Адрес модуля на шине I2C (по умолчанию 0x09) назначается программно и хранится в его энергонезависимой памяти.

Описание:

Модуль построен на базе четырёхразрядного светодиодного индикатора, микроконтроллера STM32F030K6 и снабжён собственным стабилизатором напряжения. Модуль способен выводить числа (в том числе и отрицательные), время, температуру и некоторые символы. Запись выводимых данных в модуль осуществляется через его регистры. Доступ к регистрам модуля осуществляется по шине I2C.

С помощью регистров модуля можно выполнять следующие действия:

  • Изменить адрес данного модуля на шине I2C. При изменении адреса, можно указать, что новый адрес должен сохраниться в flash память модуля, а значит адрес сохранится и после отключения питания.
  • Включить / отключить внутреннюю подтяжку линий шины I2C (по умолчанию включена). Состояние подтяжки линий шины I2C автоматически сохраняется в flash память модуля, а значит состояние линий сохранится после отключения и включения питания.
  • Узнать версию прошивки модуля.
  • Указать частоту обновления информации дисплея, от 1 до 255 Гц.
  • Указать яркость свечения всех сегментов дисплея, от 0 до 255 с шагом 8.
  • Указать схему включения светодиодов индикатора: общий анод или катод.
  • Задать вывод изображения с поворотом на 180°.
  • Включать и выключать любой сегмент (светодиод) любого разряда индикатора.
  • Указать любому разряду индикатора мигать включёнными сегментами с заданной частотой.

Выводы модуля:

На плате модуля расположен разъем из 4 выводов для подключения к шине I2C:

  • SCL - вход/выход линии тактирования шины I2C.
  • SDA - вход/выход линии данных шины I2C.
  • Vcc - вход питания логической части драйвера 3,3 или 5 В.
  • GND - общий вывод питания.

Характеристики:

  • Напряжение питания: 3,3 В или 5 В, поддерживаются оба напряжения.
  • Ток потребляемый модулем: до 10 мА.
  • Интерфейс: I2C.
  • Скорость шины I2C: 100 кбит/с.
  • Адрес на шине I2C: устанавливается программно (по умолчанию 0x09).
  • Уровень логической 1 на линиях шины I2C: Vcc.
  • Количество разрядов индикатора: 4.
  • Частота обновления выводимых данных: от 1 до 255 Гц.
  • Рабочая температура: от -20 до +70 °С.
  • Габариты: 30 х 30 мм.
  • Вес: 15 г.

Установка адреса:

Trema модуль - Четырехразрядный индикатор LED, FLASH-I2C относится к серии «Flash» модулей. Все модули данной серии позволяют назначать себе адрес для шины I2C, как временно (новый адрес действует пока есть питание), так и постоянно (новый адрес сохраняется в энергонезависимую память и действует даже после отключения питания). По умолчанию все модули серии «Flash» поставляются с адресом 0x09.

Допускается указывать адреса в диапазоне: 7 < адрес < 127.

Установка адреса (без сохранения):

Если в регистр 0x06 «ADDRESS» записать значение из 7 бит адреса и младшим битом «SAVE_FLASH» равным 0, то указанный адрес станет адресом модуля на шине I2C, но он не сохранится во FLASH памяти, а значит после отключения питания, установится прежний адрес модуля.

Установка адреса (с сохранением):

Для установки адреса с его сохранением в FLASH память модуля необходимо выполнить два действия:

  • Установить бит «SAVE_ADR_EN» в регистре 0x01 «BITS_0» (при этом адрес модуля останется прежним).
  • Записать в регистр 0x06 «ADDRESS» значение из 7 бит адреса и младшим битом «SAVE_FLASH» равным 1.
  • Если не выполнить первое действие (не установить бит «SAVE_ADR_EN»), то новый адрес будет проигнорирован и у модуля останется старый адрес.
  • ВАЖНО: запись адреса занимает не менее 30 мс. После сохранения адреса бит «SAVE_ADR_EN» в регистре 0x01 «BITS_0» самостоятельно сбросится в 0.

Регистры:

Карта регистров модуля:

адрес76543210
0x00 FLG_RESET FLG_SELF_TEST - - - FLG_I2C_UP - -
0x01 SET_RESET SET_SELF_TEST - - - SET_I2C_UP SAVE_ADR_EN -
0x02
0x03
RESERVED
0x04 MODEL[7-0]
0x05 VERSION[7-0]
0x06 ADDRESS[6-0] SAVE_FLASH
0x07 CHIP_ID[7-0]
0x08 FREQUENCY[7-0]
0x09 BRIGHTNESS[7-0]
0x0A
---
0x0F
RESERVED
адрес76543210
0x10 FLG_CA BIT_SAVE_CA - - - - - BIT_TURN
0x11 BIT_FREQUENCY[2-0] - BIT_DEG_4 BIT_DEG_3 BIT_DEG_2 BIT_DEG_1 BIT_DEG_0
0x12 SEG_0A SEG_0B SEG_0C SEG_0D SEG_0E SEG_0F SEG_0G SEG_0H
0x13 SEG_1A SEG_1B SEG_1C SEG_1D SEG_1E SEG_1F SEG_1G SEG_1H
0x14 SEG_2A SEG_2B SEG_2C SEG_2D SEG_2E SEG_2F SEG_2G SEG_2H
0x15 SEG_3A SEG_3B SEG_3C SEG_3D SEG_3E SEG_3F SEG_3G SEG_3H
0x16 - - - - - - SEG_4P_UP SEG_4P_DN

Регистры с адресами 0x02, 0x03, 0x0A - 0x0F зарезервированы, их биты сброшены в 0. Попытка записи данных в эти регистры будет проигнорирована модулем.

Регистр 0x00 «FLAGS_0» - содержит флаги чтения состояния модуля:

Регистр только для чтения.

  • FLG_RESET - Флаг указывает на факт выполнения успешной перезагрузки модуля. Флаг самостоятельно сбрасывается после чтения регистра 0x00 «FLAGS_0».
  • FLG_SELF_TEST - Флаг указывает на результат выполнения самотестирования модуля (0-провал, 1-успех). Не поддерживается данным модулем.
  • FLG_I2C_UP - Флаг указывает на то, что модуль позволяет управлять подтяжкой линий шины I2C при помощи бита «SET_I2C_UP» регистра 0x01 «BITS_0».

Регистр 0x01 «BITS_0» - содержит биты установки состояния модуля:

Регистр для записи и чтения.

  • SET_RESET - Бит запускает программную перезагрузку модуля. О завершении перезагрузки свидетельствует установка флага «FLG_RESET» регистра 0x00 «FLAGS_0».
  • SET_SELF_TEST - Бит запускает самотестирование модуля. При успешном завершении самотестирования устанавливается флаг «FLG_SELF_TEST » регистра 0x00 «FLAGS_0». Не поддерживается данным модулем.
  • SET_I2C_UP - Бит управляет внутрисхемной подтяжкой линий шины I2C. Значение бита сохраняется в FLASH память модуля. Установка бита в «1» приведёт к подтяжке линий SDA и SCL до уровня 3,3 В. На линии I2C допускается устанавливать внешние подтягивающие резисторы и иные модули с подтяжкой до уровня 3,3 В или 5 В, вне зависимости от состояния текущего бита. Если флаг «FLG_I2C_UP» регистра 0x00 «FLAGS_0» сброшен, значит управление подтяжкой не поддерживается модулем.
  • SAVE_ADR_EN - Бит разрешает записать новый адрес модуля для шины I2C в FLASH память. Бит самостоятельно сбрасывается после сохранения адреса во FLASH память. Запись адреса выполняется следующим образом: нужно установить бит «SAVE_ADR_EN», после чего записать новый адрес в регистр 0x06 «ADDRESS» с установленным битом «SAVE_FLASH».

Регистр 0x04 «MODEL» - содержит идентификатор типа модуля:

Регистр только для чтения.

Регистр 0x05 «VERSION» - содержит версию прошивки модуля:

Регистр только для чтения.

  • VERSION[7-0] - Версия прошивки (от 0x01 до 0xFF).

Регистр 0x06 «ADDRESS» - отвечает за чтение/установку адреса модуля на шине I2C:

Регистр для чтения и записи.

  • ADDRESS[6-0] - 7 бит адреса модуля на шине I2C. При чтении возвращается текущий адрес модуля, при записи устанавливается указанный адрес модулю. Допускается указывать адреса в диапазоне: 7 < адрес < 127.
  • SAVE_FLASH - Флаг записи адреса в FLASH память модуля.
    Флаг имеет значение только при записи данных в регистр.
    Если флаг сброшен, то адрес в битах ADDRESS[6-0] будет установлен временно (до отключения питания, или сброса/записи нового адреса). Если флаг установлен, то адрес в битах ADDRESS[6-0] будет сохранён в FLASH память модуля (останется и после отключения питания), но только если в бите «SAVE_ADR_EN» регистра 0x01 «BITS_0» установлена логическая 1. Если флаг «SAVE_FLASH» установлен, а бит «SAVE_ADR_EN» сброшен, то адрес в битах ADDRESS[6-0] не будет установлен ни временно, ни постоянно.

Регистр 0x07 «CHIP_ID» - содержит идентификатор общий для всех модулей серии «Flash»:

Регистр только для чтения.

У всех модулей серии «Flash» в регистре «CHIP_ID» содержится значение 0x3C. Если требуется отличить модули серии «Flash» на шине I2C от сторонних модулей, то достаточно прочитать значение регистров 0x06 «ADDRESS» и 0x07 «CHIP_ID» всех модулей на шине I2C. Если 7 старших битов регистра 0x06 «ADDRESS» хранят адрес совпадающий с адресом модуля, а в регистре 0x07 «CHIP_ID» хранится значение 0x3C, то можно с большой долей вероятности утверждать, что данный модуль является модулем серии «Flash».

Регистры 0x08 «FREQUENCY» - содержит частоту обновления дисплея:

Регистр только для записи.

  • FREQUENCY[7-0] - Частота обновления данных отображаемых на дисплее в диапазоне от 1 до 255 Гц. Значение по умолчанию 0x64 = 100 Гц.
    Если записать значение 0x00 то в регистре появится 0x01 и частота будет 1 Гц.
  • Светодиоды индикатора светятся не одновременно, а поочерёдно включаются и выключаются так, что в любой момент времени может светиться только один светодиод.

Регистр 0x09 «BRIGHTNESS» - содержит значение яркости дисплея:

Регистр только для записи.

  • BRIGHTNESS[7-0] - Число от 0 до 255 задаёт яркость свечения всех светодиодов индикатора.
    Значение по умолчанию 0xС0 = 75%.
  • Три младших бита регистра не учитываются, это значит что яркость меняется от 0 до 255 с шагом 8. Пример: 0...7 - индикатор не светится, 8...15 - индикатор работает с минимальной яркостью, 248...255 - индикатор работает на максимальной яркости.

Регистр 0x10 «FLG» - содержит статусные флаги индикатора:

Регистр для чтения и записи.

  • FLG_CA - Флаг указывает на то, что светодиоды индикатора подключены по схеме с общим анодом. Если флаг сброшен, значит светодиоды подключены по схеме с общим катодом.
  • BIT_SAVE_CA - Бит разрешает запись флага «FLG_CA». Флаг «FLG_CA» не изменит своё значение, если при записи будет сброшен бит «BIT_SAVE_CA».
  • BIT_TURN - Бит указывает развернуть изображение дисплея на 180°.

Регистр 0x11 «BLINK» - содержит биты управления миганием:

Регистр для чтения и записи.

  • BIT_FREQUENCY[1-0] - Биты определяют частоту мигания разрядов индикатора от 1 до 4 Гц.
    (00)2 - 1 Гц, (01)2 - 2 Гц, (10)2 - 3 Гц, (11)2- 4 Гц. Значение по умолчанию: (00)2 - 1 Гц.
  • BIT_DEG_0 - Бит заставляет мигать все включённые светодиоды 1 знака (левого).
  • BIT_DEG_1 - Бит заставляет мигать все включённые светодиоды 2 знака.
  • BIT_DEG_2 - Бит заставляет мигать все включённые светодиоды 3 знака.
  • BIT_DEG_3 - Бит заставляет мигать все включённые светодиоды 4 знака (правого).
  • BIT_DEG_4 - Бит заставляет мигать все включённые светодиоды двоеточия.

Регистр 0x12 «REG_DEG_0» - управляет светодиодами 1 знака:

Регистр 0x13 «REG_DEG_1» - управляет светодиодами 2 знака:

Регистр 0x14 «REG_DEG_2» - управляет светодиодами 3 знака:

Регистр 0x15 «REG_DEG_3» - управляет светодиодами 4 знака:

Регистры для чтения и записи.

  • BIT_SEG_A - Бит включает сегмент «A».
  • BIT_SEG_B - Бит включает сегмент «B».
  • BIT_SEG_C - Бит включает сегмент «C».
  • BIT_SEG_D - Бит включает сегмент «D».
  • BIT_SEG_E - Бит включает сегмент «E».
  • BIT_SEG_F - Бит включает сегмент «F».
  • BIT_SEG_G - Бит включает сегмент «G».
  • BIT_SEG_H - Бит включает сегмент «H».

Регистр 0x16 «REG_DEG_4» - управляет светодиодами двоеточия:

Регистр для чтения и записи.

  • BIT_SEG_P_UP - Бит включает верхнюю точку двоеточия.
  • BIT_SEG_P_DN - Бит включает нижнюю точку двоеточия.

Доступ к данным регистров:

Каждый регистр модуля хранит 1 байт данных. Так как модуль использует интерфейс передачи данных I2C, то и доступ к данным охарактеризован им.

Обмен данными по шине I2C происходит по одному биту за один такт, после каждых переданных 8 бит (1 байта) принимающее устройство отвечает передающему одним битом: «ACK» в случае успешного приёма, или «NACK» в случае ошибки. Пакет приёма/передачи данных начинается сигналом «START» и завершается сигналом «STOP». Первый байт пакета всегда состоит из 7 бит адреса устройства и одного (младшего) бита R/W.

Сигналы интерфейса передачи данных I2C:

    Для удобства восприятия сигналов они выполнены в следующих цветах:
  • Зелёный - сигналы формируемые мастером.
  • Красный - данные отправляемые мастером.
  • Синий - данные отправляемые модулем.
  • Фиолетовый - данные отправляемые мастером или модулем.
  • «START» - отправляется мастером в начале пакета приема/передачи данных. Сигнал представляет переход уровня линии «SDA» из «1» в «0» при наличии «1» на линии «SCL».
  • «STOP» - отправляется мастером в конце пакета приёма/передачи данных. Сигнал представляет переход уровня линии «SDA» из «0» в «1» при наличии «1» на линии «SCL».
  • БИТ - значение бита считывается с линии «SDA» по фронту импульса на линии «SCL».
  • «ACK» - бит равный 0, отправляется после успешного приёма байта данных.
  • «NACK» - бит равный 1, отправляется после байта данных в случае ошибки.
  • ПЕРВЫЙ БАЙТ - отправляется мастером, состоит из 7 бит адреса и бита «RW».
  • «R/W» - младший бит первого байта данных указывает направление передачи данных пакета, 1 - прием (от модуля к мастеру), 0 - передача (от мастера в модуль).
  • «RESTART» - повторный старт, отправляется мастером внутри пакета. Сигнал представляет из себя «START» отправленный не на свободной шине, а внутри пакета.

ВАЖНО: Все изменения на линии «SDA» должны происходить только при наличии «0» на линии «SCL» за исключением сигналов «START», «STOP» и «RESTART».

    Запись данных в регистры:

    • Отправляем сигнал «START».
    • Отправляем первый байт: 7 бит адреса модуля и бит «R/W» равный 0 (запись).
      Получаем ответ от модуля в виде одного бита «ACK».
    • Отправляем второй байт: адрес регистра в который будет произведена запись.
      Получаем ответ от модуля в виде одного бита «ACK».
    • Отправляем третий байт: данные для записи в регистр.
      Получаем ответ от модуля в виде одного бита «ACK».
    • Далее можно отправить четвёртый байт данных для записи в следующий по порядку регистр и т.д.
    • Отправляем сигнал «STOP».

    Пример записи в один регистр:

    Запись значения 0x2A в регистр 0x06 модуля с адресом 0x09:

                                     // Запись в регистр методами библиотеки Wire.h
    Wire.beginTransmission(0x09);    // Инициируем передачу данных в устройство с адресом 0x09.
    Wire.write(0x06);                // Записываем в буфер байт адреса регистра.
    Wire.write(0x26);                // Записываем в буфер байт который будет записан в регистр.
    Wire.endTransmission();          // Выполняем передачу адреса и байтов из буфера. Функция возвращает: 0-передача успешна / 1 - переполнен буфер для передачи / 2 - получен NACK при передаче адреса / 3 - получен NACK при передаче данных / 4 - другая ошибка.
    

    Пример записи в несколько регистров подряд:

    Запись в модуль с адресом 0x09 нескольких значений начиная с регистра 0x12:
    В регистр 0x12 запишется значение 0x0F, в следующий по порядку регистр (0x13) запишется значение 0x30 и в следующий по порядку регистр (0x14) запишется значение 0xB1.

                                     // Запись в регистры методами библиотеки Wire.h
    byte data[3] = {0x0F,0x30,0xB1}; // Определяем массив с данными для передачи.
    Wire.beginTransmission(0x09);    // Инициируем передачу данных в устройство с адресом 0x09.
    Wire.write(0x12);                // Записываем в буфер байт адреса первого регистра.
    Wire.write(data, 3);             // Записываем в буфер 3 байта из массива data.
    Wire.endTransmission();          // Выполняем передачу адреса и байт из буфера. Функция возвращает: 0-передача успешна / 1 - переполнен буфер для передачи / 2 - получен NACK при передаче адреса / 3 - получен NACK при передаче данных / 4 - другая ошибка.

    Чтение данных из регистров:

    • При чтении пакет делится на 2 части: запись № регистра и чтение его данных.
    • Отправляем сигнал «START».
    • Отправляем первый байт: 7 бит адреса модуля и бит «R/W» равный 0 (запись).
      Получаем ответ от модуля в виде одного бита «ACK».
    • Отправляем второй байт: адрес регистра из которого нужно прочитать данные.
      Получаем ответ от модуля в виде одного бита «ACK».
    • Отправляем сигнал «RESTART».
    • Отправляем первый байт после «RESTART»: 7 бит адреса и бит «R/W» равный 1 (чтение).
      Получаем ответ от модуля в виде одного бита «ACK».
    • Получаем байт данных из регистра модуля.
      Отвечаем битом «ACK» если хотим прочитать следующий регистр, иначе отвечаем «NACK».
    • Отправляем сигнал «STOP».

    Пример чтения одного регистра:

    Чтение из модуля с адресом 0x09 байта данных регистра 0x05:
    (в примере модуль вернул значение 0x01).

                                     // Чтение регистра методами библиотеки Wire.h
    byte data;                       // Объявляем переменную для чтения байта данных.
    Wire.beginTransmission(0x09);    // Инициируем передачу данных в устройство с адресом 0x09.
    Wire.write(0x05);                // Записываем в буфер байт адреса регистра.
    Wire.endTransmission(false);     // Выполняем передачу без установки состояния STOP.
    Wire.requestFrom(0x09, 1);       // Читаем 1 байт из устройства с адресом 0x09. Функция возвращает количество реально принятых байтов. Так как предыдущая функция не установила состояние STOP, то состояние START установленное данной функцией будет расценено как RESTART.
    data=wire.read();                // Сохраняем прочитанный байт в переменную data.

    Пример чтения нескольких регистров подряд:

    Чтение из модуля с адресом 0x09 нескольких регистров начиная с регистра 0x05:
    (в примере модуль вернул значения: 0x01 из рег. 0x05, 0x13 из рег. 0x06, 0xC3 из рег. 0x07).

                                     // Чтение регистров методами библиотеки Wire.h
    byte data[3];                    // Объявляем массив для чтения данных.
    Wire.beginTransmission(0x09);    // Инициируем передачу данных в устройство с адресом 0x09.
    Wire.write(0x05);                // Записываем в буфер байт адреса регистра.
    Wire.endTransmission(false);     // Выполняем передачу без установки состояния STOP.
    Wire.requestFrom(0x09, 3);       // Читаем 3 байта из устройства с адресом 0x09. Функция возвращает количество реально принятых байтов. Так как предыдущая функция не установила состояние STOP, то состояние START установленное данной функцией будет расценено как RESTART.
    int i=0;                         // Определяем счётчик номера прочитанного байта.
    while( Wire.available() ){       // Выполняем цикл while пока есть что читать из буфера.
      if(i<3){                       // Лучше делать такую проверку, чтоб не записать данные за пределы массива data!
        data[i] = wire.read(); i++;  // Читаем очередной байт из буфера в массив data.
      }                              //
    }                                //

    Примечание:

    • Если на линии I2C только один мастер, то сигнал «RESTART» можно заменить на сигналы «STOP» и «START».
    • Рекомендуется не выполнять чтение или запись данных чаще 200 раз в секунду.
      Обратите внимание на сигналы «RESTART» и «STOP» в пакетах чтения данных:
    • Между фронтом и спадом сигнала «RESTART» проходит фронт импульса на линии «SCL», что расценивается как передача бита равного 1.
    • Между сигналом «NACK» и сигналом «STOP» проходит фронт импульса на линии «SCL», что расценивается как передача бита равного 0.
    • Эти биты не сохраняются в модулях и не расцениваются как ошибки.

    Модуль не поддерживает горячее подключение: Подключайте модуль только при отсутствии питания и данных на шине I2C. В противном случае потребуется отключить питание при уже подключённом модуле.

    Пример вывода времени прошедшего после старта:

    Следующий скетч демонстрирует вывод секунд прошедших со старта скетча.

    #include <Wire.h>                         // Подключаем библиотеку Wire для работы с шиной I2C.
    const int ADDRESS = 0x09;                 // Определяем адрес модуля.
    const int REG_DEG = 0x12;                 // Определяем адрес регистра управляющего сегментами 1 знака.
    uint8_t   i[10]   =                       // Определяем массив i состоящий из 10 элементов, где ...
    {252,96,218,242,102,182,190,224,254,246}; // Каждый элемент содержит биты для вывода чисел 0-9.
                                              //
    void setup(){                             //
        Wire.setClock(100000L);               // Устанавливаем скорость передачи данных по шине I2C.
        Wire.begin();                         // Инициируем работу c шиной I2C в качестве мастера.
    }                                         //
                                              //
    void loop(){                              //
    //  Определяем прошедшее время:           //
        uint16_t j = millis()/1000 % 10000;   // Получаем время в секундах прошедшее с момента старта скетча, но не более 9999 секунд.
    //  Выводим данные на индикатор:          //
        Wire.beginTransmission(ADDRESS);      // Инициируем передачу данных по шине I2C к устройству с адресом ADDRESS и битом RW=0 (запись). При этом сама передача не начнётся.
        Wire.write( REG_DEG   );              // Функция write() помещает значение своего аргумента в буфер для передачи. В данном случае это номер регистра REG_DEG.
        Wire.write( i[j/1000] ); j%=1000;     // Функция write() помещает значение своего аргумента в буфер для передачи. В данном случае это число выводимое в 1 позицию индикатора.
        Wire.write( i[j/ 100] ); j%= 100;     // Функция write() помещает значение своего аргумента в буфер для передачи. В данном случае это число выводимое в 2 позицию индикатора.
        Wire.write( i[j/  10] ); j%=  10;     // Функция write() помещает значение своего аргумента в буфер для передачи. В данном случае это число выводимое в 3 позицию индикатора.
        Wire.write( i[j     ] );              // Функция write() помещает значение своего аргумента в буфер для передачи. В данном случае это число выводимое в 4 позицию индикатора.
        Wire.endTransmission ();              // Выполняем инициированную ранее передачу данных.
        delay(100);                           //
    }                                         //

    Габариты:

    Все модули линейки "Trema" выполнены в одном формате:

    Ссылки:




    Обсуждение

    Гарантии и возврат Используя сайт Вы соглашаетесь с условями