mirror of
https://github.com/DreamSourceLab/DSView.git
synced 2025-01-13 13:32:53 +08:00
demo
This commit is contained in:
commit
751e80a424
@ -56,7 +56,7 @@
|
||||
<file>icons/light/maximize.svg</file>
|
||||
<file>icons/light/nav.svg</file>
|
||||
<file>icons/light/next.svg</file>
|
||||
<file>icons/light/oneloop.svg</file>
|
||||
<file>icons/light/once.svg</file>
|
||||
<file>icons/light/open.svg</file>
|
||||
<file>icons/light/params.svg</file>
|
||||
<file>icons/light/pre.svg</file>
|
||||
@ -89,7 +89,7 @@
|
||||
<file>icons/dark/maximize.svg</file>
|
||||
<file>icons/dark/nav.svg</file>
|
||||
<file>icons/dark/next.svg</file>
|
||||
<file>icons/dark/oneloop.svg</file>
|
||||
<file>icons/dark/once.svg</file>
|
||||
<file>icons/dark/open.svg</file>
|
||||
<file>icons/dark/params.svg</file>
|
||||
<file>icons/dark/pre.svg</file>
|
||||
@ -138,9 +138,11 @@
|
||||
<file>icons/dsl_logo.svg</file>
|
||||
<file>icons/dark/minimize.svg</file>
|
||||
<file>icons/logo.svg</file>
|
||||
<file>icons/light/update.svg</file>
|
||||
<file>icons/dark/update.svg</file>
|
||||
<file>icons/light/loop.svg</file>
|
||||
<file>icons/dark/loop.svg</file>
|
||||
<file>icons/light/log.svg</file>
|
||||
<file>icons/dark/log.svg</file>
|
||||
<file>icons/light/update.svg</file>
|
||||
<file>icons/dark/update.svg</file>
|
||||
</qresource>
|
||||
</RCC>
|
||||
|
51
DSView/icons/dark/loop.svg
Normal file
51
DSView/icons/dark/loop.svg
Normal file
@ -0,0 +1,51 @@
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<svg
|
||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||
xmlns:cc="http://creativecommons.org/ns#"
|
||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||
xmlns:svg="http://www.w3.org/2000/svg"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||
version="1.1"
|
||||
x="0px"
|
||||
y="0px"
|
||||
viewBox="0 0 512 512"
|
||||
enable-background="new 0 0 100 100"
|
||||
xml:space="preserve"
|
||||
id="svg10"
|
||||
sodipodi:docname="noun-infinity-328975.svg"
|
||||
width="512"
|
||||
height="512"
|
||||
inkscape:version="0.92.4 (5da689c313, 2019-01-14)"><metadata
|
||||
id="metadata16"><rdf:RDF><cc:Work
|
||||
rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
|
||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title></dc:title></cc:Work></rdf:RDF></metadata><defs
|
||||
id="defs14" /><sodipodi:namedview
|
||||
pagecolor="#ffffff"
|
||||
bordercolor="#666666"
|
||||
borderopacity="1"
|
||||
objecttolerance="10"
|
||||
gridtolerance="10"
|
||||
guidetolerance="10"
|
||||
inkscape:pageopacity="0"
|
||||
inkscape:pageshadow="2"
|
||||
inkscape:window-width="1435"
|
||||
inkscape:window-height="691"
|
||||
id="namedview12"
|
||||
showgrid="false"
|
||||
units="in"
|
||||
inkscape:zoom="0.472"
|
||||
inkscape:cx="335.03666"
|
||||
inkscape:cy="259.44081"
|
||||
inkscape:window-x="188"
|
||||
inkscape:window-y="1926"
|
||||
inkscape:window-maximized="0"
|
||||
inkscape:current-layer="svg10" /><g
|
||||
id="g4"
|
||||
transform="matrix(5.6976252,0,0,5.6976252,-28.881258,-28.881661)"
|
||||
style="fill:#d7d7d7;fill-opacity:1"><path
|
||||
d="m 50,55.6 c -6.965,6.966 -14.202,14.612 -25.265,14.612 -11.471,0 -19.666,-8.467 -19.666,-20.211 0,-10.789 8.741,-20.213 20.759,-20.213 10.107,0 17.616,8.058 24.172,14.612 6.965,-6.964 14.203,-14.612 25.266,-14.612 11.608,0 19.665,8.468 19.665,20.213 0,10.788 -8.741,20.211 -20.758,20.211 C 64.068,70.212 56.556,62.155 50,55.6 Z M 44.539,50.001 C 39.212,45.085 33.612,37.982 25.691,37.982 c -6.828,0 -12.017,5.6 -12.017,12.019 0,6.964 4.917,12.017 11.607,12.017 7.785,0 14.067,-6.692 19.258,-12.017 z m 41.791,0 c 0,-6.966 -4.917,-12.019 -11.61,-12.019 -7.784,0 -14.067,6.691 -19.256,12.019 5.325,4.916 10.925,12.017 18.846,12.017 6.828,0 12.02,-5.599 12.02,-12.017 z"
|
||||
id="path2"
|
||||
inkscape:connector-curvature="0"
|
||||
style="fill:#d7d7d7;fill-opacity:1" /></g></svg>
|
After Width: | Height: | Size: 2.4 KiB |
64
DSView/icons/dark/once.svg
Normal file
64
DSView/icons/dark/once.svg
Normal file
@ -0,0 +1,64 @@
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<svg
|
||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||
xmlns:cc="http://creativecommons.org/ns#"
|
||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||
xmlns:svg="http://www.w3.org/2000/svg"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||
viewBox="0 0 512 512"
|
||||
x="0px"
|
||||
y="0px"
|
||||
version="1.1"
|
||||
id="svg10"
|
||||
sodipodi:docname="noun-play-once-2135776.svg"
|
||||
width="512"
|
||||
height="512"
|
||||
style="fill:none"
|
||||
inkscape:version="0.92.4 (5da689c313, 2019-01-14)">
|
||||
<metadata
|
||||
id="metadata16">
|
||||
<rdf:RDF>
|
||||
<cc:Work
|
||||
rdf:about="">
|
||||
<dc:format>image/svg+xml</dc:format>
|
||||
<dc:type
|
||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||
<dc:title></dc:title>
|
||||
</cc:Work>
|
||||
</rdf:RDF>
|
||||
</metadata>
|
||||
<defs
|
||||
id="defs14" />
|
||||
<sodipodi:namedview
|
||||
pagecolor="#ffffff"
|
||||
bordercolor="#666666"
|
||||
borderopacity="1"
|
||||
objecttolerance="10"
|
||||
gridtolerance="10"
|
||||
guidetolerance="10"
|
||||
inkscape:pageopacity="0"
|
||||
inkscape:pageshadow="2"
|
||||
inkscape:window-width="1253"
|
||||
inkscape:window-height="742"
|
||||
id="namedview12"
|
||||
showgrid="false"
|
||||
inkscape:zoom="0.47"
|
||||
inkscape:cx="279.25117"
|
||||
inkscape:cy="249.23473"
|
||||
inkscape:window-x="56"
|
||||
inkscape:window-y="470"
|
||||
inkscape:window-maximized="0"
|
||||
inkscape:current-layer="svg10" />
|
||||
<path
|
||||
d="m 313.94964,315.81124 c -4.20535,4.3153 -6.54304,10.10979 -6.50547,16.13426 0.0376,6.02447 2.44625,11.79148 6.70704,16.0518 4.26033,4.26033 10.02643,6.67084 16.05091,6.70932 6.02447,0.0385 11.82126,-2.29965 16.13519,-6.50318 l 92.2705,-92.20165 -16.14803,-16.14342 -0.0916,-0.0916 -76.02169,-75.96203 c -4.31988,-4.17329 -10.10568,-6.48119 -16.11137,-6.42897 -6.00569,0.0458 -11.75072,2.45999 -15.99731,6.70795 -4.24659,4.24658 -6.65573,9.9916 -6.70796,15.99729 -0.0458,6.00568 2.25843,11.79147 6.42898,16.11136 l 36.9366,36.90906 H 22.905 c -6.07441,0 -11.90052,2.41418 -16.19613,6.70886 C 2.4119,244.10268 0,249.92695 0,256.00181 c 0,6.07486 2.41419,11.90096 6.70887,16.1961 4.29698,4.29698 10.12172,6.70886 16.19613,6.70886 h 327.99957 z"
|
||||
id="path2"
|
||||
inkscape:connector-curvature="0"
|
||||
style="fill:#d7d7d7;stroke-width:45.80999756;fill-opacity:1" />
|
||||
<path
|
||||
d="M 512,386.04703 V 125.95197 c 0,-6.07486 -2.41419,-11.90097 -6.70658,-16.19611 -4.29698,-4.29697 -10.12401,-6.70886 -16.19842,-6.70886 -6.0744,0 -11.90143,2.41418 -16.19383,6.70886 -4.29698,4.29698 -6.71117,10.12125 -6.71117,16.19611 v 260.09506 c 0,6.07486 2.41419,11.90096 6.71117,16.19611 4.2924,4.29696 10.11943,6.70886 16.19383,6.70886 6.07441,0 11.90144,-2.41419 16.19842,-6.70886 C 509.58581,397.94616 512,392.12189 512,386.04703 Z"
|
||||
id="path4"
|
||||
inkscape:connector-curvature="0"
|
||||
style="fill:#d7d7d7;stroke-width:45.80999756;fill-opacity:1" />
|
||||
</svg>
|
After Width: | Height: | Size: 2.9 KiB |
@ -1,4 +0,0 @@
|
||||
<?xml version="1.0"?>
|
||||
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" id="Capa_1" x="0px" y="0px" width="512px" height="512px" viewBox="0 0 487.881 487.881" style="enable-background:new 0 0 487.881 487.881;" xml:space="preserve" class=""><g><g>
|
||||
<path d="M487.881,264.183v8.434c0,69.352-56.425,125.77-125.77,125.77H125.77C56.424,398.386,0,341.968,0,272.616v-8.434 c0-69.346,56.424-125.764,125.77-125.764l13.914,0.502c0,0-23.029,15.817-13.914,48.584c-44.331,0-76.669,34.397-76.669,76.678 v8.428c0,42.28,34.398,76.675,76.669,76.675h236.342c42.279,0,76.675-34.395,76.675-76.675v-8.428 c0-42.28-34.396-76.678-76.675-76.678H249.505l0,0H219.81l17.328,43.87c0.612,1.545,0.115,3.313-1.218,4.318 c-1.33,1.002-3.166,0.996-4.483-0.021l-90.754-69.768c-0.907-0.701-1.445-1.785-1.439-2.935c0-1.15,0.532-2.234,1.439-2.935 l90.76-69.776c0.659-0.514,1.457-0.763,2.252-0.763c0.786,0,1.566,0.243,2.231,0.745c1.333,1.005,1.824,2.766,1.218,4.314 l-17.328,43.876h29.701l0,0h112.601C431.456,138.419,487.881,194.843,487.881,264.183z" data-original="#000000" class="active-path" data-old_color="#000000" fill="#D7D7D7"/>
|
||||
</g></g> </svg>
|
Before Width: | Height: | Size: 1.1 KiB |
51
DSView/icons/light/loop.svg
Normal file
51
DSView/icons/light/loop.svg
Normal file
@ -0,0 +1,51 @@
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<svg
|
||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||
xmlns:cc="http://creativecommons.org/ns#"
|
||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||
xmlns:svg="http://www.w3.org/2000/svg"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||
version="1.1"
|
||||
x="0px"
|
||||
y="0px"
|
||||
viewBox="0 0 512 512"
|
||||
enable-background="new 0 0 100 100"
|
||||
xml:space="preserve"
|
||||
id="svg10"
|
||||
sodipodi:docname="noun-infinity-328975.svg"
|
||||
width="512"
|
||||
height="512"
|
||||
inkscape:version="0.92.4 (5da689c313, 2019-01-14)"><metadata
|
||||
id="metadata16"><rdf:RDF><cc:Work
|
||||
rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
|
||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title></dc:title></cc:Work></rdf:RDF></metadata><defs
|
||||
id="defs14" /><sodipodi:namedview
|
||||
pagecolor="#ffffff"
|
||||
bordercolor="#666666"
|
||||
borderopacity="1"
|
||||
objecttolerance="10"
|
||||
gridtolerance="10"
|
||||
guidetolerance="10"
|
||||
inkscape:pageopacity="0"
|
||||
inkscape:pageshadow="2"
|
||||
inkscape:window-width="1435"
|
||||
inkscape:window-height="691"
|
||||
id="namedview12"
|
||||
showgrid="false"
|
||||
units="in"
|
||||
inkscape:zoom="0.472"
|
||||
inkscape:cx="335.03666"
|
||||
inkscape:cy="259.44081"
|
||||
inkscape:window-x="188"
|
||||
inkscape:window-y="1926"
|
||||
inkscape:window-maximized="0"
|
||||
inkscape:current-layer="svg10" /><g
|
||||
id="g4"
|
||||
transform="matrix(5.6976252,0,0,5.6976252,-28.881258,-28.881661)"
|
||||
style="fill:#2a2a2a;fill-opacity:1"><path
|
||||
d="m 50,55.6 c -6.965,6.966 -14.202,14.612 -25.265,14.612 -11.471,0 -19.666,-8.467 -19.666,-20.211 0,-10.789 8.741,-20.213 20.759,-20.213 10.107,0 17.616,8.058 24.172,14.612 6.965,-6.964 14.203,-14.612 25.266,-14.612 11.608,0 19.665,8.468 19.665,20.213 0,10.788 -8.741,20.211 -20.758,20.211 C 64.068,70.212 56.556,62.155 50,55.6 Z M 44.539,50.001 C 39.212,45.085 33.612,37.982 25.691,37.982 c -6.828,0 -12.017,5.6 -12.017,12.019 0,6.964 4.917,12.017 11.607,12.017 7.785,0 14.067,-6.692 19.258,-12.017 z m 41.791,0 c 0,-6.966 -4.917,-12.019 -11.61,-12.019 -7.784,0 -14.067,6.691 -19.256,12.019 5.325,4.916 10.925,12.017 18.846,12.017 6.828,0 12.02,-5.599 12.02,-12.017 z"
|
||||
id="path2"
|
||||
inkscape:connector-curvature="0"
|
||||
style="fill:#2a2a2a;fill-opacity:1" /></g></svg>
|
After Width: | Height: | Size: 2.4 KiB |
64
DSView/icons/light/once.svg
Normal file
64
DSView/icons/light/once.svg
Normal file
@ -0,0 +1,64 @@
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<svg
|
||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||
xmlns:cc="http://creativecommons.org/ns#"
|
||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||
xmlns:svg="http://www.w3.org/2000/svg"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||
viewBox="0 0 512 512"
|
||||
x="0px"
|
||||
y="0px"
|
||||
version="1.1"
|
||||
id="svg10"
|
||||
sodipodi:docname="noun-play-once-2135776.svg"
|
||||
width="512"
|
||||
height="512"
|
||||
style="fill:none"
|
||||
inkscape:version="0.92.4 (5da689c313, 2019-01-14)">
|
||||
<metadata
|
||||
id="metadata16">
|
||||
<rdf:RDF>
|
||||
<cc:Work
|
||||
rdf:about="">
|
||||
<dc:format>image/svg+xml</dc:format>
|
||||
<dc:type
|
||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||
<dc:title></dc:title>
|
||||
</cc:Work>
|
||||
</rdf:RDF>
|
||||
</metadata>
|
||||
<defs
|
||||
id="defs14" />
|
||||
<sodipodi:namedview
|
||||
pagecolor="#ffffff"
|
||||
bordercolor="#666666"
|
||||
borderopacity="1"
|
||||
objecttolerance="10"
|
||||
gridtolerance="10"
|
||||
guidetolerance="10"
|
||||
inkscape:pageopacity="0"
|
||||
inkscape:pageshadow="2"
|
||||
inkscape:window-width="1253"
|
||||
inkscape:window-height="742"
|
||||
id="namedview12"
|
||||
showgrid="false"
|
||||
inkscape:zoom="0.47"
|
||||
inkscape:cx="279.25117"
|
||||
inkscape:cy="249.23473"
|
||||
inkscape:window-x="56"
|
||||
inkscape:window-y="470"
|
||||
inkscape:window-maximized="0"
|
||||
inkscape:current-layer="svg10" />
|
||||
<path
|
||||
d="m 313.94964,315.81124 c -4.20535,4.3153 -6.54304,10.10979 -6.50547,16.13426 0.0376,6.02447 2.44625,11.79148 6.70704,16.0518 4.26033,4.26033 10.02643,6.67084 16.05091,6.70932 6.02447,0.0385 11.82126,-2.29965 16.13519,-6.50318 l 92.2705,-92.20165 -16.14803,-16.14342 -0.0916,-0.0916 -76.02169,-75.96203 c -4.31988,-4.17329 -10.10568,-6.48119 -16.11137,-6.42897 -6.00569,0.0458 -11.75072,2.45999 -15.99731,6.70795 -4.24659,4.24658 -6.65573,9.9916 -6.70796,15.99729 -0.0458,6.00568 2.25843,11.79147 6.42898,16.11136 l 36.9366,36.90906 H 22.905 c -6.07441,0 -11.90052,2.41418 -16.19613,6.70886 C 2.4119,244.10268 0,249.92695 0,256.00181 c 0,6.07486 2.41419,11.90096 6.70887,16.1961 4.29698,4.29698 10.12172,6.70886 16.19613,6.70886 h 327.99957 z"
|
||||
id="path2"
|
||||
inkscape:connector-curvature="0"
|
||||
style="fill:#2a2a2a;stroke-width:45.80999756;fill-opacity:1" />
|
||||
<path
|
||||
d="M 512,386.04703 V 125.95197 c 0,-6.07486 -2.41419,-11.90097 -6.70658,-16.19611 -4.29698,-4.29697 -10.12401,-6.70886 -16.19842,-6.70886 -6.0744,0 -11.90143,2.41418 -16.19383,6.70886 -4.29698,4.29698 -6.71117,10.12125 -6.71117,16.19611 v 260.09506 c 0,6.07486 2.41419,11.90096 6.71117,16.19611 4.2924,4.29696 10.11943,6.70886 16.19383,6.70886 6.07441,0 11.90144,-2.41419 16.19842,-6.70886 C 509.58581,397.94616 512,392.12189 512,386.04703 Z"
|
||||
id="path4"
|
||||
inkscape:connector-curvature="0"
|
||||
style="fill:#2a2a2a;stroke-width:45.80999756;fill-opacity:1" />
|
||||
</svg>
|
After Width: | Height: | Size: 2.9 KiB |
@ -1,4 +0,0 @@
|
||||
<?xml version="1.0"?>
|
||||
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" id="Capa_1" x="0px" y="0px" width="512px" height="512px" viewBox="0 0 487.881 487.881" style="enable-background:new 0 0 487.881 487.881;" xml:space="preserve" class=""><g><g>
|
||||
<path d="M487.881,264.183v8.434c0,69.352-56.425,125.77-125.77,125.77H125.77C56.424,398.386,0,341.968,0,272.616v-8.434 c0-69.346,56.424-125.764,125.77-125.764l13.914,0.502c0,0-23.029,15.817-13.914,48.584c-44.331,0-76.669,34.397-76.669,76.678 v8.428c0,42.28,34.398,76.675,76.669,76.675h236.342c42.279,0,76.675-34.395,76.675-76.675v-8.428 c0-42.28-34.396-76.678-76.675-76.678H249.505l0,0H219.81l17.328,43.87c0.612,1.545,0.115,3.313-1.218,4.318 c-1.33,1.002-3.166,0.996-4.483-0.021l-90.754-69.768c-0.907-0.701-1.445-1.785-1.439-2.935c0-1.15,0.532-2.234,1.439-2.935 l90.76-69.776c0.659-0.514,1.457-0.763,2.252-0.763c0.786,0,1.566,0.243,2.231,0.745c1.333,1.005,1.824,2.766,1.218,4.314 l-17.328,43.876h29.701l0,0h112.601C431.456,138.419,487.881,194.843,487.881,264.183z" data-original="#000000" class="active-path" data-old_color="#000000" fill="#2A2A2A"/>
|
||||
</g></g> </svg>
|
Before Width: | Height: | Size: 1.1 KiB |
@ -676,7 +676,10 @@ void DecoderStack::execute_decode_stack()
|
||||
// all decoderstatck execute in sequence
|
||||
srd_session_new(&session);
|
||||
|
||||
assert(session);
|
||||
if (session == NULL){
|
||||
dsv_err("Failed to call srd_session_new()");
|
||||
assert(false);
|
||||
}
|
||||
|
||||
// Get the intial sample count
|
||||
_sample_count = _snapshot->get_ring_sample_count();
|
||||
|
@ -39,9 +39,9 @@
|
||||
#include "../ui/langresource.h"
|
||||
#include "../view/view.h"
|
||||
|
||||
#define SINGLE_ACTION_ICON "/oneloop.svg"
|
||||
#define SINGLE_ACTION_ICON "/once.svg"
|
||||
#define REPEAT_ACTION_ICON "/repeat.svg"
|
||||
#define LOOP_ACTION_ICON "/update.svg"
|
||||
#define LOOP_ACTION_ICON "/loop.svg"
|
||||
|
||||
using std::map;
|
||||
using std::max;
|
||||
|
@ -22,6 +22,7 @@
|
||||
#include <glib.h>
|
||||
#include "config.h" /* Needed for HAVE_LIBUSB_1_0 and others. */
|
||||
#include "log.h"
|
||||
#include <assert.h>
|
||||
|
||||
#undef LOG_PREFIX
|
||||
#define LOG_PREFIX "backend: "
|
||||
@ -316,18 +317,13 @@ SR_PRIV int sr_init(struct sr_context **ctx)
|
||||
}
|
||||
|
||||
/* + 1 to handle when struct sr_context has no members. */
|
||||
context = g_try_malloc0(sizeof(struct sr_context) + 1);
|
||||
|
||||
context = malloc(sizeof(struct sr_context));
|
||||
if (!context) {
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
ret = SR_ERR_MALLOC;
|
||||
goto done;
|
||||
}
|
||||
|
||||
context->libusb_ctx = NULL;
|
||||
context->hotplug_handle = 0;
|
||||
context->hotplug_callback = NULL;
|
||||
context->hotplug_tv.tv_sec = 0;
|
||||
context->hotplug_tv.tv_usec = 0;
|
||||
memset(context, 0, sizeof(struct sr_context));
|
||||
|
||||
ret = libusb_init(&context->libusb_ctx);
|
||||
if (LIBUSB_SUCCESS != ret) {
|
||||
|
@ -23,6 +23,7 @@
|
||||
#include "config.h" /* Needed for HAVE_LIBUSB_1_0 and others. */
|
||||
#include "log.h"
|
||||
#include <string.h>
|
||||
#include <assert.h>
|
||||
|
||||
#undef LOG_PREFIX
|
||||
#define LOG_PREFIX "device: "
|
||||
@ -46,17 +47,12 @@ SR_PRIV struct sr_channel *sr_channel_new(uint16_t index, int type, gboolean ena
|
||||
{
|
||||
struct sr_channel *probe;
|
||||
|
||||
probe = g_try_malloc0(sizeof(struct sr_channel));
|
||||
|
||||
probe = malloc(sizeof(struct sr_channel));
|
||||
if (probe == NULL) {
|
||||
sr_err("Probe malloc failed.");
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
probe->trigger = NULL;
|
||||
probe->name = NULL;
|
||||
probe->map_unit = NULL;
|
||||
probe->vga_ptr = NULL;
|
||||
memset(probe, 0, sizeof(struct sr_channel));
|
||||
|
||||
probe->index = index;
|
||||
probe->type = type;
|
||||
@ -173,7 +169,7 @@ SR_PRIV int sr_dev_trigger_set(const struct sr_dev_inst *sdi, uint16_t probenum,
|
||||
probe = l->data;
|
||||
if (probe->index == probenum) {
|
||||
/* If the probe already has a trigger, kill it first. */
|
||||
g_safe_free(probe->trigger);
|
||||
safe_free(probe->trigger);
|
||||
probe->trigger = g_strdup(trigger);
|
||||
ret = SR_OK;
|
||||
break;
|
||||
@ -188,26 +184,15 @@ SR_PRIV struct sr_dev_inst *sr_dev_inst_new(int mode, int status,
|
||||
const char *vendor, const char *model, const char *version)
|
||||
{
|
||||
struct sr_dev_inst *sdi;
|
||||
|
||||
if (!(sdi = g_try_malloc(sizeof(struct sr_dev_inst)))) {
|
||||
sr_err("Device instance malloc failed.");
|
||||
if (!(sdi = malloc(sizeof(struct sr_dev_inst)))) {
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
sdi->driver = NULL;
|
||||
sdi->channels = NULL;
|
||||
sdi->conn = NULL;
|
||||
sdi->priv = NULL;
|
||||
sdi->vendor = NULL;
|
||||
sdi->version = NULL;
|
||||
sdi->path = NULL;
|
||||
|
||||
memset(sdi, 0, sizeof(struct sr_dev_inst));
|
||||
|
||||
sdi->mode = mode;
|
||||
sdi->name[0] = '\0';
|
||||
sdi->status = status;
|
||||
sdi->handle = (ds_device_handle)sdi;
|
||||
sdi->dev_type = DEV_TYPE_UNKOWN;
|
||||
sdi->actived_times = 0;
|
||||
|
||||
if (vendor != NULL){
|
||||
sdi->vendor = g_strdup(vendor);
|
||||
@ -231,9 +216,9 @@ SR_PRIV void sr_dev_probes_free(struct sr_dev_inst *sdi)
|
||||
|
||||
for (l = sdi->channels; l; l = l->next) {
|
||||
probe = l->data;
|
||||
g_safe_free(probe->name);
|
||||
g_safe_free(probe->trigger);
|
||||
g_safe_free(probe->vga_ptr);
|
||||
safe_free(probe->name);
|
||||
safe_free(probe->trigger);
|
||||
safe_free(probe->vga_ptr);
|
||||
g_free(probe);
|
||||
}
|
||||
g_safe_free_list(sdi->channels);
|
||||
@ -246,11 +231,11 @@ SR_PRIV void sr_dev_inst_free(struct sr_dev_inst *sdi)
|
||||
|
||||
sr_dev_probes_free(sdi);
|
||||
|
||||
g_safe_free(sdi->conn);
|
||||
g_safe_free(sdi->priv);
|
||||
g_safe_free(sdi->vendor);
|
||||
g_safe_free(sdi->version);
|
||||
g_safe_free(sdi->path);
|
||||
safe_free(sdi->conn);
|
||||
safe_free(sdi->priv);
|
||||
safe_free(sdi->vendor);
|
||||
safe_free(sdi->version);
|
||||
safe_free(sdi->path);
|
||||
|
||||
g_free(sdi);
|
||||
}
|
||||
@ -259,16 +244,14 @@ SR_PRIV void sr_dev_inst_free(struct sr_dev_inst *sdi)
|
||||
SR_PRIV struct sr_usb_dev_inst *sr_usb_dev_inst_new(uint8_t bus, uint8_t address)
|
||||
{
|
||||
struct sr_usb_dev_inst *udi;
|
||||
|
||||
if (!(udi = g_try_malloc(sizeof(struct sr_usb_dev_inst)))) {
|
||||
sr_err("USB device instance malloc failed.");
|
||||
if (!(udi = malloc(sizeof(struct sr_usb_dev_inst)))) {
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return NULL;
|
||||
}
|
||||
memset(udi, 0, sizeof(struct sr_usb_dev_inst));
|
||||
|
||||
udi->bus = bus;
|
||||
udi->address = address;
|
||||
udi->devhdl = NULL;
|
||||
udi->usb_dev = NULL;
|
||||
|
||||
return udi;
|
||||
}
|
||||
@ -307,10 +290,11 @@ SR_PRIV struct sr_serial_dev_inst *sr_serial_dev_inst_new(const char *port,
|
||||
return NULL;
|
||||
}
|
||||
|
||||
if (!(serial = g_try_malloc0(sizeof(struct sr_serial_dev_inst)))) {
|
||||
sr_err("Serial device instance malloc failed.");
|
||||
if (!(serial = malloc(sizeof(struct sr_serial_dev_inst)))) {
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return NULL;
|
||||
}
|
||||
memset(serial, 0, sizeof(struct sr_serial_dev_inst));
|
||||
|
||||
serial->port = g_strdup(port);
|
||||
if (serialcomm)
|
||||
|
@ -124,10 +124,11 @@ static struct DSL_context *DSCope_dev_new(const struct DSL_profile *prof)
|
||||
|
||||
assert(prof);
|
||||
|
||||
if (!(devc = g_try_malloc(sizeof(struct DSL_context)))) {
|
||||
if (!(devc = malloc(sizeof(struct DSL_context)))) {
|
||||
sr_err("Device context malloc failed.");
|
||||
return NULL;
|
||||
}
|
||||
memset(devc, 0, sizeof(struct DSL_context));
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE(channel_modes); i++){
|
||||
assert(channel_modes[i].id == i);
|
||||
@ -353,10 +354,11 @@ static GSList *scan(GSList *options)
|
||||
else {
|
||||
char *firmware;
|
||||
char *res_path = DS_RES_PATH;
|
||||
if (!(firmware = g_try_malloc(strlen(res_path)+strlen(prof->firmware) + 5))) {
|
||||
if (!(firmware = malloc(strlen(res_path)+strlen(prof->firmware) + 5))) {
|
||||
sr_err("Firmware path malloc error!");
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
|
||||
strcpy(firmware, res_path);
|
||||
strcat(firmware, "/");
|
||||
strcat(firmware, prof->firmware);
|
||||
@ -2088,13 +2090,18 @@ static int dev_acquisition_start(struct sr_dev_inst *sdi, void *cb_data)
|
||||
/* setup callback function for data transfer */
|
||||
lupfd = libusb_get_pollfds(drvc->sr_ctx->libusb_ctx);
|
||||
for (i = 0; lupfd[i]; i++);
|
||||
if (!(devc->usbfd = g_try_malloc(sizeof(struct libusb_pollfd) * (i + 1))))
|
||||
|
||||
if (!(devc->usbfd = malloc(sizeof(struct libusb_pollfd) * (i + 1)))){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SR_ERR;
|
||||
}
|
||||
|
||||
for (i = 0; lupfd[i]; i++) {
|
||||
sr_source_add(lupfd[i]->fd, lupfd[i]->events,
|
||||
dsl_get_timeout(sdi), receive_data, sdi);
|
||||
devc->usbfd[i] = lupfd[i]->fd;
|
||||
}
|
||||
|
||||
devc->usbfd[i] = -1;
|
||||
free(lupfd);
|
||||
|
||||
|
@ -109,9 +109,17 @@ SR_PRIV void dsl_probe_init(struct sr_dev_inst *sdi)
|
||||
probe->map_unit = probeMapUnits[0];
|
||||
probe->map_min = -(probe->vdiv * probe->vfactor * DS_CONF_DSO_VDIVS / 2000.0);
|
||||
probe->map_max = probe->vdiv * probe->vfactor * DS_CONF_DSO_VDIVS / 2000.0;
|
||||
|
||||
if (devc->profile->dev_caps.vdivs && probe->vga_ptr == NULL) {
|
||||
for (i = 0; devc->profile->dev_caps.vdivs[i]; i++);
|
||||
probe->vga_ptr = g_try_malloc((i+1)*sizeof(struct DSL_vga));
|
||||
|
||||
for (i = 0; devc->profile->dev_caps.vdivs[i]; i++){
|
||||
}
|
||||
|
||||
probe->vga_ptr = malloc((i+1)*sizeof(struct DSL_vga));
|
||||
if (probe->vga_ptr == NULL){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return;
|
||||
}
|
||||
|
||||
for (i = 0; devc->profile->dev_caps.vdivs[i]; i++) {
|
||||
(probe->vga_ptr + i)->id = devc->profile->dev_caps.vga_id;
|
||||
@ -1300,7 +1308,7 @@ SR_PRIV int dsl_fpga_config(struct libusb_device_handle *hdl, const char *filena
|
||||
|
||||
filesize = (uint64_t)f_stat.st_size;
|
||||
|
||||
if ((buf = g_try_malloc(filesize)) == NULL) {
|
||||
if ((buf = malloc(filesize)) == NULL) {
|
||||
sr_err("FPGA configure buf malloc failed.");
|
||||
fclose(fw);
|
||||
return SR_ERR;
|
||||
@ -1875,7 +1883,7 @@ SR_PRIV int dsl_dev_open(struct sr_dev_driver *di, struct sr_dev_inst *sdi, gboo
|
||||
if (!(*fpga_done)) {
|
||||
char *fpga_bit;
|
||||
char *res_path = DS_RES_PATH;
|
||||
if (!(fpga_bit = g_try_malloc(strlen(res_path)+strlen(devc->profile->fpga_bit33) + 5))) {
|
||||
if (!(fpga_bit = malloc(strlen(res_path)+strlen(devc->profile->fpga_bit33) + 5))) {
|
||||
sr_err("fpag_bit path malloc error!");
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
@ -2441,12 +2449,12 @@ SR_PRIV int dsl_start_transfers(const struct sr_dev_inst *sdi)
|
||||
size = get_buffer_size(sdi);
|
||||
|
||||
/* trigger packet transfer */
|
||||
if (!(trigger_pos = g_try_malloc0(dsl_header_size(devc)))) {
|
||||
if (!(trigger_pos = malloc(dsl_header_size(devc)))) {
|
||||
sr_err("%s: USB trigger_pos buffer malloc failed.", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
|
||||
devc->transfers = g_try_malloc0(sizeof(*devc->transfers) * (num_transfers + 1));
|
||||
devc->transfers = malloc(sizeof(*devc->transfers) * (num_transfers + 1));
|
||||
if (!devc->transfers) {
|
||||
sr_err("%s: USB transfer malloc failed.", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
@ -2470,7 +2478,7 @@ SR_PRIV int dsl_start_transfers(const struct sr_dev_inst *sdi)
|
||||
|
||||
/* data packet transfer */
|
||||
for (i = 1; i <= num_transfers; i++) {
|
||||
if (!(buf = g_try_malloc(size))) {
|
||||
if (!(buf = malloc(size))) {
|
||||
sr_err("%s: USB transfer buffer malloc failed.", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
|
@ -207,10 +207,11 @@ static struct DSL_context *DSLogic_dev_new(const struct DSL_profile *prof)
|
||||
|
||||
assert(prof);
|
||||
|
||||
if (!(devc = g_try_malloc(sizeof(struct DSL_context)))) {
|
||||
if (!(devc = malloc(sizeof(struct DSL_context)))) {
|
||||
sr_err("Device context malloc failed.");
|
||||
return NULL;
|
||||
}
|
||||
memset(devc, 0, sizeof(struct DSL_context));
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE(channel_modes); i++){
|
||||
if(channel_modes[i].id != i)
|
||||
@ -439,7 +440,7 @@ static GSList *scan(GSList *options)
|
||||
else {
|
||||
char *firmware;
|
||||
char *res_path = DS_RES_PATH;
|
||||
if (!(firmware = g_try_malloc(strlen(res_path)+strlen(prof->firmware) + 5))) {
|
||||
if (!(firmware = malloc(strlen(res_path)+strlen(prof->firmware) + 5))) {
|
||||
sr_err("Firmware path malloc error!");
|
||||
return NULL;
|
||||
}
|
||||
@ -1067,7 +1068,7 @@ static int config_set(int id, GVariant *data, struct sr_dev_inst *sdi,
|
||||
|
||||
char *fpga_bit;
|
||||
char *res_path = DS_RES_PATH;
|
||||
if (!(fpga_bit = g_try_malloc(strlen(res_path) + strlen(devc->profile->fpga_bit33) + 5))) {
|
||||
if (!(fpga_bit = malloc(strlen(res_path) + strlen(devc->profile->fpga_bit33) + 5))) {
|
||||
sr_err("fpag_bit path malloc error!");
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
@ -1485,8 +1486,12 @@ static int dev_acquisition_start(struct sr_dev_inst *sdi, void *cb_data)
|
||||
/* setup callback function for data transfer */
|
||||
lupfd = libusb_get_pollfds(drvc->sr_ctx->libusb_ctx);
|
||||
for (i = 0; lupfd[i]; i++);
|
||||
if (!(devc->usbfd = g_try_malloc(sizeof(struct libusb_pollfd) * (i + 1))))
|
||||
|
||||
if (!(devc->usbfd = malloc(sizeof(struct libusb_pollfd) * (i + 1)))){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SR_ERR;
|
||||
}
|
||||
|
||||
for (i = 0; lupfd[i]; i++) {
|
||||
sr_source_add(lupfd[i]->fd, lupfd[i]->events,
|
||||
dsl_get_timeout(sdi), receive_data, sdi);
|
||||
|
@ -40,6 +40,16 @@
|
||||
|
||||
extern char DS_USR_PATH[500];
|
||||
|
||||
static uint64_t samplerates_file[1];
|
||||
static uint64_t samplecounts_file[1];
|
||||
static GTimer *packet_interval = NULL;
|
||||
static GTimer *run_time = NULL;
|
||||
static int max_probe_num = 0;
|
||||
static int64_t analog_count = 0;
|
||||
static gboolean channel_mode_change = FALSE;
|
||||
static uint64_t packet_num;
|
||||
static void *logic_post_buf = NULL;
|
||||
|
||||
/* Message logging helpers with subsystem-specific prefix string. */
|
||||
|
||||
#undef LOG_PREFIX
|
||||
@ -157,7 +167,7 @@ static int vdev_init(struct sr_dev_inst *sdi)
|
||||
vdev->is_loop = FALSE;
|
||||
vdev->unit_bits = (sdi->mode == LOGIC) ? 1 : 8;
|
||||
|
||||
vdev->logic_buf = g_try_malloc0(LOGIC_BUF_LEN);
|
||||
vdev->logic_buf = malloc(LOGIC_BUF_LEN);
|
||||
if(vdev->logic_buf == NULL)
|
||||
{
|
||||
sr_err("%s: vdev->logic_buf malloc failed", __func__);
|
||||
@ -165,7 +175,7 @@ static int vdev_init(struct sr_dev_inst *sdi)
|
||||
}
|
||||
vdev->logic_buf_len = LOGIC_BUF_LEN;
|
||||
|
||||
vdev->dso_buf = g_try_malloc0(DSO_PACKET_LEN);
|
||||
vdev->dso_buf = malloc(DSO_PACKET_LEN);
|
||||
if(vdev->dso_buf == NULL)
|
||||
{
|
||||
sr_err("%s: vdev->dso_buf malloc failed", __func__);
|
||||
@ -323,18 +333,15 @@ static void logic_adjust_samplerate(struct session_vdev * vdev)
|
||||
|
||||
static int init_analog_random_data(struct session_vdev * vdev)
|
||||
{
|
||||
if(vdev->analog_buf != NULL)
|
||||
{
|
||||
g_safe_free(vdev->analog_buf);
|
||||
vdev->analog_buf = NULL;
|
||||
}
|
||||
safe_free(vdev->analog_buf);
|
||||
|
||||
vdev->analog_buf = g_try_malloc0(DSO_BUF_LEN);
|
||||
vdev->analog_buf = malloc(DSO_BUF_LEN);
|
||||
if (vdev->analog_buf == NULL)
|
||||
{
|
||||
sr_err("%s: vdev->analog_buf malloc failed", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
|
||||
for(int i = 0;i < DSO_BUF_LEN ;i++)
|
||||
{
|
||||
if(i % 2 == 0)
|
||||
@ -342,6 +349,7 @@ static int init_analog_random_data(struct session_vdev * vdev)
|
||||
else
|
||||
*(uint8_t*)(vdev->analog_buf + i) = *(uint8_t*)(vdev->analog_buf + i -1);
|
||||
}
|
||||
|
||||
vdev->analog_buf_len = DSO_BUF_LEN;
|
||||
return SR_OK;
|
||||
}
|
||||
@ -480,7 +488,7 @@ static int reset_dsl_path(struct sr_dev_inst *sdi, uint8_t pattern_mode)
|
||||
{
|
||||
struct demo_mode_pattern *info = NULL;
|
||||
if(sdi->path != NULL)
|
||||
g_safe_free(sdi->path);
|
||||
safe_free(sdi->path);
|
||||
|
||||
char file_path[500];
|
||||
|
||||
@ -526,9 +534,12 @@ static void adjust_samplerate(struct sr_dev_inst *sdi)
|
||||
return;
|
||||
|
||||
vdev->samplerates_max_index = ARRAY_SIZE(samplerates) - 1;
|
||||
while (samplerates[vdev->samplerates_max_index] >
|
||||
channel_modes[cur_mode].max_samplerate)
|
||||
|
||||
while (samplerates[vdev->samplerates_max_index] >
|
||||
channel_modes[cur_mode].max_samplerate)
|
||||
{
|
||||
vdev->samplerates_max_index--;
|
||||
}
|
||||
|
||||
vdev->samplerates_min_index = 0;
|
||||
while (samplerates[vdev->samplerates_min_index] <
|
||||
@ -555,8 +566,8 @@ static int init_random_data(struct session_vdev * vdev,struct sr_dev_inst *sdi)
|
||||
memset(vdev->logic_buf,0,LOGIC_BUF_LEN);
|
||||
|
||||
srand((unsigned)time(NULL));
|
||||
for(int i = 0 ;i < vdev->enabled_probes;i++)
|
||||
{
|
||||
|
||||
for(int i = 0 ;i < vdev->enabled_probes;i++){
|
||||
probe_count[i] = rand()%SR_KB(1);
|
||||
}
|
||||
|
||||
@ -568,6 +579,7 @@ static int init_random_data(struct session_vdev * vdev,struct sr_dev_inst *sdi)
|
||||
if(cur_probe >vdev->enabled_probes-1)
|
||||
cur_probe = 0;
|
||||
}
|
||||
|
||||
if(probe_count[cur_probe]> 0)
|
||||
{
|
||||
memset(vdev->logic_buf+i,probe_status[cur_probe],1);
|
||||
@ -610,22 +622,24 @@ static GSList *hw_scan(GSList *options)
|
||||
|
||||
sr_info("%s", "Scan demo device.");
|
||||
|
||||
vdev = g_try_malloc0(sizeof(struct session_vdev));
|
||||
vdev = malloc(sizeof(struct session_vdev));
|
||||
if (vdev == NULL)
|
||||
{
|
||||
sr_err("%s: sdi->priv malloc failed", __func__);
|
||||
return devices;
|
||||
}
|
||||
memset(vdev, 0, sizeof(struct session_vdev));
|
||||
|
||||
sdi = sr_dev_inst_new(LOGIC, SR_ST_INACTIVE,
|
||||
supported_Demo[0].vendor,
|
||||
supported_Demo[0].model,
|
||||
supported_Demo[0].model_version);
|
||||
if (!sdi) {
|
||||
g_safe_free(vdev);
|
||||
safe_free(vdev);
|
||||
sr_err("Device instance creation failed.");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
sdi->priv = vdev;
|
||||
sdi->driver = di;
|
||||
sdi->dev_type = DEV_TYPE_DEMO;
|
||||
@ -696,11 +710,11 @@ static int hw_dev_close(struct sr_dev_inst *sdi)
|
||||
if (vdev->packet_buffer != NULL){
|
||||
pack_buf = vdev->packet_buffer;
|
||||
|
||||
g_safe_free(pack_buf->post_buf);
|
||||
safe_free(pack_buf->post_buf);
|
||||
|
||||
for (i = 0; i < SESSION_MAX_CHANNEL_COUNT; i++){
|
||||
if (pack_buf->block_bufs[i] != NULL){
|
||||
g_safe_free(pack_buf->block_bufs[i]);
|
||||
safe_free(pack_buf->block_bufs[i]);
|
||||
pack_buf->block_bufs[i] = NULL;
|
||||
}
|
||||
else{
|
||||
@ -709,12 +723,12 @@ static int hw_dev_close(struct sr_dev_inst *sdi)
|
||||
}
|
||||
}
|
||||
|
||||
g_safe_free(vdev->packet_buffer);
|
||||
g_safe_free(vdev->logic_buf);
|
||||
g_safe_free(vdev->analog_buf);
|
||||
g_safe_free(sdi->path);
|
||||
g_safe_free(packet_interval);
|
||||
g_safe_free(run_time);
|
||||
safe_free(vdev->packet_buffer);
|
||||
safe_free(vdev->logic_buf);
|
||||
safe_free(vdev->analog_buf);
|
||||
safe_free(sdi->path);
|
||||
safe_free(packet_interval);
|
||||
safe_free(run_time);
|
||||
|
||||
sdi->status = SR_ST_INACTIVE;
|
||||
return SR_OK;
|
||||
@ -1269,7 +1283,7 @@ static int hw_dev_acquisition_start(struct sr_dev_inst *sdi,
|
||||
{
|
||||
if(ideal_len>=vdev->packet_len)
|
||||
{
|
||||
sr_info("len:%d",ideal_len);
|
||||
//sr_info("len:%d",ideal_len);
|
||||
vdev->packet_len = ideal_len;
|
||||
break;
|
||||
}
|
||||
@ -1288,9 +1302,9 @@ static int hw_dev_acquisition_start(struct sr_dev_inst *sdi,
|
||||
if(vdev->sample_generator == PATTERN_RANDOM)
|
||||
{
|
||||
vdev->logci_cur_packet_num = 1;
|
||||
if(logic_post_buf == NULL)
|
||||
g_safe_free(logic_post_buf);
|
||||
logic_post_buf = g_try_malloc0(vdev->enabled_probes * vdev->packet_len);
|
||||
safe_free(logic_post_buf);
|
||||
|
||||
logic_post_buf = malloc(vdev->enabled_probes * vdev->packet_len);
|
||||
if(logic_post_buf == NULL)
|
||||
{
|
||||
sr_err("%s: logic_post_buf malloc error", __func__);
|
||||
@ -1563,14 +1577,16 @@ static int receive_data_logic_decoder(int fd, int revents, const struct sr_dev_i
|
||||
g_timer_start(packet_interval);
|
||||
|
||||
// Make buffer
|
||||
if (vdev->packet_buffer == NULL){
|
||||
if (vdev->packet_buffer == NULL)
|
||||
{
|
||||
vdev->cur_block = 0;
|
||||
|
||||
vdev->packet_buffer = g_try_malloc0(sizeof(struct session_packet_buffer));
|
||||
vdev->packet_buffer = malloc(sizeof(struct session_packet_buffer));
|
||||
if (vdev->packet_buffer == NULL){
|
||||
sr_err("%s: vdev->packet_buffer malloc failed", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
memset(vdev->packet_buffer, 0, sizeof(struct session_packet_buffer));
|
||||
|
||||
for (ch_index = 0; ch_index <= chan_num; ch_index++){
|
||||
vdev->packet_buffer->block_bufs[ch_index] = NULL;
|
||||
@ -1579,7 +1595,7 @@ static int receive_data_logic_decoder(int fd, int revents, const struct sr_dev_i
|
||||
|
||||
vdev->packet_buffer->post_buf_len = chan_num * vdev->packet_len;
|
||||
|
||||
vdev->packet_buffer->post_buf = g_try_malloc0(vdev->packet_buffer->post_buf_len + 1);
|
||||
vdev->packet_buffer->post_buf = malloc(vdev->packet_buffer->post_buf_len + 1);
|
||||
if (vdev->packet_buffer->post_buf == NULL){
|
||||
sr_err("%s: vdev->packet_buffer->post_buf malloc failed", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
@ -1601,7 +1617,7 @@ static int receive_data_logic_decoder(int fd, int revents, const struct sr_dev_i
|
||||
{
|
||||
if(pack_buffer->block_bufs[ch_index] != NULL)
|
||||
{
|
||||
g_safe_free(pack_buffer->block_bufs[ch_index]);
|
||||
safe_free(pack_buffer->block_bufs[ch_index]);
|
||||
}
|
||||
pack_buffer->block_bufs[ch_index] = NULL;
|
||||
pack_buffer->block_read_positions[ch_index] = 0;
|
||||
@ -1615,12 +1631,9 @@ static int receive_data_logic_decoder(int fd, int revents, const struct sr_dev_i
|
||||
if(pack_buffer->post_buf_len != chan_num * vdev->packet_len)
|
||||
{
|
||||
pack_buffer->post_buf_len = chan_num * vdev->packet_len;
|
||||
if(pack_buffer->post_buf != NULL)
|
||||
{
|
||||
g_safe_free(pack_buffer->post_buf);
|
||||
}
|
||||
safe_free(pack_buffer->post_buf);
|
||||
|
||||
pack_buffer->post_buf = g_try_malloc0(pack_buffer->post_buf_len);
|
||||
pack_buffer->post_buf = malloc(pack_buffer->post_buf_len);
|
||||
if (pack_buffer->post_buf == NULL)
|
||||
{
|
||||
sr_err("%s: pack_buffer->post_buf malloc failed", __func__);
|
||||
@ -1683,11 +1696,11 @@ static int receive_data_logic_decoder(int fd, int revents, const struct sr_dev_i
|
||||
for (malloc_chan_index = 0; malloc_chan_index < chan_num; malloc_chan_index++){
|
||||
// Release the old buffer.
|
||||
if (pack_buffer->block_bufs[malloc_chan_index] != NULL){
|
||||
g_safe_free(pack_buffer->block_bufs[malloc_chan_index]);
|
||||
safe_free(pack_buffer->block_bufs[malloc_chan_index]);
|
||||
pack_buffer->block_bufs[malloc_chan_index] = NULL;
|
||||
}
|
||||
|
||||
pack_buffer->block_bufs[malloc_chan_index] = g_try_malloc0(pack_buffer->block_data_len + 1);
|
||||
pack_buffer->block_bufs[malloc_chan_index] = malloc(pack_buffer->block_data_len + 1);
|
||||
if (pack_buffer->block_bufs[malloc_chan_index] == NULL){
|
||||
sr_err("%s: block buffer malloc failed", __func__);
|
||||
send_error_packet(sdi, vdev, &packet);
|
||||
@ -1855,14 +1868,16 @@ static int receive_data_dso(int fd, int revents, const struct sr_dev_inst *sdi)
|
||||
}
|
||||
|
||||
// Make buffer
|
||||
if (vdev->packet_buffer == NULL){
|
||||
if (vdev->packet_buffer == NULL)
|
||||
{
|
||||
vdev->cur_block = 0;
|
||||
|
||||
vdev->packet_buffer = g_try_malloc0(sizeof(struct session_packet_buffer));
|
||||
vdev->packet_buffer = malloc(sizeof(struct session_packet_buffer));
|
||||
if (vdev->packet_buffer == NULL){
|
||||
sr_err("%s: vdev->packet_buffer malloc failed", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
memset(vdev->packet_buffer, 0, sizeof(struct session_packet_buffer));
|
||||
|
||||
for (ch_index = 0; ch_index <= chan_num; ch_index++){
|
||||
vdev->packet_buffer->block_bufs[ch_index] = NULL;
|
||||
@ -1871,7 +1886,7 @@ static int receive_data_dso(int fd, int revents, const struct sr_dev_inst *sdi)
|
||||
|
||||
vdev->packet_buffer->post_buf_len = chan_num * 10000;
|
||||
|
||||
vdev->packet_buffer->post_buf = g_try_malloc0(vdev->packet_buffer->post_buf_len);
|
||||
vdev->packet_buffer->post_buf = malloc(vdev->packet_buffer->post_buf_len);
|
||||
if (vdev->packet_buffer->post_buf == NULL){
|
||||
sr_err("%s: vdev->packet_buffer->post_buf malloc failed", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
@ -1883,15 +1898,15 @@ static int receive_data_dso(int fd, int revents, const struct sr_dev_inst *sdi)
|
||||
pack_buffer->block_data_len = 0;
|
||||
pack_buffer->block_chan_read_pos = 0;
|
||||
}
|
||||
|
||||
pack_buffer = vdev->packet_buffer;
|
||||
|
||||
if(pack_buffer->post_buf_len != chan_num * 10000)
|
||||
{
|
||||
vdev->packet_buffer->post_buf_len = chan_num * 10000;
|
||||
if(pack_buffer->post_buf != NULL)
|
||||
{
|
||||
g_safe_free(pack_buffer->post_buf);
|
||||
}
|
||||
pack_buffer->post_buf = g_try_malloc0(pack_buffer->post_buf_len);
|
||||
safe_free(pack_buffer->post_buf);
|
||||
|
||||
pack_buffer->post_buf = malloc(pack_buffer->post_buf_len);
|
||||
if (pack_buffer->post_buf == NULL)
|
||||
{
|
||||
sr_err("%s: pack_buffer->post_buf malloc failed", __func__);
|
||||
@ -1907,7 +1922,7 @@ static int receive_data_dso(int fd, int revents, const struct sr_dev_inst *sdi)
|
||||
{
|
||||
if(pack_buffer->block_bufs[ch_index] != NULL)
|
||||
{
|
||||
g_safe_free(pack_buffer->block_bufs[ch_index]);
|
||||
safe_free(pack_buffer->block_bufs[ch_index]);
|
||||
}
|
||||
pack_buffer->block_bufs[ch_index] = NULL;
|
||||
pack_buffer->block_read_positions[ch_index] = 0;
|
||||
@ -1991,11 +2006,11 @@ static int receive_data_dso(int fd, int revents, const struct sr_dev_inst *sdi)
|
||||
for (malloc_chan_index = 0; malloc_chan_index < chan_num; malloc_chan_index++){
|
||||
// Release the old buffer.
|
||||
if (pack_buffer->block_bufs[malloc_chan_index] != NULL){
|
||||
g_safe_free(pack_buffer->block_bufs[malloc_chan_index]);
|
||||
safe_free(pack_buffer->block_bufs[malloc_chan_index]);
|
||||
pack_buffer->block_bufs[malloc_chan_index] = NULL;
|
||||
}
|
||||
|
||||
pack_buffer->block_bufs[malloc_chan_index] = g_try_malloc0(pack_buffer->block_data_len + 1);
|
||||
pack_buffer->block_bufs[malloc_chan_index] = malloc(pack_buffer->block_data_len + 1);
|
||||
if (pack_buffer->block_bufs[malloc_chan_index] == NULL){
|
||||
sr_err("%s: block buffer malloc failed", __func__);
|
||||
send_error_packet(sdi, vdev, &packet);
|
||||
@ -2142,11 +2157,6 @@ static int receive_data_dso(int fd, int revents, const struct sr_dev_inst *sdi)
|
||||
}
|
||||
}
|
||||
|
||||
for(int i = 0 ; i < DSO_PACKET_LEN ;i+=2)
|
||||
{
|
||||
// sr_info("val:%d",*(uint8_t*)(vdev->packet_buffer->post_buf+i));
|
||||
}
|
||||
|
||||
vdev->offset_change = FALSE;
|
||||
vdev->timebase_change = FALSE;
|
||||
vdev->vdiv_change = FALSE;
|
||||
@ -2270,7 +2280,7 @@ static int receive_data_analog(int fd, int revents, const struct sr_dev_inst *sd
|
||||
{
|
||||
vdev->analog_buf_len = 0;
|
||||
|
||||
void* analog_data = g_try_malloc0(ANALOG_DATA_LEN_PER_CYCLE);
|
||||
void* analog_data = malloc(ANALOG_DATA_LEN_PER_CYCLE);
|
||||
if(analog_data == NULL)
|
||||
{
|
||||
sr_err("%s:analog_data malloc failed",__func__);
|
||||
@ -2307,17 +2317,15 @@ static int receive_data_analog(int fd, int revents, const struct sr_dev_inst *sd
|
||||
total_buf_len = total_buf_len / ANALOG_DATA_LEN_PER_CYCLE * ANALOG_DATA_LEN_PER_CYCLE;
|
||||
}
|
||||
|
||||
if(vdev->analog_buf != NULL)
|
||||
{
|
||||
g_safe_free(vdev->analog_buf);
|
||||
vdev->analog_buf = NULL;
|
||||
}
|
||||
vdev->analog_buf = (g_try_malloc0(total_buf_len));
|
||||
|
||||
safe_free(vdev->analog_buf);
|
||||
vdev->analog_buf = malloc(total_buf_len);
|
||||
if (vdev->analog_buf == NULL)
|
||||
{
|
||||
sr_err("%s: vdev->analog_buf malloc failed", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
|
||||
vdev->analog_buf_len = total_buf_len;
|
||||
uint64_t per_block_after_expend = total_buf_len / ANALOG_DATA_LEN_PER_CYCLE;
|
||||
|
||||
@ -2329,6 +2337,7 @@ static int receive_data_analog(int fd, int revents, const struct sr_dev_inst *sd
|
||||
uint8_t val = 0;
|
||||
uint16_t tem;
|
||||
uint64_t cur_l = 0;
|
||||
|
||||
for(int i = 0 ; i < ANALOG_DATA_LEN_PER_CYCLE;i++)
|
||||
{
|
||||
if(i % 2 == 0)
|
||||
@ -2371,17 +2380,18 @@ static int receive_data_analog(int fd, int revents, const struct sr_dev_inst *sd
|
||||
memset(vdev->analog_buf + cur_l,temp_value,1);
|
||||
}
|
||||
}
|
||||
g_safe_free(analog_data);
|
||||
safe_free(analog_data);
|
||||
}
|
||||
vdev->load_data = FALSE;
|
||||
}
|
||||
|
||||
void* buf = g_try_malloc0(vdev->packet_len);
|
||||
void* buf = malloc(vdev->packet_len);
|
||||
if(buf == NULL)
|
||||
{
|
||||
sr_err("%s: buf malloc failed", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
|
||||
if(vdev->analog_read_pos + vdev->packet_len >= vdev->analog_buf_len - 1 )
|
||||
{
|
||||
uint64_t back_len = vdev->analog_buf_len - vdev->analog_read_pos;
|
||||
@ -2417,7 +2427,7 @@ static int receive_data_analog(int fd, int revents, const struct sr_dev_inst *sd
|
||||
|
||||
delay_time(vdev);
|
||||
ds_data_forward(sdi, &packet);
|
||||
g_safe_free(buf);
|
||||
safe_free(buf);
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
@ -2509,7 +2519,7 @@ static int load_virtual_device_session(struct sr_dev_inst *sdi)
|
||||
return SR_ERR;
|
||||
}
|
||||
|
||||
if (!(metafile = g_try_malloc(fileInfo.uncompressed_size)))
|
||||
if (!(metafile = malloc(fileInfo.uncompressed_size)))
|
||||
{
|
||||
sr_err("%s: metafile malloc failed", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
@ -2616,7 +2626,7 @@ static int load_virtual_device_session(struct sr_dev_inst *sdi)
|
||||
|
||||
g_strfreev(sections);
|
||||
g_key_file_free(kf);
|
||||
g_safe_free(metafile);
|
||||
safe_free(metafile);
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -2802,7 +2812,7 @@ int dso_wavelength_updata(struct session_vdev *vdev)
|
||||
memcpy(pack_buffer->post_buf+i*bit,tmp_buf,bit);
|
||||
}
|
||||
|
||||
g_safe_free(tmp_buf);
|
||||
safe_free(tmp_buf);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -150,19 +150,6 @@ enum DEMO_LOGIC_CHANNEL_INDEX {
|
||||
LOGIC1000x3 = 3,
|
||||
};
|
||||
|
||||
static uint64_t samplerates_file[1];
|
||||
static uint64_t samplecounts_file[1];
|
||||
|
||||
static GTimer *packet_interval = NULL;
|
||||
static GTimer *run_time = NULL;
|
||||
|
||||
static int max_probe_num = 0;
|
||||
|
||||
static int64_t analog_count = 0;
|
||||
static gboolean channel_mode_change = FALSE;
|
||||
static uint64_t packet_num;
|
||||
static void *logic_post_buf = NULL;
|
||||
|
||||
|
||||
struct session_packet_buffer;
|
||||
|
||||
|
@ -179,8 +179,11 @@ SR_PRIV struct sr_config *sr_config_new(int key, GVariant *data)
|
||||
struct sr_config *src;
|
||||
assert(data);
|
||||
|
||||
if (!(src = g_try_malloc(sizeof(struct sr_config))))
|
||||
if (!(src = malloc(sizeof(struct sr_config)))){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return NULL;
|
||||
}
|
||||
//not need init.
|
||||
|
||||
src->key = key;
|
||||
src->data = g_variant_ref_sink(data);
|
||||
|
@ -56,7 +56,7 @@ static int init(struct sr_input *in, const char *filename)
|
||||
|
||||
(void)filename;
|
||||
|
||||
if (!(ctx = g_try_malloc0(sizeof(*ctx)))) {
|
||||
if (!(ctx = malloc(sizeof(struct context)))) {
|
||||
sr_err("Input format context malloc failed.");
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
|
@ -271,11 +271,17 @@ static gboolean parse_header(FILE *file, struct context *ctx)
|
||||
else
|
||||
{
|
||||
sr_info("Probe %d is '%s' identified by '%s'.", ctx->probecount, parts[3], parts[2]);
|
||||
probe = g_malloc(sizeof(struct probe));
|
||||
probe->identifier = g_strdup(parts[2]);
|
||||
probe->name = g_strdup(parts[3]);
|
||||
ctx->probes = g_slist_append(ctx->probes, probe);
|
||||
ctx->probecount++;
|
||||
probe = malloc(sizeof(struct probe));
|
||||
|
||||
if (probe != NULL){
|
||||
probe->identifier = g_strdup(parts[2]);
|
||||
probe->name = g_strdup(parts[3]);
|
||||
ctx->probes = g_slist_append(ctx->probes, probe);
|
||||
ctx->probecount++;
|
||||
}
|
||||
else{
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
}
|
||||
}
|
||||
|
||||
g_strfreev(parts);
|
||||
@ -324,7 +330,7 @@ static int init(struct sr_input *in, const char *filename)
|
||||
|
||||
(void)filename;
|
||||
|
||||
if (!(ctx = g_try_malloc0(sizeof(*ctx)))) {
|
||||
if (!(ctx = malloc(sizeof(struct context)))) {
|
||||
sr_err("Input format context malloc failed.");
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
|
@ -95,8 +95,10 @@ static int init(struct sr_input *in, const char *filename)
|
||||
if (get_wav_header(filename, buf) != SR_OK)
|
||||
return SR_ERR;
|
||||
|
||||
if (!(ctx = g_try_malloc0(sizeof(struct context))))
|
||||
if (!(ctx = malloc(sizeof(struct context)))){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
|
||||
/* Create a virtual device. */
|
||||
in->sdi = sr_dev_inst_new(LOGIC, SR_ST_ACTIVE, NULL, NULL, NULL);
|
||||
|
@ -306,7 +306,8 @@ SR_API int ds_get_device_list(struct ds_device_base_info **out_list, int *out_co
|
||||
|
||||
array = (struct ds_device_info *)malloc(sizeof(struct ds_device_base_info) * (num + 1));
|
||||
if (array == NULL)
|
||||
{
|
||||
{
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
pthread_mutex_unlock(&lib_ctx.mutext);
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
|
@ -51,7 +51,7 @@
|
||||
#define USB_EV_HOTPLUG_ATTACH 1
|
||||
#define USB_EV_HOTPLUG_DETTACH 2
|
||||
|
||||
#define g_safe_free(p) if((p)) g_free((p)); ((p)) = NULL;
|
||||
#define safe_free(p) if((p)) free((p)); ((p)) = NULL;
|
||||
#define g_safe_free_list(p) if((p)) g_slist_free((p)); ((p)) = NULL;
|
||||
|
||||
#define DS_VENDOR_ID 0x2A0E
|
||||
|
@ -24,6 +24,7 @@
|
||||
#include <string.h>
|
||||
#include <glib.h>
|
||||
#include "../config.h" /* Needed for PACKAGE_STRING and others. */
|
||||
#include "../log.h"
|
||||
|
||||
struct context {
|
||||
unsigned int num_enabled_channels;
|
||||
@ -68,7 +69,12 @@ static int init(struct sr_output *o, GHashTable *options)
|
||||
if (!o || !o->sdi)
|
||||
return SR_ERR_ARG;
|
||||
|
||||
ctx = g_malloc0(sizeof(struct context));
|
||||
ctx = malloc(sizeof(struct context));
|
||||
if (ctx == NULL){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SR_ERR;
|
||||
}
|
||||
|
||||
o->priv = ctx;
|
||||
ctx->separator = ',';
|
||||
ctx->mask = 0;
|
||||
@ -84,12 +90,17 @@ static int init(struct sr_output *o, GHashTable *options)
|
||||
continue;
|
||||
ctx->num_enabled_channels++;
|
||||
}
|
||||
ctx->channel_index = g_malloc(sizeof(int) * ctx->num_enabled_channels);
|
||||
ctx->channel_unit = g_malloc(sizeof(int) * ctx->num_enabled_channels);
|
||||
ctx->channel_scale = g_malloc(sizeof(float) * ctx->num_enabled_channels);
|
||||
ctx->channel_offset = g_malloc(sizeof(uint16_t) * ctx->num_enabled_channels);
|
||||
ctx->channel_mmax = g_malloc(sizeof(double) * ctx->num_enabled_channels);
|
||||
ctx->channel_mmin = g_malloc(sizeof(double) * ctx->num_enabled_channels);
|
||||
ctx->channel_index = malloc(sizeof(int) * ctx->num_enabled_channels);
|
||||
ctx->channel_unit = malloc(sizeof(int) * ctx->num_enabled_channels);
|
||||
ctx->channel_scale = malloc(sizeof(float) * ctx->num_enabled_channels);
|
||||
ctx->channel_offset = malloc(sizeof(uint16_t) * ctx->num_enabled_channels);
|
||||
ctx->channel_mmax = malloc(sizeof(double) * ctx->num_enabled_channels);
|
||||
ctx->channel_mmin = malloc(sizeof(double) * ctx->num_enabled_channels);
|
||||
|
||||
if (ctx->channel_index == NULL || ctx->channel_mmin == NULL){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return;
|
||||
}
|
||||
|
||||
/* Once more to map the enabled channels. */
|
||||
for (i = 0, l = o->sdi->channels; l; l = l->next) {
|
||||
|
@ -56,9 +56,15 @@ static int init(struct sr_output *o, GHashTable *options)
|
||||
if (!o || !o->sdi)
|
||||
return SR_ERR_ARG;
|
||||
|
||||
ctx = g_malloc0(sizeof(struct context));
|
||||
ctx = malloc(sizeof(struct context));
|
||||
if (ctx == NULL){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SR_ERR;
|
||||
}
|
||||
|
||||
o->priv = ctx;
|
||||
ctx->num_enabled_channels = 0;
|
||||
|
||||
for (l = o->sdi->channels; l; l = l->next) {
|
||||
ch = l->data;
|
||||
if (ch->type != SR_CHANNEL_LOGIC)
|
||||
@ -67,11 +73,17 @@ static int init(struct sr_output *o, GHashTable *options)
|
||||
continue;
|
||||
ctx->num_enabled_channels++;
|
||||
}
|
||||
|
||||
if (ctx->num_enabled_channels <= 0) {
|
||||
sr_err("No logic channel enabled.");
|
||||
return SR_ERR;
|
||||
}
|
||||
ctx->channel_index = g_malloc(sizeof(int) * ctx->num_enabled_channels);
|
||||
ctx->channel_index = malloc(sizeof(int) * ctx->num_enabled_channels);
|
||||
|
||||
if (ctx->channel_index == NULL){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SR_ERR;
|
||||
}
|
||||
|
||||
/* Once more to map the enabled channels. */
|
||||
for (i = 0, l = o->sdi->channels; l; l = l->next) {
|
||||
@ -166,7 +178,11 @@ static int receive(const struct sr_output *o, const struct sr_datafeed_packet *p
|
||||
|
||||
if (!ctx->prevsample) {
|
||||
/* Can't allocate this until we know the stream's unitsize. */
|
||||
ctx->prevsample = g_malloc0(logic->unitsize);
|
||||
ctx->prevsample = malloc(logic->unitsize);
|
||||
|
||||
if (ctx->prevsample == NULL){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
}
|
||||
}
|
||||
|
||||
if (!ctx->header_done) {
|
||||
|
@ -191,9 +191,13 @@ SR_API const struct sr_option **sr_output_options_get(const struct sr_output_mod
|
||||
|
||||
mod_opts = omod->options();
|
||||
|
||||
for (size = 0; mod_opts[size].id; size++)
|
||||
;
|
||||
opts = g_malloc((size + 1) * sizeof(struct sr_option *));
|
||||
for (size = 0; mod_opts[size].id; size++);
|
||||
|
||||
opts = malloc((size + 1) * sizeof(struct sr_option *));
|
||||
if (opts == NULL){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
for (i = 0; i < size; i++)
|
||||
opts[i] = &mod_opts[i];
|
||||
@ -253,7 +257,12 @@ SR_API const struct sr_output *sr_output_new(const struct sr_output_module *omod
|
||||
gpointer key, value;
|
||||
int i;
|
||||
|
||||
op = g_malloc(sizeof(struct sr_output));
|
||||
op = malloc(sizeof(struct sr_output));
|
||||
if (op == NULL){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SR_ERR;
|
||||
}
|
||||
|
||||
op->module = omod;
|
||||
op->sdi = sdi;
|
||||
|
||||
|
@ -44,7 +44,12 @@ static int init(struct sr_output *o, GHashTable *options)
|
||||
{
|
||||
struct out_context *outc;
|
||||
|
||||
outc = g_malloc0(sizeof(struct out_context));
|
||||
outc = malloc(sizeof(struct out_context));
|
||||
if (outc == NULL){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SR_ERR;
|
||||
}
|
||||
|
||||
o->priv = outc;
|
||||
outc->zipArchive = NULL;
|
||||
outc->bCreated = 0;
|
||||
|
@ -61,10 +61,20 @@ static int init(struct sr_output *o, GHashTable *options)
|
||||
return SR_ERR;
|
||||
}
|
||||
|
||||
ctx = g_malloc0(sizeof(struct context));
|
||||
ctx = malloc(sizeof(struct context));
|
||||
if (ctx == NULL){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SR_ERR;
|
||||
}
|
||||
|
||||
o->priv = ctx;
|
||||
ctx->num_enabled_channels = num_enabled_channels;
|
||||
ctx->channel_index = g_malloc(sizeof(int) * ctx->num_enabled_channels);
|
||||
ctx->channel_index = malloc(sizeof(int) * ctx->num_enabled_channels);
|
||||
|
||||
if (ctx->channel_index == NULL){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SR_ERR;
|
||||
}
|
||||
|
||||
/* Once more to map the enabled channels. */
|
||||
for (i = 0, l = o->sdi->channels; l; l = l->next) {
|
||||
@ -196,7 +206,11 @@ static int receive(const struct sr_output *o, const struct sr_datafeed_packet *p
|
||||
|
||||
if (!ctx->prevsample) {
|
||||
/* Can't allocate this until we know the stream's unitsize. */
|
||||
ctx->prevsample = g_malloc0(logic->unitsize);
|
||||
ctx->prevsample = malloc(logic->unitsize);
|
||||
|
||||
if (ctx->prevsample == NULL){
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
}
|
||||
}
|
||||
|
||||
for (i = 0; i <= logic->length - logic->unitsize; i += logic->unitsize) {
|
||||
|
@ -24,6 +24,7 @@
|
||||
#include <string.h>
|
||||
#include <glib.h>
|
||||
#include "log.h"
|
||||
#include <assert.h>
|
||||
|
||||
/* Message logging helpers with subsystem-specific prefix string. */
|
||||
|
||||
@ -58,7 +59,6 @@ struct source {
|
||||
*/
|
||||
gintptr poll_object;
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* Create a new session.
|
||||
@ -75,11 +75,12 @@ SR_PRIV struct sr_session *sr_session_new(void)
|
||||
sr_session_destroy(); // Destory the old.
|
||||
}
|
||||
|
||||
session = g_try_malloc0(sizeof(struct sr_session));
|
||||
session = malloc(sizeof(struct sr_session));
|
||||
if (session == NULL) {
|
||||
sr_err("%s", "Session malloc failed.");
|
||||
sr_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return NULL;
|
||||
}
|
||||
memset(session, 0, sizeof(struct sr_session));
|
||||
|
||||
session->source_timeout = -1;
|
||||
session->running = FALSE;
|
||||
|
@ -471,11 +471,12 @@ static int receive_data_logic_dso_v2(int fd, int revents, const struct sr_dev_in
|
||||
if (vdev->packet_buffer == NULL){
|
||||
vdev->cur_block = 0;
|
||||
|
||||
vdev->packet_buffer = g_try_malloc0(sizeof(struct session_packet_buffer));
|
||||
vdev->packet_buffer = malloc(sizeof(struct session_packet_buffer));
|
||||
if (vdev->packet_buffer == NULL){
|
||||
sr_err("%s: vdev->packet_buffer malloc failed", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
memset(vdev->packet_buffer, 0, sizeof(struct session_packet_buffer));
|
||||
|
||||
for (ch_index = 0; ch_index <= chan_num; ch_index++){
|
||||
vdev->packet_buffer->block_bufs[ch_index] = NULL;
|
||||
@ -487,7 +488,7 @@ static int receive_data_logic_dso_v2(int fd, int revents, const struct sr_dev_in
|
||||
else
|
||||
vdev->packet_buffer->post_buf_len = chan_num * 10000;
|
||||
|
||||
vdev->packet_buffer->post_buf = g_try_malloc0(vdev->packet_buffer->post_buf_len + 1);
|
||||
vdev->packet_buffer->post_buf = malloc(vdev->packet_buffer->post_buf_len + 1);
|
||||
if (vdev->packet_buffer->post_buf == NULL){
|
||||
sr_err("%s: vdev->packet_buffer->post_buf malloc failed", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
@ -564,7 +565,7 @@ static int receive_data_logic_dso_v2(int fd, int revents, const struct sr_dev_in
|
||||
pack_buffer->block_bufs[malloc_chan_index] = NULL;
|
||||
}
|
||||
|
||||
pack_buffer->block_bufs[malloc_chan_index] = g_try_malloc0(pack_buffer->block_data_len + 1);
|
||||
pack_buffer->block_bufs[malloc_chan_index] = malloc(pack_buffer->block_data_len + 1);
|
||||
if (pack_buffer->block_bufs[malloc_chan_index] == NULL){
|
||||
sr_err("%s: block buffer malloc failed", __func__);
|
||||
send_error_packet(sdi, vdev, &packet);
|
||||
@ -718,34 +719,23 @@ static int dev_open(struct sr_dev_inst *sdi)
|
||||
|
||||
assert(sdi->priv == NULL);
|
||||
|
||||
sdi->priv = g_try_malloc0(sizeof(struct session_vdev));
|
||||
if (sdi->priv == NULL)
|
||||
vdev = malloc(sizeof(struct session_vdev));
|
||||
if (vdev == NULL)
|
||||
{
|
||||
sr_err("%s: sdi->priv malloc failed", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
vdev = sdi->priv;
|
||||
memset(vdev, 0, sizeof(struct session_vdev));
|
||||
|
||||
vdev->buf = NULL;
|
||||
vdev->trig_pos = 0;
|
||||
vdev->trig_time = 0;
|
||||
vdev->cur_block = 0;
|
||||
vdev->cur_channel = 0;
|
||||
vdev->num_blocks = 0;
|
||||
vdev->unit_bits = 1;
|
||||
vdev->ref_min = 0;
|
||||
vdev->ref_max = 0;
|
||||
vdev->max_timebase = MAX_TIMEBASE;
|
||||
vdev->min_timebase = MIN_TIMEBASE;
|
||||
vdev->max_height = 0;
|
||||
vdev->mstatus.measure_valid = TRUE;
|
||||
vdev->archive = NULL;
|
||||
vdev->capfile = 0;
|
||||
vdev->packet_buffer = NULL;
|
||||
vdev->logic_buf = NULL;
|
||||
vdev->unit_bits = 1;
|
||||
|
||||
sdi->priv = vdev;
|
||||
sdi->status = SR_ST_ACTIVE;
|
||||
|
||||
vdev->buf = g_try_malloc(CHUNKSIZE + sizeof(uint64_t));
|
||||
vdev->buf = malloc(CHUNKSIZE + sizeof(uint64_t));
|
||||
if (vdev->buf == NULL){
|
||||
sr_err("%s: vdev->buf malloc failed", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
@ -772,7 +762,7 @@ static void free_temp_buffer(struct session_vdev *vdev)
|
||||
|
||||
if (pack_buf != NULL)
|
||||
{
|
||||
g_safe_free(pack_buf->post_buf);
|
||||
safe_free(pack_buf->post_buf);
|
||||
|
||||
for (i = 0; i < SESSION_MAX_CHANNEL_COUNT; i++){
|
||||
if (pack_buf->block_bufs[i] != NULL){
|
||||
@ -785,9 +775,9 @@ static void free_temp_buffer(struct session_vdev *vdev)
|
||||
}
|
||||
}
|
||||
|
||||
g_safe_free(vdev->packet_buffer);
|
||||
g_safe_free(vdev->buf);
|
||||
g_safe_free(vdev->logic_buf);
|
||||
safe_free(vdev->packet_buffer);
|
||||
safe_free(vdev->buf);
|
||||
safe_free(vdev->logic_buf);
|
||||
}
|
||||
|
||||
static int dev_close(struct sr_dev_inst *sdi)
|
||||
@ -799,7 +789,7 @@ static int dev_close(struct sr_dev_inst *sdi)
|
||||
vdev = sdi->priv;
|
||||
free_temp_buffer(vdev);
|
||||
|
||||
g_safe_free(sdi->priv);
|
||||
safe_free(sdi->priv);
|
||||
|
||||
sdi->status = SR_ST_INACTIVE;
|
||||
return SR_OK;
|
||||
@ -1108,7 +1098,7 @@ static int config_set(int id, GVariant *data, struct sr_dev_inst *sdi,
|
||||
{
|
||||
if (sdi->mode == LOGIC)
|
||||
{
|
||||
if (!(vdev->logic_buf = g_try_malloc(CHUNKSIZE / 16 * vdev->num_probes)))
|
||||
if (!(vdev->logic_buf = malloc(CHUNKSIZE / 16 * vdev->num_probes)))
|
||||
{
|
||||
sr_err("%s: vdev->logic_buf malloc failed", __func__);
|
||||
}
|
||||
@ -1493,7 +1483,7 @@ SR_PRIV int sr_new_virtual_device(const char *filename, struct sr_dev_inst **out
|
||||
return SR_ERR;
|
||||
}
|
||||
|
||||
if (!(metafile = g_try_malloc(fileInfo.uncompressed_size)))
|
||||
if (!(metafile = malloc(fileInfo.uncompressed_size)))
|
||||
{
|
||||
sr_err("%s: metafile malloc failed", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
@ -1610,7 +1600,7 @@ static int sr_load_virtual_device_session(struct sr_dev_inst *sdi)
|
||||
return SR_ERR;
|
||||
}
|
||||
|
||||
if (!(metafile = g_try_malloc(fileInfo.uncompressed_size)))
|
||||
if (!(metafile = malloc(fileInfo.uncompressed_size)))
|
||||
{
|
||||
sr_err("%s: metafile malloc failed", __func__);
|
||||
return SR_ERR_MALLOC;
|
||||
|
@ -21,6 +21,7 @@
|
||||
#include "libsigrok-internal.h"
|
||||
#include <glib.h>
|
||||
#include "log.h"
|
||||
#include <assert.h>
|
||||
|
||||
/**
|
||||
* Standard sr_driver_init() API helper.
|
||||
@ -47,10 +48,11 @@ SR_PRIV int std_hw_init(struct sr_context *sr_ctx, struct sr_dev_driver *di,
|
||||
return SR_ERR_ARG;
|
||||
}
|
||||
|
||||
if (!(drvc = g_try_malloc(sizeof(struct drv_context)))) {
|
||||
if (!(drvc = malloc(sizeof(struct drv_context)))) {
|
||||
sr_err("%sDriver context malloc failed.", prefix);
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
// not need init.
|
||||
|
||||
drvc->sr_ctx = sr_ctx;
|
||||
di->priv = drvc;
|
||||
|
@ -52,7 +52,7 @@
|
||||
* @param unit The unit to append to the string, or NULL if the string
|
||||
* has no units.
|
||||
*
|
||||
* @return A g_try_malloc()ed string representation of the samplerate value,
|
||||
* @return A malloc()ed string representation of the samplerate value,
|
||||
* or NULL upon errors. The caller is responsible to g_free() the
|
||||
* memory.
|
||||
*/
|
||||
@ -97,7 +97,7 @@ SR_API char *sr_si_string_u64(uint64_t x, const char *unit)
|
||||
* @param unit The unit to append to the string, or NULL if the string
|
||||
* has no units.
|
||||
*
|
||||
* @return A g_try_malloc()ed string representation of the samplerate value,
|
||||
* @return A malloc()ed string representation of the samplerate value,
|
||||
* or NULL upon errors. The caller is responsible to g_free() the
|
||||
* memory.
|
||||
*/
|
||||
@ -139,7 +139,7 @@ SR_API char *sr_iec_string_u64(uint64_t x, const char *unit)
|
||||
*
|
||||
* @param samplerate The samplerate in Hz.
|
||||
*
|
||||
* @return A g_try_malloc()ed string representation of the samplerate value,
|
||||
* @return A malloc()ed string representation of the samplerate value,
|
||||
* or NULL upon errors. The caller is responsible to g_free() the
|
||||
* memory.
|
||||
*/
|
||||
@ -155,7 +155,7 @@ SR_API char *sr_samplerate_string(uint64_t samplerate)
|
||||
*
|
||||
* @param samplecount.
|
||||
*
|
||||
* @return A g_try_malloc()ed string representation of the samplecount value,
|
||||
* @return A malloc()ed string representation of the samplecount value,
|
||||
* or NULL upon errors. The caller is responsible to g_free() the
|
||||
* memory.
|
||||
*/
|
||||
@ -172,7 +172,7 @@ SR_API char *sr_samplecount_string(uint64_t samplecount)
|
||||
*
|
||||
* @param frequency The frequency in Hz.
|
||||
*
|
||||
* @return A g_try_malloc()ed string representation of the frequency value,
|
||||
* @return A malloc()ed string representation of the frequency value,
|
||||
* or NULL upon errors. The caller is responsible to g_free() the
|
||||
* memory.
|
||||
*/
|
||||
@ -182,7 +182,7 @@ SR_API char *sr_period_string(uint64_t frequency)
|
||||
int r;
|
||||
|
||||
/* Allocate enough for a uint64_t as string + " ms". */
|
||||
if (!(o = g_try_malloc0(30 + 1))) {
|
||||
if (!(o = malloc(30 + 1))) {
|
||||
sr_err("%s: o malloc failed", __func__);
|
||||
return NULL;
|
||||
}
|
||||
@ -213,7 +213,7 @@ SR_API char *sr_period_string(uint64_t frequency)
|
||||
*
|
||||
* @param time The time in ns.
|
||||
*
|
||||
* @return A g_try_malloc()ed string representation of the time value,
|
||||
* @return A malloc()ed string representation of the time value,
|
||||
* or NULL upon errors. The caller is responsible to g_free() the
|
||||
* memory.
|
||||
*/
|
||||
@ -223,7 +223,7 @@ SR_API char *sr_time_string(uint64_t time)
|
||||
int r;
|
||||
|
||||
/* Allocate enough for a uint64_t as string + " ms". */
|
||||
if (!(o = g_try_malloc0(30 + 1))) {
|
||||
if (!(o = malloc(30 + 1))) {
|
||||
sr_err("%s: o malloc failed", __func__);
|
||||
return NULL;
|
||||
}
|
||||
@ -262,7 +262,7 @@ SR_API char *sr_time_string(uint64_t time)
|
||||
* @param v_p The voltage numerator.
|
||||
* @param v_q The voltage denominator.
|
||||
*
|
||||
* @return A g_try_malloc()ed string representation of the voltage value,
|
||||
* @return A malloc()ed string representation of the voltage value,
|
||||
* or NULL upon errors. The caller is responsible to g_free() the
|
||||
* memory.
|
||||
*/
|
||||
@ -271,7 +271,7 @@ SR_API char *sr_voltage_string(uint64_t v_p, uint64_t v_q)
|
||||
int r;
|
||||
char *o;
|
||||
|
||||
if (!(o = g_try_malloc0(30 + 1))) {
|
||||
if (!(o = malloc(30 + 1))) {
|
||||
sr_err("%s: o malloc failed", __func__);
|
||||
return NULL;
|
||||
}
|
||||
|
@ -56,10 +56,11 @@ SR_PRIV int ds_trigger_init(void)
|
||||
int i, j;
|
||||
|
||||
if (!trigger) {
|
||||
if (!(trigger = g_try_malloc0(sizeof(struct ds_trigger)))) {
|
||||
if (!(trigger = malloc(sizeof(struct ds_trigger)))) {
|
||||
sr_err("Trigger malloc failed.");
|
||||
return SR_ERR_MALLOC;
|
||||
}
|
||||
memset(trigger, 0, sizeof(struct ds_trigger));
|
||||
}
|
||||
|
||||
trigger->trigger_en = 0;
|
||||
|
@ -50,11 +50,11 @@ Random notes
|
||||
memory. Otherwise use standard free(). Never use the wrong function!
|
||||
|
||||
- We assume that "small" memory allocations (< 1MB) will always succeed.
|
||||
Thus, it's fine to use g_malloc() or g_malloc0() for allocations of
|
||||
simple/small structs and such (instead of using g_try_malloc()), and
|
||||
Thus, it's fine to use malloc() or malloc() for allocations of
|
||||
simple/small structs and such (instead of using malloc()), and
|
||||
there's no need to check the return value.
|
||||
|
||||
Do use g_try_malloc() or g_try_malloc0() for large (>= 1MB) allocations
|
||||
Do use malloc() or malloc() for large (>= 1MB) allocations
|
||||
and check the return value.
|
||||
|
||||
- You should never print any messages (neither to stdout nor stderr nor
|
||||
|
@ -112,10 +112,10 @@ static void channel_free(void *data)
|
||||
if (!ch)
|
||||
return;
|
||||
|
||||
g_safe_free(ch->desc);
|
||||
g_safe_free(ch->name);
|
||||
g_safe_free(ch->id);
|
||||
g_safe_free(ch->idn);
|
||||
safe_free(ch->desc);
|
||||
safe_free(ch->name);
|
||||
safe_free(ch->id);
|
||||
safe_free(ch->idn);
|
||||
g_free(ch);
|
||||
}
|
||||
|
||||
@ -151,9 +151,9 @@ static void decoder_option_free(void *data)
|
||||
|
||||
g_slist_free_full(opt->values, &variant_free);
|
||||
variant_free(opt->def);
|
||||
g_safe_free(opt->desc);
|
||||
g_safe_free(opt->id);
|
||||
g_safe_free(opt->idn);
|
||||
safe_free(opt->desc);
|
||||
safe_free(opt->id);
|
||||
safe_free(opt->idn);
|
||||
g_free(opt);
|
||||
}
|
||||
|
||||
@ -227,11 +227,12 @@ static int get_channels(const struct srd_decoder *d, const char *attr,
|
||||
"a list of dict elements.", d->name, attr);
|
||||
goto err_out;
|
||||
}
|
||||
pdch = g_malloc(sizeof(struct srd_channel));
|
||||
pdch->id = NULL;
|
||||
pdch->name = NULL;
|
||||
pdch->desc = NULL;
|
||||
pdch->idn = NULL;
|
||||
pdch = malloc(sizeof(struct srd_channel));
|
||||
if (pdch == NULL){
|
||||
srd_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
goto err_out;
|
||||
}
|
||||
memset(pdch, 0, sizeof(struct srd_channel));
|
||||
|
||||
/* Add to list right away so it doesn't get lost. */
|
||||
pdchl = g_slist_prepend(pdchl, pdch);
|
||||
@ -311,12 +312,12 @@ static int get_options(struct srd_decoder *d)
|
||||
goto err_out;
|
||||
}
|
||||
|
||||
o = g_malloc0(sizeof(struct srd_decoder_option));
|
||||
o->id = NULL;
|
||||
o->idn = NULL;
|
||||
o->desc = NULL;
|
||||
o->def = NULL;
|
||||
o->values = NULL;
|
||||
o = malloc(sizeof(struct srd_decoder_option));
|
||||
if (o == NULL){
|
||||
srd_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
goto err_out;
|
||||
}
|
||||
memset(o, 0, sizeof(struct srd_decoder_option));
|
||||
|
||||
/* Add to list right away so it doesn't get lost. */
|
||||
options = g_slist_prepend(options, o);
|
||||
@ -417,6 +418,8 @@ static int get_annotations(struct srd_decoder *dec)
|
||||
unsigned int j;
|
||||
PyGILState_STATE gstate;
|
||||
|
||||
assert(dec);
|
||||
|
||||
gstate = PyGILState_Ensure();
|
||||
|
||||
if (!PyObject_HasAttrString(dec->py_dec, "annotations")) {
|
||||
@ -519,7 +522,13 @@ static int get_annotation_rows(struct srd_decoder *dec)
|
||||
dec->name);
|
||||
goto err_out;
|
||||
}
|
||||
ann_row = g_malloc0(sizeof(struct srd_decoder_annotation_row));
|
||||
ann_row = malloc(sizeof(struct srd_decoder_annotation_row));
|
||||
if (ann_row == NULL){
|
||||
srd_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
goto err_out;
|
||||
}
|
||||
memset(ann_row, 0, sizeof(struct srd_decoder_annotation_row));
|
||||
|
||||
/* Add to list right away so it doesn't get lost. */
|
||||
annotation_rows = g_slist_prepend(annotation_rows, ann_row);
|
||||
|
||||
@ -740,7 +749,13 @@ SRD_API int srd_decoder_load(const char *module_name)
|
||||
return SRD_OK;
|
||||
}
|
||||
|
||||
d = g_malloc0(sizeof(struct srd_decoder));
|
||||
d = malloc(sizeof(struct srd_decoder));
|
||||
if (d == NULL){
|
||||
srd_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
goto err_out;
|
||||
}
|
||||
memset(d, 0, sizeof(struct srd_decoder));
|
||||
|
||||
fail_txt = NULL;
|
||||
|
||||
//Load module from python script file,module_name is a sub directory
|
||||
@ -1089,6 +1104,8 @@ static void srd_decoder_load_all_path(char *path)
|
||||
const gchar *direntry;
|
||||
int ldst = 0;
|
||||
|
||||
assert(path);
|
||||
|
||||
if (!(dir = g_dir_open(path, 0, NULL))) {
|
||||
/* Not really fatal. Try zipimport method too. */
|
||||
srd_decoder_load_all_zip_path(path);
|
||||
@ -1121,8 +1138,9 @@ SRD_API int srd_decoder_load_all(void)
|
||||
if (!srd_check_init())
|
||||
return SRD_ERR;
|
||||
|
||||
for (l = searchpaths; l; l = l->next)
|
||||
for (l = searchpaths; l; l = l->next){
|
||||
srd_decoder_load_all_path(l->data);
|
||||
}
|
||||
|
||||
return SRD_OK;
|
||||
}
|
||||
|
@ -251,7 +251,11 @@ SRD_API int srd_inst_channel_set_all(struct srd_decoder_inst *di,
|
||||
return SRD_ERR_ARG;
|
||||
}
|
||||
|
||||
new_channelmap = g_malloc0(sizeof(int) * di->dec_num_channels);
|
||||
new_channelmap = malloc(sizeof(int) * di->dec_num_channels);
|
||||
if (new_channelmap == NULL){
|
||||
srd_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SRD_ERR;
|
||||
}
|
||||
|
||||
/*
|
||||
* For now, map all indexes to channel -1 (can be overridden later).
|
||||
@ -351,8 +355,13 @@ SRD_API struct srd_decoder_inst *srd_inst_new(struct srd_session *sess,
|
||||
return NULL;
|
||||
}
|
||||
|
||||
di = g_malloc0(sizeof(struct srd_decoder_inst));
|
||||
|
||||
di = malloc(sizeof(struct srd_decoder_inst));
|
||||
if (di == NULL){
|
||||
srd_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return NULL;
|
||||
}
|
||||
memset(di, 0, sizeof(struct srd_decoder_inst));
|
||||
|
||||
di->decoder = dec;
|
||||
di->sess = sess;
|
||||
|
||||
@ -383,7 +392,13 @@ SRD_API struct srd_decoder_inst *srd_inst_new(struct srd_session *sess,
|
||||
g_slist_length(di->decoder->opt_channels);
|
||||
|
||||
if (di->dec_num_channels > 0) {
|
||||
di->dec_channelmap = g_malloc(sizeof(int) * di->dec_num_channels);
|
||||
di->dec_channelmap = malloc(sizeof(int) * di->dec_num_channels);
|
||||
|
||||
if (di->dec_channelmap == NULL){
|
||||
PyGILState_Release(gstate);
|
||||
srd_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return;
|
||||
}
|
||||
|
||||
for (i = 0; i < di->dec_num_channels; i++)
|
||||
di->dec_channelmap[i] = i;
|
||||
|
@ -29,7 +29,7 @@
|
||||
#include "libsigrokdecode.h"
|
||||
#include <structmember.h>
|
||||
|
||||
#define g_safe_free(p) if((p)){g_free((p)); (p) = NULL;}
|
||||
#define safe_free(p) if((p)){free((p)); (p) = NULL;}
|
||||
|
||||
enum {
|
||||
SRD_TERM_HIGH,
|
||||
|
@ -63,17 +63,26 @@ SRD_PRIV int max_session_id = -1;
|
||||
*/
|
||||
SRD_API int srd_session_new(struct srd_session **sess)
|
||||
{
|
||||
struct srd_session *se = NULL;
|
||||
|
||||
if (!sess)
|
||||
return SRD_ERR_ARG;
|
||||
|
||||
*sess = g_malloc(sizeof(struct srd_session));
|
||||
(*sess)->session_id = ++max_session_id;
|
||||
(*sess)->di_list = (*sess)->callbacks = NULL;
|
||||
se = malloc(sizeof(struct srd_session));
|
||||
if (se == NULL){
|
||||
srd_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SRD_ERR;
|
||||
}
|
||||
memset(se, 0, sizeof(struct srd_session));
|
||||
|
||||
se->session_id = ++max_session_id;
|
||||
|
||||
/* Keep a list of all sessions, so we can clean up as needed. */
|
||||
sessions = g_slist_append(sessions, *sess);
|
||||
sessions = g_slist_append(sessions, se);
|
||||
|
||||
srd_info("Creating session %d.", (*sess)->session_id);
|
||||
*sess = se;
|
||||
|
||||
//srd_info("Creating session %d.", (*sess)->session_id);
|
||||
|
||||
return SRD_OK;
|
||||
}
|
||||
@ -379,7 +388,13 @@ SRD_API int srd_pd_output_callback_add(struct srd_session *sess,
|
||||
srd_dbg("Registering new callback for output type %s.",
|
||||
output_type_name(output_type));
|
||||
|
||||
pd_cb = g_malloc(sizeof(struct srd_pd_callback));
|
||||
pd_cb = malloc(sizeof(struct srd_pd_callback));
|
||||
if (pd_cb == NULL){
|
||||
srd_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SRD_ERR;
|
||||
}
|
||||
memset(pd_cb, 0, sizeof(struct srd_pd_callback));
|
||||
|
||||
pd_cb->output_type = output_type;
|
||||
pd_cb->cb = cb;
|
||||
pd_cb->cb_data = cb_data;
|
||||
|
@ -342,8 +342,11 @@ static int convert_binary(struct srd_decoder_inst *di, PyObject *obj,
|
||||
pdb = pdata->data;
|
||||
pdb->bin_class = bin_class;
|
||||
pdb->size = size;
|
||||
if (!(pdb->data = g_try_malloc(pdb->size)))
|
||||
if (!(pdb->data = malloc(pdb->size))){
|
||||
srd_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SRD_ERR_MALLOC;
|
||||
}
|
||||
|
||||
memcpy((void *)pdb->data, (const void *)buf, pdb->size);
|
||||
|
||||
return SRD_OK;
|
||||
@ -677,7 +680,13 @@ static PyObject *Decoder_register(PyObject *self, PyObject *args,
|
||||
return py_new_output_id;
|
||||
}
|
||||
|
||||
pdo = g_malloc(sizeof(struct srd_pd_output));
|
||||
pdo = malloc(sizeof(struct srd_pd_output));
|
||||
if (pdo == NULL){
|
||||
PyGILState_Release(gstate);
|
||||
srd_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
return SRD_ERR;
|
||||
}
|
||||
memset(pdo, 0, sizeof(struct srd_pd_output));
|
||||
|
||||
/* pdo_id is just a simple index, nothing is deleted from this list anyway. */
|
||||
pdo->pdo_id = g_slist_length(di->pd_output);
|
||||
@ -822,9 +831,16 @@ static int create_term_list(PyObject *py_dict, GSList **term_list, gboolean cur_
|
||||
goto err;
|
||||
}
|
||||
|
||||
term = g_malloc(sizeof(struct srd_term));
|
||||
term->type = get_term_type(term_str);
|
||||
term->channel = PyLong_AsLong(py_key);
|
||||
term = malloc(sizeof(struct srd_term));
|
||||
if (term != NULL){
|
||||
memset(term, 0, sizeof(struct srd_term));
|
||||
term->type = get_term_type(term_str);
|
||||
term->channel = PyLong_AsLong(py_key);
|
||||
}
|
||||
else{
|
||||
srd_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
}
|
||||
|
||||
g_free(term_str);
|
||||
|
||||
} else if (PyUnicode_Check(py_key)) {
|
||||
@ -834,10 +850,16 @@ static int create_term_list(PyObject *py_dict, GSList **term_list, gboolean cur_
|
||||
srd_err("Failed to get number of samples to skip.");
|
||||
goto err;
|
||||
}
|
||||
term = g_malloc(sizeof(struct srd_term));
|
||||
term->type = SRD_TERM_SKIP;
|
||||
term->num_samples_to_skip = num_samples_to_skip;
|
||||
term->num_samples_already_skipped = cur_matched ? (term->num_samples_to_skip != 0) : 0;
|
||||
term = malloc(sizeof(struct srd_term));
|
||||
if (term != NULL){
|
||||
memset(term, 0, sizeof(struct srd_term));
|
||||
term->type = SRD_TERM_SKIP;
|
||||
term->num_samples_to_skip = num_samples_to_skip;
|
||||
term->num_samples_already_skipped = cur_matched ? (term->num_samples_to_skip != 0) : 0;
|
||||
}
|
||||
else{
|
||||
srd_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
}
|
||||
|
||||
} else {
|
||||
srd_err("Term key is neither a string nor a number.");
|
||||
@ -992,15 +1014,25 @@ ret_9999:
|
||||
*/
|
||||
static int set_skip_condition(struct srd_decoder_inst *di, uint64_t count)
|
||||
{
|
||||
assert(di);
|
||||
|
||||
struct srd_term *term;
|
||||
GSList *term_list;
|
||||
|
||||
condition_list_free(di);
|
||||
term = g_malloc(sizeof(*term));
|
||||
term->type = SRD_TERM_SKIP;
|
||||
term->num_samples_to_skip = count;
|
||||
term->num_samples_already_skipped = di->abs_cur_matched ? (term->num_samples_to_skip != 0) : 0;
|
||||
term_list = g_slist_append(NULL, term);
|
||||
|
||||
term = malloc(sizeof(struct srd_term));
|
||||
if (term != NULL){
|
||||
memset(term, 0, sizeof(struct srd_term));
|
||||
term->type = SRD_TERM_SKIP;
|
||||
term->num_samples_to_skip = count;
|
||||
term->num_samples_already_skipped = di->abs_cur_matched ? (term->num_samples_to_skip != 0) : 0;
|
||||
term_list = g_slist_append(NULL, term);
|
||||
}
|
||||
else{
|
||||
srd_err("%s,ERROR:failed to alloc memory.", __func__);
|
||||
}
|
||||
|
||||
di->condition_list = g_slist_append(di->condition_list, term_list);
|
||||
|
||||
return SRD_OK;
|
||||
|
@ -64,7 +64,7 @@ SRD_PRIV PyObject *py_import_by_name(const char *name)
|
||||
* @param[out] outstr ptr to char * storage to be filled in.
|
||||
*
|
||||
* @return SRD_OK upon success, a (negative) error code otherwise.
|
||||
* The 'outstr' argument points to a g_malloc()ed string upon success.
|
||||
* The 'outstr' argument points to a malloc()ed string upon success.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
@ -108,7 +108,7 @@ err:
|
||||
* @param[out] outstrlist ptr to GSList of char * storage to be filled in.
|
||||
*
|
||||
* @return SRD_OK upon success, a (negative) error code otherwise.
|
||||
* The 'outstrlist' argument points to a GSList of g_malloc()ed strings
|
||||
* The 'outstrlist' argument points to a GSList of malloc()ed strings
|
||||
* upon success.
|
||||
*
|
||||
* @private
|
||||
@ -170,7 +170,7 @@ err:
|
||||
* @param[out] outstr Pointer to char * storage to be filled in.
|
||||
*
|
||||
* @return SRD_OK upon success, a (negative) error code otherwise.
|
||||
* The 'outstr' argument points to a g_malloc()ed string upon success.
|
||||
* The 'outstr' argument points to a malloc()ed string upon success.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
@ -245,7 +245,7 @@ err:
|
||||
* @param[out] outstr Pointer to char * storage to be filled in.
|
||||
*
|
||||
* @return SRD_OK upon success, a (negative) error code otherwise.
|
||||
* The 'outstr' argument points to a g_malloc()ed string upon success.
|
||||
* The 'outstr' argument points to a malloc()ed string upon success.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
@ -384,7 +384,7 @@ err:
|
||||
* @param[out] outstr ptr to char * storage to be filled in.
|
||||
*
|
||||
* @return SRD_OK upon success, a (negative) error code otherwise.
|
||||
* The 'outstr' argument points to a g_malloc()ed string upon success.
|
||||
* The 'outstr' argument points to a malloc()ed string upon success.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
|
Loading…
x
Reference in New Issue
Block a user