Status on re-factorings

This is merely a historical archive of years 2008-2021, before the migration to mailman3.

A maintained and still updated list archive can be found at https://lists.osmocom.org/hyperkitty/list/osmocom-net-gprs@lists.osmocom.org/.

Ivan Kluchnikov Ivan.Kluchnikov at fairwaves.ru
Mon Oct 28 11:16:34 UTC 2013


Hi Holger,

I have merged all patches, which you sent to mailing list previously
and also looked through the code of zecke/features/clean-up branch.
You have done really great work and as I think all structure changes
have the right direction.
As you mentioned, refactoring of some parts of the code is risky, but
when we use right code structure, it is more easy to find problems.
Also I think that after the end of refactoring, we should implement
set of tests, which will help us to find bugs and problems.

I have one question about C/C++ using in osmo-pcu project. What I see,
that now the code migrates to C++, but previously we mainly used C. As
the result now osmo-pcu code is C and C++ mix, but I think that we
should use only one as basic.
I personally prefer to use C++ in osmo-pcu.
What do you think about it?
Do you plan to migrate the most parts of the code to C++?

2013/10/20 Holger Hans Peter Freyther <hfreyther at sysmocom.de>:
> Hi all,
>
> I have continued with my refactorings and mostly done:
>
> * Remove global state (e.g. the global lists for ta, sba, tbf, bts
> * Add back-pointers to tbf, trx, pdch which will allow to kill methods
>   that take trx, ts as parameters.
> * Started to use C++ classes and functions.
> * Stop poking of internals from other classes areas (gprs_rlcmac_data
>   is still in front of me and the most hairy part).
>
> I will probably need to spend another 40h on this code to finally
> have structure in it. Once this is done I will add counters and
> rate counters, improve the VTY inspection... and then I can search
> for the actual defects we are experiencing.
>
> While doing the refactorings I noticed that both pcu_l1_if.cpp and
> sysmo_sock.cpp have different ways to reset the BTS/PCU state. Both
> of them have different issues and are both incomplete. It is the
> perfect example where structure would have saved timed and made
> the code more reliable at the same time.
>
> I am going to work on gprs_rlcmac_data.cpp and while my refactorings
> so far where low risk.. the risk will increase when touching and
> structuring the above, e.g. it is hard to judge if the difference in
> the code-clones is on purpose or actually a bug. There will be only
> one way to find it out though.
>
> I am afraid that I have 52 commits compares to master and I am only
> half way done. Review and changing directions will be quite difficult
> at this point in time.
>
> holger
>
>
> --
> - Holger Freyther <hfreyther at sysmocom.de>       http://www.sysmocom.de/
> =======================================================================
> * sysmocom - systems for mobile communications GmbH
> * Schivelbeiner Str. 5
> * 10439 Berlin, Germany
> * Sitz / Registered office: Berlin, HRB 134158 B
> * Geschaeftsfuehrer / Managing Directors: Holger Freyther, Harald Welte
>
>



-- 
Regards,
Ivan Kluchnikov.
http://fairwaves.ru




More information about the osmocom-net-gprs mailing list