Skip to content
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 6 additions & 2 deletions libc/config/baremetal/aarch64/entrypoints.txt
Original file line number Diff line number Diff line change
Expand Up @@ -123,18 +123,22 @@ set(TARGET_LIBC_ENTRYPOINTS
libc.src.inttypes.strtoumax

# stdio.h entrypoints
libc.src.stdio.asprintf
libc.src.stdio.getchar
libc.src.stdio.printf
libc.src.stdio.putchar
libc.src.stdio.puts
libc.src.stdio.remove
libc.src.stdio.scanf
libc.src.stdio.snprintf
libc.src.stdio.sprintf
libc.src.stdio.asprintf
libc.src.stdio.sscanf
libc.src.stdio.vasprintf
libc.src.stdio.vprintf
libc.src.stdio.vscanf
libc.src.stdio.vsnprintf
libc.src.stdio.vsprintf
libc.src.stdio.vasprintf
libc.src.stdio.vsscanf

# stdbit.h entrypoints
libc.src.stdbit.stdc_bit_ceil_uc
Expand Down
8 changes: 6 additions & 2 deletions libc/config/baremetal/arm/entrypoints.txt
Original file line number Diff line number Diff line change
Expand Up @@ -123,18 +123,22 @@ set(TARGET_LIBC_ENTRYPOINTS
libc.src.inttypes.strtoumax

# stdio.h entrypoints
libc.src.stdio.asprintf
libc.src.stdio.getchar
libc.src.stdio.printf
libc.src.stdio.putchar
libc.src.stdio.puts
libc.src.stdio.remove
libc.src.stdio.scanf
libc.src.stdio.snprintf
libc.src.stdio.sprintf
libc.src.stdio.asprintf
libc.src.stdio.sscanf
libc.src.stdio.vasprintf
libc.src.stdio.vprintf
libc.src.stdio.vscanf
libc.src.stdio.vsnprintf
libc.src.stdio.vsprintf
libc.src.stdio.vasprintf
libc.src.stdio.vsscanf

# stdbit.h entrypoints
libc.src.stdbit.stdc_bit_ceil_uc
Expand Down
8 changes: 6 additions & 2 deletions libc/config/baremetal/riscv/entrypoints.txt
Original file line number Diff line number Diff line change
Expand Up @@ -119,18 +119,22 @@ set(TARGET_LIBC_ENTRYPOINTS
libc.src.inttypes.strtoumax

# stdio.h entrypoints
libc.src.stdio.asprintf
libc.src.stdio.getchar
libc.src.stdio.printf
libc.src.stdio.putchar
libc.src.stdio.puts
libc.src.stdio.remove
libc.src.stdio.scanf
libc.src.stdio.snprintf
libc.src.stdio.sprintf
libc.src.stdio.asprintf
libc.src.stdio.sscanf
libc.src.stdio.vasprintf
libc.src.stdio.vprintf
libc.src.stdio.vscanf
libc.src.stdio.vsnprintf
libc.src.stdio.vsprintf
libc.src.stdio.vasprintf
libc.src.stdio.vsscanf

# stdbit.h entrypoints
libc.src.stdbit.stdc_bit_ceil_uc
Expand Down
58 changes: 4 additions & 54 deletions libc/src/stdio/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -95,20 +95,6 @@ add_entrypoint_object(
libc.src.__support.File.platform_file
)

list(APPEND scanf_deps
libc.src.__support.arg_list
libc.src.stdio.scanf_core.vfscanf_internal
libc.hdr.types.FILE
)

if(LLVM_LIBC_FULL_BUILD AND NOT LIBC_TARGET_OS_IS_GPU)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this not needed anymore?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It was moved to libc/src/stdio/generic/CMakeLists.txt.

list(APPEND scanf_deps
libc.src.__support.File.file
libc.src.__support.File.platform_file
libc.src.__support.File.platform_stdin
)
endif()

add_entrypoint_object(
sscanf
SRCS
Expand All @@ -133,46 +119,6 @@ add_entrypoint_object(
libc.src.stdio.scanf_core.string_reader
)

add_entrypoint_object(
fscanf
SRCS
fscanf.cpp
HDRS
fscanf.h
DEPENDS
${scanf_deps}
)

add_entrypoint_object(
vfscanf
SRCS
vfscanf.cpp
HDRS
vfscanf.h
DEPENDS
${scanf_deps}
)

add_entrypoint_object(
scanf
SRCS
scanf.cpp
HDRS
scanf.h
DEPENDS
${scanf_deps}
)

add_entrypoint_object(
vscanf
SRCS
vscanf.cpp
HDRS
vscanf.h
DEPENDS
${scanf_deps}
)

add_entrypoint_object(
sprintf
SRCS
Expand Down Expand Up @@ -295,8 +241,12 @@ add_stdio_entrypoint_object(getchar)
add_stdio_entrypoint_object(getchar_unlocked)
add_stdio_entrypoint_object(fgets)
add_stdio_entrypoint_object(ungetc)
add_stdio_entrypoint_object(scanf)
add_stdio_entrypoint_object(fscanf)
add_stdio_entrypoint_object(stdin)
add_stdio_entrypoint_object(stdout)
add_stdio_entrypoint_object(stderr)
add_stdio_entrypoint_object(vprintf)
add_stdio_entrypoint_object(vfprintf)
add_stdio_entrypoint_object(vscanf)
add_stdio_entrypoint_object(vfscanf)
26 changes: 26 additions & 0 deletions libc/src/stdio/baremetal/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,19 @@ add_entrypoint_object(
libc.src.__support.CPP.string_view
)

add_entrypoint_object(
scanf
SRCS
scanf.cpp
HDRS
../scanf.h
DEPENDS
libc.src.stdio.scanf_core.scanf_main
libc.src.stdio.scanf_core.reader
libc.src.__support.arg_list
libc.src.__support.OSUtil.osutil
)

add_entrypoint_object(
vprintf
SRCS
Expand All @@ -67,3 +80,16 @@ add_entrypoint_object(
libc.src.__support.arg_list
libc.src.__support.OSUtil.osutil
)

add_entrypoint_object(
vscanf
SRCS
vscanf.cpp
HDRS
../vscanf.h
DEPENDS
libc.src.stdio.scanf_core.scanf_main
libc.src.stdio.scanf_core.reader
libc.src.__support.arg_list
libc.src.__support.OSUtil.osutil
)
2 changes: 1 addition & 1 deletion libc/src/stdio/baremetal/getchar.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ namespace LIBC_NAMESPACE_DECL {
LLVM_LIBC_FUNCTION(int, getchar, ()) {
char buf[1];
auto result = read_from_stdin(buf, sizeof(buf));
if (result < 0)
if (result <= 0)
return EOF;
return buf[0];
}
Expand Down
52 changes: 52 additions & 0 deletions libc/src/stdio/baremetal/scanf.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
//===-- Implementation of scanf ---------------------------------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//

#include "src/stdio/scanf.h"

#include "hdr/stdio_macros.h"
#include "src/__support/OSUtil/io.h"
#include "src/__support/arg_list.h"
#include "src/__support/macros/config.h"
#include "src/stdio/scanf_core/reader.h"
#include "src/stdio/scanf_core/scanf_main.h"

#include <stdarg.h>

namespace LIBC_NAMESPACE_DECL {

namespace {

struct StreamReader : scanf_core::Reader<StreamReader> {
LIBC_INLINE char getc() {
char buf[1];
auto result = read_from_stdin(buf, sizeof(buf));
if (result <= 0)
return EOF;
return buf[0];
}
LIBC_INLINE void ungetc(int) {}
};
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

would it make sense to have a shared header that defines this? Similar to fvscanf_internal.h

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Done, I moved the implementation to scanf_internal.h.


} // namespace

LLVM_LIBC_FUNCTION(int, scanf, (const char *__restrict format, ...)) {
va_list vlist;
va_start(vlist, format);
internal::ArgList args(vlist); // This holder class allows for easier copying
// and pointer semantics, as well as handling
// destruction automatically.
va_end(vlist);

StreamReader reader;
int retval = scanf_core::scanf_main(&reader, format, args);
// This is done to avoid including stdio.h in the internals. On most systems
// EOF is -1, so this will be transformed into just "return retval".
return (retval == -1) ? EOF : retval;
}

} // namespace LIBC_NAMESPACE_DECL
51 changes: 51 additions & 0 deletions libc/src/stdio/baremetal/vscanf.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
//===-- Implementation of vscanf --------------------------------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//

#include "src/stdio/vscanf.h"

#include "hdr/stdio_macros.h"
#include "src/__support/OSUtil/io.h"
#include "src/__support/arg_list.h"
#include "src/__support/macros/config.h"
#include "src/stdio/scanf_core/reader.h"
#include "src/stdio/scanf_core/scanf_main.h"

#include <stdarg.h>

namespace LIBC_NAMESPACE_DECL {

namespace {

struct StreamReader : scanf_core::Reader<StreamReader> {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nit: this should be named BaremetalReader or something other than StreamReader to keep it clear which is which.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Done, I went with StdinReader.

LIBC_INLINE char getc() {
char buf[1];
auto result = read_from_stdin(buf, sizeof(buf));
if (result <= 0)
return EOF;
return buf[0];
}
LIBC_INLINE void ungetc(int) {}
};

} // namespace

LLVM_LIBC_FUNCTION(int, vscanf,
(const char *__restrict format, va_list vlist)) {
internal::ArgList args(vlist); // This holder class allows for easier copying
// and pointer semantics, as well as handling
// destruction automatically.
va_end(vlist);

StreamReader reader;
int retval = scanf_core::scanf_main(&reader, format, args);
// This is done to avoid including stdio.h in the internals. On most systems
// EOF is -1, so this will be transformed into just "return retval".
return (retval == -1) ? EOF : retval;
}

} // namespace LIBC_NAMESPACE_DECL
54 changes: 54 additions & 0 deletions libc/src/stdio/generic/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -425,6 +425,60 @@ add_entrypoint_object(
${fprintf_deps}
)

list(APPEND scanf_deps
libc.src.__support.arg_list
libc.src.stdio.scanf_core.vfscanf_internal
libc.hdr.types.FILE
)

if(LLVM_LIBC_FULL_BUILD AND NOT LIBC_TARGET_OS_IS_GPU)
list(APPEND scanf_deps
libc.src.__support.File.file
libc.src.__support.File.platform_file
libc.src.__support.File.platform_stdin
)
endif()

add_entrypoint_object(
fscanf
SRCS
fscanf.cpp
HDRS
../fscanf.h
DEPENDS
${scanf_deps}
)

add_entrypoint_object(
vfscanf
SRCS
vfscanf.cpp
HDRS
../vfscanf.h
DEPENDS
${scanf_deps}
)

add_entrypoint_object(
scanf
SRCS
scanf.cpp
HDRS
../scanf.h
DEPENDS
${scanf_deps}
)

add_entrypoint_object(
vscanf
SRCS
vscanf.cpp
HDRS
../vscanf.h
DEPENDS
${scanf_deps}
)

add_entrypoint_object(
fgets
SRCS
Expand Down
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
9 changes: 0 additions & 9 deletions libc/src/stdio/scanf_core/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -54,13 +54,6 @@ add_header_library(
libc.src.__support.CPP.string_view
)

if(NOT(TARGET libc.src.__support.File.file) AND LLVM_LIBC_FULL_BUILD AND
(NOT LIBC_TARGET_OS_IS_GPU))
# Not all platforms have a file implementation. If file is unvailable, and a
# full build is requested, then we must skip all file based scanf sections.
return()
endif()

add_header_library(
scanf_main
HDRS
Expand All @@ -71,7 +64,6 @@ add_header_library(
.converter
.core_structs
libc.src.__support.arg_list
${file_deps}
${use_system_file}
)

Expand Down Expand Up @@ -112,7 +104,6 @@ add_header_library(
libc.src.__support.CPP.limits
libc.src.__support.char_vector
libc.src.__support.str_to_float
${file_deps}
${use_system_file}
)

Expand Down
Loading