Professional Documents
Culture Documents
products and devices, such as automobile engine control systems, implantable medical devices, remote controls, oce machines, appliances, power tools, toys and
other embedded systems. By reducing the size and cost
compared to a design that uses a separate microprocessor, memory, and input/output devices, microcontrollers
make it economical to digitally control even more devices
and processes. Mixed signal microcontrollers are common, integrating analog components needed to control
non-digital electronic systems.
Some microcontrollers may use four-bit words and operate a frequencies as low as 4 kHz, for low power consumption (single-digit milliwatts or microwatts). They
will generally have the ability to retain functionality while
waiting for an event such as a button press or other interrupt; power consumption while sleeping (CPU clock
and most peripherals o) may be just nanowatts, making
many of them well suited for long lasting battery applications. Other microcontrollers may serve performancecritical roles, where they may need to act more like a
digital signal processor (DSP), with higher clock speeds
and power consumption.
1 History
The rst microprocessor was the 4-bit Intel 4004 released
in 1971, with the Intel 8008 and other more capable microprocessors becoming available over the next several
years. However, both processors required external chips
to implement a working system, raising total system cost,
and making it impossible to economically computerize
appliances.
The Smithsonian Institution credits TI engineers Gary
Boone and Michael Cochran with the successful creation of the rst microcontroller in 1971. The result of
their work was the TMS 1000, which became commercially available in 1974. It combined read-only memory,
read/write memory, processor and clock on one chip and
was targeted at embedded systems.[1]
EMBEDDED DESIGN
most successful in the companys history, and expanded three dozen microcontrollers. A typical mid-range authe divisions budget over 25%.
tomobile has as many as 30 or more microcontrollers.
Most microcontrollers at this time had concurrent vari- They can also be found in many electrical devices such
ants. One had an erasable EPROM program memory, as washing machines, microwave ovens, and telephones.
with a transparent quartz window in the lid of the package to allow it to be erased by exposure to ultraviolet light,
often used for prototyping. The other was either a mask
programmed ROM from the manufacturer for large series, or a PROM variant which was only programmable
once; sometimes this was signied with the designation OTP, standing for one-time programmable. The
PROM was of identical type of memory as the EPROM,
but because there was no way to expose it to ultraviolet light, it could not be erased. The erasable versions
required ceramic packages with quartz windows, making them signicantly more expensive than the OTP versions, which could be made in lower-cost opaque plastic
packages. For the erasable variants, quartz was required,
instead of less expensive glass, for its transparency to
ultravioletglass is largely opaque to UVbut the main
cost dierentiator was the ceramic package itself.
Historically, the 8-bit segment has dominated the MCU market [..] 16-bit microcontrollers became the largest volume MCU category in 2011, overtaking 8-bit devices for the
rst time that year [..] IC Insights believes the
makeup of the MCU market will undergo substantial changes in the next ve years with 32bit devices steadily grabbing a greater share of
sales and unit volumes. By 2017, 32-bit MCUs
are expected to account for 55% of microcontroller sales [..] In terms of unit volumes, 32-bit
MCUs are expected account for 38% of microcontroller shipments in 2017, while 16-bit
devices will represent 34% of the total, and 4/8-bit designs are forecast to be 28% of units
sold that year.
The 32-bit MCU market is expected
to grow rapidly due to increasing demand
for higher levels of precision in embeddedprocessing systems and the growth in connectivity using the Internet. [..] In the next few
years, complex 32-bit MCUs are expected to
account for over 25% of the processing power
in vehicles.
IC Insights, MCU Market on Migration
Path to 32-bit and ARM-based Devices[8]
In 1993, the introduction of EEPROM memory allowed microcontrollers (beginning with the Microchip
PIC16x84) to be electrically erased quickly without an
expensive package as required for EPROM, allowing
both rapid prototyping, and In System Programming.
(EEPROM technology had been available prior to this
time, but the earlier EEPROM was more expensive and
less durable, making it unsuitable for low-cost massproduced microcontrollers.) The same year, Atmel introduced the rst microcontroller using Flash memory,
a special type of EEPROM.[3] Other companies rapidly
followed suit, with both memory types.
In 2012, following a global crisis a worst ever annual
Cost has plummeted over time, with the cheapest 8-bit sales decline and recovery and average sales price yearmicrocontrollers being available for under 0.25 USD in over-year plunging 17% the biggest reduction since
quantity (thousands) in 2009, and some 32-bit microcon- the 1980s, the average price for a microcontroller was
US$0.88 ($0.69 for 4-/8-bit, $0.59 for 16-bit, $1.76 for
trollers around US$1 for similar quantities.
32-bit).[8]
Nowadays microcontrollers are cheap and readily available for hobbyists, with large online communities around In 2012, worldwide sales of 8-bit microcontrollers were
around $4 billion because they were so useful that many
certain processors.
companies needed them to be able to progress into betIn the future, MRAM could potentially be used in microter technology. In 2012, 4-bit microcontrollers also see
controllers as it has innite endurance and its incremental
signicant sales.[9]
semiconductor wafer process cost is relatively low.
In 2015, 8-bit microcontrollers can be bought for $0.311
(1,000 units),[10] 16-bit for $0.385 (1,000 units),[11] and
32-bit for $0.378 (1,000 units but at $0.35 for 5,000).[12]
1.1 Volumes
In 2002, about 55% of all CPUs sold in the world were
8-bit microcontrollers and microprocessors.[4] Over two
billion 8-bit microcontrollers were sold in 1997,[5] and
according to Semico, over four billion 8-bit microcontrollers were sold in 2006.[6] More recently, Semico has
claimed the MCU market grew 36.5% in 2010 and 12%
in 2011.[7]
2 Embedded design
A microcontroller can be considered a self-contained system with a processor, memory and peripherals and can be
used as an embedded system.[13] The majority of microcontrollers in use today are embedded in other machinA typical home in a developed country is likely to have ery, such as automobiles, telephones, appliances, and peonly four general-purpose microprocessors but around ripherals for computer systems.
2.2
Programs
2.2 Programs
Typically microcontroller programs must t in the available on-chip memory, since it would be costly to provide
a system with external, expandable memory. Compilers
and assemblers are used to convert both high-level and
assembly language codes into a compact machine code
for storage in the microcontrollers memory. Depending
on the device, the program memory may be permanent,
read-only memory that can only be programmed at the
factory, or it may be eld-alterable ash or erasable readonly memory.
2.1
Interrupts
HIGHER INTEGRATION
duce analog signals. This is the purpose of the analogto-digital converter (ADC). Since processors are built to
interpret and process digital data, i.e. 1s and 0s, they are
not able to do anything with the analog signals that may
be sent to it by a device. So the analog to digital converter is used to convert the incoming data into a form
that the processor can recognize. A less common feature
on some microcontrollers is a digital-to-analog converter
(DAC) that allows the processor to output analog signals
or voltage levels.
In addition to the converters, many embedded microprocessors include a variety of timers as well. One of the
most common types of timers is the Programmable Interval Timer (PIT). A PIT may either count down from
some value to zero, or up to the capacity of the count register, overowing to zero. Once it reaches zero, it sends
an interrupt to the processor indicating that it has nished
counting. This is useful for devices such as thermostats,
Die of a PIC12C508 8-bit, fully static, EEPROM/EPROM/ROMwhich periodically test the temperature around them to based CMOS microcontroller manufactured by Microchip Techsee if they need to turn the air conditioner on, the heater nology using a 1200 nanometre process.
on, etc.
A dedicated Pulse Width Modulation (PWM) block
makes it possible for the CPU to control power converters, resistive loads, motors, etc., without using lots of
CPU resources in tight timer loops.
Universal Asynchronous Receiver/Transmitter (UART)
block makes it possible to receive and transmit data over a
serial line with very little load on the CPU. Dedicated onchip hardware also often includes capabilities to communicate with other devices (chips) in digital formats such as
Inter-Integrated Circuit (IC), Serial Peripheral Interface
(SPI), Universal Serial Bus (USB), and Ethernet.[14]
Higher integration
Serial Peripheral Interface and Controller Area Net- languages, such as Python and JavaScript, are now also
work for system interconnect
in common use to target microcontrollers and embedded
systems.[16] These languages are either designed specially
peripherals such as timers, event counters, PWM
for the purpose, or versions of general purpose languages
generators, and watchdog
such as the C programming language. Compilers for
clock generator - often an oscillator for a quartz tim- general purpose languages will typically have some restrictions as well as enhancements to better support the
ing crystal, resonator or RC circuit
unique characteristics of microcontrollers. Some mimany include analog-to-digital converters, some in- crocontrollers have environments to aid developing cerclude digital-to-analog converters
tain types of applications. Microcontroller vendors often
in-circuit programming and in-circuit debugging make tools freely available to make it easier to adopt their
hardware.
support
Interpreter rmware is also available for some microcontrollers. For example, BASIC on the early microcontrollers Intel 8052;[17] BASIC and FORTH on the Zilog
Micro-controllers have proved to be highly popular in Z8[18] as well as some modern devices. Typically these
embedded systems since their introduction in the 1970s. interpreters support interactive programming.
Some microcontrollers use a Harvard architecture: sepa- Simulators are available for some microcontrollers.
rate memory buses for instructions and data, allowing ac- These allow a developer to analyze what the behavior of
cesses to take place concurrently. Where a Harvard archi- the microcontroller and their program should be if they
tecture is used, instruction words for the processor may were using the actual part. A simulator will show the inbe a dierent bit size than the length of internal memory ternal processor state and also that of the outputs, as well
and registers; for example: 12-bit instructions used with as allowing input signals to be generated. While on the
8-bit data registers.
one hand most simulators will be limited from being unThe decision of which peripheral to integrate is often difcult. The microcontroller vendors often trade operating frequencies and system design exibility against timeto-market requirements from their customers and overall lower system cost. Manufacturers have to balance the
need to minimize the chip size against additional functionality.
Programming environments
AVR32 (32-bit),
and
6 INTERRUPT LATENCY
Cypress Semiconductor's M8C Core used in their When an electronic device causes an interrupt, during the
PSoC (Programmable System-on-Chip)
context switch the intermediate results (registers) have to
be saved before the software responsible for handling the
Freescale ColdFire (32-bit) and S08 (8-bit)
interrupt can run. They must also be restored after that
interrupt handler is nished. If there are more processor
Freescale 68HC11 (8-bit), and others based on the
registers, this saving and restoring process takes more
Motorola 6800 family
time, increasing the latency. Ways to reduce such con Intel 8051, also manufactured by NXP Semiconduc- text/restore latency include having relatively few registers
in their central processing units (undesirable because it
tors, Inneon and many others
slows down most non-interrupt processing substantially),
Inneon: 8-bit XC800, 16-bit XE166, 32- or at least having the hardware not save them all (this fails
bit XMC4000 (ARM based Cortex M4F), if the software then needs to compensate by saving the
32-bit TriCore and, 32-bit Aurix Tricore Bit rest manually). Another technique involves spending
microcontrollers[19]
silicon gates on shadow registers": One or more duplicate registers used only by the interrupt software, perhaps
MIPS
supporting a dedicated stack.
Microchip Technology PIC, (8-bit PIC16, PIC18, Other factors aecting interrupt latency include:
16-bit dsPIC33 / PIC24), (32-bit PIC32)
Cycles needed to complete current CPU activi NXP Semiconductors LPC1000, LPC2000,
ties. To minimize those costs, microcontrollers tend
LPC3000, LPC4000 (32-bit), LPC900, LPC700
to have short pipelines (often three instructions or
(8-bit)
less), small write buers, and ensure that longer instructions are continuable or restartable. RISC de Parallax Propeller
sign principles ensure that most instructions take the
same number of cycles, helping avoid the need for
PowerPC ISE
most such continuation/restart logic.
Rabbit 2000 (8-bit)
The length of any critical section that needs to be
Renesas Electronics: RL78 16-bit MCU; RX 32-bit
interrupted. Entry to a critical section restricts conMCU; SuperH; V850 32-bit MCU; H8; R8C 16-bit
current data structure access. When a data structure
MCU
must be accessed by an interrupt handler, the critical section must block that interrupt. Accordingly,
Silicon Laboratories Pipelined 8-bit 8051 Microinterrupt latency is increased by however long that
controllers and mixed-signal ARM-based 32-bit miinterrupt is blocked. When there are hard external
crocontrollers
constraints on system latency, developers often need
tools to measure interrupt latencies and track down
STMicroelectronics STM8 (8-bit), ST10 (16-bit)
which critical sections cause slowdowns.
and STM32 (32-bit)
Texas Instruments TI MSP430 (16-bit), MSP432
(32-bit), C2000 (32-bit)
Toshiba TLCS-870 (8-bit/16-bit)
Interrupt latency
In contrast to general-purpose computers, microcontrollers used in embedded systems often seek to optimize
interrupt latency over instruction throughput. Issues include both reducing the latency, and making it be more
predictable (to support real-time control).
One common technique just blocks all interrupts for the duration of the critical section.
This is easy to implement, but sometimes critical sections get uncomfortably long.
A more complex technique just blocks the interrupts that may trigger access to that data
structure. This is often based on interrupt priorities, which tend to not correspond well to
the relevant system data structures. Accordingly, this technique is used mostly in very
constrained environments.
Processors may have hardware support for
some critical sections. Examples include supporting atomic access to bits or bytes within
a word, or other atomic access primitives like
the LDREX/STREX exclusive access primitives introduced in the ARMv6 architecture.
Interrupt nesting. Some microcontrollers allow
higher priority interrupts to interrupt lower priority ones. This allows software to manage latency
7
by giving time-critical interrupts higher priority (and
thus lower and more predictable latency) than lesscritical ones.
Trigger rate. When interrupts occur back-toback, microcontrollers may avoid an extra context
save/restore cycle by a form of tail call optimization.
Lower end microcontrollers tend to support fewer interrupt latency controls than higher end ones.
9 References
7
7.1
Data
[8] MCU Market on Migration Path to 32-bit and ARMbased Devices. April 25, 2013. It typically takes a global
economic recession to upset the diverse MCU marketplace, and thats exactly what occurred in 2009, when
the microcontroller business suered its worst-ever annual sales decline of 22% to $11.1 billion.
7.2
Firmware
See also
List of common microcontrollers
[13] Heath, Steve (2003). Embedded systems design. EDN series for design engineers (2 ed.). Newnes. pp. 1112.
ISBN 9780750655460.
10
[14] David Harris & Sarah Harris (2012). Digital Design and
Computer Architecture, Second Edition, p. 515. Morgan
Kaufmann. ISBN 0123944244.
[15] Easy Way to build a microcontroller project
[16] Mazzei, Daniele; Montelisciani, Gabriele; Baldi, Giacomo; Fantoni, Gualtiero (2015). Changing the programming paradigm for the embedded in the IoT domain. Internet of Things (WF-IoT), 2015 IEEE 2nd World Forum on. Milan: IEEE. pp. 239244. doi:10.1109/WFIoT.2015.7389059.
[17] 8052-Basic Microcontrollers by Jan Axelson 1994
[18] Edwards, Robert (1987). Optimizing the Zilog Z8 Forth
Microcontroller for Rapid Prototyping (PDF). Martin
Marietta: 3. Retrieved 9 December 2012.
[19] www.infineon.com/mcu
[20] Microchip unveils PIC16C84, a reprogrammable
EEPROM-based 8-bit microcontroller 1993
10
External links
Microcontroller at DMOZ
Embedded Systems Design magazine
EXTERNAL LINKS
11
11.1
Microcontroller Source: https://en.wikipedia.org/wiki/Microcontroller?oldid=733831392 Contributors: AxelBoldt, Derek Ross, PierreAbbat, Ben-Zin~enwiki, Maury Markowitz, Heron, Kwertii, Mahjongg, Mbessey, CesarB, Egil, Stan Shebs, Mac, Docu, Theresa knott,
Glenn, Jonik, GRAHAMUK, JidGom, Omegatron, Wernher, Jni, Robbot, Izx, Chris 73, Hemanshu, Roscoe x, Giftlite, Andries, DavidCary, Cathy Linton, Solipsist, Matt Crypto, Bobblewik, Edderly, Imroy, CALR, Discospinster, Rich Farmbrough, Rhobite, Gejigeji~enwiki,
Adam850, WikiPediaAid, Dyl, ESkog, Calamarain, CanisRufus, Femto, Bobo192, Netaimaid, Cje~enwiki, Shenme, R. S. Shaw, Matt
Britt, Foobaz, Colin Douglas Howell, Cheung1303, Hooperbloob, Alansohn, Atlant, Corwin8, Nasukaren, Pion, Wtmitchell, Velella, Wtshymanski, Mlut, Cburnett, Suruena, RainbowOfLight, Voxadam, Bookandcoee, Ceyockey, Mindmatrix, Hdante, Palica, Ketiltrout,
Rjwilmsi, Seidenstud, Zbxgscqf, Jasoneth, FlaBot, Heycam, Margosbot~enwiki, RexNL, Ewlyahoocom, Lmatt, Jidan, Krishnavedala,
Maluc, YurikBot, Wavelength, Spacepotato, RussBot, Stephenb, Gaius Cornelius, Rsrikanth05, TheMandarin, Ben b, Speedevil, Voidxor,
Bota47, Scope creep, Microco~enwiki, LanguidMandala, Tevildo, Allens, Ianhopkins, GrinBot~enwiki, Benhoyt, Attilios, Yakudza,
Joshbuddy, SmackBot, Sagie, Reedy, Maelwys, Henriok, Unyoyega, Davewild, Clpo13, InTheCastle~enwiki, Sloman, Gilliam, Lindosland, PATCheS, Chris the speller, DStoykov, TheParallax, CSWarren, ZyMOS, DHN-bot~enwiki, A. B., Hobiadami, Furby100, JonHarder, LouScheer, Addshore, Allan McInnes, Easwarno1, Radagast83, Clean Copy, Yrogerg, Doodle77, Wizardman, Nishkid64, Kuru,
Steve1608, The.happy.hippy, Petter73, Chrisch, CyrilB, Dicklyon, PeterJohnBishop, Jouthus, Lbokma, StephenBuxton, UncleDouggie, Drvanthorp, Menswear, Az1568, Tawkerbot2, Electron20, Mikiemike, Anon user, Ilikefood, Pfagerburg~enwiki, Nczempin, JPats, Timichal,
HenkeB, Cbmeeks, AndrewHowse, Mblumber, Mato, Vwollan, Travelbird, Kozuch, Mtpaley, Gcalac, Thijs!bot, Tom d perkins, Electron9, Turkeyphant, Brewsum, Ebde, AntiVandalBot, Majorly, Guy Macon, QuiteUnusual, Quintote, Lovibond, Obsessiveatbest, Deadbeef, JAnDbot, Viskr, CosineKitty, RastaKins, Jahoe, LittleOldMe, Magioladitis, Bongwarrior, VoABot II, SoccerCore11, M 3bdelqader,
Zedomax, ANONYMOUS COWARD0xC0DE, Kerdip, Kphowell, Calltech, Gwern, MartinBot, Moggie2002, GoldenMeadows, PJohnson, Axlq, Bogey97, Jiuguang Wang, Cpiral, Qratman, NewEnglandYankee, Stevemcl10, Cometstyles, Diwakarbista, VolkovBot, ICE77,
Kevinkor2, AlnoktaBOT, Philip Trueman, Pfrulas, TXiKiBoT, Sarenne, Gcarter68, Timmh, Andy Dingley, Usman365, Falcon8765, Neoame, SieBot, Scarian, BotMultichill, GlassCobra, Reinderien, Lisatwo, Lightmouse, Frappucino, A Sengupta, Asher196, ClueBot, GorillaWarfare, Snigbrook, The Thing That Should Not Be, Cambrasa, Rilak, Hysocc, Kiu77, Niceguyedc, Blanchardb, Na7id, Kanishafa,
DragonBot, Foadsabori, Excirial, Anonymous101, Abrech, Alikian, Andreas Gro, Chaosdruid, C628, SoxBot III, Ginbot86, DumZiBoT,
Joel Saks, XLinkBot, Jmont1, Parallelized, Skarebo, Suresh1686, Zodon, Nikhilb239, Otisjimmy1, MrOllie, Download, Glass Sword,
Chzz, OlEnglish, Vanuan, Tartarus, Luckas-bot, Yobot, Ptbotgourou, Fraggle81, DJ LoPaTa, Jmicko, Samtar, Thaiio, Clara Anthony,
AnomieBOT, KDS4444, 1exec1, Jim1138, Kingpin13, Kushagraalankar, Materialscientist, Thisara.d.m, Rmaax, Juhuang, Xqbot, Capricorn42, Oborg, Victor Waiman, J04n, Geekstu, Locobot, Secondwatch, Madison Alex, Aspwiki, Imperators II, FrescoBot, D'ohBot,
Ionutzmovie, Steve Quinn, Fuadamjala, A8UDI, NKanngaz, Mikespedia, Gapaddict, TobeBot, Codinghead, Fox Wilson, Vrenator, Zvn,
Ravikumar001, RjwilmsiBot, Dhiraj1984, PoPCulture69, Dead Horsey, Alex3yoyo, Winner 42, K6ka, Langermannia, John Cline, F,
Russell ti, A930913, Malikqasim, Willem7, Erianna, Sbmeirow, Coasterlover1994, Donner60, Whiteneon, Davewave88, Mcunerd, ClueBot NG, MSCI in space, Aleksandarbrain, Techeditor1, Kubing, Wosch21149, Amith deshpande, Widr, Danim, Iswantoumy, Calabe1992,
Microheat, BG19bot, Bmusician, Barewires, Wiki13, Akkazemi, Eagle c5, Snow Blizzard, Pratyya Ghosh, ChrisGualtieri, Dhx1, Usmanmustafa4u786, Gnetscher, Mogism, Rashid Mehmood Khokhar, Vahid alpha, Kyohyi, David CMT, Semonti, Comp.arch, Ugog Nizdast,
Sam Sailor, Inaaaa, Withnoe, Div2005, Ali.Zeineddine93, Lagoset, TerryAlex, Engr Wasim Khan, Pramod Sahu957, Jfolkens, KasparBot,
Luigi Francesco Cerfeda, Srednuas Lenoroc, Jomonthomasnew, Crtrtrc, CLCStudent, Ramarokie60, Oludu and Anonymous: 530
11.2
Images
File:153056995_5ef8b01016_o.jpg Source: https://upload.wikimedia.org/wikipedia/commons/6/64/Intel_8742_153056995.jpg License: CC BY-SA 2.0 Contributors: http://www.flickr.com/photos/biwook/153056995/ Original artist: Ioan Sameli
File:Commons-logo.svg Source: https://upload.wikimedia.org/wikipedia/en/4/4a/Commons-logo.svg License: CC-BY-SA-3.0 Contributors: ? Original artist: ?
File:Microcontrollers_Atmega32_Atmega8.jpg Source: https://upload.wikimedia.org/wikipedia/commons/c/c8/Microcontrollers_
Atmega32_Atmega8.jpg License: CC BY 3.0 Contributors: Transferred from en.wikipedia to Commons. Original artist: Vahid alpha
at English Wikipedia
File:Nuvola_apps_ksim.png Source: https://upload.wikimedia.org/wikipedia/commons/8/8d/Nuvola_apps_ksim.png License: LGPL
Contributors: http://icon-king.com Original artist: David Vignoni / ICON KING
File:PIC12C508-HD.jpg Source: https://upload.wikimedia.org/wikipedia/commons/d/d0/PIC12C508-HD.jpg License: CC BY 3.0 Contributors: http://zeptobars.ru/en/read/open-microchip-asic-what-inside-II-msp430-pic-z80 Original artist: ZeptoBars
File:PIC18F8720.jpg Source: https://upload.wikimedia.org/wikipedia/commons/1/18/PIC18F8720.jpg License: Public domain Contributors: ? Original artist: ?
File:Question_book-new.svg Source: https://upload.wikimedia.org/wikipedia/en/9/99/Question_book-new.svg License: Cc-by-sa-3.0
Contributors:
Created from scratch in Adobe Illustrator. Based on Image:Question book.png created by User:Equazcion Original artist:
Tkgd2007
File:STM32F100C4T6B-HD.jpg Source: https://upload.wikimedia.org/wikipedia/commons/6/67/STM32F100C4T6B-HD.jpg License:
CC BY 3.0 Contributors: http://zeptobars.ru/en/read/how-to-open-microchip-asic-what-inside Original artist: ZeptoBars
File:Text_document_with_red_question_mark.svg Source: https://upload.wikimedia.org/wikipedia/commons/a/a4/Text_document_
with_red_question_mark.svg License: Public domain Contributors: Created by bdesham with Inkscape; based upon Text-x-generic.svg
from the Tango project. Original artist: Benjamin D. Esham (bdesham)
File:Wikibooks-logo.svg Source: https://upload.wikimedia.org/wikipedia/commons/f/fa/Wikibooks-logo.svg License: CC BY-SA 3.0
Contributors: Own work Original artist: User:Bastique, User:Ramac et al.
10
11
11.3
Content license