summaryrefslogtreecommitdiff
path: root/docs/CAmWatchdog_8cpp_source.html
blob: 1900656438cacbf294b14566127d0aa012f90d8e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.11"/>
<title>AudioManager: AudioManagerUtilities/src/CAmWatchdog.cpp Source File</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="navtreedata.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript">
  $(document).ready(initResizable);
  $(window).load(resizeHeight);
</script>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/searchdata.js"></script>
<script type="text/javascript" src="search/search.js"></script>
<script type="text/javascript">
  $(document).ready(function() { init_search(); });
</script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  <td id="projectalign" style="padding-left: 0.5em;">
   <div id="projectname">AudioManager
   &#160;<span id="projectnumber">7.6.6</span>
   </div>
   <div id="projectbrief">Native Application Runtime Environment</div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.11 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="index.html"><span>Main&#160;Page</span></a></li>
      <li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
      <li><a href="modules.html"><span>Modules</span></a></li>
      <li><a href="namespaces.html"><span>Namespaces</span></a></li>
      <li><a href="annotated.html"><span>Classes</span></a></li>
      <li class="current"><a href="files.html"><span>Files</span></a></li>
      <li>
        <div id="MSearchBox" class="MSearchBoxInactive">
        <span class="left">
          <img id="MSearchSelect" src="search/mag_sel.png"
               onmouseover="return searchBox.OnSearchSelectShow()"
               onmouseout="return searchBox.OnSearchSelectHide()"
               alt=""/>
          <input type="text" id="MSearchField" value="Search" accesskey="S"
               onfocus="searchBox.OnSearchFieldFocus(true)" 
               onblur="searchBox.OnSearchFieldFocus(false)" 
               onkeyup="searchBox.OnSearchFieldChange(event)"/>
          </span><span class="right">
            <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
          </span>
        </div>
      </li>
    </ul>
  </div>
  <div id="navrow2" class="tabs2">
    <ul class="tablist">
      <li><a href="files.html"><span>File&#160;List</span></a></li>
      <li><a href="globals.html"><span>File&#160;Members</span></a></li>
    </ul>
  </div>
</div><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
  <div id="nav-tree">
    <div id="nav-tree-contents">
      <div id="nav-sync" class="sync"></div>
    </div>
  </div>
  <div id="splitbar" style="-moz-user-select:none;" 
       class="ui-resizable-handle">
  </div>
</div>
<script type="text/javascript">
$(document).ready(function(){initNavTree('CAmWatchdog_8cpp_source.html','');});
</script>
<div id="doc-content">
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
     onmouseover="return searchBox.OnSearchSelectShow()"
     onmouseout="return searchBox.OnSearchSelectHide()"
     onkeydown="return searchBox.OnSearchSelectKey(event)">
</div>

<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="javascript:void(0)" frameborder="0" 
        name="MSearchResults" id="MSearchResults">
</iframe>
</div>

<div class="header">
  <div class="headertitle">
