Gentoo Forums
Gentoo Forums
Gentoo Forums
Quick Search: in
No need for schedulers?
View unanswered posts
View posts from last 24 hours

Goto page 1, 2  Next  
Reply to topic    Gentoo Forums Forum Index Gentoo Chat
View previous topic :: View next topic  
Author Message
Gentoopc
Guru
Guru


Joined: 25 Dec 2017
Posts: 386

PostPosted: Sun Jan 12, 2025 8:31 am    Post subject: No need for schedulers? Reply with quote

Split from "CONFIG_SCHED_AUTOGROUP question". --Zucca

pietinger wrote:
von_kossa wrote:
2. Should CONFIG_SCHED_AUTOGROUP be enabled in 2025 or is there som caveat?

Yes. If you check the configuration of our Gentoo distribution kernel you will see it is enabled.

(I recommend it also here: https://wiki.gentoo.org/wiki/User:Pietinger/Experimental/Manual_Configuring_Current_Kernel#General_setup )


Guys, all this does not work well. Scheduling is very complex, it is carried out both in the Linux kernel and in the CPU. In this case, another scheduler is needed, which will regulate the work of all schedulers. Maybe it would even be possible to make an intelligent scheduler based on a cut-down GPT, the processor has an NPU, but that's not all. But if we had 6000 CUDA cores like on the GPU, or even 20000, then there would be no need for schedulers. There would be no queues. A real-time kernel on the GPU would make life on the Gentoo distribution very interesting. These are unlimited possibilities, which, unfortunately, we will not be given.
Back to top
View user's profile Send private message
Hu
Administrator
Administrator


Joined: 06 Mar 2007
Posts: 23020

PostPosted: Sun Jan 12, 2025 3:37 pm    Post subject: Reply with quote

Yes, if we had unlimited resources so that nothing needed to wait, we would have no need to schedule anything. We do not have unlimited resources, and on most systems, processes need to wait their turn. The kernel's scheduler tries its best to do the most good with the resources available. Part of that is allocating as little time to the scheduler itself as possible, since time spent making a decision about what to run is time not spent actually running anything the user wants done. Are you really suggesting that we use a Generative Predictive Text model, which is infamous not just for its mistakes but for its extremely high resource requirements, to make decisions that need to be made accurately, cheaply, and quickly?
Back to top
View user's profile Send private message
pingtoo
Veteran
Veteran


Joined: 10 Sep 2021
Posts: 1408
Location: Richmond Hill, Canada

PostPosted: Sun Jan 12, 2025 4:04 pm    Post subject: Reply with quote

Conceptually I agree with Gentoopc. It would be nice that linux kernel can utilise every available resource on the box (NPU/GPU etc...). Kernel offload task on to NPU/GPU would be very nice.

However I think current technology are limited in sense that the time passing data between CPU and NPU/GPU would be too long. so doing offload don't benefit for performance wise.

I also agree with Hu's point about using Generative Prediction text model for calculate process scheduler is way too expensive (resources and times wise) so it is not worthy.
Back to top
View user's profile Send private message
Gentoopc
Guru
Guru


Joined: 25 Dec 2017
Posts: 386

PostPosted: Mon Jan 13, 2025 3:05 am    Post subject: Reply with quote

Hu wrote:
and on most systems, processes need to wait their turn. as little time to the scheduler itself as possible, since time spent making a decision about what to run is time not


Guys, this should be changed because there is a strong reason for this. Many processes simply cannot wait for their turn. In a system that will work on important objects, this is exactly the role that the Linux kernel was given, so in such a system, processes cannot be killed or not wait for their turn, because the result of these processes may be needed by other processes so that they can complete. Now I will try to say the main thing

we need to run two functions in parallel

Code:
 
foo();
foo1();



this will be impossible on the CPU because the code is executed line by line. first foo() will be called; then foo1(); to solve this problem we need a new programming language and changes to the CPU components, but no one will do this, it is expensive and you are right when you said that you and we do not have such an opportunity. then we need to use what we have. guys, you understand, I do not suggest inventing something, I suggest using what already exists. and from what is available today, the GPU is well suited to solving this problem. there is already a programming language for the GPU, that is, there is nothing to invent. and you will be able to run functions in parallel, and therefore you will be able to do things that were previously inaccessible. for example, you will be able to get a snapshot of the entire structure at one moment. now the structure needs to be traversed recursively or in a cycle. The GPU provides a different approach. everything can change. and the main thing is that nothing needs to be invented, everything is already there.


Last edited by Gentoopc on Mon Jan 13, 2025 3:34 am; edited 2 times in total
Back to top
View user's profile Send private message
Hu
Administrator
Administrator


Joined: 06 Mar 2007
Posts: 23020

PostPosted: Mon Jan 13, 2025 3:14 am    Post subject: Reply with quote

As I said in the part you did not quote, yes, it would be very convenient if everyone had such powerful systems that there was always a CPU available to run any new process that wants a timeslice, and sufficient free RAM that we never need to page out any process. Most people cannot afford the cost in money or power to maintain such a massively over-powerful system, and so get by on systems that use a scheduler that does the best it can with the resources available to it. Outside of certain safety-critical systems, requiring a process to wait its turn causes no real harm.

It's easy to find things that you wish would be different. Do you have a workable plan for how we make such a change?
Back to top
View user's profile Send private message
Gentoopc
Guru
Guru


Joined: 25 Dec 2017
Posts: 386

PostPosted: Mon Jan 13, 2025 3:41 am    Post subject: Reply with quote

Hu wrote:
Do you have a workable plan for how we make such a change?


people need to understand. people don't want to change anything. they try to adapt to the present time what was relevant 30 years ago. but it doesn't work as well today as it worked in the past. i just want to say that for the present time, we need tools that are suitable for the present time. no one even tries. they just come up with excuses that old methods are better. they come up with the idea that intel core2 is better than a 2025 GPU with 6000 cores. and they do it well. there are many people and arguments that core2 is better.
Back to top
View user's profile Send private message
Gentoopc
Guru
Guru


Joined: 25 Dec 2017
Posts: 386

PostPosted: Mon Jan 13, 2025 3:58 am    Post subject: Reply with quote

Hu wrote:
Most people cannot afford the cost in money or power to maintain such a massively over-powerful system



you are right. But CPU consumes almost as much as GPU. Any video card with CUDA, even used, is affordable for anyone. That is why we need to move towards this. So that it is available to everyone. NPU is expensive now. GPU is everywhere and they are available on Ebay with different prices. That is where you need to look, that is where you need to move.
Back to top
View user's profile Send private message
Hu
Administrator
Administrator


Joined: 06 Mar 2007
Posts: 23020

PostPosted: Mon Jan 13, 2025 3:00 pm    Post subject: Reply with quote

I asked for a workable plan. Your response could be described as a wish, but I don't see a plan for how you expect people to make this work. You just want them to wave a wand and it will magically be better. Yes, if we could run everything on a 4 kilo-core processing unit that can do all the things that our current 8-32 core CPUs can do, that would be wonderful. As many people have explained to you repeatedly, video card GPUs are not a drop-in replacement for a motherboard's CPU. Software must be adapted to run on them, and, again as people have explained to you repeatedly, video card GPUs are not good at some tasks that the average user expects a processing unit to handle well.

Suppose everyone agreed with you that CUDA is the future. Who is responsible for porting all the existing software to run on it? What is your plan for dealing with the tasks that GPUs do poorly, if at all?
Back to top
View user's profile Send private message
NeddySeagoon
Administrator
Administrator


Joined: 05 Jul 2003
Posts: 54737
Location: 56N 3W

PostPosted: Mon Jan 13, 2025 3:18 pm    Post subject: Reply with quote

Gentoopc,

How does real time computing work then?
It still has a scheduler and things do get queued/forced to wait.

The trick is that answers are known before they are needed. That's good enough.
e.g. Flight control computers in most airliners today, or display computers is the same environment.

When you have 16.6ms to draw a new display frame, you do it in 16.6ms or less.
There are two approaches.
1. beef up the hardware
2. simplify what will be displayed.
_________________
Regards,

NeddySeagoon

Computer users fall into two groups:-
those that do backups
those that have never had a hard drive fail.
Back to top
View user's profile Send private message
logrusx
Advocate
Advocate


Joined: 22 Feb 2018
Posts: 2629

PostPosted: Fri Jan 17, 2025 7:42 pm    Post subject: Reply with quote

Hu wrote:
Yes, if we had unlimited resources so that nothing needed to wait, we would have no need to schedule anything.


That's not correct. Some things still need to be executed before other things so we're not going schedulerless anytime soon. Like never. Even if we had unlimited amount of memory and CPU cores. If we had, we wouldn't be able to utilize them beyond a certain limit. Laws of nature.

pingtoo wrote:
Conceptually I agree with Gentoopc. It would be nice that linux kernel can utilise every available resource on the box (NPU/GPU etc...).


There's no case where the kernel utilizes the GPU. It doesn't need to. Kernel doesn't do or need stuff that GPU/NPU is designed to do.

pingtoo wrote:
Kernel offload task on to NPU/GPU would be very nice.


Unless GPU development takes an unexpected turn and it become something other than GPU, that's not going to happen.

Best Regards,
Georgi
Back to top
View user's profile Send private message
Zucca
Moderator
Moderator


Joined: 14 Jun 2007
Posts: 3881
Location: Rasi, Finland

PostPosted: Fri Jan 17, 2025 10:26 pm    Post subject: Reply with quote

Only one area I could see where kernel could possibly utilize GPU is networking tasks.
_________________
..: Zucca :..

My gentoo installs:
init=/sbin/openrc-init
-systemd -logind -elogind seatd

Quote:
I am NaN! I am a man!
Back to top
View user's profile Send private message
dmpogo
Advocate
Advocate


Joined: 02 Sep 2004
Posts: 3468
Location: Canada

PostPosted: Fri Jan 17, 2025 10:41 pm    Post subject: Reply with quote

pingtoo wrote:
Conceptually I agree with Gentoopc. It would be nice that linux kernel can utilise every available resource on the box (NPU/GPU etc...). Kernel offload task on to NPU/GPU would be very nice.


Why, conceptually ? I would think I would prefer kernel to use as least resources as possible, leaving the rest of the resources to more productive things, no ?
Back to top
View user's profile Send private message
pingtoo
Veteran
Veteran


Joined: 10 Sep 2021
Posts: 1408
Location: Richmond Hill, Canada

PostPosted: Fri Jan 17, 2025 11:09 pm    Post subject: Reply with quote

dmpogo wrote:
pingtoo wrote:
Conceptually I agree with Gentoopc. It would be nice that linux kernel can utilise every available resource on the box (NPU/GPU etc...). Kernel offload task on to NPU/GPU would be very nice.


Why, conceptually ? I would think I would prefer kernel to use as least resources as possible, leaving the rest of the resources to more productive things, no ?


Because GPU/NPU just another calculation unit, be it doing specialized calculation. so if we there is/are calculation in kernel that can utilize GPU/NPU than why not?

So just imagining here 8O Like SiFi movie a huge network (SkyNet) its kernel need prioritize tasks, but the task count here we are talking in term of billion or even larger. to calculate priority queue would benefit from specialized calculation unit just dedicate for this job.

Please don't turn this to monolithic kernel vs micro kernel debate. I am just express a concept it does not mean anything real.
Back to top
View user's profile Send private message
Gentoopc
Guru
Guru


Joined: 25 Dec 2017
Posts: 386

PostPosted: Sun Jan 19, 2025 3:34 pm    Post subject: Reply with quote

Hu wrote:
I As many people have explained to you repeatedly?
Guys, no offense, but you can't explain anything to me because you yourself have poor knowledge in this area. I've already said in previous threads that people have said for sure that the Linux kernel can be launched on a GPU, but it requires modification. As for the plan, first we need to honestly admit to ourselves and others that our knowledge is poor in this area, and not look for reasons not to switch to a GPU. I suggest that the most important person on this site organize a fundraiser to write a real-time kernel for a GPU. Guys, this is necessary, there is currently a powerful lobbying effort to restrain development. Let's please not waste time while we have it.
Back to top
View user's profile Send private message
pingtoo
Veteran
Veteran


Joined: 10 Sep 2021
Posts: 1408
Location: Richmond Hill, Canada

PostPosted: Sun Jan 19, 2025 3:42 pm    Post subject: Reply with quote

Gentoopc wrote:
I've already said in previous threads that people have said for sure that the Linux kernel can be launched on a GPU


As far as I can tell from this thread, nobody every say 'Linux kernel can be launched on GPU". even with modification.

Can you find where this line came from and share with us?
Back to top
View user's profile Send private message
Gentoopc
Guru
Guru


Joined: 25 Dec 2017
Posts: 386

PostPosted: Sun Jan 19, 2025 4:39 pm    Post subject: Reply with quote

pingtoo wrote:


As far as I can tell from this thread, nobody every say 'Linux kernel can be launched on GPU". even with modification.

Can you find where this line came from and share with us?


I told you in other threads that the Linux kernel can be run on a GPU. I know this because this topic was raised on other resources. and people said that it was possible. it is possible without the participation of the CPU. yes, serious modifications of the Linux kernel are needed, but it is possible. I suggest going the other way, and writing the kernel for the GPU. guys, you understand, everything will change soon, your Linux Torvalds already made it clear to you when he kicked out the developers by removing even mention of them. this is very unfair. let's look to the future, if we do not arrange a place for ourselves in it, then we will not have a future.


Last edited by Gentoopc on Sun Jan 19, 2025 4:40 pm; edited 1 time in total
Back to top
View user's profile Send private message
logrusx
Advocate
Advocate


Joined: 22 Feb 2018
Posts: 2629

PostPosted: Sun Jan 19, 2025 4:40 pm    Post subject: Reply with quote

Zucca wrote:
Only one area I could see where kernel could possibly utilize GPU is networking tasks.


GPU is totally unfit to handle such tasks. In fact a GPU is not a programming unit. It's a calculation unit. The fact that it has firmware is for the same reasons there is microcode. If you don't know how microcode came into existence, read about the Microprocessor wars. That is a way to protect intellectual property. Of course you could argue there are fixes delivered through microcode, but the original reason it came into existence was to protect Intel's IP when it lost the lawsuit against AMD.

Best Regards,
Georgi
Back to top
View user's profile Send private message
logrusx
Advocate
Advocate


Joined: 22 Feb 2018
Posts: 2629

PostPosted: Sun Jan 19, 2025 4:42 pm    Post subject: Reply with quote

DELETED: a post I shouldn't have posted.

Last edited by logrusx on Sun Jan 19, 2025 5:01 pm; edited 1 time in total
Back to top
View user's profile Send private message
Gentoopc
Guru
Guru


Joined: 25 Dec 2017
Posts: 386

PostPosted: Sun Jan 19, 2025 4:47 pm    Post subject: Reply with quote

logrusx wrote:
Zucca wrote:
Only one area I could see where kernel could possibly utilize GPU is networking tasks.


GPU is totally unfit to handle such tasks. In fact a GPU is not a programming unit. It's a calculation unit. The fact that it has firmware is for the same reasons there is microcode. If you don't know how microcode came into existence, read about the Microprocessor wars. That is a way to protect intellectual property. Of course you could argue there are fixes delivered through microcode, but the original reason it came into existence was to protect Intel's IP when it lost the lawsuit against AMD.

You can tell these tales to others. Please don't tell them to me. I know that it is possible. And it will come true, it's just sad that we won't have time because of people like you.
Back to top
View user's profile Send private message
pingtoo
Veteran
Veteran


Joined: 10 Sep 2021
Posts: 1408
Location: Richmond Hill, Canada

PostPosted: Sun Jan 19, 2025 5:04 pm    Post subject: Reply with quote

Gentoopc wrote:
pingtoo wrote:


As far as I can tell from this thread, nobody every say 'Linux kernel can be launched on GPU". even with modification.

Can you find where this line came from and share with us?


I told you in other threads that the Linux kernel can be run on a GPU. I know this because this topic was raised on other resources. and people said that it was possible. it is possible without the participation of the CPU. yes, serious modifications of the Linux kernel are needed, but it is possible. I suggest going the other way, and writing the kernel for the GPU. guys, you understand, everything will change soon, your Linux Torvalds already made it clear to you when he kicked out the developers by removing even mention of them. this is very unfair. let's look to the future, if we do not arrange a place for ourselves in it, then we will not have a future.


You are making claim that is not substantiated. people said many thing but it does not make it true.

Everything in this world are possible. The question is it worthy to do it. Currently making Linux kernel running on GPU/NPU just not worthy in near future. Offload some kernel task into GPU/NPU is maybe but need deep analysis.

[joke]
People told me, they seen Linux running on a toaster and the toaster can produce micro chips that will be running faster than today's CPU.
disclaimer, the kernel and toaster was substantially modified. :P
[/joke]
Back to top
View user's profile Send private message
NeddySeagoon
Administrator
Administrator


Joined: 05 Jul 2003
Posts: 54737
Location: 56N 3W

PostPosted: Sun Jan 19, 2025 5:15 pm    Post subject: Reply with quote

Gentoopc wrote:
Guys, no offense, but you can't explain anything to me ...


That's why we keep going over the same ground. It reminds me of this clip from Oh Mr Porter. Listen to the postman.

I did think about locking the topic, but its your time.
_________________
Regards,

NeddySeagoon

Computer users fall into two groups:-
those that do backups
those that have never had a hard drive fail.
Back to top
View user's profile Send private message
logrusx
Advocate
Advocate


Joined: 22 Feb 2018
Posts: 2629

PostPosted: Sun Jan 19, 2025 5:17 pm    Post subject: Reply with quote

pingtoo wrote:

Everything in this world are possible. The question is it worthy to do it. Currently making Linux kernel running on GPU/NPU just not worthy in near future.


It is impossible. A GPU is not fully functional processing unit. It's actually more like a coprocessor. It has very limited programming capabilities only related to calculations. Most of its logic is hard-wired and can't be modified. (That's why this idea is gibberish by nature)

pingtoo wrote:

[joke]
People told me, they seen Linux running on a toaster and the toaster can produce micro chips that will be running faster than today's CPU.
disclaimer, the kernel and toaster was substantially modified. :P
[/joke]


It was NetBSD if I remember correctly. The toaster was a well disguised computer.

Best Regards,
Georgi
Back to top
View user's profile Send private message
stefan11111
l33t
l33t


Joined: 29 Jan 2023
Posts: 949
Location: Romania

PostPosted: Sun Jan 19, 2025 6:00 pm    Post subject: Reply with quote

Gentoopc wrote:

Now I will try to say the main thing

we need to run two functions in parallel

Code:
 
foo();
foo1();



this will be impossible on the CPU because the code is executed line by line. first foo() will be called; then foo1(); to solve this problem we need a new programming language and changes to the CPU components, but no one will do this, it is expensive and you are right when you said that you and we do not have such an opportunity.

I made a post about this when you hit report instead of quote, but I will make another one.

What you seem to be implying is that when running on a GPU, everything can magically become parallel.
So you would want to have a language for the GPU where every instruction is by default executed in parallel.

Think of the following:
Code:

int x = 0;
x++;
x = 2;


What is the value of x after running everything in parallel?
if x++; is run first, then x = 2; x will be 2.
if x = 2; is run first, then x++; x will be 3.
This is ignoring the fact that x++ is not atomic.

Here's another problem, a classical one:
Code:

int x = 0;
int i;
int j;

for(i = 1; i <= 1000; i++) {
    x++;
}

for (j = 1; j <= 1000; j++){
    x++;
}

This also runs into problems if you run these loops in parallel.
When running on a single thread, the value of x should be 2000 after the for loops are finished.
What if, on a particular iteration, you read x on the first thread, read x on the second thread, increment x on the first thread, increment x on the second thread.
Then, after these 2 x++; are run, the value of x is only increased once, by 1.

As you see, writing parallel programs is not as simple as: 'take a serial program and give each instruction a thread'

Now, with the above example, you could use locks, such that only one thread modifies x at any time.
If you do that, on a CPU, you will see that it takes ages for the program to complete.
This is because the locking/unlocking introduces way more overhead than is saved by the extra thread.

Now, imagine doing this on a GPU, which has slower individual cores than a CPU.
The program would run even slower.

What I'm trying to say is that throwing threads at a program does not necessarily make it faster and has to be done with care to avoid races.
Would you get any advantage running a kernel on a GPU instead of a CPU?
Most likely not, as very few things are parallelizable.
Would you get any advantage running an irc client, a web browser, etc, on a GPU?
Again, most likely not.
But you would for sure have the disadvantage of weaker cores that a CPU.

Now, multiplying 1000000 matrices with 1000000 other matrices in parallel?
Then yes, you should do that on a GPU. The overhead of the weaker cores is massively outweighed my the number of cores you can use at once.
This is what a GPU is designed to do.

So throwing more threads at all programs and writing a language where every instruction is run in parallel would definitely not make all programs faster, and would break most of them.
Some programs are easily parallelizable, but most aren't.
_________________
My overlay: https://github.com/stefan11111/stefan_overlay
INSTALL_MASK="/etc/systemd /lib/systemd /usr/lib/systemd /usr/lib/modules-load.d *udev* /usr/lib/tmpfiles.d *tmpfiles* /var/lib/dbus /usr/bin/gdbus /lib/udev"
Back to top
View user's profile Send private message
Zucca
Moderator
Moderator


Joined: 14 Jun 2007
Posts: 3881
Location: Rasi, Finland

PostPosted: Sun Jan 19, 2025 7:43 pm    Post subject: Reply with quote

logrusx wrote:
Zucca wrote:
Only one area I could see where kernel could possibly utilize GPU is networking tasks.


GPU is totally unfit to handle such tasks.
Well. I have to say I'm no expert on this field at all, but have a look at this.
I don't really know how much is possible to do with GPU regarding network packets. But at least something.
_________________
..: Zucca :..

My gentoo installs:
init=/sbin/openrc-init
-systemd -logind -elogind seatd

Quote:
I am NaN! I am a man!
Back to top
View user's profile Send private message
logrusx
Advocate
Advocate


Joined: 22 Feb 2018
Posts: 2629

PostPosted: Sun Jan 19, 2025 7:56 pm    Post subject: Reply with quote

Zucca wrote:
logrusx wrote:
Zucca wrote:
Only one area I could see where kernel could possibly utilize GPU is networking tasks.


GPU is totally unfit to handle such tasks.
Well. I have to say I'm no expert on this field at all, but have a look at this.
I don't really know how much is possible to do with GPU regarding network packets. But at least something.


All examples given pertain to processing large amounts of data or just fast processing of data.

  • Morpheus AI:
    Quote:
    NVIDIA Morpheus is a performance-oriented, application framework that enables cybersecurity developers to create fully optimized AI pipelines for filtering, processing, and classifying large volumes of real-time data.

  • Line-rate radar signal processing: signal processing. What more can I say about it?
  • Real-time DSP services over GPU: signal processing again.


Nothing networking here. Only very fast data analysis/calculations and the fast transfer of data to the GPU which I think nowadays is just a side effect of using PCI Express. Back in the old days it was AGP which had only one way of fast transfer of data i.e. CPU->GPU. And before that it was just PCI or even earlier - ISA. I have a recollection of having Voodo II somehow intercepting the output or a regular 2D graphics card, but I wasn't that interested in how things worked exactly those days.

Best Regards,
Georgi

p.s. signal processing is not the best utilization of a GPU. For as long as the processing is simple, the only advantage is the very high speed because signal processing is sequential in nature. It always depends on past values/results. I can think of a few applications for filters which can use large matrices, but I still see limited use. Maybe I'm wrong about that but more or less - that's it. But if the signal gets complex and therefore its processing gets complex, you're loosing the speed, which at a first glance is the only benefit. Or maybe processing multiple streams at once.

Still, all listed are very specialized tasks and have nothing to do with handling network operations, but transferring data from the NIC to the GPU. It also looks like NVIDIA pushing AI and similar stuff that cells their GPU's. Marketing hype, nothing more.


Last edited by logrusx on Sun Jan 19, 2025 8:39 pm; edited 1 time in total
Back to top
View user's profile Send private message
Display posts from previous:   
Reply to topic    Gentoo Forums Forum Index Gentoo Chat All times are GMT
Goto page 1, 2  Next
Page 1 of 2

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum