Raspberry PI: CRI COMPILE
Я использую buildroot cross toolchain для компиляции приложения Raspberry с моего компьютера (Ubuntu X86). Я разрабатываю сервер TCP, который разрешает соединение по номеру порта 5003 (0x138B). Когда я запускаю сервер, это верно, но мой сервер ожидает подключения по номеру TCP-порта 35603 (0x8B13) (проверьте с помощью netstat -a).
Кажется, это проблема порядка байтов, но я не знаю, как ее решить.
Не могли бы вы мне помочь?
Благодарю.
1 ответ
Спасибо за Ваш ответ.
Я согласен, это очень странно. Я не думаю, что код является проблемой. Это хорошо работает на другой платформе.
Пожалуйста, найдите код ниже:
/*Create the server */
int CreateServeur (unsigned short port, int *sock_srv, int nb_connect)
{
int l_ret = -1;
struct sockaddr_in l_srv_addr;
/* address initialisation */
printf("creation serveur port %i\n", port);
memset ((char*) &l_srv_addr,0, sizeof (struct sockaddr_in));
l_srv_addr.sin_family = PF_INET;
l_srv_addr.sin_port = port;
l_srv_addr.sin_addr.s_addr = htonl (INADDR_ANY);
/* main socket creation */
if ((*sock_srv = socket (PF_INET, SOCK_STREAM, 0)) <= 0)
{
printf("server socket creation error");
}
else
{
if (bind (*sock_srv, (struct sockaddr *) &l_srv_addr, sizeof (struct sockaddr_in)) == -1)
{
close (*sock_srv);
printf("bind socket error");
}
else
{
if (listen (*sock_srv, nb_connect) == ERROR)
{
close (*sock_srv);
printf("listen socket error");
}
else
{
l_ret = 0;
}
}
}
return (l_ret);
}
Эта функция не возвращает никаких ошибок. В первом журнале (printf("Порт службы создания%i\n", порт);) отображается исправный порт (5003), но сервер ожидает подключения к порту 35603 (netstat -a).
Если это не проблема порядка байтов, я не понимаю.