kopia lustrzana https://github.com/RPiks/pico-hf-oscillator
88 wiersze
2.7 KiB
C
88 wiersze
2.7 KiB
C
![]() |
///////////////////////////////////////////////////////////////////////////////
|
||
|
//
|
||
|
// Roman Piksaykin [piksaykin@gmail.com], R2BDY
|
||
|
// https://www.qrz.com/db/r2bdy
|
||
|
//
|
||
|
///////////////////////////////////////////////////////////////////////////////
|
||
|
//
|
||
|
//
|
||
|
// logutils.h - A set of utilities for logging/debugging.
|
||
|
//
|
||
|
// DESCRIPTION
|
||
|
// -
|
||
|
//
|
||
|
// HOWTOSTART
|
||
|
// -
|
||
|
//
|
||
|
// PLATFORM
|
||
|
// Raspberry Pi pico.
|
||
|
//
|
||
|
// REVISION HISTORY
|
||
|
// -
|
||
|
//
|
||
|
// PROJECT PAGE
|
||
|
// https://github.com/RPiks/pico-WSPR-tx
|
||
|
//
|
||
|
// LICENCE
|
||
|
// MIT License (http://www.opensource.org/licenses/mit-license.php)
|
||
|
//
|
||
|
// Copyright (c) 2023 by Roman Piksaykin
|
||
|
//
|
||
|
// Permission is hereby granted, free of charge,to any person obtaining a copy
|
||
|
// of this software and associated documentation files (the Software), to deal
|
||
|
// in the Software without restriction,including without limitation the rights
|
||
|
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||
|
// copies of the Software, and to permit persons to whom the Software is
|
||
|
// furnished to do so, subject to the following conditions:
|
||
|
//
|
||
|
// The above copyright notice and this permission notice shall be included in
|
||
|
// all copies or substantial portions of the Software.
|
||
|
//
|
||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||
|
// LIABILITY,WHETHER IN AN ACTION OF CONTRACT,TORT OR OTHERWISE, ARISING FROM,
|
||
|
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||
|
// THE SOFTWARE.
|
||
|
///////////////////////////////////////////////////////////////////////////////
|
||
|
#include <stdint.h>
|
||
|
#include <stdio.h>
|
||
|
#include <stdlib.h>
|
||
|
#include <stdarg.h>
|
||
|
|
||
|
#include "hardware/clocks.h"
|
||
|
#include "pico/stdlib.h"
|
||
|
|
||
|
void StampPrintf(const char* pformat, ...)
|
||
|
{
|
||
|
static uint32_t sTick = 0;
|
||
|
if(!sTick)
|
||
|
{
|
||
|
stdio_init_all();
|
||
|
}
|
||
|
|
||
|
uint64_t tm_us = to_us_since_boot(get_absolute_time());
|
||
|
|
||
|
const uint32_t tm_day = (uint32_t)(tm_us / 86400000000ULL);
|
||
|
tm_us -= (uint64_t)tm_day * 86400000000ULL;
|
||
|
|
||
|
const uint32_t tm_hour = (uint32_t)(tm_us / 3600000000ULL);
|
||
|
tm_us -= (uint64_t)tm_hour * 3600000000ULL;
|
||
|
|
||
|
const uint32_t tm_min = (uint32_t)(tm_us / 60000000ULL);
|
||
|
tm_us -= (uint64_t)tm_min * 60000000ULL;
|
||
|
|
||
|
const uint32_t tm_sec = (uint32_t)(tm_us / 1000000ULL);
|
||
|
tm_us -= (uint64_t)tm_sec * 1000000ULL;
|
||
|
|
||
|
printf("%02lud%02lu:%02lu:%02lu.%06llu [%04lu] ", tm_day, tm_hour, tm_min, tm_sec, tm_us, sTick++);
|
||
|
|
||
|
va_list argptr;
|
||
|
va_start(argptr, pformat);
|
||
|
vprintf(pformat, argptr);
|
||
|
va_end(argptr);
|
||
|
|
||
|
printf("\n");
|
||
|
}
|