Blame view

src/demo/main_dvpp.cpp 9.14 KB
aac5773f   hucm   功能基本完成,接口待打磨
1
  #include <iostream>
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
2
3
  #include <pthread.h>
  #include <thread>
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
4
  #include <chrono>
3d2ab595   Hu Chunming   支持gb28181
5
6
7
8
9
10
11
12
13
14
15
16
  #include <unistd.h>
  
  
  #ifdef _WIN32
  #include "Winsock2.h"
  #pragma comment(lib, "ws2_32.lib")
  #endif
  
  #ifdef __linux__
  #include "arpa/inet.h"
  #endif
  
63e6f7bc   Hu Chunming   完成dvpp。但是nv和gb281...
17
18
  #include "../interface/FFNvDecoderManager.h"
  #include "../interface/utiltools.hpp"
3d2ab595   Hu Chunming   支持gb28181
19
20
21
22
  
  #define MIN_RTP_PORT		10000
  #define MAX_RTP_PORT		60000
  
3d2ab595   Hu Chunming   支持gb28181
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
  // ȡ MIN_RTP_PORT(10000)~MAX_RTP_PORT(60000)֮�������˿�(ż���������������˿ڿ���)
  int allocRtpPort() {
  
  	static int s_rtpPort = MIN_RTP_PORT;
  	if (MIN_RTP_PORT == s_rtpPort)
  	{
  		srand((unsigned int)time(NULL));
  		s_rtpPort = MIN_RTP_PORT + (rand() % MIN_RTP_PORT);
  	}
  
  	if (s_rtpPort % 2)
  		++s_rtpPort;
  
  	while (true)
  	{
  		s_rtpPort += 2;
  		s_rtpPort = s_rtpPort >= MAX_RTP_PORT ? MIN_RTP_PORT : s_rtpPort;
  
  		int i = 0;
  		for (; i < 2; i++)
  		{
  			sockaddr_in sRecvAddr;
  			int s = socket(AF_INET, SOCK_DGRAM, 0);
  
  			sRecvAddr.sin_family = AF_INET;        
  			sRecvAddr.sin_addr.s_addr = htonl(INADDR_ANY);    
  			sRecvAddr.sin_port = htons(s_rtpPort + i); 
  
  			int nResult = bind(s, (sockaddr *)&sRecvAddr, sizeof(sRecvAddr));
  			if (nResult != 0)
  			{
  				break;
  			}
  
  			nResult = close(s);
  			if (nResult != 0)
  			{
  				printf("closesocket failed:%d\n", nResult);
  				break;
  			}
  		}
  
  		if (i == 2)
  			break;
  	}
  
  	return s_rtpPort;
  }
  
  
  
  
  
e65720d4   Hu Chunming   优化demo
76
77
78
79
80
  unsigned char *pHwRgb[2] = {nullptr, nullptr};
  
  int sum1 = 0;
  int sum2 = 0;
  
e41a52bb   Hu Chunming   1.优化数据读取线程;2. 添加A...
81
  
92989af0   ming   更新解码器
82
  string data_home = "/mnt/data/cmhu/tmp/";
a2b7fd92   ming   测试代码优化
83
84
  
  
a2b7fd92   ming   测试代码优化
85
  
a2b7fd92   ming   测试代码优化
86
  
0b43216c   Hu Chunming   添加重要注释
87
88
89
  /**
   * 注意: gpuFrame 在解码器设置的显卡上,后续操作要十分注意这一点,尤其是多线程情况
   * */
63e6f7bc   Hu Chunming   完成dvpp。但是nv和gb281...
90
  void postDecoded(const void * userPtr, DeviceRgbMemory* devFrame){
3d2ab595   Hu Chunming   支持gb28181
91
      AbstractDecoder* decoder = (AbstractDecoder*)userPtr;
aac5773f   hucm   功能基本完成,接口待打磨
92
93
      if (decoder!= nullptr)
      {
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
94
95
          // cout << "decode name: " << decoder->getName() << endl;
  
e65720d4   Hu Chunming   优化demo
96
97
98
99
100
101
              // const char* gpu_pixfmt = av_get_pix_fmt_name((AVPixelFormat)gpuFrame->format);
              // cout << "pixfmt: " << gpu_pixfmt << endl;
              // cout << "keyframe: " << gpuFrame->key_frame << " width: " << gpuFrame->width << " height: "<< gpuFrame->height << endl;
              // cout << "decode successed ✿✿ヽ(°▽°)ノ✿ " << endl;
  
              int sum = sum1;
372e629f   ming   gb28181支持TCP数据流
102
              if (decoder->getName() == "dec0")
e65720d4   Hu Chunming   优化demo
103
104
105
              {
                  sum1 ++ ;
                  sum = sum1;
e65720d4   Hu Chunming   优化demo
106
107
108
109
              } else if (decoder->getName() == "dec2") 
              {
                  sum2 ++ ;
                  sum = sum2;
e65720d4   Hu Chunming   优化demo
110
              }
aac5773f   hucm   功能基本完成,接口待打磨
111
112
113
      }
  }
  
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
114
115
116
117
118
119
  long start_time = 0;
  long end_time = 0;
  bool count_flag = false;
  int count = 0;
  int count_std = 100;
  
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
120
  
