/* ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio. This file is part of ChibiOS. ChibiOS is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. ChibiOS is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ /** * @file chdebug.c * @brief Debug support code. * * @addtogroup checks_assertions * @details Debug APIs and services: * - Runtime system state and call protocol check. The following * panic messages can be generated: * - SV#1, misplaced @p chSysDisable(). * - Called from an ISR. * - Called from a critical zone. * . * - SV#2, misplaced @p chSysSuspend() * - Called from an ISR. * - Called from a critical zone. * . * - SV#3, misplaced @p chSysEnable(). * - Called from an ISR. * - Called from a critical zone. * . * - SV#4, misplaced @p chSysLock(). * - Called from an ISR. * - Called from a critical zone. * . * - SV#5, misplaced @p chSysUnlock(). * - Called from an ISR. * - Not called from a critical zone. * . * - SV#6, misplaced @p chSysLockFromISR(). * - Not called from an ISR. * - Called from a critical zone. * . * - SV#7, misplaced @p chSysUnlockFromISR(). * - Not called from an ISR. * - Not called from a critical zone. * . * - SV#8, misplaced @p CH_IRQ_PROLOGUE(). * - Not called at ISR begin. * - Called from a critical zone. * . * - SV#9, misplaced @p CH_IRQ_EPILOGUE(). * - @p CH_IRQ_PROLOGUE() missing. * - Not called at ISR end. * - Called from a critical zone. * . * - SV#10, misplaced I-class function. * - I-class function not called from within a critical zone. * . * - SV#11, misplaced S-class function. * - S-class function not called from within a critical zone. * - Called from an ISR. * . * - Parameters check. * - Kernel assertions. * . * @note Stack checks are not implemented in this module but in the port * layer in an architecture-dependent way. * @{ */ #include "ch.h" /*===========================================================================*/ /* Module local definitions. */ /*===========================================================================*/ /*===========================================================================*/ /* Module exported variables. */ /*===========================================================================*/ /*===========================================================================*/ /* Module local types. */ /*===========================================================================*/ /*===========================================================================*/ /* Module local variables. */ /*===========================================================================*/ /*===========================================================================*/ /* Module local functions. */ /*===========================================================================*/ /*===========================================================================*/ /* Module exported functions. */ /*===========================================================================*/ #if (CH_DBG_SYSTEM_STATE_CHECK == TRUE) || defined(__DOXYGEN__) /** * @brief Guard code for @p chSysDisable(). * * @notapi */ void _dbg_check_disable(void) { if ((ch.dbg.isr_cnt != (cnt_t)0) || (ch.dbg.lock_cnt != (cnt_t)0)) { chSysHalt("SV#1"); } } /** * @brief Guard code for @p chSysSuspend(). * * @notapi */ void _dbg_check_suspend(void) { if ((ch.dbg.isr_cnt != (cnt_t)0) || (ch.dbg.lock_cnt != (cnt_t)0)) { chSysHalt("SV#2"); } } /** * @brief Guard code for @p chSysEnable(). * * @notapi */ void _dbg_check_enable(void) { if ((ch.dbg.isr_cnt != (cnt_t)0) || (ch.dbg.lock_cnt != (cnt_t)0)) { chSysHalt("SV#3"); } } /** * @brief Guard code for @p chSysLock(). * * @notapi */
.. _30second:

Client playback: a 30 second example
====================================

My local cafe is serviced by a rickety and unreliable wireless network,
generously sponsored with ratepayers' money by our city council. After
connecting, you  are redirected to an SSL-protected page that prompts you for a
username and password. Once you've entered your details, you are free to enjoy
the intermittent dropouts, treacle-like speeds and incorrectly configured
transparent proxy.

I tend to automate this kind of thing at the first opportunity, on the theory
that time spent now will be more than made up in the long run. In this case, I
might use Firebug_ to ferret out the form post
parameters and target URL, then fire up an editor to write a little script
using Python's urllib_ to simulate a submission.
That's a lot of futzing about. With mitmproxy we can do the job
in literally 30 seconds, without having to worry about any of the details.
Here's how.

1. Run mitmdump to record our HTTP conversation to a file.
----------------------------------------------------------

>>> mitmdump -w wireless-login

2. Point your browser at the mitmdump instance.
-----------------------------------------------

I use a tiny Firefox addon called `Toggle Proxy`_ to switch quickly to and from mitmproxy.
I'm assuming you've already :ref:`configured
your browser with mitmproxy's SSL certificate
authority <certinstall>`.

3. Log in as usual.
-------------------

And that's it! You now have a serialized version of the login process in the
file wireless-login, and you can replay it at any time like this:

>>> mitmdump -c wireless-login

Embellishments
--------------

We're really done at this point, but there are a couple of embellishments we
could make if we wanted. I use wicd_ to
automatically join wireless networks I frequent, and it lets me specify a
command to run after connecting. I used the client replay command above and
voila! - totally hands-free wireless network startup.

We might also want to prune requests that download CSS, JS, images and so
forth. These add only a few moments to the time it takes to replay, but they're
not really needed and I somehow feel compelled to trim them anyway. So, we fire up
the mitmproxy console tool on our serialized conversation, like so:

>>> mitmproxy -r wireless-login

We can now go through and manually delete (using the :kbd:`d` keyboard shortcut)
everything we want to trim. When we're done, we use :kbd:`w` to save the
conversation back to the file.

.. _Firebug: https://getfirebug.com/
.. _urllib: https://docs.python.org/library/urllib.html
.. _Toggle Proxy: https://addons.mozilla.org/en-us/firefox/addon/toggle-proxy-51740/
.. _wicd: https://launchpad.net/wicd