Question about which tools to use, bugs, the best way to implement a function, etc should go here. Don't forget to see if your question is answered in the wiki first! When in doubt post here.
Well, the $? was the right thing to do in the tutorial, because the command was to replace object files in a linker archive - in that case, you only need the newer object files, not all of them.
You copy&pasted that into a linker command... which requires a somewhat different handling.
I also found that in order to compile the test drivers, the Makefile dependency needed to be removed and the compiler flags rewritten.
Why would you need to remove the Makefile dependency? The variable $< is replaced with the first dependency; whether or not you have "Makefile" as second dependency shouldn't make a difference for the command (and, as I said, results in the test drivers being rebuilt when the Makefile changes). Works fine for me.
I don't see what you mean with "rewritten compiler flags".
Every good solution is obvious once you've found it.
I just realized that the $? copy&paste-error was mine, sorry.
Civillian wrote:For me, it gave a "no rule to make target." That version of the makefile is in the first $?-related post.
Well, it shouldn't, and it doesn't for me using a Makefilevery similar to the one in the Wiki, is all I can say.
Solar wrote:I don't see what you mean with "rewritten compiler flags".
This is probably not the best way to do it, but I get linker warnings and corrupted executables if I don't.
Ah, I see - your test drivers needing different CFLAGS than the kernel proper. No surprise there. I'd daresay quite some portion of kernel code can't be tested in user space.
Every good solution is obvious once you've found it.
Solar wrote:Well, it shouldn't, and it doesn't for me using a Makefilevery similar to the one in the Wiki, is all I can say.
Rhetorical question: why did I put "Makefile" in a file named "GNUmakefile"?
Solar wrote:Ah, I see - your test drivers needing different CFLAGS than the kernel proper. No surprise there. I'd daresay quite some portion of kernel code can't be tested in user space.
I wonder if I should put back -fno-builtin.
As for untestable portions, I'm not worried. All my tests so far have failed: they didn't find any bugs.
Civillian wrote:Rhetorical question: why did I put "Makefile" in a file named "GNUmakefile"?
The question might be rhetoric, but I don't have the slightest idea what you're hinting at. (Edit: Clarified via PM.)
Civillian wrote:As for untestable portions, I'm not worried. All my tests so far have failed: they didn't find any bugs.
That's not a failure, that's a success in confidence. Also, if some future change breaks compatibility, you will be immediately aware of it. Moreover, if a bug is reported (or discovered), your existing test framework should make it easy to trigger the bug in test (instead of live running of your kernel, which is much harder to debug).
Every good solution is obvious once you've found it.
The makefile is nearing completion. Now I increased its verbosity, because I'm uncomfortable with "no news".
The final thing missing would be NASM-generated dependencies. But that can wait...
For my current needs, the makefile is complete, unless anyone spots bugs.
Otherwise, thank you Solar, and Cognition, for your contributions.
See you all later.
Edit:
Rewritten the check section. In my test drivers, I usually include more than one test, so the exit code in case of failure may be greater than 1.