Кто любит RISC в жизни, заходим, не стесняемся.
Ответить

Re: stm32f4 usart+DMA

Ср фев 02, 2022 17:37:37

Я бы не включал DMA раньше чем USART сконфигурирован для работы с ним. Да и вообще не включал пока не потребуется запустить передачу.

Ну и с теми двумя строчками то дожми уже.

Re: stm32f4 usart+DMA

Ср фев 02, 2022 18:00:18

Повторяю, с передачей не разобрались. Неправильно обрабатывается момент окончания передачи. Последний байт будет искажаться.
Проведем парочку экспериментов, на последний байт.
Пишем тестовый код2
Спойлер
Код:
void func (void)
{
   SEND("\r\n");
   printu(ms_tick);
   SEND("\r\n");

    print_line('=', 38);
    SEND("\r\n STM32F100RB USART DMA-tx !!! 31");

    delay_ms(2000);

    SEND("\r\n");
    printu(SystemCoreClock);
    SEND(" MHz 32");

    delay_ms(2000);

   for (uint16_t i = 1000; i<(1000+BUFFER_SIZE); i++){
      Buffer[i-1000] = i;

   }

   SEND("\r\n");
   for (uint16_t i = 0; i<BUFFER_SIZE; i++){
      printu(Buffer[i]);
      SEND(" ");
   }
    SEND("33");
    delay_ms(5000);

    SEND("\r\n");
   printu(ms_tick);
   SEND("\r\n");
   SEND("34");

}
Каждый конец сообщения будем маркировать (31 32 33 и 34) и делать задержку, что бы уж гарантированно все ушло.
Выхлоп терминала в лог-файле
putty_test2.zip
(1.06 KiB) Скачиваний: 2


Будь так добр, взгляни, может где байтик потерялся, или лишний добавился
Пишем тестовый код 3
Спойлер
Код:
void func2 (void)
{
   SEND("\r\n");
   printu(ms_tick);
   SEND("\r\n");

    print_line('=', 38);
    SEND("\r\n STM32F100RB USART DMA-tx !!! 31");

    //delay_ms(2000);

    SEND("\r\n");
    printu(SystemCoreClock);
    SEND(" MHz 32");

    //delay_ms(2000);

   for (uint16_t i = 1000; i<(1000+BUFFER_SIZE); i++){
      Buffer[i-1000] = i;

   }

   SEND("\r\n");
   for (uint16_t i = 0; i<BUFFER_SIZE; i++){
      printu(Buffer[i]);
      SEND(" ");
   }
    SEND("33");
    //delay_ms(5000);

    SEND("\r\n");
   printu(ms_tick);
   SEND("\r\n");
   SEND("34");

}
тот же самый код но только без задержек, но будем его вызывать, скажем
Код:
    while(1)
    {
       if((millis() - previousMillis) > 10000){
          previousMillis = millis();
          GPIOC->ODR ^= GPIO_Pin_9;
          func2();
       }
    }
раз в 10 секунд, в течении 5 минут, секунды подстроил, идут нормально.
Выхлоп терминала в лог-файле
putty_test3.zip
(2.02 KiB) Скачиваний: 0

Будь так добр, взгляни, может где байтик потерялся, или лишний добавился

Re: stm32f4 usart+DMA

Ср фев 02, 2022 18:56:03

Ну и с теми двумя строчками то дожми уже.
Спойлер
Код:
 DMA2_Stream7->M0AR |=(uint32_t)&txData;
        DMA2_Stream7->PAR |=(uint32_t)&USART1->DR;

Выводит какой то мусор.Пару букв а то всё,,,,,,,,_ __ __

Добавлено after 38 minutes 17 seconds:
Получилась передача USSART DMA.А вот в прерывании передача.Да и приём нужно осилить.Функция меня не совсем устраивае.Т было в ряд а сейчас хапос.Да даже кухарка сможет управлять страной.Это я про себя.

Re: stm32f4 usart+DMA

Ср фев 02, 2022 19:04:27

ivan dimir писал(а):Выводит какой то мусор
txData - что это у Вас ?

Re: stm32f4 usart+DMA

Ср фев 02, 2022 19:53:57

Dimon456 писал(а):Проведем парочку экспериментов, на последний байт. Пишем тестовый код2

Ну-ну. Тебе говорят как нужно, чтобы код работал всегда, везде и с любым трансивером. Впрочем, все знают, кто учится на своих ошибках, тем более, когда ему их показали.

Re: stm32f4 usart+DMA

Ср фев 02, 2022 20:23:58

tonyk писал(а):везде и с любым трансивером
Вот докопался со своим трансивером, нету у меня трансивера и не будет.
Раньше когда-то, давным давно, был на 6П3С на 160 метров, и усе.

Re: stm32f4 usart+DMA

Ср фев 02, 2022 20:35:44

Dimon456 писал(а):Вот докопался со своим трансивером, нету у меня трансивера и не будет.

Ты выкладываешь новичкам код, который не у всех будет правильно работать, причём у кого будет, а у кого- нет. Поэтому или оговаривай условия его применимости, или показывай то, что будет работать у всех и всегда.

Re: stm32f4 usart+DMA

Ср фев 02, 2022 20:49:24

Я ни кому ни чего не выкладывал, мне было интересно насколько это эффективно. А эффективно это в том случае если есть куча оперативки.
А код на 2 странице выложен, мне только одно не понятно, за чем ivan dimir изобретает велосипед?

Re: stm32f4 usart+DMA

Ср фев 02, 2022 22:40:47

ivan dimir писал(а):Выводит какой то мусор
txData - что это у Вас ?

Этот код не мой а эту переменную я просто объявил как массив.И заработало.Меня другое волнует.Хочу организовать приём Как мне принять вывести на экран?

Добавлено after 57 minutes 16 seconds:
Ау где вы.? Вымерли?

Re: stm32f4 usart+DMA

Ср фев 02, 2022 23:28:17

ivan dimir, прочитайте свой пост. Вы сами понимаете, что написали ?
Как можно отвечать на хаотичный набор слов ? Уважайте оппонентов - пишите внятно, разборчиво и доходчиво.

Добавлено after 37 minutes 45 seconds:
ivan dimir писал(а):Ау где вы.? Вымерли?
А сам убежал :)))

Re: stm32f4 usart+DMA

Ср фев 02, 2022 23:38:48

Это шутка.Как вывести при приёме USART DMA на дисплей?

Re: stm32f4 usart+DMA

Чт фев 03, 2022 07:44:06

Ау где вы.? Вымерли?

У некоторых в этот момент глубокая ночь.

ivan dimir писал(а):Как вывести при приёме USART DMA на дисплей?

1. Находите, где начало буфера.
2. Находите количество принятых байт.
3. Передаёте данные в функцию вывода на экран.
4. Profit!

Если в буфере текст в кодировке, понятной экрану, то выведется текст.
Если нет - то что угодно, вплоть до ''Проверка' ("Проверка" в кодировке UTF-8, прочитаная как кодировка CP1251).

А вообще, в моём сообщении есть пример получения этих указателей в случае с кольцевым буфером. Полного примера обработки нет. В конце концов, Вы ведь хотите разобраться в коде, а не получить готовый результат, который не понимаете?

Re: stm32f4 usart+DMA

Чт фев 03, 2022 09:08:19

В конце концов, Вы ведь хотите разобраться в коде, а не получить готовый результат, который не понимаете?
Смешно.

Re: stm32f4 usart+DMA

Чт фев 03, 2022 18:20:31

ivan dimir писал(а):Да даже кухарка сможет управлять страной.
Не сможет.
Код VladislavS не полностью, это так, заготовка, да он будет работать, но на один раз, потом ждать надо.
Ты не осилил передачу, прогони мой тест, и посмотрим что у тебя выйдет.
tonyk, пытался про это сказать.

Хорошо, когда много оперативки, а вот когда ее мало, по этому сегодня будем работать с кодом VladislavS.

Добавлено after 4 hours 1 minute 15 seconds:
Код VladislavS
Спойлер
Код:
void Send_str_USART1_DMA(const char *adr)
{
  constexpr uint32_t dma_cfg = _VAL2FLD(DMA_CCR_MSIZE, 0) | _VAL2FLD(DMA_CCR_PSIZE, 0) | DMA_CCR_DIR | DMA_CCR_MINC;
  DMA1_Channel1->CCR = dma_cfg;
  DMA1_Channel1->CMAR = (uint32_t) adr;
  char *p = (char *)adr;
  while(*p) p++;
  DMA1_Channel1->CNDTR = p-adr;
  DMA1_Channel1->CCR = dma_cfg | DMA_CCR_EN;
}
Ведь еще раньше сказал, что больше телодвижений на подготовку буфера и включение канала.
Тестовый код
Спойлер
Код:
      SEND("\r\n");
      printu(ms_tick);
      SEND("\r\n");

       print_line('=', 38);
       SEND("\r\n STM32F100RB USART DMA-tx !!! \r\n");

       printu(SystemCoreClock);
       SEND(" MHz \r\n");
       print_line('=', 38);

       SEND("\r\n");
      printu(ms_tick);
      SEND("\r\n");


      for (uint16_t i = 1000; i<(1000+BUFFER_SIZE); i++){
         Buffer[i-1000] = i;

      }

       SEND("\r\n");
      printu(ms_tick);
      SEND("\r\n");

      for (uint16_t i = 0; i<BUFFER_SIZE; i++){
         printu(Buffer[i]);
         SEND(" ");
      }
      SEND("\r\n");

       SEND("\r\n");
      printu(ms_tick);
      SEND("\r\n");
смотрим где временные метки располагаются
Первый тест
СпойлерПрямой вывод
Код:
#define SEND(str) usart_send_str(str)
void usart_send_str(const char* str)
{
    while(*str) {
    while ((USART1->SR & USART_SR_TXE) == 0) {}
       USART1->DR = *str++;
    }
}
выхлоп терминала
Код:
0
====================
 STM32F100RB USART DMA-tx !!!
32000000 MHz
====================
67

70
1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015
1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031
1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047
1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063
1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079
1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095
1096 1097 1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111
1112 1113 1114 1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127
1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143
1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155 1156 1157 1158 1159
1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 1170 1171 1172 1173 1174 1175
1176 1177 1178 1179 1180 1181 1182 1183 1184 1185 1186 1187 1188 1189 1190 1191
1192 1193 1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207
1208 1209 1210 1211 1212 1213 1214 1215 1216 1217 1218 1219 1220 1221 1222 1223
1224 1225 1226 1227 1228 1229 1230 1231 1232 1233 1234 1235 1236 1237 1238 1239
1240 1241 1242 1243 1244 1245 1246 1247 1248 1249 1250 1251 1252 1253 1254 1255
1256 1257 1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271
1272 1273 1274 1275 1276 1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 1287
1288 1289 1290 1291 1292 1293 1294 1295 1296 1297 1298 1299 1300 1301 1302 1303
1304 1305 1306 1307 1308 1309 1310 1311 1312 1313 1314 1315 1316 1317 1318 1319
1320 1321 1322 1323 1324 1325 1326 1327 1328 1329 1330 1331 1332 1333 1334 1335
1336 1337 1338 1339 1340 1341 1342 1343 1344 1345 1346 1347 1348 1349 1350 1351
1352 1353 1354 1355 1356 1357 1358 1359 1360 1361 1362 1363 1364 1365 1366 1367
1368 1369 1370 1371 1372 1373 1374 1375 1376 1377 1378 1379 1380 1381 1382 1383
1384 1385 1386 1387 1388 1389 1390 1391 1392 1393 1394 1395 1396 1397 1398 1399
1400 1401 1402 1403 1404 1405 1406 1407 1408 1409 1410 1411 1412 1413 1414 1415
1416 1417 1418 1419 1420 1421 1422 1423 1424 1425 1426 1427 1428 1429 1430 1431
1432 1433 1434 1435 1436 1437 1438 1439 1440 1441 1442 1443 1444 1445 1446 1447
1448 1449 1450 1451 1452 1453 1454 1455 1456 1457 1458 1459 1460 1461 1462 1463
1464 1465 1466 1467 1468 1469 1470 1471 1472 1473 1474 1475 1476 1477 1478 1479
1480 1481 1482 1483 1484 1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495
1496 1497 1498 1499 1500 1501 1502 1503 1504 1505 1506 1507 1508 1509 1510 1511

