The MASM Forum

General => The Campus => Topic started by: markallyn on October 27, 2021, 05:45:58 AM

Title: In what library is printf found in VS 2022?
Post by: markallyn on October 27, 2021, 05:45:58 AM
Hello everyone,

I've searched lots of places, wanting to avoid cluttering up the forum with stupid questions, but with no luck.  So here's my stupid question:  having just downloaded VS 2022 and trying to run a simple program calling printf  it seems that msvcrt.lib no longer contains the function.  So, could someone kindly tell me where printf now resides in VS 2022?

Mark Allyn
Title: Re: In what library is printf found in VS 2022?
Post by: jj2007 on October 27, 2021, 06:20:19 AM
Have fun (https://docs.microsoft.com/en-us/cpp/porting/upgrade-your-code-to-the-universal-crt?view=msvc-160)
Title: Re: In what library is printf found in VS 2022?
Post by: markallyn on October 27, 2021, 08:16:35 AM
Good afternoon, Jochen,

The source code I'm using does an "includelib ucrt.lib", but it doesn't seem to "know" a naked printf.  I've looked at ucrt.lib and the references to printf in that file are prefixed by some new __imp .... code.  Is there something I should be adding to the front end of my printf in order for the proto and call statements to work?

But, anyway, thanks for the help.  I'll have to experiment a bit, it appears.

Mark
Title: Re: In what library is printf found in VS 2022?
Post by: hutch-- on October 27, 2021, 09:10:05 AM
Mark,

You go to the DLL file and see what is in it. If its there, you should know how to call it. These are the joys of starting to use newer code sources, you have to find every thing yourself.
Title: Re: In what library is printf found in VS 2022?
Post by: markallyn on October 27, 2021, 10:14:46 AM
Good evening, Hutch,

I was telling myself precisely that, your bit about the joys of starting to use new code sources, as I dumped and peeled thru ucrt.lib and ucrtbase.dll.  Says I : Son, this is a really great way to see what's inside these fellers.  Always wanted to know.  I'm still peeling ....  And garnering great joy.

Regards,
Mark
Title: Re: In what library is printf found in VS 2022?
Post by: mineiro on October 27, 2021, 10:40:58 AM
Functions inside library files have a prefix (__imp_) before function name as you noted, , __imp_ExitProcess, __imp_MessageBoxExA, ... .
You can use this as a skeleton to your tests, it's necessary to create a library (.def,externdef) file to print.
test64.asm

OPTION DOTNAME
option casemap:none

includelib kernel32.lib
EXTERNDEF ExitProcess: PROC     ;proc or proto, I suppose proc is better
                                ;__imp_ExitProcess inside kernel32.lib
includelib user32.lib
EXTERNDEF MessageBoxExA: PROTO  ;__imp_MessageBoxExA inside user32.lib

;ALIAS <MessageBoxExA>=<MessageBox>
MessageBox TEXTEQU <MessageBoxExA>

public start
;public MainCRTStartup

.data
    caption db 'testing!!!', 0
    message db 'If works!', 0

.code
start:
    sub    rsp,28h      ; shadow space, align stack
    mov    rcx, 0       ; hWnd = HWND_DESKTOP
    lea    rdx, message ; LPCSTR lpText
    lea    r8,  caption ; LPCSTR lpCaption
    mov    r9d, 0       ; uType = MB_OK
    call   MessageBox   ; call MessageBox API function
    mov    ecx, eax     ; uExitCode = MessageBox(...)
    call   ExitProcess

ALIAS <mainCRTStartup>=<start>         ;;console
;ALIAS <WinMainCRTStartup>=<start>      ;;windows
end


user32.def

LIBRARY user32.dll
EXPORTS
MessageBoxExA


kernel32.def

LIBRARY kernel32.dll
EXPORTS
ExitProcess


doit.bat

lib /MACHINE:AMD64 /DEF:kernel32.def
lib /MACHINE:AMD64 /DEF:user32.def
ml64 /c test64.asm
link /SUBSYSTEM:CONSOLE /machine:AMD64 test64.obj
Title: Re: In what library is printf found in VS 2022?
Post by: jj2007 on October 27, 2021, 11:14:11 AM
Quote from: markallyn on October 27, 2021, 10:14:46 AMas I dumped and peeled thru ucrt.lib and ucrtbase.dll

On my Win7-64, there is no printf in C:\Windows\System32\ucrtbase.dll, unfortunately.
Title: Re: In what library is printf found in VS 2022?
Post by: hutch-- on October 27, 2021, 11:56:28 AM
It should be in "msvcrt.lib".
Title: Re: In what library is printf found in VS 2022?
Post by: TimoVJL on October 27, 2021, 08:46:22 PM
in ucrt printf is just an inline function and since msvc 2015 it was removed from msvcrt.lib_Check_return_opt_
_CRT_STDIO_INLINE int __CRTDECL printf(
    _In_z_ _Printf_format_string_ char const* const _Format,
    ...)
#if defined _NO_CRT_STDIO_INLINE
;
#else
{
    int _Result;
    va_list _ArgList;
    __crt_va_start(_ArgList, _Format);
    _Result = _vfprintf_l(stdout, _Format, NULL, _ArgList);
    __crt_va_end(_ArgList);
    return _Result;
}
#endif
Title: Re: In what library is printf found in VS 2022?
Post by: jcfuller on October 27, 2021, 08:51:13 PM
Does this help?
https://gist.github.com/njsmith/08b1e52b65ea90427bfd

James
Title: Re: In what library is printf found in VS 2022?
Post by: mineiro on October 27, 2021, 09:25:02 PM
You can try "Dependency Walker" program to check.
https://www.dependencywalker.com/

I stopped in windows XP, but I remember that most dll functions are based in ntdll.dll or use some variations of functions inside this dll.
Title: Re: In what library is printf found in VS 2022?
Post by: markallyn on October 28, 2021, 12:06:40 AM
Good morning, Hutch, mineiro, JJ, JCFuller,TIMOVJL,

Hutch's masm32/lib64/msvcrt.lib does indeed contain __imp_printf.  None of the other msvcrt's I have examined in windows kits or VS 2022 have this function.  This is consistent with JJ's observation in his most recent response.  TIMOVJL:  I don't "get" what you mean when you refer to "inlining"--not your fault, I'm just too much a beginner.  Perhaps you could enlarge for my benefit? 

In the meantime, I notice that four more responses to my query have come in.  I'll check them out.

Thanks to all of you for taking the trouble to look this issue over.

Regards,
Mark
Title: Re: In what library is printf found in VS 2022?
Post by: TimoVJL on October 28, 2021, 12:19:09 AM
Quote from: markallyn on October 28, 2021, 12:06:40 AM
  TIMOVJL:  I don't "get" what you mean when you refer to "inlining"--not your fault, I'm just too much a beginner.  Perhaps you could enlarge for my benefit? 
It is similar like masm32 macros, that inserts some longer code.
Title: Re: In what library is printf found in VS 2022?
Post by: jj2007 on October 28, 2021, 12:41:02 AM
Actually, I wouldn't touch that UCRT crap with a bargepole. It's so full of bugs and errors that they had to set up an Urgent Community Response Team (https://www.provide.org.uk/service/esdaar/) :cool:
Title: Re: In what library is printf found in VS 2022?
Post by: nidud on October 28, 2021, 01:29:19 AM
deleted
Title: Re: In what library is printf found in VS 2022?
Post by: markallyn on October 28, 2021, 05:18:36 AM
Good afternoon, NIDUD,

Well, as is said, "you cracked the code".  Yes, pun intended.  I had got as far as putting libcmt.lib into my source, but didn't follow up with the legacy stdio definitions includelib. 

I do get a warning LNK4210 when building.  The warning reads something like:" .CRT section exists; may be unhandled static initializers or terminators."  Don't know what to do with that warning other than ignore it.

Anyway, it runs.

Very gratefully yours, and thanks to others who helped,

Mark



Title: Re: In what library is printf found in VS 2022?
Post by: markallyn on October 28, 2021, 09:19:46 AM
Good evening,

As Nidud makes clear including legacy_stdio_definitions provides the ability to link against previous msvcrt.lib (and I suppose others as well) functions that are no longer contained in recent editions of VS (such as my 2022) functions we know and love, such as printf.  Out of curiosity I wrote a tiny c program that calls printf and looked at the assembly program to see how cl.exe handles printf in my VS 2022 edition.  The answer is that it includes libcmt.lib just as Nidud did.  But, instead of legacy_stdio_definitions cl.exe includes oldnames.lib.  Oldnames has many familiar looking msvcrt.lib functions as well, but instead of __imp_printf, for example, it has __imp_cprintf.  The "c" prefix is what seems to distinguish printf as defined in legacy_stdio_definitions where it is __imp_printf.  I don't know what the purpose of the "c" prefix is--perhaps others who've looked at this with wiser eyes can say.

Regards,
Mark
Title: Re: In what library is printf found in VS 2022?
Post by: TimoVJL on October 28, 2021, 07:27:50 PM
This example is using ucrtbase.dll with def / lib from it.
typedef struct FILE FILE;
#undef stdin
#undef stdout
#undef stderr
//__declspec(dllimport)
extern __declspec(dllimport) FILE* __cdecl __acrt_iob_func(unsigned);
#define stdin  (__acrt_iob_func(0))
#define stdout (__acrt_iob_func(1))
#define stderr (__acrt_iob_func(2))

#pragma comment (lib, "ucrtbase.lib")

__declspec(dllimport)  int __cdecl __stdio_common_vfprintf(long long, FILE*, char const* , int, va_list);

int printf(const char * format, ...)
{
int ret;
va_list vl;
va_start(vl, format);
ret = __stdio_common_vfprintf(0, stdout, format, 0, vl);
va_end(vl);
return ret;
}
Pelles C codeprintf:
  [0000000000000000] 48894C2408                   mov               qword ptr [rsp+8],rcx
  [0000000000000005] 4889542410                   mov               qword ptr [rsp+10],rdx
  [000000000000000A] 4C89442418                   mov               qword ptr [rsp+18],r8
  [000000000000000F] 4C894C2420                   mov               qword ptr [rsp+20],r9
  [0000000000000014] 4883EC38                     sub               rsp,38
31: {
32: int ret;
33: va_list vl;
34: va_start(vl, format);
  [0000000000000018] 488D442448                   lea               rax,[rsp+48]
  [000000000000001D] 4889442428                   mov               qword ptr [rsp+28],rax
35: ret = __stdio_common_vfprintf(0, stdout, format, 0, vl);
  [0000000000000022] B901000000                   mov               ecx,1
  [0000000000000027] FF1500000000                 call              qword ptr [__imp___acrt_iob_func]
  [000000000000002D] 488B542428                   mov               rdx,qword ptr [rsp+28]
  [0000000000000032] 4889542420                   mov               qword ptr [rsp+20],rdx
  [0000000000000037] B900000000                   mov               ecx,0
  [000000000000003C] 4889C2                       mov               rdx,rax
  [000000000000003F] 4C8B442440                   mov               r8,qword ptr [rsp+40]
  [0000000000000044] 41B900000000                 mov               r9d,0
  [000000000000004A] FF1500000000                 call              qword ptr [__imp___stdio_common_vfprintf]
  [0000000000000050] 89442434                     mov               dword ptr [rsp+34],eax
36: va_end(vl);
  [0000000000000054] 48C744242800000000           mov               qword ptr [rsp+28],0
37: return ret;
  [000000000000005D] 8B442434                     mov               eax,dword ptr [rsp+34]
  [0000000000000061] 4883C438                     add               rsp,38
  [0000000000000065] C3                           ret               
38: }

EDIT: __declspec(dllimport) inserted
Title: Re: In what library is printf found in VS 2022?
Post by: markallyn on October 29, 2021, 09:37:11 AM
Good evening, TimoVJL,

I apologize for getting back to you so slowly.  You have done a fine tutorial in the code you submitted.  I owe it to you to study it more carefully.  I will do this tomorrow and get back to you.

For the moment, what I can say is that in several of the lines in PODUMP you employ [rsp+34] and similar stack variables I did not follow why the indexes were what they were.  I understand the [rsp +8] ... [rsp + 20] in principle but there is no notation indicating these are hex values.  I assume they must be.  But, the others are mysterious.

Thanks for your help.

Mark Allyn
Title: Re: In what library is printf found in VS 2022?
Post by: mineiro on October 29, 2021, 12:25:17 PM
Quote from: markallyn on October 29, 2021, 09:37:11 AM
PODUMP you employ [rsp+34] and similar stack variables I did not follow why the indexes were what they were. 
dwords with 8 bytes alignment!?
Title: Re: In what library is printf found in VS 2022?
Post by: markallyn on October 29, 2021, 12:36:59 PM
Good evening, Mineiro,

You may be right about dwords and 8-byte alignment.  But, I thought the stack was supposed to be 16-byte aligned, not eight.  Perhaps this is the thinking of yet another dopey newcomer?....  Let us see what TIMOVJL has to say.

And I do owe him some reasonable feedback on what he sent in his post.  I have this ethic which says that every person who takes the trouble to try to help me with this stuff deserves a thorough look-through.

Mark
Title: Re: In what library is printf found in VS 2022?
Post by: jj2007 on October 29, 2021, 12:57:03 PM
Quote from: markallyn on October 29, 2021, 12:36:59 PMI thought the stack was supposed to be 16-byte aligned, not eight.

Indeed, the stack is 16-byte aligned. When calling a proc, the return address gets pushed, so on entry of the proc it is 8-byte aligned. Typically, at this point a stack frame will be generated, which restores the 16-byte alignment:
push rbp
lea rbp,[rsp-30]
Title: Re: In what library is printf found in VS 2022?
Post by: TimoVJL on October 29, 2021, 03:52:29 PM
Yes, podump uses hex-base
Same with Zydis
printf:
00000000  48894C2408               mov qword ptr [rsp+8h], rcx
00000005  4889542410               mov qword ptr [rsp+10h], rdx
0000000A  4C89442418               mov qword ptr [rsp+18h], r8
0000000F  4C894C2420               mov qword ptr [rsp+20h], r9
00000014  4883EC38                 sub rsp, 38h
00000018  488D442448               lea rax, [rsp+48h]
0000001D  4889442428               mov qword ptr [rsp+28h], rax
00000022  B901000000               mov ecx, 1h
00000027  FF1500000000             call qword ptr [__imp___acrt_iob_func]
0000002D  488B542428               mov rdx, qword ptr [rsp+28h]
00000032  4889542420               mov qword ptr [rsp+20h], rdx
00000037  B900000000               mov ecx, 0h
0000003C  4889C2                   mov rdx, rax
0000003F  4C8B442440               mov r8, qword ptr [rsp+40h]
00000044  41B900000000             mov r9d, 0h
0000004A  FF1500000000             call qword ptr [__imp___stdio_common_vfprintf]
00000050  89442434                 mov dword ptr [rsp+34h], eax
00000054  48C744242800000000       mov qword ptr [rsp+28h], 0h
0000005D  8B442434                 mov eax, dword ptr [rsp+34h]
00000061  4883C438                 add rsp, 38h
00000065  C3                       ret


msvc ucrt.lib was used in msvc 2019 example and that lib uses forwanders.
_printf:
00000000  55                       push ebp
00000001  8BEC                     mov ebp, esp
00000003  83EC08                   sub esp, 8h
00000006  8D450C                   lea eax, [ebp+Ch]
00000009  8945FC                   mov dword ptr [ebp-4h], eax
0000000C  8B4DFC                   mov ecx, dword ptr [ebp-4h]
0000000F  51                       push ecx
00000010  6A00                     push 0h
00000012  8B5508                   mov edx, dword ptr [ebp+8h]
00000015  52                       push edx
00000016  6A01                     push 1h
00000018  FF1500000000             call dword ptr [__imp____acrt_iob_func]
0000001E  83C404                   add esp, 4h
00000021  50                       push eax
00000022  6A00                     push 0h
00000024  6A00                     push 0h
00000026  FF1500000000             call dword ptr [__imp____stdio_common_vfprintf]
0000002C  83C418                   add esp, 18h
0000002F  8945F8                   mov dword ptr [ebp-8h], eax
00000032  C745FC00000000           mov dword ptr [ebp-4h], 0h
00000039  8B45F8                   mov eax, dword ptr [ebp-8h]
0000003C  8BE5                     mov esp, ebp
0000003E  5D                       pop ebp
0000003F  C3                       ret
printf:
00000000  48894C2408               mov qword ptr [rsp+8h], rcx
00000005  4889542410               mov qword ptr [rsp+10h], rdx
0000000A  4C89442418               mov qword ptr [rsp+18h], r8
0000000F  4C894C2420               mov qword ptr [rsp+20h], r9
00000014  4883EC48                 sub rsp, 48h
00000018  488D442458               lea rax, [rsp+58h]
0000001D  4889442438               mov qword ptr [rsp+38h], rax
00000022  B901000000               mov ecx, 1h
00000027  FF1500000000             call qword ptr [__imp___acrt_iob_func]
0000002D  488B4C2438               mov rcx, qword ptr [rsp+38h]
00000032  48894C2420               mov qword ptr [rsp+20h], rcx
00000037  4533C9                   xor r9d, r9d
0000003A  4C8B442450               mov r8, qword ptr [rsp+50h]
0000003F  488BD0                   mov rdx, rax
00000042  33C9                     xor ecx, ecx
00000044  FF1500000000             call qword ptr [__imp___stdio_common_vfprintf]
0000004A  89442430                 mov dword ptr [rsp+30h], eax
0000004E  48C744243800000000       mov qword ptr [rsp+38h], 0h
00000057  8B442430                 mov eax, dword ptr [rsp+30h]
0000005B  4883C448                 add rsp, 48h
0000005F  C3                       ret
Title: Re: In what library is printf found in VS 2022?
Post by: hutch-- on October 30, 2021, 02:42:55 AM
Mark,

"printf" is contained in MSVCRT.DLL.


; ¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤

    include \masm32\include64\masm64rt.inc

;     externdef __imp_printf:PPROC     ; prototyped in MSVCRT.INC
;     vc_printf equ <__imp_printf>

    .code

; ¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤

entry_point proc

    invoke vc_printf,cfm$("Decimals: %d %ld\n"), 2022, 650000

    waitkey
    .exit

entry_point endp

; ¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤

    end
Title: Re: In what library is printf found in VS 2022?
Post by: hutch-- on October 30, 2021, 03:13:40 AM
Here is a variation that emulated the C "printf" with a macro.

; ¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤

    include \masm32\include64\masm64rt.inc

    printf MACRO quoted,args:VARARG
      invoke vc_printf,cfm$(quoted),args
    ENDM

    .code

; ¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤

entry_point proc

    printf "Decimals: %d %ld\n", 2022, 650000;

    waitkey
    .exit

entry_point endp

; ¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤¤

    end
Title: Re: In what library is printf found in VS 2022?
Post by: markallyn on October 30, 2021, 06:47:49 AM
Good afternoon, JJ and Hutch,

Hutch:  I didn;t post the source code I was using when I originated this thread.  But, I wasn't using ../masm32/lib64/msvcrt.lib.  I later checked and you are quite right that that version of msvcrt.lib does for sure contain the printf function as does the .dll.  As near as I can tell recent versions of visual studio (2015, 2017, 2019, and 2022) do not contain printf.  I was surprised by this.  Your macro is quite nice, by the way, and I think I'll use it going forward, if you don't mind.

JJ:  Part of my problem was not realizing that PODUMP was putting out hex characters as TIMOVJL points out.  My bad:  I should have figured this out.  And of course there is the business about return address.  You may find this nearly comic, or ridiculous, or shameful even, but I had never thought about the fact that on entry the rsp always ended with a "8" and not "0".  I had carelessly overlooked this when using a debugger. 

Still grappling with TIMOVJL's programs.

Regards,
Mark
Title: Re: In what library is printf found in VS 2022?
Post by: hutch-- on October 30, 2021, 09:50:19 AM
Hi Mark,

What you look for is what is in the system DLLs, MSVCRT has long been an OS component so you can safely use it without having scoure around later DLLs. You in fact may find plenty of useful stuff in the ucrtbase.dll and possibly the ucrtcase_clr0400.dll and you can use Pelle's tools to get a list of its content.
Title: Re: In what library is printf found in VS 2022?
Post by: TimoVJL on October 31, 2021, 11:41:06 PM
Hopefully people test ucrt and give us their opinions where it's good and what they find.
Those who analyze ms ucrt libs might see odd things like weird forwanding, and why ?
Title: Re: In what library is printf found in VS 2022?
Post by: jj2007 on November 01, 2021, 02:05:19 AM
Quote from: TimoVJL on October 31, 2021, 11:41:06 PMThose who analyze ms ucrt libs might see odd things like weird forwanding, and why ?

For many years we have seen weird forwarding in our debuggers:

769A110C  /$-/EB 05         jmp short <jmp.&API-MS-Win-Core-SysInfo- ; Jump to KERNELBASE.GetTickCount

I guess the whole ucrt.lib (or ucrt.dll) is just another wrapper :cool:
Title: Re: In what library is printf found in VS 2022?
Post by: nidud on November 01, 2021, 03:00:57 AM
deleted