winlin

Merge branch '2.0release' into develop

@@ -25,3 +25,6 @@ @@ -25,3 +25,6 @@
25 /trunk/research/api-server/static-dir/forward 25 /trunk/research/api-server/static-dir/forward
26 /trunk/research/api-server/static-dir/live 26 /trunk/research/api-server/static-dir/live
27 /trunk/research/api-server/static-dir/players 27 /trunk/research/api-server/static-dir/players
  28 +
  29 +# Apple-specific garbage files.
  30 +.AppleDouble
@@ -23,4 +23,5 @@ CONTRIBUTORS ordered by first contribution. @@ -23,4 +23,5 @@ CONTRIBUTORS ordered by first contribution.
23 * tufang14<breadbean1449@gmail.com> "Bug fixed" 23 * tufang14<breadbean1449@gmail.com> "Bug fixed"
24 * allspace<allspace@gmail.com> "The srs-librtmp windows support" 24 * allspace<allspace@gmail.com> "The srs-librtmp windows support"
25 * niesongsong<nie950@gmail.com> "Configure support relative path" 25 * niesongsong<nie950@gmail.com> "Configure support relative path"
  26 +* rudeb0t<nimrod@themanxgroup.tw> "Bug fixed"
26 27
1 -Only in .: 1.st.arm.patch  
2 -diff -r -c ./md.h ../st-1.9-patch-arm/md.h  
3 -*** ./md.h 2009-10-02 02:46:43.000000000 +0800  
4 ---- ../st-1.9-patch-arm/md.h 2014-03-16 20:49:03.845344804 +0800 1 +*** md.h Fri Oct 2 02:46:43 2009
  2 +--- ../st-1.9-patch/md.h Mon Mar 16 15:11:49 2015
5 *************** 3 ***************
6 *** 422,428 **** 4 *** 422,428 ****
7 #define MD_STACK_GROWS_DOWN 5 #define MD_STACK_GROWS_DOWN
1 -diff -r -c ./Makefile ../http-parser-2.1/Makefile  
2 -*** ./Makefile Tue Mar 10 10:44:19 2015  
3 ---- ../http-parser-2.1/Makefile Wed Mar 27 06:35:20 2013 1 +*** Makefile Wed Mar 27 06:35:20 2013
  2 +--- ../http-parser-2.1-patch/Makefile Mon Mar 16 15:25:59 2015
4 *************** 3 ***************
5 -*** 12,22 **** 4 +*** 12,17 ****
  5 +--- 12,22 ----
6 CFLAGS_FAST = $(CFLAGS) -O3 $(CFLAGS_FAST_EXTRA) 6 CFLAGS_FAST = $(CFLAGS) -O3 $(CFLAGS_FAST_EXTRA)
7 CFLAGS_LIB = $(CFLAGS_FAST) -fPIC 7 CFLAGS_LIB = $(CFLAGS_FAST) -fPIC
8 8
9 -- # patch by winlin  
10 -- CPPFLAGS_FAST = $(CPPFLAGS_DEBUG)  
11 -- CFLAGS_FAST = $(CFLAGS_DEBUG)  
12 -- CFLAGS_LIB = $(CFLAGS_FAST) -fPIC  
13 -- 9 ++ # patch by winlin
  10 ++ CPPFLAGS_FAST = $(CPPFLAGS_DEBUG)
  11 ++ CFLAGS_FAST = $(CFLAGS_DEBUG)
  12 ++ CFLAGS_LIB = $(CFLAGS_FAST) -fPIC
  13 ++
14 test: test_g test_fast 14 test: test_g test_fast
15 ./test_g 15 ./test_g
16 ./test_fast 16 ./test_fast
17 ---- 12,17 ----  
  1 +*** io.c Fri Oct 2 06:49:07 2009
  2 +--- ../st-1.9-patch/io.c Mon Mar 16 15:06:28 2015
  3 +***************
  4 +*** 89,94 ****
  5 +--- 89,102 ----
  6 + if (fdlim > 0 && rlim.rlim_max > (rlim_t) fdlim) {
  7 + rlim.rlim_max = fdlim;
  8 + }
  9 ++
  10 ++ /* when rlimit max is negative, for example, osx, use cur directly. */
  11 ++ /* @see https://github.com/winlinvip/simple-rtmp-server/issues/336 */
  12 ++ if ((int)rlim.rlim_max < 0) {
  13 ++ _st_osfd_limit = (int)(fdlim > 0? fdlim : rlim.rlim_cur);
  14 ++ return 0;
  15 ++ }
  16 ++
  17 + rlim.rlim_cur = rlim.rlim_max;
  18 + if (setrlimit(RLIMIT_NOFILE, &rlim) < 0)
  19 + return -1;
  1 +*** Makefile Fri Oct 2 06:55:03 2009
  2 +--- ../st-1.9-patch/Makefile Mon Mar 16 15:30:35 2015
  3 +***************
  4 +*** 310,315 ****
  5 +--- 310,319 ----
  6 + EXAMPLES =
  7 + endif
  8 +
  9 ++ # disable examples for ubuntu crossbuild failed.
  10 ++ # @see https://github.com/winlinvip/simple-rtmp-server/issues/308
  11 ++ EXAMPLES =
  12 ++
  13 + ifeq ($(OS), DARWIN)
  14 + LINKNAME = libst.$(DSO_SUFFIX)
  15 + SONAME = libst.$(MAJOR).$(DSO_SUFFIX)
