UART (Universal Asynchronous Receiver/Transmitter) — универсальный асинхронный приёмопередатчик, интерфейс для связи цифровых устройств, предназначенный для передачи данных в последовательной форме. Очень распространён и весьма востребован, имеет аппаратную реализацию во многих микроконтроллерах (Wiki).
Pi4J предоставляет возможность работы с UART из Java. Все классы и интерфейсы для инициализации и работы с последовательным портом находятся в пакете com.pi4j.io.serial.*;
.
Если вы ещё не установили Pi4J переходите на страницу Установка Pi4J на Raspberry Pi и Orange Pi, Banana Pi.
Внимание:
Всегда помните, что логические уровни сигнала шины GPIO составляет 3.3 В и использование сигналов с уровнем 5 В недопустимо!
- 1 Настройка UART на Raspberry Pi
- 2 Настройка UART на Orange Pi под Armbian
- 3 Интерфейс Serial
- 3.1 open(String, int, int, int, int, int)
- 3.2 open(String, int)
- 3.3 open(String, Baud, DataBits, Parity, StopBits, FlowControl)
- 3.4 open(SerialConfig)
- 3.5 close()
- 3.6 isOpen()
- 3.7 isClosed()
- 3.8 flush()
- 3.9 discardInput()
- 3.10 discardOutput()
- 3.11 discardAll()
- 3.12 sendBreak()
- 3.13 sendBreak(int)
- 3.14 setBreak(boolean)
- 3.15 setRTS(boolean)
- 3.16 setDTR(boolean)
- 3.17 getRTS()
- 3.18 getDTR()
- 3.19 getCTS()
- 3.20 getDSR()
- 3.21 getRI()
- 3.22 getCD()
- 3.23 addListener(SerialDataEventListener…)
- 3.24 removeListener(SerialDataEventListener…)
- 3.25 getFileDescriptor()
- 3.26 getInputStream()
- 3.27 getOutputStream()
- 3.28 isBufferingDataReceived()
- 3.29 setBufferingDataReceived(boolean)
- 4 Интерфейс SerialDataReader
- 5 Интерфейс SerialDataWriter
- 6 Подключение PL2303 к Orange Pi One
- 7 Похожие записи
Настройка UART на Raspberry Pi
По умолчанию последовательный порт на Raspberry Pi настроен как консольный порт для связи с ОС Linux. Если вы хотите использовать этот последовательный порт, вы должны отключить ОС от использования этого порта.
В Raspberry Pi введите следующую команду в окне терминала, чтобы включить UART и отключить консоль на последовательный порт,
sudo raspi-config
Выберите «Interfacing Options»
После «Interfacing Options» выберите «Serial», чтобы включить UART
Затем выберите «No», чтобы отключить консоль на последовательный порт
В конце попросит включить аппаратный последовательный порт, выберите «Да»
Всё, UART включен, консоль отключена
Перезагрузите Raspberry Pi.
Настройка UART на Orange Pi под Armbian
Все модели Orange Pi на базе SoC Allwinner H3 имеют по 4 UART порта. Один отдельный (UART0), что используется как консольный порт для связи с ОС Linux, а остальные находятся на гребёнке GPIO (UART1, UART2 и UART3). По умолчанию включён только UART0. Чтобы использовать и остальные, для начала необходимо включить их. UART2 так-же можно использовать как JTAG, а UART3 как SPI.
Orange Pi Zero, Orange Pi Zero Plus, Orange Pi Zero Plus 2 и Orange Pi R1 имеют по 3 UART порта.
И так, для начала сделаем резервную копию script.bin
, чтобы, в случае чего, смогли вернуть обратно все настройки:
sudo cp /boot/script.bin /boot/script.bak
Чтобы редактировать бинарный файл script.bin
, нужно конвертировать в редактируемый файл fex
:
sudo bin2fex /boot/script.bin /boot/script.fex
Редактируем файл script.fex
с помощью утилиты nano:
sudo nano /boot/script.fex
Находим разделы [uart0] ... [uart3]
:
[uart0] uart_used = 1 uart_port = 0 uart_type = 2 uart_tx = port:PA04<2><1><default><default> uart_rx = port:PA05<2><1><default><default> [uart1] uart_used = 0 uart_port = 1 uart_type = 4 uart_tx = port:PG06<2><1><default><default> uart_rx = port:PG07<2><1><default><default> uart_rts = port:PG08<2><1><default><default> uart_cts = port:PG09<2><1><default><default> [uart2] uart_used = 0 uart_port = 2 uart_type = 4 uart_tx = port:PA00<2><1><default><default> uart_rx = port:PA01<2><1><default><default> uart_rts = port:PA02<2><1><default><default> uart_cts = port:PA03<2><1><default><default> [uart3] uart_used = 0 uart_port = 3 uart_type = 4 uart_tx = port:PA13<3><1><default><default> uart_rx = port:PA14<3><1><default><default> uart_rts = port:PA15<3><1><default><default> uart_cts = port:PA16<3><1><default><default>
Включаем нужный UART порт, для этого нужно установить параметр uart_used = 1
. Я включил все порты, но это не рекомендуется:
[uart0] uart_used = 1 uart_port = 0 uart_type = 2 uart_tx = port:PA04<2><1><default><default> uart_rx = port:PA05<2><1><default><default> [uart1] uart_used = 1 uart_port = 1 uart_type = 4 uart_tx = port:PG06<2><1><default><default> uart_rx = port:PG07<2><1><default><default> uart_rts = port:PG08<2><1><default><default> uart_cts = port:PG09<2><1><default><default> [uart2] uart_used = 1 uart_port = 2 uart_type = 4 uart_tx = port:PA00<2><1><default><default> uart_rx = port:PA01<2><1><default><default> uart_rts = port:PA02<2><1><default><default> uart_cts = port:PA03<2><1><default><default> [uart3] uart_used = 1 uart_port = 3 uart_type = 4 uart_tx = port:PA13<3><1><default><default> uart_rx = port:PA14<3><1><default><default> uart_rts = port:PA15<3><1><default><default> uart_cts = port:PA16<3><1><default><default>
Сохраняем и закрываем файл:
Ctrl X, Y (Yes), Enter
Конвертируем измененный файл script.fex
обратно в script.bin
:
sudo fex2bin /boot/script.fex /boot/script.bin
Перезагружаем ОС:
sudo reboot
Проверяем доступные последовательные порты под Linux:
setserial -g /dev/ttyS[0123]
Интерфейс Serial
Этот интерфейс предоставляет набор функций для настройки и инициализации последовательной связи. Ниже вы найдёте описание всех методов этого интерфейса.
public interface Serial extends SerialDataReader, SerialDataWriter, AutoCloseable {}
open(String, int, int, int, int, int)
Открывает и инициализирует последовательное соединение и устанавливает параметры связи.
public void open( String device, int baud, int dataBits, int parity, int stopBits, int flowControl) throws IOException;
Параметры
String device
— Адрес устройства последовательного порта. Вы можете использовать константу DEFAULT_COM_PORT
, если хотите получить доступ к последовательному порту по умолчанию. ВНИМАНИЕ: параметр device
может содержать не более 128 символов.
int baud
— Скорость передачи данных для последовательного порта. (Пользовательская скорость передачи не поддерживается).
int dataBits
— Биты данных. (5, 6, 7, 8).
int parity
— Параметр четности. (None, Event, Odd, Mark, Space).
int stopBits
— Стоповые биты. (1, 2).
int flowControl
— Управление потоком передачи данных. (none, hardware, software).
Бросает
IOException
— в случае какой-либо ошибки.
open(String, int)
Открывает и инициализирует последовательное соединение и устанавливает параметры связи. Этот метод будет использовать следующие параметры последовательной конфигурации по умолчанию:
- DATA BITS = 8
- PARITY = NONE
- STOP BITS = 1
- FLOW CONTROL = NONE
public void open(String device, int baud) throws IOException;
Параметры
String device
— Адрес устройства последовательного порта. Вы можете использовать константу DEFAULT_COM_PORT
, если хотите получить доступ к последовательному порту по умолчанию. ВНИМАНИЕ: параметр device
может содержать не более 128 символов.
int baud
— Скорость передачи данных для последовательного порта. (Пользовательская скорость передачи не поддерживается).
Бросает
IOException
— в случае какой-либо ошибки.
open(String, Baud, DataBits, Parity, StopBits, FlowControl)
Открывает и инициализирует последовательное соединение и устанавливает параметры связи.
public void open( String device, Baud baud, DataBits dataBits, Parity parity, StopBits stopBits, FlowControl flowControl) throws IOException;
Параметры
String device
— Адрес устройства последовательного порта. Вы можете использовать константу DEFAULT_COM_PORT
, если хотите получить доступ к последовательному порту по умолчанию. ВНИМАНИЕ: параметр device
может содержать не более 128 символов.
Baud baud
— Скорость передачи данных для последовательного порта. (Пользовательская скорость передачи не поддерживается).
DataBits dataBits
— Биты данных. (5, 6, 7, 8).
Parity parity
— Параметр четности. (None, Event, Odd, Mark, Space).
StopBits stopBits
— Стоповые биты. (1, 2).
FlowControl flowControl
— Управление потоком передачи данных. (none, hardware, software).
Бросает
IOException
— в случае какой-либо ошибки.
open(SerialConfig)
Открывает и инициализирует последовательное соединение и устанавливает параметры связи.
public void open(SerialConfig serialConfig) throws IOException;
Параметры
SerialConfig serialConfig
— Объект конфигурации последовательной связи, содержащий адрес устройства, скорость передачи данных, бит данных, контроль четности, стоп-биты и параметры управления потоком.
Бросает
IOException
— в случае какой-либо ошибки.
close()
Этот метод вызывается, чтобы закрыть текущий открытый последовательный порт.
public void close() throws IllegalStateException, IOException;
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
isOpen()
Этот метод вызывается, чтобы определить, если последовательный порт открыт.
public boolean isOpen();
Возвращает
значение true
, если последовательный порт уже открыт.
isClosed()
Этот метод вызывается, чтобы определить, если последовательный порт закрыт.
public boolean isClosed();
Возвращает
значение true
, если последовательный порт находится в закрытом состоянии.
flush()
Принудительная передача любых оставшихся данных в буфере передачи последовательного порт. Обратите внимание, что это не заставляет передавать данные, но отбрасывает их.
public void flush() throws IllegalStateException, IOException;
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
discardInput()
Отбрасывает любые данные в буфере последовательного приема (ввода).
public void discardInput() throws IllegalStateException, IOException;
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
discardOutput()
Отбрасывает любые данные в последовательном буфере передачи (вывода).
public void discardOutput() throws IllegalStateException, IOException;
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
discardAll()
Отбрасывает любые данные в буферах последовательного приема и передачи.
public void discardAll() throws IllegalStateException, IOException;
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
sendBreak()
Отправляет сигнал BREAK подключенному устройству не менее 0.25 секунды и не более 0.5 секунд
public void sendBreak() throws IllegalStateException, IOException;
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
sendBreak(int)
public void sendBreak(int duration) throws IllegalStateException, IOException;
Параметры
int duration
— Длительность (в миллисекундах) для отправки сигнала BREAK.
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
setBreak(boolean)
Отправляет постоянный сигнал BREAK на подключенное устройство. (включение/выключение сигнала BREAK) При включении будет посылать непрерывный поток нулевых битов, а передача других данных невозможна.
public void setBreak(boolean enabled) throws IllegalStateException, IOException;
Параметры
boolean enabled
— Состояние включения или выключения для управления сигналом BREAK.
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
setRTS(boolean)
Управляет состоянием контакта RTS (запрос-на-отправку). Когда включено, это приведет к тому, что вывод RTS будет находиться в состоянии HIGH.
public void setRTS(boolean enabled) throws IllegalStateException, IOException;
Параметры
boolean enabled
— Включить или отключить состояние, чтобы контролировать состояние контакта RTS.
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
setDTR(boolean)
Контролирует состояние вывода DTR (состояние готовности к передаче данных). При включении этого вывод DTR будет установлен в высокое состояние.
public void setDTR(boolean enabled) throws IllegalStateException, IOException;
Параметры
boolean enabled
— Включить или отключить состояние, чтобы контролировать состояние контакта RTS.
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
getRTS()
Возвращает состояние вывода RTS (запрос на отправку).
public boolean getRTS() throws IllegalStateException, IOException;
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
getDTR()
Возвращает состояние вывода DTR (состояние готовности к передаче данных).
public boolean getDTR() throws IllegalStateException, IOException;
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
getCTS()
Возвращает состояние вывода CTS (clean-to-send).
public boolean getCTS() throws IllegalStateException, IOException;
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
getDSR()
Возвращает состояние вывода DSR (data-set-ready).
public boolean getDSR() throws IllegalStateException, IOException;
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
getRI()
Возвращает состояние вывода RI (ring-indicator).
public boolean getRI() throws IllegalStateException, IOException;
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
getCD()
Возвращает состояние вывода CD (carrier-detect).
public boolean getCD() throws IllegalStateException, IOException;
Бросает
IllegalStateException
— если последовательный порт еще не открыт.
IOException
— в случае какой-либо ошибки.
addListener(SerialDataEventListener…)
Метод для регистрации слушателя для событий последовательных данных (приём данных).
public void addListener(SerialDataEventListener... listener);
Параметры
SerialDataEventListener... listener
— Экземпляр класса, который реализует интерфейс SerialListener.
removeListener(SerialDataEventListener…)
Метод для отмены регистрации слушателя для событий последовательных данных (приём данных).
public void removeListener(SerialDataEventListener... listener);
Параметры
SerialDataEventListener... listener
— Экземпляр класса, который реализует интерфейс SerialListener.
getFileDescriptor()
Этот метод возвращает дескриптор файла последовательного устройства
public int getFileDescriptor();
getInputStream()
Этот метод возвращает поток входных данных для буфера приема последовательного порта
public InputStream getInputStream();
getOutputStream()
Этот метод возвращает поток выходных данных для буфера передачи последовательного порта
public InputStream getOutputStream();
isBufferingDataReceived()
Этот метод возвращает состояние буферизации данных, полученных от последовательного устройства / порта.
public boolean isBufferingDataReceived();
Возвращает
true
, если включена буферизация; иначе false
setBufferingDataReceived(boolean)
Этот метод управляет состоянием буферизации данных, полученных от последовательного устройства / порта.
Если состояние буферизации включено, все байты данных, полученные от последовательного порта, будут скопированы в буфер приема данных. Вы можете использовать методы getInputStream()
или read()
для доступа к этим данным. Данные также будут доступны через событие SerialDataEvent
. Важно знать, что если вы используете буферизацию данных, данные будут продолжать скапливаться в памяти, пока ваша программа не освободит поток данных.
Если состояние буферизации отключено, то все байты данных, полученные от последовательного порта, НЕ будут скопированы в буфер приема данных, но будут включены в полезную нагрузку данных события SerialDataEvent
. Если ваша программа не использует данные, полученные от последовательного порта, тогда вы должны отключить состояние буферизации данных, чтобы предотвратить утечку памяти.
public void setBufferingDataReceived(boolean enabled);
Параметры
boolean enabled
— Устанавливает состояние поведения буферизации.
Интерфейс SerialDataReader
Интерфейс SerialDataReader
предоставляет набор функций для чтения данных из последовательного порта.
public int available() throws IllegalStateException, IOException; public void discardData() throws IllegalStateException, IOException; public byte[] read() throws IllegalStateException, IOException; public byte[] read(int length) throws IllegalStateException, IOException; public void read(ByteBuffer buffer) throws IllegalStateException, IOException; public void read(int length, ByteBuffer buffer) throws IllegalStateException, IOException; public void read(OutputStream stream) throws IllegalStateException, IOException; public void read(int length, OutputStream stream) throws IllegalStateException, IOException; public void read(Collection<ByteBuffer> collection) throws IllegalStateException, IOException; public void read(int length, Collection<ByteBuffer> collection) throws IllegalStateException, IOException; public CharBuffer read(Charset charset) throws IllegalStateException, IOException; public CharBuffer read(int length, Charset charset) throws IllegalStateException, IOException; public void read(Charset charset, Writer writer) throws IllegalStateException, IOException; public void read(int length, Charset charset, Writer writer) throws IllegalStateException, IOException;
Интерфейс SerialDataWriter
Интерфейс SerialDataWriter
предоставляет набор функций для записи данных в последовательный порт.
public void write(byte[] data, int offset, int length) throws IllegalStateException, IOException; public void write(byte ... data) throws IllegalStateException, IOException; public void write(byte[] ... data) throws IllegalStateException, IOException; public void write(ByteBuffer... data) throws IllegalStateException, IOException; public void write(InputStream input) throws IllegalStateException, IOException; public void write(Charset charset, char[] data, int offset, int length) throws IllegalStateException, IOException; public void write(Charset charset, char ... data) throws IllegalStateException, IOException; public void write(char ... data) throws IllegalStateException, IOException; public void write(Charset charset, CharBuffer... data) throws IllegalStateException, IOException; public void write(CharBuffer ... data) throws IllegalStateException, IOException; public void write(Charset charset, CharSequence ... data) throws IllegalStateException, IOException; public void write(CharSequence ... data) throws IllegalStateException, IOException; public void write(Charset charset, Collection<? extends CharSequence> data) throws IllegalStateException, IOException; public void write(Collection<? extends CharSequence> data) throws IllegalStateException, IOException; public void writeln(Charset charset, CharSequence ... data) throws IllegalStateException, IOException; public void writeln(CharSequence ... data) throws IllegalStateException, IOException; public void writeln(Charset charset, Collection<? extends CharSequence> data) throws IllegalStateException, IOException; public void writeln(Collection<? extends CharSequence> data) throws IllegalStateException, IOException;
Подключение PL2303 к Orange Pi One
Для начала нужно выбрать платформу, если у вас Raspberry Pi, тогда этого делать не надо.
PlatformManager.setPlatform(Platform.ORANGEPI);
Чтобы работать с последовательным портом нужно создать экземпляр класса Serial
с помощью утилиты SerialFactory
.
Serial serial = SerialFactory.createInstance();
Данные могут быть отправлены несколькими способами, самый простой способ — с использованием методов write(...)
и writeln(...)
. Также можно использовать и выходной поток OutputStream outputStream = serial.getOutputStream();
.
serial.write(data);
Прочесть полученные данные можно с помощью методов read(...)
, но в таком случае нужно постоянно проверять наличие данных в буффере. Лучще всего зарегистрировать слушатель SerialDataEventListener.
Слушатель SerialDataEventListener
— это уведомляемый о поступлении новых данных в последовательном пору объект. Чтобы слушатель смог реагировать на событие источника он должен быть им зарегистрирован, т.е. подключен к источнику. Listener
должен реализовывать метод dataReceived(...)
для получения и обработки уведомлений о событии.
Listener находится в постоянном ожидании, пока в источнике, в котором он зарегистрирован, не наступит соответствующее событие, при возникновении которого слушатель получает управление. Также слушателю передается объект события (Serial
который содержется в SerialDataEvent
), чтобы он смог правильно на него отреагировать. Таким образом, источник вызывает метод-обработчик события (public void dataReceived(SerialDataEvent event)
), определенный в классе, являющемся блоком прослушивания.
После обработки события слушатель возвращает управление. Таким образом, для обработки события вызываются только те слушатели, которые на него «подписались», т.е. были зарегистрированы источником.
serial.addListener(new SerialDataEventListener() { @Override public void dataReceived(SerialDataEvent event) { try { byte[] data = event.getSerial().read(); /* data - полученные данные */ } catch (IOException e) { e.printStackTrace(); } } });
Создаём объект конфигурации последовательной связи (SerialConfig
), содержащий адрес устройства, скорость передачи данных, бит данных, контроль четности, стоп-биты и параметры управления потоком.
SerialConfig config = new SerialConfig();
и задаём эти конфигурации.
config.device(OrangePiSerial.UART3_COM_PORT) .baud(Baud._9600) .dataBits(DataBits._8) .parity(Parity.NONE) .stopBits(StopBits._1) .flowControl(FlowControl.NONE);
С помощью метода open(...)
открываем UART порт.
serial.open(config);
Схема подключения
Чтобы проверить UART на Orange Pi, я подключил его к компьютеру через преобразователь PL2303. В этом случае используется порт UART3.
Пример программы
Эта программа получает по UART данные в виде текста и выводит данный текст в консоль, также выводит текст в шестнадцатеричном формате. Для отправки использовал Terminal v1.9b.
import com.pi4j.io.serial.Baud; import com.pi4j.io.serial.DataBits; import com.pi4j.io.serial.FlowControl; import com.pi4j.io.serial.OrangePiSerial; import com.pi4j.io.serial.Parity; import com.pi4j.io.serial.Serial; import com.pi4j.io.serial.SerialConfig; import com.pi4j.io.serial.SerialDataEvent; import com.pi4j.io.serial.SerialDataEventListener; import com.pi4j.io.serial.SerialFactory; import com.pi4j.io.serial.StopBits; import com.pi4j.platform.Platform; import com.pi4j.platform.PlatformManager; import com.pi4j.util.Console; public class PL2303OrangePiOne { public static void main(String args[]) { try { PlatformManager.setPlatform(Platform.ORANGEPI); Console console = new Console(); console.promptForExit(); Serial serial = SerialFactory.createInstance(); serial.addListener(new SerialDataEventListener() { @Override public void dataReceived(SerialDataEvent event) { try { console.println("[HEX DATA] " + event.getHexByteString("0x", " ", "")); console.println("[ASCII DATA] " + event.getAsciiString()); } catch (IOException e) { e.printStackTrace(); } } }); SerialConfig config = new SerialConfig(); config.device(OrangePiSerial.UART3_COM_PORT) .baud(Baud._9600) .dataBits(DataBits._8) .parity(Parity.NONE) .stopBits(StopBits._1) .flowControl(FlowControl.NONE); serial.open(config); console.waitForExit(); } catch (Exception e) { e.printStackTrace(); } } }
Проверяем код:
- создаём java файл и вставляем код;
nano PL2303OrangePiOne.java
- компилируем файл;
javac -classpath .:classes:/opt/pi4j/lib/'*' PL2303OrangePiOne.java
- запускаем программу.
sudo java -classpath .:classes:/opt/pi4j/lib/'*' PL2303OrangePiOne
Результат
Как мы видим данные получены и программа работает правильно.
В библиотеке pi4j, по крайней мере в той которая досталась мне, есть небольшой баг:
public static final java.lang.String UART0_COM_PORT = «/dev/ttyS0»;
public static final java.lang.String UART2_COM_PORT = «/dev/ttyS2»;
public static final java.lang.String UART3_COM_PORT = «/dev/ttyS3»;
public static final java.lang.String UART7_COM_PORT = «/dev/ttyS3»;
public static final java.lang.String DEFAULT_COM_PORT = «/dev/ttyS3»;
Соответственно либо исправлять схему подключения, либо переписывать библиотеку на /dev/ttyS1;
банкротство отзывы
1вин. https://pboarders.borda.ru/?1-11-0-00000929-000-0-0-1742818701 .
1win. pro https://pboarders.borda.ru/?1-11-0-00000929-000-0-0-1742818701/ .
мос бет http://shorts.borda.ru/?1-18-0-00000397-000-0-0/ .
1win партнерка вход http://boardwars.forum24.ru/?1-10-0-00000406-000-0-0/ .
1 win регистрация http://www.boardwars.forum24.ru/?1-10-0-00000406-000-0-0 .
скачат мостбет http://tagilshops.forum24.ru/?1-4-0-00000205-000-0-0/ .
mostbets http://kharkovbynight.forum24.ru/?1-15-0-00003047-000-0-0-1742814422/ .
1 win официальный сайт [url=www.yamama.forum24.ru/?1-11-0-00000459-000-0-0-1742818616]www.yamama.forum24.ru/?1-11-0-00000459-000-0-0-1742818616[/url] .
mostbet kg https://kharkovbynight.forum24.ru/?1-15-0-00003047-000-0-0-1742814422/ .
1 win официальный сайт вход https://yamama.forum24.ru/?1-11-0-00000459-000-0-0-1742818616/ .
мостбет казино http://maksipolinovtsu.forum24.ru/?1-1-0-00000194-000-0-0-1742815870 .
мостбет зеркало мостбет зеркало .
1 win kg http://www.mymoscow.forum24.ru/?1-6-0-00026928-000-0-0 .
1vin https://www.dogzz.forum24.ru/?1-10-0-00000155-000-0-0-1742818537 .
мостбет скачать андроид мостбет скачать андроид .
1вин http://www.dogzz.forum24.ru/?1-10-0-00000155-000-0-0-1742818537 .
мосбет казино http://www.corgan.borda.ru/?1-0-0-00000265-000-0-0 .
1win партнерская программа вход https://zdorovie.forum24.ru/?1-7-0-00000231-000-0-0-1742818050 .
мостбет кыргызстан http://ashapiter0.forum24.ru/?1-19-0-00001444-000-0-0-1742819001/ .
1win личный кабинет 1win личный кабинет .
1 вин официальный сайт https://knowledge.forum24.ru/?1-0-0-00000101-000-0-0-1742817704 .
Списание долгов по 127-ФЗ лучшее решение, когда у вас начались просрочки и уже нечем платить за кредиты https://bankrotstvo-v-moskve123.ru .
mosbet https://www.mostbet6004.ru .
игра ракета на деньги 1win belbeer.borda.ru/?1-6-0-00001583-000-0-0 .
mostbet скачать https://www.girikms.forum24.ru/?1-1-0-00000361-000-0-0-1742819287 .
mostbet kg скачать на андроид girikms.forum24.ru/?1-1-0-00000361-000-0-0-1742819287 .
мостбет мобильная версия скачать http://hiend.borda.ru/?1-16-0-00000259-000-0-0-1743052953/ .
скачать мостбет скачать мостбет .
мотбет http://www.hiend.borda.ru/?1-16-0-00000259-000-0-0-1743052953 .
mostbet casino https://www.alfatraders.borda.ru/?1-0-0-00004917-000-0-0-1743053068 .
мостбет авиатор https://cah.forum24.ru/?1-3-0-00000096-000-0-0-1743053764 .
1win бк 1win бк .
мастбет cah.forum24.ru/?1-3-0-00000096-000-0-0-1743053764 .
1 вин про http://fanfiction.borda.ru/?1-0-0-00029708-000-0-0-1743051664/ .
ванвин ванвин .
1win ракета 1win ракета .
мостбет вход mostbet6006.ru .
мостбет зеркало https://mostbet6007.ru .
отзывы о банкротстве
1win.kg 1win.kg .
мостбет скачать mostbet6008.ru .
мрстбет https://mostbet6009.ru .
мостбет казино http://www.mostbet6010.ru .
1 win pro https://1win6005.ru .
mostbet официальный сайт https://mostbet6030.ru .
1 win.com 1 win.com .
1win sports http://1win13.com.ng .
мостбет зеркало мостбет зеркало .
casino 1win http://www.1win1001.top .
мостбет скачать https://mostbet6031.ru .
mostbet apk скачать http://mostbet6032.ru .
1win.pro http://1win5010.ru .
mosbet http://www.mostbet6011.ru .
1 win официальный сайт http://1win6043.ru .
мостбет казино войти https://mostbet6033.ru/ .
1win партнерка вход http://1win6044.ru/ .
1 вин скачать 1 вин скачать .
mostbet kg скачать на андроид mostbet kg скачать на андроид .
1 вин про https://www.1win6045.ru .
1win,com https://1win7013.ru/ .
1win kg https://1win6045.ru .
мостбет кыргызстан скачать http://mostbet6036.ru/ .
1win вход https://1win7002.ru/ .
1вин официальный https://1win7014.ru/ .
мостбет казино mostbet5002.ru .
1wi 1wi .
скачат мостбет [url=http://mostbet7001.ru]http://mostbet7001.ru[/url] .
1win мобильная версия сайта http://1win7017.ru/ .
1win website 1win website .
1win moldova 1win moldova .
1win metode de plată [url=https://1win5027.ru/]https://1win5027.ru/[/url] .
мостбет официальный сайт https://mostbet7003.ru .
скачать мостбет https://www.1win5028.ru .
1 win kg https://www.1win7018.ru .
скачать mostbet https://mostbet6033.ru .
мостбет промокод http://mostbet5010.ru .
1win pro 1win7009.ru .
мостбет кг http://mostbet5009.ru/ .
1win casino ug 1win1005.top .
1вин. 1вин. .
скачат мостбет mostbet6033.ru .
1вин онлайн https://1win7012.ru .
мостбет промокод http://mostbet7007.ru .
mostbet официальный сайт http://mostbet6040.ru .
1winw 1win707.ru .
www. mostbet. com mostbet6042.ru .
1win молдова 1win молдова .
1win https://1win5034.ru .
1win на телефон https://1win8006.ru .
1 win промокод на деньги http://1win8005.ru/ .
1хставка скачать на андроид http://www.1win8002.ru .
скачать бесплатно 1win https://1win8003.ru .
мостбеь http://mostbet8003.ru/ .
1win metode de plată https://1win5051.ru .
как скачать 1win на айфон https://1win8007.ru .
1win moldova http://1win5050.ru/ .
mostbet bonus olish mostbet bonus olish .
mostbets mostbets .
1win pariuri https://www.1win5054.ru .
официальный сайт 1вин 1win8019.ru .
1вин официальный мобильная зеркало http://1win8020.ru/ .
1вин мобильная версия официальный https://1win8010.ru .
1вин сайт официальный https://1win8004.ru/ .
продажа аккаунтов заработок на аккаунтах
1хставка скачать http://1win10017.ru .
маркетплейс аккаунтов соцсетей https://marketplace-akkauntov-top.ru/
профиль с подписчиками https://magazin-akkauntov-online.ru/
безопасная сделка аккаунтов https://kupit-akkaunt-top.ru/
как вывести бонусы с 1win http://1win10004.ru/ .
вход мостбет https://mostbet10009.ru .
Database of Accounts for Sale Account Buying Platform
Account Trading Platform Accounts for Sale
mostbet com login mostbet10006.ru .
Account Sale Buy accounts
Profitable Account Sales Buy Pre-made Account
как пополнить баланс в лаки джет 1win10028.ru .
account market account selling platform
website for buying accounts sell accounts
accounts marketplace account market
sell pre-made account account store
1 win регистрация https://1win10063.ru/ .
account exchange secure account purchasing platform
guaranteed accounts sell pre-made account
mostbet kg скачать https://www.mostbet10008.ru .
скачать 1win на android скачать 1win на android .
buy and sell accounts account trading platform
account store account sale
account trading platform account purchase
account market profitable account sales
verified accounts for sale account acquisition
account market account trading platform
account marketplace guaranteed accounts
account selling service accounts-for-sale.org
казино 1win зеркало https://1win10070.ru .
мелбет кж http://www.melbet1012.ru .
accounts marketplace https://buy-social-accounts.org
account buying platform https://social-accounts-marketplace.org
скачать лайки джет на андроид http://1win10076.ru/ .
account acquisition buy and sell accounts
account trading service account exchange service
buy and sell accounts gaming account marketplace
accounts marketplace https://sale-social-accounts.org/
account exchange service online account store
регистрация в 1вин http://1win10081.ru/ .
1win дзеркало https://1win10079.ru/ .
промокод продамус промокод продамус .
сервисный центр тойота сервисный центр тойота .
account trading ready-made accounts for sale
мелбет кж http://www.melbet1013.ru .
guaranteed accounts buy account
buy account find accounts for sale
1win casino ug http://1win1031.top .
purchase ready-made accounts account market
Выигрывай реальные деньги в онлайн казино! Обзоры слотов, бонусы, стратегии для победы! Подписывайся
Казино онлайн: секреты, стратегии, промокоды! Заработай с нами! Реальные обзоры.
https://t.me/Official_1win_1win/974
accounts for sale accounts market
website for selling accounts https://accounts-marketplace.xyz
accounts market https://buy-best-accounts.org/
авиатор прогнозы телеграм https://www.1win10009.ru .
secure account purchasing platform https://accounts-marketplace.live
accounts marketplace https://social-accounts-marketplace.xyz
мосвет казино http://www.mostbet10014.ru .
https://t.me/s/win1win777win
скачать приложение 1win на андроид скачать приложение 1win на андроид .
accounts marketplace https://buy-accounts-shop.pro
social media account marketplace https://accounts-marketplace.art
account acquisition https://social-accounts-marketplace.live
mel bet kg https://www.melbet1011.ru .
1win scaricare https://1win5068.ru/ .
melbet кыргызстан https://www.melbet1014.ru .
1win bet uganda http://www.1win1032.top .
охрана стоимость в месяц http://www.chop-ohrana.com/czeny-na-uslugi-ohrany .
покупка аккаунтов магазины аккаунтов
чоп охрана цены http://www.chop-ohrana.com/czeny-na-uslugi-ohrany/ .
роллетный шкаф самара роллетный шкаф самара .
мелбет кыргызстан скачать melbet1017.ru .
покупка аккаунтов https://akkaunty-optom.live/
площадка для продажи аккаунтов https://online-akkaunty-magazin.xyz
маркетплейс аккаунтов соцсетей https://kupit-akkaunt.online/
1win login online [url=www.1win1029.top]www.1win1029.top[/url] .
how to use casino bonus in 1win http://1win1024.top/ .
стоимость охраны объекта стоимость охраны объекта .
дренаж сервис http://www.vc.ru/services/1913096-kak-sdelat-drenazh-na-uchastke-v-sankt-peterburge .
мелбет удалить аккаунт https://melbet1018.ru/ .
buy facebook accounts https://buy-adsaccounts.work/
facebook account sale https://buy-ad-accounts.click
buy facebook account buy facebook profile
песня уннв скачать песня уннв скачать .
кашпо напольное пластик http://www.https://industrial-wood.ru/novosti/40260-ispolzovanie-napolnogo-kashpo-v-sovremennom-interere.html .
buy old facebook account for ads https://buy-ads-account.click/
дрова березовые купить в спб дрова березовые купить в спб .
mobila lemn la comanda http://1win5078.ru/ .
buy fb account buy facebook profiles
онлайн займ для граждан снг на карту https://vc.ru/rejting/1964646-kredity-na-kartu-na-god-s-plokhoy-istoriey .
недорогие пластиковые окна недорогие пластиковые окна .
facebook accounts to buy https://buy-ad-account.click
построить забор недорого rancho25.ru .
1win 1win22018.ru .
1win pariuri http://www.1win5079.ru .
1win http://www.1win22004.ru .
займы онлайн на карту 4 vc.ru/rejting/1964646-kredity-na-kartu-na-god-s-plokhoy-istoriey .
buy google ads verified account https://buy-ads-account.top
cheap facebook accounts buy fb account
google ads accounts ads-account-buy.work
лучшие займы онлайн на карту без проверок http://vc.ru/rejting/1964646-kredity-na-kartu-na-god-s-plokhoy-istoriey .
1win скачать kz 1win скачать kz .
google ads agency accounts https://buy-ads-invoice-account.top
скачать бк осталось исключительно лишь выбрать подходящее http://1win22008.ru .
букмекер 1 вин http://1win22022.ru/ .
buy google ads invoice account google ads account buy
ван вин фрибет http://www.1win22023.ru .
букмекерская контора 1 вин http://www.1win22009.ru .
facebook bm buy buy-business-manager-acc.org
verified bm for sale https://buy-bm-account.org
1win вывод https://1win22010.ru .
facebook bm buy buy-verified-business-manager-account.org
facebook bm buy buy-verified-business-manager.org
ставки на хоккей сегодня прогнозы точные luchshie-prognozy-na-khokkej12.ru .
устройство дренажа на участке спб https://drenazh-uchastka-1122.ru/ .
buy facebook business manager verified https://business-manager-for-sale.org/
facebook business manager buy https://buy-business-manager-verified.org/
регистрация в 1цшт http://1win22025.ru/ .
buy fb bm https://verified-business-manager-for-sale.org/
tiktok ads account buy https://buy-tiktok-ads-account.org
buy tiktok ad account https://tiktok-ads-account-buy.org
скачать 1вин зеркало https://1win22028.ru/ .
1win это что https://1win22027.ru/ .
buy tiktok business account https://tiktok-ads-account-for-sale.org
tiktok ads account buy https://tiktok-agency-account-for-sale.org
продвинуть сайт в москве https://prodvizhenie-sajtov-v-moskve231.ru/ .
игра авиатор как выиграть http://1win22029.ru .
— залог успешного — залог успешного
buy tiktok ads https://buy-tiktok-business-account.org
tiktok ad accounts https://buy-tiktok-ads.org
tiktok ads account for sale tiktok ad accounts
обустройство парковочного места обустройство парковочного места .
1win установить 1win установить .
авиатор 1вин http://1win3007.ru/ .
1 вин бонус при регистрации без депозита https://1win22064.ru/ .
1win lucky jet отзывы 1win lucky jet отзывы .
1win ставки на спорт зеркало 1win ставки на спорт зеркало .
1win online 1win22069.ru .
натяжные потолки под ключ https://potolkilipetsk.ru/ .
1win вход в личный кабинет http://1win22074.ru/ .
как набрать подписчиков в тг канал как набрать подписчиков в тг канал
1win отзывы 1win22072.ru .
заезд на участок под ключ заезд на участок под ключ .
скачать приложение mostbet http://mostbet22041.ru .
1вин казино скачать 1вин казино скачать .
https://t.me/s/vavada_official_vavada
1вин официальный сайт вход 1вин официальный сайт вход .
скачать мостбет https://mostbet22045.ru/ .
https://biotpharm.com/# Over the counter antibiotics pills
красивый заезд на участок https://doroga-k-uchastku-1122.ru/ .
1win aviator apk download 1win aviator apk download .
сделать въезд на участок https://parkovka-dlya-mashiny-1122.ru .
betwinner apk uptodown https://betswinner.bet/ .
шкаф для машиноместа в паркинге шкаф для машиноместа в паркинге .
сантехника донецк днр купить [url=https://santehnika-doneck-1.ru/]santehnika-doneck-1.ru[/url] .
стоматология цены Владимир stomatologiya-vladimir-2.ru .
mostbet app mostbet-app-download-apk.com .
mostbet app download mostbet app download .
выровнять землю на участке выровнять землю на участке .
кухни по индивидуальным размерам на заказ недорого кухни по индивидуальным размерам на заказ недорого .
zaezd-dlya-mashiny-1122.ru .
шкаф в паркинг с рольставнями цена шкаф в паркинг с рольставнями цена .
888starz скачать 888starz скачать .
живые подписчики в телеграм канал
прикольные горшки для цветов http://www.dizaynerskie-kashpo.ru/ .
zaezd-pod-klyuch-1122.ru .
бустра займ бустра займ
стоимость септика для частного стоимость септика для частного .
888starz t?l?charger [url=www.20bets.bet]www.20bets.bet[/url] .
какие банки могут одобрить кредит с плохой кредитной историей http://https://gorodschekino.ru/avtokreditovanie-v-kyrgyzstane// .
¡Bienvenidos, exploradores de la fortuna !
Me encantГі la forma en que lo explicaste. casinoextranjeros.es
Retiros en menos de 1h en casinos online extranjeros — п»їhttps://casinoextranjeros.es/
En casinosextranjerosespana.es puedes filtrar juegos por proveedor, RTP o categorГa. Esta funciГіn te ayuda a elegir mejor tu estrategia. Los casinos online extranjeros apuestan por personalizaciГіn total.
¡Que vivas asombrosas botes espectaculares!
займ на год с ежемесячным платежом займ на год с ежемесячным платежом
drenazh-pod-klyuch-812.ru .
займы без отказа omskpress.ru/news/336904/aktualnye-bankovskie-produkty-vybirajte-luchshee-dlya-sebya/ .
888starz cameroun 888starz cameroun .
¡Hola, cazadores de tesoros!
Casinos extranjeros con opciones de pago anГіnimas — https://www.casinoextranjerosespana.es/ casino online extranjero
¡Que disfrutes de asombrosas triunfos legendarios !
¡Saludos, jugadores dedicados !
Casino sin licencia en EspaГ±a sin lГmite de depГіsito — http://casinossinlicenciaenespana.es/ casino sin registro
¡Que vivas éxitos sobresalientes !
подъемник на крышу подъемник на крышу .
Купить диплом любого ВУЗа!
Наши специалисты предлагаютвыгодно заказать диплом, который выполняется на оригинальном бланке и заверен мокрыми печатями, водяными знаками, подписями. Данный диплом пройдет любые проверки, даже с использованием профессиональных приборов. Достигайте своих целей быстро и просто с нашей компанией- newsofmebel.ru/gde-kupit-diplom-ne-opasayas-posledstviy