Skip to content

This issue was moved to a discussion.

You can continue the conversation there. Go to discussion →

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rename systemClock::Frequency to systemClock::sysClk #140

Closed
squarecode opened this issue Jan 7, 2019 · 3 comments
Closed

Rename systemClock::Frequency to systemClock::sysClk #140

squarecode opened this issue Jan 7, 2019 · 3 comments

Comments

@squarecode
Copy link

The term Frequency is really misleading in many cases.

bildschirmfoto 2019-01-07 um 20 55 19

Using the term used by ST would be pretty cool for me as a beginner.

@salkinium
Copy link
Member

The entire SystemClock needs to be refactored to match ST‘s documentation. For example, SystemClock::TimerN should be called SystemClock::TimN.

@ptrks
Copy link
Contributor

ptrks commented Feb 10, 2019

Would you want all the refactoring of the names to be done in a single PR? If so what would that complete list look like? Otherwise I can get started with at least SystemClock::TimN and SystemClock::sysClk

@salkinium
Copy link
Member

This sounds easy, but it’s unfortunately a very complicated issue. The background is that we don’t yet have the clock tree information in modm-devices, so we had to manually create all the SystemClock structures for the board support packages. The usability of this obviously sucks, since you have to look up what peripherals are available manually in the datasheets and what frequencies are acceptable for what part of the tree.

Back in 2015 I prototyped a C++ compile time API for a better system clock abstraction, but it turned out to be quite difficult to map a graph into a useful template structure with all the edge cases still working. I abandoned this concept.

The way I would like to solve this issue is to parse the clock tree information in CubeMX via modm-devices and at least generate a base class that contains the correct mapping of clock domain -> peripheral (ie. I2C1 is connected to APB1 or APB2?) and maybe abstracts some domain prescalers away.
The BSP package would then inherit from this description and specialize it, in order to cut down on the boilerplate code.

Something like this maybe:

template< uint32_t SysClk, uint8_t AhbPrescaler = 1, uint8_t Abp1Prescaler = 1 >
struct SystemClockBase
{
    static constexpr uint32_t SysClk = SysClk;
    static constexpr uint32_t Ahb = SysClk / AhbPrescaler;
    static constexpr uint32_t Apb1 = Ahb / Abp1Prescaler;
    // etc, add all device specific peripherals here:
    static constexpr uint32_t Tim1 = Apb1;

    bool
    initPrescalers()
    {
        // set AHB, APBx prescalers
    }
    
    bool
    initSysClk()
    {
        // init Flash latency etc
    }

    bool
    InitClock()
    {
        // set modm::clock::fcpu etc values
    }
};
// in BSP or user code
class SystemClock : public SystemClockBase<16_MHz>
{
    // constanst are all inherited
    bool
    enable()
    {
        initPrescalers();
        // setup PLL
        initSysClk();
        initClock();
    }
};

This issue was moved to a discussion.

You can continue the conversation there. Go to discussion →

Development

No branches or pull requests

3 participants