<?xml version='1.0' encoding='UTF-8' standalone='no'?> <doxygen xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="compound.xsd" version="1.8.16"> <compounddef id="i386_2spinlock_8c" kind="file" language="C++"> <compoundname>spinlock.c</compoundname> <includes refid="__null_8h" local="no">sys/_null.h</includes> <includes refid="spinlock_8h" local="no">ubixos/spinlock.h</includes> <includes refid="sched_8h" local="no">ubixos/sched.h</includes> <includes refid="string_8h" local="no">string.h</includes> <incdepgraph> <node id="23"> <label>ufs/ufs.h</label> <link refid="ufs_8h"/> <childnode refid="4" relation="include"> </childnode> <childnode refid="24" relation="include"> </childnode> </node> <node id="27"> <label>sys/tss.h</label> <link refid="tss_8h"/> <childnode refid="4" relation="include"> </childnode> </node> <node id="26"> <label>ubixos/tty.h</label> <link refid="tty_8h"/> <childnode refid="4" relation="include"> </childnode> </node> <node id="29"> <label>strings.h</label> <link refid="strings_8h"/> <childnode refid="4" relation="include"> </childnode> </node> <node id="16"> <label>i386/cpu.h</label> <link refid="i386_2cpu_8h"/> <childnode refid="4" relation="include"> </childnode> </node> <node id="6"> <label>sys/select.h</label> <link refid="select_8h"/> <childnode refid="7" relation="include"> </childnode> <childnode refid="5" relation="include"> </childnode> <childnode refid="8" relation="include"> </childnode> <childnode refid="9" relation="include"> </childnode> <childnode refid="10" relation="include"> </childnode> </node> <node id="19"> <label>vfs/inode.h</label> <link refid="inode_8h"/> <childnode refid="4" relation="include"> </childnode> <childnode refid="20" relation="include"> </childnode> <childnode refid="21" relation="include"> </childnode> <childnode refid="22" relation="include"> </childnode> <childnode refid="23" relation="include"> </childnode> </node> <node id="1"> <label>C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c</label> <link refid="i386_2spinlock_8c"/> <childnode refid="2" relation="include"> </childnode> <childnode refid="3" relation="include"> </childnode> <childnode refid="11" relation="include"> </childnode> <childnode refid="28" relation="include"> </childnode> </node> <node id="3"> <label>ubixos/spinlock.h</label> <link refid="spinlock_8h"/> <childnode refid="4" relation="include"> </childnode> </node> <node id="10"> <label>sys/_sigset.h</label> <link refid="__sigset_8h"/> <childnode refid="5" relation="include"> </childnode> </node> <node id="25"> <label>vfs/mount.h</label> <link refid="mount_8h"/> <childnode refid="4" relation="include"> </childnode> </node> <node id="18"> <label>sys/resource.h</label> <link refid="resource_8h"/> <childnode refid="5" relation="include"> </childnode> </node> <node id="15"> <label>sys/trap.h</label> <link refid="trap_8h"/> <childnode refid="16" relation="include"> </childnode> </node> <node id="2"> <label>sys/_null.h</label> <link refid="__null_8h"/> </node> <node id="28"> <label>string.h</label> <link refid="string_8h"/> <childnode refid="4" relation="include"> </childnode> <childnode refid="29" relation="include"> </childnode> </node> <node id="4"> <label>sys/types.h</label> <link refid="include_2sys_2types_8h"/> <childnode refid="5" relation="include"> </childnode> <childnode refid="6" relation="include"> </childnode> </node> <node id="12"> <label>vfs/file.h</label> <link refid="include_2vfs_2file_8h"/> <childnode refid="4" relation="include"> </childnode> <childnode refid="13" relation="include"> </childnode> <childnode refid="14" relation="include"> </childnode> <childnode refid="19" relation="include"> </childnode> <childnode refid="25" relation="include"> </childnode> <childnode refid="23" relation="include"> </childnode> </node> <node id="22"> <label>fs/msdos_fs.h</label> <link refid="msdos__fs_8h"/> </node> <node id="17"> <label>sys/signal.h</label> <link refid="sys_2signal_8h"/> <childnode refid="4" relation="include"> </childnode> </node> <node id="21"> <label>fs/pipe_fs.h</label> <link refid="pipe__fs_8h"/> </node> <node id="20"> <label>ubixos/wait.h</label> <link refid="wait_8h"/> </node> <node id="14"> <label>sys/thread.h</label> <link refid="thread_8h"/> <childnode refid="4" relation="include"> </childnode> <childnode refid="15" relation="include"> </childnode> <childnode refid="17" relation="include"> </childnode> <childnode refid="18" relation="include"> </childnode> </node> <node id="7"> <label>sys/cdefs.h</label> <link refid="cdefs_8h"/> </node> <node id="11"> <label>ubixos/sched.h</label> <link refid="sched_8h"/> <childnode refid="4" relation="include"> </childnode> <childnode refid="12" relation="include"> </childnode> <childnode refid="26" relation="include"> </childnode> <childnode refid="27" relation="include"> </childnode> <childnode refid="14" relation="include"> </childnode> </node> <node id="5"> <label>sys/_types.h</label> <link refid="__types_8h"/> </node> <node id="8"> <label>sys/_timespec.h</label> <link refid="__timespec_8h"/> <childnode refid="5" relation="include"> </childnode> </node> <node id="24"> <label>sys/device.h</label> <link refid="include_2sys_2device_8h"/> <childnode refid="4" relation="include"> </childnode> </node> <node id="13"> <label>ubixfs/dirCache.h</label> <link refid="dirCache_8h"/> <childnode refid="4" relation="include"> </childnode> </node> <node id="9"> <label>sys/_timeval.h</label> <link refid="__timeval_8h"/> <childnode refid="5" relation="include"> </childnode> </node> </incdepgraph> <sectiondef kind="define"> <memberdef kind="define" id="i386_2spinlock_8c_1a98eeefbec68bcb915a01f12e4ebdefd5" prot="public" static="no"> <name>atomic_add</name> <param><defname>P</defname></param> <param><defname>V</defname></param> <initializer>__sync_add_and_fetch((P), (V))</initializer> <briefdescription> </briefdescription> <detaileddescription> </detaileddescription> <inbodydescription> </inbodydescription> <location file="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" line="38" column="9" bodyfile="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" bodystart="38" bodyend="-1"/> </memberdef> <memberdef kind="define" id="i386_2spinlock_8c_1ac3b21a79504f9ee98f451f9f7092170d" prot="public" static="no"> <name>atomic_clear_bit</name> <param><defname>P</defname></param> <param><defname>V</defname></param> <initializer>__sync_and_and_fetch((P), ~(1<<(V)))</initializer> <briefdescription> </briefdescription> <detaileddescription> </detaileddescription> <inbodydescription> </inbodydescription> <location file="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" line="40" column="9" bodyfile="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" bodystart="40" bodyend="-1"/> </memberdef> <memberdef kind="define" id="i386_2spinlock_8c_1a59c16c0e6ca2a4509a89b4095897f29f" prot="public" static="no"> <name>atomic_dec</name> <param><defname>P</defname></param> <initializer>__sync_add_and_fetch((P), -1)</initializer> <briefdescription> </briefdescription> <detaileddescription> </detaileddescription> <inbodydescription> </inbodydescription> <location file="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" line="37" column="9" bodyfile="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" bodystart="37" bodyend="-1"/> </memberdef> <memberdef kind="define" id="i386_2spinlock_8c_1a45a583ebc7ce181c15688c871f955e98" prot="public" static="no"> <name>atomic_inc</name> <param><defname>P</defname></param> <initializer>__sync_add_and_fetch((P), 1)</initializer> <briefdescription> </briefdescription> <detaileddescription> </detaileddescription> <inbodydescription> </inbodydescription> <location file="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" line="36" column="9" bodyfile="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" bodystart="36" bodyend="-1"/> </memberdef> <memberdef kind="define" id="i386_2spinlock_8c_1ac8aeecdc7ff00f1c46d5a91a73db87dd" prot="public" static="no"> <name>atomic_set_bit</name> <param><defname>P</defname></param> <param><defname>V</defname></param> <initializer>__sync_or_and_fetch((P), 1<<(V))</initializer> <briefdescription> </briefdescription> <detaileddescription> </detaileddescription> <inbodydescription> </inbodydescription> <location file="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" line="39" column="9" bodyfile="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" bodystart="39" bodyend="-1"/> </memberdef> <memberdef kind="define" id="i386_2spinlock_8c_1a97c020c88ee892bb5a3055d5a68c9788" prot="public" static="no"> <name>atomic_xadd</name> <param><defname>P</defname></param> <param><defname>V</defname></param> <initializer>__sync_fetch_and_add((P), (V))</initializer> <briefdescription> </briefdescription> <detaileddescription> </detaileddescription> <inbodydescription> </inbodydescription> <location file="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" line="34" column="9" bodyfile="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" bodystart="34" bodyend="-1"/> </memberdef> <memberdef kind="define" id="i386_2spinlock_8c_1a53290ac2df2384738b8769c76622f803" prot="public" static="no"> <name>barrier</name> <param></param> <initializer><ref refid="idt_8c_1af03c996a639f5610a8514c6e6f8d15e6" kindref="member">asm</ref> <ref refid="cdefs_8h_1af55a5e48555be7d32ad73e76cf5d4db0" kindref="member">volatile</ref>("": : :"memory")</initializer> <briefdescription> </briefdescription> <detaileddescription> </detaileddescription> <inbodydescription> </inbodydescription> <location file="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" line="42" column="9" bodyfile="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" bodystart="42" bodyend="-1"/> </memberdef> <memberdef kind="define" id="i386_2spinlock_8c_1a2ecfcce98539a0b972d6fa2586c4e67f" prot="public" static="no"> <name>cmpxchg</name> <param><defname>P</defname></param> <param><defname>O</defname></param> <param><defname>N</defname></param> <initializer>__sync_val_compare_and_swap((P), (O), (N))</initializer> <briefdescription> </briefdescription> <detaileddescription> </detaileddescription> <inbodydescription> </inbodydescription> <location file="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" line="35" column="9" bodyfile="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" bodystart="35" bodyend="-1"/> </memberdef> <memberdef kind="define" id="i386_2spinlock_8c_1a89af7a9ebf21399bcbd8e892b6f3d41a" prot="public" static="no"> <name>cpu_relax</name> <param></param> <initializer><ref refid="idt_8c_1af03c996a639f5610a8514c6e6f8d15e6" kindref="member">asm</ref> <ref refid="cdefs_8h_1af55a5e48555be7d32ad73e76cf5d4db0" kindref="member">volatile</ref>("pause\n": : :"memory")</initializer> <briefdescription> </briefdescription> <detaileddescription> </detaileddescription> <inbodydescription> </inbodydescription> <location file="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" line="45" column="9" bodyfile="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" bodystart="45" bodyend="-1"/> </memberdef> </sectiondef> <sectiondef kind="func"> <memberdef kind="function" id="i386_2spinlock_8c_1a0c58bcf16e5750a53054b545f314c3dc" prot="public" static="no" const="no" explicit="no" inline="no" virt="non-virtual"> <type>void</type> <definition>void spinLock</definition> <argsstring>(spinLock_t lock)</argsstring> <name>spinLock</name> <param> <type><ref refid="spinlock_8h_1a205601d674593c0fff0a54719d27465b" kindref="member">spinLock_t</ref></type> <declname>lock</declname> </param> <briefdescription> </briefdescription> <detaileddescription> </detaileddescription> <inbodydescription> </inbodydescription> <location file="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" line="64" column="6" bodyfile="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" bodystart="64" bodyend="71"/> </memberdef> <memberdef kind="function" id="i386_2spinlock_8c_1ae17adaacb59f9cc8f63d81373be35a99" prot="public" static="no" const="no" explicit="no" inline="no" virt="non-virtual"> <type>void</type> <definition>void spinLockInit</definition> <argsstring>(spinLock_t lock)</argsstring> <name>spinLockInit</name> <param> <type><ref refid="spinlock_8h_1a205601d674593c0fff0a54719d27465b" kindref="member">spinLock_t</ref></type> <declname>lock</declname> </param> <briefdescription> </briefdescription> <detaileddescription> </detaileddescription> <inbodydescription> </inbodydescription> <location file="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" line="47" column="6" bodyfile="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" bodystart="47" bodyend="49"/> <references refid="string_8h_1ace4b911463887af5e748326323e99a23">memset</references> </memberdef> <memberdef kind="function" id="i386_2spinlock_8c_1afd90c47975d942a2fdf7c2bc0ff58ea1" prot="public" static="no" const="no" explicit="no" inline="no" virt="non-virtual"> <type>int</type> <definition>int spinTryLock</definition> <argsstring>(spinLock_t lock)</argsstring> <name>spinTryLock</name> <param> <type><ref refid="spinlock_8h_1a205601d674593c0fff0a54719d27465b" kindref="member">spinLock_t</ref></type> <declname>lock</declname> </param> <briefdescription> </briefdescription> <detaileddescription> </detaileddescription> <inbodydescription> </inbodydescription> <location file="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" line="51" column="5" bodyfile="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" bodystart="51" bodyend="57"/> <references refid="i386_2spinlock_8c_1a2ecfcce98539a0b972d6fa2586c4e67f" compoundref="i386_2spinlock_8c" startline="35">cmpxchg</references> <references refid="spinlock_8h_1aef31df4fa10911959af449d9f3ccf78f" compoundref="spinlock_8h" startline="37">LLOCK_FLAG</references> <references refid="spinlock_8h_1a00de8f7e0b615f88335573ba3909583d" compoundref="spinlock_8h" startline="34">LOCKED</references> <references refid="structspinLock_1a243edf7f3d81de2a9c7e3852768e5847" compoundref="spinlock_8h" startline="43">spinLock::locked</references> <references refid="fat__string_8h_1a070d2ce7b6bb7e5c05602aa8c308d0c4" compoundref="fat__string_8h" startline="17">NULL</references> </memberdef> <memberdef kind="function" id="i386_2spinlock_8c_1ac2d032c89ee37bb624eb87b9954f4a1e" prot="public" static="no" const="no" explicit="no" inline="no" virt="non-virtual"> <type>void</type> <definition>void spinUnlock</definition> <argsstring>(spinLock_t lock)</argsstring> <name>spinUnlock</name> <param> <type><ref refid="spinlock_8h_1a205601d674593c0fff0a54719d27465b" kindref="member">spinLock_t</ref></type> <declname>lock</declname> </param> <briefdescription> </briefdescription> <detaileddescription> </detaileddescription> <inbodydescription> </inbodydescription> <location file="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" line="59" column="6" bodyfile="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c" bodystart="59" bodyend="62"/> <references refid="i386_2spinlock_8c_1a53290ac2df2384738b8769c76622f803" compoundref="i386_2spinlock_8c" startline="42">barrier</references> <references refid="structspinLock_1a243edf7f3d81de2a9c7e3852768e5847" compoundref="spinlock_8h" startline="43">spinLock::locked</references> </memberdef> </sectiondef> <briefdescription> </briefdescription> <detaileddescription> </detaileddescription> <programlisting> <codeline lineno="1"><highlight class="comment">/*-</highlight></codeline> <codeline lineno="2"><highlight class="comment"><sp/>*<sp/>Copyright<sp/>(c)<sp/>2002-2018<sp/>The<sp/>UbixOS<sp/>Project.</highlight></codeline> <codeline lineno="3"><highlight class="comment"><sp/>*<sp/>All<sp/>rights<sp/>reserved.</highlight></codeline> <codeline lineno="4"><highlight class="comment"><sp/>*</highlight></codeline> <codeline lineno="5"><highlight class="comment"><sp/>*<sp/>This<sp/>was<sp/>developed<sp/>by<sp/>Christopher<sp/>W.<sp/>Olsen<sp/>for<sp/>the<sp/>UbixOS<sp/>Project.</highlight></codeline> <codeline lineno="6"><highlight class="comment"><sp/>*</highlight></codeline> <codeline lineno="7"><highlight class="comment"><sp/>*<sp/>Redistribution<sp/>and<sp/>use<sp/>in<sp/>source<sp/>and<sp/>binary<sp/>forms,<sp/>with<sp/>or<sp/>without<sp/>modification,<sp/>are<sp/>permitted</highlight></codeline> <codeline lineno="8"><highlight class="comment"><sp/>*<sp/>provided<sp/>that<sp/>the<sp/>following<sp/>conditions<sp/>are<sp/>met:</highlight></codeline> <codeline lineno="9"><highlight class="comment"><sp/>*</highlight></codeline> <codeline lineno="10"><highlight class="comment"><sp/>*<sp/>1)<sp/>Redistributions<sp/>of<sp/>source<sp/>code<sp/>must<sp/>retain<sp/>the<sp/>above<sp/>copyright<sp/>notice,<sp/>this<sp/>list<sp/>of</highlight></codeline> <codeline lineno="11"><highlight class="comment"><sp/>*<sp/><sp/><sp/><sp/>conditions,<sp/>the<sp/>following<sp/>disclaimer<sp/>and<sp/>the<sp/>list<sp/>of<sp/>authors.</highlight></codeline> <codeline lineno="12"><highlight class="comment"><sp/>*<sp/>2)<sp/>Redistributions<sp/>in<sp/>binary<sp/>form<sp/>must<sp/>reproduce<sp/>the<sp/>above<sp/>copyright<sp/>notice,<sp/>this<sp/>list<sp/>of</highlight></codeline> <codeline lineno="13"><highlight class="comment"><sp/>*<sp/><sp/><sp/><sp/>conditions,<sp/>the<sp/>following<sp/>disclaimer<sp/>and<sp/>the<sp/>list<sp/>of<sp/>authors<sp/>in<sp/>the<sp/>documentation<sp/>and/or</highlight></codeline> <codeline lineno="14"><highlight class="comment"><sp/>*<sp/><sp/><sp/><sp/>other<sp/>materials<sp/>provided<sp/>with<sp/>the<sp/>distribution.</highlight></codeline> <codeline lineno="15"><highlight class="comment"><sp/>*<sp/>3)<sp/>Neither<sp/>the<sp/>name<sp/>of<sp/>the<sp/>UbixOS<sp/>Project<sp/>nor<sp/>the<sp/>names<sp/>of<sp/>its<sp/>contributors<sp/>may<sp/>be<sp/>used<sp/>to</highlight></codeline> <codeline lineno="16"><highlight class="comment"><sp/>*<sp/><sp/><sp/><sp/>endorse<sp/>or<sp/>promote<sp/>products<sp/>derived<sp/>from<sp/>this<sp/>software<sp/>without<sp/>specific<sp/>prior<sp/>written</highlight></codeline> <codeline lineno="17"><highlight class="comment"><sp/>*<sp/><sp/><sp/><sp/>permission.</highlight></codeline> <codeline lineno="18"><highlight class="comment"><sp/>*</highlight></codeline> <codeline lineno="19"><highlight class="comment"><sp/>*<sp/>THIS<sp/>SOFTWARE<sp/>IS<sp/>PROVIDED<sp/>BY<sp/>THE<sp/>AUTHOR<sp/>AND<sp/>CONTRIBUTORS<sp/>"AS<sp/>IS"<sp/>AND<sp/>ANY<sp/>EXPRESS<sp/>OR<sp/>IMPLIED</highlight></codeline> <codeline lineno="20"><highlight class="comment"><sp/>*<sp/>WARRANTIES,<sp/>INCLUDING,<sp/>BUT<sp/>NOT<sp/>LIMITED<sp/>TO,<sp/>THE<sp/>IMPLIED<sp/>WARRANTIES<sp/>OF<sp/>MERCHANTABILITY<sp/>AND<sp/>FITNESS</highlight></codeline> <codeline lineno="21"><highlight class="comment"><sp/>*<sp/>FOR<sp/>A<sp/>PARTICULAR<sp/>PURPOSE<sp/>ARE<sp/>DISCLAIMED.<sp/>IN<sp/>NO<sp/>EVENT<sp/>SHALL<sp/>THE<sp/>COPYRIGHT<sp/>OWNER<sp/>OR<sp/>CONTRIBUTORS</highlight></codeline> <codeline lineno="22"><highlight class="comment"><sp/>*<sp/>BE<sp/>LIABLE<sp/>FOR<sp/>ANY<sp/>DIRECT,<sp/>INDIRECT,<sp/>INCIDENTAL,<sp/>SPECIAL,<sp/>EXEMPLARY,<sp/>OR<sp/>CONSEQUENTIAL<sp/>DAMAGES</highlight></codeline> <codeline lineno="23"><highlight class="comment"><sp/>*<sp/>(INCLUDING,<sp/>BUT<sp/>NOT<sp/>LIMITED<sp/>TO,<sp/>PROCUREMENT<sp/>OF<sp/>SUBSTITUTE<sp/>GOODS<sp/>OR<sp/>SERVICES;<sp/>LOSS<sp/>OF<sp/>USE,<sp/>DATA,</highlight></codeline> <codeline lineno="24"><highlight class="comment"><sp/>*<sp/>OR<sp/>PROFITS;<sp/>OR<sp/>BUSINESS<sp/>INTERRUPTION)<sp/>HOWEVER<sp/>CAUSED<sp/>AND<sp/>ON<sp/>ANY<sp/>THEORY<sp/>OF<sp/>LIABILITY,<sp/>WHETHER<sp/>IN</highlight></codeline> <codeline lineno="25"><highlight class="comment"><sp/>*<sp/>CONTRACT,<sp/>STRICT<sp/>LIABILITY,<sp/>OR<sp/>TORT<sp/>(INCLUDING<sp/>NEGLIGENCE<sp/>OR<sp/>OTHERWISE)<sp/>ARISING<sp/>IN<sp/>ANY<sp/>WAY<sp/>OUT</highlight></codeline> <codeline lineno="26"><highlight class="comment"><sp/>*<sp/>OF<sp/>THE<sp/>USE<sp/>OF<sp/>THIS<sp/>SOFTWARE,<sp/>EVEN<sp/>IF<sp/>ADVISED<sp/>OF<sp/>THE<sp/>POSSIBILITY<sp/>OF<sp/>SUCH<sp/>DAMAGE.</highlight></codeline> <codeline lineno="27"><highlight class="comment"><sp/>*/</highlight><highlight class="normal"></highlight></codeline> <codeline lineno="28"><highlight class="normal"></highlight></codeline> <codeline lineno="29"><highlight class="normal"></highlight><highlight class="preprocessor">#include<sp/><<ref refid="__null_8h" kindref="compound">sys/_null.h</ref>></highlight><highlight class="normal"></highlight></codeline> <codeline lineno="30"><highlight class="normal"></highlight><highlight class="preprocessor">#include<sp/><<ref refid="spinlock_8h" kindref="compound">ubixos/spinlock.h</ref>></highlight><highlight class="normal"></highlight></codeline> <codeline lineno="31"><highlight class="normal"></highlight><highlight class="preprocessor">#include<sp/><<ref refid="sched_8h" kindref="compound">ubixos/sched.h</ref>></highlight><highlight class="normal"></highlight></codeline> <codeline lineno="32"><highlight class="normal"></highlight><highlight class="preprocessor">#include<sp/><<ref refid="string_8h" kindref="compound">string.h</ref>></highlight><highlight class="normal"></highlight></codeline> <codeline lineno="33"><highlight class="normal"></highlight></codeline> <codeline lineno="34" refid="i386_2spinlock_8c_1a97c020c88ee892bb5a3055d5a68c9788" refkind="member"><highlight class="normal"></highlight><highlight class="preprocessor">#define<sp/>atomic_xadd(P,<sp/>V)<sp/>__sync_fetch_and_add((P),<sp/>(V))</highlight><highlight class="normal"></highlight></codeline> <codeline lineno="35" refid="i386_2spinlock_8c_1a2ecfcce98539a0b972d6fa2586c4e67f" refkind="member"><highlight class="normal"></highlight><highlight class="preprocessor">#define<sp/>cmpxchg(P,<sp/>O,<sp/>N)<sp/>__sync_val_compare_and_swap((P),<sp/>(O),<sp/>(N))</highlight><highlight class="normal"></highlight></codeline> <codeline lineno="36" refid="i386_2spinlock_8c_1a45a583ebc7ce181c15688c871f955e98" refkind="member"><highlight class="normal"></highlight><highlight class="preprocessor">#define<sp/>atomic_inc(P)<sp/>__sync_add_and_fetch((P),<sp/>1)</highlight><highlight class="normal"></highlight></codeline> <codeline lineno="37" refid="i386_2spinlock_8c_1a59c16c0e6ca2a4509a89b4095897f29f" refkind="member"><highlight class="normal"></highlight><highlight class="preprocessor">#define<sp/>atomic_dec(P)<sp/>__sync_add_and_fetch((P),<sp/>-1)</highlight><highlight class="normal"></highlight></codeline> <codeline lineno="38" refid="i386_2spinlock_8c_1a98eeefbec68bcb915a01f12e4ebdefd5" refkind="member"><highlight class="normal"></highlight><highlight class="preprocessor">#define<sp/>atomic_add(P,<sp/>V)<sp/>__sync_add_and_fetch((P),<sp/>(V))</highlight><highlight class="normal"></highlight></codeline> <codeline lineno="39" refid="i386_2spinlock_8c_1ac8aeecdc7ff00f1c46d5a91a73db87dd" refkind="member"><highlight class="normal"></highlight><highlight class="preprocessor">#define<sp/>atomic_set_bit(P,<sp/>V)<sp/>__sync_or_and_fetch((P),<sp/>1<<(V))</highlight><highlight class="normal"></highlight></codeline> <codeline lineno="40" refid="i386_2spinlock_8c_1ac3b21a79504f9ee98f451f9f7092170d" refkind="member"><highlight class="normal"></highlight><highlight class="preprocessor">#define<sp/>atomic_clear_bit(P,<sp/>V)<sp/>__sync_and_and_fetch((P),<sp/>~(1<<(V)))</highlight><highlight class="normal"></highlight></codeline> <codeline lineno="41"><highlight class="normal"></highlight></codeline> <codeline lineno="42" refid="i386_2spinlock_8c_1a53290ac2df2384738b8769c76622f803" refkind="member"><highlight class="normal"></highlight><highlight class="preprocessor">#define<sp/>barrier()<sp/>asm<sp/>volatile("":<sp/>:<sp/>:"memory")</highlight><highlight class="normal"></highlight></codeline> <codeline lineno="43"><highlight class="normal"></highlight></codeline> <codeline lineno="44"><highlight class="normal"></highlight><highlight class="comment">/*<sp/>Pause<sp/>instruction<sp/>to<sp/>prevent<sp/>excess<sp/>processor<sp/>bus<sp/>usage<sp/>*/</highlight><highlight class="normal"></highlight></codeline> <codeline lineno="45" refid="i386_2spinlock_8c_1a89af7a9ebf21399bcbd8e892b6f3d41a" refkind="member"><highlight class="normal"></highlight><highlight class="preprocessor">#define<sp/>cpu_relax()<sp/>asm<sp/>volatile("pause\n":<sp/>:<sp/>:"memory")</highlight><highlight class="normal"></highlight></codeline> <codeline lineno="46"><highlight class="normal"></highlight></codeline> <codeline lineno="47" refid="spinlock_8h_1a3ed033ffdc33d480e77190d424149415" refkind="member"><highlight class="normal"></highlight><highlight class="keywordtype">void</highlight><highlight class="normal"><sp/><ref refid="armv6_2spinlock_8c_1a2d24a3613a1841bfa55a7b235fb5d78f" kindref="member">spinLockInit</ref>(<ref refid="structspinLock" kindref="compound">spinLock_t</ref><sp/>lock)<sp/>{</highlight></codeline> <codeline lineno="48"><highlight class="normal"><sp/><sp/><ref refid="string_8h_1ace4b911463887af5e748326323e99a23" kindref="member">memset</ref>(lock,<sp/>0x0,<sp/></highlight><highlight class="keyword">sizeof</highlight><highlight class="normal">(</highlight><highlight class="keyword">struct</highlight><highlight class="normal"><sp/><ref refid="structspinLock" kindref="compound">spinLock</ref>));</highlight></codeline> <codeline lineno="49"><highlight class="normal">}</highlight></codeline> <codeline lineno="50"><highlight class="normal"></highlight></codeline> <codeline lineno="51" refid="spinlock_8h_1aed6e978dc2762fbf062e37670b8fa04d" refkind="member"><highlight class="normal"></highlight><highlight class="keywordtype">int</highlight><highlight class="normal"><sp/><ref refid="armv6_2spinlock_8c_1a740766af5da58616f700fffab6768a78" kindref="member">spinTryLock</ref>(<ref refid="structspinLock" kindref="compound">spinLock_t</ref><sp/>lock)<sp/>{</highlight></codeline> <codeline lineno="52"><highlight class="normal"><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(!<ref refid="i386_2spinlock_8c_1a2ecfcce98539a0b972d6fa2586c4e67f" kindref="member">cmpxchg</ref>(&lock-><ref refid="structspinLock_1a243edf7f3d81de2a9c7e3852768e5847" kindref="member">locked</ref>,<sp/><ref refid="fat__string_8h_1a070d2ce7b6bb7e5c05602aa8c308d0c4" kindref="member">NULL</ref>,<sp/><ref refid="spinlock_8h_1aef31df4fa10911959af449d9f3ccf78f" kindref="member">LLOCK_FLAG</ref>))</highlight></codeline> <codeline lineno="53"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/>0;</highlight></codeline> <codeline lineno="54"><highlight class="normal"></highlight></codeline> <codeline lineno="55"><highlight class="normal"><sp/><sp/></highlight><highlight class="comment">/*<sp/>Failure!<sp/>*/</highlight><highlight class="normal"></highlight></codeline> <codeline lineno="56"><highlight class="normal"><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="spinlock_8h_1a00de8f7e0b615f88335573ba3909583d" kindref="member">LOCKED</ref>;</highlight></codeline> <codeline lineno="57"><highlight class="normal">}</highlight></codeline> <codeline lineno="58"><highlight class="normal"></highlight></codeline> <codeline lineno="59" refid="spinlock_8h_1a02e11882c06e98ee0e7ff1a9b4626fb3" refkind="member"><highlight class="normal"></highlight><highlight class="keywordtype">void</highlight><highlight class="normal"><sp/><ref refid="armv6_2spinlock_8c_1ae29ab191c93f9ead066cb462dd2e7247" kindref="member">spinUnlock</ref>(<ref refid="structspinLock" kindref="compound">spinLock_t</ref><sp/>lock)<sp/>{</highlight></codeline> <codeline lineno="60"><highlight class="normal"><sp/><sp/><ref refid="i386_2spinlock_8c_1a53290ac2df2384738b8769c76622f803" kindref="member">barrier</ref>();</highlight></codeline> <codeline lineno="61"><highlight class="normal"><sp/><sp/>lock-><ref refid="structspinLock_1a243edf7f3d81de2a9c7e3852768e5847" kindref="member">locked</ref><sp/>=<sp/>0x0;</highlight></codeline> <codeline lineno="62"><highlight class="normal">}</highlight></codeline> <codeline lineno="63"><highlight class="normal"></highlight></codeline> <codeline lineno="64" refid="spinlock_8h_1a623e97c04239abcce11cdd2826525f2e" refkind="member"><highlight class="normal"></highlight><highlight class="keywordtype">void</highlight><highlight class="normal"><sp/><ref refid="armv6_2spinlock_8c_1a71f03d2ba55111c715b6068254847a53" kindref="member">spinLock</ref>(<ref refid="structspinLock" kindref="compound">spinLock_t</ref><sp/>lock)<sp/>{</highlight></codeline> <codeline lineno="65"><highlight class="normal"><sp/><sp/></highlight><highlight class="keywordflow">while</highlight><highlight class="normal"><sp/>(1)<sp/>{</highlight></codeline> <codeline lineno="66"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(!xchg_32(&lock-><ref refid="structspinLock_1a243edf7f3d81de2a9c7e3852768e5847" kindref="member">locked</ref>,<sp/><ref refid="spinlock_8h_1a00de8f7e0b615f88335573ba3909583d" kindref="member">LOCKED</ref>))</highlight></codeline> <codeline lineno="67"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal">;</highlight></codeline> <codeline lineno="68"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">while</highlight><highlight class="normal"><sp/>(lock-><ref refid="structspinLock_1a243edf7f3d81de2a9c7e3852768e5847" kindref="member">locked</ref><sp/>==<sp/>1)</highlight></codeline> <codeline lineno="69"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="armv6_2sched_8c_1a08933fe6d593a1c78b9080359f15a0b7" kindref="member">sched_yield</ref>();</highlight></codeline> <codeline lineno="70"><highlight class="normal"><sp/><sp/>}</highlight></codeline> <codeline lineno="71"><highlight class="normal">}</highlight></codeline> <codeline lineno="72"><highlight class="normal"></highlight></codeline> </programlisting> <location file="C:/Dev/git/UbixOS/sys/arch/i386/spinlock.c"/> </compounddef> </doxygen>