@@ -376,7 +376,7 @@ if [ $SRS_EXPORT_LIBRTMP_PROJECT = NO ]; then @@ -376,7 +376,7 @@ if [ $SRS_EXPORT_LIBRTMP_PROJECT = NO ]; then
376 _ST_MAKE=linux-debug && _ST_EXTRA_CFLAGS="EXTRA_CFLAGS=-DMD_HAVE_EPOLL" 376 _ST_MAKE=linux-debug && _ST_EXTRA_CFLAGS="EXTRA_CFLAGS=-DMD_HAVE_EPOLL"
377 # for osx, use darwin for st, donot use epoll. 377 # for osx, use darwin for st, donot use epoll.
378 if [ $OS_IS_OSX = YES ]; then 378 if [ $OS_IS_OSX = YES ]; then
379 - _ST_MAKE=darwin-debug && _ST_EXTRA_CFLAGS="" 379 + _ST_MAKE=darwin-debug && _ST_EXTRA_CFLAGS="EXTRA_CFLAGS=-DMD_HAVE_KQUEUE"
380 fi 380 fi
381 # memory leak for linux-optimized 381 # memory leak for linux-optimized
382 # @see: https://github.com/winlinvip/simple-rtmp-server/issues/197 382 # @see: https://github.com/winlinvip/simple-rtmp-server/issues/197
@@ -390,10 +390,11 @@ if [ $SRS_EXPORT_LIBRTMP_PROJECT = NO ]; then @@ -390,10 +390,11 @@ if [ $SRS_EXPORT_LIBRTMP_PROJECT = NO ]; then
390 echo "build st-1.9t for arm"; 390 echo "build st-1.9t for arm";
391 ( 391 (
392 rm -rf ${SRS_OBJS}/st-1.9 && cd ${SRS_OBJS} && 392 rm -rf ${SRS_OBJS}/st-1.9 && cd ${SRS_OBJS} &&
393 - unzip -q ../3rdparty/st-1.9.zip && cd st-1.9 &&  
394 - patch -p0 -R < ../../3rdparty/patches/1.st.arm.patch &&  
395 - make ${_ST_MAKE} CC=${SrsArmCC} AR=${SrsArmAR} LD=${SrsArmLD} RANDLIB=${SrsArmRANDLIB} \  
396 - EXTRA_CFLAGS=${_ST_EXTRA_CFLAGS} && 393 + unzip -q ../3rdparty/st-1.9.zip && cd st-1.9 && chmod +w * &&
  394 + patch -p0 < ../../3rdparty/patches/1.st.arm.patch &&
  395 + patch -p0 < ../../3rdparty/patches/3.st.osx.kqueue.patch &&
  396 + patch -p0 < ../../3rdparty/patches/4.st.disable.examples.patch &&
  397 + make ${_ST_MAKE} CC=${SrsArmCC} AR=${SrsArmAR} LD=${SrsArmLD} RANDLIB=${SrsArmRANDLIB} ${_ST_EXTRA_CFLAGS} &&
397 cd .. && rm -rf st && ln -sf st-1.9/obj st && 398 cd .. && rm -rf st && ln -sf st-1.9/obj st &&
398 cd .. && touch ${SRS_OBJS}/_flag.st.arm.tmp 399 cd .. && touch ${SRS_OBJS}/_flag.st.arm.tmp
399 ) 400 )
@@ -405,7 +406,9 @@ if [ $SRS_EXPORT_LIBRTMP_PROJECT = NO ]; then @@ -405,7 +406,9 @@ if [ $SRS_EXPORT_LIBRTMP_PROJECT = NO ]; then
405 echo "build st-1.9t"; 406 echo "build st-1.9t";
406 ( 407 (
407 rm -rf ${SRS_OBJS}/st-1.9 && cd ${SRS_OBJS} && 408 rm -rf ${SRS_OBJS}/st-1.9 && cd ${SRS_OBJS} &&
408 - unzip -q ../3rdparty/st-1.9.zip && cd st-1.9 && 409 + unzip -q ../3rdparty/st-1.9.zip && cd st-1.9 && chmod +w * &&
  410 + patch -p0 < ../../3rdparty/patches/3.st.osx.kqueue.patch &&
  411 + patch -p0 < ../../3rdparty/patches/4.st.disable.examples.patch &&
409 make ${_ST_MAKE} ${_ST_EXTRA_CFLAGS} && 412 make ${_ST_MAKE} ${_ST_EXTRA_CFLAGS} &&
410 cd .. && rm -rf st && ln -sf st-1.9/obj st && 413 cd .. && rm -rf st && ln -sf st-1.9/obj st &&
411 cd .. && rm -f ${SRS_OBJS}/_flag.st.arm.tmp 414 cd .. && rm -f ${SRS_OBJS}/_flag.st.arm.tmp
@@ -431,7 +434,7 @@ if [ $SRS_HTTP_PARSER = YES ]; then @@ -431,7 +434,7 @@ if [ $SRS_HTTP_PARSER = YES ]; then
431 ( 434 (
432 rm -rf ${SRS_OBJS}/http-parser-2.1 && cd ${SRS_OBJS} && unzip -q ../3rdparty/http-parser-2.1.zip && 435 rm -rf ${SRS_OBJS}/http-parser-2.1 && cd ${SRS_OBJS} && unzip -q ../3rdparty/http-parser-2.1.zip &&
433 cd http-parser-2.1 && 436 cd http-parser-2.1 &&
434 - patch -p0 -R < ../../3rdparty/patches/2.http.parser.patch && 437 + patch -p0 < ../../3rdparty/patches/2.http.parser.patch &&
435 sed -i "s/CPPFLAGS_FAST +=.*$/CPPFLAGS_FAST = \$\(CPPFLAGS_DEBUG\)/g" Makefile && 438 sed -i "s/CPPFLAGS_FAST +=.*$/CPPFLAGS_FAST = \$\(CPPFLAGS_DEBUG\)/g" Makefile &&
436 sed -i "s/CFLAGS_FAST =.*$/CFLAGS_FAST = \$\(CFLAGS_DEBUG\)/g" Makefile && 439 sed -i "s/CFLAGS_FAST =.*$/CFLAGS_FAST = \$\(CFLAGS_DEBUG\)/g" Makefile &&
437 make CC=${SrsArmCC} AR=${SrsArmAR} package && 440 make CC=${SrsArmCC} AR=${SrsArmAR} package &&
@@ -448,7 +451,7 @@ if [ $SRS_HTTP_PARSER = YES ]; then @@ -448,7 +451,7 @@ if [ $SRS_HTTP_PARSER = YES ]; then
448 ( 451 (
449 rm -rf ${SRS_OBJS}/http-parser-2.1 && cd ${SRS_OBJS} && unzip -q ../3rdparty/http-parser-2.1.zip && 452 rm -rf ${SRS_OBJS}/http-parser-2.1 && cd ${SRS_OBJS} && unzip -q ../3rdparty/http-parser-2.1.zip &&
450 cd http-parser-2.1 && 453 cd http-parser-2.1 &&
451 - patch -p0 -R < ../../3rdparty/patches/2.http.parser.patch && 454 + patch -p0 < ../../3rdparty/patches/2.http.parser.patch &&
452 make package && 455 make package &&
453 cd .. && rm -rf hp && ln -sf http-parser-2.1 hp && 456 cd .. && rm -rf hp && ln -sf http-parser-2.1 hp &&
454 cd .. && rm -f ${SRS_OBJS}/_flag.st.hp.tmp 457 cd .. && rm -f ${SRS_OBJS}/_flag.st.hp.tmp
@@ -87,6 +87,13 @@ @@ -87,6 +87,13 @@
87 3C663F181AB0155100286D8B /* srs_play.c in Sources */ = {isa = PBXBuildFile; fileRef = 3C663F0B1AB0155100286D8B /* srs_play.c */; }; 87 3C663F181AB0155100286D8B /* srs_play.c in Sources */ = {isa = PBXBuildFile; fileRef = 3C663F0B1AB0155100286D8B /* srs_play.c */; };
88 3C663F191AB0155100286D8B /* srs_publish.c in Sources */ = {isa = PBXBuildFile; fileRef = 3C663F0C1AB0155100286D8B /* srs_publish.c */; }; 88 3C663F191AB0155100286D8B /* srs_publish.c in Sources */ = {isa = PBXBuildFile; fileRef = 3C663F0C1AB0155100286D8B /* srs_publish.c */; };
89 3C663F1A1AB0155100286D8B /* srs_rtmp_dump.c in Sources */ = {isa = PBXBuildFile; fileRef = 3C663F0D1AB0155100286D8B /* srs_rtmp_dump.c */; }; 89 3C663F1A1AB0155100286D8B /* srs_rtmp_dump.c in Sources */ = {isa = PBXBuildFile; fileRef = 3C663F0D1AB0155100286D8B /* srs_rtmp_dump.c */; };
  90 + 3C689F961AB6AAAC00C9CEEE /* event.c in Sources */ = {isa = PBXBuildFile; fileRef = 3C689F921AB6AAAC00C9CEEE /* event.c */; };
  91 + 3C689F971AB6AAAC00C9CEEE /* io.c in Sources */ = {isa = PBXBuildFile; fileRef = 3C689F931AB6AAAC00C9CEEE /* io.c */; };
  92 + 3C689F981AB6AAAC00C9CEEE /* key.c in Sources */ = {isa = PBXBuildFile; fileRef = 3C689F941AB6AAAC00C9CEEE /* key.c */; };
  93 + 3C689F9E1AB6AAC800C9CEEE /* md.S in Sources */ = {isa = PBXBuildFile; fileRef = 3C689F991AB6AAC800C9CEEE /* md.S */; };
  94 + 3C689F9F1AB6AAC800C9CEEE /* sched.c in Sources */ = {isa = PBXBuildFile; fileRef = 3C689F9B1AB6AAC800C9CEEE /* sched.c */; };
  95 + 3C689FA01AB6AAC800C9CEEE /* stk.c in Sources */ = {isa = PBXBuildFile; fileRef = 3C689F9C1AB6AAC800C9CEEE /* stk.c */; };
  96 + 3C689FA11AB6AAC800C9CEEE /* sync.c in Sources */ = {isa = PBXBuildFile; fileRef = 3C689F9D1AB6AAC800C9CEEE /* sync.c */; };
90 /* End PBXBuildFile section */ 97 /* End PBXBuildFile section */
91 98
92 /* Begin PBXCopyFilesBuildPhase section */ 99 /* Begin PBXCopyFilesBuildPhase section */
@@ -311,6 +318,16 @@ @@ -311,6 +318,16 @@
311 3C663F0B1AB0155100286D8B /* srs_play.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = srs_play.c; path = ../../../research/librtmp/srs_play.c; sourceTree = "<group>"; }; 318 3C663F0B1AB0155100286D8B /* srs_play.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = srs_play.c; path = ../../../research/librtmp/srs_play.c; sourceTree = "<group>"; };
312 3C663F0C1AB0155100286D8B /* srs_publish.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = srs_publish.c; path = ../../../research/librtmp/srs_publish.c; sourceTree = "<group>"; }; 319 3C663F0C1AB0155100286D8B /* srs_publish.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = srs_publish.c; path = ../../../research/librtmp/srs_publish.c; sourceTree = "<group>"; };
313 3C663F0D1AB0155100286D8B /* srs_rtmp_dump.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = srs_rtmp_dump.c; path = ../../../research/librtmp/srs_rtmp_dump.c; sourceTree = "<group>"; }; 320 3C663F0D1AB0155100286D8B /* srs_rtmp_dump.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = srs_rtmp_dump.c; path = ../../../research/librtmp/srs_rtmp_dump.c; sourceTree = "<group>"; };
  321 + 3C689F911AB6AAAC00C9CEEE /* common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = common.h; path = "../../objs/st-1.9/common.h"; sourceTree = "<group>"; };
  322 + 3C689F921AB6AAAC00C9CEEE /* event.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = event.c; path = "../../objs/st-1.9/event.c"; sourceTree = "<group>"; };
  323 + 3C689F931AB6AAAC00C9CEEE /* io.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = io.c; path = "../../objs/st-1.9/io.c"; sourceTree = "<group>"; };
  324 + 3C689F941AB6AAAC00C9CEEE /* key.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = key.c; path = "../../objs/st-1.9/key.c"; sourceTree = "<group>"; };
  325 + 3C689F951AB6AAAC00C9CEEE /* md.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = md.h; path = "../../objs/st-1.9/md.h"; sourceTree = "<group>"; };
  326 + 3C689F991AB6AAC800C9CEEE /* md.S */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.asm; name = md.S; path = "../../objs/st-1.9/md.S"; sourceTree = "<group>"; };
  327 + 3C689F9A1AB6AAC800C9CEEE /* public.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = public.h; path = "../../objs/st-1.9/public.h"; sourceTree = "<group>"; };
  328 + 3C689F9B1AB6AAC800C9CEEE /* sched.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = sched.c; path = "../../objs/st-1.9/sched.c"; sourceTree = "<group>"; };
  329 + 3C689F9C1AB6AAC800C9CEEE /* stk.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = stk.c; path = "../../objs/st-1.9/stk.c"; sourceTree = "<group>"; };
  330 + 3C689F9D1AB6AAC800C9CEEE /* sync.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = sync.c; path = "../../objs/st-1.9/sync.c"; sourceTree = "<group>"; };
314 /* End PBXFileReference section */ 331 /* End PBXFileReference section */
315 332
316 /* Begin PBXFrameworksBuildPhase section */ 333 /* Begin PBXFrameworksBuildPhase section */
@@ -331,6 +348,7 @@ @@ -331,6 +348,7 @@
331 3C1231DC1AAE64A400CE8F6C = { 348 3C1231DC1AAE64A400CE8F6C = {
332 isa = PBXGroup; 349 isa = PBXGroup;
333 children = ( 350 children = (
  351 + 3C689F901AB6AA9100C9CEEE /* st-1.9 */,
334 3C1EE6D21AB1366500576EE9 /* doc */, 352 3C1EE6D21AB1366500576EE9 /* doc */,
335 3C1231E61AAE64A400CE8F6C /* Products */, 353 3C1231E61AAE64A400CE8F6C /* Products */,
336 3C1232EE1AAEA71C00CE8F6C /* links */, 354 3C1232EE1AAEA71C00CE8F6C /* links */,
@@ -672,6 +690,23 @@ @@ -672,6 +690,23 @@
672 path = srs_xcode; 690 path = srs_xcode;
673 sourceTree = "<group>"; 691 sourceTree = "<group>";
674 }; 692 };
  693 + 3C689F901AB6AA9100C9CEEE /* st-1.9 */ = {
  694 + isa = PBXGroup;
  695 + children = (
  696 + 3C689F991AB6AAC800C9CEEE /* md.S */,
  697 + 3C689F9A1AB6AAC800C9CEEE /* public.h */,
  698 + 3C689F9B1AB6AAC800C9CEEE /* sched.c */,
  699 + 3C689F9C1AB6AAC800C9CEEE /* stk.c */,
  700 + 3C689F9D1AB6AAC800C9CEEE /* sync.c */,
  701 + 3C689F911AB6AAAC00C9CEEE /* common.h */,
  702 + 3C689F921AB6AAAC00C9CEEE /* event.c */,
  703 + 3C689F931AB6AAAC00C9CEEE /* io.c */,
  704 + 3C689F941AB6AAAC00C9CEEE /* key.c */,
  705 + 3C689F951AB6AAAC00C9CEEE /* md.h */,
  706 + );
  707 + name = "st-1.9";
  708 + sourceTree = "<group>";
  709 + };
675 /* End PBXGroup section */ 710 /* End PBXGroup section */
676 711
677 /* Begin PBXNativeTarget section */ 712 /* Begin PBXNativeTarget section */
@@ -730,6 +765,7 @@ @@ -730,6 +765,7 @@
730 files = ( 765 files = (
731 3C1232951AAE81D900CE8F6C /* srs_app_config.cpp in Sources */, 766 3C1232951AAE81D900CE8F6C /* srs_app_config.cpp in Sources */,
732 3C663F0F1AB0155100286D8B /* srs_aac_raw_publish.c in Sources */, 767 3C663F0F1AB0155100286D8B /* srs_aac_raw_publish.c in Sources */,
  768 + 3C689FA01AB6AAC800C9CEEE /* stk.c in Sources */,
733 3C1232961AAE81D900CE8F6C /* srs_app_conn.cpp in Sources */, 769 3C1232961AAE81D900CE8F6C /* srs_app_conn.cpp in Sources */,
734 3C12322A1AAE814D00CE8F6C /* srs_kernel_ts.cpp in Sources */, 770 3C12322A1AAE814D00CE8F6C /* srs_kernel_ts.cpp in Sources */,
735 3C12329E1AAE81D900CE8F6C /* srs_app_hls.cpp in Sources */, 771 3C12329E1AAE81D900CE8F6C /* srs_app_hls.cpp in Sources */,
@@ -737,6 +773,7 @@ @@ -737,6 +773,7 @@
737 3C663F131AB0155100286D8B /* srs_flv_injecter.c in Sources */, 773 3C663F131AB0155100286D8B /* srs_flv_injecter.c in Sources */,
738 3C1232971AAE81D900CE8F6C /* srs_app_dvr.cpp in Sources */, 774 3C1232971AAE81D900CE8F6C /* srs_app_dvr.cpp in Sources */,
739 3C1232271AAE814D00CE8F6C /* srs_kernel_log.cpp in Sources */, 775 3C1232271AAE814D00CE8F6C /* srs_kernel_log.cpp in Sources */,
  776 + 3C689F961AB6AAAC00C9CEEE /* event.c in Sources */,
740 3C1232A81AAE81D900CE8F6C /* srs_app_log.cpp in Sources */, 777 3C1232A81AAE81D900CE8F6C /* srs_app_log.cpp in Sources */,
741 3C1232A41AAE81D900CE8F6C /* srs_app_ingest.cpp in Sources */, 778 3C1232A41AAE81D900CE8F6C /* srs_app_ingest.cpp in Sources */,
742 3C1232B41AAE81D900CE8F6C /* srs_app_st.cpp in Sources */, 779 3C1232B41AAE81D900CE8F6C /* srs_app_st.cpp in Sources */,
@@ -764,6 +801,7 @@ @@ -764,6 +801,7 @@
764 3C1232491AAE81A400CE8F6C /* srs_rtmp_utility.cpp in Sources */, 801 3C1232491AAE81A400CE8F6C /* srs_rtmp_utility.cpp in Sources */,
765 3C663F191AB0155100286D8B /* srs_publish.c in Sources */, 802 3C663F191AB0155100286D8B /* srs_publish.c in Sources */,
766 3C1232A01AAE81D900CE8F6C /* srs_app_http_client.cpp in Sources */, 803 3C1232A01AAE81D900CE8F6C /* srs_app_http_client.cpp in Sources */,
  804 + 3C689F981AB6AAAC00C9CEEE /* key.c in Sources */,
767 3C12329B1AAE81D900CE8F6C /* srs_app_ffmpeg.cpp in Sources */, 805 3C12329B1AAE81D900CE8F6C /* srs_app_ffmpeg.cpp in Sources */,
768 3C1232421AAE81A400CE8F6C /* srs_rtmp_amf0.cpp in Sources */, 806 3C1232421AAE81A400CE8F6C /* srs_rtmp_amf0.cpp in Sources */,
769 3C1232AA1AAE81D900CE8F6C /* srs_app_pithy_print.cpp in Sources */, 807 3C1232AA1AAE81D900CE8F6C /* srs_app_pithy_print.cpp in Sources */,
@@ -774,12 +812,14 @@ @@ -774,12 +812,14 @@
774 3C1232A21AAE81D900CE8F6C /* srs_app_http_hooks.cpp in Sources */, 812 3C1232A21AAE81D900CE8F6C /* srs_app_http_hooks.cpp in Sources */,
775 3C663F121AB0155100286D8B /* srs_detect_rtmp.c in Sources */, 813 3C663F121AB0155100286D8B /* srs_detect_rtmp.c in Sources */,
776 3C1232B11AAE81D900CE8F6C /* srs_app_server.cpp in Sources */, 814 3C1232B11AAE81D900CE8F6C /* srs_app_server.cpp in Sources */,
  815 + 3C689F9F1AB6AAC800C9CEEE /* sched.c in Sources */,
777 3C1232B31AAE81D900CE8F6C /* srs_app_st_socket.cpp in Sources */, 816 3C1232B31AAE81D900CE8F6C /* srs_app_st_socket.cpp in Sources */,
778 3C1232061AAE812C00CE8F6C /* srs_main_server.cpp in Sources */, 817 3C1232061AAE812C00CE8F6C /* srs_main_server.cpp in Sources */,
779 3C1232281AAE814D00CE8F6C /* srs_kernel_mp3.cpp in Sources */, 818 3C1232281AAE814D00CE8F6C /* srs_kernel_mp3.cpp in Sources */,
780 3C1232B21AAE81D900CE8F6C /* srs_app_source.cpp in Sources */, 819 3C1232B21AAE81D900CE8F6C /* srs_app_source.cpp in Sources */,
781 3C1231F71AAE652D00CE8F6C /* srs_core_performance.cpp in Sources */, 820 3C1231F71AAE652D00CE8F6C /* srs_core_performance.cpp in Sources */,
782 3C1232981AAE81D900CE8F6C /* srs_app_edge.cpp in Sources */, 821 3C1232981AAE81D900CE8F6C /* srs_app_edge.cpp in Sources */,
  822 + 3C689F9E1AB6AAC800C9CEEE /* md.S in Sources */,
783 3C1232461AAE81A400CE8F6C /* srs_rtmp_msg_array.cpp in Sources */, 823 3C1232461AAE81A400CE8F6C /* srs_rtmp_msg_array.cpp in Sources */,
784 3C1232A71AAE81D900CE8F6C /* srs_app_listener.cpp in Sources */, 824 3C1232A71AAE81D900CE8F6C /* srs_app_listener.cpp in Sources */,
785 3C1232261AAE814D00CE8F6C /* srs_kernel_flv.cpp in Sources */, 825 3C1232261AAE814D00CE8F6C /* srs_kernel_flv.cpp in Sources */,
@@ -788,6 +828,7 @@ @@ -788,6 +828,7 @@
788 3C1232441AAE81A400CE8F6C /* srs_rtmp_handshake.cpp in Sources */, 828 3C1232441AAE81A400CE8F6C /* srs_rtmp_handshake.cpp in Sources */,
789 3C1232291AAE814D00CE8F6C /* srs_kernel_stream.cpp in Sources */, 829 3C1232291AAE814D00CE8F6C /* srs_kernel_stream.cpp in Sources */,
790 3C663F181AB0155100286D8B /* srs_play.c in Sources */, 830 3C663F181AB0155100286D8B /* srs_play.c in Sources */,
  831 + 3C689F971AB6AAAC00C9CEEE /* io.c in Sources */,
791 3C1232B61AAE81D900CE8F6C /* srs_app_thread.cpp in Sources */, 832 3C1232B61AAE81D900CE8F6C /* srs_app_thread.cpp in Sources */,
792 3C1232A91AAE81D900CE8F6C /* srs_app_mpegts_udp.cpp in Sources */, 833 3C1232A91AAE81D900CE8F6C /* srs_app_mpegts_udp.cpp in Sources */,
793 3C1232AE1AAE81D900CE8F6C /* srs_app_rtmp_conn.cpp in Sources */, 834 3C1232AE1AAE81D900CE8F6C /* srs_app_rtmp_conn.cpp in Sources */,
@@ -802,6 +843,7 @@ @@ -802,6 +843,7 @@
802 3C12329D1AAE81D900CE8F6C /* srs_app_heartbeat.cpp in Sources */, 843 3C12329D1AAE81D900CE8F6C /* srs_app_heartbeat.cpp in Sources */,
803 3C1232231AAE814D00CE8F6C /* srs_kernel_consts.cpp in Sources */, 844 3C1232231AAE814D00CE8F6C /* srs_kernel_consts.cpp in Sources */,
804 3C1232AF1AAE81D900CE8F6C /* srs_app_rtsp.cpp in Sources */, 845 3C1232AF1AAE81D900CE8F6C /* srs_app_rtsp.cpp in Sources */,
  846 + 3C689FA11AB6AAC800C9CEEE /* sync.c in Sources */,
805 3C1232A31AAE81D900CE8F6C /* srs_app_http.cpp in Sources */, 847 3C1232A31AAE81D900CE8F6C /* srs_app_http.cpp in Sources */,
806 3C12329A1AAE81D900CE8F6C /* srs_app_encoder.cpp in Sources */, 848 3C12329A1AAE81D900CE8F6C /* srs_app_encoder.cpp in Sources */,
807 ); 849 );
@@ -82,7 +82,7 @@ int SrsHttpHooks::on_connect(string url, int client_id, string ip, SrsRequest* r @@ -82,7 +82,7 @@ int SrsHttpHooks::on_connect(string url, int client_id, string ip, SrsRequest* r
82 return ret; 82 return ret;
83 } 83 }
84 84
85 -void SrsHttpHooks::on_close(string url, int client_id, string ip, SrsRequest* req) 85 +void SrsHttpHooks::on_close(string url, int client_id, string ip, SrsRequest* req, int64_t send_bytes, int64_t recv_bytes)
86 { 86 {
87 int ret = ERROR_SUCCESS; 87 int ret = ERROR_SUCCESS;
88 88
@@ -92,6 +92,8 @@ void SrsHttpHooks::on_close(string url, int client_id, string ip, SrsRequest* re @@ -92,6 +92,8 @@ void SrsHttpHooks::on_close(string url, int client_id, string ip, SrsRequest* re
92 << __SRS_JFIELD_ORG("client_id", client_id) << __SRS_JFIELD_CONT 92 << __SRS_JFIELD_ORG("client_id", client_id) << __SRS_JFIELD_CONT
93 << __SRS_JFIELD_STR("ip", ip) << __SRS_JFIELD_CONT 93 << __SRS_JFIELD_STR("ip", ip) << __SRS_JFIELD_CONT
94 << __SRS_JFIELD_STR("vhost", req->vhost) << __SRS_JFIELD_CONT 94 << __SRS_JFIELD_STR("vhost", req->vhost) << __SRS_JFIELD_CONT
  95 + << __SRS_JFIELD_ORG("send_bytes", send_bytes) << __SRS_JFIELD_CONT
  96 + << __SRS_JFIELD_ORG("recv_bytes", recv_bytes) << __SRS_JFIELD_CONT
95 << __SRS_JFIELD_STR("app", req->app) 97 << __SRS_JFIELD_STR("app", req->app)
96 << __SRS_JOBJECT_END; 98 << __SRS_JOBJECT_END;
97 99
@@ -66,7 +66,7 @@ public: @@ -66,7 +66,7 @@ public:
66 * @param url the api server url, to process the event. 66 * @param url the api server url, to process the event.
67 * ignore if empty. 67 * ignore if empty.
68 */ 68 */
69 - static void on_close(std::string url, int client_id, std::string ip, SrsRequest* req); 69 + static void on_close(std::string url, int client_id, std::string ip, SrsRequest* req, int64_t send_bytes, int64_t recv_bytes);
70 /** 70 /**
71 * on_publish hook, when client(encoder) start to publish stream 71 * on_publish hook, when client(encoder) start to publish stream
72 * @param client_id the id of client on server. 72 * @param client_id the id of client on server.
@@ -1294,7 +1294,7 @@ void SrsRtmpConn::http_hooks_on_close() @@ -1294,7 +1294,7 @@ void SrsRtmpConn::http_hooks_on_close()
1294 int connection_id = _srs_context->get_id(); 1294 int connection_id = _srs_context->get_id();
1295 for (int i = 0; i < (int)on_close->args.size(); i++) { 1295 for (int i = 0; i < (int)on_close->args.size(); i++) {
1296 std::string url = on_close->args.at(i); 1296 std::string url = on_close->args.at(i);
1297 - SrsHttpHooks::on_close(url, connection_id, ip, req); 1297 + SrsHttpHooks::on_close(url, connection_id, ip, req, kbps->get_send_bytes(), kbps->get_recv_bytes());
1298 } 1298 }
1299 } 1299 }
1300 #endif 1300 #endif
@@ -26,8 +26,9 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. @@ -26,8 +26,9 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
26 #include <srs_kernel_error.hpp> 26 #include <srs_kernel_error.hpp>
27 #include <srs_kernel_log.hpp> 27 #include <srs_kernel_log.hpp>
28 28
29 -#ifndef SRS_OSX 29 +#ifdef __linux__
30 #include <sys/epoll.h> 30 #include <sys/epoll.h>
  31 +
31 bool srs_st_epoll_is_supported(void) 32 bool srs_st_epoll_is_supported(void)
32 { 33 {
33 struct epoll_event ev; 34 struct epoll_event ev;
@@ -45,30 +46,31 @@ int srs_init_st() @@ -45,30 +46,31 @@ int srs_init_st()
45 { 46 {
46 int ret = ERROR_SUCCESS; 47 int ret = ERROR_SUCCESS;
47 48
48 -#ifndef SRS_OSX 49 +#ifdef __linux__
49 // check epoll, some old linux donot support epoll. 50 // check epoll, some old linux donot support epoll.
50 // @see https://github.com/winlinvip/simple-rtmp-server/issues/162 51 // @see https://github.com/winlinvip/simple-rtmp-server/issues/162
51 if (!srs_st_epoll_is_supported()) { 52 if (!srs_st_epoll_is_supported()) {
52 ret = ERROR_ST_SET_EPOLL; 53 ret = ERROR_ST_SET_EPOLL;
53 - srs_error("epoll required. ret=%d", ret); 54 + srs_error("epoll required on Linux. ret=%d", ret);
54 return ret; 55 return ret;
55 } 56 }
  57 +#endif
56 58
57 - // use linux epoll. 59 + // Select the best event system available on the OS. In Linux this is
  60 + // epoll(). On BSD it will be kqueue.
58 if (st_set_eventsys(ST_EVENTSYS_ALT) == -1) { 61 if (st_set_eventsys(ST_EVENTSYS_ALT) == -1) {
59 ret = ERROR_ST_SET_EPOLL; 62 ret = ERROR_ST_SET_EPOLL;
60 - srs_error("st_set_eventsys use linux epoll failed. ret=%d", ret); 63 + srs_error("st_set_eventsys use %s failed. ret=%d", st_get_eventsys_name(), ret);
61 return ret; 64 return ret;
62 } 65 }
63 - srs_verbose("st_set_eventsys use linux epoll success");  
64 -#endif 66 + srs_trace("st_set_eventsys to %s", st_get_eventsys_name());
65 67
66 if(st_init() != 0){ 68 if(st_init() != 0){
67 ret = ERROR_ST_INITIALIZE; 69 ret = ERROR_ST_INITIALIZE;
68 srs_error("st_init failed. ret=%d", ret); 70 srs_error("st_init failed. ret=%d", ret);
69 return ret; 71 return ret;
70 } 72 }
71 - srs_verbose("st_init success"); 73 + srs_trace("st_init success, use %s", st_get_eventsys_name());
72 74
73 return ret; 75 return ret;
74 } 76 }