bc52e542   Hu Chunming   添加关键帧解码功能
121
  static int sum = 0;
e65720d4   Hu Chunming   优化demo
122
123
  unsigned char *pHwData = nullptr;
  
63e6f7bc   Hu Chunming   完成dvpp。但是nv和gb281...
124
  void postDecoded0(const void * userPtr, DeviceRgbMemory* devFrame){
bc52e542   Hu Chunming   添加关键帧解码功能
125
126
      // std::this_thread::sleep_for(std::chrono::milliseconds(30000));
  
3d2ab595   Hu Chunming   支持gb28181
127
      AbstractDecoder* decoder = (AbstractDecoder*)userPtr;
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
128
129
130
131
132
133
134
135
136
      if (decoder!= nullptr)
      {
          // cout << "decode name: " << decoder->getName() << endl;
          if (decoder->getName() == "dec")
          {
              if (! count_flag)
              {
                  count_flag = true;
                  count = 0;
92989af0   ming   更新解码器
137
                  end_time = start_time = UtilTools::get_cur_time_ms();
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
138
139
140
              }
              count++;
              sum ++ ;
0a826b3d   Hu Chunming   适应WSL的修改
141
142
              if (count >= count_std)
              {
92989af0   ming   更新解码器
143
                  // end_time = UtilTools::get_cur_time_ms();
0a826b3d   Hu Chunming   适应WSL的修改
144
145
146
                  // long time_using = end_time - start_time;
                  // double time_per_frame = double(time_using)/count_std ;
                  // cout << count_std << "帧用时:" << time_using << "ms 每帧用时:" << time_per_frame << "ms" << endl;
63e6f7bc   Hu Chunming   完成dvpp。但是nv和gb281...
147
                  cout << decoder->getName() << " keyframe: " << devFrame->isKeyFrame() << " width: " << devFrame->getWidth() << " height: "<< devFrame->getHeight() << endl;
a2b7fd92   ming   测试代码优化
148
                  // cout << gpuFrame->pts << endl;
0a826b3d   Hu Chunming   适应WSL的修改
149
150
151
  
                  count_flag = false;
              }
a2b7fd92   ming   测试代码优化
152
              // cout << "帧数:" << sum << endl;
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
153
154
155
156
          }
      }
  }
  
6fc86385   ming   代码优化
157
  void decode_finished_cbk(const void* userPtr){
92989af0   ming   更新解码器
158
      cout << "当前时间戳: " << UtilTools::get_cur_time_ms() << endl;
6fc86385   ming   代码优化
159
160
  }
  
92989af0   ming   更新解码器
161
  bool decode_request_stream_cbk(const char* deviceId){
372e629f   ming   gb28181支持TCP数据流
162
163
164
165
      cout << "需在此请求流" << endl;
      return true;
  }
  
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
166
  // string test_uri = "rtmp://192.168.10.56:1935/objecteye/1";
e65720d4   Hu Chunming   优化demo
167
  // string test_uri = "/home/cmhu/data/output_800x480.mp4";
bc52e542   Hu Chunming   添加关键帧解码功能
168
169
  // string test_uri = "/home/cmhu/data/output_1920x1080.mp4";
  // string test_uri = "rtsp://176.10.0.2:8554/stream";
d384f0e9   Hu Chunming   代码优化
170
  // string test_uri = "/mnt/f/fiss/test_data/h265.mp4";
63e6f7bc   Hu Chunming   完成dvpp。但是nv和gb281...
171
172
  // string test_uri = "rtsp://176.10.0.4:8554/stream";
  string test_uri = "rtsp://admin:admin@123456@192.168.60.176:554/cam/realmonitor?channel=1&subtype=0";
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
173
  
a2b7fd92   ming   测试代码优化
174
  void createDecode(int index, const char* gpu_id){
aac5773f   hucm   功能基本完成,接口待打磨
175
      FFNvDecoderManager* pDecManager = FFNvDecoderManager::getInstance();
7319ea36   Hu Chunming   多显卡设置
176
      MgrDecConfig config;
48330793   Hu Chunming   修正解码线程自然结束时解码器内存没...
177
      config.name = "dec" + to_string(index);
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
178
      config.cfg.uri = test_uri;
7319ea36   Hu Chunming   多显卡设置
179
      config.cfg.post_decoded_cbk = postDecoded;
6fc86385   ming   代码优化
180
      config.cfg.decode_finished_cbk = decode_finished_cbk;
7319ea36   Hu Chunming   多显卡设置
181
      config.cfg.force_tcp = true;
3d2ab595   Hu Chunming   支持gb28181
182
      config.dec_type = DECODER_TYPE_FFMPEG;
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
183
  
372e629f   ming   gb28181支持TCP数据流
184
      config.cfg.gpuid = gpu_id;
a2b7fd92   ming   测试代码优化
185
186
      // if (index % 2 == 0)
      // {
3d2ab595   Hu Chunming   支持gb28181
187
      //     config.cfg.gpuid = "0";
a2b7fd92   ming   测试代码优化
188
189
190
191
192
      // }
      // else
      // {
      //     config.cfg.gpuid = "0";
      // }
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
193
      
3d2ab595   Hu Chunming   支持gb28181
194
195
      AbstractDecoder* decoder = pDecManager->createDecoder(config);
      if (!decoder)
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
196
      {
3d2ab595   Hu Chunming   支持gb28181
197
          return ;
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
198
      }
3d2ab595   Hu Chunming   支持gb28181
199
200
201
202
203
      pDecManager->setPostDecArg(config.name, decoder);
      pDecManager->setFinishedDecArg(config.name, decoder);
      pDecManager->startDecodeByName(config.name);
  }
  
372e629f   ming   gb28181支持TCP数据流
204
  void createGB28181Decode(int index, char* gpu_id, int port){
3d2ab595   Hu Chunming   支持gb28181
205
206
207
208
209
210
      FFNvDecoderManager* pDecManager = FFNvDecoderManager::getInstance();
      MgrDecConfig config;
      config.name = "dec" + to_string(index);
      config.cfg.uri = config.name;
      config.cfg.post_decoded_cbk = postDecoded;
      config.cfg.decode_finished_cbk = decode_finished_cbk;
372e629f   ming   gb28181支持TCP数据流
211
      config.cfg.request_stream_cbk = decode_request_stream_cbk;
3d2ab595   Hu Chunming   支持gb28181
212
213
214
      config.cfg.force_tcp = true;
  
      config.dec_type = DECODER_TYPE_GB28181;
372e629f   ming   gb28181支持TCP数据流
215
      config.cfg.port = port;//allocRtpPort();
3d2ab595   Hu Chunming   支持gb28181
216
  
372e629f   ming   gb28181支持TCP数据流
217
      config.cfg.gpuid = gpu_id;
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
218
      
3d2ab595   Hu Chunming   支持gb28181
219
      AbstractDecoder* decoder = pDecManager->createDecoder(config);
7319ea36   Hu Chunming   多显卡设置
220
221
      if (!decoder)
      {
48330793   Hu Chunming   修正解码线程自然结束时解码器内存没...
222
          return ;
7319ea36   Hu Chunming   多显卡设置
223
      }
3d2ab595   Hu Chunming   支持gb28181
224
225
      pDecManager->setPostDecArg(config.name, decoder);
      pDecManager->setFinishedDecArg(config.name, decoder);
7319ea36   Hu Chunming   多显卡设置
226
      pDecManager->startDecodeByName(config.name);
48330793   Hu Chunming   修正解码线程自然结束时解码器内存没...
227
228
  }
  
63e6f7bc   Hu Chunming   完成dvpp。但是nv和gb281...
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
  void createDvppDecoder(int index, char* devId, int channelId){
      FFNvDecoderManager* pDecManager = FFNvDecoderManager::getInstance();
      MgrDecConfig config;
      config.name = "dec" + to_string(index);
      config.cfg.uri = test_uri;
      config.cfg.post_decoded_cbk = postDecoded;
      config.cfg.decode_finished_cbk = decode_finished_cbk;
      config.cfg.force_tcp = true;
      config.dec_type = DECODER_TYPE_DVPP;
  
      config.cfg.gpuid = devId;
      
      AbstractDecoder* decoder = pDecManager->createDecoder(config);
      if (!decoder)
      {
          return ;
      }
      pDecManager->setPostDecArg(config.name, decoder);
      pDecManager->setFinishedDecArg(config.name, decoder);
      pDecManager->startDecodeByName(config.name);
  }
  
3c7e3e11   Hu Chunming   1.修改日志
251
252
253
254
255
256
  void logFF(void *, int level, const char *fmt, va_list ap)
  {
      vfprintf(stdout, fmt, ap);
  }
  
  
