cregit-Linux how code gets into the kernel

Release 4.14 arch/mips/lib/bitops.c

Directory: arch/mips/lib
/*
 * This file is subject to the terms and conditions of the GNU General Public
 * License.  See the file "COPYING" in the main directory of this archive
 * for more details.
 *
 * Copyright (c) 1994-1997, 99, 2000, 06, 07 Ralf Baechle (ralf@linux-mips.org)
 * Copyright (c) 1999, 2000  Silicon Graphics, Inc.
 */
#include <linux/bitops.h>
#include <linux/irqflags.h>
#include <linux/export.h>


/**
 * __mips_set_bit - Atomically set a bit in memory.  This is called by
 * set_bit() if it cannot find a faster solution.
 * @nr: the bit to set
 * @addr: the address to start counting from
 */

void __mips_set_bit(unsigned long nr, volatile unsigned long *addr) { unsigned long *a = (unsigned long *)addr; unsigned bit = nr & SZLONG_MASK; unsigned long mask; unsigned long flags; a += nr >> SZLONG_LOG; mask = 1UL << bit; raw_local_irq_save(flags); *a |= mask; raw_local_irq_restore(flags); }

Contributors

PersonTokensPropCommitsCommitProp
Jim Quinlan6492.75%150.00%
David Daney57.25%150.00%
Total69100.00%2100.00%

EXPORT_SYMBOL(__mips_set_bit); /** * __mips_clear_bit - Clears a bit in memory. This is called by clear_bit() if * it cannot find a faster solution. * @nr: Bit to clear * @addr: Address to start counting from */
void __mips_clear_bit(unsigned long nr, volatile unsigned long *addr) { unsigned long *a = (unsigned long *)addr; unsigned bit = nr & SZLONG_MASK; unsigned long mask; unsigned long flags; a += nr >> SZLONG_LOG; mask = 1UL << bit; raw_local_irq_save(flags); *a &= ~mask; raw_local_irq_restore(flags); }

Contributors

PersonTokensPropCommitsCommitProp
Jim Quinlan6592.86%150.00%
David Daney57.14%150.00%
Total70100.00%2100.00%

EXPORT_SYMBOL(__mips_clear_bit); /** * __mips_change_bit - Toggle a bit in memory. This is called by change_bit() * if it cannot find a faster solution. * @nr: Bit to change * @addr: Address to start counting from */
void __mips_change_bit(unsigned long nr, volatile unsigned long *addr) { unsigned long *a = (unsigned long *)addr; unsigned bit = nr & SZLONG_MASK; unsigned long mask; unsigned long flags; a += nr >> SZLONG_LOG; mask = 1UL << bit; raw_local_irq_save(flags); *a ^= mask; raw_local_irq_restore(flags); }

Contributors

PersonTokensPropCommitsCommitProp
Jim Quinlan6492.75%150.00%
David Daney57.25%150.00%
Total69100.00%2100.00%

EXPORT_SYMBOL(__mips_change_bit); /** * __mips_test_and_set_bit - Set a bit and return its old value. This is * called by test_and_set_bit() if it cannot find a faster solution. * @nr: Bit to set * @addr: Address to count from */
int __mips_test_and_set_bit(unsigned long nr, volatile unsigned long *addr) { unsigned long *a = (unsigned long *)addr; unsigned bit = nr & SZLONG_MASK; unsigned long mask; unsigned long flags; int res; a += nr >> SZLONG_LOG; mask = 1UL << bit; raw_local_irq_save(flags); res = (mask & *a) != 0; *a |= mask; raw_local_irq_restore(flags); return res; }

Contributors

PersonTokensPropCommitsCommitProp
Jim Quinlan7890.70%133.33%
David Daney89.30%266.67%
Total86100.00%3100.00%

EXPORT_SYMBOL(__mips_test_and_set_bit); /** * __mips_test_and_set_bit_lock - Set a bit and return its old value. This is * called by test_and_set_bit_lock() if it cannot find a faster solution. * @nr: Bit to set * @addr: Address to count from */
int __mips_test_and_set_bit_lock(unsigned long nr, volatile unsigned long *addr) { unsigned long *a = (unsigned long *)addr; unsigned bit = nr & SZLONG_MASK; unsigned long mask; unsigned long flags; int res; a += nr >> SZLONG_LOG; mask = 1UL << bit; raw_local_irq_save(flags); res = (mask & *a) != 0; *a |= mask; raw_local_irq_restore(flags); return res; }

Contributors

PersonTokensPropCommitsCommitProp
Jim Quinlan7890.70%133.33%
David Daney89.30%266.67%
Total86100.00%3100.00%

EXPORT_SYMBOL(__mips_test_and_set_bit_lock); /** * __mips_test_and_clear_bit - Clear a bit and return its old value. This is * called by test_and_clear_bit() if it cannot find a faster solution. * @nr: Bit to clear * @addr: Address to count from */
int __mips_test_and_clear_bit(unsigned long nr, volatile unsigned long *addr) { unsigned long *a = (unsigned long *)addr; unsigned bit = nr & SZLONG_MASK; unsigned long mask; unsigned long flags; int res; a += nr >> SZLONG_LOG; mask = 1UL << bit; raw_local_irq_save(flags); res = (mask & *a) != 0; *a &= ~mask; raw_local_irq_restore(flags); return res; }

Contributors

PersonTokensPropCommitsCommitProp
Jim Quinlan7990.80%133.33%
David Daney89.20%266.67%
Total87100.00%3100.00%

EXPORT_SYMBOL(__mips_test_and_clear_bit); /** * __mips_test_and_change_bit - Change a bit and return its old value. This is * called by test_and_change_bit() if it cannot find a faster solution. * @nr: Bit to change * @addr: Address to count from */
int __mips_test_and_change_bit(unsigned long nr, volatile unsigned long *addr) { unsigned long *a = (unsigned long *)addr; unsigned bit = nr & SZLONG_MASK; unsigned long mask; unsigned long flags; int res; a += nr >> SZLONG_LOG; mask = 1UL << bit; raw_local_irq_save(flags); res = (mask & *a) != 0; *a ^= mask; raw_local_irq_restore(flags); return res; }

Contributors

PersonTokensPropCommitsCommitProp
Jim Quinlan7890.70%133.33%
David Daney89.30%266.67%
Total86100.00%3100.00%

EXPORT_SYMBOL(__mips_test_and_change_bit);

Overall Contributors

PersonTokensPropCommitsCommitProp
Jim Quinlan55691.90%125.00%
David Daney477.77%250.00%
Ralf Bächle20.33%125.00%
Total605100.00%4100.00%
Directory: arch/mips/lib
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.