commonlib: Add GCD function
Implement a simple GCD function. BUG=b:307790895 TEST=emerge-geralt coreboot TEST=make tests/commonlib/bsd/gcd-test Change-Id: I21819cda4299b3809b8ca7a95cbdc6a87e4b3481 Signed-off-by: Yidi Lin <yidilin@chromium.org> Reviewed-on: https://review.coreboot.org/c/coreboot/+/78798 Reviewed-by: Martin L Roth <gaumless@gmail.com> Reviewed-by: Julius Werner <jwerner@chromium.org> Reviewed-by: Yu-Ping Wu <yupingso@google.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
ed62dbaf67
commit
909c317b2d
|
@ -58,3 +58,6 @@ ramstage-y += sort.c
|
|||
romstage-y += bsd/elog.c
|
||||
ramstage-y += bsd/elog.c
|
||||
smm-y += bsd/elog.c
|
||||
|
||||
decompressor-y += bsd/gcd.c
|
||||
all-y += bsd/gcd.c
|
||||
|
|
|
@ -0,0 +1,23 @@
|
|||
/* SPDX-License-Identifier: BSD-3-Clause */
|
||||
|
||||
#include <commonlib/bsd/gcd.h>
|
||||
#include <commonlib/bsd/helpers.h>
|
||||
#include <stdint.h>
|
||||
|
||||
uint32_t gcd32(uint32_t a, uint32_t b)
|
||||
{
|
||||
uint32_t c;
|
||||
|
||||
if (a == 0 || b == 0)
|
||||
return MAX(a, b);
|
||||
|
||||
c = a % b;
|
||||
|
||||
while (c > 0) {
|
||||
a = b;
|
||||
b = c;
|
||||
c = a % b;
|
||||
}
|
||||
|
||||
return b;
|
||||
}
|
|
@ -0,0 +1,10 @@
|
|||
/* SPDX-License-Identifier: BSD-3-Clause */
|
||||
|
||||
#ifndef _COMMONLIB_BSD_GCD_H_
|
||||
#define _COMMONLIB_BSD_GCD_H_
|
||||
|
||||
#include <stdint.h>
|
||||
|
||||
uint32_t gcd32(uint32_t a, uint32_t b);
|
||||
|
||||
#endif /* _COMMONLIB_BSD_GCD_H_ */
|
|
@ -1,5 +1,9 @@
|
|||
# SPDX-License-Identifier: GPL-2.0-only
|
||||
|
||||
tests-y += helpers-test
|
||||
tests-y += gcd-test
|
||||
|
||||
helpers-test-srcs += tests/commonlib/bsd/helpers-test.c
|
||||
|
||||
gcd-test-srcs += tests/commonlib/bsd/gcd-test.c
|
||||
gcd-test-srcs += src/commonlib/bsd/gcd.c
|
||||
|
|
|
@ -0,0 +1,27 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#include <commonlib/bsd/gcd.h>
|
||||
#include <tests/test.h>
|
||||
|
||||
static void test_gcd32(void **state)
|
||||
{
|
||||
assert_int_equal(gcd32(17, 11), 1);
|
||||
assert_int_equal(gcd32(64, 36), 4);
|
||||
assert_int_equal(gcd32(90, 123), 3);
|
||||
assert_int_equal(gcd32(65536, 339584), 128);
|
||||
assert_int_equal(gcd32(1, 1), 1);
|
||||
assert_int_equal(gcd32(1, 123), 1);
|
||||
assert_int_equal(gcd32(123, 1), 1);
|
||||
assert_int_equal(gcd32(1, UINT32_MAX), 1);
|
||||
assert_int_equal(gcd32(UINT32_MAX, 1), 1);
|
||||
assert_int_equal(gcd32(UINT32_MAX, UINT32_MAX), UINT32_MAX);
|
||||
}
|
||||
|
||||
int main(void)
|
||||
{
|
||||
const struct CMUnitTest tests[] = {
|
||||
cmocka_unit_test(test_gcd32),
|
||||
};
|
||||
|
||||
return cb_run_group_tests(tests, NULL, NULL);
|
||||
}
|
Loading…
Reference in New Issue