1407
смотрим на временные метки
Тест 2
Спойлеркод VladislavS в том виде в котором он есть
Код:
#define SEND(str) Send_str_USART1_DMA(str)
выхлоп терминала
Код:
 1 11  1
хотя единичную строку выводит
Тест3
СпойлерВсего одну строку добавил в код VladislavS
Код:
while ((USART1->SR & USART_SR_TC) == 0) {};
Выхлоп терминала
Код:
0
====================
 STM32F100RB USART DMA-tx !!!
32000000 MHz
====================
72

75
1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015
1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031
1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047
1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063
1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079
1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095
1096 1097 1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111
1112 1113 1114 1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127
1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143
1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155 1156 1157 1158 1159
1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 1170 1171 1172 1173 1174 1175
1176 1177 1178 1179 1180 1181 1182 1183 1184 1185 1186 1187 1188 1189 1190 1191
1192 1193 1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207
1208 1209 1210 1211 1212 1213 1214 1215 1216 1217 1218 1219 1220 1221 1222 1223
1224 1225 1226 1227 1228 1229 1230 1231 1232 1233 1234 1235 1236 1237 1238 1239
1240 1241 1242 1243 1244 1245 1246 1247 1248 1249 1250 1251 1252 1253 1254 1255
1256 1257 1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271
1272 1273 1274 1275 1276 1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 1287
1288 1289 1290 1291 1292 1293 1294 1295 1296 1297 1298 1299 1300 1301 1302 1303
1304 1305 1306 1307 1308 1309 1310 1311 1312 1313 1314 1315 1316 1317 1318 1319
1320 1321 1322 1323 1324 1325 1326 1327 1328 1329 1330 1331 1332 1333 1334 1335
1336 1337 1338 1339 1340 1341 1342 1343 1344 1345 1346 1347 1348 1349 1350 1351
1352 1353 1354 1355 1356 1357 1358 1359 1360 1361 1362 1363 1364 1365 1366 1367
1368 1369 1370 1371 1372 1373 1374 1375 1376 1377 1378 1379 1380 1381 1382 1383
1384 1385 1386 1387 1388 1389 1390 1391 1392 1393 1394 1395 1396 1397 1398 1399
1400 1401 1402 1403 1404 1405 1406 1407 1408 1409 1410 1411 1412 1413 1414 1415
1416 1417 1418 1419 1420 1421 1422 1423 1424 1425 1426 1427 1428 1429 1430 1431
1432 1433 1434 1435 1436 1437 1438 1439 1440 1441 1442 1443 1444 1445 1446 1447
1448 1449 1450 1451 1452 1453 1454 1455 1456 1457 1458 1459 1460 1461 1462 1463
1464 1465 1466 1467 1468 1469 1470 1471 1472 1473 1474 1475 1476 1477 1478 1479
1480 1481 1482 1483 1484 1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495
1496 1497 1498 1499 1500 1501 1502 1503 1504 1505 1506 1507 1508 1509 1510 1511

1466
смотрим временные метки
Это без использования оперативной памяти.
Я не вижу прироста производительности, наоборот снижение.

Ну и последний тест, с буфером на 3кило
Спойлер
Код:
0
====================
 STM32F100RB USART DMA-tx !!!
32000000 MHz
====================
0

