|
QP/C
|
00001 /***************************************************************************** 00002 * Product: QS/C 00003 * Last Updated for Version: 4.4.00 00004 * Date of the Last Update: Jan 14, 2012 00005 * 00006 * Q u a n t u m L e a P s 00007 * --------------------------- 00008 * innovating embedded systems 00009 * 00010 * Copyright (C) 2002-2012 Quantum Leaps, LLC. All rights reserved. 00011 * 00012 * This software may be distributed and modified under the terms of the GNU 00013 * General Public License version 2 (GPL) as published by the Free Software 00014 * Foundation and appearing in the file GPL.TXT included in the packaging of 00015 * this file. Please note that GPL Section 2[b] requires that all works based 00016 * on this software must also be made publicly available under the terms of 00017 * the GPL ("Copyleft"). 00018 * 00019 * Alternatively, this software may be distributed and modified under the 00020 * terms of Quantum Leaps commercial licenses, which expressly supersede 00021 * the GPL and are specifically designed for licensees interested in 00022 * retaining the proprietary status of their code. 00023 * 00024 * Contact information: 00025 * Quantum Leaps Web site: http://www.quantum-leaps.com 00026 * e-mail: info@quantum-leaps.com 00027 *****************************************************************************/ 00028 #include "qs_pkg.h" 00029 00036 /*..........................................................................*/ 00037 /* get up to *pn bytes of contiguous memory */ 00038 uint8_t const *QS_getBlock(uint16_t *pNbytes) { 00039 uint8_t *block; 00040 if (QS_used_ == (QSCtr)0) { 00041 *pNbytes = (uint16_t)0; 00042 block = (uint8_t *)0; /* no bytes to return right now */ 00043 } 00044 else { 00045 QSCtr t; 00046 QSCtr n = (QSCtr)(QS_end_ - QS_tail_); 00047 if (n > QS_used_) { 00048 n = QS_used_; 00049 } 00050 if (n > (QSCtr)(*pNbytes)) { 00051 n = (QSCtr)(*pNbytes); 00052 } 00053 *pNbytes = (uint16_t)n; 00054 QS_used_ = (QSCtr)(QS_used_ - n); 00055 t = QS_tail_; 00056 QS_tail_ = (QSCtr)(QS_tail_ + n); 00057 if (QS_tail_ == QS_end_) { 00058 QS_tail_ = (QSCtr)0; 00059 } 00060 block = &QS_PTR_AT_(t); 00061 } 00062 return block; 00063 }
1.7.6.1