<div class="title">CAmWatchdog.cpp</div>  </div>
</div><!--header-->
<div class="contents">
<a href="CAmWatchdog_8cpp.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;</div><div class="line"><a name="l00024"></a><span class="lineno">   24</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="CAmWatchdog_8h.html">CAmWatchdog.h</a>&quot;</span></div><div class="line"><a name="l00025"></a><span class="lineno">   25</span>&#160;<span class="preprocessor">#include &lt;cassert&gt;</span></div><div class="line"><a name="l00026"></a><span class="lineno">   26</span>&#160;<span class="preprocessor">#include &lt;cstdlib&gt;</span></div><div class="line"><a name="l00027"></a><span class="lineno">   27</span>&#160;<span class="preprocessor">#include &lt;stdexcept&gt;</span></div><div class="line"><a name="l00028"></a><span class="lineno">   28</span>&#160;<span class="preprocessor">#include &quot;audiomanagerconfig.h&quot;</span></div><div class="line"><a name="l00029"></a><span class="lineno">   29</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="CAmDltWrapper_8h.html">CAmDltWrapper.h</a>&quot;</span></div><div class="line"><a name="l00030"></a><span class="lineno">   30</span>&#160;<span class="preprocessor">#include &lt;systemd/sd-daemon.h&gt;</span></div><div class="line"><a name="l00031"></a><span class="lineno">   31</span>&#160;</div><div class="line"><a name="l00032"></a><span class="lineno">   32</span>&#160;<span class="keyword">namespace </span><a class="code" href="namespaceam.html">am</a></div><div class="line"><a name="l00033"></a><span class="lineno">   33</span>&#160;{</div><div class="line"><a name="l00034"></a><span class="lineno">   34</span>&#160;</div><div class="line"><a name="l00035"></a><span class="lineno"><a class="line" href="classam_1_1CAmWatchdog.html#ad4de61bd5653451dda216ec94a60e57f">   35</a></span>&#160;<a class="code" href="classam_1_1CAmWatchdog.html#ad4de61bd5653451dda216ec94a60e57f">CAmWatchdog::CAmWatchdog</a>(<a class="code" href="classam_1_1CAmSocketHandler.html">CAmSocketHandler</a>* <a class="code" href="classam_1_1CAmSocketHandler.html">CAmSocketHandler</a>) :</div><div class="line"><a name="l00036"></a><span class="lineno">   36</span>&#160;        TimerCallback(this, &amp;<a class="code" href="classam_1_1CAmWatchdog.html">CAmWatchdog</a>::timerCallback), <span class="comment">//</span></div><div class="line"><a name="l00037"></a><span class="lineno">   37</span>&#160;        mpCAmSocketHandler(CAmSocketHandler), <span class="comment">//</span></div><div class="line"><a name="l00038"></a><span class="lineno">   38</span>&#160;        mHandle(0) <span class="comment">//</span></div><div class="line"><a name="l00039"></a><span class="lineno">   39</span>&#160;{</div><div class="line"><a name="l00040"></a><span class="lineno">   40</span>&#160;    assert(mpCAmSocketHandler);</div><div class="line"><a name="l00041"></a><span class="lineno">   41</span>&#160;</div><div class="line"><a name="l00042"></a><span class="lineno">   42</span>&#160;</div><div class="line"><a name="l00043"></a><span class="lineno">   43</span>&#160;    <span class="comment">//first retrieve the timeout interval</span></div><div class="line"><a name="l00044"></a><span class="lineno">   44</span>&#160;</div><div class="line"><a name="l00045"></a><span class="lineno">   45</span>&#160;    <span class="keywordtype">int</span> watchdogTimeout = 0;</div><div class="line"><a name="l00046"></a><span class="lineno">   46</span>&#160;</div><div class="line"><a name="l00047"></a><span class="lineno">   47</span>&#160;    <span class="keywordtype">char</span>* wusec=getenv(<span class="stringliteral">&quot;WATCHDOG_USEC&quot;</span>);</div><div class="line"><a name="l00048"></a><span class="lineno">   48</span>&#160;    <span class="keywordflow">if</span> (wusec)</div><div class="line"><a name="l00049"></a><span class="lineno">   49</span>&#160;        watchdogTimeout=atoi(wusec);</div><div class="line"><a name="l00050"></a><span class="lineno">   50</span>&#160;</div><div class="line"><a name="l00051"></a><span class="lineno">   51</span>&#160;    <span class="keywordflow">if</span> (watchdogTimeout &gt; 0)</div><div class="line"><a name="l00052"></a><span class="lineno">   52</span>&#160;    {</div><div class="line"><a name="l00053"></a><span class="lineno">   53</span>&#160;        timespec timeout;</div><div class="line"><a name="l00054"></a><span class="lineno">   54</span>&#160;</div><div class="line"><a name="l00055"></a><span class="lineno">   55</span>&#160;        <span class="comment">//calculate the half cycle as the right interval to trigger the watchdog.</span></div><div class="line"><a name="l00056"></a><span class="lineno">   56</span>&#160;        timeout.tv_sec =   (watchdogTimeout / 2) / 1000000;</div><div class="line"><a name="l00057"></a><span class="lineno">   57</span>&#160;        timeout.tv_nsec = ((watchdogTimeout / 2) % 1000000) * 1000;</div><div class="line"><a name="l00058"></a><span class="lineno">   58</span>&#160;        <a class="code" href="namespaceam.html#a47d650dc91db97c1f9323b4ed5cf4fd6">logInfo</a>(<span class="stringliteral">&quot;CAmWatchdog::CAmWatchdog setting watchdog timeout:&quot;</span>, watchdogTimeout, <span class="stringliteral">&quot;us. Notification set to:&quot;</span>,</div><div class="line"><a name="l00059"></a><span class="lineno">   59</span>&#160;                (<span class="keywordtype">int</span>)timeout.tv_sec, <span class="stringliteral">&quot;sec and&quot;</span>, (<span class="keywordtype">int</span>)timeout.tv_nsec, <span class="stringliteral">&quot;ns&quot;</span>);</div><div class="line"><a name="l00060"></a><span class="lineno">   60</span>&#160;</div><div class="line"><a name="l00061"></a><span class="lineno">   61</span>&#160;        <span class="comment">//add the timer here</span></div><div class="line"><a name="l00062"></a><span class="lineno">   62</span>&#160;        <span class="keywordflow">if</span> (mpCAmSocketHandler-&gt;<a class="code" href="classam_1_1CAmSocketHandler.html#afe4e4806d91f9a4b3b1eb8a278f64cc9">addTimer</a>(timeout, &amp;<a class="code" href="classam_1_1CAmWatchdog.html#af60241c3ecfcf1f85ffcfb28cf026065">TimerCallback</a>, mHandle, NULL))</div><div class="line"><a name="l00063"></a><span class="lineno">   63</span>&#160;        {</div><div class="line"><a name="l00064"></a><span class="lineno">   64</span>&#160;            <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(<span class="stringliteral">&quot;CAmWatchdog::CAmWatchdog failed to add timer&quot;</span>);</div><div class="line"><a name="l00065"></a><span class="lineno">   65</span>&#160;            <span class="keywordflow">throw</span> std::runtime_error(<span class="stringliteral">&quot;CAmWatchdog::CAmWatchdog failed to add timer&quot;</span>);</div><div class="line"><a name="l00066"></a><span class="lineno">   66</span>&#160;        }</div><div class="line"><a name="l00067"></a><span class="lineno">   67</span>&#160;    }</div><div class="line"><a name="l00068"></a><span class="lineno">   68</span>&#160;</div><div class="line"><a name="l00069"></a><span class="lineno">   69</span>&#160;    <span class="keywordflow">else</span></div><div class="line"><a name="l00070"></a><span class="lineno">   70</span>&#160;    {</div><div class="line"><a name="l00071"></a><span class="lineno">   71</span>&#160;        <a class="code" href="namespaceam.html#a47d650dc91db97c1f9323b4ed5cf4fd6">logInfo</a>(<span class="stringliteral">&quot;CAmWatchdog::CAmWatchdog watchdog timeout was &quot;</span>, watchdogTimeout, <span class="stringliteral">&quot; museconds, no watchdog active&quot;</span>);</div><div class="line"><a name="l00072"></a><span class="lineno">   72</span>&#160;    }</div><div class="line"><a name="l00073"></a><span class="lineno">   73</span>&#160;}</div><div class="line"><a name="l00074"></a><span class="lineno">   74</span>&#160;</div><div class="line"><a name="l00075"></a><span class="lineno"><a class="line" href="classam_1_1CAmWatchdog.html#ac8adbc4a0dbf84f81eba5eb5e5fca33f">   75</a></span>&#160;<a class="code" href="classam_1_1CAmWatchdog.html#ac8adbc4a0dbf84f81eba5eb5e5fca33f">CAmWatchdog::~CAmWatchdog</a>()</div><div class="line"><a name="l00076"></a><span class="lineno">   76</span>&#160;{</div><div class="line"><a name="l00077"></a><span class="lineno">   77</span>&#160;    <span class="comment">//remove the timer again.</span></div><div class="line"><a name="l00078"></a><span class="lineno">   78</span>&#160;    <span class="keywordflow">if</span> (mHandle!=0)</div><div class="line"><a name="l00079"></a><span class="lineno">   79</span>&#160;        mpCAmSocketHandler-&gt;<a class="code" href="classam_1_1CAmSocketHandler.html#a7627416d3b2fd93baa84599b52691bec">removeTimer</a>(mHandle);</div><div class="line"><a name="l00080"></a><span class="lineno">   80</span>&#160;}</div><div class="line"><a name="l00081"></a><span class="lineno">   81</span>&#160;</div><div class="line"><a name="l00082"></a><span class="lineno"><a class="line" href="classam_1_1CAmWatchdog.html#aeb749571a8c560fba178b04071cf5279">   82</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classam_1_1CAmWatchdog.html#aeb749571a8c560fba178b04071cf5279">CAmWatchdog::timerCallback</a>(<a class="code" href="namespaceam.html#a47991fcc6785a5c97037b611e7f7e1a8">sh_timerHandle_t</a> handle, <span class="keywordtype">void</span>* userData)</div><div class="line"><a name="l00083"></a><span class="lineno">   83</span>&#160;{</div><div class="line"><a name="l00084"></a><span class="lineno">   84</span>&#160;    (void) userData;</div><div class="line"><a name="l00085"></a><span class="lineno">   85</span>&#160;    <span class="keywordtype">int</span> error(sd_notify(0, <span class="stringliteral">&quot;WATCHDOG=1&quot;</span>));</div><div class="line"><a name="l00086"></a><span class="lineno">   86</span>&#160;    <span class="keywordflow">if</span> (error &lt; 0)</div><div class="line"><a name="l00087"></a><span class="lineno">   87</span>&#160;    {</div><div class="line"><a name="l00088"></a><span class="lineno">   88</span>&#160;        <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(<span class="stringliteral">&quot;CAmWatchdog::timerCallback could not reset watchdog, error &quot;</span>, error);</div><div class="line"><a name="l00089"></a><span class="lineno">   89</span>&#160;        <span class="keywordflow">throw</span> std::runtime_error(<span class="stringliteral">&quot;CAmWatchdog::timerCallback could not reset watchdog&quot;</span>);</div><div class="line"><a name="l00090"></a><span class="lineno">   90</span>&#160;    }</div><div class="line"><a name="l00091"></a><span class="lineno">   91</span>&#160;</div><div class="line"><a name="l00092"></a><span class="lineno">   92</span>&#160;    mpCAmSocketHandler-&gt;<a class="code" href="classam_1_1CAmSocketHandler.html#a34f5a3d01d54f25eae224d5ca84f5a2a">restartTimer</a>(handle);</div><div class="line"><a name="l00093"></a><span class="lineno">   93</span>&#160;}</div><div class="line"><a name="l00094"></a><span class="lineno">   94</span>&#160;</div><div class="line"><a name="l00095"></a><span class="lineno"><a class="line" href="classam_1_1CAmWatchdog.html#a4379a7449325044199d4703a99039b9c">   95</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classam_1_1CAmWatchdog.html#a4379a7449325044199d4703a99039b9c">CAmWatchdog::startWatchdog</a>()</div><div class="line"><a name="l00096"></a><span class="lineno">   96</span>&#160;{</div><div class="line"><a name="l00097"></a><span class="lineno">   97</span>&#160;    <span class="keywordtype">int</span> error(sd_notify(0, <span class="stringliteral">&quot;READY=1&quot;</span>));</div><div class="line"><a name="l00098"></a><span class="lineno">   98</span>&#160;    <span class="keywordflow">if</span> (error &lt; 0)</div><div class="line"><a name="l00099"></a><span class="lineno">   99</span>&#160;    {</div><div class="line"><a name="l00100"></a><span class="lineno">  100</span>&#160;        <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(<span class="stringliteral">&quot;CAmWatchdog::startWatchdog could not start watchdog, error &quot;</span>, error);</div><div class="line"><a name="l00101"></a><span class="lineno">  101</span>&#160;        <span class="keywordflow">throw</span> std::runtime_error(<span class="stringliteral">&quot;CAmWatchdog::startWatchdog could not start watchdog&quot;</span>);</div><div class="line"><a name="l00102"></a><span class="lineno">  102</span>&#160;    }</div><div class="line"><a name="l00103"></a><span class="lineno">  103</span>&#160;    <a class="code" href="namespaceam.html#a47d650dc91db97c1f9323b4ed5cf4fd6">logInfo</a>(<span class="stringliteral">&quot;READY=1 was sent to systemd&quot;</span>);</div><div class="line"><a name="l00104"></a><span class="lineno">  104</span>&#160;}</div><div class="line"><a name="l00105"></a><span class="lineno">  105</span>&#160;</div><div class="line"><a name="l00106"></a><span class="lineno">  106</span>&#160;}</div><div class="line"><a name="l00107"></a><span class="lineno">  107</span>&#160;</div><div class="line"><a name="l00108"></a><span class="lineno">  108</span>&#160;<span class="comment">/* namespace am */</span></div><div class="ttc" id="namespaceam_html"><div class="ttname"><a href="namespaceam.html">am</a></div><div class="ttdoc">A Common-API wrapper class, which loads the common-api runtime and instantiates all necessary objects...</div><div class="ttdef"><b>Definition:</b> <a href="CAmCommandReceiver_8h_source.html#l00029">CAmCommandReceiver.h:29</a></div></div>
<div class="ttc" id="namespaceam_html_a47d650dc91db97c1f9323b4ed5cf4fd6"><div class="ttname"><a href="namespaceam.html#a47d650dc91db97c1f9323b4ed5cf4fd6">am::logInfo</a></div><div class="ttdeci">void logInfo(T value, TArgs...args)</div><div class="ttdoc">logs given values with infolevel with the default context </div><div class="ttdef"><b>Definition:</b> <a href="CAmDltWrapper_8h_source.html#l00420">CAmDltWrapper.h:420</a></div></div>
<div class="ttc" id="classam_1_1CAmSocketHandler_html_a34f5a3d01d54f25eae224d5ca84f5a2a"><div class="ttname"><a href="classam_1_1CAmSocketHandler.html#a34f5a3d01d54f25eae224d5ca84f5a2a">am::CAmSocketHandler::restartTimer</a></div><div class="ttdeci">am_Error_e restartTimer(const sh_timerHandle_t handle)</div><div class="ttdoc">restarts a timer with the original value </div><div class="ttdef"><b>Definition:</b> <a href="CAmSocketHandler_8cpp_source.html#l00720">CAmSocketHandler.cpp:720</a></div></div>
<div class="ttc" id="classam_1_1CAmSocketHandler_html"><div class="ttname"><a href="classam_1_1CAmSocketHandler.html">am::CAmSocketHandler</a></div><div class="ttdoc">The am::CAmSocketHandler implements a mainloop for the AudioManager. </div><div class="ttdef"><b>Definition:</b> <a href="CAmSocketHandler_8h_source.html#l00216">CAmSocketHandler.h:216</a></div></div>
<div class="ttc" id="classam_1_1CAmWatchdog_html"><div class="ttname"><a href="classam_1_1CAmWatchdog.html">am::CAmWatchdog</a></div><div class="ttdoc">Implements the watchdog of the AudioManager with the help of systemd. </div><div class="ttdef"><b>Definition:</b> <a href="CAmWatchdog_8h_source.html#l00035">CAmWatchdog.h:35</a></div></div>
<div class="ttc" id="CAmDltWrapper_8h_html"><div class="ttname"><a href="CAmDltWrapper_8h.html">CAmDltWrapper.h</a></div><div class="ttdoc">SPDX license identifier: MPL-2.0. </div></div>
<div class="ttc" id="CAmWatchdog_8h_html"><div class="ttname"><a href="CAmWatchdog_8h.html">CAmWatchdog.h</a></div><div class="ttdoc">SPDX license identifier: MPL-2.0. </div></div>
<div class="ttc" id="classam_1_1CAmSocketHandler_html_a7627416d3b2fd93baa84599b52691bec"><div class="ttname"><a href="classam_1_1CAmSocketHandler.html#a7627416d3b2fd93baa84599b52691bec">am::CAmSocketHandler::removeTimer</a></div><div class="ttdeci">am_Error_e removeTimer(const sh_timerHandle_t handle)</div><div class="ttdoc">removes a timer from the list of timers </div><div class="ttdef"><b>Definition:</b> <a href="CAmSocketHandler_8cpp_source.html#l00596">CAmSocketHandler.cpp:596</a></div></div>
<div class="ttc" id="classam_1_1CAmWatchdog_html_ac8adbc4a0dbf84f81eba5eb5e5fca33f"><div class="ttname"><a href="classam_1_1CAmWatchdog.html#ac8adbc4a0dbf84f81eba5eb5e5fca33f">am::CAmWatchdog::~CAmWatchdog</a></div><div class="ttdeci">virtual ~CAmWatchdog()</div><div class="ttdef"><b>Definition:</b> <a href="CAmWatchdog_8cpp_source.html#l00075">CAmWatchdog.cpp:75</a></div></div>
<div class="ttc" id="classam_1_1CAmWatchdog_html_ad4de61bd5653451dda216ec94a60e57f"><div class="ttname"><a href="classam_1_1CAmWatchdog.html#ad4de61bd5653451dda216ec94a60e57f">am::CAmWatchdog::CAmWatchdog</a></div><div class="ttdeci">CAmWatchdog(CAmSocketHandler *CAmSocketHandler)</div><div class="ttdef"><b>Definition:</b> <a href="CAmWatchdog_8cpp_source.html#l00035">CAmWatchdog.cpp:35</a></div></div>
<div class="ttc" id="classam_1_1CAmWatchdog_html_a4379a7449325044199d4703a99039b9c"><div class="ttname"><a href="classam_1_1CAmWatchdog.html#a4379a7449325044199d4703a99039b9c">am::CAmWatchdog::startWatchdog</a></div><div class="ttdeci">void startWatchdog()</div><div class="ttdoc">starts the watchdog by sending ready to systemD </div><div class="ttdef"><b>Definition:</b> <a href="CAmWatchdog_8cpp_source.html#l00095">CAmWatchdog.cpp:95</a></div></div>
<div class="ttc" id="namespaceam_html_ab00ba22db19413e2040c2ab246f220c6"><div class="ttname"><a href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">am::logError</a></div><div class="ttdeci">void logError(T value, TArgs...args)</div><div class="ttdoc">logs given values with errorlevel with the default context </div><div class="ttdef"><b>Definition:</b> <a href="CAmDltWrapper_8h_source.html#l00431">CAmDltWrapper.h:431</a></div></div>
<div class="ttc" id="classam_1_1CAmWatchdog_html_af60241c3ecfcf1f85ffcfb28cf026065"><div class="ttname"><a href="classam_1_1CAmWatchdog.html#af60241c3ecfcf1f85ffcfb28cf026065">am::CAmWatchdog::TimerCallback</a></div><div class="ttdeci">TAmShTimerCallBack&lt; CAmWatchdog &gt; TimerCallback</div><div class="ttdef"><b>Definition:</b> <a href="CAmWatchdog_8h_source.html#l00042">CAmWatchdog.h:42</a></div></div>
<div class="ttc" id="classam_1_1CAmWatchdog_html_aeb749571a8c560fba178b04071cf5279"><div class="ttname"><a href="classam_1_1CAmWatchdog.html#aeb749571a8c560fba178b04071cf5279">am::CAmWatchdog::timerCallback</a></div><div class="ttdeci">void timerCallback(sh_timerHandle_t handle, void *userData)</div><div class="ttdoc">the watchdog timer callback </div><div class="ttdef"><b>Definition:</b> <a href="CAmWatchdog_8cpp_source.html#l00082">CAmWatchdog.cpp:82</a></div></div>
<div class="ttc" id="namespaceam_html_a47991fcc6785a5c97037b611e7f7e1a8"><div class="ttname"><a href="namespaceam.html#a47991fcc6785a5c97037b611e7f7e1a8">am::sh_timerHandle_t</a></div><div class="ttdeci">sh_pollHandle_t sh_timerHandle_t</div><div class="ttdoc">this is a handle for a timer to be used with the SocketHandler </div><div class="ttdef"><b>Definition:</b> <a href="CAmSocketHandler_8h_source.html#l00052">CAmSocketHandler.h:52</a></div></div>
<div class="ttc" id="classam_1_1CAmSocketHandler_html_afe4e4806d91f9a4b3b1eb8a278f64cc9"><div class="ttname"><a href="classam_1_1CAmSocketHandler.html#afe4e4806d91f9a4b3b1eb8a278f64cc9">am::CAmSocketHandler::addTimer</a></div><div class="ttdeci">am_Error_e addTimer(const timespec &amp;timeouts, IAmShTimerCallBack *callback, sh_timerHandle_t &amp;handle, void *userData, const bool __attribute__((__unused__)) repeats=false)</div></div>
</div><!-- fragment --></div><!-- contents -->
</div><!-- doc-content -->
<!-- start footer part -->
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
  <ul>
    <li class="navelem"><a class="el" href="dir_789817cd9c9d85c1fb6b4cda55b71a5f.html">AudioManagerUtilities</a></li><li class="navelem"><a class="el" href="dir_2902e59c3e43e5b119a71402dd0eee5d.html">src</a></li><li class="navelem"><a class="el" href="CAmWatchdog_8cpp.html">CAmWatchdog.cpp</a></li>
    <li class="footer">Generated on Fri Feb 9 2018 14:50:29 for AudioManager by
    <a href="http://www.doxygen.org/index.html">
    <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.11 </li>
  </ul>
</div>
</body>
</html>