[PATCH 1/3] Add generic LE/BE load/store uint type convertors and use them in msgb
Max Suraev <Max.Suraev@fairwaves.co>
2014-06-04 17:07:41 GMT
---
.gitignore | 3 +-
include/Makefile.am | 7 ++
include/osmocom/core/bitXXgen.h.tpl | 101 +++++++++++++++++
include/osmocom/core/bits.h | 5 +
include/osmocom/core/msgb.h | 23 ++--
tests/bits/bitrev_test.c | 218 +++++++++++++++++++++++++++++++++++-
tests/bits/bitrev_test.ok | 31 +++++
7 files changed, 376 insertions(+), 12 deletions(-)
create mode 100644 include/osmocom/core/bitXXgen.h.tpl
diff --git a/.gitignore b/.gitignore
index 71b27f2..3fa1bbc 100644
--- a/.gitignore
+++ b/.gitignore
@@ -55,6 +55,7 @@ tests/testsuite
tests/testsuite.dir/
tests/testsuite.log
+tests/utils/utils_test
tests/sms/sms_test
tests/timer/timer_test
tests/msgfile/msgfile_test
@@ -89,7 +90,7 @@ doc/html.tar
src/crc*gen.c
include/osmocom/core/crc*gen.h
-
+include/osmocom/core/bit*gen.h
(Continue reading)
[PATCH 2/3] Add left circular shift function
Max Suraev <Max.Suraev@fairwaves.co>
2014-06-04 17:07:42 GMT
---
include/osmocom/core/bits.h | 10 ++++++++++
1 file changed, 10 insertions(+)
diff --git a/include/osmocom/core/bits.h b/include/osmocom/core/bits.h
index 5c9c7a6..c2c4863 100644
--- a/include/osmocom/core/bits.h
+++ b/include/osmocom/core/bits.h
@@ -78,6 +78,16 @@ uint32_t osmo_revbytebits_8(uint8_t x);
/* \brief reverse the bits of each byte in a given buffer */
void osmo_revbytebits_buf(uint8_t *buf, int len);
+/*! \brief left circular shift
+ * \param[in] in The 16 bit unsigned integer to be rotated
+ * \param[in] shift Number of bits to shift \a in to, [0;16] bits
+ * \returns shifted value
+ */
+static inline uint16_t osmo_rol16(uint16_t in, unsigned shift)
+{
+ return (in << shift) | (in >> (16 - shift));
+}
+
/*! @} */
#endif /* _OSMO_BITS_H */
--
--
1.9.1
[PATCH 3/3] Add Kasumi cipher implementation
Max Suraev <Max.Suraev@fairwaves.co>
2014-06-04 17:07:43 GMT
---
.gitignore | 1 +
include/osmocom/gsm/kasumi.h | 41 ++++++++++
src/gsm/Makefile.am | 2 +-
src/gsm/kasumi.c | 190 +++++++++++++++++++++++++++++++++++++++++++
src/gsm/libosmogsm.map | 4 +
tests/Makefile.am | 7 +-
tests/kasumi/kasumi_test.c | 136 +++++++++++++++++++++++++++++++
tests/kasumi/kasumi_test.ok | 10 +++
tests/testsuite.at | 6 ++
9 files changed, 394 insertions(+), 3 deletions(-)
create mode 100644 include/osmocom/gsm/kasumi.h
create mode 100644 src/gsm/kasumi.c
create mode 100644 tests/kasumi/kasumi_test.c
create mode 100644 tests/kasumi/kasumi_test.ok
diff --git a/.gitignore b/.gitignore
index 3fa1bbc..1299028 100644
--- a/.gitignore
+++ b/.gitignore
@@ -56,6 +56,7 @@ tests/testsuite.dir/
tests/testsuite.log
tests/utils/utils_test
+tests/kasumi/kasumi_test
tests/sms/sms_test
tests/timer/timer_test
tests/msgfile/msgfile_test
diff --git a/include/osmocom/gsm/kasumi.h b/include/osmocom/gsm/kasumi.h
new file mode 100644
(Continue reading)
Re: [PATCH 3/3] Add Kasumi cipher implementation
Sylvain Munaut <246tnt@gmail.com>
2014-06-15 20:49:45 GMT
Hi Max,
> +
> +#pragma once
All the other files use the classic #ifdef #define, so either replace
all before that, or stick to the current way of doing it.
> +
> +#include <stdint.h>
> +
> +/*! \brief Single iteration of KASUMI cipher
> + * \param[in] P Block, 64 bits to be processed in this round
> + * \param[in] KLi1 Expanded subkeys
> + * \param[in] KLi2 Expanded subkeys
> + * \param[in] KOi1 Expanded subkeys
> + * \param[in] KOi2 Expanded subkeys
> + * \param[in] KOi3 Expanded subkeys
> + * \param[in] KIi1 Expanded subkeys
> + * \param[in] KIi2 Expanded subkeys
> + * \param[in] KIi3 Expanded subkeys
> + * \returns processed block of 64 bits
> + */
We usually put the documentation only in the .c file and not the
header. (except for stuff that's only in the header obviously).
If it's picked up by doxygen all the same then I don't have big
objections against putting it in the header (to be checked though) if
you insist, but then be consistent ... you have some of the doc
(Continue reading)
Re: [PATCH 3/3] Add Kasumi cipher implementation
☎ <Max.Suraev@fairwaves.co>
2014-06-15 21:43:00 GMT
15.06.2014 22:49, Sylvain Munaut пишет:
> Hi Max,
>
>> +
>> +#pragma once
>
> All the other files use the classic #ifdef #define, so either replace
> all before that, or stick to the current way of doing it.
What do you mean by "all before that"?
> Either the methods are meant to be part of the public API and then
> they should carry the osmo prefix.
> Or they're meant to be internal, then the symbol should not be
> exported in the map file and the header should not be installed.
I think I've asked it already but I don't recall an answer: I do not want to make it
a part of public API (hence - no osmo_ prefix) but I still need to call it explicitly
in test/ - how can I do that without adding it to map file?
--
--
best regards,
Max, http://fairwaves.co
Re: [PATCH 3/3] Add Kasumi cipher implementation
Sylvain Munaut <246tnt@gmail.com>
2014-06-15 22:33:41 GMT
Hi,
> What do you mean by "all before that"?
Like change all libosmocore headers to use #pragma once.
We pretty much only target gcc/llvm AFAIK so that shouldn't be a problem.
Any one see an objection to that ?
> I think I've asked it already but I don't recall an answer: I do not want to make it
> a part of public API (hence - no osmo_ prefix) but I still need to call it explicitly
> in test/ - how can I do that without adding it to map file?
I think the header should be in noinst_HEADER then (don't remember the
exact name).
As for the testing, linking the test statically should do right ? I
didn't test but since this only changes the presence of the symbol in
the dynamic symbol table, linking to the static lib should work.
Cheers,
Sylvain
Re: [PATCH 3/3] Add Kasumi cipher implementation
☎ <Max.Suraev@fairwaves.co>
2014-06-16 12:54:42 GMT
16.06.2014 00:33, Sylvain Munaut пишет:
> I think the header should be in noinst_HEADER then (don't remember the
> exact name).
noinst_HEADERS it is, thanks.
> As for the testing, linking the test statically should do right ? I
> didn't test but since this only changes the presence of the symbol in
> the dynamic symbol table, linking to the static lib should work.
Where should I pass -static to gcc linker? Is there some statically-linked test
available as an example?
--
--
best regards,
Max, http://fairwaves.co
Re: [PATCH 3/3] Add Kasumi cipher implementation
Sylvain Munaut <246tnt@gmail.com>
2014-06-16 13:37:31 GMT
Hi,
>> As for the testing, linking the test statically should do right ? I
>> didn't test but since this only changes the presence of the symbol in
>> the dynamic symbol table, linking to the static lib should work.
>
> Where should I pass -static to gcc linker? Is there some statically-linked test
> available as an example?
testname_LDFLAGS = -static
I fixed it up myself and pushed the 3 patches.
Cheers,
Sylvain
Re: [PATCH 3/3] Add Kasumi cipher implementation
Holger Hans Peter Freyther <holger@freyther.de>
2014-06-16 05:41:11 GMT
On Sun, Jun 15, 2014 at 10:49:45PM +0200, Sylvain Munaut wrote:
Hi,
> > +#pragma once
>
> All the other files use the classic #ifdef #define, so either replace
> all before that, or stick to the current way of doing it.
do we really want to be that strong? I think all future header files
should use "#pragma once".
Re: [PATCH 3/3] Add Kasumi cipher implementation
Sylvain Munaut <246tnt@gmail.com>
2014-06-16 08:19:20 GMT
>> > +#pragma once
>>
>> All the other files use the classic #ifdef #define, so either replace
>> all before that, or stick to the current way of doing it.
>
> do we really want to be that strong? I think all future header files
> should use "#pragma once".
I like consistency :p
Especially since such a change won't really lead to conflict since it
only change a couple lines at the beginning/end of each file and it's
also pretty easy to do with a script. (I did it in like 10 min).
Cheers,
Sylvain
Re: [PATCH 3/3] Add Kasumi cipher implementation
☎ <Max.Suraev@fairwaves.co>
2014-06-16 08:23:16 GMT
16.06.2014 10:19, Sylvain Munaut пишет:
> Especially since such a change won't really lead to conflict since it
> only change a couple lines at the beginning/end of each file and it's
> also pretty easy to do with a script. (I did it in like 10 min).
>
Good. Can you commit this?
--
--
best regards,
Max, http://fairwaves.co
Re: [PATCH 3/3] Add Kasumi cipher implementation
Sylvain Munaut <246tnt@gmail.com>
2014-06-16 11:55:03 GMT
>> Especially since such a change won't really lead to conflict since it
>> only change a couple lines at the beginning/end of each file and it's
>> also pretty easy to do with a script. (I did it in like 10 min).
>>
>
> Good. Can you commit this?
Holger, can I get a ack on this ?
Cheers,
Sylvain
Re: [PATCH 3/3] Add Kasumi cipher implementation
Holger Hans Peter Freyther <holger@freyther.de>
2014-06-16 12:08:53 GMT
On Mon, Jun 16, 2014 at 01:55:03PM +0200, Sylvain Munaut wrote:
> >> Especially since such a change won't really lead to conflict since it
> >> only change a couple lines at the beginning/end of each file and it's
> >> also pretty easy to do with a script. (I did it in like 10 min).
> >>
> >
> > Good. Can you commit this?
>
>
> Holger, can I get a ack on this ?
sure. it looked fine.
Re: [PATCH 1/3] Add generic LE/BE load/store uint type convertors and use them in msgb
☎ <Max.Suraev@fairwaves.co>
2014-06-06 13:33:29 GMT
This series of patches adds Kasumi encryption algorithm and necessary groundwork for
it. It differs from previous version only in improved documentation (based on
previous comments).
All the tests are included and pass just fine. Once this is merged I plan to send
patches implementing A5/4, GEA4 etc which relies on Kasumi.
Please review and comment.
Max.