mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-15 14:32:43 +01:00
91269794d9
On AVR_8 512*256 causes an int overflow.
92 lines
2.3 KiB
C
92 lines
2.3 KiB
C
/*
|
|
* Copyright (C) 2016 Freie Universität Berlin
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
* directory for more details.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup tests
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Unittests for the ``flashpage`` periph driver
|
|
*
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
*
|
|
*/
|
|
|
|
#include <errno.h>
|
|
#include <stdint.h>
|
|
|
|
#include "cpu.h"
|
|
#include "embUnit.h"
|
|
#include "embUnit/embUnit.h"
|
|
|
|
/* need to define these values before including the header */
|
|
#ifndef FLASHPAGE_SIZE
|
|
#define FLASHPAGE_SIZE 256
|
|
#endif
|
|
#ifndef FLASHPAGE_NUMOF
|
|
#define FLASHPAGE_NUMOF 128
|
|
#endif
|
|
|
|
/* fake uniform flashpage sizes for devices that don't have it */
|
|
#undef PERIPH_FLASHPAGE_CUSTOM_PAGESIZES
|
|
|
|
#include "periph/flashpage.h"
|
|
|
|
#if (defined(BOARD_NATIVE) && !IS_USED(MODULE_PERIPH_FLASHPAGE))
|
|
char _native_flash[FLASHPAGE_SIZE * FLASHPAGE_NUMOF];
|
|
#endif
|
|
|
|
static void test_flashbase_addr(void)
|
|
{
|
|
void *addr;
|
|
|
|
addr = flashpage_addr(0);
|
|
TEST_ASSERT_EQUAL_INT((int)CPU_FLASH_BASE, (int)addr);
|
|
addr = flashpage_addr(FLASHPAGE_NUMOF - 1);
|
|
TEST_ASSERT_EQUAL_INT((long)CPU_FLASH_BASE + (((unsigned)FLASHPAGE_NUMOF - 1) * FLASHPAGE_SIZE), (int)addr);
|
|
addr = flashpage_addr(12);
|
|
TEST_ASSERT_EQUAL_INT((int)CPU_FLASH_BASE + (12 * FLASHPAGE_SIZE), (int)addr);
|
|
}
|
|
|
|
static void test_flashbase_page(void)
|
|
{
|
|
int page;
|
|
|
|
page = flashpage_page((void *)CPU_FLASH_BASE);
|
|
TEST_ASSERT_EQUAL_INT(0, page);
|
|
page = flashpage_page((void *)(CPU_FLASH_BASE + 1));
|
|
TEST_ASSERT_EQUAL_INT(0, page);
|
|
page = flashpage_page((void *)(CPU_FLASH_BASE + FLASHPAGE_SIZE));
|
|
TEST_ASSERT_EQUAL_INT(1, page);
|
|
page = flashpage_page((void *)(CPU_FLASH_BASE + FLASHPAGE_SIZE + 1));
|
|
TEST_ASSERT_EQUAL_INT(1, page);
|
|
page = flashpage_page((void *)(CPU_FLASH_BASE + ((unsigned)FLASHPAGE_SIZE * (FLASHPAGE_NUMOF - 1))));
|
|
TEST_ASSERT_EQUAL_INT(FLASHPAGE_NUMOF - 1, page);
|
|
}
|
|
|
|
Test *tests_flashpage_tests(void)
|
|
{
|
|
EMB_UNIT_TESTFIXTURES(fixtures) {
|
|
new_TestFixture(test_flashbase_addr),
|
|
new_TestFixture(test_flashbase_page)
|
|
};
|
|
|
|
EMB_UNIT_TESTCALLER(flashbase_tests, NULL, NULL, fixtures);
|
|
|
|
return (Test *)&flashbase_tests;
|
|
}
|
|
|
|
int main(void)
|
|
{
|
|
TESTS_START();
|
|
TESTS_RUN(tests_flashpage_tests());
|
|
TESTS_END();
|
|
return 0;
|
|
}
|
|
/** @} */
|