2b980c5a   ming   优化代码
257
258
  int main(int argc, char* argv[]){
  
63e6f7bc   Hu Chunming   完成dvpp。但是nv和gb281...
259
      test_uri = argv[1];
372e629f   ming   gb28181支持TCP数据流
260
261
262
      char* gpuid = argv[2];
      int port = atoi(argv[3]);
      cout << test_uri << "   gpu_id:" << gpuid << "   port:" << port << endl;
48330793   Hu Chunming   修正解码线程自然结束时解码器内存没...
263
  
3c7e3e11   Hu Chunming   1.修改日志
264
265
      // av_log_set_callback(&logFF);
  
63e6f7bc   Hu Chunming   完成dvpp。但是nv和gb281...
266
      // CheckCUDAProperty(atoi(gpuid));
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
267
  
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
268
269
270
271
      pthread_t m_decode_thread;
      pthread_create(&m_decode_thread,0,
          [](void* arg)
          {
a2b7fd92   ming   测试代码优化
272
              // cudaSetDevice(atoi(gpuid));
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
273
274
              while (true)
              {
372e629f   ming   gb28181支持TCP数据流
275
                  std::this_thread::sleep_for(std::chrono::minutes(1));
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
276
277
                  FFNvDecoderManager* pDecManager = FFNvDecoderManager::getInstance();
                  int count = pDecManager->count();
92989af0   ming   更新解码器
278
                  cout << "当前时间:" << UtilTools::get_cur_time_ms() << "  当前运行路数: " << pDecManager->count() << endl;
f40cc409   Hu Chunming   优化显存占用。当前在3080显卡上...
279
280
281
282
283
284
              }  
  
              return (void*)0;
          }
      ,nullptr);
  
aac5773f   hucm   功能基本完成,接口待打磨
285
  
3d2ab595   Hu Chunming   支持gb28181
286
287
      FFNvDecoderManager* pDecManager = FFNvDecoderManager::getInstance();
      int i = 0;
aac5773f   hucm   功能基本完成,接口待打磨
288
  
63e6f7bc   Hu Chunming   完成dvpp。但是nv和gb281...
289
      createDvppDecoder(i, gpuid, 0);
6042f34b   Hu Chunming   代码优化
290
      i++;
63e6f7bc   Hu Chunming   完成dvpp。但是nv和gb281...
291
  
3d2ab595   Hu Chunming   支持gb28181
292
293
294
295
296
297
298
      while (true)
      {
          int ch = getchar();
          if (ch == 'q')
          {
              break;
          }
aac5773f   hucm   功能基本完成,接口待打磨
299
  
3d2ab595   Hu Chunming   支持gb28181
300
301
302
303
          switch (ch)
          {
          case 'f':
          case 'F':
372e629f   ming   gb28181支持TCP数据流
304
              createDecode(i, gpuid);
3d2ab595   Hu Chunming   支持gb28181
305
306
307
308
              i++;
              break;
          case 'g':
          case 'G':
372e629f   ming   gb28181支持TCP数据流
309
              createGB28181Decode(i, gpuid, port);
3d2ab595   Hu Chunming   支持gb28181
310
311
              i++;
              break;
63e6f7bc   Hu Chunming   完成dvpp。但是nv和gb281...
312
313
314
315
316
          case 'd':
          case 'D':
              createDvppDecoder(i, gpuid, 0);
              i++;
              break;
3d2ab595   Hu Chunming   支持gb28181
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
          case 'r':
          case 'R':
              pDecManager->resumeDecoder("dec0");
              break;
          case 'p':
          case 'P':
              pDecManager->pauseDecoder("dec0");
              break;
  
          case 'c':
          case 'C':
              i--;
              pDecManager->closeDecoderByName("dec" + to_string(i));
              break;
  
          case 'i':
          case 'I':
          {
              int w,h;
              pDecManager->getResolution("dec0", w,h);
              printf( "%s : %dx%d\n", "dec0" , w,h );
          }
              break;
aac5773f   hucm   功能基本完成,接口待打磨
340
  
3d2ab595   Hu Chunming   支持gb28181
341
342
343
          default:
              break;
          }
aac5773f   hucm   功能基本完成,接口待打磨
344
  
3d2ab595   Hu Chunming   支持gb28181
345
346
          /* code */
      }
aac5773f   hucm   功能基本完成,接口待打磨
347
  
bc52e542   Hu Chunming   添加关键帧解码功能
348
      cout << "总共帧数:" << sum << endl;
aac5773f   hucm   功能基本完成,接口待打磨
349
350
      pDecManager->closeAllDecoder();
  }