0
1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015
1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031
1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047
1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063
1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079
1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095
1096 1097 1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111
1112 1113 1114 1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127
1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143
1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155 1156 1157 1158 1159
1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 1170 1171 1172 1173 1174 1175
1176 1177 1178 1179 1180 1181 1182 1183 1184 1185 1186 1187 1188 1189 1190 1191
1192 1193 1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207
1208 1209 1210 1211 1212 1213 1214 1215 1216 1217 1218 1219 1220 1221 1222 1223
1224 1225 1226 1227 1228 1229 1230 1231 1232 1233 1234 1235 1236 1237 1238 1239
1240 1241 1242 1243 1244 1245 1246 1247 1248 1249 1250 1251 1252 1253 1254 1255
1256 1257 1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271
1272 1273 1274 1275 1276 1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 1287
1288 1289 1290 1291 1292 1293 1294 1295 1296 1297 1298 1299 1300 1301 1302 1303
1304 1305 1306 1307 1308 1309 1310 1311 1312 1313 1314 1315 1316 1317 1318 1319
1320 1321 1322 1323 1324 1325 1326 1327 1328 1329 1330 1331 1332 1333 1334 1335
1336 1337 1338 1339 1340 1341 1342 1343 1344 1345 1346 1347 1348 1349 1350 1351
1352 1353 1354 1355 1356 1357 1358 1359 1360 1361 1362 1363 1364 1365 1366 1367
1368 1369 1370 1371 1372 1373 1374 1375 1376 1377 1378 1379 1380 1381 1382 1383
1384 1385 1386 1387 1388 1389 1390 1391 1392 1393 1394 1395 1396 1397 1398 1399
1400 1401 1402 1403 1404 1405 1406 1407 1408 1409 1410 1411 1412 1413 1414 1415
1416 1417 1418 1419 1420 1421 1422 1423 1424 1425 1426 1427 1428 1429 1430 1431
1432 1433 1434 1435 1436 1437 1438 1439 1440 1441 1442 1443 1444 1445 1446 1447
1448 1449 1450 1451 1452 1453 1454 1455 1456 1457 1458 1459 1460 1461 1462 1463
1464 1465 1466 1467 1468 1469 1470 1471 1472 1473 1474 1475 1476 1477 1478 1479
1480 1481 1482 1483 1484 1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495
1496 1497 1498 1499 1500 1501 1502 1503 1504 1505 1506 1507 1508 1509 1510 1511

6
смотрим временные метки

Re: stm32f4 usart+DMA

Чт фев 03, 2022 19:02:19

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

Re: stm32f4 usart+DMA

Чт фев 03, 2022 20:11:48

Это мрак какой-то. Отправляет данные с помощью DMA, ждёт окончания их передачи по TC и хочет увидеть разницу. Он идиот?

Re: stm32f4 usart+DMA

Чт фев 03, 2022 20:21:33

Это мрак какой-то. Отправляет данные с помощью DMA, ждёт окончания их передачи по TC и хочет увидеть разницу. Он идиот?

Ага, при этом проц в случае тупой загрузки в DR занят ожиданием окончания передачи, а в случае передачи через DMA ждёт окончания пересылки. При этом упорно забывая, что в случае передачи через DMA проц может заниматься другими делами!

Есть разные степени оценки слабоумия. Так вот, идиот гораздо умнее имбицила.

Re: stm32f4 usart+DMA

Чт фев 03, 2022 20:48:01

VladislavS писал(а):Отправляет данные с помощью DMA, ждёт окончания их передачи по TC и хочет увидеть разницу.
Все верно, что бы отправить данные с помощью DMA, я должен дождаться завершения предыдущей передачи.
А по TC, 100% гарантия что UART отработал. Пробовал по TXE, но прироста я не ощутил.

Либо так, либо буфер в 3кило.

Re: stm32f4 usart+DMA

Чт фев 03, 2022 21:07:19

В этом "супертесте" передаётся что-то около (512*5+2)*10 бит. На скорости 19200 это 1.34 секунды на физическую передачу по линии. Можно все их потратить на ожидание, а можно отправлять в фоне. Но тут надо головой не для еды и пальчиками по клавиатуре поработать.

Природу не обманешь, если данные генерируются быстрее чем передаются по линии передачи, то их надо буферизировать.

Re: stm32f4 usart+DMA

Чт фев 03, 2022 21:33:46

Это шутка.Как вывести при приёме USART DMA на дисплей?
Элементарно!: printf("USART DMA");
Пользуйтесь! :)))
Ответить