196 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			196 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/**************************************************************************/
 | 
						|
/*!
 | 
						|
    @file     printf_retarget.c
 | 
						|
    @author   hathach (tinyusb.org)
 | 
						|
 | 
						|
    @section LICENSE
 | 
						|
 | 
						|
    Software License Agreement (BSD License)
 | 
						|
 | 
						|
    Copyright (c) 2013, hathach (tinyusb.org)
 | 
						|
    All rights reserved.
 | 
						|
 | 
						|
    Redistribution and use in source and binary forms, with or without
 | 
						|
    modification, are permitted provided that the following conditions are met:
 | 
						|
    1. Redistributions of source code must retain the above copyright
 | 
						|
    notice, this list of conditions and the following disclaimer.
 | 
						|
    2. Redistributions in binary form must reproduce the above copyright
 | 
						|
    notice, this list of conditions and the following disclaimer in the
 | 
						|
    documentation and/or other materials provided with the distribution.
 | 
						|
    3. Neither the name of the copyright holders nor the
 | 
						|
    names of its contributors may be used to endorse or promote products
 | 
						|
    derived from this software without specific prior written permission.
 | 
						|
 | 
						|
    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ''AS IS'' AND ANY
 | 
						|
    EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 | 
						|
    WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | 
						|
    DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE FOR ANY
 | 
						|
    DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 | 
						|
    INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 | 
						|
    LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION HOWEVER CAUSED AND
 | 
						|
    ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 | 
						|
    INCLUDING NEGLIGENCE OR OTHERWISE ARISING IN ANY WAY OUT OF THE USE OF THIS
 | 
						|
    SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | 
						|
 | 
						|
    This file is part of the tinyusb stack.
 | 
						|
*/
 | 
						|
/**************************************************************************/
 | 
						|
 | 
						|
#include "board.h"
 | 
						|
 | 
						|
#if CFG_PRINTF_TARGET != PRINTF_TARGET_SEMIHOST
 | 
						|
 | 
						|
#if CFG_PRINTF_TARGET == PRINTF_TARGET_UART
 | 
						|
  #define retarget_getchar()     board_uart_getchar()
 | 
						|
  #define retarget_putchar(c)    board_uart_putchar(c);
 | 
						|
#elif CFG_PRINTF_TARGET == PRINTF_TARGET_SWO
 | 
						|
  volatile int32_t ITM_RxBuffer;  // keil variable to read from SWO
 | 
						|
	#define retarget_getchar()     ITM_ReceiveChar()
 | 
						|
	#define retarget_putchar(c)    ITM_SendChar(c)
 | 
						|
#else
 | 
						|
	#error Target is not implemented yet
 | 
						|
#endif
 | 
						|
 | 
						|
//--------------------------------------------------------------------+
 | 
						|
// LPCXPRESSO / RED SUITE
 | 
						|
//--------------------------------------------------------------------+
 | 
						|
#if defined __CODE_RED
 | 
						|
 | 
						|
#if CFG_PRINTF_TARGET == PRINTF_TARGET_SWO
 | 
						|
  #error author does not know how to retarget SWO with lpcxpresso/red-suite
 | 
						|
#endif
 | 
						|
 | 
						|
// Called by bottom level of printf routine within RedLib C library to write
 | 
						|
// a character. With the default semihosting stub, this would write the character
 | 
						|
// to the debugger console window . But this version writes
 | 
						|
// the character to the UART.
 | 
						|
int __sys_write (int iFileHandle, char *buf, int length)
 | 
						|
{
 | 
						|
  (void) iFileHandle;
 | 
						|
 | 
						|
  for (int i=0; i<length; i++)
 | 
						|
  {
 | 
						|
    if (buf[i] == '\n') retarget_putchar('\r');
 | 
						|
 | 
						|
    retarget_putchar( buf[i] );
 | 
						|
  }
 | 
						|
 | 
						|
  return length;
 | 
						|
}
 | 
						|
 | 
						|
// Called by bottom level of scanf routine within RedLib C library to read
 | 
						|
// a character. With the default semihosting stub, this would read the character
 | 
						|
// from the debugger console window (which acts as stdin). But this version reads
 | 
						|
// the character from the UART.
 | 
						|
int __sys_readc (void)
 | 
						|
{
 | 
						|
	return (int) retarget_getchar();
 | 
						|
}
 | 
						|
 | 
						|
