Форум программистов, компьютерный форум, киберфорум
C/С++ под Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.94/18: Рейтинг темы: голосов - 18, средняя оценка - 4.94
0 / 0 / 1
Регистрация: 17.03.2012
Сообщений: 9

Работа с модемом

17.03.2012, 22:41. Показов 3662. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Ребята, здравствуйте...
Помогите, пожалуйста, разобраться с программкой. В общем, мне надо наладить работу с модемом. Перерыл куту инфи... Пробовал так-сяк, но не выходит. Проблема в том, что в выдаче модема присутствует какой-то мусор. Использую ОС Slackware 12.2. Модем подключен через микросхему PL2303. В качестве модема представлен телефон Siemens C65. Оборудование исправно...
Вод мой код:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <termios.h>
#include <unistd.h>
#include <termios.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <iostream.h>
 
 
int main(){
  int fd;
 
  fd = open("/dev/ttyUSB0", O_RDWR);
  fcntl(fd, F_SETFL, 0);
 
 
 
  struct termios options;
  tcgetattr(fd, &options);
 
  cfsetispeed(&options, B115200);
  cfsetospeed(&options, B115200);
  cfmakeraw( &options );
 
//  options.c_lflag |= (ICANON | ECHO | ECHOE);
//options.c_lflag     &= ~(ICANON);
options.c_lflag &= ~(ICANON | ECHO | ECHOE | ISIG);
options.c_oflag &= ~OPOST;
//options.c_oflag     &= ~OPOST;
//options.c_cc[VMIN]  = 0;
//options.c_cc[VTIME] = 10;
//options.c_cflag = (CRTSCTS);
//options.c_cflag &= ~CRTSCTS;
options.c_cflag |= CS8 | CREAD | HUPCL | CLOCAL ;
 
  tcflush(fd, TCIFLUSH);
  tcsetattr(fd, TCSANOW, &options);
 
  write(fd, "AT\r", 3);
 
  char buffer[255];  /* буфер ввода */
  char *bufptr;      /* текущий символ в буфере */
  int  nbytes;       /* число прочитанных байтов*/
  int  tries;        /* число попыток */
 
  bufptr = buffer;
  while ((nbytes = read(fd, bufptr, buffer + sizeof(buffer) - bufptr - 1)) > 0){
    bufptr += nbytes;
    if (bufptr[-1] == '\n' || bufptr[-1] == '\r'){
      break;
    };
  };
  cout << "\n\r";
  cout << buffer;
 
  close(fd);
 
};
Выдача... Причем, она по разному...
AT
OK
▒D���C���&��\
root@Laptop:~/Desktop/modem_control/debug/src#

Вроде какбы работает...
Вот...






Только не сильно пинайте — это моя первая программа на C++. В общем, застрял на этом вопросе... Уже дня 3 колупаюсь...
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
17.03.2012, 22:41
Ответы с готовыми решениями:

Работа с GSM модемом
Уверен что не туда, но куда не нашел. Здравствуйте. Есть вопрос, могу ли я программно узнать код...

Работа с модемом
Я написал программу, которая должна отправлять на модем команду и считывать с него ответ, вот код:...

Работы с GSM модемом
Доброго времени суток. Возникла проблема при работе с AT командами. Задача проста - отправка и...

2
1259 / 650 / 44
Регистрация: 06.02.2011
Сообщений: 1,654
18.03.2012, 09:18
Цитата Сообщение от baytuch Посмотреть сообщение
Вроде какбы работает...
Вот...
read() читает массив байт, не строку. Добавьте что-то типа bufptr[0] = '\0'; перед break или еще как-то сделайте из полученных данных строку.
1
0 / 0 / 1
Регистрация: 17.03.2012
Сообщений: 9
24.03.2012, 05:48  [ТС]
Учтено... Большой спасибо... ( сложно, но возможно )

Хлопцы, у меня новая проблема...

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
static int fd;
 
static const char* dev_file(string dev){        //Генерация файла устройства
  string dev_dir = "/dev/";
  dev_dir = dev_dir + dev;
  return dev_dir.c_str();
};
 
static const char* speed_port(int speed){       //Генерация строки скорости
  char* speed_a = new char[10];
  string speed_b;
  string prf = "B";
 
  sprintf( speed_a, "%d", speed );
  speed_b = prf + ( char* ) speed_a;
 
  return speed_b.c_str();
};
 
extern string driver(string device, int speed, string line){
 
  fd = open(dev_file(device), O_RDWR | O_NOCTTY | O_NDELAY);
  fcntl(fd, F_SETFL, 0);
 
  struct termios options;
  tcgetattr(fd, &options);
 
  cfsetispeed(&options, speed_port(speed));
  cfsetospeed(&options, speed_port(speed));
  cfmakeraw( &options );
 
  options.c_cflag &= ~PARENB;
  options.c_cflag |= ~CSTOPB;
  options.c_cflag &= ~CSIZE;
  options.c_cflag |= CS8;
 
  tcflush(fd, TCIFLUSH);
  tcsetattr(fd, TCSANOW, &options);
 
  close(fd);
 
 
 
  return line;
};
В общем, при компиляции:

/root/Desktop/dev/modem_control/src/driver.cpp:60: error: invalid conversion from 'const char*' to 'speed_t'

