<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
		<id>https://wiki.distrap.org/index.php?action=history&amp;feed=atom&amp;title=FrequentlyAskedQuestions</id>
		<title>FrequentlyAskedQuestions - Revision history</title>
		<link rel="self" type="application/atom+xml" href="https://wiki.distrap.org/index.php?action=history&amp;feed=atom&amp;title=FrequentlyAskedQuestions"/>
		<link rel="alternate" type="text/html" href="https://wiki.distrap.org/index.php?title=FrequentlyAskedQuestions&amp;action=history"/>
		<updated>2026-05-14T15:49:26Z</updated>
		<subtitle>Revision history for this page on the wiki</subtitle>
		<generator>MediaWiki 1.29.0-rc.0</generator>

	<entry>
		<id>https://wiki.distrap.org/index.php?title=FrequentlyAskedQuestions&amp;diff=16&amp;oldid=prev</id>
		<title>Srk: rename FAQ</title>
		<link rel="alternate" type="text/html" href="https://wiki.distrap.org/index.php?title=FrequentlyAskedQuestions&amp;diff=16&amp;oldid=prev"/>
				<updated>2017-09-30T00:20:43Z</updated>
		
		<summary type="html">&lt;p&gt;rename FAQ&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Why CAN? ==&lt;br /&gt;
&lt;br /&gt;
CAN bus uses differential signaling to provide noise resistant communication between nodes.&lt;br /&gt;
This is a critical requirement for our applications as they may use high power motor drivers&lt;br /&gt;
and motors producing lots of EMI. The other reason is the availability of the CAN peripheral&lt;br /&gt;
on STM32 ARM MCUs which means only adding CAN transceiver like SN65HV is necessary.&lt;br /&gt;
&lt;br /&gt;
== Why CANOpen? ==&lt;br /&gt;
&lt;br /&gt;
Rather than reinventing our custom protocol we're using [[CANOpen]] protocol which is designed&lt;br /&gt;
for industrial applications. This also allows us to stay compatible with wide range of already&lt;br /&gt;
existing manufacturers.&lt;br /&gt;
&lt;br /&gt;
== Why Ivory Tower? ==&lt;br /&gt;
&lt;br /&gt;
Due to Ivory being embedded in Haskell it reduces a lot of headache associated&lt;br /&gt;
with maintaining larger codebase as it allows to share code between various firmwares&lt;br /&gt;
and catch most errors during compilation time. Additional safety provided by Ivory&lt;br /&gt;
also helps in mission critical deployments such as robotics applications.&lt;br /&gt;
&lt;br /&gt;
Tower allows us to compose code on even higher level and allows us to write&lt;br /&gt;
concurrently safe programs by providing communication channels which are used&lt;br /&gt;
to exchange data between various components called &amp;quot;towers&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
On the backend side of things Ivory/Tower supports GCC ARM toolchain with either&lt;br /&gt;
FreeRTOS or EChronos realtime operating system. POSIX backend allows us to&lt;br /&gt;
run similar code on POSIX and MCU which is quite handy for testing or development&lt;br /&gt;
without actually using MCU itself (especially handy for protocols related development).&lt;br /&gt;
Additional backends for verification tools are also provided allowing &lt;br /&gt;
for verification of critical parts of the code.&lt;br /&gt;
&lt;br /&gt;
== Why STM32? ==&lt;br /&gt;
&lt;br /&gt;
* natively supported by ivory-tower-stm32&lt;br /&gt;
* supported by EChronos&lt;br /&gt;
* CAN peripheral&lt;br /&gt;
&lt;br /&gt;
Also core clock speeds, high amounts of flash (1Mb quite common on F4 MCUs),&lt;br /&gt;
advanced timers for 3 phase PWM generation, hardware encoder interfaces, multiple ADCs&lt;br /&gt;
for simultaneous sampling or sampling of large number of channels in sequence,&lt;br /&gt;
checksummed parts of SRAM, battery backed parts of SRAM. Good toolchain support and&lt;br /&gt;
debugging options as well - possibility to use GCC ARM toolchain and&lt;br /&gt;
GDB directly with Black Magic probe enabled programmer.&lt;/div&gt;</summary>
		<author><name>Srk</name></author>	</entry>

	</feed>