#elif defined __SES_ARM && 0
 | 
						|
#include <stdarg.h>
 | 
						|
#include <stdio.h>
 | 
						|
#include "__libc.h"
 | 
						|
 | 
						|
int printf(const char *fmt,...) {
 | 
						|
  char buffer[128];
 | 
						|
  va_list args;
 | 
						|
  va_start (args, fmt);
 | 
						|
  int n = vsnprintf(buffer, sizeof(buffer), fmt, args);
 | 
						|
  
 | 
						|
  for(int i=0; i < n; i++)
 | 
						|
  {
 | 
						|
    retarget_putchar( buffer[i] );
 | 
						|
  }
 | 
						|
 | 
						|
  va_end(args);
 | 
						|
  return n;
 | 
						|
}
 | 
						|
 | 
						|
int __putchar(int ch, __printf_tag_ptr ctx) 
 | 
						|
{
 | 
						|
  (void)ctx;
 | 
						|
  retarget_putchar( (uint8_t) ch );
 | 
						|
  return 1;
 | 
						|
}
 | 
						|
 | 
						|
int __getchar()
 | 
						|
{
 | 
						|
  return retarget_getchar();
 | 
						|
}
 | 
						|
 | 
						|
//--------------------------------------------------------------------+
 | 
						|
// KEIL
 | 
						|
//--------------------------------------------------------------------+
 | 
						|
#elif defined __CC_ARM // keil
 | 
						|
 | 
						|
struct __FILE {
 | 
						|
  uint32_t handle;
 | 
						|
};
 | 
						|
 | 
						|
void _ttywrch(int ch)
 | 
						|
{
 | 
						|
  if ( ch == '\n' ) retarget_putchar('\r');
 | 
						|
 | 
						|
  retarget_putchar(ch);
 | 
						|
}
 | 
						|
 | 
						|
int fgetc(FILE *f)
 | 
						|
{
 | 
						|
  return retarget_getchar();
 | 
						|
}
 | 
						|
 | 
						|
int fputc(int ch, FILE *f)
 | 
						|
{
 | 
						|
  _ttywrch(ch);
 | 
						|
  return ch;
 | 
						|
}
 | 
						|
 | 
						|
//--------------------------------------------------------------------+
 | 
						|
// IAR
 | 
						|
//--------------------------------------------------------------------+
 | 
						|
#elif defined __ICCARM__ // TODO could not able to retarget to UART with IAR
 | 
						|
 | 
						|
#if CFG_PRINTF_TARGET == PRINTF_TARGET_UART
 | 
						|
#include <stddef.h>
 | 
						|
 | 
						|
size_t __write(int handle, const unsigned char *buf, size_t length)
 | 
						|
{
 | 
						|
  /* Check for the command to flush all handles */
 | 
						|
  if (handle == -1) return 0;
 | 
						|
 | 
						|
  /* Check for stdout and stderr (only necessary if FILE descriptors are enabled.) */
 | 
						|
  if (handle != 1 && handle != 2) return -1;
 | 
						|
 | 
						|
  for (size_t i=0; i<length; i++)
 | 
						|
  {
 | 
						|
    if (buf[i] == '\n') retarget_putchar('\r');
 | 
						|
 | 
						|
    retarget_putchar( buf[i] );
 | 
						|
  }
 | 
						|
 | 
						|
  return length;
 | 
						|
}
 | 
						|
 | 
						|
size_t __read(int handle, unsigned char *buf, size_t bufSize)
 | 
						|
{
 | 
						|
  /* Check for stdin (only necessary if FILE descriptors are enabled) */
 | 
						|
  if (handle != 0) return -1;
 | 
						|
 | 
						|
  size_t i;
 | 
						|
  for (i=0; i<bufSize; i++)
 | 
						|
  {
 | 
						|
    uint8_t ch = board_uart_getchar();
 | 
						|
    if (ch == 0) break;
 | 
						|
    buf[i] = ch;
 | 
						|
  }
 | 
						|
 | 
						|
  return i;
 | 
						|
}
 | 
						|
 | 
						|
#endif
 | 
						|
 | 
						|
#endif
 | 
						|
 | 
						|
#endif // CFG_PRINTF_TARGET != PRINTF_TARGET_SEMIHOST
 |