Шо это за тип такой?.. Йо-ма-йо...

Добавлено через 6 часов 0 минут
Все работает так, как нужно...

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
#include <driver.h>  //Заголовочный файл модуля
 
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <iostream.h>
#include <termios.h>
#include <fcntl.h>
 
using namespace std;
struct termios options;
 
static int fd;
 
static const char* dev_file(string dev){        //Генерация файла устройства
  string dev_dir = "/dev/";
  dev_dir = dev_dir + dev;
  return dev_dir.c_str();
};
 
static speed_t table_speed(int speed_int){      //Таблица констант скоростей
 
  speed_t speed_port;
 
  if ( speed_int == 0 ){ speed_port = B0; };
  if ( speed_int == 1 ){ speed_port = B50; };
  if ( speed_int == 2 ){ speed_port = B75; };
  if ( speed_int == 3 ){ speed_port = B110; };
  if ( speed_int == 4 ){ speed_port = B134; };
  if ( speed_int == 5 ){ speed_port = B150; };
  if ( speed_int == 6 ){ speed_port = B200; };
  if ( speed_int == 7 ){ speed_port = B300; };
  if ( speed_int == 8 ){ speed_port = B600; };
  if ( speed_int == 9 ){ speed_port = B1200; };
  if ( speed_int == 10 ){ speed_port = B1800; };
  if ( speed_int == 11 ){ speed_port = B2400; };
  if ( speed_int == 12 ){ speed_port = B4800; };
  if ( speed_int == 13 ){ speed_port = B9600; };
  if ( speed_int == 14 ){ speed_port = B19200; };
  if ( speed_int == 15 ){ speed_port = B38400; };
  if ( speed_int == 16 ){ speed_port = B57600; };
  if ( speed_int == 17 ){ speed_port = B115200; };
  if ( speed_int == 18 ){ speed_port = B230400; };
 
  return speed_port;
};
 
//Функция драйвера
extern string driver(string device, int speed, string line, int com){
 
  string out;
  out = "";
 
  if ( com == 0 ){                                //Открытие устройства и настройка порта
 
    fd = open(dev_file(device), O_RDWR | O_NOCTTY | O_NDELAY);
    fcntl(fd, F_SETFL, 0);
 
    tcgetattr(fd, &options);
 
    cfsetispeed(&options, table_speed(speed));
    cfsetospeed(&options, table_speed(speed));
    cfmakeraw( &options );
 
    options.c_cflag &= ~PARENB;
    options.c_cflag |= ~CSTOPB;
    options.c_cflag &= ~CSIZE;
    options.c_cflag |= CS8;
 
    tcflush(fd, TCIFLUSH);
    tcsetattr(fd, TCSANOW, &options);
  };
 
  if ( com == 1 ){                                   //Работа с устройством
 
    write(fd, line.c_str(), line.length());
    usleep(100000);
 
    char *buff = new char[384];
    char *buff_stat = new char[10];
    char *cache = new char[1];
    bool t_break = false;
    bool t_clean = false;
    const string c_ok = "OK";            //Устройство сообщает, что все выполнено успешно
    const string c_error = "ERROR";      //Устройство сообщает, что произошла ошибка
    const string c_sub = ">";            //Устройство ожидает данные ( это последный байт )
    for ( int i=0; i<384; i++ ){
      read(fd, cache, 1);
      usleep(10000);
      buff[i] = cache[0];
      for ( int s=0; s<2; s++ ){
        buff_stat[s] = buff[i-(2-s)];
        if ( ( char *) buff_stat == c_ok ){
          t_break = true;
          break;
        };
      };
      for ( int s=0; s<10; s++ ){
        buff_stat[s] = 0;
      };
      for ( int s=0; s<5; s++ ){
        buff_stat[s] = buff[i-(5-s)];
        if ( ( char *) buff_stat == c_error ){
          t_break = true;
          break;
        };
      };
      for ( int s=0; s<10; s++ ){
        buff_stat[s] = 0;
      };
      if ( cache == c_sub ){
        t_break = true;
        t_clean = true;
      };
      if ( t_break == true ){
        break;
      };
    };
    out = ( char* ) buff;
    if ( t_clean == false ){  //Забор с устройства оставшихся символов
      read(fd, buff, 100);
    };
  };
 
  if ( com == 2 ){                                   //Закрытие устройства
 
    close(fd);
 
  };
 
  return out;
};
Учтена одна маленькая деталь -- нужно забрать с мрдема все данные...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.03.2012, 05:48
Помогаю со студенческими работами здесь

Мне нужен API для работы с модемом ? Pls.
Нужен API, библиотеки, примеры кода - чтобы реализовать как минимум дозвон, прием звонков, работу с...

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

стандартные возможности Visual C++ 6.0 для работы с модемом(дозвон,передача сообщения)
Может кто сталкивался с подобными задачами,как разработка программ для работы с модемом (дозвон к...

Ответы при работе с модемом
Начал работать с модемами и теперь неприятность. При получении от модема развернутых &quot;словесных&quot;...

Программа управлением wi-fi модемом
Добрый день! Подскажите в какую вообще сторону копать. Хочу разработать программу на языке C++,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия SDL 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual. . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru