-
-
Notifications
You must be signed in to change notification settings - Fork 76
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
GNU remake 4.3 #51
Comments
@boretom The branch remake-4-3 has been created and is a branch of make-4-3 which is a copy of the GNU Make 4.3 sources. However I added a couple of But please build off of the Looking at this, I think it will not be as easy as you seem to think. What's gone on between 4.2 and 4.3 is that a more conventional build organization has occurred (which of course is very welcome). But that by necessity adds a bit of upheaval. Some things to keep in mind. First , Second, although GNU Make code has always been a bit back-level in terms of using best practice C style and conventions, resist the temptation to try to fix this up. Eventually GNU Make does make forward progress, albeit at a snails pace, and invariablly the GNU make fixups will be different from those in you've decided on in Of course if the back-leveness is in strictly remake code, such as in the debugger, then by all means go and fix up my crappy C code. |
@rocky thanks for the detailed info. I'll work on it as you recommend, working off branch remake-4-3 and so on. I highly doubt that rebase will work, but worth a shot :). I realized that I had a quick look at the diff from the latest make 4.2.93 and make HEAD. Which is not the right tag/commit since remake is based on make 4.2.1. But I'll follow you recommendation and do my best :) Did you have a chance to try to verify the 10x speedup for compiling the kernel sources with make 4.3? I'll surely will looking into it, it seems like a good indicator if I f*ed up or not. |
The article on GNU make 4.3 and GNU/Linux: https://www.phoronix.com/scan.php?page=news_item&px=Linux-Pipe-Parallel-Job-Opt No, I haven't verified the speedup results. The part of the article I find amusing:
Yep, 3 years between resolution of a problem for a feature and when people can start to use it. That matches my experience too. And you say you are concerned about the possibility of a two week delay? With respect to rebasing... Git is awesome and a really powerfull tool, but it helps if you keep in mind what's going on so you can use git to its full advantage. The remake git repostiory does not aim to capture the full GNU Make history. If you are interested in GNU Make version-control history, use GNU make's version control for that. Also I am not interested in tracking the full remake version control history across major GNU Make/remake releases. When you go from remake-4-2 to remake-4-3, the only thing that matters is the entire set of changes as one big patch from the most recent remake-4-2 to get to the most-recent remake-4-3. Of course, if you are interested in the ins-an-outs of how you got from make-4-2 to remake-4-2 you can use the git history within the remake-4-2 branch. Having that history also be in the remake-4-3 branch is not interesting. Using this as a guide, the first thing to note is that the file moves between GNU Make 4.2 and GNU make 4.3 such as from Therefore a simple rebase isn't going to be able track this. However what you can do and what I'd do is take the patch and manually edit file names so that the diff works on the moved file, e.g. |
Thanks for the link to Linus' article, seems I won't be able to test it easily with my 6 core laptop :) tracking full history: When it is working I'll great one big diff/commit, does make sense. |
Exciting! |
Turns out there are more stopchar_map character and that let remake fail pretty nice. Thanks to gdb that's solved. Todo: ./configure maintainer mode, make check, make install and the docs are taken from make instead of remake (Plus what I forgot :) ) branch remake-4-3-tk in case you're bored or curious :). |
WOW! I cloned and tried this. All of the basic functionality (tracing, the debugger, profiling) seems to work! As you reported in the "Todo" above, there were failures in trying to run the tests Many thanks! |
Hey, I'm happy 4.3 appears to work that smooth, I only had to apply the diff. I will look a the remaining issues and report back. |
That's good to hear. I guess this is the approach then to use in the future as well. The branch organization and method of patching may seem obvious now how to do, but it in fact took a while (and lots of painful merges after the few times a GNU make release came out). So I am also happy to hear that this aspect has improved and is not as painful as it was in the past. |
You have definitely done a great job and have lots patients. Extending existing, "old" software seems sometimes to be quite mess. While starting to fix The particular case I'm talking about is in if (exit_sig == 0)
err_with_stack(p_call_stack,
_("%s[%s] error %d%s"),
pre, f->name, exit_code, post);
else
err_with_stack(p_call_stack, "%s[%s] %s%s%s",
pre, f->name, strsignal (exit_sig), dump, post); make, if (exit_sig == 0)
error (NILF, l + INTSTR_LENGTH,
_("%s[%s: %s] Error %d%s"), pre, nm, f->name, exit_code, post);
else
{
const char *s = strsignal (exit_sig);
error (NILF, l + strlen (s) + strlen (dump),
"%s[%s: %s] %s%s%s", pre, nm, f->name, s, dump, post);
} That seems to be a difference since at least 4.2.Would you be ok if I use the Edit: Add the output difference Output of tests git:(remake-4-3-tk) ✗ ../../make/make -f work/features/errors.mk.2 one
./foobarbazbozblat xx yy
make: ./foobarbazbozblat: No such file or directory
make: [work/features/errors.mk.2:2: one] Error 127 (ignored) Output of tests git:(remake-4-3-tk) ✗ ../make -f work/features/errors.mk.2 one
./foobarbazbozblat xx yy
make: ./foobarbazbozblat: No such file or directory
work/features/errors.mk.2:2: [one] error 127 (ignored) |
Interesting. I guess it is okay to go with It seems between 4.1 and 4.3
So if I have this right, they have expanded the stuff in square brackets to include position information. I guess this makes sense, coming from where they do, in that it expands upon the format they had before. The reason I chose the format that I did, is that it matches
(In In other words I was trying to be as unoriginal as possible. But I have found every project feels that their format is clearly superior in some way and has to be different. This causes problems for tools that want to parse the output. I guess though that such tools will already have to have some upheaval because GNU Make 4.3 is different from GNU Make 4.1. (I just checked how GNU Emacs 26.2 tries to interpret that kind of GNU Make error in a "compilation" buffer, and basically it doesn't.) The question then becomes should I don't have a strong feeling either way, since each has its downside. But this is the kind of stuff I am referring to when I write about limiting the fixups in GNU Make because eventually it will get around to doing something, minimally, and in a different way that is incompatible with remake. |
I did look into it a bit more and came to agree with you. My original idea was that future patches for |
The |
Awesome! In my opinion some of the GNU make tests are a bit fragile. Basically, I look at the failures and if they indicate something serious I investigate more. If not, I'll leave with a "FIXME" to indicate I might deal with later, or give a heads up to someone down the line that things might be flaky, as seemed to happen here. I looked a little at the I noticed that the person who was doing Amiga support, Aaron "Optimizer" Digulla (see README.Amiga), seems to have cleaned up his code so the changes are isolated and not a holistic mess the way VMS When OS-specfiic code goes in cleanly, and there is someone who will responsibly test the code, then it's okay for the OS go be in there. So down the line we might contact to see if he's interested. What do you think? I see a typo in my Make target comment in to top-level Makefile.am
I was looking at that because I would like to add a comment to the "check_local" target to indicate it does (and to suggest it can be used). In general when fixing up the code helps me figure out the code, such as adding comments to the Of course, all of this little stuff might be done after the code is merged in. As it is so close, I am getting anxious for this to go in. So hurry up! :-) In sum great work! |
About the GNU make tests : I haven't looked at the failed output-sync tests too much. They add sleep to make sure the timing adds up, surely a bit fragile :). unittest failure : I don't understand right away what changed for unittest between 4.2.1 and 4.3. Do you have an idea what do add to unittest/Makefile.am? Amiga Port/Aaron Digulla : I would absolutely contact him, maybe he is up to it, my fellow Swiss - not that I know him :) typo #: : Is corrected cleanup maintMakefile : To be honest I haven't look at maintaince mode yet and don't feel I know enough about it to know what to remove. But I'm totally for cleanup what's possible! So hurry up : I do my best :) |
Commit f3ee274 gets a little closer to getting this working again. Now that there is
|
BTW when I run
What this generally means is that you have Perl code like: my $answer = ...; # line 25
...
my $answer = ...; # line 39 and this should be instead: my $answer = ...; # line 25
$answer = ... ; # line 39 |
Good morning, You see my lack of mastery of Perl (and lots of other topics) :/ ... I corrected the multiple declarations of `$myanswers. Regarding Not working with the latest commit 3728539 are Maybe you have an idea for these two issues, especially regaring |
As for |
Sounds good to me thumbsup |
Actually, if you want to handle CI testing (inside remake) that'd be fine with me. I kind of hate doing that kind of stuff when it comes down to the mechanics, although I like benefits of CI. |
I haven't done any CI related stuff, so it depends on how fast you want it done :). Would have to read into a bit. |
For CI, I am happy to wait :-) |
Hehe, you hate it that much :) ... I'll look into it. Does everything works for you with your changes? On a sidemark: compiling on macOS fails (now the same as make 4.3) and also on FreeBSD. |
But since you took the initiative to undertake this, I'm just waiting on you to decide whether it's okay to merge. (In my opinion though right now is fine.) |
It's absolutely ok to merge and continue with PRs. The move to version 4.3 doesn't have to appear all perfect in one commit. Shall I rebase so that it only is one commit? |
Up to you. If you think there is value in preserving various steps, to guide/remind folks in the future then several steps makes sense and you could decide what to squash. But other than that I don't have an opinion. In addition, it might be cool to write down say on the wiki the steps that you took while it is fresh in your mind as to what to do. I'll start such a thing for the things I remember, and copy some information from here. It had occurred to me that that in addition to the one big patch from make 4.2-last to remake-4.2 last, it might be useful to consult make-4.2-last make-4.3 to help understand what's gone on. However since you did the work, you'd be in a better position to know that. |
@boretom https://github.com/rocky/remake/wiki/Updating-for-a-major-GNU-Make-release has what I think may be the useful information here to guide someone. Please add or correct this as you see fit. |
I didn't put much effort into the commit message tbh so they are of no great use. One big commit it shall be. Updating the wiki is certainly something I'll do and taking into account the commit message. Regarding comparing make-4.2-last to make-4.3: For some parts I did that to see why a patch failed. Let's see if I can still remember details. The PR is created and CI failed (not suprise I assume) |
Question regarding how to proceed with fixes where I'm not sure if my approach is right. Example: Compilng remake on macOS fails because Do I open an issue to discuss stuff like that before submitting a PR or create an PR right away and discuss it in the PR? |
Do it in the PR. I would like to be as unbureuacratic as possible here. As for clang vs gcc, configure should be detecting stuff like this and adjusting. I never had a problem in remake before with macOS. So consult how it's done in remake 4.2. I seem to recall there I had to make a change in C flags, at least to get CircleCI to work. |
@boretom now that you have access to work in remake, please move over the new branches to remake. Thanks. |
@rocky sure, I'll move the fix branches over. And regarding clang vs gcc: -C & -Werror was also removed from MAKE_FLAGS in remake-4-2. |
@rocky I do have a more general question: The time I have available varies a lot, sometimes I won't have time for stuff like this for a week or more. How is that handled in general? How would I know the urgency of a topic/issue? How to you syncronize in such cases? For the next two weeks I will have about 3 or 4 days during which I'll have plenty of time. So getting to know and make CI will take some time and I don't know if that will take too long or not for you. |
In my experience in the open-source world, people just come and go as they please and rarely give notice. I am always prepared to take over where others leave off. If you don't get to CI, or leave it unfinished, I can take over.
Dunno. Make a suggestion that works for you. |
Release 4.3 is out . |
In issue #40 @boretom reports:
@boretom thanks, the project can wait a week or two.
Note that regarding make 4.3, I recently read in the news (and can't find it now) that Linus Torvalds has found a way to take advantange of the speedup that was proposed over a year ago in 4.3 to parallel builds. And with this, there can be something like a 10x speedup in building the Linux Kernel on multicore machines by using the
--jobs
option along with his customization in the kernel that recently went out.As a result, the prioritiy of getting this done has increased.
Another (somewhat accidental) benefit of remake over GNU make is that since it is not in the critical path of a lot of things, OS's that have 4.2 (or 3.x) can also install remake and that gives them an easy way to instal a newer GNU make to try it out without impacting existing programs.
So I had planned on doing this, but I'd rather if someone else did. That way, there are two people in the world that may understand this. And in the end I know the code will get much much better. (See my comment make previously somewhere else about making a lot of mistakes).
However... painful experience has shown that the right way to do this is to make two new branches,
make-4-3
with the GNU make source, and another branch from thatremake-4-3
. And then with the 'diff"s frommake-4-2 HEAD
toremake-4-2 HEAD
, "rebase" them onto theremake-4-3
branch. In other words, do not build off of the exisitingremake-4-2
branch atHEAD
.In the last paragraph, I put "rebase" in quotes because I don't necessariliy mean using
git rebase
. For such largish changes that might be too difficult. Of course, It is a possibility if that helps, but again; I just don't think it will, but I could be wrong.So shortly I will be creating the two branches to work off of, although I'll leave the work from the branch from
remake-4-3
to a fully featured remake 4.3 up to you.The text was updated successfully, but these errors were encountered: