Re: kernel/sched.c questions

Tim Walberg (tewalberg@mediaone.net)
Wed, 4 Apr 2001 15:08:33 -0500


--PmA2V3Z32TCmWXqI
Content-Type: text/plain; charset=iso-8859-1
Content-Disposition: inline
Content-Transfer-Encoding: quoted-printable

On 04/04/2001 16:52 -0300, Sarda=F1ons, Eliel wrote:
>> Hello, I would like to know why you put this two functions:
>> void scheduling_functions_start_here(void) { }
>> ...
>> void scheduling_functions_end_here(void) { }
>>=09

That one I have no idea about - maybe some perverse sort
of comment? Or maybe something somewhere needs to know the
address range that some functions lie within, and these functions
would delimit that range. Of course, that presumes that the
compiler in use doesn't reorder functions in the object code
that emits, but I think that's a fairly safe assumption for
now...

>> why you put 'case TASK_RUNNING'
>>=09
>> switch (prev->state) {
>> case TASK_INTERRUPTIBLE:
>> if (signal_pending(prev)) {
>> prev->state =3D TASK_RUNNING;
>> break;
>> }
>> default:
>> del_from_runqueue(prev);
>> case TASK_RUNNING:
>> }
>>=09

This just indicates that there is nothing to be done for the
TASK_RUNNING case - if it were left out, the default case would
be taken. Of course, a 'case TASK_RUNNING: break;' placed earlier
in the switch construct would be semantically the same, but there
may be reasons related to code optimization that this was done the
way it was.

>> and the last one:
>>=09
>> in the function schedule() you always use this syntax:
>>=09
>> -----
>> if (a_condition)
>> goto bebe;
>> bebe_back
>>=09
>>=09
>> bebe:
>> do_bebe();
>> goto bebe_back;
>> ------
>> why not just doing:
>> =20
>> if (a_condition)
>> do_bebe();
>>=09
>>=09
>> I know that goto's are better but finaly you are jumping to a function a=
nd
>> then calling the function. I think you can improve performance doing thi=
s.

This looks like a hand-optimization to avoid a branch in the most common
case. Chances are a_condition is supposed to be pretty rare, and the code
you suggest would usually include a branch for the usual code path, then.

tw

--=20
+--------------------------+------------------------------+
| Tim Walberg | tewalberg@mediaone.net |
| 828 Marshall Ct. | www.concentric.net/~twalberg |
| Palatine, IL 60074 | |
+--------------------------+------------------------------+

--PmA2V3Z32TCmWXqI
Content-Type: application/pgp-signature
Content-Disposition: inline

-----BEGIN PGP SIGNATURE-----
Version: PGP 6.5.1i

iQA/AwUBOst/P8PlnI9tqyVmEQLPqwCg8ugIPWfbXBapw+5dVCmK2OkmNNgAoM2O
TTax94T0EEazhVvS5la8ocj8
=Iy8H
-----END PGP SIGNATURE-----

--PmA2V3Z32TCmWXqI--
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/